/* ============================================================
   CONSILIUM CREATORS — Sales site
   Design system: warm classical / scholarly, gentle & adaptive
   ============================================================ */

/* ---------- Theme tokens ---------- */
:root{
  /* Ivory (default) */
  --bg:        oklch(0.973 0.011 85);
  --bg-2:      oklch(0.949 0.017 80);
  --surface:   oklch(0.992 0.006 85);
  --blush:     oklch(0.932 0.027 40);
  --ink:       oklch(0.265 0.018 58);
  --ink-soft:  oklch(0.45 0.02 60);
  --ink-faint: oklch(0.60 0.018 65);
  --gold:      oklch(0.74 0.115 80);
  --gold-deep: oklch(0.585 0.105 70);
  --gold-soft: oklch(0.90 0.06 85);
  --line:      oklch(0.885 0.014 80);
  --line-soft: oklch(0.93 0.012 82);
  --medallion: oklch(0.255 0.022 58);
  --shadow:    0 1px 2px rgba(40,34,24,.04), 0 18px 48px -20px rgba(40,34,24,.22);
  --shadow-sm: 0 1px 2px rgba(40,34,24,.05), 0 8px 24px -14px rgba(40,34,24,.18);

  /* secondary accent (tweakable) */
  --accent2:   oklch(0.86 0.05 30);   /* blush */
  --accent2-ink: oklch(0.50 0.09 30);

  --font-display: "Cormorant Garamond", Georgia, serif;
  --font-body: "Hanken Grotesk", system-ui, sans-serif;
  --font-mono: "Spline Sans Mono", ui-monospace, monospace;

  --maxw: 1180px;
  --radius: 18px;
  --radius-sm: 12px;
}

[data-theme="ink"]{
  --bg:        oklch(0.205 0.016 58);
  --bg-2:      oklch(0.245 0.018 58);
  --surface:   oklch(0.262 0.02 60);
  --blush:     oklch(0.33 0.03 35);
  --ink:       oklch(0.935 0.012 85);
  --ink-soft:  oklch(0.76 0.02 82);
  --ink-faint: oklch(0.62 0.02 78);
  --gold:      oklch(0.83 0.12 86);
  --gold-deep: oklch(0.86 0.11 88);
  --gold-soft: oklch(0.42 0.07 80);
  --line:      oklch(0.33 0.02 60);
  --line-soft: oklch(0.29 0.018 60);
  --medallion: oklch(0.16 0.018 58);
  --shadow:    0 1px 2px rgba(0,0,0,.3), 0 24px 60px -22px rgba(0,0,0,.6);
  --shadow-sm: 0 1px 2px rgba(0,0,0,.3), 0 12px 30px -16px rgba(0,0,0,.5);
  --accent2:   oklch(0.42 0.06 32);
  --accent2-ink: oklch(0.82 0.06 35);
}

[data-theme="parchment"]{
  --bg:        oklch(0.928 0.028 76);
  --bg-2:      oklch(0.902 0.034 73);
  --surface:   oklch(0.957 0.024 78);
  --blush:     oklch(0.892 0.04 46);
  --ink:       oklch(0.30 0.038 52);
  --ink-soft:  oklch(0.45 0.038 54);
  --ink-faint: oklch(0.57 0.035 58);
  --gold:      oklch(0.64 0.115 68);
  --gold-deep: oklch(0.53 0.105 64);
  --gold-soft: oklch(0.84 0.06 75);
  --line:      oklch(0.83 0.038 70);
  --line-soft: oklch(0.87 0.03 72);
  --medallion: oklch(0.30 0.05 52);
  --shadow:    0 1px 2px rgba(60,44,24,.05), 0 18px 48px -20px rgba(60,44,24,.26);
  --shadow-sm: 0 1px 2px rgba(60,44,24,.06), 0 8px 24px -14px rgba(60,44,24,.2);
  --accent2:   oklch(0.82 0.055 130);   /* sage */
  --accent2-ink: oklch(0.46 0.08 130);
}

/* ---------- Reset / base ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:18px;
  line-height:1.65;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition:background .5s ease, color .5s ease;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--gold-soft);color:var(--ink)}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;margin:0;line-height:1.06;letter-spacing:-0.01em}
p{margin:0}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:108px 0;position:relative}
.section-tight{padding:72px 0}

/* eyebrow / kicker */
.kicker{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--font-mono);
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:500;
}
.kicker::before{content:"";width:22px;height:1px;background:var(--gold-deep);opacity:.6}
.kicker.center::after{content:"";width:22px;height:1px;background:var(--gold-deep);opacity:.6}
.kicker.center{justify-content:center}

.eyebrow{
  font-family:var(--font-mono);font-size:11.5px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-faint);font-weight:500;
}

.lede{font-size:20px;color:var(--ink-soft);line-height:1.6;max-width:58ch}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:15px 26px;border-radius:999px;border:1px solid transparent;
  font-family:var(--font-body);font-weight:600;font-size:15.5px;letter-spacing:.01em;
  cursor:pointer;transition:transform .25s cubic-bezier(.3,.8,.3,1),box-shadow .25s,background .25s,color .25s;
  white-space:nowrap;
}
.btn-primary{
  background:var(--ink);color:var(--bg);
  box-shadow:0 1px 2px rgba(0,0,0,.12), 0 14px 30px -14px rgba(0,0,0,.4);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 1px 2px rgba(0,0,0,.12), 0 20px 38px -14px rgba(0,0,0,.45)}
.btn-gold{
  background:linear-gradient(180deg, var(--gold) 0%, var(--gold-deep) 130%);
  color:oklch(0.22 0.02 60);
  box-shadow:0 1px 2px rgba(0,0,0,.1), 0 14px 30px -14px var(--gold-deep);
}
.btn-gold:hover{transform:translateY(-2px)}
.btn-ghost{
  background:transparent;color:var(--ink);border-color:var(--line);
}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-lg{padding:18px 34px;font-size:16.5px}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .4s ease, box-shadow .4s ease, padding .3s ease, border-color .4s;
  border-bottom:1px solid transparent;
}
.nav-inner{
  max-width:var(--maxw);margin:0 auto;padding:18px 28px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav.scrolled{
  background:color-mix(in oklab, var(--bg) 80%, transparent);
  -webkit-backdrop-filter:blur(18px) saturate(140%);backdrop-filter:blur(18px) saturate(140%);
  border-bottom-color:var(--line-soft);
}
.nav.scrolled .nav-inner{padding:12px 28px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-size:21px;font-weight:600;letter-spacing:-.01em}
.brand-mark{
  width:38px;height:38px;border-radius:50%;flex:none;
  background:var(--medallion);
  display:grid;place-items:center;
  box-shadow:inset 0 0 0 1px color-mix(in oklab, var(--gold) 35%, transparent);
}
.brand-mark img{width:30px;height:30px;filter:drop-shadow(0 0 6px color-mix(in oklab,var(--gold) 40%,transparent))}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{font-size:15px;color:var(--ink-soft);font-weight:500;transition:color .2s;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:1px;background:var(--gold-deep);transform:scaleX(0);transform-origin:left;transition:transform .25s}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-toggle{display:none}

/* ---------- Hero ---------- */
.hero{padding:160px 0 90px;text-align:center;position:relative;overflow:hidden}
.hero-glow{
  position:absolute;top:-120px;left:50%;transform:translateX(-50%);
  width:760px;height:560px;border-radius:50%;pointer-events:none;
  background:radial-gradient(closest-side, color-mix(in oklab,var(--gold) 28%,transparent), transparent 72%);
  opacity:.55;filter:blur(8px);
}
.hero .wrap{position:relative}
.medallion{
  width:128px;height:128px;border-radius:50%;margin:0 auto 30px;
  background:radial-gradient(circle at 50% 38%, color-mix(in oklab,var(--medallion) 86%, var(--gold) 8%), var(--medallion));
  display:grid;place-items:center;position:relative;
  box-shadow:inset 0 0 0 1.5px color-mix(in oklab,var(--gold) 45%,transparent),
             0 0 0 8px color-mix(in oklab,var(--gold) 8%,transparent),
             0 22px 50px -18px rgba(0,0,0,.5);
}
.medallion::after{
  content:"";position:absolute;inset:-22px;border-radius:50%;
  background:radial-gradient(closest-side,color-mix(in oklab,var(--gold) 30%,transparent),transparent 70%);
  z-index:-1;opacity:.7;animation:halo 6s ease-in-out infinite;
}
@keyframes halo{0%,100%{opacity:.45;transform:scale(.96)}50%{opacity:.8;transform:scale(1.04)}}
.medallion img{width:96px;height:96px;filter:drop-shadow(0 2px 10px color-mix(in oklab,var(--gold) 55%,transparent))}

.hero h1{
  font-size:clamp(44px, 7vw, 86px);font-weight:600;
  letter-spacing:-0.018em;margin:22px auto 0;max-width:16ch;
}
.hero h1 em{font-style:italic;color:var(--gold-deep)}
.hero .lede{margin:26px auto 0;text-align:center;font-size:clamp(18px,2.2vw,22px)}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:38px}

.rating{
  display:inline-flex;align-items:center;gap:12px;margin-top:30px;
  color:var(--ink-soft);font-size:14.5px;
}
.stars{display:flex;gap:2px;color:var(--gold-deep)}
.stars svg{width:17px;height:17px}
.rating .divider{width:1px;height:16px;background:var(--line)}

/* presale ribbon chip */
.presale-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 15px;border-radius:999px;margin-bottom:8px;
  background:color-mix(in oklab,var(--gold) 16%,var(--surface));
  border:1px solid color-mix(in oklab,var(--gold) 35%,transparent);
  color:var(--gold-deep);font-family:var(--font-mono);
  font-size:11.5px;letter-spacing:.13em;text-transform:uppercase;font-weight:600;
}
.presale-chip .dot{width:7px;height:7px;border-radius:50%;background:var(--gold-deep);box-shadow:0 0 0 3px color-mix(in oklab,var(--gold) 25%,transparent);animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

/* ---------- Browser frame (product shot) ---------- */
.shot-frame{
  max-width:980px;margin:64px auto 0;border-radius:16px;overflow:hidden;
  border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);
}
.shot-bar{display:flex;align-items:center;gap:8px;padding:13px 16px;border-bottom:1px solid var(--line-soft);background:var(--bg-2)}
.shot-dots{display:flex;gap:7px}
.shot-dots i{width:11px;height:11px;border-radius:50%;background:var(--line);display:block}
.shot-url{
  margin-left:10px;flex:1;max-width:420px;height:26px;border-radius:8px;
  background:var(--bg);border:1px solid var(--line-soft);
  display:flex;align-items:center;padding:0 12px;gap:8px;
  font-family:var(--font-mono);font-size:11.5px;color:var(--ink-faint);
}
.shot-img{display:block;width:100%;background:#fff}

/* ---------- generic placeholder visual ---------- */
.ph{
  position:relative;border-radius:var(--radius-sm);overflow:hidden;
  background:
    repeating-linear-gradient(135deg,
      color-mix(in oklab,var(--ink) 5%,var(--bg-2)) 0 14px,
      color-mix(in oklab,var(--ink) 8%,var(--bg-2)) 14px 28px);
  border:1px dashed var(--line);
  display:grid;place-items:center;min-height:280px;
}
.ph .ph-label{
  font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;
  color:var(--ink-faint);background:var(--surface);
  padding:8px 14px;border-radius:999px;border:1px solid var(--line);
  text-align:center;max-width:80%;
}

/* ---------- marquee ---------- */
.marquee{
  border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  background:var(--bg-2);padding:20px 0;overflow:hidden;white-space:nowrap;
}
.marquee-track{display:inline-flex;gap:0;animation:scroll 36s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{display:inline-flex;align-items:center;gap:18px;padding:0 26px;font-family:var(--font-display);font-size:24px;font-style:italic;color:var(--ink-soft)}
.marquee-item::after{content:"✦";color:var(--gold-deep);font-style:normal;font-size:13px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- The Cycle ---------- */
.cycle-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:54px;position:relative;
}
.cycle-step{
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:24px 18px;text-align:center;position:relative;box-shadow:var(--shadow-sm);
}
.cycle-step .num{
  font-family:var(--font-mono);font-size:11px;color:var(--gold-deep);letter-spacing:.1em;
}
.cycle-step h4{font-size:21px;margin:10px 0 6px}
.cycle-step p{font-size:14px;color:var(--ink-soft);line-height:1.5}
.cycle-step .arrow{
  position:absolute;right:-13px;top:50%;transform:translateY(-50%);z-index:2;
  width:22px;height:22px;color:var(--gold-deep);
}
.cycle-loop{
  margin-top:26px;text-align:center;
  font-family:var(--font-display);font-style:italic;font-size:22px;color:var(--ink-soft);
}
.cycle-loop b{color:var(--gold-deep);font-style:normal;font-weight:600}

/* ---------- Manifesto ---------- */
.manifesto{text-align:center}
.manifesto .big{
  font-family:var(--font-display);font-size:clamp(30px,4.6vw,54px);font-weight:600;
  line-height:1.16;max-width:20ch;margin:24px auto 0;letter-spacing:-.01em;
}
.manifesto .big .hl{
  background:linear-gradient(180deg,transparent 60%,color-mix(in oklab,var(--gold) 45%,transparent) 60%);
}
.manifesto .sub{margin:30px auto 0;max-width:54ch;font-size:19px;color:var(--ink-soft)}

/* ---------- Story ---------- */
.story-grid{display:grid;grid-template-columns:0.92fr 1.08fr;gap:64px;align-items:center}
.story-portrait{position:relative}
.story-portrait .ph{min-height:440px;border-radius:var(--radius)}
.story-img{width:100%;display:block;aspect-ratio:1/1;object-fit:cover;object-position:center top;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow), inset 0 0 0 1px color-mix(in oklab,var(--gold) 30%,transparent)}
.story-portrait .badge{
  position:absolute;left:-18px;bottom:24px;background:var(--surface);
  border:1px solid var(--line);border-radius:14px;padding:16px 20px;box-shadow:var(--shadow);
  display:flex;align-items:center;gap:14px;
}
.story-portrait .badge .n{font-family:var(--font-display);font-size:34px;font-weight:600;color:var(--gold-deep);line-height:1}
.story-portrait .badge .t{font-size:13px;color:var(--ink-soft);line-height:1.3;max-width:13ch}
.story-body h2{font-size:clamp(32px,4vw,48px);margin:18px 0 0}
.story-body p{margin-top:20px;color:var(--ink-soft);font-size:18px}
.story-body p strong{color:var(--ink);font-weight:600}
.signature{margin-top:30px;display:flex;align-items:center;gap:14px}
.signature .sig-name{font-family:var(--font-display);font-style:italic;font-size:26px;color:var(--ink)}
.signature .sig-role{font-size:13px;color:var(--ink-faint);font-family:var(--font-mono);letter-spacing:.04em}

/* ---------- Stats ---------- */
.stats{background:var(--medallion);color:oklch(0.94 0.012 85)}
.stats .stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.stat{text-align:center;padding:10px}
.stat .v{font-family:var(--font-display);font-size:clamp(42px,5vw,62px);font-weight:600;color:var(--gold);line-height:1}
.stat .l{margin-top:10px;font-size:14.5px;color:oklch(0.78 0.02 82);letter-spacing:.01em}
.stats .stat + .stat{border-left:1px solid color-mix(in oklab,var(--gold) 22%,transparent)}

/* ---------- Editions toggle ---------- */
.editions{text-align:center}
.seg{
  display:inline-flex;padding:5px;border-radius:999px;background:var(--bg-2);
  border:1px solid var(--line);margin-top:30px;position:relative;gap:4px;
}
.seg button{
  position:relative;z-index:2;border:0;background:transparent;cursor:pointer;
  padding:12px 30px;border-radius:999px;font-weight:600;font-size:15.5px;color:var(--ink-soft);
  transition:color .3s;display:flex;align-items:center;gap:9px;
}
.seg button svg{width:18px;height:18px}
.seg button.active{color:oklch(0.22 0.02 60)}
.seg-thumb{
  position:absolute;top:5px;bottom:5px;border-radius:999px;
  background:linear-gradient(180deg,var(--gold) 0%, var(--gold-deep) 140%);
  box-shadow:0 6px 16px -6px var(--gold-deep);
  transition:left .35s cubic-bezier(.4,.8,.3,1), width .35s cubic-bezier(.4,.8,.3,1);
  z-index:1;
}
.edition-note{margin-top:18px;font-family:var(--font-mono);font-size:12.5px;color:var(--ink-faint);letter-spacing:.04em}
.edition-note b{color:var(--gold-deep)}

/* ---------- Features (alternating) ---------- */
.feat{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.feat + .feat{margin-top:104px}
.feat.flip .feat-text{order:2}
.feat-text .num{font-family:var(--font-mono);font-size:12px;color:var(--gold-deep);letter-spacing:.14em}
.feat-text h3{font-size:clamp(28px,3.4vw,42px);margin:14px 0 0}
.feat-text p{margin-top:18px;color:var(--ink-soft);font-size:18px}
.feat-list{margin-top:22px;display:flex;flex-direction:column;gap:12px}
.feat-list li{display:flex;gap:12px;align-items:flex-start;font-size:16px;color:var(--ink-soft);list-style:none}
.feat-list{padding:0;margin-left:0}
.feat-list .tick{flex:none;width:22px;height:22px;border-radius:50%;background:color-mix(in oklab,var(--gold) 22%,var(--surface));display:grid;place-items:center;margin-top:1px}
.feat-list .tick svg{width:12px;height:12px;color:var(--gold-deep)}
.feat-visual .ph{min-height:380px}
.feat-tag{display:inline-flex;align-items:center;gap:7px;padding:6px 13px;border-radius:999px;background:color-mix(in oklab,var(--accent2) 55%,var(--surface));color:var(--accent2-ink);font-size:12px;font-weight:600;font-family:var(--font-mono);letter-spacing:.04em;margin-bottom:14px;text-transform:uppercase}

/* ---------- Feature grid (smaller) ---------- */
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:54px}
.fcard{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 28px;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s,border-color .3s;
}
.fcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:color-mix(in oklab,var(--gold) 40%,var(--line))}
.fcard .ic{
  width:46px;height:46px;border-radius:12px;display:grid;place-items:center;margin-bottom:18px;
  background:color-mix(in oklab,var(--gold) 16%,var(--surface));border:1px solid color-mix(in oklab,var(--gold) 30%,transparent);
}
.fcard .ic svg{width:22px;height:22px;color:var(--gold-deep)}
.fcard h4{font-size:23px;margin-bottom:8px}
.fcard p{font-size:15px;color:var(--ink-soft);line-height:1.55}
.fcard.span2{grid-column:span 2}
.fcard .edition-pill{display:inline-block;margin-top:14px;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-deep);border:1px solid var(--line);border-radius:999px;padding:3px 10px}
.bonus-list{margin:14px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:8px}
.bonus-list li{list-style:none;font-size:13.5px;color:var(--ink-soft);background:var(--bg-2);border:1px solid var(--line-soft);border-radius:8px;padding:6px 12px}

/* ---------- Bonus Toolkit gallery ---------- */
.bonus-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.bonus-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s,border-color .3s}
.bonus-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:color-mix(in oklab,var(--gold) 40%,var(--line))}
.bonus-shot{position:relative;border-bottom:1px solid var(--line-soft);background:var(--bg-2)}
.bonus-shot .shot-bar{padding:10px 13px;border-bottom:1px solid var(--line-soft)}
.bonus-shot img{display:block;width:100%;height:208px;object-fit:cover;object-position:top left;background:#fff}
.bonus-body{padding:22px 24px 26px}
.bonus-body h4{font-size:23px;margin-bottom:8px}
.bonus-body p{font-size:14.5px;color:var(--ink-soft);line-height:1.55}

/* ---------- Philosophy ---------- */
.philo{background:var(--bg-2)}
.philo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.philo-card{padding:30px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.philo-card .mk{font-family:var(--font-display);font-size:40px;color:var(--gold-deep);line-height:.6}
.philo-card h4{font-size:24px;margin:16px 0 8px}
.philo-card p{font-size:15.5px;color:var(--ink-soft)}

/* ---------- Testimonials ---------- */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:54px}
.tcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.tcard .qmark{font-family:var(--font-display);font-size:54px;color:var(--gold-soft);line-height:.4;height:24px}
.tcard blockquote{margin:0;font-size:17px;line-height:1.6;color:var(--ink);font-family:var(--font-display);font-style:italic;font-weight:500;flex:1}
.tcard .who{display:flex;align-items:center;gap:12px;margin-top:22px;padding-top:18px;border-top:1px solid var(--line-soft)}
.tcard .who .av{width:40px;height:40px;border-radius:50%;background:var(--bg-2);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--font-mono);font-size:11px;color:var(--ink-faint)}
.tcard .who .nm{font-weight:600;font-size:15px}
.tcard .who .rl{font-size:12.5px;color:var(--ink-faint)}
.placeholder-note{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);background:var(--bg-2);border:1px dashed var(--line);border-radius:999px;padding:7px 14px}

/* ---------- Pricing ---------- */
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:54px;max-width:920px;margin-left:auto;margin-right:auto}
.pcard{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:38px 34px;box-shadow:var(--shadow-sm);position:relative;display:flex;flex-direction:column;
}
.pcard.featured{border-color:color-mix(in oklab,var(--gold) 55%,var(--line));box-shadow:0 0 0 1px color-mix(in oklab,var(--gold) 35%,transparent),var(--shadow)}
.pcard .ribbon{position:absolute;top:-13px;left:34px;background:linear-gradient(180deg,var(--gold),var(--gold-deep));color:oklch(0.22 0.02 60);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding:6px 14px;border-radius:999px;box-shadow:0 6px 16px -6px var(--gold-deep)}
.pcard h3{font-size:27px}
.pcard .pdesc{font-size:14.5px;color:var(--ink-soft);margin-top:6px;min-height:42px}
.price-row{display:flex;align-items:baseline;gap:12px;margin:22px 0 4px}
.price-now{font-family:var(--font-display);font-size:52px;font-weight:600;line-height:1}
.price-was{font-size:21px;color:var(--ink-faint);text-decoration:line-through;font-family:var(--font-display)}
.price-meta{font-size:13px;color:var(--ink-faint);font-family:var(--font-mono);letter-spacing:.03em}
.incl{list-style:none;padding:0;margin:24px 0;display:flex;flex-direction:column;gap:12px;flex:1}
.incl li{display:flex;gap:11px;align-items:flex-start;font-size:15px;color:var(--ink-soft)}
.incl .tick{flex:none;width:20px;height:20px;border-radius:50%;background:color-mix(in oklab,var(--gold) 20%,var(--surface));display:grid;place-items:center;margin-top:2px}
.incl .tick svg{width:11px;height:11px;color:var(--gold-deep)}
.price-guarantee{text-align:center;margin-top:26px;font-size:14px;color:var(--ink-faint)}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:760px;margin:54px auto 0}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{
  width:100%;text-align:left;background:none;border:0;cursor:pointer;
  padding:24px 4px;display:flex;align-items:center;justify-content:space-between;gap:20px;
  font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--ink);
}
.faq-q .pm{flex:none;width:26px;height:26px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:transform .3s,background .3s,border-color .3s;color:var(--gold-deep)}
.faq-item.open .faq-q .pm{transform:rotate(45deg);background:var(--gold-deep);color:var(--bg);border-color:var(--gold-deep)}
.faq-q .pm svg{width:13px;height:13px}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a-inner{padding:0 4px 26px;color:var(--ink-soft);font-size:16.5px;line-height:1.6;max-width:62ch}

/* ---------- Final CTA ---------- */
.final{text-align:center;background:var(--medallion);color:oklch(0.95 0.012 85);position:relative;overflow:hidden}
.final .hero-glow{opacity:.4}
.final .medallion{box-shadow:inset 0 0 0 1.5px color-mix(in oklab,var(--gold) 55%,transparent),0 0 0 8px color-mix(in oklab,var(--gold) 10%,transparent),0 22px 50px -18px rgba(0,0,0,.6)}
.final h2{font-size:clamp(38px,6vw,72px);margin:24px auto 0;max-width:16ch}
.final h2 em{font-style:italic;color:var(--gold)}
.final p{margin:22px auto 0;max-width:48ch;color:oklch(0.8 0.02 82);font-size:19px}
.final .hero-cta{margin-top:36px}
.final .btn-ghost{color:oklch(0.92 0.012 85);border-color:color-mix(in oklab,var(--gold) 30%,transparent)}
.final .btn-ghost:hover{border-color:var(--gold)}

/* ---------- Footer ---------- */
.footer{background:var(--bg-2);border-top:1px solid var(--line);padding:64px 0 36px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px}
.footer .brand{margin-bottom:16px}
.footer-blurb{color:var(--ink-soft);font-size:15px;max-width:36ch}
.footer h5{font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin:0 0 16px;font-weight:600}
.footer-col a{display:block;color:var(--ink-soft);font-size:15px;margin-bottom:11px;transition:color .2s}
.footer-col a:hover{color:var(--gold-deep)}
.footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;font-size:13.5px;color:var(--ink-faint)}
.footer-bottom .socials{display:flex;gap:16px}
.footer-bottom .socials a{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);color:var(--ink-soft);transition:.2s}
.footer-bottom .socials a:hover{border-color:var(--gold-deep);color:var(--gold-deep);transform:translateY(-2px)}
.footer-bottom .socials svg{width:17px;height:17px}

/* ---------- Section headers ---------- */
.sec-head{text-align:center;max-width:42ch;margin:0 auto}
.sec-head h2{font-size:clamp(32px,4.4vw,52px);margin:18px 0 0}
.sec-head p{margin-top:18px;color:var(--ink-soft);font-size:19px}

/* ---------- Reveal animation ---------- */
/* Default = VISIBLE. Hidden only when JS adds .cc-anim to <html>, so a JS or
   transition failure (throttled/offscreen tabs, exports) can never leave
   content stuck invisible. */
.reveal{transition:opacity .65s cubic-bezier(.2,.7,.3,1),transform .65s cubic-bezier(.2,.7,.3,1)}
html.cc-anim .reveal:not(.in){opacity:0;transform:translateY(26px)}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .medallion::after,.presale-chip .dot,.marquee-track{animation:none}
  html{scroll-behavior:auto}
}
/* Never let an export/print frame catch a mid-transition (invisible) reveal */
@media print{
  .reveal{opacity:1 !important;transform:none !important}
}

/* ---------- Edition visibility ---------- */
[data-edition="streamer"] .only-youtuber{display:none}
[data-edition="youtuber"] .only-streamer{display:none}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .story-grid,.feat,.feat.flip .feat-text{grid-template-columns:1fr}
  .feat.flip .feat-text{order:0}
  .feat + .feat{margin-top:72px}
  .feat-visual{order:-1}
  .fgrid,.philo-grid,.tgrid{grid-template-columns:1fr 1fr}
  .cycle-grid{grid-template-columns:1fr 1fr}
  .cycle-step .arrow{display:none}
  .stats .stat-grid{grid-template-columns:1fr 1fr;gap:0}
  .stats .stat{padding:24px}
  .stats .stat:nth-child(odd){border-left:0}
  .stats .stat:nth-child(n+3){border-top:1px solid color-mix(in oklab,var(--gold) 22%,transparent)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .bonus-gallery{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  body{font-size:16.5px}
  .section{padding:76px 0}
  .nav-links{display:none}
  .nav-links.open{
    display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:var(--bg);border-bottom:1px solid var(--line);padding:18px 28px 24px;gap:18px;
  }
  .nav-toggle{display:grid;place-items:center;width:42px;height:42px;border-radius:10px;border:1px solid var(--line);background:var(--surface);cursor:pointer}
  .nav-toggle svg{width:20px;height:20px;color:var(--ink)}
  .nav .nav-cta .btn:not(.nav-toggle){display:none}
  .fgrid,.philo-grid,.tgrid,.price-grid{grid-template-columns:1fr}
  .cycle-grid{grid-template-columns:1fr}
  .fcard.span2{grid-column:span 1}
  .hero{padding:128px 0 70px}
  .footer-grid{grid-template-columns:1fr}
  .seg button{padding:11px 20px;font-size:14px}
  .section{padding:64px 0}
  .bonus-gallery{grid-template-columns:1fr;gap:16px}
  .bonus-shot img{height:180px}
  .bonus-body{padding:16px 18px 20px}
  .bonus-body h4{font-size:18px}
}

/* hide tweaks root until react mounts */
#tweaks-root:empty{display:none}
