﻿.calendar-grid{display:grid;grid-template-columns:auto repeat(7, 1fr) auto;gap:.5rem;align-items:start}@media(max-width: 576px){.calendar-grid{gap:.25rem}}.calendar-grid .nav-button-wrapper{display:flex;align-items:center;justify-content:center}.calendar-grid .nav-button-wrapper .nav-button{font-size:1.5rem;cursor:pointer;color:var(--primary-color);background:none;border:none;padding:.25rem .5rem;border-radius:50%}.calendar-grid .nav-button-wrapper .nav-button:disabled{color:var(--text-light, #6b7280);cursor:default}.calendar-grid .day-label{display:flex;flex-direction:column;align-items:center;border-radius:10px;padding:.6rem;text-align:center;height:100%}@media(max-width: 576px){.calendar-grid .day-label{padding:.4rem .25rem}}.calendar-grid .day-label strong{font-size:.85rem;font-weight:500;color:var(--text-strong, #555)}@media(max-width: 576px){.calendar-grid .day-label strong{font-size:.75rem}}.calendar-grid .day-label span{font-size:.75rem;color:var(--text-strong, #555)}@media(max-width: 576px){.calendar-grid .day-label span{font-size:.65rem}}.calendar-grid .day-label.selected-day{background-color:var(--primary-color)}.calendar-grid .day-label.selected-day strong,.calendar-grid .day-label.selected-day span{color:var(--text-white, #ffffff)}.calendar-grid .time-slot{background-color:var(--bg-white, #ffffff);border:1px solid var(--border-color, #dee2e6);border-radius:10px;padding:.6rem;text-align:center;cursor:pointer;font-size:.85rem;font-weight:500}@media(max-width: 576px){.calendar-grid .time-slot{padding:.4rem .25rem;font-size:.75rem;border-radius:8px}}.calendar-grid .time-slot:hover{background-color:rgba(var(--primary-color-light-20-rgb), 0.1);box-shadow:0 0 0 2px var(--primary-color)}.calendar-grid .time-slot:focus-visible{outline:none;background-color:rgba(var(--primary-color-light-20-rgb), 0.1);box-shadow:0 0 0 2px var(--primary-color)}.calendar-grid .time-slot.selected-time-slot{background-color:var(--primary-color);color:var(--text-white, #ffffff);border-color:var(--primary-color)}.calendar-grid .empty-cell{visibility:hidden}.no-slots-message{border:1px solid var(--border-color, #dee2e6);border-radius:10px;padding:20px;color:var(--text-strong, #555);user-select:none}@media(max-width: 576px){.no-slots-message{padding:12px}}.no-slots-message p{font-size:1.2rem;margin-bottom:1rem;font-weight:500}@media(max-width: 576px){.no-slots-message p{font-size:1rem;margin-bottom:.75rem}}.no-slots-message strong{display:block;margin-bottom:.75rem;font-size:1.1rem;color:var(--text-strong, #555)}@media(max-width: 576px){.no-slots-message strong{font-size:.95rem}}.no-slots-message .alternative-employees{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;margin-top:10px}.no-slots-message .employee-card{background:var(--bg-white, #ffffff);border:1px solid var(--border-color, #dee2e6);border-radius:8px;padding:10px 15px;cursor:pointer;display:flex;align-items:center;gap:10px;min-width:120px;box-shadow:0 2px 5px rgba(0,0,0,.1);transition:border-color .2s ease}.no-slots-message .employee-card:hover,.no-slots-message .employee-card:focus{border-color:var(--primary-color);outline:none}.no-slots-message .employee-card .employee-avatar{position:relative;width:36px;height:36px;border-radius:50%;overflow:hidden;font-weight:bold;font-size:1.25rem;display:flex;justify-content:center;align-items:center;user-select:none}.no-slots-message .employee-card .employee-avatar i{font-size:20px}.no-slots-message .employee-card .avatar-placeholder{width:100%;height:100%;background:linear-gradient(90deg, #f5f5f5 25%, #e0e0e0 50%, #f5f5f5 75%);background-size:200% 100%;animation:shimmer 1.2s infinite;border-radius:50%}.no-slots-message .employee-card .avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.no-slots-message .employee-card .employee-name{font-size:1rem;font-weight:500;color:#333;user-select:none}@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}.selected-employee-info{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-radius:0;box-shadow:none}.selected-employee-info .employee-avatar{position:relative;width:40px;height:40px;border-radius:50%;overflow:hidden;background-color:rgba(0,0,0,0);color:var(--text-dark, #222831);font-weight:500;font-size:1.25rem;display:flex;justify-content:center;align-items:center;user-select:none;flex-shrink:0}.selected-employee-info .employee-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.selected-employee-info .employee-avatar .avatar-placeholder{width:100%;height:100%;background:linear-gradient(90deg, #e0e0e0 25%, #c7c7c7 50%, #e0e0e0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:50%;position:absolute;top:0;left:0;z-index:1}.selected-employee-info .employee-name{font-size:1.1rem;font-weight:500;color:var(--text-dark, #222831);user-select:none;white-space:nowrap}.login-page,.register-page{display:flex;align-items:center;flex-grow:1;background-color:var(--bg-light, #f9fafb)}.login-container,.register-container{background:var(--bg-white, #ffffff);padding:2rem;border-radius:.5rem;box-shadow:0 4px 6px rgba(0,0,0,.1);max-width:640px;width:100%;text-align:center;display:flex;flex-direction:column;justify-content:center;position:relative}.login-container a,.register-container a{color:var(--primary-color);text-decoration:none}.login-container a:hover,.register-container a:hover{text-decoration:underline}.login-container a:focus-visible,.register-container a:focus-visible{text-decoration:underline;outline:none}@media(max-width: 600px){.login-container,.register-container{padding:1.2rem}}.login-container .header-img,.register-container .header-img{display:block;object-fit:cover;border-radius:.5rem;width:120px;height:120px}@media(max-width: 600px){.login-container .header-img,.register-container .header-img{width:100px;height:100px}}.login-form,.register-form,.set-password-form,.resend-password-form{text-align:start}.login-form .options-wrapper,.register-form .options-wrapper,.set-password-form .options-wrapper,.resend-password-form .options-wrapper{display:flex;justify-content:space-between;align-items:center}.login-form .options-wrapper a:hover,.register-form .options-wrapper a:hover,.set-password-form .options-wrapper a:hover,.resend-password-form .options-wrapper a:hover{text-decoration:underline;cursor:pointer}.login-form .options-wrapper .option-item,.register-form .options-wrapper .option-item,.set-password-form .options-wrapper .option-item,.resend-password-form .options-wrapper .option-item{display:flex;align-items:center;font-size:.9rem;color:var(--text-color, #333)}@media(max-width: 600px){.login-form .options-wrapper,.register-form .options-wrapper,.set-password-form .options-wrapper,.resend-password-form .options-wrapper{flex-direction:column;align-items:flex-start}.login-form .options-wrapper .option-item,.register-form .options-wrapper .option-item,.set-password-form .options-wrapper .option-item,.resend-password-form .options-wrapper .option-item{display:flex;align-items:center;margin-bottom:.3rem}.login-form .options-wrapper .forgot-password-link,.register-form .options-wrapper .forgot-password-link,.set-password-form .options-wrapper .forgot-password-link,.resend-password-form .options-wrapper .forgot-password-link{margin-top:.5rem}}.login-form .forgot-password-link,.register-form .forgot-password-link,.set-password-form .forgot-password-link,.resend-password-form .forgot-password-link{font-size:.9rem}.submit-button{display:block;width:100%;padding:.75rem;background-color:var(--primary-color);color:var(--text-white, #ffffff);border:none;border-radius:.5rem;font-size:1rem;cursor:pointer;transition:background-color .3s ease}.submit-button:hover{background-color:var(--primary-color-light-10)}.submit-button:focus{box-shadow:0 0 0 .25rem var(--primary-color-light-40);outline:none}@media(max-width: 600px){.submit-button{font-size:.9rem}}.register-section,.login-section,.reset-password-section{margin-top:1.5rem;font-size:.9rem}.register-link a:hover,.login-link a:hover{text-decoration:underline;cursor:pointer}.option-item{display:flex;align-items:center;gap:.5rem}.option-label{font-size:.875rem;color:var(--secondary-color, #4b5563);cursor:pointer}.back-to-login{color:var(--primary-color);text-decoration:none;cursor:pointer}.back-to-login i{text-decoration:none}.back-to-login:hover span{text-decoration:underline}.auth-header .header-img{display:block;object-fit:cover;border-radius:.5rem;width:100px;height:100px}@media(max-width: 600px){.auth-header .header-img{width:80px;height:80px}}.appointment-booking-stepper{display:flex;position:relative;flex-direction:column;min-height:0;max-width:992px;width:100%}.appointment-booking-stepper .btn-primary,.appointment-booking-stepper .btn-secondary{display:flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap;border-radius:.375rem;font-size:.875rem;font-weight:500;height:2.5rem;padding:.5rem 1rem;transition:color .2s,background-color .2s,border-color .2s}@media(max-width: 576px){.appointment-booking-stepper .btn-primary,.appointment-booking-stepper .btn-secondary{height:2.25rem;padding:.375rem .75rem}}.appointment-booking-stepper .btn-primary:disabled,.appointment-booking-stepper .btn-secondary:disabled{opacity:.5;pointer-events:none}.appointment-booking-stepper .btn-primary:focus-visible,.appointment-booking-stepper .btn-secondary:focus-visible{outline:none;box-shadow:0 0 0 2px rgba(var(--primary-color-rgb), 0.25);outline-offset:2px}.appointment-booking-stepper .btn-secondary{border:1px solid #d1d5db;background-color:var(--background, #fff);color:inherit}.appointment-booking-stepper .btn-secondary:hover:not(:disabled){border-color:#9ca3af;background-color:var(--accent, #f8f9fa);color:var(--accent-foreground, #212529)}.button-container{display:flex;justify-content:center;margin-top:2rem;padding-left:1rem;padding-right:1rem}.button-container .btn{max-width:300px;width:100%}@media(max-width: 768px){.button-container{margin-top:0;position:fixed;bottom:0;left:0;width:100%;background-color:var(--bg-white, #ffffff);padding:1rem;z-index:1}}.stepper-container{-webkit-overflow-scrolling:touch;gap:.5rem}.step-wrapper{min-width:4rem;text-align:center}.step-circle{width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:500;transition:background-color .3s ease;background-color:var(--bg-gray, #e5e7eb);color:var(--secondary-color, #4b5563);flex-shrink:0}.step-circle .step-number{line-height:1}.step-circle.active,.step-circle.done{background-color:var(--primary-color);color:#fff}.step-label{margin-top:.5rem;font-size:.875rem;color:var(--secondary-color, #4b5563);text-align:center;word-wrap:break-word;white-space:normal;max-width:100%}@media(max-width: 576px){.step-label{font-size:.65rem}.step-circle{width:2.2rem;height:2.2rem;font-size:.75rem}.step-wrapper{min-width:3.5rem}}.booking-step{display:flex;flex-direction:column;height:100%}.booking-step .booking-step-header-container{padding-top:2rem}.booking-step .booking-step-header-container .step-header{margin-bottom:2rem}@media(max-width: 576px){.booking-step .booking-step-header-container{padding-top:1rem}.booking-step .booking-step-header-container .step-header{margin-bottom:1rem}}.booking-step .step-body{flex:1 1 auto;scrollbar-gutter:stable;min-height:300px}.booking-step .step-title{font-size:1.6rem}@media(max-width: 576px){.booking-step .step-title{font-size:1.25rem}}.appointment-card{box-shadow:0 2px 6px rgba(0,0,0,.08);transition:all .2s ease-in-out}@media(hover: hover){.appointment-card:hover{box-shadow:0 8px 16px rgba(100,150,250,.15);transform:translateY(-2px)}}.btn-outline-secondary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem;height:2.25rem;font-size:.875rem;font-weight:500;white-space:nowrap;background-color:var(--bg-white, #ffffff);color:inherit;border:1px solid #d1d5db;flex:1;transition:color .2s,background-color .2s,border-color .2s}.btn-outline-secondary:hover{border-color:#9ca3af;background-color:var(--accent, #f8f9fa);color:var(--accent-foreground, #212529)}.btn-outline-secondary:focus-visible{outline:none;box-shadow:0 0 0 2px var(--text-light, #6b7280);outline-offset:2px;background-color:var(--accent, #f8f9fa) !important}.btn-outline-secondary:disabled{opacity:.5;pointer-events:none}.btn-outline-danger{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem;height:2.25rem;font-size:.875rem;font-weight:500;white-space:nowrap;background-color:var(--background, #fff);color:#dc2626;border:1px solid #fecaca;border-radius:.375rem;transition:color .2s,background-color .2s,border-color .2s}.btn-outline-danger:hover{color:#b91c1c;background-color:#fef2f2;border-color:#fca5a5}.btn-outline-danger:focus-visible{outline:none;box-shadow:0 0 0 2px var(--ring, #ef4444);outline-offset:2px}.btn-outline-danger:disabled{opacity:.5;pointer-events:none}.option-card{cursor:pointer;transition:all 150ms ease-in-out;outline:2px solid rgba(0,0,0,0);outline-offset:1px;border-radius:1rem;padding:.5rem;position:relative}.option-card.selected{box-shadow:0 0 0 2px var(--primary-color)}.option-card.selected .selection-indicator{border-color:var(--primary-color) !important;background-color:var(--primary-color);color:#fff}.option-card .option-title{font-size:1rem;font-weight:600;line-height:1.25}.option-card .option-description{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;text-overflow:ellipsis}.option-card__image-container{width:6rem;height:6rem;flex-shrink:0;border-radius:.5rem;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 0 5px rgba(0,0,0,.2);background-color:var(--bg-gray, #e5e7eb)}.option-card__image-container .option-card-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain}.option-card__image-container .option-icon{font-size:3rem}@media screen and (max-width: 400px){.option-card__image-container{width:5rem;height:5rem}}.option-card__content{flex:1;display:flex;flex-direction:column;padding:.25rem 0;min-width:0}.option-card__content-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.option-card__content-header h3{font-size:1.125rem;font-weight:bold;line-height:1.25rem;padding-right:2rem;margin:0}@media screen and (max-width: 400px){.option-card__content-header h3{font-size:.875rem;line-height:1rem}}@media screen and (max-width: 500px){.option-card__content-header h3{font-size:1rem}}.option-card p{font-size:.875rem;margin-top:.25rem;margin-bottom:auto;padding-right:.25rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.option-card__footer{flex:1 1 auto;display:flex;justify-content:flex-end;align-items:flex-end;margin-top:.25rem;gap:.5rem}.option-card__footer__tags{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.option-card__footer__tags span{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:.375rem;font-size:.6875rem;background-color:rgba(var(--primary-color-light-20-rgb), 0.5);color:var(--primary-color);font-weight:bold;text-transform:uppercase;letter-spacing:.05em}.option-card__footer .option-card__footer__price{font-size:1rem;font-weight:600}@media screen and (max-width: 400px){.option-card__footer .option-card__footer__price{font-size:.875rem}}.selection-indicator{position:absolute;top:.75rem;right:.75rem;flex-shrink:0;display:flex;justify-content:center;align-items:center;height:1.25rem;width:1.25rem;transition:all 150ms cubic-bezier(0.4, 0, 0.2, 1)}.selection-indicator.square{border-radius:.25rem}.selection-indicator.circle{border-radius:50%}.badge-status{font-weight:500;font-size:.75rem;padding-top:.375rem;padding-bottom:.375rem}.badge-status.completed{background-color:#dbeafe;color:#1e40af}.badge-status.pending{background-color:#fef3c7;color:#92400e}.badge-status.cancelled{background-color:#fee2e2;color:#b91c1c}.my-appointment-card{box-shadow:0 2px 6px rgba(0,0,0,.08)}@media(max-width: 576px){.appointment-buttons-container{width:100%}}.nav-link{display:flex;align-items:center;color:var(--secondary-color, #4b5563);transition:color .3s ease;padding:.5rem .75rem;height:2.25rem;border-radius:.375rem}.nav-link:hover{color:var(--text-dark, #222831)}.nav-link:focus-visible{outline:none;box-shadow:0 0 0 2px var(--primary-color-light-20);outline-offset:2px}.main-nav{border-bottom:2px solid var(--border-color, #dee2e6)}.main-nav a:has(.logo-container):focus-visible{outline:none;box-shadow:none}.main-nav a:has(.logo-container):focus-visible .logo-container+span{outline:none;box-shadow:0 0 0 2px var(--primary-color-light-20);outline-offset:2px}.custom-nav-link{color:var(--secondary-color, #4b5563);transition:color .3s ease,background-color .3s ease;text-decoration:none}.custom-nav-link:hover,.custom-nav-link:focus{color:var(--text-dark, #222831);background-color:var(--bg-light, #f9fafb)}.btn-ghost-custom{background-color:rgba(0,0,0,0);border:none;color:var(--secondary-color, #4b5563);font-size:.875rem;display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:.375rem;width:100%;transition:background-color .3s ease,color .3s ease}.btn-ghost-custom:hover,.btn-ghost-custom:focus{background-color:#e0e7ff;color:var(--primary-color);outline:none}.btn-ghost-custom:disabled{pointer-events:none;opacity:.5}.btn-ghost-sm{display:flex;align-items:center;gap:.5rem;color:var(--secondary-color, #4b5563);background:rgba(0,0,0,0);border:none;padding:.25rem .5rem;cursor:pointer;transition:color .3s ease}.btn-ghost-sm:hover{color:var(--text-dark, #222831)}.logout-button,.login-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem;height:2.25rem;white-space:nowrap;color:var(--secondary-color, #4b5563);background:rgba(0,0,0,0);border:none;border-radius:.375rem;transition:color .2s,background-color .2s}.logout-button:hover,.login-button:hover{background-color:var(--accent, #f3f4f6);color:var(--text-dark, #222831)}.logout-button:focus-visible,.login-button:focus-visible{outline:none;box-shadow:0 0 0 2px var(--primary-color-light-20);outline-offset:2px}.logout-button:disabled,.login-button:disabled{opacity:.5;pointer-events:none}.burger{position:relative;width:28px;height:22px;background:rgba(0,0,0,0);cursor:pointer;display:block}.burger input{display:none}.burger span{display:block;position:absolute;height:3px;width:100%;background:#000;border-radius:6px;opacity:1;left:0;transform:rotate(0deg);transition:.25s ease-in-out}.burger span:nth-of-type(1){top:0;transform-origin:left center}.burger span:nth-of-type(2){top:50%;transform:translateY(-50%);transform-origin:left center}.burger span:nth-of-type(3){top:100%;transform:translateY(-100%);transform-origin:left center}.burger input:checked~span:nth-of-type(1){transform:rotate(45deg);top:0;left:3.5px}.burger input:checked~span:nth-of-type(2){width:0;opacity:0}.burger input:checked~span:nth-of-type(3){transform:rotate(-45deg);top:20px;left:3.5px}.logo-container{width:40px;height:40px;overflow:hidden;display:flex;align-items:center;justify-content:center}.primary-footer{background-color:var(--bg-dark, #1f2937);color:var(--text-white, #ffffff)}.primary-footer .footer-title{font-size:1rem;font-weight:500}.primary-footer .footer-text{font-size:.8125rem;line-height:1.3;color:var(--text-lighter, #9ca3af);margin-bottom:.125rem}.primary-footer .footer-links li{margin-bottom:.125rem}.primary-footer .footer-links li a{display:inline-block;font-size:.8125rem;color:var(--text-lighter, #9ca3af);text-decoration:none;transition:color .3s}.primary-footer .footer-links li a:hover{color:var(--text-white, #ffffff);text-decoration:underline;cursor:pointer}.primary-footer .footer-links-mobile{display:flex;flex-wrap:wrap;justify-content:center;column-gap:.5rem;row-gap:.25rem;margin-bottom:.5rem}.primary-footer .footer-links-mobile li a{font-size:.8125rem;color:var(--text-lighter, #9ca3af);text-decoration:none;transition:color .3s}.primary-footer .footer-links-mobile li a:hover{color:var(--text-white, #ffffff);text-decoration:underline;cursor:pointer}.primary-footer .footer-links-mobile li:not(:last-child)::after{content:"·";color:var(--text-lighter, #9ca3af);margin-left:.5rem}.primary-footer .footer-contact-mobile{text-align:center;margin-top:.25rem}.primary-footer .footer-contact-mobile .footer-contact-icons{display:flex;justify-content:center;gap:1rem;margin-top:.375rem}.primary-footer .footer-contact-mobile .footer-contact-icons a{color:var(--text-lighter, #9ca3af);font-size:1.125rem;transition:color .3s}.primary-footer .footer-contact-mobile .footer-contact-icons a:hover{color:var(--text-white, #ffffff)}.primary-footer a{color:inherit;text-decoration:none}.primary-footer a:hover{color:var(--text-white, #ffffff)}.primary-footer .text-muted{color:var(--text-lighter, #9ca3af) !important}.secondary-footer{background-color:var(--bg-dark, #1f2937);color:var(--text-lighter, #9ca3af);text-align:center}.secondary-footer a{font-size:.875rem;color:var(--text-lighter, #9ca3af);text-decoration:none;transition:color .3s}.secondary-footer a:hover{color:var(--text-white, #ffffff)}.secondary-footer .text-muted{color:var(--text-lighter, #9ca3af) !important}.secondary-footer .footer-links{display:flex;justify-content:center;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.secondary-footer .footer-links a{display:inline-block}.service-selection{display:flex;flex-direction:column}.service-selection__grid{display:grid;grid-template-columns:1fr 300px;grid-gap:1rem}@media(max-width: 992px){.service-selection__grid{grid-template-columns:1fr}}.service-selection__mobile-cart .next-step-button{display:none;margin-top:.5rem;z-index:1}@media(max-width: 768px){.service-selection__mobile-cart .next-step-button{display:block;position:fixed;left:0;bottom:0;width:100%;background:var(--bg-white, #ffffff);padding:1rem}.service-selection__mobile-cart .next-step-button .btn{padding:0 1rem}}@media(max-width: 768px){.service-selection__mobile-cart .mobile-cart-button{bottom:5.5rem}}.service-selection__categories-service-container{display:flex;flex-direction:column;flex-grow:1}.service-selection__categories{display:grid;grid-template-columns:repeat(auto-fill, minmax(min(240px, 100%), 1fr));grid-gap:1rem;justify-content:start;width:100%}.service-selection__categories-title{font-size:1.25rem;font-weight:600;margin-bottom:.75rem;color:#222;border-bottom:2px solid var(--primary-color);padding-bottom:.25rem;width:fit-content}.service-selection__services{display:grid;grid-template-columns:repeat(auto-fill, minmax(min(240px, 100%), 1fr));gap:1rem;width:100%}.service-selection__cart{width:100%}.service-cart{width:100%}.category-card{padding:.8rem 1rem;border:1px solid var(--border-color, #dee2e6);box-shadow:0 1px 2px rgba(0,0,0,.05);cursor:pointer;transition:all .2s ease}.category-card:hover,.category-card:focus{box-shadow:0 4px 6px rgba(0,0,0,.1)}.category-card:focus-visible{outline:none;box-shadow:0 0 0 2px var(--primary-color-light-20);outline-offset:2px}.category-card .category-icon{font-size:1.25rem;color:var(--text-light, #6b7280);flex-shrink:0;transition:color .2s ease}.category-card .category-title{font-weight:500;font-size:.875rem;word-break:break-word;overflow-wrap:break-word;hyphens:auto;color:var(--text-dark, #222831);margin:0}.category-card .category-content{display:flex;gap:.5rem;align-items:center;font-size:.875rem;color:var(--text-light, #6b7280);margin-top:.25rem;line-height:1.5}.sticky-wrapper{position:sticky;top:72px;max-height:calc(100vh - 72px);display:flex;flex-direction:column;overflow:auto}@media(max-width: 768px){.sticky-wrapper{display:none}}.category-card-back{background:var(--bg-gray, #e5e7eb) !important}.service-card{display:flex;flex-direction:column;height:100%;border:1px solid var(--border-color, #dee2e6);color:var(--text-dark, #222831);box-shadow:0 1px 2px rgba(0,0,0,.05);cursor:pointer;transition:all .2s ease-in-out}.service-card:hover{box-shadow:0 4px 6px rgba(0,0,0,.1)}.service-card:focus-visible{outline:none;box-shadow:0 0 0 2px var(--primary-color-light-20);outline-offset:2px}.service-card__body{display:flex;flex-direction:column;flex-grow:1;padding:1.5rem}.service-card__content{flex-grow:1}.service-card__footer{display:flex;flex-direction:column;gap:.75rem;margin-top:auto}.service-card__price-row{display:flex;justify-content:space-between;align-items:center}.service-card__title{font-size:1.125rem;font-weight:600;color:var(--text-dark, #222831);margin:0 .5rem 0 0}.service-card__price{font-size:1rem;font-weight:600;color:var(--primary-color)}.service-card__duration{font-size:.875rem;color:var(--secondary-color, #4b5563)}.service-card__options{font-size:.875rem;color:var(--secondary-color, #4b5563);padding-top:1rem;border-top:1px solid var(--border-color-light, #f3f4f6);gap:.5rem;display:flex;align-items:center}.service-card__options svg{width:1rem;height:1rem;margin-right:.25rem}@media(max-width: 768px){.service-card{font-size:.875rem}.service-card__body{padding:1rem}.service-card__title{font-size:1rem}.service-card__description{font-size:.75rem;margin-bottom:.75rem}.service-card__description p{font-size:.75rem}.service-card__price{font-size:.875rem}.service-card__duration{font-size:.75rem}.service-card__options{font-size:.75rem;padding-top:.75rem}.service-card__price-row{gap:.25rem}.service-card__footer{gap:.5rem}}.selected-articles{margin:0;padding:0}.selected-article{display:flex;justify-content:space-between;padding:.25rem 0;border-bottom:1px solid var(--border-color-light, #f3f4f6)}.selected-article:last-child{border-bottom:none}.cart-item .btn:hover{background-color:#f4f4f5}.cart-item .btn:focus-visible{color:var(--bs-btn-active-color);background-color:var(--bs-btn-active-bg);border-color:var(--bs-btn-active-border-color)}.mobile-cart-button{display:none}@media(max-width: 768px){.mobile-cart-button{position:fixed;bottom:1rem;right:1rem;width:3.5rem;height:3.5rem;background-color:var(--primary-color);color:var(--bg-white, #ffffff);border-radius:50%;box-shadow:0 4px 6px rgba(0,0,0,.2);z-index:1010;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none}.mobile-cart-button .badge{position:absolute;top:-0.25rem;right:-0.25rem;background-color:#ef4444;color:#fff;font-size:.75rem;font-weight:bold;width:1.25rem;height:1.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center}.mobile-cart-button:hover{background-color:var(--primary-color)}}.animate-pop{animation:pop .3s ease-in-out}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.3)}100%{transform:scale(1)}}.profitCenter-selection-page{padding:2rem 0;display:flex;flex-direction:column;justify-content:space-between}@media(max-width: 576px){.profitCenter-selection-page{padding:1rem 0}}.profitCenter-selection-page .container{max-width:720px;margin:auto}.profitCenter-selection-page .title{font-size:2rem;font-weight:500;color:#111827}@media(max-width: 576px){.profitCenter-selection-page .title{font-size:1.5rem}}.profitCenter-selection-page .subtitle{color:#6b7280;font-size:1rem}@media(max-width: 576px){.profitCenter-selection-page .subtitle{font-size:.875rem}}.profitCenter-selection-page .profitCenter-cards{display:flex;flex-direction:column;gap:1rem}.profitCenter-selection-page .profitCenter-card{background-color:#fff;border-radius:.75rem;padding:1rem;cursor:pointer}@media(max-width: 576px){.profitCenter-selection-page .profitCenter-card{padding:.75rem}}.profitCenter-selection-page .profitCenter-card{transition:all .2s ease-in-out;border:2px solid #e5e7eb;position:relative}.profitCenter-selection-page .profitCenter-card:hover{box-shadow:0 10px 15px -3px rgba(0,0,0,.1)}.profitCenter-selection-page .profitCenter-card.selected{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);border-width:2px}.profitCenter-selection-page .profitCenter-content{display:flex;align-items:center;gap:1rem}.profitCenter-selection-page .profitCenter-logo{position:relative;flex-shrink:0}.profitCenter-selection-page .logo-img{width:80px;height:80px;border-radius:.75rem;object-fit:cover}@media(max-width: 576px){.profitCenter-selection-page .logo-img{width:56px;height:56px}}.profitCenter-selection-page .profitCenter-info{flex:1}.profitCenter-selection-page .profitCenter-name{font-size:1.25rem;font-weight:500;color:#111827;margin-bottom:.25rem}@media(max-width: 576px){.profitCenter-selection-page .profitCenter-name{font-size:1rem}}.profitCenter-selection-page .profitCenter-description{color:#6b7280;font-size:.875rem;margin-bottom:.5rem}.profitCenter-selection-page .profitCenter-meta{display:flex;gap:1rem;font-size:.875rem;color:#6b7280}.profitCenter-selection-page .selection-indicator{flex-shrink:0}.profitCenter-selection-page .selection-indicator{display:flex;justify-content:center;align-items:center;height:1.5rem;width:1.5rem;flex-shrink:0;transition:all 150ms cubic-bezier(0.4, 0, 0.2, 1)}.profitCenter-selection-page .indicator{width:24px;height:24px;border-radius:9999px;border:2px solid #d1d5db;display:flex;align-items:center;justify-content:center;transition:background-color .2s,border-color .2s}.profitCenter-selection-page .selected-indicator{border-color:inherit;background-color:inherit}.profitCenter-selection-page .btn-continue{background-color:#9ca3af;color:#fff;padding:.75rem 2rem;font-size:1.1rem}@media(max-width: 576px){.profitCenter-selection-page .btn-continue{padding:.5rem 1.5rem;font-size:1rem}}.profitCenter-selection-page .btn-continue{font-weight:500;border-radius:.5rem;min-width:12rem;transition:background-color .2s}.profitCenter-selection-page .btn-continue:disabled{background-color:#d1d5db;cursor:not-allowed}.profitCenter-selection-page .btn-continue:active{color:#fff}.profitCenter-selection-page .footer-text{color:#9ca3af;font-size:.875rem}.reschedule-label{display:block;margin-bottom:.75rem;font-size:.75rem;font-weight:600;color:var(--text-dark, #222831)}.employee-picker{margin-bottom:1rem}.employee-picker__label{display:block;margin-bottom:.75rem;font-size:.75rem;font-weight:600;color:var(--text-dark, #222831)}.employee-picker__list{display:flex;gap:1rem;overflow-x:auto;padding:0 .5rem 1rem;flex-wrap:wrap}@media(max-width: 576px){.employee-picker__list{gap:.5rem;padding:0 .25rem .5rem}}.employee{min-width:70px;text-align:center;cursor:pointer;display:flex;flex-direction:column;align-items:center}.employee:hover .employee__avatar{border-color:var(--primary-color)}.employee:hover img{filter:grayscale(0)}.employee--selected .employee__avatar{border-color:var(--primary-color);box-shadow:0 4px 10px rgba(0,0,0,.15)}.employee--selected .employee__avatar img{filter:grayscale(0)}.employee--default .employee__avatar{background:var(--bg-light, #f9fafb)}.employee__avatar{position:relative;width:56px;height:56px}@media(max-width: 576px){.employee__avatar{width:44px;height:44px}}.employee__avatar{border-radius:50%;border:2px solid rgba(0,0,0,0);padding:2px;transition:border-color .2s ease;display:flex;align-items:center;justify-content:center}.employee__avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;filter:grayscale(1);transition:filter .2s ease}.employee__avatar--placeholder{width:100%;height:100%;border-radius:50%;color:var(--text-color, #333);background-color:var(--bg-gray, #e5e7eb);font-size:1.5rem;display:flex;align-items:center;justify-content:center}.employee__check{position:absolute;bottom:0;right:0;width:16px;height:16px;border-radius:50%;background:var(--primary-color);color:var(--bg-white, #ffffff);font-size:10px;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-white, #ffffff)}.employee__meta{margin-top:.25rem}.employee__name{display:block;font-size:.75rem;font-weight:500;color:var(--text-dark, #222831)}.employee__name--active{color:var(--primary-color);font-weight:700}.employee__price{display:block;font-size:.625rem;margin-top:.125rem;color:var(--text-lighter, #9ca3af)}.employee__price--active{color:var(--primary-color);font-weight:700}@media(max-width: 768px){.publicApp:has(.appointment-booking-stepper) .primary-footer{padding-bottom:4rem}}.header-image-container{width:100%;overflow:hidden;position:relative;border-radius:.4rem}.header-image-container .header-img{width:100%;height:auto;object-fit:cover;display:block}@media(max-width: 768px){.header-image-container .header-img{height:140px}.header-image-container{border-radius:0}}.header-image-container::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.35);z-index:1}.header-image-container-text{position:absolute;bottom:12px;left:16px;right:16px;color:#fff;font-size:1.8rem;font-weight:bold;z-index:2;text-shadow:0 2px 4px rgba(0,0,0,.5)}.service-description-container{font-size:.875rem;color:var(--secondary-color, #4b5563);margin-bottom:1rem}.service-description-container p{margin:0}.service-description-container .service-description{overflow:hidden;text-overflow:ellipsis;word-break:break-word;overflow-wrap:break-word;white-space:pre-wrap;hyphens:auto;text-align:justify}@media(max-width: 576px){.service-description-container{font-size:.75rem}}.toggle-description{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:.875rem;font-weight:500;text-decoration:underline;padding:0}.toggle-description:hover{text-decoration:none}@media(max-width: 576px){.toggle-description{font-size:.75rem}}.employee-info .avatar-wrapper{width:60px;height:60px;border-radius:50%;overflow:hidden;margin-right:1rem}@media(max-width: 576px){.employee-info .avatar-wrapper{width:48px;height:48px;margin-right:.75rem}}.employee-info .avatar-wrapper .avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.avatar-container{width:60px;height:60px;border-radius:50%;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center}@media(max-width: 576px){.avatar-container{width:48px;height:48px}}.avatar-container .initials-avatar{font-size:1.8rem}@media(max-width: 576px){.avatar-container .initials-avatar{font-size:1.4rem}}.avatar-container .avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.avatar-placeholder{width:100%;height:100%;background:linear-gradient(90deg, #f5f5f5 25%, #e0e0e0 50%, #f5f5f5 75%);background-size:200% 100%;animation:shimmer 1.2s infinite}.employee-details{flex-grow:1}.booking-overview-content{max-width:752px}.booking-steps-container{min-height:0}.employee-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}@media(max-width: 576px){.employee-grid{gap:.75rem}}@media(min-width: 768px){.employee-grid{grid-template-columns:repeat(2, 1fr)}}@media(min-width: 1024px){.employee-grid{grid-template-columns:repeat(4, 1fr)}}.no-employees-message{text-align:center;color:var(--text-light, #6b7280);font-size:1rem;margin-top:2rem}.no-employees-message a{color:var(--primary-color)}.no-employees-message a:hover{text-decoration:none}.card-profile{cursor:pointer;transition:all .15s ease-in-out}.card-profile.selected{box-shadow:0 0 0 2px var(--primary-color);position:relative}.card-profile:not(.card-profile.selected):hover{box-shadow:0 .25rem .5rem rgba(0,0,0,.1)}.card-profile .icon-wrapper{width:120px;height:120px;border-radius:50%;display:flex;align-items:center;justify-content:center}@media(max-width: 576px){.card-profile .icon-wrapper{width:80px;height:80px}}.card-profile .icon-wrapper .employee-icon{font-size:56px;color:var(--text-color, #333)}@media(max-width: 576px){.card-profile .icon-wrapper .employee-icon{font-size:36px}}.card-profile .avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.card-profile .object-fit-cover{object-fit:cover}.card-profile .badge-check{width:2rem;height:2rem;top:.8rem;right:.8rem;border-radius:50%;background-color:var(--primary-color);opacity:0;transform:scale(0.9);animation:fadeInScale .15s ease-out forwards}.card-profile .icon{width:1.25rem;height:1.25rem}.card-profile .icon-sm{width:1rem;height:1rem}.content-box{width:3.5rem;height:3.5rem;flex-shrink:0}.employee-photo{width:100%;height:100%;object-fit:cover}.booking-header{margin-bottom:2rem}@media(max-width: 576px){.booking-header{margin-bottom:1rem}}/*# sourceMappingURL=app.css.map */
