/* ============================================================
   WOVLY — wool dryer balls · editorial stylesheet v2
   ============================================================ */
:root{
  --ink:#211d1c; --ink-soft:#5b534e;
  --ecru:#EAE8E1; --greige:#7A6E62; --kraft:#C08A4E; --kraft-dk:#9d6c34;
  --sage:#6E7C5E; --sage-dk:#4f5b41; --sage-bg:#E8EBE0;
  --mist:#CDD3D8; --paper:#F2F1ED; --paper-2:#FAFAF7; --line:#E3E1D9;
  --maxw:1240px; --r:18px;
  --shadow:0 2px 6px rgba(33,29,28,.05), 0 24px 60px -20px rgba(33,29,28,.18);
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{margin:0;font-family:"Inter",system-ui,sans-serif;color:var(--ink);background:var(--paper);
  font-size:17.5px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:clip;max-width:100%;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/></svg>");
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* type */
h1,h2,h3,h4{font-family:"Archivo",sans-serif;font-weight:800;line-height:1.04;letter-spacing:-.025em;margin:0 0 .35em}
.display{font-size:clamp(2.8rem,7.5vw,6rem);font-weight:900;line-height:.95;letter-spacing:-.04em}
h1{font-size:clamp(2.4rem,5.5vw,4.2rem)}
h2{font-size:clamp(1.9rem,3.8vw,3rem)}
h3{font-size:1.2rem;letter-spacing:-.01em}
p{margin:0 0 1rem}
.serif{font-family:"Fraunces",Georgia,serif;font-optical-sizing:auto}
.lede{font-size:clamp(1.08rem,1.7vw,1.4rem);color:var(--ink-soft);max-width:48ch;line-height:1.5}
.eyebrow{font-family:"Archivo",sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.32em;font-size:.7rem;color:var(--kraft);display:inline-flex;align-items:center;gap:.8em;margin:0 0 1.1rem}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--kraft)}
.eyebrow.c::before{display:none}
.muted{color:var(--ink-soft)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:clamp(64px,10vw,140px) 0}
.center{text-align:center}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:"Archivo",sans-serif;font-weight:700;font-size:.78rem;
  letter-spacing:.12em;text-transform:uppercase;
  padding:1.02em 1.75em;border-radius:2px;border:1.5px solid var(--kraft);background:var(--kraft);color:#fff;
  cursor:pointer;transition:transform .22s var(--ease),background .2s,color .2s,border-color .2s,box-shadow .25s}
.btn:hover{transform:translateY(-2px);background:var(--kraft-dk);border-color:var(--kraft-dk);box-shadow:0 12px 26px -10px rgba(33,29,28,.4)}
.btn--kraft{background:var(--kraft);border-color:var(--kraft);color:#fff}
.btn--kraft:hover{background:var(--kraft-dk);border-color:var(--kraft-dk)}
.btn--ink{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.btn--ink:hover{background:#000;border-color:#000}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.arrowlink{font-family:"Archivo",sans-serif;font-weight:700;font-size:.92rem;display:inline-flex;gap:.5em;align-items:center;border-bottom:2px solid var(--kraft);padding-bottom:3px;transition:gap .2s}
.arrowlink:hover{gap:.9em}

/* header */
.site-head{position:sticky;top:0;z-index:60;background:rgba(242,241,237,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;height:74px}
.brand{display:flex;align-items:center;gap:11px;font-family:"Archivo",sans-serif;font-weight:900;font-size:1.4rem;letter-spacing:-.01em}
.brand img{height:48px;width:auto}
.nav-links{display:flex;gap:30px;list-style:none;margin:0;padding:0}
.nav-links a{font-weight:500;font-size:.94rem;color:var(--ink-soft);position:relative;transition:color .15s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--kraft);transition:width .25s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;gap:10px}
.nav-cta .btn{padding:.74em 1.2em;font-size:.7rem}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.3s}
.mobile-menu{display:none;border-top:1px solid var(--line);background:var(--paper);padding:12px 28px 22px}
.mobile-menu a{display:block;padding:11px 0;font-weight:500;border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:14px;width:100%;justify-content:center}
.mobile-menu.open{display:block}

/* ============ HERO — interactive pull-to-open ============ */
.hero{position:relative;min-height:94vh;display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center;
  padding:40px 0 60px;background:
    radial-gradient(120% 90% at 80% 10%,#efe6d6 0%,#e8dfce 45%,#e2d8c4 100%);
  overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(40% 50% at 78% 60%,rgba(192,138,78,.10),transparent 70%);pointer-events:none}
.hero-head{position:relative;z-index:3;max-width:34ch;padding-left:28px}
.hero .display{margin:.1em 0 .3em}
.hero .display em{font-family:"Fraunces",serif;font-style:italic;font-weight:500;color:var(--kraft)}
.hero-head .lede{color:var(--ink-soft)}
.hero-head .btn-row{margin-top:1.7rem}

/* interactive stage */
.opener{position:relative;z-index:3;padding-right:28px}
.stage{position:relative;aspect-ratio:16/11;border-radius:22px;overflow:hidden;background:#efe7d8;
  box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.5)}
.stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .45s var(--ease)}
.stage img.show{opacity:1}
.stage video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.stage .corner{position:absolute;top:16px;left:16px;z-index:4;font-family:"Archivo",sans-serif;font-weight:700;
  font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:#6b5f50;background:rgba(255,253,249,.8);
  padding:6px 12px;border-radius:999px;backdrop-filter:blur(4px)}
/* drag track */
.opener-ctl{margin:18px 4px 0;display:flex;align-items:center;gap:16px}
.track{position:relative;flex:1;height:54px;border-radius:999px;background:var(--paper-2);border:1.5px solid var(--line);
  box-shadow:inset 0 1px 3px rgba(33,29,28,.06);cursor:grab;touch-action:none;user-select:none}
.track:active{cursor:grabbing}
.track .fill{position:absolute;left:0;top:0;bottom:0;width:14%;background:linear-gradient(90deg,#efe0c9,#dcb98a);border-radius:999px;transition:width .05s linear}
.track .knob{position:absolute;top:50%;left:14%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;
  background:var(--kraft);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;
  box-shadow:0 6px 16px -4px rgba(157,108,52,.6);transition:left .05s linear,transform .15s}
.track .knob:hover{transform:translate(-50%,-50%) scale(1.06)}
.opener-label{font-family:"Archivo",sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--greige);white-space:nowrap}
@keyframes nudge{0%,100%{transform:translate(-50%,-50%)}50%{transform:translate(-30%,-50%)}}
.track.idle .knob{animation:nudge 1.6s var(--ease) infinite}

/* ============ HERO v2 — full-screen scroll-scrub ============ */
.hero-scroll{position:relative;height:280vh;background:#0c0c0e}
.hero-stage{position:sticky;top:74px;height:calc(100vh - 74px);overflow:hidden;background:#0c0c0e}
.hero-video,.hero-fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 56%;display:block}
.hero-fallback{display:none}
.hero-scrim{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:0;transition:opacity .45s var(--ease);
  background:linear-gradient(180deg,rgba(8,8,10,.10) 0%,rgba(8,8,10,.30) 55%,rgba(8,8,10,.62) 100%)}
.hero-hint{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:4;
  font-family:"Archivo",sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.85);display:flex;flex-direction:column;align-items:center;gap:10px;transition:opacity .4s var(--ease)}
.hero-hint::after{content:"";width:1.5px;height:30px;background:rgba(255,255,255,.7)}
.hero-overlay{position:absolute;z-index:3;left:0;right:0;bottom:6vh;padding:0 7vw;max-width:46ch;
  opacity:0;transform:translateY(16px);transition:opacity .55s var(--ease),transform .55s var(--ease);pointer-events:none}
.hero-overlay.show{opacity:1;transform:none;pointer-events:auto}
.hero-overlay .eyebrow{color:rgba(255,255,255,.82);font-size:.62rem;margin-bottom:.75rem}
.hero-overlay .display{color:#fff;font-size:clamp(2rem,5.2vw,4.2rem);line-height:1;margin:.1em 0 .3em}
.hero-overlay .display em{font-family:"Fraunces",serif;font-style:italic;font-weight:500;color:var(--kraft)}
.hero-overlay .hero-sub{color:#fff;font-family:"Archivo",sans-serif;font-weight:700;font-size:clamp(1rem,1.55vw,1.22rem);
  letter-spacing:-.01em;white-space:nowrap;margin:0 0 .55rem}
.hero-overlay .lede{color:rgba(255,255,255,.85);font-size:clamp(.92rem,1.15vw,1.05rem);line-height:1.5;max-width:42ch;margin-bottom:0}
.hero-overlay .btn-row{margin-top:1.3rem}
.hero-overlay .btn{padding:.9em 1.5em;font-size:.74rem}
.hero-overlay .btn--ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.hero-overlay .btn--ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
@media (max-width:760px){
  .hero-scroll{height:240vh}
  .hero-overlay{bottom:7vh;padding:0 22px;max-width:none}
  .hero-overlay .hero-sub{white-space:normal}
}
@media (prefers-reduced-motion: reduce){
  .hero-scroll{height:100vh}
  .hero-video,.hero-hint{display:none}
  .hero-fallback{display:block}
  .hero-scrim{opacity:1}
  .hero-overlay{opacity:1;transform:none;pointer-events:auto}
}

/* ============ marquee ============ */
.marquee{background:var(--ink);color:var(--paper);padding:16px 0;overflow:hidden;white-space:nowrap}
.marquee .run{display:inline-block;animation:scroll 26s linear infinite;font-family:"Archivo",sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.18em;font-size:.86rem}
.marquee .run span{padding:0 26px;opacity:.92}
.marquee .run span b{color:var(--kraft)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ generic editorial split ============ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center}
.split.rev .txt{order:2}
.figure{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.figure img{width:100%;display:block}
.figure .cap{position:absolute;left:14px;bottom:14px;background:rgba(242,241,237,.9);backdrop-filter:blur(4px);
  font-size:.72rem;font-weight:600;letter-spacing:.05em;color:var(--ink);padding:6px 12px;border-radius:999px}
.idx{font-family:"Fraunces",serif;font-weight:600;font-size:.95rem;color:var(--kraft);letter-spacing:.05em}

/* values */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;border-top:1px solid var(--line)}
.value{padding:34px 30px 30px;border-right:1px solid var(--line)}
.value:last-child{border-right:0}
.value .n{font-family:"Fraunces",serif;font-size:2.4rem;font-weight:600;color:var(--kraft);line-height:1;display:block;margin-bottom:.25em}
.value h3{margin-bottom:.25em;font-size:1.12rem}
.value p{color:var(--ink-soft);font-size:.96rem;margin:0}

/* editions */
.editions{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.ed-card{position:relative;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:transform .3s var(--ease)}
.ed-card:hover{transform:translateY(-6px)}
.ed-card .im{overflow:hidden}
.ed-card img{aspect-ratio:1/1;object-fit:cover;width:100%;transition:transform .6s var(--ease)}
.ed-card:hover img{transform:scale(1.04)}
.ed-card .body{padding:26px 28px 30px}
.ed-card h3{font-size:1.5rem}
.ed-card .tag{font-family:"Archivo",sans-serif;font-size:.72rem;color:var(--kraft);font-weight:700;text-transform:uppercase;letter-spacing:.14em}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;counter-reset:s}
.step{position:relative;padding-top:18px;border-top:2px solid var(--ecru)}
.step::before{counter-increment:s;content:"0" counter(s);font-family:"Fraunces",serif;font-weight:600;font-size:1.6rem;color:var(--kraft);display:block;margin-bottom:.3em}
.step h3{margin-bottom:.25em}
.step p{color:var(--ink-soft);font-size:.96rem;margin:0}

/* benefits */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 40px}
.benefit{border-top:2px solid var(--ink);padding-top:16px}
.benefit h3{font-size:1.06rem;margin-bottom:.25em}
.benefit p{color:var(--ink-soft);font-size:.94rem;margin:0}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat .big{font-family:"Fraunces",serif;font-weight:600;font-size:clamp(2.4rem,5vw,3.6rem);color:var(--ink);line-height:1}
.stat .lab{font-size:.86rem;color:var(--ink-soft);margin-top:.4em;letter-spacing:.02em}

/* banner */
.banner{position:relative;background:var(--ink);color:var(--paper);border-radius:24px;padding:clamp(40px,6vw,72px);
  display:grid;grid-template-columns:1.5fr 1fr;gap:30px;align-items:center;overflow:hidden}
.banner::after{content:"";position:absolute;right:-60px;top:-60px;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,rgba(192,138,78,.35),transparent 70%)}
.banner h2{color:var(--paper);position:relative;z-index:1}
.banner p{color:#d4ccc1;margin:0;position:relative;z-index:1}
.banner .btn-row{justify-content:flex-end;position:relative;z-index:1}
.banner .btn--ghost{color:var(--paper);border-color:rgba(255,255,255,.5)}
.banner .btn--ghost:hover{background:var(--paper);color:var(--ink)}

/* trust */
.trust{display:flex;flex-wrap:wrap;gap:12px 28px;justify-content:center;color:var(--greige);font-size:.84rem;font-weight:600}
.trust span{display:flex;align-items:center;gap:.5em}
.trust span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--kraft)}

/* spec */
.spec{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:30px 32px;box-shadow:var(--shadow)}
.spec dl{display:grid;grid-template-columns:auto 1fr;gap:11px 24px;margin:0}
.spec dt{font-weight:600;color:var(--greige)}
.spec dd{margin:0;text-align:right;font-weight:500}

/* page hero */
.phero{position:relative;background:radial-gradient(120% 100% at 85% 0%,#EAE8E1,#F2F1ED);
  padding:clamp(60px,9vw,110px) 0 clamp(44px,6vw,70px);border-bottom:1px solid var(--line)}
.phero .lede{margin-top:.5rem}

/* forms */
.form{display:grid;grid-template-columns:1fr 1fr;gap:18px;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:32px;box-shadow:var(--shadow)}
.form .full{grid-column:1/-1}
.form label{display:block;font-size:.8rem;font-weight:600;color:var(--greige);margin-bottom:6px;letter-spacing:.02em}
.form input,.form select,.form textarea{width:100%;padding:.82em .95em;border:1.5px solid var(--line);border-radius:11px;font:inherit;background:var(--paper);color:var(--ink)}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--kraft);box-shadow:0 0 0 3px rgba(192,138,78,.15)}
.form textarea{min-height:130px;resize:vertical}

/* footer */
.site-foot{background:var(--ink);color:#cabfb3;padding:72px 0 38px}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.2fr;gap:36px}
.site-foot h4{font-family:"Archivo",sans-serif;color:var(--paper);font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;margin:0 0 14px}
.site-foot a{display:block;color:#cabfb3;padding:5px 0;font-size:.94rem;transition:color .15s}
.site-foot a:hover{color:#fff}
.foot-brand .logo{display:flex;align-items:center;gap:10px;font-family:"Archivo",sans-serif;font-weight:900;font-size:1.35rem;color:var(--paper);margin-bottom:13px}
.foot-brand .logo img{height:111px}
.foot-brand p{font-size:.92rem;max-width:36ch}
.foot-bottom{margin-top:48px;padding-top:24px;border-top:1px solid #393230;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.82rem;color:#988f85}
.badge{display:inline-block;border:1px solid #4a423f;border-radius:9px;padding:7px 13px;font-size:.72rem;letter-spacing:.08em}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* responsive */
@media(max-width:900px){
  .nav-links,.nav-cta{display:none}.nav-toggle{display:block}
  .hero{grid-template-columns:1fr;min-height:auto;padding-top:24px}
  .hero-head{padding:0 28px;max-width:none}
  .opener{padding:0 28px}
  .values{grid-template-columns:1fr}.value{border-right:0;border-bottom:1px solid var(--line)}
  .split,.editions,.banner,.form,.foot-grid{grid-template-columns:1fr}
  .split.rev .txt{order:0}.banner .btn-row{justify-content:flex-start}
  .steps,.benefits{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .spec dd{text-align:left}
}
@media(max-width:560px){.steps,.benefits,.stats{grid-template-columns:1fr}}

/* ============ full-width color band ============ */
.band{position:relative;width:100%;min-height:clamp(360px,52vw,640px);background-size:cover;background-position:center;display:flex;align-items:flex-end;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(8,8,10,.6),rgba(8,8,10,.22) 52%,rgba(8,8,10,.04) 78%,transparent)}
.band .band-in{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%;padding:0 28px clamp(38px,6vw,72px)}
.band .eyebrow{color:rgba(255,255,255,.85)}
.band h2{color:#fff;max-width:17ch;margin:.1em 0 .5rem}
.band p{color:rgba(255,255,255,.9);max-width:42ch}
.band .btn-row{margin-top:1.4rem}
.band .btn--ghost{color:#fff;border-color:rgba(255,255,255,.6)}
.band .btn--ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.band--plain::after{background:linear-gradient(180deg,rgba(8,8,10,.04),rgba(8,8,10,.14))}
/* image hover zoom */
.figure img{transition:transform .6s var(--ease)}
.figure:hover img{transform:scale(1.045)}

/* ============ liveliness: rhythm, accent, motion ============ */
/* dark rhythm section */
.section--dark{background:var(--ink);color:var(--paper)}
.section--dark .eyebrow{color:#e0b483}
.section--dark .stat .big{color:#fff}
.section--dark .stat .lab{color:#cfc6ba}
/* sage accent section */
.section--sage{background:var(--sage-bg);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section--sage .eyebrow{color:var(--sage-dk)}
.section--sage .eyebrow::before{background:var(--sage)}
/* editorial pull-quote */
.pullquote{font-family:"Fraunces",serif;font-style:italic;font-weight:500;font-size:clamp(1.55rem,3.3vw,2.6rem);
  line-height:1.28;color:var(--ink);max-width:22ch;margin:0 auto;text-align:center}
.pullquote .by{display:block;font-family:"Archivo",sans-serif;font-style:normal;font-weight:700;font-size:.72rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--sage-dk);margin-top:1.3rem}
/* FAQ accordion */
.faq{max-width:760px;margin:0 auto}
.faq details{border-top:1px solid var(--line);padding:18px 2px}
.faq details:last-of-type{border-bottom:1px solid var(--line)}
.faq summary{font-family:"Archivo",sans-serif;font-weight:700;font-size:1.05rem;cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--kraft);font-size:1.5rem;line-height:1;transition:transform .2s}
.faq details[open] summary::after{content:"\2013"}
.faq p{color:var(--ink-soft);margin:.7rem 0 0;font-size:.98rem;max-width:64ch}
/* staggered reveal for grid siblings */
.reveal:nth-child(2){transition-delay:.07s}
.reveal:nth-child(3){transition-delay:.14s}
.reveal:nth-child(4){transition-delay:.21s}
.reveal:nth-child(5){transition-delay:.28s}
.reveal:nth-child(6){transition-delay:.35s}
@media (prefers-reduced-motion: reduce){ .reveal{transition:none} }

/* footer legal links (inline) */
.foot-legal{font-size:.82rem;color:#988f85;text-align:center}
.foot-legal a{display:inline;color:#988f85;padding:0}
.foot-legal a:hover{color:#fff}

/* ============ legal pages (terms / privacy) ============ */
.legal-body{max-width:780px;margin:0 auto;padding:clamp(48px,7vw,90px) 28px}
.legal-body h2{font-size:1.35rem;margin:2.1em 0 .55em;letter-spacing:-.01em}
.legal-body h2:first-child{margin-top:0}
.legal-body p,.legal-body li{color:var(--ink-soft);font-size:1rem;line-height:1.8;margin-bottom:1rem}
.legal-body ul{padding-left:1.25em;margin-bottom:1rem}
.legal-body li{margin-bottom:.5rem}
.legal-body a{color:var(--kraft-dk);text-decoration:underline;text-underline-offset:2px}
.legal-date{font-size:.86rem;color:var(--greige);margin-top:.6rem}
.legal-box{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:24px 28px;margin-top:44px;box-shadow:var(--shadow)}
.legal-box p{margin:0;color:var(--ink)}

/* ============================================================
   DIRECTION A — EDITORIAL WARM (site-wide, scoped to body.dir-a)
   Serif typography + centered-lifted hero + 16:9 stories +
   line-break hygiene. Applied to every page via body.dir-a.
   ============================================================ */
/* serif headings site-wide */
.dir-a h1{font-family:"Fraunces",Georgia,serif;font-weight:500;letter-spacing:-.02em;line-height:1.05}
.dir-a h2{font-family:"Fraunces",Georgia,serif;font-weight:400;letter-spacing:-.02em;line-height:1.1}
.dir-a h1 em,.dir-a h2 em{font-family:"Fraunces",serif;font-style:italic;font-weight:500;color:var(--kraft-dk)}
.dir-a .phero h1{font-weight:500}
/* line-break hygiene: avoid stranded conjunctions / short words at line ends */
.dir-a h1,.dir-a h2,.dir-a h3,.dir-a h4,.dir-a .display,.dir-a .pullquote,.dir-a .mf{text-wrap:balance}
.dir-a p,.dir-a li,.dir-a dd,.dir-a dt,.dir-a .lede,.dir-a .muted,.dir-a .hero-sub,.dir-a .nl-lede,.dir-a .cap,.dir-a summary,.dir-a figcaption{text-wrap:pretty}
/* remove decorative dash/line before eyebrow labels (looked artificial) */
.dir-a .eyebrow::before{display:none!important}
.dir-a .eyebrow{gap:0}

/* HERO: centered serif, lifted to upper region (index only) */
.dir-a .hero-scrim{background:linear-gradient(180deg,
  rgba(8,8,10,.58) 0%,rgba(8,8,10,.36) 30%,rgba(8,8,10,.12) 56%,rgba(8,8,10,0) 82%)}
.dir-a .hero-overlay{top:7vh;bottom:auto;left:0;right:0;max-width:none;padding:0 7vw;
  text-align:center;display:flex;flex-direction:column;align-items:center}
.dir-a .hero-overlay .eyebrow{justify-content:center;color:rgba(255,255,255,.9);margin-bottom:.85rem}
.dir-a .hero-overlay .eyebrow::before{background:rgba(255,255,255,.6)}
.dir-a .hero-overlay .display{font-family:"Fraunces",Georgia,serif;font-weight:500;
  font-size:clamp(2.5rem,6.6vw,5.6rem);line-height:1.02;letter-spacing:-.02em;color:#fff;margin:.05em 0 .3em}
.dir-a .hero-overlay .display em{font-style:italic;font-weight:500;color:#f0d9bd}
.dir-a .hero-overlay .hero-sub{font-family:"Fraunces",serif;font-style:italic;font-weight:400;
  font-size:clamp(1.02rem,1.6vw,1.35rem);letter-spacing:0;color:#fff;white-space:normal;margin:0 0 1.4rem}
.dir-a .hero-overlay .lede{display:none}
.dir-a .hero-overlay .btn-row{justify-content:center;margin-top:0}
@media (max-width:760px){ .dir-a .hero-overlay{top:5vh} }

/* giant letter-spaced label band */
.labelband{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:clamp(28px,4.2vw,54px) 0;overflow:hidden}
.labelband .lb{font-family:"Archivo",sans-serif;font-weight:800;text-transform:uppercase;
  font-size:clamp(1.5rem,5.8vw,4.8rem);letter-spacing:.16em;line-height:1;color:var(--ink);
  text-align:center;white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:.5em}
.labelband .lb-sub{display:block;text-align:center;font-family:"Archivo",sans-serif;font-weight:700;
  font-size:.66rem;letter-spacing:.34em;text-transform:uppercase;color:var(--greige);margin-top:1.3em}

/* editorial manifesto */
.manifesto{padding:clamp(74px,11vw,150px) 0;text-align:center}
.manifesto .mf{font-family:"Fraunces",Georgia,serif;font-weight:400;
  font-size:clamp(1.65rem,3.5vw,2.9rem);line-height:1.32;letter-spacing:-.015em;color:var(--ink);
  max-width:22ch;margin:0 auto}
.manifesto .mf em{font-style:italic;color:var(--kraft-dk)}
.manifesto .mf-tag{font-family:"Archivo",sans-serif;font-weight:700;font-size:.7rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--greige);margin:0 0 2rem}

/* material story (natural 16:9 photo + serif text) */
.story{padding:clamp(40px,6vw,86px) 0}
.story .wrap{display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(32px,5.5vw,80px);align-items:center}
.story.rev .wrap{grid-template-columns:.88fr 1.12fr}
.story.rev .story-txt{order:2}
.story-fig{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.story-fig img{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;transition:transform .7s var(--ease)}
.story-fig:hover img{transform:scale(1.04)}
.story-fig .cap{position:absolute;left:14px;bottom:14px;background:rgba(242,241,237,.92);backdrop-filter:blur(4px);
  font-size:.72rem;font-weight:600;letter-spacing:.05em;color:var(--ink);padding:6px 12px;border-radius:999px}
.story-ix{font-family:"Fraunces",serif;font-weight:500;font-size:1rem;color:var(--kraft);letter-spacing:.1em;display:block;margin-bottom:1rem}
.story-txt h2{font-size:clamp(1.9rem,3.6vw,3.1rem);line-height:1.08;margin:0 0 .5em}
.story-txt p{color:var(--ink-soft);font-size:clamp(1rem,1.25vw,1.12rem);line-height:1.65;max-width:44ch;margin:0 0 1.2rem}
.story-txt .arrowlink{margin-top:.3rem}

/* editorial hairline stat row */
.statline{padding:clamp(54px,8vw,104px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper-2)}
.statline .row{display:grid;grid-template-columns:repeat(4,1fr)}
.statline .st{padding:0 26px;border-left:1px solid var(--line);text-align:center}
.statline .st:first-child{border-left:0}
.statline .st .big{font-family:"Fraunces",serif;font-weight:400;font-size:clamp(2.4rem,4.6vw,3.7rem);color:var(--ink);line-height:1}
.statline .st .lab{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--greige);margin-top:.7em}

/* editions: editorial framing, serif heads */
.dir-a .ed-card{box-shadow:none;background:transparent;border:0;border-radius:0}
.dir-a .ed-card .im{border-radius:var(--r);box-shadow:var(--shadow)}
.dir-a .ed-card .body{padding:22px 2px 0}
.dir-a .ed-card h3{font-family:"Fraunces",serif;font-weight:500;font-size:1.7rem;letter-spacing:-.01em}

/* more air */
.dir-a .section{padding:clamp(70px,10vw,140px) 0}

@media(max-width:900px){
  .story .wrap,.story.rev .wrap{grid-template-columns:1fr;gap:26px}
  .story.rev .story-txt{order:0}
  .statline .row{grid-template-columns:1fr 1fr;gap:34px 0}
  .statline .st:nth-child(3){border-left:0}
  .statline .st{padding:0 16px}
}
@media(max-width:560px){
  .statline .row{grid-template-columns:1fr}
  .statline .st{border-left:0;padding:18px 0;border-top:1px solid var(--line)}
  .statline .st:first-child{border-top:0}
  .labelband .lb{font-size:clamp(1.3rem,8vw,2.4rem);letter-spacing:.1em}
}

/* ============ newsletter signup band ============ */
.newsletter{background:var(--ink);color:var(--paper);padding:clamp(56px,8vw,96px) 0;text-align:center}
.newsletter .wrap{max-width:720px}
.newsletter .eyebrow{color:#e0b483;justify-content:center}
.newsletter .eyebrow::before{background:#e0b483}
.newsletter h2{color:#fff;margin-bottom:.4em}
.newsletter .nl-lede{color:#cfc6ba;max-width:48ch;margin:0 auto}
.nl-form{display:flex;gap:10px;max-width:480px;margin:1.6rem auto 0}
.nl-form input[type="email"]{flex:1;padding:.92em 1.05em;border:1.5px solid rgba(255,255,255,.25);border-radius:2px;
  background:rgba(255,255,255,.06);color:#fff;font:inherit}
.nl-form input[type="email"]::placeholder{color:rgba(255,255,255,.5)}
.nl-form input[type="email"]:focus{outline:none;border-color:var(--kraft);box-shadow:0 0 0 3px rgba(192,138,78,.2)}
.nl-form .btn{flex:none}
.nl-note{font-size:.8rem;color:#988f85;margin-top:.95rem}
@media(max-width:520px){.nl-form{flex-direction:column}}

/* ============ how-it-works: media slots + steps ============ */
.media-slot{position:relative;aspect-ratio:16/9;border:2px dashed #d9d4c8;border-radius:var(--r);
  background:var(--paper-2);display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;overflow:hidden}
.media-slot img,.media-slot video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.media-slot .ms-in{position:relative;max-width:34ch}
.media-slot .ms-tag{font-family:"Archivo",sans-serif;font-weight:700;font-size:.64rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--kraft);display:block;margin-bottom:.5em}
.media-slot .ms-desc{font-size:.9rem;color:var(--greige);margin:0;line-height:1.5}
.media-slot.sq{aspect-ratio:1/1}
.media-slot.tall{aspect-ratio:4/5}
.media-slot.has-img{border:0;background:transparent}
.hiw-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.hiw-step .media-slot{aspect-ratio:4/3;margin-bottom:16px}
.hiw-step .n{font-family:"Fraunces",serif;font-weight:600;color:var(--kraft);font-size:1.4rem;line-height:1}
.hiw-step h3{margin:.3em 0 .25em}
.hiw-step p{color:var(--ink-soft);font-size:.96rem;margin:0}
@media(max-width:760px){.hiw-steps{grid-template-columns:1fr}}
