/* ============================================================
   SALTWELL HOUSE — restorative wellbeing studio
   Bespoke direction: Instrument Serif / Red Hat Display / DM Mono
   Palette: deep teal base · sand neutrals · burnt-orange accent
   Signature motion: clip-path wipe reveals + parallax layers
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --teal-900:#06231f;
  --teal-800:#0a2e29;
  --teal-700:#0f3b35;
  --teal-600:#155049;
  --teal-500:#1d685f;
  --teal-300:#5a958c;
  --sand-50:#fbf6ec;
  --sand-100:#f4ecdb;
  --sand-200:#e9dcc3;
  --sand-300:#d9c6a4;
  --sand-400:#c2a883;
  --orange:#d8612b;
  --orange-bright:#ef7733;
  --orange-soft:#f0a368;
  --ink:#0c1c19;
  --paper:#fbf6ec;
  --muted:#6f7d77;

  --font-display:"Instrument Serif",Georgia,serif;
  --font-body:"Red Hat Display",system-ui,sans-serif;
  --font-mono:"DM Mono","SFMono-Regular",monospace;

  --maxw:1240px;
  --gutter:clamp(1.25rem,5vw,4rem);
  --radius:22px;
  --radius-lg:34px;
  --ease:cubic-bezier(0.32,0.72,0,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.62;
  font-size:clamp(1rem,0.55vw + 0.9rem,1.12rem);
  font-weight:400;
  letter-spacing:-0.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;line-height:1.02;letter-spacing:-0.01em}
.eyebrow{
  font-family:var(--font-mono);
  font-size:0.72rem;
  letter-spacing:0.26em;
  text-transform:uppercase;
  color:var(--orange);
  font-weight:500;
}
.mono{font-family:var(--font-mono)}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(4.5rem,11vw,9.5rem)}
.lede{font-size:clamp(1.15rem,1.4vw,1.4rem);color:var(--teal-600);line-height:1.55;max-width:46ch}

/* skip link */
.skip{position:absolute;left:-999px;top:0;background:var(--orange);color:#fff;padding:.7rem 1.1rem;z-index:200;border-radius:0 0 10px 0}
.skip:focus{left:0}

/* ---------- Accessibility focus ---------- */
:focus-visible{outline:3px solid var(--orange);outline-offset:3px;border-radius:4px}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1.05rem var(--gutter);
  display:flex;align-items:center;justify-content:space-between;
  transition:background .5s var(--ease),backdrop-filter .5s var(--ease),padding .5s var(--ease),border-color .5s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(8,40,36,0.78);
  backdrop-filter:blur(18px) saturate(1.3);
  border-bottom:1px solid rgba(217,198,164,0.16);
  padding-block:.8rem;
}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--font-display);font-size:1.5rem;color:var(--sand-50);letter-spacing:-0.01em}
.site-header:not(.scrolled) .brand{color:var(--sand-50)}
.brand-mark{
  width:34px;height:34px;border-radius:50%;flex:none;
  background:radial-gradient(circle at 32% 30%,var(--orange-soft),var(--orange) 55%,var(--teal-700));
  box-shadow:inset 0 1px 1px rgba(255,255,255,.35);
}
.brand small{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--orange-soft);display:block;margin-top:-2px}
.nav{display:flex;align-items:center;gap:2rem}
.nav a{
  font-size:.84rem;font-weight:500;letter-spacing:.01em;color:var(--sand-100);
  position:relative;padding-block:.3rem;transition:color .3s var(--ease);
}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--orange-bright);transition:width .4s var(--ease)}
.nav a:hover{color:#fff}.nav a:hover::after{width:100%}
.nav-cta{
  font-family:var(--font-body);font-size:.84rem;font-weight:600;
  background:var(--orange);color:#fff;padding:.62rem 1.25rem;border-radius:999px;
  display:inline-flex;align-items:center;gap:.5rem;
  transition:transform .4s var(--ease),background .3s var(--ease);
}
.nav-cta:hover{background:var(--orange-bright);transform:translateY(-1px)}
.nav-cta::after{display:none}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:30px;height:22px;position:relative;z-index:120}
.nav-toggle span{position:absolute;left:0;height:2px;width:100%;background:var(--sand-50);border-radius:2px;transition:transform .4s var(--ease),opacity .3s var(--ease)}
.nav-toggle span:nth-child(1){top:2px}
.nav-toggle span:nth-child(2){top:10px}
.nav-toggle span:nth-child(3){top:18px}
body.menu-open .nav-toggle span:nth-child(1){transform:translateY(8px) rotate(45deg)}
body.menu-open .nav-toggle span:nth-child(2){opacity:0}
body.menu-open .nav-toggle span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--font-body);font-weight:600;font-size:.95rem;
  padding:.95rem 1.05rem .95rem 1.6rem;border-radius:999px;border:none;cursor:pointer;
  transition:transform .45s var(--ease),background .35s var(--ease),box-shadow .45s var(--ease);
  text-decoration:none;
}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 14px 30px -16px rgba(216,97,43,.8)}
.btn-primary:hover{background:var(--orange-bright);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--teal-700);border:1.5px solid var(--teal-300);padding:.95rem 1.6rem}
.btn-ghost:hover{background:var(--teal-700);color:var(--sand-50);border-color:var(--teal-700);transform:translateY(-2px)}
.btn-light{background:var(--sand-50);color:var(--teal-800)}
.btn-light:hover{background:#fff;transform:translateY(-2px)}
.btn .ic{
  width:34px;height:34px;border-radius:50%;flex:none;
  background:rgba(255,255,255,.18);display:grid;place-items:center;
  transition:transform .45s var(--ease),background .35s var(--ease);
}
.btn-ghost .ic{background:rgba(21,80,73,.1)}
.btn:hover .ic{transform:translate(3px,-1px) scale(1.05)}
.btn .ic svg{width:15px;height:15px}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding:clamp(7rem,14vh,10rem) var(--gutter) clamp(3rem,6vw,5rem);
  background:
    radial-gradient(120% 90% at 78% 8%,rgba(216,97,43,.35),transparent 52%),
    radial-gradient(95% 70% at 8% 92%,rgba(45,120,108,.55),transparent 60%),
    linear-gradient(160deg,var(--teal-800),var(--teal-900) 70%);
  overflow:hidden;color:var(--sand-50);
}
.hero-mesh{position:absolute;inset:0;pointer-events:none;z-index:0;opacity:.9}
.hero-mesh .orb{position:absolute;border-radius:50%;filter:blur(60px);mix-blend-mode:screen;opacity:.55}
.orb-1{width:46vw;height:46vw;left:-8vw;top:-10vw;background:radial-gradient(circle,var(--teal-500),transparent 65%)}
.orb-2{width:38vw;height:38vw;right:-6vw;top:10vw;background:radial-gradient(circle,var(--orange),transparent 62%);opacity:.4}
.orb-3{width:30vw;height:30vw;left:30vw;bottom:-14vw;background:radial-gradient(circle,var(--orange-soft),transparent 60%);opacity:.3}
.hero-grain{position:absolute;inset:0;z-index:1;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero-inner{position:relative;z-index:3;max-width:var(--maxw);margin-inline:auto;width:100%}
.hero-eyebrow{margin-bottom:1.5rem;color:var(--orange-soft)}
.hero h1{
  font-size:clamp(3.3rem,9.5vw,8.6rem);
  line-height:.93;letter-spacing:-0.02em;max-width:16ch;
  color:var(--sand-50);
}
.hero h1 em{font-style:italic;color:var(--orange-soft)}
.hero-row{display:flex;flex-wrap:wrap;gap:2.4rem;align-items:flex-end;justify-content:space-between;margin-top:2.6rem}
.hero-sub{max-width:42ch;color:var(--sand-200);font-size:clamp(1.05rem,1.3vw,1.28rem);line-height:1.55}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-stats{display:flex;gap:clamp(1.5rem,4vw,3.5rem);margin-top:3.5rem;flex-wrap:wrap;border-top:1px solid rgba(217,198,164,.18);padding-top:1.8rem}
.hero-stat .num{font-family:var(--font-display);font-size:clamp(2rem,3.5vw,2.9rem);color:var(--sand-50);line-height:1}
.hero-stat .lbl{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--orange-soft);margin-top:.5rem}

/* clip reveal helper */
.reveal{opacity:0}
.reveal-up{transform:translateY(38px)}
.reveal-clip{clip-path:inset(0 100% 0 0)}
.is-in.reveal{opacity:1}
.is-in.reveal-up{transform:translateY(0)}
.is-in.reveal-clip{clip-path:inset(0 0 0 0)}
.reveal{transition:opacity .9s var(--ease),transform 1s var(--ease),clip-path 1.1s var(--ease)}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.4s}.d6{transition-delay:.48s}

/* line-by-line hero entrance */
.line-mask{overflow:hidden;display:block}
.line-inner{display:block;transform:translateY(105%);transition:transform 1.05s var(--ease)}
.loaded .line-inner{transform:translateY(0)}
.line-inner.l2{transition-delay:.12s}
.line-inner.l3{transition-delay:.24s}

/* ============================================================
   MARQUEE / TRUST
   ============================================================ */
.trust{background:var(--teal-900);color:var(--sand-200);padding-block:1.5rem;overflow:hidden;border-top:1px solid rgba(217,198,164,.1)}
.marquee{display:flex;gap:3.5rem;white-space:nowrap;width:max-content;animation:scrollx 32s linear infinite}
.marquee span{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sand-300);display:inline-flex;align-items:center;gap:3.5rem}
.marquee span::after{content:"✦";color:var(--orange)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ============================================================
   GENERIC SECTION HEADING
   ============================================================ */
.sec-head{max-width:62ch}
.sec-head .eyebrow{margin-bottom:1.1rem;display:block}
.sec-head h2{font-size:clamp(2.4rem,5.2vw,4.3rem);line-height:1}
.sec-head h2 em{font-style:italic;color:var(--orange)}
.sec-head p{margin-top:1.4rem;color:var(--teal-600);max-width:52ch}

/* ============================================================
   INTRO / WHO
   ============================================================ */
.intro{background:var(--sand-50)}
.intro-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:center}
.intro-copy h2{font-size:clamp(2.2rem,4.6vw,3.8rem);line-height:1.02;margin-bottom:1.6rem}
.intro-copy h2 em{font-style:italic;color:var(--orange)}
.intro-copy p{color:var(--teal-600);margin-bottom:1.1rem;max-width:50ch}
.intro-sign{margin-top:2rem;font-family:var(--font-display);font-size:1.5rem;color:var(--teal-700)}
.intro-sign small{display:block;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:.3rem}
.intro-media{position:relative}
.intro-media .shell{
  padding:10px;border-radius:var(--radius-lg);background:var(--sand-100);
  border:1px solid var(--sand-200);box-shadow:0 40px 80px -50px rgba(12,28,25,.5);
}
.intro-media img{border-radius:calc(var(--radius-lg) - 10px);aspect-ratio:4/5;object-fit:cover}
.intro-media .badge{
  position:absolute;bottom:-26px;left:-26px;background:var(--teal-800);color:var(--sand-50);
  padding:1.3rem 1.5rem;border-radius:18px;box-shadow:0 24px 50px -28px rgba(6,35,31,.8);max-width:230px;
}
.intro-media .badge .q{font-family:var(--font-display);font-size:1.25rem;line-height:1.15}
.intro-media .badge .a{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--orange-soft);margin-top:.7rem}

/* ============================================================
   PILLARS / SERVICES CARDS
   ============================================================ */
.pillars{background:var(--paper)}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:clamp(2.5rem,5vw,4rem)}
.pcard{
  position:relative;background:var(--sand-50);border:1px solid var(--sand-200);
  border-radius:var(--radius-lg);padding:2.2rem 2rem 2.4rem;overflow:hidden;
  transition:transform .6s var(--ease),box-shadow .6s var(--ease),border-color .6s var(--ease);
}
.pcard::before{content:"";position:absolute;inset:0;background:linear-gradient(150deg,var(--teal-800),var(--teal-700));opacity:0;transition:opacity .6s var(--ease);z-index:0}
.pcard:hover{transform:translateY(-8px);box-shadow:0 40px 70px -45px rgba(12,28,25,.45);border-color:transparent}
.pcard:hover::before{opacity:1}
.pcard>*{position:relative;z-index:1;transition:color .5s var(--ease)}
.pcard .pnum{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;color:var(--orange);text-transform:uppercase}
.pcard:hover .pnum{color:var(--orange-soft)}
.pcard .picon{width:54px;height:54px;border-radius:14px;background:var(--sand-200);display:grid;place-items:center;margin:1.4rem 0 1.5rem;transition:background .5s var(--ease)}
.pcard:hover .picon{background:rgba(240,163,104,.2)}
.pcard .picon svg{width:26px;height:26px;stroke:var(--teal-700);transition:stroke .5s var(--ease)}
.pcard:hover .picon svg{stroke:var(--orange-soft)}
.pcard h3{font-size:1.85rem;margin-bottom:.7rem;color:var(--ink)}
.pcard:hover h3{color:var(--sand-50)}
.pcard p{color:var(--teal-600);font-size:.96rem}
.pcard:hover p{color:var(--sand-200)}
.pcard .plink{margin-top:1.5rem;display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--orange)}
.pcard:hover .plink{color:var(--orange-soft)}

/* ============================================================
   APPROACH / STEPS (parallax band)
   ============================================================ */
.approach{position:relative;background:var(--teal-800);color:var(--sand-100);overflow:hidden}
.approach .layerbg{position:absolute;inset:0;z-index:0;
  background:radial-gradient(90% 60% at 80% 0,rgba(216,97,43,.32),transparent 55%),radial-gradient(70% 70% at 0 100%,rgba(45,120,108,.5),transparent 60%)}
.approach .wrap{position:relative;z-index:2}
.approach .sec-head h2{color:var(--sand-50)}
.approach .sec-head p{color:var(--sand-200)}
.steps{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin-top:clamp(2.5rem,5vw,4rem)}
.step{
  border:1px solid rgba(217,198,164,.18);border-radius:var(--radius);
  padding:2rem 2rem 2.2rem;background:rgba(251,246,236,.03);
  transition:background .5s var(--ease),transform .5s var(--ease);
}
.step:hover{background:rgba(251,246,236,.07);transform:translateY(-4px)}
.step .sn{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;color:var(--orange-soft)}
.step h3{font-size:1.7rem;color:var(--sand-50);margin:.9rem 0 .6rem}
.step p{color:var(--sand-200);font-size:.95rem}

/* ============================================================
   STATS BAND
   ============================================================ */
.statsband{background:var(--sand-100)}
.statsband-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.sb{padding:1.6rem 0;border-top:2px solid var(--teal-700)}
.sb .num{font-family:var(--font-display);font-size:clamp(2.6rem,5vw,4rem);color:var(--teal-800);line-height:.95}
.sb .num em{font-style:normal;color:var(--orange)}
.sb .lbl{margin-top:.6rem;font-size:.92rem;color:var(--teal-600);max-width:24ch}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi{background:var(--paper)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:clamp(2.5rem,5vw,4rem)}
.tcard{
  background:var(--sand-50);border:1px solid var(--sand-200);border-radius:var(--radius-lg);
  padding:2.2rem 2rem;display:flex;flex-direction:column;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.tcard:hover{transform:translateY(-6px);box-shadow:0 36px 64px -46px rgba(12,28,25,.4)}
.tcard .stars{color:var(--orange);font-size:.95rem;letter-spacing:.18em;margin-bottom:1.1rem}
.tcard blockquote{font-family:var(--font-display);font-size:1.4rem;line-height:1.25;color:var(--teal-800);flex:1}
.tcard .who{margin-top:1.6rem;display:flex;align-items:center;gap:.8rem}
.tcard .av{width:42px;height:42px;border-radius:50%;flex:none;background:linear-gradient(135deg,var(--orange-soft),var(--teal-500));display:grid;place-items:center;font-family:var(--font-mono);font-size:.8rem;color:#fff}
.tcard .who .nm{font-weight:600;font-size:.92rem}
.tcard .who .rl{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* ============================================================
   INSIGHTS (posts)
   ============================================================ */
.insights{background:var(--teal-900);color:var(--sand-100)}
.insights .sec-head h2{color:var(--sand-50)}
.insights .sec-head h2 em{color:var(--orange-soft)}
.insights .sec-head p{color:var(--sand-200)}
.ins-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:clamp(2.5rem,5vw,4rem)}
.icard{
  background:rgba(251,246,236,.035);border:1px solid rgba(217,198,164,.16);border-radius:var(--radius-lg);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .55s var(--ease),border-color .55s var(--ease),background .55s var(--ease)}
.icard:hover{transform:translateY(-7px);border-color:rgba(240,163,104,.4);background:rgba(251,246,236,.06)}
.icard .ph{aspect-ratio:16/10;overflow:hidden}
.icard .ph img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.icard:hover .ph img{transform:scale(1.06)}
.icard .body{padding:1.6rem 1.7rem 1.9rem;display:flex;flex-direction:column;flex:1}
.icard .cat{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--orange-soft)}
.icard h3{font-size:1.55rem;line-height:1.08;margin:.8rem 0 .7rem;color:var(--sand-50)}
.icard p{font-size:.9rem;color:var(--sand-200);flex:1}
.icard .meta{margin-top:1.3rem;display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sand-300)}
.icard .meta .arr{color:var(--orange-soft)}

/* ============================================================
   RESOURCES / BLOGROLL
   ============================================================ */
.resources{background:var(--sand-100)}
.res-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-top:2.5rem}
.res-item{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:var(--sand-50);border:1px solid var(--sand-200);border-radius:16px;
  padding:1.15rem 1.4rem;transition:transform .4s var(--ease),border-color .4s var(--ease),background .4s var(--ease)}
.res-item:hover{transform:translateY(-3px);border-color:var(--orange);background:#fff}
.res-item .rx{font-family:var(--font-body);font-weight:600;font-size:.95rem;color:var(--teal-800)}
.res-item .ra{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:.25rem}
.res-item .rarrow{color:var(--orange);flex:none;transition:transform .4s var(--ease)}
.res-item:hover .rarrow{transform:translate(3px,-3px)}

/* ============================================================
   CTA BAND
   ============================================================ */
.ctaband{position:relative;overflow:hidden;
  background:radial-gradient(110% 130% at 85% 10%,rgba(216,97,43,.45),transparent 50%),linear-gradient(160deg,var(--teal-700),var(--teal-900));
  color:var(--sand-50);text-align:center}
.ctaband .wrap{position:relative;z-index:2}
.ctaband h2{font-size:clamp(2.6rem,6.5vw,5.5rem);line-height:1;max-width:18ch;margin-inline:auto}
.ctaband h2 em{font-style:italic;color:var(--orange-soft)}
.ctaband p{margin:1.5rem auto 2.5rem;color:var(--sand-200);max-width:48ch}
.ctaband .hero-actions{justify-content:center}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--teal-900);color:var(--sand-200);padding-block:clamp(3.5rem,7vw,5.5rem) 2.5rem}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem}
.foot-brand .brand{color:var(--sand-50);margin-bottom:1.2rem}
.foot-brand p{max-width:34ch;color:var(--sand-300);font-size:.92rem}
.foot-col h4{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--orange-soft);font-weight:500;margin-bottom:1.1rem}
.foot-col a{display:block;font-size:.92rem;color:var(--sand-200);padding-block:.32rem;transition:color .3s var(--ease)}
.foot-col a:hover{color:#fff}
.foot-bottom{margin-top:3.5rem;padding-top:1.8rem;border-top:1px solid rgba(217,198,164,.14);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sand-300)}

/* ============================================================
   ARTICLE PAGE
   ============================================================ */
.article-hero{
  padding:clamp(8rem,16vh,11rem) var(--gutter) clamp(2.5rem,5vw,4rem);
  background:radial-gradient(90% 80% at 80% 0,rgba(216,97,43,.28),transparent 55%),linear-gradient(160deg,var(--teal-800),var(--teal-900));
  color:var(--sand-50);position:relative;overflow:hidden}
.article-hero .wrap{position:relative;z-index:2}
.crumbs{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sand-300);margin-bottom:1.6rem;display:flex;gap:.6rem;flex-wrap:wrap}
.crumbs a{color:var(--orange-soft)}
.article-hero h1{font-size:clamp(2.5rem,6vw,5rem);line-height:1;max-width:20ch}
.article-hero .meta{margin-top:1.8rem;display:flex;gap:1.6rem;flex-wrap:wrap;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sand-300)}
.article-hero .meta span{color:var(--orange-soft)}
.article-body{background:var(--paper);padding-block:clamp(3rem,7vw,6rem)}
.article-shell{max-width:760px;margin-inline:auto;padding-inline:var(--gutter)}
.article-figure{max-width:1040px;margin:0 auto clamp(2.5rem,5vw,4rem);padding-inline:var(--gutter)}
.article-figure img{border-radius:var(--radius-lg);width:100%;aspect-ratio:16/9;object-fit:cover;box-shadow:0 40px 80px -55px rgba(12,28,25,.6)}
.prose{font-size:1.1rem;line-height:1.78;color:var(--teal-800)}
.prose>p{margin-bottom:1.5rem}
.prose h2{font-size:clamp(1.9rem,3.4vw,2.7rem);line-height:1.05;margin:2.8rem 0 1.1rem;color:var(--ink)}
.prose h3{font-size:clamp(1.35rem,2.4vw,1.7rem);margin:2rem 0 .8rem;color:var(--teal-800)}
.prose a{color:var(--orange);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px;font-weight:500;transition:color .3s var(--ease)}
.prose a:hover{color:var(--orange-bright)}
.prose strong{color:var(--ink);font-weight:600}
.prose ul,.prose ol{margin:0 0 1.6rem 1.3rem}
.prose li{margin-bottom:.6rem;padding-left:.3rem}
.prose li::marker{color:var(--orange)}
.prose img{border-radius:var(--radius);margin:2rem 0;box-shadow:0 30px 60px -45px rgba(12,28,25,.5)}
.prose section{margin-top:3rem;border-top:1px solid var(--sand-200);padding-top:2rem}
.prose section h2{margin-top:0}
.prose section div[itemprop="name"],.prose section h3{font-size:1.25rem;color:var(--teal-800);margin-top:1.6rem;font-family:var(--font-display);font-weight:400}
.prose section h3{cursor:default}
.prose [itemprop="text"]{color:var(--teal-600);font-size:1rem;margin-top:.4rem}
.article-cta{margin-top:clamp(3rem,6vw,5rem);background:var(--sand-50);border:1px solid var(--sand-200);border-radius:var(--radius-lg);padding:clamp(2rem,4vw,3rem);text-align:center}
.article-cta h3{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:.8rem;color:var(--teal-800)}
.article-cta h3 em{font-style:italic;color:var(--orange)}
.article-cta p{color:var(--teal-600);max-width:44ch;margin:0 auto 1.6rem}

/* ============================================================
   GENERIC PAGE HERO (about/services/contact)
   ============================================================ */
.page-hero{
  padding:clamp(8rem,16vh,12rem) var(--gutter) clamp(3rem,6vw,5rem);
  background:radial-gradient(80% 80% at 85% 5%,rgba(216,97,43,.3),transparent 55%),linear-gradient(160deg,var(--teal-800),var(--teal-900));
  color:var(--sand-50);position:relative;overflow:hidden}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .eyebrow{color:var(--orange-soft);margin-bottom:1.3rem;display:block}
.page-hero h1{font-size:clamp(3rem,8vw,7rem);line-height:.96;max-width:16ch}
.page-hero h1 em{font-style:italic;color:var(--orange-soft)}
.page-hero p{margin-top:1.8rem;max-width:50ch;color:var(--sand-200);font-size:clamp(1.05rem,1.3vw,1.25rem)}

/* about team */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:clamp(2.5rem,5vw,4rem)}
.tm{background:var(--sand-50);border:1px solid var(--sand-200);border-radius:var(--radius-lg);overflow:hidden;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.tm:hover{transform:translateY(-6px);box-shadow:0 36px 64px -48px rgba(12,28,25,.4)}
.tm .tmav{aspect-ratio:1;background:linear-gradient(150deg,var(--teal-600),var(--teal-800));display:grid;place-items:center;font-family:var(--font-display);font-size:3.2rem;color:var(--orange-soft)}
.tm .tmbody{padding:1.5rem 1.6rem 1.8rem}
.tm h3{font-size:1.5rem;color:var(--teal-800)}
.tm .role{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--orange);margin:.3rem 0 .8rem}
.tm p{font-size:.9rem;color:var(--teal-600)}

.values-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin-top:clamp(2.5rem,5vw,4rem)}
.value{border:1px solid var(--sand-200);background:var(--sand-50);border-radius:var(--radius);padding:2rem;display:flex;gap:1.4rem}
.value .vn{font-family:var(--font-mono);font-size:.8rem;color:var(--orange);letter-spacing:.1em}
.value h3{font-size:1.55rem;color:var(--teal-800);margin-bottom:.5rem}
.value p{color:var(--teal-600);font-size:.95rem}

/* services list */
.svc{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(2rem,5vw,5rem);align-items:center;padding-block:clamp(2.5rem,5vw,4rem);border-top:1px solid var(--sand-200)}
.svc:nth-child(even) .svc-media{order:2}
.svc-tag{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--orange)}
.svc h2{font-size:clamp(2rem,4vw,3.2rem);line-height:1.02;margin:1rem 0 1.1rem}
.svc p{color:var(--teal-600);margin-bottom:1.3rem;max-width:46ch}
.svc ul{list-style:none;display:flex;flex-direction:column;gap:.7rem}
.svc li{display:flex;gap:.7rem;align-items:flex-start;font-size:.96rem;color:var(--teal-700)}
.svc li svg{width:18px;height:18px;flex:none;margin-top:.25rem;stroke:var(--orange)}
.svc-media .shell{padding:9px;background:var(--sand-100);border:1px solid var(--sand-200);border-radius:var(--radius-lg)}
.svc-media img{border-radius:calc(var(--radius-lg) - 9px);aspect-ratio:5/4;object-fit:cover}
.svc-price{margin-top:1.4rem;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;color:var(--teal-700)}
.svc-price strong{color:var(--orange);font-size:1rem}

/* contact form */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2.5rem,6vw,5rem);align-items:start}
.contact-info h2{font-size:clamp(2rem,4vw,3rem);line-height:1.02;margin-bottom:1.3rem}
.contact-info h2 em{font-style:italic;color:var(--orange)}
.contact-info p{color:var(--teal-600);margin-bottom:2rem;max-width:40ch}
.contact-detail{display:flex;gap:1rem;align-items:flex-start;padding-block:1.1rem;border-top:1px solid var(--sand-200)}
.contact-detail .ci{width:42px;height:42px;border-radius:12px;background:var(--sand-100);display:grid;place-items:center;flex:none}
.contact-detail .ci svg{width:20px;height:20px;stroke:var(--orange)}
.contact-detail .cl{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.contact-detail .cv{font-size:1.02rem;color:var(--teal-800);font-weight:500}
.contact-detail a.cv:hover{color:var(--orange)}
.form-shell{background:var(--sand-50);border:1px solid var(--sand-200);border-radius:var(--radius-lg);padding:clamp(1.8rem,4vw,2.8rem);box-shadow:0 40px 80px -55px rgba(12,28,25,.45)}
.field{margin-bottom:1.4rem}
.field label{display:block;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-700);margin-bottom:.55rem}
.field input,.field textarea{
  width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);
  background:var(--paper);border:1.5px solid var(--sand-300);border-radius:14px;
  padding:.95rem 1.1rem;transition:border-color .3s var(--ease),box-shadow .3s var(--ease)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 4px rgba(216,97,43,.12)}
.field textarea{resize:vertical;min-height:130px}
.form-shell .btn{width:100%;justify-content:center;margin-top:.4rem}
.form-note{margin-top:1rem;font-size:.78rem;color:var(--muted);text-align:center}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:960px){
  .nav{
    position:fixed;inset:0;flex-direction:column;justify-content:center;gap:1.6rem;
    background:rgba(6,35,31,.96);backdrop-filter:blur(20px);
    transform:translateY(-100%);transition:transform .6s var(--ease);z-index:110}
  body.menu-open .nav{transform:translateY(0)}
  .nav a{font-size:1.6rem;font-family:var(--font-display);color:var(--sand-50)}
  .nav-cta{font-size:1rem}
  .nav-toggle{display:block}
  .intro-grid,.contact-grid{grid-template-columns:1fr}
  .pillars-grid,.testi-grid,.ins-grid,.team-grid,.res-grid{grid-template-columns:1fr 1fr}
  .statsband-grid{grid-template-columns:1fr 1fr}
  .steps,.values-grid{grid-template-columns:1fr}
  .svc{grid-template-columns:1fr}
  .svc-media{order:-1 !important}
  .foot-top{grid-template-columns:1fr 1fr}
  .intro-media .badge{left:0}
}
@media(max-width:600px){
  .pillars-grid,.testi-grid,.ins-grid,.team-grid,.statsband-grid,.res-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .hero-stats{gap:1.4rem}
  .intro-media .badge{position:static;margin-top:1rem;max-width:none}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1 !important;transform:none !important;clip-path:none !important}
  .line-inner{transform:none !important}
  .marquee{animation:none}
}
