:root {
    --cc-primary: #146c63;
    --cc-primary-dark: #0f3f3b;
    --cc-secondary: #315f72;
    --cc-accent: #f2b84b;
    --cc-bg: #f4f7f6;
    --cc-surface: #ffffff;
    --cc-text: #152522;
    --cc-muted: #667773;
    --cc-border: #dbe5e2;
    --cc-shadow: 0 16px 40px rgba(16, 42, 38, 0.1);
    --bs-primary: var(--cc-primary);
    --bs-primary-rgb: 20, 108, 99;
}

html {
    min-height: 100%;
}

body {
    min-height: 100vh;
    padding-bottom: 60px;
    background: var(--cc-bg);
    color: var(--cc-text);
    font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
}

a {
    color: var(--cc-primary);
}

a:hover {
    color: var(--cc-primary-dark);
}

.btn-primary {
    --bs-btn-bg: var(--cc-primary);
    --bs-btn-border-color: var(--cc-primary);
    --bs-btn-hover-bg: var(--cc-primary-dark);
    --bs-btn-hover-border-color: var(--cc-primary-dark);
    --bs-btn-focus-shadow-rgb: 20, 108, 99;
}

.btn-outline-primary {
    --bs-btn-color: var(--cc-primary);
    --bs-btn-border-color: var(--cc-primary);
    --bs-btn-hover-bg: var(--cc-primary);
    --bs-btn-hover-border-color: var(--cc-primary);
    --bs-btn-focus-shadow-rgb: 20, 108, 99;
}

.form-control:focus,
.form-select:focus,
.btn:focus-visible,
.nav-link:focus-visible,
.dropdown-item:focus-visible {
    border-color: rgba(20, 108, 99, 0.7);
    box-shadow: 0 0 0 0.22rem rgba(20, 108, 99, 0.22);
    outline: 0;
}

.custom-container,
.app-page-shell {
    width: min(100% - 1rem, 1600px);
    max-width: none !important;
    margin-inline: auto;
}

.custom-container {
    margin-top: clamp(1rem, 2vw, 1.75rem) !important;
}

.app-navbar {
    position: sticky;
    top: 0;
    z-index: 1030;
    background: linear-gradient(135deg, var(--cc-primary-dark), var(--cc-primary));
    box-shadow: 0 10px 30px rgba(13, 48, 45, 0.22);
}

.app-navbar__inner {
    width: min(100% - 1rem, 1600px);
    margin-inline: auto;
    padding-block: 0.45rem;
}

.app-navbar__logo {
    width: 2.75rem;
    height: 2.75rem;
    object-fit: contain;
}

.app-navbar__brand-text {
    max-width: 13rem;
    color: #fff;
    font-weight: 750;
    letter-spacing: 0;
    line-height: 1.1;
    white-space: normal;
}

.app-navbar .navbar-toggler {
    border-color: rgba(255, 255, 255, 0.4);
    color: #fff;
}

.app-navbar .nav-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 2.5rem;
    border-radius: 999px;
    color: rgba(255, 255, 255, 0.84);
    line-height: 1;
    padding-inline: 0.8rem;
}

.app-navbar .nav-link:hover,
.app-navbar .nav-link:focus {
    color: #fff;
    background: rgba(255, 255, 255, 0.12);
}

.app-navbar .nav-link i {
    font-size: 1rem;
}

.app-navbar .dropdown-menu {
    border: 1px solid rgba(20, 108, 99, 0.12);
    border-radius: 0.75rem;
    box-shadow: var(--cc-shadow);
    padding: 0.45rem;
}

.app-navbar .dropdown-item {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    border-radius: 0.55rem;
    color: var(--cc-text);
    line-height: 1.2;
    padding: 0.65rem 0.75rem;
}

.app-navbar .dropdown-item i {
    width: 1.15rem;
    color: var(--cc-primary);
    text-align: center;
}

.app-navbar .dropdown-item.active,
.app-navbar .dropdown-item:active {
    background: var(--cc-primary);
    color: #fff;
}

.app-navbar .dropdown-item.active i,
.app-navbar .dropdown-item:active i {
    color: #fff;
}

#assignmentHoursNote {
    margin-left: -9rem;
}

#assignmentWorkedHours, #assignmentCleanerPayment, #assignmentPrice {
    padding: .375rem .5rem !important;
}

.client-details {
    width: 200%;
}

.week-day-dropzone {
    min-height: 400px;
    padding: 10px;
    background: rgba(0,0,0,0.02);
    border: 2px dashed transparent;
    transition: background 0.2s;
}

.extra-small {
    font-size: 0.75rem;
}

.dashboard-assignment-item {
    cursor: pointer;
    transition: transform 0.1s;
}

    .dashboard-assignment-item:hover {
        transform: translateY(-2px);
        box-shadow: 0 4px 8px rgba(0,0,0,0.1) !important;
    }

.auth-page {
    min-height: calc(100vh - 160px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
}

.auth-card {
    width: 100%;
    max-width: 420px;
}

.navbar-brand {
    font-weight: 600;
    letter-spacing: 0.02em;
}

.navbar-collapse-content {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
}

.navbar-nav .nav-link {
    font-weight: 500;
}

    .navbar-nav .nav-link.active {
        background-color: rgba(255, 255, 255, 0.25);
        border-radius: 0.5rem;
        color: #fff;
        font-weight: 700;
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }

.nav-item-form {
    width: 100%;
    display: flex;
}

    .nav-item-form button {
        font-weight: 600;
        width: 100%;
    }

.dropdown-menu .dropdown-item {
    transition: background-color 0.2s ease, padding-left 0.2s ease;
    font-weight: 500;
}

    .dropdown-menu .dropdown-item:hover {
        background-color: rgba(var(--bs-primary-rgb), 0.1);
        color: var(--bs-primary);
        padding-left: 1.25rem;
    }

    .dropdown-menu .dropdown-item.active {
        background-color: var(--bs-primary);
        color: #fff;
    }

@media (max-width: 991.98px) {
    .navbar .navbar-collapse {
        background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 0.95), rgba(var(--bs-primary-rgb), 0.85));
        border-radius: 0.75rem;
        margin-top: 1rem;
        padding: 1.25rem;
        box-shadow: 0 0.5rem 1.5rem rgba(15, 23, 42, 0.2);
    }

    .navbar .navbar-collapse-content {
        gap: 1.5rem;
    }

    .navbar .navbar-nav .nav-link,
    .navbar .navbar-nav .navbar-text {
        color: rgba(255, 255, 255, 0.9);
    }

    .navbar .navbar-collapse hr {
        border-color: rgba(255, 255, 255, 0.2);
    }

    .navbar .navbar-nav .nav-link:hover,
    .navbar .navbar-nav .nav-link:focus {
        color: #fff;
    }

    .navbar .navbar-nav .btn {
        width: 100%;
    }

        .navbar .navbar-nav .btn.btn-outline-light {
            border-color: rgba(255, 255, 255, 0.65);
        }
}

@media (max-width: 991.98px) {
    .app-navbar .navbar-collapse {
        background: rgba(8, 45, 41, 0.96);
        border: 1px solid rgba(255, 255, 255, 0.14);
        border-radius: 0.9rem;
        margin-top: 0.75rem;
        padding: 0.75rem;
        box-shadow: 0 18px 40px rgba(8, 45, 41, 0.28);
    }

    .app-navbar .navbar-nav {
        gap: 0.2rem;
    }

    .app-navbar .nav-link {
        display: flex;
        width: 100%;
        justify-content: flex-start;
        border-radius: 0.65rem;
        padding: 0.85rem 0.9rem;
    }

    .app-navbar .dropdown-menu {
        margin: 0.2rem 0 0.6rem;
        box-shadow: none;
    }

    .app-navbar__brand-text {
        max-width: 10rem;
        font-size: 0.95rem;
    }
}

@media (min-width: 992px) {
    .app-navbar .navbar-nav .nav-link.active {
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.18);
        box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
    }

    .app-navbar .navbar-nav {
        flex-wrap: wrap;
        row-gap: 0.35rem;
    }
}

@media (min-width: 992px) {
    .navbar-collapse-content {
        flex-direction: row;
        align-items: center;
        gap: 1.5rem;
    }

    .nav-item-form {
        width: auto;
        display: inline-flex;
    }

        .nav-item-form button {
            width: auto;
        }
}

.page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.75rem;
}

    .page-header .btn {
        white-space: nowrap;
    }

@media (max-width: 575.98px) {
    .page-header {
        flex-direction: column;
        align-items: stretch;
    }

        .page-header .btn {
            width: 100%;
        }
}

@media (max-width: 1380px) {
    .flex-lg-nowrap { /*from bootstrap*/
        flex-wrap: wrap !important;
    }
}

.card-table {
    background-color: #fff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0.75rem;
    box-shadow: 0 0.5rem 1.5rem rgba(15, 23, 42, 0.1);
    overflow: hidden;
    margin-bottom: 2rem;
}

    .card-table .table-responsive {
        border-radius: inherit;
    }

    .card-table .table {
        margin-bottom: 0;
        table-layout: fixed;
        width: 100%;
    }

    .card-table thead th {
        background-color: rgba(var(--bs-primary-rgb), 0.05);
        font-weight: 600;
        border-bottom-width: 1px;
    }

    .card-table .table th,
    .card-table .table td {
        white-space: normal;
        word-break: break-word;
    }

.quotations-table {
    min-width: 1180px;
    table-layout: fixed;
}

    .quotations-table .quotations-col-submitted {
        width: 9rem;
    }

    .quotations-table .quotations-col-name {
        width: 10rem;
    }

    .quotations-table .quotations-col-email {
        width: 14rem;
    }

    .quotations-table .quotations-col-phone {
        width: 8rem;
    }

    .quotations-table .quotations-col-preferred {
        width: 10rem;
    }

    .quotations-table .quotations-col-payment {
        width: 9rem;
    }

    .quotations-table .quotations-col-notes {
        width: 18rem;
    }

    .quotations-table .quotations-col-response {
        width: 8rem;
    }

    .quotations-table .quotations-col-responded {
        width: 9rem;
    }

    .quotations-table .quotations-col-actions {
        width: 7rem;
    }

    .quotations-table .quotation-date {
        white-space: normal;
        overflow-wrap: anywhere;
    }

.table-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-start;
}

    .table-actions > * {
        flex: 1 1 140px;
    }

    .table-actions form {
        margin: 0;
    }

    .table-actions .btn {
        width: 100%;
    }

@media (max-width: 768px) {
    .client-details {
        width: 100%;
    }
}

@media (min-width: 768px) {
    .table-actions {
        justify-content: flex-end;
    }

        .table-actions > * {
            flex: 0 0 auto;
        }

        .table-actions .btn {
            width: auto;
        }
}

.service-list .service-item {
    border-radius: 0.75rem;
    border: 1px solid rgba(15, 23, 42, 0.08);
    margin-bottom: 0.75rem;
    box-shadow: 0 0.25rem 0.75rem rgba(15, 23, 42, 0.06);
}

    .service-list .service-item:last-child {
        margin-bottom: 0;
    }

.service-dropzone {
    border: 2px dashed rgba(var(--bs-primary-rgb), 0.4);
    border-radius: 0.75rem;
    padding: 1.25rem;
    background-color: rgba(var(--bs-primary-rgb), 0.02);
    transition: border-color 0.2s ease, background-color 0.2s ease;
    min-height: 220px;
}

    .service-dropzone.drag-over {
        border-color: rgba(var(--bs-primary-rgb), 0.8);
        background-color: rgba(var(--bs-primary-rgb), 0.08);
    }

.dashboard-day-card {
    min-width: 10rem;
    max-width: 14.5rem;
    width: 100%;
    background: #f8f9fa;
    border-radius: 8px;
}

@media (max-width: 603px) {
    .dashboard-day-card {
        min-width: 14.5rem;
        max-width: 29.5rem;
        width: 100%;
    }
}

.dashboard-day-panel {
    border-radius: 0.75rem;
    border: 1px solid rgba(15, 23, 42, 0.12);
    background-color: #f8fafc;
    /*padding: 0.5rem;*/
    height: 100%;
}

.dashboard-day-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0.5rem;
    border-radius: 0.5rem;
    background: #ffffff;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
    margin-bottom: 0.5rem;
}

.dashboard-day-count {
    font-size: 0.8rem;
    font-weight: 600;
    color: #1f2937;
    background: rgba(15, 23, 42, 0.08);
    padding: 0.15rem 0.5rem;
    border-radius: 999px;
    white-space: nowrap;
}

.dashboard-day-empty {
    padding: 0.25rem 0.35rem;
}

.dashboard-resource-picker {
    border: 1px solid rgba(15, 23, 42, 0.12);
    border-radius: 0.75rem;
    overflow: hidden;
    background: #fff;
}

.dashboard-resource-picker.is-disabled {
    opacity: 0.65;
}

.dashboard-resource-picker__header,
.dashboard-resource-picker__row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 7rem;
    gap: 0.75rem;
    align-items: center;
}

.dashboard-resource-picker__header {
    padding: 0.7rem 0.9rem;
    background: #f8fafc;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.dashboard-resource-picker__body {
    max-height: 15rem;
    overflow-y: auto;
}

.dashboard-resource-picker__row {
    margin: 0;
    padding: 0.8rem 0.9rem;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    cursor: pointer;
}

.dashboard-resource-picker__row:last-child {
    border-bottom: 0;
}

.dashboard-resource-picker__name {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
    font-weight: 600;
}

.dashboard-resource-picker__name span:last-child {
    overflow: hidden;
    text-overflow: ellipsis;
}

.dashboard-resource-picker__availability {
    justify-self: end;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 700;
}

.dashboard-resource-picker__row.is-available .dashboard-resource-picker__availability {
    background: rgba(22, 163, 74, 0.12);
    color: #166534;
}

.dashboard-resource-picker__row.is-unavailable .dashboard-resource-picker__availability {
    background: rgba(220, 38, 38, 0.12);
    color: #991b1b;
}

.dashboard-team-groups {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.dashboard-team-group {
    border-radius: 0.6rem;
    padding: 0.35rem;
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
}

.dashboard-team-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.8rem;
    font-weight: 600;
    padding: 0.15rem 0.45rem;
    border-radius: 0.4rem;
    margin-bottom: 0.35rem;
    color: #111827;
}

.dashboard-team-label {
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.dashboard-team-count {
    font-weight: 700;
}

.team-color-muted .dashboard-team-header {
    background: rgba(148, 163, 184, 0.4);
    color: #334155;
}

.team-color-lilac .dashboard-team-header {
    background: rgba(167, 139, 250, 0.35);
    color: #4c1d95;
}

.team-color-amber .dashboard-team-header {
    background: rgba(251, 191, 36, 0.35);
    color: #92400e;
}

.team-color-teal .dashboard-team-header {
    background: rgba(45, 212, 191, 0.35);
    color: #115e59;
}

.team-color-blue .dashboard-team-header {
    background: rgba(96, 165, 250, 0.35);
    color: #1e3a8a;
}

.team-color-green .dashboard-team-header {
    background: rgba(74, 222, 128, 0.35);
    color: #166534;
}

.team-color-rose .dashboard-team-header {
    background: rgba(244, 114, 182, 0.35);
    color: #9d174d;
}

.dashboard-assignment-card {
    border-radius: 0.5rem;
    padding: 0.45rem;
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    margin-bottom: 0.35rem;
}

    .dashboard-assignment-card:last-child {
        margin-bottom: 0;
    }

.assignment-content {
    display: flex;
    flex-direction: column;
    min-width: 0;
    width: 100%;
}

.assignment-header {
    cursor: pointer;
    user-select: none;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    min-width: 0;
}

.assignment-header:hover .assignment-client-name {
    color: var(--bs-primary);
}

.assignment-details {
    display: none;
    width: 100%;
    border-top: 1px solid rgba(0, 0, 0, 0.05);
    padding-top: 0.5rem;
    margin-top: 0.25rem;
}

.dashboard-assignment-card.is-expanded .assignment-details {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.assignment-main {
    min-width: 0;
    flex: 1 1 auto;
}

.assignment-meta {
    text-align: right;
    flex-shrink: 0;
}

.assignment-actions {
    gap: 0.35rem;
}

.compact-assignment-button {
    padding: 0.35rem 0.5rem;
    font-size: 0.9rem;
    white-space: nowrap;
}

.assignment-header .bi-chevron-down {
    transition: transform 0.2s ease;
}

.is-expanded .assignment-header .bi-chevron-down {
    transform: rotate(180deg);
}

.assignment-client-name {
    display: block;
    max-width: 100%;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.service-row .btn {
    min-width: 2.25rem;
}

.cc-processing-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.25);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
}

.cc-processing-card {
    background: #fff;
    border-radius: 12px;
    padding: 18px 22px;
    box-shadow: 0 10px 30px rgba(0,0,0,.18);
    display: flex;
    align-items: center;
    gap: 12px;
}

.cc-processing-text {
    font-size: 14px;
}

/* Nested Dropdowns */
.dropdown-submenu {
    position: relative;
}

.dropdown-submenu .dropdown-menu {
    top: 0;
    left: 100%;
    margin-top: -1px;
}

@media (max-width: 991.98px) {
    .dropdown-submenu .dropdown-menu {
        position: static;
        margin-top: 0;
        margin-left: 1rem;
        border: none;
        background: rgba(255, 255, 255, 0.1);
        box-shadow: none;
    }
}

@media (min-width: 992px) {
    .dropdown-submenu:hover > .dropdown-menu {
        display: block;
    }
}

/* Radical workspace shell */
:root {
    --cc-ink: #101416;
    --cc-ink-2: #1d292d;
    --cc-canvas: #eef3f1;
    --cc-panel: #fbfcfb;
    --cc-panel-2: #f6f8f7;
    --cc-line: #d7e0dd;
    --cc-bright: #16a085;
    --cc-bright-dark: #0f6f65;
    --cc-warm: #ef8354;
    --cc-sky: #4b88a2;
    --cc-plum: #7d4e57;
    --cc-focus: 22, 160, 133;
    --cc-shadow-soft: 0 18px 45px rgba(16, 20, 22, 0.08);
    --cc-shadow-float: 0 24px 70px rgba(16, 20, 22, 0.16);
    --bs-primary: var(--cc-bright-dark);
    --bs-primary-rgb: 15, 111, 101;
}

.app-body {
    min-height: 100vh;
    padding-bottom: 0;
    background:
        linear-gradient(90deg, rgba(16, 20, 22, 0.04) 1px, transparent 1px),
        linear-gradient(0deg, rgba(16, 20, 22, 0.035) 1px, transparent 1px),
        var(--cc-canvas);
    background-size: 28px 28px;
    color: var(--cc-ink);
}

.app-shell {
    min-height: 100vh;
}

.app-shell__sidebar {
    position: sticky;
    top: 0;
    z-index: 1040;
}

.app-shell__workspace {
    min-width: 0;
}

.app-navbar {
    background: var(--cc-ink);
    box-shadow: var(--cc-shadow-float);
}

.app-navbar__inner {
    width: 100%;
    max-width: none;
    padding: 0.75rem;
}

.app-navbar .navbar-brand {
    min-width: 0;
    padding: 0.25rem;
    border-radius: 8px;
}

.app-navbar__logo {
    width: 2.45rem;
    height: 2.45rem;
    padding: 0.25rem;
    border-radius: 8px;
    background: #fff;
}

.app-navbar__brand-text {
    max-width: 11rem;
    color: #fff;
    font-size: 0.95rem;
    font-weight: 800;
}

.app-navbar .navbar-toggler {
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 8px;
}

.app-navbar .navbar-toggler:focus {
    box-shadow: 0 0 0 0.2rem rgba(var(--cc-focus), 0.32);
}

.navbar-collapse-content {
    width: 100%;
}

.app-navbar .navbar-nav {
    gap: 0.35rem;
}

.app-navbar .nav-link {
    position: relative;
    display: flex;
    width: 100%;
    min-height: 2.85rem;
    justify-content: flex-start;
    gap: 0.75rem;
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.72);
    padding: 0.75rem 0.8rem;
}

.app-navbar .nav-link i {
    display: inline-grid;
    width: 1.55rem;
    height: 1.55rem;
    place-items: center;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.08);
    color: #b8f4e7;
}

.app-navbar .nav-link:hover,
.app-navbar .nav-link:focus {
    color: #fff;
    background: rgba(255, 255, 255, 0.08);
}

.app-navbar .navbar-nav .nav-link.active {
    background: #fff;
    color: var(--cc-ink);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.24);
}

.app-navbar .navbar-nav .nav-link.active::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 0.28rem;
    border-radius: 8px 0 0 8px;
    background: var(--cc-warm);
}

.app-navbar .navbar-nav .nav-link.active i {
    background: rgba(var(--cc-focus), 0.14);
    color: var(--cc-bright-dark);
}

.app-navbar .dropdown-menu {
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: var(--cc-panel);
    box-shadow: var(--cc-shadow-float);
    padding: 0.4rem;
}

.app-navbar .dropdown-item {
    border-radius: 6px;
    color: var(--cc-ink-2);
}

.app-navbar .dropdown-item i {
    color: var(--cc-sky);
}

.app-navbar .dropdown-item:hover {
    background: rgba(75, 136, 162, 0.11);
    color: var(--cc-ink);
    padding-left: 0.75rem;
}

.app-navbar .dropdown-item.active,
.app-navbar .dropdown-item:active {
    background: var(--cc-bright-dark);
    color: #fff;
}

.app-navbar .btn-outline-light {
    border-color: rgba(255, 255, 255, 0.22);
    color: rgba(255, 255, 255, 0.82);
    border-radius: 8px;
}

.app-navbar .btn-outline-light:hover,
.app-navbar .btn-outline-light.active {
    background: var(--cc-warm);
    border-color: var(--cc-warm);
    color: var(--cc-ink);
}

.app-topbar {
    display: none;
}

.custom-container,
.app-page-shell {
    width: min(100% - 1.5rem, 1720px);
}

.custom-container {
    margin-top: 0 !important;
    padding-block: clamp(1rem, 2vw, 1.5rem) 2rem;
}

.app-main {
    min-height: calc(100vh - 8rem);
}

.footer {
    border-top: 1px solid var(--cc-line);
    padding: 1rem 0;
    background: rgba(251, 252, 251, 0.82);
}

.page-header {
    position: relative;
    align-items: flex-end;
    border-bottom: 1px solid var(--cc-line);
    margin-bottom: 1.25rem !important;
    padding-bottom: 1rem;
}

.page-header h1 {
    font-size: clamp(1.7rem, 2.2vw, 2.5rem);
    font-weight: 850;
    letter-spacing: 0;
}

.page-header p {
    max-width: 56rem;
}

.card,
.card-table,
.modal-content,
.service-list .service-item {
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: rgba(251, 252, 251, 0.94);
    box-shadow: var(--cc-shadow-soft);
}

.card-header,
.card-footer {
    background: rgba(246, 248, 247, 0.86);
}

.btn {
    border-radius: 8px;
    font-weight: 650;
}

.btn-primary {
    --bs-btn-bg: var(--cc-ink);
    --bs-btn-border-color: var(--cc-ink);
    --bs-btn-hover-bg: var(--cc-bright-dark);
    --bs-btn-hover-border-color: var(--cc-bright-dark);
    --bs-btn-focus-shadow-rgb: var(--cc-focus);
}

.btn-outline-primary {
    --bs-btn-color: var(--cc-bright-dark);
    --bs-btn-border-color: rgba(var(--cc-focus), 0.42);
    --bs-btn-hover-bg: var(--cc-bright-dark);
    --bs-btn-hover-border-color: var(--cc-bright-dark);
    --bs-btn-focus-shadow-rgb: var(--cc-focus);
}

.form-control,
.form-select {
    border-color: var(--cc-line);
    border-radius: 8px;
    background-color: #fff;
}

.form-control:focus,
.form-select:focus,
.btn:focus-visible,
.nav-link:focus-visible,
.dropdown-item:focus-visible {
    border-color: rgba(var(--cc-focus), 0.7);
    box-shadow: 0 0 0 0.22rem rgba(var(--cc-focus), 0.22);
}

.table {
    --bs-table-bg: transparent;
}

.card-table thead th {
    background: #101416;
    color: #fff;
    border-bottom: 0;
}

.card-table .table tbody tr:hover {
    background: rgba(22, 160, 133, 0.06);
}

#weekly-grid {
    display: grid !important;
    grid-template-columns: repeat(7, minmax(13rem, 1fr));
    gap: 0.75rem;
    align-items: stretch !important;
    justify-content: stretch !important;
    overflow-x: auto;
    padding: 0.25rem 0.25rem 0.75rem;
    scroll-snap-type: x proximity;
}

.dashboard-day-card {
    min-width: 13rem;
    max-width: none;
    scroll-snap-align: start;
}

.dashboard-day-panel {
    display: flex;
    min-height: 34rem;
    flex-direction: column;
    border: 1px solid rgba(16, 20, 22, 0.1);
    border-radius: 8px;
    background: var(--cc-panel);
    box-shadow: var(--cc-shadow-soft);
    overflow: hidden;
}

.dashboard-day-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    border-radius: 0;
    border-bottom: 1px solid var(--cc-line);
    background: #fff;
    box-shadow: none;
    margin-bottom: 0;
    padding: 0.8rem;
}

.dashboard-day-count {
    order: 2;
    background: var(--cc-ink);
    color: #fff;
    border-radius: 999px;
}

.compact-assignment-button {
    width: calc(100% - 1rem) !important;
    margin: 0.75rem 0.5rem 0 !important;
}

.week-day-dropzone {
    display: flex;
    min-height: 26rem;
    flex: 1;
    flex-direction: column;
    border: 0;
    border-top: 1px dashed rgba(16, 20, 22, 0.12);
    background:
        linear-gradient(180deg, rgba(22, 160, 133, 0.05), rgba(239, 131, 84, 0.04)),
        var(--cc-panel-2);
    padding: 0.6rem;
}

.dashboard-day-empty {
    border: 1px dashed rgba(16, 20, 22, 0.2);
    border-radius: 8px;
    color: #5f6c70 !important;
    padding: 0.65rem;
    text-align: center;
}

.dashboard-team-groups {
    gap: 0.65rem;
}

.dashboard-team-group,
.dashboard-assignment-card {
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: #fff;
}

.dashboard-assignment-card {
    position: relative;
    padding: 0.7rem;
    box-shadow: 0 10px 24px rgba(16, 20, 22, 0.08);
}

.dashboard-assignment-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 0.25rem;
    border-radius: 8px 0 0 8px;
    background: var(--cc-sky);
}

.dashboard-assignment-card:nth-child(3n + 1)::before {
    background: var(--cc-bright);
}

.dashboard-assignment-card:nth-child(3n + 2)::before {
    background: var(--cc-warm);
}

.assignment-header {
    align-items: flex-start;
}

.assignment-header .badge {
    border-radius: 6px;
}

.assignment-client-name {
    white-space: normal;
    line-height: 1.2;
}

.dashboard-assignment-card.is-expanded .assignment-details {
    border-top-color: var(--cc-line);
}

@media (min-width: 992px) {
    .app-shell {
        display: grid;
        grid-template-columns: 18.5rem minmax(0, 1fr);
    }

    .app-shell__sidebar {
        height: 100vh;
        overflow-y: auto;
        background: var(--cc-ink);
    }

    .app-navbar {
        min-height: 100vh;
        align-items: flex-start;
        box-shadow: none;
    }

    .app-navbar__inner {
        display: flex;
        min-height: 100vh;
        flex-direction: column;
        align-items: stretch;
        padding: 1rem;
    }

    .app-navbar .navbar-brand {
        margin-bottom: 1rem;
    }

    .app-navbar .navbar-collapse {
        display: flex !important;
        flex: 1;
        align-items: stretch;
    }

    .navbar-collapse-content {
        min-height: 0;
        flex-direction: column;
        align-items: stretch;
        gap: 1rem;
    }

    .app-navbar .navbar-nav {
        flex-direction: column !important;
        align-items: stretch !important;
        flex-wrap: nowrap;
    }

    .app-navbar .dropdown-menu {
        position: static !important;
        transform: none !important;
        width: 100%;
        margin: 0.25rem 0 0.35rem;
        box-shadow: none;
    }

    .app-navbar .dropdown-submenu .dropdown-menu {
        margin-left: 0.65rem;
        border-left: 2px solid rgba(var(--cc-focus), 0.25);
    }

    .app-navbar .ms-lg-auto {
        margin-top: auto !important;
        margin-left: 0 !important;
    }

    .app-topbar {
        position: sticky;
        top: 0;
        z-index: 1020;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr) auto;
        align-items: center;
        gap: 1rem;
        min-height: 4.25rem;
        padding: 0.85rem clamp(1rem, 2vw, 1.5rem);
        border-bottom: 1px solid rgba(16, 20, 22, 0.08);
        background: rgba(238, 243, 241, 0.88);
        backdrop-filter: blur(16px);
    }

    .app-topbar__eyebrow {
        border: 1px solid rgba(16, 20, 22, 0.12);
        border-radius: 999px;
        background: #fff;
        color: #526166;
        font-size: 0.75rem;
        font-weight: 800;
        padding: 0.35rem 0.65rem;
        text-transform: uppercase;
    }

    .app-topbar__title {
        min-width: 0;
        overflow: hidden;
        color: var(--cc-ink);
        font-size: 1.2rem;
        font-weight: 850;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .app-topbar__status {
        display: inline-flex;
        align-items: center;
        gap: 0.45rem;
        border: 1px solid rgba(22, 160, 133, 0.22);
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.82);
        color: var(--cc-bright-dark);
        font-size: 0.85rem;
        font-weight: 750;
        padding: 0.45rem 0.75rem;
    }

    .app-topbar__status-dot {
        width: 0.55rem;
        height: 0.55rem;
        border-radius: 50%;
        background: var(--cc-bright);
        box-shadow: 0 0 0 0.25rem rgba(22, 160, 133, 0.14);
    }
}

@media (max-width: 991.98px) {
    .app-navbar .navbar-collapse {
        background: var(--cc-ink);
        border: 1px solid rgba(255, 255, 255, 0.12);
        border-radius: 8px;
        box-shadow: var(--cc-shadow-float);
    }

    .app-navbar .dropdown-menu {
        background: #fff;
    }

    #weekly-grid {
        grid-template-columns: repeat(7, minmax(15rem, 1fr));
    }
}

@media (max-width: 603px) {
    .dashboard-day-card {
        min-width: 15rem;
        max-width: none;
    }
}

/* Dashboard command center */
.dashboard-command-center {
    position: relative;
    display: grid;
    grid-template-columns: minmax(18rem, 1fr) minmax(28rem, 0.95fr);
    gap: clamp(1rem, 2vw, 1.5rem);
    margin-bottom: 1rem;
    overflow: hidden;
    border: 1px solid rgba(16, 20, 22, 0.1);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(16, 20, 22, 0.96), rgba(29, 41, 45, 0.94)),
        #101416;
    box-shadow: var(--cc-shadow-float);
}

.dashboard-command-center::after {
    content: "";
    position: absolute;
    inset: 0 0 0 auto;
    width: 38%;
    background:
        linear-gradient(135deg, transparent 0 30%, rgba(239, 131, 84, 0.16) 30% 44%, transparent 44% 58%, rgba(22, 160, 133, 0.16) 58% 72%, transparent 72%),
        linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.06));
    pointer-events: none;
}

.dashboard-command-center__copy {
    position: relative;
    z-index: 1;
    display: flex;
    min-height: 13rem;
    flex-direction: column;
    justify-content: flex-end;
    padding: clamp(1.15rem, 2.4vw, 2rem);
}

.dashboard-command-center__kicker,
.dashboard-board-shell__kicker {
    color: #b8f4e7;
    font-size: 0.75rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.dashboard-command-center h1 {
    max-width: 38rem;
    margin: 0.3rem 0;
    color: #fff;
    font-size: clamp(2.2rem, 5vw, 4.7rem);
    font-weight: 900;
    letter-spacing: 0;
    line-height: 0.95;
}

.dashboard-command-center p {
    max-width: 42rem;
    margin: 0;
    color: rgba(255, 255, 255, 0.72);
    font-size: 1rem;
}

.dashboard-command-center__metrics {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.65rem;
    align-content: end;
    padding: clamp(1rem, 2vw, 1.4rem);
}

.dashboard-metric {
    min-height: 6rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.09);
    color: #fff;
    padding: 0.85rem;
    backdrop-filter: blur(14px);
}

.dashboard-metric span {
    display: block;
    color: rgba(255, 255, 255, 0.68);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.dashboard-metric strong {
    display: block;
    margin-top: 0.45rem;
    font-size: clamp(1.7rem, 3vw, 2.7rem);
    font-weight: 900;
    line-height: 1;
}

.dashboard-metric--dark {
    background: #fff;
    color: var(--cc-ink);
}

.dashboard-metric--dark span {
    color: #526166;
}

.dashboard-metric--accent {
    border-color: rgba(239, 131, 84, 0.46);
    background: rgba(239, 131, 84, 0.22);
}

.dashboard-metric--money {
    border-color: rgba(22, 160, 133, 0.46);
    background: rgba(22, 160, 133, 0.22);
}

.dashboard-control-strip {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.75rem;
    align-items: stretch;
    margin-bottom: 1rem;
}

.dashboard-control-strip__form {
    /*display: flex;*/
    gap: 0.75rem;
    align-items: end;
    min-width: 0;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: rgba(251, 252, 251, 0.92);
    box-shadow: var(--cc-shadow-soft);
    padding: 0.75rem;
}

.dashboard-control-strip__fields {
    display: grid;
    grid-template-columns: repeat(3, minmax(11rem, 1fr));
    gap: 0.65rem;
    min-width: 0;
    flex: 1 1 auto;
}

.dashboard-control-field {
    min-width: 0;
}

.dashboard-control-field label {
    color: #526166;
    font-size: 0.75rem;
    font-weight: 800;
    text-transform: uppercase;
}

.dashboard-week-nav {
    display: grid;
    grid-template-columns: auto auto auto;
    gap: 1.45rem;
}

.dashboard-week-nav__button,
.dashboard-week-nav__load {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-height: 2.55rem;
    white-space: nowrap;
}

.dashboard-period-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    max-width: 18rem;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: #fff;
    color: #526166;
    box-shadow: var(--cc-shadow-soft);
    padding: 0.75rem 0.9rem;
}

.dashboard-period-pill [data-week-range-values] {
    color: var(--cc-ink);
    font-weight: 700;
}

.dashboard-board-shell {
    border: 1px solid rgba(16, 20, 22, 0.1);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(246, 248, 247, 0.92)),
        var(--cc-panel-2);
    box-shadow: var(--cc-shadow-float);
    padding: clamp(0.75rem, 1.7vw, 1.2rem);
}

.dashboard-board-shell__header {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.9rem;
    border-bottom: 1px solid rgba(16, 20, 22, 0.09);
    padding-bottom: 0.85rem;
}

.dashboard-board-shell__kicker {
    color: var(--cc-bright-dark);
}

.dashboard-board-shell h2 {
    margin: 0.15rem 0;
    color: var(--cc-ink);
    font-size: clamp(1.45rem, 2vw, 2.1rem);
    font-weight: 900;
}

.dashboard-board-shell p {
    max-width: 52rem;
    margin: 0;
    color: #5f6c70;
}

.dashboard-board-shell__legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    justify-content: flex-end;
}

.dashboard-board-shell__legend > span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 999px;
    background: #fff;
    color: #526166;
    font-size: 0.78rem;
    font-weight: 800;
    padding: 0.38rem 0.55rem;
}

.dashboard-legend-dot {
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background: var(--cc-sky);
}

.dashboard-legend-dot--open {
    background: #2fb344;
}

.dashboard-legend-dot--active {
    background: #f2b84b;
}

.dashboard-legend-dot--done {
    background: var(--cc-bright-dark);
}

.dashboard-board-shell #weekly-grid {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 14rem), 1fr));
    gap: 0.85rem;
    margin: 0;
    padding: 0.15rem 0.1rem 0.9rem;
    overflow-x: visible;
    scroll-snap-type: none;
}

.dashboard-board-shell .dashboard-day-card {
    min-width: 0;
    width: 100%;
}

.dashboard-board-shell .dashboard-day-panel {
    min-height: 38rem;
    border-color: rgba(16, 20, 22, 0.12);
    background: #fff;
}

.dashboard-day-card--today .dashboard-day-panel {
    border-color: rgba(239, 131, 84, 0.7);
    box-shadow: 0 0 0 3px rgba(239, 131, 84, 0.14), var(--cc-shadow-soft);
}

.dashboard-board-shell .dashboard-day-header {
    grid-template-columns: minmax(0, 1fr) auto;
    min-height: 6.25rem;
    background:
        linear-gradient(135deg, #fff, rgba(22, 160, 133, 0.08));
}

.dashboard-day-name {
    color: var(--cc-ink);
    font-size: 1rem;
    font-weight: 900;
    text-transform: capitalize;
}

.dashboard-day-date {
    display: flex;
    align-items: baseline;
    gap: 0.35rem;
    margin-top: 0.15rem;
    color: #5f6c70;
}

.dashboard-day-date span {
    font-size: 0.75rem;
    font-weight: 850;
    text-transform: uppercase;
}

.dashboard-day-date strong {
    color: var(--cc-ink);
    font-size: 2.4rem;
    font-weight: 950;
    line-height: 1;
}

.dashboard-day-stats {
    display: grid;
    gap: 0.35rem;
    justify-items: end;
}

.dashboard-board-shell .dashboard-day-count,
.dashboard-day-hours {
    border-radius: 999px;
    padding: 0.25rem 0.55rem;
    font-size: 0.75rem;
    font-weight: 850;
}

.dashboard-day-hours {
    background: rgba(16, 20, 22, 0.07);
    color: var(--cc-ink);
}

.dashboard-board-shell .week-day-dropzone {
    min-height: 30rem;
    background:
        linear-gradient(180deg, rgba(16, 20, 22, 0.035), rgba(16, 20, 22, 0.015)),
        var(--cc-panel-2);
}

.dashboard-board-shell .dashboard-day-empty {
    background: rgba(255, 255, 255, 0.68);
}

.dashboard-board-shell .dashboard-assignment-card {
    border-color: rgba(16, 20, 22, 0.1);
    padding: 0.75rem 0.75rem 0.75rem 0.9rem;
}

.dashboard-board-shell .dashboard-assignment-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 32px rgba(16, 20, 22, 0.12);
}

.dashboard-board-shell .assignment-header {
    gap: 0.55rem;
}

.dashboard-board-shell .assignment-header .badge {
    background: var(--cc-ink) !important;
}

.dashboard-board-shell .assignment-client-name {
    font-size: 0.95rem;
    font-weight: 850 !important;
}

.dashboard-board-empty {
    margin: 1rem 0 0;
}

@media (max-width: 1300px) {
    .dashboard-command-center,
    .dashboard-control-strip {
        grid-template-columns: 1fr;
    }

    .dashboard-period-pill {
        max-width: none;
    }
}

@media (max-width: 991.98px) {
    .dashboard-command-center {
        grid-template-columns: 1fr;
    }

    .dashboard-command-center__metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .dashboard-control-strip__form,
    .dashboard-board-shell__header {
        align-items: stretch;
        flex-direction: column;
    }

    .dashboard-control-strip__fields {
        grid-template-columns: 1fr;
    }

    .dashboard-week-nav {
        grid-template-columns: 1fr;
    }

    .dashboard-board-shell__legend {
        justify-content: flex-start;
    }
}

@media (max-width: 575.98px) {
    .dashboard-command-center__metrics {
        grid-template-columns: 1fr;
    }

    .dashboard-command-center__copy {
        min-height: 11rem;
    }

    .dashboard-period-pill {
        align-items: flex-start;
        flex-direction: column;
    }
}

/* Services financial cockpit */
.services-workspace {
    display: grid;
    gap: 1rem;
}

.services-command-center {
    position: relative;
    display: grid;
    grid-template-columns: minmax(18rem, 1fr) minmax(28rem, 0.95fr);
    gap: clamp(1rem, 2vw, 1.5rem);
    overflow: hidden;
    border: 1px solid rgba(16, 20, 22, 0.1);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(16, 20, 22, 0.97), rgba(49, 95, 114, 0.9)),
        var(--cc-ink);
    box-shadow: var(--cc-shadow-float);
}

.services-command-center::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(120deg, transparent 0 48%, rgba(239, 131, 84, 0.14) 48% 57%, transparent 57%),
        linear-gradient(40deg, transparent 0 64%, rgba(22, 160, 133, 0.14) 64% 72%, transparent 72%);
    pointer-events: none;
}

.services-command-center__copy,
.services-command-center__metrics {
    position: relative;
    z-index: 1;
}

.services-command-center__copy {
    display: flex;
    min-height: 13rem;
    flex-direction: column;
    justify-content: flex-end;
    padding: clamp(1.15rem, 2.4vw, 2rem);
}

.services-command-center__kicker,
.services-ledger-shell__kicker {
    color: #b8f4e7;
    font-size: 0.75rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.services-command-center h1 {
    max-width: 40rem;
    margin: 0.3rem 0;
    color: #fff;
    font-size: clamp(2rem, 4.5vw, 4.3rem);
    font-weight: 900;
    letter-spacing: 0;
    line-height: 0.98;
}

.services-command-center p {
    max-width: 43rem;
    margin: 0;
    color: rgba(255, 255, 255, 0.72);
}

.services-command-center__metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.65rem;
    align-content: end;
    padding: clamp(1rem, 2vw, 1.4rem);
}

.services-metric {
    min-height: 6rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.09);
    color: #fff;
    padding: 0.85rem;
    backdrop-filter: blur(14px);
}

.services-metric span {
    display: block;
    color: rgba(255, 255, 255, 0.68);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.services-metric strong {
    display: block;
    margin-top: 0.45rem;
    font-size: clamp(1.55rem, 2.6vw, 2.35rem);
    font-weight: 900;
    line-height: 1;
}

.services-metric--dark {
    background: #fff;
    color: var(--cc-ink);
}

.services-metric--dark span {
    color: #526166;
}

.services-metric--income,
.services-metric--profit {
    border-color: rgba(22, 160, 133, 0.46);
    background: rgba(22, 160, 133, 0.22);
}

.services-metric--cost {
    border-color: rgba(239, 131, 84, 0.46);
    background: rgba(239, 131, 84, 0.2);
}

.services-metric--loss {
    border-color: rgba(220, 53, 69, 0.46);
    background: rgba(220, 53, 69, 0.2);
}

.services-control-strip {
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: rgba(251, 252, 251, 0.92);
    box-shadow: var(--cc-shadow-soft);
    padding: 0.75rem;
}

.services-control-strip__form {
    display: flex;
    gap: 0.75rem;
    align-items: end;
}

.services-control-strip__fields {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
    gap: 0.65rem;
    min-width: 0;
    flex: 1 1 auto;
}

.services-control-field {
    min-width: 0;
}

.services-control-field label {
    color: #526166;
    font-size: 0.75rem;
    font-weight: 800;
    text-transform: uppercase;
}

.services-control-strip__submit {
    min-height: 2.55rem;
    min-width: 8.5rem;
}

.services-ledger-shell {
    border: 1px solid rgba(16, 20, 22, 0.1);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(246, 248, 247, 0.92)),
        var(--cc-panel-2);
    box-shadow: var(--cc-shadow-float);
    padding: clamp(0.75rem, 1.7vw, 1.2rem);
}

.services-ledger-shell__header {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.9rem;
    border-bottom: 1px solid rgba(16, 20, 22, 0.09);
    padding-bottom: 0.85rem;
}

.services-ledger-shell__kicker {
    color: var(--cc-bright-dark);
}

.services-ledger-shell h2 {
    margin: 0.15rem 0 0;
    color: var(--cc-ink);
    font-size: clamp(1.45rem, 2vw, 2.1rem);
    font-weight: 900;
}

.services-ledger-shell__count {
    display: inline-grid;
    min-width: 5.25rem;
    justify-items: center;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: #fff;
    padding: 0.55rem 0.75rem;
}

.services-ledger-shell__count strong {
    font-size: 1.45rem;
    font-weight: 900;
    line-height: 1;
}

.services-ledger-shell__count span {
    color: #526166;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.services-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 27rem), 1fr));
    gap: 0.85rem;
}

.services-ledger-card {
    display: grid;
    gap: 0.85rem;
    border: 1px solid rgba(16, 20, 22, 0.09);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--cc-shadow-soft);
    padding: 0.85rem;
}

.services-ledger-card__top {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.8rem;
    align-items: center;
}

.services-date-block {
    display: grid;
    min-width: 4.4rem;
    justify-items: center;
    border-radius: 8px;
    background: var(--cc-ink);
    color: #fff;
    padding: 0.55rem;
}

.services-date-block span,
.services-date-block small {
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.7rem;
    font-weight: 850;
    text-transform: uppercase;
}

.services-date-block strong {
    font-size: 2rem;
    font-weight: 950;
    line-height: 1;
}

.services-ledger-card__identity {
    min-width: 0;
}

.services-ledger-card__identity h3 {
    margin: 0 0 0.35rem;
    color: var(--cc-ink);
    font-size: 1.1rem;
    font-weight: 900;
    line-height: 1.15;
}

.services-status {
    display: inline-flex;
    border-radius: 999px;
    color: #fff;
    font-size: 0.75rem;
    font-weight: 850;
    padding: 0.25rem 0.55rem;
}

.services-status--completed {
    background: var(--cc-bright-dark);
}

.services-status--active {
    background: var(--cc-sky);
}

.services-status--cancelled {
    background: #b02a37;
}

.services-status--closed {
    background: #5f6c70;
}

.services-status--open {
    background: var(--cc-warm);
    color: var(--cc-ink);
}

.services-money-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.services-money-grid > div {
    border: 1px solid rgba(16, 20, 22, 0.07);
    border-radius: 8px;
    background: rgba(246, 248, 247, 0.75);
    padding: 0.65rem;
}

.services-money-grid span {
    display: block;
    color: #5f6c70;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.services-money-grid strong {
    display: block;
    margin-top: 0.2rem;
    color: var(--cc-ink);
    font-size: 1.05rem;
    font-weight: 900;
}

.services-money-grid small {
    display: block;
    margin-top: 0.15rem;
    color: #69787d;
}

.services-money-grid__margin {
    background: #fff !important;
}

.services-money--positive {
    color: var(--cc-bright-dark) !important;
}

.services-money--negative {
    color: #b02a37 !important;
}

.services-cleaner-row {
    border-top: 1px solid rgba(16, 20, 22, 0.08);
    padding-top: 0.75rem;
}

.services-cleaner-row__label {
    display: block;
    margin-bottom: 0.45rem;
    color: #526166;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.services-cleaner-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.services-cleaner-list > span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border-radius: 999px;
    background: rgba(75, 136, 162, 0.11);
    color: var(--cc-ink);
    font-size: 0.78rem;
    font-weight: 750;
    padding: 0.32rem 0.55rem;
}

.services-cleaner-list strong {
    color: var(--cc-sky);
}

.services-ledger-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-end;
}

.services-empty-state {
    border: 1px dashed rgba(16, 20, 22, 0.16);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.72);
    color: #5f6c70;
    padding: 2rem;
    text-align: center;
}

@media (max-width: 1300px) {
    .services-command-center {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    .services-command-center__metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .services-control-strip__form,
    .services-ledger-shell__header {
        align-items: stretch;
        flex-direction: column;
    }

    .services-control-strip__submit {
        width: 100%;
    }
}

@media (max-width: 575.98px) {
    .services-command-center__metrics,
    .services-money-grid {
        grid-template-columns: 1fr;
    }

    .services-ledger-card__actions .btn {
        width: 100%;
    }
}

/* Receivings and Payments operational boards */
.receivings-workspace,
.payments-workspace {
    display: grid;
    gap: 1rem;
}

.receivings-command-center,
.payments-command-center {
    display: grid;
    grid-template-columns: minmax(18rem, 0.85fr) minmax(28rem, 1.15fr);
    gap: 1rem;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(246, 248, 247, 0.9)),
        radial-gradient(circle at 92% 12%, rgba(246, 184, 67, 0.24), transparent 34%);
    box-shadow: var(--cc-shadow-soft);
    padding: clamp(1rem, 2vw, 1.45rem);
}

.payments-command-center {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(246, 248, 247, 0.9)),
        radial-gradient(circle at 92% 12%, rgba(75, 136, 162, 0.18), transparent 36%);
}

.receivings-command-center__copy,
.payments-command-center__copy {
    align-content: center;
    display: grid;
}

.receivings-command-center__kicker,
.payments-command-center__kicker,
.receivings-ledger-shell__kicker,
.payments-ledger-shell__kicker {
    color: var(--cc-bright-dark);
    font-size: 0.75rem;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.receivings-command-center h1,
.payments-command-center h1 {
    margin: 0.2rem 0 0.45rem;
    color: var(--cc-ink);
    font-size: clamp(2rem, 4vw, 4rem);
    font-weight: 950;
    line-height: 0.95;
}

.receivings-command-center p,
.payments-command-center p {
    margin: 0;
    max-width: 42rem;
    color: #526166;
    font-size: 1rem;
}

.receivings-command-center__metrics,
.payments-command-center__metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.65rem;
}

.receivings-metric,
.payments-metric {
    display: grid;
    align-content: space-between;
    min-height: 6.4rem;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: #fff;
    padding: 0.85rem;
}

.receivings-metric span,
.payments-metric span {
    color: #5f6c70;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.receivings-metric strong,
.payments-metric strong {
    color: var(--cc-ink);
    font-size: clamp(1.35rem, 2vw, 2rem);
    font-weight: 950;
    line-height: 1;
}

.receivings-metric--dark,
.payments-metric--dark {
    background: var(--cc-ink);
}

.receivings-metric--dark span,
.receivings-metric--dark strong,
.payments-metric--dark span,
.payments-metric--dark strong {
    color: #fff;
}

.receivings-metric--income,
.payments-metric--due {
    background: rgba(246, 184, 67, 0.18);
}

.receivings-metric--paid,
.payments-metric--paid {
    background: rgba(49, 169, 114, 0.14);
}

.receivings-metric--balance,
.payments-metric--balance {
    background: rgba(176, 42, 55, 0.1);
}

.receivings-control-strip,
.payments-control-strip,
.receivings-ledger-shell,
.payments-ledger-shell {
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.86);
    box-shadow: var(--cc-shadow-soft);
    padding: 1rem;
}

.receivings-control-strip__form,
.payments-control-strip__form {
    display: flex;
    align-items: end;
    gap: 0.9rem;
}

.receivings-control-strip__fields,
.payments-control-strip__fields {
    display: grid;
    flex: 1 1 auto;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 12rem), 1fr));
    gap: 0.8rem;
}

.receivings-control-field,
.payments-control-field {
    min-width: 0;
}

.receivings-control-field--check {
    align-self: end;
    padding-bottom: 0.45rem;
}

.receivings-control-strip .form-label,
.payments-control-strip .form-label {
    color: #526166;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.receivings-tabs {
    border: 0;
    display: flex;
    gap: 0.45rem;
}

.receivings-tabs .nav-link {
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.74);
    color: #526166;
    font-weight: 850;
}

.receivings-tabs .nav-link.active {
    background: var(--cc-ink);
    color: #fff;
}

.receivings-section-toolbar,
.payments-ledger-shell__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.9rem;
    border-bottom: 1px solid rgba(16, 20, 22, 0.08);
    padding-bottom: 0.85rem;
}

.receivings-select-all {
    align-items: center;
    display: inline-flex;
    gap: 0.5rem;
    color: #526166;
    font-weight: 850;
}

.payments-ledger-shell h2 {
    margin: 0.15rem 0 0;
    color: var(--cc-ink);
    font-size: clamp(1.45rem, 2vw, 2.1rem);
    font-weight: 900;
}

.payments-ledger-shell__count {
    display: inline-grid;
    min-width: 5.25rem;
    justify-items: center;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: #fff;
    padding: 0.55rem 0.75rem;
}

.payments-ledger-shell__count strong {
    font-size: 1.45rem;
    font-weight: 900;
    line-height: 1;
}

.payments-ledger-shell__count span {
    color: #526166;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.receivings-card-grid,
.payments-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 24rem), 1fr));
    gap: 0.85rem;
}

.receivings-card,
.payments-card {
    display: grid;
    gap: 0.85rem;
    min-width: 0;
    border: 1px solid rgba(16, 20, 22, 0.09);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--cc-shadow-soft);
    padding: 0.85rem;
}

.receivings-card--partial {
    border-color: rgba(246, 184, 67, 0.5);
}

.receivings-card__top,
.payments-card__top {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.8rem;
    align-items: center;
}

.receivings-card__top--selectable {
    grid-template-columns: auto auto minmax(0, 1fr);
}

.receivings-card__select {
    align-self: start;
    padding-top: 0.4rem;
}

.receivings-date-block,
.payments-date-block {
    display: grid;
    min-width: 4.4rem;
    justify-items: center;
    border-radius: 8px;
    background: var(--cc-ink);
    color: #fff;
    padding: 0.55rem;
}

.payments-date-block {
    background: var(--cc-sky);
}

.receivings-date-block span,
.receivings-date-block small,
.payments-date-block span,
.payments-date-block small {
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.7rem;
    font-weight: 850;
    text-transform: uppercase;
}

.receivings-date-block strong,
.payments-date-block strong {
    font-size: 2rem;
    font-weight: 950;
    line-height: 1;
}

.receivings-card__identity,
.payments-card__identity {
    min-width: 0;
}

.receivings-card__identity h3,
.payments-card__identity h3 {
    margin: 0 0 0.35rem;
    color: var(--cc-ink);
    font-size: 1.1rem;
    font-weight: 900;
    line-height: 1.15;
}

.payments-card__identity p,
.receivings-invoice-number {
    margin: 0 0 0.4rem;
    color: #526166;
    font-size: 0.82rem;
    font-weight: 750;
}

.receivings-status,
.payments-status {
    display: inline-flex;
    border-radius: 999px;
    color: #fff;
    font-size: 0.75rem;
    font-weight: 850;
    padding: 0.25rem 0.55rem;
}

.receivings-status--paid,
.payments-status--paid {
    background: var(--cc-bright-dark);
}

.receivings-status--partial,
.payments-status--partial,
.receivings-status--issued {
    background: var(--cc-warm);
    color: var(--cc-ink);
}

.receivings-status--unpaid,
.payments-status--unpaid {
    background: #b02a37;
}

.receivings-money-grid,
.payments-money-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
}

.payments-money-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.receivings-money-grid > div,
.payments-money-grid > div {
    min-width: 0;
    border: 1px solid rgba(16, 20, 22, 0.07);
    border-radius: 8px;
    background: rgba(246, 248, 247, 0.75);
    padding: 0.65rem;
}

.receivings-money-grid span,
.payments-money-grid span {
    display: block;
    color: #5f6c70;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.receivings-money-grid strong,
.payments-money-grid strong {
    display: block;
    margin-top: 0.2rem;
    color: var(--cc-ink);
    font-size: 1.05rem;
    font-weight: 900;
}

.payments-money-grid small {
    display: block;
    color: #69787d;
    margin-top: 0.15rem;
}

.receivings-money--positive,
.payments-money--positive {
    color: var(--cc-bright-dark) !important;
}

.receivings-money--negative,
.payments-money--negative {
    color: #b02a37 !important;
}

.receivings-card__actions,
.payments-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-end;
}

.receivings-empty-state,
.payments-empty-state {
    border: 1px dashed rgba(16, 20, 22, 0.16);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.72);
    color: #5f6c70;
    padding: 2rem;
    text-align: center;
}

@media (max-width: 1300px) {
    .receivings-command-center,
    .payments-command-center {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    .receivings-command-center__metrics,
    .payments-command-center__metrics,
    .receivings-money-grid,
    .payments-money-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .receivings-control-strip__form,
    .payments-control-strip__form,
    .receivings-section-toolbar,
    .payments-ledger-shell__header {
        align-items: stretch;
        flex-direction: column;
    }

    .receivings-control-strip__submit,
    .payments-control-strip__submit,
    .receivings-section-toolbar .btn {
        width: 100%;
    }
}

@media (max-width: 575.98px) {
    .receivings-command-center__metrics,
    .payments-command-center__metrics,
    .receivings-money-grid,
    .payments-money-grid {
        grid-template-columns: 1fr;
    }

    .receivings-card__top--selectable {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .receivings-card__select {
        grid-row: span 2;
    }

    .receivings-card__actions .btn,
    .payments-card__actions .btn {
        width: 100%;
    }
}

/* Extras and reports responsive ledgers */
.extras-workspace,
.reports-workspace {
    display: grid;
    gap: 1rem;
}

.extras-command-center,
.reports-command-center {
    display: grid;
    grid-template-columns: minmax(18rem, 0.85fr) minmax(22rem, 1.15fr) auto;
    gap: 1rem;
    align-items: stretch;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(246, 248, 247, 0.9)),
        radial-gradient(circle at 92% 12%, rgba(246, 184, 67, 0.22), transparent 34%);
    box-shadow: var(--cc-shadow-soft);
    padding: clamp(1rem, 2vw, 1.45rem);
}

.reports-command-center {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(246, 248, 247, 0.9)),
        radial-gradient(circle at 92% 12%, rgba(75, 136, 162, 0.18), transparent 36%);
}

.extras-command-center__copy,
.reports-command-center__copy {
    align-content: center;
    display: grid;
}

.extras-command-center__kicker,
.extras-ledger-shell__kicker,
.reports-command-center__kicker,
.reports-ledger-shell__kicker {
    color: var(--cc-bright-dark);
    font-size: 0.75rem;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.extras-command-center h1,
.reports-command-center h1 {
    margin: 0.2rem 0 0.45rem;
    color: var(--cc-ink);
    font-size: clamp(2rem, 4vw, 3.7rem);
    font-weight: 950;
    line-height: 0.95;
}

.extras-command-center p,
.reports-command-center p {
    margin: 0;
    max-width: 42rem;
    color: #526166;
}

.extras-command-center__metrics,
.reports-command-center__metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.65rem;
}

.reports-command-center__metrics--wide {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.reports-command-center__actions {
    align-items: start;
    display: flex;
    justify-content: flex-end;
}

.extras-metric,
.reports-metric {
    display: grid;
    align-content: space-between;
    min-height: 6.4rem;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: #fff;
    padding: 0.85rem;
}

.extras-metric span,
.reports-metric span {
    color: #5f6c70;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.extras-metric strong,
.reports-metric strong {
    color: var(--cc-ink);
    font-size: clamp(1.25rem, 2vw, 1.85rem);
    font-weight: 950;
    line-height: 1;
}

.extras-metric--dark,
.reports-metric--dark {
    background: var(--cc-ink);
}

.extras-metric--dark span,
.extras-metric--dark strong,
.reports-metric--dark span,
.reports-metric--dark strong {
    color: #fff;
}

.extras-metric--income,
.reports-metric--income,
.reports-metric--paid,
.extras-metric--paid {
    background: rgba(49, 169, 114, 0.14);
}

.extras-metric--expense,
.reports-metric--expense,
.reports-metric--balance,
.extras-metric--expense {
    background: rgba(176, 42, 55, 0.1);
}

.extras-metric--open,
.reports-metric--open {
    background: rgba(246, 184, 67, 0.18);
}

.extras-control-strip,
.extras-ledger-shell,
.reports-control-strip,
.reports-ledger-shell {
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.86);
    box-shadow: var(--cc-shadow-soft);
    padding: 1rem;
}

.extras-control-strip__form,
.reports-control-strip__form {
    display: flex;
    align-items: end;
    gap: 0.9rem;
}

.extras-control-strip__fields,
.reports-control-strip__fields {
    display: grid;
    flex: 1 1 auto;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 12rem), 1fr));
    gap: 0.8rem;
}

.reports-control-field--wide {
    min-width: min(100%, 18rem);
}

.extras-control-field,
.reports-control-field {
    min-width: 0;
}

.extras-control-strip .form-label,
.reports-control-strip .form-label {
    color: #526166;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.extras-control-strip__actions {
    display: flex;
    gap: 0.5rem;
}

.extras-ledger-shell__header,
.reports-ledger-shell__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.9rem;
    border-bottom: 1px solid rgba(16, 20, 22, 0.08);
    padding-bottom: 0.85rem;
}

.extras-ledger-shell h2,
.reports-ledger-shell h2 {
    margin: 0.15rem 0 0;
    color: var(--cc-ink);
    font-size: clamp(1.35rem, 2vw, 2rem);
    font-weight: 900;
}

.extras-ledger-shell__count,
.reports-ledger-shell__count {
    display: inline-grid;
    min-width: 5.25rem;
    justify-items: center;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: #fff;
    padding: 0.55rem 0.75rem;
}

.extras-ledger-shell__count strong,
.reports-ledger-shell__count strong {
    font-size: 1.45rem;
    font-weight: 900;
    line-height: 1;
}

.extras-ledger-shell__count span,
.reports-ledger-shell__count span {
    color: #526166;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.extras-card-grid,
.reports-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 24rem), 1fr));
    gap: 0.85rem;
}

.reports-card-grid--compact {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 20rem), 1fr));
}

.extras-card,
.reports-record-card {
    display: grid;
    gap: 0.85rem;
    min-width: 0;
    border: 1px solid rgba(16, 20, 22, 0.09);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--cc-shadow-soft);
    padding: 0.85rem;
}

.extras-card--income,
.reports-record-card--extra {
    border-color: rgba(49, 169, 114, 0.28);
}

.extras-card--expense,
.reports-record-card--urgent {
    border-color: rgba(176, 42, 55, 0.32);
}

.extras-card__top,
.reports-record-card__top {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.8rem;
    align-items: center;
}

.extras-date-block,
.reports-date-block {
    display: grid;
    min-width: 4.4rem;
    justify-items: center;
    border-radius: 8px;
    background: var(--cc-ink);
    color: #fff;
    padding: 0.55rem;
}

.reports-date-block--danger {
    background: #b02a37;
}

.extras-date-block span,
.extras-date-block small,
.reports-date-block span,
.reports-date-block small {
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.7rem;
    font-weight: 850;
    text-transform: uppercase;
}

.extras-date-block strong,
.reports-date-block strong {
    font-size: 2rem;
    font-weight: 950;
    line-height: 1;
}

.extras-card__identity,
.reports-record-card__identity {
    min-width: 0;
}

.extras-card__identity h3,
.reports-record-card__identity h3 {
    margin: 0 0 0.35rem;
    color: var(--cc-ink);
    font-size: 1.08rem;
    font-weight: 900;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.reports-record-card__identity p {
    margin: 0 0 0.4rem;
    color: #526166;
    font-size: 0.82rem;
    font-weight: 750;
    overflow-wrap: anywhere;
}

.extras-status,
.reports-status {
    display: inline-flex;
    width: fit-content;
    border-radius: 999px;
    color: #fff;
    font-size: 0.75rem;
    font-weight: 850;
    padding: 0.25rem 0.55rem;
}

.extras-status--income,
.reports-status--paid,
.reports-status--primary {
    background: var(--cc-bright-dark);
}

.extras-status--expense,
.reports-status--open {
    background: #b02a37;
}

.reports-status--partial,
.reports-status--info,
.reports-status--payment {
    background: var(--cc-warm);
    color: var(--cc-ink);
}

.reports-status--muted {
    background: #5f6c70;
}

.extras-money-grid,
.reports-money-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
}

.extras-money-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.reports-money-grid--hours {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 8.5rem), 1fr));
}

.extras-money-grid > div,
.reports-money-grid > div {
    min-width: 0;
    border: 1px solid rgba(16, 20, 22, 0.07);
    border-radius: 8px;
    background: rgba(246, 248, 247, 0.75);
    padding: 0.65rem;
}

.extras-money-grid span,
.reports-money-grid span {
    display: block;
    color: #5f6c70;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.extras-money-grid strong,
.reports-money-grid strong {
    display: block;
    margin-top: 0.2rem;
    color: var(--cc-ink);
    font-size: 1.02rem;
    font-weight: 900;
}

.extras-money--positive,
.reports-money--positive {
    color: var(--cc-bright-dark) !important;
}

.extras-money--negative,
.reports-money--negative {
    color: #b02a37 !important;
}

.extras-card__actions,
.reports-record-card__footer {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    justify-content: flex-end;
}

.reports-cleaner-row {
    border-top: 1px solid rgba(16, 20, 22, 0.08);
    padding-top: 0.75rem;
}

.reports-cleaner-row span {
    display: block;
    color: #526166;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.reports-cleaner-row strong {
    color: var(--cc-ink);
}

.extras-empty-state,
.reports-empty-state {
    border: 1px dashed rgba(16, 20, 22, 0.16);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.72);
    color: #5f6c70;
    padding: 2rem;
    text-align: center;
}

.reports-total-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    justify-content: flex-end;
    margin-top: 0.9rem;
    border-top: 1px solid rgba(16, 20, 22, 0.08);
    padding-top: 0.85rem;
}

.reports-total-strip span,
.reports-total-strip strong {
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: #fff;
    padding: 0.45rem 0.65rem;
}

.reports-total-strip span {
    color: #526166;
    font-size: 0.72rem;
    font-weight: 900;
    text-transform: uppercase;
}

.reports-pagination {
    border-top: 1px solid rgba(16, 20, 22, 0.08);
    margin-top: 1rem;
    padding-top: 0.85rem;
}

@media (max-width: 1300px) {
    .extras-command-center,
    .reports-command-center {
        grid-template-columns: 1fr;
    }

    .reports-command-center__metrics--wide {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .extras-command-center__metrics,
    .reports-command-center__metrics,
    .reports-command-center__metrics--wide,
    .extras-money-grid,
    .reports-money-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .extras-control-strip__form,
    .reports-control-strip__form,
    .extras-ledger-shell__header,
    .reports-ledger-shell__header {
        align-items: stretch;
        flex-direction: column;
    }

    .extras-control-strip__actions {
        flex-direction: column;
    }

    .extras-control-strip__actions .btn,
    .reports-control-strip__submit {
        width: 100%;
    }
}

@media (max-width: 575.98px) {
    .extras-command-center__metrics,
    .reports-command-center__metrics,
    .reports-command-center__metrics--wide,
    .extras-money-grid,
    .reports-money-grid {
        grid-template-columns: 1fr;
    }

    .extras-card__actions .btn,
    .reports-record-card__footer .btn {
        width: 100%;
    }
}

/* Entity directories: clients and third parties */
.entities-workspace {
    display: grid;
    gap: 1rem;
}

.entities-command-center {
    display: grid;
    grid-template-columns: minmax(18rem, 0.85fr) minmax(24rem, 1.15fr) auto;
    gap: 1rem;
    align-items: stretch;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(246, 248, 247, 0.9)),
        radial-gradient(circle at 92% 12%, rgba(75, 136, 162, 0.18), transparent 36%);
    box-shadow: var(--cc-shadow-soft);
    padding: clamp(1rem, 2vw, 1.45rem);
}

.entities-workspace--third-parties .entities-command-center {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(246, 248, 247, 0.9)),
        radial-gradient(circle at 92% 12%, rgba(246, 184, 67, 0.22), transparent 34%);
}

.entities-command-center__copy {
    align-content: center;
    display: grid;
}

.entities-command-center__kicker,
.entities-ledger-shell__kicker {
    color: var(--cc-bright-dark);
    font-size: 0.75rem;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.entities-command-center h1 {
    margin: 0.2rem 0 0.45rem;
    color: var(--cc-ink);
    font-size: clamp(2rem, 4vw, 3.8rem);
    font-weight: 950;
    line-height: 0.95;
}

.entities-command-center p {
    margin: 0;
    max-width: 42rem;
    color: #526166;
}

.entities-command-center__metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.65rem;
}

.entities-command-center__actions {
    align-items: start;
    display: flex;
    justify-content: flex-end;
}

.entities-metric {
    display: grid;
    align-content: space-between;
    min-height: 6.4rem;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: #fff;
    padding: 0.85rem;
}

.entities-metric span {
    color: #5f6c70;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.entities-metric strong {
    color: var(--cc-ink);
    font-size: clamp(1.35rem, 2vw, 2rem);
    font-weight: 950;
    line-height: 1;
}

.entities-metric--dark {
    background: var(--cc-ink);
}

.entities-metric--dark span,
.entities-metric--dark strong {
    color: #fff;
}

.entities-metric--contact {
    background: rgba(49, 169, 114, 0.14);
}

.entities-metric--phone {
    background: rgba(246, 184, 67, 0.18);
}

.entities-control-strip,
.entities-ledger-shell {
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.86);
    box-shadow: var(--cc-shadow-soft);
    padding: 1rem;
}

.entities-control-strip__form {
    display: flex;
    align-items: end;
    gap: 0.9rem;
}

.entities-control-strip__fields {
    display: grid;
    flex: 1 1 auto;
    grid-template-columns: minmax(min(100%, 16rem), 0.6fr) minmax(min(100%, 20rem), 1fr);
    gap: 0.8rem;
}

.entities-control-field {
    min-width: 0;
}

.entities-control-strip .form-label {
    color: #526166;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.entities-ledger-shell__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.9rem;
    border-bottom: 1px solid rgba(16, 20, 22, 0.08);
    padding-bottom: 0.85rem;
}

.entities-ledger-shell h2 {
    margin: 0.15rem 0 0;
    color: var(--cc-ink);
    font-size: clamp(1.35rem, 2vw, 2rem);
    font-weight: 900;
}

.entities-ledger-shell__count {
    display: inline-grid;
    min-width: 5.25rem;
    justify-items: center;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: #fff;
    padding: 0.55rem 0.75rem;
}

.entities-ledger-shell__count strong {
    font-size: 1.45rem;
    font-weight: 900;
    line-height: 1;
}

.entities-ledger-shell__count span {
    color: #526166;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.entities-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 24rem), 1fr));
    gap: 0.85rem;
}

.entities-card {
    display: grid;
    gap: 0.85rem;
    min-width: 0;
    border: 1px solid rgba(16, 20, 22, 0.09);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--cc-shadow-soft);
    padding: 0.85rem;
}

.entities-card__top {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.8rem;
    align-items: center;
}

.entities-avatar {
    display: grid;
    width: 3.6rem;
    height: 3.6rem;
    place-items: center;
    border-radius: 8px;
    background: var(--cc-ink);
    color: #fff;
    font-size: 1.6rem;
    font-weight: 950;
}

.entities-avatar--partner {
    background: var(--cc-sky);
}

.entities-avatar--service {
    background: var(--cc-warm);
    color: var(--cc-ink);
}

.entities-card__identity {
    min-width: 0;
}

.entities-card__identity h3 {
    margin: 0 0 0.35rem;
    color: var(--cc-ink);
    font-size: 1.12rem;
    font-weight: 900;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.entities-card__identity p {
    margin: 0;
    color: #526166;
    font-size: 0.82rem;
    font-weight: 750;
    overflow-wrap: anywhere;
}

.entities-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.entities-info-grid--single {
    grid-template-columns: 1fr;
}

.entities-info-grid--team {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.entities-info-grid > div {
    min-width: 0;
    border: 1px solid rgba(16, 20, 22, 0.07);
    border-radius: 8px;
    background: rgba(246, 248, 247, 0.75);
    padding: 0.65rem;
}

.entities-info-grid span {
    display: block;
    color: #5f6c70;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.entities-info-grid strong {
    display: block;
    margin-top: 0.2rem;
    color: var(--cc-ink);
    font-size: 0.92rem;
    font-weight: 850;
    overflow-wrap: anywhere;
}

.entities-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-end;
}

.entities-badge-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.entities-status {
    display: inline-flex;
    width: fit-content;
    border-radius: 999px;
    color: #fff;
    font-size: 0.75rem;
    font-weight: 850;
    padding: 0.25rem 0.55rem;
}

.entities-status--active,
.entities-status--driver {
    background: var(--cc-bright-dark);
}

.entities-status--inactive {
    background: var(--cc-warm);
    color: var(--cc-ink);
}

.entities-control-strip__form--dense {
    align-items: end;
}

.entities-control-strip__fields--dense {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 11rem), 1fr));
}

.entities-control-actions {
    display: flex;
    gap: 0.5rem;
}

.entities-empty-state {
    border: 1px dashed rgba(16, 20, 22, 0.16);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.72);
    color: #5f6c70;
    padding: 2rem;
    text-align: center;
}

.entities-pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 1rem;
    border-top: 1px solid rgba(16, 20, 22, 0.08);
    padding-top: 0.85rem;
}

.entities-page-size {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Quotations board */
.quotations-workspace {
    display: grid;
    gap: 1rem;
}

.quotations-command-center {
    display: grid;
    grid-template-columns: minmax(18rem, 0.95fr) minmax(16rem, 0.7fr) auto;
    gap: 1rem;
    align-items: stretch;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(246, 248, 247, 0.9)),
        radial-gradient(circle at 92% 12%, rgba(75, 136, 162, 0.18), transparent 36%);
    box-shadow: var(--cc-shadow-soft);
    padding: clamp(1rem, 2vw, 1.45rem);
}

.quotations-command-center__copy {
    display: grid;
    align-content: center;
}

.quotations-command-center__kicker,
.quotations-ledger-shell__kicker {
    color: var(--cc-bright-dark);
    font-size: 0.75rem;
    font-weight: 900;
    text-transform: uppercase;
}

.quotations-command-center h1 {
    margin: 0.2rem 0 0.45rem;
    color: var(--cc-ink);
    font-size: clamp(1.8rem, 3vw, 3rem);
    font-weight: 950;
    line-height: 1.05;
}

.quotations-command-center p {
    margin: 0;
    max-width: 42rem;
    color: #526166;
}

.quotations-command-center__metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.65rem;
}

.quotations-metric {
    display: grid;
    align-content: space-between;
    min-height: 6.4rem;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: #fff;
    padding: 0.85rem;
}

.quotations-metric span {
    color: #5f6c70;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.quotations-metric strong {
    color: var(--cc-ink);
    font-size: clamp(1.2rem, 1.8vw, 1.8rem);
    font-weight: 950;
    line-height: 1;
}

.quotations-metric--dark {
    background: var(--cc-ink);
}

.quotations-metric--dark span,
.quotations-metric--dark strong {
    color: #fff;
}

.quotations-metric--pending {
    background: rgba(246, 184, 67, 0.18);
}

.quotations-metric--sent {
    background: rgba(49, 169, 114, 0.14);
}

.quotations-command-center__actions {
    display: flex;
    justify-content: flex-end;
    align-items: start;
}

.quotations-ledger-shell {
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.86);
    box-shadow: var(--cc-shadow-soft);
    padding: 1rem;
}

.quotations-ledger-shell__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.9rem;
    border-bottom: 1px solid rgba(16, 20, 22, 0.08);
    padding-bottom: 0.85rem;
}

.quotations-ledger-shell h2 {
    margin: 0.15rem 0 0;
    color: var(--cc-ink);
    font-size: clamp(1.35rem, 2vw, 2rem);
    font-weight: 900;
}

.quotations-ledger-shell__count {
    display: inline-grid;
    min-width: 5.25rem;
    justify-items: center;
    border: 1px solid rgba(16, 20, 22, 0.08);
    border-radius: 8px;
    background: #fff;
    padding: 0.55rem 0.75rem;
}

.quotations-ledger-shell__count strong {
    font-size: 1.45rem;
    font-weight: 900;
    line-height: 1;
}

.quotations-ledger-shell__count span {
    color: #526166;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.quotations-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 24rem), 1fr));
    gap: 0.85rem;
}

.quotations-card {
    display: grid;
    gap: 0.85rem;
    min-width: 0;
    border: 1px solid rgba(16, 20, 22, 0.09);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--cc-shadow-soft);
    padding: 0.85rem;
}

.quotations-card--pending {
    border-color: rgba(246, 184, 67, 0.32);
}

.quotations-card--sent {
    border-color: rgba(49, 169, 114, 0.26);
}

.quotations-card__top {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.8rem;
    align-items: center;
}

.quotations-date-block {
    display: grid;
    min-width: 4.4rem;
    justify-items: center;
    border-radius: 8px;
    background: var(--cc-ink);
    color: #fff;
    padding: 0.55rem;
}

.quotations-date-block span,
.quotations-date-block small {
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.7rem;
    font-weight: 850;
    text-transform: uppercase;
}

.quotations-date-block strong {
    font-size: 2rem;
    font-weight: 950;
    line-height: 1;
}

.quotations-card__identity {
    min-width: 0;
}

.quotations-card__identity h3 {
    margin: 0 0 0.35rem;
    color: var(--cc-ink);
    font-size: 1.08rem;
    font-weight: 900;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.quotations-card__identity p,
.quotations-meta-row {
    margin: 0;
    color: #526166;
    font-size: 0.82rem;
    font-weight: 750;
}

.quotations-email-link {
    color: inherit;
    text-decoration: none;
}

.quotations-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.quotations-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.quotations-info-grid > div {
    min-width: 0;
    border: 1px solid rgba(16, 20, 22, 0.07);
    border-radius: 8px;
    background: rgba(246, 248, 247, 0.75);
    padding: 0.65rem;
}

.quotations-info-grid span,
.quotations-notes span {
    display: block;
    color: #5f6c70;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.quotations-info-grid strong {
    display: block;
    margin-top: 0.2rem;
    color: var(--cc-ink);
    font-size: 0.92rem;
    font-weight: 850;
    overflow-wrap: anywhere;
}

.quotations-status {
    display: inline-flex;
    width: fit-content;
    border-radius: 999px;
    color: #fff;
    font-size: 0.75rem;
    font-weight: 850;
    padding: 0.25rem 0.55rem;
}

.quotations-status--sent {
    background: var(--cc-bright-dark);
}

.quotations-status--pending {
    background: #b02a37;
}

.quotations-notes {
    border-top: 1px solid rgba(16, 20, 22, 0.08);
    padding-top: 0.75rem;
}

.quotations-notes p {
    margin: 0.2rem 0 0;
    color: #526166;
}

.quotations-card__footer {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    justify-content: space-between;
}

.quotations-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-end;
}

.quotations-empty-state {
    border: 1px dashed rgba(16, 20, 22, 0.16);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.72);
    color: #5f6c70;
    padding: 2rem;
    text-align: center;
}

@media (max-width: 1300px) {
    .quotations-command-center {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    .quotations-command-center__metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .quotations-command-center__actions,
    .quotations-ledger-shell__header {
        align-items: stretch;
        flex-direction: column;
    }
}

@media (max-width: 575.98px) {
    .quotations-command-center__metrics,
    .quotations-info-grid {
        grid-template-columns: 1fr;
    }

    .quotations-card__actions .btn {
        width: 100%;
    }
}

@media (max-width: 1300px) {
    .entities-command-center {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    .entities-command-center__metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .entities-control-strip__form,
    .entities-ledger-shell__header {
        align-items: stretch;
        flex-direction: column;
    }

    .entities-control-strip__fields {
        grid-template-columns: 1fr;
    }

    .entities-control-strip__submit,
    .entities-command-center__actions .btn,
    .entities-control-actions .btn {
        width: 100%;
    }

    .entities-control-actions {
        flex-direction: column;
    }
}

@media (max-width: 575.98px) {
    .entities-command-center__metrics,
    .entities-info-grid {
        grid-template-columns: 1fr;
    }

    .entities-card__actions .btn,
    .entities-pagination .pagination {
        width: 100%;
    }
}
