/* ===== ZERPHYX — Premium Streaming UI ===== */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#06080d;--surface:#10131a;--surface2:#181c26;--surface3:#1e2330;
  --text:#f0f3f8;--text2:#8b95a8;--text3:#555e70;
  --accent:#7c5dfa;--accent2:#a78bfa;--accent-glow:rgba(124,93,250,.25);
  --success:#22c55e;--error:#ef4444;--warning:#f59e0b;
  --radius:12px;--nav-h:64px;
  --transition:cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;overflow-x:hidden;min-height:100vh}
a{color:inherit;text-decoration:none}
button{background:none;border:none;color:inherit;cursor:pointer;font-family:inherit}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2)}
::selection{background:rgba(124,93,250,.4)}
.hidden{display:none!important}

/* ===== ANIMATIONS ===== */
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
@keyframes fadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeOut{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(12px)}}
@keyframes slideUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
@keyframes heartBeat{0%{transform:scale(1)}15%{transform:scale(1.3)}30%{transform:scale(1)}45%{transform:scale(1.15)}60%{transform:scale(1)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes toastIn{from{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(-100%)}}
@keyframes progressPulse{0%,100%{opacity:1}50%{opacity:.6}}
@keyframes scaleIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}

/* ===== SKELETON ===== */
.skeleton{background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:400% 100%;animation:shimmer 1.8s ease infinite;border-radius:var(--radius)}
.skeleton-card{width:185px;flex:0 0 185px;aspect-ratio:2/3;border-radius:var(--radius)}
.skeleton-text{height:14px;border-radius:6px;margin-bottom:8px}
.skeleton-text.w60{width:60%}
.skeleton-text.w80{width:80%}
.skeleton-text.w40{width:40%}
.skeleton-title{height:28px;width:50%;border-radius:8px;margin-bottom:12px}
.skeleton-hero{width:100%;aspect-ratio:16/9;border-radius:0}
.skeleton-row{display:flex;gap:14px;padding:0 60px;overflow:hidden}
.skeleton-row-title{height:20px;width:160px;border-radius:8px;margin:0 60px 12px}

/* ===== NAV ===== */
#navbar{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:100;display:flex;align-items:center;padding:0 40px;gap:32px;background:linear-gradient(180deg,rgba(6,8,13,.95) 0%,rgba(6,8,13,.6) 100%);backdrop-filter:blur(20px);transition:background .3s var(--transition)}
#navbar.scrolled{background:rgba(6,8,13,.97)}
.nav-brand{font-size:22px;font-weight:800;letter-spacing:2px;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.nav-links{display:flex;gap:4px}
.nav-link{padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600;color:var(--text2);transition:all .25s var(--transition);position:relative}
.nav-link:hover{color:var(--text);background:rgba(255,255,255,.06)}
.nav-link.active{color:var(--text);background:rgba(124,93,250,.15)}
.nav-link .material-icons-round{font-size:18px;vertical-align:middle;margin-left:4px}
.nav-search{margin-right:auto;position:relative}
.nav-search-wrap{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:0 14px;width:320px;transition:all .25s var(--transition)}
.nav-search-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.nav-search-wrap .material-icons-round{font-size:20px;color:var(--text3)}
.nav-search-wrap input{background:none;border:none;outline:none;color:var(--text);font-size:14px;width:100%;padding:10px 0;font-family:inherit}
.nav-search-wrap input::placeholder{color:var(--text3)}
.search-dropdown{position:absolute;top:calc(100% + 8px);right:0;left:0;background:var(--surface);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:8px;box-shadow:0 16px 48px rgba(0,0,0,.5);z-index:110;display:none;animation:slideDown .2s var(--transition)}
.search-dropdown.show{display:block}
.search-dropdown-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1px;padding:8px 10px 4px}
.search-recent-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;font-size:13px;color:var(--text2);cursor:pointer;transition:background .15s}
.search-recent-item:hover{background:rgba(255,255,255,.06);color:var(--text)}
.search-recent-item .material-icons-round{font-size:16px;color:var(--text3)}
.search-recent-clear{font-size:11px;color:var(--accent2);cursor:pointer;padding:4px 10px;text-align:left}
.search-recent-clear:hover{color:var(--text)}

/* ===== HERO ===== */
.hero{position:relative;width:100%;height:80vh;min-height:500px;overflow:hidden;margin-bottom:-80px}
.hero-backdrop{position:absolute;inset:0;background-size:cover;background-position:center top;transition:opacity .8s var(--transition)}
.hero-gradient{position:absolute;inset:0;background:linear-gradient(0deg,var(--bg) 0%,rgba(6,8,13,.4) 50%,rgba(6,8,13,.3) 100%)}
.hero-content{position:absolute;bottom:120px;right:60px;max-width:600px;z-index:2;animation:fadeIn .6s var(--transition)}
.hero-content h1{font-size:48px;font-weight:800;line-height:1.1;margin-bottom:12px;text-shadow:0 2px 20px rgba(0,0,0,.5)}
.hero-content p{font-size:16px;color:var(--text2);line-height:1.6;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.hero-meta{display:flex;gap:12px;margin-bottom:20px;font-size:13px;color:var(--text2)}
.hero-meta span{display:flex;align-items:center;gap:4px}
.hero-meta .rating{color:#f5c518;font-weight:600}
.hero-actions{display:flex;gap:12px}
.btn-primary{display:flex;align-items:center;gap:6px;padding:12px 28px;border-radius:10px;font-size:15px;font-weight:700;background:var(--accent);color:#fff;transition:all .25s var(--transition)}
.btn-primary:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(124,93,250,.3)}
.btn-primary:active{transform:scale(.96)}
.btn-secondary{display:flex;align-items:center;gap:6px;padding:12px 28px;border-radius:10px;font-size:15px;font-weight:600;background:rgba(255,255,255,.1);backdrop-filter:blur(10px);transition:all .25s var(--transition)}
.btn-secondary:hover{background:rgba(255,255,255,.18);transform:translateY(-2px)}
.btn-secondary:active{transform:scale(.96)}

/* ===== SECTION ===== */
.section-title{font-size:22px;font-weight:700;padding:32px 60px 16px}
main{padding-top:var(--nav-h)}

/* ===== VIEW TRANSITIONS ===== */
main{animation:fadeIn .35s var(--transition)}

/* ===== CATALOG ROW ===== */
.catalog-row{margin-bottom:8px;animation:fadeIn .4s var(--transition) both}
.catalog-row:nth-child(1){animation-delay:0s}
.catalog-row:nth-child(2){animation-delay:.08s}
.catalog-row:nth-child(3){animation-delay:.16s}
.catalog-row:nth-child(4){animation-delay:.24s}
.row-header{display:flex;align-items:center;justify-content:space-between;padding:0 60px;margin-bottom:12px}
.row-header h3{font-size:20px;font-weight:700}
.row-track{display:flex;gap:14px;padding:0 60px;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:16px}
.row-track::-webkit-scrollbar{display:none}

/* ===== POSTER CARD ===== */
.poster-card{flex:0 0 185px;cursor:pointer;transition:all .3s var(--transition);position:relative;border-radius:var(--radius);overflow:hidden}
.poster-card:hover{transform:scale(1.06);z-index:2;box-shadow:0 12px 40px rgba(0,0,0,.5)}
.poster-card img{width:100%;aspect-ratio:2/3;object-fit:cover;display:block;border-radius:var(--radius);background:var(--surface)}
.poster-card .card-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.85) 0%,transparent 60%);opacity:0;transition:opacity .3s var(--transition);display:flex;flex-direction:column;justify-content:flex-end;padding:14px;border-radius:var(--radius)}
.poster-card:hover .card-overlay{opacity:1}
.poster-card .card-title{font-size:13px;font-weight:600;line-height:1.3}
.poster-card .card-year{font-size:11px;color:var(--text2);margin-top:2px}
.poster-card .card-rating{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);padding:3px 8px;border-radius:6px;font-size:11px;font-weight:700;color:#f5c518;display:flex;align-items:center;gap:3px;z-index:3}
.poster-card .play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);opacity:0;transition:all .3s var(--transition);background:var(--accent);width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(124,93,250,.4)}
.poster-card:hover .play-icon{transform:translate(-50%,-50%) scale(1);opacity:1}
.poster-card .play-icon .material-icons-round{font-size:28px}

/* Card progress bar (continue watching) */
.card-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:rgba(255,255,255,.15);border-radius:0 0 var(--radius) var(--radius);overflow:hidden;z-index:3}
.card-progress-fill{height:100%;background:var(--accent);border-radius:0 0 0 var(--radius);transition:width .3s}

/* Watchlist heart */
.card-heart{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:4;opacity:0;transition:all .25s var(--transition);cursor:pointer}
.poster-card:hover .card-heart{opacity:1}
.card-heart:hover{background:rgba(239,68,68,.3);transform:scale(1.15)}
.card-heart.active{opacity:1;color:#ef4444}
.card-heart.active .material-icons-round{animation:heartBeat .6s ease}
.card-heart .material-icons-round{font-size:18px;transition:color .2s}

/* ===== POSTER GRID ===== */
.poster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:20px;padding:0 60px 60px}

/* ===== LOADER ===== */
.loader{display:flex;justify-content:center;padding:40px}
.spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
.empty-state{text-align:center;padding:80px 20px;color:var(--text3);font-size:18px}

/* ===== MODAL ===== */
.modal{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;padding:40px 20px}
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);animation:fadeIn .2s}
.modal-content{position:relative;width:100%;max-width:900px;background:var(--surface);border-radius:16px;overflow:hidden;margin:40px 0;box-shadow:0 24px 80px rgba(0,0,0,.5);animation:slideUp .35s var(--transition)}
.modal-close-btn{position:absolute;top:16px;left:16px;z-index:10;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;transition:all .2s var(--transition)}
.modal-close-btn:hover{background:rgba(255,255,255,.2);transform:scale(1.1)}
.detail-hero{width:100%;aspect-ratio:16/9;background-size:cover;background-position:center;position:relative}
.detail-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(0deg,var(--surface),transparent)}
.detail-body{padding:0 32px 32px}
.detail-info h1{font-size:32px;font-weight:800;margin-bottom:8px}
.detail-meta{display:flex;gap:12px;margin-bottom:14px;font-size:13px;color:var(--text2);flex-wrap:wrap}
.detail-meta span{display:flex;align-items:center;gap:4px}
.detail-meta .rating{color:#f5c518;font-weight:700}
.detail-info p{font-size:14px;color:var(--text2);line-height:1.7;margin-bottom:20px}
#detailCast{font-size:13px;color:var(--text3);margin-bottom:24px}
.detail-actions{display:flex;gap:12px;margin-bottom:20px}
.detail-watchlist-btn{display:flex;align-items:center;gap:6px;padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);transition:all .25s var(--transition);cursor:pointer}
.detail-watchlist-btn:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2)}
.detail-watchlist-btn.active{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.3);color:#ef4444}

/* ===== SEASONS & EPISODES ===== */
.season-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.season-tab{padding:8px 18px;border-radius:8px;font-size:13px;font-weight:600;background:var(--surface2);color:var(--text2);cursor:pointer;transition:all .2s var(--transition)}
.season-tab:hover{background:rgba(255,255,255,.1);color:var(--text)}
.season-tab.active{background:var(--accent);color:#fff}
.episodes-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;max-height:400px;overflow-y:auto}
.episode-item{display:flex;align-items:center;gap:14px;padding:12px;border-radius:10px;background:var(--surface2);cursor:pointer;transition:all .2s var(--transition)}
.episode-item:hover{background:rgba(124,93,250,.15);transform:translateX(-4px)}
.episode-thumb{width:140px;aspect-ratio:16/9;border-radius:8px;object-fit:cover;background:var(--bg);flex-shrink:0}
.episode-info{flex:1;min-width:0}
.episode-info h4{font-size:14px;font-weight:600;margin-bottom:4px}
.episode-info p{font-size:12px;color:var(--text3);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ===== STREAMS ===== */
#streamSection h3{font-size:18px;font-weight:700;margin-bottom:14px}
.stream-list{display:flex;flex-direction:column;gap:8px}
.stream-loading{display:flex;align-items:center;gap:12px;color:var(--text3);padding:20px 0}
.stream-item{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:10px;background:var(--surface2);cursor:pointer;transition:all .25s var(--transition);border:1px solid transparent}
.stream-item:hover{background:rgba(124,93,250,.12);border-color:rgba(124,93,250,.3);transform:translateX(-4px)}
.stream-item .stream-icon{width:40px;height:40px;border-radius:8px;background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stream-item .stream-info{flex:1;min-width:0}
.stream-item .stream-info h4{font-size:14px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stream-item .stream-info p{font-size:12px;color:var(--text3)}
.stream-item .stream-quality{padding:4px 10px;border-radius:6px;background:rgba(255,255,255,.08);font-size:11px;font-weight:700;flex-shrink:0}
.no-streams{color:var(--text3);font-size:14px;padding:20px 0}
.stream-addon-badge{display:inline-block;font-size:10px;padding:2px 8px;border-radius:4px;background:rgba(124,93,250,.15);color:var(--accent2);font-weight:600;margin-top:4px}

/* ===== PLAYER ===== */
#playerOverlay{position:fixed;inset:0;z-index:300;background:#000;display:flex;flex-direction:column}
#playerOverlay.hidden{display:none!important}
#videoPlayer{width:100%;height:100%;object-fit:contain}
.player-top-bar{position:absolute;top:0;left:0;right:0;padding:16px 24px;display:flex;align-items:center;gap:16px;background:linear-gradient(180deg,rgba(0,0,0,.7),transparent);z-index:10;opacity:0;transition:opacity .3s}
#playerOverlay:hover .player-top-bar,#playerOverlay.controls-visible .player-top-bar{opacity:1}
.player-top-bar button{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;transition:all .2s var(--transition)}
.player-top-bar button:hover{background:rgba(255,255,255,.2)}
.player-top-bar span:last-child{font-size:16px;font-weight:600}
.player-controls{position:absolute;bottom:0;left:0;right:0;padding:0 24px 16px;background:linear-gradient(0deg,rgba(0,0,0,.8),transparent);z-index:10;opacity:0;transition:opacity .3s}
#playerOverlay:hover .player-controls,#playerOverlay.controls-visible .player-controls{opacity:1}
.progress-bar{width:100%;height:4px;background:rgba(255,255,255,.15);border-radius:2px;cursor:pointer;margin-bottom:12px;position:relative;transition:height .15s var(--transition)}
.progress-bar:hover{height:8px}
.progress-filled{height:100%;background:var(--accent);border-radius:2px;position:absolute;top:0;right:0;transition:width .1s linear}
.progress-buffered{height:100%;background:rgba(255,255,255,.15);border-radius:2px;position:absolute;top:0;right:0}
.progress-tooltip{position:absolute;top:-32px;background:rgba(0,0,0,.85);color:#fff;font-size:12px;padding:4px 8px;border-radius:6px;transform:translateX(50%);pointer-events:none;display:none;white-space:nowrap}
.progress-bar:hover .progress-tooltip{display:block}
.controls-row{display:flex;align-items:center;justify-content:space-between}
.controls-left,.controls-right{display:flex;align-items:center;gap:8px}
.controls-left button,.controls-right button{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s var(--transition)}
.controls-left button:hover,.controls-right button:hover{background:rgba(255,255,255,.15);transform:scale(1.1)}
#timeDisplay{font-size:13px;color:var(--text2);margin-right:8px;direction:ltr}

/* Volume slider */
.volume-wrap{display:flex;align-items:center;gap:4px;position:relative}
.volume-slider{width:0;overflow:hidden;transition:width .25s var(--transition);display:flex;align-items:center}
.volume-wrap:hover .volume-slider{width:80px}
.volume-slider input[type=range]{-webkit-appearance:none;width:80px;height:4px;background:rgba(255,255,255,.2);border-radius:2px;outline:none;cursor:pointer}
.volume-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer}

/* Speed selector */
.speed-btn{font-size:12px!important;font-weight:700;width:auto!important;padding:0 8px}
.speed-menu{position:absolute;bottom:60px;background:var(--surface);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:4px;display:none;animation:scaleIn .15s var(--transition)}
.speed-menu.show{display:block}
.speed-option{padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer;transition:background .15s;white-space:nowrap}
.speed-option:hover{background:rgba(255,255,255,.08)}
.speed-option.active{color:var(--accent);font-weight:700}

/* Buffering overlay */
.player-buffering{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5;display:none}
.player-buffering.show{display:block}
.player-buffering .spinner{width:52px;height:52px;border-width:4px}

/* Next episode overlay */
.next-episode-overlay{position:absolute;bottom:100px;left:24px;background:rgba(0,0,0,.85);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:20px 24px;z-index:15;display:none;animation:slideUp .3s var(--transition);max-width:360px}
.next-episode-overlay.show{display:block}
.next-episode-overlay h4{font-size:15px;font-weight:700;margin-bottom:4px}
.next-episode-overlay p{font-size:13px;color:var(--text2);margin-bottom:12px}
.next-episode-overlay .next-ep-actions{display:flex;gap:8px}
.next-episode-overlay .next-ep-timer{font-size:12px;color:var(--accent2);margin-top:8px}

/* Skip intro */
.skip-intro-btn{position:absolute;bottom:100px;right:24px;padding:10px 24px;border-radius:8px;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);font-size:14px;font-weight:600;z-index:15;transition:all .25s var(--transition);display:none;animation:fadeIn .3s}
.skip-intro-btn.show{display:block}
.skip-intro-btn:hover{background:rgba(255,255,255,.25)}

/* Player error */
.player-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:15;display:none}
.player-error.show{display:flex;flex-direction:column;align-items:center;gap:12px}
.player-error .material-icons-round{font-size:48px;color:var(--error)}
.player-error p{font-size:14px;color:var(--text2)}

/* ===== TOAST NOTIFICATIONS ===== */
.toast-container{position:fixed;bottom:24px;left:24px;z-index:400;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:12px;background:var(--surface);border:1px solid rgba(255,255,255,.08);box-shadow:0 8px 32px rgba(0,0,0,.4);font-size:14px;font-weight:500;pointer-events:auto;animation:toastIn .3s var(--transition);backdrop-filter:blur(12px);max-width:380px}
.toast.removing{animation:toastOut .3s var(--transition) forwards}
.toast .material-icons-round{font-size:20px;flex-shrink:0}
.toast.success .material-icons-round{color:var(--success)}
.toast.error .material-icons-round{color:var(--error)}
.toast.info .material-icons-round{color:var(--accent2)}

/* ===== KEYBOARD SHORTCUTS OVERLAY ===== */
.shortcuts-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.8);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;animation:fadeIn .2s}
.shortcuts-overlay.show{display:flex}
.shortcuts-box{background:var(--surface);border-radius:16px;padding:32px;max-width:500px;width:100%;max-height:80vh;overflow-y:auto;animation:scaleIn .2s var(--transition)}
.shortcuts-box h2{font-size:20px;font-weight:800;margin-bottom:20px;display:flex;align-items:center;gap:8px}
.shortcut-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.shortcut-row:last-child{border:none}
.shortcut-key{background:var(--surface2);padding:4px 10px;border-radius:6px;font-size:12px;font-weight:700;font-family:monospace;border:1px solid rgba(255,255,255,.1)}
.shortcut-desc{font-size:13px;color:var(--text2)}

/* ===== AUTH ===== */
.nav-user{display:flex;align-items:center;gap:12px;position:relative}
.btn-auth{padding:8px 20px;border-radius:8px;font-size:13px;font-weight:700;background:var(--accent);color:#fff;cursor:pointer;border:none;font-family:inherit;transition:all .25s var(--transition)}
.btn-auth:hover{background:var(--accent2);transform:translateY(-1px)}
.user-pill{display:flex;align-items:center;gap:8px;padding:6px 14px;border-radius:10px;background:var(--surface);border:1px solid rgba(255,255,255,.08);cursor:pointer;transition:all .2s var(--transition)}
.user-pill:hover{border-color:var(--accent)}
.user-pill .user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}
.user-pill .user-name{font-size:13px;font-weight:600}
.user-dropdown{position:absolute;top:calc(var(--nav-h) - 4px);left:0;background:var(--surface);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:8px;min-width:180px;box-shadow:0 12px 40px rgba(0,0,0,.5);z-index:110;display:none;animation:slideDown .2s var(--transition)}
.user-dropdown.show{display:block}
.user-dropdown button{width:100%;text-align:right;padding:10px 14px;border:none;background:none;color:var(--text);font-size:13px;font-weight:500;cursor:pointer;border-radius:8px;font-family:inherit;display:flex;align-items:center;gap:8px;transition:background .2s}
.user-dropdown button:hover{background:rgba(255,255,255,.06)}
.user-dropdown .material-icons-round{font-size:18px;color:var(--text3)}
.auth-box{position:relative;width:100%;max-width:420px;background:var(--surface);border-radius:16px;padding:32px;box-shadow:0 24px 80px rgba(0,0,0,.5);z-index:1;animation:scaleIn .25s var(--transition)}
.auth-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--surface2);border-radius:10px;padding:4px}
.auth-tab{flex:1;padding:10px;border:none;border-radius:8px;font-size:14px;font-weight:600;color:var(--text2);cursor:pointer;background:none;font-family:inherit;transition:all .2s}
.auth-tab.active{background:var(--accent);color:#fff}
.auth-error{color:var(--error);font-size:13px;margin-bottom:12px;min-height:0}
.auth-error:empty{margin:0}
.auth-form .form-group{margin-bottom:14px}
.auth-form label{display:block;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:6px}
.auth-form input{width:100%;padding:10px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:var(--surface2);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:all .2s var(--transition)}
.auth-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.auth-submit{width:100%;padding:12px;margin-top:4px}

/* ===== ADDONS PAGE ===== */
.addons-page{padding:32px 60px 60px;max-width:1200px;margin:0 auto}
.addons-header{margin-bottom:24px}
.addons-subtitle{color:var(--text2);font-size:14px;margin-top:8px}
.addon-install-box{display:flex;gap:12px;margin-bottom:12px}
.addon-install-input-wrap{flex:1;display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:0 16px;transition:all .25s var(--transition)}
.addon-install-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.addon-install-input-wrap .material-icons-round{color:var(--text3);font-size:22px}
.addon-install-input-wrap input{background:none;border:none;outline:none;color:var(--text);font-size:14px;width:100%;padding:14px 0;font-family:inherit}
.addon-install-input-wrap input::placeholder{color:var(--text3)}
.addon-install-error{color:var(--error);font-size:13px;min-height:0}
.addon-install-error:empty{margin:0}
.addon-install-success{color:var(--success);font-size:13px;padding:8px 14px;background:rgba(34,197,94,.1);border-radius:8px;margin-bottom:12px}
.addons-section-title{font-size:18px;font-weight:700;margin:28px 0 16px}
.addons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
.addon-card{background:var(--surface);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:20px;transition:all .25s var(--transition);animation:fadeIn .3s var(--transition)}
.addon-card:hover{border-color:rgba(124,93,250,.3);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.3)}
.addon-card-header{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.addon-logo{width:48px;height:48px;border-radius:10px;object-fit:contain;background:var(--surface2)}
.addon-logo-placeholder{width:48px;height:48px;border-radius:10px;background:var(--surface2);display:flex;align-items:center;justify-content:center;color:var(--text3)}
.addon-card-info h4{font-size:16px;font-weight:700}
.addon-version{font-size:12px;color:var(--text3)}
.addon-desc{font-size:13px;color:var(--text2);line-height:1.5;margin-bottom:12px}
.addon-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.addon-tag{font-size:11px;padding:4px 10px;border-radius:6px;background:rgba(124,93,250,.12);color:var(--accent2);font-weight:600}
.addon-card-actions{display:flex;align-items:center;justify-content:space-between;border-top:1px solid rgba(255,255,255,.06);padding-top:12px}
.addon-url{font-size:11px;color:var(--text3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}
.addon-remove-btn{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--error);padding:6px 12px;border-radius:8px;background:rgba(239,68,68,.1);border:none;cursor:pointer;font-family:inherit;transition:all .2s var(--transition)}
.addon-remove-btn:hover{background:rgba(239,68,68,.2);transform:scale(1.05)}

/* ===== SIMILAR CONTENT ===== */
.similar-section{margin-top:24px;border-top:1px solid rgba(255,255,255,.06);padding-top:20px}
.similar-section h3{font-size:18px;font-weight:700;margin-bottom:14px}
.similar-track{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none}
.similar-track::-webkit-scrollbar{display:none}
.similar-track .poster-card{flex:0 0 140px}

/* ===== RESPONSIVE ===== */
@media(max-width:1100px){
  .hero-content{right:40px;max-width:500px}
  .hero-content h1{font-size:36px}
  .row-header,.row-track,.section-title,.poster-grid,.addons-page{padding-right:40px;padding-left:40px}
  .poster-card{flex:0 0 160px}
}
@media(max-width:768px){
  #navbar{padding:0 16px;gap:12px}
  .nav-search-wrap{width:200px}
  .hero-content{right:20px;left:20px;bottom:80px;max-width:none}
  .hero-content h1{font-size:28px}
  .row-header,.row-track,.section-title,.poster-grid,.addons-page{padding-right:16px;padding-left:16px}
  .poster-card{flex:0 0 130px}
  .detail-body{padding:0 16px 16px}
  .addons-grid{grid-template-columns:1fr}
  .addon-install-box{flex-direction:column}
}
