:root{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#eff6ff;--primary-border:#bfdbfe;--success:#059669;--success-hover:#047857;--success-light:#ecfdf5;--warning:#d97706;--warning-light:#fffbeb;--danger:#dc2626;--danger-hover:#b91c1c;--danger-light:#fef2f2;--purple:#7c3aed;--purple-light:#f5f3ff;--sidebar-bg:#0f172a;--sidebar-width:256px;--bg:#f1f5f9;--card:#fff;--text:#0f172a;--text-muted:#64748b;--border:#e2e8f0;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--radius-sm:4px;--radius:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#f1f5f9;background:var(--bg);color:#0f172a;color:var(--text);line-height:1.5}body,button{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--font)}button{cursor:pointer}input,select,textarea{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--font)}a{color:inherit;text-decoration:none}img{max-width:100%}.app-layout{display:flex;min-height:100vh}.main-area{flex:1 1;margin-left:256px;margin-left:var(--sidebar-width);min-height:100vh;min-width:0}.main-area.no-sidebar{margin-left:0}.page{max-width:1300px;padding:28px 32px}.sidebar{background:#0f172a;background:var(--sidebar-bg);bottom:0;display:flex;flex-direction:column;left:0;overflow-y:auto;position:fixed;top:0;width:256px;width:var(--sidebar-width);z-index:100}.sidebar-brand{align-items:center;border-bottom:1px solid #ffffff12;display:flex;gap:10px;padding:20px 16px 20px 20px}.brand-icon{flex-shrink:0;font-size:26px}.brand-name{color:#fff;font-size:16px;font-weight:700;letter-spacing:-.2px;line-height:1.2}.brand-sub{color:#475569;font-size:10px;letter-spacing:.5px;margin-top:2px;text-transform:uppercase}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;padding:12px 8px}.nav-section-label{color:#334155;font-size:10px;font-weight:600;letter-spacing:.8px;padding:12px 12px 6px;text-transform:uppercase}.nav-item{align-items:center;border-radius:8px;border-radius:var(--radius);color:#94a3b8;display:flex;font-size:13.5px;font-weight:500;gap:10px;padding:9px 12px;transition:background .12s,color .12s}.nav-item:hover{background:#ffffff0f;color:#cbd5e1}.nav-item.active{background:#2563eb33;color:#93c5fd}.nav-icon{flex-shrink:0;font-size:16px;text-align:center;width:20px}.sidebar-footer{border-top:1px solid #ffffff12;padding:12px}.user-card{border-radius:8px;border-radius:var(--radius);gap:10px;margin-bottom:8px;padding:8px}.user-avatar,.user-card{align-items:center;display:flex}.user-avatar{background:#2563eb;background:var(--primary);border-radius:9999px;border-radius:var(--radius-full);color:#fff;flex-shrink:0;font-size:14px;font-weight:700;height:34px;justify-content:center;width:34px}.user-info-text{min-width:0}.user-name{color:#e2e8f0;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role-badge{color:#64748b;font-size:10px;text-transform:capitalize}.logout-btn{align-items:center;background:#0000;border:1px solid #ef444440;border-radius:8px;border-radius:var(--radius);color:#fca5a5;display:flex;font-size:12.5px;font-weight:500;gap:6px;justify-content:center;padding:8px 12px;transition:background .12s;width:100%}.logout-btn:hover{background:#ef44441f}.page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px}.page-title{color:#0f172a;color:var(--text);font-size:22px;font-weight:700;line-height:1.2}.page-subtitle{color:#64748b;color:var(--text-muted);font-size:13px;margin-top:2px}.card{background:#fff;background:var(--card);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;box-shadow:var(--shadow)}.card-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;gap:12px;justify-content:space-between;padding:16px 20px}.card-title{color:#0f172a;color:var(--text);font-size:15px;font-weight:600}.card-body{padding:20px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.stat-card{align-items:center;background:#fff;background:var(--card);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius-lg);border-top:3px solid #0000;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;box-shadow:var(--shadow);display:flex;gap:14px;padding:18px 20px}.stat-card--blue{border-top-color:#2563eb;border-top-color:var(--primary)}.stat-card--green{border-top-color:#059669;border-top-color:var(--success)}.stat-card--orange{border-top-color:#d97706;border-top-color:var(--warning)}.stat-card--purple{border-top-color:#7c3aed;border-top-color:var(--purple)}.stat-icon{flex-shrink:0;font-size:28px}.stat-value{color:#0f172a;color:var(--text);font-size:26px;font-weight:700;line-height:1}.stat-label{font-size:12px;font-weight:500;margin-top:3px}.stat-label,.stat-sub{color:#64748b;color:var(--text-muted)}.stat-sub{font-size:11px;margin-top:1px}.table-wrapper{overflow-x:auto}.table{border-collapse:collapse;font-size:13.5px;width:100%}.table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);color:#64748b;color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:.5px;padding:10px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.table td{border-bottom:1px solid #f1f5f9;color:#0f172a;color:var(--text);padding:11px 14px;vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#fafbfc}.table .cell-muted{color:#64748b;color:var(--text-muted);font-size:12px}.badge,.table .cell-bold{font-weight:600}.badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:11.5px;padding:3px 10px;white-space:nowrap}.badge--confirmada{background:#ecfdf5;background:var(--success-light);color:#059669;color:var(--success)}.badge--pendiente{background:#fffbeb;background:var(--warning-light);color:#d97706;color:var(--warning)}.badge--cancelada{background:#fef2f2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.badge--completada{background:#eff6ff;background:var(--primary-light);color:#2563eb;color:var(--primary)}.badge--reagendada{background:#f5f3ff;background:var(--purple-light);color:#7c3aed;color:var(--purple)}.badge--director{background:#fef3c7;color:#92400e}.badge--administrador{background:#eff6ff;background:var(--primary-light);color:#2563eb;color:var(--primary)}.badge--apoyo{background:#f3f4f6;color:#374151}.badge--low-stock{background:#fef2f2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.badge--ok{background:#ecfdf5;background:var(--success-light);color:#059669;color:var(--success)}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius);display:inline-flex;font-size:13.5px;font-weight:500;gap:6px;justify-content:center;line-height:1;padding:8px 16px;transition:background .12s,box-shadow .12s;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn--primary{background:#2563eb;background:var(--primary);color:#fff}.btn--primary:hover:not(:disabled){background:#1d4ed8;background:var(--primary-hover)}.btn--success{background:#059669;background:var(--success);color:#fff}.btn--success:hover:not(:disabled){background:#047857;background:var(--success-hover)}.btn--danger{background:#dc2626;background:var(--danger);color:#fff}.btn--danger:hover:not(:disabled){background:#b91c1c;background:var(--danger-hover)}.btn--secondary{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);color:#0f172a;color:var(--text)}.btn--secondary:hover:not(:disabled){background:#f8fafc}.btn--ghost{background:#0000;border:1px solid #0000;color:#64748b;color:var(--text-muted)}.btn--ghost:hover:not(:disabled){background:#f1f5f9;color:#0f172a;color:var(--text)}.btn--sm{font-size:12.5px;padding:5px 10px}.btn--xs{font-size:11.5px;padding:3px 8px}.btn--icon{aspect-ratio:1;border-radius:4px;border-radius:var(--radius-sm);padding:6px}.btn--full{width:100%}.toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:14px}.toolbar-left,.toolbar-right{align-items:center;display:flex;gap:8px}.search-input-wrapper{align-items:center;display:flex;position:relative}.search-icon{color:#64748b;color:var(--text-muted);font-size:14px;left:10px;pointer-events:none;position:absolute}.search-input{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#0f172a;color:var(--text);font-size:13.5px;outline:none;padding:7px 12px 7px 32px;transition:border-color .12s,box-shadow .12s;width:260px}.search-input:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.search-input::placeholder{color:#cbd5e1}.form-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.form-grid--3{grid-template-columns:1fr 1fr 1fr}.form-full{grid-column:1/-1}.form-section{margin-bottom:20px}.form-section-title{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);color:#64748b;color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:.6px;margin-bottom:12px;padding-bottom:8px;text-transform:uppercase}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{color:#0f172a;color:var(--text);font-size:12.5px;font-weight:500}.form-label.required:after{color:#dc2626;color:var(--danger);content:" *"}.form-control{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#0f172a;color:var(--text);font-size:13.5px;line-height:1.4;outline:none;padding:8px 11px;transition:border-color .12s,box-shadow .12s;width:100%}.form-control:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-control::placeholder{color:#cbd5e1}.form-control:disabled{background:#f8fafc;color:#64748b;color:var(--text-muted)}textarea.form-control{min-height:72px;resize:vertical}select.form-control{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='m0 0 5 6 5-6z' fill='%2364748B'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a8c;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:200}.modal{background:#fff;border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-height:90vh;max-width:680px;width:100%}.modal--lg{max-width:860px}.modal--sm{max-width:440px}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;flex-shrink:0;justify-content:space-between;padding:18px 22px}.modal-title{font-size:16px;font-weight:600}.modal-close{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#64748b;color:var(--text-muted);display:flex;font-size:18px;height:30px;justify-content:center;line-height:1;transition:background .12s;width:30px}.modal-close:hover{background:#e2e8f0;color:#0f172a;color:var(--text)}.modal-body{flex:1 1;overflow-y:auto;padding:22px}.modal-footer{border-top:1px solid #e2e8f0;border-top:1px solid var(--border);display:flex;flex-shrink:0;gap:8px;justify-content:flex-end;padding:14px 22px}.alert{align-items:center;border-radius:8px;border-radius:var(--radius);display:flex;font-size:13.5px;gap:8px;padding:10px 14px}.alert--success{background:#ecfdf5;background:var(--success-light);border:1px solid #a7f3d0;color:#065f46}.alert--warning{background:#fffbeb;background:var(--warning-light);border:1px solid #fde68a;color:#92400e}.alert--danger{background:#fef2f2;background:var(--danger-light);border:1px solid #fecaca;color:#991b1b}.alert--info{background:#eff6ff;background:var(--primary-light);border:1px solid #bfdbfe;border:1px solid var(--primary-border);color:#1e40af}.toast-container{display:flex;flex-direction:column;gap:8px;pointer-events:none;position:fixed;right:20px;top:20px;z-index:400}.toast{align-items:center;animation:toastIn .2s ease;border-radius:8px;border-radius:var(--radius);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);display:flex;font-size:13.5px;font-weight:500;gap:10px;justify-content:space-between;max-width:380px;min-width:280px;padding:12px 16px;pointer-events:all}.toast--success{background:#065f46;color:#fff}.toast--error{background:#991b1b;color:#fff}.toast--warning{background:#92400e;color:#fff}.toast-close{background:none;border:none;color:inherit;flex-shrink:0;font-size:18px;line-height:1;opacity:.65;padding:0}.toast-close:hover{opacity:1}@keyframes toastIn{0%{opacity:0;transform:translateX(110%)}to{opacity:1;transform:translateX(0)}}.login-page{align-items:center;background:linear-gradient(145deg,#0f172a,#1e3a5f 60%,#0f172a);display:flex;justify-content:center;min-height:100vh;padding:16px}.login-card{background:#fff;border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);max-width:380px;padding:36px 40px;width:100%}.login-brand{margin-bottom:28px;text-align:center}.login-brand-icon{display:block;font-size:44px;margin-bottom:10px}.login-brand-name{color:#0f172a;color:var(--text);font-size:22px;font-weight:700}.login-brand-sub{color:#64748b;color:var(--text-muted);font-size:13px;margin-top:3px}.login-form{display:flex;flex-direction:column;gap:14px}.login-error{background:#fef2f2;background:var(--danger-light);border:1px solid #fecaca;border-radius:8px;border-radius:var(--radius);color:#991b1b;font-size:13px;padding:10px 12px}.dashboard-header-date{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius);color:#64748b;color:var(--text-muted);font-size:13px;padding:6px 12px}.appointment-row-now{background:#eff6ff!important;background:var(--primary-light)!important}.empty-state{color:#64748b;color:var(--text-muted);padding:40px 24px;text-align:center}.empty-state-icon{display:block;font-size:36px;margin-bottom:10px}.empty-state-text{font-size:14px}.loading-wrap{color:#64748b;color:var(--text-muted);font-size:14px;gap:10px;justify-content:center;padding:64px}.confirm-delete,.loading-wrap{align-items:center;display:flex}.confirm-delete{font-size:13px;gap:6px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.gap-2{gap:8px}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.text-right{text-align:right}.text-center{text-align:center}.text-muted{color:#64748b;color:var(--text-muted)}.font-bold{font-weight:700}.font-medium{font-weight:500}.text-sm{font-size:12.5px}.w-full{width:100%}.divider{background:#e2e8f0;background:var(--border);height:1px;margin:16px 0}@media (max-width:900px){:root{--sidebar-width:0px}.sidebar{display:none}.main-area{margin-left:0}.page{padding:16px}.stats-grid{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}.form-full{grid-column:span 1}}@media (max-width:560px){.stats-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.35b9ad8d.css.map*/