/* ============================================================
   Harrison Design — site stylesheet (dark, Espresso-led)
   Stone & Linen brand system
   ============================================================ */
:root{
  /* brand */
  --espresso:#2A2420;
  --bark:#4A4038;
  --stone:#8A7E70;
  --linen:#F3EFE7;
  --paper:#FBF9F4;
  --pine:#3D4A40;

  /* dark-theme semantics */
  --back:#15110E;
  --sheet:#221C18;
  --surface:#2C2520;
  --surface-2:#332B25;
  --ink:#F3EFE7;
  --ink-body:#D9D1C6;
  --ink-mute:#9E9284;
  --pine-lt:#86A48F;
  --rust-lt:#C28B79;
  --hair:rgba(201,190,175,.18);
  --hair-soft:rgba(201,190,175,.10);

  /* type */
  --display:"Libre Caslon Display", Georgia, serif;
  --serif:"Libre Caslon Text", Georgia, serif;
  --sans:"Hanken Grotesk", system-ui, sans-serif;
  --mono:"IBM Plex Mono", ui-monospace, monospace;

  /* tweakable */
  --fs:1;                 /* font scale multiplier */
  --accent:#86A48F;       /* lifted pine — accents/links/lines readable on dark */
  --accent-fill:#3D4A40;  /* TRUE brand Pine — solid button/CTA fills (light text) */

  --maxw:1240px;
  --gutter:clamp(22px,5vw,72px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
html,body{ margin:0; padding:0; }
body{
  background:var(--back);
  font-family:var(--sans);
  color:var(--ink-body);
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* ---------- shared atoms ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
.meta{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-mute); font-weight:400;
}
.idx{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; color:var(--accent); }
.hair{ height:1px; background:var(--hair); border:0; margin:0; }

.eyebrow{
  display:flex; align-items:center; gap:16px; margin-bottom:30px;
}
.eyebrow .ln{ flex:1; height:1px; background:var(--hair); }
.eyebrow .label{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.24em;
  text-transform:uppercase; color:var(--ink-body);
}

h1,h2,h3,h4{ font-weight:400; color:var(--ink); margin:0; }
.display{ font-family:var(--display); line-height:.98; letter-spacing:.005em; color:var(--ink); }
.serif{ font-family:var(--serif); }
.italic{ font-family:var(--serif); font-style:italic; }

.lead{
  font-family:var(--serif); font-size:calc(22px * var(--fs)); line-height:1.5;
  color:var(--ink-body); text-wrap:pretty;
}
.lead em{ color:var(--ink); font-style:italic; }

section{ padding-block:clamp(60px,9vw,118px); }

/* ---------- HD monogram (injected by site.js) ---------- */
.hdmark{ display:flex; flex-direction:column; align-items:center; gap:5px; flex:none; }
.hdmark .roof{ overflow:visible; display:block; }
.hdmark .roof polyline{ fill:none; stroke:var(--ink); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; vector-effect:non-scaling-stroke; }
.hdmark .roof .ring{ fill:none; stroke:var(--ink); stroke-width:1.6; vector-effect:non-scaling-stroke; }
.hdmark .roof .core{ fill:var(--ink); stroke:none; }
.hdmark .hd{ font-family:var(--display); line-height:.78; letter-spacing:.02em; color:var(--ink); }

/* ---------- top bar ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(21,17,14,.72);
  backdrop-filter:blur(14px) saturate(1.1);
  border-bottom:1px solid var(--hair-soft);
}
.nav .row{
  display:flex; align-items:center; justify-content:space-between;
  height:74px; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter);
}
.brand{ display:flex; align-items:center; gap:14px; }
.brand .hdmark .roof{ width:42px; height:13px; }
.brand .hdmark .hd{ font-size:25px; }
.brand .bwm{ display:block; white-space:nowrap; font-family:var(--display); font-size:21px; color:var(--ink); line-height:1; }
.brand .bsub{ display:block; white-space:nowrap; font-family:var(--mono); font-size:8px; letter-spacing:.2em; color:var(--ink-mute); margin-top:4px; }

.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{ white-space:nowrap; }
.nav-links a{
  font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-mute); transition:color .2s; position:relative; padding-block:6px;
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a.active{ color:var(--ink); }
.nav-links a.active::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:1px; background:var(--accent);
}
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--linen); background:var(--accent-fill);
  padding:12px 20px; border:1px solid var(--accent-fill); cursor:pointer;
  white-space:nowrap;
  transition:background .2s, color .2s, border-color .2s;
}
.btn:hover{ background:transparent; color:var(--accent); border-color:var(--accent); }
.btn.ghost{ background:transparent; color:var(--ink); border-color:var(--hair); }
.btn.ghost:hover{ border-color:var(--accent); color:var(--accent); }
.btn .arrow{ font-family:var(--serif); }
/* nav CTA: out-specify .nav-links a so the label stays crisp Linen on the Pine fill */
.nav-links a.btn{ color:var(--linen); }
.nav-links a.btn:hover{ color:var(--accent); }

.nav-toggle{ display:none; }

/* ---------- footer ---------- */
.foot{ background:var(--sheet); border-top:1px solid var(--hair); padding-block:64px 40px; }
.foot .grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; align-items:start; }
.foot .lock .bwm{ font-family:var(--display); font-size:30px; color:var(--ink); }
.foot .lock .bsub{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; color:var(--ink-mute); margin-top:10px; }
.foot .tag{ font-family:var(--serif); font-style:italic; font-size:19px; color:var(--ink-body); margin-top:22px; }
.foot .col h5{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--accent); margin:0 0 16px; font-weight:500; }
.foot .col a, .foot .col p{ display:block; font-size:14px; color:var(--ink-body); margin:0 0 10px; transition:color .2s; }
.foot .col a:hover{ color:var(--ink); }
.foot .bottom{ display:flex; justify-content:space-between; align-items:center; margin-top:54px; padding-top:24px; border-top:1px solid var(--hair-soft); }

/* ---------- image slot styling ---------- */
image-slot{
  --slot-bg:var(--surface);
  background:
    repeating-linear-gradient(135deg, rgba(201,190,175,.05) 0 12px, rgba(201,190,175,.015) 12px 24px),
    var(--surface);
  border:1px solid var(--hair);
}

/* ---------- service / card grids ---------- */
.cards{ display:grid; gap:1px; background:var(--hair-soft); border:1px solid var(--hair-soft); }
.card{
  background:var(--sheet); padding:38px 36px 40px; position:relative;
  transition:background .25s;
}
.card:hover{ background:var(--surface); }
.card .cnum{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; color:var(--accent); }
.card h3{ font-family:var(--display); font-size:calc(27px * var(--fs)); color:var(--ink); margin:18px 0 12px; line-height:1.05; }
.card p{ font-size:14.5px; color:var(--ink-mute); margin:0; }

/* ---------- utility ---------- */
.cta-band{ background:var(--espresso); }
.center{ text-align:center; }
.mt-s{ margin-top:18px; } .mt-m{ margin-top:34px; } .mt-l{ margin-top:54px; }

/* ---------- responsive ---------- */
@media (max-width:980px){
  .nav-links{
    position:fixed; inset:74px 0 auto 0; flex-direction:column; gap:0;
    background:var(--sheet); border-bottom:1px solid var(--hair);
    padding:8px 0; transform:translateY(-130%); transition:transform .3s; align-items:stretch;
  }
  .nav-links.open{ transform:translateY(0); }
  .nav-links a{ padding:16px var(--gutter); border-top:1px solid var(--hair-soft); }
  .nav-links a:first-child{ border-top:0; }
  .nav-links a.active::after{ display:none; }
  .nav-links .btn{ margin:12px var(--gutter); justify-content:center; }
  .nav-toggle{
    display:flex; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px;
  }
  .nav-toggle span{ width:24px; height:1.5px; background:var(--ink); display:block; }
  .foot .grid{ grid-template-columns:1fr; gap:34px; }
  .foot .bottom{ flex-direction:column; gap:14px; align-items:flex-start; }
}

/* Studio sign-in (footer) — discreet link to the private /admin area */
.foot .studio-signin{ display:inline-flex; align-items:center; gap:7px; padding:7px 13px;
  border:1px solid var(--hair); border-radius:3px; color:var(--ink-mute); text-decoration:none;
  font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  transition:border-color .15s, color .15s; }
.foot .studio-signin:hover{ color:var(--accent); border-color:var(--accent); }
