/* ═══════════════════════════════════════════════════════════
   BET SOLUTION — Theme System (Dark / Light)
   ═══════════════════════════════════════════════════════════ */

:root {
  --bg-primary: #0d1117;
  --bg-secondary: #161b22;
  --bg-card: #1c2128;
  --bg-elevated: #21262d;
  --text-primary: #e6edf3;
  --text-secondary: #8b949e;
  --text-muted: #484f58;
  --accent-gold: #c8a84a;
  --accent-gold-hover: #d4b85a;
  --accent-gold-dim: #8a7530;
  --border: #30363d;
  --border-light: #21262d;
  --shadow: rgba(0,0,0,0.5);
  --input-bg: #0d1117;
  --input-border: #30363d;
  --success: #2ea043;
  --danger: #da3633;
  --info: #1f6feb;
}

[data-theme="light"] {
  --bg-primary: #f8f6f0;
  --bg-secondary: #ffffff;
  --bg-card: #ffffff;
  --bg-elevated: #f0ede5;
  --text-primary: #1a1a1a;
  --text-secondary: #555555;
  --text-muted: #999999;
  --accent-gold: #b8963a;
  --accent-gold-hover: #a88530;
  --accent-gold-dim: #d4c080;
  --border: #e0ddd5;
  --border-light: #e8e5dd;
  --shadow: rgba(0,0,0,0.08);
  --input-bg: #ffffff;
  --input-border: #d0cdc5;
  --success: #1a7f37;
  --danger: #cf222e;
  --info: #0969da;
}

* { margin:0; padding:0; box-sizing:border-box; }

html, body {
  height:100%;
  background:var(--bg-primary);
  color:var(--text-primary);
  font-family:'Inter','Segoe UI',Arial,sans-serif;
  transition:background 0.3s,color 0.3s;
}

/* ── Index / public pages ────────────────────────────── */
body.public-page { overflow-y:auto; }
.public-page #app { min-height:100vh; display:flex; flex-direction:column; }
.main-hero { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:40px 16px; text-align:center; }
.main-hero h1 { font-size:2.5rem; color:var(--accent-gold); margin-bottom:12px; letter-spacing:4px; }
.main-hero p { font-size:1rem; color:var(--text-secondary); margin-bottom:32px; max-width:480px; }
.hero-buttons { display:flex; flex-direction:column; align-items:center; gap:12px; width:100%; max-width:400px; }
.hero-buttons .btn-hero { display:block; width:100%; padding:16px 24px; font-size:1.2rem; font-weight:bold; background:var(--accent-gold); color:var(--bg-primary); border:none; border-radius:8px; cursor:pointer; letter-spacing:2px; text-align:center; white-space:nowrap; transition:opacity 0.15s; }
.hero-buttons .btn-hero:hover { opacity:0.85; }

/* ── Index live stream background ─────────────────────── */
.public-page #app { position:relative; }
.public-page .live-bg { position:absolute; inset:0; z-index:0; display:flex; align-items:center; justify-content:center; background:#000; overflow:hidden; }
.public-page .live-bg-wrap { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.public-page .live-bg-wrap canvas,
.public-page .live-bg-wrap video { width:100%; height:100%; display:block; object-fit:cover; }
.public-page .live-bg-overlay { position:absolute; inset:0; background:rgba(0,0,0,0.55); z-index:1; }
.public-page .live-bg-wrap::after {
  content:''; position:absolute; inset:0; z-index:2; pointer-events:none;
  background: repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(0,0,0,0.08) 2px, rgba(0,0,0,0.08) 4px);
}
.public-page .live-bg-wrap .lb-status { position:absolute; bottom:8px; left:50%; transform:translateX(-50%); background:rgba(0,0,0,0.6); color:rgba(255,255,255,0.5); padding:3px 10px; border-radius:3px; font-size:11px; z-index:2; }
.public-page #global-ui { z-index:2; }
.public-page .main-hero { position:relative; z-index:1; }
.public-page .hidden-menu { z-index:101; }

/* ── Hidden menu (index) ─────────────────────────────── */
.hidden-menu { position:absolute; top:12px; right:16px; z-index:100; }
.hidden-menu .menu-trigger { background:none; border:none; color:var(--accent-gold); font-size:24px; cursor:pointer; padding:4px 8px; }
.hidden-menu .menu-dropdown { position:absolute; right:0; top:36px; background:var(--bg-card); border:1px solid var(--accent-gold-dim); border-radius:6px; display:none; min-width:160px; }
.hidden-menu .menu-dropdown.open { display:block; }
.hidden-menu .menu-dropdown a { display:block; padding:10px 16px; color:var(--text-primary); text-decoration:none; font-size:14px; }
.hidden-menu .menu-dropdown a:hover { background:var(--bg-elevated); color:var(--accent-gold); }

/* ── Scoreboard btn (guest mode) ─────────────────────── */
.scoreboard-btn-wrap { text-align:center; padding:12px; }
.btn-scoreboard { padding:10px 32px; font-size:1rem; font-weight:bold; background:var(--bg-elevated); color:var(--text-primary); border:1px solid var(--border); border-radius:6px; cursor:pointer; }
.btn-scoreboard:hover { background:var(--accent-gold); color:var(--bg-primary); }

/* ── Live page ───────────────────────────────────────── */
body.live-page { overflow-y:auto; }
.live-page #app { display:flex; flex-direction:column; height:100vh; }
#top-bar { display:flex; align-items:center; justify-content:space-between; background:var(--bg-secondary); border-bottom:1px solid var(--border); padding:6px 16px; height:48px; flex-shrink:0; }
#title { font-size:20px; font-weight:bold; color:var(--accent-gold); letter-spacing:2px; }
#lang-dropdown { position:relative; }
#lang-current { background:var(--bg-elevated); color:var(--text-primary); border:1px solid var(--border); padding:4px 10px; font-size:13px; font-weight:bold; cursor:pointer; border-radius:3px; white-space:nowrap; }
#lang-current:hover { background:var(--accent-gold); color:var(--bg-primary); }
.lang-menu-dropdown { display:none; position:absolute; top:32px; left:0; background:var(--bg-card); border:1px solid var(--accent-gold-dim); border-radius:4px; z-index:200; min-width:80px; }
.lang-menu-dropdown.open { display:block; }
.lang-opt { display:block; width:100%; background:none; border:none; color:var(--text-primary); padding:6px 14px; font-size:13px; cursor:pointer; text-align:left; }
.lang-opt:hover { background:var(--bg-elevated); color:var(--accent-gold); }
.lang-opt.active { color:var(--accent-gold); font-weight:bold; }
#top-right { display:flex; align-items:center; gap:8px; }
#menu-btn { background:transparent; color:var(--text-secondary); border:none; font-size:22px; cursor:pointer; padding:0 8px; }
#menu-btn:hover { color:var(--accent-gold); }

/* ── Main content (live, stacked) ────────────────────── */
#main-content { display:flex; flex-direction:column; flex:1; overflow-y:auto; gap:4px; padding:4px; }

/* Stream section — fixed height in customer mode, fills in guest mode */
#live-section { width:100%; position:relative; background:#000; border-radius:4px; overflow:hidden; height:50vh; max-height:450px; flex-shrink:0; }
.stream-wrapper { width:100%; height:100%; display:flex; align-items:center; justify-content:center; }
.stream-wrapper video, .stream-wrapper canvas, #live-canvas { width:100%; height:100%; display:block; object-fit:contain; }
#live-status { position:absolute; bottom:8px; left:8px; background:rgba(0,0,0,0.7); padding:4px 10px; font-size:12px; border-radius:3px; color:var(--text-secondary); }
#balance-float { position:absolute; bottom:8px; right:8px; background:rgba(0,0,0,0.7); padding:5px 12px; font-size:13px; border-radius:4px; color:var(--success); display:none; font-weight:bold; }

/* Not Available overlay */
#not-available-overlay { position:absolute; top:0; left:0; width:100%; height:100%; display:none; align-items:center; justify-content:center; background:rgba(0,0,0,0.85); color:#666; font-size:1.3rem; font-weight:bold; z-index:10; }
#not-available-overlay.show { display:flex; }

/* Guest mode: hide scoreboard, stream fills space */
.guest-mode #scoreboard-section { display:none !important; }
.guest-mode #live-section { flex:1; height:auto; max-height:none; min-height:200px; }

/* ── Mini Scoreboard (theme-independent, scaled via container height) ── */
#scoreboard-section { flex-shrink:0; display:flex; flex-direction:column; gap:3px; height:200px; }
#bead-road-container { flex:0 0 30%; background:#fffdf7; border-radius:3px; overflow:hidden; }
#bead-canvas, #big-canvas, #eye-canvas, #small-canvas, #cock-canvas { width:100%; height:100%; display:block; }
#info-bar { display:flex; gap:4px; flex:0 0 12%; }
#logo-area { flex:0 0 25%; background:#fffdf7; border-radius:3px; }
#info-area { flex:1; background:#fffdf7; border-radius:3px; }
#big-road-container { flex:1; background:#fffdf7; border-radius:3px; overflow:hidden; }
#derived-container { display:flex; gap:3px; flex:0 0 18%; }
#derived-container canvas { flex:1; background:#fffdf7; border-radius:3px; }
#stats-bar { display:flex; gap:4px; flex:0 0 14%; }
#counter-area { flex:1; background:#fffdf7; border-radius:3px; }
#prediction-area { flex:0 0 22%; background:#fffdf7; border-radius:3px; }

/* ── Side menu ───────────────────────────────────────── */
#side-menu { position:fixed; top:0; right:-300px; width:280px; height:100vh; background:var(--bg-card); border-left:2px solid var(--accent-gold-dim); transition:right 0.3s; z-index:999; padding:20px; overflow-y:auto; }
#side-menu.open { right:0; }
#side-menu .close { text-align:right; font-size:24px; cursor:pointer; color:var(--text-muted); }
#side-menu .close:hover { color:var(--accent-gold); }
#side-menu .menu-item { display:block; padding:12px; color:var(--text-primary); text-decoration:none; font-size:15px; border-bottom:1px solid var(--border); }
#side-menu .menu-item:hover { background:var(--bg-elevated); color:var(--accent-gold); }
#overlay { position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.5); z-index:998; display:none; }
#theme-toggle { display:block; width:100%; padding:10px 12px; background:var(--bg-elevated); border:1px solid var(--border); border-radius:6px; color:var(--text-primary); font-size:13px; cursor:pointer; margin-top:12px; text-align:center; }
#theme-toggle:hover { background:var(--accent-gold); color:var(--bg-primary); }

/* ── Bet area (inside popup) ─────────────────────────── */
#bet-area { padding:8px; }
.bet-btns { display:flex; gap:4px; }
.bet-btns button { flex:1; padding:10px; font-weight:bold; border:none; border-radius:6px; cursor:pointer; font-size:14px; }
.bet-bank { background:#cc1111; color:#fff; }
.bet-player { background:#1144cc; color:#fff; }
.bet-tie { background:#00aa44; color:#fff; }
.bet-l6 { background:#d4a800; color:#000; }
.bet-btns button:disabled { opacity:0.5; cursor:not-allowed; }
.bet-input { display:flex; gap:6px; margin-top:6px; align-items:center; }
.bet-input input { flex:1; padding:6px; background:var(--input-bg); border:1px solid var(--input-border); border-radius:4px; color:var(--text-primary); }
.bet-input button { padding:6px 16px; background:var(--accent-gold); border:none; border-radius:4px; font-weight:bold; cursor:pointer; color:var(--bg-primary); }

/* ── Bet popup modal ─────────────────────────────────── */
#bet-popup { position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(0,0,0,0.6); z-index:9999; display:none; align-items:center; justify-content:center; }
#bet-popup.open { display:flex; }
#bet-popup-inner { background:var(--bg-card); border-radius:12px; padding:24px; max-width:420px; width:92%; max-height:85vh; overflow-y:auto; border:1px solid var(--accent-gold-dim); }
#bet-popup-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; font-size:18px; font-weight:bold; color:var(--accent-gold); }
#bet-popup-header button { background:none; border:none; color:var(--text-secondary); font-size:24px; cursor:pointer; padding:0 4px; line-height:1; }
#bet-popup-header button:hover { color:var(--text-primary); }

/* ── Bet button in topbar ────────────────────────────── */
#bet-btn { padding:6px 16px; background:var(--accent-gold); border:none; border-radius:4px; font-weight:bold; font-size:13px; cursor:pointer; color:var(--bg-primary); white-space:nowrap; display:none; }
#bet-btn:hover { background:var(--accent-gold-hover); }

/* ── Floating ads ────────────────────────────────────── */
.ad-float-left, .ad-float-right { position:fixed; top:50%; transform:translateY(-50%); z-index:500; cursor:pointer; }
.ad-float-left { left:0; }
.ad-float-right { right:0; }
@media (max-width:1023px) {
  .ad-float-left, .ad-float-right { display:none; }
}
@media (min-width:1024px) {
  .ad-float-left, .ad-float-right { display:block; }
}
.ad-float-close { position:absolute; top:-12px; right:-12px; background:var(--bg-elevated); color:var(--text-primary); border:1px solid var(--border); border-radius:50%; width:24px; height:24px; font-size:14px; cursor:pointer; z-index:501; display:flex; align-items:center; justify-content:center; }
.ad-float-close:hover { background:var(--danger); color:#fff; }
.ad-footer { width:100%; background:var(--bg-secondary); border-top:2px solid var(--accent-gold-dim); padding:14px 16px; text-align:center; font-size:13px; color:var(--text-muted); flex-shrink:0; letter-spacing:1px; }

/* ── Login page ──────────────────────────────────────── */
.login-page { display:flex; justify-content:center; align-items:center; min-height:100vh; overflow-y:auto; background:var(--bg-primary); }
.login-box { background:var(--bg-card); padding:40px; border-radius:12px; width:400px; max-width:94%; border:1px solid var(--accent-gold-dim); margin:20px; }
.login-box h2 { color:var(--accent-gold); text-align:center; margin-bottom:24px; font-size:24px; }
.login-box label { color:var(--text-secondary); font-size:13px; display:block; margin-bottom:4px; }
.login-box input { width:100%; padding:10px; margin-bottom:16px; background:var(--input-bg); border:1px solid var(--input-border); border-radius:6px; color:var(--text-primary); font-size:14px; }
.login-box input:focus { outline:none; border-color:var(--accent-gold); }
.login-box button { width:100%; padding:12px; background:var(--accent-gold); color:var(--bg-primary); font-weight:bold; border:none; border-radius:6px; font-size:16px; cursor:pointer; }
.login-box button:hover { background:var(--accent-gold-hover); }
.login-box .switch { text-align:center; margin-top:16px; color:var(--text-muted); font-size:13px; cursor:pointer; }
.login-box .switch:hover { color:var(--accent-gold); }
.login-box .error { color:var(--danger); font-size:13px; text-align:center; margin-bottom:8px; display:none; }
.login-box .tab { display:flex; margin-bottom:20px; }
.login-box .tab div { flex:1; text-align:center; padding:8px; color:var(--text-muted); font-weight:bold; cursor:pointer; border-bottom:2px solid var(--border); }
.login-box .tab div.active { color:var(--accent-gold); border-bottom-color:var(--accent-gold); }

/* ── Scoreboard page ─────────────────────────────────── */
.scoreboard-page { overflow-y:auto; background:var(--bg-primary); }
.sb-container { max-width:1000px; margin:0 auto; padding:24px 16px; }
.sb-container h1 { color:var(--accent-gold); text-align:center; margin-bottom:20px; }
.sb-table { width:100%; border-collapse:collapse; margin-bottom:20px; }
.sb-table th, .sb-table td { padding:8px 12px; text-align:center; border-bottom:1px solid var(--border); font-size:14px; }
.sb-table th { background:var(--bg-elevated); color:var(--accent-gold); }
.sb-table tr:hover { background:var(--bg-card); }
.sb-table .win-b { color:#cc1111; font-weight:bold; }
.sb-table .win-p { color:#1144cc; font-weight:bold; }
.sb-table .win-t { color:#00aa44; font-weight:bold; }
.sb-back { display:inline-block; margin-bottom:16px; color:var(--accent-gold); text-decoration:none; font-weight:bold; }
.sb-back:hover { text-decoration:underline; }

/* ── Global top-left bar (for pages without own header) ─ */
#global-ui { position:fixed; top:6px; left:6px; z-index:1000; display:flex; gap:4px; align-items:center; }

/* ── Theme toggle icon ───────────────────────────────── */
.theme-toggle-btn { background:var(--bg-elevated); border:1px solid var(--border); color:var(--accent-gold); width:32px; height:32px; border-radius:50%; cursor:pointer; font-size:15px; display:flex; align-items:center; justify-content:center; padding:0; line-height:1; transition:background 0.2s; }
.theme-toggle-btn:hover { background:var(--accent-gold); color:var(--bg-primary); }

/* `inline-theme` variant for use inside existing top-bars */
.theme-toggle-btn.inline-theme { width:28px; height:28px; font-size:13px; background:transparent; border-color:var(--accent-gold-dim); }
.theme-toggle-btn.inline-theme:hover { background:var(--accent-gold); color:var(--bg-primary); }

/* ── Responsive ──────────────────────────────────────── */
@media (max-width:767px) {
  #live-section { height:35vh; max-height:300px; }
  #scoreboard-section { height:150px; }
  .main-hero h1 { font-size:1.6rem; }
  .hero-buttons .btn-hero { padding:12px 16px; font-size:0.9rem; }
  .sb-table th, .sb-table td { padding:4px 6px; font-size:12px; }
}

@media (min-width:768px) {
  #scoreboard-section { height:180px; }
  .main-hero h1 { font-size:2.2rem; }
  .hero-buttons { max-width:360px; }
}

@media (min-width:1024px) {
  #scoreboard-section { height:200px; }
  .main-hero h1 { font-size:2.5rem; }
}

/* ── Management Sidebar ── */
#mgm-sidebar { position:fixed; top:0; left:-260px; width:240px; height:100vh; background:var(--bg-card); border-right:2px solid var(--accent-gold-dim); transition:left 0.3s; z-index:999; padding:16px; overflow-y:auto; }
#mgm-sidebar.open { left:0; }
#mgm-sidebar .close { text-align:right; font-size:22px; cursor:pointer; color:var(--text-muted); }
#mgm-sidebar .close:hover { color:var(--accent-gold); }
#mgm-sidebar .user-info { color:var(--accent-gold); font-size:13px; margin:8px 0; padding-bottom:8px; border-bottom:1px solid var(--border); }
#mgm-sidebar a { display:block; padding:10px 12px; color:var(--text-primary); text-decoration:none; font-size:14px; border-bottom:1px solid var(--border); }
#mgm-sidebar a:hover { background:var(--bg-elevated); color:var(--accent-gold); }
#mgm-sidebar a.logout-link { color:#c44; margin-top:12px; border-top:1px solid var(--border); }
#mgm-overlay { position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.5); z-index:998; display:none; }