*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-color:#4a90e2;--secondary-color:#50c878;--danger-color:#e74c3c;--warning-color:#f39c12;--dark-color:#2c3e50;--light-color:#ecf0f1;--border-radius:8px;--box-shadow:0 2px 8px #0000001a}.container{margin:0 auto;max-width:1400px;padding:20px}.card{background:#fff;border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 8px #0000001a;box-shadow:var(--box-shadow);margin-bottom:20px;padding:20px}.btn{border:none;border-radius:8px;border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-primary{background-color:#4a90e2;background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:#3a7bc8}.btn-success{background-color:#50c878;background-color:var(--secondary-color);color:#fff}.btn-danger{background-color:#e74c3c;background-color:var(--danger-color);color:#fff}.btn-secondary{background-color:#95a5a6;color:#fff}.form-group{margin-bottom:15px}.form-group label{color:#2c3e50;color:var(--dark-color);display:block;font-weight:600;margin-bottom:5px}.form-control{border:1px solid #ddd;border-radius:8px;border-radius:var(--border-radius);font-size:14px;padding:10px;width:100%}.form-control:focus{border-color:#4a90e2;border-color:var(--primary-color);outline:none}.table{background:#fff;border-collapse:collapse;border-radius:8px;border-radius:var(--border-radius);overflow:hidden;width:100%}.table td,.table th{border-bottom:1px solid #eee;padding:12px;text-align:left}.table th{background-color:#4a90e2;background-color:var(--primary-color);color:#fff;font-weight:600}.table tr:hover{background-color:#f8f9fa}.alert{border-radius:8px;border-radius:var(--border-radius);margin-bottom:20px;padding:15px}.alert-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert-error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.alert-info{background-color:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.spinner{border-top-color:#4a90e2;border-top:4px solid var(--primary-color);height:40px;margin:20px auto;width:40px}.login-wrapper{align-items:center;background:linear-gradient(135deg,#667eea,#55a0bc 50%);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-container-modern{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;display:flex;max-width:1000px;min-height:600px;overflow:hidden;width:100%}.login-left{align-items:center;background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;display:flex;flex:1 1;flex-direction:column;justify-content:center;overflow:hidden;padding:60px 40px;position:relative}.login-left:before{animation:pulse 15s ease-in-out infinite;background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.3;transform:scale(1.1)}}.login-branding{position:relative;text-align:center;z-index:1}.clinic-logo{animation:float 3s ease-in-out infinite;margin-bottom:30px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.clinic-title{font-size:32px;font-weight:700;margin-bottom:10px;text-shadow:0 2px 4px #0000001a}.clinic-subtitle{font-size:16px;margin-bottom:40px;opacity:.9}.login-features{align-items:flex-start;display:flex;flex-direction:column;gap:20px;margin-top:40px;max-width:300px;width:100%}.feature-item{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:10px;display:flex;font-size:15px;gap:30px;padding:12px 20px;transition:all .3s ease;width:100%}.feature-item:hover{background:#fff3;transform:translateX(5px)}.feature-icon{font-size:24px}.login-right{align-items:center;display:flex;flex:1 1;justify-content:center;padding:60px 40px}.login-form-container{max-width:400px;width:100%}.login-form-header{margin-bottom:30px}.login-form-header h2{color:#2c3e50;font-size:28px;font-weight:700;margin-bottom:8px}.login-form-header p{color:#7f8c8d;font-size:14px}.alert-modern{align-items:center;animation:slideDown .3s ease-out;border-radius:10px;display:flex;font-size:14px;gap:10px;margin-bottom:20px;padding:12px 16px}.alert-error-modern{background-color:#fee;border:1px solid #fcc;color:#c33}.alert-error-modern svg{flex-shrink:0}.login-form-modern{display:flex;flex-direction:column;gap:20px}.form-group-modern{display:flex;flex-direction:column;gap:8px}.form-label-modern{align-items:center;color:#2c3e50;display:flex;font-size:14px;font-weight:600;gap:8px}.form-label-modern svg{color:#4a90e2}.form-input-modern{background-color:#f8f9fa;border:2px solid #e0e0e0;border-radius:10px;font-size:15px;padding:12px 16px;transition:all .3s ease;width:100%}.form-input-modern:focus{background-color:#fff;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a;outline:none}.form-input-modern::placeholder{color:#bbb}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper .form-input-modern{padding-right:45px}.password-toggle{align-items:center;background:none;border:none;color:#7f8c8d;cursor:pointer;display:flex;justify-content:center;padding:5px;position:absolute;right:12px;transition:color .3s ease}.password-toggle:hover{color:#4a90e2}.btn-login-modern{align-items:center;background:linear-gradient(135deg,#4a90e2,#357abd);border:none;border-radius:10px;box-shadow:0 4px 15px #4a90e24d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;margin-top:10px;padding:14px 24px;transition:all .3s ease;width:100%}.btn-login-modern:hover:not(:disabled){box-shadow:0 6px 20px #4a90e266;transform:translateY(-2px)}.btn-login-modern:active:not(:disabled){transform:translateY(0)}.btn-login-modern:disabled{cursor:not-allowed;opacity:.7}.spinner-login{animation:spin .8s linear infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.login-footer{margin-top:30px}.divider{align-items:center;color:#7f8c8d;display:flex;font-size:12px;margin:20px 0}.divider:after,.divider:before{background:#e0e0e0;content:"";flex:1 1;height:1px}.divider span{padding:0 15px}.system-info{flex-direction:column}.info-text,.system-info{align-items:center;display:flex;gap:8px}.info-text{color:#7f8c8d;font-size:12px}.info-text svg{color:#4a90e2;flex-shrink:0}.copyright{color:#bbb;font-size:11px;text-align:center}@media (max-width:768px){.login-container-modern{flex-direction:column;max-width:500px}.login-left{min-height:auto;padding:40px 30px}.clinic-title{font-size:24px}.clinic-subtitle{font-size:14px}.login-features{margin-top:30px}.login-right{padding:40px 30px}.login-form-header h2{font-size:24px}}@media (max-width:480px){.login-wrapper{padding:10px}.login-left,.login-right{padding:30px 20px}.clinic-title{font-size:20px}.feature-item{font-size:13px;padding:10px 15px}}.navbar{background:linear-gradient(135deg,#1e3c72,#2a5298);border-bottom:3px solid #3498db;box-shadow:0 4px 12px #00000026;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.navbar-container{height:70px;padding:0 30px}.navbar-brand{cursor:pointer;gap:12px;transition:transform .3s ease}.navbar-brand:hover{transform:scale(1.05)}.brand-logo{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:center;padding:6px}.brand-text{display:flex;flex-direction:column}.brand-title{color:#fff;font-size:18px;font-weight:700;letter-spacing:.5px;line-height:1.2}.brand-subtitle{color:#fffc;font-size:11px;font-weight:400;letter-spacing:.5px}.navbar-menu{flex:1 1;gap:5px;justify-content:center;margin:0;padding:0}.navbar-menu a,.navbar-menu li{position:relative}.navbar-menu a{align-items:center;border-radius:8px;color:#ffffffe6;display:flex;font-size:14px;font-weight:500;gap:8px;overflow:hidden;padding:10px 18px;transition:all .3s ease}.navbar-menu a:before{background:#ffffff1a;content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .3s ease;width:100%}.navbar-menu a:hover:before{left:0}.navbar-menu a:hover{background:#ffffff26;color:#fff;transform:translateY(-2px)}.navbar-menu a.active{background:#fff3;box-shadow:0 2px 8px #0003;color:#fff}.navbar-menu a.active:after{background:#3498db;border-radius:3px 3px 0 0;bottom:0;content:"";height:3px;left:0;position:absolute;right:0}.navbar-menu svg{flex-shrink:0}.navbar-user{position:relative}.user-info{align-items:center;background:#ffffff1a;border:2px solid #0000;border-radius:25px;cursor:pointer;display:flex;gap:12px;padding:8px 16px;transition:all .3s ease}.user-info:hover{background:#fff3;border-color:#ffffff4d}.user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 2px 8px #0003;color:#fff;display:flex;font-size:16px;font-weight:700;height:38px;justify-content:center;width:38px}.user-details{align-items:flex-start;display:flex;flex-direction:column}.user-name{color:#fff;font-size:14px;font-weight:600;line-height:1.2}.user-role{color:#ffffffb3;font-size:11px;font-weight:400}.dropdown-icon{color:#fffc;transition:transform .3s ease}.user-info:hover .dropdown-icon{transform:rotate(180deg)}.user-dropdown{animation:slideDown .3s ease;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;margin-top:10px;min-width:200px;overflow:hidden;position:absolute;right:0;top:100%}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{align-items:center;color:#2c3e50;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:14px 18px;transition:all .3s ease}.dropdown-item:hover{background:#f8f9fa;color:#e74c3c}.dropdown-item svg{color:#7f8c8d}.dropdown-item:hover svg{color:#e74c3c}@media (max-width:1200px){.navbar-menu a span{display:none}.navbar-menu a{padding:10px 12px}}@media (max-width:768px){.navbar-container{height:60px;padding:0 15px}.brand-subtitle{display:none}.brand-title{font-size:16px}.navbar-menu{gap:2px}.navbar-menu a{padding:8px 10px}.user-details{display:none}.user-info{padding:6px}}.dashboard-container{background-color:#f8f9fa;min-height:calc(100vh - 64px);padding:2rem}.dashboard-header{align-items:center;background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000000d;display:flex;justify-content:space-between;margin-bottom:2rem;padding:2rem}.header-content h1{color:#1a1a1a;font-size:2rem;font-weight:700;margin:0}.header-content p{color:#6c757d;font-size:1.1rem;margin-top:.5rem}.date-badge{align-items:center;background:#e9ecef;border-radius:50px;color:#495057;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.5rem 1rem}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border:1px solid #0000000d;border-radius:16px;box-shadow:0 4px 15px #0000000d;cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease}.stat-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-5px)}.stat-card:before{background:#ccc;content:"";height:100%;left:0;position:absolute;top:0;transition:all .3s ease;width:4px}.stat-card.blue:before{background:#4e73df}.stat-card.orange:before{background:#f6c23e}.stat-card.red:before{background:#e74a3b}.stat-card.green:before{background:#1cc88a}.stat-icon-wrapper{align-items:center;border-radius:12px;display:flex;font-size:1.5rem;height:48px;justify-content:center;margin-bottom:1rem;width:48px}.stat-card.blue .stat-icon-wrapper{background:#4e73df1a;color:#4e73df}.stat-card.orange .stat-icon-wrapper{background:#f6c23e1a;color:#f6c23e}.stat-card.red .stat-icon-wrapper{background:#e74a3b1a;color:#e74a3b}.stat-card.green .stat-icon-wrapper{background:#1cc88a1a;color:#1cc88a}.stat-value{color:#2d3436;font-size:2.5rem;font-weight:800;line-height:1;margin:.5rem 0}.stat-label{color:#858796;font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.stat-desc{color:#b7b9cc;font-size:.85rem;margin-top:.5rem}.dashboard-sections{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:2fr 1fr}.section-card{padding:1.5rem}.section-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.section-header h2{color:#2d3436;font-size:1.25rem;margin:0}.quick-actions-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.action-btn{align-items:center;background:#f8f9fa;border:2px solid #0000;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:.8rem;justify-content:center;padding:1.5rem;text-align:center;transition:all .2s ease}.action-btn:hover{background:#fff;border-color:#4e73df;box-shadow:0 4px 10px #4e73df26;transform:translateY(-2px)}.action-icon{font-size:1.8rem}.action-label{color:#4a5568;font-size:.9rem;font-weight:600}.welcome-banner{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff;margin-bottom:2rem;overflow:hidden;padding:2rem;position:relative}.welcome-content{position:relative;z-index:1}.welcome-banner h2{font-size:1.8rem;margin:0 0 .5rem}.welcome-banner p{font-size:1.1rem;margin:0;opacity:.9}@media (max-width:1024px){.dashboard-sections{grid-template-columns:1fr}}.pacientes-container{background-color:#f8f9fa;min-height:calc(100vh - 64px);padding:2rem}.pacientes-header{align-items:center;background:#fff;border-radius:16px;box-shadow:0 4px 15px #0000000d;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.pacientes-header h1{color:#1a1a1a;font-size:2rem;font-weight:700;margin:0}.btn-nuevo-paciente{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 2rem;transition:all .3s ease}.btn-nuevo-paciente:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.search-container{background:#fff;border-radius:16px;box-shadow:0 4px 15px #0000000d;margin-bottom:2rem;padding:1.5rem}.search-input-wrapper{max-width:500px;position:relative}.search-input-wrapper input{border:2px solid #e9ecef;border-radius:50px;font-size:1rem;padding:.875rem 1rem .875rem 3rem;transition:all .3s ease;width:100%}.search-input-wrapper input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.search-icon{color:#6c757d;font-size:1.2rem;left:1rem;position:absolute;top:50%;transform:translateY(-50%)}.paciente-edad-badge{background:#e9ecef;color:#495057;display:inline-block;font-size:.85rem;font-weight:500}.badge-genero,.paciente-edad-badge{border-radius:50px;padding:.25rem .75rem}.badge-genero{align-items:center;display:inline-flex;font-size:.75rem;font-weight:600;gap:.25rem}.badge-genero.masculino{background:#3b82f61a;color:#3b82f6}.badge-genero.femenino{background:#ec48991a;color:#ec4899}.badge-sangre{background:#ef44441a;border-radius:50px;color:#ef4444;display:inline-block;font-size:.75rem;font-weight:600;margin-left:.5rem;padding:.25rem .75rem}.btn-consulta{background:linear-gradient(135deg,#1cc88a,#13855c);color:#fff}.btn-consulta:hover{box-shadow:0 4px 12px #1cc88a4d;transform:translateY(-2px)}.btn-expediente{background:#4e73df;color:#fff}.btn-expediente:hover{background:#2e59d9;transform:translateY(-2px)}.btn-editar{background:#f6c23e;color:#fff}.btn-editar:hover{background:#dda20a;transform:translateY(-2px)}.btn-eliminar{background:#e74a3b;color:#fff}.btn-eliminar:hover{background:#c0392b;transform:translateY(-2px)}.spinner{border-top-color:#667eea}@media (max-width:768px){.pacientes-header{align-items:stretch;flex-direction:column;gap:1rem}.btn-nuevo-paciente{justify-content:center;width:100%}.table-container{overflow-x:auto}.modern-table{min-width:800px}.table-actions{flex-direction:column}.btn-accion{width:100%}}.expedientes-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;box-shadow:0 10px 30px #667eea4d;color:#fff;margin-bottom:30px;padding:30px}.expedientes-header-content{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between}.expedientes-title{font-size:32px;font-weight:700;margin:0 0 10px}.expedientes-badges{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.expedientes-badge{background:#fff3;border-radius:20px;font-size:14px;padding:8px 16px}.expedientes-badge.large{font-size:16px;font-weight:500}.btn-new-consultation{background:#fff;border:none;border-radius:10px;box-shadow:0 4px 15px #0003;color:#667eea;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-new-consultation:hover{box-shadow:0 6px 20px #0000004d;transform:translateY(-2px)}.patient-info-card{background:#fff;border:1px solid #e8e8e8;border-radius:15px;box-shadow:0 2px 10px #00000014;margin-bottom:30px;padding:25px}.section-title{border-bottom:3px solid #667eea;color:#2c3e50;display:inline-block;font-size:20px;margin:0 0 20px;padding-bottom:10px}.patient-info-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:20px}.info-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:10px;padding:15px;transition:all .3s ease}.info-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-3px)}.info-label{color:#7f8c8d;font-size:12px;font-weight:500;margin-bottom:5px}.info-value{color:#2c3e50;font-size:15px;font-weight:600}.info-value.danger{color:#e74c3c}.info-value.success{color:#27ae60}.history-card{background:#fff;border:1px solid #e8e8e8;border-radius:15px;box-shadow:0 2px 10px #00000014;padding:25px}.empty-state{color:#7f8c8d;padding:60px 20px}.empty-state-icon{font-size:64px;margin-bottom:20px}.consultations-list{display:flex;flex-direction:column;gap:25px}.consultation-item{background:#fafbfc;border:2px solid #e8e8e8;border-radius:12px;padding:20px;position:relative;transition:all .3s ease}.consultation-item:hover{border-color:#667eea;box-shadow:0 4px 20px #667eea26}.consultation-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 2px 8px #667eea4d;color:#fff;font-size:12px;font-weight:600;left:20px;padding:6px 16px;position:absolute;top:-12px}.consultation-header{align-items:center;border-bottom:2px solid #e8e8e8;display:flex;justify-content:space-between;margin-bottom:20px;margin-top:10px;padding-bottom:15px}.consultation-meta{flex-wrap:wrap;gap:15px}.consultation-meta,.meta-badge{align-items:center;display:flex}.meta-badge{background:#fff;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;gap:8px;padding:8px 16px}.meta-badge.doctor{color:#7f8c8d}.diagnostic-section{margin-bottom:20px}.diagnostic-card{border:1px solid;border-radius:10px;margin-bottom:12px;padding:15px}.diagnostic-card.motivo{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-color:#90caf9}.diagnostic-card.historia{background:#fff9e6;border-color:#ffe082}.diagnostic-card.diagnostico{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-color:#81c784}.diagnostic-label{font-size:12px;font-weight:600;margin-bottom:5px}.diagnostic-text{font-size:14px;line-height:1.6}.vitals-section{margin-bottom:20px}.vitals-title{align-items:center;color:#2c3e50;display:flex;font-size:14px;font-weight:700;gap:8px;margin-bottom:12px}.vitals-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.vital-card{background:#fff;border:2px solid;border-radius:8px;padding:12px;text-align:center}.vital-label{color:#7f8c8d;font-size:11px;margin-bottom:4px}.vital-value{font-size:18px;font-weight:700}.collapsible-sections{display:flex;flex-direction:column;gap:12px}.collapsible-item{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:12px}.collapsible-summary{align-items:center;color:#2c3e50;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px}.collapsible-content{color:#555;font-size:13px;margin-top:12px;padding-left:24px}.info-card{border:1px solid;border-radius:8px;margin-bottom:12px;padding:15px}.info-card.examen{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border-color:#ffb74d}.info-card.tratamiento{background:linear-gradient(135deg,#f3e5f5,#e1bee7);border-color:#ce93d8}.info-card.receta{background:linear-gradient(135deg,#e0f2f1,#b2dfdb);border-color:#80cbc4}.info-card.observaciones{background:#f5f5f5;border-color:#e0e0e0}.info-card-title{align-items:center;display:flex;font-size:12px;font-weight:600;gap:8px;margin-bottom:8px}.info-card-text{font-size:13px;line-height:1.6}.receta-content{background:#fff;border:1px dashed #00695c;border-radius:6px;font-family:monospace;padding:12px;white-space:pre-line}@media (max-width:768px){.expedientes-header{padding:20px}.expedientes-title{font-size:24px}.patient-info-grid{grid-template-columns:1fr}.vitals-grid{grid-template-columns:repeat(2,1fr)}.consultation-header{align-items:flex-start;flex-direction:column}}.citas-container{background-color:#f8f9fa;min-height:calc(100vh - 64px);padding:2rem}.citas-header{align-items:center;background:#fff;border-radius:16px;box-shadow:0 4px 15px #0000000d;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.citas-header h1{color:#1a1a1a;font-size:2rem;font-weight:700;margin:0}.btn-nueva-cita{align-items:center;background:#4e73df;border:none;border-radius:50px;box-shadow:0 4px 15px #4e73df4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 2rem;transition:all .3s ease}.btn-nueva-cita:hover{background:#2e59d9;box-shadow:0 6px 20px #4e73df66;transform:translateY(-2px)}.filtro-container{background:#fff;border-radius:16px;box-shadow:0 4px 15px #0000000d;margin-bottom:2rem;padding:1.5rem}.filtro-header{gap:1.5rem;justify-content:space-between}.filtro-fecha,.filtro-header{align-items:center;display:flex;flex-wrap:wrap}.filtro-fecha{gap:1rem}.filtro-fecha label{color:#2d3436;font-weight:600}.filtro-fecha input[type=date]{border:2px solid #e9ecef;border-radius:8px;font-size:.95rem;padding:.625rem 1rem;transition:all .3s ease}.filtro-fecha input[type=date]:focus{border-color:#4e73df;box-shadow:0 0 0 3px #4e73df1a;outline:none}.btn-hoy{background:#858796;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;transition:all .2s ease}.btn-hoy:hover{background:#6c757d;transform:translateY(-1px)}.fecha-seleccionada{color:#6c757d;font-size:.9rem}.fecha-seleccionada strong{color:#2d3436}.stats-resumen{display:flex;gap:2rem}.stat-item{align-items:center;display:flex;gap:.5rem}.stat-item strong{color:#2d3436;font-size:.9rem}.modern-table tbody tr{border-bottom:1px solid #f0f0f0}.modern-table tbody tr:hover{background-color:#f8f9fa;box-shadow:0 2px 8px #0000000d}.modern-table tbody tr:last-child{border-bottom:none}.badge-estado{align-items:center;border-radius:50px;display:inline-flex;font-size:.8rem;font-weight:600;gap:.375rem;padding:.375rem .875rem}.badge-estado.programada{background:#4e73df1a;color:#4e73df}.badge-estado.completada{background:#1cc88a1a;color:#1cc88a}.badge-estado.cancelada{background:#e74a3b1a;color:#e74a3b}.badge-seguro{align-items:center;border-radius:50px;display:inline-flex;font-size:.8rem;font-weight:600;gap:.375rem;padding:.375rem .875rem}.badge-seguro.con-seguro{background:#4caf501a;color:#4caf50}.badge-seguro.sin-seguro{background:#e9ecef;color:#6c757d}.btn-ver-expediente{background:#36b9cc;color:#fff}.btn-ver-expediente:hover{background:#2c9faf;transform:translateY(-2px)}.btn-completar{background:#1cc88a;color:#fff}.btn-completar:hover{background:#17a673;transform:translateY(-2px)}.btn-cancelar{background:#e74a3b;color:#fff}.btn-cancelar:hover{background:#c0392b;transform:translateY(-2px)}@media (max-width:1200px){.modern-table{font-size:.875rem}.modern-table tbody td,.modern-table thead th{padding:1rem}.filtro-header{align-items:flex-start;flex-direction:column}.stats-resumen{width:100%}}@media (max-width:768px){.citas-header{align-items:stretch;flex-direction:column;gap:1rem}.btn-nueva-cita{justify-content:center;width:100%}.table-container{overflow-x:auto}.modern-table{min-width:800px}.table-actions{flex-direction:column}.btn-accion{width:100%}.stats-resumen{flex-direction:column;gap:.75rem}}.inventario-container{background-color:#f8f9fa;min-height:calc(100vh - 64px);padding:2rem}.inventario-header{align-items:center;background:#fff;border-radius:16px;box-shadow:0 4px 15px #0000000d;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.inventario-header h1{color:#1a1a1a;font-size:2rem;font-weight:700;margin:0}.btn-nuevo-item{align-items:center;background:#4e73df;border:none;border-radius:50px;box-shadow:0 4px 15px #4e73df4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 2rem;transition:all .3s ease}.btn-nuevo-item:hover{background:#2e59d9;box-shadow:0 6px 20px #4e73df66;transform:translateY(-2px)}.btn-agregar-inventario{align-items:center;background:#4e73df;border:none;border-radius:50px;box-shadow:0 4px 15px #4e73df4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 2rem;transition:all .3s ease}.btn-agregar-inventario:hover{background:#2e59d9;box-shadow:0 6px 20px #4e73df66;transform:translateY(-2px)}.table-container{box-shadow:0 4px 15px #0000000d;overflow:hidden}.item-nombre-cell{color:#1a1a1a;font-weight:600;margin-bottom:.25rem}.item-descripcion{color:#6c757d;font-size:.85rem;margin-top:.25rem}.categoria-badge{align-items:center;border-radius:50px;display:inline-flex;font-size:.8rem;font-weight:600;gap:.375rem;padding:.375rem .875rem}.categoria-badge.medicamento{background:#4e73df1a;color:#4e73df}.categoria-badge.material{background:#f6c23e1a;color:#f6c23e}.categoria-badge.equipo{background:#36b9cc1a;color:#36b9cc}.categoria-badge.otro{background:#8587961a;color:#858796}.cantidad-cell{color:#2d3436;font-size:1.1rem;font-weight:600}.unidad-medida{color:#6c757d;font-size:.85rem;margin-left:.25rem}.stock-minimo-cell{color:#6c757d;font-size:.95rem}.badge-stock{align-items:center;border-radius:50px;display:inline-flex;font-size:.8rem;font-weight:600;gap:.375rem;padding:.375rem .875rem}.badge-stock.bajo{background:#e74a3b1a;color:#e74a3b}.badge-stock.medio{background:#f6c23e1a;color:#f6c23e}.badge-stock.ok{background:#1cc88a1a;color:#1cc88a}.precio-cell{color:#4e73df;font-size:1rem;font-weight:600}.btn-editar-item{background:#f6c23e;color:#fff}.btn-editar-item:hover{background:#dda20a;transform:translateY(-2px)}.empty-state{background:#fff;border-radius:16px;box-shadow:0 4px 15px #0000000d;padding:4rem 2rem}.empty-state-icon{font-size:4rem}.empty-state h3{color:#2d3436;margin-bottom:.5rem}.empty-state p{color:#6c757d}@media (max-width:1200px){.modern-table{font-size:.875rem}.modern-table tbody td,.modern-table thead th{padding:1rem}}@media (max-width:768px){.inventario-header{align-items:stretch;flex-direction:column;gap:1rem}.btn-agregar-inventario,.btn-nuevo-item{justify-content:center;width:100%}.table-container{overflow-x:auto}.modern-table{min-width:800px}.table-actions{flex-direction:column}.btn-accion{width:100%}}.usuarios-header{align-items:center;background:#fff;border-radius:16px;box-shadow:0 4px 15px #0000000d;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.usuarios-header h1{color:#1a1a1a;font-size:2rem;font-weight:700;margin:0}.usuarios-card{background:#fff;border-radius:16px;box-shadow:0 4px 15px #0000000d;overflow:hidden}.usuarios-table{border-collapse:initial;border-spacing:0;width:100%}.usuarios-table thead{background:#4e73df}.usuarios-table thead th{border:none;color:#fff;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1.25rem 1rem;text-align:left;text-transform:uppercase}.usuarios-table tbody tr{border-bottom:1px solid #e9ecef;transition:all .2s ease}.usuarios-table tbody tr:nth-child(odd){background-color:#fff}.usuarios-table tbody tr:nth-child(2n){background-color:#f8f9fa}.usuarios-table tbody tr:hover{background-color:#e7f1ff!important;box-shadow:0 2px 8px #4e73df26;transform:scale(1.005)}.usuarios-table tbody td{color:#2d3436;font-size:.95rem;padding:1.25rem 1rem;vertical-align:middle}.username-badge{background:#4e73df1a;color:#4e73df;font-family:monospace;font-size:.85rem}.rol-badge,.username-badge{border-radius:50px;font-weight:600;padding:.375rem .875rem}.rol-badge{align-items:center;display:inline-flex;font-size:.8rem;gap:.375rem}.rol-badge.admin{background:#dc35451a;color:#dc3545}.rol-badge.secretaria{background:#4e73df1a;color:#4e73df}.estado-badge{border-radius:50px;font-size:.8rem;font-weight:600;padding:.375rem .875rem}.estado-badge.activo{background:#1cc88a1a;color:#1cc88a}.estado-badge.inactivo{background:#e74c3c1a;color:#e74c3c}.action-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.btn-action{border:none;border-radius:8px;cursor:pointer;font-size:.8rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.btn-edit{background:#f6c23e;color:#fff}.btn-edit:hover{background:#dda20a;transform:translateY(-2px)}.btn-password{background:#36b9cc;color:#fff}.btn-password:hover{background:#2c9faf;transform:translateY(-2px)}.btn-delete{background:#e74c3c;color:#fff}.btn-delete:hover{background:#c0392b;transform:translateY(-2px)}.btn-icon{background:#0000;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem;transition:transform .2s}.btn-icon:hover{transform:scale(1.2)}@media (max-width:1200px){.usuarios-table{font-size:.875rem}.usuarios-table tbody td,.usuarios-table thead th{padding:1rem .75rem}.action-buttons{flex-direction:column}.btn-action{width:100%}}@media (max-width:768px){.usuarios-header{align-items:stretch;flex-direction:column;gap:1rem}.usuarios-header h1{font-size:1.5rem}.usuarios-card{overflow-x:auto}.usuarios-table{min-width:900px}}.cobros-container{background-color:#f8f9fa;min-height:calc(100vh - 64px);padding:2rem}.cobros-header{align-items:center;background:#fff;border-radius:16px;box-shadow:0 4px 15px #0000000d;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.cobros-header h1{color:#1a1a1a;font-size:2rem;font-weight:700;margin:0}.btn-registrar-venta{align-items:center;background:#1cc88a;border:none;border-radius:50px;box-shadow:0 4px 15px #4e73df4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 2rem;transition:all .3s ease}.btn-registrar-venta:hover{background:#2e59d9;box-shadow:0 6px 20px #4e73df66;transform:translateY(-2px)}.section-card{background:#fff;border-radius:16px;box-shadow:0 4px 15px #0000000d;margin-bottom:2rem;padding:1.5rem 2rem}.section-card h3{color:#2d3436;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.filtro-fecha-cobros{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.filtro-fecha-cobros h3{margin:0}.fecha-selector{align-items:center;display:flex;gap:1rem}.fecha-selector label{color:#2d3436;font-weight:600}.fecha-selector input[type=date]{border:2px solid #e9ecef;border-radius:8px;font-size:.95rem;padding:.625rem 1rem;transition:all .3s ease}.fecha-selector input[type=date]:focus{border-color:#4e73df;box-shadow:0 0 0 3px #4e73df1a;outline:none}.table-container{background:#fff;border-radius:16px;overflow:visible}.modern-table{border-collapse:initial;border-spacing:0;width:100%}.modern-table thead{background:#4e73df}.modern-table thead th{border:none;color:#fff;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1.25rem 1.5rem;text-align:left;text-transform:uppercase}.modern-table tbody tr{transition:all .2s ease}.modern-table tbody tr:nth-child(odd){background-color:#fff}.modern-table tbody tr:nth-child(2n){background-color:#f8f9fa}.modern-table tbody tr:hover{background-color:#e7f1ff!important;box-shadow:0 2px 8px #4e73df26;transform:scale(1.01)}.modern-table tbody td{border-bottom:1px solid #e9ecef;color:#2d3436;font-size:.95rem;padding:1.25rem 1.5rem;vertical-align:middle}.modern-table tbody tr:last-child td{border-bottom:none}.paciente-nombre-cell{color:#1a1a1a;font-weight:600}.fecha-cell{color:#495057;font-weight:500}.hora-cell{color:#6c757d;font-size:.9rem}.monto-cell{color:#2d3436;font-weight:600}.total-cell{color:#4e73df;font-size:1.1rem;font-weight:700}.badge-metodo-pago{align-items:center;border-radius:50px;display:inline-flex;font-size:.8rem;font-weight:600;gap:.375rem;padding:.375rem .875rem}.badge-metodo-pago.efectivo{background:#1cc88a1a;color:#1cc88a}.badge-metodo-pago.tarjeta{background:#36b9cc1a;color:#36b9cc}.badge-metodo-pago.transferencia{background:#4e73df1a;color:#4e73df}.badge-metodo-pago.seguro{background:#4caf501a;color:#4caf50}.resumen-dia{align-items:center;background:#f8f9fa;border-left:4px solid #4e73df;border-radius:12px;display:flex;justify-content:space-between;margin-top:2rem;padding:1.5rem}.resumen-dia-info{color:#2d3436;font-size:1rem;font-weight:600}.resumen-dia-total{color:#4e73df;font-size:1.75rem;font-weight:700}.table-actions{flex-wrap:wrap;gap:.5rem;justify-content:center}.btn-accion{border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.btn-registrar-cobro{background:#1cc88a;color:#fff}.btn-registrar-cobro:hover{background:#17a673;transform:translateY(-2px)}.btn-ver-detalle{background:#36b9cc;color:#fff}.btn-ver-detalle:hover{background:#2c9faf;transform:translateY(-2px)}.btn-editar-cobro{background:#f6c23e;color:#fff}.btn-editar-cobro:hover{background:#dda20a;transform:translateY(-2px)}.empty-state{color:#6c757d;padding:3rem 2rem;text-align:center}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.3}.spinner-container{align-items:center;display:flex;justify-content:center;min-height:300px}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#4e73df;height:50px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.productos-cell-container{cursor:pointer;position:relative}.productos-cell{align-items:center;display:flex;gap:.5rem}.productos-indicator{animation:bounce 2s infinite;font-size:1.2rem}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.productos-tooltip{animation:fadeIn .2s ease;background:#fff;border:2px solid #4e73df;border-radius:12px;box-shadow:0 10px 40px #0000004d,0 0 0 1px #0000000d;left:50%;margin-top:.5rem;max-width:350px;min-width:250px;padding:1rem;position:absolute;top:100%;transform:translateX(-50%);z-index:1000}@keyframes fadeIn{0%{opacity:0;transform:translateX(-50%) translateY(-10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.productos-tooltip:before{border-bottom:8px solid #4e73df;border-left:8px solid #0000;border-right:8px solid #0000;content:"";height:0;left:50%;position:absolute;top:-8px;transform:translateX(-50%);width:0}.tooltip-header{border-bottom:2px solid #e9ecef;color:#4e73df;font-size:.9rem;font-weight:700;margin-bottom:.75rem;padding-bottom:.5rem}.tooltip-item{grid-gap:.75rem;align-items:center;border-bottom:1px solid #f0f0f0;display:grid;gap:.75rem;grid-template-columns:1fr auto auto;padding:.5rem 0}.tooltip-item:last-child{border-bottom:none}.tooltip-nombre{color:#2d3436;font-size:.875rem;font-weight:600}.tooltip-cantidad{background:#f8f9fa;border-radius:4px;color:#6c757d;font-size:.875rem;font-weight:600;padding:.25rem .5rem}.tooltip-precio{color:#4e73df;font-size:.875rem;font-weight:700}@media (max-width:1200px){.modern-table{font-size:.875rem}.modern-table tbody td,.modern-table thead th{padding:1rem}.filtro-fecha-cobros{align-items:flex-start;flex-direction:column;gap:1rem}.resumen-dia{flex-direction:column;gap:1rem;text-align:center}}@media (max-width:768px){.cobros-header{align-items:stretch;flex-direction:column;gap:1rem}.btn-registrar-venta{justify-content:center;width:100%}.table-container{overflow-x:auto}.modern-table{min-width:900px}.table-actions{flex-direction:column}.btn-accion{width:100%}}.App{background-color:#f5f7fa;min-height:100vh}.navbar{background-color:#2c3e50;box-shadow:0 2px 8px #0000001a;color:#fff;padding:15px 30px}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px}.navbar-brand{align-items:center;display:flex;font-size:24px;font-weight:700;gap:10px}.navbar-menu{display:flex;gap:20px;list-style:none}.navbar-menu a{border-radius:4px;color:#fff;padding:8px 16px;text-decoration:none;transition:background-color .3s}.navbar-menu a.active,.navbar-menu a:hover{background-color:#ffffff1a}.navbar-user{align-items:center;display:flex;gap:15px}.navbar-user span{font-size:14px}.navbar-user button{background-color:#e74c3c;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 16px;transition:background-color .3s}.navbar-user button:hover{background-color:#c0392b}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:400px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-header h1{color:#2c3e50;margin-bottom:10px}.login-header p{color:#7f8c8d;font-size:14px}.dashboard-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:20px}.dashboard-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;padding:25px;transition:transform .3s}.dashboard-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-5px)}.dashboard-card h3{color:#2c3e50;margin-bottom:10px}.dashboard-card-value{color:#4a90e2;font-size:36px;font-weight:700;margin:10px 0}.dashboard-card-description{color:#7f8c8d;font-size:14px}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;max-height:90vh;max-width:600px;overflow-y:auto;padding:30px;width:90%}.modal-header{align-items:center;border-bottom:2px solid #eee;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.modal-header h2{color:#2c3e50;margin:0}.modal-close{background:none;border:none;color:#7f8c8d;cursor:pointer;font-size:24px}.modal-close:hover{color:#2c3e50}.modal-footer{border-top:1px solid #eee;display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:15px}.form-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.form-grid-full{grid-column:1/-1}.table-actions{display:flex;gap:8px}.btn-sm{font-size:12px;padding:6px 12px}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.page-header h1{color:#2c3e50;font-size:28px}.search-box{display:flex;gap:10px;margin-bottom:20px}.search-box input{border:1px solid #ddd;border-radius:8px;flex:1 1;font-size:14px;padding:10px}.badge{border-radius:4px;display:inline-block;font-size:12px;font-weight:600;padding:4px 8px}.badge-success{background-color:#d4edda;color:#155724}.badge-warning{background-color:#fff3cd;color:#856404}.badge-danger{background-color:#f8d7da;color:#721c24}.badge-info{background-color:#d1ecf1;color:#0c5460}@media (max-width:768px){.navbar-menu{flex-direction:column;gap:10px}.dashboard-grid,.form-grid{grid-template-columns:1fr}.table{font-size:12px}.table td,.table th{padding:8px}}
/*# sourceMappingURL=main.611354ee.css.map*/