/* Home Dashboard — NightBingoOS */
/* Mobile-first responsive grid. Matches visual style established in /caller. */

/* Nav */
.home-nav {
  position: sticky; top: 0; z-index: 100;
  background: rgba(8,13,24,0.95); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.home-nav-inner {
  max-width: 800px; margin: 0 auto;
  padding: 0 20px; height: 56px;
  display: flex; align-items: center; gap: 16px;
}
.home-logo {
  font-family: var(--font-display); font-size: 18px; color: var(--cream);
  letter-spacing: 0.02em; flex-shrink: 0;
}
.home-nav-links { display: flex; gap: 20px; margin-left: auto; }
.home-nav-link {
  font-size: 14px; color: var(--silver); text-decoration: none;
  transition: color 0.2s;
}
.home-nav-link:hover, .home-nav-link.active { color: var(--cream); }

/* Page wrapper */
.home-page {
  max-width: 800px; margin: 0 auto;
  padding: 24px 16px 80px;
  display: flex; flex-direction: column; gap: 24px;
}

/* Header */
.home-header { padding-bottom: 4px; }
.home-date {
  font-size: 12px; color: var(--silver);
  text-transform: uppercase; letter-spacing: 0.12em;
  margin-bottom: 4px;
}
.home-title {
  font-family: var(--font-display); font-size: clamp(36px, 8vw, 52px);
  color: var(--cream); line-height: 1; letter-spacing: 0.02em;
}

/* Card grid — single column on mobile, 2-col on tablet+ */
.home-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

/* Base card */
.home-card {
  background: var(--card-bg); border: 1px solid var(--border);
  border-radius: 16px; padding: 20px 22px;
}

.card-label {
  font-size: 11px; color: var(--silver);
  text-transform: uppercase; letter-spacing: 0.16em;
  font-weight: 600; margin-bottom: 14px;
}

/* Tonight's Session card */
.card-session { border-color: rgba(255,77,109,0.2); }
.session-times { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; }
.session-time-row { display: flex; align-items: baseline; gap: 10px; }
.time-tag {
  font-size: 12px; color: var(--silver); width: 74px; flex-shrink: 0;
  font-weight: 500;
}
.time-val {
  font-family: var(--font-display); font-size: 28px;
  color: var(--cream); line-height: 1; letter-spacing: 0.02em;
}
.session-status-row { display: flex; align-items: center; gap: 12px; }
.will-call-link {
  font-size: 12px; font-weight: 600; color: var(--coral);
  text-decoration: none; letter-spacing: 0.03em;
  transition: opacity 0.2s;
}
.will-call-link:hover { opacity: 0.75; }
.status-badge {
  display: inline-block; padding: 4px 12px; border-radius: 20px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase;
}
/* Status badge variants */
.status-setup   { background: rgba(138,150,168,0.12); color: var(--silver); border: 1px solid rgba(138,150,168,0.25); }
.status-doors   { background: rgba(255,194,43,0.12);  color: var(--gold);   border: 1px solid rgba(255,194,43,0.3); }
.status-live    { background: rgba(255,77,109,0.12);  color: var(--coral);  border: 1px solid rgba(255,77,109,0.3); }
.status-closed  { background: rgba(61,74,99,0.3);     color: var(--muted);  border: 1px solid rgba(61,74,99,0.5); }

/* Packs Sold card */
.card-packs { border-color: rgba(255,194,43,0.15); }
.packs-total {
  font-family: var(--font-display); font-size: clamp(40px, 10vw, 60px);
  color: var(--gold); line-height: 1; letter-spacing: 0.02em;
  margin-bottom: 4px;
}
.packs-total.packs-zero { color: var(--muted); }
.packs-count { font-size: 14px; color: var(--silver); }

/* Prize Pool card */
.card-prize { border-color: rgba(155,127,232,0.2); }
.prize-amount {
  font-family: var(--font-display); font-size: clamp(40px, 10vw, 60px);
  color: #9b7fe8; line-height: 1; letter-spacing: 0.02em;
  margin-bottom: 4px;
}
.prize-note { font-size: 13px; color: var(--silver); }

/* Quick Actions card */
.card-actions { border-color: rgba(255,255,255,0.1); }
.action-buttons { display: flex; flex-direction: column; gap: 12px; }
.action-btn {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 18px; border-radius: 12px;
  text-decoration: none; font-weight: 600; font-size: 16px;
  transition: opacity 0.15s, transform 0.12s;
  -webkit-tap-highlight-color: transparent;
}
.action-btn:active { transform: scale(0.98); opacity: 0.85; }
.action-btn-caller {
  background: var(--coral); color: var(--cream);
}
.action-btn-sell {
  background: rgba(255,194,43,0.12); color: var(--gold);
  border: 1px solid rgba(255,194,43,0.3);
}
.action-icon { font-size: 20px; line-height: 1; }
.action-text { flex: 1; }

/* Tablet+: 2-column grid */
@media (min-width: 560px) {
  .home-grid {
    grid-template-columns: 1fr 1fr;
  }
  /* Quick actions spans full width */
  .card-actions {
    grid-column: 1 / -1;
  }
  .action-buttons { flex-direction: row; }
  .action-btn { flex: 1; justify-content: center; }
}

/* Desktop tweaks */
@media (min-width: 800px) {
  .home-page { padding: 32px 24px 80px; }
  .home-grid { gap: 20px; }
  .home-card { padding: 24px 28px; }
}
