/* =================================================================
   LSM248 · #02 / TIGER PROJECT
   STYLE #14 — BOXING RING มวยไทย · เวทีหมัดไทย
   PALETTE: ring crimson · leather brown · brass · canvas cream · sweat black
   ลายเซ็น: เชือกเวที · ปุ่มสตัดทองเหลือง · เหงื่อหยด · ระฆังยก
   ================================================================= */

:root {
  /* CORE PALETTE */
  --crimson:   #8B0000;
  --crimson-2: #A01515;
  --crimson-3: #6E0000;
  --crimson-d: #380404;

  --leather:   #5D4037;
  --leather-2: #7A5448;
  --leather-d: #3E2723;
  --leather-l: #8C6E63;

  --brass:     #B5873B;
  --brass-2:   #D4A24A;
  --brass-3:   #8C6620;
  --brass-l:   #E6C26A;

  --canvas:    #F5DEB3;
  --canvas-2:  #E8CB8B;
  --canvas-3:  #C9AB6A;
  --canvas-l:  #FBEDD0;

  --sweat:     #1C1C1C;
  --sweat-2:   #0E0E0E;
  --sweat-3:   #2A2A2A;

  --blood:     #CB2025;
  --jade:      #2E7D32;
  --warn:      #FFB300;

  --line-crimson: rgba(139,0,0,0.45);
  --line-brass:   rgba(181,135,59,0.55);
  --line-leather: rgba(93,64,55,0.55);
}

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

html { scroll-behavior: smooth; }
body {
  background:
    /* canvas grain */
    repeating-linear-gradient(
      37deg,
      rgba(245,222,179,0.018) 0 2px,
      rgba(0,0,0,0) 2px 6px
    ),
    repeating-linear-gradient(
      -23deg,
      rgba(255,255,255,0.012) 0 1px,
      rgba(0,0,0,0) 1px 5px
    ),
    radial-gradient(1200px 700px at 12% -8%, rgba(139,0,0,0.28), transparent 60%),
    radial-gradient(1000px 600px at 100% 30%, rgba(181,135,59,0.16), transparent 60%),
    radial-gradient(800px 600px at 50% 110%, rgba(93,64,55,0.40), transparent 60%),
    var(--sweat);
  background-attachment: fixed;
  color: var(--canvas);
  font-family: 'Mitr', 'Bai Jamjuree', 'Sarabun', system-ui, sans-serif;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.55;
  min-height: 100vh;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; }

a { color: var(--brass-2); text-decoration: none; transition: color .15s; }
a:hover { color: var(--canvas-l); }

/* ----- TYPOGRAPHY ----- */
.h-display, h1, h2, h3, h4 {
  font-family: 'Big Shoulders Display', 'Mitr', sans-serif;
  font-weight: 900;
  line-height: 0.96;
  letter-spacing: 0.005em;
  text-transform: uppercase;
}
h1 { font-size: clamp(40px, 6vw, 84px); }
h2 { font-size: clamp(28px, 3.6vw, 48px); }
h3 { font-size: clamp(20px, 2vw, 28px); }
h4 { font-size: 18px; }

.thai-h {
  font-family: 'Mitr', sans-serif;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-transform: none;
}

.script {
  font-family:'Caveat','Mitr',cursive;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-transform: none;
}

.upper { text-transform: uppercase; letter-spacing: 0.06em; }
.dim   { color: rgba(245,222,179,0.65); }
.dim-2 { color: rgba(245,222,179,0.42); }
.center{ text-align: center; }

.crimson-text { color: var(--crimson-2); }
.brass-text   { color: var(--brass-2); }
.canvas-text  { color: var(--canvas-l); }

/* ----- TEXTURES (background utilities) ----- */
.tex-leather {
  background:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,0.04) 0 1px, transparent 1px),
    radial-gradient(circle at 70% 60%, rgba(0,0,0,0.18) 0 1px, transparent 1px),
    repeating-linear-gradient(45deg, rgba(0,0,0,0.05) 0 2px, transparent 2px 5px),
    linear-gradient(135deg, var(--leather) 0%, var(--leather-d) 100%);
  background-size: 14px 14px, 18px 18px, auto, auto;
  color: var(--canvas);
}
.tex-canvas {
  background:
    repeating-linear-gradient(0deg,  rgba(93,64,55,0.10) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(90deg, rgba(93,64,55,0.10) 0 1px, transparent 1px 4px),
    radial-gradient(circle at 30% 40%, rgba(93,64,55,0.12) 0 1px, transparent 2px),
    linear-gradient(180deg, var(--canvas-l) 0%, var(--canvas) 70%, var(--canvas-2) 100%);
  background-size: 6px 6px, 6px 6px, 22px 22px, auto;
  color: var(--leather-d);
}
.tex-crimson {
  background:
    repeating-linear-gradient(45deg, rgba(0,0,0,0.10) 0 2px, transparent 2px 6px),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,0.04), transparent 70%),
    linear-gradient(135deg, var(--crimson-2), var(--crimson-d));
  color: var(--canvas-l);
}
.tex-brass {
  background:
    repeating-linear-gradient(135deg, rgba(0,0,0,0.05) 0 1px, transparent 1px 3px),
    linear-gradient(180deg, var(--brass-l) 0%, var(--brass-2) 35%, var(--brass) 65%, var(--brass-3) 100%);
}
.tex-sweat {
  background:
    repeating-linear-gradient(0deg, rgba(245,222,179,0.02) 0 1px, transparent 1px 4px),
    radial-gradient(circle at 40% 60%, rgba(139,0,0,0.18), transparent 70%),
    var(--sweat-2);
}

/* canvas crack pattern */
.crack-tex {
  position: relative;
}
.crack-tex::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 8% at 30% 20%, rgba(0,0,0,0.18), transparent 70%),
    radial-gradient(ellipse 70% 6% at 70% 80%, rgba(0,0,0,0.15), transparent 70%),
    radial-gradient(ellipse 5% 30% at 80% 30%, rgba(0,0,0,0.12), transparent 70%);
  pointer-events: none;
}

/* ----- ROPE & BRASS DECORATIONS ----- */
/* Ringside rope border */
.rope {
  position: relative;
  border: 4px solid var(--crimson);
  background: linear-gradient(180deg, var(--crimson) 0%, var(--crimson-3) 100%);
  border-radius: 0;
  box-shadow:
    inset 0 0 0 2px var(--crimson-d),
    inset 0 0 0 6px var(--canvas-2),
    inset 0 0 0 8px var(--crimson),
    0 4px 0 var(--leather-d);
}

/* twisted rope visual */
.rope-line {
  display: block;
  height: 14px;
  background:
    repeating-linear-gradient(135deg,
      var(--crimson-d) 0 6px,
      var(--crimson) 6px 12px,
      var(--crimson-2) 12px 18px,
      var(--crimson-d) 18px 24px),
    var(--crimson);
  border-top: 2px solid var(--leather-d);
  border-bottom: 2px solid var(--leather-d);
  box-shadow: 0 0 0 1px var(--leather-d) inset;
  position: relative;
}
.rope-line::before, .rope-line::after {
  content: "";
  position: absolute; left: 0; right: 0; height: 2px;
  background: rgba(0,0,0,0.35);
}
.rope-line::before { top: 3px; }
.rope-line::after  { bottom: 3px; }

.rope-double {
  height: 38px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.rope-double .rope-line { height: 10px; }

/* Brass corner studs (decorative pseudo-element) */
.brass-frame {
  position: relative;
  border: 3px solid var(--brass-3);
  background: linear-gradient(180deg, var(--leather) 0%, var(--leather-d) 100%);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,0.05),
    0 4px 0 var(--sweat-2),
    0 8px 24px rgba(0,0,0,0.55);
}
.brass-frame::before, .brass-frame::after {
  content: "";
  position: absolute;
  width: 14px; height: 14px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
  box-shadow:
    inset -1px -1px 0 rgba(0,0,0,0.5),
    inset 1px 1px 1px rgba(255,255,255,0.5),
    0 2px 4px rgba(0,0,0,0.6);
}
.brass-frame::before { top: 7px;  left: 7px; }
.brass-frame::after  { bottom: 7px; right: 7px; }

/* additional brass studs at the other 2 corners using a child element */
.brass-frame .stud-tr,
.brass-frame .stud-bl {
  position: absolute;
  width: 14px; height: 14px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
  box-shadow:
    inset -1px -1px 0 rgba(0,0,0,0.5),
    inset 1px 1px 1px rgba(255,255,255,0.5),
    0 2px 4px rgba(0,0,0,0.6);
}
.brass-frame .stud-tr { top: 7px;    right: 7px; }
.brass-frame .stud-bl { bottom: 7px; left: 7px; }

/* Brass shimmer animation */
@keyframes brass-shimmer {
  0%,100% { filter: brightness(1); }
  50%     { filter: brightness(1.18); }
}

/* ----- BUTTONS (leather + brass studs) ----- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 28px;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 800;
  font-size: 17px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: 3px solid var(--brass-3);
  background: linear-gradient(180deg, var(--leather-l) 0%, var(--leather) 50%, var(--leather-d) 100%);
  color: var(--canvas-l);
  cursor: pointer;
  border-radius: 0;
  position: relative;
  text-decoration: none;
  transition: transform .12s, box-shadow .15s, background .15s;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.18),
    inset 0 -3px 0 rgba(0,0,0,0.4),
    0 4px 0 var(--sweat-2),
    0 6px 18px rgba(0,0,0,0.5);
  white-space: nowrap;
}
.btn:hover {
  transform: translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.22),
    inset 0 -3px 0 rgba(0,0,0,0.5),
    0 6px 0 var(--sweat-2),
    0 10px 22px rgba(0,0,0,0.6),
    0 0 0 1px var(--brass-2);
}
.btn:active { transform: translateY(1px); box-shadow: inset 0 2px 4px rgba(0,0,0,0.5); }

.btn::before, .btn::after {
  content: "";
  position: absolute;
  width: 8px; height: 8px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
  box-shadow:
    inset -0.5px -0.5px 0 rgba(0,0,0,0.5),
    inset 0.5px 0.5px 0 rgba(255,255,255,0.5);
}
.btn::before { top: 5px; left: 5px; }
.btn::after  { bottom: 5px; right: 5px; }

.btn-crimson {
  background: linear-gradient(180deg, var(--crimson-2) 0%, var(--crimson) 50%, var(--crimson-3) 100%);
  border-color: var(--brass-3);
  color: var(--canvas-l);
}
.btn-brass {
  background: linear-gradient(180deg, var(--brass-l) 0%, var(--brass-2) 45%, var(--brass) 75%, var(--brass-3) 100%);
  color: var(--sweat-2);
  border-color: var(--leather-d);
  text-shadow: 0 1px 0 rgba(255,255,255,0.25);
}
.btn-brass::before, .btn-brass::after {
  background:
    radial-gradient(circle at 30% 30%, var(--leather-l) 0%, var(--leather-d) 70%, #000 100%);
}
.btn-ghost {
  background: transparent;
  border: 2px dashed var(--brass-2);
  color: var(--canvas-l);
  box-shadow: none;
}
.btn-ghost::before, .btn-ghost::after { display: none; }
.btn-sm { padding: 8px 16px; font-size: 13px; }
.btn-lg { padding: 18px 36px; font-size: 20px; }
.btn-block { width: 100%; }

/* ----- LAYOUT ----- */
.container {
  width: 100%;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 22px;
}

.section {
  padding: 70px 0;
  position: relative;
}
.section + .section { padding-top: 30px; }

.section-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 20px; flex-wrap: wrap;
  margin-bottom: 28px;
  padding-bottom: 14px;
  border-bottom: 3px double var(--brass);
  position: relative;
}
.section-head::before {
  content: "";
  position: absolute; left: 0; bottom: -3px;
  width: 80px; height: 6px;
  background: var(--crimson);
}
.section-head h2 { color: var(--canvas-l); }
.section-head .eyebrow {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700; letter-spacing: 0.18em; font-size: 12px;
  color: var(--brass-2);
  text-transform: uppercase;
  display: block; margin-bottom: 4px;
}
.section-head .lead {
  font-family:'Caveat','Mitr',cursive; font-weight: 700;
  font-size: 22px; color: var(--canvas-2);
  max-width: 420px;
}

/* ====================================================
   HEADER + RINGSIDE TICKER + NAV
   ==================================================== */

.header-wrap {
  position: sticky; top: 0; z-index: 80;
  background:
    repeating-linear-gradient(45deg, rgba(0,0,0,0.18) 0 2px, transparent 2px 8px),
    linear-gradient(180deg, var(--leather-d) 0%, var(--sweat-2) 100%);
  border-bottom: 3px solid var(--brass-3);
  box-shadow: 0 6px 18px rgba(0,0,0,0.6);
}

/* Top promo strip */
.top-strip {
  background: var(--sweat-2);
  border-bottom: 1px solid var(--line-brass);
  font-size: 12px;
  color: var(--canvas-2);
}
.top-strip-row {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 12px; padding: 6px 0;
}
.top-strip .pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 2px 8px;
  background: var(--crimson);
  color: var(--canvas-l);
  font-weight: 600;
  letter-spacing: 0.05em;
  border-radius: 0;
  border: 1px solid var(--brass-3);
}
.top-strip .pill.amulet { background: var(--leather); }
.top-strip .pill.amulet::before { content: "᪥"; color: var(--brass-2); font-size: 14px; line-height: 1; }

/* Ringside ticker */
.ticker {
  background: var(--crimson);
  color: var(--canvas-l);
  border-top: 2px solid var(--brass-3);
  border-bottom: 2px solid var(--brass-3);
  overflow: hidden;
  position: relative;
}
.ticker::before, .ticker::after {
  content: "RINGSIDE";
  position: absolute; top: 0; bottom: 0; width: 110px;
  display: flex; align-items: center; justify-content: center;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900; font-size: 14px; letter-spacing: 0.16em;
  background: var(--leather-d);
  color: var(--brass-l);
  z-index: 2;
  border-right: 2px solid var(--brass-3);
}
.ticker::after {
  content: "BREAKING";
  left: auto; right: 0; border-right: none; border-left: 2px solid var(--brass-3);
}
.ticker-track {
  display: flex; gap: 50px;
  padding: 8px 130px;
  animation: ticker-slide 60s linear infinite;
  white-space: nowrap;
  font-size: 13px;
  font-weight: 500;
}
.ticker-track span b {
  color: var(--brass-l);
  margin-right: 8px;
  font-weight: 700;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  letter-spacing: 0.06em;
}
.ticker-track span::after {
  content: "·";
  margin-left: 50px;
  color: var(--brass-l);
  font-weight: 900;
}
@keyframes ticker-slide {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Main nav */
.nav-row {
  display: flex; align-items: center; gap: 18px;
  padding: 12px 0;
  flex-wrap: wrap;
  position: relative;
}
.brand {
  display: flex; align-items: center; gap: 12px;
  text-decoration: none; color: var(--canvas-l);
  cursor: pointer;
}
.brand-logo {
  width: 56px; height: 56px;
  display: grid; place-items: center;
  background: var(--crimson);
  border: 2px solid var(--brass-3);
  position: relative;
  flex-shrink: 0;
  box-shadow:
    inset 0 0 0 2px var(--crimson-d),
    inset 0 0 0 4px var(--brass);
}
.brand-logo svg { width: 32px; height: 32px; }
.brand-text {
  display: flex; flex-direction: column; line-height: 1;
}
.brand-text .b1 {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900; font-size: 26px;
  color: var(--canvas-l);
  letter-spacing: 0.04em;
}
.brand-text .b1 .ace {
  color: var(--crimson-2);
  text-shadow: 0 0 0 1px var(--brass-3);
  -webkit-text-stroke: 1px var(--brass-2);
}
.brand-text .b2 {
  font-family:'Caveat','Mitr',cursive;
  font-size: 14px;
  color: var(--brass-2);
  margin-top: 2px;
}

.nav-list {
  display: flex; gap: 4px; flex: 1;
  list-style: none;
  flex-wrap: wrap;
  justify-content: center;
}
.nav-list a {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 10px 14px;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700; font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--canvas-2);
  position: relative;
  border: 2px solid transparent;
  transition: all 0.15s;
  cursor: pointer;
}
.nav-list a .nav-thai {
  font-family: 'Mitr', sans-serif;
  font-weight: 600; font-size: 13px;
  letter-spacing: 0.01em;
  text-transform: none;
  color: var(--canvas-l);
}
.nav-list a:hover {
  color: var(--canvas-l);
  background: rgba(139,0,0,0.45);
  border-color: var(--brass-3);
}
.nav-list a:hover .bell-icon { animation: bell-shake 0.5s ease-in-out; }
.nav-list a.active {
  background: var(--crimson);
  color: var(--canvas-l);
  border-color: var(--brass-2);
}
.nav-list a.active::before, .nav-list a.active::after {
  content: "";
  position: absolute;
  width: 6px; height: 6px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
}
.nav-list a.active::before { top: 3px; left: 3px; }
.nav-list a.active::after  { bottom: 3px; right: 3px; }
.bell-icon {
  width: 16px; height: 16px;
  fill: var(--brass-2);
  transition: fill 0.15s;
}
.nav-list a:hover .bell-icon { fill: var(--brass-l); }

.nav-cta {
  display: flex; gap: 8px;
  align-items: center;
}

/* Mobile menu toggle */
.menu-toggle {
  display: none;
  width: 44px; height: 44px;
  background: var(--crimson);
  border: 2px solid var(--brass-3);
  cursor: pointer;
  align-items: center; justify-content: center;
  flex-direction: column; gap: 4px;
  position: relative;
}
.menu-toggle span {
  display: block; width: 22px; height: 3px;
  background: var(--canvas-l);
}

@keyframes bell-shake {
  0%, 100% { transform: rotate(0); }
  20%      { transform: rotate(-15deg); }
  40%      { transform: rotate(15deg); }
  60%      { transform: rotate(-10deg); }
  80%      { transform: rotate(8deg); }
}

/* ====================================================
   PROMO RIBBON
   ==================================================== */

.promo-ribbon {
  background: var(--brass);
  color: var(--sweat-2);
  border-top: 3px solid var(--brass-3);
  border-bottom: 3px solid var(--brass-3);
  padding: 12px 0;
  font-weight: 700;
  font-size: 14px;
  position: relative;
  overflow: hidden;
}
.promo-ribbon::before {
  content: "";
  position: absolute; inset: 0;
  background: repeating-linear-gradient(45deg,
    rgba(0,0,0,0.06) 0 6px,
    transparent 6px 12px);
  pointer-events: none;
}
.promo-row {
  display: flex; align-items: center; justify-content: center;
  gap: 30px; flex-wrap: wrap;
}
.promo-row .item {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Mitr', sans-serif;
}
.promo-row .item b {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
  color: var(--crimson-d);
  font-size: 18px;
  letter-spacing: 0.04em;
}
.promo-row .sep {
  width: 6px; height: 6px;
  background: var(--leather-d);
  border-radius: 50%;
}

/* ====================================================
   HERO — POSTER STYLE
   ==================================================== */

.hero {
  position: relative;
  padding: 60px 0 80px;
  overflow: hidden;
  background:
    /* spotlight from top */
    radial-gradient(ellipse 800px 600px at 50% -10%, rgba(245,222,179,0.18), transparent 60%),
    /* canvas vignette */
    radial-gradient(ellipse at center, rgba(28,28,28,0.0) 0%, rgba(0,0,0,0.7) 100%),
    /* leather */
    linear-gradient(180deg, var(--leather-d) 0%, var(--sweat-2) 100%);
  border-bottom: 6px double var(--brass-3);
}
.hero::before {
  /* Lumpinee Stadium silhouette */
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0; height: 38%;
  background:
    linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.6) 100%),
    repeating-linear-gradient(90deg,
      var(--sweat-2) 0 12px,
      var(--leather-d) 12px 13px,
      var(--sweat-2) 13px 26px);
  clip-path: polygon(
    0 60%, 5% 50%, 8% 55%, 13% 40%, 18% 45%, 22% 30%, 28% 38%,
    33% 25%, 38% 32%, 44% 18%, 50% 28%, 56% 18%, 62% 32%, 68% 25%,
    73% 38%, 78% 30%, 82% 45%, 87% 40%, 92% 55%, 95% 50%, 100% 60%, 100% 100%, 0 100%
  );
  opacity: 0.5;
  pointer-events: none;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 40px;
  align-items: center;
  position: relative;
  z-index: 2;
}
@media (max-width: 900px) {
  .hero-grid { grid-template-columns: 1fr; }
}

.hero-poster {
  background:
    repeating-linear-gradient(0deg,  rgba(93,64,55,0.10) 0 1px, transparent 1px 5px),
    repeating-linear-gradient(90deg, rgba(93,64,55,0.10) 0 1px, transparent 1px 5px),
    linear-gradient(180deg, var(--canvas-l) 0%, var(--canvas) 50%, var(--canvas-2) 100%);
  border: 6px solid var(--leather-d);
  outline: 3px solid var(--brass-3);
  outline-offset: 4px;
  padding: 36px 32px;
  color: var(--leather-d);
  position: relative;
  box-shadow:
    inset 0 0 60px rgba(93,64,55,0.30),
    0 12px 40px rgba(0,0,0,0.6);
  transform: rotate(-1.2deg);
}
.hero-poster::before, .hero-poster::after {
  content: ""; position: absolute;
  width: 16px; height: 16px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,0.5), 0 2px 4px rgba(0,0,0,0.6);
}
.hero-poster::before { top: 12px; left: 12px; }
.hero-poster::after  { bottom: 12px; right: 12px; }
.hero-poster .pin-tr {
  position: absolute; top: 12px; right: 12px;
  width: 16px; height: 16px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,0.5), 0 2px 4px rgba(0,0,0,0.6);
}
.hero-poster .pin-bl {
  position: absolute; bottom: 12px; left: 12px;
  width: 16px; height: 16px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,0.5), 0 2px 4px rgba(0,0,0,0.6);
}

.poster-eyebrow {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.36em;
  color: var(--crimson);
  margin-bottom: 6px;
}
.poster-stadium {
  font-family:'Caveat','Mitr',cursive;
  font-weight: 700;
  font-size: 28px;
  color: var(--leather);
  margin-bottom: 14px;
  transform: rotate(-2deg);
  display: inline-block;
}
.poster-headline {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
  font-size: clamp(40px, 6vw, 76px);
  line-height: 0.86;
  color: var(--sweat-2);
  letter-spacing: -0.005em;
  margin-bottom: 12px;
  text-transform: uppercase;
}
.poster-headline .vs {
  display: block;
  color: var(--crimson);
  font-size: 0.68em;
  margin: 4px 0;
  -webkit-text-stroke: 2px var(--brass-3);
}
.poster-meta {
  display: flex; gap: 16px; flex-wrap: wrap;
  margin-top: 18px; margin-bottom: 18px;
  border-top: 2px dashed var(--leather);
  border-bottom: 2px dashed var(--leather);
  padding: 12px 0;
}
.poster-meta .m {
  display: flex; flex-direction: column; line-height: 1.1;
}
.poster-meta .m .l {
  font-size: 11px; letter-spacing: 0.18em;
  color: var(--crimson); text-transform: uppercase;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
}
.poster-meta .m .v {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 800; font-size: 22px;
  color: var(--leather-d);
}
.poster-meta .m .v small {
  font-family: 'Mitr', sans-serif;
  font-weight: 500; font-size: 12px;
  color: var(--leather);
}
.poster-cta { display: flex; gap: 12px; flex-wrap: wrap; }
.poster-foot {
  display: flex; justify-content: space-between; align-items: flex-end;
  flex-wrap: wrap; gap: 12px;
  margin-top: 18px;
  font-size: 13px;
}
.poster-foot .channel {
  font-family:'Caveat','Mitr',cursive;
  font-size: 22px;
  color: var(--crimson);
  transform: rotate(-2deg);
}
.poster-foot .price {
  display: flex; align-items: baseline; gap: 6px;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
}
.poster-foot .price .num {
  color: var(--crimson);
  font-size: 28px;
}
.poster-foot .price .lbl {
  color: var(--leather);
  font-size: 12px; letter-spacing: 0.1em;
}

/* hero side: boxer silhouette + mini info */
.hero-side {
  position: relative;
  padding: 20px;
}
.hero-boxer {
  width: 100%; aspect-ratio: 3/4;
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.hero-boxer svg {
  width: 100%; height: 100%;
  filter: drop-shadow(0 18px 30px rgba(0,0,0,0.7));
}
.hero-boxer .corner-light {
  position: absolute; inset: -10%;
  background: radial-gradient(circle at 50% 35%, rgba(245,222,179,0.20), transparent 55%);
  pointer-events: none;
  z-index: 0;
}
.hero-boxer .punch {
  animation: boxer-punch 4s ease-in-out infinite;
  transform-origin: center;
}
@keyframes boxer-punch {
  0%, 70%, 100% { transform: translateX(0) rotate(0deg); }
  78%           { transform: translateX(8px) rotate(-2deg); }
  86%           { transform: translateX(-3px) rotate(1deg); }
}

.hero-side .badges {
  display: flex; gap: 10px; flex-wrap: wrap;
  margin-top: 18px; justify-content: center;
}
.hero-side .badge {
  padding: 6px 12px;
  border: 2px solid var(--brass-3);
  background: rgba(0,0,0,0.55);
  color: var(--canvas-l);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700; font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.hero-side .badge b { color: var(--brass-l); }

/* sweat drops decoration */
.sweat-drop {
  position: absolute;
  width: 8px; height: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,0.85) 0%, rgba(135,206,235,0.6) 100%);
  border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
  filter: blur(0.4px);
  opacity: 0.6;
  pointer-events: none;
}

/* ====================================================
   FIGHT CARD (TONIGHT)
   ==================================================== */

.fight-card-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}
@media (max-width: 800px) {
  .fight-card-grid { grid-template-columns: 1fr; }
}

.fc {
  background:
    repeating-linear-gradient(45deg, rgba(0,0,0,0.08) 0 1px, transparent 1px 4px),
    linear-gradient(180deg, var(--leather) 0%, var(--leather-d) 100%);
  border: 3px solid var(--brass-3);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,0.04),
    0 6px 18px rgba(0,0,0,0.5);
  position: relative;
  padding: 18px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 14px;
  align-items: stretch;
}
.fc::before, .fc::after {
  content: ""; position: absolute;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,0.5);
}
.fc::before { top: 6px; left: 6px; }
.fc::after  { bottom: 6px; right: 6px; }

.fc-tag {
  position: absolute; top: -2px; left: 30px;
  padding: 4px 10px;
  background: var(--crimson);
  color: var(--canvas-l);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 800; font-size: 11px;
  letter-spacing: 0.16em;
  border: 2px solid var(--brass-3);
  border-top: none;
}

.fc-fighter {
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.fc-fighter .face {
  width: 78px; height: 78px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass-3) 60%, var(--leather-d) 100%);
  border: 3px solid var(--brass-3);
  display: grid; place-items: center;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900; font-size: 30px;
  color: var(--sweat-2);
}
.fc-fighter .name {
  font-family: 'Mitr', sans-serif;
  font-weight: 700; font-size: 14px;
  color: var(--canvas-l);
  line-height: 1.1;
  min-height: 30px;
  display: flex; align-items: center; justify-content: center;
}
.fc-fighter .gym {
  font-size: 11px; color: var(--brass-2);
  font-family:'Caveat','Mitr',cursive;
  font-size: 14px;
}
.fc-fighter .rec {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700; font-size: 13px; letter-spacing: 0.06em;
  color: var(--canvas-2);
  display: flex; gap: 4px; align-items: baseline;
}
.fc-fighter .rec b { color: var(--brass-l); }
.fc-fighter .odds {
  margin-top: 8px;
  padding: 6px 12px;
  background: var(--sweat-2);
  border: 2px solid var(--brass-3);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900; font-size: 22px;
  color: var(--brass-l);
  min-width: 80px;
}
.fc-fighter.red .face { background: radial-gradient(circle at 30% 30%, #FF6B5B 0%, var(--crimson) 60%, var(--crimson-d) 100%); color: var(--canvas-l); }
.fc-fighter.blue .face { background: radial-gradient(circle at 30% 30%, #6BAEFF 0%, #1E5FA8 60%, #0E3060 100%); color: var(--canvas-l); }

.fc-vs {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 6px; min-width: 100px;
}
.fc-vs .vs-glove {
  font-size: 28px;
  filter: drop-shadow(0 0 4px rgba(0,0,0,0.6));
  animation: glove-bounce 2.4s ease-in-out infinite;
}
@keyframes glove-bounce {
  0%, 100% { transform: translateY(0) rotate(-5deg); }
  50%      { transform: translateY(-4px) rotate(5deg); }
}
.fc-vs .vs-text {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900; font-size: 26px;
  color: var(--crimson-2);
  -webkit-text-stroke: 1.5px var(--brass-3);
}
.fc-vs .vs-meta {
  text-align: center;
  font-size: 11px;
  color: var(--canvas-2);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  letter-spacing: 0.1em;
}
.fc-vs .vs-meta b { color: var(--brass-l); display: block; font-size: 14px; }

.fc-foot {
  grid-column: 1/-1;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 8px;
  margin-top: 6px; padding-top: 10px;
  border-top: 2px dashed var(--brass-3);
  font-size: 12px;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700; letter-spacing: 0.06em;
  color: var(--canvas-2);
}
.fc-foot .live-dot {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--crimson-2);
}
.fc-foot .live-dot::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--crimson-2);
  animation: pulse-dot 1.2s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.4; transform: scale(0.7); }
}
.fc-foot .channel-tag {
  padding: 3px 8px; background: var(--crimson-d);
  color: var(--canvas-l); border: 1px solid var(--brass-3);
}

/* ====================================================
   ODDS TABLE (12 fights, round-by-round)
   ==================================================== */

.odds-wrap {
  background:
    repeating-linear-gradient(0deg,  rgba(93,64,55,0.10) 0 1px, transparent 1px 4px),
    linear-gradient(180deg, var(--canvas-l) 0%, var(--canvas) 100%);
  border: 4px solid var(--leather-d);
  outline: 3px solid var(--brass-3);
  outline-offset: 3px;
  padding: 26px;
  color: var(--leather-d);
  position: relative;
}
.odds-wrap::before, .odds-wrap::after {
  content: ""; position: absolute;
  width: 16px; height: 16px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,0.4);
}
.odds-wrap::before { top: 6px; left: 6px; }
.odds-wrap::after  { bottom: 6px; right: 6px; }

.odds-head {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px;
  margin-bottom: 18px; padding-bottom: 12px;
  border-bottom: 3px double var(--leather);
}
.odds-head h3 { color: var(--leather-d); }
.odds-head .legend { display: flex; gap: 14px; flex-wrap: wrap; font-size: 12px; }
.odds-head .legend i {
  display: inline-block; width: 12px; height: 12px;
  vertical-align: middle; margin-right: 4px; border: 1px solid var(--leather-d);
}
.odds-head .legend .down { background: #B71C1C; }
.odds-head .legend .up   { background: #2E7D32; }
.odds-head .legend .flat { background: var(--brass); }

.odds-table-wrap {
  overflow-x: auto;
  border: 2px solid var(--leather-d);
  background: var(--canvas);
}
.odds-table {
  width: 100%;
  min-width: 900px;
  border-collapse: collapse;
  color: var(--leather-d);
  font-size: 13px;
}
.odds-table thead {
  background: var(--leather-d);
  color: var(--canvas-l);
}
.odds-table th {
  padding: 10px 8px;
  text-align: center;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700; font-size: 13px;
  letter-spacing: 0.06em;
  border-right: 1px solid var(--leather);
  text-transform: uppercase;
}
.odds-table th.fight-col { text-align: left; padding-left: 14px; }
.odds-table tbody tr {
  border-bottom: 1px dashed var(--leather);
}
.odds-table tbody tr:nth-child(odd) {
  background: rgba(93,64,55,0.06);
}
.odds-table td {
  padding: 9px 8px;
  text-align: center;
  border-right: 1px dashed rgba(93,64,55,0.3);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  font-size: 14px;
}
.odds-table td.fight-col {
  text-align: left;
  padding-left: 14px;
  font-family: 'Mitr', sans-serif;
  font-weight: 600;
  white-space: nowrap;
  font-size: 13px;
}
.odds-table td.fight-col small {
  display: block;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  font-size: 11px;
  color: var(--crimson);
  letter-spacing: 0.06em;
}
.odds-cell { position: relative; transition: background 0.3s; }
.odds-cell.up   { color: #2E7D32; }
.odds-cell.down { color: #B71C1C; }
.odds-cell.flat { color: var(--leather-d); }
.odds-cell.flash {
  background: rgba(255, 215, 0, 0.45);
  animation: cell-flash 1.2s ease-out;
}
@keyframes cell-flash {
  0%   { background: rgba(255, 215, 0, 0.7); }
  100% { background: rgba(255, 215, 0, 0); }
}
.odds-cell .arr {
  font-size: 9px;
  margin-left: 2px;
  letter-spacing: 0;
}

.odds-foot {
  margin-top: 14px;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 12px;
  font-size: 12px; color: var(--leather);
  font-family:'Caveat','Mitr',cursive; font-size: 18px;
}

/* ====================================================
   LIVE STREAM
   ==================================================== */

.live-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 22px;
}
@media (max-width: 900px) {
  .live-grid { grid-template-columns: 1fr; }
}

.live-screen {
  position: relative;
  background: var(--sweat-2);
  border: 4px solid var(--brass-3);
  box-shadow:
    inset 0 0 0 2px var(--leather-d),
    inset 0 0 30px rgba(0,0,0,0.7),
    0 8px 30px rgba(0,0,0,0.5);
  aspect-ratio: 16/9;
  overflow: hidden;
}
.live-screen::before {
  content: "";
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 3px),
    radial-gradient(circle at 50% 60%, rgba(245,222,179,0.10), transparent 60%);
  pointer-events: none;
  z-index: 2;
}
.live-screen .scoreboard-mock {
  position: absolute;
  top: 18px; left: 18px;
  display: flex; gap: 10px; align-items: center;
  background: var(--sweat-2);
  border: 2px solid var(--brass-3);
  padding: 6px 12px;
  z-index: 3;
}
.live-screen .scoreboard-mock .live-tag {
  padding: 2px 6px;
  background: var(--crimson);
  color: var(--canvas-l);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
  font-size: 11px;
  letter-spacing: 0.18em;
  display: inline-flex; align-items: center; gap: 4px;
}
.live-screen .scoreboard-mock .live-tag::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--canvas-l);
  animation: pulse-dot 1s ease-in-out infinite;
}
.live-screen .scoreboard-mock .scores {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900; font-size: 16px;
  color: var(--canvas-l);
  letter-spacing: 0.04em;
}
.live-screen .scoreboard-mock .round-tag {
  padding: 2px 8px;
  background: var(--brass);
  color: var(--sweat-2);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 800; font-size: 12px;
}
.live-screen .stadium-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 50% 30% at 50% 70%, rgba(245,222,179,0.25), transparent 60%),
    repeating-linear-gradient(45deg, rgba(245,222,179,0.04) 0 1px, transparent 1px 4px),
    linear-gradient(180deg, var(--leather-d) 0%, var(--sweat-2) 60%, var(--crimson-d) 100%);
}
.live-screen .ring-floor {
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 50%;
  background:
    repeating-linear-gradient(90deg,
      var(--canvas-2) 0 50px,
      var(--canvas) 50px 100px);
  transform: perspective(400px) rotateX(58deg);
  transform-origin: bottom center;
  border-top: 4px solid var(--crimson);
  opacity: 0.9;
}
.live-screen .center-text {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  height: 100%; gap: 10px;
  text-align: center;
}
.live-screen .center-text .play-btn {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: var(--crimson);
  border: 4px solid var(--brass-2);
  display: grid; place-items: center;
  cursor: pointer;
  box-shadow: 0 0 0 4px rgba(0,0,0,0.6), 0 0 30px rgba(139,0,0,0.7);
  transition: transform 0.15s;
}
.live-screen .center-text .play-btn:hover { transform: scale(1.1); }
.live-screen .center-text .play-btn::before {
  content: ""; display: block;
  width: 0; height: 0;
  border-left: 22px solid var(--canvas-l);
  border-top: 14px solid transparent;
  border-bottom: 14px solid transparent;
  margin-left: 6px;
}
.live-screen .center-text .label {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900; font-size: 22px;
  color: var(--canvas-l);
  letter-spacing: 0.1em;
}

.live-side {
  display: flex; flex-direction: column; gap: 14px;
}
.commentary {
  background: var(--leather-d);
  border: 3px solid var(--brass-3);
  padding: 14px;
  position: relative;
  flex: 1;
  min-height: 220px;
  display: flex; flex-direction: column;
}
.commentary h4 {
  color: var(--brass-l);
  font-size: 16px;
  letter-spacing: 0.12em;
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 2px dashed var(--brass-3);
}
.commentary h4 .live-pill {
  display: inline-block;
  padding: 1px 6px;
  background: var(--crimson);
  color: var(--canvas-l);
  font-size: 11px;
  margin-left: 6px;
  vertical-align: middle;
}
.commentary-feed {
  list-style: none;
  padding: 0;
  font-size: 13px;
  display: flex; flex-direction: column; gap: 8px;
  max-height: 220px;
  overflow-y: auto;
}
.commentary-feed li {
  padding: 6px 8px;
  background: rgba(0,0,0,0.25);
  border-left: 3px solid var(--crimson-2);
  color: var(--canvas-l);
}
.commentary-feed li b {
  color: var(--brass-l);
  margin-right: 6px;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  letter-spacing: 0.06em;
}
.commentary-feed li.kick    { border-color: var(--crimson-2); }
.commentary-feed li.knee    { border-color: var(--brass-2); }
.commentary-feed li.elbow   { border-color: var(--blood); }
.commentary-feed li.rest    { border-color: var(--jade); }

/* ====================================================
   WAGER-BY-ROUND (sweat-drop bonus widget)
   ==================================================== */

.wbr {
  background:
    repeating-linear-gradient(90deg, rgba(0,0,0,0.05) 0 2px, transparent 2px 6px),
    linear-gradient(180deg, var(--crimson) 0%, var(--crimson-3) 100%);
  border: 4px solid var(--brass-3);
  outline: 3px solid var(--leather-d);
  outline-offset: 4px;
  padding: 28px;
  color: var(--canvas-l);
  position: relative;
  overflow: hidden;
}
.wbr::before, .wbr::after {
  content: ""; position: absolute;
  width: 16px; height: 16px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,0.5);
  z-index: 1;
}
.wbr::before { top: 6px; left: 6px; }
.wbr::after  { bottom: 6px; right: 6px; }
.wbr-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 26px;
  align-items: center;
  position: relative; z-index: 2;
}
@media (max-width: 800px) {
  .wbr-grid { grid-template-columns: 1fr; gap: 16px; }
}

.wbr-eyebrow {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  letter-spacing: 0.32em;
  font-size: 12px;
  color: var(--brass-l);
  margin-bottom: 4px;
}
.wbr h3 { color: var(--canvas-l); margin-bottom: 8px; }
.wbr p {
  color: var(--canvas-2);
  font-size: 13px;
  margin-bottom: 14px;
}
.wbr-tags { display: flex; gap: 8px; flex-wrap: wrap; }
.wbr-tags span {
  padding: 4px 10px;
  background: rgba(0,0,0,0.3);
  border: 1px dashed var(--brass-2);
  font-size: 12px;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.wbr-clock {
  display: flex; flex-direction: column; align-items: center;
  gap: 8px;
}
.wbr-clock .label {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 800; font-size: 13px;
  letter-spacing: 0.16em;
  color: var(--brass-l);
}
.wbr-clock .timer {
  width: 160px; height: 160px;
  border-radius: 50%;
  border: 5px solid var(--brass-2);
  background:
    radial-gradient(circle at 50% 30%, rgba(255,255,255,0.06), transparent 70%),
    var(--sweat-2);
  display: grid; place-items: center;
  position: relative;
  box-shadow:
    inset 0 0 0 2px var(--leather-d),
    inset 0 0 40px rgba(0,0,0,0.7),
    0 0 0 6px var(--leather-d),
    0 0 0 9px var(--brass-3);
}
.wbr-clock .timer .digits {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
  font-size: 56px;
  color: var(--canvas-l);
  letter-spacing: 0.05em;
  line-height: 1;
}
.wbr-clock .timer .small {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-size: 12px; letter-spacing: 0.16em;
  color: var(--brass-l);
  margin-top: 2px;
}
.wbr-clock .progress {
  width: 200px;
  height: 6px;
  background: rgba(0,0,0,0.5);
  border: 1px solid var(--brass-3);
  position: relative;
  margin-top: 4px;
}
.wbr-clock .progress > i {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: linear-gradient(90deg, var(--brass-l), var(--brass-2));
  width: 60%;
  transition: width 1s linear;
}

.wbr-bonus {
  text-align: center;
}
.wbr-bonus .multiplier {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
  font-size: 64px;
  line-height: 1;
  color: var(--brass-l);
  letter-spacing: 0.04em;
  text-shadow: 0 0 12px rgba(245, 222, 179, 0.5);
  display: block;
}
.wbr-bonus .label {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  letter-spacing: 0.2em;
  font-size: 11px;
  color: var(--canvas-2);
  margin-top: 4px;
}
.wbr-bonus .formula {
  display: inline-block;
  margin-top: 8px;
  padding: 4px 10px;
  background: rgba(0,0,0,0.4);
  border: 1px dashed var(--brass-2);
  font-size: 13px;
  color: var(--brass-l);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  letter-spacing: 0.06em;
}
.wbr-bonus .btn { margin-top: 14px; }

/* sweat drop animation in wbr */
.sweat-fall {
  position: absolute;
  width: 6px; height: 10px;
  background: linear-gradient(180deg, rgba(255,255,255,0.85), rgba(173,216,230,0.6));
  border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
  pointer-events: none;
  animation: sweat-fall 4s linear infinite;
  z-index: 1;
  opacity: 0.5;
}
@keyframes sweat-fall {
  0%   { transform: translateY(-30px); opacity: 0; }
  10%  { opacity: 0.7; }
  90%  { opacity: 0.7; }
  100% { transform: translateY(280px); opacity: 0; }
}

/* ====================================================
   FIGHTER PROFILE CARDS
   ==================================================== */

.fighter-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 800px) { .fighter-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .fighter-grid { grid-template-columns: 1fr; } }

.fighter {
  background:
    repeating-linear-gradient(90deg, rgba(0,0,0,0.05) 0 1px, transparent 1px 3px),
    linear-gradient(180deg, var(--leather-l) 0%, var(--leather) 60%, var(--leather-d) 100%);
  border: 3px solid var(--brass-3);
  position: relative;
  padding: 14px;
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 14px;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,0.05),
    0 6px 16px rgba(0,0,0,0.5);
  overflow: hidden;
}
.fighter::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0;
  height: 32px;
  background: var(--crimson);
  border-bottom: 2px solid var(--brass-3);
  z-index: 0;
}
.fighter-portrait {
  width: 90px; height: 90px;
  border: 3px solid var(--brass-2);
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--leather-d) 100%);
  display: grid; place-items: center;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900; font-size: 36px;
  color: var(--sweat-2);
  position: relative; z-index: 1;
  box-shadow: 0 0 0 2px var(--leather-d), 0 4px 10px rgba(0,0,0,0.5);
}
.fighter-portrait.crimson { background: radial-gradient(circle at 30% 30%, #FF8B7B 0%, var(--crimson) 60%, var(--crimson-d) 100%); color: var(--canvas-l); }
.fighter-portrait.blue    { background: radial-gradient(circle at 30% 30%, #6BAEFF 0%, #1E5FA8 60%, #0E3060 100%); color: var(--canvas-l); }
.fighter-portrait.brass   { background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 60%, var(--brass-3) 100%); color: var(--sweat-2); }
.fighter-portrait.green   { background: radial-gradient(circle at 30% 30%, #6FBF6E 0%, #2E7D32 60%, #1B5E20 100%); color: var(--canvas-l); }
.fighter-portrait.purple  { background: radial-gradient(circle at 30% 30%, #B98EE0 0%, #6A3D9A 60%, #3E0E5A 100%); color: var(--canvas-l); }
.fighter-portrait.orange  { background: radial-gradient(circle at 30% 30%, #FFB46B 0%, #E66E1F 60%, #8C3F08 100%); color: var(--canvas-l); }

.fighter-info { position: relative; z-index: 1; }
.fighter-info .nickname {
  font-family:'Caveat','Mitr',cursive;
  font-size: 16px; color: var(--brass-l);
  margin-bottom: 2px;
}
.fighter-info .name {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900; font-size: 19px;
  color: var(--canvas-l);
  letter-spacing: 0.02em;
  line-height: 1.05;
  margin-bottom: 6px;
  text-transform: uppercase;
}
.fighter-stats {
  grid-column: 1/-1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  margin-top: 4px;
  border-top: 2px dashed var(--brass-3);
  padding-top: 8px;
}
.fighter-stats .stat {
  text-align: center;
  padding: 6px 4px;
  background: rgba(0,0,0,0.2);
  border: 1px solid rgba(0,0,0,0.3);
}
.fighter-stats .stat .l {
  font-size: 9px;
  color: var(--brass-l);
  letter-spacing: 0.16em;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
}
.fighter-stats .stat .v {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
  font-size: 16px;
  color: var(--canvas-l);
  line-height: 1.05;
}
.fighter-stats .stat .v.green { color: #A5D6A7; }
.fighter-stats .stat .v.crimson { color: #FFAB91; }

.fighter-meta {
  grid-column: 1/-1;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 6px;
  font-size: 11px;
  color: var(--canvas-2);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding-top: 8px;
}
.fighter-meta .gym {
  font-family: 'Mitr', sans-serif;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
}
.fighter-meta .flag {
  display: inline-block;
  width: 18px; height: 12px;
  margin-right: 4px;
  vertical-align: middle;
  border: 1px solid rgba(0,0,0,0.3);
}
.flag.th { background: linear-gradient(180deg, #ED1C24 0 22%, #FFFFFF 22% 36%, #2D2A4A 36% 64%, #FFFFFF 64% 78%, #ED1C24 78% 100%); }
.flag.br { background: linear-gradient(180deg, #009C3B 0 100%); }
.flag.uk { background: linear-gradient(180deg, #012169 0 100%); }
.flag.ru { background: linear-gradient(180deg, #FFFFFF 0 33%, #0033A0 33% 66%, #DA291C 66% 100%); }
.flag.kh { background: linear-gradient(180deg, #032EA1 0 25%, #E00025 25% 75%, #032EA1 75% 100%); }
.flag.la { background: linear-gradient(180deg, #CE1126 0 25%, #002868 25% 75%, #CE1126 75% 100%); }
.flag.us { background: linear-gradient(180deg, #B22234 0 100%); }
.flag.jp { background: radial-gradient(circle at 50% 50%, #BC002D 0 5px, #FFFFFF 5px); }
.flag.kr { background: linear-gradient(180deg, #FFFFFF 0 100%); }
.flag.id { background: linear-gradient(180deg, #FF0000 0 50%, #FFFFFF 50% 100%); }

/* ====================================================
   GAMES (Slot, Live, Lottery)
   ==================================================== */

.cat-pills {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-bottom: 18px;
}
.cat-pills button {
  padding: 8px 16px;
  background: var(--leather-d);
  border: 2px solid var(--brass-3);
  color: var(--canvas-l);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700; font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.15s;
}
.cat-pills button:hover { background: var(--leather); }
.cat-pills button.active {
  background: var(--crimson);
  border-color: var(--brass-2);
}

.slot-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
@media (max-width: 800px) { .slot-grid { grid-template-columns: repeat(2, 1fr); } }

.slot {
  background: var(--leather-d);
  border: 3px solid var(--brass-3);
  position: relative;
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s;
  overflow: hidden;
}
.slot:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(0,0,0,0.6);
}
.slot::before, .slot::after {
  content: ""; position: absolute;
  width: 8px; height: 8px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
  z-index: 2;
}
.slot::before { top: 4px; left: 4px; }
.slot::after  { bottom: 4px; right: 4px; }

.slot-thumb {
  height: 140px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.1), transparent 60%),
    var(--crimson-d);
  display: grid; place-items: center;
  position: relative;
  border-bottom: 3px solid var(--brass-3);
}
.slot-thumb .glove-emoji {
  font-size: 64px;
  filter: drop-shadow(0 4px 6px rgba(0,0,0,0.5));
}
.slot-thumb .hot-tag {
  position: absolute; top: 8px; right: 8px;
  padding: 3px 8px;
  background: var(--crimson);
  color: var(--canvas-l);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 800; font-size: 11px;
  letter-spacing: 0.12em;
  border: 1px solid var(--brass-3);
}
.slot-thumb .hot-tag.new  { background: var(--jade); }
.slot-thumb .hot-tag.jp   { background: var(--brass); color: var(--sweat-2); }
.slot-info {
  padding: 10px 12px;
  background:
    repeating-linear-gradient(90deg, rgba(0,0,0,0.04) 0 1px, transparent 1px 4px),
    var(--leather-d);
}
.slot-info .name {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 800; font-size: 15px;
  color: var(--canvas-l);
  letter-spacing: 0.02em;
  line-height: 1.1;
  text-transform: uppercase;
}
.slot-info .provider {
  font-size: 11px;
  color: var(--brass-l);
  letter-spacing: 0.1em;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 600;
  margin-top: 2px;
}
.slot-info .stats {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px dashed var(--brass-3);
  font-size: 11px;
}
.slot-info .stats .rtp {
  color: var(--canvas-l);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
}
.slot-info .stats .rtp b { color: var(--brass-l); }
.slot-info .stats .vol {
  color: var(--canvas-2);
  font-family:'Caveat','Mitr',cursive;
  font-size: 14px;
}

/* ====================================================
   LOTTERY
   ==================================================== */

.lott-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
@media (max-width: 800px) { .lott-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .lott-grid { grid-template-columns: 1fr; } }

.lott {
  background:
    repeating-linear-gradient(0deg,  rgba(93,64,55,0.10) 0 1px, transparent 1px 4px),
    linear-gradient(180deg, var(--canvas-l) 0%, var(--canvas) 100%);
  border: 3px solid var(--leather-d);
  outline: 2px solid var(--brass-3);
  outline-offset: 2px;
  padding: 16px;
  color: var(--leather-d);
  position: relative;
  text-align: center;
}
.lott::before, .lott::after {
  content: ""; position: absolute;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
}
.lott::before { top: 5px; left: 5px; }
.lott::after  { bottom: 5px; right: 5px; }
.lott h4 {
  color: var(--leather-d);
  font-size: 18px;
  margin-bottom: 4px;
}
.lott .subtitle {
  font-family:'Caveat','Mitr',cursive;
  color: var(--crimson);
  font-size: 16px;
  margin-bottom: 10px;
}
.lott .countdown {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
  font-size: 32px;
  color: var(--crimson);
  background: var(--sweat-2);
  border: 2px solid var(--brass-3);
  padding: 8px 6px;
  letter-spacing: 0.06em;
  display: flex; justify-content: center; gap: 4px;
}
.lott .countdown .col {
  display: flex; flex-direction: column;
  min-width: 38px;
}
.lott .countdown .col small {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-size: 9px; letter-spacing: 0.16em;
  color: var(--brass-l);
  margin-top: 2px;
}
.lott .last-result {
  margin-top: 10px;
  font-size: 12px;
  color: var(--leather);
}
.lott .last-result b {
  display: inline-block;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
  font-size: 18px;
  color: var(--crimson);
  letter-spacing: 0.08em;
  margin-left: 4px;
}
.lott .pay {
  font-size: 11px;
  color: var(--leather);
  letter-spacing: 0.08em;
  margin-top: 8px;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
}
.lott .pay b { color: var(--crimson); }

/* ====================================================
   VIP TIERS
   ==================================================== */

.vip-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
}
@media (max-width: 1000px) { .vip-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px)  { .vip-grid { grid-template-columns: 1fr; } }

.vip {
  background:
    repeating-linear-gradient(45deg, rgba(0,0,0,0.05) 0 2px, transparent 2px 6px),
    linear-gradient(180deg, var(--leather) 0%, var(--leather-d) 100%);
  border: 3px solid var(--brass-3);
  padding: 22px 18px;
  position: relative;
  text-align: center;
  display: flex; flex-direction: column; gap: 10px;
  overflow: hidden;
}
.vip::before, .vip::after {
  content: ""; position: absolute;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
}
.vip::before { top: 6px; left: 6px; }
.vip::after  { bottom: 6px; right: 6px; }

.vip .icon {
  width: 60px; height: 60px;
  margin: 0 auto;
  border: 3px solid var(--brass-2);
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 30px;
  background: rgba(0,0,0,0.4);
}
.vip .tier-name {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900; font-size: 20px;
  color: var(--canvas-l);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.vip .tier-thai {
  font-family: 'Mitr', sans-serif;
  font-weight: 600; font-size: 13px;
  color: var(--brass-l);
}
.vip .req {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700; font-size: 13px;
  color: var(--canvas-2);
  padding: 6px 0;
  border-top: 1px dashed var(--brass-3);
  border-bottom: 1px dashed var(--brass-3);
  letter-spacing: 0.04em;
}
.vip .req b { color: var(--brass-l); }
.vip ul {
  list-style: none;
  font-size: 12px;
  color: var(--canvas-l);
  text-align: left;
  display: flex; flex-direction: column; gap: 4px;
}
.vip ul li::before {
  content: "▸ ";
  color: var(--brass-l);
}
.vip.tier-5 {
  background:
    repeating-linear-gradient(45deg, rgba(0,0,0,0.08) 0 2px, transparent 2px 6px),
    linear-gradient(180deg, var(--crimson) 0%, var(--crimson-d) 100%);
  border-color: var(--brass-l);
}
.vip.tier-5 .tier-name { color: var(--brass-l); }

/* ====================================================
   BANK WALL
   ==================================================== */

.bank-wall {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 10px;
}
@media (max-width: 1000px) { .bank-wall { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 540px)  { .bank-wall { grid-template-columns: repeat(3, 1fr); } }

.bank {
  background: var(--canvas-l);
  border: 2px solid var(--brass-3);
  padding: 14px 8px;
  text-align: center;
  position: relative;
  color: var(--leather-d);
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  transition: transform 0.15s;
}
.bank:hover { transform: translateY(-2px); }
.bank::before {
  content: ""; position: absolute;
  top: 3px; left: 3px;
  width: 6px; height: 6px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
}
.bank .logo {
  width: 44px; height: 44px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
  font-size: 14px;
  color: var(--canvas-l);
  letter-spacing: -0.02em;
  text-transform: uppercase;
}
.bank.scb .logo { background: #4E2987; }
.bank.kbank .logo { background: #138F2D; }
.bank.bbl .logo { background: #1E4DA1; }
.bank.ktb .logo { background: #00A6E2; }
.bank.bay .logo { background: #FEC10E; color: var(--sweat-2); }
.bank.ttb .logo { background: #1B286F; }
.bank.gsb .logo { background: #EC008C; }
.bank.kkp .logo { background: #283A98; }
.bank.cimb .logo { background: #A00010; }
.bank.baac .logo { background: #007A38; }
.bank.lh .logo { background: #003366; }
.bank.tmw .logo { background: #F37020; }
.bank.qr .logo { background: #003C7E; }
.bank.usdt .logo { background: #26A17B; }
.bank.btc .logo { background: #F7931A; color: var(--sweat-2); }
.bank.eth .logo { background: #627EEA; }
.bank .name {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--leather-d);
  text-transform: uppercase;
}
.bank .name small {
  display: block;
  font-family: 'Mitr', sans-serif;
  font-weight: 500;
  font-size: 10px;
  color: var(--leather);
  letter-spacing: 0;
  text-transform: none;
  margin-top: 1px;
}

/* ====================================================
   BANK BAND · MID-PAGE BRASS-PLATED ROW
   ช่องทางเดิมพันของเซียน — 9 banks · sepia-vintage · ±2deg tilt
   rope-rectangle frame · brass corner studs · poster aesthetic
   ==================================================== */

.bank-band-section { padding: 50px 0; }

.bank-band {
  position: relative;
  border: 6px solid var(--leather-d);
  outline: 3px solid var(--brass-3);
  outline-offset: 4px;
  background:
    repeating-linear-gradient(0deg,  rgba(93,64,55,0.08) 0 1px, transparent 1px 5px),
    repeating-linear-gradient(90deg, rgba(93,64,55,0.08) 0 1px, transparent 1px 5px),
    repeating-linear-gradient(135deg, rgba(0,0,0,0.06) 0 1px, transparent 1px 4px),
    linear-gradient(180deg, var(--brass-l) 0%, var(--brass-2) 35%, var(--brass) 65%, var(--brass-3) 100%);
  background-size: 6px 6px, 6px 6px, auto, auto;
  padding: 30px 26px 28px;
  box-shadow:
    inset 0 0 0 2px rgba(255,255,255,0.08),
    inset 0 0 70px rgba(93,64,55,0.32),
    0 8px 24px rgba(0,0,0,0.55);
  overflow: hidden;
}

/* twisted rope (top + bottom) */
.bank-band-rope {
  position: absolute;
  left: 18px; right: 18px;
  height: 8px;
  background:
    repeating-linear-gradient(135deg,
      var(--crimson-d) 0 4px,
      var(--crimson) 4px 8px,
      var(--crimson-2) 8px 12px,
      var(--crimson-d) 12px 16px),
    var(--crimson);
  border-top: 1.5px solid var(--leather-d);
  border-bottom: 1.5px solid var(--leather-d);
  box-shadow: 0 0 0 1px var(--leather-d) inset;
  pointer-events: none;
  z-index: 2;
}
.bank-band-rope.top    { top: 8px; }
.bank-band-rope.bottom { bottom: 8px; }

/* brass corner studs (4 corners) */
.bank-band-stud {
  position: absolute;
  width: 18px; height: 18px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass-2) 40%, var(--brass-3) 100%);
  box-shadow:
    inset -1.5px -1.5px 0 rgba(0,0,0,0.55),
    inset 1.5px 1.5px 1px rgba(255,255,255,0.55),
    0 2px 5px rgba(0,0,0,0.65);
  z-index: 3;
}
.bank-band-stud.tl { top: 7px;    left: 7px; }
.bank-band-stud.tr { top: 7px;    right: 7px; }
.bank-band-stud.bl { bottom: 7px; left: 7px; }
.bank-band-stud.br { bottom: 7px; right: 7px; }

/* 9-cell single row */
.bank-band-row {
  position: relative;
  z-index: 1;
  margin: 18px 14px;
  display: grid;
  grid-template-columns: repeat(9, 1fr);
  gap: 14px;
  align-items: stretch;
  filter: sepia(.6) saturate(1.2);
}
@media (max-width: 1100px) {
  .bank-band-row { grid-template-columns: repeat(5, 1fr); row-gap: 22px; }
}
@media (max-width: 600px) {
  .bank-band-row { grid-template-columns: repeat(3, 1fr); row-gap: 22px; }
}

.bank-band-cell {
  --rot: 0deg;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px;
  padding: 14px 8px 10px;
  background:
    repeating-linear-gradient(0deg,  rgba(93,64,55,0.08) 0 1px, transparent 1px 4px),
    linear-gradient(180deg, var(--canvas-l) 0%, var(--canvas) 70%, var(--canvas-2) 100%);
  border: 2px solid var(--leather-d);
  text-decoration: none;
  color: var(--leather-d);
  position: relative;
  transform: rotate(var(--rot));
  transition: transform .2s ease, box-shadow .2s ease;
  cursor: pointer;
  box-shadow:
    inset 0 0 0 1px rgba(0,0,0,0.06),
    0 4px 0 var(--leather-d),
    0 6px 14px rgba(0,0,0,0.45);
}

/* tape strip pinned at top — counter-rotates to look horizontal */
.bank-band-tape {
  position: absolute;
  top: -6px; left: 50%;
  transform: translateX(-50%) rotate(calc(var(--rot) * -1));
  width: 28px; height: 9px;
  background:
    repeating-linear-gradient(45deg, rgba(93,64,55,0.18) 0 2px, transparent 2px 5px),
    rgba(245, 222, 179, 0.7);
  border: 1px solid rgba(93,64,55,0.45);
  box-shadow: 0 1px 3px rgba(0,0,0,0.4);
  z-index: 2;
  pointer-events: none;
}

.bank-band-cell:hover {
  transform: rotate(0deg) translateY(-3px);
  box-shadow:
    inset 0 0 0 1px rgba(0,0,0,0.10),
    0 6px 0 var(--leather-d),
    0 12px 22px rgba(0,0,0,0.55),
    0 0 0 2px var(--brass-l);
  z-index: 5;
  color: var(--leather-d);
}

.bank-band-cell img {
  width: 64px; height: 64px;
  object-fit: contain;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.30));
}
@media (max-width: 600px) {
  .bank-band-cell img { width: 52px; height: 52px; }
}

.bank-band-name {
  font-family: 'Big Shoulders Display', 'Mitr', sans-serif;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--leather-d);
  text-transform: uppercase;
  text-align: center;
  line-height: 1.05;
}

/* poster ribbon caption under the band */
.bank-band-caption {
  margin-top: 16px;
  text-align: center;
  font-family: 'Caveat', 'Mitr', cursive;
  font-size: 19px;
  color: var(--canvas-2);
  letter-spacing: 0.02em;
}
.bank-band-caption b {
  color: var(--brass-l);
  font-family: 'Big Shoulders Display', 'Mitr', sans-serif;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0 4px;
}

/* ====================================================
   WHY US
   ==================================================== */

.why-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
@media (max-width: 900px) { .why-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .why-grid { grid-template-columns: 1fr; } }

.why {
  background: var(--leather-d);
  border: 3px solid var(--brass-3);
  padding: 22px 18px;
  position: relative;
  display: flex; flex-direction: column; gap: 8px;
}
.why::before, .why::after {
  content: ""; position: absolute;
  width: 8px; height: 8px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
}
.why::before { top: 4px; left: 4px; }
.why::after  { bottom: 4px; right: 4px; }
.why .icon-wrap {
  width: 56px; height: 56px;
  border: 3px solid var(--crimson);
  background: var(--sweat-2);
  display: grid; place-items: center;
  font-size: 28px;
  margin-bottom: 4px;
}
.why h4 {
  color: var(--canvas-l);
  font-size: 18px;
  letter-spacing: 0.02em;
}
.why p {
  color: var(--canvas-2);
  font-size: 13px;
  line-height: 1.5;
}

/* ====================================================
   STATS / QUICK COUNTERS
   ==================================================== */

.stats-bar {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  background: var(--sweat-2);
  border: 3px solid var(--brass-3);
  padding: 4px;
}
@media (max-width: 700px) { .stats-bar { grid-template-columns: repeat(2, 1fr); } }
.stats-bar .s {
  background: var(--leather-d);
  padding: 16px 12px;
  text-align: center;
  position: relative;
}
.stats-bar .s .v {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
  font-size: 30px;
  color: var(--brass-l);
  letter-spacing: 0.02em;
  line-height: 1;
}
.stats-bar .s .v small {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: var(--canvas-2);
  margin-left: 2px;
}
.stats-bar .s .l {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  font-size: 11px;
  color: var(--canvas-2);
  letter-spacing: 0.18em;
  margin-top: 4px;
}
.stats-bar .s + .s {
  border-left: 1px dashed var(--brass-3);
}

/* ====================================================
   SCHEDULE PAGE
   ==================================================== */

.schedule-list {
  display: flex; flex-direction: column; gap: 0;
  background: var(--leather-d);
  border: 3px solid var(--brass-3);
}
.sched-row {
  display: grid;
  grid-template-columns: 70px 1fr 110px 90px;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px dashed var(--brass-3);
  align-items: center;
}
@media (max-width: 700px) {
  .sched-row { grid-template-columns: 1fr 1fr; }
  .sched-row .sched-time { grid-column: 1; }
  .sched-row .sched-fight { grid-column: 1/-1; }
  .sched-row .sched-card  { grid-column: 1; }
  .sched-row .sched-cta   { grid-column: 2; justify-self: end; }
}
.sched-row:last-child { border-bottom: none; }
.sched-row:hover { background: rgba(0,0,0,0.2); }

.sched-time {
  text-align: center;
  border-right: 2px dashed var(--brass-3);
  padding-right: 10px;
}
.sched-time .t {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
  font-size: 22px;
  color: var(--crimson-2);
  line-height: 1;
}
.sched-time .d {
  font-family: 'Mitr', sans-serif;
  font-size: 11px;
  color: var(--canvas-2);
  margin-top: 2px;
}
.sched-fight .matchup {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900;
  font-size: 19px;
  color: var(--canvas-l);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  line-height: 1.1;
}
.sched-fight .matchup .vs {
  color: var(--crimson-2);
  margin: 0 8px;
  font-size: 0.85em;
}
.sched-fight .meta {
  font-size: 12px;
  color: var(--canvas-2);
  margin-top: 4px;
}
.sched-fight .meta b { color: var(--brass-l); }
.sched-card {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-size: 12px;
  color: var(--canvas-l);
  letter-spacing: 0.06em;
}
.sched-card .pill {
  display: inline-block;
  padding: 3px 8px;
  background: var(--crimson);
  border: 1px solid var(--brass-3);
  letter-spacing: 0.08em;
  font-weight: 700;
}
.sched-card .pill.muay { background: var(--crimson); }
.sched-card .pill.ufc  { background: var(--leather); }
.sched-card .pill.box  { background: var(--brass); color: var(--sweat-2); }
.sched-card .channel {
  display: block; margin-top: 4px; font-size: 11px;
  color: var(--brass-l);
}

/* ====================================================
   PAGES (hash router)
   ==================================================== */

.page { display: none; }
.page.active { display: block; animation: page-in 0.35s ease-out; }
@keyframes page-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ====================================================
   BANK PAGE (deposit/withdraw form)
   ==================================================== */

.bank-page-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
@media (max-width: 800px) { .bank-page-grid { grid-template-columns: 1fr; } }

.deposit-form, .withdraw-form {
  background: var(--leather-d);
  border: 3px solid var(--brass-3);
  padding: 26px;
  position: relative;
}
.deposit-form::before, .deposit-form::after,
.withdraw-form::before, .withdraw-form::after {
  content: ""; position: absolute;
  width: 12px; height: 12px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
}
.deposit-form::before, .withdraw-form::before { top: 6px; left: 6px; }
.deposit-form::after,  .withdraw-form::after  { bottom: 6px; right: 6px; }

.form-row { margin-bottom: 14px; }
.form-row label {
  display: block;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700; font-size: 12px;
  letter-spacing: 0.18em;
  color: var(--brass-l);
  margin-bottom: 6px;
  text-transform: uppercase;
}
.form-row input, .form-row select {
  width: 100%;
  padding: 12px;
  background: var(--sweat-2);
  border: 2px solid var(--brass-3);
  color: var(--canvas-l);
  font-family: 'Mitr', sans-serif;
  font-size: 14px;
  outline: none;
}
.form-row input:focus, .form-row select:focus {
  border-color: var(--brass-l);
  box-shadow: 0 0 0 2px rgba(245,222,179,0.2);
}
.amount-quick {
  display: flex; gap: 6px; margin-top: 6px; flex-wrap: wrap;
}
.amount-quick button {
  flex: 1;
  min-width: 60px;
  padding: 8px;
  background: var(--leather);
  border: 2px solid var(--brass-3);
  color: var(--canvas-l);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700; font-size: 12px;
  cursor: pointer;
  letter-spacing: 0.04em;
}
.amount-quick button:hover { background: var(--leather-l); }

/* ====================================================
   FAQ / CONTACT
   ==================================================== */

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
@media (max-width: 800px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-card {
  background: var(--leather-d);
  border: 3px solid var(--brass-3);
  padding: 22px;
  position: relative;
}
.contact-card::before, .contact-card::after {
  content: ""; position: absolute;
  width: 10px; height: 10px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
}
.contact-card::before { top: 5px; left: 5px; }
.contact-card::after  { bottom: 5px; right: 5px; }
.contact-card h3 { color: var(--canvas-l); margin-bottom: 14px; }
.contact-card .item {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 14px;
  background: rgba(0,0,0,0.25);
  border-left: 4px solid var(--crimson);
  margin-bottom: 10px;
}
.contact-card .item .ic {
  width: 44px; height: 44px;
  background: var(--crimson);
  border: 2px solid var(--brass-3);
  display: grid; place-items: center;
  font-size: 22px;
  flex-shrink: 0;
}
.contact-card .item .info {
  display: flex; flex-direction: column;
}
.contact-card .item .info b {
  color: var(--brass-l);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  letter-spacing: 0.1em;
  font-size: 12px;
}
.contact-card .item .info span {
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 800;
  font-size: 18px;
  color: var(--canvas-l);
  letter-spacing: 0.02em;
}

.faq-list { display: flex; flex-direction: column; gap: 8px; }
.faq-item {
  background: rgba(0,0,0,0.2);
  border-left: 3px solid var(--brass);
  padding: 12px 14px;
}
.faq-item summary {
  cursor: pointer;
  font-family: 'Mitr', sans-serif;
  font-weight: 600;
  color: var(--canvas-l);
  list-style: none;
  position: relative;
  padding-right: 24px;
}
.faq-item summary::after {
  content: "+";
  position: absolute; right: 0; top: 0;
  font-size: 22px;
  color: var(--brass-l);
  line-height: 1;
}
.faq-item[open] summary::after { content: "−"; }
.faq-item p {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed var(--brass-3);
  font-size: 13px;
  color: var(--canvas-2);
}

/* ====================================================
   FLOATING & UI CHROME
   ==================================================== */

.floats {
  position: fixed; bottom: 22px; right: 22px; z-index: 90;
  display: flex; flex-direction: column; gap: 10px;
  align-items: flex-end;
}
.float-btn {
  width: 56px; height: 56px;
  border-radius: 50%;
  border: 3px solid var(--brass-3);
  display: grid; place-items: center;
  cursor: pointer;
  text-decoration: none;
  color: var(--canvas-l);
  font-size: 22px;
  position: relative;
  box-shadow: 0 4px 12px rgba(0,0,0,0.55);
  transition: transform 0.15s;
}
.float-btn:hover { transform: scale(1.08); color: var(--canvas-l); }
.float-btn::after {
  content: ""; position: absolute; inset: 4px;
  border-radius: 50%;
  border: 1px dashed rgba(255,255,255,0.4);
}
.float-line { background: #06C755; }
.float-tg   { background: #0088CC; }
.float-bell { background: var(--brass); color: var(--sweat-2); }
.float-top  { background: var(--leather-d); border-color: var(--brass); }
.float-btn .label {
  position: absolute; right: 64px;
  background: var(--sweat-2);
  border: 2px solid var(--brass-3);
  padding: 6px 12px;
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  font-size: 13px;
  color: var(--canvas-l);
  white-space: nowrap;
  letter-spacing: 0.06em;
  opacity: 0;
  transform: translateX(8px);
  transition: opacity 0.15s, transform 0.15s;
  pointer-events: none;
}
.float-btn:hover .label {
  opacity: 1;
  transform: translateX(0);
}

/* ====================================================
   FOOTER
   ==================================================== */

.footer {
  background:
    repeating-linear-gradient(45deg, rgba(0,0,0,0.10) 0 2px, transparent 2px 8px),
    linear-gradient(180deg, var(--leather-d) 0%, var(--sweat-2) 100%);
  border-top: 6px double var(--brass-3);
  padding: 50px 0 22px;
  margin-top: 40px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 30px;
  margin-bottom: 30px;
}
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .footer-grid { grid-template-columns: 1fr; } }

.footer h4 {
  color: var(--brass-l);
  font-size: 16px;
  margin-bottom: 14px;
  letter-spacing: 0.1em;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--crimson);
  display: inline-block;
}
.footer ul { list-style: none; display: flex; flex-direction: column; gap: 6px; }
.footer ul a {
  color: var(--canvas-2);
  font-size: 13px;
  font-family: 'Mitr', sans-serif;
}
.footer ul a:hover { color: var(--canvas-l); }

.footer-brand .desc {
  font-size: 13px;
  color: var(--canvas-2);
  margin-top: 14px;
  margin-bottom: 14px;
  max-width: 340px;
}
.footer-bottom {
  border-top: 2px dashed var(--brass-3);
  padding-top: 18px;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 12px;
  font-size: 12px;
  color: var(--canvas-2);
}
/* ====================================================
   MODAL (login/register)
   ==================================================== */

.modal-bg {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.85);
  z-index: 200;
  display: none;
  align-items: center; justify-content: center;
  padding: 20px;
}
.modal-bg.show { display: flex; animation: fade-in 0.2s ease-out; }
@keyframes fade-in { from { opacity: 0; } to { opacity: 1; } }

.modal {
  background:
    repeating-linear-gradient(45deg, rgba(0,0,0,0.08) 0 2px, transparent 2px 6px),
    linear-gradient(180deg, var(--leather-d) 0%, var(--sweat-2) 100%);
  border: 5px solid var(--brass-3);
  outline: 3px solid var(--leather-d);
  outline-offset: 4px;
  width: 100%; max-width: 460px;
  position: relative;
  padding: 32px 28px 24px;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,0.04),
    0 16px 40px rgba(0,0,0,0.7);
}
.modal::before, .modal::after {
  content: ""; position: absolute;
  width: 14px; height: 14px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--brass-l) 0%, var(--brass) 45%, var(--brass-3) 100%);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,0.5);
}
.modal::before { top: 8px; left: 8px; }
.modal::after  { bottom: 8px; right: 8px; }
.modal .close {
  position: absolute; top: 8px; right: 32px;
  width: 32px; height: 32px;
  background: var(--crimson);
  color: var(--canvas-l);
  border: 2px solid var(--brass-3);
  cursor: pointer;
  font-size: 18px;
  font-weight: 700;
  display: grid; place-items: center;
}
.modal h3 {
  color: var(--canvas-l);
  text-align: center;
  font-size: 28px;
  margin-bottom: 4px;
}
.modal .subtitle {
  text-align: center;
  font-family:'Caveat','Mitr',cursive;
  color: var(--brass-l);
  font-size: 18px;
  margin-bottom: 18px;
}
.modal .tabs {
  display: flex; margin-bottom: 18px;
  border-bottom: 2px solid var(--brass-3);
}
.modal .tab {
  flex: 1;
  padding: 12px;
  background: transparent;
  border: none;
  border-bottom: 3px solid transparent;
  color: var(--canvas-2);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.12em;
  cursor: pointer;
}
.modal .tab.active {
  color: var(--brass-l);
  border-bottom-color: var(--crimson);
}

/* ====================================================
   MISC HELPERS
   ==================================================== */

.divider-rope {
  display: block;
  height: 38px;
  margin: 30px 0;
  position: relative;
}
.divider-rope::before {
  content: "";
  position: absolute; left: 0; right: 0; top: 50%;
  height: 14px; transform: translateY(-50%);
  background:
    repeating-linear-gradient(135deg,
      var(--crimson-d) 0 6px,
      var(--crimson) 6px 12px,
      var(--crimson-2) 12px 18px,
      var(--crimson-d) 18px 24px);
  border-top: 2px solid var(--leather-d);
  border-bottom: 2px solid var(--leather-d);
  animation: rope-sway 6s ease-in-out infinite;
}
@keyframes rope-sway {
  0%, 100% { transform: translateY(-50%) rotate(0); }
  50%      { transform: translateY(-49%) rotate(0.4deg); }
}

.amulet-row {
  display: flex; justify-content: center; gap: 14px; margin: 16px 0;
}
.amulet {
  width: 30px; height: 38px;
  background: var(--brass);
  border: 2px solid var(--brass-3);
  border-radius: 50% 50% 30% 30%;
  display: grid; place-items: center;
  position: relative;
  color: var(--sweat-2);
  font-family:'Big Shoulders Display','Mitr',sans-serif;
  font-weight: 900; font-size: 13px;
}
.amulet::before {
  content: "";
  position: absolute; top: -8px; left: 50%; transform: translateX(-50%);
  width: 16px; height: 8px;
  border: 1.5px solid var(--brass-3);
  border-bottom: none;
  border-radius: 8px 8px 0 0;
}

@media (max-width: 900px) {
  .menu-toggle { display: inline-flex; order: 3; }
  .nav-list {
    display: none;
    position: absolute;
    top: 100%; left: 0; right: 0;
    background: var(--sweat-2);
    flex-direction: column;
    border: 3px solid var(--brass-3);
    border-top: none;
    z-index: 70;
    padding: 8px;
  }
  .nav-list.show { display: flex; }
  .nav-list a { width: 100%; }
  .nav-cta { display: none; }
}

/* tiny accessibility */
button, input, select { font-family: inherit; }

/* selection */
::selection { background: var(--crimson); color: var(--canvas-l); }
