/* ════════════════════════════════════════════════════════
   Módulo Salud — estilos portados del health tracker original.
   Todo scopeado bajo .salud-root para no chocar con el shell.
   ════════════════════════════════════════════════════════ */

.salud-root * { box-sizing: border-box; margin: 0; padding: 0; }
.salud-root {
  font-family: system-ui, sans-serif;
  background: #f0efe9;
  color: #1a1a1a;
  padding: 0 0 80px;
  border-radius: 12px;
  overflow: hidden;
}

.salud-root .topbar { background: #fff; border-bottom: 0.5px solid rgba(0,0,0,.12); padding: 14px 16px 10px; }
.salud-root .topbar h2 { font-size: 17px; font-weight: 500; }
.salud-root .topbar p { font-size: 12px; color: #666; margin-top: 2px; }

.salud-root .tab-bar { display: flex; gap: 6px; padding: 10px 16px 0; }
.salud-root .tab { flex: 1; padding: 8px 0; border-radius: 8px; font-size: 13px; border: 0.5px solid rgba(0,0,0,.15); background: transparent; color: #666; cursor: pointer; text-align: center; }
.salud-root .tab.active { background: #7F77DD; color: #fff; border-color: #7F77DD; }

.salud-root .content { padding: 12px 16px; }
.salud-root .card { background: #fff; border: 0.5px solid rgba(0,0,0,.13); border-radius: 12px; padding: 14px; margin-bottom: 10px; }
.salud-root .sec-label { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: #aaa; margin-bottom: 10px; }
.salud-root label.lbl { font-size: 13px; color: #555; display: block; margin-bottom: 4px; }

.salud-root input[type=text], .salud-root input[type=date], .salud-root textarea, .salud-root select {
  width: 100%; border: 0.5px solid rgba(0,0,0,.22); border-radius: 8px; padding: 9px 10px;
  font-size: 14px; background: #f8f8f5; color: #1a1a1a; outline: none; -webkit-appearance: none;
}
.salud-root input:focus, .salud-root textarea:focus, .salud-root select:focus { border-color: #7F77DD; box-shadow: 0 0 0 2px rgba(127,119,221,.18); }
.salud-root textarea { resize: vertical; min-height: 80px; }
.salud-root .field { margin-bottom: 12px; }
.salud-root .radio-row { display: flex; gap: 14px; margin-top: 6px; flex-wrap: wrap; }
.salud-root .ri { display: flex; align-items: center; gap: 6px; font-size: 14px; cursor: pointer; }
.salud-root .ri input { width: 16px; height: 16px; accent-color: #7F77DD; }
.salud-root .chk { display: flex; align-items: center; gap: 8px; font-size: 14px; cursor: pointer; margin-bottom: 8px; }
.salud-root .chk input { width: 16px; height: 16px; accent-color: #7F77DD; }
.salud-root .range-wrap { display: flex; align-items: center; gap: 10px; margin-top: 4px; }
.salud-root .range-wrap input[type=range] { flex: 1; accent-color: #7F77DD; }
.salud-root .rval { font-size: 15px; font-weight: 500; color: #7F77DD; min-width: 32px; text-align: right; }
.salud-root .runit { font-size: 12px; color: #999; }

.salud-root button { cursor: pointer; border-radius: 8px; font-size: 14px; border: 0.5px solid rgba(0,0,0,.22); background: transparent; color: #1a1a1a; }
.salud-root .btn-p { background: #7F77DD; color: #fff; border: none; font-weight: 500; padding: 13px; width: 100%; border-radius: 10px; font-size: 15px; margin-top: 4px; }
.salud-root .btn-p:active { background: #534AB7; }
.salud-root .btn-p:disabled { background: #AFA9EC; cursor: not-allowed; }
.salud-root .btn-mic { padding: 9px 11px; border-radius: 8px; font-size: 20px; line-height: 1; color: #666; border: 0.5px solid rgba(0,0,0,.22); background: transparent; }
.salud-root .btn-mic.on { background: #FAEEDA; border-color: #BA7517; color: #633806; }

.salud-root .toggle-link { font-size: 12px; color: #7F77DD; cursor: pointer; text-decoration: underline; display: inline-block; margin-top: 6px; }
.salud-root .desglose { display: none; margin-top: 10px; background: #f5f5f0; border-radius: 8px; padding: 12px; font-size: 13px; color: #555; line-height: 1.9; }
.salud-root .desglose.show { display: block; }
.salud-root .desglose strong { color: #1a1a1a; font-weight: 500; }

.salud-root .consejo-box { background: #EEEDFE; border-radius: 10px; padding: 14px; margin-top: 10px; }
.salud-root .consejo-title { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: #7F77DD; margin-bottom: 8px; }
.salud-root .consejo-box p { font-size: 13px; color: #3C3489; line-height: 1.75; white-space: pre-wrap; }
.salud-root .consejo-error { background: #FAECE7; border-radius: 10px; padding: 14px; margin-top: 10px; font-size: 13px; color: #712B13; }

.salud-root .pill { background: #eee; border-radius: 20px; padding: 3px 10px; font-size: 12px; color: #555; display: inline-block; margin: 2px; }
.salud-root .hentry { padding: 12px; border: 0.5px solid rgba(0,0,0,.12); border-radius: 10px; margin-bottom: 8px; background: #fff; }
.salud-root .hdate { font-weight: 500; font-size: 14px; margin-bottom: 6px; display: flex; justify-content: space-between; align-items: center; }
.salud-root .hactions { display: flex; gap: 6px; }
.salud-root .hbtn { padding: 5px 9px; font-size: 12px; border-radius: 6px; border: 0.5px solid rgba(0,0,0,.2); background: transparent; cursor: pointer; color: #555; }
.salud-root .hbtn.del { border-color: rgba(163,45,45,.3); color: #A32D2D; }

.salud-root .sum-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 10px; }
.salud-root .sum-card { background: #f5f5f0; border-radius: 8px; padding: 12px; text-align: center; }
.salud-root .sum-card .sv { font-size: 20px; font-weight: 500; }
.salud-root .sum-card .sl { font-size: 11px; color: #666; margin-bottom: 4px; }
.salud-root .sum-card .sm { font-size: 10px; color: #aaa; }

.salud-root .estado-box { background: #fff; border: 0.5px solid rgba(0,0,0,.13); border-radius: 12px; padding: 14px; margin-bottom: 10px; }
.salud-root .estado-box p { font-size: 13px; line-height: 1.7; color: #555; }
.salud-root .estado-loading { font-size: 13px; color: #7F77DD; font-style: italic; }

.salud-root .toast { position: fixed; bottom: 90px; left: 50%; transform: translateX(-50%); background: #534AB7; color: #fff; padding: 10px 20px; border-radius: 20px; font-size: 13px; z-index: 99; opacity: 0; transition: opacity .3s; pointer-events: none; }
.salud-root .toast.show { opacity: 1; }
