/* ============================================================================
   CruiseFeed — /stats/ page layout.
   Loaded (after theme.css) by the generated stats pages; see
   cruise-pipeline/cruise_pipeline/stats_site.py. Uses the brand tokens defined
   in theme.css so the stats site can never drift from the marketing site.
   ========================================================================== */

* { box-sizing: border-box; margin: 0; padding: 0; }
body { color: var(--navy); line-height: 1.6; background: #fff; }
a { color: var(--teal); text-decoration: none; }
a:hover { color: var(--cyan); }
.wrap { max-width: 1000px; margin: 0 auto; padding: 0 24px; }

/* Header — white glass, sticky */
header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.8);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--fog);
}
header .wrap { display: flex; justify-content: space-between; align-items: center; gap: 14px; flex-wrap: wrap; padding: 14px 24px; }
.brand { font-family: 'Cabinet Grotesk', 'Manrope', sans-serif; font-weight: 800; font-size: 20px; letter-spacing: -.02em; color: var(--navy); }
.brand b { color: var(--gold); font-weight: 800; }
.hcta {
  display: inline-flex; align-items: center; gap: .5rem;
  background: var(--coral); color: #fff; font-weight: 700; font-size: 14px;
  padding: 9px 18px; border-radius: 9999px;
  box-shadow: 0 10px 30px -10px rgba(255,107,91,.7);
  transition: transform .25s, background-color .25s;
}
.hcta:hover { background: var(--coraldark); color: #fff; transform: translateY(-2px); }

/* Sub-navigation */
.subnav { background: var(--mist); border-bottom: 1px solid var(--fog); }
.subnav .wrap { display: flex; gap: 6px 20px; flex-wrap: wrap; padding: 12px 24px; font-size: 14.5px; font-weight: 600; }
.subnav a { color: var(--muted); }
.subnav a:hover { color: var(--navy); }
.subnav a.cur { color: var(--navy); font-weight: 700; }

main { padding: 34px 0 10px; }
h1 { font-family: 'Cabinet Grotesk', 'Manrope', sans-serif; font-size: clamp(28px, 4.5vw, 42px); font-weight: 800; color: var(--navy); letter-spacing: -.03em; line-height: 1.1; }
h2 { font-family: 'Cabinet Grotesk', 'Manrope', sans-serif; font-size: 23px; font-weight: 700; color: var(--navy); margin: 38px 0 12px; letter-spacing: -.01em; }
.lead { color: var(--muted); font-size: 17px; margin-top: 12px; max-width: 70ch; }
.upd { color: var(--muted); font-size: 13px; margin-top: 8px; }

/* KPI tiles */
.kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 16px; margin: 26px 0; }
.kpi { background: var(--mist); border: 1px solid var(--fog); border-radius: 16px; padding: 20px; transition: transform .35s cubic-bezier(.16,.8,.3,1), box-shadow .35s, border-color .35s; }
.kpi:hover { transform: translateY(-4px); box-shadow: 0 24px 50px -30px rgba(12,35,64,.35); border-color: #cdd9e8; }
.kpi .n { font-family: 'Cabinet Grotesk', 'Manrope', sans-serif; font-size: 32px; font-weight: 800; color: var(--navy); letter-spacing: -.02em; }
.kpi .l { color: var(--muted); font-size: 13.5px; margin-top: 3px; }

/* Cards + charts */
.card { border: 1px solid var(--fog); border-radius: 16px; padding: 22px 24px; margin: 14px 0; background: #fff; transition: transform .35s cubic-bezier(.16,.8,.3,1), box-shadow .35s, border-color .35s; }
.card:hover { transform: translateY(-4px); box-shadow: 0 28px 56px -34px rgba(12,35,64,.3); border-color: #cdd9e8; }
.chart { width: 100%; height: auto; }
.chart .bl { font: 500 13px 'Manrope', sans-serif; fill: var(--navy); }
.chart .bv { font: 600 13px 'Manrope', sans-serif; fill: var(--muted); }

/* Tables */
table { width: 100%; border-collapse: collapse; font-size: 14.5px; margin-top: 8px; }
th, td { text-align: left; padding: 10px 10px; border-bottom: 1px solid var(--fog); }
th { color: var(--muted); font-weight: 700; font-size: 12px; text-transform: uppercase; letter-spacing: .06em; }
td.num, th.num { text-align: right; }
.muted { color: var(--muted); }

/* CTA block */
.cta { background: var(--navy); color: #fff; border-radius: 20px; padding: 28px; margin: 38px 0; text-align: center; }
.cta a { display: inline-block; background: var(--coral); color: #fff; font-weight: 700; padding: 12px 24px; border-radius: 9999px; margin-top: 12px; box-shadow: 0 10px 30px -10px rgba(255,107,91,.7); transition: transform .25s, background-color .25s; }
.cta a:hover { background: var(--coraldark); color: #fff; transform: translateY(-2px); }

/* Footer */
footer { border-top: 1px solid var(--fog); margin-top: 34px; padding: 24px 0; color: var(--muted); font-size: 13.5px; }
footer a { color: var(--teal); }
footer a:hover { color: var(--cyan); }
