@charset "UTF-8";.dashboard{margin:0 auto;max-width:1400px;padding:20px}.dashboard h1{color:#333;font-size:28px;margin-bottom:10px}.dashboard h2{color:#666;font-size:18px;font-weight:400;margin-bottom:30px}.stats-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{align-items:center;border-left:4px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:15px;padding:20px;transition:all .3s ease}.stat-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.stat-card.primary{background:linear-gradient(135deg,#fff,#f0f7ff);border-left-color:#4a90e2}.stat-card.success{background:linear-gradient(135deg,#fff,#f1f8f4);border-left-color:#4caf50}.stat-card.info{background:linear-gradient(135deg,#fff,#e0f7fa);border-left-color:#00bcd4}.stat-card.accent{background:linear-gradient(135deg,#fff,#f3e5f5);border-left-color:#9c27b0}.stat-card.money{background:linear-gradient(135deg,#fff,#fff3e0);border-left-color:#ff9800}.stat-card.warning{background:linear-gradient(135deg,#fff,#fbe9e7);border-left-color:#ff5722}.stat-icon{font-size:36px;opacity:.8}.stat-content{flex:1 1}.stat-content h3{color:#666;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.stat-number{color:#333;font-size:32px;line-height:1;margin:0}.stat-detail{color:#999;font-size:12px;margin:5px 0 0}.metricas-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:25px}.metricas-section h3{color:#333;font-size:18px;font-weight:600;margin:0 0 20px}.metricas-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.metrica-item{background:#f8f9fa;border-left:3px solid #e0e0e0;border-radius:8px;display:flex;flex-direction:column;gap:8px;padding:15px}.metrica-label{color:#666;font-size:13px;font-weight:600}.metrica-valor{font-size:24px;font-weight:700}.metrica-valor.success{color:#4caf50}.metrica-valor.warning{color:#ff9800}.metrica-valor.danger{color:#f44336}.turnos-section{border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:25px}.turnos-section h3{color:#333;font-size:18px;font-weight:600;margin:0 0 20px}.turnos-list{display:flex;flex-direction:column;gap:12px}.turno-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;padding:15px;transition:all .2s ease}.turno-item:hover{background:#e9ecef;transform:translateX(4px)}.turno-info-dashboard{flex:1 1}.turno-info-dashboard h4{color:#333;font-size:16px;margin:0 0 5px}.turno-info-dashboard p{color:#666;font-size:14px;margin:0}.turno-estado{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;padding:6px 12px}.turno-estado.pendiente{background:#fff3e0;color:#e65100}.turno-estado.completado{background:#e8f5e9;color:#2e7d32}.turno-estado.cancelado{background:#ffebee;color:#c62828}.turno-acciones-dashboard{display:flex;gap:8px}.btn-turno{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .3s ease}.btn-turno.completar{background:#e8f5e9;color:#2e7d32}.btn-turno.completar:hover{background:#4caf50;color:#fff}.btn-turno.cancelar{background:#ffebee;color:#c62828}.btn-turno.cancelar:hover{background:#f44336;color:#fff}.acciones-rapidas{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:30px}.accion-card{background:#fff;border:2px solid #0000;border-radius:12px;box-shadow:0 2px 8px #0000001a;cursor:pointer;padding:20px;text-align:center;transition:all .3s ease}.accion-card:hover{border-color:#4a90e2;box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.accion-card .icono{font-size:36px;margin-bottom:10px}.accion-card h4{color:#333;font-size:14px;font-weight:600;margin:0}.dashboard>div:first-of-type{color:#666;font-size:18px;padding:50px;text-align:center}.error{background:#ffebee;border-radius:12px;color:#c62828;font-weight:600;padding:20px}@media (max-width:768px){.dashboard{padding:10px}.dashboard h1{font-size:24px}.stats-grid{gap:15px;grid-template-columns:1fr}.stat-card{padding:15px}.stat-icon{font-size:28px}.stat-number{font-size:24px}.metricas-grid{grid-template-columns:1fr}.turno-item{align-items:flex-start;flex-direction:column;gap:10px}.turno-acciones-dashboard{justify-content:flex-start;width:100%}}.graficos-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin-bottom:30px}.grafico-card{border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px}.grafico-card h3{color:#333;font-size:18px;font-weight:600;margin-bottom:20px}.dashboard-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.dashboard-subtitle{color:#666;font-size:16px;margin-top:5px}.btn-refresh{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-refresh:hover{background:#0056b3;transform:translateY(-2px)}.no-turnos{color:#999;font-style:italic;padding:20px;text-align:center}@media (max-width:1200px){.dashboard{max-width:100%;padding:15px}.stats-grid{gap:15px;grid-template-columns:repeat(2,1fr)}.stat-card{padding:15px}.stat-icon{font-size:28px}.stat-number{font-size:24px}.graficos-grid{grid-template-columns:1fr}.metricas-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:992px){.dashboard{padding:12px}.dashboard h1{font-size:22px;margin-bottom:8px}.dashboard h2{font-size:16px;margin-bottom:15px}.stats-grid{gap:12px;grid-template-columns:repeat(2,1fr)}.stat-card{gap:10px;padding:12px}.stat-content h3{font-size:12px}.stat-number{font-size:20px}.stat-icon{font-size:24px}.metricas-grid{grid-template-columns:1fr}.grafico-card{padding:15px}.grafico-card h3{font-size:16px}}@media (max-width:768px){.dashboard{padding:10px}.dashboard h1{font-size:20px;margin-bottom:5px}.dashboard h2{font-size:14px;margin-bottom:12px}.stats-grid{gap:10px;grid-template-columns:1fr;margin-bottom:15px}.stat-card{flex-direction:row;padding:12px}.stat-icon{font-size:20px;min-width:30px}.stat-number{font-size:18px}.stat-content h3{font-size:11px}.stat-detail{font-size:10px}.dashboard-header{align-items:stretch;flex-direction:column;gap:10px}.btn-refresh{padding:12px;width:100%}.metricas-section,.turnos-section{margin-bottom:15px;padding:15px}.metricas-section h3,.turnos-section h3{font-size:16px;margin-bottom:15px}.metricas-grid{gap:12px;grid-template-columns:1fr}.metrica-item{padding:12px}.metrica-label{font-size:12px}.metrica-valor{font-size:20px}.turno-item{align-items:flex-start;flex-direction:column;padding:12px}.turno-info-dashboard{width:100%}.turno-status{text-align:right;width:100%}.grafico-card{margin-bottom:20px;padding:15px}.grafico-card h3{font-size:16px;margin-bottom:15px}}@media (max-width:576px){.dashboard{padding:8px}.dashboard h1{font-size:18px;margin-bottom:5px}.dashboard h2{font-size:13px;margin-bottom:10px}.stats-grid{gap:8px;grid-template-columns:1fr}.stat-card{padding:10px}.stat-icon{font-size:18px}.stat-number{font-size:16px}.stat-content h3{font-size:10px}.stat-detail{font-size:9px}.btn-refresh{font-size:14px;padding:10px}.metricas-section,.turnos-section{margin-bottom:10px;padding:12px}.metricas-section h3,.turnos-section h3{font-size:14px;margin-bottom:12px}.metricas-grid{gap:10px;grid-template-columns:1fr}.metrica-item{padding:10px}.metrica-label{font-size:11px}.metrica-valor{font-size:18px}.turno-item{margin-bottom:8px;padding:10px}.turno-info-dashboard{width:100%}.grafico-card{margin-bottom:15px;padding:12px}.grafico-card h3{font-size:14px;margin-bottom:12px}.no-turnos{font-size:14px;padding:20px 10px}.loading{font-size:14px;padding:30px 10px}}.historial-container{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 10px 30px #00000026;margin:1.5rem 0;padding:2rem}.historial-container h2{color:#fff;font-size:1.8rem;margin-bottom:1.5rem;text-shadow:2px 2px 4px #0003}.seleccionar-paciente{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:2rem}.seleccionar-paciente h3{color:#667eea;font-size:1.3rem;margin-bottom:1.5rem}.paciente-header{background:#fff3;border-radius:8px;margin-bottom:1.5rem;padding:1rem 1.5rem}.paciente-header h3{color:#fff;font-size:1.2rem;margin:0}.btn-cambiar-paciente{background:#fff;border:none;border-radius:6px;color:#667eea;cursor:pointer;font-weight:600;padding:.5rem 1rem;transition:all .3s ease}.btn-cambiar-paciente:hover{background:#f0f0f0;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.input-con-resultados input{padding:12px 16px}.input-con-resultados input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.resultados-busqueda{max-height:300px}.historial-tabs{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:8px;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;padding:.5rem}.historial-tabs button{background:#ffffff26;border:2px solid #0000;border-radius:6px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem 1.25rem;transition:all .3s ease;white-space:nowrap}.historial-tabs button:hover{background:#ffffff40;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.historial-tabs button.active{background:#fff;border-color:#fff;box-shadow:0 6px 20px #0003;color:#667eea}.historial-content{animation:fadeIn .3s ease;background:#fff;border-radius:8px;box-shadow:0 4px 15px #0000001a;min-height:400px;padding:2rem}.loading{color:#667eea;font-size:1.1rem;font-weight:600;padding:3rem}.btn-agregar{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:1.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-agregar:hover{background:#5568d3;box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-agregar:active{box-shadow:0 2px 6px #667eea4d;transform:translateY(0)}.formulario{background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.formulario>div:not(.form-buttons){margin-bottom:1.25rem}.formulario label{color:#2d3748;display:block;font-weight:600;margin-bottom:.5rem}.formulario input,.formulario select,.formulario textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:1rem;padding:.75rem;transition:all .3s ease;width:100%}.formulario input:focus,.formulario select:focus,.formulario textarea:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-row{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.form-row>div{display:flex;flex-direction:column}.form-buttons{border-top:1px solid #ddd;display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem}.btn-guardar,.btn-guardar-pequeño{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.btn-guardar-pequeño:hover,.btn-guardar:hover{background:#218838;box-shadow:0 4px 12px #28a74566;transform:translateY(-2px)}.btn-guardar-pequeño:disabled,.btn-guardar:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-cancelar,.btn-cancelar-pequeño{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.btn-cancelar-pequeño:hover,.btn-cancelar:hover{background:#5a6268;box-shadow:0 4px 12px #6c757d66;transform:translateY(-2px)}.btn-cancelar-pequeño:disabled,.btn-cancelar:disabled{cursor:not-allowed;opacity:.6}.btn-cancelar-pequeño,.btn-guardar-pequeño{font-size:.9rem;padding:.5rem 1rem}.no-data{font-style:italic;padding:2rem}.no-data-section{background:#f8f9fa;border-radius:8px;padding:2rem;text-align:center}.diagnosticos-lista,.evoluciones-lista,.notas-lista{display:flex;flex-direction:column;gap:1.25rem}.diagnostico-card,.evolucion-card,.nota-card,.objetivo-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:1.5rem;transition:all .3s ease}.diagnostico-card:hover,.evolucion-card:hover,.nota-card:hover,.objetivo-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.nota-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.nota-header h4{color:#667eea;margin:0 0 .25rem}.nota-header small{color:#999}.codigo-cie10,.duracion{background:#667eea;border-radius:20px;color:#fff;font-size:.85rem;font-weight:600;padding:.25rem .75rem}.codigo-cie10{background:#764ba2}.info-section{background:#f8f9fa;border-left:3px solid #667eea;border-radius:4px;margin:1rem 0;padding:1rem}.info-section strong{color:#667eea;display:block;margin-bottom:.5rem}.info-section p{color:#2d3748;line-height:1.6;margin:0}.avances-area{background:#e8f5e9;border-left:3px solid #28a745;border-radius:4px;margin:1rem 0;padding:1rem}.avances-area p,.avances-area strong{color:#1b5e20}.antecedentes-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.antecedente-card{background:linear-gradient(135deg,#667eea15,#764ba215);border:1px solid #667eea30;border-radius:8px;padding:1.5rem;transition:all .3s ease}.antecedente-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.antecedente-header{border-bottom:2px solid #667eea;margin-bottom:1rem;padding-bottom:.75rem}.antecedente-header h4{color:#667eea;margin:0}.antecedente-contenido{color:#2d3748;line-height:1.6;margin:0}.antecedente-campo{margin-bottom:1.5rem}.progreso-section{background:#f8f9fa;border-radius:6px;margin-top:1rem;padding:1rem}.progreso-header{align-items:center;display:flex;font-weight:600;justify-content:space-between;margin-bottom:.75rem}.progreso-valor{color:#667eea;font-size:1.1rem}.progreso-input{align-items:center;display:flex;gap:.5rem}.progreso-input input{border:1px solid #ddd;border-radius:4px;padding:.5rem;text-align:center;width:80px}.progreso-bar{background:#e0e0e0;border-radius:12px;height:24px;margin-bottom:.75rem;overflow:hidden;position:relative;width:100%}.progreso-fill{align-items:center;color:#fff;display:flex;font-size:.75rem;font-weight:600;height:100%;justify-content:center;position:relative;transition:width .3s ease}.progreso-fill span{text-shadow:0 1px 2px #0003}.progreso-botones{display:flex;gap:.5rem;justify-content:flex-end}.btn-editar-progreso{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;padding:.5rem 1rem;transition:all .3s ease;width:100%}.btn-editar-progreso:hover{background:#5568d3}.objetivo-descripcion{background:#f8f9fa;border-radius:4px;color:#2d3748;line-height:1.6;margin:.75rem 0;padding:.75rem}.objetivo-fechas{color:#667eea;display:flex;gap:1rem;margin-top:1rem}.proximo-seguimiento{border-top:1px solid #e0e0e0;color:#667eea;font-weight:600;margin-top:1rem;padding-top:1rem}@media (max-width:768px){.historial-container{padding:1rem}.historial-container h2{font-size:1.3rem}.historial-tabs{flex-direction:column}.historial-tabs button{text-align:left;width:100%}.historial-content{min-height:300px;padding:1rem}.nota-header{align-items:flex-start;flex-direction:column}.form-row{grid-template-columns:1fr}.form-buttons{flex-direction:column}.form-buttons button{width:100%}.antecedentes-grid{grid-template-columns:1fr}.progreso-header{align-items:flex-start;flex-direction:column;gap:.5rem}.btn-editar-progreso{width:100%}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.loading{animation:pulse 1.5s ease-in-out infinite}button:disabled:hover{transform:none!important}.formulario input:required:after,.formulario textarea:required:after{color:#dc3545;content:" *"}.formulario label{align-items:center;display:flex;gap:.5rem}.perfil-paciente{background:#f5f5f5;min-height:100vh;padding:20px}.perfil-container{margin:0 auto;max-width:900px}.perfil-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.perfil-header h2{color:#333;margin:0}.perfil-actions{display:flex;gap:10px}.btn-cancelar,.btn-editar,.btn-guardar,.btn-volver{border:none;border-radius:6px;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-editar{background:#667eea}.btn-editar:hover{background:#5568d3}.btn-guardar{background:#4caf50;color:#fff}.btn-guardar:hover{background:#45a049}.btn-cancelar{background:#ff6b6b;color:#fff}.btn-cancelar:hover{background:#ff5252}.btn-volver{background:#9e9e9e}.btn-volver:hover{background:#757575}.foto-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:20px;text-align:center}.foto-preview{border:4px solid #667eea;border-radius:50%;display:block;object-fit:cover}.foto-placeholder,.foto-preview{height:150px;margin:0 auto 15px;width:150px}.foto-placeholder{align-items:center;background:#f0f0f0;border:4px dashed #999;border-radius:50%;color:#999;display:flex;justify-content:center}.foto-input{display:none}.btn-subir-foto{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px}.btn-subir-foto:hover{background:#5568d3}.perfil-seccion{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:20px}.seccion-titulo{align-items:center;border-bottom:3px solid #667eea;color:#333;display:flex;font-size:1.3rem;font-weight:700;gap:10px;margin:0 0 20px;padding-bottom:12px}.seccion-titulo:before{background:#667eea;border-radius:2px;content:"";height:24px;width:4px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:15px}.form-row-full{grid-column:1/-1}.form-group{display:flex;flex-direction:column}.form-group.full{grid-column:1/-1}.form-group label{color:#333;font-size:.95rem}.form-group input,.form-group select,.form-group textarea{border:2px solid #ddd;border-radius:6px;font-family:inherit;font-size:.95rem;padding:12px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group textarea{min-height:100px}.contactos-group{background:#f9f9f9;border-radius:8px;margin-bottom:15px;padding:15px}.contactos-group h4{align-items:center;color:#667eea;display:flex;gap:8px;margin:0 0 15px}.alergias-list,.condiciones-list,.medicamentos-list{background:#f9f9f9;border-radius:8px;margin-bottom:15px;padding:15px}.alergias-list h4,.condiciones-list h4,.medicamentos-list h4{color:#667eea;margin:0 0 10px}.item-badge{background:#e3f2fd;border-radius:20px;color:#1976d2;display:inline-block;font-size:.9rem;font-weight:600;margin:5px 5px 5px 0;padding:6px 12px}.item-badge.alergia{background:#ffebee;color:#c62828}.item-badge.condicion{background:#f3e5f5;color:#6a1b9a}.notas-privadas{background:#fffbea;border-left:4px solid #ff9800;border-radius:6px;padding:15px}.notas-privadas label{color:#333;display:block;font-weight:600;margin-bottom:10px}.notas-privadas textarea{border:2px solid #ffe0b2;border-radius:6px;font-family:inherit;min-height:120px;padding:12px;resize:vertical;width:100%}.notas-privadas textarea:focus{border-color:#ff9800;box-shadow:0 0 0 3px #ff98001a;outline:none}.estado-tratamiento{background:#f1f8e9;border-left:4px solid #4caf50;border-radius:6px;padding:15px}.estado-tratamiento label{color:#333;display:block;font-weight:600;margin-bottom:10px}.estado-tratamiento select{border:2px solid #c6e9a8;border-radius:6px;padding:10px;width:100%}.valor-readonly{background:#f5f5f5;border:1px solid #ddd;border-radius:6px;color:#555;padding:12px;word-break:break-word}.valor-readonly-vacio{color:#999;font-style:italic}.valor-readonly-array{display:flex;flex-wrap:wrap;gap:8px}.perfil-mensaje{animation:slideDown .3s ease;border-radius:6px;font-weight:600;margin-bottom:20px;padding:15px}.perfil-mensaje.exito{background:#c8e6c9;color:#2e7d32}.perfil-mensaje.error{background:#fcc;color:#d32f2f}.perfil-mensaje.info{background:#b3e5fc;color:#01579b}.perfil-loading{color:#667eea;padding:40px;text-align:center}@media (max-width:768px){.perfil-header{align-items:flex-start;flex-direction:column;gap:15px}.perfil-actions{flex-wrap:wrap;width:100%}.btn-cancelar,.btn-editar,.btn-guardar,.btn-volver{flex:1 1;min-width:100px}.form-row{grid-template-columns:1fr}.contactos-group{margin-bottom:15px}.perfil-seccion{padding:15px}}.confirm-dialog-overlay{align-items:center;animation:fadeIn .2s ease-in-out;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.confirm-dialog{animation:slideUp .3s ease-out;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-width:400px;width:90%}.confirm-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.confirm-header h2{color:#333;font-size:18px;font-weight:600;margin:0}.confirm-close{align-items:center;background:none;border:none;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.confirm-close:hover{background-color:#f0f0f0;color:#333}.confirm-body{padding:20px}.confirm-message{color:#333;font-size:15px;line-height:1.5;margin:0 0 10px}.confirm-detail{background-color:#f5f5f5;border-radius:4px;color:#666;font-size:14px;font-weight:500;margin:10px 0;padding:10px;word-break:break-word}.confirm-warning{background-color:#fff3cd;border-left:4px solid #ffc107;border-radius:4px;color:#856404;font-size:13px;margin:15px 0 0;padding:12px}.confirm-footer{border-top:1px solid #e0e0e0;display:flex;gap:10px;justify-content:flex-end;padding:20px}.confirm-footer button{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.confirm-footer .btn-secondary{background-color:#e0e0e0;color:#333}.confirm-footer .btn-secondary:hover{background-color:#d0d0d0}.confirm-footer .btn-primary{background-color:#3b8bfa;color:#fff}.confirm-footer .btn-primary:hover{background-color:#2570e0}.confirm-footer .btn-danger{background-color:#dc3545;color:#fff}.confirm-footer .btn-danger:hover{background-color:#c82333}@media (max-width:600px){.confirm-dialog{width:95%}.confirm-body,.confirm-header{padding:15px}.confirm-footer{flex-direction:column;gap:8px;padding:15px}.confirm-footer button{width:100%}}.turnos-page{padding:20px}.filtros,.page-header{margin-bottom:20px}.filtros{background:#f5f5f5;border-radius:8px;padding:15px}.filtros label{font-weight:600}.filtros input[type=date]{border:2px solid #e0e0e0;border-radius:6px;font-size:14px;padding:8px 12px}.turnos-list{grid-gap:15px;display:grid;gap:15px}.turno-card{align-items:flex-start;border:2px solid #e0e0e0;transition:all .3s ease}.turno-card:hover{box-shadow:0 4px 12px #0000001a}.turno-info h3{color:#333;font-size:18px;margin:0 0 10px}.turno-info p{color:#666;font-size:14px;margin:5px 0}.turno-info .estado{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;margin-top:10px;padding:4px 12px}.turno-info .estado.pendiente{background:#fff3e0;color:#e65100}.turno-info .estado.completado{background:#e8f5e9;color:#2e7d32}.turno-info .estado.cancelado{background:#ffebee;color:#c62828}.turno-info .estado.no_show{background:#f5f5f5;color:#666}.turno-actions{align-items:flex-start;flex-wrap:wrap;gap:8px}.btn-icon{align-items:center;background:#0000;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;padding:0;transition:all .3s ease;width:40px}.btn-icon.btn-editar:hover{background:#e3f2fd;border-color:#2196f3;transform:scale(1.1)}.btn-icon.btn-eliminar:hover{background:#ffebee;border-color:#f44336;transform:scale(1.1)}.btn-small{background:#fff;border:2px solid #e0e0e0;border-radius:6px;font-size:13px;padding:6px 12px;transition:all .3s ease}.btn-small.btn-success{border-color:#4caf50;color:#2e7d32}.btn-small.btn-success:hover{background:#e8f5e9;transform:translateY(-2px)}.btn-small.btn-warning{border-color:#ff9800;color:#e65100}.btn-small.btn-warning:hover{background:#fff3e0;transform:translateY(-2px)}.modal input,.modal select,.modal textarea{border:2px solid #e0e0e0;border-radius:8px;font-size:14px;padding:12px;transition:all .3s ease}.modal input:focus,.modal select:focus,.modal textarea:focus{border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a;outline:none}.btn-primary{border-radius:8px;font-weight:600;padding:12px 24px;transition:all .3s ease}@media (max-width:1024px){.turnos-page{padding:15px}.page-header{gap:10px}.turno-card{flex-direction:column;padding:15px}.turno-actions{gap:8px;justify-content:flex-start;width:100%}}@media (max-width:768px){.turnos-page{padding:10px}.page-header{align-items:stretch;flex-direction:column;gap:10px}.page-header h1{font-size:20px;margin-bottom:0}.page-header button{width:100%}.filtros{margin-bottom:15px;padding:12px}.filtros label{align-items:flex-start;flex-direction:column;gap:5px}.filtros input[type=date]{font-size:16px;padding:10px;width:100%}.turno-card{gap:10px;padding:12px}.turno-info{width:100%}.turno-info h3{font-size:16px;margin-bottom:8px}.turno-info p{font-size:13px}.turno-actions{flex-wrap:wrap;gap:6px;width:100%}.turno-actions button{flex:1 1;font-size:12px;min-width:80px;padding:8px}.modal{max-height:90vh;padding:15px;width:95%}.modal-header{padding:12px}.modal-title{font-size:18px}.modal-body{padding:12px}}@media (max-width:576px){.turnos-page{padding:8px}.page-header{gap:8px}.page-header h1{font-size:18px}.page-header button{font-size:14px;padding:10px}.filtros{padding:10px}.filtros label{gap:3px}.turno-card{border-radius:8px;gap:8px;padding:10px}.turno-info h3{font-size:14px;margin-bottom:5px}.turno-info p{font-size:12px;margin:2px 0}.turno-actions{gap:4px}.turno-actions button{font-size:11px;padding:8px}.modal{padding:12px;width:98%}.modal-header{margin-bottom:10px;padding:10px}.modal-title{font-size:16px}.modal-body{padding:10px}.modal-footer{gap:6px;padding:10px}.modal-footer button{flex:1 1;font-size:13px;padding:8px}}@media (max-width:480px){.turnos-page{padding:5px}.page-header{flex-direction:column;gap:6px}.turno-card{padding:8px}.turno-info h3{font-size:13px}.turno-info p{font-size:11px}}@media (hover:none) and (pointer:coarse){.turno-card{padding:15px}.turno-actions button,button{min-height:44px}button{min-width:44px}}.busqueda-paciente-container{margin-bottom:15px;position:relative}.busqueda-paciente-container label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.input-con-resultados{position:relative}.input-con-resultados input{border:2px solid #e0e0e0;border-radius:8px;font-size:14px;padding:12px;transition:all .3s ease;width:100%}.input-con-resultados input:focus{border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a;outline:none}.resultados-busqueda{background:#fff;border:2px solid #e0e0e0;border-radius:0 0 8px 8px;border-top:none;box-shadow:0 4px 6px #0000001a;left:0;max-height:250px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.resultado-item{border-bottom:1px solid #f0f0f0;cursor:pointer;padding:12px;transition:all .2s ease}.resultado-item:last-child{border-bottom:none}.resultado-item:hover{background:#f8f9fa;transform:translateX(4px)}.resultado-nombre{color:#333;font-size:14px;font-weight:600;margin-bottom:4px}.resultado-info{color:#666;font-size:12px}.no-resultados{color:#999;font-size:14px;padding:20px;text-align:center}.paciente-seleccionado{align-items:center;background:#e8f5e9;border:2px solid #4caf50;border-radius:8px;color:#2e7d32;display:flex;font-size:14px;justify-content:space-between;margin-top:10px;padding:12px}.paciente-seleccionado strong{color:#1b5e20}.btn-limpiar{background:#0000;color:#d32f2f;font-size:18px;padding:0 8px;transition:all .2s ease}.btn-limpiar:hover{color:#b71c1c;transform:scale(1.2)}.modal{border-radius:12px;padding:30px}.modal h3{color:#333;font-size:24px;margin-bottom:20px}.modal form{display:flex;flex-direction:column;gap:15px}.modal input[type=date],.modal input[type=number],.modal select{border:2px solid #e0e0e0;border-radius:8px;font-size:14px;padding:12px;transition:all .3s ease}.modal input:focus,.modal select:focus{border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a;outline:none}.modal-actions{margin-top:20px}.modal-actions button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:12px;transition:all .3s ease}.btn-primary{background:#4a90e2}.btn-primary:hover{background:#357abd;box-shadow:0 4px 8px #4a90e24d}.btn-secondary{background:#f5f5f5;color:#666}.btn-secondary:hover{background:#e0e0e0}.pagos-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:20px}.pago-card{align-items:flex-start;background:#fff;border:2px solid #e0e0e0;border-radius:12px;display:flex;justify-content:space-between;padding:20px;transition:all .3s ease}.pago-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.pago-info{flex:1 1}.pago-info h3{color:#333;font-size:18px;margin:0 0 10px}.pago-info p{color:#666;font-size:14px;margin:5px 0}.pago-info .estado{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;margin-top:10px;padding:4px 12px}.pago-info .estado.pagado{background:#e8f5e9;color:#2e7d32}.pago-info .estado.pendiente{background:#fff3e0;color:#e65100}.pago-acciones{display:flex;flex-direction:column;gap:8px}.btn-editar,.btn-eliminar{align-items:center;background:#0000;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;transition:all .3s ease;width:40px}.btn-editar:hover{background:#e3f2fd;border-color:#2196f3;transform:scale(1.1)}.btn-eliminar:hover{background:#ffebee;border-color:#f44336;transform:scale(1.1)}@media (max-width:768px){.modal{padding:20px;width:95%}.modal h3{font-size:20px}.resultados-busqueda{max-height:200px}}.buscador-container{background:#f8f9fa;border-radius:8px;margin:20px 0;padding:20px}.buscador-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:20px}.buscador-header h2{color:#333;font-size:24px;margin:0}.buscador-input{border:2px solid #ddd;border-radius:6px;font-size:14px;padding:10px 15px;transition:all .3s;width:300px}.buscador-input:focus{border-color:#4caf50;box-shadow:0 0 5px #4caf504d;outline:none}.pacientes-tabla{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;overflow-x:auto}.pacientes-tabla table{border-collapse:collapse;width:100%}.pacientes-tabla th{background:#4caf50;color:#fff;font-weight:600;padding:12px;text-align:left}.pacientes-tabla td{border-bottom:1px solid #eee;padding:12px}.pacientes-tabla tr:hover{background:#f5f5f5}.sin-resultados{color:#999;padding:30px!important;text-align:center}.btn-editar,.btn-ver{border:none;border-radius:4px;cursor:pointer;font-size:12px;margin-right:5px;padding:6px 12px;transition:all .2s}.btn-ver{background:#ff9800;color:#fff}.btn-ver:hover{background:#f57c00}.paginacion-container{align-items:center;background:#fff;border-radius:8px;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-top:15px;padding:15px}.info-registros{color:#666;font-size:14px;margin:0}.controles-paginacion{align-items:center;display:flex;gap:10px}.btn-pagina{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:13px;padding:8px 15px;transition:all .2s}.btn-pagina:hover:not(:disabled){background:#4caf50;border-color:#4caf50;color:#fff}.btn-pagina:disabled{cursor:not-allowed;opacity:.5}.numero-pagina{color:#666;font-size:14px;font-weight:600;min-width:120px;text-align:center}.loading{font-style:italic;padding:20px}@media (max-width:768px){.buscador-input{width:100%}.buscador-header{flex-direction:column}.pacientes-tabla{font-size:12px}.pacientes-tabla td{padding:8px}.btn-editar,.btn-ver{font-size:11px;padding:4px 8px}.paginacion-container{align-items:stretch;flex-direction:column}.controles-paginacion{justify-content:center}}.filtrador-container{background:#f8f9fa;border-radius:8px;margin:20px 0;padding:20px}.filtrador-header{margin-bottom:20px}.filtrador-header h2{color:#333;font-size:24px;margin:0}.filtros-section{grid-gap:15px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px;padding:15px}.filtro-grupo{display:flex;flex-direction:column}.filtro-grupo label{color:#555;font-size:13px;font-weight:600;margin-bottom:5px}.filtro-input,.filtro-select{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:10px;transition:all .3s}.filtro-input:focus,.filtro-select:focus{border-color:#2196f3;box-shadow:0 0 5px #2196f34d;outline:none}.btn-limpiar{align-self:flex-end;background:#f44336;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:10px 15px;transition:all .2s}.btn-limpiar:hover{background:#d32f2f}.turnos-tabla{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;overflow-x:auto}.turnos-tabla table{border-collapse:collapse;width:100%}.turnos-tabla th{background:#2196f3;color:#fff;font-weight:600;padding:12px;text-align:left}.turnos-tabla td{border-bottom:1px solid #eee;padding:12px}.turnos-tabla tr:hover{background:#f5f5f5}.turnos-tabla tr.estado-pendiente{border-left:4px solid #ff9800}.turnos-tabla tr.estado-completado{border-left:4px solid #4caf50}.turnos-tabla tr.estado-cancelado{border-left:4px solid #f44336}.badge{border-radius:12px;padding:4px 8px;text-transform:capitalize}.badge-completado{background:#d4edda;color:#155724}.btn-editar{background:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:6px 12px;transition:all .2s}.btn-editar:hover{background:#1976d2}@media (max-width:768px){.filtros-section{grid-template-columns:1fr}.btn-limpiar{align-self:center}.turnos-tabla{font-size:12px}.turnos-tabla td{padding:8px}.turnos-tabla th{font-size:12px}}.recuperacion-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.recuperacion-box{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:450px;padding:40px;width:100%}.recuperacion-box h1{color:#333;font-size:28px;margin:0 0 30px;text-align:center}.formulario-paso h2{color:#555;font-size:20px;margin:0 0 15px;text-align:center}.descripcion{color:#999;font-size:14px;line-height:1.5;text-align:center}.descripcion,.form-grupo{margin-bottom:20px}.form-grupo label{color:#555;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-input{border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:14px;padding:12px;transition:all .3s;width:100%}.form-input:focus{border-color:#667eea;box-shadow:0 0 8px #667eea4d;outline:none}.btn-enviar,.btn-volver{border:none;border-radius:6px;cursor:pointer;font-size:16px;font-weight:600;margin-bottom:10px;padding:12px;transition:all .3s;width:100%}.btn-enviar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-enviar:hover:not(:disabled){box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.btn-enviar:disabled{cursor:not-allowed;opacity:.7}.btn-volver{background:#f0f0f0;color:#333}.btn-volver:hover{background:#e0e0e0}.mensaje-error,.mensaje-exito{animation:slideDown .3s ease;border-radius:6px;font-weight:600;margin-bottom:15px;padding:12px 16px;text-align:center}.link-login{border-top:1px solid #eee;margin-top:20px;padding-top:20px;text-align:center}.link-login p{color:#999;font-size:14px;margin:0}.link-login a{color:#667eea;font-weight:600;text-decoration:none;transition:color .3s}.link-login a:hover{color:#764ba2;text-decoration:underline}@media (max-width:600px){.recuperacion-box{padding:30px 20px}.recuperacion-box h1{font-size:24px}.formulario-paso h2{font-size:18px}.btn-enviar,.btn-volver,.form-input{font-size:16px}}.rbc-btn{color:inherit;font:inherit;margin:0}button.rbc-btn{-webkit-appearance:button;appearance:button;cursor:pointer;overflow:visible;text-transform:none}button[disabled].rbc-btn{cursor:not-allowed}button.rbc-input::-moz-focus-inner{border:0;padding:0}.rbc-calendar{align-items:stretch;box-sizing:border-box;display:flex;flex-direction:column;height:100%}.rbc-m-b-negative-3{margin-bottom:-3px}.rbc-h-full{height:100%}.rbc-calendar *,.rbc-calendar :after,.rbc-calendar :before{box-sizing:inherit}.rbc-abs-full,.rbc-row-bg{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.rbc-ellipsis,.rbc-event-label,.rbc-row-segment .rbc-event-content,.rbc-show-more{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rbc-rtl{direction:rtl}.rbc-off-range{color:#999}.rbc-off-range-bg{background:#e6e6e6}.rbc-header{border-bottom:1px solid #ddd;flex:1 0;font-size:90%;font-weight:700;min-height:0;overflow:hidden;padding:0 3px;text-align:center;text-overflow:ellipsis;vertical-align:middle;white-space:nowrap}.rbc-header+.rbc-header{border-left:1px solid #ddd}.rbc-rtl .rbc-header+.rbc-header{border-left-width:0;border-right:1px solid #ddd}.rbc-header>a,.rbc-header>a:active,.rbc-header>a:visited{color:inherit;text-decoration:none}.rbc-button-link{background:none;border:none;color:inherit;cursor:pointer;margin:0;padding:0;-webkit-user-select:text;user-select:text}.rbc-row-content{position:relative;user-select:none;-webkit-user-select:none;z-index:4}.rbc-row-content-scrollable{display:flex;flex-direction:column;height:100%}.rbc-row-content-scrollable .rbc-row-content-scroll-container{-ms-overflow-style:none;height:100%;overflow-y:scroll;scrollbar-width:none}.rbc-row-content-scrollable .rbc-row-content-scroll-container::-webkit-scrollbar{display:none}.rbc-today{background-color:#eaf6ff}.rbc-toolbar{align-items:center;display:flex;flex-wrap:wrap;font-size:16px;justify-content:center;margin-bottom:10px}.rbc-toolbar .rbc-toolbar-label{flex-grow:1;padding:0 10px;text-align:center}.rbc-toolbar button{background:none;background-image:none;border:1px solid #ccc;border-radius:4px;color:#373a3c;display:inline-block;line-height:normal;margin:0;padding:.375rem 1rem;text-align:center;vertical-align:middle;white-space:nowrap}.rbc-toolbar button.rbc-active,.rbc-toolbar button:active{background-color:#e6e6e6;background-image:none;border-color:#adadad;box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.rbc-toolbar button.rbc-active:focus,.rbc-toolbar button.rbc-active:hover,.rbc-toolbar button:active:focus,.rbc-toolbar button:active:hover{background-color:#d4d4d4;border-color:#8c8c8c;color:#373a3c}.rbc-toolbar button:focus,.rbc-toolbar button:hover{background-color:#e6e6e6;border-color:#adadad;color:#373a3c}.rbc-toolbar button:hover{cursor:pointer}.rbc-btn-group{display:inline-block;white-space:nowrap}.rbc-btn-group>button:first-child:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.rbc-btn-group>button:last-child:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.rbc-rtl .rbc-btn-group>button:first-child:not(:last-child){border-radius:4px;border-bottom-left-radius:0;border-top-left-radius:0}.rbc-rtl .rbc-btn-group>button:last-child:not(:first-child){border-radius:4px;border-bottom-right-radius:0;border-top-right-radius:0}.rbc-btn-group>button:not(:first-child):not(:last-child){border-radius:0}.rbc-btn-group button+button{margin-left:-1px}.rbc-rtl .rbc-btn-group button+button{margin-left:0;margin-right:-1px}.rbc-btn-group+.rbc-btn-group,.rbc-btn-group+button{margin-left:10px}@media (max-width:767px){.rbc-toolbar{flex-direction:column}}.rbc-day-slot .rbc-background-event,.rbc-event{background-color:#3174ad;border:none;border-radius:5px;box-shadow:none;box-sizing:border-box;color:#fff;cursor:pointer;margin:0;padding:2px 5px;text-align:left;width:100%}.rbc-day-slot .rbc-slot-selecting .rbc-background-event,.rbc-slot-selecting .rbc-day-slot .rbc-background-event,.rbc-slot-selecting .rbc-event{cursor:inherit;pointer-events:none}.rbc-day-slot .rbc-selected.rbc-background-event,.rbc-event.rbc-selected{background-color:#265985}.rbc-day-slot .rbc-background-event:focus,.rbc-event:focus{outline:5px auto #3b99fc}.rbc-event-label{font-size:80%}.rbc-event-overlaps{box-shadow:-1px 1px 5px 0 #33333380}.rbc-event-continues-prior{border-bottom-left-radius:0;border-top-left-radius:0}.rbc-event-continues-after{border-bottom-right-radius:0;border-top-right-radius:0}.rbc-event-continues-earlier{border-top-left-radius:0;border-top-right-radius:0}.rbc-event-continues-later{border-bottom-left-radius:0;border-bottom-right-radius:0}.rbc-row{display:flex;flex-direction:row}.rbc-row-segment{padding:0 1px 1px}.rbc-selected-cell{background-color:#0000001a}.rbc-show-more{background-color:#ffffff4d;color:#3174ad;font-size:85%;font-weight:700;height:auto;line-height:normal;z-index:4}.rbc-show-more:focus,.rbc-show-more:hover{color:#265985}.rbc-month-view{border:1px solid #ddd;display:flex;flex:1 0;flex-direction:column;height:100%;position:relative;user-select:none;-webkit-user-select:none;width:100%}.rbc-month-header{display:flex;flex-direction:row}.rbc-month-row{display:flex;flex:1 0;flex-basis:0px;flex-direction:column;height:100%;overflow:hidden;position:relative}.rbc-month-row+.rbc-month-row{border-top:1px solid #ddd}.rbc-date-cell{flex:1 1;min-width:0;padding-right:5px;text-align:right}.rbc-date-cell>a,.rbc-date-cell>a:active,.rbc-date-cell>a:visited{color:inherit;text-decoration:none}.rbc-row-bg{display:flex;flex:1 0;flex-direction:row;overflow:hidden;right:1px}.rbc-day-bg{flex:1 0}.rbc-day-bg+.rbc-day-bg{border-left:1px solid #ddd}.rbc-rtl .rbc-day-bg+.rbc-day-bg{border-left-width:0;border-right:1px solid #ddd}.rbc-overlay{background-color:#fff;border:1px solid #e5e5e5;box-shadow:0 5px 15px #00000040;padding:10px;position:absolute;z-index:5}.rbc-overlay>*+*{margin-top:1px}.rbc-overlay-header{border-bottom:1px solid #e5e5e5;margin:-10px -10px 5px;padding:2px 10px}.rbc-agenda-view{display:flex;flex:1 0;flex-direction:column;overflow:auto}.rbc-agenda-view table.rbc-agenda-table{border:1px solid #ddd;border-collapse:collapse;border-spacing:0;width:100%}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td{padding:5px 10px;vertical-align:top}.rbc-agenda-view table.rbc-agenda-table .rbc-agenda-time-cell{padding-left:15px;padding-right:15px;text-transform:lowercase}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left-width:0;border-right:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table tbody>tr+tr{border-top:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{border-bottom:1px solid #ddd;padding:3px 5px;text-align:left}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table thead>tr>th{text-align:right}.rbc-agenda-time-cell{text-transform:lowercase}.rbc-agenda-time-cell .rbc-continues-after:after{content:" »"}.rbc-agenda-time-cell .rbc-continues-prior:before{content:"« "}.rbc-agenda-event-cell{width:100%}.rbc-time-column{display:flex;flex-direction:column;min-height:100%}.rbc-time-column .rbc-timeslot-group{flex:1 1}.rbc-timeslot-group{border-bottom:1px solid #ddd;display:flex;flex-flow:column nowrap;min-height:40px}.rbc-header-gutter,.rbc-time-gutter{flex:none}.rbc-label{padding:0 5px}.rbc-day-slot{position:relative}.rbc-day-slot .rbc-events-container{bottom:0;left:0;margin-right:10px;position:absolute;right:0;top:0}.rbc-day-slot .rbc-events-container.rbc-rtl{left:10px;right:0}.rbc-day-slot .rbc-background-event,.rbc-day-slot .rbc-event{align-items:flex-start;border:1px solid #265985;display:flex;flex-flow:column wrap;max-height:100%;min-height:20px;overflow:hidden;position:absolute}.rbc-day-slot .rbc-background-event{opacity:.75}.rbc-day-slot .rbc-event-label{flex:none;padding-right:5px;width:auto}.rbc-day-slot .rbc-event-content{word-wrap:break-word;flex:1 1;height:100%;line-height:1;min-height:1em;width:100%}.rbc-day-slot .rbc-time-slot{border-top:1px solid #f7f7f7}.rbc-time-view-resources .rbc-time-gutter,.rbc-time-view-resources .rbc-time-header-gutter{background-color:#fff;border-right:1px solid #ddd;left:0;margin-right:-1px;position:-webkit-sticky;position:sticky;z-index:10}.rbc-time-view-resources .rbc-time-header{overflow:hidden}.rbc-time-view-resources .rbc-time-header-content{flex:1 0;flex-basis:0px;min-width:auto}.rbc-time-view-resources .rbc-time-header-cell-single-day{display:none}.rbc-time-view-resources .rbc-day-slot{min-width:140px}.rbc-time-view-resources .rbc-day-bg,.rbc-time-view-resources .rbc-header{flex:1 1;flex-basis:0 px;width:140px}.rbc-time-header-content+.rbc-time-header-content{margin-left:-1px}.rbc-time-slot{flex:1 0}.rbc-time-slot.rbc-now{font-weight:700}.rbc-day-header{text-align:center}.rbc-slot-selection{background-color:#00000080;color:#fff;font-size:75%;padding:3px;position:absolute;width:100%;z-index:10}.rbc-slot-selecting{cursor:move}.rbc-time-view{border:1px solid #ddd;display:flex;flex:1 1;flex-direction:column;min-height:0;width:100%}.rbc-time-view .rbc-time-gutter{text-align:right;white-space:nowrap}.rbc-time-view .rbc-allday-cell{box-sizing:initial;height:100%;position:relative;width:100%}.rbc-time-view .rbc-allday-cell+.rbc-allday-cell{border-left:1px solid #ddd}.rbc-time-view .rbc-allday-events{position:relative;z-index:4}.rbc-time-view .rbc-row{box-sizing:border-box;min-height:20px}.rbc-time-header{display:flex;flex:0 0 auto;flex-direction:row}.rbc-time-header.rbc-overflowing{border-right:1px solid #ddd}.rbc-rtl .rbc-time-header.rbc-overflowing{border-left:1px solid #ddd;border-right-width:0}.rbc-time-header>.rbc-row.rbc-row-resource,.rbc-time-header>.rbc-row:first-child{border-bottom:1px solid #ddd}.rbc-time-header-cell-single-day{display:none}.rbc-time-header-content{border-left:1px solid #ddd;display:flex;flex:1 1;flex-direction:column;min-width:0}.rbc-rtl .rbc-time-header-content{border-left-width:0;border-right:1px solid #ddd}.rbc-time-header-content>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd;flex-shrink:0}.rbc-time-content{align-items:flex-start;border-top:2px solid #ddd;display:flex;flex:1 0;overflow-y:auto;position:relative;width:100%}.rbc-time-content>.rbc-time-gutter{flex:none}.rbc-time-content>*+*>*{border-left:1px solid #ddd}.rbc-rtl .rbc-time-content>*+*>*{border-left-width:0;border-right:1px solid #ddd}.rbc-time-content>.rbc-day-slot{user-select:none;-webkit-user-select:none;width:100%}.rbc-current-time-indicator{background-color:#74ad31;height:1px;left:0;pointer-events:none;position:absolute;right:0;z-index:3}.rbc-resource-grouping.rbc-time-header-content{display:flex;flex-direction:column}.rbc-resource-grouping .rbc-row .rbc-header{width:141px}.calendario-container{background:#f8f9fa;min-height:100vh;padding:20px}.calendario-header{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px}.calendario-header h1{color:#2c3e50;font-size:28px;margin:0}.calendario-actions{display:flex;gap:10px}.calendario-leyenda{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px;padding:15px}.leyenda-item{align-items:center;color:#555;display:flex;font-size:14px;gap:8px}.color-box{border-radius:4px;display:inline-block;height:20px;width:20px}.color-box.pendiente{background-color:#ffc107}.color-box.confirmado{background-color:#28a745}.color-box.completado{background-color:#6c757d}.color-box.cancelado{background-color:#dc3545}.calendario-wrapper{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:20px}.rbc-calendar{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.rbc-header{background:#f8f9fa;border-bottom:2px solid #dee2e6;color:#2c3e50;font-size:14px;font-weight:600;padding:15px 5px}.rbc-today{background-color:#e3f2fd!important}.rbc-event{border-radius:5px;cursor:pointer;font-size:13px;padding:4px 8px;transition:all .3s ease}.rbc-event:hover{box-shadow:0 4px 8px #0003;transform:scale(1.05)}.rbc-event.evento-pendiente{background-color:#ffc107;color:#000}.rbc-event.evento-confirmado{background-color:#28a745}.rbc-event.evento-completado{background-color:#6c757d}.rbc-event.evento-cancelado{background-color:#dc3545}.rbc-toolbar{background:#f8f9fa;border-radius:8px;margin-bottom:20px;padding:15px}.rbc-toolbar button{background:#fff;border:1px solid #dee2e6;border-radius:5px;color:#495057;cursor:pointer;font-size:14px;font-weight:500;padding:8px 15px;transition:all .3s ease}.rbc-toolbar button.rbc-active,.rbc-toolbar button:hover{background:#007bff;border-color:#007bff;color:#fff}.rbc-toolbar button:focus{box-shadow:0 0 0 3px #007bff40;outline:none}.rbc-toolbar-label{color:#2c3e50;font-size:18px;font-weight:600;text-transform:capitalize}.rbc-month-view{border:1px solid #dee2e6;border-radius:8px;overflow:hidden}.rbc-date-cell{padding:8px}.rbc-date-cell.rbc-now{color:#007bff;font-weight:700}.rbc-off-range-bg{background:#f8f9fa}.rbc-time-view{border:1px solid #dee2e6;border-radius:8px;overflow:hidden}.rbc-time-header{border-bottom:2px solid #dee2e6}.rbc-time-slot{border-top:1px solid #f1f1f1}.rbc-current-time-indicator{background-color:#dc3545;height:2px}.rbc-agenda-view{border:1px solid #dee2e6;border-radius:8px}.rbc-agenda-table{border:none}.rbc-agenda-date-cell,.rbc-agenda-time-cell{font-weight:500;padding:12px;white-space:nowrap}.rbc-agenda-event-cell{padding:12px}.modal-contenido{max-width:600px}.detalle-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:15px}.detalle-item:last-child{border-bottom:none}.detalle-item strong{color:#555;font-weight:600;min-width:120px}.detalle-item span{color:#2c3e50;flex:1 1;text-align:right}.badge-pendiente{background:#fff3cd;color:#856404}.badge-confirmado{background:#d4edda;color:#155724}.badge-completado{background:#e2e3e5;color:#383d41}.badge-cancelado{background:#f8d7da;color:#721c24}.modal-footer{flex-wrap:wrap;justify-content:space-between}.estado-buttons{display:flex;flex-wrap:wrap;gap:10px}.btn-danger,.btn-primary,.btn-secondary,.btn-success,.btn-warning{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease}.btn-secondary:hover,.btn-success:hover,.btn-warning:hover{transform:translateY(-2px)}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333;transform:translateY(-2px)}@media (max-width:768px){.calendario-header{align-items:stretch;flex-direction:column;gap:15px}.calendario-actions{justify-content:stretch}.calendario-actions button{flex:1 1}.calendario-leyenda{justify-content:center}.modal-contenido{margin:10px;width:95%}.modal-footer{flex-direction:column}.estado-buttons{width:100%}.estado-buttons button{flex:1 1}.detalle-item{align-items:flex-start;flex-direction:column;gap:8px}.detalle-item span{text-align:left}.rbc-toolbar{align-items:stretch;flex-direction:column}.rbc-toolbar button{margin:2px 0}}@media (max-width:480px){.calendario-header h1{font-size:20px}.calendario-wrapper{padding:10px}.rbc-toolbar-label{font-size:16px}}.usuarios-container{background:#f8f9fa;min-height:100vh;padding:20px}.usuarios-header{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px}.usuarios-header h1{color:#2c3e50;font-size:28px;margin:0}.usuarios-tabla{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;overflow-x:auto;padding:20px}.usuarios-tabla table{border-collapse:collapse;width:100%}.usuarios-tabla thead{background:#f8f9fa}.usuarios-tabla th{border-bottom:2px solid #dee2e6;color:#2c3e50;font-weight:600;padding:15px;text-align:left}.usuarios-tabla td{border-bottom:1px solid #f0f0f0;color:#555;padding:15px}.usuarios-tabla tbody tr:hover{background:#f8f9fa}.badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;padding:6px 12px;text-transform:uppercase}.badge-admin{background:#dc3545;color:#fff}.badge-secretaria{background:#28a745;color:#fff}.badge-profesional{background:#007bff;color:#fff}.badge-default{background:#6c757d;color:#fff}.acciones-buttons{display:flex;gap:10px}.btn-delete,.btn-edit{border:none;border-radius:5px;cursor:pointer;font-size:16px;padding:6px 12px;transition:all .3s ease}.btn-edit{background:#ffc107;color:#000}.btn-edit:hover{background:#e0a800}.btn-delete:hover,.btn-edit:hover{transform:scale(1.1)}.no-data{color:#999;font-size:16px;padding:40px;text-align:center}.modal-overlay{animation:fadeIn .3s ease}.modal-contenido{animation:slideUp .3s ease;background:#fff;border-radius:15px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{padding:20px}.modal-header h2{color:#2c3e50;font-size:24px}.btn-close{border-radius:50%;height:40px;width:40px}.btn-close:hover{background:#f0f0f0}.modal-body{padding:20px}.form-group{margin-bottom:20px}.form-group label{color:#2c3e50}.form-group input,.form-group select{border:1px solid #dee2e6;border-radius:8px;font-size:14px;padding:12px;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-group small{color:#666;font-size:12px;margin-top:8px}.modal-footer{border-top:2px solid #f0f0f0;display:flex;gap:10px;justify-content:flex-end;padding:20px}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-primary{background:#007bff}.btn-primary:hover{background:#0056b3;box-shadow:0 4px 12px #007bff4d;transform:translateY(-2px)}.btn-secondary:hover{background:#545b62}.loading{color:#666;font-size:18px;padding:50px;text-align:center}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.usuarios-header{align-items:stretch;flex-direction:column;gap:15px}.usuarios-tabla{overflow-x:scroll;padding:10px}.usuarios-tabla table{min-width:600px}.modal-contenido{margin:10px;width:95%}.modal-footer{flex-direction:column}.modal-footer button{width:100%}}.reportes-container{margin:0 auto;max-width:1400px;padding:20px}.reportes-container.loading{align-items:center;color:#6b7280;display:flex;font-size:18px;justify-content:center;min-height:400px}.reportes-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.reportes-header h1{color:#1f2937;font-size:28px;margin:0}.header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:20px}.periodo-selector{align-items:center;display:flex;gap:10px}.periodo-selector label{color:#4b5563;font-weight:600}.periodo-selector select{background-color:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .3s ease}.periodo-selector select:hover{border-color:#3b82f6}.periodo-selector select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.export-buttons{display:flex;gap:10px}.btn-export{align-items:center;border:none;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease}.btn-export:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.btn-export.pdf{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-export.pdf:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}.btn-export.excel{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-export.excel:hover{background:linear-gradient(135deg,#059669,#047857)}.resumen-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:30px}.resumen-card{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 4px 6px #0000001a;color:#fff;display:flex;gap:20px;padding:25px;transition:transform .3s ease}.resumen-card:hover{transform:translateY(-5px)}.resumen-card.ingresos{background:linear-gradient(135deg,#10b981,#059669)}.resumen-card.turnos{background:linear-gradient(135deg,#3b82f6,#2563eb)}.resumen-card.pacientes{background:linear-gradient(135deg,#f59e0b,#d97706)}.resumen-icon{font-size:48px;line-height:1;opacity:.9}.resumen-content{flex:1 1}.resumen-content h3{font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 10px;opacity:.9;text-transform:uppercase}.resumen-valor{font-size:32px;font-weight:700;line-height:1;margin:0}.resumen-periodo{font-size:12px;opacity:.8}.graficos-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(450px,1fr))}.grafico-card{background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;padding:25px;transition:box-shadow .3s ease}.grafico-card:hover{box-shadow:0 4px 12px #0000001f}.grafico-card.full-width{grid-column:1/-1}.grafico-card h2{border-bottom:2px solid #e5e7eb;color:#1f2937;font-size:18px;margin:0 0 20px;padding-bottom:15px}.grafico-contenido{min-height:300px}.sin-datos{color:#9ca3af;font-style:italic;padding:60px 20px}.grafico-barras{align-items:flex-end;display:flex;gap:15px;height:280px;justify-content:space-around;padding:20px 0}.barra-wrapper{align-items:center;display:flex;flex:1 1;flex-direction:column;min-width:60px}.barra-container{align-items:flex-end;height:200px;width:100%}.barra,.barra-container{display:flex;justify-content:center;position:relative}.barra{align-items:flex-start;background:linear-gradient(0deg,#10b981,#34d399);border-radius:8px 8px 0 0;cursor:pointer;padding-top:8px;transition:all .3s ease;width:80%}.barra:hover{opacity:.85;transform:scaleY(1.05)}.barra-valor{color:#fff;font-size:11px;font-weight:600;text-orientation:mixed;text-shadow:0 1px 2px #0003;writing-mode:vertical-rl}.barra-label{color:#4b5563;font-size:12px;font-weight:600;margin-top:8px;text-align:center}.barra-cantidad{color:#9ca3af;font-size:11px;margin-top:4px}.grafico-dona{gap:15px;padding:20px 0}.dona-item,.grafico-dona{display:flex;flex-direction:column}.dona-item{gap:8px}.dona-barra{border-radius:20px;box-shadow:0 2px 4px #0000001a;height:40px;transition:all .3s ease}.dona-barra:hover{box-shadow:0 3px 6px #00000026;transform:scaleX(1.02)}.dona-info{align-items:center;display:flex;justify-content:space-between;padding:0 10px}.dona-label{font-size:13px;font-weight:600;text-transform:capitalize}.dona-valor{color:#1f2937;font-size:14px;font-weight:700}.grafico-linea{padding:20px 0}.linea-grid{align-items:flex-end;border-bottom:2px solid #e5e7eb;display:flex;gap:10px;height:240px;justify-content:space-around;position:relative}.linea-punto-wrapper{align-items:center;display:flex;flex:1 1;flex-direction:column;min-width:50px}.linea-punto-container{display:flex;height:200px;justify-content:center;position:relative;width:100%}.linea-punto{align-items:center;display:flex;flex-direction:column;gap:5px;position:absolute;transition:all .3s ease}.linea-punto:hover{transform:scale(1.1)}.punto-valor{background:#fff;border-radius:6px;box-shadow:0 2px 4px #0000001a;color:#3b82f6;font-size:12px;font-weight:700;padding:4px 8px}.punto-circulo{background:#3b82f6;border:3px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;height:12px;width:12px}.linea-label{color:#4b5563;font-size:11px;font-weight:600;margin-top:10px;text-align:center}.grafico-apilado{padding:20px 0}.apilado-leyenda{border-bottom:1px solid #e5e7eb;display:flex;gap:25px;justify-content:center;margin-bottom:25px;padding-bottom:15px}.leyenda-item{font-size:13px;font-weight:600}.leyenda-item.completado{color:#10b981}.leyenda-item.cancelado{color:#ef4444}.leyenda-item.no-show{color:#6b7280}.apilado-barras{align-items:flex-end;display:flex;gap:12px;height:280px;justify-content:space-around}.apilado-columna{align-items:center;display:flex;flex:1 1;flex-direction:column;min-width:60px}.apilado-barra-container{border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;gap:2px;height:220px;justify-content:flex-end;overflow:hidden;transition:all .3s ease;width:80%}.apilado-barra-container:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-5px)}.apilado-segmento{align-items:center;color:#fff;display:flex;font-size:12px;font-weight:700;justify-content:center;min-height:0;transition:all .3s ease}.apilado-segmento span{text-shadow:0 1px 2px #0000004d}.apilado-segmento.completado{background:linear-gradient(0deg,#10b981,#34d399)}.apilado-segmento.cancelado{background:linear-gradient(0deg,#ef4444,#f87171)}.apilado-segmento.no-show{background:linear-gradient(0deg,#6b7280,#9ca3af)}.apilado-label{color:#4b5563;font-size:11px;font-weight:600;margin-top:10px;text-align:center}.apilado-total{color:#9ca3af;font-size:12px;font-weight:600;margin-top:4px}@media (max-width:1200px){.graficos-grid{grid-template-columns:1fr}.grafico-card.full-width{grid-column:1}}@media (max-width:768px){.reportes-container{padding:15px}.reportes-header{align-items:flex-start;flex-direction:column;gap:15px}.resumen-cards{grid-template-columns:1fr}.resumen-card{padding:20px}.resumen-icon{font-size:36px}.resumen-valor{font-size:24px}.grafico-card{padding:20px}.apilado-barras,.grafico-barras{gap:8px}.apilado-columna,.barra-wrapper{min-width:40px}.apilado-label,.barra-label,.barra-valor,.linea-label{font-size:10px}}.agendar-container{background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh;padding:0}.error-mensaje,.loading{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px;text-align:center}.error-mensaje h2{font-size:32px;margin-bottom:20px}.error-mensaje p{font-size:18px;line-height:1.6}.agendar-header{background:#fffffff2;box-shadow:0 2px 10px #0000001a;padding:20px;text-align:center}.agendar-header h1{color:#1f2937;font-size:24px;margin:0 0 10px}.paciente-nombre{color:#667eea;font-size:18px;font-weight:600;margin:0}.agendar-nav{background:#fff;box-shadow:0 2px 5px #0000001a;display:flex}.agendar-nav button{background:#fff;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:15px;transition:all .3s ease}.agendar-nav button.active{background:#f9fafb;border-bottom-color:#667eea;color:#667eea}.agendar-nav button:hover{background:#f3f4f6}.agendar-seccion,.mis-turnos-seccion{margin:0 auto;max-width:600px;padding:20px}.agendar-seccion h2,.mis-turnos-seccion h2{color:#fff;font-size:22px;margin:0 0 20px;text-align:center}.sin-datos{background:#fff;border-radius:12px;padding:40px 20px;text-align:center}.sin-datos p{color:#6b7280;font-size:16px;margin-bottom:20px}.btn-primario{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 30px;transition:transform .2s ease}.btn-primario:hover{transform:translateY(-2px)}.turnos-lista{display:flex;flex-direction:column;gap:15px}.turno-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;transition:transform .2s ease}.turno-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.turno-card.pendiente{border-left:4px solid #f59e0b}.turno-card.completado{border-left:4px solid #10b981}.turno-card.cancelado{border-left:4px solid #ef4444;opacity:.7}.turno-header{align-items:flex-start;display:flex;gap:10px;justify-content:space-between;margin-bottom:15px}.turno-header h3{color:#1f2937;flex:1 1;font-size:16px;margin:0;text-transform:capitalize}.estado-badge{font-size:12px;font-weight:700;padding:4px 12px;white-space:nowrap}.estado-badge.pendiente{background:#fef3c7;color:#d97706}.estado-badge.completado{background:#d1fae5;color:#059669}.estado-badge.cancelado{background:#fee2e2;color:#dc2626}.turno-detalles{margin-bottom:15px}.turno-detalles p{color:#4b5563;font-size:14px;margin:8px 0}.turno-detalles strong{color:#1f2937}.btn-cancelar-turno{background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;color:#dc2626;cursor:pointer;font-weight:600;padding:10px;transition:all .3s ease;width:100%}.btn-cancelar-turno:hover{background:#fecaca;border-color:#ef4444}.agendar-form{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:25px}.form-group{margin-bottom:25px}.form-group label{color:#1f2937;display:block;font-size:15px;font-weight:600;margin-bottom:8px}.form-group small{color:#6b7280;display:block;font-size:13px;font-style:italic;margin-top:5px}.form-group input[type=date]{border:2px solid #e5e7eb;border-radius:8px;font-size:16px;padding:12px;transition:border-color .3s ease;width:100%}.form-group input[type=date]:focus{border-color:#667eea;outline:none}.loading-horarios,.sin-horarios{color:#6b7280;font-style:italic;padding:20px;text-align:center}.horarios-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.horario-btn{background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#4b5563;cursor:pointer;font-size:15px;font-weight:600;padding:12px;transition:all .3s ease}.horario-btn:hover{background:#f3f4f6;border-color:#667eea}.horario-btn.selected{background:#667eea;border-color:#667eea;color:#fff;transform:scale(1.05)}.form-group textarea{border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:15px;padding:12px;resize:vertical;transition:border-color .3s ease;width:100%}.form-group textarea:focus{border-color:#667eea;outline:none}.btn-agendar{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;box-shadow:0 4px 6px #10b9814d;color:#fff;cursor:pointer;font-size:18px;font-weight:700;padding:15px;transition:transform .2s ease;width:100%}.btn-agendar:hover:not(:disabled){box-shadow:0 6px 10px #10b98166;transform:translateY(-2px)}.btn-agendar:disabled{cursor:not-allowed;opacity:.6}.agendar-footer{background:#ffffff1a;color:#fff;margin-top:30px;padding:20px;text-align:center}.agendar-footer p{font-size:14px;margin:5px 0}.contacto-info{font-size:15px;font-weight:600}@media (min-width:768px){.agendar-header h1{font-size:32px}.paciente-nombre{font-size:20px}.agendar-nav button{font-size:18px;padding:18px}.agendar-seccion h2,.mis-turnos-seccion h2{font-size:26px}.horarios-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}.turno-header h3{font-size:18px}.turno-detalles p{font-size:15px}}@media (min-width:1024px){.agendar-seccion,.mis-turnos-seccion{max-width:800px}.turnos-lista{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}}.control-asistencia{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.asistencia-header{color:#fff;margin-bottom:30px}.asistencia-header h2{font-size:2rem;margin:0 0 5px}.asistencia-header p{margin:0;opacity:.9}.asistencia-container{margin:0 auto;max-width:1200px}.busqueda-paciente{margin-bottom:30px}.busqueda-input{background:#fff;border:none;border-radius:8px;box-shadow:0 4px 6px #0000001a;font-size:1rem;padding:15px;width:100%}.busqueda-input::placeholder{color:#999}.busqueda-input:focus{box-shadow:0 0 0 3px #667eea4d;outline:none}.pacientes-lista{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.paciente-card{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;flex-direction:column;padding:20px;transition:transform .3s ease,box-shadow .3s ease}.paciente-card:hover{box-shadow:0 8px 20px #00000026;transform:translateY(-5px)}.paciente-info{flex:1 1;margin-bottom:15px}.paciente-info h3{color:#333;font-size:1.2rem;margin:0 0 10px}.paciente-info p{color:#666;font-size:.9rem;margin:5px 0}.asistencia-info{background:#f5f5f5;border-left:4px solid #4caf50;border-radius:6px;display:flex;flex-direction:column;gap:8px;margin-top:12px;padding:12px}.duracion,.entrada,.salida{color:#555;font-size:.85rem}.duracion{color:#667eea;font-weight:700}.paciente-acciones{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.btn-checkin,.btn-checkout,.btn-historial{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 15px;transition:all .3s ease}.btn-checkin{background:#4caf50;color:#fff}.btn-checkin:hover{background:#45a049}.btn-checkout{background:#ff9800;color:#fff}.btn-checkout:hover{background:#e68900}.btn-historial{background:#2196f3;color:#fff;grid-column:1/-1}.btn-historial:hover{background:#0b7dda}button:disabled{cursor:not-allowed;opacity:.6}.historial-view{background:#fff;border-radius:12px;padding:20px}.historial-header{align-items:center;display:flex;gap:15px;margin-bottom:20px}.btn-volver{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px}.historial-header h3{flex:1 1;margin:0}.historial-tabla{border-collapse:collapse;margin-top:15px;width:100%}.historial-tabla thead{background:#f5f5f5}.historial-tabla th{border-bottom:2px solid #ddd;color:#333;font-weight:600;padding:12px;text-align:left}.historial-tabla td{border-bottom:1px solid #eee;padding:12px}.historial-tabla tr:hover{background:#f9f9f9}.estado-badge{border-radius:20px;display:inline-block;font-size:.85rem;font-weight:600;padding:6px 12px}.estado-presente .estado-badge{background:#c8e6c9;color:#2e7d32}.estado-ausente .estado-badge{background:#fcc;color:#d32f2f}.estado-retrasado .estado-badge{background:#ffe0b2;color:#f57c00}.estado-cancelado .estado-badge{background:#d1c4e9;color:#512da8}.empty-state{color:#666;padding:40px}.empty-state p{margin:0}.mensaje{animation:slideDown .3s ease;border-radius:6px;font-weight:600;margin-bottom:20px;padding:15px}.mensaje.exito{background:#c8e6c9;color:#2e7d32}.mensaje.error{background:#fcc;color:#d32f2f}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.asistencia-loading{color:#fff;padding:40px;text-align:center}@media (max-width:768px){.paciente-acciones,.pacientes-lista{grid-template-columns:1fr}.historial-tabla{font-size:.85rem}.historial-tabla td,.historial-tabla th{padding:8px}}*{box-sizing:border-box}body,html{margin:0;padding:0;width:100%}body{font-size:16px}@media (max-width:575px){html{font-size:14px}}@media (max-width:768px){.login-form{max-width:350px;padding:1.5rem;width:90%}.login-form h2{font-size:20px;margin-bottom:.25rem}.login-form h3{font-size:14px;margin-bottom:1.5rem}.login-form input{font-size:16px;margin:6px 0;padding:10px}.login-form button{font-size:16px;margin-top:.75rem;padding:10px}.demo-credentials{font-size:12px;margin-top:1.5rem;padding:.75rem}}@media (max-width:480px){.login-container{padding:10px}.login-form{border-radius:8px;max-width:100%;padding:1rem;width:100%}.login-form h2{font-size:18px}.login-form h3{font-size:13px}.login-form button,.login-form input{border-radius:4px;font-size:16px;padding:10px}.login-form button{margin-top:.5rem}.demo-credentials{font-size:11px;margin-top:1rem;padding:.5rem}.demo-credentials p{margin:.15rem 0}}@media (max-width:992px){.app{flex-direction:column}.sidebar{max-height:none;width:100%}.main-content{flex:1 1}}@media (max-width:768px){.sidebar{background:#fff;border-right:1px solid #e0e0e0;height:calc(100vh - 50px);left:-100%;max-width:250px;overflow-y:auto;position:fixed;top:50px;transition:left .3s ease;width:70%;z-index:999}.sidebar.open{left:0}.main-content{margin-left:0}.header{height:50px;padding:0 15px}.toggle-sidebar-btn{display:block}}@media (max-width:576px){.sidebar{max-width:none;width:80%}.header{padding:0 10px}.logo{font-size:18px}.user-menu{font-size:12px}}@media (max-width:1200px){.dashboard{padding:15px}.stats-grid{gap:15px;grid-template-columns:repeat(2,1fr);margin-bottom:20px}.stat-card{padding:15px}.stat-icon{font-size:28px}.stat-number{font-size:24px}}@media (max-width:992px){.dashboard{padding:12px}.stats-grid{gap:12px;grid-template-columns:repeat(2,1fr)}.stat-card{gap:10px;padding:12px}.stat-content h3{font-size:12px}.stat-number{font-size:20px}.stat-detail{font-size:11px}.stat-icon{font-size:24px}.dashboard h1{font-size:22px;margin-bottom:8px}.dashboard h2{font-size:16px;margin-bottom:15px}}@media (max-width:768px){.dashboard{padding:10px}.stats-grid{gap:10px;grid-template-columns:1fr;margin-bottom:15px}.stat-card{flex-direction:row;padding:12px}.stat-icon{font-size:20px}.stat-number{font-size:18px}.stat-content h3{font-size:11px}.dashboard h1{font-size:20px}.dashboard h2{font-size:14px;margin-bottom:12px}.metricas-grid{grid-template-columns:1fr}.turnos-list{gap:10px}.turno-item{align-items:flex-start;flex-direction:column;gap:8px}.turno-info-dashboard{width:100%}.turno-status{text-align:right;width:100%}}@media (max-width:576px){.dashboard{padding:8px}.stats-grid{gap:8px;grid-template-columns:1fr}.stat-card{padding:10px}.stat-icon{font-size:18px;min-width:30px}.stat-number{font-size:16px}.stat-content h3,.stat-detail{font-size:10px}.dashboard h1{font-size:18px;margin-bottom:5px}.dashboard h2{font-size:13px;margin-bottom:10px}.metricas-section,.turnos-section{padding:15px}.metricas-section h3,.turnos-section h3{font-size:16px;margin-bottom:15px}.metrica-item{padding:12px}.metrica-label{font-size:12px}.metrica-valor{font-size:20px}.turno-item{padding:12px}}@media (max-width:768px){table{font-size:13px}table td,table th{padding:10px 5px}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}thead{display:none}tbody tr{background:#fff;border:1px solid #e0e0e0;border-radius:8px;display:block;margin-bottom:15px;padding:10px}tbody td{display:block;padding:8px 0 8px 50%;position:relative;text-align:right}tbody td:before{color:#666;content:attr(data-label);font-size:12px;font-weight:600;left:0;position:absolute;text-align:left;width:45%}.btn-group{flex-direction:column}.btn-group a,.btn-group button{margin:4px 0;width:100%}}@media (max-width:576px){table{font-size:12px}table td,table th{padding:8px 4px}tbody td{padding:6px 0 6px 50%}tbody td:before{font-size:11px}}@media (max-width:768px){.form-row{flex-direction:column}.form-group{margin-bottom:1rem;width:100%}.form-group.inline{display:flex;gap:10px}.form-group.inline input,.form-group.inline select{flex:1 1}input,select,textarea{font-size:16px}.button-group{flex-direction:column}.button-group button{width:100%}}@media (max-width:576px){.form-group{margin-bottom:.8rem}.form-group.inline{flex-direction:column;gap:8px}.button-group{gap:8px}.button-group button{font-size:14px;padding:10px}}@media (max-width:768px){.dialog-content,.modal-content{margin:5vh auto;max-height:90vh;max-width:90%;width:90%}.dialog-header h2,.modal-header h2{font-size:18px}.dialog-body,.modal-body{max-height:calc(90vh - 120px);overflow-y:auto}}@media (max-width:576px){.dialog-content,.modal-content{margin:2.5vh auto;max-width:95%;width:95%}.dialog-header h2,.modal-header h2{font-size:16px}.dialog-body,.modal-body{padding:12px}.dialog-footer button,.modal-footer button{font-size:14px;padding:8px}}@media (max-width:768px){.navbar{flex-wrap:wrap}.navbar-menu{display:none;flex-direction:column;width:100%}.navbar-menu.active{display:flex}.navbar-menu a{border-bottom:1px solid #f0f0f0;padding:12px}.hamburger{display:block}}@media (max-width:992px){.card-grid{gap:15px;grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.card-grid{gap:12px;grid-template-columns:1fr}.card{padding:15px}.card h3{font-size:16px}}@media (max-width:576px){.card{border-radius:6px;padding:12px}.card h3{font-size:14px;margin-bottom:8px}.card p{font-size:13px}}.d-none-mobile{display:none!important}.d-none-desktop,.d-none-tablet{display:block!important}@media (min-width:577px){.d-none-mobile{display:block!important}}@media (min-width:993px){.d-none-tablet{display:none!important}}@media (min-width:1201px){.d-none-desktop{display:none!important}}@media (max-width:768px){.p-lg{padding:15px!important}.p-md{padding:10px!important}.m-lg{margin:15px!important}.m-md{margin:10px!important}}@media (max-width:576px){.p-lg{padding:10px!important}.p-md{padding:8px!important}.m-lg{margin:10px!important}.m-md{margin:8px!important}.p-0{padding:0!important}.m-0{margin:0!important}}@media (hover:none) and (pointer:coarse){a.btn,button,input[type=button],input[type=reset],input[type=submit]{min-height:44px;min-width:44px;padding:10px 16px}input,select,textarea{min-height:44px}}@media print{.action-buttons,.button-group,.navbar,.sidebar{display:none}.dashboard{padding:0}.stats-grid{grid-template-columns:repeat(2,1fr)}body{background:#fff}}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-form{background:#fff;border-radius:10px;box-shadow:0 4px 6px #0000001a;max-width:400px;padding:2rem;width:100%}.login-form h2{color:#333;margin-bottom:.5rem;text-align:center}.login-form h3{color:#666;margin-bottom:2rem;text-align:center}.login-form input{border:1px solid #ddd;border-radius:5px;font-size:16px;margin:8px 0;padding:12px;width:100%}.login-form input.input-error{background-color:#fff5f5;border-color:#c33}.form-group{margin-bottom:1rem}.error-text{color:#c33;display:block;font-size:12px;margin-top:4px}.login-form button:disabled{background:#aaa;cursor:not-allowed}.login-form button{background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;margin-top:1rem;padding:12px;width:100%}.login-form button:hover{background:#5a6fd8}.error{background:#fee;border-radius:5px;color:#c33;margin-bottom:1rem;padding:10px;text-align:center}.demo-credentials{background:#f0f8ff;border-radius:5px;color:#666;font-size:14px;margin-top:2rem;padding:1rem}.demo-credentials p{margin:.25rem 0}.app{display:flex;flex-direction:column;min-height:100vh}.header{align-items:center;background:#2c3e50;box-shadow:0 2px 4px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.logo{flex:1 1;font-size:20px;font-weight:600;margin:0}.user-name{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-info{align-items:center;display:flex;gap:1rem}.rol-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:13px;font-weight:600;gap:5px;padding:6px 12px}.rol-badge.rol-admin{background:#dc3545;color:#fff}.rol-badge.rol-secretaria{background:#28a745;color:#fff}.rol-badge.rol-profesional{background:#007bff;color:#fff}.logout-btn{background:#e74c3c;border:none;border-radius:5px;color:#fff;cursor:pointer;padding:8px 16px}.logout-btn:hover{background:#c0392b}.toggle-sidebar-btn{background:none;border:none;border-radius:4px;color:#fff;cursor:pointer;display:none;font-size:28px;margin-right:.75rem;min-height:44px;min-width:44px;padding:.5rem;transition:transform .3s ease}.toggle-sidebar-btn:hover{background:#ffffff1a;transform:scale(1.1)}.toggle-sidebar-btn:active{transform:scale(.95)}.sidebar-overlay{animation:fadeIn .3s ease;background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:998}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.main-content{display:flex;flex:1 1}.sidebar{background:#34495e;max-height:calc(100vh - 70px);overflow-y:auto;padding:1rem;transition:left .3s ease;width:250px}.nav-btn{background:none;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;margin-bottom:5px;padding:12px;text-align:left;transition:all .3s ease;width:100%}.nav-btn:hover{background:#4a627a;padding-left:20px}.nav-btn.active{background:#667eea;border-left:4px solid #fff;padding-left:8px}.content{background:#f8f9fa;flex:1 1;max-height:calc(100vh - 70px);overflow-y:auto;padding:2rem}.dashboard h2{color:#2c3e50;margin-bottom:2rem}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;padding:1.5rem;text-align:center}.stat-card h3{color:#666;font-size:14px;margin-bottom:.5rem}.stat-number{color:#667eea;font-size:2rem;font-weight:700}.turnos-section{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:1.5rem}.turnos-section h3{color:#2c3e50;margin-bottom:1rem}.turno-card{border:1px solid #eee;border-radius:5px;margin-bottom:.5rem;padding:1rem}.turno-info{align-items:center;display:flex;flex:1 1;justify-content:space-between}.estado{border-radius:4px;font-size:12px;padding:4px 8px}.estado.pendiente{background:#fff3cd;color:#856404}.estado.completado{background:#d4edda;color:#155724}.estado.cancelado{background:#f8d7da;color:#721c24}.estado.activo{background:#d4edda;color:#155724}.estado.inactivo{background:#f8d7da;color:#721c24}.acciones-rapidas{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.acciones-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.accion-btn{background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;padding:12px}.accion-btn:hover{background:#5a6fd8}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.btn-primary{background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px}.btn-primary:hover{background:#5a6fd8}.btn-secondary{background:#6c757d;border:none;border-radius:5px;color:#fff;cursor:pointer;padding:10px 20px}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:10px;max-height:90vh;max-width:500px;overflow-y:auto;padding:2rem;width:90%}.modal h3{margin-bottom:1rem}.modal input,.modal select,.modal textarea{border:1px solid #ddd;border-radius:5px;margin:5px 0;padding:10px;width:100%}.modal-actions{display:flex;gap:10px;margin-top:1rem}.pacientes-list,.pagos-list,.turnos-list{grid-gap:1rem;display:grid;gap:1rem}.paciente-card,.pago-card,.turno-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1rem}.turno-card{align-items:center;display:flex;justify-content:space-between}.turno-actions{display:flex;gap:10px}.btn-small{border:none;border-radius:4px;cursor:pointer;font-size:12px;padding:5px 10px}.btn-success{background:#28a745;color:#fff}.btn-warning{background:#ffc107;color:#000}.btn-edit{background:#17a2b8;color:#fff}.btn-toggle{background:#ffc107;color:#000}.btn-delete{background:#dc3545;color:#fff}.btn-success:hover{background:#218838}.btn-warning:hover{background:#e0a800}.btn-edit:hover{background:#138496}.btn-toggle:hover{background:#e0a800}.btn-delete:hover{background:#c82333}.filtros{margin-bottom:1rem}.filtros label{align-items:center;display:flex;gap:10px}.paciente-header{justify-content:space-between;margin-bottom:1rem}.paciente-estado,.paciente-header{align-items:center;display:flex}.paciente-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:1rem}.checkbox-label{align-items:center;display:flex;font-size:14px;gap:8px;margin:10px 0}.checkbox-label input[type=checkbox]{margin:0;width:auto}.empty-state{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;padding:3rem;text-align:center}.empty-state p{color:#666;margin-bottom:1rem}.configuracion-page{max-width:800px}.acciones-configuracion{display:flex;gap:1rem}.configuracion-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;margin-bottom:2rem}.configuracion-card{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;padding:1.5rem}.configuracion-info h3{color:#2c3e50;margin-bottom:.5rem}.clave-configuracion{color:#666;font-family:monospace;font-size:12px}.campo-configuracion{border:1px solid #ddd;border-radius:5px;font-size:14px;min-width:150px;padding:8px 12px}.mensaje{border-radius:5px;margin-bottom:1rem;padding:1rem;text-align:center}.mensaje-exito{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.mensaje-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.configuracion-info-adicional{background:#e7f3ff;border-left:4px solid #007bff;border-radius:10px;padding:1.5rem}.configuracion-info-adicional h3{color:#0056b3;margin-bottom:1rem}.configuracion-info-adicional ul{color:#495057;margin-left:1.5rem}.configuracion-info-adicional li{margin-bottom:.5rem}.notification-container{max-width:400px;position:fixed;right:20px;top:20px;z-index:2000}.notification{align-items:center;animation:slideIn .3s ease-out;border-radius:8px;box-shadow:0 4px 12px #0003;display:flex;font-weight:500;justify-content:space-between;margin-bottom:10px;padding:1rem}@keyframes slideIn{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}.notification-success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.notification-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.notification-warning{background:#fff3cd;border:1px solid #ffeeba;color:#856404}.notification-info{background:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.notification-close{background:none;border:none;color:inherit;cursor:pointer;font-size:20px;margin-left:1rem;opacity:.7}.notification-close:hover{opacity:1}.btn-small.btn-history{background:#17a2b8;border-color:#17a2b8;color:#fff}.btn-small.btn-history:hover{background:#138496;border-color:#138496;transform:translateY(-2px)}.btn-small.btn-link{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;font-weight:600}.btn-small.btn-link:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f);border-color:#5568d3;box-shadow:0 4px 8px #667eea4d;transform:translateY(-2px)}.historial-modal{max-height:90vh;max-width:90vw;overflow-y:auto;width:1200px}.modal-header{align-items:center;background:#fff;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.modal-header h2{color:#333;font-size:1.5rem;margin:0}.btn-close{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;font-size:28px;height:30px;justify-content:center;padding:0;transition:all .3s ease;width:30px}.btn-close:hover{color:#333;transform:rotate(90deg)}.modal-body{max-height:calc(90vh - 80px);overflow-y:auto;padding:2rem}@media (max-width:1024px){.header{gap:1rem;padding:1rem}.sidebar{width:200px}.content{padding:1.5rem}}@media (max-width:768px){.header{gap:.5rem;height:auto;padding:.75rem 1rem}.logo{flex:1 1;font-size:16px}.toggle-sidebar-btn{align-items:center;display:flex;justify-content:center;order:-1}.sidebar-overlay{display:block}.sidebar{background:#34495e;border-right:1px solid #2c3e50;box-shadow:2px 0 8px #0000004d;height:100vh;left:-100%;max-width:280px;padding-top:65px;position:fixed;top:0;transition:left .3s cubic-bezier(.4,0,.2,1);width:75%;z-index:999}.sidebar.open{box-shadow:2px 0 16px #0006;left:0}.main-content{flex-direction:column}.content{max-height:calc(100vh - 70px);overflow-y:auto;padding:1rem}.user-info{flex-wrap:wrap;font-size:13px;gap:.5rem}.user-name{display:none}.rol-badge{font-size:11px;padding:4px 8px}.logout-btn{font-size:14px;padding:6px 12px}.nav-btn{font-size:14px;padding:10px}.nav-btn:hover{padding-left:16px}.historial-modal{height:95vh;width:95vw}.modal-body,.modal-header{padding:1rem}.modal-body{max-height:calc(95vh - 120px)}.modal-title{font-size:18px}}@media (max-width:576px){.header{gap:.5rem;padding:.5rem .75rem}.logo{font-size:14px;font-weight:600}.toggle-sidebar-btn{font-size:24px;margin-right:.5rem;padding:.35rem}.user-info{font-size:12px;gap:.5rem}.user-name{display:none}.rol-badge{font-size:10px;padding:3px 6px}.logout-btn{font-size:12px;padding:5px 10px}.sidebar{max-width:300px;width:85%}.nav-btn{font-size:14px;margin-bottom:4px;padding:12px}.content{max-height:calc(100vh - 70px);padding:.75rem}.historial-modal{height:98vh;margin:1vh auto;width:98vw}.modal-body,.modal-header{padding:.75rem}.modal-body{max-height:calc(98vh - 140px)}.modal-title{font-size:16px}.btn-close{font-size:24px;height:25px;width:25px}}@media (max-width:480px){.header{min-height:50px}.app{font-size:13px}.content{padding:.5rem}.modal-header h2{font-size:14px}.historial-modal{border-radius:0;height:100vh;margin:0;width:100vw}.modal-body{padding:.5rem}}@media (max-height:600px){.sidebar{max-height:calc(100vh - 50px)}.content{max-height:calc(100vh - 70px)}}@media (hover:none) and (pointer:coarse){.nav-btn{padding:14px 12px}.logout-btn,.toggle-sidebar-btn{min-height:44px;min-width:44px}}
/*# sourceMappingURL=main.6dda07b2.css.map*/