@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap");:root{--bg-primary:#0f1117;--bg-secondary:#1a1d27;--bg-card:#1e2230;--bg-hover:#252a3a;--bg-active:#2d3348;--text-primary:#e8eaf0;--text-secondary:#8b90a0;--text-muted:#5a5f73;--accent-primary:#6366f1;--accent-hover:#818cf8;--accent-soft:rgba(99,102,241,.12);--success:#22c55e;--success-soft:rgba(34,197,94,.12);--warning:#f59e0b;--warning-soft:rgba(245,158,11,.12);--danger:#ef4444;--danger-soft:rgba(239,68,68,.12);--info:#3b82f6;--info-soft:rgba(59,130,246,.12);--token-validado:#22c55e;--token-pendiente:#f59e0b;--token-sin:#ef4444;--estado-disponible:#374151;--estado-reservado:#3b82f6;--estado-confirmado:#6366f1;--estado-con-token:#22c55e;--estado-atendido:#10b981;--estado-ausente-con-aviso:#f59e0b;--estado-ausente-sin-aviso:#ef4444;--estado-cancelado:#6b7280;--estado-liberado:#a855f7;--border:#2a2e3e;--border-light:#353a4e;--shadow:0 4px 16px rgba(0,0,0,.3);--radius:8px;--radius-lg:12px;--radius-xl:16px;--sidebar-width:220px;--header-height:56px}*{margin:0;padding:0;box-sizing:border-box}body,html{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;height:100%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;font-family:inherit}.btn:hover:not(:disabled){filter:brightness(1.3);transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.2)}.btn:active:not(:disabled){transform:translateY(0);filter:brightness(1.1)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-active);border-color:var(--border-light)}.btn-danger{background:var(--danger-soft);color:var(--danger)}.btn-danger:hover{background:rgba(239,68,68,.2)}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{padding:6px;width:32px;height:32px;justify-content:center}.input,.select{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);color:var(--text-primary);font-size:13px;font-family:inherit;outline:none;transition:border-color .15s;width:100%}.input:focus,.select:focus{border-color:var(--accent-primary)}.input::placeholder{color:var(--text-muted)}input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}input[type=date]{color-scheme:dark}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:100px;font-size:11px;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.badge-reservado{background:rgba(59,130,246,.15);color:#3b82f6}.badge-con_token_validado{background:var(--success-soft);color:var(--success)}.badge-presente{background:rgba(5,150,105,.15);color:#059669}.badge-ausente_con_aviso{background:var(--warning-soft);color:var(--warning)}.badge-ausente_sin_aviso{background:var(--danger-soft);color:var(--danger)}.badge-cancelado_por_profesional{background:hsla(220,9%,46%,.15);color:#6b7280}.badge-cancelado_por_administracion{background:rgba(156,163,175,.15);color:#9ca3af}.badge-feriado{background:rgba(139,92,246,.15);color:#8b5cf6}.badge-liberado_para_reasignacion{background:rgba(168,85,247,.15);color:#a855f7}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:30}.sidebar-logo{padding:16px 20px;font-size:15px;font-weight:700;color:var(--accent-hover);border-bottom:1px solid var(--border);letter-spacing:-.02em}.sidebar-nav{flex:1 1;padding:12px 8px;display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius);color:var(--text-secondary);text-decoration:none;font-size:13px;font-weight:500;transition:all .12s}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-link.active{background:var(--accent-soft);color:var(--accent-hover)}.sidebar-section{padding:16px 12px 6px;font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.sidebar-user{padding:12px 16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.sidebar-user-name{font-size:12px;font-weight:500;color:var(--text-secondary)}.sidebar-user-role{font-size:10px;color:var(--text-muted);text-transform:uppercase}.main-content{margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column}.header{height:var(--header-height);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:var(--bg-secondary);position:-webkit-sticky;position:sticky;top:0;z-index:20}.header-title{font-size:16px;font-weight:600}.page-content{flex:1 1;padding:20px 24px}.agenda-grid{display:grid;grid-template-columns:60px repeat(var(--consultorios-count,8),1fr);grid-gap:1px;gap:1px;background:var(--border);border-radius:var(--radius-lg);overflow:hidden}.agenda-header-cell{background:var(--bg-secondary);padding:10px 8px;text-align:center;font-size:12px;font-weight:600;color:var(--text-secondary)}.agenda-time-cell{background:var(--bg-secondary);padding:6px 8px;font-size:11px;font-weight:500;color:var(--text-muted);text-align:right;display:flex;align-items:flex-start;justify-content:flex-end}.agenda-slot{background:var(--bg-primary);min-height:48px;padding:3px;cursor:pointer;transition:background .1s;position:relative}.agenda-slot:hover{background:var(--bg-hover)}.agenda-turno{border-radius:6px;padding:4px 8px;font-size:11px;cursor:pointer;height:100%;display:flex;flex-direction:column;gap:2px;transition:all .12s;border-left:3px solid}.agenda-turno.estado-reservado{background:rgba(59,130,246,.1);border-color:var(--estado-reservado)}.agenda-turno.estado-confirmado{background:var(--accent-soft);border-color:var(--accent-primary)}.agenda-turno.estado-con_token_validado{background:var(--success-soft);border-color:var(--success)}.agenda-turno.estado-atendido{background:rgba(16,185,129,.1);border-color:#10b981}.agenda-turno.estado-ausente_con_aviso{background:var(--warning-soft);border-color:var(--warning)}.agenda-turno.estado-ausente_sin_aviso{background:var(--danger-soft);border-color:var(--danger)}.agenda-turno.estado-cancelado{background:hsla(220,9%,46%,.08);border-color:#6b7280;opacity:.6}.agenda-turno.estado-liberado_para_reasignacion{background:rgba(168,85,247,.1);border-color:#a855f7}.agenda-turno:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.agenda-turno-paciente{font-weight:600;color:var(--text-primary)}.agenda-turno-paciente,.agenda-turno-profesional{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.agenda-turno-profesional{color:var(--text-secondary);font-size:10px}.agenda-turno-token{font-size:9px;font-weight:600;text-transform:uppercase}.token-ok{color:var(--token-validado)}.token-pendiente{color:var(--token-pendiente)}.detail-panel{position:fixed;right:0;top:0;bottom:0;width:380px;background:var(--bg-secondary);border-left:1px solid var(--border);z-index:40;display:flex;flex-direction:column;box-shadow:-8px 0 24px rgba(0,0,0,.3);transform:translateX(100%);transition:transform .2s ease}.detail-panel.open{transform:translateX(0)}.detail-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.detail-content{flex:1 1;overflow-y:auto;padding:16px 20px}.detail-section{margin-bottom:20px}.detail-section-title{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.detail-field{display:flex;justify-content:space-between;padding:6px 0;font-size:13px}.detail-field-label{color:var(--text-secondary)}.detail-field-value{color:var(--text-primary);font-weight:500}.detail-actions{padding:16px 20px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.login-card{width:400px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px 32px;box-shadow:var(--shadow)}.login-title{font-size:22px;font-weight:700;text-align:center;margin-bottom:8px;background:linear-gradient(135deg,var(--accent-hover),var(--accent-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login-subtitle{text-align:center;color:var(--text-secondary);font-size:13px;margin-bottom:32px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.form-error{font-size:12px;color:var(--danger);margin-top:4px}.filters-bar{gap:12px;margin-bottom:16px;flex-wrap:wrap}.date-nav,.filters-bar{display:flex;align-items:center}.date-nav{gap:8px}.date-nav-btn{background:var(--bg-hover);border:1px solid var(--border);color:var(--text-secondary);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);cursor:pointer;font-size:16px;transition:all .15s}.date-nav-btn:hover{background:var(--bg-active);color:var(--text-primary)}.date-display{font-size:15px;font-weight:600;min-width:180px;text-align:center}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px;width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.5)}.modal-title{font-size:18px;font-weight:700;margin-bottom:20px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:24px}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));grid-gap:12px;gap:12px;margin-bottom:20px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px}.stat-value{font-size:24px;font-weight:700;color:var(--text-primary)}.stat-label{font-size:11px;color:var(--text-secondary);margin-top:2px}.toast{position:fixed;top:20px;right:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px 20px;z-index:60;box-shadow:var(--shadow);animation:slideIn .2s ease}@keyframes slideIn{0%{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}.chat-panel-container{display:flex;height:100%;background:var(--bg-primary)}.chat-conversations-list{width:320px;border-right:1px solid var(--border);background:var(--bg-secondary);display:flex;flex-direction:column;overflow-y:auto}.chat-list-header{padding:16px 16px 12px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.chat-conv-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;cursor:pointer;border-bottom:1px solid rgba(42,46,62,.5);transition:background .12s}.chat-conv-item:hover{background:var(--bg-hover)}.chat-conv-item.active{background:var(--accent-soft);border-left:3px solid var(--accent-primary)}.chat-conv-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),#818cf8);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;flex-shrink:0}.chat-conv-info{flex:1 1;min-width:0}.chat-conv-name{font-size:13px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.chat-unread-badge{background:var(--accent-primary);color:#fff;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.chat-conv-preview{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.chat-conv-meta{display:flex;justify-content:space-between;align-items:center;margin-top:4px;font-size:10px;color:var(--text-muted)}.chat-bot-indicator{font-size:9px;font-weight:700;padding:1px 6px;border-radius:4px}.chat-bot-indicator.active{background:rgba(37,211,102,.15);color:#25d366}.chat-bot-indicator.inactive{background:rgba(239,68,68,.15);color:#ef4444}.chat-active-panel{flex:1 1;display:flex;flex-direction:column;min-width:0}.chat-active-header{padding:12px 20px;border-bottom:1px solid var(--border);background:var(--bg-secondary);display:flex;justify-content:space-between;align-items:center}.chat-messages{flex:1 1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:8px;background:var(--bg-primary)}.chat-message{display:flex;max-width:75%}.chat-message.incoming{align-self:flex-start}.chat-message.outgoing{align-self:flex-end}.chat-bubble{padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.5;position:relative}.chat-message.incoming .chat-bubble{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-bottom-left-radius:4px}.chat-message.outgoing .chat-bubble{background:linear-gradient(135deg,rgba(99,102,241,.2),rgba(99,102,241,.12));border:1px solid rgba(99,102,241,.2);color:var(--text-primary);border-bottom-right-radius:4px}.chat-bubble-content{word-break:break-word}.chat-bubble-meta{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:4px;font-size:10px;color:var(--text-muted)}.chat-input-bar{display:flex;align-items:center;gap:10px;padding:12px 20px;border-top:1px solid var(--border);background:var(--bg-secondary)}.chat-input{flex:1 1;padding:10px 14px;border:1px solid var(--border);border-radius:20px;background:var(--bg-primary);color:var(--text-primary);font-size:13px;font-family:inherit;outline:none;transition:border-color .15s}.chat-input:focus{border-color:var(--accent-primary)}.chat-input::placeholder{color:var(--text-muted)}.chat-bot-notice{display:flex;align-items:center;gap:8px;padding:12px 20px;border-top:1px solid var(--border);background:rgba(37,211,102,.06);font-size:12px;color:var(--text-muted)}.chat-empty-state{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary)}