/* Market Health Index — shared site styles
   Color tokens mirror lib/widgets/app_colors.dart for visual consistency
   with the app and widgets. */

:root {
  --bg-deep: #02040A;
  --bg-card: #0D1423;
  --bg-surface: #1A2235;
  --divider: #1e293b;

  --text-primary: #E5E9F0;
  --text-muted: #9CA3AF;
  --text-dim: #4B5563;

  --accent-lime: #A3E635;
  --accent-yellow: #FACC15;
  --accent-orange: #F97316;

  --regime-on: #34D399;
  --regime-off: #F87171;

  --max-width: 720px;
  --max-width-wide: 980px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { background: var(--bg-deep); }

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  background: var(--bg-deep);
  color: var(--text-muted);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

a { color: var(--accent-lime); text-decoration: none; }
a:hover { text-decoration: underline; }

.container { max-width: var(--max-width); margin: 0 auto; padding: 0 24px; }
.container-wide { max-width: var(--max-width-wide); margin: 0 auto; padding: 0 24px; }

/* ── Header ─────────────────────────────────────────────────────── */
.site-header {
  border-bottom: 1px solid var(--divider);
  background: var(--bg-card);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 24px;
  flex-wrap: wrap;
}
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--text-primary);
}
.brand:hover { text-decoration: none; }
.brand-logo { width: 32px; height: 32px; border-radius: 8px; display: block; }
.brand-name {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-primary);
}
.site-nav { display: flex; gap: 24px; flex-wrap: wrap; }
.site-nav a {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: 0.5px;
}
.site-nav a:hover, .site-nav a.active { color: var(--accent-lime); text-decoration: none; }

/* ── Footer ──────────────────────────────────────────────────────── */
.site-footer {
  border-top: 1px solid var(--divider);
  background: var(--bg-card);
  margin-top: auto;
}
.footer-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 32px 24px 40px;
  text-align: center;
}
.footer-links { display: flex; gap: 20px; flex-wrap: wrap; justify-content: center; }
.footer-links a { font-size: 13px; color: var(--text-muted); }
.footer-links a:hover { color: var(--accent-lime); }
.footer-meta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  color: var(--text-dim);
}
.footer-meta a { color: var(--text-dim); }
.footer-meta a:hover { color: var(--accent-lime); }

/* ── Page content (legal pages) ─────────────────────────────────── */
main.page { flex: 1; padding: 48px 0 80px; }

h1 {
  font-size: 28px;
  font-weight: 800;
  color: var(--text-primary);
  margin-bottom: 8px;
  letter-spacing: -0.3px;
}
.subtitle {
  font-size: 13px;
  color: var(--text-dim);
  margin-bottom: 48px;
}
.callout {
  background: var(--bg-card);
  border-left: 3px solid var(--accent-lime);
  border-radius: 4px;
  padding: 20px 24px;
  margin-bottom: 40px;
}
.callout p { font-size: 15px; color: var(--text-primary); margin: 0; font-weight: 500; }
h2 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin: 40px 0 12px;
}
p { font-size: 15px; color: var(--text-muted); margin-bottom: 16px; }
ul { padding-left: 20px; margin-bottom: 16px; }
li { font-size: 15px; color: var(--text-muted); margin-bottom: 6px; }
hr.divider { border: none; border-top: 1px solid var(--divider); margin: 40px 0; }

/* ── Hero (home page) ───────────────────────────────────────────── */
.hero {
  text-align: center;
  padding: 72px 24px 56px;
}
.hero-logo {
  width: 96px;
  height: 96px;
  border-radius: 22px;
  margin: 0 auto 28px;
  display: block;
}
.hero h1 {
  font-size: 36px;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.5px;
  margin-bottom: 14px;
}
.hero .lead {
  font-size: 17px;
  color: var(--text-muted);
  max-width: 560px;
  margin: 0 auto 28px;
}
.badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--bg-deep);
  background: var(--accent-lime);
  padding: 8px 18px;
  border-radius: 999px;
}

/* ── Sections (home page) ───────────────────────────────────────── */
.section { padding: 40px 24px; }
.section-title {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-dim);
  text-align: center;
  margin-bottom: 8px;
}
.section-heading {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  text-align: center;
  margin: 0 0 16px;
  letter-spacing: -0.3px;
}
.section-intro {
  text-align: center;
  max-width: 560px;
  margin: 0 auto 40px;
  font-size: 15px;
  color: var(--text-muted);
}

/* Segment grid */
.segment-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.segment-card {
  background: var(--bg-card);
  border: 1px solid var(--divider);
  border-radius: 12px;
  padding: 22px 24px;
}
.segment-card h3 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 8px;
}
.segment-card p {
  font-size: 13.5px;
  color: var(--text-muted);
  margin: 0;
}

/* Score scale */
.scale-card {
  background: var(--bg-card);
  border: 1px solid var(--divider);
  border-radius: 12px;
  padding: 28px 28px 24px;
  max-width: 560px;
  margin: 0 auto;
}
/* Segmented score bar — mirrors MHISegmentedBar in the app/widgets
   (10 segments: 3 orange, 3 yellow, 4 lime, with small gaps) */
.scale-bar {
  display: flex;
  gap: 4px;
  height: 10px;
  margin-bottom: 10px;
}
.scale-bar .seg {
  flex: 1;
  border-radius: 2px;
}
.scale-bar .seg:first-child { border-radius: 999px 2px 2px 999px; }
.scale-bar .seg:last-child { border-radius: 2px 999px 999px 2px; }
.scale-bar .seg-orange { background: var(--accent-orange); }
.scale-bar .seg-yellow { background: var(--accent-yellow); }
.scale-bar .seg-lime { background: var(--accent-lime); }
.scale-labels {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: var(--text-dim);
  margin-bottom: 24px;
}
.regime-row {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}
.regime-pill {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 6px 16px;
  border-radius: 999px;
}
.regime-pill.on { background: rgba(52, 211, 153, 0.12); color: var(--regime-on); }
.regime-pill.off { background: rgba(248, 113, 113, 0.12); color: var(--regime-off); }

@media (max-width: 600px) {
  .hero h1 { font-size: 28px; }
  .section-heading { font-size: 20px; }
}
