@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--brand:#00d1c1;--brand-light:#33ead4;--brand-dark:#00a69a;--brand-accent:#00d1c1;--bg-primary:#1a1d21;--bg-secondary:#2c3136;--bg-tertiary:#2c313666;--bg-elevated:#2c3136;--bg-hover:#2c3136cc;--text-primary:#fff;--text-secondary:#ffffffb3;--text-tertiary:#fff6;--text-inverse:#1a1d21;--border-subtle:#ffffff0a;--border-default:#ffffff14;--border-strong:#ffffff26;--success:#00d1c1;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--star-empty:#fff3;--star-filled:#00d1c1;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--text-4xl:2.5rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px #6366f126;--ease-out:cubic-bezier(.16,1,.3,1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s;--header-height:64px;--max-width:1280px;--sidebar-width:260px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:1;background:radial-gradient(circle at 50% 30%,#0000 20%,#1a1d21 120%);position:fixed;inset:0}a{color:var(--brand-light);transition:color var(--duration-fast)var(--ease-out);text-decoration:none}a:hover{color:var(--brand)}img{max-width:100%;display:block}ul,ol{list-style:none}button{cursor:pointer;color:inherit;font-family:inherit;font-size:inherit;background:0 0;border:none}input,textarea,select{font-family:inherit;font-size:inherit}.container{width:100%;max-width:var(--max-width);padding:0 var(--space-lg);margin:0 auto}.page{min-height:calc(100vh - var(--header-height));padding-top:var(--space-2xl);padding-bottom:var(--space-3xl)}.page-header{margin-bottom:var(--space-2xl)}.page-title{font-size:var(--text-3xl);letter-spacing:-.02em;color:var(--text-primary);font-weight:800}.page-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin-top:var(--space-sm)}.grid{gap:var(--space-lg);display:grid}.grid-movies{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}@media (max-width:640px){.grid-movies{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);font-weight:600;font-size:var(--text-sm);transition:all var(--duration-fast)var(--ease-out);white-space:nowrap;-webkit-user-select:none;user-select:none;padding:.625rem 1.25rem;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover:not(:disabled){background:var(--brand-dark);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-strong)}.btn-ghost{color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){color:var(--text-primary);background:var(--bg-tertiary)}.btn-danger{color:var(--error);background:#ef444426;border:1px solid #ef444433}.btn-danger:hover:not(:disabled){background:#ef444440}.btn-sm{font-size:var(--text-xs);padding:.375rem .75rem}.btn-lg{font-size:var(--text-base);padding:.75rem 1.75rem}.btn-icon{border-radius:var(--radius-sm);padding:.5rem}.input-group{gap:var(--space-xs);flex-direction:column;display:flex}.input-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.input{background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all var(--duration-fast)var(--ease-out);outline:none;padding:.625rem .875rem}.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #6366f126}.input::placeholder{color:var(--text-tertiary)}.input-error{border-color:var(--error)}.input-error:focus{box-shadow:0 0 0 3px #ef444426}.error-message{font-size:var(--text-xs);color:var(--error);margin-top:2px}.textarea{resize:vertical;min-height:100px}.card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--duration-normal)var(--ease-out)}.card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md)}.card-glass{-webkit-backdrop-filter:blur(24px);background:#2c313666;border:1px solid #ffffff0d}.badge{font-size:var(--text-xs);border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-subtle);align-items:center;padding:.2rem .6rem;font-weight:600;display:inline-flex}.badge-brand{color:var(--brand-light);background:#6366f126;border-color:#6366f133}.badge-success{color:var(--success);background:#22c55e26}.badge-warning{color:var(--warning);background:#f59e0b26}.toast-container{bottom:var(--space-lg);right:var(--space-lg);z-index:1000;gap:var(--space-sm);flex-direction:column;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-sm);padding:var(--space-md)var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);animation:toast-in var(--duration-normal)var(--ease-out);min-width:280px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary)25%,var(--bg-hover)50%,var(--bg-tertiary)75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.divider{background:var(--border-subtle);width:100%;height:1px;margin:var(--space-lg)0}.movie-card{border-radius:var(--radius-md);aspect-ratio:2/3;background:var(--bg-tertiary);cursor:pointer;transition:all var(--duration-normal)var(--ease-out);position:relative;overflow:hidden}.movie-card:hover{box-shadow:var(--shadow-lg);z-index:5;transform:scale(1.04)}.movie-card img{object-fit:cover;width:100%;height:100%;transition:transform var(--duration-slow)var(--ease-out)}.movie-card:hover img{transform:scale(1.05)}.movie-card-overlay{opacity:0;transition:opacity var(--duration-normal)var(--ease-out);padding:var(--space-md);background:linear-gradient(#0000 0%,#0a0a0f66 60%,#0a0a0ff2 100%);flex-direction:column;justify-content:flex-end;display:flex;position:absolute;inset:0}.movie-card:hover .movie-card-overlay{opacity:1}.movie-card-title{font-weight:700;font-size:var(--text-sm);margin-bottom:2px;line-height:1.3}.movie-card-year{font-size:var(--text-xs);color:var(--text-secondary)}.movie-card-rating{top:var(--space-sm);right:var(--space-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--star-filled);opacity:0;transition:opacity var(--duration-fast)var(--ease-out);background:#0a0a0fcc;padding:2px 8px;font-weight:700;position:absolute}.movie-card:hover .movie-card-rating{opacity:1}.movie-card-quick-rate{z-index:15;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a0a0fe6;border:1px solid #ffffff1f;border-radius:999px;align-items:center;gap:6px;padding:6px 8px;display:flex;position:absolute;bottom:8px;left:8px;right:8px;box-shadow:0 6px 18px #00000073}.movie-card-quick-rate-stars{align-items:center;gap:3px;min-width:0;display:flex}.movie-card-quick-rate-btn{color:var(--border-default);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;line-height:1;transition:color .12s,transform .12s}.movie-card-quick-rate-btn.is-on{color:var(--star-filled)}.movie-card-quick-rate-btn:hover{transform:translateY(-1px)}.movie-card-quick-rate-value{color:var(--text-secondary);white-space:nowrap;margin-left:auto;font-size:10px;font-weight:700}.detail-section-tabs{top:calc(var(--header-height) + 10px);z-index:25;margin-top:var(--space-xl);border:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a0a0fb8;border-radius:999px;align-items:center;gap:6px;padding:6px;display:inline-flex;position:sticky}.detail-section-tab{color:var(--text-tertiary);font-size:var(--text-xs);letter-spacing:.02em;cursor:pointer;background:0 0;border:none;border-radius:999px;padding:8px 12px;font-weight:700;transition:all .12s}.detail-section-tab:hover{color:var(--text-primary);background:#ffffff0d}.detail-section-tab.is-active{background:var(--brand);color:#081312}.header{z-index:100;height:var(--header-height);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);background:#0a0a0fbf;position:sticky;top:0}.header-inner{height:100%;max-width:var(--max-width);padding:0 var(--space-lg);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.header-logo{align-items:center;gap:var(--space-sm);font-size:var(--text-xl);letter-spacing:-.02em;color:var(--text-primary);font-weight:800;display:flex}.header-logo-icon{background:linear-gradient(135deg,var(--brand),var(--brand-accent));border-radius:var(--radius-sm);justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;display:flex}.header-nav{align-items:center;gap:var(--space-xs);display:flex}.header-nav-link{padding:var(--space-sm)var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text-secondary);transition:all var(--duration-fast)var(--ease-out);font-weight:500}.header-nav-link:hover,.header-nav-link.active{color:var(--text-primary);background:var(--bg-tertiary)}.header-actions{align-items:center;gap:var(--space-sm);display:flex}.header-search{position:relative}.header-search-input{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-full);width:220px;color:var(--text-primary);font-size:var(--text-sm);transition:all var(--duration-fast)var(--ease-out);outline:none;padding:.5rem .75rem .5rem 2.25rem}.header-search-input:focus{border-color:var(--brand);width:300px;box-shadow:0 0 0 3px #6366f11a}.header-search-icon{color:var(--text-tertiary);font-size:var(--text-sm);pointer-events:none;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.header-avatar{border-radius:var(--radius-full);background:var(--bg-tertiary);border:2px solid var(--border-default);cursor:pointer;width:34px;height:34px;transition:border-color var(--duration-fast)var(--ease-out);overflow:hidden}.header-avatar:hover{border-color:var(--brand)}.header-avatar img{object-fit:cover;width:100%;height:100%}.user-dropdown{top:calc(100% + var(--space-sm));background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);min-width:200px;box-shadow:var(--shadow-lg);padding:var(--space-xs);animation:dropdown-in var(--duration-fast)var(--ease-out);position:absolute;right:0}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-4px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.user-dropdown-item{align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast)var(--ease-out);text-align:left;width:100%;display:flex}.user-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.auth-page{min-height:calc(100vh - var(--header-height));padding:var(--space-xl);justify-content:center;align-items:center;display:flex}.auth-card{width:100%;max-width:420px;padding:var(--space-2xl);background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.auth-header{text-align:center;margin-bottom:var(--space-xl)}.auth-title{font-size:var(--text-2xl);letter-spacing:-.02em;font-weight:800}.auth-subtitle{color:var(--text-secondary);font-size:var(--text-sm);margin-top:var(--space-xs)}.auth-form{gap:var(--space-md);flex-direction:column;display:flex}.auth-footer{margin-top:var(--space-lg);text-align:center;font-size:var(--text-sm);color:var(--text-secondary)}.auth-footer a{font-weight:600}.movie-detail{gap:var(--space-2xl);grid-template-columns:300px 1fr;align-items:start;display:grid}@media (max-width:768px){.movie-detail{gap:var(--space-lg);grid-template-columns:1fr}}.movie-poster-wrapper{aspect-ratio:2/3;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes fadeInBackdrop{0%{opacity:0}to{opacity:1}}.movie-poster-wrapper img{object-fit:cover;width:100%;height:100%}.movie-info{gap:var(--space-lg);flex-direction:column;display:flex}.movie-title{font-size:var(--text-4xl);letter-spacing:-.03em;font-weight:800;line-height:1.1}.movie-meta{align-items:center;gap:var(--space-md);color:var(--text-secondary);display:flex}.movie-genres{gap:var(--space-xs);flex-wrap:wrap;display:flex}.movie-description{font-size:var(--text-base);color:var(--text-secondary);line-height:1.7}.movie-actions{gap:var(--space-sm);flex-wrap:wrap;display:flex}.movie-stats{gap:var(--space-xl);display:flex}.movie-stat{flex-direction:column;gap:2px;display:flex}.movie-stat-value{font-size:var(--text-2xl);color:var(--text-primary);font-weight:800}.movie-stat-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.rating-picker{align-items:center;gap:4px;display:flex}.rating-star{color:var(--star-empty);cursor:pointer;transition:all var(--duration-fast)var(--ease-out);-webkit-user-select:none;user-select:none;font-size:1.5rem}.rating-star:hover,.rating-star.filled{color:var(--star-filled);transform:scale(1.15)}.rating-star:hover{filter:drop-shadow(0 0 4px #f59e0b66)}.rating-value{font-size:var(--text-sm);color:var(--star-filled);margin-left:var(--space-sm);min-width:2rem;font-weight:700}.review-card{padding:var(--space-lg);background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.review-header{align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.review-author-avatar{border-radius:var(--radius-full);background:var(--bg-tertiary);width:40px;height:40px;overflow:hidden}.review-author-name{font-weight:600;font-size:var(--text-sm)}.review-date{font-size:var(--text-xs);color:var(--text-tertiary)}.review-spoiler-tag{color:var(--error);border-radius:var(--radius-full);font-size:var(--text-xs);background:#ef444426;align-items:center;gap:4px;padding:2px 8px;font-weight:600;display:inline-flex}.review-content{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.7}.review-content.blurred{filter:blur(5px);-webkit-user-select:none;user-select:none;pointer-events:none;transition:filter var(--duration-normal)var(--ease-out)}.spoiler-wrapper{border-radius:var(--radius-sm);cursor:pointer;min-height:90px;position:relative}.spoiler-overlay{border-radius:var(--radius-sm);background:#00000014;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:12px;display:flex;position:absolute;inset:0}.profile-banner{background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));height:340px;margin:0 calc(-1*var(--space-lg));position:relative;overflow:hidden}.profile-banner img{object-fit:cover;opacity:.7;width:100%;height:100%}.profile-banner-gradient{background:linear-gradient(to top,var(--bg-primary),transparent);height:50%;position:absolute;bottom:0;left:0;right:0}.profile-header{align-items:flex-end;gap:var(--space-lg);padding:0 var(--space-lg);margin-top:-80px;display:flex;position:relative}.profile-avatar{border-radius:var(--radius-full);border:4px solid var(--bg-primary);background:var(--bg-tertiary);width:120px;height:120px;box-shadow:var(--shadow-lg);flex-shrink:0;overflow:hidden}.profile-avatar img{object-fit:cover;width:100%;height:100%}.profile-info{padding-bottom:var(--space-sm);flex:1}.profile-username{font-size:var(--text-2xl);letter-spacing:-.02em;font-weight:800}.profile-bio{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-xs);line-height:1.5}.profile-stats-bar{gap:var(--space-xl);margin-top:var(--space-xl);padding:var(--space-lg);background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);display:flex}.profile-stat{flex-direction:column;align-items:center;gap:2px;display:flex}.profile-stat-value{font-size:var(--text-xl);font-weight:800}.profile-stat-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.footer{border-top:1px solid var(--border-default);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--space-2xl)0 calc(var(--space-2xl) + 8px);margin-top:var(--space-3xl);background:linear-gradient(#ffffff03 0%,#0000002e 100%)}.footer-inner{align-items:center;gap:var(--space-md);max-width:var(--max-width);padding:0 var(--space-lg);text-align:center;flex-direction:column;margin:0 auto;display:flex}.footer-text{font-size:var(--text-sm);color:#fffc;font-weight:600}.footer-subtext{font-size:var(--text-xs);color:var(--text-tertiary)}.footer-meta{flex-direction:column;align-items:center;gap:2px;display:flex}.footer-links{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.footer-links .footer-link:not(:last-child):after{content:"•";color:var(--text-tertiary);margin-left:6px}.footer-link{font-size:var(--text-sm);color:var(--text-tertiary);transition:color var(--duration-fast)var(--ease-out)}.footer-link:hover{color:var(--brand-light)}.footer-attribution{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;display:flex}.footer-dot{color:var(--text-tertiary)}.footer-tmdb-link{align-items:center;gap:6px;display:inline-flex}.footer-tmdb-badge{letter-spacing:.04em;color:#0d253f;background:linear-gradient(90deg,#90cea1,#01b4e4);border-radius:999px;justify-content:center;align-items:center;padding:2px 8px;font-size:10px;font-weight:800;display:inline-flex}@media (max-width:640px){.footer{padding:var(--space-xl)0}.footer-link{font-size:var(--text-xs)}}.sr-only{clip:rect(0,0,0,0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.text-center{text-align:center}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items: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)}.mt-xl{margin-top:var(--space-xl)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}@media (max-width:768px){.header-search-input{width:160px}.header-search-input:focus{width:200px}.header-nav{display:none}.profile-header{text-align:center;flex-direction:column;align-items:center}.profile-stats-bar{justify-content:center}}
