:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", sans-serif;--font-display: "Inter", system-ui, sans-serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--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);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55)}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-elevated: #ffffff;--bg-overlay: rgba(0, 0, 0, .5);--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-inverse: #ffffff;--border-primary: #e2e8f0;--border-secondary: #cbd5e1;--border-focus: #3b82f6;--primary: #6366f1;--primary-hover: #4f46e5;--primary-light: #eef2ff;--primary-dark: #3730a3;--success: #10b981;--success-light: #d1fae5;--success-dark: #047857;--warning: #f59e0b;--warning-light: #fef3c7;--warning-dark: #d97706;--error: #ef4444;--error-light: #fee2e2;--error-dark: #dc2626;--toggle-bg: #cbd5e1;--toggle-bg-hover: #94a3b8;--toggle-thumb: #ffffff;--toggle-icon: #f59e0b;--gradient-primary: linear-gradient(135deg, #1f1f1f 0%, #3f3f3f 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-hero: linear-gradient(135deg, #1f1f1f 0%, #3f3f3f 50%, #5a5a5a 100%);--gradient-accent: linear-gradient(135deg, #d4a574 0%, #c9965f 100%);--accent-gold: #d4a574;--accent-nude: #e5c9b0;--accent-brown: #8b6f47}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-elevated: #1e293b;--bg-overlay: rgba(0, 0, 0, .7);--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-tertiary: #64748b;--text-inverse: #0f172a;--border-primary: #334155;--border-secondary: #475569;--border-focus: #6366f1;--primary: #818cf8;--primary-hover: #a5b4fc;--primary-light: #312e81;--primary-dark: #c7d2fe;--success: #34d399;--success-light: #064e3b;--success-dark: #6ee7b7;--warning: #fbbf24;--warning-light: #78350f;--warning-dark: #fde047;--error: #f87171;--error-light: #7f1d1d;--error-dark: #fca5a5;--toggle-bg: #334155;--toggle-bg-hover: #475569;--toggle-thumb: #1e293b;--toggle-icon: #fbbf24;--gradient-primary: linear-gradient(135deg, #2a2a2a 0%, #4a4a4a 100%);--gradient-success: linear-gradient(135deg, #34d399 0%, #10b981 100%);--gradient-hero: linear-gradient(135deg, #2a2a2a 0%, #4a4a4a 50%, #6a6a6a 100%);--gradient-accent: linear-gradient(135deg, #d4a574 0%, #c9965f 100%);--accent-gold: #d4a574;--accent-nude: #e5c9b0;--accent-brown: #8b6f47}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;transition:background-color var(--transition-base),color var(--transition-base);min-height:100vh;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;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(--space-md);color:var(--text-secondary)}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-hover)}::-webkit-scrollbar{width:10px;height:10px}::-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)}@media(max-width:768px){html{font-size:16px}body{font-size:1rem}button,a,input,select,textarea{-webkit-tap-highlight-color:rgba(0,0,0,.1)}*{-webkit-overflow-scrolling:touch}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}h5{font-size:1rem}h6{font-size:.9375rem}}@media(max-width:375px){h1{font-size:1.625rem}h2{font-size:1.375rem}h3{font-size:1.125rem}}.theme-toggle{position:relative;background:none;border:none;cursor:pointer;padding:0;width:60px;height:32px}.theme-toggle-track{position:relative;width:100%;height:100%;background:var(--toggle-bg);border-radius:16px;transition:background-color .3s ease;box-shadow:inset 0 2px 4px #0000001a}.theme-toggle-thumb{position:absolute;top:2px;left:2px;width:28px;height:28px;background:var(--toggle-thumb);border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003}.theme-toggle-thumb svg{width:16px;height:16px;color:var(--toggle-icon)}[data-theme=dark] .theme-toggle-thumb{transform:translate(28px)}.theme-toggle:hover .theme-toggle-track{background:var(--toggle-bg-hover)}.theme-toggle:focus{outline:none}.theme-toggle:focus-visible .theme-toggle-track{outline:2px solid var(--primary);outline-offset:2px}.calendar{background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-md);border:1px solid var(--border-primary);max-width:100%;overflow:hidden}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl)}.calendar-month{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.calendar-nav-btn{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);width:36px;height:36px}.calendar-nav-btn svg{width:20px;height:20px;color:var(--text-primary)}.calendar-nav-btn:hover{background:var(--bg-tertiary);border-color:var(--primary);transform:scale(1.05)}.calendar-days-header{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-xs);margin-bottom:var(--space-sm)}.calendar-day-name{text-align:center;font-size:.875rem;font-weight:600;color:var(--text-secondary);padding:var(--space-sm)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-xs);width:100%;max-width:100%}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xs);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);position:relative;background:var(--bg-primary);border:2px solid transparent;min-height:60px}.calendar-day.empty{cursor:default;background:transparent}.calendar-day:not(.empty):not(.past):hover{background:var(--bg-secondary);border-color:var(--primary);transform:scale(1.05)}.calendar-day.past{opacity:.4;cursor:not-allowed}.calendar-day.today{border-color:var(--primary);background:var(--bg-secondary)}.calendar-day.selected{background:var(--primary);border-color:var(--primary)}.calendar-day.selected .day-number{color:#fff;font-weight:700}.day-number{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-xs)}.day-indicators{display:flex;gap:3px;position:absolute;bottom:4px}.indicator{width:6px;height:6px;border-radius:50%}.appointment-indicator{background:var(--primary)}.blocked-indicator{background:var(--error)}.calendar-day.selected .indicator{background:#fff}.calendar-day.has-appointments:not(.selected){border-color:var(--primary);border-style:dashed}.calendar-day.has-blocked:not(.selected){border-color:var(--error);border-style:dashed}@media(max-width:768px){.calendar{padding:var(--space-xs) var(--space-sm);max-width:100%;box-sizing:border-box}.calendar-header{margin-bottom:var(--space-md)}.calendar-month{font-size:1.125rem}.calendar-nav-button{width:40px;height:40px;min-width:40px}.calendar-days-header,.calendar-grid{gap:4px}.calendar-day{min-height:48px;padding:2px;font-size:.875rem}.calendar-day-name{font-size:.625rem;padding:4px 2px;font-weight:600}.day-number{font-size:.875rem;margin-bottom:2px}.indicator{width:4px;height:4px}.calendar-day.available:hover{transform:none}.calendar-day.selected{transform:scale(1.02)}}@media(max-width:375px){.calendar{padding:var(--space-xs)}.calendar-month{font-size:1rem}.calendar-nav-button{width:36px;height:36px}.calendar-days-header,.calendar-grid{gap:2px}.calendar-day{min-height:44px;padding:1px}.day-number{font-size:.8125rem}.calendar-day-name{font-size:.5625rem;padding:2px}}.time-slot-picker{background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-md);border:1px solid var(--border-primary);max-width:100%;overflow:hidden}.time-slot-header{margin-bottom:var(--space-xl);text-align:center}.time-slot-header h3{margin:0 0 var(--space-sm) 0;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.selected-date{margin:0 0 var(--space-xs) 0;font-size:1rem;font-weight:600;color:var(--primary)}.service-duration{margin:0;font-size:.875rem;color:var(--text-secondary)}.admin-mode-notice{margin:var(--space-sm) 0 0 0;font-size:.8125rem;color:#ffc107e6;font-weight:600;padding:var(--space-xs) var(--space-sm);background:#ffc1071a;border-radius:var(--radius-sm);border:1px solid rgba(255,193,7,.3)}.time-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-sm);max-height:400px;overflow-y:auto;padding:var(--space-xs)}.time-slot{padding:var(--space-md) var(--space-sm);border-radius:var(--radius-md);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);border:2px solid transparent;background:var(--bg-secondary);color:var(--text-primary)}.time-slot.available{border-color:var(--border-primary)}.time-slot.available:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.time-slot.selected{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:var(--shadow-md)}.time-slot.unavailable{opacity:.3;cursor:not-allowed;background:var(--bg-tertiary);color:var(--text-tertiary);text-decoration:line-through}.time-slot.booked{background:#ffc10726;border-color:#ffc10780;color:var(--text-primary);font-weight:700}.no-date-message,.no-slots-message{text-align:center;color:var(--text-secondary);padding:var(--space-2xl);font-style:italic}.no-slots-message{margin-top:var(--space-lg);padding:var(--space-lg);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px dashed var(--border-secondary)}.time-slots-grid::-webkit-scrollbar{width:8px}.time-slots-grid::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:var(--radius-sm)}.time-slots-grid::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:var(--radius-sm)}.time-slots-grid::-webkit-scrollbar-thumb:hover{background:var(--primary)}@media(max-width:768px){.time-slot-picker{padding:var(--space-sm)}.time-slot-picker h3{font-size:1rem;margin-bottom:var(--space-md)}.time-slots-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-sm);max-height:320px}.time-slot{padding:.875rem var(--space-sm);font-size:.9375rem;min-height:48px;font-weight:500;border-radius:var(--radius-lg)}.no-slots-message{padding:var(--space-lg);font-size:.9375rem}}@media(max-width:375px){.time-slot-picker{padding:var(--space-xs)}.time-slots-grid{gap:var(--space-xs);max-height:280px}.time-slot{padding:.75rem var(--space-xs);font-size:.875rem;min-height:44px}}.booking-form{max-width:1200px;margin:0 auto;padding:var(--space-2xl);background:var(--bg-elevated);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);border:1px solid var(--border-primary);animation:slideUp .4s ease-out;width:100%;box-sizing:border-box;overflow:hidden}.booking-form h2{margin:0 0 var(--space-sm) 0;color:var(--text-primary);font-size:1.875rem;font-weight:700}.booking-form>p{margin-bottom:var(--space-xl);color:var(--text-secondary);font-size:1rem}.form-group{margin-bottom:var(--space-lg)}.form-group label{display:block;margin-bottom:var(--space-sm);font-weight:600;color:var(--text-primary);font-size:.9375rem;letter-spacing:-.01em}.form-hint{display:block;margin-top:var(--space-xs);font-size:.8125rem;color:var(--text-tertiary);font-style:italic}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--space-md) var(--space-lg);border:2px solid var(--border-primary);border-radius:var(--radius-lg);font-size:1rem;font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition-base);box-sizing:border-box}.form-group textarea{resize:vertical;min-height:80px}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:var(--border-secondary)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-group input::placeholder{color:var(--text-tertiary)}.form-group select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236366f1' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center;padding-right:var(--space-2xl)}.booking-form button[type=submit]{width:100%;padding:var(--space-lg) var(--space-xl);background:var(--gradient-primary);color:#fff;border:2px solid #d4a574;border-radius:var(--radius-lg);font-size:1.0625rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-md);margin-top:var(--space-md);position:relative;overflow:hidden}.booking-form button[type=submit]:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#d4a574,#c9965f);opacity:0;transition:opacity var(--transition-base)}.booking-form button[type=submit]:hover:not(:disabled):before{opacity:1}.booking-form button[type=submit]:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.booking-form button[type=submit]:active:not(:disabled){transform:translateY(0)}.booking-form button[type=submit]:disabled{background:var(--border-secondary);cursor:not-allowed;transform:none;box-shadow:none}.error-message{padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-lg);background-color:var(--error-light);border:1px solid var(--error);border-radius:var(--radius-lg);color:var(--error-dark);font-size:.9375rem;display:flex;align-items:center;gap:var(--space-sm);animation:shake .4s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.error-message:before{content:"⚠";font-size:1.25rem}@media(max-width:640px){.booking-form{padding:var(--space-md);border-radius:var(--radius-xl);max-width:100%}.booking-form h2{font-size:1.375rem;margin-bottom:var(--space-md)}.booking-form>p{font-size:.9375rem;margin-bottom:var(--space-lg)}.form-group{margin-bottom:var(--space-md)}.form-group label{font-size:.9375rem;margin-bottom:var(--space-xs)}.form-group input,.form-group select,.form-group textarea{padding:.875rem var(--space-md);font-size:1rem;min-height:48px;border-radius:var(--radius-lg)}.form-group textarea{min-height:100px;padding:var(--space-md)}.form-group select{background-size:16px;padding-right:2.5rem}.booking-form button[type=submit]{padding:1rem var(--space-lg);font-size:1.0625rem;min-height:52px;font-weight:600;border-radius:var(--radius-xl)}.calendar-grid-layout{grid-template-columns:1fr;gap:var(--space-lg)}.calendar-section{margin:var(--space-lg) 0}.calendar-section h3{font-size:1.125rem;margin-bottom:var(--space-md)}.error-message{padding:var(--space-md);font-size:.9375rem;margin-bottom:var(--space-md)}}@media(max-width:375px){.booking-form{padding:var(--space-sm)}.booking-form h2{font-size:1.25rem}.form-group input,.form-group select,.form-group textarea{padding:.75rem var(--space-sm)}}.calendar-section{margin:var(--space-2xl) 0}.calendar-section h3{margin:0 0 var(--space-xl) 0;font-size:1.25rem;font-weight:700;color:var(--text-primary);text-align:center}.calendar-grid-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl);margin-bottom:var(--space-xl)}.booking-page{min-height:100%}.page-hero{background:var(--gradient-hero);padding:var(--space-3xl) var(--space-xl);text-align:center;position:relative;overflow:hidden}.page-hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.3}.page-hero-content{position:relative;z-index:1;max-width:800px;margin:0 auto}.hero-image-container{margin-bottom:var(--space-xl);display:flex;justify-content:center}.hero-image{width:200px;height:200px;border-radius:var(--radius-full);object-fit:cover;border:4px solid white;box-shadow:0 8px 32px #0003;transition:transform var(--transition-base)}.hero-image:hover{transform:scale(1.05)}.page-hero h1{font-size:3rem;font-weight:800;margin-bottom:var(--space-md);color:#fff;letter-spacing:-1px;text-shadow:0 2px 10px rgba(0,0,0,.1)}.page-hero p{font-size:1.25rem;color:#fffffff2;margin-bottom:var(--space-xl);font-weight:400}.cta-button{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:#fff;color:var(--primary);border:none;border-radius:var(--radius-xl);font-size:1.125rem;font-weight:700;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-xl);margin-top:var(--space-md)}.cta-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-2xl);background:#fffffff2}.cta-button:active{transform:translateY(0)}.cta-button svg{width:20px;height:20px}.page-content{max-width:1200px;margin:0 auto;padding:var(--space-3xl) var(--space-xl)}.success-message{max-width:600px;margin:0 auto var(--space-xl) auto;padding:var(--space-lg) var(--space-xl);background:var(--success-light);border:2px solid var(--success);border-radius:var(--radius-xl);color:var(--success-dark);text-align:center;font-weight:600;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:var(--space-md);box-shadow:var(--shadow-lg);animation:slideDown .4s ease-out}.success-message:before{content:"✓";display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--success);color:#fff;border-radius:var(--radius-full);font-size:1.25rem;font-weight:700;flex-shrink:0}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-xl);margin-bottom:var(--space-3xl)}.feature-card{background:var(--bg-elevated);padding:var(--space-xl);border-radius:var(--radius-xl);border:1px solid var(--border-primary);text-align:center;transition:all var(--transition-base)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary)}.feature-icon{width:56px;height:56px;margin:0 auto var(--space-md);background:var(--primary-light);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center}.feature-icon.blonde{background:linear-gradient(135deg,#fef3c7,#fde68a)}.feature-icon.extensions{background:linear-gradient(135deg,#f5f5f4,#e7e5e4)}.feature-icon svg{width:28px;height:28px;color:var(--primary)}.feature-icon.blonde svg{color:#d97706}.feature-icon.extensions svg{color:#57534e}.feature-card h3{font-size:1.125rem;margin-bottom:var(--space-sm);color:var(--text-primary)}.feature-card p{font-size:.9375rem;color:var(--text-secondary);margin:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md);animation:fadeIn .2s ease-out}.modal-content{background:var(--bg-primary);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);max-width:1200px;width:100%;max-height:95vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xl);border-bottom:1px solid var(--border-primary);background:var(--bg-elevated)}.modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.modal-close{width:40px;height:40px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.modal-close:hover{background:var(--bg-primary);color:var(--text-primary)}.modal-close svg{width:24px;height:24px}.modal-body{padding:var(--space-xl);overflow-y:auto;flex:1}.modal-body .booking-form{max-width:100%;padding:0;background:transparent;box-shadow:none;border:none;animation:none}.modal-body .booking-form h2{display:none}.modal-body .booking-form>p{display:none}.modal-body .booking-form form{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md) var(--space-xl)}.modal-body .booking-form .form-group:nth-child(1),.modal-body .booking-form .form-group:nth-child(2){grid-column:span 1}.modal-body .booking-form .form-group:nth-child(3),.modal-body .booking-form .form-group:nth-child(4){grid-column:span 1}.modal-body .booking-form .form-group:nth-child(5),.modal-body .booking-form .form-group:nth-child(6){grid-column:span 1}.modal-body .booking-form .calendar-section,.modal-body .booking-form button[type=submit],.modal-body .booking-form .error-message{grid-column:span 2}.modal-body .calendar-grid-layout{grid-template-columns:1.2fr .8fr;gap:var(--space-xl);align-items:start}.modal-body .calendar-section{margin:var(--space-lg) 0}.modal-body .calendar{padding:var(--space-md);max-width:100%}.modal-body .calendar-day{min-height:45px;padding:var(--space-xxs)}.modal-body .day-number{font-size:.875rem;margin-bottom:2px}.modal-body .calendar-day-name{font-size:.75rem;padding:var(--space-xs)}.modal-body .calendar-header{margin-bottom:var(--space-md)}.modal-body .calendar-month{font-size:1.125rem}.modal-body .time-slot-picker{max-height:400px;overflow-y:auto}.modal-body .form-group{margin-bottom:var(--space-md)}.modal-body .form-group input,.modal-body .form-group select,.modal-body .form-group textarea{padding:var(--space-sm) var(--space-md)}.modal-body .calendar-section{margin:var(--space-md) 0}@media(max-width:768px){.page-hero{padding:var(--space-xl) var(--space-md)}.hero-image-container{margin-bottom:var(--space-lg)}.hero-image{width:120px;height:120px;border:3px solid white}.page-hero h1{font-size:1.75rem;line-height:1.2;margin-bottom:var(--space-sm)}.page-hero p{font-size:1rem;line-height:1.5;margin-bottom:var(--space-lg)}.cta-button{font-size:1.0625rem;padding:1rem 2rem;width:100%;max-width:320px;min-height:48px;font-weight:600}.page-content{padding:var(--space-lg) var(--space-md)}.features-grid{grid-template-columns:1fr;gap:var(--space-lg)}.feature-card{padding:var(--space-lg)}.feature-card h3{font-size:1.125rem}.feature-card p{font-size:.9375rem;line-height:1.5}.success-message{padding:var(--space-md);font-size:.9375rem;margin:0 var(--space-sm) var(--space-lg) var(--space-sm)}.modal-overlay{padding:0;align-items:flex-end}.modal-content{max-width:100vw;width:100vw;max-height:92vh;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;margin:0;overflow-x:hidden}.modal-header{padding:var(--space-lg) var(--space-md);position:sticky;top:0;z-index:10;background:var(--bg-elevated)}.modal-header h2{font-size:1.25rem}.modal-close{width:44px;height:44px;min-width:44px}.modal-body{padding:var(--space-md);padding-bottom:var(--space-xl);overflow-x:hidden}.modal-body .booking-form form{grid-template-columns:1fr;gap:var(--space-md)}.modal-body .booking-form .form-group,.modal-body .booking-form .calendar-section,.modal-body .booking-form button[type=submit],.modal-body .booking-form .error-message{grid-column:span 1}.modal-body .calendar-grid-layout{grid-template-columns:1fr;gap:var(--space-lg)}.modal-body .calendar{padding:var(--space-sm)}.modal-body .calendar-day{min-height:48px;font-size:.875rem}.modal-body .day-number{font-size:.9375rem}.modal-body .form-group input,.modal-body .form-group select,.modal-body .form-group textarea{padding:.875rem var(--space-md);font-size:1rem;min-height:48px}.modal-body .form-group textarea{min-height:100px}.modal-body .booking-form button[type=submit]{padding:1rem;font-size:1.0625rem;min-height:52px;font-weight:600}.modal-body .time-slot-picker{max-height:300px}.modal-body .time-slot-button{padding:.875rem;font-size:1rem;min-height:48px}}@media(max-width:375px){.page-hero h1{font-size:1.5rem}.page-hero p{font-size:.9375rem}.hero-image{width:100px;height:100px}.modal-body{padding:var(--space-sm)}.feature-card{padding:var(--space-md)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-xl);background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.login-container{width:100%;max-width:420px;background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--space-2xl);box-shadow:var(--shadow-2xl);border:1px solid var(--border-primary);animation:slideUp .4s ease-out}.login-header{text-align:center;margin-bottom:var(--space-2xl)}.login-icon{width:64px;height:64px;margin:0 auto var(--space-lg);background:var(--primary-bg);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.login-icon svg{width:32px;height:32px;color:var(--primary)}.login-header h1{margin:0 0 var(--space-sm) 0;color:var(--text-primary);font-size:1.75rem;font-weight:600}.login-header p{margin:0;color:var(--text-secondary);font-size:.9375rem}.login-form,.login-form .form-group{margin-bottom:var(--space-xl)}.login-form label{display:block;margin-bottom:var(--space-sm);color:var(--text-primary);font-weight:500;font-size:.9375rem}.login-form input{width:100%;padding:var(--space-md) var(--space-lg);border:2px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:1rem;transition:all var(--transition-base)}.login-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.btn-login{width:100%;padding:var(--space-md) var(--space-lg);font-size:1rem;font-weight:600}.login-footer{text-align:center;padding-top:var(--space-xl);border-top:1px solid var(--border-secondary)}.login-footer p{margin:0;color:var(--text-tertiary);font-size:.875rem}.error-message{margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--error-bg);color:var(--error);border-radius:var(--radius-md);border:1px solid var(--error);font-size:.9375rem;text-align:center}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.login-page{padding:var(--space-md)}.login-container{padding:var(--space-xl)}.login-header h1{font-size:1.5rem}.login-header p{font-size:.9375rem}.login-form input{padding:.875rem var(--space-md);font-size:1rem;min-height:48px}.btn-login{padding:1rem;font-size:1.0625rem;min-height:52px}}@media(max-width:480px){.login-page{padding:var(--space-sm)}.login-container{padding:var(--space-lg)}.login-header h1{font-size:1.375rem}.login-icon{width:56px;height:56px}}.appointment-card{background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-lg);box-shadow:var(--shadow-md);border:2px solid var(--border-primary);transition:all var(--transition-base);position:relative;overflow:hidden;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.appointment-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--primary);transition:width var(--transition-base)}.appointment-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-secondary)}.appointment-card:hover:before{width:6px}.appointment-card.status-confirmed:before{background:var(--success)}.appointment-card.status-pending:before{background:var(--warning)}.appointment-card.status-canceled{opacity:.6}.appointment-card.status-canceled:before{background:var(--error)}.appointment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-primary);gap:var(--space-md)}.appointment-header h3{margin:0;color:var(--text-primary);font-size:1.375rem;font-weight:700;letter-spacing:-.02em}.status-badge{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;display:inline-flex;align-items:center;gap:var(--space-xs)}.status-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.status-badge.status-confirmed{background-color:var(--success-light);color:var(--success-dark)}.status-badge.status-pending{background-color:var(--warning-light);color:var(--warning-dark)}.status-badge.status-canceled{background-color:var(--error-light);color:var(--error-dark)}.appointment-details{display:grid;gap:var(--space-md)}.detail-row{display:grid;grid-template-columns:100px 1fr;gap:var(--space-md);align-items:start}.detail-label{font-weight:600;color:var(--text-tertiary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.detail-value{color:var(--text-primary);font-weight:500;font-size:.9375rem}.appointment-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--border-primary)}.btn-approve{padding:var(--space-sm) var(--space-lg);background:var(--success);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.9375rem;font-weight:600;transition:all var(--transition-base);display:inline-flex;align-items:center;gap:var(--space-xs)}.btn-approve:before{content:"✓";font-size:1.125rem;font-weight:700}.btn-approve:hover{background:#059669;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-approve:active{transform:translateY(0)}.btn-reject{padding:var(--space-sm) var(--space-lg);background:var(--warning);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.9375rem;font-weight:600;transition:all var(--transition-base);display:inline-flex;align-items:center;gap:var(--space-xs)}.btn-reject:before{content:"⚠";font-size:1rem}.btn-reject:hover{background:#d97706;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-reject:active{transform:translateY(0)}.btn-cancel{padding:var(--space-sm) var(--space-lg);background:var(--error);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.9375rem;font-weight:600;transition:all var(--transition-base);display:inline-flex;align-items:center;gap:var(--space-xs)}.btn-cancel:before{content:"×";font-size:1.25rem;font-weight:700}.btn-cancel:hover{background:var(--error-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-cancel:active{transform:translateY(0)}@media(max-width:640px){.appointment-card{padding:var(--space-lg)}.appointment-header{flex-direction:column;align-items:flex-start}.detail-row{grid-template-columns:1fr;gap:var(--space-xs)}.detail-label{font-size:.75rem}.detail-value{font-size:.875rem}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 0%,var(--border-primary) 50%,var(--bg-tertiary) 100%);background-size:1000px 100%;animation:shimmer 2s infinite linear;border-radius:var(--radius-md)}.skeleton-card{background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-lg);border:2px solid var(--border-primary)}.skeleton-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-primary)}.skeleton-title{height:28px;width:200px}.skeleton-badge{height:24px;width:80px;border-radius:var(--radius-full)}.skeleton-body{display:flex;flex-direction:column;gap:var(--space-md)}.skeleton-text{height:16px;width:100%}.skeleton-text.short{width:60%}.skeleton-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-lg);margin-bottom:var(--space-3xl)}.skeleton-stat-card{background:var(--bg-elevated);padding:var(--space-xl);border-radius:var(--radius-xl);border:2px solid var(--border-primary)}.skeleton-stat-value{height:48px;width:80px;margin-bottom:var(--space-md)}.skeleton-stat-label{height:14px;width:120px}.admin-dashboard{max-width:1400px;margin:0 auto;padding:var(--space-3xl) var(--space-xl);animation:fadeIn .4s ease-out}.admin-dashboard.loading{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:1.125rem;color:var(--text-secondary)}.admin-dashboard.loading:before{content:"";width:40px;height:40px;margin-right:var(--space-md);border:3px solid var(--border-primary);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}.admin-nav-section{margin-bottom:var(--space-2xl);display:flex;flex-direction:column;gap:var(--space-sm)}.admin-nav-label{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin:0}.admin-nav-dropdown{width:100%;max-width:400px;padding:var(--space-md) var(--space-lg);font-size:1rem;font-weight:600;color:var(--text-primary);background:var(--bg-elevated);border:2px solid var(--border-primary);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath fill='%236366f1' d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center;padding-right:3rem}.admin-nav-dropdown:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.admin-nav-dropdown:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.admin-nav-dropdown option{padding:var(--space-md);font-size:1rem}.dashboard-header h1{margin:0;color:var(--text-primary);font-size:2.25rem;font-weight:800;letter-spacing:-.5px}.btn-refresh{padding:var(--space-md) var(--space-xl);background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-lg);cursor:pointer;font-weight:600;font-size:.9375rem;transition:all var(--transition-base);box-shadow:var(--shadow-md);display:inline-flex;align-items:center;gap:var(--space-sm)}.btn-refresh:before{content:"↻";font-size:1.25rem;transition:transform var(--transition-base)}.btn-refresh:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-refresh:hover:before{transform:rotate(180deg)}.btn-refresh:active{transform:translateY(0)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-lg);margin-bottom:var(--space-3xl)}.stat-card{background:var(--bg-elevated);padding:var(--space-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);border:2px solid var(--border-primary);position:relative;overflow:hidden;transition:all var(--transition-base)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--primary);transition:height var(--transition-base)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:var(--border-secondary)}.stat-card:hover:before{height:6px}.stat-card.pending:before{background:var(--warning)}.stat-card.confirmed:before{background:var(--success)}.stat-card.canceled:before{background:var(--error)}.stat-value{font-size:3rem;font-weight:800;color:var(--text-primary);margin-bottom:var(--space-sm);line-height:1;letter-spacing:-1px}.stat-label{color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:1px;font-weight:600}.filter-bar{display:flex;gap:var(--space-lg);margin-bottom:var(--space-2xl);padding:var(--space-md);background:var(--bg-elevated);border-radius:var(--radius-xl);border:1px solid var(--border-primary);flex-wrap:wrap;align-items:center;justify-content:space-between}.filter-bar .status-filters{display:flex;gap:var(--space-sm);flex-wrap:wrap}.filter-bar .location-filter{display:flex;align-items:center;gap:var(--space-sm)}.filter-bar .location-filter label{font-weight:600;color:var(--text-secondary);white-space:nowrap}.filter-bar .location-filter select{padding:var(--space-sm) var(--space-md);padding-right:2.5rem;background:var(--bg-primary);border:2px solid var(--border-primary);border-radius:var(--radius-lg);color:var(--text-primary);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);min-width:180px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath fill='%236366f1' d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center}.filter-bar .location-filter select:hover{border-color:var(--primary)}.filter-bar .location-filter select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.filter-bar button{padding:var(--space-sm) var(--space-lg);background:var(--bg-primary);border:2px solid var(--border-primary);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);font-weight:600;font-size:.9375rem;color:var(--text-secondary);position:relative;overflow:hidden}.filter-bar button:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--primary-light);opacity:0;transition:opacity var(--transition-base)}.filter-bar button:hover{border-color:var(--primary);color:var(--text-primary);transform:translateY(-1px)}.filter-bar button.active{background:var(--gradient-primary);color:#fff;border-color:transparent;box-shadow:var(--shadow-md)}.filter-bar button.active:before{opacity:0}.appointments-list{margin-top:var(--space-xl)}.no-appointments{text-align:center;padding:var(--space-3xl);color:var(--text-tertiary);font-size:1.125rem;background:var(--bg-elevated);border-radius:var(--radius-xl);border:2px dashed var(--border-primary)}.no-appointments:before{content:"📭";display:block;font-size:4rem;margin-bottom:var(--space-md)}.error-message{padding:var(--space-lg) var(--space-xl);margin-bottom:var(--space-xl);background-color:var(--error-light);border:2px solid var(--error);border-radius:var(--radius-xl);color:var(--error-dark);font-weight:600;display:flex;align-items:center;gap:var(--space-md);box-shadow:var(--shadow-md)}.error-message:before{content:"⚠";font-size:1.5rem}@media(max-width:768px){.admin-dashboard{padding:var(--space-lg) var(--space-md)}.dashboard-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.dashboard-header h1{font-size:1.5rem}.btn-refresh{width:100%;justify-content:center;min-height:48px;padding:.875rem var(--space-lg)}.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.stat-card{padding:var(--space-md)}.stat-value{font-size:2rem}.stat-label{font-size:.875rem}.filter-bar{gap:var(--space-md);flex-direction:column;align-items:stretch}.filter-bar .status-filters{gap:var(--space-xs);flex-wrap:wrap}.filter-bar button{flex:1;min-width:70px;padding:.75rem var(--space-sm);font-size:.875rem;min-height:44px}.filter-bar .location-filter{width:100%}.filter-bar .location-filter select{flex:1;min-width:0;padding:.875rem var(--space-md);padding-right:3rem;font-size:1rem;min-height:48px}.appointments-list{gap:var(--space-md)}.admin-nav-dropdown{max-width:100%;padding:.875rem var(--space-md);padding-right:3rem;font-size:1rem;min-height:48px}.admin-nav-label{font-size:.8125rem}}@media(max-width:480px){.admin-dashboard{padding:var(--space-md) var(--space-sm)}.dashboard-header h1{font-size:1.375rem}.stats-grid{grid-template-columns:1fr}.stat-value{font-size:1.75rem}.filter-bar button{min-width:60px;padding:.625rem var(--space-xs);font-size:.8125rem}}.services-management{max-width:1200px;margin:0 auto;padding:var(--space-2xl)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2xl)}.page-header h1{margin:0;color:var(--text-primary);font-size:2rem;font-weight:700}.service-form-card{background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--space-2xl);margin-bottom:var(--space-2xl);box-shadow:var(--shadow-lg);border:1px solid var(--border-primary);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.service-form-card h2{margin:0 0 var(--space-xl) 0;color:var(--text-primary);font-size:1.5rem;font-weight:600}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.checkbox-group{margin-top:var(--space-md)}.checkbox-group label{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;font-weight:500}.checkbox-group input[type=checkbox]{width:auto;cursor:pointer}.form-actions{display:flex;gap:var(--space-md);margin-top:var(--space-xl)}.btn-primary{padding:var(--space-sm) var(--space-xl);background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:1rem;font-weight:600;transition:all var(--transition-base)}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{padding:var(--space-sm) var(--space-xl);background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;font-size:1rem;font-weight:600;transition:all var(--transition-base)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--border-secondary)}.services-list h2{margin:0 0 var(--space-xl) 0;color:var(--text-primary);font-size:1.5rem;font-weight:600}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg)}.service-card{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-md);border:2px solid var(--border-primary);transition:all var(--transition-base);animation:fadeIn .3s ease-out}.service-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--primary)}.service-card.inactive{opacity:.6;border-color:var(--border-secondary)}.service-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-md);gap:var(--space-sm)}.service-header h3{margin:0;color:var(--text-primary);font-size:1.125rem;font-weight:600;flex:1}.status-badge{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.active{background:var(--success);color:#fff}.status-badge.inactive{background:var(--text-tertiary);color:#fff}.service-details{margin-bottom:var(--space-lg)}.detail-item{display:flex;justify-content:space-between;padding:var(--space-sm) 0;border-bottom:1px solid var(--border-primary)}.detail-label{color:var(--text-secondary);font-weight:500}.detail-value{color:var(--text-primary);font-weight:600}.service-actions{display:flex;gap:var(--space-sm)}.btn-edit{flex:1;padding:var(--space-sm) var(--space-md);background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:600;transition:all var(--transition-base)}.btn-edit:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-delete{flex:1;padding:var(--space-sm) var(--space-md);background:var(--error);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:600;transition:all var(--transition-base)}.btn-delete:hover{background:var(--error-dark);transform:translateY(-1px)}.no-data{text-align:center;color:var(--text-secondary);padding:var(--space-2xl);font-style:italic}@media(max-width:768px){.services-management{padding:var(--space-lg) var(--space-md)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.page-header h1{font-size:1.5rem}.btn-add-service{width:100%;justify-content:center;min-height:48px;padding:.875rem var(--space-lg)}.service-form{padding:var(--space-lg)}.form-row{grid-template-columns:1fr;gap:var(--space-md)}.form-group input,.form-group select{padding:.875rem var(--space-md);font-size:1rem;min-height:48px}.form-actions{flex-direction:column;gap:var(--space-sm)}.form-actions button{width:100%;min-height:48px;padding:.875rem}.services-grid{grid-template-columns:1fr;gap:var(--space-md)}.service-card{padding:var(--space-lg)}.service-actions{flex-direction:column;gap:var(--space-sm)}.service-actions button{width:100%;min-height:44px}}@media(max-width:480px){.services-management{padding:var(--space-md) var(--space-sm)}.page-header h1{font-size:1.375rem}.service-form,.service-card{padding:var(--space-md)}}.blocked-times-management{max-width:1200px;margin:0 auto;padding:var(--space-2xl)}.blocked-time-form-card{background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--space-2xl);margin-bottom:var(--space-2xl);box-shadow:var(--shadow-lg);border:1px solid var(--border-primary);animation:slideDown .3s ease-out}.blocked-time-form-card h2,.blocked-times-list h2{margin:0 0 var(--space-xl) 0;color:var(--text-primary);font-size:1.5rem;font-weight:600}.blocked-times-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--space-lg)}.blocked-time-card{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-md);border:2px solid var(--warning);transition:all var(--transition-base);animation:fadeIn .3s ease-out}.blocked-time-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--error)}.blocked-time-header{margin-bottom:var(--space-md)}.blocked-time-header h3{margin:0;color:var(--text-primary);font-size:1.125rem;font-weight:600}.blocked-time-details{margin-bottom:var(--space-lg)}.blocked-time-actions{display:flex;gap:var(--space-sm)}@media(max-width:768px){.blocked-times-management{padding:var(--space-lg) var(--space-md)}.blocked-times-management h1{font-size:1.5rem}.calendar-section{padding:var(--space-lg)}.calendar-section h2{font-size:1.25rem}.blocked-times-grid{grid-template-columns:1fr;gap:var(--space-md)}.blocked-time-card{padding:var(--space-lg)}.blocked-time-actions{flex-direction:column;gap:var(--space-sm)}.blocked-time-actions button{width:100%;min-height:44px}.blocked-times-management input[type=datetime-local],.blocked-times-management textarea{padding:.875rem var(--space-md);font-size:1rem;min-height:48px}.blocked-times-management button[type=submit]{min-height:52px;padding:1rem}}@media(max-width:480px){.blocked-times-management{padding:var(--space-md) var(--space-sm)}.blocked-times-management h1{font-size:1.375rem}.calendar-section,.blocked-time-card{padding:var(--space-md)}}.calendar-section{background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--space-2xl);margin-bottom:var(--space-2xl);box-shadow:var(--shadow-lg);border:1px solid var(--border-primary)}.calendar-section h2{margin:0 0 var(--space-sm) 0;color:var(--text-primary);font-size:1.5rem;font-weight:600;text-align:center}.calendar-section p{margin:0 0 var(--space-xl) 0;color:var(--text-secondary);text-align:center;font-size:.9375rem}.schedule-management{max-width:1200px;margin:0 auto;padding:var(--space-2xl)}.schedule-form-card{background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--space-2xl);margin-bottom:var(--space-2xl);box-shadow:var(--shadow-lg);border:1px solid var(--border-primary);animation:slideDown .3s ease-out}.schedule-form-card h2{margin:0 0 var(--space-sm) 0;color:var(--text-primary);font-size:1.5rem;font-weight:600}.schedule-form-card p{margin:0 0 var(--space-xl) 0;color:var(--text-secondary);font-size:.9375rem}.location-filter{background:var(--bg-elevated);border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-2xl);box-shadow:var(--shadow-lg);border:1px solid var(--border-primary);display:flex;align-items:center;gap:var(--space-lg);animation:slideDown .3s ease-out}.location-filter label{font-weight:600;color:var(--text-primary);font-size:1rem;white-space:nowrap;margin:0}.location-filter select{flex:1;max-width:400px;padding:var(--space-md) var(--space-lg);border:2px solid var(--border-primary);border-radius:var(--radius-lg);background:var(--bg-primary);color:var(--text-primary);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center;background-size:20px;padding-right:var(--space-2xl)}.location-filter select:hover{border-color:var(--accent-primary);box-shadow:0 0 0 3px #0000000d}.location-filter select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 4px #0000001a}:root[data-theme=dark] .location-filter select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23aaa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E")}.schedules-list h2{margin:0 0 var(--space-xl) 0;color:var(--text-primary);font-size:1.5rem;font-weight:600}.schedules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-lg)}.schedule-card{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-md);border:2px solid var(--border-primary);transition:all var(--transition-base);animation:fadeIn .3s ease-out}.schedule-card.active{border-color:var(--success)}.schedule-card.inactive{border-color:var(--warning);opacity:.7}.schedule-card.no-schedule{border-color:var(--border-secondary);border-style:dashed;opacity:.5}.schedule-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.schedule-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-secondary)}.schedule-header h3{margin:0;color:var(--text-primary);font-size:1.125rem;font-weight:600}.status-badge{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background:var(--success-bg);color:var(--success)}.status-badge.inactive{background:var(--warning-bg);color:var(--warning)}.schedule-details{margin-bottom:var(--space-md)}.schedule-time{margin:0 0 var(--space-md) 0;color:var(--text-primary);font-size:1rem;font-weight:600}.no-schedule-text{margin:0;color:var(--text-tertiary);font-style:italic;text-align:center;padding:var(--space-lg) 0}.schedule-actions{display:flex;gap:var(--space-sm)}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:768px){.schedule-management{padding:var(--space-lg) var(--space-md)}.schedule-management h1{font-size:1.5rem}.location-filter{flex-direction:column;align-items:stretch;gap:var(--space-md)}.location-filter select{max-width:100%;padding:.875rem var(--space-md);font-size:1rem;min-height:48px}.schedules-grid{grid-template-columns:1fr;gap:var(--space-md)}.schedule-card{padding:var(--space-lg)}.schedule-actions{flex-direction:column;gap:var(--space-sm)}.schedule-actions button{width:100%;min-height:44px}.schedule-management input[type=time],.schedule-management select{padding:.875rem var(--space-md);font-size:1rem;min-height:48px}.schedule-management button[type=submit]{min-height:52px;padding:1rem}}@media(max-width:480px){.schedule-management{padding:var(--space-md) var(--space-sm)}.schedule-management h1{font-size:1.375rem}.schedule-card{padding:var(--space-md)}}.admin-booking-page{min-height:100vh;background:var(--bg-primary);padding-bottom:var(--space-2xl)}.admin-booking-container{max-width:1200px;margin:0 auto;padding:var(--space-2xl);width:100%;box-sizing:border-box}.admin-booking-container h2{margin:var(--space-xl) 0 var(--space-sm) 0;color:var(--text-primary);font-size:1.875rem;font-weight:700}.admin-note{margin-bottom:var(--space-xl);padding:var(--space-md) var(--space-lg);background:#ffc1071a;border:2px solid rgba(255,193,7,.3);border-radius:var(--radius-lg);color:var(--text-primary);font-size:.9375rem;font-weight:500}.admin-booking-container .booking-form{background:var(--bg-elevated);border-radius:var(--radius-2xl);padding:var(--space-2xl);box-shadow:var(--shadow-xl);border:1px solid var(--border-primary)}.admin-booking-container .calendar-section{margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:2px solid var(--border-primary)}.admin-booking-container .calendar-section h3{margin:0 0 var(--space-lg) 0;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.admin-booking-container .calendar-time-container{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl);margin-bottom:var(--space-xl);width:100%;max-width:100%;overflow:hidden}@media(max-width:768px){.admin-booking-container{padding:var(--space-lg) var(--space-md);max-width:100%}.admin-booking-container h2{font-size:1.5rem;margin-top:var(--space-lg)}.admin-booking-container .calendar-time-container{grid-template-columns:1fr;gap:var(--space-lg)}.admin-booking-container .booking-form{padding:var(--space-lg);max-width:100%}.admin-booking-container .booking-form form{grid-template-columns:1fr}.admin-booking-container .form-group input,.admin-booking-container .form-group select,.admin-booking-container .form-group textarea{padding:.875rem var(--space-md);font-size:1rem;min-height:48px}.admin-booking-container button[type=submit]{min-height:52px;padding:1rem}.admin-note{font-size:.875rem;padding:var(--space-sm) var(--space-md)}}@media(max-width:480px){.admin-booking-container{padding:var(--space-md) var(--space-sm)}.admin-booking-container h1{font-size:1.375rem}}#root{width:100%;min-height:100vh}.app{width:100%;min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.app-header{background:var(--gradient-primary);color:var(--text-inverse);box-shadow:var(--shadow-lg);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-container{max-width:1400px;margin:0 auto;padding:var(--space-lg) var(--space-xl);display:flex;justify-content:space-between;align-items:center;gap:var(--space-xl)}.header-brand{display:flex;align-items:center;gap:var(--space-md)}.brand-icon{width:48px;height:48px;background:#fff3;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.brand-icon svg{width:28px;height:28px;color:#fff}.brand-text h1{font-size:1.75rem;font-weight:700;margin:0;color:#fff;letter-spacing:-.5px}.brand-text p{font-size:.875rem;margin:0;color:#ffffffe6;font-weight:400}.header-nav{display:flex;align-items:center;gap:var(--space-sm)}.nav-link,.logout-btn{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-lg);color:#fff;font-weight:500;font-size:.9375rem;transition:all var(--transition-base);position:relative;overflow:hidden;background:transparent;border:none;cursor:pointer;font-family:inherit;text-decoration:none}.nav-link:before,.logout-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffff1a;opacity:0;transition:opacity var(--transition-base)}.nav-link:hover:before,.logout-btn:hover:before{opacity:1}.nav-link.active{background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-link svg,.logout-btn svg{width:20px;height:20px;flex-shrink:0}.app-main{flex:1;background:var(--bg-secondary);min-height:calc(100vh - 200px)}.app-footer{background:var(--bg-elevated);border-top:1px solid var(--border-primary);padding:var(--space-2xl) var(--space-xl);margin-top:auto}.footer-container{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-lg)}.footer-content{display:flex;flex-direction:column;gap:var(--space-md)}.footer-container p{margin:0;color:var(--text-secondary);font-size:.875rem}.footer-social{display:flex;gap:var(--space-md);align-items:center}.social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--bg-secondary);color:var(--text-secondary);transition:all var(--transition-base);border:1px solid var(--border-primary)}.social-link:hover{background:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary)}.social-link svg{width:20px;height:20px}.footer-links{display:flex;gap:var(--space-lg);align-items:center}.footer-links a{color:var(--text-secondary);font-size:.875rem;transition:color var(--transition-fast)}.footer-links a:hover{color:var(--primary)}@media(max-width:768px){.app-header{position:sticky;top:0}.header-container{flex-direction:column;align-items:flex-start;padding:var(--space-md);gap:var(--space-sm)}.header-brand{width:100%;justify-content:space-between}.brand-text h1{font-size:1.25rem}.brand-text p{font-size:.75rem}.header-nav{width:100%;flex-wrap:wrap;gap:var(--space-xs)}.nav-link,.logout-btn{flex:1;justify-content:center;min-width:100px;padding:.75rem var(--space-md);min-height:44px;font-size:.9375rem}.nav-link span{display:none}.nav-link svg,.logout-btn svg{width:22px;height:22px}.footer-container{flex-direction:column;text-align:center;gap:var(--space-lg)}.footer-content{align-items:center}.footer-social{justify-content:center;gap:var(--space-lg)}.social-link{width:48px;height:48px}.social-link svg{width:24px;height:24px}.footer-links{flex-direction:column;gap:var(--space-sm)}.footer-links a{min-height:44px;display:flex;align-items:center;justify-content:center}}@media(max-width:480px){.header-container{padding:var(--space-sm) var(--space-md)}.brand-icon{width:36px;height:36px}.brand-icon svg{width:20px;height:20px}.brand-text h1{font-size:1.125rem}.brand-text p{font-size:.6875rem}.nav-link,.logout-btn{padding:.625rem var(--space-sm);min-width:80px;font-size:.875rem}.nav-link svg,.logout-btn svg{width:20px;height:20px}}
