body{background-color:#f8f9fa;min-height:100vh}*{word-break:break-word;overflow-wrap:break-word}.section-booking{padding:4rem 0;background-color:#f8f9fa;min-height:100vh}.booking-container{max-width:120rem;padding:3rem;background-color:#fff;border-radius:1rem;box-shadow:0 .2rem 1rem rgba(0,0,0,.05);margin:0 auto 4rem}.home-button{position:fixed;left:2rem;top:2rem;display:inline-flex;align-items:center;font-size:1.6rem;color:#fff;text-decoration:none;transition:all .3s;background-color:#b2d8db;padding:1rem 1.5rem;border-radius:.5rem;box-shadow:0 .2rem .5rem rgba(0,0,0,.1);z-index:1000}.home-button:hover{background-color:#7d9799;transform:translateY(-.2rem)}.home-button svg{margin-right:.8rem;width:1.8rem;height:1.8rem}.center-text{text-align:center;position:relative}.subheading{display:block;font-size:1.6rem;font-weight:500;color:#b2d8db;text-transform:uppercase;margin-bottom:1.5rem;letter-spacing:.1rem}.heading-secondary{font-size:3.6rem;font-weight:600;color:#333;margin-bottom:4rem}.heading-tertiary{font-size:2.4rem;font-weight:500;color:#555;margin-bottom:2rem}.booking-step-description{font-size:1.6rem;color:#666;margin-bottom:3.2rem;word-wrap:break-word;overflow-wrap:break-word}.booking-progress{margin-bottom:4rem;padding:2rem 0}.progress-bar-container{background:linear-gradient(135deg,#f8f9fa,#fff);border-radius:1.5rem;padding:2rem;box-shadow:0 .4rem 1.2rem rgba(0,0,0,.05);border:1px solid #e9ecef}.progress-steps{display:flex;justify-content:space-between;align-items:center;position:relative;margin-bottom:1.5rem}.progress-line{right:0;background:linear-gradient(90deg,#e9ecef,#dee2e6);z-index:1}.progress-line,.progress-line-active{position:absolute;top:50%;left:0;height:3px;border-radius:1.5px;transform:translateY(-50%)}.progress-line-active{background:linear-gradient(90deg,#b2d8db,#9bc5c8);z-index:2;transition:width .6s cubic-bezier(.4,0,.2,1)}.progress-step{flex-direction:column;z-index:3;min-width:9.5rem;text-align:center;flex:1}.progress-step,.step-circle{display:flex;align-items:center;position:relative}.step-circle{width:4rem;height:4rem;border-radius:50%;justify-content:center;font-size:1.6rem;font-weight:700;margin-bottom:1rem;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 .2rem .8rem rgba(0,0,0,.1);overflow:hidden;flex-shrink:0;min-width:4rem;min-height:4rem}.step-circle:not(.active):not(.completed){background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #dee2e6;color:#6c757d}.step-circle.active{background:linear-gradient(135deg,#b2d8db,#9bc5c8);border:2px solid #b2d8db;color:#fff;transform:scale(1.05);box-shadow:0 .4rem 1.2rem rgba(178,216,219,.4)}.step-circle.completed{background:linear-gradient(135deg,#28a745,#20c997);border:2px solid #28a745;color:#fff}.step-text{font-size:1.3rem;font-weight:500;color:#6c757d;transition:all .3s ease;line-height:1.3;max-width:9.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.progress-step.active .step-text,.progress-step.completed .step-text{color:#495057;font-weight:600}.step-circle.active:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(135deg,#b2d8db,#9bc5c8);border-radius:50%;z-index:-1;opacity:.6;animation:pulse 2s infinite}@media (max-width:768px){.progress-bar-container{padding:1.5rem 1rem}.step-circle{width:3.5rem;height:3.5rem;font-size:1.4rem;min-width:3.5rem;min-height:3.5rem;flex-shrink:0}.step-text{font-size:1.2rem;max-width:8rem;white-space:nowrap}.progress-step{min-width:8rem;flex:1}}@media (max-width:480px){.progress-bar-container{padding:1rem .5rem}.step-circle{width:3rem;height:3rem;font-size:1.2rem;min-width:3rem;min-height:3rem;flex-shrink:0}.step-text{font-size:1.1rem;max-width:6rem;white-space:nowrap}.progress-step{min-width:6rem;flex:1}.progress-line,.progress-line-active{height:2px}}.btn-primary{color:#fff}.btn-primary:hover:not(:disabled){background-color:#7d9799;transform:translateY(-.2rem)}.btn-primary:disabled{background-color:#b2d8db;opacity:.6;cursor:not-allowed}.btn-secondary{background-color:#f3f4f6;color:#444}.btn-secondary:hover:not(:disabled){background-color:#e5e7eb;transform:translateY(-.2rem)}.form-actions{gap:1.6rem;margin-top:3.2rem}.treatments-container{margin-bottom:4rem}.category-tabs{display:flex;gap:1.6rem;margin-bottom:2.4rem;border-bottom:.1rem solid #e5e7eb;padding-bottom:1.6rem;flex-wrap:wrap}.category-tab{padding:.8rem 1.6rem;border-radius:.5rem;font-size:1.4rem;font-weight:500;cursor:pointer;transition:all .3s;background-color:#f3f4f6;border:.1rem solid #e5e7eb;color:#555}.category-tab:hover{background-color:#e5e7eb;border-color:#d1d5db}.category-tab.active{background-color:#b2d8db;color:#fff;border-color:#b2d8db}.treatments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(28rem,1fr));gap:2.4rem;margin-bottom:3.2rem}.treatment-card{position:relative;border-radius:.8rem;overflow:hidden;box-shadow:0 .2rem 1rem rgba(0,0,0,.05);transition:all .3s;border:.1rem solid #e5e7eb;cursor:pointer}.treatment-card:hover{transform:translateY(-.4rem);box-shadow:0 .4rem 1.2rem rgba(0,0,0,.1)}.treatment-card.selected{border-color:#b2d8db;box-shadow:0 0 0 .2rem #b2d8db}.treatment-image{width:100%;height:16rem;position:relative}.selected-overlay{position:absolute;top:1rem;right:1rem;width:2.4rem;height:2.4rem;background-color:#b2d8db;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.treatment-info{padding:1.6rem}.treatment-name{font-size:1.8rem;margin-bottom:.8rem}.treatment-description{font-size:1.4rem;color:#666;margin-bottom:1.6rem;line-height:1.5}.treatment-meta{display:flex;justify-content:space-between;font-size:1.4rem;color:#555}.treatment-duration,.treatment-price{display:flex;align-items:center;gap:.4rem}.treatment-summary{margin-top:3.2rem;padding:2rem;background-color:#f8f9fa;border-radius:.8rem}.summary-title{font-size:1.8rem;font-weight:600;color:#333}.summary-items,.summary-title{margin-bottom:1.6rem}.summary-item{display:flex;justify-content:space-between;margin-bottom:.8rem;font-size:1.4rem;color:#555}.summary-item:last-child{margin-bottom:0}.summary-total{display:flex;justify-content:space-between;font-size:1.6rem;font-weight:600;color:#333;padding-top:1.6rem;border-top:.1rem solid #e5e7eb}.datetime-selection-container{margin-bottom:4rem;background-color:#fff}.calendar-container{margin-bottom:3.2rem;background-color:#fff}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.6rem}.month-nav-btn{background:transparent;border:none;font-size:2rem;color:#555;cursor:pointer;padding:.4rem 1.2rem;border-radius:.4rem;transition:all .3s}.month-nav-btn:hover{background-color:#f3f4f6}.current-month{font-size:1.8rem;font-weight:500;color:#333}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.4rem;margin-bottom:.8rem}.weekday{text-align:center;font-size:1.4rem;font-weight:500;color:#777;padding:.8rem 0}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.4rem;background-color:#fff}.calendar-day{display:flex;align-items:center;justify-content:center;height:4rem;font-size:1.4rem;border-radius:.4rem;cursor:default;background-color:#fff}.empty-day{background-color:transparent}.past-day{color:#ccc;background-color:#fff}.sunday{background-color:#f8f9fa;color:#aaa;position:relative}.sunday:after{content:"";position:absolute;width:80%;height:.1rem;background-color:#eee;transform:rotate(-45deg)}.blocked-day{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#64748b;position:relative;cursor:not-allowed;border:1px solid #e2e8f0;transition:all .2s ease}.blocked-day:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-color:#cbd5e1}.blocked-day:before{content:"🚫";font-size:.9rem;opacity:.8;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.blocked-day:before,.blocked-indicator{position:absolute;top:.2rem;right:.2rem;z-index:2}.blocked-icon{font-size:.8rem;color:#64748b;filter:drop-shadow(0 0 2px rgba(255,255,255,.8))}.blocked-day .blocked-tooltip{position:absolute;bottom:100%;left:50%;transform:translateX(-50%);background:#1e293b;color:#fff;padding:.6rem .8rem;border-radius:.4rem;font-size:1.1rem;white-space:nowrap;z-index:1000;opacity:0;visibility:hidden;transform:translateX(-50%) translateY(.5rem);transition:all .2s ease;box-shadow:0 4px 12px rgba(0,0,0,.15);margin-bottom:.4rem}.blocked-day .blocked-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:.4rem solid transparent;border-top-color:#1e293b}.blocked-day:hover .blocked-tooltip{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}.available-day{background-color:#f3f4f6;color:#333;cursor:pointer;transition:all .3s}.available-day:hover{background-color:#e5e7eb}.selected-day{background-color:#b2d8db;color:#fff}.calendar-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-top:1.5rem;padding:1rem;background-color:#f9fafb;border-radius:.5rem;border:1px solid #e5e7eb}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:1.2rem;color:#6b7280}.legend-indicator{width:1.6rem;height:1.6rem;border-radius:.3rem;position:relative;flex-shrink:0}.legend-indicator.available{background-color:#f3f4f6;border:1px solid #d1d5db}.legend-indicator.sunday{background-color:#f8f9fa;color:#aaa}.legend-indicator.sunday:after{content:"";position:absolute;width:80%;height:.1rem;background-color:#eee;transform:rotate(-45deg);top:50%;left:50%;transform-origin:center;transform:translate(-50%,-50%) rotate(-45deg)}.legend-indicator.past{background-color:#fff;color:#ccc;border:1px solid #e5e7eb}.legend-indicator.blocked{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;color:#64748b;position:relative}.legend-indicator.blocked:before{content:"🚫";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.7rem;opacity:.8}.legend-loading{display:flex;align-items:center;font-size:1.1rem;color:#9ca3af;font-style:italic}.time-slots-container{margin-top:3.2rem;background-color:#fff}.time-slots-heading{font-size:1.8rem;font-weight:500;color:#333;margin-bottom:1.6rem}.time-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(8rem,1fr));gap:1rem;margin-top:1.5rem}.time-slot{padding:1rem;background-color:#f3f4f6;border:.1rem solid transparent;border-radius:.4rem;font-size:1.4rem;color:#333;cursor:pointer;transition:all .2s;font-weight:500}.time-slot:hover{background-color:#e5e7eb;border-color:#d1d5db;transform:translateY(-.2rem)}.selected-time{background-color:#b2d8db;color:#fff;border-color:#b2d8db;box-shadow:0 .2rem .5rem rgba(0,0,0,.1)}.unavailable-time{color:#9ca3af!important;cursor:not-allowed!important;opacity:.6;position:relative}.unavailable-time,.unavailable-time:hover{background-color:#f8f9fa!important;border-color:#e5e7eb!important}.unavailable-time:hover{transform:none!important;box-shadow:none!important}.unavailable-time:disabled{pointer-events:none}.unavailable-icon{position:absolute;top:.2rem;right:.2rem;font-size:1rem;opacity:.7}.time-slots-legend{display:flex;justify-content:center;gap:2rem;margin-top:1.5rem;padding:1rem;background-color:#f9fafb;border-radius:.5rem;border:1px solid #e5e7eb}.time-slots-legend .legend-item{display:flex;align-items:center;gap:.5rem;font-size:1.2rem;color:#6b7280}.time-slots-legend .legend-indicator{width:2.4rem;height:2.4rem;border-radius:.4rem;position:relative;flex-shrink:0;display:flex;align-items:center;justify-content:center}.legend-indicator.time-available{background-color:#f3f4f6;border:1px solid #d1d5db}.legend-indicator.time-unavailable{background-color:#f8f9fa;border:1px solid #e5e7eb;opacity:.6}.mini-icon{font-size:.8rem;opacity:.7}.total-duration{background-color:#f3f4f6;padding:.4rem .8rem;border-radius:.3rem;margin-left:.5rem;font-weight:500;color:#555}.booking-form-container{max-width:100%;overflow-x:hidden}.booking-form{gap:2rem}.booking-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.8rem}.form-label{font-size:1.4rem;font-weight:500;color:#555}.form-input,.form-textarea{padding:1.2rem;border:.1rem solid #ddd;border-radius:.4rem;font-size:1.6rem;width:100%;transition:all .3s}.form-input:focus,.form-textarea:focus{outline:none;border-color:#b2d8db;box-shadow:0 0 0 .2rem rgba(178,216,219,.2)}.form-textarea{resize:vertical;min-height:12rem}.input-error{border-color:#f87171}.error-message{color:#ef4444;font-size:1.2rem;margin-top:.4rem}.booking-summary-container{margin-bottom:4rem}.summary-content{background-color:#f8f9fa;border-radius:.8rem;padding:2.4rem}.summary-section{margin-bottom:2.4rem;padding-bottom:2.4rem;border-bottom:.1rem solid #e5e7eb}.summary-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.summary-heading{font-weight:500;margin-bottom:1.6rem}.treatment-item{align-items:flex-start;padding:1.5rem;margin-bottom:1rem;background-color:#f8f9fa;border-radius:.8rem;transition:all .3s;flex-wrap:wrap}.treatment-item:last-child{border-bottom:none}.treatment-details{display:flex;gap:1.6rem;color:#666;font-size:1.4rem}.treatment-totals{display:flex;flex-direction:column;gap:.8rem;margin-top:1.6rem;padding-top:1.6rem;border-top:.1rem solid #e5e7eb}.total-duration,.total-price{display:flex;justify-content:space-between;font-size:1.4rem;color:#555}.total-price{font-weight:600;font-size:1.6rem}.appointment-details,.personal-details{color:#555;font-size:1.6rem;line-height:1.6}.message-heading{font-size:1.4rem;font-weight:500;color:#333;margin:1.2rem 0 .4rem}.policy-section{background-color:#fff;padding:1.6rem;border-radius:.4rem;border-left:.4rem solid #b2d8db}.policy-info{font-size:1.4rem;color:#555;line-height:1.5}.policy-info a{color:#b2d8db;text-decoration:none;font-weight:500}.policy-info a:hover{text-decoration:underline}.booking-error{background-color:#ffebee;color:#c62828;padding:1.5rem;border-radius:.5rem;margin-top:2rem;font-size:1.5rem;text-align:center}.booking-error .mt-2{margin-top:1.5rem}.booking-error .btn-secondary{background-color:#fff;color:#c62828;border:1px solid #c62828;padding:.8rem 1.5rem;font-size:1.4rem;border-radius:.5rem;margin-top:1rem;transition:all .3s}.booking-error .btn-secondary:hover{background-color:#ffebee;transform:translateY(-2px)}.booking-confirmation-container{margin-bottom:4rem}.booking-success{padding:2rem;background-color:#f0f9f7;border-radius:1rem;border-left:5px solid #b2d8db}.success-icon{margin:0 auto 1.5rem}.booking-details{background-color:#fff;border-radius:1rem;box-shadow:0 .2rem 1rem rgba(0,0,0,.05);padding:2rem;margin-bottom:2.5rem}.booking-section-title{padding-bottom:.8rem;border-bottom:1px solid #eee}.booking-reference{font-weight:500;color:#666;background-color:#f8f9fa;padding:1rem;border-left:3px solid #b2d8db;word-wrap:break-word;overflow-wrap:break-word}.treatment-list{list-style:none;padding:0;margin:0 0 2rem}.treatment-info{flex:1;min-width:0;margin-right:1rem}.treatment-name{display:block;font-weight:500;margin-bottom:.5rem;word-wrap:break-word;overflow-wrap:break-word}.treatment-price-breakdown{min-width:15rem;padding:1rem;background-color:#f0f9f7;border-radius:.5rem;flex-shrink:0;margin-top:1rem}.price-row{margin-bottom:.8rem;font-size:1.5rem;color:#616161}.price-row.discount-value{color:#2e7d32;font-weight:600;background-color:rgba(232,245,233,.5);padding:.6rem 1rem;border-radius:.5rem;margin:1rem 0}.price-row.discount-value span:last-child{color:#2e7d32}.price-row.total{font-weight:600;font-size:1.5rem;margin-top:.5rem;padding-top:.5rem;border-top:1px dashed #ddd}.booking-summary-totals{padding:1.5rem;background-color:#f0f9f7;border-radius:.8rem;border-left:4px solid #b2d8db}.summary-row{margin-bottom:1rem}.final-price-breakdown{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #ddd}.total-price{font-size:1.7rem;margin-top:.8rem;padding-top:.8rem;border-top:1px dashed #ddd}.detail-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(20rem,1fr))}.detail-item{background-color:#f8f9fa;padding:1.2rem;border-radius:.5rem;border-left:3px solid #b2d8db}.detail-label{margin-bottom:.5rem}.booking-notes{background-color:#fff;border-radius:1rem;box-shadow:0 .2rem 1rem rgba(0,0,0,.05);margin-bottom:2.5rem;border-left:4px solid #f0c040}.note-list{list-style:none;padding:0;margin:0}.note-list li{position:relative;padding-left:2.5rem;margin-bottom:1.2rem;word-wrap:break-word;overflow-wrap:break-word}.note-list li:before{content:"•";position:absolute;left:.8rem;color:#f0c040;font-size:2rem}.note-list a{transition:all .3s}.note-list a:hover{color:#7d9799}.form-actions{display:flex;justify-content:space-between;margin-top:3rem}.btn{display:inline-block;font-size:1.6rem;font-weight:500;padding:1.2rem 2.4rem;border-radius:.5rem;text-decoration:none;text-align:center;transition:all .3s;cursor:pointer;border:none}.btn-primary{background-color:#b2d8db;color:#333}.btn-primary:hover{background-color:#7d9799;color:#fff}.btn-secondary{background-color:#f8f9fa;color:#333;border:1px solid #ddd}.btn-secondary:hover{background-color:#e9ecef}@media screen and (max-width:768px){.treatment-item{flex-direction:column}.treatment-price-breakdown{width:100%;margin-top:1.5rem;margin-left:0}.detail-group{grid-template-columns:1fr}.form-actions{flex-direction:column;gap:1rem}.btn{width:100%}.treatment-info{margin-right:0;margin-bottom:1rem;width:100%}.treatments-grid{grid-template-columns:repeat(auto-fill,minmax(22rem,1fr))}.treatment-image{height:24rem}.time-slots-grid{grid-template-columns:repeat(4,1fr)}.booking-container{padding:2rem}.heading-secondary{font-size:2.8rem}.heading-tertiary{font-size:2rem}}@media screen and (max-width:576px){.treatments-grid{grid-template-columns:1fr}.treatment-image{height:26rem}.booking-progress{padding:1rem 0}.total-duration,.total-price,.treatment-totals{flex-direction:column;align-items:flex-start;gap:.4rem}.form-actions{flex-direction:column;gap:1.2rem}.btn{width:100%}}@media (max-width:400px){.treatment-image{height:28rem}.time-slots-grid{grid-template-columns:repeat(2,1fr)}}.treatment-terms-container{max-width:100%;margin:0 auto;padding:2rem 0}.terms-content{background-color:#fff;border:1px solid #e0e0e0;border-radius:1rem;padding:2rem;margin:2rem 0;max-height:60vh;overflow-y:auto;color:#333;box-shadow:0 .2rem 1rem rgba(0,0,0,.05);font-size:1.6rem}.terms-content h4{color:#333;margin-bottom:1.5rem;font-size:2rem;font-weight:600}.terms-content p{margin-bottom:1rem;line-height:1.6;color:#555}.terms-content ul{margin-bottom:1.5rem;padding-left:1.5rem}.terms-content li{margin-bottom:.8rem;line-height:1.6;color:#555}.terms-content strong{font-weight:600;color:#333}.terms-divider{margin:3rem 0;border:none;border-top:.1rem solid #e5e7eb;position:relative}.terms-divider:before{content:"";position:absolute;top:-.5rem;left:50%;transform:translateX(-50%);width:5rem;height:.1rem;background-color:#b2d8db}.terms-form{margin-top:3rem}.checkbox-group{display:flex;align-items:flex-start;margin-bottom:1.5rem}.form-checkbox{margin-right:1rem;margin-top:.3rem;width:1.6rem;height:1.6rem;accent-color:#b2d8db}.checkbox-label{line-height:1.6;font-size:1.6rem;color:#555}.terms-hint{color:#e53e3e;margin-bottom:1.5rem;font-size:1.4rem}@media (max-width:768px){.terms-content{padding:1.5rem;max-height:50vh;font-size:1.4rem}.terms-content h4{font-size:1.8rem}.checkbox-label{font-size:1.4rem}}.loading-message{font-size:1.4rem;color:#777;margin-bottom:2rem;text-align:center}.unavailable-message{background-color:#fff3cd;color:#856404;padding:1.2rem;border-radius:.4rem;margin-bottom:2rem;font-size:1.4rem;border-left:.4rem solid #ffeeba}.no-slots-message{font-size:1.4rem;color:#777;font-style:italic;text-align:center;margin:2rem 0}.booking-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}.booking-summary-column{display:flex;flex-direction:column;gap:2rem}.booking-section-title{font-size:1.8rem;font-weight:600;color:#333;margin-bottom:1.5rem}.treatment-list{display:flex;flex-direction:column;gap:1rem}.treatment-item{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid #f0f0f0}.treatment-info{display:flex;flex-direction:column}.treatment-name{font-weight:600;font-size:1.6rem;color:#333}.treatment-duration{font-size:1.4rem;color:#666;margin-top:.5rem}.treatment-price{font-weight:600;font-size:1.6rem;color:#333}.booking-summary-totals{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.summary-row{display:flex;justify-content:space-between;font-size:1.5rem;color:#555}.discount-item{margin:1.5rem 0;background-color:#e8f5e9;border:1px solid #c8e6c9;box-shadow:0 2px 4px rgba(0,0,0,.05)}.discount-row{display:flex;justify-content:space-between;align-items:center;font-size:1.6rem;color:#2e7d32;font-weight:600}.discount-row span:last-child{font-size:1.8rem;background-color:#2e7d32;color:#fff;padding:.3rem .8rem;border-radius:.5rem}.discount-note{font-size:1.4rem;color:#2e7d32;margin-top:1rem;line-height:1.5}.discount-note strong{font-weight:700;color:#1b5e20}.discount-notice{background-color:#f1f8e9;padding:1.5rem;border-radius:.8rem;margin:1.5rem 0;border:1px solid #dcedc8;box-shadow:0 2px 4px rgba(0,0,0,.05)}.discount-notice p{font-size:1.4rem;color:#558b2f;line-height:1.5}.discount-notice .bold{font-weight:700;color:#33691e}.total-price{font-size:1.8rem}.detail-group{gap:1.5rem}.detail-group,.detail-item{display:flex;flex-direction:column}.detail-item{gap:.5rem}.detail-label{font-size:1.4rem;color:#666}.detail-value{font-size:1.6rem;font-weight:500;color:#333;word-wrap:break-word;overflow-wrap:break-word}.login-tip{background-color:#fff8e1;padding:1.5rem;border-radius:.5rem;margin-top:2rem;border:1px solid #ffe082}.login-tip p{font-size:1.4rem;color:#ff8f00}.login-tip .bold{font-weight:700}.tip-list{list-style-type:disc;padding-left:2rem;margin-top:1rem;font-size:1.3rem;color:#ff8f00}.tip-list li{margin-bottom:.5rem}.booking-success{text-align:center;margin-bottom:3rem}.success-icon{width:6rem;height:6rem;background-color:#b2d8db;color:#fff;font-size:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 2rem;box-shadow:0 .4rem .8rem rgba(0,0,0,.1)}.booking-reference{font-size:1.6rem;font-weight:600;color:#333;margin-bottom:2rem;padding:1rem 1.5rem;background-color:#f5f5f5;border-radius:.5rem;display:inline-block}.booking-details{margin-bottom:3rem}.booking-info-section{margin-bottom:2.5rem}.booking-notes{margin-bottom:3rem;padding:2rem;background-color:#f9f9f9;border-radius:.5rem;border-left:4px solid #b2d8db}@media screen and (max-width:768px){.booking-summary-grid{grid-template-columns:1fr;gap:2rem}.booking-section-title{margin-top:1rem}}.note-list{list-style-type:disc;padding-left:2rem;margin-top:1rem}.note-list li{margin-bottom:1rem;font-size:1.5rem;color:#555;line-height:1.5}.note-list a{color:#b2d8db;text-decoration:none;font-weight:500}.note-list a:hover{text-decoration:underline}.treatment-price-breakdown{display:flex;flex-direction:column;font-size:.85rem;padding:.5rem;background-color:#f9f9f9;border-radius:.25rem;margin-top:.5rem;border-left:3px solid #b2d8db}.price-row{display:flex;justify-content:space-between;margin-bottom:.25rem;padding:.25rem 0}.price-row:last-child{margin-bottom:0}.price-row.subtotal,.price-row.total{font-weight:600;border-top:1px solid #e0e0e0;padding-top:.5rem;margin-top:.25rem}.price-breakdown-section{margin:1rem 0;padding:1rem;background-color:#f9f9f9;border-radius:.5rem;border-left:3px solid #b2d8db}.price-breakdown-title{font-weight:600;margin-bottom:.75rem;color:#333;font-size:.95rem}.price-breakdown{background-color:#f5f5f5;padding:.75rem;border-radius:.25rem;margin-top:.5rem;border-left:3px solid #b2d8db;font-size:.85rem}.treatment-price-container{display:flex;align-items:center;gap:.5rem}.price-details-button{background:none;border:none;color:#b2d8db;cursor:pointer;padding:0;font-size:.75rem;line-height:1}.price-details-button:hover{color:#7d9799}.final-price-breakdown{margin-top:1rem;padding:1rem;background-color:#f5f5f5;border-radius:.5rem;border-left:3px solid #b2d8db}.total-price{font-size:1.1rem;display:flex;justify-content:space-between;padding-top:.5rem;border-top:1px solid #e0e0e0;margin-top:.5rem}.price-breakdown-summary{margin-top:1rem;padding:1rem;background-color:#f9f9f9;border-radius:.5rem;border-left:3px solid #b2d8db}.discount-item.loyalty-discount{background-color:#e8f5e9;border:2px solid #4caf50;box-shadow:0 4px 8px rgba(0,0,0,.1);animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 4px 8px rgba(0,0,0,.1)}50%{box-shadow:0 8px 16px rgba(76,175,80,.2)}to{box-shadow:0 4px 8px rgba(0,0,0,.1)}}.loyalty-discount .discount-row span:last-child{font-size:1.8rem;background-color:#4caf50;color:#fff;padding:.3rem .8rem;border-radius:.5rem;font-weight:700}.booking-history-summary{margin-top:1rem;padding:.8rem 1rem;background-color:rgba(178,216,219,.1);border-radius:.5rem;border:1px dashed #b2d8db}.booking-count{font-size:1.4rem;color:#555;text-align:center}.booking-milestone{color:#2e7d32;font-weight:600;margin-left:.5rem}.loyalty-discount{position:relative;overflow:hidden}.loyalty-discount:before{content:"";position:absolute;top:-15px;right:-15px;width:80px;height:80px;background:#2e7d32;transform:rotate(45deg);opacity:.08;z-index:0}.discount-row{position:relative;z-index:1}.price-row.discount{color:#2e7d32;font-weight:600;background-color:rgba(232,245,233,.5);padding:.6rem 1rem;border-radius:.5rem;margin:1rem 0}@keyframes loyaltyPulse{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.loyalty-discount{background:linear-gradient(-45deg,rgba(46,125,50,.05),rgba(232,245,233,.5),rgba(46,125,50,.08));background-size:400% 400%;animation:loyaltyPulse 8s ease infinite}.total-price{font-weight:700;font-size:1.8rem!important;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #ddd;color:#333}.booking-summary-content{background-color:#fff;border-radius:1rem;box-shadow:0 .2rem 1rem rgba(0,0,0,.05);padding:2rem;margin-bottom:3rem}.booking-summary-section{margin-bottom:2rem}.summary-heading{font-size:1.8rem;font-weight:600;color:#333;margin-bottom:1.5rem;padding-bottom:.8rem;border-bottom:1px solid #eee}@media screen and (max-width:768px){.booking-history-summary{padding:.6rem}.booking-count{font-size:1.3rem}.booking-milestone{display:block;margin-top:.5rem;margin-left:0}}.loyalty-status-info{margin-top:1.5rem;padding:1.5rem;background-color:#f8f9fa;border-radius:.8rem;border:1px solid #e0e0e0;box-shadow:0 2px 4px rgba(0,0,0,.05)}.booking-progress-icon{font-size:1.5rem;display:inline-block;margin-right:.5rem;vertical-align:middle}.loyalty-progress-bar{margin:1.2rem 0;height:.8rem;background-color:#f0f0f0;border-radius:1rem;overflow:hidden;position:relative}.loyalty-progress{height:100%;background:linear-gradient(90deg,#b2d8db,#7d9799);border-radius:1rem;transition:width .5s ease}.loyalty-progress-text{font-size:1.4rem;color:#555;text-align:center;margin-top:.8rem}.price-comparison{display:flex;align-items:center;gap:1rem;margin:1rem 0}.original-price{text-decoration:line-through;color:#999;font-size:1.4rem}.final-price{font-size:1.8rem;font-weight:700;color:#2e7d32}.savings-text{font-size:1.3rem;color:#2e7d32;margin-top:.5rem}.discount-item{position:relative;margin:2rem 0;padding:1.5rem;border-radius:.8rem;background-color:#f5f5f5;border-left:4px solid #b2d8db;transition:all .3s ease}.discount-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.1)}.discount-amount{position:absolute;top:-10px;right:-10px;background-color:#2e7d32;color:#fff;font-weight:700;padding:.5rem 1rem;border-radius:2rem;font-size:1.4rem;box-shadow:0 2px 4px rgba(0,0,0,.2)}@media screen and (max-width:768px){.loyalty-status-info{padding:1.2rem}.loyalty-progress-bar{margin:1rem 0}.discount-amount{font-size:1.2rem;padding:.4rem .8rem}}.loyalty-status-container{background-color:#f8f8f8;border-radius:8px;padding:20px;margin:20px 0;box-shadow:0 2px 8px rgba(0,0,0,.05)}.loyalty-heading{color:#333;font-size:1.2rem;margin-bottom:15px}.loyalty-progress-container{margin:20px 0}.loyalty-progress-bar-container{background-color:#e0e0e0;height:10px;border-radius:5px;position:relative;margin-bottom:10px}.loyalty-progress-bar{background:linear-gradient(90deg,#4a90e2,#8457c7);height:100%;border-radius:5px;transition:width .5s ease-in-out}.loyalty-progress-steps{display:flex;justify-content:space-between;margin-top:5px}.loyalty-step{width:24px;height:24px;border-radius:50%;background-color:#e0e0e0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#333}.loyalty-step.completed{background-color:#4a90e2;color:#fff}.loyalty-message{font-size:1rem;margin:15px 0;line-height:1.4}.loyalty-eligible{display:flex;align-items:center;color:#2ecc71;font-weight:700}.loyalty-badge{display:inline-block;background-color:#2ecc71;color:#fff;padding:4px 8px;border-radius:4px;margin-right:10px;font-weight:700}.loyalty-details{font-size:.9rem;color:#666;border-top:1px solid #e0e0e0;padding-top:10px;margin-top:10px}.loyalty-status-container.error,.loyalty-status-container.loading{text-align:center;color:#666;padding:30px}.loyalty-status-container.error{color:#e74c3c}@media (max-width:768px){.loyalty-status-container{padding:15px}.loyalty-heading{font-size:1.1rem}}.login-required-container{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:2rem;background-color:#f8f9fa}.login-required-content{max-width:500px;width:100%;text-align:center;background-color:#fff;padding:3rem;border-radius:1rem;box-shadow:0 4px 6px rgba(0,0,0,.1)}.login-required-icon{margin-bottom:2rem}.login-required-title{font-size:2rem;font-weight:700;color:#2d3748;margin-bottom:1rem}.login-required-text{font-size:1.1rem;color:#4a5568;margin-bottom:2rem;line-height:1.6}.login-required-buttons{display:flex;gap:1rem;justify-content:center}.btn--primary{display:inline-block;padding:.75rem 2rem;background-color:#b2d8db;color:#2d3748;font-weight:600;border-radius:.5rem;transition:background-color .2s}.btn--primary:hover{background-color:#9ecacd}.btn--secondary{display:inline-block;padding:.75rem 2rem;background-color:#fff;color:#2d3748;font-weight:600;border:2px solid #b2d8db;border-radius:.5rem;transition:all .2s}.btn--secondary:hover{background-color:#f8f9fa;border-color:#9ecacd}