.game-page {
  --game-ink: var(--paper-1);
  --game-muted: var(--paper-2);
  --game-panel: color-mix(in srgb, var(--bg-1) 86%, transparent);
  --game-panel-strong: color-mix(in srgb, var(--bg-1) 92%, var(--bg-2) 8%);
  --game-line: color-mix(in srgb, var(--bg-3) 34%, transparent);
  --game-gold: var(--gold-1);
  --game-red: var(--accent);
  --game-green: var(--green-1);
  --game-cyan: var(--bg-3);
  --game-shadow: color-mix(in srgb, var(--ink) 42%, transparent);
  min-height: 100vh;
  color: var(--game-ink);
  background:
    radial-gradient(
      circle at 15% 10%,
      color-mix(in srgb, var(--paper-1) 20%, transparent),
      transparent 35%
    ),
    radial-gradient(
      circle at 85% 0%,
      color-mix(in srgb, var(--accent-2) 20%, transparent),
      transparent 40%
    ),
    radial-gradient(
      circle at 50% 80%,
      color-mix(in srgb, var(--accent-2) 25%, transparent),
      transparent 55%
    ),
    linear-gradient(
      180deg,
      var(--bg-2),
      var(--bg-1) 45%,
      var(--wood-dark) 70%,
      var(--wood-1) 85%,
      var(--wood-1) 100%
    );
  letter-spacing: 0;
}

.game-page * {
  box-sizing: border-box;
}

.game-page .game-desktop-links .nav-link-icon {
  width: 17px;
  height: 17px;
  flex: 0 0 auto;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.game-page .game-current-link {
  cursor: default;
  border-color: color-mix(in srgb, var(--gold-1) 80%, transparent);
  background:
    linear-gradient(
      145deg,
      color-mix(in srgb, var(--bg-3) 34%, transparent),
      color-mix(in srgb, var(--gold-1) 22%, transparent)
    ),
    color-mix(in srgb, var(--bg-1) 76%, transparent);
}

.game-shell {
  width: min(1180px, calc(100% - 32px));
  margin: 38px auto 64px;
}

.game-page section {
  opacity: 1;
  transform: none;
  padding: 0;
}

.casino-stage {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.65fr);
  gap: 18px;
  align-items: stretch;
}

.casino-machine,
.casino-panel {
  border: 1px solid var(--game-line);
  border-radius: 8px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--paper-1) 8%, transparent), transparent),
    var(--game-panel);
  box-shadow:
    0 24px 46px var(--game-shadow),
    inset 0 1px 0 color-mix(in srgb, var(--paper-1) 12%, transparent);
}

.casino-machine {
  min-width: 0;
  padding: 24px;
  overflow: hidden;
}

.casino-machine__top {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding-bottom: 18px;
  border-bottom: 1px solid color-mix(in srgb, var(--gold-1) 22%, transparent);
}

.casino-machine__logo {
  width: 64px;
  height: 64px;
  object-fit: contain;
  filter: drop-shadow(0 10px 16px color-mix(in srgb, var(--ink) 38%, transparent));
}

.casino-machine__eyebrow,
.casino-label {
  display: block;
  margin: 0 0 4px;
  color: var(--game-muted);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.casino-machine h1 {
  margin: 0;
  font-size: 2.4rem;
  line-height: 1;
  letter-spacing: 0;
  color: var(--paper-1);
  text-shadow: 0 2px 18px color-mix(in srgb, var(--gold-2) 24%, transparent);
}

.casino-machine__jackpot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 68px;
  min-height: 48px;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--gold-1) 72%, transparent);
  background: linear-gradient(145deg, var(--gold-1), var(--gold-2) 52%, color-mix(in srgb, var(--gold-2) 42%, var(--bg-1)));
  color: var(--ink);
  font-size: 1.2rem;
  font-weight: 1000;
  letter-spacing: 0;
  box-shadow: 0 10px 18px color-mix(in srgb, var(--ink) 28%, transparent);
}

.casino-status-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0;
}

.casino-status-row > div {
  min-width: 0;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--paper-1) 10%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--ink) 24%, transparent);
}

.casino-status-row strong {
  display: block;
  overflow-wrap: anywhere;
  color: var(--paper-1);
  font-size: 1.06rem;
  line-height: 1.15;
  letter-spacing: 0;
}

.casino-reels {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  min-height: 252px;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--gold-1) 28%, transparent);
  border-radius: 8px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--ink) 20%, transparent), color-mix(in srgb, var(--ink) 54%, transparent)),
    var(--bg-1);
}

.casino-reel {
  position: relative;
  display: grid;
  grid-template-rows: repeat(3, minmax(0, 1fr));
  gap: 7px;
  place-items: stretch;
  min-width: 0;
  min-height: 218px;
  padding: 8px;
  border: 1px solid color-mix(in srgb, var(--paper-1) 14%, transparent);
  border-radius: 8px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--paper-1) 12%, transparent), transparent),
    color-mix(in srgb, var(--paper-1) 4%, transparent);
  box-shadow:
    inset 0 16px 20px color-mix(in srgb, var(--paper-1) 5%, transparent),
    inset 0 -18px 24px color-mix(in srgb, var(--ink) 28%, transparent);
  overflow: hidden;
  z-index: 2;
}

.casino-reel::before,
.casino-reel::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 24px;
  pointer-events: none;
  z-index: 1;
}

.casino-reel::before {
  top: 0;
  background: linear-gradient(180deg, color-mix(in srgb, var(--ink) 55%, transparent), transparent);
}

.casino-reel::after {
  bottom: 0;
  background: linear-gradient(0deg, color-mix(in srgb, var(--ink) 55%, transparent), transparent);
}

.casino-payline-layer {
  position: absolute;
  inset: 12px;
  z-index: 6;
  pointer-events: none;
}

.casino-payline {
  position: absolute;
  right: 6%;
  left: 6%;
  height: 18px;
  overflow: visible;
  border-radius: 999px;
  background: transparent;
  opacity: 0;
  transform: translateY(-50%) scaleX(0.28);
  transform-origin: center;
  transition:
    opacity 0.18s ease,
    transform 0.22s ease;
}

.casino-payline::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  left: 0;
  height: 2px;
  border-radius: inherit;
  background:
    linear-gradient(90deg, transparent 0%, var(--game-cyan) 14%, var(--paper-1) 50%, var(--game-gold) 86%, transparent 100%);
  box-shadow:
    0 0 6px color-mix(in srgb, var(--game-cyan) 54%, transparent),
    0 0 14px color-mix(in srgb, var(--gold-1) 34%, transparent);
  transform: translateY(-50%);
}

.casino-payline::after {
  content: "";
  position: absolute;
  top: 50%;
  left: -18%;
  width: 18%;
  height: 12px;
  border-radius: inherit;
  background:
    radial-gradient(circle, color-mix(in srgb, var(--paper-1) 92%, transparent), transparent 68%);
  opacity: 0;
  transform: translateY(-50%) skewX(-18deg);
}

.casino-payline.is-active {
  opacity: 0.95;
  transform: translateY(-50%) scaleX(1);
}

.casino-payline.is-scanning::after {
  animation: casinoPaylineScan 0.38s ease-out both;
}

.casino-payline--row-top {
  top: 16.66%;
}

.casino-payline--row-middle {
  top: 50%;
}

.casino-payline--row-bottom {
  top: 83.33%;
}

.casino-payline--diag-down,
.casino-payline--diag-up {
  top: 50%;
  right: 1%;
  left: 1%;
}

.casino-payline--diag-down {
  --casino-payline-angle: 24deg;
  transform: translateY(-50%) rotate(var(--casino-payline-angle)) scaleX(0.28);
}

.casino-payline--diag-up {
  --casino-payline-angle: 24deg;
  transform: translateY(-50%) rotate(calc(var(--casino-payline-angle) * -1)) scaleX(0.28);
}

.casino-payline--diag-down.is-active {
  transform: translateY(-50%) rotate(var(--casino-payline-angle)) scaleX(1);
}

.casino-payline--diag-up.is-active {
  transform: translateY(-50%) rotate(calc(var(--casino-payline-angle) * -1)) scaleX(1);
}

.casino-mobile-result {
  display: none;
}

.casino-symbol {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 52px;
  padding: 6px 8px;
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--paper-1) 28%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--paper-1) 22%, transparent), transparent),
    linear-gradient(145deg, var(--symbol-a, var(--bg-3)), var(--symbol-b, color-mix(in srgb, var(--bg-3) 34%, var(--bg-1))));
  color: var(--symbol-text, var(--ink));
  box-shadow:
    0 14px 24px color-mix(in srgb, var(--ink) 30%, transparent),
    inset 0 1px 0 color-mix(in srgb, var(--paper-1) 46%, transparent);
}

.casino-symbol__image {
  display: block;
  width: min(100%, 42px);
  height: auto;
  aspect-ratio: 1;
  object-fit: contain;
  filter: drop-shadow(0 8px 10px color-mix(in srgb, var(--ink) 28%, transparent));
  pointer-events: none;
  user-select: none;
}

.casino-symbol.is-winning {
  border-color: color-mix(in srgb, var(--gold-1) 90%, transparent);
  animation: casinoWinningSymbolPulse 0.78s ease-out both;
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--gold-1) 20%, transparent),
    0 14px 24px color-mix(in srgb, var(--ink) 30%, transparent),
    inset 0 1px 0 color-mix(in srgb, var(--paper-1) 58%, transparent),
    inset 0 -18px 22px color-mix(in srgb, var(--ink) 16%, transparent);
}

.casino-symbol[data-symbol="pops"] {
  --symbol-a: color-mix(in srgb, var(--bg-3) 72%, var(--paper-1));
  --symbol-b: color-mix(in srgb, var(--bg-3) 62%, var(--bg-1));
}

.casino-symbol[data-symbol="ticket"] {
  --symbol-a: var(--gold-1);
  --symbol-b: color-mix(in srgb, var(--gold-2) 74%, var(--bg-1));
}

.casino-symbol[data-symbol="spark"] {
  --symbol-a: color-mix(in srgb, var(--green-1) 72%, var(--paper-1));
  --symbol-b: color-mix(in srgb, var(--green-1) 48%, var(--bg-1));
}

.casino-symbol[data-symbol="star"] {
  --symbol-a: var(--paper-1);
  --symbol-b: var(--gold-2);
}

.casino-symbol[data-symbol="crown"] {
  --symbol-a: color-mix(in srgb, var(--accent) 32%, var(--paper-1));
  --symbol-b: color-mix(in srgb, var(--accent) 72%, var(--bg-1));
  --symbol-text: var(--ink);
}

.casino-symbol[data-symbol="seven"] {
  --symbol-a: var(--accent);
  --symbol-b: color-mix(in srgb, var(--accent) 52%, var(--bg-1));
  --symbol-text: var(--paper-1);
}

.casino-reel.is-spinning .casino-symbol {
  animation: casinoSymbolFlicker 0.12s linear infinite;
}

.casino-reel.is-anticipating {
  border-color: color-mix(in srgb, var(--gold-1) 74%, transparent);
  box-shadow:
    0 0 28px color-mix(in srgb, var(--gold-1) 18%, transparent),
    inset 0 16px 20px color-mix(in srgb, var(--paper-1) 7%, transparent),
    inset 0 -18px 24px color-mix(in srgb, var(--ink) 28%, transparent);
}

.casino-reel.is-anticipating .casino-symbol {
  animation: casinoFinalColumnCharge 0.18s ease-in-out infinite alternate;
}

.casino-reel.is-revealing .casino-symbol {
  animation: casinoSymbolRevealSnap 0.36s cubic-bezier(0.2, 0.9, 0.25, 1.2) both;
}

.casino-reel.is-final-reveal .casino-symbol {
  animation: casinoSymbolFinalReveal 0.52s cubic-bezier(0.18, 0.9, 0.2, 1.18) both;
}

.casino-reel.is-settled {
  border-color: color-mix(in srgb, var(--gold-1) 78%, transparent);
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--gold-1) 14%, transparent),
    inset 0 16px 20px color-mix(in srgb, var(--paper-1) 6%, transparent),
    inset 0 -18px 24px color-mix(in srgb, var(--ink) 28%, transparent);
}

.casino-controls {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  margin-top: 18px;
}

.casino-wager-controls {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(148px, 0.42fr);
  gap: 8px;
  align-items: stretch;
  min-width: 0;
}

.casino-bets {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  min-width: 0;
}

.casino-bets button,
.casino-spin {
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border: 1px solid color-mix(in srgb, var(--gold-1) 42%, transparent);
  border-radius: 8px;
  color: var(--paper-1);
  font: inherit;
  font-weight: 900;
  letter-spacing: 0;
  cursor: pointer;
  transition:
    transform 0.16s ease,
    border-color 0.16s ease,
    background 0.16s ease,
    box-shadow 0.16s ease,
    opacity 0.16s ease;
}

.casino-bets button {
  display: inline-flex;
  gap: 7px;
  background: color-mix(in srgb, var(--paper-1) 8%, transparent);
}

.casino-bets button::after {
  content: none;
}

.casino-bets button.is-active {
  border-color: color-mix(in srgb, var(--gold-1) 86%, transparent);
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--bg-3) 24%, transparent),
    color-mix(in srgb, var(--gold-1) 20%, transparent)
  );
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--gold-1) 12%, transparent);
}

.casino-manual-bet {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-width: 0;
  min-height: 48px;
  padding: 7px 10px;
  border: 1px solid color-mix(in srgb, var(--gold-1) 36%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--paper-1) 7%, transparent);
  color: var(--paper-1);
  transition:
    transform 0.16s ease,
    border-color 0.16s ease,
    background 0.16s ease,
    box-shadow 0.16s ease,
    opacity 0.16s ease;
}

.casino-manual-bet:focus-within,
.casino-manual-bet.is-active {
  border-color: color-mix(in srgb, var(--gold-1) 86%, transparent);
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--bg-3) 20%, transparent),
    color-mix(in srgb, var(--gold-1) 14%, transparent)
  );
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--gold-1) 12%, transparent);
}

.casino-manual-bet__label {
  color: var(--game-muted);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.casino-manual-bet__field {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  min-width: 0;
}

.casino-manual-bet input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  appearance: textfield;
  background: transparent;
  color: var(--paper-1);
  font: inherit;
  font-weight: 950;
  letter-spacing: 0;
  text-align: right;
}

.casino-manual-bet input::placeholder {
  color: color-mix(in srgb, var(--paper-1) 46%, transparent);
  opacity: 1;
}

.casino-manual-bet input[aria-invalid="true"] {
  color: color-mix(in srgb, var(--accent) 58%, var(--paper-1));
}

.casino-manual-bet input:disabled {
  cursor: not-allowed;
}

.casino-manual-bet input::-webkit-outer-spin-button,
.casino-manual-bet input::-webkit-inner-spin-button {
  margin: 0;
  -webkit-appearance: none;
  appearance: none;
}

.casino-spin {
  min-width: 170px;
  padding: 0 18px;
  background: linear-gradient(145deg, var(--gold-1), var(--gold-2) 48%, var(--bg-3));
  color: var(--ink);
  box-shadow: 0 14px 22px color-mix(in srgb, var(--ink) 28%, transparent);
}

.casino-bets button:hover,
.casino-bets button:focus-visible,
.casino-manual-bet:hover,
.casino-spin:hover,
.casino-spin:focus-visible {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--paper-1) 90%, transparent);
  outline: none;
}

.casino-bets button:disabled,
.casino-manual-bet.is-disabled,
.casino-spin:disabled {
  cursor: not-allowed;
  opacity: 0.52;
  transform: none;
}

.casino-message {
  min-height: 24px;
  margin: 16px 0 0;
  color: var(--game-muted);
  font-weight: 800;
  letter-spacing: 0;
}

.casino-message[data-tone="success"] {
  color: color-mix(in srgb, var(--green-1) 78%, var(--paper-1));
}

.casino-message[data-tone="danger"] {
  color: color-mix(in srgb, var(--accent) 50%, var(--paper-1));
}

.casino-panel {
  display: flex;
  min-width: 0;
  flex-direction: column;
  gap: 18px;
  padding: 20px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--paper-1) 8%, transparent), transparent),
    var(--game-panel-strong);
}

.casino-panel__section + .casino-panel__section {
  padding-top: 18px;
  border-top: 1px solid color-mix(in srgb, var(--gold-1) 18%, transparent);
}

.casino-panel h2 {
  margin: 0 0 12px;
  color: var(--paper-1);
  font-size: 1.1rem;
  line-height: 1.1;
  letter-spacing: 0;
}

.casino-payouts,
.casino-history {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
}

.casino-payouts {
  list-style: none;
}

.casino-history {
  --casino-history-row-height: 84px;
  --casino-history-row-gap: 8px;
  max-height: calc(
    (var(--casino-history-row-height) * 3) +
    (var(--casino-history-row-gap) * 2)
  );
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 6px;
  scrollbar-color: color-mix(in srgb, var(--gold-1) 64%, transparent) color-mix(in srgb, var(--paper-1) 8%, transparent);
  scrollbar-width: thin;
}

.casino-history::-webkit-scrollbar {
  width: 8px;
}

.casino-history::-webkit-scrollbar-track {
  border-radius: 999px;
  background: color-mix(in srgb, var(--paper-1) 8%, transparent);
}

.casino-history::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: color-mix(in srgb, var(--gold-1) 64%, transparent);
}

.casino-payouts li,
.casino-history li {
  display: flex;
  min-width: 0;
  min-height: var(--casino-history-row-height, auto);
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid color-mix(in srgb, var(--paper-1) 8%, transparent);
  color: var(--game-muted);
  line-height: 1.25;
}

.casino-payouts span,
.casino-history span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.casino-payout-symbols,
.casino-history-symbols,
.casino-history-round {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.casino-history-round {
  gap: 10px;
}

.casino-history-round small {
  display: block;
  min-width: 82px;
  color: var(--game-muted);
  font-size: 0.72rem;
  font-weight: 850;
  line-height: 1.15;
}

.casino-history-grid {
  display: grid;
  grid-template-columns: repeat(3, 24px);
  gap: 3px;
  flex: 0 0 auto;
}

.casino-history-grid .casino-symbol-icon {
  width: 24px;
  height: 24px;
  border-radius: 6px;
}

.casino-history-grid .casino-symbol-icon img {
  width: 19px;
  height: 19px;
}

.casino-history-grid .casino-symbol-icon.is-winning {
  border-color: color-mix(in srgb, var(--gold-1) 82%, transparent);
  background: color-mix(in srgb, var(--gold-1) 18%, transparent);
  box-shadow: 0 0 8px color-mix(in srgb, var(--gold-1) 36%, transparent);
}

.casino-payout-symbols img,
.casino-symbol-icon img {
  display: block;
  width: 30px;
  height: 30px;
  object-fit: contain;
  filter: drop-shadow(0 4px 7px color-mix(in srgb, var(--ink) 28%, transparent));
}

.casino-symbol-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--paper-1) 13%, transparent);
  background: color-mix(in srgb, var(--paper-1) 6%, transparent);
}

.casino-payouts strong,
.casino-history strong {
  flex: 0 0 auto;
  color: var(--game-gold);
  letter-spacing: 0;
}

.casino-history {
  list-style-position: inside;
  color: var(--game-muted);
}

.casino-history strong[data-result="win"] {
  color: var(--green-1);
}

.casino-history strong[data-result="push"] {
  color: var(--game-cyan);
}

.casino-history strong[data-result="loss"] {
  color: color-mix(in srgb, var(--accent) 64%, var(--paper-1));
}

.casino-history strong::after {
  content: none;
}

@keyframes casinoSymbolFlicker {
  0% {
    transform: translateY(-8px);
    opacity: 0.72;
  }
  50% {
    transform: translateY(7px);
    opacity: 1;
  }
  100% {
    transform: translateY(-8px);
    opacity: 0.72;
  }
}

@keyframes casinoFinalColumnCharge {
  0% {
    transform: translateY(-3px) scale(0.985);
    filter: brightness(1);
  }
  100% {
    transform: translateY(3px) scale(1.018);
    filter: brightness(1.2);
  }
}

@keyframes casinoSymbolRevealSnap {
  0% {
    transform: translateY(-12px) scale(0.94);
    opacity: 0.62;
    filter: brightness(1.15);
  }
  55% {
    transform: translateY(5px) scale(1.035);
    opacity: 1;
    filter: brightness(1.34);
  }
  100% {
    transform: translateY(0) scale(1);
    opacity: 1;
    filter: brightness(1);
  }
}

@keyframes casinoSymbolFinalReveal {
  0% {
    transform: translateY(-18px) scale(0.9);
    opacity: 0.55;
    filter: brightness(1.05) saturate(1);
  }
  45% {
    transform: translateY(7px) scale(1.08);
    opacity: 1;
    filter: brightness(1.55) saturate(1.2);
  }
  72% {
    transform: translateY(-2px) scale(0.99);
  }
  100% {
    transform: translateY(0) scale(1);
    filter: brightness(1) saturate(1);
  }
}

@keyframes casinoWinningSymbolPulse {
  0% {
    transform: scale(1);
    filter: brightness(1);
  }
  42% {
    transform: scale(1.045);
    filter: brightness(1.38);
  }
  100% {
    transform: scale(1);
    filter: brightness(1);
  }
}

@keyframes casinoPaylineScan {
  0% {
    opacity: 0;
    transform: translateY(-50%) translateX(0) skewX(-18deg) scale(0.8);
  }
  18% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: translateY(-50%) translateX(660%) skewX(-18deg) scale(1.15);
  }
}

@media (max-width: 980px) {
  .casino-stage {
    grid-template-columns: 1fr;
  }

  .casino-panel {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .casino-panel__section + .casino-panel__section {
    padding-top: 0;
    border-top: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .casino-reel.is-spinning .casino-symbol,
  .casino-reel.is-anticipating .casino-symbol,
  .casino-reel.is-revealing .casino-symbol,
  .casino-reel.is-final-reveal .casino-symbol,
  .casino-symbol.is-winning,
  .casino-payline.is-scanning::after {
    animation: none;
  }

  .casino-bets button,
  .casino-manual-bet,
  .casino-spin,
  .navbar.is-mobile-nav .mobile-primary-link {
    transition: none;
  }
}

/* Gardien sanctuary refresh */
.game-page {
  --game-ink: var(--paper-1);
  --game-muted: var(--paper-2);
  --game-panel: color-mix(in srgb, var(--bg-1) 86%, transparent);
  --game-panel-strong: color-mix(in srgb, var(--bg-1) 92%, var(--bg-2) 8%);
  --game-line: color-mix(in srgb, var(--bg-3) 30%, transparent);
  --game-gold: var(--gold-1);
  --game-ember: var(--accent);
  --game-green: var(--green-1);
  --game-cyan: var(--bg-3);
  --game-rune: var(--bg-3);
  background:
    radial-gradient(
      circle at 15% 10%,
      color-mix(in srgb, var(--paper-1) 20%, transparent),
      transparent 35%
    ),
    radial-gradient(
      circle at 85% 0%,
      color-mix(in srgb, var(--accent-2) 20%, transparent),
      transparent 40%
    ),
    radial-gradient(
      circle at 50% 80%,
      color-mix(in srgb, var(--accent-2) 25%, transparent),
      transparent 55%
    ),
    linear-gradient(
      180deg,
      var(--bg-2),
      var(--bg-1) 45%,
      var(--wood-dark) 70%,
      var(--wood-1) 85%,
      var(--wood-1) 100%
    );
}

.casino-stage {
  grid-template-columns: minmax(0, 1.28fr) minmax(300px, 0.72fr);
  align-items: start;
}

.casino-machine {
  position: relative;
  isolation: isolate;
  border-color: color-mix(in srgb, var(--bg-3) 34%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--paper-1) 9%, transparent), transparent 24%),
    radial-gradient(circle at 22% 12%, color-mix(in srgb, var(--bg-3) 14%, transparent), transparent 34%),
    radial-gradient(circle at 78% 18%, color-mix(in srgb, var(--gold-1) 13%, transparent), transparent 32%),
    linear-gradient(
      155deg,
      color-mix(in srgb, var(--bg-1) 92%, var(--bg-2) 8%),
      color-mix(in srgb, var(--bg-1) 86%, var(--wood-1) 14%)
    );
}

.casino-machine::before,
.casino-machine::after {
  content: "";
  position: absolute;
  inset: 10px;
  z-index: -1;
  pointer-events: none;
  border-radius: 8px;
}

.casino-machine::before {
  border: 1px solid color-mix(in srgb, var(--gold-1) 20%, transparent);
  box-shadow:
    inset 0 0 38px color-mix(in srgb, var(--bg-3) 8%, transparent),
    0 0 44px color-mix(in srgb, var(--bg-3) 10%, transparent);
}

.casino-machine::after {
  opacity: 0.26;
  background:
    repeating-linear-gradient(90deg, transparent 0 42px, color-mix(in srgb, var(--bg-3) 18%, transparent) 43px 44px),
    repeating-linear-gradient(0deg, transparent 0 42px, color-mix(in srgb, var(--gold-1) 12%, transparent) 43px 44px);
  mask-image: radial-gradient(circle at 50% 42%, var(--ink), transparent 72%);
}

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

.casino-machine__ambient span {
  position: absolute;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--game-rune);
  box-shadow: 0 0 18px var(--game-rune);
  opacity: 0.45;
  animation: casinoRuneFloat 7s ease-in-out infinite;
}

.casino-machine__ambient span:nth-child(1) {
  left: 11%;
  top: 22%;
}

.casino-machine__ambient span:nth-child(2) {
  right: 16%;
  top: 16%;
  animation-delay: -1.8s;
  background: var(--game-gold);
}

.casino-machine__ambient span:nth-child(3) {
  left: 18%;
  bottom: 18%;
  animation-delay: -3.4s;
}

.casino-machine__ambient span:nth-child(4) {
  right: 12%;
  bottom: 28%;
  animation-delay: -5.1s;
  background: var(--game-ember);
}

.casino-machine > :not(.casino-machine__ambient):not(.casino-burst-layer) {
  position: relative;
  z-index: 1;
}

.casino-burst-layer {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  overflow: hidden;
}

.casino-burst-particle {
  position: absolute;
  left: 50%;
  top: 48%;
  width: 10px;
  height: 10px;
  border-radius: 3px;
  background: linear-gradient(145deg, var(--paper-1), var(--game-gold));
  box-shadow: 0 0 16px color-mix(in srgb, var(--gold-1) 78%, transparent);
  animation: casinoParticlePop 1.1s cubic-bezier(0.17, 0.84, 0.44, 1) forwards;
  animation-delay: var(--d, 0ms);
}

.casino-burst-particle[data-symbol="spark"] {
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--bg-3) 70%, var(--paper-1)),
    var(--game-cyan)
  );
  box-shadow: 0 0 16px color-mix(in srgb, var(--bg-3) 64%, transparent);
}

.casino-machine__top {
  border-bottom-color: color-mix(in srgb, var(--bg-3) 20%, transparent);
}

.casino-machine__actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.casino-audio-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 42px;
  padding: 8px 10px;
  border: 1px solid color-mix(in srgb, var(--bg-3) 34%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg-1) 46%, transparent);
  color: var(--game-ink);
  font: inherit;
  font-size: 0.78rem;
  font-weight: 900;
  cursor: pointer;
  transition:
    transform 0.16s ease,
    border-color 0.16s ease,
    background 0.16s ease;
}

.casino-audio-toggle svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.1;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.casino-audio-toggle[data-muted="true"] {
  color: color-mix(in srgb, var(--paper-1) 68%, transparent);
  border-color: color-mix(in srgb, var(--paper-1) 18%, transparent);
}

.casino-audio-toggle:hover,
.casino-audio-toggle:focus-visible {
  outline: none;
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--gold-1) 78%, transparent);
}

.guardian-aura {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  margin: 18px 0 0;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--bg-3) 24%, transparent);
  border-radius: 8px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--bg-3) 16%, transparent), color-mix(in srgb, var(--gold-1) 8%, transparent)),
    color-mix(in srgb, var(--ink) 26%, transparent);
}

.guardian-aura__figure {
  display: grid;
  place-items: end center;
  width: 76px;
  height: 76px;
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--gold-1) 24%, transparent);
  background:
    radial-gradient(circle at 50% 36%, color-mix(in srgb, var(--bg-3) 30%, transparent), transparent 58%),
    color-mix(in srgb, var(--ink) 24%, transparent);
  overflow: hidden;
}

.guardian-aura__figure img {
  display: block;
  width: 58px;
  height: auto;
  filter: drop-shadow(0 8px 12px color-mix(in srgb, var(--ink) 44%, transparent));
}

.guardian-aura__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  color: var(--paper-1);
  font-weight: 950;
}

.guardian-aura__head strong {
  color: var(--game-gold);
}

.guardian-aura__bar {
  position: relative;
  height: 14px;
  margin: 8px 0;
  overflow: hidden;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--paper-1) 16%, transparent);
  background: color-mix(in srgb, var(--ink) 34%, transparent);
}

.guardian-aura__bar span {
  display: block;
  width: var(--aura, 0%);
  height: 100%;
  border-radius: inherit;
  background:
    linear-gradient(90deg, var(--game-cyan), var(--game-gold));
  box-shadow: 0 0 18px color-mix(in srgb, var(--bg-3) 45%, transparent);
  transition: width 0.42s ease;
}

.guardian-aura p {
  margin: 0;
  color: var(--game-muted);
  font-size: 0.86rem;
  line-height: 1.35;
}

.casino-aura-ready .guardian-aura {
  border-color: color-mix(in srgb, var(--gold-1) 64%, transparent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--gold-1) 10%, transparent);
}

.casino-status-row {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.casino-status-row > div,
.casino-quick-stats span {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--paper-1) 7%, transparent), transparent),
    color-mix(in srgb, var(--ink) 26%, transparent);
}

.casino-quick-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: -6px 0 16px;
}

.casino-quick-stats span {
  min-width: 0;
  padding: 9px 10px;
  border: 1px solid color-mix(in srgb, var(--green-1) 18%, transparent);
  border-radius: 8px;
  color: var(--game-muted);
  font-size: 0.82rem;
  font-weight: 850;
  text-align: center;
  overflow-wrap: anywhere;
}

.casino-quick-stats span[data-result="win"] {
  color: color-mix(in srgb, var(--green-1) 72%, var(--paper-1));
}

.casino-quick-stats span[data-result="loss"] {
  color: color-mix(in srgb, var(--accent) 58%, var(--paper-1));
}

.casino-reels {
  position: relative;
  border-color: color-mix(in srgb, var(--bg-3) 32%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--bg-1) 22%, transparent), color-mix(in srgb, var(--bg-1) 78%, transparent)),
    radial-gradient(circle at 50% 0, color-mix(in srgb, var(--bg-3) 12%, transparent), transparent 64%),
    var(--bg-1);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--gold-1) 8%, transparent),
    inset 0 -28px 34px color-mix(in srgb, var(--ink) 36%, transparent);
}

.casino-reels::before {
  content: "";
  position: absolute;
  inset: 9px;
  border-radius: 8px;
  border: 1px dashed color-mix(in srgb, var(--gold-1) 20%, transparent);
  pointer-events: none;
  z-index: 1;
}

.casino-reel {
  border-color: color-mix(in srgb, var(--bg-3) 24%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--paper-1) 14%, transparent), transparent 30%),
    radial-gradient(circle at 50% 42%, color-mix(in srgb, var(--bg-3) 12%, transparent), transparent 58%),
    color-mix(in srgb, var(--bg-1) 84%, transparent);
}

.casino-reel.is-spinning {
  border-color: color-mix(in srgb, var(--bg-3) 64%, transparent);
  box-shadow:
    0 0 22px color-mix(in srgb, var(--bg-3) 18%, transparent),
    inset 0 16px 20px color-mix(in srgb, var(--paper-1) 6%, transparent),
    inset 0 -18px 24px color-mix(in srgb, var(--ink) 30%, transparent);
}

.casino-reel.is-settled {
  animation: casinoReelSettle 0.42s ease both;
}

.casino-symbol {
  border-color: color-mix(in srgb, var(--paper-1) 34%, transparent);
  box-shadow:
    0 16px 24px color-mix(in srgb, var(--ink) 34%, transparent),
    inset 0 1px 0 color-mix(in srgb, var(--paper-1) 50%, transparent),
    inset 0 -18px 22px color-mix(in srgb, var(--ink) 16%, transparent);
}

.casino-machine[data-result-tone="spinning"] .casino-reels {
  box-shadow:
    0 0 34px color-mix(in srgb, var(--bg-3) 16%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--gold-1) 8%, transparent),
    inset 0 -28px 34px color-mix(in srgb, var(--ink) 36%, transparent);
}

.casino-machine[data-result-tone="win"] .casino-reels,
.casino-machine[data-result-tone="jackpot"] .casino-reels,
.casino-machine[data-result-tone="protected"] .casino-reels {
  border-color: color-mix(in srgb, var(--gold-1) 70%, transparent);
  box-shadow:
    0 0 42px color-mix(in srgb, var(--gold-1) 18%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--gold-1) 20%, transparent),
    inset 0 -28px 34px color-mix(in srgb, var(--ink) 36%, transparent);
}

.casino-machine[data-result-tone="protected"] .guardian-aura {
  animation: casinoProtectedPulse 0.86s ease both;
}

.casino-machine[data-result-tone="jackpot"].is-celebrating {
  animation: casinoJackpotPulse 0.9s ease both;
}

.casino-machine[data-result-tone="jackpot"].is-celebrating .casino-payline.is-active {
  animation: casinoJackpotLineGlow 0.82s ease-out both;
}

.casino-machine[data-result-tone="jackpot"].is-celebrating .casino-symbol.is-winning {
  animation:
    casinoWinningSymbolPulse 0.78s ease-out both,
    casinoJackpotSymbolGlow 0.9s ease-out both;
}

.casino-controls {
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--bg-3) 18%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg-1) 32%, transparent);
}

.casino-spin {
  background:
    linear-gradient(145deg, var(--gold-1), var(--gold-2) 46%, var(--bg-3) 100%);
  color: var(--ink);
}

.casino-panel {
  position: sticky;
  top: 94px;
  border-color: color-mix(in srgb, var(--bg-3) 28%, transparent);
  max-height: calc(100vh - 118px);
  overflow: auto;
}

.casino-panel__details {
  display: block;
}

.casino-panel__details summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  cursor: pointer;
  list-style: none;
  color: var(--paper-1);
  font-size: 1.02rem;
  font-weight: 950;
}

.casino-panel__details summary::-webkit-details-marker {
  display: none;
}

.casino-panel__details summary::after {
  content: "";
  width: 9px;
  height: 9px;
  flex: 0 0 auto;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  transition: transform 0.18s ease;
}

.casino-panel__details[open] summary::after {
  transform: rotate(225deg) translate(-2px, -2px);
}

.casino-panel__details summary small {
  margin-left: auto;
  color: var(--game-muted);
  font-size: 0.72rem;
  font-weight: 800;
}

.casino-panel__details > :not(summary) {
  margin-top: 12px;
}

.casino-missions {
  display: grid;
  gap: 10px;
}

.casino-missions-empty {
  margin: 0;
  color: var(--game-muted);
  line-height: 1.4;
}

.casino-mission {
  position: relative;
  display: grid;
  gap: 7px;
  padding: 11px;
  border: 1px solid color-mix(in srgb, var(--bg-3) 18%, transparent);
  border-radius: 8px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--bg-3) 10%, transparent), color-mix(in srgb, var(--gold-1) 6%, transparent)),
    color-mix(in srgb, var(--ink) 22%, transparent);
}

.casino-mission[data-state="ready"] {
  border-color: color-mix(in srgb, var(--gold-1) 60%, transparent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--gold-1) 10%, transparent);
}

.casino-mission[data-state="done"] {
  opacity: 0.72;
}

.casino-mission h3,
.casino-mission p {
  margin: 0;
}

.casino-mission h3 {
  color: var(--paper-1);
  font-size: 0.94rem;
  line-height: 1.15;
}

.casino-mission p {
  color: var(--game-muted);
  font-size: 0.78rem;
  line-height: 1.3;
}

.casino-mission strong {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--game-gold);
  font-size: 0.82rem;
}

.casino-inline-gem.pops-wallet__gem {
  display: inline-block;
  flex: 0 0 auto;
  width: 14px;
  height: 19px;
  margin-left: 2px;
  vertical-align: -4px;
  box-shadow:
    inset -3px -4px 7px color-mix(in srgb, var(--accent) 40%, transparent),
    inset 3px 3px 6px color-mix(in srgb, var(--paper-1) 42%, transparent),
    0 0 8px color-mix(in srgb, var(--accent) 36%, transparent);
}

.casino-inline-gem .pops-wallet__gem-shine {
  top: 3px;
  left: 5px;
  width: 4px;
  height: 4px;
}

#casino-daily-net,
.casino-history strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.casino-history-gem.pops-wallet__gem {
  width: 12px;
  height: 17px;
}

.casino-mission__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.casino-mission__claim {
  min-height: 36px;
  padding: 7px 12px;
  border: 1px solid color-mix(in srgb, var(--gold-1) 54%, transparent);
  border-radius: 8px;
  background: linear-gradient(145deg, var(--gold-1), var(--gold-2));
  color: var(--ink);
  font: inherit;
  font-size: 0.78rem;
  font-weight: 950;
  cursor: pointer;
  transition:
    transform 0.16s ease,
    opacity 0.16s ease,
    box-shadow 0.16s ease;
}

.casino-mission__claim:hover,
.casino-mission__claim:focus-visible {
  outline: none;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px color-mix(in srgb, var(--ink) 26%, transparent);
}

.casino-mission__claim:disabled {
  cursor: wait;
  opacity: 0.62;
  transform: none;
}

.casino-mission__bar {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ink) 34%, transparent);
}

.casino-mission__bar span {
  display: block;
  width: var(--mission-progress, 0%);
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--game-cyan), var(--game-gold));
  transition: width 0.35s ease;
}

.mq-pops-fly-layer {
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  overflow: visible;
  contain: layout style;
}

.mq-pops-fly-gem.pops-wallet__gem {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 18px;
  height: 25px;
  opacity: 0;
  pointer-events: none;
  will-change: transform, opacity;
  filter:
    drop-shadow(0 0 10px color-mix(in srgb, var(--accent) 72%, transparent))
    drop-shadow(0 6px 8px color-mix(in srgb, var(--ink) 28%, transparent));
}

.mq-pops-fly-gem .pops-wallet__gem-shine {
  top: 4px;
  left: 6px;
  width: 5px;
  height: 5px;
}

.casino-profile-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 42px;
  border: 1px solid color-mix(in srgb, var(--gold-1) 40%, transparent);
  border-radius: 8px;
  color: var(--ink);
  background: linear-gradient(145deg, var(--gold-1), var(--gold-2));
  font-weight: 950;
  text-decoration: none;
}

.casino-history li[data-result="protected"] {
  color: var(--paper-2);
}

.casino-history li[data-result="jackpot"] {
  color: var(--gold-1);
}

.casino-history strong[data-result="protected"] {
  color: var(--game-cyan);
}

.casino-history strong[data-result="jackpot"] {
  color: var(--game-gold);
}

@keyframes casinoRuneFloat {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(0.82);
    opacity: 0.26;
  }
  50% {
    transform: translate3d(8px, -18px, 0) scale(1.18);
    opacity: 0.62;
  }
}

@keyframes casinoParticlePop {
  0% {
    transform: translate(-50%, -50%) scale(0.4) rotate(0deg);
    opacity: 0;
  }
  16% {
    opacity: 1;
  }
  100% {
    transform: translate(calc(-50% + var(--x)), calc(-50% + var(--y))) scale(0.1) rotate(260deg);
    opacity: 0;
  }
}

@keyframes casinoReelSettle {
  0% {
    transform: translateY(-8px);
  }
  55% {
    transform: translateY(4px);
  }
  100% {
    transform: translateY(0);
  }
}

@keyframes casinoJackpotLineGlow {
  0% {
    filter: brightness(1);
    box-shadow:
      0 0 14px color-mix(in srgb, var(--game-cyan) 58%, transparent),
      0 0 24px color-mix(in srgb, var(--gold-1) 35%, transparent);
  }
  45% {
    filter: brightness(1.75);
    box-shadow:
      0 0 20px color-mix(in srgb, var(--paper-1) 42%, transparent),
      0 0 36px color-mix(in srgb, var(--gold-1) 62%, transparent),
      0 0 58px color-mix(in srgb, var(--accent) 26%, transparent);
  }
  100% {
    filter: brightness(1.08);
  }
}

@keyframes casinoJackpotSymbolGlow {
  0%,
  100% {
    box-shadow:
      0 0 0 2px color-mix(in srgb, var(--gold-1) 20%, transparent),
      0 14px 24px color-mix(in srgb, var(--ink) 30%, transparent),
      inset 0 1px 0 color-mix(in srgb, var(--paper-1) 58%, transparent),
      inset 0 -18px 22px color-mix(in srgb, var(--ink) 16%, transparent);
  }
  48% {
    box-shadow:
      0 0 0 2px color-mix(in srgb, var(--paper-1) 42%, transparent),
      0 0 24px color-mix(in srgb, var(--gold-1) 58%, transparent),
      0 14px 24px color-mix(in srgb, var(--ink) 30%, transparent),
      inset 0 1px 0 color-mix(in srgb, var(--paper-1) 70%, transparent),
      inset 0 -18px 22px color-mix(in srgb, var(--ink) 16%, transparent);
  }
}

@keyframes casinoProtectedPulse {
  0%,
  100% {
    transform: scale(1);
  }
  45% {
    transform: scale(1.018);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--bg-3) 16%, transparent);
  }
}

@keyframes casinoJackpotPulse {
  0%,
  100% {
    transform: translateY(0);
  }
  35% {
    transform: translateY(-3px);
  }
  65% {
    transform: translateY(2px);
  }
}

@media (max-width: 980px) {
  .casino-panel {
    position: static;
    max-height: none;
    overflow: visible;
  }

  .casino-panel__missions {
    grid-column: 1 / -1;
  }
}

@media (max-width: 768px) {
  .game-page {
    --game-mobile-gap: clamp(6px, 2.2vw, 10px);
    --game-mobile-side: clamp(6px, 2.8vw, 12px);
    overflow-x: hidden;
  }

  .game-shell {
    width: min(
      calc(100% - var(--game-mobile-side) - var(--game-mobile-side)),
      520px
    );
    margin: 8px auto calc(var(--mobile-bottom-nav-height) + 22px);
  }

  .casino-stage {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--game-mobile-gap);
    align-items: stretch;
  }

  .casino-machine,
  .casino-panel {
    min-width: 0;
    border-radius: 8px;
  }

  .casino-machine {
    padding: clamp(8px, 2.4vw, 12px);
    overflow: hidden;
  }

  .casino-machine::before,
  .casino-machine::after,
  .casino-machine__ambient {
    display: none;
  }

  .casino-machine__top {
    display: grid;
    grid-template-columns: clamp(36px, 10vw, 42px) minmax(0, 1fr) auto;
    grid-template-areas: "logo title actions";
    align-items: center;
    gap: 8px;
    padding-bottom: 9px;
  }

  .casino-machine__logo {
    grid-area: logo;
    width: clamp(36px, 10vw, 42px);
    height: clamp(36px, 10vw, 42px);
  }

  .casino-machine__top > div:not(.casino-machine__actions) {
    grid-area: title;
    min-width: 0;
  }

  .casino-machine__eyebrow {
    margin-bottom: 2px;
    font-size: clamp(0.58rem, 2.3vw, 0.66rem);
    line-height: 1.05;
  }

  .casino-machine h1 {
    max-width: 100%;
    font-size: clamp(1.02rem, 5.4vw, 1.34rem);
    line-height: 1.04;
    overflow-wrap: anywhere;
  }

  .casino-machine__actions {
    grid-area: actions;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 5px;
    justify-items: stretch;
    min-width: clamp(54px, 17vw, 74px);
  }

  .casino-audio-toggle,
  .casino-machine__jackpot {
    width: 100%;
    min-height: 34px;
    padding: 6px 8px;
    border-radius: 8px;
    font-size: clamp(0.72rem, 2.8vw, 0.84rem);
    line-height: 1;
  }

  .casino-audio-toggle {
    justify-content: center;
  }

  .casino-audio-toggle svg {
    width: 15px;
    height: 15px;
  }

  .guardian-aura {
    grid-template-columns: minmax(0, 1fr);
    gap: 6px;
    margin-top: 8px;
    padding: 8px;
    border-radius: 8px;
  }

  .guardian-aura__figure {
    display: none;
  }

  .guardian-aura__head {
    gap: 8px;
    font-size: clamp(0.74rem, 3vw, 0.84rem);
    line-height: 1.14;
  }

  .guardian-aura__head span {
    min-width: 0;
    overflow-wrap: anywhere;
  }

  .guardian-aura__head strong {
    flex: 0 0 auto;
    font-size: 0.78rem;
  }

  .guardian-aura__bar {
    height: 10px;
    margin: 6px 0;
  }

  .guardian-aura p {
    font-size: clamp(0.68rem, 2.8vw, 0.76rem);
    line-height: 1.24;
  }

  .casino-quick-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 5px;
    margin: 8px 0;
  }

  .casino-quick-stats span {
    min-width: 0;
    min-height: 34px;
    padding: 6px 4px;
    justify-content: center;
    font-size: clamp(0.56rem, 2.55vw, 0.68rem);
    line-height: 1.12;
    text-align: center;
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .casino-reels {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(5px, 1.7vw, 7px);
    width: 100%;
    height: clamp(154px, 51vw, 212px);
    min-height: 0;
    padding: clamp(6px, 1.8vw, 8px);
    aspect-ratio: 1.55 / 1;
  }

  .casino-reel {
    grid-template-rows: repeat(3, minmax(0, 1fr));
    gap: clamp(4px, 1.35vw, 6px);
    height: 100%;
    min-width: 0;
    min-height: 0;
    padding: clamp(5px, 1.5vw, 7px);
  }

  .casino-reel::before,
  .casino-reel::after {
    height: 16px;
  }

  .casino-symbol {
    width: 100%;
    min-height: 0;
    height: 100%;
    padding: clamp(3px, 1.2vw, 5px);
    border-radius: 7px;
  }

  .casino-symbol__image {
    width: clamp(24px, 8.6vw, 34px);
    max-height: 100%;
  }

  .casino-payline-layer {
    inset: clamp(6px, 1.8vw, 8px);
  }

  .casino-payline {
    height: 14px;
  }

  .casino-payline::after {
    height: 10px;
  }

  .casino-payline--diag-down,
  .casino-payline--diag-up {
    --casino-payline-angle: 30deg;
  }

  .casino-mobile-result {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 9;
    display: inline-grid;
    place-items: center;
    width: min(calc(100% - 28px), 270px);
    min-height: 58px;
    padding: 10px 14px;
    border-radius: 14px;
    border: 1px solid rgba(255, 238, 199, 0.72);
    background:
      radial-gradient(
        circle at 50% 0%,
        rgba(255, 255, 255, 0.24),
        transparent 60%
      ),
      linear-gradient(
        145deg,
        rgba(9, 28, 58, 0.94),
        rgba(18, 73, 126, 0.92)
      );
    color: var(--paper-1);
    box-shadow:
      0 18px 36px color-mix(in srgb, var(--ink) 46%, transparent),
      0 0 0 999px rgba(5, 15, 35, 0.16),
      inset 0 1px 0 rgba(255, 255, 255, 0.22);
    font-size: clamp(1.05rem, 5vw, 1.42rem);
    font-weight: 950;
    line-height: 1.08;
    text-align: center;
    text-wrap: balance;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.48);
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    transform: translate(-50%, -50%) scale(0.9);
    transition:
      opacity 0.18s ease,
      visibility 0s linear 0.24s,
      transform 0.22s cubic-bezier(0.2, 0.9, 0.26, 1.16);
  }

  .casino-mobile-result.is-visible {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%, -50%) scale(1);
    transition-delay: 0s;
  }

  .casino-mobile-result[data-tone="success"] {
    border-color: color-mix(in srgb, var(--green-1) 72%, white 18%);
    background:
      radial-gradient(
        circle at 50% 0%,
        rgba(255, 255, 255, 0.26),
        transparent 62%
      ),
      linear-gradient(
        145deg,
        color-mix(in srgb, var(--green-1) 32%, var(--bg-1)),
        color-mix(in srgb, var(--bg-3) 42%, var(--bg-1))
      );
  }

  .casino-mobile-result[data-tone="danger"] {
    border-color: color-mix(in srgb, var(--accent) 72%, white 18%);
    background:
      radial-gradient(
        circle at 50% 0%,
        rgba(255, 255, 255, 0.22),
        transparent 62%
      ),
      linear-gradient(
        145deg,
        color-mix(in srgb, var(--accent) 38%, var(--bg-1)),
        color-mix(in srgb, var(--wood-dark) 82%, var(--accent))
      );
  }

  .casino-mobile-result[data-tone="neutral"] {
    border-color: color-mix(in srgb, var(--gold-1) 72%, white 16%);
  }

  .casino-mobile-result__prefix,
  .casino-mobile-result__amount {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .casino-mobile-result__prefix {
    margin-bottom: 4px;
    font-size: clamp(0.76rem, 3.3vw, 0.9rem);
    line-height: 1;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--paper-1) 82%, var(--gold-1));
  }

  .casino-mobile-result__amount {
    gap: 8px;
  }

  .casino-mobile-result__gem.pops-wallet__gem {
    width: clamp(15px, 4.5vw, 20px);
    height: clamp(22px, 6.2vw, 28px);
    flex: 0 0 auto;
    filter: drop-shadow(0 0 8px color-mix(in srgb, var(--bg-3) 46%, transparent));
  }

  .casino-controls {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
    margin: 10px -2px 0;
    padding: 8px;
    border-radius: 8px;
    border-color: color-mix(in srgb, var(--gold-1) 34%, transparent);
    background:
      linear-gradient(180deg, color-mix(in srgb, var(--paper-1) 8%, transparent), transparent),
      color-mix(in srgb, var(--bg-1) 94%, transparent);
    box-shadow: 0 12px 24px color-mix(in srgb, var(--ink) 28%, transparent);
    backdrop-filter: blur(14px);
  }

  .casino-wager-controls {
    grid-template-columns: minmax(0, 1fr);
    gap: 6px;
  }

  .casino-bets {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 6px;
  }

  .casino-bets button {
    min-width: 0;
    min-height: clamp(38px, 10.8vw, 46px);
    padding: 6px 2px;
    gap: 3px;
    border-radius: 8px;
    font-size: clamp(0.76rem, 3.2vw, 0.9rem);
  }

  .casino-manual-bet {
    min-height: clamp(38px, 10.8vw, 46px);
    padding: 6px 8px;
  }

  .casino-manual-bet__label {
    font-size: clamp(0.62rem, 2.6vw, 0.72rem);
  }

  .casino-manual-bet input {
    font-size: clamp(0.78rem, 3.4vw, 0.92rem);
  }

  .casino-spin {
    width: 100%;
    min-width: 0;
    min-height: clamp(42px, 12vw, 52px);
    border-radius: 8px;
    font-size: clamp(0.9rem, 3.7vw, 1.05rem);
    white-space: normal;
  }

  .casino-message {
    min-height: 20px;
    margin-top: 10px;
    font-size: clamp(0.78rem, 3vw, 0.86rem);
    line-height: 1.25;
  }

  .casino-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
  }

  .casino-panel__section + .casino-panel__section {
    padding-top: 0;
    border-top: 0;
  }

  .casino-panel__details {
    min-width: 0;
    padding: 0;
    border: 1px solid color-mix(in srgb, var(--bg-3) 24%, transparent);
    border-radius: 8px;
    background:
      linear-gradient(180deg, color-mix(in srgb, var(--paper-1) 7%, transparent), transparent),
      color-mix(in srgb, var(--bg-1) 88%, transparent);
    box-shadow:
      0 12px 24px color-mix(in srgb, var(--ink) 26%, transparent),
      inset 0 1px 0 color-mix(in srgb, var(--paper-1) 10%, transparent);
    overflow: hidden;
  }

  .casino-panel__details summary {
    min-height: 42px;
    padding: 10px 12px;
    gap: 8px;
    font-size: clamp(0.86rem, 3.4vw, 0.96rem);
  }

  .casino-panel__details summary small {
    font-size: clamp(0.58rem, 2.5vw, 0.68rem);
  }

  .casino-panel__details > :not(summary) {
    padding: 0 10px 10px;
  }

  .casino-missions,
  .casino-payouts,
  .casino-history {
    min-width: 0;
  }

  .casino-history {
    --casino-history-row-height: auto;
    max-height: min(42vh, 260px);
  }

  .casino-payouts li,
  .casino-history li {
    min-width: 0;
    min-height: 0;
    padding: 8px;
    gap: 8px;
  }

  .casino-payouts span,
  .casino-history span {
    min-width: 0;
  }

  .casino-history-round {
    gap: 8px;
  }

  .casino-history-round small {
    min-width: 0;
    font-size: 0.66rem;
  }

  .casino-history-grid {
    grid-template-columns: repeat(3, 22px);
    gap: 3px;
  }

  .casino-history-grid .casino-symbol-icon {
    width: 22px;
    height: 22px;
  }

  .casino-history-grid .casino-symbol-icon img,
  .casino-payout-symbols img,
  .casino-symbol-icon img {
    width: 18px;
    height: 18px;
  }

  .casino-payouts strong,
  .casino-history strong {
    flex: 0 0 auto;
    font-size: 0.78rem;
  }
}

@media (max-width: 480px) {
  .game-shell {
    width: calc(100% - 12px);
  }

  .casino-machine__top {
    grid-template-columns: 38px minmax(0, 1fr) auto;
  }

  .casino-machine h1 {
    font-size: clamp(1rem, 5.8vw, 1.18rem);
  }

  .casino-audio-toggle span[data-audio-toggle-label] {
    display: none;
  }

  .casino-audio-toggle,
  .casino-machine__jackpot {
    min-height: 32px;
    padding-inline: 7px;
  }

  .casino-reels {
    height: clamp(148px, 50vw, 188px);
  }

  .casino-symbol__image {
    width: clamp(22px, 8vw, 28px);
  }

  .casino-bets {
    gap: 5px;
  }

  .casino-bets button {
    min-height: 38px;
    font-size: clamp(0.72rem, 3.4vw, 0.82rem);
  }
}

@media (max-width: 360px) {
  .casino-quick-stats {
    gap: 4px;
  }

  .casino-quick-stats span {
    padding-inline: 2px;
    font-size: 0.54rem;
  }
}

@media (max-height: 740px) and (max-width: 768px) {
  .guardian-aura p {
    display: none;
  }

  .casino-reels {
    height: clamp(138px, 44vh, 178px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .casino-machine__ambient span,
  .casino-burst-particle,
  .casino-reel.is-settled,
  .casino-reel.is-anticipating .casino-symbol,
  .casino-reel.is-revealing .casino-symbol,
  .casino-reel.is-final-reveal .casino-symbol,
  .casino-symbol.is-winning,
  .casino-payline.is-scanning::after,
  .casino-machine[data-result-tone="protected"] .guardian-aura,
  .casino-machine[data-result-tone="jackpot"].is-celebrating,
  .casino-machine[data-result-tone="jackpot"].is-celebrating .casino-payline.is-active,
  .casino-machine[data-result-tone="jackpot"].is-celebrating .casino-symbol.is-winning {
    animation: none !important;
  }

  .guardian-aura__bar span,
  .casino-mission__bar span,
  .casino-panel__details summary::after,
  .casino-audio-toggle,
  .casino-payline {
    transition: none !important;
  }
}
