/* ============================================================
   filmiMarg — DESIGN SYSTEM
   Dark cinema theme. Gold accent on near-black, modeled after
   the brief's reference screenshot (filmi Marg homepage).
   ============================================================ */

:root{
  /* ---- Color tokens ---- */
  --bg:            #0b0b0d;
  --bg-elevated:   #15151a;
  --bg-card:       #1c1c22;
  --bg-card-hover: #23232b;
  --line:          #2a2a31;
  --line-soft:     #1f1f25;

  --gold:          #f5b417;
  --gold-soft:     rgba(245,180,23,0.2);
  --gold-dim:      rgba(245,180,23,0.08);

  --text:          #f2f1ee;
  --text-dim:      #9a9aa3;
  --text-faint:    #65656d;

  --success:       #4ade80;
  --danger:        #ff6b6b;

  /* ---- Radius / spacing scale ---- */
  --radius-sm: 6px;
  --radius:    10px;
  --radius-lg: 16px;

  /* ---- Shadows ---- */
  --shadow-card: 0 4px 16px rgba(0,0,0,0.35);
  --shadow-modal: 0 -4px 30px rgba(0,0,0,0.5);
}

/* ---- Light theme (toggled via Dark Mode switch in sidebar) ---- */
[data-theme="light"]{
  --bg:            #f7f6f3;
  --bg-elevated:   #ffffff;
  --bg-card:       #ffffff;
  --bg-card-hover: #f0eee9;
  --line:          #e4e1da;
  --line-soft:     #ecead4;

  --gold:          #b8790a;
  --gold-soft:     rgba(184,121,10,0.15);
  --gold-dim:      rgba(184,121,10,0.07);

  --text:          #1a1a1d;
  --text-dim:      #6b6b72;
  --text-faint:    #9a9aa0;

  --shadow-card: 0 4px 16px rgba(0,0,0,0.08);
  --shadow-modal: 0 -4px 30px rgba(0,0,0,0.12);
}
[data-theme="light"] .hero-slide::after{
  background:linear-gradient(180deg, rgba(247,246,243,0) 0%, rgba(247,246,243,0.55) 55%, rgba(247,246,243,0.97) 100%);
}
[data-theme="light"] .btn-primary{color:#fff;}
[data-theme="light"] .lang-overlay{
  background:linear-gradient(160deg, #fff3da 0%, var(--bg) 38%);
}

/* ---- Reset ---- */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
a{text-decoration:none;color:inherit;}
img{display:block;max-width:100%;}
button{font-family:inherit;}
ul{margin:0;padding:0;list-style:none;}

::-webkit-scrollbar{width:8px;height:8px;}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px;}

:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important;}
}

/* ============================================================
   TOP BAR + NAV (shared across pages)
   ============================================================ */
header.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:16px 24px 12px;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;background:rgba(11,11,13,0.92);
  backdrop-filter:blur(10px);
  z-index:120;
}
.icon-btn{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:transparent;border:none;color:var(--text);
  cursor:pointer;transition:background .15s;
}
.icon-btn:hover{background:var(--bg-card);}

.brand{display:flex;flex-direction:column;}
.brand .logo{font-size:21px;font-weight:800;letter-spacing:-0.5px;}
.brand .logo span{color:var(--gold);}
.brand .tagline{font-size:10.5px;color:var(--text-dim);margin-top:1px;}

.top-actions{display:flex;align-items:center;gap:8px;}
.avatar{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,#3a3a42,#1e1e24);
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;cursor:pointer;
}

nav.mainnav{
  display:flex;gap:26px;padding:12px 24px;
  border-bottom:1px solid var(--line);
  overflow-x:auto;scrollbar-width:none;
}
nav.mainnav::-webkit-scrollbar{display:none;}
nav.mainnav a{
  font-size:12.5px;font-weight:700;letter-spacing:0.5px;
  color:var(--text-dim);white-space:nowrap;
  padding-bottom:12px;border-bottom:2px solid transparent;
}
nav.mainnav a.active{color:var(--gold);border-color:var(--gold);}
nav.mainnav a:hover{color:var(--text);}

main{max-width:1100px;margin:0 auto;padding:0 20px 100px;}

/* ============================================================
   SIDEBAR (hamburger menu)
   ============================================================ */
.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:200;display:none;}
.sidebar-overlay.open{display:block;}
.sidebar{
  position:fixed;top:0;left:0;height:100%;width:280px;
  background:var(--bg-elevated);border-right:1px solid var(--line);
  z-index:210;padding:18px 0;overflow-y:auto;
  transform:translateX(-100%);transition:transform .25s ease;
}
.sidebar.open{transform:translateX(0);}
.sidebar-header{padding:0 20px 16px;border-bottom:1px solid var(--line);margin-bottom:8px;position:relative;}
.sidebar-close{position:absolute;top:0;right:16px;background:none;border:none;color:var(--text-dim);font-size:20px;cursor:pointer;}
.sidebar-section{padding:6px 0;border-bottom:1px solid var(--line);margin-bottom:6px;}
.sidebar-section:last-child{border-bottom:none;}
.sidebar-link{
  display:flex;align-items:center;gap:12px;padding:12px 20px;
  font-size:14px;font-weight:600;cursor:pointer;
}
.sidebar-link:hover{background:rgba(255,255,255,0.05);}
.sidebar-link .icon{font-size:16px;width:20px;text-align:center;}
.sidebar-link.premium-link{color:var(--gold);}
.sidebar-link.logout-link{color:var(--danger);}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 20px;border-radius:8px;font-size:14px;font-weight:700;
  border:1px solid transparent;cursor:pointer;transition:transform .12s,background .15s;
}
.btn:hover{transform:translateY(-1px);}
.btn-primary{background:var(--gold);color:#1a1300;}
.btn-primary:hover{background:#ffc738;}
.btn-ghost{background:rgba(255,255,255,0.04);color:var(--text);border-color:#3a3a42;}
.btn-ghost:hover{background:rgba(255,255,255,0.09);}
.btn-block{width:100%;}
.btn-sm{padding:7px 14px;font-size:12.5px;}

/* ============================================================
   HERO CAROUSEL
   ============================================================ */
.hero{position:relative;margin-top:16px;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#000;}
.hero-slide{position:relative;height:420px;background-size:cover;background-position:center;display:flex;flex-direction:column;justify-content:flex-end;}
.hero-slide::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(11,11,13,0) 0%, rgba(11,11,13,0.55) 55%, rgba(11,11,13,0.96) 100%);}
.hero-content{position:relative;z-index:2;padding:26px 28px 24px;}
.hero-meta{display:inline-flex;align-items:center;gap:10px;font-size:13px;color:var(--text-dim);margin-bottom:12px;flex-wrap:wrap;}
.hero-rating{display:inline-flex;align-items:center;gap:4px;background:var(--gold-soft);color:var(--gold);border:1px solid var(--gold);padding:3px 9px;border-radius:6px;font-weight:700;font-size:12.5px;}
.hero-title{font-size:34px;font-weight:800;letter-spacing:-0.5px;margin:0 0 10px;line-height:1.08;}
.hero-overview{max-width:560px;color:#cfcfd6;font-size:14px;line-height:1.55;margin:0 0 18px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;}
.hero-dots{position:absolute;bottom:14px;right:18px;z-index:3;display:flex;gap:6px;}
.hero-dots button{width:18px;height:4px;border-radius:3px;border:none;background:rgba(255,255,255,0.25);cursor:pointer;padding:0;}
.hero-dots button.active{background:var(--gold);width:22px;}
.hero-skeleton{height:420px;background:linear-gradient(100deg, var(--bg-card) 30%, var(--bg-card-hover) 50%, var(--bg-card) 70%);background-size:200% 100%;animation:shimmer 1.4s infinite;}

/* ============================================================
   PREMIUM BANNER
   ============================================================ */
.premium-banner{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:linear-gradient(135deg, #2a2310, #1c1c22);
  border:1px solid var(--gold);border-radius:10px;
  padding:12px 16px;margin:16px 0;font-size:13px;
}
.premium-banner.active{background:linear-gradient(135deg, #1e2a1a, #1c1c22);border-color:var(--success);}
.premium-banner .pb-text{display:flex;align-items:center;gap:8px;}
.premium-banner .pb-text b{color:var(--gold);}
.premium-banner.active .pb-text b{color:var(--success);}

/* ============================================================
   STATS BAR
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin:20px 0 32px;}
.stat-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 8px;text-align:center;}
.stat-icon{font-size:19px;margin-bottom:7px;color:var(--gold);}
.stat-num{font-size:17px;font-weight:800;}
.stat-label{font-size:11.5px;color:var(--text-dim);margin-top:2px;}

/* ---- Feature cards (Mood Quiz, Trivia, Watch Party, Surprise Me) ---- */
.feature-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.feature-card{
  background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:18px 14px;cursor:pointer;position:relative;
  transition:transform .15s, border-color .15s;
}
.feature-card:hover{transform:translateY(-3px);border-color:var(--gold);}
.fc-icon{font-size:26px;margin-bottom:8px;}
.fc-title{font-size:13.5px;font-weight:800;margin-bottom:4px;}
.fc-desc{font-size:11px;color:var(--text-dim);line-height:1.4;}
.fc-tag{
  position:absolute;top:14px;right:14px;font-size:9.5px;font-weight:800;
  letter-spacing:0.4px;text-transform:uppercase;padding:3px 7px;border-radius:5px;
}
.fc-tag.free{background:rgba(74,222,128,0.15);color:var(--success);}
.fc-tag.premium{background:var(--gold-soft);color:var(--gold);}
.fc-tag.soon{background:rgba(154,154,163,0.15);color:var(--text-faint);}
.coming-soon-card{opacity:0.7;cursor:default;}
.coming-soon-card:hover{transform:none;border-color:var(--line);}

.on-this-day-card{
  background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:20px;display:flex;gap:16px;align-items:center;
}
.otd-poster{width:70px;flex-shrink:0;border-radius:8px;overflow:hidden;background:#1a1a1f;aspect-ratio:2/3;}
.otd-poster img{width:100%;height:100%;object-fit:cover;}
.otd-body{flex:1;min-width:0;}
.otd-year-badge{display:inline-block;background:var(--gold-soft);color:var(--gold);font-size:11px;font-weight:800;padding:3px 9px;border-radius:6px;margin-bottom:6px;}
.otd-title{font-size:15px;font-weight:800;margin-bottom:4px;}
.otd-desc{font-size:12.5px;color:var(--text-dim);line-height:1.5;}
.otd-cta{margin-top:10px;}
@media(max-width:880px){
  .feature-cards{grid-template-columns:repeat(2,1fr);}
}

/* ============================================================
   SECTIONS + CARD GRID
   ============================================================ */
.section{margin-bottom:36px;}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.section-title{font-size:16px;font-weight:800;display:flex;align-items:center;gap:9px;}
.section-title .bar{width:4px;height:17px;background:var(--gold);border-radius:2px;display:inline-block;}
.view-all{font-size:12.5px;color:var(--text-dim);display:flex;align-items:center;gap:4px;cursor:pointer;}
.view-all:hover{color:var(--gold);}

.lang-trigger-btn{
  display:flex;align-items:center;gap:6px;
  background:var(--bg-card);border:1px solid var(--line);color:var(--text);
  font-size:12.5px;font-weight:600;padding:8px 12px;border-radius:8px;cursor:pointer;
}
.lang-trigger-btn:hover{border-color:var(--gold);}

/* ---- Full-screen language/country picker (premium style) ---- */
.lang-overlay{
  position:fixed;inset:0;z-index:270;
  background:linear-gradient(160deg, #1a1610 0%, var(--bg) 38%);
  display:none;flex-direction:column;
}
.lang-overlay.open{display:flex;}
.lang-overlay-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 20px 10px;
}
.lang-overlay-title{font-size:15px;font-weight:800;letter-spacing:0.2px;}
.lang-overlay-close{
  width:36px;height:36px;border-radius:50%;background:var(--bg-card);
  border:1px solid var(--line);color:var(--text);font-size:16px;cursor:pointer;
}
.lang-overlay-search{
  display:flex;align-items:center;gap:10px;
  margin:10px 20px 6px;padding:13px 16px;border-radius:12px;
  background:var(--bg-card);border:1px solid var(--line);color:var(--text-dim);
}
.lang-overlay-search input{
  flex:1;background:none;border:none;color:var(--text);font-size:15px;
}
.lang-overlay-search input:focus{outline:none;}
.lang-overlay-body{flex:1;overflow-y:auto;padding:14px 20px 100px;}

.lang-group-title{
  font-size:12px;font-weight:800;letter-spacing:0.6px;text-transform:uppercase;
  color:var(--gold);margin:22px 0 10px;display:flex;align-items:center;gap:8px;
}
.lang-group-title:first-child{margin-top:6px;}
.lang-group-title .bar{width:3px;height:13px;background:var(--gold);border-radius:2px;}

.lang-chip-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
@media (min-width:520px){ .lang-chip-grid{grid-template-columns:repeat(3,1fr);} }

.lang-chip{
  background:var(--bg-card);border:1px solid var(--line);border-radius:12px;
  padding:14px 14px;cursor:pointer;transition:border-color .15s, transform .12s;
  display:flex;flex-direction:column;gap:2px;
}
.lang-chip:hover{border-color:var(--gold);transform:translateY(-2px);}
.lang-chip.selected{border-color:var(--gold);background:var(--gold-dim);}
.lang-chip .chip-main{font-size:14px;font-weight:700;}
.lang-chip .chip-sub{font-size:11px;color:var(--text-dim);}
.lang-chip.selected .chip-main{color:var(--gold);}

.lang-no-match{padding:30px 0;text-align:center;color:var(--text-dim);font-size:13.5px;}

/* ---- Language onboarding popup (Spotify-style first question) ---- */
.onboarding-body{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:30px 24px;text-align:center;max-width:480px;margin:0 auto;width:100%;
}
.onboard-title{font-size:21px;font-weight:800;line-height:1.3;margin-bottom:8px;}
.onboard-sub{font-size:13px;color:var(--text-dim);margin-bottom:24px;}
.onboard-search-wrap{width:100%;margin-bottom:18px;}
.onboard-search-wrap input{
  width:100%;padding:13px 16px;border-radius:10px;background:var(--bg-card);
  border:1px solid var(--line);color:var(--text);font-size:14px;text-align:center;
}
.onboard-search-wrap input:focus{border-color:var(--gold);}
.onboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;width:100%;max-height:50vh;overflow-y:auto;}
@media(min-width:480px){ .onboard-grid{grid-template-columns:repeat(3,1fr);} }
.onboard-chip{
  background:var(--bg-card);border:1px solid var(--line);border-radius:10px;
  padding:14px 10px;font-size:13.5px;font-weight:700;cursor:pointer;
  transition:border-color .15s, transform .12s;
}
.onboard-chip:hover{border-color:var(--gold);transform:translateY(-2px);}
.onboard-chip.selected{border-color:var(--gold);background:var(--gold-dim);color:var(--gold);}
.onboard-actions{display:flex;gap:10px;margin-top:20px;width:100%;}
.onboard-actions .btn{flex:1;}

/* ---- Footer ---- */
footer.site-footer{
  border-top:1px solid var(--line);padding:28px 20px 110px;
  margin-top:20px;text-align:center;color:var(--text-dim);font-size:12.5px;
}
footer.site-footer .footer-logo{font-size:16px;font-weight:800;color:var(--text);margin-bottom:8px;}
footer.site-footer .footer-logo span{color:var(--gold);}
footer.site-footer a{color:var(--gold);}
footer.site-footer .footer-meta{margin-top:6px;}
@media(min-width:641px){
  footer.site-footer{padding-bottom:28px;}
}

.card-row{display:grid;grid-template-columns:repeat(5,1fr);gap:13px;}
.card-row.cols-6{grid-template-columns:repeat(6,1fr);}

.movie-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .15s,border-color .15s;}
.movie-card:hover{transform:translateY(-4px);border-color:#46462f;}
.poster-wrap{position:relative;aspect-ratio:2/3;background:#1a1a1f;overflow:hidden;}
.poster-wrap img{width:100%;height:100%;object-fit:cover;}
.card-rating{position:absolute;top:8px;left:8px;background:rgba(11,11,13,0.85);border:1px solid var(--gold);color:var(--gold);font-size:11px;font-weight:700;padding:2px 6px;border-radius:5px;display:flex;align-items:center;gap:3px;}
.card-bookmark{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;background:rgba(11,11,13,0.85);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-dim);}
.card-bookmark.saved{color:var(--gold);border-color:var(--gold);}
.card-body{padding:9px 10px 12px;}
.card-title{font-size:13px;font-weight:700;line-height:1.3;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;}
.card-year{font-size:11.5px;color:var(--text-dim);margin-top:3px;}

/* People (celebrity) cards — round portrait style */
.people-card{text-align:center;cursor:pointer;}
.people-photo{width:100%;aspect-ratio:1/1;border-radius:50%;overflow:hidden;background:#1a1a1f;border:1px solid var(--line);margin-bottom:8px;}
.people-photo img{width:100%;height:100%;object-fit:cover;}
.people-name{font-size:12.5px;font-weight:700;}
.people-role{font-size:11px;color:var(--text-dim);margin-top:2px;}

/* ============================================================
   RANK LIST (Top Rated style)
   ============================================================ */
.rank-list{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
.rank-row{display:flex;align-items:center;gap:13px;padding:11px 16px;border-bottom:1px solid var(--line);cursor:pointer;}
.rank-row:last-child{border-bottom:none;}
.rank-row:hover{background:rgba(255,255,255,0.03);}
.rank-num{width:18px;font-weight:800;color:var(--text-dim);font-size:13.5px;}
.rank-thumb{width:40px;height:56px;border-radius:6px;overflow:hidden;background:#1a1a1f;flex-shrink:0;}
.rank-thumb img{width:100%;height:100%;object-fit:cover;}
.rank-info{flex:1;min-width:0;}
.rank-title{font-size:13.5px;font-weight:700;}
.rank-rating{display:flex;align-items:center;gap:5px;font-size:13px;font-weight:700;color:var(--gold);width:54px;}
.rank-year{color:var(--text-dim);font-size:12.5px;width:42px;}

/* ============================================================
   NEWS CARDS
   ============================================================ */
.news-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;gap:12px;padding:12px;cursor:pointer;}
.news-card:hover{border-color:#46462f;}
.news-thumb{width:84px;height:84px;border-radius:8px;overflow:hidden;background:#1a1a1f;flex-shrink:0;}
.news-thumb img{width:100%;height:100%;object-fit:cover;}
.news-body{flex:1;min-width:0;}
.news-title{font-size:13px;font-weight:700;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.news-source{font-size:11px;color:var(--text-dim);margin-top:6px;}

/* ============================================================
   SEARCH OVERLAY
   ============================================================ */
.search-overlay{position:fixed;inset:0;background:rgba(11,11,13,0.97);z-index:300;display:none;flex-direction:column;}
.search-overlay.open{display:flex;}
.search-bar-row{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--line);}
.search-bar-row input{flex:1;background:var(--bg-card);border:1px solid var(--line);border-radius:8px;padding:11px 14px;color:var(--text);font-size:14px;}
.search-bar-row input:focus{border-color:var(--gold);}
.search-cancel{background:none;border:none;color:var(--text-dim);font-size:13px;font-weight:700;cursor:pointer;}
.search-results{flex:1;overflow-y:auto;padding:16px 20px;}
.search-result-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line-soft);cursor:pointer;}
.search-result-thumb{width:42px;height:60px;border-radius:6px;overflow:hidden;background:#1a1a1f;flex-shrink:0;}
.search-result-thumb img{width:100%;height:100%;object-fit:cover;}
.search-result-info{flex:1;min-width:0;}
.search-result-title{font-size:13.5px;font-weight:700;}
.search-result-meta{font-size:11.5px;color:var(--text-dim);margin-top:2px;}
.search-empty{text-align:center;color:var(--text-dim);font-size:13.5px;padding:40px 20px;}

/* ============================================================
   LOADING SKELETONS
   ============================================================ */
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}
.skel-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
.skel-poster{aspect-ratio:2/3;background:linear-gradient(100deg, var(--bg-card) 30%, var(--bg-card-hover) 50%, var(--bg-card) 70%);background-size:200% 100%;animation:shimmer 1.4s infinite;}
.skel-line{height:11px;margin:9px 10px;border-radius:4px;background:linear-gradient(100deg, var(--bg-card) 30%, var(--bg-card-hover) 50%, var(--bg-card) 70%);background-size:200% 100%;animation:shimmer 1.4s infinite;}
.skel-line.short{width:55%;}

.loading-row{padding:30px;text-align:center;color:var(--text-dim);font-size:13px;}

/* ============================================================
   MODALS (generic overlay used by auth / TMDB key / etc.)
   ============================================================ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);display:flex;align-items:center;justify-content:center;z-index:250;padding:20px;}
.modal-overlay.hidden{display:none;}
.modal-box{background:var(--bg-card);border:1px solid var(--line);border-radius:14px;padding:26px;max-width:380px;width:100%;}
.modal-box h2{margin:0 0 8px;font-size:18px;font-weight:800;}
.modal-box p{margin:0 0 16px;font-size:13.5px;color:var(--text-dim);line-height:1.5;}
.modal-box input{width:100%;padding:11px 13px;border-radius:8px;background:#0e0e11;border:1px solid var(--line);color:var(--text);font-size:14px;margin-bottom:10px;}
.modal-box input:focus{border-color:var(--gold);}
.modal-actions{display:flex;gap:10px;margin-top:6px;}
.modal-actions .btn{flex:1;}
.modal-note{font-size:11.5px;color:var(--text-dim);margin-top:14px;line-height:1.5;}
.modal-note a{color:var(--gold);}
.modal-error{color:var(--danger);font-size:12.5px;margin:-4px 0 10px;display:none;}
.modal-success{color:var(--success);font-size:12.5px;margin:-4px 0 10px;display:none;}

.auth-tabs{display:flex;gap:6px;margin-bottom:16px;background:#0e0e11;border-radius:8px;padding:4px;}
.auth-tab{flex:1;text-align:center;padding:8px;border-radius:6px;font-size:13px;font-weight:700;color:var(--text-dim);cursor:pointer;border:none;background:transparent;}
.auth-tab.active{background:var(--bg-card);color:var(--text);}

.user-menu{position:relative;}
.user-dropdown{position:absolute;top:46px;right:0;background:var(--bg-card);border:1px solid var(--line);border-radius:10px;min-width:200px;padding:8px;z-index:130;display:none;}
.user-dropdown.open{display:block;}
.user-dropdown .email-row{font-size:12px;color:var(--text-dim);padding:8px 10px;border-bottom:1px solid var(--line);margin-bottom:6px;word-break:break-all;}
.user-dropdown a,.user-dropdown button{display:block;width:100%;text-align:left;padding:9px 10px;border-radius:6px;font-size:13.5px;background:none;border:none;color:var(--text);cursor:pointer;}
.user-dropdown a:hover,.user-dropdown button:hover{background:rgba(255,255,255,0.06);}
.user-dropdown .logout-btn{color:var(--danger);}

/* ============================================================
   PRICING / PREMIUM PAGE
   ============================================================ */
.pricing-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.8);z-index:280;display:none;align-items:flex-start;justify-content:center;overflow-y:auto;padding:30px 16px;}
.pricing-overlay.open{display:flex;}
.pricing-box{max-width:460px;width:100%;background:var(--bg-card);border:1px solid var(--line);border-radius:16px;padding:28px;position:relative;max-height:88vh;overflow-y:auto;}
.pricing-close{position:absolute;top:18px;right:18px;background:none;border:none;color:var(--text-dim);font-size:22px;cursor:pointer;}
.pricing-box h2{margin:0 0 6px;font-size:22px;font-weight:800;}
.pricing-box .sub{color:var(--text-dim);font-size:13.5px;margin:0 0 22px;}
.plan-card{border:1px solid var(--line);border-radius:12px;padding:18px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:border-color .15s;}
.plan-card:hover{border-color:var(--gold);}
.plan-card.best-value{border-color:var(--gold);position:relative;}
.plan-card.best-value::before{content:"BEST VALUE";position:absolute;top:-9px;left:16px;background:var(--gold);color:#1a1300;font-size:10px;font-weight:800;padding:2px 8px;border-radius:4px;letter-spacing:0.4px;}
.plan-name{font-size:15px;font-weight:800;}
.plan-desc{font-size:12px;color:var(--text-dim);margin-top:3px;}
.plan-price{font-size:19px;font-weight:800;color:var(--gold);text-align:right;}
.plan-price span{font-size:11px;color:var(--text-dim);font-weight:400;display:block;}
.pricing-features{margin:18px 0;}
.pricing-features li{font-size:13px;color:var(--text-dim);padding:6px 0;display:flex;gap:8px;}
.pricing-features li::before{content:"✓";color:var(--success);font-weight:800;}

.plan-compare-title{
  font-size:12px;font-weight:800;letter-spacing:0.5px;text-transform:uppercase;
  color:var(--text-dim);margin:22px 0 10px;
}
.plan-compare-list{border:1px solid var(--line);border-radius:10px;overflow:hidden;}
.plan-compare-row{
  display:grid;grid-template-columns:1fr 64px 76px;align-items:center;gap:6px;
  padding:9px 12px;border-bottom:1px solid var(--line-soft);font-size:12.5px;
}
.plan-compare-row:last-child{border-bottom:none;}
.plan-compare-row:nth-child(odd){background:rgba(255,255,255,0.015);}
.pcr-label{color:var(--text);}
.pcr-free{color:var(--text-dim);text-align:center;font-size:11.5px;}
.pcr-premium{color:var(--gold);text-align:center;font-weight:700;font-size:11.5px;}
.plan-compare-head{
  display:grid;grid-template-columns:1fr 64px 76px;gap:6px;
  padding:0 12px 6px;font-size:10.5px;font-weight:800;letter-spacing:0.4px;
  color:var(--text-faint);text-transform:uppercase;
}
.plan-compare-head span:not(:first-child){text-align:center;}

/* ============================================================
   AI CHATBOT WIDGET
   ============================================================ */
.chat-fab-wrap{position:fixed;bottom:24px;right:18px;z-index:160;display:flex;align-items:center;gap:10px;}
.chat-fab-label{
  background:var(--bg-card);border:1px solid var(--gold);color:var(--text);
  font-size:12px;font-weight:700;padding:8px 12px;border-radius:20px;
  box-shadow:0 4px 14px rgba(0,0,0,0.3);white-space:nowrap;
}
.chat-fab{position:relative;width:54px;height:54px;border-radius:50%;background:var(--gold);color:#1a1300;border:none;font-size:24px;cursor:pointer;box-shadow:0 4px 14px rgba(0,0,0,0.4);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.chat-panel{position:fixed;bottom:24px;right:18px;z-index:290;width:100%;max-width:380px;height:75vh;max-height:600px;background:var(--bg-card);border:1px solid var(--line);border-radius:16px;display:none;flex-direction:column;box-shadow:var(--shadow-modal);}
.chat-panel.open{display:flex;}
.chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line);}
.chat-header .title{font-size:14px;font-weight:800;display:flex;align-items:center;gap:8px;}
.chat-header .title .badge{font-size:10px;background:var(--gold-soft);color:var(--gold);padding:2px 7px;border-radius:5px;font-weight:700;}
.chat-close{background:none;border:none;color:var(--text-dim);font-size:18px;cursor:pointer;}
.chat-body{flex:1;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:10px;}
.chat-msg{max-width:85%;padding:9px 12px;border-radius:10px;font-size:13.5px;line-height:1.45;}
.chat-msg.bot{background:#26262e;align-self:flex-start;}
.chat-msg.user{background:var(--gold);color:#1a1300;align-self:flex-end;}
.chat-input-row{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line);}
.chat-input-row input{flex:1;padding:10px 12px;border-radius:8px;background:#0e0e11;border:1px solid var(--line);color:var(--text);font-size:13.5px;}
.chat-input-row button{background:var(--gold);color:#1a1300;border:none;border-radius:8px;padding:10px 14px;font-weight:700;cursor:pointer;font-size:13px;}
.chat-locked{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px 20px;gap:14px;}
.chat-locked .lock-icon{font-size:34px;}
.chat-locked p{color:var(--text-dim);font-size:13.5px;margin:0;}

/* ============================================================
   FEATURE MODAL (shared host for Mood Quiz / Trivia / Watch Party)
   ============================================================ */
.feature-modal-box{max-width:420px;max-height:85vh;overflow-y:auto;}
.feature-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.feature-modal-title{font-size:16px;font-weight:800;}

/* ---- Quiz UI (shared by Mood Quiz + Trivia) ---- */
.quiz-progress{height:5px;border-radius:3px;background:var(--line);overflow:hidden;margin-bottom:18px;}
.quiz-progress-fill{height:100%;background:var(--gold);transition:width .3s;}
.quiz-question{font-size:16px;font-weight:700;margin-bottom:16px;line-height:1.4;}
.quiz-options{display:flex;flex-direction:column;gap:9px;}
.quiz-option{
  text-align:left;padding:13px 15px;border-radius:10px;
  background:#0e0e11;border:1px solid var(--line);color:var(--text);
  font-size:13.5px;cursor:pointer;transition:border-color .15s,background .15s;
}
.quiz-option:hover:not(:disabled){border-color:var(--gold);}
.quiz-option:disabled{cursor:default;}
.quiz-option.correct{border-color:var(--success);background:rgba(74,222,128,0.1);color:var(--success);}
.quiz-option.wrong{border-color:var(--danger);background:rgba(255,107,107,0.1);color:var(--danger);}
.quiz-score-mini{margin-top:14px;font-size:12px;color:var(--text-dim);text-align:right;}

.quiz-result{text-align:center;}
.quiz-result-poster{width:140px;aspect-ratio:2/3;margin:0 auto 14px;border-radius:10px;overflow:hidden;background:#1a1a1f;}
.quiz-result-poster img{width:100%;height:100%;object-fit:cover;}
.quiz-result-title{font-size:17px;font-weight:800;margin-bottom:4px;}
.quiz-result-rating{color:var(--gold);font-weight:700;font-size:13px;margin-bottom:10px;}
.quiz-result-overview{font-size:13px;color:var(--text-dim);line-height:1.55;margin-bottom:18px;}
.quiz-result-actions{display:flex;gap:10px;}
.quiz-result-actions .btn{flex:1;}
.quiz-no-result{text-align:center;color:var(--text-dim);font-size:13.5px;padding:20px 0;}
.quiz-final-score{font-size:42px;font-weight:800;color:var(--gold);margin-bottom:8px;}

/* ---- Watch Party UI ---- */
.wp-step{margin-bottom:18px;}
.wp-label{display:block;font-size:12px;font-weight:700;color:var(--text-dim);margin-bottom:7px;}
.wp-input{
  width:100%;padding:11px 13px;border-radius:8px;background:#0e0e11;
  border:1px solid var(--line);color:var(--text);font-size:13.5px;
}
.wp-input:focus{border-color:var(--gold);}
.wp-movie-results{margin-top:6px;}
.wp-result-row{padding:9px 11px;font-size:13px;border-radius:7px;cursor:pointer;background:var(--bg-card);margin-bottom:4px;}
.wp-result-row:hover{border:1px solid var(--gold);}
.wp-selected-movie{margin-top:8px;font-size:13px;color:var(--gold);font-weight:700;}
.wp-share-card{
  margin-top:18px;padding:18px;border-radius:12px;text-align:center;
  background:linear-gradient(135deg, #2a2310, var(--bg-card));border:1px solid var(--gold);
}
.wp-share-title{font-size:16px;font-weight:800;margin-bottom:6px;}
.wp-share-date{font-size:13px;color:var(--text-dim);margin-bottom:6px;}
.wp-share-note{font-size:12.5px;color:var(--text-dim);margin-bottom:14px;font-style:italic;}

/* ---- Shared "VS" comparison picker (DNA Match, Rivalry, Six Degrees) ---- */
.dna-pickers{display:flex;align-items:flex-start;gap:10px;margin-bottom:16px;}
.dna-picker{flex:1;min-width:0;}
.dna-vs{
  font-size:12px;font-weight:800;color:var(--gold);padding:11px 4px 0;flex-shrink:0;
}

/* ---- Movie DNA Match result ---- */
.dna-match-score{font-size:38px;font-weight:800;color:var(--gold);text-align:center;margin:6px 0 18px;}
.dna-match-score span{display:block;font-size:11px;color:var(--text-dim);font-weight:600;text-transform:uppercase;letter-spacing:0.5px;}
.dna-section{margin-bottom:14px;}
.dna-section-title{font-size:11.5px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:0.4px;margin-bottom:7px;}
.dna-chips{display:flex;flex-wrap:wrap;gap:6px;}
.dna-chip{font-size:12px;padding:5px 10px;border-radius:7px;background:var(--bg-card);border:1px solid var(--line);}
.dna-chip.match{color:var(--gold);border-color:var(--gold);}
.dna-chip.none{color:var(--text-faint);}

/* ---- Actor Rivalry result ---- */
.rivalry-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;}
.rivalry-col{background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:14px;text-align:center;}
.rivalry-col.winner{border-color:var(--gold);background:var(--gold-dim);}
.rivalry-name{font-size:12.5px;font-weight:700;margin-bottom:6px;}
.rivalry-stat-big{font-size:22px;font-weight:800;color:var(--gold);}
.rivalry-stat-label{font-size:10.5px;color:var(--text-dim);margin-top:2px;text-transform:uppercase;letter-spacing:0.3px;}
.rivalry-top-film{font-size:12px;font-weight:600;margin-top:4px;}

/* ---- Six Degrees result ---- */
.sd-result-direct{
  display:flex;align-items:center;gap:12px;padding:18px;border-radius:12px;
  background:var(--gold-dim);border:1px solid var(--gold);font-size:13.5px;
}
.sd-connection-icon{font-size:28px;}
.sd-path{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 10px;}
.sd-path-step{font-size:13.5px;background:var(--bg-card);border:1px solid var(--line);padding:9px 14px;border-radius:8px;text-align:center;}
.sd-path-arrow{font-size:11px;color:var(--text-dim);}

/* ---- Around the World result ---- */
.aw-group{margin-bottom:16px;}
.aw-group-title{font-size:12px;font-weight:700;color:var(--gold);margin-bottom:8px;}
.aw-movie-row{display:flex;gap:10px;overflow-x:auto;}
.aw-movie-chip{flex-shrink:0;width:72px;cursor:pointer;text-align:center;}
.aw-movie-chip img{width:72px;height:104px;object-fit:cover;border-radius:7px;margin-bottom:5px;background:#1a1a1f;}
.aw-movie-chip span{font-size:10.5px;line-height:1.3;display:block;}

/* ---- Cinema Personality result ---- */
.cp-header{text-align:center;margin-bottom:18px;}
.cp-emoji{font-size:40px;margin-bottom:6px;}
.cp-title{font-size:17px;font-weight:800;color:var(--gold);}
.cp-genre-bars{margin-bottom:18px;}
.cp-genre-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:9px;}
.cp-genre-name{font-size:12px;width:80px;flex-shrink:0;}
.cp-genre-bar-track{flex:1;height:8px;border-radius:4px;background:var(--line);overflow:hidden;}
.cp-genre-bar-fill{height:100%;background:var(--gold);}
.cp-genre-pct{font-size:11.5px;color:var(--text-dim);width:32px;text-align:right;}
.cp-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.cp-stat{background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:12px 6px;text-align:center;}
.cp-stat-num{font-size:17px;font-weight:800;color:var(--gold);}
.cp-stat-label{font-size:9.5px;color:var(--text-dim);margin-top:3px;}

/* ============================================================
   MOVIE DETAILS PAGE
   ============================================================ */
.detail-hero{position:relative;border-radius:0 0 18px 18px;overflow:hidden;min-height:260px;background:#000;margin:0 -20px;}
.detail-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(11,11,13,0.2) 0%, rgba(11,11,13,0.97) 100%);}
.detail-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center top;}
.detail-hero-content{position:relative;z-index:2;display:flex;gap:16px;padding:160px 20px 20px;align-items:flex-end;}
.detail-poster{width:110px;border-radius:10px;overflow:hidden;border:2px solid var(--line);flex-shrink:0;background:#1a1a1f;aspect-ratio:2/3;}
.detail-poster img{width:100%;height:100%;object-fit:cover;}
.detail-title-block{flex:1;min-width:0;}
.detail-title{font-size:22px;font-weight:800;line-height:1.15;margin:0 0 6px;}
.detail-meta{font-size:12.5px;color:var(--text-dim);display:flex;gap:8px;flex-wrap:wrap;align-items:center;}

.detail-actions{display:flex;gap:10px;padding:18px 20px 0;flex-wrap:wrap;}
.rating-pills{display:flex;gap:10px;padding:18px 20px 0;flex-wrap:wrap;}
.rating-pill{background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:10px 14px;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;}
.rating-pill .src{font-size:10.5px;color:var(--text-dim);font-weight:600;}

.overview-block{padding:20px;}
.overview-block h3{font-size:15px;font-weight:800;margin:0 0 8px;}
.overview-block p{font-size:13.5px;color:#cfcfd6;line-height:1.6;margin:0;}

.lang-avail-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px;}
.lang-avail-chip{
  font-size:12px;font-weight:600;padding:5px 10px;border-radius:7px;
  background:var(--bg-card);border:1px solid var(--line);color:var(--text-dim);
}
.lang-avail-chip.audio{color:var(--text);border-color:var(--gold);}
.lang-avail-chip.subtitle{color:var(--text-dim);}
.lang-avail-note{font-size:11px;color:var(--text-faint);line-height:1.5;}

.cast-row{display:flex;gap:14px;overflow-x:auto;padding:4px 20px 8px;scrollbar-width:none;}
.cast-row::-webkit-scrollbar{display:none;}
.cast-chip{flex-shrink:0;width:84px;text-align:center;}
.cast-photo{width:84px;height:84px;border-radius:50%;overflow:hidden;background:#1a1a1f;border:1px solid var(--line);margin-bottom:6px;}
.cast-photo img{width:100%;height:100%;object-fit:cover;}
.cast-name{font-size:11.5px;font-weight:700;line-height:1.3;}
.cast-char{font-size:10.5px;color:var(--text-dim);margin-top:2px;}

.trailer-frame-wrap{padding:0 20px;}
.trailer-frame-wrap iframe{width:100%;aspect-ratio:16/9;border-radius:10px;border:1px solid var(--line);}

/* ============================================================
   BOTTOM NAV (mobile)
   ============================================================ */
.bottomnav{position:fixed;bottom:0;left:0;right:0;background:rgba(11,11,13,0.97);border-top:1px solid var(--line);display:none;justify-content:space-around;padding:8px 0 14px;backdrop-filter:blur(10px);z-index:110;}
.bottomnav a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:11px;color:var(--text-dim);}
.bottomnav a.active{color:var(--gold);}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:880px){
  .stats{grid-template-columns:repeat(3,1fr);}
  .card-row{grid-template-columns:repeat(3,1fr);}
  .card-row.cols-6{grid-template-columns:repeat(3,1fr);}
}
@media (max-width:640px){
  header.topbar{padding:14px 16px;}
  nav.mainnav{padding:10px 16px;gap:20px;}
  main{padding:0 14px 110px;}
  .hero-slide,.hero-skeleton{height:460px;}
  .hero-title{font-size:26px;}
  .stats{grid-template-columns:repeat(3,1fr);}
  .stat-card{padding:13px 6px;}
  .card-row{grid-template-columns:repeat(2,1fr);}
  .card-row.cols-6{grid-template-columns:repeat(2,1fr);}
  .bottomnav{display:flex;}
  .rank-year{display:none;}
  .chat-panel{bottom:0;right:0;border-radius:16px 16px 0 0;max-width:100%;height:80vh;}
  .chat-fab-wrap{bottom:90px;}
  .chat-fab-label{display:none;}
  .detail-hero{margin:0 -14px;}
}
