/* =====================================================================
   12/12 ARCHITECTS & PLANNERS
   Premium design system  ·  Cormorant Garamond + Montserrat
   Brand palette: forest green, warm bronze/gold, cream, charcoal
   Built for luxury feel and high readability (50+ friendly)
   ===================================================================== */

/* ---------- Design tokens ---------- */
:root{
  /* greens */
  --green:        #437530;
  --green-600:    #4f8338;
  --green-700:    #3a6429;
  --green-800:    #2f5221;
  --green-900:    #233f18;
  --green-soft:   #6c9a59;

  /* golds / bronze */
  --gold:         #bc915f;
  --gold-deep:    #a87c49;
  --gold-soft:    #d4b187;
  --gold-pale:    #ead9c2;

  /* neutrals */
  --cream:        #f6f3eb;
  --cream-2:      #efeadd;
  --cream-3:      #e7e0d0;
  --warm-white:   #fcfaf5;
  --ink:          #29271f;   /* primary text - strong charcoal */
  --ink-2:        #4e4b42;   /* secondary text */
  --ink-3:        #726e62;   /* muted */
  --white:        #ffffff;

  /* lines */
  --line:         rgba(41,39,31,.14);
  --line-soft:    rgba(41,39,31,.08);
  --gold-line:    rgba(188,145,95,.45);

  /* type */
  --font-display: "Cormorant Garamond", "Times New Roman", Georgia, serif;
  --font-body:    "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  /* rhythm */
  --container:    1240px;
  --container-wide:1480px;
  --gutter:       clamp(20px, 5vw, 64px);
  --section-y:    clamp(64px, 9vw, 140px);
  --radius:       4px;
  --radius-lg:    10px;

  /* shadows */
  --shadow-sm:    0 6px 22px rgba(35,30,18,.08);
  --shadow-md:    0 18px 50px rgba(35,30,18,.12);
  --shadow-lg:    0 34px 80px rgba(35,30,18,.18);

  /* motion */
  --ease:         cubic-bezier(.22,.61,.36,1);
  --ease-out:     cubic-bezier(.16,1,.3,1);

  --header-h:     92px;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--font-body);
  font-size:clamp(1.0625rem, .6rem + .55vw, 1.18rem); /* generous, readable */
  line-height:1.78;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
ul{ margin:0; padding:0; list-style:none; }
::selection{ background:var(--green); color:var(--cream); }

/* ---------- Typography ---------- */
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.08;
  letter-spacing:.004em;
  color:var(--ink);
  margin:0 0 .5em;
}
.display{
  font-size:clamp(2.7rem, 1.4rem + 5.4vw, 5.4rem);
  font-weight:600;
  line-height:1.02;
  letter-spacing:.005em;
}
h1{ font-size:clamp(2.4rem, 1.4rem + 4.2vw, 4.2rem); }
h2{ font-size:clamp(2.05rem, 1.3rem + 2.9vw, 3.35rem); }
h3{ font-size:clamp(1.55rem, 1.15rem + 1.5vw, 2.2rem); }
h4{ font-size:clamp(1.3rem, 1.1rem + .8vw, 1.7rem); }
p{ margin:0 0 1.15em; }
p:last-child{ margin-bottom:0; }

.lead{
  font-size:clamp(1.18rem, .9rem + .8vw, 1.4rem);
  line-height:1.7;
  color:var(--ink-2);
}
strong,b{ font-weight:600; color:var(--ink); }
em{ font-style:italic; }

/* eyebrow / kicker */
.eyebrow{
  font-family:var(--font-body);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex;
  align-items:center;
  gap:.85em;
  margin:0 0 1.1rem;
}
.eyebrow::before{
  content:""; width:34px; height:1px; background:var(--gold); display:inline-block;
}
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{
  content:""; width:34px; height:1px; background:var(--gold); display:inline-block;
}
.eyebrow.light{ color:var(--gold-soft); }

.serif-accent{ font-family:var(--font-display); font-style:italic; color:var(--green); }

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.container.wide{ max-width:var(--container-wide); }
.container.narrow{ max-width:880px; }
.section{ padding-block:var(--section-y); position:relative; }
.section.tight{ padding-block:clamp(48px,6vw,90px); }
.bg-cream{ background:var(--cream); }
.bg-cream2{ background:var(--cream-2); }
.bg-white{ background:var(--warm-white); }
.bg-green{ background:var(--green-800); color:var(--cream); }
.bg-green h1,.bg-green h2,.bg-green h3,.bg-green h4{ color:var(--warm-white); }
.bg-ink{ background:#211f19; color:var(--cream); }
.text-center{ text-align:center; }
.mx-auto{ margin-inline:auto; }
.maxw-720{ max-width:720px; }
.maxw-820{ max-width:820px; }

.grid{ display:grid; gap:clamp(22px,3vw,40px); }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
.split{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(36px,5vw,84px); align-items:center; }
.split.reverse > :first-child{ order:2; }

/* decorative hairline + mark */
.rule{ height:1px; background:var(--line); border:0; margin:0; }
.gold-mark{ color:var(--gold); font-size:1.1rem; letter-spacing:.4em; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--green); --fg:var(--cream); --bd:var(--green);
  display:inline-flex; align-items:center; justify-content:center; gap:.7em;
  font-family:var(--font-body); font-size:.82rem; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase;
  padding:1.05em 2.2em; border:1px solid var(--bd); border-radius:var(--radius);
  background:var(--bg); color:var(--fg); cursor:pointer;
  position:relative; overflow:hidden; isolation:isolate;
  transition:color .45s var(--ease), border-color .45s var(--ease), transform .35s var(--ease);
  will-change:transform;
}
.btn::after{
  content:""; position:absolute; inset:0; z-index:-1; background:var(--gold);
  transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease-out);
}
.btn:hover{ color:#fff; border-color:var(--gold); transform:translateY(-2px); }
.btn:hover::after{ transform:scaleX(1); }
.btn:focus-visible{ outline:2px solid var(--gold-deep); outline-offset:3px; }

.btn-outline{ --bg:transparent; --fg:var(--green-800); --bd:rgba(41,39,31,.32); }
.btn-outline:hover{ --fg:#fff; }
.btn-gold{ --bg:var(--gold); --bd:var(--gold); --fg:#fff; }
.btn-gold::after{ background:var(--green); }
.btn-light{ --bg:transparent; --fg:var(--cream); --bd:rgba(246,243,235,.4); }
.btn-light::after{ background:var(--cream); }
.btn-light:hover{ --fg:var(--green-900); }
.btn-cream{ --bg:var(--cream); --fg:var(--green-900); --bd:var(--cream); }
.btn-cream::after{ background:var(--gold); }
.btn-cream:hover{ --fg:#fff; }
.btn.sm{ padding:.8em 1.5em; font-size:.74rem; }
.btn.block{ display:flex; width:100%; }

/* text link with arrow */
.link-arrow{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--font-body); font-weight:600; font-size:.82rem;
  letter-spacing:.16em; text-transform:uppercase; color:var(--green-700);
  transition:gap .35s var(--ease), color .35s var(--ease);
}
.link-arrow svg{ width:20px; transition:transform .4s var(--ease); }
.link-arrow:hover{ color:var(--gold-deep); gap:.95em; }
.link-arrow.light{ color:var(--gold-soft); }
.link-arrow.light:hover{ color:#fff; }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:1000;
  height:var(--header-h);
  display:flex; align-items:center;
  transition:background .5s var(--ease), box-shadow .5s var(--ease), height .45s var(--ease), border-color .5s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header .container{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.site-header.solid{
  background:rgba(246,243,235,.92);
  backdrop-filter:saturate(140%) blur(14px);
  box-shadow:0 8px 30px rgba(35,30,18,.07);
  border-bottom-color:var(--line-soft);
  height:74px;
}
.brand{ display:flex; align-items:center; gap:14px; flex:0 0 auto; z-index:2; }
.brand img{ height:50px; width:auto; transition:height .45s var(--ease); }
.site-header.solid .brand img{ height:44px; }

/* primary nav */
.nav{ display:flex; align-items:center; gap:clamp(10px,1.05vw,22px); }
.nav-item{ position:relative; }
.nav-link{
  display:inline-flex; align-items:center; gap:.35em;
  font-family:var(--font-body); font-size:.74rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:var(--ink);
  padding:10px 1px; position:relative; white-space:nowrap;
  transition:color .35s var(--ease);
}
.nav-link .chev{ width:9px; height:9px; opacity:.55; transition:transform .35s var(--ease); }
.nav-link::after{
  content:""; position:absolute; left:0; bottom:2px; height:1.5px; width:100%;
  background:var(--gold); transform:scaleX(0); transform-origin:left;
  transition:transform .4s var(--ease-out);
}
.nav-link:hover{ color:var(--green-700); }
.nav-link:hover::after,.nav-item.active > .nav-link::after{ transform:scaleX(1); }
.nav-item.has-menu:hover .chev{ transform:rotate(180deg); }

/* dropdown */
.dropdown{
  position:absolute; top:calc(100% + 14px); left:50%; transform:translate(-50%,12px);
  min-width:300px; background:var(--warm-white); border:1px solid var(--line-soft);
  border-top:2px solid var(--gold);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-md); padding:14px;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .35s var(--ease), transform .4s var(--ease), visibility .35s;
}
.nav-item.has-menu:hover .dropdown,
.nav-item.has-menu:focus-within .dropdown{
  opacity:1; visibility:visible; pointer-events:auto; transform:translate(-50%,0);
}
.dropdown::before{
  content:""; position:absolute; top:-9px; left:0; right:0; height:14px;
}
.dropdown a{
  display:block; padding:11px 16px; border-radius:var(--radius);
  font-size:.88rem; font-family:var(--font-body); font-weight:600; color:var(--ink);
  letter-spacing:.01em; line-height:1.3; transition:background .3s var(--ease), color .3s var(--ease), padding-left .3s var(--ease);
}
.dropdown a small{ display:block; font-family:var(--font-body); font-weight:400; font-size:.72rem; letter-spacing:.04em; text-transform:none; color:var(--ink-3); margin-top:2px; }
.dropdown a:hover{ background:var(--cream); color:var(--green-700); padding-left:22px; }

.header-cta{ display:flex; align-items:center; gap:14px; flex:0 0 auto; }
.header-phone{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--font-body); font-weight:600; font-size:.82rem; letter-spacing:.05em;
  color:var(--green-800);
}
.header-phone svg{ width:16px; color:var(--gold-deep); }
.header-phone:hover{ color:var(--gold-deep); }

/* --- header contrast over the hero (transparent) vs scrolled (solid) --- */
.site-header:not(.solid) .nav-link{ color:#fff; text-shadow:0 1px 12px rgba(10,16,6,.45); }
.site-header:not(.solid) .nav-link:hover{ color:var(--gold-soft); }
.site-header:not(.solid) .nav-link::after{ background:var(--gold-soft); }
.site-header:not(.solid) .header-phone{ color:#fff; text-shadow:0 1px 12px rgba(10,16,6,.45); }
.site-header:not(.solid) .header-phone svg{ color:var(--gold-soft); }
.site-header:not(.solid) .brand img{ filter:brightness(0) invert(1) drop-shadow(0 1px 10px rgba(10,16,6,.35)); }
.site-header:not(.solid) .burger{ border-color:rgba(255,255,255,.55); }
.site-header:not(.solid) .burger span,
.site-header:not(.solid) .burger span::before,
.site-header:not(.solid) .burger span::after{ background:#fff; }
.brand img{ transition:height .45s var(--ease), filter .45s var(--ease); }
/* explicit solid (scrolled) state: dark, high-contrast */
.site-header.solid .nav-link{ color:var(--ink); text-shadow:none; }
.site-header.solid .nav-link:hover{ color:var(--green-700); }
.site-header.solid .header-phone{ color:var(--green-800); text-shadow:none; }
.site-header.solid .brand img{ filter:none; }
.site-header.solid .burger span,
.site-header.solid .burger span::before,
.site-header.solid .burger span::after{ background:var(--ink); }

/* burger */
.burger{ display:none; width:44px; height:44px; border:1px solid var(--line); border-radius:var(--radius);
  background:transparent; cursor:pointer; padding:0; align-items:center; justify-content:center; z-index:1100; }
.burger span{ display:block; width:20px; height:1.6px; background:var(--ink); position:relative; transition:.35s var(--ease); }
.burger span::before,.burger span::after{ content:""; position:absolute; left:0; width:20px; height:1.6px; background:var(--ink); transition:.35s var(--ease); }
.burger span::before{ top:-6px; } .burger span::after{ top:6px; }
.burger.open span{ background:transparent; }
.burger.open span::before{ top:0; transform:rotate(45deg); }
.burger.open span::after{ top:0; transform:rotate(-45deg); }

/* mobile menu */
.mobile-nav{
  position:fixed; inset:0; z-index:1050; background:var(--cream);
  transform:translateX(100%); transition:transform .5s var(--ease);
  display:flex; flex-direction:column; padding:96px var(--gutter) 40px; overflow-y:auto;
}
.mobile-nav.open{ transform:translateX(0); }
.mobile-nav a{ font-family:var(--font-display); font-size:1.5rem; font-weight:600; color:var(--ink); padding:11px 0; border-bottom:1px solid var(--line-soft); }
.mobile-nav .m-group > button{
  width:100%; text-align:left; background:none; border:0; border-bottom:1px solid var(--line-soft);
  font-family:var(--font-display); font-size:1.5rem; font-weight:600; color:var(--ink); padding:11px 0; cursor:pointer;
  display:flex; justify-content:space-between; align-items:center;
}
.mobile-nav .m-sub{ max-height:0; overflow:hidden; transition:max-height .45s var(--ease); padding-left:16px; }
.mobile-nav .m-group.open .m-sub{ max-height:600px; }
.mobile-nav .m-sub a{ font-size:1.08rem; color:var(--ink-2); border-bottom:1px dashed var(--line-soft); }
.mobile-nav .m-cta{ margin-top:28px; display:grid; gap:14px; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:flex-end;
  color:var(--cream); overflow:hidden; isolation:isolate;
}
.hero-media{ position:absolute; inset:0; z-index:-2; }
.hero-media img{ width:100%; height:100%; object-fit:cover; }
.hero::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(20,30,12,.52) 0%, rgba(20,30,12,.20) 34%, rgba(16,24,9,.84) 100%);
}
.hero-inner{ padding-bottom:clamp(70px,11vh,150px); padding-top:160px; max-width:920px; }
.hero .eyebrow{ color:var(--gold-soft); }
.hero .eyebrow::before{ background:var(--gold-soft); }
.hero h1{ color:var(--warm-white); margin-bottom:.3em; }
.hero .lead{ color:rgba(246,243,235,.92); max-width:640px; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:16px; margin-top:36px; }
.hero-scroll{
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  font-size:.66rem; letter-spacing:.28em; text-transform:uppercase; color:rgba(246,243,235,.75);
}
.hero-scroll .dot{ width:1px; height:54px; background:linear-gradient(var(--gold-soft),transparent); position:relative; overflow:hidden; }
.hero-scroll .dot::after{ content:""; position:absolute; top:-30%; left:0; width:1px; height:30%; background:var(--cream); animation:scrolldot 2.2s var(--ease) infinite; }
@keyframes scrolldot{ to{ top:120%; } }

/* page hero (interior pages) */
.page-hero{
  position:relative; padding:calc(var(--header-h) + clamp(56px,9vw,120px)) 0 clamp(56px,8vw,110px);
  color:var(--cream); overflow:hidden; isolation:isolate; text-align:center;
}
.page-hero.has-img::before{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg,rgba(25,36,16,.62),rgba(20,30,12,.82)); }
.page-hero-media{ position:absolute; inset:0; z-index:-2; }
.page-hero-media img{ width:100%; height:100%; object-fit:cover; }
.page-hero.solid{ background:linear-gradient(160deg,var(--green-800),var(--green-900)); }
.page-hero h1{ color:var(--warm-white); max-width:16ch; margin-inline:auto; }
.page-hero .lead{ color:rgba(246,243,235,.9); max-width:760px; margin-inline:auto; }
.breadcrumb{ display:flex; gap:.6em; justify-content:center; align-items:center; flex-wrap:wrap;
  font-family:var(--font-body); font-size:.73rem; letter-spacing:.16em; text-transform:uppercase;
  color:rgba(246,243,235,.7); margin-bottom:22px; }
.breadcrumb a:hover{ color:var(--gold-soft); }
.breadcrumb .sep{ color:var(--gold-soft); }

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.sec-head{ max-width:760px; }
.sec-head.center{ margin-inline:auto; text-align:center; }
.sec-head p{ color:var(--ink-2); margin-top:.6em; }

/* ============================================================
   SPLIT / FEATURE BLOCKS
   ============================================================ */
.media-frame{ position:relative; }
.media-frame img{ width:100%; border-radius:var(--radius-lg); box-shadow:var(--shadow-md); }
.media-frame.bordered::after{
  content:""; position:absolute; inset:18px -18px -18px 18px; border:1px solid var(--gold-line);
  border-radius:var(--radius-lg); z-index:-1;
}
.media-frame .tag-badge{
  position:absolute; left:-14px; bottom:26px; background:var(--green-800); color:var(--cream);
  padding:16px 22px; border-radius:var(--radius); box-shadow:var(--shadow-md); max-width:230px;
}
.media-frame .tag-badge .n{ font-family:var(--font-display); font-size:2.4rem; line-height:1; color:var(--gold-soft); }
.media-frame .tag-badge .t{ font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; margin-top:6px; color:rgba(246,243,235,.85); }

/* budget / pill list */
.pill-list{ display:grid; gap:14px; margin:26px 0; }
.pill-row{
  display:flex; align-items:baseline; justify-content:space-between; gap:18px;
  padding:16px 22px; background:var(--warm-white); border:1px solid var(--line-soft);
  border-left:3px solid var(--gold); border-radius:var(--radius); box-shadow:var(--shadow-sm);
}
.pill-row .label{ font-family:var(--font-display); font-size:1.32rem; font-weight:600; color:var(--ink); }
.pill-row .val{ font-family:var(--font-body); font-weight:700; font-size:.82rem; letter-spacing:.08em; color:var(--green-700); white-space:nowrap; text-transform:uppercase; }

/* check list */
.check-list{ display:grid; gap:14px; margin:22px 0; }
.check-list li{ display:flex; gap:14px; align-items:flex-start; line-height:1.65; }
.check-list .ic{ flex:0 0 auto; width:26px; height:26px; border-radius:50%; background:var(--green); color:#fff; display:grid; place-items:center; margin-top:3px; }
.check-list .ic svg{ width:13px; }
.check-list b{ color:var(--ink); }

/* ============================================================
   STAT STRIP
   ============================================================ */
.stat-strip{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--gold-line); border:1px solid var(--gold-line); border-radius:var(--radius-lg); overflow:hidden; }
.stat{ background:var(--warm-white); padding:34px 22px; text-align:center; }
.bg-green .stat{ background:transparent; }
.stat .num{ font-family:var(--font-display); font-weight:600; font-size:clamp(2.4rem,1.4rem+2.6vw,3.6rem); line-height:1; color:var(--green-700); }
.bg-green .stat .num{ color:var(--gold-soft); }
.stat .lbl{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); margin-top:10px; }
.bg-green .stat .lbl{ color:rgba(246,243,235,.78); }

/* ============================================================
   PORTFOLIO CARDS
   ============================================================ */
.cards{ display:grid; gap:clamp(20px,2.4vw,34px); }
.cards.c2{ grid-template-columns:repeat(2,1fr); }
.cards.c3{ grid-template-columns:repeat(3,1fr); }
.cards.c4{ grid-template-columns:repeat(4,1fr); }

.work-card{
  position:relative; display:block; border-radius:var(--radius-lg); overflow:hidden;
  background:var(--ink); box-shadow:var(--shadow-sm);
  transition:transform .55s var(--ease-out), box-shadow .55s var(--ease-out);
}
.work-card .img-wrap{ position:relative; aspect-ratio:364/462; overflow:hidden; }
.work-card img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease-out); }
.work-card::after{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(20,28,12,0) 38%, rgba(18,26,10,.86) 100%);
  transition:opacity .5s var(--ease);
}
.work-card .meta{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:26px 24px; color:var(--cream); transform:translateY(8px); transition:transform .55s var(--ease-out); }
.work-card .meta .cat{ font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-soft); display:block; margin-bottom:8px; }
.work-card .meta h3{ color:var(--warm-white); font-size:1.5rem; margin:0; line-height:1.12; }
.work-card .meta .more{ display:inline-flex; align-items:center; gap:.5em; margin-top:12px; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--cream);
  opacity:0; transform:translateY(8px); transition:opacity .5s var(--ease), transform .5s var(--ease); }
.work-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.work-card:hover img{ transform:scale(1.07); }
.work-card:hover .meta{ transform:translateY(0); }
.work-card:hover .meta .more{ opacity:1; transform:translateY(0); }

/* category explore card (homepage) */
.cat-card{ position:relative; display:block; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:1/1.18; box-shadow:var(--shadow-sm); }
.cat-card img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease-out); }
.cat-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,28,12,.05),rgba(18,26,10,.78)); transition:background .5s; }
.cat-card .lbl{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:26px; color:var(--cream); }
.cat-card .lbl h3{ color:#fff; margin:0 0 .2em; font-size:1.7rem; }
.cat-card .lbl .more{ font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-soft); display:inline-flex; gap:.5em; align-items:center; }
.cat-card:hover img{ transform:scale(1.06); }

/* ============================================================
   SERVICE CARDS
   ============================================================ */
.svc-card{
  background:var(--warm-white); border:1px solid var(--line-soft); border-radius:var(--radius-lg);
  padding:34px 30px; box-shadow:var(--shadow-sm); height:100%;
  transition:transform .5s var(--ease-out), box-shadow .5s var(--ease-out), border-color .5s;
}
.svc-card .ic{ width:56px; height:56px; border-radius:50%; display:grid; place-items:center; background:var(--cream); border:1px solid var(--gold-line); margin-bottom:20px; }
.svc-card .ic svg{ width:26px; color:var(--green-700); }
.svc-card h3{ font-size:1.5rem; margin-bottom:.35em; }
.svc-card p{ color:var(--ink-2); font-size:1rem; }
.svc-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:var(--gold-line); }

/* small icon-link list (services nav block) */
.svc-links{ display:grid; gap:0; border-top:1px solid var(--line); }
.svc-links a{ display:flex; justify-content:space-between; align-items:center; gap:18px; padding:20px 4px; border-bottom:1px solid var(--line);
  font-family:var(--font-display); font-size:1.35rem; font-weight:600; color:var(--ink); transition:color .35s, padding-left .35s; }
.svc-links a:hover{ color:var(--green-700); padding-left:10px; }
.svc-links a svg{ width:22px; color:var(--gold-deep); flex:0 0 auto; }

/* ============================================================
   PROCESS
   ============================================================ */
.proc-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:clamp(14px,1.6vw,26px); counter-reset:step; }
.proc-step{ position:relative; text-align:center; padding-top:14px; }
.proc-step .ic{ width:78px; height:78px; margin:0 auto 18px; border-radius:50%; background:var(--warm-white); border:1px solid var(--gold-line);
  display:grid; place-items:center; box-shadow:var(--shadow-sm); position:relative; z-index:2; }
.proc-step .ic img{ width:38px; height:38px; }
.proc-step .num{ font-family:var(--font-display); font-size:1.1rem; color:var(--gold-deep); font-weight:600; letter-spacing:.1em; }
.proc-step h4{ font-family:var(--font-body); font-weight:600; font-size:1rem; line-height:1.4; letter-spacing:.005em; margin-top:8px; }
.proc-line{ position:absolute; top:52px; left:10%; right:10%; height:1px; background:var(--gold-line); z-index:1; }
@media (max-width:860px){ .proc-line{ display:none; } }

/* detailed numbered process (process page) */
.proc-rows{ display:grid; gap:clamp(34px,5vw,76px); }
.proc-row{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,72px); align-items:center; }
.proc-row:nth-child(even) .proc-row-media{ order:2; }
.proc-row-media img{ border-radius:var(--radius-lg); box-shadow:var(--shadow-md); width:100%; }
.proc-row .step-num{ font-family:var(--font-display); font-size:clamp(3rem,2rem+3vw,5rem); line-height:.8; color:var(--gold); opacity:.55; display:block; margin-bottom:14px; }
.proc-row h3{ margin-bottom:.4em; }
.proc-row p{ color:var(--ink-2); }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi{ position:relative; }
.testi-track{ display:flex; gap:28px; overflow-x:auto; scroll-snap-type:x mandatory; padding:10px 4px 28px; scrollbar-width:none; }
.testi-track::-webkit-scrollbar{ display:none; }
.testi-card{
  scroll-snap-align:center; flex:0 0 min(560px,86%); background:var(--warm-white);
  border:1px solid var(--line-soft); border-radius:var(--radius-lg); padding:40px 38px;
  box-shadow:var(--shadow-sm); display:flex; flex-direction:column; gap:18px;
}
.bg-green .testi-card{ background:rgba(255,255,255,.04); border-color:rgba(246,243,235,.14); color:var(--cream); }
.testi-card .quote-mark{ font-family:var(--font-display); font-size:3.4rem; line-height:.4; color:var(--gold); height:30px; }
.testi-card .stars{ color:var(--gold); letter-spacing:.18em; font-size:.95rem; }
.testi-card blockquote{ margin:0; font-family:var(--font-body); font-size:1.06rem; line-height:1.72; color:var(--ink); font-weight:400; }
.bg-green .testi-card blockquote{ color:var(--warm-white); }
.testi-card .who{ display:flex; align-items:center; gap:14px; margin-top:auto; padding-top:8px; }
.testi-card .who .av{ width:48px; height:48px; border-radius:50%; background:var(--green); color:var(--cream); display:grid; place-items:center; font-family:var(--font-display); font-size:1.3rem; font-weight:600; flex:0 0 auto; }
.testi-card .who .nm{ font-family:var(--font-body); font-weight:600; font-size:.95rem; color:var(--ink); letter-spacing:.02em; }
.bg-green .testi-card .who .nm{ color:#fff; }
.testi-card .who .src{ font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.bg-green .testi-card .who .src{ color:var(--gold-soft); }
.testi-nav{ display:flex; gap:12px; justify-content:center; margin-top:18px; }
.testi-nav button{ width:50px; height:50px; border-radius:50%; border:1px solid var(--gold-line); background:transparent; color:var(--green-800); cursor:pointer; display:grid; place-items:center; transition:.35s var(--ease); }
.bg-green .testi-nav button{ color:var(--cream); border-color:rgba(246,243,235,.3); }
.testi-nav button:hover{ background:var(--green); color:#fff; border-color:var(--green); transform:translateY(-2px); }
.testi-nav button svg{ width:18px; }

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
.faq-group{ margin-bottom:clamp(36px,5vw,64px); }
.faq-group > .grp-title{ display:flex; align-items:center; gap:16px; margin-bottom:8px; }
.faq-group > .grp-title h3{ margin:0; color:var(--green-800); }
.faq-group > .grp-title .ln{ flex:1; height:1px; background:var(--gold-line); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; background:none; border:0; cursor:pointer; text-align:left;
  display:flex; justify-content:space-between; align-items:flex-start; gap:24px; padding:24px 4px;
  font-family:var(--font-body); font-size:clamp(1.02rem,.92rem+.45vw,1.22rem); font-weight:600; color:var(--ink); line-height:1.4; letter-spacing:.005em; }
.faq-q:hover{ color:var(--green-700); }
.faq-q .pm{ flex:0 0 auto; width:30px; height:30px; border-radius:50%; border:1px solid var(--gold-line); position:relative; margin-top:4px; transition:.4s var(--ease); }
.faq-q .pm::before,.faq-q .pm::after{ content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); background:var(--gold-deep); transition:.4s var(--ease); }
.faq-q .pm::before{ width:12px; height:1.6px; }
.faq-q .pm::after{ width:1.6px; height:12px; }
.faq-item.open .faq-q .pm{ background:var(--green); border-color:var(--green); }
.faq-item.open .faq-q .pm::before,.faq-item.open .faq-q .pm::after{ background:#fff; }
.faq-item.open .faq-q .pm::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .5s var(--ease); }
.faq-a .inner{ padding:0 4px 26px; color:var(--ink-2); font-size:1.04rem; line-height:1.72; max-width:60ch; }
.faq-a .inner p+p{ margin-top:.9em; }

/* ============================================================
   CONTACT FORM
   ============================================================ */
.form-card{ background:var(--warm-white); border:1px solid var(--line-soft); border-radius:var(--radius-lg); padding:clamp(28px,4vw,48px); box-shadow:var(--shadow-md); }
.field{ margin-bottom:20px; }
.field label{ display:block; font-size:.74rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); margin-bottom:8px; }
.field input,.field textarea,.field select{
  width:100%; padding:15px 16px; border:1px solid var(--line); border-radius:var(--radius);
  background:var(--cream); font-family:var(--font-body); font-size:1rem; color:var(--ink);
  transition:border-color .3s, box-shadow .3s, background .3s;
}
.field textarea{ min-height:140px; resize:vertical; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:0; border-color:var(--green); background:#fff; box-shadow:0 0 0 4px rgba(67,117,48,.1); }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-note{ font-size:.82rem; color:var(--ink-3); margin-top:6px; }
.chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top:14px; }
.chip{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; font-weight:600; color:var(--green-700);
  padding:8px 14px; border:1px solid var(--gold-line); border-radius:100px; background:var(--cream); }

/* contact info list */
.contact-list{ display:grid; gap:8px; }
.contact-row{ display:flex; gap:16px; align-items:flex-start; padding:18px 0; border-bottom:1px solid var(--line-soft); }
.contact-row .ic{ width:46px; height:46px; border-radius:50%; background:var(--green-800); color:var(--gold-soft); display:grid; place-items:center; flex:0 0 auto; }
.contact-row .ic svg{ width:20px; }
.contact-row .k{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); margin-bottom:3px; }
.contact-row .v{ font-family:var(--font-display); font-size:1.3rem; font-weight:600; color:var(--ink); }
.contact-row .v a:hover{ color:var(--green-700); }

.hours{ display:grid; gap:10px; }
.hours .hr{ display:flex; justify-content:space-between; gap:16px; padding-bottom:8px; border-bottom:1px dashed var(--line); font-size:.96rem; }
.hours .hr .d{ color:var(--ink-2); } .hours .hr .t{ font-weight:600; color:var(--ink); }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{ position:relative; overflow:hidden; isolation:isolate; color:var(--cream); text-align:center; }
.cta-band::before{ content:""; position:absolute; inset:0; z-index:-2; background:linear-gradient(150deg,var(--green-800),var(--green-900)); }
.cta-band .cta-media{ position:absolute; inset:0; z-index:-3; opacity:.22; }
.cta-band .cta-media img{ width:100%; height:100%; object-fit:cover; }
.cta-band::after{ content:""; position:absolute; inset:0; z-index:-1; background:radial-gradient(120% 90% at 50% 0%, transparent, rgba(20,30,12,.45)); }
.cta-band h2{ color:var(--warm-white); max-width:18ch; margin-inline:auto; }
.cta-band p{ color:rgba(246,243,235,.88); max-width:620px; margin:0 auto 32px; }
.cta-actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

/* social row */
.social-row{ display:flex; gap:12px; flex-wrap:wrap; }
.social-row a{ width:44px; height:44px; border-radius:50%; border:1px solid var(--gold-line); display:grid; place-items:center; color:var(--green-800); transition:.35s var(--ease); }
.social-row a svg{ width:18px; }
.social-row a:hover{ background:var(--green); color:#fff; border-color:var(--green); transform:translateY(-3px); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:#1c2516; color:rgba(246,243,235,.72); padding-top:clamp(60px,8vw,100px); }
.footer-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.3fr; gap:clamp(28px,4vw,56px); padding-bottom:clamp(44px,6vw,72px); border-bottom:1px solid rgba(246,243,235,.12); }
.footer-brand img{ height:62px; width:auto; filter:brightness(0) invert(1); opacity:.92; margin-bottom:20px; }
.footer-brand p{ font-size:.96rem; line-height:1.7; color:rgba(246,243,235,.66); max-width:34ch; }
.footer-col h4{ color:var(--gold-soft); font-family:var(--font-body); font-size:.76rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; margin-bottom:20px; }
.footer-col ul{ display:grid; gap:11px; }
.footer-col a{ font-size:.95rem; color:rgba(246,243,235,.72); transition:color .3s, padding-left .3s; }
.footer-col a:hover{ color:var(--gold-soft); padding-left:5px; }
.footer-contact .row{ display:flex; gap:12px; align-items:flex-start; margin-bottom:16px; font-size:.96rem; color:rgba(246,243,235,.78); }
.footer-contact .row svg{ width:18px; color:var(--gold-soft); flex:0 0 auto; margin-top:3px; }
.footer-social{ display:flex; gap:10px; flex-wrap:wrap; margin-top:8px; }
.footer-social a{ width:40px; height:40px; border-radius:50%; border:1px solid rgba(246,243,235,.2); display:grid; place-items:center; color:rgba(246,243,235,.8); transition:.35s var(--ease); }
.footer-social a svg{ width:17px; }
.footer-social a:hover{ background:var(--gold); color:#1c2516; border-color:var(--gold); transform:translateY(-3px); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; padding:26px 0; font-size:.82rem; color:rgba(246,243,235,.5); }
.footer-bottom a:hover{ color:var(--gold-soft); }

/* back to top */
.to-top{ position:fixed; right:24px; bottom:24px; z-index:900; width:50px; height:50px; border-radius:50%;
  background:var(--green-800); color:var(--cream); border:1px solid var(--gold-line); display:grid; place-items:center;
  cursor:pointer; opacity:0; visibility:hidden; transform:translateY(14px); transition:.4s var(--ease); box-shadow:var(--shadow-md); }
.to-top.show{ opacity:1; visibility:visible; transform:translateY(0); }
.to-top:hover{ background:var(--gold); color:#1c2516; }
.to-top svg{ width:18px; }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
/* reveal states apply ONLY when JS is active (.js on <html>) so no-JS users
   and crawlers always see fully rendered content */
.js [data-reveal]{ opacity:0; transform:translateY(30px); transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.js [data-reveal].in{ opacity:1; transform:none; }
.js [data-reveal="left"]{ transform:translateX(-40px); }
.js [data-reveal="right"]{ transform:translateX(40px); }
.js [data-reveal="scale"]{ transform:scale(.94); }
.js [data-reveal].in{ transform:none; }
[data-delay="1"]{ transition-delay:.12s; }
[data-delay="2"]{ transition-delay:.24s; }
[data-delay="3"]{ transition-delay:.36s; }
[data-delay="4"]{ transition-delay:.48s; }
[data-delay="5"]{ transition-delay:.6s; }

/* above-the-fold hero text: always animate on load, never JS-gated */
.hero .eyebrow, .hero h1, .hero .lead, .hero-actions,
.page-hero .breadcrumb, .page-hero h1, .page-hero .lead{
  animation:heroIn 1s var(--ease-out) both;
}
.hero h1, .page-hero h1{ animation-delay:.12s; }
.hero .lead, .page-hero .lead{ animation-delay:.26s; }
.hero-actions{ animation-delay:.4s; }
@keyframes heroIn{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){
  .hero .eyebrow,.hero h1,.hero .lead,.hero-actions,
  .page-hero .breadcrumb,.page-hero h1,.page-hero .lead{ animation:none; }
}

@media (prefers-reduced-motion: reduce){
  [data-reveal],.reveal-line>span{ opacity:1 !important; transform:none !important; transition:none !important; }
  .hero-scroll .dot::after{ animation:none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .nav, .header-phone{ display:none; }
  .burger{ display:flex; }
  .stat-strip{ grid-template-columns:repeat(2,1fr); }
  .proc-grid{ grid-template-columns:repeat(2,1fr); gap:34px; }
}
@media (max-width:900px){
  .split,.proc-row,.proc-row:nth-child(even) .proc-row-media{ grid-template-columns:1fr; }
  .split.reverse > :first-child{ order:0; }
  .proc-row-media{ order:0 !important; }
  .cards.c4{ grid-template-columns:repeat(2,1fr); }
  .cards.c3{ grid-template-columns:repeat(2,1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; }
  .footer-brand{ grid-column:1/-1; }
  .form-row{ grid-template-columns:1fr; }
  .media-frame.bordered::after{ inset:12px -12px -12px 12px; }
}
@media (max-width:600px){
  :root{ --header-h:74px; }
  .cards.c4,.cards.c3,.cards.c2,.grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; }
  .stat-strip{ grid-template-columns:1fr 1fr; }
  .proc-grid{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr; }
  .pill-row{ flex-direction:column; gap:6px; align-items:flex-start; }
  .hero-inner{ padding-top:130px; }
  .testi-card{ padding:30px 26px; }
}
