:root{--bg: #0a0a0f;--bg-card: #15151d;--bg-elevated: #1f1f2a;--text: #f5f5f7;--text-dim: #a0a0ad;--text-mute: #6c6c7a;--accent: #fe2c55;--accent-hover: #ff4d6d;--gold: #ffc143;--green: #4ade80;--border: rgba(255, 255, 255, .08)}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.5;overflow-x:hidden}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}a{color:inherit;text-decoration:none}.app{max-width:480px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;position:relative;padding-bottom:56px}.app-frame{flex:1}.tabbar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;background:#0a0a0feb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);display:flex;padding:8px 0 calc(8px + env(safe-area-inset-bottom,0px));z-index:100}.tabbar a{flex:1;text-align:center;color:var(--text-mute);font-size:12px;padding:6px 0}.tabbar a.active{color:var(--text)}.env-badge{position:fixed;top:8px;right:8px;background:#0009;padding:4px 8px;border-radius:4px;font-size:10px;color:var(--text-dim);z-index:200;display:flex;align-items:center;gap:4px}.dot{width:6px;height:6px;border-radius:50%;display:inline-block}.dot-on{background:var(--green);box-shadow:0 0 4px var(--green)}.dot-off{background:#fbbf24}.home-header{padding:16px;padding-top:calc(20px + env(safe-area-inset-top,0px))}.home-title{font-size:22px;font-weight:700;margin-bottom:4px}.home-subtitle{font-size:12px;color:var(--text-dim)}.home-section{margin:20px 0}.section-title{padding:0 16px 12px;font-size:14px;font-weight:600;display:flex;justify-content:space-between;align-items:center}.link-more{font-size:11px;color:var(--text-mute);font-weight:400}.empty-hint{padding:24px 16px;text-align:center;color:var(--text-mute);font-size:12px}.banner{margin:0 16px;border-radius:12px;overflow:hidden;position:relative}.banner-image{width:100%;aspect-ratio:16 / 6;background-size:cover;background-position:center;position:relative;cursor:pointer}.banner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#000000b3,#0000004d,#00000080)}.banner-text{position:absolute;left:16px;top:50%;transform:translateY(-50%);z-index:2}.banner-title{font-size:18px;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5);margin-bottom:4px}.banner-subtitle{font-size:12px;color:#ffffffd9;text-shadow:0 1px 4px rgba(0,0,0,.5)}.banner-dots{position:absolute;bottom:8px;right:12px;display:flex;gap:4px}.dot-pill{width:6px;height:6px;border-radius:50%;background:#fff6;display:inline-block;transition:all .2s}.dot-pill.active{background:#fff;width:16px;border-radius:3px}.continue-list{display:flex;gap:10px;padding:0 16px;overflow-x:auto}.continue-card{flex-shrink:0;width:160px}.continue-cover{width:100%;aspect-ratio:16 / 10;background-size:cover;background-position:center;border-radius:8px;position:relative;overflow:hidden}.continue-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:50%;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;padding-left:2px}.continue-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:#00000080}.continue-progress-bar{height:100%;background:var(--accent)}.continue-title{font-size:12px;font-weight:600;margin-top:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.continue-ep{font-size:11px;color:var(--text-dim);margin-top:2px}.drama-row{display:flex;gap:10px;padding:0 16px;overflow-x:auto;scroll-snap-type:x mandatory}.drama-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 16px}.drama-card{flex-shrink:0;width:110px;scroll-snap-align:start;cursor:pointer}.drama-grid .drama-card{width:auto}.drama-card-cover{width:100%;aspect-ratio:2 / 3;background-size:cover;background-position:center;border-radius:8px;position:relative;overflow:hidden;border:2px solid transparent}.drama-card.followed .drama-card-cover{border-color:var(--gold)}.drama-card-title{font-size:12px;font-weight:600;margin-top:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drama-card-meta{font-size:10px;color:var(--text-dim);margin-top:2px}.drama-card-h{display:flex;gap:10px;padding:10px;background:var(--bg-card);border-radius:8px;cursor:pointer}.drama-card-h.followed{border:1px solid var(--gold)}.drama-card-h-cover{width:70px;height:100px;background-size:cover;background-position:center;border-radius:6px;flex-shrink:0}.drama-card-h-body{flex:1;display:flex;flex-direction:column}.drama-card-h-title{font-size:13px;font-weight:700;display:flex;align-items:center;gap:4px}.drama-card-h-meta{font-size:11px;color:var(--text-dim);margin-top:4px;display:flex;gap:6px}.drama-card-h-info{font-size:11px;color:var(--text-mute);margin-top:4px}.drama-badge{padding:1px 5px;border-radius:3px;font-size:9px;font-weight:700;display:inline-block;vertical-align:middle}.badge-new{background:var(--accent);color:#fff}.badge-hot{background:var(--gold);color:#2a1a00}.badge-end{background:#fff3;color:#fff}.badge-follow{background:var(--gold);color:#2a1a00;position:absolute;top:6px;left:6px;z-index:2}.drama-card-cover .drama-badge{position:absolute;top:6px;right:6px;z-index:2}.category-tabs{display:flex;gap:8px;padding:0 16px 12px;overflow-x:auto}.category-tab{padding:6px 14px;border-radius:16px;background:var(--bg-elevated);color:var(--text-dim);font-size:12px;font-weight:500;flex-shrink:0}.category-tab.active{background:var(--accent);color:#fff}.drama-detail{padding-bottom:40px}.detail-back{position:fixed;top:calc(12px + env(safe-area-inset-top,0px));left:12px;width:36px;height:36px;border-radius:50%;background:#00000080;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;z-index:60}.detail-hero{width:100%;height:280px;background-size:cover;background-position:center top;position:relative}.detail-hero-mask{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(10,10,15,.4) 0%,rgba(10,10,15,.6) 60%,var(--bg) 100%)}.detail-head{display:flex;gap:12px;padding:0 16px;margin-top:-80px;position:relative;z-index:2}.detail-cover{width:100px;height:140px;background-size:cover;background-position:center;border-radius:8px;flex-shrink:0;box-shadow:0 4px 16px #00000080}.detail-meta{flex:1;padding-top:80px}.detail-title{font-size:18px;font-weight:700;margin-bottom:8px}.detail-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.detail-tag{padding:2px 8px;border-radius:4px;background:var(--accent);color:#fff;font-size:10px;font-weight:600}.detail-tag.tag-outline{background:transparent;color:var(--text-dim);border:1px solid var(--border)}.detail-stats{display:flex;gap:10px;font-size:11px;color:var(--text-dim)}.detail-actions{padding:16px}.detail-actions-row{display:flex;gap:8px;margin-top:8px}.detail-actions-row .btn{flex:1}.detail-desc{padding:0 16px 20px}.detail-section-title{font-size:13px;font-weight:600;color:var(--text-dim);margin-bottom:8px;margin-top:16px}.detail-desc p{font-size:13px;color:var(--text);line-height:1.6;margin-bottom:8px}.detail-cast{font-size:12px;color:var(--text-dim)}.detail-episodes,.detail-related{padding:0 16px 20px}.episode-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.episode-card{position:relative;aspect-ratio:16 / 9;background:var(--bg-card);border-radius:8px;overflow:hidden;cursor:pointer}.episode-card img{width:100%;height:100%;object-fit:cover}.episode-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0000 50%,#000000d9);display:flex;flex-direction:column;justify-content:flex-end;padding:6px 8px}.episode-card-title{font-size:11px;font-weight:600;color:#fff}.card-new{color:var(--accent);margin-left:2px}.episode-card-meta{font-size:10px;color:#ffffffb3;margin-top:2px}.episode-badge{position:absolute;top:6px;right:6px;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:700}.badge-free{background:#4ade80e6;color:#0a3a1c}.badge-locked{background:#fe2c55e6;color:#fff}.badge-unlocked{background:#ffc143e6;color:#3a2a00}.episode-list{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}.episode-pill{flex-shrink:0;width:110px;aspect-ratio:16 / 9;border-radius:6px;overflow:hidden;position:relative;background:var(--bg-card);border:2px solid transparent}.episode-pill.active{border-color:var(--accent)}.episode-pill img{width:100%;height:100%;object-fit:cover}.episode-pill-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.9));font-size:10px;font-weight:600;padding:8px 4px 4px;display:flex;align-items:center;gap:3px}.pill-new{background:var(--accent);color:#fff;padding:0 3px;border-radius:2px;font-size:8px}.btn{padding:10px 16px;border-radius:8px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:opacity .15s}.btn:active{opacity:.7}.btn-primary{background:var(--accent);color:#fff}.btn-gold{background:var(--gold);color:#2a1a00}.btn-ghost{background:var(--bg-elevated);color:var(--text)}.btn-block{width:100%}.btn:disabled{opacity:.4;cursor:not-allowed}.player-page{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:50;display:flex;flex-direction:column;overflow-y:auto}.player-stage{flex:1;min-height:220px;display:flex;align-items:center;justify-content:center;position:relative}.player-stage video{width:100%;height:100%;object-fit:contain;background:#000}.player-back{position:absolute;top:calc(12px + env(safe-area-inset-top,0px));left:12px;width:36px;height:36px;border-radius:50%;background:#00000080;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;z-index:60}.player-info{padding:16px;background:var(--bg)}.player-title{font-size:16px;font-weight:700;margin-bottom:8px}.player-actions{display:flex;gap:8px;flex-wrap:wrap}.player-actions .btn{flex:1;min-width:100px}.episodes-strip{padding:0 16px 16px;background:var(--bg)}.episodes-strip-title{font-size:13px;font-weight:600;margin-bottom:10px;color:var(--text-dim)}.profile-page{padding-bottom:40px}.profile-header{padding:32px 16px 16px;padding-top:calc(40px + env(safe-area-inset-top,0px));text-align:center}.profile-avatar{width:72px;height:72px;border-radius:50%;background:var(--bg-elevated);margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-size:32px}.profile-name{font-size:16px;font-weight:700;margin-bottom:4px}.profile-status{font-size:12px;color:var(--text-dim)}.vip-banner{margin:0 16px 16px;padding:14px 16px;border-radius:12px;background:linear-gradient(135deg,#ffd54f,#ff9d3a);color:#2a1a00;display:flex;align-items:center;justify-content:space-between}.vip-banner-active{background:linear-gradient(135deg,#4ade80,#22c55e);color:#04420f}.vip-banner-title{font-size:14px;font-weight:700}.vip-banner-desc{font-size:11px;margin-top:2px;opacity:.85}.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);margin:0 16px 16px;background:var(--bg-card);border-radius:12px;padding:14px 0}.profile-stat{text-align:center;border-right:1px solid var(--border)}.profile-stat:last-child{border-right:none}.profile-stat-value{font-size:18px;font-weight:700;color:var(--text)}.profile-stat-label{font-size:11px;color:var(--text-dim);margin-top:2px}.profile-section{margin:16px 0}.profile-section-title{padding:0 16px 12px;font-size:14px;font-weight:600;display:flex;justify-content:space-between}.history-list,.purchase-list{padding:0 16px;display:flex;flex-direction:column;gap:8px}.history-item{display:flex;gap:10px;background:var(--bg-card);padding:8px;border-radius:8px}.history-cover{width:80px;height:50px;background-size:cover;background-position:center;border-radius:4px;flex-shrink:0;position:relative;overflow:hidden}.history-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:#00000080}.history-progress-bar{height:100%;background:var(--accent)}.history-info{flex:1;display:flex;flex-direction:column;justify-content:center}.history-title{font-size:13px;font-weight:600}.history-ep{font-size:11px;color:var(--text-dim);margin-top:2px}.history-time{font-size:10px;color:var(--text-mute);margin-top:2px}.purchase-item{display:flex;justify-content:space-between;background:var(--bg-card);padding:10px 12px;border-radius:8px}.purchase-kind{font-size:13px;font-weight:600}.purchase-product{font-size:10px;color:var(--text-mute);margin-top:2px;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.purchase-right{text-align:right}.purchase-amount{font-size:13px;font-weight:700;color:var(--gold)}.purchase-time{font-size:10px;color:var(--text-mute);margin-top:2px}.profile-actions{padding:16px;display:flex;flex-direction:column;gap:8px}.dialog-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:100;display:flex;align-items:flex-end;justify-content:center}.dialog-sheet{width:100%;max-width:480px;background:var(--bg-card);border-radius:16px 16px 0 0;padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}}.dialog-title{font-size:16px;font-weight:700;text-align:center;margin-bottom:6px}.dialog-subtitle{font-size:12px;color:var(--text-dim);text-align:center;margin-bottom:16px}.dialog-options{display:flex;flex-direction:column;gap:8px}.dialog-option{padding:12px 14px;background:var(--bg-elevated);border-radius:10px;text-align:left;display:flex;align-items:center;gap:12px}.dialog-option-highlight{background:linear-gradient(135deg,#ffc1432e,#ff9d3a14);border:1px solid rgba(255,193,67,.4)}.dialog-option-icon{font-size:20px}.dialog-option-body{flex:1}.dialog-option-title{font-size:13px;font-weight:600}.dialog-option-desc{font-size:11px;color:var(--text-dim);margin-top:2px}.dialog-cancel{margin-top:8px;text-align:center;padding:12px;color:var(--text-mute);font-size:13px}.toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:#000000d9;color:#fff;padding:8px 14px;border-radius:8px;font-size:12px;z-index:200;animation:fadeIn .15s;max-width:90vw;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,10px)}}.home-footer{text-align:center;padding:30px 0 20px;font-size:11px;color:var(--text-mute)}.scrollbar-none,.continue-list,.drama-row,.episode-list,.category-tabs,.episodes-strip,.history-list{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.scrollbar-none::-webkit-scrollbar,.continue-list::-webkit-scrollbar,.drama-row::-webkit-scrollbar,.episode-list::-webkit-scrollbar,.category-tabs::-webkit-scrollbar,.episodes-strip::-webkit-scrollbar,.history-list::-webkit-scrollbar{display:none;width:0;height:0}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#fff3}@keyframes pulse-glow{0%,to{box-shadow:0 0 #fe2c55b3;transform:scale(1)}50%{box-shadow:0 0 0 6px #fe2c5500;transform:scale(1.08)}}.badge-new{animation:pulse-glow 1.8s ease-in-out infinite}.card-new{display:inline-block;animation:pulse-glow 1.8s ease-in-out infinite;border-radius:2px;padding:0 2px}.pill-new{animation:pulse-glow 1.8s ease-in-out infinite}.detail-hero-stack{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;z-index:0}.detail-hero-slide{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;filter:blur(18px) saturate(1.3);transform:scale(1.15);opacity:0;transition:opacity 1.2s ease-in-out}.detail-hero-slide.active{opacity:1;animation:kenburns 12s ease-out forwards}@keyframes kenburns{0%{transform:scale(1.15) translate(0)}to{transform:scale(1.3) translate(-3%,-2%)}}.detail-hero{position:relative;overflow:hidden}.detail-hero-vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 0%,rgba(10,10,15,.4) 70%,rgba(10,10,15,.85) 100%);z-index:1}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--bg-card) 0%,var(--bg-elevated) 50%,var(--bg-card) 100%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:6px}.skeleton-banner{width:calc(100% - 32px);margin:0 16px;aspect-ratio:16 / 6;border-radius:12px}.skeleton-row{display:flex;gap:10px;padding:0 16px;overflow:hidden}.skeleton-card{flex-shrink:0;width:110px}.skeleton-cover{width:100%;aspect-ratio:2 / 3;border-radius:8px}.skeleton-line{height:12px;margin-top:8px;border-radius:4px}.skeleton-line-short{width:60%}.skeleton-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 16px}.skeleton-grid .skeleton-card{width:auto}.skeleton-detail-hero{width:100%;height:280px}.skeleton-detail-cover{width:100px;height:140px;border-radius:8px}.vip-banner-shine{position:relative;overflow:hidden;background:linear-gradient(135deg,#2a1a00,#5a3a00 30%,#ffc143 50%,#fff4c4,#ffc143 70%,#5a3a00 90%,#2a1a00);background-size:200% 200%;animation:gold-flow 4s ease-in-out infinite;box-shadow:0 4px 16px #ffc14340,inset 0 1px #ffffff4d}.vip-banner-shine:before{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:gold-shine 3s ease-in-out infinite;z-index:1}.vip-banner-shine>*{position:relative;z-index:2}@keyframes gold-flow{0%,to{background-position:0% 0%}50%{background-position:100% 100%}}@keyframes gold-shine{0%{left:-50%}60%,to{left:150%}}.vip-banner-active.vip-banner-shine{background:linear-gradient(135deg,#04210f,#0d4a23 30%,#4ade80 50%,#d4ffc4,#4ade80 70%,#0d4a23 90%,#04210f);background-size:200% 200%;box-shadow:0 4px 16px #4ade8040,inset 0 1px #fff3}@keyframes celebrate-fall{0%{transform:translateY(-20px) rotate(0);opacity:1}to{transform:translateY(110vh) rotate(720deg);opacity:0}}@keyframes celebrate-burst{0%{transform:translate(0) scale(0);opacity:1}to{transform:translate(var(--tx),var(--ty)) scale(1.2);opacity:0}}.celebration-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:300;overflow:hidden}.celebration-particle{position:absolute;font-size:18px;will-change:transform}.celebration-rain .celebration-particle{animation:celebrate-fall var(--dur) ease-in forwards}.celebration-burst .celebration-particle{animation:celebrate-burst var(--dur) cubic-bezier(.16,1,.3,1) forwards}@keyframes ring-pop{0%{transform:translate(-50%,-50%) scale(0);opacity:.8}to{transform:translate(-50%,-50%) scale(8);opacity:0}}.celebration-ring{position:absolute;top:50%;left:50%;width:60px;height:60px;border-radius:50%;border:3px solid var(--gold);animation:ring-pop .8s ease-out forwards}.drama-card:active .drama-card-cover,.drama-card-h:active,.episode-card:active,.episode-pill:active,.continue-card:active .continue-cover{transform:scale(.96);transition:transform .1s ease-out}.drama-card-cover,.drama-card-h,.episode-card,.episode-pill,.continue-cover{transition:transform .15s ease-out}.toast.toast-success{background:linear-gradient(135deg,#ffc143f2,#ff9d3af2);color:#2a1a00;font-weight:700;box-shadow:0 8px 24px #ffc14366}.toast.toast-error{background:linear-gradient(135deg,#fe2c55f2,#ff4d6df2);color:#fff;font-weight:600}.banner-image{transition:transform .4s ease-out}.banner-image:active{transform:scale(.98)}.banner-title{background:linear-gradient(180deg,#fff,#ffd54f);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.detail-desc p:first-line{font-weight:600;color:var(--text)}
