:root{
  --accent:#F5A623;
  --accent2:#E8596E;
  --accent3:#5B8DEF;
  --bg:#050508;
  --text:#f0f0f5;
  --text2:rgba(255,255,255,0.62);
  --border:rgba(255,255,255,0.07);
  --glass:rgba(255,255,255,0.04);
  --g-action:#e74c3c;
  --g-drama:#e85d75;
  --g-horror:#9b59b6;
  --g-scifi:#5b8def;
}
*{box-sizing:border-box;margin:0;padding:0}
*:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:inherit}
html,body{background:var(--bg);color:var(--text);font-family:'Sora',sans-serif;font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden}
/* Honor reduced-motion for the marquee/carousel animations. */
@media (prefers-reduced-motion: reduce){
  .mega-wall .col,.carousel{animation:none!important}
  .reveal{opacity:1!important;transform:none!important}
}
body{line-height:1.5}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.serif{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400}
.container{max-width:1280px;margin:0 auto;padding:0 28px;position:relative}
section{position:relative;padding:140px 0}

/* logo */
.logo{font-family:'Sora',sans-serif;font-weight:800;letter-spacing:-.04em;font-size:28px;color:#fff;display:inline-flex}
.logo .a{color:var(--accent);position:relative}
.logo .a::after{content:"";position:absolute;left:0;right:0;bottom:4px;height:2px;background:var(--accent);box-shadow:0 0 14px var(--accent),0 0 28px rgba(245,166,35,.6);border-radius:2px}

/* nav */
nav.top{position:fixed;top:0;left:0;right:0;z-index:100;padding:22px 0;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:rgba(5,5,8,.55);border-bottom:1px solid var(--border)}
nav.top .inner{display:flex;align-items:center;justify-content:space-between}
nav.top .links{display:flex;gap:32px;font-size:14px;color:var(--text2)}
nav.top .links a:hover{color:var(--text)}
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border-radius:999px;font-weight:600;font-size:14px;letter-spacing:.01em;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}
.btn.primary{background:var(--accent);color:#0a0a0f;box-shadow:0 10px 40px rgba(245,166,35,.35)}
.btn.primary:hover{transform:translateY(-2px);box-shadow:0 16px 56px rgba(245,166,35,.5)}
.btn.ghost{background:var(--glass);border:1px solid var(--border);backdrop-filter:blur(20px)}
.btn.ghost:hover{background:rgba(255,255,255,.08)}

/* ========= MEGA HERO POSTER WALL ========= */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:200px 0 160px;position:relative;text-align:center;overflow:hidden}
.mega-wall{position:absolute;inset:0;overflow:hidden;z-index:1;pointer-events:none}
.mega-wall .col{position:absolute;top:-10%;width:12.5%;height:140%;display:flex;flex-direction:column;gap:14px;will-change:transform}
.mega-wall .col img{width:100%;aspect-ratio:2/3;object-fit:cover;border-radius:12px;box-shadow:0 30px 60px rgba(0,0,0,.45)}
.mega-wall .col:nth-child(1){left:0%;animation:scrollUp 70s linear infinite}
.mega-wall .col:nth-child(2){left:12.5%;animation:scrollDown 88s linear infinite}
.mega-wall .col:nth-child(3){left:25%;animation:scrollUp 62s linear infinite}
.mega-wall .col:nth-child(4){left:37.5%;animation:scrollDown 76s linear infinite}
.mega-wall .col:nth-child(5){left:50%;animation:scrollUp 82s linear infinite}
.mega-wall .col:nth-child(6){left:62.5%;animation:scrollDown 68s linear infinite}
.mega-wall .col:nth-child(7){left:75%;animation:scrollUp 94s linear infinite}
.mega-wall .col:nth-child(8){left:87.5%;animation:scrollDown 72s linear infinite}
.mega-wall::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 46% 42% at center,rgba(5,5,8,.96) 0%,rgba(5,5,8,.9) 25%,rgba(5,5,8,.55) 52%,rgba(5,5,8,0) 82%);z-index:2;pointer-events:none}
.mega-wall::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,8,.7) 0%,transparent 10%,transparent 85%,#050508 100%);z-index:3;pointer-events:none}
@keyframes scrollUp{0%{transform:translateY(0)}100%{transform:translateY(-50%)}}
@keyframes scrollDown{0%{transform:translateY(-50%)}100%{transform:translateY(0)}}

.hero .inner{position:relative;z-index:5;max-width:960px;margin:0 auto;padding:0 28px}
.badge{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;border-radius:999px;background:rgba(5,5,8,.6);border:1px solid var(--border);backdrop-filter:blur(20px);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--text2)}
.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 rgba(245,166,35,.7);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(245,166,35,.7)}70%{box-shadow:0 0 0 12px rgba(245,166,35,0)}100%{box-shadow:0 0 0 0 rgba(245,166,35,0)}}
h1.hero-title{font-size:clamp(88px,14vw,220px);font-weight:800;letter-spacing:-.055em;line-height:.85;margin:28px 0 30px;text-shadow:0 10px 60px rgba(0,0,0,.6)}
h1.hero-title .a{color:var(--accent);position:relative}
h1.hero-title .a::after{content:"";position:absolute;left:4%;right:4%;bottom:22px;height:8px;background:var(--accent);box-shadow:0 0 40px var(--accent),0 0 80px rgba(245,166,35,.6);border-radius:8px}
.hero .sub{font-size:22px;color:rgba(255,255,255,.75);max-width:640px;margin:0 auto 44px;line-height:1.5;text-shadow:0 4px 20px rgba(0,0,0,.5)}
.hero .sub em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--text);font-weight:400}
.hero .sub strong{color:var(--accent);font-weight:600}
/* Kind pills — three glassmorphism chips below the hero subtitle
   that surface Movies / TV / Books at a glance. Calls out launch
   parity across the three kinds without forcing the user to read
   the subtitle. */
.kind-pills{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:0 auto 36px;max-width:560px}
.kind-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);font-size:14px;font-weight:600;letter-spacing:.01em;color:var(--text);text-shadow:0 2px 12px rgba(0,0,0,.4)}
.kind-pill .kind-emoji{font-size:16px;line-height:1}
.hero .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ambient poster wall (other sections) */
.poster-wall{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none}
.poster-wall .grid{position:absolute;inset:-40px;display:grid;grid-template-columns:repeat(10,1fr);gap:10px;opacity:.14;filter:blur(.5px)}
.poster-wall .grid img{width:100%;aspect-ratio:2/3;object-fit:cover;border-radius:8px}
.poster-wall .overlay{position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(5,5,8,.55) 0%,rgba(5,5,8,.88) 55%,#050508 100%)}

/* section header */
.sec-head{text-align:center;max-width:760px;margin:0 auto 70px;position:relative;z-index:2}
.sec-head .eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:18px}
.sec-head h2{font-size:clamp(42px,5.5vw,72px);font-weight:800;letter-spacing:-.035em;line-height:1;margin-bottom:22px}
.sec-head h2 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--accent)}
.sec-head p{font-size:18px;color:var(--text2);line-height:1.55}

/* kinds — three big gradient cards introducing Movies / TV / Books */
.kinds-section{padding:140px 0;position:relative}
.kind-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;max-width:1200px;margin:0 auto}
@media (max-width:980px){.kind-grid{grid-template-columns:1fr}}
.kind-card{position:relative;overflow:hidden;border-radius:28px;padding:38px 32px 32px;color:#fff;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;box-shadow:0 24px 48px -12px rgba(0,0,0,.5),0 0 0 .5px rgba(255,255,255,.08),inset 0 1px 0 rgba(255,255,255,.3);transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s ease}
.kind-card:hover{transform:translateY(-6px);box-shadow:0 36px 60px -12px rgba(0,0,0,.6),0 0 0 .5px rgba(255,255,255,.12),inset 0 1px 0 rgba(255,255,255,.36)}
.kind-card-watermark{position:absolute;top:-15%;right:-15%;font-size:280px;line-height:1;opacity:.12;transform:rotate(-12deg);pointer-events:none;user-select:none}
.kind-card-meta{position:absolute;top:24px;left:32px;font-size:11px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;opacity:.85}
.kind-card h3{font-size:42px;font-weight:900;letter-spacing:-.025em;line-height:.95;margin-bottom:14px}
.kind-card p{font-size:15px;color:rgba(255,255,255,.85);line-height:1.5;margin-bottom:18px}
.kind-card-stat{font-size:12px;font-weight:700;letter-spacing:.6px;color:rgba(255,255,255,.65);padding-top:14px;border-top:0.5px solid rgba(255,255,255,.18)}
.kind-movies{background:linear-gradient(160deg,#FF5A2A 0%,#FF3D6E 100%)}
.kind-tv{background:linear-gradient(160deg,#6E5BFF 0%,#3D2DC8 100%)}
.kind-books{background:linear-gradient(160deg,#1FCFA0 0%,#0E9F7E 100%)}

/* problem */
.problem .duel{display:flex;align-items:center;justify-content:center;gap:30px;flex-wrap:wrap;position:relative;z-index:2;margin-bottom:48px}
.problem .card{background:var(--glass);border:1px solid var(--border);backdrop-filter:blur(30px);border-radius:26px;padding:24px;width:260px;text-align:center}
.problem .card img{width:100%;aspect-ratio:2/3;object-fit:cover;border-radius:14px;margin-bottom:18px;box-shadow:0 30px 60px rgba(0,0,0,.6)}
.problem .card .t{font-size:18px;font-weight:700;margin-bottom:4px}
.problem .card .y{font-size:12px;color:var(--text2);margin-bottom:12px}
.problem .card .stars{color:var(--accent);font-size:22px;letter-spacing:2px}
.problem .eq{font-size:90px;font-weight:300;color:var(--accent2);line-height:1}
.problem .verdict{text-align:center;font-size:26px;font-weight:500;color:var(--text)}
.problem .verdict em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--accent2)}

/* vs */
.vs-stage{position:relative;perspective:1600px;padding:0 20px}
.vs-row{display:flex;align-items:center;justify-content:center;gap:50px;flex-wrap:wrap;position:relative;z-index:2}
.vs-card{width:340px;background:var(--glass);border:1px solid var(--border);border-radius:30px;padding:22px;backdrop-filter:blur(30px);transform-style:preserve-3d;transition:transform .5s cubic-bezier(.2,.8,.2,1),box-shadow .5s ease;cursor:pointer;position:relative}
.vs-card img{width:100%;aspect-ratio:2/3;object-fit:cover;border-radius:18px;box-shadow:0 40px 80px rgba(0,0,0,.7);transform:translateZ(40px);transition:transform .5s ease}
.vs-card .cap{margin-top:20px;text-align:center}
.vs-card .cap .t{font-size:22px;font-weight:700;letter-spacing:-.02em}
.vs-card .cap .y{font-size:13px;color:var(--text2);margin-top:4px}
.vs-card:hover{transform:rotateY(-8deg) translateZ(20px);box-shadow:0 60px 120px rgba(245,166,35,.15)}
.vs-card.right:hover{transform:rotateY(8deg) translateZ(20px)}
.vs-card:hover img{transform:translateZ(80px)}
.vs-card.chosen{transform:scale(1.06);box-shadow:0 60px 120px rgba(245,166,35,.35)}
.vs-card.faded{opacity:.3;transform:scale(.92)}
.vs-label{font-size:84px;font-weight:800;color:var(--accent);letter-spacing:-.04em;text-shadow:0 0 60px rgba(245,166,35,.5)}
.vs-prompt{text-align:center;font-size:34px;margin-top:54px;color:var(--text2)}
.vs-prompt em{color:var(--text)}
.vs-hint{text-align:center;margin-top:12px;font-size:13px;color:var(--text2);letter-spacing:.08em;text-transform:uppercase}

/* ranked list */
.ylist{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:start;position:relative;z-index:2}
.list-card{background:var(--glass);border:1px solid var(--border);border-radius:26px;backdrop-filter:blur(30px);padding:26px}
.list-card h3{font-size:22px;margin-bottom:18px;font-weight:700}
.list-card h3 small{display:block;font-size:12px;color:var(--text2);font-weight:400;margin-top:4px}
.list-row{display:flex;align-items:center;gap:16px;padding:12px;border-radius:16px;transition:background .2s ease}
.list-row+.list-row{margin-top:6px}
.list-row:hover{background:rgba(255,255,255,.03)}
.list-row .rk{width:38px;text-align:center;font-weight:800;font-size:22px;color:var(--text2)}
.list-row.r1 .rk{color:var(--accent);text-shadow:0 0 20px rgba(245,166,35,.5)}
.list-row.r2 .rk{color:#c9c9d4}
.list-row.r3 .rk{color:#cd7f32}
.list-row img{width:56px;height:84px;object-fit:cover;border-radius:7px;box-shadow:0 14px 28px rgba(0,0,0,.6)}
.list-row .meta{flex:1;min-width:0}
.list-row .meta .t{font-size:15px;font-weight:600;letter-spacing:-.01em}
.list-row .meta .y{font-size:12px;color:var(--text2);margin-top:2px;display:flex;gap:8px;align-items:center}
.list-row .meta .gb{display:inline-block;padding:2px 8px;border-radius:999px;background:rgba(91,141,239,.12);color:#8fb0f0;font-size:10px;font-weight:600}
.list-row .sc{display:none}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.chip{padding:8px 14px;border-radius:999px;background:var(--glass);border:1px solid var(--border);font-size:12px;color:var(--text2);cursor:pointer;transition:all .2s ease}
.chip:hover,.chip.on{background:rgba(245,166,35,.14);color:var(--accent);border-color:rgba(245,166,35,.3)}
.ylist .explainer h3{font-size:34px;font-weight:800;letter-spacing:-.02em;margin-bottom:18px;line-height:1.1}
.ylist .explainer h3 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--accent)}
.ylist .explainer p{color:var(--text2);font-size:17px;margin-bottom:14px;line-height:1.6}

/* carousel */
.carousel-sec{overflow:hidden}
.carousel{display:flex;gap:18px;animation:slide 80s linear infinite;width:max-content;padding:10px 0}
.carousel:hover{animation-play-state:paused}
.carousel .p{position:relative;width:200px;aspect-ratio:2/3;border-radius:14px;overflow:hidden;flex-shrink:0;box-shadow:0 30px 60px rgba(0,0,0,.5);transition:transform .3s ease}
.carousel .p:hover{transform:translateY(-12px) scale(1.04)}
.carousel .p img{width:100%;height:100%;object-fit:cover}
.carousel .p .score{position:absolute;top:10px;right:10px;width:40px;height:40px;border-radius:50%;background:rgba(245,166,35,.95);color:#0a0a0f;font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px rgba(245,166,35,.5);opacity:0;transform:translateY(-6px);transition:all .3s ease}
.carousel .p:hover .score{opacity:1;transform:translateY(0)}
@keyframes slide{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* social */
.social-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;position:relative;z-index:2}
.feed{background:var(--glass);border:1px solid var(--border);border-radius:26px;backdrop-filter:blur(30px);padding:28px}
.feed h3{font-size:20px;font-weight:700;margin-bottom:22px}
.feed-item{display:flex;gap:18px;padding:16px;border-radius:18px;transition:background .2s ease}
.feed-item+.feed-item{margin-top:8px}
.feed-item:hover{background:rgba(255,255,255,.03)}
.feed-item img.p{width:72px;height:108px;object-fit:cover;border-radius:10px;box-shadow:0 20px 40px rgba(0,0,0,.6);flex-shrink:0}
.feed-item .txt{display:flex;flex-direction:column;justify-content:center;flex:1}
.feed-item .avs{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.feed-item .av{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#0a0a0f}
.feed-item .who{font-size:13px;color:var(--text2)}
.feed-item .main{font-size:17px;font-weight:600;letter-spacing:-.01em;line-height:1.35}
.feed-item .main .rk{color:var(--accent);font-weight:800}
.feed-item .tag{display:inline-block;margin-top:8px;padding:4px 10px;border-radius:999px;background:rgba(232,89,110,.12);color:#f28a9b;font-size:11px;font-weight:600}
.taste{background:var(--glass);border:1px solid var(--border);border-radius:26px;backdrop-filter:blur(30px);padding:28px}
.taste h3{font-size:20px;font-weight:700;margin-bottom:6px}
.taste p{font-size:13px;color:var(--text2);margin-bottom:22px}
.match{display:flex;align-items:center;gap:14px;padding:14px;border-radius:16px;background:rgba(255,255,255,.02);margin-bottom:10px;border:1px solid var(--border)}
.match .av{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#0a0a0f}
.match .av.a1{background:linear-gradient(135deg,#F5A623,#E8596E)}
.match .av.a2{background:linear-gradient(135deg,#5B8DEF,#9b59b6)}
.match .av.a3{background:linear-gradient(135deg,#E8596E,#F5A623)}
.match .n{flex:1;font-size:15px;font-weight:600}
.match .pct{font-size:20px;font-weight:800;color:var(--accent);letter-spacing:-.02em}
.match .bar{width:100%;height:4px;border-radius:4px;background:rgba(255,255,255,.06);margin-top:6px;overflow:hidden}
.match .bar span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2))}

/* recap */
.recap-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center;position:relative;z-index:2}
.recap-card{max-width:360px;aspect-ratio:9/16;margin:0 auto;border-radius:28px;padding:30px;background:linear-gradient(180deg,#0e0e18 0%,#1a0a16 45%,#2a1508 100%);position:relative;overflow:hidden;box-shadow:0 60px 120px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.08)}
.recap-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(245,166,35,.2),transparent 60%);pointer-events:none}
.recap-card .hdr{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--text2);margin-bottom:8px}
.recap-card h3{font-size:26px;font-weight:800;letter-spacing:-.02em}
.recap-card .big{font-size:120px;font-weight:800;line-height:.9;letter-spacing:-.06em;margin:26px 0 4px;background:linear-gradient(180deg,#fff,var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}
.recap-card .big-lbl{font-size:13px;color:var(--text2);margin-bottom:22px}
.recap-card .top3{display:flex;gap:8px;margin-bottom:22px}
.recap-card .top3 img{width:33%;aspect-ratio:2/3;object-fit:cover;border-radius:10px;box-shadow:0 20px 40px rgba(0,0,0,.6)}
.recap-card .top3 img:nth-child(1){transform:translateY(-8px);box-shadow:0 20px 40px rgba(245,166,35,.35)}
.recap-card .no1{font-size:15px;font-weight:600;margin-bottom:4px}
.recap-card .no1 .k{color:var(--accent);font-weight:800}
.recap-card .persona{font-size:13px;color:var(--text2);margin-bottom:22px}
.recap-card .share{display:block;width:100%;padding:14px;border-radius:14px;background:var(--accent);color:#0a0a0f;font-weight:700;font-size:14px;text-align:center}
.recap-wrap .explainer h3{font-size:40px;font-weight:800;letter-spacing:-.03em;margin-bottom:18px;line-height:1.05}
.recap-wrap .explainer h3 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--accent)}
.recap-wrap .explainer p{color:var(--text2);font-size:17px;line-height:1.65;margin-bottom:14px}

/* watch time */
#watch-time{padding:40px 0}
.wt-wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center;max-width:1000px;margin:0 auto;background:var(--glass);border:1px solid var(--border);border-radius:28px;padding:46px;backdrop-filter:blur(20px);position:relative;z-index:2}
@media(max-width:820px){.wt-wrap{grid-template-columns:1fr;gap:32px;padding:34px;text-align:center}}
.wt-total{text-align:center}
.wt-big{font-size:96px;font-weight:900;line-height:.9;letter-spacing:-.05em;background:linear-gradient(180deg,#fff,var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}
.wt-lbl{font-size:15px;color:var(--text);font-weight:600;margin-top:8px}
.wt-sub{font-size:13px;color:var(--text2);margin-top:6px}
.wt-bars{display:flex;flex-direction:column;gap:20px}
.wt-bar{display:grid;grid-template-columns:104px 1fr 66px;align-items:center;gap:14px}
@media(max-width:820px){.wt-bar{grid-template-columns:90px 1fr 60px}}
.wt-k{font-size:14px;font-weight:600;color:var(--text);text-align:left}
.wt-track{height:12px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden}
.wt-track i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.wt-v{font-size:14px;font-weight:700;color:var(--text2);text-align:right}

/* AI recommendations */
.ai-wrap{display:grid;grid-template-columns:1.15fr 1fr;gap:60px;align-items:center;position:relative;z-index:2}
.ai-stack{display:flex;flex-direction:column;gap:18px;min-width:0}
/* min-width:0 lets the card shrink below the rail's content width so
   .ai-rail's overflow-x:auto actually scrolls on mobile instead of the
   poster tiles spilling past the card's right edge. */
.ai-card{padding:24px;border-radius:24px;background:linear-gradient(180deg,#0f0f1c 0%,#171729 60%,#0e0e18 100%);border:1px solid rgba(245,166,35,.18);box-shadow:0 40px 80px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.04) inset;min-width:0}
/* Three stacked rails (Movies / TV / Books) need slightly tighter
 * card padding so they fit comfortably on the page without the
 * column stretching past viewport height. */
.ai-stack .ai-card{padding:18px 20px}
.ai-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px}
.ai-eyebrow{font-size:13px;font-weight:800;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:8px;color:#fff}
.ai-spark{color:var(--accent);font-size:18px;line-height:1}
.ai-count{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text2)}
.ai-rail{display:flex;gap:10px;overflow-x:auto;padding-bottom:10px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.ai-rail::-webkit-scrollbar{height:6px}
.ai-rail::-webkit-scrollbar-thumb{background:rgba(245,166,35,.4);border-radius:3px}
.ai-tile{flex:0 0 96px;aspect-ratio:2/3;border-radius:10px;background:#1a1a26 center/cover no-repeat;box-shadow:0 12px 28px rgba(0,0,0,.4);scroll-snap-align:start;transition:transform .3s cubic-bezier(.2,.8,.2,1)}
.ai-tile:hover{transform:translateY(-4px) scale(1.03)}
/* Book covers from Open Library — their CDN returns oversized
 * portraits and the OG `cover` sizing crops the spine text. Use
 * `contain` + a soft paper background so the cover sits whole in
 * a slightly taller frame. */
.ai-tile.book{aspect-ratio:2/3;background-size:contain;background-color:#ece7df;background-position:center;background-repeat:no-repeat;box-shadow:0 12px 28px rgba(0,0,0,.4),inset 0 0 0 1px rgba(0,0,0,.06)}
.ai-foot{margin-top:10px;font-size:13px;color:var(--text2)}
.ai-foot em{font-family:'Instrument Serif',serif;font-style:italic;color:#fff}
.ai-explainer h3{font-size:40px;font-weight:800;letter-spacing:-.03em;margin-bottom:18px;line-height:1.05}
.ai-explainer h3 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--accent)}
.ai-explainer p{color:var(--text2);font-size:17px;line-height:1.65;margin-bottom:14px}
.ai-bullets{margin-top:18px;list-style:none;padding:0}
.ai-bullets li{font-size:15px;color:var(--text2);padding:8px 0;border-top:1px solid var(--border)}
.ai-bullets li:first-child{border-top:0}
@media (max-width:880px){
  .ai-wrap{grid-template-columns:1fr;gap:32px}
}

/* On Deck tracker — 4 tiles in a 2×2 grid + explainer column. */
.deck-wrap{display:grid;grid-template-columns:1.25fr 1fr;gap:48px;align-items:start;position:relative;z-index:2}
.deck-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.deck-tile{border-radius:18px;overflow:hidden;background:#1a1a26;box-shadow:0 32px 60px rgba(0,0,0,.55)}
.deck-still{aspect-ratio:16/9;background:#3a3a3a center/cover no-repeat;position:relative}
/* Book "still" — a portrait cover floated inside a 16:9 frame so
 * the deck-tile aspect stays consistent across kinds. The cover
 * itself is `contain`-sized; the surrounding fill comes from the
 * tile's own background color (set inline per title for the
 * poster-color identity treatment). */
.deck-still.book{aspect-ratio:16/9;background-size:auto 92%;background-position:center;background-repeat:no-repeat;background-color:transparent}
.deck-sep{position:absolute;top:10px;left:10px;background:rgba(0,0,0,.7);color:#fff;font-size:10px;font-weight:900;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;border-radius:999px}
.deck-strip{padding:14px 16px 6px;color:#fff}
.deck-eyebrow{font-size:10px;font-weight:900;letter-spacing:.2em;text-transform:uppercase;opacity:.72}
.deck-ep{font-size:15px;font-weight:800;margin-top:4px}
.deck-bar{margin-top:10px;height:6px;border-radius:999px;background:rgba(255,255,255,.22);overflow:hidden}
.deck-bar span{display:block;height:100%;background:#fff;border-radius:999px}
.deck-chips{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px;padding-bottom:14px}
.deck-chip{display:inline-flex;align-items:center;justify-content:center;height:28px;padding:0 10px;font-size:10.5px;font-weight:700;color:#fff;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.26);border-radius:999px;white-space:nowrap}
/* "Done · Rank it" — the prompt that surfaces when a book hits
 * 100% / a season is finished. Painted in brand amber so it
 * reads as the next-step CTA, not just another tracker chip. */
.deck-chip.done{background:var(--accent);color:#0a0a0f;border-color:transparent;font-weight:900}
.deck-name{padding:14px 16px;background:rgba(0,0,0,.32);color:#fff;font-size:24px;font-weight:900;letter-spacing:-.02em;line-height:1.05}
.deck-explainer h3{font-size:40px;font-weight:800;letter-spacing:-.03em;margin-bottom:18px;line-height:1.05}
.deck-explainer h3 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--accent)}
.deck-explainer p{color:var(--text2);font-size:17px;line-height:1.65;margin-bottom:14px}
@media (max-width:880px){
  .deck-wrap{grid-template-columns:1fr;gap:24px}
  .deck-grid{grid-template-columns:1fr}
  .deck-tile{max-width:100%;margin:0 auto}
}

/* milestones */
.ms-track{display:flex;gap:18px;overflow-x:auto;padding:24px 28px 40px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.ms-track::-webkit-scrollbar{height:6px}
.ms-track::-webkit-scrollbar-thumb{background:rgba(245,166,35,.4);border-radius:3px}
.ms-card{flex:0 0 230px;scroll-snap-align:start;background:var(--glass);border:1px solid var(--border);border-radius:22px;padding:24px;backdrop-filter:blur(30px);transition:transform .4s cubic-bezier(.2,.8,.2,1);perspective:800px}
.ms-card:hover{transform:rotateY(-6deg) rotateX(6deg) translateY(-6px)}
.ms-card .em{font-size:46px;margin-bottom:14px}
.ms-card .ct{font-size:14px;color:var(--accent);font-weight:700;letter-spacing:.04em}
.ms-card .nm{font-size:20px;font-weight:700;margin:4px 0 10px;letter-spacing:-.01em}
.ms-card .q{font-size:13px;color:var(--text2);font-family:'Instrument Serif',serif;font-style:italic}

/* ========= GENRE SLIDER (was 4 stacked rows — way too tall) =========
 *
 * One horizontal slide per genre. Native CSS scroll-snap handles the
 * mobile swipe for free. Prev/Next buttons and dots sit below, and an
 * IntersectionObserver keeps the dots in sync with whichever slide is
 * in view. Respects prefers-reduced-motion (no auto-advance). */
.gslider-wrap{position:relative;z-index:2}
.gslider{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;gap:24px;padding:6px 2px 26px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.gslider::-webkit-scrollbar{display:none}
.gslider .slide{flex:0 0 100%;scroll-snap-align:center;scroll-snap-stop:always;display:grid;grid-template-columns:.9fr 1.1fr;gap:40px;align-items:center;padding:20px 6px;min-height:480px}
.gslider .slide .meta .lbl{font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;margin-bottom:14px}
.gslider .slide .meta h3{font-size:48px;font-weight:800;letter-spacing:-.03em;line-height:1;margin-bottom:18px}
.gslider .slide .meta h3 em{font-family:'Instrument Serif',serif;font-style:italic}
.gslider .slide .meta p{color:var(--text2);font-size:16px;line-height:1.6;max-width:420px}
.gslider .slide .posters{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gslider .slide .posters img{width:100%;aspect-ratio:2/3;object-fit:cover;border-radius:12px;box-shadow:0 24px 50px rgba(0,0,0,.6);transition:transform .4s ease}
.gslider .slide .posters img:hover{transform:translateY(-10px) scale(1.04)}
.gslider .slide.action .meta .lbl,.gslider .slide.action .meta h3 em{color:var(--g-action)}
.gslider .slide.drama .meta .lbl,.gslider .slide.drama .meta h3 em{color:var(--g-drama)}
.gslider .slide.horror .meta .lbl,.gslider .slide.horror .meta h3 em{color:var(--g-horror)}
.gslider .slide.scifi .meta .lbl,.gslider .slide.scifi .meta h3 em{color:var(--g-scifi)}

.gslider-controls{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:10px}
.gslider-btn{width:44px;height:44px;border-radius:50%;background:var(--glass);border:1px solid var(--border);backdrop-filter:blur(20px);color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,transform .2s}
.gslider-btn:hover{background:rgba(255,255,255,.1);transform:scale(1.05)}
.gslider-btn:disabled{opacity:.35;cursor:default;transform:none}
.gslider-dots{display:flex;gap:10px}
.gslider-dots .dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.18);border:none;cursor:pointer;transition:background .25s,width .25s,transform .2s;padding:0}
.gslider-dots .dot.on{background:var(--accent);width:24px;border-radius:4px}
.gslider-dots .dot:hover:not(.on){background:rgba(255,255,255,.35)}

/* ========= Pricing ========= */
.pricing{padding:140px 0 80px;position:relative}
.pricing::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:min(800px,90%);height:1px;background:linear-gradient(90deg,transparent,rgba(245,166,35,.35),transparent)}
.pricing .eyebrow{text-align:center;color:var(--accent);font-size:12px;letter-spacing:4px;text-transform:uppercase;font-weight:700;margin-bottom:16px}
.pricing h2{text-align:center;font-size:clamp(36px,5vw,60px);font-weight:700;letter-spacing:-.035em;line-height:1.02;margin-bottom:18px;max-width:820px;margin-left:auto;margin-right:auto}
.pricing h2 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--accent);font-weight:400}
.pricing .lede{text-align:center;color:var(--text2);max-width:600px;margin:0 auto 72px;font-size:17px;line-height:1.55}

/* 3-column grid. Middle card is 4px taller via negative margins so it
   draws the eye even before the reader notices the MOST POPULAR badge. */
.pricing-grid{display:grid;grid-template-columns:1fr 1.05fr 1fr;gap:20px;max-width:1120px;margin:0 auto;align-items:stretch}
.price-card{background:var(--glass);border:1px solid var(--border);border-radius:26px;padding:40px 30px 34px;backdrop-filter:blur(30px);display:flex;flex-direction:column;position:relative;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}
.price-card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.2)}
.price-card .tier{font-size:11px;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;color:var(--text2);margin-bottom:8px}
.price-card .tagline{font-size:13px;color:var(--text2);font-style:italic;margin-bottom:22px;line-height:1.4;min-height:36px}
.price-card .price{display:flex;align-items:baseline;gap:6px;margin-bottom:6px}
.price-card .price .amount{font-size:58px;font-weight:700;line-height:1;letter-spacing:-.025em;font-feature-settings:"tnum"}
.price-card .price .per{font-size:14px;color:var(--text2)}
.price-card .sub{font-size:13px;color:var(--text2);margin-bottom:28px;min-height:20px;line-height:1.5}
.price-card .sub strong{color:var(--accent);font-weight:700}
.price-card ul{list-style:none;padding:0;margin:0 0 28px;font-size:14px;line-height:1.85;color:var(--text);flex:1}
.price-card ul li{position:relative;padding-left:24px;margin-bottom:4px}
.price-card ul li::before{content:"✓";position:absolute;left:0;top:0;color:var(--accent);font-weight:800;font-size:13px}
.price-card ul li.muted{color:var(--text2)}
.price-card ul li.muted::before{content:"—";color:var(--text2);font-weight:500}
.price-card ul li strong{color:#fff;font-weight:700}
.price-card .badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);font-size:10px;font-weight:800;letter-spacing:1.5px;padding:6px 14px;border-radius:999px;white-space:nowrap;box-shadow:0 8px 24px -6px rgba(0,0,0,.4)}
.price-card.featured{background:linear-gradient(180deg,rgba(245,166,35,.18),rgba(245,166,35,.04));border-color:rgba(245,166,35,.5);box-shadow:0 24px 72px -16px rgba(245,166,35,.4);transform:translateY(-6px)}
.price-card.featured:hover{transform:translateY(-12px)}
.price-card.featured .tier{color:var(--accent)}
.price-card.featured .badge{background:var(--accent);color:#0a0a0f}
.price-card.lifetime .badge{background:#fff;color:#0a0a0f}
.price-card .cta{width:100%;text-align:center;justify-content:center;padding:15px 22px;font-size:14px}
.pricing-fine{text-align:center;color:var(--text2);font-size:12px;margin:48px auto 0;max-width:620px;line-height:1.7}
.pricing-fine strong{color:var(--text)}

/* "Free tier includes" / "Pro adds" divider row under all cards */
.pricing-comp{max-width:1120px;margin:56px auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;text-align:center}
.pricing-comp .cell{padding:18px 14px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-size:13px;line-height:1.4}
.pricing-comp .cell .num{display:block;font-size:28px;font-weight:700;color:var(--accent);letter-spacing:-.02em;margin-bottom:4px;font-feature-settings:"tnum"}
.pricing-comp .cell .lbl{color:var(--text2);font-size:12px;letter-spacing:.5px}

@media (max-width:820px){
  .pricing-grid{grid-template-columns:1fr;max-width:420px;gap:24px}
  .price-card.featured{transform:none}
  .price-card.featured:hover{transform:translateY(-6px)}
  .pricing{padding:80px 0 50px}
  .pricing-comp{grid-template-columns:repeat(2,1fr);margin-top:40px}
}

/* ========= Inline "value prompt" CTA bands ========= */
.cta-band{position:relative;z-index:2;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;padding:34px 30px;border-radius:28px;background:linear-gradient(135deg,rgba(245,166,35,.10),rgba(232,89,110,.08));border:1px solid rgba(245,166,35,.22);backdrop-filter:blur(20px)}
.cta-band .copy h3{font-size:clamp(22px,2.6vw,32px);font-weight:800;letter-spacing:-.02em;line-height:1.15;margin-bottom:4px}
.cta-band .copy h3 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--accent)}
.cta-band .copy p{color:var(--text2);font-size:15px}
.cta-band .actions{display:flex;gap:12px;flex-wrap:wrap}

/* cta */
.cta{text-align:center;padding:160px 0}
.cta .logo{font-size:80px}
.cta h2{font-size:clamp(36px,4.5vw,60px);font-weight:800;letter-spacing:-.03em;line-height:1.05;margin:30px auto 18px;max-width:760px}
.cta h2 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--accent)}
.cta p{color:var(--text2);font-size:18px;margin-bottom:36px}
.badges{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:36px;align-items:center}
.badges a{display:inline-flex;align-items:center;justify-content:center;height:56px;padding:0 22px;border-radius:12px;background:#000;border:1px solid rgba(255,255,255,.18);color:#fff;transition:transform .2s ease,border-color .2s ease,background .2s ease;gap:12px;min-width:180px}
.badges a:hover{transform:translateY(-2px);border-color:rgba(245,166,35,.5);background:#0a0a0f}
.badges a svg{flex-shrink:0}
.badges a .lbl{display:flex;flex-direction:column;align-items:flex-start;line-height:1.1;text-align:left}
.badges a .lbl .sm{font-size:10px;font-weight:400;opacity:.82;letter-spacing:.02em}
.badges a .lbl .lg{font-size:18px;font-weight:600;letter-spacing:-.01em}
.badges a.web{background:var(--accent);color:#0a0a0f;border-color:transparent}
.badges a.web:hover{background:#ffb93a}
.badges a.web .lbl .sm{opacity:.7}

/* footer */
footer{padding:50px 0 60px;border-top:1px solid var(--border);background:rgba(0,0,0,.4)}
footer .inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}
footer .links{display:flex;gap:26px;font-size:13px;color:var(--text2)}
footer .links a:hover{color:var(--text)}
footer .copy{font-size:12px;color:var(--text2)}
footer .attrib{text-align:center;font-size:11px;color:var(--text2);margin-top:22px;opacity:.6}

/* reveal */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* responsive */
@media (max-width:960px){
  section{padding:100px 0}
  .hero{padding:160px 0 100px}
  h1.hero-title{font-size:clamp(64px,16vw,110px)}
  h1.hero-title .a::after{bottom:14px;height:6px}
  .mega-wall .col{width:25%}
  .mega-wall .col:nth-child(5),.mega-wall .col:nth-child(6),.mega-wall .col:nth-child(7),.mega-wall .col:nth-child(8){display:none}
  .mega-wall .col:nth-child(1){left:0}
  .mega-wall .col:nth-child(2){left:25%}
  .mega-wall .col:nth-child(3){left:50%}
  .mega-wall .col:nth-child(4){left:75%}
  .ylist,.social-grid,.recap-wrap{grid-template-columns:1fr}
  .gslider .slide{grid-template-columns:1fr;gap:24px;min-height:unset;padding:10px 4px}
  .gslider .slide .meta h3{font-size:34px}
  .cta-band{padding:24px 20px;flex-direction:column;align-items:flex-start}
  .cta-band .actions{width:100%}
  .cta-band .actions .btn{flex:1;justify-content:center}
  nav.top .links{display:none}
  .problem .duel{gap:16px}
  .problem .card{width:180px;padding:16px}
  .problem .card img{margin-bottom:12px}
  .problem .card .t{font-size:16px}
  .problem .card .stars{font-size:18px}
  .problem .eq{font-size:46px;transform:rotate(90deg)}
  .vs-card{width:260px}
  .vs-label{font-size:48px}
  .vs-prompt{font-size:24px}
}
@media (max-width:480px){
  .hero{padding:140px 0 80px}
  h1.hero-title{font-size:clamp(56px,18vw,88px);margin:22px 0 22px}
  h1.hero-title .a::after{bottom:10px;height:5px}
  .hero .sub{font-size:17px;margin-bottom:32px}
  .ctas{flex-direction:column;gap:12px;align-items:stretch}
  .ctas .btn{justify-content:center}
  .logo{font-size:22px}
  .logo .a::after{bottom:3px}
  .problem .duel{flex-direction:column;gap:12px}
  .problem .card{width:min(78vw,240px)}
  .problem .eq{font-size:42px;transform:rotate(90deg);margin:2px 0}
}

/* early-access form + modal */
.ea-form{display:flex;gap:10px;max-width:520px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.ea-form input[type=email]{flex:1;min-width:240px;padding:16px 20px;border-radius:999px;border:1px solid var(--border);background:rgba(5,5,8,.6);color:var(--text);font:inherit;font-size:15px;backdrop-filter:blur(20px);outline:none;transition:border-color .2s}
.ea-form input[type=email]::placeholder{color:rgba(255,255,255,.4)}
.ea-form input[type=email]:focus{border-color:var(--accent)}
.ea-form button{background:var(--accent);color:#0a0a0f;border:none;padding:16px 28px;border-radius:999px;font:inherit;font-weight:700;font-size:15px;cursor:pointer;box-shadow:0 10px 40px rgba(245,166,35,.35);transition:transform .2s}
.ea-form button:hover{transform:translateY(-2px)}
.ea-form button:disabled{opacity:.6;cursor:wait;transform:none}
.ea-msg{min-height:22px;margin-top:14px;font-size:14px;color:var(--text2)}
.ea-msg.ok{color:var(--accent)}
.ea-msg.err{color:var(--accent2)}

.modal{position:fixed;inset:0;background:rgba(5,5,8,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:1000;display:none;align-items:center;justify-content:center;padding:24px}
.modal.on{display:flex}
.modal .box{max-width:460px;width:100%;background:linear-gradient(180deg,rgba(20,20,28,.95),rgba(10,10,16,.95));border:1px solid var(--border);border-radius:24px;padding:40px 32px;text-align:center;position:relative}
.modal .box h3{font-size:28px;font-weight:800;letter-spacing:-.02em;margin-bottom:10px}
.modal .box h3 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--accent);font-weight:400}
.modal .box p{color:var(--text2);font-size:15px;margin-bottom:24px}
.modal .close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.08);border:none;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.modal .close:hover{background:rgba(255,255,255,.16)}
