/* ============================================================
   Cardioteca.com — Guía Clínica Interactiva: Insuficiencia Cardíaca
   Archivo: style.css
   Prefijo: #ic-root (scoping obligatorio — sin selectores globales)
   Versión: 20260522
   © Campus Formación Sanitaria S.L. — CIF B88633318
   ============================================================ */

/* ── VARIABLES & RESET ─────────────────────────────────── */
#ic-root{--bg:#f0f4f8;--surface:#fff;--surface2:#f8fafc;--border:#dde3ed;--border-focus:#0e6fbd;--navy:#0d2d5e;--navy2:#1a4a8a;--teal:#0891b2;--teal2:#0e7490;--green:#059669;--blue:#2563eb;--amber:#d97706;--red:#dc2626;--text:#1e293b;--text2:#475569;--text3:#94a3b8;--shadow:0 1px 3px rgba(0,0,0,.08),0 4px 16px rgba(0,0,0,.06);--shadow2:0 2px 8px rgba(0,0,0,.12),0 8px 32px rgba(0,0,0,.08)}
#ic-root *{box-sizing:border-box;margin:0;padding:0}
#ic-root{background:var(--bg);color:var(--text);font-family:'Source Sans 3',sans-serif;font-size:15px;line-height:1.6;border-radius:16px;overflow:hidden;min-height:auto}
#ic-root .ic-wrap{max-width:780px;margin:0 auto;padding:28px 16px 52px}

/* ── HEADER ────────────────────────────────────────────── */
#ic-root .app-header{text-align:center;margin-bottom:34px}
#ic-root .badge{display:inline-flex;align-items:center;gap:6px;background:var(--navy);color:#fff;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:14px;font-family:'Outfit',sans-serif}
#ic-root .badge .dot{width:6px;height:6px;border-radius:50%;background:var(--teal);animation:ic-pulse 2s infinite}
@keyframes ic-pulse{0%,100%{opacity:1}50%{opacity:.4}}
#ic-root .app-header h1{font-family:'Outfit',sans-serif;font-size:26px;font-weight:700;color:var(--navy);line-height:1.2;margin-bottom:7px}
#ic-root .app-header h1 span{color:var(--teal)}
#ic-root .app-header p{color:var(--text2);font-size:14px;max-width:540px;margin:0 auto;line-height:1.6}

/* ── HUB ───────────────────────────────────────────────── */
#ic-root .hub-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:8px}
@media(min-width:520px){#ic-root .hub-grid{grid-template-columns:1fr 1fr}}
#ic-root .hub-card{background:var(--surface);border:2px solid var(--border);border-radius:16px;padding:22px;display:flex;flex-direction:column;gap:14px;transition:all .2s}
#ic-root .hub-card:not(.disabled){cursor:pointer}
#ic-root .hub-card:not(.disabled):hover{border-color:var(--navy)}
#ic-root .hub-card.disabled{opacity:.52}
#ic-root .hub-top{display:flex;align-items:center;gap:14px}
#ic-root .hub-icon{width:48px;height:48px;border-radius:13px;background:#fff;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
#ic-root .hub-num{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;display:block}
#ic-root .hub-title{font-family:'Outfit',sans-serif;font-size:16px;font-weight:700;color:var(--navy);line-height:1.25;margin-top:2px}
#ic-root .hub-desc{font-size:13px;color:var(--text2);line-height:1.55;flex:1}
#ic-root .hub-footer{display:flex;align-items:center}
#ic-root .hub-btn{background:var(--navy);color:#fff;border:none;border-radius:8px;padding:9px 20px;font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;letter-spacing:.02em}
#ic-root .hub-btn:hover{background:var(--navy2)}
#ic-root .hub-soon{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text3);background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:3px 10px;letter-spacing:.08em;text-transform:uppercase}

/* ── PROGRESS BAR ──────────────────────────────────────── */
#ic-root .ic-prog-bar{display:flex;align-items:center;margin-bottom:24px;padding:0 2px;background:transparent}
#ic-root .prog-step{display:flex;flex-direction:column;align-items:center;gap:5px;flex:1}
#ic-root .prog-circle{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;font-family:'Outfit',sans-serif;transition:all .3s;border:2px solid var(--border);background:var(--surface);color:var(--text3)}
#ic-root .prog-circle.active{border-color:var(--navy);background:var(--navy);color:#fff}
#ic-root .prog-circle.done{border-color:var(--teal);background:var(--teal);color:#fff}
#ic-root .prog-label{font-size:10px;color:var(--text3);font-weight:500;text-align:center;line-height:1.3;white-space:nowrap}
@media(max-width:400px){#ic-root .prog-label{display:none}}
#ic-root .prog-label.active{color:var(--navy);font-weight:600}
#ic-root .prog-label.done{color:var(--teal)}
#ic-root .prog-line{flex:1;height:2px;background:var(--border);transition:background .3s;max-width:56px;margin-bottom:18px}
#ic-root .prog-line.done{background:var(--teal)}

/* ── BREADCRUMB ────────────────────────────────────────── */
#ic-root .breadcrumb{background:linear-gradient(135deg,#eff6ff,#ecfdf5);border:1px solid var(--border);border-radius:10px;padding:8px 14px;margin-bottom:18px;display:flex;align-items:center;gap:7px;font-size:12px;flex-wrap:wrap}
#ic-root .bc-label{color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-family:'Outfit',sans-serif}
#ic-root .bc-value{color:var(--navy);font-weight:600;font-family:'Outfit',sans-serif}
#ic-root .bc-sep{color:var(--text3)}

/* ── CARD ──────────────────────────────────────────────── */
#ic-root .card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:var(--shadow);margin-bottom:16px}
#ic-root .card-title{font-family:'Outfit',sans-serif;font-size:18px;font-weight:600;color:var(--navy);margin-bottom:5px}
#ic-root .card-subtitle{font-size:13px;color:var(--text2);margin-bottom:22px;line-height:1.5}

/* ── FORM SECTIONS ─────────────────────────────────────── */
#ic-root .form-section{margin-bottom:22px}
#ic-root .form-section-title{font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;color:var(--teal2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:11px;padding-bottom:6px;border-bottom:1px solid var(--border)}

/* ── SYMPTOM / SIGN GRID ───────────────────────────────── */
#ic-root .sym-grid{display:grid;grid-template-columns:1fr;gap:7px}
@media(min-width:500px){#ic-root .sym-grid{grid-template-columns:1fr 1fr}}
#ic-root .sym-item{display:flex;align-items:center;gap:10px;padding:9px 13px;border:1.5px solid var(--border);border-radius:8px;background:var(--surface2);cursor:pointer;transition:all .15s;user-select:none}
#ic-root .sym-item:hover{border-color:var(--teal)}
#ic-root .sym-item.selected{border-color:var(--navy);background:var(--navy);color:#fff}
#ic-root .sym-chk{width:17px;height:17px;border-radius:4px;border:1.5px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;color:var(--navy);transition:all .15s}
#ic-root .sym-item.selected .sym-chk{border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.22);color:#fff}
#ic-root .sym-lbl{font-size:13px;font-weight:500;color:var(--text);transition:color .15s;line-height:1.4}
#ic-root .sym-item.selected .sym-lbl{color:#fff}
#ic-root .sym-tag{font-family:'JetBrains Mono',monospace;font-size:9px;background:rgba(8,145,178,.12);color:var(--teal2);padding:1px 5px;border-radius:3px;letter-spacing:.05em;text-transform:uppercase;margin-left:5px;white-space:nowrap}
#ic-root .sym-item.selected .sym-tag{background:rgba(255,255,255,.18);color:rgba(255,255,255,.72)}

/* ── OPTION LIST (ECG, Echo) ───────────────────────────── */
#ic-root .opt-list{display:flex;flex-direction:column;gap:8px}
#ic-root .opt-btn{border:2px solid var(--border);background:var(--surface2);border-radius:10px;padding:12px 16px;cursor:pointer;text-align:left;transition:all .2s;font-family:'Source Sans 3',sans-serif;font-size:14px;font-weight:500;color:var(--text);width:100%}
#ic-root .opt-btn:hover{border-color:var(--teal)}
#ic-root .opt-btn.selected{border-color:var(--navy);background:var(--navy);color:#fff}
#ic-root .opt-btn .opt-sub{font-family:'JetBrains Mono',monospace;font-size:11px;display:block;margin-top:2px;color:var(--text3)}
#ic-root .opt-btn.selected .opt-sub{color:rgba(255,255,255,.55)}

/* ── NP INPUT ──────────────────────────────────────────── */
#ic-root .np-wrap{margin-top:12px}
#ic-root .np-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
#ic-root .np-input{background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text);font-family:'JetBrains Mono',monospace;font-size:16px;font-weight:600;width:130px;transition:border-color .15s;outline:none;-webkit-appearance:none}
#ic-root .np-input:focus{border-color:var(--border-focus);background:#fff}
#ic-root .np-input::placeholder{color:#c8d4e4;font-weight:400}
#ic-root .np-unit{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--text2)}
#ic-root .np-elev{font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;color:var(--red);display:inline-flex;align-items:center;gap:4px}
#ic-root .np-norm{font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;color:var(--green);display:inline-flex;align-items:center;gap:4px}
#ic-root .np-hint{font-size:12px;color:var(--text3);margin-top:6px;font-style:italic}

/* ── LVEF INPUT ────────────────────────────────────────── */
#ic-root .lvef-wrap{margin-top:10px}
#ic-root .lvef-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
#ic-root .lvef-input{background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text);font-family:'JetBrains Mono',monospace;font-size:22px;font-weight:700;width:100px;text-align:center;transition:border-color .15s;outline:none;-webkit-appearance:none}
#ic-root .lvef-input:focus{border-color:var(--border-focus);background:#fff}
#ic-root .lvef-input::placeholder{color:#c8d4e4;font-weight:400;font-size:18px}
#ic-root .lvef-unit{font-family:'JetBrains Mono',monospace;font-size:16px;color:var(--text2)}
#ic-root .lvef-badge{display:inline-flex;align-items:center;padding:6px 14px;border-radius:20px;font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;border:2px solid;letter-spacing:.01em}
#ic-root .lvef-badge.reduced{background:#fef2f2;color:#991b1b;border-color:#fca5a5}
#ic-root .lvef-badge.mildly{background:#fffbeb;color:#92400e;border-color:#fcd34d}
#ic-root .lvef-badge.preserved{background:#eff6ff;color:#1e40af;border-color:#93c5fd}
#ic-root .lvef-hint{font-size:12px;color:var(--text3);margin-top:8px;font-style:italic}

/* ── STRUCTURAL FINDINGS ───────────────────────────────── */
#ic-root .struct-grid{display:flex;flex-direction:column;gap:8px;margin-top:10px}
#ic-root .struct-item{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;border:1.5px solid var(--border);border-radius:8px;background:var(--surface2);cursor:pointer;transition:all .15s;user-select:none}
#ic-root .struct-item:hover{border-color:var(--teal)}
#ic-root .struct-item.selected{border-color:var(--navy);background:#eff6ff}
#ic-root .struct-chk{width:17px;height:17px;border-radius:4px;border:1.5px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;margin-top:2px;color:var(--navy);transition:all .15s}
#ic-root .struct-item.selected .struct-chk{border-color:var(--navy);background:var(--navy);color:#fff}
#ic-root .struct-main{font-size:13px;font-weight:600;color:var(--text);display:block;line-height:1.4}
#ic-root .struct-item.selected .struct-main{color:var(--navy)}
#ic-root .struct-sub{font-size:11px;color:var(--text3);font-family:'JetBrains Mono',monospace;display:block;margin-top:2px;line-height:1.5}

/* ── NYHA GRID ─────────────────────────────────────────── */
#ic-root .nyha-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
#ic-root .nyha-btn{border:2px solid var(--border);background:var(--surface2);border-radius:12px;padding:16px 14px;cursor:pointer;text-align:left;transition:all .2s;width:100%}
#ic-root .nyha-btn:hover{border-color:var(--teal);transform:translateY(-1px)}
#ic-root .nyha-btn.selected{border-color:var(--navy);background:var(--navy);color:#fff}
#ic-root .nyha-class{font-family:'Outfit',sans-serif;font-size:21px;font-weight:700;color:var(--navy);display:block;margin-bottom:5px}
#ic-root .nyha-btn.selected .nyha-class{color:#fff}
#ic-root .nyha-desc{font-size:12px;color:var(--text2);line-height:1.5;display:block}
#ic-root .nyha-btn.selected .nyha-desc{color:rgba(255,255,255,.78)}
#ic-root .nyha-ex{font-size:11px;color:var(--text3);font-style:italic;display:block;margin-top:5px;line-height:1.4}
#ic-root .nyha-btn.selected .nyha-ex{color:rgba(255,255,255,.5)}

/* ── BUTTONS ───────────────────────────────────────────── */
#ic-root .nav-row{display:flex;justify-content:space-between;align-items:center;margin-top:22px;gap:12px}
#ic-root .btn-back{margin-top:10px;background:none;border:1.5px solid var(--border);border-radius:8px;padding:10px 18px;font-family:'Source Sans 3',sans-serif;font-size:14px;font-weight:500;color:var(--text2);cursor:pointer;transition:all .2s;flex-shrink:0}
#ic-root .btn-back:hover{border-color:var(--navy);color:var(--navy)}
#ic-root .btn-next{background:var(--navy);color:#fff;border:none;border-radius:8px;padding:11px 24px;font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:7px;letter-spacing:.01em}
#ic-root .btn-next:hover{background:var(--navy2);transform:translateY(-1px);box-shadow:0 4px 12px rgba(13,45,94,.22)}
#ic-root .btn-analyze{background:linear-gradient(135deg,var(--teal2),var(--navy));color:#fff;border:none;border-radius:8px;padding:14px 32px;font-family:'Outfit',sans-serif;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;width:100%;display:flex;align-items:center;justify-content:center;gap:10px;letter-spacing:.02em;box-shadow:0 4px 16px rgba(8,145,178,.28)}
#ic-root .btn-analyze:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px rgba(8,145,178,.38)}
#ic-root .btn-analyze:disabled{background:linear-gradient(135deg,var(--text3),var(--text3));box-shadow:none;cursor:not-allowed;opacity:.7}
#ic-root .btn-restart{background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;padding:11px 24px;font-family:'Source Sans 3',sans-serif;font-size:14px;font-weight:600;color:var(--text2);cursor:pointer;transition:all .2s;width:100%;margin-top:10px;display:block;text-align:center}
#ic-root .btn-restart:hover{background:var(--border);color:var(--navy)}
#ic-root .btn-module{background:linear-gradient(135deg,var(--teal2),var(--navy));color:#fff;border:none;border-radius:8px;padding:14px 32px;font-family:'Outfit',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;width:100%;display:flex;align-items:center;justify-content:center;gap:10px;margin-top:14px;box-shadow:0 4px 16px rgba(8,145,178,.22)}
#ic-root .btn-module:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(8,145,178,.32)}
#ic-root .btn-hub{background:none;border:1.5px solid var(--border);border-radius:8px;padding:11px 24px;font-family:'Source Sans 3',sans-serif;font-size:14px;font-weight:600;color:var(--text2);cursor:pointer;transition:all .2s;width:100%;margin-top:8px;display:block;text-align:center}
#ic-root .btn-hub:hover{border-color:var(--navy);color:var(--navy)}

/* ── ECG FINDINGS SUBPANEL ─────────────────────────────── */
#ic-root .sub-panel{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px;margin-top:12px}
#ic-root .sub-panel-title{font-size:12px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}

/* ── RESULT ────────────────────────────────────────────── */
#ic-root .res-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}
#ic-root .res-icon{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}
#ic-root .res-icon.confirmed{background:#fef2f2;color:var(--red)}
#ic-root .res-icon.probable{background:#fffbeb;color:var(--amber)}
#ic-root .res-icon.unlikely{background:#f0fdf4;color:var(--green)}
#ic-root .res-icon.possible{background:#f0fdf4;color:var(--green)}
#ic-root .res-icon.insufficient{background:#f8fafc;color:var(--text3)}
#ic-root .res-title{font-family:'Outfit',sans-serif;font-size:22px;font-weight:700;color:var(--navy);line-height:1.2;margin-bottom:4px}
#ic-root .res-sub{font-size:14px;color:var(--text2)}

/* ── EVIDENCE BADGES ───────────────────────────────────── */
#ic-root .ev-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
#ic-root .ev-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:20px;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:500;border:1.5px solid}
#ic-root .ev-badge.classI{background:#f0fdf4;color:#065f46;border-color:#6ee7b7}
#ic-root .ev-badge.loe{background:#f8fafc;color:var(--text2);border-color:var(--border)}

/* ── PHENOTYPE CARD ────────────────────────────────────── */
#ic-root .phenotype-card{border:2px solid;border-radius:12px;padding:14px 18px;margin-bottom:16px;display:flex;align-items:center;gap:16px}
#ic-root .phenotype-card.ICFEr{border-color:#fca5a5;background:#fef2f2}
#ic-root .phenotype-card.ICFElr{border-color:#fcd34d;background:#fffbeb}
#ic-root .phenotype-card.ICFEp{border-color:#93c5fd;background:#eff6ff}
#ic-root .ph-icon{font-size:30px;flex-shrink:0}
#ic-root .ph-lbl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-family:'Outfit',sans-serif;opacity:.65;display:block;margin-bottom:3px}
#ic-root .ph-val{font-family:'Outfit',sans-serif;font-size:19px;font-weight:700;display:block;line-height:1.2}
#ic-root .phenotype-card.ICFEr .ph-val{color:var(--red)}
#ic-root .phenotype-card.ICFElr .ph-val{color:var(--amber)}
#ic-root .phenotype-card.ICFEp .ph-val{color:var(--blue)}
#ic-root .ph-sub{font-size:12px;color:var(--text2);display:block;margin-top:3px}

/* ── NYHA RESULT BADGE ─────────────────────────────────── */
#ic-root .nyha-badge{display:inline-flex;align-items:center;gap:12px;background:var(--surface2);border:2px solid var(--border);border-radius:10px;padding:11px 18px;margin-bottom:16px}
#ic-root .nyha-badge-num{font-family:'Outfit',sans-serif;font-size:20px;font-weight:700;color:var(--navy)}
#ic-root .nyha-badge-desc{font-size:13px;color:var(--text2)}

/* ── RESULT TEXT ───────────────────────────────────────── */
#ic-root .res-text{font-size:15px;color:var(--text);line-height:1.7;margin-bottom:16px}
#ic-root .m2-intro-banner{background:linear-gradient(135deg,#f0f4f8,#eff6ff);border:1px solid var(--border);border-left:4px solid var(--navy);border-radius:0 12px 12px 0;padding:14px 18px;margin:20px 0 16px;font-size:15px;font-family:'Source Sans 3',sans-serif;color:var(--text);line-height:1.65}
#ic-root .m2-intro-banner strong{font-weight:700;color:var(--navy)}

/* ── PENDING TESTS CARD ────────────────────────────────── */
#ic-root .pending-card{background:#fff8e1;border:1px solid #fde68a;border-radius:10px;padding:14px 16px;margin-bottom:14px}
#ic-root .pending-title{font-size:12px;font-weight:700;color:#92400e;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;font-family:'Outfit',sans-serif}
#ic-root .pending-list{list-style:none;display:flex;flex-direction:column;gap:7px}
#ic-root .pending-list li{display:flex;gap:8px;font-size:13px;color:#78350f;align-items:flex-start;line-height:1.5}
#ic-root .pending-list li::before{content:"→";color:var(--amber);font-weight:700;flex-shrink:0;margin-top:1px}

/* ── NOTES LIST ────────────────────────────────────────── */
#ic-root .notes-box{background:var(--surface2);border-radius:10px;padding:14px 16px;margin-bottom:14px}
#ic-root .notes-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;font-family:'Outfit',sans-serif}
#ic-root .notes-box ul{list-style:none;display:flex;flex-direction:column;gap:8px}
#ic-root .notes-box li{display:block;position:relative;padding-left:14px;font-size:13px;color:var(--text2);line-height:1.55}
#ic-root .notes-box li::before{content:"•";color:var(--teal);font-weight:700;position:absolute;left:0;top:0}

/* ── WARNING BOX ───────────────────────────────────────── */
#ic-root .warn-box{background:#fef2f2;border:1px solid #fca5a5;border-radius:10px;padding:11px 14px;margin-bottom:10px;font-size:13px;color:#7f1d1d;display:flex;gap:8px;align-items:flex-start;line-height:1.5}
#ic-root .warn-ico{flex-shrink:0;font-size:14px;margin-top:1px}

/* ── DISCLAIMER ────────────────────────────────────────── */
#ic-root .disclaimer{background:#fff8e1;border:1px solid #fde68a;border-radius:10px;padding:12px 16px;margin:16px 0;display:block}
#ic-root .disc-text{font-size:12px;color:#78350f;line-height:1.55}
#ic-root .disc-text strong{display:block;margin-bottom:3px;font-size:12px}
#ic-root .disclaimer-text{font-size:11px;color:#78350f;line-height:1.6}
#ic-root .disclaimer-text strong{display:inline;font-weight:700}
@media(min-width:520px){#ic-root .disclaimer-text{font-size:12px}}

/* ── FOOTER ────────────────────────────────────────────── */
#ic-root .app-footer{text-align:center;margin-top:28px;font-size:11px;color:var(--text3);line-height:1.8;padding:0 8px}
#ic-root .app-footer strong{color:var(--text2)}
#ic-root .app-footer em{font-style:italic}

/* ── PRÓXIMAMENTE ──────────────────────────────────────── */
#ic-root .soon-card{background:var(--surface);border:2px dashed var(--border);border-radius:16px;padding:48px 24px;text-align:center;margin-bottom:16px}
#ic-root .soon-ico{font-size:42px;margin-bottom:16px}
#ic-root .soon-title{font-family:'Outfit',sans-serif;font-size:20px;font-weight:700;color:var(--navy);margin-bottom:8px}
#ic-root .soon-text{font-size:14px;color:var(--text2);max-width:420px;margin:0 auto 22px;line-height:1.6}

/* ── M2: SELECTOR DE FENOTIPO ──────────────────────────── */
#ic-root .ph-select-grid{display:grid;grid-template-columns:1fr;gap:10px}
@media(min-width:460px){#ic-root .ph-select-grid{grid-template-columns:repeat(3,1fr)}}
#ic-root .ph-sel-btn{border:2px solid var(--border);background:var(--surface2);border-radius:12px;padding:16px 10px;cursor:pointer;text-align:center;transition:all .2s;width:100%}
#ic-root .ph-sel-btn:hover{border-color:var(--teal);transform:translateY(-1px)}
#ic-root .ph-sel-btn.selected{border-color:var(--navy);background:var(--navy)}
#ic-root .ph-sel-ico{font-size:26px;display:block;margin-bottom:6px}
#ic-root .ph-sel-nm{font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;color:var(--navy);display:block;margin-bottom:3px;line-height:1.2}
#ic-root .ph-sel-btn.selected .ph-sel-nm{color:#fff}
#ic-root .ph-sel-fevi{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text3);display:block}
#ic-root .ph-sel-btn.selected .ph-sel-fevi{color:rgba(255,255,255,.6)}

/* ── M2: IMPORT BANNER ─────────────────────────────────── */
#ic-root .import-banner{background:linear-gradient(135deg,#eff6ff,#ecfdf5);border:1.5px solid #93c5fd;border-radius:10px;padding:12px 16px;margin-bottom:18px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
#ic-root .import-ico{font-size:20px;flex-shrink:0}
#ic-root .import-text{flex:1;font-size:13px;color:var(--navy);line-height:1.5}
#ic-root .import-text strong{display:block;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;margin-bottom:2px}
#ic-root .btn-import{background:var(--navy);color:#fff;border:none;border-radius:7px;padding:7px 14px;font-family:'Outfit',sans-serif;font-size:12px;font-weight:600;cursor:pointer;flex-shrink:0}
#ic-root .btn-import:hover{background:var(--navy2)}

/* ── M2: PARÁMETROS NUMÉRICOS ──────────────────────────── */
#ic-root .num-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(min-width:500px){#ic-root .num-grid.cols3{grid-template-columns:1fr 1fr 1fr}}
#ic-root .num-field{display:flex;flex-direction:column;gap:5px}
#ic-root .num-label{font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
#ic-root .num-unit{font-family:'JetBrains Mono',monospace;font-weight:400;color:var(--text3);font-size:10px;text-transform:none;letter-spacing:0}
#ic-root .num-input{background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;padding:10px 10px;color:var(--text);font-family:'JetBrains Mono',monospace;font-size:20px;font-weight:700;width:100%;text-align:center;transition:border-color .15s;outline:none;-webkit-appearance:none;appearance:none}
#ic-root .num-input:focus{border-color:var(--border-focus);background:#fff}
#ic-root .num-input::placeholder{color:#c8d4e4;font-weight:400;font-size:16px}
#ic-root .num-input.ic-crit{border-color:#ef4444!important;background:#fef2f2!important;color:#b91c1c!important}
#ic-root .num-input.ic-warn{border-color:#f59e0b!important;background:#fffbeb!important;color:#92400e!important}
#ic-root .num-input.ic-ok{border-color:#10b981!important;background:#f0fdf4!important}
#ic-root .ic-alert-critical{background:#fef2f2;border:2px solid #ef4444;border-radius:14px;padding:16px 18px;margin-bottom:12px}
#ic-root .ic-alert-warning{background:#fffbeb;border:2px solid #f59e0b;border-radius:14px;padding:16px 18px;margin-bottom:12px}
#ic-root .ic-alert-title-crit{font-family:'Outfit',sans-serif;font-weight:800;font-size:13px;color:#b91c1c;display:flex;align-items:center;gap:8px;margin-bottom:8px}
#ic-root .ic-alert-title-warn{font-family:'Outfit',sans-serif;font-weight:800;font-size:13px;color:#92400e;display:flex;align-items:center;gap:8px;margin-bottom:8px}
#ic-root .ic-alert-title-crit .ic-alert-ico{font-size:18px}
#ic-root .ic-alert-body{font-size:12px;color:#374151;line-height:1.65}
#ic-root .mgmt-panel{background:#f8fafc;border-radius:10px;padding:14px;font-size:12px;color:var(--text2);margin-top:4px}
#ic-root .mgmt-src{font-size:10px;font-family:'JetBrains Mono',monospace;color:var(--teal);font-weight:700;letter-spacing:.06em;margin-bottom:10px}
#ic-root .mgmt-section-title{font-weight:700;color:var(--navy);font-size:12px;margin:10px 0 6px}
#ic-root .mgmt-section-title:first-of-type{margin-top:0}
#ic-root .mgmt-table{width:100%;border-collapse:collapse;font-size:11px}
#ic-root .mgmt-table th{padding:5px 8px;text-align:left;font-weight:700;background:#e2e8f0}
#ic-root .mgmt-table td{padding:5px 8px}
#ic-root .mgmt-adj{display:flex;flex-direction:column;gap:4px}
#ic-root .mgmt-adj-row{border-radius:6px;padding:6px 8px;border:1px solid}
#ic-root .mgmt-adj-cond{font-weight:700;color:#374151;margin-bottom:2px;font-size:11px}
#ic-root .mgmt-adj-act{font-size:11px}
#ic-root .mgmt-special{background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:8px;margin-top:10px;font-size:11px;color:#1e40af}
#ic-root .mgmt-btn{background:linear-gradient(135deg,#f0f9ff,#eff6ff);border:1.5px solid var(--teal);color:var(--teal2);border-radius:10px;padding:10px 16px;font-size:13px;font-weight:700;cursor:pointer;font-family:'Outfit',sans-serif;letter-spacing:.02em;margin-top:10px;display:block;width:100%;text-align:left;transition:all .2s}
#ic-root .mgmt-btn:hover{background:linear-gradient(135deg,var(--teal2),var(--navy));color:#fff;border-color:var(--teal2)}
#ic-root .mgmt-close-btn{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 16px;font-size:12px;font-weight:600;cursor:pointer;font-family:'Source Sans 3',sans-serif;color:var(--text2);margin-top:14px;display:block;width:100%;text-align:center;transition:all .15s}
#ic-root .mgmt-close-btn:hover{background:var(--border);color:var(--navy)}
#ic-root .k24-grid{display:flex;flex-direction:column;gap:6px;margin-top:8px}
#ic-root .k24-row{border-radius:8px;padding:10px 12px;border:1px solid;font-size:12px}
#ic-root .num-hint{font-size:11px;color:var(--text3);font-style:italic;margin-top:2px;line-height:1.4}

/* ── M2: COMORBILIDADES ────────────────────────────────── */
#ic-root .comorb-grid{display:flex;flex-direction:column;gap:8px}
#ic-root .comorb-item{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;border:1.5px solid var(--border);border-radius:8px;background:var(--surface2);cursor:pointer;transition:all .15s;user-select:none}
#ic-root .comorb-item:hover{border-color:var(--teal)}
#ic-root .comorb-item.selected{border-color:var(--navy);background:#eff6ff}
#ic-root .comorb-chk{width:17px;height:17px;border-radius:4px;border:1.5px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;margin-top:2px;color:var(--navy);transition:all .15s}
#ic-root .comorb-item.selected .comorb-chk{border-color:var(--navy);background:var(--navy);color:#fff}
#ic-root .comorb-main{font-size:13px;font-weight:600;color:var(--text);display:block;line-height:1.4}
#ic-root .comorb-sub{font-size:11px;color:var(--text3);display:block;margin-top:2px;line-height:1.4;font-family:'JetBrains Mono',monospace}

/* ── M2: PILARES (grid 2×2) ────────────────────────────── */
#ic-root .pillar-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:20px}
/* pillar-grid: single column always */
#ic-root .pillar-card{border:2px solid var(--border);border-radius:14px;padding:18px;background:var(--surface)}
#ic-root .pillar-card.indicated{border-color:#6ee7b7;background:#f0fdf4}
#ic-root .pillar-card.caution{border-color:#fcd34d;background:#fffbeb}
#ic-root .pillar-card.contraindicated{border-color:#fca5a5;background:#fef2f2}
#ic-root .pillar-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:10px;flex-wrap:wrap}
#ic-root .pillar-num{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text3);letter-spacing:.06em;text-transform:uppercase;display:block;margin-bottom:3px}
#ic-root .pillar-name{font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;color:var(--navy);line-height:1.3}
#ic-root .pillar-status{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;flex-shrink:0;margin-top:2px}
#ic-root .pillar-status.indicated{background:var(--green);color:#fff}
#ic-root .pillar-status.caution{background:var(--amber);color:#fff}
#ic-root .pillar-status.contraindicated{background:var(--red);color:#fff}
#ic-root .pillar-drugs{font-size:12px;color:var(--text2);margin-bottom:10px;line-height:1.55}
#ic-root .pillar-reason{font-size:12px;line-height:1.5;margin-bottom:8px;display:flex;gap:6px;align-items:flex-start;padding:7px 10px;border-radius:7px}
#ic-root .pillar-reason.caution{background:rgba(217,119,6,.1);color:#78350f}
#ic-root .pillar-reason.contraindicated{background:rgba(220,38,38,.08);color:#7f1d1d}
#ic-root .pillar-ev{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
#ic-root .dose-box{background:rgba(8,145,178,.07);border:1px solid rgba(8,145,178,.18);border-radius:8px;padding:9px 11px;margin-top:10px}
#ic-root .dose-label{font-size:10px;font-weight:700;color:var(--teal2);text-transform:uppercase;letter-spacing:.07em;display:block;margin-bottom:4px;font-family:'Outfit',sans-serif}
#ic-root .dose-val{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text);line-height:1.6;display:block}

/* ── M2: TRATAMIENTOS ADICIONALES ──────────────────────── */
#ic-root .add-section-title{font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;color:var(--teal2);text-transform:uppercase;letter-spacing:.08em;margin:20px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
#ic-root .add-card{background:var(--surface);border:1.5px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:10px}
#ic-root .add-card.ok{border-color:#6ee7b7;background:#f0fdf4}
#ic-root .add-card.ok-amber{border-color:#fcd34d;background:#fffbeb}
#ic-root .add-card.dimmed{background:var(--surface2);border-color:var(--border)}
#ic-root .add-card.dimmed .add-name{color:var(--text2)}
#ic-root .add-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:7px;flex-wrap:wrap}
#ic-root .add-name{font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;color:var(--navy)}
#ic-root .add-indication{font-size:13px;color:var(--text2);margin-bottom:7px;line-height:1.55}
#ic-root .add-dose{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text);background:rgba(8,145,178,.07);border:1px solid rgba(8,145,178,.15);border-radius:6px;padding:6px 10px;display:block;margin-bottom:7px;line-height:1.6}
#ic-root .add-note{font-size:12px;color:var(--text2);font-style:italic;line-height:1.5}


/* ── M2: LAYOUT ICFElr / ICFEp ─────────────────────────── */
#ic-root .spotlight-card{border:2px solid #6ee7b7;background:#f0fdf4;border-radius:14px;padding:20px;margin-bottom:14px}
#ic-root .spotlight-label{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;display:block}
#ic-root .spotlight-title{font-family:'Outfit',sans-serif;font-size:17px;font-weight:700;color:var(--navy);margin-bottom:6px}
#ic-root .spotlight-sub{font-size:13px;color:var(--text2);margin-bottom:12px;line-height:1.55}

/* ── M3: DISPOSITIVOS ──────────────────────────────────── */
#ic-root .device-card{border:2px solid var(--border);border-radius:14px;padding:20px;margin-bottom:14px;background:var(--surface)}
#ic-root .device-card.indicated{border-color:#6ee7b7;background:#f0fdf4}
#ic-root .device-card.consider{border-color:#93c5fd;background:#eff6ff}
#ic-root .device-card.consider-weak{border-color:#fcd34d;background:#fffbeb}
#ic-root .device-card.wait{border-color:#93c5fd;background:#eff6ff}
#ic-root .device-card.not-indicated{border-color:#fca5a5;background:#fef2f2}
#ic-root .device-card.contraindicated{border-color:#fca5a5;background:#fef2f2}
#ic-root .device-card.na{border-color:var(--border);background:var(--surface2);opacity:.7}
#ic-root .device-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px;flex-wrap:wrap}
#ic-root .device-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
#ic-root .device-icon.indicated{background:#d1fae5;color:var(--green)}
#ic-root .device-icon.consider{background:#dbeafe;color:var(--blue)}
#ic-root .device-icon.consider-weak{background:#fef9c3;color:var(--amber)}
#ic-root .device-icon.wait{background:#dbeafe;color:var(--blue)}
#ic-root .device-icon.not-indicated,.device-icon.contraindicated{background:#fee2e2;color:var(--red)}
#ic-root .device-icon.na{background:var(--surface2);color:var(--text3)}
#ic-root .device-title{font-family:'Outfit',sans-serif;font-size:16px;font-weight:700;color:var(--navy);margin-bottom:3px}
#ic-root .device-subtitle{font-size:12px;color:var(--text2)}
#ic-root .device-text{font-size:14px;color:var(--text);line-height:1.65;margin-bottom:10px}
#ic-root .device-note{font-size:12px;color:var(--text2);font-style:italic;line-height:1.55;padding:8px 12px;background:rgba(0,0,0,.03);border-radius:7px}

/* ── M3: IC AVANZADA ───────────────────────────────────── */
#ic-root .adv-section{border:2px solid var(--border);border-radius:14px;padding:20px;margin-bottom:14px;background:var(--surface)}
#ic-root .adv-section.confirmed{border-color:#fca5a5;background:#fef2f2}
#ic-root .adv-section.borderline{border-color:#fcd34d;background:#fffbeb}
#ic-root .adv-criteria{display:flex;flex-direction:column;gap:8px;margin:14px 0}
#ic-root .adv-crit-row{display:flex;align-items:flex-start;gap:10px;padding:10px 13px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface2);font-size:13px}
#ic-root .adv-crit-row.met{border-color:#fca5a5;background:#fef2f2}
#ic-root .adv-dot{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;margin-top:1px}
#ic-root .adv-dot.met{background:var(--red);color:#fff}
#ic-root .adv-dot.unmet{background:var(--border);color:var(--text3)}
#ic-root .adv-advanced-title{font-family:'Outfit',sans-serif;font-size:16px;font-weight:700;color:var(--red);margin-bottom:6px}
#ic-root .adv-borderline-title{font-family:'Outfit',sans-serif;font-size:16px;font-weight:700;color:var(--amber);margin-bottom:6px}
#ic-root .adv-option{background:var(--surface);border:1.5px solid var(--border);border-radius:10px;padding:13px 16px;margin-bottom:8px}
#ic-root .adv-option-name{font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;color:var(--navy);display:block;margin-bottom:3px}
#ic-root .adv-option-text{font-size:12px;color:var(--text2);line-height:1.55}

/* ── M4: PERFIL HEMODINÁMICO 2×2 ──────────────────────── */
#ic-root .profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
#ic-root .profile-cell{border-radius:12px;padding:14px 10px;text-align:center;border:2px solid;transition:all .2s;cursor:default}
#ic-root .profile-cell .pc-label{font-family:'JetBrains Mono',monospace;font-size:22px;font-weight:700;display:block;margin-bottom:4px}
#ic-root .profile-cell .pc-name{font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;display:block;margin-bottom:2px}
#ic-root .profile-cell .pc-sub{font-size:11px;display:block;line-height:1.4}
#ic-root .profile-cell.active-A{border-color:#6ee7b7;background:#f0fdf4}
#ic-root .profile-cell.active-A .pc-label{color:var(--green)}
#ic-root .profile-cell.active-A .pc-name{color:#065f46}
#ic-root .profile-cell.active-A .pc-sub{color:#059669}
#ic-root .profile-cell.active-B{border-color:#fcd34d;background:#fffbeb}
#ic-root .profile-cell.active-B .pc-label{color:var(--amber)}
#ic-root .profile-cell.active-B .pc-name{color:#92400e}
#ic-root .profile-cell.active-B .pc-sub{color:#b45309}
#ic-root .profile-cell.active-L{border-color:#93c5fd;background:#eff6ff}
#ic-root .profile-cell.active-L .pc-label{color:var(--blue)}
#ic-root .profile-cell.active-L .pc-name{color:#1e40af}
#ic-root .profile-cell.active-L .pc-sub{color:#2563eb}
#ic-root .profile-cell.active-C{border-color:#fca5a5;background:#fef2f2}
#ic-root .profile-cell.active-C .pc-label{color:var(--red)}
#ic-root .profile-cell.active-C .pc-name{color:#991b1b}
#ic-root .profile-cell.active-C .pc-sub{color:#dc2626}
#ic-root .profile-cell.inactive{border-color:var(--border);background:var(--surface2);opacity:.42}
#ic-root .profile-cell.inactive .pc-label{color:var(--text3)}
#ic-root .profile-cell.inactive .pc-name{color:var(--text3)}
#ic-root .profile-cell.inactive .pc-sub{color:var(--text3)}
#ic-root .profile-legend{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:16px;font-size:11px}
#ic-root .profile-legend-item{display:flex;align-items:center;gap:6px;color:var(--text2)}
#ic-root .profile-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* ── M4: ACCIÓN URGENTE ────────────────────────────────── */
#ic-root .action-section-title{font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;color:var(--teal2);text-transform:uppercase;letter-spacing:.08em;margin:18px 0 8px;padding-bottom:5px;border-bottom:1px solid var(--border)}
#ic-root .action-card{border-left:4px solid;border-radius:0 10px 10px 0;padding:13px 16px;margin-bottom:8px;background:var(--surface);border-top:1px solid var(--border);border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
#ic-root .action-card.red{border-left-color:var(--red)}
#ic-root .action-card.amber{border-left-color:var(--amber)}
#ic-root .action-card.blue{border-left-color:var(--blue)}
#ic-root .action-card.green{border-left-color:var(--green)}
#ic-root .action-card.teal{border-left-color:var(--teal)}
#ic-root .action-card.grey{border-left-color:var(--border)}
#ic-root .action-head{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;margin-bottom:6px}
#ic-root .action-title{font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;color:var(--navy)}
#ic-root .action-body{font-size:13px;color:var(--text);line-height:1.6}
#ic-root .action-dose{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text);background:rgba(8,145,178,.06);border:1px solid rgba(8,145,178,.15);border-radius:6px;padding:7px 10px;margin-top:8px;display:block;line-height:1.7;white-space:pre-line}
#ic-root .action-note{font-size:12px;color:var(--text2);font-style:italic;margin-top:6px;line-height:1.5}
#ic-root .action-warn{font-size:12px;color:#7f1d1d;background:#fef2f2;border:1px solid #fca5a5;border-radius:6px;padding:7px 10px;margin-top:7px;display:flex;gap:6px;align-items:flex-start;line-height:1.5}

/* ── M4: CONGESTIÓN / HIPOPERFUSIÓN CHECKLIST ──────────── */
#ic-root .two-col-checks{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){#ic-root .two-col-checks{grid-template-columns:1fr}}
#ic-root .check-col-title{font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px;padding:6px 10px;border-radius:6px;display:flex;align-items:center;gap:6px}
#ic-root .check-col-title.wet{background:#fffbeb;color:#92400e}
#ic-root .check-col-title.cold{background:#eff6ff;color:#1e40af}
#ic-root .check-items{display:flex;flex-direction:column;gap:6px}
#ic-root .check-item{display:flex;align-items:center;gap:8px;padding:8px 11px;border:1.5px solid var(--border);border-radius:7px;background:var(--surface2);cursor:pointer;transition:all .15s;user-select:none;font-size:13px;font-weight:500;color:var(--text)}
#ic-root .check-item:hover{border-color:var(--teal)}
#ic-root .check-item.wet-sel{border-color:#fcd34d;background:#fffbeb;color:#92400e}
#ic-root .check-item.cold-sel{border-color:#93c5fd;background:#eff6ff;color:#1e40af}
#ic-root .check-box{width:16px;height:16px;border-radius:3px;border:1.5px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0;transition:all .15s}
#ic-root .check-item.wet-sel .check-box{border-color:var(--amber);background:var(--amber);color:#fff}
#ic-root .check-item.cold-sel .check-box{border-color:var(--blue);background:var(--blue);color:#fff}

/* ── M4: CRITERIOS DE ALTA ─────────────────────────────── */
#ic-root .discharge-grid{display:grid;grid-template-columns:1fr;gap:6px;margin-top:8px}
#ic-root .dc-item{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--text2);line-height:1.5;padding:5px 0}
#ic-root .dc-dot{width:6px;height:6px;border-radius:50%;background:var(--teal);flex-shrink:0;margin-top:6px}
/* ── M5: ESTRATEGIA DIURÉTICA ──────────────────────────── */
#ic-root .m5-prog-bar{display:flex;align-items:center;margin-bottom:24px;padding:0 4px}
#ic-root .ctx-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:8px}
@media(min-width:520px){#ic-root .ctx-grid{grid-template-columns:repeat(3,1fr)}}
#ic-root .ctx-btn{background:var(--surface2);border:2px solid var(--border);border-radius:14px;padding:18px 16px;cursor:pointer;text-align:left;transition:all .2s;width:100%;display:block}
#ic-root .ctx-btn:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:0 4px 16px rgba(8,145,178,.12)}
#ic-root .ctx-btn.m5sel{border-color:var(--navy);background:linear-gradient(135deg,#eff6ff,#f0fdf4)}
#ic-root .ctx-ico{font-size:28px;display:block;margin-bottom:6px}
#ic-root .ctx-name{font-family:'Outfit',sans-serif;font-size:15px;font-weight:700;color:var(--navy);display:block;margin-bottom:3px}
#ic-root .ctx-desc{font-size:12px;color:var(--text2);line-height:1.5;display:block}
#ic-root .m5-hub-grid{display:grid;grid-template-columns:1fr;gap:14px;margin:16px 0 8px}
@media(min-width:520px){#ic-root .m5-hub-grid{grid-template-columns:1fr 1fr}}
#ic-root .m5-hub-card{background:var(--surface);border:2px solid var(--border);border-radius:16px;padding:22px;display:flex;flex-direction:column;gap:12px;cursor:pointer;transition:all .2s}
#ic-root .m5-hub-card:hover{border-color:var(--teal)}
#ic-root .m5-hub-card.m5sel{border-color:var(--navy);box-shadow:var(--shadow2)}
#ic-root .m5-hemo-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}
#ic-root .m5-hemo-btn{background:var(--surface2);border:2px solid var(--border);border-radius:12px;padding:14px 12px;cursor:pointer;text-align:center;transition:all .2s;width:100%}
#ic-root .m5-hemo-btn:hover{border-color:var(--teal)}
#ic-root .m5-hemo-btn.m5sel{border-color:var(--navy);background:var(--navy)}
#ic-root .m5-hemo-ico{font-size:22px;display:block;margin-bottom:4px}
#ic-root .m5-hemo-name{font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;color:var(--navy);display:block}
#ic-root .m5-hemo-btn.m5sel .m5-hemo-name{color:#fff}
#ic-root .m5-hemo-sub{font-size:11px;color:var(--text3);display:block;margin-top:3px;line-height:1.3}
#ic-root .m5-hemo-btn.m5sel .m5-hemo-sub{color:rgba(255,255,255,.6)}
#ic-root .m5-cs-grid{display:flex;flex-direction:column;gap:10px}
#ic-root .m5-cs-row{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
#ic-root .m5-cs-label{font-size:12px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}
#ic-root .m5-cs-opts{display:flex;gap:6px;flex-wrap:wrap}
#ic-root .m5-cs-opt{border:1.5px solid var(--border);background:var(--surface);border-radius:8px;padding:5px 10px;cursor:pointer;font-size:12px;font-weight:500;color:var(--text2);transition:all .15s;text-align:center}
#ic-root .m5-cs-opt:hover{border-color:var(--teal)}
#ic-root .m5-cs-opt.m5sel{background:var(--navy);border-color:var(--navy);color:#fff}
#ic-root .m5-cong-result{border-radius:12px;padding:14px 18px;margin:12px 0;display:flex;align-items:center;gap:14px;border:2px solid}
#ic-root .m5-cong-g{background:#f0fdf4;border-color:#6ee7b7}
#ic-root .m5-cong-b{background:#eff6ff;border-color:#93c5fd}
#ic-root .m5-cong-a{background:#fffbeb;border-color:#fcd34d}
#ic-root .m5-cong-r{background:#fef2f2;border-color:#fca5a5}
#ic-root .m5-cong-ico{font-size:26px;flex-shrink:0}
#ic-root .m5-cong-grade{font-family:'Outfit',sans-serif;font-size:17px;font-weight:700}
#ic-root .m5-dose-box{background:var(--navy);color:#fff;border-radius:12px;padding:16px;margin:10px 0}
#ic-root .m5c-action{border-radius:14px;padding:20px 22px;margin-bottom:14px}
#ic-root .m5c-action.up{background:linear-gradient(135deg,#fff7ed,#fef3c7);border:2px solid #f59e0b}
#ic-root .m5c-action.down{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #60a5fa}
#ic-root .m5c-action.ok{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #4ade80}
#ic-root .m5c-action-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-family:Outfit,sans-serif;opacity:.75;margin-bottom:6px}
#ic-root .m5c-action-main{font-family:Outfit,sans-serif;font-size:24px;font-weight:700;line-height:1.2;margin-bottom:6px}
#ic-root .m5c-action-sub{font-size:13px;opacity:.85;line-height:1.5}
#ic-root .m5c-action.up .m5c-action-main{color:#92400e}#ic-root .m5c-action.up .m5c-action-label{color:#92400e}
#ic-root .m5c-action.down .m5c-action-main{color:#1e40af}#ic-root .m5c-action.down .m5c-action-label{color:#1e40af}
#ic-root .m5c-action.ok .m5c-action-main{color:#065f46}#ic-root .m5c-action.ok .m5c-action-label{color:#065f46}
#ic-root .m5c-switch{background:#f8fafc;border:1.5px solid var(--border);border-radius:12px;padding:14px 18px;margin-bottom:14px;display:flex;gap:12px;align-items:flex-start}
#ic-root .m5c-switch-ico{font-size:20px;flex-shrink:0;margin-top:2px}
#ic-root .m5c-switch-body{flex:1}
#ic-root .m5c-switch-title{font-family:Outfit,sans-serif;font-size:14px;font-weight:700;color:var(--navy);margin-bottom:4px}
#ic-root .m5c-switch-text{font-size:13px;color:var(--text2);line-height:1.5}
#ic-root .m5c-notes{background:var(--surface2);border-radius:10px;padding:14px 16px;margin-bottom:12px}
#ic-root .m5c-notes-title{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-family:Outfit,sans-serif}
#ic-root .m5c-note{display:flex;gap:8px;font-size:13px;color:var(--text2);line-height:1.5;margin-bottom:6px}
#ic-root .m5c-note:last-child{margin-bottom:0}
#ic-root .m5c-note-dot{color:var(--teal);font-weight:700;flex-shrink:0}
#ic-root .m5c-tab-header{background:var(--surface2);border:1.5px solid var(--border);border-radius:14px;padding:16px 18px;margin-bottom:16px}
#ic-root .m5c-tab-intro{font-size:13px;color:var(--text2);margin-bottom:14px;line-height:1.5}
#ic-root .m5c-tab-intro strong{color:var(--navy)}
#ic-root .m5c-tabs{display:grid;grid-template-columns:1fr;gap:8px}@media(min-width:420px){#ic-root .m5c-tabs{grid-template-columns:1fr 1fr;gap:10px}}
#ic-root .m5c-tab-btn{border:2px solid var(--border);border-radius:12px;padding:14px 16px;cursor:pointer;text-align:left;background:var(--surface);transition:all .2s;display:flex;align-items:center;gap:12px}
#ic-root .m5c-tab-btn:hover{border-color:var(--teal);box-shadow:0 2px 8px rgba(8,145,178,.1)}
#ic-root .m5c-tab-btn.active-a{border-color:#f59e0b;background:#fffbeb;box-shadow:0 2px 12px rgba(245,158,11,.2)}
#ic-root .m5c-tab-btn.active-b{border-color:var(--teal);background:#ecfeff;box-shadow:0 2px 12px rgba(8,145,178,.2)}
#ic-root .m5c-tab-ico{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;font-size:18px;font-weight:700;flex-shrink:0;border:2px solid var(--border);color:var(--text3);background:var(--surface2);transition:all .2s}
#ic-root .m5c-tab-btn.active-a .m5c-tab-ico{background:#f59e0b;border-color:#f59e0b;color:#fff}
#ic-root .m5c-tab-btn.active-b .m5c-tab-ico{background:var(--teal);border-color:var(--teal);color:#fff}
#ic-root .m5c-tab-text{flex:1}
#ic-root .m5c-tab-name{font-family:Outfit,sans-serif;font-size:13px;font-weight:700;color:var(--navy);line-height:1.3;margin-bottom:2px}
#ic-root .m5c-tab-sub{font-size:11px;color:var(--text3)}
#ic-root .m5c-tab-btn.active-a .m5c-tab-name{color:#92400e}
#ic-root .m5c-tab-btn.active-b .m5c-tab-name{color:var(--teal2)}
#ic-root .m5c-tab-content{animation:m5cFadeIn .2s ease}
@keyframes m5cFadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
#ic-root .m5c-path{border:2px solid var(--border);border-radius:16px;overflow:hidden;margin-bottom:8px}
#ic-root .m5c-path-head{display:flex;align-items:center;gap:14px;padding:16px 20px}
#ic-root .m5c-path-head.a{background:linear-gradient(135deg,#fef3c7,#fffbeb);border-bottom:2px solid #fcd34d}
#ic-root .m5c-path-head.b{background:linear-gradient(135deg,#ecfeff,#e0f2fe);border-bottom:2px solid #67e8f9}
#ic-root .m5c-path-badge{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;font-size:20px;font-weight:700;flex-shrink:0}
#ic-root .m5c-path-badge.a{background:#f59e0b;color:#fff}
#ic-root .m5c-path-badge.b{background:var(--teal);color:#fff}
#ic-root .m5c-path-label{font-family:Outfit,sans-serif;font-size:15px;font-weight:700;line-height:1.3}
#ic-root .m5c-path-label.a{color:#92400e}
#ic-root .m5c-path-label.b{color:var(--teal2)}
#ic-root .m5c-path-body{padding:16px 18px;background:var(--surface)}
#ic-root .m5c-or{text-align:center;margin:16px 0;font-size:12px;font-weight:700;color:var(--text3);letter-spacing:.1em;font-family:Outfit,sans-serif;display:flex;align-items:center;gap:12px}
#ic-root .m5c-or::before,#ic-root .m5c-or::after{content:"";flex:1;height:2px;background:var(--border)}
#ic-root .m5-dose-main{font-family:'Outfit',sans-serif;font-size:22px;font-weight:700;margin-bottom:4px}
#ic-root .m5-dose-sub{font-size:12px;opacity:.8}
#ic-root .m5-dose-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:10px 0}
#ic-root .m5-dose-card{border-radius:10px;padding:14px;text-align:center}
#ic-root .m5-dose-blue{background:#eff6ff;border:1.5px solid #93c5fd}
#ic-root .m5-dose-green{background:#f0fdf4;border:2px solid #6ee7b7}
#ic-root .m5-dose-badge{font-size:9px;font-family:'JetBrains Mono',monospace;font-weight:700;text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:6px}
#ic-root .m5-dose-val{font-family:'Outfit',sans-serif;font-size:18px;font-weight:700;display:block}
#ic-root .m5-dose-note{font-size:11px;color:var(--text2);margin-top:4px;display:block}
#ic-root .m5-resp-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0}
#ic-root .m5-resp-card{border:2px solid var(--border);border-radius:12px;padding:14px;text-align:center}
#ic-root .m5-resp-ok{border-color:#6ee7b7;background:#f0fdf4}
#ic-root .m5-resp-fail{border-color:#fca5a5;background:#fef2f2}
#ic-root .m5-resp-pend{border-color:var(--border);background:var(--surface2)}
#ic-root .m5-resp-ico{font-size:22px;margin-bottom:4px}
#ic-root .m5-resp-lbl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3)}
#ic-root .m5-resp-val{font-family:'JetBrains Mono',monospace;font-size:16px;font-weight:700;margin:4px 0;color:var(--navy)}
#ic-root .m5-resp-thr{font-size:11px;color:var(--text3)}
#ic-root .m5-abox{border-radius:12px;padding:14px 16px;margin:10px 0;border:2px solid}
#ic-root .m5-abox-r{background:#fef2f2;border-color:#ef4444}
#ic-root .m5-abox-a{background:#fffbeb;border-color:#f59e0b}
#ic-root .m5-abox-b{background:#eff6ff;border-color:#3b82f6}
#ic-root .m5-abox-g{background:#f0fdf4;border-color:#10b981}
#ic-root .m5-abox-title{font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:7px}
#ic-root .m5-abox-body{font-size:12px;line-height:1.65}
#ic-root .m5-blist{list-style:none;padding:0;margin:6px 0 0;display:flex;flex-direction:column;gap:6px}
#ic-root .m5-blist li{display:block;position:relative;padding-left:22px;line-height:1.55;font-size:12px}
#ic-root .m5-blist li .bico{position:absolute;left:0;top:1px;font-size:13px}
#ic-root .m5-int-box{background:var(--surface2);border-left:3px solid var(--teal);border-radius:0 8px 8px 0;padding:10px 14px;margin:8px 0}
#ic-root .m5-int-title{font-size:11px;font-weight:700;color:var(--teal2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
#ic-root .m5-int-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:6px}
#ic-root .m5-int-list li{display:block;position:relative;padding-left:16px;font-size:12px;color:var(--text2);line-height:1.55}
#ic-root .m5-int-list li::before{content:'\2192';position:absolute;left:0;color:var(--teal);font-weight:700}
#ic-root .m5-esc-step{border-radius:12px;padding:14px 16px;margin:8px 0;border:2px solid}
#ic-root .m5-esc-l1{border-color:#fcd34d;background:#fffbeb}
#ic-root .m5-esc-l2{border-color:#fed7aa;background:#fff7ed}
#ic-root .m5-esc-l3{border-color:#bfdbfe;background:#eff6ff}
#ic-root .m5-esc-l4{border-color:#fca5a5;background:#fef2f2}
#ic-root .m5-esc-head{font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;margin-bottom:8px;display:flex;align-items:flex-start;gap:8px;flex-wrap:wrap}
#ic-root .m5-esc-dose{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;background:rgba(0,0,0,.08)}
#ic-root .m5-esc-notes{display:flex;flex-direction:column;gap:5px;margin-top:4px}
#ic-root .m5-esc-note{display:flex;gap:7px;font-size:12px;color:var(--text2);line-height:1.5}
#ic-root .m5-esc-warn{font-size:11px;color:#92400e;margin-top:6px;padding:6px 10px;background:rgba(0,0,0,.04);border-radius:6px;font-style:italic}
#ic-root .m5-chk-list{display:flex;flex-direction:column;gap:8px}
#ic-root .m5-chk-item{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface2)}
#ic-root .m5-chk-ico{font-size:16px;flex-shrink:0;margin-top:1px}
#ic-root .m5-chk-text{font-size:13px;color:var(--text);line-height:1.5}
#ic-root .m5-info-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:10px 12px;font-size:12px;color:#1e40af;margin:8px 0;line-height:1.55}
#ic-root .m5-sect-title{font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;color:var(--teal2);text-transform:uppercase;letter-spacing:.08em;margin:18px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}

/* ── EXPORTACIÓN DE RESULTADOS ──────────────────────── */
#ic-root .ic-action-row {
  display: flex;
  gap: 10px;
  margin: 4px 0 16px 0;
  width: 100%;
}
#ic-root button.ic-btn-export {
  flex: 1;
  display: block !important;
  width: 100% !important;
  background: #ffffff !important;
  border: 1.5px solid #cbd5e1 !important;
  border-radius: 10px !important;
  padding: 13px 16px !important;
  font-family: 'Source Sans 3', sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #475569 !important;
  cursor: pointer !important;
  transition: border-color .18s, color .18s, background .18s;
  text-align: center !important;
  letter-spacing: .01em;
  box-shadow: 0 1px 4px rgba(0,0,0,.08) !important;
  line-height: 1.4 !important;
  outline: none !important;
  text-decoration: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
#ic-root button#ic-btn-copy:hover {
  border-color: #0891b2 !important;
  color: #0e7490 !important;
  background: #f0f9ff !important;
}
#ic-root button#ic-btn-print:hover {
  border-color: #0d2d5e !important;
  color: #0d2d5e !important;
  background: #eff6ff !important;
}
@media (max-width: 420px) {
  #ic-root .ic-action-row { flex-direction: column; }
}

/* ═══════════════════════════════════════════════════════════════
 * MEJORAS TRANSVERSALES v4.4 — Cardioteca.com
 * Guía: Insuficiencia Cardíaca Suite · Prefijo: ic · 2026-06-01
 * ═══════════════════════════════════════════════════════════════ */

/* ── MJ-01 · ANIMACIÓN FADE ──────────────────────────────────── */
@keyframes icFadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
#ic-root #ic-app.ic-anim {
  animation: icFadeIn 180ms ease forwards;
}

/* ── MJ-02 · MODO OSCURO — BOTÓN (v4.4 DEFINITIVO) ──────────── */
/* Botón en fragmento-joomla.html como HERMANO de .app-header     */
/* #ic-root tiene position:relative para anclarlo                  */
#ic-root { position: relative; }
#ic-root .dark-toggle {
  position: absolute; top: 14px; right: 14px;
  width: 34px; height: 34px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; cursor: pointer; z-index: 2;
  background: rgba(13,45,94,.10);
  border: 1.5px solid rgba(13,45,94,.28);
  color: #0d2d5e;
  box-shadow: 0 1px 4px rgba(13,45,94,.12);
  transition: background .2s, transform .15s;
  -webkit-tap-highlight-color: transparent;
}
#ic-root .dark-toggle:hover {
  background: rgba(13,45,94,.18); transform: scale(1.08);
}
#ic-root.dk .dark-toggle {
  background: rgba(255,255,255,.15);
  border-color: rgba(255,255,255,.40);
  color: #fff;
}
#ic-root.dk .dark-toggle:hover { background: rgba(255,255,255,.28); }

/* ── MJ-02 · MODO OSCURO — VARIABLES ────────────────────────── */
#ic-root.dk {
  --bg:#0f172a; --surface:#1e293b; --surface2:#162032;
  --border:#334155; --border-focus:#38bdf8;
  --navy:#7dd3fc; --navy2:#38bdf8;
  --teal:#22d3ee; --teal2:#06b6d4;
  --green:#34d399; --amber:#fbbf24; --red:#f87171;
  --text:#f1f5f9; --text2:#94a3b8; --text3:#64748b;
  --shadow:0 1px 3px rgba(0,0,0,.4),0 4px 16px rgba(0,0,0,.3);
}
#ic-root.dk .app-header {
  background: linear-gradient(135deg,#0c1a3d 0%,#1e293b 100%);
}
#ic-root.dk .ic-wrap,
#ic-root.dk #app-wrapper { background: var(--bg); }
#ic-root.dk .card,
#ic-root.dk .hub-card,
#ic-root.dk .res-card { background: var(--surface); border-color: var(--border); }
#ic-root.dk input, #ic-root.dk select, #ic-root.dk textarea {
  background: var(--surface2); color: var(--text); border-color: var(--border);
}
#ic-root.dk .ev-badge.classI    { background:#052e16; color:#86efac; border-color:#166534; }
#ic-root.dk .ev-badge.classIIa  { background:#0c1a3d; color:#93c5fd; border-color:#1d4ed8; }
#ic-root.dk .ev-badge.classIIb  { background:#271a00; color:#fcd34d; border-color:#92400e; }
#ic-root.dk .ev-badge.classIII  { background:#2d0a0a; color:#fca5a5; border-color:#991b1b; }
#ic-root.dk .ev-badge.loe       { background:#1e293b; color:var(--text2); border-color:var(--border); }
#ic-root.dk .disclaimer         { background:#271a00; border-color:#92400e; }
#ic-root.dk .disclaimer-text    { color:#fbbf24; }
#ic-root.dk .disclaimer-text strong { color:#fbbf24; }
#ic-root.dk [style*="background:#f0fdf4"] { background:#052e16 !important; }
#ic-root.dk [style*="background:#eff6ff"] { background:#0c1a3d !important; }
#ic-root.dk [style*="background:#fef2f2"] { background:#2d0a0a !important; }
#ic-root.dk [style*="background:#fffbeb"] { background:#271a00 !important; }
#ic-root.dk [style*="background:#f8fafc"] { background:var(--surface2) !important; }
#ic-root.dk [style*="background:#fff"]    { background:var(--surface) !important; }
#ic-root.dk .ic-prog-bar .prog-circle       { background:var(--surface2); border-color:var(--border); color:var(--text2); }
#ic-root.dk .ic-prog-bar .prog-circle.done  { background:var(--teal); border-color:var(--teal); color:#fff; }
#ic-root.dk .ic-prog-bar .prog-circle.active{ background:var(--navy); border-color:var(--navy); color:#fff; }
#ic-root.dk .sym-item, #ic-root.dk .sign-item { background:var(--surface2); border-color:var(--border); color:var(--text); }
#ic-root.dk .sym-item.selected, #ic-root.dk .sign-item.selected { background:#0c1a3d; border-color:var(--navy); color:var(--navy); }
#ic-root.dk .btn-restart, #ic-root.dk .btn-back,
#ic-root.dk .btn-next,    #ic-root.dk .btn-analyze,
#ic-root.dk .btn-module,  #ic-root.dk .hub-btn { filter: brightness(0.85); }
#ic-root.dk .ic-btn-export {
  background: var(--surface2) !important;
  border-color: var(--border) !important;
  color: var(--text2) !important;
}
#ic-root.dk .ic-btn-save {
  filter: brightness(0.85);
}

/* ── MJ-04 · TIMELINE VISUAL DE SEGUIMIENTO ─────────────────── */
#ic-root .followup-timeline { margin-bottom: 16px; padding-top: 8px; }
#ic-root .ft-label {
  font-size: 11px; font-weight: 700; color: var(--text3);
  text-transform: uppercase; letter-spacing: .08em;
  font-family: 'Outfit', sans-serif; margin-bottom: 10px;
}
#ic-root .ft-track {
  display: flex; align-items: flex-start;
  padding: 4px 4px 0; overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
#ic-root .ft-step {
  flex: 1; min-width: 72px; flex-shrink: 0;
  display: flex; flex-direction: column;
  align-items: center; position: relative;
}
#ic-root .ft-step:not(:last-child)::after {
  content: ''; position: absolute; top: 10px; left: 50%;
  width: 100%; height: 2px; background: var(--border); z-index: 0;
}
#ic-root .ft-dot {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--teal); border: 3px solid var(--bg);
  box-shadow: 0 0 0 2px var(--teal);
  z-index: 1; position: relative; flex-shrink: 0;
}
#ic-root .ft-step:first-child .ft-dot {
  background: var(--navy); box-shadow: 0 0 0 2px var(--navy);
}
#ic-root .ft-step-content { text-align: center; margin-top: 6px; padding: 0 2px; }
#ic-root .ft-time {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  font-weight: 700; color: var(--teal);
}
#ic-root .ft-step:first-child .ft-time { color: var(--navy); }
#ic-root .ft-action {
  font-size: 11px; color: var(--text2); line-height: 1.3; margin-top: 2px;
}

/* ── MJ-11 · GUARDAR CASOS ───────────────────────────────────── */
#ic-root .ic-btn-save {
  display: block; width: 100%; padding: 13px 16px;
  background: linear-gradient(135deg, var(--teal2), var(--navy));
  color: #fff; border: none; border-radius: 10px;
  font-family: 'Outfit', sans-serif; font-size: 15px; font-weight: 700;
  cursor: pointer; margin-top: 10px; margin-bottom: 6px;
  letter-spacing: .02em; transition: opacity .2s, transform .15s;
  box-shadow: 0 2px 8px rgba(8,145,178,.25); text-align: center;
  -webkit-tap-highlight-color: transparent;
}
#ic-root .ic-btn-save:hover { opacity: .92; transform: translateY(-1px); }
#ic-root input#ic-case-name {
  width: 100%; padding: 9px 12px;
  border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 14px; color: var(--text); background: var(--surface);
  margin-bottom: 10px; box-sizing: border-box;
  font-family: 'Source Sans 3', sans-serif;
}
#ic-root input#ic-case-name:focus { outline: none; border-color: var(--teal); }
#ic-root .cases-panel-scroll {
  max-height: 210px; overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: var(--border) transparent;
}
#ic-root .cases-panel-scroll::-webkit-scrollbar { width: 4px; }
#ic-root .cases-panel-scroll::-webkit-scrollbar-thumb {
  background: var(--border); border-radius: 2px;
}
