:root{--primary-color:#8b2a47;--primary-hover:#7a2440;--secondary-color:#f5e9da;--background-color:#f8f9fa;--text-color:#333;--text-muted:#666;--border-color:#e9ecef;--success-color:#28a745;--error-color:#dc3545;--warning-color:#ffc107;--warning-bg:#fff3cd;--error-bg:#ffe6e6;--error-border:#f99;--white:#fff;--shadow:0 0.25rem 0.75rem rgba(0,0,0,.1);--shadow-hover:0 0.25rem 0.75rem rgba(139,42,71,.3);--border-radius:0.75rem;--border-radius-lg:1rem;--transition:all 0.3s ease}*{box-sizing:border-box}body{font-family:Vazir,Arial,sans-serif;margin:0;padding:0;line-height:1.6;color:var(--text-color);background:var(--background-color)}.booking-wizard,.page-container{width:100%;min-height:100vh}.page-container{background:var(--white);font-family:Vazir,sans-serif;direction:rtl}.booking-header{padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.edit-btn{border:0;background-color:transparent}.booking-title{font-size:1.125rem;margin:0;text-align:right}.track-bookings-link{color:var(--primary-color);text-decoration:none;font-size:1rem;transition:var(--transition);text-decoration:underline}.header{background:var(--secondary-color);padding:1rem;display:flex;align-items:center;gap:.9375rem;position:relative}.back-button{background:none;border:none;font-size:1.25rem;color:var(--primary-color);cursor:pointer;padding:.3125rem;transition:var(--transition)}.back-button:hover{transform:scale(1.1)}.title{font-size:1.125rem;font-weight:700;color:var(--primary-color);margin:0;text-align:center}.content{padding:1.25rem;max-width:37.5rem;margin:0 auto}.section-title{text-align:right;font-size:1.25rem;font-weight:700;color:var(--text-color);margin-bottom:.625rem;padding:1rem}.subtitle{text-align:right;color:var(--text-muted);margin-bottom:2.5rem;font-size:1rem}.input-group{margin-bottom:1.25rem;position:relative}.form-input{width:100%;padding:.9375rem 1.25rem;border:.125rem solid var(--border-color);border-radius:var(--border-radius);font-size:1rem;background:var(--white);transition:var(--transition);text-align:right;direction:rtl}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 .1875rem rgba(139,42,71,.1)}.form-input.verified{border-color:var(--success-color);background:#f8fff9;padding-left:3.125rem}.verified-icon{position:absolute;left:.9375rem;top:50%;transform:translateY(-50%);color:var(--success-color);font-size:1.25rem}.verified-field{display:flex;align-items:center;justify-content:space-between;padding:.9375rem 1.25rem;border:.125rem solid var(--success-color);border-radius:var(--border-radius);background:#f8fff9;font-size:1rem;text-align:right;direction:rtl}.verified-field .field-label{color:var(--text-secondary);font-weight:500;margin-left:.5rem}.verified-field .field-value{color:var(--text-primary);font-weight:600;flex-grow:1}.verified-field .verified-icon{position:static;transform:none;margin-right:.5rem}.btn{padding:.9375rem 1.25rem;border:none;border-radius:var(--border-radius);font-size:1rem;font-weight:700;cursor:pointer;transition:var(--transition);text-align:center;display:inline-block;text-decoration:none}.btn-primary{background:var(--primary-color);color:var(--white)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-.0625rem);box-shadow:var(--shadow-hover)}.btn-primary:disabled{background:#ccc;cursor:not-allowed;transform:none}.confirm-button{width:100%;background:#ccc;border:none;border-radius:var(--border-radius);padding:.9375rem;font-size:1rem;font-weight:700;color:var(--white);cursor:not-allowed;transition:var(--transition)}.confirm-button.active{background:var(--primary-color);cursor:pointer}.confirm-button.active:hover{background:var(--primary-hover);transform:translateY(-.0625rem);box-shadow:var(--shadow-hover)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:flex-end;z-index:1000;animation:fadeIn .3s ease}.modal-content{background:var(--white);width:100%;max-width:31.25rem;margin:0 auto;border-radius:1rem 1rem 0 0!important;padding:1.875rem 1.25rem;animation:slideUp .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding:0 1rem!important}.modal-header h3{margin:0;font-size:1.1rem;color:var(--text-color)}.close-button{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:.3125rem}.otp-description{text-align:center;color:var(--text-muted);line-height:1.5}.edit-otp{text-align:center;background-color:var(--secondary-color);padding:.5rem .7rem;width:-moz-fit-content;width:fit-content;margin:0 auto 1rem;border-radius:20px}.phone-highlight{padding:.125rem .375rem;font-weight:700}.edit-link{color:var(--primary-color);cursor:pointer;text-decoration:underline;font-weight:500;margin-right:.625rem;transition:var(--transition)}.edit-link:hover{color:var(--primary-hover)}.otp-inputs{display:flex;justify-content:center;gap:.9375rem;margin-bottom:1.25rem;direction:ltr}.otp-input{width:3.125rem;height:3.125rem;border:.125rem solid var(--border-color);border-radius:.5rem;text-align:center;font-size:1.25rem;font-weight:700;transition:var(--transition)}.otp-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 .1875rem rgba(139,42,71,.1)}.timer-text{text-align:center;color:var(--text-muted);font-size:.875rem;margin-bottom:1.875rem}.modal-confirm-button{width:100%;background:#ccc;border:none;border-radius:var(--border-radius);padding:.9375rem;font-size:1rem;font-weight:700;color:var(--white);cursor:not-allowed;transition:var(--transition);margin-bottom:.9375rem}.modal-confirm-button.active{background:var(--primary-color);cursor:pointer}.modal-confirm-button.active:hover{background:var(--primary-hover)}.cancel-button{width:100%;background:none;border:none;color:var(--error-color);font-size:1rem;font-weight:500;cursor:pointer;padding:.625rem}.cancel-button:hover{text-decoration:underline}.terms-text{text-align:right;color:var(--text-muted);font-size:.875rem;margin:1.875rem 0}.terms-link{background:none;border:none;color:var(--primary-color);text-decoration:underline;cursor:pointer;font-size:.875rem;padding:0}.terms-link:hover{color:var(--primary-hover)}.terms-modal{max-height:80vh;overflow-y:auto}.terms-content{max-height:25rem;overflow-y:auto;margin-bottom:1.25rem;padding:0 .3125rem}.terms-content h4{color:var(--primary-color);font-size:1rem;font-weight:700;margin:1.25rem 0 .625rem;border-bottom:.0625rem solid var(--border-color);padding-bottom:.3125rem}.terms-content h4:first-child{margin-top:0}.terms-content p{margin-bottom:.75rem;line-height:1.6;color:#555;font-size:.875rem}.selected-info{background:var(--white);border-radius:var(--border-radius);padding:1.25rem;margin-bottom:1.875rem;border:.0625rem solid var(--border-color)}.info-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.625rem}.info-row:last-child{margin-bottom:0}.label{font-weight:500;color:var(--text-muted)}.value{font-weight:700;color:var(--text-color)}.datetime-selection{width:100%;min-height:100vh;background:var(--white);font-family:Vazir,sans-serif;direction:rtl}.month-navigation{display:flex;align-items:center;justify-content:center;margin-bottom:1.875rem;gap:1.25rem}.nav-arrow{background:none;border:none;font-size:1.125rem;color:var(--primary-color);cursor:pointer;padding:.625rem}.nav-arrow.disabled{opacity:.3;cursor:not-allowed;color:var(--text-muted)}.month-year{font-size:1.125rem;font-weight:700;color:var(--text-color);min-width:9.375rem;text-align:center}.calendar-container{margin-bottom:1.875rem;position:relative}.calendar-dates{display:flex;gap:.9375rem;overflow-x:auto;padding:.625rem 0;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.calendar-dates::-webkit-scrollbar{display:none}.date-card{background:var(--white);border:.125rem solid var(--border-color);border-radius:var(--border-radius);padding:.9375rem 1.25rem;text-align:center;cursor:pointer;transition:var(--transition);min-width:7.5rem;flex-shrink:0}.date-card:hover{border-color:var(--primary-color);transform:translateY(-.125rem)}.date-card.selected{background:var(--primary-color);border-color:var(--primary-color);color:var(--white)}.date-number{font-size:1.5rem;font-weight:700;margin-bottom:.3125rem}.day-name{font-size:.875rem;margin-bottom:.3125rem;opacity:.8}.time-slots{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:.625rem;gap:.625rem;margin-bottom:2.5rem}.time-slot{background:var(--white);border:.125rem solid var(--border-color);border-radius:.5rem;padding:.75rem .5rem;text-align:center;cursor:pointer;transition:var(--transition);font-size:.875rem}.time-slot:hover:not(.disabled){border-color:var(--primary-color);background:var(--background-color)}.time-slot.selected{background:var(--primary-color)!important;border-color:var(--primary-color)!important;color:var(--white)!important}.time-slot.disabled{opacity:.5;cursor:not-allowed;background:var(--background-color)}.customer-info{width:100%;min-height:100vh;background:var(--white);font-family:Vazir,sans-serif;direction:rtl}.no-dates-message{background:var(--warning-bg);border:.0625rem solid #ffeaa7;border-radius:.5rem;padding:1.25rem;margin-bottom:1.25rem;text-align:center;color:#856404;font-size:1rem}.retry-button{background:#c00;color:var(--white);border:none;border-radius:.375rem;padding:.5rem 1rem;margin-top:.625rem;cursor:pointer;font-size:.875rem}.retry-button:hover{background:#a00}.error-message{background:var(--error-bg);border:.0625rem solid var(--error-border);border-radius:.5rem;padding:.75rem;color:#c00;font-size:.875rem}.error-message,.success-message{margin-bottom:1.25rem;text-align:center}.success-message{background:var(--white);border-radius:var(--border-radius-lg);padding:1.875rem 1.25rem}.success-icon{margin-bottom:1.25rem;display:flex;justify-content:center}.success-title{font-size:1.125rem;font-weight:600;color:var(--text-color);line-height:1.6;margin:0}.confirmation-container{max-width:37.5rem;margin:0 auto;background:var(--white);min-height:100vh;padding:1.25rem;font-family:Vazir,sans-serif;direction:rtl}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:50vh;gap:1.25rem}.spinner{width:2.5rem;height:2.5rem;border:.25rem solid #f3f3f3;border-top:.25rem solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.booking-card{background:var(--white);border-radius:var(--border-radius-lg);padding:1.25rem;margin-bottom:1.25rem}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.9375rem;border-bottom:.0625rem solid #f0f0f0}.service-name{font-size:1.25rem;font-weight:700;color:var(--text-color);margin:0}.service-description-section{margin:.75rem 0;padding:.75rem;background:#f8f9fa;border-radius:8px;border-right:3px solid var(--primary-color)}.service-description-text{color:#555;font-size:.9rem;line-height:1.5;margin:0;text-align:right;direction:rtl}.professional-button{background:var(--warning-color)}.professional-button,.professional-notice{color:var(--text-color);padding:.5rem 1rem;border-radius:1.25rem;font-size:.75rem;font-weight:500}.booking-details{display:flex;flex-direction:column;gap:.9375rem}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.detail-label{color:var(--text-color)}.detail-label,.detail-value{font-weight:500;font-size:.875rem}.detail-value{color:var(--text-muted)}.bottom-notice{gap:.625rem;background:var(--warning-bg);border:.0625rem solid #ffeaa7;border-radius:.5rem;padding:.75rem 1rem;margin-bottom:1.25rem;font-size:.875rem;color:#856404}.bottom-notice,.notice-icon{display:flex;align-items:center}.notice-icon{background:var(--warning-color);color:var(--white);width:1.25rem;height:1.25rem;border-radius:50%;justify-content:center;font-weight:700;font-size:.75rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.content{padding:.9375rem}.booking-header{padding:.75rem 1rem;margin-bottom:1rem}.booking-title{font-size:1rem}.otp-inputs{gap:.625rem}.otp-input{width:2.8125rem;height:2.8125rem;font-size:1.125rem}.time-slots{grid-template-columns:repeat(3,1fr)}.date-card{min-width:6.25rem;padding:.75rem .9375rem}.confirmation-container{padding:.625rem}.card-header{flex-direction:column;gap:.625rem;align-items:stretch}.service-name{font-size:1.125rem}.professional-button,.service-name{text-align:center}}@media (max-width:480px){.calendar-dates{gap:.625rem}.time-slots{grid-template-columns:repeat(2,1fr)}.date-card{min-width:5.625rem;padding:.75rem .625rem}.date-number{font-size:1.25rem}}.text-center{text-align:center}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.my-0{margin-top:0;margin-bottom:0}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-2{margin-top:.5rem;margin-bottom:.5rem}.my-3{margin-top:.75rem;margin-bottom:.75rem}.my-4{margin-top:1rem;margin-bottom:1rem}.my-5{margin-top:1.25rem;margin-bottom:1.25rem}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.d-none{display:none}.d-block{display:block}.d-flex{display:flex}.d-grid{display:grid}.w-100{width:100%}.h-100{height:100%}.professional-container{max-width:37.5rem;margin:0 auto;background:var(--white);min-height:100vh;font-family:Vazir,sans-serif}.professional-header{background:var(--white);padding:2.5rem 1.25rem;text-align:center;color:var(--text-color);position:relative}.professional-image-container{margin-bottom:1.25rem}.professional-image{width:6.25rem;height:6.25rem;margin:0 auto;border-radius:50%;border:.25rem solid hsla(0,0%,100%,.3);background:var(--white)}.professional-image img{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}.professional-name{font-size:1.5rem;font-weight:700;margin:0;color:var(--text-color)}.booking-section{background:var(--white);padding:1.875rem 1.25rem}.booking-title{font-size:1.25rem;font-weight:700;color:var(--primary-color);margin:0 0 .625rem;text-align:center}.booking-subtitle{color:var(--text-muted);font-size:1rem;margin:0 0 1.875rem;text-align:center}.services-list{display:flex;flex-direction:column;gap:.9375rem}.service-card{background:var(--white);border-radius:.9375rem;padding:1.25rem;border:.0625rem solid var(--border-color);display:flex;justify-content:space-between;align-items:center;gap:.9375rem;transition:transform .2s ease}.service-card:hover{transform:translateY(-.125rem)}.service-info{flex:1 1;text-align:right;direction:rtl}.service-card .service-name{font-size:1.125rem;margin:0 0 .5rem}.service-card .service-name,.service-price{font-weight:700;color:var(--text-color);text-align:right}.service-price{font-size:1rem;margin-bottom:.75rem}.service-details{flex-direction:column;gap:.375rem}.service-detail,.service-details{display:flex;text-align:right;direction:rtl}.service-detail{align-items:center;color:var(--text-muted);font-size:.875rem;gap:.5rem;justify-content:flex-start}.detail-icon{font-size:.875rem;width:1.25rem;text-align:center;color:var(--primary-color);margin-left:.25rem}.service-button{background:var(--secondary-color);border:none;border-radius:.75rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:var(--primary-color);cursor:pointer;transition:var(--transition);white-space:nowrap;min-width:7.5rem}.service-button:hover{background:#f0dcc7;transform:translateY(-.0625rem)}.service-button:active{transform:translateY(0)}.service-selection-step{max-width:50rem;margin:0 auto;padding:1.25rem;background:var(--white);min-height:100vh}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(18.75rem,1fr));grid-gap:1.25rem;gap:1.25rem;margin-bottom:1.875rem}.services-grid .service-card{border:.125rem solid var(--border-color);border-radius:.75rem;padding:1.25rem;cursor:pointer;transition:var(--transition);position:relative;background:var(--white)}.services-grid .service-card:hover{border-color:var(--primary-color);transform:translateY(-.125rem)}.services-grid .service-card.selected{border-color:var(--primary-color);background:linear-gradient(135deg,var(--primary-color) 0,#a8285a 100%);color:var(--white)}.service-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.9375rem}.services-grid .service-name,.services-grid .service-price{margin:0;font-weight:700;font-size:1.125rem}.services-grid .service-price{color:var(--success-color)}.services-grid .service-card.selected .service-price{color:var(--white)}.service-description{margin-bottom:.9375rem;font-size:.875rem;opacity:.8}.services-grid .service-details{display:flex;gap:1.25rem;flex-direction:row}.services-grid .service-detail{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.services-grid .detail-icon{width:1rem;opacity:.7}.selected-indicator{position:absolute;top:.9375rem;right:.9375rem;font-size:1.5rem;color:var(--success-color)}.services-grid .service-card.selected .selected-indicator{color:var(--white)}.navigation-buttons{display:flex;justify-content:space-between;gap:.9375rem}.btn-outline-secondary{background:var(--white);border:.125rem solid var(--border-color);color:var(--text-color)}.btn-outline-secondary:hover{background:var(--border-color)}@media (max-width:768px){.professional-header{padding:1.875rem .9375rem}.professional-image{width:5rem;height:5rem}.professional-name{font-size:1.25rem}.booking-section{padding:1.25rem .9375rem}.service-card{flex-direction:column;align-items:stretch;gap:.9375rem;text-align:center}.service-info{direction:rtl}.service-card .service-name,.service-info,.service-price{text-align:center}.service-details{align-items:flex-start}.service-detail,.service-details{justify-content:flex-start;text-align:right;direction:rtl}.service-button{width:100%}.services-grid{grid-template-columns:1fr}.navigation-buttons{flex-direction:column}}@media (max-width:480px){.professional-image{width:4.375rem;height:4.375rem}.professional-name{font-size:1.125rem}.service-card{padding:.9375rem}.service-card .service-name{font-size:1rem}.service-price{font-size:.875rem}}.bookings-step,.otp-step,.phone-step{max-width:28rem;margin:0 auto}.no-bookings{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.no-bookings i{font-size:3rem;margin-bottom:1rem;color:var(--border-color)}.no-bookings h4{margin-bottom:.5rem;color:var(--text-color)}.bookings-list{display:flex;flex-direction:column;gap:1rem}.bookings-list .booking-card{background:var(--white);border-radius:var(--border-radius);padding:1rem;border:1px solid var(--border-color);box-shadow:var(--shadow)}.bookings-list .booking-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:.75rem;direction:rtl}.bookings-list .booking-header .service-name{font-size:1.125rem;font-weight:700;color:var(--text-color);margin:0;text-align:right}.status-badge{background:var(--secondary-color);color:var(--primary-color);padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:700;white-space:nowrap}.status-pending{background:#fff3cd;color:#856404}.status-confirmed{background:#d4edda;color:#155724}.status-completed{background:#d1ecf1;color:#0c5460}.status-cancelled{background:#f8d7da;color:#721c24}.bookings-list .booking-details{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.bookings-list .detail-row{display:flex;justify-content:space-between;align-items:center;padding:.125rem 0;border-bottom:1px solid #f8f9fa}.bookings-list .detail-row:last-child{border-bottom:none}.bookings-list .detail-label{color:var(--text-muted);font-size:.85rem;min-width:6rem}.bookings-list .detail-value{color:var(--text-color);font-weight:500;text-align:left;direction:ltr;font-size:.85rem}.booking-notice{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#f8f9fa;border-radius:var(--border-radius);color:var(--text-muted);font-size:.85rem}.booking-notice i{color:var(--primary-color);font-size:1rem}@media (max-width:768px){.bookings-list .booking-header{gap:.5rem}.bookings-list .booking-header .service-name{font-size:1rem}.status-badge{align-self:flex-start}.bookings-list .detail-row{display:flex;justify-content:space-between;align-items:center;padding:.125rem 0}.bookings-list .detail-label{min-width:auto;font-size:.85rem}.bookings-list .detail-value{text-align:left;direction:ltr;font-size:.85rem}}.track-bookings-link-container{margin:1.5rem 0;text-align:center}.track-bookings-link-container .track-bookings-link{display:inline-block;padding:.75rem 1.5rem;background:var(--primary-color);color:var(--white);text-decoration:none;border-radius:var(--border-radius);font-weight:500;transition:var(--transition);font-size:1rem}.track-bookings-link-container .track-bookings-link:hover{background:var(--primary-hover);transform:translateY(-.0625rem);box-shadow:var(--shadow-hover)}.pwa-install-prompt{margin-top:1.5rem;margin-bottom:1rem}.install-card{background:var(--white);border-radius:var(--border-radius);border:1px solid var(--border-color);padding:1.25rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1rem;transition:var(--transition)}.install-card:hover{box-shadow:var(--shadow-hover)}.install-icon{display:flex;justify-content:center;align-items:center;margin-bottom:.5rem}.install-content{text-align:center}.install-title{font-size:1.125rem;font-weight:700;color:var(--text-color);margin:0 0 .5rem;line-height:1.4}.install-description{font-size:.875rem;color:var(--text-muted);margin:0;line-height:1.5}.install-actions{display:flex;gap:.75rem;justify-content:center;margin-top:.5rem}.install-button{background:var(--primary-color);color:var(--white);border:none;padding:.75rem 1.5rem;border-radius:var(--border-radius);font-size:.875rem;font-weight:700;cursor:pointer;transition:var(--transition);flex:1 1;max-width:150px}.install-button:hover{background:var(--primary-hover);transform:translateY(-1px)}.dismiss-button{background:transparent;color:var(--text-muted);border:1px solid var(--border-color);padding:.75rem 1.5rem;border-radius:var(--border-radius);font-size:.875rem;cursor:pointer;transition:var(--transition);flex:1 1;max-width:150px}.dismiss-button:hover{background:var(--background-color);color:var(--text-color)}@media (max-width:768px){.install-card{padding:1rem}.install-title{font-size:1rem}.install-description{font-size:.8125rem}.install-actions{flex-direction:column;gap:.5rem}.dismiss-button,.install-button{max-width:none;padding:.875rem 1rem}}.install-instructions-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--white);border-radius:1rem 1rem 0 0;box-shadow:0 -4px 20px rgba(0,0,0,.15);z-index:1001;padding:1rem 1.25rem 1.5rem;animation:slideUpSheet .3s ease-out}.sheet-handle{display:flex;justify-content:center;margin-bottom:1rem}.handle-bar{width:2.5rem;height:.25rem;background:#d1d5db;border-radius:.125rem}.sheet-header{text-align:center;margin-bottom:1.5rem}.sheet-title{font-size:1.125rem;font-weight:700;color:var(--text-color);margin:0 0 .5rem}.sheet-subtitle{font-size:.875rem;color:var(--text-muted);margin:0}.instructions-card{background:#f0f9ff;border:1px solid #bae6fd;border-radius:var(--border-radius);padding:1rem;margin-bottom:1.5rem;display:flex;gap:.75rem;align-items:flex-start}.instruction-icon{width:2rem;height:2rem;background:#dbeafe;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.instruction-content{flex:1 1}.instruction-title{font-weight:600;color:#1e40af;margin-bottom:.5rem;font-size:1rem}.instruction-step{color:#1e40af;font-size:1rem;margin-bottom:.25rem;line-height:1.4}.instruction-step:last-child{margin-bottom:0}.sheet-close-button{width:100%;background:var(--primary-color);color:var(--white);border:none;padding:.875rem 1rem;border-radius:var(--border-radius);font-size:1rem;font-weight:700;cursor:pointer;transition:var(--transition)}.sheet-close-button:hover{background:var(--primary-hover)}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media (max-width:768px){.install-instructions-sheet{padding:.75rem 1rem 1.25rem}.sheet-title{font-size:1rem}.sheet-subtitle{font-size:.8125rem}.instructions-card{padding:.875rem;gap:.625rem}.instruction-step,.instruction-title{font-size:.8125rem}}.pwa-status-notifications{margin-top:1rem;display:flex;flex-direction:column;gap:1rem}.pwa-status-card{background:#f0f9ff;border:1px solid #bae6fd;border-radius:var(--border-radius);padding:.75rem 1rem;box-shadow:var(--shadow)}.notification-permission-card{background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--border-radius);padding:1rem;box-shadow:var(--shadow)}.notification-permission-card .flex{display:flex}.notification-permission-card .flex-col{flex-direction:column}.notification-permission-card .gap-2{gap:.5rem}.notification-permission-card .items-center{align-items:center}@media (max-width:768px){.notification-permission-card,.pwa-status-card{padding:.75rem}.notification-permission-card .flex{flex-direction:column;gap:.5rem}}.radio-group{display:flex;gap:1rem;margin-top:.5rem;flex-wrap:wrap}.radio-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem 0}.radio-option input[type=radio]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border:2px solid var(--border-color);border-radius:50%;background:var(--white);cursor:pointer;position:relative;transition:var(--transition)}.radio-option input[type=radio]:checked{border-color:var(--primary-color);background:var(--primary-color)}.radio-option input[type=radio]:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background:var(--white)}.radio-option input[type=radio]:focus{outline:none;box-shadow:0 0 0 3px rgba(139,42,71,.1)}.radio-label{font-size:1rem;color:var(--text-color);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-weight:500;transition:var(--transition)}.radio-option:hover .radio-label{color:var(--primary-color)}.radio-option input[type=radio]:checked+.radio-label{color:var(--primary-color);font-weight:600}.toggle-container{display:flex;align-items:center;margin-top:.5rem}.toggle-switch{position:relative;display:inline-block;width:60px;height:34px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.4s;border-radius:34px}.toggle-slider:before{position:absolute;content:"";height:26px;width:26px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.toggle-slider{background-color:#7b1e3c}input:focus+.toggle-slider{box-shadow:0 0 1px #7b1e3c}input:checked+.toggle-slider:before{transform:translateX(26px)}.work-samples-section{margin-top:2rem;padding:1.5rem;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef}.work-samples-title{font-size:1.3rem;font-weight:700;color:#333;margin:0 0 .5rem;display:flex;align-items:center;gap:.5rem}.work-samples-title:before{content:"";font-size:1.2rem}.work-samples-subtitle{color:#666;font-size:.9rem;margin:0 0 1.5rem;line-height:1.5}.work-samples-grid{display:flex;gap:.75rem;margin-top:1rem;overflow-x:auto;padding:.5rem 0;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.work-samples-grid::-webkit-scrollbar{height:6px}.work-samples-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.work-samples-grid::-webkit-scrollbar-thumb{background:#7b1e3c;border-radius:3px}.work-samples-grid::-webkit-scrollbar-thumb:hover{background:#6a1a34}.work-sample-item{position:relative;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.1);transition:all .3s ease;background:#fff;border:1px solid #e9ecef;cursor:pointer;flex-shrink:0;width:120px}.work-sample-item:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.15)}.work-sample-image{width:100%;height:120px;object-fit:cover;display:block;transition:transform .3s ease}.work-sample-item:hover .work-sample-image{transform:scale(1.05)}.work-sample-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;color:#fff;font-size:1.5rem}.work-sample-item:hover .work-sample-overlay{opacity:1}.image-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.image-modal-content{position:relative;overflow:hidden}.image-modal-content,.image-modal-scroll-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.image-modal-scroll-container{overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;padding:2rem}.image-modal-scroll-container::-webkit-scrollbar{height:8px}.image-modal-scroll-container::-webkit-scrollbar-track{background:hsla(0,0%,100%,.1);border-radius:4px}.image-modal-scroll-container::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.3);border-radius:4px}.image-modal-scroll-container::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,100%,.5)}.image-modal-image{max-width:none;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.5);cursor:-webkit-grab;cursor:grab}.image-modal-image:active{cursor:-webkit-grabbing;cursor:grabbing}.image-modal-close{position:fixed;top:20px;right:20px;background:hsla(0,0%,100%,.95);border:2px solid #7b1e3c;border-radius:50%;width:60px;height:60px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.8rem;color:#7b1e3c;transition:all .3s ease;z-index:1002;box-shadow:0 4px 15px rgba(0,0,0,.3);font-weight:700}.image-modal-close:hover{background:#7b1e3c;color:#fff;transform:scale(1.1);border-color:#7b1e3c;box-shadow:0 6px 20px rgba(123,30,60,.4)}@media (max-width:768px){.work-samples-section{margin-top:1.5rem;padding:1rem}.work-samples-grid{gap:.5rem}.work-sample-item{width:100px}.work-sample-image{height:100px}.image-modal-overlay,.image-modal-scroll-container{padding:1rem}.image-modal-close{top:15px;right:15px;width:50px;height:50px;font-size:1.5rem}}@media (max-width:480px){.work-samples-grid{gap:.4rem}.work-sample-item{width:80px}.work-sample-image{height:80px}}