.kasino-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);

  padding: 44px 0 20px;
  background: color-mix(in srgb, var(--color-bg) 94%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  animation: kasino-overlay-in 0.22s var(--ease-out-expo, ease-out);
  font-family: var(--font-body);

  user-select: none;
  -webkit-user-select: none;
}

.kasino-overlay,
.kasino-overlay *,
.kasino-overlay *::before,
.kasino-overlay *::after {
  user-select: none !important;
  -webkit-user-select: none !important;
  -webkit-touch-callout: none;
}

.kasino-rules-panel,
.kasino-rules-panel * {
  user-select: text !important;
  -webkit-user-select: text !important;
  -webkit-touch-callout: default;
}

.kasino-rules-panel .kasino-rules-close,
.kasino-rules-panel .kasino-rules-close *,
.kasino-rules-panel .kasino-lang,
.kasino-rules-panel .kasino-lang * {
  user-select: none !important;
  -webkit-user-select: none !important;
}
@keyframes kasino-overlay-in { from { opacity: 0; } to { opacity: 1; } }

.kasino-ambient {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.kasino-ambient::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(120% 90% at 50% 45%,
    transparent 55%,
    color-mix(in srgb, var(--color-bg) 70%, transparent) 100%);
  animation: kasino-ambient-breathe 9s var(--ease-in-out, ease-in-out) infinite;
}
.kasino-orb {
  position: absolute;
  border-radius: 50%;
  opacity: 0;
  will-change: transform, opacity;

  background: radial-gradient(circle at 50% 50%,
    var(--orb-color, var(--color-accent)) 0%,
    color-mix(in srgb, var(--orb-color, var(--color-accent)) 40%, transparent) 42%,
    transparent 70%);
  filter: blur(var(--orb-blur, 70px));
}
.kasino-orb[data-orb="1"] {
  width: 420px; height: 420px; top: -6%; left: -4%;
  --orb-color: var(--color-accent); --orb-blur: 90px;
  animation: kasino-orb-a 34s var(--ease-in-out, ease-in-out) infinite;
}
.kasino-orb[data-orb="2"] {
  width: 320px; height: 320px; bottom: -8%; right: -2%;
  --orb-color: #f5b301; --orb-blur: 100px;
  animation: kasino-orb-b 41s var(--ease-in-out, ease-in-out) infinite;
}
.kasino-orb[data-orb="3"] {
  width: 260px; height: 260px; top: 12%; right: 8%;
  --orb-color: #34d399; --orb-blur: 80px;
  animation: kasino-orb-c 47s var(--ease-in-out, ease-in-out) infinite;
}
.kasino-orb[data-orb="4"] {
  width: 300px; height: 300px; bottom: 6%; left: 6%;
  --orb-color: var(--color-accent); --orb-blur: 85px;
  animation: kasino-orb-b 38s var(--ease-in-out, ease-in-out) infinite reverse;
}
.kasino-orb[data-orb="5"] {
  width: 200px; height: 200px; top: 40%; left: 2%;
  --orb-color: #38bdf8; --orb-blur: 70px;
  animation: kasino-orb-a 52s var(--ease-in-out, ease-in-out) infinite reverse;
}
.kasino-orb[data-orb="6"] {
  width: 240px; height: 240px; top: 4%; left: 44%;
  --orb-color: #f5b301; --orb-blur: 95px;
  animation: kasino-orb-c 44s var(--ease-in-out, ease-in-out) infinite;
}

@keyframes kasino-orb-a {
  0%   { transform: translate(0, 0)           scale(1);    opacity: 0.10; }
  25%  { transform: translate(60px, 40px)     scale(1.12); opacity: 0.20; }
  50%  { transform: translate(20px, 90px)     scale(0.95); opacity: 0.14; }
  75%  { transform: translate(-50px, 40px)    scale(1.08); opacity: 0.21; }
  100% { transform: translate(0, 0)           scale(1);    opacity: 0.10; }
}
@keyframes kasino-orb-b {
  0%   { transform: translate(0, 0)           scale(1);    opacity: 0.12; }
  30%  { transform: translate(-70px, -30px)   scale(1.1);  opacity: 0.22; }
  60%  { transform: translate(-30px, -80px)   scale(0.92); opacity: 0.15; }
  100% { transform: translate(0, 0)           scale(1);    opacity: 0.12; }
}
@keyframes kasino-orb-c {
  0%   { transform: translate(0, 0)           scale(1);    opacity: 0.09; }
  40%  { transform: translate(50px, -50px)    scale(1.14); opacity: 0.18; }
  70%  { transform: translate(-40px, -20px)   scale(1);    opacity: 0.13; }
  100% { transform: translate(0, 0)           scale(1);    opacity: 0.09; }
}
@keyframes kasino-ambient-breathe {
  0%, 100% { opacity: 0.85; }
  50%      { opacity: 1; }
}

.kasino-shell {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  width: min(1180px, 96vw);

  height: min(940px, calc(100vh - 110px));
  height: min(940px, calc(100dvh - 110px));
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow:
    0 30px 80px rgba(0, 0, 0, 0.7),
    0 0 0 1px var(--color-accent-glow);
  overflow: hidden;
  animation: kasino-shell-in 0.32s var(--ease-out-expo, ease-out);
}
@keyframes kasino-shell-in {
  from { transform: translateY(16px) scale(0.985); opacity: 0; }
  to   { transform: translateY(0)    scale(1);     opacity: 1; }
}

.kasino-topbar {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  background: color-mix(in srgb, var(--color-surface) 80%, #000);
  border-bottom: 1px solid var(--color-border);
}

.kasino-topbar-end {
  justify-self: end;
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.kasino-back {
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: 44px;
  padding: var(--space-3) var(--space-6);
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full, 999px);
  color: var(--color-muted);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: normal;
  text-transform: none;
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease-in-out),
              border-color var(--dur-fast) var(--ease-in-out),
              background var(--dur-fast) var(--ease-in-out),
              transform var(--dur-fast) var(--ease-out-expo),
              box-shadow var(--dur-fast) var(--ease-out-expo);
}
.kasino-back:hover {
  color: var(--color-text);
  border-color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 10%, transparent);
  transform: translateY(-3px);
  box-shadow: 0 6px 20px var(--color-accent-glow);
}

.kasino-title {
  margin: 0;
  font-family: var(--font-display, serif);
  font-size: clamp(24px, 3.4vw, 34px);
  font-weight: 800;
  letter-spacing: 0.005em;
  line-height: 1.5;
  text-align: center;
  white-space: nowrap;
  overflow: visible;
  padding: 2px 0;
  user-select: none;
  -webkit-user-select: none;

  background: linear-gradient(110deg,
    var(--color-text) 0%,
    color-mix(in srgb, var(--color-accent) 70%, #fff) 35%,
    var(--color-text) 50%,
    color-mix(in srgb, var(--color-accent) 70%, #fff) 65%,
    var(--color-text) 100%);
  background-size: 220% 100%;
  background-position: 0% 50%;
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--color-text);
  filter: drop-shadow(0 0 14px color-mix(in srgb, var(--color-accent) 32%, transparent));
  animation: kasino-title-shimmer 8s linear infinite;
}
@keyframes kasino-title-shimmer {
  0%   { background-position: 0%   50%; }
  100% { background-position: 200% 50%; }
}
.kasino-title-sub {
  color: var(--color-muted);
  font-weight: 500;
  font-size: 0.78em;
  margin-left: 4px;
}

.kasino-title-mark {
  color: var(--color-accent);
  font-weight: 800;
  text-shadow: 0 0 12px var(--color-accent-glow);
  margin-left: 1px;
}
.kasino-balance {
  font-family: var(--font-display, serif);
  font-size: clamp(18px, 2.4vw, 24px);
  font-weight: 800;
  color: var(--color-accent);
  letter-spacing: -0.01em;
  text-shadow: 0 0 16px var(--color-accent-glow);
  transition: color 0.3s, text-shadow 0.3s;
  white-space: nowrap;
}

.kasino-shell:has(.kasino-endstate[data-kind="busted"]:not([hidden])) .kasino-balance {
  color: #ef4444;
  text-shadow:
    0 0 16px color-mix(in srgb, #ef4444 60%, transparent),
    0 0 30px color-mix(in srgb, #ef4444 35%, transparent);
}
.kasino-balance.is-flash-gain {
  animation: kasino-flash-gain 0.7s ease-out;
}
.kasino-balance.is-flash-loss {
  animation: kasino-flash-loss 0.7s ease-out;
}
@keyframes kasino-flash-gain {
  0%   { transform: scale(1);    color: var(--color-accent); }
  30%  { transform: scale(1.08); color: #34d399; text-shadow: 0 0 24px rgba(52, 211, 153, 0.55); }
  100% { transform: scale(1);    color: var(--color-accent); }
}
@keyframes kasino-flash-loss {
  0%   { transform: scale(1);    color: var(--color-accent); }
  30%  { transform: scale(0.96); color: #ef4444; text-shadow: 0 0 24px rgba(239, 68, 68, 0.55); }
  100% { transform: scale(1);    color: var(--color-accent); }
}

.kasino-rules-btn {
  position: relative;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  background: color-mix(in srgb, var(--color-text) 4%, transparent);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  color: var(--color-muted);
  font-family: var(--font-display, serif);
  font-size: 17px;
  font-weight: 800;
  font-style: italic;
  cursor: pointer;
  overflow: visible;
  transition:
    color    var(--dur-fast, 0.18s) var(--ease-in-out, ease),
    border-color var(--dur-fast, 0.18s) var(--ease-in-out, ease),
    background  var(--dur-fast, 0.18s) var(--ease-in-out, ease),
    transform   var(--dur-fast, 0.18s) var(--ease-out-expo, ease-out),
    box-shadow  var(--dur-fast, 0.18s) var(--ease-out-expo, ease-out);
}

.kasino-rules-btn::before {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 999px;
  background: conic-gradient(
    from 0deg,
    var(--color-accent),
    color-mix(in srgb, var(--color-accent) 30%, transparent),
    var(--color-accent),
    color-mix(in srgb, var(--color-accent) 30%, transparent),
    var(--color-accent));
  opacity: 0;
  z-index: -1;
  filter: blur(2px);
  transition: opacity 0.25s var(--ease-out-expo, ease-out);
  animation: kasino-rules-ring-spin 4s linear infinite;
}
.kasino-rules-btn:hover {
  color: var(--color-accent);
  border-color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 12%, transparent);
  transform: translateY(-2px) scale(1.06);
  box-shadow:
    0 6px 18px var(--color-accent-glow),
    0 0 0 4px color-mix(in srgb, var(--color-accent) 12%, transparent);
}
.kasino-rules-btn:hover::before { opacity: 0.8; }
.kasino-rules-btn:active { transform: translateY(0) scale(1); }
@keyframes kasino-rules-ring-spin {
  to { transform: rotate(360deg); }
}

.kasino-lang {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 3px;
  background: color-mix(in srgb, var(--color-text) 4%, transparent);
  border: 1px solid var(--color-border);
  border-radius: 999px;
}
.kasino-lang-btn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border: none;
  background: transparent;
  color: var(--color-muted);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  padding: 4px 7px;
  border-radius: 999px;
  cursor: pointer;
  transition:
    color      var(--dur-fast, 0.18s) var(--ease-in-out, ease),
    background  var(--dur-fast, 0.18s) var(--ease-in-out, ease);
}
.kasino-lang-flag {
  width: 16px;
  height: 11px;
  border-radius: 2px;
  display: block;
  flex-shrink: 0;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.25);
}
.kasino-lang-btn:hover { color: var(--color-text); }
.kasino-lang-btn.is-active {
  color: var(--color-on-accent, #fff);
  background: var(--color-accent);
  box-shadow: 0 0 12px var(--color-accent-glow);
}

.kasino-stage {
  position: relative;
  flex: 1;

  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6) var(--space-5);

  overflow-anchor: none;

  background:
    radial-gradient(ellipse at top, color-mix(in srgb, var(--color-accent) 8%, transparent), transparent 60%),
    linear-gradient(180deg, var(--color-surface-2) 0%, color-mix(in srgb, var(--color-surface-2) 78%, #08231a) 100%);

  overflow: hidden;
  justify-content: center;
}

.kasino-stage::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center,
    transparent 45%,
    color-mix(in srgb, #000 18%, transparent) 100%);
  pointer-events: none;
  z-index: 0;
}
.kasino-stage > * { position: relative; z-index: 1; }

.kasino-stage > .kasino-stats {
  position: absolute;
  top: var(--space-5);
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
}
.kasino-stats {
  display: flex;
  align-items: flex-start;
  gap: var(--space-6);
  pointer-events: none;
  animation: kasino-stats-in 0.4s var(--ease-out-expo, ease-out) both;
}
.kasino-stats[hidden] { display: none; }
.kasino-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
}
.kasino-stat-label {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.kasino-stat-value {
  font-family: var(--font-display, serif);
  font-size: 20px;
  font-weight: 800;
  color: var(--color-text);
  line-height: 1;
  white-space: nowrap;
}
.kasino-stat-dots {
  display: flex;
  gap: 5px;
  align-items: center;
  min-height: 20px;
}
.kasino-stat-dots:empty::after {
  content: '-';
  color: var(--color-muted);
  font-size: 14px;
}
.kasino-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--color-muted);
}

.kasino-dot[data-outcome="win"],
.kasino-dot[data-outcome="blackjack"] { background: #34d399; box-shadow: 0 0 6px color-mix(in srgb, #34d399 55%, transparent); }
.kasino-dot[data-outcome="goal"]      { background: #f5c451; box-shadow: 0 0 8px color-mix(in srgb, #f5c451 65%, transparent); }
.kasino-dot[data-outcome="push"]      { background: color-mix(in srgb, var(--color-muted) 80%, var(--color-text)); }
.kasino-dot[data-outcome="loss"]      { background: #ef4444; box-shadow: 0 0 6px color-mix(in srgb, #ef4444 50%, transparent); }
@keyframes kasino-stats-in {
  from { opacity: 0; transform: translate(-50%, -8px); }
  to   { opacity: 1; transform: translate(-50%, 0); }
}

.kasino-progress {
  position: relative;
  z-index: 1;
  width: min(720px, 70vw);
  height: 6px;
  background: color-mix(in srgb, var(--color-text) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--color-border) 60%, transparent);
  border-radius: 999px;
  overflow: visible;
  margin-bottom: var(--space-4);
}
.kasino-progress-bar {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0%;
  background: linear-gradient(90deg, var(--color-accent) 0%, color-mix(in srgb, var(--color-accent) 60%, #fff) 100%);
  border-radius: 999px;
  box-shadow: 0 0 12px var(--color-accent-glow);
  transition: width 0.5s var(--ease-out-expo, ease-out), box-shadow 0.4s;
}

.kasino-progress-bar.is-gold {
  background: linear-gradient(90deg,
    #b45309 0%,
    #f59e0b 20%,
    #fcd34d 40%,
    #fffbeb 50%,
    #fcd34d 60%,
    #f59e0b 80%,
    #b45309 100%);
  background-size: 220% 100%;
  box-shadow:
    0 0 14px rgba(251, 191, 36, 0.75),
    0 0 28px rgba(245, 158, 11, 0.45);
  animation: kasino-gold-shimmer 1.8s linear infinite;
}
@keyframes kasino-gold-shimmer {
  0%   { background-position: 0%   50%; }
  100% { background-position: 200% 50%; }
}

.kasino-progress-label {
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  margin-bottom: 8px;
  font-family: var(--font-display, serif);
  font-size: clamp(18px, 1.8vw, 22px);
  font-weight: 800;
  letter-spacing: -0.005em;
  text-transform: none;
  white-space: nowrap;
  color: var(--color-text);
  text-shadow: 0 0 18px color-mix(in srgb, var(--color-accent) 45%, transparent);
  user-select: none;
  -webkit-user-select: none;
}

.kasino-hand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
}
.kasino-hand[hidden] { display: none; }
.kasino-hand-label {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.kasino-hand[data-actor="player"] .kasino-hand-label { color: var(--color-accent); }
.kasino-hand-total {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 10px;
  background: color-mix(in srgb, var(--color-text) 6%, transparent);
  border-radius: 999px;
  font-family: var(--font-display, serif);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--color-text);
  min-width: 28px;
  text-align: center;
}
.kasino-cards {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  min-height: 192px;
}

.kasino-card {
  position: relative;
  width: 134px;
  height: 190px;
  border-radius: 14px;
  overflow: hidden;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.35), inset 0 0 0 1px color-mix(in srgb, var(--color-text) 4%, transparent);
  animation: kasino-card-in 0.28s var(--ease-out-expo, ease-out);
  perspective: 600px;
  transform-style: preserve-3d;
}
@keyframes kasino-card-in {
  from { transform: translateY(-18px) rotate(-4deg); opacity: 0; }
  to   { transform: translateY(0)     rotate(0);     opacity: 1; }
}
.kasino-card-face,
.kasino-card-back {
  position: absolute;
  inset: 0;
  display: grid;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transition: transform 0.35s var(--ease-out-expo, ease-out);
}
.kasino-card-face {
  grid-template-rows: auto 1fr auto;
  padding: 8px 10px;
  background: #f0f0f0;
  color: #15171a;
}
.kasino-card.is-red .kasino-card-face { color: #c52525; }
.kasino-card-corner {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  line-height: 1;
  justify-self: start;
}
.kasino-card-corner--br {
  justify-self: end;
  transform: rotate(180deg);
}
.kasino-card-rank {
  font-family: var(--font-display, Georgia, serif);
  font-size: 30px;
  font-weight: 800;
  letter-spacing: -0.04em;
}
.kasino-card-suit {
  font-size: 20px;
  line-height: 1;
}
.kasino-card-center {
  place-self: center;
  font-size: 62px;
  line-height: 1;
}

.kasino-card.is-face .kasino-card-face {
  background:

    repeating-linear-gradient(135deg,
      color-mix(in srgb, currentColor 4%, transparent) 0 2px,
      transparent 2px 6px),

    #f0f0f0;
}
.kasino-card.is-red.is-face .kasino-card-face {
  background:
    repeating-linear-gradient(135deg,
      color-mix(in srgb, #c52525 6%, transparent) 0 2px,
      transparent 2px 6px),
    #f0f0f0;
}

.kasino-card.is-face .kasino-card-face::before {
  content: '';
  position: absolute;
  inset: 32px 16px;
  border: 1px solid currentColor;
  border-radius: 6px;
  opacity: 0.3;
  pointer-events: none;
  z-index: 0;
}
.kasino-card.is-face .kasino-card-face::after {
  content: '';
  position: absolute;
  inset: 36px 20px;
  border: 1px solid currentColor;
  border-radius: 4px;
  opacity: 0.18;
  pointer-events: none;
  z-index: 0;
}

.kasino-card.is-face .kasino-card-corner,
.kasino-card.is-face .kasino-card-center {
  position: relative;
  z-index: 1;
}
.kasino-card-court {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  font-size: 1em;
}
.kasino-court-letter {
  font-family: var(--font-display, Georgia, serif);
  font-size: 48px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.04em;
  text-shadow:
    0 1px 0 color-mix(in srgb, currentColor 20%, transparent),
    0 0 18px color-mix(in srgb, currentColor 18%, transparent);
}
.kasino-court-suit {
  font-size: 22px;
  line-height: 1;
  opacity: 0.85;
}
.kasino-card-back {
  background:
    repeating-linear-gradient(45deg,
      var(--color-accent) 0 8px,
      color-mix(in srgb, var(--color-accent) 60%, #000) 8px 16px);
  border-radius: 8px;
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--color-accent) 40%, #000);
  transform: rotateY(180deg);
}
.kasino-card.is-hidden .kasino-card-face { transform: rotateY(-180deg); }
.kasino-card.is-hidden .kasino-card-back { transform: rotateY(0deg); }

.kasino-message {
  min-height: 1.4em;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--color-muted);
  text-align: center;
}
.kasino-message[hidden] { display: none; }

.kasino-actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-3);
  width: min(580px, 100%);
}

.kasino-actions[hidden] { display: none !important; }

.kasino-bet-row {
  display: grid;
  grid-template-columns: 72px 1fr 72px;
  gap: var(--space-3);
  align-items: stretch;
}
.kasino-bet-pm {
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm, 8px);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 28px;
  font-weight: 700;
  cursor: pointer;
  transition: border-color 0.18s, background 0.18s;
}
.kasino-bet-pm:hover {
  border-color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 10%, transparent);
}
.kasino-bet-amount {
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--color-text) 4%, transparent);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm, 8px);
  padding: 16px 18px;
}
.kasino-bet-value {
  font-family: var(--font-display, serif);
  font-size: clamp(28px, 3.6vw, 38px);
  font-weight: 800;
  color: var(--color-accent);
  letter-spacing: -0.02em;
}
.kasino-bet-presets {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
}
.kasino-bet-presets button {
  padding: 14px 0;
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm, 8px);
  color: var(--color-muted);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  transition: color 0.18s, border-color 0.18s, background 0.18s;
}
.kasino-bet-presets button:hover {
  color: var(--color-text);
  border-color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 10%, transparent);
}

.kasino-place-btn {
  position: relative;
  align-self: center;
  width: auto;
  min-width: 240px;
  max-width: 100%;
  background: var(--color-accent);
  color: var(--color-on-accent, #fff);
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 20px 24px;
  border: none;
  border-radius: var(--radius-sm, 8px);
  cursor: pointer;
  overflow: hidden;
  isolation: isolate;
  box-shadow: 0 8px 24px var(--color-accent-glow);
  transition:
    transform   var(--dur-fast, 0.18s) var(--ease-out-expo, ease-out),
    background  var(--dur-fast, 0.18s) var(--ease-in-out, ease),
    box-shadow  var(--dur-fast, 0.18s) var(--ease-out-expo, ease-out);
}

.kasino-place-btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 50%;
  height: 100%;
  transform: translateX(-150%) skewX(-18deg);
  background: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in srgb, #fff 58%, transparent) 50%,
    transparent 100%);
  pointer-events: none;
  z-index: 1;
  animation: kasino-sheen-loop 2.375s linear infinite;
}
.kasino-place-btn:hover {
  transform: translateY(-3px) scale(1.015);
  background: var(--color-accent-dim, var(--color-accent));
  box-shadow:
    0 12px 32px var(--color-accent-glow),
    0 0 0 6px color-mix(in srgb, var(--color-accent) 14%, transparent);
}

.kasino-place-btn:hover::before {
  animation-duration: 1.8s;
}
.kasino-place-btn:active { transform: translateY(-1px) scale(1); }
@keyframes kasino-sheen-loop {
  0%   { transform: translateX(-150%) skewX(-18deg); }
  37%  { transform: translateX(300%)  skewX(-18deg); }
  100% { transform: translateX(300%)  skewX(-18deg); }
}
.kasino-place-amount { margin-left: 6px; position: relative; z-index: 2; }

.kasino-actions[data-phase="playing"] {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2);
}
.kasino-action {
  padding: 14px 8px;
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm, 8px);
  color: var(--color-accent);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  transition: color 0.18s, border-color 0.18s, background 0.18s, transform 0.18s, box-shadow 0.18s;
}
.kasino-action:hover {
  transform: translateY(-1px);
  border-color: var(--color-accent);
  box-shadow: 0 6px 16px var(--color-accent-glow);
}
.kasino-action:disabled {
  opacity: 0.35;
  cursor: not-allowed;
  pointer-events: none;
}
.kasino-action--hit:hover    { background: color-mix(in srgb, var(--color-accent) 14%, transparent); }
.kasino-action--stand:hover  { background: color-mix(in srgb, var(--color-text)   6%, transparent); }
.kasino-action--double {
  border-color: color-mix(in srgb, var(--color-accent) 60%, transparent);
  color: var(--color-accent);
}
.kasino-action--double:hover {
  background: color-mix(in srgb, var(--color-accent) 14%, transparent);
  box-shadow: 0 6px 16px var(--color-accent-glow);
}

.kasino-actions[data-phase="result"] {
  position: relative;
  align-items: center;
  gap: var(--space-3);
}

.kasino-actions[data-phase="result"]:has(.kasino-result-label[data-outcome="win"])::before,
.kasino-actions[data-phase="result"]:has(.kasino-result-label[data-outcome="blackjack"])::before {
  content: '';
  position: absolute;
  top: -8%;
  left: 50%;
  width: 92%;
  height: 70%;
  transform: translateX(-50%);
  background: radial-gradient(ellipse at center,
    color-mix(in srgb, #34d399 32%, transparent) 0%,
    color-mix(in srgb, #34d399 14%, transparent) 35%,
    transparent 70%);
  filter: blur(16px);
  pointer-events: none;
  z-index: 0;
  animation: kasino-glow-pulse 3.6s ease-in-out infinite;
}
.kasino-actions[data-phase="result"] > * { position: relative; z-index: 1; }
@keyframes kasino-glow-pulse {
  0%, 100% { opacity: 0.7; transform: translateX(-50%) scale(1);    }
  50%      { opacity: 1;   transform: translateX(-50%) scale(1.06); }
}

.kasino-result-label {
  position: relative;
  margin: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  font-family: var(--font-display, serif);
  font-size: clamp(30px, 4vw, 44px);
  font-weight: 800;
  letter-spacing: -0.015em;
  line-height: 1;
  color: var(--color-text);
  text-align: center;
  padding: 0 8px;
  animation: kasino-result-in 0.55s var(--ease-out-expo, ease-out) both;
}

.kasino-result-label::before,
.kasino-result-label::after {
  content: '✦';
  display: inline-block;
  font-size: 0.42em;
  line-height: 1;
  opacity: 0.55;
  transform: translateY(-0.08em);
}

.kasino-result-label::after { }
@keyframes kasino-result-in {
  0%   { opacity: 0; transform: translateY(10px) scale(0.88); }
  55%  { opacity: 1; transform: translateY(0)    scale(1.06); }
  100% { opacity: 1; transform: translateY(0)    scale(1); }
}

.kasino-actions[data-phase="result"] .kasino-result-label {
  isolation: isolate;
}
.kasino-actions[data-phase="result"] .kasino-result-label > .kasino-result-text {
  position: relative;
  z-index: 1;
}

.kasino-result-label[data-outcome="win"],
.kasino-result-label[data-outcome="blackjack"] {
  background: linear-gradient(110deg,
    #6ee7b7 0%,
    #34d399 25%,
    #a7f3d0 45%,
    #34d399 65%,
    #10b981 100%);
  background-size: 220% 100%;
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  color: #34d399;
  filter:
    drop-shadow(0 0 20px color-mix(in srgb, #34d399 60%, transparent))
    drop-shadow(0 0 42px color-mix(in srgb, #34d399 38%, transparent));
  animation:
    kasino-result-in 0.55s var(--ease-out-expo, ease-out) both,
    kasino-result-shimmer 4.5s 0.6s linear infinite,
    kasino-result-pulse 2.4s 0.6s ease-in-out infinite;
}
@keyframes kasino-result-shimmer {
  0%   { background-position: 0%   50%; }
  100% { background-position: 200% 50%; }
}
@keyframes kasino-result-pulse {
  0%, 100% {
    filter:
      drop-shadow(0 0 20px color-mix(in srgb, #34d399 60%, transparent))
      drop-shadow(0 0 42px color-mix(in srgb, #34d399 38%, transparent));
  }
  50% {
    filter:
      drop-shadow(0 0 32px color-mix(in srgb, #34d399 78%, transparent))
      drop-shadow(0 0 60px color-mix(in srgb, #34d399 50%, transparent));
  }
}

.kasino-result-label[data-outcome="win"]::before,
.kasino-result-label[data-outcome="win"]::after,
.kasino-result-label[data-outcome="blackjack"]::before,
.kasino-result-label[data-outcome="blackjack"]::after {
  color: #34d399;
  opacity: 0.85;
  text-shadow:
    0 0 8px  color-mix(in srgb, #34d399 70%, transparent),
    0 0 18px color-mix(in srgb, #34d399 35%, transparent);
  animation: kasino-ornament-spin 6s 0.6s linear infinite;
}
@keyframes kasino-ornament-spin {
  0%   { transform: translateY(-0.08em) rotate(0deg);   }
  100% { transform: translateY(-0.08em) rotate(360deg); }
}

.kasino-result-label[data-outcome="blackjack"] {
  font-size: clamp(34px, 4.6vw, 50px);
}
.kasino-result-label[data-outcome="loss"] { color: #ef4444; }
.kasino-result-label[data-outcome="loss"]::before,
.kasino-result-label[data-outcome="loss"]::after { color: #ef4444; }
.kasino-result-label[data-outcome="push"] { color: var(--color-muted); }

.kasino-result-amount {
  margin: 0;
  font-family: var(--font-display, serif);
  font-size: clamp(18px, 2.4vw, 24px);
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--color-muted);
  text-align: center;
  animation: kasino-result-in 0.55s 0.08s var(--ease-out-expo, ease-out) both;
}
.kasino-result-label[data-outcome="win"]      ~ .kasino-result-amount,
.kasino-result-label[data-outcome="blackjack"] ~ .kasino-result-amount {
  color: #34d399;
  text-shadow: 0 0 16px color-mix(in srgb, #34d399 35%, transparent);
}
.kasino-result-label[data-outcome="loss"] ~ .kasino-result-amount {
  color: #ef4444;
  text-shadow: 0 0 12px color-mix(in srgb, #ef4444 25%, transparent);
}

.kasino-result-label[data-outcome="push"] ~ .kasino-result-amount {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.kasino-balance-wrap {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-3);
}

.kasino-result-streak[hidden] { display: none !important; }
.kasino-result-streak {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  background: color-mix(in srgb, #34d399 14%, transparent);
  border: 1px solid color-mix(in srgb, #34d399 45%, transparent);
  border-radius: 999px;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #6ee7b7;
  box-shadow: 0 0 12px color-mix(in srgb, #34d399 30%, transparent);
  animation: kasino-streak-in 0.5s var(--ease-out-expo, ease-out) both;
  white-space: nowrap;
}
.kasino-result-streak strong {
  font-weight: 800;
  color: #a7f3d0;
  font-size: 1.08em;
}
.kasino-streak-flame {
  font-size: 1.1em;
  line-height: 1;
  display: inline-block;
  animation: kasino-streak-flicker 1.3s ease-in-out infinite;
}
@keyframes kasino-streak-in {
  0%   { opacity: 0; transform: translateY(6px) scale(0.85); }
  100% { opacity: 1; transform: translateY(0)   scale(1); }
}
@keyframes kasino-streak-flicker {
  0%, 100% { transform: scale(1)    rotate(-2deg); }
  50%      { transform: scale(1.18) rotate(3deg);  }
}
.kasino-newhand {
  position: relative;
  width: min(280px, 100%);
  padding: 12px 18px;
  background: transparent;
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-sm, 8px);
  color: var(--color-accent);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  overflow: hidden;
  isolation: isolate;
  transition:
    background var(--dur-fast, 0.18s) var(--ease-in-out, ease),
    color      var(--dur-fast, 0.18s) var(--ease-in-out, ease),
    transform  var(--dur-fast, 0.18s) var(--ease-out-expo, ease-out),
    box-shadow var(--dur-fast, 0.18s) var(--ease-out-expo, ease-out);
}

.kasino-newhand::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 50%;
  height: 100%;
  transform: translateX(-150%) skewX(-18deg);
  background: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in srgb, var(--color-accent) 40%, transparent) 50%,
    transparent 100%);
  pointer-events: none;
  z-index: 1;
  animation: kasino-sheen-loop 2.375s linear infinite;
}
.kasino-newhand:hover {
  background: var(--color-accent);
  color: var(--color-on-accent, #fff);
  transform: translateY(-2px) scale(1.02);
  box-shadow:
    0 10px 26px var(--color-accent-glow),
    0 0 0 4px color-mix(in srgb, var(--color-accent) 12%, transparent);
}

.kasino-newhand:hover::before {
  background: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in srgb, #fff 58%, transparent) 50%,
    transparent 100%);
  animation-duration: 1.8s;
}
.kasino-newhand:active { transform: translateY(0) scale(1); }

.kasino-endstate {
  position: absolute;
  inset: 0;
  z-index: 20;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  padding: var(--space-6) var(--space-5);
  background: color-mix(in srgb, var(--color-surface-2) 86%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.kasino-endstate[hidden] { display: none; }

.kasino-endstate-icon:empty { display: none; }
.kasino-endstate-icon {
  font-size: clamp(115px, 17vw, 192px);
  line-height: 1;
  text-align: center;
  align-self: center;
  filter: drop-shadow(0 8px 24px rgba(0,0,0,0.45));
  animation: kasino-icon-bounce 0.7s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
.kasino-endstate[data-kind="won"] .kasino-endstate-icon,
.kasino-endstate[data-kind="busted"] .kasino-endstate-icon {
  animation:
    kasino-icon-bounce 0.7s cubic-bezier(0.34, 1.56, 0.64, 1) both,
    kasino-icon-spin 1.2s 0.7s linear infinite;
}
@keyframes kasino-icon-bounce {
  0%   { opacity: 0; transform: translateY(-24px) scale(0.3) rotate(-12deg); }
  60%  { opacity: 1; transform: translateY(6px)   scale(1.15) rotate(6deg); }
  100% { opacity: 1; transform: translateY(0)     scale(1)    rotate(0deg); }
}
@keyframes kasino-icon-spin {
  0%   { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.kasino-endstate-score:empty { display: none; }
.kasino-endstate-score {
  font-family: var(--font-display, serif);
  font-size: clamp(40px, 6vw, 68px);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1;
  background: linear-gradient(135deg, #a7f3d0 0%, #34d399 50%, #10b981 100%);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  color: #34d399;
  filter: drop-shadow(0 0 22px color-mix(in srgb, #34d399 55%, transparent));
  animation:
    kasino-score-in 0.6s 0.2s cubic-bezier(0.34, 1.56, 0.64, 1) both,
    kasino-victory-glow 2.4s 0.8s ease-in-out infinite;
}
@keyframes kasino-score-in {
  0%   { opacity: 0; transform: scale(0.6); }
  100% { opacity: 1; transform: scale(1); }
}

.kasino-endstate[data-kind="won"]::before {
  content: '';
  position: absolute;
  inset: -10% -5%;
  background: radial-gradient(ellipse at center,
    color-mix(in srgb, #34d399 32%, transparent) 0%,
    color-mix(in srgb, #10b981 14%, transparent) 40%,
    transparent 70%);
  filter: blur(20px);
  pointer-events: none;
  z-index: 0;
  animation: kasino-victory-pulse 2.8s ease-in-out infinite;
}
.kasino-endstate[data-kind="won"] > * { position: relative; z-index: 1; }
.kasino-endstate[data-kind="won"] .kasino-endstate-title {
  font-size: clamp(44px, 7vw, 64px);
  background: linear-gradient(110deg,
    #6ee7b7 0%,
    #34d399 30%,
    #a7f3d0 50%,
    #34d399 70%,
    #10b981 100%);
  background-size: 220% 100%;
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  color: #34d399;
  filter:
    drop-shadow(0 0 20px color-mix(in srgb, #34d399 60%, transparent))
    drop-shadow(0 0 42px color-mix(in srgb, #34d399 38%, transparent));
  animation:
    kasino-victory-punch 0.75s cubic-bezier(0.34, 1.56, 0.64, 1) both,
    kasino-victory-shimmer 4.5s 0.75s linear infinite,
    kasino-victory-glow 2.4s 0.75s ease-in-out infinite;
  letter-spacing: -0.005em;

  line-height: 1.2;
  padding: 0.08em 0.12em;
  max-width: 100%;
}
.kasino-endstate[data-kind="won"] .kasino-endstate-sub {
  color: color-mix(in srgb, #a7f3d0 75%, var(--color-muted));
  font-size: 15px;
  text-shadow: 0 0 10px color-mix(in srgb, #34d399 24%, transparent);
}
.kasino-endstate[data-kind="won"] .kasino-endstate-btn {
  background: #10b981;
  box-shadow:
    0 8px 24px color-mix(in srgb, #34d399 55%, transparent),
    0 0 0 1px color-mix(in srgb, #34d399 30%, transparent);
}
.kasino-endstate[data-kind="won"] .kasino-endstate-btn:hover {
  background: #34d399;
  transform: translateY(-3px) scale(1.015);
  box-shadow:
    0 12px 32px color-mix(in srgb, #34d399 60%, transparent),
    0 0 0 6px color-mix(in srgb, #34d399 20%, transparent);
}

@keyframes kasino-victory-punch {
  0%   { opacity: 0; transform: translateY(-30px) scale(0.5) rotate(-2deg); }
  60%  { opacity: 1; transform: translateY(6px)   scale(1.1)  rotate(1deg); }
  80%  {              transform: translateY(-2px) scale(0.97) rotate(-0.3deg); }
  100% { opacity: 1; transform: translateY(0)    scale(1)    rotate(0deg); }
}

@keyframes kasino-victory-shimmer {
  0%   { background-position: 0%   50%; }
  100% { background-position: 200% 50%; }
}

@keyframes kasino-victory-glow {
  0%, 100% {
    filter:
      drop-shadow(0 0 20px color-mix(in srgb, #34d399 60%, transparent))
      drop-shadow(0 0 42px color-mix(in srgb, #34d399 38%, transparent));
  }
  50% {
    filter:
      drop-shadow(0 0 32px color-mix(in srgb, #34d399 78%, transparent))
      drop-shadow(0 0 60px color-mix(in srgb, #34d399 50%, transparent));
  }
}
@keyframes kasino-victory-pulse {
  0%, 100% { opacity: 0.7; transform: scale(1);    }
  50%      { opacity: 1;   transform: scale(1.06); }
}

.kasino-endstate[data-kind="busted"]::before {
  content: '';
  position: absolute;
  inset: -10% -5%;
  background: radial-gradient(ellipse at center,
    color-mix(in srgb, #ef4444 28%, transparent) 0%,
    color-mix(in srgb, #dc2626 10%, transparent) 40%,
    transparent 70%);
  filter: blur(18px);
  pointer-events: none;
  z-index: 0;
  animation: kasino-bankrot-pulse 2.6s ease-in-out infinite;
}
.kasino-endstate[data-kind="busted"] > * { position: relative; z-index: 1; }

.kasino-endstate-title {
  margin: 0;
  font-family: var(--font-display, serif);
  font-size: clamp(28px, 5vw, 44px);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--color-text);
  text-align: center;
  max-width: 100%;
  animation: kasino-endstate-in 0.5s var(--ease-out-expo, ease-out) both;
}

.kasino-endstate[data-kind="busted"] .kasino-endstate-title {
  font-size: clamp(40px, 7vw, 64px);
  background: linear-gradient(135deg,
    #fca5a5 0%,
    #ef4444 35%,
    #dc2626 70%,
    #991b1b 100%);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  color: #ef4444;
  filter:
    drop-shadow(0 0 18px color-mix(in srgb, #ef4444 55%, transparent))
    drop-shadow(0 0 36px color-mix(in srgb, #dc2626 35%, transparent));
  animation:
    kasino-bankrot-punch 0.7s cubic-bezier(0.34, 1.56, 0.64, 1) both,
    kasino-bankrot-shake 3.2s 0.7s ease-in-out infinite;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 1.2;
  padding: 0.08em 0.12em;
}
@keyframes kasino-endstate-in {
  0%   { opacity: 0; transform: translateY(8px) scale(0.92); }
  100% { opacity: 1; transform: translateY(0)   scale(1); }
}

@keyframes kasino-bankrot-punch {
  0%   { opacity: 0; transform: translateY(-30px) scale(0.4) rotate(-3deg); }
  60%  { opacity: 1; transform: translateY(6px)   scale(1.12) rotate(1deg); }
  80%  {              transform: translateY(-2px) scale(0.96) rotate(-0.5deg); }
  100% { opacity: 1; transform: translateY(0)    scale(1)    rotate(0deg); }
}

@keyframes kasino-bankrot-shake {
  0%, 100% { transform: translateX(0); }
  10%      { transform: translateX(-1px) rotate(-0.4deg); }
  20%      { transform: translateX(1px)  rotate(0.4deg); }
  30%      { transform: translateX(-1px) rotate(-0.2deg); }
  40%      { transform: translateX(1px)  rotate(0.2deg); }
  50%      { transform: translateX(0)    rotate(0deg); }
}

@keyframes kasino-bankrot-pulse {
  0%, 100% { opacity: 0.7; transform: scale(1);    }
  50%      { opacity: 1;   transform: scale(1.08); }
}

.kasino-endstate-sub {
  margin: 0;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--color-muted);
  text-align: center;
  animation: kasino-endstate-in 0.5s 0.15s var(--ease-out-expo, ease-out) both;
}
.kasino-endstate[data-kind="busted"] .kasino-endstate-sub {
  color: color-mix(in srgb, #fca5a5 80%, var(--color-muted));
  font-size: clamp(17px, 2vw, 21px);
  font-weight: 600;
  text-shadow: 0 0 12px color-mix(in srgb, #ef4444 28%, transparent);
}

.kasino-endstate-btn {
  position: relative;
  padding: 14px 28px;
  background: var(--color-accent);
  color: var(--color-on-accent, #fff);
  border: none;
  border-radius: var(--radius-sm, 8px);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  overflow: hidden;
  isolation: isolate;
  box-shadow: 0 8px 24px var(--color-accent-glow);
  transition: transform 0.18s, background 0.18s, box-shadow 0.18s;
  animation: kasino-endstate-in 0.5s 0.3s var(--ease-out-expo, ease-out) both;
}
.kasino-endstate-btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 50%;
  height: 100%;
  transform: translateX(-150%) skewX(-18deg);
  background: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in srgb, #fff 58%, transparent) 50%,
    transparent 100%);
  pointer-events: none;
  z-index: 1;
  animation: kasino-sheen-loop 2.375s linear infinite;
}
.kasino-endstate-btn:hover {
  transform: translateY(-3px) scale(1.015);
  background: var(--color-accent-dim);
  box-shadow:
    0 12px 32px var(--color-accent-glow),
    0 0 0 6px color-mix(in srgb, var(--color-accent) 14%, transparent);
}
.kasino-endstate-btn:hover::before {
  animation-duration: 1.8s;
}
.kasino-endstate-btn:active { transform: translateY(-1px) scale(1); }

.kasino-endstate[data-kind="busted"] .kasino-endstate-btn {
  background: #dc2626;
  box-shadow:
    0 8px 24px color-mix(in srgb, #ef4444 50%, transparent),
    0 0 0 1px color-mix(in srgb, #ef4444 30%, transparent);
}
.kasino-endstate[data-kind="busted"] .kasino-endstate-btn:hover {
  background: #ef4444;
  transform: translateY(-3px) scale(1.015);
  box-shadow:
    0 12px 32px color-mix(in srgb, #ef4444 60%, transparent),
    0 0 0 6px color-mix(in srgb, #ef4444 18%, transparent);
}

.kasino-rules {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--color-bg) 70%, transparent);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 10;
  animation: kasino-overlay-in 0.18s var(--ease-out-expo, ease-out);
}
.kasino-rules[hidden] { display: none; }
.kasino-rules-panel {
  width: min(440px, 88%);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.55);
  overflow: hidden;
}
.kasino-rules-head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
}
.kasino-rules-head h3 {
  margin: 0;
  font-family: var(--font-display, serif);
  font-size: 20px;
  font-weight: 800;
  color: var(--color-text);
}

.kasino-rules-close {
  margin-left: auto;
  width: 30px;
  height: 30px;
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  color: var(--color-muted);
  font-size: 18px;
  cursor: pointer;
  transition: color 0.18s, border-color 0.18s;
}
.kasino-rules-close:hover {
  color: var(--color-text);
  border-color: var(--color-muted-dim);
}
.kasino-rules-list {
  list-style: none;
  margin: 0;
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.kasino-rules-list li {
  font-family: var(--font-body);
  font-size: 13px;
  line-height: 1.55;
  color: var(--color-text);
}
.kasino-rules-list strong {
  color: var(--color-accent);
  font-weight: 700;
  margin-right: 4px;
}

.kasino-confetti {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;

  z-index: 30;
  display: grid;
  place-items: center;
}

.kasino-confetti--page {
  position: fixed;
  inset: 0;
  z-index: 100;
}

.kasino-confetti--page span { animation-duration: 15s; }
.kasino-confetti span {
  position: absolute;
  width: var(--size, 10px);
  height: var(--size, 10px);
  border-radius: 50%;
  background: hsl(var(--hue, 200) 80% 64%);
  box-shadow:
    0 0 6px  hsl(var(--hue, 200) 80% 64%),
    0 0 16px hsl(var(--hue, 200) 80% 64% / 0.6);
  animation: kasino-confetti-burst 6.19s cubic-bezier(0.18, 0.7, 0.32, 1) var(--delay, 0s) forwards;
  opacity: 0;
}

.kasino-confetti span[data-shape="square"] {
  border-radius: 2px;
  width: calc(var(--size, 10px) + 2px);
  height: calc(var(--size, 10px) - 2px);
}

.kasino-confetti span[data-shape="spark"] {
  width: 3px;
  height: calc(var(--size, 10px) * 1.4);
  border-radius: 999px;
}

.kasino-confetti span[data-shape="star"] {
  border-radius: 0;
  clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
  width: calc(var(--size, 10px) * 1.3);
  height: calc(var(--size, 10px) * 1.3);
  box-shadow: 0 0 12px hsl(var(--hue, 200) 90% 70% / 0.9);
}

@keyframes kasino-confetti-burst {
  0%   { transform: translate(0, 0)                                                          scale(0.6) rotate(0deg);                              opacity: 1; }
  5%   { transform: translate(calc(var(--x, 0px) * 0.18), calc(var(--y, -300px) * 0.18))      scale(1)   rotate(calc(var(--rot, 540deg) * 0.12)); opacity: 1; }
  40%  { transform: translate(calc(var(--x, 0px) * 0.65), calc(var(--y, -300px) * 0.65))      scale(1)   rotate(calc(var(--rot, 540deg) * 0.5));  opacity: 1; }
  75%  { transform: translate(calc(var(--x, 0px) * 0.92), calc(var(--y, -300px) * 0.92))      scale(0.85) rotate(calc(var(--rot, 540deg) * 0.85)); opacity: 1; }
  100% { transform: translate(var(--x, 0px), var(--y, -300px))                                scale(0.4) rotate(var(--rot, 540deg));              opacity: 0; }
}

@media (max-width: 1024px) {
  .kasino-shell { width: 96vw; }
  .kasino-card  { width: 118px; height: 166px; }
  .kasino-card-center { font-size: 52px; }
  .kasino-card-rank   { font-size: 26px; }
  .kasino-card-suit   { font-size: 18px; }
  .kasino-court-letter { font-size: 42px; }
  .kasino-court-suit   { font-size: 18px; }
  .kasino-cards       { min-height: 176px; }
  .kasino-actions     { width: min(540px, 100%); }

  .kasino-card.is-face .kasino-card-face::before { inset: 28px 14px; }
  .kasino-card.is-face .kasino-card-face::after  { inset: 32px 18px; }
}

@media (max-width: 768px) {

  .kasino-overlay { padding: 34px 0 16px; }
  .kasino-shell {
    width: 100vw;

    height: calc(100vh - 104px);
    height: calc(100dvh - 104px);
    max-height: none;
    border-radius: 0;
    border: none;
  }
  .kasino-progress { width: 100vw; border-radius: 0; border: none; margin-bottom: 0; }
  .kasino-progress-label { font-size: 15px; margin-bottom: 6px; }
  .kasino-topbar {
    padding: 10px var(--space-3);
    grid-template-columns: 1fr auto 1fr;
    gap: var(--space-2);
  }
  .kasino-topbar-end { gap: var(--space-2); }
  .kasino-rules-btn {
    width: 32px;
    height: 32px;
    font-size: 14px;
  }
  .kasino-title { font-size: 20px; }
  .kasino-title-sub { display: none; }
  .kasino-balance { font-size: 18px; }
  .kasino-back { padding: 6px 10px; font-size: 11px; }
  .kasino-stage {
    padding: var(--space-4) var(--space-3) var(--space-5);
    gap: var(--space-4);
  }
  .kasino-card { width: 98px; height: 138px; }
  .kasino-card-center { font-size: 42px; }
  .kasino-card-rank   { font-size: 22px; }
  .kasino-card-suit   { font-size: 15px; }
  .kasino-court-letter { font-size: 36px; }
  .kasino-court-suit   { font-size: 16px; }
  .kasino-cards       { min-height: 148px; }

  .kasino-card.is-face .kasino-card-face::before { inset: 22px 11px; }
  .kasino-card.is-face .kasino-card-face::after  { inset: 26px 15px; }

  .kasino-result-label { gap: 10px; }
  .kasino-result-label::before,
  .kasino-result-label::after { width: 18px; }
  .kasino-actions     { width: 100%; }
  .kasino-bet-row     { grid-template-columns: 60px 1fr 60px; gap: var(--space-2); }
  .kasino-bet-pm      { font-size: 24px; }
  .kasino-bet-amount  { padding: 12px 14px; }
  .kasino-action      { padding: 18px 4px; font-size: 13px; }
  .kasino-place-btn   { padding: 18px; font-size: 14px; }
  .kasino-rules-panel { width: 92%; }

  .kasino-lang-code { display: none; }
  .kasino-lang-btn { padding: 5px 6px; }
}

@media (max-height: 860px) {
  .kasino-stage { gap: var(--space-3); padding: var(--space-4) var(--space-6); }
  .kasino-card  { width: 112px; height: 158px; }
  .kasino-card-center { font-size: 50px; }
  .kasino-card-rank   { font-size: 25px; }
  .kasino-card-suit   { font-size: 17px; }
  .kasino-court-letter { font-size: 42px; }
  .kasino-court-suit   { font-size: 18px; }
  .kasino-cards       { min-height: 160px; }
  .kasino-hand        { gap: var(--space-2); }
  .kasino-card.is-face .kasino-card-face::before { inset: 28px 14px; }
  .kasino-card.is-face .kasino-card-face::after  { inset: 32px 18px; }
}
@media (max-height: 860px) {

  .kasino-endstate { gap: var(--space-3); }
  .kasino-endstate-icon { font-size: clamp(96px, 13vw, 144px); }
  .kasino-endstate-score { font-size: clamp(34px, 5vw, 56px); }
}
@media (max-height: 740px) {
  .kasino-stage { gap: var(--space-2); padding: var(--space-3) var(--space-6); }
  .kasino-card  { width: 92px; height: 130px; }
  .kasino-card-center { font-size: 40px; }
  .kasino-card-rank   { font-size: 21px; }
  .kasino-card-suit   { font-size: 14px; }
  .kasino-court-letter { font-size: 34px; }
  .kasino-court-suit   { font-size: 15px; }
  .kasino-cards       { min-height: 132px; }
  .kasino-card.is-face .kasino-card-face::before { inset: 22px 11px; }
  .kasino-card.is-face .kasino-card-face::after  { inset: 26px 15px; }
  .kasino-endstate { gap: 10px; }
  .kasino-endstate-icon { font-size: clamp(77px, 11vw, 110px); }
  .kasino-endstate-score { font-size: clamp(30px, 4.5vw, 46px); }
  .kasino-endstate[data-kind="won"] .kasino-endstate-title,
  .kasino-endstate[data-kind="busted"] .kasino-endstate-title { font-size: clamp(34px, 5.5vw, 48px); }
}
@media (max-height: 640px) {
  .kasino-card  { width: 76px; height: 108px; }
  .kasino-card-center { font-size: 32px; }
  .kasino-card-rank   { font-size: 17px; }
  .kasino-card-suit   { font-size: 12px; }
  .kasino-court-letter { font-size: 28px; }
  .kasino-court-suit   { font-size: 13px; }
  .kasino-cards       { min-height: 110px; }
}

@media (max-width: 768px) {
  .kasino-stage { gap: var(--space-3); }
  .kasino-card { width: 86px; height: 120px; }
  .kasino-card-center  { font-size: 36px; }
  .kasino-card-rank    { font-size: 19px; }
  .kasino-card-suit    { font-size: 13px; }
  .kasino-court-letter { font-size: 30px; }
  .kasino-court-suit   { font-size: 14px; }
  .kasino-cards        { min-height: 124px; flex-wrap: nowrap; }
  .kasino-cards:has(.kasino-card:nth-child(4)) { gap: 0; }
  .kasino-cards:has(.kasino-card:nth-child(4)) .kasino-card + .kasino-card { margin-left: -14px; }
  .kasino-cards:has(.kasino-card:nth-child(5)) .kasino-card + .kasino-card { margin-left: -26px; }
  .kasino-cards:has(.kasino-card:nth-child(6)) .kasino-card + .kasino-card { margin-left: -38px; }
  .kasino-cards:has(.kasino-card:nth-child(7)) .kasino-card + .kasino-card { margin-left: -48px; }
  .kasino-card.is-face .kasino-card-face::before { inset: 18px 9px; }
  .kasino-card.is-face .kasino-card-face::after  { inset: 22px 12px; }
}
@media (max-width: 768px) and (max-height: 720px) {
  .kasino-stage { gap: var(--space-2); }
  .kasino-card { width: 74px; height: 104px; }
  .kasino-card-center  { font-size: 30px; }
  .kasino-card-rank    { font-size: 16px; }
  .kasino-card-suit    { font-size: 11px; }
  .kasino-court-letter { font-size: 26px; }
  .kasino-court-suit   { font-size: 12px; }
  .kasino-cards        { min-height: 108px; }
}

@media (prefers-reduced-motion: reduce) {
  .kasino-overlay,
  .kasino-shell,
  .kasino-card,
  .kasino-balance.is-flash-gain,
  .kasino-balance.is-flash-loss,
  .kasino-result-label,
  .kasino-result-amount,
  .kasino-result-label::before,
  .kasino-result-label::after,
  .kasino-actions[data-phase="result"]::before,
  .kasino-result-streak,
  .kasino-streak-flame,
  .kasino-rules-btn::before,
  .kasino-place-btn::before,
  .kasino-newhand::before,
  .kasino-endstate-btn::before,
  .kasino-endstate-title,
  .kasino-endstate-sub,
  .kasino-endstate-btn,
  .kasino-endstate[data-kind="busted"]::before,
  .kasino-endstate[data-kind="won"]::before,
  .kasino-endstate[data-kind="won"] .kasino-endstate-title,
  .kasino-endstate[data-kind="busted"] .kasino-endstate-title,
  .kasino-endstate-icon,
  .kasino-endstate[data-kind="won"] .kasino-endstate-icon,
  .kasino-endstate-score,
  .kasino-progress-bar.is-gold,
  .kasino-stats,
  .kasino-title {
    animation: none !important;
  }
  .kasino-card-face,
  .kasino-card-back {
    transition: none !important;
  }
  .kasino-confetti span { display: none; }

  .kasino-ambient::after { animation: none !important; }
  .kasino-orb {
    animation: none !important;
    opacity: 0.14 !important;
  }
}

:root[data-theme="light"] .kasino-card-face { background: #ffffff; color: #15171a; }
:root[data-theme="light"] .kasino-card.is-red .kasino-card-face { color: #c52525; }
