:root {
    --black: #111111;
    --black-soft: #1c1c1c;
    --gold: #dcae57;
    --gold-dark: #b88934;
    --gold-pale: #f7edd9;
    --page: #f5f5f3;
    --surface: #ffffff;
    --line: #e4e4df;
    --text: #1d1d1b;
    --muted: #6f706c;
    --danger: #b42318;
    --danger-pale: #fef3f2;
    --success: #16794b;
    --success-pale: #ecfdf3;
    --warning: #9a6700;
    --warning-pale: #fffaeb;
    --shadow: 0 12px 35px rgba(17, 17, 17, 0.06);
}

* {
    box-sizing: border-box;
}

html {
    min-height: 100%;
}

body {
    min-height: 100vh;
    margin: 0;
    background: var(--page);
    color: var(--text);
    font-family: "Montserrat", "Segoe UI", Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
}

a {
    color: inherit;
    text-decoration: none;
}

.app-shell {
    min-height: 100vh;
}

.sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 10;
    display: flex;
    width: 244px;
    flex-direction: column;
    background: var(--black);
    color: #ffffff;
    padding: 28px 20px 22px;
}

.brand {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 8px 28px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.brand-logo {
    display: block;
    width: 78px;
    height: auto;
    flex: 0 0 auto;
    object-fit: contain;
}

.brand-copy {
    display: flex;
    min-width: 0;
    flex-direction: column;
}

.brand-copy strong {
    font-size: 15px;
    letter-spacing: 0.01em;
}

.brand-copy small {
    margin-top: 4px;
    color: rgba(255, 255, 255, 0.58);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.main-nav {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 6px;
    padding-top: 28px;
}

.nav-link {
    border-left: 3px solid transparent;
    border-radius: 4px;
    color: rgba(255, 255, 255, 0.7);
    font-size: 14px;
    font-weight: 600;
    padding: 12px 14px;
    transition: 160ms ease;
}

.nav-link:hover {
    background: rgba(255, 255, 255, 0.07);
    color: #ffffff;
}

.nav-link-active {
    border-left-color: var(--gold);
    background: rgba(220, 174, 87, 0.12);
    color: var(--gold);
}

.sidebar-footer {
    display: flex;
    flex-direction: column;
    gap: 5px;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    padding: 20px 8px 0;
}

.sidebar-footer span {
    color: rgba(255, 255, 255, 0.48);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.sidebar-footer strong {
    overflow: hidden;
    font-size: 13px;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.sidebar-footer a {
    margin-top: 7px;
    color: var(--gold);
    font-size: 12px;
    font-weight: 700;
}

.main-content {
    min-height: 100vh;
    margin-left: 244px;
    padding: 36px 42px 52px;
}

.page-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 28px;
}

.eyebrow,
.panel-kicker {
    margin: 0 0 7px;
    color: var(--gold-dark);
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.14em;
}

.page-header h1 {
    margin: 0;
    color: var(--black);
    font-size: clamp(32px, 4vw, 48px);
    font-weight: 750;
    letter-spacing: -0.04em;
}

.page-subtitle {
    margin: 7px 0 0;
    color: var(--muted);
    font-size: 15px;
}

.quick-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
}

.button {
    display: inline-flex;
    min-height: 42px;
    align-items: center;
    justify-content: center;
    border: 1px solid transparent;
    border-radius: 4px;
    padding: 0 17px;
    font-size: 13px;
    font-weight: 750;
    transition: 160ms ease;
}

.button-primary {
    background: var(--gold);
    color: var(--black);
}

.button-primary:hover {
    background: #e7bb68;
}

.button-secondary {
    border-color: #d9d9d4;
    background: var(--surface);
    color: var(--text);
}

.button-secondary:hover {
    border-color: var(--gold);
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 20px;
}

.stat-card {
    position: relative;
    overflow: hidden;
    min-height: 138px;
    border: 1px solid var(--line);
    border-radius: 7px;
    background: var(--surface);
    box-shadow: var(--shadow);
    padding: 20px 22px;
}

.stat-card::before {
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: var(--gold);
    content: "";
}

.stat-card-alert::before {
    background: var(--danger);
}

.stat-label {
    display: block;
    color: var(--muted);
    font-size: 12px;
    font-weight: 700;
}

.stat-value {
    display: block;
    margin-top: 8px;
    color: var(--black);
    font-size: 38px;
    line-height: 1;
    letter-spacing: -0.04em;
}

.stat-detail {
    display: block;
    margin-top: 13px;
    color: #92938e;
    font-size: 11px;
}

.dashboard-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(310px, 0.8fr);
    gap: 20px;
}

.panel {
    min-width: 0;
    border: 1px solid var(--line);
    border-radius: 7px;
    background: var(--surface);
    box-shadow: var(--shadow);
    padding: 22px;
}

.panel-large {
    grid-row: span 2;
}

.panel-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 19px;
    padding-bottom: 15px;
    border-bottom: 1px solid var(--line);
}

.panel-header h2 {
    margin: 0;
    color: var(--black);
    font-size: 19px;
    letter-spacing: -0.02em;
}

.panel-kicker-alert {
    color: var(--danger);
}

.text-link {
    flex: 0 0 auto;
    color: var(--gold-dark);
    font-size: 12px;
    font-weight: 750;
}

.text-link:hover {
    text-decoration: underline;
}

.timeline {
    display: flex;
    flex-direction: column;
}

.timeline-item {
    display: grid;
    grid-template-columns: 56px 18px minmax(0, 1fr);
    gap: 13px;
    min-height: 105px;
}

.timeline-time {
    display: flex;
    flex-direction: column;
    padding-top: 2px;
}

.timeline-time strong {
    color: var(--black);
    font-size: 14px;
}

.timeline-time span {
    margin-top: 4px;
    color: var(--muted);
    font-size: 11px;
}

.timeline-marker {
    position: relative;
}

.timeline-marker::before {
    position: absolute;
    top: 5px;
    left: 5px;
    z-index: 2;
    width: 8px;
    height: 8px;
    border: 2px solid var(--gold);
    border-radius: 50%;
    background: var(--surface);
    content: "";
}

.timeline-marker::after {
    position: absolute;
    top: 19px;
    bottom: 0;
    left: 9px;
    width: 1px;
    background: var(--line);
    content: "";
}

.timeline-item:last-child .timeline-marker::after {
    display: none;
}

.timeline-content {
    padding: 0 0 24px;
}

.timeline-content h3,
.list-item h3 {
    margin: 0;
    color: var(--black);
    font-size: 14px;
    line-height: 1.35;
}

.timeline-content p,
.list-item p {
    margin: 7px 0 4px;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.5;
}

.item-heading-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
}

.badge,
.priority {
    display: inline-flex;
    flex: 0 0 auto;
    align-items: center;
    border-radius: 999px;
    padding: 4px 8px;
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.badge-confirmed,
.badge-completed {
    background: var(--success-pale);
    color: var(--success);
}

.badge-tentative,
.badge-neutral {
    background: var(--gold-pale);
    color: var(--gold-dark);
}

.badge-cancelled,
.badge-no_show {
    background: var(--danger-pale);
    color: var(--danger);
}

.priority-low {
    background: #f2f4f7;
    color: #667085;
}

.priority-normal {
    background: #eef4ff;
    color: #3538cd;
}

.priority-high {
    background: var(--warning-pale);
    color: var(--warning);
}

.priority-urgent {
    background: var(--danger-pale);
    color: var(--danger);
}

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

.item-list {
    display: flex;
    flex-direction: column;
    gap: 9px;
}

.list-item {
    display: flex;
    gap: 13px;
    border: 1px solid var(--line);
    border-radius: 5px;
    padding: 13px;
    transition: 160ms ease;
}

.list-item:hover {
    border-color: #cab585;
    transform: translateY(-1px);
}

.list-item-alert {
    border-left: 3px solid var(--danger);
    background: #fffafa;
}

.list-item > .item-heading-row {
    width: 100%;
}

.list-item:has(.item-heading-row) {
    display: block;
}

.date-tile {
    display: flex;
    width: 44px;
    min-width: 44px;
    height: 48px;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border: 1px solid #e4d3b0;
    border-radius: 4px;
    background: var(--gold-pale);
}

.date-tile strong {
    font-size: 16px;
    line-height: 1;
}

.date-tile span {
    margin-top: 4px;
    color: var(--gold-dark);
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
}

.list-item-main {
    min-width: 0;
}

.empty-state {
    display: flex;
    min-height: 180px;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border: 1px dashed #d7d7d1;
    border-radius: 5px;
    background: #fafaf8;
    padding: 25px;
    text-align: center;
}

.empty-state.compact {
    min-height: 125px;
}

.empty-state strong {
    font-size: 14px;
}

.empty-state p {
    margin: 7px 0;
    color: var(--muted);
    font-size: 12px;
}

.empty-state a {
    margin-top: 5px;
    color: var(--gold-dark);
    font-size: 12px;
    font-weight: 750;
}

.active-jobs-panel {
    margin-top: 20px;
}

.table-wrap {
    overflow-x: auto;
}

.data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
}

.data-table th,
.data-table td {
    border-bottom: 1px solid var(--line);
    padding: 13px 12px;
    text-align: left;
    vertical-align: top;
}

.data-table th {
    color: var(--muted);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.data-table tbody tr:hover {
    background: #fbfaf7;
}

.data-table td:first-child a {
    color: var(--gold-dark);
    font-weight: 800;
}

.table-subtext {
    display: block;
    margin-top: 4px;
    color: var(--muted);
    font-size: 10px;
}

@media (max-width: 1120px) {
    .stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .dashboard-grid {
        grid-template-columns: 1fr;
    }

    .panel-large {
        grid-row: auto;
    }
}

@media (max-width: 780px) {
    .sidebar {
        position: static;
        width: auto;
        padding: 18px;
    }

    .main-nav {
        flex-direction: row;
        overflow-x: auto;
        padding-top: 17px;
    }

    .nav-link {
        flex: 0 0 auto;
        border-left: 0;
        border-bottom: 2px solid transparent;
    }

    .nav-link-active {
        border-bottom-color: var(--gold);
    }

    .sidebar-footer {
        display: none;
    }

    .main-content {
        margin-left: 0;
        padding: 25px 18px 40px;
    }

    .page-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .quick-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 560px) {
    .stats-grid {
        grid-template-columns: 1fr;
    }

    .stat-card {
        min-height: 115px;
    }

    .panel {
        padding: 17px;
    }

    .button {
        width: 100%;
    }

    .quick-actions {
        width: 100%;
    }
}

/* Enquiry pipeline */

.message-stack {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 20px;
}

.message {
    border: 1px solid var(--line);
    border-left: 4px solid var(--gold);
    border-radius: 5px;
    background: var(--surface);
    box-shadow: var(--shadow);
    padding: 14px 16px;
    font-size: 13px;
    font-weight: 650;
}

.message-success {
    border-left-color: var(--success);
    background: var(--success-pale);
}

.message-error {
    border-left-color: var(--danger);
    background: var(--danger-pale);
}

.message-info {
    border-left-color: var(--gold);
    background: var(--gold-pale);
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    clip-path: inset(50%);
}

.pipeline-panel {
    padding: 0;
    overflow: hidden;
}

.pipeline-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    border-bottom: 1px solid var(--line);
    padding: 18px 20px;
}

.pipeline-filters {
    display: flex;
    min-width: 0;
    flex: 1;
    align-items: center;
    gap: 10px;
}

.search-field {
    width: min(430px, 100%);
}

.search-field input,
.select-field select {
    width: 100%;
    min-height: 42px;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    background: #ffffff;
    color: var(--text);
    font: inherit;
    font-size: 13px;
    padding: 0 13px;
}

.search-field input:focus,
.select-field select:focus {
    border-color: var(--gold);
    outline: 2px solid rgba(220, 174, 87, 0.18);
}

.select-field {
    min-width: 190px;
}

.clear-filter {
    padding: 8px;
}

.view-toggle {
    display: inline-flex;
    flex: 0 0 auto;
    border: 1px solid #d9d9d4;
    border-radius: 5px;
    background: #ffffff;
    padding: 3px;
}

.view-toggle-link {
    border-radius: 3px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
    padding: 8px 13px;
}

.view-toggle-active {
    background: var(--black);
    color: var(--gold);
}

.enquiry-table th,
.enquiry-table td {
    padding: 15px 14px;
}

.enquiry-table tbody tr:last-child td {
    border-bottom: 0;
}

.table-actions,
.enquiry-card-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 7px;
}

.table-actions form,
.enquiry-card-actions form {
    margin: 0;
}

.button-small {
    min-height: 32px;
    padding: 0 11px;
    font-size: 11px;
}

.readiness-note {
    display: inline-block;
    max-width: 170px;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.35;
}

.pipeline-board {
    display: grid;
    grid-template-columns: repeat(6, minmax(260px, 1fr));
    gap: 14px;
    overflow-x: auto;
    padding: 18px;
}

.board-column {
    min-height: 440px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #f8f8f6;
}

.board-column-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid var(--line);
    padding: 14px;
}

.board-column-header h2 {
    margin: 0;
    color: var(--black);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.board-column-header span {
    display: grid;
    min-width: 24px;
    height: 24px;
    place-items: center;
    border-radius: 999px;
    background: var(--gold-pale);
    color: var(--gold-dark);
    font-size: 10px;
    font-weight: 800;
}

.board-card-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 10px;
}

.enquiry-card {
    border: 1px solid var(--line);
    border-radius: 5px;
    background: var(--surface);
    box-shadow: 0 7px 18px rgba(17, 17, 17, 0.04);
    padding: 14px;
}

.enquiry-card-topline {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 8px;
}

.enquiry-card-topline > a {
    color: var(--gold-dark);
    font-size: 11px;
    font-weight: 800;
}

.enquiry-card h3 {
    margin: 13px 0 5px;
    color: var(--black);
    font-size: 15px;
}

.enquiry-property {
    min-height: 36px;
    margin: 0;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.5;
}

.enquiry-card-meta {
    display: grid;
    gap: 8px;
    margin: 14px 0;
    padding: 12px 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}

.enquiry-card-meta div {
    display: grid;
    grid-template-columns: 64px minmax(0, 1fr);
    gap: 8px;
}

.enquiry-card-meta dt {
    color: #93948f;
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.enquiry-card-meta dd {
    margin: 0;
    color: var(--text);
    font-size: 11px;
}

.board-empty {
    display: grid;
    min-height: 100px;
    place-items: center;
    color: var(--muted);
    font-size: 11px;
}

@media (max-width: 900px) {
    .pipeline-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .pipeline-filters {
        flex-wrap: wrap;
    }

    .search-field {
        width: 100%;
    }

    .view-toggle {
        align-self: flex-start;
    }
}

@media (max-width: 620px) {
    .pipeline-filters {
        align-items: stretch;
        flex-direction: column;
    }

    .select-field {
        width: 100%;
    }

    .pipeline-filters .button {
        width: 100%;
    }

    .enquiry-stats {
        grid-template-columns: 1fr;
    }
}

/* Jobs pipeline */

.jobs-toolbar {
    align-items: flex-start;
}

.jobs-filters {
    flex-wrap: wrap;
}

.jobs-filters .search-field {
    flex: 1 1 360px;
}

.jobs-filters .select-field {
    flex: 0 1 190px;
}

.jobs-filters .sort-field {
    flex-basis: 210px;
}

.jobs-board {
    grid-template-columns: repeat(7, minmax(285px, 1fr));
}

.job-board-column {
    min-height: 510px;
}

.job-card-alert {
    border-left: 3px solid var(--danger);
}

.job-card-readiness,
.readiness-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.job-card-readiness {
    margin-top: 13px;
}

.readiness-chip,
.readiness-indicator {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    border: 1px solid transparent;
    border-radius: 999px;
    padding: 4px 7px;
    font-size: 9px;
    font-weight: 750;
    line-height: 1;
    white-space: nowrap;
}

.readiness-ready {
    border-color: #b7ebcd;
    background: var(--success-pale);
    color: var(--success);
}

.readiness-pending {
    border-color: #dedfd9;
    background: #f4f4f1;
    color: #777872;
}

.job-card-meta div {
    grid-template-columns: 72px minmax(0, 1fr);
}

.attention-line {
    margin: -3px 0 12px;
    color: var(--danger);
    font-size: 10px;
    font-weight: 800;
}

.jobs-table {
    min-width: 1320px;
}

.jobs-table td {
    vertical-align: middle;
}

.jobs-table td:nth-child(2) {
    min-width: 145px;
}

.jobs-table td:nth-child(3) {
    min-width: 220px;
}

.jobs-table td:nth-child(4) {
    min-width: 180px;
}

.jobs-table td:nth-child(6) {
    min-width: 220px;
}

.jobs-table td:nth-child(8) {
    min-width: 220px;
}

.job-row-alert {
    background: #fffafa;
}

.job-row-alert td:first-child {
    box-shadow: inset 3px 0 0 var(--danger);
}

.table-alert-text {
    color: var(--danger);
    font-weight: 800;
}

@media (max-width: 1100px) {
    .jobs-toolbar {
        align-items: stretch;
    }

    .jobs-filters .search-field,
    .jobs-filters .select-field,
    .jobs-filters .sort-field {
        flex: 1 1 220px;
    }
}

/* Custom individual job record */

.job-detail-topbar {
    margin-bottom: 18px;
}

.back-link {
    color: var(--gold-dark);
    font-size: 12px;
    font-weight: 750;
}

.job-detail-header {
    align-items: center;
}

.job-title-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 14px;
}

.job-title-row h1 {
    margin: 0;
}

.job-summary-grid .stat-value-money {
    font-size: 27px;
    line-height: 1.15;
}

.job-summary-grid .stat-value-date {
    font-size: 25px;
    line-height: 1.15;
}

.job-detail-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.65fr) minmax(310px, 0.75fr);
    gap: 20px;
    align-items: start;
}

.job-detail-main,
.job-detail-sidebar {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 20px;
}

.job-overview-form input,
.job-overview-form select,
.job-overview-form textarea {
    width: 100%;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    background: #ffffff;
    color: var(--text);
    font: inherit;
    font-size: 13px;
    padding: 10px 11px;
}

.job-overview-form input,
.job-overview-form select {
    min-height: 42px;
}

.job-overview-form textarea {
    resize: vertical;
}

.job-overview-form input:focus,
.job-overview-form select:focus,
.job-overview-form textarea:focus {
    border-color: var(--gold);
    outline: 2px solid rgba(220, 174, 87, 0.18);
}

.form-grid {
    display: grid;
    gap: 15px;
}

.form-grid-three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.form-field {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 7px;
}

.form-field > span {
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.form-field-span-two {
    grid-column: span 2;
}

.form-field-span-three {
    grid-column: span 3;
}

.form-actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 18px;
}

.errorlist {
    margin: 0;
    padding: 0;
    color: var(--danger);
    font-size: 11px;
    list-style: none;
}

.form-error-summary {
    margin-bottom: 15px;
    border-left: 3px solid var(--danger);
    background: var(--danger-pale);
    padding: 11px 13px;
    color: var(--danger);
    font-size: 12px;
    font-weight: 700;
}

.readiness-total {
    color: var(--muted);
    font-size: 11px;
    font-weight: 750;
}

.readiness-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.readiness-detail-card {
    display: flex;
    min-height: 145px;
    flex-direction: column;
    justify-content: space-between;
    gap: 15px;
    border: 1px solid var(--line);
    border-left: 3px solid #cfcfc9;
    border-radius: 5px;
    background: #fafaf8;
    padding: 15px;
}

.readiness-detail-ready {
    border-left-color: var(--success);
    background: var(--success-pale);
}

.readiness-detail-icon {
    display: grid;
    width: 27px;
    height: 27px;
    place-items: center;
    margin-bottom: 10px;
    border-radius: 50%;
    background: #eeeeea;
    color: var(--muted);
    font-size: 11px;
    font-weight: 850;
}

.readiness-detail-ready .readiness-detail-icon {
    background: var(--success);
    color: #ffffff;
}

.readiness-detail-card h3 {
    margin: 0;
    color: var(--black);
    font-size: 14px;
}

.readiness-detail-card p {
    margin: 6px 0 0;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.45;
}

.text-action {
    border: 0;
    background: transparent;
    color: var(--gold-dark);
    cursor: pointer;
    font: inherit;
    font-size: 11px;
    font-weight: 800;
    padding: 0;
}

.text-action:hover {
    text-decoration: underline;
}

.job-task-list,
.appointment-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.job-task-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    border: 1px solid var(--line);
    border-radius: 5px;
    padding: 14px;
}

.job-task-overdue {
    border-left: 3px solid var(--danger);
    background: #fffafa;
}

.job-task-main {
    min-width: 0;
    flex: 1;
}

.job-task-main h3,
.appointment-row h3 {
    margin: 0;
    color: var(--black);
    font-size: 13px;
}

.job-task-main p,
.appointment-row p {
    margin: 5px 0;
    color: var(--muted);
    font-size: 11px;
}

.task-item-actions {
    display: flex;
    flex: 0 0 auto;
    align-items: center;
    gap: 7px;
}

.completed-tasks {
    margin-top: 16px;
    border-top: 1px solid var(--line);
    padding-top: 14px;
}

.completed-tasks summary {
    color: var(--muted);
    cursor: pointer;
    font-size: 11px;
    font-weight: 750;
}

.completed-task-list {
    display: flex;
    flex-direction: column;
    gap: 7px;
    margin-top: 11px;
}

.completed-task-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: var(--muted);
    font-size: 11px;
}

.appointment-row {
    display: flex;
    align-items: center;
    gap: 13px;
    border: 1px solid var(--line);
    border-radius: 5px;
    padding: 13px;
    transition: 160ms ease;
}

.appointment-row:hover {
    border-color: #cab585;
    transform: translateY(-1px);
}

.appointment-row-main {
    min-width: 0;
    flex: 1;
}

.progress-action-grid {
    display: flex;
    flex-direction: column;
    gap: 9px;
}

.progress-action-card {
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr) auto;
    align-items: center;
    gap: 13px;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #fafaf8;
    padding: 13px;
}

.progress-action-card > span {
    display: grid;
    width: 28px;
    height: 28px;
    place-items: center;
    border-radius: 50%;
    background: #e9e9e4;
    color: var(--muted);
    font-size: 10px;
    font-weight: 850;
}

.progress-action-card h3 {
    margin: 0;
    font-size: 13px;
}

.progress-action-card p {
    margin: 4px 0 0;
    color: var(--muted);
    font-size: 10px;
}

.progress-complete {
    border-left: 3px solid var(--success);
    background: var(--success-pale);
}

.progress-complete > span {
    background: var(--success);
    color: #ffffff;
}

.detail-list {
    display: flex;
    flex-direction: column;
    gap: 13px;
    margin: 0;
}

.detail-list-spaced {
    margin-top: 18px;
}

.detail-list div {
    display: grid;
    grid-template-columns: 105px minmax(0, 1fr);
    gap: 12px;
}

.detail-list dt {
    color: var(--muted);
    font-size: 10px;
    font-weight: 750;
}

.detail-list dd {
    min-width: 0;
    margin: 0;
    color: var(--text);
    font-size: 11px;
    overflow-wrap: anywhere;
}

.detail-list a {
    color: var(--gold-dark);
    font-weight: 700;
}

.property-address {
    color: var(--text);
    font-size: 13px;
    font-style: normal;
    line-height: 1.65;
}

.button-full {
    width: 100%;
    margin-top: 18px;
}

.activity-list {
    display: flex;
    flex-direction: column;
}

.activity-item {
    position: relative;
    display: grid;
    grid-template-columns: 15px minmax(0, 1fr);
    gap: 10px;
    padding-bottom: 18px;
}

.activity-item::before {
    position: absolute;
    top: 10px;
    bottom: 0;
    left: 5px;
    width: 1px;
    background: var(--line);
    content: "";
}

.activity-item:last-child::before {
    display: none;
}

.activity-dot {
    position: relative;
    z-index: 1;
    width: 11px;
    height: 11px;
    margin-top: 2px;
    border: 2px solid var(--gold);
    border-radius: 50%;
    background: var(--surface);
}

.activity-item h3 {
    margin: 0;
    font-size: 11px;
}

.activity-item p {
    margin: 4px 0;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.45;
}

.activity-item span {
    color: #999a95;
    font-size: 9px;
}

@media (max-width: 1180px) {
    .job-detail-layout {
        grid-template-columns: 1fr;
    }

    .job-detail-sidebar {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .job-detail-sidebar .panel:last-child {
        grid-column: span 2;
    }
}

@media (max-width: 820px) {
    .form-grid-three {
        grid-template-columns: 1fr;
    }

    .form-field-span-two,
    .form-field-span-three {
        grid-column: auto;
    }

    .readiness-detail-grid,
    .job-detail-sidebar {
        grid-template-columns: 1fr;
    }

    .job-detail-sidebar .panel:last-child {
        grid-column: auto;
    }

    .job-task-item {
        align-items: stretch;
        flex-direction: column;
    }

    .task-item-actions {
        justify-content: flex-end;
    }
}

@media (max-width: 560px) {
    .progress-action-card {
        grid-template-columns: 30px minmax(0, 1fr);
    }

    .progress-action-card form {
        grid-column: 2;
    }
}

/* Job documents */

.document-section-layout {
    display: grid;
    grid-template-columns: minmax(280px, 0.75fr) minmax(0, 1.35fr);
    gap: 20px;
    align-items: start;
}

.document-upload-form {
    display: flex;
    flex-direction: column;
    gap: 16px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #fafaf8;
    padding: 17px;
}

.document-upload-heading h3 {
    margin: 0;
    color: var(--black);
    font-size: 15px;
}

.document-upload-heading p {
    margin: 6px 0 0;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.5;
}

.document-upload-form input,
.document-upload-form select,
.document-upload-form textarea {
    width: 100%;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    background: #ffffff;
    color: var(--text);
    font: inherit;
    font-size: 12px;
    padding: 10px 11px;
}

.document-upload-form input[type="file"] {
    min-height: 44px;
    padding: 8px;
}

.document-upload-form input:focus,
.document-upload-form select:focus,
.document-upload-form textarea:focus {
    border-color: var(--gold);
    outline: 2px solid rgba(220, 174, 87, 0.18);
}

.checkbox-field {
    display: flex;
    align-items: center;
    gap: 9px;
    color: var(--text);
    font-size: 11px;
    font-weight: 700;
}

.checkbox-field input {
    width: auto;
    margin: 0;
}

.field-help {
    color: var(--muted);
    font-size: 9px;
}

.document-list {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 10px;
}

.document-row {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) auto;
    gap: 13px;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: var(--surface);
    padding: 14px;
}

.document-icon {
    display: grid;
    width: 44px;
    height: 48px;
    place-items: center;
    border: 1px solid #e4d3b0;
    border-radius: 4px;
    background: var(--gold-pale);
    color: var(--gold-dark);
    font-size: 9px;
    font-weight: 850;
    letter-spacing: 0.05em;
}

.document-main {
    min-width: 0;
}

.document-title-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

.document-title-row > a {
    color: var(--black);
    font-size: 13px;
    font-weight: 800;
    overflow-wrap: anywhere;
}

.document-title-row > a:hover {
    color: var(--gold-dark);
}

.document-main > p {
    margin: 6px 0 4px;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.document-notes {
    border-left: 2px solid var(--gold);
    padding-left: 8px;
}

.document-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 7px;
}

.document-actions form {
    margin: 0;
}

.button-danger-outline {
    border-color: #efc4c0;
    background: #ffffff;
    color: var(--danger);
}

.button-danger-outline:hover {
    border-color: var(--danger);
    background: var(--danger-pale);
}

.text-action-warning {
    color: var(--warning);
}

@media (max-width: 980px) {
    .document-section-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 620px) {
    .document-row {
        grid-template-columns: 40px minmax(0, 1fr);
    }

    .document-actions {
        grid-column: 2;
        justify-content: flex-start;
    }
}


/* Custom appointments calendar */

.calendar-panel {
    padding: 0;
    overflow: hidden;
}

.calendar-toolbar {
    display: grid;
    grid-template-columns: auto minmax(180px, 1fr) auto;
    align-items: center;
    gap: 18px;
    border-bottom: 1px solid var(--line);
    padding: 18px 20px;
}

.calendar-navigation,
.calendar-filters {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

.calendar-range {
    text-align: center;
}

.calendar-range strong {
    color: var(--black);
    font-size: 16px;
}

.calendar-filters {
    justify-content: flex-end;
}

.calendar-filters .select-field {
    min-width: 175px;
}

.week-calendar-wrap {
    overflow-x: auto;
}

.week-calendar {
    display: grid;
    min-width: 1120px;
    grid-template-columns: repeat(7, minmax(150px, 1fr));
}

.calendar-day {
    min-height: 510px;
    border-right: 1px solid var(--line);
    background: #fbfbf9;
}

.calendar-day:last-child {
    border-right: 0;
}

.calendar-day-today {
    background: #fffaf0;
}

.calendar-day-header {
    display: flex;
    min-height: 70px;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid var(--line);
    padding: 12px;
}

.calendar-day-header div {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.calendar-day-header span {
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.calendar-day-header strong {
    color: var(--black);
    font-size: 22px;
}

.calendar-day-header > a {
    display: grid;
    width: 27px;
    height: 27px;
    place-items: center;
    border: 1px solid #dfdfda;
    border-radius: 50%;
    background: #ffffff;
    color: var(--gold-dark);
    font-size: 16px;
    font-weight: 800;
}

.calendar-day-body {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 9px;
}

.calendar-event {
    display: block;
    border: 1px solid #e3d3af;
    border-left: 3px solid var(--gold);
    border-radius: 5px;
    background: #ffffff;
    padding: 10px;
    transition: 160ms ease;
}

.calendar-event:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(17, 17, 17, 0.07);
}

.calendar-event-client_call,
.calendar-event-post_survey_call {
    border-left-color: #5b7cbb;
}

.calendar-event-access_collection {
    border-left-color: #9a6700;
}

.calendar-event-meeting {
    border-left-color: #7a5aa6;
}

.calendar-event-admin {
    border-left-color: #7a7c78;
}

.calendar-event-status-cancelled {
    opacity: 0.55;
    text-decoration: line-through;
}

.calendar-event-status-completed {
    border-left-color: var(--success);
    background: var(--success-pale);
}

.calendar-event-time {
    margin-bottom: 6px;
    color: var(--gold-dark);
    font-size: 9px;
    font-weight: 850;
}

.calendar-event h3 {
    margin: 0;
    color: var(--black);
    font-size: 11px;
    line-height: 1.35;
}

.calendar-event p {
    margin: 6px 0 0;
    color: var(--muted);
    font-size: 9px;
}

.calendar-event > span {
    display: block;
    margin-top: 5px;
    color: #8c8d87;
    font-size: 8px;
    line-height: 1.4;
}

.calendar-day-empty {
    display: grid;
    min-height: 90px;
    place-items: center;
    color: #a2a39e;
    font-size: 9px;
}

.calendar-agenda-panel {
    margin-top: 20px;
}

.appointment-agenda-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.appointment-agenda-row {
    display: flex;
    align-items: center;
    gap: 13px;
    border: 1px solid var(--line);
    border-radius: 5px;
    padding: 13px;
    transition: 160ms ease;
}

.appointment-agenda-row:hover {
    border-color: #cab585;
    transform: translateY(-1px);
}

.appointment-agenda-main {
    min-width: 0;
    flex: 1;
}

.appointment-agenda-main h3 {
    margin: 0;
    font-size: 13px;
}

.appointment-agenda-main p {
    margin: 5px 0;
    color: var(--muted);
    font-size: 10px;
}

/* Custom appointment editor */

.appointment-form-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(290px, 0.65fr);
    gap: 20px;
    align-items: start;
}

.appointment-editor input,
.appointment-editor select,
.appointment-editor textarea {
    width: 100%;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    background: #ffffff;
    color: var(--text);
    font: inherit;
    font-size: 13px;
    padding: 10px 11px;
}

.appointment-editor input,
.appointment-editor select {
    min-height: 42px;
}

.appointment-editor textarea {
    resize: vertical;
}

.appointment-editor input:focus,
.appointment-editor select:focus,
.appointment-editor textarea:focus {
    border-color: var(--gold);
    outline: 2px solid rgba(220, 174, 87, 0.18);
}

.form-grid-two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.form-section {
    border-bottom: 1px solid var(--line);
    padding: 0 0 24px;
    margin-bottom: 24px;
}

.form-section:last-of-type {
    margin-bottom: 0;
}

.form-section-heading {
    margin-bottom: 16px;
}

.form-section-heading h2 {
    margin: 0;
    font-size: 18px;
}

.checkbox-field {
    flex-direction: row;
    align-items: center;
}

.checkbox-field input {
    width: auto;
    min-height: auto;
}

.checkbox-field > span {
    color: var(--text);
    font-size: 12px;
    text-transform: none;
    letter-spacing: 0;
}

.appointment-form-actions {
    gap: 10px;
}

.appointment-form-sidebar {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.guidance-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.guidance-list p {
    margin: 0;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.6;
}

@media (max-width: 1150px) {
    .calendar-toolbar {
        grid-template-columns: 1fr;
    }

    .calendar-range {
        text-align: left;
    }

    .calendar-filters {
        justify-content: flex-start;
    }

    .appointment-form-layout {
        grid-template-columns: 1fr;
    }

    .appointment-form-sidebar {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .appointment-agenda-list,
    .appointment-form-sidebar,
    .form-grid-two {
        grid-template-columns: 1fr;
    }

    .calendar-navigation,
    .calendar-filters {
        align-items: stretch;
        flex-direction: column;
    }

    .calendar-filters .select-field {
        width: 100%;
    }
}


/* Appointment date and time selectors */

.form-section-help {
    margin: 7px 0 0;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.5;
}

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

.appointment-time-group {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(130px, 0.55fr);
    gap: 12px;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #fafaf8;
    padding: 15px;
}

.appointment-time-group h3 {
    grid-column: span 2;
    margin: 0 0 2px;
    color: var(--black);
    font-size: 13px;
}

.appointment-clock-field select {
    max-height: 42px;
}

.appointment-all-day-field {
    grid-column: span 2;
    align-self: center;
    margin-top: 1px;
}

.all-day-help {
    grid-column: span 2;
    margin: -7px 0 0 27px;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.45;
}

.appointment-time-disabled {
    opacity: 0.48;
}

@media (max-width: 760px) {
    .appointment-time-grid,
    .appointment-time-group {
        grid-template-columns: 1fr;
    }

    .appointment-time-group h3,
    .appointment-all-day-field,
    .all-day-help {
        grid-column: auto;
    }

    .all-day-help {
        margin-left: 0;
    }
}

/* Custom tasks workspace */

.task-stat-link {
    color: inherit;
    transition: 160ms ease;
}

.task-stat-link:hover,
.task-stat-selected {
    border-color: #cfb16f;
    transform: translateY(-1px);
}

.task-workspace {
    padding: 0;
    overflow: hidden;
}

.task-toolbar {
    display: flex;
    flex-direction: column;
    gap: 16px;
    border-bottom: 1px solid var(--line);
    padding: 18px 20px;
}

.task-view-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.task-view-tab {
    border-radius: 4px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
    padding: 9px 13px;
}

.task-view-tab:hover {
    background: #f3f2ed;
    color: var(--text);
}

.task-view-active {
    background: var(--black);
    color: var(--gold);
}

.task-filters {
    display: grid;
    grid-template-columns: minmax(280px, 1fr) minmax(170px, 0.45fr) minmax(150px, 0.35fr) minmax(170px, 0.4fr) auto auto;
    gap: 10px;
    align-items: center;
}

.task-filters .search-field,
.task-filters .select-field {
    width: 100%;
    min-width: 0;
}

.task-filter-notice {
    border-bottom: 1px solid var(--line);
    background: var(--gold-pale);
    color: var(--muted);
    font-size: 11px;
    padding: 11px 20px;
}

.task-filter-notice a {
    color: var(--gold-dark);
    font-weight: 800;
}

.task-content {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.task-group {
    padding: 20px;
    border-bottom: 1px solid var(--line);
}

.task-group:last-child {
    border-bottom: 0;
}

.task-group-alert {
    background: #fffdfd;
}

.task-group-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 14px;
}

.task-group-heading h2 {
    margin: 0;
    color: var(--black);
    font-size: 19px;
}

.task-group-heading > span {
    display: grid;
    min-width: 27px;
    height: 27px;
    place-items: center;
    border-radius: 999px;
    background: var(--gold-pale);
    color: var(--gold-dark);
    font-size: 10px;
    font-weight: 850;
}

.task-card-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.task-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: var(--surface);
    padding: 15px;
    transition: 160ms ease;
}

.task-card:hover {
    border-color: #cab585;
    transform: translateY(-1px);
}

.task-card-overdue {
    border-left: 3px solid var(--danger);
    background: #fffafa;
}

.task-card-main {
    min-width: 0;
    flex: 1;
}

.task-card h3 {
    margin: 0;
    color: var(--black);
    font-size: 14px;
}

.task-related-record {
    margin: 5px 0 0;
    color: var(--muted);
    font-size: 10px;
}

.task-related-record a {
    color: var(--gold-dark);
    font-weight: 700;
}

.task-card-badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 5px;
}

.task-details {
    margin: 11px 0 0;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.55;
}

.task-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 7px 17px;
    margin-top: 12px;
    color: #83847f;
    font-size: 10px;
}

.task-due-overdue {
    color: var(--danger);
    font-weight: 800;
}

.task-card-actions {
    display: flex;
    flex: 0 0 auto;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 7px;
}

.task-card-actions form {
    margin: 0;
}

.task-form-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(290px, 0.65fr);
    gap: 20px;
    align-items: start;
}

.task-editor input,
.task-editor select,
.task-editor textarea {
    width: 100%;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    background: #ffffff;
    color: var(--text);
    font: inherit;
    font-size: 13px;
    padding: 10px 11px;
}

.task-editor input,
.task-editor select {
    min-height: 42px;
}

.task-editor textarea {
    resize: vertical;
}

.task-editor input:focus,
.task-editor select:focus,
.task-editor textarea:focus {
    border-color: var(--gold);
    outline: 2px solid rgba(220, 174, 87, 0.18);
}

.task-due-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(160px, 0.45fr);
    gap: 12px;
    max-width: 650px;
}

.task-form-actions {
    gap: 10px;
}

.task-form-sidebar {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

@media (max-width: 1180px) {
    .task-filters {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .task-filters .search-field {
        grid-column: span 2;
    }

    .task-form-layout {
        grid-template-columns: 1fr;
    }

    .task-form-sidebar {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .task-filters,
    .task-due-grid,
    .task-form-sidebar {
        grid-template-columns: 1fr;
    }

    .task-filters .search-field {
        grid-column: auto;
    }

    .task-card {
        align-items: stretch;
        flex-direction: column;
    }

    .task-card-actions {
        justify-content: flex-start;
    }
}

/* Clients and properties */
.record-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;padding:20px}.record-grid-empty{grid-column:1/-1}.record-card{display:flex;min-width:0;flex-direction:column;border:1px solid var(--line);border-radius:6px;background:var(--surface);box-shadow:0 8px 22px rgba(17,17,17,.04);padding:18px}.record-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.record-overline{margin:0 0 6px;color:var(--gold-dark);font-size:9px;font-weight:850;text-transform:uppercase;letter-spacing:.08em}.record-card h2,.record-card h3{margin:0;color:var(--black)}.record-card h2{font-size:17px;line-height:1.35}.record-card h3{font-size:15px}.record-card h2 a:hover{color:var(--gold-dark)}.record-card-details{display:flex;flex-direction:column;gap:9px;margin:17px 0;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.record-card-details div{display:grid;grid-template-columns:92px minmax(0,1fr);gap:9px}.record-card-details dt{color:var(--muted);font-size:10px;font-weight:750}.record-card-details dd{min-width:0;margin:0;font-size:11px;overflow-wrap:anywhere}.record-card-details a{color:var(--gold-dark);font-weight:700}.record-count-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:auto;color:var(--muted);font-size:10px}.record-count-row strong{color:var(--black)}.record-card-actions{display:flex;gap:8px;margin-top:17px}
.record-form-page{display:flex;flex-direction:column;gap:20px}.record-form-page input,.record-form-page select,.record-form-page textarea{width:100%;border:1px solid #d9d9d4;border-radius:4px;background:#fff;color:var(--text);font:inherit;font-size:13px;padding:10px 11px}.record-form-page input,.record-form-page select{min-height:42px}.record-form-page textarea{resize:vertical}.record-form-page input:focus,.record-form-page select:focus,.record-form-page textarea:focus{border-color:var(--gold);outline:2px solid rgba(220,174,87,.18)}.form-grid-two{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid-four{grid-template-columns:repeat(4,minmax(0,1fr))}.form-actions-page{gap:10px;margin-top:0;padding:2px 0 25px}.checkbox-card{display:flex;min-height:44px;align-items:center;gap:10px;border:1px solid var(--line);border-radius:5px;background:#fafaf8;padding:11px 13px;cursor:pointer}.checkbox-card input{width:auto;min-height:auto;margin:0}.checkbox-card span{font-size:11px;font-weight:750}.checkbox-card-spaced{margin-top:17px}.checkbox-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:17px}.checkbox-grid-two{grid-template-columns:repeat(2,minmax(0,1fr))}.form-help{margin:10px 0 17px;color:var(--muted);font-size:11px;line-height:1.5}
.record-detail-header{align-items:center}.record-detail-layout{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(300px,.65fr);gap:20px;align-items:start}.record-detail-main,.record-detail-sidebar{display:flex;min-width:0;flex-direction:column;gap:20px}.contact-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}.contact-card{border:1px solid var(--line);border-radius:5px;background:#fafaf8;padding:15px}.communication-flags{display:flex;flex-wrap:wrap;gap:4px}.communication-flags span{border-radius:999px;background:var(--gold-pale);color:var(--gold-dark);padding:3px 6px;font-size:8px;font-weight:800}.compact-record-list{display:flex;flex-direction:column;gap:8px}.compact-record-row{display:flex;align-items:center;justify-content:space-between;gap:18px;border:1px solid var(--line);border-radius:5px;padding:13px;transition:160ms ease}.compact-record-row:hover{border-color:#cab585;transform:translateY(-1px)}.compact-record-row>div{display:flex;min-width:0;flex-direction:column;gap:4px}.compact-record-row strong{color:var(--black);font-size:12px}.compact-record-row span{color:var(--muted);font-size:10px}.compact-record-row-right{flex:0 0 auto;align-items:flex-end;text-align:right}.property-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.property-mini-card{display:flex;min-height:88px;flex-direction:column;justify-content:center;gap:7px;border:1px solid var(--line);border-radius:5px;background:#fafaf8;padding:14px}.property-mini-card:hover{border-color:#cab585}.property-mini-card strong{font-size:12px;line-height:1.45}.property-mini-card span{color:var(--muted);font-size:10px}.record-notes{margin-top:18px;border-top:1px solid var(--line);padding-top:14px}.record-notes strong{font-size:11px}.record-notes p{margin:6px 0 0;color:var(--muted);font-size:11px;line-height:1.55}.mini-link-list{display:flex;flex-direction:column;gap:8px}.mini-link-list a{display:flex;flex-direction:column;gap:4px;border:1px solid var(--line);border-radius:5px;padding:11px}.mini-link-list a:hover{border-color:#cab585}.mini-link-list strong{font-size:11px}.mini-link-list span{color:var(--muted);font-size:9px}.record-link,.inline-record-link{color:var(--gold-dark);font-weight:700}.record-link:hover,.inline-record-link:hover{text-decoration:underline}
@media(max-width:1180px){.record-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.record-detail-layout{grid-template-columns:1fr}.record-detail-sidebar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.record-detail-sidebar .panel:last-child{grid-column:span 2}}@media(max-width:900px){.form-grid-four{grid-template-columns:repeat(2,minmax(0,1fr))}.checkbox-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:700px){.record-card-grid,.contact-card-grid,.property-mini-grid,.record-detail-sidebar,.form-grid-two,.form-grid-four,.checkbox-grid,.checkbox-grid-two{grid-template-columns:1fr}.record-detail-sidebar .panel:last-child{grid-column:auto}.compact-record-row{align-items:flex-start;flex-direction:column}.compact-record-row-right{align-items:flex-start;text-align:left}}

/* Custom enquiry record */

.panel-header-actions {
    display: flex;
    align-items: center;
    gap: 14px;
}

.form-grid-spaced {
    margin-top: 17px;
}

.enquiry-quick-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
}

.enquiry-quick-actions form {
    margin: 0;
}

.conversion-panel {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    margin-top: 17px;
    border-top: 1px solid var(--line);
    padding-top: 17px;
}

.readiness-message {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    color: var(--muted);
    font-size: 11px;
}

.readiness-message strong {
    color: var(--black);
}

.quote-checkbox {
    align-self: end;
    margin-bottom: 1px;
}

@media (max-width: 700px) {
    .panel-header-actions {
        align-items: flex-start;
        flex-direction: column;
        gap: 7px;
    }

    .enquiry-quick-actions .button {
        width: 100%;
    }

    .enquiry-quick-actions form {
        width: 100%;
    }

    .conversion-panel {
        align-items: stretch;
        flex-direction: column;
    }

    .readiness-message {
        align-items: flex-start;
    }
}

.audit-help {
    margin: 0 0 14px;
}


/* Structured enquiry call logging */

.call-log-dialog {
    width: min(690px, calc(100vw - 32px));
    max-height: calc(100vh - 40px);
    border: 0;
    border-radius: 8px;
    background: var(--surface);
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.28);
    padding: 0;
}

.call-log-dialog::backdrop {
    background: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(2px);
}

.call-log-form {
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - 40px);
}

.dialog-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    border-bottom: 1px solid var(--line);
    padding: 22px 24px 18px;
}

.dialog-header h2 {
    margin: 3px 0 0;
    font-size: 25px;
}

.dialog-header p:last-child {
    margin: 8px 0 0;
    color: var(--muted);
    font-size: 11px;
}

.dialog-close {
    display: grid;
    width: 34px;
    height: 34px;
    flex: 0 0 auto;
    place-items: center;
    border: 1px solid var(--line);
    border-radius: 50%;
    background: #ffffff;
    color: var(--black);
    cursor: pointer;
    font-size: 22px;
    line-height: 1;
}

.dialog-body {
    overflow-y: auto;
    padding: 22px 24px;
}

.call-log-form input,
.call-log-form select,
.call-log-form textarea {
    width: 100%;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    background: #ffffff;
    color: var(--text);
    font: inherit;
    font-size: 13px;
    padding: 10px 11px;
}

.call-log-form input,
.call-log-form select {
    min-height: 42px;
}

.call-log-form textarea {
    resize: vertical;
}

.call-log-form input:focus,
.call-log-form select:focus,
.call-log-form textarea:focus {
    border-color: var(--gold);
    outline: 2px solid rgba(220, 174, 87, 0.18);
}

.dialog-help {
    margin: 17px 0 0;
}

.dialog-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    border-top: 1px solid var(--line);
    padding: 16px 24px 20px;
}

@media (max-width: 620px) {
    .call-log-dialog {
        width: calc(100vw - 18px);
    }

    .dialog-header,
    .dialog-body,
    .dialog-actions {
        padding-left: 16px;
        padding-right: 16px;
    }

    .dialog-actions .button {
        flex: 1;
    }
}


/* Enquiry follow-up and automatic ageing */

.enquiry-followup-panel {
    margin-top: 20px;
}

.followup-summary-row {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    margin-bottom: 18px;
    border-bottom: 1px solid var(--line);
    padding-bottom: 15px;
    color: var(--muted);
    font-size: 11px;
}

.followup-summary-row strong {
    color: var(--black);
    font-size: 15px;
}

.followup-count-alert,
.followup-count-alert strong {
    color: var(--danger);
}

.followup-columns {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.followup-columns > div > h3 {
    margin: 0 0 10px;
    color: var(--black);
    font-size: 12px;
}

.followup-overdue-row {
    border-left: 3px solid var(--danger);
    background: #fffafa;
}

.automatic-status-notice {
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin-bottom: 20px;
    border: 1px solid #ead5a6;
    border-left: 4px solid var(--gold);
    border-radius: 5px;
    background: var(--gold-pale);
    padding: 13px 15px;
}

.automatic-status-notice strong {
    font-size: 12px;
}

.automatic-status-notice span {
    color: var(--muted);
    font-size: 11px;
    line-height: 1.45;
}

@media (max-width: 1050px) {
    .followup-columns {
        grid-template-columns: 1fr;
    }
}


/* Integrated enquiry intake */
.mode-choice-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 11px;
    margin-bottom: 18px;
}

.mode-choice-card {
    display: flex;
    min-height: 86px;
    align-items: flex-start;
    gap: 10px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #fafaf8;
    padding: 14px;
    cursor: pointer;
    transition: 160ms ease;
}

.mode-choice-card:hover,
.mode-choice-card.is-selected {
    border-color: var(--gold);
    background: var(--gold-pale);
}

.mode-choice-card input {
    width: auto;
    min-height: auto;
    margin: 3px 0 0;
}

.mode-choice-card > span {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.mode-choice-card strong {
    color: var(--black);
    font-size: 11px;
}

.mode-choice-card small {
    color: var(--muted);
    font-size: 9px;
    line-height: 1.45;
}

.intake-mode-section {
    border-top: 1px solid var(--line);
    padding-top: 18px;
}

.intake-mode-section[hidden],
.joint-client-fields[hidden] {
    display: none !important;
}

.joint-client-fields {
    margin-top: 14px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #fafaf8;
    padding: 15px;
}

.subsection-heading {
    display: flex;
    align-items: baseline;
    gap: 9px;
    margin-bottom: 13px;
}

.subsection-heading strong {
    font-size: 12px;
}

.subsection-heading span {
    color: var(--muted);
    font-size: 9px;
}

.form-grid-five {
    grid-template-columns: 0.55fr 1fr 1fr 1.35fr 1fr;
}

.enquiry-intake-form .errorlist {
    margin: 6px 0 0;
    padding: 0;
    color: #b42318;
    font-size: 10px;
    font-weight: 700;
    list-style: none;
}

@media (max-width: 1050px) {
    .mode-choice-grid {
        grid-template-columns: 1fr;
    }

    .form-grid-five {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .form-grid-five {
        grid-template-columns: 1fr;
    }
}

/* Enquiry communications */

.communication-template-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.communication-help {
    margin: 13px 0 16px;
}

.communication-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.communication-card {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #fafaf8;
    padding: 15px;
}

.communication-card-main {
    min-width: 0;
    flex: 1;
}

.communication-card h3 {
    margin: 0;
    color: var(--black);
    font-size: 13px;
    line-height: 1.4;
}

.communication-recipient,
.communication-meta {
    margin: 8px 0 0;
    color: var(--muted);
    font-size: 9px;
    line-height: 1.5;
}

.communication-preview {
    margin: 12px 0 0;
    color: var(--text);
    font-size: 10px;
    line-height: 1.55;
}

.communication-card-actions {
    display: flex;
    flex: 0 0 auto;
    align-items: center;
    gap: 7px;
}

.communication-card-actions form {
    margin: 0;
}

.communication-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(300px, 0.65fr);
    gap: 20px;
    align-items: start;
}

.communication-main,
.communication-sidebar {
    min-width: 0;
}

.communication-copy-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}

.communication-form-page textarea#id_body {
    min-height: 430px;
    font-family: inherit;
    line-height: 1.6;
}

.copy-status {
    min-height: 18px;
    margin: 10px 0 0;
    color: var(--gold-dark);
    font-weight: 700;
}

.communication-lock-notice {
    margin-bottom: 20px;
}

.form-grid-one {
    grid-template-columns: 1fr;
}

@media (max-width: 1050px) {
    .communication-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .communication-card {
        flex-direction: column;
    }

    .communication-card-actions {
        width: 100%;
        flex-wrap: wrap;
    }

    .communication-copy-actions {
        width: 100%;
    }
}


/* Email template settings */

.placeholder-guide-panel {
    margin-bottom: 20px;
}

.placeholder-chip-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 9px;
}

.placeholder-chip {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 5px;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #fafaf8;
    padding: 10px 12px;
}

.placeholder-chip code,
.placeholder-insert-button code {
    color: var(--gold-dark);
    font-family: Consolas, monospace;
    font-size: 10px;
    font-weight: 750;
}

.placeholder-chip span,
.placeholder-insert-button span {
    color: var(--muted);
    font-size: 9px;
    line-height: 1.4;
}

.email-template-group {
    margin-bottom: 20px;
}

.panel-description {
    margin: 5px 0 0;
    color: var(--muted);
    font-size: 11px;
}

.email-template-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 13px;
}

.email-template-card {
    display: flex;
    min-width: 0;
    flex-direction: column;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #ffffff;
    padding: 16px;
}

.email-template-inactive {
    opacity: 0.66;
}

.email-template-card h3 {
    margin: 0;
    font-size: 15px;
}

.template-badge-stack {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 5px;
}

.template-subject-preview {
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin: 14px 0 10px;
    border-top: 1px solid var(--line);
    padding-top: 12px;
}

.template-subject-preview span {
    color: var(--muted);
    font-size: 9px;
    font-weight: 750;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.template-subject-preview strong {
    font-size: 11px;
    line-height: 1.45;
}

.template-card-actions {
    align-items: center;
    margin-top: auto;
}

.template-card-actions form {
    margin: 0;
}

.email-template-editor-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(280px, 0.55fr);
    gap: 20px;
    align-items: start;
}

.email-template-editor-main,
.email-template-editor-sidebar {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 20px;
}

.sticky-template-tools {
    position: sticky;
    top: 20px;
}

.placeholder-button-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-height: 620px;
    overflow-y: auto;
}

.placeholder-insert-button {
    display: flex;
    width: 100%;
    flex-direction: column;
    align-items: flex-start;
    gap: 3px;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: #fafaf8;
    padding: 9px 10px;
    text-align: left;
    cursor: pointer;
}

.placeholder-insert-button:hover {
    border-color: var(--gold);
    background: var(--gold-pale);
}

.rendered-email-preview {
    margin-top: 16px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #fafaf8;
    overflow: hidden;
}

.rendered-email-preview > div {
    display: flex;
    flex-direction: column;
    gap: 5px;
    border-bottom: 1px solid var(--line);
    padding: 13px 15px;
}

.rendered-email-preview span {
    color: var(--muted);
    font-size: 9px;
    font-weight: 750;
    text-transform: uppercase;
}

.rendered-email-preview strong {
    font-size: 12px;
}

.rendered-email-preview pre {
    margin: 0;
    padding: 16px;
    white-space: pre-wrap;
    font-family: inherit;
    font-size: 11px;
    line-height: 1.65;
}

.template-form-actions {
    flex-wrap: wrap;
}

.communication-template-picker {
    margin-bottom: 20px;
}

.template-picker-form {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) auto;
    gap: 10px;
    align-items: end;
}

.template-picker-form select {
    width: 100%;
    min-height: 42px;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    background: #ffffff;
    padding: 10px 11px;
}

@media (max-width: 1000px) {
    .email-template-editor-layout {
        grid-template-columns: 1fr;
    }

    .sticky-template-tools {
        position: static;
    }

    .placeholder-chip-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .email-template-card-grid,
    .placeholder-chip-grid,
    .template-picker-form {
        grid-template-columns: 1fr;
    }
}


/* Referrer workspace */

.token-value {
    font-family: Consolas, "Courier New", monospace;
    font-size: 9px;
    overflow-wrap: anywhere;
}

.referrer-portal-card {
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #fafaf8;
    padding: 14px;
}


/* Secure external referral links and review */

.referral-link-box {
    margin-top: 15px;
    border-top: 1px solid var(--line);
    padding-top: 13px;
}

.referral-link-box label {
    display: block;
    margin-bottom: 7px;
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.referral-link-controls {
    display: flex;
    gap: 7px;
}

.referral-link-controls input {
    min-width: 0;
    flex: 1;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: #ffffff;
    padding: 8px;
    font-size: 9px;
}

.external-referral-page {
    min-height: 100vh;
    background:
        radial-gradient(circle at top right, rgba(220, 174, 87, 0.12), transparent 30%),
        #f3f3f0;
}

.external-referral-shell {
    width: min(980px, calc(100% - 28px));
    margin: 0 auto;
    padding: 30px 0 45px;
}

.external-referral-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 30px;
}

.external-referral-header > div:last-child {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.external-referral-header strong {
    font-size: 15px;
}

.external-referral-header span {
    color: var(--muted);
    font-size: 8px;
    font-weight: 750;
    text-transform: uppercase;
    letter-spacing: 0.13em;
}

.external-brand-logo {
    display: block;
    width: 68px;
    height: auto;
    flex: 0 0 auto;
    object-fit: contain;
}

.external-referral-hero {
    margin-bottom: 24px;
}

.external-referral-hero h1 {
    max-width: 760px;
    margin: 6px 0 10px;
    font-size: clamp(32px, 5vw, 54px);
    line-height: 1.02;
}

.external-referral-hero > p:last-child {
    max-width: 760px;
    margin: 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.65;
}

.external-referral-form {
    display: flex;
    flex-direction: column;
    gap: 17px;
}

.external-form-section {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: var(--shadow);
    padding: 24px;
}

.external-section-heading {
    display: flex;
    align-items: flex-start;
    gap: 13px;
    margin-bottom: 20px;
    padding-bottom: 17px;
    border-bottom: 1px solid var(--line);
}

.external-section-heading > span {
    display: grid;
    width: 28px;
    height: 28px;
    flex: 0 0 28px;
    place-items: center;
    border-radius: 50%;
    background: var(--gold);
    color: #111111;
    font-size: 12px;
    font-weight: 900;
}

.external-section-heading h2 {
    margin: 0 0 4px;
    font-size: 20px;
}

.external-section-heading p {
    margin: 0;
    color: var(--muted);
    font-size: 11px;
}

.external-referral-form input,
.external-referral-form select,
.external-referral-form textarea {
    width: 100%;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    background: #ffffff;
    color: var(--text);
    font: inherit;
    font-size: 13px;
    padding: 11px;
}

.external-referral-form input,
.external-referral-form select {
    min-height: 44px;
}

.external-referral-form textarea {
    resize: vertical;
}

.external-referral-form input:focus,
.external-referral-form select:focus,
.external-referral-form textarea:focus {
    border-color: var(--gold);
    outline: 2px solid rgba(220, 174, 87, 0.18);
}

.external-consent-section p {
    margin: 10px 0 0;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.55;
}

.external-form-actions {
    display: flex;
    justify-content: flex-end;
}

.external-form-actions .button {
    min-width: 230px;
}

.external-referral-footer {
    margin-top: 25px;
    color: var(--muted);
    font-size: 9px;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.external-success-shell {
    max-width: 720px;
}

.external-success-card {
    border: 1px solid var(--line);
    border-radius: 9px;
    background: #ffffff;
    box-shadow: var(--shadow);
    padding: 50px 34px;
    text-align: center;
}

.external-success-icon {
    display: grid;
    width: 58px;
    height: 58px;
    margin: 0 auto 18px;
    place-items: center;
    border-radius: 50%;
    background: #e7f7ec;
    color: #127a3d;
    font-size: 28px;
    font-weight: 900;
}

.external-success-card h1 {
    margin: 5px 0 12px;
    font-size: 38px;
}

.external-success-card > p:not(.eyebrow) {
    max-width: 520px;
    margin: 0 auto 20px;
    color: var(--muted);
    line-height: 1.6;
}

.external-reference {
    display: inline-flex;
    gap: 8px;
    margin-bottom: 23px;
    border-radius: 999px;
    background: var(--gold-pale);
    padding: 8px 13px;
    font-size: 11px;
}

.external-review-panel {
    margin-bottom: 20px;
    border: 1px solid var(--line);
    border-left: 5px solid var(--gold);
    border-radius: 7px;
    background: #ffffff;
    box-shadow: var(--shadow);
    padding: 22px;
}

.external-review-pending {
    border-left-color: var(--danger);
}

.external-review-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--line);
}

.external-review-heading h2 {
    margin: 3px 0 6px;
}

.external-review-heading p {
    margin: 0;
    color: var(--muted);
    font-size: 11px;
}

.external-submission-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
    padding: 18px 0;
}

.external-submission-grid h3 {
    margin: 0 0 12px;
    font-size: 13px;
}

.external-submission-grid > div > p {
    color: var(--text);
    font-size: 11px;
    line-height: 1.55;
}

.external-submission-notes {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 15px;
    margin-bottom: 16px;
}

.external-submission-notes > div {
    border-radius: 5px;
    background: #fafaf8;
    padding: 13px;
}

.external-submission-notes strong {
    font-size: 10px;
}

.external-submission-notes p {
    margin: 6px 0 0;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.55;
}

.duplicate-warning {
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin-bottom: 16px;
    border: 1px solid #ecd9a4;
    border-radius: 5px;
    background: #fff9e8;
    padding: 13px;
    font-size: 10px;
}

.external-review-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 16px;
    align-items: end;
    padding-top: 16px;
    border-top: 1px solid var(--line);
}

.external-review-form textarea {
    width: 100%;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    padding: 10px;
    font: inherit;
    font-size: 12px;
    resize: vertical;
}

.external-review-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

.button-danger-outline {
    border: 1px solid var(--danger);
    background: #ffffff;
    color: var(--danger);
}

.external-referral-alert-panel {
    margin-bottom: 20px;
    border-left: 5px solid var(--danger);
}

.external-referral-alert-row {
    border-color: #ead0ca;
    background: #fffaf9;
}

@media (max-width: 760px) {
    .referral-link-controls,
    .external-review-heading,
    .external-review-form {
        align-items: stretch;
        flex-direction: column;
    }

    .referral-link-controls {
        display: flex;
    }

    .external-submission-grid,
    .external-submission-notes,
    .external-review-form {
        grid-template-columns: 1fr;
    }

    .external-review-actions,
    .external-form-actions {
        flex-direction: column;
    }

    .external-review-actions .button,
    .external-form-actions .button {
        width: 100%;
    }

    .external-form-section {
        padding: 18px;
    }
}

/* Referral advancement: duplicate resolution, tracking and payments */

.resolution-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: 18px;
}

.resolution-card {
    min-width: 0;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #fafaf8;
    padding: 16px;
}

.resolution-card h3 {
    margin: 0 0 12px;
    font-size: 14px;
    line-height: 1.4;
}

.radio-choice-list ul {
    display: flex;
    flex-direction: column;
    gap: 7px;
    margin: 0 0 14px;
    padding: 0;
    list-style: none;
}

.radio-choice-list label {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 10px;
    line-height: 1.45;
}

.radio-choice-list input {
    width: auto;
    min-height: auto;
    margin-top: 2px;
}

.external-review-note {
    margin-top: 16px;
}

.resolution-summary {
    margin-top: 14px;
    border: 1px solid #cfe4d5;
    border-radius: 5px;
    background: #f3fbf5;
    padding: 13px;
}

.resolution-summary strong {
    font-size: 11px;
}

.resolution-summary p {
    margin: 5px 0 0;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.5;
}

.external-header-action {
    margin-left: auto;
}

.external-success-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
}

.external-tracking-shell {
    max-width: 980px;
}

.external-tracking-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.external-tracking-card {
    border: 1px solid var(--line);
    border-radius: 7px;
    background: #ffffff;
    box-shadow: 0 14px 35px rgba(17, 17, 17, 0.06);
    padding: 20px;
}

.external-tracking-card-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
}

.external-tracking-card h2 {
    margin: 0 0 7px;
    font-size: 20px;
}

.external-tracking-card p {
    margin: 0;
    color: var(--muted);
    font-size: 12px;
}

.public-progress {
    flex: 0 0 auto;
    border-radius: 999px;
    background: var(--gold-pale);
    color: var(--gold-dark);
    padding: 7px 10px;
    font-size: 9px;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.public-progress-completed {
    background: #e6f7eb;
    color: #16723a;
}

.public-progress-not_proceeding {
    background: #fdeaea;
    color: #a82620;
}

.external-tracking-meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin: 17px 0 0;
    border-top: 1px solid var(--line);
    padding-top: 14px;
}

.external-tracking-meta div {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.external-tracking-meta dt {
    color: var(--muted);
    font-size: 9px;
    font-weight: 750;
}

.external-tracking-meta dd {
    margin: 0;
    font-size: 11px;
}

.external-empty-card {
    max-width: none;
}

.referral-tracking-box {
    margin-top: 8px;
}

.commission-summary-grid,
.commission-summary-card {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.commission-summary-grid article,
.commission-summary-card > div {
    display: flex;
    min-height: 75px;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #fafaf8;
    padding: 13px;
}

.commission-summary-grid span,
.commission-summary-card span {
    color: var(--muted);
    font-size: 9px;
    font-weight: 750;
}

.commission-summary-grid strong,
.commission-summary-card strong {
    color: var(--black);
    font-size: 14px;
    line-height: 1.35;
}

.commission-list-spaced {
    margin-top: 14px;
}

.payment-report-filters {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
    align-items: end;
}

.payment-filter-actions {
    display: flex;
    gap: 7px;
}

.payment-report-heading {
    padding: 20px;
}

.payment-table td {
    vertical-align: top;
}

.payment-date {
    display: block;
    margin-top: 4px;
    color: var(--muted);
    font-size: 9px;
}

.payment-action-form {
    display: flex;
    min-width: 180px;
    flex-direction: column;
    gap: 6px;
}

.payment-action-form input {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 4px;
    padding: 7px 8px;
    font: inherit;
    font-size: 10px;
}

@media (max-width: 1100px) {
    .resolution-grid,
    .payment-report-filters {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .commission-summary-grid,
    .commission-summary-card {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .resolution-grid,
    .payment-report-filters,
    .commission-summary-grid,
    .commission-summary-card,
    .external-tracking-meta {
        grid-template-columns: 1fr;
    }

    .external-referral-header,
    .external-tracking-card-top {
        align-items: flex-start;
        flex-direction: column;
    }

    .external-header-action {
        margin-left: 0;
    }
}

/* Referral activity report layout refinement */

.referral-activity-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 0 20px 20px;
}

.referral-activity-card {
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #ffffff;
    box-shadow: 0 6px 18px rgba(17, 17, 17, 0.035);
    padding: 16px;
}

.referral-activity-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 13px;
    border-bottom: 1px solid var(--line);
}

.referral-activity-card-header h3 {
    margin: 0;
    font-size: 15px;
}

.referral-activity-grid {
    display: grid;
    grid-template-columns: 1.15fr 1.55fr 1fr 0.7fr 0.8fr;
    gap: 14px;
    padding-top: 14px;
}

.referral-activity-field {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 5px;
}

.referral-activity-field > span {
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.referral-activity-field strong,
.referral-activity-field a {
    font-size: 11px;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.referral-activity-field small {
    color: var(--muted);
    font-size: 9px;
}

.referral-activity-empty {
    margin: 0;
}

@media (max-width: 1180px) {
    .referral-activity-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .referral-activity-field-wide {
        grid-column: span 1;
    }
}

@media (max-width: 760px) {
    .referral-activity-list {
        padding: 0 14px 14px;
    }

    .referral-activity-card-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .referral-activity-grid {
        grid-template-columns: 1fr;
    }
}

/* Referral commission statement layout refinement */

.commission-statement-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 0 20px 20px;
}

.commission-statement-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 230px;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #ffffff;
    box-shadow: 0 6px 18px rgba(17, 17, 17, 0.035);
}

.commission-statement-main {
    min-width: 0;
    padding: 16px;
}

.commission-statement-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 13px;
    border-bottom: 1px solid var(--line);
}

.commission-statement-header h3 {
    margin: 0;
    font-size: 15px;
}

.commission-status-block {
    display: flex;
    flex: 0 0 auto;
    flex-direction: column;
    align-items: flex-end;
    gap: 5px;
}

.commission-status-block small {
    color: var(--muted);
    font-size: 9px;
}

.commission-statement-grid {
    display: grid;
    grid-template-columns: 1.15fr 1.45fr 1fr 0.7fr 0.55fr 0.75fr;
    gap: 14px;
    padding-top: 14px;
}

.commission-statement-field {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 5px;
}

.commission-statement-field > span {
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.commission-statement-field strong,
.commission-statement-field a {
    font-size: 11px;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.commission-amount-field strong {
    color: var(--gold-dark);
    font-size: 15px;
}

.commission-action-panel {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 12px;
    border-left: 1px solid var(--line);
    background: #fafaf8;
    padding: 16px;
}

.commission-payment-summary {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.commission-payment-summary strong {
    font-size: 11px;
}

.commission-payment-summary span {
    color: var(--muted);
    font-size: 9px;
    overflow-wrap: anywhere;
}

.payment-action-form-stacked {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.payment-action-form-stacked .form-field {
    gap: 5px;
}

.payment-action-form-stacked .form-field > span {
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.payment-action-form-stacked input {
    width: 100%;
    min-height: 38px;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    background: #ffffff;
    padding: 9px 10px;
    font: inherit;
    font-size: 11px;
}

.commission-statement-empty {
    margin: 0;
}

@media (max-width: 1180px) {
    .commission-statement-card {
        grid-template-columns: 1fr;
    }

    .commission-action-panel {
        border-top: 1px solid var(--line);
        border-left: 0;
    }

    .commission-statement-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .commission-statement-list {
        padding: 0 14px 14px;
    }

    .commission-statement-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .commission-status-block {
        align-items: flex-start;
    }

    .commission-statement-grid {
        grid-template-columns: 1fr;
    }
}

/* Staff access and authenticated referrer portal */

.button-danger-outline {
    border: 1px solid #c81e1e;
    background: transparent;
    color: #a51414;
}

.portal-reset-form {
    margin-top: 16px;
}

.portal-body {
    min-height: 100vh;
    margin: 0;
    background: #f4f4f1;
    color: var(--text);
}

.portal-header {
    display: flex;
    width: min(1180px, calc(100% - 40px));
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    margin: 0 auto;
    padding: 20px 0;
}

.portal-brand {
    display: flex;
    align-items: center;
    gap: 12px;
}

.portal-logo {
    display: block;
    width: 68px;
    height: auto;
    flex: 0 0 auto;
    object-fit: contain;
}

.portal-brand > span:last-child {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.portal-brand strong {
    color: var(--black);
    font-size: 14px;
}

.portal-brand small {
    color: var(--gold-dark);
    font-size: 7.5px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.14em;
}

.portal-nav {
    display: flex;
    align-items: center;
    gap: 18px;
}

.portal-nav a,
.portal-nav button {
    border: 0;
    background: transparent;
    color: var(--black);
    font: inherit;
    font-size: 11px;
    font-weight: 750;
    cursor: pointer;
}

.portal-nav form {
    margin: 0;
}

.portal-main {
    width: min(1180px, calc(100% - 40px));
    min-height: calc(100vh - 150px);
    margin: 0 auto;
    padding-bottom: 38px;
}

.portal-footer {
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
    padding: 0 0 24px;
    color: var(--muted);
    font-size: 8px;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.portal-auth-card {
    width: min(470px, 100%);
    margin: 70px auto;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 18px 45px rgba(17, 17, 17, 0.08);
    padding: 34px;
}

.portal-auth-card h1 {
    margin: 5px 0 10px;
    font-size: 32px;
}

.portal-auth-card > p:not(.eyebrow):not(.portal-help) {
    color: var(--muted);
    line-height: 1.6;
}

.portal-auth-form {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-top: 24px;
}

.portal-auth-form input {
    width: 100%;
    min-height: 44px;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    padding: 10px 11px;
    font: inherit;
}

.portal-help {
    margin: 18px 0 0;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.5;
}

.portal-page-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    margin: 28px 0 24px;
}

.portal-page-header h1 {
    margin: 4px 0 6px;
    font-size: clamp(34px, 5vw, 52px);
}

.portal-page-header p:not(.eyebrow) {
    margin: 0;
    color: var(--muted);
}

.portal-panel {
    margin-bottom: 20px;
    border: 1px solid var(--line);
    border-radius: 7px;
    background: #ffffff;
    box-shadow: 0 10px 28px rgba(17, 17, 17, 0.045);
    padding: 20px;
}

.portal-panel-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
    border-bottom: 1px solid var(--line);
    padding-bottom: 14px;
}

.portal-panel-header h2 {
    margin: 0;
    font-size: 19px;
}

.portal-stats {
    margin-bottom: 20px;
}

.portal-referral-list,
.portal-payment-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.portal-referral-card,
.portal-payment-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #fafaf8;
    padding: 15px;
}

.portal-referral-card:hover {
    border-color: #cbb57f;
}

.portal-referral-card h3 {
    margin: 0 0 5px;
    font-size: 15px;
}

.portal-referral-card p:not(.record-overline) {
    margin: 0;
    color: var(--muted);
    font-size: 10px;
}

.portal-referral-meta {
    display: flex;
    flex: 0 0 auto;
    flex-direction: column;
    align-items: flex-end;
    gap: 5px;
}

.portal-referral-meta small,
.portal-payment-row span {
    color: var(--muted);
    font-size: 9px;
}

.portal-payment-row > div {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 4px;
}

.portal-payment-row > div:last-child {
    flex: 0 0 auto;
    align-items: flex-end;
}

.portal-payment-row-detailed {
    align-items: flex-start;
}

.portal-record-form {
    max-width: none;
}

.portal-back-row {
    margin-top: 20px;
}

.portal-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

.portal-detail-wide {
    grid-column: 1 / -1;
}

.portal-payment-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.portal-payment-summary-grid > div {
    display: flex;
    flex-direction: column;
    gap: 5px;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #fafaf8;
    padding: 13px;
}

.portal-payment-summary-grid span {
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
}

.portal-filter-form {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
    gap: 12px;
    align-items: end;
}

.portal-filter-form input,
.portal-filter-form select {
    width: 100%;
    min-height: 42px;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    background: #ffffff;
    padding: 9px 10px;
    font: inherit;
}

.portal-readonly-value {
    min-height: 42px;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: #fafaf8;
    padding: 11px;
    font-size: 12px;
}

.portal-readonly-value + small {
    color: var(--muted);
    font-size: 9px;
}

@media (max-width: 900px) {
    .portal-header,
    .portal-page-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .portal-nav {
        flex-wrap: wrap;
    }

    .portal-detail-grid,
    .portal-payment-summary-grid {
        grid-template-columns: 1fr;
    }

    .portal-detail-wide {
        grid-column: auto;
    }

    .portal-filter-form {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 680px) {
    .portal-header,
    .portal-main,
    .portal-footer {
        width: min(100% - 24px, 1180px);
    }

    .portal-referral-card,
    .portal-payment-row {
        align-items: flex-start;
        flex-direction: column;
    }

    .portal-referral-meta,
    .portal-payment-row > div:last-child {
        align-items: flex-start;
    }

    .portal-auth-card {
        margin: 35px auto;
        padding: 24px;
    }
}
@media (max-width: 680px) {
    .brand-logo {
        width: 66px;
        height: 38px;
    }

    .portal-logo,
    .external-brand-logo {
        width: 62px;
        height: auto;
    }
}

/* Internal CRM navigation and sidebar refinement */

.crm-body {
    overflow-x: hidden;
}

.app-shell {
    min-height: 100vh;
}

.sidebar {
    width: 268px;
    overflow: hidden;
    padding: 20px 16px 18px;
}

.sidebar-header {
    position: relative;
    flex: 0 0 auto;
}

.brand {
    gap: 11px;
    min-height: 75px;
    padding: 0 8px 19px;
}

.brand-logo {
    width: 68px;
    height: auto;
}

.brand-copy strong {
    font-size: 14px;
}

.brand-copy small {
    margin-top: 3px;
    font-size: 9px;
    letter-spacing: 0.13em;
}

.sidebar-close {
    display: none;
}

.main-nav {
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    gap: 0;
    margin: 0 -5px;
    padding: 17px 5px 18px;
    scrollbar-color: rgba(220, 174, 87, 0.5) transparent;
    scrollbar-width: thin;
}

.main-nav::-webkit-scrollbar {
    width: 5px;
}

.main-nav::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: rgba(220, 174, 87, 0.42);
}

.nav-section {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.nav-section + .nav-section {
    margin-top: 17px;
}

.nav-section-label {
    margin: 0 11px 5px;
    color: rgba(255, 255, 255, 0.38);
    font-size: 8px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.15em;
}

.nav-link {
    min-height: 38px;
    border-left-width: 2px;
    border-radius: 4px;
    padding: 9px 12px;
    font-size: 12px;
    font-weight: 650;
}

.nav-link-active {
    background: rgba(220, 174, 87, 0.13);
    box-shadow: inset 0 0 0 1px rgba(220, 174, 87, 0.04);
}

.sidebar-footer {
    flex: 0 0 auto;
    gap: 4px;
    padding: 16px 8px 0;
}

.sidebar-footer span {
    font-size: 8px;
    letter-spacing: 0.12em;
}

.sidebar-footer strong {
    font-size: 12px;
}

.sidebar-footer small {
    color: rgba(255, 255, 255, 0.48);
    font-size: 9px;
}

.sidebar-footer a {
    margin-top: 5px;
    font-size: 11px;
}

.main-content {
    margin-left: 268px;
    padding: 34px 38px 52px;
}

.mobile-topbar,
.sidebar-backdrop {
    display: none;
}

@media (max-width: 1120px) and (min-width: 901px) {
    .sidebar {
        width: 244px;
    }

    .main-content {
        margin-left: 244px;
        padding-right: 28px;
        padding-left: 28px;
    }

    .brand-logo {
        width: 62px;
    }
}

@media (max-width: 900px) {
    .mobile-topbar {
        position: fixed;
        inset: 0 0 auto 0;
        z-index: 30;
        display: flex;
        min-height: 64px;
        align-items: center;
        justify-content: space-between;
        gap: 18px;
        border-bottom: 1px solid var(--line);
        background: rgba(255, 255, 255, 0.97);
        box-shadow: 0 6px 20px rgba(17, 17, 17, 0.07);
        padding: 9px 16px;
        backdrop-filter: blur(12px);
    }

    .mobile-brand {
        display: flex;
        align-items: center;
        gap: 10px;
        color: var(--black);
        font-size: 13px;
        font-weight: 800;
    }

    .mobile-brand img {
        display: block;
        width: 58px;
        height: auto;
    }

    .mobile-nav-toggle {
        display: flex;
        width: 42px;
        height: 42px;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 5px;
        border: 1px solid #d9d9d4;
        border-radius: 5px;
        background: #ffffff;
        cursor: pointer;
    }

    .mobile-nav-toggle span {
        display: block;
        width: 18px;
        height: 2px;
        border-radius: 999px;
        background: var(--black);
        transition: 160ms ease;
    }

    .sidebar {
        position: fixed;
        inset: 0 auto 0 0;
        z-index: 40;
        display: flex;
        width: min(330px, 88vw);
        max-width: none;
        flex-direction: column;
        overflow: hidden;
        transform: translateX(-105%);
        transition: transform 200ms ease;
        padding: 18px 15px;
    }

    .sidebar-open .sidebar {
        transform: translateX(0);
    }

    .sidebar-backdrop {
        position: fixed;
        inset: 0;
        z-index: 35;
        display: block;
        visibility: hidden;
        background: rgba(0, 0, 0, 0.5);
        opacity: 0;
        transition:
            opacity 200ms ease,
            visibility 200ms ease;
    }

    .sidebar-open .sidebar-backdrop {
        visibility: visible;
        opacity: 1;
    }

    .sidebar-open {
        overflow: hidden;
    }

    .sidebar-header {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 10px;
    }

    .brand {
        flex: 1;
    }

    .sidebar-close {
        display: grid;
        width: 38px;
        height: 38px;
        flex: 0 0 auto;
        place-items: center;
        border: 1px solid rgba(255, 255, 255, 0.18);
        border-radius: 4px;
        background: transparent;
        color: #ffffff;
        font-size: 25px;
        line-height: 1;
        cursor: pointer;
    }

    .main-nav {
        flex: 1;
        flex-direction: column;
        overflow-x: hidden;
        overflow-y: auto;
        padding-top: 16px;
    }

    .nav-link {
        flex: none;
        border-bottom: 0;
        border-left: 2px solid transparent;
    }

    .nav-link-active {
        border-bottom-color: transparent;
        border-left-color: var(--gold);
    }

    .sidebar-footer {
        display: flex;
    }

    .main-content {
        margin-left: 0;
        padding: 88px 18px 42px;
    }
}

@media (max-width: 560px) {
    .mobile-topbar {
        min-height: 60px;
        padding: 8px 12px;
    }

    .mobile-brand img {
        width: 52px;
    }

    .mobile-brand span {
        font-size: 12px;
    }

    .main-content {
        padding: 80px 12px 34px;
    }

    .sidebar {
        width: min(320px, 92vw);
    }
}

/* Today dashboard balance and responsive refinement */

.dashboard-focus-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.65fr) minmax(310px, 0.85fr);
    align-items: start;
    gap: 20px;
}

.dashboard-schedule-panel,
.dashboard-action-panel {
    align-self: start;
}

.dashboard-action-stack {
    display: grid;
    align-content: start;
    gap: 20px;
}

.dashboard-schedule-panel .timeline-item {
    min-height: 0;
}

.dashboard-schedule-panel .timeline-content {
    padding-bottom: 20px;
}

.dashboard-schedule-panel .timeline-item:last-child .timeline-content {
    padding-bottom: 0;
}

.dashboard-action-panel .panel-header {
    margin-bottom: 14px;
    padding-bottom: 13px;
}

.dashboard-action-panel .list-item {
    padding: 14px;
}

.dashboard-action-panel .empty-state.compact,
.dashboard-empty-state {
    min-height: 0;
    padding: 25px 18px;
}

.dashboard-upcoming-panel {
    margin-top: 20px;
}

.dashboard-inspection-grid {
    display: grid;
    grid-template-columns: repeat(
        auto-fit,
        minmax(min(100%, 285px), 1fr)
    );
    gap: 12px;
}

.inspection-summary-card {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) auto;
    align-items: center;
    gap: 13px;
    min-width: 0;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #ffffff;
    padding: 14px;
    transition: 160ms ease;
}

.inspection-summary-card:hover {
    border-color: #cab585;
    box-shadow: 0 7px 18px rgba(17, 17, 17, 0.045);
    transform: translateY(-1px);
}

.inspection-summary-main {
    min-width: 0;
}

.inspection-summary-main h3 {
    margin: 0;
    color: var(--black);
    font-size: 13px;
    line-height: 1.4;
}

.inspection-summary-main p {
    margin: 6px 0 3px;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.45;
}

.dashboard-inspection-empty {
    grid-column: 1 / -1;
}

@media (max-width: 1180px) {
    .dashboard-focus-grid {
        grid-template-columns: minmax(0, 1.35fr) minmax(285px, 0.85fr);
    }
}

@media (max-width: 1020px) {
    .dashboard-focus-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-action-stack {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .dashboard-action-stack {
        grid-template-columns: 1fr;
    }

    .inspection-summary-card {
        grid-template-columns: 44px minmax(0, 1fr);
    }

    .inspection-summary-card > .badge {
        grid-column: 2;
        justify-self: start;
    }
}

@media (max-width: 560px) {
    .dashboard-focus-grid,
    .dashboard-action-stack {
        gap: 14px;
    }

    .dashboard-upcoming-panel {
        margin-top: 14px;
    }

    .dashboard-inspection-grid {
        grid-template-columns: 1fr;
    }

    .inspection-summary-card {
        padding: 12px;
    }

    .dashboard-schedule-panel .timeline-item {
        grid-template-columns: 48px 16px minmax(0, 1fr);
        gap: 9px;
    }

    .dashboard-schedule-panel .item-heading-row {
        flex-direction: column;
        gap: 7px;
    }
}

/* Today dashboard compact flow correction */

.dashboard-main-stack {
    display: grid;
    min-width: 0;
    align-content: start;
    gap: 20px;
}

.dashboard-main-stack .dashboard-upcoming-panel {
    margin-top: 0;
}

@media (max-width: 1020px) {
    .dashboard-main-stack {
        gap: 16px;
    }
}

@media (max-width: 560px) {
    .dashboard-main-stack {
        gap: 14px;
    }
}

/* Today follow-up and active-job refinement */

.followup-clear-state {
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 82px;
    border: 1px solid #d8e8dc;
    border-radius: 5px;
    background: #f8fcf9;
    padding: 17px 18px;
}

.followup-clear-icon {
    display: grid;
    width: 34px;
    height: 34px;
    flex: 0 0 auto;
    place-items: center;
    border-radius: 999px;
    background: var(--success-pale);
    color: var(--success);
    font-size: 16px;
    font-weight: 900;
}

.followup-clear-state strong {
    font-size: 13px;
}

.followup-clear-state p {
    margin: 4px 0 0;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.5;
}

.followup-columns {
    grid-template-columns: repeat(
        auto-fit,
        minmax(min(100%, 285px), 1fr)
    );
}

.dashboard-job-list {
    display: grid;
    grid-template-columns: repeat(
        auto-fit,
        minmax(min(100%, 360px), 1fr)
    );
    gap: 12px;
}

.dashboard-job-card {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 14px;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #ffffff;
    padding: 15px;
    transition: 160ms ease;
}

.dashboard-job-card:hover {
    border-color: #cab585;
    box-shadow: 0 7px 18px rgba(17, 17, 17, 0.045);
    transform: translateY(-1px);
}

.dashboard-job-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 13px;
    min-width: 0;
    border-bottom: 1px solid var(--line);
    padding-bottom: 12px;
}

.dashboard-job-heading > div {
    min-width: 0;
}

.dashboard-job-heading h3 {
    margin: 2px 0 5px;
    color: var(--black);
    font-size: 13px;
    line-height: 1.4;
    overflow-wrap: anywhere;
}

.dashboard-job-heading > div > span {
    color: var(--muted);
    font-size: 10px;
    line-height: 1.4;
}

.dashboard-job-details {
    display: grid;
    grid-template-columns: minmax(120px, 0.8fr) minmax(0, 1.2fr);
    gap: 14px;
}

.dashboard-job-details > div {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 5px;
}

.dashboard-job-details > div > span {
    color: var(--muted);
    font-size: 8.5px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.dashboard-job-details strong {
    color: var(--text);
    font-size: 11px;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.dashboard-job-details small {
    color: var(--muted);
    font-size: 9px;
}

@media (max-width: 700px) {
    .followup-clear-state {
        align-items: flex-start;
    }

    .dashboard-job-list {
        grid-template-columns: 1fr;
    }

    .dashboard-job-details {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .dashboard-job-heading {
        flex-direction: column;
    }
}

/* Enquiries workspace refinement */

.enquiry-review-alert {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 20px;
    border: 1px solid #efc9c5;
    border-left: 4px solid var(--danger);
    border-radius: 6px;
    background: #fff9f8;
    box-shadow: var(--shadow);
    padding: 15px 17px;
}

.enquiry-review-alert-icon {
    display: grid;
    width: 32px;
    height: 32px;
    flex: 0 0 auto;
    place-items: center;
    border-radius: 999px;
    background: var(--danger-pale);
    color: var(--danger);
    font-size: 15px;
    font-weight: 900;
}

.enquiry-review-alert > div:nth-child(2) {
    min-width: 0;
    flex: 1;
}

.enquiry-review-alert strong {
    font-size: 13px;
}

.enquiry-review-alert p {
    margin: 4px 0 0;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.5;
}

.enquiry-toolbar {
    align-items: flex-end;
    padding: 17px 20px;
}

.enquiry-filters {
    display: grid;
    grid-template-columns:
        minmax(250px, 1.6fr)
        minmax(160px, 0.75fr)
        minmax(160px, 0.75fr)
        minmax(175px, 0.85fr)
        auto;
    align-items: end;
    gap: 10px;
}

.pipeline-filter-field {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 6px;
}

.pipeline-filter-field > span {
    color: var(--muted);
    font-size: 8.5px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.07em;
}

.pipeline-filter-field input,
.pipeline-filter-field select {
    width: 100%;
    min-height: 41px;
    border: 1px solid #d9d9d4;
    border-radius: 4px;
    background: #ffffff;
    color: var(--text);
    font: inherit;
    font-size: 12px;
    padding: 0 11px;
}

.pipeline-filter-field input:focus,
.pipeline-filter-field select:focus {
    border-color: var(--gold);
    outline: 2px solid rgba(220, 174, 87, 0.17);
}

.pipeline-filter-actions {
    display: flex;
    align-items: center;
    gap: 6px;
}

.enquiry-toolbar-meta {
    display: flex;
    flex: 0 0 auto;
    align-items: center;
    gap: 12px;
}

.pipeline-result-count {
    color: var(--muted);
    font-size: 10px;
    font-weight: 700;
    white-space: nowrap;
}

.enquiry-table th,
.enquiry-table td {
    padding: 15px 13px;
}

.enquiry-table th:nth-child(1) {
    width: 13%;
}

.enquiry-table th:nth-child(2) {
    width: 26%;
}

.enquiry-table th:nth-child(3) {
    width: 19%;
}

.enquiry-table th:nth-child(4) {
    width: 14%;
}

.enquiry-table th:nth-child(5) {
    width: 15%;
}

.enquiry-table th:nth-child(6) {
    width: 13%;
}

.enquiry-reference-link {
    color: var(--gold-dark);
    font-weight: 850;
}

.enquiry-client-name {
    display: block;
    color: var(--black);
    font-size: 12px;
    line-height: 1.4;
}

.enquiry-property-line {
    line-height: 1.45;
}

.enquiry-row-review {
    box-shadow: inset 3px 0 0 var(--danger);
}

.enquiry-row-overdue:not(.enquiry-row-review) {
    box-shadow: inset 3px 0 0 #d66c36;
}

.enquiry-status {
    display: inline-flex;
    max-width: 100%;
    line-height: 1.2;
    text-align: left;
    white-space: normal;
}

.enquiry-status-new {
    background: var(--gold-pale);
    color: var(--gold-dark);
}

.enquiry-status-contact_attempted {
    background: #eef1ff;
    color: #3347a3;
}

.enquiry-status-quote_sent,
.enquiry-status-awaiting_response {
    background: #fff2d9;
    color: #906000;
}

.enquiry-status-dormant {
    background: #efefed;
    color: #666762;
}

.enquiry-status-instructed {
    background: var(--success-pale);
    color: var(--success);
}

.enquiry-status-closed_no_response,
.enquiry-status-lost,
.enquiry-status-cancelled {
    background: var(--danger-pale);
    color: var(--danger);
}

.table-attention-note {
    display: block;
    margin-top: 6px;
    color: var(--danger);
    font-size: 9px;
    font-weight: 800;
    line-height: 1.35;
}

.table-attention-note-overdue,
.enquiry-overdue-text {
    color: #b33f25;
}

.enquiry-table-actions {
    align-items: flex-start;
    flex-direction: column;
}

.enquiry-table-actions .button,
.enquiry-table-actions form {
    width: 100%;
}

.enquiry-table-actions form .button {
    width: 100%;
}

.conversion-readiness {
    display: block;
    color: var(--muted);
    font-size: 9px;
    line-height: 1.4;
}

.pipeline-board-shell {
    min-width: 0;
}

.pipeline-scroll-hint {
    display: none;
    margin: 14px 18px 0;
    color: var(--muted);
    font-size: 10px;
}

.enquiry-board {
    grid-template-columns: repeat(6, minmax(285px, 1fr));
    align-items: start;
}

.enquiry-board-column {
    min-height: 250px;
    overflow: hidden;
}

.enquiry-board-column .board-column-header {
    position: sticky;
    top: 0;
    z-index: 2;
    background: #f8f8f6;
}

.enquiry-card {
    position: relative;
    padding: 14px;
}

.enquiry-card-overdue {
    border-left: 3px solid #d66c36;
}

.enquiry-card-review {
    border-left: 3px solid var(--danger);
}

.enquiry-attention-chip {
    display: inline-flex;
    margin-top: 10px;
    border-radius: 999px;
    background: var(--danger-pale);
    color: var(--danger);
    font-size: 8px;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 5px 7px;
}

.enquiry-attention-chip-overdue {
    background: #fff0e8;
    color: #a94022;
}

.enquiry-source-line {
    display: flex;
    flex-wrap: wrap;
    gap: 5px 10px;
    margin-top: 9px;
    color: var(--muted);
    font-size: 9px;
}

.enquiry-source-line span + span::before {
    content: "·";
    margin-right: 10px;
}

.enquiry-card-meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 12px;
}

.enquiry-card-meta div {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 4px;
}

.enquiry-card-meta dd {
    overflow-wrap: anywhere;
}

.enquiry-card-meta dd small {
    display: block;
    margin-top: 3px;
    color: var(--muted);
    font-size: 9px;
}

.enquiry-card-actions {
    align-items: stretch;
    flex-direction: column;
}

.enquiry-card-actions .button,
.enquiry-card-actions form,
.enquiry-card-actions form .button {
    width: 100%;
}

.board-empty {
    min-height: 78px;
    padding: 14px;
    text-align: center;
}

@media (max-width: 1380px) {
    .enquiry-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .enquiry-toolbar-meta {
        justify-content: space-between;
    }
}

@media (max-width: 1120px) {
    .enquiry-filters {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pipeline-search-field {
        grid-column: 1 / -1;
    }

    .pipeline-filter-actions {
        align-self: end;
    }
}

@media (max-width: 820px) {
    .enquiry-review-alert {
        align-items: flex-start;
        flex-wrap: wrap;
    }

    .enquiry-review-alert .button {
        margin-left: 46px;
    }

    .pipeline-scroll-hint {
        display: block;
    }

    .enquiry-responsive-table,
    .enquiry-responsive-table tbody,
    .enquiry-responsive-table tr,
    .enquiry-responsive-table td {
        display: block;
        width: 100%;
    }

    .enquiry-responsive-table thead {
        display: none;
    }

    .enquiry-responsive-table tbody {
        display: grid;
        gap: 12px;
        padding: 14px;
    }

    .enquiry-responsive-table tr {
        overflow: hidden;
        border: 1px solid var(--line);
        border-radius: 6px;
        background: #ffffff;
        box-shadow: 0 6px 16px rgba(17, 17, 17, 0.035);
    }

    .enquiry-responsive-table td {
        display: grid;
        grid-template-columns: 125px minmax(0, 1fr);
        gap: 12px;
        border-bottom: 1px solid var(--line);
        padding: 11px 13px;
    }

    .enquiry-responsive-table td::before {
        content: attr(data-label);
        color: var(--muted);
        font-size: 8.5px;
        font-weight: 850;
        text-transform: uppercase;
        letter-spacing: 0.06em;
    }

    .enquiry-responsive-table td:last-child {
        border-bottom: 0;
    }

    .enquiry-table-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 7px;
    }

    .enquiry-table-actions .conversion-readiness {
        grid-column: 1 / -1;
    }
}

@media (max-width: 640px) {
    .enquiry-filters {
        grid-template-columns: 1fr;
    }

    .pipeline-search-field {
        grid-column: auto;
    }

    .pipeline-filter-actions {
        width: 100%;
        align-items: stretch;
        flex-direction: column;
    }

    .pipeline-filter-actions .button,
    .pipeline-filter-actions .text-link {
        width: 100%;
        text-align: center;
    }

    .enquiry-toolbar-meta {
        align-items: stretch;
        flex-direction: column;
    }

    .view-toggle {
        align-self: stretch;
    }

    .view-toggle-link {
        flex: 1;
        text-align: center;
    }

    .enquiry-review-alert .button {
        width: 100%;
        margin-left: 0;
    }

    .enquiry-responsive-table td {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    .enquiry-table-actions {
        grid-template-columns: 1fr;
    }

    .enquiry-board {
        grid-template-columns: repeat(6, minmax(270px, 85vw));
    }
}

/* Jobs workspace refinement */

.jobs-toolbar {
    align-items: flex-end;
    padding: 17px 20px;
}

.jobs-filters {
    display: grid;
    grid-template-columns:
        minmax(270px, 1.65fr)
        minmax(175px, 0.85fr)
        minmax(175px, 0.85fr)
        minmax(190px, 0.9fr)
        auto;
    align-items: end;
    gap: 10px;
}

.jobs-toolbar-meta {
    display: flex;
    flex: 0 0 auto;
    align-items: center;
    gap: 12px;
}

.job-reference-link {
    display: block;
    color: var(--gold-dark);
    font-weight: 850;
}

.job-client-name,
.job-property-name {
    display: block;
    margin-top: 6px;
    color: var(--black);
    font-size: 12px;
    line-height: 1.4;
    overflow-wrap: anywhere;
}

.jobs-table th,
.jobs-table td {
    padding: 15px 13px;
}

.jobs-table th:nth-child(1) {
    width: 17%;
}

.jobs-table th:nth-child(2) {
    width: 24%;
}

.jobs-table th:nth-child(3) {
    width: 22%;
}

.jobs-table th:nth-child(4) {
    width: 11%;
}

.jobs-table th:nth-child(5) {
    width: 17%;
}

.jobs-table th:nth-child(6) {
    width: 9%;
}

.job-row-alert {
    box-shadow: inset 3px 0 0 var(--danger);
}

.job-status {
    display: inline-flex;
    max-width: 100%;
    line-height: 1.2;
    text-align: left;
    white-space: normal;
}

.job-status-instruction_received,
.job-status-terms_preparation,
.job-status-awaiting_signature,
.job-status-awaiting_payment {
    background: #fff2d9;
    color: #906000;
}

.job-status-access_pending,
.job-status-booked {
    background: #eef1ff;
    color: #3347a3;
}

.job-status-desktop_research,
.job-status-ready_for_inspection {
    background: #edf6ff;
    color: #245b84;
}

.job-status-inspection_complete,
.job-status-report_in_progress,
.job-status-report_review {
    background: #f4edff;
    color: #67418b;
}

.job-status-report_complete,
.job-status-report_issued,
.job-status-completed {
    background: var(--success-pale);
    color: var(--success);
}

.job-status-on_hold {
    background: #efefed;
    color: #666762;
}

.job-status-cancelled {
    background: var(--danger-pale);
    color: var(--danger);
}

.job-table-readiness {
    display: flex;
    flex-direction: column;
    gap: 7px;
    margin-top: 9px;
}

.job-table-readiness > span {
    color: var(--muted);
    font-size: 9px;
    font-weight: 750;
}

.jobs-table-actions {
    align-items: stretch;
    flex-direction: column;
}

.jobs-table-actions .button {
    width: 100%;
}

.job-overdue-text {
    color: var(--danger);
    font-weight: 800;
}

.jobs-board {
    grid-template-columns: repeat(7, minmax(295px, 1fr));
    align-items: start;
}

.job-board-column {
    min-height: 250px;
    overflow: hidden;
}

.job-board-column .board-column-header {
    position: sticky;
    top: 0;
    z-index: 2;
    background: #f8f8f6;
}

.job-pipeline-card {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 13px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #ffffff;
    padding: 14px;
    box-shadow: 0 5px 14px rgba(17, 17, 17, 0.03);
}

.job-pipeline-card-alert {
    border-left: 3px solid var(--danger);
}

.job-pipeline-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    min-width: 0;
    border-bottom: 1px solid var(--line);
    padding-bottom: 12px;
}

.job-pipeline-card-header > div {
    min-width: 0;
}

.job-pipeline-card-header h3 {
    margin: 2px 0 5px;
    color: var(--black);
    font-size: 13px;
    line-height: 1.4;
    overflow-wrap: anywhere;
}

.job-pipeline-card-header > div > span {
    color: var(--muted);
    font-size: 10px;
    line-height: 1.4;
}

.job-attention-line {
    border-radius: 4px;
    background: var(--danger-pale);
    color: var(--danger);
    font-size: 9px;
    font-weight: 800;
    line-height: 1.45;
    padding: 8px 9px;
}

.job-readiness-summary {
    display: flex;
    flex-direction: column;
    gap: 9px;
}

.job-readiness-summary > div:first-child {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.job-readiness-summary > div:first-child span {
    color: var(--muted);
    font-size: 8.5px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.job-readiness-summary > div:first-child strong {
    font-size: 10px;
}

.job-readiness-chips {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
}

.job-readiness-chips .readiness-chip {
    justify-content: flex-start;
    overflow: hidden;
    white-space: nowrap;
}

.job-pipeline-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 12px;
    margin: 0;
}

.job-pipeline-meta > div {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 4px;
}

.job-pipeline-meta dt {
    color: var(--muted);
    font-size: 8px;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.job-pipeline-meta dd {
    margin: 0;
    color: var(--text);
    font-size: 10px;
    font-weight: 650;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.job-pipeline-meta dd small {
    display: block;
    margin-top: 3px;
    color: var(--muted);
    font-size: 9px;
    font-weight: 500;
}

.job-pipeline-next {
    grid-column: 1 / -1;
    border-top: 1px solid var(--line);
    padding-top: 10px;
}

.job-pipeline-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
}

.job-pipeline-actions .button {
    width: 100%;
}

@media (max-width: 1380px) {
    .jobs-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .jobs-toolbar-meta {
        justify-content: space-between;
    }
}

@media (max-width: 1120px) {
    .jobs-filters {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .jobs-search-field {
        grid-column: 1 / -1;
    }

    .pipeline-filter-actions {
        align-self: end;
    }
}

@media (max-width: 860px) {
    .jobs-responsive-table,
    .jobs-responsive-table tbody,
    .jobs-responsive-table tr,
    .jobs-responsive-table td {
        display: block;
        width: 100%;
    }

    .jobs-responsive-table thead {
        display: none;
    }

    .jobs-responsive-table tbody {
        display: grid;
        gap: 12px;
        padding: 14px;
    }

    .jobs-responsive-table tr {
        overflow: hidden;
        border: 1px solid var(--line);
        border-radius: 6px;
        background: #ffffff;
        box-shadow: 0 6px 16px rgba(17, 17, 17, 0.035);
    }

    .jobs-responsive-table td {
        display: grid;
        grid-template-columns: 125px minmax(0, 1fr);
        gap: 12px;
        border-bottom: 1px solid var(--line);
        padding: 11px 13px;
    }

    .jobs-responsive-table td::before {
        content: attr(data-label);
        color: var(--muted);
        font-size: 8.5px;
        font-weight: 850;
        text-transform: uppercase;
        letter-spacing: 0.06em;
    }

    .jobs-responsive-table td:last-child {
        border-bottom: 0;
    }

    .jobs-table-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 7px;
    }
}

@media (max-width: 640px) {
    .jobs-filters {
        grid-template-columns: 1fr;
    }

    .jobs-search-field {
        grid-column: auto;
    }

    .jobs-toolbar-meta {
        align-items: stretch;
        flex-direction: column;
    }

    .jobs-responsive-table td {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    .jobs-table-actions {
        grid-template-columns: 1fr;
    }

    .jobs-board {
        grid-template-columns: repeat(7, minmax(280px, 85vw));
    }
}

/* Individual job workspace refinement */

#job-overview,
#delivery,
#readiness,
#tasks,
#appointments,
#documents,
#activity,
#commission {
    scroll-margin-top: 78px;
}

.job-focus-bar {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.8fr) auto;
    align-items: center;
    gap: 20px;
    margin-bottom: 12px;
    border: 1px solid var(--line);
    border-left: 4px solid var(--gold);
    border-radius: 6px;
    background: #ffffff;
    box-shadow: var(--shadow);
    padding: 15px 17px;
}

.job-focus-alert {
    border-left-color: var(--danger);
    background: #fffafa;
}

.job-focus-main,
.job-focus-meta > div {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 4px;
}

.job-focus-main > span,
.job-focus-meta span {
    color: var(--muted);
    font-size: 8.5px;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.07em;
}

.job-focus-main > strong {
    color: var(--black);
    font-size: 15px;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.job-focus-main > small {
    color: var(--muted);
    font-size: 9px;
}

.job-focus-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.job-focus-meta strong {
    color: var(--text);
    font-size: 11px;
    line-height: 1.35;
}

.job-section-nav {
    position: sticky;
    top: 10px;
    z-index: 12;
    display: flex;
    gap: 5px;
    overflow-x: auto;
    margin-bottom: 20px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 8px 22px rgba(17, 17, 17, 0.06);
    padding: 7px;
    backdrop-filter: blur(12px);
    scrollbar-width: none;
}

.job-section-nav::-webkit-scrollbar {
    display: none;
}

.job-section-nav a {
    flex: 0 0 auto;
    border-radius: 4px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
    padding: 8px 11px;
    white-space: nowrap;
}

.job-section-nav a:hover {
    background: var(--gold-pale);
    color: var(--gold-dark);
}

.job-detail-layout {
    grid-template-columns: minmax(0, 1.75fr) minmax(300px, 0.65fr);
}

.job-control-primary-grid {
    display: grid;
    grid-template-columns:
        minmax(170px, 0.8fr)
        minmax(250px, 1.35fr)
        minmax(180px, 0.85fr)
        minmax(170px, 0.8fr);
    gap: 14px;
}

.job-control-disclosure {
    margin-top: 16px;
    border-top: 1px solid var(--line);
    padding-top: 13px;
}

.job-control-disclosure summary {
    color: var(--gold-dark);
    cursor: pointer;
    font-size: 11px;
    font-weight: 800;
}

.job-control-disclosure[open] summary {
    margin-bottom: 15px;
}

.job-control-secondary-grid {
    padding-top: 2px;
}

.readiness-detail-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.readiness-detail-card {
    min-height: 124px;
    padding: 14px;
}

.progress-action-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.progress-action-card {
    grid-template-columns: 30px minmax(0, 1fr);
    align-content: start;
    min-height: 132px;
    padding: 14px;
}

.progress-action-card form,
.progress-action-card > .muted {
    grid-column: 2;
    align-self: end;
    margin-top: 8px;
}

.job-operations-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
    gap: 20px;
}

.job-operations-panel {
    min-width: 0;
}

.job-task-item {
    align-items: flex-start;
    flex-direction: column;
    gap: 12px;
}

.task-item-actions {
    width: 100%;
    justify-content: flex-end;
}

.job-operations-panel .appointment-row {
    align-items: flex-start;
}

.job-operations-panel .item-heading-row {
    align-items: flex-start;
}

.job-documents-panel .document-section-layout {
    grid-template-columns: minmax(270px, 0.72fr) minmax(0, 1.28fr);
}

.job-commission-panel .commission-summary-card {
    grid-template-columns: 1fr;
}

.job-commission-panel .commission-summary-card > div {
    min-height: 0;
}

.job-detail-sidebar .panel {
    min-width: 0;
}

.job-detail-sidebar .activity-list {
    max-height: 620px;
    overflow-y: auto;
    padding-right: 4px;
    scrollbar-color: rgba(220, 174, 87, 0.45) transparent;
    scrollbar-width: thin;
}

@media (max-width: 1320px) {
    .job-control-primary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .job-control-next-action {
        grid-column: span 2;
    }

    .readiness-detail-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1180px) {
    .job-focus-bar {
        grid-template-columns: minmax(0, 1fr) auto;
    }

    .job-focus-meta {
        grid-column: 1;
        grid-row: 2;
        max-width: 420px;
    }

    .job-focus-bar > .button {
        grid-column: 2;
        grid-row: 1 / span 2;
    }

    .job-section-nav {
        top: 8px;
    }

    .progress-action-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .job-documents-panel .document-section-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    #job-overview,
    #delivery,
    #readiness,
    #tasks,
    #appointments,
    #documents,
    #activity,
    #commission {
        scroll-margin-top: 132px;
    }

    .job-section-nav {
        top: 70px;
    }
}

@media (max-width: 820px) {
    .job-focus-bar {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .job-focus-meta,
    .job-focus-bar > .button {
        grid-column: auto;
        grid-row: auto;
        max-width: none;
    }

    .job-focus-bar > .button {
        width: 100%;
    }

    .job-control-primary-grid {
        grid-template-columns: 1fr;
    }

    .job-control-next-action {
        grid-column: auto;
    }

    .job-operations-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 660px) {
    .job-focus-meta {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .readiness-detail-grid,
    .progress-action-grid {
        grid-template-columns: 1fr;
    }

    .progress-action-card {
        min-height: 0;
    }

    .job-section-nav {
        margin-right: -12px;
        margin-left: -12px;
        border-right: 0;
        border-left: 0;
        border-radius: 0;
        padding-right: 12px;
        padding-left: 12px;
    }

    .job-detail-header .quick-actions {
        width: 100%;
    }

    .job-detail-header .quick-actions .button {
        flex: 1 1 100%;
    }
}

/* Job detail delivery logic and disclosure refinement */

.job-controls-disclosure,
.document-upload-disclosure {
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #fbfbfa;
}

.job-controls-disclosure > summary,
.document-upload-disclosure > summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    cursor: pointer;
    list-style: none;
    padding: 14px 15px;
}

.job-controls-disclosure > summary::-webkit-details-marker,
.document-upload-disclosure > summary::-webkit-details-marker {
    display: none;
}

.job-controls-disclosure > summary::after,
.document-upload-disclosure > summary::after {
    content: "+";
    display: grid;
    width: 25px;
    height: 25px;
    flex: 0 0 auto;
    place-items: center;
    border-radius: 999px;
    background: var(--gold-pale);
    color: var(--gold-dark);
    font-size: 17px;
    font-weight: 800;
}

.job-controls-disclosure[open] > summary::after,
.document-upload-disclosure[open] > summary::after {
    content: "−";
}

.job-controls-disclosure > summary span,
.document-upload-disclosure > summary span {
    color: var(--black);
    font-size: 12px;
    font-weight: 850;
}

.job-controls-disclosure > summary small,
.document-upload-disclosure > summary small {
    flex: 1;
    color: var(--muted);
    font-size: 9px;
    line-height: 1.4;
}

.job-controls-disclosure .job-overview-form {
    border-top: 1px solid var(--line);
    padding: 16px;
}

.progress-action-card.progress-current {
    border-left-color: var(--gold);
    background: #fffaf0;
}

.progress-action-card.progress-current > span {
    background: var(--gold);
    color: var(--black);
}

.document-section-layout {
    display: block;
}

.document-upload-disclosure {
    margin-bottom: 15px;
}

.document-upload-disclosure .document-upload-form {
    max-width: none;
    border: 0;
    border-top: 1px solid var(--line);
    border-radius: 0;
    background: #ffffff;
    padding: 16px;
}

.document-upload-disclosure .document-upload-form .form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.document-upload-disclosure .document-upload-form .checkbox-field,
.document-upload-disclosure .document-upload-form > .button {
    grid-column: 1 / -1;
}

.document-list {
    width: 100%;
}

@media (max-width: 760px) {
    .job-controls-disclosure > summary,
    .document-upload-disclosure > summary {
        align-items: flex-start;
        flex-wrap: wrap;
    }

    .job-controls-disclosure > summary small,
    .document-upload-disclosure > summary small {
        order: 3;
        flex-basis: 100%;
    }

    .document-upload-disclosure .document-upload-form .form-grid {
        grid-template-columns: 1fr;
    }

    .document-upload-disclosure .document-upload-form .checkbox-field,
    .document-upload-disclosure .document-upload-form > .button {
        grid-column: auto;
    }
}

/* Client and property workspace refinement */

.records-toolbar {
    align-items: flex-end;
    padding: 17px 20px;
}

.client-record-filters {
    display: grid;
    grid-template-columns:
        minmax(290px, 1.6fr)
        minmax(180px, 0.75fr)
        minmax(170px, 0.7fr)
        auto;
    align-items: end;
    gap: 10px;
}

.property-record-filters {
    display: grid;
    grid-template-columns:
        minmax(260px, 1.35fr)
        repeat(4, minmax(155px, 0.72fr))
        auto;
    align-items: end;
    gap: 10px;
}

.refined-record-card {
    transition: 160ms ease;
}

.refined-record-card:hover {
    border-color: #cab585;
    box-shadow: 0 10px 26px rgba(17, 17, 17, 0.065);
    transform: translateY(-2px);
}

.record-attention-strip {
    margin-top: 13px;
    border-radius: 4px;
    font-size: 9px;
    font-weight: 800;
    line-height: 1.4;
    padding: 7px 9px;
}

.record-attention-positive {
    background: var(--success-pale);
    color: var(--success);
}

.record-badge-stack {
    display: flex;
    flex: 0 0 auto;
    align-items: flex-end;
    flex-direction: column;
    gap: 5px;
}

.record-count-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    width: 100%;
    gap: 7px;
}

.record-count-grid span {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 2px;
    border-radius: 4px;
    background: #f7f7f4;
    padding: 8px;
    text-align: center;
}

.record-count-grid strong {
    font-size: 13px;
}

.record-section-nav {
    position: sticky;
    top: 10px;
    z-index: 11;
    display: flex;
    gap: 5px;
    overflow-x: auto;
    margin-bottom: 20px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 8px 22px rgba(17, 17, 17, 0.06);
    padding: 7px;
    backdrop-filter: blur(12px);
    scrollbar-width: none;
}

.record-section-nav::-webkit-scrollbar {
    display: none;
}

.record-section-nav a {
    flex: 0 0 auto;
    border-radius: 4px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
    padding: 8px 11px;
    white-space: nowrap;
}

.record-section-nav a:hover {
    background: var(--gold-pale);
    color: var(--gold-dark);
}

#contacts,
#client-jobs,
#client-enquiries,
#client-appointments,
#client-properties,
#client-activity,
#property-jobs,
#property-enquiries,
#property-appointments,
#property-documents,
#property-details,
#property-clients,
#property-activity {
    scroll-margin-top: 78px;
}

.refined-record-detail-layout {
    grid-template-columns: minmax(0, 1.7fr) minmax(310px, 0.65fr);
}

.refined-contact-card {
    display: flex;
    min-width: 0;
    flex-direction: column;
}

.refined-contact-card .button {
    align-self: flex-start;
    margin-top: auto;
}

.panel-meta {
    color: var(--muted);
    font-size: 10px;
    font-weight: 700;
}

.record-history-disclosure {
    margin-top: 13px;
    border-top: 1px solid var(--line);
    padding-top: 12px;
}

.record-history-disclosure summary {
    color: var(--gold-dark);
    cursor: pointer;
    font-size: 10px;
    font-weight: 800;
}

.record-history-disclosure[open] summary {
    margin-bottom: 10px;
}

.record-activity-list {
    max-height: 590px;
    overflow-y: auto;
    padding-right: 4px;
    scrollbar-color: rgba(220, 174, 87, 0.45) transparent;
    scrollbar-width: thin;
}

.record-detail-sidebar .detail-list dd,
.record-detail-sidebar .record-notes p {
    overflow-wrap: anywhere;
}

@media (max-width: 1380px) {
    .records-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .records-toolbar > .pipeline-result-count {
        align-self: flex-end;
    }

    .property-record-filters {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .records-search-field {
        grid-column: span 2;
    }
}

@media (max-width: 1120px) {
    .client-record-filters,
    .property-record-filters {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .records-search-field {
        grid-column: 1 / -1;
    }

    .refined-record-detail-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    .record-section-nav {
        top: 70px;
    }

    #contacts,
    #client-jobs,
    #client-enquiries,
    #client-appointments,
    #client-properties,
    #client-activity,
    #property-jobs,
    #property-enquiries,
    #property-appointments,
    #property-documents,
    #property-details,
    #property-clients,
    #property-activity {
        scroll-margin-top: 132px;
    }
}

@media (max-width: 700px) {
    .client-record-filters,
    .property-record-filters {
        grid-template-columns: 1fr;
    }

    .records-search-field {
        grid-column: auto;
    }

    .records-toolbar > .pipeline-result-count {
        align-self: flex-start;
    }

    .record-count-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .record-section-nav {
        margin-right: -12px;
        margin-left: -12px;
        border-right: 0;
        border-left: 0;
        border-radius: 0;
        padding-right: 12px;
        padding-left: 12px;
    }

    .record-detail-header .quick-actions {
        width: 100%;
    }

    .record-detail-header .quick-actions .button {
        flex: 1 1 100%;
    }
}

/* Appointments and tasks workspace refinement */

.refined-task-toolbar {
    gap: 14px;
}

.task-toolbar-bottom {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
}

.refined-task-filters {
    display: grid;
    flex: 1;
    grid-template-columns:
        minmax(280px, 1.4fr)
        minmax(165px, 0.65fr)
        minmax(145px, 0.55fr)
        minmax(170px, 0.65fr)
        auto;
    align-items: end;
    gap: 10px;
}

.task-search-field {
    min-width: 0;
}

.task-related-record {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.task-related-record > span {
    color: var(--muted);
    font-size: 9px;
}

.task-status-not_started {
    background: var(--gold-pale);
    color: var(--gold-dark);
}

.task-status-in_progress {
    background: #eef1ff;
    color: #3347a3;
}

.task-status-waiting {
    background: #fff2d9;
    color: #906000;
}

.task-status-completed {
    background: var(--success-pale);
    color: var(--success);
}

.task-status-cancelled {
    background: var(--danger-pale);
    color: var(--danger);
}

.refined-task-workspace .task-card {
    min-height: 104px;
}

.refined-task-workspace .task-card-actions .button {
    min-width: 78px;
}

.refined-calendar-toolbar {
    grid-template-columns: auto minmax(220px, 1fr);
}

.refined-calendar-toolbar .calendar-range {
    text-align: right;
}

.refined-calendar-toolbar .calendar-range span {
    display: block;
    margin-bottom: 4px;
    color: var(--muted);
    font-size: 8px;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.07em;
}

.refined-calendar-filters {
    display: grid;
    grid-template-columns:
        minmax(300px, 1.45fr)
        minmax(190px, 0.75fr)
        minmax(165px, 0.65fr)
        auto
        auto;
    align-items: end;
    gap: 10px;
    border-bottom: 1px solid var(--line);
    padding: 15px 20px 17px;
}

.calendar-search-field {
    min-width: 0;
}

.calendar-day-header small {
    color: #8b8c87;
    font-size: 8px;
    font-weight: 650;
}

.calendar-event-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 6px;
}

.calendar-event-heading .calendar-event-time {
    margin: 0;
}

.appointment-status {
    flex: 0 0 auto;
    padding: 3px 6px;
    font-size: 7px;
}

.appointment-status-tentative {
    background: #fff2d9;
    color: #906000;
}

.appointment-status-confirmed {
    background: var(--success-pale);
    color: var(--success);
}

.appointment-status-completed {
    background: #eef1ff;
    color: #3347a3;
}

.appointment-status-cancelled {
    background: var(--danger-pale);
    color: var(--danger);
}

.calendar-event-location,
.agenda-location {
    color: #8c8d87;
    font-size: 8px;
    line-height: 1.45;
}

.refined-appointment-agenda {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.agenda-location {
    display: block;
    margin-top: 5px;
}

@media (max-width: 1260px) {
    .task-toolbar-bottom {
        align-items: stretch;
        flex-direction: column;
    }

    .task-toolbar-bottom > .pipeline-result-count {
        align-self: flex-end;
    }

    .refined-task-filters {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .task-search-field {
        grid-column: 1 / -1;
    }

    .refined-calendar-filters {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .calendar-search-field {
        grid-column: 1 / -1;
    }

    .refined-calendar-filters > .pipeline-result-count {
        justify-self: end;
    }
}

@media (max-width: 900px) {
    .refined-calendar-toolbar {
        grid-template-columns: 1fr;
    }

    .refined-calendar-toolbar .calendar-range {
        text-align: left;
    }

    .refined-week-calendar {
        min-width: 0;
        grid-template-columns: 1fr;
    }

    .refined-week-calendar .calendar-day {
        min-height: 0;
        border-right: 0;
        border-bottom: 1px solid var(--line);
    }

    .refined-week-calendar .calendar-day:last-child {
        border-bottom: 0;
    }

    .refined-week-calendar .calendar-day-header {
        min-height: 60px;
    }

    .refined-week-calendar .calendar-day-body {
        min-height: 82px;
    }

    .refined-week-calendar .calendar-day-empty {
        min-height: 62px;
    }
}

@media (max-width: 720px) {
    .refined-task-filters,
    .refined-calendar-filters {
        grid-template-columns: 1fr;
    }

    .task-search-field,
    .calendar-search-field {
        grid-column: auto;
    }

    .task-toolbar-bottom > .pipeline-result-count,
    .refined-calendar-filters > .pipeline-result-count {
        align-self: flex-start;
        justify-self: start;
    }

    .refined-task-workspace .task-card-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        width: 100%;
    }

    .refined-task-workspace .task-card-actions .button,
    .refined-task-workspace .task-card-actions form {
        width: 100%;
    }

    .refined-task-workspace .task-card-actions form .button {
        width: 100%;
    }

    .refined-appointment-agenda {
        grid-template-columns: 1fr;
    }

    .calendar-navigation .button {
        width: 100%;
    }
}

/* Appointment calendar final spacing polish */

.refined-week-calendar .calendar-day {
    min-height: 330px;
}

.refined-week-calendar .calendar-day-body {
    min-height: 235px;
}

@media (max-width: 900px) {
    .refined-week-calendar .calendar-day {
        min-height: 0;
    }

    .refined-week-calendar .calendar-day-body {
        min-height: 82px;
    }
}

/* Security, staff access and production-readiness UI */

.sidebar-signout-form {
    margin: 0;
}

.sidebar-signout-form button {
    border: 0;
    background: transparent;
    color: var(--gold);
    cursor: pointer;
    font: inherit;
    font-size: 10px;
    font-weight: 800;
    padding: 0;
}

.sidebar-signout-form button:hover {
    color: #f0ca78;
}

.staff-auth-body {
    min-height: 100vh;
    margin: 0;
    background: #f2f1ed;
    color: var(--black);
}

.staff-auth-layout {
    display: grid;
    min-height: 100vh;
    grid-template-columns: minmax(420px, 0.94fr) minmax(520px, 1.06fr);
}

.staff-auth-intro {
    position: relative;
    display: flex;
    min-height: 100vh;
    overflow: hidden;
    background:
        radial-gradient(
            circle at 82% 18%,
            rgba(220, 174, 87, 0.18),
            transparent 31%
        ),
        linear-gradient(145deg, #171717 0%, #080808 74%);
    color: #ffffff;
}

.staff-auth-intro::before {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
    background-size: 52px 52px;
    content: "";
    mask-image: linear-gradient(to bottom, black, transparent 84%);
    pointer-events: none;
}

.staff-auth-intro::after {
    position: absolute;
    right: -180px;
    bottom: -240px;
    width: 530px;
    height: 530px;
    border: 1px solid rgba(220, 174, 87, 0.23);
    border-radius: 50%;
    box-shadow:
        0 0 0 62px rgba(220, 174, 87, 0.035),
        0 0 0 125px rgba(220, 174, 87, 0.018);
    content: "";
    pointer-events: none;
}

.staff-auth-intro-inner {
    position: relative;
    z-index: 1;
    display: flex;
    width: min(620px, 100%);
    min-height: 100%;
    flex-direction: column;
    margin: 0 auto;
    padding: clamp(36px, 5vw, 72px) clamp(34px, 6vw, 84px) 46px;
}

.staff-auth-logo {
    display: inline-flex;
    width: fit-content;
    align-items: center;
}

.staff-auth-logo img {
    display: block;
    width: 124px;
    height: auto;
    filter: drop-shadow(0 8px 20px rgba(0, 0, 0, 0.22));
}

.staff-auth-intro-copy {
    margin-top: clamp(70px, 10vh, 126px);
}

.staff-auth-kicker {
    margin: 0 0 15px;
    color: var(--gold);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.staff-auth-intro h1 {
    max-width: 560px;
    margin: 0;
    color: #ffffff;
    font-size: clamp(42px, 5.4vw, 72px);
    font-weight: 760;
    letter-spacing: -0.055em;
    line-height: 0.98;
}

.staff-auth-intro-copy > p:last-child {
    max-width: 525px;
    margin: 27px 0 0;
    color: rgba(255, 255, 255, 0.68);
    font-size: 15px;
    line-height: 1.75;
}

.staff-auth-feature-list {
    display: grid;
    gap: 0;
    max-width: 545px;
    margin-top: clamp(48px, 8vh, 88px);
    border-top: 1px solid rgba(255, 255, 255, 0.13);
}

.staff-auth-feature {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 15px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.13);
    padding: 18px 0;
}

.staff-auth-feature > span {
    color: var(--gold);
    font-size: 10px;
    font-weight: 850;
    letter-spacing: 0.12em;
}

.staff-auth-feature p {
    display: grid;
    gap: 5px;
    margin: 0;
    color: rgba(255, 255, 255, 0.58);
    font-size: 11px;
    line-height: 1.55;
}

.staff-auth-feature strong {
    color: #ffffff;
    font-size: 12px;
    font-weight: 760;
}

.staff-auth-strapline {
    margin: auto 0 0;
    padding-top: 38px;
    color: rgba(255, 255, 255, 0.42);
    font-size: 9px;
    font-weight: 720;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.staff-auth-panel {
    display: grid;
    min-height: 100vh;
    place-items: center;
    padding: 48px clamp(34px, 7vw, 110px);
    background:
        radial-gradient(
            circle at 100% 0%,
            rgba(220, 174, 87, 0.11),
            transparent 30%
        ),
        #f3f2ee;
}

.staff-auth-panel-inner {
    width: min(470px, 100%);
}

.staff-auth-messages {
    margin-bottom: 16px;
}

.staff-auth-card {
    border: 1px solid rgba(17, 17, 17, 0.08);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 26px 70px rgba(17, 17, 17, 0.12);
    padding: clamp(30px, 5vw, 46px);
}

.staff-auth-status {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 34px;
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.staff-auth-status span {
    width: 8px;
    height: 8px;
    border: 2px solid #ffffff;
    border-radius: 50%;
    background: var(--success);
    box-shadow: 0 0 0 3px rgba(22, 121, 75, 0.13);
}

.staff-auth-card .eyebrow {
    margin-bottom: 8px;
}

.staff-auth-card h2 {
    margin: 0;
    color: var(--black);
    font-size: clamp(31px, 5vw, 43px);
    font-weight: 760;
    letter-spacing: -0.045em;
    line-height: 1.05;
}

.staff-auth-card-copy {
    margin: 13px 0 0;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.65;
}

.staff-auth-form {
    display: grid;
    gap: 18px;
    margin-top: 32px;
}

.staff-auth-field {
    display: grid;
    gap: 8px;
}

.staff-auth-field > span {
    color: #4d4e4a;
    font-size: 10px;
    font-weight: 820;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.staff-auth-field input {
    width: 100%;
    min-height: 50px;
    border: 1px solid #d7d7d1;
    border-radius: 5px;
    background: #fbfbf9;
    color: var(--text);
    font: inherit;
    font-size: 14px;
    padding: 0 14px;
    transition: 150ms ease;
}

.staff-auth-field input:hover {
    border-color: #bcbdb6;
}

.staff-auth-field input:focus {
    border-color: var(--gold-dark);
    background: #ffffff;
    box-shadow: 0 0 0 4px rgba(220, 174, 87, 0.15);
    outline: 0;
}

.staff-auth-form .form-error-summary {
    margin: 0;
    border: 1px solid #f1c4c0;
    border-radius: 5px;
    background: var(--danger-pale);
    color: var(--danger);
    font-size: 11px;
    line-height: 1.55;
    padding: 12px 14px;
}

.staff-auth-form .form-error-summary .errorlist {
    color: inherit;
}

.staff-auth-submit {
    display: flex;
    min-height: 52px;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 3px;
    border: 1px solid var(--black);
    border-radius: 5px;
    background: var(--black);
    color: #ffffff;
    cursor: pointer;
    font: inherit;
    font-size: 12px;
    font-weight: 800;
    padding: 0 18px;
    transition: 160ms ease;
}

.staff-auth-submit span:last-child {
    color: var(--gold);
    font-size: 18px;
    transition: transform 160ms ease;
}

.staff-auth-submit:hover {
    border-color: #262626;
    background: #262626;
}

.staff-auth-submit:hover span:last-child {
    transform: translateX(3px);
}

.staff-auth-submit:focus-visible {
    outline: 3px solid rgba(220, 174, 87, 0.42);
    outline-offset: 3px;
}

.staff-auth-help {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-top: 27px;
    border-top: 1px solid var(--line);
    padding-top: 20px;
    color: var(--muted);
    font-size: 10px;
}

.staff-auth-help a {
    color: var(--gold-dark);
    font-weight: 820;
}

.staff-auth-help a:hover {
    text-decoration: underline;
    text-underline-offset: 3px;
}

.staff-auth-security-note {
    max-width: 400px;
    margin: 18px auto 0;
    color: #858680;
    font-size: 9px;
    line-height: 1.6;
    text-align: center;
}

.system-error-body {
    min-height: 100vh;
    margin: 0;
    background:
        radial-gradient(
            circle at top right,
            rgba(220, 174, 87, 0.13),
            transparent 38%
        ),
        #f4f4f1;
    color: var(--black);
}

.system-error-shell {
    width: min(590px, calc(100% - 32px));
    margin: 0 auto;
    padding: 54px 0;
    text-align: center;
}

.system-error-card {
    border: 1px solid var(--line);
    border-radius: 7px;
    background: #ffffff;
    box-shadow: 0 24px 60px rgba(17, 17, 17, 0.11);
    padding: 32px;
}

.system-error-card h1 {
    margin: 5px 0 9px;
    font-size: clamp(30px, 7vw, 42px);
}

.system-error-card > p:not(.eyebrow) {
    color: var(--muted);
    line-height: 1.65;
}

.staff-role-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 20px;
}

.staff-role-grid article {
    border: 1px solid var(--line);
    border-top: 3px solid var(--gold);
    border-radius: 6px;
    background: #ffffff;
    box-shadow: 0 12px 30px rgba(17, 17, 17, 0.055);
    padding: 20px;
}

.staff-role-grid h2 {
    margin: 7px 0 8px;
    font-size: 16px;
}

.staff-role-grid p:last-child {
    margin-bottom: 0;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.65;
}

.field-help {
    display: block;
    margin-top: 5px;
    color: var(--muted);
    font-size: 9px;
    line-height: 1.45;
}

.system-error-shell > img {
    width: 115px;
    height: auto;
    margin-bottom: 24px;
}

.system-error-card > span {
    display: inline-grid;
    width: 64px;
    height: 64px;
    place-items: center;
    margin-bottom: 12px;
    border-radius: 999px;
    background: var(--gold-pale);
    color: var(--gold-dark);
    font-size: 23px;
    font-weight: 900;
}

.system-error-actions {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 24px;
}

@media (max-width: 1050px) {
    .staff-auth-layout {
        grid-template-columns: minmax(330px, 0.8fr) minmax(470px, 1.2fr);
    }

    .staff-auth-feature-list {
        display: none;
    }

    .staff-auth-intro-copy {
        margin-top: clamp(70px, 15vh, 140px);
    }
}

@media (max-width: 820px) {
    .staff-auth-layout {
        display: block;
    }

    .staff-auth-intro {
        min-height: auto;
    }

    .staff-auth-intro-inner {
        width: 100%;
        padding: 28px 26px 34px;
    }

    .staff-auth-logo img {
        width: 104px;
    }

    .staff-auth-intro-copy {
        margin-top: 48px;
    }

    .staff-auth-intro h1 {
        max-width: 620px;
        font-size: clamp(38px, 10vw, 56px);
    }

    .staff-auth-intro-copy > p:last-child {
        max-width: 600px;
        margin-top: 20px;
    }

    .staff-auth-strapline {
        display: none;
    }

    .staff-auth-panel {
        min-height: auto;
        padding: 38px 22px 52px;
    }

    .staff-role-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 520px) {
    .staff-auth-intro-inner {
        padding: 24px 20px 29px;
    }

    .staff-auth-intro-copy {
        margin-top: 38px;
    }

    .staff-auth-intro-copy > p:last-child {
        font-size: 13px;
    }

    .staff-auth-panel {
        padding: 28px 14px 42px;
    }

    .staff-auth-card {
        border-radius: 7px;
        padding: 27px 21px;
    }

    .staff-auth-status {
        margin-bottom: 27px;
    }

    .staff-auth-help,
    .system-error-actions {
        align-items: flex-start;
        flex-direction: column;
    }

    .system-error-actions .button {
        width: 100%;
    }
}

/* Custom administration workspace */

.administration-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 20px;
}

.administration-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: start;
    gap: 18px;
    border: 1px solid var(--line);
    border-top: 3px solid var(--gold);
    border-radius: 7px;
    background: #ffffff;
    box-shadow: 0 14px 34px rgba(17, 17, 17, 0.055);
    padding: 24px;
    color: var(--black);
    transition:
        transform 160ms ease,
        box-shadow 160ms ease;
}

.administration-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 20px 42px rgba(17, 17, 17, 0.085);
}

.administration-card-icon {
    display: grid;
    width: 42px;
    height: 42px;
    place-items: center;
    border-radius: 999px;
    background: var(--gold-pale);
    color: var(--gold-dark);
    font-size: 12px;
    font-weight: 900;
}

.administration-card h2 {
    margin: 6px 0 8px;
    font-size: 19px;
}

.administration-card p:last-child {
    margin: 0;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.65;
}

.administration-card > span {
    align-self: center;
    color: var(--gold-dark);
    font-size: 10px;
    font-weight: 850;
    white-space: nowrap;
}

.system-status-panel,
.advanced-administration-panel {
    margin-bottom: 20px;
}

.system-status-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 0;
}

.system-status-grid > div {
    border-right: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    padding: 18px 20px;
}

.system-status-grid > div:nth-child(3n) {
    border-right: 0;
}

.system-status-grid > div:nth-last-child(-n + 3) {
    border-bottom: 0;
}

.system-status-grid dt {
    margin-bottom: 6px;
    color: var(--muted);
    font-size: 8px;
    font-weight: 850;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.system-status-grid dd {
    margin: 0;
    font-size: 11px;
    font-weight: 800;
    overflow-wrap: anywhere;
}

.advanced-administration-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    padding: 20px;
}

.advanced-administration-content p {
    max-width: 800px;
    margin: 0 0 7px;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.65;
}

.advanced-administration-content p:last-child {
    margin-bottom: 0;
}

@media (max-width: 980px) {
    .administration-grid {
        grid-template-columns: 1fr;
    }

    .system-status-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .system-status-grid > div:nth-child(3n) {
        border-right: 1px solid var(--line);
    }

    .system-status-grid > div:nth-child(2n) {
        border-right: 0;
    }

    .system-status-grid > div:nth-last-child(-n + 3) {
        border-bottom: 1px solid var(--line);
    }

    .system-status-grid > div:nth-last-child(-n + 2) {
        border-bottom: 0;
    }
}

@media (max-width: 680px) {
    .administration-card {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .administration-card > span {
        grid-column: 2;
        justify-self: start;
    }

    .system-status-grid {
        grid-template-columns: 1fr;
    }

    .system-status-grid > div,
    .system-status-grid > div:nth-child(2n),
    .system-status-grid > div:nth-child(3n) {
        border-right: 0;
        border-bottom: 1px solid var(--line);
    }

    .system-status-grid > div:last-child {
        border-bottom: 0;
    }

    .advanced-administration-content {
        align-items: stretch;
        flex-direction: column;
    }

    .advanced-administration-content .button {
        width: 100%;
    }
}

/* Terms and invoice foundation */
.terms-invoice-header {
    align-items: flex-start;
}

.terms-stage-notice {
    border: 1px solid #e5c472;
    border-left: 4px solid var(--gold);
    border-radius: 10px;
    background: #fffaf0;
    margin-bottom: 22px;
    padding: 17px 20px;
}

.terms-stage-notice strong {
    display: block;
    margin-bottom: 5px;
    font-size: 12px;
}

.terms-stage-notice p {
    margin: 0;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.65;
}

.terms-stage-ready {
    border-color: #b9dfc5;
    border-left-color: #2d9b58;
    background: #f3fbf6;
}

.terms-invoice-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.7fr) minmax(280px, 0.8fr);
    gap: 22px;
    align-items: start;
}

.terms-invoice-form {
    overflow: hidden;
}

.terms-form-section {
    border-top: 1px solid var(--line);
    padding: 22px 24px;
}

.terms-form-section:first-of-type {
    border-top: 0;
}

.terms-form-section h3 {
    margin: 0 0 14px;
    font-size: 13px;
}

.terms-form-section .section-help {
    margin: -5px 0 15px;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.55;
}

.terms-form-actions {
    border-top: 1px solid var(--line);
    padding: 20px 24px;
}

.terms-invoice-sidebar {
    display: grid;
    gap: 16px;
}

.terms-summary-card,
.terms-rule-card {
    padding: 22px;
}

.terms-summary-card h2 {
    margin: 6px 0 18px;
    font-size: 17px;
    line-height: 1.25;
}

.terms-summary-list,
.terms-preview-list {
    margin: 0;
}

.terms-summary-list > div,
.terms-preview-list > div {
    display: grid;
    grid-template-columns: minmax(110px, 0.55fr) minmax(0, 1fr);
    gap: 18px;
    border-top: 1px solid var(--line);
    padding: 11px 0;
}

.terms-summary-list dt,
.terms-preview-list dt {
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
}

.terms-summary-list dd,
.terms-preview-list dd {
    margin: 0;
    font-size: 10px;
    font-weight: 700;
    overflow-wrap: anywhere;
}

.terms-rule-card p:last-child {
    margin: 8px 0 0;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.65;
}

.terms-draft-stats {
    margin-bottom: 22px;
}

.terms-template-short {
    font-size: 18px;
}

.terms-preview-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
    margin-bottom: 22px;
}

.terms-preview-grid .panel,
.terms-rules-preview,
.terms-internal-note {
    padding: 0 24px 22px;
}

.terms-preview-grid .panel-header,
.terms-rules-preview .panel-header {
    margin: 0 -24px 8px;
    padding: 20px 24px;
}

.terms-rule-columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.terms-rule-columns article {
    border: 1px solid var(--line);
    border-radius: 9px;
    padding: 18px;
}

.terms-rule-columns h3 {
    margin: 0 0 8px;
    font-size: 12px;
}

.terms-rule-columns p,
.terms-internal-note p:last-child {
    margin: 0;
    color: var(--muted);
    font-size: 10px;
    line-height: 1.7;
}

.terms-internal-note {
    padding-top: 20px;
}

.form-field small {
    display: block;
    margin-top: 6px;
    color: var(--muted);
    font-size: 8px;
    line-height: 1.45;
}

@media (max-width: 1080px) {
    .terms-invoice-layout {
        grid-template-columns: 1fr;
    }

    .terms-invoice-sidebar {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .terms-summary-card {
        grid-row: span 2;
    }
}

@media (max-width: 760px) {
    .terms-invoice-sidebar,
    .terms-preview-grid,
    .terms-rule-columns {
        grid-template-columns: 1fr;
    }

    .terms-summary-card {
        grid-row: auto;
    }

    .terms-summary-list > div,
    .terms-preview-list > div {
        grid-template-columns: 1fr;
        gap: 4px;
    }
}

/* Terms and invoice document generation */
.terms-section-heading-row {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: flex-start;
    margin-bottom: 14px;
}

.terms-section-heading-row h3,
.terms-section-heading-row .section-help {
    margin-top: 0;
}

.terms-checkbox-inline,
.terms-confirm-checkbox {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    cursor: pointer;
    font-size: 10px;
    font-weight: 700;
    line-height: 1.45;
}

.terms-checkbox-inline input,
.terms-confirm-checkbox input {
    width: 17px;
    height: 17px;
    margin: 1px 0 0;
    accent-color: var(--gold);
}

.fee-breakdown-preview {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-top: 14px;
    padding: 13px 15px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel-soft);
}

.fee-breakdown-preview span {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    color: var(--muted);
    font-size: 9px;
}

.fee-breakdown-preview strong {
    color: var(--ink);
}

.terms-stage-warning {
    border-left-color: #d78b18;
    background: #fff9eb;
}

.terms-generated-documents,
.terms-secure-link-panel {
    margin-bottom: 22px;
    padding: 0 24px 24px;
}

.terms-generated-documents .panel-header,
.terms-secure-link-panel .panel-header {
    margin: 0 -24px 14px;
    padding: 20px 24px;
}

.generated-document-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.generated-document-card {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 14px;
    align-items: center;
    padding: 15px;
    border: 1px solid var(--line);
    border-radius: 9px;
}

.generated-document-card h3 {
    margin: 0 0 4px;
    font-size: 11px;
}

.generated-document-card p,
.terms-secure-link-panel > p {
    margin: 0;
    color: var(--muted);
    font-size: 9px;
    line-height: 1.55;
}

.document-type-tile {
    display: grid;
    place-items: center;
    width: 44px;
    height: 52px;
    border: 1px solid #ead19e;
    border-radius: 6px;
    background: #fff8e8;
    color: #9a6c18;
    font-size: 9px;
    font-weight: 900;
    letter-spacing: .08em;
}

.secure-link-copy-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    margin-top: 14px;
}

.secure-link-copy-row input {
    min-width: 0;
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: var(--panel-soft);
    color: var(--muted);
    font-size: 9px;
}

.terms-generate-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 310px;
    gap: 22px;
    align-items: start;
}

.terms-generate-layout main {
    display: grid;
    gap: 22px;
}

.terms-final-check-list > div {
    grid-template-columns: 165px 1fr;
}

.terms-generate-form {
    padding: 0 24px 24px;
}

.terms-generate-form .panel-header {
    margin: 0 -24px 18px;
    padding: 20px 24px;
}

.terms-sequence-note,
.terms-sequence-confirmed {
    margin: 14px 0 18px;
    padding: 14px 16px;
    border: 1px solid #e9c97c;
    border-radius: 8px;
    background: #fff9eb;
}

.terms-sequence-note strong,
.terms-sequence-confirmed span {
    display: block;
    margin-bottom: 4px;
    color: #805b17;
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.terms-sequence-note p {
    margin: 0;
    color: var(--muted);
    font-size: 9px;
    line-height: 1.55;
}

.terms-sequence-confirmed strong {
    font-size: 22px;
}

.terms-confirm-checkbox {
    margin: 18px 0;
    padding: 15px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel-soft);
}

.terms-status-ready_to_issue {
    background: #e9f6ee;
    color: #167047;
}

.terms-status-superseded,
.terms-status-cancelled {
    background: #f0f0ed;
    color: #6b6b66;
}

.inline-form {
    display: inline;
}

@media (max-width: 1080px) {
    .terms-generate-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .terms-section-heading-row {
        display: block;
    }

    .terms-checkbox-inline {
        margin-top: 10px;
    }

    .fee-breakdown-preview,
    .generated-document-grid {
        grid-template-columns: 1fr;
    }

    .generated-document-card {
        grid-template-columns: auto 1fr;
    }

    .generated-document-card .button {
        grid-column: 1 / -1;
    }

    .secure-link-copy-row {
        grid-template-columns: 1fr;
    }
}

/* Professional allocation and Terms compliance */
.allocation-dialog {
    width: min(680px, calc(100vw - 32px));
    max-height: calc(100vh - 40px);
    padding: 0;
    border: 0;
    border-radius: 12px;
    box-shadow: 0 24px 70px rgba(0, 0, 0, .28);
}

.allocation-dialog::backdrop {
    background: rgba(12, 12, 12, .58);
}

.allocation-dialog-form {
    padding: 24px;
    background: #fff;
}

.allocation-dialog-header,
.terms-section-heading-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.allocation-dialog-header h2 {
    margin: 2px 0 0;
}

.dialog-close {
    width: 36px;
    height: 36px;
    border: 1px solid var(--line);
    border-radius: 50%;
    background: #fff;
    font-size: 25px;
    line-height: 1;
    cursor: pointer;
}

.allocation-dialog-summary {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin: 20px 0;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: var(--panel-soft);
}

.allocation-dialog-summary span,
.job-allocation-card span,
.professional-check-summary span {
    display: block;
    margin-bottom: 4px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
}

.allocation-dialog .form-field {
    margin-bottom: 16px;
}

.job-allocation-card {
    display: grid;
    grid-template-columns: minmax(230px, .8fr) minmax(320px, 1.2fr);
    gap: 20px;
    align-items: end;
    margin-bottom: 18px;
    padding: 16px;
    border: 1px solid var(--line);
    border-left: 4px solid var(--gold);
    border-radius: 10px;
    background: var(--panel-soft);
}

.job-allocation-card strong,
.job-allocation-card small {
    display: block;
}

.job-allocation-card small {
    margin-top: 4px;
    color: var(--muted);
}

.job-allocation-missing {
    border-left-color: #b24d3f;
    background: #fff5f2;
}

.job-allocation-form {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) auto;
    gap: 10px;
    align-items: end;
}

.job-allocation-form .form-field {
    margin: 0;
}

.staff-permission-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-top: 16px;
}

.checkbox-card span strong,
.checkbox-card span small {
    display: block;
}

.checkbox-card span small {
    margin-top: 4px;
    color: var(--muted);
    font-weight: 400;
}

.professional-check-summary {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 14px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel-soft);
}

.terms-stage-notice ul {
    margin: 8px 0 0 18px;
    padding: 0;
}

@media (max-width: 760px) {
    .allocation-dialog-summary,
    .job-allocation-card,
    .staff-permission-grid,
    .professional-check-summary {
        grid-template-columns: 1fr;
    }

    .job-allocation-form {
        grid-template-columns: 1fr;
    }
}

/* Terms issue, email readiness and audit layout corrections */
.terms-issue-form .terms-issue-confirm {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    align-items: start;
    gap: 11px;
    width: 100%;
    margin: 0;
}

.terms-issue-form .terms-issue-confirm input[type="checkbox"] {
    width: 18px !important;
    min-width: 18px;
    height: 18px;
    min-height: 0 !important;
    margin: 1px 0 0;
    padding: 0;
    flex: 0 0 18px;
}

.terms-issue-form .terms-issue-confirm span {
    min-width: 0;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.5;
}

.terms-issue-form .button[disabled] {
    cursor: not-allowed;
    opacity: .5;
}

.terms-audit-panel .activity-list {
    width: 100%;
}

.terms-audit-panel .activity-item {
    grid-template-columns: 15px minmax(0, 1fr);
    width: 100%;
}

.terms-audit-panel .activity-item > div {
    min-width: 0;
}

.terms-audit-panel .activity-item strong,
.terms-audit-panel .activity-item p {
    overflow-wrap: anywhere;
}

.terms-audit-panel .terms-audit-error {
    color: var(--danger);
    font-weight: 650;
}


/* Xero payment status synchronisation */
.terms-xero-heading-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

.payment-status-badge {
    vertical-align: middle;
}

.payment-status-neutral,
.payment-status-draft {
    background: var(--gold-pale);
    color: var(--gold-dark);
}

.payment-status-awaiting-payment {
    background: var(--warning-pale);
    color: var(--warning);
}

.payment-status-part-paid {
    background: #eef4ff;
    color: #3538cd;
}

.payment-status-paid {
    background: var(--success-pale);
    color: var(--success);
}

.payment-status-voided {
    background: var(--danger-pale);
    color: var(--danger);
}

.payment-status-credited {
    background: #f2f4f7;
    color: #475467;
}

.xero-finance-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin: 18px 0;
}

.xero-finance-summary article {
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel-soft);
}

.xero-finance-summary span,
.xero-finance-summary strong {
    display: block;
}

.xero-finance-summary span {
    margin-bottom: 5px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .05em;
    text-transform: uppercase;
}

.xero-finance-summary strong {
    font-size: 18px;
}

.xero-guidance {
    margin-top: 16px;
    padding: 13px 14px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel-soft);
}

.xero-guidance p:last-child {
    margin-bottom: 0;
}

.xero-guidance-warning {
    border-left: 4px solid var(--warning);
}

.xero-guidance-error {
    border-left: 4px solid var(--danger);
    background: var(--danger-pale);
}

.readiness-card-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
}

.readiness-card-actions form {
    margin: 0;
}

@media (max-width: 760px) {
    .xero-finance-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .readiness-card-actions {
        align-items: flex-start;
    }
}

/* Rich HTML email editor and payment reminders */
.rich-email-editor {
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #ffffff;
}

.rich-email-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    align-items: center;
    border-bottom: 1px solid var(--line);
    background: #f7f6f2;
    padding: 8px;
}

.rich-email-toolbar button {
    min-height: 32px;
    border: 1px solid #d4d1ca;
    border-radius: 5px;
    background: #ffffff;
    padding: 5px 9px;
    color: #171717;
    font: inherit;
    font-size: 11px;
    font-weight: 700;
    cursor: pointer;
}

.rich-email-toolbar button:hover,
.rich-email-toolbar button:focus-visible {
    border-color: var(--gold);
    background: var(--gold-pale);
}

.rich-email-toolbar-divider {
    width: 1px;
    height: 25px;
    margin: 0 2px;
    background: #d9d6cf;
}

.rich-email-mode-button {
    margin-left: auto;
}

.rich-email-visual {
    min-height: 360px;
    padding: 22px;
    outline: none;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 15px;
    line-height: 1.65;
}

.rich-email-visual:focus {
    box-shadow: inset 0 0 0 2px rgba(220, 174, 87, 0.35);
}

.rich-email-visual p {
    margin: 0 0 16px;
}

.rich-email-visual h2,
.rich-email-visual h3 {
    margin: 20px 0 10px;
}

.rich-email-visual .email-button {
    display: inline-block;
    border-radius: 6px;
    background: var(--gold);
    padding: 11px 18px;
    color: #000000;
    font-weight: 750;
    text-decoration: none;
}

.rich-email-source-panel textarea,
.rich-email-source {
    width: 100%;
    min-height: 360px;
    border: 0;
    border-radius: 0;
    padding: 18px;
    font-family: Consolas, "Courier New", monospace;
    font-size: 12px;
    line-height: 1.55;
    resize: vertical;
}

.rich-email-plain-mode .rich-email-toolbar {
    display: none;
}

.rich-email-plain-mode .rich-email-source-panel {
    display: block !important;
}

.rich-email-plain-mode .rich-email-source-panel[hidden] {
    display: block !important;
}

.rich-email-plain-mode .rich-email-visual {
    display: none !important;
}

.rendered-email-preview-html iframe {
    display: block;
    width: 100%;
    min-height: 620px;
    border: 0;
    background: #f3f2ef;
}

.rendered-email-preview details {
    border-top: 1px solid var(--line);
    background: #ffffff;
}

.rendered-email-preview summary {
    padding: 12px 16px;
    font-size: 11px;
    font-weight: 750;
    cursor: pointer;
}

.payment-reminder-form {
    max-width: 1050px;
}

.reminder-confirmations {
    margin-top: 18px;
}

.checkbox-card-confirm {
    border-color: rgba(220, 174, 87, 0.7);
    background: var(--gold-pale);
}

@media (max-width: 760px) {
    .rich-email-toolbar-divider {
        display: none;
    }

    .rich-email-mode-button {
        margin-left: 0;
    }

    .rich-email-visual,
    .rich-email-source-panel textarea,
    .rich-email-source {
        min-height: 300px;
    }
}

/* Organisation and company settings */
.branding-preview-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin: 18px 0 24px;
}

.branding-preview-card {
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
}

.branding-preview-card .form-field {
    padding: 16px;
}

.branding-preview-image {
    display: flex;
    min-height: 112px;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: var(--black);
    border-bottom: 1px solid var(--line);
}

.branding-preview-image-light {
    background: #ffffff;
}

.branding-preview-image img {
    display: block;
    max-width: 190px;
    max-height: 72px;
    object-fit: contain;
}

.company-colour-grid input[type="color"] {
    width: 100%;
    min-height: 46px;
    padding: 4px;
    cursor: pointer;
}

.company-settings-audit {
    margin-top: 24px;
}

.company-settings-change-list {
    margin: 8px 0 0;
    padding-left: 18px;
    color: var(--muted);
    font-size: 0.9rem;
}

.company-settings-change-list li + li {
    margin-top: 5px;
}

@media (max-width: 900px) {
    .branding-preview-grid {
        grid-template-columns: 1fr;
    }
}

/* Invoice administration and automation readiness */
.branding-preview-image {
    min-height: 96px;
    max-height: 112px;
    overflow: hidden;
}

.branding-preview-image img {
    width: auto !important;
    height: auto !important;
    max-width: 160px !important;
    max-height: 64px !important;
}

.reminder-readiness-summary {
    margin: 18px 0 22px;
}

.reminder-readiness-summary .stat-card {
    min-height: 132px;
}

.reminder-readiness-summary .stat-value {
    font-size: clamp(1.15rem, 2vw, 1.55rem);
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.reminder-readiness-summary .stat-value-date {
    font-size: clamp(1rem, 1.45vw, 1.25rem);
}

.reminder-controls-form {
    padding-top: 6px;
}

.finance-action-panel .checkbox-card,
.reminder-controls-panel .checkbox-card {
    margin-top: 12px;
}

.finance-history-panel .activity-item span {
    display: block;
    margin-top: 4px;
}

.badge-danger {
    color: #8f1515;
    background: #fff0f0;
    border-color: #e7b8b8;
}


/* Invoice administration and recovery states */
.finance-review-warning {
    margin: 0 0 1.25rem;
    border-left: 4px solid #dcae57;
}
.finance-action-status-needs_review { color: #9a5b00; }
.finance-action-status-failed { color: #b42318; }
.finance-action-status-succeeded { color: #087443; }
.finance-action-status-pending { color: #5f6470; }
.company-logo-preview,
.company-logo-preview img,
.business-logo-preview,
.business-logo-preview img {
    max-width: 160px !important;
    max-height: 64px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
}

/* Email automation rules and queue */
.badge-success {
    background: var(--success-pale);
    color: var(--success);
}

.badge-warning {
    background: var(--warning-pale);
    color: var(--warning);
}

.automation-rules-panel,
.automation-queue-panel {
    margin-bottom: 20px;
}

.automation-rule-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.automation-rule-card {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 13px;
    border: 1px solid var(--line);
    border-radius: 7px;
    background: #fafaf8;
    padding: 18px;
}

.automation-rule-enabled {
    box-shadow: inset 4px 0 0 var(--gold);
    background: var(--surface);
}

.automation-rule-card-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.automation-rule-card h3 {
    margin: 0;
    color: var(--black);
    font-size: 16px;
}

.automation-rule-card > p {
    min-height: 44px;
    margin: 0;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.55;
}

.automation-rule-meta {
    display: grid;
    gap: 7px;
    margin: 0;
    padding-top: 10px;
    border-top: 1px solid var(--line);
}

.automation-rule-meta div {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.automation-rule-meta dt,
.automation-rule-meta dd {
    margin: 0;
    font-size: 10px;
}

.automation-rule-meta dt { color: var(--muted); }
.automation-rule-meta dd { color: var(--text); font-weight: 700; text-align: right; }

.inline-filter-form select {
    min-height: 38px;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: var(--surface);
    padding: 0 34px 0 11px;
}

.automation-queue-table td:nth-child(2) strong,
.automation-queue-table td:nth-child(2) small {
    display: block;
}

.automation-queue-table td:nth-child(2) small {
    max-width: 340px;
    margin-top: 4px;
    color: var(--muted);
    overflow-wrap: anywhere;
}

.automation-review-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(360px, 0.85fr);
    gap: 20px;
    align-items: start;
    margin-bottom: 20px;
}

.automation-preview-panel {
    position: sticky;
    top: 20px;
}

.automation-preview-panel iframe {
    width: 100%;
    min-height: 620px;
    border: 0;
    background: #f5f5f3;
}

.automation-action-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    align-items: start;
}

.automation-action-grid form {
    margin: 0;
}

.queue-reason-action {
    display: grid;
    gap: 8px;
}

.queue-reason-action textarea {
    min-height: 70px;
    resize: vertical;
}

/* Destructive primary action used only on explicit confirmation pages. */
.button-danger {
    border-color: var(--danger);
    background: var(--danger);
    color: #ffffff;
}

.button-danger:hover {
    border-color: #8f1515;
    background: #8f1515;
}

.button-danger:disabled,
.button-danger[aria-disabled="true"] {
    border-color: #e4c7c4;
    background: #ead6d4;
    color: #8b6c69;
    cursor: not-allowed;
    opacity: 1;
}

@media (max-width: 1100px) {
    .automation-rule-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .automation-review-layout { grid-template-columns: 1fr; }
    .automation-preview-panel { position: static; }
}

@media (max-width: 680px) {
    .automation-rule-grid,
    .automation-action-grid { grid-template-columns: 1fr; }
    .automation-preview-panel iframe { min-height: 500px; }
}
