:root{--color-error: #D54949;--color-blacklist: #F8ECEC;--color-green: #2AC55E;--color-green-stroke: #14EA00;--color-green-background: linear-gradient(90deg, rgba(102, 255, 130, .16) 0%, rgba(94, 255, 191, .16) 100% );--color-white: #FFFFFF;--color-light-background: #F6F6F6;--color-stroke: #DDDDDD;--color-grey: #6C7278;--color-black: #000000;--color-almost-black: #3B3B3B;--color-dark-gradient: linear-gradient(180deg, #000000 0%, #3B3B3B 100%);--color-orange: #EA2F00;--color-orange-light: #EA5A00;--color-orange-dark: #8B1A00;--color-orange-darker: #5C1200;--color-orange-gradient: linear-gradient(180deg, #EA2F00 0%, #FF9A1F 100%);--color-orange-white-gradient: linear-gradient( 180deg, rgba(234, 47, 0, 1) 0%, rgba(255, 154, 31, 1) 45%, rgba(255, 255, 255, 0) 200% );--color-orange-gradient-background: linear-gradient(180deg, rgba(234, 47, 0, .16) 0%, rgba(255, 154, 31, .16) 100% );--color-text: #251819;--color-sub-text: #969091;--shadow-light: 0 4px 20px rgba(0, 0, 0, .08);--shadow-medium: 0 8px 32px rgba(0, 0, 0, .1);--radius-small: 8px;--radius-medium: 12px;--radius-large: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-round: 9999px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--font-light: 300;--font-regular: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--transition-fast: .1s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}html{background-color:var(--color-orange)}body{margin:0;font-family:Rubik,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-orange)}.booking-form-page{min-height:100dvh;background:#f6f6f6;padding:0 0 env(safe-area-inset-bottom,40px);font-family:Rubik,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;max-width:100%;overflow-x:hidden;-webkit-overflow-scrolling:touch;-webkit-tap-highlight-color:transparent}.form-header{padding:max(16px,env(safe-area-inset-top)) 20px 16px;margin-bottom:0;position:sticky;top:0;z-index:10}.back-button{display:flex;align-items:center;gap:12px;font-size:16px;color:var(--color-grey);border:none;font-weight:400;transition:opacity .2s;-webkit-tap-highlight-color:transparent}.back-button:hover,.back-button:active{opacity:.8}.back-button svg{stroke:var(--color-grey)}.summary-card{background:linear-gradient(180deg,#3b3b3b,#000);border-radius:16px;padding:20px 16px 28px;margin:24px;text-align:center}.summary-label{color:var(--color-white);font-size:14px;font-weight:lighter;display:block;margin-bottom:8px}.summary-card-service-name{color:var(--color-orange-light);font-size:24px;font-weight:700;margin:0 0 10px;line-height:1.2;word-wrap:break-word}.summary-card-datetime{color:var(--color-white);font-size:20px;font-weight:500;margin:0 0 16px}.summary-badges{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.summary-badge{display:flex;align-items:center;gap:6px;background:var(--color-almost-black);padding:8px 14px;border-radius:20px;color:#fff;font-size:13px;font-weight:500}.timer-img{width:16px;height:16px}.info-form{background:transparent;padding:0 16px}.info-form-title{font-size:20px;font-weight:500;color:var(--color-text);margin-bottom:16px}.form-field{margin-bottom:20px}.form-field label{display:block;margin-bottom:16px;color:var(--color-text);font-weight:400;font-size:16px}.form-input{width:100%;padding:16px;border:1px solid var(--color-stroke);border-radius:10px;font-size:16px;background:var(--color-white);color:var(--color-text);box-sizing:border-box;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input:focus{background-color:var(--color-white);border-color:var(--color-grey)}.form-input::placeholder{color:var(--color-sub-text)}.phone-input-wrapper{display:flex;border:1px solid var(--color-stroke);border-radius:10px;font-size:16px;background:var(--color-white);color:var(--color-text);box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.phone-input-wrapper:focus-within{border-color:var(--color-grey)}.country-code-select{display:flex;align-items:center;padding:16px 8px 16px 12px;border:none;border-right:1px solid var(--color-stroke);border-radius:10px 0 0 10px;background:var(--color-white);color:var(--color-text);font-size:16px;font-weight:500;flex-shrink:0;cursor:pointer;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:100px}.country-code-select:focus{outline:none}.phone-input{border:none!important;border-radius:10px!important;box-shadow:none!important}.phone-input:focus{border:none!important;box-shadow:none!important}.form-input.error{border-color:#e74c3c}.phone-input-wrapper:has(.error){border-color:#e74c3c}.error-message{color:#e74c3c;font-size:13px;margin-top:8px;display:block}.confirm-button{width:100%;padding:18px;font-size:14px;font-weight:400;background:#1a1a1a;color:#fff;border:none;border-radius:12px;cursor:pointer;display:flex;justify-content:center;align-items:center;gap:8px;margin-top:24px;min-height:56px;transition:opacity .2s,transform .1s;-webkit-tap-highlight-color:transparent}.confirm-button:hover:not(:disabled){opacity:.9}.confirm-button:active:not(:disabled){transform:scale(.98)}.confirm-button:disabled{background:#ccc;cursor:not-allowed}.back-link{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px;margin-top:18px;background:var(--color-stroke);border:none;color:var(--color-text);font-size:16px;font-weight:400;cursor:pointer;min-height:48px;transition:color .2s;-webkit-tap-highlight-color:transparent}.back-link:hover,.back-link:active{color:#333}@media(min-width:480px){.summary-card{padding:24px 20px 32px;border-radius:0 0 32px 32px}.summary-service-name{font-size:28px}.summary-datetime{font-size:18px}.info-form{padding:0 20px}.info-form-title{font-size:22px}}@media(min-width:768px){.booking-form-page{max-width:480px;margin:0 auto;box-shadow:0 0 40px #0000001a;min-height:100vh;background:#f6f6f6}.form-header{padding:20px;position:relative}.summary-card{margin-bottom:32px}}@media(max-height:500px)and (orientation:landscape){.form-header{padding:12px 20px}.summary-card{padding:16px}.info-form-title,.form-field{margin-bottom:16px}.confirm-button{margin-top:16px}}@media(prefers-reduced-motion:reduce){.spinner-small{animation:none}.confirm-button,.back-button,.back-link,.form-input{transition:none}}.booking-confirmation-page{min-height:100dvh;background:#f6f6f6;padding:0 0 env(safe-area-inset-bottom,40px);font-family:Rubik,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;max-width:100%;overflow-x:hidden;-webkit-overflow-scrolling:touch;-webkit-tap-highlight-color:transparent}.booking-success{text-align:center;padding:32px 20px max(32px,env(safe-area-inset-bottom));background:var(--color-light-background);min-height:100dvh}.success-icon{font-size:56px;margin-bottom:20px}.success-img{margin-top:50px;width:68px;height:68px}.booking-success h1,.booking-success h2{color:#1a1a1a;margin-bottom:24px;font-size:22px;font-weight:700}.success-message-card{margin:0 auto;max-width:400px}.success-message{color:var(--color-text);line-height:1.6;font-size:20px;padding:10px}.booking-details{padding:16px;border-radius:16px;margin-bottom:20px;margin-top:20px;text-align:left}.detail-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--color-stroke)}.detail-row:last-child{margin-bottom:0;border-bottom:none;padding-bottom:0}.detail-row .label{color:var(--color-grey);font-weight:400;font-size:16px}.detail-row .value{color:var(--color-almost-black);font-weight:400;font-size:20px;text-align:right;max-width:60%;word-wrap:break-word}.status-pending{color:#ea5a00!important;text-transform:capitalize;font-weight:600}@media(min-width:480px){.booking-success{padding:40px 24px}.success-icon{font-size:64px}.booking-success h1,.booking-success h2{font-size:24px}.booking-details{padding:20px}.detail-row .label,.detail-row .value{font-size:14px}}@media(min-width:768px){.booking-confirmation-page{max-width:480px;margin:0 auto;box-shadow:0 0 40px #0000001a;min-height:100vh}.booking-success{max-width:480px;margin:0 auto;border-radius:0;box-shadow:0 0 40px #0000001a}}.booking-page{min-height:100vh;background:var(--color-light-background);color:#1a1a1a;font-family:Rubik,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;padding-bottom:140px}.gradient-background{background:var(--color-orange-white-gradient);border-radius:0}.page-header{padding:40px 20px}.logo{display:flex;margin-bottom:8px}.logo-img{height:30px;width:auto;margin-right:6px}.master-info-card{background:var(--color-dark-gradient);padding:16px;border-radius:16px}.logo-title{color:var(--color-white);font-size:24px;font-weight:600;margin:0;letter-spacing:.5px}.header-subtitle{color:var(--color-white);font-size:14px;margin:24px 0 16px;font-weight:500}.steps-indicator{display:flex;justify-content:center;gap:8px;flex-wrap:nowrap}.step{display:flex;align-items:center;gap:6px;background:var(--color-dark-gradient);padding:6px 10px;border-radius:29px;font-size:11px;color:var(--color-white);white-space:nowrap}.step-icon{font-size:12px}.step-icon img{width:14px;height:14px}.step-text{font-weight:500}.user-info-section{padding:20px 20px 50px;text-align:center;margin-top:0;border-radius:32px;position:relative}.avatar-container{width:100px;height:100px;border-radius:50%;margin:0 auto 16px;overflow:hidden;border:4px solid var(--color-dark-gradient);background:#ea2f00}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#e8e0d5;color:#d4a574}.user-name{color:#fff;font-size:24px;font-weight:600;margin:0 0 8px}.user-bio{color:#fffc;font-size:14px;line-height:1.5;max-width:280px;margin:0 auto}.services-section{padding:32px 20px;background:var(--color-light-background);border-radius:32px 32px 0 0;position:relative;margin-top:-32px}.section-title{font-size:20px;font-weight:500;color:#1a1a1a;margin:0 0 20px}.service-card{background:#fff;border:1px solid #eee;border-radius:16px;padding:20px;cursor:pointer;transition:all .2s ease}.service-card{position:relative}@media(min-width:480px){.services-list{display:grid;grid-template-columns:1fr;gap:12px}.services-list .service-card:first-child{grid-column:1 / -1}}.datetime-section{padding:0 20px 32px;background:var(--color-light-background)}.loading-schedule{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#666}.loading-schedule .spinner{width:32px;height:32px;margin-bottom:12px}.loading-schedule p{margin:0;font-size:14px}.no-slots{text-align:center;padding:40px 20px;background:#f9f9f9;border-radius:16px;color:#666}.no-slots p{margin:0;font-size:14px}.calendar{background:#f6f6f6;border-radius:16px;padding:20px;margin-bottom:24px}.nav-btn{width:36px;height:36px;border:1px solid #eee;border-radius:8px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;transition:all .2s}.nav-btn:hover{border-color:#ddd;background:#f9f9f9}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day-name{text-align:center;font-size:12px;font-weight:500;color:#999;padding:8px 0;text-transform:capitalize}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;color:#1a1a1a;background:transparent;border:1px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s;position:relative}.calendar-day.empty{cursor:default}.calendar-day.disabled{color:#ccc;cursor:not-allowed}.calendar-day.available:not(.selected):not(.today){color:#1a1a1a;background:#fff;border-color:#ddd}.calendar-day.available:hover:not(.selected){background:#f5f5f5;border-color:#ccc}.calendar-day.today{color:var(--color-text);background:var(--color-white);border-color:var(--color-orange)}.calendar-day.selected{background:var(--color-orange-gradient-background);border-color:var(--color-orange);color:var(--color-text)}.calendar-legend{display:flex;justify-content:flex-start;gap:20px;margin-top:20px;padding-top:16px;padding-bottom:16px;border-bottom:1px solid var(--color-stroke)}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--color-grey)}.legend-dot{width:10px;height:10px;border-radius:50%}.today-dot{background:transparent;border:2px solid var(--color-orange)}.selected-dot{background:var(--color-orange)}.available-dot{background:transparent;border:2px solid var(--color-stroke)}.time-slots{display:flex;flex-wrap:wrap;gap:12px}.time-slot{padding:14px 24px;border:1px solid #eee;border-radius:16px;background:#fff;font-size:15px;font-weight:500;color:#1a1a1a;cursor:pointer;transition:all .2s}.time-slot:hover{border-color:var(--color-stroke);background:var(--color-white)}.time-slot.selected{background:var(--color-white);border-color:var(--color-orange)}.booking-summary-footer{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #eee;padding:16px 20px;padding-bottom:max(16px,env(safe-area-inset-bottom));z-index:100;box-shadow:0 -4px 20px #00000014}.summary-content{display:flex;align-items:center;justify-content:space-between;max-width:600px;margin:0 auto}.summary-service{flex:1;min-width:0}.summary-service-name{font-size:15px;font-weight:600;color:#1a1a1a;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.summary-details{font-size:13px;color:#666;margin:0}.summary-datetime{font-size:13px;color:var(--color-orange-light);margin:4px 0 0;font-weight:500}.next-btn{display:flex;align-items:center;gap:8px;background:#000;color:var(--color-white);border:none;padding:14px 28px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;flex-shrink:0;margin-left:16px}.next-btn:hover:not(:disabled){background:#333}.next-btn:disabled{background:#ccc;cursor:not-allowed}.next-btn svg{transition:transform .2s}.next-btn:hover:not(:disabled) svg{transform:translate(4px)}@media(max-width:480px){.page-header{padding:30px 16px 20px}.steps-indicator{gap:6px}.step{padding:6px 8px;font-size:10px;margin-bottom:16px}.user-info-section{padding:0 16px 32px}.avatar-container{width:80px;height:80px}.user-name{font-size:20px}.user-bio{font-size:13px}.services-section,.datetime-section{padding-left:16px;padding-right:16px}.section-title{font-size:20px}.service-card,.calendar{padding:16px}.calendar-day{font-size:13px}.time-slot{padding:12px 20px;font-size:14px}.booking-summary-footer{padding:14px 16px;padding-bottom:max(14px,env(safe-area-inset-bottom))}.summary-service-name{font-size:14px}.summary-details,.summary-datetime{font-size:12px}.next-btn{padding:12px 20px;font-size:14px}}@media(min-width:768px){.booking-page{max-width:480px;margin:0 auto;box-shadow:0 0 40px #0000001a}.booking-summary-footer{max-width:480px;left:50%;transform:translate(-50%);border-radius:16px 16px 0 0}}.reschedule-page{min-height:100vh;background:var(--color-light-background);color:#1a1a1a;font-family:Rubik,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;padding-bottom:40px}.gradient-header{background:var(--color-orange-gradient);border-radius:0 0 32px 32px}.reschedule-page .page-header{padding:40px 20px 20px}.reschedule-page .logo{display:flex;align-items:center;gap:12px}.reschedule-page .logo-img{width:40px;height:40px}.reschedule-page .logo-title{font-size:24px;font-weight:700;color:var(--color-almost-black);margin:0}.master-info-section{padding:0 20px 20px}.master-card{text-align:center}.avatar-container{width:100px;height:100px;margin:0 auto 16px;border-radius:50%;overflow:hidden;background:var(--color-white);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000001a}.avatar-img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f5f5f5;color:#999}.master-name{font-size:24px;font-weight:700;color:var(--color-almost-black);margin:0 0 8px}.master-bio{font-size:20px;color:var(--color-almost-black);line-height:1.5;max-width:400px;margin:0 auto}.back-button{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--color-grey);font-size:16px;font-weight:400;cursor:pointer;padding:8px;margin:0;transition:opacity .2s}.back-button:hover{opacity:.7}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#1a1a1a}.spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top:3px solid #1a1a1a;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.loading-schedule{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px}.spinner-small{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top:2px solid #ffffff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-card{background:#fff;border-radius:16px;padding:40px;text-align:center;box-shadow:0 4px 20px #00000014;max-width:400px;margin:2rem auto}.error-card h2{color:#e74c3c;margin-bottom:12px;font-size:20px;font-weight:600}.error-card p{color:#666;margin-bottom:20px;font-size:14px;line-height:1.5}.primary-btn{background:#1a1a1a;color:#fff;border:none;padding:12px 24px;border-radius:24px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s}.primary-btn:hover{opacity:.9}.error-message-banner{background:#fee;border:1px solid #fcc;color:#e74c3c;padding:12px 20px;border-radius:8px;margin:20px;text-align:center}.current-booking-container{padding:20px;max-width:600px;margin:0 auto}.section-title{font-size:24px;font-weight:600;color:#1a1a1a;margin-bottom:24px;margin-top:20px;padding:0 4px}.subsection-title{font-size:20px;font-weight:500;color:var(--color-text);margin-bottom:16px;padding:0 4px}.appointment-details-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 2px 12px #0000000f;margin-bottom:24px}.appointment-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--color-stroke)}.appointment-row:last-child{border-bottom:none;padding-bottom:0}.appointment-row:first-child{padding-top:0}.appointment-label{font-size:15px;color:var(--color-grey);font-weight:400}.appointment-value{font-size:16px;color:var(--color-almost-black);font-weight:500;text-align:right;max-width:60%}.status-badge{background:#fff3e0;color:#ea5a00;padding:6px 12px;border-radius:12px;font-size:14px;font-weight:600;text-transform:capitalize}.change-booking-btn{width:100%;padding:16px;background:#1a1a1a;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:500;cursor:pointer;transition:opacity .2s;margin-bottom:12px}.change-booking-btn:hover{opacity:.9}.cancel-booking-btn{width:100%;padding:16px;background:transparent;color:#e74c3c;border:2px solid #e74c3c;border-radius:12px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.cancel-booking-btn:hover{background:#e74c3c;color:#fff}.cancelled-info{background:#fff3e0;border:1px solid #ffb74d;border-radius:12px;padding:16px;margin-bottom:12px}.cancelled-message{color:#e65100;font-size:15px;line-height:1.5;margin:0;text-align:center;font-weight:500}.new-booking-btn{width:100%;padding:16px;background:#1a1a1a;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:500;cursor:pointer;transition:opacity .2s}.new-booking-btn:hover{opacity:.9}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:16px;padding:32px 24px 24px;max-width:400px;width:100%;box-shadow:0 8px 32px #0003;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-title{font-size:22px;font-weight:600;color:#1a1a1a;margin:0 0 12px;text-align:center}.modal-message{font-size:15px;color:#666;line-height:1.6;margin:0 0 24px;text-align:center}.modal-actions{display:flex;gap:12px;flex-direction:column}.modal-btn{width:100%;padding:14px;border:none;border-radius:12px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.modal-btn:disabled{opacity:.6;cursor:not-allowed}.modal-btn-secondary{background:#f5f5f5;color:#1a1a1a}.modal-btn-secondary:hover:not(:disabled){background:#e5e5e5}.modal-btn-danger{background:#e74c3c;color:#fff}.modal-btn-danger:hover:not(:disabled){background:#d43f2f}.modal-btn .spinner-small{border-color:#ffffff4d;border-top-color:#fff}.reschedule-content{max-width:600px;margin:0 auto;padding:0 20px}.services-list{display:flex;flex-direction:column;gap:12px}.service-card{background:#fff;border:1px solid var(--color-stroke);border-radius:16px;padding:20px;cursor:pointer;transition:all .2s ease;position:relative}.service-card.selected{border-color:var(--color-orange-light);background:var(--color-orange-gradient-background)}.service-check{position:absolute;top:14px;right:20px;width:22px;height:22px;color:#5c1200}.service-content{display:flex;flex-direction:column;gap:8px}.service-name{font-size:16px;font-weight:500;color:var(--color-text);margin:0}.service-description{font-size:14px;font-weight:300;color:var(--color-text);margin:0}.service-meta{display:flex;align-items:center;justify-content:space-between;margin-top:6px}.service-duration{background:var(--color-white);border-radius:68px;padding:4px;display:flex;align-items:center;gap:4px;font-size:14px;color:var(--color-text)}.service-duration svg{opacity:.6}.service-price{background:var(--color-white);border-radius:68px;padding:4px;font-size:14px;font-weight:400;color:var(--color-text)}.datetime-section{margin-bottom:32px}.calendar{border-radius:16px;padding:20px;margin-bottom:24px}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.calendar-header h3{font-size:18px;font-weight:600;color:#1a1a1a;margin:0}.calendar-nav{display:flex;gap:8px}.nav-btn{background:transparent;border:1px solid var(--color-stroke);border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666;transition:all .2s}.nav-btn:hover{background:#f5f5f5;border-color:#ccc}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.calendar-day-name{text-align:center;font-size:12px;font-weight:500;color:#999;padding:8px 0}.calendar-day{aspect-ratio:1;border:1px solid var(--color-stroke);border-radius:8px;background:#fff;color:#ccc;font-size:14px;font-weight:500;cursor:not-allowed;transition:all .2s}.calendar-day.available{color:#1a1a1a;cursor:pointer;border-color:var(--color-stroke)}.calendar-day.today{border-color:var(--color-orange-light);background:#fff9f5}.calendar-day.selected{background:var(--color-orange-light);border-color:var(--color-orange);color:var(--color-white)}.calendar-day.disabled{color:#ddd;cursor:not-allowed}.calendar-day.empty{border:none;background:transparent}.calendar-legend{display:flex;justify-content:center;gap:16px;margin-top:16px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#666}.legend-dot{width:12px;height:12px;border-radius:50%;border:1px solid var(--color-stroke)}.legend-dot.today-dot{border-color:var(--color-orange-light);background:#fff9f5}.legend-dot.selected-dot{background:var(--color-orange-light);border-color:var(--color-orange-light)}.legend-dot.available-dot{border-color:var(--color-stroke);background:#fff}.time-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.time-slot{padding:12px;border:2px solid var(--color-stroke);border-radius:10px;background:#fff;color:#1a1a1a;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.time-slot:hover{border-color:#ccc;background:#f5f5f5}.time-slot.selected{border-color:var(--color-orange-light);background:var(--color-orange-light);color:#fff}.reschedule-footer{position:fixed;bottom:0;left:0;right:0;background:#fff;padding:16px 20px;box-shadow:0 -4px 20px #00000014;z-index:100}.reschedule-btn{width:100%;max-width:600px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;background:#1a1a1a;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:500;cursor:pointer;transition:opacity .2s}.reschedule-btn:hover:not(:disabled){opacity:.9}.reschedule-btn:disabled{background:#ccc;cursor:not-allowed}.no-changes-message{text-align:center;color:#999;font-size:13px;margin-top:8px}.success-container{text-align:center;padding:60px 20px;max-width:600px;margin:0 auto}.success-img{width:80px;height:80px;margin-bottom:24px}.success-container h1{font-size:28px;font-weight:700;color:#1a1a1a;margin-bottom:16px}.success-message{font-size:16px;color:#666;line-height:1.6;margin-bottom:32px}.booking-details-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 2px 12px #0000000f;text-align:left}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--color-stroke)}.detail-row:last-child{border-bottom:none}.detail-row .label{font-size:14px;color:#666;font-weight:400}.detail-row .value{font-size:16px;color:#1a1a1a;font-weight:500;text-align:right}@media(min-width:768px){.reschedule-page{background:#e5e5e5}.reschedule-content,.current-booking-container{max-width:600px;margin:0 auto}.reschedule-footer{left:50%;transform:translate(-50%);max-width:640px;border-radius:16px 16px 0 0}}@media(max-height:500px)and (orientation:landscape){.reschedule-footer{position:relative;box-shadow:none;padding:16px 0}}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f3f3ee;min-height:100vh;position:relative;overflow-x:hidden}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:#c2dc800d;pointer-events:none;z-index:-1}.App{min-height:100vh;position:relative;z-index:1}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{border:none;cursor:pointer;font-family:inherit;border-radius:16px;transition:all .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}input{font-family:inherit;background:#f3f3ee99;border:1px solid rgba(194,220,128,.3);color:#191919;border-radius:16px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:16px 20px;font-size:16px;transition:all .3s ease}input::placeholder{color:#19191999}.card{background:#f3f3ee66;border-radius:24px;padding:24px;margin-bottom:20px;border:1px solid rgba(194,220,128,.3);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 32px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1)}.card:hover{transform:translateY(-4px);box-shadow:0 16px 64px #00000026;border-color:#c2dc80}.card-title{font-size:24px;font-weight:700;margin-bottom:16px;color:#191919}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.glass-button{background:#c2dc804d;color:#191919;border:1px solid rgba(194,220,128,.5);padding:16px 32px;border-radius:16px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 32px #0000001a}.glass-button:hover{transform:translateY(-2px);box-shadow:0 12px 40px #00000026}.glass-button:active{transform:translateY(0);box-shadow:0 4px 16px #0000001a}.glass-button:disabled{background:#fcd5d34d;color:#19191980;cursor:not-allowed;transform:none;border-color:#fcd5d380}.glass-button-primary{background:#c2dc8099}.glass-button-primary:hover{box-shadow:0 12px 40px #c2dc804d}.glass-button-secondary{background:#fcd5d34d;border:1px solid rgba(252,213,211,.5)}.glass-button-secondary:hover{background:#fcd5d380}
