:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--primary-color: #646cff;--primary-hover: #535bf2;--secondary-color: #6c757d;--danger-color: #dc3545;--success-color: #28a745;--warning-color: #ffc107;--background: #1a1a1a;--surface: #242424;--surface-light: #2a2a2a;--text-primary: rgba(255, 255, 255, .87);--text-secondary: rgba(255, 255, 255, .6);--border-color: rgba(255, 255, 255, .1);--shadow: 0 4px 6px rgba(0, 0, 0, .3)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;background-color:var(--background);color:var(--text-primary);line-height:1.5}.app{min-height:100vh}.btn{padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--surface);border:1px solid transparent;border-radius:8px;cursor:pointer;transition:all .25s;color:var(--text-primary)}.btn:hover{border-color:var(--primary-color)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover)}.btn-secondary{background-color:var(--secondary-color);color:#fff}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-small{padding:.4em .8em;font-size:.875em}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-group input,.form-group select{width:100%;padding:.75rem;font-size:1rem;background-color:var(--surface);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);transition:border-color .25s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-color)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.auth-box{background-color:var(--surface);padding:2.5rem;border-radius:12px;box-shadow:var(--shadow);width:100%;max-width:400px}.auth-box h1{text-align:center;margin-bottom:.5rem;color:var(--primary-color);font-size:2.5rem}.auth-box h2{text-align:center;margin-bottom:2rem;color:var(--text-secondary);font-weight:400}.auth-link{text-align:center;margin-top:1.5rem;color:var(--text-secondary)}.auth-link a{color:var(--primary-color);text-decoration:none}.auth-link a:hover{text-decoration:underline}.dashboard{min-height:100vh;display:flex;flex-direction:column}.dashboard-header{background-color:var(--surface);border-bottom:1px solid var(--border-color);padding:1rem 0}.header-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.header-content h1{color:var(--primary-color);font-size:2rem}.header-actions{display:flex;align-items:center;gap:1rem}.username{color:var(--text-secondary)}.dashboard-main{flex:1;max-width:1200px;margin:0 auto;padding:2rem;width:100%}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background-color:var(--surface);padding:1.5rem;border-radius:8px;text-align:center;border:1px solid var(--border-color)}.stat-card h3{font-size:2rem;color:var(--primary-color);margin-bottom:.5rem}.stat-card p{color:var(--text-secondary)}.dashboard-controls{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.search-input{flex:1;min-width:250px;padding:.75rem;font-size:1rem;background-color:var(--surface);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary)}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.stat-card.stat-watching h3{color:var(--success-color)}.stat-card.stat-completed h3{color:#6366f1}.quick-filters{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-btn{padding:.5rem 1rem;background-color:var(--surface);border:1px solid var(--border-color);border-radius:20px;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:.875rem}.filter-btn:hover{border-color:var(--primary-color);color:var(--text-primary)}.filter-btn.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.control-group{display:flex;gap:.75rem;flex:1;flex-wrap:wrap;align-items:center}.filter-select,.sort-select{padding:.75rem;background-color:var(--surface);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.875rem;cursor:pointer}.filter-select:focus,.sort-select:focus{outline:none;border-color:var(--primary-color)}.results-info{margin-bottom:1rem;color:var(--text-secondary);font-size:.875rem}.almost-complete-section{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-color)}.almost-complete-section h2{margin-bottom:1rem;color:var(--text-primary)}.almost-complete-list{display:flex;flex-direction:column;gap:.5rem}.almost-complete-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:var(--surface);border-radius:6px}.almost-complete-item .show-name{color:var(--text-primary)}.almost-complete-item .progress-badge{background-color:var(--warning-color);color:var(--background);padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600}.search-input:focus{outline:none;border-color:var(--primary-color)}.show-list{margin-top:2rem}.show-group{margin-bottom:3rem}.show-group-title{margin-bottom:1rem;color:var(--text-primary);font-size:1.5rem}.show-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.show-card{background-color:var(--surface);border-radius:8px;overflow:hidden;border:1px solid var(--border-color);transition:transform .2s,box-shadow .2s}.show-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.show-card-image{width:100%;height:200px;overflow:hidden;background-color:var(--surface-light)}.show-card-image img{width:100%;height:100%;object-fit:cover}.placeholder-image,.placeholder-image-large{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:var(--surface-light);font-size:3rem;font-weight:700;color:var(--primary-color)}.placeholder-image-large{height:400px;font-size:6rem}.show-card-content{padding:1rem}.show-card-title{margin-bottom:.5rem;font-size:1.25rem;color:var(--text-primary)}.show-card-stats{display:flex;gap:1rem;margin-bottom:.75rem;font-size:.875rem;color:var(--text-secondary)}.progress-bar,.progress-bar-large,.progress-bar-small{width:100%;height:8px;background-color:var(--surface-light);border-radius:4px;overflow:hidden;position:relative;margin-bottom:.75rem}.progress-bar-large{height:12px;margin:1rem 0}.progress-bar-small{height:6px;margin:.5rem 0}.progress-fill{height:100%;background-color:var(--primary-color);transition:width .3s ease}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.show-card-actions{display:flex;gap:.5rem;align-items:center}.status-select{flex:1;padding:.5rem;font-size:.875rem;background-color:var(--surface-light);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary)}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;padding:2rem;z-index:1000}.modal-content{background-color:var(--surface);padding:2rem;border-radius:12px;box-shadow:var(--shadow);width:100%;max-width:500px}.modal-content h2{margin-bottom:1.5rem;color:var(--text-primary)}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.show-detail{min-height:100vh;max-width:1200px;margin:0 auto;padding:2rem}.show-detail-header{margin-bottom:2rem}.back-link{color:var(--primary-color);text-decoration:none;font-size:1.125rem}.back-link:hover{text-decoration:underline}.show-detail-content{background-color:var(--surface);border-radius:12px;padding:2rem}.show-detail-main{display:grid;grid-template-columns:300px 1fr;gap:2rem;margin-bottom:3rem}.show-detail-image{width:100%;height:400px;border-radius:8px;overflow:hidden}.show-detail-image img{width:100%;height:100%;object-fit:cover}.show-detail-info h1{margin-bottom:1rem;font-size:2.5rem;color:var(--text-primary)}.show-detail-stats{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.stat{display:flex;align-items:center;gap:1rem}.stat label{font-weight:500;color:var(--text-secondary);min-width:100px}.status-badge{padding:.25rem .75rem;border-radius:4px;font-size:.875rem;font-weight:500}.status-watching{background-color:var(--primary-color);color:#fff}.status-completed{background-color:var(--success-color);color:#fff}.status-plan-to-watch{background-color:var(--warning-color);color:#000}.status-dropped{background-color:var(--danger-color);color:#fff}.streaming-badge{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600;color:#fff;margin:.25rem 0;text-transform:uppercase;letter-spacing:.5px}.show-card .streaming-badge{margin-bottom:.5rem}.text-secondary{color:var(--text-secondary)}.seasons-section{margin-top:3rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{color:var(--text-primary);font-size:1.75rem}.add-season-form{display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem;background-color:var(--surface-light);border-radius:8px}.add-season-form input{flex:1;padding:.5rem;background-color:var(--surface);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary)}.seasons-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.season-card{background-color:var(--surface-light);padding:1.5rem;border-radius:8px;border:1px solid var(--border-color)}.season-card h3{margin-bottom:1rem;color:var(--text-primary)}.season-progress{color:var(--text-secondary);font-size:.875rem}.no-seasons{text-align:center;color:var(--text-secondary);padding:2rem}.loading,.loading-screen{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--text-secondary);font-size:1.25rem}.loading-screen{min-height:100vh}.error-message{background-color:#dc35451a;color:var(--danger-color);padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid rgba(220,53,69,.3)}.error-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.error-page p{font-size:1.25rem;margin-bottom:1rem;color:var(--text-secondary)}.empty-state{text-align:center;padding:3rem;color:var(--text-secondary);font-size:1.125rem}.season-card{background-color:var(--surface);border-radius:8px;margin-bottom:1rem;overflow:hidden;transition:box-shadow .3s}.season-card:hover{box-shadow:var(--shadow)}.season-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.season-info{flex:1}.season-title{font-size:1.125rem;font-weight:600;margin-bottom:.25rem}.season-episode-count{color:var(--text-secondary);font-size:.875rem}.season-progress{display:flex;align-items:center;gap:1rem;margin:0 2rem}.expand-button{background:none;border:none;color:var(--text-secondary);font-size:1rem;cursor:pointer;padding:.5rem;transition:color .2s}.expand-button:hover{color:var(--text-primary)}.season-content{padding:0 1.5rem 1.5rem;border-top:1px solid var(--border-color)}.season-actions{display:flex;gap:.75rem;margin:1rem 0}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.episode-list{display:flex;flex-direction:column;gap:.5rem}.episode-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background-color:var(--surface-light);border-radius:6px;transition:background-color .2s}.episode-item:hover{background-color:var(--surface)}.episode-checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;flex:1}.episode-checkbox{width:1.25rem;height:1.25rem;cursor:pointer}.episode-number{font-weight:500;color:var(--text-primary)}.episode-title{color:var(--text-secondary);font-size:.875rem}.episode-watched-date{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.episode-list-loading,.episode-list-empty{text-align:center;padding:2rem;color:var(--text-secondary)}.progress-bar{flex:1;height:8px;background-color:var(--surface-light);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background-color:var(--success-color);transition:width .3s ease}.progress-text{font-size:.875rem;color:var(--text-secondary);font-weight:500;min-width:40px;text-align:right}.progress-bar-large{position:relative;height:24px;background-color:var(--surface);border-radius:12px;overflow:hidden;margin-top:1rem}.progress-bar-large .progress-fill{background:linear-gradient(90deg,var(--success-color),var(--primary-color))}.progress-bar-large .progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-primary);font-weight:600;font-size:.875rem}@media (max-width: 768px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}.show-detail-main{grid-template-columns:1fr}.show-detail-image{height:300px}.dashboard-controls{flex-direction:column}.search-input{width:100%}.season-progress{margin:0 1rem}.season-actions{flex-wrap:wrap}.episode-item{flex-direction:column;align-items:flex-start;gap:.5rem}.episode-watched-date{margin-left:2rem}}.loading-skeleton{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.skeleton-card{background-color:var(--surface);border-radius:8px;overflow:hidden;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-image{height:200px;background-color:var(--surface-light)}.skeleton-content{padding:1rem}.skeleton-title{height:24px;background-color:var(--surface-light);border-radius:4px;margin-bottom:.75rem}.skeleton-text{height:16px;background-color:var(--surface-light);border-radius:4px;margin-bottom:.5rem}.skeleton-text.short{width:60%}.skeleton-list-item{background-color:var(--surface);padding:1rem;border-radius:6px;margin-bottom:.5rem;animation:skeleton-pulse 1.5s ease-in-out infinite}@keyframes skeleton-pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}
