/* ── OVERVIEW ────────────────────────────────────── */
.section-head{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:10px;margin-top:24px;display:flex;align-items:center;gap:6px}
.section-head:first-child{margin-top:0}
.section-head::after{content:'';flex:1;height:1px;background:var(--border)}
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(172px,1fr));gap:10px;margin-bottom:4px}
.bio-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px;cursor:pointer;transition:all .18s;position:relative;overflow:hidden}
.bio-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:10px 0 0 10px}
.bio-card.s-green::before{background:var(--green)}
.bio-card.s-amber::before{background:var(--amber)}
.bio-card.s-red::before{background:var(--red)}
.bio-card:hover{border-color:var(--indigo-m);box-shadow:0 4px 16px rgba(79,70,229,.1);transform:translateY(-1px)}
.bc-unit{font-size:10px;color:var(--muted2);margin-bottom:5px;font-weight:500;letter-spacing:.2px}
.bc-name{font-size:12px;font-weight:500;color:var(--text2);margin-bottom:8px;line-height:1.3}
.bc-val{font-size:22px;font-weight:800;line-height:1;letter-spacing:-0.5px}
.bc-val.s-green{color:var(--green)}
.bc-val.s-amber{color:var(--amber)}
.bc-val.s-red{color:var(--red)}
.bc-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
.bc-trend{font-size:13px}
.bc-count{font-size:10px;color:var(--muted2);font-weight:500}

/* ── CHART VIEW ──────────────────────────────────── */
#chart-view{display:none}
#chart-view.show{display:block}
.cv-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:20px;flex-wrap:wrap}
.cv-title-block .cv-title{font-size:20px;font-weight:800;color:var(--text);letter-spacing:-0.3px}
.cv-title-block .cv-sub{font-size:12px;color:var(--muted);margin-top:3px}
.cv-stats{display:flex;gap:10px;flex-wrap:wrap}
.cv-stat{background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:10px 16px;text-align:center;min-width:90px}
.cv-stat .sv{font-size:20px;font-weight:800;letter-spacing:-0.3px;font-variant-numeric:tabular-nums}
.cv-stat .sl{font-size:10px;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:16px}
canvas{max-height:340px}
.history-table{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-top:20px}
.history-table table{width:100%;border-collapse:collapse}
.history-table thead th{padding:10px 16px;text-align:left;font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;background:var(--surface2);border-bottom:1px solid var(--border)}
.history-table tbody tr{border-top:1px solid var(--border);transition:background .1s}
.history-table tbody tr:hover{background:var(--surface2)}
.history-table td{padding:9px 16px;font-size:12px}

/* ── TIMELINE VIEW ───────────────────────────────── */
#timeline-view{display:none}
#timeline-view.show{display:block}
.tl-wrapper{position:relative;padding-left:120px}
.tl-item{position:relative;margin-bottom:20px}
.tl-item::before{content:'';position:absolute;left:-25px;top:20px;bottom:-20px;width:1px;background:var(--border)}
.tl-item:last-child::before{display:none}
.tl-node{position:absolute;left:-31px;top:14px;width:12px;height:12px;border-radius:50%;border:2px solid var(--surface);z-index:1}
.tl-date-col{position:absolute;left:-120px;top:12px;text-align:right;width:86px}
.tl-date-txt{font-size:12px;font-weight:600;color:var(--text2)}
.tl-src-txt{font-size:10px;color:var(--muted);margin-top:1px;font-weight:500}
.tl-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px}
.tl-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.tl-card-doctor{font-size:11px;color:var(--muted)}
.tl-card-count{font-size:11px;font-weight:600;color:var(--muted2)}
.tl-tags{display:flex;flex-wrap:wrap;gap:6px}
.tl-tag{font-size:11px;padding:3px 9px;border-radius:20px;cursor:pointer;font-weight:500;transition:opacity .1s}
.tl-tag:hover{opacity:.75}
.tl-note{font-size:12px;color:var(--blue);background:var(--blue-l);border-radius:6px;padding:8px 10px;margin-bottom:8px}

/* ── ALERTS VIEW ─────────────────────────────────── */
#alerts-view{display:none}
#alerts-view.show{display:block}
#diag-view{display:none}
#diag-view.show{display:block}
.diag-score-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px 28px;display:flex;align-items:center;gap:32px;margin-bottom:20px}
.score-ring{position:relative;width:96px;height:96px;flex-shrink:0}
.score-ring svg{transform:rotate(-90deg)}
.score-ring .score-num{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:800;font-size:24px;line-height:1;letter-spacing:-0.5px}
.score-ring .score-lbl{font-size:9px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.score-meta{flex:1}
.score-meta h2{font-size:17px;font-weight:700;margin-bottom:4px}
.score-meta p{font-size:12px;color:var(--muted);line-height:1.5}
.score-bars{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:14px}
.score-bar-item{display:flex;flex-direction:column;gap:4px}
.score-bar-item label{font-size:10px;font-weight:500;color:var(--muted);display:flex;justify-content:space-between}
.score-bar-track{height:5px;background:var(--border);border-radius:3px;overflow:hidden}
.score-bar-fill{height:100%;border-radius:3px;transition:width .5s}
.sys-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:14px;margin-bottom:20px}
.sys-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.sys-card-head{padding:14px 16px 10px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}
.sys-card-head .sys-icon{font-size:18px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;flex-shrink:0}
.sys-card-head .sys-title{font-size:13px;font-weight:700;flex:1}
.sys-card-head .sys-status{font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px}
.sys-card-head .sys-status.green{background:var(--green-l);color:var(--green)}
.sys-card-head .sys-status.amber{background:var(--amber-l);color:var(--amber)}
.sys-card-head .sys-status.red{background:var(--red-l);color:var(--red)}
.sys-card-body{padding:12px 16px}
.sys-markers{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
.sys-marker-row{display:flex;align-items:center;gap:8px;font-size:11px;cursor:pointer;padding:3px 0;border-radius:4px;transition:background .1s}
.sys-marker-row:hover{background:var(--surface2)}
.sys-marker-row .smr-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.sys-marker-row .smr-name{flex:1;color:var(--text2)}
.sys-marker-row .smr-val{font-weight:600;font-variant-numeric:tabular-nums}
.sys-marker-row .smr-trend{font-size:10px;color:var(--muted)}
.sys-diag{background:var(--surface2);border-radius:8px;padding:10px 12px;font-size:11px;color:var(--text2);line-height:1.6;border-left:3px solid var(--border2)}
.sys-diag.red{border-color:var(--red);background:var(--red-l)}
.sys-diag.amber{border-color:var(--amber);background:var(--amber-l)}
.sys-diag.green{border-color:var(--green);background:var(--green-l)}
.action-plan{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-top:4px}
.action-plan-head{padding:14px 20px;border-bottom:1px solid var(--border);font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px}
.action-item{display:flex;align-items:flex-start;gap:14px;padding:14px 20px;border-bottom:1px solid var(--border);transition:background .1s}
.action-item:last-child{border-bottom:none}
.action-item:hover{background:var(--surface2)}
.action-num{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;margin-top:1px}
.action-num.red{background:var(--red-l);color:var(--red)}
.action-num.amber{background:var(--amber-l);color:var(--amber)}
.action-num.green{background:var(--green-l);color:var(--green)}
.action-body{flex:1}
.action-title{font-size:12px;font-weight:600;margin-bottom:3px}
.action-desc{font-size:11px;color:var(--muted);line-height:1.55}
.alerts-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px}
.alert-kpi{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;text-align:center}
.alert-kpi .ak-num{font-size:28px;font-weight:800;line-height:1}
.alert-kpi .ak-lbl{font-size:11px;color:var(--muted);margin-top:4px;font-weight:500}
.alert-section{margin-bottom:32px}
.alert-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.alert-section-title span{flex:1;height:1px;background:var(--border);display:block}
.alert-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:10px;display:flex;gap:14px;cursor:pointer;transition:all .15s}
.alert-card:hover{border-color:var(--border2);box-shadow:0 2px 12px rgba(0,0,0,.06)}
.alert-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.alert-icon.red{background:var(--red-l)}
.alert-icon.amber{background:var(--amber-l)}
.alert-icon.green{background:var(--green-l)}
.alert-icon.blue{background:var(--blue-l)}
.alert-body{flex:1;min-width:0}
.alert-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px}
.alert-desc{font-size:12px;color:var(--muted);line-height:1.5}
.alert-rec{margin-top:8px;font-size:12px;color:var(--text2);background:var(--surface2);border-radius:6px;padding:8px 10px;border-left:3px solid var(--indigo-m);line-height:1.5}
.alert-meta{font-size:10px;color:var(--muted2);margin-top:6px;font-weight:500}
.severity-badge{flex-shrink:0;align-self:flex-start;margin-top:1px}

/* ── VACCINE TAB ─────────────────────────────────── */
#vaccine-view{display:none}
#vaccine-view.show{display:block}
.vacc-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
.vacc-kpi{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;text-align:center}
.vacc-kpi .vk-num{font-size:28px;font-weight:800;line-height:1}
.vacc-kpi .vk-lbl{font-size:11px;color:var(--muted);margin-top:4px}
.vacc-list{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:20px}
.vacc-list-head{padding:14px 20px;border-bottom:1px solid var(--border);font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:space-between}
.vacc-row{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border);transition:background .1s}
.vacc-row:last-child{border-bottom:none}
.vacc-row:hover{background:var(--surface2)}
.vacc-check{width:20px;height:20px;border-radius:5px;border:2px solid var(--border2);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s}
.vacc-check.done{background:var(--green);border-color:var(--green);color:#fff}
.vacc-check.miss{background:var(--red-l);border-color:var(--red)}
.vacc-info{flex:1;min-width:0}
.vacc-name{font-size:13px;font-weight:600;color:var(--text)}
.vacc-meta{font-size:11px;color:var(--muted);margin-top:2px}
.vacc-note{font-size:10px;color:var(--indigo);margin-top:3px;font-style:italic;line-height:1.4}
.vacc-date-input{border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-size:11px;font-family:inherit;color:var(--text2);background:var(--surface);outline:none;width:110px;flex-shrink:0}
.vacc-date-input:focus{border-color:var(--indigo)}
.vacc-badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:20px;flex-shrink:0;white-space:nowrap}
.vacc-badge.done{background:var(--green-l);color:var(--green)}
.vacc-badge.miss{background:var(--red-l);color:var(--red)}
.vacc-badge.fut{background:var(--surface2);color:var(--muted)}
.vacc-badge.rec{background:var(--amber-l);color:var(--amber)}
.ann-pin{cursor:pointer;font-size:13px}
.ann-add{cursor:pointer;font-size:13px;color:var(--muted2)}

/* ── BIO AGE WIDGET ─────────────────────────────── */
.bio-age-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px 24px;margin-bottom:20px;display:flex;gap:32px;align-items:flex-start;flex-wrap:wrap}
.bio-age-ring{text-align:center;flex-shrink:0}
.bio-age-ring .bar{font-size:40px;font-weight:900;line-height:1;letter-spacing:-2px}
.bio-age-ring .lbl{font-size:11px;color:var(--muted);font-weight:500;margin-top:4px}
.bio-age-factors{flex:1;min-width:240px}
.bio-age-factors h3{font-size:13px;font-weight:700;margin-bottom:12px}
.baf-row{display:flex;align-items:center;gap:8px;font-size:11px;margin-bottom:6px}
.baf-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.baf-name{flex:1;color:var(--text2)}
.baf-val{font-weight:600;min-width:50px;text-align:right}

/* ── CORR SECTION ────────────────────────────────── */
.corr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-bottom:20px}
.corr-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 16px;cursor:pointer;transition:all .15s}
.corr-card:hover{border-color:var(--indigo-m);transform:translateY(-1px)}
.corr-r{font-size:22px;font-weight:800;letter-spacing:-0.5px}
.corr-names{font-size:11px;color:var(--text2);margin-top:4px}
.corr-dir{font-size:10px;color:var(--muted);margin-top:3px}

/* ── NEXT EXAM SECTION ───────────────────────────── */
.next-exam-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:10px;display:flex;gap:14px}
.next-exam-icon{width:36px;height:36px;border-radius:8px;background:var(--blue-l);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.next-exam-body{flex:1}
.next-exam-title{font-size:13px;font-weight:600;margin-bottom:3px}
.next-exam-desc{font-size:12px;color:var(--muted);line-height:1.5}

/* ── MOBILE HEALTH RESPONSIVE ───────────────────── */
@media (max-width:768px){
  .alerts-summary{grid-template-columns:repeat(2,1fr);gap:8px}
  .vacc-summary{grid-template-columns:repeat(2,1fr);gap:8px}
  .score-bars{grid-template-columns:1fr 1fr}
  .sys-grid{grid-template-columns:1fr}
  .diag-score-card{flex-direction:column;align-items:flex-start;gap:16px;padding:18px}
  .bio-age-card{flex-direction:column;gap:16px}
  .bio-age-factors{min-width:0}
  .tl-wrapper{padding-left:0}
  .tl-date-col{display:none}
  .tl-item::before{left:5px}
  .tl-node{left:-1px}
  canvas{max-height:220px}
  .vacc-row{flex-wrap:wrap;gap:8px}
  .vacc-date-input{width:100%}
}

@media (max-width:480px){
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .corr-grid{grid-template-columns:1fr}
  .score-bars{grid-template-columns:1fr}
  .cv-header{flex-direction:column;gap:10px}
  .cv-stats{width:100%}
  .cv-stat{flex:1;min-width:0;padding:8px}
  .cv-stat .sv{font-size:16px}
  .bio-age-ring .bar{font-size:32px}
}
