:root{--brand:#4f46e5;--brand-hover:#4338ca;--brand-50:#eef2ff;--brand-100:#e0e7ff;--brand-200:#c7d2fe;--brand-600:#4f46e5;--brand-700:#4338ca;--primary:var(--brand-color,#4f46e5);--primary-dark:color-mix(in srgb, var(--primary) 82%, #0f172a);--primary-light:color-mix(in srgb, var(--primary) 65%, #fff);--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--surface:#fff;--surface-1:#f4f4f5;--surface-2:#e9e9eb;--border:#e2e8f0;--border-strong:#cbd5e1;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--sidebar-bg:#f1f5f9;--sidebar-top-bg:#e2e8f0;--sidebar-fg:#334155;--sidebar-top-fg:#1e293b;--sidebar-fg-hover:#0f172a;--sidebar-section-fg:#64748b;--sidebar-divider:#00000014;--topbar-bg:#fff;--topbar-fg:#1e293b;--main-bg:#f4f4f5;--main-fg:#1e293b;--main-bg-image:none;--panel-bg:#fff;--panel-fg:#1e293b;--shadow-sm:0 1px 2px #0f172a0f, 0 1px 3px #0f172a0a;--shadow-md:0 4px 12px #0f172a14, 0 2px 4px #0f172a0d;--shadow-lg:0 8px 30px #0f172a1a, 0 4px 8px #0f172a0f;--shadow-xl:0 20px 60px #0f172a2e, 0 8px 20px #0f172a1a;color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-synthesis:none;text-rendering:optimizelegibility;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.5}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--surface-1);min-height:100vh}#root{width:100%;min-height:100svh}h1,h2,h3,h4,h5,h6{color:var(--text-primary);letter-spacing:-.015em;font-family:Inter,system-ui,sans-serif;font-weight:600}p{margin:0}.auth-root{background:linear-gradient(135deg,#0f172a 0%,#1e1b4b 50%,#1a1a3e 100%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex;position:relative;overflow:hidden}.auth-root:before{content:"";pointer-events:none;background:radial-gradient(at 20%,#6366f12e 0%,#0000 55%),radial-gradient(at 80% 20%,#8b5cf61f 0%,#0000 45%),radial-gradient(at 60% 85%,#4f46e51a 0%,#0000 40%);position:absolute;inset:0}.auth-panel{z-index:1;flex-direction:column;align-items:center;gap:1.75rem;width:100%;max-width:420px;display:flex;position:relative}.auth-brand{align-items:center;gap:.75rem;display:flex}.auth-brand-mark{background:linear-gradient(135deg,#818cf8 0%,#4f46e5 100%);border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;display:flex;box-shadow:0 0 0 4px #6366f140,0 4px 16px #4f46e566}.auth-brand-name{color:#f1f5f9;letter-spacing:-.015em;font-size:1.1rem;font-weight:700}.auth-card{background:#fffffffa;border-radius:18px;width:100%;padding:2.25rem 2rem;box-shadow:0 0 0 1px #ffffff1a,0 24px 64px #00000073,0 8px 24px #0000004d}.auth-card h2{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:.3rem;font-size:1.45rem;font-weight:700}.auth-subtitle{color:var(--text-secondary);margin-bottom:1.75rem;font-size:.9rem}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-field{flex-direction:column;gap:.4rem;display:flex}.auth-field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-weight:600}.auth-field input{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);background:#fff;outline:none;padding:.72rem .9rem;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.auth-field input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51f}.auth-field input::placeholder{color:var(--text-tertiary)}.auth-error{color:#dc2626;border-radius:var(--radius-sm);background:#fef2f2;border:1px solid #fecaca;padding:.7rem .9rem;font-size:.875rem}.auth-submit-btn{color:#fff;border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.01em;background:linear-gradient(135deg,#6366f1 0%,#4f46e5 100%);border:none;width:100%;margin-top:.5rem;padding:.8rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:opacity .15s,transform .1s,box-shadow .15s;box-shadow:0 2px 8px #4f46e559}.auth-submit-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 4px 16px #4f46e566}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-footer{color:#94a3b8bf;letter-spacing:.02em;font-size:.78rem}.app-shell{background:var(--surface-1);grid-template-columns:256px 1fr;min-height:100vh;display:grid;position:relative}.app-shell:before{content:"";z-index:0;pointer-events:none;background-image:var(--shell-bg-image);opacity:.08;background-position:50%;background-size:cover;position:fixed;inset:0}.app-sidebar{background:var(--sidebar-bg);z-index:10;border-right:none;flex-direction:column;height:100vh;display:flex;position:sticky;top:0;overflow:hidden}.sidebar-inner{flex-direction:column;flex:1;padding-top:.75rem;padding-bottom:.5rem;display:flex;overflow-y:auto}.sidebar-brand{background:var(--sidebar-top-bg);height:60px;color:var(--sidebar-top-fg);border-bottom:1px solid var(--sidebar-divider);flex-shrink:0;align-items:center;gap:.65rem;padding:0 1rem;display:flex}.brand-mark{background:linear-gradient(135deg,#818cf8 0%,#4f46e5 100%);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex;box-shadow:0 2px 8px #4f46e54d}.brand-name{color:inherit;letter-spacing:-.01em;font-size:.875rem;font-weight:700}.sidebar-nav{flex-direction:column;gap:1px;padding:0 0 0 .5rem;display:flex}.sidebar-section-label{color:var(--sidebar-section-fg);text-transform:none;letter-spacing:.01em;background:#ffffff12;border-left:3px solid #ffffff38;align-items:center;gap:.5rem;margin:.65rem 0 .2rem -.5rem;padding:.45rem .75rem .45rem .9rem;font-size:.72rem;font-weight:700;display:flex}.sidebar-section-label:after{content:"";background:#ffffff1a;flex:1;height:1px}.sidebar-nav-btn{color:var(--sidebar-fg);text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-right:none;border-radius:8px 0 0 8px;align-items:center;gap:.65rem;width:100%;padding:.58rem .75rem .58rem 1rem;font-family:inherit;font-size:.855rem;font-weight:500;line-height:1;transition:background .12s,color .12s;display:flex;position:relative}.nav-icon{opacity:.75;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:flex}.sidebar-nav-btn:hover{background:color-mix(in srgb, var(--sidebar-bg) 90%, var(--sidebar-fg));color:var(--sidebar-fg-hover)}.sidebar-nav-btn:hover .nav-icon{opacity:1}.sidebar-nav-btn.active{background:var(--surface-1);color:var(--primary);border-color:var(--border);box-shadow:inset 3px 0 0 0 var(--primary);z-index:2;font-weight:600}.sidebar-nav-btn.active .nav-icon{opacity:1}.sidebar-nav-btn.active:before{content:"";background:var(--sidebar-bg);pointer-events:none;z-index:3;border-bottom-right-radius:10px;width:10px;height:10px;position:absolute;bottom:100%;right:-1px}.sidebar-nav-btn.active:after{content:"";background:var(--sidebar-bg);pointer-events:none;z-index:3;border-top-right-radius:10px;width:10px;height:10px;position:absolute;top:100%;right:-1px}.sidebar-theme-section{border-top:1px solid var(--sidebar-divider);margin-top:.75rem;padding:.75rem 0 0 .5rem}.theme-toggle{margin-bottom:.5rem}.theme-panel{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;gap:.55rem;margin-right:.5rem;padding:.9rem .85rem;display:flex}.theme-panel h4{color:var(--text-primary);margin-bottom:.1rem;font-size:.8rem;font-weight:700}.theme-panel label{color:var(--text-secondary);font-size:.75rem;font-weight:600}.theme-panel input[type=text]{border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;width:100%;padding:.45rem .6rem;font-family:inherit;font-size:.8rem}.theme-panel input[type=text]:focus{border-color:var(--primary);box-shadow:0 0 0 2px #4f46e51a}.theme-panel input[type=file]{border:1px dashed var(--border-strong);border-radius:var(--radius-sm);background:#fff;width:100%;padding:.35rem;font-size:.78rem}.theme-panel input[type=color]{border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:#fff;width:52px;height:32px;padding:2px}.theme-color-row{grid-template-columns:1fr auto auto;align-items:center;gap:.4rem;display:grid}.theme-color-row label{margin:0}.theme-color-row .theme-swatch-group{align-items:center;gap:2px;display:flex}.theme-swatch-label{color:var(--text-muted,#94a3b8);text-align:center;font-size:.65rem;line-height:1}.theme-notice{color:var(--text-secondary);font-size:.75rem;line-height:1.4}.theme-tab-bar{gap:2px;margin-bottom:.5rem;display:flex}.theme-tab{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;flex:1;padding:.3rem 0;font-size:.75rem;font-weight:600;transition:background .15s,color .15s,border-color .15s}.theme-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.theme-tab:disabled{opacity:.4;cursor:not-allowed}.topbar-store-logo{object-fit:contain;border-radius:6px;flex-shrink:0;width:auto;max-width:120px;height:44px;margin:8px 0}.topbar-business-picker{align-items:center;gap:.5rem;display:flex}.sidebar-footer{border-top:1px solid var(--sidebar-divider);background:var(--sidebar-footer-bg);flex-shrink:0;padding:.6rem .5rem}.sidebar-user{border-radius:var(--radius-sm);align-items:center;gap:.6rem;padding:.55rem .65rem;transition:background .12s;display:flex}.sidebar-user:hover{background:color-mix(in srgb, var(--sidebar-footer-bg) 88%, var(--sidebar-footer-fg))}.user-avatar{color:#fff;letter-spacing:.02em;background:linear-gradient(135deg,#818cf8 0%,#4f46e5 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.7rem;font-weight:700;display:flex}.sidebar-user-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sidebar-user-name{color:var(--sidebar-footer-fg);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--sidebar-footer-fg);opacity:.65;text-transform:capitalize;font-size:.7rem}.sidebar-logout-btn{color:var(--sidebar-footer-fg);opacity:.7;cursor:pointer;background:0 0;border:none;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;padding:.3rem;transition:color .12s,background .12s;display:flex}.sidebar-logout-btn:hover{color:var(--danger);background:#ef444424}.app-workspace{z-index:1;flex-direction:column;min-width:0;display:flex;position:relative}.workspace-topbar{background:var(--topbar-bg);height:60px;color:var(--topbar-fg);border-bottom:1px solid var(--border);z-index:9;flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:0 1.5rem;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:.75rem;min-width:0;display:flex}.topbar-page-title{color:var(--text-primary);white-space:nowrap;font-size:.925rem;font-weight:600}.store-context-badge{background:var(--surface-1);border:1px solid var(--border);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;border-radius:999px;align-items:center;gap:.45rem;max-width:240px;padding:.28rem .75rem;font-size:.78rem;font-weight:600;display:inline-flex;overflow:hidden}.store-logo{object-fit:cover;border:1px solid var(--border);border-radius:5px;width:20px;height:20px}.topbar-business-picker{width:280px}.topbar-business-picker .bp-control{background:var(--surface-1);min-height:34px}.app-main{background:var(--main-bg);background-image:var(--main-bg-image);color:var(--main-fg);background-position:50%;background-size:cover;background-attachment:local;flex:1;padding:1.5rem;overflow-y:auto}.home-page{animation:.25s ease-out fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.welcome-section{max-width:900px}.welcome-header{margin-bottom:1.75rem}.welcome-header h2{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:.3rem;font-size:1.55rem;font-weight:700}.welcome-header p{color:var(--text-secondary);font-size:.9rem}.business-select{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:1.75rem;padding:1.25rem}.business-select label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.6rem;font-size:.8rem;font-weight:600;display:block}.quick-actions{grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:.875rem;display:grid}.quick-action-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;flex-direction:column;gap:.45rem;padding:1.1rem 1.1rem 1rem;font-family:inherit;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex;position:relative}.quick-action-card:hover:not(:disabled){border-color:var(--brand-200,#c7d2fe);transform:translateY(-2px);box-shadow:0 6px 20px #4f46e51a}.quick-action-card:disabled{opacity:.4;cursor:not-allowed}.quick-action-primary{border-color:var(--brand-200,#c7d2fe);background:linear-gradient(145deg,#eef2ff 0%,#f8f9ff 100%)}.qa-icon-wrap{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;margin-bottom:.15rem;display:flex}.qa-icon-indigo{color:#4f46e5;background:#eef2ff}.qa-icon-amber{color:#d97706;background:#fffbeb}.qa-icon-emerald{color:#16a34a;background:#f0fdf4}.qa-icon-violet{color:#7c3aed;background:#f5f3ff}.qa-icon-sky{color:#0284c7;background:#f0f9ff}.qa-icon-pink{color:#c026d3;background:#fdf2f8}.qa-label{color:var(--text-primary);font-size:.875rem;font-weight:600}.qa-desc{color:var(--text-tertiary);font-size:.775rem;line-height:1.4}.bp-container{text-align:left;width:100%;position:relative}.bp-control{border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:#fff;align-items:center;width:100%;min-height:42px;padding:0 .75rem;font-family:inherit;transition:border-color .15s,box-shadow .15s;display:flex}.bp-control--open{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.bp-control--selected{border-color:var(--primary)}.bp-selected-display{justify-content:space-between;align-items:center;gap:.5rem;width:100%;display:flex}.bp-selected-info{flex-direction:column;gap:.1rem;min-width:0;display:flex}.bp-selected-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.bp-selected-meta{color:var(--text-tertiary);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;overflow:hidden}.bp-input-wrap{align-items:center;gap:.5rem;width:100%;display:flex}.bp-search-icon{color:var(--text-tertiary);flex-shrink:0;font-size:.9rem}.bp-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;padding:.5rem 0;font-family:inherit;font-size:.9rem}.bp-input::placeholder{color:var(--text-tertiary)}.bp-clear-btn{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:.2rem .3rem;font-size:.8rem;line-height:1}.bp-clear-btn:hover{color:var(--text-primary);background:var(--surface-2)}.bp-dropdown{z-index:200;border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);background:#fff;max-height:320px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.bp-state{color:var(--text-tertiary);text-align:center;padding:1rem;font-size:.875rem}.bp-state--error{color:var(--danger)}.bp-option{cursor:pointer;border-bottom:1px solid var(--surface-1);padding:.7rem 1rem;font-family:inherit;transition:background .1s}.bp-option:last-child{border-bottom:none}.bp-option:hover{background:var(--surface-1)}.bp-option--active{background:var(--brand-50,#eef2ff)}.bp-option-name{color:var(--text-primary);margin-bottom:.2rem;font-size:.9rem;font-weight:600}.bp-option-meta{color:var(--text-tertiary);flex-wrap:wrap;gap:.5rem;font-size:.78rem;display:flex}.bp-highlight{color:inherit;background:#fef9c3;border-radius:2px;padding:0 1px}.bp-hint{color:var(--text-tertiary);text-align:center;margin-top:.75rem;font-size:.82rem}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.4rem;padding:.65rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:600;transition:background .15s,box-shadow .15s,transform .1s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 4px #4f46e540}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #4f46e54d}.btn-secondary{background:var(--surface);color:var(--text-primary);border:1.5px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-1);border-color:var(--border-strong)}.btn-small,.btn-sm{padding:.45rem .9rem;font-size:.8rem}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#16a34a}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-edit{background:var(--surface-1);color:var(--text-secondary);border-color:var(--border)}.btn-edit:hover:not(:disabled){background:var(--surface-2);color:var(--text-primary)}.btn-checkin{color:#fff;background:#0ea5e9}.btn-checkin:hover:not(:disabled){background:#0284c7}.btn-checkout{color:#fff;background:#16a34a}.btn-checkout:hover:not(:disabled){background:#15803d}.btn-complete{color:#fff;background:#16a34a}.btn-complete:hover:not(:disabled){background:#15803d}.btn-checkin{color:#fff;background:#0284c7;border-color:#0284c7}.btn-checkin:hover:not(:disabled){background:#0369a1;border-color:#0369a1}.btn-cash{color:#fff;background:#15803d;border-color:#15803d}.btn-cash:hover:not(:disabled){background:#166534;border-color:#166534}.btn-cancel{color:#dc2626;background:#fff;border-color:#fca5a5}.btn-cancel:hover:not(:disabled){background:#fee2e2;border-color:#dc2626}.btn-payment{color:#fff;background:#4f46e5;border-color:#4f46e5}.btn-payment:hover:not(:disabled){background:#4338ca;border-color:#4338ca}.button-group{flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;display:flex}.booking-form,.reschedule-form{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);max-width:620px;margin:0 auto;padding:1.75rem}.booking-form h3,.reschedule-form h3{margin-bottom:.4rem;font-size:1.1rem}.booking-form>p,.reschedule-form>p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.875rem}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem;font-size:.8rem;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);background:#fff;outline:none;padding:.65rem .85rem;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.form-group textarea{resize:vertical;min-height:80px}.warning{color:var(--warning);margin-top:.4rem;font-size:.8rem}.error-message{color:#991b1b;border:1px solid #fecaca;border-left:3px solid var(--danger);border-radius:var(--radius-sm);background:#fef2f2;margin-bottom:1.25rem;padding:.875rem 1.1rem;font-size:.875rem}.error-toast{z-index:2000;color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-left:3px solid #dc2626;border-radius:8px;align-items:center;gap:12px;width:max-content;max-width:520px;padding:12px 16px;font-size:14px;display:flex;position:fixed;top:20px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #00000026}.error-toast-close{cursor:pointer;color:#991b1b;opacity:.6;background:0 0;border:none;flex-shrink:0;padding:0;font-size:18px;line-height:1}.error-toast-close:hover{opacity:1}.success-message{color:#166534;border:1px solid #bbf7d0;border-left:3px solid var(--success);border-radius:var(--radius-sm);background:#f0fdf4;margin-bottom:1.25rem;padding:.875rem 1.1rem;font-size:.875rem;animation:.25s ease-out slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.services-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.875rem;margin-bottom:1.25rem;display:grid}.service-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;padding:1.25rem;transition:border-color .15s,box-shadow .15s,transform .15s}.service-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.service-card h4{margin-bottom:.4rem;font-size:.95rem}.service-card p{color:var(--text-secondary);margin:.35rem 0;font-size:.825rem}.service-duration{color:var(--primary);font-weight:600}.time-slots{grid-template-columns:repeat(auto-fill,minmax(95px,1fr));gap:.6rem;display:grid}.time-slot{border:1.5px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);text-align:center;padding:.6rem .5rem;font-family:inherit;font-size:.825rem;font-weight:600;transition:all .15s}.time-slot:hover{border-color:var(--primary);color:var(--primary);background:var(--brand-50,#eef2ff)}.time-slot.selected{background:var(--primary);color:#fff;border-color:var(--primary)}.booking-summary,.change-summary{background:var(--surface-1);border-radius:var(--radius-md);border:1px solid var(--border);margin-bottom:1.25rem;padding:1.25rem}.summary-item,.change-item{border-bottom:1px solid var(--border);justify-content:space-between;padding:.6rem 0;font-size:.875rem;display:flex}.summary-item:last-child,.change-item:last-child{border-bottom:none}.summary-item label,.change-item label{color:var(--text-secondary);font-weight:600}.old-time{color:var(--danger);font-weight:600;text-decoration:line-through}.new-time{color:var(--success);font-weight:600}.reschedule-filters{background:var(--surface-1);border-radius:var(--radius-md);border:1px solid var(--border);grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem;padding:1rem;display:grid}.rp-no-results{color:var(--text-tertiary);text-align:center;padding:1.5rem 0;font-size:.875rem}.apt-customer-name{font-weight:600;color:var(--primary)!important;margin-bottom:.2rem!important}.appointments-list{flex-direction:column;gap:.75rem;display:flex}.appointment-item{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-md);cursor:pointer;justify-content:space-between;align-items:center;padding:1.1rem 1.25rem;transition:border-color .15s,box-shadow .15s;display:flex}.appointment-item:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.appointment-info h4{margin-bottom:.3rem;font-size:.95rem}.appointment-info p{color:var(--text-secondary);margin:.2rem 0;font-size:.8rem}.current-appointment{background:var(--brand-50,#eef2ff);border-left:3px solid var(--primary);border-radius:var(--radius-sm);margin-bottom:1.25rem;padding:1rem;font-size:.875rem}.current-appointment h4{margin-bottom:.4rem}.admin-dashboard{flex-direction:column;gap:1.5rem;display:flex}.admin-container{width:100%;max-width:1200px;margin:0 auto}.admin-container h2{margin-bottom:1.25rem}.admin-tabs{border-bottom:1.5px solid var(--border);flex-wrap:wrap;gap:2px;margin-bottom:1.5rem;padding:0;display:flex}.admin-tabs button{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2.5px solid #0000;margin-bottom:-1.5px;padding:.7rem 1.1rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:color .15s,border-color .15s}.admin-tabs button:hover{color:var(--primary)}.admin-tabs button.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.tab-content{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:1.5rem}.tab-content h3{margin-bottom:1.25rem;font-size:1rem}.date-filter{flex-wrap:wrap;align-items:center;gap:.875rem;margin-bottom:1.25rem;display:flex}.date-filter label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.date-filter input{border:1.5px solid var(--border);border-radius:var(--radius-sm);outline:none;padding:.45rem .7rem;font-family:inherit;font-size:.875rem}.date-filter input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #4f46e51a}.appointments-table,.customers-table,.calls-table{width:100%;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.875rem}table thead{background:var(--surface-1);border-bottom:1.5px solid var(--border)}table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;padding:.75rem 1rem;font-size:.78rem;font-weight:600}table td{border-bottom:1px solid var(--surface-2);color:var(--text-primary);vertical-align:middle;padding:.75rem 1rem}table tr:last-child td{border-bottom:none}table tbody tr:hover{background:var(--surface-1)}.status-badge{letter-spacing:.02em;border-radius:999px;align-items:center;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-flex}.status-scheduled{color:#1d4ed8;background:#dbeafe}.status-completed{color:#15803d;background:#dcfce7}.status-cancelled{color:#dc2626;background:#fee2e2}.status-pending{color:#92400e;background:#fef3c7}.status-noshow{color:#a16207;background:#fef9c3}.status-checkedin{color:#0369a1;background:#e0f2fe}.outcome-badge{border-radius:999px;align-items:center;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-flex}.outcome-booking{color:#166534;background:#dcfce7}.outcome-rescheduling{color:#0c4a6e;background:#dbeafe}.outcome-information{color:#6b21a8;background:#f3e8ff}.outcome-no-answer{color:#7f1d1d;background:#fee2e2}.outcome-transferred{color:#92400e;background:#fef3c7}.sentiment-badge{white-space:nowrap;border-radius:999px;align-items:center;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-flex}.sentiment-positive{color:#15803d;background:#dcfce7}.sentiment-negative{color:#b91c1c;background:#fee2e2}.sentiment-neutral{color:#64748b;background:#f1f5f9}.customer-info{flex-direction:column;gap:.2rem;display:flex}.customer-info strong{color:var(--text-primary);font-weight:600}.customer-info small{color:var(--text-tertiary);font-size:.775rem}.action-buttons{flex-wrap:wrap;gap:.4rem;display:flex}.call-stats{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:.875rem;margin-bottom:1.5rem;display:grid}.stat-card{background:linear-gradient(135deg, var(--primary-light) 0%, var(--primary) 100%);color:#fff;border-radius:var(--radius-lg);flex-direction:column;align-items:flex-start;gap:.4rem;padding:1.25rem;display:flex}.stat-label{opacity:.85;text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:500}.stat-value{letter-spacing:-.03em;font-size:1.7rem;font-weight:700}.employees-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;display:grid}.employee-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;transition:border-color .15s,box-shadow .15s}.employee-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.employee-card h4{margin-bottom:.75rem;font-size:.95rem}.employee-card p{color:var(--text-secondary);margin:.35rem 0;font-size:.85rem}.employee-card .active{color:var(--success);font-weight:600}.employee-card .inactive{color:var(--danger);font-weight:600}.business-hours-grid{grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:.875rem;display:grid}.hours-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);text-align:center;padding:1.1rem}.hours-card h4{margin-bottom:.75rem;font-size:.875rem}.hours-card p{color:var(--text-secondary);font-size:.875rem;font-weight:600}.hours-card .closed{color:var(--danger);font-size:1rem}.chatbot-portal{max-width:900px;margin:0 auto}.chatbot-header{margin-bottom:1rem}.chatbot-header h2{margin-bottom:.2rem}.chatbot-header p{color:var(--text-secondary);font-size:.875rem}.chatbot-window{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:.65rem;min-height:420px;max-height:520px;padding:1rem;display:flex;overflow-y:auto}.chat-msg{border-radius:var(--radius-md);gap:.4rem;padding:.7rem .9rem;font-size:.875rem;line-height:1.5;display:flex}.chat-msg.user{background:var(--brand-50,#eef2ff);border:1px solid var(--brand-200,#c7d2fe);align-self:flex-end;max-width:85%}.chat-msg.assistant{background:var(--surface-1);border:1px solid var(--border);align-self:flex-start;max-width:90%}.chatbot-form{grid-template-columns:1fr auto auto;gap:.6rem;margin-top:.875rem;display:grid}.chatbot-form input{border:1.5px solid var(--border);border-radius:var(--radius-sm);outline:none;width:100%;padding:.65rem .85rem;font-family:inherit;font-size:.875rem}.chatbot-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.appts-page{max-width:1100px;margin:0 auto}.appts-header{justify-content:space-between;align-items:center;margin-bottom:1.1rem;display:flex}.appts-header-left{align-items:baseline;gap:.875rem;display:flex}.appts-header h2{margin:0;font-size:1.15rem}.appts-count{color:var(--text-tertiary);font-size:.825rem}.walk-in-btn{white-space:nowrap;padding:.45rem 1.1rem;font-size:.875rem}.walk-in-modal{background:var(--surface);border-radius:var(--radius-lg);flex-direction:column;width:100%;max-width:480px;margin:auto;display:flex;overflow:hidden;box-shadow:0 20px 60px #0000002e}.walk-in-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;padding:1.25rem 1.5rem 1rem;display:flex}.walk-in-modal-body{flex-direction:column;gap:1rem;padding:1.25rem 1.5rem;display:flex}.walk-in-modal-footer{justify-content:flex-end;gap:.75rem;padding-top:.5rem;display:flex}.appts-filters{background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);flex-wrap:nowrap;align-items:flex-end;gap:.65rem .75rem;margin-bottom:1.1rem;padding:.875rem 1.1rem;display:flex;overflow-x:auto}.appts-filter-group{flex-direction:column;flex:1 1 0;gap:.3rem;min-width:100px;display:flex}.appts-filter-group label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;font-weight:600}.appts-filter-group input[type=date],.appts-filter-group input[type=text],.appts-filter-group select{border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);background:#fff;outline:none;padding:.45rem .6rem;font-family:inherit;font-size:.825rem}.appts-filter-group input[type=date]:focus,.appts-filter-group input[type=text]:focus,.appts-filter-group select:focus{border-color:var(--primary);box-shadow:0 0 0 2px #4f46e51a}.appts-refresh-btn{white-space:nowrap;align-self:flex-end;padding:.45rem .9rem;font-size:.825rem}.appts-table-wrap{border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow-x:auto}.appts-table{border-collapse:collapse;background:var(--surface);width:100%;font-size:.875rem}.appts-table thead tr{background:var(--surface-1);border-bottom:1.5px solid var(--border)}.appts-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;-webkit-user-select:none;user-select:none;padding:.7rem 1rem;font-size:.72rem;font-weight:600}.appts-table th.sortable{cursor:pointer}.appts-table th.sortable:hover{color:var(--primary);background:var(--surface-2)}.sort-icon{color:var(--primary);margin-left:.3rem;font-size:.7rem}.sort-icon--idle{color:var(--text-tertiary)}.appts-table tbody tr{border-bottom:1px solid var(--surface-2);transition:background .1s}.appts-table tbody tr:last-child{border-bottom:none}.appts-table tbody tr:hover{background:var(--surface-1)}.appts-table tbody tr.visit-group-header{background:var(--surface-1);border-top:1px solid var(--primary,#4f46e5)}.appts-table tbody tr.visit-group-header:hover{background:var(--surface-2)}.visit-summary-cell{color:var(--text-muted,#6b7280);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;font-size:.75rem;font-weight:700}.visit-collapse-btn{cursor:pointer;width:18px;height:18px;color:var(--text-muted,#6b7280);vertical-align:middle;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;margin-right:5px;padding:0;transition:background .15s;display:inline-flex}.visit-collapse-btn:hover{background:var(--surface-3,#00000014);color:var(--text-primary)}.visit-collapse-btn svg{transition:transform .2s}.visit-collapse-btn.collapsed svg{transform:rotate(-90deg)}.visit-total-cell{vertical-align:middle}.visit-total-amt{color:var(--text-primary);font-weight:700}.visit-txn-badge{color:var(--text-secondary,#6b7280);letter-spacing:.04em;vertical-align:middle;margin-left:.5rem;font-family:monospace;font-size:.72rem;font-weight:600;display:inline-block}.visit-txn-link{color:var(--primary);background:color-mix(in srgb, var(--primary) 10%, transparent);border:1px solid color-mix(in srgb, var(--primary) 30%, transparent);cursor:pointer;vertical-align:middle;border-radius:4px;margin-left:.4rem;padding:1px 5px;font-family:monospace;font-size:.72rem;line-height:1.4;text-decoration:none;display:inline-block}.visit-txn-link:hover{background:color-mix(in srgb, var(--primary) 18%, transparent);text-decoration:underline}.receipt-overlay{z-index:1100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.receipt-box{background:var(--surface-0,#fff);border-radius:14px;width:100%;max-width:460px;max-height:90vh;padding:28px;overflow-y:auto;box-shadow:0 20px 60px #00000040}.receipt-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.receipt-title{color:var(--text-primary);font-size:18px;font-weight:700}.receipt-txn{color:var(--text-secondary,#6b7280);letter-spacing:.03em;margin-top:3px;font-family:monospace;font-size:12px}.receipt-close{cursor:pointer;color:#9ca3af;background:0 0;border:none;flex-shrink:0;padding:0;font-size:24px;line-height:1}.receipt-close:hover{color:var(--text-primary)}.receipt-meta{background:var(--surface-1,#f9fafb);border-radius:8px;margin-bottom:18px;padding:12px 14px}.receipt-meta-row{justify-content:space-between;align-items:baseline;padding:3px 0;font-size:13px;display:flex}.receipt-label{color:var(--text-secondary,#6b7280);flex-shrink:0;margin-right:12px;font-weight:500}.receipt-value{color:var(--text-primary);text-align:right;font-weight:500}.receipt-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary,#6b7280);margin-bottom:8px;font-size:11px;font-weight:700}.receipt-services{border:1px solid var(--border,#e5e7eb);border-radius:8px;margin-bottom:18px;overflow:hidden}.receipt-service-row{border-bottom:1px solid var(--border,#e5e7eb);justify-content:space-between;align-items:center;padding:10px 14px;font-size:14px;display:flex}.receipt-service-row:last-child{border-bottom:none}.receipt-service-info{flex-direction:column;gap:2px;display:flex}.receipt-service-name{color:var(--text-primary);font-weight:600}.receipt-service-emp{color:var(--text-secondary,#6b7280);font-size:12px}.receipt-service-price{color:var(--text-primary);flex-shrink:0;margin-left:12px;font-weight:600}.receipt-totals{border-top:1px solid var(--border,#e5e7eb);margin-bottom:18px;padding-top:14px}.receipt-total-row{color:var(--text-primary);justify-content:space-between;align-items:center;padding:4px 0;font-size:14px;display:flex}.receipt-total-paid{font-size:15px;font-weight:700}.receipt-total-status{margin-top:4px}.receipt-stripe-link{text-align:center;background:var(--surface-1,#f9fafb);border:1px solid var(--border,#e5e7eb);color:var(--primary);border-radius:8px;margin-bottom:10px;padding:10px;font-size:13px;font-weight:600;text-decoration:none;display:block}.receipt-stripe-link:hover{text-decoration:underline}.receipt-charge-id{color:var(--text-secondary,#9ca3af);text-align:center;font-family:monospace;font-size:11px}.appts-table tbody tr.visit-service-row td{background:0 0;border-bottom:none;padding-top:.3rem;padding-bottom:.3rem}.appts-table tbody tr.visit-service-row:hover td{background:var(--surface-1)}.visit-svc-time{color:var(--text-muted,#6b7280);white-space:nowrap;font-size:.85rem;border-left:2px solid var(--accent,#6366f1)!important;padding-left:.75rem!important}.visit-svc-name{font-weight:500}.appts-table tbody tr.visit-service-last td{border-bottom:2px solid var(--surface-2,#e5e7eb);padding-bottom:.6rem}.appts-table td{color:var(--text-primary);vertical-align:middle;padding:.7rem 1rem}.appts-customer-name{color:var(--text-primary);font-weight:600}.appts-customer-phone,.appts-meta{color:var(--text-tertiary);margin-top:1px;font-size:.78rem}.appts-unassigned{color:var(--text-tertiary);font-style:italic}.appts-actions{flex-wrap:wrap;gap:.4rem;display:flex}.appts-empty{text-align:center;color:var(--text-tertiary);padding:2.5rem;font-size:.9rem}.chatbot-manager{max-width:1100px;margin:0 auto}.cm-header{margin-bottom:1.25rem}.cm-header h2{margin-bottom:.25rem}.cm-header p{color:var(--text-secondary);font-size:.875rem}.cm-loading{color:var(--text-tertiary);padding:2rem 0;font-size:.875rem}.cm-empty{color:var(--text-tertiary);font-size:.875rem;font-style:italic}.cm-layout{align-items:flex-start;gap:1.5rem;display:flex}.cm-list{flex-direction:column;flex:1;gap:.875rem;min-width:0;display:flex}.cm-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem;transition:border-color .15s}.cm-card--active{border-color:var(--primary)}.cm-card-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.875rem;display:flex}.cm-biz-info{flex-direction:column;gap:.15rem;display:flex}.cm-biz-info strong{font-size:1rem}.cm-biz-meta{color:var(--text-tertiary);font-size:.8rem}.cm-card-actions{flex-shrink:0;gap:.5rem;display:flex}.cm-snippet-block{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);padding:.75rem}.cm-snippet-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;font-size:.72rem;font-weight:600;display:block}.cm-snippet-pre{color:var(--text-primary);white-space:pre-wrap;word-break:break-all;margin:0;font-family:Menlo,Consolas,monospace;font-size:.775rem;line-height:1.5}.cm-preview-panel{background:var(--surface);border:1.5px solid var(--primary);border-radius:var(--radius-lg);flex-shrink:0;width:500px;position:sticky;top:1rem;overflow:hidden}.cm-preview-header{background:var(--primary);color:#fff;justify-content:space-between;align-items:center;padding:.7rem 1rem;font-size:.875rem;font-weight:600;display:flex}.cm-close-btn{color:#fff;cursor:pointer;background:0 0;border:none;padding:0 .2rem;font-size:1.1rem;line-height:1}.cm-preview-panel .chatbot-portal{max-width:none;margin:0;padding:1rem}.feature-flags-panel{flex-direction:column;gap:.75rem;display:flex}.feature-flag-row{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.feature-flag-info{flex-direction:column;gap:.15rem;display:flex}.feature-flag-info strong{color:var(--text-primary);font-size:.9rem}.feature-flag-info small{color:var(--text-secondary);font-size:.75rem}.feature-toggle{cursor:pointer;flex-shrink:0;align-items:center;width:44px;height:24px;display:inline-flex;position:relative}.feature-toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{background:var(--border-strong);border-radius:999px;transition:background .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.feature-toggle input:checked+.toggle-slider{background:var(--success)}.feature-toggle input:checked+.toggle-slider:before{transform:translate(20px)}.feature-badge{border-radius:999px;align-items:center;padding:.15rem .45rem;font-size:.7rem;font-weight:600;display:inline-flex}.feature-badge--on{color:#15803d;background:#dcfce7}.feature-badge--off{color:#dc2626;background:#fee2e2}.salon-logo-preview{object-fit:cover;border:1px solid var(--border);border-radius:10px;width:44px;height:44px;margin-bottom:.35rem}.embed-widget{background:var(--surface-1);flex-direction:column;height:100vh;font-family:Inter,system-ui,sans-serif;display:flex}.embed-header{background:var(--primary);color:#fff;align-items:center;gap:.6rem;padding:.7rem 1rem;font-size:.9rem;font-weight:600;display:flex}.embed-dot{background:#86efac;border-radius:50%;flex-shrink:0;width:8px;height:8px}.embed-reset-btn{color:#fff;cursor:pointer;background:#ffffff2e;border:none;border-radius:6px;margin-left:auto;padding:.25rem .5rem;font-size:1rem;line-height:1}.embed-reset-btn:hover:not(:disabled){background:#ffffff4d}.embed-window{flex-direction:column;flex:1;gap:.6rem;padding:.75rem;display:flex;overflow-y:auto}.embed-msg{border-radius:var(--radius-md);word-break:break-word;max-width:88%;padding:.6rem .8rem;font-size:.875rem;line-height:1.5}.embed-msg.user{background:var(--brand-50,#eef2ff);border:1px solid var(--brand-200,#c7d2fe);align-self:flex-end}.embed-msg.assistant{background:var(--surface);border:1px solid var(--border);align-self:flex-start}.embed-typing{letter-spacing:.3em;color:var(--text-tertiary)}.embed-error{color:#991b1b;background:#fef2f2;border-top:1px solid #fecaca;padding:.4rem .75rem;font-size:.78rem}.embed-form{background:var(--surface);border-top:1px solid var(--border);gap:.5rem;padding:.75rem;display:flex}.embed-form input{border:1.5px solid var(--border);border-radius:var(--radius-sm);outline:none;flex:1;padding:.6rem .8rem;font-family:inherit;font-size:.875rem}.embed-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.embed-form button{background:var(--primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;padding:.6rem 1rem;font-family:inherit;font-size:.875rem;font-weight:600}.embed-form button:disabled{opacity:.5;cursor:not-allowed}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.section-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.section-header h3{margin:0;font-size:1.05rem}.section-subtitle{color:var(--text-tertiary);margin-top:.2rem;font-size:.8rem}.salon-cards-grid{border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;display:flex;overflow:hidden}.salon-card-item{background:var(--surface);border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:.875rem;padding:.9rem 1.1rem;transition:background .12s;display:flex}.salon-card-item:last-child{border-bottom:none}.salon-card-item:hover{background:var(--surface-1)}.salon-card-item.active{background:var(--brand-50,#eef2ff)}.salon-card-logo{border:1px solid var(--border);background:var(--surface-2);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex;overflow:hidden}.salon-card-logo img{object-fit:cover;border-radius:inherit;width:100%;height:100%}.upload-field{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.upload-preview{object-fit:cover;border:1px solid var(--border-color);border-radius:8px;width:56px;height:56px}.upload-hint{color:var(--text-tertiary);font-size:.8rem}.salon-card-logo-placeholder{color:var(--text-tertiary);font-size:1.1rem;font-weight:700}.salon-card-info{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.salon-card-primary-line{white-space:nowrap;flex-wrap:nowrap;align-items:baseline;gap:.3rem;display:flex;overflow:hidden}.salon-card-primary-line strong{color:var(--text-primary);white-space:nowrap;font-size:.9rem;font-weight:600}.salon-card-primary-line span{color:var(--text-tertiary);white-space:nowrap;font-size:.775rem}.salon-card-sep{color:var(--border,#e2e8f0)}.salon-card-info strong{color:var(--text-primary);font-size:.9rem;font-weight:600}.salon-card-info>span{color:var(--text-tertiary);white-space:nowrap;text-overflow:ellipsis;font-size:.775rem;overflow:hidden}.salon-card-chevron{color:var(--text-tertiary);flex-shrink:0;font-size:1.3rem;line-height:1}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:.6rem;padding:3rem 1rem;display:flex}.empty-state-icon{font-size:2.5rem}.empty-state h4{color:var(--text-primary);margin:0;font-size:1rem;font-weight:600}.empty-state p{color:var(--text-tertiary);font-size:.875rem}.empty-state-sm{text-align:center;color:var(--text-tertiary);background:var(--surface-1);border-radius:var(--radius-md);border:1px dashed var(--border-strong);margin-bottom:1rem;padding:1.25rem;font-size:.875rem}.loading-state{text-align:center;color:var(--text-tertiary);padding:2rem;font-size:.875rem}.drawer-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);background:#0f172a59;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.drawer-panel{background:var(--panel-bg);width:500px;max-width:100vw;color:var(--panel-fg);z-index:101;flex-direction:column;animation:.22s cubic-bezier(.25,.46,.45,.94) drawerSlideIn;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-4px 0 40px #0f172a24}@keyframes drawerSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem 1rem;display:flex}.drawer-title{color:var(--text-primary);margin-bottom:.15rem;font-size:1.05rem;font-weight:700}.drawer-subtitle{color:var(--text-tertiary);font-size:.78rem}.drawer-close{color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;padding:.3rem .4rem;font-size:1rem;line-height:1;transition:color .12s,background .12s}.drawer-close:hover{color:var(--text-primary);background:var(--surface-2)}.drawer-tabs{border-bottom:1px solid var(--border);flex-shrink:0;padding:0 1.5rem;display:flex}.drawer-tabs button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2.5px solid #0000;margin-bottom:-1px;padding:.6rem .9rem;font-family:inherit;font-size:.845rem;font-weight:500;transition:color .15s,border-color .15s}.drawer-tabs button:hover{color:var(--primary)}.drawer-tabs button.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.drawer-body{flex:1;padding:1.25rem 1.5rem;overflow-y:auto}.drawer-form{flex-direction:column;gap:.875rem;display:flex}.drawer-divider{background:var(--border);height:1px;margin:.5rem 0}.drawer-section-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.25rem;font-size:.72rem;font-weight:700}.drawer-section-desc{color:var(--text-tertiary);margin-top:-.5rem;margin-bottom:.25rem;font-size:.8rem}.drawer-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:.75rem;margin-top:.5rem;padding-top:.875rem;display:flex}.manager-rows{border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;margin-bottom:.25rem;display:flex;overflow:hidden}.manager-row-item{border-bottom:1px solid var(--border);background:var(--surface);align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.manager-row-item:last-child{border-bottom:none}.manager-row-info{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.manager-row-info strong{color:var(--text-primary);font-size:.875rem;font-weight:600}.manager-row-info span{color:var(--text-tertiary);font-size:.775rem}.manager-row-actions{flex-shrink:0;gap:.4rem;display:flex}.optional-label{color:var(--text-tertiary);font-size:.75em;font-weight:400}.chip-group{flex-wrap:wrap;gap:.4rem;margin-top:.25rem;display:flex}.chip{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;border-radius:999px;padding:.3rem .75rem;font-family:inherit;font-size:.8rem;font-weight:500;transition:border-color .12s,background .12s,color .12s}.chip:hover{border-color:var(--primary);color:var(--primary)}.chip-active{background:var(--brand-50,#eef2ff);border-color:var(--primary);color:var(--primary);font-weight:600}@media (width<=1024px){.app-shell{grid-template-columns:220px 1fr}}@media (width<=768px){.app-shell{grid-template-rows:auto 1fr;grid-template-columns:1fr}.app-sidebar{border-bottom:1px solid #ffffff1a;border-right:none;height:auto;position:static}.sidebar-inner{flex-direction:row;gap:0;padding:.5rem .75rem;overflow:auto visible}.sidebar-brand{border-bottom:none;flex-shrink:0;margin-bottom:0;padding:.5rem .75rem .5rem 0}.sidebar-nav{flex-direction:row;gap:2px;padding:0}.sidebar-section-label{display:none}.sidebar-nav-btn{white-space:nowrap;border-radius:var(--radius-sm);border:1px solid #0000;flex-shrink:0}.sidebar-nav-btn.active{border-radius:var(--radius-sm);box-shadow:none;border-color:#0000}.sidebar-nav-btn.active:before,.sidebar-nav-btn.active:after{display:none}.sidebar-theme-section{border-top:none;border-left:1px solid #ffffff1a;margin-top:0;margin-left:.25rem;padding-top:0;padding-left:.5rem}.sidebar-footer{display:none}.app-main{padding:1rem}.income-page{padding:1rem 1rem 2rem}.workspace-topbar{padding:0 1rem}.quick-actions{grid-template-columns:repeat(2,1fr)}.chatbot-form{grid-template-columns:1fr}.call-stats{grid-template-columns:repeat(2,1fr)}.employees-grid,.business-hours-grid{grid-template-columns:1fr}.button-group{flex-direction:column}.button-group button{width:100%}.services-grid{grid-template-columns:1fr}.time-slots{grid-template-columns:repeat(3,1fr)}.admin-tabs button{padding:.6rem .75rem;font-size:.8rem}table{font-size:.8rem}table th,table td{padding:.6rem .75rem}.cm-layout{flex-direction:column}.cm-preview-panel{width:100%;position:static}}.appts-header-right{align-items:center;gap:.75rem;display:flex}.view-toggle{border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;overflow:hidden}.view-toggle-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:.35rem .9rem;font-size:.825rem;font-weight:500;transition:background .15s,color .15s}.view-toggle-btn:not(:last-child){border-right:1px solid var(--border)}.view-toggle-btn:hover{background:var(--surface-1);color:var(--text-primary)}.view-toggle-btn.active{background:var(--primary);color:#fff}.cal-container{flex-direction:column;gap:.75rem;display:flex}.cal-nav{justify-content:space-between;align-items:center;display:flex}.cal-nav-left{align-items:center;gap:.5rem;display:flex}.cal-today-btn{padding:.35rem .875rem!important;font-size:.8rem!important}.cal-arrow-btn{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:30px;height:30px;color:var(--text-secondary);background:0 0;justify-content:center;align-items:center;font-size:1.2rem;line-height:1;transition:background .15s;display:flex}.cal-arrow-btn:hover{background:var(--surface-1)}.cal-date-label{color:var(--text-primary);margin-left:.25rem;font-size:.9rem;font-weight:600}.cal-loading-hint{color:var(--text-tertiary);font-size:.78rem}.cal-viewport{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);max-height:calc(100vh - 230px);overflow:auto}.cal-inner{flex-direction:column;display:flex}.cal-staff-headers{z-index:10;background:var(--surface);border-bottom:2px solid var(--border);display:flex;position:sticky;top:0}.cal-time-gutter-header{border-right:1px solid var(--border);flex-shrink:0;width:60px}.cal-staff-header{border-right:1px solid var(--border);flex-direction:column;flex:1;align-items:center;gap:4px;min-width:160px;padding:.6rem .5rem;display:flex}.cal-staff-avatar{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:.8rem;font-weight:700;display:flex}.cal-staff-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-size:.78rem;font-weight:600;overflow:hidden}.cal-body{display:flex}.cal-time-gutter{border-right:1px solid var(--border);flex-shrink:0;width:60px}.cal-hour-label{border-bottom:1px solid var(--border);justify-content:flex-end;align-items:flex-start;padding-top:4px;padding-right:8px;display:flex}.cal-hour-label span{color:var(--text-tertiary);white-space:nowrap;margin-top:0;font-size:.68rem;line-height:1;transform:translateY(-50%)}.cal-staff-body{border-right:1px solid var(--border);flex:1;min-width:160px;position:relative}.cal-hour-cell{border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;position:absolute;left:0;right:0}.cal-hour-cell:hover{background:color-mix(in srgb, var(--primary) 6%, transparent)}.cal-appt-block{cursor:grab;z-index:2;-webkit-user-select:none;user-select:none;border-left:3px solid;border-radius:4px;padding:3px 6px;transition:filter .12s,box-shadow .12s,opacity .1s;position:absolute;left:4px;right:4px;overflow:hidden}.cal-appt-block:hover{filter:brightness(.93);box-shadow:0 2px 8px #00000024}.cal-appt-block.is-dragging{opacity:.35;cursor:grabbing}.cal-staff-body.drag-over{background:color-mix(in srgb, var(--primary) 6%, transparent)}.search-input{border:1.5px solid var(--border);width:100%;color:var(--text-primary);background:var(--surface);box-sizing:border-box;border-radius:8px;padding:.5rem .875rem;font-size:.875rem;transition:border-color .15s}.search-input:focus{border-color:var(--primary);outline:none}.cal-nav-right{align-items:center;gap:.625rem;display:flex}.cal-staff-picker{position:relative}.cal-staff-picker-btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:.4rem;padding:.42rem .85rem;font-size:.83rem;font-weight:500;transition:border-color .12s,color .12s,background .12s;display:inline-flex}.cal-staff-picker-btn:hover{border-color:var(--primary);color:var(--primary)}.cal-staff-picker-btn.filtered{border-color:var(--primary);color:var(--primary);background:color-mix(in srgb, var(--primary) 8%, var(--surface));font-weight:600}.cal-staff-picker-drop{background:var(--surface);border:1px solid var(--border);z-index:50;border-radius:10px;min-width:200px;padding:.375rem 0;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 8px 24px #0000001f}.cal-staff-picker-opt{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.6rem;padding:.55rem 1rem;font-size:.85rem;transition:background .1s;display:flex}.cal-staff-picker-opt:hover{background:var(--surface-hover,#f3f4f6)}.cal-staff-picker-check{border:2px solid var(--border);border-radius:4px;flex-shrink:0;width:16px;height:16px;transition:background .1s,border-color .1s}.cal-staff-picker-check.checked{background:var(--primary);border-color:var(--primary);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:10px}.cal-staff-picker-av{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.65rem;font-weight:700;display:inline-flex}.cal-staff-picker-all-label{font-weight:500}.cal-staff-picker-divider{background:var(--border);height:1px;margin:.25rem 0}.cal-appt-customer{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;font-weight:600;overflow:hidden}.cal-appt-service{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.67rem;overflow:hidden}.cal-appt-time{color:var(--text-tertiary);font-size:.64rem}.appt-form-panel{flex-direction:column;display:flex;overflow:hidden}.appt-form-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem 1rem;display:flex}.appt-form-title{color:var(--text-primary);letter-spacing:-.015em;font-size:1.15rem;font-weight:700}.appt-form-customer-section{border-bottom:1px solid var(--border);flex-shrink:0;padding:1rem 1.5rem}.appt-form-customer-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.appt-form-cust-avatar{background:var(--surface-2);width:38px;height:38px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.95rem;font-weight:700;display:flex}.appt-form-cust-info{flex:1;min-width:0}.appt-form-cust-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.appt-form-cust-phone{color:var(--text-secondary);margin-top:1px;font-size:.78rem}.appt-form-cust-clear{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;font-size:1rem;line-height:1}.appt-form-cust-clear:hover{color:var(--text-primary);background:var(--surface-2)}.appt-form-cust-input{border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--surface);width:100%;color:var(--text-primary);outline:none;padding:.65rem .875rem;font-family:inherit;font-size:.875rem;transition:border-color .15s}.appt-form-cust-input:focus{border-color:var(--primary)}.appt-form-cust-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:200;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden}.appt-form-cust-option{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.6rem 1rem;transition:background .1s;display:flex}.appt-form-cust-option:hover{background:var(--surface-1)}.appt-form-cust-opt-av{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.78rem;font-weight:700;display:flex}.appt-form-cust-opt-name{color:var(--text-primary);font-size:.85rem;font-weight:600}.appt-form-cust-opt-phone{color:var(--text-secondary);font-size:.75rem}.appt-form-cust-hint{color:var(--text-tertiary);padding:.5rem 0;font-size:.78rem}.appt-form-tabs{border-bottom:2px solid var(--border);flex-shrink:0;display:flex}.appt-form-tab{letter-spacing:.06em;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-2px;padding:.75rem 1rem;font-size:.78rem;font-weight:700;transition:color .15s,border-color .15s}.appt-form-tab.active{color:var(--text-primary);border-bottom-color:var(--text-primary)}.appt-form-body{flex-direction:column;flex:1;gap:1rem;padding:1.25rem 1.5rem;display:flex;overflow-y:auto}.appt-form-date-row{align-items:center;gap:.75rem;display:flex}.appt-form-date-badge{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;white-space:nowrap;padding:.35rem .875rem;font-size:.825rem;font-weight:600;transition:background .1s}.appt-form-date-badge:hover{background:var(--surface-2)}.appt-form-date-badge.is-today{color:var(--primary);border-color:var(--primary);background:var(--brand-50)}.appt-form-date-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-primary);outline:none;flex:1;padding:.4rem .75rem;font-family:inherit;font-size:.875rem}.appt-form-date-input:focus{border-color:var(--primary)}.appt-form-date-label{color:var(--text-secondary);margin-top:-.25rem;font-size:.8rem;font-weight:500}.appt-form-service-block{background:var(--surface-1);border-radius:var(--radius-md);border:1px solid var(--border);flex-direction:column;gap:.625rem;padding:1rem;display:flex}.appt-form-svc-card{border-left:4px solid var(--primary);padding-left:.75rem}.appt-form-svc-card-top{justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;display:flex}.appt-form-svc-name{color:var(--text-primary);font-size:.9rem;font-weight:700}.appt-form-svc-placeholder{color:var(--text-tertiary);font-size:.875rem}.appt-form-svc-meta{color:var(--text-secondary);margin-top:2px;font-size:.75rem}.appt-form-svc-price{color:var(--text-primary);font-size:.9rem;font-weight:700}.appt-form-svc-remove{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.9rem}.appt-form-svc-remove:hover{color:var(--danger);background:#fee2e2}.appt-form-svc-select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:100%;color:var(--text-primary);outline:none;padding:.45rem .625rem;font-family:inherit;font-size:.825rem}.appt-form-time-row{align-items:flex-end;gap:.5rem;display:flex}.appt-form-time-field{flex-direction:column;flex:1;gap:4px;display:flex}.appt-form-time-field label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.appt-form-time-field input[type=time]{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-primary);outline:none;width:100%;padding:.45rem .625rem;font-family:inherit;font-size:.9rem}.appt-form-time-field input[type=time]:focus{border-color:var(--primary)}.appt-form-time-sep{color:var(--text-tertiary);padding-bottom:8px;font-size:1rem}.appt-form-staff-field{flex-direction:column;gap:4px;display:flex}.appt-form-staff-field label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.appt-form-staff-field select{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-primary);outline:none;padding:.45rem .625rem;font-family:inherit;font-size:.875rem}.appt-form-add-svc-btn{border:1.5px dashed var(--border);border-radius:var(--radius-md);letter-spacing:.06em;color:var(--text-secondary);cursor:pointer;text-align:center;background:0 0;width:100%;padding:.75rem;font-size:.8rem;font-weight:700;transition:border-color .15s,color .15s,background .15s}.appt-form-add-svc-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--brand-50)}.appt-form-footer{border-top:2px solid var(--border);flex-direction:column;flex-shrink:0;gap:.875rem;padding:1rem 1.5rem;display:flex}.appt-form-total{gap:2rem;display:flex}.appt-form-total-label{color:var(--text-secondary);margin-bottom:2px;font-size:.75rem}.appt-form-total-amount{color:var(--text-primary);letter-spacing:-.02em;font-size:1.3rem;font-weight:800}.appt-form-footer-btns{gap:.75rem;display:flex}.appt-form-discard-btn{border:1.5px solid var(--border);border-radius:var(--radius-sm);letter-spacing:.06em;color:var(--text-secondary);cursor:pointer;background:0 0;flex:1;padding:.75rem;font-size:.825rem;font-weight:700;transition:background .15s,color .15s}.appt-form-discard-btn:hover:not(:disabled){background:var(--surface-1);color:var(--text-primary)}.appt-form-save-btn{background:var(--text-primary);border-radius:var(--radius-sm);letter-spacing:.06em;color:#fff;cursor:pointer;border:none;flex:2;padding:.75rem;font-size:.825rem;font-weight:700;transition:opacity .15s}.appt-form-save-btn:hover:not(:disabled){opacity:.88}.appt-form-save-btn:disabled,.appt-form-discard-btn:disabled{opacity:.5;cursor:not-allowed}.appt-form-slots-section{padding-top:.25rem}.appt-form-slots-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;font-size:.7rem;font-weight:700}.appt-form-slots-grid{flex-wrap:wrap;gap:.375rem;display:flex}.appt-form-slot-chip{border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:20px;padding:.3rem .75rem;font-size:.78rem;font-weight:500;transition:border-color .12s,color .12s,background .12s}.appt-form-slot-chip:hover{border-color:var(--primary);color:var(--primary);background:var(--brand-50)}.appt-form-slot-chip.selected{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.appt-form-staff-pref{border:1.5px solid var(--border);border-radius:8px;margin-top:.5rem;display:flex;overflow:hidden}.appt-form-pref-btn{background:var(--surface);color:var(--text-secondary);cursor:pointer;text-align:center;border:none;flex:1;padding:.42rem .5rem;font-size:.775rem;font-weight:500;transition:background .12s,color .12s}.appt-form-pref-btn:first-child{border-right:1.5px solid var(--border)}.appt-form-pref-btn.active{background:var(--primary);color:#fff;font-weight:600}.appt-form-pref-btn:not(.active):hover{background:color-mix(in srgb, var(--primary) 8%, var(--surface));color:var(--primary)}.appt-form-slots-loading,.appt-form-slots-empty{color:var(--text-tertiary);padding:.25rem 0;font-size:.775rem;font-style:italic}.comm-detail-row{border-bottom:1px solid var(--border);align-items:baseline;gap:.75rem;padding:.5rem 0;display:flex}.comm-detail-row:last-of-type{border-bottom:none}.comm-detail-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;min-width:80px;font-size:.75rem;font-weight:600}.comm-detail-value{color:var(--text-primary);font-size:.875rem}.income-page{background:var(--bg-primary,#f8fafc);max-width:1100px;min-height:100%;padding:1.5rem 2rem 3rem}.income-header{margin-bottom:1.25rem}.income-header h2{color:var(--text-primary);margin:0;font-size:1.25rem;font-weight:700}.income-filter-bar{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.income-period-tabs{background:var(--bg-secondary,#f1f5f9);border-radius:8px;gap:.25rem;padding:3px;display:flex}.income-period-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem .85rem;font-size:.875rem;font-weight:500;transition:background .15s,color .15s}.income-period-tab.active{color:var(--primary,#4f46e5);background:#fff;box-shadow:0 1px 3px #0000001a}.income-date-range{align-items:center;gap:.75rem;display:flex}.income-date-range label{color:var(--text-secondary);align-items:center;gap:.4rem;font-size:.875rem;display:flex}.income-date-range input[type=date]{border:1px solid var(--border-color,#e2e8f0);background:#fff;border-radius:6px;padding:.35rem .6rem;font-size:.875rem}.income-run-btn{background:var(--primary,#4f46e5);color:#fff;cursor:pointer;border:none;border-radius:7px;padding:.45rem 1.1rem;font-size:.875rem;font-weight:600;transition:opacity .15s}.income-run-btn:disabled{opacity:.55;cursor:default}.income-period-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem;font-size:.875rem;font-weight:600}.income-store-summary{border:1px solid var(--border-color,#e2e8f0);background:#fff;border-radius:10px;margin-bottom:1rem;padding:.75rem 1rem}.income-store-summary h3{color:var(--text-muted,#94a3b8);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .6rem;font-size:.8rem;font-weight:600}.income-store-grid{flex-wrap:nowrap;gap:.4rem;display:flex;overflow-x:auto}.income-store-card{background:var(--bg-secondary,#f8fafc);white-space:nowrap;border-radius:6px;flex:1 1 0;min-width:0;padding:.45rem .65rem}.income-store-card-total{background:color-mix(in srgb, var(--primary,#4f46e5) 8%, #fff)}.income-store-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted,#94a3b8);white-space:nowrap;margin-bottom:.15rem;font-size:.65rem}.income-store-val{color:var(--text-primary);font-size:.9rem;font-weight:700}.income-val-green{color:var(--success,#22c55e)}.income-val-red{color:var(--danger,#ef4444)}.income-section{background:var(--surface-1,#fff);border:1px solid var(--border-color,#e2e8f0);border-radius:12px;margin-bottom:1.5rem;padding:1.25rem 1.5rem}.income-section h3{color:var(--text-primary);background:var(--surface-1,#fff);margin:0 0 .75rem;font-size:1rem;font-weight:700}.income-staff-list{flex-direction:column;gap:.5rem;display:flex}.income-staff-row{border:1px solid var(--border-color,#e2e8f0);cursor:pointer;background:#fff;border-radius:10px;align-items:center;gap:1rem;padding:.9rem 1.1rem;transition:box-shadow .15s,border-color .15s;display:flex}.income-staff-row:hover{border-color:var(--primary,#4f46e5);box-shadow:0 2px 8px #4f46e51a}.income-staff-info{flex:1;align-items:baseline;gap:.6rem;display:flex}.income-staff-name{color:var(--text-primary);white-space:nowrap;font-size:.9375rem;font-weight:600}.income-staff-meta{color:var(--text-muted,#94a3b8);font-size:.775rem}.income-staff-amounts{text-align:right}.income-staff-earnings{color:var(--success,#22c55e);font-size:1rem;font-weight:700}.income-staff-tips{color:var(--text-secondary);font-size:.75rem}.income-staff-chevron{color:var(--text-muted,#94a3b8);font-size:1.25rem;line-height:1}.income-staff-header{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.income-staff-header h2{color:var(--text-primary);flex:1;margin:0;font-size:1.125rem;font-weight:700}.income-back-btn{border:1px solid var(--border-color,#e2e8f0);cursor:pointer;color:var(--text-secondary);background:0 0;border-radius:7px;padding:.35rem .85rem;font-size:.875rem;transition:background .15s}.income-back-btn:hover{background:var(--bg-secondary,#f1f5f9)}.income-period-badge{background:var(--brand-50,#eef2ff);color:var(--primary,#4f46e5);border-radius:20px;padding:.25rem .65rem;font-size:.75rem;font-weight:600}.income-summary-cards{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.income-card{border:1px solid var(--border-color,#e2e8f0);text-align:center;background:#fff;border-radius:14px;padding:1.25rem 1rem}.income-card-icon{justify-content:center;margin-bottom:.75rem;display:flex}.income-card-icon.green{color:#22c55e}.income-card-icon.blue{color:#3b82f6}.income-card-value{color:var(--text-primary);font-size:1.75rem;font-weight:800;line-height:1.1}.income-card-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted,#94a3b8);margin-top:.4rem;font-size:.7rem;font-weight:600}.income-split-grid{border:1px solid var(--border-color,#e2e8f0);background:#fff;border-radius:10px;overflow:hidden}.income-split-row{color:var(--text-primary);border-bottom:1px solid var(--border-color,#e2e8f0);justify-content:space-between;align-items:center;padding:.65rem 1rem;font-size:.875rem;display:flex}.income-split-row:last-child{border-bottom:none}.income-split-total{background:var(--bg-secondary,#f8fafc);font-weight:700}.income-split-rate{color:var(--text-muted,#94a3b8);font-size:.8rem}.income-split-value{color:var(--success,#22c55e);font-weight:600}.income-table-wrap{border:1px solid #c8cfd8;margin-top:.5rem;overflow-x:auto}.income-table{border-collapse:collapse;table-layout:fixed;background:#fff;width:100%;font-family:Inter,system-ui,sans-serif;font-size:.8rem}.income-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:#374151;white-space:nowrap;z-index:1;background:#f0f2f5;border:1px solid #c8cfd8;padding:.38rem .6rem;font-size:.68rem;font-weight:700;position:sticky;top:0;overflow:hidden}.income-table td{color:#1f2937;white-space:nowrap;text-overflow:ellipsis;border:1px solid #dde1e7;padding:.3rem .6rem;font-size:.8rem;overflow:hidden}.income-table-store th:first-child{width:82px}.income-table-store th:nth-child(2){width:92px}.income-table-store th:nth-child(3){width:62px}.income-table-store th:nth-child(4){width:120px}.income-table-store th:nth-child(5){width:100px}.income-table-store th:nth-child(6){width:120px}.income-table-store th:nth-child(7){width:72px}.income-table-store th:nth-child(8){text-align:left;width:58px}.income-table-store th:nth-child(9){text-align:right;width:72px}.income-table-store th:nth-child(10){width:62px}.income-table-store th:nth-child(11){text-align:right;width:68px}.income-table-store th:nth-child(12),.income-table-store th:nth-child(13){text-align:right;width:72px}.income-table:not(.income-table-store) th:first-child{width:82px}.income-table:not(.income-table-store) th:nth-child(2){width:92px}.income-table:not(.income-table-store) th:nth-child(3){width:62px}.income-table:not(.income-table-store) th:nth-child(4){width:130px}.income-table:not(.income-table-store) th:nth-child(5){width:150px}.income-table:not(.income-table-store) th:nth-child(6){width:72px}.income-table:not(.income-table-store) th:nth-child(7){text-align:left;width:58px}.income-table:not(.income-table-store) th:nth-child(8){text-align:right;width:72px}.income-table:not(.income-table-store) th:nth-child(9){width:62px}.income-table:not(.income-table-store) th:nth-child(10){text-align:right;width:68px}.income-table:not(.income-table-store) th:nth-child(11){text-align:right;width:78px}.income-table tbody tr:nth-child(2n) td{background:#f7f8fa}.income-table tbody tr:hover td{background:#eef2ff}.income-table tr:last-child td{border-bottom:1px solid #dde1e7}.income-customer{color:#111827;font-weight:600}.income-earnings{color:#16a34a;text-align:right;font-weight:700}.income-rate{white-space:nowrap}.income-rate-badge{color:#374151;font-size:.72rem;font-weight:500;display:inline-block}.income-rate-na{color:#9ca3af}.income-txn-num{color:#64748b;white-space:nowrap;font-family:monospace;font-size:.78rem}.income-txn-link{color:var(--primary,#6366f1);cursor:pointer;white-space:nowrap;background:#ede9fe;border:1px solid #c4b5fd;border-radius:3px;padding:1px 5px;font-family:monospace;font-size:.78rem;font-weight:600}.income-txn-link:hover{background:#ddd6fe;text-decoration:underline}.income-service-cell{color:#374151}.income-time{white-space:nowrap;color:#6b7280}.income-type,.income-staff-cell{color:#6b7280}.income-store-net{color:#4f46e5;text-align:right;font-weight:700}.income-table-store tfoot tr.income-table-totals td{background:#eef2ff;border-top:2px solid #6366f1;padding:.35rem .6rem;font-size:.8rem}.income-table-store tfoot tr.income-table-totals .income-store-net,.income-table-store tfoot tr.income-table-totals .income-earnings{color:inherit}.btn-checkout{color:#fff;background:#0891b2;border:none}.btn-checkout:hover{background:#0e7490}.co-root{background:#f4f4f5;flex-direction:column;align-items:center;min-height:100vh;padding:0 0 48px;display:flex}.co-header{color:#fff;text-align:center;background:#4f46e5;width:100%;padding:28px 20px 22px}.co-biz-name{letter-spacing:.01em;font-size:1.25rem;font-weight:700}.co-cust-name{opacity:.85;margin-top:4px;font-size:1rem}.co-card{background:#fff;border-radius:16px;width:100%;max-width:540px;margin-top:-16px;padding:28px 24px 32px;box-shadow:0 8px 32px #0000001a}.co-steps{justify-content:center;align-items:center;gap:0;margin-bottom:28px;display:flex}.co-step{flex-direction:column;align-items:center;gap:4px;display:flex}.co-step-dot{color:#9ca3af;background:#e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.co-step-active .co-step-dot{color:#fff;background:#4f46e5}.co-step-done .co-step-dot{color:#fff;background:#10b981}.co-step-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.co-step-active .co-step-label{color:#4f46e5}.co-step-done .co-step-label{color:#10b981}.co-step-line{background:#e5e7eb;flex:1;min-width:32px;height:2px;margin:0 6px 18px}.co-step-line-done{background:#10b981}.co-section{flex-direction:column;gap:0;display:flex}.co-services{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:22px;padding:12px 14px}.co-svc-row{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:flex-start;padding:6px 0;display:flex}.co-svc-row:last-child{border-bottom:none}.co-svc-name{color:#1a1a2e;font-size:15px;font-weight:600}.co-svc-emp{color:#6b7280;margin-top:2px;font-size:12px}.co-svc-price{color:#374151;white-space:nowrap;font-size:15px;font-weight:600}.co-subtotal-row{color:#1a1a2e;border-top:1px solid #e5e7eb;justify-content:space-between;margin-top:4px;padding-top:8px;font-size:15px;font-weight:700;display:flex}.co-tip-label{color:#374151;margin-bottom:12px;font-size:16px;font-weight:600}.co-tip-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px;display:grid}.co-tip-btn{cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:3px;padding:14px 8px;transition:border-color .15s,background .15s;display:flex}.co-tip-btn:hover{background:#eef2ff;border-color:#a5b4fc}.co-tip-btn-active{background:#eef2ff!important;border-color:#4f46e5!important}.co-tip-btn-none{border-color:#e5e7eb}.co-tip-btn-none.co-tip-btn-active{background:#f3f4f6!important;border-color:#6b7280!important}.co-tip-pct{color:#1a1a2e;font-size:16px;font-weight:700}.co-tip-amt{color:#6b7280;font-size:13px}.co-custom-tip-wrap{margin-bottom:16px;position:relative}.co-custom-tip-dollar{color:#6b7280;font-size:16px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.co-custom-tip-input{box-sizing:border-box;border:1.5px solid #d1d5db;border-radius:9px;width:100%;padding:13px 14px 13px 28px;font-size:18px}.co-custom-tip-input:focus{border-color:#4f46e5;outline:none;box-shadow:0 0 0 3px #eef2ff}.co-total-row{color:#374151;border-top:1px solid #f0f0f0;justify-content:space-between;align-items:center;margin-top:4px;padding:14px 0 18px;font-size:18px;font-weight:600;display:flex}.co-total-amt{color:#4f46e5;font-size:24px;font-weight:800}.co-sign-prompt{color:#374151;margin-bottom:14px;font-size:17px;font-weight:600}.co-canvas-wrap{touch-action:none;background:#fafafa;border:2px solid #d1d5db;border-radius:10px;margin-bottom:10px;position:relative;overflow:hidden}.co-canvas{cursor:crosshair;touch-action:none;width:100%;display:block}.co-canvas-hint{color:#d1d5db;pointer-events:none;justify-content:center;align-items:center;font-size:16px;font-style:italic;display:flex;position:absolute;inset:0}.co-card-prompt{color:#374151;margin-bottom:6px;font-size:17px;font-weight:600}.co-card-hint{color:#9ca3af;margin-bottom:14px;font-size:13px}.co-card-el{background:#fff;border:1.5px solid #d1d5db;border-radius:9px;min-height:52px;margin-bottom:4px;padding:14px}.co-btn-primary{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:10px;width:100%;margin-top:6px;padding:16px;font-size:17px;font-weight:700;transition:background .15s}.co-btn-primary:hover:not(:disabled){background:#4338ca}.co-btn-primary:disabled{cursor:default;background:#9ca3af}.co-btn-pay{padding:18px;font-size:19px}.co-btn-ghost{color:#6b7280;cursor:pointer;background:0 0;border:1.5px solid #e5e7eb;border-radius:8px;align-self:flex-start;margin-bottom:8px;padding:8px 16px;font-size:13px}.co-btn-ghost:hover{background:#f9fafb}.co-loading,.co-error-screen{text-align:center;color:#6b7280;padding:48px 20px;font-size:15px}.co-error-screen{color:#dc2626}.co-error{color:#dc2626;background:#fee2e2;border-radius:8px;margin-top:8px;padding:10px 14px;font-size:14px}.co-success{text-align:center;padding:40px 0 20px}.co-success-icon{color:#059669;background:#d1fae5;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 18px;font-size:36px;display:flex}.co-success-title{color:#065f46;margin-bottom:8px;font-size:24px;font-weight:800}.co-success-amt{color:#374151;margin-bottom:6px;font-size:20px;font-weight:700}.co-success-tip{color:#6b7280;margin-bottom:4px;font-size:14px}.co-success-msg{color:#9ca3af;margin-top:12px;font-size:15px}.income-empty{color:var(--text-muted,#94a3b8);padding:1rem 0;font-size:.875rem}.income-empty-state{text-align:center;color:var(--text-muted,#94a3b8);padding:3rem 1rem;font-size:.9rem}.income-loading{text-align:center;color:var(--text-muted,#94a3b8);padding:2rem}.booking-link-row{align-items:center;gap:8px;display:flex}.booking-link-input{border:1px solid var(--border-color,#e2e8f0);color:var(--text-secondary,#4b5563);background:var(--input-bg,#f8fafc);border-radius:6px;flex:1;min-width:0;padding:8px 10px;font-family:monospace;font-size:13px}.booking-link-copy{background:var(--brand-color,#4f46e5);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:6px;flex-shrink:0;padding:8px 14px;font-size:13px;font-weight:600;transition:opacity .15s}.booking-link-copy:hover{opacity:.85}.booking-snippet-wrap{margin-top:6px;position:relative}.booking-snippet{color:#cdd6f4;white-space:pre;background:#1e1e2e;border-radius:8px;margin:0;padding:12px 14px;font-family:Menlo,Consolas,monospace;font-size:12px;line-height:1.6;overflow-x:auto}.booking-snippet-copy{color:#cdd6f4;cursor:pointer;background:#ffffff1f;border:1px solid #fff3;border-radius:4px;padding:4px 10px;font-size:11px;font-weight:600;transition:background .15s;position:absolute;top:8px;right:8px}.booking-snippet-copy:hover{background:#ffffff38}.cbk-root{background:#f4f4f5;flex-direction:column;align-items:center;min-height:100vh;padding-bottom:60px;display:flex}.cbk-header{color:#fff;text-align:center;background:#4f46e5;width:100%;padding:28px 20px 22px}.cbk-biz-name{letter-spacing:.01em;font-size:1.3rem;font-weight:700}.cbk-biz-addr{opacity:.8;margin-top:4px;font-size:.9rem}.cbk-content{width:100%;max-width:600px;padding:0 16px}.cbk-stepbar{justify-content:center;align-items:center;padding:20px 0 4px;display:flex}.cbk-sb-step{flex-direction:column;align-items:center;gap:4px;display:flex}.cbk-sb-dot{color:#9ca3af;background:#e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.cbk-sb-active .cbk-sb-dot{color:#fff;background:#4f46e5}.cbk-sb-done .cbk-sb-dot{color:#fff;background:#10b981}.cbk-sb-label{color:#9ca3af;white-space:nowrap;font-size:10px}.cbk-sb-active .cbk-sb-label{color:#4f46e5;font-weight:600}.cbk-sb-done .cbk-sb-label{color:#10b981}.cbk-sb-line{background:#e5e7eb;flex:1;min-width:8px;height:2px;margin:0 3px 18px}.cbk-sb-line-done{background:#10b981}.cbk-section-title{color:#111827;margin:20px 0 4px;font-size:1.1rem;font-weight:700}.cbk-section-hint{color:#6b7280;margin:0 0 14px;font-size:13px}.cbk-back{color:#6b7280;cursor:pointer;background:0 0;border:none;padding:16px 0 0;font-size:14px;display:block}.cbk-back:hover{color:#374151}.cbk-empty{color:#6b7280;text-align:center;padding:32px 0;font-size:15px}.cbk-loading-sm{color:#6b7280;padding:20px 0;font-size:14px}.cbk-no-slots{color:#6b7280;text-align:center;background:#f9fafb;border-radius:8px;margin:8px 0;padding:14px;font-size:14px}.cbk-slots-err{color:#b91c1c;background:#fef2f2}.cbk-svc-list{flex-direction:column;gap:8px;margin-bottom:8px;display:flex}.cbk-svc-row{cursor:pointer;text-align:left;background:#fff;border:2px solid #e5e7eb;border-radius:12px;align-items:center;gap:12px;padding:14px 16px;transition:border-color .15s,box-shadow .15s;display:flex;position:relative}.cbk-svc-row:hover{border-color:#a5b4fc}.cbk-svc-row-sel{background:#fafafe;border-color:#4f46e5}.cbk-svc-checkbox{color:#0000;border:2px solid #d1d5db;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;font-weight:700;transition:border-color .15s,background .15s,color .15s;display:flex}.cbk-svc-checkbox-sel{color:#fff;background:#4f46e5;border-color:#4f46e5}.cbk-svc-order{color:#fff;background:#4f46e5;border-radius:99px;padding:1px 6px;font-size:10px;font-weight:700;position:absolute;top:-8px;left:12px}.cbk-svc-thumb{object-fit:cover;border-radius:8px;flex-shrink:0;width:44px;height:44px}.cbk-svc-details{flex:1;min-width:0}.cbk-svc-row-name{color:#111827;font-size:15px;font-weight:700}.cbk-svc-row-desc{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.cbk-svc-meta-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:3px;display:flex}.cbk-svc-dur{color:#6b7280;background:#f3f4f6;border-radius:99px;padding:2px 8px;font-size:12px}.cbk-svc-price-tag{color:#4f46e5;font-size:14px;font-weight:700}.cbk-svc-footer{background:#fff;border:2px solid #4f46e5;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;margin-top:12px;padding:12px 16px;display:flex}.cbk-svc-footer-info{color:#374151;align-items:center;gap:8px;font-size:14px;display:flex}.cbk-footer-count{color:#4f46e5;font-weight:700}.cbk-footer-sep{color:#d1d5db}.cbk-next-inline{width:auto!important;margin-top:0!important;padding:10px 20px!important;font-size:14px!important}.cbk-date-input{color:#111827;box-sizing:border-box;cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:8px;width:100%;padding:10px 12px;font-size:15px}.cbk-date-input:focus{border-color:#4f46e5;outline:none}.cbk-slots-date{color:#6b7280;margin:16px 0 10px;font-size:13px;font-weight:600}.cbk-time-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px;margin-bottom:8px;display:grid}.cbk-time-btn{color:#374151;cursor:pointer;text-align:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;padding:10px 4px;font-size:14px;font-weight:600;transition:border-color .15s,background .15s,color .15s}.cbk-time-btn:hover{background:#eef2ff;border-color:#a5b4fc}.cbk-time-btn-sel{color:#fff!important;background:#4f46e5!important;border-color:#4f46e5!important}.cbk-staff-blocks{flex-direction:column;gap:16px;margin-bottom:8px;display:flex}.cbk-staff-block{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.cbk-staff-block-hd{background:#f9fafb;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.cbk-staff-svc-name{color:#111827;font-size:14px;font-weight:700}.cbk-staff-svc-time{color:#6b7280;font-size:12px}.cbk-staff-row{-webkit-overflow-scrolling:touch;gap:10px;padding:14px 16px;display:flex;overflow-x:auto}.cbk-staff-card{cursor:pointer;background:0 0;border:2px solid #e5e7eb;border-radius:12px;flex-direction:column;flex-shrink:0;align-items:center;gap:6px;min-width:100px;max-width:140px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.cbk-staff-card:hover{background:#f5f3ff;border-color:#a5b4fc}.cbk-staff-card-sel{background:#eef2ff!important;border-color:#4f46e5!important}.cbk-staff-card-busy{opacity:.75;border-color:#e5e7eb}.cbk-staff-card-busy:hover{background:#f9fafb;border-color:#d1d5db}.cbk-staff-card-busy.cbk-staff-card-sel{opacity:1;background:#fffbeb!important;border-color:#f59e0b!important}.cbk-staff-card-busy-badge{color:#92400e;background:#fef3c7;border:1px solid #fcd34d;border-radius:4px;margin-top:2px;padding:1px 6px;font-size:10px;font-weight:600}.cbk-staff-avatar{color:#4f46e5;background:#e0e7ff;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;font-weight:700;display:flex}.cbk-avatar-any{color:#10b981;background:#f0fdf4;font-size:16px}.cbk-staff-avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%}.cbk-staff-card-name{color:#374151;text-align:center;white-space:nowrap;font-size:12px;font-weight:600}.cbk-staff-card-desc{color:#6b7280;text-align:center;-webkit-line-clamp:3;white-space:normal;-webkit-box-orient:vertical;max-width:120px;font-size:11px;line-height:1.4;display:-webkit-box;overflow:hidden}.cbk-nostaff-wrap{background:#fafafa;border-radius:10px;flex-direction:column;gap:10px;padding:14px;display:flex}.cbk-nostaff-msg{color:#374151;margin:0;font-size:14px}.cbk-nostaff-actions{flex-wrap:wrap;gap:8px;display:flex}.cbk-nostaff-btn{cursor:pointer;border:2px solid #0000;border-radius:8px;flex:1;min-width:140px;padding:9px 14px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s}.cbk-nostaff-back{color:#374151;background:#f3f4f6;border-color:#e5e7eb}.cbk-nostaff-back:hover{background:#e5e7eb}.cbk-nostaff-waitlist{color:#fff;background:#4f46e5}.cbk-nostaff-waitlist:hover{background:#4338ca}.cbk-waitlist-form{flex-direction:column;gap:8px;padding-top:4px;display:flex}.cbk-waitlist-hint{color:#6b7280;margin:0 0 2px;font-size:12px}.cbk-waitlist-success{color:#065f46;background:#d1fae5;border-radius:8px;padding:10px 14px;font-size:14px;font-weight:500}.cbk-form{flex-direction:column;gap:4px;margin-bottom:8px;display:flex}.cbk-label{color:#374151;align-items:center;gap:6px;margin-top:12px;font-size:13px;font-weight:600;display:flex}.cbk-req{color:#ef4444;font-size:12px}.cbk-opt{color:#9ca3af;font-size:12px;font-weight:400}.cbk-input{color:#111827;box-sizing:border-box;background:#fff;border:2px solid #e5e7eb;border-radius:8px;width:100%;padding:10px 12px;font-size:15px}.cbk-input:focus{border-color:#4f46e5;outline:none}.cbk-textarea{color:#111827;box-sizing:border-box;resize:vertical;background:#fff;border:2px solid #e5e7eb;border-radius:8px;width:100%;padding:10px 12px;font-family:inherit;font-size:15px}.cbk-textarea:focus{border-color:#4f46e5;outline:none}.cbk-summary{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:20px;overflow:hidden}.cbk-sum-group{padding:14px 18px}.cbk-sum-group+.cbk-sum-group{border-top:1px solid #f3f4f6}.cbk-sum-group-label{text-transform:uppercase;letter-spacing:.08em;color:#9ca3af;margin-bottom:10px;font-size:10px;font-weight:700}.cbk-sum-row{justify-content:space-between;align-items:flex-start;gap:8px;padding:4px 0;display:flex}.cbk-sum-key{color:#6b7280;flex-shrink:0;width:60px;font-size:13px}.cbk-sum-val{color:#111827;text-align:right;font-size:14px;font-weight:500}.cbk-confirm-svc{border-bottom:1px solid #f3f4f6;padding:7px 0}.cbk-confirm-svc:last-child{border-bottom:none}.cbk-confirm-svc-name{color:#111827;font-size:14px;font-weight:600}.cbk-confirm-svc-meta{color:#6b7280;flex-wrap:wrap;align-items:center;gap:6px;margin-top:2px;font-size:12px;display:flex}.cbk-confirm-staff{color:#4f46e5;font-weight:600}.cbk-next-btn{color:#fff;cursor:pointer;background:#4f46e5;border:none;border-radius:10px;width:100%;margin-top:16px;padding:14px;font-size:16px;font-weight:700;transition:background .15s}.cbk-next-btn:hover:not(:disabled){background:#4338ca}.cbk-next-btn:disabled{cursor:default;background:#c7d2fe}.cbk-submit-btn{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:10px;width:100%;padding:16px;font-size:17px;font-weight:700;transition:background .15s}.cbk-submit-btn:hover:not(:disabled){background:#059669}.cbk-submit-btn:disabled{cursor:default;background:#a7f3d0}.cbk-error-msg{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:12px;padding:12px 14px;font-size:14px}.cbk-error-card{color:#dc2626;text-align:center;background:#fff;border-radius:12px;margin-top:24px;padding:24px;font-size:15px;box-shadow:0 4px 16px #00000014}.cbk-spinner-wrap{justify-content:center;align-items:center;min-height:100vh;display:flex}.cbk-spinner{border:4px solid #e5e7eb;border-top-color:#4f46e5;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite cbk-spin}@keyframes cbk-spin{to{transform:rotate(360deg)}}.cbk-success-wrap{text-align:center;flex-direction:column;align-items:center;width:100%;max-width:480px;padding:48px 24px;display:flex}.cbk-success-icon{color:#fff;background:#10b981;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:20px;font-size:28px;display:flex;box-shadow:0 4px 16px #10b9814d}.cbk-success-title{color:#111827;margin:0 0 4px;font-size:1.6rem;font-weight:800}.cbk-success-biz{color:#4f46e5;margin:0 0 24px;font-size:15px;font-weight:600}.cbk-success-details{background:#fff;border:1px solid #e5e7eb;border-radius:12px;width:100%;margin-bottom:20px;padding:16px 20px}.cbk-sd-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;padding:6px 0;display:flex}.cbk-sd-row:last-child{border-bottom:none}.cbk-sd-key{color:#6b7280;font-size:13px}.cbk-sd-val{color:#111827;font-size:14px;font-weight:600}.cbk-success-note{color:#6b7280;margin-bottom:24px;font-size:14px}.cbk-book-another{color:#4f46e5;cursor:pointer;background:0 0;border:2px solid #4f46e5;border-radius:10px;padding:12px 24px;font-size:15px;font-weight:600;transition:background .15s,color .15s}.cbk-book-another:hover{color:#fff;background:#4f46e5}
