/* @minicasino — gentlemen's club video poker table.
   Wood, green felt, aged brass, leather, warm low light. Mobile-first. */
:root {
  --felt-green: #11593b;
  --felt-green-dk: #07351f;
  --wood: #3a2415;
  --wood-dk: #221309;
  --wood-lt: #6a4527;
  --brass: #c9a24b;
  --brass-lt: #ecd79a;
  --brass-dk: #7d5f22;
  --leather: #5b2222;
  --cream: #f4ecd6;
  --ink: #1c1208;
  --card-bg: #fbf6ea;
  --card-red: #b3261e;
  --card-ink: #1d1d1d;
  --shadow: rgba(0, 0, 0, 0.55);
  --serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --display: "Cinzel", var(--serif);
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body {
  margin: 0; min-height: 100vh; font-family: var(--serif); color: var(--cream);
  background: radial-gradient(125% 90% at 50% -10%, #5a3a22 0%, var(--wood-dk) 55%, #120a04 100%);
  overflow-x: hidden;
}
button { font-family: var(--display); }

.club { min-height: 100vh; display: flex; flex-direction: column;
  padding: env(safe-area-inset-top) 10px env(safe-area-inset-bottom); max-width: 560px; margin: 0 auto; }

/* top bar */
.club__bar { display: flex; align-items: center; justify-content: space-between;
  padding: 12px 6px 10px; border-bottom: 2px solid var(--brass-dk); }
.club__brand { font-family: var(--display); font-size: 21px; color: var(--brass-lt);
  letter-spacing: 1px; text-shadow: 0 1px 0 #000, 0 0 14px rgba(201,162,75,.25); }
.club__balance { display: inline-flex; align-items: center; gap: 7px; font-size: 19px;
  color: var(--cream); font-weight: 700; }
.chip { width: 16px; height: 16px; border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #ffe9a8, var(--brass) 60%, var(--brass-dk));
  border: 2px dashed #fff7; box-shadow: 0 1px 3px #000; }
.admin-btn { font-size: 11px; font-weight: 700; padding: 3px 9px; margin-right: 8px;
  border-radius: 7px; border: 1px solid var(--brass-dk); cursor: pointer; color: var(--ink);
  background: linear-gradient(180deg, var(--brass-lt), var(--brass-dk)); font-family: var(--display); }
.admin-btn[hidden] { display: none; }
.admin-btn:active { transform: translateY(1px); }

/* header icon buttons (menu, lock) */
.icon-btn { background: none; border: 1px solid var(--brass-dk); color: var(--brass-lt);
  width: 34px; height: 30px; border-radius: 8px; font-size: 15px; cursor: pointer; flex: none; }
.icon-btn.on { background: var(--brass); color: var(--ink); border-color: var(--brass); }
.icon-btn:active { transform: translateY(1px); }

/* rotating clickable brand */
.club__bar .club__brand { font-size: 15px; flex: 1; text-align: center; margin: 0 8px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; cursor: pointer;
  text-decoration: none; }
.club__brand.fadein { animation: brandFade .45s ease; }
@keyframes brandFade { from { opacity: 0; transform: translateY(-3px); } to { opacity: 1; } }

/* main menu modal */
.menu-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 6px; }
.menu-item { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border-radius: 12px;
  background: rgba(0,0,0,.3); border: 1px solid var(--brass-dk); color: var(--cream);
  font-size: 16px; cursor: pointer; font-family: var(--display); text-align: left; }
.menu-item span { font-size: 20px; }
.menu-item:active { transform: translateY(1px); }

/* clickable channels (header + disclaimers) */
.channels { font-size: 12px; color: var(--brass); margin: 12px 0 4px; line-height: 1.8; }
.tglink { color: var(--brass-lt); text-decoration: underline; cursor: pointer; }

/* paytable */
.paytable { display: flex; flex-wrap: wrap; gap: 5px 7px; justify-content: center;
  padding: 9px 4px; }
.pt { display: inline-flex; gap: 6px; align-items: baseline; font-size: 11px;
  padding: 4px 8px; border-radius: 7px; color: var(--cream);
  background: linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.4));
  border: 1px solid var(--brass-dk); }
.pt b { font-weight: 600; color: var(--brass-lt); }
.pt i { font-style: normal; color: #ffd86b; font-weight: 700; }

/* felt table */
.felt { flex: 1; margin: 6px 2px; border-radius: 18px;
  background: radial-gradient(130% 130% at 50% 0%, var(--felt-green) 0%, var(--felt-green-dk) 100%);
  border: 11px solid transparent;
  border-image: linear-gradient(160deg, var(--wood-lt), var(--wood-dk)) 1;
  box-shadow: inset 0 0 70px rgba(0,0,0,.5), 0 12px 30px var(--shadow);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px;
  padding: 18px 10px; }

/* hand of cards */
.hand { display: flex; gap: 2.2vw; justify-content: center; width: 100%; }
.card { position: relative; flex: 1 1 0; max-width: 84px; aspect-ratio: 5 / 7;
  border-radius: 8px; perspective: 600px; }
.card__face, .card__back { position: absolute; inset: 0; border-radius: 8px;
  /* stronger, deeper shadow under cards */
  box-shadow: 0 10px 20px rgba(0,0,0,.6), 0 4px 8px rgba(0,0,0,.45); }
.card__face { background: linear-gradient(160deg, #fffdf6, var(--card-bg));
  border: 1px solid #b6a87f; color: var(--card-ink); overflow: hidden; }
/* thin classic inner frame on the card face */
.card__face::before { content: ""; position: absolute; inset: 4px; border-radius: 5px;
  border: 1px solid rgba(120,100,55,.45); pointer-events: none; }
.card--red { color: var(--card-red); }
.card__back { background:
  repeating-linear-gradient(45deg, #6e1b1b 0 6px, #581414 6px 12px);
  border: 2px solid var(--brass-dk);
  box-shadow: inset 0 0 0 3px #2a0d0d, 0 10px 20px rgba(0,0,0,.6), 0 4px 8px rgba(0,0,0,.45); }

/* "magic" shimmer on the cards that form the winning combo */
.card.magic .card__face {
  border-color: var(--brass-lt);
  animation: magicGlow 1.4s ease-in-out infinite;
}
.card.magic .card__face::after {
  content: ""; position: absolute; inset: 0; border-radius: 8px; pointer-events: none;
  background: linear-gradient(115deg, transparent 38%, rgba(255,234,160,.6) 50%, transparent 62%);
  background-size: 250% 100%;
  animation: magicSheen 1.8s linear infinite;
  mix-blend-mode: screen;
}
@keyframes magicGlow {
  0%,100% { box-shadow: 0 10px 20px rgba(0,0,0,.6), 0 0 12px rgba(255,216,107,.55),
              inset 0 0 10px rgba(255,216,107,.3); }
  50% { box-shadow: 0 10px 20px rgba(0,0,0,.6), 0 0 28px rgba(255,216,107,.95),
              inset 0 0 20px rgba(255,216,107,.5); }
}
@keyframes magicSheen {
  0% { background-position: 200% 0; }
  100% { background-position: -100% 0; }
}
.card__corner { position: absolute; display: flex; flex-direction: column; align-items: center;
  line-height: .9; font-weight: 700; }
.card__corner b { font-size: clamp(11px, 4.2vw, 18px); font-family: var(--serif); }
.card__corner i { font-style: normal; font-size: clamp(9px, 3.4vw, 14px); }
.card__corner.tl { top: 5px; left: 6px; }
.card__corner.br { bottom: 5px; right: 6px; transform: rotate(180deg); }
.card__pip { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-size: clamp(26px, 11vw, 46px); opacity: .92; }

/* hold button under each card */
.hold { position: absolute; bottom: -28px; left: 50%; transform: translateX(-50%);
  font-size: 10px; letter-spacing: 1px; padding: 4px 9px; border-radius: 6px; cursor: pointer;
  color: var(--brass-lt); background: rgba(0,0,0,.45); border: 1px solid var(--brass-dk);
  opacity: 0; transition: opacity .2s; }
.hand.holds-on .hold { opacity: 1; }
.card.is-held .card__face { outline: 3px solid var(--brass-lt);
  animation: heldBlink 1s ease-in-out infinite; }
.card.is-held .hold { background: var(--brass); color: var(--ink); font-weight: 700;
  box-shadow: 0 0 12px rgba(236,215,154,.7); }
@keyframes heldBlink {
  0%,100% { box-shadow: 0 0 6px rgba(236,215,154,.5), 0 4px 10px rgba(0,0,0,.45); }
  50% { box-shadow: 0 0 20px rgba(236,215,154,.95), 0 4px 10px rgba(0,0,0,.45); }
}
.deal-in { animation: dealIn .34s cubic-bezier(.2,.8,.25,1) both; }
@keyframes dealIn {
  from { transform: translateY(-24px) rotateY(90deg) scale(.9); opacity: 0; }
  to { transform: none; opacity: 1; }
}

/* message line */
.message { margin: 24px 0 0; font-size: 16px; min-height: 22px; text-align: center;
  color: var(--cream); font-style: italic; }
.message--win { color: #ffd86b; font-style: normal; font-weight: 700;
  text-shadow: 0 0 16px rgba(255,216,107,.5); }
.message--lose { color: #e8a; opacity: .9; }

/* double-up */
.gamble { margin: 8px 2px 0; padding: 12px; border-radius: 14px; text-align: center;
  background: linear-gradient(180deg, rgba(91,34,34,.6), rgba(40,14,14,.7));
  border: 1px solid var(--brass-dk); }
.gamble__title { margin: 0 0 10px; color: var(--brass-lt); font-family: var(--display); }
.gamble__cards { display: flex; gap: 20px; justify-content: center; }
.gamble__cards:not(:empty) { margin-bottom: 8px; }
.ducard { display: flex; flex-direction: column; align-items: center; gap: 5px; }
.ducard .card { flex: none; width: 58px; aspect-ratio: 5 / 7; }
.ducard__lbl { font-size: 11px; color: var(--brass); }
.gamble__hint { font-size: 11px; color: var(--brass); opacity: .8; margin: 0 0 10px; }
.gamble__row { display: flex; gap: 10px; margin-bottom: 10px; }
.gamble__row .btn { flex: 1; }

/* controls */
.controls { display: flex; align-items: center; gap: 12px; padding: 12px 4px 8px; }
.bet { display: flex; align-items: center; gap: 8px; }
.bet__box { display: flex; flex-direction: column; align-items: center; min-width: 56px;
  padding: 4px 8px; border-radius: 9px; background: rgba(0,0,0,.35); border: 1px solid var(--brass-dk); }
.bet__label { font-size: 9px; letter-spacing: 2px; color: var(--brass); }
.bet__box span:last-child { font-size: 20px; font-weight: 700; color: var(--cream); }

/* buttons */
.btn { font-size: 15px; font-weight: 700; padding: 11px 18px; border-radius: 10px; border: none;
  cursor: pointer; letter-spacing: .6px; }
.btn:disabled { opacity: .5; cursor: default; }
.btn--brass { color: var(--ink);
  background: linear-gradient(180deg, var(--brass-lt) 0%, var(--brass) 45%, var(--brass-dk) 100%);
  box-shadow: 0 3px 0 var(--brass-dk), 0 6px 14px var(--shadow); border: 1px solid #6b521c; }
.btn--brass:active:not(:disabled) { transform: translateY(2px); box-shadow: 0 1px 0 var(--brass-dk); }
.btn--felt { color: var(--cream); background: linear-gradient(180deg, #14613f, #0c3f28);
  border: 1px solid var(--brass-dk); box-shadow: 0 3px 8px var(--shadow); }
.btn--felt:active:not(:disabled) { transform: translateY(1px); }
.btn--round { width: 40px; height: 40px; border-radius: 50%; padding: 0; font-size: 22px; }
.btn--main { flex: 1; font-size: 19px; padding: 15px; letter-spacing: 2px; }
.btn--wide { width: 100%; }

/* provably fair */
.fair { margin: 4px 2px 0; }
.fair__toggle { width: 100%; background: none; border: 1px dashed var(--brass-dk); color: var(--brass);
  padding: 9px; border-radius: 9px; cursor: pointer; font-size: 13px; letter-spacing: 1px; }
.fair__body { margin-top: 8px; padding: 12px; border-radius: 12px;
  background: rgba(0,0,0,.3); border: 1px solid var(--brass-dk); }
.fair__line { margin: 0 0 8px; font-size: 11px; color: var(--cream); display: flex;
  flex-direction: column; gap: 3px; }
.fair__line code { word-break: break-all; color: #ffd86b; font-size: 11px; }
.fair__result { font-size: 12px; margin: 6px 0 0; min-height: 16px; }
.fair__result.ok { color: #7be29a; } .fair__result.bad { color: #f3a; }
.fair__note { font-size: 10px; opacity: .6; margin: 6px 0 0; }

.club__foot { padding: 10px 8px 14px; text-align: center; font-size: 10px; color: var(--brass);
  opacity: .7; font-style: italic; }

/* bottom nav */
.nav { display: flex; gap: 8px; padding: 8px 2px 2px; }
.nav__btn { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 2px;
  background: linear-gradient(180deg, rgba(58,36,21,.7), rgba(34,19,9,.85));
  border: 1px solid var(--brass-dk); border-radius: 11px; padding: 8px 4px; cursor: pointer;
  color: var(--brass-lt); }
.nav__btn span { font-size: 18px; }
.nav__btn i { font-style: normal; font-size: 11px; letter-spacing: .5px; }
.nav__btn:active { transform: translateY(1px); }

/* modal */
.modal { position: fixed; inset: 0; background: rgba(10,6,3,.72); backdrop-filter: blur(3px);
  display: flex; align-items: flex-end; justify-content: center; z-index: 50; }
.modal[hidden] { display: none; }  /* class display:flex would otherwise override [hidden] */
.modal__sheet { width: 100%; max-width: 560px; max-height: 88vh; overflow-y: auto;
  background: radial-gradient(120% 60% at 50% 0%, #2c1a0e, #1a0f07);
  border: 1px solid var(--brass-dk); border-bottom: none; border-radius: 18px 18px 0 0;
  box-shadow: 0 -10px 40px rgba(0,0,0,.6); padding: 16px 16px 28px;
  animation: sheetUp .25s ease both; }
@keyframes sheetUp { from { transform: translateY(40px); opacity: 0; } to { transform: none; opacity: 1; } }
.sheet__head { display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid var(--brass-dk); padding-bottom: 10px; margin-bottom: 12px; }
.sheet__head h2 { margin: 0; font-family: var(--display); font-size: 19px; color: var(--brass-lt); }
.sheet__x { background: none; border: none; color: var(--brass); font-size: 20px; cursor: pointer; }
.sheet__body h3 { font-family: var(--display); font-size: 13px; color: var(--brass);
  letter-spacing: 1px; margin: 14px 0 8px; text-transform: uppercase; }

/* shop product rows */
.prod { display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 11px 12px; margin-bottom: 8px; border-radius: 12px;
  background: rgba(0,0,0,.3); border: 1px solid var(--brass-dk); }
.prod b { display: block; color: var(--cream); font-size: 15px; }
.prod span { font-size: 11px; color: var(--brass); }
.prod .btn { padding: 9px 14px; }

/* disclaimer */
.disc { font-size: 14px; line-height: 1.5; color: var(--cream); margin: 0 0 14px; }
.check { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--cream);
  margin: 0 0 14px; cursor: pointer; }
.check input { width: 18px; height: 18px; accent-color: var(--brass); }

/* leaderboard */
.lbrow { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: 9px;
  margin-bottom: 5px; background: rgba(0,0,0,.25); }
.lbrow.me { background: linear-gradient(90deg, rgba(201,162,75,.25), rgba(201,162,75,.08));
  border: 1px solid var(--brass); }
.lbrow.sticky { position: sticky; bottom: 0; margin-top: 10px; }
.lbrank { width: 40px; color: var(--brass); font-weight: 700; }
.lbname { flex: 1; color: var(--cream); }
.lbchips { color: #ffd86b; font-weight: 700; }
.muted { color: var(--brass); opacity: .7; font-size: 12px; text-align: center; padding: 10px; }

/* settings */
.setrow { display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 10px 0; border-bottom: 1px solid rgba(201,162,75,.2); }
.setrow.col { flex-direction: column; align-items: flex-start; gap: 8px; }
.lng { background: rgba(0,0,0,.3); border: 1px solid var(--brass-dk); color: var(--brass-lt);
  padding: 6px 12px; border-radius: 8px; cursor: pointer; margin-left: 6px; font-weight: 700; }
.lng.on { background: var(--brass); color: var(--ink); }
.sheet__body code { color: #ffd86b; font-size: 12px; word-break: break-all; }
