body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:initial;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-color:#007bff;--secondary-color:#6c757d;--font-family:"Arial, sans-serif"}*{font-family:"Arial, sans-serif";font-family:var(--font-family)}.App{align-items:center;background-color:initial;background-color:#282c34b3;display:flex;justify-content:center;min-height:100vh;text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.App-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fffffff2;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:40px}.App-content h1{color:#333;font-size:36px;font-weight:600;margin:0 0 30px}.open-modal-button{border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:all .2s}.open-modal-button,.open-modal-button:hover{background-color:#007bff;background-color:var(--primary-color)}.open-modal-button:hover{box-shadow:0 2px 8px #007bff4d;opacity:.8;transform:translateY(-1px)}.open-modal-button:active{box-shadow:0 1px 4px #007bff4d;transform:translateY(0)}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:10vh 20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;max-height:800px;max-width:700px;min-height:500px;width:90%}@media (max-height:600px){.modal-overlay{padding:5vh 20px}.modal-content{height:90vh;min-height:400px}}@media (min-height:900px){.modal-content{max-height:90vh}}.modal-content.with-progress-card{height:85vh;max-height:900px;max-width:1200px;width:95%}.modal-content-with-sidebar{display:flex;flex:1 1;min-height:0}.modal-main-content{display:flex;flex:2 1;flex-direction:column;min-width:0}.modal-progress-sidebar{background-color:#f8f9fa;border-left:1px solid #e0e0e0;flex:1 1;max-width:400px;min-width:300px}.progress-card{box-sizing:border-box;height:100%;max-height:calc(100vh - 200px);overflow-y:auto;padding:20px}.progress-card .recap-section{background-color:#fff;border:1px solid #e9ecef;border-radius:6px;margin-bottom:16px;padding:12px}.progress-card .recap-item{padding:8px 0}.progress-card .recap-section.editable .edit-icon{color:var(--primary-color);opacity:0;transition:opacity .2s}.progress-card .recap-section.editable:hover .edit-icon{opacity:1}.progress-card .recap-section.editable:hover{background-color:#f0f0f0}@media (max-width:1024px){.modal-content.with-progress-card{max-width:700px;width:90%}.modal-content-with-sidebar{display:block}.modal-progress-sidebar{display:none}.modal-main-content{flex:none}}.variant-v2 .step.completed{color:var(--primary-color)}.variant-v2 .step-line.completed,.variant-v2 .step.completed{background-color:rgba(var(--primary-color-rgb),.25)}.variant-v2 .action-button.secondary{background-color:var(--secondary-button-bg);border:1px solid var(--secondary-button-bg);color:var(--secondary-button-text)}.variant-v2 .action-button.primary{background-color:var(--primary-button-bg);color:var(--primary-button-text)}.variant-v2 .action-button.primary:hover:not(:disabled){background-color:var(--primary-color-dark)}.variant-v2 h1{color:#333;font-size:32px;font-weight:700;line-height:1.2;margin:0 0 24px}.variant-v2 h2{color:#333;font-size:24px;font-weight:600;line-height:1.3;margin:0 0 20px}.variant-v2 h3{color:#333;font-size:20px;font-weight:600;line-height:1.4;margin:0 0 16px}.variant-v2 h4{color:#333;font-size:18px;font-weight:500;line-height:1.4;margin:0 0 12px}.variant-v2 .subtitle{color:#555;font-size:16px;font-weight:500;line-height:1.5;margin:0 0 12px}.variant-v2 .body-text{color:#666;font-size:16px;font-weight:400;line-height:1.6;margin:0 0 8px}.variant-v2 .caption{color:#777;font-size:14px;font-weight:400;line-height:1.5;margin:0 0 8px}.variant-v2 .label{color:#333;font-size:14px;font-weight:500;line-height:1.4;margin:0 0 4px}.variant-v2 .error-text{color:#c53030;font-size:14px;font-weight:400;line-height:1.5;margin:0 0 8px}.variant-v2 .success-text{color:#28a745;font-size:16px;font-weight:500;line-height:1.5;margin:0 0 12px}h1{color:#333;font-size:32px;font-weight:700;line-height:1.2;margin:0 0 24px}h2{font-size:24px;line-height:1.3;margin:0 0 20px}h2,h3{color:#333;font-weight:600}h3{font-size:20px;line-height:1.4;margin:0 0 16px}h4{color:#333;font-size:18px;line-height:1.4}.subtitle,h4{font-weight:500;margin:0 0 12px}.subtitle{color:#555;font-size:16px;line-height:1.5}.body-text{font-size:16px;line-height:1.6}.body-text,.caption{font-weight:400;margin:0 0 8px}.caption{color:#777;font-size:14px;line-height:1.5}.label{color:#333;font-size:14px;font-weight:500;line-height:1.4;margin:0 0 4px}.error-text{color:#c53030;font-size:14px;font-weight:400;line-height:1.5;margin:0 0 8px}.success-text{color:#28a745;font-size:16px;font-weight:500;line-height:1.5;margin:0 0 12px}.recap-header{align-items:center;display:flex;gap:8px;justify-content:center;margin-bottom:12px}.recap-header-icon{align-items:center;color:var(--primary-color);display:flex;font-size:20px!important}.recap-header h3{line-height:1;margin:0!important}.modal-header,.recap-header h3{align-items:center;display:flex}.modal-header{border-bottom:1px solid #e0e0e0;justify-content:space-between;padding:20px;position:relative}.modal-logo{left:20px;position:absolute;top:50%;transform:translateY(-50%)}.modal-logo img{max-height:40px;max-width:120px;object-fit:contain}.modal-header h2{color:#333;flex:1 1;font-size:24px;margin:0 160px;text-align:center}.close-button{align-items:center;background:none;border:none;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:32px;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.close-button:hover{background-color:#f0f0f0;color:#333}.step-indicator{background-color:#f8f9fa;justify-content:center;padding:20px 40px}.step,.step-container,.step-indicator{align-items:center;display:flex}.step{background-color:#e0e0e0;border-radius:50%;color:#666;font-size:16px;font-weight:600;height:40px;justify-content:center;transition:all .3s;width:40px}.step.active{background-color:var(--primary-color);color:#fff}.step.completed{background-color:rgba(var(--primary-color-rgb),.25);color:var(--primary-color)}.step-line{background-color:#e0e0e0;height:2px;margin:0 8px;transition:all .3s;width:60px}.step-line.completed{background-color:rgba(var(--primary-color-rgb),.25)}.modal-body{flex:1 1;padding:20px}.modal-body,.step-content{box-sizing:border-box;overflow-x:hidden;overflow-y:auto}.step-content{display:flex;flex-direction:column;height:100%;width:100%}@media (max-width:768px){.modal-content{display:flex;flex-direction:column;height:100vh!important;max-height:100vh!important}.modal-body{flex:1 1;min-height:0;overflow-y:auto;padding:16px}.step-content{flex:1 1;height:auto;overflow-y:auto}.modal-footer{background-color:#fff;bottom:0;box-shadow:0 -2px 10px #0000001a;flex-shrink:0;position:-webkit-sticky;position:sticky}}.locations-list{display:flex;flex-direction:column;gap:16px}.location-item{background-color:#f8f9fa;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;padding:16px;transition:all .2s}.location-item:hover{background-color:#e9ecef;border-color:silver}.location-item.selected{background-color:rgba(var(--primary-color-rgb),.1);border-color:var(--primary-color)}.location-item h3{color:#333;font-size:18px;font-weight:600;margin:0 0 8px}.location-item p{color:#666;font-size:14px;line-height:1.5;margin:0}.services-list{box-sizing:border-box;display:flex;flex-direction:column;gap:12px;width:100%}.search-container{margin-bottom:24px;padding:0 16px}.search-container,.search-input{box-sizing:border-box;width:100%}.search-input{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:16px;padding:12px 16px;transition:border-color .2s ease}.search-input:focus{border-color:var(--primary-color);outline:none}.search-input::placeholder{color:#999}.service-group{margin-bottom:24px}.service-group:last-child{margin-bottom:0}.service-group-header{align-items:center;display:flex;gap:16px;margin-bottom:16px}.service-group-header:not(.clickable){justify-content:center}.service-group-header.clickable{border-radius:8px;cursor:pointer;margin:-8px -8px 16px;padding:8px;transition:background-color .2s ease}.service-group-header.clickable:hover{background-color:rgba(var(--primary-color-rgb),.04)}.service-group-header.clickable:focus{outline:none}.service-group-title-container{align-items:center;display:flex;flex:1 1;gap:12px}.service-group-title{color:var(--primary-color);font-size:18px;font-weight:600;margin:0!important;padding:0;white-space:nowrap}.service-group-icon{align-items:center;background-color:var(--primary-color);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:24px;justify-content:center;transition:transform .2s ease,background-color .2s ease;-webkit-user-select:none;user-select:none;width:24px}.service-group-icon.collapsed,.service-group-icon.expanded{transform:rotate(0deg)}.service-group-header.clickable:hover .service-group-icon{background-color:var(--primary-color-dark)}.service-group-divider{background-color:rgba(var(--primary-color-rgb),.2);flex:1 1;height:1px}.service-group-items{box-sizing:border-box;display:flex;flex-direction:column;gap:12px;overflow:hidden;transition:all .3s ease;width:100%}.service-group-items.collapsed{gap:0;margin-top:-16px;max-height:0;opacity:0;padding-top:0}.service-group-items.expanded{margin-top:0;max-height:none;opacity:1;padding-top:0}.service-item{align-items:center;background-color:#f8f9fa;border:2px solid #e0e0e0;border-radius:6px;box-sizing:border-box;cursor:pointer;display:flex;gap:16px;max-width:100%;padding:16px;transition:all .2s}.service-item:hover{background-color:#e9ecef;border-color:silver}.service-item.selected{background-color:initial;border-color:#000;border-width:2px}.service-checkbox input[type=checkbox]{cursor:pointer;height:20px;width:20px}.service-info{flex:1 1}.service-info h3{color:#333;font-size:16px;font-weight:600;margin:0 0 4px}.service-info p{color:#666;font-size:14px;margin:0}.personal-info-form{gap:20px;margin:0 auto;max-width:400px}.form-group,.personal-info-form{display:flex;flex-direction:column}.form-group{gap:8px;position:relative}.form-group label{color:#333;font-size:14px;font-weight:600}.form-group input,.form-group select,.form-group textarea{background-color:#fff;border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-family:inherit;font-size:16px;padding:12px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary-color);outline:none}.form-group input:disabled,.form-group select:disabled{background-color:#f0f0f0;color:#666;cursor:not-allowed}.form-group input.error,.form-group select.error{background-color:#fff5f5;border-color:#dc3545}.form-group input.error:focus,.form-group select.error:focus{border-color:#c53030;box-shadow:0 0 0 1px #dc354533}.form-group .error-message{color:#dc3545;display:block;font-size:13px;line-height:1.4;margin-top:4px}.form-select{background-color:#fff;cursor:pointer}.form-section{margin-bottom:32px}.section-title{border-bottom:2px solid var(--primary-color);color:#333;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:8px}.form-row{display:flex;gap:16px;margin-bottom:20px}.form-row .form-group{flex:1 1;margin-bottom:0}.personal-info-form{max-width:none;width:100%}@media (max-width:768px){.form-row{flex-direction:column;gap:12px}.form-section{margin-bottom:24px}.section-title{font-size:16px;margin-bottom:16px}}.phone-validation-only{margin:40px auto;max-width:400px;text-align:center}.phone-validation-only .section-title{border-bottom:none;margin-bottom:12px}.section-description{color:#666;font-size:14px;margin-bottom:30px}.phone-validation-only .form-group{margin-bottom:20px}.phone-input-large{font-size:20px!important;letter-spacing:2px;padding:16px!important;text-align:center}.verified-badge{align-items:center;color:#28a745;display:inline-flex;font-size:14px;position:absolute;right:12px;top:50%;transform:translateY(8px)}.date-selection{display:flex;flex-direction:column;height:100%;justify-content:flex-start;overflow-y:auto;padding:10px}.calendar-month{margin-bottom:30px}.calendar-month:last-child{margin-bottom:0}.calendar-month-name{color:#333;font-size:18px;font-weight:600;margin:0 0 15px;text-align:center}.calendar-grid{margin:0 auto;max-width:350px}.calendar-header{grid-gap:5px;display:grid;gap:5px;grid-template-columns:repeat(7,1fr);margin-bottom:5px}.calendar-day-name{color:#666;font-size:12px;font-weight:600;padding:5px;text-align:center}.calendar-days{grid-gap:5px;display:grid;gap:5px;grid-template-columns:repeat(7,1fr)}.calendar-day{align-items:center;aspect-ratio:1;background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;display:flex;font-size:14px;font-weight:500;justify-content:center;transition:all .2s}.calendar-day.empty{background-color:initial;border:none;cursor:default}.calendar-day:not(.disabled):not(.empty):hover{background-color:#e9ecef;border-color:silver}.calendar-day.selected{background-color:var(--primary-color);border-color:#0056b3;color:#fff}.calendar-day.disabled{background-color:#f0f0f0;border-color:#e0e0e0;color:#ccc;cursor:not-allowed}.calendar-day.today{border-color:#007bff;font-weight:700}.recap{display:flex;flex-direction:column;gap:24px}.recap-section{background-color:#f8f9fa;border-radius:6px;padding:16px}.recap-section h3{color:#333;font-size:18px;font-weight:600;margin:0 0 12px}.recap-item{border-bottom:1px solid #e0e0e0;margin-bottom:12px;padding-bottom:12px}.recap-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.recap-item strong{color:#333;font-size:16px}.recap-item p{color:#666;font-size:14px;margin:4px 0}.modal-footer{border-top:1px solid #e0e0e0;padding:20px}.modal-actions{align-items:center;display:flex;justify-content:space-between}.action-button{border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:500;padding:10px 24px;transition:all .2s}.action-button.primary{background-color:var(--primary-button-bg);color:var(--primary-button-text)}.action-button.primary:hover:not(:disabled){background-color:var(--primary-color-dark)}.action-button.primary:disabled{background-color:#e0e0e0;color:#999;cursor:not-allowed}.action-button.secondary{background-color:var(--secondary-button-bg);border:1px solid var(--secondary-button-bg);color:var(--secondary-button-text)}.action-button.secondary:hover{background-color:var(--secondary-button-bg);opacity:.9}.pagination{align-items:center;display:flex;gap:20px;justify-content:center;margin-top:20px}.pagination-button{background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .2s}.pagination-button:hover:not(:disabled){background-color:#0056b3}.pagination-button:disabled{background-color:#e0e0e0;color:#999;cursor:not-allowed}.page-info{color:#666;font-size:14px;font-weight:500}.success-screen{align-items:center;display:flex!important;flex-direction:column;height:auto!important;justify-content:center;min-height:0!important}.success-icon{animation:checkmark .5s ease;background-color:#28a745;font-size:40px;font-weight:700;margin-bottom:24px}@keyframes checkmark{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.success-screen h2{margin:0 0 16px}.success-message{color:#666;font-size:18px;line-height:1.5;margin:0 0 8px}.success-submessage{color:#888;font-size:16px;line-height:1.5;margin:0}@media (max-width:600px){.modal-overlay{padding:0}.modal-content{border-radius:0;display:flex;flex-direction:column;height:100%;margin:0;max-height:100%;max-width:100%;width:100%}.step-indicator{display:none}.modal-header{background-color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:10}.modal-body{flex:1 1;overflow-y:auto;padding:15px}.modal-footer{background-color:#fff;bottom:0;box-shadow:0 -2px 10px #0000001a;position:-webkit-sticky;position:sticky}.calendar-grid,.personal-info-form{max-width:100%}.calendar-day{font-size:12px}.location-item h3,.service-info h3{font-size:16px}.location-item p,.service-info p{font-size:12px}.modal-actions{gap:10px}.action-button{flex:1 1;padding:12px 16px}}.phone-verification{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-top:15px;padding:20px}.phone-verification.verified{align-items:center;background-color:#d4edda;border-color:#c3e6cb;display:flex;justify-content:center;padding:15px}.verified-icon{color:#155724;font-size:20px;margin-right:10px}.verified-text{color:#155724;font-weight:500}.verification-message{color:#495057;margin-bottom:15px;text-align:center}.verify-button{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;display:block;font-size:16px;margin:0 auto;padding:10px 20px;transition:background-color .2s}.verify-button:hover:not(:disabled){background-color:#0056b3}.verify-button:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.65}.code-input-container{align-items:center;display:flex;gap:10px;justify-content:center;margin-bottom:15px}.code-input{border:2px solid #ced4da;border-radius:5px;font-size:20px;letter-spacing:8px;padding:10px;text-align:center;transition:border-color .2s;width:120px}.code-input:focus{border-color:#007bff;outline:none}.resend-container{margin-top:10px;text-align:center}.resend-timer{color:#6c757d;font-size:14px}.resend-link{background:none;border:none;color:#007bff;cursor:pointer;font-size:14px;padding:0;text-decoration:underline}.resend-link:hover:not(:disabled){color:#0056b3}.resend-link:disabled{color:#6c757d;cursor:not-allowed}.error-message{color:#dc3545;font-size:14px;margin-top:10px;text-align:center}.success-screen{padding:40px 20px;text-align:center}.success-icon{align-items:center;background-color:#4caf50;border-radius:50%;color:#fff;display:flex;font-size:48px;height:80px;justify-content:center;margin:0 auto 30px;width:80px}.success-screen h2{color:#333;font-size:28px;margin-bottom:15px}.success-screen .subtitle{color:#666;font-size:16px;margin-bottom:30px}.appointment-details{max-width:500px;padding:20px}.appointment-details h3{font-size:18px;margin-bottom:15px;text-align:center}.detail-row{border-bottom:1px solid #e0e0e0;justify-content:space-between;padding:10px 0}.detail-row:last-of-type{border-bottom:none}.detail-label{flex:0 0 120px}.detail-value{text-align:right}.download-calendar-button{background-color:#f0f0f0;border:1px solid #ddd;border-radius:6px;color:#333;cursor:pointer;display:block;font-size:14px;margin-top:15px;padding:10px 20px;text-align:center;transition:all .2s ease;width:100%}.download-calendar-button:hover{background-color:#e8e8e8;border-color:#ccc}.body-text{color:#666;font-size:14px;margin:20px 0 30px}.action-buttons{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:30px}.action-buttons .action-button{min-width:150px;padding:12px 20px}@media (max-width:600px){.action-buttons{align-items:center;flex-direction:column}.action-buttons .action-button{max-width:300px;width:100%}.detail-row{flex-direction:column;gap:5px}.detail-value{text-align:left}.detail-label{color:#666;flex:0 0 12px;font-weight:600}}.cancel-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.cancel-modal-content{animation:cancelModalSlideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:400px;padding:30px;width:100%}@keyframes cancelModalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.cancel-modal-content h3{color:#333;font-size:24px;margin:0 0 15px;text-align:center}.cancel-modal-content p{color:#666;font-size:16px;line-height:1.5;margin:0 0 15px;text-align:center}.cancel-modal-content .cancel-modal-warning-text{background-color:#ffebee;border-radius:6px;color:#d32f2f;font-size:14px;margin:20px 0;padding:10px 15px}.cancel-modal-actions{display:flex;gap:12px;justify-content:center;margin-top:25px}.cancel-modal-button{border:none;border-radius:6px;cursor:pointer;font-size:16px;font-weight:500;min-width:140px;padding:12px 24px;transition:all .2s ease}.cancel-modal-button.cancel{background-color:#f5f5f5;color:#333}.cancel-modal-button.cancel:hover{background-color:#e0e0e0}.cancel-modal-button.confirm{background-color:#d32f2f;color:#fff}.cancel-modal-button.confirm:hover{background-color:#c62828}@media (max-width:480px){.cancel-modal-content{padding:20px}.cancel-modal-actions{flex-direction:column}.cancel-modal-button{width:100%}}.cancelled-screen{align-items:center;display:flex;flex-direction:column;justify-content:flex-start;min-height:400px;padding:40px 20px;text-align:center}.cancelled-message{color:#666;font-size:18px;line-height:1.5;max-width:500px;padding:0 10px}.cancelled-submessage{color:#888;font-size:16px;line-height:1.5;margin-bottom:40px;max-width:500px}.appointment-details{background-color:#f5f5f5;border-radius:8px;margin:30px auto;max-width:600px;padding:24px;text-align:left}.appointment-details h3{color:#333;font-size:20px;font-weight:600;margin:0 0 20px}.detail-row{display:flex;font-size:16px;margin-bottom:12px}.detail-row:last-child{margin-bottom:0}.detail-label{color:#666;font-weight:600;margin-right:16px;min-width:120px}.detail-value{color:#333;flex:1 1}.cancelled-datetime{color:#999;text-decoration:line-through}.new-booking-button{background-color:#1976d2;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;min-width:200px;padding:14px 32px;transition:background-color .3s ease}.new-booking-button:hover{background-color:#1565c0}@media (max-width:600px){.cancelled-message{font-size:16px}.cancelled-submessage{font-size:14px}.new-booking-button{max-width:300px;width:100%}.appointment-details{margin:20px 10px;padding:16px}.appointment-details h3{font-size:18px}.detail-row{flex-direction:column;margin-bottom:16px}.detail-label{margin-bottom:4px}}
/*# sourceMappingURL=main.c42eb71f.css.map*/