/* ===== BLOQUE CSS 1 ===== */

:root{
  --ink:#0d1b2a;--ink2:#2c3e50;--ink3:#5a7080;
  --bg:#f5f3ee;--bg2:#ede9e0;--bg3:#fff;
  --accent:#1a5276;--accent2:#2e86c1;--accent-lt:#d6eaf8;
  --green:#1e8449;--green-lt:#d5f5e3;
  --red:#c0392b;--red-lt:#fde8e8;
  --amber:#b7950b;--amber-lt:#fef9e7;
  --orange:#d35400;--orange-lt:#fdebd0;
  --purple:#6c3483;--purple-lt:#e8daef;
  --border:#d5cfc4;--border2:#c5bfb4;
  --radius:10px;--radius2:6px;
  --shadow:0 2px 12px rgba(13,27,42,.08),0 1px 3px rgba(13,27,42,.05);
  --shadow2:0 8px 32px rgba(13,27,42,.12),0 2px 8px rgba(13,27,42,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--ink);min-height:100vh;overflow-x:hidden}
/* ── Reglas globales por rol ── */
body.role-asistente .medico-only,
body.role-asistente .tb-medico-only{display:none !important}
body.role-medico .asistente-only{display:none !important}
body.role-asistente .asistente-only{display:block !important}
/* Modo solo-lectura para asistente: deshabilita inputs, labels-action y oculta acciones */
body.role-asistente .readonly-asistente input,
body.role-asistente .readonly-asistente textarea,
body.role-asistente .readonly-asistente select,
body.role-asistente .readonly-asistente label.btn,
body.role-asistente .readonly-asistente button:not(.btn-icon-readonly){
  pointer-events:none;opacity:.65;cursor:not-allowed
}
body.role-asistente .readonly-asistente .hide-readonly{display:none !important}
/* Áreas exclusivas del titular (owner / médico individual): ocultas para
   médico invitado (miembro) y asistente. */
body:not(.acceso-titular) .solo-titular{display:none !important}
.serif{font-family:'DM Serif Display',serif}
.mono{font-family:'JetBrains Mono',monospace}
button{cursor:pointer;font-family:'DM Sans',sans-serif}
input,select,textarea{font-family:'DM Sans',sans-serif}

/* -- LAYOUT -- */
.app{display:flex;min-height:100vh}
#sidebar{width:224px;flex-shrink:0;background:var(--ink);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;overflow-y:auto}
#sidebar .brand{padding:22px 20px 18px;border-bottom:1px solid rgba(255,255,255,.08)}
#sidebar .brand .logo{font-family:'DM Serif Display',serif;font-size:1.25rem;color:#fff;line-height:1.1}
#sidebar .brand .logo span{color:#5dade2}
#sidebar .brand .nom{font-size:.59rem;color:rgba(255,255,255,.28);letter-spacing:.12em;margin-top:3px}
.brand-logo-img{display:block;width:100%;height:auto;border-radius:8px;box-shadow:0 10px 24px rgba(0,0,0,.18)}
.login-logo-img{display:block;width:245px;max-width:100%;height:auto;margin:0 auto 15px;border-radius:9px;box-shadow:0 12px 32px rgba(13,27,42,.16)}
#sidebar nav{padding:14px 0;flex:1}
.nav-grp-lbl{font-size:.59rem;letter-spacing:.18em;color:rgba(255,255,255,.22);padding:8px 20px 3px;text-transform:uppercase}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 20px;font-size:.82rem;color:rgba(255,255,255,.55);cursor:pointer;transition:all .18s;border-left:2px solid transparent}
.nav-item:hover{background:rgba(255,255,255,.05);color:#fff}
.nav-item.active{background:rgba(93,173,226,.12);color:#5dade2;border-left-color:#5dade2}
.nav-item .ni{width:16px;text-align:center;font-size:.88rem}
#sidebar .sb-footer{padding:14px 20px;border-top:1px solid rgba(255,255,255,.08)}
#sidebar .sb-footer .dr-name{font-size:.8rem;color:rgba(255,255,255,.7);font-weight:500}
#sidebar .sb-footer .dr-sub{font-size:.67rem;color:rgba(255,255,255,.28);margin-top:2px}
#main{margin-left:224px;flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh}
#topbar{background:var(--bg3);border-bottom:1px solid var(--border);padding:12px 28px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
#topbar .pt{font-size:.94rem;font-weight:600;color:var(--ink)}
#content{padding:22px 28px;flex:1;min-width:0}

/* -- BUTTONS -- */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 15px;border-radius:var(--radius2);font-size:.81rem;font-weight:500;border:none;transition:all .18s;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent2)}
.btn-secondary{background:transparent;border:1px solid var(--border2);color:var(--ink2)}.btn-secondary:hover{background:var(--bg2)}
.btn-green{background:var(--green);color:#fff}.btn-green:hover{background:#17713e}
.btn-red{background:var(--red);color:#fff}.btn-red:hover{background:#a93226}
.btn-amber{background:var(--amber);color:#fff}.btn-amber:hover{background:#9e8209}
.btn-sm{padding:5px 10px;font-size:.76rem}
.btn-icon{width:30px;height:30px;padding:0;border-radius:6px;justify-content:center;background:transparent;border:1px solid var(--border);color:var(--ink3)}.btn-icon:hover{background:var(--bg2);color:var(--ink)}
.full-w{width:100%}

/* -- CARDS -- */
.card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}

/* === UPGRADE CARDS === */
.upgrade-plan-card{background:var(--bg3);border:1.5px solid var(--border);border-radius:12px;padding:22px 18px;display:flex;flex-direction:column;gap:8px;position:relative;transition:transform .2s,border-color .2s,box-shadow .2s}
.upgrade-plan-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 8px 24px rgba(46,134,193,.18)}
.upgrade-plan-card.current{border-color:var(--green);background:rgba(39,174,96,.06)}
.upgrade-plan-card .upg-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:.66rem;font-weight:700;padding:3px 10px;border-radius:10px;letter-spacing:.04em;text-transform:uppercase}
.upgrade-plan-card .upg-icon{font-size:2rem;margin-bottom:4px}
.upgrade-plan-card .upg-name{font-weight:700;font-size:1.05rem;color:var(--ink)}
.upgrade-plan-card .upg-price{font-size:1.45rem;font-weight:700;color:var(--ink);margin:6px 0 8px;font-family:'DM Serif Display',serif}
.upgrade-plan-card .upg-feature{font-size:.8rem;color:var(--ink2);padding:4px 0;border-bottom:1px dashed var(--border)}
.upgrade-plan-card .upg-feature:last-of-type{border-bottom:none;margin-bottom:8px}
.upgrade-plan-card .upg-btn{margin-top:auto;width:100%;justify-content:center}
.card-sm{padding:13px}
.ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.ct{font-size:.89rem;font-weight:600;color:var(--ink)}

/* -- FORMS -- */
.fg{display:flex;flex-direction:column;gap:4px}
.fl{font-size:.75rem;font-weight:500;color:var(--ink2)}
.fl .req{color:var(--red)}
.fi{padding:7px 10px;border:1px solid var(--border2);border-radius:var(--radius2);font-size:.83rem;color:var(--ink);background:var(--bg3);transition:border-color .18s,box-shadow .18s;outline:none}
.fi:focus{border-color:var(--accent2);box-shadow:0 0 0 3px rgba(46,134,193,.1)}
.fi-sel{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%235a7080'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;padding-right:26px}
textarea.fi{resize:vertical;min-height:66px}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.fg3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:11px}
.fg4{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}

/* -- ALERTA SOMATOMETRÍA -- */
.soma-alert{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 9px;border-radius:20px;font-size:.72rem;font-weight:600;
  margin-top:4px;
}
.soma-normal{background:var(--green-lt);color:var(--green)}
.soma-warn{background:var(--amber-lt);color:var(--amber)}
.soma-danger{background:var(--red-lt);color:var(--red)}
.soma-info{background:var(--accent-lt);color:var(--accent)}
.soma-panel{
  background:var(--bg);border:1px solid var(--border);
  border-radius:10px;padding:14px 16px;margin-top:14px;
}
.soma-panel-title{font-size:.74rem;font-weight:600;color:var(--ink3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.soma-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border)}
.soma-row:last-child{border-bottom:none}
.soma-label{font-size:.8rem;color:var(--ink2)}
.soma-value{font-size:.8rem;font-weight:600;color:var(--ink)}

/* -- TABLE -- */
.tbl-wrap{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:.71rem;font-weight:600;color:var(--ink3);letter-spacing:.06em;text-transform:uppercase;padding:8px 11px;border-bottom:2px solid var(--border);background:var(--bg)}
.tbl td{padding:9px 11px;font-size:.82rem;border-bottom:1px solid var(--border);color:var(--ink2);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--bg)}

/* -- BADGES -- */
.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:20px;font-size:.69rem;font-weight:600}
.bd-blue{background:var(--accent-lt);color:var(--accent)}
.bd-green{background:var(--green-lt);color:var(--green)}
.bd-red{background:var(--red-lt);color:var(--red)}
.bd-amber{background:var(--amber-lt);color:var(--amber)}
.bd-orange{background:var(--orange-lt);color:var(--orange)}
.bd-purple{background:var(--purple-lt);color:var(--purple)}

/* -- MODALS -- */
.modal-bg{position:fixed;inset:0;background:rgba(13,27,42,.52);z-index:500;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity .2s}
.modal-bg.open{opacity:1;pointer-events:auto}
.modal{background:var(--bg3);border-radius:14px;box-shadow:var(--shadow2);width:92%;max-width:800px;max-height:90vh;overflow-y:auto;transform:translateY(14px);transition:transform .22s}
.modal-bg.open .modal{transform:translateY(0)}
.modal-xl{max-width:1060px}
.mh{padding:17px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--bg3);z-index:2}
.mh-title{font-size:.93rem;font-weight:600}
.mb{padding:20px}
.mf{padding:13px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;position:sticky;bottom:0;background:var(--bg3)}
.xbtn{background:none;border:none;font-size:1.1rem;color:var(--ink3);cursor:pointer;padding:3px}.xbtn:hover{color:var(--ink)}

/* -- SECTION NOM -- */
.snom{border-left:3px solid var(--accent);padding-left:12px;margin-bottom:18px}
.snom-lbl{font-size:.64rem;letter-spacing:.14em;color:var(--accent);text-transform:uppercase;font-weight:600;margin-bottom:3px}
.snom-title{font-size:.88rem;font-weight:600;color:var(--ink);margin-bottom:10px}

/* -- STATS -- */
.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:13px;margin-bottom:20px}
.stat-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:15px 17px;display:flex;align-items:flex-start;gap:12px;min-width:0}
.stat-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0}
.stat-val{font-size:1.45rem;font-weight:700;line-height:1;color:var(--ink)}
.stat-lbl{font-size:.7rem;color:var(--ink3);margin-top:2px}

/* Top 10 dx/meds: las cards son grid items; sin min-width:0 el track se
   expande con el texto largo y el ellipsis del diagnóstico nunca dispara. */
.ana-cli-2col>.card{min-width:0}

/* ════ DESKTOP NORMAL/iMac — 1400-1700px: 3 KPI columns + 2 cols análisis ════ */
@media (max-width:1700px){
  .stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}

/* -- TABS -- */
.tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:16px}
.tab-btn{padding:7px 15px;font-size:.81rem;font-weight:500;background:none;border:none;color:var(--ink3);cursor:pointer;position:relative;transition:color .16s}
.tab-btn.active{color:var(--accent)}
.tab-btn.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--accent)}
.tab-panel{display:none}.tab-panel.active{display:block}

/* -- TIMELINE -- */
.timeline{position:relative;padding-left:24px}
.timeline::before{content:'';position:absolute;left:7px;top:0;bottom:0;width:2px;background:var(--border)}
.tl-item{position:relative;margin-bottom:16px}
.tl-dot{position:absolute;left:-21px;top:3px;width:10px;height:10px;border-radius:50%;background:var(--accent);border:2px solid var(--bg3);box-shadow:0 0 0 2px var(--accent)}
.tl-date{font-size:.69rem;color:var(--ink3);margin-bottom:3px;font-family:'JetBrains Mono',monospace}

/* -- AUTOCOMPLETE -- */
.ac-wrap{position:relative}
.ac-list{position:absolute;top:100%;left:0;right:0;z-index:300;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius2);box-shadow:var(--shadow2);max-height:210px;overflow-y:auto;display:none}
.ac-item{padding:7px 10px;font-size:.8rem;cursor:pointer;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border)}
.ac-item:last-child{border-bottom:none}
.ac-item:hover{background:var(--accent-lt)}
.ac-code{font-family:'JetBrains Mono',monospace;font-size:.69rem;color:var(--accent);flex-shrink:0;min-width:56px}

/* -- VIEWS -- */
.view{display:none}.view.active{display:block}

/* -- LOGIN -- */
#login-screen{position:fixed;inset:0;background:var(--ink);display:flex;align-items:center;justify-content:center;z-index:1000}
#login-screen.hidden{display:none}
.login-box{position:relative;z-index:3;overflow:hidden;background:#042C53;border:1px solid rgba(133,183,235,.28);border-radius:16px;padding:34px 38px;width:380px;box-shadow:0 24px 60px rgba(4,44,83,.34),0 0 0 1px rgba(55,138,221,.08);opacity:0;transform:translateY(12px) scale(.98);animation:loginReveal .8s ease 4.45s forwards}
.login-box::before{content:'';position:absolute;inset:0;border-radius:16px;background:radial-gradient(circle at 85% 15%,rgba(55,138,221,.18),transparent 38%);pointer-events:none}
.login-box>*{position:relative}
.login-logo{font-family:'DM Serif Display',serif;font-size:1.75rem;color:var(--accent);text-align:center}
.login-logo span{color:#2e86c1}
.login-box > :not(.login-logo){opacity:0;transform:translateY(8px);animation:formReveal .55s ease 5s forwards}
#lt-login,#lt-reg,#lt-priv{opacity:1!important;transform:none!important;animation:none!important}
.login-nom{font-size:.67rem;color:rgba(133,183,235,.82);letter-spacing:.1em;margin-bottom:24px;text-align:center}
.login-tabs{display:flex;border-bottom:2px solid rgba(133,183,235,.2);margin-bottom:20px}
#login-screen .tab-btn{color:rgba(255,255,255,.64)}
#login-screen .tab-btn.active{color:#85B7EB}
#login-screen .tab-btn.active::after{background:#378ADD}
#login-screen .fl{color:rgba(255,255,255,.78)}
#login-screen .fi{background:rgba(255,255,255,.08);border-color:rgba(133,183,235,.26);color:#fff}
#login-screen .fi::placeholder{color:rgba(255,255,255,.48)}
#login-screen .fi:focus{border-color:#85B7EB;box-shadow:0 0 0 3px rgba(55,138,221,.18)}
#login-screen .btn-primary{background:#185FA5}
#login-screen .btn-primary:hover{background:#378ADD}
#login-screen .btn-secondary{border-color:rgba(133,183,235,.32);color:#d6eaf8;background:rgba(255,255,255,.05)}
#login-screen .btn-secondary:hover{background:rgba(55,138,221,.16)}
#login-screen #sb-alert{background:rgba(183,149,11,.14)!important;border-color:rgba(254,249,231,.36)!important;color:#f7dc6f!important}
.login-intro{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,rgba(46,134,193,.2) 0,rgba(13,27,42,.96) 34%,var(--ink) 72%);pointer-events:none;animation:introLayer 2.75s ease forwards;z-index:1}
.login-brand-intro{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,rgba(55,138,221,.18) 0,rgba(4,44,83,.98) 42%,var(--ink) 76%);opacity:0;pointer-events:none;z-index:2;animation:brandLayer 99s ease 0s forwards}
.brand-intro-wordmark{font-family:'DM Serif Display',serif;text-align:center;line-height:.92;letter-spacing:.08em;text-shadow:0 0 22px rgba(133,183,235,.34),0 18px 46px rgba(0,0,0,.28);transform:scale(.6);animation:brandWordReveal 1.9s cubic-bezier(.2,.8,.2,1) 2.65s forwards}
.brand-intro-wordmark .medyra{display:block;color:#fff;font-size:3rem}
.brand-intro-wordmark .care{display:block;color:#378ADD;font-size:2.82rem;margin-top:8px}
.brand-intro-wordmark .tagline{display:block;margin-top:17px;font-family:'DM Sans',sans-serif;color:#85B7EB;font-size:.62rem;font-weight:600;letter-spacing:.34em;text-transform:uppercase;opacity:.72}
.brand-intro-wordmark .rule{display:block;width:210px;height:1px;background:linear-gradient(90deg,transparent,#378ADD,transparent);margin:13px auto 0;opacity:.65}
.intro-mark{position:relative;width:104px;height:180px;display:flex;align-items:center;justify-content:center;animation:introMark 2.35s cubic-bezier(.2,.8,.2,1) forwards}
.intro-mark::before,.intro-mark::after{content:'';position:absolute;inset:18px -20px;border:1px solid rgba(133,183,235,.26);border-radius:30px;opacity:0;animation:introRing 2.2s ease forwards}
.intro-mark::after{animation-delay:.22s}
.intro-icon{width:104px;height:180px;filter:drop-shadow(0 18px 32px rgba(55,138,221,.22))}
.intro-icon .doc{animation:docGlow 1.8s ease-in-out forwards}
.intro-icon .ecg{stroke-dasharray:130;stroke-dashoffset:130;animation:ecgDraw .9s ease .38s forwards}
@keyframes introLayer{0%,78%{opacity:1}100%{opacity:0;visibility:hidden}}
@keyframes introMark{0%{opacity:0;transform:translateY(18px) scale(.72)}18%{opacity:1;transform:translateY(0) scale(1)}58%{opacity:1;transform:scale(1.06)}100%{opacity:0;transform:scale(5.2)}}
@keyframes introRing{12%{opacity:0;transform:scale(.74)}38%{opacity:.55}100%{opacity:0;transform:scale(2.5)}}
@keyframes ecgDraw{to{stroke-dashoffset:0}}
@keyframes docGlow{0%,100%{filter:drop-shadow(0 0 0 rgba(133,183,235,0))}45%{filter:drop-shadow(0 0 13px rgba(133,183,235,.68))}}
@keyframes brandVideoFadeIn{0%{opacity:0}100%{opacity:1}}
@keyframes brandVideoFadeOut{0%{opacity:1}100%{opacity:0}}
@keyframes brandLayer{0%{opacity:0}22%,72%{opacity:1}100%{opacity:0;visibility:hidden}}
@keyframes brandWordReveal{0%{opacity:0;transform:scale(.6);filter:blur(7px)}24%{opacity:1;transform:scale(1.04);filter:blur(0)}66%{opacity:1;transform:scale(1.18)}100%{opacity:0;transform:scale(2.15);filter:blur(5px)}}
@keyframes loginReveal{to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes formReveal{to{opacity:1;transform:translateY(0)}}
@media (prefers-reduced-motion:reduce){
  .login-intro{display:none}
  .login-brand-intro{display:none}
  .login-box{opacity:1;transform:none;animation:none}
  .login-box > :not(.login-logo){opacity:1;transform:none;animation:none}
}

/* -- TOAST -- */
#toast-area{position:fixed;bottom:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:7px}
.toast{background:var(--ink);color:#fff;padding:10px 15px;border-radius:8px;font-size:.81rem;box-shadow:var(--shadow2);animation:toastIn .22s ease;max-width:300px;display:flex;align-items:center;gap:7px}
.toast.success{background:var(--green)}.toast.error{background:var(--red)}.toast.warn{background:var(--amber)}
@keyframes toastIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* -- EMPTY STATE -- */
.empty-state{text-align:center;padding:38px 18px;color:var(--ink3)}
.empty-state .ei{font-size:2.1rem;margin-bottom:9px}
.empty-state .et{font-size:.88rem;font-weight:600;color:var(--ink2);margin-bottom:5px}
.empty-state .eb{font-size:.78rem}

/* -- MISC -- */
.divider{height:1px;background:var(--border);margin:16px 0}
.flex{display:flex}.aic{align-items:center}.jbc{justify-content:space-between}.gap8{gap:8px}.gap12{gap:12px}
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.search-bar{position:relative;display:flex;align-items:center}
.search-bar input{padding-left:29px}
.search-bar .si{position:absolute;left:9px;color:var(--ink3);font-size:.8rem;pointer-events:none}
.pac-header{background:linear-gradient(135deg,var(--accent) 0%,#154360 100%);border-radius:var(--radius);padding:19px 22px;color:#fff;margin-bottom:16px;display:flex;align-items:center;gap:16px}
.pac-avatar{width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.15);border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.pac-name{font-family:'DM Serif Display',serif;font-size:1.15rem;margin-bottom:3px}
.pac-meta{font-size:.77rem;opacity:.72;display:flex;gap:12px;flex-wrap:wrap}

/* -- ESTUDIOS -- */
.estudio-card{
  background:var(--bg);border:1px solid var(--border);border-radius:10px;
  padding:13px 15px;margin-bottom:10px;display:flex;align-items:flex-start;gap:12px;
}
.estudio-card .ec-ico{font-size:1.5rem;flex-shrink:0;margin-top:2px}
.estudio-card .ec-info{flex:1;min-width:0}
.estudio-card .ec-name{font-size:.85rem;font-weight:600;color:var(--ink);margin-bottom:2px}
.estudio-card .ec-meta{font-size:.74rem;color:var(--ink3)}
.estudio-card .ec-nota{font-size:.78rem;color:var(--ink2);margin-top:4px;white-space:pre-wrap}
.estudio-img{max-width:100%;border-radius:6px;margin-top:8px;cursor:pointer;border:1px solid var(--border)}
.estudio-pdf{display:inline-flex;align-items:center;gap:6px;background:var(--red-lt);color:var(--red);border-radius:6px;padding:5px 10px;font-size:.76rem;font-weight:600;margin-top:6px;cursor:pointer;border:1px solid rgba(192,57,43,.2)}

/* AGENDA */
.agenda-shell{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:14px;align-items:start}
.agenda-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:13px;flex-wrap:wrap}
.agenda-month{font-size:1rem;font-weight:700;color:var(--ink)}
.agenda-calendar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--bg3)}
.agenda-weekday{background:var(--bg);font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);padding:8px 6px;text-align:center;border-right:1px solid var(--border)}
.agenda-weekday:nth-child(7n){border-right:none}
.agenda-day{min-height:106px;padding:8px;border-right:1px solid var(--border);border-top:1px solid var(--border);background:var(--bg3);cursor:pointer;transition:background .14s}
.agenda-day:nth-child(7n){border-right:none}
.agenda-day:hover{background:var(--accent-lt)}
.agenda-day.muted{background:var(--bg);color:var(--ink3)}
.agenda-day.today{box-shadow:inset 0 0 0 2px var(--accent2)}
.agenda-day.selected{box-shadow:inset 0 0 0 2px var(--accent);background:rgba(46,134,193,.06)}
.agenda-day.today.selected{box-shadow:inset 0 0 0 2px var(--accent2),inset 0 0 0 4px rgba(46,134,193,.4)}
.agenda-day-num{font-size:.72rem;font-weight:700;margin-bottom:6px;color:var(--ink2)}
.agenda-chip{display:block;width:100%;border:0;border-radius:6px;padding:4px 6px;margin-bottom:4px;background:#eaf3fb;color:var(--accent);font-size:.68rem;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.agenda-chip.confirmada{background:var(--green-lt);color:var(--green)}
.agenda-chip.pendiente{background:var(--amber-lt);color:var(--amber)}
.agenda-chip.cancelada{background:var(--red-lt);color:var(--red);text-decoration:line-through}
.agenda-chip.completada{background:var(--bg2);color:var(--ink3)}
.agenda-more{font-size:.64rem;color:var(--ink3);margin-top:2px}
.agenda-alert{border:1px solid var(--border);background:var(--bg);border-radius:9px;padding:10px 11px;margin-bottom:8px}
.agenda-alert.soon{border-color:rgba(183,149,11,.35);background:var(--amber-lt)}
.agenda-alert.today{border-color:rgba(30,132,73,.32);background:var(--green-lt)}
.agenda-alert-title{font-size:.82rem;font-weight:700;color:var(--ink)}
.agenda-alert-meta{font-size:.72rem;color:var(--ink3);margin-top:2px}
.agenda-status{display:inline-flex;align-items:center;padding:2px 7px;border-radius:20px;font-size:.68rem;font-weight:700}
.agenda-status.confirmada{background:var(--green-lt);color:var(--green)}
.agenda-status.pendiente{background:var(--amber-lt);color:var(--amber)}
.agenda-status.cancelada{background:var(--red-lt);color:var(--red)}
.agenda-status.completada{background:var(--bg2);color:var(--ink3)}
/* ════════════════════════════════════════════════════════════════════
   ███ RESPONSIVE — TABLETS Y MÓVILES ███
   Breakpoints: 1100px (laptop pequeña), 900px (tablet),
                640px (móvil grande), 420px (móvil chico)
═══════════════════════════════════════════════════════════════════════ */

/* ── Botón hamburguer (móvil) ── */
#mobile-menu-btn{
  display:none;background:transparent;border:0;color:#fff;
  font-size:1.4rem;cursor:pointer;padding:6px 10px;
  position:fixed;top:10px;left:10px;z-index:101;
  background:rgba(13,27,42,.85);border-radius:8px;
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.1);
}
#mobile-menu-btn:hover{background:rgba(13,27,42,.95)}

/* ── Overlay para cerrar sidebar al tocar fuera ── */
#sidebar-backdrop{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.5);z-index:99;
  backdrop-filter:blur(2px);
}

/* ════ LAPTOP / MACBOOK — 1400px (cubre MacBook 13/14/15) ════ */
@media (max-width:1400px){
  .agenda-shell{grid-template-columns:1fr}
  .agenda-day{min-height:92px}
  .stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  /* Análisis clínico: 2 col → 1 col (deja respirar el Top 10) */
  .ana-cli-2col{grid-template-columns:1fr !important}
  #content{padding:18px 20px}
  #topbar{padding:11px 20px}
  .fg4{grid-template-columns:repeat(2,1fr)}
}

/* ════ TABLET — 900px ════ */
@media (max-width:900px){
  /* Sidebar se convierte en menú deslizante */
  #sidebar{
    transform:translateX(-100%);
    transition:transform .25s ease-out;
    width:260px;
    z-index:100;
  }
  #sidebar.mobile-open{transform:translateX(0);box-shadow:6px 0 24px rgba(0,0,0,.3)}
  #sidebar-backdrop.mobile-open{display:block}
  #main{margin-left:0}
  #mobile-menu-btn{display:block}
  /* Topbar deja espacio al hamburguer */
  #topbar{padding-left:60px}
  /* Cards y grids más compactos */
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .stat-card{padding:12px 14px}
  .stat-val{font-size:1.25rem}
  .fg3{grid-template-columns:1fr 1fr}
  .grid2{grid-template-columns:1fr}
  /* Modales un poco más pequeños */
  .modal{width:95%;max-height:94vh}
  .mb{padding:16px}
  .mh{padding:14px 18px}
  .mf{padding:11px 18px;flex-wrap:wrap}
  /* Tabla con scroll horizontal por defecto */
  .tbl-wrap{margin:0 -18px;padding:0 18px}
}

/* ════ MÓVIL GRANDE — 640px ════ */
@media (max-width:640px){
  body{font-size:14px}
  #content{padding:14px 14px 60px}
  #topbar{padding:10px 14px 10px 56px}
  #topbar .pt{font-size:.85rem}
  /* Búsqueda global compacta en móvil */
  .gsearch-label-full, .gsearch-kbd{display:none}
  /* Stats en 1 columna en móviles */
  .stats-grid{grid-template-columns:1fr;gap:8px}
  .stat-card{padding:11px 13px;gap:10px}
  .stat-val{font-size:1.15rem}
  .stat-lbl{font-size:.66rem}
  /* Análisis clínico: 2 col → 1 col */
  .ana-cli-2col{grid-template-columns:1fr !important}
  #ana-cli-kpis{grid-template-columns:repeat(2,1fr) !important}
  /* Grids de form siempre 1 columna */
  .fg2,.fg3,.fg4{grid-template-columns:1fr}
  /* Modales casi pantalla completa */
  .modal{width:100%;max-width:100%;max-height:100vh;height:100vh;border-radius:0}
  .mh{padding:12px 14px}
  .mh-title{font-size:.86rem}
  .mb{padding:14px}
  .mf{padding:10px 14px;flex-direction:column-reverse;gap:8px}
  .mf .btn{width:100%;justify-content:center}
  /* Botones más fáciles de tocar */
  .btn{padding:9px 14px;font-size:.84rem;min-height:38px}
  .btn-sm{padding:7px 11px;font-size:.78rem;min-height:32px}
  .btn-icon{width:34px;height:34px}
  /* Inputs más altos para escritura cómoda */
  .fi{padding:10px 12px;font-size:.9rem;min-height:40px}
  /* Tabs scrolleable horizontal */
  .tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}
  .tab-btn{flex-shrink:0;font-size:.78rem;padding:7px 12px}
  /* Tablas: forzar scroll horizontal */
  .tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:8px;margin:0 0 12px}
  .tbl{min-width:580px}
  .tbl th{font-size:.66rem;padding:7px 9px}
  .tbl td{font-size:.78rem;padding:8px 9px}
  /* Cards */
  .card{padding:14px}
  .card-sm{padding:11px}
  .ch{margin-bottom:11px;flex-wrap:wrap;gap:6px}
  /* Header de paciente más compacto */
  .timeline{padding-left:18px}
  .timeline::before{left:5px}
  .tl-dot{left:-15px}
  /* Sidebar móvil nivelado */
  #sidebar{width:88vw;max-width:300px}
  /* Topbar con info colapsada */
  #topbar > div:first-child > .pt-sub{display:none}
  /* Toasts más pequeños */
  .toast{font-size:.82rem;padding:10px 14px;max-width:calc(100vw - 28px)}
  /* Form labels más legibles */
  .fl{font-size:.78rem}
  /* Modales propios (dialog) */
  .medyra-spinner{width:32px;height:32px}
  /* Snom (secciones NOM) */
  .snom{padding-left:9px;margin-bottom:14px}
  .snom-lbl{font-size:.6rem}
  /* Soma alerts más compactas */
  .soma-alert{font-size:.66rem}
  /* Badges pequeñas */
  .badge{font-size:.66rem;padding:1px 6px}
}

/* ════ MÓVIL CHICO — 420px ════ */
@media (max-width:420px){
  body{font-size:13.5px}
  #content{padding:12px 10px 60px}
  #topbar{padding:9px 12px 9px 52px}
  #topbar .pt{font-size:.8rem}
  /* Quitar padding lateral en mb/mh para usar todo el ancho */
  .mh{padding:10px 12px}
  .mb{padding:12px}
  .mf{padding:9px 12px}
  .btn{padding:9px 12px;font-size:.81rem}
  .fi{padding:10px 11px;font-size:.88rem}
  /* Stat cards aún más compactas */
  .stat-card{padding:9px 11px}
  .stat-val{font-size:1.05rem}
  /* Logo brand más chico */
  #sidebar .brand{padding:18px 16px 14px}
  #sidebar .brand .logo{font-size:1.1rem}
  /* Nav items un poco más altos para tocar bien */
  .nav-item{padding:11px 16px;font-size:.84rem}
}

/* Mejoras táctiles generales */
@media (hover:none) and (pointer:coarse){
  /* Eliminar hovers para evitar "stuck hover" en táctil */
  .btn:hover, .nav-item:hover, .tbl tr:hover td{
    background:initial;
  }
  /* Áreas de tap mínimas (Apple/Google guideline: 44x44px) */
  .btn-icon{min-width:38px;min-height:38px}
  .xbtn{padding:10px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
}

/* -- MED CARD EN RECETA -- */
.lab-chk-item{display:flex;align-items:center;gap:6px;font-size:.77rem;cursor:pointer;padding:5px 8px;border:1px solid var(--border);border-radius:6px;background:var(--bg);transition:background .12s;user-select:none}
.lab-chk-item:hover{background:var(--accent-lt)}
.lab-chk-item input[type=checkbox]{flex-shrink:0;width:14px;height:14px;cursor:pointer;accent-color:var(--accent)}
.radio-visita label{transition:all .15s;cursor:pointer}
.dx-sec-item{background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:10px 12px;margin-bottom:7px;display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center}
.med-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:13px 15px;margin-bottom:9px}
.med-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}

/* -- FARMACOTECA -- */
.farm-item{display:flex;align-items:center;justify-content:space-between;padding:9px 13px;border:1px solid var(--border);border-radius:8px;margin-bottom:7px;cursor:pointer;transition:all .15s}
.farm-item:hover{background:var(--accent-lt);border-color:var(--accent)}

/* -- PREVIEW RECETA — bloques arrastrables -- */
.prev-bloque{
  position:absolute;cursor:move;user-select:none;
  padding:3px 5px;border-radius:3px;
  border:1.5px dashed transparent;
  transition:border-color .15s;
  font-family:'DM Sans',sans-serif;
}
.prev-bloque:hover{border-color:rgba(46,134,193,.5);background:rgba(46,134,193,.04);}
.prev-bloque.selected{border-color:var(--accent2)!important;background:rgba(46,134,193,.08)!important;}
.prev-bloque .bloque-handle{
  position:absolute;top:-10px;left:0;
  background:var(--accent);color:#fff;font-size:.6rem;
  padding:1px 5px;border-radius:3px;white-space:nowrap;
  opacity:0;transition:opacity .15s;pointer-events:none;
}
.prev-bloque:hover .bloque-handle,.prev-bloque.selected .bloque-handle{opacity:1;}

/* -- Lab preview blocks -- */
.lab-prev-bloque{
  position:absolute;cursor:move;user-select:none;
  padding:3px 5px;border-radius:3px;
  border:1.5px dashed transparent;
  transition:border-color .15s;
  font-family:'DM Sans',sans-serif;
}
.lab-prev-bloque:hover{border-color:rgba(46,134,193,.5);background:rgba(46,134,193,.04);}
.lab-prev-bloque.selected{border-color:var(--accent2)!important;background:rgba(46,134,193,.08)!important;}
.lab-prev-bloque .bloque-handle{
  position:absolute;top:-10px;left:0;
  background:var(--accent);color:#fff;font-size:.6rem;
  padding:1px 5px;border-radius:3px;white-space:nowrap;
  opacity:0;transition:opacity .15s;pointer-events:none;
}
.lab-prev-bloque:hover .bloque-handle,.lab-prev-bloque.selected .bloque-handle{opacity:1;}

/* -- MIC pulse -- */
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}

#receta-print-area{display:none}
@media print{
  body>*{display:none!important}
  /* position:static permite que el contenido fluya en múltiples páginas.
     position:fixed/inset:0 anterior lo limitaba a una sola pantalla y
     causaba que solicitudes de lab y SUIVE solo imprimieran la 1ra hoja. */
  #receta-print-area{display:block!important;position:static!important;background:#fff;width:100%;min-height:100vh}
  #modal-preview-rx{display:none!important}
  #modal-preview-lab{display:none!important}
  @page{size:letter;margin:0}
}

/* ======================================
   TUTORIAL DR. CHEMIS — ONBOARDING
====================================== */
#tutorial-overlay {
  position: fixed; inset: 0; z-index: 9000;
  pointer-events: none;
  display: none;
}
#tutorial-overlay.active { display: block; }

/* Backdrop con spotlight */
#tutorial-backdrop {
  position: absolute; inset: 0;
  background: rgba(5, 20, 40, 0.72);
  backdrop-filter: blur(2px);
  pointer-events: auto;
  transition: opacity 0.4s;
}

/* Spotlight recorte del elemento destacado */
#tutorial-spotlight {
  position: absolute;
  border-radius: 10px;
  box-shadow: 0 0 0 9999px rgba(5, 20, 40, 0.72);
  transition: all 0.45s cubic-bezier(.4,0,.2,1);
  pointer-events: none;
  z-index: 1;
}

/* Burbuja de diálogo */
#tutorial-bubble {
  position: absolute;
  background: #fff;
  border-radius: 16px;
  padding: 18px 20px 16px;
  box-shadow: 0 20px 60px rgba(5,20,40,.28), 0 4px 16px rgba(5,20,40,.14);
  width: 320px;
  z-index: 9002;
  pointer-events: auto;
  transition: all 0.4s cubic-bezier(.4,0,.2,1);
  border: 1.5px solid rgba(26,82,118,.12);
}
#tutorial-bubble::before {
  content: '';
  position: absolute;
  width: 14px; height: 14px;
  background: #fff;
  border: 1.5px solid rgba(26,82,118,.12);
  border-right: none; border-bottom: none;
  transform: rotate(225deg);
  transition: all 0.4s;
}
#tutorial-bubble.arrow-left::before { left: -8px; top: 24px; transform: rotate(225deg) translate(0,0); border-right: none; border-bottom: none; }
#tutorial-bubble.arrow-right::before { right: -8px; top: 24px; transform: rotate(45deg); border-right: none; border-bottom: none; }
#tutorial-bubble.arrow-top::before { top: -8px; left: 50%; margin-left: -7px; transform: rotate(315deg); border-right: none; border-bottom: none; }
#tutorial-bubble.arrow-bottom::before { bottom: -8px; left: 50%; margin-left: -7px; transform: rotate(135deg); border-right: none; border-bottom: none; }
#tutorial-bubble.arrow-none::before { display: none; }

/* Header burbuja */
.tut-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 10px;
}
.tut-badge {
  font-size: .62rem; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--accent);
  background: var(--accent-lt); border-radius: 20px;
  padding: 2px 9px; white-space: nowrap;
}
.tut-step-counter {
  font-size: .7rem; color: var(--ink3); margin-left: auto; white-space: nowrap;
}
.tut-msg {
  font-size: .84rem; color: var(--ink); line-height: 1.6; margin-bottom: 14px;
}
.tut-msg strong { color: var(--accent); }
.tut-footer { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.tut-dots { display: flex; gap: 5px; }
.tut-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--border2); transition: background .2s;
}
.tut-dot.active { background: var(--accent); }
.tut-actions { display: flex; gap: 7px; }
.tut-btn-skip {
  background: none; border: none; font-size: .76rem;
  color: var(--ink3); cursor: pointer; padding: 6px 8px;
}
.tut-btn-skip:hover { color: var(--ink); }
.tut-btn-next {
  background: var(--accent); color: #fff; border: none;
  border-radius: 7px; padding: 7px 16px; font-size: .81rem;
  font-weight: 600; cursor: pointer; transition: background .16s;
  font-family: 'DM Sans', sans-serif;
}
.tut-btn-next:hover { background: var(--accent2); }

/* Dr. Chemis avatar flotante */
#dr-chemis-avatar {
  position: absolute;
  z-index: 9003;
  pointer-events: none;
  transition: all 0.5s cubic-bezier(.4,0,.2,1);
}
#dr-chemis-avatar img {
  width: 150px;
  height: auto;
  display: block;
  /* Remove white background */
  mix-blend-mode: multiply;
  filter: drop-shadow(0 8px 24px rgba(5,20,40,.18));
}
/* Speaking animation - subtle bounce + glow */
#dr-chemis-avatar.speaking img {
  animation: drSpeaking 0.45s ease-in-out infinite alternate;
}
@keyframes drSpeaking {
  0%   { transform: translateY(0px) scale(1);    filter: drop-shadow(0 8px 24px rgba(26,82,118,.25)); }
  50%  { transform: translateY(-4px) scale(1.02); filter: drop-shadow(0 12px 30px rgba(26,82,118,.4)); }
  100% { transform: translateY(-2px) scale(1.01); filter: drop-shadow(0 10px 28px rgba(26,82,118,.32)); }
}
/* Mouth wave overlay */
#dr-chemis-avatar .tut-soundwave {
  position: absolute;
  bottom: 18px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 2px;
  align-items: flex-end;
  height: 14px;
  opacity: 0;
  transition: opacity .2s;
}
#dr-chemis-avatar.speaking .tut-soundwave { opacity: 1; }
#dr-chemis-avatar .tut-soundwave span {
  display: inline-block;
  width: 3px;
  border-radius: 2px;
  background: var(--accent);
  animation: tutWave 0.6s ease-in-out infinite alternate;
}
#dr-chemis-avatar .tut-soundwave span:nth-child(1) { height: 5px;  animation-delay: 0s; }
#dr-chemis-avatar .tut-soundwave span:nth-child(2) { height: 10px; animation-delay: .1s; }
#dr-chemis-avatar .tut-soundwave span:nth-child(3) { height: 14px; animation-delay: .2s; }
#dr-chemis-avatar .tut-soundwave span:nth-child(4) { height: 10px; animation-delay: .3s; }
#dr-chemis-avatar .tut-soundwave span:nth-child(5) { height: 5px;  animation-delay: .4s; }
@keyframes tutWave {
  from { transform: scaleY(0.4); opacity: .5; }
  to   { transform: scaleY(1);   opacity: 1; }
}

/* Animación de entrada */
@keyframes tutSlideIn {
  from { opacity: 0; transform: translateY(12px) scale(.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes tutDrIn {
  from { opacity: 0; transform: translateX(-20px); }
  to   { opacity: 1; transform: translateX(0); }
}
#tutorial-bubble.animating { animation: tutSlideIn .38s ease forwards; }
#dr-chemis-avatar.animating { animation: tutDrIn .5s ease forwards; }

/* Typing effect cursor */
.tut-cursor { display: inline-block; width: 2px; height: 1em; background: var(--accent); margin-left: 2px; vertical-align: middle; animation: tutBlink .7s step-end infinite; }
@keyframes tutBlink { 0%,100%{opacity:1} 50%{opacity:0} }

/* ══ PACIENTE AUTOCOMPLETE ══ */
.pac-autocomplete-wrap {
  position: relative;
  width: 100%;
}
.pac-autocomplete-wrap input.pac-search {
  width: 100%;
}
.pac-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--bg3);
  border: 1.5px solid var(--accent2);
  border-top: none;
  border-radius: 0 0 8px 8px;
  max-height: 220px;
  overflow-y: auto;
  z-index: 3000;
  box-shadow: 0 8px 24px rgba(13,27,42,.14);
  display: none;
}
.pac-dropdown.open { display: block; }
.pac-dropdown-item {
  padding: 9px 12px;
  font-size: .8rem;
  cursor: pointer;
  border-bottom: 1px solid var(--border);
  color: var(--ink);
  transition: background .12s;
  line-height: 1.4;
}
.pac-dropdown-item:last-child { border-bottom: none; }
.pac-dropdown-item:hover, .pac-dropdown-item.active { background: var(--accent-lt); color: var(--accent); }
.pac-dropdown-item .pac-exp { font-size: .7rem; color: var(--ink3); }
.pac-dropdown-empty { padding: 10px 12px; font-size: .8rem; color: var(--ink3); font-style: italic; }


/* ===== BLOQUE CSS 2 ===== */

@keyframes cronoLatido {
  0%   { box-shadow: 0 0 0 0 rgba(39,174,96,.6); }
  70%  { box-shadow: 0 0 0 8px rgba(39,174,96,0); }
  100% { box-shadow: 0 0 0 0 rgba(39,174,96,0); }
}
@media (max-width:640px){
  #cronometro-flotante{
    bottom:12px !important; right:12px !important; left:12px !important;
    min-width:0 !important; padding:11px 14px !important;
  }
  #cronometro-flotante .crono-tiempo,
  #crono-tiempo{ font-size:1.7rem !important; }
}

/* ═══════════════════════════════════════════════════════════════════
   ╔════════════════════════════════════════════════════════════════╗
   ║  UX PREMIUM v2 — Pulido global de interacciones                 ║
   ║  · Toast con icono, animaciones, hover-pause                    ║
   ║  · Sync indicator en topbar                                     ║
   ║  · Spinner para botones en loading                              ║
   ║  · Microinteracciones (hover, active, focus)                    ║
   ║  · Skeleton loaders                                             ║
   ╚════════════════════════════════════════════════════════════════╝
═══════════════════════════════════════════════════════════════════════ */

/* ── TOAST v2 ── */
.toast-v2{
  position:relative;
  background:#0d1b2a;
  color:#fff;
  padding:11px 14px 11px 12px;
  border-radius:12px;
  font-size:.83rem;
  font-weight:500;
  box-shadow:0 12px 32px rgba(13,27,42,.22), 0 2px 6px rgba(13,27,42,.10);
  animation:toastSlideIn .32s cubic-bezier(.2,.9,.3,1.25);
  max-width:380px;
  min-width:220px;
  display:flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
  border:1px solid rgba(255,255,255,.06);
  backdrop-filter:blur(8px);
  user-select:none;
  line-height:1.4;
}
.toast-v2:hover{ transform:translateY(-1px); box-shadow:0 16px 40px rgba(13,27,42,.28); }
.toast-v2.toast-out{ animation:toastSlideOut .22s ease-in forwards; }
.toast-v2 .toast-ico{
  flex-shrink:0;
  width:22px; height:22px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:.78rem; font-weight:700;
  background:rgba(255,255,255,.14);
  color:#fff;
}
.toast-v2 .toast-msg{ flex:1; word-break:break-word; white-space:pre-wrap; }
.toast-v2 .toast-action{
  background:rgba(255,255,255,.16);
  color:#fff;
  border:none;
  border-radius:7px;
  padding:5px 11px;
  font-size:.76rem;
  font-weight:600;
  cursor:pointer;
  font-family:inherit;
  transition:background .15s;
  flex-shrink:0;
}
.toast-v2 .toast-action:hover{ background:rgba(255,255,255,.26); }
.toast-v2.success{ background:linear-gradient(135deg,#1e8449,#27ae60); }
.toast-v2.success .toast-ico{ background:rgba(255,255,255,.22); }
.toast-v2.error{ background:linear-gradient(135deg,#c0392b,#e74c3c); }
.toast-v2.error .toast-ico{ background:rgba(255,255,255,.22); }
.toast-v2.warn{ background:linear-gradient(135deg,#b7950b,#d4a829); color:#1a1500; }
.toast-v2.warn .toast-ico{ background:rgba(0,0,0,.16); color:#1a1500; }
.toast-v2.warn .toast-action{ background:rgba(0,0,0,.16); color:#1a1500; }
.toast-v2.sync{ background:linear-gradient(135deg,#1a5276,#2e86c1); }
.toast-v2.sync .toast-ico{ background:rgba(255,255,255,.22); animation:syncRotate 1.2s linear infinite; }

@keyframes toastSlideIn{
  0%   { opacity:0; transform:translateX(40px) scale(.94); }
  60%  { transform:translateX(-3px) scale(1.01); }
  100% { opacity:1; transform:translateX(0) scale(1); }
}
@keyframes toastSlideOut{
  0%   { opacity:1; transform:translateX(0); }
  100% { opacity:0; transform:translateX(40px) scale(.96); }
}
@keyframes syncRotate{ to { transform:rotate(360deg); } }


/* ── SYNC INDICATOR ── */
#sync-indicator{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:5px 11px;
  border-radius:20px;
  font-size:.7rem;
  font-weight:600;
  letter-spacing:.02em;
  border:1px solid;
  transition:all .25s ease;
  cursor:default;
  user-select:none;
  height:30px;
}
#sync-indicator .sync-dot{
  width:7px; height:7px; border-radius:50%;
  background:currentColor;
  flex-shrink:0;
}
#sync-indicator.sync-ok{
  background:rgba(30,132,73,.07);
  border-color:rgba(30,132,73,.22);
  color:#1e8449;
}
#sync-indicator.sync-ok .sync-dot{ animation:syncPulseOk 2.4s ease infinite; }
#sync-indicator.sync-syncing{
  background:rgba(46,134,193,.10);
  border-color:rgba(46,134,193,.28);
  color:#2e86c1;
}
#sync-indicator.sync-syncing .sync-dot{ animation:syncPulseActive 1s ease infinite; }
#sync-indicator.sync-pending{
  background:rgba(183,149,11,.10);
  border-color:rgba(183,149,11,.28);
  color:#b7950b;
}
#sync-indicator.sync-pending .sync-dot{ animation:syncPulseActive 1.4s ease infinite; }
#sync-indicator.sync-error{
  background:rgba(192,57,43,.08);
  border-color:rgba(192,57,43,.28);
  color:#c0392b;
}
#sync-indicator.sync-offline{
  background:rgba(90,112,128,.10);
  border-color:rgba(90,112,128,.25);
  color:#5a7080;
}
@keyframes syncPulseOk{
  0%,100% { opacity:1; box-shadow:0 0 0 0 rgba(30,132,73,.4); }
  50%     { opacity:.7; box-shadow:0 0 0 4px rgba(30,132,73,0); }
}
@keyframes syncPulseActive{
  0%   { transform:scale(1);   opacity:1; }
  50%  { transform:scale(1.4); opacity:.55; }
  100% { transform:scale(1);   opacity:1; }
}
/* En pantallas pequeñas, mostrar solo el punto */
@media (max-width:720px){
  #sync-indicator .sync-label{ display:none; }
  #sync-indicator{ padding:5px 7px; }
}


/* ── SPINNER de botón (loading state) ── */
.btn-spinner{
  display:inline-block;
  width:13px; height:13px;
  border:2px solid rgba(255,255,255,.28);
  border-top-color:#fff;
  border-radius:50%;
  animation:btnSpin .7s linear infinite;
  vertical-align:-2px;
  margin-right:5px;
}
.btn-secondary .btn-spinner,
.btn-icon .btn-spinner{
  border-color:rgba(13,27,42,.18);
  border-top-color:var(--ink);
}
@keyframes btnSpin{ to { transform:rotate(360deg); } }

/* Botón en estado disabled más elegante */
button:disabled,
.btn:disabled{
  opacity:.62;
  cursor:not-allowed !important;
  filter:saturate(.7);
}


/* ── MICROINTERACCIONES — botones ── */
.btn{
  transition:transform .12s ease, box-shadow .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}
.btn:not(:disabled):hover{ transform:translateY(-1px); }
.btn:not(:disabled):active{ transform:translateY(0) scale(.985); }
.btn-primary:not(:disabled):hover{ box-shadow:0 6px 14px rgba(26,82,118,.24); }
.btn-secondary:not(:disabled):hover{ box-shadow:0 4px 10px rgba(13,27,42,.08); }

/* Focus visible — accesibilidad y feedback claro */
.btn:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
  outline:2px solid var(--accent2);
  outline-offset:1px;
}

/* Cards: hover sutil */
.stat-card,
.card{
  transition:transform .15s ease, box-shadow .2s ease;
}
.stat-card:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(13,27,42,.08);
}


/* ── EMPTY STATES más vivos ── */
.empty-state{ animation:fadeUp .35s ease both; }
@keyframes fadeUp{
  from { opacity:0; transform:translateY(8px); }
  to   { opacity:1; transform:translateY(0); }
}
.empty-state .ei{
  font-size:2.4rem;
  margin-bottom:12px;
  filter:grayscale(.2);
  opacity:.85;
  display:inline-block;
  animation:emptyBob 3.6s ease-in-out infinite;
}
@keyframes emptyBob{
  0%,100% { transform:translateY(0); }
  50%     { transform:translateY(-4px); }
}


/* ── SKELETON loader (para listas mientras cargan) ── */
.skel{
  background:linear-gradient(90deg, rgba(13,27,42,.05) 25%, rgba(13,27,42,.10) 50%, rgba(13,27,42,.05) 75%);
  background-size:200% 100%;
  border-radius:6px;
  animation:skelShine 1.4s ease infinite;
  display:inline-block;
}
@keyframes skelShine{
  0%   { background-position:200% 0; }
  100% { background-position:-200% 0; }
}
.skel-line{ height:12px; width:100%; margin:4px 0; }
.skel-line.sm{ width:60%; }
.skel-line.lg{ height:18px; }


/* ── TABLAS: hover y transición ── */
tbody tr{ transition:background-color .12s ease; }


/* ── INPUTS: focus más limpio ── */
input,select,textarea{
  transition:border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
}
input:focus,select:focus,textarea:focus{
  box-shadow:0 0 0 3px rgba(46,134,193,.14);
}


/* ── MOTION REDUCIDA ── */
@media (prefers-reduced-motion:reduce){
  .toast-v2,
  .toast-v2.toast-out,
  #sync-indicator .sync-dot,
  .empty-state .ei,
  .skel,
  .btn{
    animation:none !important;
    transition:none !important;
  }
}


/* ── TRANSICIÓN ENTRE VISTAS ── */
.view{ display:none; }
.view.active{
  display:block;
  animation:viewFadeIn .28s cubic-bezier(.2,.7,.3,1) both;
}
/* Fix layout: forzar que view-suscripcion no se desplace verticalmente */
#view-suscripcion.active{
  position: relative;
  top: 0;
  margin-top: 0;
  padding-top: 0;
}
@keyframes viewFadeIn{
  from { opacity:0; transform:translateY(8px); }
  to   { opacity:1; transform:translateY(0); }
}
@media (prefers-reduced-motion:reduce){
  .view.active{ animation:none; }
}


/* ── SKELETON helpers para tablas / cards ── */
.skel-row{
  display:flex; gap:12px; padding:12px 14px;
  border-bottom:1px solid var(--border);
  align-items:center;
}
.skel-cell{ flex:1; }
.skel-cell.sm{ flex:0 0 80px; }
.skel-cell.md{ flex:0 0 140px; }
.skel-tag{
  display:inline-block; width:60px; height:18px;
  background:linear-gradient(90deg, rgba(13,27,42,.05) 25%, rgba(13,27,42,.10) 50%, rgba(13,27,42,.05) 75%);
  background-size:200% 100%;
  border-radius:11px;
  animation:skelShine 1.4s ease infinite;
}
.skel-circle{
  width:40px; height:40px; border-radius:50%;
  background:linear-gradient(90deg, rgba(13,27,42,.05) 25%, rgba(13,27,42,.10) 50%, rgba(13,27,42,.05) 75%);
  background-size:200% 100%;
  animation:skelShine 1.4s ease infinite;
  flex-shrink:0;
}


/* ── EMPTY STATE más rico (variant con CTA visible) ── */
.empty-state.lg{
  padding:54px 22px 60px;
}
.empty-state.lg .ei{ font-size:3.2rem; margin-bottom:14px; }
.empty-state.lg .et{ font-size:1.05rem; margin-bottom:8px; }
.empty-state.lg .eb{ font-size:.85rem; line-height:1.55; max-width:380px; margin:0 auto 16px; }
.empty-state .e-cta{
  display:inline-flex; align-items:center; gap:7px;
  background:linear-gradient(135deg, var(--accent), var(--accent2));
  color:#fff !important; border:none; border-radius:8px;
  padding:9px 18px; font-size:.85rem; font-weight:600;
  cursor:pointer; box-shadow:0 4px 10px rgba(26,82,118,.18);
  transition:transform .12s ease, box-shadow .18s ease;
  font-family:inherit; text-decoration:none;
}
.empty-state .e-cta:hover{ transform:translateY(-1px); box-shadow:0 8px 18px rgba(26,82,118,.26); }


/* ═══════════════════════════════════════════════════════════
   VELOCIDAD MÉDICA — Atajos de teclado + Autosave visible
═══════════════════════════════════════════════════════════ */

/* Teclas individuales en el cheat sheet y tooltips */
kbd.ks{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.18);
  border-bottom-width:2px;
  border-radius:6px;
  padding:3px 8px;
  font-family:'JetBrains Mono', Menlo, Monaco, monospace;
  font-size:.74rem;
  font-weight:600;
  color:#fff;
  line-height:1;
  min-width:24px;
  text-align:center;
  letter-spacing:.02em;
}

/* Indicador permanente de autosave en header de modales */
.autosave-indicador{
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:5px 11px;
  border-radius:18px;
  background:rgba(46,134,193,.07);
  border:1px solid rgba(46,134,193,.18);
  font-size:.72rem;
  color:var(--ink3);
  font-weight:500;
  white-space:nowrap;
  user-select:none;
  margin-left:auto;
}
.autosave-indicador .as-dot{
  width:7px; height:7px; border-radius:50%;
  background:var(--ink3);
  flex-shrink:0;
}
.autosave-indicador .as-dot.as-ok{
  background:#1e8449;
  box-shadow:0 0 0 0 rgba(30,132,73,.4);
  animation:asPulseOk 2.6s ease infinite;
}
.autosave-indicador .as-dot.as-idle{
  background:rgba(13,27,42,.25);
}
.autosave-indicador .as-txt{
  font-size:.7rem;
  letter-spacing:.01em;
}
@keyframes asPulseOk{
  0%,100% { box-shadow:0 0 0 0 rgba(30,132,73,.35); }
  50%     { box-shadow:0 0 0 5px rgba(30,132,73,0); }
}
@media (max-width:720px){
  .autosave-indicador .as-txt{ display:none; }
  .autosave-indicador{ padding:5px 7px; }
}
@media (prefers-reduced-motion:reduce){
  .autosave-indicador .as-dot.as-ok{ animation:none; }
}


/* Indicador "hint" de Ctrl+K en el botón de búsqueda — mejor visibilidad */
#btn-gsearch-topbar .gsearch-kbd{
  transition:background .15s, color .15s;
}


/* ===== BLOQUE CSS 3 ===== */
'+css+'

/* ===== BLOQUE CSS 4 ===== */
'
    +'*{box-sizing:border-box;margin:0;padding:0}'
    +'body{font-family:Arial,sans-serif;background:#fff;padding:14mm}'
    +'@media print{'
    +'@page{size:letter;margin:14mm}'
    +'body{padding:0}'
    +'}'
    +'

/* ===== BLOQUE CSS 5 ===== */
'
    +'*{box-sizing:border-box;margin:0;padding:0}'
    +'body{font-family:Arial,sans-serif;background:#fff;padding:14mm;color:#111}'
    +'@media print{@page{size:letter;margin:14mm}body{padding:0}}'
    +'

/* ===== BLOQUE CSS 6 ===== */
' + css + '

/* ===== BLOQUE CSS 7 ===== */
'
    +'*{box-sizing:border-box;margin:0;padding:0}'
    +'body{font-family:"DM Sans",sans-serif;padding:15mm 18mm;font-size:9pt;color:#111;background:#fff}'
    +'@media print{@page{size:letter;margin:0}body{padding:12mm 14mm}}'
    +'

/* ===== BLOQUE CSS 8 ===== */
*{box-sizing:border-box;margin:0;padding:0}'
    +'body{font-family:"DM Sans",sans-serif;background:#fff}'
    +'.pag{width:215.9mm;min-height:279.4mm;page-break-after:always;}'
    +'@media print{@page{size:letter;margin:0}.pag{page-break-after:always}}'
    +'

/* ===== BLOQUE CSS 9 ===== */
'+css+'


/* ===== Select con búsqueda (combobox, SOLO desktop) — Pendiente 2 =====
   Capa no destructiva sobre <select> nativos. Reutiliza el look del
   autocompletado (.ac-*). En móvil/tablet no se instala (picker nativo). */
.ss-wrap{position:relative}
.ss-native-hidden{display:none !important}
.ss-input{width:100%;cursor:text}
.ss-input::placeholder{color:var(--ink3)}
.ss-list{position:fixed;z-index:9999;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius2);box-shadow:var(--shadow2);max-height:260px;overflow-y:auto;display:none}
.ss-list.open{display:block}
.ss-item{padding:7px 11px;font-size:.82rem;cursor:pointer;border-bottom:1px solid var(--border);color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ss-item:last-child{border-bottom:none}
.ss-item:hover,.ss-item.ss-active{background:var(--accent-lt)}
.ss-item.ss-current{font-weight:600;color:var(--accent)}
.ss-empty{padding:9px 11px;font-size:.78rem;color:var(--ink3);text-align:center}

/* El asistente NO puede activar/quitar el perfil público (solo el médico). */
body.role-asistente #pp-toggle-label{pointer-events:none !important;opacity:.45;cursor:not-allowed}
/* El asistente SÍ puede editar y guardar los HORARIOS DE ATENCIÓN + bio del médico,
   aunque estén dentro de la card readonly. Reactivamos solo esos controles y el botón Guardar. */
body.role-asistente #pp-horarios-grid input,
body.role-asistente #pp-bio{
  pointer-events:auto !important;opacity:1 !important;cursor:auto !important
}
body.role-asistente #cfg-btn-guardar{
  pointer-events:auto !important;opacity:1 !important;cursor:pointer !important
}
