/* ── Reset & Variables ───────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --g900:#0d2b1a; --g800:#114023; --g700:#1a6b4a; --g600:#2d9566;
  --g500:#3dab78; --g200:#a4d4bb; --g100:#c8e8d6; --g50:#e8f5ee;
  --gold:#d4a017; --gold-l:#f6e9c0; --gold-ll:#fdf6e3;
  --red:#c0392b;  --red-l:#f9d0cc; --red-ll:#fef4f3;
  --ink9:#0d2b1a; --ink7:#1e4533; --ink5:#4a7060; --ink4:#6b9080;
  --ink3:#9ab8ad; --ink2:#c8ddd7; --ink1:#e4efeb; --ink0:#f4faf7;
  --white:#fff;
  --sidebar-w:256px; --topbar-h:58px;
  --r:12px; --rs:8px;
  --sh:0 1px 3px rgba(13,43,26,.07),0 2px 8px rgba(13,43,26,.05);
  --sh-md:0 4px 16px rgba(13,43,26,.1),0 1px 4px rgba(13,43,26,.06);
  --t:.17s ease;
  --slot-h:52px;
  --time-w:60px;
}

body{font-family:'Inter',system-ui,sans-serif;background:var(--ink0);color:var(--ink9);
  display:flex;min-height:100vh;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}

/* ── SIDEBAR ─────────────────────────────────────── */
.sidebar{width:var(--sidebar-w);min-height:100vh;position:fixed;left:0;top:0;z-index:100;
  background:linear-gradient(170deg,var(--g900) 0%,var(--g700) 100%);
  display:flex;flex-direction:column;
  box-shadow:4px 0 24px rgba(13,43,26,.18)}

.sidebar-logo{display:flex;align-items:center;gap:12px;padding:22px 18px 18px;
  border-bottom:1px solid rgba(255,255,255,.07)}
.logo-svg{width:42px;height:42px;flex-shrink:0;filter:drop-shadow(0 2px 5px rgba(0,0,0,.2))}
.logo-title{display:block;font-size:19px;font-weight:700;color:var(--white);letter-spacing:-.4px}
.logo-sub{display:block;font-size:10.5px;color:var(--g200);text-transform:uppercase;letter-spacing:1px;font-weight:500}

.sidebar-nav{flex:1;padding:14px 10px;display:flex;flex-direction:column;gap:2px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;
  color:rgba(255,255,255,.6);text-decoration:none;font-size:13.5px;font-weight:500;cursor:pointer;
  transition:all var(--t);position:relative}
.nav-item svg{width:17px;height:17px;flex-shrink:0}
.nav-item:hover{background:rgba(255,255,255,.08);color:var(--white)}
.nav-item.active{background:rgba(255,255,255,.13);color:var(--white);font-weight:600}
.nav-item.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:55%;background:var(--gold);border-radius:0 3px 3px 0}
.nav-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;
  color:rgba(255,255,255,.35);padding:8px 12px 4px;}

.sidebar-footer{display:flex;align-items:center;gap:10px;padding:16px 16px;
  border-top:1px solid rgba(255,255,255,.07)}
.doctor-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;
  background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:var(--white);letter-spacing:.5px}
.doctor-name{font-size:13px;font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doctor-spec{font-size:11px;color:var(--g200);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.btn-logout{width:28px;height:28px;border-radius:7px;border:none;background:rgba(255,255,255,.1);
  color:rgba(255,255,255,.6);cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:all var(--t)}
.btn-logout:hover{background:rgba(192,57,43,.5);color:var(--white)}

/* ── MAIN ────────────────────────────────────────── */
.main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;overflow:hidden}

/* ── VIEWS ───────────────────────────────────────── */
.view{display:none;flex-direction:column;flex:1;overflow:hidden}
.view.active{display:flex}
.view-form{overflow-y:auto;padding:24px 28px}
.view-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;flex-shrink:0}
.page-title{font-size:20px;font-weight:700;color:var(--ink9);letter-spacing:-.3px}

/* ── CALENDAR HEADER & STATS BAR ─────────────────── */
.cal-header{display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px 10px;flex-shrink:0}
.cal-title{font-size:20px;font-weight:700;color:var(--ink9);letter-spacing:-.3px}
.cal-subtitle{font-size:12px;color:var(--ink4);margin-top:2px}

.btn-nueva-cita{display:inline-flex;align-items:center;gap:7px;
  padding:9px 18px;background:var(--g700);color:var(--white);
  border:none;border-radius:9px;font-size:13.5px;font-weight:600;font-family:inherit;
  cursor:pointer;transition:all var(--t);box-shadow:0 2px 8px rgba(26,107,74,.25)}
.btn-nueva-cita:hover{background:var(--g900);transform:translateY(-1px);box-shadow:0 4px 14px rgba(26,107,74,.35)}
.btn-nueva-cita svg{width:15px;height:15px}

.stats-bar{display:flex;align-items:center;gap:8px;padding:0 24px 12px;flex-shrink:0;flex-wrap:wrap}
.stat-pill{display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;background:var(--white);border:1px solid var(--ink1);
  border-radius:9999px;font-size:12.5px;box-shadow:var(--sh)}
.stat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.stat-num{font-weight:700;color:var(--ink9)}
.stat-lbl{color:var(--ink4);font-weight:500}
.stat-consultorio{gap:6px;color:var(--g700);font-weight:600;font-size:12.5px}

/* ── CALENDAR TOPBAR ─────────────────────────────── */
.cal-topbar{display:flex;align-items:center;justify-content:space-between;
  padding:10px 20px;background:var(--white);border-bottom:1px solid var(--ink1);
  flex-shrink:0;box-shadow:var(--sh)}

.cal-nav-group{display:flex;align-items:center;gap:4px}
.cal-nav-btn{width:34px;height:34px;border-radius:8px;border:1.5px solid var(--ink1);
  background:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--ink5);transition:all var(--t)}
.cal-nav-btn svg{width:16px;height:16px}
.cal-nav-btn:hover{background:var(--g50);color:var(--g700);border-color:var(--g200)}
.btn-hoy{padding:7px 14px;border-radius:8px;border:1.5px solid var(--ink1);background:var(--white);
  font-size:13px;font-weight:600;color:var(--g700);cursor:pointer;transition:all var(--t);font-family:inherit}
.btn-hoy:hover{background:var(--g700);color:var(--white);border-color:var(--g700)}

.cal-date-label{font-size:15px;font-weight:600;color:var(--ink9);letter-spacing:-.2px}

.cal-view-switcher{display:flex;background:var(--ink0);border-radius:9px;padding:3px;gap:2px;border:1px solid var(--ink1)}
.cvs-btn{padding:6px 14px;border-radius:7px;border:none;background:transparent;
  font-size:12.5px;font-weight:500;color:var(--ink4);cursor:pointer;transition:all var(--t);font-family:inherit}
.cvs-btn:hover{color:var(--g700)}
.cvs-btn.active{background:var(--white);color:var(--g700);font-weight:600;box-shadow:var(--sh)}

/* ── CALENDAR CONTAINER ──────────────────────────── */
.cal-container{flex:1;overflow:hidden;display:flex;flex-direction:column}

/* ══ WEEK VIEW ═══════════════════════════════════════ */
.cal-week-wrap{display:flex;flex-direction:column;height:100%;overflow:hidden}

.cal-week-header{display:flex;border-bottom:2px solid var(--ink1);background:var(--white);flex-shrink:0}
.cal-corner{width:var(--time-w);flex-shrink:0;border-right:1px solid var(--ink1)}
.cal-day-hdr{flex:1;padding:10px 6px 10px;text-align:center;border-right:1px solid var(--ink1);cursor:pointer;transition:background var(--t)}
.cal-day-hdr:hover{background:var(--g50)}
.cal-day-hdr.is-today .day-num{background:var(--g700);color:var(--white);border-radius:50%;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center}
.cal-day-hdr.no-work{background:var(--ink0);opacity:.5}
.day-name{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--ink4);margin-bottom:3px}
.day-num{display:inline-block;font-size:18px;font-weight:700;color:var(--ink9);line-height:1}

.cal-week-body{flex:1;overflow-y:auto;display:flex;scroll-behavior:smooth}

.cal-time-col{width:var(--time-w);flex-shrink:0;border-right:1px solid var(--ink1);background:var(--white);position:sticky;left:0;z-index:10}
.cal-time-slot{height:var(--slot-h);display:flex;align-items:flex-start;justify-content:flex-end;
  padding:4px 8px 0 0;border-bottom:1px solid var(--ink1);position:relative}
.cal-time-slot.half{border-bottom:1px dashed var(--ink1)}
.cal-time-label{font-size:10.5px;font-weight:500;color:var(--ink3);white-space:nowrap;margin-top:-7px}

.cal-days-grid{flex:1;display:grid;grid-template-columns:repeat(7,1fr)}
.cal-day-col{border-right:1px solid var(--ink1);position:relative}
.cal-day-col.no-work{background:repeating-linear-gradient(
  45deg,transparent,transparent 8px,rgba(0,0,0,.012) 8px,rgba(0,0,0,.012) 16px)}
.cal-day-body{position:relative;height:calc(var(--slot-h)*24)}

.cal-slot-line{position:absolute;left:0;right:0;border-bottom:1px solid var(--ink1);pointer-events:none}
.cal-slot-line.half{border-bottom:1px dashed var(--ink1);opacity:.5}
.cal-slot-line.clickable{cursor:pointer}
.cal-slot-line.clickable:hover{background:var(--g50);opacity:1}

/* ── CALENDAR EVENTS ─────────────────────────────── */
.cal-event{position:absolute;left:2px;right:2px;border-radius:6px;padding:4px 6px;
  font-size:11px;cursor:pointer;overflow:hidden;z-index:5;transition:filter var(--t),box-shadow var(--t);
  min-height:20px;border-left:3px solid rgba(0,0,0,.2)}
.cal-event:hover{filter:brightness(.93);box-shadow:0 2px 8px rgba(0,0,0,.15);z-index:10}
.cal-event.ev-confirmada{background:#1a6b4a;color:#fff;border-left-color:#0d4a28}
.cal-event.ev-confirmada .ev-time{opacity:.85}
.cal-event.ev-confirmada .ev-room{opacity:.75}
.cal-event.ev-pendiente {background:#d4a017;color:#fff;border-left-color:#a87c10}
.cal-event.ev-pendiente .ev-time{opacity:.85}
.cal-event.ev-pendiente .ev-room{opacity:.75}
.cal-event.ev-cancelada {background:#e8e8e8;color:#888;border-left-color:#bbb;opacity:.75}
.cal-event.ev-bloqueo   {background:#cdd8de;color:#4a6070;border-left-color:#8fa8b5;cursor:default}
.cal-event.ev-bloqueo .ev-name{font-style:italic}
.cal-event .ev-time{font-weight:600;display:block;line-height:1.2}
.cal-event .ev-name{display:block;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}
.cal-event .ev-room{font-size:10px;opacity:.7;display:block}

/* ══ DAY VIEW ════════════════════════════════════════ */
.cal-day-wrap{display:flex;flex-direction:column;height:100%}
.cal-day-sub-header{padding:12px 20px;border-bottom:1px solid var(--ink1);background:var(--white);
  font-size:14px;font-weight:600;color:var(--g700);flex-shrink:0}
.cal-day-body-scroll{flex:1;overflow-y:auto;display:flex}
.cal-day-timeline{flex:1;display:flex}
.cal-day-time-col{width:var(--time-w);flex-shrink:0;border-right:1px solid var(--ink1);background:var(--white);position:sticky;left:0}
.cal-day-events-col{flex:1;position:relative;height:calc(var(--slot-h)*24)}

/* ══ MONTH VIEW ══════════════════════════════════════ */
.cal-month-wrap{display:flex;flex-direction:column;height:100%}
.cal-month-dow{display:grid;grid-template-columns:repeat(7,1fr);
  border-bottom:2px solid var(--ink1);background:var(--white);flex-shrink:0}
.cal-dow-lbl{padding:10px 0;text-align:center;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.6px;color:var(--ink4)}
.cal-month-grid{flex:1;display:grid;grid-template-columns:repeat(7,1fr);
  grid-auto-rows:minmax(90px,1fr);overflow-y:auto;border-left:1px solid var(--ink1)}
.cal-month-cell{border-right:1px solid var(--ink1);border-bottom:1px solid var(--ink1);
  padding:6px;cursor:pointer;transition:background var(--t);position:relative;overflow:hidden}
.cal-month-cell:hover{background:var(--g50)}
.cal-month-cell.today{background:#ecf7f1}
.cal-month-cell.today .mcell-num{color:var(--g700);font-weight:700}
.cal-month-cell.other-month{background:var(--ink0)}
.cal-month-cell.other-month .mcell-num{color:var(--ink2)}
.cal-month-cell.no-work{background:repeating-linear-gradient(
  45deg,transparent,transparent 6px,rgba(0,0,0,.015) 6px,rgba(0,0,0,.015) 12px)}
.mcell-num{font-size:13px;font-weight:600;color:var(--ink7);margin-bottom:4px}
.mcell-dots{display:flex;flex-direction:column;gap:2px}
.mcell-dot{height:18px;border-radius:3px;font-size:10px;font-weight:500;padding:1px 5px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:16px}
.mcell-dot.ev-confirmada{background:#1a6b4a;color:#fff}
.mcell-dot.ev-pendiente {background:#d4a017;color:#fff}
.mcell-dot.ev-cancelada {background:#e0e0e0;color:#888}
.mcell-dot.ev-bloqueo   {background:#cdd8de;color:#4a6070}
.mcell-more{font-size:10px;color:var(--ink4);font-weight:600;margin-top:2px}

/* ── FORMS ───────────────────────────────────────── */
.form-wrap{max-width:720px}
.form-card{background:var(--white);border-radius:var(--r);box-shadow:var(--sh-md);border:1px solid var(--ink1);overflow:hidden}
.form-card-header{display:flex;align-items:flex-start;gap:14px;padding:24px 28px;
  background:linear-gradient(135deg,var(--g900),var(--g700));color:var(--white)}
.form-card-header svg{width:42px;height:42px;flex-shrink:0;opacity:.9}
.form-card-header h2{font-size:17px;font-weight:700;letter-spacing:-.2px}
.form-card-header p{font-size:12.5px;opacity:.7;margin-top:3px}
form{padding:24px 28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.form-group label{font-size:11.5px;font-weight:600;color:var(--ink7);text-transform:uppercase;letter-spacing:.4px}
.form-group input,.form-group select,.form-group textarea{
  padding:9px 13px;border:1.5px solid var(--ink1);border-radius:var(--rs);
  font-size:13.5px;font-family:inherit;color:var(--ink9);outline:none;
  transition:border-color var(--t),box-shadow var(--t);background:var(--ink0)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--g500);box-shadow:0 0 0 3px rgba(45,149,102,.12);background:var(--white)}
.form-group textarea{resize:vertical}
.form-group select{cursor:pointer}
.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:18px;border-top:1px solid var(--ink1)}

/* ── CONFIG ──────────────────────────────────────── */
.config-section{margin-bottom:26px;padding-bottom:22px;border-bottom:1px solid var(--ink1)}
.config-section:last-of-type{border-bottom:none}
.config-section-title{font-size:13px;font-weight:700;color:var(--ink7);text-transform:uppercase;letter-spacing:.6px;margin-bottom:14px}
.dias-grid{display:flex;gap:8px;flex-wrap:wrap}
.dia-chk{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer}
.dia-chk input{display:none}
.dia-chk span{width:40px;height:40px;border-radius:50%;border:2px solid var(--ink1);
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;
  color:var(--ink4);transition:all var(--t);user-select:none}
.dia-chk input:checked+span{background:var(--g700);border-color:var(--g700);color:var(--white)}
.dia-chk:hover span{border-color:var(--g500);color:var(--g700)}
.duracion-grid{display:flex;gap:8px;flex-wrap:wrap}
.dur-opt{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:9999px;
  border:1.5px solid var(--ink1);cursor:pointer;font-size:13px;font-weight:500;color:var(--ink5);transition:all var(--t)}
.dur-opt input{display:none}
.dur-opt:has(input:checked){background:var(--g700);border-color:var(--g700);color:var(--white)}
.dur-opt:hover{border-color:var(--g500);color:var(--g700)}
.cfg-input-inline{flex:1;padding:9px 13px;border:1.5px solid var(--ink1);border-radius:var(--rs);
  font-size:13.5px;font-family:inherit;color:var(--ink9);outline:none;background:var(--ink0)}

/* ── TIPO DE NEGOCIO ─────────────────────────────── */
.tipo-negocio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:600px){.tipo-negocio-grid{grid-template-columns:1fr 1fr}}

.tipo-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;
  border:2px solid var(--ink1);border-radius:var(--r);cursor:pointer;transition:all var(--t);
  background:var(--white);text-align:center;position:relative}
.tipo-card input{position:absolute;opacity:0;pointer-events:none}
.tipo-card:hover{border-color:var(--g200);background:var(--g50)}
.tipo-card:has(input:checked){border-color:var(--g700);background:var(--g50);box-shadow:0 0 0 3px rgba(26,107,74,.12)}
.tipo-icono{font-size:28px;line-height:1}
.tipo-label{font-size:12.5px;font-weight:600;color:var(--ink7);line-height:1.3}
.tipo-vocab{font-size:10.5px;color:var(--ink4);font-weight:400;margin-top:2px}
.tipo-card:has(input:checked) .tipo-label{color:var(--g700)}
.tipo-card:has(input:checked) .tipo-vocab{color:var(--g600)}

/* ── CITAS VIEW ──────────────────────────────────── */
.citas-view-list{display:flex;flex-direction:column;gap:8px;max-width:860px}
.cita-row{background:var(--white);border-radius:var(--r);padding:14px 18px;
  display:grid;grid-template-columns:56px 1fr auto auto;gap:14px;align-items:center;
  box-shadow:var(--sh);border:1px solid var(--ink1);border-left:4px solid var(--ink2);
  transition:all var(--t);cursor:pointer}
.cita-row:hover{transform:translateX(2px);box-shadow:var(--sh-md)}
.cita-row.est-confirmada{border-left-color:#1a6b4a}
.cita-row.est-pendiente {border-left-color:#d4a017}
.cita-row.est-cancelada {border-left-color:#c0392b;opacity:.7}
.cr-hora{font-size:16px;font-weight:700;color:var(--g700);text-align:center;line-height:1}
.cr-hora small{display:block;font-size:10px;color:var(--ink3);font-weight:400;margin-top:2px}
.cr-paciente{font-size:14px;font-weight:600;color:var(--ink9)}
.cr-motivo{font-size:12.5px;color:var(--ink5);margin-top:3px}
.cr-meta{font-size:11.5px;color:var(--ink3);margin-top:3px;display:flex;gap:8px;flex-wrap:wrap}
.cr-estado{flex-shrink:0}
.cr-acciones{display:flex;gap:6px;flex-shrink:0}
.estado-chip{padding:3px 10px;border-radius:9999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.chip-confirmada{background:var(--g50);color:var(--g700);border:1px solid var(--g100)}
.chip-pendiente {background:var(--gold-ll);color:var(--gold);border:1px solid var(--gold-l)}
.chip-cancelada {background:var(--red-ll);color:var(--red);border:1px solid var(--red-l)}

/* ── BLOQUEOS VIEW ───────────────────────────────── */
.bloqueos-list{display:flex;flex-direction:column;gap:10px;max-width:720px}
.bloqueo-card{background:var(--white);border-radius:var(--r);padding:16px 18px;
  display:flex;align-items:center;justify-content:space-between;
  box-shadow:var(--sh);border:1px solid var(--ink1);border-left:4px solid #8fa8b5}
.bloqueo-info{display:flex;align-items:center;gap:14px}
.bloqueo-icon{width:40px;height:40px;border-radius:10px;background:#e8eef0;
  display:flex;align-items:center;justify-content:center;color:#4a6070;flex-shrink:0}
.bloqueo-icon svg{width:18px;height:18px}
.bloqueo-titulo{font-size:14px;font-weight:600;color:var(--ink9)}
.bloqueo-horario{font-size:12.5px;color:var(--ink4);margin-top:2px}
.bloqueo-recurrente{display:inline-block;font-size:10.5px;font-weight:600;padding:2px 8px;
  border-radius:9999px;background:var(--g50);color:var(--g700);border:1px solid var(--g100);margin-top:4px}

/* ── UBICACIONES VIEW ────────────────────────────── */
.ubicaciones-list{display:flex;flex-direction:column;gap:12px;max-width:800px}

.ub-card{background:var(--white);border-radius:var(--r);box-shadow:var(--sh);
  border:1px solid var(--ink1);border-left:4px solid var(--g500);overflow:hidden;
  transition:box-shadow var(--t)}
.ub-card:hover{box-shadow:var(--sh-md)}

.ub-card-body{display:flex;align-items:flex-start;justify-content:space-between;
  gap:16px;padding:18px 20px}
.ub-card-left{display:flex;align-items:flex-start;gap:14px;flex:1;min-width:0}

.ub-icon-circle{width:44px;height:44px;border-radius:12px;background:var(--g50);
  border:2px solid var(--g100);display:flex;align-items:center;justify-content:center;
  font-size:22px;flex-shrink:0}

.ub-card-info{flex:1;min-width:0}
.ub-nombre{font-size:15px;font-weight:700;color:var(--ink9);margin-bottom:4px}
.ub-meta-row{font-size:12.5px;color:var(--ink4);margin-top:3px}

.ub-dias-row{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
.ub-dia-badge{display:inline-flex;align-items:center;padding:3px 9px;
  background:var(--g50);border:1px solid var(--g100);border-radius:9999px;
  font-size:11px;font-weight:600;color:var(--g700);white-space:nowrap}

.ub-card-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* ── MODAL UBICACIÓN ─────────────────────────────── */
.ub-schedule-section{margin-top:4px}

.ub-horario-grid{display:flex;flex-direction:column;gap:6px;
  border:1px solid var(--ink1);border-radius:var(--r);padding:6px;background:var(--ink0)}

.ub-day-row{display:grid;grid-template-columns:90px auto 1fr;align-items:center;
  gap:12px;padding:8px 10px;border-radius:var(--rs);background:var(--white);
  border:1px solid var(--ink1)}
.ub-day-name{font-size:13px;font-weight:600;color:var(--ink7)}

.ub-day-times{display:flex;align-items:center;gap:8px}
.ub-day-times input[type="time"]{width:100px;padding:6px 10px;border:1.5px solid var(--ink1);
  border-radius:var(--rs);font-size:13px;font-family:inherit;color:var(--ink9);
  background:var(--ink0);outline:none;transition:border-color var(--t)}
.ub-day-times input[type="time"]:focus{border-color:var(--g500);background:var(--white)}
.ub-time-sep{font-size:14px;color:var(--ink3);font-weight:500}

/* ── BUTTONS ─────────────────────────────────────── */
.btn-primary{padding:9px 20px;background:var(--g700);color:var(--white);border:none;border-radius:var(--rs);
  font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer;
  display:inline-flex;align-items:center;gap:7px;transition:all var(--t)}
.btn-primary:hover{background:var(--g900);box-shadow:0 4px 12px rgba(26,107,74,.3);transform:translateY(-1px)}
.btn-primary svg{width:15px;height:15px}
.btn-ghost{padding:9px 16px;background:var(--white);color:var(--ink5);
  border:1.5px solid var(--ink1);border-radius:var(--rs);font-size:13.5px;font-weight:500;
  font-family:inherit;cursor:pointer;transition:all var(--t);display:inline-flex;align-items:center;gap:6px}
.btn-ghost:hover{border-color:var(--ink2);color:var(--ink9);background:var(--ink0)}
.btn-ghost svg{width:14px;height:14px}
.btn-danger{padding:9px 16px;background:var(--red-ll);color:var(--red);border:1.5px solid var(--red-l);
  border-radius:var(--rs);font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--t)}
.btn-danger:hover{background:var(--red);color:var(--white)}
.btn-gold{padding:9px 16px;background:var(--gold-ll);color:var(--gold);border:1.5px solid var(--gold-l);
  border-radius:var(--rs);font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--t)}
.btn-gold:hover{background:var(--gold);color:var(--white)}
.btn-sm-danger{padding:5px 10px;background:transparent;color:var(--red);border:1px solid var(--red-l);
  border-radius:6px;font-size:12px;cursor:pointer;transition:all var(--t);font-family:inherit}
.btn-sm-danger:hover{background:var(--red);color:var(--white)}

/* ── TOGGLE ──────────────────────────────────────── */
.toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:13px;color:var(--ink7);font-weight:500}
.toggle-label input{display:none}
.toggle-switch{width:40px;height:22px;background:var(--ink2);border-radius:11px;position:relative;transition:background var(--t);flex-shrink:0}
.toggle-switch::after{content:'';position:absolute;width:16px;height:16px;background:var(--white);
  border-radius:50%;top:3px;left:3px;transition:transform var(--t);box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle-label input:checked~.toggle-switch{background:var(--g700)}
.toggle-label input:checked~.toggle-switch::after{transform:translateX(18px)}

/* ── MODAL ───────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(13,43,26,.4);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .18s ease}
.modal-overlay.hidden{display:none}
.modal{background:var(--white);border-radius:16px;width:460px;max-width:95vw;
  box-shadow:0 24px 60px rgba(13,43,26,.2);animation:slideUp .22s ease;overflow:hidden}
.modal-lg{width:540px}
.modal-xl{width:680px}
.modal-header{display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;border-bottom:1px solid var(--ink1)}
.modal-header h3{font-size:15px;font-weight:700;color:var(--ink9);text-transform:capitalize}
.modal-close{width:28px;height:28px;border-radius:50%;border:none;background:var(--ink1);
  display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink4);transition:all var(--t)}
.modal-close:hover{background:var(--red-l);color:var(--red)}
.modal-close svg{width:13px;height:13px}
.modal-body{padding:20px 22px;max-height:70vh;overflow-y:auto}
.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 22px;
  border-top:1px solid var(--ink1);background:var(--ink0)}

.mc-info{background:var(--g50);border:1px solid var(--g100);border-radius:var(--rs);
  padding:14px;font-size:13px;color:var(--g900);line-height:2}
.mc-estado{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:9999px;
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-left:8px}
.mc-confirmada{background:var(--g50);color:var(--g700);border:1px solid var(--g100)}
.mc-pendiente {background:var(--gold-ll);color:var(--gold);border:1px solid var(--gold-l)}
.mc-cancelada {background:var(--red-ll);color:var(--red);border:1px solid var(--red-l)}

/* ── TOAST ───────────────────────────────────────── */
.toast-container{position:fixed;bottom:22px;right:22px;display:flex;flex-direction:column;gap:8px;z-index:2000}
.toast{padding:12px 16px;border-radius:var(--rs);font-size:13.5px;font-weight:500;
  display:flex;align-items:center;gap:9px;box-shadow:var(--sh-md);animation:slideUp .25s ease;max-width:340px}
.toast svg{width:17px;height:17px;flex-shrink:0}
.toast-success{background:var(--g900);color:var(--white)}
.toast-error  {background:#7f1d1d;color:var(--white)}
.toast-info   {background:var(--g700);color:var(--white)}
.toast-out{animation:slideDown .25s ease forwards}

/* ── EMPTY / LOADING ─────────────────────────────── */
.empty-state{text-align:center;padding:48px 20px;background:var(--white);
  border-radius:var(--r);box-shadow:var(--sh);border:1px solid var(--ink1);max-width:800px}
.empty-state svg{width:52px;height:52px;color:var(--ink2);margin-bottom:14px}
.empty-state h3{font-size:15px;font-weight:600;color:var(--ink4)}
.empty-state p{font-size:13px;color:var(--ink3);margin-top:5px}
.spinner{width:30px;height:30px;border:3px solid var(--g100);border-top-color:var(--g700);
  border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}

/* ── VALIDACIÓN EN TIEMPO REAL ───────────────────── */
.input-error{
  border-color:#dc2626!important;
  background:#fff5f5!important;
  box-shadow:0 0 0 3px rgba(220,38,38,.12)!important;
}
.field-error-msg{
  display:block;margin-top:4px;
  font-size:12px;font-weight:500;color:#dc2626;
}

/* ── SPINNER DENTRO DEL BOTÓN ────────────────────── */
.btn-icon-spinner{
  width:18px;height:18px;
  animation:spin .7s linear infinite;
  flex-shrink:0;
}

/* ── MISC ────────────────────────────────────────── */
.hidden{display:none!important}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--ink2);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--ink3)}

/* ── ANIMATIONS ──────────────────────────────────── */
@keyframes fadeIn  {from{opacity:0}to{opacity:1}}
@keyframes slideUp {from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
@keyframes slideDown{from{opacity:1}to{opacity:0;transform:translateY(16px)}}
@keyframes spin    {to{transform:rotate(360deg)}}

/* ── NOW LINE ────────────────────────────────────── */
.cal-now-line{position:absolute;left:0;right:0;height:2px;background:#e74c3c;z-index:20;pointer-events:none}
.cal-now-dot{position:absolute;left:-5px;top:-4px;width:10px;height:10px;border-radius:50%;background:#e74c3c}

/* ── CITAS VIEW: smart sections ──────────────────── */
.citas-section-hdr{display:flex;align-items:center;gap:8px;
  margin:4px 0 10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--ink5)}
.section-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;display:inline-block}
.section-titulo{letter-spacing:1px}
.section-date-sub{font-size:11.5px;font-weight:400;color:var(--ink4);text-transform:none;letter-spacing:0}
.section-badge-gold{padding:2px 9px;border-radius:9999px;font-size:10px;font-weight:700;
  background:var(--gold-ll);color:var(--gold);border:1px solid var(--gold-l);
  text-transform:none;letter-spacing:0}

.cita-row.est-ahora{
  border-left-color:var(--gold) !important;
  box-shadow:0 0 0 2px rgba(212,160,23,.18),var(--sh) !important;
  background:var(--gold-ll)}
.cita-row.cita-pasada{opacity:.45}
.cita-row.cita-pasada:hover{opacity:.7}

.citas-fecha-grupo{margin-bottom:14px}
.citas-fecha-lbl{font-size:11.5px;font-weight:600;color:var(--ink4);
  margin-bottom:6px;padding-left:2px;text-transform:capitalize}

.citas-pasadas-toggle{display:flex;align-items:center;gap:8px;width:100%;
  background:none;border:1.5px dashed var(--ink1);border-radius:var(--rs);
  padding:10px 14px;cursor:pointer;font-family:inherit;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:1px;color:var(--ink4);transition:all var(--t)}
.citas-pasadas-toggle:hover{background:var(--white);color:var(--ink7);border-color:var(--ink2)}
.pasadas-count{padding:2px 9px;border-radius:9999px;background:var(--ink1);color:var(--ink5);
  font-size:10.5px;font-weight:700;text-transform:none;letter-spacing:0}
.toggle-arrow{margin-left:auto;font-size:13px;color:var(--ink3)}
.citas-pasadas-body{margin-top:8px}

.empty-mini{color:var(--ink3);font-size:13px;padding:14px;
  border:1.5px dashed var(--ink1);border-radius:var(--rs);text-align:center;margin-bottom:12px}

/* ══ BOTTOM NAV ══════════════════════════════════════ */
.bottom-nav{
  display:none; /* hidden on desktop */
  position:fixed;bottom:0;left:0;right:0;
  height:62px;
  background:var(--white);
  border-top:1px solid var(--ink1);
  box-shadow:0 -4px 20px rgba(13,43,26,.08);
  z-index:200;
  align-items:stretch;
  justify-content:space-around;
  padding-bottom:env(safe-area-inset-bottom,0px);
}
.bn-item{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;flex:1;padding:8px 4px 4px;
  border:none;background:transparent;cursor:pointer;
  color:var(--ink3);font-family:inherit;font-size:10px;font-weight:600;
  transition:color var(--t);border-radius:0;-webkit-tap-highlight-color:transparent;
}
.bn-item svg{width:22px;height:22px;transition:transform var(--t)}
.bn-item.active{color:var(--g700)}
.bn-item.active svg{transform:translateY(-1px)}
.bn-item:active svg{transform:scale(.9)}

/* ══ FAB NUEVA CITA ══════════════════════════════════ */
.fab-nueva-cita{
  display:none; /* hidden on desktop */
  position:fixed;
  bottom:74px; /* above bottom nav */
  right:18px;
  width:54px;height:54px;border-radius:50%;
  background:var(--g700);color:var(--white);
  border:none;box-shadow:0 4px 18px rgba(26,107,74,.45);
  cursor:pointer;align-items:center;justify-content:center;
  z-index:150;transition:all var(--t);-webkit-tap-highlight-color:transparent;
}
.fab-nueva-cita:hover{background:var(--g900);transform:scale(1.07);box-shadow:0 6px 24px rgba(26,107,74,.5)}
.fab-nueva-cita:active{transform:scale(.95)}
.fab-nueva-cita svg{width:24px;height:24px}

/* logo solo en móvil — oculto en desktop */
.mobile-logo-svg{display:none}

/* ══ BOTTOM SHEET ════════════════════════════════════ */
.bs-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.45);z-index:300;
  opacity:0;transition:opacity .25s ease;
}
.bs-overlay.open{display:block;opacity:1}

.bottom-sheet{
  display:none;position:fixed;left:0;right:0;bottom:0;
  background:var(--white);
  border-radius:20px 20px 0 0;
  box-shadow:0 -8px 40px rgba(0,0,0,.18);
  z-index:301;
  transform:translateY(100%);
  transition:transform .3s cubic-bezier(.32,1,.6,1);
  padding-bottom:env(safe-area-inset-bottom,0px);
}
.bottom-sheet.open{
  display:block;
  transform:translateY(0);
}

.bs-handle{
  width:40px;height:4px;border-radius:2px;
  background:var(--ink1);
  margin:12px auto 0;
}
.bs-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px 12px;
  border-bottom:1px solid var(--ink1);
}
.bs-title{
  font-size:17px;font-weight:700;color:var(--ink9);letter-spacing:-0.3px;
}
.bs-close{
  border:none;background:var(--ink0);border-radius:50%;
  width:30px;height:30px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--ink5);transition:background var(--t);
}
.bs-close:hover{background:var(--ink1)}
.bs-close svg{width:16px;height:16px}

.bs-body{padding:8px 12px 16px;display:flex;flex-direction:column;gap:4px}

.bs-item{
  display:flex;align-items:center;gap:14px;
  padding:13px 12px;border-radius:14px;border:none;
  background:transparent;cursor:pointer;width:100%;text-align:left;
  transition:background var(--t);-webkit-tap-highlight-color:transparent;
}
.bs-item:hover,.bs-item:active{background:var(--ink0)}

.bs-item-icon{
  width:42px;height:42px;border-radius:11px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.bs-item-icon svg{width:20px;height:20px}
.bs-icon-green{background:#e8f5ee;color:#1a6b4a}
.bs-icon-blue{background:#e8f0fb;color:#3b72e0}
.bs-icon-red{background:#fdecea;color:#c0392b}
.bs-icon-purple{background:#f2eafb;color:#7c3aed}

.bs-item-text{flex:1;display:flex;flex-direction:column;gap:2px}
.bs-item-label{font-size:15px;font-weight:600;color:var(--ink9)}
.bs-item-sub{font-size:12px;color:var(--ink4)}

.bs-chevron{width:18px;height:18px;color:var(--ink3);flex-shrink:0}

/* ══ RESPONSIVE (max-width: 768px) ═══════════════════ */
@media(max-width:768px){
  /* ── Variables ─────────────────────────────────── */
  :root{ --sidebar-w:0px; --bn-h:62px }

  /* ── Layout ────────────────────────────────────── */
  .sidebar{ display:none }
  .main{ margin-left:0; padding-bottom:calc(var(--bn-h) + env(safe-area-inset-bottom,0px)) }

  /* ── Bottom nav & FAB visible ─────────────────── */
  .bottom-nav{ display:flex }
  .fab-nueva-cita{ display:flex }

  /* ── Cal header: logo + título en línea limpia ── */
  .cal-header{
    padding:12px 14px 8px;
    flex-wrap:nowrap;
    align-items:center;
    gap:0;
  }
  .cal-header-left{
    display:flex;align-items:center;gap:10px;flex:1;min-width:0
  }
  .mobile-logo-svg{
    display:block;width:32px;height:32px;flex-shrink:0;
    filter:drop-shadow(0 1px 3px rgba(0,0,0,.15))
  }
  .cal-title{ font-size:16px }
  .cal-subtitle{ font-size:11px }
  /* Ocultar botón "Nueva Cita" del header — se usa FAB */
  .btn-nueva-cita{ display:none }

  /* ── Stats bar: 2×2 grid ───────────────────────── */
  .stats-bar{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:6px;
    padding:0 12px 10px;
  }
  .stat-pill{ justify-content:flex-start;font-size:12px }
  .stat-consultorio{ grid-column:1/-1;justify-content:center }

  /* ── Cal topbar ────────────────────────────────── */
  .cal-topbar{ padding:8px 12px;gap:6px }
  .cal-date-label{ font-size:13px }
  .cal-view-switcher .cvs-btn{ padding:5px 10px;font-size:11.5px }

  /* ── Calendar full width day view ─────────────── */
  .cal-day-sub-header{ padding:10px 14px;font-size:13px }

  /* ── View forms ────────────────────────────────── */
  .view-form{ padding:14px 14px 20px }
  .form-row{ grid-template-columns:1fr }
  .form-wrap{ max-width:100% }
  .view-header{ flex-wrap:wrap;gap:10px;padding:0 0 4px }
  .view-header > div{ width:100%;justify-content:flex-start }

  /* ── Cita rows: simplificar columnas ──────────── */
  .cita-row{
    grid-template-columns:52px 1fr auto;
    gap:10px;
    padding:12px 14px;
  }
  .cr-acciones{ grid-column:3;grid-row:1/3;align-self:center }
  .cr-estado{ display:none } /* eliminar chip — el color del borde indica estado */

  /* ── Tipo negocio ──────────────────────────────── */
  .tipo-negocio-grid{ grid-template-columns:1fr 1fr }

  /* ── Ub day row ────────────────────────────────── */
  .ub-day-row{ grid-template-columns:72px auto 1fr;gap:6px }
  .ub-day-times input[type="time"]{ width:84px;font-size:12px }

  /* ── Modal ─────────────────────────────────────── */
  .modal,.modal-lg,.modal-xl{
    width:100%;max-width:100%;
    border-radius:20px 20px 0 0;
    position:fixed;bottom:0;left:0;right:0;
    margin:0;max-height:90vh;
  }
  .modal-overlay{ align-items:flex-end }
  .modal-body{ max-height:55vh }

  /* ── Toast above bottom nav ────────────────────── */
  .toast-container{
    bottom:calc(var(--bn-h) + 10px);
    right:12px;left:12px;
  }
  .toast{ max-width:100% }

  /* ── Bloqueos ──────────────────────────────────── */
  .bloqueo-card{ flex-direction:column;align-items:flex-start;gap:10px }

  /* ── Ubicaciones ───────────────────────────────── */
  .ub-card-body{ flex-direction:column;gap:10px }
  .ub-card-actions{ width:100%;justify-content:flex-end }
}
