/* ===================================================================
   DALCORE CONTRACTING — DESIGN SYSTEM
   Palette, typography, components, motion. Shared across all pages.
   =================================================================== */

/* ----------  FONTS  ----------
   BRAND TYPE HIERARCHY (per DALCORE brand guide):
     Headings -> Lexend Peta SemiBold (uppercase, wide tracking)        ✓
     Subheads -> Ernestine Pro        (serif accent)                    ✓
     Body     -> Proxima Nova         (Adobe Fonts / Typekit)           ✓
     Logo     -> Hanover              (logo lockup only — not body type)
   Hanover is reserved for the logo, exactly as the brand guide intends. */
@import url("https://use.typekit.net/xwo6dnh.css");
@import url("https://fonts.googleapis.com/css2?family=Lexend+Peta:wght@400;500;600&display=swap");

/* Hanover (display / headlines) */
@font-face{font-family:"Hanover";font-weight:100;font-style:normal;font-display:swap;
  src:url("../fonts/hanover-thin.woff2?v=3") format("woff2"),url("../fonts/hanover-thin.woff?v=3") format("woff");}
@font-face{font-family:"Hanover";font-weight:300;font-style:normal;font-display:swap;
  src:url("../fonts/hanover-light.woff2?v=3") format("woff2"),url("../fonts/hanover-light.woff?v=3") format("woff");}
@font-face{font-family:"Hanover";font-weight:400;font-style:normal;font-display:swap;
  src:url("../fonts/hanover-regular.woff2?v=3") format("woff2"),url("../fonts/hanover-regular.woff?v=3") format("woff");}
@font-face{font-family:"Hanover";font-weight:700;font-style:normal;font-display:swap;
  src:url("../fonts/hanover-bold.woff2?v=3") format("woff2"),url("../fonts/hanover-bold.woff?v=3") format("woff");}
@font-face{font-family:"Hanover";font-weight:400;font-style:italic;font-display:swap;
  src:url("../fonts/hanover-italic.woff2?v=3") format("woff2"),url("../fonts/hanover-italic.woff?v=3") format("woff");}

/* Ernestine Pro (serif accent) is defined ONCE in fonts.css (embedded base64)
   so it loads reliably everywhere, including local file:// preview.
   Do NOT add a competing @font-face here — a later file:// src would override
   the embedded one and break the font on local preview. */

/* ----------  TOKENS  ---------- */
:root{
  /* Brand palette (exact) */
  --silver:#9FA097;
  --pale:#F5F4F3;
  --beige:#E8E7DD;
  --tan:#C9C8AF;
  --dark-green:#181E18;
  --green:#3B5B48;
  --emerald:#0E351F;
  --sage:#5A7765;

  /* Derived */
  --ink:#181E18;
  --line:rgba(159,160,151,.28);
  --line-strong:rgba(159,160,151,.5);
  --glass:rgba(245,244,243,.06);
  --glass-border:rgba(159,160,151,.22);

  /* Type */
  --display:"Lexend Peta","Oswald",sans-serif;   /* headings — brand supporting font */
  --label:"Lexend Peta","Oswald",sans-serif;     /* eyebrows / labels / buttons */
  --body:"proxima-nova","Inter",system-ui,sans-serif;
  --serif:"Ernestine",Georgia,"Times New Roman",serif;  /* subheads / accents — Ernestine only, no Spectral */
  --logo:"Hanover",sans-serif;                    /* reserved for logo lockup */

  /* Rhythm */
  --container:1240px;
  --gutter:clamp(20px,5vw,72px);
  --section:clamp(72px,11vw,160px);
  --radius:2px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ----------  RESET / BASE  ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--pale);
  line-height:1.65;
  font-weight:400;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--sage);color:var(--pale)}

/* ----------  TYPE SCALE  ---------- */
.display{
  font-family:var(--display);
  font-weight:600;
  text-transform:uppercase;
  line-height:1.04;
  letter-spacing:.02em;
}
h1,h2,h3{font-family:var(--display);font-weight:600;text-transform:uppercase;line-height:1.12;letter-spacing:.03em}
h1{font-size:clamp(2.1rem,5.2vw,4.4rem);line-height:1.06}
h2{font-size:clamp(1.6rem,3.4vw,2.7rem)}
h3{font-size:clamp(1.05rem,1.5vw,1.3rem);letter-spacing:.02em}
p{font-size:clamp(1rem,1.15vw,1.12rem);color:var(--ink)}
.lead{font-size:clamp(1.1rem,1.5vw,1.4rem);line-height:1.55;font-weight:300;color:var(--sage)}

.eyebrow{
  font-family:var(--label);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.34em;
  font-size:.7rem;
  color:var(--sage);
  display:inline-flex;align-items:center;gap:.8em;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--line-strong);display:inline-block}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--line-strong);display:inline-block}
.eyebrow.center{justify-content:center}

.serif{font-family:var(--serif)}

/* ----------  LAYOUT  ---------- */
.wrap{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter);width:100%}
.section{padding-block:var(--section);position:relative}
.section.tight{padding-block:clamp(48px,7vw,96px)}
.center{text-align:center}
.muted{color:var(--sage)}
.divider{height:1px;background:var(--line);width:100%}

/* Theme surfaces */
.bg-dark{background:var(--dark-green);color:var(--pale)}
.bg-emerald{background:var(--emerald);color:var(--pale)}
.bg-pale{background:var(--pale);color:var(--ink)}
.bg-beige{background:var(--beige);color:var(--ink)}
.bg-dark p,.bg-emerald p{color:rgba(245,244,243,.74)}
.bg-dark .lead,.bg-emerald .lead{color:rgba(245,244,243,.62)}
.bg-dark .eyebrow,.bg-emerald .eyebrow{color:var(--tan)}
.bg-dark .muted,.bg-emerald .muted{color:rgba(245,244,243,.55)}

/* ----------  NAV  ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--gutter);
  transition:background .4s var(--ease),padding .4s var(--ease),border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(24,30,24,.86);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  padding:14px var(--gutter);
  border-bottom:1px solid rgba(159,160,151,.16);
}
.nav__brand{display:flex;align-items:center;gap:12px}
.nav__brand img{height:44px;width:auto;transition:height .4s var(--ease)}
.nav.scrolled .nav__brand img{height:36px}
@media(max-width:600px){.nav__brand img{height:38px}}
.nav__links{display:flex;align-items:center;gap:38px}
.nav__links a{
  font-family:var(--label);font-weight:500;text-transform:uppercase;
  letter-spacing:.18em;font-size:.7rem;color:rgba(245,244,243,.82);
  position:relative;padding-block:6px;transition:color .3s;
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--tan);transition:width .35s var(--ease)}
.nav__links a:hover{color:var(--pale)}
.nav__links a:hover::after,.nav__links a.active::after{width:100%}
.nav__links a.active{color:var(--pale)}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.nav__toggle span{width:24px;height:2px;background:var(--pale);transition:.3s var(--ease);display:block}

/* light-nav variant for pages whose hero is pale */
.nav.light .nav__links a{color:rgba(24,30,24,.7)}
.nav.light .nav__links a:hover,.nav.light .nav__links a.active{color:var(--ink)}
.nav.light .nav__toggle span{background:var(--ink)}
.nav.light.scrolled .nav__links a{color:rgba(245,244,243,.82)}
.nav.light.scrolled .nav__links a:hover,.nav.light.scrolled .nav__links a.active{color:var(--pale)}
.nav.light.scrolled .nav__toggle span{background:var(--pale)}

/* ----------  BUTTONS  ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--label);font-weight:600;text-transform:uppercase;
  letter-spacing:.16em;font-size:.72rem;
  padding:16px 30px;border-radius:var(--radius);
  border:1px solid transparent;cursor:pointer;
  transition:all .35s var(--ease);position:relative;overflow:hidden;
}
.btn .arw{transition:transform .35s var(--ease)}
.btn:hover .arw{transform:translateX(5px)}
.btn--primary{background:var(--emerald);color:var(--pale);border-color:var(--emerald)}
.btn--primary:hover{background:var(--dark-green);border-color:var(--sage)}
.btn--ghost{background:transparent;color:var(--pale);border-color:rgba(159,160,151,.5)}
.btn--ghost:hover{border-color:var(--tan);background:rgba(245,244,243,.05)}
.btn--dark{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn--dark:hover{background:var(--ink);color:var(--pale);border-color:var(--ink)}
.btn--solidlight{background:var(--pale);color:var(--emerald);border-color:var(--pale)}
.btn--solidlight:hover{background:var(--tan);border-color:var(--tan)}
.btn-row{display:flex;flex-wrap:wrap;gap:16px}

/* ----------  MONOGRAM WATERMARK  ---------- */
.watermark{
  position:absolute;pointer-events:none;opacity:.05;z-index:0;
  width:min(60vw,640px);
}
.watermark.tr{top:-6%;right:-8%}
.watermark.bl{bottom:-10%;left:-8%}
.section>.wrap{position:relative;z-index:1}

/* ----------  PRECISION GRID OVERLAY (logo-spacing inspired)  ---------- */
.grid-lines{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5}
.grid-lines span{position:absolute;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,var(--line),transparent)}

/* ----------  CARDS  ---------- */
.card{
  background:var(--pale);border:1px solid var(--line);
  border-radius:var(--radius);padding:38px 34px;
  transition:transform .5s var(--ease),border-color .5s var(--ease),box-shadow .5s var(--ease),background .5s var(--ease);
  position:relative;overflow:hidden;height:100%;
}
.card:hover{transform:translateY(-6px);border-color:var(--sage);box-shadow:0 30px 60px -30px rgba(14,53,31,.25)}
.card__num{font-family:var(--label);font-weight:600;font-size:.7rem;letter-spacing:.2em;color:var(--silver)}
.card__rule{height:1px;background:var(--line);margin:22px 0;transition:background .5s}
.card:hover .card__rule{background:var(--sage)}
.card h3{margin-bottom:10px}
.card p{color:var(--sage);font-size:.98rem;line-height:1.6}
.card__more{
  margin-top:24px;display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--label);font-weight:600;text-transform:uppercase;
  letter-spacing:.16em;font-size:.66rem;color:var(--emerald);
}
.card__more .arw{transition:transform .35s var(--ease)}
.card:hover .card__more .arw{transform:translateX(5px)}
/* card as link */
a.card--link{display:block;text-decoration:none;color:inherit;cursor:pointer}
a.card--link h3{color:var(--dark-green)}

/* ----- Project filter bar + empty state ----- */
.pfilter{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.pf__grp{flex-basis:100%;font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.18em;font-size:.6rem;color:var(--silver);margin:14px 0 2px}
.pf__grp:first-of-type{margin-top:4px}
.pf{font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;color:var(--sage);background:transparent;border:1px solid var(--line);border-radius:999px;padding:10px 18px;cursor:pointer;transition:background .35s var(--ease),border-color .35s var(--ease),color .35s var(--ease)}
.pf:hover{border-color:var(--sage);color:var(--emerald)}
.pf.is-active{background:var(--emerald);border-color:var(--emerald);color:var(--pale)}
.pempty{text-align:center;max-width:560px;margin:32px auto 0;padding:clamp(46px,6vw,78px) 28px;border:1px dashed var(--silver);border-radius:var(--radius);background:var(--pale)}
.pempty h3{margin:14px 0 12px}
.pempty p{color:var(--sage);max-width:46ch;margin:0 auto 26px}

/* ----- Filter dropdowns ----- */
.pf-select{position:relative;display:inline-flex;align-items:center}
.pf-select::after{content:"";position:absolute;right:16px;top:50%;width:7px;height:7px;border-right:1.5px solid var(--sage);border-bottom:1.5px solid var(--sage);transform:translateY(-70%) rotate(45deg);pointer-events:none;transition:border-color .35s var(--ease)}
.pf-select select{appearance:none;-webkit-appearance:none;background:transparent;border:1px solid var(--line);border-radius:999px;padding:10px 38px 10px 18px;font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;color:var(--sage);cursor:pointer;transition:background .35s var(--ease),border-color .35s var(--ease),color .35s var(--ease)}
.pf-select select:hover{border-color:var(--sage);color:var(--emerald)}
.pf-select.is-active select{background:var(--emerald);border-color:var(--emerald);color:var(--pale)}
.pf-select.is-active::after{border-color:var(--pale)}

/* ----- Horizontal projects carousel ----- */
.ptrack{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding-bottom:10px;-webkit-overflow-scrolling:touch}
.ptrack>.case{flex:0 0 calc((100% - 48px) / 3);scroll-snap-align:start}
@media(max-width:1024px){.ptrack>.case{flex-basis:calc((100% - 24px) / 2)}}
@media(max-width:640px){.ptrack>.case{flex-basis:86%}}
.ptrack::-webkit-scrollbar{height:6px}
.ptrack::-webkit-scrollbar-track{background:transparent}
.ptrack::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.ptrack-nav{display:flex;justify-content:flex-end;gap:10px;margin:26px 0 6px}
.pnav{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--emerald);font-size:1.05rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .3s var(--ease),border-color .3s var(--ease)}
.pnav:hover{border-color:var(--sage);background:var(--beige)}

/* ----- Clickable case card ----- */
.case--click{cursor:pointer}
.case--click:focus-visible{outline:2px solid var(--sage);outline-offset:3px}
.case__more{display:inline-flex;align-items:center;gap:.6em;margin-top:4px;font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;color:var(--emerald)}
.case__more .arw{transition:transform .35s var(--ease)}
.case--click:hover .case__more .arw{transform:translateX(5px)}

/* ----- Project detail modal ----- */
.pmodal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}
.pmodal[hidden]{display:none}
.pmodal__overlay{position:absolute;inset:0;background:rgba(24,30,24,.62);backdrop-filter:blur(4px)}
.pmodal__panel{position:relative;z-index:1;background:var(--pale);border-radius:var(--radius);max-width:760px;width:100%;max-height:88vh;overflow:auto;padding:clamp(28px,4vw,52px);box-shadow:0 40px 90px -30px rgba(14,53,31,.5)}
.pmodal__close{position:absolute;top:12px;right:18px;background:none;border:none;font-size:2rem;line-height:1;color:var(--sage);cursor:pointer;transition:color .3s}
.pmodal__close:hover{color:var(--emerald)}
.pmodal__content h2{margin:10px 0 12px}
.pmodal__content .case__meta{margin-bottom:6px}
.pmodal__content p{color:var(--sage);margin-bottom:12px}
.pmodal__gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:22px 0}
.pmodal__gallery img{width:100%;height:220px;object-fit:cover;border-radius:10px}
.pgi--soon{grid-column:1/-1;height:200px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--pale),var(--beige));border:1px dashed var(--silver);border-radius:10px}
.pgi--soon span{font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.2em;font-size:.66rem;color:var(--sage)}
body.modal-open{overflow:hidden}

/* glass cards for technology section */
.glass{
  background:var(--glass);border:1px solid var(--glass-border);
  border-radius:var(--radius);padding:34px 30px;backdrop-filter:blur(8px);
  transition:transform .5s var(--ease),border-color .5s var(--ease),background .5s var(--ease);height:100%;
}
.glass:hover{transform:translateY(-6px);border-color:var(--tan);background:rgba(245,244,243,.09)}
.glass h3{color:var(--pale);margin-bottom:10px;font-size:1.15rem}
.glass p{color:rgba(245,244,243,.66);font-size:.95rem}
.glass .gk{font-family:var(--label);font-weight:600;font-size:.65rem;letter-spacing:.22em;color:var(--tan);text-transform:uppercase}

/* ----------  GRIDS  ---------- */
.grid{display:grid;gap:24px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,7vw,110px);align-items:center}

/* ----------  STAT STRIP  ---------- */
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line);border-left:1px solid var(--line);border-right:1px solid var(--line)}
@media(max-width:900px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{background:var(--dark-green);padding:40px 28px;text-align:center}
.bg-pale .stat{background:var(--pale)}
.stat__num{font-family:var(--display);font-size:clamp(2.4rem,4vw,3.4rem);line-height:1;color:var(--tan);height:clamp(48px,5vw,62px);display:flex;align-items:center;justify-content:center}
.bg-pale .stat__num{color:var(--emerald)}
.stat__ico{height:clamp(48px,5vw,62px);width:auto;color:var(--tan);display:block;margin:0 auto}
.stat__ico path,.stat__ico rect,.stat__ico circle{stroke-linecap:round;stroke-linejoin:round}
.stat__lbl{font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.18em;font-size:.64rem;color:var(--tan);margin-top:18px}
.bg-pale .stat__lbl{color:var(--sage)}

/* ----------  PROCESS TIMELINE  ---------- */
.timeline{position:relative;margin-top:60px}
.timeline__track{position:absolute;left:0;right:0;top:46px;height:1px;background:rgba(159,160,151,.25)}
.timeline__fill{position:absolute;left:0;top:46px;height:1px;background:var(--tan);width:0;transition:width 1.6s var(--ease)}
.steps{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;position:relative}
.step__dot{width:13px;height:13px;border-radius:50%;border:1px solid var(--tan);background:var(--dark-green);position:relative;z-index:2;margin-bottom:34px}
.step__dot::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--tan);transform:scale(0);transition:transform .5s var(--ease)}
.step.in .step__dot::after{transform:scale(1)}
.step__n{font-family:var(--label);font-weight:600;font-size:.64rem;letter-spacing:.2em;color:var(--silver)}
.step h3{font-size:1.05rem;color:var(--pale);margin:8px 0 8px;min-height:2.5em;display:flex;align-items:flex-end}
.step p{font-size:.88rem;color:rgba(245,244,243,.6)}

/* ----------  PROJECT CARDS  ---------- */
.project{
  position:relative;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);background:var(--beige);
  min-height:clamp(320px,42vw,460px);display:flex;flex-direction:column;justify-content:flex-end;
  transition:transform .6s var(--ease),box-shadow .6s var(--ease);
}
.project:hover{transform:translateY(-6px);box-shadow:0 40px 70px -34px rgba(14,53,31,.4)}
.project__canvas{position:absolute;inset:0;z-index:0}
.project__meta{position:relative;z-index:2;padding:30px 30px 32px;color:var(--pale)}
.project__cat{font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.2em;font-size:.62rem;color:var(--tan)}
.project h3{font-size:1.35rem;margin:10px 0 6px;color:var(--pale)}
.project__loc{font-size:.85rem;color:rgba(245,244,243,.72)}
.project__scope{font-size:.9rem;color:rgba(245,244,243,.78);margin-top:14px;max-width:46ch}
.project__tag{display:inline-block;margin-top:18px;font-family:var(--label);font-weight:500;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--pale);border:1px solid rgba(245,244,243,.4);padding:6px 12px;border-radius:99px}
.ph-note{position:absolute;top:18px;left:18px;z-index:2;font-family:var(--label);font-weight:500;font-size:.55rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(245,244,243,.7);border:1px solid rgba(245,244,243,.3);padding:5px 9px;border-radius:99px;background:rgba(24,30,24,.3)}

/* ----------  VALUE / WHY LIST  ---------- */
.vrow{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:30px 0;border-top:1px solid var(--line);align-items:start}
.vrow:last-child{border-bottom:1px solid var(--line)}
.vrow__n{font-family:var(--label);font-weight:600;font-size:.7rem;letter-spacing:.2em;color:var(--silver);padding-top:6px}
.vrow h3{font-size:1.3rem;margin-bottom:8px}
.vrow p{color:var(--sage);max-width:60ch}

/* ----------  BEFORE / AFTER SLIDER  ---------- */
.ba{position:relative;width:100%;aspect-ratio:16/10;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;user-select:none}
.ba__layer{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.ba__after{clip-path:inset(0 0 0 50%)}
.ba__lbl{position:absolute;bottom:16px;font-family:var(--label);font-weight:600;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--pale);background:rgba(24,30,24,.5);padding:6px 12px;border-radius:99px;z-index:4}
.ba__lbl.l{left:16px}.ba__lbl.r{right:16px}
.ba__handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--pale);z-index:5;cursor:ew-resize}
.ba__grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border-radius:50%;background:var(--pale);display:flex;align-items:center;justify-content:center;color:var(--emerald);font-size:.8rem}
.ba input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize;z-index:6;margin:0}

/* ----------  FORM  ---------- */
.form{display:grid;gap:22px}
.field{display:flex;flex-direction:column;gap:9px}
.field label{font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.16em;font-size:.62rem;color:var(--sage)}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:1rem;color:var(--ink);
  background:var(--pale);border:1px solid var(--line-strong);border-radius:var(--radius);
  padding:14px 16px;transition:border-color .3s,box-shadow .3s;width:100%;
}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sage);box-shadow:0 0 0 3px rgba(90,119,101,.12)}
.form .g2{gap:22px}
.form-note{font-size:.82rem;color:var(--silver)}

/* ----------  FOOTER  ---------- */
.footer{background:var(--dark-green);color:var(--pale);padding-top:clamp(48px,5vw,72px);position:relative;overflow:hidden}
.footer__top{display:grid;grid-template-columns:1.7fr 1fr 1.2fr 1.4fr;gap:clamp(32px,4vw,60px);padding-bottom:38px}
.footer img.fmono{height:54px;width:auto;margin-bottom:22px}
.flogo{width:clamp(140px,14vw,184px);height:auto;margin-bottom:16px;display:block}
.footer p{color:rgba(245,244,243,.6);font-size:.9rem;max-width:32ch}
.footer h4{font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.2em;font-size:.66rem;color:var(--tan);margin-bottom:16px}
.footer ul{list-style:none;display:grid;gap:10px}
.footer ul li{color:rgba(245,244,243,.7);font-size:.92rem}
.footer ul a{color:rgba(245,244,243,.7);font-size:.92rem;transition:color .3s}
.footer ul a:hover{color:var(--pale)}
.footer__bottom{border-top:1px solid rgba(159,160,151,.16);padding:20px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px}
.footer__bottom span{font-size:.78rem;color:rgba(245,244,243,.45);letter-spacing:.04em}
.footer__wm{display:none}

/* ----------  FLOATING MOBILE CTA  ---------- */
.fab{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:900;display:none;
  justify-content:center;background:var(--emerald);color:var(--pale);
  padding:16px;border-radius:var(--radius);font-family:var(--label);font-weight:600;
  text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;
  box-shadow:0 20px 40px -16px rgba(0,0,0,.5);
}

/* ----------  PAGE HERO (interior pages)  ---------- */
.phero{position:relative;padding-top:clamp(150px,20vh,220px);padding-bottom:clamp(70px,9vw,120px);overflow:hidden}
.phero h1{max-width:18ch}
.phero .lead{max-width:60ch;margin-top:26px}

/* ----------  HERO  ---------- */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;overflow:hidden;background:var(--dark-green)}
.hero__bg{
  position:absolute;inset:0;z-index:0;
  background:url("https://images.squarespace-cdn.com/content/v1/66a30b8182130279d7bac2c8/4653a659-8732-4360-9b0d-e147a5429121/Interior.jpg?format=2500w") center/cover no-repeat;
  transform:scale(1.08);animation:heroZoom 18s var(--ease) forwards;filter:saturate(.85) brightness(.7);
}
@keyframes heroZoom{to{transform:scale(1)}}

/* ----- Residential rotating hero slideshow (green tint preserved via base filter + veil) ----- */
.hero--slides .hero__bg{animation:heroSlide 21s var(--ease) infinite;opacity:0;will-change:opacity,transform}
.hero--slides .hero__bg:nth-of-type(2){animation-delay:7s}
.hero--slides .hero__bg:nth-of-type(3){animation-delay:14s}
@keyframes heroSlide{0%{opacity:0;transform:scale(1.09)}5%{opacity:1}33%{opacity:1}38%{opacity:0}100%{opacity:0;transform:scale(1.03)}}
@media(prefers-reduced-motion:reduce){.hero--slides .hero__bg{animation:none}.hero--slides .hero__bg:nth-of-type(1){opacity:1}.hero--slides .hero__bg:nth-of-type(2),.hero--slides .hero__bg:nth-of-type(3){opacity:0}}

/* ----- Live animated AI + construction hero ----- */
.hero--anim .hero__bg{
  background:
    radial-gradient(130% 95% at 78% 12%, rgba(14,53,31,.92), transparent 58%),
    radial-gradient(120% 110% at 12% 90%, rgba(24,30,24,1), rgba(14,53,31,.8) 52%, var(--dark-green));
  animation:none;transform:none;filter:none;
}
.hero__canvas{position:absolute;inset:0;z-index:1;width:100%;height:100%;display:block}
.hero--anim .hero__mono{display:none}
@media(max-width:980px){.hero__canvas{opacity:.4}}
.hero--anim .hero__veil{
  background:
    linear-gradient(180deg,rgba(24,30,24,.5) 0%,rgba(24,30,24,.05) 28%,rgba(24,30,24,.3) 70%,rgba(24,30,24,.96) 100%),
    linear-gradient(90deg,rgba(24,30,24,.94) 0%,rgba(24,30,24,.45) 42%,transparent 72%);
}
.hero__veil{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(24,30,24,.6) 0%,rgba(24,30,24,.2) 30%,rgba(14,53,31,.55) 70%,rgba(24,30,24,.95) 100%),
    linear-gradient(90deg,rgba(24,30,24,.8) 0%,rgba(24,30,24,.15) 60%,transparent 100%);
}
.hero__grid{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.5}
.hero__grid span{position:absolute;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,rgba(159,160,151,.22),transparent)}
.hero__grid span:nth-child(1){left:20%}.hero__grid span:nth-child(2){left:40%}.hero__grid span:nth-child(3){left:60%}.hero__grid span:nth-child(4){left:80%}
.hero__mono{position:absolute;right:-6%;top:8%;width:min(52vw,560px);opacity:.06;z-index:2;pointer-events:none}
/* hero content band sits wider than the standard container so it never strands left */
.hero .wrap{max-width:1500px}
.hero__inner{position:relative;z-index:3;padding-top:90px;padding-bottom:40px;max-width:min(640px,56%)}
@media(max-width:980px){.hero__inner{max-width:100%}}
.hero h1{color:var(--pale);max-width:15ch;margin:22px 0 28px}
.hero .lead{color:rgba(245,244,243,.78);max-width:52ch;font-weight:300;margin-bottom:38px}
.hero .btn-row{margin-top:0}
.hero .eyebrow{color:var(--tan)}
.hero__scroll{position:absolute;left:var(--gutter);bottom:34px;z-index:3;display:flex;align-items:center;gap:14px;color:rgba(245,244,243,.6);font-family:var(--label);font-size:.62rem;letter-spacing:.24em;text-transform:uppercase}
.hero__scroll i{width:1px;height:42px;background:linear-gradient(180deg,var(--tan),transparent);position:relative;overflow:hidden}
.hero__scroll i::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--pale);animation:scrollLine 2.2s var(--ease) infinite}
@keyframes scrollLine{0%{top:-50%}100%{top:100%}}

/* ----------  SECTION HEAD  ---------- */
.section__head{max-width:760px}
.section__head h2{margin:18px 0 20px}

/* ----------  BRAND STATEMENT  ---------- */
.statement{max-width:1000px}
.statement__lead{font-size:clamp(1.5rem,3.4vw,2.7rem);line-height:1.28;font-weight:300;color:var(--ink);margin-top:28px;letter-spacing:-.01em}
.statement__lead .hl{color:var(--emerald);font-weight:500}
.statement__byline{margin-top:34px;font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--sage);font-style:normal;max-width:70ch}

/* ----------  QUOTE  ---------- */
.quote{font-size:clamp(1.3rem,2.2vw,1.85rem);line-height:1.4;font-style:normal;color:var(--emerald);border-left:2px solid var(--tan);padding-left:30px}
.quote__by{margin-top:22px;font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;color:var(--sage);padding-left:32px}

/* ----------  PROJECT VEIL (image cards)  ---------- */
.project{background-size:cover;background-position:center}
.project__veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(24,30,24,.05) 0%,rgba(24,30,24,.35) 45%,rgba(14,53,31,.92) 100%);transition:background .6s var(--ease)}
.project:hover .project__veil{background:linear-gradient(180deg,rgba(24,30,24,.1) 0%,rgba(24,30,24,.45) 45%,rgba(14,53,31,.96) 100%)}

/* ----------  CTA BANNER  ---------- */
.cta{position:relative;padding-block:clamp(90px,13vw,170px);overflow:hidden;background:var(--dark-green);color:var(--pale)}
.cta__bg{position:absolute;inset:0;z-index:0;background:radial-gradient(120% 120% at 50% 0%,rgba(14,53,31,.9),rgba(24,30,24,1))}
.cta h2{color:var(--pale)}
.cta .lead{color:rgba(245,244,243,.72)}
.cta .eyebrow{color:var(--tan)}

/* ----------  CONTACT  ---------- */
.contact-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:clamp(34px,5vw,64px);align-items:start}
.contact-side{display:grid;gap:16px}
.cside-card{border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;background:var(--pale)}
.cside-card h4{font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.18em;font-size:.64rem;color:var(--sage);margin-bottom:14px}
.cside-card p{font-size:.94rem;color:var(--sage)}
.cside-link{display:block;font-family:var(--body);font-size:1rem;color:var(--emerald);font-weight:500;padding:4px 0}
.cside-steps{margin:0;padding-left:18px;display:grid;gap:10px}
.cside-steps li{font-size:.92rem;color:var(--sage)}
.cside-card--dark{background:var(--dark-green);border-color:transparent}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}.form .g2{grid-template-columns:1fr}}

/* ----------  TESTIMONIALS CAROUSEL  ---------- */
.tw{margin-top:40px;position:relative}
.tw__track{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;padding:4px var(--gutter) 18px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.tw__track::-webkit-scrollbar{display:none}
.tcard{flex:0 0 clamp(260px,28vw,340px);scroll-snap-align:start;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:26px 24px;display:flex;flex-direction:column;gap:14px;backdrop-filter:blur(6px)}
.tcard__stars{color:var(--tan);letter-spacing:.16em;font-size:.72rem}
.tcard__quote{font-size:1rem;line-height:1.5;color:var(--pale);flex:1;border:none;padding:0;margin:0;font-style:normal}
.tcard__by{display:flex;flex-direction:column;gap:4px;border-top:1px solid rgba(159,160,151,.18);padding-top:14px}
.tcard__name{font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;color:var(--tan)}
.tcard__role{font-size:.82rem;color:rgba(245,244,243,.55)}
.tw__nav{display:flex;gap:12px;margin-top:24px}
.tw__btn{width:42px;height:42px;border:1px solid var(--glass-border);background:transparent;color:var(--tan);border-radius:50%;font-size:1rem;cursor:pointer;transition:all .35s var(--ease)}
.tw__btn:hover{background:var(--tan);color:var(--emerald);border-color:var(--tan)}
@media(max-width:600px){.tcard{flex-basis:78vw}}

/* ----------  INSIGHTS / POST CARDS  ---------- */
.post{border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px 28px;background:var(--pale);transition:transform .5s var(--ease),border-color .5s var(--ease),box-shadow .5s var(--ease);display:flex;flex-direction:column;min-height:230px}
.post:hover{transform:translateY(-6px);border-color:var(--sage);box-shadow:0 30px 56px -34px rgba(14,53,31,.26)}
.post__tag{font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.16em;font-size:.6rem;color:var(--sage)}
.post h3{margin:16px 0 12px;font-size:1.2rem}
.post p{color:var(--sage);font-size:.95rem;flex:1}
.post__meta{margin-top:18px;font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.16em;font-size:.6rem;color:var(--silver)}
a.post--link{text-decoration:none;color:inherit;cursor:pointer}
a.post--link:hover{transform:translateY(-6px);border-color:var(--sage);box-shadow:0 30px 60px -30px rgba(14,53,31,.25)}
a.post--link h3{color:var(--ink)}

/* ----- Article (blog post) ----- */
.article{max-width:720px;margin:0 auto}
.article p{font-size:1.08rem;line-height:1.8;margin-bottom:22px}
.article h2{font-size:clamp(1.3rem,2.4vw,1.75rem);margin:40px 0 14px}
.article__sign{font-family:var(--serif);font-style:normal;color:var(--emerald);margin-top:30px;font-size:1.15rem}

/* ----------  SOCIAL ICONS  ---------- */
.social-row{display:flex;gap:14px;align-items:center}
.social{width:42px;height:42px;border:1px solid var(--glass-border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--tan);transition:all .35s var(--ease)}
.social svg{width:18px;height:18px}
.social:hover{background:var(--tan);color:var(--emerald);border-color:var(--tan);transform:translateY(-3px)}
.bg-pale .social,.bg-beige .social{border-color:var(--line);color:var(--sage)}
.bg-pale .social:hover,.bg-beige .social:hover{background:var(--emerald);color:var(--pale);border-color:var(--emerald)}
.footer__social{margin-top:18px}
.footer__social .social{width:38px;height:38px}

/* ----------  CREDENTIAL LIST (technology / founder proof)  ---------- */
.cred-list{display:grid;gap:0;border-top:1px solid var(--line)}
.cred{display:grid;grid-template-columns:130px 1fr;gap:18px;padding:18px 0;border-bottom:1px solid var(--line);align-items:baseline}
.cred__k{font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.16em;font-size:.64rem;color:var(--sage)}
.cred__v{font-size:.98rem;color:var(--ink)}
@media(max-width:560px){.cred{grid-template-columns:1fr;gap:4px}}

/* ----------  DASHBOARD MODULE (technology page)  ---------- */
.dash{background:var(--dark-green);border:1px solid var(--glass-border);border-radius:var(--radius);padding:34px 32px}
.dash__row{display:grid;grid-template-columns:1fr;gap:9px;padding:14px 0;border-bottom:1px solid rgba(159,160,151,.14)}
.dash__row span{font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.14em;font-size:.64rem;color:rgba(245,244,243,.8)}
.dash .bar{height:5px;border-radius:99px;background:rgba(159,160,151,.18);position:relative;overflow:hidden}
.dash .bar::after{content:"";position:absolute;inset:0;width:var(--w);background:linear-gradient(90deg,var(--sage),var(--tan));border-radius:99px}
.dash__note{margin-top:18px;font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.16em;font-size:.58rem;color:var(--silver)}

/* ----------  PROCESS GRID (process page)  ---------- */
.proc-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 60px}
.proc{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:32px 0;border-top:1px solid var(--line);align-items:start}
.proc__n{font-family:var(--display);font-size:clamp(1.8rem,3vw,2.6rem);color:var(--tan);line-height:1}
.proc h3{font-size:1.2rem;margin-bottom:8px}
.proc p{color:var(--sage);font-size:.96rem}
@media(max-width:860px){.proc-grid{grid-template-columns:1fr;gap:0}}

/* ----------  CASE STUDY CARDS  ---------- */
.case{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--pale);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.case:hover{transform:translateY(-6px);box-shadow:0 34px 64px -34px rgba(14,53,31,.28)}
.case__img{height:clamp(240px,32vw,360px);background-size:cover;background-position:center}
.case__img--soon{background:linear-gradient(135deg,var(--pale),var(--beige));display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line)}
.case__img--soon span{font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.2em;font-size:.66rem;color:var(--sage)}
.case__body{padding:32px 30px 36px}
.case__body h3{margin:12px 0 14px}
.case__body p{color:var(--sage);font-size:.96rem;margin-bottom:12px}
.case__meta{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:18px}
.case__meta span{font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.12em;font-size:.62rem;color:var(--silver)}

/* ----------  GALLERY  ---------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gi{aspect-ratio:4/3;background-size:cover;background-position:center;border-radius:var(--radius);transition:transform .6s var(--ease),filter .6s var(--ease);filter:saturate(.92)}
.gi:hover{transform:scale(1.02);filter:saturate(1.05)}
.gi--soon{background:linear-gradient(135deg,var(--pale),var(--beige));display:flex;align-items:center;justify-content:center;border:1px solid var(--line);filter:none}
.gi--soon:hover{transform:none;filter:none}
.gi--soon span{font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.18em;font-size:.6rem;color:var(--sage)}
@media(max-width:860px){.gallery{grid-template-columns:1fr 1fr;gap:10px}}

/* ----------  SPEC LISTS / SERVICE CELLS  ---------- */
.speclist{list-style:none;display:grid;gap:0}
.speclist li{padding:16px 0;border-top:1px solid var(--line);font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;color:var(--emerald);display:flex;align-items:center;gap:14px}
.speclist li::before{content:"";width:7px;height:7px;background:var(--tan);flex:0 0 auto}
.speclist li:last-child{border-bottom:1px solid var(--line)}
.bg-dark .speclist li,.bg-emerald .speclist li{color:var(--tan);border-color:rgba(159,160,151,.18)}
.speclist.sm li{font-size:.68rem;padding:11px 0}
.svc-cell{background:var(--pale);padding:42px 34px}
.svc-cell h3{margin:14px 0 12px}
.svc-cell>p{color:var(--sage);margin-bottom:20px}

/* ----------  REVEAL MOTION  ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ----------  RESPONSIVE  ---------- */
@media(max-width:1024px){
  .g4{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(3,1fr);gap:30px 18px}
  .timeline__track,.timeline__fill{display:none}
  .footer__top{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .nav__links{
    position:fixed;top:0;right:0;height:100vh;width:min(78vw,360px);
    background:var(--dark-green);flex-direction:column;justify-content:center;
    align-items:flex-start;padding:40px 44px;gap:26px;
    transform:translateX(100%);transition:transform .5s var(--ease);
    border-left:1px solid rgba(159,160,151,.16);
  }
  .nav__links.open{transform:none}
  .nav__links a{font-size:1rem;color:rgba(245,244,243,.85)!important}
  .nav__toggle{display:flex;z-index:1001}
  .nav__toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav__toggle.open span:nth-child(2){opacity:0}
  .nav__toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .g2,.g3,.g4,.split,.stats{grid-template-columns:1fr}
  .stats{gap:1px}
  .steps{grid-template-columns:1fr;gap:0}
  .step{padding:24px 0;border-top:1px solid rgba(159,160,151,.18)}
  .step__dot{margin-bottom:16px}
  .fab{display:flex}
  body{padding-bottom:78px}
  .footer__top{grid-template-columns:1fr;gap:34px}
}
