:root{--bg-primary: #121218;--bg-secondary: #1a1a24;--bg-tertiary: #242430;--bg-card: #1e1e28;--text-primary: #ffffff;--text-secondary: #a0a0b0;--text-muted: #707080;--accent: #6366f1;--accent-hover: #4f46e5;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--border: #353545;--gold: #ffd700;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .3);--radius: 8px;--radius-lg: 12px}[data-theme=light]{--bg-primary: #f8f9fa;--bg-secondary: #ffffff;--bg-tertiary: #e9ecef;--bg-card: #ffffff;--text-primary: #1a1a2e;--text-secondary: #4a4a5a;--text-muted: #8a8a9a;--border: #dee2e6;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}button{color:inherit;font-family:inherit}html,body{font-size:16px;min-height:100%;height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6}.app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-primary)}.main-content{flex:1;padding:20px;max-width:1600px;margin:0 auto;width:100%;background-color:var(--bg-primary)}.navbar-toolbar{display:flex;align-items:center;gap:8px}.toolbar-search{flex:1;min-width:120px}.desktop-controls{display:flex;align-items:center;gap:8px}.mobile-controls{display:none}.view-select{width:auto;padding:6px 10px}.settings-menu{position:relative}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:199}.settings-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 12px #00000026;min-width:180px;z-index:200;overflow:hidden}.settings-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;background:none;border:none;color:var(--text-primary);font-size:.9rem;cursor:pointer;text-align:left}.settings-item:hover{background:var(--bg-tertiary)}.settings-item select{flex:1;padding:4px 8px;font-size:.85rem}.settings-divider{height:1px;background:var(--border);margin:4px 0}.rating-scale-dropdown{padding:8px 12px;background:var(--bg-tertiary)}.rating-scale-row{display:flex;align-items:center;gap:10px;padding:4px 0}.rating-scale-row .rating-scale-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 6px;border-radius:4px;font-weight:700;font-size:.8rem}.rating-scale-row .rating-scale-label{font-size:.8rem;color:var(--text-secondary)}.loading,.error{display:flex;align-items:center;justify-content:center;min-height:200px;font-size:1.1rem;color:var(--text-secondary)}.error{color:var(--error)}.navbar{background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:12px 20px;position:sticky;top:0;z-index:100}.navbar-content{max-width:1600px;margin:0 auto;display:flex;flex-direction:column;gap:12px}.navbar-top{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}.navbar-brand{font-size:1.25rem;font-weight:700;background:linear-gradient(90deg,#ff0080,#ff8c00,#fd0,#00ff80,#00bfff,#8000ff,#ff0080);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 3s linear infinite}@keyframes shimmer{0%{background-position:0% center}to{background-position:200% center}}@keyframes legendaryPulse{0%,to{box-shadow:0 0 5px #ffd70066,0 0 10px #ffd7004d,0 0 15px #ffd70033}50%{box-shadow:0 0 10px #ffd70099,0 0 20px #ffd70066,0 0 30px #ffd7004d}}@keyframes shimmerLoad{0%{background-position:-200% 0}to{background-position:200% 0}}.info-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:8px 0}.info-card{background:var(--bg-tertiary);border-radius:var(--radius);padding:12px;transition:transform .2s ease,background .2s ease,box-shadow .2s ease;position:relative}.info-card:hover{transform:translateY(-2px);background:var(--bg-card);box-shadow:var(--shadow);cursor:pointer}.info-card.legendary{animation:legendaryPulse 2s ease-in-out infinite;border:1px solid rgba(255,215,0,.3)}.info-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;gap:8px}.info-card-title-row{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.info-card-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);line-height:1.3}.info-card-watch-count{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;padding:2px 6px;border-radius:4px;font-size:.7rem;font-weight:600;white-space:nowrap}.info-card-rating{background:var(--accent);color:#fff;padding:3px 7px;border-radius:var(--radius);font-size:.8rem;font-weight:600;white-space:nowrap}.info-card-rating.perfect{background:#c084fc}.rating-1{background:#b91c1c!important}.rating-2{background:#dc2626!important}.rating-3{background:#ef4444!important}.rating-4{background:#f87171!important}.rating-5{background:#fb923c!important}.rating-6{background:#facc15!important;color:#1a1a2e!important}.rating-7{background:#22d3ee!important;color:#1a1a2e!important}.rating-8{background:#60a5fa!important}.rating-9{background:#4ade80!important;color:#1a1a2e!important}.rating-10{background:#c084fc!important}.rating-badge{display:inline-block;padding:3px 8px;border-radius:var(--radius);font-size:.85rem;font-weight:600;color:#fff;background:var(--accent)}.rating-badge-inline{display:inline-block;padding:2px 6px;border-radius:4px;font-size:.85rem;font-weight:600;color:#fff;background:var(--accent);margin-left:4px}.wishlist-controls{display:flex;flex-direction:column;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.priority-control{display:flex;align-items:center;gap:8px}.priority-badge{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;padding:4px 10px;border-radius:12px;font-size:.85rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.priority-badge:hover{transform:scale(1.05);box-shadow:0 2px 8px #8b5cf666}.priority-edit{display:flex;align-items:center;gap:6px}.priority-input{width:50px;padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem;text-align:center}.reserve-control{display:flex;flex-direction:column;gap:6px}.reserved-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.reserved-by{color:var(--warning);font-size:.85rem;font-weight:500}.reserve-form{display:flex;gap:6px;flex-wrap:wrap}.reserve-input{flex:1;min-width:100px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem}.btn-reserve{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;padding:6px 12px;border-radius:var(--radius);font-weight:500;cursor:pointer;transition:transform .15s,box-shadow .15s}.btn-reserve:hover{transform:scale(1.03);box-shadow:0 2px 8px #f59e0b66}.btn-sm{padding:4px 10px;font-size:.85rem}.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:var(--radius);cursor:pointer}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer}.info-card-quick-watch{position:absolute;top:8px;right:8px;padding:4px 8px;font-size:.8rem;background:var(--accent);opacity:0;transition:opacity .2s}.info-card:hover .info-card-quick-watch{opacity:1}@media(max-width:768px){.info-card-quick-watch{display:none!important}}@media(hover:none){.info-card-quick-watch{display:none!important}}.info-card-details{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px}.info-card-detail{display:flex;flex-direction:column;gap:1px}.info-card-detail-label{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.info-card-detail-value{font-size:.75rem;color:var(--text-secondary)}.shimmer-placeholder{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-secondary) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmerLoad 1.5s ease-in-out infinite}.poster-card.loading .poster-card-img{opacity:0}.poster-card .shimmer-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;border-radius:var(--radius)}.owned-badge{display:inline-block;padding:3px 8px;border-radius:var(--radius);font-size:.75rem;font-weight:600}.owned-badge.yes{background:#065f46;color:#6ee7b7}.owned-badge.no{background:#7c2d12;color:#fca5a5}.watch-count-table-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border-radius:var(--radius);font-size:.75rem;font-weight:600}.wishlist-badge{position:absolute;right:10px;padding:4px 10px;border-radius:var(--radius);font-size:.7rem;font-weight:600;color:#fff;z-index:5}.wishlist-badge.reserved{top:10px;background:linear-gradient(135deg,#f59e0b,#d97706)}.wishlist-badge.boxset{top:38px;background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.movie-detail-collection-info{display:flex;flex-direction:column;gap:8px;margin:12px 0}.collection-info-item{display:flex;align-items:center;gap:8px;padding:10px 14px;background:linear-gradient(135deg,var(--bg-tertiary),transparent);border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;color:var(--text-secondary)}.collection-info-item .collection-icon{font-size:1.1rem}.info-banner{background:var(--bg-tertiary);border-left:4px solid var(--accent);padding:16px 20px;margin-bottom:20px;border-radius:0 var(--radius) var(--radius) 0;display:flex;align-items:center;gap:12px}.info-banner-icon{font-size:1.5rem}.info-banner-text{color:var(--text-secondary);font-size:.95rem;line-height:1.5}.legendary{animation:legendaryPulse 2s ease-in-out infinite}.movie-list-row.legendary{background:linear-gradient(90deg,#ffd7000d,#ffd7001a,#ffd7000d);border:1px solid rgba(255,215,0,.2)}.poster-card.legendary{animation:legendaryPulse 2s ease-in-out infinite}.navbar-brand-section{display:flex;flex-direction:column;gap:4px}.quick-stats{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.stat{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--text-secondary);cursor:default}.stat-icon{font-size:.85rem}.stat-value{font-weight:600;color:var(--text-primary)}.search-input{padding:8px 16px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:.9rem}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{outline:none;border-color:var(--accent)}.navbar-actions{display:flex;align-items:center;gap:8px}.tabs{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;padding-bottom:10px;border-bottom:1px solid var(--border)}.tabs::-webkit-scrollbar{display:none}.tab{padding:8px 16px;background:transparent;border:none;border-radius:var(--radius);color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s}.tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.tab.active{background:var(--accent);color:#fff}.tab-count{margin-left:6px;opacity:.7}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-icon{padding:8px;background:transparent;border:1px solid var(--border);color:var(--text-primary)}.btn-icon:hover{background:var(--bg-tertiary)}.btn-icon.btn-active{background:var(--accent);border-color:var(--accent);color:#fff}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{background:#dc2626}.movie-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.movie-card{background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;position:relative}.movie-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.movie-card.gold-border{box-shadow:0 0 0 2px var(--gold),var(--shadow)}.movie-card-poster{aspect-ratio:2/3;background:var(--bg-tertiary);position:relative}.movie-card-poster img{width:100%;height:100%;object-fit:cover}.movie-card-overlay{position:absolute;bottom:0;left:0;right:0;padding:40px 12px 12px;background:linear-gradient(transparent,#000000e6)}.movie-card-title{font-size:.95rem;font-weight:600;color:#fff;margin-bottom:4px}.movie-card-meta{font-size:.8rem;color:#ffffffb3}.movie-card-rating{position:absolute;top:8px;right:8px;background:#000000b3;padding:4px 8px;border-radius:var(--radius);font-size:.85rem;font-weight:600;color:#fff}.movie-card-rating.perfect{background:var(--gold);color:#000}.poster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.poster-card{aspect-ratio:2/3;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;position:relative}.poster-card.gold-border{box-shadow:0 0 0 3px var(--gold)}.poster-card img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.poster-card:hover img{transform:scale(1.05)}.poster-card-overlay{position:absolute;bottom:0;left:0;right:0;padding:20px;background:linear-gradient(transparent,#000000f2);opacity:0;transition:opacity .3s}.poster-card:hover .poster-card-overlay{opacity:1}.movie-table{width:100%;border-collapse:collapse;background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden}.movie-table th,.movie-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}.movie-table th{background:var(--bg-tertiary);font-weight:600;font-size:.85rem;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.movie-table th:hover{color:var(--text-primary)}.movie-table th.sorted{color:var(--accent)}.movie-table tr{cursor:pointer;transition:background .2s}.movie-table tbody tr:hover{background:var(--bg-tertiary)}.movie-table-title{display:flex;align-items:center;gap:12px}.movie-table-poster{width:40px;height:60px;border-radius:4px;object-fit:cover}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-secondary);border-radius:var(--radius-lg);max-width:900px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-title{font-size:1.25rem;font-weight:600}.modal-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;font-size:1.5rem;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:20px;overflow-y:auto;flex:1;min-height:0}.modal>form{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.sort-options{display:flex;flex-direction:column}.sort-option{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;background:transparent;border:none;border-bottom:1px solid var(--border);cursor:pointer;font-size:.95rem;color:var(--text-primary);transition:background .15s ease}.sort-option:last-child{border-bottom:none}.sort-option:hover{background:var(--bg-tertiary)}.sort-option.active{background:var(--bg-tertiary);color:var(--accent);font-weight:600}.sort-direction{font-size:.8rem;color:var(--text-muted);font-weight:400}.checkbox-large{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-tertiary);border-radius:var(--radius);cursor:pointer}.checkbox-large input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--accent)}.checkbox-large span{font-size:.95rem}.movie-detail{display:grid;grid-template-columns:300px 1fr;gap:24px}.movie-detail-poster{width:100%;aspect-ratio:2/3;border-radius:var(--radius);object-fit:cover}.movie-detail-info h1{font-size:1.75rem;margin-bottom:8px}.movie-detail-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px;color:var(--text-secondary);font-size:.9rem}.movie-detail-rating{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-tertiary);border-radius:var(--radius);font-weight:600}.movie-detail-rating.perfect{background:var(--gold);color:#000}.watch-count-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-tertiary);border-radius:var(--radius);font-weight:500;font-size:.9rem;color:var(--text-secondary)}.watch-count-badge.rewatched{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff}.watch-history-section{margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.watch-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.watch-history-header h4{margin:0;font-size:.95rem;color:var(--text-primary)}.watch-history-dates{display:flex;flex-wrap:wrap;gap:8px}.watch-date-badge{padding:6px 12px;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:var(--radius);font-size:.85rem}.watch-date-badge.latest{background:var(--accent);color:#fff}.watch-date-rating{margin-left:8px;font-weight:500}.watch-date-latest{margin-left:6px;font-size:.75rem;opacity:.85}.rewatch-prompt{text-align:center}.movie-detail-genres{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.genre-tag{padding:4px 10px;background:var(--bg-tertiary);border-radius:var(--radius);font-size:.8rem;color:var(--text-secondary)}.movie-detail-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:12px}.movie-detail-tab{padding:8px 16px;background:transparent;border:none;border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;font-size:.9rem}.movie-detail-tab.active{background:var(--accent);color:#fff}.movie-detail-tab.amazon-tab{background:linear-gradient(135deg,#f90,#f60);color:#fff;text-decoration:none;font-weight:500;margin-left:auto;transition:all .2s ease}.movie-detail-tab.amazon-tab:hover{background:linear-gradient(135deg,#fa2,#f71);transform:translateY(-1px);box-shadow:0 4px 12px #ff99004d}.add-movie-preview{display:flex;gap:16px;padding:16px;background:var(--bg-tertiary);border-radius:var(--radius);margin-bottom:20px}.add-movie-preview-poster{width:80px;height:120px;object-fit:cover;border-radius:4px;flex-shrink:0}.add-movie-preview-info{flex:1;min-width:0}.form-group{margin-bottom:16px}.form-label{display:block;margin-bottom:6px;font-size:.9rem;font-weight:500;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:.95rem}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent)}.form-textarea{resize:vertical;min-height:100px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.achievement-toast{position:fixed;bottom:20px;right:20px;background:var(--bg-secondary);border:1px solid var(--gold);border-radius:var(--radius-lg);padding:16px 20px;display:flex;align-items:center;gap:16px;box-shadow:0 0 20px #ffd7004d;animation:slideInRight .4s;z-index:300}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.achievement-icon{font-size:2rem}.achievement-info h4{color:var(--gold);font-size:.9rem;margin-bottom:2px}.achievement-info p{font-size:1rem;font-weight:600}.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.news-card{background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;transition:transform .2s}.news-card:hover{transform:translateY(-4px)}.news-card a{text-decoration:none;color:inherit}.news-card-image{aspect-ratio:16/9;background:var(--bg-tertiary)}.news-card-image img{width:100%;height:100%;object-fit:cover}.news-card-content{padding:16px}.news-card-title{font-size:1rem;font-weight:600;margin-bottom:8px;line-height:1.4}.news-card-source{font-size:.8rem;color:var(--text-muted)}.recommendations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:12px}.recommendations-header h2{margin:0;font-size:1.5rem}@media(max-width:480px){.recommendations-header{flex-direction:column;align-items:stretch;text-align:center}.recommendations-header h2{font-size:1.25rem;margin-bottom:8px}.recommendations-header .btn{width:100%}}.recommendation-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:16px;display:flex;gap:16px;margin-bottom:16px}.recommendation-poster{width:80px;height:120px;border-radius:var(--radius);object-fit:cover;flex-shrink:0}.recommendation-info h3{font-size:1.1rem;margin-bottom:4px}.recommendation-from{font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.recommendation-message{font-size:.9rem;color:var(--text-secondary);font-style:italic}.recommendation-actions{display:flex;gap:8px;margin-top:12px}.scanner-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:300;display:flex;flex-direction:column}.scanner-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#000c}.scanner-header h2{color:#fff}.scanner-video{flex:1;min-height:0;overflow:hidden}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.stat-card{background:var(--bg-tertiary);border-radius:var(--radius);padding:16px}.stat-card h3{font-size:.9rem;color:var(--text-secondary);margin-bottom:12px}.achievements-modal{max-width:800px}.achievements-summary{display:flex;justify-content:center;gap:40px;padding:16px;background:var(--bg-tertiary);border-radius:var(--radius);margin-bottom:16px}.achievement-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.achievement-stat-value{font-size:2rem;font-weight:700;color:var(--accent)}.achievement-stat-label{font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.achievements-progress{height:6px;background:var(--bg-tertiary);border-radius:3px;margin-bottom:16px;overflow:hidden}.achievements-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--success));border-radius:3px;transition:width .3s ease}.achievements-categories{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.category-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:20px;cursor:pointer;font-size:.85rem;color:var(--text-secondary);transition:all .2s ease}.category-btn:hover{background:var(--bg-card);color:var(--text-primary)}.category-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.category-icon{font-size:1rem}.category-count{font-size:.75rem;opacity:.8}.achievements-list{max-height:400px;overflow-y:auto}.achievements-category{margin-bottom:20px}.achievements-category:last-child{margin-bottom:0}.achievements-category-title{font-size:1rem;font-weight:600;margin-bottom:12px;color:var(--text-primary);display:flex;align-items:center;gap:8px}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}.achievement-card{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:var(--radius);transition:all .2s ease;position:relative}.achievement-card.locked{opacity:.5;filter:grayscale(.5)}.achievement-card.unlocked{background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(99,102,241,.1) 100%);border:1px solid rgba(99,102,241,.3)}.achievement-icon{font-size:1.75rem;flex-shrink:0}.achievement-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.achievement-name{font-weight:600;font-size:.9rem;color:var(--text-primary)}.achievement-description{font-size:.8rem;color:var(--text-muted);line-height:1.3}.achievement-check{position:absolute;top:8px;right:8px;color:var(--success);font-size:1rem;font-weight:700}.rating-scale-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}.rating-scale-item{display:flex;align-items:center;gap:10px;padding:6px 8px;background:var(--bg-secondary);border-radius:var(--radius)}.rating-scale-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 8px;border-radius:6px;font-weight:700;font-size:.9rem;color:#fff}.rating-scale-label{font-size:.85rem;color:var(--text-primary)}.filter-section{margin-bottom:20px}.filter-section h4{font-size:.9rem;color:var(--text-secondary);margin-bottom:10px}.filter-chips{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{padding:6px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:20px;font-size:.85rem;color:var(--text-primary);cursor:pointer;transition:all .2s}.filter-chip:hover,.filter-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.login-form{max-width:400px;margin:0 auto;padding:40px 20px}.login-form h2{text-align:center;margin-bottom:24px}@media(max-width:1024px){.movie-detail{grid-template-columns:200px 1fr}}@media(max-width:768px){.desktop-controls{display:none}.mobile-controls{display:flex;flex-direction:row;align-items:center;gap:4px}.navbar-top{flex-wrap:nowrap}.navbar-brand-section{flex:1;min-width:0;overflow:hidden}.navbar-actions{flex-shrink:0;gap:2px}.navbar-actions .btn-icon{padding:4px 6px;font-size:.9rem}.navbar-toolbar{flex-wrap:wrap}.toolbar-search{flex:1;min-width:100px}.quick-stats{gap:8px}.stat{font-size:.7rem}.stat-icon{font-size:.75rem}.tabs{flex-wrap:wrap;justify-content:center;overflow-x:visible}.tab{padding:6px 10px;font-size:.85rem}.movie-detail{grid-template-columns:1fr}.movie-detail-poster{max-width:200px;margin:0 auto}.movie-detail-tab.amazon-tab{padding:6px 10px;font-size:.8rem}.movie-grid,.poster-grid{grid-template-columns:repeat(3,1fr);gap:10px}.poster-card-overlay{opacity:1;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.5) 80%,transparent 100%);padding:30px 8px 8px}.poster-card:hover img{transform:none}.movie-card:hover{transform:none;box-shadow:none}.movie-card-overlay{opacity:1;background:linear-gradient(transparent,#000000d9)}.movie-card-title{font-size:.85rem;line-height:1.2}.movie-card-meta{font-size:.7rem}.movie-table th,.movie-table td{padding:8px 10px;font-size:.85rem}.modal-overlay{padding:0;align-items:stretch}.modal{max-height:100vh;max-height:100dvh;height:100%;border-radius:0}.modal-body{padding:16px}.btn{min-height:44px;min-width:44px}.form-input,.form-select,.form-textarea{font-size:16px}.login-modal.modal-overlay{align-items:flex-start;padding-top:60px}.login-modal .modal{height:auto;max-height:none;border-radius:var(--radius-lg);margin:0 16px;width:calc(100% - 32px)}.feedback-review-modal{display:flex;flex-direction:column}.feedback-review-modal .modal-body{flex:1;min-height:0}}@media(max-width:480px){.tabs{gap:2px}.tab{padding:5px 8px;font-size:.8rem}.movie-grid,.poster-grid{grid-template-columns:repeat(2,1fr);gap:8px}.toolbar-search{min-width:80px}.navbar-toolbar .btn-primary span{display:none}.navbar-toolbar .btn-primary:before{content:"+"}.quick-stats{gap:6px}.stat{font-size:.65rem;gap:2px}.stat-icon{font-size:.7rem}.movie-card-title{font-size:.75rem}.movie-card-meta{font-size:.65rem}.poster-card-overlay{padding:20px 6px 6px}.poster-card-overlay h3{font-size:.75rem}.watch-count-badge{padding:4px 8px;font-size:.8rem}}@media(max-width:400px){.movie-grid,.poster-grid{gap:6px}.movie-card-overlay{padding:20px 8px 8px}}@media(max-width:320px){html{font-size:14px}.movie-grid,.poster-grid{grid-template-columns:1fr 1fr;gap:4px}.stat:nth-child(5){display:none}.main-content{padding:10px}.movie-card-title{font-size:.7rem}.movie-card-rating{padding:2px 4px;font-size:.7rem}}.scroll-buttons{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:100}.scroll-btn{width:44px;height:44px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000004d;transition:transform .2s,background-color .2s,box-shadow .2s}.scroll-btn:hover{transform:scale(1.1);background:var(--accent-hover);box-shadow:0 4px 12px #0006}.scroll-btn:active{transform:scale(.95)}@media(max-width:768px){.scroll-buttons{bottom:15px;right:15px}.scroll-btn{width:40px;height:40px;font-size:18px}}.toast-container{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:10000;display:flex;flex-direction:column;gap:10px;max-width:90%;width:400px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius);background:var(--bg-secondary);border:1px solid var(--border);box-shadow:0 4px 20px #0000004d;animation:toastSlideIn .3s ease;pointer-events:auto;cursor:pointer}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.toast-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:14px;font-weight:700;flex-shrink:0}.toast-success .toast-icon{background:var(--success);color:#fff}.toast-error .toast-icon{background:var(--error);color:#fff}.toast-warning .toast-icon{background:var(--warning);color:#1a1a24}.toast-info .toast-icon{background:var(--accent);color:#fff}.toast-message{flex:1;font-size:14px;color:var(--text-primary);line-height:1.4}.toast-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:0 4px;line-height:1;opacity:.6;transition:opacity .2s}.toast-close:hover{opacity:1}@media(max-width:768px){.toast-container{bottom:70px;width:calc(100% - 20px);max-width:none}.toast{padding:12px 14px}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 0%,var(--bg-secondary) 50%,var(--bg-tertiary) 100%);background-size:200% 100%;animation:skeletonShimmer 1.5s ease-in-out infinite;border-radius:4px}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{pointer-events:none}.skeleton-text{display:inline-block}.skeleton-badge{border-radius:12px}.skeleton-poster{pointer-events:none}.button-spinner{display:inline-block;width:14px;height:14px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:buttonSpin .8s linear infinite;margin-right:6px;vertical-align:middle}@keyframes buttonSpin{to{transform:rotate(360deg)}}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:var(--radius)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:buttonSpin .8s linear infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-muted);grid-column:1 / -1}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.8}.empty-state-title{font-size:1.25rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.empty-state-message{font-size:.95rem;color:var(--text-muted);max-width:300px;line-height:1.5}.help-modal .modal-body{padding:20px}.shortcuts-grid{display:flex;flex-direction:column;gap:8px}.shortcut-row{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--radius)}.shortcut-row.shortcut-disabled{opacity:.5}.shortcut-key{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:28px;padding:0 8px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;font-family:monospace;font-size:.85rem;font-weight:600;color:var(--text-primary);box-shadow:0 2px 0 var(--border)}.shortcut-description{flex:1;font-size:.9rem;color:var(--text-secondary);display:flex;align-items:center;gap:8px}.shortcut-admin-badge{font-size:.7rem;padding:2px 6px;background:var(--accent);color:#fff;border-radius:10px;font-weight:500}.help-tips{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.help-tips h4{margin:0 0 12px;font-size:.95rem;color:var(--text-primary)}.help-tips ul{margin:0;padding-left:20px;color:var(--text-muted);font-size:.85rem;line-height:1.8}.help-tips li{margin-bottom:4px}.similar-movies-section{margin-top:8px}.similar-movies-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media(max-width:600px){.similar-movies-grid{grid-template-columns:repeat(2,1fr)}}.similar-movie-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;background:var(--bg-tertiary);border-radius:var(--radius);overflow:hidden;transition:transform .2s,box-shadow .2s}.similar-movie-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.similar-movie-poster{width:100%;aspect-ratio:2/3;object-fit:cover}.similar-movie-no-poster{background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.8rem}.similar-movie-info{padding:8px 10px}.similar-movie-title{font-size:.85rem;font-weight:500;color:var(--text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.similar-movie-meta{display:flex;gap:8px;margin-top:4px;font-size:.75rem;color:var(--text-muted)}.tag-input-container{position:relative}.tag-input-wrapper{display:flex;flex-wrap:wrap;gap:6px;padding:8px 10px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);min-height:42px;align-items:center}.tag-input-wrapper:focus-within{border-color:var(--accent);outline:none}.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:var(--accent);color:#fff;border-radius:12px;font-size:.85rem;font-weight:500}.tag-chip-remove{background:none;border:none;color:#fff;font-size:14px;cursor:pointer;padding:0;line-height:1;opacity:.8;margin-left:2px}.tag-chip-remove:hover{opacity:1}.tag-input-field{flex:1;min-width:120px;border:none;background:none;outline:none;font-size:.9rem;color:var(--text-primary);padding:2px}.tag-input-field::placeholder{color:var(--text-muted)}.tag-add-btn{background:var(--accent);color:#fff;border:none;border-radius:50%;width:26px;height:26px;font-size:18px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .15s ease,background .15s ease}.tag-add-btn:hover{background:var(--accent-hover, var(--accent));transform:scale(1.1)}.tag-add-btn:active{transform:scale(.95)}.tag-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);margin-top:4px;z-index:100;max-height:150px;overflow-y:auto;box-shadow:0 4px 12px #0003}.tag-suggestion{display:block;width:100%;padding:8px 12px;text-align:left;background:none;border:none;color:var(--text-primary);cursor:pointer;font-size:.9rem}.tag-suggestion:hover{background:var(--bg-tertiary)}.tags-display{display:flex;flex-wrap:wrap;column-gap:6px;row-gap:4px;margin-top:4px;margin-bottom:12px}.tag-badge{display:inline-block;padding:4px 10px;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:12px;font-size:.8rem}.franchise-view{padding:20px;display:flex;flex-direction:column;gap:32px}.franchise-group{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:20px;border:1px solid var(--border)}.franchise-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.franchise-icon{font-size:1.5rem}.franchise-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;flex:1}.franchise-count{font-size:.85rem;color:var(--text-muted);background:var(--bg-tertiary);padding:4px 10px;border-radius:12px}.franchise-movies{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}.franchise-movie-card{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;border-radius:var(--radius);overflow:hidden;background:var(--bg-tertiary)}.franchise-movie-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.franchise-movie-card.legendary{box-shadow:0 0 0 2px var(--legendary-border)}.franchise-movie-card.legendary:hover{box-shadow:0 0 0 2px var(--legendary-border),0 8px 24px #c484fc4d}.franchise-movie-poster{width:100%;aspect-ratio:2/3;object-fit:cover;display:block}.franchise-movie-poster.no-poster{display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-muted);font-size:2rem;font-weight:700}.franchise-movie-info{padding:10px;display:flex;flex-direction:column;gap:4px}.franchise-movie-title{font-size:.85rem;font-weight:500;color:var(--text-primary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}.franchise-movie-year{font-size:.75rem;color:var(--text-muted)}.franchise-movie-rating{display:inline-block;padding:2px 6px;border-radius:4px;font-size:.7rem;font-weight:600;width:fit-content;color:#fff}.franchise-movie-rating.rating-10{background:#c084fc}.franchise-movie-rating.rating-9{background:#4ade80;color:#1a1a2e}.franchise-movie-rating.rating-8{background:#60a5fa}.franchise-movie-rating.rating-7{background:#22d3ee;color:#1a1a2e}.franchise-movie-rating.rating-6{background:#facc15;color:#1a1a2e}.franchise-movie-rating.rating-5{background:#fb923c}.franchise-movie-rating.rating-4{background:#f87171}.franchise-movie-rating.rating-3{background:#ef4444}.franchise-movie-rating.rating-2{background:#dc2626}.franchise-movie-rating.rating-1{background:#b91c1c}.franchise-group.standalone{background:transparent;border:1px dashed var(--border)}@media(max-width:768px){.franchise-view{padding:12px;gap:24px}.franchise-group{padding:16px}.franchise-header{flex-wrap:wrap}.franchise-name{font-size:1.1rem}.franchise-movies{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.franchise-movie-title{font-size:.75rem}.franchise-movie-info{padding:8px}}.bulk-actions-bar{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:2px solid var(--accent);padding:12px 20px;display:flex;justify-content:space-between;align-items:center;z-index:100;box-shadow:0 -4px 20px #00000026}.bulk-actions-info{display:flex;align-items:center;gap:8px}.bulk-actions-count{background:var(--accent);color:#fff;font-weight:600;padding:4px 12px;border-radius:16px;font-size:1rem}.bulk-actions-label{color:var(--text-secondary);font-size:.9rem}.bulk-actions-buttons{display:flex;gap:10px;align-items:center}.bulk-move-dropdown{position:relative}.bulk-move-menu{position:absolute;bottom:100%;left:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 -4px 12px #00000026;margin-bottom:8px;min-width:150px;overflow:hidden}.bulk-move-item{display:block;width:100%;padding:10px 16px;background:none;border:none;color:var(--text-primary);text-align:left;cursor:pointer;font-size:.9rem}.bulk-move-item:hover{background:var(--bg-tertiary)}.selection-checkbox{position:absolute;top:8px;left:8px;z-index:10;width:24px;height:24px;cursor:pointer}.selection-checkbox input{width:20px;height:20px;cursor:pointer;accent-color:var(--accent)}.info-card.selecting{cursor:pointer}.info-card.selected{outline:3px solid var(--accent);outline-offset:-3px}.poster-card.selecting{cursor:pointer}.poster-card.selected{outline:3px solid var(--accent);outline-offset:-3px}.movie-list-row.selected{background:#6366f126}.btn-select-mode{background:var(--bg-tertiary);border:1px solid var(--border)}.btn-select-mode.active{background:var(--accent);border-color:var(--accent);color:#fff}@media(max-width:768px){.bulk-actions-bar{flex-direction:column;gap:12px;padding:16px}.bulk-actions-buttons{width:100%;justify-content:stretch}.bulk-actions-buttons .btn{flex:1}.bulk-move-menu{left:auto;right:0}}.dashboard{padding:20px;max-width:1400px;margin:0 auto;overflow-x:hidden}.dashboard-loading,.dashboard-error{padding:40px;text-align:center;color:var(--text-muted)}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:16px;margin-bottom:24px}.dash-stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;text-align:center}.dash-stat-value{font-size:1.6rem;font-weight:700;line-height:1.2}.dash-stat-label{font-size:.85rem;color:var(--text-muted);margin-top:4px}.feedback-banner{background:linear-gradient(135deg,var(--accent-gradient-start, #6366f1) 0%,var(--accent-gradient-end, #8b5cf6) 100%);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:24px}.feedback-banner-content{display:flex;align-items:center;justify-content:space-between;gap:16px}.feedback-banner-text{display:flex;align-items:center;gap:12px;color:#fff}.feedback-banner-icon{font-size:1.75rem;flex-shrink:0}.feedback-banner-text strong{display:block;font-size:1rem;margin-bottom:2px}.feedback-banner-text p{margin:0;font-size:.85rem;opacity:.9}.feedback-banner-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;white-space:nowrap;flex-shrink:0}.feedback-banner-btn:hover{background:#ffffff4d}@media(max-width:600px){.feedback-banner-content{flex-direction:column;text-align:center}.feedback-banner-text{flex-direction:column}.feedback-banner-btn{width:100%}}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:24px}.dashboard-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;overflow:hidden;min-width:0}.dashboard-section-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.dashboard-empty{color:var(--text-muted);font-size:.9rem;text-align:center;padding:20px 0}.recent-watches{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto}.recent-watch-item{display:flex;align-items:center;gap:12px;padding:8px;border-radius:var(--radius);cursor:pointer;transition:background .2s ease}.recent-watch-item:hover{background:var(--bg-tertiary)}.recent-watch-poster{width:45px;height:68px;object-fit:cover;border-radius:4px;flex-shrink:0}.recent-watch-poster.no-poster{display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-muted);font-weight:700}.recent-watch-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.recent-watch-title{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-watch-date{font-size:.8rem;color:var(--text-muted)}.recent-watch-rating{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.75rem;font-weight:600;color:#fff}.top-rated-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.top-rated-card{cursor:pointer;transition:transform .2s ease}.top-rated-card:hover{transform:translateY(-4px)}.top-rated-poster{width:100%;aspect-ratio:2/3;object-fit:cover;border-radius:var(--radius)}.top-rated-poster.no-poster{display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-muted);font-size:1.5rem;font-weight:700}.top-rated-info{margin-top:6px;text-align:center}.top-rated-title{display:block;font-size:.75rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-rated-rating{display:inline-block;padding:2px 6px;border-radius:4px;font-size:.7rem;font-weight:600;color:#fff;margin-top:4px}.up-next-list{display:flex;flex-direction:column;gap:10px}.up-next-item{display:flex;align-items:center;gap:12px;padding:8px;border-radius:var(--radius);cursor:pointer;transition:background .2s ease}.up-next-item:hover{background:var(--bg-tertiary)}.up-next-poster{width:40px;height:60px;object-fit:cover;border-radius:4px;flex-shrink:0}.up-next-poster.no-poster{display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-muted);font-weight:700}.up-next-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.up-next-title{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-next-meta{font-size:.8rem;color:var(--text-muted)}.genre-bars{display:flex;flex-direction:column;gap:8px}.genre-bar-item{display:flex;align-items:center;gap:10px}.genre-bar-label{width:80px;font-size:.85rem;color:var(--text-secondary);text-align:right;flex-shrink:0}.genre-bar-track{flex:1;min-width:0;height:12px;background:var(--bg-tertiary);border-radius:6px;overflow:hidden}.genre-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#8b5cf6);border-radius:6px;transition:width .3s ease}.genre-bar-count{width:30px;font-size:.8rem;color:var(--text-muted);text-align:left}.dashboard-footer{display:flex;justify-content:center;gap:40px;margin-top:24px;padding:20px;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border)}.dashboard-footer-stat{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.9rem}.footer-stat-icon{font-size:1.2rem}@media(max-width:768px){.dashboard{padding:12px;max-width:100%;box-sizing:border-box}.dashboard-stats{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}.feedback-banner,.chat-panel,.dashboard-grid{margin-bottom:16px}.dash-stat-card{padding:12px}.dash-stat-value{font-size:1.5rem}.dash-stat-label{font-size:.75rem}.dashboard-grid{grid-template-columns:1fr;gap:16px}.dashboard-section{padding:16px}.dashboard-footer{flex-direction:column;gap:12px;align-items:center}.genre-bar-label{width:60px;font-size:.75rem}.genre-bar-item{max-width:100%}}@media(max-width:480px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}.year-review-overlay{background:#000000f2}.year-review-modal{position:relative;width:100%;max-width:450px;height:80vh;max-height:700px;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);border-radius:24px;overflow:hidden;display:flex;flex-direction:column}.year-review-modal.slide-0{background:linear-gradient(135deg,#667eea,#764ba2)}.year-review-modal.slide-1{background:linear-gradient(135deg,#f093fb,#f5576c)}.year-review-modal.slide-2{background:linear-gradient(135deg,#4facfe,#00f2fe)}.year-review-modal.slide-3{background:linear-gradient(135deg,#43e97b,#38f9d7)}.year-review-modal.slide-4{background:linear-gradient(135deg,#fa709a,#fee140)}.year-review-modal.slide-5{background:linear-gradient(135deg,#a18cd1,#fbc2eb)}.year-review-modal.slide-6{background:linear-gradient(135deg,#ff9a9e,#fecfef)}.year-review-modal.slide-7{background:linear-gradient(135deg,#ffecd2,#fcb69f)}.year-review-modal.slide-8{background:linear-gradient(135deg,#a1c4fd,#c2e9fb)}.year-review-modal.slide-9{background:linear-gradient(135deg,#667eea,#764ba2)}.yr-top-controls{position:absolute;top:16px;right:16px;display:flex;gap:8px;z-index:10}.yr-close,.yr-music-toggle{width:36px;height:36px;background:#fff3;border:none;border-radius:50%;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.yr-close{font-size:1.5rem}.yr-close:hover,.yr-music-toggle:hover{background:#ffffff4d}.yr-content{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;transition:opacity .3s ease,transform .3s ease}.yr-content.yr-animating{opacity:0;transform:scale(.95)}.yr-slide{width:100%;text-align:center;color:#fff;animation:slideIn .5s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.yr-slide-intro .yr-year-badge{font-size:5rem;font-weight:900;text-shadow:0 4px 20px rgba(0,0,0,.3);margin-bottom:16px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.yr-slide-intro h1{font-size:2rem;font-weight:700;margin-bottom:8px}.yr-subtitle{font-size:1.1rem;opacity:.9}.yr-tap-hint{position:absolute;bottom:80px;left:0;right:0;font-size:.9rem;opacity:.7;animation:bounce 1.5s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.yr-label{font-size:1.2rem;opacity:.9;margin:8px 0}.yr-big-number{font-size:6rem;font-weight:900;line-height:1;text-shadow:0 4px 20px rgba(0,0,0,.3);animation:countUp .8s ease-out}@keyframes countUp{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.yr-detail{font-size:1rem;opacity:.8;margin-top:16px}.yr-slide-genres h2,.yr-slide-directors h2{font-size:1.8rem;margin-bottom:24px}.yr-genre-list,.yr-director-list{display:flex;flex-direction:column;gap:12px}.yr-genre-item,.yr-director-item{display:flex;align-items:center;gap:12px;background:#ffffff26;padding:12px 16px;border-radius:12px;animation:slideInLeft .5s ease;animation-fill-mode:both}.yr-genre-item:nth-child(1){animation-delay:.1s}.yr-genre-item:nth-child(2){animation-delay:.2s}.yr-genre-item:nth-child(3){animation-delay:.3s}.yr-genre-item:nth-child(4){animation-delay:.4s}.yr-genre-item:nth-child(5){animation-delay:.5s}.yr-director-item:nth-child(1){animation-delay:.1s}.yr-director-item:nth-child(2){animation-delay:.2s}.yr-director-item:nth-child(3){animation-delay:.3s}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.yr-rank{font-weight:700;font-size:1.2rem;min-width:40px}.yr-genre-name,.yr-director-name{flex:1;text-align:left;font-weight:500}.yr-genre-count,.yr-director-count{opacity:.8;font-size:.9rem}.yr-decade-badge{font-size:4rem;font-weight:900;background:#fff3;padding:24px 48px;border-radius:20px;display:inline-block;margin:24px 0;text-shadow:0 4px 20px rgba(0,0,0,.3)}.yr-poster{width:150px;height:225px;object-fit:cover;border-radius:12px;box-shadow:0 8px 32px #0006;margin:16px 0}.yr-movie-title{font-size:1.3rem;font-weight:600;margin:8px 0}.yr-slide-ratings h2{font-size:1.8rem;margin-bottom:20px}.yr-avg-rating{margin-bottom:24px}.yr-rating-value{font-size:4rem;font-weight:900;display:block}.yr-rating-label{font-size:1rem;opacity:.8}.yr-rating-extremes{display:flex;flex-direction:column;gap:12px}.yr-rating-extreme{background:#ffffff26;padding:12px 16px;border-radius:12px;display:flex;flex-direction:column;gap:4px}.yr-extreme-label{font-size:.85rem;opacity:.7}.yr-extreme-title{font-weight:600}.yr-extreme-value{font-weight:700;color:gold}.yr-slide-monthly h2{font-size:1.8rem;margin-bottom:24px}.yr-monthly-chart{display:flex;justify-content:space-between;align-items:flex-end;height:200px;gap:4px;padding:0 8px}.yr-month-bar{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.yr-bar-fill{width:100%;background:#fffc;border-radius:4px 4px 0 0;min-height:4px;display:flex;align-items:flex-start;justify-content:center;transition:height .5s ease}.yr-bar-count{font-size:.7rem;font-weight:700;color:#333;padding-top:4px}.yr-month-label{font-size:.65rem;margin-top:8px;opacity:.8}.yr-slide-summary h2{font-size:2rem;margin-bottom:24px}.yr-summary-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}.yr-summary-stat{background:#ffffff26;padding:16px;border-radius:12px}.yr-summary-value{font-size:2rem;font-weight:900;display:block}.yr-summary-label{font-size:.85rem;opacity:.8}.yr-summary-detail{font-size:1rem;opacity:.9;margin-bottom:24px}.yr-action-buttons{display:flex;gap:12px;justify-content:center;margin-top:24px}.yr-share-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;min-width:80px}.yr-share-btn:hover{background:#ffffff4d}.yr-close-btn{min-width:80px}.yr-nav{display:flex;justify-content:center;align-items:center;gap:16px;padding:16px}.yr-nav-btn{width:44px;height:44px;border-radius:50%;background:#fff3;border:none;color:#fff;font-size:1.2rem;cursor:pointer;transition:all .2s}.yr-nav-btn:hover:not(:disabled){background:#ffffff4d;transform:scale(1.1)}.yr-nav-btn:disabled{opacity:.3;cursor:not-allowed}.yr-dots{display:flex;gap:8px}.yr-dot{width:10px;height:10px;border-radius:50%;background:#ffffff4d;border:none;cursor:pointer;transition:all .2s}.yr-dot.active{background:#fff;transform:scale(1.2)}.yr-dot:hover:not(.active){background:#ffffff80}.yr-progress{height:4px;background:#fff3}.yr-progress-fill{height:100%;background:#fff;transition:width .3s ease}.year-review-loading,.year-review-error,.year-review-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#fff;text-align:center;padding:24px}.year-review-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:480px){.year-review-modal{max-width:100%;height:100vh;max-height:none;border-radius:0}.yr-big-number{font-size:4rem}.yr-slide-intro .yr-year-badge{font-size:3.5rem}.yr-decade-badge{font-size:3rem;padding:20px 36px}.yr-monthly-chart{height:150px}.yr-summary-stats{gap:12px}.yr-summary-value{font-size:1.5rem}}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;padding:2rem;text-align:center}.error-boundary h2{margin-bottom:1rem;color:var(--text-primary)}.error-boundary p{margin-bottom:1.5rem;color:var(--text-secondary)}.error-boundary button{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem}.error-boundary button:hover{opacity:.9}.chat-panel{background:linear-gradient(180deg,#0d0d0d,#1a1a1a);border:2px solid #333;border-radius:var(--radius-lg);margin:0 0 24px;display:flex;flex-direction:column;max-height:400px;overflow:hidden;box-shadow:0 4px 20px #00000080,inset 0 1px #ffffff0d}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:2px solid #c41e3a;background:linear-gradient(135deg,#1a1a1a,#2d2d2d,#1a1a1a);border-radius:var(--radius) var(--radius) 0 0;position:relative;box-shadow:inset 0 1px #ffffff0d,inset 0 -1px #0000004d,0 2px 8px #0000004d}.chat-header:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:#c41e3a;box-shadow:0 0 10px #c41e3a,0 0 20px #c41e3a80}.chat-title{font-weight:700;color:#e8e8e8;display:flex;align-items:center;gap:10px;font-family:Segoe UI,system-ui,sans-serif;text-transform:uppercase;letter-spacing:1.5px;font-size:.85rem;text-shadow:0 0 10px rgba(196,30,58,.5)}.chat-title:before{content:"";width:8px;height:8px;background:#c41e3a;border-radius:50%;box-shadow:0 0 6px #c41e3a,0 0 12px #c41e3acc;animation:ed209-pulse 2s ease-in-out infinite}@keyframes ed209-pulse{0%,to{opacity:1;box-shadow:0 0 6px #c41e3a,0 0 12px #c41e3acc}50%{opacity:.6;box-shadow:0 0 3px #c41e3a,0 0 6px #c41e3a80}}.chat-close{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;line-height:1;padding:0}.chat-close:hover{color:var(--text-primary)}.chat-messages{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:12px;min-height:150px;max-height:250px;background:linear-gradient(180deg,#111,#0a0a0a)}.chat-message{display:flex;gap:10px;align-items:flex-start}.chat-message.user{flex-direction:row-reverse}.chat-avatar{font-size:1.2rem;flex-shrink:0}.chat-bubble{background:#252525;padding:10px 14px;border-radius:16px;max-width:80%;line-height:1.4;color:#e0e0e0;white-space:pre-wrap;border:1px solid #333}.chat-message.user .chat-bubble{background:linear-gradient(135deg,#c41e3a,#8b1528);color:#fff;border-radius:16px 16px 4px;border:1px solid #d42f4a;box-shadow:0 2px 8px #c41e3a4d}.chat-message.assistant .chat-bubble{border-radius:16px 16px 16px 4px;background:#1e1e1e;border:1px solid #3a3a3a}.chat-typing{display:flex;gap:4px;padding:12px 16px}.chat-typing span{width:8px;height:8px;background:#c41e3a;border-radius:50%;animation:typing 1.4s infinite ease-in-out;box-shadow:0 0 4px #c41e3a}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}.chat-error{color:var(--error);font-size:.9rem;padding:8px 12px;background:#ef44441a;border-radius:var(--radius);text-align:center}.chat-input-form{display:flex;gap:8px;padding:12px 16px;border-top:2px solid #c41e3a;background:linear-gradient(135deg,#1a1a1a,#2d2d2d,#1a1a1a);position:relative;box-shadow:inset 0 1px #ffffff0d,inset 0 -1px #0000004d}.chat-input-form:before{content:"";position:absolute;top:-2px;left:0;right:0;height:2px;background:#c41e3a;box-shadow:0 0 10px #c41e3a,0 0 20px #c41e3a80}.chat-input{flex:1;padding:10px 14px;border:1px solid #444;border-radius:20px;background:#0d0d0d;color:#e0e0e0;font-size:.95rem}.chat-input:focus{outline:none;border-color:#c41e3a;box-shadow:0 0 8px #c41e3a4d}.chat-input::placeholder{color:#666}.chat-send{padding:10px 16px;background:#c41e3a;color:#fff;border:none;border-radius:20px;cursor:pointer;font-size:1rem;transition:all .2s;box-shadow:0 0 8px #c41e3a66}.chat-send:hover:not(:disabled){background:#d42f4a;box-shadow:0 0 12px #c41e3a99}.chat-send:disabled{opacity:.5;cursor:not-allowed}.chat-rate-limit{padding:8px 16px 10px;font-size:.7rem;color:#888;text-align:center;background:linear-gradient(135deg,#1a1a1a,#2d2d2d,#1a1a1a);border-top:1px solid #333;text-transform:uppercase;letter-spacing:1px;font-family:Segoe UI,system-ui,sans-serif;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.btn-icon.active{background:var(--accent);color:#fff}@media(max-width:768px){.chat-panel{margin:0 0 16px;max-height:350px}.chat-messages{max-height:200px}.chat-bubble{max-width:85%}}.affiliate-section{margin-top:24px;padding:20px;background:var(--bg-secondary);border-radius:var(--radius);border:1px solid var(--border)}.affiliate-support-banner{display:block;padding:20px 24px;background:linear-gradient(135deg,#8b5cf614,#3b82f614);border-radius:var(--radius);border:1px solid rgba(139,92,246,.2);text-decoration:none;color:inherit;transition:all .2s ease;position:relative;overflow:hidden}.affiliate-support-banner:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#8b5cf6,#3b82f6,#8b5cf6);background-size:200% 100%}.affiliate-support-banner:hover{transform:translateY(-2px);box-shadow:0 8px 24px #8b5cf626;border-color:#8b5cf666}.affiliate-support-content{display:flex;align-items:center;gap:20px}.affiliate-support-icon{font-size:2.5rem;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.affiliate-support-text{flex:1;display:flex;flex-direction:column;gap:6px}.affiliate-support-title{font-weight:700;font-size:1.15rem;color:var(--text-primary);letter-spacing:-.01em}.affiliate-support-desc{font-size:.9rem;color:var(--text-secondary);line-height:1.5}.affiliate-support-cta{flex-shrink:0;padding:12px 24px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-radius:var(--radius);font-weight:600;font-size:.95rem;transition:all .2s ease;box-shadow:0 2px 8px #8b5cf64d}.affiliate-support-banner:hover .affiliate-support-cta{background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 4px 12px #8b5cf666;transform:scale(1.02)}.affiliate-disclosure{font-size:.75rem;color:var(--text-muted);margin:8px 0 0;text-align:center}.affiliate-header{display:flex;justify-content:space-between;align-items:center;margin:16px 0 12px}.affiliate-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0}.affiliate-loading,.affiliate-empty{color:var(--text-muted);text-align:center;padding:20px}.affiliate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.affiliate-card{display:flex;flex-direction:column;padding:12px;background:var(--bg-tertiary);border-radius:var(--radius);border:1px solid var(--border);text-decoration:none;color:inherit;transition:transform .15s,box-shadow .15s;position:relative}.affiliate-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.affiliate-badge{position:absolute;top:-8px;left:8px;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;color:#fff;white-space:nowrap;box-shadow:0 2px 6px #0003;z-index:1}.affiliate-image{width:100%;aspect-ratio:1 / 1;object-fit:contain;border-radius:calc(var(--radius) - 4px);margin-bottom:10px;background:var(--bg-primary);padding:8px}.affiliate-info{display:flex;flex-direction:column;gap:4px}.affiliate-link-title{font-weight:500;color:var(--text-primary);font-size:.95rem}.affiliate-description{font-size:.8rem;color:var(--text-muted);line-height:1.4}.affiliate-admin-actions{position:absolute;top:8px;right:8px;display:flex;gap:4px;opacity:0;transition:opacity .15s}.affiliate-card:hover .affiliate-admin-actions{opacity:1}.affiliate-admin-actions .btn{padding:4px 8px;font-size:.75rem;background:var(--bg-secondary)}.smart-suggestions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-top:12px}.smart-suggestion-card{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:linear-gradient(135deg,#8b5cf614,#3b82f614);border:1px solid rgba(139,92,246,.15);border-radius:var(--radius);text-decoration:none;color:inherit;transition:all .2s ease}.smart-suggestion-card:hover{background:linear-gradient(135deg,#8b5cf626,#3b82f626);transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf626}.smart-suggestion-content{display:flex;flex-direction:column;gap:2px}.smart-suggestion-title{font-weight:600;font-size:.95rem}.smart-suggestion-desc{font-size:.8rem;color:var(--text-muted)}.smart-suggestion-cta{padding:6px 14px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-radius:20px;font-size:.8rem;font-weight:500;white-space:nowrap}@media(max-width:768px){.affiliate-section{margin-top:16px;padding:16px}.affiliate-support-banner{padding:16px 18px}.affiliate-support-content{flex-wrap:wrap;gap:14px}.affiliate-support-icon{font-size:2rem}.affiliate-support-text{flex:1 1 calc(100% - 60px)}.affiliate-support-title{font-size:1.05rem}.affiliate-support-desc{font-size:.85rem}.affiliate-support-cta{width:100%;text-align:center;padding:14px 20px;font-size:1rem}.affiliate-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.affiliate-image{aspect-ratio:1 / 1}.affiliate-admin-actions{opacity:1}.smart-suggestions-grid{grid-template-columns:1fr;gap:10px}.smart-suggestion-card{padding:12px 14px}.smart-suggestion-title{font-size:.9rem}.smart-suggestion-cta{padding:5px 12px;font-size:.75rem}}
