:root{--bg: #0a0c12;--bg-2: #0f131d;--surface: #141927;--surface-2: #1b2233;--border: #232b3d;--text: #e9edf6;--muted: #94a0b8;--accent: #7c5cff;--accent-2: #27e0c8;--gold: #ffcc4d;--danger: #ff5d73;--radius: 16px;--shadow: 0 10px 30px rgba(0, 0, 0, .35)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:radial-gradient(1200px 600px at 80% -10%,#19203a 0%,var(--bg) 55%);color:var(--text);font-family:Inter,system-ui,sans-serif;-webkit-font-smoothing:antialiased;min-height:100vh}a{color:inherit;text-decoration:none}h1,h2,h3,.brand-text{font-family:Sora,system-ui,sans-serif}.app{display:flex;flex-direction:column;min-height:100vh}.main{flex:1;width:100%;max-width:1180px;margin:0 auto;padding:28px 22px 60px}.navbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:14px 22px;background:#0a0c12b8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:20px;letter-spacing:-.02em}.brand-mark{display:grid;place-items:center}.brand-dot{background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}.nav-links{display:flex;gap:6px;align-items:center}.nav-link{position:relative;padding:8px 14px;border-radius:999px;color:var(--muted);font-weight:600;font-size:14px;transition:background .15s,color .15s}.nav-link:hover{color:var(--text);background:var(--surface)}.nav-link.active{color:var(--text);background:var(--surface-2)}.badge{margin-left:7px;background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#0a0c12;font-size:11px;font-weight:800;padding:1px 7px;border-radius:999px}.hero{position:relative;text-align:center;padding:56px 12px 30px}.hero-glow{position:absolute;inset:-40px 0 auto;height:280px;background:radial-gradient(closest-side,rgba(124,92,255,.28),transparent 70%);filter:blur(20px);z-index:-1}.hero-title{font-size:clamp(34px,6vw,58px);line-height:1.05;margin:0 0 14px;letter-spacing:-.03em}.grad{background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}.hero-sub{max-width:620px;margin:0 auto 28px;color:var(--muted);font-size:17px;line-height:1.6}.searchbar{display:flex;align-items:center;gap:8px;max-width:680px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:7px 7px 7px 18px;box-shadow:var(--shadow);transition:border-color .15s,box-shadow .15s}.searchbar:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #7c5cff2e}.search-icon{color:var(--muted);font-size:20px}.search-input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:16px;font-family:inherit}.search-input::placeholder{color:#6b768f}.search-btn{border:none;cursor:pointer;padding:11px 22px;border-radius:999px;font-weight:700;font-size:15px;color:#0a0c12;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:transform .12s,filter .12s}.search-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}.search-btn.as-link{display:inline-block}.examples{display:flex;flex-wrap:wrap;justify-content:center;gap:9px;margin-top:22px}.example-chip{background:var(--surface);border:1px solid var(--border);color:var(--muted);padding:8px 14px;border-radius:999px;font-size:13px;cursor:pointer;transition:all .15s}.example-chip:hover{color:var(--text);border-color:var(--accent);background:var(--surface-2)}.results{margin-top:36px}.results-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.results-head h2{font-size:22px;margin:0}.count{color:var(--muted);font-weight:500}.link-btn{background:none;border:none;color:var(--accent-2);cursor:pointer;font-size:14px;font-weight:600}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .16s,border-color .16s,box-shadow .16s}.card:hover{transform:translateY(-4px);border-color:#34406090;box-shadow:var(--shadow)}.card-poster{position:relative;aspect-ratio:3 / 4;background:var(--surface-2)}.card-poster img{width:100%;height:100%;object-fit:cover;display:block}.card-poster-fallback{width:100%;height:100%;display:grid;place-items:center;font-size:46px;font-weight:800;background:linear-gradient(135deg,var(--surface-2),#0c1626);color:#46557a}.fav-btn{position:absolute;top:8px;right:8px;width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;font-size:17px;line-height:1;color:#fff;background:#0a0c128c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:transform .12s,background .12s,color .12s}.fav-btn:hover{transform:scale(1.12)}.fav-btn.is-fav{color:var(--danger);background:#ff5d7329}.match-badge{position:absolute;top:8px;left:8px;font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;color:#0a0c12;background:linear-gradient(90deg,var(--accent),var(--accent-2))}.score-badge{position:absolute;bottom:8px;left:8px;font-size:12px;font-weight:700;padding:3px 8px;border-radius:999px;color:var(--gold);background:#0a0c12b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.score-badge.static{position:static;display:inline-block}.card-body{padding:12px 13px 14px}.card-title{font-size:14.5px;margin:0 0 4px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-meta{font-size:12px;color:var(--muted);margin:0 0 8px}.card-tags{display:flex;flex-wrap:wrap;gap:5px}.chip{font-size:12px;padding:4px 10px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);color:var(--muted);white-space:nowrap}.chip-sm{font-size:11px;padding:3px 8px}.chip-accent{color:var(--accent-2);border-color:#1e4a48;background:#0e2725;text-transform:capitalize}.chip-theme{color:#bcacff;border-color:#322a5e;background:#18142e}.chip-mood{color:#8ee6da;border-color:#1e4a48;background:#0e2725}.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.back-btn{background:var(--surface);border:1px solid var(--border);color:var(--muted);padding:7px 14px;border-radius:999px;cursor:pointer;font-size:14px;margin-bottom:18px}.back-btn:hover{color:var(--text)}.detail-hero{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--border)}.detail-hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;filter:blur(28px) brightness(.4) saturate(1.2);transform:scale(1.15)}.detail-hero-inner{position:relative;display:flex;gap:26px;padding:30px;background:linear-gradient(to top,#0a0c12f5,#0a0c1299)}.detail-poster{width:210px;flex-shrink:0;border-radius:14px;box-shadow:var(--shadow);object-fit:cover;align-self:flex-start}.detail-head h1{font-size:clamp(24px,4vw,38px);margin:0 0 6px;letter-spacing:-.02em}.detail-native{color:var(--muted);margin:0 0 12px;font-size:15px}.detail-meta{color:var(--accent-2);font-size:14px;font-weight:600;margin:0 0 14px}.detail-badges{display:flex;align-items:center;gap:10px;margin-bottom:16px}.btn-fav{background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:11px 20px;border-radius:999px;cursor:pointer;font-weight:700;font-size:14px;transition:all .15s}.btn-fav:hover{border-color:var(--danger)}.btn-fav.is-fav{color:var(--danger);border-color:var(--danger);background:#ff5d731f}.detail-section{margin-top:34px}.detail-section h2{font-size:20px;margin:0 0 14px}.detail-desc{color:#c3cbdc;line-height:1.75;font-size:15.5px;max-width:820px;margin:0}.warnings{color:var(--danger);font-size:13px;margin-top:14px}.trailer{position:relative;width:100%;max-width:820px;aspect-ratio:16 / 9;border-radius:14px;overflow:hidden;border:1px solid var(--border)}.trailer iframe{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:0}.shots{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.shot{border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:zoom-in;padding:0;background:var(--surface-2);aspect-ratio:16 / 9}.shot img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.shot:hover img{transform:scale(1.05)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#05060ae6;display:grid;place-items:center;cursor:zoom-out;padding:30px}.lightbox img{max-width:92vw;max-height:88vh;border-radius:12px;box-shadow:var(--shadow)}.spinner-wrap{display:flex;flex-direction:column;align-items:center;gap:14px;padding:70px 0}.spinner{width:38px;height:38px;border-radius:50%;border:3px solid var(--surface-2);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner-label{color:var(--muted);font-size:14px}.error{color:var(--danger)}.empty{color:var(--muted);padding:30px 0}.empty-state{text-align:center;padding:70px 0;color:var(--muted)}.empty-heart{font-size:56px;color:var(--surface-2);margin-bottom:10px}.empty-state p{margin-bottom:20px}.detail-error{display:flex;flex-direction:column;gap:14px;align-items:flex-start;padding:40px 0}.footer{border-top:1px solid var(--border);text-align:center;padding:40px 22px 34px;background:linear-gradient(to bottom,transparent,rgba(124,92,255,.05))}.footer-tagline{font-family:Sora,system-ui,sans-serif;font-size:clamp(20px,3vw,26px);font-weight:700;letter-spacing:-.02em;margin:0 0 10px;background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}.footer-brand{font-weight:600;color:var(--text);margin:0 0 14px;font-size:15px}.footer-legal{color:var(--muted);font-size:13px;margin:0}.nav-user{margin-left:8px;padding-left:14px;border-left:1px solid var(--border);color:var(--muted);font-size:14px;font-weight:600;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-link.logout{background:none;border:none;cursor:pointer;font-family:inherit}.nav-link.logout:hover{color:var(--danger)}.auth-page{display:grid;place-items:center;padding:50px 16px;min-height:60vh}.auth-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:34px 30px;box-shadow:var(--shadow);text-align:center;position:relative;overflow:hidden}.auth-card:before{content:"";position:absolute;inset:-2px -2px auto;height:4px;background:linear-gradient(90deg,var(--accent),var(--accent-2))}.auth-brand{font-family:Sora,system-ui,sans-serif;font-weight:800;font-size:22px;margin-bottom:18px}.auth-title{font-size:26px;margin:0 0 6px}.auth-sub{color:var(--muted);font-size:14px;margin:0 0 24px;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:12px;text-align:left}.auth-input{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:13px 15px;color:var(--text);font-size:15px;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}.auth-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #7c5cff29}.auth-submit{margin-top:4px;width:100%;padding:13px}.auth-submit:disabled{opacity:.6;cursor:default}.auth-error{color:var(--danger);font-size:13.5px;margin:0;background:#ff5d731a;border:1px solid rgba(255,93,115,.3);padding:9px 12px;border-radius:10px}.auth-divider{display:flex;align-items:center;gap:12px;margin:22px 0 18px;color:var(--muted);font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-google{display:flex;justify-content:center;min-height:4px}.auth-switch{margin:22px 0 0;color:var(--muted);font-size:14px}.auth-prompt{margin:0 0 20px;font-size:13.5px;color:var(--accent-2);background:#27e0c814;border:1px solid rgba(39,224,200,.28);padding:9px 12px;border-radius:10px}.nav-link.signin{color:#0a0c12;background:linear-gradient(90deg,var(--accent),var(--accent-2));font-weight:700}.nav-link.signin:hover{filter:brightness(1.08);color:#0a0c12}@media(max-width:640px){.detail-hero-inner{flex-direction:column;align-items:center;text-align:center;padding:22px}.detail-poster{width:160px}.chip-row,.detail-badges{justify-content:center}.searchbar{flex-wrap:wrap;border-radius:18px;padding:12px}.search-btn{width:100%}}:root{--bg: #07060f;--bg-2: #0d0b1a;--surface: #141022;--surface-2: #1e1838;--border: #2a2348;--text: #f1effb;--muted: #a79fc4;--accent: #a06bff;--accent-2: #2fe6d6;--pink: #ff5cae;--gold: #ffd24d;--danger: #ff5d8a;--grad: linear-gradient(100deg, #ff5cae 0%, #a06bff 48%, #2fe6d6 100%);--radius: 18px;--shadow: 0 18px 44px rgba(0, 0, 0, .5)}body{background:var(--bg)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;pointer-events:none;background:radial-gradient(38% 44% at 10% 6%,rgba(255,92,174,.2),transparent 62%),radial-gradient(42% 50% at 90% 2%,rgba(160,107,255,.22),transparent 60%),radial-gradient(55% 55% at 50% 108%,rgba(47,230,214,.14),transparent 60%);animation:aurora 18s ease-in-out infinite alternate}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;pointer-events:none;background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:24px 24px;-webkit-mask-image:linear-gradient(to bottom,#000,transparent 65%);mask-image:linear-gradient(to bottom,#000,transparent 65%)}@keyframes aurora{0%{transform:translateZ(0) scale(1);opacity:.9}to{transform:translate3d(0,-2%,0) scale(1.06);opacity:1}}.grad,.brand-dot{background:var(--grad);background-size:220% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:grad-pan 7s linear infinite}@keyframes grad-pan{to{background-position:220% center}}.brand-text{letter-spacing:-.03em}.brand-mark svg{filter:drop-shadow(0 0 8px rgba(160,107,255,.55))}.navbar{background:#090712a8;border-bottom:1px solid rgba(160,107,255,.14);-webkit-backdrop-filter:blur(14px) saturate(1.2);backdrop-filter:blur(14px) saturate(1.2)}.hero{padding-top:64px}.hero-glow{height:360px;background:radial-gradient(closest-side,rgba(160,107,255,.32),transparent 72%)}.hero-kicker{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--accent-2);background:#2fe6d614;border:1px solid rgba(47,230,214,.28);padding:6px 14px;border-radius:999px;margin-bottom:22px}.hero-sub{font-size:18px}.searchbar{background:#141022d9;border-color:#a06bff40;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.searchbar:focus-within{border-color:var(--pink);box-shadow:0 0 0 3px #ff5cae29,0 8px 40px #a06bff47}.search-btn{background:var(--grad);background-size:200% auto;box-shadow:0 6px 20px #a06bff66;transition:transform .12s,filter .12s,background-position .5s ease}.search-btn:hover{background-position:right center}.example-chip:hover{border-color:var(--pink);color:#fff}.card{background:linear-gradient(180deg,var(--surface),#100c1e)}.card-poster img{transition:transform .5s ease}.card:hover{transform:translateY(-7px);border-color:transparent;box-shadow:0 22px 50px #a06bff47,0 0 0 1px #a06bff73}.card:hover .card-poster img{transform:scale(1.07)}.card-title{transition:color .15s}.card:hover .card-title{color:#fff}.match-badge{background:var(--grad);box-shadow:0 4px 14px #ff5cae73}.score-badge{border:1px solid rgba(255,210,77,.3)}.fav-btn.is-fav{color:var(--pink);background:#ff5cae2e}.chip-theme{color:#d9c8ff;border-color:#3a2f6b;background:#1a1430}.chip-mood{color:#8ff0e4;border-color:#1f5350;background:#0e2926}.chip-accent,.detail-meta{color:var(--accent-2)}.btn-fav.is-fav{color:var(--pink);border-color:var(--pink);background:#ff5cae1f}.footer{background:linear-gradient(to bottom,transparent,rgba(160,107,255,.06))}.auth-card:before{background:var(--grad)}.nav-link.signin{background:var(--grad)}
