:root{color-scheme:light;font-family:Inter,sans-serif;--bg: #f4f5f7;--surface: #ffffff;--surface-soft: #f8f9fb;--surface-low: #f1f5fb;--surface-high: #e8eef7;--border: #dfe1e6;--border-strong: #c3c6d6;--text: #051a3e;--muted: #434654;--subtle: #737685;--primary: #0052cc;--primary-strong: #003d9b;--secondary: #00b8d9;--secondary-soft: #d9f7ff;--tertiary: #6554c0;--tertiary-soft: #ece8ff;--success: #1f845a;--success-soft: #d7f0e5;--warning: #b76e00;--warning-soft: #fff1cc;--danger: #ba1a1a;--danger-soft: #ffdad6;--shadow-1: 0 4px 8px rgba(9, 30, 66, .08);--shadow-2: 0 12px 24px rgba(9, 30, 66, .12);--sidebar-width: 240px;--topbar-height: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;background:var(--bg);color:var(--text)}button,input,select,textarea{font:inherit}button{border:0;cursor:pointer;transition:background-color .16s ease,border-color .16s ease,color .16s ease,opacity .16s ease}button:disabled,input:disabled,select:disabled,textarea:disabled{cursor:not-allowed;opacity:.6}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);min-height:38px;padding:8px 10px;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0052cc1f}textarea{min-height:92px;resize:vertical}.primary,.secondary,.ghost-button,.sidebar-link,.icon-button{border-radius:var(--radius-sm)}.primary{background:var(--primary);color:#fff;padding:10px 16px}.primary:hover{background:var(--primary-strong)}.secondary,.ghost-button,.icon-button,.appointment-actions button{background:var(--surface);color:var(--text);border:1px solid var(--border);padding:10px 14px}.ghost-button.today-button{min-height:36px;padding:7px 12px}.secondary:hover,.ghost-button:hover,.icon-button:hover,.appointment-actions button:hover,.sidebar-link:hover{background:#0052cc0d}.eyebrow{margin:0 0 4px;color:var(--subtle);font-size:11px;line-height:14px;letter-spacing:.05em;text-transform:uppercase;font-weight:600}.muted{color:var(--muted)}.state-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(135deg,#0052cc14,#00b8d914),var(--bg)}.login-panel{width:min(960px,100%);min-height:520px;display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-2);overflow:hidden}.login-copy{display:grid;align-content:center;gap:12px;padding:48px;background:var(--surface-soft);border-right:1px solid var(--border)}.login-copy h1{margin:0;font-size:36px;line-height:44px;letter-spacing:0}.login-copy p{max-width:44ch}.login-form{display:grid;align-content:center;gap:16px;padding:40px}.state-card{width:min(560px,100%);padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-2)}.state-panel,.state-copy,.state-actions{display:grid;gap:16px}.state-panel h1,.page-header h1{margin:0;font-size:30px;line-height:38px;letter-spacing:0;font-weight:700}.crm-shell{min-height:100vh}.app-sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar-width);background:var(--surface-soft);border-right:1px solid var(--border);padding:20px 14px;display:flex;flex-direction:column;gap:18px;z-index:30}.sidebar-brand{display:flex;align-items:center;gap:12px}.brand-mark{width:40px;height:40px;border-radius:var(--radius-md);background:var(--primary);color:#fff;display:grid;place-items:center;font-size:18px;font-weight:700}.sidebar-brand h2,.section-head h3,.setting-title h3,.topbar-title{margin:0;font-size:20px;line-height:28px;font-weight:600}.sidebar-brand p{margin:0;color:var(--muted);font-size:12px;line-height:16px}.sidebar-cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%}.sidebar-logout{width:100%}.sidebar-nav,.sidebar-footer,.side-stack,.message-stack,.team-list,.checklist-list,.stack-list,.form-grid{display:grid;gap:12px}.sidebar-nav{flex:1;align-content:start}.sidebar-link{background:transparent;color:var(--muted);display:flex;align-items:center;gap:12px;padding:12px;text-align:left}.sidebar-link.active{background:#0052cc14;color:var(--primary-strong);border-right:4px solid var(--primary);font-weight:600}.sidebar-note-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;display:grid;gap:4px;box-shadow:var(--shadow-1)}.app-topbar{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--topbar-height);padding:0 20px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;z-index:20}.topbar-actions,.date-nav,.page-actions,.metric-card-head,.setting-head,.setting-title,.status-toggle,.toggle-row,.button-row,.message-row,.highlight-callout,.section-head{display:flex;align-items:center;gap:12px}.topbar-actions{flex-wrap:wrap;justify-content:flex-end}.date-nav{gap:6px}.topbar-field{min-width:170px;gap:0}.topbar-field span{display:none}.topbar-field input,.topbar-field select{min-height:36px;padding:7px 10px}.icon-button{width:40px;height:40px;padding:0;display:grid;place-items:center}.avatar-chip{width:36px;height:36px;border-radius:999px;background:var(--surface-high);border:1px solid var(--border-strong);display:grid;place-items:center;font-weight:700}.app-main{margin-left:var(--sidebar-width);width:calc(100% - var(--sidebar-width));padding:calc(var(--topbar-height) + 24px) 24px 32px}.page-header{display:flex;justify-content:space-between;align-items:end;gap:16px;max-width:1280px;margin:0 auto 20px}.page-description{margin:0;color:var(--muted);font-size:16px;line-height:24px;max-width:68ch}.page-meta{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.page-meta span{border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--muted);padding:6px 10px;font-size:12px;line-height:16px}.notice-banner,.error-banner{margin-bottom:16px;padding:14px 16px;border-radius:var(--radius-md);border:1px solid var(--border)}.notice-banner{background:var(--success-soft);color:var(--success)}.error-banner{background:var(--danger-soft);color:var(--danger)}.metrics-grid,.dashboard-grid,.signal-grid,.mini-stats,.service-catalog,.inline-grid,.simulate-grid,.availability-row{display:grid;gap:16px}.metrics-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:16px;max-width:1280px;margin-left:auto;margin-right:auto}.overview-grid+.overview-grid,.overview-grid{align-items:stretch}.metric-card,.surface-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 1px 2px #091e420d}.metric-card{padding:16px;display:grid;gap:10px;min-height:132px;border-top:3px solid var(--primary)}.metric-card-head{justify-content:space-between;align-items:start;color:var(--muted);font-size:12px;line-height:16px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.metric-card strong{font-size:30px;line-height:36px;letter-spacing:0}.metric-card p{margin:0;color:var(--muted)}.surface-card{padding:18px}.dashboard-grid{grid-template-columns:repeat(12,minmax(0,1fr));align-items:start;max-width:1280px;margin:0 auto}.shortcut-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.shortcut-card{min-height:148px;display:grid;justify-items:start;align-content:center;gap:8px;padding:18px;background:var(--surface-soft);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);text-align:left}.shortcut-card:hover{background:var(--surface-low);border-color:var(--border-strong)}.shortcut-card .material-symbols-outlined{color:var(--primary);font-size:28px}.shortcut-card small{color:var(--muted)}.dashboard-span-4{grid-column:span 4}.dashboard-span-6{grid-column:span 6}.dashboard-span-8{grid-column:span 8}.dashboard-span-12{grid-column:span 12}.section-head{justify-content:space-between;align-items:start;margin-bottom:16px}.highlight-callout{justify-content:space-between;align-items:center;background:var(--surface-low);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;margin-bottom:16px;border-left:4px solid var(--primary)}.highlight-callout strong{font-size:20px;line-height:28px}.highlight-callout p{margin:4px 0 0}.signal-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.signal-card,.mini-stat,.team-card,.service-pill,.checklist-row,.message-row,.appointment-row,.empty-card,.availability-row{background:var(--surface-soft);border:1px solid var(--border);border-radius:var(--radius-md)}.signal-card,.mini-stat,.team-card,.service-pill,.checklist-row,.empty-card{padding:14px}.signal-card{display:grid;gap:6px}.signal-card.good{background:linear-gradient(180deg,#50dcff1f,#fff)}.signal-card.warn{background:linear-gradient(180deg,#fff1ccb3,#fff)}.signal-head{display:flex;justify-content:space-between;align-items:center}.accent-icon{color:var(--tertiary)}.signal-card p,.checklist-row p,.message-copy p,.appointment-main p{margin:0;color:var(--muted)}.info-band{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:16px;color:var(--muted);font-size:12px;line-height:16px}.checklist-row{display:flex;justify-content:space-between;align-items:start;gap:12px}.checklist-row.done{border-left:4px solid var(--success)}.checklist-row.pending{border-left:4px solid var(--warning)}.message-row,.appointment-row{padding:14px}.message-row{justify-content:space-between;align-items:start}.message-row.incoming{border-left:4px solid var(--secondary)}.message-row.outgoing{border-left:4px solid var(--primary)}.message-copy{display:grid;gap:6px;min-width:0}.appointment-row{display:grid;grid-template-columns:112px minmax(0,1fr) auto;gap:16px;align-items:center}.appointment-time,.appointment-main{display:grid;gap:6px}.appointment-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.appointment-actions button{padding:7px 10px;font-size:12px;line-height:16px}.week-strip{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;margin-bottom:14px}.week-day{display:grid;gap:2px;min-height:62px;padding:10px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--muted);text-align:left}.week-day span{font-size:11px;line-height:14px;text-transform:uppercase;letter-spacing:.05em;color:var(--subtle)}.week-day strong{color:var(--text);font-size:14px;line-height:20px}.week-day.active{background:var(--primary);border-color:var(--primary)}.week-day.active span,.week-day.active strong{color:#fff}.calendar-section{display:grid;gap:18px}.calendar-head{gap:16px}.calendar-toolbar{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px}.calendar-date-input{width:152px;min-height:40px}.segmented-control{display:inline-flex;padding:3px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-soft)}.segmented-control button{min-height:32px;padding:6px 12px;border-radius:var(--radius-sm);background:transparent;color:var(--muted)}.segmented-control button.active{background:var(--surface);color:var(--primary-strong);box-shadow:var(--shadow-1)}.calendar-day{display:grid;grid-template-columns:64px minmax(0,1fr);min-height:620px;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--surface)}.calendar-time-axis{display:grid;grid-template-rows:repeat(12,1fr);background:var(--surface-soft);border-right:1px solid var(--border)}.calendar-time-axis span{padding:8px 10px 0 0;text-align:right;color:var(--subtle);font-size:12px;line-height:16px}.calendar-track{position:relative;display:grid;grid-template-rows:repeat(12,1fr);background:linear-gradient(90deg,rgba(0,82,204,.03) 1px,transparent 1px) 0 0 / 56px 100%,var(--surface)}.calendar-hour-line{border-bottom:1px solid var(--border)}.calendar-hour-line:last-child{border-bottom:0}.calendar-event{position:absolute;left:12px;right:12px;min-height:44px;display:grid;align-content:start;gap:3px;padding:10px 12px;border-radius:var(--radius-md);border-left:4px solid var(--primary);background:#eef5ff;box-shadow:var(--shadow-1);overflow:hidden}.calendar-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;align-content:center;gap:8px;color:var(--muted);text-align:center;pointer-events:none}.calendar-empty .material-symbols-outlined{color:var(--primary);font-size:34px}.calendar-empty p{margin:0}.calendar-event strong,.calendar-event span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-event span{color:var(--muted);font-size:12px;line-height:16px}.calendar-event.confirmed{border-left-color:var(--success);background:#eef8f2}.calendar-event.completed{border-left-color:var(--secondary);background:#ecfbff}.calendar-event.cancelled,.calendar-event.no_show{border-left-color:var(--danger);background:#fff1ef}.calendar-event.pending,.calendar-event.scheduled{border-left-color:var(--warning);background:#fff8e6}.calendar-list{display:grid;gap:12px}.calendar-week{display:grid;gap:10px}.calendar-week-axis{display:grid;grid-template-columns:64px repeat(7,minmax(120px,1fr));gap:8px}.week-column-head{min-height:58px;display:grid;align-content:center;gap:2px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-soft);color:var(--muted);text-align:left}.week-column-head.active{background:var(--primary);border-color:var(--primary);color:#fff}.week-column-head span{font-size:11px;line-height:14px;text-transform:uppercase}.calendar-week-grid{display:grid;grid-template-columns:64px minmax(0,1fr);min-height:560px;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--surface)}.week-hours{display:grid;grid-template-rows:repeat(12,1fr);background:var(--surface-soft);border-right:1px solid var(--border)}.week-hours span{padding:8px 10px 0 0;color:var(--subtle);font-size:12px;line-height:16px;text-align:right}.week-columns{display:grid;grid-template-columns:repeat(7,minmax(120px,1fr))}.week-day-column{min-width:0;display:grid;align-content:start;gap:8px;padding:10px;border-right:1px solid var(--border);background:linear-gradient(180deg,transparent calc(8.33% - 1px),var(--border) calc(8.33% - 1px),var(--border) 8.33%,transparent 8.33%),var(--surface);background-size:100% 46.66px}.week-day-column:last-child{border-right:0}.week-event{display:grid;gap:2px;padding:8px;border-radius:var(--radius-sm);border-left:4px solid var(--primary);background:#eef5ff;box-shadow:var(--shadow-1)}.week-event span,.week-event small{overflow:hidden;color:var(--muted);text-overflow:ellipsis;white-space:nowrap}.calendar-month{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--surface)}.month-weekday{padding:10px;background:var(--surface-soft);border-right:1px solid var(--border);border-bottom:1px solid var(--border);color:var(--subtle);font-size:12px;line-height:16px;text-transform:uppercase;font-weight:600}.month-cell{min-height:118px;display:grid;align-content:start;gap:5px;padding:10px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface);color:var(--text);text-align:left}.month-cell.active{box-shadow:inset 0 0 0 2px var(--primary)}.month-cell.muted-month{background:var(--surface-soft);color:var(--subtle)}.month-cell span,.month-cell small{overflow:hidden;padding:3px 6px;border-radius:999px;background:var(--secondary-soft);color:var(--text);font-size:11px;line-height:14px;text-overflow:ellipsis;white-space:nowrap}.compact-head{margin-bottom:0}.empty-state{min-height:180px;display:grid;place-items:center;align-content:center;gap:8px;padding:24px;border:1px dashed var(--border-strong);border-radius:var(--radius-md);color:var(--muted);text-align:center;background:var(--surface-soft)}.empty-state .material-symbols-outlined{color:var(--primary);font-size:32px}.empty-state p{margin:0}.status-badge{display:inline-flex;align-items:center;width:fit-content;padding:4px 8px;border-radius:999px;font-size:12px;line-height:16px;font-weight:600;background:var(--surface-high);color:var(--text)}.status-badge.confirmed,.status-badge.completed{background:var(--success-soft);color:var(--success)}.status-badge.scheduled,.status-badge.pending{background:var(--warning-soft);color:var(--warning)}.status-badge.cancelled,.status-badge.no_show{background:var(--danger-soft);color:var(--danger)}.field{display:grid;gap:8px}.field span{font-size:12px;line-height:16px;letter-spacing:.05em;text-transform:uppercase;font-weight:600;color:var(--subtle)}.inline-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.simulate-grid{grid-template-columns:minmax(220px,.75fr) minmax(0,1.25fr) auto;align-items:end;margin-bottom:16px}.simulate-wide{grid-column:span 1}.mini-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.mini-stat{display:grid;gap:6px}.mini-stat strong{font-size:24px;line-height:32px}.team-card,.service-pill,.client-card{display:grid;gap:4px}.client-list{display:grid;gap:12px}.client-card{background:var(--surface-soft);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;gap:12px}.client-card span,.client-users{color:var(--muted);font-size:12px;line-height:16px}.client-meta,.client-users{display:flex;flex-wrap:wrap;gap:8px}.client-meta span,.client-users span{background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:4px 8px}.service-catalog{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:16px}.availability-editor{display:grid;gap:12px}.availability-row{grid-template-columns:minmax(130px,.8fr) minmax(120px,.8fr) minmax(120px,.8fr) auto;align-items:center;padding:12px}.button-row{justify-content:space-between;flex-wrap:wrap}.setting-card{display:grid;gap:16px}.setting-head{justify-content:space-between;align-items:start}.setting-title{align-items:start}.setting-title p{margin:4px 0 0;color:var(--muted);font-size:12px;line-height:16px}.status-toggle{gap:8px;color:var(--muted);font-size:12px;line-height:16px}.toggle-switch{width:40px;height:20px;background:var(--surface-high);border-radius:999px;padding:2px;display:inline-flex;align-items:center;justify-content:flex-start}.toggle-switch span{width:16px;height:16px;background:#fff;border-radius:999px;border:1px solid var(--border)}.toggle-switch.on{justify-content:flex-end;background:var(--secondary)}.toggle-row{flex-wrap:wrap}.toggle-item{display:flex;align-items:center;gap:8px;color:var(--muted)}.toggle-item input{width:auto}.empty-card{color:var(--muted)}.contact-table{display:grid;gap:10px}.contact-row{display:grid;grid-template-columns:minmax(220px,1.2fr) minmax(150px,.8fr) minmax(160px,1fr) auto;gap:14px;align-items:center;padding:14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-soft)}.contact-row div:first-child{display:grid;gap:4px}.contact-row span{color:var(--muted)}.row-actions{display:flex;justify-content:flex-end;gap:8px}.ghost-button.danger{color:var(--danger);border-color:#ba1a1a4d}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:grid;place-items:center;padding:24px;background:#051a3e6b}.modal-panel{width:min(620px,100%);max-height:min(820px,calc(100vh - 48px));overflow:auto;display:grid;gap:16px;padding:20px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-2)}.modal-head{display:flex;justify-content:space-between;align-items:start;gap:16px}.modal-head h3{margin:0}.contact-suggestions{display:grid;gap:8px;max-height:190px;overflow:auto}.contact-suggestions button{display:flex;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-soft);color:var(--text);text-align:left}.contact-suggestions button.selected{border-color:var(--primary);background:#0052cc14}.modal-calendar{padding:14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-low)}@media(max-width:1220px){.metrics-grid,.shortcut-grid,.calendar-week-axis{grid-template-columns:repeat(2,minmax(0,1fr))}.calendar-week-axis>span{display:none}.calendar-week-grid{grid-template-columns:1fr}.week-hours{display:none}.week-columns{grid-template-columns:repeat(2,minmax(0,1fr))}.week-strip{grid-template-columns:repeat(4,minmax(0,1fr))}.dashboard-span-4,.dashboard-span-6,.dashboard-span-8,.dashboard-span-12{grid-column:span 12}}@media(max-width:960px){.app-sidebar{position:static;width:100%;border-right:0;border-bottom:1px solid var(--border)}.app-topbar{position:static;left:0;height:auto;padding:16px;flex-direction:column;align-items:stretch;gap:16px}.app-main{margin-left:0;padding:24px 16px}}@media(max-width:760px){.state-card,.surface-card,.metric-card{padding:16px}.page-header,.topbar-actions,.page-actions,.highlight-callout,.message-row,.checklist-row{display:grid}.metrics-grid,.inline-grid,.signal-grid,.mini-stats,.service-catalog,.shortcut-grid,.week-strip,.simulate-grid,.availability-row,.info-band,.appointment-row,.contact-row,.week-columns,.calendar-month{grid-template-columns:1fr}.calendar-toolbar,.row-actions{justify-content:stretch}.calendar-toolbar>*,.row-actions button,.calendar-date-input{width:100%}.button-row,.appointment-actions{flex-direction:column;align-items:stretch}.topbar-field{min-width:0}.login-panel{grid-template-columns:1fr;min-height:0}.login-copy{border-right:0;border-bottom:1px solid var(--border);padding:28px}.login-form{padding:28px}}
