.sidebar{width:240px;height:100vh;background:linear-gradient(180deg,#0b2041,#122a52);color:#fff;box-shadow:2px 0 12px #0b204140;display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:100;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}.sidebar:before{content:"";position:absolute;top:120px;left:-60px;width:200px;height:200px;background:radial-gradient(circle,rgba(109,202,209,.12) 0%,transparent 70%);pointer-events:none}.sidebar-header{padding:1.25rem;display:flex;align-items:center;border-bottom:1px solid rgba(255,255,255,.08);position:relative;z-index:1}.sidebar-logo{display:flex;align-items:center;gap:10px}.sidebar-logo img{width:32px;height:32px;object-fit:contain;filter:drop-shadow(0 0 8px rgba(109,202,209,.4))}.logo{font-size:1.125rem;font-weight:700;color:#fff;margin:0;letter-spacing:.3px}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto;position:relative;z-index:1}.sidebar-nav ul{list-style:none;padding:0;margin:0}.sidebar-nav li{margin-bottom:2px;padding:0 .5rem}.sidebar-nav a{display:flex;align-items:center;padding:.625rem 1rem;color:#ffffffa6;text-decoration:none;transition:all .15s ease;position:relative;font-weight:500;font-size:.8125rem;border-radius:10px;gap:10px}.sidebar-nav a:hover{background-color:#ffffff0f;color:#ffffffe6}.sidebar-nav a.active{background-color:#6dcad11f;color:#fff;font-weight:600}.sidebar-nav a.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:linear-gradient(180deg,var(--bodenvy-teal),var(--bodenvy-gold));border-radius:0 3px 3px 0}.sidebar-nav .icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;opacity:.85;position:relative;flex-shrink:0}.sidebar-nav a.active .icon{opacity:1}.icon-calendar:before{content:"";background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");width:20px;height:20px;display:block;background-size:contain;background-repeat:no-repeat;position:absolute}.icon-people:before{content:"";background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2'%3E%3C/path%3E%3Ccircle cx='9' cy='7' r='4'%3E%3C/circle%3E%3Cpath d='M23 21v-2a4 4 0 0 0-3-3.87'%3E%3C/path%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'%3E%3C/path%3E%3C/svg%3E");width:20px;height:20px;display:block;background-size:contain;background-repeat:no-repeat;position:absolute}.icon-history:before{content:"";background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='1 4 1 10 7 10'%3E%3C/polyline%3E%3Cpath d='M3.51 15a9 9 0 1 0 2.13-9.36L1 10'%3E%3C/path%3E%3Cpolyline points='12 7 12 12 16 14'%3E%3C/polyline%3E%3C/svg%3E");width:20px;height:20px;display:block;background-size:contain;background-repeat:no-repeat;position:absolute}.icon-users:before{content:"";background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M22 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a4 4 0 0 1 0 7.75'/%3E%3C/svg%3E");width:20px;height:20px;display:block;background-size:contain;background-repeat:no-repeat;position:absolute}.sidebar-section-label{font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#ffffff4d;padding:1rem 1.5rem .375rem}.sidebar-footer{padding:.875rem 1.25rem;border-top:1px solid rgba(255,255,255,.06);font-size:.6875rem;color:#ffffff59;text-align:center;position:relative;z-index:1}@media (max-width: 768px){.sidebar{width:60px}.sidebar:before{display:none}.sidebar-logo img{width:28px;height:28px}.logo,.sidebar-nav .label,.sidebar-section-label{display:none}.sidebar-nav li{padding:0 .25rem}.sidebar-nav a{justify-content:center;padding:.75rem}.sidebar-nav .icon{margin-right:0}.sidebar-footer{display:none}}.loc-dropdown{position:relative}.loc-trigger{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;background:#fff;border:1px solid var(--color-border);border-radius:10px;font-size:.9375rem;font-weight:700;color:var(--bodenvy-navy);cursor:pointer;min-width:220px;transition:all .15s ease;font-family:inherit}.loc-trigger:hover{border-color:#cbd5e1;box-shadow:0 1px 3px #0f172a0f}.loc-pin{width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,var(--bodenvy-blue),var(--bodenvy-teal));display:flex;align-items:center;justify-content:center;color:#fff;font-size:.625rem;font-weight:700;flex-shrink:0;letter-spacing:.02em}.loc-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}.loc-chevron{color:#94a3b8;flex-shrink:0;transition:transform .15s ease}.loc-trigger[aria-expanded=true] .loc-chevron{transform:rotate(180deg)}.loc-panel{position:absolute;top:calc(100% + 6px);left:0;width:280px;background:#fff;border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-lg);z-index:300;overflow:hidden;animation:locFadeIn .12s ease}@keyframes locFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.loc-search-wrap{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--color-border)}.loc-search-icon{color:var(--color-text-lightest);flex-shrink:0}.loc-search{border:none;outline:none;font-size:.8125rem;font-family:inherit;color:var(--bodenvy-navy);width:100%;background:transparent}.loc-search::placeholder{color:var(--color-text-lightest)}.loc-section{padding:6px 0}.loc-section+.loc-section{border-top:1px solid var(--color-border)}.loc-section-label{font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-lightest);padding:6px 14px 4px}.loc-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 14px;background:none;border:none;cursor:pointer;font-size:.8125rem;font-family:inherit;color:var(--bodenvy-navy);text-align:left;transition:background-color .1s ease}.loc-option:hover,.loc-option.highlighted{background-color:#f1f5f9}.loc-option.current{font-weight:600;color:var(--bodenvy-blue)}.loc-option-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loc-check{color:var(--bodenvy-blue);flex-shrink:0}.loc-empty{padding:12px 14px;font-size:.8125rem;color:var(--color-text-lightest);text-align:center}.date-pill-wrap{position:relative}.date-pill{display:inline-flex;align-items:center;gap:2px;background:#fff;border:1px solid var(--color-border);border-radius:10px;padding:3px;height:42px}.dp-arrow{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;background:transparent;color:var(--color-text-light);cursor:pointer;border-radius:8px;transition:all .12s ease}.dp-arrow:hover{background:#f1f5f9;color:var(--bodenvy-navy)}.dp-label{border:none;background:transparent;font-size:.9375rem;font-weight:700;font-family:inherit;color:var(--bodenvy-navy);cursor:pointer;padding:4px 12px;border-radius:6px;white-space:nowrap;transition:background-color .12s ease}.dp-label:hover{background:#f1f5f9}.dp-today-btn{border:none;background:var(--bodenvy-blue);color:#fff;font-size:.75rem;font-weight:700;font-family:inherit;padding:6px 12px;border-radius:6px;cursor:pointer;margin-left:2px;margin-right:2px;white-space:nowrap;transition:background-color .12s ease}.dp-today-btn:hover{background:var(--bodenvy-navy)}.dp-picker{position:absolute;top:calc(100% + 6px);left:0;width:260px;background:#fff;border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-lg);z-index:300;padding:12px;animation:dpFadeIn .12s ease}@keyframes dpFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dp-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.dp-picker-title{font-size:.8125rem;font-weight:600;color:var(--bodenvy-navy)}.dp-picker-nav{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--color-text-light);cursor:pointer;border-radius:6px;transition:all .12s ease}.dp-picker-nav:hover{background:#f1f5f9;color:var(--bodenvy-navy)}.dp-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px}.dp-weekday{font-size:.625rem;font-weight:600;color:var(--color-text-lightest);text-align:center;padding:4px 0}.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.dp-cell{display:flex;align-items:center;justify-content:center;width:32px;height:32px;margin:0 auto;border:none;background:transparent;font-size:.75rem;font-family:inherit;color:var(--bodenvy-navy);cursor:pointer;border-radius:8px;transition:all .1s ease}.dp-cell:hover:not(.dp-empty){background:#f1f5f9}.dp-cell.dp-empty{cursor:default}.dp-cell.dp-today{font-weight:700;color:var(--bodenvy-blue)}.dp-cell.dp-selected{background:var(--bodenvy-blue);color:#fff;font-weight:600}.dp-cell.dp-selected.dp-today{color:#fff}.gs-trigger{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;background:var(--color-input-bg);border:1px solid var(--color-border);border-radius:10px;font-size:.875rem;font-family:inherit;color:var(--color-text-lightest);cursor:pointer;transition:all .15s ease;min-width:200px}.gs-trigger:hover{border-color:#cbd5e1;background:#fff}.gs-trigger.gs-active{border-color:var(--bodenvy-blue);box-shadow:0 0 0 2px #2363af26}.gs-trigger svg{flex-shrink:0;color:var(--color-text-lightest)}.gs-hint{flex:1;text-align:left}.gs-kbd{background:#fff;border:1px solid var(--color-border);border-radius:4px;padding:1px 5px;font-size:.625rem;font-family:SF Mono,Fira Code,monospace;color:var(--color-text-lightest);font-weight:500}.gs-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;justify-content:center;padding-top:15vh;animation:gsOverlayIn .12s ease}@keyframes gsOverlayIn{0%{opacity:0}to{opacity:1}}.gs-modal{width:480px;max-height:420px;background:#fff;border-radius:14px;border:1px solid var(--color-border);box-shadow:0 24px 80px #0f172a33;overflow:hidden;display:flex;flex-direction:column;animation:gsModalIn .15s ease}@keyframes gsModalIn{0%{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.gs-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--color-border)}.gs-input-icon{color:var(--color-text-lightest);flex-shrink:0}.gs-input{flex:1;border:none;outline:none;font-size:.9375rem;font-family:inherit;color:var(--bodenvy-navy);background:transparent}.gs-input::placeholder{color:var(--color-text-lightest)}.gs-esc{background:var(--color-input-bg);border:1px solid var(--color-border);border-radius:4px;padding:2px 6px;font-size:.5625rem;font-family:SF Mono,Fira Code,monospace;color:var(--color-text-lightest);cursor:pointer;font-weight:600}.gs-results{flex:1;overflow-y:auto;padding:6px}.gs-result{display:flex;align-items:center;gap:10px;width:100%;padding:10px;border:none;background:transparent;cursor:pointer;border-radius:8px;font-family:inherit;text-align:left;transition:background-color .1s ease}.gs-result:hover,.gs-result.gs-highlighted{background:#f1f5f9}.gs-result-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--bodenvy-blue),var(--bodenvy-teal));color:#fff;display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:700;flex-shrink:0}.gs-result-info{flex:1;min-width:0}.gs-result-name{font-size:.8125rem;font-weight:600;color:var(--bodenvy-navy)}.gs-result-meta{font-size:.75rem;color:var(--color-text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gs-loading,.gs-empty,.gs-tip{padding:20px 16px;font-size:.8125rem;color:var(--color-text-light);text-align:center}.gs-tip strong{color:var(--bodenvy-navy)}body{margin:0;padding:0;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--bodenvy-navy)}.main-content{flex:1;margin-left:240px;padding:0;background-color:#f8fafc;display:flex;flex-direction:column;min-height:100vh}.top-bar{background-color:#fff;border-bottom:1px solid var(--color-border);padding:0 1.25rem;display:flex;justify-content:space-between;align-items:center;height:64px;position:sticky;top:0;z-index:50;flex-shrink:0}.top-bar-left{display:flex;align-items:center;gap:16px}.top-bar-right{display:flex;align-items:center;gap:12px}.new-consult-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:linear-gradient(135deg,#2363af,#3a8ccb);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s ease}.new-consult-btn:hover{background:linear-gradient(135deg,#0b2041,#2363af);box-shadow:0 2px 8px #2363af4d}.user-menu-container{position:relative}.user-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--bodenvy-blue),var(--bodenvy-teal));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.6875rem;cursor:pointer;transition:opacity .15s ease}.user-avatar:hover{opacity:.85}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:220px;background-color:#fff;border-radius:12px;border:1px solid var(--color-border);box-shadow:var(--shadow-lg);padding:.75rem;display:flex;flex-direction:column;z-index:200;animation:fadeIn .15s ease}.user-info{display:flex;flex-direction:column;padding:.25rem .5rem;margin-bottom:.25rem}.user-name{font-weight:600;font-size:.8125rem;color:var(--bodenvy-navy)}.user-email{font-size:.75rem;color:var(--color-text-light);margin-top:2px}.dropdown-divider{height:1px;background-color:var(--color-border);margin:.375rem 0}.dropdown-item{display:flex;align-items:center;padding:.5rem;border-radius:8px;cursor:pointer;color:var(--bodenvy-navy);text-decoration:none;border:none;background:none;font-size:.8125rem;font-weight:500;text-align:left;width:100%;transition:background-color .15s ease}.dropdown-item:hover{background-color:var(--color-input-bg)}.logout-btn{color:var(--color-danger)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.content-area{flex:1;padding:0}@media (max-width: 768px){.main-content{margin-left:60px}.top-bar{padding:0 .75rem;height:48px}.search-trigger{min-width:auto}.search-hint,.search-kbd{display:none}.location-trigger{min-width:140px}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e4e8eb);padding:1rem}.login-container{background:#fff;border-radius:10px;box-shadow:0 10px 25px #00000014;padding:2.5rem;width:100%;max-width:450px}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:120px;height:120px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center}.swirl-logo{width:100%;height:auto;max-height:120px;object-fit:contain}.login-header h1{font-size:1.8rem;color:#2c3e50;margin:.5rem 0}.login-form{display:flex;flex-direction:column}.error-message{background-color:#ffe0e0;color:#d8000c;padding:10px;border-radius:5px;margin-bottom:1rem;text-align:center}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:8px;font-size:.9rem;color:#555}.form-group input[type=email],.form-group input[type=password]{width:100%;padding:12px;border:1px solid #e1e5eb;border-radius:5px;font-size:1rem;transition:border .2s ease}.form-group input:focus{border-color:#3a8ccb;outline:none;box-shadow:0 0 0 2px #3a8ccb33}.remember-me{display:flex;align-items:center}.remember-me label{display:flex;align-items:center;cursor:pointer;margin-bottom:0}.remember-me input[type=checkbox]{margin-right:8px;width:16px;height:16px}.login-button{background-color:#3a8ccb;color:#fff;border:none;border-radius:5px;padding:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s ease;margin-top:1rem}.login-button:hover{background-color:#2f78b2}.login-button:focus{outline:none;box-shadow:0 0 0 3px #3a8ccb4d}.login-button:disabled{background-color:#a3c9e9;cursor:not-allowed}.microsoft-login-section{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.microsoft-login-button{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:14px 20px;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;font-weight:500;color:#1f2937;cursor:pointer;transition:all .15s ease;box-shadow:0 1px 3px #00000014}.microsoft-login-button:hover{background:#f9fafb;border-color:#9ca3af;box-shadow:0 2px 6px #0000001a}.microsoft-login-button:disabled{opacity:.6;cursor:not-allowed}.login-divider{text-align:center;margin-top:.5rem}.admin-login-link{background:none;border:none;color:#6b7280;font-size:.8125rem;cursor:pointer;text-decoration:underline;padding:4px 8px}.admin-login-link:hover{color:#374151}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh}.loading-spinner{border:4px solid rgba(0,0,0,.1);border-left-color:#3a8ccb;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 480px){.login-container{padding:1.5rem}.login-logo{width:90px;height:90px}.login-header h1{font-size:1.5rem}}:root{--bodenvy-navy: #0B2041;--bodenvy-blue: #2363AF;--bodenvy-medium-blue: #3A8CCB;--bodenvy-teal: #6DCAD1;--bodenvy-gold: #FFC709;--bodenvy-dark-gray: #394148;--bodenvy-gray: #848484;--bodenvy-light-gray: #F7F7F7;--bodenvy-light-blue: #5EB5E6;--bodenvy-pale-blue: #A1DDF3;--bodenvy-lightest-blue: #DFF3FA;--status-booked: #20acf7;--status-confirmed: #111827;--status-arrived: #10B981;--status-completed: #27378a;--status-noshow: #EF4444;--status-cancelled: #F97316;--color-primary: #2363AF;--color-primary-dark: #0B2041;--color-primary-light: #eff6ff;--color-secondary: #64748b;--color-accent: #6DCAD1;--color-success: #10B981;--color-danger: #EF4444;--color-warning: #F97316;--color-info: #3A8CCB;--color-gold: #FFC709;--color-bg: #f8fafc;--color-surface: #ffffff;--color-sidebar: #0B2041;--color-sidebar-dark: #081a35;--color-text: #0B2041;--color-text-light: #64748b;--color-text-lightest: #94a3b8;--color-border: #e2e8f0;--color-input-bg: #f8fafc;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 12px rgba(15, 23, 42, .08);--shadow-lg: 0 12px 40px rgba(15, 23, 42, .12);--shadow-sheet: 0 12px 40px rgba(15, 23, 42, .1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.5}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.25;margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none}button,input,select,textarea{font-family:inherit;font-size:100%}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background-color:var(--color-sidebar);color:#fff;position:fixed;height:100vh;z-index:10}.sidebar-header{padding:var(--spacing-lg);background-color:var(--color-sidebar-dark)}.sidebar .logo{font-size:1.25rem;font-weight:700}.sidebar-nav{padding:var(--spacing-md) 0}.sidebar-nav ul{list-style:none}.sidebar-nav a{display:flex;align-items:center;padding:var(--spacing-md) var(--spacing-lg);color:var(--color-text-lightest);transition:all .2s}.sidebar-nav a:hover{background-color:#ffffff0d;color:#fff}.sidebar-nav a.active{background-color:var(--color-primary);color:#fff}.sidebar-nav .icon{margin-right:var(--spacing-md);width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center}.main-content{flex:1;margin-left:240px;min-width:0}.top-bar{height:56px;background-color:#fff;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg)}.location-selector select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-input-bg);color:var(--color-text);width:200px;font-size:.875rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;background-size:1rem}.user-menu{display:flex;align-items:center}.user-avatar{width:36px;height:36px;border-radius:50%;background-color:var(--color-border);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--color-text)}.content-area{padding:var(--spacing-xl)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xl)}.view-toggle{display:flex;gap:var(--spacing-sm)}.dashboard-header{margin-bottom:var(--spacing-xl);display:flex;justify-content:space-between;align-items:flex-start}.location-info{margin-top:var(--spacing-sm)}.location-info h2{margin-bottom:var(--spacing-xs);font-size:1.25rem}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl)}.dashboard-card{background-color:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.appointments-list h2{margin-bottom:var(--spacing-lg)}.appointments-grid{display:grid;gap:var(--spacing-md)}.appointment-card{display:flex;padding:var(--spacing-md);background-color:var(--color-bg);border-radius:var(--radius-md);border-left:5px solid var(--color-primary);position:relative}.appointment-card.cancelled{border-left-color:var(--color-danger);opacity:.75}.appointment-details{flex:1}.appointment-details h3{margin-bottom:var(--spacing-xs);font-size:1rem}.appointment-details p{color:var(--color-text-light);font-size:.875rem;margin-bottom:var(--spacing-xs)}.appointment-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);justify-content:center}.time-slot-grid{margin-top:var(--spacing-md)}.time-slot-section{margin-bottom:var(--spacing-md)}.time-slot-heading{font-size:.875rem;color:var(--color-text-light);margin-bottom:var(--spacing-sm)}.time-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--spacing-sm)}.time-slot{padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-input-bg);text-align:center;cursor:pointer;display:flex;flex-direction:column;align-items:center;font-size:.875rem}.time-slot:hover{border-color:var(--color-primary);background-color:var(--color-primary-light)}.time-slot.selected{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.time-slot .staff-name{font-size:.75rem;margin-top:var(--spacing-xs);color:var(--color-text-light)}.time-slot.selected .staff-name{color:#fffc}.appointment-form-container{background-color:#fff;padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.form-section{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.form-section h3{font-size:1rem;margin-bottom:var(--spacing-md);color:var(--color-text-light)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-size:.875rem;font-weight:500;color:var(--color-text-light)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-input-bg)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-actions{display:flex;gap:var(--spacing-md)}.client-search-container{background-color:#fff;padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.search-form{margin-bottom:var(--spacing-lg)}.search-box{display:flex;gap:var(--spacing-sm)}.search-box input{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-input-bg)}.client-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-md)}.client-card{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);background-color:var(--color-bg)}.client-info h3{margin-bottom:var(--spacing-sm);font-size:1rem}.client-details{margin-bottom:var(--spacing-md)}.client-details p{display:flex;margin-bottom:var(--spacing-xs);font-size:.875rem}.client-details .label{width:60px;color:var(--color-text-light)}.client-actions{display:flex;gap:var(--spacing-sm)}.search-results{margin-top:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);max-height:200px;overflow-y:auto}.client-result{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border);cursor:pointer;display:flex;flex-direction:column}.client-result:last-child{border-bottom:none}.client-result:hover{background-color:var(--color-primary-light)}.client-result strong{margin-bottom:var(--spacing-xs)}.client-result span{font-size:.75rem;color:var(--color-text-light)}.btn{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-weight:500;cursor:pointer;border:none;transition:all .2s}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-dark)}.btn-secondary{background-color:var(--color-input-bg);color:var(--color-text)}.btn-secondary:hover{background-color:var(--color-border)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover{background-color:#dc2626}.btn:disabled{opacity:.7;cursor:not-allowed}.success-message{background-color:#ecfdf5;border:1px solid #10b981;color:#047857;padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.error-message{background-color:#fef2f2;border:1px solid #ef4444;color:#b91c1c;padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;color:#b91c1c;cursor:pointer;font-size:.875rem;font-weight:500}.no-location-message,.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.loading-spinner{border:3px solid rgba(0,0,0,.1);border-radius:50%;border-top:3px solid var(--color-primary);width:24px;height:24px;animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}.calendar-container{background-color:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.view-buttons{display:flex;gap:var(--spacing-sm)}.calendar-wrapper{height:70vh}.fc{font-family:inherit}.fc .fc-toolbar-title{font-size:1.2rem}.fc .fc-event{border-radius:4px;padding:2px 4px;font-size:.85rem;border:none}.fc .fc-timegrid-event .fc-event-main{padding:4px}.fc .fc-timegrid-slot{height:2.5em}.status-legend{background-color:#fff;border-radius:8px;padding:16px;margin-bottom:20px;box-shadow:0 1px 3px #0000001a}.legend-title{font-size:1rem;font-weight:600;margin-bottom:12px;color:var(--color-text)}.legend-items{display:flex;flex-wrap:wrap;gap:12px}.legend-item{display:flex;align-items:center;min-width:160px;flex:1}.color-box{width:16px;height:16px;border-radius:4px;margin-right:8px;flex-shrink:0}.status-info{display:flex;flex-direction:column}.status-name{font-weight:500;font-size:.875rem}.status-description{font-size:.75rem;color:var(--color-text-light)}@media (max-width: 768px){.legend-items{flex-direction:column;gap:8px}.legend-item{min-width:unset}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.filter-options{margin-bottom:var(--spacing-lg)}.time-range-filter{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-input-bg)}.no-appointments,.no-results{text-align:center;padding:var(--spacing-lg);color:var(--color-text-light)}.no-times-message{text-align:center;padding:var(--spacing-md);background-color:var(--color-bg);border-radius:var(--radius-md);color:var(--color-text-light)}@media screen and (max-width: 1024px){.dashboard-grid{grid-template-columns:1fr}}@media screen and (max-width: 768px){.sidebar{width:60px}.sidebar-header{padding:var(--spacing-md)}.sidebar .logo,.sidebar-nav a .label{display:none}.sidebar-nav a{padding:var(--spacing-md);justify-content:center}.sidebar-nav .icon{margin-right:0}.main-content{margin-left:60px}.form-row{grid-template-columns:1fr}}.App{max-width:1200px;margin:0 auto;padding:2rem;font-family:Arial,sans-serif}h1{color:#3b82f6}.locations{margin-top:2rem}.locations ul{list-style:none;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.locations li{padding:1.5rem;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a;background-color:#f8fafc}.locations h3{margin-top:0;color:#1e3a8a}.error{color:#ef4444;padding:1rem;border-radius:8px;background-color:#fee2e2}
