@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ─── Reset ─── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --bg: #0d0d0d;
  --bg2: #161616;
  --bg3: #1e1e1e;
  --border: #2a2a2a;
  --border2: #3a3a3a;
  --text: #e8e8e8;
  --text2: #999;
  --text3: #666;
  --white: #fff;
  --green: #2ecc71;
  --green-bg: rgba(46,204,113,0.12);
  --red: #e74c3c;
  --red-bg: rgba(231,76,60,0.12);
  --font: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

html { font-size:15px; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  min-height: 100dvh;
  -webkit-font-smoothing: antialiased;
}

/* ─── Utilities ─── */
.hidden { display:none !important; }

/* ─── Toast ─── */
.toast-container { position:fixed; top:12px; left:50%; transform:translateX(-50%); z-index:9999; display:flex; flex-direction:column; gap:6px; pointer-events:none; }
.toast { padding:10px 20px; background:var(--bg3); border:1px solid var(--border2); color:var(--text); font-size:0.85rem; border-radius:4px; opacity:0; transition:opacity 200ms; pointer-events:auto; }
.toast.show { opacity:1; }
.toast-success { border-color:var(--green); }
.toast-error { border-color:var(--red); }

/* ─── Layout ─── */
.app-wrapper {
  width:100%;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
}

.screen {
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:20px;
}
.screen.hidden { display:none; }

/* ─── Card ─── */
.card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 16px;
  width:100%;
}

/* ─── Inputs ─── */
.input-group { margin-bottom:12px; }
.input-label, .input-group label {
  display:block;
  font-size:0.8rem;
  font-weight:500;
  color:var(--text2);
  margin-bottom:6px;
  text-transform:uppercase;
  letter-spacing:0.04em;
}
.input-field {
  width:100%;
  padding:8px 10px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:3px;
  color:var(--text);
  font-family:var(--font);
  font-size:0.9rem;
  outline:none;
}
.input-field:focus { border-color:var(--border2); }
select.input-field { height:36px; }

/* ─── Buttons ─── */
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:8px 16px;
  border:1px solid var(--border);
  border-radius:3px;
  font-family:var(--font);
  font-size:0.85rem;
  font-weight:600;
  cursor:pointer;
  background:var(--bg3);
  color:var(--text);
  transition:background 150ms;
  width:100%;
}
.btn:hover { background:var(--border); }
.btn:active { opacity:0.8; }
.btn:disabled { opacity:0.35; cursor:not-allowed; }

.btn svg { width:16px; height:16px; flex-shrink:0; }

.btn-primary { background:var(--white); color:#000; border-color:var(--white); }
.btn-primary:hover { background:#ddd; border-color:#ddd; }

.btn-secondary { background:var(--bg3); color:var(--text); }

.btn-success { background:var(--green-bg); color:var(--green); border-color:rgba(46,204,113,0.3); }
.btn-success:hover { background:var(--green); color:#fff; }

.btn-danger { background:var(--red-bg); color:var(--red); border-color:rgba(231,76,60,0.3); }
.btn-danger:hover { background:var(--red); color:#fff; }

.btn-sm { padding:6px 10px; font-size:0.8rem; }

/* ─── Badge ─── */
.badge { display:inline-block; padding:3px 8px; font-size:0.75rem; font-weight:700; border-radius:3px; text-transform:uppercase; letter-spacing:0.03em; }
.badge-dealer { background:var(--white); color:#000; }
.badge-sb { background:var(--bg3); color:var(--text2); border:1px solid var(--border); }

/* ─── Game Header (player side) ─── */
.game-header {
  width:100%;
  padding:12px 16px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-bottom:1px solid var(--border);
  background:var(--bg2);
  flex-shrink:0;
}

/* ─── Game Content ─── */
.game-content {
  flex:1;
  width:100%;
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:12px;
  overflow-y:auto;
}

/* ─── Pot Display ─── */
.pot-display {
  text-align:center;
  padding:16px;
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:4px;
}
.pot-label { font-size:0.7rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--text3); margin-bottom:4px; }
.pot-value { font-size:2rem; font-weight:700; color:var(--white); font-variant-numeric:tabular-nums; }

/* ─── Turn Indicator ─── */
.turn-indicator {
  text-align:center;
  padding:14px;
  background:var(--bg2);
  border:1px solid var(--border2);
  border-radius:4px;
}
.turn-indicator.waiting { border-color:var(--border); }
.turn-icon { display:none; }
.turn-text { font-size:0.95rem; font-weight:600; }
.turn-subtext { font-size:0.8rem; color:var(--text2); margin-top:2px; }

/* ─── Action Panel (bet input) ─── */
.action-panel {
  padding:16px;
  border-top:1px solid var(--border);
  background:var(--bg2);
  flex-shrink:0;
  width:100%;
}

/* ─── Celebration Overlay ─── */
.celebration-overlay {
  position:fixed;
  inset:0;
  z-index:200;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,0.85);
  padding:20px;
}
.celebration-content { text-align:center; max-width:360px; }
.celebration-title { font-size:1.6rem; font-weight:700; margin-bottom:8px; }
.celebration-subtitle { font-size:0.9rem; color:var(--text2); }
.celebration-tokens { font-size:1.8rem; font-weight:700; color:var(--green); margin-top:12px; }

/* ─── Desktop: wider container ─── */
@media (min-width:640px) {
  .game-content, .action-panel { max-width:560px; margin-left:auto; margin-right:auto; }
  .screen { padding:32px; }
  .card { max-width:560px; }
  .admin-layout .card { max-width:none; }
}

/* ─── Admin Layout ─── */
.admin-layout {
  max-width:720px !important;
  margin:0 auto;
  padding:16px;
}
.admin-layout .screen {
  min-height:auto;
  padding:0;
  align-items:stretch;
  justify-content:flex-start;
}
