*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
[hidden]{display:none!important}
:root{--bg:#030307;--surface:#0c0c14;--surface2:#14141e;--card:#1a1a2e;--card-hover:#222240;--border:rgba(225,29,72,0.1);--text:#fafafa;--muted:#6b7280;--amber:#e11d48;--amber-dim:rgba(225,29,72,0.12);--amber-glow:rgba(225,29,72,0.2);--green:#22c55e;--blue:#3b82f6;--purple:#a21caf;--radius:10px}
body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;overflow-x:hidden;padding-bottom:72px;-webkit-font-smoothing:antialiased}
#app{max-width:600px;margin:0 auto;padding:env(safe-area-inset-top) 16px 0}

header{display:flex;justify-content:space-between;align-items:center;padding:18px 0 6px}
header h1{font-size:1.25em;font-weight:700;letter-spacing:-0.3px;background:linear-gradient(135deg,#fff 40%,var(--amber));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
#today-label{display:block;color:var(--muted);font-size:0.75em;margin-top:1px;font-weight:400}
.header-left{display:flex;align-items:center;gap:12px;min-width:0}
.header-icon{background:var(--surface);border:1px solid var(--border);color:var(--muted);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s;flex-shrink:0}
.header-icon:hover{color:var(--amber);border-color:var(--amber)}
.header-icon:active{transform:scale(0.92)}

#hero{margin:8px 0 4px;display:none;animation:fadeIn 0.4s ease}
#hero.visible{display:block}
.hero-card{display:flex;gap:14px;background:linear-gradient(135deg,var(--surface2),var(--surface));border:1px solid var(--border);border-radius:14px;padding:14px;position:relative;overflow:hidden;cursor:pointer}
.hero-card::before{content:'';position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,var(--amber-dim),transparent 70%);pointer-events:none}
.hero-poster{width:72px;height:100px;border-radius:8px;overflow:hidden;flex-shrink:0;position:relative;z-index:1}
.hero-poster img{width:100%;height:100%;object-fit:cover}
.hero-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1;gap:4px}
.hero-badge{display:inline-block;font-size:0.65em;font-weight:600;text-transform:uppercase;letter-spacing:0.8px;color:var(--amber);background:var(--amber-dim);padding:2px 8px;border-radius:4px;width:fit-content}
.hero-title{font-size:1em;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.hero-meta{display:flex;align-items:center;gap:4px;font-size:0.82em;color:var(--muted)}
.hero-dot{color:var(--amber)}
.hero-progress{margin-top:4px}
.progress-track{height:3px;background:var(--border);border-radius:2px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--amber),#be123c);border-radius:2px;transition:width 0.6s ease;width:0}

#day-nav{display:flex;gap:4px;overflow-x:auto;padding:8px 0 12px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
#day-nav::-webkit-scrollbar{display:none}
.day-btn{flex-shrink:0;background:var(--surface);border:1px solid var(--border);color:var(--muted);padding:6px 14px;border-radius:20px;font-size:0.78em;cursor:pointer;transition:all 0.25s;font-weight:500}
.day-btn.today{position:relative}
.day-btn.today::after{content:'';position:absolute;bottom:1px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--amber)}
.day-btn.active{background:var(--amber);color:#fafafa;border-color:var(--amber);font-weight:700;box-shadow:0 0 12px var(--amber-glow)}

#loading{text-align:center;padding:60px 20px;color:var(--muted)}
.spinner{width:28px;height:28px;border:2.5px solid var(--border);border-top-color:var(--amber);border-radius:50%;animation:spin 0.7s cubic-bezier(0.4,0,0.2,1) infinite;margin:0 auto 12px}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}


#calendar{padding-bottom:12px}
.day-section{display:none}
.day-section.visible{display:block;animation:fadeIn 0.25s ease}
.schedule-item{display:flex;align-items:center;gap:16px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:6px;cursor:pointer;transition:all 0.2s}
.schedule-item:hover{border-color:var(--amber-dim)}
.schedule-item:active{transform:scale(0.98);background:var(--surface2)}
.schedule-poster{width:70px;height:98px;border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--surface2);box-shadow:0 2px 8px rgba(0,0,0,0.35)}
.schedule-poster img{width:100%;height:100%;object-fit:cover;display:block}
.schedule-time{font-size:0.82em;color:var(--muted);width:48px;flex-shrink:0;font-variant-numeric:tabular-nums;text-align:center}
.schedule-title{flex:1;font-size:0.92em;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.schedule-ep{font-size:0.78em;color:var(--muted);flex-shrink:0;margin-left:auto}
.schedule-badge{font-size:0.6em;font-weight:600;padding:2px 6px;border-radius:4px;background:var(--surface2);color:var(--muted);text-transform:uppercase;letter-spacing:0.4px;flex-shrink:0;margin-left:6px}
.schedule-badge.tv{color:#60a5fa;background:#3b82f61a}
.schedule-badge.ona{color:#c084fc;background:#a855f71a}
.schedule-badge.ova{color:#f472b6;background:#ec48991a}
.schedule-badge.movie{color:#f59e0b;background:#f59e0b1a}
.schedule-badge.short{color:#34d399;background:#10b9811a}
.schedule-empty{color:var(--muted);font-size:0.82em;padding:24px 4px;text-align:center}

.day-header{display:flex;justify-content:space-between;align-items:center;padding:16px 4px 10px}
.day-header h2{font-size:0.9em;font-weight:600}
.day-header .day-date{font-size:0.75em;color:var(--muted)}
.day-header .day-date strong{color:var(--amber)}
.day-header:first-child{padding-top:4px}

#error-msg{background:#1c1010;border:1px solid #3a1515;border-radius:8px;padding:12px;color:#fca5a5;font-size:0.82em;margin:10px 0}
.hidden{display:none!important}

#bottom-sheet{position:fixed;top:0;left:0;right:0;bottom:0;z-index:100;visibility:hidden;pointer-events:none;contain:layout}
#bottom-sheet.open{visibility:visible;pointer-events:auto}
#bottom-sheet .sheet-content{position:absolute;bottom:0;left:0;right:0;background:var(--surface);border-radius:16px 16px 0 0;max-height:80vh;overflow-y:auto;overflow-x:hidden;padding:0 0 24px;border-top:1px solid var(--border);transform:translateY(100%);transition:transform 0.35s cubic-bezier(0.32,0.72,0,1);will-change:transform}
#bottom-sheet.open .sheet-content{transform:translateY(0)}
#bottom-sheet .sheet-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;transition:opacity 0.3s ease}
#bottom-sheet.open .sheet-backdrop{opacity:1}
.sheet-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:10px auto}
.sheet-body{padding:4px 20px 0;padding-bottom:env(safe-area-inset-bottom,16px)}
.sheet-header-row{display:flex;gap:12px;margin-bottom:12px;align-items:flex-start}
.sheet-header-poster{width:60px;height:84px;border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--surface2)}
.sheet-header-poster img{width:100%;height:100%;object-fit:cover;display:block}
.sheet-header-info{flex:1;min-width:0}
.sheet-title{font-size:1.1em;font-weight:700;margin-bottom:6px}
.sheet-original-title{font-size:0.72em;color:var(--muted);margin-bottom:8px}
.sheet-stats{display:flex;gap:14px;margin-bottom:8px;flex-wrap:wrap}
.sheet-stat{text-align:center}
.sheet-stat-value{font-size:0.95em;font-weight:700;color:var(--amber)}
.sheet-stat-label{font-size:0.65em;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}
.sheet-desc{font-size:0.8em;color:var(--muted);line-height:1.6;max-height:80px;overflow:hidden;position:relative;margin-bottom:12px}
.sheet-desc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:24px;background:linear-gradient(transparent,var(--surface));pointer-events:none}
.sheet-genres{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.sheet-genre{font-size:0.7em;padding:4px 10px;border-radius:12px;background:var(--amber-dim);color:var(--amber);font-weight:500}
.sheet-separator{height:1px;background:rgba(255,255,255,0.06);margin:10px 0}
.sheet-actions{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.sheet-btn{flex:1;padding:12px;border-radius:10px;font-size:0.88em;font-weight:600;cursor:pointer;transition:all 0.2s;border:none;min-height:44px}
.sheet-btn:active{transform:scale(0.97)}
.sheet-btn-primary{background:var(--amber);color:#fafafa}
.sheet-btn-primary:hover{box-shadow:0 0 16px var(--amber-glow)}
.sheet-btn-secondary{background:var(--surface2);border:1px solid var(--border);color:var(--text)}

.sheet-status-row{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
.sheet-status-row::-webkit-scrollbar{display:none}
.sheet-status-btn{font-size:0.78em;padding:10px 16px;border-radius:12px;font-weight:500;cursor:pointer;transition:all 0.2s;border:1px solid;min-height:44px;white-space:nowrap;text-align:center;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}
.sheet-status-btn:active{transform:scale(0.97)}
.sheet-status-btn.current{background:#1a3a2a;border-color:#2d6a4f}
.sheet-status-btn.current:hover,.sheet-status-btn.current.active{background:rgba(45,106,79,0.4);border-color:#2d6a4f}
.sheet-status-btn.completed{background:#1a2a3a;border-color:#4a6fa5}
.sheet-status-btn.completed:hover,.sheet-status-btn.completed.active{background:rgba(74,111,165,0.4);border-color:#4a6fa5}
.sheet-status-btn.planned{background:#3a2a1a;border-color:#b8860b}
.sheet-status-btn.planned:hover,.sheet-status-btn.planned.active{background:rgba(184,134,11,0.4);border-color:#b8860b}
.sheet-status-btn.on_hold{background:#3a2010;border-color:#cc7a3a}
.sheet-status-btn.on_hold:hover,.sheet-status-btn.on_hold.active{background:rgba(204,122,58,0.4);border-color:#cc7a3a}
.sheet-status-btn.dropped{background:#2a2a2a;border-color:#555}
.sheet-status-btn.dropped:hover,.sheet-status-btn.dropped.active{background:rgba(85,85,85,0.4);border-color:#555}

.sheet-action-btn{font-size:0.85em;padding:10px 16px;border-radius:12px;font-weight:500;cursor:pointer;transition:all 0.2s;border:1px solid;min-height:44px;display:flex;align-items:center;justify-content:center;gap:6px;width:100%;color:#fff}
.sheet-action-btn:active{transform:scale(0.97)}
.sheet-action-btn.watched{background:#1a3a2a;border-color:#2d6a4f}
.sheet-action-btn.watched:hover{background:rgba(45,106,79,0.4);border-color:#2d6a4f}
.sheet-action-btn.subscribe{background:#2a1a3a;border-color:#7b4fa2}
.sheet-action-btn.subscribe:hover{background:rgba(123,79,162,0.4);border-color:#7b4fa2}
.sheet-action-btn.close{background:#3a1a1a;border-color:#a04040}
.sheet-action-btn.close:hover{background:rgba(160,64,64,0.4);border-color:#a04040}

footer{position:fixed;bottom:0;left:0;right:0;background:var(--bg);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:flex-start;padding:4px 0 max(8px,env(safe-area-inset-bottom));max-width:600px;margin:0 auto;z-index:50}
.tab-btn{background:none;border:none;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 12px;cursor:pointer;transition:color 0.2s;font-size:0.6em;font-weight:500}
.tab-btn svg{width:20px;height:20px}
.tab-btn span{margin-top:-1px}
.tab-btn.active,.tab-btn:active{color:var(--amber)}
.tab-btn.active svg{filter:drop-shadow(0 0 4px var(--amber-glow))}

.anilist-login-btn{display:inline-block;background:var(--amber);color:#fafafa;padding:12px 24px;border-radius:10px;font-size:0.9em;font-weight:600;text-decoration:none;transition:all 0.2s}
.anilist-login-btn:hover{box-shadow:0 0 16px var(--amber-glow)}
.anilist-login-btn:active{transform:scale(0.97)}

.list-item{display:flex;align-items:center;gap:16px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:6px;transition:all 0.2s}
.list-item .schedule-poster{width:70px;height:98px;border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--surface2);box-shadow:0 2px 8px rgba(0,0,0,0.35)}
.list-item .schedule-poster img{width:100%;height:100%;object-fit:cover;display:block}
.list-status-btn{flex-shrink:0;background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all 0.2s;align-self:stretch}
.list-status-btn:hover,.list-status-btn:active{color:var(--amber);background:var(--amber-dim)}
.list-info{flex:1;min-width:0;overflow:hidden}
.list-title{font-size:0.92em;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-meta{font-size:0.78em;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

#toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--surface2);color:var(--text);padding:10px 20px;border-radius:10px;font-size:0.85em;border:1px solid var(--border);opacity:0;transition:opacity 0.3s;z-index:200;pointer-events:none;max-width:90%;white-space:nowrap}
#toast.show{opacity:1}
#toast.toast-completed{background:#22c55e1a;border-color:#22c55e;color:#22c55e}
#toast.toast-planned{background:#3b82f61a;border-color:#3b82f6;color:#3b82f6}
#toast.toast-on_hold{background:#a855f71a;border-color:#a855f7;color:#a855f7}
#toast.toast-dropped{background:#ef44441a;border-color:#ef4444;color:#ef4444}
#toast.toast-current{background:var(--amber-dim);border-color:var(--amber);color:var(--amber)}

.status-tabs{display:flex;gap:6px;overflow-x:auto;padding:8px 0 12px;scrollbar-width:none}
.status-tabs::-webkit-scrollbar{display:none}
.status-tab{background:var(--surface);border:1px solid var(--border);color:var(--muted);padding:6px 14px;border-radius:20px;font-size:0.78em;cursor:pointer;white-space:nowrap;transition:all 0.2s;flex-shrink:0}
.status-tab:hover{border-color:var(--amber);color:var(--text)}
.status-tab-active{background:var(--amber);border-color:var(--amber);color:#fafafa}

/* NOVEDADES */
.news-section{padding:0}
.news-item{background:var(--card);border-radius:var(--radius);padding:14px;margin-bottom:10px;border-left:3px solid var(--amber);transition:background .2s;contain:layout}
.news-item:hover{background:var(--card-hover)}
.news-item .source{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--amber);margin-bottom:4px}
.news-item .title{font-size:14px;font-weight:600;margin-bottom:4px;color:var(--text)}
.news-item .meta{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:8px}
.news-item .meta .dot{width:4px;height:4px;border-radius:50%;background:var(--amber);opacity:0.6}
.news-loading{text-align:center;padding:40px;color:var(--muted);font-size:13px}
.news-empty{text-align:center;padding:40px;color:var(--muted);font-size:13px}
.news-error{text-align:center;padding:40px;color:#ef4444;font-size:13px}
.news-refresh-btn{display:inline-block;padding:6px 16px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--muted);font-size:12px;cursor:pointer;margin-top:8px}
.status-count{margin-left:4px;opacity:0.6}
.status-tab-active .status-count{opacity:0.8}
.list-badge{display:inline-block;font-size:0.7em;padding:1px 6px;border-radius:4px;margin-left:4px;font-weight:500}
.status-current{background:var(--amber-dim);color:var(--amber)}
.status-completed{background:#22c55e1a;color:#22c55e}
.status-planned{background:#3b82f61a;color:#3b82f6}
.status-on_hold{background:#a855f71a;color:#a855f7}
.status-dropped{background:#ef44441a;color:#ef4444}

.list-item-wrap{position:relative;overflow:hidden;border-radius:12px;margin-bottom:6px;touch-action:pan-y;-webkit-user-select:none;user-select:none}
.list-item-swipe{position:relative;z-index:2;transition:transform 0.3s cubic-bezier(0.32,0.72,0,1);background:var(--surface);border-radius:12px;will-change:transform}
.list-item-wrap.swiping .list-item-swipe{transition:none}
.list-item-remove{position:absolute;top:0;right:-4px;bottom:0;width:100px;background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;font-size:0.65em;font-weight:500;letter-spacing:0.3px;border-radius:14px 12px 12px 14px;cursor:pointer;z-index:1;opacity:0;transition:opacity 0.25s ease;box-shadow:-2px 0 10px rgba(220,38,38,0.25)}
.list-item-remove svg{width:22px;height:22px}
.list-item-remove:active{background:linear-gradient(135deg,#b91c1c,#dc2626)}

.platform-badge{display:inline-block;font-size:0.72em;font-weight:600;padding:3px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:0.3px}
@keyframes confettiFall{0%{transform:translateY(0) rotate(0deg);opacity:1}100%{transform:translateY(100vh) rotate(720deg);opacity:0}}
#quick-status-menu{z-index:300}
#quick-status-menu button:active{background:var(--surface2)!important}

.upcoming-view{padding-bottom:12px}
.upcoming-day{padding:16px 4px 8px;font-size:0.82em;color:var(--muted);font-weight:600;border-bottom:1px solid var(--border);margin-bottom:8px}
.upcoming-empty{text-align:center;padding:60px 20px;color:var(--muted)}
.upcoming-hint{font-size:0.8em;margin-top:8px;opacity:0.6}
.page-pad{padding:12px 0}
.text-center{text-align:center}
.text-muted{color:var(--muted)}
.flex{display:flex}
.flex-wrap{flex-wrap:wrap}
.gap-sm{gap:6px}
.gap-md{gap:8px}
.mb-sm{margin-bottom:4px}
.mb-md{margin-bottom:12px}
.mt-md{margin-top:12px}
.flex-between{display:flex;justify-content:space-between;align-items:center}
.input-base{width:100%;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:12px 14px;border-radius:10px;font-size:16px;outline:none;transition:border 0.2s;-webkit-appearance:none}
.input-base:focus{border-color:var(--amber)}
.btn-ghost{background:none;border:1px solid var(--border);color:var(--muted);padding:4px 12px;border-radius:6px;font-size:0.75em;cursor:pointer}
.btn-link{background:none;border:none;color:var(--amber);cursor:pointer;text-decoration:underline}
.btn-sm{font-size:0.78em;padding:8px}
.pad-page{padding:16px 0}
.empty-state{text-align:center;padding:40px 20px;color:var(--muted);font-size:0.85em}

#next-upcoming{display:none;margin:0 0 8px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;font-size:0.78em;align-items:center;gap:10px}
#next-upcoming.visible{display:flex}
#next-upcoming .nu-dot{width:6px;height:6px;border-radius:50%;background:var(--amber);flex-shrink:0;animation:nuPulse 2s ease-in-out infinite}
@keyframes nuPulse{0%,100%{opacity:1}50%{opacity:0.25}}
#next-upcoming .nu-info{flex:1;color:var(--muted);min-width:0}
#next-upcoming .nu-info strong{color:var(--text)}
#next-upcoming .nu-time{color:var(--amber);font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}

.skeleton{background:linear-gradient(90deg,var(--surface) 25%,var(--surface2) 50%,var(--surface) 75%);background-size:200% 100%;animation:skeletonSlide 1.2s ease-in-out infinite;border-radius:8px}
@keyframes skeletonSlide{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-poster{width:70px;height:98px;border-radius:10px;flex-shrink:0}
.skeleton-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:10px}
.skeleton-title{height:16px;width:70%;border-radius:4px}
.skeleton-meta{height:13px;width:45%;border-radius:4px}

/* Mix Stats */
.mix-stats-panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:12px}
.mix-stats-row{display:flex;gap:12px;justify-content:space-around}
.mix-stat-card{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}
.mix-stat-value{font-size:1.2em;font-weight:700;color:var(--amber)}
.mix-stat-label{font-size:0.68em;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}

.mix-stats-section{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.mix-stats-section-title{font-size:0.72em;color:var(--muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:0.5px}
.mix-genre-list{display:flex;flex-wrap:wrap;gap:6px}
.mix-genre-tag{font-size:0.72em;padding:3px 10px;border-radius:12px;background:var(--amber-dim);color:var(--amber);font-weight:500}
.mix-genre-count{opacity:0.6;margin-left:2px}
.mix-format-badge{display:flex;align-items:center;gap:8px}
.mix-format-count{font-size:0.78em;color:var(--muted)}

/* Mix Filter */
.mix-filter-row{display:flex;gap:6px;overflow-x:auto;padding:8px 0 12px;scrollbar-width:none}
.mix-filter-row::-webkit-scrollbar{display:none}
.mix-filter-chip{flex-shrink:0;background:var(--surface);border:1px solid var(--border);color:var(--muted);padding:5px 12px;border-radius:20px;font-size:0.78em;cursor:pointer;transition:all 0.2s;font-weight:500}
.mix-filter-chip:hover{border-color:var(--amber);color:var(--text)}
.mix-filter-active{background:var(--amber);border-color:var(--amber);color:#fafafa}

/* Calendar Grid */
.calendar-grid-view{padding:12px 0}
.calendar-grid-header{display:flex;justify-content:space-between;align-items:center;padding:0 4px 12px}
.calendar-grid-title{font-size:1em;font-weight:600}
.calendar-grid-nav{display:flex;gap:8px}
.calendar-grid-nav button{background:var(--surface);border:1px solid var(--border);color:var(--text);width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s}
.calendar-grid-nav button:hover{border-color:var(--amber);color:var(--amber)}
.calendar-grid-nav button:active{transform:scale(0.92)}
.calendar-grid-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}
.calendar-grid-weekday{text-align:center;font-size:0.68em;color:var(--muted);font-weight:500;text-transform:uppercase;padding:4px 0}
.calendar-grid-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.calendar-grid-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:6px 0;border-radius:10px;background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:all 0.2s;position:relative;min-height:0}
.calendar-grid-day:hover{border-color:var(--amber-dim)}
.calendar-grid-day:active{transform:scale(0.95)}
.calendar-grid-day-number{font-size:0.82em;font-weight:500;color:var(--text);line-height:1}
.calendar-grid-day.today{background:var(--amber-dim);border-color:var(--amber);box-shadow:0 0 8px var(--amber-glow)}
.calendar-grid-day.today .calendar-grid-day-number{color:var(--amber);font-weight:700}
.calendar-grid-day.other-month{opacity:0.4}
.calendar-grid-dots{display:flex;gap:2px;flex-wrap:wrap;justify-content:center;margin-top:3px;max-width:80%}
.calendar-grid-dot{width:4px;height:4px;border-radius:50%;background:var(--amber);flex-shrink:0}
.calendar-grid-dot-more{font-size:0.55em;color:var(--amber);font-weight:600;line-height:1;position:relative;top:1px}

/* Compact Mode */
body.compact .list-item,body.compact .schedule-item{padding:8px;gap:10px}
body.compact .schedule-poster,body.compact .list-item .schedule-poster{width:56px;height:78px}
body.compact .schedule-time{font-size:0.75em;width:40px}
body.compact .schedule-title,body.compact .list-title{font-size:0.85em}
body.compact .list-meta,body.compact .schedule-ep{font-size:0.72em}
body.compact .schedule-badge{font-size:0.55em;padding:1px 4px}
body.compact .day-header{padding:12px 4px 8px}
body.compact .day-header h2{font-size:0.82em}
body.compact .day-header .day-date{font-size:0.7em}
body.compact .day-btn{padding:4px 10px;font-size:0.72em}
body.compact .hero-card{gap:10px;padding:10px}
body.compact .hero-poster{width:56px;height:78px}
body.compact .hero-title{font-size:0.9em}
body.compact .hero-meta{font-size:0.75em}
body.compact .hero-badge{font-size:0.6em;padding:1px 6px}
body.compact .calendar-grid-day{padding:4px 0}
body.compact .calendar-grid-day-number{font-size:0.75em}
body.compact .calendar-grid-dots{margin-top:2px}
body.compact .calendar-grid-dot{width:3px;height:3px}
body.compact .calendar-grid-weekday{font-size:0.62em}
body.compact .calendar-grid-title{font-size:0.9em}
body.compact .mix-stats-panel{padding:10px}
body.compact .mix-stat-value{font-size:1.05em}
body.compact .mix-stat-label{font-size:0.62em}
body.compact .mix-genre-tag{font-size:0.67em;padding:2px 8px}
body.compact .mix-stats-section{margin-top:8px;padding-top:8px}
body.compact .mix-stats-section-title{font-size:0.67em}
body.compact .mix-filter-chip{padding:4px 10px;font-size:0.72em}
body.compact .sheet-title{font-size:1em}
body.compact .sheet-body{padding:2px 16px 0}
body.compact .sheet-desc{font-size:0.75em}
body.compact .status-tab{padding:4px 10px;font-size:0.72em}

/* Search results: no zoom/transition, no double-tap zoom */
#search-results .list-item{transition:none}
#search-results{touch-action:manipulation}

/* Mix sub-tabs */
.mix-subtab{background:var(--surface);border:1px solid var(--border);color:var(--muted);padding:6px 14px;border-radius:20px;font-size:0.78em;cursor:pointer;white-space:nowrap;transition:all 0.2s;flex:1}
.mix-subtab:hover{border-color:var(--amber);color:var(--text)}
.mix-subtab-active{background:var(--amber);border-color:var(--amber);color:#fafafa}
