/* ===== KitSalva CSS — Premium Mobile-First ===== */

/* ---- TOKENS ---- */
:root {
  --navy:       #0B2545;
  --navy-mid:   #1B3D6B;
  --blue:       #1B6CA8;
  --blue-light: #2E86C1;
  --green:      #1A7A4A;
  --green-light:#27AE60;
  --green-pale: #E8F8F0;
  --orange:     #E8530A;
  --orange-mid: #F0792A;
  --orange-pale:#FEF0E8;
  --teal:       #0E7490;
  --teal-pale:  #E0F7FA;
  --red:        #C0392B;
  --red-pale:   #FDEDEC;
  --yellow:     #D4AC0D;
  --yellow-pale:#FEFDE7;

  --bg:         #F4F7FB;
  --surface:    #FFFFFF;
  --surface2:   #EDF2F8;
  --border:     #D5E1EE;
  --text:       #0B2545;
  --text-mid:   #3A5272;
  --text-muted: #7A95B5;

  --radius-sm:  8px;
  --radius:     14px;
  --radius-lg:  20px;
  --radius-xl:  28px;

  --shadow-sm:  0 1px 4px rgba(11,37,69,.07);
  --shadow:     0 4px 16px rgba(11,37,69,.10);
  --shadow-lg:  0 8px 32px rgba(11,37,69,.14);

  --topbar-h:   60px;
  --bnav-h:     68px;
  --sidebar-w:  280px;

  --transition: .2s cubic-bezier(.4,0,.2,1);
  --spring:     .35s cubic-bezier(.34,1.56,.64,1);
}

[data-theme="dark"] {
  --bg:        #060F1C;
  --surface:   #0E1E33;
  --surface2:  #152540;
  --border:    #1E3557;
  --text:      #E8F0FC;
  --text-mid:  #9BB8D4;
  --text-muted:#4D6B8A;
  --shadow-sm: 0 1px 4px rgba(0,0,0,.3);
  --shadow:    0 4px 16px rgba(0,0,0,.35);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.45);
}

/* ---- RESET ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{
  font-family:'DM Sans',sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100dvh;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4,h5{font-family:'Sora',sans-serif;line-height:1.2}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit;font-size:1rem}
img{max-width:100%;height:auto}

/* ---- SPLASH ---- */
.splash{
  position:fixed;inset:0;
  background:var(--navy);
  display:flex;align-items:center;justify-content:center;
  z-index:9999;
  transition:opacity .6s ease, transform .6s ease;
}
.splash.fade-out{opacity:0;transform:scale(1.04);pointer-events:none}
.splash-inner{
  display:flex;flex-direction:column;align-items:center;gap:24px;
  padding:32px;text-align:center;
}
.splash-logo{display:flex;align-items:center;gap:16px}
.splash-icon svg{width:64px;height:64px;filter:drop-shadow(0 4px 16px rgba(27,108,168,.5))}
.splash-name{
  display:block;font-family:'Sora',sans-serif;font-size:2rem;font-weight:800;
  color:#fff;letter-spacing:-.02em;
}
.splash-tagline{display:block;font-size:.85rem;color:#7AACCE;margin-top:2px}
.splash-loader{width:200px;height:3px;background:rgba(255,255,255,.15);border-radius:99px;overflow:hidden}
.splash-bar{
  height:100%;background:linear-gradient(90deg,#1B6CA8,#27AE60);
  border-radius:99px;animation:splashLoad 1.8s ease forwards;
}
@keyframes splashLoad{from{width:0}to{width:100%}}
.splash-subtitle{color:#7AACCE;font-size:.9rem}

/* ---- LAYOUT ---- */
.hidden{display:none!important}
.app{min-height:100dvh;display:flex;flex-direction:column}

/* ---- TOP BAR ---- */
.topbar{
  position:fixed;top:0;left:0;right:0;
  height:var(--topbar-h);
  background:var(--surface);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;
  z-index:100;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:8px}
.menu-btn{
  display:flex;flex-direction:column;gap:5px;padding:8px;
  border-radius:var(--radius-sm);
}
.menu-btn span{
  display:block;width:22px;height:2px;
  background:var(--text);border-radius:2px;
  transition:var(--transition);
}
.menu-btn.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-btn.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.menu-btn.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.topbar-brand{display:flex;align-items:center;gap:8px;font-family:'Sora',sans-serif;font-weight:700;font-size:1.1rem;color:var(--navy)}
[data-theme="dark"] .topbar-brand{color:var(--text)}
.brand-icon svg{width:28px;height:28px}
.icon-btn{
  width:38px;height:38px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  background:var(--surface2);
  position:relative;
  transition:var(--transition);
  color:var(--text-mid);
}
.icon-btn:hover{background:var(--border)}
.icon-btn svg{width:18px;height:18px}
.badge{
  position:absolute;top:-4px;right:-4px;
  min-width:18px;height:18px;padding:0 4px;
  background:var(--orange);color:#fff;
  font-size:.7rem;font-weight:700;
  border-radius:99px;display:flex;align-items:center;justify-content:center;
  border:2px solid var(--surface);
}
.badge:empty,.badge[data-count="0"]{display:none}

/* ---- SIDEBAR ---- */
.sidebar{
  position:fixed;top:0;left:0;bottom:0;
  width:var(--sidebar-w);
  background:var(--surface);
  border-right:1px solid var(--border);
  transform:translateX(-100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  z-index:200;
  display:flex;flex-direction:column;
  overflow-y:auto;
  padding-top:var(--topbar-h);
}
.sidebar.open{transform:translateX(0)}
.sidebar-overlay{
  position:fixed;inset:0;background:rgba(11,37,69,.4);
  backdrop-filter:blur(4px);
  opacity:0;pointer-events:none;
  transition:opacity .3s ease;
  z-index:199;
}
.sidebar-overlay.show{opacity:1;pointer-events:all}
.sidebar-header{padding:20px 16px 12px}
.sidebar-profile{display:flex;align-items:center;gap:12px}
.profile-avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--green-light));
  display:flex;align-items:center;justify-content:center;
  font-family:'Sora',sans-serif;font-weight:700;font-size:1.1rem;color:#fff;
  flex-shrink:0;
}
.profile-name{display:block;font-weight:600;font-size:.95rem}
.profile-members{display:block;font-size:.8rem;color:var(--text-muted)}
.nav-list{list-style:none;padding:0 8px;flex:1}
.nav-list li{margin:2px 0}
.nav-divider{height:1px;background:var(--border);margin:8px 8px}
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 12px;border-radius:var(--radius-sm);
  font-size:.9rem;font-weight:500;color:var(--text-mid);
  transition:var(--transition);
}
.nav-item svg{width:18px;height:18px;flex-shrink:0}
.nav-item:hover{background:var(--surface2);color:var(--text)}
.nav-item.active{background:rgba(27,108,168,.12);color:var(--blue);font-weight:600}
.nav-item.nav-highlight{color:var(--orange)}
.nav-item.nav-highlight:hover,.nav-item.nav-highlight.active{background:var(--orange-pale)}
.sidebar-footer{padding:16px;margin-top:auto}
.legal-notice{
  font-size:.75rem;color:var(--text-muted);
  background:var(--surface2);border-radius:var(--radius-sm);
  padding:10px;line-height:1.4;
}

/* ---- MAIN CONTENT ---- */
.main-content{
  margin-top:var(--topbar-h);
  padding:20px 16px calc(var(--bnav-h) + 20px);
  min-height:calc(100dvh - var(--topbar-h));
  max-width:700px;margin-left:auto;margin-right:auto;
  width:100%;
}

/* ---- SECTIONS ---- */
.section{display:none;animation:sectionIn .3s ease}
.section.active{display:block}
@keyframes sectionIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.section-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:20px;
}
.section-header h1{font-size:1.5rem;font-weight:800;color:var(--text)}
.section-subtitle{font-size:.85rem;color:var(--text-muted);margin-top:2px}

/* ---- BUTTONS ---- */
.btn-primary{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 18px;border-radius:var(--radius-sm);
  background:var(--blue);color:#fff;
  font-weight:600;font-size:.88rem;
  transition:var(--transition);
  white-space:nowrap;
}
.btn-primary:hover{background:var(--navy-mid);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-primary:active{transform:translateY(0)}
.btn-primary svg{width:16px;height:16px}
.btn-ghost{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 18px;border-radius:var(--radius-sm);
  background:var(--surface2);color:var(--text-mid);
  font-weight:600;font-size:.88rem;
  border:1px solid var(--border);
  transition:var(--transition);
}
.btn-ghost:hover{background:var(--border)}
.btn-danger{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:var(--radius-sm);
  background:var(--red-pale);color:var(--red);
  font-weight:600;font-size:.82rem;
  transition:var(--transition);
}
.btn-danger:hover{background:var(--red);color:#fff}

/* ---- DASHBOARD ---- */
.prep-score-card{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);
  border-radius:var(--radius-lg);
  padding:24px;
  display:flex;align-items:center;gap:24px;
  margin-bottom:20px;
  box-shadow:var(--shadow-lg);
  overflow:hidden;
  position:relative;
}
.prep-score-card::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:160px;height:160px;border-radius:50%;
  background:rgba(255,255,255,.04);
}
.prep-score-visual{position:relative;flex-shrink:0}
.score-ring{width:100px;height:100px}
.ring-bg{stroke:rgba(255,255,255,.1)}
.ring-fill{stroke:var(--green-light);transition:stroke-dashoffset 1.2s cubic-bezier(.4,0,.2,1)}
.score-center{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
}
.score-number{font-family:'Sora',sans-serif;font-size:1.6rem;font-weight:800;color:#fff}
.score-pct{font-size:.75rem;color:rgba(255,255,255,.6);margin-top:-4px}
.prep-score-info{flex:1}
.prep-level{font-family:'Sora',sans-serif;font-size:1.15rem;font-weight:700;color:#fff;margin-bottom:6px}
.prep-desc{font-size:.8rem;color:rgba(255,255,255,.65);line-height:1.4;margin-bottom:12px}
.traffic-light{display:flex;gap:8px;align-items:center}
.tl-dot{
  width:14px;height:14px;border-radius:50%;
  background:rgba(255,255,255,.15);
  transition:var(--transition);
}
.tl-dot.red.active{background:#e74c3c;box-shadow:0 0 8px #e74c3c}
.tl-dot.yellow.active{background:#f1c40f;box-shadow:0 0 8px #f1c40f}
.tl-dot.green.active{background:#27AE60;box-shadow:0 0 8px #27AE60}

.stats-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:12px;
  margin-bottom:20px;
}
.stat-card{
  background:var(--surface);border-radius:var(--radius);
  padding:16px;display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow-sm);border:1px solid var(--border);
  cursor:pointer;transition:var(--transition);
}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.stat-icon{
  width:40px;height:40px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.stat-icon svg{width:20px;height:20px}
.stat-icon.blue{background:rgba(27,108,168,.12);color:var(--blue)}
.stat-icon.green{background:var(--green-pale);color:var(--green)}
.stat-icon.orange{background:var(--orange-pale);color:var(--orange)}
.stat-icon.teal{background:var(--teal-pale);color:var(--teal)}
.stat-value{display:block;font-family:'Sora',sans-serif;font-size:1.3rem;font-weight:700}
.stat-label{display:block;font-size:.75rem;color:var(--text-muted)}

.pending-section{margin-bottom:20px}
.pending-title{font-size:.95rem;font-weight:700;margin-bottom:12px;color:var(--text)}
.pending-list{display:flex;flex-direction:column;gap:8px}
.pending-item{
  display:flex;align-items:center;gap:10px;
  background:var(--surface);border-radius:var(--radius-sm);
  padding:12px;border:1px solid var(--border);
  font-size:.85rem;color:var(--text-mid);
}
.pending-item.empty{justify-content:center;opacity:.6}
.pending-item svg{width:16px;height:16px;flex-shrink:0;color:var(--orange)}
.pending-item.empty svg{color:var(--text-muted)}
.pending-item.done{opacity:.5;text-decoration:line-through}

.risk-banner{
  background:linear-gradient(135deg,rgba(27,108,168,.08),rgba(27,174,96,.06));
  border:1px solid rgba(27,108,168,.2);
  border-radius:var(--radius);
  padding:16px;display:flex;gap:12px;align-items:flex-start;
  margin-bottom:16px;
}
.risk-icon{font-size:1.5rem;flex-shrink:0}
.risk-info strong{display:block;font-size:.9rem;margin-bottom:4px;color:var(--navy)}
[data-theme="dark"] .risk-info strong{color:var(--blue-light)}
.risk-info p{font-size:.8rem;color:var(--text-muted);line-height:1.4}

.legal-bar{
  background:var(--green-pale);border:1px solid rgba(26,122,74,.2);
  border-radius:var(--radius-sm);padding:12px;
  display:flex;gap:8px;align-items:flex-start;
}
[data-theme="dark"] .legal-bar{background:rgba(26,122,74,.1)}
.legal-bar svg{width:16px;height:16px;color:var(--green);flex-shrink:0;margin-top:2px}
.legal-bar p{font-size:.78rem;color:var(--green);line-height:1.4}

/* ---- FAMILIA ---- */
.family-name-input{
  background:var(--surface);border-radius:var(--radius);
  padding:16px;border:1px solid var(--border);
  margin-bottom:20px;
}
.family-name-input label{display:block;font-size:.82rem;font-weight:600;color:var(--text-muted);margin-bottom:6px}
.family-name-input input{
  width:100%;border:none;background:transparent;font-size:1.1rem;
  font-weight:600;font-family:'Sora',sans-serif;color:var(--text);
  outline:none;
}
.members-list{display:flex;flex-direction:column;gap:12px}
.member-card{
  background:var(--surface);border-radius:var(--radius);
  border:1px solid var(--border);
  overflow:hidden;box-shadow:var(--shadow-sm);
  transition:var(--transition);
}
.member-card:hover{box-shadow:var(--shadow)}
.member-card-header{
  display:flex;align-items:center;gap:12px;padding:16px;
  cursor:pointer;
}
.member-avatar{
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;color:#fff;
  flex-shrink:0;
}
.member-avatar.adult{background:linear-gradient(135deg,#1B6CA8,#2E86C1)}
.member-avatar.child{background:linear-gradient(135deg,#27AE60,#58D68D)}
.member-avatar.senior{background:linear-gradient(135deg,#E8530A,#F0792A)}
.member-name{font-weight:700;font-size:.95rem}
.member-meta{font-size:.78rem;color:var(--text-muted)}
.member-blood{
  margin-left:auto;background:var(--red-pale);color:var(--red);
  padding:3px 8px;border-radius:99px;font-size:.75rem;font-weight:700;
}
.member-card-body{
  display:none;border-top:1px solid var(--border);padding:16px;
  background:var(--surface2);
}
.member-card-body.open{display:block}
.member-detail-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px;
}
.member-detail{font-size:.82rem}
.member-detail-label{color:var(--text-muted);display:block;margin-bottom:2px}
.member-detail-value{font-weight:600;color:var(--text)}
.member-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}

/* ---- MEDICAMENTOS ---- */
.meds-filter{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.filter-chip{
  padding:6px 14px;border-radius:99px;font-size:.82rem;font-weight:600;
  background:var(--surface);border:1px solid var(--border);
  color:var(--text-muted);transition:var(--transition);
}
.filter-chip:hover{border-color:var(--blue);color:var(--blue)}
.filter-chip.active{background:var(--blue);border-color:var(--blue);color:#fff}
.meds-list{display:flex;flex-direction:column;gap:12px}
.med-card{
  background:var(--surface);border-radius:var(--radius);
  border:1px solid var(--border);padding:16px;
  box-shadow:var(--shadow-sm);
  display:flex;gap:12px;align-items:flex-start;
  transition:var(--transition);
  position:relative;overflow:hidden;
}
.med-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:4px;
  background:var(--green);
}
.med-card.warn::before{background:var(--yellow)}
.med-card.danger::before{background:var(--orange)}
.med-card.expired::before{background:var(--red)}
.med-icon{
  width:40px;height:40px;border-radius:var(--radius-sm);flex-shrink:0;
  background:var(--green-pale);color:var(--green);
  display:flex;align-items:center;justify-content:center;font-size:1.2rem;
}
.med-icon.warn{background:var(--yellow-pale);color:var(--yellow)}
.med-icon.danger{background:var(--orange-pale);color:var(--orange)}
.med-icon.expired{background:var(--red-pale);color:var(--red)}
.med-info{flex:1;min-width:0}
.med-name{font-weight:700;font-size:.95rem;margin-bottom:4px}
.med-sub{font-size:.78rem;color:var(--text-muted);margin-bottom:8px}
.med-tags{display:flex;gap:6px;flex-wrap:wrap}
.med-tag{
  padding:2px 8px;border-radius:99px;font-size:.72rem;font-weight:600;
  background:var(--surface2);color:var(--text-mid);border:1px solid var(--border);
}
.med-tag.green{background:var(--green-pale);color:var(--green);border-color:transparent}
.med-tag.orange{background:var(--orange-pale);color:var(--orange);border-color:transparent}
.med-tag.red{background:var(--red-pale);color:var(--red);border-color:transparent}
.med-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}
.icon-action{
  width:32px;height:32px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  transition:var(--transition);color:var(--text-muted);
  background:var(--surface2);
}
.icon-action:hover{background:var(--red-pale);color:var(--red)}
.icon-action svg{width:14px;height:14px}

/* ---- ALERGIAS ---- */
.alergia-tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.alergia-tab{
  padding:8px 14px;border-radius:99px;font-size:.82rem;font-weight:600;
  background:var(--surface);border:1px solid var(--border);
  color:var(--text-muted);transition:var(--transition);
}
.alergia-tab.active{background:var(--orange);border-color:var(--orange);color:#fff}
.alergias-list{display:flex;flex-direction:column;gap:10px}
.alergia-card{
  background:var(--surface);border-radius:var(--radius);
  border:1px solid var(--border);padding:14px;
  display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow-sm);
}
.alergia-sev{
  padding:3px 10px;border-radius:99px;font-size:.72rem;font-weight:700;
  margin-left:auto;flex-shrink:0;
}
.sev-leve{background:var(--yellow-pale);color:var(--yellow)}
.sev-moderada{background:var(--orange-pale);color:var(--orange)}
.sev-severa{background:var(--red-pale);color:var(--red)}

/* ---- CRÓNICAS ---- */
.cronicas-grid{display:flex;flex-direction:column;gap:12px}
.cronica-card{
  background:var(--surface);border-radius:var(--radius);
  border:1px solid var(--border);padding:16px;
  box-shadow:var(--shadow-sm);
  display:flex;align-items:center;gap:14px;
}
.cronica-icon{font-size:1.6rem;flex-shrink:0}
.cronica-info{flex:1}
.cronica-name{font-weight:700;font-size:.95rem;margin-bottom:2px}
.cronica-detail{font-size:.8rem;color:var(--text-muted)}
.cronica-reserva{
  background:var(--blue);color:#fff;
  padding:4px 10px;border-radius:99px;font-size:.75rem;font-weight:700;
  flex-shrink:0;
}

/* ---- CHECKLIST ---- */
.checklist-progress{
  background:var(--surface);border-radius:var(--radius);
  border:1px solid var(--border);padding:16px;
  margin-bottom:20px;
}
.progress-bar-wrap{
  height:8px;background:var(--surface2);border-radius:99px;
  overflow:hidden;margin-bottom:8px;
}
.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--green-light));border-radius:99px;transition:width .6s ease}
.progress-label{font-size:.82rem;color:var(--text-muted);font-weight:600}
.checklist-categories{display:flex;flex-direction:column;gap:16px}
.checklist-cat{
  background:var(--surface);border-radius:var(--radius);
  border:1px solid var(--border);overflow:hidden;
}
.checklist-cat-header{
  display:flex;align-items:center;gap:10px;padding:14px;
  cursor:pointer;transition:var(--transition);
}
.checklist-cat-header:hover{background:var(--surface2)}
.checklist-cat-emoji{font-size:1.3rem}
.checklist-cat-name{font-weight:700;font-size:.9rem}
.checklist-cat-count{margin-left:auto;font-size:.78rem;color:var(--text-muted)}
.checklist-cat-arrow{width:16px;height:16px;color:var(--text-muted);transition:transform .2s}
.checklist-cat-body{display:none;border-top:1px solid var(--border)}
.checklist-cat-body.open{display:block}
.checklist-item{
  display:flex;align-items:center;gap:12px;padding:12px 14px;
  border-bottom:1px solid var(--border);transition:var(--transition);
}
.checklist-item:last-child{border-bottom:none}
.checklist-item:hover{background:var(--surface2)}
.checklist-item input[type=checkbox]{
  width:18px;height:18px;accent-color:var(--blue);cursor:pointer;flex-shrink:0;
}
.checklist-item label{flex:1;font-size:.85rem;cursor:pointer}
.checklist-item.checked label{text-decoration:line-through;color:var(--text-muted)}

/* ---- ALERTAS ---- */
.alerts-list{display:flex;flex-direction:column;gap:10px}
.alert-item{
  background:var(--surface);border-radius:var(--radius);
  border:1px solid var(--border);padding:14px;
  display:flex;gap:12px;align-items:flex-start;
  box-shadow:var(--shadow-sm);
  border-left:4px solid transparent;
}
.alert-item.critical{border-left-color:var(--red)}
.alert-item.warning{border-left-color:var(--orange)}
.alert-item.info{border-left-color:var(--blue)}
.alert-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:6px}
.alert-item.critical .alert-dot{background:var(--red)}
.alert-item.warning .alert-dot{background:var(--orange)}
.alert-item.info .alert-dot{background:var(--blue)}
.alert-title{font-weight:700;font-size:.88rem;margin-bottom:3px}
.alert-desc{font-size:.8rem;color:var(--text-muted)}

/* ---- TARJETA EMERGENCIA ---- */
.emergency-card-preview{
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-lg);
  border:1px solid var(--border);
}
.card-print{
  background:#fff;padding:24px;
  font-family:'DM Sans',sans-serif;color:#0B2545;
}
[data-theme="dark"] .card-print{background:#fff;color:#0B2545}
.card-header-print{
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:3px solid #1B6CA8;padding-bottom:14px;margin-bottom:14px;
  flex-wrap:wrap;gap:12px;
}
.card-logo-area{display:flex;align-items:center;gap:10px}
.card-logo-area h2{font-family:'Sora',sans-serif;font-size:1.1rem;font-weight:800;color:#0B2545;margin-bottom:2px}
.card-logo-area p{font-size:.75rem;color:#7A95B5}
.card-date{font-size:.75rem;color:#7A95B5}
.card-body-print{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
@media(max-width:480px){.card-body-print{grid-template-columns:1fr}}
.card-section-print{background:#F4F7FB;border-radius:8px;padding:12px}
.card-section-print h3{font-size:.8rem;font-weight:700;color:#1B6CA8;margin-bottom:6px}
.card-section-print div{font-size:.8rem;color:#3A5272;line-height:1.6}
.card-footer-print{
  background:#0B2545;border-radius:8px;padding:12px;
  text-align:center;
}
.card-footer-print p{color:#7AACCE;font-size:.75rem;line-height:1.6}
.card-legal{color:rgba(122,172,206,.6)!important;font-size:.68rem!important}

/* ---- REPORTE ---- */
.report-preview{
  background:var(--surface);border-radius:var(--radius-lg);
  border:1px solid var(--border);padding:24px;
  box-shadow:var(--shadow);
}
.report-section{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.report-section:last-child{border-bottom:none;margin-bottom:0}
.report-section h2{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:12px;display:flex;gap:8px;align-items:center}
.report-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.report-stat{text-align:center;background:var(--surface2);border-radius:var(--radius-sm);padding:12px}
.report-stat-val{font-family:'Sora',sans-serif;font-size:1.4rem;font-weight:800;color:var(--blue)}
.report-stat-label{font-size:.72rem;color:var(--text-muted);margin-top:2px}
.report-list{list-style:none;display:flex;flex-direction:column;gap:6px}
.report-list li{font-size:.85rem;color:var(--text-mid);padding-left:12px;position:relative}
.report-list li::before{content:'•';position:absolute;left:0;color:var(--blue)}
.report-rec{
  background:var(--green-pale);border:1px solid rgba(26,122,74,.15);
  border-radius:var(--radius-sm);padding:10px 12px;
  font-size:.82rem;color:var(--green);line-height:1.5;
}
[data-theme="dark"] .report-rec{background:rgba(26,122,74,.1)}

/* ---- FORMS ---- */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:.82rem;font-weight:600;color:var(--text-muted);margin-bottom:5px}
.form-group input,
.form-group select,
.form-group textarea{
  width:100%;padding:10px 12px;
  border:1.5px solid var(--border);border-radius:var(--radius-sm);
  background:var(--surface);color:var(--text);
  font-size:.9rem;font-family:inherit;
  transition:border-color var(--transition);
  -webkit-appearance:none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  outline:none;border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(27,108,168,.12);
}
.form-group textarea{resize:vertical;min-height:72px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ---- MODALS ---- */
.modal-overlay{
  position:fixed;inset:0;background:rgba(11,37,69,.5);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  z-index:500;
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .25s ease;
}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{
  background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;
  width:100%;max-width:600px;max-height:90dvh;
  overflow-y:auto;
  transform:translateY(20px);
  transition:transform .3s var(--spring);
}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 20px 16px;
  position:sticky;top:0;background:var(--surface);
  border-bottom:1px solid var(--border);z-index:1;
}
.modal-header h2{font-size:1.1rem;font-weight:700}
.modal-close{
  width:32px;height:32px;border-radius:50%;
  background:var(--surface2);color:var(--text-mid);
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;transition:var(--transition);
}
.modal-close:hover{background:var(--red-pale);color:var(--red)}
.modal-body{padding:20px}
.modal-footer{
  display:flex;gap:10px;justify-content:flex-end;
  padding:16px 20px;border-top:1px solid var(--border);
  position:sticky;bottom:0;background:var(--surface);
}

/* ---- EMPTY STATE ---- */
.empty-state{
  text-align:center;padding:40px 20px;
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.empty-icon{font-size:2.8rem}
.empty-state h3{font-size:1rem;font-weight:700}
.empty-state p{font-size:.85rem;color:var(--text-muted)}

/* ---- BOTTOM NAV ---- */
.bottom-nav{
  position:fixed;bottom:0;left:0;right:0;
  height:var(--bnav-h);
  background:var(--surface);
  border-top:1px solid var(--border);
  display:grid;grid-template-columns:repeat(5,1fr);
  z-index:100;
  backdrop-filter:blur(12px);
  padding-bottom:env(safe-area-inset-bottom);
}
.bnav-item{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;font-size:.65rem;font-weight:600;color:var(--text-muted);
  transition:var(--transition);padding:8px 4px;
}
.bnav-item svg{width:22px;height:22px;transition:var(--transition)}
.bnav-item.active{color:var(--blue)}
.bnav-item.active svg{transform:scale(1.1)}
.bnav-item:hover{color:var(--blue)}

/* ---- TOAST ---- */
.toast{
  position:fixed;bottom:calc(var(--bnav-h) + 12px);left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--navy);color:#fff;
  padding:10px 18px;border-radius:99px;font-size:.85rem;font-weight:600;
  box-shadow:var(--shadow-lg);white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:opacity .2s,transform .3s var(--spring);
  z-index:600;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---- RESPONSIVE DESKTOP ---- */
@media(min-width:768px){
  .main-content{padding:24px 32px calc(var(--bnav-h) + 24px)}
  .sidebar{transform:translateX(0)}
  .sidebar-overlay{display:none!important}
  .menu-btn{display:none}
  .main-content{margin-left:var(--sidebar-w)}
  .topbar{padding-left:calc(var(--sidebar-w) + 16px)}
  .prep-score-card{padding:28px}
  .score-ring{width:120px;height:120px}
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .bottom-nav{display:none}
  .main-content{padding-bottom:32px}
  .modal-overlay{align-items:center}
  .modal{border-radius:var(--radius-xl);max-height:85dvh}
}
@media(min-width:1024px){.main-content{max-width:900px;padding:28px 40px}}

/* ---- PRINT ---- */
@media print{
  body{background:#fff}
  .topbar,.sidebar,.bottom-nav,.btn-primary,.btn-ghost,
  .section-header button,.modal-overlay{display:none!important}
  .main-content{margin:0;padding:0;max-width:none}
  .section{display:none!important}
  #section-tarjeta{display:block!important}
  .emergency-card-preview{box-shadow:none;border:1px solid #ccc}
}

/* ---- SCROLLBAR ---- */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}

/* ===== ADDITIONS v2 ===== */

/* SOS Banner on dashboard */
.sos-banner{
  background:linear-gradient(135deg,#C0392B,#E74C3C);
  border-radius:var(--radius);padding:16px;
  display:flex;align-items:center;gap:12px;
  margin-bottom:16px;cursor:pointer;
  box-shadow:0 4px 16px rgba(192,57,43,.3);
  transition:var(--transition);
}
.sos-banner:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(192,57,43,.4)}
.sos-banner-icon{font-size:1.8rem;flex-shrink:0}
.sos-banner-info{flex:1}
.sos-banner-info strong{color:#fff;display:block;font-size:.95rem;margin-bottom:2px}
.sos-banner-info p{color:rgba(255,255,255,.8);font-size:.8rem}
.sos-banner-arrow{color:rgba(255,255,255,.7);font-size:1.5rem;font-weight:300}

/* Nav SOS */
.nav-item.nav-sos{color:var(--red)!important;font-weight:700}
.nav-item.nav-sos:hover,.nav-item.nav-sos.active{background:var(--red-pale)!important;color:var(--red)!important}
.bnav-sos{color:var(--red)!important}
.bnav-sos.active{color:var(--red)!important}

/* SOS Section */
.sos-tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.sos-tab{
  padding:9px 14px;border-radius:99px;font-size:.82rem;font-weight:600;
  background:var(--surface);border:1px solid var(--border);
  color:var(--text-muted);transition:var(--transition);
}
.sos-tab.active{background:var(--red);border-color:var(--red);color:#fff}
.sos-panel{display:none}
.sos-panel.active{display:block;animation:sectionIn .25s ease}

/* Vitales form */
.sos-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
@media(max-width:480px){.sos-form-grid{grid-template-columns:1fr}}
.sos-field-card{
  background:var(--surface);border-radius:var(--radius);
  border:1px solid var(--border);padding:14px;
}
.sos-field-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}
.sos-field-emoji{font-size:1.4rem;flex-shrink:0;margin-top:2px}
.sos-field-header label{display:block;font-weight:700;font-size:.88rem;margin-bottom:2px}
.sos-normal-range{display:block;font-size:.73rem;color:var(--text-muted)}
.sos-field-card input{
  width:100%;padding:10px 12px;border:1.5px solid var(--border);
  border-radius:var(--radius-sm);background:var(--surface);color:var(--text);
  font-size:.95rem;font-weight:600;
}
.sos-field-card input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(27,108,168,.12)}
.sos-pa-inputs{display:flex;align-items:center;gap:8px}
.sos-pa-inputs input{flex:1}
.sos-pa-inputs span{font-size:1.2rem;color:var(--text-muted);font-weight:700}
.sos-result{
  margin-top:10px;padding:8px 12px;border-radius:var(--radius-sm);
  font-size:.8rem;font-weight:600;line-height:1.4;display:none;
}
.sos-result.normal{background:var(--green-pale);color:var(--green);display:block}
.sos-result.alterado{background:var(--yellow-pale);color:#A0831A;display:block}
.sos-result.riesgo{background:var(--orange-pale);color:var(--orange);display:block}
.sos-result.critico{background:var(--red-pale);color:var(--red);display:block}

/* SOS Resumen */
.sos-resumen{
  border-radius:var(--radius);padding:16px;margin-top:12px;
  border:2px solid transparent;
}
.sos-resumen.normal{background:var(--green-pale);border-color:rgba(26,122,74,.2)}
.sos-resumen.warning{background:var(--orange-pale);border-color:rgba(232,83,10,.2)}
.sos-resumen.critical{background:var(--red-pale);border-color:rgba(192,57,43,.3)}
.sos-resumen h3{font-size:.95rem;margin-bottom:8px}
.sos-resumen p{font-size:.82rem;line-height:1.5}

/* XABCDE */
.xabcde-list{display:flex;flex-direction:column;gap:10px}
.xabcde-item{
  background:var(--surface);border-radius:var(--radius);
  border:1px solid var(--border);padding:14px;
  display:flex;gap:12px;align-items:flex-start;
}
.xabcde-letter{
  width:36px;height:36px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-family:'Sora',sans-serif;font-size:1.1rem;font-weight:800;
  color:#fff;flex-shrink:0;
}
.xabcde-letter.x{background:#9B59B6}
.xabcde-letter.a{background:#E74C3C}
.xabcde-letter.b{background:#E67E22}
.xabcde-letter.c{background:#C0392B}
.xabcde-letter.d{background:#2980B9}
.xabcde-letter.e{background:#27AE60}
.xabcde-info{flex:1}
.xabcde-info strong{display:block;font-size:.9rem;margin-bottom:2px}
.xabcde-info p{font-size:.8rem;color:var(--text-muted);margin-bottom:8px}
.xabcde-guide{
  background:var(--surface2);border-radius:var(--radius-sm);
  padding:10px;margin-top:8px;display:none;
}
.xabcde-guide.show{display:block}
.sos-check{display:flex;align-items:center;gap:8px;font-size:.85rem;cursor:pointer}
.sos-check input{accent-color:var(--red);width:16px;height:16px}

/* Guide steps */
.guide-step{
  font-size:.8rem;color:var(--text-mid);padding:6px 0;
  border-bottom:1px solid var(--border);line-height:1.4;
}
.guide-step:last-child{border-bottom:none}
.guide-step.urgent{
  color:var(--red);font-weight:600;
  background:var(--red-pale);border-radius:var(--radius-sm);
  padding:6px 8px;margin-top:4px;border-bottom:none;
}

/* Síndromes */
.sos-sindrome-tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.sind-tab{
  padding:7px 12px;border-radius:99px;font-size:.78rem;font-weight:600;
  background:var(--surface);border:1px solid var(--border);
  color:var(--text-muted);transition:var(--transition);
}
.sind-tab.active{background:var(--navy);border-color:var(--navy);color:#fff}
.sind-panel{display:none}
.sind-panel.active{display:block;animation:sectionIn .2s ease}
.sind-header{
  display:flex;align-items:center;gap:14px;padding:14px;
  border-radius:var(--radius);margin-bottom:14px;
}
.sind-header span{font-size:2rem}
.sind-header h3{font-size:1rem;font-weight:700;margin-bottom:2px}
.sind-header p{font-size:.8rem;opacity:.8}
.sind-header.hipo{background:linear-gradient(135deg,rgba(230,126,34,.15),rgba(230,126,34,.05));border:1px solid rgba(230,126,34,.3)}
.sind-header.hiper{background:linear-gradient(135deg,rgba(192,57,43,.15),rgba(192,57,43,.05));border:1px solid rgba(192,57,43,.3)}
.sind-header.acv{background:linear-gradient(135deg,rgba(41,128,185,.15),rgba(41,128,185,.05));border:1px solid rgba(41,128,185,.3)}
.sind-header.iam{background:linear-gradient(135deg,rgba(192,57,43,.15),rgba(192,57,43,.05));border:1px solid rgba(192,57,43,.3)}
.sind-header.rcp{background:linear-gradient(135deg,rgba(26,122,74,.15),rgba(26,122,74,.05));border:1px solid rgba(26,122,74,.3)}
.sind-checker{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:14px;margin-bottom:14px}
.sind-check-title{font-size:.85rem;font-weight:700;margin-bottom:10px;color:var(--text-muted)}
.sind-checks{display:flex;flex-direction:column;gap:8px}
.sind-result{
  margin-top:12px;padding:10px 14px;border-radius:var(--radius-sm);
  font-size:.82rem;font-weight:600;line-height:1.5;display:none;
}
.sind-result.leve{background:var(--yellow-pale);color:#A0831A;display:block}
.sind-result.moderado{background:var(--orange-pale);color:var(--orange);display:block}
.sind-result.grave{background:var(--red-pale);color:var(--red);display:block}
.sind-guide{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:14px}
.sind-guide h4{font-size:.88rem;font-weight:700;margin-bottom:10px}
.guide-steps{display:flex;flex-direction:column;gap:6px}

/* FAST */
.fast-eval{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.fast-item{
  background:var(--surface);border-radius:var(--radius);
  border:1px solid var(--border);padding:14px;
  display:flex;align-items:center;gap:12px;
}
.fast-letter{
  width:40px;height:40px;background:var(--blue);color:#fff;
  border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;
  font-family:'Sora',sans-serif;font-size:1.2rem;font-weight:800;flex-shrink:0;
}
.fast-info{flex:1}
.fast-info strong{display:block;font-size:.88rem;margin-bottom:2px}
.fast-info p{font-size:.78rem;color:var(--text-muted)}
.fast-btns{display:flex;gap:6px;flex-shrink:0}
.fast-btn{
  padding:6px 12px;border-radius:99px;font-size:.78rem;font-weight:600;
  background:var(--surface2);border:1px solid var(--border);color:var(--text-mid);
  transition:var(--transition);
}
.fast-btn.yes{background:var(--red);border-color:var(--red);color:#fff}
.fast-btn.no{background:var(--green-pale);border-color:rgba(26,122,74,.3);color:var(--green)}

/* RCP */
.rcp-steps{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.rcp-step{
  background:var(--surface);border-radius:var(--radius);
  border:1px solid var(--border);padding:14px;
  display:flex;gap:12px;align-items:flex-start;
}
.rcp-step.urgent-step{border-color:rgba(192,57,43,.3);background:var(--red-pale)}
.rcp-num{
  width:32px;height:32px;border-radius:50%;background:var(--blue);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'Sora',sans-serif;font-weight:800;font-size:.9rem;flex-shrink:0;
}
.rcp-step.urgent-step .rcp-num{background:var(--red)}
.rcp-content strong{display:block;font-size:.88rem;margin-bottom:4px}
.rcp-content p{font-size:.8rem;color:var(--text-mid);line-height:1.4}
.rcp-step.urgent-step .rcp-content p{color:var(--red)}
.rcp-timer-card{
  background:var(--navy);border-radius:var(--radius);
  padding:16px;text-align:center;
}
.rcp-timer-card p{color:rgba(255,255,255,.7);font-size:.82rem;margin-bottom:10px}
.rcp-timer-display{margin-top:14px}
.rcp-pulse{font-size:2.5rem;animation:rcpPulse 0.6s ease infinite}
@keyframes rcpPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.25)}}
#rcpTimerCount{color:#fff;font-family:'Sora',sans-serif;font-size:1.5rem;font-weight:700;margin-top:6px}

/* Member meds section */
.member-meds-section{background:var(--surface2);border-radius:var(--radius-sm);padding:10px;margin-top:6px}
.member-meds-section h5{font-size:.78rem;font-weight:700;color:var(--text-muted);margin-bottom:4px}
.member-meds-section p{font-size:.8rem;color:var(--text-mid);line-height:1.5}

/* Med detail expand */
.med-card-body{display:none;padding:12px;background:var(--surface2);border-top:1px solid var(--border)}
.med-card-body.open{display:block}
.med-detail-section{margin-bottom:8px}
.med-detail-section h5{font-size:.75rem;font-weight:700;color:var(--text-muted);margin-bottom:3px;text-transform:uppercase;letter-spacing:.04em}
.med-detail-section p{font-size:.82rem;color:var(--text-mid);line-height:1.4}
.med-urgencia-box{background:var(--orange-pale);border-radius:var(--radius-sm);padding:8px 10px}
.med-urgencia-box p{color:var(--orange)}


/* ---- NEW ADDITIONS v2 ---- */

/* NAV SOS */
.nav-item.nav-sos{color:var(--red);font-weight:700}
.nav-item.nav-sos:hover,.nav-item.nav-sos.active{background:var(--red-pale)}
.bnav-sos{color:var(--red)!important}
.bnav-sos.active{color:var(--red)!important}

/* SOS BANNER on dashboard */
.sos-banner{
  background:linear-gradient(135deg,var(--red) 0%,#C0392B 100%);
  border-radius:var(--radius);padding:16px;
  display:flex;align-items:center;gap:12px;
  cursor:pointer;transition:var(--transition);margin-bottom:14px;
  box-shadow:0 4px 16px rgba(192,57,43,.25);
}
.sos-banner:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(192,57,43,.35)}
.sos-banner-icon{font-size:1.6rem;flex-shrink:0}
.sos-banner-info{flex:1}
.sos-banner-info strong{display:block;color:#fff;font-size:.95rem;margin-bottom:3px}
.sos-banner-info p{color:rgba(255,255,255,.75);font-size:.8rem}
.sos-banner-arrow{color:rgba(255,255,255,.7);font-size:1.4rem;font-weight:300}

/* MED CLINICAL INFO */
.med-info-toggle{
  margin-top:8px;font-size:.78rem;color:var(--blue);font-weight:600;
  background:none;border:none;cursor:pointer;padding:2px 0;
  display:block;
}
.med-info-toggle:hover{text-decoration:underline}
.med-clinical{
  display:none;margin-top:8px;border-top:1px solid var(--border);
  padding-top:8px;
}
.med-clinical.open{display:block}
.med-clin-row{
  margin-bottom:6px;font-size:.8rem;line-height:1.45;
}
.med-clin-label{
  display:block;font-weight:700;color:var(--text-mid);margin-bottom:2px;font-size:.75rem;text-transform:uppercase;letter-spacing:.02em;
}
.urgent-clin{
  background:var(--red-pale);border-radius:var(--radius-sm);padding:8px;
  border-left:3px solid var(--red);
}
.urgent-clin .med-clin-label{color:var(--red)}

/* MEMBER MEDS BLOCK */
.member-meds-block{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:12px;margin-bottom:10px;
}
.member-meds-block.warn{background:var(--orange-pale);border-color:rgba(232,83,10,.2)}
.member-meds-title{font-size:.78rem;font-weight:700;color:var(--text-mid);margin-bottom:5px}
.member-meds-content{font-size:.82rem;color:var(--text);line-height:1.6}

/* SOS VITAL RESULTS */
.sos-res-critical{background:var(--red-pale);color:var(--red);border:1px solid rgba(192,57,43,.2);border-radius:var(--radius-sm);padding:8px 10px;display:flex;gap:8px;align-items:flex-start;margin-top:6px;font-size:.82rem;font-weight:600}
.sos-res-warning{background:var(--orange-pale);color:var(--orange);border:1px solid rgba(232,83,10,.2);border-radius:var(--radius-sm);padding:8px 10px;display:flex;gap:8px;align-items:flex-start;margin-top:6px;font-size:.82rem;font-weight:600}
.sos-res-elevated{background:var(--yellow-pale);color:#A0830A;border:1px solid rgba(212,172,13,.2);border-radius:var(--radius-sm);padding:8px 10px;display:flex;gap:8px;align-items:flex-start;margin-top:6px;font-size:.82rem;font-weight:600}
.sos-res-normal{background:var(--green-pale);color:var(--green);border:1px solid rgba(26,122,74,.2);border-radius:var(--radius-sm);padding:8px 10px;display:flex;gap:8px;align-items:flex-start;margin-top:6px;font-size:.82rem;font-weight:600}

/* SOS RESUMEN */
.sos-resumen{border-radius:var(--radius);padding:16px;margin-top:16px}
.sos-resumen strong{display:block;margin-bottom:4px;font-size:.95rem}
.sos-resumen p{font-size:.85rem;line-height:1.4}
.sos-resumen-critical{background:var(--red-pale);border:2px solid var(--red);color:var(--red)}
.sos-resumen-warning{background:var(--orange-pale);border:2px solid var(--orange);color:var(--orange)}

/* SOS FORM GRID */
.sos-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.sos-tab{padding:8px 14px;border-radius:99px;font-size:.82rem;font-weight:600;background:var(--surface);border:1.5px solid var(--border);color:var(--text-muted);transition:var(--transition);cursor:pointer}
.sos-tab.active{background:var(--navy);border-color:var(--navy);color:#fff}
.sos-panel{display:none}.sos-panel.active{display:block}
.sos-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
@media(max-width:480px){.sos-form-grid{grid-template-columns:1fr}}
.sos-field-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm)}
.sos-field-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px}
.sos-field-emoji{font-size:1.3rem;flex-shrink:0;margin-top:2px}
.sos-field-header label{display:block;font-weight:700;font-size:.88rem}
.sos-normal-range{display:block;font-size:.72rem;color:var(--text-muted);margin-top:1px}
.sos-field-card input[type=number]{width:100%;padding:8px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:.95rem;font-family:inherit;-webkit-appearance:none}
.sos-field-card input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(27,108,168,.1)}
.sos-pa-inputs{display:flex;align-items:center;gap:6px}
.sos-pa-inputs input{flex:1}
.sos-pa-inputs span{font-weight:700;color:var(--text-muted)}

/* XABCDE */
.xabcde-list{display:flex;flex-direction:column;gap:10px}
.xabcde-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;gap:14px;align-items:flex-start}
.xabcde-letter{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-weight:800;font-size:1rem;color:#fff;flex-shrink:0}
.xabcde-letter.x{background:var(--red)}
.xabcde-letter.a{background:var(--orange)}
.xabcde-letter.b{background:var(--blue)}
.xabcde-letter.c{background:var(--teal)}
.xabcde-letter.d{background:var(--navy-mid)}
.xabcde-letter.e{background:var(--green)}
.xabcde-info{flex:1}
.xabcde-info strong{display:block;font-size:.9rem;margin-bottom:3px}
.xabcde-info p{font-size:.8rem;color:var(--text-muted);margin-bottom:8px}
.xabcde-actions{display:flex;flex-direction:column;gap:6px}
.xabcde-guide{display:none;margin-top:8px;padding:10px;background:var(--orange-pale);border-radius:var(--radius-sm);border-left:3px solid var(--orange)}
.sos-check{display:flex;align-items:center;gap:8px;font-size:.85rem;cursor:pointer}
.sos-check input[type=checkbox]{width:16px;height:16px;accent-color:var(--red);cursor:pointer;flex-shrink:0}

/* SÍNDROMES */
.sos-sindrome-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}
.sind-tab{padding:7px 12px;border-radius:99px;font-size:.78rem;font-weight:600;background:var(--surface);border:1.5px solid var(--border);color:var(--text-muted);transition:var(--transition);cursor:pointer}
.sind-tab.active{background:var(--navy);border-color:var(--navy);color:#fff}
.sind-panel{display:none}.sind-panel.active{display:block;animation:sectionIn .25s ease}
.sind-header{display:flex;align-items:center;gap:14px;padding:14px;border-radius:var(--radius);margin-bottom:14px}
.sind-header span{font-size:2rem;flex-shrink:0}
.sind-header h3{font-size:1rem;font-weight:700;margin-bottom:3px}
.sind-header p{font-size:.8rem;opacity:.8}
.sind-header.hipo{background:linear-gradient(135deg,#2874A6,#1B6CA8);color:#fff}
.sind-header.hiper{background:linear-gradient(135deg,#E67E22,#F0792A);color:#fff}
.sind-header.acv{background:linear-gradient(135deg,#5B2C6F,#7D3C98);color:#fff}
.sind-header.iam{background:linear-gradient(135deg,var(--red),#E74C3C);color:#fff}
.sind-header.rcp{background:linear-gradient(135deg,var(--navy),var(--navy-mid));color:#fff}
.sind-checker{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:14px}
.sind-check-title{font-size:.85rem;font-weight:700;margin-bottom:10px}
.sind-checks{display:flex;flex-direction:column;gap:8px}
.sind-result{margin-top:12px;font-size:.85rem;line-height:1.5}
.sind-result:empty{display:none}
.sind-result-critical{color:var(--red);font-weight:700;background:var(--red-pale);padding:10px;border-radius:var(--radius-sm);display:block}
.sind-result-warn{color:var(--orange);font-weight:700;background:var(--orange-pale);padding:10px;border-radius:var(--radius-sm);display:block}
.sind-result-ok{color:var(--green);font-weight:600;background:var(--green-pale);padding:10px;border-radius:var(--radius-sm);display:block}
.sind-guide{background:var(--surface2);border-radius:var(--radius);padding:14px;border:1px solid var(--border)}
.sind-guide h4{font-size:.88rem;font-weight:700;margin-bottom:10px}
.guide-steps{display:flex;flex-direction:column;gap:6px}
.guide-step{font-size:.82rem;padding:8px 10px;background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border);line-height:1.4}
.guide-step.urgent{background:var(--red-pale);border-color:rgba(192,57,43,.2);color:var(--red);font-weight:600}

/* FAST */
.fast-eval{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.fast-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px;display:flex;align-items:center;gap:12px}
.fast-letter{width:36px;height:36px;background:var(--navy);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-weight:800;color:#fff;font-size:1rem;flex-shrink:0}
.fast-info{flex:1}
.fast-info strong{display:block;font-size:.88rem;margin-bottom:2px}
.fast-info p{font-size:.78rem;color:var(--text-muted)}
.fast-btns{display:flex;gap:6px;flex-shrink:0}
.fast-btn{padding:6px 12px;border-radius:var(--radius-sm);background:var(--surface2);border:1.5px solid var(--border);font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition);color:var(--text-mid)}
.fast-btn:hover{background:var(--border)}
.fast-btn.selected{background:var(--navy);border-color:var(--navy);color:#fff}

/* RCP */
.rcp-steps{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.rcp-step{display:flex;gap:12px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px}
.rcp-step.urgent-step{background:rgba(192,57,43,.06);border-color:rgba(192,57,43,.25)}
.rcp-num{width:32px;height:32px;background:var(--blue);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-weight:700;font-size:.9rem;flex-shrink:0}
.urgent-step .rcp-num{background:var(--red)}
.rcp-content strong{display:block;font-size:.88rem;margin-bottom:3px}
.rcp-content p{font-size:.8rem;color:var(--text-muted);line-height:1.4}
.rcp-timer-card{background:var(--surface2);border-radius:var(--radius);padding:14px;border:1px solid var(--border);text-align:center}
.rcp-timer-card p{font-size:.85rem;margin-bottom:10px;font-weight:600}
.rcp-timer-display{margin-top:14px}
.rcp-pulse{font-size:2rem;transition:transform .1s;display:inline-block}
#rcpTimerCount{font-family:'Sora',sans-serif;font-size:.95rem;font-weight:700;color:var(--blue);margin-top:4px}

/* ---- AUTH SCREEN ---- */
.auth-screen{
  position:fixed;inset:0;background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  z-index:9000;padding:20px;overflow-y:auto;
}
.auth-card{
  background:var(--surface);border-radius:var(--radius-xl);
  border:1px solid var(--border);box-shadow:var(--shadow-lg);
  width:100%;max-width:420px;padding:28px 24px;
}
.auth-logo{display:flex;align-items:center;gap:14px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border);}
.auth-logo svg{width:44px;height:44px;flex-shrink:0}
.auth-logo h1{font-family:'Sora',sans-serif;font-size:1.4rem;font-weight:800;color:var(--navy);margin:0}
[data-theme="dark"] .auth-logo h1{color:var(--text)}
.auth-logo p{font-size:.78rem;color:var(--text-muted);margin:0}
.auth-panel h2{font-family:'Sora',sans-serif;font-size:1.2rem;font-weight:700;margin-bottom:4px}
.auth-sub{font-size:.83rem;color:var(--text-muted);margin-bottom:18px;line-height:1.4}
.btn-full{width:100%;justify-content:center;padding:12px;font-size:.95rem}
.btn-google{
  width:100%;display:flex;align-items:center;justify-content:center;gap:10px;
  padding:11px;border-radius:var(--radius-sm);margin-top:10px;
  background:var(--surface);border:1.5px solid var(--border);
  font-weight:600;font-size:.88rem;cursor:pointer;
  color:var(--text);transition:var(--transition);font-family:inherit;
}
.btn-google:hover{background:var(--surface2);border-color:var(--blue)}
.auth-switch{text-align:center;font-size:.83rem;color:var(--text-muted);margin-top:14px}
.auth-switch button{background:none;border:none;color:var(--blue);font-weight:600;cursor:pointer;font-size:.83rem;font-family:inherit}
.auth-switch button:hover{text-decoration:underline}
.auth-error{background:var(--red-pale);color:var(--red);border-radius:var(--radius-sm);padding:10px 12px;font-size:.83rem;margin-bottom:12px;line-height:1.4}
.auth-success{background:var(--green-pale);color:var(--green);border-radius:var(--radius-sm);padding:10px 12px;font-size:.83rem;margin-bottom:12px}
.auth-legal{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);font-size:.72rem;color:var(--text-muted);text-align:center;line-height:1.4}
.auth-confirm-icon{font-size:3rem;text-align:center;margin:8px 0 12px}

/* Sidebar email */
.profile-email{display:block;font-size:.72rem;color:var(--text-muted);margin-top:1px;word-break:break-all}

/* Sync spinner */
.sync-btn svg{width:16px;height:16px}
@keyframes spinAnim{to{transform:rotate(360deg)}}
.sync-btn.spin svg{animation:spinAnim .8s linear infinite}

/* ---- PASSWORD TOGGLE & REMEMBER ME ---- */
.pw-wrap{position:relative;display:flex;align-items:center}
.pw-wrap input{width:100%;padding-right:42px}
.pw-toggle{
  position:absolute;right:10px;
  width:28px;height:28px;
  display:flex;align-items:center;justify-content:center;
  background:none;border:none;cursor:pointer;
  color:var(--text-muted);border-radius:6px;
  transition:color var(--transition);flex-shrink:0;
}
.pw-toggle:hover{color:var(--blue)}
.pw-toggle svg{width:18px;height:18px;pointer-events:none}

.remember-me{
  display:flex;align-items:center;gap:9px;
  margin-bottom:14px;cursor:pointer;
  font-size:.84rem;color:var(--text-mid);
  user-select:none;
}
.remember-me input[type=checkbox]{
  width:16px;height:16px;
  accent-color:var(--blue);
  cursor:pointer;flex-shrink:0;
}

/* ---- COOKIE BANNER ---- */
.cookie-banner{
  position:fixed;bottom:calc(var(--bnav-h) + 10px);left:12px;right:12px;
  background:var(--navy);color:#fff;border-radius:var(--radius);
  padding:12px 16px;z-index:800;box-shadow:var(--shadow-lg);
  animation:slideUp .3s ease;
}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-content{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.cookie-content span{font-size:.82rem;flex:1;line-height:1.4}
.cookie-content a{color:#7AACCE;text-decoration:underline}
.cookie-btn{background:#1B6CA8;color:#fff;border:none;border-radius:var(--radius-sm);padding:7px 14px;font-size:.82rem;font-weight:700;cursor:pointer;white-space:nowrap;font-family:inherit}
.cookie-btn:hover{background:#2E86C1}
@media(min-width:768px){.cookie-banner{bottom:16px;left:auto;right:16px;max-width:420px}}

/* ---- APP FOOTER ---- */
.app-footer{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:16px;font-size:.75rem;color:var(--text-muted);
  border-top:1px solid var(--border);margin-top:8px;flex-wrap:wrap;
}
.app-footer a{color:var(--blue);text-decoration:none}
.app-footer a:hover{text-decoration:underline}

/* ---- ESTADO DE SALUD ---- */
.salud-member-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.salud-member-tab{
  display:flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:99px;
  background:var(--surface);border:1.5px solid var(--border);
  font-size:.84rem;font-weight:600;color:var(--text-mid);
  cursor:pointer;transition:var(--transition);font-family:inherit;
}
.salud-member-tab:hover{border-color:var(--blue);color:var(--blue)}
.salud-member-tab.active{background:var(--blue);border-color:var(--blue);color:#fff}
.salud-tab-avatar{
  width:24px;height:24px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.68rem;font-weight:700;color:#fff;flex-shrink:0;
}
.salud-member-tab.active .salud-tab-avatar{background:rgba(255,255,255,.25)}
.salud-tab-avatar.adult{background:#1B6CA8}
.salud-tab-avatar.child{background:#27AE60}
.salud-tab-avatar.senior{background:#E8530A}
.salud-member-tab.active .salud-tab-avatar.adult,
.salud-member-tab.active .salud-tab-avatar.child,
.salud-member-tab.active .salud-tab-avatar.senior{background:rgba(255,255,255,.3)}
.salud-chart-wrap{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:16px;margin-bottom:16px;
  box-shadow:var(--shadow-sm);
}
.salud-chart-wrap canvas{max-height:260px}
.salud-empty{
  text-align:center;padding:28px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius);
  margin-bottom:16px;font-size:.85rem;color:var(--text-muted);line-height:1.6;
}
.salud-empty div{font-size:2rem;margin-bottom:8px}
.salud-hist-title{font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:10px}
.salud-registro-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:14px;margin-bottom:10px;
  position:relative;box-shadow:var(--shadow-sm);
}
.salud-reg-fecha{font-size:.78rem;color:var(--text-muted);margin-bottom:8px;font-weight:600}
.salud-reg-items{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}
.salud-reg-item{
  display:flex;flex-direction:column;align-items:center;
  padding:6px 10px;border-radius:var(--radius-sm);min-width:64px;
  border:1px solid transparent;
}
.salud-reg-label{font-size:.68rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em;margin-bottom:2px}
.salud-reg-val{font-size:.85rem;font-weight:700}
.status-green{background:var(--green-pale);color:var(--green);border-color:rgba(26,122,74,.15)}
.status-yellow{background:var(--yellow-pale);color:#A0830A;border-color:rgba(212,172,13,.15)}
.status-orange{background:var(--orange-pale);color:var(--orange);border-color:rgba(232,83,10,.15)}
.status-red{background:var(--red-pale);color:var(--red);border-color:rgba(192,57,43,.15)}
.salud-reg-notas{font-size:.78rem;color:var(--text-muted);margin-top:4px;padding-top:6px;border-top:1px solid var(--border)}
.salud-reg-delete{
  position:absolute;top:10px;right:10px;
  background:none;border:none;cursor:pointer;
  font-size:.9rem;opacity:.4;transition:opacity .2s;padding:4px;
}
.salud-reg-delete:hover{opacity:1}

/* ---- LOGO REAL KITSALVA ---- */
.auth-logo-img{
  width:160px;max-width:75%;
  display:block;margin:0 auto 20px;
}
.splash-logo-img{
  width:240px;max-width:80%;
  display:block;margin:0 auto;
  filter:brightness(0) invert(1); /* fondo oscuro: logo blanco */
}
.topbar-logo{
  height:32px;width:auto;
  display:block;
  object-fit:contain;
}

/* Modo claro: logo claro, ocultar oscuro */
[data-theme="light"] .logo-light-img{display:block!important}
[data-theme="light"] .logo-dark-img{display:none!important}
/* Modo oscuro: logo oscuro (fondo negro), ocultar claro */
[data-theme="dark"] .logo-light-img{display:none!important}
[data-theme="dark"] .logo-dark-img{display:block!important}
/* En splash siempre fondo oscuro */
.splash .splash-logo-img{filter:none}

/* Auth card fondo oscuro en dark mode */
[data-theme="dark"] .auth-card{
  background:var(--surface);
}

/* Topbar brand sin texto extra */
.topbar-brand span{display:none}

/* ---- LOGO SVG KITSALVA v2 ---- */
.auth-logo{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;margin-bottom:24px;padding-bottom:20px;
  border-bottom:1px solid var(--border);
}
.auth-logo-svg svg{width:56px;height:56px;margin-bottom:10px;display:block}
.auth-logo-text{display:flex;flex-direction:column;align-items:center;gap:2px}
.auth-logo-name{
  font-family:'Sora',sans-serif;font-size:1.6rem;font-weight:800;
  color:var(--text);letter-spacing:-.02em;line-height:1;
}
.auth-logo-name span{color:#E8153A}
.auth-logo-tag{font-size:.78rem;color:var(--text-muted)}

/* Splash logo */
.splash-logo{display:flex;flex-direction:column;align-items:center;gap:10px}
.splash-name{
  font-family:'Sora',sans-serif;font-size:1.8rem;font-weight:800;
  color:#fff;letter-spacing:-.02em;
}
.splash-name span{color:#FF6B8A}

/* Topbar brand con texto */
.topbar-brand{display:flex;align-items:center;gap:8px}
.topbar-brand span{
  display:block!important;
  font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;color:var(--text);
}
