
/* ============================================================
   KWAFO OFORI-BOATENG — Light palette
   Timeless, Graceful, Sophisticated, Bold
   Two fonts: Cormorant (display) + DM Sans (body/UI)
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',system-ui,sans-serif;background:#f5f2ec;color:#1a1814;-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.7}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

:root{
  --stone:#f5f2ec;
  --stone-mid:#ede8df;
  --stone-deep:#ddd8ce;
  --ink:#1a1814;
  --ink-mid:#3a3630;
  --ink-light:#7a7268;
  --titanium:#8c8c8c;
  --warm:#8a642e;
  --warm-light:#f0e8d8;
  --dark:#1c1a14;
  --white:#ffffff;
  --rule:#ddd8ce;
  --serif:'Cormorant',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --gap:22px;
  --max:1120px;
  /* ── TYPOGRAPHY CONTROL ── */
  --font-display:'Cormorant',Georgia,serif;
  --font-ui:'DM Sans',system-ui,sans-serif;
  --fs-hero:clamp(40px,5vw,64px);
  --fs-page:clamp(34px,4vw,52px);
  --fs-section:clamp(18px,2vw,22px);
  --fs-body:15px;
  --fs-body-lg:16px;
  --fs-label:11px;
  --lh-display:1.06;
  --lh-tight:1.2;
  --lh-body:1.7;
  --ls-display:-0.02em;
  --ls-label:.14em;
}

.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 var(--gap)}
.eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;color:var(--warm)}
.section-label{font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;color:var(--ink-mid)}
.bg-white{background:var(--white)}.bg-paper{background:var(--stone)}.bg-mid{background:var(--stone-mid)}.bg-dark{background:var(--dark)}
.border-b{border-bottom:1px solid var(--rule)}

.reveal{opacity:0;transform:translateY(14px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* NAV */
nav{position:sticky;top:0;z-index:200;background:var(--stone);border-bottom:1px solid var(--stone-deep)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 var(--gap);height:64px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.nav-logo img{height:36px;display:block;transition:opacity .2s;opacity:1;filter:none}
.nav-logo:hover img{opacity:.65}
.nav-toggle{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;margin-left:12px}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--ink);transition:all .25s}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav-links{display:none;position:fixed;top:64px;left:0;right:0;bottom:0;background:var(--stone);flex-direction:column;align-items:flex-start;padding:32px var(--gap) 40px;gap:0;list-style:none;overflow-y:auto;z-index:199;border-top:1px solid var(--stone-deep)}
.nav-links.open{display:flex}
.nav-links li{width:100%;border-bottom:1px solid var(--stone-deep)}
.nav-links a{display:block;padding:16px 0;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mid);transition:color .15s;font-weight:400}
.nav-links a:hover,.nav-links a.active{color:var(--warm)}
.nav-cta{background:var(--ink) !important;color:var(--stone) !important;padding:10px 18px !important;font-weight:500 !important;letter-spacing:.1em !important;font-size:11px !important;border-bottom:none !important}

/* CREDS */
.creds{background:var(--dark);padding:11px 0;overflow:hidden}
.creds-inner{max-width:var(--max);margin:0 auto;padding:0 var(--gap)}
.creds-scroll{display:flex;gap:48px;white-space:nowrap;animation:credscroll 32s linear infinite}
.creds-scroll:hover{animation-play-state:paused}
@keyframes credscroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.cred{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.35);flex-shrink:0;font-weight:300}
.cred strong{color:rgba(255,255,255,.72);font-weight:500}

/* HERO */
.hero{background:var(--stone);overflow:hidden;border-bottom:1px solid var(--stone-deep)}
.hero-inner{display:grid;grid-template-columns:1fr;gap:0}
/* removed duplicate */
.hero-kwafo-img{height:clamp(44px,6vw,72px);width:auto;max-width:none;margin-bottom:28px;opacity:.88}
.hero-thesis{font-family:var(--serif);font-size:clamp(28px,4.2vw,50px);font-weight:300;line-height:1.1;letter-spacing:-.02em;color:var(--ink);margin-top:0}
.hero-fix-line{font-family:var(--serif);font-size:clamp(28px,4.2vw,50px);font-weight:300;line-height:1.1;letter-spacing:-.02em;color:var(--warm);font-style:italic;margin-top:20px}
.hero-sub-role{font-size:11px;letter-spacing:.10em;text-transform:uppercase;color:var(--titanium);font-weight:400;margin-top:32px;white-space:nowrap}
.hero-btns{display:flex;flex-direction:column;gap:12px;margin-top:32px}
.hero-btns a{text-align:center}
.hero-photo-wrap{position:relative;overflow:hidden;background:var(--stone-mid);max-height:460px}
.hero-photo-wrap img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.hero-photo-wrap::after{content:'';position:absolute;top:0;left:0;bottom:0;width:80px;background:linear-gradient(to right,var(--stone),transparent)}
.hero-avail{display:inline-flex;align-items:center;gap:10px;margin-top:28px}
.avail-dot{width:7px;height:7px;border-radius:50%;background:#2d9e5f;flex-shrink:0}
.hero-avail span{font-size:12px;color:var(--ink-light);font-weight:300}

/* EXPANSION */
/* removed duplicate expansion */
.expansion-inner{max-width:var(--max);margin:0 auto;padding:0 var(--gap)}
.expansion-lead{font-family:var(--serif);font-size:clamp(19px,2.6vw,28px);font-weight:300;line-height:1.55;color:var(--ink);max-width:820px;margin-bottom:28px}
.expansion-body{font-size:15px;color:var(--ink-mid);font-weight:300;line-height:1.8;max-width:700px;margin-bottom:24px}
.expansion-stamp{font-size:12px;letter-spacing:.14em;color:var(--ink-light);font-weight:500;text-transform:uppercase;border-left:2px solid var(--warm);padding-left:16px}

/* SECTIONS */
section{padding:80px 0}
.section-wrap{border-bottom:1px solid var(--rule)}
.sec-head{margin-bottom:40px}
.sec-title{font-family:var(--serif);font-size:clamp(28px,4vw,44px);font-weight:300;line-height:1.08;letter-spacing:-.01em;margin-top:12px}
.sec-title em{font-style:italic;color:var(--warm)}

/* WHEN ITEMS */
.when-grid{display:grid;gap:16px}
.when-item{display:flex;align-items:flex-start;gap:14px;padding:28px;background:var(--stone);border:1px solid var(--stone-deep)}
.when-dot{width:5px;height:5px;border-radius:50%;background:var(--warm);margin-top:8px;flex-shrink:0}
.when-text{font-size:14px;line-height:1.7;color:var(--ink-mid);font-weight:300}

/* FIX GRID */
.fix-grid{display:grid;gap:1px;background:var(--stone-deep)}
.fix-card{background:var(--white);padding:36px 30px;display:flex;flex-direction:column;gap:10px}
.fix-problem{font-size:14px;font-weight:500;color:var(--ink);line-height:1.4}
.fix-resolution{font-size:13px;color:var(--ink-light);font-weight:300;line-height:1.65;flex:1}
.fix-tag{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--warm);font-weight:500;padding-top:14px;border-top:1px solid var(--stone-deep);margin-top:auto}

/* PHASE GRID */
.phase-grid{display:grid;gap:1px;background:var(--stone-deep)}
.phase{background:var(--white);padding:36px 30px;position:relative}
.phase-num{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--warm);font-weight:500;margin-bottom:12px}
.phase-timeframe{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--titanium);font-weight:400;margin-bottom:16px}
.phase-title{font-family:var(--serif);font-size:22px;font-weight:300;color:var(--ink);line-height:1.2;margin-bottom:14px}
.phase-desc{font-size:14px;color:var(--ink-mid);font-weight:300;line-height:1.7;margin-bottom:14px}
.phase-output{font-size:13px;color:var(--ink-light);font-weight:300;line-height:1.65;border-top:1px solid var(--stone-deep);padding-top:14px}
.phase-output strong{color:var(--ink-mid);font-weight:500}
.phase-arrow{position:absolute;top:36px;right:24px;color:var(--stone-deep);font-size:18px}

/* ENGAGE GRID */
.engage-grid{display:grid;gap:1px;background:var(--stone-deep)}
.engage-card{background:var(--white);padding:36px 30px}
.engage-number{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--warm);font-weight:500;margin-bottom:10px}
.engage-title{font-family:var(--serif);font-size:22px;font-weight:300;color:var(--ink);line-height:1.2;margin-bottom:6px}
.engage-scope{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--titanium);margin-bottom:14px}
.engage-desc{font-size:14px;color:var(--ink-mid);font-weight:300;line-height:1.7;margin-bottom:10px}
.engage-when{font-size:13px;color:var(--ink-light);font-weight:300;font-style:italic;line-height:1.65;border-top:1px solid var(--stone-deep);padding-top:12px}

/* TWO COL */
.two-col{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}

/* PROSE */
.prose{font-size:15px;line-height:1.8;color:var(--ink-mid);font-weight:300}
.prose+.prose{margin-top:16px}
.prose strong{color:var(--ink);font-weight:500}
.pull{font-family:var(--serif);font-size:20px;font-style:italic;line-height:1.55;color:var(--ink-mid);border-left:2px solid var(--warm);padding-left:20px;margin:20px 0 24px}

/* CHALLENGE GRID */
.challenge-grid{display:grid;gap:1px;background:var(--stone-deep)}
.challenge-item{background:var(--white);padding:28px 24px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px}
.challenge-from{font-size:14px;color:var(--ink-mid);font-weight:300;line-height:1.5}
.challenge-arrow{font-size:16px;color:var(--warm);text-align:center}
.challenge-to{font-size:14px;color:var(--ink);font-weight:500;line-height:1.5}

/* FORMAT GRID */
.format-grid{display:grid;gap:1px;background:var(--stone-deep)}
.format-item{background:var(--stone);padding:24px 22px}
.format-title{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:6px}
.format-desc{font-size:13px;color:var(--ink-light);font-weight:300;line-height:1.65}

/* TAKEAWAY */
.takeaway-grid{display:grid;gap:12px}
.takeaway-item{display:flex;align-items:flex-start;gap:14px;padding:20px 22px;background:var(--white);border:1px solid var(--stone-deep)}
.takeaway-dot{width:5px;height:5px;border-radius:50%;background:var(--warm);margin-top:8px;flex-shrink:0}
.takeaway-text{font-size:14px;color:var(--ink-mid);font-weight:300;line-height:1.65}

/* CTA BAND */
.cta-band{background:var(--stone-mid);padding:80px 0;border-top:1px solid var(--stone-deep);border-bottom:1px solid var(--stone-deep)}
.cta-inner{max-width:var(--max);margin:0 auto;padding:0 var(--gap)}
.cta-title{font-family:var(--serif);font-size:clamp(26px,4vw,44px);font-weight:300;color:var(--ink);line-height:1.1}
.cta-title em{font-style:italic;color:var(--warm)}
.cta-sub{font-size:15px;line-height:1.75;color:var(--ink-mid);font-weight:300;margin-top:16px}
.cta-btns{display:flex;flex-direction:column;gap:12px;margin-top:28px;align-items:flex-start}

/* DIAGNOSTIC CTA */
.diagnostic-cta{background:var(--dark);padding:88px 0}
.diagnostic-inner{max-width:820px;margin:0 auto;padding:0 var(--gap)}
.diagnostic-points{margin:24px 0}
.diagnostic-point{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}
.diagnostic-point-dot{width:4px;height:4px;border-radius:50%;background:var(--warm);margin-top:9px;flex-shrink:0}
.diagnostic-point span{font-size:14px;color:rgba(255,255,255,.62);font-weight:300;line-height:1.6}

/* STAT GRID */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--stone-deep)}
.stat{background:var(--white);padding:28px 22px}
.stat-v{font-family:var(--serif);font-size:42px;font-weight:300;line-height:1;color:var(--ink);margin-bottom:8px}
.stat-v sup{font-size:18px;vertical-align:super}
.stat-d{font-size:13px;line-height:1.65;color:var(--ink-mid);font-weight:300}

/* PAGE BANNER */
.page-banner{background:var(--stone);padding:72px 0 60px;border-bottom:1px solid var(--stone-deep)}
.page-banner-inner{max-width:var(--max);margin:0 auto;padding:0 var(--gap)}
.page-banner h1{font-family:var(--serif);font-size:clamp(32px,5.5vw,58px);font-weight:300;line-height:1.08;color:var(--ink);margin-top:14px;letter-spacing:-.02em}
.page-banner h1 em{font-style:italic;color:var(--ink-light)}
.page-banner .intro{font-size:16px;line-height:1.8;color:var(--ink-mid);font-weight:300;margin-top:18px;max-width:640px}

/* BLOG CARDS */
.blog-list{display:flex;flex-direction:column;border:1px solid var(--rule)}
.blog-card{background:var(--white);padding:28px 24px;display:flex;flex-direction:column;gap:10px;text-decoration:none;border-bottom:1px solid var(--rule);position:relative;transition:background .15s}
.blog-card:hover{background:#faf8f4}
.blog-card:last-child{border-bottom:none}
.blog-card-title{font-family:var(--serif);font-size:21px;line-height:1.25;font-weight:400;color:var(--ink)}
.blog-card-sum{font-size:14px;line-height:1.75;color:var(--ink-mid);font-weight:300}
.blog-card-date{font-size:10px;letter-spacing:.1em;color:var(--ink-light);text-transform:uppercase}
.blog-arr{position:absolute;right:24px;bottom:24px;font-size:18px;color:var(--warm);opacity:0;transition:.15s}
.blog-card:hover .blog-arr{opacity:1;transform:translateX(4px)}

/* CHAPTER LIST */
.chapter-item{display:grid;grid-template-columns:auto 1fr auto;gap:20px;padding:20px 0;border-bottom:1px solid var(--stone-deep);align-items:start}
.chapter-n{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--warm);font-weight:500;padding-top:4px;min-width:32px}
.chapter-title{font-family:var(--serif);font-size:18px;font-weight:300;color:var(--ink);line-height:1.3;margin-bottom:4px}
.chapter-concept{font-size:13px;color:var(--ink-light);font-weight:300;line-height:1.65}
.chapter-badge{font-size:9px;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;font-weight:500}
.badge-complete{background:#e8f0e8;color:#2d6e2d}
.badge-progress{background:var(--warm-light);color:var(--warm)}
.badge-planned{background:var(--stone-mid);color:var(--titanium)}

/* PANEL */
.panel{background:var(--white);border:1px solid var(--rule);padding:28px 24px}
.panel-title{font-family:var(--serif);font-size:20px;font-weight:400;line-height:1.3;margin-bottom:12px;color:var(--ink)}
.badge{font-size:9px;letter-spacing:.14em;text-transform:uppercase;background:var(--warm-light);color:var(--warm);font-weight:500;padding:4px 10px}
.chips{display:flex;flex-wrap:wrap;gap:7px;padding-top:14px;border-top:1px solid var(--rule);margin-top:12px}
.chip{font-size:11px;color:var(--ink-mid);border:1px solid var(--rule);padding:4px 11px;border-radius:16px}

/* BUTTONS */
.btn-warm,.btn-dark,.btn-outline,.btn-ghost{display:inline-block;text-decoration:none;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:13px 26px;white-space:nowrap;transition:.15s;font-family:var(--sans);cursor:pointer;font-weight:500;border:none}
.btn-warm{background:var(--ink);color:var(--stone);border-left:3px solid var(--warm)}
.btn-warm:hover{opacity:.82}
.btn-dark{background:var(--ink);color:var(--stone)}
.btn-dark:hover{opacity:.82}
.btn-outline{border:1px solid var(--rule);color:var(--ink-mid);background:none;padding:12px 24px}
.btn-outline:hover{border-color:var(--warm);color:var(--warm)}
.btn-ghost{border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.55);background:none}
.btn-ghost:hover{border-color:rgba(255,255,255,.4);color:rgba(255,255,255,.8)}

/* FORM */
.form-group{display:flex;flex-direction:column;gap:7px;margin-bottom:18px}
.form-label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mid);font-weight:500}
.form-input,.form-textarea,.form-select{width:100%;padding:13px 15px;border:1px solid var(--stone-deep);background:var(--white);font-family:var(--sans);font-size:15px;color:var(--ink);outline:none;-webkit-appearance:none}
.form-textarea{min-height:120px;resize:vertical}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--warm)}
.muted-list{display:flex;flex-direction:column;gap:12px}
.muted-list div{padding-bottom:12px;border-bottom:1px solid var(--rule);font-size:14px;line-height:1.75;color:var(--ink-mid);font-weight:300}
.muted-list div:last-child{border-bottom:none;padding-bottom:0}

/* FOOTER */
footer{background:var(--ink);padding:52px 0 32px}
.footer-inner{max-width:var(--max);margin:0 auto;padding:0 var(--gap)}
.footer-top{padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.08);display:grid;grid-template-columns:1fr;gap:36px}
.footer-brand{font-family:var(--serif);font-size:24px;color:rgba(255,255,255,.9);line-height:1.1}
.footer-brand em{font-style:italic;color:rgba(255,255,255,.38)}
.foot-desc{font-size:13px;line-height:1.8;color:rgba(255,255,255,.32);font-weight:300;margin-top:12px;max-width:300px}
.foot-cols{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.foot-col-title{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.25);font-weight:500;margin-bottom:14px}
.foot-links{list-style:none;display:flex;flex-direction:column;gap:9px}
.foot-links a{font-size:13px;color:rgba(255,255,255,.42);font-weight:300;transition:color .15s}
.foot-links a:hover{color:rgba(255,255,255,.85)}
.footer-bottom{margin-top:24px;display:flex;flex-direction:column;gap:8px;align-items:center;text-align:center}
.foot-copy,.foot-misc{font-size:11px;color:rgba(255,255,255,.2)}
.foot-misc{text-transform:uppercase;letter-spacing:.12em}

/* ESSAY */
.essay-body{max-width:680px;margin:0 auto}
.essay-body h2{font-family:var(--serif);font-size:26px;font-weight:300;color:var(--ink);margin:40px 0 16px;line-height:1.2}
.essay-body p{font-size:15px;line-height:1.85;color:var(--ink-mid);font-weight:300;margin-bottom:20px}
.essay-body strong{color:var(--ink);font-weight:500}
.essay-pull{font-family:var(--serif);font-size:22px;font-style:italic;line-height:1.5;color:var(--ink);border-left:2px solid var(--warm);padding-left:24px;margin:32px 0;font-weight:300}

/* TABLET 640px+ */
@media(min-width:640px){
  :root{--gap:32px}
  .hero-btns{flex-direction:row}
  .hero-btns a{text-align:left}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .when-grid{grid-template-columns:1fr 1fr}
  .fix-grid{grid-template-columns:repeat(2,1fr)}
  .cta-btns{flex-direction:row;align-items:center}
  .foot-cols{grid-template-columns:repeat(3,1fr)}
  .takeaway-grid{grid-template-columns:1fr 1fr}
}

/* DESKTOP NAV 860px+ */
@media(min-width:860px){
  :root{--gap:48px}
  .nav-toggle{display:none}
  .nav-links{display:flex !important;position:static;flex-direction:row;align-items:center;background:transparent;padding:0;gap:28px;overflow:visible;border:none}
  .nav-links li{width:auto;border:none}
  .nav-links a{padding:0;font-size:11px;letter-spacing:.12em;color:var(--ink-mid)}
  .nav-links a:hover,.nav-links a.active{color:var(--warm)}
  .nav-cta{background:var(--ink) !important;color:var(--stone) !important;padding:9px 18px !important}
  .nav-inner{height:68px}
  .nav-logo img{height:40px}
}

/* DESKTOP 1024px+ */
@media(min-width:1024px){
  .section{padding:100px var(--gap)}
  .page-banner{padding:88px 0 76px}
  .two-col{grid-template-columns:1fr 1fr;gap:72px}
  .fix-grid{grid-template-columns:repeat(3,1fr)}
  .phase-grid{grid-template-columns:repeat(3,1fr)}
  .engage-grid{grid-template-columns:repeat(3,1fr)}
  .stat-grid{grid-template-columns:repeat(4,1fr)}
  .footer-top{grid-template-columns:2fr 3fr}
  .foot-cols{grid-template-columns:repeat(3,1fr)}
  .footer-bottom{flex-direction:column;align-items:center}
  .hero-inner{grid-template-columns:1.1fr .9fr;min-height:88vh}
  /* removed duplicate */
  .hero-btns{flex-direction:row}
  .hero-photo-wrap{max-height:none}
  .format-grid{grid-template-columns:repeat(2,1fr)}
  .blog-card{padding:34px}
  .cta-btns{flex-direction:column;align-items:flex-end}
  .cta-inner-grid{display:grid;grid-template-columns:1fr auto;align-items:center;gap:56px}
}

/* ── ESSAY PAGES ── */
.essay-back{display:inline-flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-light);text-decoration:none;font-weight:500;margin-bottom:32px;transition:color .15s}
.essay-back:hover{color:var(--warm)}
.essay-hero{background:var(--stone);padding:72px 0 60px;border-bottom:1px solid var(--stone-deep)}
.essay-hero-inner{max-width:740px;margin:0 auto;padding:0 var(--gap)}
.essay-tag{display:inline-block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--warm);font-weight:500;margin-bottom:16px}
.essay-title{font-family:var(--serif);font-size:clamp(32px,5vw,52px);font-weight:300;line-height:1.06;letter-spacing:-.02em;color:var(--ink);margin-bottom:20px}
.essay-thesis{font-size:18px;line-height:1.7;color:var(--ink-mid);font-weight:300;margin-bottom:20px;max-width:58ch}
.essay-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding-top:20px;border-top:1px solid var(--stone-deep)}
.essay-author-name{font-size:13px;color:var(--ink-mid);font-weight:400}
.essay-date{font-size:12px;color:var(--ink-light);font-weight:300}
.essay-divider{height:1px;background:var(--stone-deep);max-width:740px;margin:0 auto}
.essay-body{max-width:740px;margin:0 auto;padding:60px var(--gap) 80px}
.essay-h2{font-family:var(--serif);font-size:clamp(22px,2.8vw,30px);font-weight:300;color:var(--ink);margin:48px 0 18px;line-height:1.2}
.essay-p{font-size:16px;line-height:1.85;color:var(--ink-mid);font-weight:300;margin-bottom:22px;max-width:64ch}
.essay-pull{font-family:var(--serif);font-size:22px;font-style:italic;line-height:1.5;color:var(--ink);border-left:2px solid var(--warm);padding-left:24px;margin:36px 0;font-weight:300;max-width:36ch}
.essay-table{width:100%;border-collapse:collapse;margin:32px 0}
.essay-table th{font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;color:var(--warm);padding:0 16px 12px 0;text-align:left;border-bottom:2px solid var(--stone-deep)}
.essay-table td{padding:14px 16px 14px 0;font-size:14px;color:var(--ink-mid);font-weight:300;border-bottom:1px solid var(--stone-deep);vertical-align:top;line-height:1.65}
.essay-cta{background:var(--stone-mid);padding:64px 0;border-top:1px solid var(--stone-deep)}
.essay-cta-inner{max-width:740px;margin:0 auto;padding:0 var(--gap)}

/* ── MOBILE FIXES ── */
/* Hero sub — allow wrap on narrow screens */
@media(max-width:639px){
  .hero-sub-role{white-space:normal}
  .hero-sub{white-space:normal}

  /* Impact table — stack on mobile */
  .impact-table thead{display:none}
  .impact-table tr{display:block;padding:20px 0;border-bottom:1px solid var(--stone-deep)}
  .impact-table td{display:block;padding:6px 0;width:100% !important;border-bottom:none;font-size:13px}
  .impact-table td:first-child::before{content:"Situation";font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--warm);font-weight:500;display:block;margin-bottom:4px}
  .impact-table td:nth-child(2)::before{content:"Intervention";font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--warm);font-weight:500;display:block;margin-bottom:4px}
  .impact-table td:nth-child(3)::before{content:"Outcome";font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--warm);font-weight:500;display:block;margin-bottom:4px}
  .impact-table td:nth-child(3) strong{font-size:16px}

  /* Creds ticker — smaller on mobile */
  .creds-scroll{gap:32px}
  .cred{font-size:9px}

  /* Fix cards — single column */
  .fix-grid{grid-template-columns:1fr !important}

  /* Buttons — full width on mobile */
  .hero-btns{flex-direction:column;align-items:flex-start}

  /* Footer columns — stack */
  .foot-cols{grid-template-columns:1fr 1fr}
}

/* ── INDEX PAGE — HERO ── */
.hero{background:var(--stone);display:grid;grid-template-columns:1fr;min-height:auto;border-bottom:1px solid var(--stone-deep)}
.hero-content{padding:40px var(--gap) 36px;display:flex;flex-direction:column;justify-content:center}
.hero-eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--warm);font-weight:500;margin-bottom:18px}
.hero-wordmark{margin-bottom:22px}
.hero-wordmark img{height:clamp(40px,5.72vw,77px);width:auto;max-width:none;opacity:.9}
.hero-thesis{font-family:var(--serif);font-size:clamp(26px,3.8vw,48px);font-weight:300;line-height:1.1;letter-spacing:-.02em;color:var(--ink)}
.hero-fix{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.75;color:var(--ink-mid);margin-top:20px}
.hero-sub{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--titanium);font-weight:400;margin-top:24px}
.hero-btns{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap;align-items:center;flex-direction:column;align-items:flex-start}
.btn-primary{background:var(--ink);color:var(--stone);padding:13px 28px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;text-decoration:none;display:inline-block;border-left:3px solid var(--warm)}
.btn-secondary{color:var(--ink-mid);font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:400;text-decoration:none;opacity:.55}
.hero-avail{display:inline-flex;align-items:center;gap:10px;margin-top:24px}
.hero-avail-dot{width:7px;height:7px;border-radius:50%;background:#4a9e6b;flex-shrink:0}
.hero-avail span{font-size:12px;color:var(--ink-light);font-weight:300}
.hero-photo{overflow:hidden;position:relative;background:var(--stone-mid);max-height:320px}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.hero-photo::after{content:'';position:absolute;top:0;left:0;bottom:0;width:60px;background:linear-gradient(to right,var(--stone),transparent)}

/* INDEX — SECTIONS */
.expansion{background:var(--stone-mid);padding:56px var(--gap);border-top:1px solid var(--stone-deep);border-bottom:1px solid var(--stone-deep)}
.expansion-inner{max-width:1080px;margin:0 auto}
.expansion-lead{font-family:var(--serif);font-size:clamp(18px,2.6vw,30px);font-weight:300;line-height:1.6;color:var(--ink);margin-bottom:24px}
.expansion-body{font-size:15px;color:var(--ink-mid);font-weight:300;line-height:1.85;margin-bottom:24px}
.expansion-stamp{font-size:12px;letter-spacing:.14em;color:var(--ink-light);font-weight:500;text-transform:uppercase;border-left:2px solid var(--warm);padding-left:16px}
.section{padding:60px var(--gap);max-width:1200px;margin:0 auto}
.section-wrap{border-bottom:1px solid var(--stone-deep)}
.when-grid{display:grid;grid-template-columns:1fr;gap:12px}
.when-item{display:flex;align-items:flex-start;gap:14px;padding:24px;background:var(--stone);border:1px solid var(--stone-deep)}
.when-dot{width:5px;height:5px;border-radius:50%;background:var(--warm);margin-top:8px;flex-shrink:0}
.when-text{font-size:14px;line-height:1.65;color:var(--ink-mid);font-weight:300}
.section-note{margin-top:16px;font-size:13px;color:var(--ink-light);font-style:italic;font-weight:300}
.fix-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--stone-deep)}
.fix-card{background:#fff;padding:28px 24px;display:flex;flex-direction:column}
.fix-problem{font-size:14px;font-weight:500;color:var(--ink);margin-bottom:8px;line-height:1.4}
.fix-resolution{font-size:13px;color:var(--ink-light);font-weight:300;line-height:1.65;flex:1}
.fix-tag{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--warm);font-weight:500;margin-top:14px}
.impact-table{width:100%;border-collapse:collapse;margin-top:0}
.impact-table th{font-size:10px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;color:var(--warm);padding:0 16px 14px 0;text-align:left;border-bottom:2px solid var(--stone-deep)}
.impact-table td{padding:20px 16px 20px 0;vertical-align:top;font-size:14px;line-height:1.7;font-weight:300;border-bottom:1px solid var(--stone-deep)}
.impact-table tr:last-child td{border-bottom:none}
.impact-table td:nth-child(3) strong{font-family:var(--serif);font-size:18px;font-weight:300;color:var(--ink);display:block;margin-bottom:4px}
.cta-section{background:var(--ink);padding:60px var(--gap)}
.cta-inner{max-width:800px;margin:0 auto}
.btn-warm{background:var(--ink);color:var(--stone);padding:14px 30px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;text-decoration:none;display:inline-block;border-left:3px solid var(--warm)}

@media(min-width:640px){
  .when-grid{grid-template-columns:1fr 1fr}
  .fix-grid{grid-template-columns:1fr 1fr}
  .hero-btns{flex-direction:row;align-items:center}
}
@media(min-width:860px){
  .hero{grid-template-columns:1.1fr .9fr;min-height:88vh}
  .hero-content{padding:80px 60px 72px 64px}
  .hero-photo{max-height:none}
  /* removed — handled by index page styles */
  .section{padding:100px 64px}
  .fix-grid{grid-template-columns:1fr 1fr 1fr}
  .cta-section{padding:88px 64px}
}

/* =========================================
   PASS 1 — TYPOGRAPHY GOVERNANCE
   ========================================= */

/* Base — DM Sans everywhere */
body,p,li,a,span,div,input,textarea,select,button{font-family:var(--font-ui)}
body{font-size:var(--fs-body);line-height:var(--lh-body);font-weight:300}

/* Display — Cormorant restricted to hero/titles/pull only */
.hero-thesis,
.page-banner h1,
.essay-title,
.book-title{
  font-family:var(--font-display);
  font-weight:300;
  line-height:var(--lh-display);
  letter-spacing:var(--ls-display);
}
.hero-thesis{font-size:var(--fs-hero)}
.page-banner h1{font-size:var(--fs-page)}
.essay-title{font-size:clamp(34px,4vw,52px)}

/* Pull quotes — only place outside hero where Cormorant italic lives */
.pull,.essay-pull,blockquote.pull{
  font-family:var(--font-display);
  font-weight:300;
  font-style:italic;
  line-height:1.45;
}

/* Section titles — DM Sans, not Cormorant */
.sec-title,
.feature-title,
.writing-title,
.path-title,
.diag-title,
.engage-title,
.clarity-title,
.cta-title{
  font-family:var(--font-ui);
  font-size:var(--fs-section);
  font-weight:400;
  line-height:1.25;
  letter-spacing:-0.01em;
}

/* em inside display lines stays serif italic */
.hero-thesis em,
.page-banner h1 em,
.essay-title em,
.book-title em{
  font-family:var(--font-display);
  font-style:italic;
}

/* em inside section titles stays sans */
.sec-title em,
.cta-title em,
.clarity-title em{
  font-family:var(--font-ui);
  font-style:italic;
  color:var(--warm);
}

/* Prevent italic drift in cards */
.feature-title,.path-title,.diag-title,.engage-title{font-style:normal}

/* Labels, eyebrows, nav, metadata */
.eyebrow,.section-label,.feature-label,.writing-tag,
.diag-label,.path-label,.essay-tag,.essay-date,.cred{
  font-family:var(--font-ui);
  font-size:var(--fs-label);
  font-weight:500;
  letter-spacing:var(--ls-label);
  text-transform:uppercase;
}

/* Nav */
.nav-links a{font-weight:400;letter-spacing:.12em}
.nav-cta{font-weight:500;letter-spacing:.1em}

/* Buttons */
.btn-warm,.btn-dark,.btn-outline,.btn-ghost,.btn-primary,.btn-secondary{
  font-family:var(--font-ui);
  font-weight:500;
  letter-spacing:.1em;
}

/* Body hierarchy */
.hero-fix,.intro,.expansion-lead,.essay-thesis{
  font-family:var(--font-ui);
  font-size:var(--fs-body-lg);
  line-height:1.7;
  font-weight:300;
}
.prose,.expansion-body,.when-text,.diag-text,.diag-line,
.path-text,.writing-desc,.feature-text,.cta-sub{
  font-family:var(--font-ui);
  font-size:var(--fs-body);
  line-height:var(--lh-body);
}

/* =========================================
   PASS 2 — MOBILE TYPOGRAPHY TIGHTENING
   ========================================= */
@media(max-width:639px){
  body{font-size:15px;line-height:1.72}

  p,li,.prose,.essay-p,.essay-thesis,.intro,.expansion-body,
  .when-text,.diag-text,.diag-line,.path-text,.writing-desc,
  .feature-text,.cta-sub{font-size:15px;line-height:1.72}

  .hero-thesis{
    font-size:clamp(30px,8vw,38px);
    line-height:1.04;
    letter-spacing:-0.02em;
    max-width:12ch;
  }
  .page-banner h1{
    font-size:clamp(28px,7vw,36px);
    line-height:1.08;
    letter-spacing:-0.02em;
  }
  .essay-title{font-size:clamp(28px,7vw,36px);line-height:1.06}

  .hero-fix,.intro,.expansion-lead,.essay-thesis{
    font-size:15px;line-height:1.68;
  }

  .sec-title,.feature-title,.writing-title,.diag-title,
  .path-title,.engage-title,.clarity-title,.cta-title{
    font-size:20px;line-height:1.22;font-weight:400;letter-spacing:-0.01em;
  }

  .eyebrow,.section-label,.feature-label,.writing-tag,
  .diag-label,.path-label,.essay-tag,.nav-links a,.nav-cta{
    font-size:10px;letter-spacing:.1em;font-weight:500;
  }

  .nav-links a{padding:18px 0;line-height:1.2}

  .btn-warm,.btn-dark,.btn-outline,.btn-ghost,.btn-primary,.btn-secondary{
    font-size:10px;letter-spacing:.08em;padding:13px 20px;line-height:1.2;
  }

  .pull,.essay-pull{
    font-size:20px;line-height:1.42;padding-left:18px;margin:28px 0;max-width:100%;
  }

  .chapter-title{font-size:19px;line-height:1.24}

  .fix-problem,.format-title{font-size:14px;line-height:1.4;font-weight:500}
  .fix-resolution,.format-desc{font-size:13px;line-height:1.62}

  .prose + .prose,.essay-p + .essay-p{margin-top:14px}
}

/* Clarity band title — display exception, makes a claim not a label */
.clarity-title{
  font-family:var(--font-display);
  font-weight:300;
  line-height:1.12;
  letter-spacing:var(--ls-display);
}
.clarity-title em{
  font-family:var(--font-display);
  font-style:italic;
  color:rgba(255,255,255,.42);
}

/* =========================================
   PASS 3 — INLINE STYLE CLEANUP
   ========================================= */

/* Thank-you page headings */
.thankyou-title{
  font-family:var(--font-display);
  font-size:clamp(32px,5vw,56px);
  font-weight:300;
  line-height:1.08;
  color:var(--ink);
  margin-top:14px;
  letter-spacing:-0.02em;
}
.thankyou-title em{
  font-family:var(--font-display);
  font-style:italic;
  color:var(--warm);
}
.thankyou-body{
  font-size:var(--fs-body-lg);
  line-height:1.8;
  color:var(--ink-mid);
  font-weight:300;
  margin-top:20px;
  max-width:560px;
}

/* About hero heading */
.about-hero-title{
  font-family:var(--font-display);
  font-size:clamp(28px,3.8vw,44px);
  font-weight:300;
  line-height:1.1;
  letter-spacing:-0.02em;
  color:var(--ink);
}

/* Book framework panel titles */
.book-panel-title{
  font-family:var(--font-display);
  font-size:18px;
  font-weight:400;
  color:var(--ink);
}

/* Essay lead paragraph emphasis */
.essay-p-lead{
  font-weight:400;
  color:var(--ink);
}

/* Speaking format title — smaller sec-title variant */
.sec-title-sm{
  font-family:var(--font-ui);
  font-size:clamp(20px,2.4vw,28px);
  font-weight:400;
  line-height:1.25;
  letter-spacing:-0.01em;
}

.panel-title{font-family:var(--font-display);font-size:19px;font-weight:400;color:var(--ink);margin:0}


/* ============================================================
   Refinements — intellectual framework / writing architecture
   ============================================================ */

.nav-links a.nav-plain{background:transparent!important;color:var(--ink-mid)!important;padding:0!important;border-bottom:none!important}
.nav-links a.nav-plain:hover,.nav-links a.nav-plain.active{color:var(--warm)!important}

.featured-essay-band{background:var(--stone);border-bottom:1px solid var(--stone-deep);padding:72px 0}
.featured-essay{max-width:var(--max);margin:0 auto;padding:0 var(--gap)}
.featured-essay-inner{border-top:1px solid var(--stone-deep);border-bottom:1px solid var(--stone-deep);padding:42px 0;display:grid;gap:22px}
.featured-essay-title{font-family:var(--serif);font-size:clamp(34px,5vw,58px);line-height:1.02;letter-spacing:-.025em;font-weight:300;color:var(--ink);max-width:860px}
.featured-essay-text{font-size:15px;line-height:1.8;color:var(--ink-mid);font-weight:300;max-width:660px}
.featured-essay-link{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--warm);font-weight:500;text-decoration:none}
.featured-essay-link:hover{color:var(--ink)}

.writing-hero{background:var(--stone);border-bottom:1px solid var(--stone-deep);padding:84px 0 70px}
.writing-hero-inner{max-width:var(--max);margin:0 auto;padding:0 var(--gap)}
.writing-hero h1{font-family:var(--serif);font-size:clamp(44px,7vw,78px);font-weight:300;line-height:1;letter-spacing:-.03em;color:var(--ink);max-width:860px}
.writing-hero .intro{font-size:16px;line-height:1.8;color:var(--ink-mid);font-weight:300;max-width:680px;margin-top:24px}

.writing-framework{padding:82px 0;background:var(--white);border-bottom:1px solid var(--stone-deep)}
.writing-framework-inner{max-width:var(--max);margin:0 auto;padding:0 var(--gap)}
.feature-article{border-top:1px solid var(--stone-deep);border-bottom:1px solid var(--stone-deep);padding:46px 0 48px;display:grid;gap:20px;text-decoration:none;background:transparent}
.feature-article:hover .feature-title{color:var(--warm)}
.feature-article .feature-title{font-family:var(--serif);font-size:clamp(36px,5.5vw,64px);line-height:1;letter-spacing:-.03em;font-weight:300;max-width:920px;transition:color .15s}
.feature-article .feature-text{font-size:16px;line-height:1.8;color:var(--ink-mid);font-weight:300;max-width:700px}

.essay-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--stone-deep);margin-top:42px;max-width:var(--max)}
.thesis-card{display:flex;flex-direction:column;gap:14px;background:var(--white);padding:34px 30px;text-decoration:none;min-height:250px;transition:background .15s}
.thesis-card:hover{background:#faf8f4}
.thesis-card .card-label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--warm);font-weight:500}
.thesis-card .card-title{
  font-family:var(--serif);
  font-size:clamp(23px,2.4vw,30px);
  line-height:1.08;
  font-weight:300;
  color:var(--ink);
  max-width:22ch;
}
.thesis-card .card-line{font-size:14px;line-height:1.75;color:var(--ink-mid);font-weight:300;max-width:42ch}
.thesis-card .card-link{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--warm);font-weight:500;margin-top:auto}
.essay-grid-spacer{height:54px}

@media(min-width:760px){
  .essay-grid{grid-template-columns:1fr 1fr}
  .thesis-card.wide{grid-column:1/span 1}
}

.essay-body{max-width:720px!important;width:92vw;margin:0 auto;padding:80px 0 94px}
.essay-p{font-size:16px!important;line-height:1.9!important;color:var(--ink-mid);font-weight:300;margin-bottom:28px!important}
.essay-pull{font-family:var(--serif);font-size:clamp(25px,3.2vw,36px)!important;line-height:1.22!important;font-style:italic;color:var(--ink);border-left:2px solid var(--warm);padding-left:26px;margin:44px 0!important;font-weight:300}
.essay-h2{font-family:var(--serif);font-size:clamp(28px,3.6vw,40px);line-height:1.12;font-weight:300;color:var(--ink);margin:56px 0 22px}
.essay-thesis{max-width:720px!important}

.book-structure{display:grid;grid-template-columns:1fr;gap:1px;background:var(--stone-deep);margin-top:34px}
.book-part{background:var(--white);padding:34px 30px;display:flex;flex-direction:column;gap:12px}
.book-part-label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--warm);font-weight:500}
.book-part-title{font-family:var(--serif);font-size:30px;line-height:1.08;font-weight:300;color:var(--ink)}
.book-part-text{font-size:14px;line-height:1.75;color:var(--ink-mid);font-weight:300}
.principle-grid{display:grid;gap:1px;background:var(--stone-deep);margin-top:34px}
.principle{background:var(--white);padding:26px 24px}
.principle-title{font-family:var(--serif);font-size:24px;line-height:1.1;font-weight:300;color:var(--ink)}
.principle-text{font-size:14px;line-height:1.7;color:var(--ink-mid);font-weight:300;margin-top:8px}
@media(min-width:760px){.book-structure{grid-template-columns:1fr 1fr}.principle-grid{grid-template-columns:repeat(4,1fr)}}

.quiet-cta{border-top:1px solid rgba(255,255,255,.08);margin-top:28px;padding-top:18px;font-size:13px;line-height:1.7;color:rgba(255,255,255,.55);font-weight:300}
.quiet-cta a{color:rgba(255,255,255,.78);border-bottom:1px solid rgba(255,255,255,.22)}

@media(max-width:859px){
  .nav-links a.nav-plain{padding:16px 0!important}
  .hero-fix{font-size:15px;line-height:1.85}
}


/* LOCKED: Mobile Writing card headline sizing */
@media(max-width:639px){
  .thesis-card .card-title{
    font-size:24px;
    line-height:1.1;
    max-width:100%;
  }
}



/* LOCKED BOOK PAGE V3
   Spacious editorial book page.  Prevents the hero from feeling squashed by moving the notification form out of the hero and restoring vertical scale. */
.book-v2-hero{
  background:var(--dark);
  border-bottom:1px solid rgba(255,255,255,.08);
  padding:clamp(92px,13vw,160px) 0 clamp(86px,11vw,138px);
}
.book-v2-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--gap);
}
.book-v2-kicker{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--warm);
  font-weight:500;
  margin-bottom:28px;
}
.book-v2-title{
  font-family:var(--font-display);
  font-size:clamp(66px,13vw,146px);
  font-weight:300;
  line-height:.88;
  letter-spacing:-.045em;
  color:#fff;
  max-width:880px;
}
.book-v2-subtitle{
  font-size:clamp(17px,2vw,22px);
  line-height:1.35;
  color:rgba(255,255,255,.58);
  font-weight:300;
  margin-top:34px;
  max-width:700px;
}
.book-v2-premise{
  font-size:16px;
  line-height:1.85;
  color:rgba(255,255,255,.66);
  font-weight:300;
  margin-top:32px;
  max-width:720px;
}
.book-v2-meta{
  margin-top:34px;
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.38);
  font-weight:400;
}
.book-notice-band{
  background:#15130f;
  border-bottom:1px solid rgba(255,255,255,.08);
  padding:24px 0;
}
.book-notice-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--gap);
  display:grid;
  gap:22px;
  align-items:center;
}
.book-notice-label{
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--warm);
  font-weight:500;
  margin-bottom:4px;
}
.book-notice-copy{
  font-size:13px;
  line-height:1.65;
  color:rgba(255,255,255,.56);
  font-weight:300;
}
.book-notice-form{
  display:flex;
  width:100%;
  max-width:480px;
}
.book-notice-form input{
  flex:1;
  min-width:0;
  padding:13px 14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  color:#fff;
  font-family:var(--font-ui);
  font-size:14px;
  outline:none;
}
.book-notice-form input::placeholder{color:rgba(255,255,255,.32)}
.book-notice-form button{
  background:var(--warm);
  color:#fff;
  border:none;
  padding:13px 18px;
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:500;
  font-family:var(--font-ui);
  white-space:nowrap;
  cursor:pointer;
}
.book-editorial-section{padding:clamp(76px,9vw,112px) 0}
.book-intro-grid{display:grid;gap:42px;align-items:start}
.book-section-head{max-width:780px;margin-bottom:38px}
.book-section-title{
  font-family:var(--font-display);
  font-size:clamp(34px,5vw,58px);
  line-height:1.02;
  letter-spacing:-.025em;
  font-weight:300;
  color:var(--ink);
}
.book-section-title em{
  font-family:var(--font-display);
  font-style:italic;
  color:var(--warm);
}
.book-prose{max-width:720px}
.book-prose p{
  font-size:16px;
  line-height:1.9;
  color:var(--ink-mid);
  font-weight:300;
  margin-bottom:24px;
}
.book-v2-structure{
  display:grid;
  gap:1px;
  background:var(--stone-deep);
}
.book-v2-part{
  background:var(--white);
  padding:clamp(32px,5vw,48px);
}
.book-v2-part h3{
  font-family:var(--font-display);
  font-size:clamp(32px,4vw,46px);
  line-height:1.02;
  letter-spacing:-.02em;
  font-weight:300;
  color:var(--ink);
  margin:12px 0 18px;
}
.book-v2-part p{
  font-size:15px;
  line-height:1.8;
  color:var(--ink-mid);
  font-weight:300;
  max-width:56ch;
}
.book-chapter-columns{
  display:grid;
  gap:1px;
  background:var(--stone-deep);
}
.book-chapter-col{
  background:var(--white);
  padding:clamp(28px,4vw,42px);
}
.book-col-label,
.book-part-label{
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--warm);
  font-weight:500;
}
.book-chapter-col ol{
  list-style:none;
  counter-reset:chapter;
  margin-top:24px;
}
.book-chapter-col ol[start="6"]{counter-reset:chapter 5}
.book-chapter-col li{
  counter-increment:chapter;
  position:relative;
  padding:18px 0 18px 44px;
  border-top:1px solid var(--stone-deep);
}
.book-chapter-col li::before{
  content:counter(chapter, decimal-leading-zero);
  position:absolute;
  left:0;
  top:20px;
  font-size:10px;
  letter-spacing:.12em;
  color:var(--warm);
  font-weight:500;
}
.book-chapter-col li span{
  display:block;
  font-family:var(--font-display);
  font-size:24px;
  line-height:1.08;
  font-weight:300;
  color:var(--ink);
}
.book-chapter-col li em{
  display:block;
  font-family:var(--font-ui);
  font-size:13px;
  line-height:1.65;
  font-style:normal;
  color:var(--ink-light);
  font-weight:300;
  margin-top:6px;
}
.book-principle-grid{
  display:grid;
  gap:1px;
  background:var(--stone-deep);
}
.book-principle{
  background:var(--white);
  padding:32px 28px;
}
.book-principle h3{
  font-family:var(--font-display);
  font-size:30px;
  line-height:1.05;
  font-weight:300;
  color:var(--ink);
}
.book-principle p{
  font-size:14px;
  line-height:1.75;
  color:var(--ink-mid);
  font-weight:300;
  margin-top:12px;
}
.book-close-section{
  background:var(--dark);
  padding:clamp(74px,9vw,108px) 0;
}
.book-close-inner{
  max-width:840px;
}
.book-close-inner p{
  font-family:var(--font-display);
  font-size:clamp(32px,5vw,58px);
  line-height:1.08;
  letter-spacing:-.025em;
  font-weight:300;
  color:rgba(255,255,255,.88);
  margin-top:22px;
}
@media(min-width:760px){
  .book-notice-inner{grid-template-columns:1fr auto}
  .book-v2-structure{grid-template-columns:1fr 1fr}
  .book-chapter-columns{grid-template-columns:1fr 1fr}
  .book-principle-grid{grid-template-columns:repeat(4,1fr)}
}
@media(min-width:900px){
  .book-intro-grid{grid-template-columns:.85fr 1fr}
}
@media(max-width:639px){
  .book-v2-hero{padding:74px 0 70px}
  .book-v2-title{font-size:clamp(58px,18vw,76px);line-height:.92;letter-spacing:-.04em}
  .book-v2-subtitle{margin-top:26px;font-size:17px}
  .book-v2-premise{font-size:15px;line-height:1.8;margin-top:24px}
  .book-notice-form{display:grid;gap:10px;max-width:none}
  .book-notice-form button{width:100%}
  .book-section-title{font-size:clamp(31px,10vw,42px);line-height:1.05}
  .book-chapter-col li span{font-size:22px}
}
/* END LOCKED BOOK PAGE V3 */
