.site-header{background:var(--bg-header);border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 3px 14px rgba(0,0,0,.12);position:relative;top:0;z-index:1000}
.header-inner{max-width:1240px;margin:0 auto;padding:10px 18px;display:flex;align-items:center;gap:18px}
.site-logo{display:flex;align-items:center;height:80px;overflow:hidden}
.site-logo img{height:90px!important;width:auto!important;max-height:none!important;max-width:none!important;display:block}
.header-right{margin-left:auto;display:flex;align-items:center;gap:10px;justify-content:flex-start}
.auth-slot{display:flex;align-items:center;gap:10px;position:relative}
.search-toggle{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:6px 8px;cursor:pointer;border:none;background:rgba(255,255,255,.24);backdrop-filter:blur(4px);transition:.25s;flex-shrink:0}
.search-toggle ion-icon{--ionicon-stroke-width:50px;font-size:20px;color:#fff}

.nav-btn{font-size:14px;font-weight:675;padding:7px 16px;border-radius:6px;cursor:pointer;transition:background .2s,color .2s,transform .2s,border-color .2s;}
html:not(.dark) .nav-btn{background:var(--accent-gold,#FFCB1C);color:var(--accent);border:2px solid var(--accent-gold,#FFCB1C);}
html:not(.dark) .nav-btn:hover{background:#FFB800;transform:translateY(-2px);}
html.dark .nav-btn{background:var(--accent-soft);color:var(--accent);border:2px solid var(--accent);}
html.dark .nav-btn:hover{background:var(--bg-elevated);transform:translateY(-2px);}

.sub-nav{position:relative;background:var(--bg-subnav);border-bottom:1px solid var(--border-subtle);padding:10px 0;overflow:visible;z-index:500}
.sub-nav-inner{max-width:1240px;margin:0 auto;display:flex;align-items:center;gap:12px;padding:0 18px;white-space:nowrap;overflow:visible}
.sub-nav-inner>a{flex-shrink:0;font-size:16px;font-weight:600;letter-spacing:.4px;padding:4px 12px;color:var(--text-secondary);text-decoration:none;transition:color .25s ease}
.sub-nav-inner>a:hover{color:var(--accent)}

.search-bar-drop{width:100%;display:flex;justify-content:center;padding:0 18px;overflow:hidden;max-height:0;opacity:0;background:var(--bg-nav);transition:max-height .3s,opacity .25s,padding .2s;position:relative;z-index:200000;pointer-events:none}
.search-bar-drop.active{padding:35px 18px;max-height:180px;opacity:1;pointer-events:auto}
.search-bar-drop>div{width:100%;max-width:520px;margin:0 auto;display:flex}
.search-drop-inner{width:100%;max-width:520px;margin:0 auto;display:flex}
html:not(.dark) .search-bar-drop{background:#f3f3f3}
html:not(.dark) .search-drop-input{background:#e6e6e6;color:#111}
html.dark .search-drop-input{background:var(--bg-subnav)}

.search-drop-input{height:50px;box-sizing:border-box;flex:1;padding:0 14px;background:var(--bg);border:none;width:100%;font-size:16px;line-height:20px;color:var(--text-primary)}
.search-drop-input:focus{outline:none!important;box-shadow:none!important;border:none!important}

.search-drop-btn{position:relative;background:var(--accent);color:#fff;padding:16px 25px;border:none;cursor:pointer;font-weight:600;border-radius:0 6px 6px 0;transition:.25s}
.search-drop-btn:hover{background:color-mix(in srgb,var(--accent) 85%,#000)}
.search-drop-btn.loading{color:transparent}

.search-drop-btn .loader-bars{position:absolute;inset:0;display:none;justify-content:center;align-items:center;gap:4px;pointer-events:none}
.search-drop-btn.loading .loader-bars{display:flex}
.search-drop-btn .loader-bars span{width:4px;height:15px;background:#fff;border-radius:2px;animation:pulseLoader .6s infinite ease-in-out}
.search-drop-btn .loader-bars span:nth-child(1){animation-delay:0s}
.search-drop-btn .loader-bars span:nth-child(2){animation-delay:.1s}
.search-drop-btn .loader-bars span:nth-child(3){animation-delay:.2s}
.search-drop-btn .loader-bars span:nth-child(4){animation-delay:.3s}
.search-drop-btn .loader-bars span:nth-child(5){animation-delay:.4s}

@keyframes pulseLoader{0%,100%{transform:scaleY(.4);opacity:.6}50%{transform:scaleY(1.2);opacity:1}}
.search-btn-wrapper{position:relative;display:flex;align-items:center}
.search-advanced-text{position:absolute;top:100%;right:0;margin-top:4px;font-size:12px;font-weight:700;color:var(--accent);white-space:nowrap;user-select:none;cursor:pointer;text-align:right}

.search-results{position:fixed;background:var(--bg-elevated);box-shadow:0 12px 32px rgba(0,0,0,.25);border-radius:8px;max-height:calc(5 * 114px);overflow-y:auto;display:none;z-index:999999}

.search-input-wrap{position:relative;flex:1 1 auto;min-width:0}
.search-result-item{display:flex;align-items:center;gap:12px;padding:12px;cursor:pointer;border-bottom:1px solid var(--border-subtle);transition:background .2s}
.search-result-item:hover{background:var(--accent-soft)}
.search-result-thumb{width:64px;height:88px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0}
.search-result-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:filter .25s ease}
.search-result-item:hover .search-result-thumb img{filter:saturate(150%)}
.search-result-title{font-size:15px;font-weight:600;color:var(--text-primary);transition:color .18s,transform .18s,font-weight .18s}
.search-result-item:hover .search-result-title{color:var(--accent);font-weight:700;transform:translateX(2px)}
.search-result-genres{font-size:12px;color:var(--text-muted)}

.nav-more{position:relative;display:inline-flex;align-items:center;flex-shrink:0;min-width:max-content;z-index:999998}
.nav-more::after{content:"";position:absolute;left:-60px;right:-60px;top:100%;height:40px;pointer-events:auto;z-index:999999}
.nav-more .more-link{display:inline-flex;align-items:center;font-size:16px;font-weight:600;letter-spacing:.4px;padding:4px 12px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:color .2s}
.nav-more .more-link:hover{color:var(--accent)}
.more-dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%);margin-top:2px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-bottom:3px solid var(--accent);border-radius:10px;box-shadow:0 12px 30px rgba(0,0,0,.22);padding:18px 20px;z-index:1000000;opacity:0;pointer-events:none;width:min(1240px,calc(100vw - 36px));transition:opacity .25s ease}
.sub-nav.open .more-dropdown{opacity:1;pointer-events:auto}
.genres-grid{width:100%;max-width:1240px;margin:0 auto;display:grid;gap:12px 18px}
@media(max-width:479px){.genres-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:480px){.genres-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.genres-grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1024px){.genres-grid{grid-template-columns:repeat(6,1fr)}}
@media(min-width:1280px){.genres-grid{grid-template-columns:repeat(8,1fr)}}

.genres-grid a{display:block;font-size:14px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;color:var(--text-primary);white-space:nowrap;cursor:pointer}
.genres-grid a:hover{color:var(--accent)}

.site-footer{width:100%;margin:0;padding:16px 18px 26px;font-size:12px;font-weight:475;color:var(--text-muted);text-align:center;border-top:1px solid var(--border-subtle);background:var(--bg-footer);}
.footer-links{display:flex;justify-content:center;gap:18px;margin-bottom:10px;flex-wrap:wrap}
.footer-links a{transition:.22s}
.footer-links a:hover{opacity:1;text-decoration:underline;color:var(--accent)}

.mobile-menu-toggle{width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(255,255,255,.24);backdrop-filter:blur(4px);transition:background .25s,transform .2s}
.mobile-menu-toggle ion-icon{font-size:22px;color:#fff}
body.dark .mobile-menu-toggle{background:rgba(255,255,255,.24)}
@media(hover:hover){.mobile-menu-toggle:hover{background:#fff;transform:scale(1.05)}.mobile-menu-toggle:hover ion-icon{color:#000}}

.mobile-menu{background:var(--bg-elevated);border-bottom:2px solid var(--border-strong);padding:0 18px;max-height:0;overflow:hidden;opacity:0;transform:translateY(-6px);transition:max-height .35s,opacity .25s,transform .25s,padding .25s}
.mobile-menu a{text-align:center;display:block;padding:12px 0;font-size:15px;font-weight:700;color:var(--text-primary);border-bottom:1px solid var(--border-subtle)}
.mobile-menu a:last-child{border-bottom:none}
.mobile-menu a:hover{background:var(--accent-soft)}
.mobile-menu.active{padding:12px 18px;max-height:200px;opacity:1;transform:translateY(0)}

@media(max-width:820px){.signin-btn,.signup-btn{display:none!important}}
@media(max-width:820px){.site-header{position:relative}}
@media(max-width:820px){.header-inner{position:relative;flex-wrap:nowrap}}
@media(max-width:820px){.site-logo{flex-shrink:0}}
@media(max-width:820px){.site-logo img{height:64px!important;width:auto!important}}
@media(max-width:820px){.header-right{position:absolute;right:14px;top:0;bottom:0;margin:auto 0;display:flex;align-items:center;gap:6px;justify-content:flex-end}}
@media(max-width:820px){.search-toggle,.icon-btn,.profile-wrap,.profile-avatar{position:static!important;transform:none!important}}
@media(max-width:820px){.search-toggle,.icon-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center}}
@media(max-width:820px){body.is-authenticated .profile-wrap{display:flex;align-items:center}}
@media(max-width:820px){body.is-authenticated .profile-avatar{width:48px;height:48px;min-width:48px;min-height:48px;aspect-ratio:1/1;object-fit:cover}}
@media(max-width:820px){.search-results{left:16px!important;right:16px!important;width:auto!important;max-width:calc(100vw - 32px)}}
@media(max-width:820px){.profile-dropdown{display:none!important}}

.mobile-menu .mobile-auth-only{display:none!important}
body.is-authenticated .mobile-menu .mobile-auth-only{display:block!important}
body.is-authenticated #open-login-mobile{display:none!important}
body.is-authenticated #open-signup-mobile{display:none!important}

@media(max-width:820px){body{overscroll-behavior:none}}
@media(max-width:820px){.site-header{overflow-x:hidden}}
@media(max-width:820px){.site-header,.header-inner{overflow:visible!important}}
@media(max-width:820px){.sub-nav{position:relative;z-index:99999;overflow:visible!important}}
@media(max-width:820px){body:not(.is-authenticated) #mobile-signup{border-bottom:none!important}}

.search-bar-drop>div{width:100%;max-width:none}
.search-drop-inner{width:100%;max-width:none}

.nav-more .more-hit{position:relative;display:inline-block}
.nav-more .more-hit::after{content:"";position:absolute;left:0;right:0;top:100%;height:calc(100% + 10px);pointer-events:auto}

.auth-modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;justify-content:center;align-items:center;z-index:99999}
.auth-modal.active{display:flex}

.auth-card{position:relative;background:var(--bg-elevated);width:360px;padding:28px 24px 24px;border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.25);text-align:center}
.auth-card input{width:100%;padding:12px;margin-bottom:12px;border:1px solid var(--border-subtle);background:var(--bg);color:var(--text-primary)}
.auth-card button:not(.auth-close){width:100%;padding:12px;background:var(--accent);color:#fff;font-weight:700;border:none;cursor:pointer;border-radius:6px}

.auth-close{position:absolute;top:10px;right:12px;background:transparent;border:none;padding:0;font-size:22px;line-height:1;font-weight:700;color:var(--accent);cursor:pointer;transition:transform .15s,opacity .15s}
.auth-close:hover{transform:scale(1.15);opacity:.75}
.auth-modal .auth-card button:not(.auth-close){transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;}
.auth-modal .auth-card button:not(.auth-close):hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.18);filter:brightness(1.05);}
.auth-modal .auth-card button:not(.auth-close):active{transform:translateY(0);box-shadow:0 3px 8px rgba(0,0,0,.18);}


.profile-wrap{position:relative;display:inline-flex;align-items:center;flex-shrink:0}
.profile-dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--bg-elevated);border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.18);display:none;z-index:99999;overflow:hidden}
.profile-dropdown.active{display:block}
.profile-item{display:flex;align-items:center;height:44px;padding:0 16px;font-size:14px;font-weight:600;color:var(--text-primary);cursor:pointer;white-space:nowrap;width:100%}
.profile-item:hover{background:var(--accent-soft)}

.logout-btn{border:none;background:none;text-align:left;width:100%}

@media(max-width:820px){.mobile-menu a,.mobile-menu a:hover,.mobile-menu a:active,.mobile-menu a:focus{color:var(--text-primary);background:transparent}}

.auth-hidden{display:none!important}
@media(min-width:821px){.search-bar-drop>div,.search-drop-inner{max-width:620px}}

.auth-resend-wrap{margin-top:12px;font-size:13px;color:var(--text-muted)}
.auth-resend-link{margin-left:4px;font-weight:700;color:var(--accent);cursor:pointer;transition:opacity .2s}
.auth-resend-link:hover{opacity:.7;text-decoration:underline}
.auth-resend-link.disabled{pointer-events:none;opacity:.45;text-decoration:none}

.auth-otp-wrap{display:flex;justify-content:center;gap:8px;margin-bottom:12px}
.auth-otp{width:44px;height:52px;font-size:22px;font-weight:800;text-align:center;border:2px solid var(--border-subtle);border-radius:8px;outline:none;transition:border-color .2s,box-shadow .2s}
.auth-otp:focus{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 25%,transparent)}
.auth-otp.error{border-color:var(--accent)}

.auth-error{margin-top:10px;font-size:13px;font-weight:600;color:var(--accent);text-align:center}

/* Scrollbars (theme-aware) */
*{scrollbar-width:thin;scrollbar-color:var(--accent) var(--bg-elevated)}
::-webkit-scrollbar{width:9px}
::-webkit-scrollbar-track{background:var(--bg-elevated)}
::-webkit-scrollbar-thumb{background:var(--accent);border-radius:999px}
::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--accent) 85%,#000)}

/* 🔒 Lock scrollbar colors on MOBILE even in dark mode */
@media (max-width:820px){
  body.dark,body.dark *{scrollbar-color:var(--accent) var(--bg-elevated)!important}
  body.dark ::-webkit-scrollbar-track{background:var(--bg-elevated)!important}
  body.dark ::-webkit-scrollbar-thumb{background:var(--accent)!important}
  body.dark ::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--accent) 85%,#000)!important}
}

#auth-switch-link{color:var(--accent);font-weight:600;cursor:pointer;transition:opacity .2s,text-decoration .2s}
#auth-switch-link:hover{opacity:.8;text-decoration:underline}

.auth-helper{font-size:12px;margin-top:4px;text-align:left;margin-bottom:6px}
.auth-helper.error{color:var(--accent)}
.auth-helper.success{color:#2E7D32}

.auth-input-error{border-color:var(--accent)!important;box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 25%,transparent)}
.auth-input-success{border-color:#2E7D32!important}

.profile-avatar{opacity:0;pointer-events:none;transition:opacity .15s}
.profile-avatar.is-loaded{opacity:1;pointer-events:auto}
.profile-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;cursor:pointer;flex-shrink:0;border:2px solid transparent;transition:border-color .3s,opacity .15s}
.profile-avatar:hover{border-color:var(--accent)}
html:not(.dark) .profile-avatar:hover{border-color:var(--accent-yellow);}

body:not(.is-authenticated) .mobile-menu a:nth-of-type(2){border-bottom:none}
body.auth-loading .mobile-menu{pointer-events:none;opacity:0;max-height:0!important;padding-top:0!important;padding-bottom:0!important;transform:translateY(-6px)!important;transition:none!important}
body.auth-loading .mobile-menu *{display:none!important}

.signin-btn,.signup-btn{display:inline-flex}
.profile-wrap{display:none}
body.is-authenticated .signin-btn,body.is-authenticated .signup-btn{display:none}
body.is-authenticated .profile-wrap{display:inline-flex}

.sub-nav-inner{visibility:hidden;opacity:0;transition:opacity .15s ease}
.sub-nav-inner.is-ready{visibility:visible;opacity:1}

.logout-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;z-index:99999}
.logout-box{background:var(--bg);color:var(--text-primary);padding:24px;border-radius:12px;max-width:320px;text-align:center}

.more-dropdown a{transition:color .3s ease}
.more-dropdown a:hover{color:var(--accent)}
.icon-btn{width:40px;height:40px;border-radius:50%;border:none;background:rgba(255,255,255,.24);backdrop-filter:blur(4px);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s,transform .2s;flex-shrink:0}
.icon-btn ion-icon{font-size:20px;color:#fff}

/* Desktop hover only (both light + dark) */
@media(hover:hover){
  .icon-btn:hover,
  .search-toggle:hover{background:#fff;transform:scale(1.05)}
  .icon-btn:hover ion-icon,
  .search-toggle:hover ion-icon{color:#000}
}

/* Dark mode base (non-hover) */
body.dark .icon-btn,
body.dark .search-toggle{background:rgba(255,255,255,.24)}
body.dark .icon-btn ion-icon,
body.dark .search-toggle ion-icon{color:#fff}

.header-right{display:flex;align-items:center;gap:12px;}
.header-icons{display:flex;align-items:center;gap:8px;}

@media (max-width:820px){
body:not(.is-authenticated) .mobile-menu.active{padding:8px 18px!important;}
html:not(.dark) body:not(.is-authenticated) .mobile-menu.active{background:var(--accent-yellow);}
html:not(.dark) body:not(.is-authenticated) .mobile-menu a.mobile-auth-btn{background:var(--accent-yellow)!important;color:var(--accent)!important;display:block;text-align:center;font-weight:650;margin:0 -18px!important;padding:14px 18px!important;border:none!important;position:relative;}
html:not(.dark) body:not(.is-authenticated) .mobile-menu a.mobile-auth-btn:first-of-type::after{content:"";position:absolute;bottom:0;left:18px;right:18px;height:2px;background:#000;opacity:.6;}
}

/* Logged-in mobile / header behavior */
body.is-authenticated .mobile-menu-toggle{display:none!important;}
body.is-authenticated .header-icons{order:1;}
body.is-authenticated .auth-slot{order:2;margin-left:auto;}

@media(min-width:821px){.mobile-menu-toggle{display:none!important;}}
@media(min-width:821px){.header-icons{order:1;}}
@media(min-width:821px){.auth-slot{order:2;}}
body.is-authenticated .profile-wrap{margin-left:-6px;}
html:not(.dark) .site-footer{color:var(--accent-yellow)}
html:not(.dark) .site-footer a{color:var(--accent-yellow)}
html:not(.dark) .site-footer a:hover{color:#fff}