.section.active{display:block}

/* ─── Command Palette ────────────────────────────────── */
.cmdk-bg{
  position:fixed;inset:0;z-index:60;
  background:rgba(5,7,10,0.72);
  backdrop-filter:blur(8px);
  display:none;
  align-items:flex-start;justify-content:center;
  padding-top:14vh;
}
.cmdk-bg.open{display:flex;animation:fadeIn .16s ease-out}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.cmdk{
  width:min(640px,92vw);
  background:var(--ink-1);
  border:1px solid var(--line-2);
  border-radius:18px;overflow:hidden;
  box-shadow:0 40px 100px rgba(0,0,0,0.6);
  animation:slideDown .22s cubic-bezier(.22,1,.36,1);
}
@keyframes slideDown{from{transform:translateY(-14px);opacity:0}to{transform:translateY(0);opacity:1}}
.cmdk-input-row{
  padding:18px 22px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:12px;
}
.cmdk-input{
  flex:1;font-size:17px;color:var(--fg);background:transparent;border:none;outline:none;
}
.cmdk-input::placeholder{color:var(--fg-mute)}
.cmdk-hint{font-family:var(--mono);font-size:10px;color:var(--fg-mute);letter-spacing:.14em;text-transform:uppercase}
.cmdk-group{padding:6px 0}
.cmdk-label{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-mute);padding:8px 22px 6px}
.cmdk-item{
  display:flex;align-items:center;gap:14px;
  padding:10px 22px;cursor:pointer;transition:background .1s;
}
.cmdk-item:hover,.cmdk-item.active{background:rgba(39,196,123,0.08)}
.cmdk-item.active{box-shadow:inset 3px 0 0 var(--emerald)}
.cmdk-ico{
  width:30px;height:30px;border-radius:8px;
  background:var(--ink-3);display:grid;place-items:center;
  color:var(--fg-dim);border:1px solid var(--line);font-size:13px;
}
.cmdk-ico svg{width:16px;height:16px;stroke-width:1.6}
.cmdk-item.active .cmdk-ico{color:var(--emerald);border-color:rgba(39,196,123,.3);background:rgba(39,196,123,.1)}
.cmdk-text{flex:1;min-width:0}
.cmdk-title{font-size:14px;color:var(--fg);font-weight:500}
.cmdk-sub{font-family:var(--mono);font-size:11px;color:var(--fg-mute);margin-top:2px}
.cmdk-kbd{font-family:var(--mono);font-size:10px;padding:3px 7px;border-radius:5px;background:var(--ink-3);border:1px solid var(--line);color:var(--fg-dim)}

/* ─── AI Overlay ─────────────────────────────────────── */
.ai-overlay{
  position:fixed;right:24px;bottom:24px;z-index:50;
  width:400px;max-width:calc(100vw - 48px);
  background:var(--ink-1);
  border:1px solid rgba(144,80,200,0.4);
  border-radius:20px;
  box-shadow:0 30px 80px rgba(0,0,0,0.6), 0 0 40px rgba(144,80,200,0.15);
  overflow:hidden;display:none;
  animation:popup .25s cubic-bezier(.22,1,.36,1);
}
.ai-overlay.open{display:block}
@keyframes popup{from{transform:translateY(12px) scale(0.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
.ai-o-head{
  padding:16px 20px;
  background:linear-gradient(135deg,rgba(144,80,200,0.22),rgba(144,80,200,0.05));
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:10px;
}
.ai-o-name{font-family:var(--serif);font-size:20px;color:var(--fg)}
.ai-o-name i{color:var(--amethyst-2);font-style:italic}
.ai-o-close{margin-left:auto;color:var(--fg-mute);width:26px;height:26px;border-radius:6px;display:grid;place-items:center;background:none;border:none;font-size:16px;cursor:pointer}
.ai-o-close:hover{background:var(--ink-3);color:var(--fg);transform:none}
.ai-o-body{padding:18px 20px;max-height:340px;overflow:auto}
.ai-msg{margin-bottom:14px}
.ai-msg-label{font-family:var(--mono);font-size:10px;color:var(--fg-mute);letter-spacing:.14em;text-transform:uppercase;margin-bottom:5px}
.ai-msg-body{font-size:13px;color:var(--fg);line-height:1.6}
.ai-o-input-row{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:10px}
.ai-o-input{
  flex:1;background:var(--ink-2);border:1px solid var(--line);border-radius:10px;
  padding:10px 14px;font-size:13px;color:var(--fg);
}
.ai-o-send{padding:0 14px;border-radius:10px;background:var(--amethyst);color:#fff;display:grid;place-items:center;border:none}

/* ─── Legacy sidebar hidden ──────────────────────────── */
.sidebar{display:none}
.nav-sep{height:1px;background:var(--line);margin:.5rem .25rem}
.nav-lbl{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:.4rem .5rem .15rem}
.nbtn{display:flex;align-items:center;gap:.6rem;width:100%;text-align:left;padding:.55rem .65rem;border-radius:.5rem;border:1px solid transparent;background:transparent;font-size:.82rem;color:var(--ink);margin-bottom:.15rem}
.nbtn:hover{background:var(--panel2);transform:none}
.nbtn.active{background:var(--brand-l);border-color:rgba(39,196,123,.3);color:var(--brand);font-weight:600}
.nbtn .ni{width:1.1rem;text-align:center;font-size:.88rem;flex-shrink:0}
.nbtn .nc{flex:1}
.nbtn .nb{margin-left:auto;font-size:.65rem;font-weight:700;background:var(--bad);color:#fff;border-radius:999px;padding:.05rem .4rem;min-width:1.2rem;text-align:center}

/* Main */
.main{flex:1;overflow-y:auto;padding:1.25rem}
.section{display:none}
.section.active{display:block}

/* ─── Typography & Utilities ──────────────────────────────── */
.ph{font-size:1.05rem;font-weight:700;margin-bottom:.2rem}
.ps{font-size:.8rem;color:var(--muted);margin-bottom:1.2rem}

/* Buttons */
.btn{padding:.45rem .75rem;border-radius:.625rem;border:1px solid var(--line);background:var(--ink-2);font-size:.8rem;font-weight:500;color:var(--fg);display:inline-flex;align-items:center;gap:6px}
.btn:hover{background:var(--ink-3)}
.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:600}
.btn-primary:hover{background:var(--brand-d);border-color:var(--brand-d)}
.btn-ok{background:var(--ok);border-color:var(--ok);color:#fff;font-weight:600}
.btn-ok:hover{opacity:.9}
.btn-bad{background:var(--bad-l);border-color:rgba(239,68,68,.3);color:var(--bad);font-weight:600}
.btn-bad:hover{background:var(--bad);color:#fff}
.btn-warn{background:var(--warn-l);border-color:rgba(245,158,11,.3);color:var(--warn);font-weight:600}

/* Pills */
.pill{display:inline-flex;align-items:center;padding:.1rem .5rem;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.02em;gap:.25rem}
.pill-ok{background:var(--ok-l);color:#15803D}
.pill-bad{background:var(--bad-l);color:#DC2626}
.pill-warn{background:var(--warn-l);color:#92400E}
.pill-brand{background:var(--brand-l);color:var(--brand)}
.pill-gray{background:var(--panel2);color:var(--muted);border:1px solid var(--line)}
.pill-purple{background:var(--purple-l);color:var(--purple)}

/* KPI grid — legacy (still used in some sections) */
.kpi-row-legacy{display:grid;grid-template-columns:repeat(auto-fit,minmax(9rem,1fr));gap:.75rem;margin-bottom:1.25rem}

/* KPI strip — Dashboard redesign */
.kpi-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;margin:0 0 1.5rem;
  border:1px solid var(--line);border-radius:16px;overflow:hidden;
  background:var(--ink-1);
}
.kpi{
  padding:20px 22px;border-right:1px solid var(--line);
  position:relative;overflow:hidden;cursor:default;
}
.kpi:last-child{border-right:none}
.kpi-label{
  font-family:var(--mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--fg-mute);margin-bottom:10px;
}
.kpi .kv{
  font-family:var(--serif);font-size:42px;line-height:1;letter-spacing:-0.02em;
  color:var(--fg);font-weight:400;margin-bottom:6px;
}
.kpi .kl{font-size:.72rem;color:var(--fg-mute);margin-top:.1rem;display:none}
.kpi-delta{font-family:var(--mono);font-size:11px;color:var(--emerald);display:flex;align-items:center;gap:6px}
.kpi-delta.warn{color:var(--warn)}
.kpi-delta.bad{color:var(--bad)}
.kpi .spark{position:absolute;bottom:16px;right:18px;width:72px;height:24px;opacity:.75}
.kpi.k-warn .kv{color:var(--warn)}
.kpi.k-bad  .kv{color:var(--bad)}
.kpi.k-ok   .kv{color:var(--ok)}

/* Cards */
.card{background:var(--ink-1);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:1rem}
.card-hdr{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--line);gap:.5rem}
.card-hdr .cht{font-size:.85rem;font-weight:700;flex:1}
.card-acts{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
.card-body{padding:1rem}

/* Table */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.82rem}
thead th{padding:.5rem 1rem;text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--fg-mute);background:var(--ink-2);border-bottom:1px solid var(--line);white-space:nowrap}
tbody td{padding:.65rem 1rem;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:var(--ink-2);cursor:pointer}
tbody tr.selected td{background:var(--brand-l)}

/* Forms */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.form-grid.cols-1{grid-template-columns:1fr}
.form-grid.cols-3{grid-template-columns:1fr 1fr 1fr}
.fg{display:flex;flex-direction:column;gap:.2rem}
.fg.span2{grid-column:span 2}
.fg label{font-size:.72rem;font-weight:600;color:var(--muted)}
.fg input,.fg select,.fg textarea{padding:.5rem .75rem;border:1px solid var(--line);border-radius:.5rem;background:var(--ink-2);font-size:.83rem;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-l)}
.fg textarea{resize:vertical;min-height:4rem}
.fg .hint{font-size:.7rem;color:var(--muted)}
.req::after{content:" *";color:var(--bad)}

/* Search row */
.search-row{display:flex;gap:.5rem;margin-bottom:.875rem;align-items:center;flex-wrap:wrap}
.search-row input{flex:1;min-width:12rem;padding:.5rem .75rem;border:1px solid var(--line);border-radius:.5rem;background:var(--panel);font-size:.82rem}
.search-row input:focus{outline:none;border-color:var(--brand)}

/* Empty state */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;color:var(--muted);text-align:center;gap:.4rem}
.empty .ei{font-size:2.25rem;opacity:.35}
.empty .et{font-size:.9rem;font-weight:600;color:var(--ink)}
.empty .es{font-size:.78rem}

/* Master-detail */
.md{display:grid;grid-template-columns:minmax(18rem,26rem) 1fr;gap:1rem;align-items:start}
.md-master{background:var(--ink-1);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.md-list{display:flex;flex-direction:column;max-height:calc(100vh - 14rem);overflow-y:auto}
.md-item{display:block;width:100%;text-align:left;padding:.75rem;border:1px solid var(--line);border-radius:.625rem;background:var(--ink-2);cursor:pointer;transition:border-color .15s;margin-bottom:.35rem}
.md-item:hover{border-color:var(--emerald)}
.md-item.active{border-color:var(--emerald);background:var(--brand-l)}
.md-item .mi-name{font-weight:600;font-size:.88rem}
.md-item .mi-sub{font-size:.72rem;color:var(--fg-mute);margin-top:.2rem;display:flex;gap:.75rem;flex-wrap:wrap}
.md-detail{background:var(--ink-1);border:1px solid var(--line);border-radius:var(--r);min-height:20rem}

/* Detail sections */
.ds{padding:1rem;border-bottom:1px solid var(--line)}
.ds:last-child{border-bottom:none}
.ds-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);margin-bottom:.6rem;border-bottom:1px solid var(--line);padding-bottom:.35rem}
.dg{display:grid;grid-template-columns:1fr 1fr;gap:.5rem .75rem}
.dg.cols-3{grid-template-columns:repeat(3,1fr)}
.df{display:flex;flex-direction:column;gap:.1rem}
.df .dl{font-size:.7rem;color:var(--muted);font-weight:600}
.df .dv{font-size:.85rem;word-break:break-word}

/* Tabs */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--line);margin-bottom:1rem;}
.tab{padding:.55rem .875rem;border:none;background:transparent;font-size:.8rem;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;font-weight:500}
.tab.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:700}
.tab-pane{display:none}
.tab-pane.active{display:block}

/* Drawer */
.drawer-bg{position:fixed;inset:0;top:0;background:rgba(0,0,0,.55);z-index:200;opacity:0;pointer-events:none;transition:opacity .25s;backdrop-filter:blur(4px)}
.drawer-bg.open{opacity:1;pointer-events:all;display:block}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(56rem,90vw);background:var(--ink-1);border-left:1px solid var(--line);box-shadow:-1rem 0 3rem rgba(0,0,0,.4);z-index:201;display:flex;flex-direction:column;transform:translateX(105%);transition:transform .3s cubic-bezier(.22,1,.36,1)}
.drawer.open{transform:translateX(0)}
.drawer-hdr{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-bottom:1px solid var(--line);flex-shrink:0}
.drawer-hdr h3{font-size:1rem;margin:0;font-weight:700}
.drawer-close{background:transparent;border:none;font-size:1.2rem;color:var(--muted);line-height:1;padding:.2rem;cursor:pointer}
.drawer-body{flex:1;overflow-y:auto;padding:1.25rem}
.drawer-footer{padding:.75rem 1.25rem;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:.5rem;flex-shrink:0}

/* Toast */
#toastArea{position:fixed;bottom:1rem;right:1rem;z-index:500;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}
.toast{padding:.65rem 1rem;border-radius:.5rem;font-size:.82rem;font-weight:600;box-shadow:0 4px 16px rgba(0,0,0,.15);pointer-events:auto;display:flex;align-items:center;gap:.5rem;animation:toastIn .2s ease}
@keyframes toastIn{from{opacity:0;transform:translateY(.5rem)}to{opacity:1;transform:none}}
.toast-ok{background:var(--ok);color:#fff}
.toast-bad{background:var(--bad);color:#fff}
.toast-info{background:var(--brand);color:#fff}
.toast-warn{background:var(--warn);color:#fff}

/* Delegación toggle */
.deleg-row{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;border-bottom:1px solid var(--line)}
.deleg-row:last-child{border-bottom:none}
.davatar{width:2.25rem;height:2.25rem;border-radius:50%;background:var(--brand-l);color:var(--brand);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem;flex-shrink:0}
.dinfo{flex:1;min-width:0}
.dname{font-weight:700;font-size:.85rem}
.drole{font-size:.72rem;color:var(--muted)}
.toggle-wrap{display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:var(--muted);flex-shrink:0}
.sw{position:relative;width:2.75rem;height:1.5rem;flex-shrink:0}
.sw input{opacity:0;width:0;height:0;position:absolute}
.sw-track{position:absolute;inset:0;background:var(--line);border-radius:999px;transition:background .2s;cursor:pointer}
.sw input:checked~.sw-track{background:var(--brand)}
.sw-thumb{position:absolute;top:.2rem;left:.2rem;width:1.1rem;height:1.1rem;background:#fff;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:transform .2s;pointer-events:none}
.sw input:checked~.sw-thumb{transform:translateX(1.25rem)}

/* Agenda — toolbar y vistas */
.ag-toolbar{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;flex-wrap:wrap}
.ag-toolbar input[type=date]{padding:.4rem .65rem;border:1px solid var(--line);border-radius:.5rem;background:var(--panel);font-size:.82rem}
.ag-view-btns{display:flex;border:1px solid var(--line);border-radius:.5rem;overflow:hidden;background:var(--panel2)}
.ag-view-btns button{padding:.3rem .7rem;font-size:.75rem;font-weight:600;border:none;background:transparent;color:var(--muted);white-space:nowrap}
.ag-view-btns button.active{background:var(--brand);color:#fff}
.ag-day-label{font-size:.9rem;font-weight:700;flex:1;color:var(--ink)}
/* Vista dia */
.slot-row{display:flex;align-items:stretch;gap:0;margin-bottom:.35rem}
.slot-time{width:4rem;flex-shrink:0;font-size:.72rem;color:var(--muted);padding:.65rem 0;font-variant-numeric:tabular-nums}
.slot-card{flex:1;border-left:3px solid;padding:.5rem .75rem;border-radius:0 .5rem .5rem 0;background:var(--panel);border-top:1px solid var(--line);border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.slot-card.st-AGENDADA{border-left-color:var(--warn)}
.slot-card.st-CONFIRMADA{border-left-color:var(--brand)}
.slot-card.st-EN_ATENCION{border-left-color:var(--ok)}
.slot-card.st-ATENDIDA{border-left-color:var(--muted)}
.slot-card.st-CANCELADA,.slot-card.st-NO_ASISTIO{border-left-color:var(--bad);opacity:.55}
.slot-name{font-weight:700;font-size:.84rem}
.slot-meta{font-size:.72rem;color:var(--muted);margin-top:.1rem}
.slot-acts{display:flex;gap:.3rem;margin-top:.4rem;flex-wrap:wrap}
.slot-acts button{padding:.2rem .5rem;font-size:.7rem;border-radius:.35rem;border:1px solid var(--line);background:transparent;color:var(--muted)}
.slot-acts button:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-l)}
.slot-acts button.btn-confirm{border-color:rgba(39,196,123,.3);color:var(--brand);background:var(--brand-l)}
.slot-acts button.btn-atender{border-color:rgba(34,197,94,.3);color:#15803D;background:var(--ok-l)}
.slot-acts button.btn-cancel{border-color:rgba(239,68,68,.3);color:var(--bad);background:var(--bad-l)}
/* Vista semana — grid de columnas */
.week-grid{display:grid;gap:.5rem;overflow-x:auto;min-height:6rem}
.week-grid.wg-7{grid-template-columns:repeat(7,minmax(9rem,1fr))}
.week-grid.wg-5{grid-template-columns:repeat(5,minmax(9.5rem,1fr))}
.wg-col{background:var(--panel);border:1px solid var(--line);border-radius:.5rem;min-height:6rem;display:flex;flex-direction:column}
.wg-col-hdr{padding:.45rem .6rem;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:.05rem}
.wg-col-hdr .wg-dow{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.wg-col-hdr .wg-date{font-size:.88rem;font-weight:800;color:var(--ink)}
.wg-col-hdr.today{background:var(--brand-l);border-bottom-color:var(--brand)}
.wg-col-hdr.today .wg-date{color:var(--brand)}
.wg-col-body{flex:1;padding:.35rem .4rem;display:flex;flex-direction:column;gap:.3rem}
.wg-chip{border-left:3px solid var(--warn);border-radius:0 .4rem .4rem 0;background:var(--panel2);padding:.28rem .45rem;font-size:.68rem;cursor:pointer;transition:box-shadow .15s}
.wg-chip:hover{box-shadow:0 1px 6px rgba(0,0,0,.1)}
.wg-chip.st-AGENDADA{border-left-color:var(--warn)}
.wg-chip.st-CONFIRMADA{border-left-color:var(--brand);background:var(--brand-l)}
.wg-chip.st-EN_ATENCION{border-left-color:var(--ok);background:var(--ok-l)}
.wg-chip.st-ATENDIDA{border-left-color:var(--muted);opacity:.65}
.wg-chip.st-CANCELADA,.wg-chip.st-NO_ASISTIO{border-left-color:var(--bad);opacity:.45}
.wg-chip-time{color:var(--muted);font-size:.64rem;font-variant-numeric:tabular-nums}
.wg-chip-name{font-weight:700;margin-top:.05rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.wg-chip-meta{color:var(--muted);margin-top:.02rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wg-empty{color:var(--muted);font-size:.7rem;text-align:center;padding:.75rem .5rem;opacity:.7}

/* Historia tabs */
.htabs{display:flex;gap:0;overflow-x:auto;border-bottom:1px solid var(--line);margin-bottom:1rem;flex-shrink:0}
.htab{padding:.45rem .7rem;border:none;background:transparent;font-size:.76rem;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap}
.htab.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:700}

/* Responsive */
@media(max-width:900px){.md{grid-template-columns:1fr}.md-master{max-height:14rem}}
@media(max-width:700px){.sidebar{display:none}.form-grid{grid-template-columns:1fr}}

/* ─── Drawer ancho (paciente) ────────────────────── */
.drawer-wide{width:min(72rem,90vw)}

/* ─── Consultation Workspace Overlay ───────────────── */
#consultOverlay{position:fixed;inset:0;z-index:300;background:var(--bg);display:none;flex-direction:column;overflow:hidden}
#consultOverlay.open{display:flex}
.co-bar{height:3.5rem;background:var(--panel);border-bottom:2px solid var(--line);display:flex;align-items:center;padding:0 1.1rem;gap:.75rem;flex-shrink:0;box-shadow:0 1px 6px rgba(0,0,0,.06)}
.co-logo{font-size:.68rem;font-weight:800;color:var(--brand);letter-spacing:.04em;padding:.18rem .45rem;background:var(--brand-l);border-radius:.3rem;flex-shrink:0;white-space:nowrap}
.co-pacinfo{flex:1;min-width:0}
.co-pacname{font-size:.9rem;font-weight:800;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.co-pacsub{font-size:.68rem;color:var(--muted)}
.co-body{flex:1;display:flex;min-height:0}
.co-left{width:20rem;flex-shrink:0;border-right:1px solid var(--line);overflow-y:auto;background:var(--panel)}
.co-right{flex:1;overflow-y:auto;padding:1.35rem 1.5rem;background:var(--bg)}
.co-sect{padding:.825rem 1rem;border-bottom:1px solid var(--line)}
.co-sect:last-child{border-bottom:none}
.co-sect-hd{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:.6rem;display:flex;justify-content:space-between;align-items:center}
.vitals-grid{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}
.vf{display:flex;flex-direction:column;gap:.18rem}
.vf label{font-size:.64rem;font-weight:600;color:var(--muted)}
.vf input{padding:.36rem .45rem;border:1px solid var(--line);border-radius:.38rem;background:var(--panel2);font-size:.78rem;width:100%;text-align:center}
.vf input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-l)}
.dx-item{display:flex;align-items:flex-start;gap:.4rem;padding:.42rem .55rem;background:var(--panel2);border:1px solid var(--line);border-radius:.38rem;margin-bottom:.28rem}
.dx-body{flex:1;min-width:0}
.dx-code{font-size:.67rem;font-weight:700;color:var(--brand)}
.dx-desc{font-size:.76rem;margin-top:.08rem;word-break:break-word}
.dx-tipo{font-size:.63rem;color:var(--muted);margin-top:.08rem}
.dx-princ{font-size:.6rem;font-weight:700;background:var(--ok-l);color:#15803D;padding:.04rem .3rem;border-radius:999px;vertical-align:middle;margin-left:.3rem}
.dx-rm{background:none;border:none;color:var(--line);padding:.1rem;border-radius:.25rem;font-size:.72rem;flex-shrink:0;cursor:pointer;line-height:1}
.dx-rm:hover{color:var(--bad);background:var(--bad-l)}
.dx-add-form{background:var(--panel2);border:1px solid var(--line);border-radius:.42rem;padding:.55rem;margin-top:.4rem}
.dx-add-row{display:flex;gap:.3rem;margin-bottom:.3rem}
.dx-add-row input{flex:1;padding:.35rem .45rem;border:1px solid var(--line);border-radius:.32rem;background:var(--panel);font-size:.74rem}

/* ─── CIE-10 autocomplete ────────────────────────────────── */
.cie-wrap{position:relative}
.cie-input{width:100%;padding:.38rem .45rem;border:1px solid var(--line);border-radius:.32rem;background:var(--panel);font-size:.74rem;color:var(--fg)}
.cie-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-l)}
.cie-dropdown{
  position:fixed;z-index:9999;
  background:var(--ink-1);border:1px solid var(--line-2);border-radius:.5rem;
  box-shadow:0 8px 28px rgba(0,0,0,.5);overflow:hidden;display:none;
  max-height:220px;overflow-y:auto;min-width:220px;
}
.cie-dropdown.open{display:block}
.cie-opt{
  display:flex;align-items:baseline;gap:.5rem;
  padding:.42rem .65rem;cursor:pointer;transition:background .1s;font-size:.74rem;
}
.cie-opt:hover,.cie-opt.active{background:rgba(39,196,123,.08)}
.cie-code{font-family:var(--mono);font-size:.68rem;font-weight:700;color:var(--brand);flex-shrink:0;min-width:4rem}
.cie-desc{color:var(--fg);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cie-loading{padding:.5rem .65rem;font-size:.72rem;color:var(--fg-mute);font-style:italic}
.cie-badge{display:none;align-items:center;gap:.4rem;padding:.3rem .5rem;background:rgba(39,196,123,.1);border:1px solid rgba(39,196,123,.3);border-radius:.3rem;font-size:.72rem;margin-bottom:.3rem}
.cie-badge.show{display:flex}
.cie-badge-code{font-family:var(--mono);font-weight:700;color:var(--brand)}
.cie-badge-desc{color:var(--fg-dim);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cie-badge-clear{color:var(--fg-mute);cursor:pointer;font-size:.9rem;flex-shrink:0;line-height:1}
.cie-badge-clear:hover{color:var(--bad)}
.soap-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:1.25rem;max-width:54rem;margin:0 auto}
.soap-title{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:1.1rem}
.soap-f{display:flex;flex-direction:column;gap:.28rem;margin-bottom:.9rem}
.soap-f label{font-size:.72rem;font-weight:600;color:var(--muted)}
.soap-f textarea{padding:.52rem .65rem;border:1px solid var(--line);border-radius:.42rem;background:var(--panel2);font-size:.82rem;resize:vertical;min-height:3.2rem;width:100%;line-height:1.55}
.soap-f textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-l)}
.soap-f select,.soap-f input[type=number],.soap-f input[type=text]{padding:.48rem .65rem;border:1px solid var(--line);border-radius:.42rem;background:var(--panel2);font-size:.82rem}
.soap-f select:focus,.soap-f input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-l)}
.co-foot{padding:.7rem 1.1rem;background:var(--panel);border-top:1px solid var(--line);display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.co-foot-status{flex:1;font-size:.73rem;color:var(--muted);display:flex;align-items:center;gap:.38rem}
.co-dot{width:.42rem;height:.42rem;border-radius:50%;background:var(--muted);display:inline-block;flex-shrink:0}
.co-dot.ok{background:var(--ok)}
.co-dot.saving{background:var(--warn);animation:coPulse .9s infinite}
@keyframes coPulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ─── Dashboard Hero ─────────────────────────────────────── */
.dash-hero{
  padding:36px 28px 0;
  display:grid;grid-template-columns:1.2fr 1fr;gap:28px;align-items:end;
}
.hero-eyebrow{
  font-family:var(--mono);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--emerald);display:flex;align-items:center;gap:10px;margin-bottom:14px;
}
.hero-eyebrow::before{content:"";width:24px;height:1px;background:var(--emerald)}
.hero-title{
  font-family:var(--serif);font-size:clamp(42px,4.5vw,72px);line-height:.96;
  letter-spacing:-0.02em;font-weight:400;color:var(--fg);margin:0 0 10px;
}
.hero-title i{color:var(--emerald);font-style:italic}
.hero-title .am{color:var(--amethyst-2);font-style:italic}
.hero-sub{color:var(--fg-dim);font-size:15px;max-width:480px;line-height:1.55;margin-bottom:8px}
.hero-sub b{color:var(--fg);font-weight:500}
.hero-kalkora{
  font-family:var(--mono);font-size:10px;letter-spacing:0.24em;text-transform:uppercase;
  color:var(--fg-mute);display:flex;align-items:center;gap:8px;margin-top:14px;
}
.hero-kalkora::before{content:"";width:14px;height:1px;background:var(--line-2)}
.hero-right{display:flex;flex-direction:column;gap:14px;align-items:flex-end}
.hero-pill-row{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.hero-pill{
  padding:7px 13px;border-radius:999px;border:1px solid var(--line);background:var(--ink-2);
  font-family:var(--mono);font-size:11px;letter-spacing:0.05em;text-transform:uppercase;
  color:var(--fg-dim);display:flex;align-items:center;gap:8px;
}
.hero-pill.em{color:var(--emerald);border-color:rgba(39,196,123,.35);background:rgba(39,196,123,.08)}
.hero-pill.am{color:var(--warn);border-color:rgba(245,180,84,.35);background:rgba(245,180,84,.08)}
.hero-pill .dot{width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor}

/* Dashboard body grid */
.dash-body{display:grid;grid-template-columns:1fr 340px;gap:20px;padding:24px 28px 32px}
@media(max-width:1100px){.dash-body{grid-template-columns:1fr}.dash-hero{grid-template-columns:1fr}}

/* ─── Agenda card ─────────────────────────────────────────── */
.agenda-card{background:var(--ink-1);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.agenda-head{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--line);gap:14px}
.agenda-title{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--fg);margin:0}
.agenda-date-lbl{font-family:var(--mono);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-mute)}
.agenda-prog{flex:1;max-width:200px;height:5px;border-radius:3px;background:var(--ink-3);overflow:hidden}
.agenda-prog-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--emerald),var(--emerald-2));box-shadow:0 0 10px rgba(39,196,123,.5)}
.agenda-prog-lbl{font-family:var(--mono);font-size:11px;color:var(--fg);white-space:nowrap}
.agenda-prog-lbl b{color:var(--emerald)}
.agenda-more{padding:10px 20px;border-top:1px solid var(--line);text-align:center}
.agenda-more a{font-family:var(--mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--emerald)}
.agenda-more a:hover{color:var(--emerald-2)}

/* Slot rows in dashboard agenda card */
.slot-dash{
  display:grid;grid-template-columns:72px 10px 1fr auto;gap:14px;
  padding:13px 20px;border-bottom:1px solid var(--line);
  align-items:center;cursor:pointer;transition:background .13s;position:relative;
}
.slot-dash:last-child{border-bottom:none}
.slot-dash:hover{background:rgba(39,196,123,.03)}
.slot-dash.sl-active{background:linear-gradient(90deg,rgba(39,196,123,.07),transparent 70%)}
.slot-dash.sl-active::before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:3px;border-radius:2px;background:var(--emerald);box-shadow:0 0 10px var(--emerald)}
.slot-dash.sl-done{opacity:.55}
.slot-dash.sl-canc{opacity:.5;background:rgba(240,107,107,.04)}
.slot-dash.sl-canc .slot-name{text-decoration:line-through;text-decoration-color:var(--bad);text-decoration-thickness:1px}
.slot-dash.sl-noasis{opacity:.55;background:rgba(245,180,84,.03)}
.slot-dash.sl-attn{background:rgba(245,180,84,.05)}
.slot-time{font-family:var(--mono);font-size:12px;color:var(--fg-mute);letter-spacing:.03em}
.slot-dot{width:8px;height:8px;border-radius:50%;background:var(--line-2)}
.slot-dot.em{background:var(--emerald);box-shadow:0 0 8px var(--emerald)}
.slot-dot.am{background:var(--warn);box-shadow:0 0 8px var(--warn)}
.slot-dot.warn{background:var(--warn);box-shadow:0 0 8px var(--warn)}
.slot-dot.bad{background:var(--bad);box-shadow:0 0 8px var(--bad)}
.slot-dot.done{background:var(--fg-mute)}
.slot-info{min-width:0}
.slot-name{font-size:14px;font-weight:600;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.slot-motive{font-size:12px;color:var(--fg-mute);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.slot-cta{flex-shrink:0}
.slot-cta .btn-em{padding:6px 12px;border-radius:8px;background:var(--emerald);color:#fff;font-size:11px;font-weight:600;box-shadow:0 4px 12px rgba(39,196,123,.3)}
.slot-cta .btn-ghost{padding:6px 12px;border-radius:8px;border:1px solid var(--line);color:var(--fg-dim);font-size:11px;font-weight:500}
.slot-cta .btn-ghost:hover{border-color:var(--line-2);color:var(--fg)}
.slot-cta .btn-warn{padding:6px 12px;border-radius:8px;border:1px solid rgba(245,180,84,.4);color:var(--warn);font-size:11px;background:rgba(245,180,84,.08)}
.slot-cta .btn-done{color:var(--fg-mute);font-size:11px;font-family:var(--mono)}

/* ─── Dashboard sidebar panels ──────────────────────────── */
.dash-sidebar{display:flex;flex-direction:column;gap:16px}
.ds-panel{background:var(--ink-1);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.ds-panel-head{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}
.ds-panel-title{font-size:13px;font-weight:600;color:var(--fg);margin:0}
.ds-panel-badge{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-mute);margin-left:auto}
.ds-panel-body{padding:16px 18px}

/* Next patient panel */
.nxt-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(140deg,var(--amethyst-deep),var(--amethyst));display:grid;place-items:center;font-family:var(--serif);font-size:18px;font-weight:700;color:#fff;box-shadow:0 6px 18px rgba(122,43,196,.28);flex-shrink:0}
.nxt-meta{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-mute);margin-top:4px}
.nxt-chief{font-size:13px;color:var(--fg-dim);margin-top:10px;line-height:1.5}
.nxt-cov{margin-top:8px}

/* AI insight panel */
.ai-panel{background:linear-gradient(135deg,rgba(122,43,196,.14),rgba(122,43,196,.04));border-color:rgba(122,43,196,.3)!important}
.ai-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--amethyst-2);display:flex;align-items:center;gap:6px;margin-bottom:10px}
.ai-insight{font-size:13px;color:var(--fg-dim);line-height:1.6}
.ai-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.ai-chip{padding:4px 10px;border-radius:6px;background:rgba(122,43,196,.15);border:1px solid rgba(122,43,196,.3);font-family:var(--mono);font-size:11px;color:var(--amethyst-2)}
.ai-cta-btn{margin-top:12px;padding:8px 14px;border-radius:8px;border:1px solid rgba(122,43,196,.4);color:var(--amethyst-2);font-size:12px;font-weight:600;background:transparent;width:100%;font-family:var(--mono);letter-spacing:.04em}
.ai-cta-btn:hover{background:rgba(122,43,196,.1);transform:none}

/* ─── Modal ad-hoc (cancelar / reagendar cita) ───────────────── */
.modal-backdrop{position:fixed;inset:0;background:rgba(5,7,10,.65);display:flex;align-items:center;justify-content:center;z-index:9000;padding:1rem}
.modal-box{background:var(--ink-1);border:1px solid var(--line);border-radius:1rem;padding:1.25rem;width:100%;max-width:28rem;box-shadow:0 20px 60px rgba(0,0,0,.5)}
html[data-theme="light"] .modal-box{background:#fff}
