.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0F1215 0%,var(--color-background) 100%);padding:20px}.login-container{width:100%;max-width:400px;background:var(--color-surface);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:32px}.login-logo{width:80px;height:80px;margin-bottom:16px}.login-header h1{color:var(--color-text);margin-bottom:4px}.login-subtitle{color:var(--color-text-muted);font-size:1rem}.login-form{margin-bottom:24px}.login-error{background-color:#e170551a;color:var(--color-error);padding:12px 16px;border-radius:var(--radius-md);margin-bottom:16px;font-size:.875rem}.login-btn{width:100%;margin-top:8px}.login-footer{text-align:center;color:var(--color-text-muted);font-size:.875rem}.login-footer p{margin:4px 0}@media (max-width: 480px){.login-container{padding:24px}.login-logo{width:60px;height:60px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);animation:fadeIn .15s ease}.modal-overlay~.modal-overlay{z-index:1001}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-height:calc(100vh - 32px);display:flex;flex-direction:column;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-small{max-width:400px}.modal-medium{max-width:500px}.modal-large{max-width:700px}.modal-full{max-width:900px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-title{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0}.modal-close{background:none;border:none;font-size:1.75rem;color:var(--color-text-muted);cursor:pointer;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast);line-height:1}.modal-close:hover{background-color:var(--color-light-grey);color:var(--color-text)}.modal-content{padding:var(--spacing-lg);overflow-y:auto;flex:1}.modal-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}@media (max-width: 768px){.modal-overlay{padding:0;align-items:flex-end}.modal-container{max-width:100%;max-height:90vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;animation:slideUpMobile .25s ease}@keyframes slideUpMobile{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--spacing-md)}.modal-content{padding:var(--spacing-md);padding-bottom:140px}.modal-actions{position:fixed;bottom:0;left:0;right:0;flex-direction:column-reverse;background:var(--color-surface);padding:var(--spacing-md);padding-bottom:max(var(--spacing-md),env(safe-area-inset-bottom));margin-top:0;border-top:1px solid var(--color-border);box-shadow:0 -2px 10px #0003;z-index:10}.modal-actions .btn{width:100%}}.inline-select-row{display:flex;gap:var(--spacing-sm);align-items:stretch}.inline-select-row select{flex:1}.inline-select-row .btn{white-space:nowrap}.appt-hint{margin:calc(-1 * var(--spacing-sm)) 0 var(--spacing-md);font-size:.875rem}.dashboard{max-width:1400px;margin:0 auto}.dashboard-loading,.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:var(--color-text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:20px;text-align:center;box-shadow:var(--shadow-sm)}.stat-value{display:block;font-family:var(--font-heading);font-size:2rem;font-weight:700;color:var(--color-teal);margin-bottom:4px}.stat-label{font-size:.875rem;color:var(--color-text-muted)}.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.dashboard-section{background:var(--color-surface);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--color-border)}.section-header h2{font-size:1.125rem;font-weight:600}.job-count{background:var(--color-teal);color:#1a1d21;font-size:.875rem;font-weight:600;padding:4px 12px;border-radius:var(--radius-full)}.job-count.warning{background:var(--color-warning);color:#1a1d21}.job-list{display:flex;flex-direction:column;gap:12px}.job-card{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-md);background:var(--color-light-grey);text-decoration:none;color:inherit;transition:all var(--transition-fast)}.job-card:hover{background:var(--color-border);transform:translateY(-1px)}.job-time,.job-date{font-family:var(--font-heading);font-weight:600;font-size:.875rem;color:var(--color-teal);min-width:60px;text-align:center}.job-info{flex:1;min-width:0}.job-info h3{font-size:.95rem;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-customer,.job-address{font-size:.8rem;color:var(--color-text-muted);margin:0}.view-all-link{display:block;text-align:center;padding:12px;color:var(--color-teal);font-weight:500;transition:color var(--transition-fast)}.view-all-link:hover{color:var(--color-teal-dark)}.empty-state{text-align:center;padding:32px 16px;color:var(--color-text-muted)}.empty-state.success{color:var(--color-success)}.attention-section .section-header h2{color:var(--color-warning)}.attention-list{display:flex;flex-direction:column;gap:8px}.attention-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:var(--radius-md);background:#fdcb6e1a;text-decoration:none;color:inherit;border-left:3px solid var(--color-warning);transition:all var(--transition-fast)}.attention-item:hover{background:#fdcb6e33}.attention-icon{font-size:1.25rem}.attention-info h4{font-size:.9rem;font-weight:600;margin-bottom:2px}.attention-info p{font-size:.8rem;color:var(--color-text-muted);margin:0}@media (max-width: 1200px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}.attention-section{grid-column:span 2}}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.attention-section{grid-column:span 1}.stat-value{font-size:1.5rem}}.calendar-page{max-width:1400px;margin:0 auto;width:100%;overflow-x:hidden}.calendar-controls{display:flex;align-items:center;justify-content:space-between;background:var(--color-surface);padding:16px 20px;border-radius:var(--radius-lg);margin-bottom:24px;box-shadow:var(--shadow-sm);flex-wrap:wrap;gap:16px}.nav-buttons{display:flex;gap:8px}.nav-buttons .btn{padding:8px 16px;min-height:40px}.calendar-title{font-size:1.25rem;font-weight:600;color:var(--color-text)}.view-toggle{display:flex;background:var(--color-light-grey);border-radius:var(--radius-md);padding:4px}.view-btn{padding:8px 16px;border:none;background:transparent;font-size:.875rem;font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);color:var(--color-text-muted)}.view-btn.active{background:var(--color-surface-raised);color:var(--color-teal);box-shadow:var(--shadow-sm)}.week-view{background:var(--color-surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.week-header{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--color-border)}.week-day-header{padding:16px;text-align:center;border-right:1px solid var(--color-border)}.week-day-header:last-child{border-right:none}.week-day-header.today{background:#00b4a61a}.day-name{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:4px}.day-number{display:block;font-family:var(--font-heading);font-size:1.5rem;font-weight:600;color:var(--color-text)}.week-day-header.today .day-number{color:var(--color-teal)}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);min-height:400px}.week-day{padding:8px;border-right:1px solid var(--color-border);display:flex;flex-direction:column;gap:6px;min-height:200px}.week-day:last-child{border-right:none}.week-day.today{background:#00b4a60d}.calendar-job{display:flex;flex-direction:column;padding:8px;border-radius:var(--radius-sm);font-size:.75rem;text-decoration:none;color:#1a1d21;transition:transform var(--transition-fast)}.calendar-job:hover{transform:scale(1.02)}.calendar-job .job-time{font-weight:600;margin-bottom:2px}.calendar-job .job-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day-view{background:var(--color-surface);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.day-title{font-size:1.25rem;margin-bottom:20px;color:var(--color-text)}.day-jobs{display:flex;flex-direction:column;gap:12px}.day-job-card{display:flex;align-items:center;gap:16px;padding:16px;border-radius:var(--radius-md);background:var(--color-light-grey);text-decoration:none;color:inherit;transition:all var(--transition-fast)}.day-job-card:hover{background:var(--color-border);transform:translateY(-2px)}.day-job-card .job-time{font-family:var(--font-heading);font-size:1.125rem;font-weight:600;color:var(--color-teal);min-width:80px}.day-job-card .job-details{flex:1}.day-job-card .job-details h4{font-size:1rem;margin-bottom:4px}.day-job-card .job-details p{font-size:.875rem;color:var(--color-text-muted);margin:0}.calendar-loading{display:flex;justify-content:center;padding:80px}.empty-state{text-align:center;padding:40px;color:var(--color-text-muted)}.person-filter{width:auto;min-width:150px;padding:8px 12px;min-height:40px}.calendar-appt{display:flex;flex-direction:column;gap:2px;padding:8px 10px;border:none;border-left:4px solid var(--color-teal);border-radius:var(--radius-sm);font-size:.75rem;color:#1a1d21;cursor:pointer;text-align:left;width:100%;transition:transform var(--transition-fast)}.calendar-appt:hover{transform:scale(1.02)}.calendar-appt .appt-time{font-weight:700}.calendar-appt .appt-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-appt .appt-sub{opacity:.85;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day-appts{display:flex;flex-direction:column;gap:12px}.day-appts .calendar-appt{font-size:.95rem;padding:14px 16px}.loading-spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-teal);border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 768px){.calendar-controls{flex-direction:column;align-items:stretch}.nav-buttons{justify-content:center}.calendar-title{text-align:center}.view-toggle{justify-content:center}.week-header,.week-grid{display:none}.week-view{padding:24px;text-align:center;color:var(--color-text-muted)}.week-view:after{content:"Switch to Day view for mobile";display:block}.day-view{padding:16px}.day-job-card{flex-direction:column;align-items:flex-start;gap:8px}.day-job-card .job-time{min-width:auto;font-size:1rem}.day-job-card .status-badge{align-self:flex-start}}.appointments-page{max-width:1000px;margin:0 auto;width:100%}.appt-filters{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.appt-filters .appt-search{flex:1;min-width:180px}.appt-filters select{width:auto;min-width:140px}.appt-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.appt-row{display:flex;align-items:center;gap:var(--spacing-md);width:100%;text-align:left;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);cursor:pointer;transition:all var(--transition-fast)}.appt-row:hover{background:var(--color-surface-raised);transform:translateY(-1px)}.appt-when{display:flex;flex-direction:column;border-left:4px solid var(--color-teal);padding-left:var(--spacing-md);min-width:130px}.appt-row-date{font-weight:600;color:var(--color-text)}.appt-row-time{font-size:.875rem;color:var(--color-teal)}.appt-main{flex:1}.appt-main h3{font-size:1rem;margin-bottom:2px}.appt-main p{font-size:.875rem;margin:0}@media (max-width: 768px){.appt-row{flex-wrap:wrap}.appt-when{min-width:110px}}.clients-page{max-width:1100px;margin:0 auto;width:100%}.clients-search{margin-bottom:var(--spacing-lg)}.client-card{display:block;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);color:inherit;transition:all var(--transition-fast)}.client-card:hover{border-color:var(--color-teal);transform:translateY(-2px);color:inherit}.client-card h3{font-size:1.05rem;margin-bottom:var(--spacing-sm)}.client-card p{font-size:.875rem;margin:2px 0}.client-email{overflow:hidden;text-overflow:ellipsis}.client-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-md)}.client-detail{max-width:1000px;margin:0 auto;width:100%}.back-link{font-size:.875rem;display:inline-block;margin-bottom:var(--spacing-xs)}.client-detail-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--spacing-lg)}@media (max-width: 768px){.client-detail-grid{grid-template-columns:1fr}}.client-detail .card p{margin-bottom:var(--spacing-xs)}.client-appt-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.client-appt{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border);flex-wrap:wrap}.client-appt:last-child{border-bottom:none}.client-appt-when{display:flex;flex-direction:column;min-width:130px}.client-appt .status-badge{margin-left:auto}.services-page{max-width:1100px;margin:0 auto;width:100%}.service-card{position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);cursor:pointer;transition:all var(--transition-fast)}.service-card:hover{border-color:var(--color-teal);transform:translateY(-2px)}.service-card.inactive{opacity:.6}.service-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.service-card-head h3{font-size:1.1rem}.service-duration{color:var(--color-teal);font-weight:600;white-space:nowrap}.service-desc{font-size:.875rem;margin-bottom:var(--spacing-md);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.service-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.service-delete{position:absolute;top:var(--spacing-md);right:var(--spacing-md);display:none}.service-card:hover .service-delete{display:inline-flex}@media (max-width: 768px){.service-delete{display:inline-flex;position:static;margin-top:var(--spacing-sm)}}.availability-page{max-width:800px;margin:0 auto;width:100%}.avail-section{margin-bottom:var(--spacing-lg)}.hours-list{display:flex;flex-direction:column}.hours-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border)}.hours-row:last-child{border-bottom:none}.hours-row.off{opacity:.6}.hours-day{min-width:120px}.hours-times{display:flex;align-items:center;gap:var(--spacing-sm)}.hours-times input{width:auto}.exception-form{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);align-items:center}.exception-form input,.exception-form select{width:auto;flex:1;min-width:120px}.exception-list{list-style:none;display:flex;flex-direction:column;gap:var(--spacing-sm)}.exception-list li{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.exception-list li .btn{margin-left:auto}.chip-extra{background:var(--color-teal);color:#1a1d21}@media (max-width: 768px){.hours-row{flex-direction:column;align-items:flex-start}.exception-form input,.exception-form select{flex:1 1 100%}}.team-page{max-width:900px;margin:0 auto;width:100%}.team-card{display:flex;gap:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-fast)}.team-card:hover{border-color:var(--color-teal)}.team-card.inactive{opacity:.6}.team-avatar{width:48px;height:48px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:700;font-size:1.25rem;color:#1a1d21;flex-shrink:0}.team-info{flex:1;min-width:0}.team-info h3{font-size:1.05rem;display:flex;align-items:center;gap:var(--spacing-sm)}.team-info p{font-size:.85rem;margin:2px 0;overflow:hidden;text-overflow:ellipsis}.team-flags{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-sm);flex-wrap:wrap}.team-deactivate{align-self:flex-start}.settings-page{max-width:720px;margin:0 auto;width:100%}.settings-section{margin-bottom:var(--spacing-lg)}.settings-hint{font-size:.85rem;margin-top:calc(-1 * var(--spacing-sm))}.settings-toggle{display:flex;margin-top:var(--spacing-md)}.booking-layout{min-height:100vh;min-height:-webkit-fill-available;display:flex;flex-direction:column;background:radial-gradient(1200px 500px at 50% -10%,rgba(45,212,191,.12),transparent),var(--color-background)}.booking-topbar{display:flex;justify-content:center;padding:var(--spacing-lg) var(--spacing-md)}.booking-brand{display:flex;align-items:center;gap:var(--spacing-sm)}.booking-mark{font-size:1.5rem}.booking-brand-name{font-family:var(--font-heading);font-weight:600;font-size:1.25rem;color:var(--color-text)}.booking-main{flex:1;width:100%;max-width:560px;margin:0 auto;padding:var(--spacing-md) var(--spacing-md) 120px}.booking-footer{text-align:center;padding:var(--spacing-lg);color:var(--color-text-light);font-size:.8rem}.booking-wizard{width:100%}.stepper{display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg);gap:4px}.step-dot{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;position:relative}.step-dot span{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;background:var(--color-surface-raised);color:var(--color-text-muted);border:1px solid var(--color-border)}.step-dot label{font-size:.65rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px}.step-dot.active span{background:var(--color-teal);color:#1a1d21;border-color:var(--color-teal)}.step-dot.done span{background:var(--color-teal-dark);color:#1a1d21;border-color:var(--color-teal-dark)}.booking-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md)}.booking-card h1{font-size:1.4rem;margin-bottom:var(--spacing-sm)}.booking-sub{margin-bottom:var(--spacing-md)}.booking-error{background:#f871711f;border:1px solid var(--color-error);color:var(--color-error);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:.9rem}.choice-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.choice{display:flex;align-items:center;gap:var(--spacing-md);text-align:left;width:100%;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);cursor:pointer;transition:all var(--transition-fast)}.choice:hover{border-color:var(--color-teal);transform:translateY(-1px)}.choice-avatar{width:44px;height:44px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:700;color:#1a1d21;flex-shrink:0}.choice-body{display:flex;flex-direction:column;gap:4px}.choice-body strong{font-size:1.05rem}.choice-body .text-muted{font-size:.85rem}.choice-meta{display:flex;gap:var(--spacing-xs);margin-top:4px;flex-wrap:wrap}.date-grid,.time-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:var(--spacing-sm)}.date-chip,.time-chip{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-sm);cursor:pointer;font-weight:500;color:var(--color-text);transition:all var(--transition-fast)}.date-chip:hover,.time-chip:hover{border-color:var(--color-teal);color:var(--color-teal)}.date-chip.active,.time-chip.active{background:var(--color-teal);color:#1a1d21;border-color:var(--color-teal)}.time-chip:disabled{opacity:.5;cursor:default}.booking-actions{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom));background:linear-gradient(transparent,var(--color-background) 30%);max-width:560px;margin:0 auto}.booking-actions .btn{flex:1}.booking-confirm{flex:2!important}.booking-done{text-align:center}.done-check{width:64px;height:64px;margin:0 auto var(--spacing-md);border-radius:var(--radius-full);background:var(--color-success);color:#1a1d21;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700}.done-when,.manage-service{font-size:1.1rem;font-weight:600;margin:var(--spacing-sm) 0}.done-actions{display:flex;gap:var(--spacing-sm);justify-content:center;margin-top:var(--spacing-lg);flex-wrap:wrap}.reschedule-panel{margin-top:var(--spacing-md)}.link-btn{background:none;border:none;color:var(--color-teal);cursor:pointer;width:auto;padding:0;text-decoration:underline}.main-layout{display:flex;min-height:100vh;min-height:-webkit-fill-available;background-color:var(--color-background);width:100%;overflow-x:hidden}.sidebar{width:260px;background-color:var(--color-surface);color:var(--color-text);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;border-right:1px solid var(--color-border)}.sidebar-header{padding:20px;border-bottom:1px solid var(--color-border)}.logo{display:flex;align-items:center;gap:12px}.logo img{width:40px;height:40px}.logo span{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--color-text)}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;color:var(--color-text-muted);text-decoration:none;transition:all .2s ease;font-family:var(--font-body);font-size:.95rem}.nav-item:hover{background-color:var(--color-surface-raised);color:var(--color-text)}.nav-item.active{background-color:var(--color-teal);color:#1a1d21}.nav-item svg{width:20px;height:20px;flex-shrink:0}.sidebar-footer{padding:16px;border-top:1px solid var(--color-border)}.user-info{padding:8px 12px;margin-bottom:8px}.user-name{font-size:.9rem;color:var(--color-text-muted)}.logout-btn{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;border:none;border-radius:8px;background:transparent;color:var(--color-text-muted);cursor:pointer;font-family:var(--font-body);font-size:.95rem;transition:all .2s ease}.logout-btn:hover{background-color:var(--color-surface-raised);color:var(--color-text)}.logout-btn svg{width:20px;height:20px}.main-content{flex:1;margin-left:260px;padding:24px 24px 100px;min-height:100vh}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background-color:var(--color-surface);border-top:1px solid var(--color-border);padding:8px 0;padding-bottom:calc(8px + env(safe-area-inset-bottom));z-index:100}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 4px;color:var(--color-text-muted);text-decoration:none;font-size:.65rem;gap:2px;transition:color .2s ease;min-width:0;flex:1}.mobile-nav-item svg{width:24px;height:24px}.mobile-nav-item.active{color:var(--color-teal)}.mobile-nav-item span{font-family:var(--font-body)}@media (max-width: 768px){.sidebar{display:none}.main-content{margin-left:0;padding:16px 16px 80px;width:100%;max-width:100vw;overflow-x:hidden}.mobile-nav{display:flex;justify-content:space-around;position:fixed;bottom:0;left:0;right:0;background-color:var(--color-surface);border-top:1px solid var(--color-border);padding:8px 0;padding-bottom:max(8px,env(safe-area-inset-bottom));z-index:1000}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;color:var(--color-text-muted)}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-teal);border-radius:50%;animation:spin 1s linear infinite}:root{--color-charcoal: #E4E6E8;--color-teal: #2DD4BF;--color-teal-dark: #14B8A6;--color-teal-light: #5EEAD4;--color-white: #FFFFFF;--color-light-grey: #2A2F35;--color-background: #1A1D21;--color-surface: #242930;--color-surface-raised: #2A2F35;--color-border: #3D444D;--color-text: #F1F3F5;--color-text-muted: #9CA3AF;--color-text-light: #6B7280;--color-success: #34D399;--color-warning: #FBBF24;--color-error: #F87171;--color-info: #60A5FA;--status-pending: #FBBF24;--status-confirmed: #34D399;--status-cancelled: #9CA3AF;--status-completed: #60A5FA;--status-no-show: #F87171;--font-heading: "Fraunces", Georgia, "Times New Roman", serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{height:100%;overflow-x:hidden}body{font-family:var(--font-body);font-size:1rem;line-height:1.5;color:var(--color-text);background-color:var(--color-background);min-height:100vh;min-height:-webkit-fill-available}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.3;color:var(--color-text)}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}a{color:var(--color-teal);text-decoration:none}a:hover{color:var(--color-teal-dark)}input,textarea,select{font-family:var(--font-body);font-size:1rem;padding:12px 16px;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-text);width:100%;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-teal);box-shadow:0 0 0 3px #00b4a61a}input::placeholder,textarea::placeholder{color:var(--color-text-light)}label{display:block;font-weight:500;margin-bottom:6px;color:var(--color-text)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-family:var(--font-body);font-size:1rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;min-height:44px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--color-teal);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-teal-dark)}.btn-secondary{background-color:var(--color-surface-raised);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background-color:var(--color-border)}.btn-outline{background-color:transparent;border:2px solid var(--color-border);color:var(--color-text)}.btn-outline:hover:not(:disabled){border-color:var(--color-teal);color:var(--color-teal)}.btn-danger{background-color:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background-color:#c44d3a}.btn-sm{padding:8px 16px;font-size:.875rem;min-height:36px}.btn-lg{padding:16px 32px;font-size:1.125rem;min-height:52px}.card{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.card-title{font-size:1.125rem;font-weight:600}.status-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-pending{background-color:var(--status-pending);color:#1a1d21}.status-confirmed{background-color:var(--status-confirmed);color:#1a1d21}.status-cancelled{background-color:var(--status-cancelled);color:#1a1d21}.status-completed{background-color:var(--status-completed);color:#1a1d21}.status-no-show{background-color:var(--status-no-show);color:#1a1d21}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--color-border)}th{font-weight:600;color:var(--color-text-muted);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}tr:hover{background-color:var(--color-light-grey)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.page-title{font-size:1.75rem;font-weight:700;color:var(--color-text)}.page-actions{display:flex;gap:var(--spacing-sm)}.form-group{margin-bottom:var(--spacing-md)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.form-error{color:var(--color-error);font-size:.875rem;margin-top:4px}.checkbox-label{display:inline-flex;align-items:center;gap:var(--spacing-sm);font-weight:500;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;margin:0}input[type=color]{height:44px;padding:4px;cursor:pointer}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--spacing-md)}.chip{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);background:var(--color-surface-raised);color:var(--color-text-muted);font-size:.75rem;font-weight:500}.chip-muted{opacity:.7}.loading-spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-teal);border-radius:50%;animation:spin .8s linear infinite;margin:var(--spacing-lg) auto}@keyframes spin{to{transform:rotate(360deg)}}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-center{text-align:center}.text-right{text-align:right}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.click-to-call,.click-to-map{color:var(--color-teal);cursor:pointer;display:inline-flex;align-items:center;gap:4px}.click-to-call:hover,.click-to-map:hover{color:var(--color-teal-dark);text-decoration:underline}@media (max-width: 768px){h1{font-size:1.5rem}h2{font-size:1.25rem}.page-header{flex-direction:column;align-items:flex-start}.form-row{grid-template-columns:1fr}.hide-mobile{display:none!important}}@media (min-width: 769px){.hide-desktop{display:none!important}}
