/* HOA Sentinel — public design system.
   Premium, compliance-focused B2B intelligence product.
   Off-white surfaces, dark-navy header, teal accent, restrained risk hues.
   Inter throughout. Reused class names keep pricing/sample/events visually
   consistent with the redesigned home page. */

/* ─── Tokens ──────────────────────────────────────────────────────────── */
:root {
  /* Surfaces */
  --background:        #F7F6F2;          /* page — warm off-white */
  --surface:           #FFFFFF;          /* card */
  --surface-elevated:  #FFFFFF;
  --surface-sunken:    #F1EFEA;          /* form fields, code */
  --surface-strong:    #EAE7DF;

  /* Brand / structure */
  --navy:              #0F2A3D;          /* header, dark sections, hero */
  --navy-2:            #163B53;
  --navy-3:            #21536F;
  --navy-text:         #E5EEF5;          /* readable text on navy */
  --navy-muted:        #9FB3C2;

  /* Type */
  --text-primary:      #0B1726;          /* core text — 18:1 on background */
  --text-secondary:    #34495C;          /* prose support — 8:1 */
  --text-muted:        #5A6E80;          /* metadata — 5:1 (AA) */

  /* Borders */
  --border:            #E2DFD5;
  --border-strong:     #C9C4B6;

  /* Accent — teal */
  --accent:            #0F766E;          /* WCAG AA on white */
  --accent-hover:      #0B5852;
  --accent-soft:       #E6F4F2;
  --accent-contrast:   #FFFFFF;

  /* CTA — restrained amber for the primary "Get the free roundup" */
  --cta:               #C77B00;
  --cta-hover:         #A86600;
  --cta-soft:          #FFF1DC;
  --cta-contrast:      #FFFFFF;

  /* Risk / status */
  --risk-high:         #B91C1C;
  --risk-high-bg:      #FDECEC;
  --risk-high-bd:      #F4C7C7;
  --risk-med:          #B45309;
  --risk-med-bg:       #FDF1DE;
  --risk-med-bd:       #F2DCB1;
  --risk-low:          #475569;
  --risk-low-bg:       #EEF1F5;
  --risk-low-bd:       #D8DEE6;
  --ok:                #047857;
  --ok-bg:             #E5F4EE;
  --ok-bd:             #BDDDCB;

  /* Source-type colors (used on tags + dots) */
  --src-leg:    #0F766E;       --tint-leg:    #E6F4F2;
  --src-dbpr:   #B45309;       --tint-dbpr:   #FDF1DE;
  --src-rule:   #1E4FBF;       --tint-rule:   #E6EDFA;
  --src-court:  #6B21A8;       --tint-court:  #F1E8F8;

  /* Geometry */
  --r-card: 14px;
  --r-btn:  10px;
  --r-tag:  6px;
  --r-pill: 999px;
  --maxw:   1200px;
  --gutter: 24px;

  /* Shadows — subtle only */
  --shadow-sm:  0 1px 2px rgba(11,23,38,0.04);
  --shadow-md:  0 6px 16px rgba(11,23,38,0.06), 0 1px 2px rgba(11,23,38,0.04);
  --shadow-lg:  0 18px 40px rgba(11,23,38,0.10), 0 2px 6px rgba(11,23,38,0.04);

  /* Legacy aliases for views that reference older tokens */
  --gold:           var(--cta);
  --gold-dark:      var(--cta-hover);
  --primary-dark:   var(--navy);
  --primary-dark-2: var(--navy-2);
  --hero-grad:      linear-gradient(135deg, var(--navy) 0%, var(--navy-2) 60%, var(--navy-3) 100%);
  --bg-warm:        var(--background);
  --bg-card:        var(--surface);
  --text:           var(--text-primary);
  --text-2:         var(--text-secondary);
  --success:        var(--ok);
  --success-bg:     var(--ok-bg);
  --warning:        var(--risk-med);
  --warning-bg:     var(--risk-med-bg);
  --info:           #1E4FBF;
  --info-bg:        #E6EDFA;
  --danger:         var(--risk-high);
  --danger-bg:      var(--risk-high-bg);
  --error-bg:       var(--risk-high-bg);
  --error-fg:       var(--risk-high);
  --error-border:   var(--risk-high-bd);
  --badge-high-bg:  var(--risk-high-bg);
  --badge-high-fg:  var(--risk-high);
  --form-focus-bg:  #FFFFFF;
  --accent-soft-bg: var(--accent-soft);

  color-scheme: light;
}

/* Dark mode keeps the same brand language: deep navy surfaces, teal accent. */
[data-theme="dark"] {
  --background:        #08141E;
  --surface:           #102434;
  --surface-elevated:  #163147;
  --surface-sunken:    #0A1A26;
  --surface-strong:    #1A3A52;
  --navy:              #08141E;
  --navy-2:            #102434;
  --navy-3:            #163147;
  --navy-text:         #E5EEF5;
  --navy-muted:        #95ACBE;
  --text-primary:      #ECF1F7;
  --text-secondary:    #B6C5D2;
  --text-muted:        #8597A8;
  --border:            #1F3A52;
  --border-strong:     #2C547A;
  --accent:            #2DD4BF;
  --accent-hover:      #5EEAD4;
  --accent-soft:       rgba(45, 212, 191, 0.14);
  --accent-contrast:   #00231F;
  --cta:               #F5A524;
  --cta-hover:         #FFC056;
  --cta-soft:          rgba(245, 165, 36, 0.14);
  --cta-contrast:      #261800;
  --risk-high:         #FCA5A5;     --risk-high-bg: rgba(252,165,165,0.12);   --risk-high-bd: rgba(252,165,165,0.36);
  --risk-med:          #FCD34D;     --risk-med-bg:  rgba(252,211,77,0.12);    --risk-med-bd:  rgba(252,211,77,0.36);
  --risk-low:          #94A3B8;     --risk-low-bg:  rgba(148,163,184,0.12);   --risk-low-bd:  rgba(148,163,184,0.36);
  --ok:                #5EEAD4;     --ok-bg:        rgba(94,234,212,0.12);    --ok-bd:        rgba(94,234,212,0.36);
  --src-leg:    #5EEAD4;     --tint-leg:    rgba(94,234,212,0.14);
  --src-dbpr:   #FCD34D;     --tint-dbpr:   rgba(252,211,77,0.14);
  --src-rule:   #93C5FD;     --tint-rule:   rgba(147,197,253,0.14);
  --src-court:  #D8B4FE;     --tint-court:  rgba(216,180,254,0.14);
  color-scheme: dark;
}
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --background:        #08141E; --surface: #102434; --surface-elevated: #163147;
    --surface-sunken: #0A1A26; --surface-strong: #1A3A52;
    --navy: #08141E; --navy-2: #102434; --navy-3: #163147;
    --text-primary: #ECF1F7; --text-secondary: #B6C5D2; --text-muted: #8597A8;
    --border: #1F3A52; --border-strong: #2C547A;
    --accent: #2DD4BF; --accent-hover: #5EEAD4; --accent-soft: rgba(45,212,191,0.14); --accent-contrast: #00231F;
    --cta: #F5A524; --cta-hover: #FFC056; --cta-soft: rgba(245,165,36,0.14); --cta-contrast: #261800;
    color-scheme: dark;
  }
}

/* ─── Base ────────────────────────────────────────────────────────────── */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Inter', ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
    "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.55;
  color: var(--text-primary);
  background: var(--background);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
@media (min-width: 760px) { body { font-size: 17px; } }

h1, h2, h3, h4 {
  font-family: inherit;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  margin: 0 0 14px;
  line-height: 1.15;
}
h1 { font-size: 36px; letter-spacing: -0.025em; }
h2 { font-size: 28px; }
h3 { font-size: 20px; letter-spacing: -0.015em; }
@media (min-width: 760px) {
  h1 { font-size: 44px; }
  h2 { font-size: 34px; }
  h3 { font-size: 22px; }
}

p  { margin: 0 0 18px; max-width: 70ch; }
a  { color: var(--accent); text-decoration: none; font-weight: 500; }
a:hover { color: var(--accent-hover); text-decoration: underline; text-underline-offset: 3px; }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }
.muted { color: var(--text-muted); }
.small { font-size: 14px; }

.eyebrow {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: rgba(255,255,255,0.78);
  margin-bottom: 18px;
}
.eyebrow-dark {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--accent);
  margin-bottom: 14px;
}

/* ─── Header ──────────────────────────────────────────────────────────── */
.site-header {
  background: var(--navy);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  padding: 14px 0;
  color: var(--navy-text);
}
.site-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  font-size: 17px;
  letter-spacing: -0.015em;
  color: #FFFFFF;
  text-decoration: none;
}
.brand:hover { color: var(--accent); }
.brand svg { display: block; flex: 0 0 auto; color: var(--accent); }

.site-header nav { display: flex; align-items: center; gap: 4px; flex-wrap: wrap; }
.site-header nav a {
  color: var(--navy-text);
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  padding: 8px 14px;
  border-radius: var(--r-btn);
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  transition: background .12s ease, color .12s ease;
}
.site-header nav a:hover { background: rgba(255,255,255,0.08); color: #fff; }
.site-header nav a.active { background: rgba(45,212,191,0.14); color: var(--accent); }
.site-header nav a.cta {
  background: var(--cta);
  color: var(--cta-contrast);
  font-weight: 600;
  margin-left: 8px;
  padding: 9px 16px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.20);
}
.site-header nav a.cta:hover { background: var(--cta-hover); color: var(--cta-contrast); }
.site-header nav a.cta.active { background: var(--cta-hover); }

.theme-toggle {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.20);
  border-radius: var(--r-btn);
  padding: 0;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--navy-text);
  cursor: pointer;
  margin-left: 4px;
  transition: background .12s ease, color .12s ease, border-color .12s ease;
}
.theme-toggle:hover { color: var(--accent); border-color: var(--accent); background: rgba(255,255,255,0.06); }
.theme-toggle svg { width: 16px; height: 16px; display: block; }
.theme-toggle .icon-sun { display: none; }
.theme-toggle .icon-moon { display: block; }
[data-theme="dark"] .theme-toggle .icon-sun { display: block; }
[data-theme="dark"] .theme-toggle .icon-moon { display: none; }
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .theme-toggle .icon-sun { display: block; }
  :root:not([data-theme="light"]) .theme-toggle .icon-moon { display: none; }
}
@media (max-width: 720px) {
  .site-header nav a { font-size: 13px; padding: 7px 10px; }
  .site-header .container { flex-wrap: wrap; }
}

/* ─── Buttons ─────────────────────────────────────────────────────────── */
.btn-primary, .btn-secondary, .btn-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 13px 22px;
  border-radius: var(--r-btn);
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.005em;
  text-decoration: none;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background .12s ease, color .12s ease, border-color .12s ease, box-shadow .12s ease, transform .05s ease;
  line-height: 1.2;
}
.btn-primary:active, .btn-secondary:active, .btn-ghost:active { transform: translateY(1px); }

.btn-primary {
  background: var(--cta);
  color: var(--cta-contrast);
  border-color: var(--cta);
  box-shadow: var(--shadow-sm);
}
.btn-primary:hover { background: var(--cta-hover); border-color: var(--cta-hover); color: var(--cta-contrast); box-shadow: var(--shadow-md); }
.btn-primary.alt { background: var(--accent); border-color: var(--accent); color: var(--accent-contrast); }
.btn-primary.alt:hover { background: var(--accent-hover); border-color: var(--accent-hover); color: var(--accent-contrast); }

.btn-secondary {
  background: transparent;
  color: var(--text-primary);
  border-color: var(--border-strong);
}
.btn-secondary:hover { background: var(--surface); color: var(--accent); border-color: var(--accent); }
.hero .btn-secondary { color: #FFFFFF; border-color: rgba(255,255,255,0.40); }
.hero .btn-secondary:hover { background: rgba(255,255,255,0.10); border-color: rgba(255,255,255,0.70); color: #fff; }

.btn-ghost {
  background: var(--surface);
  color: var(--text-primary);
  border-color: var(--border-strong);
}
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }

/* ─── Hero ────────────────────────────────────────────────────────────── */
.hero {
  background:
    radial-gradient(1100px 380px at 12% -10%, rgba(45,212,191,0.16), transparent 60%),
    radial-gradient(800px 340px at 90% 110%, rgba(199,123,0,0.10), transparent 60%),
    linear-gradient(180deg, var(--navy) 0%, var(--navy-2) 100%);
  color: #FFFFFF;
  padding: 72px 0 88px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  position: relative;
}
.hero .container { position: relative; z-index: 1; }
.hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  align-items: center;
}
@media (min-width: 1000px) {
  .hero-grid { grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr); gap: 64px; }
}
.hero-text h1 {
  color: #FFFFFF;
  font-size: 38px;
  line-height: 1.08;
  letter-spacing: -0.025em;
  margin: 0 0 18px;
}
@media (min-width: 760px)  { .hero-text h1 { font-size: 48px; } }
@media (min-width: 1200px) { .hero-text h1 { font-size: 56px; } }
.hero-text .lede {
  color: rgba(255,255,255,0.86);
  font-size: 18px;
  line-height: 1.55;
  max-width: 56ch;
  margin: 0 0 30px;
  font-weight: 400;
}
.hero-text .cta-row { display: flex; gap: 12px; flex-wrap: wrap; }

/* Hero product mockup card — alert list */
.hero-mockup {
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: 18px;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  color: var(--text-primary);
  position: relative;
}
.hero-mockup .mock-head {
  padding: 14px 18px;
  background: var(--surface-strong);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  letter-spacing: 0.02em;
}
.hero-mockup .mock-head .dots { display: flex; gap: 6px; }
.hero-mockup .mock-head .dots span { width: 10px; height: 10px; border-radius: 50%; background: var(--border-strong); }
.hero-mockup .mock-head .label { font-family: 'Inter', sans-serif; font-size: 12px; }
.hero-mockup .mock-body { padding: 18px 18px 12px; }
.hero-mockup .mock-title { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 14px; gap: 12px; }
.hero-mockup .mock-title strong { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.hero-mockup .mock-title span   { font-size: 12px; color: var(--text-muted); }

.alert-card {
  padding: 14px 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
  margin-bottom: 10px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: flex-start;
}
.alert-card .impact-dot {
  width: 8px; height: 8px; border-radius: 50%;
  margin-top: 7px;
  background: var(--text-muted);
}
.alert-card.high  .impact-dot { background: var(--risk-high); }
.alert-card.med   .impact-dot { background: var(--risk-med); }
.alert-card.low   .impact-dot { background: var(--risk-low); }
.alert-card .meta {
  display: flex; gap: 8px; flex-wrap: wrap;
  font-size: 11px; color: var(--text-muted); margin-bottom: 4px;
  text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600;
}
.alert-card .ttl  { font-size: 14px; font-weight: 600; color: var(--text-primary); line-height: 1.3; }
.alert-card .pill {
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em;
  padding: 3px 8px; border-radius: var(--r-tag); white-space: nowrap;
  align-self: flex-start;
}
.alert-card.high  .pill { background: var(--risk-high-bg); color: var(--risk-high); border: 1px solid var(--risk-high-bd); }
.alert-card.med   .pill { background: var(--risk-med-bg);  color: var(--risk-med);  border: 1px solid var(--risk-med-bd); }
.alert-card.low   .pill { background: var(--risk-low-bg);  color: var(--risk-low);  border: 1px solid var(--risk-low-bd); }
.alert-card .stat-row { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; grid-column: 1 / -1; }
.alert-card .chip {
  font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: var(--r-tag);
  background: var(--surface-strong); color: var(--text-secondary);
}

/* ─── Proof strip (right under hero) ──────────────────────────────────── */
.proof-strip {
  background: var(--surface);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.proof-strip .container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
}
@media (min-width: 760px)  { .proof-strip .container { grid-template-columns: repeat(4, 1fr); } }
.proof-cell {
  padding: 22px 18px;
  border-right: 1px solid var(--border);
  text-align: center;
}
.proof-cell:last-child { border-right: none; }
.proof-cell:nth-child(2) { border-right: none; }
@media (min-width: 760px) { .proof-cell:nth-child(2) { border-right: 1px solid var(--border); } }
.proof-cell strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.005em;
}
.proof-cell span {
  display: block;
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  font-weight: 600;
}

/* ─── Sections ───────────────────────────────────────────────────────── */
.section { padding: 80px 0; }
.section + .section { padding-top: 0; }
.section h2 { margin-top: 0; }
.section .lede {
  color: var(--text-secondary);
  font-size: 17px;
  line-height: 1.6;
  max-width: 60ch;
  margin: 0 0 36px;
}
.section-head { margin-bottom: 36px; }

/* ─── "What we monitor" — 5 source cards ─────────────────────────────── */
.source-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 700px)  { .source-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .source-grid { grid-template-columns: repeat(5, 1fr); } }
.source-grid .cell {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: 22px 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: border-color .12s ease, transform .12s ease, box-shadow .12s ease;
}
.source-grid .cell:hover { border-color: var(--accent); box-shadow: var(--shadow-md); }
.source-grid .cell .src-icon {
  width: 36px; height: 36px;
  border-radius: 9px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent-soft);
  color: var(--accent);
  flex: 0 0 auto;
}
.source-grid .cell .src-icon svg { width: 20px; height: 20px; }
.source-grid .cell.leg   .src-icon { background: var(--tint-leg);   color: var(--src-leg); }
.source-grid .cell.dbpr  .src-icon { background: var(--tint-dbpr);  color: var(--src-dbpr); }
.source-grid .cell.rule  .src-icon { background: var(--tint-rule);  color: var(--src-rule); }
.source-grid .cell.court .src-icon { background: var(--tint-court); color: var(--src-court); }
.source-grid .cell h3 {
  margin: 4px 0 0;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.source-grid .cell .src-label {
  font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.10em;
  color: var(--text-muted); margin: 0;
}
.source-grid .cell p {
  margin: 4px 0 0;
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.55;
}
.dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; flex: 0 0 auto; }
.dot-leg   { background: var(--src-leg); }
.dot-dbpr  { background: var(--src-dbpr); }
.dot-rule  { background: var(--src-rule); }
.dot-court { background: var(--src-court); }

/* ─── How it works — 4 step cards ────────────────────────────────────── */
.step-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 760px)  { .step-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .step-grid { grid-template-columns: repeat(4, 1fr); } }
.step-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
}
.step-card .step-num {
  width: 32px; height: 32px;
  border-radius: 8px;
  background: var(--navy);
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 14px;
  letter-spacing: -0.02em;
}
.step-card h3 { margin: 0; font-size: 17px; font-weight: 700; letter-spacing: -0.01em; }
.step-card p  { margin: 0; color: var(--text-secondary); font-size: 14px; line-height: 1.55; }

/* ─── Recent activity — alert cards ───────────────────────────────────── */
.activity-list, .timeline {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}
.activity-list li, .timeline li {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: 18px 20px;
  transition: border-color .12s ease, box-shadow .12s ease;
  position: relative;
}
.activity-list li:hover, .timeline li:hover { border-color: var(--accent); box-shadow: var(--shadow-sm); }
.timeline li::before { display: none; }
.activity-list li.recent, .timeline li.recent { border-left: 3px solid var(--accent); }

.activity-list .row1, .timeline .row1 {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 8px;
  font-size: 13px;
  color: var(--text-muted);
}
.activity-list .row1 time, .timeline .row1 time { color: var(--text-muted); font-weight: 600; }
.activity-list a.title, .timeline a.title {
  color: var(--text-primary);
  font-weight: 600;
  text-decoration: none;
  font-size: 16px;
  line-height: 1.4;
  display: inline-block;
  letter-spacing: -0.005em;
}
.activity-list a.title:hover, .timeline a.title:hover { color: var(--accent); }

/* Source-type tag (used in row1, on activity cards, and event-detail) */
.tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 9px;
  border-radius: var(--r-tag);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  line-height: 1.4;
  white-space: nowrap;
  border: 1px solid transparent;
}
.tag-leg   { background: var(--tint-leg);   color: var(--src-leg);   border-color: var(--tint-leg); }
.tag-dbpr  { background: var(--tint-dbpr);  color: var(--src-dbpr);  border-color: var(--tint-dbpr); }
.tag-rule  { background: var(--tint-rule);  color: var(--src-rule);  border-color: var(--tint-rule); }
.tag-court { background: var(--tint-court); color: var(--src-court); border-color: var(--tint-court); }

.badge-high {
  display: inline-block;
  background: var(--risk-high-bg);
  color: var(--risk-high);
  border: 1px solid var(--risk-high-bd);
  padding: 2px 9px;
  border-radius: var(--r-tag);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

/* ─── Pricing ─────────────────────────────────────────────────────────── */
.pricing-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media (min-width: 880px) {
  .pricing-grid { grid-template-columns: repeat(3, 1fr); align-items: stretch; }
}
.plan {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: border-color .12s ease, box-shadow .12s ease, transform .12s ease;
}
.plan:hover { border-color: var(--border-strong); box-shadow: var(--shadow-md); }
.plan.featured {
  border: 2px solid var(--accent);
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}
.plan.featured::before {
  content: "Most popular";
  position: absolute;
  top: -12px;
  left: 24px;
  background: var(--accent);
  color: var(--accent-contrast);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: var(--r-tag);
}
.plan h3 { margin: 0 0 4px; font-size: 22px; font-weight: 700; letter-spacing: -0.01em; color: var(--text-primary); }
.plan .freq {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-muted);
  margin-bottom: 18px;
}
.plan .price {
  font-size: 44px;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1;
  margin: 0 0 6px;
  letter-spacing: -0.025em;
  font-variant-numeric: tabular-nums;
}
.plan .price .per { font-size: 15px; font-weight: 500; color: var(--text-muted); margin-left: 4px; }
.plan .price .free-tag { font-size: 44px; font-weight: 800; color: var(--text-primary); letter-spacing: -0.025em; }
.plan .blurb {
  color: var(--text-secondary);
  font-size: 15px;
  line-height: 1.55;
  margin: 16px 0 24px;
  flex: 1;
}
.plan ul.feat {
  list-style: none;
  margin: 0 0 24px;
  padding: 0;
  display: grid;
  gap: 8px;
  flex: 1;
}
.plan ul.feat li {
  font-size: 14px;
  color: var(--text-primary);
  padding-left: 24px;
  position: relative;
  line-height: 1.5;
}
.plan ul.feat li::before {
  content: "";
  position: absolute;
  left: 0; top: 6px;
  width: 14px; height: 14px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M3 8.5l3.2 3L13 5' stroke='%230F766E' stroke-width='2.2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-size: 14px 14px;
  background-repeat: no-repeat;
}
.plan .btn-primary, .plan .btn-ghost { width: 100%; }
.center-cta { text-align: center; margin-top: 32px; }

/* ─── Trust / disclaimer strip ─────────────────────────────────────── */
.trust-strip {
  background: var(--surface-strong);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 22px 0;
}
.trust-strip .row {
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  font-size: 14px; color: var(--text-secondary);
}
.trust-strip .row svg { color: var(--accent); flex: 0 0 auto; }
.trust-strip strong { color: var(--text-primary); font-weight: 700; }

/* ─── Sample / digest pages (kept) ─────────────────────────────────── */
.sample-banner {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: 18px 22px;
  margin-bottom: 28px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
}
.sample-banner p { margin: 0; color: var(--text-secondary); font-size: 15px; }
.digest-mock {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: 32px 28px;
  box-shadow: var(--shadow-sm);
}
.digest-mock .digest-head { border-bottom: 1px solid var(--border); padding-bottom: 18px; margin-bottom: 22px; }
.digest-mock .digest-head h2 { margin: 0 0 4px; font-size: 24px; }
.digest-mock .digest-head .meta { color: var(--text-muted); font-size: 14px; }
.digest-mock article { padding: 18px 0; border-bottom: 1px solid var(--border); }
.digest-mock article:last-of-type { border-bottom: none; }
.digest-mock article h3 { font-size: 18px; margin: 6px 0 8px; }
.digest-mock article h3 a { color: var(--text-primary); text-decoration: none; }
.digest-mock article h3 a:hover { color: var(--accent); }
.digest-mock article .summary { color: var(--text-secondary); font-size: 15px; margin: 0 0 8px; max-width: 70ch; }
.digest-mock article .row1 { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; font-size: 13px; color: var(--text-muted); }

.inline-cta {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: 28px;
  margin-top: 28px;
  text-align: center;
  box-shadow: var(--shadow-sm);
}
.inline-cta h3 { margin: 0 0 8px; }
.inline-cta p  { color: var(--text-secondary); margin: 0 auto 18px; max-width: 60ch; }
.inline-cta form { display: flex; gap: 8px; max-width: 460px; margin: 0 auto; flex-wrap: wrap; }
.inline-cta input[type=email] { flex: 1 1 220px; min-width: 0; }

/* ─── Forms ───────────────────────────────────────────────────────── */
.form-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: 32px 28px;
  max-width: 560px;
  box-shadow: var(--shadow-sm);
}
.form-card label {
  display: block;
  margin-bottom: 18px;
  font-weight: 600;
  font-size: 14px;
  color: var(--text-primary);
}
.form-card input[type=text],
.form-card input[type=email],
.form-card input[type=number],
.form-card select,
.inline-cta input[type=email] {
  width: 100%;
  padding: 12px 14px;
  font-size: 15px;
  font-family: inherit;
  background: var(--surface);
  color: var(--text-primary);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-btn);
  margin-top: 6px;
  min-height: 46px;
  -webkit-appearance: none;
  appearance: none;
  transition: border-color .12s ease, box-shadow .12s ease;
}
.form-card input:focus, .form-card select:focus, .inline-cta input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.form-card .row-inline { display: grid; grid-template-columns: 1fr; gap: 12px; }
@media (min-width: 600px) { .form-card .row-inline { grid-template-columns: 1fr 1fr; } }
.form-card label.checkbox { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.form-card label.checkbox input { width: auto; margin: 0; min-height: auto; }
.form-card button { width: 100%; }

.error {
  background: var(--risk-high-bg);
  color: var(--risk-high);
  border: 1px solid var(--risk-high-bd);
  border-radius: var(--r-btn);
  padding: 12px 14px;
  margin-bottom: 18px;
  font-size: 14px;
}

/* ─── Event detail / update page ─────────────────────────────────── */
.event-detail {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: 36px 32px;
  box-shadow: var(--shadow-sm);
}
.event-detail .meta-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; font-size: 13px; color: var(--text-muted); margin-bottom: 14px; }
.event-detail h1 { font-size: 30px; line-height: 1.18; margin: 0 0 18px; letter-spacing: -0.025em; }
@media (min-width: 760px) { .event-detail h1 { font-size: 38px; } }
.event-detail .summary { font-size: 17px; line-height: 1.65; max-width: 70ch; color: var(--text-primary); }
.event-detail .summary p { margin: 0 0 16px; }
.event-detail .summary-line { font-size: 15px; max-width: 70ch; color: var(--text-secondary); }
.event-detail .summary-line strong { color: var(--text-primary); }
.event-detail .source-box {
  background: var(--surface-sunken);
  border: 1px solid var(--border);
  padding: 18px;
  border-radius: var(--r-btn);
  margin: 26px 0;
  font-size: 14px;
}
.event-detail .source-box strong { display: block; margin-bottom: 4px; color: var(--text-primary); }
.event-detail .source-box a { word-break: break-all; }
.event-detail .chapters { color: var(--text-muted); font-size: 13px; }

/* ─── Filter pill bar (events list) ──────────────────────────────── */
.filter-bar { display: flex; gap: 8px; margin: 0 0 24px; flex-wrap: wrap; }
.filter-bar a {
  padding: 8px 16px;
  border-radius: var(--r-pill);
  background: var(--surface);
  border: 1px solid var(--border-strong);
  color: var(--text-primary);
  font-size: 13px;
  text-decoration: none;
  font-weight: 600;
  min-height: 36px;
  display: inline-flex;
  align-items: center;
}
.filter-bar a:hover { color: var(--accent); border-color: var(--accent); }
.filter-bar a.active { background: var(--accent); color: var(--accent-contrast); border-color: var(--accent); }

/* ─── Events list ────────────────────────────────────────────────── */
.event-list {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 12px;
}
.event-list li {
  padding: 22px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  transition: border-color .12s ease, box-shadow .12s ease;
}
.event-list li:hover { border-color: var(--accent); box-shadow: var(--shadow-sm); }
.event-list .row1 { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 8px; font-size: 13px; color: var(--text-muted); }
.event-list a.title { color: var(--text-primary); font-weight: 600; text-decoration: none; font-size: 17px; line-height: 1.4; letter-spacing: -0.005em; }
.event-list a.title:hover { color: var(--accent); }
.event-list p.summary { margin: 8px 0 0; color: var(--text-secondary); font-size: 14px; max-width: 70ch; line-height: 1.55; }

/* ─── Footer ─────────────────────────────────────────────────────── */
.site-footer {
  background: var(--navy);
  color: var(--navy-text);
  padding: 48px 0 36px;
  margin-top: 96px;
}
.site-footer .row { display: flex; gap: 22px; flex-wrap: wrap; margin-bottom: 18px; }
.site-footer .row a { color: var(--navy-text); text-decoration: none; font-size: 14px; font-weight: 500; }
.site-footer .row a:hover { color: var(--accent); }
.site-footer .disclaimer { font-size: 12px; color: var(--navy-muted); line-height: 1.6; max-width: 880px; margin: 0 0 8px; }
.site-footer .addr       { font-size: 12px; color: var(--navy-muted); margin: 0; }

/* ─── Misc page chrome ───────────────────────────────────────────── */
main { display: block; }
.page { padding: 64px 0 80px; }
.page h1 { margin-bottom: 14px; font-size: 36px; letter-spacing: -0.025em; }
@media (min-width: 760px) { .page h1 { font-size: 44px; } }
.page .lede { font-size: 18px; color: var(--text-secondary); max-width: 65ch; margin-bottom: 32px; line-height: 1.55; }
.cta-row { display: flex; gap: 12px; flex-wrap: wrap; }
article + article { margin-top: 18px; }
.page ol, .page ul { padding-left: 24px; color: var(--text-primary); }
.page ol li, .page ul li { margin: 8px 0; }
hr { border: none; border-top: 1px solid var(--border); margin: 36px 0; }

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: 28px;
  box-shadow: var(--shadow-sm);
}

/* skip link for a11y */
.skip-link { position: absolute; left: -9999px; top: 0; background: var(--navy); color: #fff; padding: 8px 14px; border-radius: 0 0 var(--r-btn) 0; z-index: 100; }
.skip-link:focus { left: 0; }

a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.status-pill {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--r-pill);
  background: var(--surface-sunken);
  color: var(--text-primary);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.status-pill-success { background: var(--ok-bg);        color: var(--ok); }
.status-pill-warning { background: var(--risk-med-bg);  color: var(--risk-med); }
.status-pill-info    { background: var(--info-bg);      color: var(--info); }
.status-pill-danger  { background: var(--risk-high-bg); color: var(--risk-high); }
