/* SPIN007 — Manga Halftone · มังงะฮาล์ฟโทน
   Style #26 — light paper · halftone dots · 3px panel borders · SFX text */

:root{
  --paper:#FAFAFA;
  --paper-2:#F0EFEB;
  --ink:#0A0A0A;
  --ink-soft:#2A2A2A;
  --grey-1:#7A7A7A;
  --grey-2:#C4C4C4;
  --grey-3:#E2E2E0;
  --red:#E53E3E;
  --red-deep:#B91C1C;
  --yellow:#F6E05E;
  --yellow-deep:#D69E2E;
  --shadow:6px 6px 0 var(--ink);
  --shadow-sm:3px 3px 0 var(--ink);
  --shadow-red:6px 6px 0 var(--red);
  --shadow-yellow:6px 6px 0 var(--yellow-deep);
  --halftone:radial-gradient(circle at 1px 1px, rgba(10,10,10,0.18) 1px, transparent 1.4px) 0 0/8px 8px;
  --halftone-soft:radial-gradient(circle at 1px 1px, rgba(10,10,10,0.10) 1px, transparent 1.4px) 0 0/10px 10px;
  --halftone-red:radial-gradient(circle at 1px 1px, rgba(229,62,62,0.22) 1.2px, transparent 1.6px) 0 0/8px 8px;
  --speed-lines:repeating-linear-gradient(115deg, transparent 0 14px, rgba(10,10,10,.06) 14px 16px);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink)}
html{scroll-behavior:smooth}
body{
  font-family:'Mitr','Bai Jamjuree',system-ui,sans-serif;
  font-weight:400;
  font-size:15px;
  line-height:1.6;
  min-height:100vh;
  position:relative;
  overflow-x:hidden;
  background-color:var(--paper);
  background-image:var(--halftone-soft);
}

/* page paper texture overlay */
.halftone-overlay{
  position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:repeating-linear-gradient(0deg, transparent 0 2px, rgba(10,10,10,.012) 2px 3px);
}

a{color:var(--ink);text-decoration:none}
a:hover{color:var(--red)}
img{display:block;max-width:100%}
button,input,select,textarea{font:inherit;color:inherit}

.wrap{max-width:1280px;margin:0 auto;padding:0 24px;position:relative;z-index:2}

/* ========== TYPOGRAPHY ========== */
h1,h2,h3,h4{font-family:'Bangers','Anton','Mitr',sans-serif;letter-spacing:.5px;text-transform:uppercase;line-height:1.05;color:var(--ink)}
h1{font-size:22px;letter-spacing:1.5px}
h2{font-size:42px;letter-spacing:2px}
h3{font-size:24px;letter-spacing:1px}
h4{font-size:16px;letter-spacing:1px}
.dialog{font-family:'Sniglet','Mitr',sans-serif;font-weight:400;color:var(--ink-soft)}
small{font-family:'Mitr',sans-serif;font-size:12px;color:var(--grey-1)}
.ink-red{color:var(--red);text-shadow:2px 2px 0 var(--ink)}

/* ========== PANEL (comic frame) ========== */
.panel{
  background:var(--paper);
  border:3px solid var(--ink);
  border-radius:0;
  box-shadow:var(--shadow);
  position:relative;
  padding:18px;
}
.panel::before{
  content:"";
  position:absolute;inset:0;
  background-image:var(--halftone);
  background-size:8px 8px;
  opacity:0;pointer-events:none;
  transition:opacity .25s;
}
.panel:hover::before{opacity:.45}
.panel-tag{
  position:absolute;top:-13px;left:14px;
  background:var(--ink);color:var(--paper);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:13px;letter-spacing:1.5px;
  padding:3px 10px 4px;
  border:3px solid var(--ink);
  z-index:3;
}

.panel-divider{
  border:0;
  height:6px;
  margin:60px auto 32px;
  background:repeating-linear-gradient(90deg, var(--ink) 0 22px, transparent 22px 30px);
}

/* ========== HEADER ========== */
.topbar{
  position:sticky;top:0;z-index:30;
  background:var(--paper);
  border-bottom:3px solid var(--ink);
  box-shadow:0 4px 0 var(--ink);
}
.head-wrap{
  display:flex;align-items:center;gap:18px;
  padding:14px 24px;flex-wrap:wrap;
}
.logo{
  display:flex;align-items:center;gap:12px;
  text-decoration:none;
}
.logo-mark{
  width:50px;height:50px;
  background:var(--red);
  border:3px solid var(--ink);
  display:grid;place-items:center;
  position:relative;
  box-shadow:var(--shadow-sm);
  flex-shrink:0;
}
.logo-mark span{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:36px;color:var(--paper);
  -webkit-text-stroke:1.5px var(--ink);
  line-height:1;
  margin-top:-2px;
}
.logo-mark i{
  position:absolute;
  top:-7px;right:-7px;
  width:18px;height:18px;
  background:var(--yellow);
  border:2px solid var(--ink);
  border-radius:50%;
}
.logo-text h1{font-size:22px;color:var(--ink);line-height:1}
.logo-text h1 em{color:var(--red);font-style:normal;text-shadow:1.5px 1.5px 0 var(--ink)}
.logo-text small{font-family:'Bangers','Anton','Mitr',sans-serif;font-size:11px;letter-spacing:1.5px;color:var(--grey-1);display:block;margin-top:2px}

.nav-main{
  display:flex;align-items:center;gap:2px;flex:1;justify-content:center;flex-wrap:wrap;
}
.nav-main a{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:14px;letter-spacing:1.5px;
  padding:8px 12px;
  display:flex;align-items:center;gap:6px;
  color:var(--ink);
  border:2px solid transparent;
  position:relative;
  transition:.18s;
}
.nav-main a b{
  background:var(--ink);color:var(--paper);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  padding:1px 5px;
  font-size:11px;
  border-radius:0;
}
.nav-main a:hover{background:var(--yellow);border-color:var(--ink);transform:rotate(-1.5deg)}
.nav-main a.act{background:var(--red);color:var(--paper);border-color:var(--ink);box-shadow:var(--shadow-sm)}
.nav-main a.act b{background:var(--paper);color:var(--ink)}

.head-cta{display:flex;gap:8px}

.burger{
  display:none;
  background:var(--ink);color:var(--paper);
  border:3px solid var(--ink);
  padding:6px 12px;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:18px;letter-spacing:2px;
  cursor:pointer;
  box-shadow:var(--shadow-sm);
}

/* ========== BUTTONS ========== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:15px;letter-spacing:1.2px;
  padding:9px 18px;
  border:3px solid var(--ink);
  border-radius:0;
  cursor:pointer;
  text-transform:uppercase;
  transition:transform .15s, box-shadow .15s;
  background:var(--paper);
  color:var(--ink);
  box-shadow:var(--shadow-sm);
}
.btn:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink);color:var(--ink)}
.btn:active{transform:translate(0,0);box-shadow:1px 1px 0 var(--ink)}
.btn-red{background:var(--red);color:var(--paper)}
.btn-red:hover{background:var(--red-deep);color:var(--paper)}
.btn-yellow{background:var(--yellow);color:var(--ink)}
.btn-yellow:hover{background:var(--yellow-deep);color:var(--paper)}
.btn-ghost{background:var(--paper);color:var(--ink)}
.btn-big{padding:13px 28px;font-size:18px;letter-spacing:1.6px}
.btn-block{display:flex;width:100%;margin-top:10px}

/* ========== RIBBON ========== */
.ribbon{
  background:var(--yellow);
  border-bottom:3px solid var(--ink);
  overflow:hidden;
  position:relative;
  z-index:2;
}
.ribbon::before,.ribbon::after{
  content:"";position:absolute;top:0;bottom:0;width:60px;z-index:2;pointer-events:none;
}
.ribbon::before{left:0;background:linear-gradient(90deg, var(--yellow) 0%, transparent 100%)}
.ribbon::after{right:0;background:linear-gradient(-90deg, var(--yellow) 0%, transparent 100%)}
.ribbon-track{
  display:flex;gap:34px;
  white-space:nowrap;
  padding:9px 0;
  animation:ribbon 60s linear infinite;
  font-family:'Mitr',sans-serif;
  font-size:13px;
  font-weight:500;
  color:var(--ink);
}
.ribbon-track span{display:inline-flex;align-items:center;gap:8px}
.sfx-mini{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  background:var(--red);color:var(--paper);
  padding:2px 8px 3px;
  -webkit-text-stroke:.5px var(--ink);
  letter-spacing:1.5px;
  border:2px solid var(--ink);
  display:inline-block;
  transform:rotate(-3deg);
}
@keyframes ribbon{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ========== ROUTES ========== */
.route{display:none;padding:34px 0 60px}
.route.act{display:block;animation:pageFlip .55s ease-out}
@keyframes pageFlip{
  0%{opacity:0;transform-origin:left center;transform:perspective(1400px) rotateY(-22deg) translateX(-30px)}
  60%{opacity:1}
  100%{opacity:1;transform:perspective(1400px) rotateY(0) translateX(0)}
}
.page-curl{
  position:absolute;top:0;right:0;
  width:90px;height:90px;
  background:linear-gradient(135deg, transparent 50%, var(--ink) 50.5%, var(--ink) 51%, transparent 51%),
             linear-gradient(135deg, transparent 49%, var(--paper-2) 49.5%, var(--paper-2) 100%);
  z-index:5;
  pointer-events:none;
}
.page-curl span{
  position:absolute;
  bottom:18px;right:6px;
  transform:rotate(-45deg);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:11px;letter-spacing:1px;
  color:var(--ink);
  white-space:nowrap;
}

/* ========== HERO ========== */
.hero{padding:30px 0 12px}
.hero-grid{
  display:grid;
  grid-template-columns:1.7fr 1fr;
  gap:24px;
  align-items:stretch;
}
.hero-panel-main{
  min-height:480px;
  padding:36px 36px;
  position:relative;
  background:var(--paper);
  background-image:var(--halftone);
  background-size:9px 9px;
  overflow:hidden;
}
.hero-panel-main .speed-bg{
  position:absolute;inset:0;
  background:var(--speed-lines);
  pointer-events:none;
  opacity:.7;
}
.hero-text{position:relative;z-index:3;max-width:560px;margin-top:60px}
.hero-kicker{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:14px;letter-spacing:2px;
  background:var(--ink);color:var(--paper);
  padding:4px 14px 5px;
  display:inline-block;
  margin-bottom:14px;
}
.hero-text h2{
  font-size:64px;letter-spacing:2px;
  -webkit-text-stroke:0;
  margin-bottom:16px;
  text-shadow:4px 4px 0 var(--paper-2), 6px 6px 0 var(--ink);
}
.hero-text h2 .ink-red{
  color:var(--red);
  text-shadow:4px 4px 0 var(--ink), 6px 6px 0 var(--yellow);
}
.hero-text p.dialog{
  font-size:16px;line-height:1.7;
  background:var(--paper);
  border:2px solid var(--ink);
  padding:12px 16px;
  margin-bottom:22px;
  position:relative;
  box-shadow:3px 3px 0 var(--ink);
  font-weight:500;
}
.hero-text p.dialog::before{
  content:"";
  position:absolute;
  top:-12px;left:30px;
  width:0;height:0;
  border-left:10px solid transparent;
  border-right:10px solid transparent;
  border-bottom:12px solid var(--ink);
}
.hero-text p.dialog::after{
  content:"";
  position:absolute;
  top:-9px;left:32px;
  width:0;height:0;
  border-left:8px solid transparent;
  border-right:8px solid transparent;
  border-bottom:10px solid var(--paper);
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* SFX text */
.sfx{
  position:absolute;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  -webkit-text-stroke:2.5px var(--ink);
  text-shadow:6px 6px 0 var(--ink);
  font-weight:400;
  letter-spacing:2px;
  pointer-events:none;
  z-index:2;
}
.sfx-pow{
  top:24px;right:60px;
  font-size:90px;color:var(--red);
  transform:rotate(8deg);
  animation:sfxPulse 2.4s ease-in-out infinite;
}
.sfx-bang{
  top:130px;right:30px;
  font-size:74px;color:var(--yellow);
  transform:rotate(-12deg);
  animation:sfxPulse 3.2s ease-in-out infinite .4s;
}
.sfx-zoom{
  top:80px;right:80px;
  font-size:68px;color:var(--ink);
  transform:rotate(-7deg);
  animation:sfxPulse 2.8s ease-in-out infinite;
}
.sfx-boom{
  top:20px;right:70px;
  font-size:80px;color:var(--red);
  transform:rotate(5deg);
  animation:sfxPulse 2.6s ease-in-out infinite;
}
@keyframes sfxPulse{
  0%,100%{transform:rotate(var(--rot,8deg)) scale(1)}
  50%{transform:rotate(var(--rot,8deg)) scale(1.08)}
}
.sfx-pow{--rot:8deg}.sfx-bang{--rot:-12deg}.sfx-zoom{--rot:-7deg}.sfx-boom{--rot:5deg}

/* speech bubble big */
.speech{
  position:absolute;
  top:340px;left:24px;
  background:var(--paper);
  border:3px solid var(--ink);
  padding:10px 16px;
  max-width:300px;
  box-shadow:var(--shadow-sm);
  z-index:2;
  border-radius:18px;
}
.speech p{
  font-family:'Sniglet','Mitr',sans-serif;
  font-weight:800;
  font-size:14px;
  line-height:1.4;
  color:var(--ink);
  margin:0;
}
.speech::before{
  content:"";position:absolute;
  bottom:-18px;left:30px;
  width:0;height:0;
  border-left:14px solid transparent;
  border-right:14px solid transparent;
  border-top:18px solid var(--ink);
}
.speech::after{
  content:"";position:absolute;
  bottom:-13px;left:32px;
  width:0;height:0;
  border-left:12px solid transparent;
  border-right:12px solid transparent;
  border-top:14px solid var(--paper);
}

/* ========== HERO PANEL SIDE (QUEST) ========== */
.hero-panel-side{
  display:flex;flex-direction:column;
  background:var(--yellow);
  background-image:radial-gradient(circle at 2px 2px, rgba(10,10,10,.18) 1.5px, transparent 1.8px);
  background-size:11px 11px;
}
.quest-head{
  display:flex;justify-content:space-between;align-items:center;
  margin:8px 0 14px;
  padding-bottom:10px;
  border-bottom:2px dashed var(--ink);
}
.quest-head h3{font-size:22px}
.quest-stamp{
  background:var(--red);color:var(--paper);
  border:3px solid var(--ink);
  padding:6px 12px;
  text-align:center;
  box-shadow:var(--shadow-sm);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  transform:rotate(6deg);
}
.quest-stamp span{font-size:11px;display:block;letter-spacing:1.5px}
.quest-stamp b{font-size:24px;line-height:1}

.quest-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.quest{
  display:flex;gap:10px;align-items:flex-start;
  background:var(--paper);
  border:2px solid var(--ink);
  padding:10px 12px;
  position:relative;
  box-shadow:var(--shadow-sm);
}
.quest .qbox{
  width:24px;height:24px;
  background:var(--paper);
  border:2px solid var(--ink);
  flex-shrink:0;
  display:grid;place-items:center;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:14px;
  color:var(--ink);
}
.quest.done{background:var(--yellow);}
.quest.done .qbox{background:var(--ink);color:var(--paper)}
.quest>div{flex:1}
.quest b{font-family:'Bangers','Anton','Mitr',sans-serif;font-size:14px;display:block;letter-spacing:1px;color:var(--ink)}
.quest small{display:block;color:var(--grey-1);margin-top:2px}
.qprog{
  position:absolute;bottom:-2px;left:-2px;right:-2px;height:4px;
  background:var(--grey-3);
}
.qprog span{display:block;height:100%;background:var(--red)}

/* ========== COMBO ========== */
.combo-strip{padding-top:30px}
.combo-panel{
  display:grid;
  grid-template-columns:1.4fr 1.5fr auto;
  gap:24px;
  align-items:center;
  padding:20px 24px;
  background:var(--paper);
  background-image:var(--halftone);
  background-size:8px 8px;
}
.combo-left .sfx-mini-tag{
  display:inline-block;
  background:var(--ink);color:var(--yellow);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  padding:3px 10px;
  letter-spacing:1.5px;
  font-size:13px;
  border:2px solid var(--ink);
  margin-bottom:6px;
}
.combo-left h3{font-size:20px;margin-bottom:4px}
.combo-left p{font-family:'Mitr',sans-serif;font-size:13px;color:var(--ink-soft)}
.combo-meter{padding:10px 0}
.combo-bar{
  height:18px;
  background:var(--paper);
  border:3px solid var(--ink);
  position:relative;
  overflow:hidden;
}
.combo-bar span{
  display:block;height:100%;
  background:linear-gradient(90deg, var(--yellow) 0%, var(--red) 100%);
  background-image:repeating-linear-gradient(45deg, var(--yellow) 0 8px, var(--red) 8px 16px);
  transition:width .4s ease-out;
}
.combo-label{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-top:8px;
  font-family:'Bangers','Anton','Mitr',sans-serif;
}
.combo-label span{font-size:30px;color:var(--red);text-shadow:2px 2px 0 var(--ink);letter-spacing:1px}
.combo-label small{font-family:'Mitr',sans-serif;font-size:12px;color:var(--grey-1)}

/* ========== STATS ========== */
.stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:32px;
}
.stat{
  text-align:left;
  padding:16px 18px;
  background:var(--paper);
}
.stat .sfx-mini-tag{
  display:inline-block;
  background:var(--ink);color:var(--yellow);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  padding:2px 8px;
  font-size:10px;letter-spacing:1.5px;
  border:2px solid var(--ink);
  margin-bottom:8px;
  transform:rotate(-3deg);
}
.stat .k{
  font-family:'Mitr',sans-serif;
  font-size:12px;color:var(--grey-1);
  text-transform:uppercase;letter-spacing:.8px;
}
.stat .v{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:32px;letter-spacing:1.5px;
  color:var(--ink);
  text-shadow:2px 2px 0 var(--paper-2);
  margin-top:2px;
}
.stat .v small{font-size:14px;color:var(--red)}

/* ========== SECTION HEADERS ========== */
.section-block{margin-top:30px}
.section-title{
  font-size:36px;letter-spacing:1.5px;
  margin-bottom:6px;
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  text-shadow:3px 3px 0 var(--paper-2);
}
.section-title em{color:var(--red);font-style:normal;text-shadow:2px 2px 0 var(--ink)}
.section-title .sfx-mini{
  font-size:18px;
  padding:4px 10px;
  transform:rotate(-4deg);
}
.section-sub{
  font-family:'Mitr',sans-serif;
  font-size:14px;color:var(--grey-1);
  margin-bottom:22px;
  padding-left:6px;
  border-left:4px solid var(--ink);
}

/* ========== CATS ========== */
.cats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.cats .cat{
  display:block;
  text-align:center;
  padding:24px 18px 22px;
  background:var(--paper);
  border:3px solid var(--ink);
  position:relative;
  box-shadow:var(--shadow);
  transition:transform .2s, box-shadow .2s;
  background-image:var(--halftone-soft);
  background-size:9px 9px;
}
.cats .cat:hover{
  transform:translate(-3px,-3px) rotate(-1deg);
  box-shadow:9px 9px 0 var(--red);
  color:var(--ink);
}
.cat-num{
  position:absolute;top:-13px;left:14px;
  background:var(--red);color:var(--paper);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:13px;letter-spacing:1.5px;
  padding:3px 10px 4px;
  border:3px solid var(--ink);
}
.cat-icon{font-size:48px;line-height:1;margin:8px 0 12px;filter:drop-shadow(3px 3px 0 var(--ink))}
.cats .cat h3{font-size:22px;letter-spacing:1px;margin-bottom:4px}
.cats .cat p{font-family:'Mitr',sans-serif;font-size:13px;color:var(--grey-1)}
.casino-cats{grid-template-columns:repeat(4,1fr)}

/* ========== GAMES (slot grid) ========== */
.games{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:14px;
}
.game{
  background:var(--paper);
  border:3px solid var(--ink);
  position:relative;
  cursor:pointer;
  transition:transform .15s;
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.game:hover{transform:translate(-2px,-2px) rotate(-1.2deg);box-shadow:6px 6px 0 var(--red)}
.game-thumb{
  width:100%;
  aspect-ratio:3/4;
  background:var(--grey-3);
  display:block;
  border-bottom:3px solid var(--ink);
  position:relative;
}
.game-thumb img{
  width:100%;height:100%;object-fit:cover;
  filter:contrast(1.05) saturate(.92);
}
.game-thumb::after{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(10,10,10,.18) 1px, transparent 1.4px);
  background-size:5px 5px;
  mix-blend-mode:multiply;
  opacity:.55;
  pointer-events:none;
}
.game-info{padding:8px 10px;background:var(--paper)}
.game-info h4{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:14px;letter-spacing:1px;
  color:var(--ink);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin-bottom:1px;
}
.game-info small{
  font-family:'Mitr',sans-serif;
  font-size:11px;color:var(--grey-1);
}
.game-tag{
  position:absolute;top:6px;left:6px;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:11px;letter-spacing:1px;
  padding:2px 7px;
  z-index:2;
  border:2px solid var(--ink);
  box-shadow:2px 2px 0 var(--ink);
}
.game-tag.hot{background:var(--red);color:var(--paper);transform:rotate(-4deg)}
.game-tag.new{background:var(--yellow);color:var(--ink);top:6px;right:6px;left:auto;transform:rotate(5deg)}

.provider-tag{
  position:absolute;bottom:50px;right:6px;
  background:var(--ink);color:var(--paper);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:9px;letter-spacing:.8px;
  padding:1px 6px;
  z-index:2;
  border:1.5px solid var(--ink);
}
.thumb{width:100%;display:block}

/* ========== LIVE TABLES ========== */
.lives{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.live{
  background:var(--paper);
  border:3px solid var(--ink);
  box-shadow:var(--shadow);
  overflow:hidden;
  position:relative;
}
.live-thumb{
  height:180px;
  background:var(--grey-3);
  position:relative;
  border-bottom:3px solid var(--ink);
  overflow:hidden;
}
.live-thumb img{width:100%;height:100%;object-fit:cover;filter:contrast(1.1)}
.live-thumb::after{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(10,10,10,.2) 1px, transparent 1.4px);
  background-size:6px 6px;
  mix-blend-mode:multiply;
  opacity:.4;
}
.live-badge{
  position:absolute;top:10px;left:10px;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:13px;letter-spacing:1.5px;
  padding:3px 10px 4px;
  background:var(--red);color:var(--paper);
  border:2px solid var(--ink);
  box-shadow:2px 2px 0 var(--ink);
  transform:rotate(-3deg);
  z-index:2;
}
.live-badge::before{
  content:"●";color:var(--yellow);
  margin-right:5px;
  animation:livePulse 1.4s ease-in-out infinite;
}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.3}}
.live-info{padding:14px 16px}
.live-info h4{font-family:'Bangers','Anton','Mitr',sans-serif;font-size:18px;letter-spacing:1px;margin-bottom:4px}
.live-info p{font-family:'Mitr',sans-serif;font-size:12px;color:var(--grey-1);margin-bottom:10px}
.live-stats{
  display:flex;gap:16px;
  font-family:'Mitr',sans-serif;font-size:11px;
  border-top:2px dashed var(--ink);
  padding-top:8px;
}
.live-stats b{font-family:'Bangers','Anton','Mitr',sans-serif;font-size:14px;color:var(--red);letter-spacing:.5px}

/* ========== SPORTS TABLE ========== */
.sports-wrap{padding:0;overflow:hidden}
.sports-tab{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  font-family:'Mitr',sans-serif;
  font-size:13px;
  background:var(--paper);
}
.sports-tab thead th{
  background:var(--ink);color:var(--paper);
  padding:10px 12px;
  text-align:left;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:12px;letter-spacing:1.5px;
  border-bottom:3px solid var(--ink);
}
.sports-tab tbody tr{transition:background .15s}
.sports-tab tbody tr:nth-child(even){background:var(--paper-2)}
.sports-tab tbody tr:hover{background:var(--yellow)}
.sports-tab tbody td{
  padding:10px 12px;
  border-bottom:2px solid var(--grey-3);
  vertical-align:middle;
}
.odd{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:14px;letter-spacing:.5px;
  color:var(--ink);
  background:var(--paper);
  border:2px solid var(--ink);
  padding:4px 10px 5px;
  display:inline-block;
  cursor:pointer;
  box-shadow:2px 2px 0 var(--ink);
  transition:.15s;
}
.odd:hover{background:var(--red);color:var(--paper);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}
.odd.up{color:var(--red-deep)}
.odd.down{color:var(--ink-soft)}
.league-tag{
  background:var(--red);color:var(--paper);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:10px;letter-spacing:1px;
  padding:1px 7px 2px;
  border:1.5px solid var(--ink);
  display:inline-block;
}

/* ========== LOTTO GRID ========== */
.lotto-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.lotto-card{
  background:var(--paper);
  border:3px solid var(--ink);
  box-shadow:var(--shadow);
  padding:16px;
  position:relative;
  background-image:var(--halftone-soft);
  background-size:10px 10px;
  text-align:center;
}
.lotto-card .lotto-flag{
  position:absolute;top:-13px;right:14px;
  background:var(--yellow);color:var(--ink);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:11px;letter-spacing:1.5px;
  padding:3px 10px 4px;
  border:3px solid var(--ink);
}
.lotto-card h3{font-size:20px;margin-bottom:6px}
.lotto-card .lotto-time{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:14px;letter-spacing:1px;
  color:var(--grey-1);
  margin-bottom:10px;
}
.lotto-count{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:38px;letter-spacing:2.5px;
  color:var(--red);
  text-shadow:3px 3px 0 var(--ink);
  margin-bottom:12px;
  display:block;
}
.lotto-card .btn{padding:7px 14px;font-size:13px}

/* ========== LUCKY NUMBERS ========== */
.lucky-pad{
  text-align:center;
  padding:34px 24px;
  background-image:var(--halftone);
  background-size:8px 8px;
  background-color:var(--paper);
  margin-top:20px;
}
.lucky-numbers{
  display:flex;justify-content:center;gap:14px;
  margin-bottom:24px;flex-wrap:wrap;
}
.lucky-numbers span{
  width:64px;height:64px;
  background:var(--paper);
  border:3px solid var(--ink);
  box-shadow:var(--shadow-sm);
  display:grid;place-items:center;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:34px;
  color:var(--red);
  text-shadow:2px 2px 0 var(--ink);
}
.lucky-pad p.dialog{
  margin-top:18px;font-size:14px;
  font-style:italic;color:var(--ink);
}

/* ========== SPEECH FEED ========== */
.speech-feed{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:18px;
}
.bubble{
  background:var(--paper);
  border:3px solid var(--ink);
  border-radius:18px;
  padding:14px 18px;
  position:relative;
  box-shadow:var(--shadow-sm);
  font-family:'Sniglet','Mitr',sans-serif;
  animation:bubbleIn .35s ease-out;
}
.bubble.alt{background:var(--yellow)}
.bubble.win{background:var(--red);color:var(--paper)}
.bubble::before{
  content:"";position:absolute;
  bottom:-18px;left:24px;
  width:0;height:0;
  border-left:14px solid transparent;
  border-right:14px solid transparent;
  border-top:18px solid var(--ink);
}
.bubble::after{
  content:"";position:absolute;
  bottom:-13px;left:26px;
  width:0;height:0;
  border-left:12px solid transparent;
  border-right:12px solid transparent;
  border-top:14px solid var(--paper);
}
.bubble.alt::after{border-top-color:var(--yellow)}
.bubble.win::after{border-top-color:var(--red)}
.bubble .name{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:16px;letter-spacing:1px;
  display:block;margin-bottom:2px;
}
.bubble .amount{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:22px;letter-spacing:1px;
  color:var(--red);
  text-shadow:2px 2px 0 var(--ink);
  display:block;
}
.bubble.win .amount{color:var(--yellow)}
.bubble small{display:block;margin-top:2px;font-family:'Mitr',sans-serif;color:var(--grey-1)}
.bubble.win small{color:rgba(250,250,250,.85)}
@keyframes bubbleIn{from{opacity:0;transform:translateY(8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ========== PROVIDERS ========== */
.providers{
  display:flex;flex-wrap:wrap;gap:10px;
}
.providers span,.providers .provider-chip{
  padding:8px 14px;
  background:var(--paper);
  border:3px solid var(--ink);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:13px;letter-spacing:1.2px;
  box-shadow:var(--shadow-sm);
  cursor:default;
  transition:.15s;
}
.providers span:hover{background:var(--yellow);transform:translate(-1px,-1px)}
.providers .provider-chip.featured{background:var(--red);color:var(--paper)}

/* ========== WHY ========== */
.why{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.why-item{
  padding:22px 20px;
  text-align:left;
  background-image:var(--halftone-soft);
  background-size:10px 10px;
}
.why-num{margin-bottom:10px}
.why-item .sfx-mini-tag{
  display:inline-block;
  background:var(--red);color:var(--paper);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:18px;letter-spacing:1.5px;
  padding:3px 12px;
  border:2px solid var(--ink);
  box-shadow:var(--shadow-sm);
  transform:rotate(-4deg);
}
.why-item h4{font-size:20px;margin-bottom:4px;letter-spacing:1px}
.why-item p{font-family:'Mitr',sans-serif;font-size:13px;color:var(--ink-soft)}

/* ========== BANK ARCHIVE · MANGA HALFTONE STAIRCASE ========== */
.bank-archive{margin-top:10px}
.bank-archive-head{margin-bottom:34px}
.bank-archive-title{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:64px;letter-spacing:3px;
  line-height:1.05;
  margin-bottom:8px;
  display:inline-flex;align-items:center;gap:18px;flex-wrap:wrap;
  color:var(--ink);
  text-shadow:
    2px 2px 0 var(--yellow),
    4px 4px 0 var(--red),
    6px 6px 0 var(--ink);
  text-transform:uppercase;
}
.bank-archive-title em{
  color:var(--red);
  font-style:normal;
  text-shadow:
    2px 2px 0 var(--yellow),
    4px 4px 0 var(--ink),
    6px 6px 0 var(--paper-2);
}
.bank-archive-title small{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:24px;letter-spacing:2px;
  background:var(--ink);color:var(--yellow);
  padding:5px 14px 7px;
  border:3px solid var(--ink);
  box-shadow:4px 4px 0 var(--red);
  transform:rotate(-3deg);
  text-shadow:none;
  white-space:nowrap;
}

.bank-mosaic{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px 26px;
  position:relative;
  padding:18px 12px 44px;
  z-index:1;
}

.bank-panel{
  --ty:0px;
  position:relative;
  background:var(--paper);
  border:3px solid var(--ink);
  border-radius:0;
  box-shadow:6px 6px 0 var(--ink);
  padding:30px 18px 20px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:14px;
  cursor:pointer;
  font-family:inherit;
  color:var(--ink);
  transform:translateY(var(--ty));
  transition:transform .22s, box-shadow .22s;
  overflow:visible;
  text-align:center;
}

/* halftone overlay (inside panel, behind content) */
.bank-panel::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(0,0,0,.18) 1px, transparent 1px);
  background-size:4px 4px;
  pointer-events:none;
  opacity:.55;
  z-index:0;
}

/* Hover SFX (BIG, comic-book impact) — uses data-sfx */
.bank-panel::after{
  content:attr(data-sfx);
  position:absolute;
  top:-32px;
  right:-26px;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:48px;
  letter-spacing:2.5px;
  line-height:1;
  color:var(--red);
  -webkit-text-stroke:2.5px var(--ink);
  text-shadow:
    4px 4px 0 var(--yellow),
    7px 7px 0 var(--ink);
  transform:rotate(-15deg) scale(0);
  transition:transform .28s cubic-bezier(.34,1.65,.64,1), opacity .18s;
  pointer-events:none;
  white-space:nowrap;
  z-index:7;
  opacity:0;
}
.bank-panel:hover{
  transform:translate(-3px, calc(var(--ty) - 4px)) rotate(-1.4deg);
  box-shadow:9px 9px 0 var(--red);
  z-index:6;
}
.bank-panel:hover::after{
  transform:rotate(-15deg) scale(1);
  opacity:1;
}
.bank-panel:active{
  transform:translate(2px, calc(var(--ty) + 2px)) rotate(0);
  box-shadow:2px 2px 0 var(--ink);
}

/* Staircase translateY + uneven heights (alternating tall/short) */
.bank-panel.pos-1{--ty:0px;min-height:172px}
.bank-panel.pos-2{--ty:22px;min-height:158px}
.bank-panel.pos-3{--ty:-6px;min-height:188px}
.bank-panel.pos-4{--ty:14px;min-height:166px}
.bank-panel.pos-5{--ty:-10px;min-height:198px}
.bank-panel.pos-6{--ty:24px;min-height:160px}
.bank-panel.pos-7{--ty:-2px;min-height:182px}
.bank-panel.pos-8{--ty:30px;min-height:158px}
.bank-panel.pos-9{--ty:8px;min-height:190px}

/* Small SFX text above logo · rotated -8deg · varies per panel */
.bank-panel .bank-sfx{
  position:absolute;
  top:-13px;
  left:50%;
  transform:translateX(-50%) rotate(-8deg);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:15px;letter-spacing:1.5px;
  padding:3px 10px 4px;
  border:2.5px solid var(--ink);
  box-shadow:2px 2px 0 var(--ink);
  -webkit-text-stroke:.5px var(--ink);
  z-index:4;
  white-space:nowrap;
}
.bank-panel.pos-1 .bank-sfx{background:var(--red);color:var(--paper)}
.bank-panel.pos-2 .bank-sfx{background:var(--yellow);color:var(--ink)}
.bank-panel.pos-3 .bank-sfx{background:var(--ink);color:var(--yellow)}
.bank-panel.pos-4 .bank-sfx{background:var(--paper);color:var(--red)}
.bank-panel.pos-5 .bank-sfx{background:var(--red);color:var(--yellow)}
.bank-panel.pos-6 .bank-sfx{background:var(--yellow);color:var(--red)}
.bank-panel.pos-7 .bank-sfx{background:var(--ink);color:var(--paper)}
.bank-panel.pos-8 .bank-sfx{background:var(--red);color:var(--paper);transform:translateX(-50%) rotate(8deg)}
.bank-panel.pos-9 .bank-sfx{background:var(--yellow);color:var(--ink);transform:translateX(-50%) rotate(-12deg)}

.bank-panel .bank-frame{
  position:relative;
  z-index:2;
  width:100%;
  max-width:160px;
  display:grid;
  place-items:center;
  padding:6px;
  margin-top:8px;
}
.bank-panel .bank-frame img{
  display:block;
  width:100%;
  max-width:130px;
  height:64px;
  object-fit:contain;
  filter:contrast(1.05);
}

.bank-panel .bank-name{
  position:relative;
  z-index:2;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:18px;letter-spacing:2px;
  color:var(--ink);
  background:var(--paper);
  border:2.5px solid var(--ink);
  padding:3px 12px 4px;
  box-shadow:2px 2px 0 var(--ink);
  text-shadow:1.5px 1.5px 0 var(--paper-2);
}

/* Dialogue chevron arrows (3 of them, mid-row, manga-flow indicators) */
.bank-arrow{
  position:absolute;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:78px;
  line-height:.7;
  color:var(--red);
  -webkit-text-stroke:2.5px var(--ink);
  text-shadow:5px 5px 0 var(--ink);
  pointer-events:none;
  z-index:3;
  user-select:none;
  letter-spacing:-4px;
}
.bank-arrow.arrow-1{
  top:24%;
  left:calc(33.33% - 18px);
  transform:rotate(-12deg);
  color:var(--red);
}
.bank-arrow.arrow-2{
  top:54%;
  left:calc(66.66% - 18px);
  transform:rotate(8deg);
  color:var(--yellow);
  text-shadow:5px 5px 0 var(--ink), -2px -2px 0 var(--ink), 2px -2px 0 var(--ink), -2px 2px 0 var(--ink);
}
.bank-arrow.arrow-3{
  top:80%;
  left:calc(33.33% - 22px);
  transform:rotate(-6deg);
  color:var(--paper);
  text-shadow:5px 5px 0 var(--red), -1px -1px 0 var(--ink), 1px -1px 0 var(--ink), -1px 1px 0 var(--ink), 1px 1px 0 var(--ink);
}

/* ========== PAGE HEADERS (sub pages) ========== */
.page-header{
  position:relative;
  padding:34px 36px 30px;
  margin-bottom:24px;
  background-image:var(--halftone);
  background-size:10px 10px;
  overflow:hidden;
}
.page-header h2{
  font-size:54px;letter-spacing:2px;
  margin-bottom:6px;
  text-shadow:3px 3px 0 var(--paper-2), 5px 5px 0 var(--ink);
}
.page-header p{font-family:'Mitr',sans-serif;font-size:14px;color:var(--ink-soft);max-width:520px}

/* ========== FILTER BAR ========== */
.filter-bar{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-bottom:22px;
}
.filter{
  background:var(--paper);
  border:3px solid var(--ink);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:13px;letter-spacing:1.2px;
  padding:7px 14px;
  cursor:pointer;
  box-shadow:var(--shadow-sm);
  transition:.15s;
}
.filter:hover{background:var(--yellow);transform:translate(-1px,-1px)}
.filter.act{background:var(--red);color:var(--paper)}

/* ========== THAI TEAMS ========== */
.thai-teams{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:12px;
  margin-top:14px;
}
.thai-team{
  text-align:center;
  padding:14px 10px;
  background-image:var(--halftone-soft);
  background-size:10px 10px;
}
.thai-team b{font-family:'Bangers','Anton','Mitr',sans-serif;font-size:14px;letter-spacing:1px;display:block;margin-bottom:2px}
.thai-team small{font-family:'Mitr',sans-serif;font-size:11px;color:var(--grey-1)}

/* ========== BANK PAGE ========== */
.bank-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.power-pane{padding:24px}
.power-pane h3{font-size:22px;margin-bottom:14px;letter-spacing:1px}
.field{margin-bottom:12px}
.field label{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:12px;letter-spacing:1.2px;
  display:block;margin-bottom:4px;
  color:var(--ink-soft);
}
.field input,.field select{
  width:100%;
  background:var(--paper);
  border:3px solid var(--ink);
  padding:9px 12px;
  font-family:'Mitr',sans-serif;
  font-size:14px;
  color:var(--ink);
  outline:none;
  box-shadow:var(--shadow-sm);
}
.field input:focus,.field select:focus{box-shadow:5px 5px 0 var(--red);transform:translate(-2px,-2px)}
.qchips{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.qchips span{
  background:var(--paper);
  border:2px solid var(--ink);
  padding:5px 11px;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:12px;letter-spacing:1px;
  cursor:pointer;
  box-shadow:2px 2px 0 var(--ink);
  transition:.15s;
}
.qchips span:hover{background:var(--yellow);transform:translate(-1px,-1px)}

.bonus-panel{
  margin-top:14px;
  background:var(--yellow);
  border:3px solid var(--ink);
  padding:10px 14px;
  position:relative;
  box-shadow:var(--shadow-sm);
  display:flex;align-items:center;gap:14px;
}
.bonus-panel .sfx-mini{
  background:var(--red);color:var(--paper);
  font-size:14px;
  padding:3px 10px;
  transform:rotate(-6deg);
  -webkit-text-stroke:0;
}
.bonus-panel p{font-family:'Mitr',sans-serif;font-size:13px;color:var(--ink)}
.bonus-panel b{color:var(--red-deep)}

.dash-hr{
  border:0;
  height:0;
  border-top:2px dashed var(--ink);
  margin:18px 0;
}

/* ========== VIP RANKS ========== */
.ranks{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:12px;
}
.rank{
  text-align:center;
  padding:24px 14px 18px;
  position:relative;
  background-image:var(--halftone-soft);
  background-size:9px 9px;
  background-color:var(--paper);
}
.rank-tag{
  position:absolute;top:-13px;left:50%;
  transform:translateX(-50%);
  background:var(--ink);color:var(--paper);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:11px;letter-spacing:1.5px;
  padding:3px 10px 4px;
  border:3px solid var(--ink);
}
.rank.pro .rank-tag{background:var(--red);color:var(--paper)}
.rank.pro{transform:scale(1.04);box-shadow:var(--shadow-red)}
.rank-icon{font-size:48px;line-height:1;margin:6px 0 8px;filter:drop-shadow(3px 3px 0 var(--ink))}
.rank h3{font-size:18px;margin-bottom:2px;letter-spacing:1px}
.rank small{font-family:'Mitr',sans-serif;font-size:11px;color:var(--grey-1);display:block;margin-bottom:10px}
.rank ul{list-style:none;text-align:left}
.rank ul li{
  font-family:'Mitr',sans-serif;
  font-size:12px;
  padding:4px 0 4px 18px;
  position:relative;
  color:var(--ink-soft);
}
.rank ul li::before{
  content:"⚡";
  position:absolute;left:0;top:4px;
  font-size:11px;color:var(--red);
}

/* ========== HERO COLLECTION ========== */
.collection-meta{
  padding:18px 22px;
  margin-bottom:20px;
  background-image:var(--halftone-soft);
  background-size:10px 10px;
}
.meta-row{display:flex;align-items:center;gap:14px;margin-bottom:10px;flex-wrap:wrap}
.meta-row h3{font-size:20px}
.meta-row .sfx-mini-tag{
  background:var(--red);color:var(--paper);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:11px;letter-spacing:1.5px;
  padding:3px 10px;
  border:2px solid var(--ink);
  transform:rotate(-3deg);
  display:inline-block;
}
.collection-stat{
  margin-left:auto;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  text-align:right;
}
.collection-stat b{font-size:32px;color:var(--red);text-shadow:2px 2px 0 var(--ink);letter-spacing:1px}
.collection-stat small{font-family:'Mitr',sans-serif;font-size:13px;color:var(--grey-1);display:block;margin-top:-4px}
.meta-bar{
  height:14px;
  background:var(--paper);
  border:3px solid var(--ink);
  margin-bottom:14px;
}
.meta-bar span{
  display:block;height:100%;
  background:repeating-linear-gradient(45deg, var(--red) 0 8px, var(--yellow) 8px 16px);
  transition:width .4s ease-out;
}
.meta-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.meta-actions small{font-family:'Mitr',sans-serif;color:var(--grey-1);font-size:12px}

.hero-collection{
  display:grid;
  grid-template-columns:repeat(10,1fr);
  gap:8px;
}
.hero-card{
  aspect-ratio:3/4;
  background:var(--paper);
  border:3px solid var(--ink);
  position:relative;
  cursor:pointer;
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:.18s;
}
.hero-card:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--red)}
.hero-card .hero-num{
  position:absolute;top:3px;left:4px;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:10px;letter-spacing:.5px;
  color:var(--ink);
  background:var(--paper);
  padding:0 4px;
  border:1.5px solid var(--ink);
}
.hero-card .hero-icon{
  width:100%;height:60%;
  display:grid;place-items:center;
  font-size:40px;line-height:1;
  background:var(--paper);
  background-image:radial-gradient(circle at 1px 1px, rgba(10,10,10,.16) 1px, transparent 1.4px);
  background-size:5px 5px;
  border-bottom:2px solid var(--ink);
  filter:drop-shadow(2px 2px 0 var(--ink));
}
.hero-card .hero-name{
  padding:4px 5px 2px;
  text-align:center;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:10px;letter-spacing:.6px;
  color:var(--ink);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  line-height:1.1;
}
.hero-card .hero-rarity{
  padding:0 5px 4px;
  text-align:center;
  font-family:'Mitr',sans-serif;
  font-size:9px;
  color:var(--grey-1);
  letter-spacing:.5px;
}
.hero-card.locked{
  background:var(--grey-3);
  filter:grayscale(1) brightness(.92);
}
.hero-card.locked .hero-icon{filter:none}
.hero-card.locked::after{
  content:"?";
  position:absolute;inset:0;
  background:rgba(10,10,10,.55);
  color:var(--paper);
  display:grid;place-items:center;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:46px;
  text-shadow:2px 2px 0 var(--ink);
  pointer-events:none;
}
.hero-card.rare{box-shadow:4px 4px 0 var(--red)}
.hero-card.epic{box-shadow:4px 4px 0 var(--yellow-deep)}
.hero-card.legend{box-shadow:4px 4px 0 var(--red-deep)}

/* ========== ACCOUNT (LOGIN) ========== */
.acct-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.acct-pane{padding:24px}
.tabs{
  display:flex;gap:0;margin-bottom:16px;
  border-bottom:3px solid var(--ink);
}
.tabs span{
  flex:1;
  padding:10px 16px;
  background:var(--paper);
  border:3px solid var(--ink);
  border-bottom:0;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:14px;letter-spacing:1.2px;
  text-align:center;
  cursor:pointer;
  transition:.15s;
  margin-right:-3px;
  margin-bottom:-3px;
}
.tabs span.act{background:var(--red);color:var(--paper);position:relative;z-index:2}
.tabs span:hover:not(.act){background:var(--yellow)}
.bonus-list{display:flex;flex-direction:column;gap:10px}
.bonus-item{
  display:flex;gap:12px;align-items:center;
  background:var(--paper);
  border:2px solid var(--ink);
  padding:10px 12px;
  box-shadow:var(--shadow-sm);
}
.bonus-item .sfx-mini-tag{
  background:var(--yellow);color:var(--ink);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:14px;letter-spacing:1px;
  padding:4px 10px;
  border:2px solid var(--ink);
  flex-shrink:0;
  transform:rotate(-4deg);
  white-space:nowrap;
}
.bonus-item b{font-family:'Bangers','Anton','Mitr',sans-serif;font-size:14px;letter-spacing:.8px;display:block}
.bonus-item small{font-family:'Mitr',sans-serif;font-size:12px;color:var(--grey-1);display:block}

/* ========== HELP / FAQ ========== */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:24px}
.contact-pane{padding:22px}
.contact-pane h3{font-size:22px;margin-bottom:12px;letter-spacing:1px}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.contact-list li{
  font-family:'Mitr',sans-serif;
  font-size:14px;
  padding:8px 12px;
  background:var(--paper-2);
  border:2px solid var(--ink);
  box-shadow:var(--shadow-sm);
}
.contact-pane details{
  border:2px solid var(--ink);
  padding:0;
  margin-bottom:8px;
  box-shadow:var(--shadow-sm);
  background:var(--paper);
}
.contact-pane summary{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:14px;letter-spacing:.8px;
  padding:10px 14px;
  cursor:pointer;
  list-style:none;
  position:relative;
}
.contact-pane summary::after{
  content:"+";
  position:absolute;right:14px;top:8px;
  font-size:22px;color:var(--red);
}
.contact-pane details[open] summary::after{content:"−"}
.contact-pane details[open] summary{background:var(--yellow)}
.contact-pane details p{
  font-family:'Mitr',sans-serif;
  font-size:13px;
  color:var(--ink-soft);
  padding:10px 14px 14px;
  border-top:2px dashed var(--ink);
  line-height:1.7;
}

/* ========== FOOTER ========== */
.footer{
  background:var(--ink);
  color:var(--paper);
  border-top:3px solid var(--ink);
  margin-top:60px;
  padding:40px 0 24px;
  position:relative;
  z-index:2;
  background-image:radial-gradient(circle at 1px 1px, rgba(250,250,250,0.08) 1px, transparent 1.4px);
  background-size:8px 8px;
}
.foot{
  display:grid;
  grid-template-columns:2.5fr 1fr 1fr 1fr;
  gap:30px;
  padding-bottom:24px;
  border-bottom:2px solid rgba(250,250,250,.18);
}
.foot p{font-family:'Mitr',sans-serif;font-size:13px;color:rgba(250,250,250,.7);margin:8px 0 12px}
.logo-foot .logo-text h1{color:var(--paper)}
.logo-foot .logo-text small{color:rgba(250,250,250,.6)}
.foot h4{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:16px;letter-spacing:1.5px;
  color:var(--yellow);
  margin-bottom:10px;
  border-bottom:2px solid rgba(255,255,255,.2);
  padding-bottom:6px;
}
.foot ul{list-style:none}
.foot ul li{
  font-family:'Mitr',sans-serif;
  font-size:13px;
  padding:4px 0;
  color:rgba(250,250,250,.8);
}
.foot ul li a{color:rgba(250,250,250,.8)}
.foot ul li a:hover{color:var(--yellow)}
.copyright{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;
  margin-top:18px;
  font-family:'Mitr',sans-serif;
  font-size:11px;
  color:rgba(250,250,250,.55);
}

/* ========== FLOATING ========== */
.float{
  position:fixed;
  right:20px;bottom:24px;
  display:flex;flex-direction:column;gap:10px;
  z-index:40;
}
.float-btn{
  width:50px;height:50px;
  background:var(--paper);
  border:3px solid var(--ink);
  display:grid;place-items:center;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:18px;
  cursor:pointer;
  box-shadow:var(--shadow-sm);
  transition:.15s;
  color:var(--ink);
}
.float-btn:hover{transform:translate(-2px,-2px) rotate(-4deg);box-shadow:5px 5px 0 var(--red);background:var(--yellow)}
.float-btn.line{background:#06C755;color:var(--paper);font-size:22px}
.float-btn.tele{background:#0088CC;color:var(--paper)}
.float-btn.top{background:var(--red);color:var(--paper);font-size:22px}

/* ========== TOAST ========== */
.toast-host{
  position:fixed;
  top:90px;right:20px;
  display:flex;flex-direction:column;gap:10px;
  z-index:60;
  pointer-events:none;
}
.toast{
  background:var(--paper);
  border:3px solid var(--ink);
  padding:12px 18px 14px;
  border-radius:18px;
  position:relative;
  box-shadow:var(--shadow);
  pointer-events:auto;
  min-width:240px;max-width:340px;
  animation:toastIn .35s ease-out;
}
.toast::before{
  content:"";position:absolute;
  bottom:-18px;left:24px;
  width:0;height:0;
  border-left:14px solid transparent;
  border-right:14px solid transparent;
  border-top:18px solid var(--ink);
}
.toast::after{
  content:"";position:absolute;
  bottom:-13px;left:26px;
  width:0;height:0;
  border-left:12px solid transparent;
  border-right:12px solid transparent;
  border-top:14px solid var(--paper);
}
.toast .sfx-mini{
  display:inline-block;
  background:var(--red);color:var(--paper);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:14px;letter-spacing:1.2px;
  padding:3px 10px;
  border:2px solid var(--ink);
  margin-bottom:5px;
  -webkit-text-stroke:0;
}
.toast b{
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:16px;letter-spacing:1px;
  display:block;
}
.toast p{
  font-family:'Sniglet','Mitr',sans-serif;
  font-weight:400;
  font-size:13px;
  color:var(--ink-soft);
  margin-top:2px;
}
@keyframes toastIn{from{opacity:0;transform:translateX(20px) scale(.9)}to{opacity:1;transform:translateX(0) scale(1)}}
.toast.fade-out{animation:toastOut .25s ease-in forwards}
@keyframes toastOut{to{opacity:0;transform:translateX(40px)}}

/* ========== MODAL ========== */
.modal-mask{
  position:fixed;inset:0;
  background:rgba(10,10,10,.45);
  display:none;
  place-items:center;
  z-index:80;
  padding:20px;
  background-image:radial-gradient(circle at 1px 1px, rgba(250,250,250,.18) 1px, transparent 1.4px);
  background-size:6px 6px;
}
.modal-mask.show{display:grid}
.modal{
  width:100%;
  max-width:440px;
  padding:28px 26px;
  background:var(--paper);
  background-image:var(--halftone);
  background-size:8px 8px;
  text-align:center;
  position:relative;
  animation:modalIn .35s ease-out;
}
@keyframes modalIn{from{opacity:0;transform:scale(.9) rotate(-2deg)}to{opacity:1;transform:scale(1) rotate(0)}}
.modal .close{
  position:absolute;top:8px;right:8px;
  width:34px;height:34px;
  background:var(--red);color:var(--paper);
  border:3px solid var(--ink);
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:22px;
  cursor:pointer;
  box-shadow:2px 2px 0 var(--ink);
}
.gacha-card{
  margin:22px 0 14px;
  padding:20px 16px;
  background:var(--paper);
  border:3px solid var(--ink);
  box-shadow:var(--shadow-sm);
  position:relative;
  background-image:radial-gradient(circle at 1px 1px, rgba(229,62,62,.18) 1px, transparent 1.4px);
  background-size:5px 5px;
}
.gacha-card .gacha-icon{font-size:74px;line-height:1;filter:drop-shadow(4px 4px 0 var(--ink));margin-bottom:10px}
.gacha-card h4{font-size:24px;letter-spacing:1.5px;margin-bottom:4px}
.gacha-card p.dialog{font-family:'Sniglet','Mitr',sans-serif;font-weight:800;font-size:14px;color:var(--ink-soft)}
.gacha-card .gacha-rarity{
  position:absolute;top:-13px;right:14px;
  font-family:'Bangers','Anton','Mitr',sans-serif;
  font-size:13px;letter-spacing:1.2px;
  padding:3px 10px 4px;
  border:3px solid var(--ink);
}
.gacha-rarity.common{background:var(--grey-2);color:var(--ink)}
.gacha-rarity.rare{background:var(--yellow);color:var(--ink)}
.gacha-rarity.epic{background:var(--red);color:var(--paper)}
.gacha-rarity.legend{background:var(--ink);color:var(--yellow)}

/* ========== SPEED LINE host (scroll-triggered) ========== */
.speed-host{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1;
  opacity:0;
  background:repeating-linear-gradient(95deg, transparent 0 22px, rgba(10,10,10,.06) 22px 23px);
  transition:opacity .15s;
}
.speed-host.go{opacity:.85;animation:speedShift .35s linear}
@keyframes speedShift{from{background-position:0 0}to{background-position:60px 0}}

/* ========== RESPONSIVE ========== */
@media (max-width: 1100px){
  .nav-main{order:4;width:100%;justify-content:flex-start}
  .nav-main a{font-size:13px;padding:6px 8px}
  .games{grid-template-columns:repeat(4,1fr)}
  .hero-collection{grid-template-columns:repeat(8,1fr)}
  .ranks{grid-template-columns:repeat(3,1fr)}
  .casino-cats{grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 860px){
  .head-wrap{padding:10px 16px;gap:10px}
  .burger{display:inline-flex}
  .nav-main{display:none;flex-direction:column;width:100%;gap:6px;padding:12px 0;border-top:2px solid var(--ink)}
  .nav-main.show{display:flex}
  .head-cta{margin-left:auto}
  .head-cta .btn{padding:7px 12px;font-size:13px}
  .hero-grid{grid-template-columns:1fr;gap:16px}
  .hero-text h2{font-size:42px}
  .sfx-pow{font-size:60px;right:30px}
  .sfx-bang{font-size:48px;top:80px;right:14px}
  .sfx-zoom{font-size:44px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .cats{grid-template-columns:repeat(2,1fr)}
  .casino-cats{grid-template-columns:repeat(2,1fr)}
  .games{grid-template-columns:repeat(3,1fr)}
  .lives{grid-template-columns:1fr}
  .lotto-grid{grid-template-columns:repeat(2,1fr)}
  .why{grid-template-columns:repeat(2,1fr)}
  .bank-archive-title{font-size:48px;letter-spacing:2px}
  .bank-archive-title small{font-size:18px}
  .bank-mosaic{grid-template-columns:repeat(2,1fr);gap:24px 18px}
  .bank-panel.pos-1,.bank-panel.pos-3,.bank-panel.pos-5,.bank-panel.pos-7,.bank-panel.pos-9{--ty:0px}
  .bank-panel.pos-2,.bank-panel.pos-4,.bank-panel.pos-6,.bank-panel.pos-8{--ty:18px}
  .bank-arrow{font-size:54px}
  .bank-arrow.arrow-1{top:18%;left:calc(50% - 14px)}
  .bank-arrow.arrow-2{top:50%;left:8%}
  .bank-arrow.arrow-3{top:78%;left:calc(50% - 18px)}
  .ranks{grid-template-columns:repeat(2,1fr)}
  .ranks .rank.pro{transform:none}
  .hero-collection{grid-template-columns:repeat(5,1fr)}
  .acct-grid,.bank-grid,.contact-grid{grid-template-columns:1fr}
  .combo-panel{grid-template-columns:1fr;gap:14px}
  .thai-teams{grid-template-columns:repeat(3,1fr)}
  .foot{grid-template-columns:1fr 1fr;gap:24px}
  .page-header h2{font-size:38px}
  .section-title{font-size:28px}
  h2{font-size:32px}
}
@media (max-width: 480px){
  .games{grid-template-columns:repeat(2,1fr)}
  .hero-collection{grid-template-columns:repeat(4,1fr)}
  .bank-archive-title{font-size:36px;letter-spacing:1.5px}
  .bank-archive-title small{font-size:14px;padding:3px 10px}
  .bank-mosaic{grid-template-columns:1fr;gap:30px 0;padding:14px 6px 30px}
  .bank-panel{--ty:0px !important;min-height:140px !important;padding:24px 14px 16px}
  .bank-panel .bank-frame img{height:54px}
  .bank-panel::after{font-size:36px;top:-22px;right:-12px}
  .bank-arrow{font-size:42px}
  .bank-arrow.arrow-1{top:18%;left:calc(85% - 12px)}
  .bank-arrow.arrow-2{top:50%;left:5%}
  .bank-arrow.arrow-3{top:80%;left:calc(85% - 14px)}
  .foot{grid-template-columns:1fr}
  .lotto-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .lucky-numbers span{width:48px;height:48px;font-size:24px}
  .hero-text h2{font-size:36px}
}
