/* ============================================================================
   THE BOOK OF POSSIBILITY — Pre-Order Experience
   Built to the JIM CURTIS / BLOOM brand system.

   Brand truth (from the brand guide):
     • Headlines → "Laro" (elegant geometric sans). Laro is paid & not shipped,
       so we substitute "Jost" and use the brand's mixed-weight treatment
       (light + semibold). Drop Laro woff2 in assets/fonts/ and set
       --font-display:"Laro" to go pixel-exact.
     • Body      → Poppins (self-hosted).
     • Buttons   → rectangular, solid TEAL primary + TAUPE secondary, uppercase, tracked.
     • Palette   → navy / cream / teal / taupe / pale-blue. Gold = whisper only.
     • Motifs    → warm cream grounds, prismatic light flares, thin rules.
   Icons: Lucide (https://lucide.dev) — ISC licensed, inlined.
   ============================================================================ */

@font-face{font-family:"Poppins";src:url("fonts/Poppins-regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Poppins";src:url("fonts/Poppins-italic.ttf") format("truetype");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Poppins";src:url("fonts/Poppins-bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Poppins";src:url("fonts/Poppins-boldItalic.ttf") format("truetype");font-weight:700;font-style:italic;font-display:swap}

/* Laro — Jim Curtis's licensed brand headline font (self-hosted from his site CDN). */
@font-face{font-family:"Laro";src:url("fonts/laro-regular.woff2") format("woff2");font-weight:300 400;font-style:normal;font-display:swap}
@font-face{font-family:"Laro";src:url("fonts/laro-medium.woff2") format("woff2");font-weight:500 700;font-style:normal;font-display:swap}

:root{
  --navy:#0d2d41; --navy-deep:#081f2d; --navy-ink:#0a2434;
  --teal:#3b6672; --teal-dk:#2f535e;
  --taupe:#bfada1; --cream:#e1ded9;
  --paper:#f5f1e9; --paper-2:#efe9df;
  --paleblue:#bccdd1;
  --ink:#1a2a33; --ink-soft:#3f4f58; --muted:#6a7882;
  --gold:#c6a15b; --white:#ffffff;
  /* sage / eucalyptus — complementary warm-organic accent */
  --sage:#7e9480; --sage-deep:#566b5d; --sage-soft:#e9eee5;
  --line:rgba(13,45,65,.12);

  --font-display:"Laro","Jost","Poppins",system-ui,sans-serif;  /* real Laro, Jost fallback */
  --font-body:"Poppins",system-ui,-apple-system,sans-serif;

  --maxw:1200px; --gutter:clamp(20px,5vw,56px);
  --radius:6px; --radius-lg:18px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow-sm:0 1px 2px rgba(13,45,65,.04),0 8px 22px -6px rgba(13,45,65,.10);
  --shadow:0 2px 4px rgba(13,45,65,.04),0 20px 48px -14px rgba(13,45,65,.20);
  --shadow-xl:0 4px 10px rgba(8,31,45,.06),0 44px 90px -22px rgba(8,31,45,.36);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);color:var(--ink);background:var(--paper);line-height:1.72;
  font-size:clamp(16px,1.05vw,17.5px);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;-webkit-hyphens:none;hyphens:none}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--navy);color:var(--cream)}
:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:2px}

body::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- Type ---------- */
.display,h1,h2,h3{font-family:var(--font-display);color:var(--navy);font-weight:300;line-height:1.06;letter-spacing:-.012em}
h1{font-size:clamp(2.6rem,6vw,4.9rem)}
h2{font-size:clamp(2.1rem,4.4vw,3.5rem);line-height:1.1;text-wrap:balance}
h3{font-size:clamp(1.22rem,1.8vw,1.5rem);font-weight:500;line-height:1.2;text-wrap:balance}
.lead{text-wrap:pretty}
.eyebrow{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.34em;font-size:.72rem;font-weight:500;color:var(--teal);display:inline-block}
.lead{font-size:clamp(1.06rem,1.3vw,1.22rem);color:var(--ink-soft);line-height:1.7}
.muted{color:var(--muted)}
.rule-v{width:1px;height:54px;background:linear-gradient(var(--taupe),transparent);margin:0 auto}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.wrap-tight{max-width:920px;margin:0 auto;padding:0 var(--gutter)}
section{position:relative;padding:clamp(74px,9vw,130px) 0;z-index:2;isolation:isolate}
.center{text-align:center}
.sec-head{max-width:700px;margin:0 auto clamp(44px,5vw,72px);text-align:center}
.sec-head .eyebrow{margin-bottom:18px}
.sec-head h2{margin-bottom:18px}

/* prismatic flare */
.flare{position:absolute;pointer-events:none;z-index:0;border-radius:50%;filter:blur(72px);opacity:.5;
  background:conic-gradient(from 120deg,#ffd9b3,#ffc9d6,#d6c9ff,#c9e6ff,#c9fff0,#ffe9c9);mix-blend-mode:multiply}
.flare--soft{opacity:.32;filter:blur(94px)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;font-family:var(--font-display);
  font-weight:600;font-size:.98rem;text-transform:none;letter-spacing:.01em;padding:.92em 2em;
  border-radius:999px;border:1.5px solid transparent;cursor:pointer;white-space:nowrap;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s,color .3s,border-color .3s}
.btn .arw{transition:transform .35s var(--ease)}
.btn:hover .arw{transform:translateX(4px)}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-dk);box-shadow:0 18px 36px rgba(59,102,114,.32);transform:translateY(-2px)}
.btn-taupe{background:var(--taupe);color:var(--navy-deep)}
.btn-taupe:hover{box-shadow:0 18px 36px rgba(191,173,161,.45);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--navy);border-color:rgba(13,45,65,.28)}
.btn-outline:hover{border-color:var(--navy);background:rgba(13,45,65,.04);transform:translateY(-2px)}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.08);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--navy)}
.btn-light:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.btn-lg{padding:1.05em 2.4em;font-size:1.04rem}
.btn-block{width:100%}
.tlink{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;font-weight:500;
  color:var(--teal);border-bottom:1px solid var(--taupe);padding-bottom:3px;transition:.3s}
.tlink:hover{color:var(--navy);border-color:var(--navy)}

/* lucide icon defaults */
.ico{width:24px;height:24px;stroke:currentColor;stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:60;transition:.45s var(--ease)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:78px}
.site-header.scrolled{background:rgba(244,241,236,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(13,45,65,.07);height:64px}
.site-header.scrolled .wrap{height:64px}
.brand{display:flex;align-items:center;gap:11px}
.logo-img{height:21px;width:auto;display:block;transition:.45s var(--ease)}
.site-header.scrolled .logo-img{height:19px}
.nav{display:flex;align-items:center;gap:34px}
.nav a.navlink{font-family:var(--font-display);text-transform:none;letter-spacing:.01em;font-size:.95rem;font-weight:500;color:var(--navy);opacity:.74;transition:.3s}
.nav a.navlink:hover{opacity:1}
.header-cta{padding:.85em 1.5em}
@media(max-width:860px){.nav .navlink{display:none}}

/* ---------- HERO ---------- */
.hero{padding-top:150px;padding-bottom:clamp(70px,8vw,120px);
  background:radial-gradient(120% 90% at 80% 0%,#fbf9f5 0%,var(--paper) 45%,var(--paper-2) 100%);overflow:hidden}
.hero .flare{width:620px;height:620px;top:-220px;right:-160px}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(40px,5vw,80px);align-items:center}
.hero .eyebrow{margin-bottom:26px}
.hero h1{margin-bottom:24px}
.hero h1{line-height:1.02}
.hero h1 .lt{display:block;font-weight:300;color:var(--navy);white-space:nowrap}
.hero h1 .hv{display:block;font-weight:600;color:var(--navy)}
.hero .steps{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:30px;
  font-family:var(--font-display);text-transform:uppercase;letter-spacing:.28em;font-size:.82rem;color:var(--teal)}
.hero .steps i{width:26px;height:1px;background:var(--taupe);display:inline-block}
.hero .lead{max-width:46ch;margin-bottom:36px}
.hero .cta-row{display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-bottom:22px}
.hero .onsale{font-family:var(--font-display);letter-spacing:.04em;font-size:.92rem;color:var(--muted)}
.hero .onsale b{color:var(--navy);font-weight:600}

.book-stage{perspective:1600px;display:flex;justify-content:center;align-items:center;min-height:480px}
.book{position:relative;width:336px;max-width:80%;transform:rotateY(-12deg) rotateX(3deg);
  animation:bookfloat 7s ease-in-out infinite;transition:transform .5s var(--ease);will-change:transform;
  border-radius:3px 9px 9px 3px;
  box-shadow:0 1px 1px rgba(0,0,0,.16),0 26px 50px -14px rgba(8,31,45,.5),0 14px 26px -16px rgba(8,31,45,.42)}
.book__face{position:relative;border-radius:3px 9px 9px 3px;overflow:hidden}
.book__face img{width:100%;display:block}
/* spine shading on the left edge (no protruding element) */
.book__face::before{content:"";position:absolute;left:0;top:0;bottom:0;width:16px;z-index:2;pointer-events:none;
  background:linear-gradient(90deg,rgba(0,0,0,.32),rgba(0,0,0,.06) 55%,rgba(255,255,255,.06) 86%,transparent)}
/* soft sheen */
.book__face::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(105deg,rgba(255,255,255,.20),rgba(255,255,255,0) 32%)}
.book__shadow{position:absolute;left:50%;bottom:-44px;width:72%;height:38px;transform:translateX(-50%);
  background:radial-gradient(closest-side,rgba(8,31,45,.34),transparent 75%);filter:blur(11px);z-index:-1}
@keyframes bookfloat{0%,100%{transform:rotateY(-12deg) rotateX(3deg) translateY(0)}50%{transform:rotateY(-10deg) rotateX(2deg) translateY(-13px)}}

/* ---------- As seen on ---------- */
/* Bonuses featured high (warm, rounded) */
.bonusfeature{background:#fff}
.bf-head{max-width:680px;margin:0 auto clamp(40px,5vw,58px);text-align:center}
.bf-head h2{margin:14px 0 14px}
.bf-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2vw,26px);max-width:940px;margin:0 auto}
.bf-card{background:var(--paper);border-radius:24px;padding:clamp(28px,3vw,42px);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.bf-card:hover{transform:translateY(-4px);box-shadow:0 24px 50px rgba(13,45,65,.1)}
.bf-tag{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.22em;font-size:.68rem;color:var(--teal);display:block;margin-bottom:14px}
.bf-card h3{color:var(--navy);font-weight:500;margin-bottom:10px}
.bf-card p{color:var(--ink-soft);font-size:.99rem}
.bf-cta{text-align:center;margin-top:clamp(34px,4vw,50px)}

.seenon{padding:clamp(44px,4.5vw,64px) 0;background:var(--paper)}
.seenon .lbl{text-align:center;margin-bottom:24px}
.seenon .logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:16px 40px}
.seenon .logos span{font-family:var(--font-display);font-weight:300;font-size:clamp(.95rem,1.35vw,1.18rem);letter-spacing:.05em;color:var(--navy);opacity:.58;transition:.3s}
.seenon .logos span:hover{opacity:1}

/* ---------- Invitation ---------- */
.invitation{background:#fff;text-align:center;overflow:hidden}
.invitation .flare{width:520px;height:520px;left:-160px;bottom:-240px;opacity:.32}
.invitation .pull{font-family:var(--font-body);font-weight:300;font-size:clamp(1.3rem,2.3vw,1.95rem);line-height:1.55;color:var(--navy);max-width:880px;margin:28px auto 0;letter-spacing:0}
.invitation .pull em{font-style:italic;color:var(--teal)}
.invitation .sig{margin-top:30px;font-family:var(--font-display);letter-spacing:.2em;text-transform:uppercase;font-size:.76rem;color:var(--muted)}

/* ---------- Method ---------- */
.method{background:var(--paper)}
.method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,3vw,52px)}
.m-card{position:relative;padding-top:34px;border-top:1px solid rgba(13,45,65,.18)}
.m-card .no{font-family:var(--font-display);font-weight:300;font-size:3.4rem;color:var(--taupe);line-height:1;letter-spacing:-.02em}
.m-card h3{margin:18px 0 14px;color:var(--navy);font-weight:500;letter-spacing:.02em}
.m-card p{color:var(--ink-soft);font-size:.99rem}
.m-card .tag{display:block;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.24em;font-size:.68rem;color:var(--teal);margin-top:18px}

/* ---------- Experiential (dark) + app mockup ---------- */
.exp{background:var(--navy);color:var(--cream);overflow:hidden}
.exp .flare{width:560px;height:560px;right:-220px;top:-180px;opacity:.16;mix-blend-mode:screen}
.exp .grid{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(40px,5vw,76px);align-items:center}
.exp h2{color:#fff}
.exp .eyebrow{color:var(--paleblue)}
.exp p{color:#c5d2d8;margin-top:18px}
.exp .seq{display:flex;gap:12px;margin-top:34px;flex-wrap:wrap}
.exp .seq .chip{border:1px solid rgba(255,255,255,.26);border-radius:3px;padding:.8em 1.3em;font-family:var(--font-display);
  text-transform:uppercase;letter-spacing:.2em;font-size:.72rem;color:#fff;display:flex;align-items:center;gap:.7em}
.exp .seq .chip b{color:var(--paleblue);font-weight:500}
.exp .note{margin-top:30px;font-size:.92rem;color:#9fb2ba}

/* Real companion-app screenshot in a phone frame */
.app-shot{display:flex;justify-content:center;position:relative}
.app-shot::before{content:"";position:absolute;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(closest-side,rgba(188,205,209,.5),transparent 70%);filter:blur(40px);z-index:0}
.app-phone{position:relative;z-index:1;width:min(78%,290px);background:#0a1a24;padding:9px;border-radius:42px;
  box-shadow:var(--shadow-xl),0 0 0 1.5px rgba(255,255,255,.06) inset;animation:floaty 8s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.app-phone .notch{position:absolute;top:18px;left:50%;transform:translateX(-50%);width:84px;height:22px;background:#0a1a24;border-radius:14px;z-index:3}
.app-phone img{width:100%;display:block;border-radius:34px}
@media(prefers-reduced-motion:reduce){.app-phone{animation:none}}

/* ---------- What's inside — editorial hairline grid ---------- */
.inside{background:#fff}
.i-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.i-cell{background:var(--paper);padding:clamp(28px,2.6vw,42px);transition:background .4s var(--ease)}
.i-cell:hover{background:#fff}
.i-cell .ic-wrap{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:rgba(59,102,114,.09);color:var(--teal);margin-bottom:20px;transition:.4s var(--ease)}
.i-cell:hover .ic-wrap{background:var(--teal);color:#fff;transform:translateY(-2px)}
.i-cell h3{color:var(--navy);font-weight:500;margin-bottom:10px}
.i-cell p{font-size:.95rem;color:var(--ink-soft)}

/* ---------- Cinematic quote band ---------- */
.band{position:relative;min-height:clamp(560px,82vh,820px);display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.band .bg{position:absolute;inset:0;z-index:0}
.band .bg img{width:100%;height:100%;object-fit:cover;object-position:center 28%;transform:scale(1.08)}
.band .bg::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 100% at 30% 30%,rgba(13,45,65,.55),rgba(8,31,45,.86) 75%)}
.band .flare{width:560px;height:560px;right:-200px;bottom:-220px;opacity:.2;mix-blend-mode:screen}
.band .inner{position:relative;z-index:2;max-width:1040px;padding:0 var(--gutter)}
.band .qmark{font-family:var(--font-display);font-weight:500;font-size:clamp(4rem,9vw,8rem);line-height:.5;color:var(--taupe);opacity:.55;display:block;margin-bottom:6px}
.band .q{font-family:var(--font-body);font-weight:300;line-height:1.42;letter-spacing:0;font-size:clamp(1.5rem,3.4vw,2.6rem);color:#fff}
.band .q b{font-weight:500;color:var(--paleblue)}
.band .q .iam{color:#fff;font-weight:600;letter-spacing:.04em}
.band .div{width:54px;height:1px;background:var(--taupe);margin:34px auto 0;opacity:.6}
.band .attr{margin-top:22px;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.28em;font-size:.74rem;color:var(--paleblue)}

/* ---------- Praise: grand editorial endorsement (no cards, no borders) ---------- */
.praise{background:#fff;overflow:hidden}
.praise .flare{width:520px;height:520px;left:-180px;top:90px;opacity:.22}
/* two-up photo-led endorsements */
.endorse-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,30px);max-width:1060px;margin:0 auto}
.endorse-card{display:flex;flex-direction:column;background:var(--paper);border-radius:22px;
  padding:clamp(30px,3vw,44px);box-shadow:0 14px 40px rgba(13,45,65,.06)}
.endorse-card .glyph{font-family:var(--font-display);font-weight:600;font-size:3rem;line-height:.5;color:var(--taupe);display:block;margin-bottom:14px}
.endorse-card blockquote{flex:1}
.endorse-card blockquote p{font-family:var(--font-body);font-weight:300;font-size:clamp(1.12rem,1.5vw,1.34rem);
  line-height:1.55;color:var(--navy);letter-spacing:0}
.ecard-by{display:flex;align-items:center;gap:16px;margin-top:26px;padding-top:24px;border-top:1px solid var(--line)}
.ecard-meta{display:flex;flex-direction:column}
.ecard-meta .nm{font-family:var(--font-display);font-weight:500;font-size:1.04rem;color:var(--navy)}
.ecard-meta .rl{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;color:var(--muted);margin-top:3px}
/* circular portrait (placeholder until real headshot) */
.endorse-photo{flex:none;width:60px;height:60px;border-radius:50%;object-fit:cover;
  background:linear-gradient(140deg,#efe7dc,#cdbaa7);display:grid;place-items:center;color:#fff;
  font-family:var(--font-display);font-weight:400;font-size:1.18rem;letter-spacing:.03em;
  box-shadow:0 8px 18px rgba(13,45,65,.14),0 0 0 4px #fff,0 0 0 5px rgba(13,45,65,.05)}
.endorse-photo[data-initials]::before{content:attr(data-initials)}

/* ---------- Voices: warm client-testimonial grid (light, 2x2) ---------- */
.voices{background:var(--paper);overflow:hidden}
.tgrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.2vw,28px);max-width:1060px;margin:0 auto}
.tcard{display:flex;flex-direction:column;background:#fff;border-radius:22px;
  padding:clamp(28px,3vw,40px);box-shadow:0 14px 40px rgba(13,45,65,.06)}
.tcard .tq{font-family:var(--font-display);font-weight:600;font-size:2.6rem;line-height:.4;color:var(--taupe);display:block;margin-bottom:18px}
.tcard blockquote{flex:1;font-family:var(--font-body);font-weight:400;font-size:1.04rem;line-height:1.62;color:var(--navy)}
.tcard .tname{margin-top:24px;padding-top:20px;border-top:1px solid var(--line);
  font-family:var(--font-display);font-weight:500;text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--teal)}

/* ---------- Pre-order / bonuses (warm, light) ---------- */
.order{background:var(--paper);color:var(--ink);overflow:hidden}
.order .flare{width:560px;height:560px;right:-220px;bottom:-240px;opacity:.24}
/* stacked boxes (capture is box 03) */
.order-stack{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:16px}
.obox{display:flex;gap:22px;align-items:flex-start;background:#fff;color:var(--ink);
  border-radius:20px;padding:clamp(26px,2.8vw,38px);box-shadow:0 14px 38px rgba(13,45,65,.07)}
.obox-num{flex:none;font-family:var(--font-display);font-weight:300;font-size:1.7rem;line-height:1;color:var(--teal);
  width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:rgba(59,102,114,.1)}
.obox-body{flex:1}
.obox-body h3{color:var(--navy);font-weight:500;margin-bottom:7px}
.obox-body>p{color:var(--ink-soft);font-size:.98rem}
.obox-form .small{font-size:.92rem;color:var(--muted);margin-bottom:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;color:var(--teal);margin-bottom:8px;font-weight:500}
.field input{width:100%;padding:.95em 1.1em;font-family:var(--font-body);font-size:1rem;color:var(--ink);border:1.5px solid #dcdfe1;border-radius:var(--radius);background:#fbfbfa;transition:.25s}
.field input::placeholder{color:#aab3b8}
.field input:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(59,102,114,.1)}
.obox-form .btn{margin-top:6px}
.consent{font-size:.74rem;color:#9aa6ac;margin-top:14px;line-height:1.5}
.setup-note{font-size:.72rem;background:#f3f7f8;border:1px dashed var(--teal);color:#2f535e;padding:10px 12px;border-radius:10px;margin-bottom:18px;line-height:1.5}

/* CTA block under the boxes: hardcover tip + retailers */
.order-cta{max-width:740px;margin:clamp(30px,3.4vw,44px) auto 0;text-align:center}
.hardcover-tip{font-size:.96rem;line-height:1.6;color:var(--ink-soft);max-width:620px;margin:0 auto 26px;
  padding:18px 24px;background:#fff;border:1px solid var(--line);border-radius:16px}
.hardcover-tip b{color:var(--navy);font-weight:600}
.order .retailers{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.order .retailers .btn{flex:1 1 auto;min-width:150px}
.order .onsale{font-family:var(--font-display);letter-spacing:.04em;font-size:.9rem;color:var(--muted);margin-top:18px}
.order .onsale b{color:var(--navy);font-weight:500}

/* ---------- About ---------- */
.about{background:#fff}
.about-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(40px,5vw,72px);align-items:center}
.about-photo{position:relative}
.about-photo img{border-radius:var(--radius-lg);box-shadow:var(--shadow);width:100%}
.about-photo .badge{position:absolute;left:-18px;bottom:26px;background:#fff;border-radius:var(--radius);padding:16px 22px;box-shadow:var(--shadow-sm);font-family:var(--font-display)}
.about-photo .badge b{display:block;color:var(--navy);font-weight:500;font-size:1.3rem}
.about-photo .badge span{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal)}
.about-body .eyebrow{margin-bottom:14px}
.about-body h2{margin-bottom:22px}
.about-body p{color:var(--ink-soft);margin-bottom:16px}
.about-body p.first::first-letter{font-family:var(--font-display);font-weight:300;float:left;font-size:3.5rem;line-height:.82;padding:6px 12px 0 0;color:var(--teal)}
.creds{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:24px;padding-top:22px;border-top:1px solid var(--line)}
.creds span{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--muted)}

/* ---------- Final ---------- */
.final{background:var(--paper);color:var(--ink);text-align:center;overflow:hidden}
.final .flare{width:560px;height:560px;left:50%;top:-260px;transform:translateX(-50%);opacity:.3}
.final .eyebrow{color:var(--teal)}
.final h2{color:var(--navy);max-width:18ch;margin:0 auto 18px}
.final .lead{color:var(--ink-soft);max-width:48ch;margin:0 auto 36px}
.final-cta{margin-bottom:20px}
.final .onsale{font-family:var(--font-display);letter-spacing:.06em;font-size:.9rem;color:var(--muted)}
.final .onsale b{color:var(--navy);font-weight:500}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-deep);color:#8fa3ac;padding:clamp(50px,5vw,68px) 0 40px;font-size:.9rem}
.foot-top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:28px;align-items:flex-start;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand{display:flex;align-items:center;gap:11px}
.foot-logo{height:24px;width:auto;display:block;opacity:.95}
.foot-brand .tag{display:block;font-family:var(--font-display);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#7e929b;margin-top:8px}
.foot-links{display:flex;flex-wrap:wrap;gap:14px 28px}
.foot-links a{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:#bccdd1;transition:.3s}
.foot-links a:hover{color:#fff}
.foot-fine{padding-top:24px;color:#6f8089;font-size:.78rem;line-height:1.6;max-width:780px}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero-grid,.exp .grid,.order-grid,.about-grid{grid-template-columns:1fr}
  .hero-grid{gap:30px}
  .book-stage{min-height:420px;order:-1}
  .i-grid{grid-template-columns:1fr 1fr}
  .about-photo{max-width:420px;margin:0 auto}
  .exp .grid .app-shot{order:-1}
  .endorse-grid,.tgrid{grid-template-columns:1fr;gap:18px}
}
@media(max-width:680px){
  .i-grid{grid-template-columns:1fr}
  .bf-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .hero{padding-top:120px}
  .order .retailers .btn,.final .retailers .btn{flex-basis:100%}
  .nav{gap:0}
  .about-body p.first::first-letter{font-size:3rem}
  .band{min-height:64vh}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
  .book{transform:rotateY(-12deg) rotateX(3deg)}
  .band .bg img{transform:scale(1.08)!important}
}

/* ============================================================================
   THANK-YOU PAGES (post-pre-order confirmation)
   ============================================================================ */
.ty-hero{background:radial-gradient(120% 90% at 80% 0%,#fbf9f5 0%,var(--paper) 55%,var(--paper-2) 100%);text-align:center;overflow:hidden;padding-top:clamp(124px,16vw,168px)}
.ty-check{width:86px;height:86px;border-radius:50%;background:var(--teal);display:grid;place-items:center;margin:0 auto clamp(26px,4vw,38px);box-shadow:0 20px 44px rgba(59,102,114,.34);animation:floaty 7s ease-in-out infinite}
.ty-check svg{width:40px;height:40px;stroke:#fff;stroke-width:2.4;fill:none;stroke-linecap:round;stroke-linejoin:round}
.ty-hero h1{margin:18px auto 18px;max-width:16ch}
.ty-hero .lead{color:var(--ink-soft);max-width:42ch;margin:0 auto}
.ty-body{max-width:56ch;margin:clamp(24px,3vw,34px) auto 0;color:var(--ink-soft);font-size:1.06rem;line-height:1.72}
.ty-gifts{background:#fff}
.ty-note{text-align:center;max-width:62ch;margin:clamp(30px,3.4vw,42px) auto 0;color:var(--muted);font-size:.95rem;line-height:1.65}
.ty-note a{color:var(--teal);border-bottom:1px solid var(--taupe);white-space:nowrap}
.ty-cta{text-align:center;margin-top:clamp(34px,4vw,50px)}
.ty-cta .sub{margin-top:16px;color:var(--muted);font-size:.92rem}
/* event (Version 2) */
.ty-event{background:var(--paper);overflow:hidden}
.ty-event .flare{width:540px;height:540px;left:50%;top:-220px;transform:translateX(-50%);opacity:.26}
.ev-card{position:relative;max-width:860px;margin:0 auto;background:#fff;border-radius:26px;padding:clamp(34px,4.5vw,64px);box-shadow:var(--shadow);text-align:center}
.ev-card .eyebrow{color:var(--teal)}
.ev-card h2{margin:14px auto 8px;max-width:18ch}
.ev-meta{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.2em;font-size:.8rem;color:var(--muted);margin-bottom:clamp(22px,3vw,30px)}
.ev-meta b{color:var(--navy);font-weight:600}
.ev-card p{color:var(--ink-soft);max-width:60ch;margin:0 auto 16px}
.ev-list{list-style:none;text-align:left;max-width:480px;margin:clamp(24px,3vw,34px) auto;display:flex;flex-direction:column;gap:14px}
.ev-list li{display:flex;align-items:flex-start;gap:14px;color:var(--navy);font-size:1rem}
.ev-list li::before{content:"";flex:none;width:9px;height:9px;border-radius:50%;background:var(--teal);margin-top:8px}
.ev-gift{background:var(--paper);border-radius:16px;padding:20px 24px;max-width:600px;margin:clamp(24px,3vw,32px) auto;color:var(--ink-soft);font-size:.98rem;line-height:1.6}
.ev-gift b{color:var(--navy);font-weight:600}
.ev-card .ev-cta{margin-top:clamp(28px,3.4vw,40px)}
.ev-card .ev-stream{margin-top:16px;color:var(--muted);font-size:.9rem}

/* thank-you: bonus blocks with visuals (alternating) */
.ty-bonus{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,76px);align-items:center;max-width:1040px;margin:0 auto}
.ty-bonus + .ty-bonus{margin-top:clamp(54px,7vw,92px)}
.ty-bonus:nth-child(even) .ty-media{order:2}
.ty-media{display:flex;justify-content:center}
.ty-media img.rounded{width:100%;max-width:440px;border-radius:22px;box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover}
.ty-bonus .bf-tag{display:block;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.22em;font-size:.7rem;color:var(--teal);margin-bottom:14px}
.ty-bonus h3{color:var(--navy);font-weight:500;margin-bottom:12px;font-size:clamp(1.3rem,2vw,1.6rem)}
.ty-bonus p{color:var(--ink-soft);font-size:1.02rem;line-height:1.7}
@media(max-width:760px){
  .ty-bonus{grid-template-columns:1fr;gap:26px}
  .ty-bonus:nth-child(even) .ty-media{order:0}
  .ty-media{order:-1}
}

/* event card portrait of Jim */
.ev-photo{width:clamp(120px,18vw,150px);height:clamp(120px,18vw,150px);border-radius:50%;object-fit:cover;
  object-position:50% 20%;margin:0 auto clamp(22px,3vw,30px);display:block;
  box-shadow:0 18px 40px rgba(13,45,65,.18),0 0 0 6px #fff,0 0 0 7px rgba(13,45,65,.06)}

/* ============================================================================
   PREMIUM POLISH PASS
   ============================================================================ */
/* consistent, refined card hover micro-interactions */
.endorse-card,.tcard,.bf-card{transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.endorse-card:hover,.tcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.bf-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}

/* richer hero book: softer larger ground shadow + warm glow behind */
.book-stage{position:relative}
.book-stage::after{content:"";position:absolute;top:50%;left:50%;width:64%;aspect-ratio:1;
  transform:translate(-50%,-54%);border-radius:50%;z-index:-1;pointer-events:none;
  background:radial-gradient(closest-side,rgba(198,161,91,.16),transparent 72%);filter:blur(50px)}
.book__shadow{bottom:-50px;width:82%;height:48px;filter:blur(16px);
  background:radial-gradient(closest-side,rgba(8,31,45,.30),transparent 78%)}

/* smoother, more refined reveal */
.reveal{transform:translateY(22px) scale(.99);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{transform:none}

/* refined transitions on small labels/logos */
.seenon .logos span{transition:color .35s var(--ease),opacity .35s var(--ease)}
.nav a.navlink{transition:opacity .3s var(--ease),color .3s var(--ease)}

/* mobile refinements for a tighter, premium feel */
@media(max-width:560px){
  section{padding:clamp(56px,14vw,72px) 0}
  h1{font-size:clamp(2.5rem,9.5vw,3.2rem)}
  .sec-head{margin-bottom:clamp(30px,8vw,40px)}
  .bf-card,.endorse-card,.tcard,.obox{border-radius:18px}
  .ty-hero{padding-top:116px}
  .ev-card{padding:30px 22px}
}
@media(prefers-reduced-motion:reduce){
  .reveal{transform:none}
  .book-stage::after,.book__shadow{filter:blur(16px)}
}
