@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", sans-serif;--primary: #6B7280;--primary-hover: #9CA3AF;--primary-dark: #4B5563;--secondary: #10B981;--accent: #6B7280;--danger: #EF4444;--warning: #F97316;--primary-color: var(--primary);--secondary-color: var(--secondary);--accent-color: var(--accent);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5), 0 2px 4px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 10px 10px -5px rgba(0, 0, 0, .4);--glass-bg: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .1)}[data-theme=dark]{--bg-primary: #0A0A0A;--bg-secondary: #111111;--bg-tertiary: #1A1A1A;--bg-elevated: #1F1F1F;--bg-overlay: rgba(0, 0, 0, .8);--text-primary: #FFFFFF;--text-secondary: #A3A3A3;--text-tertiary: #737373;--text-muted: #525252;--border-primary: #262626;--border-secondary: #404040;--card-bg: #141414;--card-hover: #1C1C1C;--input-bg: #0F0F0F;--input-border: #2A2A2A;--input-focus: var(--primary-color, #ff6b35)}[data-theme=light]{--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-elevated: #FFFFFF;--bg-overlay: rgba(0, 0, 0, .5);--text-primary: #171717;--text-secondary: #525252;--text-tertiary: #737373;--text-muted: #A3A3A3;--border-primary: #E5E5E5;--border-secondary: #D4D4D4;--card-bg: #FFFFFF;--card-hover: #F9F9F9;--input-bg: #FFFFFF;--input-border: #D4D4D4;--input-focus: var(--primary-color, #ff6b35);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(0, 0, 0, .1)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;padding:0;margin:0}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;transition:background-color var(--transition-base),color var(--transition-base);padding:0;margin:0;padding-top:constant(safe-area-inset-top);padding-top:env(safe-area-inset-top);padding-bottom:constant(safe-area-inset-bottom);padding-bottom:env(safe-area-inset-bottom);padding-left:constant(safe-area-inset-left);padding-left:env(safe-area-inset-left);padding-right:constant(safe-area-inset-right);padding-right:env(safe-area-inset-right)}body.no-scroll{overflow:hidden!important;position:fixed!important;width:100%!important}input,textarea,select{font-size:16px!important}#root,.app{min-height:100vh;display:flex;flex-direction:column;position:relative}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;margin-bottom:var(--spacing-md);color:var(--text-primary)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{margin-bottom:var(--spacing-md);color:var(--text-secondary)}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-hover)}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 var(--spacing-lg)}.glass{background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border)}.card{background:var(--card-bg);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base)}.card:hover{background:var(--card-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-size:.875rem;font-weight:600;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;font-family:var(--font-family)}.btn-primary:hover{background:var(--primary-600, var(--primary-hover));transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary:hover{background:var(--bg-elevated);border-color:var(--border-secondary)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-primary)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-secondary)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.input,.textarea,.select{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;font-family:var(--font-family);transition:all var(--transition-fast)}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--primary-color, var(--input-focus));box-shadow:0 0 0 3px var(--primary-100, rgba(255, 107, 53, .1))}.input::placeholder,.textarea::placeholder{color:var(--text-muted)}.label{display:block;margin-bottom:var(--spacing-xs);font-size:.875rem;font-weight:500;color:var(--text-secondary)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite;background:var(--bg-tertiary);border-radius:var(--radius-md)}@media (max-width: 640px){html{font-size:14px}.container{padding:0 var(--spacing-md)}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}}@media (max-width: 768px){.hide-mobile{display:none!important}}@media (min-width: 768px){.hide-desktop{display:none!important}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.animate-fadeIn{animation:fadeIn var(--transition-base)}.animate-slideInUp{animation:slideInUp var(--transition-base)}.animate-slideInDown{animation:slideInDown var(--transition-base)}.barber-wizard-container{min-height:100vh;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);display:flex;align-items:center;justify-content:center;padding:2rem}.wizard-wrapper{width:100%;max-width:800px;background:var(--card-bg);border-radius:20px;box-shadow:0 20px 60px #00000080;overflow:hidden}.wizard-logo{text-align:center;padding:2rem;border-bottom:1px solid var(--border-primary)}.wizard-logo h1{color:var(--primary);font-size:1.8rem;font-weight:700}.wizard-progress{padding:2rem 3rem 1rem;display:flex;justify-content:center}.progress-steps{display:flex;justify-content:center;align-items:center;gap:3rem}.progress-step{display:flex;flex-direction:column;align-items:center;gap:.5rem}.step-circle{width:40px;height:40px;border-radius:50%;background:var(--bg-tertiary);border:2px solid var(--border-primary);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--text-tertiary);transition:all .3s ease}.progress-step.active .step-circle{background:var(--primary);border-color:var(--primary);color:#fff;transform:scale(1.1)}.progress-step.completed .step-circle{background:#10b981;border-color:#10b981;color:#fff}.step-label{font-size:.875rem;color:var(--text-tertiary);font-weight:500}.progress-step.active .step-label{color:var(--primary)}.progress-step.completed .step-label{color:#10b981}.wizard-content{padding:3rem}.wizard-step{animation:fadeIn .5s ease}.step-header{text-align:center;margin-bottom:2rem}.step-header h2{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary)}.step-header p{color:var(--text-secondary);font-size:1.1rem}.wizard-form{max-width:600px;margin:0 auto}.form-section{margin-bottom:2rem}.form-section h3{font-size:1.2rem;margin-bottom:1.5rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-group label svg{flex-shrink:0;color:var(--text-tertiary)}.form-group input{width:100%;padding:.875rem 1rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--text-primary);font-size:1rem;transition:all .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #ff6b351a}.form-group input.error{border-color:var(--danger)}.error-text{color:var(--danger);font-size:.875rem;margin-top:.25rem;display:block}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.template-card{padding:1.5rem;background:var(--bg-tertiary);border:2px solid var(--border-primary);border-radius:12px;cursor:pointer;transition:all .3s ease;position:relative}.template-card:hover{transform:translateY(-2px);border-color:var(--primary)}.template-card.selected{background:var(--primary);border-color:var(--primary);color:#fff}.template-preview{font-size:3rem;margin-bottom:1rem;text-align:center}.template-card h4{font-size:1.1rem;margin-bottom:.5rem}.template-card p{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.template-card.selected p{color:#ffffffe6}.template-features{list-style:none;padding:0}.template-features li{display:flex;align-items:center;gap:.5rem;font-size:.875rem;margin-bottom:.5rem}.selected-badge{position:absolute;top:1rem;right:1rem;background:#fff;color:var(--primary);padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.25rem}.color-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem;margin-bottom:2rem}.color-card{text-align:center;cursor:pointer;transition:all .3s ease;position:relative}.color-preview{display:flex;margin-bottom:.5rem;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0003}.color-swatch{height:60px;flex:1}.color-swatch.secondary{opacity:.7}.color-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.color-card.selected .color-preview{box-shadow:0 0 0 3px var(--primary)}.color-check{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:50%;padding:4px;color:var(--primary)}.packages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.package-card{background:var(--bg-tertiary);border:2px solid var(--border-primary);border-radius:16px;padding:2rem;position:relative;cursor:pointer;transition:all .3s ease}.package-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px #0000004d}.package-card.selected{border-color:var(--primary);background:linear-gradient(135deg,var(--primary) 0%,transparent 100%)}.package-card.popular{border-color:var(--primary)}.popular-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--primary);color:#fff;padding:.25rem 1rem;border-radius:20px;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.25rem}.package-header{text-align:center;margin-bottom:1.5rem}.package-icon{margin-bottom:1rem}.package-header h3{font-size:1.5rem;margin-bottom:.5rem}.package-description{font-size:.875rem;color:var(--text-secondary)}.package-price{text-align:center;margin-bottom:1.5rem;display:flex;align-items:baseline;justify-content:center;gap:.25rem}.currency{font-size:1.5rem;color:var(--text-secondary)}.amount{font-size:3rem;font-weight:700;color:var(--text-primary)}.period{font-size:1rem;color:var(--text-secondary)}.savings-text{text-align:center;color:#10b981;font-weight:600;margin-bottom:1rem}.package-features{list-style:none;padding:0}.package-features li{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;color:var(--text-primary)}.selected-indicator{position:absolute;top:1rem;right:1rem;width:32px;height:32px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center}.billing-toggle{display:flex;justify-content:center;gap:1rem;margin-bottom:2rem}.toggle-btn{padding:.75rem 1.5rem;background:var(--bg-tertiary);border:2px solid var(--border-primary);border-radius:25px;color:var(--text-primary);font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.toggle-btn:hover{border-color:var(--primary)}.toggle-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.savings-badge{background:#10b981;color:#fff;padding:.125rem .5rem;border-radius:10px;font-size:.75rem;font-weight:600}.price-summary{background:var(--bg-tertiary);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.summary-box h4{font-size:1.1rem;margin-bottom:1rem;color:var(--text-primary)}.summary-line{display:flex;justify-content:space-between;padding:.5rem 0;color:var(--text-secondary)}.summary-line.total{border-top:2px solid var(--border-primary);margin-top:.5rem;padding-top:1rem;font-size:1.2rem;color:var(--text-primary)}.payment-step{max-width:500px;margin:0 auto}.payment-form{background:var(--bg-tertiary);border-radius:12px;padding:2rem}.payment-header{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.5rem;color:var(--text-secondary)}.payment-element-container{margin-bottom:2rem}.payment-summary{background:var(--bg-primary);border-radius:8px;padding:1rem;margin-bottom:1.5rem}.security-badges{text-align:center;padding-top:1rem;color:var(--text-tertiary);font-size:.875rem;display:flex;align-items:center;justify-content:center;gap:1rem}.wizard-actions{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem}.btn-primary,.btn-secondary{padding:.875rem 2rem;border-radius:8px;font-weight:600;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:all .3s ease;border:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-2px)}.btn-secondary{background:transparent;color:var(--text-secondary);border:2px solid var(--border-primary)}.btn-secondary:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-payment{background:linear-gradient(135deg,var(--primary),var(--primary-hover))}.wizard-success{text-align:center;padding:3rem}.success-icon{margin-bottom:2rem}.wizard-success h1{font-size:2rem;margin-bottom:1rem;color:var(--text-primary)}.wizard-success p{color:var(--text-secondary);margin-bottom:1rem}.redirecting{color:var(--primary);font-weight:600}.success-details{background:var(--bg-tertiary);border-radius:12px;padding:2rem;margin-top:2rem;text-align:left}.detail-item{padding:.5rem 0;color:var(--text-primary)}.detail-item strong{color:var(--text-secondary);margin-right:.5rem}.customization-note{background:var(--bg-tertiary);border-left:4px solid var(--primary);padding:1rem;margin-bottom:2rem;border-radius:4px;display:flex;align-items:flex-start;gap:1rem;color:var(--text-secondary)}.security-info{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;color:var(--text-tertiary);font-size:.875rem}.wizard-footer{padding:1.5rem;text-align:center;border-top:1px solid var(--border-primary);color:var(--text-tertiary);font-size:.875rem}.loading-state,.error-state{text-align:center;padding:4rem 2rem}.spinner-large{width:60px;height:60px;border:4px solid var(--border-primary);border-top:4px solid var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 2rem}.spinner{width:20px;height:20px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;display:inline-block;animation:spin 1s linear infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.error-message,.error-banner{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--danger);padding:1rem;border-radius:8px;margin-bottom:1.5rem;text-align:center}@media (max-width: 768px){.wizard-wrapper{border-radius:0;max-width:100%;min-height:100vh}.wizard-content{padding:1.5rem}.packages-grid{grid-template-columns:1fr}.wizard-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%;justify-content:center}}.support-button{position:fixed;bottom:2rem;right:2rem;width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;border:none;box-shadow:0 4px 12px #ff6b354d;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:9998;transition:all .3s ease}.support-button:hover{background:var(--primary-dark, #e55a2b);box-shadow:0 6px 20px #ff6b3566}.support-modal{background:var(--bg-primary);border-radius:var(--radius-xl);max-width:600px;width:100%;max-height:85vh;overflow-y:auto;padding:2rem;position:relative;z-index:10000;pointer-events:auto}.modal-header{text-align:center;margin-bottom:2rem}.modal-header h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.modal-subtitle{color:var(--text-secondary);font-size:.95rem;margin:0}.progress-step{display:flex;align-items:center;gap:.75rem;opacity:.5;transition:opacity .3s;flex:1}.progress-step.active .step-number{background:var(--primary);border-color:var(--primary);color:#fff}.progress-step.completed .step-number{background:var(--success, #10b981);border-color:var(--success, #10b981);color:#fff}.step-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.progress-step.active .step-label,.progress-step.completed .step-label{color:var(--text-primary)}.step-content{min-height:300px}.step-content h3{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0 0 1.5rem}.step-hint{color:var(--text-secondary);font-size:.875rem;margin:-1rem 0 1rem}.choice-chips{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.choice-chip{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.choice-chip:hover{background:var(--bg-tertiary);border-color:var(--primary);transform:translateY(-2px)}.choice-chip.selected{background:var(--primary);border-color:var(--primary);color:#fff}.choice-chip svg{flex-shrink:0}.choice-chips.multi-select{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.support-textarea{width:100%;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-family:inherit;resize:vertical;transition:all .2s}.support-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-100, rgba(255, 107, 53, .1))}.character-count{text-align:right;color:var(--text-tertiary);font-size:.75rem;margin-top:.5rem}.modal-actions{display:flex;gap:1rem;justify-content:space-between;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-primary)}.modal-actions .btn-primary{margin-left:auto}.modal-actions button{display:flex;align-items:center;gap:.5rem}.success-state{text-align:center;padding:3rem 1rem}.success-icon{width:80px;height:80px;border-radius:50%;background:var(--success-bg, #10b98120);color:var(--success, #10b981);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}.success-state h2{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0 0 .75rem}.success-state p{color:var(--text-secondary);font-size:.95rem;margin:0 0 .5rem}.success-note{color:var(--text-tertiary);font-size:.875rem;font-style:italic;margin-top:1rem}@media (max-width: 768px){.support-button{bottom:1.5rem;right:1.5rem;width:48px;height:48px}.support-button svg{width:20px;height:20px}.support-modal{padding:1.5rem;max-width:100%;margin:1rem}.wizard-progress{flex-direction:column;gap:.75rem}.progress-step{width:100%}.choice-chips{grid-template-columns:1fr}.choice-chips.multi-select{grid-template-columns:repeat(2,1fr)}.modal-actions{flex-direction:column}.modal-actions .btn-primary{margin-left:0;order:1}.modal-actions .btn-secondary{order:2}}.pending-appointments-modal{position:relative;background:#fff;border-radius:12px;width:90%;max-width:700px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0003;animation:modalFadeIn .3s ease}.pending-appointments-modal .modal-header{padding:24px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.pending-appointments-modal .modal-header h2{margin:0;font-size:24px;font-weight:600;color:#1f2937}.pending-appointments-modal .close-btn{background:none;border:none;cursor:pointer;color:#6b7280;transition:color .2s;padding:4px;display:flex;align-items:center;justify-content:center}.pending-appointments-modal .close-btn:hover{color:#1f2937}.pending-appointments-modal .modal-body{flex:1;overflow-y:auto;padding:24px}.pending-appointments-modal .loading-state,.pending-appointments-modal .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#6b7280}.pending-appointments-modal .empty-state svg{color:#d1d5db;margin-bottom:16px}.pending-appointments-modal .empty-state p{margin:0;font-size:18px;font-weight:500;color:#4b5563}.pending-appointments-modal .empty-state span{font-size:14px;color:#9ca3af;margin-top:8px}.pending-appointments-modal .appointments-list{display:flex;flex-direction:column;gap:16px}.pending-appointments-modal .appointment-card{border:1px solid #e5e7eb;border-radius:8px;padding:20px;background:#fff;transition:all .2s}.pending-appointments-modal .appointment-card:hover{box-shadow:0 4px 12px #00000014;border-color:#d1d5db}.pending-appointments-modal .appointment-info{margin-bottom:16px}.pending-appointments-modal .appointment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.pending-appointments-modal .appointment-header h3{margin:0;font-size:18px;font-weight:600;color:#1f2937}.pending-appointments-modal .appointment-date{font-size:14px;color:#6b7280;font-weight:500}.pending-appointments-modal .appointment-details{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px}.pending-appointments-modal .detail-item{display:flex;align-items:center;gap:6px;font-size:14px;color:#4b5563}.pending-appointments-modal .detail-item svg{color:#9ca3af}.pending-appointments-modal .client-contact{display:flex;align-items:center;gap:6px;font-size:14px;color:#6b7280;margin-top:8px}.pending-appointments-modal .client-contact svg{color:#9ca3af}.pending-appointments-modal .appointment-actions{display:flex;gap:12px;padding-top:16px;border-top:1px solid #f3f4f6}.pending-appointments-modal .btn-approve,.pending-appointments-modal .btn-deny{flex:1;padding:10px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}.pending-appointments-modal .btn-approve{background:#10b981;color:#fff}.pending-appointments-modal .btn-approve:hover:not(:disabled){background:#059669}.pending-appointments-modal .btn-deny{background:#ef4444;color:#fff}.pending-appointments-modal .btn-deny:hover:not(:disabled){background:#dc2626}.pending-appointments-modal .btn-approve:disabled,.pending-appointments-modal .btn-deny:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.pending-appointments-modal{width:95%;max-height:90vh}.pending-appointments-modal .modal-header,.pending-appointments-modal .modal-body{padding:20px}.pending-appointments-modal .appointment-header{flex-direction:column;align-items:flex-start;gap:4px}.pending-appointments-modal .appointment-details{flex-direction:column;gap:8px}.pending-appointments-modal .appointment-actions{flex-direction:column}}.day-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000}.day-modal-container{background:var(--bg-primary);width:100%;max-width:500px;height:60vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;flex-direction:column;overflow:hidden}.day-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.day-modal-date-nav{display:flex;align-items:center;gap:1rem}.day-modal-date-nav h2{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.nav-btn{padding:.5rem;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.nav-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.day-modal-weekday{padding:.75rem 1.5rem;background:var(--bg-elevated);color:var(--text-secondary);font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-primary)}.day-modal-content{flex:1;overflow-y:auto;padding:1rem}.no-appointments{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);text-align:center;padding:2rem}.no-appointments svg{opacity:.3;margin-bottom:1rem}.no-appointments p{font-size:.95rem}.appointments-list{display:flex;flex-direction:column;gap:.75rem}.appointment-item{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:1rem;position:relative;transition:all var(--transition-fast)}.appointment-item:hover{background:var(--bg-elevated);transform:translate(4px)}.appointment-time{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem;margin-bottom:.5rem}.time-end{color:var(--text-tertiary)}.appointment-details{margin-left:1.5rem}.appointment-title{font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.appointment-client,.appointment-services,.appointment-price{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.appointment-client svg,.appointment-services svg,.appointment-price svg{color:var(--text-tertiary)}.appointment-status{position:absolute;top:1rem;right:1rem;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:500;text-transform:uppercase}.day-modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-primary);background:var(--bg-secondary);text-align:center;color:var(--text-secondary);font-size:.875rem}@media (min-width: 768px){.day-modal-overlay{align-items:center}.day-modal-container{height:70vh;max-height:600px;border-radius:var(--radius-lg)}.day-modal-header h2{font-size:1.25rem}}.appointment-details-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1500}.appointment-details-container{background:var(--bg-primary);width:100%;max-width:500px;height:50vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;flex-direction:column;overflow:hidden}.appointment-details-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.appointment-details-header h2{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.close-btn{padding:.5rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast)}.close-btn:hover{color:var(--text-primary)}.appointment-details-content{flex:1;overflow-y:auto;padding:1.5rem}.detail-section{margin-bottom:1.5rem}.detail-section:last-child{margin-bottom:0}.detail-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}.detail-item:last-child{margin-bottom:0}.detail-item svg{color:var(--text-tertiary);margin-top:.125rem}.detail-item>div{flex:1}.detail-item label{display:block;font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.detail-item span{display:block;font-size:.95rem;color:var(--text-primary);font-weight:500}.status-row{display:flex;align-items:center;justify-content:space-between}.status-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:500;text-transform:uppercase;margin-left:1rem}.status-confirmed{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.status-pending{background:#fbbf241a;color:#fbbf24;border:1px solid rgba(251,191,36,.2)}.status-completed{background:#3b82f61a;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.status-cancelled{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.notes-text{background:var(--bg-secondary);padding:.75rem;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;margin-top:.5rem;line-height:1.5}.appointment-details-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-primary);background:var(--bg-secondary)}.appointment-details-footer .btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.appointment-details-footer .btn:hover{background:var(--primary-dark);transform:translateY(-1px)}@media (min-width: 768px){.appointment-details-overlay{align-items:center}.appointment-details-container{height:auto;max-height:80vh;min-height:400px;border-radius:var(--radius-lg)}.appointment-details-header h2{font-size:1.25rem}}.rbc-btn{color:inherit;font:inherit;margin:0}button.rbc-btn{overflow:visible;text-transform:none;-webkit-appearance:button;-moz-appearance:button;appearance:button;cursor:pointer}button[disabled].rbc-btn{cursor:not-allowed}button.rbc-input::-moz-focus-inner{border:0;padding:0}.rbc-calendar{-webkit-box-sizing:border-box;box-sizing:border-box;height:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:stretch;-ms-flex-align:stretch;align-items:stretch}.rbc-m-b-negative-3{margin-bottom:-3px}.rbc-h-full{height:100%}.rbc-calendar *,.rbc-calendar *:before,.rbc-calendar *:after{-webkit-box-sizing:inherit;box-sizing:inherit}.rbc-abs-full,.rbc-row-bg{overflow:hidden;position:absolute;inset:0}.rbc-ellipsis,.rbc-show-more,.rbc-row-segment .rbc-event-content,.rbc-event-label{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rbc-rtl{direction:rtl}.rbc-off-range{color:#999}.rbc-off-range-bg{background:#e6e6e6}.rbc-header{overflow:hidden;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;text-overflow:ellipsis;white-space:nowrap;padding:0 3px;text-align:center;vertical-align:middle;font-weight:700;font-size:90%;min-height:0;border-bottom:1px solid #ddd}.rbc-header+.rbc-header{border-left:1px solid #ddd}.rbc-rtl .rbc-header+.rbc-header{border-left-width:0;border-right:1px solid #ddd}.rbc-header>a,.rbc-header>a:active,.rbc-header>a:visited{color:inherit;text-decoration:none}.rbc-button-link{color:inherit;background:none;margin:0;padding:0;border:none;cursor:pointer;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.rbc-row-content{position:relative;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;z-index:4}.rbc-row-content-scrollable{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;height:100%}.rbc-row-content-scrollable .rbc-row-content-scroll-container{height:100%;overflow-y:scroll;-ms-overflow-style:none;scrollbar-width:none}.rbc-row-content-scrollable .rbc-row-content-scroll-container::-webkit-scrollbar{display:none}.rbc-today{background-color:#eaf6ff}.rbc-toolbar{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:10px;font-size:16px}.rbc-toolbar .rbc-toolbar-label{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;padding:0 10px;text-align:center}.rbc-toolbar button{color:#373a3c;display:inline-block;margin:0;text-align:center;vertical-align:middle;background:none;background-image:none;border:1px solid #ccc;padding:.375rem 1rem;border-radius:4px;line-height:normal;white-space:nowrap}.rbc-toolbar button:active,.rbc-toolbar button.rbc-active{background-image:none;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px #00000020;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:active:hover,.rbc-toolbar button:active:focus,.rbc-toolbar button.rbc-active:hover,.rbc-toolbar button.rbc-active:focus{color:#373a3c;background-color:#d4d4d4;border-color:#8c8c8c}.rbc-toolbar button:focus{color:#373a3c;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:hover{color:#373a3c;cursor:pointer;background-color:#e6e6e6;border-color:#adadad}.rbc-btn-group{display:inline-block;white-space:nowrap}.rbc-btn-group>button:first-child:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.rbc-btn-group>button:last-child:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.rbc-rtl .rbc-btn-group>button:first-child:not(:last-child){border-radius:0 4px 4px 0}.rbc-rtl .rbc-btn-group>button:last-child:not(:first-child){border-radius:4px 0 0 4px}.rbc-btn-group>button:not(:first-child):not(:last-child){border-radius:0}.rbc-btn-group button+button{margin-left:-1px}.rbc-rtl .rbc-btn-group button+button{margin-left:0;margin-right:-1px}.rbc-btn-group+.rbc-btn-group,.rbc-btn-group+button{margin-left:10px}@media (max-width: 767px){.rbc-toolbar{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}}.rbc-event,.rbc-day-slot .rbc-background-event{border:none;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-box-shadow:none;box-shadow:none;margin:0;padding:2px 5px;background-color:#3174ad;border-radius:5px;color:#fff;cursor:pointer;width:100%;text-align:left}.rbc-slot-selecting .rbc-event,.rbc-slot-selecting .rbc-day-slot .rbc-background-event,.rbc-day-slot .rbc-slot-selecting .rbc-background-event{cursor:inherit;pointer-events:none}.rbc-event.rbc-selected,.rbc-day-slot .rbc-selected.rbc-background-event{background-color:#265985}.rbc-event:focus,.rbc-day-slot .rbc-background-event:focus{outline:5px auto #3b99fc}.rbc-event-label{font-size:80%}.rbc-event-overlaps{-webkit-box-shadow:-1px 1px 5px 0px rgba(51,51,51,.5);box-shadow:-1px 1px 5px #33333380}.rbc-event-continues-prior{border-top-left-radius:0;border-bottom-left-radius:0}.rbc-event-continues-after{border-top-right-radius:0;border-bottom-right-radius:0}.rbc-event-continues-earlier{border-top-left-radius:0;border-top-right-radius:0}.rbc-event-continues-later{border-bottom-left-radius:0;border-bottom-right-radius:0}.rbc-row{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-row-segment{padding:0 1px 1px}.rbc-selected-cell{background-color:#0000001a}.rbc-show-more{background-color:#ffffff4d;z-index:4;font-weight:700;font-size:85%;height:auto;line-height:normal;color:#3174ad}.rbc-show-more:hover,.rbc-show-more:focus{color:#265985}.rbc-month-view{position:relative;border:1px solid #ddd;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;width:100%;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;height:100%}.rbc-month-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-month-row{display:-webkit-box;display:-ms-flexbox;display:flex;position:relative;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;-ms-flex-preferred-size:0px;flex-basis:0px;overflow:hidden;height:100%}.rbc-month-row+.rbc-month-row{border-top:1px solid #ddd}.rbc-date-cell{-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;min-width:0;padding-right:5px;text-align:right}.rbc-date-cell.rbc-now{font-weight:700}.rbc-date-cell>a,.rbc-date-cell>a:active,.rbc-date-cell>a:visited{color:inherit;text-decoration:none}.rbc-row-bg{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;overflow:hidden;right:1px}.rbc-day-bg{-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%}.rbc-day-bg+.rbc-day-bg{border-left:1px solid #ddd}.rbc-rtl .rbc-day-bg+.rbc-day-bg{border-left-width:0;border-right:1px solid #ddd}.rbc-overlay{position:absolute;z-index:5;border:1px solid #e5e5e5;background-color:#fff;-webkit-box-shadow:0 5px 15px rgba(0,0,0,.25);box-shadow:0 5px 15px #00000040;padding:10px}.rbc-overlay>*+*{margin-top:1px}.rbc-overlay-header{border-bottom:1px solid #e5e5e5;margin:-10px -10px 5px;padding:2px 10px}.rbc-agenda-view{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;overflow:auto}.rbc-agenda-view table.rbc-agenda-table{width:100%;border:1px solid #ddd;border-spacing:0;border-collapse:collapse}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td{padding:5px 10px;vertical-align:top}.rbc-agenda-view table.rbc-agenda-table .rbc-agenda-time-cell{padding-left:15px;padding-right:15px;text-transform:lowercase}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left-width:0;border-right:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table tbody>tr+tr{border-top:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{padding:3px 5px;text-align:left;border-bottom:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table thead>tr>th{text-align:right}.rbc-agenda-time-cell{text-transform:lowercase}.rbc-agenda-time-cell .rbc-continues-after:after{content:" »"}.rbc-agenda-time-cell .rbc-continues-prior:before{content:"« "}.rbc-agenda-date-cell,.rbc-agenda-time-cell{white-space:nowrap}.rbc-agenda-event-cell{width:100%}.rbc-time-column{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;min-height:100%}.rbc-time-column .rbc-timeslot-group{-webkit-box-flex:1;-ms-flex:1;flex:1}.rbc-timeslot-group{border-bottom:1px solid #ddd;min-height:40px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.rbc-time-gutter,.rbc-header-gutter{-webkit-box-flex:0;-ms-flex:none;flex:none}.rbc-label{padding:0 5px}.rbc-day-slot{position:relative}.rbc-day-slot .rbc-events-container{inset:0;position:absolute;margin-right:10px}.rbc-day-slot .rbc-events-container.rbc-rtl{left:10px;right:0}.rbc-day-slot .rbc-event,.rbc-day-slot .rbc-background-event{border:1px solid #265985;display:-webkit-box;display:-ms-flexbox;display:flex;max-height:100%;min-height:20px;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-flow:column wrap;flex-flow:column wrap;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;overflow:hidden;position:absolute}.rbc-day-slot .rbc-background-event{opacity:.75}.rbc-day-slot .rbc-event-label{-webkit-box-flex:0;-ms-flex:none;flex:none;padding-right:5px;width:auto}.rbc-day-slot .rbc-event-content{width:100%;-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;word-wrap:break-word;line-height:1;height:100%;min-height:1em}.rbc-day-slot .rbc-time-slot{border-top:1px solid #f7f7f7}.rbc-time-view-resources .rbc-time-gutter,.rbc-time-view-resources .rbc-time-header-gutter{position:sticky;left:0;background-color:#fff;border-right:1px solid #ddd;z-index:10;margin-right:-1px}.rbc-time-view-resources .rbc-time-header{overflow:hidden}.rbc-time-view-resources .rbc-time-header-content{min-width:auto;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;-ms-flex-preferred-size:0px;flex-basis:0px}.rbc-time-view-resources .rbc-time-header-cell-single-day{display:none}.rbc-time-view-resources .rbc-day-slot{min-width:140px}.rbc-time-view-resources .rbc-header,.rbc-time-view-resources .rbc-day-bg{width:140px;-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;-ms-flex-preferred-size:0 px;flex-basis:0 px}.rbc-time-header-content+.rbc-time-header-content{margin-left:-1px}.rbc-time-slot{-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0}.rbc-time-slot.rbc-now{font-weight:700}.rbc-day-header{text-align:center}.rbc-slot-selection{z-index:10;position:absolute;background-color:#00000080;color:#fff;font-size:75%;width:100%;padding:3px}.rbc-slot-selecting{cursor:move}.rbc-time-view{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1;flex:1;width:100%;border:1px solid #ddd;min-height:0}.rbc-time-view .rbc-time-gutter{white-space:nowrap;text-align:right}.rbc-time-view .rbc-allday-cell{-webkit-box-sizing:content-box;box-sizing:content-box;width:100%;height:100%;position:relative}.rbc-time-view .rbc-allday-cell+.rbc-allday-cell{border-left:1px solid #ddd}.rbc-time-view .rbc-allday-events{position:relative;z-index:4}.rbc-time-view .rbc-row{-webkit-box-sizing:border-box;box-sizing:border-box;min-height:20px}.rbc-time-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-time-header.rbc-overflowing{border-right:1px solid #ddd}.rbc-rtl .rbc-time-header.rbc-overflowing{border-right-width:0;border-left:1px solid #ddd}.rbc-time-header>.rbc-row:first-child{border-bottom:1px solid #ddd}.rbc-time-header>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd}.rbc-time-header-cell-single-day{display:none}.rbc-time-header-content{-webkit-box-flex:1;-ms-flex:1;flex:1;display:-webkit-box;display:-ms-flexbox;display:flex;min-width:0;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;border-left:1px solid #ddd}.rbc-rtl .rbc-time-header-content{border-left-width:0;border-right:1px solid #ddd}.rbc-time-header-content>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd;-ms-flex-negative:0;flex-shrink:0}.rbc-time-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;width:100%;border-top:2px solid #ddd;overflow-y:auto;position:relative}.rbc-time-content>.rbc-time-gutter{-webkit-box-flex:0;-ms-flex:none;flex:none}.rbc-time-content>*+*>*{border-left:1px solid #ddd}.rbc-rtl .rbc-time-content>*+*>*{border-left-width:0;border-right:1px solid #ddd}.rbc-time-content>.rbc-day-slot{width:100%;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none}.rbc-current-time-indicator{position:absolute;z-index:3;left:0;right:0;height:1px;background-color:#74ad31;pointer-events:none}.rbc-resource-grouping.rbc-time-header-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.rbc-resource-grouping .rbc-row .rbc-header{width:141px}.service-complete-modal{max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.service-complete-modal .client-info{padding:1rem;background:var(--bg-primary);border-radius:var(--radius-md);margin-bottom:1.5rem}.service-complete-modal .client-info h3{margin:0 0 .5rem;color:var(--text-primary)}.service-complete-modal .client-info p{margin:0;color:var(--text-secondary);font-size:.875rem}.services-section{margin-bottom:1.5rem}.services-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.services-section h3{margin:0;color:var(--text-primary)}.btn-text{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem;background:transparent;border:none;color:var(--primary);font-size:.875rem;cursor:pointer;transition:opacity var(--transition-fast)}.btn-text:hover{opacity:.8}.services-list{display:flex;flex-direction:column;gap:.75rem}.service-item{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:1rem;padding:.75rem;background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.service-info{display:flex;justify-content:space-between;align-items:center}.service-price{color:var(--text-secondary);font-size:.875rem}.quantity-controls{display:flex;align-items:center;gap:.5rem;background:var(--bg-secondary);border-radius:var(--radius-sm);padding:.25rem}.qty-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.qty-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.quantity{min-width:30px;text-align:center;color:var(--text-primary);font-weight:500}.service-total{text-align:right;font-weight:600;color:var(--text-primary)}.adjustment-section{margin-bottom:1.5rem}.adjustment-section label{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;color:var(--text-primary);font-weight:500}.adjustment-section textarea{width:100%;padding:.75rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-md);color:var(--text-primary);resize:vertical;font-family:inherit}.total-section{padding:1rem;background:var(--bg-primary);border-radius:var(--radius-md);margin-bottom:1rem}.total-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;color:var(--text-secondary)}.total-row.final-total{border-top:1px solid var(--border-primary);padding-top:1rem;margin-top:.5rem;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.total-input{display:flex;align-items:center;gap:.5rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-md);padding:.5rem .75rem}.total-input input{background:transparent;border:none;color:var(--text-primary);font-size:1.125rem;font-weight:600;width:100px;text-align:right}.total-input input:focus{outline:none}.warning-message{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fbbf241a;border:1px solid rgba(251,191,36,.3);border-radius:var(--radius-md);color:var(--warning);font-size:.875rem}.payment-qr-modal{max-width:800px;width:90%;max-height:90vh;overflow-y:auto}.payment-amount{display:flex;flex-direction:column;align-items:center;padding:2rem;background:linear-gradient(135deg,var(--primary),var(--primary-hover));border-radius:var(--radius-lg);margin-bottom:2rem;color:#fff}.payment-amount svg{opacity:.9}.payment-amount .amount{font-size:3rem;font-weight:700;margin:.5rem 0}.payment-amount .label{font-size:1rem;opacity:.9;text-transform:uppercase;letter-spacing:1px}.payment-methods-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.5rem;margin-bottom:2rem}.payment-method-card{background:var(--card-bg);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-primary);transition:transform var(--transition-fast)}.payment-method-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.method-header{padding:.75rem;text-align:center;border-bottom:2px solid;background:var(--bg-primary)}.method-header h3{margin:0;font-size:1rem;color:var(--text-primary)}.qr-code{padding:1rem;background:#fff;display:flex;justify-content:center;align-items:center}.qr-code img{width:140px;height:140px;image-rendering:pixelated}.method-handle{padding:.75rem;display:flex;justify-content:space-between;align-items:center;background:var(--bg-primary);border-top:1px solid var(--border-primary)}.method-handle span{font-size:.875rem;color:var(--text-primary);font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.copy-btn{padding:.25rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast);display:flex;align-items:center;justify-content:center}.copy-btn:hover{color:var(--primary)}.payment-actions{display:flex;flex-direction:column;gap:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-primary)}.cash-option{text-align:center}.btn-outline{padding:.75rem 1.5rem;background:transparent;border:2px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-outline:hover:not(:disabled){background:var(--bg-primary);border-color:var(--primary);color:var(--primary)}.btn-outline:disabled{opacity:.5;cursor:not-allowed}.mark-paid-section label{display:block;margin-bottom:.75rem;color:var(--text-secondary);font-size:.875rem;text-align:center}.method-buttons{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.method-btn{padding:.5rem 1rem;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);position:relative}.method-btn:hover:not(:disabled){background:var(--method-color, var(--primary));color:#fff;border-color:var(--method-color, var(--primary))}.method-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.payment-qr-modal{width:95%}.payment-amount .amount{font-size:2rem}.payment-methods-grid{grid-template-columns:repeat(2,1fr)}.qr-code img{width:120px;height:120px}}.appointment-calendar{padding:2rem}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.calendar-header h2{font-size:1.5rem;font-weight:600}.header-buttons{display:flex;gap:1rem;align-items:center}.btn-warning{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#fbbf24;color:#78350f;border:none;border-radius:var(--radius-md);font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 1px 3px #0000001f}.btn-warning:hover{background:#f59e0b;transform:translateY(-2px);box-shadow:0 4px 6px #00000026}.calendar-container{background:var(--card-bg);border-radius:var(--radius-lg);padding:1.5rem;border:1px solid var(--border-primary)}.custom-calendar-controls{background:var(--card-bg);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.controls-nav{display:flex;align-items:center;gap:1rem}.controls-views{display:flex;gap:.5rem}.current-date-label{font-size:1.125rem;font-weight:600;color:var(--text-primary);padding:0 1rem}.btn-outline{background:transparent;color:var(--primary);border:1px solid var(--primary)}.btn-outline:hover{background:var(--primary);color:#fff}.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-primary)}.toolbar-nav{display:flex;align-items:center;gap:.5rem}.btn-today{padding:.5rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:500;transition:all var(--transition-fast)}.btn-today:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-nav{padding:.5rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.btn-nav:hover{background:var(--primary-hover);transform:translateY(-1px)}.toolbar-label{font-size:1.125rem;font-weight:600;margin-left:1rem;color:var(--text-primary)}.toolbar-views{display:flex;gap:.25rem;background:var(--bg-tertiary);padding:.25rem;border-radius:var(--radius-md)}.toolbar-views button{padding:.5rem 1rem;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast)}.toolbar-views button:hover{color:var(--text-primary);background:var(--bg-primary)}.toolbar-views button.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.calendar-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem}.spinner{width:40px;height:40px;border:3px solid var(--border-primary);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.event-details{background:var(--card-bg);padding:2rem;border-radius:var(--radius-lg);max-width:400px;width:90%}.event-details h3{margin-bottom:1.5rem}.detail-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;color:var(--text-secondary)}.detail-status{margin:1.5rem 0;font-weight:500}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500;text-transform:capitalize;margin-left:.5rem}.status-badge.pending{background:#fbbf241a;color:var(--warning);border:1px solid rgba(251,191,36,.2)}.status-badge.confirmed{background:#3b82f61a;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.status-badge.completed{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.status-badge.cancelled{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2)}.status-badge.paid{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem}.modal-actions .btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem}.rbc-calendar{font-family:inherit;background:transparent}.rbc-header{padding:.75rem;font-weight:600;background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary)!important}.rbc-today{background:#ff6b350d}.rbc-event{padding:.25rem .5rem}.rbc-selected{box-shadow:0 0 0 3px #ff6b3566!important;border:2px solid rgba(255,107,53,.8)!important;transform:scale(1.02)}.rbc-day-bg+.rbc-day-bg,.rbc-month-row+.rbc-month-row{border-top:1px solid var(--border-primary)}.rbc-month-view,.rbc-time-view,.rbc-agenda-view{border:1px solid var(--border-primary);border-radius:var(--radius-md)}.rbc-time-header-cell{min-height:25px}.rbc-time-content{border-top:1px solid var(--border-primary)}.rbc-time-content>*+*>*{border-left:1px solid var(--border-primary)}.rbc-timeslot-group{min-height:60px}.rbc-time-slot{border-top:1px solid var(--border-primary)}.dark .rbc-day-bg+.rbc-day-bg,.dark .rbc-month-row+.rbc-month-row{border-top:1px solid rgba(255,255,255,.05)}.dark .rbc-month-view,.dark .rbc-time-view,.dark .rbc-agenda-view{border:1px solid rgba(255,255,255,.08)}.dark .rbc-time-content{border-top:1px solid rgba(255,255,255,.05)}.dark .rbc-time-content>*+*>*{border-left:1px solid rgba(255,255,255,.05)}.dark .rbc-time-slot{border-top:1px solid rgba(255,255,255,.03)}.dark .rbc-header{border-bottom:1px solid rgba(255,255,255,.08)!important}.dark .rbc-header+.rbc-header{border-left:1px solid rgba(255,255,255,.05)!important}.dark .rbc-time-header-cell{border-left:1px solid rgba(255,255,255,.05)!important}.dark .rbc-time-header-gutter{border-right:1px solid rgba(255,255,255,.05)!important}.dark .rbc-time-header-content{border-left:1px solid rgba(255,255,255,.05)!important}.dark .rbc-today{background:#ff6b3514}.dark .rbc-off-range-bg{background:#00000008}.dark .rbc-timeslot-group{border-bottom:1px solid rgba(255,255,255,.03)}.dark .rbc-day-slot .rbc-time-slot{border-top:1px solid rgba(255,255,255,.03)}.dark .rbc-day-slot .rbc-events-container{border-left:1px solid rgba(255,255,255,.05)}.dark .rbc-time-header-content>.rbc-row>*+*{border-left:1px solid rgba(255,255,255,.05)!important}.rbc-agenda-view table{width:100%;border-collapse:collapse}.rbc-agenda-view thead tr{background:var(--bg-secondary)!important}.rbc-agenda-view th{background:var(--bg-secondary)!important;color:var(--text-secondary)!important;font-weight:600;padding:.75rem;text-align:left;border-bottom:2px solid var(--border-primary)}.rbc-agenda-view td{padding:.75rem;border-bottom:1px solid var(--border-primary);background:var(--bg-primary)!important;color:var(--text-primary)!important}.rbc-agenda-date-cell{min-width:100px;font-weight:500}.rbc-agenda-time-cell{min-width:120px;color:var(--text-secondary)}.rbc-agenda-event-cell{color:var(--text-primary)}.rbc-agenda-view .rbc-agenda-row{background:var(--bg-primary)!important}@media (max-width: 768px){.appointment-calendar{padding:1rem}.calendar-header{flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.header-buttons{width:100%;flex-direction:column}.header-buttons button{width:100%;justify-content:center}.calendar-header h2{font-size:1.25rem}.calendar-container{padding:1rem;border-radius:var(--radius-md)}.custom-calendar-controls{padding:1rem;margin-bottom:1rem}.controls-nav{display:grid;grid-template-columns:max-content 1fr;grid-template-rows:auto auto;gap:.75rem;align-items:center;width:100%}.controls-nav button:first-child{grid-column:1;grid-row:1;width:auto;margin-right:auto}.current-date-label{grid-column:2;grid-row:1;text-align:right;font-weight:600;margin-left:auto;padding-right:0}.controls-nav button:nth-child(2){grid-column:1;grid-row:2;width:auto;margin-right:auto}.controls-nav button:last-child{grid-column:2;grid-row:2;width:auto;margin-left:auto}.controls-nav button{justify-content:center}.controls-views{display:none}.toolbar-nav{flex-wrap:wrap;gap:.25rem}.toolbar-label{font-size:1rem;margin-left:.5rem}.toolbar-views{flex-wrap:wrap}.toolbar-views button{padding:.375rem .75rem;font-size:.875rem}.event-details{padding:1.5rem;margin:1rem}.event-details h3{font-size:1.125rem}.detail-row{font-size:.875rem;gap:.5rem}.calendar-toolbar .toolbar-views{display:none!important}.rbc-event{min-height:24px;font-size:.75rem}.rbc-time-slot,.rbc-timeslot-group{min-height:40px}}@media (max-width: 640px){.appointment-calendar{padding:.75rem}.calendar-header{margin-bottom:1rem}.calendar-header h2{font-size:1.125rem}.calendar-container{padding:.75rem}.btn{padding:.5rem 1rem;font-size:.875rem}.calendar-toolbar{flex-direction:column;gap:1rem;align-items:stretch}.toolbar-nav,.toolbar-views{justify-content:center}.event-details{padding:1rem;margin:.5rem;max-width:none;width:calc(100% - 1rem)}.rbc-time-slot,.rbc-timeslot-group{min-height:50px}.rbc-event{min-height:30px;font-size:.75rem;padding:.125rem .25rem}.rbc-header{padding:.5rem .25rem;font-size:.875rem}.rbc-agenda-date-cell{min-width:60px}.rbc-agenda-time-cell{min-width:80px}}@media (max-width: 480px){.appointment-calendar{padding:.5rem}.calendar-container{padding:.5rem;border-radius:var(--radius-sm)}.calendar-header{gap:.75rem}.calendar-header h2{font-size:1rem}.btn{padding:.375rem .75rem;font-size:.75rem}.btn-nav{padding:.375rem}.toolbar-label{font-size:.875rem;margin-left:.25rem}.toolbar-views button{padding:.25rem .5rem;font-size:.75rem}.event-details{padding:.75rem;margin:.25rem;border-radius:var(--radius-md)}.event-details h3{font-size:1rem;margin-bottom:1rem}.detail-row{font-size:.75rem}.rbc-time-slot,.rbc-timeslot-group{min-height:45px}.rbc-event{min-height:28px;font-size:.6875rem}.rbc-header{padding:.375rem .125rem;font-size:.75rem}.rbc-agenda-view .rbc-agenda-content{font-size:.875rem}.rbc-agenda-date-cell{min-width:50px}.rbc-agenda-time-cell{min-width:70px}}.mapboxgl-map{font:12px/20px Helvetica Neue,Arial,Helvetica,sans-serif;overflow:hidden;position:relative;-webkit-tap-highlight-color:rgb(0 0 0/0)}.mapboxgl-canvas{left:0;position:absolute;top:0}.mapboxgl-map:-webkit-full-screen{height:100%;width:100%}.mapboxgl-canary{background-color:salmon}.mapboxgl-canvas-container.mapboxgl-interactive,.mapboxgl-ctrl-group button.mapboxgl-ctrl-compass{cursor:grab;-webkit-user-select:none;user-select:none}.mapboxgl-canvas-container.mapboxgl-interactive.mapboxgl-track-pointer{cursor:pointer}.mapboxgl-canvas-container.mapboxgl-interactive:active,.mapboxgl-ctrl-group button.mapboxgl-ctrl-compass:active{cursor:grabbing}.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate,.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate .mapboxgl-canvas{touch-action:pan-x pan-y}.mapboxgl-canvas-container.mapboxgl-touch-drag-pan,.mapboxgl-canvas-container.mapboxgl-touch-drag-pan .mapboxgl-canvas{touch-action:pinch-zoom}.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate.mapboxgl-touch-drag-pan,.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate.mapboxgl-touch-drag-pan .mapboxgl-canvas{touch-action:none}.mapboxgl-ctrl-bottom,.mapboxgl-ctrl-bottom-left,.mapboxgl-ctrl-bottom-right,.mapboxgl-ctrl-left,.mapboxgl-ctrl-right,.mapboxgl-ctrl-top,.mapboxgl-ctrl-top-left,.mapboxgl-ctrl-top-right{pointer-events:none;position:absolute;z-index:2}.mapboxgl-ctrl-top-left{left:0;top:0}.mapboxgl-ctrl-top{left:50%;top:0;transform:translate(-50%)}.mapboxgl-ctrl-top-right{right:0;top:0}.mapboxgl-ctrl-right{right:0;top:50%;transform:translateY(-50%)}.mapboxgl-ctrl-bottom-right{bottom:0;right:0}.mapboxgl-ctrl-bottom{bottom:0;left:50%;transform:translate(-50%)}.mapboxgl-ctrl-bottom-left{bottom:0;left:0}.mapboxgl-ctrl-left{left:0;top:50%;transform:translateY(-50%)}.mapboxgl-ctrl{clear:both;pointer-events:auto;transform:translate(0)}.mapboxgl-ctrl-top-left .mapboxgl-ctrl{float:left;margin:10px 0 0 10px}.mapboxgl-ctrl-top .mapboxgl-ctrl{float:left;margin:10px 0}.mapboxgl-ctrl-top-right .mapboxgl-ctrl{float:right;margin:10px 10px 0 0}.mapboxgl-ctrl-bottom-right .mapboxgl-ctrl,.mapboxgl-ctrl-right .mapboxgl-ctrl{float:right;margin:0 10px 10px 0}.mapboxgl-ctrl-bottom .mapboxgl-ctrl{float:left;margin:10px 0}.mapboxgl-ctrl-bottom-left .mapboxgl-ctrl,.mapboxgl-ctrl-left .mapboxgl-ctrl{float:left;margin:0 0 10px 10px}.mapboxgl-ctrl-group{background:#fff;border-radius:4px}.mapboxgl-ctrl-group:not(:empty){box-shadow:0 0 0 2px #0000001a}@media (-ms-high-contrast:active){.mapboxgl-ctrl-group:not(:empty){box-shadow:0 0 0 2px ButtonText}}.mapboxgl-ctrl-group button{background-color:initial;border:0;box-sizing:border-box;cursor:pointer;display:block;height:29px;outline:none;overflow:hidden;padding:0;width:29px}.mapboxgl-ctrl-group button+button{border-top:1px solid #ddd}.mapboxgl-ctrl button .mapboxgl-ctrl-icon{background-position:50%;background-repeat:no-repeat;display:block;height:100%;width:100%}@media (-ms-high-contrast:active){.mapboxgl-ctrl-icon{background-color:initial}.mapboxgl-ctrl-group button+button{border-top:1px solid ButtonText}}.mapboxgl-ctrl-attrib-button:focus,.mapboxgl-ctrl-group button:focus{box-shadow:0 0 2px 2px #0096ff}.mapboxgl-ctrl button:disabled{cursor:not-allowed}.mapboxgl-ctrl button:disabled .mapboxgl-ctrl-icon{opacity:.25}.mapboxgl-ctrl-group button:first-child{border-radius:4px 4px 0 0}.mapboxgl-ctrl-group button:last-child{border-radius:0 0 4px 4px}.mapboxgl-ctrl-group button:only-child{border-radius:inherit}.mapboxgl-ctrl button:not(:disabled):hover{background-color:#0000000d}.mapboxgl-ctrl-group button:focus:focus-visible{box-shadow:0 0 2px 2px #0096ff}.mapboxgl-ctrl-group button:focus:not(:focus-visible){box-shadow:none}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E")}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E")}}.mapboxgl-ctrl button.mapboxgl-ctrl-fullscreen .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3h1zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16h1zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5H13zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1V7.5z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-shrink .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1h-5.5zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1v-5.5zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1v5.5zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1h5.5z'/%3E%3C/svg%3E")}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-fullscreen .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3h1zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16h1zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5H13zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1V7.5z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-shrink .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1h-5.5zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1v-5.5zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1v5.5zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1h5.5z'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-fullscreen .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3h1zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16h1zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5H13zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1V7.5z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-shrink .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1h-5.5zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1v-5.5zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1v5.5zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1h5.5z'/%3E%3C/svg%3E")}}.mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M10.5 14l4-8 4 8h-8z'/%3E%3Cpath id='south' d='M10.5 16l4 8 4-8h-8z' fill='%23ccc'/%3E%3C/svg%3E")}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M10.5 14l4-8 4 8h-8z'/%3E%3Cpath id='south' d='M10.5 16l4 8 4-8h-8z' fill='%23999'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M10.5 14l4-8 4 8h-8z'/%3E%3Cpath id='south' d='M10.5 16l4 8 4-8h-8z' fill='%23ccc'/%3E%3C/svg%3E")}}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23333'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate:disabled .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23aaa'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' fill='%23f00'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e58978'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2' display='none'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e54e33'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2' display='none'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-waiting .mapboxgl-ctrl-icon{animation:mapboxgl-spin 2s linear infinite}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23fff'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate:disabled .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23999'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' fill='%23f00'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e58978'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2' display='none'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e54e33'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2' display='none'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23000'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate:disabled .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23666'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' fill='%23f00'/%3E%3C/svg%3E")}}@keyframes mapboxgl-spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}a.mapboxgl-ctrl-logo{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd' viewBox='0 0 88 23'%3E%3Cdefs%3E%3Cpath id='logo' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 013.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='text' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 00-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 004.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 01-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 01.3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 01-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='clip'%3E%3Crect x='0' y='0' width='100%25' height='100%25' fill='white'/%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/mask%3E%3Cg id='outline' opacity='0.3' stroke='%23000' stroke-width='3'%3E%3Ccircle mask='url(%23clip)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23text' mask='url(%23clip)'/%3E%3C/g%3E%3Cg id='fill' opacity='0.9' fill='%23fff'%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/g%3E%3C/svg%3E");background-repeat:no-repeat;cursor:pointer;display:block;height:23px;margin:0 0 -4px -4px;overflow:hidden;width:88px}a.mapboxgl-ctrl-logo.mapboxgl-compact{width:23px}@media (-ms-high-contrast:active){a.mapboxgl-ctrl-logo{background-color:initial;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd' viewBox='0 0 88 23'%3E%3Cdefs%3E%3Cpath id='logo' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 013.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='text' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 00-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 004.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 01-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 01.3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 01-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='clip'%3E%3Crect x='0' y='0' width='100%25' height='100%25' fill='white'/%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/mask%3E%3Cg id='outline' opacity='1' stroke='%23000' stroke-width='3'%3E%3Ccircle mask='url(%23clip)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23text' mask='url(%23clip)'/%3E%3C/g%3E%3Cg id='fill' opacity='1' fill='%23fff'%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/g%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){a.mapboxgl-ctrl-logo{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd' viewBox='0 0 88 23'%3E%3Cdefs%3E%3Cpath id='logo' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 013.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='text' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 00-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 004.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 01-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 01.3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 01-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='clip'%3E%3Crect x='0' y='0' width='100%25' height='100%25' fill='white'/%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/mask%3E%3Cg id='outline' opacity='1' stroke='%23fff' stroke-width='3' fill='%23fff'%3E%3Ccircle mask='url(%23clip)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23text' mask='url(%23clip)'/%3E%3C/g%3E%3Cg id='fill' opacity='1' fill='%23000'%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/g%3E%3C/svg%3E")}}.mapboxgl-ctrl.mapboxgl-ctrl-attrib{background-color:#ffffff80;margin:0;padding:0 5px}@media screen{.mapboxgl-ctrl-attrib.mapboxgl-compact{background-color:#fff;border-radius:12px;box-sizing:initial;margin:10px;min-height:20px;padding:2px 24px 2px 0;position:relative}.mapboxgl-ctrl-attrib.mapboxgl-compact-show{padding:2px 28px 2px 8px;visibility:visible}.mapboxgl-ctrl-bottom-left>.mapboxgl-ctrl-attrib.mapboxgl-compact-show,.mapboxgl-ctrl-left>.mapboxgl-ctrl-attrib.mapboxgl-compact-show,.mapboxgl-ctrl-top-left>.mapboxgl-ctrl-attrib.mapboxgl-compact-show{border-radius:12px;padding:2px 8px 2px 28px}.mapboxgl-ctrl-attrib.mapboxgl-compact .mapboxgl-ctrl-attrib-inner{display:none}.mapboxgl-ctrl-attrib-button{background-color:#ffffff80;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E");border:0;border-radius:12px;box-sizing:border-box;cursor:pointer;display:none;height:24px;outline:none;position:absolute;right:0;top:0;width:24px}.mapboxgl-ctrl-bottom-left .mapboxgl-ctrl-attrib-button,.mapboxgl-ctrl-left .mapboxgl-ctrl-attrib-button,.mapboxgl-ctrl-top-left .mapboxgl-ctrl-attrib-button{left:0}.mapboxgl-ctrl-attrib.mapboxgl-compact .mapboxgl-ctrl-attrib-button,.mapboxgl-ctrl-attrib.mapboxgl-compact-show .mapboxgl-ctrl-attrib-inner{display:block}.mapboxgl-ctrl-attrib.mapboxgl-compact-show .mapboxgl-ctrl-attrib-button{background-color:#0000000d}.mapboxgl-ctrl-bottom-right>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{bottom:0;right:0}.mapboxgl-ctrl-right>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{right:0}.mapboxgl-ctrl-top-right>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{right:0;top:0}.mapboxgl-ctrl-top-left>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{left:0;top:0}.mapboxgl-ctrl-bottom-left>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{bottom:0;left:0}.mapboxgl-ctrl-left>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{left:0}}@media screen and (-ms-high-contrast:active){.mapboxgl-ctrl-attrib.mapboxgl-compact:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd' fill='%23fff'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E")}}@media screen and (-ms-high-contrast:black-on-white){.mapboxgl-ctrl-attrib.mapboxgl-compact:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E")}}.mapboxgl-ctrl-attrib a{color:#000000bf;text-decoration:none}.mapboxgl-ctrl-attrib a:hover{color:inherit;text-decoration:underline}.mapboxgl-ctrl-attrib .mapbox-improve-map{font-weight:700;margin-left:2px}.mapboxgl-attrib-empty{display:none}.mapboxgl-ctrl-scale{background-color:#ffffffbf;border:2px solid #333;border-top:#333;box-sizing:border-box;color:#333;font-size:10px;padding:0 5px;white-space:nowrap}.mapboxgl-popup{display:flex;left:0;pointer-events:none;position:absolute;top:0;will-change:transform}.mapboxgl-popup-anchor-top,.mapboxgl-popup-anchor-top-left,.mapboxgl-popup-anchor-top-right{flex-direction:column}.mapboxgl-popup-anchor-bottom,.mapboxgl-popup-anchor-bottom-left,.mapboxgl-popup-anchor-bottom-right{flex-direction:column-reverse}.mapboxgl-popup-anchor-left{flex-direction:row}.mapboxgl-popup-anchor-right{flex-direction:row-reverse}.mapboxgl-popup-tip{border:10px solid #0000;height:0;width:0;z-index:1}.mapboxgl-popup-anchor-top .mapboxgl-popup-tip{align-self:center;border-bottom-color:#fff;border-top:none}.mapboxgl-popup-anchor-top-left .mapboxgl-popup-tip{align-self:flex-start;border-bottom-color:#fff;border-left:none;border-top:none}.mapboxgl-popup-anchor-top-right .mapboxgl-popup-tip{align-self:flex-end;border-bottom-color:#fff;border-right:none;border-top:none}.mapboxgl-popup-anchor-bottom .mapboxgl-popup-tip{align-self:center;border-bottom:none;border-top-color:#fff}.mapboxgl-popup-anchor-bottom-left .mapboxgl-popup-tip{align-self:flex-start;border-bottom:none;border-left:none;border-top-color:#fff}.mapboxgl-popup-anchor-bottom-right .mapboxgl-popup-tip{align-self:flex-end;border-bottom:none;border-right:none;border-top-color:#fff}.mapboxgl-popup-anchor-left .mapboxgl-popup-tip{align-self:center;border-left:none;border-right-color:#fff}.mapboxgl-popup-anchor-right .mapboxgl-popup-tip{align-self:center;border-left-color:#fff;border-right:none}.mapboxgl-popup-close-button{background-color:initial;border:0;border-radius:0 3px 0 0;cursor:pointer;position:absolute;right:0;top:0}.mapboxgl-popup-close-button:hover{background-color:#0000000d}.mapboxgl-popup-content{background:#fff;border-radius:3px;box-shadow:0 1px 2px #0000001a;padding:10px 10px 15px;pointer-events:auto;position:relative}.mapboxgl-popup-anchor-top-left .mapboxgl-popup-content{border-top-left-radius:0}.mapboxgl-popup-anchor-top-right .mapboxgl-popup-content{border-top-right-radius:0}.mapboxgl-popup-anchor-bottom-left .mapboxgl-popup-content{border-bottom-left-radius:0}.mapboxgl-popup-anchor-bottom-right .mapboxgl-popup-content{border-bottom-right-radius:0}.mapboxgl-popup-track-pointer{display:none}.mapboxgl-popup-track-pointer *{pointer-events:none;-webkit-user-select:none;user-select:none}.mapboxgl-map:hover .mapboxgl-popup-track-pointer{display:flex}.mapboxgl-map:active .mapboxgl-popup-track-pointer{display:none}.mapboxgl-marker{left:0;opacity:1;position:absolute;top:0;transition:opacity .2s;will-change:transform}.mapboxgl-user-location-dot,.mapboxgl-user-location-dot:before{background-color:#1da1f2;border-radius:50%;height:15px;width:15px}.mapboxgl-user-location-dot:before{animation:mapboxgl-user-location-dot-pulse 2s infinite;content:"";position:absolute}.mapboxgl-user-location-dot:after{border:2px solid #fff;border-radius:50%;box-shadow:0 0 3px #00000059;box-sizing:border-box;content:"";height:19px;left:-2px;position:absolute;top:-2px;width:19px}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading{height:0;width:0}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:after,.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:before{border-bottom:7.5px solid #4aa1eb;content:"";position:absolute}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:before{border-left:7.5px solid #0000;transform:translateY(-28px) skewY(-20deg)}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:after{border-right:7.5px solid #0000;transform:translate(7.5px,-28px) skewY(20deg)}@keyframes mapboxgl-user-location-dot-pulse{0%{opacity:1;transform:scale(1)}70%{opacity:0;transform:scale(3)}to{opacity:0;transform:scale(1)}}.mapboxgl-user-location-dot-stale{background-color:#aaa}.mapboxgl-user-location-dot-stale:after{display:none}.mapboxgl-user-location-accuracy-circle{background-color:#1da1f233;border-radius:100%;height:1px;width:1px}.mapboxgl-crosshair,.mapboxgl-crosshair .mapboxgl-interactive,.mapboxgl-crosshair .mapboxgl-interactive:active{cursor:crosshair}.mapboxgl-boxzoom{background:#fff;border:2px dotted #202020;height:0;left:0;opacity:.5;position:absolute;top:0;width:0}@media print{.mapbox-improve-map{display:none}}.mapboxgl-scroll-zoom-blocker,.mapboxgl-touch-pan-blocker{align-items:center;background:#000000b3;color:#fff;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;height:100%;justify-content:center;left:0;opacity:0;pointer-events:none;position:absolute;text-align:center;top:0;transition:opacity .75s ease-in-out;transition-delay:1s;width:100%}.mapboxgl-scroll-zoom-blocker-show,.mapboxgl-touch-pan-blocker-show{opacity:1;transition:opacity .1s ease-in-out}.mapboxgl-canvas-container.mapboxgl-touch-pan-blocker-override.mapboxgl-scrollable-page,.mapboxgl-canvas-container.mapboxgl-touch-pan-blocker-override.mapboxgl-scrollable-page .mapboxgl-canvas{touch-action:pan-x pan-y}.mapboxgl-ctrl-separator{background-color:#e0e0e0;height:1px}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button{color:#333;font-size:18px;font-weight:700;height:44px;width:44px}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button:hover{background-color:#f5f5f5}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button-selected{background-color:#4a5568;color:#fff}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button-selected:hover{background-color:#2d3748}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.auth-modal{background:var(--bg-primary);border-radius:var(--radius-xl);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;padding:2rem;position:relative;z-index:10000;pointer-events:auto}.modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:var(--radius-sm);transition:all .2s;z-index:10002}.modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.wizard-progress{display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-primary)}.progress-step{display:flex;align-items:center;gap:.75rem;opacity:.5;transition:opacity .3s}.step-number{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:2px solid var(--border-primary);font-weight:600;font-size:.875rem;color:var(--text-secondary);transition:all .3s}.step-info{display:flex;flex-direction:column}.step-title{font-weight:600;font-size:.875rem;color:var(--text-primary)}.auth-form{display:flex;flex-direction:column;gap:1.5rem;position:relative;z-index:1}.auth-form h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0}.auth-subtitle{color:var(--text-secondary);font-size:.95rem;margin-top:-1rem}.input-wrapper{position:relative;display:flex;align-items:center;z-index:1}.input-wrapper svg{position:absolute;left:1rem;color:var(--text-tertiary);pointer-events:none}.input,.select{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;font-family:inherit;transition:all .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none}.input:focus,.select:focus{outline:none;border-color:var(--primary-color, var(--input-focus));box-shadow:0 0 0 3px var(--primary-100, rgba(255, 107, 53, .1))}.input:disabled,.select:disabled{background:var(--bg-tertiary);color:var(--text-tertiary);cursor:not-allowed}.input-wrapper .input,.input-wrapper .select{padding-left:3rem;width:100%;pointer-events:auto;position:relative;z-index:2}.input-wrapper.has-password-toggle{position:relative}.input-wrapper.has-password-toggle .input{padding-right:3rem;width:100%}.password-toggle{position:absolute;right:1px;top:1px;bottom:1px;background:var(--bg-secondary);border:none;border-left:1px solid var(--border-primary);border-radius:0 calc(var(--radius-md) - 1px) calc(var(--radius-md) - 1px) 0;color:var(--text-tertiary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;z-index:10;width:2.75rem}.password-toggle:hover{color:var(--text-secondary)}.divider{display:flex;align-items:center;gap:1rem;margin:.5rem 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border-primary)}.divider span{color:var(--text-tertiary);font-size:.875rem;font-weight:500;text-transform:uppercase}.btn-google{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.75rem 1.5rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-weight:500;cursor:pointer;transition:all .2s}.btn-google:hover{background:var(--bg-tertiary);border-color:var(--border-secondary)}.btn-google img{width:20px;height:20px}.auth-switch{text-align:center;color:var(--text-secondary);font-size:.9rem}.link-button{background:transparent;border:none;color:var(--primary-color, var(--primary));font-weight:600;cursor:pointer;text-decoration:underline;transition:opacity .2s}.link-button:hover{opacity:.8}.checkbox-group{display:flex;flex-direction:column;gap:.75rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.9rem;color:var(--text-primary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-color, var(--primary));cursor:pointer}.textarea{width:100%;padding:.75rem 1rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;font-family:var(--font-family);resize:vertical;transition:all var(--transition-fast)}.textarea:focus{outline:none;border-color:var(--primary-color, var(--input-focus));box-shadow:0 0 0 3px var(--primary-100, rgba(255, 107, 53, .1))}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-primary)}.form-actions .btn-primary,.form-actions .btn-secondary{min-width:120px}.form-actions .btn-primary{flex:1}.error-message{padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#ef4444;font-size:.875rem;margin-top:.5rem}.spin{animation:spin 1s linear infinite}.client-portal-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-primary);text-align:center}.portal-text{color:var(--text-secondary);font-size:.95rem;margin-bottom:.75rem}.btn-ghost{background:transparent;color:var(--primary-color, var(--primary));border:2px solid var(--primary-color, var(--primary));padding:.75rem 1.5rem;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .2s}.btn-ghost:hover{background:var(--primary-color, var(--primary));color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}@media (max-width: 768px){.auth-modal{padding:1.5rem;max-width:100%;margin:1rem}.wizard-progress{flex-direction:column;gap:1rem;align-items:flex-start}.progress-step{width:100%}.form-actions{flex-direction:column}.form-actions .btn-secondary{order:2}.form-actions .btn-primary{order:1}}.booking-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;overflow-y:auto}.booking-modal{background:var(--bg-primary);border-radius:var(--radius-xl);max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;position:relative;z-index:10000;overflow:hidden}.booking-modal .modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:var(--radius-sm);transition:all .2s;z-index:10002}.booking-modal .modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-header{padding:2rem 2rem 1.5rem;border-bottom:1px solid var(--border-primary)}.modal-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.modal-header .shop-name{color:var(--text-secondary);font-size:.95rem;margin-bottom:1.5rem}.progress-bar{margin-top:1rem}.progress-steps{display:flex;justify-content:space-between;gap:1rem}.progress-step{display:flex;align-items:center;gap:.5rem;opacity:.5;transition:opacity .3s}.progress-step.active,.progress-step.completed{opacity:1}.step-number{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:2px solid var(--border-primary);font-weight:600;font-size:.75rem;color:var(--text-secondary);transition:all .3s}.progress-step.active .step-number,.progress-step.completed .step-number{background:var(--primary-color, var(--primary));border-color:var(--primary-color, var(--primary));color:#fff}.step-label{font-size:.875rem;color:var(--text-secondary);display:none}@media (min-width: 640px){.step-label{display:block}}.modal-body{flex:1;overflow-y:auto;padding:2rem;position:relative}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-secondary)}.loading-state .spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#ef4444;font-size:.875rem;margin-bottom:1rem}.booking-step h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.step-description{color:var(--text-secondary);font-size:.95rem;margin-bottom:2rem}.services-container{display:flex;flex-direction:column;gap:2rem}.service-category h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.service-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.service-card{background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-lg);padding:1rem;cursor:pointer;transition:all .2s}.service-card:hover{border-color:var(--primary-color, var(--primary));transform:translateY(-2px)}.service-card.selected{background:var(--primary-100, rgba(255, 107, 53, .1));border-color:var(--primary-color, var(--primary))}.service-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.service-header h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.service-check{width:24px;height:24px;border-radius:50%;background:var(--primary-color, var(--primary));color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.service-card.selected .service-check{opacity:1}.service-description{color:var(--text-secondary);font-size:.875rem;margin-bottom:.75rem;line-height:1.4}.service-details{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border-primary)}.service-duration{display:flex;align-items:center;gap:.25rem;color:var(--text-secondary);font-size:.875rem}.service-price{font-size:1.1rem;font-weight:600;color:var(--primary-color, var(--primary))}.selection-summary{margin-top:2rem;padding:1.5rem;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.selection-summary h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.summary-items{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.summary-item{display:flex;justify-content:space-between;color:var(--text-secondary);font-size:.9rem}.summary-total{display:flex;justify-content:space-between;padding-top:1rem;border-top:1px solid var(--border-primary);font-size:1.1rem;color:var(--text-primary)}.summary-duration{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;color:var(--text-secondary);font-size:.875rem}.datetime-container{display:flex;flex-direction:column;gap:2rem}.date-selection label,.time-selection label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.date-input{width:100%;max-width:300px;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;transition:all .2s}.date-input:focus{outline:none;border-color:var(--primary-color, var(--primary));box-shadow:0 0 0 3px var(--primary-100, rgba(255, 107, 53, .1))}.no-slots{color:var(--text-tertiary);font-style:italic}.time-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.time-slot{padding:.75rem 1rem;background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-weight:500;cursor:pointer;transition:all .2s}.time-slot:hover{border-color:var(--primary-color, var(--primary));transform:translateY(-2px)}.time-slot.selected{background:var(--primary-color, var(--primary));border-color:var(--primary-color, var(--primary));color:#fff}.contact-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.form-input,.form-textarea{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;font-family:inherit;transition:all .2s}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--primary-color, var(--primary));box-shadow:0 0 0 3px var(--primary-100, rgba(255, 107, 53, .1))}.form-textarea{resize:vertical;min-height:80px}.confirmation-details{display:flex;flex-direction:column;gap:2rem}.detail-section{padding:1.5rem;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.detail-section h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.detail-section h4{font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-top:1rem;margin-bottom:.5rem}.detail-item{display:flex;justify-content:space-between;margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem}.detail-total{display:flex;justify-content:space-between;padding-top:.75rem;margin-top:.75rem;border-top:1px solid var(--border-primary);font-size:1rem;color:var(--text-primary)}.detail-section p{color:var(--text-primary);margin-bottom:.5rem}.detail-section .duration{color:var(--text-secondary);font-size:.875rem;margin-top:.5rem}.detail-section .notes{color:var(--text-secondary);font-style:italic;font-size:.875rem;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--radius-md);margin-top:.5rem}.confirmation-overlay{position:absolute;inset:0;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:100}.confirmation-content{text-align:center;padding:2rem}.confirmation-icon{width:80px;height:80px;margin:0 auto 1.5rem;background:var(--primary-color, var(--primary));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.confirmation-content h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.confirmation-content p{color:var(--text-secondary);margin-bottom:1.5rem}.confirmation-summary{padding:1rem;background:var(--bg-secondary);border-radius:var(--radius-lg);margin-bottom:1rem}.confirmation-summary p{margin:.25rem 0;color:var(--text-primary)}.confirmation-note{font-size:.875rem;color:var(--text-tertiary)}.modal-footer{display:flex;gap:1rem;justify-content:space-between;padding:1.5rem 2rem;border-top:1px solid var(--border-primary);background:var(--bg-primary)}.modal-footer .btn-secondary,.modal-footer .btn-primary{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:.95rem}.modal-footer .btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary)}.modal-footer .btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);transform:translateY(-2px)}.modal-footer .btn-primary{background:var(--primary-color, var(--primary));color:#fff;flex:1;justify-content:center}.modal-footer .btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-2px);box-shadow:var(--shadow-md)}.modal-footer button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.booking-modal{max-width:100%;margin:1rem;max-height:calc(100vh - 2rem)}.modal-header{padding:1.5rem 1.5rem 1rem}.modal-body{padding:1.5rem}.service-cards{grid-template-columns:1fr}.time-slots{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.modal-footer{padding:1rem 1.5rem}.progress-steps{justify-content:center}.progress-step{flex-direction:column;gap:.25rem}}.reschedule-modal{position:relative;background:#fff;border-radius:12px;width:90%;max-width:500px;box-shadow:0 10px 40px #0003;animation:modalFadeIn .3s ease}.reschedule-modal .modal-header{padding:24px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.reschedule-modal .modal-header h2{margin:0;font-size:24px;font-weight:600;color:#1f2937}.reschedule-modal .close-btn{background:none;border:none;cursor:pointer;color:#6b7280;transition:color .2s;padding:4px;display:flex;align-items:center;justify-content:center}.reschedule-modal .close-btn:hover{color:#1f2937}.reschedule-modal .modal-body{padding:24px}.reschedule-modal .current-appointment{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-bottom:24px}.reschedule-modal .current-appointment h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.reschedule-modal .appointment-info{display:flex;gap:20px}.reschedule-modal .info-item{display:flex;align-items:center;gap:8px;color:#374151;font-size:14px}.reschedule-modal .info-item svg{color:#9ca3af}.reschedule-modal .reschedule-form{margin-bottom:24px}.reschedule-modal .form-group{margin-bottom:20px}.reschedule-modal .form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:#374151}.reschedule-modal .form-control{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;color:#1f2937;background:#fff;transition:border-color .2s}.reschedule-modal .form-control:focus{outline:none;border-color:#ff6b35;box-shadow:0 0 0 3px #ff6b351a}.reschedule-modal .no-times-message{padding:12px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#991b1b;font-size:14px;text-align:center;margin:0}.reschedule-modal .modal-actions{display:flex;gap:12px;justify-content:flex-end}.reschedule-modal .btn-primary,.reschedule-modal .btn-secondary{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.reschedule-modal .btn-primary{background:#ff6b35;color:#fff}.reschedule-modal .btn-primary:hover:not(:disabled){background:#e55a2b}.reschedule-modal .btn-primary:disabled{background:#d1d5db;cursor:not-allowed}.reschedule-modal .btn-secondary{background:#f3f4f6;color:#4b5563}.reschedule-modal .btn-secondary:hover:not(:disabled){background:#e5e7eb}.reschedule-modal .btn-secondary:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.reschedule-modal{width:95%}.reschedule-modal .appointment-info{flex-direction:column;gap:8px}.reschedule-modal .modal-actions{flex-direction:column-reverse}.reschedule-modal .btn-primary,.reschedule-modal .btn-secondary{width:100%}}.cancel-modal{position:relative;background:#fff;border-radius:12px;width:90%;max-width:500px;box-shadow:0 10px 40px #0003;animation:modalFadeIn .3s ease}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.cancel-modal .modal-header{padding:24px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;position:relative}.cancel-modal .modal-header.warning{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-bottom:1px solid #fecaca}.cancel-modal .header-icon{margin-right:12px;color:#dc2626;display:flex;align-items:center}.cancel-modal .modal-header h2{margin:0;font-size:24px;font-weight:600;color:#1f2937;flex:1}.cancel-modal .close-btn{background:none;border:none;cursor:pointer;color:#6b7280;transition:color .2s;padding:4px;display:flex;align-items:center;justify-content:center;position:absolute;right:16px;top:50%;transform:translateY(-50%)}.cancel-modal .close-btn:hover{color:#1f2937}.cancel-modal .modal-body{padding:24px}.cancel-modal .warning-message{margin-bottom:24px}.cancel-modal .warning-message p{margin:0;font-size:16px;color:#374151;font-weight:500}.cancel-modal .appointment-details{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-bottom:20px}.cancel-modal .appointment-details h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.cancel-modal .detail-list{display:flex;flex-direction:column;gap:10px}.cancel-modal .detail-item{display:flex;align-items:center;gap:8px;color:#374151;font-size:14px}.cancel-modal .detail-item svg{color:#9ca3af}.cancel-modal .service-name{font-weight:500;color:#1f2937}.cancel-modal .cancellation-policy{background:#fef3c7;border:1px solid #fde68a;border-radius:8px;padding:16px;margin-bottom:24px}.cancel-modal .policy-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.cancel-modal .policy-header svg{color:#d97706}.cancel-modal .policy-header h3{margin:0;font-size:14px;font-weight:600;color:#92400e;text-transform:uppercase;letter-spacing:.5px}.cancel-modal .policy-content{color:#78350f;font-size:14px;line-height:1.6}.cancel-modal .policy-content p{margin:0}.cancel-modal .policy-notice{display:flex;align-items:flex-start;gap:8px;padding:12px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:6px;margin-bottom:24px}.cancel-modal .policy-notice svg{color:#0284c7;flex-shrink:0;margin-top:2px}.cancel-modal .policy-notice p{margin:0;font-size:14px;color:#075985;line-height:1.5}.cancel-modal .modal-actions{display:flex;gap:12px;justify-content:flex-end}.cancel-modal .btn-secondary,.cancel-modal .btn-danger{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.cancel-modal .btn-secondary{background:#f3f4f6;color:#4b5563}.cancel-modal .btn-secondary:hover:not(:disabled){background:#e5e7eb}.cancel-modal .btn-danger{background:#ef4444;color:#fff}.cancel-modal .btn-danger:hover:not(:disabled){background:#dc2626}.cancel-modal .btn-secondary:disabled,.cancel-modal .btn-danger:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.cancel-modal{width:95%}.cancel-modal .modal-header h2{font-size:20px}.cancel-modal .modal-actions{flex-direction:column-reverse}.cancel-modal .btn-secondary,.cancel-modal .btn-danger{width:100%}}.shop-landing-new{display:flex;height:100vh;background:var(--bg-primary);position:relative;overflow:hidden}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary);color:var(--text-primary)}.spinner{width:48px;height:48px;border:3px solid var(--border-primary);border-top-color:var(--primary-color, var(--primary));border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sidebar-nav{width:250px;background:var(--bg-secondary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;transition:width .3s ease;position:relative;z-index:100}.sidebar-nav.closed{width:60px}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;min-height:80px}.sidebar-nav.closed .sidebar-header h2{display:none}.sidebar-header h2{font-size:1.25rem;font-weight:700;color:var(--primary-color, var(--primary));margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-toggle{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all .2s}.sidebar-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-menu{flex:1;padding:1rem 0;overflow-y:auto}.nav-item{width:100%;padding:1rem 1.5rem;background:transparent;border:none;color:var(--text-secondary);display:flex;align-items:center;gap:1rem;cursor:pointer;transition:all .2s;text-align:left;font-size:.95rem;font-weight:500;position:relative}.sidebar-nav.closed .nav-item{padding:1rem;justify-content:center}.sidebar-nav.closed .nav-item span{display:none}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--primary-100, rgba(255, 107, 53, .1));color:var(--primary-color, var(--primary))}.nav-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary-color, var(--primary))}.sidebar-footer{padding:1.5rem;border-top:1px solid var(--border-primary)}.main-content{flex:1;overflow-y:auto;padding:2rem;background:var(--bg-primary)}.section-content{max-width:1200px;margin:0 auto}.section-content h2{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:2rem}.welcome-section .welcome-hero{text-align:center;padding:2rem 0}.welcome-hero h1{font-size:3rem;font-weight:800;color:var(--text-primary);margin-bottom:1rem;line-height:1.2}.hero-subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:2rem}.welcome-message{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:1.5rem;margin:2rem auto;max-width:600px;border:1px solid var(--border-primary)}.hero-actions{display:flex;gap:1rem;justify-content:center;margin:2rem 0}.quick-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:3rem}.info-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .3s;text-decoration:none;color:var(--text-primary)}.info-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-color, var(--primary))}.info-card.clickable{cursor:pointer}.info-card.clickable:hover{background:var(--bg-tertiary)}.info-card svg{color:var(--primary-color, var(--primary))}.about-content{max-width:800px}.about-content p{font-size:1.1rem;line-height:1.8;color:var(--text-secondary);margin-bottom:2rem}.mission-block,.team-block{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:2rem;margin:2rem 0;border:1px solid var(--border-primary)}.mission-block h3,.team-block h3{color:var(--primary-color, var(--primary));margin-bottom:1rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:2rem}.feature{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.feature-icon{color:var(--primary-color, var(--primary));flex-shrink:0}.service-category{margin-bottom:3rem}.service-category h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary-color, var(--primary));display:inline-block}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.service-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:1.5rem;cursor:pointer;transition:all .3s}.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-color, var(--primary))}.service-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.service-header h4{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.service-price{font-size:1.25rem;font-weight:700;color:var(--primary-color, var(--primary))}.service-description{color:var(--text-secondary);line-height:1.6;margin-bottom:1rem;font-size:.95rem}.service-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border-primary)}.service-duration{display:flex;align-items:center;gap:.5rem;color:var(--text-tertiary);font-size:.9rem}.service-arrow{color:var(--primary-color, var(--primary))}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.gallery-item{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-secondary);aspect-ratio:1}.gallery-item img{width:100%;height:100%;object-fit:cover}.photo-caption{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);color:#fff;font-size:.9rem}.hours-location-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.hours-card,.location-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:2rem;position:relative}.hours-card h3,.location-card h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem}.hours-list{space-y:.75rem}.hours-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border-primary)}.hours-row:last-child{border-bottom:none}.day{font-weight:500;color:var(--text-primary)}.time{color:var(--text-secondary)}.location-info{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.address{display:flex;align-items:flex-start;gap:.75rem;color:var(--text-secondary);line-height:1.6}.address svg{flex-shrink:0;margin-top:.25rem;color:var(--primary-color, var(--primary))}.contact-link{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);text-decoration:none;transition:color .2s}.contact-link:hover{color:var(--primary-color, var(--primary))}.contact-link svg{color:var(--primary-color, var(--primary))}.map-container{width:100%;height:300px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-primary);margin-top:1.5rem}.map-box{width:100%;height:100%}.map-fallback{width:100%;height:300px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);margin-top:1.5rem}.map-placeholder{text-align:center;padding:2rem}.map-placeholder p{color:var(--text-secondary);margin-bottom:1rem;font-size:1.1rem}.mapboxgl-popup-content{background:var(--bg-primary, #1a1a1a)!important;color:var(--text-primary, #fff)!important;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:0!important}.mapboxgl-popup-content>div{padding:1rem}.mapboxgl-popup-anchor-top .mapboxgl-popup-tip,.mapboxgl-popup-anchor-bottom .mapboxgl-popup-tip,.mapboxgl-popup-anchor-left .mapboxgl-popup-tip,.mapboxgl-popup-anchor-right .mapboxgl-popup-tip{border-color:transparent!important}.mapboxgl-popup-anchor-top .mapboxgl-popup-tip{border-bottom-color:var(--bg-primary, #1a1a1a)!important}.mapboxgl-popup-close-button{color:var(--text-secondary);font-size:18px;padding:.5rem}.mapboxgl-popup-close-button:hover{color:var(--text-primary);background:transparent}.mapboxgl-ctrl-attrib{display:none!important}.policies-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.policy-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:1.5rem}.policy-card h3{font-size:1.1rem;font-weight:600;color:var(--primary-color, var(--primary));margin-bottom:1rem}.policy-card p{color:var(--text-secondary);line-height:1.7}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:3rem}.contact-info,.social-media{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:2rem}.contact-info h3,.social-media h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem}.contact-list{display:flex;flex-direction:column;gap:1.5rem}.contact-item{display:flex;align-items:center;gap:1rem;color:var(--text-secondary);text-decoration:none;transition:color .2s}.contact-item:hover{color:var(--primary-color, var(--primary))}.contact-item svg{color:var(--primary-color, var(--primary));flex-shrink:0}.contact-label{display:block;font-size:.875rem;color:var(--text-tertiary);margin-bottom:.25rem}.contact-value{display:block;font-weight:500}.social-links{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.social-link{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;transition:all .2s}.social-link:hover{background:var(--primary-100, rgba(255, 107, 53, .1));border-color:var(--primary-color, var(--primary));color:var(--primary-color, var(--primary));transform:translateY(-2px)}.contact-cta{text-align:center;padding:3rem;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.contact-cta h3{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem}.contact-cta p{color:var(--text-secondary);margin-bottom:2rem}.no-content{text-align:center;color:var(--text-tertiary);padding:3rem;font-size:1.1rem}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border-radius:var(--radius-md);font-weight:600;font-size:.95rem;border:none;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background:var(--primary-color, var(--primary));color:#fff}.btn-primary:hover{background:var(--primary-600, var(--primary-hover));transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-secondary:hover{background:var(--bg-elevated);border-color:var(--primary-color, var(--primary));color:var(--primary-color, var(--primary))}.btn-primary.large,.btn-secondary.large{padding:1rem 2rem;font-size:1.05rem}.full-width{width:100%}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--bg-primary);border-radius:var(--radius-xl);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.service-modal{padding:2rem}.modal-close{position:absolute;top:1rem;right:1rem;background:var(--bg-tertiary);border:none;border-radius:var(--radius-md);padding:.5rem;cursor:pointer;color:var(--text-secondary);transition:all .2s}.modal-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-right:2rem}.modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.modal-price{font-size:1.5rem;font-weight:700;color:var(--primary-color, var(--primary))}.modal-body{margin-bottom:1.5rem}.modal-description{color:var(--text-secondary);line-height:1.7;margin-bottom:1.5rem}.modal-details{display:flex;flex-direction:column;gap:1rem}.detail-item{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary)}.detail-item svg{color:var(--primary-color, var(--primary))}.modal-footer{padding-top:1.5rem;border-top:1px solid var(--border-primary)}.user-indicator{display:flex;align-items:center;gap:.75rem;padding:1rem;margin:0 1rem 1rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-color, var(--primary));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.2rem;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{display:block;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{display:block;font-size:.85rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-logout{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:var(--radius-sm);transition:all .2s}.btn-logout:hover{background:var(--bg-tertiary);color:var(--primary-color, var(--primary))}.appointments-section,.profile-section,.rewards-section{padding:2rem}.empty-state{text-align:center;padding:3rem 2rem;max-width:400px;margin:0 auto}.empty-icon{color:var(--text-tertiary);margin-bottom:1.5rem}.empty-state h3{font-size:1.5rem;margin-bottom:.5rem;color:var(--text-primary)}.empty-state p{color:var(--text-secondary);margin-bottom:1.5rem}.text-secondary{color:var(--text-secondary)}.profile-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:2rem;border:1px solid var(--border-primary)}.profile-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-primary)}.profile-avatar{width:80px;height:80px;border-radius:50%;background:var(--primary-color, var(--primary));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:2rem}.profile-info h3{margin:0 0 .5rem;color:var(--text-primary)}.profile-info p{margin:.25rem 0;color:var(--text-secondary)}.profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-primary)}.stat-item{text-align:center}.stat-value{display:block;font-size:2rem;font-weight:700;color:var(--primary-color, var(--primary));margin-bottom:.25rem}.stat-label{display:block;font-size:.9rem;color:var(--text-secondary)}.profile-preferences h4{margin:0 0 1rem;color:var(--text-primary)}.profile-preferences p{margin:.5rem 0;color:var(--text-secondary)}.profile-preferences ul{margin:.5rem 0 0 1.5rem;padding:0;list-style:disc}.profile-preferences li{color:var(--text-secondary);margin:.25rem 0}.mobile-only{display:none}.desktop-only{display:block}.mobile-header{display:none;position:sticky;top:0;height:60px;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);padding:0 1rem;align-items:center;justify-content:space-between;z-index:90}.mobile-header h2{font-size:1.1rem;font-weight:700;color:var(--primary-color, var(--primary))}.mobile-menu-btn,.mobile-book-btn{background:transparent;border:none;color:var(--text-primary);padding:.5rem;cursor:pointer}.mobile-book-btn{background:var(--primary-color, var(--primary));color:#fff;border-radius:var(--radius-md);padding:.5rem 1rem;font-weight:600}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:89}@media (max-width: 1024px){.hours-location-grid,.contact-grid{grid-template-columns:1fr}}@media (max-width: 768px){.shop-landing-new{flex-direction:column}.mobile-only{display:flex}.desktop-only{display:none}.mobile-header{display:flex}.sidebar-nav{position:fixed;top:60px;left:0;bottom:0;width:250px;transform:translate(-100%);transition:transform .3s ease;z-index:91}.sidebar-nav.open{transform:translate(0)}.sidebar-nav.closed{transform:translate(-100%);width:250px}.sidebar-overlay{display:block}.main-content{padding:1rem;padding-top:0}.welcome-hero h1{font-size:2rem}.hero-subtitle{font-size:1.1rem}.hero-actions{flex-direction:column}.quick-info-grid{grid-template-columns:1fr 1fr}.services-grid{grid-template-columns:1fr}.gallery-grid{grid-template-columns:repeat(2,1fr)}.social-links{grid-template-columns:1fr}}@media (max-width: 480px){.quick-info-grid,.gallery-grid{grid-template-columns:1fr}}.appointments-list{display:flex;flex-direction:column;gap:1rem}.appointment-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:1.5rem;transition:all .2s}.appointment-card:hover{border-color:var(--primary-color, var(--primary));transform:translateY(-2px);box-shadow:var(--shadow-md)}.appointment-card.past{opacity:.7}.appointment-card.cancelled{opacity:.6;background:var(--bg-tertiary)}.appointment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-primary)}.appointment-date{display:flex;align-items:center;gap:.5rem;color:var(--text-primary);font-weight:600}.appointment-status{padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.875rem;font-weight:500;text-transform:capitalize}.appointment-status.pending{background:#ffc1071a;color:#ffc107;border:1px solid rgba(255,193,7,.3)}.appointment-status.confirmed{background:#4caf501a;color:#4caf50;border:1px solid rgba(76,175,80,.3)}.appointment-status.cancelled{background:#f443361a;color:#f44336;border:1px solid rgba(244,67,54,.3)}.appointment-time,.appointment-services,.appointment-total,.appointment-notes{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem;color:var(--text-secondary)}.appointment-time svg,.appointment-services svg,.appointment-total svg,.appointment-notes svg{flex-shrink:0;margin-top:2px}.appointment-time .duration{color:var(--text-tertiary);margin-left:.5rem}.services-list{display:flex;flex-direction:column;gap:.25rem}.service-item{color:var(--text-primary)}.appointment-total{color:var(--text-primary);font-weight:600;font-size:1.1rem}.appointment-actions{display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-primary)}.btn-secondary.small,.btn-ghost.small{padding:.5rem 1rem;font-size:.875rem}.text-danger{color:#f44336!important}.text-danger:hover{background:#f443361a!important;border-color:#f44336!important}� �/�*� �B�a�r�b�e�r� �S�i�g�n� �I�n� �F�o�o�t�e�r� �*�/� � �.�b�a�r�b�e�r�-�s�i�g�n�i�n�-�f�o�o�t�e�r� �{� � � � �p�o�s�i�t�i�o�n�:� �f�i�x�e�d�;� � � � �b�o�t�t�o�m�:� �2�0�p�x�;� � � � �r�i�g�h�t�:� �2�0�p�x�;� � � � �z�-�i�n�d�e�x�:� �1�0�;� � � � �b�a�c�k�g�r�o�u�n�d�:� �v�a�r�(�-�-�b�g�-�e�l�e�v�a�t�e�d�)�;� � � � �p�a�d�d�i�n�g�:� �0�.�5�r�e�m� �1�r�e�m�;� � � � �b�o�r�d�e�r�-�r�a�d�i�u�s�:� �2�0�p�x�;� � � � �b�o�x�-�s�h�a�d�o�w�:� �0� �2�p�x� �1�0�p�x� �r�g�b�a�(�0�,� �0�,� �0�,� �0�.�2�)�;� � �}� � � .appointment-management-container{min-height:100vh;background:var(--bg-primary);padding:2rem}.appointment-management-content{max-width:800px;margin:0 auto}.back-button{display:inline-flex;align-items:center;gap:.5rem;background:transparent;border:1px solid var(--border-primary);color:var(--text-secondary);padding:.5rem 1rem;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;margin-bottom:2rem;font-size:.9rem}.back-button:hover{background:var(--bg-secondary);border-color:var(--primary-color, var(--primary));color:var(--primary-color, var(--primary))}.appointment-card-large{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-lg)}.appointment-header-large{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--border-primary)}.appointment-header-large h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.status-badge{padding:.5rem 1rem;border-radius:var(--radius-full);font-size:.95rem;font-weight:600;text-transform:capitalize}.status-badge.pending{background:#ffc10726;color:#ffc107;border:1px solid rgba(255,193,7,.4)}.status-badge.confirmed{background:#4caf5026;color:#4caf50;border:1px solid rgba(76,175,80,.4)}.status-badge.cancelled{background:#f4433626;color:#f44336;border:1px solid rgba(244,67,54,.4)}.status-badge.rescheduled{background:#9c27b026;color:#9c27b0;border:1px solid rgba(156,39,176,.4)}.status-message{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-radius:var(--radius-lg);margin-bottom:2rem;font-weight:500}.status-message.cancelled{background:#f443361a;color:#f44336;border:1px solid rgba(244,67,54,.3)}.status-message.rescheduled{background:#9c27b01a;color:#9c27b0;border:1px solid rgba(156,39,176,.3)}.status-message.past{background:#9e9e9e1a;color:#9e9e9e;border:1px solid rgba(158,158,158,.3)}.shop-info-section{background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem;border:1px solid var(--border-primary)}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;color:var(--primary-color, var(--primary))}.section-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.shop-details{display:flex;flex-direction:column;gap:.75rem}.appointment-details-section{display:flex;flex-direction:column;gap:1.5rem}.detail-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.detail-item{display:flex;align-items:flex-start;gap:.75rem}.detail-item svg{flex-shrink:0;margin-top:3px;color:var(--primary-color, var(--primary))}.detail-item>div{flex:1;display:flex;flex-direction:column;gap:.25rem}.detail-item label{font-size:.875rem;color:var(--text-tertiary);font-weight:500}.detail-item span{color:var(--text-primary);font-weight:600}.services-section{background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:1.5rem;border:1px solid var(--border-primary)}.services-section .services-list{display:flex;flex-direction:column;gap:.75rem}.services-section .service-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.service-name{color:var(--text-primary);font-weight:500}.service-price{color:var(--primary-color, var(--primary));font-weight:700;font-size:1.1rem}.total-section{display:flex;align-items:center;gap:.75rem;padding:1.5rem;background:var(--primary-100, rgba(255, 107, 53, .1));border-radius:var(--radius-lg);border:1px solid var(--primary-color, var(--primary))}.total-section svg{color:var(--primary-color, var(--primary));flex-shrink:0}.total-section>div{flex:1;display:flex;justify-content:space-between;align-items:center}.total-section label{font-size:1rem;color:var(--text-secondary);font-weight:600}.total-amount{font-size:1.75rem;font-weight:700;color:var(--primary-color, var(--primary))}.notes-section{padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.notes-section label{display:block;font-size:.875rem;color:var(--text-tertiary);font-weight:500;margin-bottom:.5rem}.notes-section p{color:var(--text-primary);line-height:1.6;margin:0}.appointment-actions-large{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:2px solid var(--border-primary)}.btn-danger{background:#f443361a;color:#f44336;border:1px solid rgba(244,67,54,.3);padding:.875rem 1.5rem;border-radius:var(--radius-md);font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s}.btn-danger:hover{background:#f4433633;border-color:#f44336;transform:translateY(-2px);box-shadow:var(--shadow-md)}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center}.error-state svg{color:var(--text-tertiary);margin-bottom:1rem}.error-state h2{color:var(--text-primary);margin-bottom:.5rem}.error-state p{color:var(--text-secondary)}.spinner-large{width:64px;height:64px;border:4px solid var(--border-primary);border-top-color:var(--primary-color, var(--primary));border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.modal-container-large{background:var(--bg-primary);border-radius:var(--radius-xl);max-width:900px;width:100%;max-height:90vh;overflow-y:auto}.appointment-status.rescheduled{background:#9c27b01a;color:#9c27b0;border:1px solid rgba(156,39,176,.3)}@media (max-width: 768px){.appointment-management-container{padding:1rem}.appointment-card-large{padding:1.5rem}.appointment-header-large{flex-direction:column;align-items:flex-start;gap:1rem}.detail-row,.appointment-actions-large{grid-template-columns:1fr}}.credentials-grid-2x2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:1.5rem;margin-bottom:3rem;max-width:100%}.credentials-grid-2x2>*{grid-column:span 1}.credential-card{background:var(--bg-tertiary);padding:1.25rem;border-radius:var(--radius-md);border:1px solid var(--border-primary);min-height:80px}.credential-card h4{color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;font-weight:600;opacity:.8}.credential-card p{color:var(--text-primary);font-size:1rem;line-height:1.4;margin:0;word-wrap:break-word}.credentials-block{margin-bottom:3rem}.credentials-block h3{margin-bottom:1rem}.features-badges{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:2rem}.feature-badge{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-primary);transition:all .2s}.feature-badge:hover{background:var(--bg-hover);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.badge-icon{color:var(--primary);width:20px;height:20px;flex-shrink:0}.feature-badge span{color:var(--text-primary);font-size:.95rem;font-weight:500}@media (max-width: 768px){.credentials-grid-2x2{grid-template-columns:1fr;gap:1rem}.features-badges{grid-template-columns:1fr}}.theme-toggle-container{padding:1rem;border-top:1px solid var(--border-primary);margin-top:auto}.theme-toggle-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s;border-radius:var(--radius-md);font-size:.95rem}.theme-toggle-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.toggle-switch{width:44px;height:24px;background:var(--bg-tertiary);border-radius:12px;position:relative;transition:background .3s;border:1px solid var(--border-primary)}.toggle-switch.active{background:var(--primary-color, var(--primary));border-color:var(--primary-color, var(--primary))}.toggle-slider{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s;box-shadow:0 2px 4px #0003}.toggle-switch.active .toggle-slider{transform:translate(20px)}.payment-section{max-width:800px;margin:0 auto}.payment-card{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--border-primary)}.payment-card h3{color:var(--text-primary);font-size:1.125rem;margin-bottom:1rem;font-weight:600}.payment-methods-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.payment-method-item{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-secondary)}.payment-method-icon{color:var(--primary);flex-shrink:0}.payment-method-item span{color:var(--text-primary);font-size:.95rem;font-weight:500}.tax-notice{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-secondary)}.tax-notice p{color:var(--text-secondary);font-size:.875rem;font-style:italic}.payment-apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.payment-app-card{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-secondary);transition:all .2s}.payment-app-card:hover{background:var(--bg-hover);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.payment-app-icon{color:var(--primary);flex-shrink:0}.payment-app-info{display:flex;flex-direction:column;gap:.25rem}.payment-app-name{color:var(--text-primary);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.payment-app-handle{color:var(--text-secondary);font-size:.875rem}.deposit-card{background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-elevated));border:2px solid var(--primary)}.deposit-content{display:flex;flex-direction:column;gap:1rem}.deposit-amount{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-primary)}.deposit-icon{color:var(--primary)}.deposit-amount .amount{color:var(--primary);font-size:1.25rem;font-weight:700}.deposit-text{color:var(--text-secondary);font-size:.95rem}.deposit-policy{color:var(--text-secondary);font-size:.875rem;line-height:1.5;margin:0}@media (max-width: 768px){.payment-methods-grid,.payment-apps-grid{grid-template-columns:1fr}}.client-portal-section{padding:1rem;border-top:1px solid var(--border-primary)}.auth-buttons-container{display:flex;flex-direction:column;gap:.75rem;align-items:center}.auth-btn{padding:.625rem 1.25rem!important;font-size:.875rem!important;width:auto!important;min-width:140px!important}.gallery-lightbox{position:fixed;inset:0;background:#000000f2;z-index:10000;display:flex;align-items:center;justify-content:center;padding:2rem;cursor:zoom-out}.lightbox-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;cursor:default}.lightbox-image{max-width:100%;max-height:80vh;object-fit:contain;border-radius:var(--radius-md);box-shadow:0 20px 60px #00000080}.lightbox-close{position:absolute;top:-40px;right:-40px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lightbox-close:hover{background:#fff3;transform:scale(1.1)}.lightbox-caption{color:#fff;margin-top:1.5rem;text-align:center;font-size:1rem;line-height:1.5;max-width:600px;opacity:.9}.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10001}.lightbox-nav:hover{background:#fff3;transform:translateY(-50%) scale(1.1)}.lightbox-prev{left:5%}.lightbox-next{right:5%}.lightbox-counter{position:absolute;bottom:-40px;color:#fff;font-size:.875rem;opacity:.7;letter-spacing:.1em}@media (max-width: 768px){.gallery-lightbox{padding:1rem}.lightbox-close{top:10px;right:10px;position:fixed;width:35px;height:35px}.lightbox-nav{width:40px;height:40px;position:fixed}.lightbox-prev{left:3%}.lightbox-next{right:3%}.lightbox-caption{font-size:.875rem;margin-top:1rem}.lightbox-counter{bottom:20px;position:fixed}}
