/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:#0a0f1e;color:#e2e8f0;line-height:1.6;min-height:100vh}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ===== CSS VARIABLES ===== */
:root{
  --bg-dark:#0a0f1e;
  --bg-mid:#0f1628;
  --bg-card:#141c32;
  --bg-card2:#1a2240;
  --border:#1e2d4d;
  --border-light:#2a3a5c;
  --text-primary:#f0f4ff;
  --text-secondary:#94a3b8;
  --text-muted:#64748b;
  --accent-blue:#6366f1;
  --accent-cyan:#22d3ee;
  --accent-violet:#a78bfa;
  --accent-green:#34d399;
  --accent-red:#f87171;
  --accent-amber:#fbbf24;
  --radius:12px;
  --radius-sm:8px;
  --shadow:0 4px 24px rgba(0,0,0,0.4);
  --shadow-lg:0 8px 48px rgba(0,0,0,0.5);
}

/* ===== NAVBAR ===== */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:60px;
  background:rgba(10,15,30,0.85);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  transition:all 0.3s;
}
.navbar.scrolled{background:rgba(10,15,30,0.97);box-shadow:0 2px 20px rgba(0,0,0,0.5)}
.nav-container{
  max-width:1280px;margin:0 auto;padding:0 24px;
  height:100%;display:flex;align-items:center;justify-content:space-between;
}
.nav-brand{
  display:flex;align-items:center;gap:10px;
  font-family:'DM Sans',sans-serif;font-weight:600;font-size:1.05rem;
  color:var(--text-primary);
}
.brand-dot{
  width:10px;height:10px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent-blue),var(--accent-cyan));
  box-shadow:0 0 8px var(--accent-blue);
}
.nav-links{
  display:flex;align-items:center;gap:8px;
}
.nav-links a{
  padding:6px 14px;border-radius:6px;
  font-size:0.875rem;font-weight:500;
  color:var(--text-secondary);transition:all 0.2s;
}
.nav-links a:hover{color:var(--text-primary);background:rgba(99,102,241,0.1)}
.nav-links a.active{color:var(--accent-blue)}
.nav-cta{
  background:var(--accent-blue)!important;color:#fff!important;
  padding:7px 18px!important;border-radius:8px!important;
  font-weight:600!important;
  box-shadow:0 0 16px rgba(99,102,241,0.4);
  transition:all 0.2s!important;
}
.nav-cta:hover{background:#4f46e5!important;transform:translateY(-1px);box-shadow:0 0 24px rgba(99,102,241,0.6)!important}
.hamburger{
  display:none;background:none;border:none;color:var(--text-primary);
  font-size:1.4rem;cursor:pointer;padding:4px;
}
@media(max-width:768px){
  .hamburger{display:block}
  .nav-links{
    display:none;position:fixed;top:60px;left:0;right:0;
    background:var(--bg-mid);border-bottom:1px solid var(--border);
    flex-direction:column;padding:16px;gap:4px;
  }
  .nav-links.open{display:flex}
}

/* ===== HERO ===== */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:80px 24px 60px;position:relative;overflow:hidden;
  max-width:1280px;margin:0 auto;
}
.hero-backdrop{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
}
.backdrop-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:60px 60px;
  opacity:0.3;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 40%,transparent 100%);
}
.backdrop-blob{
  position:absolute;border-radius:50%;filter:blur(80px);opacity:0.12;
}
.blob-1{width:600px;height:600px;top:-100px;left:-100px;background:radial-gradient(circle,var(--accent-blue),transparent)}
.blob-2{width:500px;height:500px;bottom:-50px;right:-80px;background:radial-gradient(circle,var(--accent-violet),transparent)}
.hero-content{
  flex:1;max-width:620px;
  animation:fadeUp 0.8s ease both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
.hero-eyebrow{
  display:inline-block;padding:4px 14px;
  background:rgba(99,102,241,0.12);border:1px solid rgba(99,102,241,0.3);
  border-radius:100px;font-size:0.78rem;font-weight:500;
  color:var(--accent-blue);letter-spacing:0.05em;margin-bottom:20px;
}
.hero-title{
  font-family:'Crimson Pro',Georgia,serif;
  font-size:clamp(2.8rem,6vw,5rem);font-weight:300;line-height:1.08;
  color:var(--text-primary);margin-bottom:20px;
}
.hero-title em{font-style:italic;color:var(--accent-violet)}
.hero-sub{
  font-size:1.05rem;color:var(--text-secondary);max-width:520px;
  margin-bottom:36px;line-height:1.7;
}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent-blue);color:#fff;
  padding:12px 28px;border-radius:10px;
  font-weight:600;font-size:0.95rem;
  box-shadow:0 0 24px rgba(99,102,241,0.4);
  transition:all 0.2s;
}
.btn-primary:hover{background:#4f46e5;transform:translateY(-2px);box-shadow:0 0 36px rgba(99,102,241,0.6)}
.btn-ghost{
  display:inline-flex;align-items:center;
  padding:12px 28px;border-radius:10px;
  border:1px solid var(--border-light);color:var(--text-secondary);
  font-weight:500;font-size:0.95rem;transition:all 0.2s;
}
.btn-ghost:hover{border-color:var(--accent-blue);color:var(--text-primary);background:rgba(99,102,241,0.06)}
.hero-stats{
  display:flex;align-items:center;gap:0;flex-wrap:wrap;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
}
.hstat{
  flex:1;min-width:100px;padding:16px 20px;text-align:center;
}
.hstat-n{font-family:'DM Mono',monospace;font-size:1.4rem;font-weight:500;color:var(--text-primary)}
.hstat-l{font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em;margin-top:2px}
.hstat-sep{width:1px;background:var(--border);align-self:stretch}
.hero-diagram{flex:0 0 380px;display:flex;justify-content:center;align-items:center}
.diagram-svg{width:100%;max-width:360px}
.p-dot{animation:pulse 3s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:0.4;r:2}50%{opacity:1;r:3.5}}
@media(max-width:900px){
  .hero{flex-direction:column;text-align:center;align-items:center}
  .hero-diagram{display:none}
  .hero-btns{justify-content:center}
  .hero-stats{justify-content:center}
}

/* ===== SECTIONS ===== */
.section{padding:80px 24px}
.bg-dark{background:var(--bg-dark)}
.bg-mid{background:var(--bg-mid)}
.container{max-width:1280px;margin:0 auto}
.sec-head{text-align:center;margin-bottom:56px}
.sec-tag{
  display:inline-block;padding:3px 12px;
  background:rgba(99,102,241,0.1);border:1px solid rgba(99,102,241,0.25);
  border-radius:100px;font-size:0.75rem;color:var(--accent-blue);
  letter-spacing:0.07em;text-transform:uppercase;margin-bottom:12px;
}
.sec-head h2{
  font-family:'Crimson Pro',serif;font-size:clamp(2rem,4vw,3rem);
  font-weight:400;color:var(--text-primary);margin-bottom:12px;
}
.sec-head p{color:var(--text-secondary);max-width:600px;margin:0 auto;font-size:1.02rem}

/* ===== FINDINGS CARDS ===== */
.findings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.fc{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:32px;
  transition:all 0.3s;position:relative;overflow:hidden;
}
.fc::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
}
.fc-cyan::before{background:linear-gradient(90deg,var(--accent-cyan),var(--accent-blue))}
.fc-purple::before{background:linear-gradient(90deg,var(--accent-violet),var(--accent-blue))}
.fc-green::before{background:linear-gradient(90deg,var(--accent-green),var(--accent-cyan))}
.fc:hover{border-color:var(--border-light);transform:translateY(-4px);box-shadow:var(--shadow)}
.fc-paf{
  font-family:'DM Mono',monospace;font-size:2.8rem;font-weight:500;
  color:var(--text-primary);line-height:1;
}
.fc-paf-label{font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:12px;margin-top:2px}
.fc-name{font-weight:600;font-size:1.05rem;color:var(--text-primary);margin-bottom:10px}
.fc p{color:var(--text-secondary);font-size:0.9rem;line-height:1.65}
.fc-link{display:inline-block;margin-top:20px;font-size:0.85rem;color:var(--accent-blue);font-weight:500}
.fc-link:hover{color:var(--accent-cyan)}

/* ===== PATHWAY ===== */
.pathway-row{
  display:flex;align-items:center;justify-content:center;
  gap:0;flex-wrap:wrap;padding:32px 0;
}
.pnode{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:20px 24px;border-radius:var(--radius);
  border:1px solid var(--border);background:var(--bg-card);
  text-align:center;min-width:140px;
}
.pnode-icon{font-size:1.4rem;margin-bottom:2px}
.pnode strong{font-size:0.95rem;color:var(--text-primary)}
.pnode span{font-size:0.78rem;color:var(--text-muted)}
.pnode-blue{border-color:rgba(99,102,241,0.4);box-shadow:0 0 20px rgba(99,102,241,0.1)}
.pnode-blue .pnode-icon{color:var(--accent-blue)}
.pnode-violet{border-color:rgba(167,139,250,0.4);box-shadow:0 0 20px rgba(167,139,250,0.1)}
.pnode-violet .pnode-icon{color:var(--accent-violet)}
.pnode-cyan{border-color:rgba(34,211,238,0.4);box-shadow:0 0 20px rgba(34,211,238,0.1)}
.pnode-cyan .pnode-icon{color:var(--accent-cyan)}
.pnode-red{border-color:rgba(248,113,113,0.4);box-shadow:0 0 20px rgba(248,113,113,0.1)}
.pnode-red .pnode-icon{color:var(--accent-red)}
.parrow{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:0 8px;position:relative;
}
.parrow-line{
  width:60px;height:1px;
  background:linear-gradient(90deg,var(--accent-blue),var(--accent-violet));
  opacity:0.6;
}
.parrow-head{
  width:0;height:0;
  border-left:6px solid var(--accent-violet);
  border-top:4px solid transparent;
  border-bottom:4px solid transparent;
  margin-top:-4px;opacity:0.7;
}
.parrow-label{font-size:0.65rem;color:var(--text-muted);text-align:center;white-space:nowrap}
@media(max-width:900px){
  .pathway-row{flex-direction:column}
  .parrow{transform:rotate(90deg)}
}

/* ===== MODULES GRID ===== */
.modules-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}
.mcard{
  display:block;background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:32px;
  transition:all 0.3s;position:relative;overflow:hidden;
}
.mcard:hover{border-color:var(--accent-blue);transform:translateY(-4px);box-shadow:0 8px 32px rgba(99,102,241,0.2)}
.mcard-featured{
  border-color:rgba(99,102,241,0.4);
  background:linear-gradient(135deg,var(--bg-card),rgba(99,102,241,0.08));
}
.mcard-badge{
  display:inline-block;padding:2px 10px;
  background:rgba(99,102,241,0.2);border:1px solid rgba(99,102,241,0.3);
  border-radius:100px;font-size:0.68rem;color:var(--accent-blue);
  letter-spacing:0.07em;text-transform:uppercase;margin-bottom:12px;
}
.mcard-num{
  font-family:'DM Mono',monospace;font-size:2.5rem;font-weight:400;
  color:var(--border-light);line-height:1;margin-bottom:12px;
}
.mcard h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:10px}
.mcard p{font-size:0.875rem;color:var(--text-secondary);line-height:1.65}
.mcard-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:20px}
.mcard-tags span{
  padding:3px 10px;border-radius:100px;
  background:rgba(30,45,77,0.8);border:1px solid var(--border);
  font-size:0.7rem;color:var(--text-muted);
}

/* ===== FOOTER ===== */
.footer{
  background:var(--bg-mid);border-top:1px solid var(--border);
  padding:56px 24px 32px;
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:40px}
.footer-brand{
  display:flex;align-items:center;gap:8px;
  font-weight:600;font-size:1rem;color:var(--text-primary);margin-bottom:12px;
}
.footer-desc{font-size:0.85rem;color:var(--text-muted);line-height:1.6}
.footer-head{font-weight:600;font-size:0.8rem;text-transform:uppercase;letter-spacing:0.08em;color:var(--text-muted);margin-bottom:16px}
.footer ul{list-style:none}
.footer ul li{margin-bottom:8px}
.footer ul a{font-size:0.875rem;color:var(--text-secondary);transition:color 0.2s}
.footer ul a:hover{color:var(--accent-blue)}
.footer-bottom{
  border-top:1px solid var(--border);padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
  font-size:0.8rem;color:var(--text-muted);
}
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr}
}

/* ===== OVERVIEW PAGE ===== */
.overview-hero{
  padding:120px 24px 60px;
  background:linear-gradient(180deg,var(--bg-dark) 0%,var(--bg-mid) 100%);
  border-bottom:1px solid var(--border);
}
.page-eyebrow{
  display:inline-block;padding:3px 12px;
  background:rgba(99,102,241,0.1);border:1px solid rgba(99,102,241,0.25);
  border-radius:100px;font-size:0.75rem;color:var(--accent-blue);
  letter-spacing:0.07em;margin-bottom:16px;
}
.page-title{
  font-family:'Crimson Pro',serif;
  font-size:clamp(2.2rem,4vw,3.5rem);font-weight:300;
  color:var(--text-primary);margin-bottom:16px;line-height:1.15;
}
.page-sub{font-size:1.05rem;color:var(--text-secondary);max-width:640px;line-height:1.7}

/* ===== CARD ===== */
.card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:28px;transition:all 0.3s;
}
.card:hover{border-color:var(--border-light);box-shadow:var(--shadow)}
.card-title{font-weight:600;font-size:1rem;color:var(--text-primary);margin-bottom:8px}

/* ===== TABLE ===== */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}
.data-table{width:100%;border-collapse:collapse;font-size:0.85rem}
.data-table th{
  background:var(--bg-card2);color:var(--text-muted);
  font-weight:600;font-size:0.72rem;text-transform:uppercase;letter-spacing:0.07em;
  padding:12px 16px;text-align:left;border-bottom:1px solid var(--border);
  white-space:nowrap;
}
.data-table td{
  padding:10px 16px;border-bottom:1px solid var(--border);
  color:var(--text-secondary);vertical-align:middle;
}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:rgba(99,102,241,0.04)}
.data-table .num{font-family:'DM Mono',monospace;font-size:0.82rem}
.sig-mark{color:var(--accent-amber);font-weight:700}
.sig-high{color:var(--accent-red);font-weight:700}
.tag-pill{
  display:inline-block;padding:2px 8px;border-radius:100px;
  font-size:0.7rem;font-weight:600;
}
.tag-all{background:rgba(99,102,241,0.15);color:var(--accent-blue)}
.tag-ad{background:rgba(167,139,250,0.15);color:var(--accent-violet)}
.tag-vad{background:rgba(34,211,238,0.15);color:var(--accent-cyan)}
.tag-other{background:rgba(52,211,153,0.15);color:var(--accent-green)}

/* ===== TABS ===== */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:28px;flex-wrap:wrap}
.tab-btn{
  padding:10px 20px;background:none;border:none;cursor:pointer;
  font-family:'DM Sans',sans-serif;font-size:0.875rem;font-weight:500;
  color:var(--text-muted);border-bottom:2px solid transparent;
  margin-bottom:-1px;transition:all 0.2s;
}
.tab-btn:hover{color:var(--text-primary)}
.tab-btn.active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* ===== FILTER PILLS (CHECKBOXES) ===== */
.filter-pill {
  display: inline-flex;
  align-items: center;
  position: relative;
}
.filter-pill input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  cursor: pointer;
}
.filter-pill span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 100px;
  border: 1px solid var(--border);
  background: var(--bg-card2);
  color: var(--text-muted);
  font-family: 'DM Sans', sans-serif;
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
  user-select: none;
}
.filter-pill span::before {
  content: '';
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid var(--border);
  border-radius: 4px;
  background: var(--bg-card2);
  transition: all 0.2s;
}
.filter-pill span:hover {
  border-color: var(--accent-blue);
  color: var(--text-primary);
  background: rgba(99,102,241,0.08);
}
.filter-pill span:hover::before {
  border-color: var(--accent-blue);
}
.filter-pill input[type="checkbox"]:checked + span {
  background: var(--accent-blue);
  border-color: var(--accent-blue);
  color: #fff;
  box-shadow: 0 0 12px rgba(99,102,241,0.35);
}
.filter-pill input[type="checkbox"]:checked + span::before {
  background: #fff;
  border-color: #fff;
  content: '✓';
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--accent-blue);
}
.filter-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}
.filter-btn {
  padding: 6px 16px;
  border-radius: 100px;
  border: 1px solid var(--border);
  background: var(--bg-card2);
  color: var(--text-muted);
  font-family: 'DM Sans', sans-serif;
  font-size: 0.8rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}
.filter-btn:hover {
  border-color: var(--accent-blue);
  color: var(--text-primary);
  background: rgba(99,102,241,0.08);
}
.filter-btn.active {
  background: var(--accent-blue);
  border-color: var(--accent-blue);
  color: #fff;
  box-shadow: 0 0 12px rgba(99,102,241,0.35);
}

/* ===== FILTER PANEL ===== */
.filter-panel {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 28px;
  margin-bottom: 28px;
}
.filter-panel-title {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent-blue);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.filter-icon { font-size: 1rem; }
.filter-section {
  margin-bottom: 24px;
}
.filter-section:last-child {
  margin-bottom: 0;
}
.filter-section-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text-muted);
  margin-bottom: 12px;
  display: block;
}
.filter-section-hint {
  font-size: 0.68rem;
  color: var(--text-muted);
  opacity: 0.7;
  margin-top: 2px;
}

/* ===== FIGURE DISPLAY ===== */
.figure-box{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
}
.figure-box img{width:100%;display:block}
.figure-caption{padding:12px 20px;font-size:0.82rem;color:var(--text-muted);border-top:1px solid var(--border)}

/* ===== CALCULATOR PAGE ===== */
.calc-layout{
  display:grid;grid-template-columns:420px 1fr;gap:32px;align-items:start;
}
@media(max-width:1024px){
  .calc-layout{grid-template-columns:1fr}
}
.form-section-title{
  font-size:0.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:0.1em;color:var(--accent-blue);margin:24px 0 12px;
  padding-bottom:6px;border-bottom:1px solid var(--border);
}
.form-row{margin-bottom:16px}
.form-row label{
  display:block;font-size:0.82rem;font-weight:500;
  color:var(--text-secondary);margin-bottom:6px;
}
.form-row input[type=number],.form-row select{
  width:100%;background:var(--bg-card2);border:1px solid var(--border);
  color:var(--text-primary);padding:9px 12px;border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif;font-size:0.9rem;transition:border-color 0.2s;
}
.form-row input:focus,.form-row select:focus{outline:none;border-color:var(--accent-blue)}
.form-check-group{display:flex;flex-wrap:wrap;gap:8px}
.check-item{
  display:flex;align-items:center;gap:6px;padding:6px 12px;
  background:var(--bg-card2);border:1px solid var(--border);
  border-radius:var(--radius-sm);cursor:pointer;transition:all 0.2s;
  font-size:0.82rem;color:var(--text-secondary);
}
.check-item:hover{border-color:var(--accent-blue)}
.check-item input{accent-color:var(--accent-blue)}
.btn-calc{
  width:100%;padding:14px;background:var(--accent-blue);color:#fff;
  border:none;border-radius:var(--radius);font-family:'DM Sans',sans-serif;
  font-weight:700;font-size:1rem;cursor:pointer;transition:all 0.2s;
  box-shadow:0 0 24px rgba(99,102,241,0.3);margin-top:8px;
}
.btn-calc:hover{background:#4f46e5;transform:translateY(-2px);box-shadow:0 0 36px rgba(99,102,241,0.5)}
.risk-display{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:32px;
}
.risk-hero{
  text-align:center;margin-bottom:32px;
}
.risk-label{font-size:0.8rem;text-transform:uppercase;letter-spacing:0.08em;color:var(--text-muted);margin-bottom:8px}
.risk-value{
  font-family:'DM Mono',monospace;font-size:4rem;font-weight:500;line-height:1;
}
.risk-low{color:var(--accent-green)}
.risk-med{color:var(--accent-amber)}
.risk-high{color:var(--accent-red)}
.risk-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:28px;
}
.risk-tile{
  background:var(--bg-card2);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:16px;text-align:center;
}
.risk-tile-val{
  font-family:'DM Mono',monospace;font-size:1.8rem;color:var(--text-primary);
}
.risk-tile-label{font-size:0.72rem;color:var(--text-muted);margin-top:4px}
.baseline-compare{
  background:rgba(99,102,241,0.06);border:1px solid rgba(99,102,241,0.2);
  border-radius:var(--radius-sm);padding:14px 18px;
  font-size:0.875rem;color:var(--text-secondary);line-height:1.6;margin-bottom:24px;
}
.baseline-compare strong{color:var(--accent-blue)}
.risk-badge{
  display:inline-block;padding:4px 14px;border-radius:100px;
  font-size:0.8rem;font-weight:700;margin-bottom:6px;
}
.badge-low{background:rgba(52,211,153,0.15);color:var(--accent-green);border:1px solid rgba(52,211,153,0.3)}
.badge-med{background:rgba(251,191,36,0.15);color:var(--accent-amber);border:1px solid rgba(251,191,36,0.3)}
.badge-high{background:rgba(248,113,113,0.15);color:var(--accent-red);border:1px solid rgba(248,113,113,0.3)}

/* ===== KM CHART ===== */
#km-canvas{width:100%;height:280px;background:var(--bg-card2);border-radius:var(--radius-sm)}

/* ===== SLIDER ===== */
.slider-row{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}
.slider-header{display:flex;justify-content:space-between;align-items:baseline}
.slider-name{font-size:0.875rem;font-weight:500;color:var(--text-secondary)}
.slider-val{font-family:'DM Mono',monospace;font-size:1rem;color:var(--text-primary)}
.slider-percentile{font-size:0.7rem;color:var(--text-muted)}
input[type=range]{
  -webkit-appearance:none;width:100%;height:4px;
  background:linear-gradient(90deg,var(--accent-blue) var(--pct,50%),var(--border) var(--pct,50%));
  border-radius:2px;cursor:pointer;outline:none;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:16px;height:16px;border-radius:50%;
  background:var(--accent-blue);border:2px solid #fff;
  box-shadow:0 0 8px rgba(99,102,241,0.6);
}
.sim-compare{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px;
}
.sim-tile{
  background:var(--bg-card2);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:14px;text-align:center;
}
.sim-tile-label{font-size:0.7rem;color:var(--text-muted);margin-bottom:6px}
.sim-tile-val{font-family:'DM Mono',monospace;font-size:1.5rem;color:var(--text-primary)}
.sim-reduction{text-align:center;margin-top:12px;font-size:0.9rem}
.sim-reduction strong{color:var(--accent-green)}

/* ===== PAF BARS ===== */
.paf-bar-row{margin-bottom:16px}
.paf-bar-label{display:flex;justify-content:space-between;font-size:0.85rem;margin-bottom:6px}
.paf-bar-name{color:var(--text-secondary)}
.paf-bar-val{font-family:'DM Mono',monospace;color:var(--text-primary);font-weight:600}
.paf-bar-track{
  height:8px;background:var(--border);border-radius:4px;overflow:hidden;
}
.paf-bar-fill{
  height:100%;border-radius:4px;transition:width 1s ease;
}
.paf-fill-cyan{background:linear-gradient(90deg,var(--accent-cyan),var(--accent-blue))}
.paf-fill-violet{background:linear-gradient(90deg,var(--accent-violet),var(--accent-blue))}
.paf-fill-green{background:linear-gradient(90deg,var(--accent-green),var(--accent-cyan))}

/* ===== LOADING ===== */
.loading{text-align:center;padding:40px;color:var(--text-muted);font-size:0.9rem}
.spinner{
  width:32px;height:32px;border:3px solid var(--border);
  border-top-color:var(--accent-blue);border-radius:50%;
  animation:spin 0.8s linear infinite;margin:0 auto 12px;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg-dark)}
::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}

/* ===== CONTROLS ===== */
.ctrl-select {
  background: var(--bg-card2);
  border: 1px solid var(--border);
  color: var(--text-primary);
  padding: 9px 12px;
  border-radius: var(--radius-sm);
  font-family: 'DM Sans', sans-serif;
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s;
  width: 100%;
}
.ctrl-select:hover {
  border-color: var(--accent-blue);
  background: rgba(99,102,241,0.08);
}
.ctrl-select:focus {
  outline: none;
  border-color: var(--accent-blue);
  box-shadow: 0 0 8px rgba(99,102,241,0.2);
}
.ctrl-select option {
  background: var(--bg-card2);
  color: var(--text-primary);
}
.btn-generate {
  padding: 10px 28px;
  background: var(--accent-blue);
  color: #fff;
  border: none;
  border-radius: var(--radius-sm);
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  font-size: 0.9rem;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
  box-shadow: 0 0 16px rgba(99,102,241,0.3);
}
.btn-generate:hover {
  background: #4f46e5;
  transform: translateY(-1px);
  box-shadow: 0 0 24px rgba(99,102,241,0.5);
}
.btn-generate:active {
  transform: translateY(0);
}

/* ===== UTILITY ===== 
/* ===== UTILITY ===== */
.visible { animation: fadeUp 0.6s ease both; }

/* ===== OVERVIEW HERO padding fix ===== */
.overview-hero { padding: 100px 24px 60px; background: linear-gradient(180deg, var(--bg-dark) 0%, var(--bg-mid) 100%); border-bottom: 1px solid var(--border); }
.page-eyebrow { display: inline-block; padding: 3px 12px; background: rgba(99,102,241,0.1); border: 1px solid rgba(99,102,241,0.25); border-radius: 100px; font-size: 0.75rem; color: var(--accent-blue); letter-spacing: 0.07em; margin-bottom: 16px; }
.page-title { font-family: 'Crimson Pro', serif; font-size: clamp(2.2rem,4vw,3.5rem); font-weight: 300; color: var(--text-primary); margin-bottom: 16px; line-height: 1.15; }
.page-sub { font-size: 1.05rem; color: var(--text-secondary); max-width: 640px; line-height: 1.7; }

