/* ═══════════════════════════════════════════════════════════
   CHAMPCHASE — SHARED STYLES
   Canonical variables, reset, and components used on ALL pages
   ═══════════════════════════════════════════════════════════ */

/* ═══ CSS VARIABLES ═══ */
:root{
  --bg:#09090b;--bg2:#111115;--bg3:#18181e;
  --cherry:#B91C1C;--cherry-l:#DC2626;--cherry-g:rgba(185,28,28,.3);--cherry-glow:rgba(185,28,28,.6);
  --gold:#F5C518;--gold-d:#C9A30A;--gold-g:rgba(245,197,24,.3);
  --green:#22c55e;--blue:#3b82f6;--purple:#a855f7;
  --w:#F5F5F0;--w2:#C8C8BE;--g:#9CA3AF;--dg:#2A2A32;
  --px:'Press Start 2P',monospace;--dp:'Bebas Neue',sans-serif;--bd:'Source Sans 3',sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);--bounce:cubic-bezier(.34,1.56,.64,1);
}

/* ═══ RESET ═══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
img,video,svg{max-width:100%;height:auto}

/* ═══ BASE ═══ */
html{scroll-behavior:smooth;-webkit-overflow-scrolling:touch;overflow-x:hidden;max-width:100vw}
body{background:var(--bg);color:var(--w);font-family:var(--bd);line-height:1.6;overflow-x:hidden;max-width:100vw}

/* ═══ FONT SMOOTHING ═══ */
*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* ═══ FOCUS VISIBLE ═══ */
*:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

/* ═══ UTILITIES ═══ */
.pixel{font-family:var(--px)}
.gold{color:var(--gold)}
.red{color:var(--cherry-l);font-weight:700}
.ctr{max-width:1200px;margin:0 auto;padding:0 24px;position:relative;z-index:2}

/* ═══ BUTTONS ═══ */
.btn{display:inline-block;padding:14px 28px;font-family:var(--dp);font-size:18px;letter-spacing:2px;text-decoration:none;border:none;cursor:pointer;transition:all .3s var(--ease);border-radius:3px;position:relative}
.btn:hover{transform:translateY(-2px) scale(1.05)}
.btn:active{transform:scale(.97);transition:transform .1s}
.primary{background:var(--cherry);color:var(--w);animation:heartbeat 3s ease-in-out infinite}
.primary:hover{background:var(--cherry-l);box-shadow:0 6px 30px var(--cherry-glow);animation:none}
@keyframes heartbeat{0%,100%{transform:scale(1)}50%{transform:scale(1.02)}}
.ghost{background:transparent;color:var(--gold);border:2px solid var(--gold-d)}
.ghost:hover{border-color:var(--gold);background:rgba(245,197,24,.06);box-shadow:0 6px 30px var(--gold-g)}

/* ═══ AUDIO BAR ═══ */
.audio-bar{position:fixed;bottom:0;left:0;right:0;height:44px;background:rgba(9,9,11,.97);backdrop-filter:blur(12px);border-top:1px solid var(--dg);display:flex;align-items:center;padding:0 12px;padding-bottom:env(safe-area-inset-bottom,0);gap:8px;z-index:1000}
.audio-toggle{background:none;border:1px solid var(--dg);color:var(--w);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .3s var(--ease)}
.audio-toggle:hover,.audio-toggle.playing{border-color:var(--cherry);background:var(--cherry);transform:scale(1.1)}
.audio-toggle:active{transform:scale(.95)}
.now-playing{display:none}
.mood-selector{display:flex;align-items:center;gap:6px;flex:1;overflow:visible;min-width:0}
.mood-label{font-family:var(--px);font-size:7px;color:var(--g);letter-spacing:2px;flex-shrink:0}
.mood-chips{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;padding:3px 0}
.mood-chips::-webkit-scrollbar{display:none}
.mood-chip{padding:5px 12px;font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;background:var(--bg3);border:1px solid #3a3a44;color:var(--w2);border-radius:16px;cursor:pointer;white-space:nowrap;transition:all .3s var(--ease);flex-shrink:0;position:relative}
.mood-chip:hover{border-color:var(--gold);color:var(--w)}
.mood-chip.active{background:var(--gold);border-color:var(--gold);color:var(--bg);font-weight:700;box-shadow:0 0 12px var(--gold-g)}
.mood-tip{position:absolute;bottom:100%;left:50%;transform:translateX(-50%);background:var(--bg);border:1px solid var(--dg);padding:4px 10px;border-radius:4px;font-size:9px;color:var(--w2);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s;margin-bottom:6px}
.mood-chip:hover .mood-tip{opacity:1}
.audio-collapse-btn{display:none}
.audio-collapse-btn.expanded{transform:rotate(180deg)}
.volume-slider{-webkit-appearance:none;width:60px;height:3px;border-radius:2px;background:var(--dg);outline:none;flex-shrink:0}
.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--cherry);cursor:pointer}
.volume-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--cherry);cursor:pointer;border:none}
.audio-tagline{display:none;margin:0;padding:0}

/* ═══ VISUALIZER ═══ */
.visualizer{position:fixed;bottom:44px;left:0;right:0;height:3px;z-index:999;display:flex;gap:1px;pointer-events:none}
.viz-bar{flex:1;background:var(--cherry);transform-origin:bottom;transform:scaleY(0);transition:transform .05s}

/* ═══ TOAST NOTIFICATIONS ═══ */
.toast{position:fixed;top:20px;right:20px;background:var(--bg3);border:1px solid var(--gold);padding:12px 20px;border-radius:4px;z-index:9995;font-size:13px;color:var(--w);display:flex;align-items:center;gap:8px;animation:toastIn .4s var(--bounce),toastOut .4s 2.6s var(--ease) forwards;backdrop-filter:blur(8px)}
.toast .toast-icon{font-size:18px}
@keyframes toastIn{from{transform:translateX(120px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes toastOut{to{transform:translateX(120px);opacity:0}}

/* ═══ SCROLL TO TOP ═══ */
.scroll-top-btn{position:fixed;bottom:64px;right:24px;width:44px;height:44px;border-radius:50%;background:var(--cherry);color:var(--w);border:none;font-size:20px;cursor:pointer;z-index:999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease,transform .2s;box-shadow:0 4px 16px rgba(0,0,0,.4)}
.scroll-top-btn.show{opacity:1;pointer-events:auto}
.scroll-top-btn:hover{transform:scale(1.1)}

/* ═══ PAGE TRANSITION ═══ */
.page-fade-out{opacity:0;transition:opacity .3s ease}

/* ═══ LIVE STATS ═══ */
.live-stat{font-family:var(--px);font-size:12px;color:var(--gold);text-align:center;margin-top:12px;letter-spacing:1px;opacity:.8}

/* ═══ SHARED NAV BAR ═══ */
.cc-nav{position:fixed;top:0;left:0;right:0;height:50px;background:rgba(9,9,11,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--dg);display:flex;align-items:center;padding:0 20px;z-index:9998;gap:12px}
.cc-nav-brand{font-family:var(--px);font-size:10px;color:var(--gold);text-decoration:none;letter-spacing:2px;flex-shrink:0;transition:color .2s}
.cc-nav-brand:hover{color:var(--cherry-l)}
.cc-nav-links{display:flex;gap:4px;align-items:center;margin-left:auto}
.cc-nav-link{font-family:var(--dp);font-size:14px;letter-spacing:2px;color:var(--g);text-decoration:none;padding:6px 12px;border-radius:3px;transition:all .2s var(--ease);background:none;border:none;cursor:pointer;white-space:nowrap}
.cc-nav-link:hover{color:var(--w)}
.cc-nav-link.active{color:var(--gold);border-bottom:2px solid var(--gold)}
.cc-nav-social{display:flex;gap:8px;align-items:center;margin-left:12px;flex-shrink:0}
.cc-nav-social a{color:var(--dg);text-decoration:none;font-size:14px;transition:color .2s}
.cc-nav-social a:hover{color:var(--gold)}
.cc-nav-eq{display:flex;gap:2px;align-items:flex-end;height:20px;margin-left:8px;flex-shrink:0}
.cc-nav-eq-bar{width:3px;background:var(--gold);border-radius:1px;transition:height .15s ease;min-height:3px}
.cc-nav-track{font-size:9px;color:var(--g);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px;margin-left:8px;flex-shrink:1}
.cc-nav-mute{background:none;border:1px solid var(--dg);color:var(--g);width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.cc-nav-mute:hover{border-color:var(--gold);color:var(--gold)}
.cc-nav-mute.muted{color:var(--cherry-l);border-color:var(--cherry)}
/* Hamburger toggle (mobile) */
.cc-nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:4px;flex-shrink:0}
.cc-nav-toggle span{display:block;width:20px;height:2px;background:var(--w);margin:4px 0;transition:all .3s var(--ease);border-radius:1px}
.cc-nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.cc-nav-toggle.open span:nth-child(2){opacity:0}
.cc-nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* ═══ SCROLL PROGRESS BAR ═══ */
.cc-scroll-bar{position:fixed;top:0;left:0;height:3px;z-index:9999;background:linear-gradient(to right,var(--cherry),var(--gold));width:0;transition:width .1s linear;pointer-events:none}

/* ═══ STORY TICKER ═══ */
.cc-ticker{position:fixed;top:50px;left:0;right:0;height:28px;background:rgba(9,9,11,.95);border-bottom:1px solid rgba(42,42,50,.5);z-index:9997;overflow:hidden;display:flex;align-items:center}
.cc-ticker-inner{display:flex;gap:40px;animation:tickerScroll 60s linear infinite;white-space:nowrap;padding-left:100%}
.cc-ticker-inner:hover{animation-play-state:paused}
.cc-ticker-item{font-size:11px;color:var(--g);text-decoration:none;transition:color .2s;flex-shrink:0;cursor:pointer}
.cc-ticker-item:hover{color:var(--gold)}
@keyframes tickerScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ═══ COOKIE CONSENT ═══ */
.cc-cookie{position:fixed;bottom:70px;left:50%;transform:translateX(-50%);background:var(--bg3);border:1px solid var(--dg);border-radius:8px;padding:16px 24px;z-index:1001;display:flex;align-items:center;gap:16px;max-width:600px;width:calc(100% - 40px);backdrop-filter:blur(12px);animation:toastIn .4s var(--bounce)}
.cc-cookie-text{font-size:13px;color:var(--w2);line-height:1.5}
.cc-cookie-text strong{color:var(--gold)}
.cc-cookie-btn{font-family:var(--px);font-size:9px;padding:8px 16px;background:var(--cherry);color:var(--w);border:none;border-radius:3px;cursor:pointer;letter-spacing:1px;white-space:nowrap;transition:all .2s}
.cc-cookie-btn:hover{background:var(--cherry-l);transform:scale(1.05)}
.cc-cookie-dismiss{font-size:11px;color:var(--g);background:none;border:none;cursor:pointer;white-space:nowrap;transition:color .2s}
.cc-cookie-dismiss:hover{color:var(--w)}
.cc-cookie.dismiss{animation:toastOut .3s var(--ease) forwards}

/* ═══ NIGHT MODE ═══ */
html.night-mode{--bg:#000;--bg2:#050505;--bg3:#0a0a0a;--dg:#1a1a22}
html.night-mode img:not(.loot-item-img):not(.loot-box){filter:brightness(.85)}
.cc-night-icon{font-size:14px;cursor:pointer}

/* ═══ PAGE TRANSITION OVERLAY ═══ */
.cc-transition{position:fixed;inset:0;background:var(--bg);z-index:10001;opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.cc-transition.active{opacity:1;pointer-events:all}

/* ═══ PRELOADER ═══ */
.cc-preloader{position:fixed;inset:0;z-index:10002;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:24px;padding:24px}
.cc-preloader-title{font-family:var(--px);font-size:clamp(16px,4vw,28px);color:var(--gold);letter-spacing:3px;text-shadow:0 0 30px var(--gold-g)}
.cc-preloader-bar{width:min(300px,80vw);height:4px;background:var(--dg);border-radius:2px;overflow:hidden}
.cc-preloader-fill{height:100%;background:linear-gradient(to right,var(--cherry),var(--gold));border-radius:2px;transition:width .3s ease;width:0}
.cc-preloader-msg{font-family:var(--dp);font-size:16px;color:var(--g);letter-spacing:2px}
.cc-preloader-tip{font-size:13px;color:var(--w2);text-align:center;max-width:400px;line-height:1.6;opacity:.7;transition:opacity .3s ease}
.cc-preloader-notice{font-size:11px;color:var(--g);text-align:center;max-width:420px;line-height:1.6;opacity:.5;margin-top:8px;font-style:italic}
.cc-preloader-pct{font-family:var(--px);font-size:11px;color:var(--gold);letter-spacing:1px}
.cc-preloader.done{opacity:0;pointer-events:none;transition:opacity .5s var(--ease)}

/* ═══ FOOTER ═══ */
.cc-footer{background:var(--bg2);border-top:1px solid var(--dg);padding:48px 24px 100px;text-align:center}
.cc-footer-brand{font-family:var(--px);font-size:12px;color:var(--gold);letter-spacing:3px;margin-bottom:12px}
.cc-footer-tag{font-family:var(--dp);font-size:18px;color:var(--w2);letter-spacing:2px;margin-bottom:8px}
.cc-footer-honest{font-size:13px;color:var(--w2);line-height:1.6;max-width:600px;margin:0 auto 24px;font-style:italic}
.cc-footer-built{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.cc-footer-built span{font-size:11px;color:var(--w2);padding:4px 10px;border:1px solid var(--dg);border-radius:12px;transition:color .2s,border-color .2s}
.cc-footer-built span:hover{color:var(--gold);border-color:var(--gold)}
.cc-footer-links{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.cc-footer-links a{font-size:12px;color:var(--w2);text-decoration:none;transition:color .2s;letter-spacing:1px}
.cc-footer-links a:hover{color:var(--gold)}
.cc-footer-social{display:flex;gap:16px;justify-content:center;margin-bottom:16px}
.cc-footer-social a{color:var(--w2);text-decoration:none;font-size:18px;transition:color .2s}
.cc-footer-social a:hover{color:var(--gold)}
.cc-footer-easter{font-size:10px;color:var(--g);margin-bottom:8px;letter-spacing:1px}
.cc-footer-legal{font-size:10px;color:var(--g);letter-spacing:1px}
.cc-footer-bmc{margin-bottom:12px}
.cc-footer-bmc a{font-size:12px;color:var(--gold-d);text-decoration:none;transition:color .2s}
.cc-footer-bmc a:hover{color:var(--gold)}

/* ═══ VISITOR STREAK ═══ */
.cc-streak-badge{position:fixed;top:60px;right:16px;font-family:var(--px);font-size:8px;color:var(--gold);letter-spacing:1px;z-index:9996;opacity:.6;pointer-events:none;animation:fadeIn .5s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(-10px)}to{opacity:.6;transform:translateY(0)}}

/* ═══ MOBILE RESPONSIVE (SHARED COMPONENTS) ═══ */
@media(max-width:768px){
  .cc-nav{height:44px;padding:0 12px}
  .cc-nav-toggle{display:block}
  .cc-nav-links{position:fixed;top:44px;left:0;right:0;background:rgba(9,9,11,.97);backdrop-filter:blur(12px);flex-direction:column;padding:12px;border-bottom:1px solid var(--dg);display:none}
  .cc-nav-links.open{display:flex}
  .cc-nav-link{padding:10px 16px;font-size:16px}
  .cc-nav-eq{display:none}
  .cc-nav-track{display:none}
  .cc-ticker{top:44px;height:24px}
  .cc-ticker-item{font-size:10px}
  .cc-cookie{flex-direction:column;text-align:center;bottom:90px}
  .cc-footer{padding:36px 16px 100px}
  .cc-footer-built{gap:6px}

  /* Toast: slide down on mobile instead of from the right (120px pushes off narrow screens) */
  .toast{top:56px;right:12px;left:12px;max-width:none;animation:toastInMobile .4s var(--bounce),toastOutMobile .4s 2.6s var(--ease) forwards}
  @keyframes toastInMobile{from{transform:translateY(-30px);opacity:0}to{transform:translateY(0);opacity:1}}
  @keyframes toastOutMobile{to{transform:translateY(-30px);opacity:0}}

  /* Audio bar: 2-row layout on mobile. Mood chips visible by default. */
  .audio-bar{height:auto;min-height:60px;flex-direction:column;align-items:stretch;padding:6px 10px;padding-bottom:max(8px,env(safe-area-inset-bottom,8px));gap:4px}
  .audio-bar-row1{display:flex;align-items:center;gap:8px;height:34px;flex-shrink:0}
  .audio-toggle{width:32px;height:32px;flex-shrink:0}
  .now-playing{display:none}
  .mood-selector{display:flex;flex:1;min-width:0;overflow:visible;height:34px;align-items:center}
  .mood-label{display:none}
  .audio-tagline{display:block;font-family:var(--px);font-size:6px;color:var(--gold);letter-spacing:2px;text-align:center;margin:0;padding:2px 0;opacity:.7;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .mood-chips{display:flex;gap:6px;padding:2px 4px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;touch-action:pan-x}
  .mood-chips::-webkit-scrollbar{display:none}
  .mood-chip{padding:6px 12px;font-size:10px;min-height:28px;touch-action:manipulation;flex-shrink:0}
  .volume-slider{display:none}
  .audio-collapse-btn{display:none !important}
  .visualizer{bottom:calc(60px + env(safe-area-inset-bottom,0px))}

  /* Button stacking on top of the audio bar */
  .scroll-top-btn{bottom:calc(72px + env(safe-area-inset-bottom,0px));right:16px;width:40px;height:40px;font-size:18px}
}

@media(max-width:480px){
  .ctr{padding:0 16px}
  .audio-bar{padding:0 8px;gap:4px}
  .now-playing{display:none}
  .mood-chip{padding:5px 10px;font-size:9px}
}

/* ═══ REDUCED MOTION ═══ */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important}
  .cc-ticker-inner{animation:none}
}
