/* ═══════════════════════════════════════════════════════
   COMPLIANCE WITH CARE — Design System
   Laradon.org WCAG 2.2 AA Accessibility Audit
   ═══════════════════════════════════════════════════════ */

:root {
  /* Brand palette */
  --teal: #0d7377;
  --teal-dark: #054547;
  --teal-deeper: #03302f;
  --teal-light: #e6f5f5;
  --teal-mid: rgba(13,115,119,0.07);
  --coral: #e8725c;
  --coral-light: #fdf0ee;
  --coral-dark: #c4513d;
  --coral-glow: rgba(232,114,92,0.12);

  /* Neutrals */
  --cream: #f9f7f4;
  --cream-dark: #eee9e2;
  --warm-white: #ffffff;
  --text: #2a2d2e;
  --text-light: #5a6368;
  --text-muted: #97a0a5;
  --border: #e2ddd6;

  /* Semantic */
  --red: #c0392b;
  --red-bg: #fdf2f2;
  --orange: #d35400;
  --orange-bg: #fef6f0;
  --green: #0e8c6f;
  --green-bg: #eef9f5;
  --blue: #2471a3;
  --blue-bg: #edf4fb;
  --gold: #8b6914;
  --gold-bg: #fef9e7;

  /* Typography */
  --font-body: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-display: 'DM Serif Display', Georgia, 'Times New Roman', serif;
  --leading: 1.78;
  --leading-tight: 1.35;

  /* Elevation */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.03), 0 1px 2px rgba(0,0,0,0.04);
  --shadow: 0 2px 8px rgba(0,0,0,0.04), 0 4px 16px rgba(0,0,0,0.03);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.05), 0 8px 24px rgba(0,0,0,0.04);
  --shadow-lg: 0 8px 20px rgba(0,0,0,0.06), 0 16px 40px rgba(0,0,0,0.05);

  /* Shape */
  --radius: 16px;
  --radius-sm: 10px;
  --radius-lg: 22px;
  --radius-pill: 100px;
}

/* ─── Reset ──────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);color:var(--text);background:var(--cream);line-height:var(--leading);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* Branded selection */
::selection{background:rgba(13,115,119,0.14);color:var(--text)}
::-moz-selection{background:rgba(13,115,119,0.14);color:var(--text)}

/* Accessible focus */
:focus-visible{outline:2px solid var(--coral);outline-offset:3px;border-radius:4px}
.site-nav :focus-visible{outline-color:rgba(255,255,255,0.7)}

/* Subtle scrollbar */
@supports(scrollbar-width:thin){
  html{scrollbar-width:thin;scrollbar-color:var(--cream-dark) transparent}
}
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--cream-dark);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--border)}

/* ─── Global Typography ──────────────────────────────── */
p{margin-bottom:16px;font-size:0.92rem;color:var(--text);letter-spacing:-0.006em}
strong{font-weight:600}
a{color:var(--teal);text-decoration-thickness:1px;text-underline-offset:3px;transition:color 0.2s,text-decoration-color 0.2s}
a:hover{color:var(--coral);text-decoration-color:var(--coral)}
code{font-family:'DM Mono','Fira Code',monospace;font-size:0.8em;background:var(--cream-dark);padding:2px 7px;border-radius:5px;color:var(--coral-dark);word-break:break-word;border:1px solid rgba(0,0,0,0.04)}
ul,ol{margin:10px 0 18px 24px}
li{margin-bottom:7px;font-size:0.9rem;line-height:1.72}
li strong{color:var(--text)}
hr{border:none;border-top:1px solid var(--border);margin:32px 0}

/* ─── Navigation ─────────────────────────────────────── */
.site-nav{background:var(--teal-deeper);padding:0 40px;position:sticky;top:0;z-index:200;border-bottom:3px solid var(--coral);backdrop-filter:blur(8px)}
.site-nav-inner{max-width:980px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:56px}
.site-nav .brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:white;font-family:var(--font-display);font-size:1rem;letter-spacing:-0.01em;white-space:nowrap}
.site-nav .brand .icon{font-size:1rem;background:var(--coral);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.site-nav .nav-links{display:flex;gap:2px;list-style:none;flex-wrap:wrap;align-items:center}
.site-nav .nav-links a{color:rgba(255,255,255,0.5);text-decoration:none;font-size:0.68rem;font-weight:500;padding:5px 8px;border-radius:6px;transition:all 0.2s;white-space:nowrap;letter-spacing:0.01em}
.site-nav .nav-links a:hover{color:white;background:rgba(255,255,255,0.08)}
.site-nav .nav-links a.active{color:white;background:rgba(255,255,255,0.12);font-weight:600}

/* ─── Hero ───────────────────────────────────────────── */
.hero{background:linear-gradient(160deg,#021f1f 0%,var(--teal-deeper) 20%,var(--teal-dark) 45%,var(--teal) 78%,#1a9a9e 100%);color:white;padding:72px 40px 60px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-30%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(232,114,92,0.08) 0%,rgba(232,114,92,0.03) 40%,transparent 70%);border-radius:50%;pointer-events:none}
.hero::after{content:'';position:absolute;bottom:-25%;left:-8%;width:450px;height:450px;background:radial-gradient(circle,rgba(255,255,255,0.025) 0%,transparent 60%);border-radius:50%;pointer-events:none}
.hero-inner{max-width:980px;margin:0 auto;position:relative;z-index:1}
.hero h1{font-family:var(--font-display);font-size:2.6rem;line-height:1.28;margin-bottom:18px;font-weight:400;letter-spacing:-0.015em}
.hero h1 em{font-style:normal;color:var(--coral);display:inline-block}
.hero-sub{font-size:0.96rem;font-weight:300;color:rgba(255,255,255,0.68);max-width:660px;line-height:1.76;margin-bottom:24px;letter-spacing:-0.005em}
.hero-sub a{color:rgba(255,255,255,0.82);text-decoration:underline;text-underline-offset:3px;transition:color 0.2s}
.hero-sub a:hover{color:white}
.hero-meta{display:flex;gap:24px;flex-wrap:wrap;font-size:0.78rem;color:rgba(255,255,255,0.35);letter-spacing:0.005em}
.hero-meta strong{color:rgba(255,255,255,0.68)}

/* ─── Layout ─────────────────────────────────────────── */
.wrap{max-width:980px;margin:0 auto;padding:0 40px}
.content-wrap{max-width:980px;margin:0 auto;padding:36px 40px 64px}

/* ─── Cards ──────────────────────────────────────────── */
.card{background:var(--warm-white);border:1px solid var(--border);border-radius:var(--radius);padding:44px 46px;margin-bottom:24px;box-shadow:var(--shadow);transition:box-shadow 0.3s ease}
.card:hover{box-shadow:var(--shadow-md)}
.card h2{font-family:var(--font-display);font-size:1.55rem;color:var(--teal-dark);margin-bottom:14px;display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;line-height:1.32;letter-spacing:-0.01em}
.card h2 .tag{background:var(--coral);color:white;font-family:var(--font-body);font-size:0.56rem;font-weight:700;padding:4px 13px;border-radius:var(--radius-pill);letter-spacing:0.09em;text-transform:uppercase;white-space:nowrap;position:relative;top:-1px}
.lead{font-size:0.96rem;color:var(--text-light);margin-bottom:26px;max-width:700px;line-height:1.82}
h3{font-family:var(--font-display);font-size:1.12rem;color:var(--teal);margin:32px 0 12px;line-height:var(--leading-tight);letter-spacing:-0.005em}
.card > h3:first-child,.card > div + h3{margin-top:0}
h4{font-size:0.76rem;font-weight:600;color:var(--text-muted);margin:22px 0 10px;text-transform:uppercase;letter-spacing:0.07em}

/* ─── Tables ─────────────────────────────────────────── */
table{width:100%;border-collapse:collapse;font-size:0.84rem;margin:16px 0 24px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--cream-dark)}
thead th{background:var(--teal-dark);color:white;font-weight:600;text-align:left;padding:11px 16px;font-size:0.67rem;text-transform:uppercase;letter-spacing:0.08em;border-bottom:2px solid var(--coral)}
tbody td{padding:11px 16px;border-bottom:1px solid var(--cream-dark);vertical-align:top;line-height:1.65}
tbody tr:nth-child(even){background:rgba(249,247,244,0.5)}
tbody tr:hover{background:var(--teal-mid)}
tbody tr:last-child td{border-bottom:none}
tbody td a{font-weight:500}
table code{font-size:0.78em;padding:1px 5px}

/* ─── Badges ─────────────────────────────────────────── */
.badge{display:inline-block;padding:3px 11px;border-radius:var(--radius-pill);font-size:0.6rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em}
.b-crit{background:var(--red-bg);color:var(--red);border:1px solid rgba(192,57,43,0.12)}
.b-maj{background:var(--orange-bg);color:var(--orange);border:1px solid rgba(211,84,0,0.12)}
.b-min{background:var(--blue-bg);color:var(--blue);border:1px solid rgba(36,113,163,0.12)}
.b-risk{background:var(--gold-bg);color:var(--gold);border:1px solid rgba(139,105,20,0.12)}
.b-low{background:var(--green-bg);color:var(--green);border:1px solid rgba(14,140,111,0.12)}

/* ─── Callout Notes ──────────────────────────────────── */
.note{border-radius:var(--radius);padding:24px 28px;margin:20px 0;font-size:0.88rem;line-height:1.78;position:relative;border:1px solid transparent}
.note-urgent{background:linear-gradient(140deg,#fef5f5,#fce8e8);border-left:4px solid var(--red);border-color:rgba(192,57,43,0.08);border-left-color:var(--red)}
.note-warm{background:linear-gradient(140deg,#fef5f2,#fce8e4);border-left:4px solid var(--coral);border-color:rgba(232,114,92,0.1);border-left-color:var(--coral)}
.note-calm{background:linear-gradient(140deg,#edf8f8,#e2f2f2);border-left:4px solid var(--teal);border-color:rgba(13,115,119,0.08);border-left-color:var(--teal)}
.note-hope{background:linear-gradient(140deg,#f0faf6,#e2f5ed);border-left:4px solid var(--green);border-color:rgba(14,140,111,0.08);border-left-color:var(--green)}
.note strong{display:block;margin-bottom:8px;font-size:0.93rem;letter-spacing:-0.005em}
.note p:last-child{margin-bottom:0}

/* ─── Blockquote (reusable) ──────────────────────────── */
blockquote,.quote{border-left:3px solid var(--coral);padding:20px 28px;margin:22px 0;background:linear-gradient(135deg,#fef6f4,var(--coral-light));border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:0.9rem;color:var(--text-light);font-style:italic;line-height:1.82;border:1px solid rgba(232,114,92,0.08);border-left:3px solid var(--coral)}
blockquote strong,.quote strong{color:var(--text);font-style:normal}
blockquote cite,.quote cite{display:block;margin-top:10px;font-size:0.76rem;font-style:normal;color:var(--text-muted);letter-spacing:0.01em}

/* ─── Evidence Block (reusable) ──────────────────────── */
.evidence{background:linear-gradient(135deg,var(--cream),#f5f2ed);border:1px solid var(--cream-dark);border-radius:var(--radius-sm);padding:18px 22px;margin:16px 0;font-size:0.86rem;line-height:1.74}
.evidence::before{content:'Evidence';display:block;font-size:0.6rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--teal);margin-bottom:8px}
.evidence a{font-weight:600}

/* ─── Stat Bar (reusable) ────────────────────────────── */
.stat-bar{display:flex;align-items:center;gap:16px;background:var(--warm-white);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 22px;margin:10px 0;box-shadow:var(--shadow-sm)}
.stat-bar .stat-num{font-size:1.8rem;font-weight:700;line-height:1;flex-shrink:0;min-width:60px}
.stat-bar .stat-label{font-size:0.82rem;color:var(--text-light);line-height:1.5}
.stat-bar .stat-label strong{color:var(--text)}

/* ─── Section Intro (reusable) ───────────────────────── */
.section-intro{font-size:1.04rem;color:var(--text-light);line-height:1.88;margin-bottom:28px;max-width:720px;padding-bottom:22px;border-bottom:1px solid var(--cream-dark);letter-spacing:-0.005em}

/* ─── Cite Link (reusable inline) ────────────────────── */
a.cite{font-size:0.75rem;font-weight:600;color:var(--teal);background:var(--teal-light);padding:1px 7px;border-radius:var(--radius-pill);text-decoration:none;white-space:nowrap;transition:all 0.15s}
a.cite:hover{background:var(--teal);color:white}

/* ─── Verdict Chip (reusable) ────────────────────────── */
.verdict{display:inline-flex;align-items:center;gap:5px;font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;padding:4px 12px;border-radius:var(--radius-pill)}
.verdict-fail{background:var(--red-bg);color:var(--red)}
.verdict-pass{background:var(--green-bg);color:var(--green)}
.verdict-warn{background:var(--orange-bg);color:var(--orange)}
.verdict-risk{background:var(--gold-bg);color:var(--gold)}

/* ─── Pills ──────────────────────────────────────────── */
.pills{display:flex;flex-wrap:wrap;gap:14px;margin:20px 0}
.pill{background:var(--warm-white);border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px;text-align:center;flex:1;min-width:140px;box-shadow:var(--shadow-sm);transition:all 0.25s ease}
.pill:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.pill .pv{font-size:1.65rem;font-weight:700;line-height:1;letter-spacing:-0.02em}
.pill .pl{font-size:0.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;margin-top:6px}

/* ─── People Cards ───────────────────────────────────── */
.people-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:20px 0}
.person-card{border:1px solid var(--border);border-radius:var(--radius);padding:24px;background:linear-gradient(145deg,var(--warm-white),var(--cream));transition:all 0.25s ease}
.person-card:hover{box-shadow:var(--shadow-md);border-color:var(--teal);transform:translateY(-1px)}
.person-card h4{margin:0 0 10px;text-transform:none;letter-spacing:-0.005em;font-size:0.94rem;color:var(--teal-dark);font-weight:600}
.person-card .barrier{color:var(--coral-dark);font-size:0.84rem;margin-bottom:8px;line-height:1.65}
.person-card .after{color:var(--teal);font-size:0.84rem;line-height:1.65}

/* ─── Resolution Box ─────────────────────────────────── */
.resolution-box{background:linear-gradient(145deg,var(--teal-deeper),var(--teal-dark) 60%,var(--teal));color:white;border-radius:var(--radius);padding:30px 36px;margin:22px 0;font-size:0.9rem;line-height:1.9;box-shadow:var(--shadow-md)}
.resolution-box strong{color:var(--coral)}
.resolution-box ul{margin-top:10px;margin-bottom:0}
.resolution-box li{color:rgba(255,255,255,0.88);margin-bottom:8px}
.resolution-box a{color:rgba(255,255,255,0.88);text-decoration:underline;text-underline-offset:3px}
.resolution-box a:hover{color:white}
.resolution-box code{background:rgba(255,255,255,0.12);color:var(--coral);border-radius:4px}

/* ─── Home Grid ──────────────────────────────────────── */
.home-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:24px 0}
.home-card{background:var(--warm-white);border:1px solid var(--border);border-radius:var(--radius);padding:28px 30px;text-decoration:none;color:var(--text);transition:all 0.3s cubic-bezier(0.4,0,0.2,1);display:block;position:relative;overflow:hidden}
.home-card::after{content:'→';position:absolute;bottom:16px;right:18px;font-size:1.1rem;color:var(--cream-dark);transition:all 0.3s cubic-bezier(0.4,0,0.2,1);font-weight:300}
.home-card:hover{box-shadow:var(--shadow-lg);border-color:var(--coral);transform:translateY(-2px)}
.home-card:hover::after{color:var(--coral);right:15px}
.home-card .card-num{font-size:0.62rem;font-weight:700;color:var(--coral);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:6px}
.home-card .card-title{font-family:var(--font-display);font-size:1.1rem;color:var(--teal-dark);margin-bottom:8px;line-height:var(--leading-tight);letter-spacing:-0.01em}
.home-card .card-desc{font-size:0.82rem;color:var(--text-light);line-height:1.65;padding-right:22px}

/* ─── Metrics Row ────────────────────────────────────── */
.metrics-row{display:grid;grid-template-columns:repeat(5,1fr);gap:0;background:var(--warm-white);border:1px solid var(--border);border-radius:var(--radius);margin:24px 0;overflow:hidden;box-shadow:var(--shadow)}
.metric-item{padding:22px 18px;text-align:center;border-right:1px solid var(--cream-dark);position:relative}
.metric-item:last-child{border-right:none}
.metric-item .mv{font-size:1.75rem;font-weight:700;line-height:1;letter-spacing:-0.02em}
.metric-item .ml{font-size:0.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;margin-top:7px}

/* ─── Two-Column Layout (reusable) ───────────────────── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:16px 0}
.two-col > *{min-width:0}

/* ─── Law Excerpt (statute quote) ────────────────────── */
.law-excerpt{border-left:4px solid var(--teal);background:linear-gradient(140deg,#eef8f8,#e4f2f2);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:22px 26px;margin:18px 0;font-size:0.9rem;line-height:1.85;color:var(--text);border:1px solid rgba(13,115,119,0.06);border-left:4px solid var(--teal)}
.law-excerpt .law-text{font-style:italic;color:var(--text-light);margin-bottom:10px}
.law-excerpt .law-text strong{color:var(--text);font-style:normal}
.law-excerpt .law-source{font-size:0.7rem;font-weight:600;color:var(--teal);text-transform:uppercase;letter-spacing:0.06em}
.law-excerpt .law-source a{color:var(--teal);text-decoration:underline;text-underline-offset:2px}
.law-excerpt .law-applies{font-size:0.84rem;color:var(--coral-dark);font-weight:600;margin-top:10px;padding-top:10px;border-top:1px solid rgba(13,115,119,0.12)}

/* ─── Law Cards (framework grid) ────────────────────── */
.law-grid{display:grid;grid-template-columns:1fr;gap:16px;margin:18px 0}
.law-card{border:1px solid var(--border);border-radius:var(--radius);padding:26px 30px;background:var(--warm-white);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:all 0.25s ease}
.law-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.law-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%}
.law-card.lc-red::before{background:var(--red)}
.law-card.lc-orange::before{background:var(--orange)}
.law-card.lc-blue::before{background:var(--blue)}
.law-card.lc-gold::before{background:var(--gold)}
.law-card .lc-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.law-card .lc-title{font-family:var(--font-display);font-size:1.05rem;color:var(--teal-dark);line-height:var(--leading-tight)}
.law-card .lc-deadline{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;padding:3px 10px;border-radius:var(--radius-pill)}
.law-card .lc-deadline.dl-expired{background:var(--red-bg);color:var(--red)}
.law-card .lc-deadline.dl-soon{background:var(--orange-bg);color:var(--orange)}
.law-card .lc-deadline.dl-risk{background:var(--gold-bg);color:var(--gold)}
.law-card .lc-body{font-size:0.86rem;color:var(--text-light);line-height:1.75;margin-bottom:12px}
.law-card .lc-body strong{color:var(--text)}
.law-card .lc-exposure{font-size:0.92rem;font-weight:700;padding:10px 16px;border-radius:var(--radius-sm);margin-top:10px;display:inline-block}
.law-card .lc-exposure.ex-red{background:var(--red-bg);color:var(--red)}
.law-card .lc-exposure.ex-orange{background:var(--orange-bg);color:var(--orange)}

/* ─── Risk Cards ────────────────────────────────────── */
.risk-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:18px 0}
.risk-card{border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;background:var(--warm-white);box-shadow:var(--shadow-sm);text-align:center;transition:all 0.25s ease}
.risk-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.risk-card .rc-score{font-size:1.8rem;font-weight:700;line-height:1;margin-bottom:4px}
.risk-card .rc-label{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;color:var(--text-muted);margin-bottom:8px}
.risk-card .rc-detail{font-size:0.78rem;color:var(--text-light);line-height:1.6;text-align:left}
.risk-card .rc-detail a{font-weight:500}

/* ─── Comparison Cards (proactive vs reactive) ──────── */
.compare-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:18px 0}
.compare-card{border-radius:var(--radius);padding:26px 28px;position:relative;transition:all 0.25s ease}
.compare-card:hover{transform:translateY(-1px)}
.compare-card.cc-good{background:linear-gradient(145deg,#f0faf6,var(--green-bg));border:2px solid var(--green)}
.compare-card.cc-bad{background:linear-gradient(145deg,#fef5f4,var(--red-bg));border:2px solid var(--red)}
.compare-card .cc-label{font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:8px}
.compare-card.cc-good .cc-label{color:var(--green)}
.compare-card.cc-bad .cc-label{color:var(--red)}
.compare-card .cc-price{font-size:1.6rem;font-weight:700;line-height:1.2;margin-bottom:10px}
.compare-card.cc-good .cc-price{color:var(--green)}
.compare-card.cc-bad .cc-price{color:var(--red)}
.compare-card .cc-items{list-style:none;margin:0;padding:0}
.compare-card .cc-items li{font-size:0.82rem;line-height:1.6;color:var(--text-light);padding:4px 0;border-bottom:1px solid rgba(0,0,0,0.06)}
.compare-card .cc-items li:last-child{border-bottom:none}
.compare-card .cc-items li strong{color:var(--text)}

/* ─── Timeline (vertical) ───────────────────────────── */
.timeline{position:relative;padding-left:32px;margin:20px 0}
.timeline::before{content:'';position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--teal),var(--coral));border-radius:2px}
.tl-item{position:relative;padding-bottom:24px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:'';position:absolute;left:-25px;top:6px;width:12px;height:12px;border-radius:50%;border:2px solid var(--teal);background:var(--warm-white);z-index:1;transition:all 0.2s}
.tl-item.tl-past::before{background:var(--red);border-color:var(--red)}
.tl-item.tl-now::before{background:var(--orange);border-color:var(--orange);box-shadow:0 0 0 4px rgba(211,84,0,0.15)}
.tl-item.tl-soon::before{background:var(--coral);border-color:var(--coral)}
.tl-item.tl-future::before{background:var(--teal-light);border-color:var(--teal)}
.tl-date{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-muted);margin-bottom:3px}
.tl-title{font-family:var(--font-display);font-size:1rem;color:var(--teal-dark);margin-bottom:4px;line-height:1.35}
.tl-title a{color:var(--teal-dark);text-decoration:underline;text-underline-offset:2px}
.tl-status{font-size:0.78rem;font-weight:600;line-height:1.5}

/* ─── Journey Cards ─────────────────────────────────── */
.journey-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:18px 0}
.journey-card{border:1px solid var(--border);border-radius:var(--radius);padding:24px 26px;background:var(--warm-white);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:all 0.25s ease}
.journey-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.journey-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--red)}
.journey-card .jc-task{font-family:var(--font-display);font-size:1.05rem;color:var(--teal-dark);margin-bottom:6px}
.journey-card .jc-page{font-size:0.76rem;color:var(--text-muted);margin-bottom:10px}
.journey-card .jc-page a{color:var(--teal);font-weight:500}
.journey-card .jc-verdict{margin-bottom:10px}
.journey-card .jc-detail{font-size:0.84rem;color:var(--text-light);line-height:1.65}
.journey-card .jc-tabs{font-size:0.72rem;font-weight:600;color:var(--text-muted);margin-top:8px}

/* ─── Action Items (checklist) ──────────────────────── */
.action-list{margin:16px 0;display:flex;flex-direction:column;gap:12px}
.action-item{display:flex;gap:16px;border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;background:var(--warm-white);box-shadow:var(--shadow-sm);transition:all 0.2s;align-items:flex-start}
.action-item:hover{box-shadow:var(--shadow-md)}
.action-item .ai-num{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:var(--teal);color:white;font-size:0.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:2px}
.action-item .ai-body{flex:1;min-width:0}
.action-item .ai-title{font-weight:600;font-size:0.9rem;color:var(--text);margin-bottom:4px;line-height:1.5}
.action-item .ai-title code{font-size:0.78em}
.action-item .ai-meta{font-size:0.78rem;color:var(--text-muted);margin-bottom:6px}
.action-item .ai-meta a{font-weight:500}
.action-item .ai-detail{font-size:0.84rem;color:var(--text-light);line-height:1.65}
.action-item .ai-detail a{font-weight:500}

/* ─── Finding Cards ─────────────────────────────────── */
.finding-list{display:flex;flex-direction:column;gap:14px;margin:18px 0}
.finding-card{border:1px solid var(--border);border-radius:var(--radius);padding:22px 26px;background:var(--warm-white);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:all 0.25s ease;display:grid;grid-template-columns:40px 1fr;gap:16px;align-items:start}
.finding-card:hover{box-shadow:var(--shadow-md)}
.finding-card .fc-num{font-size:1.3rem;font-weight:700;color:var(--teal);line-height:1;padding-top:2px}
.finding-card .fc-body{min-width:0}
.finding-card .fc-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.finding-card .fc-title{font-weight:600;font-size:0.94rem;color:var(--text);line-height:1.4}
.finding-card .fc-desc{font-size:0.84rem;color:var(--text-light);line-height:1.7;margin-bottom:8px}
.finding-card .fc-desc a{font-weight:500}
.finding-card .fc-foot{display:flex;gap:10px;flex-wrap:wrap;align-items:center;font-size:0.76rem;color:var(--text-muted)}
.finding-card .fc-foot a{font-weight:500;font-size:0.76rem}

/* ─── Concept Cards ─────────────────────────────────── */
.concept-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:18px 0}
.concept-card{border:1px solid var(--border);border-radius:var(--radius);padding:24px 26px;background:var(--warm-white);box-shadow:var(--shadow-sm);transition:all 0.25s ease}
.concept-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.concept-card .cc-name{font-family:var(--font-display);font-size:1rem;color:var(--coral-dark);margin-bottom:6px}
.concept-card .cc-meaning{font-size:0.86rem;color:var(--text);line-height:1.7;margin-bottom:10px}
.concept-card .cc-evidence{font-size:0.78rem;color:var(--text-muted);line-height:1.6;padding-top:10px;border-top:1px solid var(--cream-dark)}
.concept-card .cc-evidence a{font-weight:500;color:var(--teal)}

/* ─── Owner Cards ───────────────────────────────────── */
.owner-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:18px 0}
.owner-card{border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;background:var(--warm-white);box-shadow:var(--shadow-sm);transition:all 0.25s ease}
.owner-card:hover{box-shadow:var(--shadow-md)}
.owner-card .oc-who{font-family:var(--font-display);font-size:0.96rem;color:var(--teal-dark);margin-bottom:6px}
.owner-card .oc-what{font-size:0.84rem;color:var(--text-light);line-height:1.65;margin-bottom:6px}
.owner-card .oc-when{font-size:0.72rem;font-weight:600;color:var(--coral);text-transform:uppercase;letter-spacing:0.04em}

/* ─── Stat Grid ─────────────────────────────────────── */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin:18px 0}
.stat-item{border:1px solid var(--border);border-radius:var(--radius-sm);padding:18px 20px;background:var(--warm-white);box-shadow:var(--shadow-sm)}
.stat-item .si-val{font-size:1.2rem;font-weight:700;color:var(--teal-dark);line-height:1.2;margin-bottom:4px}
.stat-item .si-label{font-size:0.78rem;color:var(--text-light);line-height:1.5}
.stat-item .si-label a{font-weight:500}

/* ─── Phase Cards ───────────────────────────────────── */
.phase-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:18px 0}
.phase-card{border:1px solid var(--border);border-radius:var(--radius);padding:24px 26px;background:var(--warm-white);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:all 0.25s ease}
.phase-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.phase-card .pc-num{font-size:0.6rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--coral);margin-bottom:6px}
.phase-card .pc-title{font-family:var(--font-display);font-size:1.05rem;color:var(--teal-dark);margin-bottom:4px}
.phase-card .pc-meta{font-size:0.76rem;font-weight:600;color:var(--text-muted);margin-bottom:8px}
.phase-card .pc-desc{font-size:0.84rem;color:var(--text-light);line-height:1.65}

/* ─── Peer Cards ────────────────────────────────────── */
.peer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin:18px 0}
.peer-card{border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;background:var(--warm-white);box-shadow:var(--shadow-sm);text-align:center;transition:all 0.25s ease}
.peer-card:hover{box-shadow:var(--shadow-md)}
.peer-card.peer-self{border-color:var(--red);background:linear-gradient(145deg,#fef5f4,var(--red-bg))}
.peer-card .pc-org{font-family:var(--font-display);font-size:0.96rem;color:var(--teal-dark);margin-bottom:10px}
.peer-card .pc-org a{color:var(--teal-dark)}
.peer-card .pc-row{display:flex;justify-content:space-between;font-size:0.78rem;padding:5px 0;border-bottom:1px solid var(--cream-dark);color:var(--text-light)}
.peer-card .pc-row:last-child{border-bottom:none}
.peer-card .pc-row strong{color:var(--text)}

/* ─── Impact Trails ─────────────────────────────────── */
.impact-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:18px 0}
.impact-card{border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;background:var(--warm-white);box-shadow:var(--shadow-sm);transition:all 0.25s ease;display:flex;flex-direction:column;gap:10px}
.impact-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.impact-card .ic-finding{font-family:var(--font-display);font-size:0.92rem;color:var(--coral-dark);display:flex;align-items:center;gap:8px}
.impact-card .ic-finding .ic-tag{display:inline-block;background:var(--coral);color:#fff;font-family:var(--font-body);font-size:0.62rem;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;padding:2px 8px;border-radius:10px;white-space:nowrap}
.impact-card .ic-arrow{color:var(--text-muted);font-size:0.78rem;padding-left:2px}
.impact-card .ic-chain{display:flex;flex-direction:column;gap:6px}
.impact-card .ic-effect{font-size:0.82rem;color:var(--text);line-height:1.6;padding-left:14px;border-left:2px solid var(--cream-dark)}
.impact-card .ic-effect strong{color:var(--red)}
.impact-card .ic-link{font-size:0.74rem;color:var(--teal);font-weight:600;margin-top:auto}

/* ─── Nav Dropdowns ──────────────────────────────────── */
.nav-drop{position:relative}
.nav-drop-btn{background:none;border:none;cursor:pointer;color:rgba(255,255,255,0.5);font-size:0.68rem;font-weight:500;padding:5px 8px;border-radius:6px;transition:all 0.15s;white-space:nowrap;font-family:inherit;display:flex;align-items:center;gap:4px;letter-spacing:0.01em}
.nav-drop-btn:hover{color:white;background:rgba(255,255,255,0.1)}
.nav-drop-btn .caret{font-size:0.6rem;transition:transform 0.2s;display:inline-block}
.nav-drop.open .nav-drop-btn .caret{transform:rotate(180deg)}
.nav-drop-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);min-width:160px;background:var(--teal-deeper);border:1px solid rgba(255,255,255,0.12);border-radius:var(--radius-sm);box-shadow:0 8px 24px rgba(0,0,0,0.3);padding:6px 0;opacity:0;visibility:hidden;transition:opacity 0.2s,visibility 0.2s;z-index:400;margin-top:4px}
@media(hover:hover){.nav-drop:hover .nav-drop-menu{opacity:1;visibility:visible}}
.nav-drop.open .nav-drop-menu{opacity:1;visibility:visible}
.site-nav .nav-links .nav-drop-menu a{display:block;color:rgba(255,255,255,0.7);font-size:0.76rem;font-weight:500;padding:9px 18px;text-decoration:none;transition:all 0.15s;white-space:nowrap;border-radius:0}
.site-nav .nav-links .nav-drop-menu a:hover{color:white;background:rgba(255,255,255,0.1)}
.site-nav .nav-links .nav-drop-menu a.active{color:white;background:rgba(232,114,92,0.15);font-weight:600}

/* ─── Separator (reusable) ───────────────────────────── */
.sep{border:none;border-top:2px solid var(--cream-dark);margin:32px 0;position:relative}

/* ─── Page Navigation ────────────────────────────────── */
.page-nav{display:flex;justify-content:space-between;align-items:center;margin-top:36px;padding-top:28px;border-top:2px solid var(--cream-dark)}
.page-nav a{text-decoration:none;font-size:0.82rem;font-weight:600;color:var(--teal-dark);padding:11px 22px;border:1px solid var(--border);border-radius:var(--radius-sm);transition:all 0.25s cubic-bezier(0.4,0,0.2,1);background:var(--warm-white);box-shadow:var(--shadow-sm)}
.page-nav a:hover{background:var(--teal);border-color:var(--teal);color:white;box-shadow:var(--shadow-md);transform:translateY(-1px)}
.page-nav .spacer{flex:1}

/* ─── Footer ─────────────────────────────────────────── */
footer{background:linear-gradient(180deg,var(--teal-dark),var(--teal-deeper));color:rgba(255,255,255,0.38);padding:40px 40px;text-align:center;font-size:0.76rem;margin-top:0;border-top:3px solid var(--teal);letter-spacing:0.015em;line-height:1.7}
footer strong{color:var(--coral)}

/* ─── Print ──────────────────────────────────────────── */
@media print{
  .site-nav{position:static;print-color-adjust:exact;-webkit-print-color-adjust:exact}
  .card{break-inside:avoid;box-shadow:none;border:1px solid #ccc}
  .hero{break-after:page}
  .page-nav{display:none}
}

/* ─── Hamburger Button (hidden on desktop) ──────────── */
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px;margin-right:-6px;position:relative;z-index:310;-webkit-tap-highlight-color:transparent}
.menu-toggle span{display:block;width:22px;height:2px;background:white;border-radius:2px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);position:relative}
.menu-toggle span::before,.menu-toggle span::after{content:'';position:absolute;left:0;width:22px;height:2px;background:white;border-radius:2px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1)}
.menu-toggle span::before{top:-7px}
.menu-toggle span::after{top:7px}
.menu-toggle.open span{background:transparent}
.menu-toggle.open span::before{top:0;transform:rotate(45deg)}
.menu-toggle.open span::after{top:0;transform:rotate(-45deg)}

/* ─── Mobile Overlay ────────────────────────────────── */
.nav-overlay{display:none}

/* ─── Mobile ─────────────────────────────────────────── */
@media(max-width:768px){
  .hero{padding:44px 22px 36px}
  .hero h1{font-size:1.75rem}
  .hero-sub{font-size:0.9rem;line-height:1.7}
  .content-wrap,.wrap{padding-left:20px;padding-right:20px}
  .card{padding:28px 24px;margin-bottom:18px}
  .card h2{font-size:1.32rem}
  .home-grid,.people-grid,.two-col{grid-template-columns:1fr}
  .metrics-row{grid-template-columns:repeat(3,1fr)}
  .metric-item{padding:18px 14px}
  .metric-item .mv{font-size:1.45rem}
  .metric-item:nth-child(4),.metric-item:nth-child(5){border-top:1px solid var(--cream-dark)}
  .pills{gap:10px}
  .pill{min-width:110px;padding:14px 16px}
  .pill .pv{font-size:1.35rem}
  table{font-size:0.78rem}
  thead th{padding:9px 12px;font-size:0.64rem}
  tbody td{padding:9px 12px}
  .site-nav{padding:0 16px}
  .stat-bar{flex-direction:column;text-align:center;gap:8px}
  .page-nav a{padding:10px 16px;font-size:0.78rem}
  .resolution-box{padding:24px 22px}
  blockquote,.quote{padding:18px 20px}
  .risk-grid,.compare-row{grid-template-columns:1fr}
  .law-excerpt{padding:18px 20px}
  .law-card{padding:22px 24px}
  .compare-card{padding:22px 24px}
  .note{padding:20px 22px}
  .home-card{padding:24px 24px}
  .person-card{padding:20px 22px}
  .journey-grid,.concept-grid,.owner-grid,.phase-grid,.peer-grid,.impact-grid{grid-template-columns:1fr}
  .finding-card{grid-template-columns:32px 1fr;gap:12px;padding:18px 20px}
  .finding-card .fc-num{font-size:1.1rem}
  .action-item{padding:16px 18px;gap:12px}
  .action-item .ai-num{width:28px;height:28px;font-size:0.65rem}
  .stat-grid{grid-template-columns:1fr 1fr}
  .stat-item .si-val{font-size:1rem}
  .timeline{padding-left:28px}

  /* Nav dropdowns → accordion style on mobile */
  .nav-drop{width:100%}
  .nav-drop-btn{width:100%;color:rgba(255,255,255,0.7);font-size:0.92rem;font-weight:500;padding:14px 28px;border-radius:0;border-bottom:1px solid rgba(255,255,255,0.06);justify-content:space-between}
  .nav-drop-btn:hover,.nav-drop-btn:active{color:white;background:rgba(255,255,255,0.08)}
  .nav-drop-menu{position:static;transform:none;opacity:1;visibility:visible;min-width:0;background:rgba(0,0,0,0.15);border:none;border-radius:0;box-shadow:none;padding:0;margin:0;max-height:0;overflow:hidden;transition:max-height 0.3s ease}
  .nav-drop.open .nav-drop-menu{max-height:300px}
  .site-nav .nav-links .nav-drop-menu a{font-size:0.85rem;padding:12px 28px 12px 44px;border-bottom:1px solid rgba(255,255,255,0.04)}
  .site-nav .nav-links .nav-drop-menu a:last-child{border-bottom:1px solid rgba(255,255,255,0.06)}

  /* Hamburger visible on mobile */
  .menu-toggle{display:block}

  /* Overlay */
  .nav-overlay{display:block;position:fixed;inset:0;background:rgba(3,48,47,0.55);z-index:290;opacity:0;pointer-events:none;transition:opacity 0.3s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
  .nav-overlay.open{opacity:1;pointer-events:auto}

  /* Slide-out panel */
  .site-nav .nav-links{
    position:fixed;top:0;right:0;bottom:0;width:280px;max-width:80vw;
    background:var(--teal-deeper);
    display:flex;flex-direction:column;align-items:stretch;gap:0;
    padding:72px 0 32px;
    z-index:300;
    transform:translateX(100%);
    transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);
    box-shadow:-8px 0 32px rgba(0,0,0,0.25);
    overflow-y:auto;-webkit-overflow-scrolling:touch;
  }
  .site-nav .nav-links.open{transform:translateX(0)}
  .site-nav .nav-links a{
    color:rgba(255,255,255,0.7);font-size:0.92rem;font-weight:500;
    padding:14px 28px;border-radius:0;white-space:nowrap;
    border-bottom:1px solid rgba(255,255,255,0.06);
    transition:all 0.15s;
  }
  .site-nav .nav-links a:hover,.site-nav .nav-links a:active{
    color:white;background:rgba(255,255,255,0.08);
  }
  .site-nav .nav-links a.active{
    color:white;background:rgba(232,114,92,0.15);
    border-left:3px solid var(--coral);padding-left:25px;font-weight:600;
  }
}
