/* ═══════════════════════════════════════════════════════
   GOALPULSE AI v2 — COMPONENTS
   Cards, Badges, Buttons, Inputs, Data Rows
   ═══════════════════════════════════════════════════════ */

/* ── Card ── */
.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 16px;
  margin-bottom: 8px;
  transition: transform var(--speed) var(--ease);
}
.card:active { transform: scale(0.985); }
.card.gold-border { border-color: var(--gold-border); }
.card.cyan-border { border-color: var(--cyan-border); }
.card.red-border  { border-color: var(--red-border); }

/* ── Data Row ── */
.data-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.data-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 11px 14px;
  border-bottom: 1px solid var(--border);
}
.data-row:last-child { border-bottom: none; }
.data-label { font-size: 12px; color: var(--text-2); }
.data-value {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
}

/* ── Buttons ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 20px;
  border-radius: var(--r-md);
  font-family: var(--font);
  font-size: 13px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  transition: all var(--speed) var(--ease);
}
.btn:active { transform: scale(0.96); }
.btn-cyan {
  background: var(--cyan);
  color: var(--bg);
}
.btn-gold {
  background: var(--gold);
  color: var(--bg);
}
.btn-outline {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-2);
}

/* ── Chips/Pills ── */
.chip {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: var(--r-sm);
  font-size: 11px;
  font-weight: 600;
  border: 1px solid var(--border);
  color: var(--text-3);
  cursor: pointer;
  transition: all var(--speed) var(--ease);
  background: var(--bg-card);
}
.chip.active {
  background: var(--cyan-soft);
  border-color: var(--cyan-border);
  color: var(--cyan);
}
.chip:active { transform: scale(0.95); }

/* ── Section Header ── */
.section-hdr {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 20px 16px 8px;
}
.section-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.section-action {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
  cursor: pointer;
}

/* ── Form Dots ── */
.form-dot {
  width: 22px; height: 22px;
  border-radius: var(--r-sm);
  display: inline-grid;
  place-items: center;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
}
.form-dot.w { background: var(--green-soft); color: var(--green); border: 1px solid var(--green-border); }
.form-dot.d { background: var(--gold-soft);  color: var(--gold);  border: 1px solid var(--gold-border); }
.form-dot.l { background: var(--red-soft);   color: var(--red);   border: 1px solid var(--red-border); }

/* ── Pulse Score ── */
.pulse-score {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: var(--r-sm);
}
.pulse-high   { background: var(--gold-soft);  color: var(--gold);  border: 1px solid var(--gold-border); }
.pulse-medium { background: var(--cyan-soft);  color: var(--cyan);  border: 1px solid var(--cyan-border); }
.pulse-low    { background: rgba(255,255,255,0.04); color: var(--text-3); border: 1px solid var(--border); }

/* ── Live Indicator ── */
.live-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--green);
  animation: pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; box-shadow: 0 0 4px var(--green); }
  50% { opacity: 0.3; box-shadow: none; }
}

/* ── Empty State ── */
.empty-state {
  text-align: center;
  padding: 48px 24px;
}
.empty-state .icon { font-size: 40px; margin-bottom: 16px; }
.empty-state h3 { font-size: 15px; font-weight: 700; margin-bottom: 6px; }
.empty-state p { font-size: 12px; color: var(--text-3); }

/* ── Match Cards ── */
.match-card {
  margin: 0 16px 6px;
  padding: 14px 16px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  cursor: pointer;
  transition: transform var(--speed) var(--ease);
}
.match-card:active { transform: scale(0.985); }
.match-card.has-pick { border-left: 3px solid var(--gold); }
.match-card.has-alert { border-left: 3px solid var(--red); }
.match-card.is-live { border: 1px solid var(--green-border); }
.mc-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; }
.mc-league { font-size:11px; color:var(--text-3); font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:60%; }
.mc-time { font-family:var(--font-mono); font-size:11px; color:var(--text-3); flex-shrink:0; }
.mc-time.live { color:var(--green); display:flex; align-items:center; gap:4px; }
.mc-body { display:flex; align-items:center; }
.mc-team { flex:1; display:flex; align-items:center; gap:8px; min-width:0; }
.mc-team.away { flex-direction:row-reverse; }
.mc-team-logo { width:26px; height:26px; border-radius:var(--r-sm); background:var(--bg-card2); border:1px solid var(--border); display:grid; place-items:center; flex-shrink:0; overflow:hidden; font-size:12px; color:var(--text-3); }
.mc-team-name { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mc-team.away .mc-team-name { text-align:right; }
.mc-score { font-family:var(--font-mono); font-size:20px; font-weight:700; min-width:54px; text-align:center; flex-shrink:0; letter-spacing:3px; }
.mc-score.live { color:var(--green); }
.mc-score.pre { font-size:11px; color:var(--text-3); font-weight:500; letter-spacing:0; }
.mc-footer { display:flex; align-items:center; gap:8px; margin-top:8px; padding-top:8px; border-top:1px solid var(--border); font-size:11px; color:var(--text-3); flex-wrap:wrap; }
.league-divider { padding:16px 16px 6px; display:flex; align-items:center; gap:6px; }
.league-divider .flag { font-size:14px; }
.league-divider .name { font-size:11px; font-weight:600; color:var(--text-3); text-transform:uppercase; letter-spacing:0.8px; }

/* ── Toast ── */
.toast {
  position: fixed;
  bottom: 80px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  opacity: 0;
  background: var(--bg-card2);
  border: 1px solid var(--border-light);
  border-radius: var(--r-md);
  padding: 10px 20px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  z-index: var(--z-toast);
  transition: all 300ms var(--ease);
  pointer-events: none;
}
.toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
