:root {
  --green: #1B5E44;
  --green-light: #2A7D5F;
  --green-subtle: #EAF5F0;
  --green-border: #C4E0D6;
  --orange: #C84B0F;
  --orange-subtle: #FEF0E8;
  --orange-border: #F9C4A3;
  --yellow: #92650A;
  --yellow-subtle: #FEF9E8;
  --yellow-border: #F5DFA0;
  --red: #B42318;
  --red-dark: #7A1A14;
  --red-subtle: #FDECEB;
  --blue: #1A4FAD;
  --blue-subtle: #EBF1FD;
  --blue-border: #B3CDFA;
  --gray-950: #0E1117;
  --gray-900: #181C24;
  --gray-800: #252A36;
  --gray-700: #363C4E;
  --gray-600: #4E5568;
  --gray-500: #6B7385;
  --gray-400: #909AAD;
  --gray-300: #BEC5D1;
  --gray-200: #E2E6ED;
  --gray-100: #F2F4F7;
  --gray-50: #F8F9FB;
  --white: #FFFFFF;
  --sidebar-w: 228px;
  --font: "Inter", "DM Sans", Arial, sans-serif;
  --mono: "JetBrains Mono", Consolas, monospace;
  --radius: 8px;
  --radius-sm: 6px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
  --shadow: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);
  --shadow-lg: 0 18px 48px rgba(0,0,0,.18), 0 6px 16px rgba(0,0,0,.08);
}

* { box-sizing: border-box; }
html, body { height: 100%; margin: 0; overflow: hidden; }
body { background: var(--gray-100); color: var(--gray-900); font: 14px/1.45 var(--font); }
a { color: inherit; }
button, input, select, textarea { font: inherit; }

.app { display: flex; height: 100vh; min-width: 0; }
.sidebar { width: var(--sidebar-w); flex: 0 0 var(--sidebar-w); background: var(--gray-900); color: var(--gray-300); display: flex; flex-direction: column; }
.logo { display: flex; align-items: center; gap: 10px; padding: 18px 20px 15px; border-bottom: 1px solid var(--gray-800); }
.logo-icon { width: 32px; height: 32px; border-radius: 8px; display: grid; place-items: center; background: var(--green); color: white; font-weight: 800; }
.logo-name { color: white; font-weight: 800; letter-spacing: -.02em; }
.logo-tag { color: var(--gray-500); font: 10px/1.2 var(--mono); letter-spacing: .08em; }
.nav { flex: 1; overflow: auto; padding: 12px 10px; }
.nav-label { padding: 9px 10px 5px; color: var(--gray-600); font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.nav-link { min-height: 38px; display: flex; align-items: center; gap: 10px; padding: 8px 10px; margin-bottom: 3px; border-radius: var(--radius-sm); color: var(--gray-400); text-decoration: none; font-weight: 650; font-size: 13px; }
.nav-link:hover { background: var(--gray-800); color: var(--gray-100); }
.nav-link.active { background: rgba(27,94,68,.28); color: #6DD0A7; }
.nav-link svg, .icon { width: 16px; height: 16px; flex: 0 0 auto; }
.nav-badge { margin-left: auto; min-width: 20px; padding: 1px 6px; border-radius: 999px; background: var(--orange); color: white; font: 700 10px/1.6 var(--mono); text-align: center; }
.nav-badge.green { background: var(--green); }
.user-card { display: flex; align-items: center; gap: 10px; padding: 12px 20px 18px; border-top: 1px solid var(--gray-800); }
.avatar { width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; background: var(--green); color: white; font-weight: 800; font-size: 12px; }
.user-name { color: var(--gray-200); font-weight: 700; font-size: 13px; }
.user-role { color: var(--gray-600); font-size: 11px; }

.main { flex: 1; min-width: 0; display: flex; flex-direction: column; overflow: hidden; }
.topbar { height: 54px; flex: 0 0 54px; display: flex; align-items: center; gap: 14px; padding: 0 20px; background: white; border-bottom: 1px solid var(--gray-200); }
.top-title { font-weight: 800; }
.top-sub { color: var(--gray-500); font-size: 12px; margin-left: 8px; }
.top-search { display: flex; align-items: center; gap: 8px; width: min(360px, 28vw); margin-left: 12px; padding: 7px 10px; border: 1px solid var(--gray-200); border-radius: var(--radius-sm); background: var(--gray-50); color: var(--gray-500); }
.top-search input { border: 0; outline: 0; background: transparent; width: 100%; min-width: 0; }
.top-actions { margin-left: auto; display: flex; align-items: center; gap: 9px; }
.pill { display: inline-flex; align-items: center; gap: 6px; border: 1px solid var(--gray-200); border-radius: 999px; padding: 4px 10px; background: var(--gray-50); color: var(--gray-600); font-size: 12px; white-space: nowrap; }
.live-dot { width: 7px; height: 7px; border-radius: 50%; background: #22C55E; }
.content { flex: 1; min-height: 0; overflow: hidden; display: flex; }
.app-powered {
  flex: 0 0 auto;
  padding: 10px 20px;
  border-top: 1px solid var(--gray-200);
  background: #fff;
  color: var(--gray-500);
  font-size: 12px;
  text-align: right;
}
.app-powered a {
  color: var(--gray-700);
  font-weight: 700;
  text-decoration: none;
}
.app-powered a:hover { color: var(--green); }

.btn { min-height: 34px; border: 0; border-radius: var(--radius-sm); padding: 7px 13px; display: inline-flex; align-items: center; justify-content: center; gap: 7px; font-weight: 800; font-size: 12px; cursor: pointer; text-decoration: none; white-space: nowrap; }
.btn svg { width: 14px; height: 14px; }
.btn-primary { background: var(--green); color: white; }
.btn-primary:hover { background: var(--green-light); box-shadow: 0 4px 12px rgba(27,94,68,.22); }
.btn-secondary { background: var(--gray-100); border: 1px solid var(--gray-200); color: var(--gray-700); }
.btn-call { background: var(--blue); color: white; }
.btn-confirm { background: var(--green); color: white; }
.btn-danger { background: var(--red-subtle); color: var(--red); border: 1px solid #F9C0BB; }
.btn-ghost { background: transparent; color: var(--gray-600); border: 1px solid var(--gray-200); }
.btn-sm { min-height: 28px; padding: 5px 10px; font-size: 11px; }
.icon-btn { width: 34px; height: 34px; padding: 0; }
.action-menu { position: relative; display: inline-flex; }
.action-list { position: absolute; top: calc(100% + 6px); right: 0; min-width: 180px; max-height: calc(100vh - 110px); display: none; flex-direction: column; padding: 6px; border: 1px solid var(--gray-200); border-radius: var(--radius); background: white; box-shadow: var(--shadow-lg); z-index: 60; overflow-y: auto; }
.action-menu.open .action-list { display: flex; }
.action-list button { width: 100%; border: 0; background: transparent; color: var(--gray-700); padding: 8px 9px; border-radius: var(--radius-sm); text-align: left; font-weight: 750; font-size: 12px; cursor: pointer; }
.action-list button:hover { background: var(--gray-100); color: var(--gray-900); }
.card-actions-inline { display: flex; justify-content: flex-end; margin-top: 10px; }

.badge { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: 999px; font-size: 10px; font-weight: 900; letter-spacing: .03em; white-space: nowrap; }
.badge-new { background: var(--orange-subtle); color: var(--orange); border: 1px solid var(--orange-border); }
.badge-pending { background: var(--yellow-subtle); color: var(--yellow); border: 1px solid var(--yellow-border); }
.badge-confirmed { background: var(--green-subtle); color: var(--green); border: 1px solid var(--green-border); }
.badge-booked, .badge-dispatched { background: var(--blue-subtle); color: var(--blue); border: 1px solid var(--blue-border); }
.badge-due { background: var(--red-subtle); color: var(--red); border: 1px solid #F9C0BB; }
.badge-overdue { background: #F6D7D4; color: var(--red-dark); border: 1px solid #EDAAA3; }
.badge-gray { background: var(--gray-100); color: var(--gray-600); border: 1px solid var(--gray-200); }
.zapier-tag { display: inline-flex; align-items: center; padding: 2px 6px; border-radius: 4px; background: #FF4A00; color: white; font: 800 9px/1.4 var(--mono); letter-spacing: .06em; }

.queue-panel { width: 370px; flex: 0 0 370px; background: white; border-right: 1px solid var(--gray-200); display: flex; flex-direction: column; overflow: hidden; }
.queue-header, .toolbar { padding: 13px 16px; border-bottom: 1px solid var(--gray-200); background: white; display: flex; align-items: center; gap: 10px; }
.queue-header { display: block; }
.queue-title-row { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.queue-title { font-weight: 800; }
.queue-count { padding: 1px 7px; border-radius: 999px; background: var(--orange-subtle); color: var(--orange); border: 1px solid var(--orange-border); font: 800 11px/1.5 var(--mono); }
.filters { display: flex; flex-wrap: wrap; gap: 6px; }
.filter-btn { border: 1px solid var(--gray-200); background: white; color: var(--gray-600); border-radius: 999px; padding: 4px 10px; font-weight: 800; font-size: 11px; cursor: pointer; flex-shrink: 0; }
select.filter-btn { max-width: 150px; min-width: 90px; }
.filter-input { min-width: 132px; max-width: 160px; padding: 4px 12px; font-family: var(--font); }
input.filter-btn { line-height: 1.6; }
input.filter-btn::-webkit-calendar-picker-indicator { opacity: .65; cursor: pointer; }
.filter-btn.active { background: var(--green); color: white; border-color: var(--green); }
.queue-list { flex: 1; overflow: auto; padding: 10px; display: flex; flex-direction: column; gap: 7px; }
.order-card, .kanban-card, .panel, .vendor-card, .client-row-card { background: white; border: 1px solid var(--gray-200); border-radius: var(--radius); box-shadow: none; }
.order-card { padding: 12px 14px; cursor: pointer; text-decoration: none; display: block; }
.order-card:hover, .kanban-card:hover, .vendor-card:hover, .client-row-card:hover { border-color: var(--gray-300); box-shadow: var(--shadow-sm); }
.order-card.selected, .order-card.highlight { border-color: var(--green); background: var(--green-subtle); box-shadow: 0 0 0 2px rgba(27,94,68,.12); }
.order-card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; margin-bottom: 8px; }
.order-customer { font-weight: 800; font-size: 13px; }
.order-id { color: var(--gray-400); font: 11px/1.4 var(--mono); }
.order-card.compact { padding: 8px 10px; border-radius: 7px; }
.order-card .badge { font-size: 9px; padding: 1px 6px; }
.compact-top { margin-bottom: 5px; align-items: center; }
.order-title-col { min-width: 0; }
.order-card.compact .order-customer { font-size: 12px; line-height: 1.25; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 185px; }
.order-card.compact .order-id { font-size: 10px; line-height: 1.2; }
.order-compact-row, .compact-location { display: flex; align-items: center; justify-content: space-between; gap: 8px; min-width: 0; color: var(--gray-600); font-size: 11px; line-height: 1.25; }
.order-compact-row .icon, .compact-location .icon { width: 12px; height: 12px; }
.compact-main, .compact-sub { display: flex; align-items: center; gap: 5px; min-width: 0; }
.compact-main span, .compact-sub span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.compact-main { color: var(--gray-700); font-weight: 700; max-width: 58%; }
.compact-sub { color: var(--gray-500); font-weight: 650; max-width: 42%; justify-content: flex-end; gap: 8px; }
.compact-price { color: var(--green); font-weight: 900; font-size: 10px; }
.compact-date { display: inline-flex; align-items: center; gap: 4px; font-size: 11px; }
.compact-date .icon { width: 11px; height: 11px; }
.compact-location { margin-top: 3px; color: var(--gray-500); justify-content: flex-start; }
.compact-location span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.meta { display: flex; flex-direction: column; gap: 4px; color: var(--gray-600); font-size: 12px; }
.meta-row { display: flex; align-items: center; gap: 6px; min-width: 0; }
.meta strong { color: var(--gray-800); }

.detail-panel { flex: 1; min-width: 0; background: var(--gray-50); overflow: auto; padding: 18px; }
.dispatch-map-empty { min-height: 100%; border: 1px solid var(--gray-200); border-radius: 12px; background: radial-gradient(circle at 20% 10%, #F5FBF8 0%, #EEF4F1 38%, #F8F9FB 100%); position: relative; overflow: hidden; display: grid; place-items: center; padding: 24px; }
.dispatch-google-map { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; filter: saturate(.9) contrast(.96) brightness(1.01); }
.dispatch-map-overlay { position: absolute; inset: 0; z-index: 2; pointer-events: none; }
.dispatch-map-pin { position: absolute; transform: translate(-50%, -100%); pointer-events: auto; text-decoration: none; }
.dispatch-map-pin::before { content: ""; width: 10px; height: 10px; border-radius: 50%; display: block; margin: 0 auto 2px; background: var(--green); border: 2px solid #fff; box-shadow: 0 2px 8px rgba(0,0,0,.24); }
.dispatch-map-pin span { display: inline-flex; align-items: center; justify-content: center; max-width: 110px; padding: 1px 6px; border-radius: 999px; font: 800 9px/1.3 var(--mono); background: rgba(255,255,255,.92); border: 1px solid var(--green-border); color: var(--green); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dispatch-map-empty-copy { position: relative; z-index: 2; max-width: 520px; text-align: center; padding: 16px 20px; border: 1px solid rgba(27, 94, 68, .2); border-radius: 10px; background: rgba(255,255,255,.82); backdrop-filter: blur(2px); }
.dispatch-map-empty-title { color: var(--green); font-size: 18px; font-weight: 900; letter-spacing: -.01em; }
.dispatch-map-empty-sub { margin-top: 6px; color: var(--gray-600); font-size: 13px; }
.empty-state { height: 100%; display: grid; place-items: center; color: var(--gray-400); text-align: center; }
.panel { margin-bottom: 14px; overflow: clip; }
.dispatch-vendors-panel, .dispatch-vendors-body, .dispatch-vendor-grid, .vendor-compact-card { overflow: visible; }
.panel-head { padding: 12px 15px; border-bottom: 1px solid var(--gray-100); display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.panel-title { font-weight: 900; }
.panel-sub { color: var(--gray-500); font-size: 12px; margin-top: 1px; }
.panel-body { padding: 14px 15px; }
.accordion-stack { display: flex; flex-direction: column; gap: 8px; }
.accordion-row { border: 1px solid var(--gray-200); border-radius: var(--radius); background: white; overflow: hidden; }
.accordion-row.tone-green { border-color: var(--green-border); }
.accordion-row.tone-orange { border-color: var(--orange-border); }
.accordion-row.tone-blue { border-color: var(--blue-border); }
.accordion-head { width: 100%; min-height: 46px; border: 0; background: var(--gray-50); color: var(--gray-800); display: flex; align-items: center; justify-content: space-between; padding: 11px 13px; font-weight: 900; cursor: pointer; }
.tone-green .accordion-head { background: var(--green-subtle); color: var(--green); }
.tone-orange .accordion-head { background: var(--orange-subtle); color: var(--orange); }
.tone-blue .accordion-head { background: var(--blue-subtle); color: var(--blue); }
.accordion-chevron { transition: transform .16s ease; font-size: 18px; line-height: 1; }
.accordion-row.open .accordion-chevron { transform: rotate(90deg); }
.accordion-body { display: none; padding: 13px; border-top: 1px solid var(--gray-100); }
.accordion-row.open .accordion-body { display: block; }
.info-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.info-field.full { grid-column: 1 / -1; }
.info-field label { display: block; margin-bottom: 3px; color: var(--gray-500); font-size: 11px; font-weight: 900; letter-spacing: .05em; text-transform: uppercase; }
.info-field span, .info-field div.value { color: var(--gray-900); font-weight: 650; }
.map-thumb { min-height: 92px; border: 1px solid var(--gray-200); border-radius: var(--radius); background: linear-gradient(135deg, #E8EFEA, #F7F0DE); display: flex; align-items: center; justify-content: center; color: var(--green); font-weight: 900; }
.source-badge { text-transform: uppercase; }

.vendor-list { display: flex; flex-direction: column; gap: 10px; }
.dispatch-vendor-toolbar { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 10px; align-items: center; }
.vendor-sort-chip { border: 1px solid var(--gray-200); background: #fff; color: var(--gray-600); border-radius: 999px; padding: 4px 10px; font-weight: 850; font-size: 11px; cursor: pointer; }
.vendor-sort-chip.active { background: var(--green); border-color: var(--green); color: #fff; }
.vendor-inline-search { border: 1px solid var(--gray-200); background: #fff; color: var(--gray-700); border-radius: 999px; padding: 6px 10px; min-width: 210px; max-width: 240px; outline: 0; font-size: 12px; }
.vendor-inline-search:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(27,94,68,.08); }
.dispatch-vendor-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
.vendor-compact-card { background: #fff; border: 1px solid var(--gray-200); border-radius: var(--radius); padding: 10px 11px; }
.vendor-compact-card.assigned { border-color: var(--green); background: var(--green-subtle); box-shadow: 0 0 0 1px rgba(27,94,68,.12); }
.vendor-compact-card.best { border-color: var(--green-border); }
.vendor-compact-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.vendor-compact-left { min-width: 0; flex: 1; }
.vendor-compact-right { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; justify-content: flex-end; flex-shrink: 0; }
.vendor-name-tip { border: 0; background: transparent; padding: 0; margin: 0; color: var(--gray-900); font-size: 13px; font-weight: 900; line-height: 1.2; text-align: left; cursor: help; text-decoration: underline dotted rgba(54,60,78,.45); text-underline-offset: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 240px; }
.vendor-name-tip:hover { color: var(--green); text-decoration-color: var(--green); }
.vendor-compact-tags { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; justify-content: flex-end; }
.vendor-compact-meta { margin-top: 3px; color: var(--gray-500); font-size: 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.vendor-compact-metrics { margin-top: 5px; display: flex; gap: 9px; flex-wrap: wrap; color: var(--gray-600); font-size: 11px; }
.vendor-compact-metrics strong { color: var(--green); font-size: 15px; line-height: 1; margin-right: 2px; }
.vendor-card { padding: 14px 16px; display: flex; align-items: center; gap: 16px; }
.vendor-card.best { background: var(--green-subtle); border-color: var(--green-border); }
.vendor-rank { width: 25px; height: 25px; border-radius: 50%; display: grid; place-items: center; flex: 0 0 25px; background: var(--gray-100); color: var(--gray-700); font: 800 11px/1 var(--mono); }
.vendor-rank.rank-1 { background: var(--green); color: white; }
.vendor-rating { flex: 0 0 58px; display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 4px 0; border-right: 1px solid var(--gray-100); padding-right: 16px; margin-right: 0; }
.vendor-rating-num { font: 800 22px/1 var(--mono); color: var(--gray-900); }
.vendor-stars { color: #F59E0B; font-size: 10px; letter-spacing: 1.5px; line-height: 1.2; }
.vendor-review-ct { color: var(--gray-400); font-size: 10px; font-weight: 700; white-space: nowrap; }
.vendor-info { flex: 1; min-width: 0; }
.vendor-name-row { display: flex; align-items: center; gap: 8px; margin-bottom: 2px; }
.vendor-name { font-weight: 900; font-size: 14px; }
.vendor-clean-tag { display: inline-flex; align-items: center; padding: 1px 6px; border-radius: 4px; background: var(--green-subtle); color: var(--green); font: 800 9px/1.4 var(--mono); letter-spacing: .06em; border: 1px solid var(--green-border); flex-shrink: 0; }
.vendor-loc { color: var(--gray-500); font-size: 12px; margin-bottom: 6px; }
.vendor-freshness { color: var(--gray-500); font-size: 11px; }
.vendor-contact-row { display: flex; align-items: center; gap: 6px; color: var(--gray-600); font-size: 12px; }
.vendor-contact-row svg { width: 13px; height: 13px; flex-shrink: 0; }
.vendor-contact-row a { color: var(--gray-700); font-weight: 650; text-decoration: none; }
.vendor-contact-row a:hover { color: var(--green); }
.vendor-contact-sep { color: var(--gray-300); }
.vendor-details { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 8px; }
.vendor-detail-label { color: var(--gray-500); font-size: 10px; font-weight: 900; text-transform: uppercase; letter-spacing: .05em; }
.vendor-detail-val { color: var(--gray-900); font-weight: 850; font-size: 12px; }
.vendor-detail-val.price { color: var(--green); font-size: 14px; }
.vendor-actions { flex-shrink: 0; display: flex; align-items: center; gap: 6px; }
.vendor-count-badge { margin-left: auto; padding: 3px 10px; border-radius: 999px; background: var(--gray-100); border: 1px solid var(--gray-200); color: var(--gray-600); font: 700 11px/1.5 var(--mono); white-space: nowrap; }

.view-toggle { display: flex; border: 1px solid var(--gray-200); border-radius: var(--radius-sm); overflow: hidden; flex-shrink: 0; }
.view-toggle-btn { border: 0; background: white; color: var(--gray-600); padding: 5px 13px; font-weight: 800; font-size: 11px; cursor: pointer; display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
.view-toggle-btn:hover { background: var(--gray-50); }
.view-toggle-btn.active { background: var(--green); color: white; }
.view-toggle-btn svg { width: 13px; height: 13px; }

.cal-filter-group { display: flex; gap: 8px; flex-wrap: wrap; }
.cal-filter-btn { border: 1px solid var(--gray-200); border-radius: 999px; background: white; color: var(--gray-600); padding: 7px 12px; font-weight: 800; font-size: 11px; cursor: pointer; }
.cal-filter-btn.active { background: var(--green); color: white; border-color: transparent; }
.cal-filter-btn:hover { background: var(--gray-50); }

.cal-day-status-red { border: 1px solid rgba(244,63,94,0.3); background: rgba(244,63,94,0.06); }
.cal-day-status-yellow { border: 1px solid rgba(234,179,8,0.3); background: rgba(234,179,8,0.08); }
.cal-day-status-lightgreen { border: 1px solid rgba(52,211,153,0.3); background: rgba(52,211,153,0.07); }
.cal-day-status-green { border: 1px solid rgba(34,197,94,0.3); background: rgba(34,197,94,0.07); }

.kanban-page { flex: 1; min-width: 0; display: flex; flex-direction: column; overflow: auto; }
.kanban-board { flex: 1; display: flex; gap: 12px; padding: 16px; overflow: auto; align-items: flex-start; }
.kanban-col { flex: 1 0 280px; min-width: 280px; max-width: 340px; max-height: 100%; background: var(--gray-100); border-radius: var(--radius); display: flex; flex-direction: column; }
.kanban-col-head { display: flex; align-items: center; gap: 8px; padding: 12px 14px 10px; position: sticky; top: 0; z-index: 5; background: var(--gray-100); border-radius: var(--radius) var(--radius) 0 0; }
.kanban-col-title { color: var(--gray-700); font-size: 12px; font-weight: 900; letter-spacing: .05em; text-transform: uppercase; }
.kanban-col-count { margin-left: auto; padding: 1px 7px; border-radius: 999px; background: white; border: 1px solid var(--gray-200); color: var(--gray-600); font: 800 11px/1.5 var(--mono); }
.kanban-line { height: 3px; margin: 0 14px 10px; border-radius: 2px; background: var(--gray-400); }
.col-confirmed .kanban-line { background: var(--green); }
.col-booked .kanban-line { background: var(--blue); }
.col-dispatched .kanban-line { background: var(--orange); }
.kanban-cards { flex: 1; min-height: 120px; overflow: auto; padding: 0 10px 10px; display: flex; flex-direction: column; gap: 8px; }
.kanban-cards.drag-over { outline: 2px dashed var(--green-border); background: rgba(27,94,68,.05); border-radius: var(--radius-sm); }
.kanban-card { padding: 12px; cursor: grab; }
.kanban-card.dragging { opacity: .45; }
.kanban-card-top { display: flex; justify-content: space-between; gap: 8px; margin-bottom: 7px; }
.kanban-customer { font-weight: 900; }
.kanban-date { padding: 2px 6px; border-radius: 4px; background: var(--gray-100); color: var(--gray-600); font: 700 10px/1.4 var(--mono); }
.kanban-actions { display: flex; gap: 6px; margin-top: 10px; flex-wrap: wrap; }
.schedule-detail { flex: 0 0 360px; border-left: 1px solid var(--gray-200); background: var(--gray-50); overflow: auto; padding: 16px; }

.tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--gray-200); padding: 0 15px; background: white; overflow-x: auto; position: sticky; top: 0; z-index: 10; }
.tab-btn { border: 0; background: transparent; color: var(--gray-500); padding: 11px 14px; border-bottom: 2px solid transparent; margin-bottom: -1px; font-size: 12px; font-weight: 900; cursor: pointer; white-space: nowrap; }
.tab-btn.active { color: var(--green); border-bottom-color: var(--green); }
.tab-content { display: none; }
.tab-content.active { display: block; }
.record-page { flex: 1; overflow: auto; padding: 18px; background: var(--gray-50); }
.record-shell { max-width: 1180px; margin: 0 auto; }
.record-head { display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; margin-bottom: 14px; }
.record-title { font-size: 22px; font-weight: 900; letter-spacing: -.02em; }
.sticky-action-bar { position: sticky; bottom: 0; z-index: 30; margin-top: 14px; padding: 12px 14px; border: 1px solid var(--gray-200); border-radius: var(--radius); background: rgba(255,255,255,.96); box-shadow: var(--shadow-lg); display: flex; align-items: center; justify-content: space-between; gap: 12px; backdrop-filter: blur(8px); }

.clients-layout { flex: 1; display: flex; min-width: 0; overflow: hidden; }
.clients-main { flex: 1; min-width: 0; display: flex; flex-direction: column; overflow: hidden; }
.clients-list { flex: 1; overflow: auto; padding: 12px 12px 60px; display: flex; flex-direction: column; gap: 8px; }
.client-row-card { display: grid; grid-template-columns: 1.4fr 1fr .8fr .8fr .8fr auto; gap: 12px; align-items: center; padding: 12px 14px; cursor: pointer; }
.client-name { font-weight: 900; }
.client-sub { color: var(--gray-500); font-size: 12px; }
.client-detail { flex: 0 0 380px; border-left: 1px solid var(--gray-200); background: var(--gray-50); padding: 16px; overflow: auto; }
.side-drawer { flex: 0 0 390px; border-left: 1px solid var(--gray-200); background: var(--gray-50); overflow: auto; transition: flex-basis .2s ease, padding .2s ease; }
.side-drawer.drawer-collapsed { flex-basis: 0; padding: 0; border-left: 0; overflow: hidden; }
.drawer-head { position: sticky; top: 0; z-index: 10; background: white; border-bottom: 1px solid var(--gray-200); padding: 13px 16px; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.clickable-card { cursor: pointer; transition: border-color .15s, box-shadow .15s; }
.clickable-card:hover { border-color: var(--green-border); box-shadow: 0 4px 14px rgba(0,0,0,.10), 0 1px 4px rgba(0,0,0,.06); }

.metric-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin: 14px 0; }
.metric-card { background: white; border: 1px solid var(--gray-200); border-radius: var(--radius); padding: 14px 15px; }
.metric-label { color: var(--gray-500); font-size: 11px; font-weight: 900; letter-spacing: .05em; text-transform: uppercase; }
.metric-value { margin-top: 4px; color: var(--gray-900); font-size: 24px; line-height: 1.1; font-weight: 900; letter-spacing: -.02em; }
.metric-note { margin-top: 5px; color: var(--gray-500); font-size: 12px; }
.vendor-directory { display: flex; flex-direction: column; gap: 8px; margin-top: 14px; }
.intel-table-wrap { overflow: auto; }
.intel-table { width: 100%; border-collapse: collapse; min-width: 760px; }
.intel-table th { text-align: left; padding: 10px 12px; color: var(--gray-500); background: var(--gray-50); border-bottom: 1px solid var(--gray-200); font-size: 11px; font-weight: 900; letter-spacing: .05em; text-transform: uppercase; }
.intel-table td { padding: 11px 12px; border-bottom: 1px solid var(--gray-100); color: var(--gray-700); font-size: 13px; }
.intel-table tr:hover td { background: var(--gray-50); }
.report-list { display: flex; flex-direction: column; gap: 2px; }
.report-row { display: flex; align-items: center; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--gray-100); }
.report-row:last-child { border-bottom: 0; }

.modal-overlay { position: fixed; inset: 0; z-index: 100; display: none; align-items: center; justify-content: center; padding: 20px; background: rgba(14,17,23,.58); backdrop-filter: blur(4px); }
.modal-overlay.open { display: flex; }
.modal { width: min(500px, 96vw); max-height: 90vh; overflow: auto; background: white; border-radius: 12px; box-shadow: var(--shadow-lg); }
.modal-header, .modal-footer { padding: 16px 20px; display: flex; align-items: center; justify-content: space-between; gap: 10px; border-bottom: 1px solid var(--gray-100); }
.modal-footer { border-top: 1px solid var(--gray-100); border-bottom: 0; justify-content: flex-end; }
.modal-title { font-weight: 900; font-size: 16px; }
.modal-subtitle { color: var(--gray-500); font-size: 12px; }
.modal-body { padding: 18px 20px; display: flex; flex-direction: column; gap: 13px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-field label { display: block; margin-bottom: 6px; color: var(--gray-700); font-size: 12px; font-weight: 850; }
.form-field input, .form-field select, .form-field textarea { width: 100%; border: 1px solid var(--gray-200); border-radius: var(--radius-sm); background: white; padding: 9px 11px; outline: 0; color: var(--gray-900); }
.form-field textarea { min-height: 76px; resize: vertical; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(27,94,68,.1); }

.activity-entry, .doc-row, .note-row, .timeline-item { padding: 11px 0; border-bottom: 1px solid var(--gray-100); display: flex; gap: 10px; align-items: flex-start; }
.activity-entry:last-child, .doc-row:last-child, .note-row:last-child, .timeline-item:last-child { border-bottom: 0; }
.activity-icon { width: 30px; height: 30px; border-radius: 50%; flex: 0 0 auto; display: grid; place-items: center; background: var(--blue-subtle); color: var(--blue); }
.timeline { display: flex; flex-direction: column; }
.toast-wrap { position: fixed; right: 24px; bottom: 24px; z-index: 200; display: flex; flex-direction: column; gap: 8px; }
.toast { min-width: 260px; padding: 12px 16px; border-radius: var(--radius); background: var(--gray-900); color: white; box-shadow: var(--shadow-lg); border-left: 4px solid #22C55E; font-weight: 700; font-size: 13px; }
.toast.info { border-left-color: var(--blue); }
.hidden { display: none !important; }
.order-hover-tooltip { position: fixed; z-index: 400; max-width: 360px; pointer-events: none; white-space: pre-line; display: none; border: 1px solid var(--green-border); border-radius: 9px; background: rgba(255,255,255,.96); color: var(--gray-800); padding: 9px 10px; box-shadow: var(--shadow-lg); font-size: 11px; line-height: 1.45; }
.order-hover-tooltip.open { display: block; }
.cal-wrap { flex: 1; display: flex; min-height: 0; overflow: auto; }
.cal-main { flex: 1; display: flex; flex-direction: column; min-width: 0; overflow: hidden; }
.cal-nav { display: flex; align-items: center; gap: 10px; padding: 10px 16px; border-bottom: 1px solid var(--gray-200); background: white; flex-shrink: 0; }
.cal-month-label { font-weight: 900; font-size: 15px; letter-spacing: -.01em; }
.cal-day-names { display: grid; grid-template-columns: repeat(7, 1fr); border-bottom: 1px solid var(--gray-200); background: white; flex-shrink: 0; }
.cal-day-name { padding: 7px 8px; text-align: center; color: var(--gray-500); font-size: 10px; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; }
.cal-week-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; padding: 16px; }
.cal-day-section { border: 1px solid var(--gray-200); border-radius: 14px; background: white; overflow: hidden; display: flex; flex-direction: column; }
.cal-day-section-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 12px 14px; background: var(--gray-50); font-weight: 800; font-size: 12px; }
.cal-day-section-list { display: flex; flex-direction: column; gap: 10px; padding: 12px 14px 14px; }
.cal-list { display: flex; flex-direction: column; gap: 12px; padding: 16px; }
.cal-list-card { border: 1px solid var(--gray-200); border-radius: 14px; padding: 16px; background: white; transition: transform .14s ease, box-shadow .14s ease; cursor: pointer; }
.cal-list-card:hover { transform: translateY(-1px); box-shadow: 0 12px 30px rgba(0,0,0,.08); }
.cal-list-card-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 10px; }
.cal-list-card-tag { color: var(--gray-500); font-size: 11px; font-weight: 700; }
.cal-list-card-body { display: flex; flex-wrap: wrap; gap: 10px; color: var(--gray-600); font-size: 12px; }
.cal-list-card-foot { margin-top: 10px; }
.cal-list-empty { padding: 30px 16px; border: 1px dashed var(--gray-200); border-radius: 14px; color: var(--gray-500); background: var(--gray-50); text-align: center; }
.cal-grid { flex: 1; display: grid; grid-template-columns: repeat(7, 1fr); grid-auto-rows: minmax(110px, 1fr); overflow: auto; align-content: start; border-left: 1px solid var(--gray-100); border-top: 1px solid var(--gray-100); }
.cal-week-view { width: 100%; overflow: auto; min-height: 640px; }
.cal-week-grid { display: grid; grid-template-columns: 80px repeat(7, minmax(150px, 1fr)); min-height: 720px; gap: 1px; background: var(--gray-200); }
.cal-week-grid.single-day { grid-template-columns: 80px minmax(0, 1fr); }
.cal-time-axis { display: grid; grid-template-rows: repeat(13, 56px); background: white; }
.cal-time-label { display: flex; align-items: center; justify-content: flex-end; padding: 0 10px; font-size: 11px; color: var(--gray-500); border-bottom: 1px solid var(--gray-100); }
.cal-week-column { display: grid; grid-template-rows: 56px repeat(13, 56px); position: relative; background: white; }
.cal-week-column::before { content: ""; position: absolute; inset: 56px 0 0 0; background-image: linear-gradient(to bottom, transparent 55px, rgba(226,230,237,.6) 56px); background-size: 100% 56px; pointer-events: none; }
.cal-week-day-header { padding: 12px 10px; background: var(--gray-50); border-bottom: 1px solid var(--gray-100); display: flex; flex-direction: column; gap: 2px; font-weight: 800; font-size: 12px; }
.cal-week-day-header .panel-sub { color: var(--gray-500); font-size: 11px; }
.cal-week-event { position: relative; margin: 4px 8px 0; border-radius: 14px; padding: 12px 13px; color: white; box-shadow: 0 14px 32px rgba(0,0,0,.1); z-index: 2; display: flex; flex-direction: column; gap: 5px; font-size: 12px; }
.cal-event-title { font-weight: 800; }
.cal-event-info, .cal-event-meta { font-size: 11px; opacity: .95; }
.cal-event-confirmed { background: linear-gradient(135deg, #22c55e, #4ade80); }
.cal-event-booked { background: linear-gradient(135deg, #38bdf8, #0ea5e9); }
.cal-event-dispatched { background: linear-gradient(135deg, #a855f7, #c084fc); }
.cal-event-green { background: linear-gradient(135deg, #16a34a, #22c55e); }
.cal-event-yellow { background: linear-gradient(135deg, #f59e0b, #fbbf24); }
.cal-event-gray { background: linear-gradient(135deg, #64748b, #94a3b8); }
.cal-day { border-right: 1px solid var(--gray-100); border-bottom: 1px solid var(--gray-100); padding: 6px 7px; background: white; display: flex; flex-direction: column; gap: 3px; transition: background .1s; }
.cal-day-empty { border-right: 1px solid var(--gray-100); border-bottom: 1px solid var(--gray-100); background: var(--gray-50); }
.cal-today { background: rgba(27,94,68,.04); }
.cal-today .cal-day-num > span:first-child { width: 22px; height: 22px; border-radius: 50%; background: var(--green); color: white; display: inline-grid; place-items: center; }
.cal-past { background: var(--gray-50); }
.cal-past .cal-day-num > span:first-child { color: var(--gray-400); }
.cal-day-num { display: flex; align-items: center; gap: 6px; margin-bottom: 2px; font: 800 12px/1 var(--mono); color: var(--gray-700); }
.cal-day-count { padding: 1px 5px; border-radius: 999px; background: var(--orange); color: white; font: 800 9px/1.5 var(--mono); }
.cal-day-cards { display: flex; flex-direction: column; gap: 3px; }
.cal-day.cal-drag-over { background: var(--green-subtle) !important; outline: 2px dashed var(--green-border); outline-offset: -2px; }

.cal-card { padding: 5px 7px; background: white; border: 1px solid var(--gray-200); border-radius: var(--radius-sm); cursor: grab; font-size: 11px; transition: border-color .12s, box-shadow .12s; }
.cal-card:hover { border-color: var(--gray-300); box-shadow: var(--shadow-sm); }
.cal-card.dragging { opacity: .4; cursor: grabbing; }
.cal-card.cal-card-selected { border-color: var(--green); background: var(--green-subtle); }
.cal-card-top { display: flex; align-items: center; justify-content: space-between; gap: 4px; }
.cal-card-name { font-weight: 900; font-size: 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1; min-width: 0; }
.cal-card-info { color: var(--gray-500); font-size: 10px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 1px; }
.cal-card-badge { margin-top: 3px; }

.cal-sidebar { width: 200px; flex: 0 0 200px; border-left: 1px solid var(--gray-200); display: flex; flex-direction: column; background: var(--gray-50); overflow: hidden; }
.cal-sidebar-head { padding: 12px 14px; border-bottom: 1px solid var(--gray-200); display: flex; align-items: center; gap: 8px; font-weight: 900; font-size: 12px; background: white; flex-shrink: 0; }
.cal-sidebar-list { flex: 1; overflow: auto; padding: 10px; display: flex; flex-direction: column; gap: 6px; }

.modal-open .queue-list,
.modal-open .clients-list,
.modal-open .kanban-cards { overflow: hidden; }

.payment-mock-modal { width: min(540px, 96vw); }
.pay-mock-total { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px; background: var(--gray-50); border: 1px solid var(--gray-200); border-radius: var(--radius-sm); margin-bottom: 4px; }
.pay-mock-total strong { font-size: 20px; font-weight: 800; letter-spacing: -0.02em; }
.pay-method-tabs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.pay-method-btn { border: 1px solid var(--gray-200); background: #fff; border-radius: 999px; padding: 6px 12px; font-size: 11px; font-weight: 800; color: var(--gray-600); cursor: pointer; }
.pay-method-btn:hover { border-color: var(--gray-300); }
.pay-method-btn.active { background: var(--green); border-color: var(--green); color: #fff; }
.pay-tab-panel { margin-top: 2px; }
.pay-paypal-btn { background: #0070ba; border-color: #0070ba; }
.pay-paypal-btn:hover { filter: brightness(1.05); }
.pay-apple-btn { background: #000; border-color: #000; color: #fff; }
.pay-apple-btn:hover { filter: brightness(1.08); }
.pay-google-btn { background: #1a73e8; border-color: #1a73e8; color: #fff; }
.pay-google-btn:hover { filter: brightness(1.05); }
.pay-wallet-panel { margin-top: 12px; padding: 0; }
.pay-wallet-inner { border-radius: 12px; padding: 16px; text-align: center; }
.pay-wallet-inner.pay-wallet-apple { background: #000; color: #fff; border: 1px solid #222; }
.pay-wallet-inner.pay-wallet-apple .pay-wallet-hint { color: rgba(255,255,255,.72); font-size: 12px; margin: 8px 0 14px; }
.pay-wallet-inner.pay-wallet-google { background: #fff; border: 1px solid var(--gray-200); box-shadow: var(--shadow-sm); }
.pay-wallet-inner.pay-wallet-google .pay-wallet-brand { color: var(--gray-600); }
.pay-wallet-inner.pay-wallet-google .pay-wallet-amt { color: var(--gray-900); }
.pay-wallet-brand { font-size: 11px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; opacity: .85; }
.pay-wallet-amt { font-size: 26px; font-weight: 800; margin: 10px 0 4px; letter-spacing: -0.02em; }

.payments-table-wrap { border: 1px solid var(--gray-200); border-radius: var(--radius); overflow: auto; background: #fff; }
.payments-table-wrap .payments-table-head,
.payments-table-wrap .payments-table-body .payments-table-row { min-width: 520px; }
.payments-table-head, .payments-table-row { display: grid; grid-template-columns: 1.25fr 0.95fr 0.85fr 1fr 5.5rem; gap: 10px; align-items: center; padding: 8px 12px; font-size: 12px; }
.payments-table-head--payrun, .payments-table-row--payrun { grid-template-columns: 34px 0.95fr 1.2fr 0.95fr 0.85fr 0.85fr 0.85fr; }
.payments-table-head--wide, .payments-table-row--wide { grid-template-columns: 1.1fr 0.85fr 0.95fr 1.1fr 0.8fr 1.2fr 0.8fr; min-width: 760px; }
.payments-table-head { background: var(--gray-50); border-bottom: 1px solid var(--gray-200); color: var(--gray-500); font-size: 10px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.04em; }
.payments-table-row { border-bottom: 1px solid var(--gray-100); text-decoration: none; color: inherit; transition: background .1s; }
.payments-table-row:last-child { border-bottom: 0; }
.payments-table-row:hover { background: var(--green-subtle); }
.payments-table-body { max-height: calc(100vh - 240px); overflow: auto; }
.payments-amt { font-family: var(--mono); font-weight: 800; text-align: right; }
.pay-run-body { display: flex; flex-direction: column; gap: 12px; }
.pay-run-controls { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.pay-run-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.pay-run-actions .client-sub { margin-right: auto; }
.pay-run-check { width: 16px; height: 16px; cursor: pointer; }

.record-page--payments .metric-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.pay-methods-panel .panel-body { padding-top: 4px; }
.pay-methods-body { display: flex; flex-direction: column; gap: 10px; }
.pay-method-row { display: grid; grid-template-columns: 92px 1fr 5rem 2.5rem; gap: 10px; align-items: center; font-size: 12px; }
.pay-method-name { font-weight: 700; color: var(--gray-700); }
.pay-method-bar-wrap { height: 8px; background: var(--gray-100); border-radius: 999px; overflow: hidden; }
.pay-method-bar { height: 100%; background: linear-gradient(90deg, var(--green), var(--green-light)); border-radius: 999px; min-width: 0; transition: width .3s ease; }
.pay-method-amt { font-family: var(--mono); font-weight: 800; text-align: right; font-size: 11px; }
.pay-method-pct { color: var(--gray-500); font-size: 11px; text-align: right; }

.pay-empty-wrap { text-align: center; padding: 28px 20px 20px; max-width: 520px; margin: 0 auto; }
.pay-empty-icon { color: var(--gray-300); display: flex; justify-content: center; margin-bottom: 12px; }
.pay-empty-icon .icon { width: 40px; height: 40px; stroke-width: 1.5; }
.pay-empty-title { margin: 0 0 8px; font-size: 17px; font-weight: 900; letter-spacing: -0.02em; color: var(--gray-900); }
.pay-empty-lead { margin: 0 0 18px; color: var(--gray-600); font-size: 13px; line-height: 1.5; }
.pay-empty-steps { text-align: left; margin: 0 auto 22px; padding-left: 22px; max-width: 440px; color: var(--gray-700); font-size: 13px; line-height: 1.55; }
.pay-empty-steps li { margin-bottom: 8px; }
.pay-empty-steps strong { color: var(--gray-900); }
.pay-empty-actions { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; align-items: center; }

.pay-quick-list { display: flex; flex-direction: column; gap: 0; }
.pay-quick-row { display: grid; grid-template-columns: 1fr auto auto; gap: 12px; align-items: center; padding: 10px 4px; border-bottom: 1px solid var(--gray-100); text-decoration: none; color: inherit; font-size: 12px; transition: background .1s; }
.pay-quick-row:last-child { border-bottom: 0; }
.pay-quick-row:hover { background: var(--gray-50); }
.pay-quick-row .client-sub { display: block; margin-top: 2px; }
.pay-quick-amt { font-family: var(--mono); font-weight: 800; color: var(--gray-800); }

.panel-head-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-thumb { background: var(--gray-300); border-radius: 999px; }
::-webkit-scrollbar-track { background: transparent; }

@media (max-width: 1100px) {
  .sidebar { width: 72px; flex-basis: 72px; }
  .logo > div:last-child, .nav-label, .nav-link span.label, .user-card > div:last-child { display: none; }
  .nav-link { justify-content: center; }
  .nav-badge { position: absolute; margin-left: 22px; margin-top: -18px; }
  .top-search, .pill.price-pill { display: none; }
  .queue-panel { width: 330px; flex-basis: 330px; }
  .schedule-detail, .client-detail, .side-drawer { flex-basis: 330px; }
  .metric-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dispatch-vendor-grid { grid-template-columns: 1fr; }
  .vendor-inline-search { min-width: 170px; max-width: 100%; flex: 1; }
}

@media (max-width: 860px) {
  html, body { overflow: auto; }
  .app { min-height: 100vh; height: auto; }
  .content, .clients-layout { flex-direction: column; overflow: visible; }
  .main, .clients-main, .record-page { overflow: visible; }
  .queue-panel, .detail-panel, .schedule-detail, .client-detail, .side-drawer { width: 100%; flex: none; border-left: 0; border-right: 0; }
  .detail-panel, .schedule-detail, .client-detail, .side-drawer { min-height: 50vh; }
  .topbar { position: sticky; top: 0; z-index: 20; }
  .top-actions .pill { display: none; }
  .btn { min-height: 44px; }
  .btn-sm { min-height: 36px; }
  .info-grid, .form-row { grid-template-columns: 1fr; }
  .client-row-card { grid-template-columns: 1fr; }
  .metric-grid { grid-template-columns: 1fr; }
  .report-row { align-items: flex-start; flex-wrap: wrap; }
  .sticky-action-bar { flex-direction: column; align-items: stretch; }
  .cal-grid { grid-auto-rows: minmax(80px, auto); }
  .cal-sidebar { display: none; }
  .view-toggle-btn span.label { display: none; }
}
