
/* ── DISCOVER ───────────────────────────────────────────────── */
.disc-controls{position:sticky;top:52px;z-index:90;background:rgba(0,0,0,.92);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:12px var(--page-pad) 12px}
.disc-top{display:flex;align-items:center;gap:12px}
.disc-search-wrap{flex:1;position:relative;max-width:360px}
.disc-search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-s);pointer-events:none}
.disc-search{width:100%;height:38px;padding:0 12px 0 34px;background:var(--bg-surf);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:13.5px;outline:none;box-sizing:border-box;transition:border-color var(--t)}
.disc-search:focus{border-color:var(--border-h)}
.disc-search::placeholder{color:var(--text-s)}
.disc-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;color:var(--text-s);font-size:14px;grid-column:1/-1}
.disc-spinner{width:32px;height:32px;border:2.5px solid var(--border-h);border-top-color:var(--brand);border-radius:50%;animation:spin 0.8s linear infinite}
.disc-filter-btn{position:relative;height:38px;padding:0 16px;display:flex;align-items:center;gap:8px;background:var(--bg-surf);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:13.5px;font-weight:500;cursor:pointer;transition:all var(--t);flex-shrink:0}
.disc-filter-btn:hover{border-color:var(--border-h)}
.disc-filter-btn.active{border-color:var(--accent);color:var(--accent)}
.filt-badge{position:absolute;top:-7px;right:-7px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--accent);color:var(--bg);font-size:10px;font-weight:800;line-height:18px;text-align:center;border:2px solid var(--bg);opacity:0;transform:scale(.5) translateZ(0);transition:opacity .15s ease,transform .15s ease;pointer-events:none}
.filt-badge.vis{opacity:1;transform:scale(1) translateZ(0)}
.vtog{display:flex;border:1.5px solid var(--border);border-radius:7px;overflow:hidden;margin-left:auto;flex-shrink:0}
.vtog-btn{height:36px;width:40px;display:flex;align-items:center;justify-content:center;color:var(--text-s);transition:all var(--t)}
.vtog-btn:hover{color:var(--text);background:rgba(255,255,255,.05)}
.vtog-btn.on{background:var(--accent-d);color:var(--accent)}
/* ── FILTER POPUP ───────────────────────────────────────────── */
.filt-ov{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.68);backdrop-filter:blur(14px);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease}
.filt-ov.open{opacity:1;pointer-events:auto}
.filt-sheet{width:100%;max-width:700px;background:var(--bg-surf);border:1px solid var(--border-h);border-bottom:none;border-radius:18px 18px 0 0;max-height:82vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent;transform:translateY(28px);transition:transform .2s ease}
.filt-ov.open .filt-sheet{transform:translateY(0)}
.filt-handle{width:36px;height:4px;border-radius:2px;background:rgba(255,255,255,.14);margin:14px auto 0}
.filt-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 24px 10px}
.filt-hd-title{font-size:15px;font-weight:700;color:var(--text)}
.filt-hd-clear{font-size:12.5px;color:var(--accent);font-weight:600;background:none;border:none;cursor:pointer;font-family:inherit;padding:6px 10px;border-radius:6px;transition:background var(--t)}
.filt-hd-clear:hover{background:var(--accent-d)}
.filt-sec{padding:0 24px 20px}
.filt-sec-lbl{font-size:10.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-s);margin-bottom:10px}
.filt-bubbles{display:flex;flex-wrap:wrap;gap:8px}
.filt-bbl{height:36px;padding:0 16px;border-radius:8px;border:1.5px solid var(--border-h);background:transparent;color:var(--text-s);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all var(--t);white-space:nowrap}
.filt-bbl:hover{color:var(--text);background:rgba(255,255,255,.06)}
.filt-bbl.on{background:var(--accent);border-color:var(--accent);color:var(--bg);font-weight:700}
.filt-divider{height:1px;background:var(--border);margin:0 24px 20px}
.filt-foot{position:sticky;bottom:0;display:flex;gap:10px;padding:14px 24px calc(14px + env(safe-area-inset-bottom,0px));background:var(--bg-surf);border-top:1px solid var(--border)}
.filt-cancel-btn{height:44px;padding:0 20px;border-radius:10px;background:transparent;border:1px solid var(--border-h);color:var(--text-s);font-family:inherit;font-size:13.5px;font-weight:500;cursor:pointer;transition:all var(--t)}
.filt-cancel-btn:hover{color:var(--text);border-color:var(--border-h);background:rgba(255,255,255,.05)}
.filt-apply-btn{flex:1;height:44px;border-radius:10px;background:var(--accent);border:none;color:var(--bg);font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;transition:filter var(--t)}
.filt-apply-btn:hover{filter:brightness(1.12)}
/* ── DISC RESULTS ───────────────────────────────────────────── */
.disc-content{padding:20px var(--page-pad) 40px}
.disc-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.disc-count{font-size:12.5px;color:var(--text-s)}
.disc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:16px}
.disc-grid .card{width:100%}
.disc-list{display:flex;flex-direction:column;gap:8px}
.dli{display:flex;align-items:center;gap:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:10px;cursor:pointer;transition:background var(--t)}
.dli:hover{background:var(--bg-surf)}
.dli-poster{width:52px;height:78px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--bg-surf)}
.dli-info{flex:1;min-width:0}
.dli-title{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}
.dli-sub{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-s);flex-wrap:wrap}
.dli-dot{width:3px;height:3px;border-radius:50%;background:var(--text-m)}
.dli-badge{font-size:11px;padding:2px 7px;border-radius:4px;background:var(--accent-d);color:var(--accent)}
.dli-play{width:38px;height:38px;border-radius:50%;background:var(--accent-d);border:1.5px solid var(--accent);color:var(--accent);display:flex;align-items:center;justify-content:center;padding-left:2px;flex-shrink:0;transition:all var(--t)}
.dli:hover .dli-play{background:var(--accent);color:var(--bg)}
.disc-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:80px 20px;color:var(--text-s);text-align:center;grid-column:1/-1}
.disc-loadmore{display:flex;align-items:center;justify-content:center;padding:28px 0;grid-column:1/-1}
.disc-loadmore .disc-spinner{width:26px;height:26px;border-width:2px}
.disc-end{display:flex;align-items:center;justify-content:center;padding:32px 0 20px;color:var(--text-m);font-size:12px;letter-spacing:.5px;text-transform:uppercase;grid-column:1/-1}
.rev-loading{display:flex;align-items:center;gap:12px;color:var(--text-s);font-size:13.5px;padding:30px 0}
.rev-empty{color:var(--text-s);font-size:13.5px;padding:30px 0;font-style:italic}
.rev-av[style*="background-image"]{font-size:0;color:transparent}
.disc-empty svg{opacity:.3}
.disc-empty h3{font-size:16px;font-weight:700;color:var(--text)}
/* ── DICE BUTTON ─────────────────────────────────────────────── */
.dice-btn{width:38px;height:38px;border-radius:8px;background:var(--bg-surf);border:1.5px solid var(--border);color:var(--text-s);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--t);flex-shrink:0;margin-left:8px}
.dice-btn:hover{border-color:var(--brand);color:var(--brand);box-shadow:0 0 12px rgba(0,230,118,.18)}
.dice-btn.rolling{border-color:var(--brand);color:var(--brand)}
.dice-btn.rolling svg{animation:diceRoll .6s ease-in-out infinite}
@keyframes diceRoll{0%{transform:rotate(0deg) scale(1)}25%{transform:rotate(-20deg) scale(1.15)}75%{transform:rotate(20deg) scale(1.15)}100%{transform:rotate(0deg) scale(1)}}
/* ── DICE MODAL ──────────────────────────────────────────────── */
.dice-ov{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.72);backdrop-filter:blur(18px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease}
.dice-ov.open{opacity:1;pointer-events:auto}
.dice-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:32px 28px 28px;width:min(92vw,420px);display:flex;flex-direction:column;gap:0;transform:scale(.94) translateY(12px);transition:transform .25s cubic-bezier(.34,1.56,.64,1);position:relative}
.dice-ov.open .dice-modal{transform:scale(1) translateY(0)}
.dice-hd{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.dice-hd-icon{width:44px;height:44px;border-radius:12px;background:rgba(0,230,118,.12);border:1.5px solid rgba(0,230,118,.25);display:flex;align-items:center;justify-content:center;color:var(--brand);flex-shrink:0}
.dice-hd-icon svg.spinning{animation:diceRoll .5s ease-in-out infinite}
.dice-title{font-size:18px;font-weight:800;color:var(--text);letter-spacing:-.3px}
.dice-sub{font-size:13px;color:var(--text-s);margin-bottom:20px;line-height:1.5}
.dice-section-lbl{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-s);margin-bottom:10px}
.dice-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.dice-chip{height:34px;padding:0 14px;border-radius:50px;background:var(--bg-surf);border:1.5px solid var(--border);color:var(--text-s);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}
.dice-chip:hover{border-color:var(--border-h);color:var(--text)}
.dice-chip.on{background:rgba(0,230,118,.12);border-color:var(--brand);color:var(--brand);font-weight:700}
.dice-roll-btn{width:100%;height:50px;border-radius:14px;background:var(--brand);border:none;color:var(--bg);font-family:inherit;font-size:15px;font-weight:900;letter-spacing:.3px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:filter .15s,transform .1s;margin-top:4px}
.dice-roll-btn:hover{filter:brightness(1.1)}
.dice-roll-btn:active{transform:scale(.97)}
.dice-roll-btn:disabled{opacity:.55;cursor:default;transform:none;filter:none}
/* Result card inside modal */
.dice-result{display:flex;gap:14px;padding:16px;background:var(--bg-surf);border:1.5px solid var(--border);border-radius:14px;cursor:pointer;transition:border-color .15s;margin-top:16px}
.dice-result:hover{border-color:var(--brand)}
.dice-result-poster{width:64px;flex-shrink:0;aspect-ratio:2/3;border-radius:8px;object-fit:cover;background:var(--bg-card)}
.dice-result-info{display:flex;flex-direction:column;justify-content:center;gap:4px;min-width:0}
.dice-result-type{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--brand);margin-bottom:2px}
.dice-result-title{font-size:16px;font-weight:800;color:var(--text);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dice-result-meta{font-size:12px;color:var(--text-s)}
.dice-result-cta{margin-top:8px;font-size:13px;font-weight:700;color:var(--brand);letter-spacing:.2px}
.dice-again{width:100%;height:44px;margin-top:10px;border-radius:12px;background:transparent;border:1.5px solid var(--border);color:var(--text-s);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}
.dice-again:hover{border-color:var(--border-h);color:var(--text)}