/* ── Variables ────────────────────────────────────────────────────────── */
:root {
  --bg0:    #0a0f1a;
  --bg1:    #0f1623;
  --bg2:    #141d2e;
  --bg3:    #1a2540;
  --bg4:    #1f2d4a;
  --border: rgba(255,255,255,0.07);
  --bord2:  rgba(255,255,255,0.12);
  --bord3:  rgba(255,255,255,0.18);
  --text:   #e8edf5;
  --text2:  #8fa3bc;
  --text3:  #546a82;
  --green:  #22c55e;
  --green2: #16a34a;
  --green-d: rgba(34,197,94,0.12);
  /* Brand/primary accent (Mike: purple CRM). Used for buttons, focus, active nav,
     links - NOT for status/semantic (won/paid/profit stay green). */
  --accent:   #7c3aed;
  --accent2:  #6d28d9;
  --accent-d: rgba(124,58,237,0.13);
  --blue:   #3b82f6;
  --blue-d: rgba(59,130,246,0.12);
  --orange: #f97316;
  --orange-d: rgba(249,115,22,0.12);
  --red:    #ef4444;
  --red-d:  rgba(239,68,68,0.12);
  --yellow: #eab308;
  --yellow-d: rgba(234,179,8,0.12);
  --purple: #a855f7;
  --purple-d: rgba(168,85,247,0.12);
  --r:      8px;
  --r2:     12px;
  --r3:     16px;
  --shadow: 0 4px 32px rgba(0,0,0,0.5);
  --trans:  all 0.15s ease;
  --sb-w:   220px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
html, body { height: 100%; background: var(--bg0); color: var(--text); font-family: 'Inter', sans-serif; font-size: 14px; -webkit-font-smoothing: antialiased; }
a { color: var(--blue); text-decoration: none; }
a:hover { text-decoration: underline; }
code, .mono { font-family: 'JetBrains Mono', monospace; font-size: 12px; }
.hidden { display: none !important; }
svg { stroke: currentColor; stroke-width: 1.5; fill: none; stroke-linecap: round; stroke-linejoin: round; }

/* ── Scrollbars ── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--bg4); border-radius: 3px; }

/* ── Auth ──────────────────────────────────────────────────────────────── */
.auth-screen { display: flex; min-height: 100vh; }
.auth-left {
  width: 420px; background: var(--bg1); border-right: 1px solid var(--border);
  display: flex; flex-direction: column; justify-content: center; padding: 60px 48px; flex-shrink: 0;
}
.auth-right { flex: 1; display: flex; align-items: center; justify-content: center; padding: 24px; }
.auth-brand { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.auth-brand span { font-size: 22px; font-weight: 700; letter-spacing: -0.5px; }
.auth-tagline { font-size: 15px; color: var(--text2); margin-bottom: 32px; }
.auth-features { display: flex; flex-direction: column; gap: 12px; }
.af-item { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--text2); }
.af-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--green); flex-shrink: 0; }
.auth-card { width: 380px; background: var(--bg2); border: 1px solid var(--bord2); border-radius: var(--r3); padding: 36px; }
.auth-card h2 { font-size: 19px; font-weight: 600; margin-bottom: 22px; letter-spacing: -0.3px; }
.auth-hint { font-size: 12px; color: var(--text3); text-align: center; margin-top: 14px; }

/* Brand icon */
.brand-icon { width: 34px; height: 34px; background: var(--green2); border-radius: 9px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.brand-icon svg { width: 18px; height: 18px; fill: #fff; stroke: none; }
.brand-icon.sm { width: 26px; height: 26px; border-radius: 7px; }
.brand-icon.sm svg { width: 14px; height: 14px; }

/* ── App Shell ─────────────────────────────────────────────────────────── */
#app { display: flex; height: 100vh; overflow: hidden; }

/* ── Sidebar ───────────────────────────────────────────────────────────── */
#sidebar {
  width: var(--sb-w); background: var(--bg1); border-right: 1px solid var(--border);
  display: flex; flex-direction: column; flex-shrink: 0; z-index: 200;
  transition: transform 0.25s ease;
}
.sb-top { flex: 1; overflow-y: auto; padding: 0 0 12px; }
.sb-top::-webkit-scrollbar { display: none; }
.sb-logo { display: flex; align-items: center; gap: 10px; padding: 16px 14px 12px; cursor: pointer; border-bottom: 1px solid var(--border); margin-bottom: 8px; }
.sb-company { font-size: 15px; font-weight: 700; letter-spacing: -0.3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sb-nav { display: flex; flex-direction: column; padding: 0 8px; gap: 1px; }
.sb-section-label { font-size: 10px; font-weight: 600; letter-spacing: 0.8px; text-transform: uppercase; color: var(--text3); padding: 14px 8px 4px; }
.sb-link {
  display: flex; align-items: center; gap: 9px; padding: 8px 10px; border-radius: var(--r);
  color: var(--text2); font-size: 13.5px; cursor: pointer; transition: var(--trans);
  text-decoration: none;
}
.sb-link:hover { background: var(--bg3); color: var(--text); text-decoration: none; }
.sb-link.active { background: var(--green-d); color: var(--green); }
.sb-link svg { width: 16px; height: 16px; flex-shrink: 0; }
.sb-bottom { border-top: 1px solid var(--border); padding: 10px; position: relative; }
.sb-user { display: flex; align-items: center; gap: 9px; padding: 8px 8px; border-radius: var(--r); cursor: pointer; transition: var(--trans); }
.sb-user:hover { background: var(--bg3); }
.user-av { width: 30px; height: 30px; border-radius: 50%; background: var(--green2); display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 600; color: #fff; flex-shrink: 0; }
.sb-user-info { flex: 1; min-width: 0; }
.sb-user-name { font-size: 13px; font-weight: 500; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sb-user-role { font-size: 11px; color: var(--text3); text-transform: capitalize; }
.sb-caret { width: 14px; height: 14px; color: var(--text3); flex-shrink: 0; }
.sb-user-menu { position: absolute; bottom: calc(100% + 6px); left: 8px; width: 190px; right: auto; background: var(--bg3); border: 1px solid var(--bord2); border-radius: 12px; overflow: hidden; z-index: 999; box-shadow: 0 10px 30px rgba(0,0,0,0.35); }
.sm-item { display: flex; align-items: center; padding: 10px 14px; font-size: 13.5px; color: var(--text2); cursor: pointer; white-space: nowrap; }
.sm-item:hover { background: var(--bg4); color: var(--text); }
.sm-item.danger { color: var(--red); }
.sm-sep { height: 1px; background: var(--border); }

/* Mobile sidebar category groups (accordion) - mirrors the desktop top-nav. */
#sidebar .sb-group-hdr { width: 100%; text-align: left; background: none; border: none; font-family: inherit; }
#sidebar .sb-group-hdr .sb-arrow { width: 14px; height: 14px; background: none; padding: 0; border-radius: 0;
  margin-left: auto; opacity: 0.55; transition: transform 0.2s ease; flex-shrink: 0; }
#sidebar .sb-group.open > .sb-group-hdr .sb-arrow { transform: rotate(180deg); }
#sidebar .sb-sub { display: none; margin: 1px 0 2px; }
#sidebar .sb-group.open > .sb-sub,
#sidebar .sb-group:has(.sb-link.active) > .sb-sub { display: block; }
#sidebar .sb-sub-link { padding-left: 42px; font-size: 13px; }
#sidebar .sb-group:has(.sb-link.active) > .sb-group-hdr { color: #a78bfa; }

/* ── Mobile Header ─────────────────────────────────────────────────────── */
.mobile-header {
  display: none; align-items: center; justify-content: space-between;
  height: 52px; padding: 0 14px; background: var(--bg1); border-bottom: 1px solid var(--border);
  position: fixed; top: 0; left: 0; right: 0; z-index: 300;
}
.mob-menu-btn, .mob-new-btn {
  background: transparent; border: 1px solid var(--bord2); border-radius: var(--r);
  color: var(--text2); padding: 6px 10px; cursor: pointer; display: flex; align-items: center; gap: 6px;
}
.mob-menu-btn svg { width: 18px; height: 18px; }
.mob-logo { display: flex; align-items: center; gap: 8px; font-size: 15px; font-weight: 700; }
.mob-new-btn { color: var(--accent); border-color: rgba(124,58,237,0.3); font-size: 13px; font-weight: 500; }

/* ── Main Content ──────────────────────────────────────────────────────── */
#main-content { flex: 1; overflow-y: auto; background: var(--bg0); }
.view { min-height: 100vh; }
.view.active { display: block; }

/* ── Global top bar (search) ───────────────────────────────────────────── */
#topbar { position: sticky; top: 0; z-index: 60; display: flex; align-items: center; gap: 14px;
  padding: 11px 28px; background: var(--bg2); border-bottom: 1px solid var(--border);
  box-shadow: 0 1px 4px rgba(15,23,42,0.05); }
.topbar-search { position: relative; width: 440px; max-width: 100%; }
.topbar-search input { width: 100%; padding: 10px 14px 10px 38px; border: 1px solid transparent;
  border-radius: 10px; background: var(--bg3); color: var(--text); font-size: 13px; box-sizing: border-box; transition: var(--trans); }
.topbar-search input::placeholder { color: var(--text3); }
.topbar-search input:focus { border-color: var(--accent); background: var(--bg2); outline: none; box-shadow: 0 0 0 3px var(--accent-d); }
.topbar-search .ts-icon { position: absolute; left: 13px; top: 50%; transform: translateY(-50%);
  width: 15px; height: 15px; color: var(--text3); stroke: currentColor; fill: none; stroke-width: 2; pointer-events: none; }
#gsearch-results { display: none; position: absolute; left: 0; right: 0; top: 100%; margin-top: 6px; z-index: 200;
  background: var(--bg-elev, var(--bg2)); border: 1px solid var(--border); border-radius: 10px;
  box-shadow: 0 12px 32px rgba(15,23,42,0.13); max-height: 64vh; overflow: auto; }
/* Top bar right-side actions: notifications, settings, user */
.topbar-actions { margin-left: auto; display: flex; align-items: center; gap: 4px; }
.tb-icon { position: relative; width: 37px; height: 37px; border-radius: 10px; border: 1px solid transparent;
  background: transparent; color: var(--text2); display: inline-flex; align-items: center; justify-content: center; cursor: pointer; transition: var(--trans); }
.tb-icon:hover { background: var(--bg3); color: var(--text); }
.tb-icon svg { width: 19px; height: 19px; stroke: currentColor; fill: none; stroke-width: 2; }
.tb-badge { position: absolute; top: 3px; right: 3px; min-width: 16px; height: 16px; padding: 0 4px; border-radius: 8px;
  background: var(--green2, var(--green)); color: #fff; font-size: 10px; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.tb-menu-wrap { position: relative; }
.tb-user { display: flex; align-items: center; gap: 8px; padding: 4px 8px 4px 4px; border-radius: 10px; cursor: pointer; transition: var(--trans); }
.tb-user:hover { background: var(--bg3); }
.tb-user .user-av { width: 30px; height: 30px; }
.tb-user-name { font-size: 13px; font-weight: 600; color: var(--text); }
.tb-user .sb-caret { width: 15px; height: 15px; color: var(--text3); }
.tb-menu { position: absolute; right: 0; top: calc(100% + 6px); min-width: 190px; background: var(--bg-elev, var(--bg2));
  border: 1px solid var(--border); border-radius: 11px; box-shadow: 0 12px 32px rgba(15,23,42,0.13); padding: 6px; z-index: 300; }
.sm-userhead { padding: 5px 11px 8px; font-size: 11px; color: var(--text3); text-transform: capitalize; border-bottom: 1px solid var(--border); margin-bottom: 4px; }
/* Notification (My Tasks) dropdown */
#tb-notif-menu { width: 322px; padding: 0; overflow: hidden; }
.notif-head { display: flex; justify-content: space-between; align-items: center; padding: 12px 15px; border-bottom: 1px solid var(--border); }
.notif-head .notif-title-lg { font-size: 13px; font-weight: 700; color: var(--text); }
.notif-head a { font-size: 12px; color: var(--accent); font-weight: 600; text-decoration: none; }
.notif-list { max-height: 58vh; overflow: auto; }
.notif-row { display: flex; align-items: center; gap: 11px; padding: 11px 15px; cursor: pointer; border-top: 1px solid var(--border); }
.notif-row:first-child { border-top: 0; }
.notif-row:hover { background: var(--bg2); }
.notif-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.notif-main { flex: 1; min-width: 0; }
.notif-row-title { font-size: 13px; font-weight: 500; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.notif-row-sub { font-size: 11px; color: var(--text3); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-top: 1px; }
.notif-due { flex-shrink: 0; font-size: 10px; font-weight: 700; padding: 3px 9px; border-radius: 20px; background: var(--bg2); color: var(--text3); }
.notif-due.overdue { background: var(--red-d); color: var(--red); }
.notif-due.today { background: var(--orange-d); color: var(--orange); }
.notif-foot { padding: 10px 14px; text-align: center; font-size: 11px; color: var(--text3); border-top: 1px solid var(--border); }
.notif-empty { padding: 30px 16px; text-align: center; color: var(--text3); font-size: 13px; line-height: 1.6; }
/* Activity timeline (customer profile) */
.tl { padding: 8px 18px 14px; }
.tl-row { display: flex; gap: 13px; position: relative; padding-bottom: 15px; }
.tl-row:not(:last-child)::before { content: ''; position: absolute; left: 15px; top: 32px; bottom: 0; width: 2px; background: var(--border); }
.tl-dot { width: 31px; height: 31px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; z-index: 1; }
.tl-body { flex: 1; min-width: 0; padding-top: 4px; }
.tl-title { font-size: 13px; font-weight: 600; color: var(--text); }
.tl-sub { font-size: 12px; color: var(--text2); margin-top: 2px; overflow-wrap: anywhere; word-break: break-word; white-space: pre-wrap; max-height: 58px; overflow: hidden; }
.tl-time { font-size: 11px; color: var(--text3); margin-top: 3px; }
@media (max-width: 860px) { #topbar { padding: 9px 14px; } .topbar-search { flex: 1; width: auto; min-width: 0; } .tb-user-name { display: none; } }

/* ── Desktop top-nav (experiment: menu on top instead of left sidebar) ──────
   Mobile keeps the existing left sidebar untouched; on desktop (>=901px) the
   sidebar is hidden and the nav moves into a horizontal bar under the topbar. */
#app-header { position: sticky; top: 0; z-index: 60; }
#topbar { position: static; }            /* stickiness now handled by #app-header */
#topnav { display: none; }               /* hidden by default (mobile) */
.tb-brand { display: none; align-items: center; gap: 9px; cursor: pointer; margin-right: 6px; text-decoration: none; flex-shrink: 0; }
.tb-brand .sb-company { font-size: 15px; }

/* Top-nav item: icon + label side by side (Mike) */
.tn-item {
  display: flex; flex-direction: row; align-items: center; gap: 7px;
  flex: 0 0 auto; padding: 8px 13px; border-radius: 9px; cursor: pointer; white-space: nowrap;
  background: none; border: none; color: rgba(255,255,255,0.72); font-size: 13px; font-weight: 500;
  text-decoration: none; transition: var(--trans); font-family: inherit;
}
.tn-item svg { width: 18px; height: 18px; flex-shrink: 0; }
.tn-item:hover { background: rgba(255,255,255,0.08); color: #fff; text-decoration: none; }
/* Active tab = filled purple pill + white label/icon (Mike loved this on mobile).
   On the dark sub-bar the purple pops; purple only on the active item. */
.tn-item.active,
.tn-group:has(.tn-dd.active) > .tn-item,
.tn-group:has(.tn-dd.active) > .tn-group-btn {
  background: rgba(124,58,237,0.30); color: #fff; font-weight: 600;
  box-shadow: inset 0 0 0 1px rgba(124,58,237,0.55);
}
#topnav .tn-item.active span,
#topnav .tn-group:has(.tn-dd.active) > .tn-item span { color: #fff !important; }
#topnav .tn-item.active svg,
#topnav .tn-group:has(.tn-dd.active) > .tn-group-btn svg { color: #c4b5fd !important; }
.tn-group { position: relative; flex: 0 0 auto; }
.tn-caret { width: 11px; height: 11px; opacity: 0.5; margin-left: -1px; }
/* Icons are uniform (inherit the light label color) - no per-category colors. */
.tn-dropdown {
  position: absolute; top: 100%; left: 0; min-width: 190px; display: none; z-index: 70;
  background: var(--bg2); border: 1px solid var(--bord2); border-radius: 12px; padding: 6px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.16);
}
/* Invisible bridge: fills the space between the item and the menu so moving the
   cursor down doesn't drop the :hover and close the menu before you can click. */
.tn-dropdown::before { content: ''; position: absolute; top: -10px; left: 0; right: 0; height: 10px; }
/* Hover-only: only the category under the cursor opens, so two dropdowns can
   never be open at once. */
.tn-group:hover .tn-dropdown { display: block; }
/* After clicking a leaf item, force the menu shut even though the cursor is still
   over the group (JS adds .tn-suppress, removed once the cursor moves away). */
.tn-group.tn-suppress .tn-dropdown { display: none !important; }
/* Dropdown items - self-contained (NOT .sb-link, to avoid the sidebar icon-tile
   styles bleeding in and breaking the top nav). */
.tn-dd {
  display: block; padding: 9px 11px; border-radius: 8px; color: var(--text2);
  font-size: 13px; cursor: pointer; white-space: nowrap; text-decoration: none; transition: var(--trans);
}
.tn-dd:hover { background: var(--bg3); color: var(--text); text-decoration: none; }
.tn-dd.active { background: rgba(124,58,237,0.10); color: #6d28d9; font-weight: 600; }

@media (min-width: 901px) {
  #sidebar { display: none; }
  .tb-brand { display: flex; }
  /* flex-wrap (not overflow) so a narrow window wraps to a second row instead of
     clipping the dropdowns and showing a scrollbar. */
  #topnav {
    display: flex; flex-wrap: wrap; align-items: center; gap: 2px;
    padding: 6px 18px; background: linear-gradient(180deg, #1e293b, #0f172a);
    border-bottom: 1px solid rgba(0,0,0,0.2);
    box-shadow: 0 1px 6px rgba(15,23,42,0.12);
  }
  /* The estimator is a fixed-height flex view; subtract the taller app-header
     (topbar + topnav) so its map sits below the nav instead of under it. */
  .estimator-layout { height: calc(100vh - 116px); }
}

/* ── Page Header ───────────────────────────────────────────────────────── */
.page-hdr { display: flex; align-items: center; justify-content: space-between; padding: 24px 28px 0; margin-bottom: 20px; }
.page-hdr h1 { font-size: 21px; font-weight: 700; letter-spacing: -0.4px; }
.page-subtitle { font-size: 13px; color: var(--text2); margin-top: 2px; }
.page-hdr-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
/* Two logical clusters in the project-detail header: manage (left) + create (right).
   The end group is pushed right; both wrap as units on narrow screens. */
.page-hdr-actions .hdr-group { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.page-hdr-actions .hdr-group-end { margin-left: auto; }
@media (max-width: 720px) { .page-hdr-actions .hdr-group-end { margin-left: 0; } }

/* ── Forms ─────────────────────────────────────────────────────────────── */
.field { margin-bottom: 12px; }
.field label { display: block; font-size: 12px; font-weight: 500; color: var(--text2); margin-bottom: 5px; }
.field input, .field select, .field textarea {
  width: 100%; padding: 9px 12px; background: var(--bg2); border: 1px solid var(--bord2);
  border-radius: var(--r); color: var(--text); font-family: 'Inter', sans-serif; font-size: 13.5px;
  outline: none; transition: border-color 0.15s; resize: vertical;
}
.field input::placeholder, .field textarea::placeholder { color: var(--text3); }
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--green); }
.field-error { font-size: 12.5px; color: var(--red); padding: 4px 0 8px; }
.form-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.form-row3 { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 10px; }
.form-row4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
.check-row { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; font-size: 13.5px; color: var(--text2); cursor: pointer; }
.check-row input[type=checkbox] { width: 16px; height: 16px; accent-color: var(--green); cursor: pointer; }
.input-group { display: flex; }
.input-group input { border-radius: var(--r) 0 0 var(--r); flex: 1; }
.input-addon { padding: 9px 12px; background: var(--bg3); border: 1px solid var(--bord2); border-left: none; border-radius: 0 var(--r) var(--r) 0; color: var(--text3); font-size: 13px; white-space: nowrap; }

/* ── Buttons ───────────────────────────────────────────────────────────── */
.btn-primary {
  padding: 9px 18px; background: var(--green2); color: #fff; border: none; border-radius: var(--r);
  font-family: 'Inter', sans-serif; font-size: 13.5px; font-weight: 500; cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px; transition: var(--trans); white-space: nowrap;
}
.btn-primary:hover { background: var(--green); }
.btn-primary.full { width: 100%; justify-content: center; }
.btn-primary svg { width: 15px; height: 15px; flex-shrink: 0; }
.btn-sec {
  padding: 8px 16px; background: transparent; color: var(--text2); border: 1px solid var(--bord2);
  border-radius: var(--r); font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 500;
  cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: var(--trans); white-space: nowrap;
}
.btn-sec:hover { background: var(--bg3); color: var(--text); }
.btn-sec svg { width: 14px; height: 14px; }
.btn-danger { background: var(--red-d); color: var(--red); border-color: rgba(239,68,68,0.3); }
.btn-danger:hover { background: rgba(239,68,68,0.22); }
/* Solid destructive button (confirm dialogs) - a real filled red button, not faint text. */
.btn-danger-solid { padding: 9px 18px; background: #ef4444; color: #fff; border: none; border-radius: var(--r); font-size: 13.5px; font-weight: 600; font-family: 'Inter', sans-serif; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: var(--trans); white-space: nowrap; box-shadow: 0 2px 8px rgba(239,68,68,0.32); }
.btn-danger-solid:hover { background: #dc2626; }
.btn-danger-solid:active { transform: translateY(0) scale(0.99); }
/* Reusable toggle switch */
.rp-switch { position: relative; display: inline-block; width: 42px; height: 24px; flex-shrink: 0; }
.rp-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.rp-switch .sl { position: absolute; inset: 0; background: var(--bord3); border-radius: 24px; transition: .18s; cursor: pointer; }
.rp-switch .sl:before { content: ""; position: absolute; height: 18px; width: 18px; left: 3px; top: 3px; background: #fff; border-radius: 50%; transition: .18s; box-shadow: 0 1px 3px rgba(0,0,0,.25); }
.rp-switch input:checked + .sl { background: var(--green2); }
.rp-switch input:checked + .sl:before { transform: translateX(18px); }
.btn-sm {
  padding: 5px 11px; font-size: 12px; font-weight: 500; font-family: 'Inter', sans-serif;
  background: transparent; color: var(--text2); border: 1px solid var(--bord2);
  border-radius: var(--r); cursor: pointer; display: inline-flex; align-items: center; gap: 5px;
  transition: var(--trans); white-space: nowrap;
}
.btn-sm:hover { background: var(--bg3); color: var(--text); }
.btn-sm.btn-danger { background: var(--red-d); color: var(--red); border-color: rgba(239,68,68,0.3); }
.btn-sm.btn-danger:hover { background: rgba(239,68,68,0.22); }
.btn-sm svg { width: 13px; height: 13px; }

/* Clean borderless icon button (card/row actions across SMS views). */
.icon-btn { width: 30px; height: 30px; display: inline-flex; align-items: center; justify-content: center; border: none; background: transparent; border-radius: 8px; color: var(--text3); cursor: pointer; transition: var(--trans); padding: 0; }
.icon-btn:hover { background: var(--bg3); color: var(--text); }
.icon-btn svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 2; }
.icon-btn.danger:hover { background: var(--red-d); color: var(--red); }
.icon-btn-row { display: inline-flex; align-items: center; gap: 2px; }

/* SMS workspace - a section with its own left sidebar (like the old texting app). */
.sms-shell { display: flex; align-items: stretch; min-height: calc(100vh - 64px); }
.sms-shell-nav { width: 208px; flex-shrink: 0; border-right: 1px solid var(--border); padding: 18px 10px; display: flex; flex-direction: column; gap: 2px; }
.sms-shell-main { flex: 1; min-width: 0; }
.sms-nav-item { display: block; padding: 9px 13px; border-radius: 9px; font-size: 14px; font-weight: 500; color: var(--text2); cursor: pointer; transition: var(--trans); }
.sms-nav-item:hover { background: var(--bg3); color: var(--text); }
.sms-nav-item.active { background: var(--green-d); color: var(--green); }
@media (max-width: 760px) {
  .sms-shell { flex-direction: column; }
  .sms-shell-nav { width: auto; flex-direction: row; flex-wrap: wrap; border-right: none; border-bottom: 1px solid var(--border); padding: 10px; gap: 4px; }
  .sms-nav-item { padding: 7px 11px; font-size: 13px; }
}

/* Company Settings - left vertical sub-menu (like the SMS / AI Studio shell) */
.set-shell { display: flex; align-items: flex-start; gap: 28px; }
.set-shell-nav {
  width: 212px; flex-shrink: 0; display: flex; flex-direction: column; gap: 3px;
  position: sticky; top: 18px;
  background: var(--bg2); border: 1px solid var(--border); border-radius: 14px;
  padding: 10px; box-shadow: 0 1px 2px rgba(15,23,42,0.05), 0 8px 24px rgba(15,23,42,0.05);
}
.set-shell-main { flex: 1; min-width: 0; max-width: 820px; }
/* override the centered ".stab-panel .card" rule so cards sit flush against the nav */
.set-shell .stab-panel .card { margin-left: 0; margin-right: 0; }
.set-nav-item {
  display: flex; align-items: center; width: 100%; text-align: left;
  padding: 10px 13px; border: none; background: none; border-radius: 10px;
  font-size: 14px; font-weight: 500; color: var(--text2); cursor: pointer;
  transition: var(--trans);
}
.set-nav-item:hover { background: var(--bg3); color: var(--text); }
.set-nav-item.active { background: var(--green-d); color: var(--green); font-weight: 600; }
@media (max-width: 760px) {
  .set-shell { flex-direction: column; gap: 14px; }
  .set-shell-nav { width: auto; flex-direction: row; flex-wrap: wrap; gap: 4px; position: static; box-shadow: none; }
  .set-shell-main { max-width: none; }
  .set-nav-item { width: auto; padding: 7px 11px; font-size: 13px; }
}

/* Proposal-text line editor (draft estimates) - drag-to-reorder bullet rows */
.prop-row { position: relative; display: flex; align-items: flex-start; gap: 4px; padding: 8px 8px 8px 4px; margin-bottom: 7px; background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; transition: border-color .15s, box-shadow .15s; }
.prop-row:hover { border-color: var(--bord2); box-shadow: 0 2px 10px rgba(15,23,42,0.06); }
.prop-row:focus-within { border-color: var(--green2); box-shadow: 0 0 0 2px rgba(34,197,94,0.16); }
.prop-row.prop-dragging { opacity: 0.4; }
/* green drop-position indicator while dragging */
.prop-row.drop-before::before, .prop-row.drop-after::after { content: ''; position: absolute; left: 6px; right: 6px; height: 3px; background: var(--green); border-radius: 2px; }
.prop-row.drop-before::before { top: -5px; }
.prop-row.drop-after::after  { bottom: -5px; }
.prop-grip { display: flex; align-items: center; align-self: stretch; cursor: grab; color: var(--text3); padding: 0 5px; border-radius: 6px; flex-shrink: 0; transition: background .15s, color .15s; }
.prop-grip svg { fill: currentColor; }
.prop-grip:hover { background: var(--bg3); color: var(--text2); }
.prop-grip:active { cursor: grabbing; }
.prop-input { flex: 1; min-width: 0; display: block; border: none; border-radius: 6px; padding: 4px 4px; font-family: 'Inter',sans-serif; font-size: 13px; line-height: 1.5; background: transparent; color: var(--text); resize: none; overflow: hidden; }
.prop-input:focus { outline: none; }
.prop-del { border: none; background: transparent; color: var(--text3); cursor: pointer; font-size: 12px; padding: 6px 7px 0; border-radius: 6px; flex-shrink: 0; opacity: 0; transition: opacity .12s, background .15s, color .15s; }
.prop-row:hover .prop-del, .prop-row:focus-within .prop-del { opacity: 1; }
.prop-del:hover { background: rgba(239,68,68,0.12); color: var(--red); }
.prop-empty { color: var(--text3); font-size: 13px; padding: 18px 4px; text-align: center; }

/* Proposal editor - split view: line editor (left) + live PDF preview (right) */
/* ── Proposal editor - single column, edit directly on the document ──────── */
.modal.proposal-editor { width: 94vw; max-width: 1040px; height: 92vh; max-height: 92vh; display: flex; flex-direction: column; padding: 0; overflow: hidden; }
.proposal-editor .modal-hdr { padding: 14px 16px 14px 22px; flex-shrink: 0; }
.proposal-editor .modal-hdr > div { flex-wrap: wrap; justify-content: flex-end; }
.proposal-editor .modal-hdr .btn-sm svg { vertical-align: -2px; margin-right: 5px; }

/* Modern info banner above the document */
.proposal-hint { display: flex; align-items: center; gap: 9px; margin: 13px 16px 0; padding: 9px 14px; font-size: 12.5px; line-height: 1.4; color: var(--text2); background: linear-gradient(90deg, rgba(34,197,94,0.10), rgba(34,197,94,0.02)); border: 1px solid rgba(34,197,94,0.28); border-left: 3px solid var(--green2); border-radius: 10px; }
.proposal-hint::before { content: '✎'; color: var(--green2); font-size: 14px; flex-shrink: 0; }
.proposal-hint b { color: var(--text); font-weight: 600; }
.proposal-hint .hint-muted { color: var(--text3); }
.proposal-hint kbd { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 10px; font-weight: 600; color: var(--text2); background: var(--bg3); border: 1px solid var(--bord2); border-radius: 4px; padding: 1px 5px; margin: 0 2px; white-space: nowrap; }

/* Document canvas - soft backdrop, the white page floats with a real shadow */
.proposal-canvas-wrap { flex: 1; min-height: 0; overflow-y: auto; background: var(--bg4); padding: 20px 18px 32px; display: flex; flex-direction: column; align-items: center; gap: 20px; }
.proposal-doc { background: #fff; color: #111827; width: 100%; max-width: 720px; margin: 0 auto; padding: 44px 52px; box-shadow: 0 8px 30px rgba(0,0,0,0.30); border-radius: 5px; font-family: 'Inter', sans-serif; }
.proposal-doc .pd-head { display: grid; grid-template-columns: 1fr auto 1fr; gap: 14px; align-items: start; }
.proposal-doc .pd-logo { max-width: 112px; max-height: 112px; width: auto; height: auto; display: block; margin-bottom: 6px; }
.proposal-doc .pd-co-name { font-weight: 700; font-size: 14px; }
.proposal-doc .pd-co-line { color: #6b7280; font-size: 9.5px; margin-top: 2px; }
.proposal-doc .pd-title { color: #9ca3af; font-size: 22px; letter-spacing: 1px; text-align: center; }
.proposal-doc .pd-for-h { font-weight: 700; font-size: 12px; margin-bottom: 5px; }
.proposal-doc .pd-field { font-size: 10.5px; border-bottom: 1px solid #d1d5db; padding: 3px 0; color: #111827; }
.proposal-doc .pd-field b { color: #6b7280; font-weight: 700; margin-right: 6px; }
.proposal-doc .pd-banner { font-weight: 700; font-size: 16px; margin-top: 22px; }
.proposal-doc .pd-rule { height: 3px; background: #111827; margin: 8px 0 12px; }
.proposal-doc .pd-section { font-weight: 700; font-size: 11px; display: flex; align-items: center; gap: 8px; }
.proposal-doc .pd-edit-badge { font-size: 9px; font-weight: 700; letter-spacing: .4px; text-transform: uppercase; color: var(--green2, #16a34a); background: rgba(34,197,94,0.14); padding: 2px 8px; border-radius: 20px; }
.proposal-doc .pd-includes { color: #6b7280; font-size: 10px; margin: 3px 0 9px; }
.proposal-doc .pd-scope { list-style: none; padding: 0; margin: 0; }
.proposal-doc .pd-scope li { position: relative; padding: 3px 0 3px 16px; color: #374151; font-size: 11px; line-height: 1.45; }
.proposal-doc .pd-scope li::before { content: '•'; position: absolute; left: 3px; color: #374151; }
.proposal-doc .pd-warranty { margin-top: 10px; }
.proposal-doc .pd-warranty-h { font-weight: 700; font-size: 11px; color: #111827; margin-bottom: 3px; }
.proposal-doc .pd-warranty .pd-line { cursor: default; }
.proposal-doc .pd-total-rule { border-top: 1px solid #111827; margin: 16px 0 8px auto; width: 45%; }
.proposal-doc .pd-total { text-align: right; font-weight: 700; font-size: 15px; }
.proposal-doc .pd-total span { margin-left: 10px; }
.proposal-doc .pd-total-edit { display: inline-block; min-width: 90px; padding: 1px 8px; border-radius: 6px; outline: none; cursor: text; transition: background .15s, box-shadow .15s; }
.proposal-doc .pd-total-edit:hover { background: #f3f4f6; }
.proposal-doc .pd-total-edit:focus { background: #f0fdf4; box-shadow: inset 0 0 0 1.5px rgba(34,197,94,0.45); }

/* Page 2 - Terms & Conditions (display-only) */
.proposal-doc.pd-terms-page { color: #374151; }
.proposal-doc .pd-terms-title { font-weight: 700; font-size: 13px; color: #111827; }
.proposal-doc .pd-terms-co { font-weight: 700; font-size: 10px; color: #111827; margin-top: 4px; }
.proposal-doc .pd-terms-intro { font-size: 9.5px; color: #374151; margin: 9px 0 12px; line-height: 1.5; }
.proposal-doc .pd-term { margin-bottom: 9px; }
.proposal-doc .pd-term-h { font-weight: 700; font-size: 9.5px; color: #111827; }
.proposal-doc .pd-term-b { font-size: 9px; color: #374151; line-height: 1.5; margin-top: 2px; }
.proposal-doc .pd-term-closing { font-style: italic; font-size: 9px; color: #111827; margin: 14px 0 26px; line-height: 1.5; }
.proposal-doc .pd-sign-line { border-top: 1px solid #111827; width: 55%; }
.proposal-doc .pd-sign-label { font-size: 9px; color: #6b7280; margin-top: 4px; }

/* The scope list is edited in place (contenteditable) */
/* Paginated editor - each sheet is one printed page; scope = editable lines */
.proposal-doc .pd-scope-edit { border-radius: 8px; padding: 4px 10px; margin: 2px -10px 0; transition: background .15s, box-shadow .15s; }
.proposal-doc .pd-scope-edit:focus-within { background: #f0fdf4; box-shadow: inset 0 0 0 1.5px rgba(34,197,94,0.40); }
/* Same font (DejaVu Sans) as the printed PDF so on-screen wrapping/fill matches */
@font-face { font-family: 'DejaVuProp'; src: url('/fonts/DejaVuSans.ttf') format('truetype'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'DejaVuProp'; src: url('/fonts/DejaVuSans-Bold.ttf') format('truetype'); font-weight: 700; font-display: swap; }
.proposal-doc .pd-line { position: relative; padding: 2px 0 2px 18px; font-family: 'DejaVuProp', sans-serif; font-size: 10.8px; line-height: 1.165; color: #374151; outline: none; word-break: break-word; cursor: text; font-kerning: none; }
.proposal-doc .pd-line::before { content: '•'; position: absolute; left: 4px; color: #374151; }
.proposal-doc .pd-line.pd-blank::before { content: none; }   /* blank line = spacing, no bullet (matches PDF) */
/* Page-break marker - placed at the exact line the PDF starts a new page */
.proposal-doc .pd-line.pd-pagebreak,
.proposal-doc .pd-terms-block.pd-pagebreak-block {
  position: relative; margin-top: 60px; padding-top: 22px;
  border-top: 2px solid #94a3b8;
}
.proposal-doc .pd-line.pd-pagebreak::after,
.proposal-doc .pd-terms-block.pd-pagebreak-block::before {
  content: '⎯⎯  PAGE ' attr(data-pageno) '  ⎯⎯';
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  font-size: 10px; font-weight: 800; letter-spacing: 1.4px; white-space: nowrap;
  color: #fff; background: #475569; padding: 4px 15px; border-radius: 20px;
  box-shadow: 0 3px 9px rgba(0,0,0,0.28);
}

@media (max-width: 820px) {
  .modal.proposal-editor { position: fixed; inset: 0; width: auto; height: auto; max-width: none; max-height: none; border-radius: 0; }
  /* Header: title on its own row, action buttons wrap below so none get clipped
     off-screen (Save/✕ were being cut on narrow phones). padding-top keeps the
     title clear of the status bar / notch / Dynamic Island (safe-area inset). */
  .proposal-editor .modal-hdr { flex-wrap: wrap; gap: 10px; padding: 12px 14px; padding-top: calc(12px + env(safe-area-inset-top)); }
  .proposal-editor .modal-hdr h3 { flex: 1 1 100%; font-size: 15px; }
  .proposal-editor .modal-hdr > div { width: 100%; justify-content: flex-start; flex-wrap: wrap; gap: 6px; }
  .proposal-editor .modal-hdr .btn-close { margin-left: auto; }
  /* Canvas: no horizontal bleed; the sheet fills the phone width. */
  .proposal-canvas-wrap { overflow-x: hidden; padding: 14px 10px 28px; }
  .proposal-doc { padding: 22px 16px; max-width: 100%; }
  .proposal-doc .pd-head { gap: 8px; }
  .proposal-doc .pd-head > * { min-width: 0; }
  .proposal-doc .pd-field { overflow-wrap: anywhere; }
  .proposal-hint { margin: 10px 12px 0; }
}

/* Detail-page action toolbars: the secondary buttons were washed-out
   (transparent bg + faint text), clashing with the single green primary. Give
   them a crisp, consistent card-like look with a brand-green hover. */
.page-hdr-actions .btn-sec,
.page-hdr-actions select {
  background: var(--bg2); color: var(--text); border: 1px solid var(--bord2);
  box-shadow: 0 1px 2px rgba(15,23,42,0.05);
}
.page-hdr-actions .btn-sec:hover {
  background: var(--bg3); color: var(--text);
  border-color: var(--green2); box-shadow: 0 3px 10px rgba(34,197,94,0.18);
}
.page-hdr-actions .btn-sec svg { opacity: 0.85; }
.btn-icon { width: 32px; height: 32px; padding: 0; justify-content: center; }
.btn-icon svg { width: 15px; height: 15px; }

/* ── Actions dropdown menu (estimate detail toolbar) ───────────────────── */
.action-menu { position: relative; display: inline-flex; }
.action-menu > .btn-sec svg { width: 15px; height: 15px; }
.action-menu-pop {
  position: absolute; top: calc(100% + 6px); right: 0; min-width: 218px;
  background: var(--bg2); border: 1px solid var(--bord2); border-radius: 12px;
  box-shadow: 0 12px 34px rgba(15,23,42,0.28); padding: 6px; z-index: 60;
  display: none; transform-origin: top right;
}
.action-menu-pop.open { display: block; animation: rp-menu-pop 0.13s ease both; }
@keyframes rp-menu-pop { from { opacity: 0; transform: translateY(-4px) scale(0.98); } to { opacity: 1; transform: none; } }
.action-menu-pop .menu-label {
  font-size: 10px; font-weight: 700; letter-spacing: 0.6px; text-transform: uppercase;
  color: var(--text3); padding: 7px 10px 3px;
}
.action-menu-pop .menu-item {
  display: flex; align-items: center; gap: 10px; width: 100%; text-align: left;
  background: transparent; border: none; border-radius: 8px; padding: 9px 10px;
  font-family: inherit; font-size: 13px; font-weight: 500; color: var(--text);
  cursor: pointer; text-decoration: none; transition: background 0.12s, color 0.12s;
}
.action-menu-pop .menu-item:hover { background: var(--bg3); }
.action-menu-pop .menu-item svg { width: 16px; height: 16px; flex-shrink: 0; color: var(--text2); stroke-width: 1.8; }
.action-menu-pop .menu-item.danger { color: var(--red); }
.action-menu-pop .menu-item.danger svg { color: var(--red); }
.action-menu-pop .menu-item.danger:hover { background: var(--red-d); }
.action-menu-pop .menu-sep { height: 1px; background: var(--bord2); margin: 5px 6px; }

/* ── Cards ─────────────────────────────────────────────────────────────── */
.card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r2); }
.card-pad { padding: 18px 20px; }
.card-hdr { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; border-bottom: 1px solid var(--border); }
.card-hdr h3 { font-size: 14px; font-weight: 600; }
.card-body { padding: 16px 18px; }

/* ── Stat Cards ────────────────────────────────────────────────────────── */
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; padding: 0 28px; margin-bottom: 20px; }
.stat-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r2); padding: 18px 20px; }
.stat-label { font-size: 11.5px; font-weight: 500; color: var(--text3); letter-spacing: 0.3px; margin-bottom: 8px; text-transform: uppercase; }
.stat-value { font-size: 26px; font-weight: 700; color: var(--text); letter-spacing: -0.5px; line-height: 1; margin-bottom: 4px; }
.stat-sub { font-size: 12px; color: var(--text3); }
.stat-card.green  { border-color: rgba(34,197,94,0.25); background: linear-gradient(135deg, var(--bg2), rgba(34,197,94,0.05)); }
.stat-card.blue   { border-color: rgba(59,130,246,0.25); background: linear-gradient(135deg, var(--bg2), rgba(59,130,246,0.05)); }
.stat-card.orange { border-color: rgba(249,115,22,0.25); background: linear-gradient(135deg, var(--bg2), rgba(249,115,22,0.05)); }
.stat-card.purple { border-color: rgba(168,85,247,0.25); background: linear-gradient(135deg, var(--bg2), rgba(168,85,247,0.05)); }
.stat-card.green  .stat-value { color: var(--green); }
.stat-card.blue   .stat-value { color: var(--blue); }
.stat-card.orange .stat-value { color: var(--orange); }
.stat-card.purple .stat-value { color: var(--purple); }

/* ── Tables ────────────────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
thead th { padding: 10px 14px; text-align: left; font-size: 11px; font-weight: 600; color: var(--text3); letter-spacing: 0.5px; text-transform: uppercase; border-bottom: 1px solid var(--border); background: var(--bg2); white-space: nowrap; }
tbody tr { border-bottom: 1px solid var(--border); transition: background 0.1s; cursor: pointer; }
tbody tr:last-child { border-bottom: none; }
tbody tr:hover { background: var(--bg3); }
tbody td { padding: 11px 14px; color: var(--text); vertical-align: middle; }
.td-muted { color: var(--text2); }
.td-mono { font-family: 'JetBrains Mono', monospace; font-size: 12px; }

/* ── Status Badges ─────────────────────────────────────────────────────── */
.badge { display: inline-flex; align-items: center; padding: 3px 9px; border-radius: 20px; font-size: 11.5px; font-weight: 500; white-space: nowrap; }
.badge-lead       { background: var(--blue-d);   color: var(--blue); }
.badge-contacted  { background: var(--purple-d); color: var(--purple); }
.badge-measured   { background: var(--yellow-d); color: var(--yellow); }
.badge-quoted     { background: var(--orange-d); color: var(--orange); }
.badge-approved   { background: var(--green-d);  color: var(--green); }
.badge-scheduled  { background: var(--blue-d);   color: #60a5fa; }
.badge-in_progress{ background: var(--orange-d); color: var(--orange); }
.badge-complete   { background: var(--green-d);  color: var(--green); }
.badge-lost       { background: var(--red-d);    color: var(--red); }
.badge-draft      { background: var(--bg4);      color: var(--text3); }
/* Client (production) pipeline */
.badge-client_intake    { background: rgba(20,184,166,0.18); color: #2dd4bf; }
.badge-contract_signed  { background: var(--green-d);  color: var(--green); }
.badge-pre_production   { background: var(--purple-d); color: var(--purple); }
.badge-permit_pulled    { background: var(--blue-d);   color: var(--blue); }
.badge-ordered_material { background: var(--purple-d); color: var(--purple); }
.badge-job_scheduled    { background: var(--blue-d);   color: #60a5fa; }
.badge-waiting_on       { background: var(--yellow-d); color: var(--yellow); }
.badge-final_payment    { background: var(--orange-d); color: var(--orange); }
.badge-job_completed    { background: var(--green-d);  color: var(--green); }
.badge-job_lost         { background: var(--red-d);    color: var(--red); }
.badge-sent       { background: var(--blue-d);   color: var(--blue); }
.badge-rejected   { background: var(--red-d);    color: var(--red); }
.badge-expired    { background: var(--bg4);      color: var(--text3); }

/* ── Pipeline Board ────────────────────────────────────────────────────── */
/* Fixed-height board: columns scroll internally so the horizontal scrollbar
   stays at the bottom of the viewport (always reachable) even when one column
   has many cards. */
.pipeline { display: flex; gap: 12px; padding: 0 28px 18px; overflow-x: auto; height: calc(100vh - 150px); min-height: 380px; }
.pipeline-col { max-height: 100%; }
.pipeline-col { width: 220px; flex-shrink: 0; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r2); display: flex; flex-direction: column; }
.pipeline-col-hdr { padding: 12px 14px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
.pipeline-col-title { font-size: 12.5px; font-weight: 600; color: var(--text); }
.pipeline-col-count { font-size: 11px; color: var(--text3); background: var(--bg3); border-radius: 10px; padding: 2px 7px; }
/* Custom pipeline columns (admin): delete x in the header + a ghost "+ Add" column */
.pcol-del { background: none; border: none; color: var(--text3); cursor: pointer; font-size: 12px; line-height: 1; padding: 2px 5px; border-radius: 6px; }
.pcol-del:hover { background: var(--red-d, rgba(239,68,68,0.10)); color: var(--red, #dc2626); }
.pipeline-col.pcol-add { width: 200px; background: transparent; border: 1.5px dashed var(--bord2); cursor: pointer; }
.pipeline-col.pcol-add:hover { border-color: var(--accent); background: var(--accent-d); }
.pcol-add-inner { display: flex; align-items: center; justify-content: center; width: 100%; min-height: 120px; color: var(--accent); font-weight: 700; font-size: 13px; }
.pipeline-cards { flex: 1; min-height: 0; padding: 10px; display: flex; flex-direction: column; gap: 8px; overflow-y: auto; }
.pipeline-card { background: var(--bg3); border: 1px solid var(--bord2); border-radius: var(--r); padding: 10px 12px; cursor: pointer; transition: var(--trans); }
.pipeline-card:hover { border-color: var(--green); }
.pipeline-card .pc-name { font-size: 13px; font-weight: 500; margin-bottom: 3px; }
.pipeline-card .pc-addr { font-size: 12px; color: var(--text2); margin-bottom: 6px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pipeline-card .pc-meta { display: flex; justify-content: space-between; align-items: center; }
.pipeline-card .pc-rep { font-size: 11px; color: var(--text3); }
.pipeline-card .pc-val { font-size: 12px; font-weight: 600; color: var(--green); }

/* ── Estimator Layout ──────────────────────────────────────────────────── */
.estimator-layout { display: flex; height: calc(100vh - 52px); }
.est-sidebar { width: 320px; background: var(--bg1); border-right: 1px solid var(--border); overflow-y: auto; display: flex; flex-direction: column; flex-shrink: 0; }
.est-sidebar::-webkit-scrollbar { width: 4px; }
.est-map { flex: 1; position: relative; }
.est-results { width: 280px; background: var(--bg1); border-left: 1px solid var(--border); overflow-y: auto; flex-shrink: 0; }
.est-results::-webkit-scrollbar { width: 4px; }

/* Estimator sections */
.est-block { padding: 14px 16px; border-bottom: 1px solid var(--border); }
.est-block-title { font-size: 10.5px; font-weight: 600; letter-spacing: 0.7px; text-transform: uppercase; color: var(--text3); margin-bottom: 10px; display: flex; align-items: center; justify-content: space-between; }
.est-block-title span.toggle { cursor: pointer; color: var(--blue); font-size: 11px; letter-spacing: 0; text-transform: none; font-weight: 400; }

/* Pitch grid */
.pitch-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 5px; }
.pitch-btn { display: flex; flex-direction: column; align-items: center; padding: 6px 4px; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r); cursor: pointer; transition: var(--trans); text-align: center; }
.pitch-btn:hover { background: var(--bg4); }
.pitch-btn.sel { background: var(--green-d); border-color: rgba(34,197,94,0.35); }
.pitch-btn .pv { font-size: 12px; font-weight: 500; color: var(--text); }
.pitch-btn .pf { font-size: 9.5px; color: var(--text3); }
.pitch-btn.sel .pv { color: var(--green); }

/* Material select */
.mat-btn { display: flex; justify-content: space-between; align-items: center; padding: 8px 10px; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r); cursor: pointer; margin-bottom: 5px; transition: var(--trans); }
.mat-btn:hover { background: var(--bg4); }
.mat-btn.sel { background: var(--green-d); border-color: rgba(34,197,94,0.3); }
.mat-btn .mn { font-size: 13px; font-weight: 500; color: var(--text); }
.mat-btn .mp { font-size: 11px; color: var(--text3); font-family: 'JetBrains Mono', monospace; }

/* Map area */
.map-search-overlay { position: absolute; top: 12px; left: 50%; transform: translateX(-50%); z-index: 20; display: flex; gap: 6px; width: 480px; max-width: calc(100% - 24px); }
.map-search-inner { flex: 1; position: relative; background: rgba(10,15,26,0.92); border: 1px solid var(--bord2); border-radius: var(--r); display: flex; align-items: center; }
.map-search-inner svg { position: absolute; left: 10px; width: 15px; height: 15px; color: var(--text3); }
.map-search-inner input { flex: 1; padding: 9px 10px 9px 32px; background: transparent; border: none; color: var(--text); font-family: 'Inter',sans-serif; font-size: 13.5px; outline: none; }
.map-search-inner input::placeholder { color: var(--text3); }
.map-go-btn { padding: 9px 16px; background: var(--green2); color: #fff; border: none; border-radius: var(--r); font-family: 'Inter',sans-serif; font-size: 13px; font-weight: 500; cursor: pointer; }
.map-go-btn:hover { background: var(--green); }
.ac-dropdown { position: absolute; top: calc(100% + 4px); left: 0; right: 0; background: var(--bg3); border: 1px solid var(--bord2); border-radius: var(--r); overflow: hidden; z-index: 9999; box-shadow: var(--shadow); }
.ac-item { padding: 9px 13px; font-size: 13px; color: var(--text2); cursor: pointer; border-bottom: 1px solid var(--border); }
.ac-item:last-child { border-bottom: none; }
.ac-item:hover { background: var(--bg4); color: var(--text); }
.map-status-bar { position: absolute; bottom: 50px; left: 50%; transform: translateX(-50%); background: rgba(10,15,26,0.88); border: 1px solid var(--bord2); border-radius: 20px; padding: 6px 16px; font-size: 12.5px; color: var(--text2); pointer-events: none; z-index: 20; white-space: nowrap; }
.map-coords { position: absolute; bottom: 14px; right: 14px; font-family: 'JetBrains Mono',monospace; font-size: 10.5px; color: var(--text3); background: rgba(10,15,26,0.7); padding: 3px 8px; border-radius: 5px; pointer-events: none; z-index: 10; }
.map-tools { position: absolute; top: 12px; left: 12px; display: flex; flex-direction: column; align-items: flex-start; gap: 5px; z-index: 20; }
.map-tool-btn { width: 34px; height: 34px; background: rgba(10,15,26,0.88); border: 1px solid var(--bord2); border-radius: var(--r); color: var(--text2); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: var(--trans); }
.map-tool-draw, .map-tool-pan, .map-tool-measure { width: auto; gap: 6px; padding: 0 12px; font-size: 12px; font-weight: 600; letter-spacing: 0.2px; }
.map-tool-btn:hover { background: var(--bg3); color: var(--text); }
.map-tool-btn.sel { background: var(--green-d); color: var(--green); border-color: rgba(34,197,94,0.35); }
.map-tool-btn svg { width: 16px; height: 16px; }

/* Draw is the key action - keep it prominent (bright green) at all times, and
   make the active state unmistakable with a white ring + glow. */
.map-tool-draw { background: #16a34a; color: #fff; border-color: #16a34a; font-weight: 700;
  box-shadow: 0 2px 8px rgba(22,163,74,0.45); }
.map-tool-draw:hover { background: #22c55e; color: #fff; border-color: #22c55e; }
.map-tool-draw.sel { background: #15803d; color: #fff; border-color: #fff;
  box-shadow: 0 0 0 2px rgba(255,255,255,0.9), 0 3px 12px rgba(22,163,74,0.65); }

/* Section list */
.section-item { display: flex; align-items: center; gap: 8px; padding: 7px 10px; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r); margin-bottom: 5px; cursor: pointer; transition: var(--trans); }
.section-item:hover { background: var(--bg4); }
.section-item.sel { border-color: var(--blue); background: var(--blue-d); }
.sec-dot { width: 10px; height: 10px; border-radius: 3px; flex-shrink: 0; }
.sec-info { flex: 1; min-width: 0; }
.sec-name { font-size: 12.5px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sec-area { font-size: 11px; color: var(--text3); font-family: 'JetBrains Mono', monospace; }
.sec-del { width: 22px; height: 22px; flex-shrink: 0; background: transparent; border: none; color: var(--text3); cursor: pointer; border-radius: 5px; display: flex; align-items: center; justify-content: center; transition: var(--trans); }
.sec-del:hover { background: var(--red-d); color: var(--red); }
.sec-del svg { width: 12px; height: 12px; }

/* Results panel */
.result-card { padding: 12px 14px; border-radius: var(--r2); margin-bottom: 8px; }
.result-card.green  { background: var(--green-d);  border: 1px solid rgba(34,197,94,0.25); }
.result-card.orange { background: var(--orange-d); border: 1px solid rgba(249,115,22,0.25); }
.result-card.blue   { background: var(--blue-d);   border: 1px solid rgba(59,130,246,0.25); }
.result-card.plain  { background: var(--bg3); border: 1px solid var(--border); }
/* Highlighted key number (Actual Area) - light-yellow box so the rep spots the correct evaluated figure (Mike) */
.result-card.highlight { background: rgba(250,204,21,0.16); border: 1.5px solid rgba(250,204,21,0.65); box-shadow: 0 0 0 1px rgba(250,204,21,0.15); }
.rl { font-size: 10.5px; color: var(--text3); margin-bottom: 3px; }
.result-card.green  .rl { color: rgba(34,197,94,0.7); }
.result-card.orange .rl { color: rgba(249,115,22,0.7); }
.result-card.blue   .rl { color: rgba(59,130,246,0.7); }
.rv { font-size: 22px; font-weight: 700; letter-spacing: -0.4px; line-height: 1.1; }
.result-card.green  .rv { color: var(--green); }
.result-card.orange .rv { color: var(--orange); }
.result-card.blue   .rv { color: var(--blue); }
.result-card.plain  .rv { color: var(--text); font-size: 16px; }
.result-card.highlight .rl { color: #eab308; font-weight: 600; }
.result-card.highlight .rv { color: #fde047; font-size: 18px; }
.ru { font-size: 11px; color: var(--text3); margin-top: 2px; }
.res-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 8px; }
.breakdown { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r); padding: 10px 12px; }
.bd-row { display: flex; justify-content: space-between; padding: 4px 0; border-bottom: 1px solid var(--border); font-size: 12px; }
.bd-row:last-child { border-bottom: none; padding-top: 8px; border-top: 1px solid var(--bord2); }
.bd-row span:first-child { color: var(--text2); }
.bd-row span:last-child { color: var(--text); font-family: 'JetBrains Mono', monospace; }
.bd-row.total span { color: var(--green) !important; font-weight: 600; }
.margin-bar { height: 8px; background: var(--bg4); border-radius: 4px; overflow: hidden; margin: 6px 0 3px; }
.margin-fill { height: 100%; background: var(--green); border-radius: 4px; transition: width 0.4s; }
.margin-fill.warn { background: var(--yellow); }
.margin-fill.bad  { background: var(--red); }

/* ── Photos ────────────────────────────────────────────────────────────── */
.photos-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px; padding: 14px; }
/* Photo phase sections (Before Build / During-After Build) on the customer profile */
.photo-section { border-top: 1px solid var(--border); }
.photo-section:first-of-type { border-top: none; }
.photo-section-hdr { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 12px 16px 0; }
.photo-section-title { font-size: 13px; font-weight: 600; color: var(--text2); }
.photo-section .empty-state { padding: 12px 16px 16px; }
.photo-section .photos-grid { padding: 12px 16px 16px; }
.photo-thumb { position: relative; border-radius: var(--r); overflow: hidden; background: var(--bg3); aspect-ratio: 1; cursor: pointer; }
.photo-thumb img { width: 100%; height: 100%; object-fit: cover; cursor: zoom-in; }

/* Full-screen image viewer (click a photo) - zoom + pan */
.img-lightbox { position: fixed; inset: 0; z-index: 2000; background: rgba(0,0,0,0.9); overflow: hidden; animation: rp-lb-in .12s ease; }
.img-lightbox.hidden { display: none; }
@keyframes rp-lb-in { from { opacity: 0; } to { opacity: 1; } }
.img-lightbox .lb-stage { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.img-lightbox .lb-img { width: 94vw; height: 88vh; object-fit: contain; transform-origin: center center; will-change: transform; user-select: none; -webkit-user-drag: none; }
.img-lightbox .lb-toolbar { position: absolute; top: 16px; left: 50%; transform: translateX(-50%); display: flex; align-items: center; gap: 5px; background: rgba(20,20,20,0.72); backdrop-filter: blur(8px); border: 1px solid rgba(255,255,255,0.14); border-radius: 12px; padding: 6px; z-index: 2; }
.img-lightbox .lb-tool { width: 36px; height: 36px; border: none; background: rgba(255,255,255,0.08); color: #fff; border-radius: 8px; font-size: 19px; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .12s; }
.img-lightbox .lb-tool:hover { background: rgba(255,255,255,0.22); }
.img-lightbox .lb-zoom { color: #fff; font-size: 12px; min-width: 48px; text-align: center; font-variant-numeric: tabular-nums; }
.img-lightbox .lb-nav { position: absolute; top: 50%; transform: translateY(-50%); z-index: 2; width: 52px; height: 72px; border: none; background: rgba(20,20,20,0.55); color: #fff; font-size: 40px; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center; border-radius: 12px; transition: background .12s; }
.img-lightbox .lb-nav:hover { background: rgba(255,255,255,0.22); }
.img-lightbox .lb-prev { left: 14px; }
.img-lightbox .lb-next { right: 14px; }
@media (max-width: 640px) { .img-lightbox .lb-nav { width: 42px; height: 60px; font-size: 30px; } }
.photo-thumb .ph-del { position: absolute; top: 6px; right: 6px; width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; background: rgba(15,23,42,0.62); border: 1px solid rgba(255,255,255,0.18); border-radius: 7px; color: #fff; cursor: pointer; opacity: 0; transition: opacity 0.16s ease, background 0.16s ease; font-size: 12px; line-height: 1; z-index: 3; }
.photo-thumb .ph-del:hover { background: rgba(220,38,38,0.92); }
.photo-thumb:hover .ph-del, .photo-thumb:focus-within .ph-del { opacity: 1; }
.photo-thumb .ph-cat { position: absolute; top: 5px; left: 5px; background: rgba(0,0,0,0.68); color: #fff; font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; padding: 2px 7px; border-radius: 5px; pointer-events: none; }
.photo-thumb .ph-cat-damage { background: rgba(239,68,68,0.92); }
.photo-thumb .ph-cat-before { background: rgba(100,116,139,0.92); }
.photo-thumb .ph-cat-after  { background: rgba(34,197,94,0.92); }
.photo-thumb .ph-cat-measurement { background: rgba(37,99,235,0.92); }

/* Annotate (draw) button - sits left of the delete button */
/* Hover dim + centered "Annotate" pill so it's obvious a photo is editable */
.photo-thumb .ph-overlay { position: absolute; inset: 0; background: linear-gradient(rgba(15,23,42,0.05), rgba(15,23,42,0.34)); opacity: 0; transition: opacity 0.16s ease; pointer-events: none; z-index: 1; }
.photo-thumb:hover .ph-overlay, .photo-thumb:focus-within .ph-overlay { opacity: 1; }
.photo-thumb .ph-edit-pill { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -46%); display: inline-flex; align-items: center; gap: 6px; background: rgba(15,23,42,0.82); border: 1px solid rgba(255,255,255,0.22); color: #fff; font-size: 12.5px; font-weight: 600; padding: 8px 15px; border-radius: 999px; cursor: pointer; opacity: 0; transition: opacity 0.16s ease, transform 0.16s ease, background 0.16s ease; white-space: nowrap; z-index: 2; -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px); }
.photo-thumb .ph-edit-pill svg { display: block; }
.photo-thumb:hover .ph-edit-pill, .photo-thumb:focus-within .ph-edit-pill { opacity: 1; transform: translate(-50%, -50%); }
.photo-thumb .ph-edit-pill:hover { background: var(--accent, #2563eb); border-color: var(--accent, #2563eb); }

/* Touch devices have no hover: keep the affordance gently visible */
@media (hover: none) {
  .photo-thumb .ph-overlay { opacity: 1; background: linear-gradient(rgba(15,23,42,0), rgba(15,23,42,0.22)); }
  .photo-thumb .ph-edit-pill { opacity: .96; transform: translate(-50%, -50%); padding: 6px 13px; font-size: 12px; }
  .photo-thumb .ph-del { opacity: .9; }
}
/* Inline caption strip across the bottom of a thumbnail */
.photo-thumb .ph-caption { position: absolute; left: 0; right: 0; bottom: 0; background: linear-gradient(transparent, rgba(0,0,0,0.78)); color: #fff; font-size: 11px; padding: 14px 7px 5px; cursor: text; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.photo-thumb .ph-caption-empty { opacity: 0; transition: opacity 0.15s; font-style: italic; }
.photo-thumb:hover .ph-caption-empty { opacity: .85; }

/* ── Photo annotator (draw-on-photo editor) ───────────────────────────────────
   Self-contained dark chrome - intentionally theme-independent so it looks the
   same in the app's light OR dark theme (a markup surface, like Preview/Acrobat). */
.pa-overlay { position: fixed; inset: 0; z-index: 4000; background: #0d1014; display: flex; flex-direction: column; color: #e7ebf0; }
.pa-bar { display: flex; flex-wrap: wrap; align-items: center; gap: 10px 14px; padding: 9px 16px; background: #181c23; border-bottom: 1px solid rgba(255,255,255,0.08); box-shadow: 0 2px 12px rgba(0,0,0,0.4); }
.pa-group { display: flex; align-items: center; gap: 4px; }
.pa-sep { width: 1px; align-self: stretch; min-height: 32px; background: rgba(255,255,255,0.1); margin: 0 4px; }
.pa-actions { margin-left: auto; gap: 8px; }

.pa-tool { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; width: 52px; height: 46px; padding: 4px; border: 1px solid transparent; border-radius: 9px; background: transparent; color: #9aa4b2; cursor: pointer; transition: background .12s, color .12s; }
.pa-tool svg { width: 20px; height: 20px; }
.pa-tool .pa-tool-lbl { font-size: 9px; font-weight: 600; letter-spacing: .4px; text-transform: uppercase; }
.pa-tool:hover { background: rgba(255,255,255,0.07); color: #fff; }
.pa-tool.active { background: #2f6fed; color: #fff; box-shadow: 0 2px 8px rgba(47,111,237,0.4); }

.pa-color { width: 26px; height: 26px; border-radius: 50%; background: var(--sw); border: 2px solid rgba(255,255,255,0.2); cursor: pointer; padding: 0; transition: transform .1s; }
.pa-color:hover { transform: scale(1.12); }
.pa-color.active { border-color: #fff; box-shadow: 0 0 0 2px #2f6fed; }
.pa-width-wrap { display: flex; align-items: center; gap: 8px; margin-left: 10px; }
.pa-width-dot { width: 14px; height: 14px; border-radius: 50%; background: #cdd4de; flex-shrink: 0; }
.pa-width { width: 100px; accent-color: #2f6fed; cursor: pointer; }

.pa-btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; border-radius: 9px; border: 1px solid rgba(255,255,255,0.16); background: rgba(255,255,255,0.06); color: #e7ebf0; cursor: pointer; font-size: 13px; font-weight: 600; transition: background .12s, border-color .12s; }
.pa-btn svg { width: 16px; height: 16px; }
.pa-btn:hover { background: rgba(255,255,255,0.12); }
.pa-btn.pa-cancel { border-color: rgba(255,255,255,0.16); }
.pa-btn.pa-cancel:hover { background: rgba(239,68,68,0.85); border-color: rgba(239,68,68,0.85); color: #fff; }
.pa-btn.pa-save { background: #16a34a; border-color: #16a34a; color: #fff; }
.pa-btn.pa-save:hover { background: #15803d; }
.pa-btn.pa-save:disabled { opacity: .6; cursor: default; }

.pa-stage { flex: 1; display: flex; align-items: center; justify-content: center; overflow: hidden; min-height: 0; padding: 10px; }
.pa-stage canvas { background: #000; box-shadow: 0 6px 40px rgba(0,0,0,0.6); cursor: crosshair; touch-action: none; max-width: 100%; max-height: 100%; }
.pa-caption-inp { margin: 0 auto 16px; width: min(560px, 90%); padding: 11px 14px; border-radius: 9px; border: 1px solid rgba(255,255,255,0.18); background: rgba(255,255,255,0.07); color: #fff; font-size: 14px; }
.pa-caption-inp::placeholder { color: rgba(255,255,255,0.45); }
.pa-caption-inp:focus { outline: none; border-color: #2f6fed; background: rgba(255,255,255,0.1); }
@media (max-width: 720px) {
  .pa-bar { gap: 8px; padding: 8px 10px; }
  .pa-sep { display: none; }
  .pa-actions { margin-left: 0; width: 100%; justify-content: flex-end; }
  .pa-tool { width: 44px; height: 42px; }
  .pa-tool .pa-tool-lbl { font-size: 8px; }
}

/* ── Documents card ─────────────────────────────────────────────────────── */
.doc-list { padding: 6px 8px; }
.doc-row { display: flex; align-items: center; gap: 12px; padding: 9px 10px; border-radius: 9px; transition: background .12s; }
.doc-row:hover { background: var(--bg3); }
.doc-row + .doc-row { border-top: 1px solid var(--border); }
.doc-ext { flex-shrink: 0; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; border-radius: 8px; font-size: 10px; font-weight: 700; letter-spacing: .3px; color: #fff; }
.doc-ext-pdf { background: #ef4444; }
.doc-ext-img { background: #8b5cf6; }
.doc-ext-doc { background: #2563eb; }
.doc-ext-xls { background: #16a34a; }
.doc-ext-gen { background: #64748b; }
.doc-meta { min-width: 0; flex: 1; }
.doc-name { display: block; font-size: 13.5px; font-weight: 500; color: var(--text); text-decoration: none; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.doc-name:hover { color: var(--green2); text-decoration: underline; }
.doc-sub { display: flex; align-items: center; gap: 8px; font-size: 11.5px; color: var(--text3); margin-top: 2px; }
.doc-share { display: inline-flex; align-items: center; gap: 4px; cursor: pointer; user-select: none; padding: 1px 7px; border-radius: 999px; background: var(--bg2); border: 1px solid var(--border); font-weight: 600; color: var(--text2); }
.doc-share input { accent-color: var(--green); cursor: pointer; margin: 0; }
.doc-share:has(input:checked) { background: var(--green-d); border-color: rgba(34,197,94,0.35); color: var(--green); }
.doc-cat { text-transform: uppercase; letter-spacing: .4px; color: var(--green2); background: rgba(34,197,94,0.16); border: 1px solid rgba(34,197,94,0.35); padding: 2px 8px; border-radius: 6px; font-weight: 700; font-size: 9.5px; }
.doc-cat-general { color: var(--text2); background: var(--bg3); border-color: var(--bord2); }
.doc-actions { display: flex; gap: 4px; flex-shrink: 0; }
.doc-btn { width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--bord2); background: var(--bg2); border-radius: 7px; color: var(--text2); cursor: pointer; text-decoration: none; transition: var(--trans); }
.doc-btn:hover { color: var(--text); border-color: var(--green2); }
.doc-btn.doc-del:hover { color: var(--red); border-color: var(--red); }

/* Upload modal drop zone */
.doc-drop { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 26px 18px; border: 1.5px dashed var(--bord2); border-radius: 12px; cursor: pointer; color: var(--text2); text-align: center; transition: var(--trans); }
.doc-drop:hover, .doc-drop.drag-over { border-color: var(--green2); background: rgba(34,197,94,0.06); color: var(--text); }
.doc-drop svg { color: var(--green2); }
.doc-drop b { color: var(--text); }
.doc-drop-hint { font-size: 11.5px; color: var(--text3); }
.doc-picked { margin-top: 10px; display: flex; flex-direction: column; gap: 5px; }
.doc-picked-item { display: flex; justify-content: space-between; font-size: 12.5px; color: var(--text); background: var(--bg3); padding: 6px 10px; border-radius: 7px; }
.doc-picked-item span { color: var(--text3); }

/* ── Tasks / reminders ──────────────────────────────────────────────────── */
.user-av { position: relative; }
.task-badge { position: absolute; top: -5px; right: -5px; min-width: 17px; height: 17px; padding: 0 4px; border-radius: 9px; background: var(--green2); color: #fff; font-size: 10px; font-weight: 700; display: flex; align-items: center; justify-content: center; line-height: 1; box-shadow: 0 0 0 2px rgba(0,0,0,0.35); }
.task-badge.has-overdue { background: var(--red); }
.task-badge.hidden { display: none; }
/* Sidebar count pill (e.g. pending appointment requests on Calendar) */
.sb-badge { display: inline-flex; align-items: center; justify-content: center; min-width: 17px; height: 17px; padding: 0 5px; margin-left: 7px; border-radius: 9px; background: var(--orange); color: #fff; font-size: 10px; font-weight: 700; line-height: 1; }
.sb-badge.hidden { display: none; }
.sm-task-count { display: inline-flex; align-items: center; justify-content: center; margin-left: 8px; min-width: 18px; height: 18px; padding: 0 5px; border-radius: 9px; background: var(--green2); color: #fff; font-size: 11px; font-weight: 700; }
.sm-task-count.has-overdue { background: var(--red); }
.sm-task-count.hidden { display: none; }

.task-list { padding: 5px 8px; }
.task-row { display: flex; align-items: flex-start; gap: 10px; padding: 8px; border-radius: 8px; transition: background .12s; }
.task-row:hover { background: var(--bg3); }
.task-row + .task-row { border-top: 1px solid var(--border); }
.task-check { flex-shrink: 0; width: 20px; height: 20px; margin-top: 1px; border: 1.5px solid var(--bord2); border-radius: 6px; background: transparent; color: transparent; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: var(--trans); }
.task-check:hover { border-color: var(--green2); }
.task-check.on { background: var(--green2); border-color: var(--green2); color: #fff; }
.task-main { flex: 1; min-width: 0; cursor: pointer; }
.task-title { font-size: 13.5px; font-weight: 500; color: var(--text); display: flex; align-items: center; gap: 6px; }
.task-row.is-done .task-title { text-decoration: line-through; color: var(--text3); }
.task-sub { display: flex; align-items: center; gap: 8px; margin-top: 3px; flex-wrap: wrap; }
.task-flag { color: var(--red); font-weight: 800; }
.task-due { font-size: 11px; font-weight: 600; padding: 1px 8px; border-radius: 12px; background: var(--bg3); color: var(--text2); }
.task-due.due-over { background: var(--red-d); color: var(--red); }
.task-due.due-today { background: rgba(245,158,11,0.16); color: #f59e0b; }
.task-ctx { font-size: 11px; color: var(--text3); }
.task-del { flex-shrink: 0; width: 28px; height: 28px; border: none; background: transparent; color: var(--text3); border-radius: 6px; cursor: pointer; opacity: 0; display: flex; align-items: center; justify-content: center; transition: var(--trans); }
.task-row:hover .task-del { opacity: 1; }
.task-del:hover { color: var(--red); background: var(--red-d); }

/* My Tasks page - kanban-style board (mirrors Projects) */
.tasks-board { padding-top: 4px; }
.tasks-board .pipeline-col { width: auto; flex: 1 1 0; min-width: 220px; }
.tasks-board .pipeline-col.drag-over .pipeline-cards { background: rgba(34,197,94,0.07); border-radius: 8px; }
.pipeline-col-title.is-over  { color: var(--red); }
.pipeline-col-title.is-today { color: #f59e0b; }
.pipeline-col-title.is-done  { color: var(--text3); }
.task-kcard { position: relative; display: flex; align-items: flex-start; gap: 10px; background: var(--bg3); border: 1px solid var(--bord2); border-left: 3px solid var(--bord2); border-radius: 9px; padding: 10px 11px; cursor: pointer; transition: var(--trans); }
.task-kcard:active { cursor: grabbing; }
.task-kcard.dragging { opacity: 0.35; }
.task-drag-clone { position: fixed; z-index: 3000; pointer-events: none; opacity: 0.96; margin: 0; box-shadow: 0 12px 32px rgba(0,0,0,0.35); transform: rotate(1.5deg); }
.task-kcard.is-done .task-title { text-decoration: line-through; color: var(--text3); }
.task-kcard:hover { border-color: var(--green); box-shadow: 0 4px 12px rgba(0,0,0,0.10); }
.task-kcard.u-over  { border-left-color: var(--red); }
.task-kcard.u-today { border-left-color: #f59e0b; }
.task-kcard.u-soon  { border-left-color: var(--green2); }
.task-kcard.u-none  { border-left-color: var(--bord2); }
.task-kcard.u-done  { border-left-color: var(--green2); }
.task-kcard .tk-body { flex: 1; min-width: 0; }
.task-kcard .task-title { display: block; font-size: 13px; font-weight: 500; color: var(--text); line-height: 1.35; word-break: break-word; }
.task-kcard .task-title .task-flag { display: inline; margin-right: 4px; }
.task-kcard .tk-meta { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; margin-top: 7px; }
.task-kcard .task-check { width: 18px; height: 18px; margin-top: 1px; }
.task-kcard .task-del { position: absolute; top: 6px; right: 6px; width: 24px; height: 24px; }
.task-kcard:hover .task-del { opacity: 1; }
.tk-empty { font-size: 11.5px; color: var(--text3); text-align: center; padding: 16px 8px; }

.tasks-empty { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 6px; margin: 7vh auto 0; max-width: 400px; color: var(--text2); }
.tasks-empty-icon { width: 68px; height: 68px; border-radius: 50%; background: rgba(34,197,94,0.12); color: var(--green2); display: flex; align-items: center; justify-content: center; margin-bottom: 10px; }
.tasks-empty h3 { font-size: 18px; font-weight: 600; color: var(--text); }
.tasks-empty p { font-size: 13.5px; line-height: 1.55; margin-bottom: 14px; }
.file-drop-zone { border: 1.5px dashed var(--bord2); border-radius: var(--r); padding: 24px; text-align: center; cursor: pointer; color: var(--text3); font-size: 13px; transition: var(--trans); display: flex; flex-direction: column; align-items: center; gap: 8px; }
.file-drop-zone:hover { border-color: var(--green); color: var(--green); }
.file-drop-zone svg { width: 24px; height: 24px; }
.photo-preview-list { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.photo-preview-item { width: 70px; height: 70px; border-radius: var(--r); overflow: hidden; position: relative; }
.photo-preview-item img { width: 100%; height: 100%; object-fit: cover; }
.photo-progress { margin-top: 14px; }
.photo-progress.hidden { display: none; }
.photo-progress-label { display: flex; justify-content: space-between; font-size: 12.5px; color: var(--text2); margin-bottom: 6px; }
.photo-progress-bar { height: 7px; background: var(--bg2); border-radius: 5px; overflow: hidden; }
.photo-progress-fill { height: 100%; width: 0; background: var(--green); border-radius: 5px; transition: width 0.25s ease; }

/* ── CRM Notes ─────────────────────────────────────────────────────────── */
.note-item { padding: 12px; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r); margin-bottom: 8px; }
.note-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.note-type-badge { font-size: 10px; padding: 2px 7px; border-radius: 10px; font-weight: 500; }
.note-type-note  { background: var(--blue-d);   color: var(--blue); }
.note-type-call  { background: var(--green-d);  color: var(--green); }
.note-type-email { background: var(--purple-d); color: var(--purple); }
.note-type-visit { background: var(--orange-d); color: var(--orange); }
.note-who  { font-size: 12px; color: var(--text2); }
.note-when { font-size: 11px; color: var(--text3); margin-left: auto; }
.note-del { background: none; border: none; color: var(--text3); font-size: 17px; line-height: 1; cursor: pointer; padding: 0 2px; opacity: 0.5; transition: var(--trans); }
.note-del:hover { color: var(--red); opacity: 1; }
.note-body { font-size: 13px; color: var(--text); line-height: 1.6; overflow-wrap: anywhere; word-break: break-word; }

/* ── Modals ────────────────────────────────────────────────────────────── */
.modal-back { position: fixed; inset: 0; background: rgba(0,0,0,0.65); backdrop-filter: blur(6px); z-index: 8000; display: flex; align-items: center; justify-content: center; padding: 16px; }
/* Google Places autocomplete dropdown - must sit above the modal (z 8000). */
.pac-container { z-index: 9000; border-radius: 10px; border: 1px solid var(--bord2); box-shadow: var(--shadow); background: var(--bg3); margin-top: 3px; font-family: inherit; }
.pac-item { padding: 7px 12px; font-size: 13px; color: var(--text2); border-top: 1px solid var(--border); cursor: pointer; }
.pac-item:hover, .pac-item-selected { background: var(--bg2); }
.pac-item-query { color: var(--text); font-size: 13px; }
.pac-matched { color: var(--accent, var(--blue, #2563eb)); }
.pac-icon { display: none; }
.pac-logo:after { opacity: 0.5; }
.modal { background: var(--bg2); border: 1px solid var(--bord2); border-radius: var(--r3); padding: 0; width: 520px; max-width: 100%; box-shadow: var(--shadow); max-height: 90vh; display: flex; flex-direction: column; }
.modal.lg  { width: 680px; }
.modal.xl  { width: 800px; }
.modal.sm  { width: 400px; }
.modal-hdr { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.modal-hdr h3 { font-size: 16px; font-weight: 600; }
.btn-close { background: none; border: none; color: var(--text3); cursor: pointer; font-size: 18px; line-height: 1; padding: 4px; }
.btn-close:hover { color: var(--text); }
.modal-body { padding: 20px 22px; overflow-y: auto; flex: 1; }
.modal-ftr { display: flex; gap: 8px; justify-content: flex-end; padding: 14px 22px; border-top: 1px solid var(--border); flex-shrink: 0; }

/* Bulk-send modal (email/SMS to a list) - clean selectable cards.
   !important on display beats the generic ".field label { display:block }". */
.bs-card { display: flex !important; flex-direction: column; align-items: center; justify-content: center; gap: 7px;
  padding: 15px 10px; margin: 0; border: 1.5px solid var(--bord2); border-radius: 12px; cursor: pointer;
  transition: var(--trans); color: var(--text2); position: relative; }
.bs-card svg { width: 24px; height: 24px; }
.bs-card span { font-size: 13px; font-weight: 600; }
.bs-card input { position: absolute; opacity: 0; pointer-events: none; }
.bs-card:hover { border-color: var(--accent); color: var(--text); }
.bs-card:has(:checked) { border-color: var(--accent); background: rgba(124,58,237,0.08); color: var(--accent); box-shadow: inset 0 0 0 1px var(--accent); }
.bs-opt { display: flex !important; align-items: center; gap: 8px; flex-wrap: nowrap; margin: 0; padding: 10px 13px;
  border: 1.5px solid var(--bord2); border-radius: 10px; cursor: pointer; font-size: 13.5px; color: var(--text); transition: var(--trans); }
.bs-opt:hover { border-color: var(--accent); }
.bs-opt:has(:checked) { border-color: var(--accent); background: rgba(124,58,237,0.06); }
.bs-opt > span { flex-shrink: 0; }
.bs-opt input[type=radio] { accent-color: var(--accent); width: 16px; height: 16px; flex-shrink: 0; margin: 0 2px 0 0; }
/* more specific than ".field input" so it doesn't get stretched to 100% width */
.bs-opt input.bs-num { flex: 0 0 64px; width: 64px; padding: 6px 8px; border: 1px solid var(--bord2);
  border-radius: 7px; background: var(--bg2); color: var(--text); font-size: 13px; text-align: center; }
.bs-preview { font-size: 12.5px; color: var(--text2); background: var(--bg3); border-radius: 9px; padding: 11px 13px; margin-top: 4px; line-height: 1.55; }

/* ── Admin Panels ──────────────────────────────────────────────────────── */
.admin-layout { display: grid; grid-template-columns: 1fr 2fr; gap: 20px; padding: 0 28px 28px; }
.presets-table td:last-child { text-align: right; }

/* ── Reports ───────────────────────────────────────────────────────────── */
.chart-placeholder { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--r2); display: flex; align-items: center; justify-content: center; min-height: 200px; color: var(--text3); font-size: 13px; }

/* ── Tabs ──────────────────────────────────────────────────────────────── */
.tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--border); padding: 0 28px; margin-bottom: 20px; overflow-x: auto; }
.tab-btn { padding: 10px 16px; background: none; border: none; border-bottom: 2px solid transparent; color: var(--text2); font-family: 'Inter',sans-serif; font-size: 13.5px; cursor: pointer; white-space: nowrap; transition: var(--trans); }
.tab-btn:hover { color: var(--text); }
.tab-btn.active { color: var(--green); border-bottom-color: var(--green); font-weight: 500; }

/* ── Toast ─────────────────────────────────────────────────────────────── */
.toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(10px);
  background: var(--bg3); border: 1px solid var(--bord2); border-radius: 24px;
  padding: 9px 20px; font-size: 13px; color: var(--text); z-index: 99999;
  pointer-events: none; opacity: 0; transition: all 0.25s; white-space: nowrap; box-shadow: var(--shadow);
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.success { border-color: rgba(34,197,94,0.4); color: var(--green); }
.toast.error   { border-color: rgba(239,68,68,0.4); color: var(--red); }

/* ── Misc ──────────────────────────────────────────────────────────────── */
.empty-state { text-align: center; padding: 48px 24px; color: var(--text3); }
.empty-state svg { width: 40px; height: 40px; margin-bottom: 12px; }
.empty-state p { font-size: 14px; margin-bottom: 16px; }
/* Shared transient-state classes (were inlined per view; .loading was even used
   undefined in a few places). Use class="loading" / class="error-state". */
.loading     { text-align: center; padding: 40px; color: var(--text3); font-size: 14px; }
.error-state { text-align: center; padding: 28px; color: var(--red);   font-size: 14px; }
.section-divider { height: 1px; background: var(--border); margin: 16px 0; }
.tag { display: inline-flex; padding: 2px 8px; border-radius: 10px; font-size: 11px; background: var(--bg4); color: var(--text2); margin: 2px; }
.search-bar { display: flex; gap: 8px; padding: 0 28px; margin-bottom: 18px; }
.search-bar input { flex: 1; max-width: 360px; padding: 8px 12px; background: var(--bg2); border: 1px solid var(--bord2); border-radius: var(--r); color: var(--text); font-family: 'Inter',sans-serif; font-size: 13.5px; outline: none; }
.search-bar input:focus { border-color: var(--green); }
.search-bar select { padding: 8px 12px; background: var(--bg2); border: 1px solid var(--bord2); border-radius: var(--r); color: var(--text); font-family: 'Inter',sans-serif; font-size: 13px; outline: none; }
.detail-layout { display: grid; grid-template-columns: 1fr 360px; gap: 20px; padding: 0 28px 28px; }
.detail-main { display: flex; flex-direction: column; gap: 16px; }
.detail-side { display: flex; flex-direction: column; gap: 16px; }
/* Project detail (MOBILE): JobNimbus-style header + contact action row + tabs */
/* Project cover / header photo (Mike 3 Jul) */
.proj-cover { position: relative; height: 180px; background-color: var(--bg3,#f1f5f9); background-size: cover; background-position: center; }
@media (min-width: 641px) { .proj-cover { height: 300px; } }
.proj-cover-actions { position: absolute; top: 10px; right: 10px; display: flex; gap: 8px; }
.proj-cover-btn { width: 36px; height: 36px; border-radius: 50%; border: 0; background: rgba(0,0,0,0.45); color: #fff; display: flex; align-items: center; justify-content: center; cursor: pointer; }
.proj-cover-btn:hover { background: rgba(0,0,0,0.62); }
.proj-cover-btn svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.proj-cover-add { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 11px; border: 0; border-bottom: 1px solid var(--border); background: var(--bg3,#f1f5f9); color: var(--text2); font-family: 'Inter',sans-serif; font-size: 12.5px; font-weight: 600; cursor: pointer; }
.proj-cover-add:hover { color: var(--accent); }
.proj-cover-add svg { width: 17px; height: 17px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.mproj-topbar { display: flex; align-items: center; gap: 10px; padding: 8px 14px; }
.mproj-back { width: 38px; height: 38px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; border-radius: 50%; background: var(--bg3); border: 1px solid var(--border); cursor: pointer; }
.mproj-back svg { width: 18px; height: 18px; fill: none; stroke: var(--text); stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; }
.mproj-title { flex: 1; text-align: center; font-size: 16px; font-weight: 700; color: var(--text); }
.mproj-edit { padding: 9px 18px; border-radius: 999px; background: var(--bg3); border: 1px solid var(--border); color: var(--accent); font-family: 'Inter',sans-serif; font-size: 14px; font-weight: 600; cursor: pointer; }
.mproj-head { padding: 6px 18px 4px; }
.mproj-status { background: none; border: none; padding: 0 0 10px; cursor: pointer; display: inline-flex; gap: 6px; align-items: center; }
.mproj-name { font-size: 26px; font-weight: 800; margin: 0 0 4px; color: var(--text); }
.mproj-sub { font-size: 14.5px; color: var(--text2); line-height: 1.5; }
.proj-actions { display: flex; gap: 10px; padding: 14px 18px 16px; }
.proj-act { flex: 1; min-width: 0; display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 13px 6px; background: var(--bg3); border: none; border-radius: 16px; color: var(--blue,#3b82f6); font-family: 'Inter',sans-serif; font-size: 13px; font-weight: 600; cursor: pointer; text-decoration: none; transition: var(--trans); }
.proj-act:hover { background: var(--bg2); }
.proj-act-i { display: inline-flex; }
.proj-act-i svg { width: 22px; height: 22px; fill: none; stroke: var(--blue,#3b82f6); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.proj-seg { margin: 0 18px 18px; }
/* JobNimbus-style collapsible section list */
.jn-list { background: var(--bg2,#fff); border: 1px solid var(--border); border-radius: 16px; overflow: hidden; box-shadow: 0 1px 3px rgba(15,23,42,0.05); }
.jn-item + .jn-item { border-top: 1px solid var(--border); }
.jn-row { display: flex; align-items: center; gap: 14px; width: 100%; padding: 15px 18px; background: none; border: none; cursor: pointer; text-align: left; font-family: 'Inter',sans-serif; transition: background 0.14s; }
.jn-row:hover { background: var(--bg3); }
.jn-row-i { flex-shrink: 0; display: inline-flex; }
.jn-row-i svg { width: 22px; height: 22px; fill: none; stroke: var(--blue,#3b82f6); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.jn-row-label { flex: 1; font-size: 15.5px; font-weight: 500; color: var(--text); }
.jn-row-count { flex-shrink: 0; min-width: 22px; text-align: center; font-size: 12px; font-weight: 700; color: var(--text2); background: var(--bg3); border-radius: 20px; padding: 2px 8px; }
.jn-chev { flex-shrink: 0; width: 18px; height: 18px; fill: none; stroke: var(--text3,#94a3b8); stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; transition: transform 0.18s; }
.jn-row.open .jn-chev { transform: rotate(90deg); }
.jn-body { padding: 4px 18px 18px; border-top: 1px solid var(--border); background: var(--bg,#f8fafc); }
.jn-body-actions { display: flex; justify-content: flex-end; gap: 8px; padding: 12px 0; }
@media (max-width: 640px) {
  .proj-actions { padding: 0 16px 14px; gap: 8px; }
  .proj-tabs { padding: 0 16px; }
  .proj-pane { padding-left: 16px !important; padding-right: 16px !important; }
  .jn-row { padding: 15px 14px; gap: 12px; }
  .jn-body { padding: 4px 14px 16px; }
}
.back-btn { display: inline-flex; align-items: center; gap: 6px; margin: 0 0 16px 28px; padding: 7px 14px 7px 10px; background: rgba(124,58,237,0.12); border: 1px solid rgba(124,58,237,0.32); border-radius: 999px; color: var(--accent); font-size: 13px; font-weight: 600; cursor: pointer; transition: all 0.18s cubic-bezier(0.4,0,0.2,1); }
.back-btn:hover { background: rgba(124,58,237,0.2); border-color: rgba(124,58,237,0.5); transform: translateX(-2px); box-shadow: 0 2px 10px rgba(124,58,237,0.25); }
.back-btn svg { width: 14px; height: 14px; }
.profit-pill { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: 20px; font-size: 12px; font-weight: 600; }
.profit-pill.good { background: var(--green-d); color: var(--green); }
.profit-pill.warn { background: var(--yellow-d); color: var(--yellow); }
.profit-pill.bad  { background: var(--red-d);   color: var(--red); }

/* ── Responsive ────────────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .stats-grid { grid-template-columns: repeat(2,1fr); }
  .est-results { width: 240px; }
}
/* Drawer backdrop: never shown on desktop (base = none); only the mobile rule
   below reveals it, and only while the drawer is open (.show). */
#sb-backdrop { display: none; }
@media (max-width: 900px) {
  #sidebar { position: fixed; top: 0; bottom: 0; left: 0; transform: translateX(-100%); z-index: 500; }
  #sidebar.open { transform: translateX(0); }
  #sb-backdrop.show { display: block; position: fixed; inset: 0; background: rgba(0,0,0,0.45); z-index: 490; }
  .mobile-header { display: flex; }
  #main-content { margin-top: 52px; }
  .estimator-layout { flex-direction: column; height: auto; }
  .est-sidebar, .est-results { width: 100%; height: auto; }
  /* flex:none so the explicit height applies - otherwise flex-basis:0% collapses
     the map to 0 in the stacked column layout and the overlays land on the
     results panel below it. */
  /* Mike: on phones the map goes to the very top, above the customer/project. */
  .est-map { flex: none; height: 55vh; min-height: 340px; order: -1; }
}
@media (max-width: 640px) {
  .page-hdr { flex-direction: column; align-items: flex-start; gap: 10px; }
  .page-hdr-actions { flex-wrap: wrap; }            /* action buttons wrap, don't overflow */
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .form-row2, .form-row3, .form-row4 { grid-template-columns: 1fr; }
  .detail-layout { grid-template-columns: 1fr; }
  .modal.lg, .modal.xl { width: calc(100vw - 16px); }
  .auth-left { display: none; }

  /* ── Estimator map (mobile) ──────────────────────────────────────────────
     Mike: the address search bar covered the Draw/Pan tools. On phones the
     search now spans the top full-width, and the tool buttons drop BELOW it as
     a compact wrapping row (instead of a tall column that ran off a 50vh map). */
  .est-map { flex: none; height: 60vh; min-height: 340px; }
  .map-search-overlay { left: 8px; right: 8px; width: auto; max-width: none; transform: none; }
  /* keep the Auto-Measure button on one line + compact so it doesn't wrap to
     two rows and squash the address field */
  .map-go-btn { white-space: nowrap; padding: 9px 13px; font-size: 12px; line-height: 1; }
  .map-search-inner input { font-size: 12.5px; padding: 8px 8px 8px 30px; }
  .map-tools {
    top: 50px; left: 8px; right: 8px;
    flex-direction: row; flex-wrap: wrap; gap: 6px;
    background: transparent;
  }
  .map-tools > div { display: none; }               /* hide the column separators in row mode */
  .map-tool-btn { box-shadow: 0 1px 4px rgba(0,0,0,0.3); }
  .map-coords { display: none; }                     /* coords readout is desktop-only clutter on phones */
}
@media print {
  #sidebar, .mobile-header, .modal-back, .btn-primary, .btn-sec { display: none !important; }
}

/* ── UX polish (additive · visual only · 2026) ──────────────────────────── */
/* Snappier, springier feel on interactive elements */
.btn-primary, .btn-sec, .btn-danger, .stat-card, .pipeline-card, .pitch-btn,
.mat-btn, .sb-link, .result-card, .tab-btn, .map-go-btn, .card {
  transition: all 0.18s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Primary buttons - purple accent gradient, depth + tactile press */
.btn-primary, .map-go-btn {
  color: #fff;
  background: linear-gradient(180deg, var(--accent), var(--accent2));
  box-shadow: 0 1px 2px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.10);
}
.btn-primary:hover, .map-go-btn:hover {
  background: linear-gradient(180deg, #8b5cf6, var(--accent));
  box-shadow: 0 6px 18px rgba(124,58,237,0.34); transform: translateY(-1px);
}
.btn-primary:active, .map-go-btn:active { transform: translateY(0) scale(0.99); box-shadow: 0 1px 2px rgba(0,0,0,0.25); }
.btn-sec:hover, .btn-danger:hover { transform: translateY(-1px); }
.btn-sec:active, .btn-danger:active { transform: translateY(0) scale(0.99); }

/* Cards lift a touch on hover - feels interactive, not flat */
.stat-card:hover { transform: translateY(-2px); box-shadow: 0 10px 26px rgba(0,0,0,0.28); }
.pipeline-card:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(0,0,0,0.25); }

/* Inputs - soft purple focus glow */
.field input:focus, .field select:focus, .field textarea:focus,
.search-bar input:focus, .map-search-inner:focus-within {
  border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-d);
}

/* Sidebar active link - left accent bar */
.sb-link.active { box-shadow: inset 3px 0 0 var(--accent); }

/* Keyboard focus ring for accessibility */
.btn-primary:focus-visible, .btn-sec:focus-visible, .sb-link:focus-visible {
  outline: 2px solid var(--accent); outline-offset: 2px;
}

/* Gentle entrance - page headers + modals pop in softly */
@keyframes rp-rise { from { opacity: 0; transform: translateY(7px); } to { opacity: 1; transform: none; } }
@keyframes rp-pop  { from { opacity: 0; transform: translateY(8px) scale(0.985); } to { opacity: 1; transform: none; } }
@keyframes rp-fade { from { opacity: 0; } to { opacity: 1; } }
.page-hdr { animation: rp-rise 0.26s ease both; }
.modal-back { animation: rp-fade 0.16s ease both; }
.modal { animation: rp-pop 0.2s cubic-bezier(0.4, 0, 0.2, 1) both; }

/* Respect users who prefer less motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .btn-primary:hover, .btn-sec:hover, .stat-card:hover, .pipeline-card:hover,
  .map-go-btn:hover, .btn-danger:hover { transform: none !important; }
}

/* ── Visible refresh - rounder, deeper, more alive (at-rest, not just hover) ─ */
:root {
  --r:  10px;   /* was 8  */
  --r2: 14px;   /* was 12 */
  --r3: 18px;   /* was 16 */
}
/* Soft depth on surfaces so the UI reads as layered cards, not flat panels */
.card, .stat-card, .pipeline-col, .breakdown, .note-item, .auth-card,
.result-card, .pitch-btn, .mat-btn {
  box-shadow: 0 2px 10px rgba(0,0,0,0.18);
}
.modal { box-shadow: 0 24px 70px rgba(0,0,0,0.55); }

/* Living background - a faint brand glow at the top of the work area */
#main-content {
  background:
    radial-gradient(1100px 520px at 78% -8%, rgba(124,58,237,0.04), transparent 60%),
    radial-gradient(900px 480px at 0% 0%, rgba(37,99,235,0.03), transparent 55%),
    var(--bg0);
}
/* Page titles a touch larger + tighter - more confident */
.page-hdr h1 { font-size: 23px; letter-spacing: -0.6px; }
/* Inputs a bit taller - easier to hit, friendlier */
.field input, .field select, .field textarea { padding: 10px 13px; }
/* Sidebar active link - stronger highlight */
.sb-link.active { background: linear-gradient(90deg, rgba(34,197,94,0.18), rgba(34,197,94,0.08)); box-shadow: inset 3px 0 0 var(--green); }

/* ══════════════════════════════════════════════════════════════════════════
   v2 BOLD THEME - bigger, rounder, more confident (visible at a glance)
   ════════════════════════════════════════════════════════════════════════ */

/* Pill-shaped, bolder buttons */
.btn-primary, .map-go-btn { border-radius: 999px; padding: 11px 22px; font-size: 14px; font-weight: 600; }
.btn-sec { border-radius: 999px; padding: 9px 18px; font-weight: 600; }

/* Sidebar - roomier nav, SOLID green active pill (no mistaking it) */
.sb-link { padding: 10px 12px; font-size: 14px; border-radius: 10px; }
.sb-link.active {
  background: linear-gradient(90deg, var(--green2), var(--green));
  color: #fff; box-shadow: 0 5px 16px rgba(34,197,94,0.4);
}
.sb-link.active svg { color: #fff; }

/* Big, confident page headers */
.page-hdr { padding: 30px 28px 0; margin-bottom: 24px; }
.page-hdr h1 { font-size: 27px; letter-spacing: -0.7px; }
.page-subtitle { font-size: 14px; }

/* Stat cards - large numbers, always-on gradient + depth */
.stats-grid { gap: 16px; }
.stat-card { padding: 22px; border-radius: 16px; box-shadow: 0 6px 20px rgba(0,0,0,0.25); }
.stat-value { font-size: 33px; letter-spacing: -0.8px; }
.stat-card:not(.green):not(.blue):not(.orange):not(.purple) {
  background: linear-gradient(135deg, var(--bg2), rgba(34,197,94,0.05));
}

/* Cards - rounder, clearly layered */
.card { border-radius: 16px; box-shadow: 0 4px 20px rgba(0,0,0,0.22); }

/* Tables - roomier, more readable rows */
tbody td { padding: 14px 16px; font-size: 14px; }
thead th { padding: 12px 16px; }

/* Rich app backdrop - subtle brand glow, not a flat black panel */
#main-content {
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(34,197,94,0.09), transparent 55%),
    radial-gradient(1000px 520px at -5% 0%, rgba(59,130,246,0.06), transparent 50%),
    var(--bg0);
}

/* ══════════════════════════════════════════════════════════════════════════
   LIGHT THEME - clean, bright, Roofle-like.  Delete this whole block to
   revert to the dark navy theme.  (CSS only - no markup/logic touched.)
   ════════════════════════════════════════════════════════════════════════ */
:root {
  --bg0: #f8fafc;   /* page background - neutral (Mike: purple-accent theme) */
  --bg1: #ffffff;   /* sidebar / side panels */
  --bg2: #ffffff;   /* cards */
  --bg3: #f1f4fa;   /* hover / inputs / subtle fills */
  --bg4: #e3e9f2;   /* deeper fills */
  --border: rgba(15,23,42,0.08);
  --bord2:  rgba(15,23,42,0.14);
  --bord3:  rgba(15,23,42,0.20);
  --text:   #0f172a;   /* primary text - slate-900 (Mike) */
  --text2:  #37445a;   /* secondary (darkened for readability) */
  --text3:  #586679;   /* muted (darkened for readability) */
  --shadow: 0 12px 40px rgba(15,23,42,0.14);
}
body, html { background: var(--bg0); color: var(--text); }

/* Soft, light-appropriate depth (the earlier black shadows are too heavy here) */
.card { box-shadow: 0 1px 2px rgba(15,23,42,0.05), 0 8px 24px rgba(15,23,42,0.06); }
.stat-card, .pipeline-col, .breakdown, .note-item, .auth-card,
.result-card, .pitch-btn, .mat-btn { box-shadow: 0 1px 2px rgba(15,23,42,0.05), 0 6px 18px rgba(15,23,42,0.05); }
.modal { box-shadow: 0 30px 80px rgba(15,23,42,0.22); }

/* Clean light backdrop with a faint brand tint */
#main-content {
  background:
    radial-gradient(1100px 520px at 82% -10%, rgba(34,197,94,0.07), transparent 55%),
    radial-gradient(900px 460px at -5% 0%, rgba(59,130,246,0.05), transparent 50%),
    var(--bg0);
}

/* White rail sidebar with a hairline edge */
#sidebar { box-shadow: 1px 0 0 var(--border); }
.auth-left { background: var(--bg0); }

/* Tables / inputs on white */
thead th { background: var(--bg1); }
tbody tr:hover { background: var(--bg3); }
.field input, .field select, .field textarea,
.search-bar input, .search-bar select { background: #fff; }
/* Readable placeholders (default --text3 was too faint to read) */
.field input::placeholder, .field textarea::placeholder,
.input-group input::placeholder, .search-bar input::placeholder,
input::placeholder, textarea::placeholder { color: #515f73; opacity: 1; font-weight: 500; }
/* Green checkboxes / radios everywhere */
input[type=checkbox], input[type=radio] { accent-color: #16a34a; }

/* Highlighted Actual Area - darker amber so it stays readable on light */
.result-card.highlight { background: rgba(234,179,8,0.16); border-color: rgba(202,138,4,0.55); }
.result-card.highlight .rl { color: #a16207; }
.result-card.highlight .rv { color: #854d0e; }

/* Light scrollbars */
::-webkit-scrollbar-thumb { background: #c7d0de; }
::-webkit-scrollbar-thumb:hover { background: #aab6c8; }

/* ── Badges & chips - crisp pastel that actually reads on light ─────────── */
.badge { font-weight: 600; padding: 3px 10px; border: 1px solid rgba(15,23,42,0.06); }
.badge-lead, .badge-sent          { background: #dbeafe; color: #1d4ed8; }
.badge-contacted                  { background: #f3e8ff; color: #7e22ce; }
.badge-measured                   { background: #fef9c3; color: #a16207; }
.badge-quoted, .badge-in_progress { background: #ffedd5; color: #c2410c; }
.badge-approved, .badge-complete  { background: #dcfce7; color: #15803d; }
.badge-scheduled                  { background: #e0f2fe; color: #0369a1; }
.badge-lost, .badge-rejected, .badge-job_lost { background: #fee2e2; color: #b91c1c; }
.badge-draft, .badge-expired      { background: #e2e8f0; color: #475569; border-color: rgba(15,23,42,0.12); }
/* Client (production) pipeline */
.badge-client_intake              { background: #ccfbf1; color: #0f766e; }
.badge-contract_signed            { background: #dcfce7; color: #15803d; }
.badge-pre_production             { background: #f3e8ff; color: #7e22ce; }
.badge-permit_pulled              { background: #dbeafe; color: #1d4ed8; }
.badge-ordered_material           { background: #f3e8ff; color: #7e22ce; }
.badge-job_scheduled              { background: #e0f2fe; color: #0369a1; }
.badge-waiting_on                 { background: #fef9c3; color: #a16207; }
.badge-final_payment              { background: #ffedd5; color: #c2410c; }
.badge-job_completed              { background: #dcfce7; color: #15803d; }

/* Source / generic chips - defined indigo chip, not a washed-out grey blob */
.tag {
  background: #eef2ff; color: #4f46e5; border: 1px solid rgba(79,70,229,0.20);
  font-weight: 600; padding: 3px 10px; border-radius: 20px; text-transform: capitalize;
}

/* Tables - zebra rows + a defined header for easy scanning */
thead th { background: #f8fafc; color: #64748b; border-bottom: 1px solid var(--bord2); }
tbody tr:nth-child(even) { background: rgba(15,23,42,0.022); }
tbody tr:hover { background: #eef4ff; }

/* Action buttons in tables - a touch more defined */
td .btn-sm { border-color: var(--bord2); }
td .btn-sm:hover { border-color: var(--green); color: var(--green); background: #f0fdf4; }

/* ── "Designed" nav icons - soft colored tiles, not plain grey lines ─────── */
.sb-link { padding: 8px 12px; }
.sb-link svg {
  width: 26px; height: 26px; padding: 5px; border-radius: 8px;
  background: var(--bg3); color: var(--text2); box-sizing: border-box;
  transition: all 0.15s ease; flex-shrink: 0;
}
.sb-link[data-view="dashboard"]      svg { background: #e0edff; color: #2563eb; }
.sb-link[data-view="leads"]          svg { background: #f3e8ff; color: #9333ea; }
.sb-link[data-view="projects"]       svg { background: #dcfce7; color: #16a34a; }
.sb-link[data-view="estimates"]      svg { background: #ffedd5; color: #ea580c; }
.sb-link[data-view="estimator"]      svg { background: #cffafe; color: #0891b2; }
.sb-link[data-view="campaigns"]      svg { background: #fce7f3; color: #db2777; }
.sb-link[data-view="siding"]         svg { background: #e0e7ff; color: #4f46e5; }
.sb-link[data-view="reports"]        svg { background: #fef9c3; color: #ca8a04; }
.sb-link[data-view="admin-pricing"]  svg { background: #d1fae5; color: #059669; }
.sb-link[data-view="admin-team"]     svg { background: #ede9fe; color: #7c3aed; }
.sb-link[data-view="admin-settings"] svg { background: #eef2f7; color: #475569; }
.sb-link:hover svg { transform: scale(1.06); }
/* On the active green pill, the tile turns glassy white to sit on the green */
.sb-link.active svg { background: rgba(255,255,255,0.25) !important; color: #fff !important; }

/* ── Sortable table headers (click to sort) ─────────────────────────────── */
/* Only columns tagged .th-sortable get the affordance - Actions/empty don't. */
.th-sortable { cursor: pointer; user-select: none; transition: color 0.12s; white-space: nowrap; }
.th-sortable:hover { color: var(--text); }
.th-sortable::after {
  content: '\21C5';                 /* ⇅ always visible so it's obviously clickable */
  display: inline-block; margin-left: 6px; font-size: 14px; font-weight: 700;
  color: var(--text3); opacity: 0.7; vertical-align: -1px;
}
.th-sortable:hover::after { opacity: 1; color: var(--text2); }
.th-sortable.sort-asc::after  { content: '\25B2'; font-size: 11px; opacity: 1; color: var(--green); }  /* ▲ */
.th-sortable.sort-desc::after { content: '\25BC'; font-size: 11px; opacity: 1; color: var(--green); }  /* ▼ */
/* Active sorted column header reads stronger */
.th-sortable.sort-asc, .th-sortable.sort-desc { color: var(--text); }
.th-nosort { cursor: default; }

/* ── Input groups (value + unit addon) - one clean cohesive field ───────── */
/* The accessory inputs sit outside .field, so they were falling back to the
   raw browser number input (heavy border + spinners). Style the whole group. */
.input-group {
  display: flex; align-items: stretch;
  background: #fff; border: 1px solid var(--bord2); border-radius: 10px;
  overflow: hidden; transition: border-color 0.15s, box-shadow 0.15s;
}
.input-group:focus-within { border-color: var(--green); box-shadow: 0 0 0 3px rgba(34,197,94,0.15); }
.input-group input {
  flex: 1; min-width: 0; width: 100%;
  padding: 9px 12px; font-family: 'Inter', sans-serif; font-size: 13.5px;
  color: var(--text); background: transparent; border: none; border-radius: 0; outline: none;
}
.input-group input::placeholder { color: var(--text3); }
.input-addon {
  display: flex; align-items: center; padding: 0 13px;
  background: #f1f4fa; border: none; border-left: 1px solid var(--border); border-radius: 0;
  color: var(--text3); font-size: 12px; font-weight: 600; white-space: nowrap;
}
/* Drop the clunky number spinners for a clean look */
.input-group input[type=number]::-webkit-inner-spin-button,
.input-group input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.input-group input[type=number] { -moz-appearance: textfield; appearance: textfield; }

/* ── PDF preview modal ──────────────────────────────────────────────────── */
.modal.pdf-preview { width: 860px; max-width: 96vw; height: 92vh; }
.pdf-preview-body { flex: 1; overflow: hidden; background: #525659; }
.pdf-preview-body iframe { width: 100%; height: 100%; border: none; display: block; }
@media (max-width: 820px) {
  /* Pin to the viewport directly (fixed/inset:0) instead of sitting centered in
     the padded backdrop: the backdrop's 16px padding + iOS's oversized 100vh were
     pushing the single-row header (with the ✕) above the visible area, so it was
     unreachable. fixed inset:0 fills the real visual viewport. Header clears the
     status bar / notch / Dynamic Island; footer clears the home bar. */
  .modal.pdf-preview { position: fixed; inset: 0; width: auto; height: auto; max-width: none; max-height: none; border-radius: 0; }
  .modal.pdf-preview .modal-hdr { padding-top: calc(18px + env(safe-area-inset-top)); }
  .modal.pdf-preview .modal-ftr { flex-wrap: wrap; padding-bottom: calc(14px + env(safe-area-inset-bottom)); }
}

/* ── Material Order modal ───────────────────────────────────────────────────
   On a phone the .modal.lg width (calc(100vw - 16px)) plus the backdrop's 16px
   padding on BOTH sides overflowed by ~16px (modal shifted off-centre / "skewed"),
   and the 5-button footer (Close/CSV/PDF/Preview/Save) had no flex-wrap so it spilled
   past the edge. Pin to the visual viewport like the PDF preview + wrap the footer.
   Desktop (>640px) is unchanged - the modal stays a centered .lg dialog. */
@media (max-width: 640px) {
  .modal.material-order { position: fixed; inset: 0; width: auto; height: auto; max-width: none; max-height: none; border-radius: 0; }
  .modal.material-order .modal-hdr { padding-top: calc(18px + env(safe-area-inset-top)); }
  .modal.material-order .modal-ftr { flex-wrap: wrap; padding-bottom: calc(14px + env(safe-area-inset-bottom)); }
}

/* ── Date / month inputs - clean, consistent with the other fields ──────── */
input[type=date], input[type=month], .date-input {
  padding: 9px 12px; background: #fff; border: 1px solid var(--bord2);
  border-radius: 10px; color: var(--text); font-family: 'Inter', sans-serif; font-size: 13.5px;
  outline: none; transition: border-color 0.15s, box-shadow 0.15s; min-height: 38px;
}
input[type=date]:focus, input[type=month]:focus, .date-input:focus {
  border-color: var(--green); box-shadow: 0 0 0 3px rgba(34,197,94,0.15);
}
input[type=date]::-webkit-calendar-picker-indicator,
input[type=month]::-webkit-calendar-picker-indicator,
.date-input::-webkit-calendar-picker-indicator {
  cursor: pointer; opacity: 0.5; padding: 2px; border-radius: 4px;
}
input[type=date]::-webkit-calendar-picker-indicator:hover,
input[type=month]::-webkit-calendar-picker-indicator:hover,
.date-input::-webkit-calendar-picker-indicator:hover { opacity: 1; background: var(--bg3); }

/* ── Settings tab panels - centered card so it doesn't dump to the left ──── */
.stab-panel .card { max-width: 820px !important; margin: 0 auto; }

/* ── Map overlays sit over the satellite image → keep them dark, force light
   text/icons (the light theme flipped these to dark = invisible on the map) ── */
.map-search-inner input { color: #fff; }
.map-search-inner input::placeholder { color: rgba(255,255,255,0.55); }
.map-search-inner svg { color: rgba(255,255,255,0.6); }
.ac-dropdown { background: rgba(12,18,30,0.97); border-color: rgba(255,255,255,0.16); }
.ac-item { color: rgba(255,255,255,0.85); border-bottom-color: rgba(255,255,255,0.08); }
.ac-item:hover { background: rgba(255,255,255,0.10); color: #fff; }
.map-tool-btn { color: rgba(255,255,255,0.82); }
.map-tool-btn:hover { background: rgba(255,255,255,0.16); color: #fff; }
.map-coords { color: rgba(255,255,255,0.7); }
.map-status-bar { color: rgba(255,255,255,0.85); }

/* ══════════════════════════════════════════════════════════════════════════
   Sidebar v3 - dark icon rail (icon on top, label below). RoofQuotePRO style.
   ════════════════════════════════════════════════════════════════════════ */
:root { --sb-w: 94px; }
#sidebar { background: linear-gradient(180deg, #1e293b, #0f172a); border-right: none; box-shadow: 1px 0 0 rgba(0,0,0,0.15); }

/* Logo: just the brand mark, centered (hide the text in a narrow rail) */
.sb-logo { justify-content: center; padding: 16px 6px 12px; border-bottom-color: rgba(255,255,255,0.08); }
.sb-company { display: none; }

/* Section labels don't fit a rail */
.sb-section-label { display: none; }
.sb-nav { padding: 8px 6px; gap: 3px; }

/* Nav items: vertical icon + small label, centered */
.sb-link {
  flex-direction: column; align-items: center; justify-content: center; text-align: center;
  gap: 5px; padding: 9px 4px; border-radius: 12px; font-size: 10px; line-height: 1.15;
  color: rgba(255,255,255,0.68); font-weight: 500;
}
.sb-link svg {
  width: 22px; height: 22px; padding: 0; border-radius: 0;
  background: none !important; color: inherit !important;
}
.sb-link:hover { background: rgba(255,255,255,0.07); color: #fff; transform: none; }
.sb-link.active { background: rgba(124,58,237,0.30); color: #fff; box-shadow: inset 0 0 0 1px rgba(124,58,237,0.5); }
.sb-link.active svg { color: #c4b5fd !important; background: none !important; }

/* Bottom user area on the dark rail - just the avatar */
.sb-bottom { border-top-color: rgba(255,255,255,0.08); padding: 8px 6px; }
.sb-user { flex-direction: column; gap: 4px; padding: 7px 2px; border-radius: 12px; justify-content: center; }
.sb-user:hover { background: rgba(255,255,255,0.08); }
.sb-user-info, .sb-caret { display: none; }

/* Logo mark + avatar - white so they pop on the green rail (green-on-green looked muddy) */
.sb-logo .brand-icon { background: #fff; box-shadow: 0 2px 8px rgba(0,0,0,0.2); width: 34px; height: 34px; border-radius: 10px; }
.sb-logo .brand-icon svg { fill: none; stroke: #16a34a; stroke-width: 2; width: 20px; height: 20px; }
.sb-user .user-av { background: #fff; color: #14402e; box-shadow: 0 2px 8px rgba(0,0,0,0.2); }

/* On MOBILE the sidebar is a full drawer (not the 94px rail) so the grouped
   categories + accordion fit: wider, labels shown, left-aligned rows. Placed
   after the rail block so it wins. Dark-green surface kept. */
@media (max-width: 900px) {
  :root { --sb-w: 274px; }
  .sb-logo { justify-content: flex-start; padding: 16px 16px 12px; }
  .sb-company { display: block; color: #fff; }
  .sb-nav { padding: 8px 10px; gap: 1px; }
  #sidebar .sb-link {
    flex-direction: row; align-items: center; justify-content: flex-start; text-align: left;
    gap: 11px; padding: 11px 13px; font-size: 14px; line-height: 1.3; border-radius: 10px;
  }
  #sidebar .sb-link svg { width: 20px; height: 20px; }
  #sidebar .sb-sub-link { padding-left: 45px; font-size: 13.5px; }
  #sidebar .sb-group-hdr .sb-arrow { width: 15px; height: 15px; }
  .sb-user { flex-direction: row; gap: 9px; justify-content: flex-start; padding: 8px 10px; }
  .sb-user-info, .sb-caret { display: block; }
  .sb-user-name { color: #fff; }
}

/* Bulk email (Mass Email / Campaigns) - per Mike, the bulk BLASTING should be
   hidden before going live (ruins domain reputation; they'll use a dedicated
   tool). For now the Email menu stays visible for local testing. Re-enable the
   hide rule below before the live deploy if Mike still wants it gone.
   .sb-link[data-view="campaigns"] { display: none !important; } */

/* ══════════════════════════════════════════════════════════════════════════
   DARK MODE (html.dark) - restores the original dark palette so the toggle
   flips cleanly. Light is the default (no class).
   ════════════════════════════════════════════════════════════════════════ */
html.dark {
  --bg0:#0a0f1a; --bg1:#0f1623; --bg2:#141d2e; --bg3:#1a2540; --bg4:#1f2d4a;
  --border:rgba(255,255,255,0.07); --bord2:rgba(255,255,255,0.12); --bord3:rgba(255,255,255,0.18);
  --text:#e8edf5; --text2:#8fa3bc; --text3:#546a82;
  --shadow:0 4px 32px rgba(0,0,0,0.5);
}
html.dark body { background: var(--bg0); color: var(--text); }
html.dark #main-content {
  background:
    radial-gradient(1100px 520px at 80% -10%, rgba(34,197,94,0.06), transparent 55%),
    var(--bg0);
}
/* Dark mode: sidebar matches the dark theme (navy), green stays as the accent */
html.dark #sidebar { background: linear-gradient(180deg, #111b2b, #0c1320); }
html.dark .sb-logo .brand-icon, html.dark .sb-user .user-av { box-shadow: 0 2px 8px rgba(0,0,0,0.45); }
html.dark .card { box-shadow: 0 4px 24px rgba(0,0,0,0.4); }
html.dark .stat-card, html.dark .modal { box-shadow: 0 10px 36px rgba(0,0,0,0.5); }
/* inputs back to dark surfaces (light theme forced them white) */
html.dark .field input, html.dark .field select, html.dark .field textarea,
html.dark .search-bar input, html.dark .search-bar select,
html.dark input[type=date], html.dark input[type=month], html.dark .date-input { background: var(--bg2); }
html.dark .input-group { background: var(--bg2); }
html.dark .input-addon { background: var(--bg3); }
html.dark thead th { background: var(--bg2); color: var(--text3); }
html.dark tbody tr:nth-child(even) { background: rgba(255,255,255,0.02); }
html.dark tbody tr:hover { background: var(--bg3); }
html.dark ::-webkit-scrollbar-thumb { background: var(--bg4); }
html.dark .result-card.highlight { background: rgba(250,204,21,0.16); border-color: rgba(250,204,21,0.55); }
html.dark .result-card.highlight .rl { color: #eab308; }
html.dark .result-card.highlight .rv { color: #fde047; }
html.dark td .btn-sm:hover { background: var(--bg3); color: var(--green); }

/* ── Supplement light-mode overrides ────────────────────────────────────── */
/* In light mode --bg1 and --bg2 are both white, so everything blends.
   These rules add the visual separation that the dark theme gets for free. */
.supp-layout { background: #f1f5fb; }
.supp-list-col { background: #fff; box-shadow: 1px 0 0 rgba(15,23,42,0.08); }
.supp-list-col-top { background: #fff; }
.supp-list-inner-scroll { background: #f8fafc; }
.supp-list-item { border: 1px solid transparent; }
.supp-list-item:hover { background: #eef2ff; border-color: rgba(124,58,237,0.15); }
.supp-list-item.active { background: #ede9fe; border-color: rgba(124,58,237,0.3); box-shadow: inset 3px 0 0 #7c3aed; }
.supp-list-name { color: #0f172a; }
.supp-list-meta { color: #64748b; }
.supp-list-counts { color: #94a3b8; }
.supp-search { background: #fff; border: 1.5px solid #b8c4d6; color: #0f172a; box-shadow: inset 0 1px 2px rgba(15,23,42,0.05); }
.supp-search::placeholder { color: #94a3b8; }
.supp-search:focus { border-color: #7c3aed; box-shadow: 0 0 0 3px rgba(124,58,237,0.1); }

.supp-detail-col { background: #f1f5fb; }
.supp-detail-hdr { background: #fff; border-bottom: 1.5px solid #e2e8f0; box-shadow: 0 1px 3px rgba(15,23,42,0.06); }
.supp-detail-name { color: #0f172a; }
.supp-detail-sub { color: #64748b; }
.supp-approved-total { background: #dcfce7; color: #15803d; border-color: rgba(21,128,61,0.25); }

.supp-tabs { background: #fff; border-bottom: 1.5px solid #e2e8f0; }
.supp-tab { color: #64748b; font-weight: 500; }
.supp-tab:hover { color: #0f172a; background: #f8fafc; }
.supp-tab.active { color: #7c3aed; border-bottom-color: #7c3aed; background: #faf5ff; }

.supp-tab-body { background: #f1f5fb; }

/* Form inputs - clear white cards on the light bg */
.supp-step-hint { background: #faf5ff; border-color: #7c3aed; color: #4c1d95; border-left-width: 3px; }
.supp-form-grid { background: #fff; border: 1px solid #dbe2ec; border-radius: 12px; padding: 22px; box-shadow: 0 1px 3px rgba(15,23,42,0.06); }
.supp-form-group label { color: #334155; font-weight: 700; }
.supp-form-group input, .supp-form-group textarea {
  background: #fff; border: 1.5px solid #b8c4d6; color: #0f172a;
  box-shadow: inset 0 1px 2px rgba(15,23,42,0.05);
}
.supp-form-group input:focus, .supp-form-group textarea:focus {
  background: #fff; border-color: #7c3aed; box-shadow: 0 0 0 3px rgba(124,58,237,0.12);
}
.supp-form-group input::placeholder, .supp-form-group textarea::placeholder { color: #94a3b8; }
.supp-form-footer { border-top-color: #e2e8f0; }
.supp-saved-msg { color: #15803d; }

/* Scope tab */
.supp-section { background: #fff; border-color: #e2e8f0; box-shadow: 0 1px 3px rgba(15,23,42,0.05); }
.supp-upload-box { background: #f8fafc; border-color: #cbd5e1; color: #475569; }
.supp-upload-box:hover { background: #faf5ff; border-color: #7c3aed; color: #4c1d95; }
.supp-section-lbl { color: #7c3aed; font-weight: 700; }
.supp-section textarea { background: #fff; border: 1.5px solid #b8c4d6; color: #0f172a; border-radius: 8px; padding: 10px 12px; box-shadow: inset 0 1px 2px rgba(15,23,42,0.05); }

/* Photos tab */
.supp-photo-drop { background: #fff; border-color: #cbd5e1; color: #475569; }
.supp-photo-drop:hover, .supp-photo-drop.dragover { background: #faf5ff; border-color: #7c3aed; color: #4c1d95; }
.supp-thumb { border-color: #e2e8f0; }

/* AI items tab */
.supp-readiness { background: #fff; border-color: #e2e8f0; box-shadow: 0 1px 3px rgba(15,23,42,0.05); }
.supp-readiness-title { color: #7c3aed; }
.supp-readiness-row { color: #334155; }
.supp-ready-ok { color: #15803d; }
.supp-ready-no { color: #94a3b8; }
.supp-bulk-actions { background: #fff; border-color: #e2e8f0; }
.supp-summary { background: #eff6ff; border-color: rgba(59,130,246,0.3); color: #1e40af; }

/* Items table */
.supp-table-wrap { background: #fff; border-color: #e2e8f0; box-shadow: 0 1px 3px rgba(15,23,42,0.05); }
.supp-table thead { background: #f8fafc; }
.supp-table th { color: #7c3aed; border-bottom-color: #dbe2ec; }
.supp-table td { border-bottom-color: #eef2f7; color: #0f172a; }
.supp-table tbody tr:nth-child(even) td { background: #f8fafc; }
.supp-table tbody tr:hover td { background: #f5f3ff; }
.supp-cell { color: #0f172a; background: #fff; border-color: #cdd6e3; }
.supp-cell:hover, .supp-cell:focus { background: #fff; border-color: #7c3aed; }
.supp-reason { color: #64748b; }
.supp-cell-total { color: #0f172a; font-weight: 700; }
.supp-conf-high { background: #dcfce7; color: #15803d; border-color: rgba(21,128,61,0.2); }
.supp-conf-med  { background: #fef9c3; color: #a16207; border-color: rgba(161,98,7,0.2); }
.supp-conf-low  { background: #fee2e2; color: #b91c1c; border-color: rgba(185,28,28,0.2); }
.supp-btn-approve { background: #dcfce7; color: #15803d; border-color: rgba(21,128,61,0.25); }
.supp-btn-approve:hover { background: #16a34a; color: #fff; }
.supp-btn-reject { background: #fee2e2; color: #b91c1c; border-color: rgba(185,28,28,0.2); }
.supp-btn-reject:hover { background: #dc2626; color: #fff; }
.supp-btn-del { color: #94a3b8; }
.supp-btn-del:hover { background: #fee2e2; color: #b91c1c; border-color: rgba(185,28,28,0.15); }

/* Add item form */
.supp-add-item-inline { background: #fff; border-color: #e2e8f0; }
.supp-add-item-grid .supp-form-group select { background: #f8fafc; border-color: #d1d9e6; color: #0f172a; }

/* Totals */
.supp-totals-block { background: #fff; border-color: #e2e8f0; box-shadow: 0 2px 8px rgba(15,23,42,0.06); }
.supp-op-label { color: #64748b; }
.supp-op-field-wrap { color: #334155; }
.supp-op-input { background: #f1f5fb; border-color: #d1d9e6; color: #0f172a; }
.supp-tot-row { color: #334155; border-bottom-color: #f1f5f9; }
.supp-tot-grand { background: #dcfce7; color: #15803d; border-color: rgba(21,128,61,0.2); }
.supp-export-bar { border-top-color: #e2e8f0; }

/* Email modal */
.supp-email-modal { background: #fff; border-color: #e2e8f0; }

/* Dark mode: keep original dark styles (reset the overrides above) */
html.dark .supp-layout { background: var(--bg0); }
html.dark .supp-list-col { background: var(--bg1); box-shadow: none; }
html.dark .supp-list-col-top { background: var(--bg1); }
html.dark .supp-list-inner-scroll { background: var(--bg1); }
html.dark .supp-list-item:hover { background: var(--bg3); border-color: transparent; }
html.dark .supp-list-item.active { background: var(--accent-d); border-color: rgba(124,58,237,0.3); }
html.dark .supp-list-name { color: var(--text); }
html.dark .supp-search { background: var(--bg2); border-color: var(--border); color: var(--text); }
html.dark .supp-detail-col { background: var(--bg0); }
html.dark .supp-detail-hdr { background: var(--bg1); border-color: var(--border); box-shadow: none; }
html.dark .supp-approved-total { background: var(--green-d); color: var(--green); border-color: rgba(34,197,94,0.2); }
html.dark .supp-tabs { background: var(--bg1); border-color: var(--border); }
html.dark .supp-tab { color: var(--text3); }
html.dark .supp-tab.active { color: var(--accent); background: transparent; }
html.dark .supp-tab-body { background: var(--bg0); }
html.dark .supp-step-hint { background: var(--bg2); border-color: var(--accent); color: var(--text2); }
html.dark .supp-form-grid { background: transparent; border: none; padding: 0; box-shadow: none; }
html.dark .supp-form-group label { color: var(--text3); }
html.dark .supp-form-group input, html.dark .supp-form-group textarea { background: var(--bg2); border-color: var(--border); color: var(--text); }
html.dark .supp-form-group input:focus, html.dark .supp-form-group textarea:focus { background: var(--bg2); border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-d); }
html.dark .supp-upload-box { background: var(--bg2); border-color: var(--border); color: var(--text2); }
html.dark .supp-upload-box:hover { background: var(--accent-d); border-color: var(--accent); color: var(--text); }
html.dark .supp-photo-drop { background: var(--bg2); border-color: var(--border); color: var(--text2); }
html.dark .supp-photo-drop:hover { background: var(--accent-d); border-color: var(--accent); }
html.dark .supp-readiness { background: var(--bg2); border-color: var(--border); box-shadow: none; }
html.dark .supp-readiness-title { color: var(--text3); }
html.dark .supp-table-wrap { background: transparent; border-color: var(--border); box-shadow: none; }
html.dark .supp-table thead { background: var(--bg2); }
html.dark .supp-table th { color: var(--text3); border-color: var(--border); }
html.dark .supp-table td { border-color: var(--border); color: var(--text); }
html.dark .supp-table tbody tr:hover td { background: var(--bg2); }
html.dark .supp-totals-block { background: var(--bg1); border-color: var(--border); box-shadow: none; }
html.dark .supp-tot-row { color: var(--text2); border-color: var(--border); }
html.dark .supp-tot-grand { background: var(--green-d); color: var(--green); border-color: rgba(34,197,94,0.2); }
html.dark .supp-add-item-inline { background: var(--bg2); border-color: var(--border); }
html.dark .supp-email-modal { background: var(--bg1); border-color: var(--border); }
html.dark .supp-conf-high { background: rgba(34,197,94,0.14); color: var(--green); border-color: rgba(34,197,94,0.2); }
html.dark .supp-conf-med  { background: rgba(234,179,8,0.14); color: var(--yellow); border-color: rgba(234,179,8,0.2); }
html.dark .supp-conf-low  { background: rgba(239,68,68,0.10); color: var(--red); border-color: rgba(239,68,68,0.18); }
html.dark .supp-btn-approve { background: rgba(34,197,94,0.12); color: var(--green); border-color: rgba(34,197,94,0.2); }
html.dark .supp-btn-reject { background: rgba(239,68,68,0.10); color: var(--red); border-color: rgba(239,68,68,0.18); }
html.dark .supp-summary { background: var(--blue-d); border-color: rgba(59,130,246,0.25); color: var(--text2); }
html.dark .supp-bulk-actions { background: var(--bg2); border-color: var(--border); }
html.dark .supp-section-lbl { color: var(--text3); }

/* ── Theme toggle - lives inline in the page-header action row (JS places it
   there); falls back to a floating top-right button on pages with no header. */
#theme-toggle {
  width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0;
  background: var(--bg2); border: 1px solid var(--bord2); color: var(--text2);
  cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
  transition: all 0.15s ease;
}
#theme-toggle:hover { color: var(--text); background: var(--bg3); }
#theme-toggle.floating { position: fixed; top: 14px; right: 16px; z-index: 250; box-shadow: 0 2px 12px rgba(15,23,42,0.14); }
#theme-toggle svg { width: 18px; height: 18px; }
#theme-toggle .th-sun { display: none; }
#theme-toggle .th-moon { display: block; }
html.dark #theme-toggle .th-sun { display: block; }
html.dark #theme-toggle .th-moon { display: none; }

/* ── Dashboard (modern KPI cards + leaderboard) ─────────────────────────────── */
.dash-wrap { max-width: 1140px; padding: 0 28px 28px; }
.dash-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 18px; }
.dash-kpi {
  background: var(--bg2); border: 1px solid var(--border); border-radius: 16px;
  padding: 20px 22px; transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.dash-kpi:hover { transform: translateY(-2px); box-shadow: 0 10px 26px rgba(15,23,42,0.07); border-color: var(--bord2); }
.dash-kpi-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.dash-kpi-label { font-size: 12px; font-weight: 600; color: var(--text3); letter-spacing: .2px; text-transform: uppercase; }
.dash-kpi-icon { width: 38px; height: 38px; border-radius: 11px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.dash-kpi-icon svg { width: 19px; height: 19px; stroke: currentColor; fill: none; stroke-width: 2; }
.dash-kpi-icon.green  { background: var(--green-d);  color: var(--green); }
.dash-kpi-icon.blue   { background: var(--blue-d);   color: var(--blue); }
.dash-kpi-icon.purple { background: var(--purple-d); color: var(--purple); }
.dash-kpi-value { font-size: 30px; font-weight: 800; letter-spacing: -0.6px; color: var(--text); line-height: 1; }
.dash-kpi-sub { font-size: 12.5px; color: var(--text3); margin-top: 9px; }

/* Dashboard layout: Revenue + Leaderboard side by side on top, Upcoming Schedule
   full-width below. Centered with a max width so wide screens have symmetric
   margins (not an empty right side). Stacks on phones. */
.dash-cols { max-width: 1320px; margin: 0 auto; padding: 0 28px 28px; }
.dash-top  { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; }
@media (max-width: 640px) { .dash-top { grid-template-columns: 1fr; } }

.dash-lb { padding: 6px 10px 12px; }
.dash-lb-row { display: flex; align-items: center; gap: 14px; padding: 11px 12px; border-radius: 12px; transition: background .14s ease; }
.dash-lb-row:hover { background: var(--bg1); }
.dash-lb-rank { width: 30px; height: 30px; border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 800; color: #fff; flex-shrink: 0; }
.dash-lb-main { flex: 1; min-width: 0; }
.dash-lb-name { font-size: 14px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dash-lb-bar { height: 5px; background: var(--bg3); border-radius: 3px; margin-top: 6px; overflow: hidden; }
.dash-lb-bar > span { display: block; height: 100%; background: var(--green); border-radius: 3px; }
.dash-lb-meta { font-size: 11.5px; color: var(--text3); margin-top: 4px; }
.dash-lb-amt { font-size: 15px; font-weight: 800; color: var(--green); flex-shrink: 0; }
@media (max-width: 640px) { .dash-kpis { grid-template-columns: 1fr; } }

/* Dashboard rows: weather (2-col), then contingency/leaderboard/contest (3-col),
   then revenue + schedule (2-col). All collapse to one column on narrow screens. */
.dash-grid3 { display: grid; grid-template-columns: 1fr 1fr 1.15fr; gap: 20px; margin-bottom: 20px; }
.dash-grid2 { display: grid; grid-template-columns: 1fr 1.45fr; gap: 20px; }
@media (max-width: 1000px) {
  .dash-grid3, .dash-grid2 { grid-template-columns: 1fr; }
}
.wx-skelcard { padding: 18px 22px; }
.wx-skel { font-size: 13.5px; color: var(--text3); padding: 12px 4px; }
.wx-skel a { color: var(--accent); font-weight: 600; }

.dash-updated { font-size: 12px; color: var(--text3); font-weight: 500; margin-left: 4px; }

/* Reusable segmented two-button toggle (e.g. Retail / Insurance in forms) */
.seg-toggle { display: inline-flex; width: 100%; background: var(--bg3); border: 1px solid var(--border); border-radius: 9px; padding: 3px; gap: 3px; box-sizing: border-box; }
.seg-toggle .seg-btn { flex: 1; border: none; background: transparent; color: var(--text2); font-size: 13px; font-weight: 600; padding: 8px 12px; border-radius: 7px; cursor: pointer; transition: background .14s, color .14s; }
.seg-toggle .seg-btn:hover { color: var(--text); }
.seg-toggle .seg-btn.on { background: var(--bg2); color: var(--accent); box-shadow: 0 1px 3px rgba(15,23,42,0.10); font-weight: 700; }

/* Folder (area/label) badge shown on campaign + estimate rows */
.folder-badge { display: inline-flex; align-items: center; gap: 5px; font-size: 10.5px; font-weight: 700; color: #6d28d9; background: rgba(124,58,237,0.10); border: 1px solid rgba(124,58,237,0.20); padding: 2px 8px 2px 6px; border-radius: 20px; white-space: nowrap; }
.folder-badge::before { content: ""; width: 11px; height: 11px; flex-shrink: 0; background: no-repeat center / contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236d28d9' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 7a2 2 0 0 1 2-2h4l2 2h8a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z'/%3E%3C/svg%3E"); }

/* Destination-folder picker = one clean dropdown (matches the Brand dropdown). */
.fp-select {
  width: 100%; appearance: none; -webkit-appearance: none;
  background-color: #fff; color: #334155; font-size: 12px; font-weight: 600;
  border: 1px solid #cbd5e1; border-radius: 8px; padding: 5px 28px 5px 11px; cursor: pointer; outline: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2351607a' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 9px center; background-size: 11px;
}
.fp-select:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-d); }

/* Folders page - Google Drive-style explorer */
.drive-body { display: flex; gap: 0; padding: 0 28px 28px; align-items: flex-start; }
.drive-rail { flex: 0 0 232px; max-width: 232px; display: flex; flex-direction: column; gap: 2px; padding: 6px 14px 6px 0; margin-right: 18px; border-right: 1px solid var(--border); position: sticky; top: 18px; max-height: calc(100vh - 120px); overflow-y: auto; }
.drive-rail-item { display: flex; align-items: center; gap: 10px; width: 100%; text-align: left; padding: 9px 12px; border: 1px solid transparent; border-radius: 10px; background: transparent; color: var(--text2); font-size: 13.5px; font-weight: 600; cursor: pointer; transition: background .14s ease, color .14s ease, border-color .14s ease; }
.drive-rail-item:hover { background: var(--accent-d); color: var(--text); }
.drive-rail-item.active { background: var(--accent-d); color: var(--accent); }
.drive-rail-item.drop-hot { background: var(--accent-d); border-color: var(--accent); color: var(--accent); }
.drive-rail-item .dri-ico { flex-shrink: 0; display: inline-flex; width: 22px; height: 22px; color: var(--text3); }
.drive-rail-item:hover .dri-ico, .drive-rail-item.active .dri-ico { color: var(--accent); }
.drive-rail-item .dri-ico svg { width: 18px; height: 18px; }
.drive-rail-item .dri-name { flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.drive-rail-item .dri-count { flex-shrink: 0; font-size: 11px; font-weight: 700; color: var(--text3); background: var(--bg3); border-radius: 999px; padding: 1px 8px; min-width: 20px; text-align: center; }
.drive-rail-item.active .dri-count { background: var(--accent); color: #fff; }
.drive-rail-sep { height: 1px; background: var(--border); margin: 8px 2px; }
.drive-rail-empty { font-size: 12px; color: var(--text3); padding: 10px 12px; }
.drive-main { flex: 1; min-width: 0; }

.dcrumb-link { cursor: pointer; color: var(--accent); font-weight: 600; }
.dcrumb-link:hover { text-decoration: underline; }
.dcrumb-sep { margin: 0 7px; color: var(--text3); }
.dcrumb-cur { color: var(--text2); font-weight: 600; }
.drive-sec-label { font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--text3); margin: 0 0 12px; }

/* Folder chips (root grid) */
.drive-folder-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(232px, 1fr)); gap: 12px; margin-bottom: 26px; }
.drive-folder-chip { display: flex; align-items: center; gap: 13px; padding: 13px 15px; background: var(--bg2); border: 1px solid var(--border); border-radius: 12px; cursor: pointer; transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease; }
.drive-folder-chip:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(15,23,42,0.08); border-color: var(--bord2); }
.drive-folder-chip:focus-visible { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-d); }
.drive-folder-chip.drop-hot { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-d); }
.dfc-ico { flex-shrink: 0; width: 46px; height: 46px; border-radius: 11px; display: flex; align-items: center; justify-content: center; background: var(--accent-d); color: var(--accent); }
.dfc-ico svg { width: 26px; height: 26px; }
.dfc-body { flex: 1; min-width: 0; }
.dfc-name { font-size: 14.5px; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dfc-meta { font-size: 12px; color: var(--text3); margin-top: 2px; }

/* Item tiles (estimates + uploads inside a folder) - compact file-card rows */
.drive-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(252px, 1fr)); gap: 12px; }
.drive-tile { background: var(--bg2); border: 1px solid var(--border); border-radius: 12px; padding: 13px 14px; cursor: pointer; transition: box-shadow .14s ease, border-color .14s ease, background .14s ease; }
.drive-tile:hover { box-shadow: 0 4px 14px rgba(15,23,42,0.07); border-color: var(--bord2); background: var(--bg); }
.drive-tile:focus-visible { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-d); }
.drive-tile.item[draggable="true"] { cursor: grab; }
.drive-tile.dragging { opacity: .45; cursor: grabbing; }
.drive-tile.drop-hot { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-d); }
.dt-head { display: flex; align-items: center; gap: 12px; min-width: 0; }
.dt-ico { flex-shrink: 0; width: 42px; height: 42px; border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.dt-ico.doc { background: var(--accent-d); color: var(--accent); }
.dt-ico.upl { background: var(--orange-d, rgba(249,115,22,0.12)); color: var(--orange, #f97316); }
.dt-ico svg { width: 22px; height: 22px; }
.dt-info { flex: 1; min-width: 0; }
.dt-name { font-size: 14px; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dt-meta { font-size: 12.5px; color: var(--text3); margin-top: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dt-head .badge { flex-shrink: 0; align-self: flex-start; }
.dt-actions { display: flex; gap: 7px; margin-top: 12px; }
.dt-actions .btn-sm { flex: 1; text-align: center; }

/* Folders toolbar: search + grid/list toggle */
.drive-toolbar { display: flex; align-items: center; gap: 12px; padding: 0 0 14px; flex-wrap: wrap; }
.drive-search { position: relative; flex: 1; min-width: 220px; max-width: 420px; display: flex; align-items: center; }
.drive-search .ds-ico { position: absolute; left: 11px; display: inline-flex; width: 16px; height: 16px; color: var(--text3); pointer-events: none; }
.drive-search .ds-ico svg { width: 16px; height: 16px; }
.drive-search input { width: 100%; font-size: 13.5px; padding: 9px 32px 9px 34px; border: 1px solid var(--bord2); border-radius: 9px; outline: none; background: var(--bg2); color: var(--text); }
.drive-search input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-d); }
.drive-search .ds-clear { position: absolute; right: 6px; width: 22px; height: 22px; border: none; background: transparent; color: var(--text3); cursor: pointer; border-radius: 6px; font-size: 13px; line-height: 1; }
.drive-search .ds-clear:hover { background: var(--bg3); color: var(--text); }
.drive-view-toggle { display: inline-flex; border: 1px solid var(--bord2); border-radius: 9px; overflow: hidden; flex-shrink: 0; }
.dv-btn { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border: none; background: var(--bg2); color: var(--text3); cursor: pointer; transition: background .12s ease, color .12s ease; }
.dv-btn + .dv-btn { border-left: 1px solid var(--bord2); }
.dv-btn:hover { background: var(--bg3); color: var(--text2); }
.dv-btn.active { background: var(--accent-d); color: var(--accent); }
.dv-btn svg { width: 17px; height: 17px; }

/* Folder chip kebab (hover-reveal quick menu) */
.drive-folder-chip { position: relative; }
.drive-kebab { position: absolute; top: 6px; right: 6px; width: 26px; height: 26px; border: none; background: transparent; color: var(--text3); cursor: pointer; border-radius: 7px; font-size: 17px; line-height: 1; opacity: 0; transition: opacity .12s ease, background .12s ease; }
.drive-folder-chip:hover .drive-kebab, .drive-folder-chip:focus-within .drive-kebab { opacity: 1; }
.drive-kebab:hover { background: var(--bg3); color: var(--text); }

/* List view: folders + items collapse to single-column rows */
.drive-folder-grid.is-list, .drive-grid.is-list { grid-template-columns: 1fr; gap: 8px; }
.drive-grid.is-list .drive-tile { padding: 10px 13px; }
.drive-grid.is-list .dt-actions { margin-top: 0; flex: 0 0 auto; }
.drive-grid.is-list .dt-head { gap: 10px; }
.drive-grid.is-list .drive-tile { display: flex; align-items: center; gap: 14px; }
.drive-grid.is-list .drive-tile .dt-head { flex: 1; min-width: 0; }
.drive-grid.is-list .dt-actions .btn-sm { flex: 0 0 auto; }
.drive-folder-grid.is-list .drive-folder-chip { padding: 10px 14px; }

/* Right-click context menu */
.drive-ctx { position: fixed; z-index: 9000; min-width: 184px; max-height: 60vh; overflow-y: auto; background: var(--bg2); border: 1px solid var(--bord2); border-radius: 10px; box-shadow: 0 10px 34px rgba(15,23,42,0.18); padding: 5px; }
.drive-ctx-item { display: block; width: 100%; text-align: left; padding: 8px 11px; border: none; background: transparent; color: var(--text); font-size: 13px; border-radius: 7px; cursor: pointer; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.drive-ctx-item:hover { background: var(--accent-d); color: var(--accent); }
.drive-ctx-item.danger { color: var(--red, #dc2626); }
.drive-ctx-item.danger:hover { background: rgba(220,38,38,0.1); color: var(--red, #dc2626); }
.drive-ctx-sep { height: 1px; background: var(--border); margin: 4px 6px; }
.drive-ctx-hdr { font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: var(--text3); padding: 7px 11px 3px; }

@media (max-width: 760px) {
  .drive-body { flex-direction: column; padding: 0 16px 22px; }
  .drive-rail { flex-basis: auto; max-width: none; width: 100%; flex-direction: row; flex-wrap: nowrap; overflow-x: auto; border-right: none; border-bottom: 1px solid var(--border); margin: 0 0 16px; padding: 0 0 12px; position: static; max-height: none; }
  .drive-rail-sep { display: none; }
  .drive-rail-item { width: auto; flex-shrink: 0; }
  .drive-folder-grid, .drive-grid { grid-template-columns: 1fr; }
  .drive-toolbar { padding: 0 16px 14px; }
  .drive-kebab { opacity: 1; }
}

/* Folder Manager modal */
.fm-new { display: flex; gap: 7px; margin-bottom: 14px; }
.fm-new input { flex: 1; min-width: 0; font-size: 13px; padding: 8px 11px; border: 1px solid var(--bord2); border-radius: 8px; outline: none; background: var(--bg2); color: var(--text); }
.fm-new input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-d); }
.fm-list { display: flex; flex-direction: column; gap: 7px; max-height: 320px; overflow-y: auto; }
.fm-row { display: flex; align-items: center; gap: 8px; }
.fm-row .fm-name { flex: 1; min-width: 0; font-size: 13px; font-weight: 600; padding: 7px 10px; border: 1px solid var(--border); border-radius: 8px; background: var(--bg2); color: var(--text); outline: none; }
.fm-row .fm-name:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-d); }
.fm-count { font-size: 11px; color: var(--text3); white-space: nowrap; flex-shrink: 0; }
.fm-save { flex-shrink: 0; background: var(--accent-d); color: var(--accent); border: 1px solid rgba(124,58,237,0.25); border-radius: 7px; padding: 6px 11px; font-size: 11.5px; font-weight: 700; cursor: pointer; }
.fm-del { flex-shrink: 0; background: var(--red-d, rgba(239,68,68,0.10)); color: var(--red, #dc2626); border: 1px solid rgba(239,68,68,0.22); border-radius: 7px; padding: 6px 10px; font-size: 12px; font-weight: 700; cursor: pointer; }

/* Inline SVG weather icons (replace emoji) - monochrome, muted slate */
.wxi { display: inline-block; vertical-align: middle; color: #64748b; }
.wxi-fc  { width: 23px; height: 23px; }
.wxi-now { width: 30px; height: 30px; }
.wxi-hr  { width: 22px; height: 22px; }
.ct-trophy svg    { width: 22px; height: 22px; }
.ct-prize-ico svg { width: 27px; height: 27px; }

/* Leaderboard Week / Month segmented toggle */
.dash-seg { display: inline-flex; background: var(--bg3); border-radius: 9px; padding: 3px; gap: 2px; }
.dash-seg-btn { border: none; background: transparent; color: var(--text3); font-size: 12px; font-weight: 700; padding: 5px 13px; border-radius: 7px; cursor: pointer; transition: all .14s ease; }
.dash-seg-btn:hover { color: var(--text2); }
.dash-seg-btn.on { background: var(--bg2); color: var(--accent); box-shadow: 0 1px 3px rgba(15,23,42,0.10); }

/* Shared roofing-day verdict badge */
.wx-verdict { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; font-weight: 700; padding: 6px 12px; border-radius: 9px; white-space: nowrap; }
.wx-verdict-dot { width: 16px; height: 16px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 10px; color: #fff; }
.wx-verdict.good { background: var(--green-d); color: #15803d; }
.wx-verdict.good .wx-verdict-dot { background: var(--green); }
.wx-verdict.fair { background: rgba(249,115,22,0.13); color: #c2410c; }
.wx-verdict.fair .wx-verdict-dot { background: var(--orange); }
.wx-verdict.bad  { background: rgba(239,68,68,0.12); color: #b91c1c; }
.wx-verdict.bad  .wx-verdict-dot { background: var(--red); }

/* ── Weather hero (neutral white card, calm) ──────────────────────────────── */
.wx-hero { background: var(--bg2); border: 1px solid var(--border); border-radius: 16px; padding: 16px 20px 18px; margin-bottom: 20px; }
.wx-hero-bar { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 0 0 14px; margin-bottom: 14px; border-bottom: 1px solid var(--border); }
.wx-hero-id { display: flex; align-items: center; gap: 13px; min-width: 0; }
.wx-hero-logo { width: 40px; height: 40px; border-radius: 11px; background: linear-gradient(135deg,#7c3aed,#6d28d9); display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 4px 12px rgba(124,58,237,0.28); }
.wx-hero-logo svg { width: 21px; height: 21px; }
.wx-hero-co { font-size: 17px; font-weight: 800; color: var(--text); letter-spacing: -0.3px; }
.wx-hero-loc { font-size: 12.5px; color: var(--text3); margin-top: 2px; display: flex; align-items: center; gap: 8px; }
.wx-hero-live { display: inline-flex; align-items: center; gap: 5px; color: #16a34a; font-weight: 700; }
.wx-live-pip { width: 7px; height: 7px; border-radius: 50%; background: #22c55e; box-shadow: 0 0 0 3px rgba(34,197,94,0.18); animation: wxpip 2s ease-in-out infinite; }
@keyframes wxpip { 0%,100% { opacity: 1; } 50% { opacity: .35; } }
.wx-hero-time { text-align: right; flex-shrink: 0; }
.wx-hero-clock { font-size: 22px; font-weight: 800; color: var(--text); letter-spacing: -0.5px; line-height: 1; font-variant-numeric: tabular-nums; }
.wx-hero-date { font-size: 11.5px; color: var(--text3); margin-top: 4px; }
.wx-hero-body { display: grid; grid-template-columns: 0.82fr 1.28fr; gap: 24px; }
@media (max-width: 900px) { .wx-hero-body { grid-template-columns: 1fr; gap: 18px; } }
/* split by a quiet divider - no nested boxes */
.wx-hero-fc { border-right: 1px solid var(--border); padding-right: 24px; }
@media (max-width: 900px) { .wx-hero-fc { border-right: none; padding-right: 0; padding-bottom: 16px; border-bottom: 1px solid var(--border); } }
.wx-hero-h { font-size: 11px; font-weight: 800; color: var(--text3); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 9px; }

/* forecast rows */
.wx-fc-list { padding: 0; }
.wx-fc-row { display: flex; align-items: center; gap: 11px; padding: 6px 8px; border-radius: 9px; }
.wx-fc-row.on { background: var(--accent-d); }
.wx-fc-ico { width: 24px; text-align: center; flex-shrink: 0; }
.wx-fc-day { font-size: 13px; font-weight: 700; color: var(--text); width: 42px; flex-shrink: 0; }
.wx-fc-temp { display: flex; gap: 6px; align-items: baseline; flex: 1; }
.wx-fc-temp b { font-size: 13.5px; font-weight: 800; color: var(--text); }
.wx-fc-temp span { font-size: 12px; color: var(--text3); }
.wx-fc-cond { font-size: 12px; font-weight: 600; text-align: right; white-space: nowrap; }
.wx-fc-hint { margin-top: 12px; padding: 10px 12px; background: var(--bg3); border: 1px solid var(--border); border-radius: 10px; display: flex; flex-direction: column; gap: 6px; }
.wx-rec { display: flex; align-items: center; gap: 9px; font-size: 11.5px; }
.wx-rec-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.wx-rec.good .wx-rec-dot { background: #16a34a; }
.wx-rec.rain .wx-rec-dot { background: #2563eb; }
.wx-rec-l { color: var(--text3); font-weight: 600; flex-shrink: 0; }
.wx-rec b { color: var(--text); font-weight: 700; margin-left: auto; text-align: right; }
/* clickable "schedule a crew" day chips */
.wx-rec-days { margin-left: auto; display: flex; gap: 5px; flex-wrap: wrap; justify-content: flex-end; }
.wx-rec-day { font: inherit; font-size: 11.5px; font-weight: 700; color: #15803d; background: rgba(34,197,94,0.10); border: 1px solid rgba(34,197,94,0.22); border-radius: 7px; padding: 2px 9px; cursor: pointer; transition: background .12s, transform .12s; }
.wx-rec-day:hover { background: rgba(34,197,94,0.20); transform: translateY(-1px); }
.wx-rec-day::after { content: " +"; font-weight: 800; opacity: .55; }

/* hourly + stats */
.wx-hr-top { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 12px; }
.wx-hr-now { display: flex; align-items: center; gap: 10px; }
.wx-hr-temp { font-size: 28px; font-weight: 800; letter-spacing: -1px; color: var(--text); line-height: 1; }
.wx-hours { display: grid; grid-template-columns: repeat(7, 1fr); gap: 7px; }
/* faintly tinted chips - workability via a soft wash + dot + coloured label */
.wx-hour { text-align: center; padding: 9px 3px; border-radius: 11px; border: 1px solid var(--border); background: var(--bg3); }
.wx-hour-t { font-size: 11px; font-weight: 700; color: var(--text3); }
.wx-hour-ico { margin: 5px 0 4px; line-height: 1; }
.wx-hour-temp { font-size: 14px; font-weight: 800; color: var(--text); }
.wx-hour-lbl { font-size: 9.5px; font-weight: 700; margin-top: 4px; display: inline-flex; align-items: center; gap: 4px; }
.wx-hour-lbl::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.wx-hour.good  { background: rgba(34,197,94,0.07);  border-color: rgba(34,197,94,0.18); }
.wx-hour.good  .wx-hour-lbl { color: #16a34a; }
.wx-hour.hot   { background: rgba(249,115,22,0.07); border-color: rgba(249,115,22,0.18); }
.wx-hour.hot   .wx-hour-lbl { color: #ea580c; }
.wx-hour.mod   { background: rgba(59,130,246,0.07); border-color: rgba(59,130,246,0.18); }
.wx-hour.mod   .wx-hour-lbl { color: #2563eb; }
.wx-hour.heavy { background: rgba(239,68,68,0.07);  border-color: rgba(239,68,68,0.18); }
.wx-hour.heavy .wx-hour-lbl { color: #dc2626; }
.wx-stats { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; margin-top: 13px; padding-top: 13px; border-top: 1px solid var(--border); }
.wx-stat { background: var(--bg3); border: 1px solid var(--border); border-radius: 10px; padding: 8px 6px; text-align: center; }
.wx-stat span { display: block; font-size: 10px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: .3px; }
.wx-stat b { display: block; font-size: 13px; font-weight: 800; color: var(--text); margin-top: 3px; }
@media (max-width: 560px) {
  .wx-hours { grid-template-columns: repeat(4, 1fr); }
  .wx-stats { grid-template-columns: repeat(3, 1fr); }
}

/* Contingencies KPI (centered big number + Today / This week mini-boxes) */
.ct-kpi { display: flex; flex-direction: column; }
.ct-big { font-size: 56px; font-weight: 800; letter-spacing: -2px; color: var(--text); line-height: 1; text-align: center; margin: 8px 0 2px; }
.ct-mini { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: auto; padding-top: 16px; }
.ct-mini-box { background: var(--bg1); border: 1px solid var(--border); border-radius: 11px; padding: 10px; text-align: center; }
.ct-mini-box span { display: block; font-size: 11px; font-weight: 600; color: var(--text3); }
.ct-mini-box b { display: block; font-size: 22px; font-weight: 800; color: var(--text); margin-top: 2px; }

/* Weekly contest card (neutral card, single amber accent) */
.ct-contest { background: var(--bg2); border: 1px solid var(--border); border-radius: 16px; padding: 16px 18px; display: flex; flex-direction: column; }
.ct-head { display: flex; align-items: center; gap: 12px; }
.ct-trophy { width: 40px; height: 40px; border-radius: 11px; background: rgba(245,158,11,0.18); display: flex; align-items: center; justify-content: center; font-size: 20px; flex-shrink: 0; }
.ct-head-main { flex: 1; min-width: 0; }
.ct-week { font-size: 14.5px; font-weight: 800; color: var(--text); }
.ct-range { font-size: 11.5px; font-weight: 600; color: var(--text3); margin-top: 2px; }
.ct-reset { text-align: right; flex-shrink: 0; }
.ct-reset span { display: block; font-size: 10px; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: .3px; }
.ct-reset b { font-size: 14px; font-weight: 800; color: var(--text); }
.ct-prize { display: flex; align-items: center; gap: 12px; margin: 14px 0; padding: 13px 14px; background: rgba(245,158,11,0.07); border: 1px solid rgba(245,158,11,0.18); border-radius: 12px; }
.ct-prize-ico { flex-shrink: 0; }
.ct-prize-name { font-size: 18px; font-weight: 800; color: var(--text); letter-spacing: -0.4px; }
.ct-prize-rule { font-size: 11.5px; font-weight: 500; color: var(--text3); margin-top: 2px; }
.ct-standings { margin-top: auto; display: flex; flex-direction: column; gap: 1px; }
.ct-rk { display: flex; align-items: center; gap: 11px; padding: 8px 10px; border-radius: 9px; }
.ct-rk.lead { background: rgba(245,158,11,0.09); }
.ct-rk-n { width: 18px; font-size: 12px; font-weight: 800; color: var(--text3); text-align: center; flex-shrink: 0; }
.ct-rk.lead .ct-rk-n { color: #d97706; }
.ct-rk-name { flex: 1; min-width: 0; font-size: 13.5px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ct-rk-ct { font-size: 16px; font-weight: 800; color: var(--text2); flex-shrink: 0; }
.ct-rk.lead .ct-rk-ct { color: #d97706; }
.ct-empty { text-align: center; font-size: 12.5px; color: var(--text3); font-weight: 500; padding: 20px 8px; margin-top: auto; }

/* ── Calendar / JobBoard ────────────────────────────────────────────────────── */
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; }
.cal-dow { background: var(--bg2); padding: 9px 8px; font-size: 11px; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: .4px; text-align: center; }
.cal-cell { background: var(--bg2); min-height: 106px; padding: 6px 7px; cursor: pointer; transition: background .12s; display: flex; flex-direction: column; gap: 3px; }
.cal-cell:hover { background: var(--bg1); }
.cal-cell.other-month { opacity: .45; }
.cal-daynum { font-size: 12px; font-weight: 600; color: var(--text2); width: 23px; height: 23px; display: flex; align-items: center; justify-content: center; border-radius: 50%; align-self: flex-start; }
.cal-cell.today .cal-daynum { background: var(--green); color: #fff; }
.cal-ev { font-size: 11px; font-weight: 600; padding: 3px 7px; border-radius: 6px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cal-ev.install  { background: var(--green-d);  color: var(--green); }
.cal-ev.delivery { background: var(--orange-d); color: var(--orange); }
.cal-ev.appointment { background: var(--blue-d); color: var(--blue); }
.cal-ev.other    { background: var(--bg3);      color: var(--text2); }
.cal-ev.task-high   { background: var(--red-d);  color: var(--red); }
.cal-ev.task-normal { background: var(--blue-d); color: var(--blue); }
.cal-ev.task-done   { background: var(--bg3);    color: var(--text3); text-decoration: line-through; }
.cal-dot.task-high   { background: var(--red); }
.cal-dot.task-normal { background: var(--blue); }
.cal-dot.task-done   { background: var(--text3); }
.cal-more { font-size: 10.5px; color: var(--text3); font-weight: 600; padding: 0 4px; }
/* Map measure-tool segment length label (pinned to the line midpoint) */
.measure-lbl {
  position: absolute; transform: translate(-50%, -50%); white-space: nowrap; pointer-events: none;
  background: #0f172a; color: #fff; font: 700 11px 'Inter', sans-serif;
  padding: 2px 7px; border-radius: 6px; box-shadow: 0 1px 5px rgba(0,0,0,0.45);
}
.cal-ev[draggable="true"] { cursor: grab; }
.cal-ev[draggable="true"]:active { cursor: grabbing; }
.cal-cell.cal-drop { background: var(--green-d); box-shadow: inset 0 0 0 2px var(--green); }
.cal-cell-hd { display: flex; align-items: center; justify-content: space-between; gap: 4px; }
.cal-chips { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.cal-dots { display: none; flex-wrap: wrap; gap: 3px; }
.cal-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.cal-dot.install  { background: var(--green); }
.cal-dot.delivery { background: var(--orange); }
.cal-dot.other    { background: var(--text3); }
.cal-agenda { display: none; }
/* Narrow screens: dots sit to the RIGHT of the day number, the event text wraps
   BELOW it on the calendar, AND a detailed agenda list is shown under the grid. */
@media (max-width: 760px) {
  .cal-dots   { display: flex; }
  .cal-ev     { white-space: normal; font-size: 10px; line-height: 1.25; padding: 2px 5px; }
  .cal-cell   { min-height: 62px; padding: 5px 4px; }
  .cal-dow    { padding: 7px 2px; font-size: 9.5px; }
  .cal-daynum { font-size: 12px; width: 20px; height: 20px; }
  .cal-agenda { display: block; margin-top: 20px; border-top: 1px solid var(--border); padding-top: 16px; }
}

/* ── Mobile: Estimates table → cards (phones only, scoped to .est-table) ──────
   Additive + scoped: desktop (>640px) and every OTHER table are untouched. On
   phones each row becomes a card with label:value pairs (via td[data-label]),
   so the action buttons no longer run off the screen / require sideways scroll. */
@media (max-width: 640px) {
  .est-table { display: block; }
  .est-table thead { display: none; }
  .est-table tbody { display: block; }
  .est-table tbody tr {
    display: block;
    background: var(--bg1);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 12px 14px;
    margin-bottom: 12px;
  }
  .est-table td[data-label] {
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
    text-align: right; padding: 5px 0; border: none;
  }
  .est-table td[data-label]::before {
    content: attr(data-label);
    font-size: 11px; font-weight: 700; letter-spacing: 0.4px; text-transform: uppercase;
    color: var(--text3); text-align: left; flex-shrink: 0;
  }
  /* Secondary columns: hidden on phones to keep the card scannable. */
  .est-table td[data-label="Pitch"],
  .est-table td[data-label="Squares"],
  .est-table td[data-label="Margin"] { display: none; }
  /* Customer = the card header: full-width, left-aligned, no inline label. */
  .est-table td[data-label="Customer"] {
    display: block; text-align: left; padding: 0 0 8px;
    margin-bottom: 6px; border-bottom: 1px solid var(--border);
  }
  .est-table td[data-label="Customer"]::before { display: none; }
  .est-table td[data-label="Customer"] > div:first-child { font-size: 15px; font-weight: 700; }
  /* Actions = full-width wrapping button row at the bottom of the card. */
  .est-table td[data-label="Actions"] {
    flex-wrap: wrap; justify-content: flex-start; gap: 6px;
    padding-top: 11px; margin-top: 5px; border-top: 1px solid var(--border);
  }
  .est-table td[data-label="Actions"]::before { display: none; }
  .est-table td[data-label="Actions"] .btn-sm { flex: 0 0 auto; }
}

/* ── Mobile: generic responsive table → cards (phones only, opt-in via .rtable) ─
   Any <table class="rtable"> whose <td>s carry data-label="..." becomes a card
   list on phones. Reused across Invoices/Projects/Leads/etc. Desktop untouched. */
@media (max-width: 640px) {
  .rtable, .rtable tbody { display: block; }
  .rtable thead { display: none; }
  .rtable tbody tr {
    display: block; background: var(--bg1);
    border: 1px solid var(--border); border-radius: 12px;
    padding: 12px 14px; margin-bottom: 12px;
  }
  .rtable td { display: block; text-align: left; border: none; padding: 4px 0; }
  .rtable td[data-label] {
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px; text-align: right; padding: 5px 0;
  }
  .rtable td[data-label]::before {
    content: attr(data-label);
    font-size: 11px; font-weight: 700; letter-spacing: 0.4px; text-transform: uppercase;
    color: var(--text3); text-align: left; flex-shrink: 0;
  }
  /* A cell marked data-label="" is a header/primary cell: full-width, no label. */
  .rtable td[data-label=""] { display: block; text-align: left; }
  .rtable td[data-label=""]::before { display: none; }
  /* The actions cell (last) wraps its buttons into a row at the card bottom. */
  .rtable td.rcell-actions {
    display: flex; flex-wrap: wrap; justify-content: flex-start; gap: 6px;
    padding-top: 11px; margin-top: 5px; border-top: 1px solid var(--border);
  }
  .rtable td.rcell-actions::before { display: none; }
}

/* ── Mobile: general polish (phones only · additive) ─────────────────────────
   Small layout fixes so existing screens aren't cramped on phones. All scoped
   to <=640px so desktop is untouched. */
@media (max-width: 640px) {
  /* Kanban already scrolls sideways; make each column near-full-width so the
     rep swipes one stage at a time instead of seeing slivers of three. */
  .pipeline { padding: 0 12px 14px; height: calc(100vh - 120px); }
  .pipeline-col { width: 80vw; max-width: 290px; }
  /* Card content + tables get a little breathing room back. */
  .card .table-wrap { -webkit-overflow-scrolling: touch; }
  /* Page header actions already wrap; let the title block use full width. */
  .page-hdr h1 { font-size: 22px; }
  /* Modals: roomier on phones, scrollable. */
  .modal { width: calc(100vw - 16px); max-height: 92vh; }

  /* ── Siding estimator form (phones) ──────────────────────────────────────
     The form is a 2-column grid (form + 340px price panel) with wide wall/
     opening entry grids. On phones: stack to one column, and let the multi-
     column wall/opening rows scroll horizontally as an aligned unit. */
  #si-form { grid-template-columns: 1fr !important; padding: 0 12px 32px !important; }
  .si-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .si-wrow { min-width: 460px; }
  .si-orow { min-width: 600px; }

  /* Reports: 4-up KPI grid is too tight on phones -> 2 columns. */
  #report-kpis { grid-template-columns: 1fr 1fr !important; }
}

/* ── Power dialer (cockpit) ───────────────────────────────────────────────── */
.pd-wrap { padding: 0 28px 34px; }
.pd-topbar { display: flex; align-items: center; gap: 18px; padding: 6px 0 22px; flex-wrap: wrap; }
.pd-topbar h1 { font-size: 20px; font-weight: 700; margin: 0; white-space: nowrap; }
.pd-progress { flex: 1; min-width: 140px; height: 8px; background: var(--bg3); border-radius: 8px; overflow: hidden; }
.pd-progress-fill { height: 100%; background: linear-gradient(90deg, var(--green2), var(--green)); border-radius: 8px; transition: width .35s ease; }
.pd-progress-label { font-size: 12.5px; color: var(--text2); font-weight: 600; white-space: nowrap; font-variant-numeric: tabular-nums; }
.pd-grid { display: grid; grid-template-columns: 1fr 280px; gap: 18px; align-items: start; }
.pd-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 16px; }
.pd-main { padding: 32px 26px 26px; text-align: center; box-shadow: 0 6px 26px rgba(0,0,0,.07); }
.pd-avatar { width: 74px; height: 74px; border-radius: 50%; margin: 0 auto 14px; display: flex; align-items: center; justify-content: center; font-size: 27px; font-weight: 700; color: #fff; background: linear-gradient(135deg, var(--green), var(--green2)); box-shadow: 0 8px 20px rgba(34,197,94,.30); letter-spacing: .5px; }
.pd-name { font-size: 23px; font-weight: 700; line-height: 1.2; }
.pd-phone { font-size: 15px; color: var(--text2); margin-top: 3px; font-variant-numeric: tabular-nums; }
.pd-badge { display: inline-block; margin-top: 11px; font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; padding: 4px 12px; border-radius: 20px; background: var(--bg3); color: var(--text2); }
.pd-state { margin-top: 24px; }
.pd-count { font-size: 46px; font-weight: 800; color: var(--green); line-height: 1; font-variant-numeric: tabular-nums; }
.pd-hint { font-size: 13px; color: var(--text2); margin-top: 6px; }
.pd-actions { display: flex; gap: 10px; justify-content: center; margin-top: 18px; flex-wrap: wrap; }
.pd-oncall { display: inline-flex; align-items: center; gap: 9px; font-size: 16px; font-weight: 600; color: var(--green); }
.pd-dot { width: 11px; height: 11px; border-radius: 50%; background: var(--green); animation: pd-pulse 1.4s infinite; }
@keyframes pd-pulse { 0% { box-shadow: 0 0 0 0 rgba(34,197,94,.45); } 70% { box-shadow: 0 0 0 10px rgba(34,197,94,0); } 100% { box-shadow: 0 0 0 0 rgba(34,197,94,0); } }
.pd-note { width: 100%; box-sizing: border-box; padding: 10px 12px; border: 1px solid var(--bord2); border-radius: 10px; background: var(--bg3); color: var(--text); font-size: 13.5px; font-family: inherit; resize: vertical; margin-bottom: 14px; }
.pd-dispo-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 9px; }
.pd-dispo { display: flex; align-items: center; gap: 9px; cursor: pointer; border: 1px solid var(--bord2); background: var(--bg3); color: var(--text); border-radius: 11px; padding: 11px 13px; font-size: 13px; font-weight: 600; text-align: left; transition: background .15s, border-color .15s, transform .05s; }
.pd-dispo:hover { background: var(--bg4); border-color: var(--bord3); }
.pd-dispo:active { transform: scale(.98); }
.pd-dispo i { width: 9px; height: 9px; border-radius: 50%; flex: 0 0 auto; }
.pd-skip { margin-top: 14px; }
.pd-side { display: flex; flex-direction: column; gap: 14px; }
.pd-side-sec { background: var(--bg2); border: 1px solid var(--border); border-radius: 14px; padding: 16px 18px; }
.pd-side-title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--text3); margin-bottom: 12px; }
.pd-up-item { display: flex; align-items: center; gap: 10px; padding: 8px 0; }
.pd-up-item + .pd-up-item { border-top: 1px solid var(--border); }
.pd-up-ava { width: 32px; height: 32px; border-radius: 50%; background: var(--bg3); color: var(--text2); display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; flex: 0 0 auto; }
.pd-up-name { font-size: 13px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pd-up-phone { font-size: 11.5px; color: var(--text3); font-variant-numeric: tabular-nums; }
.pd-up-empty { font-size: 12.5px; color: var(--text3); }
.pd-stat { display: flex; align-items: baseline; justify-content: space-between; padding: 5px 0; }
.pd-stat-label { font-size: 13px; color: var(--text2); }
.pd-stat-num { font-size: 18px; font-weight: 700; font-variant-numeric: tabular-nums; }
.pd-outcome { text-align: left; max-width: 440px; margin: 18px auto 0; display: flex; flex-direction: column; gap: 16px; }
.pd-row { display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.pd-row-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--text3); }
.pd-ok { font-size: 12.5px; color: var(--green); font-weight: 600; }
.pd-task-fields { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 8px; }
.pd-input { padding: 8px 10px; border: 1px solid var(--bord2); border-radius: 9px; background: var(--bg3); color: var(--text); font-size: 13px; font-family: inherit; }
@media (max-width: 860px) {
  .pd-wrap { padding: 0 16px 28px; }
  .pd-grid { grid-template-columns: 1fr; }
  .pd-side { flex-direction: row; flex-wrap: wrap; }
  .pd-side-sec { flex: 1; min-width: 150px; }
}
/* 3-Line (parallel) dialer: the live ringing lines. */
.pd3-lines { display: flex; flex-direction: column; gap: 9px; text-align: left; }
.pd3-line { display: flex; align-items: center; gap: 11px; padding: 11px 13px; border: 1px solid var(--border); border-radius: 11px; background: var(--bg2); }
.pd3-line-ava { width: 34px; height: 34px; border-radius: 50%; background: var(--bg3); color: var(--text2); display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; flex: 0 0 auto; }
.pd3-line-status { font-size: 12.5px; font-weight: 700; white-space: nowrap; }
.pd3-ring { border-color: var(--bord3); animation: pd3-ring 1.3s ease-in-out infinite; }
@keyframes pd3-ring { 0%,100% { background: var(--bg2); } 50% { background: var(--bg3); } }

/* ── Automation builder ───────────────────────────────────────────────────── */
.au-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
.au-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 14px; padding: 16px 18px; cursor: pointer; transition: border-color .15s, transform .05s; }
.au-card:hover { border-color: var(--bord3); }
.au-card:active { transform: scale(.995); }
.au-card-name { font-weight: 700; font-size: 15px; margin-bottom: 8px; }
.au-badge { display: inline-block; font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; padding: 3px 9px; border-radius: 20px; }
.au-badge.active { background: var(--green-d); color: var(--green); }
.au-badge.draft { background: var(--bg3); color: var(--text3); }
.au-badge.paused { background: var(--red-d); color: var(--red); }
/* node icon chip (shared by canvas nodes + palette pick) */
.au-node-ic { width: 36px; height: 36px; border-radius: 10px; display: flex; align-items: center; justify-content: center; flex: 0 0 auto; background: var(--bg3); box-shadow: inset 0 0 0 1px rgba(127,127,127,0.06); }
.au-node-ic svg { width: 18px; height: 18px; display: block; }
.au-node-tt { font-weight: 700; font-size: 13.5px; }
.au-node-sb { font-size: 12px; color: var(--text3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* builder layout: free canvas left, draggable palette docked right */
.au-build { display: flex; align-items: flex-start; gap: 16px; }
.au-cv-wrap { flex: 1; min-width: 0; }
.au-cv { position: relative; overflow: auto; height: calc(100vh - 210px); min-height: 440px; border: 1px solid var(--border); border-radius: 14px; background-color: var(--bg1); background-image: radial-gradient(rgba(127,127,127,0.13) 1px, transparent 1px); background-size: 22px 22px; }
.au-cv-hint { position: absolute; left: 50%; top: 120px; transform: translateX(-50%); text-align: center; font-size: 13px; color: var(--text3); line-height: 1.7; pointer-events: none; }
.au-edges { position: absolute; top: 0; left: 0; pointer-events: none; overflow: visible; }
.au-edge { fill: none; stroke-width: 2.5; }
.au-edge-temp { fill: none; stroke: var(--accent); stroke-width: 2.5; stroke-dasharray: 6 5; }
.au-markers { position: absolute; top: 0; left: 0; right: 0; bottom: 0; pointer-events: none; }
.au-edge-x { position: absolute; transform: translate(-50%, -50%); width: 18px; height: 18px; padding: 0; border: none; border-radius: 50%; background: var(--bg2); color: var(--text3); box-shadow: 0 0 0 1px var(--bord2); font-size: 11px; line-height: 1; cursor: pointer; opacity: 0; transition: opacity .12s, color .12s, box-shadow .12s; pointer-events: auto; }
.au-cv:hover .au-edge-x { opacity: .85; }
.au-edge-x:hover { color: var(--red); box-shadow: 0 0 0 2px var(--red); opacity: 1; }

/* free-canvas node */
.au-gnode { position: absolute; width: 210px; box-sizing: border-box; background: var(--bg2); border: 1px solid var(--border); border-radius: 14px; padding: 11px 12px; box-shadow: 0 3px 14px rgba(0,0,0,.08); cursor: grab; user-select: none; touch-action: none; transition: box-shadow .12s, border-color .12s; }
.au-gnode:hover { border-color: var(--bord3); box-shadow: 0 8px 22px rgba(0,0,0,.12); }
.au-gnode.au-gn-drag { cursor: grabbing; box-shadow: 0 16px 36px rgba(0,0,0,.2); z-index: 6; }
.au-gnode.au-gn-target { box-shadow: 0 0 0 2px var(--green), 0 8px 22px rgba(0,0,0,.12); border-color: var(--green); }
.au-gn-trigger { width: 290px; background: linear-gradient(135deg, var(--accent), var(--accent2)); color: #fff; border: none; }
.au-gn-branch { background: linear-gradient(135deg, #d97706, #b45309); color: #fff; border: none; }
.au-gnode:not(.au-gn-trigger):not(.au-gn-branch)::before { content: ''; position: absolute; left: 0; top: 11px; bottom: 11px; width: 3px; border-radius: 0 3px 3px 0; background: var(--accent-clr, var(--border)); }
.au-gn-row { display: flex; align-items: center; gap: 11px; }
.au-gn-bd { flex: 1; min-width: 0; }
.au-gn-ax { display: flex; gap: 2px; flex: 0 0 auto; opacity: .6; transition: opacity .12s; }
.au-gnode:hover .au-gn-ax { opacity: 1; }
.au-gn-ax button { width: 26px; height: 26px; border: none; background: transparent; color: inherit; border-radius: 7px; cursor: pointer; font-size: 12.5px; opacity: .8; }
.au-gn-ax button:hover { background: rgba(127,127,127,.18); opacity: 1; }
.au-trig-sel { background: rgba(0,0,0,0.18); color: #fff; border: none; border-radius: 6px; padding: 3px 22px 3px 8px; font-size: 12px; width: 100%; max-width: 100%; box-sizing: border-box; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.au-trig-sel option { color: #111; }

/* connection ports */
.au-port { position: absolute; width: 14px; height: 14px; border-radius: 50%; background: var(--bg2); border: 2px solid var(--bord3); left: 50%; transform: translateX(-50%); z-index: 3; }
.au-in { top: -8px; }
.au-out { bottom: -8px; cursor: crosshair; touch-action: none; }
.au-out:hover { border-color: var(--green); background: var(--green); transform: translateX(-50%) scale(1.2); }
.au-out-yes { left: 30%; border-color: #16a34a; }
.au-out-no { left: 70%; border-color: #e11d48; }
.au-out-yes::after { content: 'Yes'; position: absolute; top: 13px; left: 50%; transform: translateX(-50%); font-size: 9px; font-weight: 700; color: #16a34a; }
.au-out-no::after { content: 'No'; position: absolute; top: 13px; left: 50%; transform: translateX(-50%); font-size: 9px; font-weight: 700; color: #e11d48; }

/* palette (right dock) */
.au-pick-ic { width: 30px; height: 30px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; margin-right: 10px; flex: 0 0 auto; }
.au-pick-ic svg { width: 17px; height: 17px; display: block; }
.au-palette { flex: 0 0 200px; display: flex; flex-direction: column; align-items: stretch; gap: 8px; padding: 13px 13px 15px; background: var(--bg3); border: 1px solid var(--border); border-radius: 14px; position: sticky; top: 14px; }
.au-pal-lbl { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--text3); margin: 0 0 2px 2px; }
.au-pal-chip { display: flex; align-items: center; gap: 9px; padding: 7px 11px 7px 7px; background: var(--bg2); border: 1px solid var(--bord2); border-radius: 10px; font-size: 12.5px; font-weight: 600; color: var(--text); cursor: grab; user-select: none; transition: box-shadow .12s, transform .08s, border-color .12s; }
.au-pal-chip:hover { border-color: var(--bord3); box-shadow: 0 3px 10px rgba(0,0,0,.09); transform: translateY(-1px); }
.au-pal-chip:active { cursor: grabbing; transform: scale(.97); }
.au-pal-ic { width: 26px; height: 26px; border-radius: 7px; display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.au-pal-ic svg { width: 16px; height: 16px; display: block; }
@media (max-width: 760px) {
  .au-build { flex-direction: column; }
  .au-cv { height: 70vh; }
  .au-palette { flex: none; width: 100%; flex-direction: row; flex-wrap: wrap; align-items: center; position: static; order: -1; }
  .au-palette .au-pal-lbl { width: 100%; }
}

/* ── Supplement AI ──────────────────────────────────────────────────────── */
.supp-layout { display: flex; height: calc(100vh - 130px); overflow: hidden; }

/* ── Left panel ── */
.supp-list-col {
  width: 290px; flex-shrink: 0; border-right: 1px solid var(--border);
  display: flex; flex-direction: column; overflow: hidden; background: var(--bg1);
}
.supp-list-col-top { padding: 12px 12px 8px; border-bottom: 1px solid var(--border); }
.supp-search {
  width: 100%; background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--r); color: var(--text); padding: 8px 12px; font-size: 13px;
}
.supp-search:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-d); }
.supp-list-inner-scroll { flex: 1; overflow-y: auto; padding: 8px; }
.supp-list-item {
  display: flex; align-items: flex-start; gap: 10px; padding: 11px 10px;
  border-radius: var(--r); cursor: pointer; margin-bottom: 3px;
  border: 1px solid transparent; transition: var(--trans);
}
.supp-list-item:hover { background: var(--bg3); border-color: var(--border); }
.supp-list-item.active {
  background: var(--accent-d); border-color: rgba(124,58,237,0.3);
  box-shadow: inset 3px 0 0 var(--accent);
}
.supp-list-main { flex: 1; min-width: 0; }
.supp-list-name { font-weight: 600; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--text); }
.supp-list-meta { font-size: 11.5px; color: var(--text3); margin-top: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.supp-list-counts { font-size: 11px; color: var(--text3); margin-top: 3px; }
.supp-list-right { display: flex; flex-direction: column; align-items: flex-end; gap: 5px; flex-shrink: 0; }
.supp-list-total { font-size: 12px; font-weight: 700; color: var(--green); }
.supp-list-loading { padding: 32px 16px; text-align: center; color: var(--text3); font-size: 13px; }
.supp-list-empty { padding: 32px 12px; text-align: center; color: var(--text3); font-size: 13px; line-height: 1.7; }

/* ── Right panel ── */
.supp-detail-col { flex: 1; overflow-y: auto; background: var(--bg0); }
.supp-loading { padding: 60px; text-align: center; color: var(--text3); font-size: 14px; }

/* ── Empty state ── */
.supp-empty-state {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  height: 100%; padding: 48px; text-align: center;
}
.supp-empty-icon { font-size: 52px; margin-bottom: 20px; opacity: 0.7; }
.supp-empty-title { font-size: 20px; font-weight: 700; margin-bottom: 10px; letter-spacing: -0.3px; }
.supp-empty-sub { color: var(--text3); font-size: 14px; max-width: 380px; line-height: 1.6; margin-bottom: 28px; }
.supp-how-it-works { display: flex; flex-direction: column; gap: 10px; text-align: left; max-width: 320px; margin-bottom: 28px; }
.supp-how-step { display: flex; align-items: center; gap: 12px; font-size: 13.5px; color: var(--text2); }
.supp-how-num {
  width: 26px; height: 26px; border-radius: 50%; background: var(--accent-d);
  color: var(--accent); font-weight: 700; font-size: 12px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  border: 1.5px solid rgba(124,58,237,0.4);
}

/* ── Detail header ── */
.supp-detail-hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 28px; background: var(--bg1);
  border-bottom: 1px solid var(--border);
}
.supp-detail-name { font-size: 17px; font-weight: 700; letter-spacing: -0.3px; }
.supp-detail-sub { font-size: 12.5px; color: var(--text3); margin-top: 3px; }
.supp-detail-hdr-right { display: flex; align-items: center; gap: 12px; }
.supp-approved-total {
  font-size: 16px; font-weight: 700; color: var(--green);
  background: var(--green-d); padding: 4px 12px; border-radius: 20px;
  border: 1px solid rgba(34,197,94,0.2);
}

/* ── Tabs ── */
.supp-tabs {
  display: flex; background: var(--bg1);
  border-bottom: 1px solid var(--border); padding: 0 20px; gap: 0;
  position: sticky; top: 0; z-index: 20;
  box-shadow: 0 2px 6px rgba(0,0,0,0.04);
}
.supp-tab {
  background: none; border: none; color: var(--text3);
  padding: 13px 15px; font-size: 13px; cursor: pointer;
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: var(--trans); white-space: nowrap;
}
.supp-tab:hover { color: var(--text); }
.supp-tab.active { color: var(--accent); border-bottom-color: var(--accent); font-weight: 600; }
.supp-tab-check { color: var(--green); font-size: 11px; margin-left: 2px; }
.supp-tab-body { padding: 28px 32px; max-width: 1080px; margin: 0 auto; }

/* ── Step hint ── */
.supp-step-hint {
  display: flex; align-items: flex-start; gap: 10px;
  background: var(--bg2); border: 1px solid var(--border);
  border-left: 3px solid var(--accent); border-radius: 0 var(--r) var(--r) 0;
  padding: 11px 16px; font-size: 13px; color: var(--text2);
  margin-bottom: 22px; line-height: 1.6;
}

/* ── Form ── */
.supp-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.supp-form-group { display: flex; flex-direction: column; gap: 6px; }
.supp-form-group label {
  font-size: 11.5px; color: var(--text3); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.5px;
}
.supp-form-group input, .supp-form-group textarea {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--r); color: var(--text); padding: 9px 12px; font-size: 13.5px; width: 100%;
  transition: var(--trans);
}
.supp-form-group input:focus, .supp-form-group textarea:focus {
  outline: none; border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-d);
}
.supp-form-full { grid-column: 1 / -1; }
.supp-form-footer { margin-top: 20px; display: flex; align-items: center; gap: 12px; padding-top: 16px; border-top: 1px solid var(--border); }
.supp-label-hint { font-weight: 400; text-transform: none; letter-spacing: 0; color: var(--text3); font-size: 11px; }
.supp-saved-msg { color: var(--green); font-size: 13px; font-weight: 500; }
.supp-cust-wrap { position: relative; }
.supp-cust-wrap input { width: 100%; }
.supp-dropdown {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0;
  background: var(--bg3); border: 1px solid var(--bord2);
  border-radius: var(--r); z-index: 200; max-height: 200px; overflow-y: auto;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.supp-dd-item { padding: 10px 14px; font-size: 13px; cursor: pointer; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.supp-dd-item:last-child { border-bottom: none; }
.supp-dd-item:hover { background: var(--accent-d); color: var(--text); }
.supp-dd-empty { padding: 10px 14px; font-size: 12.5px; color: var(--text3); }

/* ── Scope tab ── */
.supp-section {
  background: var(--bg1); border: 1px solid var(--border);
  border-radius: var(--r2); padding: 18px 20px; margin-bottom: 18px;
}
.supp-section:last-child { margin-bottom: 0; }
.supp-section-lbl {
  font-size: 11px; color: var(--text3); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.6px; margin-bottom: 10px;
}
.supp-upload-box {
  background: var(--bg2); border: 2px dashed var(--border);
  border-radius: var(--r2); padding: 32px; text-align: center;
  cursor: pointer; transition: var(--trans); font-size: 14px; color: var(--text2);
}
.supp-upload-box:hover { border-color: var(--accent); background: var(--accent-d); color: var(--text); }
.supp-upload-icon { font-size: 36px; margin-bottom: 10px; display: block; }
.supp-upload-hint { font-size: 12px; color: var(--text3); margin-top: 8px; }
.supp-pdf-ok { color: var(--green); font-weight: 600; }
.supp-status-msg { min-height: 22px; margin-top: 10px; font-size: 13px; }
.supp-status-blue { color: var(--blue); }
.supp-status-green { color: var(--green); }
.supp-status-red { color: var(--red); }

/* ── Photos tab ── */
.supp-photo-drop {
  background: var(--bg2); border: 2px dashed var(--border);
  border-radius: var(--r2); padding: 28px; text-align: center;
  cursor: pointer; transition: var(--trans); font-size: 14px; color: var(--text2);
}
.supp-photo-drop:hover, .supp-photo-drop.dragover {
  border-color: var(--accent); background: var(--accent-d); color: var(--text);
}
.supp-photo-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(108px, 1fr));
  gap: 10px; margin-top: 10px;
}
/* Compact dropzone (horizontal) so the panels below stay visible without scrolling */
.supp-photo-drop-sm {
  display: flex; align-items: center; justify-content: center; gap: 12px;
  padding: 14px 18px; text-align: left;
}
.supp-upload-icon-sm { font-size: 22px; line-height: 1; }
.supp-drop-text { display: flex; flex-direction: column; line-height: 1.3; }
.supp-drop-text .supp-upload-hint { margin-top: 2px; }
/* Prominent "add from client" panel so it isn't buried at the bottom */
.supp-photos-panel {
  margin-top: 14px; border: 1px solid var(--accent, #2fa86e);
  background: var(--accent-d, rgba(47,168,110,0.08));
  border-radius: var(--r2); padding: 14px 16px;
}
.supp-photos-panel-muted {
  border-color: var(--border); background: var(--bg2);
  color: var(--text2); font-size: 13px;
}
.supp-photos-panel-hdr { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.supp-photos-panel-icon { font-size: 22px; line-height: 1; }
.supp-photos-panel-title { font-weight: 700; font-size: 14px; }
.supp-photos-panel-sub { font-size: 12px; color: var(--text3); margin-top: 2px; }
.supp-thumb {
  position: relative; border-radius: var(--r); overflow: hidden;
  aspect-ratio: 1; background: var(--bg2);
  border: 1px solid var(--border); transition: var(--trans);
}
.supp-thumb:hover { border-color: var(--bord2); }
.supp-thumb img { width: 100%; height: 100%; object-fit: cover; cursor: zoom-in; display: block; }
.supp-thumb-del {
  position: absolute; top: 5px; right: 5px; background: rgba(0,0,0,0.75);
  border: none; color: #fff; width: 24px; height: 24px; border-radius: 50%;
  cursor: pointer; font-size: 15px; display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: var(--trans);
}
.supp-thumb:hover .supp-thumb-del { opacity: 1; }

/* ── Add-from-client photos (one-click attach, no re-upload) ── */
.supp-cust-photos-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); gap: 10px;
}
.supp-cust-photo {
  position: relative; border-radius: var(--r); overflow: hidden;
  aspect-ratio: 1; background: var(--bg2); border: 1px solid var(--border);
}
.supp-cust-photo img { width: 100%; height: 100%; object-fit: cover; cursor: zoom-in; display: block; }
.supp-cust-photo.added { opacity: 0.5; }
.supp-cust-photo-add {
  position: absolute; bottom: 6px; left: 50%; transform: translateX(-50%);
  font-size: 11px; font-weight: 600; padding: 4px 12px; border-radius: 999px;
  border: none; background: var(--accent, #2fa86e); color: #fff; cursor: pointer;
  white-space: nowrap; box-shadow: 0 1px 4px rgba(0,0,0,0.3);
}
.supp-cust-photo-add:disabled { background: rgba(127,127,127,0.7); cursor: default; }

/* ── Measurement report (Scope tab) ── */
.supp-measure-current {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  border: 1px solid var(--accent, #2fa86e); background: var(--accent-d, rgba(47,168,110,0.08));
  border-radius: var(--r); margin-bottom: 12px;
}
.supp-measure-ico { font-size: 18px; line-height: 1; }
.supp-measure-name { font-weight: 600; font-size: 13px; color: var(--text); text-decoration: none; word-break: break-word; }
.supp-measure-name:hover { text-decoration: underline; }
.supp-measure-avail-lbl { font-size: 12px; color: var(--text3); margin: 4px 0 6px; }
.supp-measure-list { display: flex; flex-direction: column; gap: 6px; }
.supp-measure-item {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 8px 12px; border: 1px solid var(--border); border-radius: var(--r); background: var(--bg2);
}
.supp-measure-attach {
  flex-shrink: 0; font-size: 11px; font-weight: 600; padding: 4px 12px; border-radius: 999px;
  border: none; background: var(--accent, #2fa86e); color: #fff; cursor: pointer;
}
.supp-measure-attach:disabled { background: rgba(127,127,127,0.7); cursor: default; }

/* ── AI Items tab ── */
.supp-items-toolbar {
  display: flex; flex-direction: column; align-items: stretch; gap: 14px;
  margin-bottom: 24px;
}
.supp-readiness {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--r2); padding: 16px 18px; width: 100%;
}
.supp-readiness-title {
  font-size: 10.5px; font-weight: 700; color: var(--text3);
  text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 8px;
}
.supp-readiness-row { font-size: 12.5px; color: var(--text2); line-height: 1.9; display: flex; align-items: baseline; gap: 6px; }
.supp-ready-ok { color: var(--green); }
.supp-ready-no { color: var(--text3); }
.supp-ready-hint { font-size: 11px; color: var(--text3); }
.supp-analyze-row {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--r2); padding: 14px 18px;
}
.supp-analyze-btn { display: inline-flex; align-items: center; gap: 8px; }
.supp-items-total { font-size: 14px; font-weight: 600; color: var(--green); margin-left: auto; }
.supp-bulk-actions {
  margin-bottom: 14px; display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r);
  padding: 10px 14px;
}
.supp-items-empty { text-align: center; padding: 60px 24px; color: var(--text3); }

/* ── Internal / Adjuster preview toggle ── */
.supp-preview-bar {
  margin-bottom: 14px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
}
.supp-preview-toggle {
  display: inline-flex; background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--r); padding: 3px; flex-shrink: 0;
}
.supp-seg {
  border: none; background: none; color: var(--text2); cursor: pointer;
  font-size: 13px; font-weight: 600; padding: 6px 14px; border-radius: calc(var(--r) - 3px);
  transition: all 0.15s ease;
}
.supp-seg:hover { color: var(--text); }
.supp-seg.active { background: #7c3aed; color: #fff; }
.supp-preview-note { font-size: 12.5px; color: var(--text3); line-height: 1.5; flex: 1; min-width: 200px; }
.supp-summary {
  background: var(--blue-d); border: 1px solid rgba(59,130,246,0.25);
  border-radius: var(--r); padding: 12px 16px; font-size: 13px;
  margin-bottom: 16px; line-height: 1.6; color: var(--text2);
}

/* ── Items table ── */
.supp-table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: var(--r); }
.supp-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.supp-table thead { background: var(--bg2); }
.supp-table th {
  text-align: left; padding: 13px 12px; font-size: 10.5px;
  color: var(--text3); text-transform: uppercase; letter-spacing: 0.6px;
  border-bottom: 1px solid var(--border); white-space: nowrap; font-weight: 700;
}
.supp-table td { padding: 12px 10px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.supp-table tbody tr:last-child td { border-bottom: none; }
.supp-table tbody tr:hover td { background: var(--bg2); }
.supp-cell {
  background: transparent; border: 1px solid transparent;
  border-radius: 4px; color: var(--text); padding: 4px 7px; font-size: 13px;
  transition: var(--trans);
}
.supp-cell:hover, .supp-cell:focus {
  background: var(--bg3); border-color: var(--accent); outline: none;
}
.supp-cell-wide { width: 100%; min-width: 170px; }
.supp-cell-total { font-weight: 700; white-space: nowrap; color: var(--text); }
.supp-reason { font-size: 11px; color: var(--text3); margin-top: 4px; line-height: 1.5; max-width: 320px; }
.supp-conf { font-size: 10.5px; font-weight: 600; padding: 2px 8px; border-radius: 10px; }
.supp-conf-high { background: rgba(34,197,94,0.14); color: var(--green); border: 1px solid rgba(34,197,94,0.2); }
.supp-conf-med  { background: rgba(234,179,8,0.14); color: var(--yellow); border: 1px solid rgba(234,179,8,0.2); }
.supp-conf-low  { background: rgba(239,68,68,0.10); color: var(--red); border: 1px solid rgba(239,68,68,0.18); }
.supp-row-actions { display: flex; gap: 4px; }
.supp-btn-approve {
  background: rgba(34,197,94,0.12); color: var(--green);
  border: 1px solid rgba(34,197,94,0.2); border-radius: 5px;
  width: 28px; height: 28px; cursor: pointer; font-size: 13px;
  display: flex; align-items: center; justify-content: center; transition: var(--trans);
}
.supp-btn-approve:hover { background: var(--green); color: #000; border-color: var(--green); }
.supp-btn-reject {
  background: rgba(239,68,68,0.10); color: var(--red);
  border: 1px solid rgba(239,68,68,0.18); border-radius: 5px;
  width: 28px; height: 28px; cursor: pointer; font-size: 13px;
  display: flex; align-items: center; justify-content: center; transition: var(--trans);
}
.supp-btn-reject:hover { background: var(--red); color: #fff; border-color: var(--red); }
.supp-btn-del {
  background: none; color: var(--text3); border: 1px solid transparent;
  width: 28px; height: 28px; cursor: pointer; border-radius: 5px;
  font-size: 13px; display: flex; align-items: center; justify-content: center; transition: var(--trans);
}
.supp-btn-del:hover { background: var(--red-d); color: var(--red); border-color: rgba(239,68,68,0.2); }

.btn-danger-sm {
  background: var(--red-d); color: var(--red);
  border: 1px solid rgba(239,68,68,0.25); border-radius: var(--r);
  padding: 7px 14px; font-size: 13px; cursor: pointer; transition: var(--trans);
}
.btn-danger-sm:hover { background: var(--red); color: #fff; }

/* ── Add item inline ── */
.supp-add-item-inline {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--r2); padding: 18px; margin-bottom: 16px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.supp-add-item-grid { display: grid; grid-template-columns: 2fr 1fr 80px 90px 110px; gap: 10px; }
.supp-add-item-grid .supp-form-group select {
  background: var(--bg3); border: 1px solid var(--border);
  border-radius: var(--r); color: var(--text); padding: 9px 12px; font-size: 13px; width: 100%;
}

/* ── Totals & export ── */
.supp-totals-block {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 24px; margin-top: 24px;
  background: var(--bg1); border: 1px solid var(--border);
  border-radius: var(--r2); padding: 20px 24px; flex-wrap: wrap;
}
.supp-totals-left { flex: 1; min-width: 220px; }
.supp-op-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.supp-op-label { font-size: 11px; color: var(--text3); font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; }
.supp-op-field-wrap { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--text2); }
.supp-op-input {
  width: 54px; background: var(--bg3); border: 1px solid var(--bord2);
  border-radius: var(--r); color: var(--text); padding: 5px 8px; font-size: 13px;
  text-align: center; transition: var(--trans);
}
.supp-op-input:focus { outline: none; border-color: var(--accent); }
.supp-totals-right { min-width: 250px; }
.supp-tot-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 7px 0; font-size: 13.5px; gap: 20px;
  border-bottom: 1px solid var(--border);
}
.supp-tot-row:last-child { border-bottom: none; }
.supp-tot-grand {
  font-weight: 700; font-size: 16px;
  color: var(--green); background: var(--green-d);
  border: 1px solid rgba(34,197,94,0.2); border-radius: var(--r);
  padding: 8px 12px; margin-top: 8px; display: flex;
  justify-content: space-between; gap: 20px;
}
.supp-export-bar {
  display: flex; gap: 10px; margin-top: 18px; flex-wrap: wrap; align-items: center;
  padding-top: 18px; border-top: 1px solid var(--border);
}
/* Export/send actions, top-right of the items table (above the list). */
.supp-export-actions {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
  margin-left: auto; flex-shrink: 0;
}
.supp-export-actions .btn-primary, .supp-export-actions .btn-sec {
  padding: 6px 12px; font-size: 13px;
}
.supp-btn-disabled { opacity: 0.45; cursor: not-allowed; pointer-events: none; }
.supp-email-modal {
  background: var(--bg1); border: 1px solid var(--bord2);
  border-radius: var(--r2); padding: 28px; width: 500px;
  max-width: 94vw; box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}
.supp-email-modal-hdr { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.supp-email-modal-title { font-size: 17px; font-weight: 700; letter-spacing: -0.3px; }

/* ── Spinner ── */
.supp-spin {
  width: 14px; height: 14px; border: 2px solid rgba(255,255,255,0.25);
  border-top-color: #fff; border-radius: 50%;
  animation: spin 0.7s linear infinite; display: inline-block; vertical-align: middle;
}
@keyframes spin { to { transform: rotate(360deg); } }

@media (max-width: 780px) {
  .supp-layout { flex-direction: column; height: auto; }
  .supp-list-col { width: 100%; height: 260px; border-right: none; border-bottom: 1px solid var(--border); }
  .supp-detail-col { min-height: 400px; }
  .supp-form-grid { grid-template-columns: 1fr; }
  .supp-add-item-grid { grid-template-columns: 1fr 1fr; }
  .supp-table th:nth-child(7), .supp-table td:nth-child(7) { display: none; }
}

/* ══ AI Job Assistant - floating chatbox (bottom-right of customer detail) ══ */
.jobai-widget { position: fixed; right: 24px; bottom: 24px; z-index: 1400; }

/* Launcher pill (shown when closed) */
.jobai-fab {
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  padding: 12px 18px; border: none; border-radius: 999px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #fff; font-weight: 700; font-size: 14px; letter-spacing: 0.2px;
  box-shadow: 0 8px 28px rgba(124,58,237,0.45); transition: transform .12s, box-shadow .12s;
}
.jobai-fab:hover { transform: translateY(-2px); box-shadow: 0 12px 34px rgba(124,58,237,0.55); }
.jobai-fab-ic { font-size: 18px; line-height: 1; }
.jobai-widget.open .jobai-fab { display: none; }

/* Chat panel */
.jobai-panel {
  display: none; flex-direction: column; width: 390px; max-width: calc(100vw - 32px);
  height: 600px; max-height: calc(100vh - 110px);
  background: var(--bg1); border: 1px solid var(--bord2); border-radius: var(--r3);
  box-shadow: 0 18px 60px rgba(0,0,0,0.55); overflow: hidden;
  animation: jobaiPop .16s ease;
}
.jobai-widget.open .jobai-panel { display: flex; }
@keyframes jobaiPop { from { opacity: 0; transform: translateY(12px) scale(0.98); } to { opacity: 1; transform: none; } }

/* Header */
.jobai-head {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 13px 14px; background: linear-gradient(135deg, var(--accent), var(--accent2)); color: #fff; flex-shrink: 0;
}
.jobai-head-l { display: flex; align-items: center; gap: 10px; min-width: 0; }
.jobai-avatar { width: 34px; height: 34px; border-radius: 50%; background: rgba(255,255,255,0.2); display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.jobai-title { font-weight: 700; font-size: 14px; line-height: 1.2; }
.jobai-sub { font-size: 11.5px; opacity: 0.85; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 220px; }
.jobai-head-r { display: flex; gap: 4px; flex-shrink: 0; }
.jobai-iconbtn { width: 30px; height: 30px; border: none; background: rgba(255,255,255,0.16); color: #fff; border-radius: 8px; cursor: pointer; font-size: 15px; line-height: 1; transition: background .12s; }
.jobai-iconbtn:hover { background: rgba(255,255,255,0.3); }

/* Messages */
.jobai-messages { flex: 1; overflow-y: auto; padding: 16px 14px; display: flex; flex-direction: column; gap: 12px; }
.jobai-row { display: flex; gap: 8px; align-items: flex-end; }
.jobai-row-user { justify-content: flex-end; }
.jobai-mini { width: 26px; height: 26px; border-radius: 50%; background: var(--accent-d); display: flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; }
.jobai-bubble { font-size: 13.5px; line-height: 1.55; border-radius: 14px; padding: 10px 13px; max-width: 80%; word-break: break-word; }
.jobai-user { background: linear-gradient(135deg, var(--accent), var(--accent2)); color: #fff; border-bottom-right-radius: 4px; white-space: pre-wrap; }
.jobai-bot { background: var(--bg3); color: var(--text); border-bottom-left-radius: 4px; }
.jobai-bot.jobai-err { background: var(--red-d); color: #fca5a5; }
.jobai-bot p { margin: 0 0 7px; } .jobai-bot p:last-child { margin-bottom: 0; }
.jobai-bot strong { color: var(--accent); font-weight: 700; }
.jobai-ul { margin: 4px 0 7px; padding-left: 18px; } .jobai-ul li { margin: 3px 0; }

/* Welcome empty-state */
.jobai-welcome { margin: auto; text-align: center; padding: 20px; color: var(--text2); }
.jobai-welcome-ic { font-size: 40px; margin-bottom: 10px; }
.jobai-welcome-t { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 6px; }
.jobai-welcome-s { font-size: 12.5px; line-height: 1.5; max-width: 260px; margin: 0 auto; }

/* Typing dots */
.jobai-typing { display: inline-flex; gap: 4px; align-items: center; }
.jobai-typing span { width: 6px; height: 6px; border-radius: 50%; background: var(--text2); display: inline-block; animation: jobaiBlink 1.2s infinite both; }
.jobai-typing span:nth-child(2) { animation-delay: 0.2s; }
.jobai-typing span:nth-child(3) { animation-delay: 0.4s; }
@keyframes jobaiBlink { 0%, 80%, 100% { opacity: 0.25; } 40% { opacity: 1; } }

/* Footer: quick chips + input */
.jobai-foot { flex-shrink: 0; border-top: 1px solid var(--border); padding: 10px 12px 12px; background: var(--bg2); }
.jobai-quick { display: flex; flex-wrap: nowrap; gap: 6px; margin-bottom: 10px; overflow-x: auto; padding-bottom: 2px; scrollbar-width: thin; }
.jobai-quick::-webkit-scrollbar { height: 5px; }
.jobai-quick::-webkit-scrollbar-thumb { background: var(--bord2); border-radius: 3px; }
.jobai-chip {
  flex-shrink: 0; white-space: nowrap;
  font-size: 11.5px; font-weight: 600; line-height: 1.2; padding: 7px 10px; border-radius: 999px; cursor: pointer;
  background: var(--accent-d); color: var(--purple); border: 1px solid rgba(124,58,237,0.3); transition: background .12s, transform .05s;
}
.jobai-chip:hover { background: rgba(124,58,237,0.22); }
.jobai-chip:active { transform: translateY(1px); }
.jobai-form { display: flex; gap: 8px; align-items: flex-end; }
.jobai-input {
  flex: 1; resize: none; font-family: inherit; font-size: 13.5px; line-height: 1.4;
  padding: 10px 12px; border: 1px solid var(--bord2); border-radius: 12px;
  background: var(--bg1); color: var(--text); max-height: 110px; overflow-y: auto;
}
.jobai-input::placeholder { color: var(--text3); }
.jobai-input:focus { outline: none; border-color: var(--accent); }
.jobai-send {
  flex-shrink: 0; width: 40px; height: 40px; border: none; border-radius: 12px; cursor: pointer;
  background: linear-gradient(135deg, var(--accent), var(--accent2)); color: #fff;
  display: flex; align-items: center; justify-content: center; transition: filter .12s, opacity .12s;
}
.jobai-send:hover { filter: brightness(1.08); }
.jobai-send:disabled { opacity: 0.5; cursor: default; }

@media (max-width: 480px) {
  .jobai-widget { right: 14px; bottom: 14px; }
  .jobai-panel { width: calc(100vw - 28px); height: calc(100vh - 90px); }
}

/* SMS inbox mobile: single-pane. List OR conversation, never the cramped
   two-column split (Mike 2 Jul: reply box was off-screen on phones). Desktop
   is untouched (both panels stay visible above 640px). */
.sms-inbox-back { display: none; }
@media (max-width: 640px) {
  .sms-inbox-wrap { height: calc(100vh - 150px) !important; min-height: 0 !important; }
  .sms-inbox-list { width: 100% !important; }
  /* Conversation is a full-pane overlay only once a chat is opened. */
  .sms-inbox-conv { display: none !important; }
  .sms-inbox-wrap.has-active .sms-inbox-list { display: none !important; }
  .sms-inbox-wrap.has-active .sms-inbox-conv { display: flex !important; width: 100% !important; }
  .sms-inbox-back { display: inline-flex; flex-shrink: 0; }
}
