/* ============================================================================
   GTO Wizard Pessoal — Eros  ·  tema escuro · identidade ROXA
   Fonte: Inter (vendorizada localmente)
   ========================================================================== */
@font-face { font-family: 'Inter'; src: url('../fonts/inter-400.woff2') format('woff2'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'Inter'; src: url('../fonts/inter-500.woff2') format('woff2'); font-weight: 500; font-display: swap; }
@font-face { font-family: 'Inter'; src: url('../fonts/inter-600.woff2') format('woff2'); font-weight: 600; font-display: swap; }
@font-face { font-family: 'Inter'; src: url('../fonts/inter-700.woff2') format('woff2'); font-weight: 700; font-display: swap; }
@font-face { font-family: 'Inter'; src: url('../fonts/inter-800.woff2') format('woff2'); font-weight: 800; font-display: swap; }

:root {
  --bg: #0a0c10;
  --bg-soft: #0d1014;
  --panel: #13161c;
  --panel2: #171b22;
  --panel3: #1f242d;
  --line: rgba(255, 255, 255, .07);
  --line2: rgba(255, 255, 255, .13);
  --tx: #eef0f4;
  --tx2: #99a1ae;
  --tx3: #636b78;
  --violet: #a98bff;
  --violet-br: #c3acff;
  --violet-deep: #7c4dff;
  --violet-700: #6a3df0;
  --glow: rgba(124, 77, 255, .38);
  --green: #3fce9a;
  --red: #ef5a5a;
  --amber: #ecb54a;
  --blue: #5b9dff;
  /* cores de ação (estilo GTO) */
  --act-raise: #e24a3c;
  --act-call: #41c98a;
  --act-fold: #3f5d96;
  --radius: 14px;
  --shadow: 0 10px 30px rgba(0, 0, 0, .5);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { overflow-x: hidden; }
body {
  background: var(--bg);
  color: var(--tx);
  font: 15px/1.55 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
  letter-spacing: -.005em;
}
/* mesh de fundo animado (profundidade, sem prejudicar a leitura) */
body::before {
  content: ''; position: fixed; inset: -10%; z-index: -1; pointer-events: none;
  background:
    radial-gradient(620px 520px at 86% -4%, rgba(124, 77, 255, .16), transparent 60%),
    radial-gradient(520px 520px at 8% 8%, rgba(91, 140, 255, .07), transparent 55%),
    radial-gradient(560px 460px at 50% 112%, rgba(190, 80, 200, .06), transparent 60%);
  animation: meshmove 26s ease-in-out infinite alternate;
}
@keyframes meshmove { from { transform: translate3d(0, 0, 0) scale(1); } to { transform: translate3d(-2.5%, 1.5%, 0) scale(1.08); } }
@media (prefers-reduced-motion: reduce) { body::before { animation: none; } }
/* transição ao trocar de aba */
@keyframes viewIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.view-enter { animation: viewIn .38s cubic-bezier(.2, .7, .2, 1) both; }
::selection { background: rgba(124, 77, 255, .35); }
a { color: var(--violet); text-decoration: none; }
h1, h2, h3, h4 { margin: 0 0 .4em; font-weight: 700; letter-spacing: -.02em; }
.muted { color: var(--tx2); } .dim { color: var(--tx3); }
.small { font-size: 13px; } .tiny { font-size: 11px; }
.center { text-align: center; } .right { text-align: right; }
.mono { font-variant-numeric: tabular-nums; }

/* ---- Layout ---- */
.wrap { max-width: 1200px; margin: 0 auto; padding: 26px 22px 96px; }
header.top {
  position: sticky; top: 0; z-index: 50; backdrop-filter: blur(18px) saturate(1.2);
  background: rgba(10, 8, 16, .78); border-bottom: 1px solid var(--line);
}
.top-in { max-width: 1280px; margin: 0 auto; padding: 11px 22px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.brand { flex: 0 0 auto; order: 1; }
.top-actions { flex: 0 0 auto; order: 2; margin-left: auto; }

/* brand */
.brand { display: flex; align-items: center; gap: 11px; }
.brand .logo {
  width: 34px; height: 34px; border-radius: 10px; display: grid; place-items: center; font-size: 18px; color: #fff;
  background: linear-gradient(140deg, var(--violet), var(--violet-deep));
  box-shadow: 0 4px 16px var(--glow), inset 0 1px 0 rgba(255, 255, 255, .25);
}
.brand-txt { font-weight: 800; font-size: 16px; letter-spacing: -.03em; line-height: 1; color: #fff; display: flex; flex-direction: column; }
.brand-txt b { font-weight: 600; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--violet); margin-top: 2px; }
.userchip { font-size: 11px; font-weight: 600; padding: 4px 10px; border-radius: 20px; color: var(--violet-br);
  background: rgba(124, 77, 255, .12); border: 1px solid var(--line2); margin-left: 4px; }

/* nav (segmented, centralizada) */
.tabs { display: flex; gap: 3px; margin: 2px 0 0; padding: 4px; border-radius: 13px; order: 3; flex: 1 1 100%; min-width: 0;
  flex-wrap: wrap; justify-content: center; row-gap: 4px;
  background: rgba(255, 255, 255, .03); border: 1px solid var(--line); }
.tab { display: inline-flex; align-items: center; gap: 7px; padding: 8px 13px; border-radius: 9px; cursor: pointer; flex: 0 0 auto;
  color: var(--tx2); font-size: 13.5px; font-weight: 600; white-space: nowrap; user-select: none; transition: .14s; }
.tab .ti { display: inline-flex; align-items: center; opacity: .85; }
.tab.active .ti { opacity: 1; }
/* ícones SVG (Lucide) */
.ic-svg { display: block; }
.ic, .ti, .ico { display: inline-flex; align-items: center; }
.tab:hover { color: var(--tx); background: rgba(255, 255, 255, .04); }
.tab.active { color: #fff; background: rgba(124, 77, 255, .15); box-shadow: inset 0 0 0 1px rgba(124, 77, 255, .42); }
.tab.active .ti { color: var(--violet); opacity: 1; }

.top-actions { display: flex; align-items: center; gap: 10px; }
.btn-upload { display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px; border-radius: 11px; cursor: pointer;
  font: inherit; font-size: 13.5px; font-weight: 700; color: #fff; border: none;
  background: linear-gradient(140deg, var(--violet), var(--violet-deep)); box-shadow: 0 4px 16px var(--glow); }
.btn-upload:hover { filter: brightness(1.08); }
.sfx-btn { background: var(--panel2); border: 1px solid var(--line2); color: var(--tx2); border-radius: 10px; width: 38px; height: 38px;
  font-size: 16px; cursor: pointer; display: grid; place-items: center; }
.sfx-btn:hover { background: var(--panel3); color: #fff; }
.icon-btn { background: var(--panel2); border: 1px solid var(--line2); color: var(--tx2); border-radius: 10px; width: 38px; height: 38px;
  cursor: pointer; display: grid; place-items: center; }
.icon-btn:hover { background: var(--panel3); color: #fff; }
.btn-login { display: inline-flex; align-items: center; gap: 6px; padding: 9px 14px; border-radius: 11px; cursor: pointer;
  font: inherit; font-size: 13px; font-weight: 600; color: var(--violet-br); background: rgba(124,77,255,.12);
  border: 1px solid rgba(124,77,255,.35); }
.btn-login:hover { background: rgba(124,77,255,.2); color: #fff; }
.profile-btn { width: 38px; height: 38px; border-radius: 50%; cursor: pointer; display: grid; place-items: center;
  color: #fff; border: 1px solid rgba(124,77,255,.5); background: linear-gradient(140deg, var(--violet), var(--violet-deep)); }
.profile-btn:hover { filter: brightness(1.1); }
/* abas bloqueadas (em breve) */
.tab.locked { cursor: pointer; opacity: .55; position: relative; }
.tab.locked:hover { opacity: .8; background: rgba(255,255,255,.03); }
.tab.locked .ti { opacity: .6; }
.soon { font-size: 8.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; margin-left: 5px;
  padding: 2px 6px; border-radius: 20px; color: var(--violet-br); background: rgba(124,77,255,.16); border: 1px solid rgba(124,77,255,.3); }
/* modal "em breve" */
.soon-modal { text-align: center; padding: 10px 6px 4px; }
.soon-ic { width: 60px; height: 60px; margin: 4px auto 14px; border-radius: 16px; display: grid; place-items: center;
  color: var(--violet-br); background: rgba(124,77,255,.12); border: 1px solid rgba(124,77,255,.3); }
.soon-modal p { max-width: 380px; margin: 0 auto 16px; line-height: 1.55; }
.soon-badge { display: inline-block; font-size: 12px; font-weight: 700; padding: 6px 14px; border-radius: 20px;
  color: var(--violet-br); background: rgba(124,77,255,.14); border: 1px solid rgba(124,77,255,.34); }
.soon-badge.sm { font-size: 10.5px; padding: 4px 10px; }
/* configurações */
.settings-modal { display: flex; flex-direction: column; gap: 4px; margin-top: 6px; }
.set-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 14px 2px; border-bottom: 1px solid var(--line2); }
.set-row:last-child { border-bottom: none; }
.set-t { font-weight: 600; font-size: 14px; margin-bottom: 2px; }

/* ---- Hero banner (gradiente roxo, estilo dashboard premium) ---- */
.hero-banner {
  position: relative; overflow: hidden; border-radius: 16px; padding: 24px 28px; margin-bottom: 22px;
  display: flex; align-items: center; justify-content: space-between; gap: 20px; color: #fff;
  background: linear-gradient(118deg, #14171e 0%, #181523 56%, #1d1730 100%);
  border: 1px solid var(--line2);
  box-shadow: 0 14px 40px rgba(0, 0, 0, .5), inset 0 1px 0 rgba(255, 255, 255, .05);
}
.hero-banner::before { content: ''; position: absolute; width: 420px; height: 420px; right: -120px; top: -180px;
  background: radial-gradient(circle, rgba(124, 77, 255, .35), transparent 68%); pointer-events: none; }
.hero-deco { position: absolute; right: 128px; top: 50%; transform: translateY(-50%); color: #fff; pointer-events: none; }
.hero-deco svg { opacity: .15; }
.hero-deco .hero-glass { width: 154px; height: auto; opacity: .92; filter: drop-shadow(0 10px 26px rgba(0, 0, 0, .4)); mix-blend-mode: screen; }
.hero-spade { position: absolute; right: -10px; bottom: -40px; font-size: 150px; line-height: 1; color: rgba(255, 255, 255, .08); pointer-events: none; }
.hero-main { position: relative; z-index: 1; min-width: 0; }
.hero-eyebrow { text-transform: uppercase; letter-spacing: .16em; font-size: 11px; font-weight: 700; color: var(--violet); }
.hero-title { font-size: 25px; font-weight: 800; letter-spacing: -.02em; margin: 5px 0 3px; }
.hero-meta { font-size: 13px; opacity: .9; }
.hero-chips { display: flex; gap: 8px; margin-top: 15px; flex-wrap: wrap; }
.hero-chip { background: rgba(255, 255, 255, .05); border: 1px solid var(--line2); border-radius: 20px;
  padding: 5px 13px; font-size: 12.5px; font-weight: 600; color: var(--tx2); }
.hero-chip b { font-weight: 800; }
.hero-score { position: relative; z-index: 1; width: 104px; height: 104px; border-radius: 50%; flex-shrink: 0;
  background: rgba(124, 77, 255, .10); border: 2px solid rgba(124, 77, 255, .45);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1px;
  box-shadow: inset 0 2px 12px rgba(124, 77, 255, .18), 0 0 22px rgba(124, 77, 255, .2); }
.hero-score .n { font-size: 30px; font-weight: 800; line-height: 1; }
.hero-score .l { font-size: 8px; font-weight: 700; letter-spacing: .08em; color: var(--tx3); }
.hero-trocar { position: absolute; top: 16px; right: 18px; z-index: 2; display: inline-flex; align-items: center; gap: 6px;
  background: rgba(255, 255, 255, .06); border: 1px solid var(--line2); color: var(--tx2); border-radius: 9px;
  padding: 6px 12px; font: inherit; font-size: 12.5px; font-weight: 600; cursor: pointer; }
.hero-trocar:hover { background: rgba(255, 255, 255, .12); color: #fff; }

/* ---- Cards ---- */
.card { position: relative; background: linear-gradient(180deg, rgba(28, 24, 40, .66), rgba(15, 13, 21, .66));
  border: 1px solid var(--line); border-radius: 16px; padding: 22px; margin-bottom: 18px; backdrop-filter: blur(10px) saturate(1.1);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05), 0 14px 34px rgba(0, 0, 0, .42); }
.card.pad-sm { padding: 14px 18px; }
.section-title { display: flex; align-items: center; gap: 9px; font-size: 12px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--tx2); margin: 32px 2px 15px; }
.section-title::before { content: ''; width: 3px; height: 15px; border-radius: 3px; background: linear-gradient(var(--violet), var(--violet-deep)); box-shadow: 0 0 10px var(--glow); }
.section-title .ico { color: var(--violet); display: inline-flex; }
.btn-upload .ti { display: inline-flex; align-items: center; }
.grid { display: grid; gap: 14px; }
.row { display: flex; gap: 16px; flex-wrap: wrap; }
.row > * { flex: 1; min-width: 0; }

/* ---- Stat cards ---- */
.stats { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.stat { background: var(--panel2); border: 1px solid var(--line); border-radius: 13px; padding: 15px 16px; position: relative; overflow: hidden; transition: transform .15s, border-color .15s, box-shadow .15s; }
.stat:hover { transform: translateY(-2px); border-color: var(--line2); box-shadow: 0 8px 22px rgba(0, 0, 0, .35); }
.stat::before { content: ''; position: absolute; inset: 0 auto auto 0; width: 3px; height: 100%; background: var(--violet-deep); opacity: .0; }
.stat .k { font-size: 11.5px; color: var(--tx3); margin-bottom: 7px; font-weight: 600; letter-spacing: .02em; }
.stat .v { font-size: 27px; font-weight: 800; letter-spacing: -.03em; line-height: 1; }
.stat .v.blue { color: var(--blue); } .stat .v.green { color: var(--green); }
.stat .v.amber { color: var(--amber); } .stat .v.red { color: var(--red); }
.stat .sub { font-size: 11px; color: var(--tx3); margin-top: 6px; }

/* ---- Alert ---- */
.alert { border-left: 3px solid var(--amber); background: rgba(240, 184, 74, .07); border-radius: 10px; padding: 15px 17px; margin: 18px 0; }
.alert.red { border-color: var(--red); background: rgba(255, 107, 107, .08); }
.alert.green { border-color: var(--green); background: rgba(67, 212, 160, .07); }
.alert.violet { border-color: var(--violet-deep); background: rgba(124, 77, 255, .09); }
.alert b { color: #fff; }

/* ---- Charts ---- */
.chart-wrap { width: 100%; position: relative; }
.chart-svg { display: block; overflow: visible; }
.chart-tip { position: absolute; transform: translate(-50%, -135%); background: rgba(10, 8, 16, .96); border: 1px solid var(--line2);
  border-radius: 8px; padding: 5px 10px; font-size: 12px; color: var(--tx2); pointer-events: none; white-space: nowrap; z-index: 5;
  box-shadow: 0 6px 18px rgba(0, 0, 0, .55); }
.chart-tip b { color: #fff; font-variant-numeric: tabular-nums; }
@keyframes cdraw { from { clip-path: inset(0 100% 0 0); } to { clip-path: inset(0 0 0 0); } }
.cdraw { animation: cdraw 1s cubic-bezier(.4, .9, .3, 1) both; }
@keyframes cslice { from { opacity: 0; transform: scale(.7); } to { opacity: 1; transform: scale(1); } }
.cslice { transform-box: fill-box; transform-origin: center; animation: cslice .5s ease both; }
@keyframes cbar { from { transform: scaleY(0); opacity: .3; } to { transform: scaleY(1); opacity: 1; } }
.cbar { transform-box: fill-box; animation: cbar .6s cubic-bezier(.2, .8, .2, 1) both; }
@media (prefers-reduced-motion: reduce) { .cdraw, .cslice, .cbar { animation: none; clip-path: none; } }
.legend { display: flex; gap: 16px; flex-wrap: wrap; font-size: 12.5px; color: var(--tx2); margin: 4px 0 12px; }
.legend span { display: inline-flex; align-items: center; gap: 6px; }
.dot { width: 11px; height: 11px; border-radius: 4px; display: inline-block; }
.donut-wrap { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }

/* ---- Scores ---- */
.scores { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.score { background: var(--panel2); border: 1px solid var(--line); border-radius: 13px; padding: 15px; }
.score .lbl { font-size: 12.5px; color: var(--tx2); margin-bottom: 8px; }
.score .num { font-size: 25px; font-weight: 800; min-width: 30px; display: inline-block; }
.bar { height: 6px; border-radius: 4px; background: rgba(255, 255, 255, .07); overflow: hidden; margin-top: 9px; }
.bar > i { display: block; height: 100%; border-radius: 4px; }
.score .note { font-size: 11px; color: var(--tx3); margin-top: 8px; }

/* ---- Cartas estilo GGPoker (FUNDO BRANCO + naipe colorido) ---- */
.pc { display: inline-flex; align-items: center; gap: 0; justify-content: center; min-width: 28px; padding: 3px 6px;
  margin: 0 2px; border-radius: 5px; background: linear-gradient(180deg, #fff, #eef0f4); color: #15111f; font-weight: 800; font-size: 12.5px;
  box-shadow: inset 0 1px 0 #fff, 0 1px 2px rgba(0, 0, 0, .4); }
.pc.spade { color: #1a1a22; } .pc.heart { color: #e0394b; } .pc.diam { color: #2f7ae0; } .pc.club { color: #1f9d57; }
.cards-line { display: inline-flex; align-items: center; gap: 3px; }
.board-chip { background: rgba(255, 255, 255, .03); border: 1px solid var(--line); border-radius: 9px; padding: 7px 10px;
  display: inline-flex; gap: 8px; align-items: center; font-size: 12px; color: var(--tx2); }

/* ---- Cartas grandes (mesa) — FUNDO BRANCO + naipe colorido (4 cores) ---- */
.pcard { width: 56px; height: 78px; border-radius: 9px; position: relative; overflow: hidden; color: #15111f;
  background: linear-gradient(180deg, #ffffff, #e9e7f0);
  box-shadow: 0 6px 16px rgba(0, 0, 0, .5), inset 0 1px 0 #fff; }
.pcard.spade .idx, .pcard.spade .suit, .pcard.spade .big { color: #1a1a22; }
.pcard.heart .idx, .pcard.heart .suit, .pcard.heart .big { color: #e0394b; }
.pcard.diam .idx, .pcard.diam .suit, .pcard.diam .big { color: #2f7ae0; }
.pcard.club .idx, .pcard.club .suit, .pcard.club .big { color: #1f9d57; }
.pcard .idx { position: absolute; top: 5px; left: 7px; line-height: .92; display: flex; flex-direction: column; align-items: center; }
.pcard .idx .r { font-size: 17px; font-weight: 800; }
.pcard .idx .s { font-size: 12px; margin-top: -1px; }
.pcard .big { position: absolute; right: 5px; bottom: 2px; font-size: 30px; font-weight: 800; opacity: .96; line-height: 1; }
.pcard .suit { position: absolute; left: 50%; top: 52%; transform: translate(-50%, -50%); font-size: 26px; opacity: .16; }

/* ---- Play cards ---- */
.play { background: var(--panel2); border: 1px solid var(--line); border-radius: 13px; padding: 16px 18px; margin-bottom: 12px; transition: .14s; }
.play:hover { border-color: var(--line2); }
.play .head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin-bottom: 10px; }
.play .title { font-size: 15.5px; font-weight: 700; }
.play .meta { font-size: 12px; color: var(--tx3); margin-top: 3px; }
.tag { font-size: 11px; font-weight: 700; padding: 4px 11px; border-radius: 20px; white-space: nowrap; }
.tag.exc { background: rgba(67, 212, 160, .16); color: var(--green); }
.tag.good { background: rgba(111, 140, 255, .16); color: var(--blue); }
.tag.warn { background: rgba(240, 184, 74, .16); color: var(--amber); }
.tag.err { background: rgba(255, 107, 107, .16); color: var(--red); }
.tag.gto { background: rgba(163, 133, 255, .16); color: var(--violet); }
.chips-row { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 11px; }
.chip { font-size: 11.5px; padding: 4px 11px; border-radius: 20px; background: rgba(255, 255, 255, .04); border: 1px solid var(--line); color: var(--tx2); }
.chip.pos { color: var(--green); border-color: rgba(67, 212, 160, .3); }
.chip.neg { color: var(--red); border-color: rgba(255, 107, 107, .3); }

.notes { margin-top: 11px; display: grid; gap: 5px; }
.note-line { display: flex; gap: 9px; font-size: 13px; align-items: baseline; }
.note-line .st { font-size: 10px; font-weight: 800; color: var(--tx3); min-width: 62px; letter-spacing: .05em; }
.note-line.ok .vd { color: var(--green); } .note-line.warn .vd { color: var(--amber); } .note-line.error .vd { color: var(--red); }
.vd { font-weight: 700; }

/* ---- Leak cards ---- */
.leak { display: flex; gap: 14px; align-items: flex-start; background: var(--panel2); border: 1px solid var(--line);
  border-radius: 13px; padding: 14px 16px; margin-bottom: 10px; }
.leak .badge { width: 36px; height: 36px; border-radius: 10px; display: grid; place-items: center; font-weight: 800; flex-shrink: 0;
  background: rgba(255, 107, 107, .14); color: var(--red); }
.leak.ok .badge { background: rgba(67, 212, 160, .14); color: var(--green); }
.leak .body { flex: 1; }
.leak .name { font-weight: 700; font-size: 14.5px; }
.leak .stat-line { font-size: 12.5px; color: var(--tx2); margin-top: 3px; }
.leak-fix { font-size: 12.5px; color: var(--tx); margin-top: 8px; background: rgba(124, 77, 255, .08); border: 1px solid var(--line2); border-radius: 8px; padding: 7px 10px; line-height: 1.45; }
/* insights & dicas */
.ins-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.insight { margin-bottom: 0; }
.ins-title { font-weight: 700; font-size: 15px; margin-bottom: 6px; }
.ins-tip { margin-top: 10px; font-size: 13px; color: var(--tx); background: rgba(124, 77, 255, .08); border: 1px solid var(--line2); border-radius: 9px; padding: 8px 11px; line-height: 1.45; }
.strat-why { margin-top: 8px; font-size: 12px; color: var(--tx2); background: rgba(124, 77, 255, .08); border-radius: 8px; padding: 7px 9px; line-height: 1.4; }
@media (max-width: 780px) { .ins-grid { grid-template-columns: 1fr; } }

/* ---- Tables ---- */
table.tbl { width: 100%; border-collapse: collapse; font-size: 13.5px; }
table.tbl th { text-align: left; color: var(--tx3); font-weight: 700; font-size: 11px; text-transform: uppercase;
  letter-spacing: .06em; padding: 9px 10px; border-bottom: 1px solid var(--line2); }
table.tbl td { padding: 10px; border-bottom: 1px solid var(--line); }
table.tbl tr:hover td { background: rgba(163, 133, 255, .04); }
table.tbl tr.hist-row { cursor: pointer; }
table.tbl tr.hist-row:hover td { background: rgba(124, 77, 255, .12); }

/* ---- Buttons / inputs ---- */
.btn { display: inline-flex; align-items: center; gap: 8px; padding: 9px 16px; border-radius: 11px; border: 1px solid var(--line2);
  background: var(--panel2); color: var(--tx); font: inherit; font-size: 14px; font-weight: 600; cursor: pointer; transition: .14s; }
.btn:hover { background: var(--panel3); }
.btn.primary { background: linear-gradient(140deg, var(--violet), var(--violet-deep)); border-color: transparent; color: #fff; box-shadow: 0 4px 16px var(--glow); }
.btn.green { background: linear-gradient(140deg, var(--green), #2faa7f); border-color: transparent; color: #042018; }
.btn.red { background: linear-gradient(140deg, var(--red), #d84d4d); border-color: transparent; color: #fff; }
.btn.ghost { background: transparent; }
.btn:disabled { opacity: .5; cursor: default; }
input, select { background: var(--bg-soft); border: 1px solid var(--line2); color: var(--tx); border-radius: 10px; padding: 9px 12px; font: inherit; font-size: 14px; }
input:focus, select:focus { outline: none; border-color: var(--violet); box-shadow: 0 0 0 3px rgba(124, 77, 255, .18); }
input[type=range] { accent-color: var(--violet); padding: 0; }
label.field { display: block; font-size: 12px; color: var(--tx3); margin-bottom: 5px; }

/* ---- Dropzone ---- */
.drop { border: 1.5px dashed var(--line2); border-radius: 18px; padding: 50px 24px; text-align: center; cursor: pointer; transition: .15s; background: rgba(163, 133, 255, .02); }
.drop:hover, .drop.over { border-color: var(--violet); background: rgba(124, 77, 255, .07); }
.drop .drop-ic { width: 60px; height: 60px; margin: 0 auto 14px; border-radius: 16px; display: grid; place-items: center;
  color: var(--violet); background: rgba(124, 77, 255, .12); border: 1px solid var(--line2); }
.drop .big { font-size: 19px; font-weight: 700; margin-bottom: 6px; }
/* badge de ícone nos feature cards */
.feat-ic { width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center; margin-bottom: 12px;
  color: var(--violet); background: rgba(124, 77, 255, .12); border: 1px solid var(--line2); }

/* ---- Push/Fold grid (cores de ação estilo GTO) ---- */
.pf-gridwrap { display: flex; gap: 22px; align-items: flex-start; }
.pf-gridwrap .pf-grid { flex: 1 1 auto; max-width: 600px; }
.pf-side { flex: 1 1 240px; min-width: 220px; display: flex; flex-direction: column; gap: 12px; }
.pf-side-card { background: var(--panel2); border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px; }
.pfs-h { font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--tx2); margin-bottom: 10px; }
.pfs-row { display: flex; justify-content: space-between; align-items: center; font-size: 13px; color: var(--tx2); padding: 3px 0; }
.pfs-row b { color: var(--tx); }
.pfs-dist { display: flex; align-items: center; gap: 8px; margin-bottom: 7px; font-size: 12px; }
.pfs-dot { width: 10px; height: 10px; border-radius: 3px; flex: 0 0 auto; }
.pfs-dl { width: 78px; flex: 0 0 auto; color: var(--tx2); }
.pfs-bar { flex: 1; height: 7px; border-radius: 5px; background: rgba(255, 255, 255, .07); overflow: hidden; }
.pfs-bar i { display: block; height: 100%; border-radius: 5px; }
.pfs-pct { width: 24px; text-align: right; font-weight: 700; font-variant-numeric: tabular-nums; }
.pf-side-tip { font-size: 12px; line-height: 1.5; color: var(--tx2); background: rgba(124, 77, 255, .08);
  border: 1px solid rgba(124, 77, 255, .2); border-radius: 12px; padding: 12px 14px; }
@media (max-width: 900px) { .pf-gridwrap { flex-direction: column; } .pf-gridwrap .pf-grid { max-width: 100%; } }
.pf-grid { display: grid; grid-template-columns: repeat(13, 1fr); gap: 3px; max-width: 580px; }
.pf-cell { aspect-ratio: 1; border-radius: 4px; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 0; color: #fff; position: relative; overflow: hidden; text-shadow: 0 1px 2px rgba(0, 0, 0, .5); }
.pf-cell.darktext { color: #20142e; text-shadow: none; }
.pf-cell.darktext .pf-suit { opacity: .7; }
.pf-rank { font-size: 10px; font-weight: 800; line-height: 1.05; }
.pf-suit { font-size: 8px; line-height: 1; opacity: .9; letter-spacing: .5px; }
.pf-cell.dimtext { color: rgba(255, 255, 255, .6); }
.pf-cell.hl { box-shadow: 0 0 0 2px #fff, 0 0 9px rgba(255, 255, 255, .7); z-index: 1; }
.pf-grid.mini { max-width: 320px; gap: 2px; }
.pf-grid.mini .pf-cell { border-radius: 3px; }
.pf-grid.mini .pf-rank, .pf-grid.mini .pf-suit { display: none; }
.pf-grid.mini .pf-cell.hl .pf-rank { display: block; font-size: 7px; }

/* guia de cartas */
.card-guide .cg-title { font-size: 13px; font-weight: 700; margin-bottom: 8px; }
.card-guide .cg-row { font-size: 13px; color: var(--tx2); margin-top: 5px; }
.card-guide .cg-row b { color: var(--tx); }
.card-guide .cg-gly { font-weight: 800; color: #fff; }
.suit-c { color: #38b56a; } .suit-d { color: #4789f2; } .suit-h { color: #e0514e; } .suit-s { color: #cdd3df; }
.card-guide .suit-c, .card-guide .suit-d, .card-guide .suit-h, .card-guide .suit-s { font-size: 15px; }

/* sub-navegação de Trainer (Push/Fold | vs Bot) */
.subnav { display: flex; gap: 8px; margin: 0 2px 16px; flex-wrap: wrap; }
.subnav-btn { display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px; border-radius: 11px; cursor: pointer;
  font: inherit; font-size: 13.5px; font-weight: 600; color: var(--tx2); background: var(--panel2); border: 1px solid var(--line); }
.subnav-btn .ic-svg { display: inline-block; }
.subnav-btn.on { color: #fff; background: rgba(124, 77, 255, .16); border-color: rgba(124, 77, 255, .45); }
.subnav-btn.locked { opacity: .7; }
.subnav-btn.locked:hover { opacity: 1; }
.subnav-btn .soon { margin-left: 2px; }
/* controles push/fold — tipo de mesa em cima · posição + stack lado a lado */
.pf-tablerow { text-align: center; margin-bottom: 18px; padding-bottom: 16px; border-bottom: 1px solid var(--line); }
.pf-tablerow .field { margin-bottom: 8px; }
.pf-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: center; }
.pf-col2 { min-width: 0; }
.pf-col2 .pos-ring { margin: 8px auto 0; }
.stack-chips { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin-top: 10px; }
.stack-chips .stack-chip { text-align: center; padding: 6px 4px; }
@media (max-width: 820px) {
  .pf-grid2 { grid-template-columns: 1fr; gap: 18px; }
}
.ctrl-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.ctrl-row .field { margin: 0; }
.segmented { display: inline-flex; background: rgba(255, 255, 255, .04); border: 1px solid var(--line); border-radius: 10px; padding: 3px; gap: 2px; }
.seg { padding: 7px 14px; border-radius: 8px; border: none; background: transparent; color: var(--tx2); font: inherit; font-size: 13px; font-weight: 600; cursor: pointer; }
.seg:hover { color: var(--tx); }
.seg.on { background: rgba(124, 77, 255, .16); color: #fff; box-shadow: inset 0 0 0 1px rgba(124, 77, 255, .4); }
.stack-chip { padding: 6px 12px; border-radius: 20px; border: 1px solid var(--line2); background: transparent; color: var(--tx2); font: inherit; font-size: 12.5px; font-weight: 700; cursor: pointer; }
.stack-chip:hover { color: var(--tx); border-color: var(--violet); }
.stack-chip.on { background: rgba(124, 77, 255, .18); color: #fff; border-color: var(--violet); }
/* anel de posições clicável */
.pos-ring { position: relative; width: 340px; max-width: 100%; aspect-ratio: 1.55 / 1; margin: 8px 0 4px; }
.pos-ring::before { content: ''; position: absolute; inset: 10% 6%; border-radius: 50%; border: 1.5px dashed var(--line2); }
.pos-node { position: absolute; transform: translate(-50%, -50%); min-width: 42px; padding: 6px 9px; border-radius: 9px;
  border: 1px solid var(--line2); background: var(--panel2); color: var(--tx2); font: inherit; font-size: 11.5px; font-weight: 700; cursor: pointer; transition: .12s; }
.pos-node:hover { color: #fff; border-color: var(--violet); }
.pos-node.on { background: linear-gradient(140deg, var(--violet), var(--violet-deep)); color: #fff; border-color: transparent; box-shadow: 0 4px 14px var(--glow); }
.pos-ring-center { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); font-size: 11px; font-weight: 700; color: var(--tx3); letter-spacing: .05em; }

/* ---- Trainer: mesa de poker ---- */
.trainer-card { padding: 24px; }
.ptable { position: relative; width: 100%; max-width: 640px; aspect-ratio: 1.62 / 1; margin: 0 auto 58px; }
:root { --felt-a: #2d2447; --felt-b: #1c1531; --felt-c: #120d1d; --felt-glow: rgba(170, 130, 255, .13); }
html.felt-green { --felt-a: #1f5a3a; --felt-b: #143f29; --felt-c: #0b2417; --felt-glow: rgba(120, 255, 180, .10); }
html.felt-blue { --felt-a: #234a86; --felt-b: #15315e; --felt-c: #0c1d3a; --felt-glow: rgba(120, 170, 255, .12); }
html.felt-red { --felt-a: #6a2230; --felt-b: #471722; --felt-c: #270c13; --felt-glow: rgba(255, 120, 140, .10); }
html.felt-dark { --felt-a: #2a2e36; --felt-b: #1b1e24; --felt-c: #101216; --felt-glow: rgba(255, 255, 255, .06); }
.felt { position: absolute; inset: 6% 2%; border-radius: 50%/50%;
  background:
    radial-gradient(ellipse at 50% 30%, var(--felt-glow), transparent 56%),
    radial-gradient(ellipse at 50% 52%, var(--felt-a) 0%, var(--felt-b) 56%, var(--felt-c) 100%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
  background-blend-mode: normal, normal, overlay;
  border: 2px solid rgba(255, 255, 255, .12);
  box-shadow: inset 0 0 72px rgba(0, 0, 0, .6), inset 0 0 0 10px rgba(255, 255, 255, .03), 0 14px 44px rgba(0, 0, 0, .55); }
/* deck de 2 cores (paus=preto, ouros=vermelho) */
html.deck-2color .pcard.club .pc-r, html.deck-2color .pcard.club .big, html.deck-2color .pcard.club .suit, html.deck-2color .pcard.club .idx { color: #15111f; }
html.deck-2color .pcard.diam .pc-r, html.deck-2color .pcard.diam .big, html.deck-2color .pcard.diam .suit, html.deck-2color .pcard.diam .idx { color: #d8323f; }
html.deck-2color .pc.club { color: #1a1a22; }
html.deck-2color .pc.diam { color: #d8323f; }
/* deck FUNDO COLORIDO (4 cores, texto branco) */
html.deck-colored .pcard.spade { background: linear-gradient(160deg, #404856, #20262f); }
html.deck-colored .pcard.heart { background: linear-gradient(160deg, #e5544f, #bb302d); }
html.deck-colored .pcard.diam { background: linear-gradient(160deg, #4789f2, #2360d4); }
html.deck-colored .pcard.club { background: linear-gradient(160deg, #3cbb6d, #1c8a48); }
html.deck-colored .pcard .idx, html.deck-colored .pcard .big, html.deck-colored .pcard .suit { color: #fff; }
html.deck-colored .pcard .suit { opacity: .3; }
html.deck-colored .pc { color: #fff; }
html.deck-colored .pc.spade { background: linear-gradient(165deg, #3c434f, #232932); }
html.deck-colored .pc.heart { background: linear-gradient(165deg, #e0514e, #bf322f); }
html.deck-colored .pc.diam { background: linear-gradient(165deg, #3f86f0, #2360d4); }
html.deck-colored .pc.club { background: linear-gradient(165deg, #38b56a, #1d8a49); }
/* barra de tema da mesa */
.theme-bar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 12px; padding: 10px 12px; background: var(--panel2); border: 1px solid var(--line); border-radius: 12px; }
.tb-label { font-size: 12px; color: var(--tx3); font-weight: 600; margin-left: 4px; }
.felt-sw { width: 24px; height: 24px; border-radius: 7px; border: 2px solid transparent; cursor: pointer; padding: 0; }
.felt-sw.on { border-color: #fff; box-shadow: 0 0 0 2px rgba(124, 77, 255, .4); }
.felt-sw.felt-purple { background: #2d2447; } .felt-sw.felt-green { background: #1f5a3a; } .felt-sw.felt-blue { background: #234a86; } .felt-sw.felt-red { background: #6a2230; } .felt-sw.felt-dark { background: #2a2e36; }
/* avatar do jogador na mesa */
.nameplate.with-av { flex-direction: row; align-items: center; gap: 7px; }
.np-txt { display: flex; flex-direction: column; align-items: center; }
.seat-av { width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0; display: grid; place-items: center;
  background: #2a2f3a; color: var(--tx3); font-size: 10px; font-weight: 800; background-size: cover; background-position: center; }
.seat-av.me { background: var(--violet-deep); color: #fff; box-shadow: 0 0 0 2px var(--violet); }
.seat-av.img { box-shadow: 0 0 0 2px var(--violet); }
/* editor de avatar */
.av-wrap { position: relative; width: 220px; height: 220px; margin: 6px auto 0; }
.av-canvas { display: block; border-radius: 10px; touch-action: none; cursor: grab; }
.av-canvas:active { cursor: grabbing; }
.av-circle { position: absolute; inset: 0; border-radius: 50%; border: 2px solid var(--violet); box-shadow: 0 0 0 999px rgba(10, 8, 16, .55); pointer-events: none; }
.felt-logo { position: absolute; inset: 0; display: grid; place-items: center; font-size: 64px; color: rgba(163, 133, 255, .06); }
.pot { position: absolute; left: 50%; top: 34%; transform: translate(-50%, -50%); font-size: 12px; font-weight: 700;
  color: var(--violet-br); background: rgba(124, 77, 255, .14); border: 1px solid var(--line2); padding: 4px 12px; border-radius: 20px; }
.seat { position: absolute; transform: translate(-50%, -50%); display: flex; flex-direction: column; align-items: center; gap: 5px; }
.nameplate { background: rgba(12, 9, 19, .92); border: 1px solid var(--line); border-radius: 9px; padding: 5px 9px; min-width: 78px;
  display: flex; flex-direction: column; align-items: center; gap: 1px; }
.nameplate.hero { border-color: var(--violet); box-shadow: 0 0 0 2px rgba(124, 77, 255, .3), 0 6px 18px var(--glow); }
.posbadge { font-size: 9.5px; font-weight: 800; letter-spacing: .04em; color: #fff; background: var(--violet-deep);
  padding: 1px 7px; border-radius: 5px; }
.posbadge.dim { background: #2b2440; color: var(--tx2); }
.np-name { font-size: 11px; font-weight: 700; color: var(--tx); margin-top: 2px; }
.np-stack { font-size: 10px; color: var(--green); font-weight: 700; }
.hero-cards { display: flex; gap: 4px; }
.seat:not(.hero) .nameplate { opacity: .62; transform: scale(.92); }

.trainer-q { text-align: center; font-size: 14px; color: var(--tx2); margin: 14px 0 12px; font-weight: 600; }
.trainer-actions { display: flex; gap: 12px; justify-content: center; }
.tbtn { border: none; border-radius: 13px; padding: 14px 30px; min-width: 150px; cursor: pointer; font: inherit;
  display: flex; flex-direction: column; align-items: center; gap: 1px; transition: .12s; }
.tbtn b { font-size: 16px; font-weight: 800; letter-spacing: .02em; }
.tbtn small { font-size: 11px; opacity: .85; }
.tbtn:hover { transform: translateY(-2px); }
.tbtn.fold { background: linear-gradient(140deg, #3a3350, #2a2440); color: var(--tx); border: 1px solid var(--line2); }
.tbtn.shove { background: linear-gradient(140deg, var(--violet), var(--violet-deep)); color: #fff; box-shadow: 0 6px 20px var(--glow); }
.trainer-feedback { text-align: center; font-size: 15px; font-weight: 700; min-height: 24px; margin-top: 16px; }

/* trainer: layout 2 colunas + painéis laterais (estilo GTO Base) */
.trainer-layout { display: flex; gap: 20px; align-items: flex-start; }
.trainer-main { flex: 1.5; min-width: 0; }
.trainer-side { flex: 1; min-width: 268px; display: flex; flex-direction: column; gap: 12px; }
.side-card { background: var(--panel2); border: 1px solid var(--line); border-radius: 12px; padding: 14px 16px; }
.side-card h5 { margin: 0 0 11px; font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: var(--tx3); font-weight: 700; }
.outs-cards { flex-wrap: wrap; gap: 4px; margin-top: 8px; }

/* outs na coluna principal do replay */
.replay-outs { margin-top: 12px; background: var(--panel2); border: 1px solid var(--line); border-radius: 12px; padding: 13px 15px; }
.replay-outs .ro-head { font-size: 14px; color: var(--tx); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; line-height: 1.4; }
.replay-outs .ro-head.ahead { color: var(--green); }
.replay-outs .ro-head.dead { color: var(--tx2); }
.replay-outs .ro-cards { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 9px; }

/* ===== Modo Clip (9:16) ===== */
.clip-overlay { position: fixed; inset: 0; z-index: 200; background: #05060a; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; padding: 16px; }
.clip-wrap { position: relative; }
.clip-stage { position: absolute; top: 0; left: 0; width: 1080px; height: 1920px; transform-origin: top left; overflow: hidden; border-radius: 20px;
  background: radial-gradient(120% 80% at 50% 16%, #1d1730, transparent 60%), linear-gradient(160deg, #0d1f17, #0a1a14 45%, #08120e); }
.clip-top { position: absolute; top: 52px; left: 0; right: 0; display: flex; flex-direction: column; align-items: center; gap: 12px; z-index: 3; }
.clip-bug { display: flex; align-items: center; gap: 12px; background: rgba(10,12,16,.6); border: 1px solid rgba(255,255,255,.15); padding: 12px 26px; border-radius: 999px; }
.clip-spade { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 10px; background: linear-gradient(140deg, #a98bff, #7c4dff); font-size: 25px; color: #fff; font-weight: 900; }
.clip-wm { font-size: 27px; font-weight: 900; color: #fff; } .clip-wm b { color: #c9b3ff; }
.clip-tourn { font-size: 19px; color: #dfe3ea; font-weight: 600; background: rgba(124,77,255,.2); border: 1px solid rgba(124,77,255,.4); padding: 6px 18px; border-radius: 999px; }
.clip-tablewrap { position: absolute; top: 300px; left: 40px; right: 40px; z-index: 2; }
.clip-stage .ptable { max-width: 1000px; margin: 0 auto; }
.clip-cap { position: absolute; bottom: 250px; left: 40px; right: 40px; text-align: center; z-index: 3; }
.clip-res { font-size: 42px; font-weight: 900; color: #fff; }
.clip-res.pos { color: #3fce9a; } .clip-res.neg { color: #ef5a5a; }
.clip-note { font-size: 21px; color: #cdd2db; margin-top: 12px; line-height: 1.35; }
.clip-cta { position: absolute; bottom: 72px; left: 0; right: 0; display: flex; justify-content: center; z-index: 3; }
.clip-cta span { font-size: 23px; font-weight: 800; color: #fff; background: linear-gradient(140deg, #a98bff, #7c4dff); padding: 14px 30px; border-radius: 999px; box-shadow: 0 8px 30px rgba(124,77,255,.5); }
.clip-ctrls { display: flex; gap: 14px; align-items: center; z-index: 201; }
.eq-badge { position: absolute; bottom: -8px; left: 50%; transform: translateX(-50%); font-size: 10px; font-weight: 800;
  color: #06231a; border-radius: 6px; padding: 2px 8px; box-shadow: 0 2px 8px rgba(0, 0, 0, .45); white-space: nowrap; }
.hero-cards { position: relative; }
.strat-row { display: flex; align-items: center; gap: 10px; font-size: 13px; margin-bottom: 8px; }
.strat-row > span:first-child { width: 44px; color: var(--tx2); font-weight: 600; }
.strat-bar { flex: 1; height: 8px; border-radius: 5px; background: rgba(255, 255, 255, .07); overflow: hidden; }
.strat-bar > i { display: block; height: 100%; border-radius: 5px; }
@media (max-width: 920px) { .trainer-layout { flex-direction: column; } .trainer-side { width: 100%; } }

/* ---- Misc ---- */
.pill { display: inline-block; padding: 4px 12px; border-radius: 20px; font-size: 12px; font-weight: 700;
  background: rgba(124, 77, 255, .12); border: 1px solid var(--line2); color: var(--violet-br); }
.checkitem { display: flex; gap: 12px; align-items: center; padding: 12px 4px; border-bottom: 1px solid var(--line); cursor: pointer; }
.checkitem:last-child { border-bottom: none; }
.checkbox { width: 23px; height: 23px; border-radius: 7px; border: 2px solid var(--line2); flex-shrink: 0; display: grid; place-items: center; font-size: 14px; color: transparent; transition: .12s; }
.checkitem:hover .checkbox { border-color: var(--violet); }
.checkitem.done .checkbox { background: var(--violet-deep); border-color: var(--violet-deep); color: #fff; }
.checkitem.done .lbl { color: var(--tx3); text-decoration: line-through; }

/* ---- Brand assets (Figma) — aplicados quando os arquivos existem ---- */
.brand .logo.has-img { background: none; box-shadow: none; padding: 0; }
.brand .logo .logo-img { width: 100%; height: 100%; object-fit: contain; display: block; border-radius: 9px; }
body.has-felt .felt {
  background:
    linear-gradient(rgba(20, 15, 32, .55), rgba(20, 15, 32, .55)),
    url('../brand/felt.jpg') center/cover;
}
body.has-herobg::before {
  content: ''; position: fixed; inset: 0 0 auto 0; height: 360px; z-index: -1; opacity: .5; pointer-events: none;
  background: url('../brand/hero-bg.png') top center/cover no-repeat;
  -webkit-mask-image: linear-gradient(#000, transparent); mask-image: linear-gradient(#000, transparent);
}
.welcome-illu { max-width: 300px; width: 64%; height: auto; margin: 0 auto 18px; display: block; animation: floaty 7s ease-in-out infinite; }
@keyframes floaty { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-9px); } }
.hero-deco .hero-glass { animation: floaty 6s ease-in-out infinite; }
@media (prefers-reduced-motion: reduce) { .welcome-illu, .hero-deco .hero-glass { animation: none; } }

/* ---- Modal + Replayer (mesa visual) ---- */
.modal-overlay { position: fixed; inset: 0; background: rgba(5, 4, 9, .74); backdrop-filter: blur(4px); z-index: 200;
  display: flex; align-items: flex-start; justify-content: center; padding: 24px; overflow: auto; }
.modal { background: var(--panel); border: 1px solid var(--line2); border-radius: 16px; padding: 20px 22px; width: 100%;
  max-width: 680px; box-shadow: 0 24px 70px rgba(0, 0, 0, .65); margin: auto; }
.modal-wide { max-width: 1000px; }
.modal-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.modal-head h3 { margin: 0; }
.modal-x { background: none; border: none; color: var(--tx2); font-size: 18px; cursor: pointer; padding: 4px 8px; }
.modal-x:hover { color: #fff; }
.btn-mesa { background: rgba(124, 77, 255, .14); border: 1px solid var(--line2); color: var(--violet-br); border-radius: 8px;
  padding: 4px 10px; font: inherit; font-size: 12px; font-weight: 700; cursor: pointer; white-space: nowrap; }
.btn-mesa:hover { background: rgba(124, 77, 255, .26); color: #fff; }

.replay-layout { display: flex; gap: 18px; align-items: flex-start; margin-top: 16px; }
.replay-main { flex: 1.6; min-width: 0; }
.replay-side { flex: 1; min-width: 240px; display: flex; flex-direction: column; gap: 12px; }
.replay-table { max-width: 100%; aspect-ratio: 1.7 / 1; margin-top: 34px; }
.replay-table .pcard { width: 40px; height: 56px; }
.replay-table .pcard .idx .r { font-size: 12px; } .replay-table .pcard .idx .s { font-size: 9px; }
.replay-table .pcard .big { font-size: 21px; } .replay-table .pcard .suit { font-size: 18px; }
.replay-table .nameplate { min-width: 66px; padding: 3px 6px; }
.replay-table .np-name { font-size: 9px; } .replay-table .np-stack { font-size: 9px; } .replay-table .posbadge { font-size: 8.5px; }
.replay-table .board-cards { position: absolute; left: 50%; top: 52%; transform: translate(-50%, -50%); display: flex; gap: 5px; align-items: center; }
.replay-table .pot { top: 26%; }
.pcard.back { background: repeating-linear-gradient(45deg, #b23b3b, #b23b3b 5px, #8c2c2c 5px, #8c2c2c 10px); border: 1px solid rgba(255, 255, 255, .14); }
/* fichas de poker (CSS, sem imagem) */
.chip-coin { width: 16px; height: 16px; border-radius: 50%; flex-shrink: 0;
  background: radial-gradient(circle at 50% 38%, #b79bff 0%, #7c4dff 55%, #5a32cc 100%);
  border: 2px dashed rgba(255, 255, 255, .75); box-shadow: 0 2px 5px rgba(0, 0, 0, .5); }
.chip-coin.big { width: 20px; height: 20px; }
/* ficha empilhada (várias fichas) */
.chip-coin.stacked { width: 17px; height: 17px; border: 2px dashed rgba(255, 255, 255, .7);
  box-shadow: 0 -3px 0 -1px rgba(0, 0, 0, .35), 0 -2px 0 0 currentColor, 0 2px 4px rgba(0, 0, 0, .55); }
.bet-chip { position: absolute; transform: translate(-50%, -50%); display: flex; align-items: center; gap: 6px;
  background: rgba(8, 6, 12, .9); border: 1px solid var(--line2); border-radius: 20px; padding: 3px 10px 3px 4px;
  font-size: 11px; font-weight: 700; color: #fff; z-index: 4; white-space: nowrap; box-shadow: 0 3px 10px rgba(0, 0, 0, .55); animation: chipIn .3s ease; }
.bet-chip .chip-amt { line-height: 1; }
.pot-chip { position: absolute; left: 50%; top: 26%; transform: translate(-50%, -50%); display: flex; align-items: center; gap: 7px;
  font-size: 12px; font-weight: 700; color: var(--violet-br); background: rgba(124, 77, 255, .14);
  border: 1px solid var(--line2); padding: 4px 12px 4px 5px; border-radius: 20px; }
.seat.winner { animation: winGlow 1s ease infinite alternate; }
.seat.winner .nameplate { border-color: #e8c24a; box-shadow: 0 0 0 2px rgba(232, 194, 74, .45), 0 0 18px rgba(232, 194, 74, .4); }
.win-amt { position: absolute; top: -22px; left: 50%; transform: translateX(-50%); font-size: 13px; font-weight: 800;
  color: #ffd968; text-shadow: 0 1px 3px rgba(0, 0, 0, .6); animation: winPop .5s ease; white-space: nowrap; }
.play-btn { background: rgba(124, 77, 255, .16) !important; box-shadow: inset 0 0 0 1px rgba(124, 77, 255, .4); }
/* sinais de ação (3-bet, call, fold...) + jogador que desistiu */
.act-tag { font-size: 9px; font-weight: 800; letter-spacing: .04em; padding: 1px 7px; border-radius: 5px; color: #fff;
  margin: 1px 0; box-shadow: 0 2px 6px rgba(0, 0, 0, .45); z-index: 2; white-space: nowrap; }
.act-tag.raise { background: var(--act-raise); }
.act-tag.call { background: var(--blue); }
.act-tag.check { background: #5a6473; }
.act-tag.fold { background: #353a45; color: var(--tx3); }
.act-tag.allin { background: linear-gradient(140deg, #e8c24a, #d89a2a); color: #3a2c00; }
.act-tag.post { background: #43395e; color: var(--violet-br); }
.seat.folded { opacity: .4; }
.seat.folded .pcard { filter: grayscale(.85) brightness(.6); }
@keyframes chipIn { from { opacity: 0; transform: translate(-50%, -50%) scale(.4); } to { opacity: 1; transform: translate(-50%, -50%) scale(1); } }
@keyframes cardIn { from { opacity: 0; transform: translateY(-8px) scale(.8); } to { opacity: 1; transform: none; } }
.card-in { animation: cardIn .35s ease backwards; }
@keyframes winGlow { from { filter: brightness(1); } to { filter: brightness(1.15); } }
@keyframes winPop { from { opacity: 0; transform: translateX(-50%) translateY(8px) scale(.6); } to { opacity: 1; transform: translateX(-50%) translateY(0) scale(1); } }
@media (prefers-reduced-motion: reduce) { .card-in, .bet-chip, .win-amt, .seat.winner { animation: none; } }
.dealer-btn { position: absolute; top: -7px; right: -7px; width: 18px; height: 18px; border-radius: 50%; background: #e8c24a;
  color: #3a2c00; font-size: 10px; font-weight: 800; display: grid; place-items: center; box-shadow: 0 2px 6px rgba(0, 0, 0, .55); }
.street-stepper { display: flex; gap: 6px; justify-content: center; margin-top: 12px; flex-wrap: wrap; }
.street-stepper .seg { border: 1px solid var(--line2); }
.street-stepper .seg:disabled { opacity: .35; cursor: default; }
.replay-result { text-align: center; font-weight: 700; margin-top: 12px; font-size: 15px; }
.replay-result.pos { color: var(--green); } .replay-result.neg { color: var(--red); }
.replay-log { display: flex; flex-direction: column; gap: 3px; max-height: 320px; overflow: auto; }
.rl-street { font-size: 10px; text-transform: uppercase; letter-spacing: .06em; color: var(--violet); font-weight: 700; margin-top: 8px; }
.rl-act { display: flex; gap: 8px; font-size: 12.5px; color: var(--tx2); }
.rl-act.hero { color: #fff; font-weight: 600; }
.rl-actor { min-width: 56px; color: var(--tx3); }
.rl-act.hero .rl-actor { color: var(--violet); }
/* jogador da vez (playback ação-a-ação) */
.seat.acting .nameplate { border-color: var(--violet); box-shadow: 0 0 0 2px rgba(124, 77, 255, .55), 0 0 20px var(--glow); }
.seat.acting { animation: actPulse 1.1s ease infinite alternate; z-index: 3; }
@keyframes actPulse { from { filter: brightness(1); } to { filter: brightness(1.18); } }
.replay-turn { text-align: center; font-size: 13px; font-weight: 700; color: var(--violet-br); margin: 10px 0 2px; }
.playbar { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 10px; }
.pb-btn { background: var(--panel2); border: 1px solid var(--line2); color: var(--tx); border-radius: 9px; padding: 8px 14px;
  font: inherit; font-size: 13px; font-weight: 700; cursor: pointer; }
.pb-btn:hover { background: var(--panel3); }
.pb-btn.play { background: linear-gradient(140deg, var(--violet), var(--violet-deep)); border-color: transparent; color: #fff; min-width: 130px; }
.pb-step { font-size: 11.5px; color: var(--tx3); margin-left: 6px; font-variant-numeric: tabular-nums; }
.rl-act.now { background: rgba(124, 77, 255, .18); border-radius: 5px; padding: 1px 4px; margin: 0 -4px; }
@media (prefers-reduced-motion: reduce) { .seat.acting { animation: none; } }
.sum-line { font-size: 12.5px; margin: 5px 0; line-height: 1.45; }
.sum-line.good { color: var(--green); }
.sum-line.bad { color: var(--amber); }
.fly-chip { position: absolute; transform: translate(-50%, -50%); z-index: 4; pointer-events: none;
  transition: left .85s cubic-bezier(.4, .8, .3, 1), top .85s cubic-bezier(.4, .8, .3, 1), opacity .85s ease; }
@media (prefers-reduced-motion: reduce) { .fly-chip { display: none; } }
@media (max-width: 860px) { .replay-layout { flex-direction: column; } .replay-side { width: 100%; } }

/* glossário */
.glossary { min-width: 240px; }
.glossary .gl-item { display: flex; gap: 8px; padding: 6px 0; border-bottom: 1px solid var(--line); font-size: 12.5px; }
.glossary .gl-item:last-child { border-bottom: none; }
.gl-term { font-weight: 700; color: var(--violet-br); min-width: 104px; flex-shrink: 0; }
.gl-def { color: var(--tx2); }

.hidden { display: none !important; }
.flex { display: flex; } .between { justify-content: space-between; } .ac { align-items: center; }
.gap { gap: 12px; } .wrap-f { flex-wrap: wrap; } .mt { margin-top: 16px; } .mb { margin-bottom: 16px; }

/* ---- Responsivo ---- */
@media (max-width: 1080px) {
  .top-in { flex-wrap: wrap; }
  .tabs { order: 3; width: 100%; justify-content: center; }
  .brand { margin-right: auto; }
}
@media (max-width: 860px) {
  .stats { grid-template-columns: repeat(3, 1fr); }
  .scores { grid-template-columns: repeat(2, 1fr); }
  .tab { padding: 8px 10px; }
  .tab .ti { font-size: 13px; }
}
@media (max-width: 540px) {
  .stats { grid-template-columns: repeat(2, 1fr); }
  .row { flex-direction: column; }
  .tabs { overflow-x: auto; justify-content: flex-start; }
}

/* ============================================================================
   Reforma gráfica (passe 2): textura sutil + profundidade
   ========================================================================== */
/* grão de filme bem leve sobre o fundo, dá aspecto premium sem atrapalhar leitura */
body::after {
  content: ''; position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: .04; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
/* aurora um pouco mais viva */
body::before {
  background:
    radial-gradient(680px 560px at 88% -6%, rgba(124, 77, 255, .22), transparent 60%),
    radial-gradient(540px 540px at 6% 6%, rgba(91, 140, 255, .10), transparent 55%),
    radial-gradient(620px 520px at 50% 116%, rgba(190, 80, 200, .09), transparent 60%);
}
/* cards: respiro de luz no topo + leve realce no hover */
.card { transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease; }
.card:hover { border-color: var(--line2); box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 20px 44px rgba(0,0,0,.5); }
.stat:hover .v { color: var(--violet-br); }

/* ============================================================================
   Equity — seletor visual de cartas
   ========================================================================== */
.eq-slots { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; min-height: 52px; margin-top: 6px; }
.eq-card { background: none; border: none; padding: 0; cursor: pointer; line-height: 0; transition: transform .12s; }
.eq-card .pc { font-size: 16px; min-width: 36px; padding: 8px 9px; margin: 0; }
.eq-card:hover { transform: translateY(-2px); filter: brightness(.93); }
.eq-add { width: 48px; height: 42px; border-radius: 9px; cursor: pointer; display: grid; place-items: center;
  color: var(--violet-br); background: rgba(124, 77, 255, .1); border: 1px dashed rgba(124, 77, 255, .45); }
.eq-add:hover { background: rgba(124, 77, 255, .2); color: #fff; }
.picker { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; }
.picker-grid-box { display: flex; flex-direction: column; gap: 6px; }
.picker-foot { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line2); }
.picker-foot .btn { padding: 9px 22px; }
.picker-row { display: grid; grid-template-columns: repeat(13, 1fr); gap: 5px; }
.pick-card { background: none; border: none; padding: 0; cursor: pointer; line-height: 0; transition: transform .1s; }
.pick-card .pc { font-size: 13px; min-width: 100%; padding: 9px 1px; margin: 0; }
.pick-card:hover { transform: translateY(-2px); }
.pick-card.used { opacity: .22; cursor: not-allowed; }

/* ============================================================================
   Estudo gamificado (nível / XP / anotações)
   ========================================================================== */
.level-card { display: flex; align-items: center; gap: 18px; margin-bottom: 18px; padding: 18px 22px; border-radius: 16px;
  background: linear-gradient(135deg, rgba(124, 77, 255, .18), rgba(124, 77, 255, .04)); border: 1px solid rgba(124, 77, 255, .3); }
.level-badge { width: 64px; height: 64px; border-radius: 16px; flex: 0 0 auto; color: #fff; display: flex; flex-direction: column;
  align-items: center; justify-content: center; background: linear-gradient(140deg, var(--violet), var(--violet-deep)); box-shadow: 0 6px 18px var(--glow); }
.lv-num { font-size: 26px; font-weight: 800; line-height: 1; }
.lv-lbl { font-size: 8px; font-weight: 700; letter-spacing: .12em; opacity: .85; margin-top: 2px; }
.level-main { flex: 1; min-width: 0; }
.level-title { font-size: 18px; font-weight: 800; margin-bottom: 8px; letter-spacing: -.01em; }
.xpbar { height: 12px; border-radius: 8px; background: rgba(255, 255, 255, .08); overflow: hidden; margin-bottom: 6px; }
.xpbar-fill { height: 100%; border-radius: 8px; background: linear-gradient(90deg, var(--violet), var(--violet-br)); transition: width .5s ease; }
.xp-tag { margin-left: auto; font-size: 10px; font-weight: 700; color: var(--violet-br); white-space: nowrap;
  background: rgba(124, 77, 255, .14); border: 1px solid rgba(124, 77, 255, .3); padding: 2px 8px; border-radius: 20px; opacity: 0; transition: opacity .15s; }
.checkitem:hover .xp-tag { opacity: 1; }
.checkitem.done .xp-tag { opacity: .35; }
.notes-area { width: 100%; min-height: 110px; resize: vertical; background: var(--panel2); border: 1px solid var(--line2);
  border-radius: 12px; color: var(--tx); font: inherit; font-size: 14px; line-height: 1.5; padding: 12px 14px; }
.notes-area:focus { outline: none; border-color: rgba(124, 77, 255, .5); box-shadow: 0 0 0 3px rgba(124, 77, 255, .12); }

/* ============================================================================
   Tutorial / tour guiado
   ========================================================================== */
.tour-overlay { align-items: center; }
.tour-modal { max-width: 460px; text-align: center; }
.tour-ic { width: 64px; height: 64px; margin: 4px auto 14px; border-radius: 16px; display: grid; place-items: center;
  color: var(--violet-br); background: rgba(124, 77, 255, .12); border: 1px solid rgba(124, 77, 255, .3); }
.tour-step { font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--tx3); margin-bottom: 4px; }
.tour-modal h3 { font-size: 20px; margin-bottom: 8px; }
.tour-modal p { max-width: 380px; margin: 0 auto 16px; line-height: 1.6; }
.tour-dots { display: flex; gap: 6px; justify-content: center; margin-bottom: 18px; }
.tour-dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(255, 255, 255, .18); transition: .2s; }
.tour-dot.on { background: var(--violet); width: 18px; border-radius: 4px; }
.tour-nav { display: flex; align-items: center; justify-content: space-between; gap: 10px; }

/* ============================================================================
   Rating de decisões (Best / Correct / Inaccuracy / Wrong / Blunder)
   ========================================================================== */
.rate-row { display: flex; align-items: center; gap: 10px; margin-bottom: 9px; font-size: 13px; }
.rate-dot { width: 11px; height: 11px; border-radius: 3px; flex: 0 0 auto; }
.rate-lbl { width: 92px; flex: 0 0 auto; font-weight: 600; }
.rate-bar { flex: 1; height: 9px; border-radius: 6px; background: rgba(255, 255, 255, .07); overflow: hidden; }
.rate-bar i { display: block; height: 100%; border-radius: 6px; }
.rate-n { width: 86px; text-align: right; color: var(--tx2); font-variant-numeric: tabular-nums; }
.rate-badge { font-size: 11px; font-weight: 800; letter-spacing: .03em; padding: 4px 11px; border-radius: 20px;
  border: 1px solid; background: rgba(255, 255, 255, .04); text-transform: uppercase; white-space: nowrap; }

/* metas diárias auto-rastreadas */
.stat-ico { font-size: 34px; font-weight: 800; display: inline-flex; align-items: center; justify-content: center; gap: 6px; }
.stat-ico .ic-svg { width: 26px; height: 26px; }
.goal { display: flex; align-items: center; gap: 12px; padding: 12px 4px; border-bottom: 1px solid var(--line); }
.goal:last-of-type { border-bottom: none; }
.goal-ic { width: 32px; height: 32px; border-radius: 9px; display: grid; place-items: center; flex: 0 0 auto; color: var(--tx2); background: rgba(255, 255, 255, .05); }
.goal.done .goal-ic { color: var(--green); background: rgba(63, 206, 154, .14); }
.goal-main { flex: 1; min-width: 0; }
.goal-lbl { font-weight: 600; font-size: 14px; }
.goal.done .goal-lbl { color: var(--tx2); }
.goal-hint { font-size: 12px; color: var(--tx3); }
.goal-prog { font-variant-numeric: tabular-nums; font-weight: 700; font-size: 13px; color: var(--tx2); }
.goal.done .goal-prog { color: var(--green); }
.goal .xp-tag { opacity: .35; }
.goal.done .xp-tag { opacity: 0; }

/* conquistas (badges) do estudo */
.ach-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 12px; }
.ach { display: flex; align-items: center; gap: 12px; padding: 13px 16px; border-radius: 14px; background: var(--panel2); border: 1px solid var(--line); opacity: .5; }
.ach.on { opacity: 1; border-color: rgba(124, 77, 255, .4); background: linear-gradient(135deg, rgba(124, 77, 255, .12), rgba(124, 77, 255, .03)); }
.ach-ic { flex: 0 0 auto; display: flex; color: var(--tx2); }
.ach.on .ach-ic { color: var(--violet); }
.ach-lbl { flex: 1; font-size: 13px; font-weight: 600; }
.ach-st { flex: 0 0 auto; display: flex; color: var(--tx3); }
.ach.on .ach-st { color: var(--green); }


/* cards de ajuda/tutorial (equity etc.) */
.help-card { background: rgba(124,77,255,.07); border: 1px solid rgba(124,77,255,.22); border-radius: 14px; padding: 16px 20px; margin-bottom: 16px; }
.help-h { font-weight: 700; font-size: 15px; display: flex; align-items: center; gap: 7px; margin-bottom: 8px; color: var(--violet-br); }
.help-card p { color: var(--tx2); line-height: 1.55; }
.help-list { margin: 10px 0 0; padding-left: 18px; color: var(--tx2); display: flex; flex-direction: column; gap: 5px; }
.help-list li { line-height: 1.5; }
/* grade em notação s/o (padrão GTO) */
.pf-cell.so .pf-suit { font-size: 9px; opacity: .85; font-weight: 700; letter-spacing: .5px; }

/* drills salvos (Trainer) */
.drill-chip { display: inline-flex; align-items: center; gap: 6px; padding: 7px 12px; border-radius: 20px; cursor: pointer; font: inherit; font-size: 12.5px; font-weight: 600; color: var(--violet-br); background: rgba(124,77,255,.1); border: 1px solid rgba(124,77,255,.3); }
.drill-chip:hover { background: rgba(124,77,255,.2); color: #fff; }
.drill-x { font-size: 10px; opacity: .6; }
.drill-x:hover { opacity: 1; color: var(--red); }

/* ===== Auth (login/cadastro/perfil) ===== */
.auth-box { display: flex; flex-direction: column; gap: 8px; min-width: 300px; }
.auth-tabs { display: flex; gap: 6px; margin-bottom: 8px; }
.auth-tabs .at { flex: 1; background: var(--panel3); border: 1px solid var(--line2); color: var(--tx2); border-radius: 9px; padding: 9px; font-size: 13px; font-weight: 700; cursor: pointer; }
.auth-tabs .at.on { background: linear-gradient(140deg, var(--violet), var(--violet-deep)); color: #fff; border-color: transparent; }
.auth-l { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--tx3); font-weight: 700; margin-top: 4px; }
.auth-i { width: 100%; background: var(--panel3); border: 1px solid var(--line2); color: var(--tx); border-radius: 9px; padding: 11px 12px; font-size: 14px; }
.auth-i:focus { outline: none; border-color: var(--violet); }
.auth-go { margin-top: 12px; width: 100%; padding: 12px; font-size: 15px; }
.auth-msg { font-size: 13px; min-height: 4px; margin-top: 6px; }
.auth-msg.err { color: var(--red); }
.auth-msg.ok { color: var(--green); }
.auth-foot { font-size: 11px; color: var(--tx3); text-align: center; margin-top: 10px; }
.prof-row { display: flex; align-items: center; gap: 14px; }
.prof-av { width: 52px; height: 52px; border-radius: 13px; display: grid; place-items: center; font-weight: 900; font-size: 22px; color: #fff; background: linear-gradient(140deg, var(--violet), var(--violet-deep)); }
.prof-mail { font-weight: 700; color: var(--tx); }
.prof-plan { font-size: 13px; color: var(--tx2); margin-top: 2px; }
