:root{--bg-primary: #0f0b08;--bg-secondary: #1a1410;--bg-card: #1e1812;--text-primary: #f5ece3;--text-secondary: #9a8e82;--accent: #e8a849;--accent-hover: #f0bc6a;--accent-muted: rgba(232, 168, 73, .1);--border: #2e2620;--radius: 8px;--radius-lg: 12px;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.6;font-weight:400;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent}*,*:before,*:after{box-sizing:border-box}html{overflow-x:hidden}body{margin:0;min-width:320px;min-height:100dvh;width:100%;max-width:100vw;overflow-x:hidden}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}h1,h2,h3{line-height:1.2}h1{font-size:clamp(1.75rem,5vw,2.5rem)}h2{font-size:clamp(1.25rem,3.5vw,1.75rem);margin-bottom:.5rem}img{max-width:100%;height:auto;display:block}button{cursor:pointer;font-family:inherit}.navbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.navbar-brand{font-size:1.1rem;font-weight:700;color:var(--text-primary)!important;letter-spacing:-.3px;white-space:nowrap}.navbar-links{display:flex;gap:1.5rem;margin-left:auto;margin-right:1.5rem}.navbar-links a{color:var(--text-secondary);font-weight:500;font-size:.95rem;padding:.5rem .25rem;min-height:44px;display:flex;align-items:center;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}.navbar-links a:hover,.navbar-links a.active{color:var(--accent);border-bottom-color:var(--accent)}.navbar-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;padding:8px;cursor:pointer;-webkit-tap-highlight-color:transparent}.navbar-hamburger span{display:block;width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:transform .3s,opacity .3s}.navbar-hamburger--open span:first-child{transform:translateY(7px) rotate(45deg)}.navbar-hamburger--open span:nth-child(2){opacity:0}.navbar-hamburger--open span:last-child{transform:translateY(-7px) rotate(-45deg)}.navbar-login-btn{background:none;border:1px solid var(--accent);color:var(--accent);font-size:.85rem;font-weight:500;padding:.5rem .75rem;min-height:44px;display:flex;align-items:center;border-radius:6px;transition:background .2s,color .2s}.navbar-login-btn:hover{background:var(--accent);color:#0f0b08}.main-content{max-width:1100px;margin:0 auto;padding:1rem 2rem}#root{max-width:100%;margin:0;padding:0;text-align:left;overflow-x:hidden}.home-page{position:relative}.hero-backdrop{position:absolute;top:0;left:0;right:0;height:280px;overflow:hidden;pointer-events:none;z-index:0}.video-backdrop{position:absolute;top:50%;left:50%;width:200%;height:200%;transform:translate(-50%,-50%);opacity:0;transition:opacity 2s ease-in;filter:blur(4px) saturate(.6)}.video-backdrop--visible{opacity:.5}.video-backdrop iframe{width:100%;height:100%;border:none;pointer-events:none}.hero-backdrop-overlay{position:absolute;inset:0;background:linear-gradient(180deg,#0f0b0866,#0f0b08b3,#0f0b08)}.hero{position:relative;z-index:1;text-align:center;padding:2.5rem 0 1.5rem}.hero-tagline{font-size:1rem;color:var(--text-secondary);max-width:550px;margin:0 auto 1.25rem}.hero-actions{display:flex;gap:1rem;justify-content:center}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.75rem;min-height:44px;border-radius:var(--radius);font-weight:600;font-size:.95rem;transition:background .2s,color .2s,border-color .2s;border:2px solid transparent}.btn-primary{background:var(--accent);color:#0f0b08}.btn-primary:hover{background:var(--accent-hover);color:#0f0b08}.btn-secondary{border-color:var(--accent);color:var(--accent);background:transparent}.btn-secondary:hover{background:var(--accent-muted);color:var(--accent-hover);border-color:var(--accent-hover)}.featured-section{position:relative;z-index:1;padding:0 0 .5rem}.featured-section h2{text-align:center;margin:0 0 .15rem}.featured-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}.featured-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:2/3;cursor:default}.featured-card img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.featured-card:hover img{transform:scale(1.05)}.featured-overlay{position:absolute;bottom:0;left:0;right:0;padding:1.5rem 1rem 1rem;background:linear-gradient(transparent,#0f0b08e6)}.featured-overlay h3{margin:0 0 .25rem;font-size:1.05rem}.featured-overlay span{font-size:.8rem;color:var(--text-secondary)}.movie-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.movie-card-link{text-decoration:none;color:inherit;display:flex}.movie-card-link:hover{color:inherit}.movie-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s,transform .2s}.movie-card:hover{border-color:var(--accent);transform:translateY(-2px)}.movie-card-poster{aspect-ratio:16/10;overflow:hidden;background:var(--bg-card)}.movie-card-poster img{width:100%;height:100%;object-fit:cover}.movie-card-info{padding:1rem 1.25rem 1.25rem;flex:1}.movie-card-info h3{margin:0 0 .25rem;font-size:1.1rem}.movie-year{font-weight:400;color:var(--text-secondary);font-size:.9rem}.movie-director{color:var(--text-secondary);font-size:.85rem;margin:0 0 .5rem}.movie-rating{color:var(--accent);font-size:.95rem;margin-bottom:.5rem;letter-spacing:1px}.movie-description{color:var(--text-secondary);font-size:.9rem;margin:0;line-height:1.5}.page-subtitle{color:var(--text-secondary);font-size:1.05rem;max-width:600px;margin:0 auto 2rem}.section-subtitle{color:var(--text-secondary);text-align:center;max-width:500px;margin:0 auto 1.5rem}.chatbot-section{padding:3rem 0;text-align:center}.chatbot,.recommend-chat{max-width:650px;margin:0 auto;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.chatbot-messages,.chat-messages{min-height:250px;max-height:400px;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}.chatbot-welcome,.chat-empty{color:var(--text-secondary);font-size:.9rem;text-align:center;padding:2rem 1rem}.chat-empty ul{list-style:none;padding:0;margin:.75rem 0 0}.chat-empty li{padding:.25rem 0;color:var(--accent);font-style:italic}.chat-message{display:flex}.chat-user{justify-content:flex-end}.chat-assistant{justify-content:flex-start}.chat-bubble{max-width:80%;padding:.65rem 1rem;border-radius:var(--radius);font-size:.95rem;line-height:1.5;white-space:pre-wrap}.chat-user .chat-bubble{background:var(--accent);color:#0f0b08;border-bottom-right-radius:2px}.chat-assistant .chat-bubble{background:var(--bg-card);border:1px solid var(--border);border-bottom-left-radius:2px}.chat-loading{color:var(--text-secondary);font-style:italic}.chatbot-input-form,.chat-input-form{display:flex;gap:0;border-top:1px solid var(--border)}.chatbot-input-form input,.chat-input-form input{flex:1;padding:.85rem 1rem;min-height:44px;border:none;background:var(--bg-primary);color:var(--text-primary);font-size:1rem;font-family:inherit;outline:none}.chatbot-input-form input::placeholder,.chat-input-form input::placeholder{color:var(--text-secondary)}.chatbot-input-form button,.chat-input-form button{padding:.85rem 1.5rem;min-height:44px;background:var(--accent);color:#0f0b08;border:none;font-weight:600;font-size:.95rem;transition:background .2s}.chatbot-input-form button:hover:not(:disabled),.chat-input-form button:hover:not(:disabled){background:var(--accent-hover)}.chatbot-input-form button:disabled,.chat-input-form button:disabled{opacity:.5;cursor:not-allowed}.recommend-page{padding-bottom:3rem}.recommend-chat{text-align:left}.reviews-page{padding-bottom:3rem;text-align:center}.review-detail{max-width:720px;margin:0 auto;padding-bottom:3rem}.back-link{display:inline-flex;align-items:center;color:var(--text-secondary);font-size:.9rem;min-height:44px;padding:.5rem 0;margin-bottom:1rem;transition:color .2s}.back-link:hover{color:var(--accent)}.review-header{margin-bottom:2.5rem}.review-header h1{font-size:2.5rem;font-weight:800;margin:0 0 .75rem;line-height:1.15}.review-meta{color:var(--text-secondary);font-size:.9rem;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.meta-separator{opacity:.4}.review-content{font-size:1.05rem;line-height:1.8;color:var(--text-primary)}.review-content p{margin:0 0 1.5rem}.review-content figure{margin:2rem 0}.review-content figure img{width:100%;border-radius:var(--radius)}.review-content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.review-content a:hover{color:var(--accent-hover)}.review-content em{font-style:italic}.review-content strong{font-weight:700;color:var(--accent)}.review-content .footnote{font-size:.9rem;color:var(--text-secondary);border-left:2px solid var(--border);padding-left:1rem;margin-top:2rem}.review-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border)}.medium-link{color:var(--text-secondary);font-size:.9rem;display:inline-flex;align-items:center;min-height:44px;padding:.5rem 0;transition:color .2s}.medium-link:hover{color:var(--accent)}.rec-input-form{display:flex;gap:.5rem;max-width:500px;margin:1rem auto 0;flex-wrap:wrap;justify-content:center}.rec-input-form textarea{width:100%;padding:.65rem .85rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;font-family:inherit;outline:none;resize:none;overflow:hidden;transition:border-color .2s}.rec-input-form textarea:focus{border-color:var(--accent)}.rec-step-label{width:100%;font-size:.85rem;font-weight:600;color:var(--text-primary);text-align:left}.rec-step-label--optional{margin-top:.25rem}.rec-step-note{width:100%;font-size:.72rem;color:var(--text-secondary);text-align:left;margin:0;opacity:.7}.platform-chips{display:flex;flex-wrap:wrap;gap:.4rem;width:100%;justify-content:center}.platform-chip{padding:.45rem .85rem;min-height:44px;display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:20px;background:var(--bg-card);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .15s}.platform-chip:hover{border-color:var(--accent);color:var(--text-primary)}.platform-chip--selected{background:var(--accent);color:#0f0b08;border-color:var(--accent);font-weight:600}.rec-input-form button[type=submit]{padding:.75rem 1.5rem;min-height:44px;background:var(--accent);color:#0f0b08;border:none;border-radius:var(--radius);font-weight:600;font-size:.95rem;transition:background .2s}.rec-input-form button[type=submit]:hover:not(:disabled){background:var(--accent-hover)}.rec-input-form button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.rec-input-cancel{padding:.75rem 1rem;min-height:44px;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;transition:color .2s,border-color .2s}.rec-input-cancel:hover{color:var(--text-primary);border-color:var(--text-secondary)}.rec-error{width:100%;text-align:center;color:#e55;font-size:.9rem;margin:.5rem 0 0}.rec-query{text-align:center;color:var(--text-secondary);font-style:italic;font-size:1.1rem;margin-bottom:.75rem}.featured-subtitle{text-align:center;color:var(--text-secondary);font-size:.95rem;margin:0 0 .5rem}.rec-results-actions{display:flex;gap:.5rem;justify-content:center;margin-bottom:1rem}.btn-sm{padding:.5rem 1rem;min-height:44px;font-size:.85rem}.btn-text{background:none;border:none;color:var(--text-secondary);font-size:.9rem;min-height:44px;padding:.5rem;text-decoration:underline;text-underline-offset:2px;transition:color .2s}.btn-text:hover{color:var(--accent)}.featured-grid--3{grid-template-columns:repeat(3,1fr)}.platform-note{color:var(--accent);font-size:.95rem;font-weight:500;text-align:center;background:#e8a84914;border:1px solid rgba(232,168,73,.3);border-radius:var(--radius);padding:.85rem 1.25rem;margin-bottom:1.25rem}.rec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.rec-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.rec-card-poster{aspect-ratio:2/3;overflow:hidden}.rec-card-poster img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.rec-card:hover .rec-card-poster img{transform:scale(1.05)}a.rec-card-poster{display:block;cursor:pointer}.rec-card-title-link{color:inherit;text-decoration:none}.rec-card-title-link:hover{color:var(--accent)}.rec-card-info{padding:.5rem .75rem .75rem;display:flex;flex-direction:column;flex:1;gap:.15rem}.rec-card--seen{opacity:.55}.rec-card-info h3{margin:0 0 .25rem;font-size:1.05rem}.rec-card-meta{font-size:.8rem;color:var(--text-secondary);display:block;margin-bottom:.5rem}.rec-reason{font-size:.85rem;color:var(--text-secondary);margin:0 0 .5rem;line-height:1.5}.streaming-badges{display:flex;gap:.4rem;margin-top:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.streaming-badge{display:inline-flex;align-items:center;padding:.4rem .65rem;min-height:32px;background:#e8a84926;color:var(--accent);font-size:.75rem;font-weight:600;border-radius:4px;text-decoration:none;transition:background .2s}.streaming-badge:hover{background:#e8a8494d;color:var(--accent-hover)}.rec-loading{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:4rem 1rem}.rec-loading-dots{display:flex;gap:.6rem}.rec-loading-dots span{width:10px;height:10px;border-radius:50%;background:var(--accent);animation:rec-dot-pulse 1.4s ease-in-out infinite}.rec-loading-dots span:nth-child(2){animation-delay:.2s}.rec-loading-dots span:nth-child(3){animation-delay:.4s}@keyframes rec-dot-pulse{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}.rec-loading-text{color:var(--text-secondary);font-size:1rem;letter-spacing:.02em}.rec-loading-disclaimer{color:var(--text-secondary);font-size:.8rem;text-align:center;max-width:420px;line-height:1.5;opacity:.7}.seen-this-btn{background:#ffffff0a;border:1px solid var(--border);color:var(--text-secondary);font-size:.75rem;font-weight:500;padding:.5rem .75rem;min-height:36px;border-radius:4px;cursor:pointer;transition:all .15s;margin-top:auto;width:fit-content;align-self:flex-end}.seen-this-btn:hover{border-color:var(--accent);color:var(--accent);background:#e8a8491a}.seen-this-btn--active{background:#e8a8491a;border-color:var(--accent);color:var(--accent);cursor:default}.seen-this-btn--active:before{content:"✓ "}@media(prefers-reduced-motion:reduce){.video-backdrop{display:none}}@media(max-width:768px){.navbar{flex-wrap:wrap;padding:.5rem 1rem}.navbar-brand{order:1;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;min-width:0}.navbar-hamburger{display:flex;order:3;margin-left:.5rem;min-width:44px;min-height:44px;align-items:center;justify-content:center}.navbar-auth{order:2;margin-left:auto}.navbar-links{order:4;display:none;width:100%;flex-direction:column;gap:0;margin:0;padding:.5rem 0 .25rem;border-top:1px solid var(--border);margin-top:.5rem}.navbar-links--open{display:flex}.navbar-links a{padding:.75rem .25rem;min-height:44px;border-bottom:none;font-size:1rem}.navbar-login-btn{font-size:.8rem;padding:.5rem .6rem;min-height:44px}.main-content{padding:1rem}.hero-backdrop{height:200px}.hero-actions{flex-direction:column;align-items:center}.featured-grid,.featured-grid--3{grid-template-columns:repeat(2,1fr);gap:.75rem}.rec-grid{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:.75rem;padding-bottom:.5rem;scrollbar-width:none;-ms-overflow-style:none}.rec-grid::-webkit-scrollbar{display:none}.rec-grid>*{flex:0 0 44%;scroll-snap-align:start;min-width:0}.movie-grid{grid-template-columns:1fr}.rec-input-form{max-width:100%;padding:0 .25rem}.rec-input-form textarea{font-size:16px;min-width:0}.chatbot-input-form input,.chat-input-form input{font-size:16px}.rec-card-info{padding:.5rem .6rem .6rem}.rec-card-info h3{font-size:.95rem}.rec-reason{font-size:.8rem}.admin-section{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{min-width:580px}.admin-header{flex-wrap:wrap;gap:.5rem}.admin-filter-bar{flex-wrap:wrap}.admin-filter-summary{width:100%;margin-left:0;margin-top:.25rem}.admin-login-form{max-width:100%}.admin-profile-stats{flex-direction:column;gap:.5rem}.review-header h1{font-size:clamp(1.5rem,5vw,2.5rem)}.review-content{font-size:1rem;line-height:1.7}.review-content figure{margin:1.25rem -1rem}.review-content figure img{border-radius:0}}.no-poster{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1410,#2e2218,#3a2a1a);padding:1.5rem;text-align:center;gap:.5rem}.no-poster-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);line-height:1.3}.no-poster-year{font-size:.9rem;color:var(--text-secondary)}.admin-page{max-width:900px;margin:0 auto;padding-bottom:3rem}.admin-page h1{font-size:2rem;margin-bottom:1.5rem}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.admin-header h1{margin-bottom:0}.admin-login-form{display:flex;gap:.5rem;max-width:400px}.admin-login-form input{flex:1;padding:.75rem 1rem;min-height:44px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;font-family:inherit;outline:none}.admin-login-form input:focus{border-color:var(--accent)}.admin-login-form button{padding:.75rem 1.5rem;min-height:44px;background:var(--accent);color:#0f0b08;border:none;border-radius:var(--radius);font-weight:600}.admin-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.admin-tab{padding:.75rem 1.5rem;min-height:44px;background:none;border:none;color:var(--text-secondary);font-size:.95rem;font-weight:500;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}.admin-tab:hover{color:var(--text-primary)}.admin-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.admin-section{min-height:200px}.admin-loading,.admin-empty{color:var(--text-secondary);text-align:center;padding:2rem}.admin-error{color:#e55;text-align:center;padding:1rem}.admin-filter-bar{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.admin-filter-btn{padding:.4rem .75rem;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:.85rem;transition:all .15s ease;display:flex;align-items:center;gap:.4rem}.admin-filter-btn:hover{border-color:var(--accent);color:var(--text)}.admin-filter-btn--active{background:var(--accent);color:#0f0b08;border-color:var(--accent);font-weight:600}.admin-badge{font-size:.75rem;background:#ffffff26;padding:.1rem .4rem;border-radius:10px;min-width:1.4rem;text-align:center}.admin-filter-btn--active .admin-badge{background:#0003}.admin-filter-summary{margin-left:auto;color:var(--text-secondary);font-size:.8rem}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th,.admin-table td{padding:.75rem .5rem;text-align:left;border-bottom:1px solid var(--border)}.admin-table th{color:var(--text-secondary);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.admin-unrated{background:#ffffff08}.admin-preference{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary)}.admin-rated{color:var(--text-secondary);font-weight:500}.admin-rate-buttons{display:flex;gap:.25rem}.admin-star-btn{width:28px;height:28px;border:1px solid var(--border);border-radius:4px;background:var(--bg-card);color:var(--text-primary);font-size:.8rem;font-weight:600;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s}.admin-star-btn:hover,.admin-star-btn--active{background:var(--accent);color:#0f0b08;border-color:var(--accent)}.admin-dislike-btn{width:28px;height:28px;border:1px solid #e55;border-radius:4px;background:transparent;color:#e55;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:background .2s}.admin-dislike-btn:hover,.admin-dislike-btn--active{background:#e55;color:#080808}.admin-profile-form{display:flex;flex-direction:column;gap:1.25rem}.admin-profile-form label{display:flex;flex-direction:column;gap:.4rem;color:var(--text-secondary);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.admin-profile-form textarea{padding:.75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;font-family:inherit;line-height:1.5;resize:vertical;outline:none}.admin-profile-form textarea:focus{border-color:var(--accent)}.admin-profile-stats{display:flex;gap:2rem;color:var(--text-secondary);font-size:.9rem}.admin-profile-stats p{margin:0}.admin-profile-actions{display:flex;align-items:center;gap:1rem}.admin-saved{color:#4c4;font-size:.9rem;font-weight:500}@media(max-width:480px){.navbar-brand{font-size:.85rem}.featured-grid{grid-template-columns:1fr 1fr;gap:.5rem}.featured-grid--3{grid-template-columns:repeat(2,1fr)}.rec-card-info{padding:.75rem}.rec-card-info h3{font-size:.9rem}.platform-chips{gap:.35rem}.platform-chip{padding:.4rem .65rem;font-size:.75rem;min-height:40px}.pref-list li{flex-wrap:wrap;padding:.75rem;gap:.5rem}.pref-film-actions{margin-left:auto}.admin-star-btn,.admin-dislike-btn{width:40px;height:40px;font-size:.85rem}.admin-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-tab{white-space:nowrap;padding:.6rem 1rem;font-size:.85rem}.onboarding-page,.preferences-page{padding-left:.5rem;padding-right:.5rem}.review-detail{padding-left:0;padding-right:0}.review-detail>*:not(.review-content figure){padding-left:1rem;padding-right:1rem}.review-content{padding:0 1rem}.review-content figure{margin-left:-1rem;margin-right:-1rem}.hero{padding:1.5rem 0 1rem}.featured-section{padding:0}}.navbar-auth{display:flex;align-items:center;gap:.75rem}.navbar-user{position:relative}.navbar-avatar-btn{background:none;border:2px solid transparent;border-radius:50%;padding:0;cursor:pointer;transition:border-color .2s}.navbar-avatar-btn:hover{border-color:var(--accent)}.navbar-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;display:block}.navbar-avatar-fallback{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#0f0b08;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem}.navbar-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);min-width:160px;padding:.5rem 0;z-index:200;box-shadow:0 4px 12px #0000004d}.navbar-dropdown-name{display:block;padding:.5rem 1rem;color:var(--text-secondary);font-size:.85rem;border-bottom:1px solid var(--border);margin-bottom:.25rem}.navbar-dropdown button{display:block;width:100%;text-align:left;padding:.75rem 1rem;min-height:44px;background:none;border:none;color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:background .15s}.navbar-dropdown button:hover{background:var(--accent-muted);color:var(--accent)}.onboarding-page,.preferences-page{max-width:700px;margin:0 auto;padding-bottom:3rem;text-align:center}.onboarding-page h1,.preferences-page h1{font-size:2rem;margin-bottom:.5rem}.onboarding-page h2,.preferences-page h2{font-size:1.25rem;margin-bottom:.25rem;color:var(--text-primary)}.onboarding-step-indicator{color:var(--text-secondary);font-size:.9rem;margin-bottom:2rem}.tag-grid{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:1.5rem 0}.tag-btn{padding:.5rem 1.25rem;min-height:44px;display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:20px;background:var(--bg-card);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:all .2s}.tag-btn:hover{border-color:var(--accent)}.tag-btn--selected{background:var(--accent);color:#0f0b08;border-color:var(--accent);font-weight:600}.onboarding-actions{display:flex;gap:.75rem;justify-content:center;margin-top:2rem}.pref-section{margin-bottom:2rem;text-align:center}.pref-list{list-style:none;padding:0;margin:1rem 0 0}.pref-list li{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.5rem;font-size:.9rem}.pref-list li span{flex:1;color:var(--text-primary);text-align:left}.pref-empty{color:var(--text-secondary);font-size:.9rem;text-align:center;padding:1.5rem 1rem;background:var(--bg-card);border:1px dashed var(--border);border-radius:var(--radius);margin-top:1rem}.pref-film-actions{display:flex;align-items:center;gap:.4rem;flex-shrink:0;margin-left:.5rem}.pref-remove-btn{background:none;border:none;color:var(--text-secondary);font-size:1.1rem;line-height:1;padding:.4rem;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px;transition:color .15s,background .15s;opacity:.5}.pref-remove-btn:hover{color:#e55;background:#ee55551a;opacity:1}.pref-thumb-btn{background:none;border:1px solid var(--border);font-size:1rem;padding:.35rem .5rem;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;cursor:pointer;transition:all .15s;line-height:1}.pref-thumb-up:hover,.pref-thumb-btn--active.pref-thumb-up{background:#4caf5026;border-color:#4caf50}.pref-thumb-down:hover{background:#ee555526;border-color:#e55}.pref-thumb-btn--active{transform:scale(1.15)}.pref-disliked-toggle{background:none;border:none;color:var(--text-secondary);font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;padding:.75rem .25rem;min-height:44px;transition:color .2s}.pref-disliked-toggle:hover{color:var(--text-primary)}.pref-toggle-arrow{font-size:.65rem;transition:transform .2s;display:inline-block}.pref-toggle-arrow--open{transform:rotate(90deg)}.pref-list--disliked li{opacity:.6}.pref-undislike-btn{background:none;border:1px solid var(--border);color:var(--text-secondary);font-size:.8rem;padding:.5rem .75rem;min-height:44px;display:inline-flex;align-items:center;border-radius:4px;cursor:pointer;transition:all .15s;white-space:nowrap}.pref-undislike-btn:hover{border-color:var(--accent);color:var(--accent)}
