:root {
  --bg-deep: #0a0a0a; --bg-panel: #111; --bg-card: #1a1a1a; --bg-hover: #252525;
  --bg-tag: #1e1e1e; --bg-tag-active: #2a2018; --accent: #f07c3e;
  --accent-glow: rgba(240,124,62,0.25); --text-primary: #e8e8e8;
  --text-secondary: #999; --text-muted: #666; --border: #222;
  --sidebar-w: 54px; --info-w: 360px;
  --radius-sm: 6px; --radius-md: 10px; --radius-lg: 14px;
  --safe-bottom: env(safe-area-inset-bottom,0px); --safe-top: env(safe-area-inset-top,0px);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;width:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif;background:var(--bg-deep);color:var(--text-primary);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}

/* ===== App Shell ===== */
.app{display:flex;height:100vh;height:100dvh;width:100%;position:relative;overflow:hidden}
.default{ text-align: center;align-items:center;display: table-cell;vertical-align: middle;text-align: center;display: flex;
  justify-content: center; color: #666;}
.loading {position: relative;width: 30px;height: 30px;border: 5px solid #e55b00;border-top-color: rgba(229, 90, 0, 0.2);border-right-color: rgba(229, 90, 0, 0.2);border-bottom-color: rgba(229, 90, 0, 0.2);border-radius: 100%;animation: circle infinite 0.75s linear;}
@keyframes circle {
  0% {transform: rotate(0);}
  100% {transform: rotate(360deg);}
}

/* ===== Sidebar ===== */
.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-panel);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding-top:calc(16px + var(--safe-top));padding-bottom:var(--safe-bottom);z-index:100}
.sidebar-logo{width:36px;height:36px;margin-bottom:28px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:transform .2s,box-shadow .2s}
.sidebar-logo img{width:36px;}
.sidebar-logo:hover{transform:scale(1.08);box-shadow:0 0 16px var(--accent-glow)}
.nav-items{display:flex;flex-direction:column;gap:15px;flex:1}
.nav-item{width:42px;height:42px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;color:var(--text-muted);position:relative;color: #666;text-decoration: none; text-align: center; display: block; line-height: 0;}
.nav-item:hover{background:var(--bg-hover);color:var(--text-secondary)}
.nav-item.active p,.nav-item.active span{color:#ef7c3e;}
.nav-item.active::before{content:'';position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:4px;height:20px;background:var(--accent);border-radius:0 2px 2px 0}
.nav-icon{font-size:26px;line-height:1; color: #eee}
.nav-label{font-size:11px;line-height:1;font-weight:500}

/* ===== Main ===== */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-deep)}
.main-inner{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:0 24px 24px;scroll-behavior:smooth}
.main-inner::-webkit-scrollbar{width:4px}
.main-inner::-webkit-scrollbar-track{background:transparent}
.main-inner::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* Search */
.search-wrap{position:sticky;top:0;z-index:50;background:var(--bg-deep);padding:14px 0 10px;display: flex;gap:10px;align-items:center;}
.search-bar{display:flex;align-items:center;gap:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:22px;padding:10px 18px;transition:border-color .2s,box-shadow .2s;width:100%;}
.search-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.search-bar input{flex:1;border:none;outline:none;background:transparent;color:var(--text-primary);font-size:14px}
.search-bar input::placeholder{color:var(--text-muted)}
.search-icon{font-size:18px;color:var(--text-muted);flex-shrink:0}

/* Tags */
.tag-bar{position:sticky;top:52px;z-index:51;display:flex;gap:8px;padding:4px 0 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;background: #0a0a0a;}
.tag-barsoos{position:sticky;top:56px;z-index:51;display:flex;gap:8px;padding:4px 0 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;background: #0a0a0a; flex-wrap:wrap;}
.tag-bar::-webkit-scrollbar{display:none}
.tag-bar a,.tag-barsoos a,.poster-card a{color: #999; text-decoration: none;}
.tag{flex-shrink:0;padding:6px 14px;border-radius:16px;background:var(--bg-tag);color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .2s;white-space:nowrap;font-weight:500;border:1px solid transparent}
.tag:hover,.tag-bar a:hover{background:var(--bg-hover);color:var(--text-primary)}
.tag.active{background:var(--bg-tag-active);color:var(--accent);border-color:var(--accent); font-weight: bold;}

/* Section */
.section-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:5px 0 10px;display:flex;align-items:center;gap:8px}
.soostop{margin:12px 0;}
.section-title .dot{font-size: 20px;color:var(--accent);}

/* Poster Grid */
.poster-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-bottom:32px}
.poster-gridlist{display:grid;grid-template-columns:repeat(7,1fr);gap:16px;margin-bottom:32px}
.poster-card{cursor:pointer;transition:transform .25s cubic-bezier(.25,.46,.45,.94);border-radius:var(--radius-md);overflow:hidden;position:relative}
.poster-card:hover{transform:translateY(-4px)}
.poster-card:active{transform:scale(.97)}
.poster-img{aspect-ratio:3/4;border-radius:var(--radius-md);overflow:hidden;position:relative;background:var(--bg-card)}
.poster-img .bg{width:100%;height:100%;position:absolute;inset:0;transition:transform .4s cubic-bezier(.25,.46,.45,.94); display:flex; justify-content:center; background: #1a1a1a;}
.poster-card:hover .poster-img .bg{transform:scale(1.06)}
.poster-img .overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 50%);z-index:2}
.poster-img .score{position:absolute;top:8px;right:8px;z-index:3;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);color:var(--accent);font-size:12px;font-weight:700;padding:3px 8px;border-radius:4px}
.poster-img .ep-count{position:absolute;bottom:10px;left:10px;z-index:3;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);color:#ccc;font-size:11px;padding:2px 8px;border-radius:4px}
.poster-img .play-btn{position:absolute;inset:0;z-index:4;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
/*.poster-img .play-btn::after{content:'�?;font-size:36px;color:#fff;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5)}*/
.poster-card:hover .play-btn{opacity:1}
.poster-info{padding:10px 2px 0}
.poster-title{font-size:14px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.poster-subtitle{font-size:12px;color:var(--text-muted);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.poster-tags{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap;overflow-x:hidden;max-height:24px;}
.poster-tags::-webkit-scrollbar {width: 0;height: 0;}
.poster-tag{font-size:11px;padding:2px 8px;border-radius:4px;background:var(--bg-tag);color:var(--text-muted);border:1px solid var(--border)}
/*.poster-tag:first-child{color:var(--accent);border-color:rgba(240,124,62,.3);background:rgba(240,124,62,.08)}*/

/* Poster Grid app */
.poster-gridapp{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:32px}
.poster-cardapp{cursor: pointer;transition:transform .25s cubic-bezier(.25,.46,.45,.94);border-radius:var(--radius-md);overflow:hidden;position:relative;background: #151515;min-height:200px;}
.poster-cardapp a{display: flex;height: 140px;gap: 10px; padding: 10px;text-decoration: none;}
.poster-cardapp:hover{transform:translateY(-4px)}
.poster-cardapp:active{transform:scale(.97)}
.poster-imgapp{/*aspect-ratio:3/2;*/border-radius:var(--radius-md);overflow:hidden;position:relative;background:var(--bg-card);width:140px;min-height:180px;}
.poster-imgapp .bgapp{width:100%;height:100%;position:absolute;inset:0;transition:transform .4s cubic-bezier(.25,.46,.45,.94); display:flex;align-items:center;justify-content:center;}
.bgapp img{width:100%;}
.poster-cardapp:hover .poster-imgapp .bgapp{transform:scale(1.06)}
.poster-imgapp .overlayapp{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 50%);z-index:2}
.poster-imgapp .scoreapp{position:absolute;top:8px;right:8px;z-index:3;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);color:var(--accent);font-size:12px;font-weight:700;padding:3px 8px;border-radius:4px}
.poster-imgapp .ep-countapp{position:absolute;bottom:10px;left:10px;z-index:3;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);color:#ccc;font-size:11px;padding:2px 8px;border-radius:4px}
.poster-imgapp .play-btnapp{position:absolute;inset:0;z-index:4;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.poster-cardapp:hover .play-btnapp{opacity:1}
.poster-infoapp{padding:10px 2px 0}
.poster-titleapp{font-size:14px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;-webkit-line-clamp: 2;
  -webkit-box-orient: vertical;display: -webkit-box;width:13em;}
.poster-subtitleapp{font-size:12px;color:var(--text-muted);margin-top:3px;overflow:hidden;text-overflow:ellipsis;-webkit-line-clamp: 5;
  -webkit-box-orient: vertical;display: -webkit-box;width:15em;}
.poster-tagsapp{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap;overflow-x:auto;max-height:24px;width:10em;}
.poster-tagsapp::-webkit-scrollbar {width: 0;height: 0;}
.poster-tagapp{font-size:11px;padding:2px 8px;border-radius:4px;background:var(--bg-tag);color:var(--text-muted);border:1px solid var(--border)}

/* ======================================== */
.login-wrapper {width: 100%;max-width: 500px;position: relative;z-index: 1;padding: 40px 0;margin:8% auto 0;}
    /* Logo */
.logo {text-align: center;margin-bottom: 10px;display: flex;align-items: center;justify-content: center;gap: 5px;}
.logo img{width:50px;}
.logo-text {font-size: 36px;background: linear-gradient(135deg, #ffb800 0%, #ff8a00 100%);-webkit-background-clip: text;background-clip: text;-webkit-text-fill-color: transparent;letter-spacing: 1px;font-family: "Arial Black", "Helvetica Neue", sans-serif;}
    /* ����ָ���?*/
.divider-title {display: flex;align-items: center;justify-content: center;margin-bottom: 50px;gap: 20px;}
.divider-title .line {flex: 1;height: 1px;background: linear-gradient(90deg, transparent 0%, #1e3a5f 50%, transparent 100%);max-width: 200px;}
.divider-title .text {font-size: 16px;color: #999;white-space: nowrap;letter-spacing: 1px;}
    /* �� */
.form-group {margin-bottom: 10px;}
.input-row {display: flex;gap: 12px;}
.input-row .form-group { flex: 1; margin-bottom: 0; }
.form-input { width: 100%;height: 56px;background: #0a0a0a;border: 1px solid #1a2540;border-radius: 4px;padding: 0 18px;color: #fff;font-size: 15px;outline: none;transition: all 0.25s ease;font-family: inherit; }
.form-input::placeholder { color: #4a5568; }
.form-input:hover { border-color: #2a3a60; }
.form-input:focus {border-color: #ff8a00;background: #0d0d0d;box-shadow: 0 0 0 3px rgba(255, 138, 0, 0.08);}
.form-input.error { border-color: #e74c3c; }
.form-input.error:focus { box-shadow: 0 0 0 3px rgba(231, 76, 60, 0.1); }
    /* ������֤�� */
.send-code-btn {width: 130px;height: 56px;background: #1e3a5f;color: #fff;border: none;border-radius: 4px;font-size: 14px;cursor: pointer;transition: all 0.25s ease;white-space: nowrap;font-family: inherit;flex-shrink: 0;}
.send-code-btn:hover { background: #2a4a7a; }
.send-code-btn:active { background: #16304f; }
.send-code-btn:disabled {background: #1a1a1a;color: #555;cursor: not-allowed;}
    /* Э�� */
.agreement {display: flex;align-items: flex-start;margin: 20px 0 30px 10px;user-select: none;}
.custom-checkbox {width: 18px;height: 18px;border: 1px solid #2a3a5f;border-radius: 3px;background: #0a0a0a;cursor: pointer;position: relative;flex-shrink: 0;margin-right: 10px;margin-top: 2px;transition: all 0.2s ease; }
.custom-checkbox:hover { border-color: #ff8a00; }
.custom-checkbox.checked {background: #ff8a00;border-color: #ff8a00;}
.custom-checkbox.checked::after {content: "";position: absolute;left: 5px;top: 1px;width: 5px;height: 10px;border: solid #fff;border-width: 0 2px 2px 0;transform: rotate(45deg);}
.agreement-text {font-size: 14px;color: #7a8599;line-height: 1.5;}
.agreement-text a {color: #4a90e2;text-decoration: none;transition: color 0.2s ease;}
.agreement-text a:hover { color: #6ba9e8; text-decoration: underline; }
    /* ��¼��ť */
.login-btn {width: 100%;height: 54px;background: linear-gradient(90deg, #ff5500 0%, #ffa500 100%);color: #fff;border: none;border-radius: 4px;font-size: 17px;font-weight: 600;cursor: pointer;transition: all 0.3s ease;letter-spacing: 4px;font-family: inherit;position: relative; overflow: hidden;}
.login-btn:hover {background: linear-gradient(90deg, #ff6600 0%, #ffb500 100%);transform: translateY(-1px);box-shadow: 0 8px 24px rgba(255, 100, 0, 0.25);}
.login-btn:active { transform: translateY(0); }
.login-btn:disabled {background: #1a1a1a;color: #555;cursor: not-allowed;transform: none;box-shadow: none;}
.login-btn .spinner {display: none;width: 18px;height: 18px;border: 2px solid rgba(255,255,255,0.3);border-top-color: #fff;border-radius: 50%;animation: spin 0.8s linear infinite;position: absolute;right: 20px;top: 50%;margin-top: -9px;}
.login-btn.loading .spinner { display: block; }
.login-btn.loading .btn-text { opacity: 0.5; }
@keyframes spin { to { transform: rotate(360deg); } }
    /* ������ʾ */
.error-msg {font-size: 12px;color: #e74c3c;margin-top: 6px;min-height: 16px;transition: opacity 0.2s ease;}
    /* Toast ��ʾ */
.toast {position: fixed;top: 40px;left: 50%;transform: translateX(-50%) translateY(-20px);background: rgba(30, 30, 30, 0.95);color: #fff;padding: 12px 24px;border-radius: 4px;font-size: 14px;z-index: 1000;opacity: 0;pointer-events: none;transition: all 0.3s ease;backdrop-filter: blur(10px);border: 1px solid rgba(255, 138, 0, 0.3);max-width: 90%;}
.toast.show {opacity: 1;transform: translateX(-50%) translateY(0);}
.toast.success { border-color: rgba(46, 204, 113, 0.4); }
.toast.error { border-color: rgba(231, 76, 60, 0.4); }
/* ===== PLAYER PAGE ===== */
/* ======================================== */
.player-page{position:fixed;inset:0;z-index:200;background:#0d0d0d;display:flex;flex-direction:column;transition:opacity .35s}
.player-page.show{opacity:1;pointer-events:auto}

.hot-page{width:100%;inset:0;z-index:149;background:#0d0d0d;display:flex;flex-direction:column;transition:opacity .35s}
.hot-page.show{opacity:1;pointer-events:auto}
/* Player Header */
.player-top{display:flex;align-items:center;padding:12px 16px;padding-top:calc(12px + var(--safe-top));gap:14px;z-index:10;position: fixed; top:0;width:100%;}
.player-back{width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;font-size:16px;color:#ccc;transition:all .2s;flex-shrink:0;background:rgba(255,255,255,.08);}
.player-back a{color: #999; text-decoration: none;}
.player-back:hover{background:rgba(255,255,255,.1);color:#fff}
.player-search{flex:1;max-width:280px;display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:7px 14px;transition:border-color .2s}
.player-search input{flex:1;border:none;outline:none;background:transparent;color:#ccc;font-size:14px}
.player-search input::placeholder{color:rgba(255,255,255,.25)}
.player-search:focus-within{border-color:rgba(255,255,255,.2)}
.player-top-actions{margin-left:auto;display:flex;gap:10px}
.ptop-btn{display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;color:#999;font-size:20px;transition:all .2s}
.ptop-btn:hover{background:rgba(255,255,255,.06);color:#fff}

/* Player Body */
.player-body{flex:1;display:flex;overflow:hidden;min-height:0;}
.container {display: flex;align-items: flex-start;width:100%;}
.vertical {width:100%}
.horizontal {align-self: center;width:100%}

/* Video Area */
.video-area{flex:1;display:flex;align-items:center;justify-content:center;position:relative;min-width:0;padding:0 20px}
.video-area video{width:100%;}
.video-container{width:100%;aspect-ratio:16/9;background:#111;border-radius:var(--radius-lg);overflow:hidden;position:relative;cursor:pointer}
.video-container .vid-bg{position:absolute;inset:0;background:linear-gradient(160deg,#1a1520 0%,#1a1418 30%,#1a1015 60%,#0d0a0e 100%)}
.video-container .vid-accent{position:absolute;inset:0;background:radial-gradient(ellipse at 45% 45%,rgba(200,160,120,.06) 0%,transparent 65%)}
.video-container .vid-subject{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.video-container .vid-subject-inner{width:50%;height:80%;background:linear-gradient(180deg,rgba(180,140,100,.15) 0%,rgba(140,100,70,.08) 50%,transparent 100%);border-radius:40% 40% 0 0;position:relative;margin-top:5%}
.video-container .vid-subject-inner::before{content:'';position:absolute;bottom:20%;left:50%;transform:translateX(-50%);width:30%;height:25%;background:rgba(180,140,100,.1);border-radius:50%;filter:blur(20px)}
.video-particles{position:absolute;inset:0;overflow:hidden}
.vp{position:absolute;width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.1);animation:floatP 6s infinite ease-in-out}
@keyframes floatP{0%,100%{transform:translateY(0)translateX(0);opacity:.2}25%{transform:translateY(-25px)translateX(12px);opacity:.6}50%{transform:translateY(-8px)translateX(-8px);opacity:.3}75%{transform:translateY(-35px)translateX(4px);opacity:.5}}
.video-container .big-play-btn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:5}
.big-play-circle{width:68px;height:68px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;transition:all .3s;box-shadow:0 0 40px var(--accent-glow);cursor:pointer}
.big-play-circle:hover{transform:scale(1.12);box-shadow:0 0 60px rgba(240,124,62,.5)}

/* Side action buttons on video */
.video-side-actions{position:absolute;right:380px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:18px;z-index:10}
.vsa-btn{display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;transition:transform .2s}
.vsa-btn:active{transform:scale(.9)}
.vsa-icon{width:40px;height:40px;border-radius:50%;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;font-size:18px;color:#999;transition:all .2s}
.vsa-btn:hover .vsa-icon{background:rgba(0,0,0,.6);color: #eee;}
.vsa-count{font-size:11px;color:#ccc;font-weight:500}
.vsa-btn.liked .vsa-icon{color:#ff4466}

/* Bottom Controls */
.player-bottom{display:flex;align-items:center;gap:14px;padding:10px 20px;padding-bottom:calc(10px + var(--safe-bottom));background:rgba(0,0,0,.5);z-index:10}
.ctrl-btn{font-size:13px;color:#aaa;cursor:pointer;padding:5px 8px;border-radius:4px;transition:all .2s;white-space:nowrap;display:flex;align-items:center;gap:4px}
.ctrl-btn:hover{color:#fff;background:rgba(255,255,255,.06)}
.progress-wrap{flex:1;display:flex;align-items:center;gap:8px}
.progress-bar{flex:1;height:3px;background:rgba(255,255,255,.12);border-radius:2px;cursor:pointer;position:relative;transition:height .15s}
.progress-bar:hover{height:5px}
.progress-fill{height:100%;background:var(--accent);border-radius:2px;width:22%;transition:width .1s linear}
.progress-time{font-size:12px;color:var(--text-muted);min-width:90px;text-align:right;font-variant-numeric:tabular-nums}

/* ===== Info Panel ===== */
.info-panel{width:var(--info-w);min-width:var(--info-w);background:var(--bg-panel);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.info-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}
.info-tab{flex:1;text-align:center;padding:12px 0;font-size:14px;font-weight:600;cursor:pointer;color:var(--text-muted);position:relative;transition:color .2s}
.info-tab.active{color:var(--text-primary)}
.info-tab.active::after{content:'';position:absolute;bottom:-1px;left:50%;transform:translateX(-50%);width:28px;height:2px;background:var(--accent);border-radius:1px}
.info-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px 20px;overflow-y:scroll;scrollbar-width: thin;scrollbar-color: rgba(255,255,255,.1) transparent;}
.info-body::-webkit-scrollbar{width:3px}
.info-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.info-drama-title{font-size:18px;font-weight:700;margin-bottom:8px;line-height:1.4}
.info-drama-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.info-drama-tag{font-size:11px;padding:3px 10px;border-radius:4px;background:var(--bg-tag);color:var(--text-muted);border:1px solid var(--border)}
.info-drama-desc{font-size:13px;color:var(--text-secondary);line-height:1.7;margin-bottom:20px}
.info-sec-title{font-size:14px;font-weight:600;margin-bottom:10px;color:var(--text-primary)}
.ep-grid-vd{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:20px}
.ep-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:8px;margin-bottom:20px;max-height:50%;overflow-y:scroll;scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,.1) transparent;}
.ep-grid::-webkit-scrollbar{width:3px}
.ep-btn{padding:8px 10px;text-align:left;border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .2s;border:1px solid var(--border);text-overflow: ellipsis; overflow: hidden;white-space: nowrap;}
.ep-btn b{font-weight: inherit;font-size: 12px; color: #666;}
.ep-btn:hover{background:var(--bg-hover);color:var(--text-primary)}
.ep-btn.playing{background:var(--accent);color:#fff;border-color:var(--accent)}
.ep-btn.locked{color:var(--text-muted);opacity:.5;cursor:not-allowed;position:relative}
.ep-btn.locked::after{content:'🔒';font-size:9px;position:absolute;top:2px;right:3px}
.related-list{display:flex;flex-direction:column;gap:10px;touch-action: pan-y;}
.related-item{display:flex;gap:10px;cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:background .2s}
.related-item:hover{background:var(--bg-hover)}
.related-thumb{width:100px;height:60px;border-radius:6px;flex-shrink:0;overflow:hidden;position:relative}
.related-thumb-bg{width:100%;height:100%;display: flex; align-items: center; background: #1a1a1a;}
.related-thumb-bg img{width:100%;}
.related-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}
.related-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.related-meta{font-size:11px;color:var(--text-muted);margin-top:3px}
.no-player-swipe {pointer-events: auto;}

/* Toast */
.toast{position:fixed;top:60px;left:50%;transform:translateX(-50%);background:var(--bg-card);color:var(--text-primary);padding:10px 24px;border-radius:20px;z-index:999;font-size:13px;border:1px solid var(--border);opacity:0;transition:opacity .3s;pointer-events:none}
.toast.show{opacity:1}
.button,.hot-button{display: none;}

/* ===== Page Sections ===== */
.page {width:50%;margin: 0 auto;}
.page.active { display: block; animation: fadeIn .3s ease; }
/* ===== �ҵ� (My) Page ===== */
.my-page { padding-top: 4px; }
.my-user-bar {display: flex; align-items: center; gap: 14px;background: var(--bg-secondary);border-radius: 14px;padding: 14px 18px;margin-bottom: 10px;cursor: pointer;transition: background var(--transition);}
.my-user-bar:hover { background: #232323; }
.my-user-bar .avatar {width: 52px; height: 52px; border-radius: 50%;background: #2a2a2a;display: flex; align-items: center; justify-content: center;flex-shrink: 0;color: #555;font-size: 26px;position: relative;overflow: hidden;}
.my-user-bar .avatar::after {content: ''; position: absolute; inset: 0;border: 1.5px solid #3a3a3a; border-radius: 50%;}
.my-user-bar .user-meta { flex: 1; min-width: 0; }
.my-user-bar .login-text {font-size: 15px; font-weight: 600; color: #fff; margin-bottom: 4px;}
.my-user-bar .uid-text {font-size: 12px; color: var(--text-muted);}
.my-user-bar .arrow {color: #555; font-size: 18px; flex-shrink: 0;}
.my-vip-card {position: relative;background: linear-gradient(135deg, #f7d39a 0%, #f3b270 45%, #d9874a 100%);border-radius: 16px;padding: 22px 24px 20px;margin-bottom: 16px;overflow: hidden;box-shadow: 0 8px 24px rgba(217, 135, 74, 0.18);}
.my-vip-card::before {content: 'VIP';position: absolute;top: -28px; right: 30px;font-size: 130px;font-weight: 900;font-style: italic;letter-spacing: 4px;color: rgba(255, 255, 255, 0.18);pointer-events: none;user-select: none;font-family: Georgia, serif;}
.my-vip-card::after {content: '';position: absolute;top: -50%; right: -20%;width: 240px; height: 240px;background: radial-gradient(circle, rgba(255,255,255,.4) 0%, transparent 60%);pointer-events: none;}
.my-vip-title {font-size: 17px;font-weight: 700;color: #6b3a1c;margin-bottom: 16px;position: relative; z-index: 2;}
.my-vip-perks {display: flex;gap: 24px;margin-bottom: 18px;position: relative; z-index: 2;}
.my-vip-perk {display: flex;flex-direction: column;align-items: center;gap: 6px;}
.my-vip-perk .perk-icon {width: 38px; height: 38px;border-radius: 8px;background: rgba(255, 255, 255, 0.35);display: flex; align-items: center; justify-content: center;color: #8a4a1f;font-size: 18px;backdrop-filter: blur(2px);}
.my-vip-perk .perk-icon svg { width: 22px; height: 22px; fill: currentColor; }
.my-vip-perk .perk-text {font-size: 12px; color: #7a4422; font-weight: 500;}
.my-vip-btn {display: inline-block;background: linear-gradient(180deg, #ff8542 0%, #d9601f 100%);color: #fff;font-size: 14px;font-weight: 600;padding: 9px 38px;border-radius: 22px;box-shadow: 0 4px 12px rgba(217, 96, 31, 0.4);transition: transform var(--transition), box-shadow var(--transition);position: relative; z-index: 2;cursor: pointer;border: 1px solid rgba(255,255,255,.2);}
.my-vip-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(217, 96, 31, 0.55); }
.my-vip-btn:active { transform: translateY(0); }
.my-vip-badge {position: absolute;right: 16px;bottom: 14px;width: 86px; height: 96px;z-index: 2;pointer-events: none;}
.my-section {background: var(--bg-secondary);overflow: hidden;margin-bottom: 16px;}
.my-row {display: flex; align-items: center; gap: 10px;padding: 12px 18px;cursor: pointer;transition: background var(--transition);margin-bottom: 5px;;border-radius: 10px;background: #171717;}
.my-row:last-child { border-bottom: none; }
.my-row:hover { background: #242424; }
.my-row:active { background: #2a2a2a; }
.my-row .row-icon {font-size: 24px;color: var(--text-secondary);flex-shrink: 0;display: flex; align-items: center; justify-content: center;}
.my-row .row-icon svg { width: 100%; height: 100%; fill: currentColor; stroke: currentColor; }
.my-row .row-label {flex: 1;font-size: 14px;color: var(--text-primary);}
.my-row .row-extra {font-size: 12px;color: var(--text-muted);margin-right: 8px;}
.my-row .row-arrow {color: #555; font-size: 16px;}
.my-logout-bar { margin-top: 8px; text-align: center; }
.my-logout-btn { display: inline-block;width: 100%;padding: 14px 0;background: var(--bg-secondary);border-radius: 12px;font-size: 14px;color: #ff6b6b;cursor: pointer;transition: background var(--transition);}
.my-logout-btn:hover { background: #2a1a1a; }
.my-logout-btn:active { background: #3a2020; }

/* ===== Modal (Login / VIP) ===== */
.modal-mask {position: fixed; inset: 0;background: rgba(0,0,0,.65);display: none;align-items: center; justify-content: center;z-index: 200;padding: 20px;backdrop-filter: blur(4px);animation: fadeIn .2s ease;}
.modal-mask.show { display: flex; }
.modal-box {width: 100%; max-width: 360px;background: #171717;border-radius: 16px;padding: 28px 24px 22px;text-align: center;position: relative;animation: scaleIn .25s ease;}
.modal-box .modal-close {position: absolute; top: 12px; right: 12px;width: 28px; height: 28px;border-radius: 50%;background: #2a2a2a;color: #aaa;display: flex; align-items: center; justify-content: center;cursor: pointer; font-size: 16px;transition: all var(--transition);}
.modal-box .modal-close:hover { background: #3a3a3a; color: #fff; }
.modal-box .modal-icon {width: 56px; height: 56px;border-radius: 50%;background:#121212;display: flex; align-items: center; justify-content: center;margin: 0 auto 14px;font-size: 26px;color: #fff;border: 1px dotted #666;}
.modal-box .modal-icon img{width:40px;}
.modal-box .modal-title {font-size: 17px; font-weight: 600;margin-bottom: 8px;}
.modal-box .modal-desc {font-size: 12px; color: var(--text-secondary);margin-bottom: 20px;}
.modal-box .modal-desc img{margin-top: 10px;width:200px;}
.modal-box .modal-actions {display: flex; gap: 10px;}
.modal-box .modal-btn {flex: 1;padding: 11px 0;border-radius: 22px;font-size: 14px; font-weight: 500;cursor: pointer;transition: all var(--transition);}
.modal-box .modal-btn.primary {background: linear-gradient(180deg, var(--accent), #d9601f);color: #fff;box-shadow: 0 4px 12px rgba(255,107,43,.35);}
.modal-box .modal-btn.primary a{text-decoration: none; color: #fff;}
.modal-box .modal-btn.primary:hover { transform: translateY(-1px); }
.modal-box .modal-btn.secondary {background: #2a2a2a; color: var(--text-primary);}
.modal-box .modal-btn.secondary:hover { background: #333; }
.modal-box .vip-plans {display: grid; grid-template-columns: repeat(3, 1fr);gap: 8px; margin-bottom: 20px;}
.modal-box .vip-plan {padding: 10px 15px;border: 1px solid #2a2a2a;border-radius: 5px;cursor: pointer;transition: all var(--transition);position: relative;}
.modal-box .vip-plan:hover { border-color: #3a3a3a; }
.modal-box .vip-plan.active {border-color: var(--accent);background: rgba(255,107,43,.08);}
.modal-box .vip-plan .plan-name {font-size: 12px; color: var(--text-secondary);margin-bottom: 4px;}
.modal-box .vip-plan .plan-price {font-size: 16px; font-weight: 700; color: #fff;}
.modal-box .vip-plan .plan-price small {font-size: 11px; font-weight: 400; color: var(--text-muted);}
.modal-box .vip-plan .plan-tag {position: absolute; top: -8px; right: -4px;background: var(--accent); color: #fff;font-size: 9px; padding: 1px 6px; border-radius: 8px;}

.pp{text-align: center;color: #666;line-height: 50px;}

/* ===== Animations ===== */
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
@keyframes scaleIn { from { opacity: 0; transform: scale(.92); } to { opacity: 1; transform: scale(1); } }

/* ===== Responsive ===== */
@media(max-width:1400px){.poster-grid{grid-template-columns:repeat(4,1fr);gap:14px}}
@media(max-width:1200px){
  .info-panel{width:300px;min-width:300px}
  .player-search{max-width:200px}
}
@media(min-width:900px) and (max-width:1600px){.poster-gridapp{grid-template-columns:repeat(3,1fr);gap:10px}}
@media(min-width:1600px) and (max-width:1800px){.poster-gridapp{grid-template-columns:repeat(4,1fr);gap:10px}}
@media(max-width:1100px){.poster-grid{grid-template-columns:repeat(3,1fr);gap:12px}}
@media(max-width:900px){
  .player-body{flex: auto;display: flex;align-items: flex-start;}
  .video-area{padding:0;flex:none;width:100%}
	.video-area video{min-height:80%;}
  .video-container{border-radius:0;max-width:100%}
  .info-panel{width:100%;min-width:100%;height:auto;border-left:none;border-top:1px solid var(--border)}
  .player-search{max-width:160px}
  .player-bottom{gap:8px;padding:8px 12px}
  .ctrl-btn{font-size:12px;padding:4px 6px}
  .poster-gridapp{grid-template-columns:repeat(2,1fr);gap:10px}
}
@media(max-width:768px){
  .sidebar{position:fixed;bottom:0;left:0;right:0;top:auto;width:100%;min-width:100%;height:56px;flex-direction:row;padding:0 0 var(--safe-bottom);border-right:none;border-top:1px solid var(--border);z-index:150;background:rgba(17,17,17,.95);backdrop-filter:blur(20px)}
  .sidebar-logo{display:none}
  .nav-items{flex-direction:row;justify-content:space-around;width:100%;gap:0}
  .nav-item{width:auto;height:56px;padding:8px 12px 0;flex:1}
  .nav-item.active::before{left:50%;top:0;transform:translateX(-50%);width:20px;height:3px;border-radius:0 0 2px 2px}
  .main-inner{padding:0 14px 80px}
  .poster-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .poster-gridlist{grid-template-columns:repeat(2,1fr);gap:10px}
  .poster-gridapp{grid-template-columns:repeat(1,1fr);gap:10px}
  .search-wrap{padding:10px 0 6px}
  .tag{padding:5px 12px;font-size:12px}
  .player-top{padding:8px 10px;gap:8px}
  .player-search{max-width:140px}
  .player-search input{font-size:12px}
  .video-side-actions{right:6px;gap:12px}
  .vsa-icon{width:34px;height:34px;font-size:16px}
  .vsa-count{font-size:10px}
  .info-panel{height:auto}
  .info-body{padding:12px 14px}
  .info-drama-title{font-size:16px}
  .ep-grid{grid-template-columns:repeat(1,1fr);gap:6px}
  .ep-btn{font-size:12px;padding:6px 10px}
  .player-bottom{gap:6px;padding:8px 10px}
  .ctrl-btn{font-size:11px;padding:3px 5px;gap:2px}
  .progress-time{font-size:10px;min-width:70px}
  .big-play-circle{width:52px;height:52px;font-size:18px}
  /* �ƶ��˵��� */
  .modal {position: fixed;bottom: 0;left: 0; width: 100%;height: 100%;background: rgba(0,0,0,0.0);display: flex;justify-content: center;align-items: flex-end;pointer-events: none;z-index: 9999;transition: opacity 0.3s ease;}
  .modal.active {pointer-events: all;}
  .modal-content {background: #111;border-radius: 16px 16px 0 0;width: 100%;max-width: 500px;padding: 20px;transform: translateY(100%);transition: transform 0.3s ease;pointer-events: all; margin-top:90%;}
  .modal.active .modal-content {transform: translateY(0);}
  .close-btn {position: absolute;top: 10px;right: 10px;font-size: 24px;cursor: pointer;}
  .button{position: fixed;bottom:2em;background: rgba(0,0,0,0.6); display: flex;flex-wrap: wrap; color: #999; border-radius: 10px; padding: 10px 20px;width:93%;margin:0 calc(1vw + 10px) 5px;}
  .hot-button{position: fixed;bottom:4em;background: rgba(0,0,0,0.6); display: flex;flex-wrap: wrap; color: #999; border-radius: 10px; padding: 10px 20px; margin: 0 0.8em;}
  .button p,.hot-button p{padding-bottom: 5px; color: #fff;width:100%;overflow:hidden;text-overflow:ellipsis;-webkit-line-clamp: 1;
  -webkit-box-orient: vertical;display: -webkit-box;max-height: 25px;margin-bottom: 4px;}
  .button span,.hot-button span{margin-right:5px; color: #999;}
  .page {width:92%;}
  .login-wrapper { padding: 20px; }
	.logo { margin-bottom: 10px; }
	.logo img{width:40px;}
	.logo-text { font-size: 32px; }
	.divider-title { margin-bottom: 36px; }
	.divider-title .line { max-width: 100px; }
	.divider-title .text { font-size: 14px; }
	.form-input, .send-code-btn { height: 50px; font-size: 14px; }
	.send-code-btn { width: 110px; font-size: 13px; }
	.login-btn { height: 50px; font-size: 16px; }
	.input-row { gap: 8px; }
}
@media(max-width:480px){
  .poster-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .poster-gridlist{grid-template-columns:repeat(2,1fr);gap:8px}
  .poster-gridapp{grid-template-columns:repeat(1,1fr);gap:8px}
  .main-inner{padding:0 10px 76px}
  .poster-title{font-size:13px}
  .poster-subtitle{font-size:11px}
  .poster-tag{font-size:10px;padding:1px 6px}
  .tag{padding:4px 10px;font-size:12px}
  .search-bar{padding:8px 14px}
  .search-bar input{font-size:13px}
  .player-top{padding:6px 8px;gap:6px}
  .player-search{max-width:120px;padding:9px 10px;line-height: 0;}
  .video-side-actions{right:4px;gap:10px}
  .vsa-icon{width:30px;height:30px;font-size:14px}
  .vsa-count{font-size:10px}
  .info-body{padding:10px 12px}
  .ep-grid{grid-template-columns:repeat(1,1fr);gap:5px}
  .info-drama-title{font-size:15px}
  .player-bottom{gap:4px;padding:6px 8px}
  .ctrl-btn{font-size:10px;padding:3px 4px}
  .progress-time{font-size:10px;min-width:60px}
  .big-play-circle{width:44px;height:44px;font-size:16px}
  .logo-text { font-size: 30px; }
  .divider-title .line { max-width: 60px; }
  .divider-title .text { font-size: 13px; }
}