:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#e8e3d9;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}body{margin:0;padding:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}button{background-color:#f9f9f9}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#f8f9fa;color:#333;line-height:1.6}.app{min-height:100vh;width:100%}.form-container{max-width:800px;margin:0 auto;padding:2rem;min-height:100vh;background:#f8f9fa}.form-content{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.form-content h2{font-size:1.8rem;margin-bottom:1.5rem;color:#333;font-weight:600;text-align:center}.form-actions{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem}.btn-primary,.btn-secondary{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:120px}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5a6fd8;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.btn-secondary{background:#f8f9fa;color:#666;border:2px solid #e0e0e0}.btn-secondary:hover{background:#e9ecef;border-color:#ccc}@media (max-width: 768px){.form-container{padding:1rem}.form-content{padding:1.5rem}.form-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.minimal-stepper{display:flex;align-items:center;justify-content:center;gap:0;padding:1rem 0}.step-wrapper{display:flex;align-items:center}.connector{width:80px;height:2px;background:#bfbfbf}.dot{width:32px;height:32px;border-radius:50%;background-color:#fff;border:2px solid #BFBFBF;display:flex;align-items:center;justify-content:center;position:relative}.dot.active{border-color:#8b0000}.inner-dot{width:8px;height:8px;background-color:#8b0000;border-radius:50%}:root{--brown: #a56b3e;--dark-brown: #2b2118;--beige: #f4efe9}.agendar-consulta-content{background:#e8e3d9;padding:.75rem 1rem;overflow-y:auto;flex:1}.agendar-consulta-footer{display:flex;justify-content:center;padding:.5rem 0;background:#e8e3d9}.header-section{padding:12px 0;text-align:center}.subtitle{font-size:1.1rem;color:#666;margin-bottom:1.5rem}.doctors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;margin-bottom:32px}.doctor-card{background:#fff;border-radius:12px;overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column;box-shadow:0 2px 8px #0000001a}.doctor-card:hover{transform:translateY(-8px);box-shadow:0 12px 32px #0003}.doctor-photo-container{position:relative;width:100%;height:240px;overflow:hidden;cursor:pointer}.doctor-photo-container.show-services .doctor-photo{filter:brightness(.4)}.service-selection-overlay{position:absolute;inset:0;background:#000000d9;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:20px;z-index:2}.service-selection-title{font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:16px;text-align:center}.service-buttons{display:flex;flex-direction:column;gap:10px;width:100%;margin-bottom:12px}.btn-service-option{width:100%;background:var(--brown);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .3s ease;text-align:center}.btn-service-option:hover{background:var(--dark-brown);transform:translateY(-2px);box-shadow:0 4px 12px #a56b3e4d}.btn-cancel-service{width:100%;background:transparent;color:#fff;border:1px solid white;padding:8px 16px;border-radius:8px;font-weight:500;font-size:.85rem;cursor:pointer;transition:all .3s ease}.btn-cancel-service:hover{background:#ffffff1a}.doctor-photo{width:100%;height:100%;object-fit:cover;display:block;object-position:top}.photo-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.6) 70%,transparent 100%);padding:20px 16px 16px;color:#fff}.doctor-name{font-size:1.35rem;font-weight:700;color:#fff;margin:0 0 6px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.doctor-discipline{font-size:.9rem;font-weight:500;color:#fffffff2;margin:0;letter-spacing:.5px;text-shadow:0 1px 3px rgba(0,0,0,.3)}.card-action{padding:12px 16px;background:#fff;display:flex;flex-direction:column;gap:10px}.btn-select{width:100%;background:var(--brown);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;text-transform:uppercase;letter-spacing:.5px}.btn-select:hover{background:var(--dark-brown);transform:translateY(-2px);box-shadow:0 4px 12px #a56b3e4d}.booking-panel{display:grid;grid-template-columns:320px 1fr 360px;gap:0;min-height:auto;overflow:hidden;max-width:fit-content;margin-left:auto;margin-right:auto}.service-card{background:var(--beige);overflow:hidden;border-right:1px solid #000000;display:flex;flex-direction:column}.service-doctor-info{display:flex;flex-direction:column;align-items:center;padding:6px 10px;background:#fff;border-bottom:1px solid #ddd}.service-doctor-photo{width:70px;height:70px;border-radius:50%;object-fit:cover;margin-bottom:6px;border:2px solid var(--brown)}.service-doctor-name{font-size:1.2rem;font-weight:700;color:var(--dark-brown);margin:0 0 4px;text-align:center}.service-header{text-align:center;padding:8px 10px 4px}.service-title{font-family:serif;font-size:1.2rem;margin:0;color:var(--dark-brown);line-height:1.2}.price-band{background:var(--brown);color:#fff;text-align:center;padding:8px;font-size:1.3rem;font-weight:700}.price-band span{font-size:1rem;margin-left:6px}.service-body{padding:10px;display:flex;flex-direction:column;flex:1}.service-description{text-align:center;margin-bottom:8px;color:#555;font-size:.8rem;line-height:1.3}.service-features-title{font-weight:600;margin-bottom:8px;font-size:.9rem}.service-features{list-style:none;padding:0;margin:0 0 8px}.service-features li{display:flex;gap:6px;margin-bottom:4px;font-size:.75rem;align-items:flex-start}.service-features svg{color:var(--brown);margin-top:2px;flex-shrink:0}.btn-change-doctor{width:100%;background:transparent;border:1px solid var(--brown);color:var(--brown);padding:6px 10px;border-radius:4px;cursor:pointer;font-weight:500;font-size:.8rem;transition:all .2s ease;margin-top:auto}.btn-change-doctor:hover{background:var(--brown);color:#fff}.calendar-dark{background:var(--dark-brown);color:#eee;padding:8px;display:flex;flex-direction:column;min-height:100%}.calendar-header-logo{text-align:center;margin-bottom:8px;padding-top:2px}.logo-circle{display:inline-flex;align-items:center;justify-content:center;width:45px;height:45px;border-radius:50%;background:#fff;margin-bottom:6px}.logo-img{width:60%;height:60%;object-fit:contain}.calendar-title{color:#fff;font-size:1rem;font-weight:400;margin:0;letter-spacing:.3px}.calendar-header-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.calendar-month-title{font-size:1.1rem;font-weight:600;color:#fff;margin:0}.nav-btn{background:transparent;border:none;color:#ccc;font-size:1.2rem;cursor:pointer;padding:.5rem;transition:color .2s ease}.nav-btn:hover{color:#fff}.calendar-week{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-size:.65rem;opacity:.7;margin-bottom:4px;color:#fff;gap:3px;justify-items:center}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;min-height:auto;align-content:start;justify-items:center}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.8rem;cursor:pointer;transition:all .2s ease;background:transparent;border:1px solid rgba(255,255,255,.2);color:#fff;opacity:.3;width:36px;height:36px}.calendar-day.inactive{visibility:hidden}.calendar-day.available{opacity:1;cursor:pointer}.calendar-day.unavailable{opacity:.3;cursor:not-allowed;color:#666}.calendar-day.available:hover{background:#ffffff26}.calendar-day.selected{background:#fff;color:var(--dark-brown);font-weight:700;border-color:#fff}.calendar-slots{background:#fff;padding:10px;display:flex;flex-direction:column;overflow-y:auto;min-height:100%}.booking-info-header{margin-bottom:6px}.booking-info-header .fw-bold{color:var(--dark-brown);font-weight:600;font-size:.95rem;margin-bottom:4px}.booking-info-header .text-muted{color:#666;font-size:.85rem}.selected-date-highlight{color:var(--brown);font-weight:600;font-size:.8rem;margin-bottom:8px;display:flex;align-items:center;gap:6px}.date-edit-btn{color:var(--brown);font-size:.85rem;cursor:pointer;text-decoration:underline;font-weight:500;transition:opacity .2s ease;background:none;border:none;padding:0}.date-edit-btn:hover{opacity:.7}.slots-grid{display:grid;grid-template-columns:1fr;gap:6px;margin-bottom:12px}.btn-slot{border:1px solid #ddd;padding:8px 12px;background:#fff;border-radius:4px;cursor:pointer;transition:all .2s ease;font-size:.85rem;text-align:center}.btn-slot:hover{background:#f8f9fa;border-color:#bbb}.btn-slot.active{background:var(--dark-brown);color:#fff;border-color:var(--dark-brown)}.btn-cancel{padding:12px 32px;background:transparent;border:2px solid black;border-radius:0;font-family:DM Mono,monospace;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-cancel:hover{background:#000;color:#fff}.btn-submit{padding:12px 32px;background:#25d366;color:#fff;border:none;border-radius:0;font-family:DM Mono,monospace;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.btn-submit:hover:not(:disabled){background:#128c7e}.btn-submit:disabled{background:#ccc;cursor:not-allowed;opacity:.6}@media (max-width: 768px){.agendar-consulta-content{padding:.75rem}.header-section{padding:8px 0}.subtitle{font-size:1rem;margin-bottom:1rem}.doctors-grid{grid-template-columns:1fr;gap:12px;margin-bottom:20px}.doctor-photo-container{height:180px}.doctor-name{font-size:1.1rem}.doctor-discipline{font-size:.8rem}.card-action{padding:10px 12px}.calendar-day{font-size:.7rem;width:32px;height:32px}.booking-panel{grid-template-columns:1fr}.calendar-slots{display:none}.calendar-slots.is-visible{display:flex}.service-card{border-right:none;border-bottom:1px solid #000}.service-doctor-photo{width:60px;height:60px}.service-header{padding:12px 8px 6px}.service-title{font-size:1.2rem}.price-band{padding:10px;font-size:1.4rem}.service-body{padding:12px}.calendar-dark{padding:10px}.calendar-slots{padding:12px}}@media (min-width: 769px) and (max-width: 1024px){.agendar-consulta-content{padding:1rem 1.25rem}.doctors-grid{grid-template-columns:repeat(2,1fr);gap:20px}.booking-panel{grid-template-columns:280px 1fr 320px}.service-doctor-photo{width:70px;height:70px}.service-title{font-size:1.3rem}.price-band{font-size:1.5rem;padding:14px}.service-body{padding:14px}.calendar-dark{padding:10px}.calendar-slots{padding:16px}}@media (min-width: 1025px){.doctors-grid{grid-template-columns:repeat(3,1fr)}.doctor-photo-container{height:300px}.booking-panel{grid-template-columns:320px 550px 360px;max-width:1230px;margin-left:auto;margin-right:auto}}
