:root {
    --bg: #f5f7fb;
    --card: #ffffff;
    --ink: #182235;
    --muted: #65748b;
    --line: #dce3ef;
    --primary: #0b2447;
    --primary-2: #163e75;
    --accent: #f9b233;
    --danger: #b42318;
    --success: #047857;
    --warning: #a16207;
    --radius: 16px;
    --shadow: 0 18px 42px rgba(24, 34, 53, 0.08);
}

* { box-sizing: border-box; }

body {
    margin: 0;
    background: var(--bg);
    color: var(--ink);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
    line-height: 1.5;
}

a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar {
    position: sticky;
    top: 0;
    z-index: 10;
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 14px 28px;
    background: rgba(255, 255, 255, 0.96);
    border-bottom: 1px solid var(--line);
    backdrop-filter: blur(10px);
}

.brand {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 265px;
}

.brand:hover { text-decoration: none; }
.brand small { display: block; color: var(--muted); font-size: 12px; }

.brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: linear-gradient(145deg, var(--primary), var(--primary-2));
    color: #fff;
    font-weight: 800;
    letter-spacing: 0.04em;
    box-shadow: 0 8px 20px rgba(11, 36, 71, 0.22);
}

.nav {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    flex: 1;
}

.nav a {
    display: inline-block;
    padding: 9px 12px;
    border-radius: 999px;
    color: var(--muted);
    font-size: 14px;
}

.nav a:hover {
    background: #eef3fb;
    color: var(--primary);
    text-decoration: none;
}

.user-chip {
    padding: 8px 12px;
    background: #eef3fb;
    border-radius: 999px;
    color: var(--primary);
    font-weight: 700;
    font-size: 14px;
}

.container {
    width: min(1220px, calc(100% - 32px));
    margin: 28px auto 60px;
}

.footer {
    width: min(1220px, calc(100% - 32px));
    margin: 20px auto;
    color: var(--muted);
    font-size: 13px;
}

.page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 18px;
    margin-bottom: 20px;
}

.page-head h1 {
    margin: 0 0 4px;
    font-size: clamp(28px, 4vw, 42px);
    letter-spacing: -0.03em;
}

.muted { color: var(--muted); }
.small { font-size: 13px; }

.card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 22px;
}

.card + .card { margin-top: 18px; }

.grid { display: grid; gap: 16px; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }

.stat-card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 18px;
}

.stat-card strong {
    display: block;
    font-size: 30px;
    line-height: 1;
    margin-bottom: 8px;
}

.filter-card {
    display: flex;
    align-items: end;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 18px;
}

label {
    display: block;
    font-weight: 700;
    font-size: 14px;
    color: var(--ink);
}

input, select, textarea {
    width: 100%;
    margin-top: 6px;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 11px 12px;
    background: #fff;
    color: var(--ink);
    font: inherit;
}

textarea { min-height: 120px; resize: vertical; }

input:focus, select:focus, textarea:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(11, 36, 71, 0.12);
    outline: none;
}

.button,
button {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    min-height: 42px;
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 10px 16px;
    background: #fff;
    color: var(--primary);
    font-weight: 800;
    font: inherit;
    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;
}

.button:hover,
button:hover { text-decoration: none; background: #eef3fb; }

.button-primary {
    background: var(--primary);
    border-color: var(--primary);
    color: #fff;
}

.button-primary:hover { background: var(--primary-2); color: #fff; }
.button-danger { border-color: #fecaca; color: var(--danger); }
.button-mini { min-height: 32px; padding: 6px 11px; font-size: 13px; }

.actions { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }

.table-wrap {
    overflow-x: auto;
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

table {
    width: 100%;
    border-collapse: collapse;
}

th, td {
    padding: 14px 16px;
    border-bottom: 1px solid var(--line);
    vertical-align: top;
    text-align: left;
}

th {
    background: #f8fafc;
    color: var(--muted);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

tr:last-child td { border-bottom: 0; }

.status-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 5px 10px;
    font-size: 12px;
    font-weight: 800;
    white-space: nowrap;
}

.status-blank { background: #eef2f7; color: #475569; }
.status-no-answer { background: #fef3c7; color: #92400e; }
.status-job-lost { background: #fee2e2; color: #991b1b; }
.status-requires-quote { background: #dcfce7; color: #166534; }

.quote-badge {
    display: inline-block;
    margin-top: 6px;
    border-radius: 9px;
    background: #e0f2fe;
    color: #075985;
    padding: 4px 8px;
    font-size: 12px;
    font-weight: 700;
}

.alert {
    margin: 0 0 16px;
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: #eef3fb;
}

.alert-success { background: #ecfdf5; border-color: #a7f3d0; color: #065f46; }
.alert-danger { background: #fef2f2; border-color: #fecaca; color: #991b1b; }
.alert-warning { background: #fffbeb; border-color: #fde68a; color: #92400e; }
.alert-info { background: #eff6ff; border-color: #bfdbfe; color: #1d4ed8; }

.login-page,
.install-page {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 24px;
}

.login-card,
.install-card {
    width: min(520px, 100%);
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 22px;
    box-shadow: var(--shadow);
    padding: 30px;
}

.login-card h1,
.install-card h1 { margin: 14px 0 8px; }

.stacked-form { display: grid; gap: 15px; margin-top: 18px; }

.code-box {
    min-height: 170px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 12px;
}

.checklist { padding-left: 20px; }
.checklist li { margin: 8px 0; }

.detail-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.75fr);
    gap: 18px;
}

.form-section-title {
    margin: 0 0 14px;
    font-size: 20px;
}

.note-list { display: grid; gap: 12px; }
.note-item {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 14px;
    background: #fbfdff;
}
.note-item p { white-space: pre-wrap; margin: 8px 0 0; }

.empty-state {
    text-align: center;
    padding: 34px 18px;
    color: var(--muted);
}

.client-title { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.client-title h1 { margin: 0; }

.call-box {
    background: linear-gradient(145deg, #0b2447, #163e75);
    border-radius: var(--radius);
    padding: 20px;
    color: #fff;
    box-shadow: var(--shadow);
}
.call-box a { color: #fff; text-decoration: underline; }
.call-box .button { background: #fff; color: var(--primary); border-color: #fff; }

.import-help code { background: #eef3fb; padding: 2px 6px; border-radius: 6px; }

@media (max-width: 980px) {
    .topbar { position: static; flex-direction: column; align-items: flex-start; padding: 16px; }
    .brand { min-width: auto; }
    .user-chip { align-self: flex-start; }
    .page-head, .detail-layout { display: block; }
    .page-head .actions { margin-top: 14px; }
    .grid-2, .grid-3, .grid-4, .grid-5 { grid-template-columns: 1fr; }
    .card { padding: 18px; }
    th, td { padding: 12px; }
}

/* v3 layout updates: full-width call table, PBM logo, inline row editing, and spam handling. */
.brand-logo {
    display: block;
    width: 132px;
    height: auto;
    max-height: 58px;
    object-fit: contain;
}

.login-logo,
.install-logo {
    display: block;
    width: min(210px, 78%);
    height: auto;
    margin-bottom: 10px;
}

.container-wide {
    width: calc(100% - 24px);
    max-width: none;
    margin-left: auto;
    margin-right: auto;
}

.footer {
    width: calc(100% - 24px);
    max-width: none;
}

.grid-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.stats-grid .stat-card { min-height: 100%; }

.filter-search { min-width: 300px; flex: 1 1 380px; }
.filter-select { min-width: 210px; flex: 0 0 220px; }

input[type="checkbox"] {
    width: auto;
    margin: 0;
}

.checkbox-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: auto;
    margin-top: 0;
    font-weight: 800;
    white-space: nowrap;
}

.show-spam-toggle {
    min-height: 42px;
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
}

.table-wrap-wide {
    width: 100%;
}

.call-table {
    min-width: 1500px;
    table-layout: fixed;
}

.call-table th,
.call-table td {
    padding: 12px 12px;
}

.call-table .date-col { width: 145px; }
.call-table .client-col { width: 230px; }
.call-table .contact-col { width: 180px; }
.call-table .service-col { width: 190px; }
.call-table .status-col { width: 180px; }
.call-table .quote-when-col { width: 155px; }
.call-table .comment-col { width: 330px; }
.call-table .save-col { width: 92px; text-align: center; }

.inline-table-form select,
.inline-table-form input,
.inline-table-form textarea {
    margin-top: 0;
    border-radius: 10px;
    padding: 9px 10px;
}

.inline-table-form textarea {
    min-height: 72px;
}

.inline-spam-check {
    margin-top: 8px;
    color: var(--muted);
    font-size: 13px;
}

.latest-note-preview {
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px dashed var(--line);
    color: var(--muted);
    font-size: 12px;
    line-height: 1.35;
}

.status-spam {
    background: #e2e8f0;
    color: #334155;
}

.spam-row {
    background: #f8fafc;
    opacity: 0.88;
}

@media (max-width: 980px) {
    .container-wide { width: calc(100% - 16px); }
    .grid-6 { grid-template-columns: 1fr; }
    .brand-logo { width: 124px; }
    .filter-search,
    .filter-select { min-width: 100%; flex-basis: 100%; }
}


/* v4 updates: dark header, smaller PBM logo, and remember-login controls. */
.topbar {
    background: linear-gradient(135deg, #071a33, #0b2447);
    border-bottom-color: rgba(255, 255, 255, 0.14);
    box-shadow: 0 12px 28px rgba(7, 26, 51, 0.22);
}

.topbar .brand,
.topbar .brand strong,
.topbar .nav a {
    color: #ffffff;
}

.topbar .brand small {
    color: rgba(255, 255, 255, 0.72);
}

.topbar .nav a {
    background: rgba(255, 255, 255, 0.06);
}

.topbar .nav a:hover {
    background: rgba(255, 255, 255, 0.16);
    color: #ffffff;
}

.topbar .user-chip {
    background: rgba(255, 255, 255, 0.12);
    color: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.16);
}

.brand-logo {
    width: 92px;
    max-height: 42px;
    padding: 0;
}

.brand {
    min-width: 245px;
}

.remember-login {
    justify-content: flex-start;
}

.remember-help {
    margin: -8px 0 0;
}

@media (max-width: 980px) {
    .brand-logo { width: 88px; max-height: 40px; }
}

.login-logo,
.install-logo {
    width: min(160px, 62%);
}

/* v5 updates: dashboard, left category menu, quote value, ICS, and editable categories. */
.app-shell {
    display: flex;
    align-items: flex-start;
    gap: 0;
    width: 100%;
}

.side-menu {
    position: sticky;
    top: 74px;
    flex: 0 0 230px;
    min-height: calc(100vh - 74px);
    padding: 18px 12px;
    background: #ffffff;
    border-right: 1px solid var(--line);
    box-shadow: 12px 0 28px rgba(24, 34, 53, 0.04);
}

.side-menu-title {
    padding: 0 10px 10px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.side-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 12px;
    color: var(--ink);
    font-weight: 800;
}

.side-link strong {
    display: inline-flex;
    min-width: 28px;
    justify-content: center;
    border-radius: 999px;
    background: #eef3fb;
    color: var(--primary);
    padding: 2px 8px;
    font-size: 12px;
}

.side-link:hover,
.side-link.active {
    background: #eef3fb;
    text-decoration: none;
}

.side-manage {
    display: block;
    margin: 14px 10px 0;
    font-size: 13px;
    font-weight: 900;
}

.app-shell > .container {
    flex: 1 1 auto;
    min-width: 0;
    margin: 24px 16px 60px;
}

.app-shell > .container-wide {
    width: auto;
    max-width: none;
}

.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 16px;
}

.metric-card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 18px;
    box-shadow: var(--shadow);
}

.metric-card span,
.metric-card small {
    display: block;
    color: var(--muted);
    font-weight: 800;
}

.metric-card strong {
    display: block;
    margin: 8px 0;
    font-size: clamp(28px, 3.5vw, 44px);
    line-height: 1;
    letter-spacing: -0.04em;
}

.metric-primary {
    background: linear-gradient(145deg, #0b2447, #163e75);
    color: #fff;
}

.metric-primary span,
.metric-primary small { color: rgba(255,255,255,0.78); }
.metric-value strong { font-size: clamp(24px, 3vw, 36px); }

.monthly-card { margin-bottom: 16px; }
.monthly-head { display: flex; justify-content: space-between; gap: 12px; align-items: baseline; flex-wrap: wrap; }
.month-bars { display: grid; gap: 9px; }
.month-row { display: grid; grid-template-columns: 110px minmax(120px, 1fr) 45px; align-items: center; gap: 12px; }
.month-row span { color: var(--muted); font-weight: 800; }
.month-bar { height: 10px; overflow: hidden; border-radius: 999px; background: #eef3fb; }
.month-bar i { display: block; height: 100%; border-radius: inherit; background: var(--primary); }
.month-row strong { text-align: right; }

.call-table { min-width: 1640px; }
.call-table .quote-value-col { width: 120px; }
.call-table .calendar-col { width: 86px; text-align: center; }
.call-table .comment-col { width: 300px; }
/* v7 update: quote date and quote time share one compact table cell. */
.quote-when-fields { display: grid; gap: 8px; }
.quote-when-fields input { width: 100%; }
.inline-money { text-align: right; }

.categories-table .sort-input { max-width: 90px; }
.categories-table small { display: block; margin-top: 5px; }
.add-category-form { align-items: end; }
.category-check { min-height: 44px; align-items: center; }
.status-custom { background: #ede9fe; color: #5b21b6; }

@media (max-width: 1180px) {
    .dashboard-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .side-menu { flex-basis: 200px; }
}

@media (max-width: 980px) {
    .app-shell { display: block; }
    .side-menu {
        position: static;
        min-height: auto;
        border-right: 0;
        border-bottom: 1px solid var(--line);
        display: flex;
        gap: 8px;
        overflow-x: auto;
        padding: 12px;
    }
    .side-menu-title,
    .side-manage { display: none; }
    .side-link { flex: 0 0 auto; min-width: 145px; }
    .app-shell > .container { margin: 16px 8px 50px; }
    .dashboard-grid { grid-template-columns: 1fr; }
    .month-row { grid-template-columns: 92px minmax(90px, 1fr) 36px; }
}

/* v8 updates: consistent compact table text, collapsible sidebar, quote-flow categories, and allocation controls. */
.call-table,
.call-table th,
.call-table td,
.call-table input,
.call-table select,
.call-table textarea,
.call-table .button,
.call-table button,
.call-table a,
.call-table label,
.inline-table-form {
    font-size: 13.5px;
}

.call-table th {
    font-size: 13px;
    letter-spacing: 0.045em;
}

.call-table .small,
.call-table .muted,
.call-table .latest-note-preview,
.call-table .inline-spam-check {
    font-size: 13.5px;
}

.call-table {
    min-width: 1560px;
}

.call-table th,
.call-table td {
    padding: 10px 10px;
}

.call-table .date-col { width: 128px; }
.call-table .client-col { width: 205px; }
.call-table .contact-col { width: 158px; }
.call-table .service-col { width: 165px; }
.call-table .alloc-col { width: 112px; }
.call-table .status-col { width: 150px; }
.call-table .quote-when-col { width: 138px; }
.call-table .quote-value-col { width: 104px; }
.call-table .calendar-col { width: 72px; }
.call-table .comment-col { width: 270px; }
.call-table .save-col { width: 76px; }

.inline-table-form select,
.inline-table-form input,
.inline-table-form textarea {
    padding: 8px 9px;
    line-height: 1.25;
}

.inline-table-form textarea {
    min-height: 66px;
}

.inline-alloc-check,
.inline-spam-check {
    display: flex;
    margin: 0 0 7px;
    gap: 6px;
    font-size: 13.5px;
}

.inline-alloc-check:last-child,
.inline-spam-check:last-child {
    margin-bottom: 0;
}

.status-new-lead { background: #e0f2fe; color: #075985; }

.side-menu,
.side-menu a,
.side-menu-title,
.side-link,
.side-manage {
    font-size: 13.5px;
}

.side-menu {
    flex-basis: 205px;
    transition: flex-basis 0.18s ease, width 0.18s ease, min-width 0.18s ease, padding 0.18s ease, opacity 0.18s ease;
}

.side-link {
    padding: 8px 10px;
    border-radius: 10px;
}

.side-link strong {
    min-width: 24px;
    padding: 1px 7px;
    font-size: 12px;
}

.sidebar-toggle {
    min-height: 34px;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.18);
    color: #fff;
    font-size: 13.5px;
    font-weight: 800;
}

.sidebar-toggle:hover {
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
}

body.sidebar-collapsed .side-menu {
    flex-basis: 0;
    width: 0;
    min-width: 0;
    padding-left: 0;
    padding-right: 0;
    border-right: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
}

body.sidebar-collapsed .app-shell > .container,
body.sidebar-collapsed .app-shell > .container-wide {
    margin-left: 12px;
}

@media (max-width: 980px) {
    .call-table { min-width: 1500px; }
    .side-menu { transition: max-height 0.18s ease, padding 0.18s ease, opacity 0.18s ease; }
    body.sidebar-collapsed .side-menu {
        max-height: 0;
        width: auto;
        padding-top: 0;
        padding-bottom: 0;
        border-bottom: 0;
    }
    body.sidebar-collapsed .app-shell > .container,
    body.sidebar-collapsed .app-shell > .container-wide { margin-left: 8px; }
}

/* v9 compact CRM workspace updates. */
:root { --compact-font: 13.5px; }

body,
input,
select,
textarea,
button,
.button {
    font-size: var(--compact-font);
}

.button,
button {
    min-height: 34px;
    padding: 7px 12px;
    font-size: var(--compact-font);
    line-height: 1.2;
    border-radius: 999px;
    font-weight: 800;
}

.button-mini {
    min-height: 29px;
    padding: 5px 8px;
    font-size: var(--compact-font);
}

.topbar {
    padding: 10px 18px;
    gap: 14px;
}

.brand { min-width: 230px; }
.brand-logo { width: 82px; max-height: 38px; }
.brand strong { font-size: var(--compact-font); }
.brand small { font-size: 11.5px; }
.nav a { font-size: var(--compact-font); padding: 7px 10px; }
.user-chip,
.user-chip-link {
    font-size: var(--compact-font);
    padding: 7px 11px;
    line-height: 1.2;
}
.user-chip-link:hover { text-decoration: none; background: rgba(255, 255, 255, 0.2); }

.page-head-compact {
    margin-bottom: 12px;
}
.page-head-compact h1 {
    font-size: clamp(22px, 2.2vw, 30px);
}
.page-head-compact p {
    margin: 0;
    font-size: var(--compact-font);
}

.app-shell { min-height: calc(100vh - 60px); }
.side-menu {
    top: 59px;
    flex: 0 0 172px;
    min-height: calc(100vh - 59px);
    display: flex;
    flex-direction: column;
    padding: 10px 8px;
    gap: 8px;
    transition: flex-basis 0.18s ease, width 0.18s ease, min-width 0.18s ease, padding 0.18s ease;
}
.side-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
}
.side-menu-title {
    padding: 0 6px;
    font-size: 10.5px;
    line-height: 1.2;
    letter-spacing: 0.06em;
}
.side-collapse-button {
    flex: 0 0 28px;
    width: 28px;
    height: 28px;
    min-height: 28px;
    padding: 0;
    border-radius: 9px;
    font-size: 20px;
    line-height: 1;
    font-weight: 900;
}
.side-links {
    display: grid;
    gap: 3px;
    min-height: 0;
    overflow-y: auto;
    padding-bottom: 6px;
}
.side-link {
    gap: 6px;
    min-height: 29px;
    padding: 6px 8px;
    border-radius: 9px;
    font-size: 12.5px;
    line-height: 1.15;
    font-weight: 800;
}
.side-link span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.side-link strong {
    min-width: 22px;
    padding: 1px 6px;
    font-size: 11px;
    line-height: 1.35;
}
.side-settings {
    margin-top: auto;
    border-top: 1px solid var(--line);
    padding: 8px 4px 0;
    font-size: 12.5px;
}
.side-settings summary {
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 30px;
    padding: 6px 8px;
    border-radius: 9px;
    color: var(--primary);
    font-weight: 900;
}
.side-settings summary::-webkit-details-marker { display: none; }
.side-settings summary:hover { background: #eef3fb; }
.side-settings a {
    display: block;
    padding: 7px 10px;
    margin-top: 2px;
    border-radius: 9px;
    color: var(--ink);
    font-size: 12.5px;
    font-weight: 800;
}
.side-settings a:hover { background: #eef3fb; text-decoration: none; }

body.sidebar-collapsed .side-menu,
html.sidebar-collapsed-preload .side-menu {
    flex-basis: 42px;
    width: 42px;
    min-width: 42px;
    padding: 10px 6px;
    opacity: 1;
    overflow: visible;
    pointer-events: auto;
}
body.sidebar-collapsed .side-menu-title,
body.sidebar-collapsed .side-links,
body.sidebar-collapsed .side-settings,
html.sidebar-collapsed-preload .side-menu-title,
html.sidebar-collapsed-preload .side-links,
html.sidebar-collapsed-preload .side-settings {
    display: none;
}
body.sidebar-collapsed .side-top,
html.sidebar-collapsed-preload .side-top {
    justify-content: center;
}
body.sidebar-collapsed .side-collapse-button,
html.sidebar-collapsed-preload .side-collapse-button {
    width: 30px;
    flex-basis: 30px;
}
body.sidebar-collapsed .app-shell > .container,
body.sidebar-collapsed .app-shell > .container-wide,
html.sidebar-collapsed-preload .app-shell > .container,
html.sidebar-collapsed-preload .app-shell > .container-wide {
    margin-left: 12px;
}

.app-shell > .container { margin-top: 14px; }
.container-wide { width: calc(100% - 20px); }

.dashboard-grid-compact,
.dashboard-grid {
    grid-template-columns: repeat(5, minmax(128px, 1fr));
    gap: 9px;
    margin-bottom: 10px;
}
.metric-card {
    padding: 11px 12px;
    border-radius: 12px;
}
.metric-card span,
.metric-card small {
    font-size: 11.5px;
    line-height: 1.25;
}
.metric-card strong {
    margin: 5px 0 4px;
    font-size: clamp(22px, 2.1vw, 30px);
    letter-spacing: -0.03em;
}
.metric-value strong { font-size: clamp(18px, 1.9vw, 26px); }
.monthly-card {
    padding: 12px 14px;
    margin-bottom: 10px;
    border-radius: 12px;
}
.monthly-head { margin-bottom: 8px; }
.monthly-head .form-section-title {
    margin: 0;
    font-size: 15px;
}
.month-bars { gap: 6px; }
.month-row {
    grid-template-columns: 90px minmax(120px, 1fr) 34px;
    gap: 8px;
    font-size: 12.5px;
}
.month-bar { height: 8px; }

.filter-card {
    padding: 12px;
    gap: 9px;
    margin-bottom: 10px;
}
.filter-card label { font-size: 12.5px; }
.filter-card input,
.filter-card select {
    min-height: 32px;
    padding: 7px 9px;
    border-radius: 9px;
    font-size: var(--compact-font);
}
.show-spam-toggle { min-height: 32px; padding: 7px 10px; }

.call-table,
.call-table th,
.call-table td,
.call-table input,
.call-table select,
.call-table textarea,
.call-table .button,
.call-table button,
.call-table a,
.call-table label,
.inline-table-form {
    font-size: var(--compact-font) !important;
}
.call-table {
    min-width: 1320px;
    table-layout: fixed;
}
.call-table th {
    padding: 8px 8px;
    font-size: 11.5px !important;
    letter-spacing: 0.035em;
    line-height: 1.2;
}
.call-table td {
    padding: 8px 8px;
    line-height: 1.25;
}
.call-table .date-col { width: 88px; }
.call-table .client-col { width: 175px; }
.call-table .contact-col { width: 145px; }
.call-table .service-col { width: 132px; }
.call-table .alloc-col { width: 92px; }
.call-table .status-col { width: 130px; }
.call-table .quote-when-col { width: 126px; }
.call-table .quote-value-col { width: 86px; }
.call-table .calendar-col { width: 55px; }
.call-table .comment-col { width: 235px; }
.call-table .save-col { width: 62px; }

.entry-date-cell span,
.entry-date-line,
.entry-time-line {
    display: block;
    font-size: var(--compact-font) !important;
    line-height: 1.18;
}
.entry-date-line {
    font-weight: 800;
    color: var(--ink);
}
.entry-time-line {
    margin-top: 2px;
    color: var(--muted);
}
.client-name-link {
    display: block;
    font-size: var(--compact-font) !important;
    font-weight: 900;
    line-height: 1.15;
    overflow-wrap: anywhere;
}
.client-message-preview {
    display: block;
    margin-top: 5px;
    font-size: 12.2px !important;
    line-height: 1.25;
}
.contact-links a {
    display: inline-block;
    max-width: 100%;
    font-size: var(--compact-font) !important;
    line-height: 1.25;
    overflow-wrap: anywhere;
}
.category-suburb-cell .service-name,
.category-suburb-cell .suburb-name {
    display: block;
    font-size: var(--compact-font) !important;
    line-height: 1.2;
    overflow-wrap: anywhere;
}
.category-suburb-cell .service-name { font-weight: 900; }
.category-suburb-cell .suburb-name {
    margin-top: 3px;
    color: var(--muted);
}
.inline-table-form select,
.inline-table-form input,
.inline-table-form textarea {
    min-height: 31px;
    margin-top: 0;
    padding: 6px 7px;
    border-radius: 8px;
    line-height: 1.2;
    font-size: var(--compact-font) !important;
}
.inline-table-form input[type="date"],
.inline-table-form input[type="time"],
.inline-table-form input[type="number"] {
    height: 31px;
}
.inline-table-form textarea {
    min-height: 58px;
    resize: vertical;
}
.quote-when-fields { gap: 5px; }
.inline-money { text-align: right; }
.inline-alloc-check,
.inline-spam-check {
    margin: 0 0 6px;
    gap: 5px;
    font-size: var(--compact-font) !important;
    line-height: 1.2;
}
.inline-spam-check { margin-top: 6px; }
.latest-note-preview {
    margin-top: 6px;
    padding-top: 6px;
    font-size: 12.2px !important;
    line-height: 1.25;
}
.call-table .button-mini {
    min-height: 28px;
    padding: 4px 7px;
}

@media (max-width: 1180px) {
    .dashboard-grid-compact,
    .dashboard-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .side-menu { flex-basis: 158px; }
}

@media (max-width: 980px) {
    .topbar { padding: 10px 12px; }
    .brand { min-width: auto; }
    .brand-logo { width: 76px; }
    .app-shell { display: block; }
    .side-menu {
        position: sticky;
        top: 0;
        min-height: auto;
        width: 100%;
        flex-basis: auto;
        border-right: 0;
        border-bottom: 1px solid var(--line);
    }
    .side-links {
        display: flex;
        overflow-x: auto;
        gap: 6px;
        padding-bottom: 0;
    }
    .side-link { flex: 0 0 auto; min-width: 110px; }
    .side-settings { margin-top: 0; }
    body.sidebar-collapsed .side-menu,
    html.sidebar-collapsed-preload .side-menu {
        width: 42px;
        min-width: 42px;
        padding: 8px 6px;
        display: flex;
    }
    body.sidebar-collapsed .side-links,
    body.sidebar-collapsed .side-settings,
    html.sidebar-collapsed-preload .side-links,
    html.sidebar-collapsed-preload .side-settings { display: none; }
    body.sidebar-collapsed .app-shell > .container,
    body.sidebar-collapsed .app-shell > .container-wide,
    html.sidebar-collapsed-preload .app-shell > .container,
    html.sidebar-collapsed-preload .app-shell > .container-wide { margin-left: 8px; }
    .dashboard-grid-compact,
    .dashboard-grid { grid-template-columns: 1fr; }
    .call-table { min-width: 1280px; }
}

/* v9 compact UI: sidebar arrow, settings menu, smaller dashboard/table controls. */
:root { --compact-font: 13.5px; }
body, input, select, textarea, button, .button { font-size: var(--compact-font); }
label { font-size: var(--compact-font); }
.button, button { min-height: 34px; padding: 7px 11px; border-radius: 999px; font-size: var(--compact-font); line-height: 1.2; font-weight: 800; }
.button-mini { min-height: 28px; padding: 5px 8px; font-size: var(--compact-font); }
input, select, textarea { padding: 8px 10px; border-radius: 10px; font-size: var(--compact-font); line-height: 1.25; }
.topbar { padding: 10px 18px; gap: 14px; }
.brand { min-width: 230px; }
.brand-logo { width: 82px; max-height: 38px; }
.nav a { padding: 7px 10px; font-size: var(--compact-font); }
a.user-chip, a.user-chip-link { display: inline-flex; align-items: center; min-height: 34px; text-decoration: none; }
a.user-chip:hover, a.user-chip-link:hover { background: rgba(255, 255, 255, 0.18); color: #fff; text-decoration: none; }
.app-shell { align-items: stretch; }
.side-menu { top: 59px; flex: 0 0 176px; min-height: calc(100vh - 59px); padding: 10px 8px; display: flex; flex-direction: column; gap: 10px; transition: flex-basis 0.18s ease, width 0.18s ease, min-width 0.18s ease, padding 0.18s ease, opacity 0.18s ease; }
.side-menu-main { min-height: 0; }
.side-menu-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 6px; }
.side-menu-title { padding: 0 6px; font-size: 11.5px; letter-spacing: 0.07em; }
.side-collapse-button { width: 28px; min-width: 28px; min-height: 28px; padding: 0; border-radius: 9px; font-size: 15px; background: #eef3fb; }
.side-links { display: grid; gap: 3px; overflow-y: auto; max-height: calc(100vh - 190px); padding-right: 2px; }
.side-link { padding: 6px 8px; border-radius: 9px; gap: 7px; font-size: 12.5px; line-height: 1.15; }
.side-link span { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.side-link strong { min-width: 22px; padding: 1px 6px; font-size: 11px; }
.side-bottom { margin-top: auto; position: relative; padding-top: 8px; border-top: 1px solid var(--line); }
.settings-menu { position: relative; }
.settings-menu summary { list-style: none; display: flex; align-items: center; justify-content: center; min-height: 32px; border: 1px solid var(--line); border-radius: 999px; background: #fff; color: var(--primary); font-size: 12.5px; font-weight: 900; cursor: pointer; user-select: none; }
.settings-menu summary::-webkit-details-marker { display: none; }
.settings-links { position: absolute; left: 0; bottom: calc(100% + 8px); width: min(210px, calc(100vw - 24px)); display: grid; gap: 4px; padding: 8px; border: 1px solid var(--line); border-radius: 12px; background: #fff; box-shadow: var(--shadow); z-index: 20; }
.settings-menu:not([open]) .settings-links { display: none; }
.settings-links a { display: block; padding: 7px 9px; border-radius: 9px; color: var(--ink); font-size: 12.5px; font-weight: 800; }
.settings-links a:hover { background: #eef3fb; text-decoration: none; }
body.sidebar-collapsed .side-menu { flex-basis: 0; width: 0; min-width: 0; padding-left: 0; padding-right: 0; border-right: 0; opacity: 0; overflow: hidden; pointer-events: none; }
.app-shell > .container { margin-top: 14px; }
.page-head-compact { margin-bottom: 10px; }
.page-head-compact h1 { font-size: clamp(22px, 2.5vw, 31px); }
.page-head-compact p { margin-top: 2px; font-size: 13px; }
.dashboard-grid { gap: 9px; margin-bottom: 10px; }
.metric-card { padding: 11px 12px; border-radius: 13px; }
.metric-card span, .metric-card small { font-size: 12px; line-height: 1.25; }
.metric-card strong, .metric-value strong { margin: 4px 0; font-size: clamp(22px, 2.2vw, 31px); }
.monthly-card { margin-bottom: 10px; padding: 12px; border-radius: 13px; }
.monthly-head { margin-bottom: 6px; }
.monthly-head .form-section-title { margin-bottom: 0; font-size: 15px; }
.monthly-head .small, .month-row, .month-row span, .month-row strong { font-size: 12.5px; }
.month-bars { gap: 6px; }
.month-row { grid-template-columns: 88px minmax(90px, 1fr) 34px; gap: 8px; }
.month-bar { height: 7px; }
.filter-card { gap: 8px; padding: 12px; margin-bottom: 10px; align-items: end; }
.filter-search { min-width: 240px; flex-basis: 320px; }
.filter-select { min-width: 155px; flex-basis: 175px; }
.show-spam-toggle { min-height: 34px; padding: 7px 10px; }
.call-table, .call-table th, .call-table td, .call-table input, .call-table select, .call-table textarea, .call-table .button, .call-table button, .call-table a, .call-table label, .inline-table-form { font-size: var(--compact-font); }
.call-table { min-width: 1380px; }
.call-table th, .call-table td { padding: 8px 8px; }
.call-table th { font-size: 12px; letter-spacing: 0.035em; }
.call-table .date-col { width: 104px; }
.call-table .client-col { width: 178px; }
.call-table .contact-col { width: 154px; }
.call-table .service-col { width: 138px; }
.call-table .alloc-col { width: 94px; }
.call-table .status-col { width: 132px; }
.call-table .quote-when-col { width: 122px; }
.call-table .quote-value-col { width: 88px; }
.call-table .calendar-col { width: 60px; }
.call-table .comment-col { width: 238px; }
.call-table .save-col { width: 64px; }
.entry-date-cell, .client-col, .contact-links, .category-suburb-cell { line-height: 1.25; }
.entry-date-line, .entry-time-line, .category-suburb-cell .service-name, .category-suburb-cell .suburb-name, .client-message-preview { display: block; }
.entry-date-line, .client-name-link, .category-suburb-cell .service-name { font-weight: 800; }
.entry-time-line, .category-suburb-cell .suburb-name, .client-message-preview { color: var(--muted); }
.client-name-link, .contact-links a, .category-suburb-cell, .call-table .small, .call-table .muted, .call-table .latest-note-preview, .call-table .inline-spam-check { font-size: var(--compact-font); }
.client-message-preview { margin-top: 4px; font-size: 12.5px; }
.inline-table-form select, .inline-table-form input, .inline-table-form textarea { min-height: 30px; padding: 6px 7px; border-radius: 8px; font-size: var(--compact-font); }
.inline-table-form textarea { min-height: 58px; }
.quote-when-fields { gap: 5px; }
.inline-alloc-check, .inline-spam-check { margin-bottom: 5px; gap: 5px; font-size: var(--compact-font); }
.latest-note-preview { margin-top: 6px; padding-top: 6px; line-height: 1.25; }
@media (max-width: 1180px) { .side-menu { flex-basis: 168px; } }
@media (max-width: 980px) {
    .topbar { padding: 10px 12px; gap: 10px; }
    .brand { min-width: auto; }
    .brand-logo { width: 78px; max-height: 36px; }
    .side-menu { position: relative; top: auto; min-height: auto; display: flex; flex-direction: column; max-height: 55vh; }
    .side-links { max-height: 38vh; }
    .side-bottom { border-top: 0; }
    .settings-links { left: 0; bottom: auto; top: calc(100% + 8px); }
    .dashboard-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .call-table { min-width: 1360px; }
}
@media (max-width: 680px) { .dashboard-grid { grid-template-columns: 1fr; } }

/* v9 final overrides: keep sidebar arrow visible when minimised and normalise actual table/header class names. */
:root { --compact-font: 13.5px; }

body,
input,
select,
textarea,
button,
.button,
.call-table,
.call-table th,
.call-table td,
.call-table a,
.call-table label {
    font-size: var(--compact-font) !important;
}

.button,
button {
    min-height: 34px !important;
    padding: 7px 11px !important;
    font-size: var(--compact-font) !important;
    line-height: 1.2 !important;
}

.button-mini {
    min-height: 28px !important;
    padding: 4px 8px !important;
}

.topbar {
    padding: 10px 18px !important;
}

.brand-logo {
    width: 82px !important;
    max-height: 38px !important;
}

.nav a,
.user-chip,
.user-chip-link {
    font-size: var(--compact-font) !important;
}

.user-chip-link {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 34px !important;
    text-decoration: none !important;
}

.side-menu {
    position: sticky !important;
    top: 59px !important;
    flex: 0 0 176px !important;
    width: 176px !important;
    min-width: 176px !important;
    min-height: calc(100vh - 59px) !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    padding: 10px 8px !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    overflow: visible !important;
    border-right: 1px solid var(--line) !important;
    transition: flex-basis 0.18s ease, width 0.18s ease, min-width 0.18s ease, padding 0.18s ease !important;
}

.side-top {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 6px !important;
}

.side-menu-title {
    padding: 0 4px !important;
    font-size: 11px !important;
    letter-spacing: 0.06em !important;
}

.side-collapse-button {
    flex: 0 0 28px !important;
    width: 28px !important;
    min-width: 28px !important;
    min-height: 28px !important;
    padding: 0 !important;
    border-radius: 9px !important;
    font-size: 18px !important;
    line-height: 1 !important;
}

.side-links {
    display: grid !important;
    gap: 3px !important;
    max-height: calc(100vh - 180px) !important;
    overflow-y: auto !important;
    padding-right: 2px !important;
}

.side-link {
    padding: 6px 8px !important;
    border-radius: 9px !important;
    gap: 6px !important;
    font-size: 12.5px !important;
    line-height: 1.15 !important;
}

.side-link span {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.side-link strong {
    min-width: 22px !important;
    padding: 1px 6px !important;
    font-size: 11px !important;
}

.side-settings {
    margin-top: auto !important;
    padding-top: 8px !important;
    border-top: 1px solid var(--line) !important;
    font-size: 12.5px !important;
}

.side-settings summary {
    min-height: 32px !important;
    padding: 7px 9px !important;
    border: 1px solid var(--line) !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: var(--primary) !important;
    font-size: 12.5px !important;
    font-weight: 900 !important;
    cursor: pointer !important;
    list-style: none !important;
}

.side-settings summary::-webkit-details-marker { display: none !important; }

.side-settings a {
    display: block !important;
    margin-top: 4px !important;
    padding: 6px 9px !important;
    border-radius: 9px !important;
    color: var(--ink) !important;
    font-size: 12.5px !important;
    font-weight: 800 !important;
}

.side-settings a:hover {
    background: #eef3fb !important;
    text-decoration: none !important;
}

body.sidebar-collapsed .side-menu,
html.sidebar-collapsed-preload .side-menu {
    flex: 0 0 42px !important;
    width: 42px !important;
    min-width: 42px !important;
    min-height: calc(100vh - 59px) !important;
    padding: 10px 6px !important;
    border-right: 1px solid var(--line) !important;
    border-bottom: 0 !important;
    opacity: 1 !important;
    overflow: visible !important;
    pointer-events: auto !important;
}

body.sidebar-collapsed .side-menu-title,
body.sidebar-collapsed .side-links,
body.sidebar-collapsed .side-settings,
html.sidebar-collapsed-preload .side-menu-title,
html.sidebar-collapsed-preload .side-links,
html.sidebar-collapsed-preload .side-settings {
    display: none !important;
}

body.sidebar-collapsed .side-top,
html.sidebar-collapsed-preload .side-top {
    justify-content: center !important;
}

body.sidebar-collapsed .side-collapse-button,
html.sidebar-collapsed-preload .side-collapse-button {
    margin: 0 auto !important;
}

body.sidebar-collapsed .app-shell > .container,
body.sidebar-collapsed .app-shell > .container-wide,
html.sidebar-collapsed-preload .app-shell > .container,
html.sidebar-collapsed-preload .app-shell > .container-wide {
    margin-left: 10px !important;
}

.page-head-compact {
    margin-bottom: 10px !important;
}

.page-head-compact h1 {
    font-size: clamp(22px, 2.5vw, 31px) !important;
}

.page-head-compact p {
    margin-top: 2px !important;
    font-size: 13px !important;
}

.dashboard-grid,
.dashboard-grid-compact {
    gap: 9px !important;
    margin-bottom: 10px !important;
}

.metric-card {
    padding: 11px 12px !important;
    border-radius: 13px !important;
}

.metric-card span,
.metric-card small {
    font-size: 12px !important;
    line-height: 1.25 !important;
}

.metric-card strong,
.metric-value strong {
    margin: 4px 0 !important;
    font-size: clamp(22px, 2.2vw, 31px) !important;
}

.monthly-card {
    margin-bottom: 10px !important;
    padding: 12px !important;
    border-radius: 13px !important;
}

.monthly-head .form-section-title {
    margin-bottom: 0 !important;
    font-size: 15px !important;
}

.month-row,
.month-row span,
.month-row strong,
.monthly-head .small {
    font-size: 12.5px !important;
}

.month-row {
    grid-template-columns: 88px minmax(90px, 1fr) 34px !important;
    gap: 8px !important;
}

.month-bar { height: 7px !important; }

.filter-card {
    gap: 8px !important;
    padding: 12px !important;
    margin-bottom: 10px !important;
}

.call-table {
    min-width: 1380px !important;
    table-layout: fixed !important;
}

.call-table th,
.call-table td {
    padding: 8px 8px !important;
}

.call-table th {
    font-size: 12px !important;
    letter-spacing: 0.035em !important;
}

.call-table .date-col { width: 104px !important; }
.call-table .client-col { width: 178px !important; }
.call-table .contact-col { width: 154px !important; }
.call-table .service-col { width: 138px !important; }
.call-table .alloc-col { width: 94px !important; }
.call-table .status-col { width: 132px !important; }
.call-table .quote-when-col { width: 122px !important; }
.call-table .quote-value-col { width: 88px !important; }
.call-table .calendar-col { width: 60px !important; }
.call-table .comment-col { width: 238px !important; }
.call-table .save-col { width: 64px !important; }

.entry-date-stack,
.entry-date-stack span,
.entry-date-stack small,
.client-name-link,
.client-message-preview,
.contact-info a,
.category-suburb-cell .service-main,
.category-suburb-cell .suburb-line {
    display: block !important;
    font-size: var(--compact-font) !important;
    line-height: 1.25 !important;
}

.entry-date-stack small,
.client-message-preview,
.category-suburb-cell .suburb-line {
    color: var(--muted) !important;
}

.client-name-link,
.category-suburb-cell .service-main {
    font-weight: 900 !important;
}

.client-message-preview,
.category-suburb-cell .suburb-line {
    margin-top: 4px !important;
}

.contact-info a {
    overflow-wrap: anywhere !important;
}

.inline-table-form select,
.inline-table-form input,
.inline-table-form textarea {
    min-height: 30px !important;
    margin-top: 0 !important;
    padding: 6px 7px !important;
    border-radius: 8px !important;
    font-size: var(--compact-font) !important;
    line-height: 1.2 !important;
}

.inline-table-form textarea {
    min-height: 58px !important;
}

.quote-when-fields {
    gap: 5px !important;
}

.inline-alloc-check,
.inline-spam-check {
    margin-bottom: 5px !important;
    gap: 5px !important;
    font-size: var(--compact-font) !important;
}

.latest-note-preview {
    margin-top: 6px !important;
    padding-top: 6px !important;
    font-size: 12.5px !important;
    line-height: 1.25 !important;
}

@media (max-width: 980px) {
    .side-menu,
    body.sidebar-collapsed .side-menu,
    html.sidebar-collapsed-preload .side-menu {
        position: sticky !important;
        top: 0 !important;
        min-height: 100vh !important;
    }
    .call-table { min-width: 1360px !important; }
}

/* v9 final compact override. Keep this block last. */
:root { --pbm-compact-font: 13.5px; }
body, input, select, textarea, button, .button { font-size: var(--pbm-compact-font); }
button, .button { min-height: 34px; padding: 7px 11px; line-height: 1.2; }
.button-mini { min-height: 28px; padding: 4px 7px; font-size: var(--pbm-compact-font); }
.topbar { padding: 10px 18px; gap: 14px; }
.brand { min-width: 220px; }
.brand-logo { width: 82px; max-height: 38px; }
.nav a { padding: 7px 10px; font-size: var(--pbm-compact-font); }
.user-chip-link { text-decoration: none; }
.user-chip-link:hover { text-decoration: none; background: rgba(255,255,255,.2); color: #fff; }

.side-menu {
    top: 59px;
    flex: 0 0 166px;
    min-height: calc(100vh - 59px);
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 10px 8px;
    opacity: 1;
    overflow: visible;
    pointer-events: auto;
}
.side-top { display: flex; align-items: center; justify-content: space-between; gap: 6px; min-height: 30px; }
.side-menu-title { padding: 0 3px; font-size: 11px; line-height: 1.1; letter-spacing: .075em; }
.side-collapse-button { width: 28px; min-width: 28px; min-height: 28px; padding: 0; border-radius: 9px; font-size: 18px; line-height: 1; background: #eef3fb; }
.side-links { display: grid; gap: 3px; overflow-y: auto; max-height: calc(100vh - 172px); padding-right: 2px; }
.side-link { padding: 6px 7px; border-radius: 9px; gap: 6px; font-size: 12.5px; line-height: 1.15; }
.side-link span { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.side-link strong { min-width: 22px; padding: 1px 6px; font-size: 11px; }
details.side-settings { margin-top: auto; position: relative; padding-top: 8px; border-top: 1px solid var(--line); }
details.side-settings summary { list-style: none; display: flex; align-items: center; justify-content: center; min-height: 32px; border: 1px solid var(--line); border-radius: 999px; background: #fff; color: var(--primary); font-size: 12.5px; font-weight: 900; cursor: pointer; user-select: none; }
details.side-settings summary::-webkit-details-marker { display: none; }
details.side-settings a { display: block; padding: 7px 9px; border-radius: 9px; color: var(--ink); font-size: 12.5px; font-weight: 800; }
details.side-settings a:hover { background: #eef3fb; text-decoration: none; }
details.side-settings[open] { z-index: 30; }
details.side-settings[open]::before { content: ''; position: absolute; left: 0; bottom: calc(100% + 7px); width: min(210px, calc(100vw - 24px)); height: calc(100% + 128px); max-height: 180px; border: 1px solid var(--line); border-radius: 12px; background: #fff; box-shadow: var(--shadow); z-index: -1; }
details.side-settings[open] a { position: relative; background: #fff; }

body.sidebar-collapsed .side-menu,
html.sidebar-collapsed-preload .side-menu {
    flex: 0 0 42px;
    width: 42px;
    min-width: 42px;
    padding: 10px 6px;
    border-right: 1px solid var(--line);
    opacity: 1;
    overflow: visible;
    pointer-events: auto;
}
body.sidebar-collapsed .side-menu-title,
body.sidebar-collapsed .side-links,
body.sidebar-collapsed .side-settings,
html.sidebar-collapsed-preload .side-menu-title,
html.sidebar-collapsed-preload .side-links,
html.sidebar-collapsed-preload .side-settings { display: none; }
body.sidebar-collapsed .side-top,
html.sidebar-collapsed-preload .side-top { justify-content: center; }
body.sidebar-collapsed .app-shell > .container,
body.sidebar-collapsed .app-shell > .container-wide,
html.sidebar-collapsed-preload .app-shell > .container,
html.sidebar-collapsed-preload .app-shell > .container-wide { margin-left: 12px; }

.app-shell > .container, .app-shell > .container-wide { margin-top: 14px; }
.page-head-compact { margin-bottom: 10px; }
.page-head-compact h1 { font-size: clamp(22px, 2.5vw, 31px); }
.page-head-compact p { margin: 2px 0 0; font-size: 13px; }
.dashboard-grid { gap: 9px; margin-bottom: 10px; }
.metric-card { padding: 10px 12px; border-radius: 13px; }
.metric-card span, .metric-card small { font-size: 12px; line-height: 1.25; }
.metric-card strong, .metric-value strong { margin: 4px 0; font-size: clamp(22px, 2.2vw, 30px); }
.monthly-card { margin-bottom: 10px; padding: 12px; border-radius: 13px; }
.monthly-head { margin-bottom: 6px; }
.monthly-head .form-section-title { margin: 0; font-size: 15px; }
.monthly-head .small, .month-row, .month-row span, .month-row strong { font-size: 12.5px; }
.month-bars { gap: 6px; }
.month-row { grid-template-columns: 88px minmax(90px, 1fr) 34px; gap: 8px; }
.month-bar { height: 7px; }
.filter-card { gap: 8px; padding: 12px; margin-bottom: 10px; align-items: end; }
.filter-search { min-width: 240px; flex-basis: 320px; }
.filter-select { min-width: 155px; flex-basis: 175px; }
.filter-card input, .filter-card select { padding: 7px 8px; border-radius: 9px; }
.show-spam-toggle { min-height: 34px; padding: 7px 10px; }

.call-table, .call-table th, .call-table td, .call-table input, .call-table select, .call-table textarea, .call-table .button, .call-table button, .call-table a, .call-table label, .inline-table-form { font-size: var(--pbm-compact-font); }
.call-table { min-width: 1360px; table-layout: fixed; }
.call-table th, .call-table td { padding: 8px 8px; line-height: 1.25; }
.call-table th { font-size: 12px; letter-spacing: .035em; }
.call-table .date-col { width: 98px; }
.call-table .client-col { width: 178px; }
.call-table .contact-col { width: 150px; }
.call-table .service-col { width: 140px; }
.call-table .alloc-col { width: 94px; }
.call-table .status-col { width: 132px; }
.call-table .quote-when-col { width: 122px; }
.call-table .quote-value-col { width: 88px; }
.call-table .calendar-col { width: 60px; }
.call-table .comment-col { width: 238px; }
.call-table .save-col { width: 64px; }
.entry-date-stack, .entry-date-stack span, .entry-date-stack small, .client-name-link, .client-message-preview, .contact-info a, .category-suburb-cell .service-main, .category-suburb-cell .suburb-line { display: block; }
.entry-date-stack span { font-weight: 800; line-height: 1.15; }
.entry-date-stack small { margin-top: 2px; color: var(--muted); font-size: 12.5px; line-height: 1.15; }
.client-name-link { font-weight: 900; line-height: 1.18; overflow-wrap: anywhere; }
.client-message-preview { margin-top: 4px; font-size: 12.5px !important; line-height: 1.25; }
.contact-info a { font-size: 13px; line-height: 1.25; overflow-wrap: anywhere; }
.category-suburb-cell .service-main { font-size: 13px; font-weight: 900; line-height: 1.2; }
.category-suburb-cell .suburb-line { margin-top: 3px; color: var(--muted); font-size: 12.5px; line-height: 1.2; }
.inline-table-form select, .inline-table-form input, .inline-table-form textarea { min-height: 30px; padding: 6px 7px; border-radius: 8px; line-height: 1.2; }
.inline-table-form textarea { min-height: 58px; }
.quote-when-fields { gap: 5px; }
.inline-alloc-check, .inline-spam-check { margin: 0 0 5px; gap: 5px; font-size: var(--pbm-compact-font); line-height: 1.2; }
.latest-note-preview { margin-top: 6px; padding-top: 6px; font-size: 12.5px !important; line-height: 1.25; }

@media (max-width: 1180px) { .side-menu { flex-basis: 158px; } }
@media (max-width: 980px) {
    .topbar { padding: 10px 12px; gap: 10px; }
    .brand { min-width: auto; }
    .brand-logo { width: 76px; max-height: 36px; }
    .app-shell { display: block; }
    .side-menu { position: sticky; top: 0; min-height: auto; width: 100%; flex-basis: auto; max-height: 55vh; border-right: 0; border-bottom: 1px solid var(--line); }
    .side-links { max-height: 38vh; }
    body.sidebar-collapsed .side-menu,
    html.sidebar-collapsed-preload .side-menu { width: 42px; min-width: 42px; padding: 8px 6px; display: flex; }
    body.sidebar-collapsed .side-links,
    body.sidebar-collapsed .side-settings,
    html.sidebar-collapsed-preload .side-links,
    html.sidebar-collapsed-preload .side-settings { display: none; }
    .dashboard-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .call-table { min-width: 1340px; }
}
@media (max-width: 680px) { .dashboard-grid { grid-template-columns: 1fr; } }

/* v9 class aliases for compact stacked cells. */
.contact-links a { display: block; word-break: break-word; }
.category-suburb-cell .service-name,
.category-suburb-cell .suburb-name,
.entry-date-line,
.entry-time-line { display: block; }

/* v9 final polish and compatibility overrides. */
:root { --compact-font: 13.5px; }
.button,
button,
input,
select,
textarea,
label,
.nav a,
.user-chip,
.user-chip-link {
    font-size: var(--compact-font) !important;
}
.button,
button {
    min-height: 34px;
    padding: 7px 11px;
    line-height: 1.2;
}
.button-mini { min-height: 28px; padding: 5px 8px; }
.nav a.active { background: rgba(255,255,255,0.18); color: #fff; }
.user-chip-link { display: inline-flex; align-items: center; justify-content: center; text-decoration: none; }
.user-chip-link:hover { text-decoration: none; background: rgba(255,255,255,0.2); color: #fff; }

.side-menu-main { min-height: 0; display: flex; flex-direction: column; gap: 6px; }
.side-menu-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 4px; }
.side-bottom { margin-top: auto; padding-top: 8px; border-top: 1px solid var(--line); }
.settings-menu { position: relative; }
.settings-menu summary { list-style: none; display: flex; align-items: center; justify-content: center; min-height: 32px; border: 1px solid var(--line); border-radius: 999px; background: #fff; color: var(--primary); font-size: 12.5px; font-weight: 900; cursor: pointer; user-select: none; }
.settings-menu summary::-webkit-details-marker { display: none; }
.settings-links { position: absolute; left: 0; bottom: calc(100% + 8px); width: min(210px, calc(100vw - 24px)); display: grid; gap: 4px; padding: 8px; border: 1px solid var(--line); border-radius: 12px; background: #fff; box-shadow: var(--shadow); z-index: 20; }
.settings-menu:not([open]) .settings-links { display: none; }
.settings-links a { display: block; padding: 7px 9px; border-radius: 9px; color: var(--ink); font-size: 12.5px; font-weight: 800; }
.settings-links a:hover { background: #eef3fb; text-decoration: none; }
body.sidebar-collapsed .side-menu,
html.sidebar-collapsed-preload .side-menu { flex-basis: 0; width: 0; min-width: 0; padding-left: 0; padding-right: 0; border-right: 0; opacity: 0; overflow: hidden; pointer-events: none; }
body.sidebar-collapsed .app-shell > .container,
body.sidebar-collapsed .app-shell > .container-wide,
html.sidebar-collapsed-preload .app-shell > .container,
html.sidebar-collapsed-preload .app-shell > .container-wide { margin-left: 8px; }

.call-table,
.call-table th,
.call-table td,
.call-table input,
.call-table select,
.call-table textarea,
.call-table a,
.call-table label,
.call-table .button,
.call-table button { font-size: var(--compact-font) !important; }
.call-table { min-width: 1360px; }
.call-table th,
.call-table td { padding: 8px 8px; }
.call-table th { font-size: 12px !important; }
.call-table .date-col { width: 98px; }
.call-table .client-col { width: 178px; }
.call-table .contact-col { width: 154px; }
.call-table .service-col { width: 138px; }
.call-table .alloc-col { width: 94px; }
.call-table .status-col { width: 132px; }
.call-table .quote-when-col { width: 122px; }
.call-table .quote-value-col { width: 88px; }
.call-table .calendar-col { width: 60px; }
.call-table .comment-col { width: 238px; }
.call-table .save-col { width: 64px; }
.entry-date-cell,
.contact-info,
.category-suburb-cell { line-height: 1.25; }
.entry-date-stack,
.entry-date-stack span,
.entry-date-stack small { display: block; line-height: 1.18; }
.entry-date-stack span { font-weight: 900; color: var(--ink); }
.entry-date-stack small { margin-top: 2px; color: var(--muted); font-size: 12.5px !important; }
.client-name-link { display: block; font-weight: 900; line-height: 1.15; overflow-wrap: anywhere; }
.client-message-preview { display: block; margin-top: 4px; font-size: 12.5px !important; line-height: 1.25; }
.contact-info a { display: block; max-width: 100%; line-height: 1.25; overflow-wrap: anywhere; }
.category-suburb-cell .service-main,
.category-suburb-cell .suburb-line { display: block; line-height: 1.2; overflow-wrap: anywhere; font-size: var(--compact-font) !important; }
.category-suburb-cell .service-main { font-weight: 900; }
.category-suburb-cell .suburb-line { margin-top: 3px; color: var(--muted); }
.inline-table-form select,
.inline-table-form input,
.inline-table-form textarea { min-height: 30px; padding: 6px 7px; border-radius: 8px; font-size: var(--compact-font) !important; }
.inline-table-form textarea { min-height: 58px; }
.quote-when-fields { gap: 5px; }
.inline-alloc-check,
.inline-spam-check { margin-bottom: 5px; gap: 5px; font-size: var(--compact-font) !important; }
.latest-note-preview { margin-top: 6px; padding-top: 6px; line-height: 1.25; font-size: 12.5px !important; }

@media (max-width: 980px) {
    .settings-links { left: 0; bottom: auto; top: calc(100% + 8px); }
    .call-table { min-width: 1360px; }
}


/* v10: one sidebar arrow only, and a full-width call-list table. */
.app-shell {
    display: flex !important;
    align-items: stretch !important;
    width: 100% !important;
    max-width: none !important;
}

.app-shell > main.container,
.app-shell > main.container-wide,
.app-shell > .container,
.app-shell > .container-wide {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    width: auto !important;
    max-width: none !important;
    margin: 14px 10px 60px !important;
}

.inline-table-form,
.table-wrap,
.table-wrap-wide {
    width: 100% !important;
    max-width: none !important;
}

.table-wrap,
.table-wrap-wide {
    overflow-x: auto !important;
}

.call-table {
    width: 100% !important;
    min-width: 100% !important;
    max-width: none !important;
    table-layout: fixed !important;
}

.call-table th,
.call-table td {
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
}

.call-table input,
.call-table select,
.call-table textarea,
.call-table .button,
.call-table button {
    max-width: 100% !important;
}

/* Collapsed sidebar remains as a slim rail so the same arrow can restore it. */
body.sidebar-collapsed .side-menu,
html.sidebar-collapsed-preload .side-menu {
    flex: 0 0 44px !important;
    width: 44px !important;
    min-width: 44px !important;
    padding: 10px 6px !important;
    border-right: 1px solid var(--line) !important;
    opacity: 1 !important;
    overflow: visible !important;
    pointer-events: auto !important;
}

body.sidebar-collapsed .side-menu-main,
html.sidebar-collapsed-preload .side-menu-main {
    display: block !important;
}

body.sidebar-collapsed .side-menu-head,
html.sidebar-collapsed-preload .side-menu-head {
    display: flex !important;
    justify-content: center !important;
    margin: 0 !important;
}

body.sidebar-collapsed .side-menu-title,
body.sidebar-collapsed .side-links,
body.sidebar-collapsed .side-bottom,
html.sidebar-collapsed-preload .side-menu-title,
html.sidebar-collapsed-preload .side-links,
html.sidebar-collapsed-preload .side-bottom {
    display: none !important;
}

body.sidebar-collapsed .side-collapse-button,
html.sidebar-collapsed-preload .side-collapse-button {
    display: inline-flex !important;
    width: 30px !important;
    min-width: 30px !important;
    min-height: 30px !important;
    padding: 0 !important;
    margin: 0 auto !important;
    pointer-events: auto !important;
    opacity: 1 !important;
}

@media (max-width: 980px) {
    .app-shell {
        display: block !important;
    }

    .app-shell > main.container,
    .app-shell > main.container-wide,
    .app-shell > .container,
    .app-shell > .container-wide {
        width: calc(100% - 16px) !important;
        margin: 10px 8px 50px !important;
    }

    body.sidebar-collapsed .side-menu,
    html.sidebar-collapsed-preload .side-menu {
        width: 44px !important;
        min-width: 44px !important;
        min-height: auto !important;
        margin: 0 0 0 8px !important;
    }

    .call-table {
        min-width: 1180px !important;
    }
}


/* v11: compact ICS, VOIP settings, and suburb tags. Keep this block last. */
.brand small { display: none !important; }
.call-table .calendar-col { display: none !important; }
.call-table .save-col { width: 72px !important; text-align: center; }
.call-table .comment-col { width: 252px !important; }
.call-table .service-col { width: 132px !important; }
.call-table .contact-col { width: 150px !important; }
.call-table .client-col { width: 174px !important; }
.call-table .quote-when-col { width: 116px !important; }
.call-table .quote-value-col { width: 84px !important; }
.row-actions-stack {
    display: grid;
    grid-template-columns: 1fr;
    gap: 5px;
    align-items: stretch;
    justify-items: stretch;
}
.row-actions-stack .button,
.row-actions-stack button {
    width: 100%;
    min-height: 28px;
    padding-left: 6px;
    padding-right: 6px;
}
.button-disabled,
.button-disabled:hover {
    background: #e5e7eb !important;
    border-color: #d1d5db !important;
    color: #8b98aa !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
    text-decoration: none !important;
}
.category-suburb-cell {
    display: flex !important;
    flex-direction: column !important;
    min-height: 76px;
    gap: 6px;
}
.category-suburb-cell .service-name,
.category-suburb-cell .service-main {
    display: block;
    font-weight: 900;
    line-height: 1.22;
}
.category-suburb-cell .suburb-tag {
    margin-top: auto !important;
    align-self: flex-start;
}
.suburb-tag {
    display: inline-flex !important;
    align-items: center;
    max-width: 100%;
    border: 1px solid #d8e2f1;
    border-radius: 999px;
    background: #eef3fb;
    color: var(--primary);
    padding: 3px 8px;
    font-size: 12.5px !important;
    font-weight: 900;
    line-height: 1.15;
    overflow-wrap: anywhere;
}
.show-spam-toggle { gap: 6px; padding-left: 10px; padding-right: 10px; }
.voip-settings-form code,
.voip-settings-form .code-box { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; }
.call-recording-item .button { margin-top: 8px; }
@media (max-width: 980px) { .call-table { min-width: 1120px !important; } }
.provider-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 10px;
    margin-top: 12px;
}
.subtle-card {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #f8fafc;
    padding: 12px;
}
.rotate-secret-box {
    align-self: end;
    min-height: 42px;
}


/* v11.1 final compact table, ICS action stack, and VoIP/suburb cleanup. */
.brand small { display: none !important; }
.call-table { width: 100% !important; min-width: 100% !important; table-layout: fixed !important; }
.call-table th, .call-table td { white-space: normal !important; overflow-wrap: anywhere !important; word-break: normal !important; }
.call-table .calendar-col { display: none !important; }
.call-table .date-col { width: 88px !important; }
.call-table .client-col { width: 168px !important; }
.call-table .contact-col { width: 140px !important; }
.call-table .service-col { width: 124px !important; }
.call-table .alloc-col { width: 88px !important; }
.call-table .status-col { width: 126px !important; }
.call-table .quote-when-col { width: 108px !important; }
.call-table .quote-value-col { width: 78px !important; }
.call-table .comment-col { width: 230px !important; }
.call-table .save-col { width: 70px !important; text-align: center !important; }
.row-actions-stack { display: grid !important; grid-template-columns: 1fr !important; gap: 5px !important; align-items: stretch !important; justify-items: stretch !important; }
.row-actions-stack .button, .row-actions-stack button { width: 100% !important; min-height: 28px !important; padding: 5px 7px !important; font-size: 13.5px !important; }
.button-disabled, .button-disabled:hover { background: #e5e7eb !important; border-color: #d1d5db !important; color: #8b98aa !important; cursor: not-allowed !important; pointer-events: none !important; text-decoration: none !important; }
.category-suburb-cell { display: flex !important; flex-direction: column !important; min-height: 76px !important; gap: 6px !important; }
.category-suburb-cell .service-name, .category-suburb-cell .service-main { display: block !important; font-weight: 900 !important; line-height: 1.22 !important; }
.category-suburb-cell .suburb-tag { margin-top: auto !important; align-self: flex-start !important; }
.suburb-tag { display: inline-flex !important; align-items: center !important; max-width: 100% !important; border: 1px solid #d8e2f1 !important; border-radius: 999px !important; background: #eef3fb !important; color: var(--primary) !important; padding: 3px 8px !important; font-size: 12.5px !important; font-weight: 900 !important; line-height: 1.15 !important; overflow-wrap: anywhere !important; }
.show-spam-toggle { gap: 6px !important; padding-left: 10px !important; padding-right: 10px !important; }
.voip-settings-form code, .voip-settings-form .code-box { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace !important; }
.call-recording-item .button { margin-top: 8px !important; }
@media (max-width: 980px) { .call-table { min-width: 1120px !important; } }


/* v11.2: keep category at top and suburb tag anchored at bottom without forcing the table cell itself into flex layout. */
.category-suburb-cell { display: table-cell !important; min-height: 0 !important; }
.category-suburb-stack { display: flex !important; flex-direction: column !important; gap: 6px !important; min-height: 74px !important; height: 100% !important; }
.category-suburb-stack .suburb-tag { margin-top: auto !important; align-self: flex-start !important; text-transform: none !important; }
.button-ics[disabled] { background: #e5e7eb !important; border-color: #d1d5db !important; color: #8b98aa !important; cursor: not-allowed !important; }


/* v12: tighter inline controls, 2-digit year dates, sticky filters, and scrollable entries. Keep this block last. */
:root { --pbm-v12-compact-font: 13.5px; }

.filter-card {
    position: sticky !important;
    top: 60px !important;
    z-index: 8 !important;
    margin-bottom: 8px !important;
    box-shadow: 0 10px 24px rgba(24, 34, 53, 0.10) !important;
}

.filter-card .button,
.filter-card button,
.filter-card .show-spam-toggle {
    min-height: 34px !important;
    padding: 7px 12px !important;
    font-size: var(--pbm-v12-compact-font) !important;
    line-height: 1.2 !important;
}

.filter-card .show-spam-toggle {
    color: var(--ink) !important;
    font-weight: 800 !important;
    border-radius: 999px !important;
}

.filter-card .show-spam-toggle input,
.inline-alloc-check input,
.inline-spam-check input {
    width: 15px !important;
    height: 15px !important;
    flex: 0 0 15px !important;
}

.table-wrap-wide {
    max-height: calc(100vh - 150px) !important;
    overflow: auto !important;
}

.call-table thead th {
    position: sticky !important;
    top: 0 !important;
    z-index: 3 !important;
}

.call-table,
.call-table th,
.call-table td,
.call-table input,
.call-table select,
.call-table textarea,
.call-table a,
.call-table label,
.call-table .button,
.call-table button {
    font-size: var(--pbm-v12-compact-font) !important;
}

.call-table th,
.call-table td {
    padding: 7px 7px !important;
}

.call-table .date-col { width: 76px !important; }
.call-table .client-col { width: 162px !important; }
.call-table .contact-col { width: 138px !important; }
.call-table .service-col { width: 122px !important; }
.call-table .alloc-col { width: 84px !important; }
.call-table .status-col { width: 95px !important; }
.call-table .quote-when-col { width: 82px !important; }
.call-table .quote-value-col { width: 86px !important; padding-left: 12px !important; }
.call-table .comment-col { width: 242px !important; }
.call-table .save-col { width: 68px !important; }

.call-table .status-col select.inline-status {
    width: 100% !important;
    min-width: 0 !important;
    padding-left: 6px !important;
    padding-right: 18px !important;
}

.quote-when-fields {
    gap: 4px !important;
}

.quote-when-fields input,
.quote-when-fields .inline-date,
.quote-when-fields .inline-time {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
    letter-spacing: -0.02em !important;
}

.compact-date-input::placeholder {
    color: #8b98aa !important;
    opacity: 1 !important;
}

.call-table .quote-value-col .inline-money {
    width: calc(100% - 4px) !important;
    margin-left: 4px !important;
    padding-left: 7px !important;
    padding-right: 7px !important;
}

.entry-date-cell {
    line-height: 1.18 !important;
}

.entry-date-line,
.entry-time-line {
    display: block !important;
    white-space: nowrap !important;
}

.inline-spam-check {
    color: var(--ink) !important;
}

.category-suburb-stack {
    min-height: 70px !important;
}

@media (max-width: 980px) {
    .filter-card {
        position: static !important;
        top: auto !important;
    }
    .table-wrap-wide {
        max-height: none !important;
    }
    .call-table { min-width: 1060px !important; }
}
