:root{--azul:#1e6fd9;--azul-h:#1a5fb8;--azul-bg:#eaf3fe;--verde:#1f9d57;--verde-bg:#e6f6ed;--ambar:#b7791f;--ambar-bg:#fdf4e3;--rojo:#d12c2c;--text:#2b2f36;--text-soft:#6b7280;--bg:#f4f6f9;--card:#fff;--border:#e3e7ed;--shadow:0 1px 3px #1018280f, 0 1px 2px #1018280a;--radius:12px;--sans:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;font-family:var(--sans);color:var(--text);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5}*{box-sizing:border-box}body{background:var(--bg);margin:0}h1,h2,h3{color:#111827;margin:0;font-weight:600}h2{margin-bottom:.25rem;font-size:1.35rem}h3{font-size:1.1rem}p{margin:0}.app-shell{max-width:760px;margin:0 auto;padding:0 16px 48px}.topbar{background:var(--card);border-bottom:1px solid var(--border);margin-bottom:28px}.topbar-inner{justify-content:space-between;align-items:center;max-width:760px;margin:0 auto;padding:14px 16px;display:flex}.brand{color:#111827;align-items:center;gap:10px;font-weight:600;display:flex}.brand-logo{background:var(--azul);color:#fff;border-radius:8px;place-items:center;width:30px;height:30px;font-weight:700;display:grid}.user-meta{align-items:center;gap:14px;display:flex}.user-name{font-size:.92rem}.role-badge{text-transform:uppercase;letter-spacing:.04em;background:var(--azul-bg);color:var(--azul);border-radius:999px;padding:3px 9px;font-size:.72rem;font-weight:600}.section-title{margin-bottom:14px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:12px;padding:16px 18px}.card.muted{opacity:.65}.card-row{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.med-name{color:#111827;font-weight:600}.med-sub{color:var(--text-soft);margin-top:2px;font-size:.85rem}.med-time{font-variant-numeric:tabular-nums;color:var(--azul);white-space:nowrap;font-weight:600}.status{align-items:center;gap:6px;font-size:.9rem;font-weight:500;display:inline-flex}.status.taken{color:var(--verde)}.status.note{color:var(--text-soft);font-size:.82rem}button{cursor:pointer;border:1px solid #0000;border-radius:8px;padding:8px 14px;font-family:inherit;font-size:.9rem;font-weight:500;transition:background .15s,border-color .15s}.btn-primary{background:var(--azul);color:#fff}.btn-primary:hover{background:var(--azul-h)}.btn-primary:disabled{opacity:.6;cursor:default}.btn-secondary{color:var(--text);border-color:var(--border);background:#fff}.btn-secondary:hover{background:#f6f8fa}.btn-success{background:var(--verde);color:#fff}.btn-success:hover{filter:brightness(.95)}.btn-danger-text{color:var(--rojo);background:0 0;padding:8px 10px}.btn-danger-text:hover{background:#fdeaea}.btn-row{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.field{border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:8px;margin-bottom:10px;padding:10px 12px;font-family:inherit;font-size:.95rem;display:block}.field:focus{border-color:var(--azul);box-shadow:0 0 0 3px var(--azul-bg);outline:none}.form-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:28px;padding:18px}.login-wrap{place-items:center;min-height:100vh;padding:16px;display:grid}.login-card{background:var(--card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:360px;padding:32px 28px;box-shadow:0 8px 30px #10182814}.login-logo{background:var(--azul);color:#fff;border-radius:12px;place-items:center;width:48px;height:48px;margin:0 auto 16px;font-size:1.4rem;font-weight:700;display:grid}.login-card h2{text-align:center;margin-bottom:20px}.error-msg{color:var(--rojo);text-align:center;margin-top:10px;font-size:.88rem}.empty{color:var(--text-soft);font-size:.92rem}.list{margin:0;padding:0;list-style:none}.patient-group{margin-bottom:28px}.patient-group h3{border-bottom:1px solid var(--border);margin-bottom:10px;padding-bottom:6px}.btn-link{color:var(--azul);cursor:pointer;font-weight:600;font-size:inherit;background:0 0;border:none;padding:0}.btn-link:hover{text-decoration:underline}.tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:24px;display:flex}.tab{color:var(--text-soft);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:0;padding:10px 16px;font-size:.95rem;font-weight:500}.tab:hover{color:var(--text)}.tab.active{color:var(--azul);border-bottom-color:var(--azul)}.summary{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.summary-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.summary-label{color:var(--text-soft);margin-bottom:2px;font-size:.82rem}.summary-num{font-size:1.6rem;font-weight:600;line-height:1}.summary-num.pend{color:var(--ambar)}.summary-num.done{color:var(--verde)}.dose{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:14px;margin-bottom:10px;padding:14px 16px;display:flex}.dose-icon{border-radius:10px;flex-shrink:0;place-items:center;width:42px;height:42px;display:grid}.dose-icon.pending{background:var(--ambar-bg);color:var(--ambar)}.dose-icon.taken{background:var(--verde-bg);color:var(--verde)}.dose-info{flex:1;min-width:0}.dose-name{color:#111827;font-weight:600}.dose-dose{color:var(--text-soft);margin-top:1px;font-size:.85rem}.dose-time{color:var(--azul);font-variant-numeric:tabular-nums;white-space:nowrap;font-weight:600}.dose-status{color:var(--verde);white-space:nowrap;align-items:center;gap:5px;font-size:.9rem;font-weight:500;display:inline-flex}.dose-status .sub{color:var(--text-soft);font-size:.82rem;font-weight:400}.form-grid{flex-direction:column;gap:10px;display:flex}.rx{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:10px;padding:16px 18px}.rx.ajena{opacity:.6}.rx-head{align-items:flex-start;gap:12px;display:flex}.rx-icon{background:var(--azul-bg);width:42px;height:42px;color:var(--azul);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.rx-body{flex:1;min-width:0}.rx-name{color:#111827;font-weight:600}.rx-meta{color:var(--text-soft);margin-top:2px;font-size:.85rem}.rx-hours{color:var(--text-soft);align-items:center;gap:5px;margin-top:4px;font-size:.8rem;display:flex}.rx-tag{color:var(--text-soft);font-size:.78rem;font-style:italic}
