:root{font-family:Oswald,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#0f172a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #6366f1;--primary-dark: #4f46e5;--secondary-color: #8b5cf6;--background: #191b1a;--surface: #1e293b;--surface-light: #334155;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border-color: #334155;--shadow: rgba(0, 0, 0, .3)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--background);color:var(--text-primary);min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{width:100%;max-width:1400px;margin:0 auto;background:var(--background);padding:1.25rem 2rem;border-bottom:1px solid var(--border-color)}.header-inner{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:1.25rem}.header-brand{text-align:left}.app-header h1{font-family:Oswald,sans-serif;font-size:2.25rem;margin-bottom:.25rem;font-weight:400;text-transform:uppercase;color:#fff}.app-header .subtitle{color:#ffffffe6;font-size:1rem}.header-auth{display:flex;align-items:center;gap:1rem;flex-shrink:0}.header-email{color:#fffffff2;font-size:.9rem;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-btn,.header-link{padding:.2rem 1rem;background:#fff3;border:1px solid rgba(255,255,255,.5);color:#fff;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-block}.header-btn:hover,.header-link:hover{background:#ffffff4d;border-color:#fff;color:#fff}.header-btn.active,.header-link.active{background:#fff;border-color:#fff;color:var(--primary-color)}.header-logout:hover{background:#dc26264d;border-color:#fffc}.header-nav{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;width:100%}.header-search{flex:1;min-width:160px;max-width:320px;margin-right:auto;display:flex;align-items:center}.header-search .search-bar{width:100%;margin:0;max-width:none;gap:.5rem}.header-search .search-bar input{padding:.45rem .65rem;font-size:.9rem;background:#fffffff2;border:1px solid rgba(255,255,255,.6);color:var(--background);border-radius:6px}.header-search .search-bar input::placeholder{color:var(--text-muted)}.header-search .search-bar input:focus{outline:none;border-color:#fff;background:#fff}.header-search .search-bar button{padding:.45rem .9rem;font-size:.85rem;background:#fff;color:var(--primary-color);border:1px solid white;border-radius:6px}.header-search .search-bar button:hover:not(:disabled){background:#ffffffe6}.lists-dropdown{position:relative}.lists-dropdown-trigger{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem 1rem}.lists-dropdown-chevron{font-size:.7rem;opacity:.9}.lists-dropdown-content{position:absolute;top:calc(100% + .5rem);left:0;min-width:220px;max-width:320px;max-height:320px;overflow-y:auto;background:var(--surface);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 10px 38px -10px #00000059;z-index:100;padding:.25rem}.lists-dropdown-loading,.lists-dropdown-empty{padding:1rem .75rem;color:var(--text-secondary);font-size:.9rem;display:flex;align-items:center;gap:.5rem}.lists-dropdown-list{list-style:none}.lists-dropdown-list li{padding:0}.lists-dropdown-section-header{padding:.5rem .75rem .25rem;font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.lists-dropdown-section-header:not(:first-child){margin-top:.25rem;padding-top:.5rem;border-top:1px solid var(--border-color)}.lists-dropdown-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;width:100%;padding:.5rem .75rem;border:none;border-radius:6px;background:transparent;font:inherit;font-size:.9rem;color:var(--text-primary);text-align:left;cursor:pointer}.lists-dropdown-item:hover{background:var(--surface-light)}.lists-dropdown-item-type{font-size:.75rem;color:var(--text-muted)}.auth-page{max-width:400px;margin:2rem auto;padding:2rem}.auth-page h2{margin-bottom:1.5rem;color:var(--text-primary)}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form input{padding:.75rem 1rem;background:var(--surface);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem}.auth-form input:focus{outline:none;border-color:var(--primary-color)}.auth-form button{padding:.75rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.auth-form button:hover:not(:disabled){background:var(--primary-dark)}.auth-form button:disabled{opacity:.7;cursor:not-allowed}.auth-error{color:#f87171;font-size:.9rem;margin:0}.auth-message{color:var(--primary-color);font-size:.9rem;margin:0}.auth-switch{margin-top:1.5rem;color:var(--text-muted);font-size:.95rem}.auth-switch a{color:var(--primary-color);text-decoration:none}.auth-switch a:hover{text-decoration:underline}.search-section{padding:2rem;background:var(--surface);border-bottom:1px solid var(--border-color)}.search-bar{max-width:600px;margin:0 auto;display:flex;gap:1rem}.search-bar input{flex:1;padding:1rem;background:var(--background);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;transition:border-color .3s}.search-bar input:focus{outline:none;border-color:var(--primary-color)}.search-bar button{padding:1rem 2rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s}.search-bar button:hover:not(:disabled){background:var(--primary-dark)}.search-bar button:disabled{opacity:.6;cursor:not-allowed}.app-main{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%}.movie-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1.5rem;margin-bottom:2rem}.movie-card{background:var(--surface);border-radius:10px;overflow:hidden;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease;border:1px solid var(--border-color)}.movie-card:hover{transform:translateY(-6px);box-shadow:0 10px 20px var(--shadow)}.movie-poster{width:100%;aspect-ratio:2/3;overflow:hidden;background:var(--surface-light)}.movie-poster img{width:100%;height:100%;object-fit:cover}.poster-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9rem}.movie-info{padding:.75rem}.movie-title{font-size:.9rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.movie-date{color:var(--text-muted);font-size:.8rem;margin-bottom:.35rem}.movie-rating{display:flex;align-items:center;gap:.2rem;color:var(--text-secondary);font-size:.8rem}.loading-container,.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.spinner{border:4px solid var(--border-color);border-top:4px solid var(--primary-color);border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.load-more-container{text-align:center;margin-top:2rem}.load-more-btn{padding:1rem 2rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s}.load-more-btn:hover:not(:disabled){background:var(--primary-dark)}.load-more-btn:disabled{opacity:.6;cursor:not-allowed}.movie-details-overlay{position:fixed;inset:0;background:#000000e6;z-index:1000;overflow-y:auto;padding:2rem}.movie-details-content{max-width:1200px;margin:0 auto;background:var(--surface);border-radius:12px;overflow:hidden;position:relative}.close-button{position:absolute;top:1rem;right:1rem;z-index:1001;background:#000000b3;color:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s}.close-button:hover{background:#000000e6}.movie-details-content-header{position:absolute;top:1rem;right:1rem;z-index:1;display:flex;align-items:center;gap:1rem}.add-to-list-btn{padding:.5rem 1rem;background:#fff3;border:1px solid rgba(255,255,255,.5);color:#fff;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.add-to-list-btn:hover{background:#ffffff4d}.consumed-checkbox{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-primary);font-size:.9375rem;font-weight:500}.consumed-checkbox-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.consumed-checkbox-box{width:16px;height:16px;border:2px solid var(--border-color);border-radius:4px;background:var(--surface-light);display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s}.consumed-checkbox:hover .consumed-checkbox-box{border-color:var(--primary-color)}.consumed-checkbox-input:focus-visible+.consumed-checkbox-box{outline:2px solid var(--primary-color);outline-offset:2px}.consumed-checkbox-input:checked+.consumed-checkbox-box{background:var(--primary-color);border-color:var(--primary-color)}.consumed-checkbox-check{width:10px;height:10px;color:#fff}.consumed-checkbox-label{color:var(--text-primary)}.consumed-checkbox-input:disabled+.consumed-checkbox-box{opacity:.6;cursor:not-allowed}.consumed-login-hint{font-size:.9375rem;color:var(--text-secondary)}.consumed-login-hint a{color:var(--primary-color);text-decoration:none}.consumed-login-hint a:hover{text-decoration:underline}.add-to-list-modal-overlay{position:fixed;inset:0;background:#000000b3;z-index:1100;display:flex;align-items:center;justify-content:center;padding:2rem}.add-to-list-modal{background:var(--surface);border-radius:12px;max-width:400px;width:100%;padding:1.5rem 2rem;position:relative;box-shadow:0 8px 32px #0006}.add-to-list-modal-title{font-size:1.25rem;font-weight:600;margin-bottom:1.25rem;color:var(--text-primary)}.add-to-list-modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;line-height:1;padding:.25rem}.add-to-list-modal-close:hover{color:var(--text-primary)}.add-to-list-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;color:var(--text-secondary)}.add-to-list-list{list-style:none;margin-bottom:1rem;max-height:240px;overflow-y:auto}.add-to-list-item{padding:.5rem 0;border-bottom:1px solid var(--border-color)}.add-to-list-item:last-child{border-bottom:none}.add-to-list-checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.add-to-list-checkbox{position:absolute;width:0;height:0;opacity:0}.add-to-list-checkbox-box{flex-shrink:0;width:18px;height:18px;border:2px solid var(--border-color);border-radius:4px;background:var(--surface-light);display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s}.add-to-list-checkbox:checked+.add-to-list-checkbox-box{background:var(--primary-color);border-color:var(--primary-color)}.add-to-list-checkbox:checked+.add-to-list-checkbox-box:after{content:"";width:5px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.add-to-list-checkbox:focus-visible+.add-to-list-checkbox-box{outline:2px solid var(--primary-color);outline-offset:2px}.add-to-list-checkbox:disabled+.add-to-list-checkbox-box{opacity:.6}.add-to-list-checkbox-text{color:var(--text-primary)}.add-to-list-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.add-to-list-create-link{background:none;border:none;color:var(--primary-color);font-size:.95rem;cursor:pointer;padding:0;text-decoration:none}.add-to-list-create-link:hover{text-decoration:underline}.add-to-list-create-form{margin-top:1rem;display:flex;gap:.75rem}.add-to-list-create-input{flex:1;padding:.5rem .75rem;background:var(--surface-light);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.95rem}.add-to-list-create-input:focus{outline:none;border-color:var(--primary-color)}.add-to-list-create-btn{padding:.5rem 1rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer}.add-to-list-create-btn:hover:not(:disabled){background:var(--primary-dark)}.add-to-list-create-btn:disabled{opacity:.6;cursor:not-allowed}.movie-backdrop{width:100%;height:400px;overflow:hidden}.movie-backdrop img{width:100%;height:100%;object-fit:cover}.movie-details-body{position:relative;display:flex;gap:2rem;padding:2rem}.movie-details-content-header{position:absolute;top:1rem;right:1rem;z-index:1}.movie-details-poster{flex-shrink:0;width:300px}.movie-details-poster img{width:100%;border-radius:8px}.movie-details-info{flex:1}.movie-details-info h1{font-size:2.5rem;margin-bottom:1rem}.tagline{font-style:italic;color:var(--text-muted);margin-bottom:1rem;font-size:1.1rem}.movie-meta{display:flex;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.movie-meta span{color:var(--text-secondary)}.genres{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}.genre-tag{background:var(--primary-color);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem}.overview{margin-bottom:2rem}.overview h3{margin-bottom:.5rem;color:var(--text-primary)}.overview p{line-height:1.6;color:var(--text-secondary)}.cast h3,.videos h3{margin-bottom:1rem;color:var(--text-primary)}.cast-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;margin-bottom:2rem}.cast-member{text-align:center}.cast-member img{width:100%;aspect-ratio:2/3;object-fit:cover;border-radius:8px;margin-bottom:.5rem}.cast-member p{font-size:.9rem;color:var(--text-primary);margin-bottom:.25rem}.cast-member .character{color:var(--text-muted);font-size:.8rem}.cast-member-link{text-decoration:none;color:inherit;display:block;transition:transform .2s ease}.cast-member-link:hover{transform:scale(1.03)}.cast-member-link .character{color:var(--text-muted)}.cast-member-placeholder{width:100%;aspect-ratio:2/3;background:var(--surface-light);border-radius:8px;margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.75rem}.video-list{display:flex;flex-direction:column;gap:.5rem}.video-item a{color:var(--primary-color);text-decoration:none;padding:.5rem;display:block;border-radius:4px;transition:background .3s}.video-item a:hover{background:var(--surface-light)}.consumed-page{flex:1;width:100%}.consumed-page-inner{max-width:1400px;margin:0 auto;padding:2rem;width:100%}.consumed-page-title{font-size:1.75rem;margin-bottom:.5rem;color:var(--text-primary)}.consumed-page-subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:.95rem}.consumed-page-empty{color:var(--text-muted);font-style:italic;margin-bottom:2rem}.consumed-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.consumed-list-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary)}.consumed-list-title{font-weight:500}.consumed-list-type{font-size:.875rem;color:var(--text-muted);text-transform:capitalize}.consumed-back-link{display:inline-block;margin-top:2rem;color:var(--primary-color);text-decoration:none;font-weight:500;transition:color .2s}.consumed-back-link:hover{color:var(--primary-dark)}.person-detail-page{flex:1;width:100%}.person-detail-inner{max-width:900px;margin:0 auto;padding:2rem;width:100%}.person-detail-back{display:inline-block;margin-bottom:1.5rem;color:var(--primary-color);text-decoration:none;font-weight:500}.person-detail-back:hover{color:var(--primary-dark)}.person-detail-header{display:flex;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}.person-detail-profile{flex-shrink:0;width:200px}.person-detail-profile img{width:100%;border-radius:12px;display:block}.person-detail-profile-placeholder{width:200px;aspect-ratio:2/3;background:var(--surface-light);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9rem}.person-details-body{position:relative;padding:2rem;max-height:calc(100vh - 4rem);overflow-y:auto}.person-details-content.movie-details-content{max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.person-details-content .person-details-body{flex:1;overflow-y:auto}.person-detail-meta{flex:1;min-width:200px}.person-detail-name{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary)}.person-detail-dept{text-transform:uppercase;font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem}.person-detail-birth,.person-detail-death{font-size:.9rem;color:var(--text-secondary);margin-bottom:.25rem}.person-detail-bio{margin-bottom:2rem}.person-detail-bio h3,.person-detail-movies h3{font-size:1.1rem;margin-bottom:.75rem;color:var(--text-primary)}.person-detail-bio p{color:var(--text-secondary);line-height:1.6;font-size:.95rem}.person-detail-movies{margin-top:2rem}.person-movie-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.person-movie-item{margin:0}.person-movie-link{display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .2s ease}.person-movie-link:hover{transform:scale(1.02)}.person-movie-poster{width:100%;aspect-ratio:2/3;object-fit:cover;border-radius:8px;margin-bottom:.5rem}.person-movie-poster-placeholder{background:var(--surface-light);display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--text-muted)}.person-movie-title{font-size:.85rem;font-weight:500;color:var(--text-primary);margin-bottom:.2rem}.person-movie-year,.person-movie-character{font-size:.75rem;color:var(--text-muted)}.person-detail-error{color:var(--text-muted);margin-bottom:1rem}@media(max-width:768px){.movie-details-body{flex-direction:column}.movie-details-poster{width:100%}.movie-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem}.app-header h1{font-size:2rem}.header-nav{gap:.5rem}.header-inner{flex-direction:column;align-items:flex-start}.header-auth{width:100%;justify-content:flex-end}}
