:root{--background: #050608;--surface-card: #101217;--surface-subtle: #151823;--border-subtle: rgba(255, 255, 255, .05);--text-primary: #F5F7FA;--text-secondary: #A1A7B3;--text-muted: #6E7482;--accent-primary: #00E054;--accent-primary-soft: rgba(0, 224, 84, .15);--accent-primary-hover: #00C047;--accent-danger: #FF4D70;--accent-focus: #46E0FF;--star-technical: #46E0FF;--star-emotional: #FF64A3;--star-originality: #FFCB5C;--star-rewatch: #4CE4B5;--star-overall: #00E054;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 24px;--space-2xl: 32px;--space-3xl: 48px;--spacing-xs: var(--space-sm);--spacing-sm: var(--space-md);--spacing-md: var(--space-lg);--spacing-lg: var(--space-xl);--spacing-xl: var(--space-2xl);--spacing-2xl: var(--space-3xl);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 999px;--bg-primary: var(--background);--bg-secondary: var(--surface-card);--bg-tertiary: var(--surface-subtle);--border: var(--border-subtle);--accent: var(--accent-primary);--accent-hover: var(--accent-primary-hover);--accent-dim: var(--accent-primary-soft);--danger: var(--accent-danger);--border-hover: rgba(255, 255, 255, .1)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--background);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}.text-display{font-size:28px;font-weight:600;letter-spacing:-.01em;line-height:1.2;color:var(--text-primary)}.text-title{font-size:20px;font-weight:600;line-height:1.3;color:var(--text-primary)}.text-subtitle{font-size:16px;font-weight:500;line-height:1.4;color:var(--text-primary)}.text-body{font-size:15px;font-weight:400;line-height:1.6;color:var(--text-primary)}.text-caption{font-size:13px;font-weight:400;line-height:1.5;color:var(--text-muted)}.text-label{font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-weight:500;color:var(--text-muted)}.page-container{max-width:1200px;margin:0 auto;padding:var(--space-lg) var(--space-lg) var(--space-xl);width:100%}@media(max-width:768px){.page-container{padding:var(--space-md) var(--space-md) var(--space-lg)}}.container{max-width:1200px;margin:0 auto;padding:var(--space-xl);width:100%}.card{background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);padding:var(--space-lg);box-shadow:0 10px 30px #00000059;transition:box-shadow .15s ease,transform .15s ease}.card:hover{transform:translateY(-2px);box-shadow:0 16px 40px #00000073}.card-subtle{background:var(--surface-subtle);border-radius:var(--radius-md);border:1px solid var(--border-subtle);padding:var(--space-md);transition:all .15s ease}.input,.textarea,input[type=text],input[type=email],input[type=password],input[type=number],input[type=search],textarea{width:100%;background:var(--surface-subtle);border-radius:var(--radius-md);border:1px solid var(--border-subtle);padding:var(--space-md) var(--space-md);color:var(--text-primary);font-size:15px;font-family:inherit;outline:none;transition:border-color .12s ease,box-shadow .12s ease,background-color .12s ease}.input:focus,.textarea:focus,input:focus,textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary-soft);background:#00e05408}.input::placeholder,.textarea::placeholder,input::placeholder,textarea::placeholder{color:var(--text-muted)}textarea{min-height:100px;resize:vertical}.label{display:block;color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:var(--space-sm)}.button{padding:6px 12px;border-radius:var(--radius-full);border:none;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:6px;text-decoration:none;white-space:nowrap;line-height:1.4}@media(min-width:768px){.button{padding:var(--space-sm) var(--space-lg);font-size:14px;gap:var(--space-sm)}}.button-primary,.button.accent,.diary-page .button,.discover-add-btn{background:var(--accent-primary);color:#000;box-shadow:0 2px 8px #00e05433}.button-primary:hover,.button.accent:hover,.diary-page .button:hover,.discover-add-btn:hover{background:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #00e0544d}.button-secondary{background:var(--surface-subtle);color:var(--text-primary);border:1px solid var(--border-subtle)}.button-secondary:hover{background:#ffffff0d;border-color:#ffffff1a}.button-outline{border-radius:var(--radius-full);padding:6px 12px;border:1px solid var(--accent-primary);background:transparent;color:var(--accent-primary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .12s ease}@media(min-width:768px){.button-outline{padding:var(--space-sm) var(--space-lg);font-size:14px}}.button-outline:hover{background:var(--accent-primary-soft);transform:translateY(-1px)}.button-danger{background:var(--accent-danger);color:#fff}.button-danger:hover{background:#ff365c;transform:translateY(-1px);box-shadow:0 4px 12px #ff4d704d}.button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.button svg{width:16px;height:16px;flex-shrink:0}@media(min-width:768px){.button svg{width:18px;height:18px}}.film-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-xl);margin-top:var(--space-2xl)}@media(max-width:768px){.film-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-lg)}}.top-bar{padding:var(--space-lg) 0;border-bottom:1px solid var(--border-subtle);margin-bottom:var(--space-xl);background:linear-gradient(to bottom,var(--surface-card),transparent)}.top-bar-title{font-size:24px;font-weight:600;letter-spacing:-.01em;color:var(--text-primary);margin:0}.top-bar-subtitle{font-size:14px;color:var(--text-secondary);margin-top:var(--space-xs)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl);text-align:center;color:var(--text-secondary)}.loading-spinner{width:48px;height:48px;border:3px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-xl);max-width:400px;margin:0 auto}.empty-state h2{color:var(--text-primary);font-size:24px;margin-bottom:var(--space-md)}.empty-state p{color:var(--text-secondary);font-size:16px;line-height:1.6;margin-bottom:var(--space-xl)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-column{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background:var(--surface-subtle);border-radius:var(--radius-sm);border:2px solid var(--background)}::-webkit-scrollbar-thumb:hover{background:#ffffff1a}:focus-visible{outline:2px solid var(--accent-focus);outline-offset:2px}button:focus-visible,a:focus-visible{outline:2px solid var(--accent-focus);outline-offset:2px}[data-theme=light]{--background: #FAFBFC;--surface-card: #FFFFFF;--surface-subtle: #F5F7FA;--border-subtle: rgba(0, 0, 0, .08);--text-primary: #1A1D23;--text-secondary: #4A5568;--text-muted: #718096;--accent-primary: #00C048;--accent-primary-soft: rgba(0, 192, 72, .12);--accent-primary-hover: #00A03C;--bg-primary: var(--background);--bg-secondary: var(--surface-card);--bg-tertiary: var(--surface-subtle);--border: var(--border-subtle);--border-hover: rgba(0, 0, 0, .12)}[data-theme=light] body{background-color:var(--background);color:var(--text-primary)}[data-theme=light] .card{box-shadow:0 2px 8px #00000014,0 1px 2px #0000000a}[data-theme=light] .card:hover{box-shadow:0 4px 16px #0000001f,0 2px 4px #0000000f}[data-theme=light] ::-webkit-scrollbar-track{background:var(--background)}[data-theme=light] ::-webkit-scrollbar-thumb{background:#0003;border:2px solid var(--background)}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#0000004d}@media(max-width:768px){.hide-mobile{display:none!important}.text-display{font-size:24px}.text-title{font-size:18px}}@media(min-width:769px){.show-mobile{display:none!important}}input,textarea,select,button,.input,.textarea{font-size:16px!important;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;-ms-text-size-adjust:100%;text-size-adjust:100%}.beat-textarea,.question-textarea,.reflection-textarea,.review-textarea,.profile-bio-input,.export-filename,textarea{font-size:16px!important;line-height:1.5;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;-ms-text-size-adjust:100%;text-size-adjust:100%}input[type=text],input[type=email],input[type=password],input[type=search],input[type=number],input[type=tel],input[type=url],input[type=date],input[type=datetime],input[type=datetime-local],input[type=month],input[type=time],input[type=week]{font-size:16px!important;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;-ms-text-size-adjust:100%;text-size-adjust:100%}input{font-size:16px!important;min-height:44px}*{touch-action:manipulation}.modal-overlay,.export-modal-overlay{position:fixed;inset:0;overflow:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.discover-card{-webkit-tap-highlight-color:transparent;touch-action:manipulation}html,body{overflow-x:hidden;width:100%;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;-ms-text-size-adjust:100%;text-size-adjust:100%}.discover-page .search-input,.auth-gate .auth-input,.new-film-page .input,.film-detail .beat-textarea,.film-detail .question-textarea,.film-detail .reflection-textarea,.film-detail .review-textarea{font-size:16px!important;line-height:1.5!important}.film-detail{overflow-x:hidden;width:100%}.auth-form input,.auth-form button,.search-input,.search-button{font-size:16px!important}.star-rating{touch-action:manipulation;-webkit-tap-highlight-color:transparent}body.modal-open{position:fixed;width:100%;overflow:hidden}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a0a0a,#1c1c1e);padding:20px}.auth-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0a0a0a;color:#fff}.loading-spinner{width:40px;height:40px;border:3px solid #38383A;border-top-color:#ff6b35;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-card{width:100%;max-width:400px;background:#1c1c1e;border-radius:16px;padding:32px;box-shadow:0 10px 40px #0006}.auth-header{text-align:center;margin-bottom:32px}.auth-title{font-size:32px;font-weight:700;color:#ff6b35;margin:0 0 8px;letter-spacing:-.5px;white-space:nowrap}@media(max-width:375px){.auth-title{font-size:24px}}@media(max-width:320px){.auth-title{font-size:20px}}.auth-subtitle{font-size:14px;color:#8e8e93;margin:0}.auth-tabs{display:flex;margin-bottom:24px;background:#2c2c2e;border-radius:8px;padding:4px}.auth-tab{flex:1;padding:10px;background:none;border:none;color:#8e8e93;font-size:16px;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s}.auth-tab:hover:not(:disabled){color:#fff}.auth-tab.active{background:#38383a;color:#fff}.auth-tab:disabled{opacity:.5;cursor:not-allowed}.auth-form{margin-bottom:24px}.form-group{margin-bottom:16px}.auth-input{width:100%;padding:12px 16px;background:#2c2c2e;border:1px solid #38383A;border-radius:8px;color:#fff;font-size:16px;transition:all .2s;box-sizing:border-box}.auth-input::placeholder{color:#8e8e93}.auth-input:focus{outline:none;border-color:#ff6b35;background:#38383a}.auth-input:disabled{opacity:.5;cursor:not-allowed}.auth-error{padding:10px;background:#ff3b301a;border:1px solid rgba(255,59,48,.3);border-radius:6px;color:#ff3b30;font-size:14px;margin-bottom:16px;text-align:center}.auth-button{width:100%;padding:14px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.auth-button:disabled{opacity:.5;cursor:not-allowed}.auth-button.primary{background:#ff6b35;color:#fff}.auth-button.primary:hover:not(:disabled){background:#ff5722;transform:translateY(-1px)}.auth-divider{position:relative;text-align:center;margin:24px 0}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#38383a}.auth-divider span{position:relative;padding:0 16px;background:#1c1c1e;color:#8e8e93;font-size:14px}.auth-social{display:flex;flex-direction:column;gap:12px}.auth-button.social{background:#2c2c2e;color:#fff;border:1px solid #38383A}.auth-button.social:hover:not(:disabled){background:#38383a;transform:translateY(-1px)}.social-icon{width:20px;height:20px;flex-shrink:0}@media(max-width:480px){.auth-card{padding:24px}.auth-title{font-size:28px}}.data-migration{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:1000;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:20px;color:#fff;box-shadow:0 10px 30px #0000004d;max-width:400px;width:90%;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translate(-50%) translateY(100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.migration-prompt h3{margin:0 0 10px;font-size:18px;font-weight:600}.migration-prompt p{margin:0 0 15px;font-size:14px;opacity:.95;line-height:1.5}.migrate-button{background:#fff;color:#667eea;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.migrate-button:hover{transform:scale(1.05);box-shadow:0 5px 15px #0003}.migration-progress{text-align:center;padding:10px 0}.spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 15px}.migration-progress p{margin:0;font-size:14px}.migration-success h3{color:#4ade80;margin:0 0 10px;font-size:20px}.migration-success p{margin:5px 0;font-size:14px}.migration-notes{background:#ffffff1a;padding:10px;border-radius:6px;margin:10px 0}.refresh-note{font-size:12px;opacity:.8;font-style:italic;margin-top:10px}.migration-error h3{color:#ff6b6b;margin:0 0 10px;font-size:18px}.migration-error p{margin:5px 0;font-size:14px}.error-details{background:#ff6b6b1a;padding:10px;border-radius:6px;margin:10px 0;max-height:150px;overflow-y:auto}.error-message{font-size:12px;margin:5px 0;word-break:break-word}.retry-button{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s ease;margin-top:10px}.retry-button:hover{background:#ffffff4d}.dismiss-button{position:absolute;top:10px;right:10px;background:none;border:none;color:#fff;font-size:24px;cursor:pointer;opacity:.8;transition:opacity .2s;width:30px;height:30px;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.dismiss-button:hover{opacity:1}.skip-button{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5);padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s ease;margin-left:10px}.skip-button:hover{background:#ffffff1a;border-color:#fff}.migration-buttons{display:flex;justify-content:center;gap:10px;margin-top:15px}.migration-prompt,.migration-error{position:relative}.setup-note{background:#ffffff1a;padding:10px;border-radius:6px;margin:10px 0;font-size:13px;line-height:1.4}@media(max-width:480px){.data-migration{bottom:70px;padding:15px}.migration-prompt h3{font-size:16px}.migration-prompt p{font-size:13px}}.demo-banner{position:sticky;top:0;z-index:1000;background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:.5rem 1rem;text-align:center;font-size:14px;box-shadow:0 2px 4px #0000001a}.demo-banner-text{display:inline-block;max-width:800px;line-height:1.5}.app-layout{display:flex;flex-direction:column;height:100vh;width:100%;background:var(--bg-primary);position:relative}.app-header,.header-title{display:none}.app-content{flex:1;overflow-y:auto;padding-bottom:60px}.tab-bar{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:center;padding:var(--spacing-xs) 0;z-index:100;height:60px;box-shadow:0 -2px 8px #0000004d}.tab-button{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xs);text-decoration:none;color:var(--text-muted);transition:all .2s ease;flex:1;height:100%;position:relative}.tab-button:hover{color:var(--text-secondary)}.tab-icon{font-size:1.25rem;margin-bottom:2px}.tab-label{font-size:.75rem;font-weight:400}.tab-active{color:#10b981}.tab-active .tab-label{font-weight:600}.tab-active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:40px;height:2px;background:#10b981}@media(max-width:768px){.app-header{padding:var(--spacing-sm) var(--spacing-md)}.header-title{font-size:1.25rem}.tab-bar{height:56px}.app-content{padding-bottom:56px}}@supports (padding-bottom: env(safe-area-inset-bottom)){.tab-bar{padding-bottom:env(safe-area-inset-bottom);height:calc(60px + env(safe-area-inset-bottom))}.app-content{padding-bottom:calc(60px + env(safe-area-inset-bottom))}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);padding:var(--space-2xl)}.loading-container.small{padding:var(--space-lg)}.loading-container.large{padding:var(--space-3xl);min-height:400px}.loading-spinner{border:3px solid var(--border-subtle);border-top:3px solid var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.loading-container.small .loading-spinner{width:20px;height:20px;border-width:2px}.loading-container.medium .loading-spinner{width:40px;height:40px}.loading-container.large .loading-spinner{width:60px;height:60px;border-width:4px}.loading-message{color:var(--text-secondary);font-size:.875rem;margin:0}[data-theme=light] .loading-spinner{border-color:#0000001a;border-top-color:var(--accent-primary)}.home-page{min-height:100%;padding:var(--spacing-lg);padding-bottom:var(--spacing-2xl)}.home-page .container{max-width:1200px;margin:0 auto}.welcome-header{text-align:center;padding-top:0;margin:var(--spacing-md) 0 var(--spacing-xl) 0;animation:slideUp .6s ease}.welcome-title{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-sm);letter-spacing:-.02em}.welcome-subtitle{color:var(--text-secondary);font-size:1.125rem;font-weight:400}.main-cta-section{display:flex;flex-direction:column;gap:var(--spacing-xl);margin-bottom:var(--spacing-xl);animation:fadeIn .8s ease .1s backwards}.primary-cta-button{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-xl) var(--spacing-2xl);background:linear-gradient(135deg,var(--accent-primary),var(--accent-primary-hover));border-radius:var(--radius-xl);text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 32px #00e05433;position:relative;overflow:hidden}.primary-cta-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}.primary-cta-button:hover{transform:translateY(-2px);box-shadow:0 12px 48px #00e0544d}.primary-cta-button:hover:before{left:100%}.cta-icon{display:flex;align-items:center;justify-content:center;font-size:2.5rem;flex-shrink:0}.cta-content{display:flex;flex-direction:column;gap:var(--spacing-xs);text-align:left}.cta-title{color:#000;font-size:1.25rem;font-weight:700;letter-spacing:-.01em}.cta-description{color:#000000b3;font-size:.95rem}.continue-study-card{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-xl);background:var(--bg-secondary);border:1px solid var(--accent-primary);border-radius:var(--radius-lg);text-decoration:none;transition:all .2s ease;position:relative;overflow:hidden}.continue-study-card:after{content:"";position:absolute;inset:0;background:var(--accent-primary-soft);opacity:0;transition:opacity .2s ease}.continue-study-card:hover{transform:translate(4px);border-color:var(--accent-primary-hover)}.continue-study-card:hover:after{opacity:1}.continue-label{color:var(--accent-primary);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-right:var(--spacing-lg);position:relative;z-index:1}.continue-film-info{flex:1;display:flex;align-items:baseline;gap:var(--spacing-sm);position:relative;z-index:1}.continue-film-title{color:var(--text-primary);font-size:1.125rem;font-weight:600}.continue-film-year{color:var(--text-secondary);font-size:.95rem}.continue-arrow{color:var(--accent-primary);font-size:1.5rem;position:relative;z-index:1}.info-section{margin-bottom:var(--spacing-xl);animation:fadeIn .8s ease .2s backwards}.info-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl)}.info-section-title{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.carousel-controls{display:flex;align-items:center;gap:var(--spacing-md)}.carousel-button{width:36px;height:36px;border-radius:var(--radius-full);background:var(--bg-secondary);border:1px solid var(--border-subtle);color:var(--text-primary);font-size:1.125rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.carousel-button:hover{background:var(--bg-tertiary);border-color:var(--accent-primary);color:var(--accent-primary)}.carousel-indicator{color:var(--text-secondary);font-size:.875rem;font-weight:500;min-width:50px;text-align:center}.info-cards-container{overflow:hidden;border-radius:var(--radius-lg)}.info-cards-track{display:flex;transition:transform .4s cubic-bezier(.4,0,.2,1)}.info-card{flex:0 0 100%;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--spacing-2xl);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:350px;text-align:center}.info-card-body{display:contents}.info-card-icon{width:80px;height:80px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin:0 auto var(--spacing-sm)}.info-card-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-md)}.info-card-content{color:var(--text-secondary);font-size:1rem;line-height:1.6;max-width:500px;margin:0 auto}.quick-links-section{margin-bottom:var(--spacing-xl);animation:fadeIn .8s ease .3s backwards}.quick-links-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xl)}.quick-links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg)}.quick-link-card{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);text-decoration:none;transition:all .2s ease}.quick-link-card:hover{transform:translateY(-2px);border-color:var(--accent-primary);box-shadow:0 8px 24px #0000004d}.quick-link-icon{width:56px;height:56px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0}.quick-link-content{flex:1}.quick-link-content h3{color:var(--text-primary);font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-xs)}.quick-link-content p{color:var(--text-secondary);font-size:.875rem;line-height:1.4}.study-tip-card{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-xl);background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--accent-primary);border-radius:var(--radius-lg);margin-bottom:var(--spacing-2xl);animation:fadeIn .8s ease .4s backwards}.study-tip-icon{display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0}.study-tip-content h4{color:var(--accent-primary);font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--spacing-sm)}.study-tip-content p{color:var(--text-secondary);font-size:.95rem;line-height:1.6}@media(max-width:768px){.welcome-title{font-size:2rem}.primary-cta-button{padding:var(--spacing-lg) var(--spacing-xl)}.cta-icon{font-size:2rem}.cta-title{font-size:1.125rem}.quick-links-grid{grid-template-columns:1fr}.info-section-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.carousel-controls{align-self:flex-end}}@media(max-width:480px){.welcome-title{font-size:1.75rem}.welcome-subtitle{font-size:1rem}.primary-cta-button{flex-direction:column;text-align:center}.cta-content{text-align:center}.quick-link-card,.study-tip-card{flex-direction:column;text-align:center}.info-card{min-height:350px}}.star-rating{display:flex;align-items:center;gap:12px;transition:opacity .2s ease}.star-rating-label{font-size:14px;font-weight:500;color:var(--text-secondary);min-width:140px;letter-spacing:.3px}.stars-container{display:flex;gap:3px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px;border-radius:8px;transition:background-color .2s ease;outline:none;position:relative}.stars-container:focus-visible{background-color:#ffffff0d;box-shadow:0 0 0 2px #00e0544d}.star-rating.focused .stars-container{background-color:#ffffff08}.star-rating.readonly .stars-container{cursor:default;padding:0}.star-rating *{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.star{position:relative;display:inline-block;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.star-small{width:18px;height:18px}.star-medium{width:28px;height:28px}.star-large{width:36px;height:36px}.star-left,.star-right{position:absolute;top:0;height:100%;width:50%;z-index:10;cursor:pointer;background:transparent;transition:opacity .15s ease}.star-left{left:0}.star-right{right:0}.star-rating.readonly .star-left,.star-rating.readonly .star-right{cursor:default}.star-svg{width:100%;height:100%;transition:all .25s cubic-bezier(.34,1.56,.64,1);filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.star-full .star-svg{transform:scale(1);animation:starPop .3s ease}.star-half .star-svg{transform:scale(1)}.star-empty:hover .star-svg{transform:scale(1.15) rotate(5deg);filter:drop-shadow(0 3px 6px rgba(0,0,0,.2))}.star-full:hover .star-svg,.star-half:hover .star-svg{transform:scale(1.12);filter:drop-shadow(0 3px 8px rgba(0,0,0,.25))}.star-rating.readonly .star:hover .star-svg{transform:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}@keyframes starPop{0%{transform:scale(.8) rotate(-10deg)}50%{transform:scale(1.2) rotate(5deg)}to{transform:scale(1) rotate(0)}}@keyframes starGlow{0%,to{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1)) drop-shadow(0 0 8px currentColor);opacity:1}50%{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1)) drop-shadow(0 0 12px currentColor);opacity:.95}}.star-full .star-svg path{animation:starGlow 2s ease-in-out infinite}.star-rating-value{font-size:15px;font-weight:600;min-width:45px;text-align:right;letter-spacing:.5px;transition:color .2s ease;opacity:.9}@media(hover:none)and (pointer:coarse){.star-left:active,.star-right:active{opacity:.7}.stars-container{gap:5px;padding:8px 4px}}@media(max-width:600px){.star-rating{flex-wrap:wrap;gap:8px}.star-rating-label{flex:1 0 100%;min-width:unset;margin-bottom:4px}.star-small{width:20px;height:20px}.star-medium{width:30px;height:30px}.star-large{width:38px;height:38px}}.rating-section{background:#1c1c1e99;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:24px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,inset 0 1px #ffffff0d;border:1px solid rgba(255,255,255,.05);transition:all .3s ease}.rating-section:hover{box-shadow:0 10px 15px -3px #00000026,0 4px 6px -2px #00000014,inset 0 1px #ffffff14}.rating-row{padding:12px 0;border-bottom:1px solid rgba(255,255,255,.03);transition:background-color .2s ease}.rating-row:hover{background-color:#ffffff05;margin:0 -12px;padding:12px}.rating-row:last-child{border-bottom:none}.diary-page{min-height:100%;padding:var(--spacing-lg)}.diary-page .container{max-width:1200px;margin:0 auto}.diary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-top:0}.diary-header h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-sm);margin-top:0}.diary-subtitle{color:var(--text-secondary);font-size:1rem}.diary-timeline{display:flex;flex-direction:column;gap:var(--spacing-xl)}.diary-month-group{margin-bottom:var(--spacing-lg)}.diary-month-header{font-size:1.2rem;font-weight:600;color:var(--accent);letter-spacing:.5px;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--bg-tertiary)}.diary-entries{display:flex;overflow-x:auto;gap:var(--spacing-sm);padding-bottom:var(--spacing-sm);-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}.diary-entry{display:flex;flex-direction:column;min-width:180px;max-width:180px;padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:transform .2s ease,background .2s ease;border:1px solid transparent;flex-shrink:0;scroll-snap-align:start}.diary-entry:hover{transform:translateY(-4px);background:var(--bg-tertiary);border-color:var(--accent)}.diary-entry-poster{width:100%;height:240px;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-tertiary);margin-bottom:var(--spacing-xs)}.diary-entry-poster img{width:100%;height:100%;object-fit:cover}.diary-entry-poster-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);font-size:1.5rem;opacity:.5}.diary-entry-info{flex:1;display:flex;flex-direction:column;justify-content:space-between;min-width:0;padding:var(--spacing-xs)}.diary-entry-title{font-size:.85rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.diary-entry-meta{font-size:.7rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.diary-entry-rating{margin-bottom:var(--spacing-xs)}.diary-entry-date{font-size:.8rem;color:var(--text-muted);font-weight:500}.diary-entry-progress{margin:var(--spacing-sm) 0}.progress-bar{width:100%;height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-xs)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--star-technical));border-radius:var(--radius-full);transition:width .3s ease}.progress-details{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.progress-indicator{font-size:.75rem;color:var(--text-muted);opacity:.5;transition:all .2s ease}.progress-indicator.active{color:var(--accent-primary);opacity:1;font-weight:500}.diary-page .empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-lg);max-width:400px;margin:0 auto;margin-top:var(--spacing-2xl)}.diary-page .empty-icon{font-size:4rem;margin-bottom:var(--spacing-lg);opacity:.8}.diary-page .empty-state h2{color:var(--text-primary);font-size:1.75rem;margin-bottom:var(--spacing-sm)}.diary-page .empty-state p{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:var(--spacing-xl)}@media(max-width:768px){.diary-header h1{font-size:1.5rem}.diary-month-header{font-size:1rem}.diary-entries{scroll-snap-type:x mandatory}.diary-entry{min-width:160px;max-width:160px}.diary-entry-poster{height:220px}}@media(max-width:480px){.diary-page{padding:var(--spacing-md)}.diary-entry{padding:var(--spacing-xs);min-width:150px;max-width:150px}.diary-entry-poster{height:200px}.diary-entry-title{font-size:.8rem}.diary-entry-meta{font-size:.65rem}.diary-entry-date{font-size:.7rem}}.discover-page{min-height:100%;padding:var(--spacing-lg)}.discover-header{margin-bottom:var(--spacing-xl);padding-top:0;text-align:left}.discover-title{font-size:2rem;font-weight:700;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.discover-subtitle{color:var(--text-secondary);font-size:1rem}.search-section{margin-bottom:var(--spacing-xl)}.search-input-wrapper{position:relative;display:flex;align-items:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:0 var(--spacing-lg);transition:border-color .2s ease}.search-input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #ff6b351a}.search-icon{font-size:1.2rem;margin-right:var(--spacing-md);opacity:.6}.search-input{flex:1;background:transparent;border:none;padding:var(--spacing-md) 0;font-size:1rem;color:var(--text-primary);outline:none}.search-input::placeholder{color:var(--text-muted)}.search-clear{background:none;border:none;color:var(--text-secondary);padding:var(--spacing-xs);margin-left:var(--spacing-sm);cursor:pointer;font-size:1.2rem;opacity:.7;transition:opacity .2s ease}.search-clear:hover{opacity:1}.search-loading{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);margin-top:var(--spacing-md);font-size:.9rem}.loading-spinner-small{display:inline-block;animation:spin 1s linear infinite}.discover-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-lg);animation:fadeIn .3s ease}@media(max-width:768px){.discover-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-md)}}.discover-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;text-align:left;width:100%;padding:0;position:relative}.discover-card:hover:not(:disabled){transform:translateY(-4px);box-shadow:0 8px 24px #0006;border-color:var(--accent-dim)}.discover-card:disabled{opacity:.6;cursor:not-allowed}.discover-poster{width:100%;aspect-ratio:2/3;object-fit:cover;display:block}.discover-poster-placeholder{width:100%;aspect-ratio:2/3;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:3rem}.discover-info{padding:var(--spacing-md);flex:1;display:flex;flex-direction:column}.discover-film-title{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-xs);color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.3}.discover-meta{color:var(--text-secondary);font-size:.85rem;margin-bottom:var(--spacing-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.discover-year,.discover-director{color:var(--text-secondary)}.discover-add-btn{margin-top:auto;padding:6px 12px;background:var(--accent);color:#000;border:none;border-radius:var(--radius-full);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s ease;text-align:center;width:100%;display:inline-flex;align-items:center;justify-content:center}.discover-view-btn{margin-top:auto;padding:6px 12px;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-full);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s ease;text-align:center;width:100%;display:inline-flex;align-items:center;justify-content:center}@media(min-width:768px){.discover-add-btn,.discover-view-btn{padding:var(--space-sm) var(--space-lg);font-size:14px}}.discover-add-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #00e0544d}.discover-view-btn:hover{background:var(--surface-subtle);border-color:#ffffff1a}.empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-lg);max-width:400px;margin:0 auto;margin-top:var(--spacing-2xl)}.empty-icon{font-size:4rem;margin-bottom:var(--spacing-lg);opacity:.8}.empty-state h2{color:var(--text-primary);font-size:1.75rem;margin-bottom:var(--spacing-sm)}.empty-state p{color:var(--text-secondary);font-size:1rem;line-height:1.6}.loading-spinner{font-size:3rem;display:inline-block;animation:spin 1s linear infinite;opacity:.7;margin-bottom:var(--spacing-lg)}.details-loading{text-align:center;color:var(--text-secondary);font-size:.9rem;margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg);animation:fadeIn .2s ease}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-lg);max-width:900px;max-height:90vh;width:100%;overflow-y:auto;position:relative;animation:slideUp .3s ease;border:1px solid var(--border)}.modal-close{position:absolute;top:var(--spacing-lg);right:var(--spacing-lg);background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;z-index:10;transition:all .2s ease}.modal-close:hover{background:var(--accent);border-color:var(--accent)}.modal-loading{padding:var(--spacing-2xl);text-align:center}.modal-error{padding:var(--spacing-2xl);text-align:center;color:var(--text-secondary)}.modal-body{padding:0}.modal-header-section{display:flex;gap:var(--spacing-xl);padding:var(--spacing-xl);background:linear-gradient(to bottom,var(--bg-tertiary),transparent)}@media(max-width:768px){.modal-header-section{flex-direction:column}}.modal-poster-section{flex-shrink:0}.modal-poster{width:250px;border-radius:var(--radius-md);box-shadow:0 8px 24px #0006}.modal-poster-placeholder{width:250px;aspect-ratio:2/3;background:var(--bg-tertiary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:4rem}@media(max-width:768px){.modal-poster,.modal-poster-placeholder{width:100%;max-width:300px;margin:0 auto}}.modal-info-section{flex:1;display:flex;flex-direction:column;gap:var(--spacing-md)}.modal-title{font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1.2}.modal-meta{display:flex;gap:var(--spacing-md);color:var(--text-secondary);font-size:1rem;flex-wrap:wrap}.modal-rating{color:var(--accent)}.modal-tagline{font-style:italic;color:var(--text-secondary);font-size:1.1rem;opacity:.9}.modal-genres{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.genre-tag{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;color:var(--text-secondary)}.modal-crew{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--bg-primary);border-radius:var(--radius-md)}.crew-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.crew-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.crew-value{font-size:.95rem;color:var(--text-primary);font-weight:500}.modal-add-btn{width:100%;padding:6px 12px;background:var(--accent);color:#000;border:none;border-radius:var(--radius-full);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s ease;margin-top:var(--spacing-md);display:inline-flex;align-items:center;justify-content:center}@media(min-width:768px){.modal-add-btn{padding:var(--space-sm) var(--space-lg);font-size:14px}}.modal-add-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #00e0544d}.modal-add-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.modal-details-section{padding:0 var(--spacing-xl) var(--spacing-xl)}.modal-section{margin-bottom:var(--spacing-xl)}.modal-section-title{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--text-primary)}.modal-synopsis{color:var(--text-primary);line-height:1.6;font-size:1rem}.modal-cast{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-md)}.cast-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:background .2s ease}.cast-item:hover{background:var(--bg-tertiary)}.cast-photo,.crew-photo{width:48px;height:48px;flex-shrink:0;border-radius:var(--radius-full);overflow:hidden;background:var(--bg-secondary)}.cast-photo img,.crew-photo img{width:100%;height:100%;object-fit:cover}.cast-photo-placeholder,.crew-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-tertiary);font-size:1.25rem}.cast-info,.crew-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.cast-name{color:var(--text-primary);font-weight:500;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cast-character{color:var(--text-secondary);font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-crew-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-md)}.crew-member-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:background .2s ease}.crew-member-item:hover{background:var(--bg-tertiary)}.crew-name{color:var(--text-primary);font-weight:500;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.crew-role{color:var(--text-secondary);font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-box-office{display:flex;gap:var(--spacing-2xl);flex-wrap:wrap}.box-office-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.box-office-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.box-office-value{font-size:1.25rem;font-weight:600;color:var(--accent)}.modal-production{color:var(--text-secondary);line-height:1.5}.modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg)}.modal-content{background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);max-width:500px;width:100%;max-height:80vh;display:flex;flex-direction:column;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--space-xl);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .12s ease}.modal-close:hover{background:var(--surface-subtle);color:var(--text-primary)}.modal-body{padding:var(--space-xl);overflow-y:auto;flex:1}.export-section{margin-bottom:var(--space-2xl)}.export-section:last-child{margin-bottom:0}.export-section h3{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-md)}.format-options,.selection-options{display:flex;flex-direction:column;gap:var(--space-sm)}.format-option,.selection-option{display:flex;align-items:flex-start;padding:var(--space-md);background:var(--surface-subtle);border-radius:var(--radius-md);border:1px solid var(--border-subtle);cursor:pointer;transition:all .12s ease}.format-option:hover,.selection-option:hover{border-color:var(--accent-primary);background:#00e05408}.format-option input[type=radio],.selection-option input[type=radio]{margin-right:var(--space-md);margin-top:2px}.format-label{display:flex;flex-direction:column;gap:var(--space-xs)}.format-label strong{color:var(--text-primary);font-weight:600}.format-label small{color:var(--text-secondary);font-size:13px}.film-list{margin-top:var(--space-lg);max-height:200px;overflow-y:auto;background:var(--surface-subtle);border-radius:var(--radius-md);padding:var(--space-md)}.film-checkbox{display:flex;align-items:center;padding:var(--space-sm);cursor:pointer;transition:background .12s ease;border-radius:var(--radius-sm)}.film-checkbox:hover{background:#ffffff08}.film-checkbox input[type=checkbox]{margin-right:var(--space-md)}.film-checkbox span{color:var(--text-primary);font-size:14px}.no-films{color:var(--text-secondary);text-align:center;padding:var(--space-xl)}.modal-footer{padding:var(--space-xl);border-top:1px solid var(--border-subtle);display:flex;gap:var(--space-md);justify-content:flex-end}[data-theme=light] .modal-overlay{background:#fffc}[data-theme=light] .modal-content{background:#fff;border-color:#0000001a}[data-theme=light] .modal-header{border-bottom-color:#0000001a}[data-theme=light] .format-option,[data-theme=light] .selection-option{background:#f5f7fa;border-color:#00000014}[data-theme=light] .film-list{background:#f5f7fa}[data-theme=light] .modal-footer{border-top-color:#0000001a}.profile-page{min-height:100%;padding:var(--spacing-lg);padding-bottom:var(--spacing-2xl)}.profile-page>.container>h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xl);padding-top:0;text-align:center}.profile-header-section{text-align:center;padding:var(--spacing-2xl) var(--spacing-lg);margin-bottom:var(--spacing-2xl);background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border-radius:var(--radius-xl);position:relative;animation:slideUp .6s ease}.profile-avatar-container{position:relative;display:inline-block;margin-bottom:var(--spacing-lg)}.profile-avatar{width:120px;height:120px;background:linear-gradient(135deg,var(--accent-primary),var(--star-technical));border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #00e05433;cursor:pointer;transition:transform .12s ease}.profile-avatar:hover{transform:scale(1.05)}.avatar-icon{font-size:3.5rem}.avatar-change-button{position:absolute;bottom:0;right:0;width:36px;height:36px;background:var(--bg-primary);border:2px solid var(--accent-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.avatar-change-button:hover{transform:scale(1.1);background:var(--accent-primary)}.avatar-change-button span{font-size:1rem}.profile-name{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs);cursor:pointer;display:inline-flex;align-items:center;gap:var(--spacing-sm);transition:opacity .12s ease}.profile-name:hover{opacity:.8}.profile-name .edit-icon{font-size:1.2rem;opacity:.6;transition:opacity .12s ease}.profile-name:hover .edit-icon{opacity:1}.name-edit-container{margin-bottom:var(--spacing-xs)}.name-input{font-size:2rem;font-weight:700;color:var(--text-primary);background:var(--bg-tertiary);border:2px solid var(--accent-primary);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);text-align:center;width:auto;min-width:200px;max-width:400px}.avatar-picker-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.avatar-picker{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);padding:var(--spacing-2xl);max-width:400px;width:90%;animation:slideUp .2s ease}.avatar-picker h3{color:var(--text-primary);font-size:1.25rem;margin-bottom:var(--spacing-lg);text-align:center}.avatar-options{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md)}.avatar-option{width:60px;height:60px;border-radius:50%;background:var(--bg-tertiary);border:2px solid var(--border-subtle);display:flex;align-items:center;justify-content:center;font-size:2rem;cursor:pointer;transition:all .12s ease}.avatar-option:hover{background:var(--accent-primary-soft);border-color:var(--accent-primary);transform:scale(1.1)}.avatar-option.selected{background:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 4px 12px #00e0544d}.profile-email{color:var(--text-secondary);font-size:1rem;margin-bottom:var(--spacing-md)}.streak-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:linear-gradient(135deg,#ff6b35,#f7b731);color:#fff;border-radius:var(--radius-full);font-weight:600;font-size:.875rem;animation:pulse 2s infinite}.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl);animation:fadeIn .8s ease .1s backwards}.metric-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);border:1px solid var(--border-subtle);transition:all .2s ease}.metric-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d;border-color:var(--accent-primary)}.metric-icon{width:56px;height:56px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.75rem;flex-shrink:0}.metric-content{display:flex;flex-direction:column}.metric-value{font-size:1.75rem;font-weight:700;color:var(--accent-primary);line-height:1}.metric-label{font-size:.875rem;color:var(--text-secondary);margin-top:var(--spacing-xs)}.detailed-stats-section{margin-bottom:var(--spacing-2xl);animation:fadeIn .8s ease .2s backwards}.section-header{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm)}.section-header:before{content:"";width:4px;height:24px;background:var(--accent-primary);border-radius:var(--radius-sm)}.detailed-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--border-subtle)}.stat-item{text-align:center;padding:var(--spacing-md);border-right:1px solid var(--border-subtle)}.stat-item:last-child{border-right:none}.stat-value{display:block;font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary),var(--accent-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-xs)}.stat-description{font-size:.875rem;color:var(--text-secondary)}.top-films-section{margin-bottom:var(--spacing-2xl);animation:fadeIn .8s ease .3s backwards}.top-films-list{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-subtle)}.top-film-link{text-decoration:none;color:inherit;display:block}.top-film-link:hover .top-film-item{background:var(--bg-tertiary)}.top-film-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--border-subtle);transition:background .2s ease;cursor:pointer}.top-film-item:last-child{border-bottom:none}.film-rank{min-width:32px;min-height:32px;width:32px;height:32px;background:linear-gradient(135deg,var(--accent-primary),var(--star-technical));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#000;font-weight:700;font-size:.875rem;flex-shrink:0;aspect-ratio:1}.film-details{flex:1;min-width:0;overflow:hidden;display:flex;flex-direction:column}.film-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;width:100%}.film-meta{font-size:.875rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;width:100%}.film-rating{flex-shrink:0;margin-left:auto}@media(max-width:414px){.top-film-item:nth-child(n+4){display:none}.film-title{font-size:.875rem;white-space:normal;overflow:visible;text-overflow:clip;line-height:1.3}.film-meta{display:none}.top-films-list{padding:var(--spacing-md)}.top-film-item{gap:var(--spacing-sm);align-items:center}.film-rank{font-size:.75rem;width:28px;height:28px;min-width:28px;min-height:28px}.film-details{flex-direction:row;align-items:center;justify-content:space-between}.film-rating{margin-left:var(--spacing-sm)}}.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl);animation:fadeIn .8s ease .4s backwards}.directors-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--border-subtle)}.directors-chart{display:flex;flex-direction:column;gap:var(--spacing-md)}.director-row{display:grid;grid-template-columns:120px 1fr 40px;align-items:center;gap:var(--spacing-md)}.director-name{font-size:.875rem;color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.director-bar-container{height:24px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.director-bar{height:100%;border-radius:var(--radius-full);transition:width .5s ease;animation:slideIn 1s ease}.director-count{font-size:.875rem;color:var(--text-secondary);font-weight:600}.genres-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--border-subtle)}.genres-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.genre-card{padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;text-align:center;transition:all .2s ease}.genre-card:hover{background:var(--accent-primary-soft);transform:translateY(-2px)}.genre-name{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.genre-count{font-size:.8rem;color:var(--text-secondary)}.year-distribution-section{margin-bottom:var(--spacing-2xl);animation:fadeIn .8s ease .5s backwards}.year-chart{display:flex;align-items:flex-end;gap:var(--spacing-md);height:200px;background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--border-subtle)}.year-column{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.year-bar-wrapper{flex:1;width:100%;display:flex;align-items:flex-end}.year-bar-fill{width:100%;background:linear-gradient(to top,var(--accent-primary),var(--star-technical));border-radius:var(--radius-sm) var(--radius-sm) 0 0;position:relative;transition:height .5s ease;animation:growUp 1s ease}.year-count-label{position:absolute;top:-20px;left:50%;transform:translate(-50%);color:var(--text-primary);font-size:.875rem;font-weight:600}.year-label{color:var(--text-secondary);font-size:.875rem;margin-top:var(--spacing-sm)}.settings-section{margin-bottom:var(--spacing-xl);animation:fadeIn .8s ease .6s backwards}.settings-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--border-subtle)}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) 0;border-bottom:1px solid var(--border-subtle)}.setting-item:last-of-type{border-bottom:none}.setting-info h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.setting-info p{font-size:.875rem;color:var(--text-secondary)}.theme-toggle,.export-button{padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.theme-toggle:hover,.export-button:hover{background:var(--accent-primary-soft);border-color:var(--accent-primary)}.sign-out-button{width:100%;margin-top:var(--spacing-xl);padding:var(--spacing-md) var(--spacing-xl);background:linear-gradient(135deg,#ff4d70,#ff365c);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.sign-out-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff4d704d}.profile-empty-state{text-align:center;padding:var(--spacing-3xl);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);margin:var(--spacing-2xl) 0}.empty-state-icon{font-size:4rem;margin-bottom:var(--spacing-lg);opacity:.8}.profile-empty-state h2{color:var(--text-primary);font-size:1.75rem;margin-bottom:var(--spacing-sm)}.profile-empty-state p{color:var(--text-secondary);font-size:1rem;max-width:400px;margin:0 auto}@media(max-width:1024px){.stats-row{grid-template-columns:1fr}.detailed-stats-grid{grid-template-columns:repeat(2,1fr)}.stat-item:nth-child(2n){border-right:none}.stat-item:nth-last-child(-n+2){border-bottom:none}}@media(max-width:768px){.metrics-grid,.detailed-stats-grid{grid-template-columns:1fr}.stat-item{border-right:none!important;border-bottom:1px solid var(--border-subtle)}.stat-item:last-child{border-bottom:none}.director-row{grid-template-columns:100px 1fr 40px}}@media(max-width:480px){.profile-name{font-size:1.5rem}.genres-grid{grid-template-columns:1fr}.year-chart{padding:var(--spacing-md);gap:var(--spacing-xs)}.year-count-label{font-size:.75rem}.top-films-section{display:none}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes slideIn{0%{width:0}}@keyframes growUp{0%{height:0}}.back-link{display:inline-flex;align-items:center;color:var(--text-secondary);text-decoration:none;font-size:.95rem;margin-bottom:var(--spacing-md);transition:color .2s ease}.back-link:hover{color:var(--text-primary)}.new-film-content{display:flex;flex-direction:column;gap:var(--spacing-xl);max-width:800px;margin:0 auto}.search-section{margin-bottom:var(--spacing-lg)}.search-section h2{font-size:1.3rem;margin-bottom:var(--spacing-lg);color:var(--text-primary)}.search-container{position:relative}.search-loading{color:var(--text-secondary);font-size:.9rem;margin-top:var(--spacing-sm)}.search-results{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);margin-top:var(--spacing-xs);max-height:400px;overflow-y:auto;z-index:10;box-shadow:0 4px 16px #0000004d}.search-result-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;width:100%;text-align:left;cursor:pointer;transition:background .2s ease;color:var(--text-primary)}.search-result-item:hover{background:var(--bg-secondary)}.result-poster{width:40px;height:60px;object-fit:cover;border-radius:var(--radius-sm);background:var(--bg-tertiary)}.result-info{flex:1;min-width:0}.result-title{font-weight:500;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-year{font-size:.85rem;color:var(--text-secondary)}.film-form h2{font-size:1.3rem;margin-bottom:var(--spacing-lg);color:var(--text-primary)}.form-poster{width:200px;height:300px;object-fit:cover;border-radius:var(--radius-md);margin-bottom:var(--spacing-xl);display:block;box-shadow:0 4px 16px #0000004d}.form-row{margin-bottom:var(--spacing-lg)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.create-button{margin-top:var(--spacing-xl);width:100%;padding:var(--spacing-md);font-size:1rem}@media(max-width:640px){.form-grid{grid-template-columns:1fr}.form-poster{width:150px;height:225px}}.credits-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.credits-modal{background:var(--bg-primary);border-radius:var(--radius-lg);width:90%;max-width:800px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease}.credits-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl);border-bottom:1px solid var(--border-color)}.credits-modal-header h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0}.credits-modal-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.credits-modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.credits-tabs{display:flex;gap:var(--spacing-xs);padding:var(--spacing-md) var(--spacing-xl);background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.credits-tab{padding:var(--spacing-sm) var(--spacing-lg);background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.credits-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.credits-tab.active{background:var(--accent-primary-soft);color:var(--accent-primary);border-color:var(--accent-primary)}.credits-modal-content{flex:1;overflow-y:auto;padding:var(--spacing-xl)}.credits-loading,.credits-empty{text-align:center;color:var(--text-secondary);padding:var(--spacing-3xl)}.credits-list{display:grid;gap:var(--spacing-md)}.credit-person{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:background .2s ease}.credit-person:hover{background:var(--bg-secondary)}.credit-person-photo{width:48px;height:48px;flex-shrink:0;border-radius:var(--radius-full);overflow:hidden;background:var(--bg-secondary)}.credit-person-photo img{width:100%;height:100%;object-fit:cover}.credit-person-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-tertiary)}.credit-person-info{flex:1;min-width:0}.credit-person-name{color:var(--text-primary);font-size:1rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.credit-person-role{color:var(--text-secondary);font-size:.875rem;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.credits-modal{width:95%;max-height:90vh}.credits-modal-header{padding:var(--spacing-lg)}.credits-modal-header h2{font-size:1.25rem}.credits-tabs{padding:var(--spacing-sm) var(--spacing-lg)}.credits-modal-content{padding:var(--spacing-lg)}}@media(max-width:480px){.credits-modal-header h2{font-size:1.125rem}.credit-person-photo{width:40px;height:40px}.credit-person-name{font-size:.95rem}.credit-person-role{font-size:.8125rem}}.film-detail{min-height:100vh;background:var(--bg-primary);padding-bottom:var(--spacing-3xl)}.film-detail-header{position:sticky;top:0;z-index:100;background:#101217f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);padding:var(--spacing-md) var(--spacing-xl);display:flex;align-items:center;justify-content:space-between}.header-back{color:var(--text-secondary);text-decoration:none;font-size:.95rem;transition:color .2s ease;display:flex;align-items:center}.header-back:hover{color:var(--accent-primary)}.header-title{font-size:1.25rem;font-weight:600;flex:1;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0 var(--spacing-lg)}.header-actions{display:flex;align-items:center;gap:var(--spacing-md)}.save-indicator{font-size:.85rem;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);animation:fadeIn .2s ease}.save-indicator.saved{background:var(--accent-primary);color:#000}.header-delete{background:none;border:none;font-size:1.2rem;cursor:pointer;opacity:.7;transition:opacity .2s ease}.header-delete:hover{opacity:1}.delete-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.delete-modal{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:400px;width:90%}.delete-modal h3{margin-bottom:var(--spacing-md)}.delete-modal p{color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.delete-modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end}.film-hero-card{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--spacing-2xl);margin:var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);animation:slideUp .6s ease}.hero-content{display:flex;gap:var(--spacing-2xl)}.hero-poster{flex-shrink:0;width:200px}.hero-poster img{width:100%;aspect-ratio:2/3;object-fit:cover;border-radius:var(--radius-lg);box-shadow:0 12px 32px #00000080}.hero-info{flex:1}.hero-title{font-size:2.5rem;font-weight:700;margin-bottom:var(--spacing-md);background:linear-gradient(135deg,var(--text-primary),var(--accent-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-meta{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.meta-badge{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-size:.875rem;color:var(--text-secondary);display:flex;align-items:center;gap:var(--spacing-xs)}.hero-director{font-size:1.125rem;color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.hero-director strong{color:var(--text-primary)}.hero-progress{margin-bottom:var(--spacing-xl)}.hero-progress h3{font-size:1rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);margin-bottom:var(--spacing-md)}.progress-bar-large{height:12px;background:var(--bg-primary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-md)}.progress-fill-large{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--star-technical));border-radius:var(--radius-full);transition:width .5s ease}.progress-stats{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.progress-stat{font-size:.875rem;color:var(--text-muted);opacity:.6;transition:all .2s ease}.progress-stat.active{color:var(--accent-primary);opacity:1;font-weight:500}.hero-rating{margin-top:var(--spacing-lg)}.tab-navigation-fixed{display:flex;gap:var(--spacing-xs);padding:var(--spacing-md) var(--spacing-xl);background:var(--bg-secondary);border-bottom:2px solid var(--border);position:sticky;top:60px;z-index:90}.tab-button{flex:1;padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);border-radius:var(--radius-md)}.tab-icon{font-size:1.125rem}.tab-label{display:inline}.tab-button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.tab-button.active{background:var(--accent-primary-soft);color:var(--accent-primary)}.tab-button.active:after{content:"";position:absolute;bottom:-2px;left:20%;right:20%;height:3px;background:var(--accent-primary);border-radius:var(--radius-sm)}.tab-content{padding:var(--spacing-2xl) var(--spacing-xl);max-width:1200px;margin:0 auto;animation:fadeIn .4s ease}.tab-title{font-size:1.75rem;font-weight:600;margin-bottom:var(--spacing-sm)}.tab-helper-text{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:var(--spacing-2xl)}.overview-sections{display:grid;gap:var(--spacing-xl)}.overview-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.overview-card h3{font-size:1.25rem;font-weight:600;color:var(--accent-primary);margin-bottom:var(--spacing-lg)}.credits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg)}.credit-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.credit-label{font-size:.875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.credit-value{font-size:1rem;color:var(--text-primary);font-weight:500}.see-full-credits-button{margin-top:var(--spacing-lg);padding:var(--spacing-sm) var(--spacing-lg);background:var(--accent-primary-soft);color:var(--accent-primary);border:1px solid var(--accent-primary);border-radius:var(--radius-sm);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.see-full-credits-button:hover{background:var(--accent-primary);color:#000;transform:translateY(-1px);box-shadow:0 4px 12px #00e0544d}.components-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.component-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:all .2s ease;cursor:pointer}.component-item:hover{background:var(--bg-secondary);transform:translate(4px)}.component-item.in-progress{border-color:var(--star-originality)}.component-item.complete{border-color:var(--accent-primary);background:var(--accent-primary-soft)}.component-icon{font-size:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:var(--radius-md)}.component-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.component-name{font-weight:600;color:var(--text-primary)}.component-status{font-size:.875rem;color:var(--text-secondary)}.timeline-info p{margin-bottom:var(--spacing-sm);color:var(--text-secondary)}.timeline-info strong{color:var(--text-primary)}.beats-progress-section{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.beats-progress-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}.beats-progress-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.beats-progress-label{font-size:.875rem;color:var(--text-secondary);display:flex;justify-content:space-between;align-items:center}.beats-progress-bar{height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;position:relative}.beats-progress-fill{height:100%;background:var(--accent-primary);border-radius:var(--radius-full);transition:width .3s ease}.structure-toggle{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.structure-toggle-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-sm);display:block}.structure-toggle-buttons{display:flex;gap:2px;background:var(--bg-tertiary);border-radius:var(--radius-md);padding:4px}.structure-toggle-button{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.95rem}.structure-toggle-button:hover{color:var(--text-primary)}.structure-toggle-button.active{background:var(--bg-primary);color:var(--accent-primary);box-shadow:0 1px 3px #0003}.beats-actions{margin-bottom:var(--spacing-lg)}.expand-all-button{padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-full);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.expand-all-button:hover{background:var(--accent-primary-soft);border-color:var(--accent-primary)}.beats-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.beat-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;transition:all .2s ease}.beat-card.expanded{border-color:var(--accent-primary)}.beat-card.has-content{border-color:var(--accent-primary);background:var(--accent-primary-soft)}.beat-header{width:100%;padding:var(--spacing-lg);background:none;border:none;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background .2s ease}.beat-header:hover{background:var(--bg-tertiary)}.beat-title{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.beat-number{width:32px;height:32px;background:var(--accent-primary);color:#000;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.beat-name{font-size:1rem;font-weight:600;color:var(--text-primary)}.beat-indicator{color:var(--accent-primary);font-size:1.125rem;margin-left:auto}.beat-expand{font-size:1.5rem;color:var(--text-secondary);width:32px;height:32px;display:flex;align-items:center;justify-content:center}.beat-content{padding:0 var(--spacing-lg) var(--spacing-lg);animation:slideDown .3s ease}.beat-description{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin-bottom:var(--spacing-xs);padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border-left:3px solid var(--accent-primary)}.beat-page-range{font-size:.75rem;color:var(--text-muted);margin-top:2px;margin-bottom:var(--spacing-xs);opacity:.7}.beat-time-hint{font-size:.75rem;color:var(--text-muted);margin-top:2px;margin-bottom:var(--spacing-lg);opacity:.7;font-style:italic}.three-act-page-range{font-size:12px;color:var(--text-muted);margin-top:2px;margin-bottom:var(--spacing-xs)}.three-act-time-hint{font-size:12px;color:var(--text-muted);margin-top:2px;margin-bottom:var(--spacing-lg);font-style:italic}.beat-textarea{width:100%;min-height:120px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--spacing-md);color:var(--text-primary);font-family:inherit;font-size:16px;line-height:1.5;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease;overflow-y:auto}.beat-textarea:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 1px var(--accent-primary-soft)}.questions-sections{display:flex;flex-direction:column;gap:var(--spacing-3xl)}.questions-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--border-subtle)}.section-subtitle{font-size:1.25rem;font-weight:600;color:var(--accent-primary);margin-bottom:var(--spacing-sm)}.section-description{color:var(--text-secondary);font-size:.95rem;margin-bottom:var(--spacing-lg)}.questions-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.question-card{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--spacing-lg);transition:all .2s ease}.question-card.answered{border-color:var(--accent-primary);background:var(--accent-primary-soft)}.question-card.academic{border-color:var(--star-emotional)}.question-header{display:flex;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.question-number{color:var(--accent-primary);font-weight:700;flex-shrink:0}.question-prompt{color:var(--text-primary);font-size:1rem;line-height:1.6;flex:1}.question-indicator{color:var(--accent-primary);font-size:1.125rem;flex-shrink:0}.question-textarea{width:100%;min-height:100px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--spacing-md);color:var(--text-primary);font-family:inherit;font-size:16px;line-height:1.5;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease;overflow-y:auto}.question-textarea:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 1px var(--accent-primary-soft)}.reflection-prompts{background:var(--bg-secondary);border:1px solid var(--accent-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.reflection-prompts h3{color:var(--accent-primary);font-size:1.125rem;margin-bottom:var(--spacing-md)}.reflection-prompts ul{list-style:none;padding:0}.reflection-prompts li{padding:var(--spacing-sm) 0;color:var(--text-secondary);padding-left:var(--spacing-lg);position:relative}.reflection-prompts li:before{content:"→";position:absolute;left:0;color:var(--accent-primary)}.reflection-textarea{width:100%;min-height:400px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--spacing-xl);color:var(--text-primary);font-family:inherit;font-size:16px;line-height:1.8;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease;overflow-y:auto}.reflection-textarea:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 2px var(--accent-primary-soft)}.ratings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.rating-item{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all .2s ease}.rating-item:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.rating-item.overall{grid-column:span 2;background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border-color:var(--accent-primary)}.rating-description{font-size:.875rem;color:var(--text-secondary);margin-top:var(--spacing-sm)}.review-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--border-subtle)}.review-section h3{font-size:1.25rem;font-weight:600;color:var(--accent-primary);margin-bottom:var(--spacing-sm)}.review-helper{color:var(--text-secondary);font-size:.95rem;margin-bottom:var(--spacing-lg)}.review-textarea{width:100%;min-height:300px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--spacing-lg);color:var(--text-primary);font-family:inherit;font-size:16px;line-height:1.8;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease;overflow-y:auto}.review-textarea:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 2px var(--accent-primary-soft)}.word-count{margin-top:var(--spacing-sm);font-size:.875rem;color:var(--text-secondary);text-align:right}.tab-navigation,.overview-tab .overview-grid,.overview-tab h2,.overview-meta,.overview-poster,.overview-details,.overview-credits,.overview-dates{display:none}@media(max-width:768px){.hero-content{flex-direction:column}.hero-poster{width:150px;margin:0 auto}.hero-title{font-size:1.75rem}.tab-navigation-fixed{padding:var(--spacing-sm);gap:2px}.tab-button{padding:var(--spacing-sm);flex-direction:column;gap:2px}.tab-label{font-size:.75rem}.tab-icon{font-size:1rem}.ratings-grid{grid-template-columns:1fr}.rating-item.overall{grid-column:span 1}.credits-grid{grid-template-columns:1fr}}@media(max-width:480px){.film-detail-header{padding:var(--spacing-sm) var(--spacing-md)}.header-title{font-size:1rem}.film-hero-card{margin:var(--spacing-md);padding:var(--spacing-lg)}.tab-content{padding:var(--spacing-lg) var(--spacing-md)}.progress-stats{flex-direction:column;gap:var(--spacing-sm)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-xl);background:var(--background);color:var(--text-primary)}.error-content{max-width:500px;text-align:center;animation:fadeIn .3s ease}.error-icon{font-size:4rem;margin-bottom:var(--space-xl);animation:pulse 2s infinite}.error-content h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-md)}.error-content p{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-2xl)}.error-details{background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-xl);text-align:left}.error-details summary{cursor:pointer;color:var(--text-secondary);font-size:.875rem;margin-bottom:var(--space-md);-webkit-user-select:none;user-select:none}.error-details pre{font-family:Courier New,monospace;font-size:.75rem;color:var(--accent-danger);overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;margin:var(--space-md) 0}.error-actions{display:flex;gap:var(--space-md);justify-content:center}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}[data-theme=light] .error-boundary{background:var(--background);color:var(--text-primary)}[data-theme=light] .error-details{background:var(--surface-card);border-color:var(--border-subtle)}
