/* ─── CSS VARIABLES ──────────────────────────────────────────────────────────── */
:root {
  --glass:          rgba(11, 15, 26, 0.58);
  --glass-heavy:    rgba(6, 9, 18, 0.78);
  --glass-blur:     blur(28px) saturate(1.9) brightness(1.04);
  --glass-blur-sm:  blur(16px) saturate(1.7);
  --glass-blur-lg:  blur(48px) saturate(2.2) brightness(1.06);
  --border:         rgba(255, 255, 255, 0.075);
  --specular:       rgba(255, 255, 255, 0.10);
  --shadow-sm:      0 1px 0 rgba(255,255,255,0.08) inset, 0 4px 20px rgba(0,0,0,0.45);
  --shadow-md:      0 1px 0 rgba(255,255,255,0.09) inset, 0 8px 36px rgba(0,0,0,0.55);
  --shadow-lg:      0 1px 0 rgba(255,255,255,0.10) inset, 0 20px 72px rgba(0,0,0,0.70);
  --accent:         #f97316;
  --accent-dim:     rgba(249, 115, 22, 0.15);
  --text:           #f1f5f9;
  --text-muted:     #64748b;
  --bg:             #050709;
  --r-sm:           8px;
  --r-md:           13px;
  --r-lg:           17px;
  --r-xl:           22px;
}

/* ─── RESET & BASE ───────────────────────────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box;}
body{
  background: var(--bg);
  background-image:
    radial-gradient(ellipse 900px 560px at 12% 0%,   rgba(249,115,22,0.08) 0%, transparent 65%),
    radial-gradient(ellipse 700px 500px at 88% 90%,  rgba(249,115,22,0.05) 0%, transparent 60%),
    radial-gradient(ellipse 500px 350px at 55% 45%,  rgba(249,115,22,0.03) 0%, transparent 55%);
  color: var(--text);
  font-family: 'DM Sans','Segoe UI',sans-serif;
  min-height: 100vh;
}
button,input,textarea,select{font-family:inherit;}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent)!important;box-shadow:0 0 0 3px rgba(249,115,22,0.12)!important;}
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08);border-radius:2px;}
textarea{resize:vertical;}
a{text-decoration:none;color:inherit;}

/* ─── ANIMATIONS ─────────────────────────────────────────────────────────────── */
@keyframes pulse     {0%,100%{opacity:1}50%{opacity:0.3}}
@keyframes fadeIn    {from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin      {to{transform:rotate(360deg)}}
@keyframes glassIn   {from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes onlinePulse{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}50%{box-shadow:0 0 0 4px rgba(34,197,94,0)}}

/* ─── NAV ────────────────────────────────────────────────────────────────────── */
#nav{
  background: var(--glass-heavy);
  backdrop-filter: var(--glass-blur-lg);
  -webkit-backdrop-filter: var(--glass-blur-lg);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 1px 0 var(--specular) inset, 0 4px 28px rgba(0,0,0,0.5), 0 0 60px rgba(249,115,22,0.04);
  padding: 0 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 54px;
  position: sticky;
  top: 0;
  z-index: 50;
}
.nav-logo{display:flex;align-items:center;cursor:pointer;text-decoration:none;flex-shrink:0;}
.nav-logo-img{height:36px;width:auto;object-fit:contain;display:block;image-rendering:-webkit-optimize-contrast;}
.nav-links{display:flex;gap:2px;}
.nav-btn{
  padding:5px 11px;border-radius:7px;border:none;
  font-size:12px;background:transparent;color:var(--text-muted);cursor:pointer;
  transition:color .15s, background .15s;
}
.nav-btn:hover{color:var(--text);background:rgba(255,255,255,0.05);}
.nav-btn.active{
  background: var(--accent-dim);
  color: var(--accent);
  font-weight:700;
  box-shadow: 0 0 12px rgba(249,115,22,0.15);
}
.nav-right{display:flex;gap:7px;align-items:center;}
.user-chip{
  display:flex;align-items:center;gap:6px;
  padding:2px 9px 2px 4px;
  background: rgba(255,255,255,0.05);
  backdrop-filter: var(--glass-blur-sm);
  border-radius:20px;
  border: 1px solid var(--border);
  box-shadow: 0 1px 0 var(--specular) inset;
}

/* ─── MOBILE MENU ────────────────────────────────────────────────────────────── */
/* ─── HAMBURGER BUTTON ───────────────────────────────────────────────────────── */
.hamburger{
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 7px 9px;
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  transition: border-color .18s, box-shadow .18s, background .18s;
  position: relative;
  overflow: hidden;
}
.hamburger::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.08) 0%,transparent 60%);
  pointer-events:none;
}
.hamburger:hover{
  border-color: var(--accent);
  box-shadow: 0 0 14px rgba(249,115,22,0.22), 0 1px 0 rgba(255,255,255,0.1) inset;
  background: rgba(249,115,22,0.06);
}
.hamburger.open{
  border-color: rgba(249,115,22,0.4);
  background: rgba(249,115,22,0.08);
  box-shadow: 0 0 16px rgba(249,115,22,0.2);
}

/* Bars → smooth X with spring feel */
.ham-bar{
  display: block;
  width: 16px; height: 2px;
  background: var(--text);
  border-radius: 2px;
  transform-origin: center;
  transition:
    transform  .32s cubic-bezier(.34,1.56,.64,1),
    opacity    .2s  ease,
    width      .22s cubic-bezier(.34,1.56,.64,1),
    background .2s  ease;
}
.hamburger.open .bar1{ transform: translateY(7px) rotate(45deg);  background: var(--accent); }
.hamburger.open .bar2{ opacity: 0; width: 0; transform: scaleX(0); }
.hamburger.open .bar3{ transform: translateY(-7px) rotate(-45deg); background: var(--accent); }

/* ─── MOBILE MENU — true translateY slide ────────────────────────────────────── */
#mobile-menu{
  position: fixed;
  top: 54px;
  left: 0;
  right: 0;
  background: rgba(6,9,18,0.97);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
  z-index: 49;
  overflow: hidden;
  padding: .9rem;
  pointer-events: none;
  visibility: hidden;
  opacity: 0;
  transform: translateY(-6px);
  transition:
    opacity    .18s ease,
    transform  .2s  cubic-bezier(.4,0,.2,1),
    visibility 0s   linear .2s;
}
#mobile-menu.open{
  pointer-events: auto;
  visibility: visible;
  opacity: 1;
  transform: translateY(0);
  will-change: transform, opacity;
  transition:
    opacity    .16s ease,
    transform  .18s cubic-bezier(.4,0,.2,1),
    visibility 0s   linear 0s;
}

.m-nav-btn{
  display: block;
  width: 100%;
  padding: 10px 12px;
  border-radius: 9px;
  border: none;
  font-size: 13px;
  background: transparent;
  color: var(--text);
  cursor: pointer;
  text-align: left;
  margin-bottom: 3px;
  transition: background .15s, color .15s;
}

.m-nav-btn:hover{ background: rgba(255,255,255,0.05); }
.m-nav-btn.active{
  background: var(--accent-dim);
  color: var(--accent);
  font-weight: 700;
  border-left: 2px solid var(--accent);
  padding-left: 10px;
}

/* ─── PAGE WRAPPER ───────────────────────────────────────────────────────────── */
#app{opacity:1;}
.page{max-width:960px;margin:0 auto;padding:2rem 1.25rem;animation:fadeIn .25s ease forwards;}

/* ─── LOADING ────────────────────────────────────────────────────────────────── */
.spinner{
  width:32px;height:32px;
  border:2px solid rgba(255,255,255,0.08);
  border-top-color:var(--accent);
  border-radius:50%;
  animation:spin .7s linear infinite;
  margin:4rem auto;
  box-shadow: 0 0 20px rgba(249,115,22,0.15);
}
/* ─── SPLASH LOADING SCREEN ─────────────────────────────────────────────────── */
.loading-screen{
  position:fixed;inset:0;
  background:#050709;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  z-index:9999;
  transition:opacity .45s ease;
}
.loading-screen.dismissing{ opacity:0; pointer-events:none; }

/* Radial glow behind logo */
.splash-glow{
  position:absolute;
  width:320px;height:320px;
  background:radial-gradient(circle, rgba(249,115,22,0.18) 0%, rgba(249,115,22,0.06) 45%, transparent 70%);
  border-radius:50%;
  animation: splashPulse 2s ease-in-out infinite;
}
@keyframes splashPulse{
  0%,100%{ transform:scale(1);   opacity:.8; }
  50%    { transform:scale(1.12);opacity:1;  }
}

/* Logo container */
.splash-logo{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  animation: splashLogoIn .6s cubic-bezier(.34,1.56,.64,1) forwards;
  opacity:0;
  animation-delay:.1s;
}
@keyframes splashLogoIn{
  from{ opacity:0; transform:scale(.82) translateY(12px); }
  to  { opacity:1; transform:scale(1)   translateY(0);    }
}

/* Progress bar */
.splash-bar-wrap{
  position:relative;z-index:1;
  width:160px;height:3px;
  background:rgba(255,255,255,.07);
  border-radius:2px;
  overflow:hidden;
  margin-top:28px;
  animation: splashLogoIn .4s ease forwards;
  animation-delay:.3s;
  opacity:0;
}
.splash-bar{
  height:100%;width:0%;
  background:linear-gradient(90deg,#ea6c0a,#f97316,#fbbf24);
  border-radius:2px;
  animation: splashProgress 2.8s cubic-bezier(.4,0,.2,1) forwards;
  animation-delay:.4s;
}
@keyframes splashProgress{
  0%  { width:0%;  }
  30% { width:45%; }
  60% { width:72%; }
  85% { width:90%; }
  100%{ width:100%;}
}

/* Pulsing dots */
.splash-dots{
  position:relative;z-index:1;
  display:flex;gap:5px;margin-top:12px;
  animation: splashLogoIn .4s ease forwards;
  animation-delay:.4s;
  opacity:0;
}
.splash-dots span{
  width:5px;height:5px;border-radius:50%;
  background:rgba(249,115,22,.35);
  animation: splashDot 1.2s ease-in-out infinite;
}
.splash-dots span:nth-child(2){ animation-delay:.2s; }
.splash-dots span:nth-child(3){ animation-delay:.4s; }
@keyframes splashDot{
  0%,100%{ background:rgba(249,115,22,.2);  transform:scale(.8);  }
  50%    { background:rgba(249,115,22,.85); transform:scale(1.2); }
}

/* ─── BUTTONS ────────────────────────────────────────────────────────────────── */
.btn{border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .15s;display:inline-flex;align-items:center;gap:6px;}
.btn:hover{transform:translateY(-1px);}
.btn:active{transform:translateY(0);}
.btn-sm{padding:5px 13px;font-size:11px;}
.btn-md{padding:8px 18px;font-size:13px;}
.btn-lg{padding:10px 22px;font-size:14px;}
.btn-primary{
  background: linear-gradient(135deg, #f97316, #ea6c0a);
  color:#fff;border:none;
  box-shadow: 0 0 20px rgba(249,115,22,0.35), 0 2px 8px rgba(0,0,0,0.3);
}
.btn-primary:hover{box-shadow:0 0 28px rgba(249,115,22,0.5), 0 4px 12px rgba(0,0,0,0.3);}
.btn-outline{
  background: rgba(255,255,255,0.04);
  color:var(--text-muted);
  border:1px solid var(--border);
}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);}
.btn-green{background:rgba(34,197,94,.1);color:#22c55e;border:1px solid rgba(34,197,94,.3);}
.btn-danger{background:rgba(239,68,68,.08);color:#ef4444;border:1px solid rgba(239,68,68,.25);}
.btn-google{
  width:100%;padding:10px;border-radius:10px;
  border:1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.96);
  color:#1f2937;font-size:13px;font-weight:600;
  display:flex;align-items:center;justify-content:center;gap:10px;
  cursor:pointer;transition:all .15s;
  box-shadow: 0 2px 12px rgba(0,0,0,0.3), 0 1px 0 rgba(255,255,255,0.8) inset;
}
.btn-google:hover{background:#fff;box-shadow:0 4px 20px rgba(0,0,0,0.35);}

/* ─── STATUS PILLS ───────────────────────────────────────────────────────────── */
.pill{
  display:inline-flex;align-items:center;gap:5px;border-radius:20px;
  padding:3px 9px;font-size:10px;font-weight:700;letter-spacing:.06em;
  border:1px solid transparent;
}
.pill-live     {background:rgba(239,68,68,.14) ;color:#ef4444;border-color:rgba(239,68,68,.3);}
.pill-upcoming {background:rgba(249,115,22,.12);color:#f97316;border-color:rgba(249,115,22,.3);}
.pill-completed{background:rgba(100,116,139,.12);color:#64748b;border-color:rgba(100,116,139,.28);}
.pill-open     {background:rgba(34,197,94,.12) ;color:#22c55e;border-color:rgba(34,197,94,.3);}
.pill-closed   {background:rgba(100,116,139,.12);color:#64748b;border-color:rgba(100,116,139,.28);}
.pill-full     {background:rgba(239,68,68,.12) ;color:#ef4444;border-color:rgba(239,68,68,.3);}
.pill-pending  {background:rgba(251,191,36,.12);color:#fbbf24;border-color:rgba(251,191,36,.3);}
.pill-confirmed{background:rgba(34,197,94,.12) ;color:#22c55e;border-color:rgba(34,197,94,.3);}
.pill-rejected {background:rgba(239,68,68,.12) ;color:#ef4444;border-color:rgba(239,68,68,.3);}
.live-dot{width:6px;height:6px;border-radius:50%;background:#ef4444;animation:pulse 1.2s infinite;display:inline-block;flex-shrink:0;box-shadow:0 0 6px rgba(239,68,68,0.6);}

/* ─── POSITION BADGES ────────────────────────────────────────────────────────── */
.pos-badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:9px;font-weight:700;letter-spacing:.05em;white-space:nowrap;}
.pos-Roamer {background:rgba(168,85,247,.14);color:#a855f7;border:1px solid rgba(168,85,247,.28);}
.pos-Gold   {background:rgba(251,191,36,.14);color:#fbbf24;border:1px solid rgba(251,191,36,.28);}
.pos-Exp    {background:rgba(34,197,94,.14) ;color:#22c55e;border:1px solid rgba(34,197,94,.28);}
.pos-Mid    {background:rgba(34,211,238,.14);color:#22d3ee;border:1px solid rgba(34,211,238,.28);}
.pos-Jungle {background:rgba(249,115,22,.14);color:#f97316;border:1px solid rgba(249,115,22,.28);}
.pos-Sub    {background:rgba(100,116,139,.10);color:#64748b;border:1px solid rgba(100,116,139,.22);}
/* Honor of Kings positions */
.pos-Baron  {background:rgba(239,68,68,.14) ;color:#ef4444;border:1px solid rgba(239,68,68,.28);}
.pos-Dragon {background:rgba(20,184,166,.14);color:#14b8a6;border:1px solid rgba(20,184,166,.28);}
.pos-Support{background:rgba(99,102,241,.14);color:#6366f1;border:1px solid rgba(99,102,241,.28);}

/* ─── AVATAR ─────────────────────────────────────────────────────────────────── */
.av{
  border-radius:50%;
  background: rgba(249,115,22,0.12);
  border:1px solid rgba(249,115,22,0.25);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-weight:700;color:var(--accent);
  box-shadow: 0 0 10px rgba(249,115,22,0.1);
}

/* ─── GLASS CARD ─────────────────────────────────────────────────────────────── */
.card{
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-md);
  position: relative;
  overflow: hidden;
}
.card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background: linear-gradient(135deg, rgba(255,255,255,0.055) 0%, transparent 45%);
  pointer-events:none;
}
.card-pad{padding:1rem;}

/* ─── SECTION HEADER ─────────────────────────────────────────────────────────── */
.sec-head{display:flex;align-items:center;gap:10px;margin-bottom:.9rem;}
.sec-title{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;color:var(--text);}
.sec-line{flex:1;height:1px;background:linear-gradient(90deg, rgba(249,115,22,0.3), rgba(255,255,255,0.04));}

/* ─── GRID LAYOUTS ───────────────────────────────────────────────────────────── */
.tour-grid  {display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:11px;}
.steps-grid {display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:1.5rem;}
.two-col    {display:grid;grid-template-columns:1fr 1fr;gap:12px;}

/* ─── TOURNAMENT CARD ────────────────────────────────────────────────────────── */
.tour-card{
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 1rem;
  cursor: pointer;
  transition: transform .14s, box-shadow .14s, border-color .14s;
  border-top: 2px solid var(--accent);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}
/* Index page cards override padding to let sections control their own spacing */
a.tour-card{ padding: 0; }
.tour-card::before{
  content:'';position:absolute;inset:0;
  background: linear-gradient(135deg, rgba(255,255,255,0.045) 0%, transparent 40%);
  pointer-events:none;
  z-index:0;
}
.tour-card > *{ position:relative;z-index:1; }
.tour-card:hover{
  transform:translateY(-3px);
  box-shadow: 0 1px 0 var(--specular) inset, 0 14px 48px rgba(0,0,0,0.6), 0 0 28px rgba(249,115,22,0.12);
  border-color: rgba(255,255,255,0.12);
}

/* ─── TABLE ──────────────────────────────────────────────────────────────────── */
.tbl-wrap{
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  position: relative;
}
.tbl-wrap::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.04) 0%,transparent 35%);
  pointer-events:none;z-index:0;
}
table{width:100%;border-collapse:collapse;position:relative;z-index:1;}
th{
  padding:8px 11px;text-align:left;font-size:9px;font-weight:700;
  color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;
  border-bottom:1px solid var(--border);
  background: rgba(255,255,255,0.02);
}
td{padding:10px 11px;border-bottom:1px solid rgba(255,255,255,0.04);font-size:13px;}
tr:last-child td{border-bottom:none;}
tr:hover td{background:rgba(255,255,255,0.025);}

/* ─── TABS ───────────────────────────────────────────────────────────────────── */
.tabs{
  display:flex;
  border-bottom:1px solid var(--border);
  margin-bottom:16px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  gap:2px;
}
.tabs::-webkit-scrollbar{display:none;}
.tab-btn{
  padding:10px 16px;
  background:transparent;
  border:none;
  border-bottom:2px solid transparent;
  color:var(--text-muted);
  font-size:12px;
  font-weight:600;
  cursor:pointer;
  transition:color .15s, border-color .15s;
  white-space:nowrap;
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  gap:4px;
  position:relative;
}
.tab-btn:hover{color:var(--text);}
.tab-btn.active{
  border-bottom-color:var(--accent);
  color:var(--accent);
  font-weight:700;
}
@media(max-width:640px){
  .tab-btn{padding:9px 12px;font-size:11px;}
}

/* ─── FILTERS ────────────────────────────────────────────────────────────────── */
.filters{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:16px;}
.filter-btn{
  padding:4px 12px;border-radius:20px;
  border:1px solid var(--border);
  background: rgba(255,255,255,0.03);
  color:var(--text-muted);font-size:11px;cursor:pointer;transition:all .15s;
}
.filter-btn.active{
  background:var(--accent-dim);
  border-color:rgba(249,115,22,0.4);
  color:var(--accent);font-weight:700;
  box-shadow:0 0 12px rgba(249,115,22,0.15);
}

/* ─── FORM FIELDS ────────────────────────────────────────────────────────────── */
.field-label{font-size:10px;color:var(--text-muted);margin-bottom:4px;font-weight:700;letter-spacing:.06em;display:block;}
.field-input{
  width:100%;padding:9px 11px;
  background: rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:9px;color:var(--text);font-size:13px;
  transition: border-color .15s, box-shadow .15s;
}
.field-input::placeholder{color:var(--text-muted);}
.pos-select{
  width:100%;padding:7px 10px;
  background: rgba(5,7,9,0.7);
  border:1px solid var(--border);
  border-radius:8px;color:var(--text);font-size:12px;cursor:pointer;
}

/* ─── PLAYER CARD ────────────────────────────────────────────────────────────── */
.player-card{
  background: rgba(255,255,255,0.03);
  border:1px solid var(--border);
  border-radius:11px;padding:.85rem;margin-bottom:9px;
  transition: border-color .15s;
}
.player-card.main{border-left:3px solid var(--accent);box-shadow:inset 3px 0 12px rgba(249,115,22,0.06);}
.player-card.sub {border-left:3px solid rgba(100,116,139,0.4);}
.player-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px;}
.reg-team-info{display:grid;grid-template-columns:1fr 90px;gap:9px;margin-bottom:16px;}
@media(max-width:400px){
  .player-fields{grid-template-columns:1fr;}
  .reg-team-info{grid-template-columns:1fr;}
}

/* ─── MODAL ──────────────────────────────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,0.82);
  z-index:999;display:flex;align-items:center;justify-content:center;
  padding:12px;overflow-y:auto;
}
.modal-box{
  background: var(--glass-heavy);
  backdrop-filter: var(--glass-blur-lg);
  -webkit-backdrop-filter: var(--glass-blur-lg);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:var(--r-xl);
  width:100%;max-width:440px;padding:1.5rem;
  position:relative;max-height:90vh;overflow-y:auto;margin:auto;
  animation:glassIn .18s ease;
  box-shadow: 0 1px 0 rgba(255,255,255,0.12) inset, 0 28px 90px rgba(0,0,0,0.75), 0 0 60px rgba(249,115,22,0.06);
}
.modal-box::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg,rgba(255,255,255,0.06) 0%,transparent 40%);
  pointer-events:none;
}
.modal-box.wide{max-width:600px;}
.modal-box.narrow{max-width:380px;}
@media(max-width:640px){
  .modal-box.wide,.modal-box.narrow{ max-width:100%; padding:1.1rem; border-radius:var(--r-lg); }
  .modal-box{ padding:1.1rem; }
}
.modal-close{
  position:absolute;top:12px;right:12px;
  background:rgba(255,255,255,0.07);border:1px solid var(--border);
  border-radius:7px;color:var(--text-muted);font-size:16px;cursor:pointer;
  line-height:1;width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.modal-close:hover{background:rgba(239,68,68,0.15);color:#ef4444;border-color:rgba(239,68,68,0.3);}

/* ─── HERO ───────────────────────────────────────────────────────────────────── */
.hero{
  background: var(--glass);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-radius:var(--r-xl);
  border:1px solid var(--border);
  box-shadow: var(--shadow-lg), 0 0 60px rgba(249,115,22,0.06);
  overflow:hidden;margin-bottom:1.5rem;
  position:relative;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(255,255,255,0.06) 0%, transparent 45%);
  pointer-events:none;z-index:0;
}
.hero-body{padding:2rem 2rem 1.5rem;position:relative;z-index:1;}
.hero-stats{
  display:flex;gap:24px;
  border-top:1px solid var(--border);
  padding:1.1rem 2rem;
  background: rgba(0,0,0,0.2);
  flex-wrap:wrap;position:relative;z-index:1;
}

/* ─── TOAST ──────────────────────────────────────────────────────────────────── */
#toast{
  position:fixed;bottom:76px;left:50%;transform:translateX(-50%);
  background: var(--glass-heavy);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border:1px solid var(--border);
  border-radius:12px;padding:10px 20px;
  font-size:13px;font-weight:600;z-index:9999;
  opacity:0;transition:opacity .3s;pointer-events:none;white-space:normal;max-width:90vw;text-align:center;
  box-shadow:0 1px 0 var(--specular) inset, 0 8px 32px rgba(0,0,0,0.6);
}
#toast.show{opacity:1;}
#toast.success{border-color:rgba(34,197,94,.4);color:#22c55e;box-shadow:0 1px 0 rgba(34,197,94,0.1) inset,0 8px 32px rgba(0,0,0,0.6),0 0 20px rgba(34,197,94,0.1);}
#toast.error  {border-color:rgba(239,68,68,.4) ;color:#ef4444;box-shadow:0 1px 0 rgba(239,68,68,0.1) inset,0 8px 32px rgba(0,0,0,0.6),0 0 20px rgba(239,68,68,0.1);}

/* ─── GLOBAL CHAT FLOATING BOX ───────────────────────────────────────────────── */
#online-panel{
  contain: layout style;
  position:fixed;
  right:12px;
  bottom:76px; /* sits above the FAB */
  width:300px;
  height:420px;
  background:rgba(6,9,18,0.97);
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow:0 8px 40px rgba(0,0,0,0.7), 0 0 0 1px rgba(255,255,255,0.04) inset;
  display:flex;flex-direction:column;overflow:hidden;z-index:40;
  transform:scale(0.92) translateY(12px);
  transform-origin:bottom right;
  opacity:0;
  transition:transform .22s cubic-bezier(.4,0,.2,1), opacity .18s ease;
  visibility:hidden;pointer-events:none;
}
#online-panel.open{
  transform:scale(1) translateY(0);
  opacity:1;visibility:visible;pointer-events:auto;
}
@media(max-width:640px){
  #online-panel{
    right:8px;
    bottom:72px;
    width:calc(100vw - 16px);
    height:60vh;
    max-height:420px;
    border-radius:16px;
  }
}


/* ─── ONLINE TOGGLE FAB ──────────────────────────────────────────────────────── */
#online-toggle{
  position:fixed;right:12px;bottom:16px;width:46px;height:46px;border-radius:50%;
  background: var(--glass-heavy);
  backdrop-filter: var(--glass-blur);
  border:1px solid var(--border);cursor:pointer;
  display:flex;align-items:center;justify-content:center;z-index:45;
  box-shadow: 0 1px 0 var(--specular) inset, 0 6px 20px rgba(0,0,0,0.55);
  transition:border-color .15s,box-shadow .15s,transform .15s;
}
#online-toggle:hover{border-color:var(--accent);transform:scale(1.08);box-shadow:0 1px 0 var(--specular) inset,0 8px 24px rgba(0,0,0,0.6),0 0 18px rgba(249,115,22,0.2);}
#online-toggle.active{border-color:rgba(249,115,22,.5);background:rgba(249,115,22,.08);box-shadow:0 0 16px rgba(249,115,22,0.2);}

/* ─── CHAT ───────────────────────────────────────────────────────────────────── */
#gchat-messages::-webkit-scrollbar{width:3px;}
#gchat-messages::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08);border-radius:2px;}

/* ─── RESPONSIVE ─────────────────────────────────────────────────────────────── */
@media(max-width:640px){
  .page{padding:1rem;}
  .hero-body{padding:1.1rem;}
  .hero-stats{padding:.9rem 1.1rem;gap:14px;}
  .tour-grid{grid-template-columns:1fr 1fr;}
  .steps-grid{grid-template-columns:1fr 1fr;}
  .two-col{grid-template-columns:1fr;}
  .nav-links{display:none;}
  .nav-right .btn,.nav-right .user-chip{display:none;}
  .desktop-only{display:none!important;}
  .hamburger{display:flex;}
}

/* ─── MOBILE PERFORMANCE: reduce blur on mid-range devices ───────────────── */
@media (max-width: 640px) {
  :root {
    --glass-blur:    blur(8px) saturate(1.4);
    --glass-blur-sm: blur(4px) saturate(1.2);
    --glass-blur-lg: blur(12px) saturate(1.5);
  }
}

/* Respect reduced-motion preference — disable all animations */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ─── EPOCKET NAV BUTTON ─────────────────────────────────────────────────── */
#epocket-btn{
  display: none; /* hidden by default, shown via JS when logged in */
  align-items: center;
}
@media(min-width:641px){
  #epocket-btn{ display:none!important; } /* desktop already shows coin badge */
}

