:root{--color-bg-base: #0a0a0f;--color-bg-primary: #12121a;--color-bg-secondary: #1a1a24;--color-bg-tertiary: #24242e;--color-bg-accent: #1e1e2e;--color-primary-50: rgba(168, 85, 247, .08);--color-primary-100: rgba(168, 85, 247, .15);--color-primary-200: rgba(168, 85, 247, .25);--color-primary-500: #a855f7;--color-primary-600: #9333ea;--color-primary-700: #7e22ce;--color-secondary-500: #3b82f6;--color-secondary-600: #2563eb;--color-highlight: #22d3ee;--color-neutral-50: #f0f0f5;--color-neutral-100: #e0e0e8;--color-neutral-200: #c0c0cc;--color-neutral-300: #8888a0;--color-neutral-400: #6b6b7b;--color-neutral-500: #55556a;--color-neutral-600: #404055;--color-neutral-700: #2e2e3e;--color-neutral-800: #1e1e28;--color-neutral-900: #0a0a0f;--color-success: #22c55e;--color-success-bg: rgba(34, 197, 94, .12);--color-warning: #f59e0b;--color-warning-bg: rgba(245, 158, 11, .12);--color-error: #ef4444;--color-error-bg: rgba(239, 68, 68, .12);--color-danger-50: rgba(239, 68, 68, .12);--color-danger-500: #ef4444;--color-danger-600: #dc2626;--color-star-filled: #fbbf24;--color-star-empty: #404055;--color-border: rgba(255, 255, 255, .08);--color-border-hover: rgba(255, 255, 255, .15);--color-border-focus: rgba(168, 85, 247, .5);--glass-bg: rgba(18, 18, 26, .8);--glass-border: rgba(255, 255, 255, .08);--glass-blur: blur(12px);--gradient-primary: linear-gradient(135deg, #a855f7 0%, #3b82f6 100%);--gradient-accent: linear-gradient(135deg, #9333ea 0%, #22d3ee 100%);--gradient-card-hover: linear-gradient(135deg, rgba(168, 85, 247, .05) 0%, rgba(59, 130, 246, .05) 100%);--gradient-ambient: radial-gradient(ellipse at 20% 0%, rgba(147, 51, 234, .15) 0%, transparent 50%), radial-gradient(ellipse at 80% 100%, rgba(59, 130, 246, .1) 0%, transparent 50%);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.25rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -4px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 8px 10px -6px rgba(0, 0, 0, .4);--shadow-card: 0 4px 16px rgba(0, 0, 0, .4);--shadow-card-hover: 0 8px 30px rgba(0, 0, 0, .5), 0 0 40px rgba(168, 85, 247, .1);--shadow-glow-purple: 0 0 20px rgba(168, 85, 247, .3);--shadow-glow-blue: 0 0 20px rgba(59, 130, 246, .3);--font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box}*{margin:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:1rem;line-height:1.5;color:var(--color-neutral-50);background-color:var(--color-bg-base);background-image:var(--gradient-ambient);background-attachment:fixed;min-height:100vh}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.container{width:100%;max-width:1024px;margin:0 auto;padding:0 var(--space-4)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-weight:600;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);border:none;text-decoration:none}.btn:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{height:32px;padding:0 var(--space-3);font-size:.875rem}.btn-md{height:40px;padding:0 var(--space-4);font-size:.875rem}.btn-lg{height:48px;padding:0 var(--space-6);font-size:1rem}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow-purple);border:none}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#c084fc,#60a5fa);transform:translateY(-1px);box-shadow:0 0 30px #a855f766}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-glow-purple)}.btn-secondary{background-color:transparent;border:1px solid var(--color-border-hover);color:var(--color-neutral-100)}.btn-secondary:hover:not(:disabled){background-color:var(--color-bg-tertiary);border-color:var(--color-primary-500)}.btn-ghost{background-color:transparent;color:var(--color-neutral-300)}.btn-ghost:hover:not(:disabled){background-color:var(--color-bg-tertiary);color:var(--color-neutral-100)}.btn-full{width:100%}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--color-neutral-200);margin-bottom:var(--space-2)}.form-input{width:100%;height:44px;padding:var(--space-3) var(--space-4);font-size:1rem;color:var(--color-neutral-50);border:1px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-bg-secondary);transition:border-color .15s ease,box-shadow .15s ease}.form-input::placeholder{color:var(--color-neutral-400)}.form-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100),var(--shadow-glow-purple)}.form-input:disabled{background-color:var(--color-bg-tertiary);color:var(--color-neutral-400);cursor:not-allowed}.form-input.error{border-color:var(--color-error)}.form-input.error:focus{box-shadow:0 0 0 3px var(--color-error-bg)}.form-error{font-size:.75rem;color:var(--color-error);margin-top:var(--space-1)}.card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card)}.card-sm{padding:var(--space-3)}.card-md{padding:var(--space-4)}.card-lg{padding:var(--space-6)}.alert{padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:.875rem;margin-bottom:var(--space-4)}.alert-error{background-color:var(--color-error-bg);color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.alert-success{background-color:var(--color-success-bg);color:#86efac;border:1px solid rgba(34,197,94,.3)}.header{height:64px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);display:flex;align-items:center;position:sticky;top:0;z-index:100}.header-content{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:1024px;margin:0 auto;padding:0 var(--space-4)}.header-logo{font-size:1.25rem;font-weight:700;color:var(--color-neutral-50);text-decoration:none;display:flex;align-items:center;gap:var(--space-2)}.header-logo:before{content:"";display:inline-block;width:8px;height:8px;background:var(--gradient-primary);border-radius:50%;box-shadow:var(--shadow-glow-purple)}.header-left{display:flex;align-items:center;gap:var(--space-6)}.header-nav{display:flex;align-items:center;gap:var(--space-1)}.header-nav-link{padding:var(--space-2) var(--space-3);font-size:.875rem;font-weight:500;color:var(--color-neutral-400);text-decoration:none;border-radius:var(--radius-md);transition:color .15s ease,background-color .15s ease}.header-nav-link:hover{color:var(--color-neutral-200);background-color:var(--color-neutral-800)}.header-nav-link-active{color:var(--color-neutral-50);background-color:var(--color-neutral-800)}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:var(--color-bg-base);background-image:var(--gradient-ambient)}.auth-card{width:100%;max-width:400px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);padding:var(--space-8)}.auth-title{font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:var(--space-6);color:var(--color-neutral-50)}.auth-footer{text-align:center;margin-top:var(--space-6);font-size:.875rem;color:var(--color-neutral-400)}.auth-footer a{color:var(--color-primary-500);text-decoration:none;font-weight:500;transition:color var(--transition-fast)}.auth-footer a:hover{color:var(--color-primary-600);text-decoration:underline}.main-layout{min-height:calc(100vh - 64px)}.page-content{padding:var(--space-6) 0}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6);flex-wrap:wrap;gap:var(--space-4)}.page-title{font-size:1.75rem;font-weight:700;color:var(--color-neutral-50);letter-spacing:-.02em}.sort-control{display:flex;align-items:center;gap:var(--space-2)}.sort-label{font-size:.875rem;color:var(--color-neutral-400);white-space:nowrap}.sort-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--color-bg-secondary);border:1px solid var(--color-neutral-700);border-radius:var(--radius-md);color:var(--color-neutral-200);font-size:.875rem;padding:var(--space-2) var(--space-8) var(--space-2) var(--space-3);cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-2) center;min-width:160px;transition:border-color .15s ease,box-shadow .15s ease}.sort-select:hover{border-color:var(--color-neutral-600)}.sort-select:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #8b5cf626}.analytics-filters{display:flex;align-items:center;gap:var(--space-2)}.filter-label{font-size:.875rem;color:var(--color-neutral-400);white-space:nowrap}.rankings-list{display:flex;flex-direction:column;gap:var(--space-4)}.rankings-list .movie-card{animation:slideUp .4s ease-out backwards}.rankings-list .movie-card:nth-child(1){animation-delay:0ms}.rankings-list .movie-card:nth-child(2){animation-delay:50ms}.rankings-list .movie-card:nth-child(3){animation-delay:.1s}.rankings-list .movie-card:nth-child(4){animation-delay:.15s}.rankings-list .movie-card:nth-child(5){animation-delay:.2s}.rankings-list .movie-card:nth-child(6){animation-delay:.25s}.rankings-list .movie-card:nth-child(7){animation-delay:.3s}.rankings-list .movie-card:nth-child(8){animation-delay:.35s}.rankings-list .movie-card:nth-child(9){animation-delay:.4s}.rankings-list .movie-card:nth-child(10){animation-delay:.45s}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.movie-card{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-5);padding:var(--space-5);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);transition:transform var(--transition-normal),box-shadow var(--transition-normal),border-color var(--transition-normal),background var(--transition-normal);position:relative;overflow:hidden}.movie-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-card-hover);opacity:0;transition:opacity var(--transition-normal);pointer-events:none}.movie-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover)}.movie-card:hover:before{opacity:1}.movie-poster{flex-shrink:0;width:100px;height:150px;border-radius:var(--radius-lg);overflow:hidden;background-color:var(--color-bg-tertiary);box-shadow:var(--shadow-md);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.movie-card:hover .movie-poster{transform:scale(1.03);box-shadow:var(--shadow-lg),var(--shadow-glow-purple)}.movie-poster-image{width:100%;height:100%;object-fit:cover}.movie-poster-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-neutral-500);background:linear-gradient(135deg,var(--color-bg-tertiary) 0%,var(--color-bg-secondary) 100%)}.movie-info{flex:1;min-width:0;position:relative;z-index:1}.movie-title{font-size:1.125rem;font-weight:600;color:var(--color-neutral-50);margin-bottom:var(--space-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.movie-year{font-size:.875rem;color:var(--color-neutral-400)}.movie-genres,.movie-date{font-size:.75rem;color:var(--color-neutral-500);margin-top:var(--space-1)}.movie-date-edit{display:inline-flex;align-items:center;gap:var(--space-1);background:none;border:none;padding:var(--space-1) var(--space-2);margin:var(--space-1) calc(-1 * var(--space-2)) 0;border-radius:var(--radius-sm);cursor:pointer;font-size:.75rem;color:var(--color-neutral-500);transition:background-color .15s ease,color .15s ease;min-height:28px}.movie-date-edit:hover{background-color:var(--color-bg-tertiary);color:var(--color-neutral-300)}.movie-date-edit:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.movie-date-edit-icon{width:12px;height:12px;opacity:0;flex-shrink:0;transition:opacity .15s ease}.movie-date-edit:hover .movie-date-edit-icon,.movie-date-edit:focus-visible .movie-date-edit-icon{opacity:1}.movie-date-editor{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-1)}.movie-date-editor.saving{opacity:.6;pointer-events:none}.movie-date-input{height:28px;padding:var(--space-1) var(--space-2);font-size:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-bg-secondary);color:var(--color-neutral-50);width:130px;transition:border-color .15s ease,box-shadow .15s ease}.movie-date-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 2px var(--color-primary-100)}.movie-date-actions{display:flex;gap:var(--space-1)}.movie-rating{flex-shrink:0}.movie-actions{display:flex;align-items:center;gap:var(--space-2);position:relative;z-index:1}.btn-icon{background:none;border:none;padding:var(--space-2);cursor:pointer;color:var(--color-neutral-500);border-radius:var(--radius-md);transition:color .15s ease,background-color .15s ease;display:flex;align-items:center;justify-content:center}.btn-icon:hover{color:var(--color-danger-500);background-color:var(--color-danger-50)}.btn-icon:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.btn-icon-sm{background:none;border:none;width:24px;height:24px;padding:var(--space-1);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-neutral-400);transition:color .15s ease,background-color .15s ease}.btn-icon-sm svg{width:14px;height:14px}.btn-icon-sm:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.btn-icon-sm:disabled{opacity:.5;cursor:not-allowed}.btn-icon-save:hover:not(:disabled){color:var(--color-success);background-color:var(--color-success-bg, rgba(34, 197, 94, .1))}.btn-icon-cancel:hover:not(:disabled){color:var(--color-neutral-600);background-color:var(--color-neutral-100)}.movie-card{position:relative}.delete-confirm{position:absolute;top:0;left:0;right:0;bottom:0;background:#12121af2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);border-radius:var(--radius-lg);padding:var(--space-4);text-align:center;z-index:10}.delete-confirm p{font-size:.875rem;color:var(--color-neutral-200);font-weight:500}.delete-confirm-actions{display:flex;gap:var(--space-2)}.btn-danger{background-color:var(--color-danger-500);color:#fff;border:none;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .15s ease}.btn-danger:hover{background-color:var(--color-danger-600)}.btn-danger:focus-visible{outline:2px solid var(--color-danger-500);outline-offset:2px}.star-rating{display:flex;gap:4px}.star-rating.sm .star{width:18px;height:18px}.star-rating.md .star{width:28px;height:28px}.star-rating.lg .star{width:36px;height:36px}.star{cursor:pointer;transition:transform var(--transition-fast),filter var(--transition-fast)}.star:hover{transform:scale(1.15);filter:drop-shadow(0 2px 8px rgba(251,191,36,.5))}.star.readonly{cursor:default}.star.readonly:hover{transform:none;filter:none}.star-filled{color:var(--color-star-filled)}.star-empty{color:var(--color-star-empty)}.empty-state{text-align:center;padding:var(--space-12) var(--space-4);max-width:360px;margin:0 auto}.empty-state-icon{width:72px;height:72px;margin:0 auto var(--space-6);color:var(--color-primary-500);opacity:.8;animation:float 3s ease-in-out infinite;filter:drop-shadow(var(--shadow-glow-purple))}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.empty-state-title{font-size:1.5rem;font-weight:700;color:var(--color-neutral-100);margin-bottom:var(--space-3)}.empty-state-description{font-size:1rem;color:var(--color-neutral-400);margin-bottom:var(--space-8);line-height:1.6}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:200;animation:fadeIn .15s ease}.modal{width:100%;max-width:480px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl),var(--shadow-glow-purple);animation:scaleIn .15s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border)}.modal-title{font-size:1.125rem;font-weight:600;color:var(--color-neutral-50)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:none;border:none;cursor:pointer;color:var(--color-neutral-400);transition:background-color var(--transition-fast),color var(--transition-fast)}.modal-close:hover{background-color:var(--color-bg-tertiary);color:var(--color-neutral-200)}.modal-body{padding:var(--space-6)}.spinner{width:20px;height:20px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}.loading-container{display:flex;align-items:center;justify-content:center;padding:var(--space-8)}.loading-container .spinner{width:32px;height:32px;color:var(--color-primary-600)}.load-more{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);margin-top:var(--space-6)}.load-more-progress{font-size:.875rem;color:var(--color-neutral-500)}.back-to-top{position:fixed;bottom:var(--space-6);right:var(--space-6);width:44px;height:44px;border-radius:50%;background-color:var(--color-bg-secondary);border:1px solid var(--color-neutral-700);color:var(--color-neutral-300);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:background-color .15s ease,border-color .15s ease,transform .15s ease;z-index:100;animation:fadeIn .2s ease-out}.back-to-top:hover{background-color:var(--color-neutral-800);border-color:var(--color-neutral-600);transform:translateY(-2px)}.back-to-top:focus{outline:none;border-color:var(--color-primary-500);box-shadow:var(--shadow-lg),0 0 0 3px #8b5cf626}.back-to-top:active{transform:translateY(0)}.activity-chart{background-color:var(--color-bg-secondary);border:1px solid var(--color-neutral-800);border-radius:var(--radius-xl);padding:var(--space-6)}.activity-chart-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-4);flex-wrap:wrap;gap:var(--space-2)}.activity-chart-title{font-size:1rem;font-weight:600;color:var(--color-neutral-200);margin:0}.activity-chart-total{font-size:.875rem;color:var(--color-neutral-500)}.activity-chart-container{overflow-x:auto;padding-bottom:var(--space-2)}.activity-chart-months{position:relative;height:16px;margin-bottom:var(--space-1);margin-left:32px}.activity-chart-month{position:absolute;font-size:.75rem;color:var(--color-neutral-500);white-space:nowrap}.activity-chart-grid-wrapper{display:flex;gap:var(--space-2)}.activity-chart-day-labels{display:flex;flex-direction:column;gap:2px;padding-top:0;min-width:28px}.activity-chart-day-labels span{font-size:.625rem;color:var(--color-neutral-500);height:10px;line-height:10px}.activity-chart-grid{display:flex;gap:3px}.activity-chart-week{display:flex;flex-direction:column;gap:2px}.activity-chart-day{width:10px;height:10px;border-radius:2px;cursor:pointer;transition:transform .1s ease}.activity-chart-day:hover{transform:scale(1.2)}.activity-empty{background-color:transparent;cursor:default}.activity-empty:hover{transform:none}.activity-level-0{background-color:var(--color-neutral-800)}.activity-level-1{background-color:#6d28d9}.activity-level-2{background-color:#8b5cf6}.activity-level-3{background-color:#a78bfa}.activity-level-4{background-color:var(--color-primary-500)}.activity-future{background-color:var(--color-neutral-800);opacity:.4}.activity-chart-legend{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:var(--space-4)}.activity-chart-legend-label{font-size:.75rem;color:var(--color-neutral-500);margin:0 var(--space-1)}.activity-chart-legend .activity-chart-day{cursor:default}.activity-chart-legend .activity-chart-day:hover{transform:none}.activity-chart-tooltip{position:fixed;transform:translate(-50%,-100%);margin-top:-8px;background-color:var(--color-neutral-900);border:1px solid var(--color-neutral-700);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);display:flex;flex-direction:column;gap:2px;font-size:.75rem;color:var(--color-neutral-200);white-space:nowrap;z-index:1000;pointer-events:none;box-shadow:var(--shadow-lg)}.activity-chart-tooltip strong{color:var(--color-neutral-50)}.activity-chart-tooltip span{color:var(--color-neutral-400)}.analytics-grid{display:flex;flex-direction:column;gap:var(--space-6)}.genre-chart{background-color:var(--color-bg-secondary);border:1px solid var(--color-neutral-800);border-radius:var(--radius-xl);padding:var(--space-6)}.genre-chart-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-4);flex-wrap:wrap;gap:var(--space-2)}.genre-chart-title{font-size:1rem;font-weight:600;color:var(--color-neutral-200);margin:0}.genre-chart-total{font-size:.875rem;color:var(--color-neutral-500)}.genre-radar-container{position:relative;width:100%;max-width:320px;margin:var(--space-4) auto;aspect-ratio:1}.genre-radar{width:100%;height:100%}.genre-radar-grid{fill:none;stroke:var(--color-neutral-700);stroke-width:1}.genre-radar-axis{stroke:var(--color-neutral-700);stroke-width:1}.genre-radar-data{fill:#8b5cf64d;stroke:var(--color-primary-500);stroke-width:2}.genre-radar-point{fill:var(--color-primary-400);stroke:var(--color-bg-primary);stroke-width:2}.genre-radar-labels{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.genre-radar-label{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center}.genre-radar-label-name{font-size:.75rem;font-weight:500;color:var(--color-neutral-300);white-space:nowrap}.genre-radar-label-count{font-size:.625rem;font-weight:600;color:var(--color-primary-400)}.genre-radar-label-empty .genre-radar-label-name{color:var(--color-neutral-600)}.genre-chart-empty{text-align:center;padding:var(--space-8) var(--space-4)}.genre-chart-empty-text{font-size:1rem;color:var(--color-neutral-400);margin:0 0 var(--space-2) 0}.genre-chart-empty-hint{font-size:.875rem;color:var(--color-neutral-500);margin:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}.movie-search,.movie-search-input-wrapper{position:relative}.movie-search-input{padding-right:var(--space-10)}.movie-search-spinner{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);color:var(--color-neutral-400)}.movie-search-spinner .spinner{width:16px;height:16px}.movie-search-error{font-size:.875rem;color:var(--color-error);margin-top:var(--space-2)}.movie-search-no-results{font-size:.875rem;color:var(--color-neutral-400);text-align:center;padding:var(--space-4);margin-top:var(--space-2);background-color:var(--color-bg-secondary);border-radius:var(--radius-lg)}.movie-search-results{list-style:none;padding:0;margin:var(--space-2) 0 0 0;max-height:320px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-bg-secondary);box-shadow:var(--shadow-lg)}.movie-search-result{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);cursor:pointer;transition:background-color .15s ease}.movie-search-result:not(:last-child){border-bottom:1px solid var(--color-border)}.movie-search-result:hover,.movie-search-result.highlighted{background:var(--gradient-card-hover)}.movie-search-result.highlighted{outline:none}.movie-search-result-poster{flex-shrink:0;width:40px;height:60px;border-radius:var(--radius-sm);overflow:hidden;background-color:var(--color-bg-tertiary)}.movie-search-poster-img{width:100%;height:100%;object-fit:cover}.movie-search-poster-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-neutral-300)}.movie-search-poster-placeholder svg{width:20px;height:20px}.movie-search-result-info{flex:1;min-width:0}.movie-search-result-title{display:block;font-size:.875rem;font-weight:500;color:var(--color-neutral-50);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.movie-search-result-year{display:block;font-size:.75rem;color:var(--color-neutral-400);margin-top:2px}.add-movie-form{display:flex;flex-direction:column;gap:var(--space-4)}.mode-switch{text-align:center;padding:var(--space-2) 0}.mode-switch-link{background:none;border:none;padding:0;font-size:.875rem;color:var(--color-primary-500);cursor:pointer;text-decoration:none}.mode-switch-link:hover{color:var(--color-primary-600);text-decoration:underline}.mode-switch-link:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px;border-radius:var(--radius-sm)}.form-actions{margin-top:var(--space-4)}.form-actions-row{display:flex;gap:var(--space-3);margin-top:var(--space-2)}.selected-movie{display:flex;gap:var(--space-4);padding:var(--space-4);background-color:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.selected-movie-poster{flex-shrink:0;width:80px;height:120px;border-radius:var(--radius-md);overflow:hidden;background-color:var(--color-bg-tertiary)}.selected-movie-poster-img{width:100%;height:100%;object-fit:cover}.selected-movie-poster-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-neutral-400)}.selected-movie-poster-placeholder svg{width:32px;height:32px}.selected-movie-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}.selected-movie-title{font-size:1.125rem;font-weight:600;color:var(--color-neutral-50);margin:0 0 var(--space-1) 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selected-movie-year{font-size:.875rem;color:var(--color-neutral-400);margin:0 0 var(--space-2) 0}.add-movie-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);min-height:180px;padding:var(--space-6);background:#12121a66;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:2px dashed var(--color-neutral-600);border-radius:var(--radius-xl);cursor:pointer;transition:border-color var(--transition-normal),background-color var(--transition-normal),box-shadow var(--transition-normal),transform var(--transition-normal);position:relative;overflow:hidden}.add-movie-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,rgba(168,85,247,.08) 0%,transparent 70%);opacity:0;transition:opacity var(--transition-normal);pointer-events:none}.add-movie-card:hover{border-color:var(--color-primary-500);border-style:solid;background:#18182499;transform:translateY(-2px);box-shadow:0 8px 32px #0006,0 0 0 1px #a855f71a,inset 0 1px #ffffff0d}.add-movie-card:hover:before{opacity:1}.add-movie-card:focus-visible{outline:none;border-color:var(--color-primary-500);border-style:solid;box-shadow:0 0 0 3px var(--color-primary-100),var(--shadow-glow-purple)}.add-movie-card:active{transform:translateY(0);background:#1e1e2ab3}.add-movie-card-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#a855f726,#3b82f61a);border:1px solid rgba(168,85,247,.2);color:var(--color-primary-500);transition:transform var(--transition-normal),box-shadow var(--transition-normal),background var(--transition-normal)}.add-movie-card:hover .add-movie-card-icon{transform:scale(1.08);background:linear-gradient(135deg,#a855f740,#3b82f626);box-shadow:0 0 20px #a855f74d,0 0 40px #a855f71a}.add-movie-card-icon svg{width:28px;height:28px;stroke-width:2;transition:transform var(--transition-fast)}.add-movie-card:hover .add-movie-card-icon svg{transform:rotate(90deg)}.add-movie-card-label{font-size:.9375rem;font-weight:500;color:var(--color-neutral-400);transition:color var(--transition-normal)}.add-movie-card:hover .add-movie-card-label{color:var(--color-neutral-200)}.add-movie-card-hint{font-size:.8125rem;color:var(--color-neutral-500);opacity:0;transform:translateY(-4px);transition:opacity var(--transition-normal),transform var(--transition-normal)}.add-movie-card:hover .add-movie-card-hint{opacity:1;transform:translateY(0)}.rankings-list .add-movie-card{animation:fadeSlideUp .5s ease-out backwards}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.movie-card{flex-wrap:wrap;padding:var(--space-4)}.movie-poster{width:80px;height:120px}.movie-info{flex:1 1 0;min-width:120px}.movie-actions{flex-basis:100%;margin-top:var(--space-3);justify-content:space-between}.movie-rating{margin-top:0}.movie-date-edit-icon{opacity:.6}.movie-date-editor{flex-wrap:wrap}.page-header{flex-direction:column;align-items:flex-start}.page-header .btn{width:100%}.empty-state-icon{width:56px;height:56px}.empty-state-title{font-size:1.25rem}.add-movie-card{min-height:140px;padding:var(--space-4)}.add-movie-card-icon{width:48px;height:48px}.add-movie-card-icon svg{width:24px;height:24px}.add-movie-card-label{font-size:.875rem}.add-movie-card-hint{display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.movie-card:hover,.movie-card:hover .movie-poster{transform:none}.empty-state-icon{animation:none}.add-movie-card,.add-movie-card-icon,.add-movie-card-icon svg,.add-movie-card-hint{transition:none}.add-movie-card:hover .add-movie-card-icon svg{transform:none}.add-movie-card:hover .add-movie-card-icon{transform:none}.rankings-list .add-movie-card{animation:none}}
