/* Game stage chrome — light casino theme (rev 2). 3D canvas + lazy poster + HUD overlays.
   Loaded only on the homepage (#game-root). */

.game-stage {
  position: relative;
  width: 100%;
  height: clamp(520px, 78vh, 820px);
  /* matches the WebGL scene background (#16402a) so there's no light→dark flash while it loads */
  background: radial-gradient(circle at 50% 42%, #1d5034 0%, #16402a 72%);
  overflow: hidden;
}
/* title band BELOW the table — Art Deco flourish on parchment, gold rule against the felt */
.game-hero { background:
    radial-gradient(ellipse 70% 120% at 50% 0%, rgba(31,122,77,0.06), transparent 60%),
    var(--cream);
  text-align: center; padding: clamp(28px, 5vw, 56px) 0 clamp(20px, 3vw, 32px);
  border-top: 3px solid var(--gold); position: relative; }
.hero-flourish { display: flex; align-items: center; justify-content: center; gap: 16px; color: var(--gold); font-size: 1.05rem; margin-bottom: 16px; }
.hero-flourish span:nth-child(2), .hero-flourish span:nth-child(3) { color: #b03a2e; } /* ♥ ♦ in red */
.hero-flourish::before, .hero-flourish::after { content: ''; height: 1px; width: clamp(40px, 12vw, 90px); }
.hero-flourish::before { background: linear-gradient(90deg, transparent, var(--gold)); }
.hero-flourish::after { background: linear-gradient(90deg, var(--gold), transparent); }
.game-hero h1 { color: var(--green-deep); margin: 0 0 12px; font-size: clamp(1.4rem, 4vw, 2.4rem); }
.game-hero p { color: var(--ink-soft); max-width: 720px; margin: 0 auto; font-size: clamp(0.9rem, 2vw, 1.05rem); }

.gv-stage { position: absolute; inset: 0; }
.gv-canvas { position: absolute; inset: 0; width: 100% !important; height: 100% !important; display: block; }

/* two spotlight beams from the top corners of the window, angled toward the table */
.stage-beams {
  position: absolute; inset: 0; z-index: 16; pointer-events: none; mix-blend-mode: screen;
  background:
    /* soft wash over the centre + foreground (chips area) so no dark band forms */
    radial-gradient(ellipse 130% 95% at 50% 60%, rgba(255,250,238,0.10) 0%, rgba(255,250,238,0.035) 45%, transparent 78%),
    /* top-left beam, wide, aimed lower so it sweeps down to the table edge */
    conic-gradient(from 108deg at 0% 0%, transparent 0deg, rgba(255,250,238,0.03) 16deg, rgba(255,250,238,0.10) 50deg, rgba(255,250,238,0.03) 84deg, transparent 100deg),
    /* top-right beam, mirrored, meeting in the centre */
    conic-gradient(from 152deg at 100% 0%, transparent 0deg, rgba(255,250,238,0.03) 16deg, rgba(255,250,238,0.10) 50deg, rgba(255,250,238,0.03) 84deg, transparent 100deg);
}
@media (prefers-reduced-motion: reduce) { .stage-beams { display: none; } }

/* 2D fallback table — realistic green felt + brown wooden rim */
.gv-flat { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  background: radial-gradient(circle at 50% 30%, #2a6b46 0%, #1d4f33 70%, #163c28 100%); }
.gv-flat .flat-rim {
  width: min(90%, 940px); height: 64%;
  background: radial-gradient(circle at center, #2e8b57 0%, #1f7a4d 55%, #176a41 100%);
  border: 18px solid #5a3414;
  border-radius: 50% / 60%;
  box-shadow: inset 0 0 90px rgba(0,0,0,0.35), 0 0 0 4px #3a2110, 0 18px 40px rgba(0,0,0,0.3);
}

/* lazy-init poster — light, protects LCP */
.game-poster {
  position: absolute; inset: 0; z-index: 30;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 20px;
  text-align: center; padding: 24px;
  background: radial-gradient(circle at 50% 38%, #f6f1e6 0%, #e6efe3 72%);
}
.game-poster .gp-title { font-family: var(--font-display); color: var(--green-deep); font-size: clamp(1.4rem, 4vw, 2.4rem); letter-spacing: 0.06em; margin: 0; }
.game-poster .gp-sub { color: var(--ink-soft); max-width: 540px; margin: 0; }
.game-poster .play-btn {
  font-family: var(--font-display); letter-spacing: 0.16em; text-transform: uppercase;
  background: var(--gold); color: #fff; border: 0; padding: 18px 40px; cursor: pointer;
  font-size: 0.9rem; transition: background .25s, transform .25s; box-shadow: 0 6px 18px rgba(184,134,47,0.4);
}
.game-poster .play-btn:hover { background: var(--green); transform: translateY(-2px); }
.game-poster .gp-note { font-size: 0.72rem; color: var(--ink-soft); letter-spacing: 0.04em; }
.game-poster.hidden { display: none; }

/* projected hand-value tags (3D) — light chips */
.hud-tags3d { position: absolute; inset: 0; pointer-events: none; z-index: 18; }
.hud-tag3d {
  position: absolute; top: 0; left: 0; will-change: transform;
  font-family: var(--font-display); font-size: 0.8rem; letter-spacing: 0.06em;
  background: #fffdf6; border: 1px solid var(--gold); color: var(--green-deep);
  padding: 3px 10px; border-radius: 4px; white-space: nowrap; box-shadow: 0 2px 6px rgba(0,0,0,0.25);
}
.hud-tag3d.bust { border-color: var(--bad); color: var(--bad); }
.hud-tag3d.bj { border-color: var(--gold); color: var(--gold); background: #fff8e6; }
.hud-tag3d.active-hand { box-shadow: 0 0 0 2px var(--gold); }

/* ===== HUD (hud.js / cards2d.js) — light panels over green felt ===== */
.gv-hud { position: absolute; inset: 0; z-index: 22; display: flex; flex-direction: column; justify-content: flex-end; pointer-events: none; font-family: var(--font-body); }
.gv-hud > * { pointer-events: auto; }

.hud-status { position: absolute; top: 12px; left: 12px; right: 12px; display: flex; align-items: center; gap: 10px; pointer-events: none; }
.hud-pill { background: rgba(255,253,246,0.92); border: 1px solid var(--gold); color: var(--green-deep); font-size: 0.78rem; font-weight: 700; padding: 6px 12px; }
.hud-pill .v { color: var(--gold); }
.hud-xpbar { flex: 1 1 auto; max-width: 220px; height: 12px; border: 1px solid var(--gold); background: rgba(255,253,246,0.92); position: relative; overflow: hidden; }
.hud-xpbar i { position: absolute; inset: 0; width: var(--xp-pct, 0%); background: linear-gradient(90deg, var(--gold), var(--gold-bright)); transition: width 0.4s ease-out; }
.hud-lessons { margin-left: auto; pointer-events: auto; font-family: var(--font-display); font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: #fff; background: var(--green); border: 0; padding: 9px 13px; cursor: pointer; }
.hud-lessons:hover { background: var(--green-deep); }

.hud-bubble { position: absolute; left: 50%; top: 12%; transform: translateX(-50%); max-width: min(460px, 86vw); background: #fffdf6; border: 1px solid var(--gold); border-top: 4px solid var(--green); box-shadow: 0 16px 40px rgba(0,0,0,0.3); padding: 14px 18px; font-size: 0.95rem; line-height: 1.5; color: var(--ink); }
.hud-bubble::after { content: ''; position: absolute; bottom: -10px; left: 50%; margin-left: -8px; border: 8px solid transparent; border-top-color: #fffdf6; }
.hud-bubble .who { display: block; font-family: var(--font-display); font-size: 0.68rem; color: var(--green-deep); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 6px; }
.hud-bubble .tap { display: block; text-align: right; font-size: 0.7rem; font-weight: 700; color: var(--gold); margin-top: 8px; animation: tap-pulse 1.4s ease-in-out infinite; }
@keyframes tap-pulse { 0%,100% { opacity: 0.45; } 50% { opacity: 1; } }

.hud-cards { position: absolute; inset: 0; pointer-events: none; }
.pcard { position: absolute; width: var(--card-w, 58px); height: calc(var(--card-w, 58px) * 1.45); transform-style: preserve-3d; transition: transform 0.45s cubic-bezier(0.25,0.6,0.3,1), left 0.45s cubic-bezier(0.25,0.6,0.3,1), top 0.45s cubic-bezier(0.25,0.6,0.3,1); will-change: transform; }
.pcard .cf { position: absolute; inset: 0; backface-visibility: hidden; border: 1px solid #cdbfa0; background: #fbf7ef; border-radius: 6px; overflow: hidden; }
.pcard .cf svg { width: 100%; height: 100%; display: block; }
.pcard .cf-back { transform: rotateY(180deg); background: repeating-linear-gradient(45deg, #176a41 0 6px, #1f7a4d 6px 12px); border-color: var(--gold); }
.pcard.facedown { transform: rotateY(180deg); }

.hud-tag { position: absolute; transform: translate(-50%, 0); background: #fffdf6; color: var(--green-deep); border: 1px solid var(--gold); font-size: 0.75rem; font-weight: 700; padding: 2px 8px; pointer-events: none; font-family: var(--font-display); }
.hud-tag.bust { border-color: var(--bad); color: var(--bad); }
.hud-tag.bj { border-color: var(--gold); color: var(--gold); }
.hud-tag.active-hand { outline: 2px solid var(--gold); outline-offset: 2px; }

.hud-toast { position: absolute; left: 50%; top: 36%; transform: translateX(-50%); font-family: var(--font-display); font-size: 1.1rem; pointer-events: none; animation: toast-rise 1.4s ease-out forwards; white-space: nowrap; text-shadow: 0 1px 3px rgba(0,0,0,0.4); }
.hud-toast.good { color: var(--gold-bright); } .hud-toast.bad { color: #ffd2cb; }
@keyframes toast-rise { 0% { opacity: 0; translate: 0 14px; } 18% { opacity: 1; translate: 0 0; } 75% { opacity: 1; } 100% { opacity: 0; translate: 0 -22px; } }

.hud-actions { position: relative; display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; padding: 12px max(10px, env(safe-area-inset-left)) max(14px, env(safe-area-inset-bottom)); background: linear-gradient(transparent, rgba(20,55,36,0.28)); }
/* premium casino action buttons — beveled, gold-edged, colour-coded per action */
.btn-act {
  font-family: var(--font-display); font-size: 0.76rem; letter-spacing: 0.08em; text-transform: uppercase;
  color: #fff; padding: 13px 18px; min-width: 92px; min-height: 50px; cursor: pointer;
  border: 1.5px solid var(--gold); border-radius: 11px;
  background: linear-gradient(180deg, #2a9460, #176a41);
  box-shadow: 0 3px 0 rgba(0,0,0,0.28), 0 7px 16px rgba(0,0,0,0.32), inset 0 1px 0 rgba(255,255,255,0.28);
  text-shadow: 0 1px 2px rgba(0,0,0,0.4);
  transition: transform .12s ease, box-shadow .12s ease, filter .15s ease;
}
.btn-act:not(:disabled):hover { filter: brightness(1.09); transform: translateY(-1px); }
.btn-act:not(:disabled):active { transform: translateY(2px); box-shadow: 0 1px 0 rgba(0,0,0,0.28), 0 2px 6px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.22); }
.btn-act:disabled { opacity: 0.42; cursor: default; box-shadow: 0 2px 0 rgba(0,0,0,0.2); }
/* casino colour-coding by action */
.btn-act[data-action="hit"]       { background: linear-gradient(180deg, #2a9460, #166a40); }
.btn-act[data-action="stand"]     { background: linear-gradient(180deg, #cf4436, #9a2c20); }
.btn-act[data-action="double"]    { background: linear-gradient(180deg, #ecca72, #b8862f); color: #3a2410; text-shadow: 0 1px 0 rgba(255,255,255,0.35); }
.btn-act[data-action="split"]     { background: linear-gradient(180deg, #4a7fc0, #2b5d9a); }
.btn-act[data-action="surrender"] { background: linear-gradient(180deg, #6f7d73, #444f49); }
.btn-act.primary { background: linear-gradient(180deg, #ecca72, #b8862f); color: #3a2410; text-shadow: 0 1px 0 rgba(255,255,255,0.35); }
.btn-act.glow { animation: btn-glow 1.3s ease-in-out infinite; }
@keyframes btn-glow {
  0%, 100% { box-shadow: 0 3px 0 rgba(0,0,0,0.28), 0 7px 16px rgba(0,0,0,0.32), inset 0 1px 0 rgba(255,255,255,0.28); }
  50% { box-shadow: 0 3px 0 rgba(0,0,0,0.28), 0 0 20px 5px rgba(224,184,85,0.65), inset 0 1px 0 rgba(255,255,255,0.3); }
}

.hud-bet { display: flex; gap: 8px; align-items: center; justify-content: center; flex-wrap: wrap; }
.bet-clear { font-family: var(--font-display); font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--cream); background: rgba(15,59,36,0.55); border: 1px solid rgba(255,255,255,0.5); border-radius: 8px; padding: 10px 14px; min-height: 44px; cursor: pointer; transition: filter .15s, opacity .15s; }
.bet-clear:not(:disabled):hover { filter: brightness(1.15); border-color: var(--gold-bright); }
.bet-clear:disabled { opacity: 0.35; cursor: default; }
.chipbtn { width: 54px; height: 54px; border-radius: 50%; border: 3px dashed rgba(255,255,255,0.85); font-family: var(--font-display); font-weight: 700; font-size: 0.8rem; cursor: pointer; color: #fff; background: var(--green); text-shadow: 0 1px 2px rgba(0,0,0,0.5); box-shadow: 0 4px 10px rgba(0,0,0,0.4), inset 0 0 0 4px rgba(0,0,0,0.16), inset 0 2px 3px rgba(255,255,255,0.4); transition: transform .12s ease, border-color .15s ease; }
.chipbtn:hover { border-color: var(--gold-bright); transform: translateY(-3px); }
.chipbtn:active { transform: translateY(1px); }
.chipbtn[data-v="25"] { background: #2b5d9a; } .chipbtn[data-v="50"] { background: var(--bad); } .chipbtn[data-v="100"] { background: var(--brown-deep); border-color: var(--gold-bright); color: var(--gold-bright); }

.hud-overlay { position: fixed; inset: 0; z-index: 70; display: flex; align-items: flex-start; justify-content: center; background: rgba(15,59,36,0.78); padding: calc(var(--header-h) + 16px) clamp(18px, 5vh, 42px) clamp(18px, 5vh, 42px); overflow-y: auto; }
.ov-panel { background: var(--cream); border: 2px solid var(--gold); border-radius: var(--radius); box-shadow: 0 24px 60px rgba(0,0,0,0.4); max-width: 540px; width: 100%; max-height: 100%; margin: auto; overflow-y: auto; padding: 26px; position: relative; color: var(--ink); scrollbar-width: thin; scrollbar-color: var(--gold) transparent; }
.ov-panel::-webkit-scrollbar { width: 9px; }
.ov-panel::-webkit-scrollbar-track { background: transparent; margin: 6px 0; }
.ov-panel::-webkit-scrollbar-thumb { background: var(--gold); border-radius: 6px; border: 2px solid var(--cream); }
.ov-panel::-webkit-scrollbar-thumb:hover { background: var(--green); }
.ov-panel h2 { margin: 0 0 6px; font-size: 1.3rem; color: var(--green-deep); }
.ov-panel .sub { font-size: 0.9rem; color: var(--ink-soft); margin: 0 0 16px; }
.ov-close { position: absolute; top: 12px; right: 12px; width: 34px; height: 34px; border: 1px solid var(--green); background: transparent; color: var(--green-deep); font-weight: 700; font-size: 1rem; cursor: pointer; line-height: 1; }
.ov-close:hover { background: var(--green); color: #fff; }

.ch-list { display: grid; gap: 10px; margin: 0; padding: 0; list-style: none; }
.ch-item { border: 1px solid var(--line-gold); background: var(--panel); padding: 14px; display: grid; grid-template-columns: 40px 1fr auto; gap: 4px 12px; align-items: center; }
.ch-item.done { background: var(--green-tint); }
.ch-num { grid-row: span 2; font-family: var(--font-display); font-size: 1.35rem; color: var(--gold); }
.ch-item.done .ch-num { color: var(--green); }
.ch-title { font-weight: 700; font-size: 0.95rem; color: var(--green-deep); }
.ch-desc { grid-column: 2; font-size: 0.8rem; color: var(--ink-soft); }
.ch-go { grid-row: span 2; font-family: var(--font-display); font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase; background: var(--gold); border: 0; padding: 10px 13px; cursor: pointer; color: #fff; }
.ch-free { margin-top: 14px; width: 100%; }

.lb-form { display: flex; gap: 8px; margin: 12px 0; }
.lb-form input { flex: 1; font: inherit; padding: 11px 13px; border: 1px solid var(--green); background: #fff; color: var(--ink); min-width: 0; }
.lb-form button { flex-shrink: 0; }
.lb-err { color: var(--bad); font-size: 0.85rem; font-weight: 700; min-height: 1.2em; margin: 0; }
.lb-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; margin-top: 10px; }
.lb-table td, .lb-table th { padding: 8px; border-bottom: 1px solid var(--line); text-align: left; color: var(--ink); }
.lb-table .r { text-align: right; }
.lb-table tr.me { background: var(--green-tint); font-weight: 700; }
.lb-rank { font-family: var(--font-display); color: var(--gold); font-size: 0.85rem; }

.lvl-burst { text-align: center; padding: 10px 0 4px; }
.lvl-burst .big { font-family: var(--font-display); font-size: 2.2rem; color: var(--green-deep); display: block; }
.confetti { position: absolute; width: 10px; height: 10px; top: -12px; animation: conf-fall 1.5s linear forwards; }
@keyframes conf-fall { to { transform: translateY(110vh) rotate(540deg); opacity: 0.2; } }

.hud-skip { position: absolute; right: 12px; bottom: 14px; background: #fffdf6; color: var(--green-deep); border: 1px solid var(--gold); font-weight: 700; font-size: 0.8rem; padding: 9px 13px; cursor: pointer; }

/* rotate-to-landscape hint — shown only on small portrait screens */
.rotate-hint {
  position: absolute; top: calc(var(--header-h) + 8px); left: 50%; transform: translateX(-50%);
  z-index: 19; display: none; align-items: center; gap: 8px;          /* above the canvas, BELOW the dealer bubble (gv-hud z22) */
  background: rgba(15,59,36,0.9); color: #f3ecdb; border: 1px solid var(--gold);
  font-family: var(--font-display); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 7px 14px; border-radius: 999px; pointer-events: none; white-space: nowrap;
}

/* ---------- mobile (bottom-sheet controls, big touch targets) ---------- */
@media (max-width: 640px) {
  /* action bar becomes a full-width bottom sheet */
  .hud-actions { gap: 8px; padding: 12px 10px max(16px, env(safe-area-inset-bottom)); background: linear-gradient(transparent, rgba(20,55,36,0.5)); }
  .btn-act { flex: 1 1 28%; min-width: 0; font-size: 0.74rem; padding: 15px 6px; min-height: 52px; }
  .hud-bet { gap: 10px; max-width: 100%; overflow-x: auto; padding: 4px 2px; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .hud-bet::-webkit-scrollbar { display: none; }
  .chipbtn { flex: 0 0 auto; width: 56px; height: 56px; }
  .hud-bubble { top: 8%; font-size: 0.9rem; max-width: 92vw; padding: 12px 14px; }
  .hud-status { gap: 6px; top: 8px; left: 8px; right: 8px; }
  .hud-pill { font-size: 0.7rem; padding: 4px 8px; }
  .hud-lessons { padding: 8px 10px; }
  .gv-hudbar { top: 8px; left: 8px; min-width: 0; padding: 8px 12px; }
  .gv-hudbar .bank { font-size: 1.3rem; }
  /* overlays stay a floating, bordered panel (with margin) so it reads as a window, below the header */
  .hud-overlay { padding: calc(var(--header-h) + 12px) 14px 14px; align-items: flex-start; }
  .ov-panel { max-width: 100%; padding: 22px 18px calc(22px + env(safe-area-inset-bottom)); }
  .ch-item { grid-template-columns: 34px 1fr; }
  .ch-go { grid-column: 2; grid-row: auto; justify-self: start; margin-top: 6px; }
}
@media (orientation: portrait) and (max-width: 768px) {
  .rotate-hint { display: inline-flex; }
}

/* ===== "Progresul meu" dashboard (progress.js) — light panels ===== */
.pg-grid, .pg-summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 12px; margin: 6px 0 18px; }
.pg-stat { border: 1px solid var(--line-gold); background: var(--panel); padding: 14px; text-align: center; }
.pg-stat--hero { grid-column: 1 / -1; background: var(--green-tint); }
.pg-num { font-family: var(--font-display); font-size: 1.9rem; color: var(--green-deep); line-height: 1; }
.pg-stat--hero .pg-num { font-size: 2.8rem; color: var(--gold); }
.pg-lbl { font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-soft); margin-top: 6px; }
.pg-sub { font-size: 0.78rem; color: var(--ink-soft); margin-top: 4px; }
.pg-level { border: 1px solid var(--line-gold); background: var(--panel); padding: 14px 16px; margin-bottom: 18px; }
.pg-level-top { display: flex; justify-content: space-between; font-family: var(--font-display); color: var(--green-deep); font-size: 0.9rem; margin-bottom: 8px; }
.pg-bar { height: 12px; background: rgba(21,89,47,0.1); border: 1px solid var(--line-gold); overflow: hidden; }
.pg-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--gold), var(--gold-bright)); }
.pg-h { font-family: var(--font-display); color: var(--green-deep); font-size: 0.95rem; letter-spacing: 0.06em; margin: 20px 0 10px; }
.pg-mistakes { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.pg-mistakes li { display: flex; justify-content: space-between; gap: 10px; padding: 9px 12px; border: 1px solid var(--line); background: var(--panel); font-size: 0.88rem; color: var(--ink); }
.pg-mc { font-family: var(--font-display); color: var(--bad); }
.pg-chart { width: 100%; height: auto; border: 1px solid var(--line-gold); background: var(--panel); padding: 8px; }
.pg-hint { font-size: 0.78rem; color: var(--ink-soft); margin: 8px 0 0; }
.pg-badges { display: flex; flex-wrap: wrap; gap: 8px; }
.pg-badge { font-family: var(--font-display); font-size: 0.72rem; letter-spacing: 0.04em; padding: 7px 12px; border: 1px solid var(--line); border-radius: 999px; color: var(--ink-soft); background: var(--cream-2); opacity: 0.6; }
.pg-badge.got { color: #fff; background: var(--green); border-color: var(--green); opacity: 1; }
