/* ══════════════════════════════════════════════════════════════
   PS5 Arena — style.css  (mobile-first responsive)
══════════════════════════════════════════════════════════════ */

/* ── THEMES ──────────────────────────────────────────────────── */
:root,[data-theme="dark"]{
  --bg:#06090f; --s1:#0b1018; --s2:#111923; --s3:#182232; --s4:#1f2d42;
  --border:rgba(255,255,255,.07); --border2:rgba(255,255,255,.12);
  --blue:#3b82f6; --bdim:rgba(59,130,246,.15); --bglow:rgba(59,130,246,.35);
  --teal:#2dd4bf; --tdim:rgba(45,212,191,.13);
  --gold:#f59e0b; --gdim:rgba(245,158,11,.14);
  --green:#22c55e;--gndim:rgba(34,197,94,.12);
  --red:#ef4444;  --rdim:rgba(239,68,68,.12);
  --purple:#a78bfa;--pdim:rgba(167,139,250,.12);
  --orange:#f97316;
  --pink:#f472b6;
  --tx:#e8edf5; --tx2:#7b92ac; --tx3:#374f66;
  --shadow:0 8px 40px rgba(0,0,0,.75);
  --shadow-sm:0 4px 16px rgba(0,0,0,.5);
  --r:10px; --rs:7px; --rl:14px;
  --tr:all .2s cubic-bezier(.4,0,.2,1);
  --hdr-bg:rgba(6,9,15,.92);
  --bg-image:url('/static/images/bg.jpg');
  --bg-overlay:linear-gradient(to bottom,rgba(4,6,12,.92) 0%,rgba(6,9,15,.82) 50%,rgba(6,9,15,.96) 100%);
  --cal-today:rgba(59,130,246,.2);
}
[data-theme="light"]{
  --bg:#dde8f5; --s1:#fff; --s2:#f2f6fc; --s3:#e4edf9; --s4:#d5e3f4;
  --border:rgba(0,0,0,.08); --border2:rgba(0,0,0,.13);
  --blue:#2563eb; --bdim:rgba(37,99,235,.1); --bglow:rgba(37,99,235,.25);
  --teal:#0d9488; --tdim:rgba(13,148,136,.1);
  --gold:#d97706; --gdim:rgba(217,119,6,.1);
  --green:#16a34a;--gndim:rgba(22,163,74,.1);
  --red:#dc2626;  --rdim:rgba(220,38,38,.1);
  --purple:#7c3aed;--pdim:rgba(124,58,237,.1);
  --orange:#ea580c;
  --pink:#db2777;
  --tx:#111827; --tx2:#3d5a78; --tx3:#8fa3b8;
  --shadow:0 4px 24px rgba(0,0,0,.14);
  --shadow-sm:0 2px 10px rgba(0,0,0,.09);
  --hdr-bg:rgba(255,255,255,.93);
  --bg-overlay:linear-gradient(to bottom,rgba(200,220,240,.88) 0%,rgba(210,228,248,.72) 50%,rgba(200,220,240,.92) 100%);
  --cal-today:rgba(37,99,235,.13);
}

/* ── RESET ────────────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Outfit",sans-serif;
  background-color:var(--bg);
  background-image:var(--bg-overlay),var(--bg-image);
  background-size:cover;
  background-attachment:fixed;
  background-position:center;
  color:var(--tx);
  min-height:100vh;
  overflow-x:hidden;
  font-size:14px;
  transition:background-color .4s,color .3s;
}
.mono{font-family:"JetBrains Mono",monospace}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:var(--s1)}
::-webkit-scrollbar-thumb{background:var(--s3);border-radius:3px}

/* ── UTILITIES ────────────────────────────────────────────────── */
.flex{display:flex;align-items:center}
.fj{display:flex;align-items:center;justify-content:space-between}
.col{display:flex;flex-direction:column}
.g4{gap:4px}.g6{gap:6px}.g8{gap:8px}.g10{gap:10px}.g12{gap:12px}.g16{gap:16px}
.mb4{margin-bottom:4px}.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}
.mb16{margin-bottom:16px}.mb20{margin-bottom:20px}.mb24{margin-bottom:24px}.mb32{margin-bottom:32px}
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}
.w100{width:100%}.ta-c{text-align:center}
.tx2{color:var(--tx2)}.tx3{color:var(--tx3)}
.tblue{color:var(--blue)}.tgreen{color:var(--green)}.tred{color:var(--red)}
.tgold{color:var(--gold)}.tteal{color:var(--teal)}.tpurple{color:var(--purple)}
.bold{font-weight:600}.hidden{display:none!important}
.err-text{color:var(--red)}
.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── BUTTONS ──────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:var(--rs);border:none;cursor:pointer;font-family:"Outfit",sans-serif;font-size:.86rem;font-weight:600;transition:var(--tr);white-space:nowrap;text-decoration:none;line-height:1;touch-action:manipulation}
.btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}
.btn-sm{padding:6px 13px;font-size:.8rem}
.btn-xs{padding:4px 10px;font-size:.73rem}
.btn-lg{padding:12px 28px;font-size:.95rem}
.btn-full{width:100%}
.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:#2563eb;box-shadow:0 0 24px var(--bglow)}
.btn-ghost{background:transparent;color:var(--tx2);border:1px solid var(--border2)}.btn-ghost:hover{background:var(--s3);color:var(--tx)}
.btn-teal{background:var(--teal);color:#001a18;font-weight:700}.btn-teal:hover{background:#14b8a6}
.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#dc2626}
.btn-success{background:var(--green);color:#001a0d;font-weight:700}.btn-success:hover{background:#16a34a}
.btn-gold{background:var(--gold);color:#1a0800;font-weight:700}.btn-gold:hover{background:#d97706}
.btn-orange{background:var(--orange);color:#1a0500;font-weight:700}.btn-orange:hover{background:#ea580c}
.btn-purple{background:var(--purple);color:#0f0020;font-weight:700}.btn-purple:hover{background:#8b5cf6}
.btn-outline{background:transparent;border:1px solid var(--blue);color:var(--blue)}.btn-outline:hover{background:var(--bdim)}
.glow-btn:hover{box-shadow:0 0 30px var(--bglow),0 0 60px rgba(59,130,246,.15)}

/* ── BADGES ───────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:20px;font-size:.68rem;font-weight:700;letter-spacing:.04em;white-space:nowrap}
.b-viewer{background:var(--s3);color:var(--tx2)}
.b-customer{background:var(--tdim);color:var(--teal)}
.b-admin{background:var(--bdim);color:var(--blue)}
.b-superadmin{background:var(--gdim);color:var(--gold)}
.b-active{background:var(--gndim);color:var(--green)}
.b-suspended{background:var(--rdim);color:var(--red)}
.b-available{background:var(--gndim);color:var(--green)}
.b-bidding{background:var(--gdim);color:var(--gold)}
.b-booked{background:var(--bdim);color:var(--blue)}
.b-full{background:var(--rdim);color:var(--red)}
.b-cancelled{background:var(--rdim);color:var(--red)}
.b-expired{background:var(--s3);color:var(--tx3)}
.b-upcoming{background:var(--pdim);color:var(--purple)}
.b-new{background:rgba(244,114,182,.12);color:var(--pink)}
.b-priority{background:rgba(245,158,11,.18);color:var(--gold)}
.b-private{background:rgba(167,139,250,.15);color:var(--purple)}
.b-open{background:rgba(34,197,94,.13);color:var(--green)}

/* ── CARDS ────────────────────────────────────────────────────── */
.card{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);padding:18px}
.card2{background:var(--s2);border:1px solid var(--border2);border-radius:var(--r);padding:14px}
.card3{background:var(--s3);border:1px solid var(--border2);border-radius:var(--rs);padding:10px}
.card-glass{background:rgba(11,16,24,.78);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--r);padding:18px}
[data-theme="light"] .card-glass{background:rgba(255,255,255,.82)}

/* ── STATS ────────────────────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-bottom:20px}
.stat{background:var(--s2);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px}
.stat-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--tx3);margin-bottom:4px}
.stat-val{font-family:"JetBrains Mono",monospace;font-size:1.55rem;font-weight:600;line-height:1}

/* ── FORMS ────────────────────────────────────────────────────── */
.fg{margin-bottom:14px}
.fl{display:block;font-size:.78rem;font-weight:600;color:var(--tx2);margin-bottom:5px}
.fi{width:100%;padding:10px 12px;background:var(--s2);border:1px solid var(--border2);border-radius:var(--rs);color:var(--tx);font-family:"Outfit",sans-serif;font-size:.88rem;transition:var(--tr);-webkit-appearance:none;appearance:none}
.fi:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--bdim)}
.fi::placeholder{color:var(--tx3)}
textarea.fi{resize:vertical;min-height:80px}
select.fi{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237b92ac' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fa{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}
.fhint{font-size:.71rem;color:var(--tx3);margin-top:3px}
.str-bar{height:3px;border-radius:2px;margin-top:5px;transition:var(--tr);width:0}
.str-label{font-size:.69rem;margin-top:3px;transition:color .2s}

/* ── INFO BOXES ───────────────────────────────────────────────── */
.info-box{background:var(--bdim);border:1px solid rgba(59,130,246,.2);border-radius:var(--rs);padding:10px 12px;font-size:.81rem;color:var(--tx2);margin-bottom:12px}
.warn-box{background:var(--gdim);border:1px solid rgba(245,158,11,.25);border-radius:var(--rs);padding:10px 12px;font-size:.81rem;color:var(--gold)}
.danger-box{background:var(--rdim);border:1px solid rgba(239,68,68,.25);border-radius:var(--rs);padding:10px 12px;font-size:.81rem;color:var(--red)}
.success-box{background:var(--gndim);border:1px solid rgba(34,197,94,.2);border-radius:var(--rs);padding:10px 12px;font-size:.81rem;color:var(--green)}

/* ── LOADING ──────────────────────────────────────────────────── */
.loading-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.skeleton{height:200px;background:linear-gradient(90deg,var(--s2) 25%,var(--s3) 50%,var(--s2) 75%);background-size:200% 100%;border-radius:var(--r);animation:shimmer 1.4s infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.loading-state{display:flex;align-items:center;justify-content:center;height:260px}
.spinner{width:36px;height:36px;border:3px solid var(--border2);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── INTRO OVERLAY ────────────────────────────────────────────── */
#intro-overlay{position:fixed;inset:0;z-index:9999;background:#000;display:flex;flex-direction:column;align-items:center;justify-content:space-between;overflow:hidden;transition:opacity 1s ease,visibility 1s}
#intro-overlay.fade-out{opacity:0;visibility:hidden;pointer-events:none}
#intro-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.intro-vignette{position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(ellipse at center,transparent 15%,rgba(0,0,0,.82) 100%)}
.intro-top{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;padding:clamp(28px,6vh,56px) 20px 0;text-align:center}
.intro-logo{font-family:"Outfit",sans-serif;font-size:clamp(1.8rem,6vw,3.8rem);font-weight:900;color:#fff;letter-spacing:-.03em;text-shadow:0 0 50px rgba(59,130,246,.9),0 2px 8px rgba(0,0,0,.8);animation:logoPulse 3s ease-in-out infinite}
.intro-logo span{color:#3b82f6}
@keyframes logoPulse{0%,100%{text-shadow:0 0 50px rgba(59,130,246,.9),0 2px 8px rgba(0,0,0,.8)}50%{text-shadow:0 0 80px rgba(59,130,246,1),0 0 120px rgba(59,130,246,.4),0 2px 8px rgba(0,0,0,.8)}}
.intro-tagline{color:rgba(255,255,255,.6);font-size:clamp(.75rem,2vw,1rem);letter-spacing:.2em;text-transform:uppercase;font-weight:500}
.intro-prog-wrap{width:min(220px,55vw);height:3px;background:rgba(255,255,255,.2);border-radius:2px;overflow:hidden;margin-top:8px}
.intro-bar{height:100%;background:#3b82f6;border-radius:2px;width:0;transition:width .15s linear}
/* Sound button — center */
.intro-sound{position:relative;z-index:2;background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.85);padding:11px 18px;border-radius:30px;cursor:pointer;font-family:"Outfit",sans-serif;font-size:.88rem;font-weight:500;transition:all .28s;opacity:0;transform:translateY(10px);pointer-events:none;white-space:nowrap;display:flex;align-items:center;gap:6px;touch-action:manipulation}
.intro-sound.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.intro-sound.active{background:rgba(59,130,246,.35);border-color:rgba(59,130,246,.6);color:#fff}
/* Skip button — bottom */
.intro-bot{position:relative;z-index:2;padding:0 20px clamp(20px,4vh,40px);display:flex;justify-content:center;align-items:center;gap:12px}
.intro-skip{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.28);color:#fff;padding:11px 26px;border-radius:30px;cursor:pointer;font-family:"Outfit",sans-serif;font-size:.88rem;font-weight:600;letter-spacing:.04em;transition:all .28s;opacity:0;transform:translateY(10px);display:flex;align-items:center;gap:7px;touch-action:manipulation}
.intro-skip.visible{opacity:1;transform:translateY(0)}
.intro-skip:hover,.intro-skip:active{background:rgba(255,255,255,.22);transform:translateY(-2px)}

/* ── HEADER ───────────────────────────────────────────────────── */
.hdr{position:fixed;top:0;left:0;right:0;height:56px;background:var(--hdr-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:300;display:flex;align-items:center;padding:0 14px;gap:10px;transition:background .3s}
.logo{font-weight:800;font-size:1rem;color:var(--blue);cursor:pointer;display:flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0}
.logo-mark{width:26px;height:26px;background:var(--blue);border-radius:6px;display:grid;place-items:center;font-size:.7rem;font-weight:800;color:#fff;flex-shrink:0}
.logo-text{font-size:.95rem}
.hdr-space{flex:1}
.hdr-nav{display:flex;align-items:center;gap:6px}
.theme-toggle{background:var(--s3);border:1px solid var(--border2);border-radius:20px;width:52px;height:26px;position:relative;cursor:pointer;transition:var(--tr);flex-shrink:0}
.theme-knob{width:18px;height:18px;background:var(--blue);border-radius:50%;position:absolute;top:3px;left:3px;transition:transform .25s cubic-bezier(.4,0,.2,1);display:grid;place-items:center;font-size:.65rem}
[data-theme="light"] .theme-knob{transform:translateX(25px)}
.avt{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--purple));display:grid;place-items:center;font-size:.7rem;font-weight:700;color:#fff;flex-shrink:0;border:2px solid var(--border2)}
.avt-lg{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--purple));display:grid;place-items:center;font-size:1.2rem;font-weight:700;color:#fff;flex-shrink:0}
/* Hamburger */
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:5px;border-radius:var(--rs);flex-direction:column;gap:4px;width:30px;touch-action:manipulation}
.hamburger span{display:block;height:2px;background:var(--tx);border-radius:2px;transition:var(--tr)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:199;backdrop-filter:blur(3px)}
.sidebar-overlay.visible{display:block}

/* ── APP LAYOUT ───────────────────────────────────────────────── */
.app-layout{display:flex;padding-top:56px;min-height:100vh}
.sidebar{width:200px;flex-shrink:0;background:rgba(11,16,24,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-right:1px solid var(--border);position:fixed;top:56px;bottom:0;left:0;overflow-y:auto;z-index:200;display:flex;flex-direction:column;transition:transform .3s,background .3s}
[data-theme="light"] .sidebar{background:rgba(255,255,255,.9)}
.sidebar-inner{flex:1;overflow-y:auto;padding:8px 0}
.sb-section{padding:6px 8px;margin-top:2px}
.sb-label{font-size:.61rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tx3);padding:0 6px;margin-bottom:4px}
.sb-item{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:var(--rs);cursor:pointer;color:var(--tx2);font-size:.83rem;font-weight:500;transition:var(--tr);border:none;background:none;width:100%;font-family:"Outfit",sans-serif;position:relative;text-align:left;touch-action:manipulation}
.sb-item:hover{background:var(--s2);color:var(--tx)}
.sb-item.active{background:var(--bdim);color:var(--blue)}
.sb-item.active::before{content:"";position:absolute;left:0;top:5px;bottom:5px;width:2px;background:var(--blue);border-radius:0 2px 2px 0}
.sb-icon{font-size:.88rem;width:16px;text-align:center;flex-shrink:0}
.sb-bot{padding:10px;border-top:1px solid var(--border)}
.main{margin-left:200px;padding:20px;flex:1;min-height:calc(100vh - 56px);transition:margin .3s}
.ph{margin-bottom:18px}
.ph h1{font-size:1.2rem;font-weight:700;margin-bottom:2px}
.ph p{font-size:.81rem;color:var(--tx2)}
.section-title{font-size:.8rem;font-weight:700;font-family:"JetBrains Mono",monospace;letter-spacing:.03em;color:var(--tx2)}

/* ── PAGES ────────────────────────────────────────────────────── */
.page{display:none}.page.active{display:block}

/* ── HOME HERO ────────────────────────────────────────────────── */
.home-page{padding-top:56px;min-height:100vh}
.hero-section{padding:clamp(36px,6vh,70px) clamp(14px,4vw,32px) 40px;max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:36px;flex-wrap:wrap}
.hero-text{flex:1;min-width:min(260px,100%)}
.hero-eyebrow{display:inline-flex;align-items:center;gap:7px;background:var(--bdim);border:1px solid rgba(59,130,246,.22);border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:600;color:var(--blue);margin-bottom:14px}
.eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse-dot 1.5s infinite;flex-shrink:0}
.hero-title{font-size:clamp(2rem,5vw,3.6rem);font-weight:900;line-height:1.06;letter-spacing:-.03em;margin-bottom:14px}
.hero-accent{background:linear-gradient(90deg,#3b82f6,#8b5cf6,#2dd4bf);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:.95rem;color:var(--tx2);line-height:1.7;max-width:420px;margin-bottom:24px}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.hero-kpis{display:flex;gap:24px;flex-wrap:wrap}
.kpi-n{font-family:"JetBrains Mono",monospace;font-size:1.8rem;font-weight:700;color:var(--blue);line-height:1}
.kpi-l{font-size:.67rem;color:var(--tx3);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
/* Hero visual */
.hero-visual{width:clamp(180px,28vw,260px);height:clamp(180px,28vw,260px);flex-shrink:0;background:rgba(11,16,24,.6);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:clamp(16px,3vw,26px);display:grid;place-items:center;position:relative;overflow:hidden}
[data-theme="light"] .hero-visual{background:rgba(255,255,255,.5)}
.hero-controller{font-size:clamp(3rem,6vw,5.5rem);position:relative;z-index:2;filter:drop-shadow(0 0 28px rgba(59,130,246,.5));animation:float 3.5s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-12px) rotate(3deg)}}
.ring{position:absolute;border-radius:50%;border:1px solid rgba(59,130,246,.15);animation:ringPulse 3s ease-in-out infinite}
.ring1{width:55%;height:55%;animation-delay:0s}
.ring2{width:78%;height:78%;animation-delay:.8s}
.ring3{width:100%;height:100%;animation-delay:1.6s}
@keyframes ringPulse{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:.75;transform:scale(1.04)}}
.live-badge{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.35);border-radius:20px;padding:4px 12px;font-size:.72rem;font-weight:600;color:var(--green);white-space:nowrap;display:flex;align-items:center;gap:5px;z-index:3}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse-dot 1.5s infinite;flex-shrink:0}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

/* ── HOME SECTIONS ────────────────────────────────────────────── */
.home-container{max-width:1100px;margin:0 auto;padding:0 clamp(14px,4vw,28px) 48px}
.section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.section-ttl{font-size:1rem;font-weight:700}
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.filter-bar .fi{flex:1;min-width:100px}
.home-divider{height:1px;background:var(--border);margin:32px 0}
.hiw-section{margin-top:44px;text-align:center}
.hiw-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px;margin-top:16px}
.hiw-card{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);padding:20px 14px;text-align:center;transition:var(--tr)}
.hiw-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);border-color:var(--blue)}
.hiw-num{font-family:"JetBrains Mono",monospace;font-size:.68rem;color:var(--blue);font-weight:700;letter-spacing:.06em;margin-bottom:8px}
.hiw-icon{font-size:2rem;margin-bottom:8px}
.hiw-title{font-size:.88rem;font-weight:700;margin-bottom:5px}
.hiw-desc{font-size:.76rem;color:var(--tx2);line-height:1.6}

/* ── SLOT CARDS ───────────────────────────────────────────────── */
.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,270px),1fr));gap:12px}
.slt{background:rgba(11,16,24,.82);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--r);padding:14px;transition:var(--tr);position:relative;overflow:hidden}
[data-theme="light"] .slt{background:rgba(255,255,255,.85)}
.slt::before{content:"";position:absolute;top:0;left:0;right:0;height:3px}
.slt.available::before{background:var(--green)}.slt.bidding::before{background:var(--gold)}
.slt.booked::before{background:var(--blue)}.slt.full::before,.slt.cancelled::before,.slt.expired::before{background:var(--tx3)}
.slt:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.slt-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;gap:8px}
.slt-name{font-weight:700;font-size:.9rem;line-height:1.3}
.slt-meta{display:flex;flex-direction:column;gap:3px;margin-bottom:10px}
.slt-row{display:flex;align-items:center;gap:5px;font-size:.78rem;color:var(--tx2)}
.slt-badges{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:6px}
.slt-foot{display:flex;align-items:flex-end;justify-content:space-between;padding-top:8px;border-top:1px solid var(--border);gap:8px}
.price-lbl{font-size:.62rem;color:var(--tx3);text-transform:uppercase;letter-spacing:.05em}
.price-val{font-family:"JetBrains Mono",monospace;font-size:1rem;font-weight:700;color:var(--teal)}
.price-sub{font-size:.68rem;color:var(--tx3);margin-top:1px}
.bid-blink{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse-dot 1.4s infinite;margin-right:2px}
.win-tag{display:inline-flex;align-items:center;gap:4px;background:rgba(245,158,11,.2);border:1px solid rgba(245,158,11,.35);border-radius:20px;padding:2px 7px;font-size:.68rem;color:var(--gold);font-weight:700}
.slt-actions{display:flex;flex-direction:column;gap:4px;align-items:flex-end;flex-shrink:0}

/* ── BOOKING TYPE TAGS ────────────────────────────────────────── */
.btype-tag{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:4px;font-size:.64rem;font-weight:700;letter-spacing:.03em}
.btype-priority{background:rgba(245,158,11,.15);color:var(--gold)}
.btype-private{background:rgba(167,139,250,.14);color:var(--purple)}
.btype-open{background:rgba(34,197,94,.12);color:var(--green)}
.btype-standard{background:rgba(59,130,246,.12);color:var(--blue)}

/* ── PAYMENT MODAL ────────────────────────────────────────────── */
.pay-methods{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.pay-method{background:var(--s2);border:2px solid var(--border2);border-radius:var(--r);padding:14px 12px;cursor:pointer;transition:var(--tr);text-align:center;position:relative}
.pay-method:hover{border-color:var(--blue);background:var(--bdim)}
.pay-method.selected{border-color:var(--blue);background:var(--bdim)}
.pay-method .pm-icon{font-size:1.6rem;margin-bottom:4px}
.pay-method .pm-name{font-size:.78rem;font-weight:600}
.pay-method .pm-sub{font-size:.67rem;color:var(--tx2)}
.pay-check{position:absolute;top:6px;right:6px;width:16px;height:16px;border-radius:50%;background:var(--blue);color:#fff;display:none;align-items:center;justify-content:center;font-size:.6rem}
.pay-method.selected .pay-check{display:flex}
.pay-input-section{border-top:1px solid var(--border);padding-top:14px;margin-top:4px}
.pay-summary{background:var(--gndim);border:1px solid rgba(34,197,94,.2);border-radius:var(--rs);padding:12px;margin-bottom:14px}
.pay-summary .ps-row{display:flex;justify-content:space-between;font-size:.82rem;margin-bottom:4px}
.pay-summary .ps-total{display:flex;justify-content:space-between;font-weight:700;font-size:.95rem;padding-top:6px;border-top:1px solid rgba(34,197,94,.25);margin-top:6px}
/* Booking type selector in booking modal */
.bk-type-grid{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:14px}
.bk-type-opt{background:var(--s2);border:2px solid var(--border2);border-radius:var(--r);padding:12px 14px;cursor:pointer;transition:var(--tr);display:flex;align-items:flex-start;gap:10px}
.bk-type-opt:hover{border-color:var(--blue)}
.bk-type-opt.selected{border-color:var(--blue);background:var(--bdim)}
.bk-type-opt.selected.gold{border-color:var(--gold);background:var(--gdim)}
.bk-type-opt.selected.purple{border-color:var(--purple);background:var(--pdim)}
.bto-icon{font-size:1.4rem;flex-shrink:0;margin-top:1px}
.bto-info .bto-name{font-size:.88rem;font-weight:700;margin-bottom:2px}
.bto-info .bto-desc{font-size:.75rem;color:var(--tx2);line-height:1.5}
.bto-info .bto-price{font-size:.8rem;font-weight:700;margin-top:4px}
.bto-radio{width:16px;height:16px;border-radius:50%;border:2px solid var(--border2);margin-left:auto;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:var(--tr);margin-top:2px}
.bk-type-opt.selected .bto-radio{border-color:var(--blue);background:var(--blue)}
.bk-type-opt.selected.gold .bto-radio{border-color:var(--gold);background:var(--gold)}
.bk-type-opt.selected.purple .bto-radio{border-color:var(--purple);background:var(--purple)}
.bto-radio::after{content:"";width:6px;height:6px;border-radius:50%;background:#fff;opacity:0;transition:opacity .15s}
.bk-type-opt.selected .bto-radio::after{opacity:1}

/* ── GAME GRID ────────────────────────────────────────────────── */
.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:12px}
.game-card{background:rgba(11,16,24,.8);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:var(--tr);backdrop-filter:blur(6px)}
[data-theme="light"] .game-card{background:rgba(255,255,255,.8)}
.game-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--border2)}
.game-thumb{height:100px;display:flex;align-items:center;justify-content:center;font-size:3rem}
.game-info{padding:10px 12px}
.game-title{font-weight:700;font-size:.85rem;margin-bottom:3px}
.game-meta{font-size:.7rem;color:var(--tx2)}

/* ── NEWS GRID ────────────────────────────────────────────────── */
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,290px),1fr));gap:14px}
.news-card{background:rgba(11,16,24,.8);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:var(--tr);backdrop-filter:blur(6px)}
[data-theme="light"] .news-card{background:rgba(255,255,255,.8)}
.news-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:var(--border2)}
.news-thumb{height:120px;display:flex;align-items:center;justify-content:center;font-size:2.8rem}
.news-body{padding:12px}
.news-cat{font-size:.63rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--blue);margin-bottom:5px}
.news-title{font-size:.9rem;font-weight:700;margin-bottom:5px;line-height:1.4}
.news-excerpt{font-size:.76rem;color:var(--tx2);line-height:1.6}
.news-foot{padding:8px 12px 12px;display:flex;align-items:center;justify-content:space-between;font-size:.7rem;color:var(--tx3)}

/* ── AUTH ─────────────────────────────────────────────────────── */
.auth-wrap{padding-top:56px;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:70px 16px 24px}
.auth-card{background:rgba(11,16,24,.9);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--rl);padding:clamp(18px,4vw,28px);width:100%;max-width:390px;box-shadow:var(--shadow)}
[data-theme="light"] .auth-card{background:rgba(255,255,255,.92)}
.auth-brand{text-align:center;margin-bottom:16px}
.auth-logo{width:42px;height:42px;background:var(--blue);border-radius:9px;display:grid;place-items:center;font-size:1rem;font-weight:800;color:#fff;margin:0 auto 9px}
.auth-brand h2{font-size:1.1rem;font-weight:700}
.sec-banner{background:var(--gndim);border:1px solid rgba(34,197,94,.22);border-radius:var(--rs);padding:6px 11px;font-size:.74rem;color:var(--green);display:flex;gap:6px;align-items:center;margin-bottom:14px}
.auth-tabs{display:flex;background:var(--s2);border-radius:var(--rs);padding:3px;margin-bottom:16px}
.atab{flex:1;padding:7px;border:none;background:none;cursor:pointer;font-family:"Outfit",sans-serif;font-size:.83rem;font-weight:600;color:var(--tx2);border-radius:5px;transition:var(--tr);touch-action:manipulation}
.atab.active{background:var(--s4);color:var(--tx)}
.demo-box{background:var(--s2);border:1px solid var(--border);border-radius:var(--rs);padding:11px;font-size:.76rem;margin-top:12px;line-height:2}
.demo-label{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:var(--tx3);margin-bottom:3px;display:block}
.demo-box code{font-family:"JetBrains Mono",monospace;font-size:.82em;color:var(--blue)}

/* ── CALENDAR ─────────────────────────────────────────────────── */
.cal-wrap{background:rgba(11,16,24,.82);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;height:calc(100vh - 140px);min-height:500px}
[data-theme="light"] .cal-wrap{background:rgba(255,255,255,.88)}
.cal-toolbar{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap;row-gap:6px}
.cal-month-label{font-size:.95rem;font-weight:700;font-family:"JetBrains Mono",monospace;min-width:0;flex:1}
.cal-view-btns{display:flex;background:var(--s2);border-radius:var(--rs);padding:2px;gap:2px}
.cv-btn{padding:5px 11px;border:none;background:none;cursor:pointer;font-family:"Outfit",sans-serif;font-size:.77rem;font-weight:600;color:var(--tx2);border-radius:4px;transition:var(--tr);touch-action:manipulation}
.cv-btn.active{background:var(--s4);color:var(--tx)}
/* Two-column on desktop, stacked on mobile */
.cal-body{display:flex;flex:1;overflow:hidden}
.cal-sidebar-panel{width:200px;flex-shrink:0;background:var(--s2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;padding:12px}
.cal-main-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}
.cal-mini-title{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--tx3);margin-bottom:7px}
.mini-cal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px}
.mini-cal-mn{font-size:.78rem;font-weight:700}
.mini-cal-btn{background:none;border:none;cursor:pointer;color:var(--tx2);font-size:.88rem;padding:2px 5px;border-radius:4px;transition:var(--tr);touch-action:manipulation}
.mini-cal-btn:hover{background:var(--s3)}
.mini-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;margin-bottom:12px}
.mini-dh{font-size:.58rem;text-align:center;color:var(--tx3);padding:2px;font-weight:600}
.mini-day{font-size:.68rem;text-align:center;padding:3px 1px;border-radius:50%;cursor:pointer;transition:var(--tr);aspect-ratio:1;display:grid;place-items:center;touch-action:manipulation}
.mini-day:hover{background:var(--s4)}
.mini-day.today{background:var(--blue);color:#fff}
.mini-day.has-slots{font-weight:700;color:var(--teal)}
.mini-day.other{color:var(--tx3);pointer-events:none}
.mini-day.selected{background:var(--bdim);color:var(--blue)}
/* Month grid */
.cal-hdr-row{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border);flex-shrink:0}
.cal-dname{padding:7px 2px;text-align:center;font-size:.63rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--tx3)}
.cal-grid-scroll{flex:1;overflow-y:auto}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:minmax(75px,1fr)}
.cal-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:4px;cursor:pointer;transition:background .15s;min-height:75px;touch-action:manipulation}
.cal-cell:hover{background:rgba(59,130,246,.05)}
.cal-cell.today-cell{background:var(--cal-today)}
.cal-cell.selected-cell{background:rgba(59,130,246,.1)}
.cal-cell.other-month{opacity:.25;pointer-events:none}
.cal-dn{font-size:.72rem;font-weight:600;color:var(--tx2);margin-bottom:2px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%}
.cal-cell.today-cell .cal-dn{background:var(--blue);color:#fff}
.cal-chips{display:flex;flex-direction:column;gap:1px}
.cc{font-size:.59rem;padding:1px 3px;border-radius:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;cursor:pointer}
.cc:hover{filter:brightness(1.15)}
.cc-available{background:rgba(34,197,94,.22);color:var(--green)}
.cc-bidding{background:rgba(245,158,11,.22);color:var(--gold)}
.cc-booked{background:rgba(59,130,246,.22);color:var(--blue)}
.cc-full,.cc-cancelled{background:rgba(239,68,68,.2);color:var(--red)}
.cc-expired{background:rgba(58,80,104,.2);color:var(--tx3)}
.cal-more{font-size:.56rem;color:var(--tx3);padding:1px 2px}
/* Day detail panel */
.cal-detail-panel{position:absolute;right:0;top:0;bottom:0;width:min(270px,100%);background:rgba(11,16,24,.96);backdrop-filter:blur(16px);border-left:1px solid var(--border);z-index:10;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}
[data-theme="light"] .cal-detail-panel{background:rgba(255,255,255,.97)}
.cal-detail-panel.open{transform:translateX(0)}
.cdp-head{padding:11px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.cdp-body{flex:1;overflow-y:auto;padding:10px}
.cdp-slot{background:var(--s2);border-radius:var(--rs);padding:10px;margin-bottom:8px}
/* Week view */
.week-grid{display:grid;grid-template-columns:55px repeat(7,1fr)}
.wk-dname{padding:7px 3px;text-align:center;font-size:.68rem;font-weight:700;border-right:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer;transition:var(--tr)}
.wk-dname:hover,.wk-dname.today{color:var(--blue)}
.wk-time{padding:4px 4px;text-align:right;font-size:.6rem;color:var(--tx3);font-family:"JetBrains Mono",monospace;border-right:1px solid var(--border);border-bottom:1px solid var(--border);white-space:nowrap}
.wk-slot{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:2px;min-height:34px;cursor:pointer;transition:var(--tr)}
.wk-slot:hover{background:rgba(59,130,246,.05)}
.wk-event{border-radius:3px;padding:2px 4px;font-size:.62rem;font-weight:600;cursor:pointer;margin-bottom:1px}
/* Upcoming list */
.upcoming-list{display:flex;flex-direction:column;gap:7px;flex:1;overflow-y:auto}
.upcoming-item{background:var(--s3);border-radius:var(--rs);padding:7px 9px;cursor:pointer;transition:var(--tr);touch-action:manipulation}
.upcoming-item:hover{background:var(--s4)}
.upcoming-date{font-size:.62rem;color:var(--tx3);font-family:"JetBrains Mono",monospace;margin-bottom:2px}
.upcoming-name{font-size:.78rem;font-weight:600;margin-bottom:2px}
.upcoming-time{font-size:.68rem;color:var(--tx2)}

/* ── TABLE ────────────────────────────────────────────────────── */
.tw{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;min-width:560px}
thead th{padding:8px 10px;text-align:left;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--tx3);border-bottom:1px solid var(--border);white-space:nowrap}
tbody td{padding:10px;font-size:.82rem;border-bottom:1px solid var(--border);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:rgba(59,130,246,.04)}

/* ── MODAL ────────────────────────────────────────────────────── */
.modal-ov{position:fixed;inset:0;z-index:800;background:rgba(0,0,0,.82);display:flex;align-items:flex-end;justify-content:center;padding:0;backdrop-filter:blur(6px)}
.modal-ov.hidden{display:none}
.modal-box{background:rgba(11,16,24,.97);backdrop-filter:blur(20px);border:1px solid var(--border2);border-radius:var(--rl) var(--rl) 0 0;padding:20px;width:100%;max-width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 -8px 40px rgba(0,0,0,.8)}
[data-theme="light"] .modal-box{background:rgba(255,255,255,.98)}
.mhd{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.mttl{font-size:.98rem;font-weight:700}
.mclose{background:none;border:none;color:var(--tx2);cursor:pointer;font-size:1.1rem;padding:3px 7px;border-radius:5px;line-height:1;transition:var(--tr);touch-action:manipulation}
.mclose:hover{background:var(--s3);color:var(--tx)}

/* ── TOAST ────────────────────────────────────────────────────── */
.toast{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);z-index:1000;padding:11px 18px;border-radius:30px;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow);max-width:calc(100vw - 32px);width:max-content;animation:toastIn .28s ease;pointer-events:none;text-align:center}
.toast.hidden{display:none}
.toast.success{background:var(--green);color:#001a0a}
.toast.error{background:var(--red);color:#fff}
.toast.info{background:var(--blue);color:#fff}
.toast.warning{background:var(--gold);color:#1a0800}
@keyframes toastIn{from{transform:translateX(-50%) translateY(20px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}

/* ── MISC ─────────────────────────────────────────────────────── */
hr.div{border:none;border-top:1px solid var(--border);margin:12px 0}
.empty{text-align:center;padding:40px 16px;color:var(--tx2)}
.empty .ei{font-size:2.4rem;margin-bottom:9px}
.sec-lock{display:flex;align-items:center;gap:6px;background:var(--rdim);border:1px solid rgba(239,68,68,.2);border-radius:var(--rs);padding:10px 12px;font-size:.8rem;color:var(--red);margin-bottom:14px}
.profile-hero{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.rl{border-radius:14px}

/* ── TABLET / DESKTOP OVERRIDES ───────────────────────────────── */
@media(min-width:600px){
  .modal-ov{align-items:center;padding:16px}
  .modal-box{border-radius:var(--rl);max-width:480px;max-height:90vh}
  .bk-type-grid{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:768px){
  .hamburger{display:none}
  .sidebar{transform:none!important}
  .main{margin-left:200px}
}
@media(min-width:1024px){
  .cal-sidebar-panel{display:flex}
}

/* ── MOBILE OVERRIDES ─────────────────────────────────────────── */
@media(max-width:767px){
  /* show hamburger */
  .hamburger{display:flex}
  /* hide sidebar off-screen */
  .sidebar{transform:translateX(-100%);z-index:400;width:220px}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0;padding:12px}
  /* hero */
  .hero-section{flex-direction:column;align-items:flex-start;padding:30px 14px 24px;gap:20px}
  .hero-visual{width:140px;height:140px;align-self:center}
  .hero-controller{font-size:3.2rem}
  .hero-cta .btn-lg{padding:10px 20px;font-size:.88rem}
  .hero-kpis{gap:18px}
  .kpi-n{font-size:1.5rem}
  /* form rows become single col */
  .fr{grid-template-columns:1fr}
  /* stats */
  .stats{grid-template-columns:repeat(2,1fr)}
  /* calendar: hide sidebar panel */
  .cal-sidebar-panel{display:none}
  .cal-dname{font-size:.57rem;padding:5px 1px}
  .cal-wrap{height:calc(100vh - 120px)}
  /* slots grid: 1 col */
  .slots-grid{grid-template-columns:1fr}
  /* games grid */
  .games-grid{grid-template-columns:repeat(2,1fr)}
  /* header nav: hide label */
  .avt-name{display:none}
  .logo-text{font-size:.85rem}
  /* tables scroll */
  .tw{margin:0 -12px;width:calc(100% + 24px);padding:0 12px}
  /* section headers */
  .section-hdr{gap:6px}
  /* auth */
  .auth-card{padding:18px 16px}
  /* hiw grid */
  .hiw-grid{grid-template-columns:repeat(2,1fr)}
  /* pay methods */
  .pay-methods{grid-template-columns:1fr 1fr}
}
@media(max-width:420px){
  .hero-title{font-size:1.85rem}
  .games-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .stats{grid-template-columns:1fr 1fr}
  .hdr{padding:0 10px;gap:8px}
  .logo-mark{width:24px;height:24px;font-size:.65rem}
  .hiw-grid{grid-template-columns:1fr}
  .hero-visual{width:120px;height:120px}
  .filter-bar .fi{min-width:0}
}

/* ── USERNAME FIELD ───────────────────────────────────────────── */
.username-row{display:flex;align-items:center;gap:0}
.username-input{border-radius:var(--rs) 0 0 var(--rs);flex:1;border-right:none}
.username-suffix{background:var(--s3);border:1px solid var(--border2);border-left:none;border-radius:0 var(--rs) var(--rs) 0;padding:10px 12px;color:var(--blue);font-weight:700;font-size:.85rem;white-space:nowrap;font-family:"JetBrains Mono",monospace}
.username-preview{font-size:.75rem;margin-top:5px;height:16px}
.username-preview.available{color:var(--green)}
.username-preview.taken{color:var(--red)}

/* ── AUTH 3 TABS ──────────────────────────────────────────────── */
.auth-tabs{display:flex;background:var(--s2);border-radius:var(--rs);padding:3px;margin-bottom:16px;gap:2px}
.atab{flex:1;padding:6px 4px;border:none;background:none;cursor:pointer;font-family:"Outfit",sans-serif;font-size:.77rem;font-weight:600;color:var(--tx2);border-radius:5px;transition:var(--tr);touch-action:manipulation;white-space:nowrap}
.atab.active{background:var(--s4);color:var(--tx)}

/* ── AMAZON PAY PRIMARY ───────────────────────────────────────── */
.pay-amazon{background:linear-gradient(135deg,#ff9900,#ff6600);border:2px solid #ff9900;border-radius:var(--r);padding:16px;cursor:pointer;transition:var(--tr);position:relative;overflow:hidden;margin-bottom:14px}
.pay-amazon.selected{box-shadow:0 0 0 3px rgba(255,153,0,.4)}
.pay-amazon:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(255,153,0,.3)}
.pay-amazon::before{content:"PRIMARY";position:absolute;top:6px;right:8px;font-size:.6rem;font-weight:700;letter-spacing:.08em;color:rgba(255,255,255,.8);background:rgba(0,0,0,.25);border-radius:4px;padding:2px 5px}
.pay-amazon .pa-row{display:flex;align-items:center;gap:10px}
.pay-amazon .pa-icon{font-size:1.8rem;flex-shrink:0}
.pay-amazon .pa-info .pa-name{font-size:1rem;font-weight:800;color:#fff}
.pay-amazon .pa-info .pa-sub{font-size:.75rem;color:rgba(255,255,255,.8)}
.pay-amazon .pa-check{margin-left:auto;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,.3);border:2px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-size:.72rem;color:#fff;transition:var(--tr)}
.pay-amazon.selected .pa-check{background:#fff;border-color:#fff;color:#ff6600}

/* ── REFUND MODAL ─────────────────────────────────────────────── */
.refund-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:.7rem;font-weight:700}
.refund-requested{background:rgba(245,158,11,.15);color:var(--gold)}
.refund-approved{background:rgba(34,197,94,.13);color:var(--green)}
.refund-rejected{background:rgba(239,68,68,.12);color:var(--red)}
.refund-processed{background:rgba(59,130,246,.12);color:var(--blue)}

/* ── ADMIN REQUEST BADGES ─────────────────────────────────────── */
.req-badge-pending{background:rgba(245,158,11,.15);color:var(--gold)}
.req-badge-approved{background:rgba(34,197,94,.13);color:var(--green)}
.req-badge-rejected{background:rgba(239,68,68,.12);color:var(--red)}

/* ── NOTIFICATION DOT ─────────────────────────────────────────── */
.notif-dot{width:7px;height:7px;border-radius:50%;background:var(--red);display:inline-block;margin-left:4px;flex-shrink:0;animation:pulse-dot 2s infinite}

/* ── TESTIMONIALS ──────────────────────────────────────────── */
.testimonial-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:14px}
.tcard{background:rgba(11,16,24,.82);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--r);padding:16px;transition:var(--tr)}
[data-theme="light"] .tcard{background:rgba(255,255,255,.85)}
.tcard.featured{border-color:var(--gold);box-shadow:0 0 20px rgba(245,158,11,.15)}
.tcard:hover{border-color:var(--border2);transform:translateY(-2px)}
.tcard-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.tcard-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--purple));display:grid;place-items:center;font-size:.85rem;font-weight:700;color:#fff;flex-shrink:0}
.tcard-name{font-weight:700;font-size:.88rem}
.tcard-username{font-size:.72rem;color:var(--tx2);font-family:"JetBrains Mono",monospace}
.tcard-stars{color:var(--gold);font-size:.85rem;letter-spacing:2px}
.tcard-content{font-size:.83rem;color:var(--tx2);line-height:1.65;margin-bottom:10px}
.tcard-media-link{display:inline-flex;align-items:center;gap:5px;color:var(--blue);font-size:.76rem;font-weight:600;text-decoration:none}
.tcard-media-link:hover{text-decoration:underline}
.tcard-foot{display:flex;align-items:center;justify-content:space-between;padding-top:8px;border-top:1px solid var(--border);font-size:.7rem;color:var(--tx3)}
.tcard-status{font-size:.68rem;font-weight:700;padding:2px 7px;border-radius:20px}
.ts-pending{background:rgba(245,158,11,.15);color:var(--gold)}
.ts-approved{background:rgba(34,197,94,.13);color:var(--green)}
.ts-rejected{background:rgba(239,68,68,.12);color:var(--red)}
.ts-pending_sa{background:rgba(59,130,246,.13);color:var(--blue)}
.ts-featured{background:rgba(245,158,11,.2);color:var(--gold)}

/* ── MEDIA POSTS ───────────────────────────────────────────── */
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:16px}
.media-card{background:rgba(11,16,24,.82);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:var(--tr)}
[data-theme="light"] .media-card{background:rgba(255,255,255,.85)}
.media-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:var(--border2)}
.media-thumb{height:140px;display:flex;align-items:center;justify-content:center;font-size:3.5rem;background:var(--s3);position:relative}
.media-play-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.45);opacity:0;transition:opacity .2s}
.media-card:hover .media-play-icon{opacity:1}
.media-play-icon span{font-size:2.5rem}
.media-body{padding:12px}
.media-title{font-weight:700;font-size:.9rem;margin-bottom:4px}
.media-desc{font-size:.76rem;color:var(--tx2);line-height:1.5;margin-bottom:8px}
.media-foot{display:flex;align-items:center;justify-content:space-between;font-size:.7rem;color:var(--tx3)}
.media-status-badge{font-size:.67rem;font-weight:700;padding:2px 7px;border-radius:20px}
.ms-pending{background:rgba(245,158,11,.15);color:var(--gold)}
.ms-published{background:rgba(34,197,94,.13);color:var(--green)}
.ms-rejected{background:rgba(239,68,68,.12);color:var(--red)}

/* ── ORDER MANAGEMENT ──────────────────────────────────────── */
.order-card{background:rgba(11,16,24,.82);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:12px;transition:var(--tr)}
[data-theme="light"] .order-card{background:rgba(255,255,255,.85)}
.order-card.active-order{border-color:var(--teal)}
.order-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.order-title{font-weight:700;font-size:.95rem}
.order-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:6px;margin-bottom:12px}
.order-field{font-size:.8rem;color:var(--tx2)}
.order-field strong{color:var(--tx);font-weight:600}
.order-actions{display:flex;gap:8px;flex-wrap:wrap;padding-top:10px;border-top:1px solid var(--border)}
.tracking-id{font-family:"JetBrains Mono",monospace;font-size:.78rem;color:var(--teal);font-weight:600;padding:3px 8px;background:var(--tdim);border-radius:6px}
.refund-info{background:var(--gdim);border:1px solid rgba(245,158,11,.2);border-radius:var(--rs);padding:10px 12px;margin-top:10px;font-size:.8rem}

/* ── PENDING CASES ─────────────────────────────────────────── */
.cases-section{margin-bottom:28px}
.cases-section h3{font-size:.88rem;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.case-card{background:var(--s2);border:1px solid var(--border2);border-radius:var(--r);padding:14px;margin-bottom:10px;display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap}
.case-icon{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-size:1rem;flex-shrink:0}
.case-body{flex:1;min-width:200px}
.case-title{font-weight:700;font-size:.87rem;margin-bottom:3px}
.case-detail{font-size:.78rem;color:var(--tx2);line-height:1.5}
.case-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}

/* ── STAR RATING INPUT ─────────────────────────────────────── */
.star-rating{display:flex;gap:4px}
.star-btn{background:none;border:none;cursor:pointer;font-size:1.4rem;color:var(--tx3);transition:color .15s;padding:2px;line-height:1}
.star-btn.active,.star-btn:hover{color:var(--gold)}

/* ── VIDEO EMBED ───────────────────────────────────────────── */
.video-embed-box{background:var(--s3);border-radius:var(--r);overflow:hidden;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;font-size:2rem;position:relative}
.video-embed-box iframe{width:100%;height:100%;border:none}

/* ── STATUS TIMELINE ───────────────────────────────────────── */
.timeline{display:flex;flex-direction:column;gap:0}
.tl-step{display:flex;gap:12px;position:relative}
.tl-step:not(:last-child)::before{content:"";position:absolute;left:14px;top:28px;bottom:-4px;width:1px;background:var(--border)}
.tl-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--border2);display:grid;place-items:center;font-size:.78rem;flex-shrink:0;margin-top:2px;background:var(--s2)}
.tl-dot.done{border-color:var(--green);background:var(--gndim);color:var(--green)}
.tl-dot.active{border-color:var(--blue);background:var(--bdim);color:var(--blue)}
.tl-dot.error{border-color:var(--red);background:var(--rdim);color:var(--red)}
.tl-content{flex:1;padding-bottom:16px}
.tl-label{font-size:.83rem;font-weight:600;margin-bottom:2px}
.tl-detail{font-size:.74rem;color:var(--tx2)}

/* ── ATTACHMENT UPLOAD ─────────────────────────────────────── */
.upload-box{border:2px dashed var(--border2);border-radius:var(--r);padding:20px;text-align:center;cursor:pointer;transition:var(--tr)}
.upload-box:hover,.upload-box.dragover{border-color:var(--blue);background:var(--bdim)}
.upload-box input{display:none}
.upload-preview{max-width:100%;max-height:120px;border-radius:var(--rs);margin-top:10px;object-fit:contain}
.upload-note{font-size:.74rem;color:var(--tx3);margin-top:5px}

/* ── CHAT ──────────────────────────────────────────────────────── */
.chat-list{display:flex;flex-direction:column;gap:8px}
.chat-item{background:var(--s2);border:1px solid var(--border);border-radius:var(--r);padding:14px;cursor:pointer;transition:var(--tr);display:flex;align-items:flex-start;gap:12px}
.chat-item:hover{border-color:var(--blue);background:var(--bdim)}
.chat-item.escalated{border-color:var(--red)}
.chat-item.unread{border-left:3px solid var(--blue)}
.chat-icon{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-size:1rem;flex-shrink:0}
.chat-body{flex:1;min-width:0}
.chat-subject{font-weight:700;font-size:.9rem;margin-bottom:3px}
.chat-preview{font-size:.77rem;color:var(--tx2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-meta{font-size:.68rem;color:var(--tx3);margin-top:4px;display:flex;gap:8px;flex-wrap:wrap}
.chat-badge{font-size:.65rem;font-weight:700;padding:1px 6px;border-radius:20px}
.cb-open{background:var(--gndim);color:var(--green)}
.cb-escalated{background:var(--rdim);color:var(--red)}
.cb-closed{background:var(--s3);color:var(--tx3)}
.cb-awaiting_gamer{background:var(--gdim);color:var(--gold)}
/* Chat window */
.chat-window{display:flex;flex-direction:column;height:calc(100vh - 200px);min-height:400px;background:var(--s1);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.chat-win-head{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;flex-shrink:0}
.chat-win-title{font-weight:700;font-size:.92rem}
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.msg-bubble{max-width:80%;display:flex;flex-direction:column;gap:3px}
.msg-bubble.mine{align-self:flex-end;align-items:flex-end}
.msg-bubble.theirs{align-self:flex-start;align-items:flex-start}
.msg-text{padding:10px 14px;border-radius:16px;font-size:.85rem;line-height:1.5;word-break:break-word}
.msg-bubble.mine .msg-text{background:var(--blue);color:#fff;border-radius:16px 16px 4px 16px}
.msg-bubble.theirs .msg-text{background:var(--s3);color:var(--tx);border-radius:16px 16px 16px 4px}
.msg-bubble .msg-text[data-system]{background:var(--gdim);color:var(--gold);font-style:italic;font-size:.78rem;border-radius:8px;text-align:center;align-self:center}
.msg-meta{font-size:.66rem;color:var(--tx3);display:flex;align-items:center;gap:4px}
.msg-sender-badge{font-size:.6rem;font-weight:700;padding:1px 5px;border-radius:10px;background:var(--bdim);color:var(--blue)}
.chat-input-row{padding:12px;border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0}
.chat-input-row .fi{flex:1;margin:0;border-radius:20px;padding:10px 16px}

/* ── SLOT REQUEST CALENDAR ─────────────────────────────────────── */
.sreq-form{background:var(--s2);border:1px solid var(--border2);border-radius:var(--r);padding:18px;margin-bottom:16px}
.sreq-item{background:var(--s2);border:1px solid var(--border);border-radius:var(--r);padding:14px;margin-bottom:10px;display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap}
.sreq-badge{font-size:.67rem;font-weight:700;padding:2px 8px;border-radius:20px}
.sreq-pending{background:var(--gdim);color:var(--gold)}
.sreq-approved{background:var(--gndim);color:var(--green)}
.sreq-sa_approved{background:rgba(167,139,250,.15);color:var(--purple)}
.sreq-rejected{background:var(--rdim);color:var(--red)}

/* ── REPUTATION / USER RATING ─────────────────────────────────── */
.rep-card{background:var(--s2);border:1px solid var(--border2);border-radius:var(--r);padding:16px}
.rep-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-top:10px}
.rep-item{background:var(--s3);border-radius:var(--rs);padding:10px;text-align:center}
.rep-val{font-family:"JetBrains Mono",monospace;font-size:1.4rem;font-weight:700;line-height:1}
.rep-label{font-size:.65rem;color:var(--tx3);margin-top:3px;text-transform:uppercase;letter-spacing:.05em}
.flag-note{background:var(--rdim);border:1px solid rgba(239,68,68,.2);border-radius:var(--rs);padding:8px 12px;font-size:.78rem;color:var(--red);margin-top:8px}

/* ── FORGOT PASSWORD ───────────────────────────────────────────── */
.forgot-link{font-size:.78rem;color:var(--blue);cursor:pointer;text-decoration:underline;display:inline-block;margin-top:8px}
.forgot-link:hover{opacity:.8}
.reset-token-box{background:var(--gndim);border:1px solid rgba(34,197,94,.25);border-radius:var(--r);padding:16px;margin:12px 0;text-align:center}
.reset-token-val{font-family:"JetBrains Mono",monospace;font-size:1.2rem;font-weight:700;color:var(--green);letter-spacing:.1em;margin:8px 0}

/* ── CONFIRM MODAL (replaces browser prompt) ───────────────────── */
.confirm-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}

/* ── HAMBURGER FIX ─────────────────────────────────────────────── */
.hamburger.hidden-nav{display:none!important}

/* ── AVATAR ─────────────────────────────────────────────────────── */
.avt-img{border-radius:50%;object-fit:cover;border:2px solid var(--border2)}
.avt-upload-area{border:2px dashed var(--border2);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--tr);position:relative;overflow:hidden}
.avt-upload-area:hover{border-color:var(--blue);background:var(--bdim)}
.avt-upload-area input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}

/* ── AUDIT LOG ROLE CHIP ───────────────────────────────────────── */
.audit-role-chip{font-size:.6rem;font-weight:700;padding:1px 5px;border-radius:10px;margin-left:3px;vertical-align:middle}
.arc-superadmin{background:rgba(245,158,11,.2);color:var(--gold)}
.arc-admin{background:rgba(59,130,246,.15);color:var(--blue)}
.arc-customer{background:rgba(45,212,191,.12);color:var(--teal)}

/* ── GAME LIBRARY ADMIN ──────────────────────────────────────── */
.game-req-badge{font-size:.67rem;font-weight:700;padding:2px 7px;border-radius:20px}
.grb-pending{background:var(--gdim);color:var(--gold)}
.grb-approved{background:var(--gndim);color:var(--green)}
.grb-rejected{background:var(--rdim);color:var(--red)}

/* ── ADMIN RATINGS ───────────────────────────────────────────── */
.rating-bar-wrap{height:6px;background:var(--s3);border-radius:3px;overflow:hidden;flex:1}
.rating-bar-fill{height:100%;border-radius:3px;background:var(--gold);transition:width .3s}
.admin-perf-card{background:var(--s2);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:12px}
.admin-perf-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.admin-score{font-family:"JetBrains Mono",monospace;font-size:2rem;font-weight:700;color:var(--gold)}
.feedback-item{background:var(--s3);border-radius:var(--rs);padding:10px 12px;margin-bottom:8px;font-size:.8rem}
.feedback-item .emg-tag{font-size:.65rem;font-weight:700;padding:1px 5px;border-radius:10px;background:rgba(239,68,68,.15);color:var(--red);margin-left:6px}

/* ── PRIORITY LABELS ─────────────────────────────────────────── */
.prio-urgent{color:var(--red);font-weight:700}
.prio-high{color:var(--orange);font-weight:600}
.prio-normal{color:var(--tx2)}
.prio-low{color:var(--tx3)}

/* ── EMERGENCY FEEDBACK BUTTON ───────────────────────────────── */
.emergency-btn{background:linear-gradient(135deg,#dc2626,#b91c1c);border:none;color:#fff;padding:8px 16px;border-radius:20px;cursor:pointer;font-family:"Outfit",sans-serif;font-size:.82rem;font-weight:700;transition:var(--tr);animation:emergencyPulse 2s ease-in-out infinite;display:flex;align-items:center;gap:6px}
.emergency-btn:hover{transform:scale(1.04);box-shadow:0 4px 16px rgba(220,38,38,.4)}
@keyframes emergencyPulse{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.4)}50%{box-shadow:0 0 0 8px rgba(220,38,38,0)}}
.emergency-uses{font-size:.7rem;color:var(--tx3);margin-top:3px;text-align:center}

/* ── GAMER CALENDAR SLOT VIEW ────────────────────────────────── */
.gcal-slot{background:var(--s2);border:1px solid var(--border);border-radius:var(--rs);padding:10px;margin-bottom:6px}
.gcal-slot.available{border-color:var(--green)}
.gcal-slot.booked{border-color:var(--blue)}
.gcal-slot.bidding{border-color:var(--gold)}
.bid-rules{background:var(--bdim);border:1px solid rgba(59,130,246,.2);border-radius:var(--rs);padding:10px 12px;font-size:.78rem;margin-bottom:12px;color:var(--tx2)}
.bid-rules strong{color:var(--blue)}

/* ── TYPING INDICATOR ────────────────────────────────────────── */
.typing-indicator{display:flex;align-items:center;gap:4px;padding:6px 10px;background:var(--s3);border-radius:12px;width:fit-content;margin-bottom:4px}
.typing-dot{width:6px;height:6px;border-radius:50%;background:var(--tx3);animation:typingBounce 1.4s infinite ease-in-out}
.typing-dot:nth-child(1){animation-delay:0s}
.typing-dot:nth-child(2){animation-delay:.2s}
.typing-dot:nth-child(3){animation-delay:.4s}
@keyframes typingBounce{0%,80%,100%{transform:scale(0);opacity:.4}40%{transform:scale(1);opacity:1}}
.typing-label{font-size:.7rem;color:var(--tx3);font-style:italic}

/* ── CHAT IMAGE ──────────────────────────────────────────────── */
.chat-img{max-width:200px;max-height:150px;border-radius:8px;margin-top:4px;object-fit:contain;cursor:pointer;transition:var(--tr)}
.chat-img:hover{opacity:.85}

/* ── SA EDIT USER MODAL ──────────────────────────────────────── */
.sa-edit-note{font-size:.74rem;color:var(--gold);background:var(--gdim);border-radius:var(--rs);padding:8px 10px;margin-bottom:12px}


/* ═══════════════════════════════ PS5 Arena V8 CSS ═══════════════════════════════ */

/* ── PS5-style menu button ── */
.menu-btn { display:none; background:rgba(59,130,246,.10); border:1.5px solid rgba(59,130,246,.28); cursor:pointer; padding:0; border-radius:var(--r); align-items:center; justify-content:center; width:40px; height:40px; transition:background .2s,border-color .2s; flex-shrink:0; touch-action:manipulation; overflow:hidden; }
.menu-btn:hover { background:rgba(59,130,246,.22); border-color:var(--blue); }
.menu-btn.menu-open { background:rgba(239,68,68,.12); border-color:rgba(239,68,68,.45); }
.ps-menu-icon { display:grid; grid-template-columns:1fr 1fr; gap:5px; padding:11px; }
.ps-dot { width:7px; height:7px; border-radius:50%; background:var(--blue); transition:background .2s; }
.menu-btn:hover .ps-dot { background:var(--tx); }
.menu-btn.menu-open .ps-dot { background:var(--red); }
.ps-menu-close { display:none; font-size:1.1rem; font-weight:700; color:var(--red); line-height:1; }
.menu-btn.menu-open .ps-menu-icon { display:none; }
.menu-btn.menu-open .ps-menu-close { display:flex; }
@media(max-width:767px){ .menu-btn { display:flex !important; } }

/* ── Sidebar tooltips ── */
.sb-item { position:relative; }
.sb-item[data-tip]:hover::after {
  content: attr(data-tip);
  position:absolute; left:calc(100% + 8px); top:50%; transform:translateY(-50%);
  background:#111827; color:#f9fafb; font-size:.7rem; padding:5px 9px; border-radius:6px;
  white-space:nowrap; pointer-events:none; z-index:999;
  opacity:1; box-shadow:0 2px 8px rgba(0,0,0,.3);
}
@media(max-width:767px){ .sb-item[data-tip]:hover::after { display:none; } }

/* ── Pending Cases ── */
.cases-section { margin-bottom:24px; }
.cases-section h3 { font-size:.9rem; font-weight:700; margin-bottom:10px; display:flex; align-items:center; gap:8px; }
.case-card { display:flex; align-items:flex-start; gap:10px; padding:12px; background:var(--s2); border-radius:var(--r); margin-bottom:8px; border:1px solid var(--border); }
.case-icon { width:38px; height:38px; border-radius:50%; display:grid; place-items:center; font-size:1.1rem; flex-shrink:0; }
.case-body { flex:1; min-width:0; }
.case-title { font-weight:700; font-size:.86rem; margin-bottom:4px; }
.case-detail { font-size:.76rem; color:var(--tx2); line-height:1.5; }
.case-actions { display:flex; flex-direction:column; gap:4px; flex-shrink:0; }
.req-badge-pending { background:rgba(245,158,11,.15); color:var(--gold); padding:1px 6px; border-radius:10px; font-size:.64rem; font-weight:700; }
.req-badge-pending_sa { background:rgba(59,130,246,.15); color:var(--blue); padding:1px 6px; border-radius:10px; font-size:.64rem; font-weight:700; }
.req-badge-approved { background:rgba(34,197,94,.15); color:var(--green); padding:1px 6px; border-radius:10px; font-size:.64rem; font-weight:700; }
.req-badge-rejected { background:rgba(239,68,68,.15); color:var(--red); padding:1px 6px; border-radius:10px; font-size:.64rem; font-weight:700; }

/* ── Live Session ── */
.live-session-wrap { display:flex; flex-direction:column; gap:14px; }
.live-top-bar { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.live-dual-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media(max-width:767px) { .live-dual-grid { grid-template-columns:1fr; } }
.live-panel { background:var(--s2); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; display:flex; flex-direction:column; }
.live-panel-head { display:flex; justify-content:space-between; align-items:center; padding:8px 12px; background:var(--s3); border-bottom:1px solid var(--border); }
.live-label { font-weight:700; font-size:.85rem; }
.live-dot-badge { display:flex; align-items:center; gap:5px; font-size:.68rem; font-weight:700; color:var(--red); }
.live-dot { width:7px; height:7px; border-radius:50%; background:var(--red); animation:pulse 1.4s infinite; }
@keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:.3;} }
.live-frame-wrap { position:relative; padding-bottom:56.25%; background:#000; }
.live-frame-wrap iframe { position:absolute; top:0; left:0; width:100%; height:100%; border:none; }
.live-placeholder { position:absolute; top:0; left:0; width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; font-size:2rem; color:var(--tx3); background:var(--s1); }
.live-placeholder span { font-size:.8rem; }
.live-input-row { display:flex; gap:6px; align-items:center; padding:10px 12px 0; }
.live-input-row .fi { flex:1; }

/* ── Badge adjustments ── */
.confirm-actions { display:flex; gap:8px; justify-content:flex-end; margin-top:12px; }
.bid-rules { background:rgba(245,158,11,.08); border:1px solid rgba(245,158,11,.2); border-radius:var(--r); padding:10px; font-size:.78rem; color:var(--gold); margin-bottom:12px; }
.ucr-section { max-width:520px; margin-top:16px; }
.cal-past { opacity:.65; }

/* ── Username preview ── */
.username-preview { font-size:.76rem; margin-top:3px; font-weight:600; }
.username-preview.available { color:var(--green); }
.username-preview.taken { color:var(--red); }


/* ══ V8 Fix CSS ══════════════════════════════════════════════════ */

/* ── Hamburger / PS5 menu button — all screen sizes ── */
.menu-btn {
  display: none !important;
  background: rgba(59,130,246,.10);
  border: 1.5px solid rgba(59,130,246,.28);
  cursor: pointer; padding: 0;
  border-radius: 8px;
  align-items: center; justify-content: center;
  width: 40px; height: 40px;
  transition: background .2s, border-color .2s;
  flex-shrink: 0;
  touch-action: manipulation;
  position: relative; z-index: 1001;
}
/* Show ONLY when logged in — JS sets display:flex */
.menu-btn.visible, .menu-btn[style*="flex"] {
  display: flex !important;
}
.menu-btn:hover { background: rgba(59,130,246,.22); border-color: var(--blue); }
.menu-btn.menu-open { background: rgba(239,68,68,.12); border-color: rgba(239,68,68,.45); }
.ps-menu-icon {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 5px; padding: 11px;
}
.ps-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--blue); transition: background .15s;
  display: block;
}
.menu-btn:hover .ps-dot { background: var(--tx); }
.menu-btn.menu-open .ps-dot { background: var(--red); }
.ps-menu-close {
  display: none; font-size: 1.1rem; font-weight: 700;
  color: var(--red); line-height: 1;
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
}
.menu-btn.menu-open .ps-menu-icon { display: none !important; }
.menu-btn.menu-open .ps-menu-close { display: block !important; }

/* Make sure hamburger only shows on mobile when logged in */
@media (max-width: 767px) {
  .menu-btn[style*="flex"] { display: flex !important; }
  .menu-btn[style*="none"] { display: none !important; }
}

/* ── Auth page layout fix ── */
.auth-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: var(--bg);
}
.auth-card {
  width: 100%;
  max-width: 440px;
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 32px 28px;
  box-shadow: 0 8px 32px rgba(0,0,0,.25);
}
.auth-brand { text-align: center; margin-bottom: 20px; }
.auth-logo {
  width: 56px; height: 56px; border-radius: 14px;
  background: linear-gradient(135deg,var(--blue),var(--purple));
  display: inline-grid; place-items: center;
  font-size: 1.4rem; font-weight: 900; color: #fff;
  margin-bottom: 12px;
}
.auth-brand h2 { font-size: 1.4rem; font-weight: 800; margin: 0 0 4px; }
.auth-brand p { color: var(--tx2); font-size: .88rem; margin: 0; }
.sec-banner {
  text-align: center; font-size: .73rem; color: var(--tx3);
  padding: 6px 12px; background: var(--s3);
  border-radius: 20px; margin-bottom: 16px;
  border: 1px solid var(--border);
}
.auth-tabs {
  display: flex; gap: 6px; margin-bottom: 20px;
  background: var(--s3); border-radius: 10px; padding: 4px;
}
.atab {
  flex: 1; padding: 8px 4px; border: none; cursor: pointer;
  background: transparent; color: var(--tx2); font-size: .82rem;
  font-weight: 600; border-radius: 7px; transition: all .2s;
  font-family: 'Outfit', sans-serif;
}
.atab.active { background: var(--blue); color: #fff; }
.atab:hover:not(.active) { background: var(--s2); color: var(--tx); }

/* ── Home page hero buttons layout ── */
.hero-cta {
  display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px;
}
.hero-cta .btn-sm {
  padding: 8px 14px !important; font-size: .78rem;
}
.btn-lg { padding: 14px 28px !important; font-size: 1rem !important; }

/* ── FAQ section ── */
.faq-list { display: flex; flex-direction: column; gap: 10px; }
.faq-item {
  background: var(--s2); border: 1px solid var(--border);
  border-radius: var(--r); overflow: hidden;
}
.faq-q {
  padding: 14px 16px; font-weight: 600; font-size: .88rem;
  cursor: pointer; display: flex; justify-content: space-between;
  align-items: center; user-select: none;
}
.faq-q:hover { background: var(--s3); }
.faq-a {
  padding: 0 16px; max-height: 0; overflow: hidden;
  transition: max-height .3s ease, padding .3s;
  font-size: .84rem; color: var(--tx2); line-height: 1.6;
}
.faq-item.open .faq-a { max-height: 300px; padding: 0 16px 14px; }
.faq-item.open .faq-chevron { transform: rotate(180deg); }
.faq-chevron { transition: transform .3s; font-size: .8rem; }

/* ── Contact section ── */
.contact-wrap { display: grid; grid-template-columns: 1fr 300px; gap: 20px; }
@media(max-width:767px) { .contact-wrap { grid-template-columns: 1fr; } }
.contact-card {
  background: var(--s2); border: 1px solid var(--border);
  border-radius: var(--r); padding: 20px;
  display: flex; flex-direction: column; gap: 12px;
}
.contact-info {
  background: var(--s2); border: 1px solid var(--border);
  border-radius: var(--r); padding: 20px;
  display: flex; flex-direction: column; gap: 14px;
}
.contact-item {
  font-size: .85rem; color: var(--tx2);
  padding: 8px 0; border-bottom: 1px solid var(--border);
}
.contact-item:last-child { border-bottom: none; }

/* ── Header layout fix ── */
.hdr {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; gap: 10px;
  padding: 0 16px; height: 58px;
  background: rgba(var(--bg-rgb, 6,9,15), .92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.hdr-space { flex: 1; }
.hdr-nav {
  display: flex; align-items: center; gap: 8px;
}

/* Fix sidebar overlay */
.sidebar-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.6);
  z-index: 199; display: none;
}
.sidebar-overlay.visible { display: block; }

/* ── App layout responsive ── */
.app-layout {
  display: flex; height: calc(100vh - 58px);
}
.sidebar {
  width: 220px; flex-shrink: 0;
  background: var(--s2); border-right: 1px solid var(--border);
  overflow-y: auto; display: flex; flex-direction: column;
  position: sticky; top: 58px; height: calc(100vh - 58px);
}
.main { flex: 1; overflow-y: auto; padding: 20px; }
@media(max-width:767px){
  .sidebar {
    position: fixed; left: -240px; top: 58px;
    width: 240px; height: calc(100vh - 58px);
    z-index: 200; transition: left .28s cubic-bezier(.4,0,.2,1);
    box-shadow: 4px 0 20px rgba(0,0,0,.3);
  }
  .sidebar.open { left: 0; }
  .main { padding: 14px; }
}

/* ── Intro sound active state ── */
.intro-sound.active {
  background: rgba(59,130,246,.2) !important;
  border-color: var(--blue) !important;
  color: var(--blue) !important;
}


/* ═══════════════════ PS5 Arena V9 — Final CSS ═══════════════════ */

/* ── PS5 Symbol Menu Button ── */
.ps-menu-btn {
  display: none;
  align-items: center; justify-content: center;
  width: 40px; height: 40px;
  background: var(--s2);
  border: 1.5px solid var(--border2);
  border-radius: 10px;
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  transition: background .15s, border-color .15s;
  touch-action: manipulation;
  z-index: 201;
}
.ps-menu-btn:hover { background: var(--s3); border-color: var(--blue); }
.ps-menu-btn.ps-menu-open { background: rgba(239,68,68,.12); border-color: rgba(239,68,68,.4); }
.ps-btn-icons {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 2px; padding: 6px;
}
.ps-sym {
  display: flex; align-items: center; justify-content: center;
  font-size: .72rem; font-weight: 800; width: 12px; height: 12px;
  color: var(--blue); transition: color .15s;
  font-family: 'Outfit', sans-serif;
}
.ps-menu-btn:hover .ps-sym { color: var(--tx); }
.ps-menu-btn.ps-menu-open .ps-sym { color: var(--red); }
.ps-close-x {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  font-size: 1rem; font-weight: 800; color: var(--red);
  line-height: 1;
}

/* Show on ALL screen sizes when logged in (JS sets display:'') */
@media (max-width: 767px) {
  .ps-menu-btn { display: flex !important; }
  /* hide old hamburger class if any remnant */
  .hamburger { display: none !important; }
}

/* ── Header ── */
.hdr {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; gap: 10px;
  padding: 0 16px; height: 58px;
  background: rgba(6,9,15,.94);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.hdr-space { flex: 1; min-width: 0; }
.hdr-uname {
  font-size: .82rem; font-weight: 600; max-width: 120px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
@media (max-width: 420px) { .hdr-uname { max-width: 70px; } }

/* ── App layout — fully responsive ── */
.app-layout {
  display: flex;
  height: calc(100vh - 58px);
  overflow: hidden;
}
.sidebar {
  width: 220px; flex-shrink: 0;
  background: var(--s2);
  border-right: 1px solid var(--border);
  overflow-y: auto; overflow-x: hidden;
  display: flex; flex-direction: column;
  transition: transform .28s cubic-bezier(.4,0,.2,1);
}
.main {
  flex: 1; overflow-y: auto; overflow-x: hidden;
  padding: 20px;
  min-width: 0;
}
@media (max-width: 767px) {
  .sidebar {
    position: fixed;
    top: 58px; left: 0;
    height: calc(100vh - 58px);
    transform: translateX(-100%);
    z-index: 200;
    box-shadow: 4px 0 20px rgba(0,0,0,.35);
  }
  .sidebar.open { transform: translateX(0); }
  .main { padding: 12px; }
}

/* ── Tables responsive ── */
.tw { overflow-x: auto; -webkit-overflow-scrolling: touch; }
table { min-width: 560px; }
@media (max-width: 600px) {
  table { min-width: 440px; font-size: .76rem; }
  th, td { padding: 6px 8px; }
}

/* ── Calendar responsive ── */
.cal-grid { grid-template-columns: repeat(7,1fr); }
.cal-cell { min-height: 80px; }
@media (max-width: 600px) {
  .cal-cell { min-height: 52px; padding: 2px; }
  .cal-dn { font-size: .7rem; }
  .cc { font-size: .55rem; padding: 1px 2px; }
  .cal-wrap { height: auto; }
}

/* ── Browse slots grid ── */
.slots-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}
@media (max-width: 600px) {
  .slots-grid { grid-template-columns: 1fr; }
}

/* ── Sidebar tooltip ── */
@media (min-width: 768px) {
  .sb-item { position: relative; }
  .sb-item[data-tip]:hover::after {
    content: attr(data-tip);
    position: absolute; left: calc(100% + 8px); top: 50%;
    transform: translateY(-50%);
    background: #111827; color: #f9fafb;
    font-size: .7rem; padding: 5px 9px; border-radius: 6px;
    white-space: nowrap; pointer-events: none; z-index: 999;
    box-shadow: 0 2px 8px rgba(0,0,0,.3);
  }
}

/* ── Auth page ── */
.auth-wrap {
  min-height: 100vh; display: flex;
  align-items: center; justify-content: center;
  padding: 20px; background: var(--bg);
}
.auth-card {
  width: 100%; max-width: 420px;
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 16px; padding: 28px 24px;
  box-shadow: 0 8px 32px rgba(0,0,0,.25);
}
@media (max-width: 480px) {
  .auth-card { padding: 20px 16px; border-radius: 12px; }
}
.auth-brand { text-align: center; margin-bottom: 18px; }
.auth-logo {
  width: 52px; height: 52px; border-radius: 13px;
  background: linear-gradient(135deg,var(--blue),var(--purple));
  display: inline-grid; place-items: center;
  font-size: 1.3rem; font-weight: 900; color: #fff; margin-bottom: 10px;
}
.auth-tabs {
  display: flex; gap: 4px; margin-bottom: 18px;
  background: var(--s3); border-radius: 10px; padding: 4px;
}
.atab {
  flex: 1; padding: 7px 4px; border: none; cursor: pointer;
  background: transparent; color: var(--tx2);
  font-size: .8rem; font-weight: 600;
  border-radius: 7px; transition: all .2s;
  font-family: 'Outfit', sans-serif;
}
.atab.active { background: var(--blue); color: #fff; }
.atab:hover:not(.active) { background: var(--s2); color: var(--tx); }

/* ── FAQ ── */
.faq-item { background: var(--s2); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; margin-bottom: 8px; }
.faq-q { padding: 14px 16px; font-weight: 600; font-size: .88rem; cursor: pointer; display: flex; justify-content: space-between; align-items: center; user-select: none; gap: 10px; }
.faq-q:hover { background: var(--s3); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s ease, padding .3s; font-size: .84rem; color: var(--tx2); line-height: 1.65; padding: 0 16px; }
.faq-item.open .faq-a { max-height: 400px; padding: 0 16px 14px; }
.faq-chevron { transition: transform .3s; font-size: .75rem; flex-shrink: 0; }
.faq-item.open .faq-chevron { transform: rotate(180deg); }

/* ── Contact ── */
.contact-wrap { display: grid; grid-template-columns: 1fr 280px; gap: 18px; }
@media (max-width: 680px) { .contact-wrap { grid-template-columns: 1fr; } }
.contact-card { background: var(--s2); border: 1px solid var(--border); border-radius: var(--r); padding: 18px; display: flex; flex-direction: column; gap: 12px; }
.contact-info { background: var(--s2); border: 1px solid var(--border); border-radius: var(--r); padding: 18px; display: flex; flex-direction: column; gap: 12px; }
.contact-item { font-size: .84rem; color: var(--tx2); padding: 8px 0; border-bottom: 1px solid var(--border); }
.contact-item:last-child { border-bottom: none; }

/* ── Live Session ── */
.live-top-bar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 14px; }
.live-dual-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 767px) { .live-dual-grid { grid-template-columns: 1fr; } }
.live-panel { background: var(--s2); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; }
.live-panel-head { display: flex; justify-content: space-between; align-items: center; padding: 8px 12px; background: var(--s3); border-bottom: 1px solid var(--border); }
.live-dot-badge { display: flex; align-items: center; gap: 5px; font-size: .68rem; font-weight: 700; color: var(--red); }
.live-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--red); animation: livePulse 1.4s infinite; }
@keyframes livePulse { 0%,100%{opacity:1;}50%{opacity:.3;} }
.live-frame-wrap { position: relative; padding-bottom: 56.25%; background: #000; }
.live-frame-wrap iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; }
.live-placeholder { position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; font-size: 2.2rem; color: var(--tx3); background: var(--s1); }
.live-placeholder span { font-size: .78rem; }
.live-input-row { display: flex; gap: 6px; align-items: center; padding: 10px 12px 0; }
.live-input-row .fi { flex: 1; }

/* ── Cases ── */
.cases-section { margin-bottom: 24px; }
.cases-section h3 { font-size: .9rem; font-weight: 700; margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
.case-card { display: flex; align-items: flex-start; gap: 10px; padding: 12px; background: var(--s2); border-radius: var(--r); margin-bottom: 8px; border: 1px solid var(--border); flex-wrap: wrap; }
.case-icon { width: 36px; height: 36px; border-radius: 50%; display: grid; place-items: center; font-size: 1rem; flex-shrink: 0; }
.case-body { flex: 1; min-width: 180px; }
.case-title { font-weight: 700; font-size: .86rem; margin-bottom: 4px; }
.case-detail { font-size: .76rem; color: var(--tx2); line-height: 1.5; }
.case-actions { display: flex; flex-direction: column; gap: 4px; flex-shrink: 0; }
@media (max-width: 500px) { .case-actions { flex-direction: row; flex-wrap: wrap; } }

/* ── Badges ── */
.req-badge-pending { background: rgba(245,158,11,.15); color: var(--gold); padding: 1px 6px; border-radius: 10px; font-size: .64rem; font-weight: 700; }
.req-badge-pending_sa { background: rgba(59,130,246,.15); color: var(--blue); padding: 1px 6px; border-radius: 10px; font-size: .64rem; font-weight: 700; }
.req-badge-approved { background: rgba(34,197,94,.15); color: var(--green); padding: 1px 6px; border-radius: 10px; font-size: .64rem; font-weight: 700; }
.req-badge-rejected { background: rgba(239,68,68,.15); color: var(--red); padding: 1px 6px; border-radius: 10px; font-size: .64rem; font-weight: 700; }
.sreq-badge { padding: 1px 6px; border-radius: 10px; font-size: .64rem; font-weight: 700; white-space: nowrap; }
.sreq-pending { background: rgba(245,158,11,.15); color: var(--gold); }
.sreq-approved, .sreq-sa_approved { background: rgba(34,197,94,.15); color: var(--green); }
.sreq-rejected { background: rgba(239,68,68,.15); color: var(--red); }

/* ── Confirm modal actions ── */
.confirm-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 14px; }

/* ── Username preview ── */
.username-preview { font-size: .76rem; margin-top: 4px; font-weight: 600; min-height: 16px; }
.username-preview.available { color: var(--green); }
.username-preview.taken { color: var(--red); }

/* ── Intro sound active ── */
.intro-sound.active { background: rgba(59,130,246,.2) !important; border-color: var(--blue) !important; color: var(--blue) !important; }

/* ── Sec-lock ── */
.sec-lock { text-align: center; padding: 80px 20px; font-size: 2rem; color: var(--tx3); }

/* ── Notification Bell ── */
.notif-btn:hover { transform: scale(1.15) !important; }
.notif-btn:hover span:first-child { animation: bellRing .4s ease; }
@keyframes bellRing {
  0%,100%{transform:rotate(0);}
  25%{transform:rotate(-18deg);}
  75%{transform:rotate(18deg);}
}
.notif-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 0; border-bottom: 1px solid var(--border);
  cursor: pointer; border-radius: 6px;
  transition: background .15s;
}
.notif-item:hover { background: var(--s2); padding: 10px 8px; }
.notif-item:last-child { border-bottom: none; }
.notif-icon {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--s3); display: grid;
  place-items: center; font-size: .9rem; flex-shrink: 0;
}
.notif-title { font-weight: 700; font-size: .84rem; }

/* ── Slot request form highlight transition ── */
.sreq-form {
  transition: border .3s;
  border: 2px solid transparent;
  border-radius: var(--r);
  padding: 16px;
  background: var(--s2);
  margin-top: 8px;
}
