/* ═══════════════════════════════════════════════
   YOABLO — Hoja de estilos principal
   Dominio: https://yoablo.inteccocorp.com
   Paleta:
     Coral Vivo    #FF5733  (principal)
     Amarillo Sol  #FFD700  (acento/logros)
     Menta Alegre  #4ECDC4  (terapeuta)
     Índigo Noche  #2D2654  (master/admin)
     Lavanda       #F9F5FF  (fondo suave)
   ═══════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --font:      'Plus Jakarta Sans', 'Nunito', system-ui, sans-serif;
  --coral:     #FF5733;
  --coral-dk:  #c44b00;
  --coral-lt:  #fff4f0;
  --coral-md:  #ffb899;
  --gold:      #FFD700;
  --gold-dk:   #7a5c00;
  --gold-lt:   #FFF9E6;
  --mint:      #4ECDC4;
  --mint-dk:   #0f4f4c;
  --mint-lt:   #f0fdf9;
  --indigo:    #2D2654;
  --indigo-lt: #f5f3ff;
  --indigo-md: #a5b4fc;
  --lavender:  #F9F5FF;
  --c-bg:      #F9F5FF;
  --c-surface: #ffffff;
  --c-border:  rgba(45,38,84,0.1);
  --c-border-md: rgba(45,38,84,0.18);
  --c-text:    #1a1a2e;
  --c-muted:   #6b6b8a;
  --c-hint:    #a0a0b8;
  --r-sm:  8px;
  --r-md:  12px;
  --r-lg:  16px;
  --r-xl:  20px;
}

@media (prefers-color-scheme: dark) {
  :root {
    --c-bg:      #12101e;
    --c-surface: #1c1a2e;
    --c-border:  rgba(165,180,252,0.12);
    --c-border-md: rgba(165,180,252,0.2);
    --c-text:    #f0eeff;
    --c-muted:   #a0a0c0;
    --c-hint:    #6b6b8a;
    --lavender:  #12101e;
    --coral-lt:  #2a1410;
    --gold-lt:   #201800;
    --mint-lt:   #0a1f1e;
    --indigo-lt: #15122a;
  }
}

html { font-size: 16px; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font);
  background: var(--c-bg);
  color: var(--c-text);
  min-height: 100vh;
  line-height: 1.5;
}

/* ═══════════════════════════════
   APP WRAPPER
═══════════════════════════════ */
.app { display: flex; flex-direction: column; min-height: 100vh; }

/* ═══════════════════════════════
   TOPBAR
═══════════════════════════════ */
.topbar {
  background: var(--indigo);
  display: flex;
  align-items: center;
  padding: 0 20px;
  height: 60px;
  gap: 12px;
  flex-shrink: 0;
  position: sticky;
  top: 0;
  z-index: 100;
}

/* Logo */
.tb-brand { display: flex; align-items: center; gap: 10px; flex-shrink: 0; text-decoration: none; }
.tb-icon-wrap {
  width: 38px; height: 38px;
  border-radius: 11px;
  background: rgba(255,255,255,.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
  position: relative;
}
.tb-icon-bubble {
  position: absolute;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--gold);
  top: -3px; right: -3px;
  border: 2px solid var(--indigo);
}
.tb-logo-name {
  font-size: 22px;
  font-weight: 900;
  color: #fff;
  letter-spacing: -1px;
  line-height: 1;
}
.tb-logo-name span { color: var(--gold); }
.tb-logo-sub { font-size: 10px; color: var(--indigo-md); margin-top: 1px; letter-spacing: .3px; }

/* Nav central */
.tb-center { flex: 1; display: flex; justify-content: center; align-items: center; gap: 2px; overflow-x: auto; scrollbar-width: none; }
.tb-center::-webkit-scrollbar { display: none; }
.tnav {
  padding: 7px 13px;
  border-radius: 9px;
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,.55);
  white-space: nowrap;
  font-family: var(--font);
  transition: all .15s;
}
.tnav:hover { background: rgba(255,255,255,.1); color: #fff; }
.tnav.on   { background: rgba(255,255,255,.18); color: #fff; }

/* Staff buttons — top right */
.tb-staff { display: flex; align-items: center; gap: 7px; flex-shrink: 0; }
.staff-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 13px;
  border-radius: 9px;
  cursor: pointer;
  font-size: 11px; font-weight: 700;
  font-family: var(--font);
  transition: all .15s;
  white-space: nowrap;
  border: 1px solid transparent;
}
.sb-master { background: rgba(255,215,0,.18); border-color: rgba(255,215,0,.45); color: var(--gold); }
.sb-master:hover { background: rgba(255,215,0,.3); color: #fff; }
.sb-tera   { background: rgba(78,205,196,.15); border-color: rgba(78,205,196,.4); color: var(--mint); }
.sb-tera:hover   { background: rgba(78,205,196,.28); color: #fff; }
.tb-divider { width: 1px; height: 20px; background: rgba(255,255,255,.15); flex-shrink: 0; }

/* User chip */
#tb-chip { display: flex; align-items: center; gap: 8px; }
.user-chip {
  display: flex; align-items: center; gap: 7px;
  padding: 4px 11px 4px 5px;
  border-radius: 20px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
}
.uc-av {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(255,255,255,.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
}
.uc-nm { color: #fff; font-size: 11px; font-weight: 700; max-width: 100px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.uc-pill { font-size: 9px; padding: 2px 8px; border-radius: 8px; font-weight: 700; }
.pill-m { background: rgba(255,215,0,.25); color: var(--gold); }
.pill-t { background: rgba(78,205,196,.25); color: var(--mint); }
.pill-p { background: rgba(255,87,51,.25); color: #ffb899; }
.logout-btn {
  padding: 5px 11px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.2);
  background: transparent;
  color: rgba(255,255,255,.75);
  font-size: 10px; font-weight: 600;
  cursor: pointer; font-family: var(--font);
  transition: all .15s; flex-shrink: 0;
}
.logout-btn:hover { background: rgba(255,255,255,.12); color: #fff; }

/* ═══════════════════════════════
   STAFF DROPDOWN
═══════════════════════════════ */
.sd-wrapper { display: flex; justify-content: flex-end; background: var(--indigo); transition: background .3s; }
.staff-dropdown {
  display: none;
  background: var(--c-surface);
  border: .5px solid var(--c-border-md);
  border-top: none;
  border-radius: 0 0 16px 16px;
  padding: 20px 22px;
  width: 360px; max-width: 100%;
}
.staff-dropdown.show { display: block; }
.sd-header { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 16px; }
.sd-icon { font-size: 24px; }
.sd-title { font-size: 15px; font-weight: 700; color: var(--c-text); }
.sd-sub   { font-size: 11px; color: var(--c-muted); margin-top: 2px; }
.sd-close { margin-left: auto; background: none; border: none; cursor: pointer; color: var(--c-muted); font-size: 18px; padding: 0; line-height: 1; flex-shrink: 0; }
.sd-btns  { display: flex; gap: 8px; margin-top: 8px; }

/* ═══════════════════════════════
   CONTENT & SCREENS
═══════════════════════════════ */
.content { flex: 1; display: flex; flex-direction: column; }

.pac-screen {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 30px 20px;
  background: var(--lavender);
}
.pac-box {
  background: var(--c-surface);
  border-radius: var(--r-xl);
  border: .5px solid var(--c-border-md);
  padding: 36px 30px;
  width: 100%; max-width: 400px;
}
.pac-logo-wrap {
  text-align: center;
  margin-bottom: 14px;
}
.pac-logo-icon {
  width: 72px; height: 72px;
  border-radius: 22px;
  background: var(--coral);
  display: flex; align-items: center; justify-content: center;
  font-size: 38px;
  margin: 0 auto 10px;
  position: relative;
}
.pac-logo-bubble {
  position: absolute;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--gold);
  top: -5px; right: -5px;
  border: 2px solid var(--c-surface);
}
.pac-logo-name { font-size: 32px; font-weight: 900; color: var(--coral); letter-spacing: -1px; }
.pac-logo-name span { color: var(--indigo); }
.pac-logo-sub  { font-size: 12px; color: var(--c-muted); margin-top: 2px; }
.pac-title { text-align: center; font-size: 18px; font-weight: 700; color: var(--c-text); margin-bottom: 3px; }
.pac-sub   { text-align: center; font-size: 13px; color: var(--c-muted); margin-bottom: 22px; }
.pac-help  { text-align: center; margin-top: 14px; font-size: 11px; color: var(--c-muted); }
.link { color: var(--coral); cursor: pointer; font-weight: 600; }
.link:hover { text-decoration: underline; }
.btn-full { width: 100%; margin-top: 6px; }

.chpw-screen {
  flex: 1;
  display: flex; align-items: center; justify-content: center;
  padding: 30px 20px; background: var(--lavender);
}
.chpw-box {
  background: var(--c-surface);
  border-radius: var(--r-xl);
  border: .5px solid var(--c-border-md);
  padding: 28px 26px;
  width: 100%; max-width: 400px;
}
.chpw-icon  { text-align: center; font-size: 40px; margin-bottom: 8px; }
.chpw-title { text-align: center; font-size: 17px; font-weight: 700; color: var(--c-text); margin-bottom: 3px; }
.chpw-sub   { text-align: center; font-size: 12px; color: var(--c-muted); margin-bottom: 14px; }

.app-body { flex: 1; padding: 18px 22px; max-width: 920px; margin: 0 auto; width: 100%; }

/* ═══════════════════════════════
   SECTIONS
═══════════════════════════════ */
.sec { display: none; }
.sec.on { display: block; }

/* ═══════════════════════════════
   CARDS
═══════════════════════════════ */
.card {
  background: var(--c-surface);
  border-radius: var(--r-md);
  border: .5px solid var(--c-border);
  padding: 16px 18px;
  margin-bottom: 14px;
}
.card-hdr { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 14px; gap: 10px; }
.ct { font-size: 14px; font-weight: 700; color: var(--c-text); }
.cs { font-size: 12px; color: var(--c-muted); margin-top: 2px; }
.sl {
  font-size: 10px; font-weight: 700;
  color: var(--coral);
  text-transform: uppercase; letter-spacing: .7px;
  margin-bottom: 10px; padding-bottom: 5px;
  border-bottom: .5px solid var(--coral-md);
  margin-top: 16px;
}

/* ═══════════════════════════════
   FORMS
═══════════════════════════════ */
.fg { margin-bottom: 12px; }
.fl { font-size: 11px; color: var(--c-muted); margin-bottom: 4px; font-weight: 600; display: block; }
.fi {
  width: 100%;
  padding: 9px 13px;
  border: .5px solid var(--c-border-md);
  border-radius: var(--r-sm);
  font-size: 13px;
  background: var(--lavender);
  color: var(--c-text);
  font-family: var(--font);
  transition: border-color .15s, background .15s;
  outline: none;
}
.fi:focus { border-color: var(--coral); background: var(--c-surface); }
.fi-row { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 12px; }
select.fi {
  cursor: pointer; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M6 8L0 0h12z' fill='%236b6b8a'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center; padding-right: 32px;
}
textarea.fi { resize: vertical; min-height: 72px; }
.pw-w { position: relative; }
.pw-w .fi { padding-right: 42px; }
.pw-eye { position: absolute; right: 11px; top: 50%; transform: translateY(-50%); background: none; border: none; cursor: pointer; font-size: 14px; padding: 0; color: var(--c-hint); }
.pw-str { font-size: 11px; margin-top: 4px; min-height: 16px; }
.form-panel { background: var(--lavender); border-radius: var(--r-md); padding: 14px 16px; margin-bottom: 14px; border: .5px solid var(--c-border); }
.form-panel-title { font-size: 13px; font-weight: 700; color: var(--c-text); margin-bottom: 12px; }

/* ═══════════════════════════════
   BUTTONS
═══════════════════════════════ */
.btn {
  padding: 9px 18px;
  border-radius: var(--r-sm);
  border: .5px solid var(--c-border-md);
  background: var(--c-surface);
  cursor: pointer;
  font-size: 12px; font-weight: 700;
  font-family: var(--font);
  color: var(--c-text);
  transition: all .15s;
  display: inline-flex; align-items: center; gap: 5px;
}
.btn:hover { border-color: var(--coral); color: var(--coral); }
.btn:disabled { opacity: .45; cursor: not-allowed; }
.btn.pri { background: var(--coral); color: #fff; border-color: var(--coral); }
.btn.pri:hover:not(:disabled) { background: var(--coral-dk); border-color: var(--coral-dk); color: #fff; }
.btn.grn { background: var(--mint); color: var(--mint-dk); border-color: var(--mint); }
.btn.grn:hover:not(:disabled) { background: #3db8b0; color: #fff; }
.btn.ind { background: var(--indigo); color: #fff; border-color: var(--indigo); }
.btn.ind:hover:not(:disabled) { background: #1e1a3e; color: #fff; }
.btn.gold { background: var(--gold); color: var(--gold-dk); border-color: var(--gold); }
.btn.red  { background: #dc2626; color: #fff; border-color: #dc2626; }
.btn.amb  { background: #d97706; color: #fff; border-color: #d97706; }
.btn.ghost { background: transparent; border-color: var(--coral-md); color: var(--coral); }
.btn.sm { padding: 5px 11px; font-size: 11px; }
.brow { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.mt-10 { margin-top: 10px; }
.mb-12 { margin-bottom: 12px; }

/* ═══════════════════════════════
   BADGES
═══════════════════════════════ */
.badge { display: inline-flex; align-items: center; gap: 3px; padding: 2px 9px; border-radius: 10px; font-size: 10px; font-weight: 700; }
.b-m    { background: rgba(255,215,0,.2);  color: var(--gold-dk); }
.b-t    { background: rgba(78,205,196,.2); color: var(--mint-dk); }
.b-p    { background: rgba(255,87,51,.15); color: var(--coral-dk); }
.b-g    { background: #dcfce7; color: #166534; }
.b-a    { background: #fef3c7; color: #92400e; }
.b-r    { background: #fee2e2; color: #991b1b; }
.b-gray { background: var(--lavender); color: var(--c-muted); }
.b-ind  { background: rgba(45,38,84,.12); color: var(--indigo); }

/* ═══════════════════════════════
   ALERTS
═══════════════════════════════ */
.alert { border-radius: var(--r-sm); padding: 10px 13px; font-size: 12px; margin: 8px 0; display: flex; gap: 8px; align-items: flex-start; line-height: 1.6; }
.a-ok   { background: #dcfce7; border: .5px solid #86efac; color: #166534; }
.a-err  { background: #fee2e2; border: .5px solid #fca5a5; color: #991b1b; }
.a-warn { background: var(--gold-lt); border: .5px solid var(--gold); color: var(--gold-dk); }
.a-info { background: var(--indigo-lt); border: .5px solid var(--indigo-md); color: var(--indigo); }
.a-mast { background: rgba(45,38,84,.08); border: .5px solid var(--indigo-md); color: var(--indigo); }

/* ═══════════════════════════════
   METRICS
═══════════════════════════════ */
.metrics { display: grid; gap: 10px; margin-bottom: 14px; }
.metric { background: var(--lavender); border-radius: var(--r-sm); padding: 12px; text-align: center; border: .5px solid var(--c-border); }
.mn { font-size: 24px; font-weight: 900; color: var(--coral); }
.ml { font-size: 10px; color: var(--c-muted); margin-top: 3px; font-weight: 600; }

/* ═══════════════════════════════
   USER ROWS
═══════════════════════════════ */
.urow {
  display: flex; align-items: center; gap: 11px;
  padding: 12px 14px; border-radius: var(--r-md);
  border: .5px solid var(--c-border);
  margin-bottom: 8px; transition: all .15s;
}
.urow:hover { border-color: var(--coral-md); background: var(--coral-lt); }
.uav { width: 38px; height: 38px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.uin { flex: 1; min-width: 0; }
.unm { font-size: 13px; font-weight: 700; color: var(--c-text); }
.umt { font-size: 11px; color: var(--c-muted); margin-top: 2px; }
.uac { display: flex; gap: 5px; flex-shrink: 0; }
.blk { padding: 2px 7px; border-radius: 5px; font-size: 10px; font-weight: 700; background: #fee2e2; color: #991b1b; }
.act { padding: 2px 7px; border-radius: 5px; font-size: 10px; font-weight: 700; background: #dcfce7; color: #166534; }

/* ═══════════════════════════════
   ROLE GRID
═══════════════════════════════ */
.role-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 10px; margin-bottom: 14px; }
.role-card { background: var(--c-surface); border-radius: var(--r-md); border: .5px solid var(--c-border); padding: 14px; text-align: center; }
.role-ic   { font-size: 26px; margin-bottom: 6px; }
.role-name { font-size: 12px; font-weight: 700; margin-bottom: 3px; }
.role-desc { font-size: 10px; color: var(--c-muted); }

/* ═══════════════════════════════
   AUDIT
═══════════════════════════════ */
.audit-row { display: flex; align-items: flex-start; gap: 8px; padding: 9px; border-radius: 8px; margin-bottom: 6px; font-size: 11px; }
.audit-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; margin-top: 3px; }

/* ═══════════════════════════════
   EXPEDIENTE
═══════════════════════════════ */
.exp-header { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.exp-av     { font-size: 34px; }
.exp-name   { font-size: 16px; font-weight: 700; color: var(--c-text); }
.exp-meta   { font-size: 12px; color: var(--c-muted); margin-top: 2px; }
.exp-grid   { display: grid; grid-template-columns: repeat(2,1fr); gap: 6px; font-size: 12px; }
.exp-grid span { color: var(--c-muted); }

/* ═══════════════════════════════
   PATIENT PROFILE
═══════════════════════════════ */
.pac-profile  { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.pac-prof-av  { font-size: 40px; }
.pac-prof-name{ font-size: 17px; font-weight: 700; color: var(--c-text); }
.pac-prof-diag{ font-size: 12px; color: var(--c-muted); margin-top: 2px; }

/* ═══════════════════════════════
   HINT BOX
═══════════════════════════════ */
.hint-box {
  margin-top: 12px;
  background: var(--lavender);
  border-radius: 9px;
  padding: 10px 13px;
  font-size: 11px;
  color: var(--c-muted);
  border: .5px solid var(--c-border);
  line-height: 1.6;
}

/* ═══════════════════════════════
   IA BOX
═══════════════════════════════ */
.ia-section { background: var(--indigo-lt); border: .5px solid var(--indigo-md); border-radius: 11px; padding: 14px; margin-bottom: 10px; }
.ia-section-title { font-size: 12px; font-weight: 700; color: var(--indigo); margin-bottom: 7px; display: flex; align-items: center; gap: 6px; }
.ia-section-body  { font-size: 12px; color: var(--indigo); line-height: 1.7; }

/* ═══════════════════════════════
   SPINNER
═══════════════════════════════ */
.spin {
  display: inline-block; width: 13px; height: 13px;
  border: 2px solid var(--coral-md);
  border-top-color: var(--coral);
  border-radius: 50%;
  animation: sp .7s linear infinite;
  vertical-align: middle; margin-right: 6px;
}
@keyframes sp { to { transform: rotate(360deg); } }

/* ═══════════════════════════════
   RESPONSIVE
═══════════════════════════════ */
@media (max-width: 640px) {
  .topbar { padding: 0 12px; height: 54px; }
  .tb-logo-name { font-size: 18px; }
  .tb-logo-sub  { display: none; }
  .staff-btn { padding: 5px 9px; font-size: 10px; }
  .staff-btn span[style*="font-size"] { display: none; }
  .app-body { padding: 12px 14px; }
  .fi-row { grid-template-columns: 1fr; }
  .role-grid { grid-template-columns: 1fr; }
  .metrics { grid-template-columns: repeat(2,minmax(0,1fr)) !important; }
  .staff-dropdown { width: 100%; border-radius: 0; }
  .pac-box, .chpw-box { padding: 26px 18px; }
}

@media (max-width: 380px) {
  .uc-nm { max-width: 60px; }
  .tb-divider { display: none; }
}
