:root {
  --bg: #170024;
  --panel: rgba(55, 7, 78, 0.78);
  --panel-strong: rgba(104, 15, 96, 0.82);
  --gold: #ffd24d;
  --gold-light: #fff0a6;
  --pink: #ff37b9;
  --blue: #23c9ff;
  --red: #ff3434;
  --text: #fff9e8;
  --muted: #ffd7f5;
  --line: rgba(255, 210, 77, 0.48);
  --shadow: rgba(23, 0, 36, 0.55);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
  box-sizing: border-box;
}

body {
  min-height: 100vh;
  margin: 0;
  color: var(--text);
  overflow-x: hidden;
  background:
    linear-gradient(90deg, rgba(17, 0, 30, 0.42), rgba(48, 0, 57, 0.12), rgba(10, 0, 24, 0.36)),
    url("back-graund.png") center / cover fixed no-repeat,
    var(--bg);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 55, 185, 0.18), transparent 28rem),
    radial-gradient(circle at 74% 34%, rgba(35, 201, 255, 0.18), transparent 22rem);
  animation: ambient-glow 7s ease-in-out infinite alternate;
}

button {
  font: inherit;
}

input {
  min-width: 0;
  font: inherit;
}

.casino-shell {
  width: min(920px, calc(100% - 24px));
  min-height: 100vh;
  margin: 0 auto;
  padding: 14px 0;
  display: grid;
  grid-template-rows: auto auto;
  align-content: center;
  gap: 10px;
}

.top-panel,
.machine,
.control-panel,
.balance-card,
.win-window,
.user-card {
  border: 1px solid var(--line);
  background: var(--panel);
  box-shadow: 0 16px 38px var(--shadow), inset 0 0 28px rgba(255, 55, 185, 0.12);
  backdrop-filter: blur(10px);
  transition: border-color 220ms ease, box-shadow 220ms ease, transform 220ms ease;
}

.top-panel {
  min-height: 78px;
  display: grid;
  grid-template-columns: 1fr minmax(150px, auto) auto minmax(150px, auto);
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-radius: 8px;
}

h1 {
  margin: 0;
  color: var(--gold-light);
  font-size: clamp(2rem, 6vw, 4.4rem);
  line-height: 0.9;
  letter-spacing: 0;
  text-shadow:
    0 0 12px rgba(255, 55, 185, 0.75),
    0 0 28px rgba(35, 201, 255, 0.35),
    0 4px 0 rgba(210, 45, 32, 0.72);
}

.title-block {
  min-width: 0;
  animation: title-enter 620ms cubic-bezier(0.2, 0.9, 0.2, 1) both;
}

.balance-card,
.win-window,
.user-card {
  border-radius: 8px;
  padding: 10px 12px;
}

.balance-card span,
.win-window span,
.deposit-form label,
.bet-box legend,
.user-card span {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
}

.balance-card strong,
.win-window strong,
.user-card strong {
  display: block;
  margin-top: 2px;
  color: var(--gold-light);
  font-size: clamp(1.1rem, 2vw, 1.55rem);
  line-height: 1.1;
  text-shadow: 0 0 12px rgba(255, 210, 77, 0.65);
}

.balance-card strong {
  font-weight: 900;
}

.user-card {
  display: grid;
  gap: 5px;
}

.user-switch {
  min-height: 34px;
  padding: 0 10px;
}

.machine {
  position: relative;
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
  padding: 10px;
  border-radius: 8px;
}

.reels {
  height: 250px;
  display: grid;
  grid-template-columns: repeat(3, minmax(60px, 1fr));
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(255, 240, 166, 0.4);
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 50%, rgba(35, 201, 255, 0.18), transparent 50%),
    linear-gradient(180deg, rgba(255, 55, 185, 0.34), rgba(22, 0, 39, 0.84)),
    rgba(22, 0, 39, 0.78);
  overflow: hidden;
  transform: translateZ(0);
  transition: box-shadow 260ms ease, transform 260ms ease;
}

.reels.is-spinning {
  box-shadow: 0 0 34px rgba(35, 201, 255, 0.34), inset 0 0 38px rgba(255, 55, 185, 0.18);
}

.reel {
  position: relative;
  min-width: 0;
  min-height: 0;
  height: 100%;
  overflow: hidden;
  border: 1px solid rgba(255, 210, 77, 0.42);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.14), transparent 18%, transparent 82%, rgba(0, 0, 0, 0.34)),
    rgba(21, 0, 38, 0.9);
  box-shadow: inset 0 0 18px rgba(35, 201, 255, 0.16);
  transform: translateZ(0);
  transition: transform 280ms cubic-bezier(0.18, 0.85, 0.3, 1), box-shadow 240ms ease;
}

.reel.is-active {
  box-shadow: inset 0 0 18px rgba(35, 201, 255, 0.24), 0 0 18px rgba(35, 201, 255, 0.2);
}

.reel.is-stopping {
  animation: reel-brake 620ms cubic-bezier(0.08, 0.86, 0.16, 1) both;
}

.reel.is-anticipating {
  border-color: var(--gold-light);
  animation: reel-anticipation 480ms ease-in-out infinite alternate;
}

.reel::before,
.reel::after {
  content: "";
  position: absolute;
  z-index: 2;
  left: 0;
  right: 0;
  height: 22%;
  pointer-events: none;
}

.reel::before {
  top: 0;
  background: linear-gradient(180deg, rgba(22, 0, 39, 0.8), transparent);
}

.reel::after {
  bottom: 0;
  background: linear-gradient(0deg, rgba(22, 0, 39, 0.8), transparent);
}

.reel-strip {
  position: relative;
  height: 100%;
  display: grid;
  grid-template-rows: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.reel-strip.is-spinning {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: calc(300% + 16px);
  grid-template-rows: repeat(9, minmax(0, 1fr));
  animation: reel-roll 260ms linear infinite;
  will-change: transform, filter;
}

.reel.is-stopping .reel-strip {
  animation: reel-settle 620ms cubic-bezier(0.08, 0.86, 0.16, 1) both;
}

.symbol {
  min-width: 0;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255, 240, 166, 0.28);
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 20%, rgba(255, 240, 166, 0.34), transparent 50%),
    linear-gradient(180deg, rgba(255, 54, 65, 0.92), rgba(110, 0, 128, 0.82));
  color: var(--text);
  font-size: clamp(1.45rem, 3.6vw, 3rem);
  line-height: 1;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.12), 0 0 14px rgba(255, 55, 185, 0.18);
  transition: transform 160ms ease, border-color 160ms ease;
  text-shadow: 0 2px 0 rgba(0, 0, 0, 0.34), 0 0 12px rgba(255, 210, 77, 0.5);
}

.symbol.is-win {
  border-color: var(--gold-light);
  transform: translateY(-2px);
  box-shadow: 0 0 22px rgba(255, 210, 77, 0.7);
  animation: symbol-win 760ms ease-in-out 2;
}

.control-panel {
  display: grid;
  grid-template-columns: minmax(145px, 0.9fr) minmax(220px, 1.15fr) minmax(145px, 0.8fr) minmax(180px, 1fr);
  align-items: stretch;
  gap: 10px;
  padding: 10px;
  border-radius: 8px;
  background: var(--panel-strong);
}

.win-window {
  min-height: 78px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: rgba(19, 0, 36, 0.72);
}

.deposit-form {
  display: grid;
  gap: 6px;
}

.deposit-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px;
}

.money-input {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(31, 0, 49, 0.72);
}

.money-input span {
  padding-right: 10px;
  color: var(--gold-light);
  font-weight: 800;
}

.deposit-row input {
  width: 100%;
  min-height: 40px;
  border: 0;
  padding: 0 10px;
  color: var(--text);
  background: transparent;
  outline: none;
}

.money-input:focus-within {
  border-color: var(--gold-light);
  box-shadow: 0 0 0 3px rgba(215, 170, 74, 0.16);
}

.bet-box {
  margin: 0;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.bet-stepper {
  display: grid;
  grid-template-columns: 42px minmax(96px, 1fr) 42px;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
}

.bet-input {
  min-height: 42px;
  display: flex;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--gold-light);
  background: rgba(19, 0, 36, 0.72);
  font-size: 1.1rem;
  font-weight: 800;
  overflow: hidden;
}

.bet-input:focus-within {
  border-color: var(--gold-light);
  box-shadow: 0 0 0 3px rgba(255, 210, 77, 0.14);
}

.bet-input input {
  width: 100%;
  min-width: 0;
  border: 0;
  padding: 0 4px 0 8px;
  color: inherit;
  background: transparent;
  font: inherit;
  text-align: right;
  outline: none;
  appearance: textfield;
}

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

.bet-input span {
  padding-right: 8px;
}

.button,
.step-button {
  min-height: 48px;
  border: 1px solid transparent;
  border-radius: 8px;
  cursor: pointer;
  color: var(--text);
  text-decoration: none;
  transition:
    transform 180ms cubic-bezier(0.2, 0.9, 0.2, 1),
    border-color 180ms ease,
    background 180ms ease,
    box-shadow 180ms ease,
    opacity 180ms ease;
}

.button:hover,
.step-button:hover {
  transform: translateY(-2px) scale(1.01);
}

.button:active,
.step-button:active {
  transform: translateY(0) scale(0.98);
}

.button:disabled,
.step-button:disabled {
  cursor: not-allowed;
  opacity: 0.45;
  transform: none;
}

.button-primary {
  min-height: 72px;
  color: #2b001f;
  background: linear-gradient(180deg, #fff0a6, #ffcf24 48%, #ff4c1f);
  box-shadow: 0 0 22px rgba(255, 72, 31, 0.48);
  font-weight: 800;
  text-transform: uppercase;
}

#spinButton {
  width: 78px;
  min-height: 0;
  aspect-ratio: 1;
  justify-self: center;
  align-self: center;
  padding: 0;
}

.button-secondary,
.step-button {
  background: linear-gradient(180deg, rgba(255, 55, 185, 0.34), rgba(35, 201, 255, 0.16));
  border-color: var(--line);
  font-weight: 700;
}

.deposit-link {
  min-height: 48px;
  display: grid;
  place-items: center;
  padding: 0 18px;
}

.step-button {
  min-height: 42px;
  color: var(--gold-light);
  font-size: 1.35rem;
}

.status {
  min-height: 0;
  margin: 0;
  align-self: center;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.45;
}

.win-overlay {
  position: absolute;
  inset: 10px;
  z-index: 5;
  display: grid;
  place-items: center;
  pointer-events: none;
  opacity: 0;
  transform: scale(0.86);
}

.win-overlay.is-visible {
  animation: win-overlay-pop 1900ms cubic-bezier(0.16, 0.96, 0.2, 1) both;
}

.win-overlay div {
  width: min(82%, 520px);
  display: grid;
  place-items: center;
  gap: 8px;
  padding: 26px 18px;
  border: 2px solid rgba(255, 240, 166, 0.72);
  border-radius: 8px;
  background:
    radial-gradient(circle, rgba(255, 210, 77, 0.28), transparent 62%),
    linear-gradient(180deg, rgba(255, 55, 185, 0.82), rgba(22, 0, 39, 0.9));
  box-shadow: 0 0 42px rgba(255, 210, 77, 0.68), inset 0 0 36px rgba(35, 201, 255, 0.28);
}

.win-overlay strong {
  color: var(--gold-light);
  font-size: clamp(4rem, 16vw, 9rem);
  line-height: 0.8;
  text-shadow: 0 0 18px rgba(255, 210, 77, 0.96), 0 6px 0 rgba(255, 52, 52, 0.85);
}

.win-overlay span {
  color: #ffffff;
  font-size: clamp(1.4rem, 5vw, 3rem);
  font-weight: 800;
  text-shadow: 0 0 14px rgba(35, 201, 255, 0.9);
}

.deposit-page {
  width: min(760px, calc(100% - 24px));
}

.deposit-top {
  grid-template-columns: 1fr minmax(150px, auto) auto minmax(150px, auto);
}

.deposit-machine {
  padding: 12px;
}

.deposit-card {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(19, 0, 36, 0.72);
}

.deposit-card label {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
}

.auth-locked .casino-shell {
  filter: blur(3px);
  pointer-events: none;
  user-select: none;
}

.auth-modal {
  position: fixed;
  inset: 0;
  z-index: 20;
  display: none;
  place-items: center;
  padding: 18px;
  background: rgba(18, 0, 30, 0.72);
  backdrop-filter: blur(8px);
}

.auth-modal.is-visible {
  display: grid;
}

.auth-card {
  width: min(420px, 100%);
  display: grid;
  gap: 12px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 0%, rgba(255, 210, 77, 0.2), transparent 48%),
    rgba(43, 0, 62, 0.94);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.48), inset 0 0 34px rgba(255, 55, 185, 0.12);
}

.auth-card h2 {
  margin: 0;
  color: var(--gold-light);
  font-size: clamp(1.8rem, 8vw, 3rem);
  line-height: 0.95;
  text-shadow: 0 0 18px rgba(255, 55, 185, 0.75);
}

.auth-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.auth-tab {
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  background: rgba(31, 0, 49, 0.72);
  cursor: pointer;
  font-weight: 800;
}

.auth-tab.is-active {
  color: #2b001f;
  background: linear-gradient(180deg, #fff0a6, #ffcf24 48%, #ff4c1f);
}

.auth-card label {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
}

.auth-card input {
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 0 12px;
  color: var(--text);
  background: rgba(31, 0, 49, 0.72);
  outline: none;
}

.auth-card input:focus {
  border-color: var(--gold-light);
  box-shadow: 0 0 0 3px rgba(215, 170, 74, 0.16);
}

.auth-message {
  min-height: 22px;
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.35;
}

@keyframes reel-roll {
  0% {
    filter: brightness(0.88) blur(0.7px);
    transform: translateY(-64%);
  }
  100% {
    filter: brightness(1.32) blur(0.7px);
    transform: translateY(0);
  }
}

@keyframes reel-settle {
  0% {
    transform: translateY(-62%);
    filter: brightness(1.25) blur(0.6px);
  }
  56% {
    transform: translateY(5%);
    filter: brightness(1.12) blur(0);
  }
  72% {
    transform: translateY(-2.5%);
  }
  86% {
    transform: translateY(1%);
  }
  100% {
    transform: translateY(0);
    filter: brightness(1) blur(0);
  }
}

@keyframes reel-brake {
  0%,
  100% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(8px) scaleY(0.98);
  }
  64% {
    transform: translateY(-4px) scaleY(1.01);
  }
  82% {
    transform: translateY(2px);
  }
}

@keyframes reel-anticipation {
  0% {
    box-shadow: inset 0 0 20px rgba(255, 210, 77, 0.28), 0 0 12px rgba(255, 55, 185, 0.32);
    filter: brightness(1);
  }
  100% {
    box-shadow: inset 0 0 34px rgba(255, 210, 77, 0.54), 0 0 30px rgba(255, 210, 77, 0.58);
    filter: brightness(1.2);
  }
}

@keyframes symbol-win {
  0%,
  100% {
    transform: translateY(-2px) scale(1);
  }
  50% {
    transform: translateY(-4px) scale(1.08);
  }
}

@keyframes win-overlay-pop {
  0% {
    opacity: 0;
    transform: scale(0.58);
    filter: blur(6px);
  }
  18% {
    opacity: 1;
    transform: scale(1.08);
    filter: blur(0);
  }
  34%,
  78% {
    opacity: 1;
    transform: scale(1);
  }
  100% {
    opacity: 0;
    transform: scale(1.12);
  }
}

@keyframes title-enter {
  0% {
    opacity: 0;
    transform: translateY(-8px) scale(0.98);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes ambient-glow {
  0% {
    opacity: 0.66;
    transform: scale(1);
  }
  100% {
    opacity: 1;
    transform: scale(1.04);
  }
}

@media (max-width: 860px) {
  .game-page {
    height: 100dvh;
    min-height: 0;
    overflow: hidden;
  }

  .casino-shell {
    width: min(100% - 20px, 680px);
    height: 100dvh;
    min-height: 0;
    padding: 6px 0;
    grid-template-rows: auto minmax(0, 1fr);
    align-content: stretch;
    gap: 6px;
  }

  .deposit-top {
    grid-template-columns: 1fr;
  }

  .top-panel {
    min-height: 0;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 6px;
    padding: 6px;
  }

  .title-block {
    min-width: 0;
  }

  h1 {
    font-size: clamp(1.25rem, 6vw, 2rem);
    line-height: 1;
  }

  .balance-card,
  .user-card {
    padding: 6px 8px;
  }

  .balance-card span,
  .user-card > span {
    display: none;
  }

  .balance-card strong,
  .user-card strong {
    margin: 0;
    font-size: 0.94rem;
  }

  .deposit-link {
    min-height: 38px;
    padding: 0 10px;
    font-size: 0.78rem;
  }

  .user-card {
    grid-column: 1 / -1;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
  }

  .user-switch {
    min-height: 28px;
    font-size: 0.72rem;
  }

  .machine {
    min-height: 0;
    grid-template-rows: minmax(0, 1fr) auto;
    gap: 6px;
    padding: 6px;
  }

  .reels {
    grid-template-columns: repeat(3, minmax(48px, 1fr));
    height: 100%;
    min-height: 145px;
    gap: 6px;
    padding: 6px;
  }

  .reel-strip {
    grid-template-rows: repeat(3, minmax(0, 1fr));
    gap: 6px;
  }

  .reel-strip.is-spinning {
    height: calc(300% + 12px);
    grid-template-rows: repeat(9, minmax(0, 1fr));
  }

  .control-panel {
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
    grid-template-rows: auto auto auto;
    min-height: 0;
    gap: 6px;
    padding: 6px;
  }

  .win-window,
  .bet-box {
    min-height: 62px;
    padding: 6px;
  }

  .bet-stepper {
    grid-template-columns: 36px minmax(86px, 1fr) 36px;
    gap: 4px;
    margin-top: 3px;
  }

  .step-button,
  .bet-input {
    min-height: 36px;
  }

  #spinButton {
    grid-column: 1 / -1;
    width: 100%;
    min-height: 96px;
    aspect-ratio: auto;
    font-size: 1.35rem;
  }

  .status {
    grid-column: 1 / -1;
    min-height: 16px;
    font-size: 0.7rem;
    line-height: 1.2;
    text-align: center;
  }
}

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

  .top-panel,
  .machine,
  .control-panel {
    padding: 5px;
  }

  .deposit-row {
    grid-template-columns: 1fr;
  }

  .reels {
    min-height: 132px;
  }

  .reel-strip {
    grid-template-rows: repeat(3, minmax(0, 1fr));
  }

  .reel-strip.is-spinning {
    grid-template-rows: repeat(9, minmax(0, 1fr));
  }

  .symbol {
    font-size: clamp(1.2rem, 8vw, 2rem);
  }

  .bet-stepper {
    grid-template-columns: 34px minmax(0, 1fr) 34px;
  }
}

@media (max-width: 860px) and (max-height: 600px) {
  .top-panel {
    grid-template-columns: minmax(0, 1fr) auto auto auto;
  }

  .user-card {
    grid-column: auto;
  }

  .user-card strong {
    display: none;
  }

  .reels {
    min-height: 112px;
  }

  .reel-strip {
    grid-template-rows: repeat(3, minmax(0, 1fr));
  }

  .win-window,
  .bet-box {
    min-height: 52px;
  }

  .control-panel {
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
  }

  #spinButton {
    min-height: 64px;
  }
}
