: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}.modal-selector-turno{background:#e8e3d9}.modal-selector-header{background:#81b0d2;border-bottom:2px solid black;text-align:center;font-family:DM Mono,monospace;font-weight:600;padding:1rem}.modal-selector-body{padding:2rem 2.5rem;overflow-y:auto;background:#e8e3d9}.modal-selector-body.modal-info-open{overflow:hidden;pointer-events:none}.modal-selector-body.modal-info-open *{pointer-events:none}.modal-selector-footer{background:#e8e3d9;border-top:2px solid black;display:flex;justify-content:center;padding:1rem}.header-section{padding:20px 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:280px;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:16px 20px;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}.btn-view-more{width:100%;background:transparent;color:var(--brown);border:1px solid var(--brown);padding:9px 18px;border-radius:8px;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.btn-view-more:hover{background:var(--beige);border-color:var(--dark-brown);color:var(--dark-brown)}.doctor-info-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:20000;padding:20px;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:fadeIn .3s ease;pointer-events:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.doctor-info-modal-container{position:relative;background:var(--beige);border-radius:16px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease;overflow:hidden;border:2px solid var(--dark-brown);pointer-events:auto;height:90vh}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.doctor-info-modal-header{background:var(--brown);color:#fff;border-bottom:2px solid var(--dark-brown);padding:1.5rem;display:flex;justify-content:space-between;align-items:flex-start}.doctor-info-modal-title{font-size:1.75rem;font-weight:700;margin:0 0 8px;font-family:serif}.doctor-info-modal-specialty{font-size:.95rem;font-weight:400;opacity:.9;margin:0}.doctor-info-modal-close{background:#fff3;border:none;border-radius:4px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#fff;font-size:1.2rem}.doctor-info-modal-close:hover{background:#ffffff4d}.doctor-info-modal-body{padding:2rem;overflow-y:auto;overflow-x:hidden;flex:1;color:var(--dark-brown);overscroll-behavior:contain;pointer-events:auto;max-height:calc(90vh - 200px);scrollbar-width:thin;scrollbar-color:var(--brown) rgba(0,0,0,.1);will-change:transform;backface-visibility:hidden;-webkit-backface-visibility:hidden;transform:translateZ(0);-webkit-transform:translateZ(0);-webkit-overflow-scrolling:touch;-webkit-transform:translate3d(0,0,0)}.doctor-info-modal-body::-webkit-scrollbar{width:6px}.doctor-info-modal-body::-webkit-scrollbar-track{background:#0000000d;border-radius:3px}.doctor-info-modal-body::-webkit-scrollbar-thumb{background-color:var(--brown);border-radius:3px}.doctor-info-modal-body *{pointer-events:auto}.doctor-info-bio{margin-bottom:24px}.bio-paragraph{font-size:.875rem;line-height:1.7;color:#444;margin:0 0 16px;font-weight:400}.bio-paragraph:last-child{margin-bottom:0}.bio-paragraph strong{font-weight:600;color:var(--dark-brown)}.doctor-quote{margin:24px 0;padding:20px;background:#e8e3d9;border-left:4px solid var(--brown);border-radius:4px;font-style:italic;color:#555;font-size:.9rem;line-height:1.6}.doctor-credentials{margin-top:24px;padding-top:20px;border-top:1px solid rgba(165,107,62,.2)}.doctor-credentials-title{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--dark-brown)}.credential-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border:1px solid #ddd;margin-bottom:8px}.credential-title{font-style:italic;font-weight:500;color:#666;font-size:.85rem}.credential-number{font-weight:600;color:var(--dark-brown);font-size:.9rem}.doctor-info-modal-footer{background:#e8e3d9;border-top:2px solid var(--dark-brown);padding:1.5rem 2rem;display:flex;justify-content:center;gap:1rem;flex-shrink:0}.calendar-view{padding:0}.booking-panel{display:grid;grid-template-columns:380px 1fr;gap:0;min-height:600px;overflow:hidden}.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:20px;background:#fff;border-bottom:1px solid #ddd}.service-doctor-photo{width:100px;height:100px;border-radius:50%;object-fit:cover;margin-bottom:12px;border:3px 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-doctor-specialty{font-size:.85rem;color:#666;margin:0;text-align:center}.service-header{text-align:center;padding:24px 16px 12px}.service-title{font-family:serif;font-size:1.7rem;margin:0;color:var(--dark-brown);line-height:1.3}.price-band{background:var(--brown);color:#fff;text-align:center;padding:16px;font-size:2rem;font-weight:700}.price-band span{font-size:1rem;margin-left:6px}.service-body{padding:28px;display:flex;flex-direction:column;flex:1}.service-description{text-align:center;margin-bottom:28px;color:#555;font-size:.95rem;line-height:1.6}.service-features-title{font-weight:600;margin-bottom:18px;font-size:1.05rem}.service-features{list-style:none;padding:0;margin:0 0 28px}.service-features li{display:flex;gap:12px;margin-bottom:16px;font-size:.95rem;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:12px 16px;border-radius:4px;cursor:pointer;font-weight:500;font-size:.95rem;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:16px;display:flex;flex-direction:column;min-height:100%}.calendar-header-logo{text-align:center;margin-bottom:32px;padding-top:16px}.logo-circle{display:inline-flex;align-items:center;justify-content:center;width:70px;height:70px;border-radius:50%;background:#fff;margin-bottom:16px}.logo-img{width:60%;height:60%;object-fit:contain}.calendar-title{color:#fff;font-size:1.4rem;font-weight:400;margin:0;letter-spacing:.3px}.calendar-header-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.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:.75rem;opacity:.7;margin-bottom:10px;color:#fff;gap:4px;justify-items:center}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;min-height:300px;align-content:start;justify-items:center}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.875rem;cursor:pointer;transition:all .2s ease;background:transparent;border:1px solid rgba(255,255,255,.2);color:#fff;opacity:.3;width:42px;height:42px}.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:24px;display:flex;flex-direction:column;overflow-y:auto;min-height:100%}.booking-info-header{margin-bottom:20px}.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:.9rem;margin-bottom:15px;display:flex;align-items:center;gap:8px}.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:10px;margin-bottom:20px}.btn-slot{border:1px solid #ddd;padding:12px 16px;background:#fff;border-radius:4px;cursor:pointer;transition:all .2s ease;font-size:.95rem;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-back-to-doctors{display:flex;align-items:center;gap:.5rem;background:transparent;border:none;color:var(--brown);font-weight:500;cursor:pointer;padding:.5rem 1rem;border-radius:4px;transition:all .2s ease;font-size:.9rem}.btn-back-to-doctors:hover{background:#a56b3e1a}.selected-doctor-name{font-weight:600;color:var(--dark-brown);font-size:.95rem}.empty-slots-state{text-align:center;padding:3rem 1rem;background:#f5f5f5;border-radius:8px}.empty-slots-state-text{color:#666;margin-bottom:.5rem}.empty-slots-state-hint{font-size:.85rem;color:#999}.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){.doctors-grid{grid-template-columns:1fr;gap:16px}.doctor-photo-container{height:220px}.doctor-name{font-size:1.25rem}.doctor-discipline{font-size:.85rem}.doctor-info-modal-container{max-width:95%;max-height:95vh;margin:10px}.doctor-info-modal-header{padding:1.25rem}.doctor-info-modal-title{font-size:1.4rem}.doctor-info-modal-specialty{font-size:.85rem}.doctor-info-modal-body{padding:1.5rem}.bio-paragraph{font-size:.9rem}.card-action{padding:16px}.calendar-day{font-size:.75rem;width:36px;height:36px}.booking-panel{grid-template-columns:1fr}.service-card{border-right:none;border-bottom:1px solid #000}}@media (min-width: 769px) and (max-width: 1024px){.doctors-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1025px){.doctors-grid{grid-template-columns:repeat(3,1fr)}}
