:root{
  --bg:#0f1b24;
  --game:#152431;
  --panel:#1a2c38;
  --input:#0f212e;
  --tile:#2f4553;
  --tile-hover:#3a5161;
  --border:#2a4254;
  --blue:#1475e1;
  --blue-hover:#1267c7;
  --text:#fff;
  --muted:#b1bcca;
  --muted-2:#7a8a99;
  --green:#2bd47d;
  --red:#e9415f;
  --felt:#13222d;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);color:var(--text);min-height:100vh;
}
a{color:inherit;text-decoration:none}

/* ---- topbar ---- */
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 22px;border-bottom:1px solid var(--border);background:#11202b;
}
.back{color:var(--muted);font-size:14px;font-weight:500;transition:.15s}
.back:hover{color:var(--text)}
.logo{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:20px;letter-spacing:-.5px}
.logo .dot{color:var(--green)}
.balance{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1;
  background:var(--input);border:1px solid var(--border);border-radius:9px;padding:6px 13px}
.balance small{color:var(--muted-2);font-size:10px;text-transform:uppercase;letter-spacing:.5px}
.balance b{font-size:15px;color:var(--green);font-family:'Space Grotesk',sans-serif}

/* ---- layout do jogo ---- */
.game{
  display:flex;gap:0;max-width:1180px;margin:22px auto;background:var(--game);
  border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.03);
  min-height:560px;
}
.panel{
  width:300px;flex:0 0 300px;background:var(--panel);padding:16px;
  display:flex;flex-direction:column;gap:14px;
}
.board-wrap{flex:1;padding:22px;display:flex;flex-direction:column;gap:16px}

/* ---- campos ---- */
.field{display:flex;flex-direction:column;gap:7px}
.field-label{
  font-size:13px;color:var(--muted);font-weight:500;
  display:flex;justify-content:space-between;align-items:center;
}
.field-label .usd{color:var(--muted-2);font-size:12px}
.bet-row{display:flex;gap:8px}
.input-wrap{
  position:relative;flex:1;display:flex;align-items:center;
  background:var(--input);border:1px solid var(--border);border-radius:8px;
  transition:.15s;
}
.input-wrap:focus-within{border-color:var(--blue)}
.input-wrap.static{background:var(--input)}
.input-wrap .prefix{padding-left:12px;color:var(--muted-2);font-size:14px}
.input-wrap input{
  width:100%;background:transparent;border:none;outline:none;color:var(--text);
  font-family:inherit;font-size:14px;font-weight:600;padding:11px 12px;
}
.input-wrap input[readonly]{color:var(--muted)}
.chip{
  background:var(--input);border:1px solid var(--border);color:var(--text);
  border-radius:8px;padding:0 14px;font-weight:600;font-size:13px;cursor:pointer;
  font-family:inherit;transition:.15s;
}
.chip:hover{background:var(--tile)}

/* ---- botões ---- */
.btn-primary{
  background:var(--blue);color:#fff;border:none;border-radius:8px;
  padding:14px;font-weight:700;font-size:15px;cursor:pointer;font-family:inherit;
  transition:.15s;box-shadow:0 2px 0 rgba(0,0,0,.2);
}
.btn-primary:hover{background:var(--blue-hover)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}

.rules{
  font-size:12px;line-height:1.55;color:var(--muted-2);
  border-top:1px solid var(--border);padding-top:14px;margin-top:2px;
}
.rules b{color:var(--muted)}

/* ---- versus / estado ---- */
.versus{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--panel);border-radius:10px;padding:12px 18px;
}
.vs-player{display:flex;align-items:center;gap:8px;font-weight:600;font-size:15px;transition:.2s}
.vs-player .avatar{font-size:20px}
.vs-sep{font-size:13px;color:var(--muted);text-align:center;flex:1}
.vs-player.win{color:var(--green);text-shadow:0 0 12px rgba(43,212,125,.5)}
.vs-player.win .avatar{transform:scale(1.18)}
.vs-player.lost{color:var(--red)}

/* ---- mesa (felt) ---- */
.table{
  position:relative;flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:space-between;gap:14px;
  padding:26px 18px;border-radius:16px;
  background:
    radial-gradient(circle at 50% 42%,#1c3340,var(--felt) 72%);
  border:1px solid var(--border);
  box-shadow:inset 0 0 60px rgba(0,0,0,.4);
  overflow:hidden;
}

/* faixa central estilo casino */
.ribbon{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  display:flex;flex-direction:column;align-items:center;gap:5px;
  text-align:center;pointer-events:none;user-select:none;opacity:.55;
}
.ribbon-main{
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:13px;
  letter-spacing:2px;color:#cbb26b;
  padding:7px 26px;border-top:1px solid rgba(203,178,107,.5);
  border-bottom:1px solid rgba(203,178,107,.5);
}
.ribbon-sub{font-size:10px;letter-spacing:2px;color:var(--muted-2);font-weight:600}

/* ---- lugares (assentos) ---- */
.seat{
  position:relative;z-index:1;width:100%;max-width:560px;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:10px 14px;border-radius:14px;transition:.25s;
}
.seat.win{background:rgba(43,212,125,.07);box-shadow:0 0 26px rgba(43,212,125,.18)}
.seat.lost{opacity:.5}
.seat-head{display:flex;align-items:center;gap:12px}
.seat-name{
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;
  letter-spacing:.5px;color:var(--muted);text-transform:uppercase;
}
.seat.win .seat-name{color:var(--green)}

.total{
  min-width:38px;height:28px;padding:0 11px;border-radius:8px;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:16px;
  background:var(--input);border:1px solid var(--border);color:var(--text);
}
.seat.win .total{border-color:var(--green);color:var(--green)}
.total.bust{border-color:var(--red);color:var(--red)}

/* ---- mão e cartas ---- */
.hand{display:flex;justify-content:center;min-height:118px;padding-left:30px}
.hand .card{margin-left:-30px}

.card{
  position:relative;width:84px;height:118px;border-radius:9px;flex:0 0 auto;
  background:linear-gradient(160deg,#ffffff,#eef2f7);
  box-shadow:0 6px 16px rgba(0,0,0,.45);
  color:#16222d;
  animation:deal .32s cubic-bezier(.2,.8,.3,1.1) both;
}
.card.red{color:var(--red)}
.c-corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:1;font-weight:700}
.c-corner b{font-family:'Space Grotesk',sans-serif;font-size:16px}
.c-corner i{font-style:normal;font-size:13px;margin-top:1px}
.c-corner.tl{top:7px;left:8px}
.c-corner.br{bottom:7px;right:8px;transform:rotate(180deg)}
.c-pip{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:42px;line-height:1;
}

@keyframes deal{
  0%{opacity:0;transform:translateY(-26px) rotate(-9deg) scale(.9)}
  100%{opacity:1;transform:translateY(0) rotate(0) scale(1)}
}

/* ---- toast ---- */
.toast{
  position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(20px);
  background:var(--panel);border:1px solid var(--border);border-radius:12px;
  padding:14px 22px;font-weight:600;font-size:15px;opacity:0;pointer-events:none;
  transition:.3s;box-shadow:0 14px 40px rgba(0,0,0,.5);z-index:20;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.win{border-color:var(--green);color:var(--green)}
.toast.lose{border-color:var(--red);color:var(--red)}
.toast.push{border-color:var(--blue);color:#69b4ff}

@media(max-width:760px){
  .game{flex-direction:column;margin:14px;min-height:auto}
  .panel{width:100%;flex:none}
  .table{padding:18px 10px}
  .card{width:64px;height:90px}
  .c-corner b{font-size:13px}
  .c-pip{font-size:32px}
  .hand{min-height:92px;padding-left:24px}
  .hand .card{margin-left:-24px}
  .ribbon-main{font-size:11px;letter-spacing:1px;padding:6px 16px}
}
/* ---- mesa Blackjack inspirada na referência da pasta /blackjack ---- */
.board-wrap{background:var(--game)}
.versus{border:1px solid rgba(42,66,84,.72)}
.vs-player .avatar{width:30px;height:30px;display:grid;place-items:center;border-radius:8px;background:var(--input);border:1px solid var(--border);font-size:14px}
.vs-player.you .avatar{color:#70b7ff;border-color:rgba(20,117,225,.55)}
.table{min-height:500px;padding:24px 24px 20px;gap:12px;background:#0d202b;border:0;border-radius:12px;box-shadow:inset 0 0 42px rgba(2,12,18,.22)}
.table:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,117,225,.025),transparent 25%,transparent 75%,rgba(20,117,225,.025));pointer-events:none}
.deck-stack{position:absolute;right:30px;top:-9px;width:54px;height:70px;z-index:4}
.deck-stack i{position:absolute;inset:0;border-radius:6px;border:3px solid #e4edf5;background:linear-gradient(145deg,#1787f5,#0873dc);box-shadow:inset 0 0 0 2px rgba(255,255,255,.24),0 4px 8px rgba(0,0,0,.3)}
.deck-stack i:after{content:"";position:absolute;inset:8px;border:1px solid rgba(255,255,255,.28);border-radius:3px}
.deck-stack i:nth-child(1){transform:translateY(7px);opacity:.5}.deck-stack i:nth-child(2){transform:translateY(4px);opacity:.72}
.seat{max-width:620px;min-height:170px;gap:7px;padding:8px 14px;background:transparent;box-shadow:none}
.seat.win{background:transparent;box-shadow:none}.seat.win .hand{filter:drop-shadow(0 0 12px rgba(43,212,125,.24))}.seat.lost{opacity:.45}
.seat-head{display:flex;flex-direction:row-reverse;gap:7px;min-height:25px}
.seat-name{padding:4px 8px;border-radius:999px;background:#132c39;border:1px solid rgba(42,66,84,.75);font-size:9px;line-height:1;color:var(--muted-2)}
.total{min-width:30px;height:23px;padding:0 8px;border:0;border-radius:999px;background:#2d4451;font-size:12px;box-shadow:0 3px 8px rgba(0,0,0,.25)}
.seat.win .total{background:var(--green);color:#082217;border:0}.total.bust{background:var(--red);color:#fff;border:0}
.hand{min-height:124px;padding-left:30px;align-items:center}.hand .card{margin-left:-30px}
.card{width:84px;height:118px;border-radius:8px;box-shadow:0 5px 10px rgba(0,0,0,.36);border:1px solid rgba(255,255,255,.8)}
.ribbon{z-index:1;opacity:.58;gap:6px}
.ribbon:before,.ribbon:after{content:"";position:absolute;top:4px;width:36px;height:30px;background:#132e3c;z-index:-1}.ribbon:before{right:100%;clip-path:polygon(0 0,100% 0,88% 50%,100% 100%,0 100%,25% 50%)}.ribbon:after{left:100%;clip-path:polygon(0 0,100% 0,75% 50%,100% 100%,0 100%,12% 50%)}
.ribbon-main{min-width:270px;padding:8px 24px;border:0;border-radius:3px;background:#142f3d;box-shadow:0 3px 0 rgba(3,15,22,.3);color:#91a0ad;font-size:12px;letter-spacing:.5px}
.ribbon-sub{font-size:10px;letter-spacing:.6px;color:#738593}
@media(max-width:760px){.board-wrap{padding:14px}.table{min-height:430px;padding:18px 8px}.deck-stack{right:18px;width:43px;height:57px}.seat{min-height:145px}.card{width:64px;height:90px}.hand{min-height:94px;padding-left:24px}.hand .card{margin-left:-24px}.ribbon-main{min-width:220px;font-size:10px;padding:7px 15px}.ribbon-sub{font-size:8px}.seat-name{font-size:8px}}
@media(max-width:430px){.pname{display:none}.ribbon-main{min-width:176px;font-size:9px}.ribbon:before,.ribbon:after{width:25px}.seat{width:100%}}