/* ============================================================
   NORVIK — style.css (reads ONLY var(--token) from tokens.css)
   Luxe monochrome agency. Reconstructed from altrum DNA: dark canvas,
   oversized condensed display, acid-green + Caveat micro-labels,
   numbered callouts (01/02/03), editorial portrait imagery with tonal
   overlays, numbered services list, two-plan pricing, giant footer wordmark.
   ============================================================ */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:var(--fs-body);line-height:1.6;
  color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* —— layout —— */
.section{background:var(--bg);color:var(--ink);position:relative}
.wrap{max-width:var(--container);margin-inline:auto;padding:var(--section-y) var(--gutter)}
.wrap-tight{max-width:58rem;margin-inline:auto;padding-inline:var(--gutter)}

/* —— typography —— */
.display,h1{font-family:var(--font-display);font-size:var(--fs-display);font-weight:var(--w-black);
  letter-spacing:var(--tracking-tight);line-height:var(--lh-display);text-transform:uppercase}
.h2,h2{font-family:var(--font-display);font-size:var(--fs-h2);font-weight:var(--w-bold);
  letter-spacing:var(--tracking-tight);line-height:var(--lh-h2);text-transform:uppercase}
.h3,h3{font-family:var(--font-display);font-size:var(--fs-h3);font-weight:var(--w-semi);letter-spacing:var(--tracking-tight)}
.lead{font-size:var(--fs-lead);color:var(--body);line-height:1.55;max-width:56ch}
.muted{color:var(--body)}
.reg{font-weight:var(--w-reg)}
.accent{color:var(--accent)}

/* eyebrow / label — uppercase tracked; optional Caveat script twin */
.eyebrow{display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-body);
  font-size:var(--fs-eyebrow);font-weight:var(--w-semi);letter-spacing:var(--tracking-eyebrow);
  text-transform:var(--eyebrow-transform);color:var(--body)}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex:none}
.script{font-family:var(--font-script);font-size:1.5rem;font-weight:500;color:var(--accent);
  text-transform:none;letter-spacing:0;line-height:1}

/* —— buttons — pill, off-white fill inverting; green as accent rail —— */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-body);font-weight:var(--w-semi);
  font-size:.95rem;padding:.95em 1.7em;border-radius:var(--radius-pill);cursor:pointer;
  border:var(--bw) solid var(--ink);
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:transparent;color:var(--ink)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--border)}
.btn-ghost:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn-accent{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.btn-accent:hover{background:var(--accent-strong);border-color:var(--accent-strong)}
.btn-arrow::after{content:"\2192";transition:transform var(--dur) var(--ease)}
.btn-arrow:hover::after{transform:translateX(4px)}

/* —— nav —— */
.nav{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--bg) 82%,transparent);
  backdrop-filter:blur(12px);border-bottom:var(--bw) solid transparent;transition:border-color var(--dur) var(--ease)}
.nav.is-stuck{border-color:var(--border)}
.nav-row{max-width:var(--container);margin-inline:auto;padding:1.05rem var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:1rem}
.nav-logo{font-family:var(--font-display);font-weight:var(--w-black);font-size:1.5rem;letter-spacing:-.02em;
  text-transform:uppercase;display:inline-flex;align-items:flex-start;gap:.08rem}
.nav-logo .sup{font-size:.5em;font-weight:var(--w-semi);vertical-align:super;color:var(--accent);margin-top:.15em}
.nav-links{display:flex;align-items:center;gap:1.7rem}
.nav-links a{font-family:var(--font-body);font-weight:var(--w-med);font-size:.92rem;color:var(--body);
  transition:color var(--dur) var(--ease)}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.nav-burger{display:none;background:none;border:var(--bw) solid var(--border);border-radius:var(--radius-pill);
  width:44px;height:44px;font-size:1.2rem;cursor:pointer;color:var(--ink)}

/* —— hero — statement wordmark + editorial portrait —— */
.hero .wrap{padding-top:clamp(3rem,7vw,5rem);padding-bottom:clamp(2.5rem,6vw,4rem)}
.hero-top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem;margin-bottom:clamp(1.6rem,4vw,2.6rem)}
.hero-h1{margin:0;letter-spacing:-.03em;line-height:.92}
.hero-h1 .sup{font-size:.28em;font-weight:var(--w-semi);vertical-align:super;color:var(--accent)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(1.5rem,4vw,3rem);align-items:end;margin-top:clamp(2rem,5vw,3.2rem)}
.hero-lead{max-width:46ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}
.hero-portrait{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;background:var(--surface-alt)}
.hero-portrait img{width:100%;height:100%;object-fit:cover}
.hero-portrait::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(255,214,232,.10),rgba(7,7,7,.55));mix-blend-mode:normal}
.hero-media-wide{margin-top:clamp(2rem,5vw,3rem);border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:16/7;background:var(--surface-alt)}
.hero-media-wide img{width:100%;height:100%;object-fit:cover}

/* —— word marquee (signature service-word strip) —— */
.marquee-strip{border-top:var(--bw) solid var(--border);border-bottom:var(--bw) solid var(--border);
  background:var(--bg-alt);padding-block:clamp(1.3rem,3vw,1.9rem)}
.marquee{overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent,#000 var(--marquee-fade),#000 calc(100% - var(--marquee-fade)),transparent);
  mask:linear-gradient(90deg,transparent,#000 var(--marquee-fade),#000 calc(100% - var(--marquee-fade)),transparent)}
.marquee-track{display:flex;width:max-content;gap:0;align-items:center;animation:marquee var(--marquee-speed) linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{font-family:var(--font-display);font-weight:var(--w-bold);text-transform:uppercase;
  font-size:clamp(1.5rem,3.2vw,2.4rem);letter-spacing:-.01em;color:var(--ink);white-space:nowrap;
  display:inline-flex;align-items:center}
.marquee-item::after{content:"\2217";margin-inline:clamp(1rem,3vw,2.2rem);color:var(--accent);font-size:.7em}
@keyframes marquee{to{transform:translateX(-50%)}}

/* —— head row (eyebrow + heading + side) —— */
.head{display:flex;justify-content:space-between;align-items:flex-end;gap:1.5rem;flex-wrap:wrap;margin-bottom:clamp(2rem,4vw,3rem)}
.head .h2{max-width:18ch;margin-top:.9rem}
.head .lead{margin-top:1rem;max-width:42ch}

/* —— numbered callouts (01/02/03 intro) —— */
.callouts{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,3vw,2rem)}
.callout{border-top:2px solid var(--border);padding-top:1.4rem;transition:border-color var(--dur) var(--ease)}
.callout:hover{border-color:var(--accent)}
.callout .num{font-family:var(--font-display);font-weight:var(--w-bold);color:var(--accent);font-size:1.05rem;letter-spacing:.04em}
.callout h3{margin:1rem 0 .6rem}
.callout p{color:var(--body);font-size:.98rem}

/* —— intro statement (big editorial paragraph) —— */
.statement{max-width:30ch;font-family:var(--font-display);font-weight:var(--w-semi);text-transform:uppercase;
  letter-spacing:-.02em;line-height:1.1;font-size:var(--fs-h3)}
.statement .accent{color:var(--accent)}

/* —— work grid (editorial cards w/ tonal overlay) —— */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.2rem,2.5vw,1.75rem)}
.work-card{display:block;border-radius:var(--radius-lg);overflow:hidden;position:relative;
  border:var(--bw) solid var(--border);background:var(--card)}
.work-media{aspect-ratio:4/3;overflow:hidden;background:var(--surface-alt);position:relative}
.work-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur) var(--ease)}
.work-card:hover .work-media img{transform:var(--hover-img)}
.work-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(7,7,7,.7))}
.work-body{position:absolute;left:0;right:0;bottom:0;padding:clamp(1.3rem,2.5vw,1.8rem);
  display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;z-index:1}
.work-body .name{font-family:var(--font-display);font-weight:var(--w-bold);text-transform:uppercase;font-size:1.3rem;color:#fff}
.work-body .cat{color:var(--accent);font-size:.85rem;white-space:nowrap;font-weight:var(--w-med)}

/* —— services list (numbered rows, altrum 01..07) —— */
.srv-rows{border-top:var(--bw) solid var(--border)}
.srv-row{display:grid;grid-template-columns:auto 1.1fr 1.5fr auto;gap:clamp(1rem,3vw,2.5rem);align-items:center;
  padding:clamp(1.5rem,3vw,2.2rem) 0;border-bottom:var(--bw) solid var(--border);
  transition:padding-left var(--dur) var(--ease)}
.srv-row:hover{padding-left:.9rem}
.srv-row .num{font-family:var(--font-display);color:var(--accent);font-weight:var(--w-bold);font-size:1rem}
.srv-row h3{margin:0;text-transform:uppercase;font-weight:var(--w-bold);letter-spacing:-.01em}
.srv-row p{color:var(--body);margin:0;font-size:.96rem}
.srv-row .arrow{font-size:1.3rem;color:var(--body);transition:transform var(--dur) var(--ease),color var(--dur) var(--ease)}
.srv-row:hover .arrow{color:var(--accent);transform:translateX(5px)}

/* —— services cards (alt grid) —— */
.srv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:clamp(1.2rem,2.5vw,1.75rem)}
.srv-card{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-lg);
  padding:clamp(1.6rem,3vw,2.4rem);transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.srv-card:hover{transform:var(--hover-card);border-color:var(--accent)}
.srv-card .num{font-family:var(--font-display);color:var(--accent);font-weight:var(--w-bold);font-size:1rem}
.srv-card h3{margin:1.2rem 0 .6rem;text-transform:uppercase;font-weight:var(--w-bold)}
.srv-card p{color:var(--body)}

/* —— stats band (count-up) —— */
.stats-band{border-block:var(--bw) solid var(--border);background:var(--bg-alt)}
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:clamp(1.5rem,4vw,3rem)}
.stat-item .n{font-family:var(--font-display);font-size:clamp(2.6rem,6vw,4rem);font-weight:var(--w-black);
  letter-spacing:-.03em;line-height:1;color:var(--ink)}
.stat-item .n .accent{color:var(--accent)}
.stat-item .l{color:var(--body);font-size:.95rem;margin-top:.6rem;max-width:22ch}

/* —— about split / media-text —— */
.split{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.split-media{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;background:var(--surface-alt);position:relative}
.split-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur) var(--ease)}
.split-media:hover img{transform:var(--hover-img)}
.split .lead{margin:1.2rem 0 1.6rem}

/* —— testimonials —— */
.quotes{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:clamp(1.2rem,2.5vw,1.75rem)}
.quote{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-lg);
  padding:clamp(1.8rem,3vw,2.4rem);display:flex;flex-direction:column;gap:1.6rem}
.quote .mark{font-family:var(--font-display);color:var(--accent);font-size:2.4rem;line-height:.6;font-weight:var(--w-black)}
.quote p{line-height:1.55;font-size:1.08rem;color:var(--ink)}
.quote .who{display:flex;align-items:center;gap:.85rem;margin-top:auto}
.quote .who img{width:52px;height:52px;border-radius:50%;object-fit:cover}
.quote .who .nm{font-family:var(--font-display);font-weight:var(--w-bold);font-size:1rem;display:block;text-transform:uppercase}
.quote .who .rl{font-size:.85rem;color:var(--body)}

/* —— reel / video CTA —— */
.reel{position:relative;border-radius:var(--radius-huge);overflow:hidden;aspect-ratio:16/8;background:var(--surface-alt)}
.reel img{width:100%;height:100%;object-fit:cover}
.reel::after{content:"";position:absolute;inset:0;background:rgba(7,7,7,.45)}
.reel-inner{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.2rem;text-align:center;padding:1.5rem}
.reel-play{width:84px;height:84px;border-radius:50%;border:var(--bw) solid #fff;display:grid;place-items:center;
  background:rgba(255,255,255,.08);transition:background var(--dur) var(--ease),transform var(--dur) var(--ease)}
.reel-play::before{content:"";border-left:18px solid #fff;border-block:11px solid transparent;margin-left:5px}
.reel:hover .reel-play{background:var(--accent);transform:scale(1.06)}
.reel:hover .reel-play::before{border-left-color:var(--accent-ink)}
.reel h2,.reel p{color:#fff}

/* —— pricing (two plans) —— */
.price-wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.2rem,3vw,2rem);align-items:stretch}
.price-card{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-huge);
  padding:clamp(2rem,4vw,3rem);display:flex;flex-direction:column}
.price-card.is-feature{border-color:var(--accent)}
.price-card .plan{font-family:var(--font-display);font-weight:var(--w-bold);text-transform:uppercase;font-size:1.2rem}
.price-card .tag{color:var(--accent);font-size:.85rem;font-weight:var(--w-semi);margin-bottom:1.2rem}
.price-now{font-family:var(--font-display);font-size:clamp(1.9rem,4vw,2.6rem);font-weight:var(--w-black);letter-spacing:-.02em;line-height:1.05}
.price-now .per{font-size:1rem;font-weight:var(--w-med);color:var(--body)}
.price-meta{color:var(--body);font-size:.92rem;margin-top:.7rem}
.price-feature-list{list-style:none;display:grid;gap:.9rem;margin:1.8rem 0;flex:1}
.price-feature-list li{display:flex;gap:.7rem;align-items:flex-start;color:var(--body)}
.price-feature-list li::before{content:"\2713";color:var(--accent);font-weight:var(--w-bold)}
.price-card .btn{margin-top:auto}

/* —— process steps —— */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(1.2rem,2.5vw,1.75rem)}
.step{border-top:2px solid var(--border);padding-top:1.4rem;transition:border-color var(--dur) var(--ease)}
.step:hover{border-color:var(--accent)}
.step-n{font-family:var(--font-display);font-weight:var(--w-bold);color:var(--accent);font-size:1.05rem}
.step h3{font-size:1.2rem;margin:.9rem 0 .5rem;text-transform:uppercase;font-weight:var(--w-bold)}
.step p{color:var(--body)}

/* —— faq —— */
.faq-list{border-top:var(--bw) solid var(--border)}
.faq-item{border-bottom:var(--bw) solid var(--border)}
.faq-item summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;
  padding:clamp(1.4rem,3vw,1.9rem) 0;font-family:var(--font-display);font-weight:var(--w-semi);font-size:1.15rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-q-num{color:var(--accent);font-weight:var(--w-bold);margin-right:.9rem}
.faq-item summary .sign{margin-left:auto;font-size:1.4rem;color:var(--accent);transition:transform var(--dur) var(--ease);flex:none}
.faq-item[open] summary .sign{transform:rotate(45deg)}
.faq-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--dur) var(--ease)}
.faq-item[open] .faq-body{grid-template-rows:1fr}
.faq-body>div{overflow:hidden;min-height:0}
.faq-body p{color:var(--body);padding-bottom:clamp(1.3rem,3vw,1.8rem);max-width:72ch}

/* —— blog / journal —— */
.posts{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:clamp(1.2rem,2.5vw,1.75rem)}
.post{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-lg);overflow:hidden;
  transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.post:hover{transform:var(--hover-card);border-color:var(--accent)}
.post-media{aspect-ratio:16/10;overflow:hidden;background:var(--surface-alt)}
.post-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur) var(--ease)}
.post:hover .post-media img{transform:var(--hover-img)}
.post-body{padding:clamp(1.4rem,2.5vw,1.8rem)}
.post-meta{display:flex;gap:.6rem;align-items:center;color:var(--accent);font-size:.82rem;margin-bottom:.8rem;
  text-transform:uppercase;letter-spacing:.08em;font-weight:var(--w-semi)}
.post-body h3{margin-bottom:.6rem;text-transform:uppercase;font-weight:var(--w-bold);font-size:1.25rem}
.post-body p{color:var(--body);font-size:.95rem}

/* —— team —— */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:clamp(1.2rem,2.5vw,1.75rem)}
.member{border-radius:var(--radius-lg);overflow:hidden;background:var(--card);border:var(--bw) solid var(--border);
  transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.member:hover{transform:var(--hover-card);border-color:var(--accent)}
.member-media{aspect-ratio:3/4;overflow:hidden;background:var(--surface-alt)}
.member-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur) var(--ease)}
.member:hover .member-media img{transform:var(--hover-img)}
.member-body{padding:1.3rem 1.4rem 1.6rem}
.member-body .nm{font-family:var(--font-display);font-weight:var(--w-bold);font-size:1.1rem;display:block;text-transform:uppercase}
.member-body .rl{color:var(--accent);font-size:.88rem;margin-top:.25rem}

/* —— newsletter —— */
.news{background:var(--card);border:var(--bw) solid var(--border);border-radius:var(--radius-huge);
  padding:clamp(2rem,5vw,3.5rem);text-align:center}
.news form{display:flex;gap:.7rem;max-width:30rem;margin:1.6rem auto 0;flex-wrap:wrap;justify-content:center}
.news input{flex:1 1 220px;font-family:var(--font-body);font-size:1rem;color:var(--ink);background:var(--bg);
  border:var(--bw) solid var(--border);border-radius:var(--radius-pill);padding:.9em 1.4em}
.news input:focus{outline:none;border-color:var(--accent)}

/* —— work case list (rows) —— */
.case-list{border-top:var(--bw) solid var(--border)}
.case-row{display:grid;grid-template-columns:auto 1.3fr 1fr auto;gap:clamp(1rem,3vw,2.5rem);align-items:center;
  padding:clamp(1.5rem,3vw,2.2rem) 0;border-bottom:var(--bw) solid var(--border);transition:padding-left var(--dur) var(--ease)}
.case-row:hover{padding-left:.9rem}
.case-row .num{font-family:var(--font-display);color:var(--accent);font-weight:var(--w-bold)}
.case-row h3{margin:0;text-transform:uppercase;font-weight:var(--w-bold)}
.case-row .meta{color:var(--body);font-size:.92rem}
.case-row .yr{color:var(--accent);font-size:.9rem;font-weight:var(--w-semi)}

/* —— cta (big text) —— */
.cta{text-align:center}
.cta .display{margin:0 auto .8rem;max-width:16ch}
.cta-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:1.8rem}

/* —— contact —— */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:start}
.info-list{display:flex;flex-direction:column;gap:1.5rem}
.info-item .k{font-family:var(--font-body);font-size:.76rem;text-transform:uppercase;letter-spacing:.14em;
  color:var(--accent);margin-bottom:.4rem;font-weight:var(--w-semi)}
.info-item .v{font-size:1.1rem;font-weight:var(--w-med);color:var(--ink)}
.form{display:grid;gap:1rem}
.field{display:grid;gap:.45rem}
.field label{font-family:var(--font-body);font-size:.85rem;font-weight:var(--w-semi);color:var(--body)}
.field input,.field textarea{font-family:var(--font-body);font-size:1rem;color:var(--ink);background:var(--card);
  border:var(--bw) solid var(--border);border-radius:var(--radius-md);padding:.9em 1.1em;width:100%;
  transition:border-color var(--dur) var(--ease)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field textarea{min-height:150px;resize:vertical}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form .btn{justify-self:start;margin-top:.4rem}
.map-embed{border-radius:var(--radius-lg);overflow:hidden;border:var(--bw) solid var(--border);margin-top:2rem}
.map-embed iframe{width:100%;height:300px;border:0;display:block;filter:grayscale(1) invert(.92) contrast(.9)}

/* —— page hero (subpages) —— */
.page-hero .wrap{padding-top:clamp(3rem,7vw,4.5rem);padding-bottom:clamp(1.5rem,4vw,2.5rem)}
.page-hero .eyebrow{margin-bottom:1.2rem}
.page-hero .display{max-width:16ch}
.page-hero .lead{margin-top:1.4rem}
.crumb{display:flex;gap:.5rem;align-items:center;color:var(--body);font-size:.85rem;margin-bottom:1.4rem}
.crumb a:hover{color:var(--accent)}

/* —— footer — giant wordmark —— */
.footer .wrap{padding-bottom:2.5rem}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem;padding-bottom:3rem;
  border-bottom:var(--bw) solid var(--border)}
.footer-brand .nav-logo{font-size:1.9rem;margin-bottom:1rem}
.footer-brand .muted{max-width:38ch}
.footer-col h4{font-family:var(--font-body);font-size:.76rem;text-transform:uppercase;letter-spacing:.14em;
  color:var(--accent);margin-bottom:1.1rem;font-weight:var(--w-semi)}
.footer-col a{display:block;color:var(--body);padding:.35rem 0;transition:color var(--dur) var(--ease)}
.footer-col a:hover{color:var(--ink)}
.wordmark{font-family:var(--font-display);font-weight:var(--w-black);font-size:var(--fs-wordmark);
  line-height:.82;letter-spacing:-.04em;text-align:center;color:var(--ink);margin-top:clamp(2rem,5vw,3.5rem);
  text-transform:uppercase;white-space:nowrap;overflow:hidden}
.wordmark .sup{font-size:.18em;color:var(--accent);vertical-align:super}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  padding-top:1.8rem;color:var(--body);font-size:.88rem}
.footer-bottom a:hover{color:var(--accent)}

/* ============================================================
   ANIMATIONS — baseline R2 (fade from LEFT, 0.15s delay) + extracted.
   start-state ONLY with JS active (.js) → no JS = text visible.
   ============================================================ */
.js [data-reveal]{opacity:0;transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease);transition-delay:var(--base-delay)}
.js [data-reveal="left"],.js [data-reveal=""]{transform:translateX(var(--base-x))}
.js [data-reveal="right"]{transform:translateX(calc(-1 * var(--base-x)))}
.js [data-reveal="up"]{transform:translateY(var(--reveal-shift))}
.js [data-reveal="down"]{transform:translateY(calc(-1 * var(--reveal-shift)))}
.js [data-reveal="fade"]{transform:none}
.js [data-reveal="scale"]{transform:scale(.94)}
.js [data-reveal].is-in{opacity:1;transform:none}
.js [data-delay="1"]{transition-delay:calc(var(--base-delay) + 1*var(--stagger))}
.js [data-delay="2"]{transition-delay:calc(var(--base-delay) + 2*var(--stagger))}
.js [data-delay="3"]{transition-delay:calc(var(--base-delay) + 3*var(--stagger))}
.js [data-delay="4"]{transition-delay:calc(var(--base-delay) + 4*var(--stagger))}
.js [data-delay="5"]{transition-delay:calc(var(--base-delay) + 5*var(--stagger))}
.js [data-delay="6"]{transition-delay:calc(var(--base-delay) + 6*var(--stagger))}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important;transition-delay:0!important}
  [data-reveal]{opacity:1!important;transform:none!important}
  .marquee-track{animation:none!important}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:960px){
  .hero-grid,.split,.price-wrap,.contact-grid{grid-template-columns:1fr}
  .callouts{grid-template-columns:1fr}
  .work-grid{grid-template-columns:1fr}
  .srv-row{grid-template-columns:auto 1fr auto;gap:1rem}
  .srv-row p{grid-column:1 / -1;grid-row:2}
  .case-row{grid-template-columns:auto 1fr auto;gap:1rem}
  .case-row .meta{grid-column:1 / -1;grid-row:2}
  .footer-top{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .nav-burger{display:block}
  .nav.is-open .nav-links{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:var(--bg);border-bottom:var(--bw) solid var(--border);padding:1.2rem var(--gutter);gap:1.1rem}
}
@media (max-width:560px){
  .footer-top{grid-template-columns:1fr}
  .field-2{grid-template-columns:1fr}
  .hero-media-wide{aspect-ratio:4/3}
  .nav-cta .btn-ghost{display:none}
}

/* ============================================================
   READABLE DETAIL PAGES — article (blog post) + case study
   Uses ONLY tokens from tokens.css. Dark luxe, hairline borders,
   readable measure ~68ch, h2 stays within the 65px cap.
   ============================================================ */
.article-hero .wrap{padding-bottom:clamp(1.5rem,4vw,2.5rem)}
.article-hero .eyebrow{margin-bottom:1.2rem}
.article-hero h1.display{max-width:18ch;margin-top:.2rem}
.article-hero .lead{margin-top:1.4rem;max-width:62ch}
.mini-link{display:inline-flex;align-items:center;gap:.4em;font-family:var(--font-body);
  font-size:.85rem;color:var(--body);margin-bottom:1.4rem;transition:color var(--dur) var(--ease)}
.mini-link:hover{color:var(--accent)}
.article-hero .eyebrow .sep{opacity:.5;margin:0 .1em}

.article-figure{margin-top:clamp(2rem,5vw,3rem)}
.article-figure img{display:block;width:100%;height:auto;border:var(--bw) solid var(--border);
  border-radius:var(--radius-lg);background:var(--surface-alt)}

/* at-a-glance meta row (case studies) */
.case-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);
  border:var(--bw) solid var(--border);border-radius:var(--radius-md);overflow:hidden;
  margin-top:clamp(2rem,5vw,3rem)}
.case-meta div{background:var(--card);padding:1.2rem 1.3rem}
.case-meta dt{font-family:var(--font-body);font-size:var(--fs-eyebrow);font-weight:var(--w-semi);
  letter-spacing:var(--tracking-eyebrow);text-transform:uppercase;color:var(--accent);margin-bottom:.5rem}
.case-meta dd{margin:0;font-family:var(--font-display);font-weight:var(--w-semi);
  font-size:var(--fs-h3);color:var(--ink);line-height:1.1}

/* long-form body */
.article-section .wrap{padding-top:clamp(2.5rem,5vw,3.5rem)}
.article-layout{max-width:68ch;margin-inline:auto}
.article-body h2{font-family:var(--font-display);font-size:var(--fs-h2);font-weight:var(--w-bold);
  line-height:var(--lh-h2);letter-spacing:var(--tracking-tight);color:var(--ink);
  margin:clamp(2.2rem,5vw,3rem) 0 1rem}
.article-body h2:first-child{margin-top:0}
.article-body p{font-size:var(--fs-body);line-height:1.7;color:var(--body);margin:0 0 1.2rem}
.article-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.article-body a:hover{color:var(--accent-strong)}
.article-body blockquote{margin:clamp(2rem,4vw,2.6rem) 0;padding:.2rem 0 .2rem 1.6rem;
  border-left:2px solid var(--accent);font-family:var(--font-display);font-weight:var(--w-semi);
  font-size:var(--fs-h3);line-height:1.3;color:var(--ink);max-width:60ch}
.article-body ul,.article-body ol{margin:0 0 1.4rem;padding-left:1.3rem;color:var(--body);
  font-size:var(--fs-body);line-height:1.7}
.article-body li{margin-bottom:.5rem}
.article-body li::marker{color:var(--accent)}

.article-next{margin-top:clamp(2.5rem,5vw,3.5rem);padding-top:1.6rem;
  border-top:var(--bw) solid var(--border)}
.article-next a{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-display);
  font-weight:var(--w-semi);font-size:var(--fs-h3);color:var(--ink);
  transition:color var(--dur) var(--ease)}
.article-next a:hover{color:var(--accent)}
.article-next .lbl{display:block;font-family:var(--font-body);font-size:var(--fs-eyebrow);
  font-weight:var(--w-semi);letter-spacing:var(--tracking-eyebrow);text-transform:uppercase;
  color:var(--body);margin-bottom:.5rem}

@media (max-width:720px){
  .case-meta{grid-template-columns:1fr 1fr}
}
