/* ═══════════════════════════════════════════════════════
   hero.css — Shared hero component
   Used by: app-v2.html (SPA), admin/project-hq.html (HQ)
   Single source of truth for hero layout and typography.
   Color tokens come from each consumer's own :root vars.
   ═══════════════════════════════════════════════════════ */

.hero { background: var(--bg); border: none; border-bottom: 0.5px solid var(--border); border-radius: 0; box-shadow: none; padding: 18px 16px 16px; overflow: visible; position: relative; }
/* Glow removed — flat surface hero */
.hero-body { position: relative; }
.hero-eyebrow { display: flex; align-items: center; gap: var(--space-sm, 8px); margin-bottom: var(--space-sm, 8px); }
.hero-icon { width: 6px; height: 6px; border-radius: 50%; background: var(--primary); display: inline-block; flex-shrink: 0; font-size: 0; overflow: hidden; }
.hero-title { font-family: var(--font-heading, 'Plus Jakarta Sans', sans-serif); font-size: 10px; font-weight: 600; color: var(--primary); letter-spacing: 0.1em; text-transform: uppercase; line-height: 1; margin: 0; }
.hero-greeting { font-size: 12px; color: var(--text-faint); margin-bottom: var(--space-sm, 8px); }
.hero-label { font-family: var(--font-heading, 'Plus Jakarta Sans', sans-serif); font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted); }
.hero-badge { background: var(--primary-subtle, rgba(248,189,68,0.10)); border: 0.5px solid var(--ring, rgba(248,189,68,0.3)); color: var(--primary, #f8bd44); font-family: var(--font-heading, 'Plus Jakarta Sans', sans-serif); font-size: 0.6rem; font-weight: 700; padding: 2px var(--space-sm, 8px); border-radius: 100px; letter-spacing: 0.04em; }
.hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg, 24px); margin-bottom: var(--space-md, 16px); align-items: start; }
.hero-kpi-label { font-family: var(--font-heading, 'Plus Jakarta Sans', sans-serif); font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-faint); margin-bottom: var(--space-xs, 4px); }
.hero-kpi { font-family: var(--font-display, 'Fraunces', serif); font-style: italic; font-size: 42px; font-weight: 300; color: var(--primary, #f8bd44); line-height: 1; letter-spacing: -0.02em; margin-bottom: var(--space-xs, 4px); }
.hero-kpi-sub { font-family: var(--font-body, 'Plus Jakarta Sans', sans-serif); font-size: 11px; font-weight: 400; color: var(--text-faint); }
.hero-stats { display: flex; flex-direction: column; gap: var(--space-sm, 8px); padding-left: var(--space-lg, 24px); border-left: 0.5px solid var(--border-strong); }
.hero-stat { display: flex; flex-direction: column; align-items: flex-start; gap: 2px; }
.hero-stat-val { font-family: var(--font-mono, 'JetBrains Mono', monospace); font-size: 0.95rem; font-weight: 500; }
.hero-stat-label { font-family: var(--font-heading, 'Plus Jakarta Sans', sans-serif); font-size: 0.65rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-faint); }
.hero-spark { width: 100%; height: 40px; margin-bottom: var(--space-sm, 8px); }
.hero-spark-full { width: 100%; height: 48px; margin-top: var(--space-sm, 8px); display: none; }
.hero-spark-full.has-data { display: block; }
.hero-divider { height: 1px; background: var(--border-strong); margin-bottom: var(--space-md, 16px); }
.hero-actions { display: flex; align-items: center; justify-content: space-between; gap: var(--space-md, 16px); }
.hero-meta { font-family: var(--font-body, 'Plus Jakarta Sans', sans-serif); font-size: 0.75rem; font-weight: 300; color: var(--text-faint); }

/* Hero stat strip — page-renderer pattern (KPI grid) */
.hero-stat-strip { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; padding: 16px; border-top: none; border-bottom: 0.5px solid var(--border); background: var(--bg); margin: 0; }
.hero-stat-strip .hero-stat-val { font-family: var(--font-mono, 'JetBrains Mono', monospace); font-size: 16px; font-weight: 500; color: var(--text); }
.hero-stat-strip .hero-stat-label { font-family: var(--font-heading, 'Plus Jakarta Sans', sans-serif); font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-faint); }

/* ── Desktop ── */
@media (min-width: 1025px) {
  .hero { padding: 24px 24px 20px; border-left: none; border-right: none; border-radius: 0; box-shadow: none; }
  .hero-kpi { font-size: 52px; }
  .hero-stat-strip { grid-template-columns: repeat(4, 1fr) !important; padding: 20px 24px; gap: 32px; background: var(--bg); border-top: none; box-shadow: none; border-radius: 0; }
}

/* ── Responsive ── */
@media (max-width: 767px) {
  .hero { padding: 18px 16px 16px; border-radius: 0; }
  .hero-grid { grid-template-columns: 1fr; gap: var(--space-md, 16px); }
  .hero-stats { border-left: none; padding-left: 0; border-top: 0.5px solid var(--border-strong); padding-top: var(--space-sm, 8px); flex-direction: row; flex-wrap: wrap; gap: var(--space-md, 16px); }
  .hero-stat { flex-direction: column; align-items: flex-start; gap: 2px; }
  /* Stat strip: already grid on all breakpoints, just adjust gap */
  .hero-stat-strip { gap: var(--space-sm, 8px); }
  .hero-stat-strip .hero-meta { grid-column: 1 / -1; text-align: right; margin-left: 0 !important; }
  /* Eyebrow: allow wrapping so action button stays accessible on narrow phones */
  .hero-eyebrow { flex-wrap: wrap; }
  .hero-actions { flex-direction: column; align-items: stretch; }
}
@media (max-width: 390px) {
  /* Hide "This Month" label on very small phones — eyebrow is too cramped */
  .hero-eyebrow > span:not(.hero-badge):not(.hero-label) { display: none; }
  /* Scale down large KPI number so long dollar values don't overflow 360px */
  .hero-kpi { font-size: 34px; }
}

/* ── Light mode overrides ── */
[data-theme="light"] .hero-kpi { color: var(--primary); }
[data-theme="light"] .hero-kpi-sub { color: var(--text-muted); }
[data-theme="light"] .hero-stat-val { filter: brightness(0.62); }
[data-theme="light"] .hero-meta { color: var(--text-muted); }
