.reservation-page .treatment-card{background:rgba(15,19,51,.95);border:1px solid rgba(59,130,246,.2);border-radius:.75rem;padding:1.5rem;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.reservation-page .treatment-card:hover{border-color:rgba(59,130,246,.5);background:#0f1333;box-shadow:0 8px 32px rgba(59,130,246,.2)}.reservation-page .treatment-card.selected{border-color:#3b82f6;background:rgba(59,130,246,.1);box-shadow:0 8px 32px rgba(59,130,246,.3)}.reservation-page .treatment-card-title{font-size:1.125rem;font-weight:600;color:#fff;margin-bottom:.5rem}.reservation-page .treatment-card-description{font-size:.875rem;color:hsla(0,0%,100%,.7);margin-bottom:1rem}.reservation-page .treatment-card-duration{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:hsla(0,0%,100%,.1);backdrop-filter:blur(12px);border:1px solid hsla(0,0%,100%,.2);border-radius:.5rem;font-size:.875rem;color:#fff}.reservation-page .treatment-card-time-info{margin-top:1rem;padding:.75rem;background:rgba(59,130,246,.05);border:1px solid rgba(59,130,246,.2);border-radius:.75rem}.time-details{display:flex;flex-direction:column;gap:.25rem}@media (max-width:768px){.time-details{gap:.125rem}.reservation-page .treatment-card-time-info{padding:.5rem;margin-top:.5rem}.actual-time,.appointment-time{margin:0;padding:0}}.actual-time,.appointment-time{display:flex;justify-content:space-between;align-items:center}.time-label{font-size:.8125rem;color:hsla(0,0%,100%,.6);font-weight:400}.time-value{font-size:.875rem;color:hsla(0,0%,100%,.9);font-weight:500}.time-value-highlight{font-size:1rem;color:#60a5fa;font-weight:600;padding:.125rem .5rem;background:rgba(59,130,246,.1);border-radius:.375rem}.date-picker-container{background:rgba(15,19,51,.95);border:1px solid rgba(59,130,246,.2);border-radius:.75rem;padding:1.5rem}.date-picker-title{font-size:1rem;font-weight:600;color:#fff;margin-bottom:1rem}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.calendar-nav-button{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.3);color:#60a5fa;padding:.5rem;border-radius:.375rem;cursor:pointer;transition:all .3s ease}.calendar-nav-button:hover:not(:disabled){background:rgba(59,130,246,.2);border-color:rgba(59,130,246,.5)}.calendar-nav-button:disabled{opacity:.3;cursor:not-allowed}.calendar-month-year{font-weight:600;color:#fff;font-size:1.125rem}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem;margin-bottom:.5rem}.calendar-weekday{text-align:center;font-size:.75rem;font-weight:600;color:hsla(0,0%,100%,.5);padding:.5rem}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:.375rem;cursor:pointer;transition:all .3s ease;background:hsla(0,0%,100%,.02);border:1px solid transparent;color:hsla(0,0%,100%,.8)}.calendar-day:hover:not(.disabled):not(.selected){background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.3);color:#fff}.calendar-day.selected{background:linear-gradient(135deg,#3b82f6,#60a5fa);color:#fff;font-weight:600;box-shadow:0 4px 20px rgba(59,130,246,.3)}.calendar-day.disabled{cursor:not-allowed;background:transparent}.calendar-day.disabled,.calendar-day.other-month{color:hsla(0,0%,100%,.2)}.calendar-day.today{border-color:rgba(59,130,246,.5);font-weight:600}.time-slots-container{background:rgba(15,19,51,.95);border:1px solid rgba(59,130,246,.2);border-radius:.75rem;padding:1.5rem}.time-slots-title{font-size:1rem;font-weight:600;color:#fff;margin-bottom:1rem}.time-slots-loading{text-align:center;color:hsla(0,0%,100%,.7);padding:2rem}.time-slots-empty{text-align:center;color:hsla(0,0%,100%,.5);padding:2rem}.time-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.time-slot{padding:.75rem;text-align:center;border-radius:.5rem;cursor:pointer;transition:all .3s ease;background:hsla(0,0%,100%,.02);border:1px solid rgba(59,130,246,.2);color:hsla(0,0%,100%,.8);font-weight:500}.time-slot:hover:not(.unavailable):not(.selected){background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.4);color:#fff}.time-slot.selected{background:linear-gradient(135deg,#3b82f6,#60a5fa);border-color:transparent;color:#fff;font-weight:600;box-shadow:0 4px 20px rgba(59,130,246,.3)}.time-slot.unavailable{background:hsla(0,0%,100%,.02);border-color:hsla(0,0%,100%,.1);color:hsla(0,0%,100%,.3);cursor:not-allowed;text-decoration:line-through}.customer-form{background:rgba(15,19,51,.95);border:1px solid rgba(59,130,246,.2);border-radius:.75rem;padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:#fff;margin-bottom:.5rem}.form-label-required{color:#f87171;margin-left:.25rem}.form-input{width:100%;padding:.75rem;background:hsla(0,0%,100%,.05);border:1px solid rgba(59,130,246,.2);border-radius:.5rem;color:#fff;transition:all .3s ease}.form-input:focus{outline:none;border-color:rgba(59,130,246,.5);background:hsla(0,0%,100%,.08);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.form-input::-moz-placeholder{color:hsla(0,0%,100%,.4)}.form-input::placeholder{color:hsla(0,0%,100%,.4)}.form-error{margin-top:.25rem;font-size:.875rem;color:#f87171}.form-submit-button{width:100%;padding:.75rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#60a5fa);color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px rgba(59,130,246,.3)}.form-submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 30px rgba(59,130,246,.4)}.form-submit-button:disabled{opacity:.5;cursor:not-allowed;transform:none}@keyframes spin{to{transform:rotate(1turn)}}.loading-spinner{display:inline-block;width:1.25rem;height:1.25rem;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.reservation-page{min-height:100vh;background:linear-gradient(180deg,#0a0e27,#0f1333)}.reservation-header{background:rgba(15,19,51,.95);backdrop-filter:blur(12px);border-bottom:1px solid rgba(59,130,246,.1)}.reservation-title{color:#fff;font-size:1.875rem;font-weight:700}@media (max-width:640px){.reservation-header .max-w-6xl{padding:.75rem 1rem}.reservation-title{font-size:1.25rem}}.progress-indicator{margin-bottom:2rem}.progress-circle,.progress-step{display:flex;align-items:center}.progress-circle{width:2.5rem;height:2.5rem;border-radius:50%;justify-content:center;font-weight:600;transition:all .3s ease}.progress-circle.active{background:linear-gradient(135deg,#3b82f6,#60a5fa);color:#fff;box-shadow:0 4px 20px rgba(59,130,246,.3)}.progress-circle.inactive{background:hsla(0,0%,100%,.05);color:hsla(0,0%,100%,.3);border:1px solid hsla(0,0%,100%,.1)}.progress-line{width:5rem;height:2px;margin-left:.5rem;transition:all .3s ease}.progress-line.active{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.progress-line.inactive{background:hsla(0,0%,100%,.1)}.progress-labels{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;max-width:32rem;margin:1rem auto 0}.progress-label{text-align:center;font-size:.875rem;transition:color .3s ease}.progress-label.active{color:#fff;font-weight:600}.progress-label.inactive{color:hsla(0,0%,100%,.5)}.error-message{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:.5rem;padding:1rem;color:#f87171;margin-bottom:1.5rem}.reservation-page .section-title{font-size:1.25rem;font-weight:600;color:#fff;margin-bottom:1.5rem}.reservation-page .treatment-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.reservation-page .treatment-card-wrapper{cursor:pointer;transition:transform .3s ease}.reservation-page .treatment-card-wrapper:hover{transform:translateY(-4px)}.reservation-page .back-button{color:#60a5fa;font-weight:500;margin-bottom:1rem;display:inline-flex;align-items:center;transition:color .3s ease;background:none;border:none;cursor:pointer;font-size:1rem}.reservation-page .back-button:hover{color:#93bbfc}.reservation-page .treatment-info{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.3);border-radius:.75rem;padding:1rem;margin-bottom:1.5rem}.reservation-page .treatment-info-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid rgba(59,130,246,.2)}.reservation-page .treatment-time-details{display:flex;gap:2rem;flex-wrap:wrap}@media (max-width:768px){.reservation-page .treatment-time-details{flex-direction:column;gap:.25rem}}.reservation-page .time-detail-item{display:flex;align-items:center;gap:.5rem}.reservation-page .time-detail-label{font-size:.875rem;color:hsla(0,0%,100%,.6)}.reservation-page .time-detail-value{font-size:.875rem;color:hsla(0,0%,100%,.9);font-weight:500}.reservation-page .time-detail-value-highlight{font-size:1rem;color:#60a5fa;font-weight:600;padding:.125rem .5rem;background:rgba(59,130,246,.15);border-radius:.375rem}.reservation-page .info-label{font-weight:600;color:#fff}.reservation-page .info-value{color:hsla(0,0%,100%,.8);margin-left:.5rem}.reservation-page .datetime-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media (min-width:1024px){.reservation-page .datetime-grid{grid-template-columns:1fr 1fr}}.reservation-page .customer-form-container{max-width:32rem;margin:0 auto}.reservation-page .summary-box{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.3);border-radius:.5rem;padding:1rem;margin-bottom:1.5rem}.reservation-page .summary-title{font-weight:600;color:#fff;margin-bottom:.5rem}.reservation-page .summary-item{font-size:.875rem;color:hsla(0,0%,100%,.8);margin-bottom:.25rem}.reservation-page .summary-label{font-weight:600;color:#fff}.success-container{max-width:32rem;margin:0 auto;text-align:center}.success-box{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);border-radius:.5rem;padding:2rem}.success-icon{width:4rem;height:4rem;margin:0 auto 1rem;color:#4ade80}.success-title{font-size:1.5rem;font-weight:700;color:#4ade80;margin-bottom:.5rem}.email-reminder{background:rgba(251,191,36,.1);border:2px solid rgba(251,191,36,.3);border-radius:.75rem;padding:1rem;margin-bottom:1.5rem}.email-reminder-text{font-size:1.125rem;font-weight:600;color:#fbbf24;display:flex;align-items:center;justify-content:center}.warning-icon{width:1.5rem;height:1.5rem;margin-right:.5rem;flex-shrink:0}.btn-primary{background:linear-gradient(135deg,#3b82f6,#60a5fa);color:#fff;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;border:none;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px rgba(59,130,246,.3)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 30px rgba(59,130,246,.4)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.nav-cta-retour{padding:.75rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:50px;font-weight:600;transition:all .3s ease;box-shadow:0 10px 30px rgba(102,126,234,.3);border:none;cursor:pointer;font-size:.875rem;display:inline-flex;align-items:center;gap:.5rem;white-space:nowrap}.nav-cta-retour:hover{transform:translateY(-2px);box-shadow:0 15px 40px rgba(102,126,234,.4)}@media (max-width:640px){.nav-cta-retour{padding:.5rem 1rem;font-size:.8125rem;gap:.25rem}}.reservation-content{max-width:72rem;margin:0 auto;padding:2rem 1rem}