/* ═══════════════════════════════════════════════════
   Observatorio Nacional de EPOF — v8.0
   8 Secciones numeradas · Animaciones · Zero inline
   ═══════════════════════════════════════════════════ */
:root{
  --pri:#4F0D9B;--pri-dk:#3D0A7A;--pri-lt:#7C3AED;--mag:#E6007E;--pmid:#8E1E82;--cyan:#00AEEF;
  --bg:#FFF;--surf:#FCFCFD;--bor:#E5E7EB;--tx:#111827;--mut:#6B7280;
  --s50:#F8FAFC;--s100:#F1F5F9;--s200:#E2E8F0;--s300:#CBD5E1;
  --s400:#94A3B8;--s500:#64748B;--s600:#475569;--s700:#334155;--s900:#0F172A;
  --g50:#F0FDF4;--g100:#DCFCE7;--g500:#22C55E;--g700:#15803D;
  --y50:#FEFCE8;--y100:#FEF9C3;--y500:#EAB308;--y700:#A16207;--y800:#854D0E;
  --r50:#FEF2F2;--r100:#FEE2E2;--r500:#DC2626;--r700:#B91C1C;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--tx);-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}
html{overflow-x:hidden}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{max-width:100%;height:auto;display:block}

/* ── Keyframes ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes gradientFlow{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes countPulse{0%{transform:scale(1)}50%{transform:scale(1.06)}100%{transform:scale(1)}}

/* ── Scroll reveal ── */
.rv{opacity:0;transform:translateY(24px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1)}
.rv.in{opacity:1;transform:none}
.rv-s{opacity:0;transform:scale(.93);transition:opacity .5s ease,transform .5s ease}
.rv-s.in{opacity:1;transform:none}
.d1{transition-delay:.06s}.d2{transition-delay:.12s}.d3{transition-delay:.18s}.d4{transition-delay:.24s}

/* ── Wrap ── */
.wrap{max-width:1280px;margin:0 auto;padding:0 12px;box-sizing:border-box;width:100%}
@media(min-width:600px){.wrap{padding:0 20px}}
@media(min-width:768px){.wrap{padding:0 40px}}

/* ════════════════════════════════════
   HEADER
   ════════════════════════════════════ */
.hdr{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(255,255,255,.95);backdrop-filter:blur(14px);border-bottom:1px solid var(--bor);transition:box-shadow .3s}
.hdr.scrolled{box-shadow:0 4px 20px rgba(0,0,0,.06)}
/* Single-row header */
.hdr-row{display:flex;align-items:center;justify-content:space-between;height:56px;gap:8px}
.hdr-left{display:flex;align-items:center;gap:10px;flex-shrink:0}
.hdr-brand-text{display:none}
@media(min-width:768px){.hdr-brand-text{display:block}}
.hdr-logo{height:34px;width:auto;transition:transform .3s}
.hdr-logo:hover{transform:scale(1.04)}
.hdr-title-main{font-size:12px;font-weight:800;color:var(--s800);letter-spacing:-.01em;line-height:1.15;text-transform:uppercase}
@media(min-width:900px){.hdr-title-main{font-size:14px}}
.hdr-title-sub{font-size:9px;font-weight:600;color:var(--pri);letter-spacing:.1em;text-transform:uppercase;margin-top:1px}
@media(min-width:900px){.hdr-title-sub{font-size:10px}}
.hdr-center{flex:1;display:flex;justify-content:center}
.hdr-right{flex-shrink:0;display:flex;align-items:center}
@media(max-width:767px){.hdr-row{height:auto;gap:0;flex-wrap:wrap;justify-content:center;padding:8px 0 6px}.hdr-left{width:100%;display:flex;justify-content:center;margin-bottom:6px}.hdr-center{flex:none;justify-content:center}.hdr-right{margin-left:4px}}
.pill-g{display:flex;background:var(--s50);padding:2px;border-radius:8px;border:1px solid var(--s100);gap:1px;flex-shrink:0}
@media(min-width:768px){.pill-g{padding:3px;border-radius:10px;gap:2px}}
.pill{display:flex;align-items:center;gap:3px;padding:4px 8px;border-radius:6px;font-size:10px;font-weight:700;color:var(--s400);transition:all .25s;white-space:nowrap}
@media(min-width:768px){.pill{padding:7px 16px;font-size:13px;gap:5px;border-radius:8px}}
.pill:hover{color:var(--s600);background:rgba(79,13,155,.04)}
.pill.on{background:#fff;color:var(--pri);box-shadow:0 2px 8px rgba(79,13,155,.1)}
.pill .material-symbols-outlined{font-size:13px}
@media(min-width:768px){.pill .material-symbols-outlined{font-size:16px}}
.yr-g{display:flex;gap:1px;flex-shrink:0}
.yr{padding:4px 6px;border-radius:6px;font-size:9px;font-weight:800;color:var(--s300);transition:.2s}
@media(min-width:768px){.yr-g{gap:2px}.yr{padding:6px 10px;font-size:11px;border-radius:7px}}
.yr.on{background:#fff;color:var(--pri);box-shadow:0 1px 3px rgba(0,0,0,.06)}.yr.off{pointer-events:none;opacity:.35}
.gbar{height:4px;background:linear-gradient(90deg,#E6007E,#4F0D9B,#00AEEF,#4F0D9B,#E6007E);background-size:300% 100%;animation:gradientFlow 4s ease infinite;margin-top:56px}
@media(max-width:767px){.gbar{margin-top:72px}}

/* ════════════════════════════════════
   HERO
   ════════════════════════════════════ */
.hero{position:relative;background:linear-gradient(135deg,#5B1299,#4F0D9B 40%,#6A1B9A 70%,#7B1FA2);border-radius:16px;padding:24px;color:#fff;margin-top:16px;display:flex;flex-wrap:wrap;align-items:center;gap:20px;overflow:hidden}
@media(min-width:768px){.hero{border-radius:20px;padding:36px;margin-top:24px;gap:28px}}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(230,0,126,.15),transparent 50%),radial-gradient(circle at 80% 20%,rgba(0,174,239,.12),transparent 50%);pointer-events:none}
.hero-p{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-p span{position:absolute;width:4px;height:4px;background:rgba(255,255,255,.25);border-radius:50%;animation:float 3s ease-in-out infinite}
.hp1{top:15%;left:10%;animation-duration:3.2s!important}
.hp2{top:60%;left:25%;animation-delay:.4s;animation-duration:2.8s!important;width:3px!important;height:3px!important}
.hp3{top:30%;left:55%;animation-delay:.8s;animation-duration:3.5s!important;width:5px!important;height:5px!important}
.hp4{top:75%;left:70%;animation-delay:1.2s;animation-duration:2.6s!important}
.hp5{top:20%;left:85%;animation-delay:1.6s;animation-duration:3.8s!important;width:3px!important;height:3px!important}
.hero-txt{flex:1;min-width:240px;position:relative;z-index:1;animation:fadeUp .8s ease-out}
.hero h2{font-size:26px;font-weight:900;letter-spacing:-.02em;line-height:1.15;margin-bottom:8px}
.hero p{font-size:14px;color:#D8B4FE;line-height:1.7;max-width:480px}
.hero-stats{display:flex;flex-wrap:wrap;gap:8px;position:relative;z-index:1}
@media(min-width:768px){.hero-stats{gap:10px}}
.hero-stat{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:12px 14px;text-align:center;min-width:0;flex:1 1 auto;backdrop-filter:blur(8px);transition:all .35s;cursor:default}
@media(min-width:768px){.hero-stat{border-radius:14px;padding:16px 20px;min-width:110px;flex:0 0 auto}}
.hero-stat:hover{background:rgba(255,255,255,.18);transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.hero-stat b{display:block;font-size:24px;font-weight:900}
.hero-stat small{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#D8B4FE;margin-top:2px;display:block}

/* ════════════════════════════════════
   PANELS
   ════════════════════════════════════ */
.panel{display:none}.panel.vis{display:block;animation:fadeIn .35s ease-out}

/* ════════════════════════════════════
   SECTION HEADERS — numbered
   ════════════════════════════════════ */
.sec{margin-top:36px}
.sec-h{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.sec-n{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--pri),var(--pri-lt));color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;flex-shrink:0;box-shadow:0 4px 12px rgba(79,13,155,.2)}
.sec-txt h3{font-size:18px;font-weight:800;color:var(--s900);line-height:1.2}
@media(min-width:768px){.sec-txt h3{font-size:22px}}
.sec-txt p{font-size:13px;color:var(--s500);margin-top:2px}

/* Section intro (unnumbered) */
.sec-intro{margin:32px 0 20px}
.sec-intro h2{font-size:28px;font-weight:900;color:var(--s900)}
.sec-intro p{font-size:14px;color:var(--s500);margin-top:4px}

/* ════════════════════════════════════
   CARD
   ════════════════════════════════════ */
.card{background:#fff;border-radius:16px;border:1px solid var(--bor);padding:28px;box-shadow:0 1px 3px rgba(0,0,0,.04);margin-bottom:16px;transition:all .3s}
.card:hover{box-shadow:0 6px 24px -4px rgba(79,13,155,.08);border-color:rgba(79,13,155,.1)}
.card-t{font-size:15px;font-weight:700;color:var(--s700);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.card-t .material-symbols-outlined{color:var(--pri);font-size:20px}

/* ════════════════════════════════════
   KPI
   ════════════════════════════════════ */
.kpi-row{display:grid;gap:12px;margin-bottom:16px}
.kpi-r2{grid-template-columns:1fr 1fr}
.kpi-r3{grid-template-columns:1fr 1fr 1fr}
.kpi-r4{grid-template-columns:1fr 1fr 1fr 1fr}
@media(max-width:900px){.kpi-r3,.kpi-r4{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.kpi-r2,.kpi-r3,.kpi-r4{grid-template-columns:1fr}}
.kpi{background:#fff;border-radius:12px;border:1px solid var(--s100);padding:16px;box-shadow:0 2px 10px -3px rgba(0,0,0,.05);transition:all .35s;position:relative;overflow:hidden}
@media(min-width:768px){.kpi{border-radius:14px;padding:20px}}
.kpi::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--pri),var(--pri-lt));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.kpi:hover{transform:translateY(-4px);box-shadow:0 10px 28px -6px rgba(79,13,155,.12);border-color:rgba(79,13,155,.12)}
.kpi:hover::after{transform:scaleX(1)}
.kpi-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;color:var(--pri)}
.kpi-val{font-size:28px;font-weight:900;line-height:1;color:var(--pri);transition:transform .3s}
@media(min-width:768px){.kpi-val{font-size:34px}}
.kpi:hover .kpi-val{transform:scale(1.03)}
.kpi-note{font-size:11px;color:var(--s400);margin-top:5px}

/* ════════════════════════════════════
   DONUT
   ════════════════════════════════════ */
.donut-wrap{display:flex;justify-content:center;margin-bottom:12px}
.donut-ring{stroke-dasharray:0 100;transition:stroke-dasharray 1.2s cubic-bezier(.22,1,.36,1)}
.donut-ring.drawn{stroke-dasharray:var(--seg) 100}
.donut-txt-b{font-size:6px;font-weight:900;fill:var(--tx);opacity:0;transition:opacity .5s .6s}
.donut-txt-s{font-size:2.2px;font-weight:700;fill:var(--s400);opacity:0;transition:opacity .5s .8s}
.donut-txt-b.shown,.donut-txt-s.shown{opacity:1}

/* Coverage items */
.cov{display:flex;align-items:center;justify-content:space-between;padding:7px 12px;background:var(--s50);border-radius:10px;margin-bottom:5px;transition:all .25s}
.cov:hover{background:#F3E8FF;transform:translateX(4px)}
.cov-d{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-right:8px}
.dp{background:var(--pri)}.dm{background:var(--pmid)}.dc{background:var(--cyan)}.ds{background:var(--s300)}
.cov span:first-of-type{font-size:13px;font-weight:500;color:var(--s600);flex:1}
.cov b{font-size:13px;font-weight:800;color:var(--tx)}

/* ════════════════════════════════════
   BARS — fixed animation
   ════════════════════════════════════ */
.bbar{margin-bottom:14px}
.bbar-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}
.bbar-lbl{font-size:13px;font-weight:600;color:var(--s700)}
.bbar-val{font-size:15px;font-weight:900;color:var(--pri)}
.bbar-track{width:100%;height:8px;background:var(--s100);border-radius:99px;overflow:hidden}
.bbar-fill{height:100%;border-radius:99px;background:var(--pri);width:0;transition:width 1s cubic-bezier(.22,1,.36,1)}

/* ════════════════════════════════════
   PURPLE SECTION
   ════════════════════════════════════ */
.purple{position:relative;background:linear-gradient(135deg,#3D0A7A,#4F0D9B 30%,#6A1B9A 65%,#7B1FA2);background-size:200% 200%;animation:gradientFlow 8s ease infinite;border-radius:16px;padding:24px;color:#fff;margin-bottom:16px;overflow:hidden}
@media(min-width:768px){.purple{border-radius:18px;padding:32px}}
.purple::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 0%,rgba(230,0,126,.12),transparent 60%),radial-gradient(ellipse at 90% 90%,rgba(0,174,239,.1),transparent 50%);pointer-events:none}
.purple h4{font-size:18px;font-weight:800;position:relative;margin-bottom:3px}
.purple-sub{font-size:12px;color:#D8B4FE;margin-bottom:16px;position:relative}
.emo-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;position:relative}
@media(max-width:800px){.emo-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.emo-grid{grid-template-columns:repeat(2,1fr)}}
.emo{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;text-align:center;transition:all .3s;cursor:default;backdrop-filter:blur(4px)}
.emo:hover{background:rgba(255,255,255,.18);transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.emo-ico{display:flex;align-items:center;justify-content:center;width:40px;height:40px;margin:0 auto 8px;border-radius:10px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1)}
.emo-ico .material-symbols-outlined{font-size:22px;color:#D8B4FE}
.emo b{display:block;font-size:26px;font-weight:900;margin-bottom:2px}
.emo small{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#D8B4FE}
.treat-div{margin-top:20px;padding-top:16px;border-top:1px solid rgba(255,255,255,.15);position:relative}
.treat-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#D8B4FE;margin-bottom:8px}
.treat-chips{display:flex;flex-wrap:wrap;gap:8px}
.tchip{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.1);padding:7px 14px;border-radius:10px;font-size:13px;border:1px solid rgba(255,255,255,.08);transition:all .3s}
.tchip:hover{background:rgba(255,255,255,.18);transform:translateY(-2px)}
.tchip b{font-weight:900}.tchip span{color:#D8B4FE}

/* ════════════════════════════════════
   GAUGES
   ════════════════════════════════════ */
.gauge{margin-bottom:20px}
.gauge-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.gauge-lbl{font-size:13px;font-weight:600;color:var(--s600)}
.gauge-val{font-size:22px;font-weight:900;color:var(--pri)}
.gauge-val span{font-size:13px;color:var(--s400)}
.gauge-segs{display:flex;gap:4px}
.gauge-seg{flex:1;height:8px;border-radius:99px}
.gauge-on{background:var(--pri)}.gauge-off{background:var(--s200)}
.gauge-note{font-size:11px;color:var(--s400);margin-top:4px}

/* ════════════════════════════════════
   MINIS & ALERT
   ════════════════════════════════════ */
.mini{border-radius:12px;padding:16px;text-align:center;background:#F3E8FF;transition:all .3s}
.mini:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(79,13,155,.08)}
.mini-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--pri)}
.mini-val{font-size:28px;font-weight:900;margin:3px 0;color:var(--pri)}
.mini-note{font-size:11px;font-weight:500;color:var(--pri)}
.mini-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:480px){.mini-row{grid-template-columns:1fr}}
.mini-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
@media(max-width:600px){.mini-row-3{grid-template-columns:1fr}}

.alert{display:flex;gap:10px;padding:14px;border-radius:12px;font-size:13px;line-height:1.5;align-items:flex-start;margin-top:12px;transition:all .3s}
.alert-y{background:var(--y50);border:1px solid var(--y100);color:var(--y800)}
.alert-y:hover{box-shadow:0 4px 12px rgba(234,179,8,.08)}

/* ════════════════════════════════════
   GRIDS
   ════════════════════════════════════ */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.g38{display:grid;grid-template-columns:3fr 8fr;gap:12px}
@media(max-width:700px){.g2,.g38{grid-template-columns:1fr}}

/* ════════════════════════════════════
   SCORECARD — Accordion
   ════════════════════════════════════ */
.sc-summary{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}
.sc-avg{display:flex;align-items:center;gap:12px;background:var(--s50);padding:12px 20px;border-radius:12px;border:1px solid var(--s100)}
.sc-avg-val{font-size:28px;font-weight:900;color:var(--tx)}
.sc-avg-lbl{font-size:10px;font-weight:700;color:var(--s400);text-transform:uppercase;letter-spacing:.06em}
.sc-avg-row{display:flex;align-items:center;gap:10px}
.legend{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.legend span{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:#fff;border:1px solid var(--s100);border-radius:6px;font-size:11px;font-weight:700;color:var(--s600)}
.legend i{width:10px;height:10px;border-radius:50%;display:inline-block}
.lg-g{background:var(--g500)}.lg-y{background:var(--y500)}.lg-r{background:var(--r500)}

.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:99px;font-size:10px;font-weight:900;text-transform:uppercase;white-space:nowrap}
.badge i{width:8px;height:8px;border-radius:50%}
.badge.green{background:var(--g50);border:1px solid var(--g100);color:var(--g700)}.badge.green i{background:var(--g500)}
.badge.yellow{background:var(--y50);border:1px solid var(--y100);color:var(--y800)}.badge.yellow i{background:var(--y500)}
.badge.red{background:var(--r50);border:1px solid var(--r100);color:var(--r700)}.badge.red i{background:var(--r500)}

.acc{border-radius:16px;border:1px solid var(--bor);margin-bottom:14px;overflow:hidden;background:#fff;box-shadow:0 2px 8px -2px rgba(0,0,0,.04);transition:all .4s}
.acc:hover{box-shadow:0 6px 20px -4px rgba(79,13,155,.08)}
.acc.open{box-shadow:0 8px 30px -6px rgba(79,13,155,.15);border-color:rgba(79,13,155,.18)}
.acc-trigger{width:100%;padding:0;text-align:left;cursor:pointer;display:block}
.acc-bar{display:flex;align-items:center;gap:10px;padding:14px 14px}
@media(min-width:768px){.acc-bar{gap:14px;padding:18px 22px}}
.acc-num{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:900;color:#fff;flex-shrink:0;transition:transform .3s}
@media(min-width:768px){.acc-num{width:42px;height:42px;border-radius:11px;font-size:17px}}
.acc:hover .acc-num{transform:scale(1.06)}
.acc-num.green{background:var(--g500)}.acc-num.yellow{background:var(--y500)}.acc-num.red{background:var(--r500)}
.acc-info{flex:1;min-width:0}
.acc-name{font-size:14px;font-weight:800;color:var(--s900)}
@media(min-width:768px){.acc-name{font-size:17px}}
.acc-sub{font-size:12px;color:var(--s500);margin-top:1px}
@media(max-width:700px){.acc-sub{display:none}}
.acc-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.acc-pct{font-size:22px;font-weight:900;color:var(--tx);line-height:1}
@media(min-width:768px){.acc-pct{font-size:28px}}
.acc-pts{font-size:11px;font-weight:600;color:var(--s400);text-align:right}
.acc-arrow{width:32px;height:32px;border-radius:8px;background:var(--s50);display:flex;align-items:center;justify-content:center;transition:all .3s;flex-shrink:0}
.acc-arrow .material-symbols-outlined{font-size:18px;color:var(--s400);transition:transform .3s}
.acc.open .acc-arrow{background:var(--pri);box-shadow:0 4px 10px rgba(79,13,155,.2)}
.acc.open .acc-arrow .material-symbols-outlined{color:#fff;transform:rotate(180deg)}

.acc-vis{padding:0 14px 14px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media(min-width:768px){.acc-vis{padding:0 22px 16px;gap:10px}}
@media(max-width:700px){.acc-vis{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.acc-vis{grid-template-columns:1fr}}
.vis-card{border-radius:11px;padding:12px 14px;display:flex;align-items:flex-start;gap:8px;border:1px solid transparent;transition:all .3s}
.vis-card:hover{transform:translateY(-2px);box-shadow:0 4px 10px rgba(0,0,0,.05)}
.vc-g{background:var(--g50);border-color:var(--g100)}.vc-y{background:var(--y50);border-color:var(--y100)}
.vc-r{background:var(--r50);border-color:var(--r100)}.vc-n{background:var(--s50);border-color:var(--s100)}
.vi{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.vi .material-symbols-outlined{font-size:16px}
.vi-g{background:var(--g100);color:var(--g700)}.vi-y{background:var(--y100);color:var(--y700)}
.vi-r{background:var(--r100);color:var(--r700)}.vi-n{background:var(--s100);color:var(--s500)}
.vb{flex:1;min-width:0}
.vv{font-size:18px;font-weight:900;line-height:1.1}
.vv-g{color:var(--g700)}.vv-y{color:var(--y700)}.vv-r{color:var(--r700)}.vv-n{color:var(--s700)}
.vl{font-size:10px;font-weight:600;margin-top:2px;line-height:1.3}
.vl-g{color:var(--g700)}.vl-y{color:var(--y700)}.vl-r{color:var(--r700)}.vl-n{color:var(--s500)}

.dots-row{display:flex;gap:4px;align-items:center;flex-wrap:wrap;padding:0 22px 14px}
.dot-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:10px;font-weight:700;background:var(--s50);color:var(--s600);border:1px solid var(--s100)}
.dot-c{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot-c-g{background:var(--g500)}.dot-c-y{background:var(--y500)}.dot-c-r{background:var(--r500)}

.acc-body{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.22,1,.36,1)}
.acc.open .acc-body{max-height:4000px}
.acc-body-inner{border-top:1px solid var(--s100)}
.det-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 22px;background:var(--s50);flex-wrap:wrap;gap:8px}
.det-title{font-size:11px;font-weight:800;color:var(--pri);text-transform:uppercase;letter-spacing:.04em}
.det-legend{display:flex;gap:10px}
.det-legend span{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:700;color:var(--s500)}

.ind-row{display:grid;grid-template-columns:28px 1fr 55px;gap:8px;padding:12px 14px;border-bottom:1px solid var(--s50);align-items:start;transition:all .2s}
@media(min-width:768px){.ind-row{grid-template-columns:28px 1fr 65px;gap:10px;padding:14px 22px}}
.ind-row:last-child{border-bottom:none}
.ind-row:hover{background:var(--s50)}
.ind-status{margin-top:2px;font-size:16px}
.ind-name{font-size:13px;font-weight:700;color:var(--tx)}
.ind-desc{font-size:11px;color:var(--s500);margin-top:2px;line-height:1.5}
.ind-obs{font-size:10px;color:var(--s400);margin-top:4px;line-height:1.5;font-style:italic;border-left:2px solid var(--s200);padding-left:8px}
.ind-pts{font-size:11px;font-weight:800;text-align:center;padding:3px 10px;border-radius:7px;background:var(--s50);color:var(--s600);white-space:nowrap}

/* ── Footer ── */
/* ── Utilities ── */
.mb-sm{margin-bottom:14px}.mt-sm{margin-top:12px}
.ind-g{color:var(--g500)}.ind-y{color:var(--y500)}.ind-r{color:var(--r500)}
.mini-danger{background:var(--r50)}
.mini-danger .mini-lbl,.mini-danger .mini-val,.mini-danger .mini-note{color:var(--r700)}
.anx-intro{font-size:13px;color:var(--s500);margin-bottom:14px}
.anx-intro strong{color:var(--pri)}
.meth{display:flex;gap:12px;align-items:flex-start;background:var(--s50);border-radius:12px;border:1px solid var(--s100);padding:20px;margin:32px 0}
.meth .material-symbols-outlined{color:var(--pri);flex-shrink:0}
.meth h4{font-size:13px;font-weight:800;margin-bottom:3px}
.meth p{font-size:11px;color:var(--s500);line-height:1.7}
.ftr{border-top:1px solid var(--s100);padding:20px 0;margin-top:32px}
.ftr-in{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}
@media(min-width:600px){.ftr-in{flex-direction:row;justify-content:space-between;text-align:left}}
.ftr-left img{height:24px;opacity:.4}
.ftr-copy{font-size:11px;color:var(--s400);font-weight:500}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .rv,.rv-s{opacity:1;transform:none}
}
