/* ── HERO ───────────────────────────────────────────────────── */
.hero{position:relative;height:88vh;min-height:520px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center top;transition:opacity .6s ease}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--hero-grad) 0%,rgba(0,0,0,.55) 40%,rgba(0,0,0,.1) 100%)}
.hero-c{position:relative;z-index:2;padding:0 var(--page-pad) 80px;max-width:660px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.hero-title{font-size:clamp(34px,5vw,60px);font-weight:900;line-height:1.05;letter-spacing:-1.5px;margin-bottom:12px}
.hero-meta{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.rating{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--accent)}
.hero-tag{font-size:12px;color:var(--text-s);background:rgba(255,255,255,.06);padding:3px 8px;border-radius:4px;border:1px solid var(--border)}
.muted{color:var(--text-s);font-size:13px}
.hero-desc{font-size:14.5px;color:rgba(241,245,249,.75);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:24px;max-width:520px}
.hero-btns{display:flex;align-items:flex-end;gap:24px}
.hbtn-wrap{display:flex;flex-direction:column;align-items:center;gap:10px}
.hbtn-wrap span{font-size:11px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--text-s)}
.hbtn-wrap span.accent{color:var(--brand)}
.hbtn{display:flex;align-items:center;justify-content:center;border:none;transition:transform var(--t),filter var(--t),box-shadow var(--t)}
.hbtn-play{width:70px;height:70px;border-radius:50%;background:var(--brand);color:var(--bg);box-shadow:var(--brand-glow);padding-left:4px}
.hbtn-play:hover{transform:scale(1.08);filter:brightness(1.1)}
.hbtn-sm{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.2);color:var(--text);backdrop-filter:blur(8px)}
.hbtn-sm:hover{transform:scale(1.06);background:rgba(255,255,255,.18)}
.hero-dots{position:absolute;bottom:28px;right:var(--page-pad);display:flex;gap:6px;z-index:3}
.hdot{width:6px;height:6px;border-radius:3px;background:rgba(255,255,255,.28);transition:all .3s;border:none;cursor:pointer}
.hdot.on{width:20px;background:var(--accent)}
/* ── CONTENT ROWS ───────────────────────────────────────────── */
.content{padding:0 var(--page-pad) 40px}
.row{margin-bottom:32px}
.row-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.row-title{font-size:18px;font-weight:700;letter-spacing:-.3px}
.row-sub{font-size:11.5px;color:var(--text-s);font-weight:400;margin-top:2px;letter-spacing:.1px}
.row-hd-left{display:flex;flex-direction:column;gap:1px}
.see-all{font-size:12.5px;color:var(--text-s);font-weight:500;transition:color var(--t)}
.see-all:hover{color:var(--accent)}
.row-wrap{position:relative}
.row-items{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px var(--page-pad) 6px;margin-left:calc(-1 * var(--page-pad));margin-right:calc(-1 * var(--page-pad));scroll-padding-left:var(--page-pad);scrollbar-width:none;-ms-overflow-style:none}
.row-items::-webkit-scrollbar{display:none}
.sarr{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:36px;height:36px;border-radius:50%;background:rgba(20,20,20,.9);border:1px solid var(--border-h);color:var(--text);font-size:16px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--t);backdrop-filter:blur(8px)}
.row-wrap:hover .sarr{opacity:1}
.sarr:hover{background:rgba(40,40,40,.95);border-color:var(--accent)}
.sarr.l{left:4px}.sarr.r{right:4px}
/* ── CARDS ──────────────────────────────────────────────────── */
.card{position:relative;flex-shrink:0;width:155px;border-radius:var(--r);overflow:hidden;background:var(--bg-card);scroll-snap-align:start;cursor:pointer;transition:transform var(--t)}
.card:hover{transform:scale(1.04)}
.card.wide{width:230px}
.card-poster{position:relative;height:232px;background:var(--bg-surf)}
.card.wide .card-poster{height:130px}
.card-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.3) 50%,transparent 100%);opacity:0;display:flex;align-items:center;justify-content:center;transition:opacity var(--t)}
.card:hover .card-ov{opacity:1}
.play-btn{width:44px;height:44px;border-radius:50%;background:var(--brand);color:var(--bg);display:flex;align-items:center;justify-content:center;box-shadow:var(--brand-glow);padding-left:3px;margin-bottom:48px}
.ov-rating{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:2px 6px;font-size:11px;font-weight:600;color:var(--accent)}
.card-info{padding:10px 10px 12px}
.card-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-sub{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-s);margin-top:3px}
.card-dot{width:3px;height:3px;border-radius:50%;background:var(--text-m)}
.card-theater-badge{position:absolute;bottom:4px;left:6px;z-index:3;background:rgba(0,0,0,.93);border-radius:3px;padding:1px 6px;transform:rotate(-1.5deg);pointer-events:none}
.card-theater-badge span{font-size:7.5px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--brand);text-shadow:0 0 10px var(--brand),0 0 4px rgba(0,230,118,.8)}
.hero-theater-badge{display:inline-flex;align-items:center;background:rgba(0,0,0,.93);border-radius:3px;padding:2px 8px;transform:rotate(-1.5deg)}
.hero-theater-badge span{font-size:10px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:var(--brand);text-shadow:0 0 12px var(--brand),0 0 6px rgba(0,230,118,.8)}
.progress-bar{height:3px;background:rgba(255,255,255,.12);border-radius:2px;margin-top:8px}
.progress-fill{height:100%;background:var(--accent);border-radius:2px}