body{background-color:#f7f9fc;color:#333;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;margin:0}.App{display:flex;flex-direction:column;min-height:100vh}header{padding:1rem 2rem}footer,header{background-color:#004d7a;color:#fff;text-align:center}footer{margin-top:auto;padding:.5rem 1rem}.menu-container{background-color:#fff;box-shadow:0 2px 4px #0000001a;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;padding:1rem}.menu-container a{text-decoration:none}.menu-button{background-color:#008cba;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .3s ease}.menu-button:hover{background-color:#005f75}main{margin:0 auto;max-width:1200px;padding:2rem;width:100%}form{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;padding:1.5rem}form label{display:block;font-weight:500;margin-bottom:.5rem}form input[type=date],form input[type=email],form input[type=text],form select,form textarea{border:1px solid #ccc;border-radius:4px;font-size:1rem;margin-bottom:1rem;padding:.75rem;transition:border-color .3s ease;width:100%}form input[type=date]:focus,form input[type=email]:focus,form input[type=text]:focus,form select:focus,form textarea:focus{border-color:#008cba;outline:none}form button{background-color:#008cba;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .3s ease}form button:hover{background-color:#005f75}table{border-collapse:collapse;margin-top:1rem;width:100%}table td,table th{border:1px solid #ddd;padding:.75rem;text-align:left}table th{background-color:#f2f2f2;font-weight:600}.login-container,.register-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:2rem auto;max-width:400px;padding:2rem}.login-container h2,.register-container h2{color:#004d7a;margin-bottom:1.5rem;text-align:center}.form-group input[type=password]{border:1px solid #ccc;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .3s ease;width:100%}.form-group input[type=password]:focus{border-color:#008cba;outline:none}.form-group small{margin-top:.25rem}.login-links,.register-links{margin-top:1.5rem;text-align:center}.login-links span,.register-links span{color:#008cba;cursor:pointer;text-decoration:underline}.user-info{align-items:center;background-color:#f5f5f5;border-radius:4px;display:flex;justify-content:space-between;margin-bottom:1rem;padding:.5rem 1rem;width:100%}.logout-button{background-color:#f44336;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;padding:.5rem 1rem}.logout-button:hover{background-color:#d32f2f}.acceso-denegado{margin:3rem auto;max-width:600px;text-align:center}.acceso-denegado h1{color:#d32f2f;margin-bottom:1rem}.loading{align-items:center;color:#008cba;display:flex;font-size:1.5rem;height:100vh;justify-content:center}.inicio-container{padding:1rem;text-align:center}.inicio-container h1{color:#004d7a;margin-bottom:.5rem}.user-role-info{background-color:#f0f8ff;border-left:4px solid #008cba;border-radius:4px;box-shadow:0 2px 5px #0000000d;margin:1.5rem auto;max-width:600px;padding:1rem;text-align:left}.user-role-info h3{color:#004d7a;margin:0 0 .5rem}.user-role-info p{color:#555;margin:0}.menu-opciones-inicio{margin:2rem 0}.menu-opciones-inicio h2{color:#004d7a;display:inline-block;margin-bottom:1.5rem;position:relative}.menu-opciones-inicio h2:after{background-color:#008cba;bottom:-10px;content:"";height:3px;left:25%;position:absolute;width:50%}.opciones-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin:2rem auto;max-width:1000px}.opcion-card{align-items:center;background-color:#fff;border-radius:8px;box-shadow:0 4px 10px #00000014;color:#333;display:flex;flex-direction:column;justify-content:center;padding:1.5rem 1rem;text-align:center;text-decoration:none;transition:all .3s ease}.opcion-card:hover{background-color:#f7fdff;box-shadow:0 8px 15px #0000001a;transform:translateY(-5px)}.opcion-card.admin{background-color:#f0f8ff;border-left:3px solid #004d7a}.opcion-card.admin:hover{background-color:#e0f2fe}.opcion-icon{font-size:2.5rem;margin-bottom:1rem}.opcion-title{color:#004d7a;font-size:1.1rem;font-weight:500}@media (max-width:768px){.menu-container{align-items:center;flex-direction:column}.user-info{flex-direction:column;gap:.5rem}.opciones-grid{grid-template-columns:1fr;max-width:400px}}.registro-paciente-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000000d;margin:0 auto;max-width:1000px;padding:1.5rem}.mensaje{border-radius:4px;font-weight:500;margin-bottom:1rem;padding:.75rem;text-align:center}.success{background-color:#e8f5e9;border-left:4px solid #2e7d32;color:#2e7d32}.error{background-color:#ffebee;border-left:4px solid #d32f2f;color:#d32f2f}.search-section h2{color:#004d7a;font-size:1.3rem;margin-bottom:1rem;margin-top:0}.form-section h2{font-size:1.3rem}.form-group{flex:1 1}.form-group input,.form-group select{border:1px solid #ccc;border-radius:4px;font-size:.95rem;padding:.75rem;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#008cba;box-shadow:0 0 0 3px #008cba1a;outline:none}.full-width{width:100%}.form-actions{justify-content:center;margin-top:1.5rem}.form-actions button{min-width:180px}.delete-section{background-color:#fff9f9;border:1px solid #ffe8e8;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.delete-section h2{color:#b71c1c;font-size:1.3rem;margin-bottom:1rem;margin-top:0}.delete-button{background-color:#f44336!important}.delete-button:hover{background-color:#d32f2f!important}hr{background-color:#eaeaea;border:0;height:1px;margin:2rem 0}@media (max-width:768px){.form-row{gap:.5rem}.form-row,.search-container{flex-direction:column}.search-input{width:100%}}.lista-medicos-container{margin:0 auto;max-width:1200px;padding:20px}.lista-medicos-container h1{color:#004d7a;font-size:2rem;margin-bottom:30px;text-align:center}.cargando{color:#666;font-size:1.2rem;padding:40px;text-align:center}.error-message{margin:20px 0;padding:15px;text-align:center}.no-medicos{background-color:#f5f5f5;border-radius:8px;color:#666;padding:30px;text-align:center}.medicos-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.medico-tarjeta{background-color:#fff;border-radius:8px;box-shadow:0 3px 8px #0000001a;display:flex;flex-direction:column;padding:20px;transition:transform .3s ease,box-shadow .3s ease}.medico-tarjeta:hover{box-shadow:0 5px 15px #00000026;transform:translateY(-5px)}.medico-tarjeta h3{border-bottom:2px solid #e0e0e0;color:#004d7a;font-size:1.5rem;margin-bottom:10px;margin-top:0;padding-bottom:8px}.medico-foto{margin-bottom:15px}.especialidades{color:#555;font-weight:500;margin-bottom:10px}.contacto,.direccion{color:#666;font-size:.9rem;margin:5px 0}.horarios{background-color:#f9f9f9;border-radius:6px;margin-top:15px;padding:12px}.horarios h4{color:#004d7a;font-size:1rem;margin-bottom:8px;margin-top:0}.horarios ul{list-style-type:none;margin:0;padding-left:0}.horarios li{border-bottom:1px solid #e0e0e0;font-size:.9rem;padding:5px 0}.horarios li:last-child{border-bottom:none}.biografia-preview{color:#666;flex-grow:1;font-size:.9rem;font-style:italic;line-height:1.4;margin-top:15px}.contactar-btn{align-self:flex-start;background-color:#008cba;border-radius:4px;color:#fff;display:inline-block;margin-top:15px;padding:8px 15px;text-align:center;text-decoration:none;transition:background-color .3s}.contactar-btn:hover{background-color:#005f75}@media (max-width:768px){.medicos-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.lista-medicos-container{padding:15px}}@media (max-width:480px){.medicos-grid{grid-template-columns:1fr}.medico-tarjeta{padding:15px}}.reservar-cita-contenedor{margin:0 auto;max-width:900px;padding:20px}.reservar-cita-contenedor h1{color:#004d7a;margin-bottom:30px;text-align:center}.toggle-busqueda{background-color:#f0f0f0;border-radius:30px;display:flex;justify-content:center;margin-bottom:30px;margin-left:auto;margin-right:auto;max-width:600px;padding:5px;width:100%}.toggle-btn{background-color:initial;border:none;border-radius:25px;cursor:pointer;flex:1 1;font-size:16px;padding:10px 20px;transition:all .3s ease}.toggle-btn.active{background-color:#008cba;box-shadow:0 2px 5px #0000001a;color:#fff}.reserva-form{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:25px}.form-section{margin-bottom:25px}.form-group{margin-bottom:20px}.form-group label{color:#333;margin-bottom:8px}.form-select{background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:16px;padding:12px;width:100%}.form-select:focus{border-color:#008cba;outline:none}.form-input{background-color:#f9f9f9;border:1px solid #ddd;border-radius:4px;font-size:16px;padding:12px;width:100%}.form-input.address{background-color:#f0f4f7;color:#555;font-style:italic}.form-actions{margin-top:30px}.btn-primary{padding:12px 30px}.btn-primary:hover{background-color:#006d8a}.btn-secondary{background-color:#f2f2f2;border:1px solid #ddd;color:#333;font-size:16px;margin-right:10px;padding:12px 30px}.btn-secondary:hover{background-color:#e0e0e0}.cargando,.error-mensaje,.mensaje-reserva,.sin-medicos{border-radius:8px;margin:20px 0;padding:30px;text-align:center}.cargando{background-color:#f0f8ff;color:#06c}.error-mensaje{background-color:#fff0f0;color:#c00}.mensaje-reserva{background-color:#f0fff0;border-left:4px solid green;color:green;font-weight:500}.sin-medicos{background-color:#f9f9f9;color:#555;font-style:italic}.medicos-disponibles{margin-top:25px}.medicos-disponibles h3{color:#004d7a;margin-bottom:15px}.medicos-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-top:15px}.medico-card{border:1px solid #e0e0e0;cursor:pointer;position:relative;transition:all .3s ease}.medico-card:hover{box-shadow:0 5px 15px #0000001a;transform:translateY(-2px)}.medico-card.seleccionado{border-color:#008cba;box-shadow:0 0 0 2px #008cba4d}.medico-card h4{color:#004d7a;font-size:18px;margin-bottom:10px;margin-top:0}.medico-card p{color:#555;font-size:14px}.select-medico{align-items:center;border-top:1px solid #f0f0f0;display:flex;margin-top:15px;padding-top:10px}.select-medico input{margin-right:8px}.select-medico span{color:#004d7a;font-weight:500}@media (max-width:768px){.medicos-cards{grid-template-columns:1fr}.toggle-busqueda{flex-direction:column;gap:10px}.toggle-btn,.toggle-busqueda{border-radius:8px}}.presupuesto-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000000d;margin:0 auto;max-width:800px;padding:2rem}.presupuesto-container h1{color:#004d7a;font-size:1.8rem;margin-bottom:1.5rem;text-align:center}.form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}.form-group.full-width{grid-column:span 2}.form-group input[type=email],.form-group input[type=tel],.form-group input[type=text],.form-group select,.form-group textarea{background-color:#fff;border:1px solid #ccc;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.form-group textarea{min-height:120px}.procedimiento-select{background-color:#f8fbff;border:1px solid #c0d6e8;color:#004d7a;font-weight:500}.procedimiento-select:focus{background-color:#fff;border-color:#008cba}.procedimiento-select optgroup{background-color:#f0f7fa;color:#004d7a;font-weight:700;padding:.5rem}.procedimiento-select option{background-color:#fff;color:#333;padding:.5rem}.mensaje-exito{background-color:#e8f5e9;border-left:4px solid #2e7d32;color:#2e7d32}.mensaje-error,.mensaje-exito{animation:fadeIn .5s ease-in;border-radius:4px;font-weight:500;margin-bottom:2rem;padding:1rem;text-align:center}.mensaje-error{background-color:#ffebee;border-left:4px solid #d32f2f;color:#d32f2f}.info-card{background-color:#f0f7fa;border-left:4px solid #008cba;border-radius:4px;margin-bottom:2rem;padding:1rem}.info-card h3{color:#004d7a;font-size:1.2rem;margin-top:0}.info-card p{color:#555;margin-bottom:.5rem}.info-card ul{margin:.5rem 0;padding-left:1.5rem}.info-card li{margin-bottom:.25rem}.btn-primary{display:block;font-size:1rem;font-weight:500;margin:1.5rem auto 0;min-width:180px;padding:.75rem 2rem}.btn-primary:disabled{background-color:#ccc;cursor:not-allowed}.servicio-input{background-color:#f8fbff;border:1px solid #c0d6e8;color:#004d7a;font-weight:500;letter-spacing:.5px}.servicio-input:focus{background-color:#fff;border-color:#008cba}@media (max-width:768px){.presupuesto-container{padding:1.5rem}.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}}.sugerencias-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000000d;margin:0 auto;max-width:800px;padding:2rem}.page-title{margin-bottom:1rem}.page-description{color:#555;font-size:1.1rem;margin-bottom:2rem;text-align:center}.form-container{background-color:#f8f9fa;border:1px solid #e6e6e6;border-radius:8px;padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#444}.form-control{border:1px solid #ccc;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.form-control:focus{border-color:#008cba;box-shadow:0 0 0 3px #008cba1a;outline:none}.select-tipo{background-color:#fff;color:#333}.textarea-mensaje{min-height:150px;resize:vertical}.button-container{margin-top:1.5rem;text-align:center}.btn-enviar{background-color:#008cba;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;min-width:180px;padding:.75rem 2rem;transition:background-color .3s}.btn-enviar:hover{background-color:#005f75}.success-message{animation:fadeIn .5s ease-in;font-weight:500;margin-top:1.5rem;padding:1rem;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.tipo-badge{border-radius:20px;display:inline-block;font-size:.9rem;font-weight:500;margin-bottom:1rem;padding:.35rem .75rem}.tipo-reclamo{background-color:#ffebee;border:1px solid #ffcdd2;color:#d32f2f}.tipo-sugerencia{background-color:#e8f5e9;border:1px solid #c8e6c9;color:#2e7d32}.tipo-felicitacion{background-color:#e3f2fd;border:1px solid #bbdefb;color:#1565c0}.tipo-otro{background-color:#fff8e1;border:1px solid #ffecb3;color:#f57f17}@media (max-width:768px){.form-container,.sugerencias-container{padding:1.5rem}}.historia-medica-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000000d;margin:0 auto;max-width:1000px;padding:1.5rem}.page-title{color:#004d7a;font-size:1.8rem;margin-bottom:1.5rem;text-align:center}.search-section{background-color:#f7fbff;border:1px solid #e1e7f0;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.search-container{align-items:center;display:flex;gap:.5rem}.search-input{border:1px solid #ccc;border-radius:4px;flex:1 1;font-size:1rem;padding:.75rem;transition:border-color .3s ease}.search-input:focus{border-color:#008cba;box-shadow:0 0 0 3px #008cba1a;outline:none}.paciente-info{background-color:#f8f9fa;border-left:4px solid #008cba;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.paciente-info h3{color:#004d7a;margin-bottom:1rem;margin-top:0}.info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.info-item{margin-bottom:.5rem}.info-item strong{color:#555;font-weight:600}.export-buttons{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}.export-button{flex:1 1;min-width:200px}.historial-section{background-color:#fff;border:1px solid #eaeaea;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.historial-section h2{color:#004d7a;margin-bottom:1.5rem;margin-top:0}.consulta-selector{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.consulta-selector select{border:1px solid #ccc;border-radius:4px;min-width:200px;padding:.5rem}.consulta-card{background-color:#fff;border:1px solid #e1e7f0;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:1.5rem;padding:1.5rem}.consulta-card p{line-height:1.5;margin:.5rem 0}.consulta-card strong{color:#004d7a;display:inline-block;font-weight:600;min-width:200px}.form-section{background-color:#fff;border:1px solid #eaeaea;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.form-section h2{color:#004d7a;font-size:1.5rem;margin-bottom:1.5rem;margin-top:0}.form-section h3{border-bottom:1px solid #eaeaea;color:#008cba;font-size:1.2rem;margin-bottom:1rem;margin-top:1.5rem;padding-bottom:.5rem}.form-group{margin-bottom:1.25rem}.form-group label{color:#555}.form-group input,.form-group select,.form-group textarea{border:1px solid #ccc;border-radius:4px;font-size:.95rem;padding:.75rem;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#008cba;box-shadow:0 0 0 3px #008cba1a;outline:none}.form-row{margin-bottom:1rem}.form-col{flex:1 1;min-width:0}.documento-input{background-color:#f8fbff;border:1px solid #c0d6e8!important;color:#004d7a;font-weight:500;letter-spacing:.5px}.documento-input:focus{background-color:#fff;border-color:#008cba!important}.medicamento-fieldset{background-color:#f9f9f9;border:1px solid #ddd;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.medicamento-fieldset legend{color:#004d7a;font-size:1.1rem;font-weight:600;padding:0 .5rem}.medicamento-form{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.medicamento-button{background-color:#008cba;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:1rem;padding:.75rem 1.5rem;transition:background-color .3s}.medicamento-button:hover{background-color:#005f75}.form-actions{margin-top:2rem;text-align:center}.submit-button{background-color:#008cba;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 2rem;transition:background-color .3s}.submit-button:hover{background-color:#005f75}.error-message{margin-bottom:1.5rem;padding:.75rem}.lentes-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.lente-section{background-color:#f8fbff;border:1px solid #e1e7f0;border-radius:8px;padding:1.25rem}.lente-section h3{color:#004d7a;font-size:1.1rem;margin-bottom:1rem;margin-top:0;text-align:center}.lente-fields{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.config-lente{background-color:#f0f7fa;border:1px solid #d6e9f0;border-radius:8px;margin-top:1.5rem;padding:1.25rem}@media (max-width:768px){.export-buttons,.form-row,.search-container{flex-direction:column}.lentes-grid,.medicamento-form{grid-template-columns:1fr}}.admin-medicos-container{margin:0 auto;max-width:1000px;padding:20px}.admin-medicos-container h1{color:#004d7a;margin-bottom:20px;text-align:center}.admin-medicos-container h2{border-bottom:1px solid #ddd;color:#004d7a;margin:30px 0 20px;padding-bottom:10px}.success-message{background-color:#e8f5e9;border-left:4px solid #2e7d32;color:#2e7d32}.error-message,.success-message{border-radius:4px;margin-bottom:20px;padding:12px 15px}.error-message{background-color:#ffebee;border-left:4px solid #d32f2f;color:#d32f2f}.medico-form{background-color:#f9f9f9;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px;padding:20px}.especialidad-selector{margin-bottom:15px}.especialidad-dropdown{background-color:#fff;border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:16px;padding:10px;width:100%}.especialidad-dropdown:focus{border-color:#008cba;outline:none}.especialidad-personalizada{border-top:1px solid #e0e0e0;margin-top:15px;padding-top:15px}.especialidad-personalizada .form-row{display:flex;gap:10px}.input-especialidad{border:1px solid #ccc;border-radius:4px;flex:1 1;font-size:14px;padding:8px 12px}.btn-add{margin-left:0;padding:8px 15px;white-space:nowrap}.especialidades-seleccionadas{background-color:#f0f4f7;border-radius:6px;margin-top:15px;padding:10px 15px}.especialidades-seleccionadas p{color:#004d7a;margin-bottom:10px;margin-top:0}.especialidades-seleccionadas ul{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:0;padding:0}.especialidades-seleccionadas li{align-items:center;background-color:#fff;border:1px solid #e0e0e0;border-radius:20px;box-shadow:0 1px 2px #0000000d;display:flex;justify-content:space-between;padding:5px 10px}.btn-remove{background-color:initial;border:none;color:#d32f2f;cursor:pointer;font-size:18px;font-weight:700;line-height:1;margin-left:8px;padding:0 5px}.btn-remove:hover{color:#b71c1c}.especialidades-vacio{background-color:#fff;border:1px dashed #ccc;border-radius:4px;color:#777;font-style:italic;padding:10px;text-align:center}.form-group{margin-bottom:15px}.form-group label{display:block;font-weight:500;margin-bottom:5px}.form-group input[type=text],.form-group input[type=time],.form-group select{border:1px solid #ccc;border-radius:4px;font-size:16px;padding:10px;width:100%}.form-group select[multiple]{height:120px}.form-group small{color:#666;display:block;font-size:.8rem;margin-top:5px}.form-row{display:flex;gap:15px}.form-row .form-group{flex:1 1}.asignaciones-section{background-color:#f0f4f7;border-radius:6px;margin-bottom:20px;padding:15px}.asignaciones-section h3{color:#004d7a;font-size:1.1rem;margin-bottom:15px;margin-top:0}.asignacion-form{background-color:#fff;border-radius:6px;margin-bottom:15px;padding:15px}.asignaciones-list{margin-top:20px}.asignaciones-list h4{color:#004d7a;margin-bottom:10px}.asignaciones-list ul{list-style:none;padding:0}.asignaciones-list li{align-items:center;background-color:#fff;border-radius:4px;box-shadow:0 1px 3px #0000001a;display:flex;justify-content:space-between;margin-bottom:8px;padding:8px 10px}.btn-primary{background-color:#008cba;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;padding:10px 20px;transition:background-color .3s}.btn-primary:hover{background-color:#005f75}.btn-secondary{background-color:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;margin-left:10px;padding:8px 15px;transition:background-color .3s}.btn-secondary:hover{background-color:#545b62}.btn-danger{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:6px 12px;transition:background-color .3s}.btn-danger:hover{background-color:#c82333}.medicos-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.medico-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:15px;transition:transform .2s}.medico-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-3px)}.medico-card h3{color:#004d7a;font-size:1.1rem;margin-bottom:10px;margin-top:0}.medico-card p{margin:8px 0}.medico-card ul{margin:8px 0;padding-left:20px}.biografia-text{color:#555;font-size:.9rem;font-style:italic;line-height:1.4;padding:5px 0;text-align:justify}.medico-foto{margin:15px 0;text-align:center}.medico-foto img{border-radius:8px;box-shadow:0 2px 4px #0000001a;height:auto;max-height:200px;max-width:100%}.card-actions{display:flex;justify-content:flex-end;margin-top:15px}.loading{color:#004d7a;font-size:1.2rem;padding:30px;text-align:center}.inicio-publico-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh}.hero-section{background:linear-gradient(135deg,#004d7a,#008cba);color:#fff;overflow:hidden;padding:4rem 2rem;position:relative;text-align:center}.hero-section:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Ccircle cx='50' cy='50' r='2' fill='rgba(255,255,255,0.1)'/%3E%3C/svg%3E") repeat;bottom:0;content:"";left:0;opacity:.1;position:absolute;right:0;top:0}.hero-content{margin:0 auto;max-width:800px;position:relative;z-index:1}.hero-title{animation:fadeInUp .8s ease-out;font-size:3.5rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px #0000004d}.hero-subtitle{animation:fadeInUp .8s ease-out .2s both;color:#e3f2fd;font-size:1.8rem;font-weight:300;margin-bottom:1.5rem}.hero-description{animation:fadeInUp .8s ease-out .4s both;font-size:1.1rem;line-height:1.6;margin:0 auto;max-width:600px;opacity:.9}.main-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:1fr 400px;margin:0 auto;max-width:1400px;padding:3rem 2rem}.carousel-section{animation:slideInLeft .8s ease-out;background:#fff;border-radius:16px;box-shadow:0 10px 30px #0000001a;overflow:hidden}.carousel-container{height:500px;position:relative}.carousel-wrapper{height:100%;position:relative;width:100%}.carousel-slide{height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .6s ease-in-out;width:100%}.carousel-slide.active{opacity:1}.carousel-slide img{height:100%;object-fit:cover;width:100%}.carousel-caption{background:linear-gradient(#0000,#000c);bottom:0;color:#fff;left:0;padding:2rem 1.5rem 1.5rem;position:absolute;right:0;text-align:center}.carousel-caption p{font-size:1.1rem;font-weight:500;margin:0}.carousel-btn{background:#ffffffe6;border:none;border-radius:50%;box-shadow:0 4px 15px #0003;color:#004d7a;cursor:pointer;font-size:1.2rem;height:50px;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;width:50px;z-index:2}.carousel-btn:hover{background:#fff;transform:translateY(-50%) scale(1.1)}.prev-btn{left:20px}.next-btn{right:20px}.carousel-dots{bottom:20px;display:flex;gap:10px;left:50%;position:absolute;transform:translateX(-50%);z-index:2}.dot{background:#ffffff80;border-radius:50%;cursor:pointer;height:12px;transition:all .3s ease;width:12px}.dot.active{background:#fff;transform:scale(1.2)}.contact-section{animation:slideInRight .8s ease-out}.contact-form-container{background:#fff;border-radius:16px;box-shadow:0 10px 30px #0000001a;padding:2.5rem;position:sticky;top:2rem}.contact-form-container h3{color:#004d7a;font-size:2rem;font-weight:700;margin-bottom:.5rem;text-align:center}.form-subtitle{color:#666;font-size:.95rem;margin-bottom:2rem;text-align:center}.message{border-radius:8px;font-weight:500;margin-bottom:1.5rem;padding:1rem;text-align:center}.message.success{background-color:#e8f5e8;border:1px solid #c8e6c9;color:#2e7d32}.message.error{background-color:#ffebee;border:1px solid #ffcdd2;color:#d32f2f}.contact-form{display:flex;flex-direction:column}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column}.form-group.half{flex:1 1}.form-group label{color:#004d7a;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group textarea{background-color:#fafbfc;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;padding:1rem;transition:all .3s ease}.form-group input:focus,.form-group textarea:focus{background-color:#fff;border-color:#008cba;box-shadow:0 0 0 3px #008cba1a;outline:none}.form-group textarea{font-family:inherit;min-height:100px;resize:vertical}.form-actions{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.submit-btn{background:linear-gradient(135deg,#008cba,#004d7a);border:none;border-radius:8px;box-shadow:0 4px 15px #008cba4d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1.2rem 2rem;transition:all .3s ease}.submit-btn:hover:not(:disabled){box-shadow:0 6px 20px #008cba66;transform:translateY(-2px)}.submit-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.divider{margin:.5rem 0;position:relative;text-align:center}.divider:before{background-color:#e1e5e9;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.divider span{background:#fff;color:#666;font-weight:500;padding:0 1rem}.whatsapp-btn{align-items:center;background:#25d366;border:none;border-radius:8px;box-shadow:0 4px 15px #25d3664d;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;justify-content:center;padding:1.2rem 2rem;transition:all .3s ease;img{height:2em}}.whatsapp-btn:hover{background:#128c7e;box-shadow:0 6px 20px #25d36666;transform:translateY(-2px)}.whatsapp-icon{font-size:1.2rem}.services-preview{background:#fff;margin-top:2rem;padding:4rem 2rem}.services-container{margin:0 auto;max-width:1200px;text-align:center}.services-container h3{color:#004d7a;font-size:2.5rem;font-weight:700;margin-bottom:3rem}.services-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.service-card{background:#fafbfc;border:1px solid #e1e5e9;border-radius:16px;padding:2rem;text-align:center;transition:all .3s ease}.service-card:hover{background:#fff;box-shadow:0 10px 30px #0000001a;transform:translateY(-5px)}.service-icon{font-size:3rem;margin-bottom:1rem}.service-card h4{color:#004d7a;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.service-card p{color:#666;line-height:1.6}.contact-info{background:#004d7a;color:#fff;padding:3rem 2rem}.contact-info-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:0 auto;max-width:1200px}.info-item{text-align:center}.info-item h4{color:#e3f2fd;font-size:1.2rem;margin-bottom:1rem}.info-item p{line-height:1.6;opacity:.9}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-50px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(50px)}to{opacity:1;transform:translateX(0)}}@media (max-width:1024px){.main-content{gap:2rem;grid-template-columns:1fr}.contact-form-container{position:static}}@media (max-width:768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.4rem}.main-content{padding:2rem 1rem}.carousel-container{height:400px}.contact-form-container{padding:2rem}.form-row,.services-grid{grid-template-columns:1fr}.contact-info-container{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:480px){.hero-section{padding:2rem 1rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.2rem}.carousel-btn{font-size:1rem;height:40px;width:40px}.prev-btn{left:10px}.next-btn{right:10px}.contact-form-container{padding:1.5rem}.services-container h3{font-size:2rem}}@media print{.carousel-btn,.submit-btn,.whatsapp-btn{display:none}}
/*# sourceMappingURL=main.cf9401a8.css.map*/