/* ─────────────────────────────────────────────────────────
   Yeti Design Co. — agency shell
   Design system v1.2 · cream + aubergine + dusty lavender
   ───────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --paper:#f5f1ea;
  --paper-2:#ede6dc;
  --paper-3:#e3d9cc;
  --surface:#ffffff;
  --ink:#2f2833;
  --ink-2:rgba(47,40,51,.66);
  --ink-3:rgba(47,40,51,.44);
  --ink-4:rgba(47,40,51,.22);
  --rule:rgba(47,40,51,.20);
  --rule-soft:rgba(47,40,51,.10);
  --accent:#9b80ad;
  --accent-2:#76608a;
  --accent-3:#c2adcf;
  --accent-soft:rgba(155,128,173,.14);
  --serif:'Fraunces', 'Times New Roman', serif;
  --sans:'Inter', system-ui, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;
  --max:1280px;
  --pad-x:32px;
}
html,body{background:var(--paper);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;font-feature-settings:'ss01','cv11'}
body{overflow-x:clip}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
::selection{background:var(--accent);color:#fff}

/* ─── Accessibility: keyboard focus ring (visible only on keyboard nav) ─── */
:focus{outline:none}
:focus-visible{outline:2px solid var(--accent-2);outline-offset:3px;border-radius:2px}
button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,summary:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent-2);outline-offset:3px;border-radius:2px}
.section--inverted :focus-visible{outline-color:var(--accent-3)}
.footer :focus-visible{outline-color:var(--accent-3)}

/* Skip to main content (visually hidden until focused) */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:14px 22px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;z-index:9999}
.skip-link:focus,.skip-link:focus-visible{left:16px;top:16px;outline:2px solid var(--accent-3);outline-offset:3px}

/* Visually-hidden but readable to screen readers */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Tap delay removal + intentional tap highlight */
button,a,input[type=submit],input[type=button],.btn,.menu-toggle,.nav-cta,.rail-cta{touch-action:manipulation;-webkit-tap-highlight-color:rgba(155,128,173,.18)}

/* page wrappers */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad-x)}
.bleed{padding:0 var(--pad-x)}
.section{padding:120px 0;border-top:1px solid var(--rule-soft)}
.section--lavender{background:var(--paper-2)}
.section--deep{background:var(--paper-3)}
.section--inverted{background:var(--ink);color:var(--paper)}
.section--inverted .eyebrow{color:var(--accent-3)}
.section--inverted .h-display em,.section--inverted .h-section em{color:var(--accent-3)}
.section--inverted .lnk{color:var(--paper)}

/* ── Editorial top bar ────────────────────────────────── */
.topbar{position:sticky;top:0;z-index:50;background:linear-gradient(180deg,#bcaec6 0%,#b3a3bf 100%);color:#2f2833;border-bottom:1px solid rgba(47,40,51,.10);box-shadow:0 1px 0 rgba(255,255,255,.18) inset-soft)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;padding:18px var(--pad-x);max-width:var(--max);margin:0 auto;gap:32px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#2f2833;font-weight:500;white-space:nowrap;flex:0 0 auto}
.brand svg{display:block;flex:0 0 auto;color:#2f2833}
.brand-mark{font-family:var(--serif);font-style:italic;font-weight:300;font-size:18px;letter-spacing:-.01em;text-transform:none;color:#2f2833;white-space:nowrap}
.nav{display:flex;gap:32px;align-items:center}
.nav a{font-family:var(--sans);font-size:14px;color:rgba(47,40,51,.72);padding:6px 0;position:relative;transition:color .2s}
.nav a:hover{color:#2f2833}
.nav a.is-active{color:#2f2833}
.nav a.is-active::after{content:'';position:absolute;left:0;right:0;bottom:-2px;height:1px;background:#2f2833}
.topbar .right{display:flex;align-items:center;gap:18px;flex:0 0 auto}
.topbar .right .btn{white-space:nowrap;background:#2f2833;border-color:#2f2833;color:#f5f1ea}
.topbar .right .btn:hover{background:transparent;border-color:#2f2833;color:#2f2833}
@media (max-width:1024px){.topbar .right .status{display:none}}
.status{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:rgba(47,40,51,.65);display:flex;align-items:center;gap:8px}
.status::before{content:'';width:6px;height:6px;border-radius:50%;background:#2f2833;box-shadow:0 0 0 4px rgba(47,40,51,.12)}
.menu-toggle{display:none;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#2f2833;background:transparent;border:1px solid rgba(47,40,51,.4);padding:8px 14px;cursor:pointer}

/* mobile nav */
.mobile-nav{display:none;border-top:1px solid var(--rule-soft);padding:0 var(--pad-x);background:var(--paper)}
.mobile-nav.is-open{display:block}
.mobile-nav a{display:block;padding:14px 0;border-bottom:1px solid var(--rule-soft);font-size:18px;color:var(--ink);font-family:var(--serif);font-weight:300}
.mobile-nav a:last-of-type{border-bottom:0}

/* ── Type ─────────────────────────────────────────────── */
.h-display{font-family:var(--serif);font-weight:300;font-size:clamp(56px,9.5vw,168px);line-height:.92;letter-spacing:-.035em;color:var(--ink)}
.h-display em{font-style:italic;font-weight:300;color:var(--accent)}
.h-section{font-family:var(--serif);font-weight:300;font-size:clamp(40px,6vw,84px);line-height:.96;letter-spacing:-.025em;color:var(--ink)}
.h-section em{font-style:italic;font-weight:300;color:var(--accent)}
.h-card{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3.2vw,40px);line-height:1.02;letter-spacing:-.015em;color:var(--ink)}
.h-card em{font-style:italic;color:var(--accent)}
.body{font-family:var(--sans);font-weight:400;font-size:16px;line-height:1.7;color:var(--ink-2);max-width:54ch}
.body--lg{font-size:18px;line-height:1.65}
.lead{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.4vw,30px);line-height:1.4;letter-spacing:-.01em;color:var(--ink);max-width:34ch}
.lead em{font-style:italic;color:var(--accent)}
.small{font-family:var(--sans);font-size:13px;line-height:1.6;color:var(--ink-3)}
.eyebrow{font-family:var(--mono);font-weight:500;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-2);display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:'';width:24px;height:1px;background:currentColor;flex:0 0 24px}
.eyebrow--plain{color:var(--ink-3)}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.mono b{color:var(--ink);font-weight:500}

/* ── Buttons ──────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:14px;white-space:nowrap;
  font-family:var(--sans);font-weight:500;font-size:14px;letter-spacing:.005em;
  padding:18px 26px;
  background:transparent;color:var(--ink);
  border:1px solid var(--ink);border-radius:0;
  cursor:pointer;transition:background .22s ease,color .22s ease,border-color .22s ease;
}
/* Arrow: SVG mask — pixel-perfect, currentColor-aware, vector-clean */
.btn .arrow{display:inline-block;width:20px;height:12px;background:currentColor;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 12' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M1 6h17M13 1l5 5-5 5'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 12' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M1 6h17M13 1l5 5-5 5'/></svg>") center/contain no-repeat;vertical-align:middle;margin-left:2px;transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(3px)}
.btn:hover .arrow{width:28px}
.btn--primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn--primary:hover{background:var(--accent-2);border-color:var(--accent-2);color:#fff}
.btn--accent{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn--accent:hover{background:var(--accent-2);border-color:var(--accent-2)}
.btn--ghost{border-color:var(--rule);color:var(--ink-2)}
.btn--ghost:hover{border-color:var(--ink);color:var(--ink)}
.btn--lg{padding:22px 32px;font-size:15px}
.btn--pill{border-radius:999px}
.btn--sm{padding:10px 16px;font-size:12.5px;gap:10px}
.btn--accent.btn--pill{box-shadow:0 1px 0 rgba(0,0,0,.04)}

/* Pill chip — for tags / quick filter rows */
.chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--rule);border-radius:999px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);background:var(--paper);transition:color .2s ease,background-color .2s ease,border-color .2s ease,transform .2s ease;cursor:pointer;text-decoration:none}
.chip:hover{border-color:var(--ink);color:var(--ink);background:var(--surface)}
.chip.is-on{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.chip .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex:0 0 auto}

.lnk{
  font-family:var(--sans);font-weight:500;font-size:14px;
  display:inline-flex;align-items:center;gap:10px;color:var(--ink);
  padding-bottom:4px;
  background-image:linear-gradient(currentColor,currentColor);
  background-size:0 1px;background-repeat:no-repeat;background-position:0 100%;
  transition:background-size .35s ease;
}
.lnk:hover{background-size:100% 1px}
.lnk .arrow{display:inline-block;width:18px;height:10px;background:currentColor;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 10' fill='none' stroke='black' stroke-width='1.25' stroke-linecap='round' stroke-linejoin='round'><path d='M1 5h15M11.5 1l4 4-4 4'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 10' fill='none' stroke='black' stroke-width='1.25' stroke-linecap='round' stroke-linejoin='round'><path d='M1 5h15M11.5 1l4 4-4 4'/></svg>") center/contain no-repeat;vertical-align:middle;margin-left:4px;transition:transform .25s ease}
.lnk:hover .arrow{transform:translateX(3px)}

/* ── Section header (eyebrow + headline) ─────────────── */
.sect-head{padding-top:32px;margin-bottom:56px;border-top:1px solid var(--rule-soft)}
.sect-head .meta{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);font-weight:500;margin-bottom:24px;display:block}
.sect-head .meta b{font-weight:500}
.sect-head .meta br,.sect-head .meta em{display:none}

/* hairline rules */
.rule{height:1px;background:var(--rule-soft);width:100%}
.rule--accent{height:1px;background:var(--accent);width:64px}

/* ── Hero ─────────────────────────────────────────────── */
.hero{padding:80px 0 120px;position:relative;overflow:hidden}
.hero-tag{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:24px;margin-bottom:64px;border-bottom:1px solid var(--rule-soft);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);gap:24px;flex-wrap:wrap}
.hero-tag b{color:var(--ink);font-weight:500}
.hero-headline{margin:48px 0 56px;max-width:18ch}
.hero-foot{display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:end;padding-top:48px;border-top:1px solid var(--rule-soft);margin-top:24px}
.hero-foot p{font-size:15px;line-height:1.7;color:var(--ink-2);max-width:46ch}
.hero-actions{display:flex;flex-direction:column;gap:18px;align-items:flex-start}

/* ── Numbered list ────────────────────────────────────── */
.nlist{list-style:none;border-top:1px solid var(--rule-soft)}
.nlist li{display:grid;grid-template-columns:80px 1.1fr 1fr;gap:48px;padding:48px 0;border-bottom:1px solid var(--rule-soft);align-items:start;transition:background .25s ease;padding-left:0;padding-right:0}
.nlist li:hover{background:linear-gradient(90deg,transparent,var(--accent-soft) 50%,transparent)}
.nlist .n{font-family:var(--mono);font-weight:500;font-size:11px;letter-spacing:.08em;color:var(--accent-2);padding-top:8px}
.nlist .h{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3vw,40px);line-height:1.02;letter-spacing:-.015em;color:var(--ink)}
.nlist .h em{font-style:italic;color:var(--accent);font-weight:300}
.nlist .b{font-size:15px;line-height:1.7;color:var(--ink-2);max-width:46ch}

/* ── Photo / image plates ─────────────────────────────── */
.plate{background:var(--paper-3);position:relative;overflow:hidden}
.plate--ratio-43{aspect-ratio:4/3}
.plate--ratio-32{aspect-ratio:3/2}
.plate--ratio-11{aspect-ratio:1/1}
.plate--ratio-169{aspect-ratio:16/9}
.plate img{width:100%;height:100%;object-fit:cover}
.plate-cap{position:absolute;left:14px;bottom:14px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.78);background:rgba(58,47,68,.55);padding:6px 10px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.placeholder{width:100%;height:100%;background:repeating-linear-gradient(135deg,#dfd3da 0 14px,#d6c8d0 14px 28px);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);text-align:center;padding:24px}
.placeholder span{max-width:24ch}

/* ── Index card (work grid) ───────────────────────────── */
.idx{display:grid;grid-template-columns:repeat(2,1fr);gap:64px 48px}
.idx-card{display:flex;flex-direction:column;gap:20px;text-decoration:none;color:inherit}
.idx-card .plate{transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.idx-card:hover .plate{transform:scale(1.02)}
.idx-card .meta-row{display:flex;justify-content:space-between;align-items:baseline;gap:24px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.idx-card .meta-row b{color:var(--accent-2);font-weight:500}
.idx-card h3{font-family:var(--serif);font-weight:300;font-size:32px;line-height:1.05;letter-spacing:-.02em;color:var(--ink)}
.idx-card h3 em{font-style:italic;color:var(--accent)}
.idx-card .small{color:var(--ink-2)}

/* ── Pull quote ───────────────────────────────────────── */
.pullquote{display:grid;grid-template-columns:160px 1fr;gap:64px;align-items:start;padding:56px 0}
.pullquote .mark{font-family:var(--serif);font-style:italic;font-weight:300;font-size:120px;line-height:.6;color:var(--accent);padding-top:40px}
.pullquote blockquote{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3.4vw,42px);line-height:1.18;letter-spacing:-.015em;color:var(--ink);max-width:32ch}
.pullquote blockquote em{font-style:italic;color:var(--accent)}
.pullquote .cite{display:block;margin-top:32px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.pullquote .cite b{color:var(--ink);font-weight:500}

/* ─── Shared section variants (used on multiple pages) ─── */
.section--cream{background:var(--paper)}
.section--peach{background:#f1e8da}
.section--ink{background:var(--ink);color:var(--paper)}
.section--ink .h-section,.section--ink .h-display{color:var(--paper)}
.section--ink .h-section em,.section--ink .h-display em{color:var(--accent-3)}
.section--ink .body,.section--ink .lead,.section--ink p{color:rgba(255,255,255,.72)}
.section--ink .sect-head .meta{color:rgba(255,255,255,.5)}
.section--ink .sect-head .meta b{color:var(--accent-3)}
.section--ink .sect-head .meta em{color:var(--paper)}
.section--ink .sect-head{border-top-color:rgba(255,255,255,.12)}
.section--ink .lnk{color:var(--paper)}
.section--ink .chip{background:transparent;border-color:rgba(255,255,255,.18);color:rgba(255,255,255,.7)}
.section--ink .chip:hover{border-color:#fff;color:#fff;background:transparent}
.section--ink .chip.is-on{background:var(--accent);border-color:var(--accent);color:#fff}
.section--ink .nlist{border-top-color:rgba(255,255,255,.12)}
.section--ink .nlist li{border-bottom-color:rgba(255,255,255,.10)}
.section--ink .nlist .n{color:var(--accent-3)}
.section--ink .nlist .h{color:var(--paper)}
.section--ink .nlist .h em{color:var(--accent-3)}
.section--ink .nlist .b{color:rgba(255,255,255,.62)}
.section--ink .lead em{color:var(--accent-3)}
.section--ink .btn--primary{background:var(--accent);border-color:var(--accent);color:#fff}
.section--ink .btn--primary:hover{background:#fff;border-color:#fff;color:var(--ink)}

/* ─── Pricing cards (homepage + pricing.html) ───────────── */
.pricing{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:24px}
@media (max-width:880px){.pricing{grid-template-columns:1fr}}
.price-card{background:var(--surface);border:1px solid var(--rule);padding:40px 36px;display:flex;flex-direction:column;gap:24px;border-radius:14px;position:relative}
.price-card.is-feat{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.price-card.is-feat h3,.price-card.is-feat .price-num{color:var(--paper)}
.price-card.is-feat .price-num em{color:var(--accent-3)}
.price-card.is-feat .price-num small,.price-card.is-feat .pc-eyebrow{color:rgba(255,255,255,.62)}
.price-card.is-feat ul{color:rgba(255,255,255,.78);border-top-color:rgba(255,255,255,.15)}
.price-card.is-feat ul li::before{background:var(--accent-3)}
.price-card.is-feat .btn{background:var(--accent);border-color:var(--accent);color:#fff}
.price-card.is-feat .btn:hover{background:#fff;border-color:#fff;color:var(--ink)}
.price-card .pc-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);display:flex;justify-content:space-between;align-items:center}
.price-card .pc-eyebrow .badge{font-family:var(--mono);font-size:10px;letter-spacing:.08em;background:var(--ink);color:var(--paper);padding:4px 10px;border-radius:999px}
.price-card.is-feat .pc-eyebrow .badge{background:var(--accent);color:#fff}
.price-num{font-family:var(--serif);font-weight:300;font-size:80px;line-height:.9;letter-spacing:-.03em;color:var(--ink);display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.price-num em{font-style:italic;color:var(--accent)}
.price-num small{font-family:var(--sans);font-weight:400;font-size:13px;color:var(--ink-3);letter-spacing:0;line-height:1.6;display:block;width:100%;margin-top:8px}
.price-card h3{font-family:var(--serif);font-weight:400;font-size:22px;letter-spacing:-.01em;color:var(--ink)}
.price-card ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:14px;line-height:1.55;color:var(--ink-2);padding-top:24px;border-top:1px solid var(--rule-soft);margin:0}
.price-card li{display:grid;grid-template-columns:18px 1fr;gap:12px;align-items:start}
.price-card li::before{content:'';width:8px;height:1px;background:var(--accent-2);margin-top:11px}

/* ─── Testimonial cards (homepage + about/services) ────── */
.testimonials{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px}
@media (max-width:880px){.testimonials{grid-template-columns:1fr;gap:16px}}
.tcard{display:flex;flex-direction:column;gap:20px;padding:32px;background:var(--surface);border:1px solid var(--rule-soft);border-radius:14px}
.section--ink .tcard{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.10)}
.section--ink .tcard blockquote{color:var(--paper)}
.section--ink .tcard blockquote em{color:var(--accent-3)}
.section--ink .tcard .cite{color:rgba(255,255,255,.46);border-top-color:rgba(255,255,255,.12)}
.section--ink .tcard .cite b{color:#fff}
.section--ink .tcard .cite .verified{color:var(--accent-3)}
.section--ink .tcard .stars{color:var(--accent-3)}
.tcard .stars{color:var(--accent);font-family:var(--mono);font-size:14px;letter-spacing:.2em}
.tcard blockquote{font-family:var(--serif);font-weight:300;font-size:clamp(20px,2vw,26px);line-height:1.32;letter-spacing:-.01em;color:var(--ink);max-width:36ch;font-style:italic}
.tcard blockquote em{color:var(--accent);font-style:italic}
.tcard .cite{display:flex;justify-content:space-between;align-items:center;padding-top:18px;border-top:1px solid var(--rule-soft);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.tcard .cite b{color:var(--ink);font-weight:500}
.tcard .cite .verified{color:var(--accent-2);display:inline-flex;align-items:center;gap:6px}
.tcard .cite .verified::before{content:'\2713';font-family:var(--sans);font-weight:600}

/* ─── FAQ details (homepage + approach.html) ─────────────── */
.faq{margin-top:24px;border-top:1px solid var(--rule)}
.faq details{border-bottom:1px solid var(--rule-soft);padding:28px 0;transition:padding .2s}
.faq details[open]{padding-bottom:36px}
.faq summary{cursor:pointer;display:grid;grid-template-columns:60px 1fr 32px;gap:24px;align-items:start;font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.4vw,28px);line-height:1.18;letter-spacing:-.015em;color:var(--ink);list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary .n{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--accent-2);font-weight:500;padding-top:12px}
.faq summary .plus{font-family:var(--serif);font-weight:300;font-size:32px;color:var(--accent);justify-self:end;line-height:1;padding-top:4px;transition:transform .3s ease}
.faq details[open] summary .plus{transform:rotate(45deg)}
.faq summary em{font-style:italic;color:var(--accent)}
.faq .answer{padding:18px 0 0 84px;font-size:15px;line-height:1.7;color:var(--ink-2);max-width:62ch}
@media (max-width:880px){.faq summary{grid-template-columns:1fr 24px;gap:14px;font-size:20px}.faq summary .n{display:none}.faq .answer{padding-left:0}}

/* ─── Journal cards (homepage + journal.html) ─────────── */
.journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px}
@media (max-width:880px){.journal-grid{grid-template-columns:1fr;gap:16px}}
.jc{display:flex;flex-direction:column;gap:14px;text-decoration:none;color:inherit;background:var(--surface);border:1px solid var(--rule-soft);border-radius:12px;padding:24px;transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease}
.jc:hover{transform:translateY(-3px);box-shadow:0 18px 40px -22px rgba(47,40,51,.18)}
.jc .meta-row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}
.jc .meta-row b{color:var(--accent-2);font-weight:500}
.jc h3{font-family:var(--serif);font-weight:300;font-size:24px;line-height:1.18;letter-spacing:-.015em;color:var(--ink)}
.jc h3 em{font-style:italic;color:var(--accent)}
.jc:hover h3{color:var(--accent-2)}
.jc p{font-size:13.5px;color:var(--ink-2);line-height:1.65;margin:0}
.jc .read{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2);margin-top:auto;padding-top:8px;display:inline-flex;align-items:center;gap:8px}

/* ─── Studio "note" (Kyle quote + photo) — about.html ─── */
.note{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center;padding:64px 0;border-top:1px solid var(--rule-soft);border-bottom:1px solid var(--rule-soft)}
@media (max-width:880px){.note{grid-template-columns:1fr;gap:24px}}
.note .meta{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);line-height:1.9}
.note .meta b{display:block;color:var(--accent-2);font-weight:500;margin-bottom:8px}
.note p{font-family:var(--serif);font-weight:300;font-size:24px;line-height:1.4;letter-spacing:-.005em;color:var(--ink);max-width:36ch}
.note p em{font-style:italic;color:var(--accent)}

/* ─── Niche grid mini-previews (homepage + services.html) ── */
/* Note: the legacy 3-col .niches grid rules have been superseded by the v20
   magazine spread defined later in this file (asymmetric 6-col with feature spans). */
.niche{display:flex;flex-direction:column;text-decoration:none;color:inherit;background:var(--surface);border:1px solid rgba(47,40,51,.16);border-radius:14px;overflow:hidden;transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease,border-color .35s ease;position:relative;box-shadow:0 1px 0 rgba(47,40,51,.04),0 8px 24px -18px rgba(47,40,51,.18)}
.niche:hover{transform:translateY(-3px);box-shadow:0 24px 56px -28px rgba(47,40,51,.30);border-color:var(--ink-3)}
.niche-meta{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--rule-soft);font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);background:var(--paper-2)}
.niche-meta b{color:var(--ink);font-weight:500}
.niche-meta .palette{display:flex;gap:4px}
.niche-meta .palette i{display:block;width:10px;height:10px;border-radius:50%;border:1px solid rgba(0,0,0,.06)}
.niche-preview{position:relative;aspect-ratio:4/3;overflow:hidden;display:block}
.niche-foot{padding:18px 18px 20px;display:flex;justify-content:space-between;align-items:center;gap:14px;background:var(--surface)}
.niche-name{font-family:var(--serif);font-weight:300;font-size:22px;line-height:1.05;letter-spacing:-.015em;color:var(--ink)}
.niche-name em{font-style:italic;color:var(--accent)}
.niche-cta{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2);display:inline-flex;align-items:center;gap:8px;flex:0 0 auto}
.niche-cta .arr{display:inline-block;width:14px;height:1px;background:currentColor;position:relative;transition:width .25s}
.niche-cta .arr::after{content:'';position:absolute;right:0;top:-3px;width:6px;height:6px;border-top:1px solid currentColor;border-right:1px solid currentColor;transform:rotate(45deg);transform-origin:right center}
.niche:hover .niche-cta .arr{width:24px}
.niche-preview .pv{position:absolute;inset:0;padding:24px 22px;display:flex;flex-direction:column;gap:10px;justify-content:center}
.niche-preview .pv-bar{position:absolute;top:0;left:0;right:0;height:22px;display:flex;align-items:center;gap:6px;padding:0 10px;font-family:'JetBrains Mono', monospace;font-size:8.5px;letter-spacing:.04em;opacity:.78}
.niche-preview .pv-bar i{display:inline-block;width:5px;height:5px;border-radius:50%}
.niche-preview .pv-eyebrow{font-family:'JetBrains Mono', monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;opacity:.7}
.niche-preview .pv-h{line-height:.95;letter-spacing:-.02em}
.niche-preview .pv-sub{font-size:10.5px;line-height:1.5;max-width:32ch;opacity:.7}
.niche-preview .pv-cta{display:inline-flex;align-items:center;gap:6px;font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:6px 12px;border-radius:999px;align-self:flex-start;margin-top:4px}
.pv--hair{background:#f7f3ee;color:#1c1c1c}
.pv--hair .pv-bar{color:#1c1c1c;background:rgba(247,243,238,.85);border-bottom:1px solid rgba(28,28,28,.08)}
.pv--hair .pv-eyebrow{color:#b8924a}
.pv--hair .pv-h{font-family:'Cormorant Garamond', serif;font-weight:300;font-style:italic;font-size:30px}
.pv--hair .pv-cta{background:#1c1c1c;color:#f7f3ee}
.pv--barber{background:#111;color:#f5f0e8}
.pv--barber .pv-bar{color:#f5f0e8;background:rgba(0,0,0,.55);border-bottom:1px solid rgba(212,160,23,.15)}
.pv--barber .pv-eyebrow{color:#d4a017}
.pv--barber .pv-h{font-family:'Bebas Neue', sans-serif;font-size:38px;letter-spacing:.005em;line-height:.9}
.pv--barber .pv-sub{color:rgba(245,240,232,.62)}
.pv--barber .pv-cta{background:#d4a017;color:#111}
.pv--spa{background:linear-gradient(180deg,#0e1a10 0%,#172818 100%);color:#f5f0e8}
.pv--spa .pv-bar{color:#f5f0e8;background:rgba(0,0,0,.35);border-bottom:1px solid rgba(122,158,138,.16)}
.pv--spa .pv-eyebrow{color:#7a9e8a}
.pv--spa .pv-h{font-family:'Playfair Display', serif;font-weight:400;font-size:26px;line-height:1.05}
.pv--spa .pv-sub{color:rgba(245,240,232,.58)}
.pv--spa .pv-cta{background:#c9a96e;color:#0e1a10}
.pv--lash{background:#fefcfa;color:#2d1f24}
.pv--lash .pv-bar{color:#2d1f24;background:rgba(254,252,250,.85);border-bottom:1px solid rgba(232,180,184,.4)}
.pv--lash .pv-eyebrow{color:#c98a8e}
.pv--lash .pv-h{font-family:'Cormorant', serif;font-style:italic;font-weight:400;font-size:32px;line-height:1.0}
.pv--lash .pv-sub{color:rgba(45,31,36,.6)}
.pv--lash .pv-cta{background:#e8b4b8;color:#2d1f24}
.pv--med{background:#f4f6fa;color:#1a1a2e}
.pv--med .pv-bar{color:#1a1a2e;background:rgba(244,246,250,.85);border-bottom:1px solid rgba(143,168,200,.32)}
.pv--med .pv-eyebrow{color:#1e3a5f}
.pv--med .pv-h{font-family:'Libre Baskerville', serif;font-weight:400;font-size:22px;line-height:1.1}
.pv--med .pv-sub{color:rgba(26,26,46,.6)}
.pv--med .pv-cta{background:#1e3a5f;color:#fff}
.pv--nails{background:#fdf6f0;color:#1e1412}
.pv--nails .pv-bar{color:#1e1412;background:rgba(253,246,240,.85);border-bottom:1px solid rgba(200,169,138,.32)}
.pv--nails .pv-eyebrow{color:#c8a98a;font-family:'DM Sans',sans-serif;letter-spacing:.16em}
.pv--nails .pv-h{font-family:'DM Serif Display', serif;font-style:italic;font-weight:400;font-size:30px;line-height:.95}
.pv--nails .pv-sub{color:rgba(30,20,18,.6);font-family:'DM Sans',sans-serif}
.pv--nails .pv-cta{background:#1e1412;color:#fdf6f0;font-family:'DM Sans',sans-serif}
.pv--tattoo{background:#080808;color:#f0ece4}
.pv--tattoo .pv-bar{color:#f0ece4;background:rgba(0,0,0,.55);border-bottom:1px solid rgba(204,68,34,.3)}
.pv--tattoo .pv-eyebrow{color:#cc4422;font-family:'Space Grotesk',sans-serif;font-weight:500}
.pv--tattoo .pv-h{font-family:'Space Grotesk', sans-serif;font-weight:700;font-size:24px;line-height:.95;letter-spacing:-.01em;text-transform:uppercase}
.pv--tattoo .pv-sub{color:rgba(240,236,228,.6);font-family:'Space Grotesk',sans-serif}
.pv--tattoo .pv-cta{background:#cc4422;color:#fff;border-radius:0;font-family:'Space Grotesk',sans-serif}
.niche--all{background:var(--paper-2);border-style:dashed;border-color:var(--rule)}
.niche--all .niche-preview{display:flex;align-items:center;justify-content:center;background:var(--paper-2)}
.niche--all .all-num{font-family:var(--serif);font-weight:300;font-style:italic;font-size:96px;line-height:1;color:var(--accent);letter-spacing:-.03em}
.niche--all .all-lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);text-align:center}
.niche--all .all-num + .all-lbl{margin-top:6px}

/* ── CTA block (used on every page above the footer) ─── */
.cta-block{padding:120px 0;background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.cta-block::before{content:'';position:absolute;inset:auto -10% -40% 30%;height:600px;width:600px;border-radius:50%;background:radial-gradient(circle,var(--accent) 0%,transparent 70%);opacity:.18;pointer-events:none}
.cta-block .wrap{position:relative;z-index:1}
.cta-block .h-display{color:var(--paper);max-width:18ch}
.cta-block .h-display em{color:var(--accent-3)}
.cta-block .lead{color:rgba(255,255,255,.72);max-width:52ch}
.cta-actions{display:flex;flex-wrap:wrap;gap:16px;margin-top:48px;align-items:center}
.cta-block .btn{background:var(--accent);border-color:var(--accent);color:#fff}
.cta-block .btn:hover{background:#fff;border-color:#fff;color:var(--ink)}
.cta-block .btn.btn--ghost{background:transparent;border-color:rgba(255,255,255,.3);color:var(--paper)}
.cta-block .btn.btn--ghost:hover{border-color:#fff;color:#fff;background:transparent}
.cta-block .lnk{color:rgba(255,255,255,.85)}
.cta-block .meta-strip{display:flex;gap:32px;flex-wrap:wrap;margin-top:64px;padding-top:32px;border-top:1px solid rgba(255,255,255,.16);font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.cta-block .meta-strip b{color:#fff;font-weight:500}
@media (max-width:880px){
  .cta-block{padding:64px 0 56px}
  .cta-block .meta-strip{gap:18px;margin-top:36px;padding-top:20px;font-size:10.5px}
  .cta-actions{gap:10px;margin-top:32px}
}

/* ── Featured case study mock browser (homepage + work.html) ─ */
/* ─── v17: Featured case study cover — editorial tearsheet (replaces fake-browser) */
.featured-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:80px;align-items:start;margin-top:56px}
@media (max-width:820px){.featured-grid{grid-template-columns:1fr;gap:32px;margin-top:36px}}
.featured-cover{aspect-ratio:5/7;background:#1c1c1c;border-radius:0;overflow:hidden;position:relative;border:1px solid rgba(28,28,28,.10);display:block;box-shadow:0 28px 80px -32px rgba(28,28,28,.45);isolation:isolate;text-decoration:none}
.featured-cover img{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.04) contrast(1.02);transition:transform 1.8s cubic-bezier(.2,.7,.2,1),filter 1s ease}
.featured-cover:hover img{transform:scale(1.04);filter:saturate(1.1) contrast(1.04)}
.featured-cover::before{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(28,28,28,.55) 0%,rgba(28,28,28,0) 26%,rgba(28,28,28,0) 48%,rgba(28,28,28,.85) 100%)}
.featured-cover::after{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;mix-blend-mode:overlay;opacity:.35;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .9 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");background-size:160px}
.featured-cover .cover-folio{position:absolute;left:32px;top:32px;z-index:3;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:28px;letter-spacing:0;color:#b8924a;line-height:1}
.featured-cover .cover-tag{position:absolute;right:32px;top:36px;z-index:3;font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(247,243,238,.78);display:inline-flex;align-items:center;gap:8px}
.featured-cover .cover-tag b{color:#b8924a;font-weight:500;letter-spacing:.16em}
.featured-cover .cover-h{position:absolute;left:32px;right:32px;bottom:140px;z-index:3;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(38px,4.6vw,64px);line-height:1.0;color:#f7f3ee;max-width:14ch;letter-spacing:-.018em;margin:0}
.featured-cover .cover-h em{font-style:italic;color:#b8924a;font-weight:300}
.featured-cover .cover-foot{position:absolute;left:32px;right:32px;bottom:80px;z-index:3;display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding-bottom:16px;border-bottom:1px solid rgba(247,243,238,.22);font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:rgba(247,243,238,.7)}
.featured-cover .cover-cta{position:absolute;left:32px;right:32px;bottom:32px;z-index:3;display:flex;justify-content:space-between;align-items:baseline;gap:12px;font-family:'JetBrains Mono',monospace;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:#f7f3ee}
.featured-cover .cover-arr{display:inline-block;transition:transform .35s cubic-bezier(.2,.7,.2,1);font-family:var(--sans);font-size:14px;color:#b8924a}
.featured-cover:hover .cover-arr{transform:translateX(8px)}
.featured-meta-list{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule-soft);border:1px solid var(--rule-soft);margin:24px 0}
.featured-meta-list > div{padding:18px 22px;background:var(--paper);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.featured-meta-list b{display:block;color:var(--ink);font-family:var(--serif);font-weight:400;font-size:22px;letter-spacing:-.015em;text-transform:none;margin-top:6px}
.featured-meta-list .stat-up{color:var(--accent-2)}
.featured-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
@media (max-width:560px){
  .featured-cover .cover-h{font-size:clamp(28px,8vw,40px);bottom:110px}
  .featured-cover .cover-foot{bottom:68px}
  .featured-cover .cover-folio{font-size:22px;top:24px;left:24px}
  .featured-cover .cover-tag{top:28px;right:24px;font-size:9.5px}
  .featured-meta-list{grid-template-columns:1fr}
}

/* ── Footer ───────────────────────────────────────────── */
.footer{padding:120px 0 48px;background:var(--ink);color:var(--paper)}
.footer .wrap{position:relative}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:64px;align-items:start;padding-bottom:88px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-mark{font-family:var(--serif);font-weight:300;font-size:clamp(64px,12vw,224px);line-height:.86;color:var(--paper);margin-bottom:14px;
  /* Scroll-velocity stretch: idle = tight (-.045em), high vel = loose (-.002em) */
  letter-spacing:calc(-.045em + var(--mark-stretch, 0em));
  transition:letter-spacing .25s ease;
}
.footer-mark em{font-style:italic;font-weight:300;color:var(--accent-3)}
.footer h4{font-family:var(--mono);font-weight:500;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:18px}
.footer a{display:block;font-size:14px;color:rgba(255,255,255,.78);padding:5px 0;transition:color .15s}
.footer a:hover{color:#fff}
.footer .blurb{font-size:13px;line-height:1.65;color:rgba(255,255,255,.6);max-width:36ch;margin-top:24px}
.footer .sub-row{display:flex;gap:8px;align-items:center;margin-top:14px;border-bottom:1px solid rgba(255,255,255,.18);padding-bottom:10px;max-width:280px}
.footer .sub-row input{background:transparent;border:0;outline:0;color:#fff;font-family:var(--sans);font-size:14px;flex:1;padding:6px 0}
.footer .sub-row input:focus-visible{outline:2px solid var(--accent-3);outline-offset:4px;border-radius:2px}
.footer .sub-row input::placeholder{color:rgba(255,255,255,.45)}
.footer .sub-row button{background:transparent;border:0;color:var(--accent-3);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;padding:6px 0}
.footer-foot{padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.46)}
.footer-foot a{display:inline;color:rgba(255,255,255,.6);padding:0}

/* ── Generic helpers ──────────────────────────────────── */
.cluster{display:flex;flex-wrap:wrap;gap:18px;align-items:center}
.stack{display:flex;flex-direction:column;gap:24px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:64px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.spacer-lg{height:88px}
.spacer{height:48px}

/* index list */
.list-rows{border-top:1px solid var(--rule-soft)}
.list-row{display:grid;grid-template-columns:60px 1fr 1fr 200px 24px;gap:32px;align-items:center;padding:28px 0;border-bottom:1px solid var(--rule-soft);transition:background .2s ease;cursor:pointer}
.list-row:hover{background:linear-gradient(90deg,transparent,var(--accent-soft) 50%,transparent)}
.list-row .n{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--accent-2);font-weight:500}
.list-row .name{font-family:var(--serif);font-weight:300;font-size:28px;letter-spacing:-.015em;color:var(--ink)}
.list-row .name em{font-style:italic;color:var(--accent)}
.list-row .what{font-family:var(--sans);font-size:14px;color:var(--ink-2)}
.list-row .where{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.list-row .arrow-cell{justify-self:end;width:32px;height:1px;background:var(--ink-3);position:relative;transition:width .3s ease}
.list-row .arrow-cell::after{content:'';position:absolute;right:0;top:-4px;width:9px;height:9px;border-top:1px solid var(--ink-3);border-right:1px solid var(--ink-3);transform:rotate(45deg);transform-origin:right center}
.list-row:hover .arrow-cell{width:48px;background:var(--accent-2)}
.list-row:hover .arrow-cell::after{border-color:var(--accent-2)}

/* metric row */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rule-soft);border:1px solid var(--rule-soft);margin-top:24px}
.metrics > div{padding:32px 24px;background:var(--paper);display:flex;flex-direction:column;gap:8px}
.metrics .num{font-family:var(--serif);font-weight:300;font-size:clamp(40px,4.5vw,64px);line-height:1;letter-spacing:-.025em;color:var(--ink)}
.metrics .num em{font-style:italic;color:var(--accent)}
.metrics .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}

/* ── Mobile ───────────────────────────────────────────── */
@media (max-width:880px){
  :root{--pad-x:20px}
  /* Use overflow-x:clip (not :hidden) so position:sticky on .topbar still works.
     overflow-x:hidden on html/body breaks all sticky descendants in iOS Safari. */
  html,body{overflow-x:clip}
  .nav{display:none}
  .topbar-inner{gap:14px;padding:14px var(--pad-x)}
  .topbar .right{gap:10px}
  .topbar .right .status{display:none}
  /* Hide the topbar pill on mobile — it lives in the slide-out menu and the hero CTA */
  .topbar .right .btn{display:none}
  .brand-mark{font-size:16px}
  .menu-toggle{display:inline-flex;padding:9px 14px}
  /* Hide the standalone location/time strip on mobile — it stays in the footer */
  .crumb{display:none}
  .section{padding:60px 0}
  .hero{padding:32px 0 56px}
  .hero-tag{font-size:10px}
  .hero-foot,.grid-2,.idx,.grid-3,.grid-4{grid-template-columns:1fr;gap:32px}
  .sect-head{grid-template-columns:1fr;gap:18px}
  .nlist li{grid-template-columns:1fr;gap:14px;padding:32px 0}
  .nlist .n{padding-top:0}
  .pullquote{grid-template-columns:1fr;gap:24px;padding:32px 0}
  .pullquote .mark{padding-top:0;font-size:80px}
  /* Compact footer on mobile — drastically reduced (was ~559px tall) */
  .footer{padding:32px 0 16px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:18px 20px;padding-bottom:16px}
  .footer-mark{font-size:26px;margin-bottom:6px;line-height:.95}
  .footer .blurb{font-size:12px;line-height:1.45;margin-top:8px;max-width:32ch}
  .footer h4{font-size:10px;margin-bottom:6px;letter-spacing:.14em}
  .footer-grid a, .footer-col li{font-size:12.5px;padding:1px 0}
  .footer-foot{flex-direction:column;align-items:flex-start;gap:4px;padding-top:12px;font-size:9.5px;letter-spacing:.06em}
  /* The brand cell spans the full row at top — collapse from 4 cells to a tighter mobile shape */
  .footer-grid > div:first-child{grid-column:1 / -1;margin-bottom:4px}
  .footer-grid > div:first-child .blurb{max-width:48ch}
  /* Hide the email subscribe form on mobile — it's the largest single block in the footer */
  .footer-grid > div:last-child{display:none}
  .sub-row{display:none}
  .metrics{grid-template-columns:1fr 1fr}
  .list-row{grid-template-columns:40px 1fr;gap:14px;padding:20px 0}
  .list-row .what,.list-row .where,.list-row .arrow-cell{display:none}
  .list-row .name{font-size:22px}
  .cluster{gap:8px}
  .chip{padding:7px 12px;font-size:10.5px}
}

/* ─── Motion ──────────────────────────────────────────── */
/* All reveal animations are gated on `.js` class on <html> — added by yeti.js on load. */
/* If JS fails entirely, content stays visible (no opacity:0 starting state). */
@media (prefers-reduced-motion:no-preference){
  /* Reveal up */
  .js .reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
  .js .reveal.is-in{opacity:1;transform:none}
  .js .reveal[data-d="100"]{transition-delay:.10s}
  .js .reveal[data-d="200"]{transition-delay:.20s}
  .js .reveal[data-d="300"]{transition-delay:.30s}
  .js .reveal[data-d="400"]{transition-delay:.40s}

  /* Words split: each word reveals individually */
  .js .words .w{display:inline-block;opacity:0;transform:translateY(.4em);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
  .js .words.is-in .w{opacity:1;transform:none}

  /* Letters split */
  .js .lines .ln{overflow:hidden;display:block}
  .js .lines .ln span{display:inline-block;transform:translateY(110%);transition:transform .9s cubic-bezier(.2,.7,.2,1)}
  .js .lines.is-in .ln span{transform:none}

  /* Marquee */
  @keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
  .marquee{display:flex;overflow:hidden;border-top:1px solid var(--rule-soft);border-bottom:1px solid var(--rule-soft);padding:24px 0;align-items:center;gap:0;background:var(--paper)}
  .marquee-track{display:flex;gap:60px;white-space:nowrap;animation:marquee 60s linear infinite;will-change:transform;flex:0 0 auto;padding-right:60px}
  .marquee-track:hover{animation-play-state:paused}
  .marquee span{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(36px,5vw,64px);line-height:1;letter-spacing:-.02em;color:var(--ink);display:inline-flex;align-items:center;gap:60px}
  .marquee span::after{content:'★';color:var(--accent);font-style:normal;font-size:.4em;vertical-align:middle;margin-left:60px}

  /* Animated counter */
  .counter[data-anim="counter"]{font-variant-numeric:tabular-nums}

  /* Parallax photo */
  .plate[data-parallax]{will-change:transform}
  .plate[data-parallax] img{transition:transform .2s linear}

  /* Niche tile lift */
  .niche{transition:background .28s ease,color .28s ease,transform .28s ease}
  .niche:hover{transform:translateY(-2px)}

  /* Index-row arrow */
  .list-row .name{transition:transform .35s cubic-bezier(.2,.7,.2,1)}
  .list-row:hover .name{transform:translateX(8px)}

  /* Cursor follow dot */
  .cursor-dot{position:fixed;top:0;left:0;width:8px;height:8px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:100;mix-blend-mode:multiply;transform:translate(-50%,-50%);opacity:0;transition:opacity .2s,width .25s,height .25s,background .25s}
  .cursor-dot.is-on{opacity:.85}
  .cursor-dot.is-link{width:36px;height:36px;background:var(--accent-soft);mix-blend-mode:multiply}
  @media (hover:none){.cursor-dot{display:none}}
}

/* Scroll progress */
.progress-bar{position:fixed;top:0;left:0;height:2px;background:var(--accent);z-index:60;transform-origin:left;transform:scaleX(0);transition:transform .12s linear}

/* ─────────────────────────────────────────────────────────
   v8 — dynamism push: atmosphere · spine · full-bleed · bleed-hero
   ───────────────────────────────────────────────────────── */

/* ─── Atmospheric paper grain (subtle, fixed, multiply) ─── */
.atmosphere{
  position:fixed;inset:0;pointer-events:none;z-index:1;
  opacity:.045;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='5'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size:240px 240px;
}
@media (prefers-reduced-motion:reduce){.atmosphere{display:none}}

/* ─── Magazine spine (fixed right-edge running text) ─── */
.spine{
  position:fixed;top:50%;right:14px;transform:translateY(-50%);
  z-index:30;pointer-events:none;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-3);
}
.spine > span{writing-mode:vertical-rl;text-orientation:mixed;display:inline-block}
.spine b{color:var(--ink);font-weight:500}
.spine .spine-rule{width:1px;height:48px;background:var(--rule)}
.spine .spine-prog{font-variant-numeric:tabular-nums;color:var(--accent-2);font-weight:500}
@media (max-width:1080px){.spine{display:none}}

/* ─── Full-bleed utility (escape the .wrap constraint) ─── */
.fullbleed{width:100%;max-width:none;padding:0 var(--pad-x)}
@media (min-width:1400px){.fullbleed{padding:0 56px}}
@media (min-width:1800px){.fullbleed{padding:0 88px}}
@media (max-width:880px){.fullbleed{padding:0 var(--pad-x)}}

/* ─── Bleed hero ───────────────────────────────────────── */
.bleed-hero{padding:88px 0 96px;position:relative;overflow:hidden}
.bleed-hero-meta{
  display:grid;grid-template-columns:1fr auto 1fr;gap:32px;align-items:baseline;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
  margin-bottom:84px;
}
.bleed-hero-meta b{color:var(--ink);font-weight:500;letter-spacing:.16em}
.bleed-hero-meta .center-mark{
  font-family:var(--serif);font-style:italic;font-weight:300;font-size:14px;
  letter-spacing:0;text-transform:none;color:var(--ink);
  display:inline-flex;align-items:center;gap:14px;
}
.bleed-hero-meta .center-mark::before,.bleed-hero-meta .center-mark::after{
  content:'';display:inline-block;width:18px;height:1px;background:var(--rule);
}
.bleed-hero-meta .right{text-align:right}

.bleed-hero-headline{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(72px,13.5vw,228px);line-height:.86;letter-spacing:-.045em;
  color:var(--ink);margin:0 0 64px;
  max-width:none;
}
.bleed-hero-headline em{font-style:italic;font-weight:300;color:var(--accent)}
.bleed-hero-headline .accent-rule{display:inline-block;width:.7em;height:1px;background:var(--accent);vertical-align:0.3em;margin:0 0.18em 0 0;opacity:.7}

.bleed-hero-foot{
  display:grid;grid-template-columns:1.2fr 1fr;gap:96px;align-items:end;
  padding-top:48px;border-top:1px solid var(--rule-soft);
}
.bleed-hero-lede{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(22px,2.4vw,30px);line-height:1.36;letter-spacing:-.005em;color:var(--ink-2);
  max-width:38ch;
}
.bleed-hero-lede b{color:var(--ink);font-weight:500}
.bleed-hero-lede em{font-style:italic;color:var(--accent-2)}
.bleed-hero-side{display:flex;flex-direction:column;gap:18px;align-items:flex-start}
.bleed-hero-side .hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.bleed-hero-side .cluster{margin-top:6px}

.bleed-hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:64px;
  margin-top:96px;padding-top:56px;
  border-top:1px solid var(--rule);
}
.bleed-hero-stats > div{
  display:flex;flex-direction:column;gap:18px;
}
.bleed-hero-stats .lbl{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
  order:-1; /* eyebrow label sits ABOVE the figure (editorial convention) */
}
.bleed-hero-stats .num{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(56px,7.2vw,108px);line-height:.92;letter-spacing:-.035em;color:var(--ink);
  font-feature-settings:'tnum' 1;
}
.bleed-hero-stats .num em{font-style:italic;color:var(--accent)}

@media (max-width:980px){
  .bleed-hero{padding:36px 0 48px}
  .bleed-hero-meta{grid-template-columns:1fr;gap:6px;margin-bottom:32px;font-size:9.5px;letter-spacing:.14em}
  .bleed-hero-meta .center-mark{display:none}
  .bleed-hero-meta .right{text-align:left}
  .bleed-hero-headline{font-size:clamp(46px,11vw,80px);margin-bottom:32px;letter-spacing:-.03em}
  .bleed-hero-foot{grid-template-columns:1fr;gap:24px;padding-top:24px}
  .bleed-hero-lede{font-size:18px;line-height:1.45;max-width:none}
  .bleed-hero-stats{grid-template-columns:1fr 1fr;gap:32px;margin-top:48px;padding-top:32px}
  .bleed-hero-stats > div{gap:12px}
  .bleed-hero-stats .num{font-size:clamp(40px,11vw,64px)}
}

/* ─── Marquee: JS-driven smooth scrolling (replaces CSS keyframe when JS active) ─── */
.marquee-track.js-driven{animation:none !important;will-change:transform;transform:translate3d(0,0,0)}

/* ─── v17: Topbar scroll-shrink — gets thinner + glassy when past hero ─── */
.topbar{transition:background .4s ease,backdrop-filter .4s ease,box-shadow .4s ease,border-bottom-color .4s ease}
.topbar .topbar-inner{transition:padding .35s cubic-bezier(.2,.7,.2,1)}
.topbar .brand-mark{transition:font-size .35s cubic-bezier(.2,.7,.2,1)}
.topbar .brand svg{transition:width .35s ease,height .35s ease}

.topbar.is-scrolled{
  background:rgba(188,174,198,.78);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  box-shadow:0 4px 24px -16px rgba(28,28,28,.18);
  border-bottom-color:rgba(47,40,51,.16);
}
.topbar.is-scrolled .topbar-inner{padding:10px var(--pad-x)}
.topbar.is-scrolled .brand-mark{font-size:16px}
.topbar.is-scrolled .brand svg{width:18px;height:16px}

@media (max-width:880px){
  .topbar.is-scrolled .topbar-inner{padding:8px var(--pad-x)}
  .topbar.is-scrolled .brand-mark{font-size:14px}
}

/* ─── v17: Cursor mode-switching — context-aware label inside cursor blob ─── */
.cursor-dot.has-label{
  width:auto;height:auto;
  padding:14px 22px;
  background:var(--ink);color:var(--paper);
  border-radius:999px;
  mix-blend-mode:normal;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  white-space:nowrap;font-weight:500;
  display:inline-flex;align-items:center;gap:8px;
}
.cursor-dot .cd-arr{font-family:var(--sans);font-size:14px;font-weight:600;color:var(--accent-3)}

/* ─── v17: Ribbon marquee — horizontal type strip between sections ─── */
.ribbon-marquee{
  display:flex;overflow:hidden;
  border-top:1px solid var(--rule-soft);border-bottom:1px solid var(--rule-soft);
  padding:18px 0;background:var(--paper-2);
  position:relative;
}
.ribbon-marquee .ribbon-track{
  display:flex;gap:48px;white-space:nowrap;
  flex:0 0 auto;padding-right:48px;will-change:transform;
}
.ribbon-marquee .ribbon-track > span{
  display:inline-flex;align-items:center;gap:48px;
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(20px,2vw,30px);line-height:1;letter-spacing:-.005em;color:var(--ink);
}
.ribbon-marquee .ribbon-track > span::after{
  content:'·';margin-left:48px;color:var(--accent);font-style:normal;
}
.section--ink + .ribbon-marquee,.cta-block + .ribbon-marquee{background:var(--ink);border-color:rgba(255,255,255,.12)}
.section--ink + .ribbon-marquee .ribbon-track > span,
.cta-block + .ribbon-marquee .ribbon-track > span{color:var(--paper)}
.section--ink + .ribbon-marquee .ribbon-track > span::after,
.cta-block + .ribbon-marquee .ribbon-track > span::after{color:var(--accent-3)}

/* ─── v16: Editorial intake form (contact page brief) ─── */
.brief-form{display:flex;flex-direction:column;gap:48px;max-width:640px;margin-top:48px}
.brief-section{display:flex;flex-direction:column;gap:24px;position:relative}
.brief-section-head{display:flex;align-items:baseline;gap:18px;padding-bottom:18px;border-bottom:1px solid var(--rule)}
.brief-section-head .num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:32px;line-height:.88;letter-spacing:0;color:var(--accent);
  flex:0 0 auto;
}
.brief-section-head h3{
  font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.2vw,30px);
  line-height:1.1;letter-spacing:-.015em;color:var(--ink);margin:0;flex:1;
}
.brief-section-head h3 em{font-style:italic;color:var(--accent)}
.brief-section-head .sub{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-3);
}
.brief-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.brief-grid--single{grid-template-columns:1fr}
.brief-field{display:flex;flex-direction:column;gap:8px}
.brief-field--full{grid-column:1 / -1}
.brief-field > label{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-3);font-weight:500;
}
.brief-field > label .req{color:var(--accent);margin-left:4px}
.brief-field > label .opt{color:var(--ink-3);margin-left:6px;font-style:italic;font-family:var(--serif);font-weight:300;letter-spacing:0;text-transform:none;font-size:11px}
.brief-field input,
.brief-field select,
.brief-field textarea{
  padding:14px 16px;background:var(--surface);
  border:1px solid var(--rule);border-radius:0;
  font-family:var(--sans);font-size:16px;color:var(--ink);
  transition:border-color .25s ease,background .25s ease;
  font-feature-settings:'ss01' 1;
}
.brief-field input::placeholder,.brief-field textarea::placeholder{color:var(--ink-4)}
.brief-field input:focus,
.brief-field select:focus,
.brief-field textarea:focus{
  border-color:var(--ink);background:#fff;outline:none;
}
.brief-field textarea{resize:vertical;min-height:120px;line-height:1.55}

/* Toggle-pill multi-select (visible checkboxes styled as editorial pills) */
.pill-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.pill{
  position:relative;display:inline-flex;align-items:center;
  padding:9px 14px;border:1px solid var(--rule);border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-2);background:var(--paper);cursor:pointer;user-select:none;
  transition:background .25s,color .25s,border-color .25s;
}
.pill input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.pill:hover{border-color:var(--ink-2);color:var(--ink)}
.pill:has(input:checked){background:var(--ink);color:var(--paper);border-color:var(--ink)}
.pill:focus-within{outline:2px solid var(--accent-2);outline-offset:3px}

.brief-submit{display:flex;flex-wrap:wrap;align-items:center;gap:18px;margin-top:8px}
.brief-submit .reassurance{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:15px;line-height:1.4;color:var(--ink-3);max-width:32ch;
}

@media (max-width:880px){
  .brief-grid{grid-template-columns:1fr}
  .brief-form{gap:36px}
  .brief-section-head h3{font-size:20px}
}

/* ─── v13: Page hero (secondary pages) — upgraded to editorial scale ───
   Was duplicated in inline <style> across 7 pages with clamp(44px,7vw,108px).
   Centralized here; each page's inline <style> block now removed. */
.page-hero{padding:96px 0 80px;background:var(--paper);position:relative}
.page-hero .eyebrow{color:var(--accent-2)}
.page-hero .folio{margin-bottom:8px}
.page-hero h1{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(56px,9vw,168px);line-height:.92;letter-spacing:-.035em;
  color:var(--ink);max-width:14ch;margin-top:24px;
}
.page-hero h1 em{font-style:italic;color:var(--accent)}
.page-hero p.lead{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(20px,2.2vw,30px);line-height:1.4;letter-spacing:-.01em;
  color:var(--ink-2);max-width:54ch;margin-top:32px;
}
.page-hero p.lead em{font-style:italic;color:var(--accent-2)}
@media (max-width:880px){
  .page-hero{padding:48px 0 40px}
  .page-hero h1{font-size:clamp(40px,9vw,68px);max-width:none}
}

/* ─── v20: Niche tiles — editorial magazine spread (drops the gray-out).
   Kyle's feedback: the shared-gray-until-hover felt off-brand and tablet-y.
   New approach: each tile shows its FULL-COLOR brand world from the start
   (so each feels distinct immediately, not a samey gray cohort). Asymmetric
   3-col / 2-feature / 3-col grid breaks the uniform-rectangle vibe — wider
   features in the middle row read as a magazine spread. Hover = subtle
   zoom + lift, no shimmer, no breathing, no vignette. Cleaner, more
   confident, more editorial. */
.niche{
  display:flex;flex-direction:column;
  background:var(--bb,var(--surface));color:var(--bf,var(--ink));
  border-radius:0;border:1px solid rgba(0,0,0,.04);
  position:relative;overflow:hidden;
  text-decoration:none;
  isolation:isolate;
  box-shadow:0 4px 18px -10px rgba(28,28,28,.18);
  transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s ease,opacity .35s ease,filter .35s ease;
}
/* Brand-color stripe at the top edge — a small identity marker per tile */
.niche::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--ba,var(--accent));z-index:4;pointer-events:none;
  transform-origin:left;transform:scaleX(.35);
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
}
.niche:hover::before{transform:scaleX(1)}
.niche:hover{
  transform:translateY(-4px);
  box-shadow:0 36px 80px -28px rgba(28,28,28,.38);
  z-index:2;
}

/* Hover-to-feature focus — when one tile is hovered, the others fade slightly
   and shrink. Pulls the eye to the hovered tile without being heavy-handed. */
@media (hover:hover) and (pointer:fine){
  .niches:hover .niche:not(:hover){
    opacity:.62;
    filter:saturate(.78);
    transform:scale(.985);
  }
  .niches:hover .niche:not(:hover) .niche-art img{filter:saturate(.85) contrast(.96)}
}

/* The art window — image fills it at full color, type overlays the bottom */
.niche-art{
  position:relative;flex:1;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:22px 22px 26px;
  overflow:hidden;
  min-height:280px;
}

/* The image — always full color, slow zoom on hover. */
.niche-art img{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;object-fit:cover;
  filter:saturate(1.05) contrast(1.02);
  transform:scale(1);
  transition:transform 1.4s cubic-bezier(.2,.7,.2,1),filter .8s ease;
}
.niche:hover .niche-art img{
  transform:scale(1.06);
  filter:saturate(1.12) contrast(1.05);
}

/* Tonal scrim — top + bottom darken so type stays readable across any
   image. No mid-band darkening — image breathes through the middle. */
.niche-art::before{
  content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,
    rgba(0,0,0,.45) 0%,
    rgba(0,0,0,.12) 18%,
    rgba(0,0,0,0) 36%,
    rgba(0,0,0,0) 56%,
    rgba(0,0,0,.55) 100%);
  transition:opacity .5s ease;
}

/* Shimmer span left in markup but no longer styled (kept for backwards-
   compatibility with markup; intentionally invisible). */
.niche-shimmer{display:none}

/* Top row inside niche-art (folio + niche label) — overlaid on photo,
   so always paper-color (top tonal scrim handles legibility). */
.niche-top{
  position:relative;z-index:2;
  display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:#f7f3ee;opacity:.92;
}
.niche-folio{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:20px;letter-spacing:0;text-transform:none;
  color:var(--ba,#f7f3ee);opacity:1;
  text-shadow:0 1px 12px rgba(0,0,0,.32);
}

/* Brand name — overlays the lower portion of the photo. Paper-color always
   (bottom tonal scrim provides contrast across any image). */
.niche-name{
  position:relative;z-index:3;
  font-family:var(--bn,var(--serif));font-style:var(--bs,italic);font-weight:var(--bw,400);
  line-height:.86;letter-spacing:-.02em;
  color:#f7f3ee;margin:0;
  text-shadow:0 2px 28px rgba(0,0,0,.42),0 1px 4px rgba(0,0,0,.28);
  word-break:break-word;
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
}
.niche:hover .niche-name{transform:translateY(-3px)}
.niche-name em{font-style:italic;color:var(--ba,inherit);font-weight:inherit}

/* Bottom strip outside the art (tagline + place + CTA) — uses brand BG color
   so each tile's identity carries through below the photo. */
.niche-bottom{
  position:relative;z-index:3;
  background:var(--bb);
  padding:14px 22px 18px;
  display:flex;flex-direction:column;gap:8px;
}
.niche-tagline{
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--bf);opacity:.62;margin:0;
}
.niche-row{
  display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  padding-top:10px;border-top:1px solid rgba(0,0,0,.10);
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--bf);opacity:.85;
}
.niche-place{opacity:.7}
.niche-cta{display:inline-flex;align-items:center;gap:8px;color:var(--ba,inherit);opacity:1;font-weight:500}
.niche-arr{transition:transform .3s cubic-bezier(.2,.7,.2,1);display:inline-block}
.niche:hover .niche-arr{transform:translateX(8px)}

/* Per-brand vars — palette + signature font for the tile */
.niche-hair{--bb:#f7f3ee;--bf:#1c1c1c;--ba:#b8924a;--bn:'Cormorant Garamond',serif;--bs:italic;--bw:400}
.niche-barber{--bb:#0d0d0d;--bf:#f5f0e8;--ba:#d4a017;--bn:'Bebas Neue',sans-serif;--bs:normal;--bw:400}
.niche-spa{--bb:#0e1a10;--bf:#f5f0e8;--ba:#c9a96e;--bn:'Marcellus',serif;--bs:normal;--bw:400}
.niche-lash{--bb:#e8c8d0;--bf:#2d1f24;--ba:#9c5566;--bn:'Italiana',serif;--bs:normal;--bw:400}
.niche-med{--bb:#1e3a5f;--bf:#f4f6fa;--ba:#c47a3d;--bn:'Tenor Sans',serif;--bs:normal;--bw:400}
.niche-nails{--bb:#fdf6f0;--bf:#1e1412;--ba:#dd5b3e;--bn:'Yeseva One',serif;--bs:normal;--bw:400}
.niche-tattoo{--bb:#0a0a0a;--bf:#f0ece4;--ba:#cc4422;--bn:'Cinzel',serif;--bs:normal;--bw:400}
.niche-archive{--bb:var(--paper-2);--bf:var(--ink);--ba:var(--accent);--bn:var(--serif);--bs:italic;--bw:300}

/* Per-brand name SIZE adjustments — sized for both the tall portrait tiles
   AND the wide cinematic feature tiles (middle row of the magazine spread). */
.niche-hair .niche-name{font-size:clamp(48px,5vw,80px)}
.niche-barber .niche-name{text-transform:uppercase;letter-spacing:.005em;font-size:clamp(40px,4.4vw,68px)}
.niche-spa .niche-name{font-size:clamp(44px,4.6vw,72px)}
.niche-lash .niche-name{font-size:clamp(48px,5vw,76px)}
.niche-med .niche-name{font-size:clamp(44px,4.6vw,68px)}
.niche-nails .niche-name{font-size:clamp(46px,4.8vw,72px)}
.niche-tattoo .niche-name{text-transform:uppercase;letter-spacing:.04em;font-size:clamp(34px,3.6vw,52px)}
.niche-archive .niche-name{font-size:clamp(38px,4.2vw,60px)}

/* Wide feature tiles (middle row, span 3) — bigger names since there's more horizontal room */
.niches .niche:nth-child(4) .niche-name,
.niches .niche:nth-child(5) .niche-name{font-size:clamp(56px,6vw,108px)}
.niches .niche-barber:nth-child(4) .niche-name,
.niches .niche-barber:nth-child(5) .niche-name{font-size:clamp(48px,5.2vw,88px)}
.niches .niche-tattoo:nth-child(4) .niche-name,
.niches .niche-tattoo:nth-child(5) .niche-name{font-size:clamp(40px,4.4vw,72px)}

/* Dark tiles need a lighter row separator */
.niche-barber .niche-row,
.niche-spa .niche-row,
.niche-med .niche-row,
.niche-tattoo .niche-row{border-top-color:rgba(255,255,255,.14)}

/* Archive tile (no photo) — diagonal paper stripes as the visual.
   Type goes back to ink color since there's no photo behind it. */
.niche-archive .niche-art{
  background:repeating-linear-gradient(135deg,var(--paper-2) 0 18px,var(--paper-3) 18px 19px);
}
.niche-archive .niche-art::before{display:none}
.niche-archive .niche-top{color:var(--ink-2)}
.niche-archive .niche-folio{text-shadow:none}
.niche-archive .niche-name{color:var(--ink);text-shadow:none}
.niche-archive .niche-name em{font-style:italic;color:var(--accent)}

/* ─── Niche grid: asymmetric magazine spread (3 portraits / 2 features / 3) ───
   Replaces the uniform 3-col rectangle grid with an editorial spread that
   uses CSS-grid spans + varied aspect ratios. Three portrait tiles (3/4) on
   top, two wide cinematic feature tiles (4/3) in the middle, three portraits
   on bottom. Reads like a magazine page-turn instead of a card sheet. */
.niches{
  display:grid;grid-template-columns:repeat(6, 1fr);
  gap:20px;margin-top:40px;
}
.niches .niche{grid-column:span 2;aspect-ratio:3/4}
.niches .niche:nth-child(4),
.niches .niche:nth-child(5){grid-column:span 3;aspect-ratio:4/3}

@media (max-width:1100px){
  .niches{grid-template-columns:repeat(2, 1fr);gap:16px}
  .niches .niche{grid-column:auto;aspect-ratio:4/5}
  .niches .niche:nth-child(4),
  .niches .niche:nth-child(5){grid-column:auto;aspect-ratio:4/5}
}
@media (max-width:640px){
  .niches{grid-template-columns:1fr;gap:14px}
  .niches .niche{aspect-ratio:5/6}
  .niches .niche:nth-child(4),
  .niches .niche:nth-child(5){aspect-ratio:5/6}
  .niche-art{padding:18px 18px 22px;min-height:240px}
  .niche-name{font-size:clamp(36px,11vw,60px) !important}
  .niche-barber .niche-name,.niche-tattoo .niche-name{font-size:clamp(32px,10vw,52px) !important}
  .niche-bottom{padding:12px 16px 16px}
}

/* ─── Policy section: what we don't do (anti-manifesto) ─── */
.policy-section{padding:140px 0 120px;background:var(--paper);position:relative;border-top:1px solid var(--rule-soft);border-bottom:1px solid var(--rule-soft)}
.policy-stack{
  list-style:none;display:flex;flex-direction:column;
  border-top:1px solid var(--rule);margin:56px 0 0;padding:0;
}
.policy-beat{
  display:grid;grid-template-columns:96px 1fr;gap:48px 56px;
  padding:64px 0;border-bottom:1px solid var(--rule-soft);
  align-items:start;
}
.policy-beat:last-child{border-bottom:0}
.policy-num{
  grid-row:1/2;grid-column:1/2;
  font-family:var(--mono);font-size:13px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent-2);font-weight:500;
  padding-top:.65em;line-height:1;font-feature-settings:'tnum' 1;
}
.policy-h{
  grid-row:1/2;grid-column:2/3;margin:0;
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(40px,7vw,116px);line-height:.94;letter-spacing:-.034em;color:var(--ink);
}
.policy-h .ne{font-style:normal;font-weight:300;color:var(--ink-3)}
.policy-h em{font-style:italic;color:var(--accent);font-weight:300}
.policy-body{
  grid-row:2/3;grid-column:2/3;margin:0;
  font-size:16px;line-height:1.7;color:var(--ink-2);max-width:54ch;
}
.policy-close{
  margin:64px 0 0;padding:32px 0 0;
  border-top:1px solid var(--rule);
  font-family:var(--serif);font-weight:300;
  font-size:clamp(22px,2.4vw,32px);line-height:1.36;letter-spacing:-.008em;
  color:var(--ink);max-width:54ch;
}
.policy-close em{font-style:italic;color:var(--accent-2)}
@media (prefers-reduced-motion:no-preference){
  .policy-beat{
    opacity:.18;transform:translateX(40px);
    transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1);
  }
  .policy-beat.is-in{opacity:1;transform:none}
}
@media (max-width:880px){
  .policy-section{padding:64px 0 56px}
  .policy-stack{margin-top:32px}
  .policy-beat{grid-template-columns:1fr;gap:6px;padding:36px 0;transform:translateY(20px) translateX(0)}
  .policy-beat.is-in{transform:none}
  .policy-num{grid-row:auto;grid-column:auto;padding-top:0}
  .policy-h{grid-row:auto;grid-column:auto;font-size:clamp(32px,9vw,56px);line-height:.96;margin-top:6px}
  .policy-body{grid-row:auto;grid-column:auto;margin-top:14px}
  .policy-close{margin-top:40px;padding-top:24px;font-size:18px;line-height:1.4}
}

/* ─── Section folios (Roman numerals — magazine section indicators) ─── */
.folio{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(48px,5vw,88px);line-height:.86;letter-spacing:-.02em;
  color:var(--accent);
  margin:0 0 18px;display:block;
}
.section--ink .folio,.approach-pin .folio,.cta-block .folio{color:var(--accent-3)}
@media (max-width:880px){
  .folio{font-size:clamp(40px,9vw,56px);margin-bottom:8px}
}

/* ─── Counter completion flash (small payoff moment when stats finish counting) ─── */
@media (prefers-reduced-motion:no-preference){
  @keyframes counterDone{
    0%{color:var(--ink);text-shadow:none}
    18%{color:var(--accent);text-shadow:0 0 22px rgba(155,128,173,.32)}
    100%{color:var(--ink);text-shadow:none}
  }
  .counter.is-done{animation:counterDone 1.6s cubic-bezier(.2,.7,.2,1)}
  .section--ink .counter.is-done,.cta-block .counter.is-done{
    animation-name:counterDoneInk;
  }
  @keyframes counterDoneInk{
    0%{color:var(--paper);text-shadow:none}
    18%{color:var(--accent-3);text-shadow:0 0 28px rgba(194,173,207,.4)}
    100%{color:var(--paper);text-shadow:none}
  }
}

/* ─── Section heading underline draw on reveal (editorial flourish) ─── */
@media (prefers-reduced-motion:no-preference){
  .h-section{position:relative;padding-bottom:18px;display:inline-block}
  .h-section::after{
    content:'';position:absolute;left:0;bottom:0;
    width:0;height:1px;background:var(--accent);
    transition:width 1.4s cubic-bezier(.2,.7,.2,1) .4s;
  }
  .reveal.is-in .h-section::after,
  .reveal.is-in > .h-section::after,
  .is-in .h-section::after{width:96px}
  .section--ink .h-section::after{background:var(--accent-3)}
  .approach-pin h2{position:relative;padding-bottom:18px;display:inline-block}
  .approach-pin h2::after{
    content:'';position:absolute;left:0;bottom:0;
    width:0;height:1px;background:var(--accent-3);
    transition:width 1.4s cubic-bezier(.2,.7,.2,1) .4s;
  }
  .approach-pin h2.is-in::after,
  .reveal.is-in.approach-pin h2::after,
  .approach-pin .reveal.is-in h2::after{width:96px}
}

/* ─── Niche tile 3D hover tilt (pointermove-driven perspective) ─── */
@media (prefers-reduced-motion:no-preference){
  .niche{will-change:transform}
  .niche.is-tilt{transition:transform .12s linear,box-shadow .35s ease,border-color .35s ease}
}

/* ─── Studio note recompose (Kyle quote — full-bleed editorial feature) ─── */
.studio-note-bleed-section{background:var(--paper-2);position:relative;border-top:1px solid var(--rule-soft);border-bottom:1px solid var(--rule-soft)}
.studio-note-bleed{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  min-height:88vh;align-items:stretch;
}
.studio-note-photo{position:relative;overflow:hidden;background:var(--ink)}
.studio-note-photo img{width:100%;height:100%;object-fit:cover;display:block}
.studio-note-cap{
  position:absolute;left:24px;bottom:24px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.92);
  background:rgba(58,47,68,.55);padding:8px 14px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.studio-note-content{
  display:flex;align-items:center;
  padding:96px 72px 96px 96px;
}
.studio-note-content .reveal{display:flex;flex-direction:column;gap:32px;max-width:46ch}
.studio-note-eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-2);font-weight:500;
}
.studio-note-quote{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(28px,3.4vw,46px);line-height:1.18;letter-spacing:-.018em;color:var(--ink);
}
.studio-note-quote em{font-style:italic;color:var(--accent-2);font-weight:300}
.studio-note-cite{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);
  padding-top:20px;border-top:1px solid var(--rule-soft);max-width:46ch;
}
@media (max-width:980px){
  .studio-note-bleed{grid-template-columns:1fr;min-height:0}
  .studio-note-photo{aspect-ratio:4/3;max-height:520px}
  .studio-note-content{padding:48px 24px}
  .studio-note-quote{font-size:22px;line-height:1.36}
  .studio-note-content .reveal{gap:20px}
}

/* ─── Pull-quote testimonial (the lead "wow" review on testimonials) ─── */
.pull-quote-feature{
  display:grid;grid-template-columns:1fr 4fr;gap:64px;align-items:start;
  margin:0 0 80px;padding-top:32px;
  border-top:1px solid rgba(255,255,255,.12);
}
.pull-quote-feature .pq-meta{
  display:flex;flex-direction:column;gap:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
}
.pull-quote-feature .pq-meta b{color:var(--accent-3);font-weight:500}
.pull-quote-feature .pq-stars{color:var(--accent-3);font-size:14px;letter-spacing:.24em;font-family:var(--mono)}
.pull-quote-feature .pq-body{position:relative;display:flex;flex-direction:column;gap:32px;max-width:64ch}
.pull-quote-feature blockquote{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(34px,4.6vw,68px);line-height:1.06;letter-spacing:-.018em;
  color:var(--paper);margin:0;max-width:22ch;position:relative;
}
.pull-quote-feature blockquote::before{
  content:'\201C';position:absolute;left:-0.5em;top:-0.18em;
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:1.8em;line-height:1;color:var(--accent-3);opacity:.55;
}
.pull-quote-feature blockquote em{font-style:italic;color:var(--accent-3);font-weight:300}
.pull-quote-feature figcaption{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  padding-top:18px;border-top:1px solid rgba(255,255,255,.18);
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
.pull-quote-feature .pq-name{color:#fff;font-weight:500;letter-spacing:.14em}
.pull-quote-feature .pq-verified{color:var(--accent-3);display:inline-flex;align-items:center;gap:6px}
.pull-quote-feature .pq-verified::before{content:'\2713';font-family:var(--sans);font-weight:600}
@media (max-width:880px){
  .pull-quote-feature{grid-template-columns:1fr;gap:18px;margin-bottom:40px;padding-top:24px}
  .pull-quote-feature blockquote{font-size:clamp(26px,8vw,40px)}
  .pull-quote-feature blockquote::before{font-size:1.4em;left:-0.4em}
  .pull-quote-feature figcaption{font-size:10px;flex-direction:column;align-items:flex-start;gap:6px}
}

/* ─── Editorial section breaker (used between sections) ─── */
.section-break{
  display:flex;align-items:center;gap:24px;
  padding:36px 0;max-width:var(--max);margin:0 auto;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}
.section-break::before,.section-break::after{content:'';flex:1;height:1px;background:var(--rule-soft)}
.section-break b{color:var(--ink);font-weight:500;letter-spacing:.16em}
.section-break em{font-style:italic;font-family:var(--serif);font-weight:300;color:var(--accent);letter-spacing:0;text-transform:none;font-size:13px}
@media (max-width:880px){.section-break{padding:20px var(--pad-x);gap:14px}}

/* ─────────────────────────────────────────────────────────
   v9 — phase 2 dynamism: niches bleed · approach pin · featured pin · CTA bleed
   ───────────────────────────────────────────────────────── */

/* ─── Editorial running-head (3-column section meta) ─── */
.running-head{
  display:grid;grid-template-columns:1fr auto 1fr;gap:32px;align-items:baseline;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
  margin:0 0 32px;
}
.running-head b{color:var(--ink);font-weight:500;letter-spacing:.16em}
.running-head .center{
  font-family:var(--serif);font-style:italic;font-weight:300;font-size:14px;
  letter-spacing:0;text-transform:none;color:var(--ink);
  display:inline-flex;align-items:center;gap:14px;
}
.running-head .center::before,.running-head .center::after{
  content:'';display:inline-block;width:18px;height:1px;background:var(--rule);
}
.running-head .right{text-align:right}
.section--ink .running-head{color:rgba(255,255,255,.5)}
.section--ink .running-head b{color:#fff}
.section--ink .running-head .center{color:var(--paper)}
.section--ink .running-head .center::before,.section--ink .running-head .center::after{background:rgba(255,255,255,.18)}
.cta-block .running-head{color:rgba(255,255,255,.5)}
.cta-block .running-head b{color:var(--accent-3)}
.cta-block .running-head .center{color:var(--paper)}
.cta-block .running-head .center::before,.cta-block .running-head .center::after{background:rgba(255,255,255,.18)}
@media (max-width:880px){
  .running-head{grid-template-columns:1fr;gap:6px;font-size:9.5px;letter-spacing:.14em;margin-bottom:20px}
  .running-head .center{display:none}
  .running-head .right{text-align:left}
}

/* ─── Niches grid: full-bleed at desktop, 4-col at large ─── */
/* Note: a previous v8 4-col-at-1400+ override was removed in v20 since the
   new asymmetric magazine spread (6-col grid with span-2/span-3 mixing) supersedes it. */

/* ─── Approach: scroll-pinned narrative ─── */
.approach-grid{
  display:grid;grid-template-columns:1fr 1.25fr;gap:96px;
  position:relative;align-items:start;
}
.approach-pin{
  position:sticky;top:120px;
  align-self:start;
  display:flex;flex-direction:column;gap:24px;
  padding-top:8px;
}
.approach-pin .meta{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:8px}
.approach-pin .meta b{color:var(--accent-3);font-weight:500}
.approach-pin h2{font-family:var(--serif);font-weight:300;font-size:clamp(40px,5.5vw,84px);line-height:.96;letter-spacing:-.025em;color:var(--paper)}
.approach-pin h2 em{font-style:italic;color:var(--accent-3);font-weight:300}
.approach-pin .lead{font-family:var(--serif);font-weight:300;font-size:clamp(20px,2vw,26px);line-height:1.4;color:rgba(255,255,255,.85);max-width:34ch}
.approach-pin .lead em{font-style:italic;color:var(--accent-3)}
.approach-pin .lead::first-letter{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:3.6em;line-height:.82;
  float:left;
  margin:.06em .14em -.05em -.04em;
  color:var(--accent-3);
}
.approach-pin .body{font-size:15px;line-height:1.7;color:rgba(255,255,255,.62);max-width:42ch}
.approach-pin .actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-top:16px}

.approach-steps{list-style:none;display:flex;flex-direction:column;gap:0}
.approach-step{
  display:grid;grid-template-columns:120px 1fr;gap:32px;align-items:start;
  padding:64px 0;border-bottom:1px solid rgba(255,255,255,.10);
  opacity:.18;transform:translateX(48px);
  transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1);
}
.approach-step:first-child{padding-top:0}
.approach-step:last-child{border-bottom:0}
.approach-step.is-in{opacity:1;transform:none}
.approach-step .step-num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(72px,7vw,104px);line-height:.86;letter-spacing:-.03em;
  color:var(--accent-3);
  font-feature-settings:'tnum' 1;
}
.approach-step .step-content{display:flex;flex-direction:column;gap:14px}
.approach-step .step-when{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
}
.approach-step .step-h{
  font-family:var(--serif);font-weight:300;font-size:clamp(28px,3.4vw,46px);line-height:1.02;letter-spacing:-.02em;
  color:var(--paper);
}
.approach-step .step-h em{font-style:italic;color:var(--accent-3);font-weight:300}
.approach-step .step-body{
  font-size:15.5px;line-height:1.7;color:rgba(255,255,255,.62);max-width:50ch;margin-top:4px;
}

@media (max-width:980px){
  .approach-grid{grid-template-columns:1fr;gap:32px}
  .approach-pin{position:static;padding-top:0}
  .approach-step{grid-template-columns:64px 1fr;gap:18px;padding:32px 0;transform:translateY(20px) translateX(0)}
  .approach-step.is-in{transform:none}
  .approach-step .step-num{font-size:48px}
  .approach-step .step-h{font-size:24px}
}
@media (prefers-reduced-motion:reduce){
  .approach-step{opacity:1;transform:none}
}

/* ─── Featured case study: pin the cover, scroll the meta+rows ─── */
.featured-pin-grid{
  display:grid;grid-template-columns:1fr 1.05fr;gap:80px;align-items:start;
  margin-top:56px;
}
.featured-pin-col{position:sticky;top:120px;align-self:start}
.featured-flow-col{display:flex;flex-direction:column;gap:36px;min-width:0}
/* Tighten the right-column rhythm — was reading as oversized blocks of empty space.
   Lead in this context is a brief, not a hero lede — drop it a tier from .lead's
   global clamp(22px,2.4vw,30px) to a more conversational scale. */
.featured-flow-col .lead{
  font-size:clamp(19px,1.7vw,24px);line-height:1.4;max-width:46ch;margin-top:14px;
}
.featured-flow-col .featured-meta-list{margin:24px 0 0}
.featured-flow-col .featured-actions{margin-top:24px}
.featured-flow-col .list-rows{margin-top:8px}

@media (max-width:980px){
  .featured-pin-grid{grid-template-columns:1fr;gap:32px;margin-top:32px}
  .featured-pin-col{position:static}
  .featured-flow-col{gap:24px}
  .featured-flow-col .lead{font-size:18px;line-height:1.42}
}

/* ─── CTA block: full-bleed theatrical variant ─── */
.cta-block--bleed{padding:140px 0 120px;position:relative;overflow:hidden}
.cta-block--bleed::before{
  content:'';position:absolute;inset:auto -10% -50% 20%;
  height:720px;width:720px;border-radius:50%;
  background:radial-gradient(circle,var(--accent) 0%,transparent 70%);
  opacity:.22;pointer-events:none;
}
.cta-block--bleed::after{
  content:'';position:absolute;inset:-30% 60% auto auto;
  height:480px;width:480px;border-radius:50%;
  background:radial-gradient(circle,var(--accent-3) 0%,transparent 65%);
  opacity:.10;pointer-events:none;
}
.cta-block--bleed .fullbleed{position:relative;z-index:1}
.cta-bleed-h{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(64px,11vw,196px);line-height:.88;letter-spacing:-.04em;
  color:var(--paper);margin:0 0 48px;max-width:none;
}
.cta-bleed-h em{font-style:italic;font-weight:300;color:var(--accent-3)}
.cta-bleed-foot{
  display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:end;
  padding-top:48px;border-top:1px solid rgba(255,255,255,.18);
}
.cta-bleed-foot .lead{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(20px,2.2vw,28px);line-height:1.36;letter-spacing:-.005em;
  color:rgba(255,255,255,.82);max-width:42ch;
}
.cta-bleed-foot .lead em{font-style:italic;color:var(--accent-3)}
.cta-bleed-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.cta-block--bleed .meta-strip{
  display:flex;gap:32px;flex-wrap:wrap;margin-top:64px;padding-top:32px;
  border-top:1px solid rgba(255,255,255,.16);
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5);
}
.cta-block--bleed .meta-strip b{color:#fff;font-weight:500}

@media (max-width:980px){
  .cta-block--bleed{padding:64px 0 56px}
  .cta-bleed-h{font-size:clamp(40px,9vw,72px);margin-bottom:32px;letter-spacing:-.03em}
  .cta-bleed-foot{grid-template-columns:1fr;gap:24px;padding-top:24px}
  .cta-bleed-foot .lead{font-size:18px;line-height:1.45;max-width:none}
  .cta-block--bleed .meta-strip{gap:18px;margin-top:36px;padding-top:20px;font-size:10.5px;letter-spacing:.12em}
}

/* ────────────────────────────────────────────────────────────────────────
   Mobile scroll-perf overrides — disable expensive effects that cause
   jank on iOS Safari and lower-end Android. Targets:
   - backdrop-filter (very expensive blur+saturate on iOS Safari)
   - infinite kenburns + heavy image animations (continuous compositor work)
   - hover transitions that don't apply on touch
   - content-visibility: auto on long off-screen sections
   ──────────────────────────────────────────────────────────────────────── */
@media (max-width: 880px) {
  /* Solid-bg topbar instead of expensive blur — iOS Safari struggles with
     backdrop-filter during scroll, especially on a sticky element. */
  .topbar.is-scrolled,
  .topbar {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  .topbar.is-scrolled {
    background: rgba(245,241,234,0.96) !important;
  }

  /* Subnav (sticky nav under hero on some pages) — same treatment */
  .subnav {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    background: rgba(245,241,234,0.96) !important;
  }

  /* Plate captions on photos — backdrop-filter not worth the cost on a
     small mobile element; use solid bg with same visual feel. */
  .plate-cap, .niche-tag, .hero-photo-cap, .studio-note-cap, .featured-cover .cover-tag {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  /* Long off-screen sections — let the browser skip rendering until they
     scroll close to viewport. Saves layout/paint work mid-scroll. */
  section.section,
  section.policy-section,
  section.studio-note-bleed-section,
  section.bleed-hero ~ section {
    content-visibility: auto;
    contain-intrinsic-size: 0 800px;
  }
}

/* Always-on: pause infinite-loop animations when user prefers reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
