*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
[hidden]{display:none!important}
:root{--bg:#0a0a0a;--surface:#121212;--surface2:#1a1a1a;--border:#1e1e1e;--text:#e8e8e8;--muted:#666;--amber:#f59e0b;--amber-dim:#f59e0b1a;--amber-glow:#f59e0b40;--green:#22c55e;--blue:#3b82f6}
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{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}
.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),#fbbf24);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:#0a0a0a;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:8px;padding:8px 10px;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:36px;height:50px;border-radius:5px;overflow:hidden;flex-shrink:0;background:var(--surface2)}
.schedule-poster img{width:100%;height:100%;object-fit:cover;display:block}
.schedule-time{font-size:0.78em;color:var(--muted);width:40px;flex-shrink:0;font-variant-numeric:tabular-nums}
.schedule-title{flex:1;font-size:0.85em;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.schedule-ep{font-size:0.75em;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;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}
.sheet-title{font-size:1.15em;font-weight:700;margin-bottom:4px}
.sheet-original-title{font-size:0.75em;color:var(--muted);margin-bottom:12px}
.sheet-stats{display:flex;gap:16px;margin-bottom:14px;flex-wrap:wrap}
.sheet-stat{text-align:center}
.sheet-stat-value{font-size:1em;font-weight:700;color:var(--amber)}
.sheet-stat-label{font-size:0.68em;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px}
.sheet-desc{font-size:0.82em;color:var(--muted);line-height:1.6;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:16px}
.sheet-genres{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.sheet-genre{font-size:0.7em;padding:3px 10px;border-radius:12px;background:var(--amber-dim);color:var(--amber);font-weight:500}
.sheet-actions{display:flex;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}
.sheet-btn:active{transform:scale(0.97)}
.sheet-btn-primary{background:var(--amber);color:#0a0a0a}
.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)}

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:#0a0a0a;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:8px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:6px;transition:all 0.2s}
.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}
.list-title{font-size:0.85em;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-meta{font-size:0.75em;color:var(--muted);margin-top:1px}

#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:#0a0a0a}
.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)}

@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:0.9em;outline:none;transition:border 0.2s}
.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}
