body {
    background:
        radial-gradient(circle at top right, rgba(198, 90, 46, 0.09), transparent 30%),
        linear-gradient(180deg, var(--crm-bg) 0%, color-mix(in srgb, var(--crm-bg) 88%, #ffffff 12%) 100%);
    color: var(--crm-text);
}

[data-bs-theme="dark"] body.bg-light,
[data-bs-theme="dark"] .bg-light,
[data-bs-theme="dark"] .bg-white,
[data-bs-theme="dark"] .text-bg-light {
    background-color: var(--crm-surface-muted) !important;
    color: var(--crm-text) !important;
    border-color: var(--crm-border) !important;
}

[data-bs-theme="dark"] .text-muted {
    color: var(--crm-text-muted) !important;
}

[data-bs-theme="dark"] .card,
[data-bs-theme="dark"] .modal-content,
[data-bs-theme="dark"] .dropdown-menu,
[data-bs-theme="dark"] .list-group-item {
    background-color: var(--crm-surface);
    color: var(--crm-text);
    border-color: var(--crm-border);
}

[data-bs-theme="dark"] .card-header.bg-light,
[data-bs-theme="dark"] .card-footer.bg-light {
    background-color: var(--crm-surface-muted) !important;
    color: var(--crm-text) !important;
    border-color: var(--crm-border) !important;
}

[data-bs-theme="dark"] .table-light,
[data-bs-theme="dark"] .table-light > th,
[data-bs-theme="dark"] .table-light > td,
[data-bs-theme="dark"] .table-light > * > th,
[data-bs-theme="dark"] .table-light > * > td {
    --bs-table-bg: var(--crm-surface-muted);
    --bs-table-color: var(--crm-text);
    --bs-table-border-color: var(--crm-border);
    --bs-table-striped-bg: color-mix(in srgb, var(--crm-surface-muted) 88%, #ffffff 12%);
    --bs-table-striped-color: var(--crm-text);
    --bs-table-hover-bg: color-mix(in srgb, var(--crm-surface-muted) 84%, #ffffff 16%);
    --bs-table-hover-color: var(--crm-text);
    background-color: var(--crm-surface-muted) !important;
    color: var(--crm-text) !important;
    border-color: var(--crm-border) !important;
}

[data-bs-theme="dark"] .alert-light,
[data-bs-theme="dark"] .alert-dark {
    --bs-alert-bg: var(--crm-surface-muted);
    --bs-alert-color: var(--crm-text);
    --bs-alert-border-color: var(--crm-border);
}

[data-bs-theme="dark"] .btn-outline-dark {
    --bs-btn-color: var(--crm-text);
    --bs-btn-border-color: color-mix(in srgb, var(--crm-text-muted) 60%, transparent 40%);
    --bs-btn-hover-color: var(--crm-bg);
    --bs-btn-hover-bg: var(--crm-text);
    --bs-btn-hover-border-color: var(--crm-text);
    --bs-btn-active-color: var(--crm-bg);
    --bs-btn-active-bg: var(--crm-text);
    --bs-btn-active-border-color: var(--crm-text);
    --bs-btn-disabled-color: var(--crm-text-muted);
    --bs-btn-disabled-border-color: var(--crm-border);
}

:root {
    --crm-btn-radius: 0.48rem;
}

.btn {
    border-radius: var(--crm-btn-radius);
}

.crm-navbar {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-height: 48px;
    backdrop-filter: blur(14px);
    background: rgba(22, 29, 35, 0.92) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.crm-navbar .navbar-brand,
.crm-navbar__brand {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex: 0 1 18rem;
    min-width: 0;
    font-weight: 700;
    letter-spacing: 0.02em;
}

.crm-navbar__brand-label {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.crm-navbar__actions {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem;
    margin-left: auto;
    padding-right: 0.5rem;
    flex: 0 0 auto;
}

.crm-navbar__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-height: 2.4rem;
    min-width: 2.4rem;
    padding: 0 0.8rem;
    color: rgba(255, 255, 255, 0.92);
    text-decoration: none;
    border-radius: var(--crm-btn-radius);
    transition: background-color 0.2s ease, color 0.2s ease;
}

.crm-navbar__action:hover,
.crm-navbar__action:focus-visible {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
}

.crm-navbar__theme {
    padding-inline: 0.75rem;
}

.crm-navbar__logout-label {
    white-space: nowrap;
}

.crm-mobile-tabbar {
    display: none;
}

@media (min-width: 768px) and (max-width: 991.98px) {
    .crm-navbar__brand {
        flex: 0 1 15rem;
    }

    .crm-navbar__action {
        padding-inline: 0.65rem;
    }

    .crm-main {
        padding-inline: 1rem !important;
    }
}

@media (max-width: 1199.98px) {
    .crm-navbar__logout-label {
        display: none;
    }

    .crm-navbar__logout {
        padding-inline: 0.7rem;
    }
}

@media (max-width: 767.98px) {
    .crm-navbar {
        gap: 0.35rem;
    }

    .crm-navbar .navbar-toggler {
        right: 0.55rem;
        top: 0.35rem;
    }

    .crm-navbar__brand {
        flex-basis: auto;
        max-width: calc(100% - 8rem);
    }

    .crm-navbar__actions {
        padding-right: 3.25rem;
    }
}

.crm-sidebar-shell {
    height: calc(100vh - 48px);
    overflow-y: auto;
    overflow-x: hidden;
    padding: 1rem 0 1.25rem;
}

.crm-sidebar-group {
    padding: 0 0.9rem;
    margin-top: 1.1rem;
}

.crm-sidebar-heading {
    display: block;
    padding: 0 0.55rem;
    margin-bottom: 0.45rem;
    color: var(--crm-text-muted);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.crm-sidebar-quick {
    margin-top: 1.5rem;
}

.crm-sidebar-quick .nav-link {
    font-size: 0.93rem;
}

.crm-sidebar-footer {
    padding: 0 0.9rem;
    margin-top: 1.2rem;
}

.crm-main {
    padding-top: 1rem;
    padding-bottom: 2rem;
}

.crm-page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.1rem 1.25rem;
    margin-bottom: 1.25rem;
    border: 1px solid var(--crm-border);
    border-radius: var(--crm-radius-lg);
    background: linear-gradient(135deg, var(--crm-surface) 0%, var(--crm-surface-muted) 100%);
    box-shadow: var(--crm-shadow);
}

.crm-page-head__title {
    margin: 0;
    font-size: clamp(1.4rem, 2vw, 2rem);
    font-weight: 700;
    letter-spacing: -0.02em;
}

.crm-page-head__meta {
    margin-top: 0.35rem;
    color: var(--crm-text-muted);
    font-size: 0.92rem;
}

.crm-toolbar {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    align-items: center;
}

.crm-icon-round-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    padding: 0;
    border-radius: 999px;
    line-height: 1;
}

.crm-segments {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.crm-tabs-nowrap {
    flex-wrap: nowrap;
    overflow-x: auto;
}

.crm-segment-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 2.2rem;
    padding: 0.4rem 0.8rem;
    border: 1px solid var(--crm-border);
    border-radius: 999px;
    background: var(--crm-surface);
    color: var(--crm-text-muted);
    font-size: 0.87rem;
    font-weight: 600;
    text-decoration: none;
    box-shadow: var(--crm-shadow);
}

.crm-segment-link:hover {
    color: var(--crm-brand-strong);
    border-color: color-mix(in srgb, var(--crm-brand) 35%, var(--crm-border) 65%);
}

.crm-segment-link.is-active {
    background: var(--crm-brand-soft);
    color: var(--crm-brand-strong);
    border-color: color-mix(in srgb, var(--crm-brand) 35%, var(--crm-border) 65%);
}

.crm-panel {
    border: 1px solid var(--crm-border);
    border-radius: var(--crm-radius-md);
    background: var(--crm-surface);
    box-shadow: var(--crm-shadow);
}

.crm-panel .card-header {
    background: transparent;
    border-bottom: 1px solid var(--crm-border);
}

.crm-panel .card-body {
    background: transparent;
}

.crm-chart-box {
    position: relative;
    flex: 1 1 auto;
    min-height: 0;
}

.crm-chart-box canvas {
    width: 100% !important;
    height: 100% !important;
}

.crm-filter-card {
    border: 1px solid var(--crm-border);
    border-radius: var(--crm-radius-md);
    background: color-mix(in srgb, var(--crm-surface) 84%, var(--crm-brand-soft) 16%);
    box-shadow: var(--crm-shadow);
}

.crm-table thead th {
    background: color-mix(in srgb, var(--crm-surface-muted) 92%, var(--crm-brand-soft) 8%);
}

.crm-inline-edit-row {
    margin: 0;
}

.crm-inline-edit-grid {
    display: grid;
    grid-template-columns: minmax(110px, 1fr) minmax(100px, 1fr) minmax(100px, 1fr) auto auto;
    gap: 0.55rem;
    align-items: end;
}

.crm-inline-edit-field {
    display: flex;
    flex-direction: column;
    gap: 0.22rem;
    margin: 0;
}

.crm-inline-edit-label {
    color: var(--crm-text-muted);
    font-size: 0.67rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    white-space: nowrap;
}

.crm-inline-input {
    min-height: 2.2rem;
    border-radius: 0.5rem;
    padding: 0.35rem 0.55rem;
    text-align: center;
}

.crm-inline-check {
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
    min-height: 2.2rem;
    padding: 0 0.15rem 0.1rem;
    margin: 0;
    white-space: nowrap;
}

.crm-inline-check .form-check-input {
    margin-top: 0;
}

.crm-inline-save {
    min-height: 2.2rem;
    white-space: nowrap;
}

.crm-form-label {
    color: var(--crm-text-muted);
    font-size: 0.83rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.crm-input,
.crm-select {
    min-height: 2.65rem;
    border-color: var(--crm-border);
    border-radius: 14px;
    background: color-mix(in srgb, var(--crm-surface) 92%, #ffffff 8%);
}

.crm-input:focus,
.crm-select:focus {
    border-color: color-mix(in srgb, var(--crm-brand) 55%, white 45%);
    box-shadow: 0 0 0 0.24rem rgba(198, 90, 46, 0.14);
}

.crm-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    min-height: 2rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: var(--crm-brand-soft);
    color: var(--crm-brand-strong);
    font-size: 0.85rem;
    font-weight: 600;
}

.crm-chip--neutral {
    background: color-mix(in srgb, var(--crm-surface-muted) 90%, var(--crm-border) 10%);
    color: var(--crm-text-muted);
}

.crm-chip--danger {
    background: color-mix(in srgb, var(--crm-danger) 16%, var(--crm-surface) 84%);
    color: var(--crm-danger-ink);
}

.crm-chip--warning {
    background: color-mix(in srgb, var(--crm-warning) 18%, var(--crm-surface) 82%);
    color: var(--crm-warning-ink);
}

.crm-chip--success {
    background: color-mix(in srgb, var(--crm-success) 16%, var(--crm-surface) 84%);
    color: var(--crm-success-ink);
}

.crm-paid-state {
    display: inline-flex;
    align-items: center;
    gap: 0.38rem;
    white-space: nowrap;
}

.crm-paid-indicator {
    display: inline-block;
    width: 0.72rem;
    height: 0.72rem;
    flex: 0 0 0.72rem;
    border-radius: 50%;
    background: var(--crm-success);
    border: 1px solid rgba(255, 255, 255, 0.92);
    box-shadow:
        0 0 0 2px rgba(22, 163, 74, 0.16),
        0 0 10px rgba(22, 163, 74, 0.78);
    vertical-align: middle;
}

[data-bs-theme="dark"] .crm-paid-indicator {
    border-color: rgba(8, 16, 12, 0.9);
    box-shadow:
        0 0 0 2px rgba(34, 197, 94, 0.22),
        0 0 12px rgba(34, 197, 94, 0.86);
}

.crm-status-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    min-height: 1.9rem;
    padding: 0.28rem 0.65rem;
    border: 1px solid transparent;
    border-radius: 0.48rem;
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
}

.crm-status-pill--strong {
    border-width: 1.5px;
    border-style: solid;
    border-radius: 0.42rem;
    font-weight: 800;
    letter-spacing: 0.01em;
    box-shadow: none;
}

.crm-status-pill--warning {
    background: color-mix(in srgb, var(--crm-warning) 22%, var(--crm-surface) 78%);
    border-color: color-mix(in srgb, var(--crm-warning) 30%, var(--crm-border) 70%);
    color: var(--crm-warning-ink);
}

.crm-status-pill--strong.crm-status-pill--warning {
    background: var(--crm-warning-soft);
    color: var(--crm-warning-ink);
    border-color: var(--crm-warning);
}

.crm-status-pill--info {
    background: color-mix(in srgb, var(--crm-info) 20%, var(--crm-surface) 80%);
    border-color: color-mix(in srgb, var(--crm-info) 28%, var(--crm-border) 72%);
    color: var(--crm-info-ink);
}

.crm-status-pill--strong.crm-status-pill--info {
    background: var(--crm-info-soft);
    color: var(--crm-info-ink);
    border-color: var(--crm-info);
}

.crm-status-pill--success {
    background: color-mix(in srgb, var(--crm-success) 18%, var(--crm-surface) 82%);
    border-color: color-mix(in srgb, var(--crm-success) 28%, var(--crm-border) 72%);
    color: var(--crm-success-ink);
}

.crm-status-pill--strong.crm-status-pill--success {
    background: var(--crm-success-soft);
    color: var(--crm-success-ink);
    border-color: var(--crm-success);
}

.crm-status-pill--danger {
    background: color-mix(in srgb, var(--crm-danger) 16%, var(--crm-surface) 84%);
    border-color: color-mix(in srgb, var(--crm-danger) 28%, var(--crm-border) 72%);
    color: var(--crm-danger-ink);
}

.crm-status-pill--strong.crm-status-pill--danger {
    background: var(--crm-danger-soft);
    color: var(--crm-danger-ink);
    border-color: var(--crm-danger);
}

.crm-status-pill--maroon {
    background: color-mix(in srgb, var(--crm-maroon) 16%, var(--crm-surface) 84%);
    border-color: color-mix(in srgb, var(--crm-maroon) 28%, var(--crm-border) 72%);
    color: var(--crm-maroon-ink);
}

.crm-status-pill--strong.crm-status-pill--maroon {
    background: var(--crm-maroon-soft);
    color: var(--crm-maroon-ink);
    border-color: var(--crm-maroon);
}

.crm-status-pill--neutral {
    background: color-mix(in srgb, var(--crm-surface-muted) 90%, var(--crm-border) 10%);
    border-color: color-mix(in srgb, var(--crm-border) 70%, var(--crm-surface) 30%);
    color: var(--crm-text-muted);
}

.crm-status-pill--strong.crm-status-pill--neutral {
    background: color-mix(in srgb, var(--ctp-mauve) 16%, var(--crm-surface));
    color: color-mix(in srgb, var(--ctp-mauve) 65%, var(--crm-text));
    border-color: var(--ctp-mauve);
}

.crm-status-pill--dark {
    background: color-mix(in srgb, var(--crm-text) 14%, var(--crm-surface) 86%);
    border-color: color-mix(in srgb, var(--crm-text) 22%, var(--crm-border) 78%);
    color: var(--crm-text);
}

.crm-history-status .crm-status-pill {
    min-height: 1.35rem;
    padding: 0.16rem 0.48rem;
    font-size: 0.68rem;
    font-weight: 600;
    border-radius: 0.42rem;
}

.crm-history-page .crm-table thead th {
    padding-top: 0.55rem;
    padding-bottom: 0.55rem;
    font-size: 0.76rem;
}

.crm-history-page .crm-table tbody td,
.crm-history-page .crm-table tfoot td {
    padding-top: 0.48rem;
    padding-bottom: 0.48rem;
    line-height: 1.2;
}

.crm-history-page .crm-table tbody tr {
    height: 3rem;
}

.crm-kpi-card {
    border: 1px solid var(--crm-border);
    border-radius: var(--crm-radius-md);
    background: linear-gradient(180deg, var(--crm-surface) 0%, color-mix(in srgb, var(--crm-surface) 90%, var(--crm-brand-soft) 10%) 100%);
    box-shadow: var(--crm-shadow);
}

.crm-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
}

.crm-kpi-grid--compact {
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.crm-kpi-card {
    padding: 1rem 1.1rem;
}

.crm-kpi-label {
    display: block;
    color: var(--crm-text-muted);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.crm-kpi-value {
    display: block;
    margin-top: 0.35rem;
    font-size: clamp(1.35rem, 1.8vw, 2rem);
    font-weight: 700;
    line-height: 1.05;
}

.crm-kpi-meta {
    display: block;
    margin-top: 0.4rem;
    color: var(--crm-text-muted);
    font-size: 0.86rem;
}

.crm-panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.95rem 1.1rem;
    border-bottom: 1px solid var(--crm-border);
}

.crm-panel-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
}

.crm-panel-meta {
    color: var(--crm-text-muted);
    font-size: 0.88rem;
    font-weight: 600;
}

.crm-empty-state {
    padding: 3.5rem 1rem;
}

.crm-action-chip {
    display: inline-flex;
    align-items: center;
    min-height: 1.9rem;
    padding: 0.25rem 0.7rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--crm-surface-muted) 90%, var(--crm-border) 10%);
    color: var(--crm-text-muted);
    font-size: 0.8rem;
    font-weight: 700;
}

.crm-action-chip.is-warning {
    background: color-mix(in srgb, var(--crm-warning) 18%, var(--crm-surface) 82%);
    color: var(--crm-warning-ink);
}

.crm-autocomplete-menu {
    position: absolute;
    inset-inline: 0;
    z-index: 1000;
    max-height: 220px;
    overflow-y: auto;
}

.kpi-card {
    border-radius: 12px;
    overflow: hidden;
}

.kpi-card .card-body {
    padding: 1.1rem 1.25rem;
}

.kpi-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.1;
}

.kpi-value-sm {
    font-size: 1.45rem;
    font-weight: 700;
    line-height: 1.2;
}

.kpi-label {
    margin-bottom: 0.25rem;
    color: var(--bs-secondary-color);
    font-size: 0.73rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.kpi-icon-wrap {
    display: flex;
    width: 52px;
    height: 52px;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    font-size: 1.4rem;
}

.kpi-bar {
    height: 3px;
}

.kpi-blue {
    background: rgba(13, 110, 253, 0.15); /* decorative tint */
    color: var(--crm-info);
}

.kpi-green {
    background: rgba(25, 135, 84, 0.15); /* decorative tint */
    color: var(--crm-success);
}

.kpi-yellow {
    background: rgba(255, 193, 7, 0.18); /* decorative tint */
    color: var(--crm-warning-ink);
}

.kpi-purple {
    background: rgba(111, 66, 193, 0.15); /* decorative tint */
    color: var(--ctp-mauve);
}

.kpi-teal {
    background: rgba(13, 202, 240, 0.15); /* decorative tint */
    color: var(--crm-accent);
}

.kpi-emerald {
    background: rgba(32, 201, 151, 0.16); /* decorative tint */
    color: var(--crm-success);
}

.kpi-muted {
    background: rgba(108, 117, 125, 0.12); /* decorative tint */
    color: var(--crm-text-muted);
}

.kpi-blue-bar {
    background: var(--crm-info);
}

.kpi-green-bar {
    background: var(--crm-success);
}

.kpi-yellow-bar {
    background: var(--crm-warning);
}

.kpi-purple-bar {
    background: var(--ctp-mauve);
}

.kpi-teal-bar {
    background: var(--crm-accent);
}

.kpi-emerald-bar {
    background: var(--crm-success);
}

.kpi-muted-bar {
    background: rgba(108, 117, 125, 0.3);
}

.kpi-alert {
    box-shadow: 0 0 0 2px rgba(255, 193, 7, 0.5);
}

[data-bs-theme="dark"] .kpi-blue {
    background: rgba(13, 110, 253, 0.25); /* decorative tint */
    color: var(--crm-info);
}

[data-bs-theme="dark"] .kpi-green {
    background: rgba(25, 135, 84, 0.25); /* decorative tint */
    color: var(--crm-success);
}

[data-bs-theme="dark"] .kpi-yellow {
    background: rgba(255, 193, 7, 0.22); /* decorative tint */
    color: var(--crm-warning);
}

[data-bs-theme="dark"] .kpi-purple {
    background: rgba(111, 66, 193, 0.25); /* decorative tint */
    color: var(--ctp-lavender);
}

[data-bs-theme="dark"] .kpi-teal {
    background: rgba(13, 202, 240, 0.2); /* decorative tint */
    color: var(--crm-accent);
}

[data-bs-theme="dark"] .kpi-emerald {
    background: rgba(32, 201, 151, 0.22); /* decorative tint */
    color: var(--crm-success);
}

[data-bs-theme="dark"] .kpi-muted {
    background: rgba(108, 117, 125, 0.2); /* decorative tint */
    color: var(--crm-text-muted);
}

[data-bs-theme="dark"] .text-warning {
    color: var(--crm-warning) !important;
}

.progress-thin {
    height: 6px;
    border-radius: 3px;
}

.order-card {
    border-radius: 10px;
    transition: box-shadow 0.15s;
}

.order-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

.days-badge {
    padding: 0.2rem 0.5rem;
    font-size: 0.7rem;
}

.worker-bar,
.dashboard-worker-progress {
    height: 8px;
    border-radius: 4px;
}

.dashboard-icon-xs {
    font-size: 0.7rem;
}

.crm-empty {
    padding: 3.5rem 1rem;
    text-align: center;
    color: var(--crm-text-muted);
}

.crm-inbox-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.crm-order-card {
    border: 1px solid var(--crm-border);
    border-radius: var(--crm-radius-md);
    background: linear-gradient(180deg, var(--crm-surface) 0%, color-mix(in srgb, var(--crm-surface) 94%, var(--crm-brand-soft) 6%) 100%);
    box-shadow: var(--crm-shadow);
    padding: 1rem 1.1rem;
}

.crm-order-card__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 0.85rem;
}

.crm-order-card__id {
    font-size: 1.05rem;
    font-weight: 700;
}

.crm-order-card__meta {
    color: var(--crm-text-muted);
    font-size: 0.92rem;
}

.crm-order-card__client {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.crm-order-card__name {
    font-size: 1rem;
    font-weight: 700;
}

.crm-order-card__phone {
    color: var(--crm-text-muted);
    font-size: 0.92rem;
}

.crm-order-card__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
    margin-bottom: 0.9rem;
}

.crm-order-card__field {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.crm-order-card__label {
    color: var(--crm-text-muted);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.crm-order-card__value {
    font-size: 0.95rem;
    font-weight: 600;
}

.crm-order-card__foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    padding-top: 0.85rem;
    border-top: 1px solid var(--crm-border);
}

.crm-order-card__actions {
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.crm-action-queue {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.crm-action-card {
    border: 1px solid var(--crm-border);
    border-radius: var(--crm-radius-md);
    background: linear-gradient(180deg, var(--crm-surface) 0%, color-mix(in srgb, var(--crm-surface) 90%, var(--crm-brand-soft) 10%) 100%);
    box-shadow: var(--crm-shadow);
    padding: 1rem 1.1rem;
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.crm-action-card__top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    margin-bottom: 0.65rem;
}

.crm-action-card__title {
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--crm-text-muted);
}

.crm-action-card__count {
    font-size: 1.85rem;
    font-weight: 800;
    line-height: 1;
}

.crm-action-card__text {
    color: var(--crm-text-muted);
    font-size: 0.93rem;
    margin-bottom: 0.8rem;
    flex: 1 1 auto;
}

.crm-action-card__cta {
    align-self: flex-start;
}

.crm-summary-strip {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0.85rem;
    margin-bottom: 1rem;
}

.crm-summary-card {
    border: 1px solid var(--crm-border);
    border-radius: var(--crm-radius-md);
    background: linear-gradient(180deg, var(--crm-surface) 0%, color-mix(in srgb, var(--crm-surface) 90%, var(--crm-brand-soft) 10%) 100%);
    box-shadow: var(--crm-shadow);
    padding: 0.9rem 1rem;
}

.crm-summary-card__label {
    color: var(--crm-text-muted);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.crm-summary-card__value {
    font-size: 1.05rem;
    font-weight: 700;
}

.crm-section-nav {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.crm-section-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 2.2rem;
    padding: 0.42rem 0.8rem;
    border-radius: 999px;
    border: 1px solid var(--crm-border);
    background: var(--crm-surface);
    color: var(--crm-text-muted);
    font-size: 0.87rem;
    font-weight: 600;
    text-decoration: none;
    box-shadow: var(--crm-shadow);
}

.crm-section-link:hover {
    color: var(--crm-brand-strong);
    border-color: color-mix(in srgb, var(--crm-brand) 35%, var(--crm-border) 65%);
}

.crm-rail {
    position: sticky;
    top: 5.5rem;
}

.crm-rail > .card,
.crm-rail > .crm-panel {
    margin-bottom: 1rem;
}

.crm-mini-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.crm-mini-item {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--crm-border);
}

.crm-mini-item:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.crm-mini-item__label {
    color: var(--crm-text-muted);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.crm-mini-item__value {
    font-weight: 700;
    text-align: right;
}

.crm-detail-list {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.crm-detail-row {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 1rem;
    padding: 0.85rem 0;
    border-bottom: 1px solid var(--crm-border);
}

.crm-detail-row:first-child {
    padding-top: 0;
}

.crm-detail-row:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.crm-detail-label {
    color: var(--crm-text-muted);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.crm-detail-value {
    font-weight: 600;
}

.crm-detail-value--multiline {
    line-height: 1.55;
}

.crm-worker-table td,
.crm-worker-table th {
    vertical-align: middle;
}

.crm-activity-feed {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.crm-activity-item {
    display: flex;
    gap: 0.9rem;
    padding: 0.95rem 1rem;
    border: 1px solid var(--crm-border);
    border-radius: var(--crm-radius-md);
    background: linear-gradient(180deg, var(--crm-surface) 0%, color-mix(in srgb, var(--crm-surface) 94%, var(--crm-brand-soft) 6%) 100%);
    box-shadow: var(--crm-shadow);
}

.crm-activity-icon {
    flex: 0 0 auto;
    width: 2.4rem;
    height: 2.4rem;
    border-radius: 0.8rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--crm-surface-muted) 88%, var(--crm-brand-soft) 12%);
    color: var(--crm-text-muted);
}

.crm-activity-body {
    min-width: 0;
    flex: 1 1 auto;
}

.crm-activity-head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
}

.crm-activity-title {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    flex-wrap: wrap;
    font-weight: 700;
}

.crm-activity-time {
    color: var(--crm-text-muted);
    font-size: 0.82rem;
    white-space: nowrap;
}

.crm-activity-meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.35rem;
    flex-wrap: wrap;
    color: var(--crm-text-muted);
    font-size: 0.9rem;
}

.crm-activity-note {
    margin-top: 0.35rem;
    color: var(--crm-text-muted);
    font-size: 0.85rem;
}

.crm-task-toolbar {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.crm-task-toolbar__meta {
    color: var(--crm-text-muted);
    font-size: 0.92rem;
}

.crm-create-shell {
    padding-bottom: 2rem;
}

.crm-create-card {
    border: 0;
    box-shadow: 0 0.5rem 1.25rem rgba(33, 37, 41, 0.08);
}

.crm-create-card .card-header {
    font-weight: 700;
}

.crm-create-card__header--brand {
    background: linear-gradient(135deg, var(--crm-brand-strong) 0%, color-mix(in srgb, var(--crm-brand-strong) 80%, #ffffff 20%) 100%);
    color: #fff;
}

.crm-create-card__header--success {
    background: linear-gradient(135deg, var(--crm-success) 0%, color-mix(in srgb, var(--crm-success) 70%, var(--crm-success-soft) 30%) 100%);
    color: #fff;
}

.crm-create-card__header--warning {
    background: linear-gradient(135deg, var(--crm-warning) 0%, color-mix(in srgb, var(--crm-warning) 70%, var(--crm-warning-soft) 30%) 100%);
    color: var(--crm-warning-ink);
}

.crm-inline-hint {
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.08), rgba(25, 135, 84, 0.08));
    border: 1px solid rgba(13, 110, 253, 0.15);
    border-radius: 0.75rem;
    padding: 0.85rem 1rem;
}

.crm-order-number-panel {
    background: color-mix(in srgb, var(--crm-surface-muted) 88%, var(--crm-brand-soft) 12%);
    color: var(--crm-text);
    border-color: var(--crm-border) !important;
}

[data-bs-theme="dark"] .crm-order-number-panel {
    background: color-mix(in srgb, var(--crm-surface) 82%, #ffffff 6%);
    color: var(--crm-text);
}

.crm-task-row {
    border: 1px solid var(--crm-border);
    border-radius: 0.75rem;
    padding: 1rem;
    background: color-mix(in srgb, var(--crm-surface) 90%, var(--crm-brand-soft) 10%);
}

.crm-task-row + .crm-task-row {
    margin-top: 0.75rem;
}

.crm-mobile-only {
    display: none;
}

.crm-desktop-actions {
    display: flex;
    gap: 0.75rem;
}

.crm-sticky-actions {
    position: sticky;
    bottom: 0;
    z-index: 20;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(8px);
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    padding: 1rem 0 calc(1rem + env(safe-area-inset-bottom));
}

.crm-task-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.crm-task-metric {
    border: 1px solid var(--crm-border);
    border-radius: 14px;
    background: color-mix(in srgb, var(--crm-surface) 92%, var(--crm-brand-soft) 8%);
    padding: 0.8rem 0.9rem;
}

.crm-task-metric__label {
    color: var(--crm-text-muted);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: 0.3rem;
}

.crm-task-metric__value {
    font-size: 1rem;
    font-weight: 700;
}

.crm-task-table td,
.crm-task-table th {
    vertical-align: middle;
}

.crm-task-title {
    font-weight: 700;
}

.crm-task-subnote {
    margin-top: 0.35rem;
    color: var(--crm-text-muted);
    font-size: 0.82rem;
}

.crm-board-col {
    min-height: 240px;
}

.crm-board-card {
    border: 1px solid var(--crm-border);
    border-radius: 12px;
    padding: 12px;
    background: var(--crm-surface);
    box-shadow: var(--crm-shadow);
}

.crm-board-card--urgent {
    border-color: color-mix(in srgb, var(--crm-danger) 32%, var(--crm-border) 68%);
}

.crm-board-card--blocked {
    border-color: color-mix(in srgb, var(--crm-warning) 36%, var(--crm-border) 64%);
}

.crm-board-card--active {
    border-color: color-mix(in srgb, var(--crm-info) 30%, var(--crm-border) 70%);
}

.crm-board-card__meta {
    color: var(--crm-text-muted);
    font-size: 0.84rem;
}

.crm-board-card__reason {
    background: color-mix(in srgb, var(--crm-warning) 12%, var(--crm-surface) 88%);
    border: 1px solid color-mix(in srgb, var(--crm-warning) 22%, var(--crm-border) 78%);
    border-radius: 10px;
    padding: 10px;
}

.crm-category-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.crm-category-pills .btn {
    border-radius: var(--crm-btn-radius);
}

.crm-search-box {
    max-width: 480px;
    margin-bottom: 1rem;
}

.crm-article-card {
    transition: box-shadow .15s, transform .15s;
    cursor: pointer;
}

.crm-article-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, .12);
    transform: translateY(-2px);
}

.crm-brand-badge {
    font-size: .75rem;
}

.crm-section-header {
    font-size: .65rem;
    letter-spacing: .08em;
    font-weight: 700;
    text-transform: uppercase;
}

.crm-article-body h6 {
    margin-top: 1.25rem;
    font-weight: 700;
}

.crm-article-body table {
    font-size: .875rem;
}

.crm-article-body .lead {
    font-size: 1rem;
}

.crm-article-body ul {
    padding-left: 1.25rem;
}

.crm-article-body ul li {
    margin-bottom: .4rem;
}

.crm-related-card {
    transition: box-shadow .15s;
    cursor: pointer;
}

.crm-related-card:hover {
    box-shadow: 0 2px 12px rgba(0, 0, 0, .1);
}

.crm-hint-pill {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    background: var(--crm-surface-muted);
    border-radius: 20px;
    padding: .2rem .65rem;
    font-size: .75rem;
    color: var(--crm-text-muted);
}

.crm-hint-pill--client {
    background: var(--crm-success-soft);
    color: var(--crm-success-ink);
}

.crm-price-input {
    width: 130px;
    font-size: 1rem;
    font-weight: 600;
}

.crm-dir-header {
    background: var(--crm-surface-muted);
    border-radius: 8px;
    padding: .6rem 1rem;
    font-weight: 700;
    font-size: .95rem;
}

.op-row-done {
    background: var(--crm-success-soft);
}

.op-row-claimed {
    background: var(--crm-warning-soft);
}

.op-row-reserved {
    background: var(--crm-surface-muted);
}

.price-cell input {
    width: 120px;
}

.dir-section-title {
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: .02em;
    padding: .5rem .75rem;
    background: var(--crm-surface-muted);
    border-radius: 6px;
    margin-bottom: .5rem;
}

.op-progress {
    height: 6px;
    border-radius: 3px;
}

.stat-card {
    border-radius: 12px;
    padding: 1rem 1.25rem;
}

.op-row-pending {
    background: transparent;
}

.norm-hint {
    font-size: .75rem;
    color: var(--crm-text-muted);
}

.stat-mini {
    border-radius: 10px;
    padding: .75rem 1rem;
}

.price-inline {
    max-width: 110px;
}

.crm-label-cell-fixed {
    width: 110px;
}

.crm-status-rail {
    min-width: 160px;
}

.crm-progress-md {
    height: 10px;
    border-radius: 6px;
}

.crm-progress-rail-80x6 {
    width: 80px;
    height: 6px;
    flex: 0 0 80px;
}

.crm-progress-input {
    max-width: 96px;
}

.crm-master-task-list {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.crm-master-tabs {
    gap: 0.5rem;
    flex-wrap: wrap;
}

.crm-master-tabs .nav-link {
    border-radius: 999px;
    padding: 0.6rem 1rem;
    font-weight: 700;
    color: var(--crm-text);
    background: var(--crm-surface);
    border: 1px solid var(--crm-border);
}

.crm-master-tabs .nav-link.active {
    background: var(--crm-brand);
    color: #fff;
    border-color: var(--crm-brand);
}

.crm-master-task-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.9rem 1rem;
    border: 1px solid var(--crm-border);
    border-radius: var(--crm-radius-md);
    background: color-mix(in srgb, var(--crm-surface) 96%, var(--crm-brand-soft) 4%);
}

.crm-master-task-row__body {
    min-width: 0;
    flex: 1 1 auto;
}

.crm-master-task-row__title {
    font-weight: 700;
}

.crm-master-task-row__meta {
    margin-top: 0.35rem;
}

.crm-master-task-row__qty {
    flex: 0 0 112px;
}

.crm-master-sticky-actions {
    position: sticky;
    bottom: 0;
    z-index: 5;
    background: var(--crm-surface);
    border-top: 1px solid var(--crm-border);
}

.crm-micro-stat-label {
    font-size: .7rem;
}

code.small {
    font-size: 0.85em;
}

.muted {
    color: var(--crm-text-muted);
}

.data-json {
    max-width: 520px;
    white-space: pre-wrap;
    word-break: break-word;
    font-size: 0.85rem;
}

.op-inactive {
    opacity: .45;
}

.price-hint {
    font-size: .75rem;
    color: var(--crm-text-muted);
}

.direction-card {
    border: 2px solid var(--crm-border);
    border-radius: 12px;
    padding: 1rem 1.25rem;
    transition: border-color .2s, background .2s;
}

.direction-card.active {
    border-color: var(--crm-info);
    background: var(--crm-info-soft);
}

.direction-label {
    font-size: 1.1rem;
    font-weight: 600;
}

.direction-full {
    font-size: 0.82rem;
    color: var(--crm-text-muted);
}

.qty-input {
    width: 90px;
    font-size: 1.2rem;
    font-weight: 600;
    text-align: center;
}

.norm-table th {
    white-space: nowrap;
    font-size: .78rem;
}

.norm-table td {
    vertical-align: middle;
    font-size: .85rem;
}

.model-col {
    width: 80px;
}

.chap-collapse {
    cursor: pointer;
    user-select: none;
}

.cat-row td {
    background: var(--bs-tertiary-bg);
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--bs-secondary-color);
    padding: .3rem .75rem;
}

.vt-tab.active {
    font-weight: 700;
}

.source-note {
    font-size: .72rem;
}

.chap-header {
    background: var(--bs-secondary-bg);
}

.chap-header:hover {
    background: var(--bs-light-bg-subtle);
}

.grade-col {
    width: 44px;
    text-align: center;
    color: var(--bs-secondary-color);
    font-size: .75rem;
}

.analytics-stat-card {
    border-left: 4px solid;
}

.analytics-stat-card--blue {
    border-color: var(--crm-info);
}

.analytics-stat-card--green {
    border-color: var(--crm-success);
}

.analytics-stat-card--orange {
    border-color: var(--crm-brand);
}

.analytics-stat-card--purple {
    border-color: var(--ctp-mauve);
}

.analytics-stat-card--red {
    border-color: var(--crm-danger);
}

.stat-val {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
}

.stat-label {
    font-size: .8rem;
    color: var(--crm-text-muted);
    margin-top: .25rem;
}

.dir-badge {
    min-width: 2.5rem;
    text-align: center;
}

.crm-progress-sm {
    height: 8px;
}

.text-purple-accent {
    color: var(--ctp-mauve);
}

.text-bronze {
    color: var(--crm-brand);
}

.crm-row-clickable {
    cursor: pointer;
}

.crm-progress-mini {
    height: 6px;
}

.crm-progress-mini--wide {
    width: 88px;
}

.crm-progress-mini--compact {
    width: 56px;
}

.crm-icon-tiny {
    font-size: .7rem;
}

.crm-icon-tiny--muted {
    opacity: .4;
}

.crm-minw-140 {
    min-width: 140px;
}

.crm-minw-150 {
    min-width: 150px;
}

.crm-minw-180 {
    min-width: 180px;
}

.crm-minw-260 {
    min-width: 260px;
}

.crm-minw-360 {
    min-width: 360px;
}

.crm-minw-420 {
    min-width: 420px;
}

.crm-minw-520 {
    min-width: 520px;
}

.crm-maxw-120 {
    max-width: 120px;
}

.crm-maxw-130 {
    max-width: 130px;
}

.crm-maxw-140 {
    max-width: 140px;
}

.crm-w-32 {
    width: 32px;
}

.crm-text-xs {
    font-size: .75rem;
}

.crm-badge-xs {
    font-size: .65rem;
}

.crm-progress-tiny {
    height: 6px;
}

.crm-login-page {
    background: linear-gradient(135deg, var(--ctp-lavender) 0%, var(--ctp-mauve) 100%); /* decorative */
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.login-card {
    background: var(--crm-surface);
    padding: 40px;
    border-radius: 10px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
    width: 100%;
    max-width: 460px;
}

.invoice-wrap {
    max-width: 900px;
    margin: 0 auto;
    background: var(--crm-surface);
    padding: 2rem;
    border: 1px solid var(--crm-border);
    border-radius: 8px;
}

.inv-title {
    font-size: 1.4rem;
    font-weight: 700;
}

.inv-section {
    border: 1px solid var(--crm-text);
}

.inv-section td,
.inv-section th {
    padding: .3rem .5rem;
    border: 1px solid var(--crm-border);
    font-size: .85rem;
}

.inv-section th {
    background: var(--crm-surface-muted);
    font-weight: 600;
}

.req-block {
    font-size: .82rem;
    line-height: 1.6;
}

.req-block--lg {
    font-size: .9rem;
}

.total-row td {
    font-weight: 700;
    font-size: 1rem;
}

.inv-total-label {
    font-size: 1.05rem;
    font-weight: 700;
}

.inv-total-value {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--crm-success-ink);
}

.inv-signatures {
    font-size: .85rem;
}

.xls-header {
    font-weight: 700;
    background: var(--crm-surface-muted);
}

.xls-total-label {
    text-align: right;
    font-weight: 700;
}

.xls-total-value {
    font-weight: 700;
}

.xls-total-row {
    font-weight: 700;
    font-size: 1.1em;
}

@media print {
    .no-print {
        display: none !important;
    }

    body {
        background: var(--crm-surface) !important;
    }

    .invoice-wrap {
        box-shadow: none !important;
        border: none !important;
    }
}

@media (max-width: 768px) {
    .crm-page-head {
        padding: 1rem;
        border-radius: var(--crm-radius-md);
    }

    .crm-order-card__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .crm-action-queue {
        grid-template-columns: 1fr;
    }

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

    .crm-task-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .crm-detail-row {
        grid-template-columns: 1fr;
        gap: 0.45rem;
    }

    .crm-rail {
        position: static;
        top: auto;
    }

    .crm-create-card {
        border-radius: 1rem;
        margin-bottom: 1rem !important;
    }

    .crm-create-card .card-header {
        font-size: 1rem;
        line-height: 1.35;
        padding: 0.9rem 1rem;
    }

    .crm-create-card .card-body {
        padding: 1rem;
    }

    .crm-task-row {
        padding: 0.9rem;
        border-radius: 0.9rem;
    }

    .crm-desktop-actions {
        display: none;
    }

    .crm-mobile-only {
        display: block;
    }

    .crm-sticky-actions .btn {
        width: 100%;
    }

    .crm-sticky-actions .btn + .btn {
        margin-top: 0.75rem;
    }
}

/* ── Motorka milestone pills ─────────────────────────────────────────────── */

.ms-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    vertical-align: middle;
    min-width: 4.4rem;
    min-height: 2rem;
    padding: 0.28rem 0.55rem;
    border: 1px solid var(--crm-border);
    border-radius: 0.38rem;
    font-size: 0.78rem;
    font-weight: 600;
    cursor: pointer;
    background: var(--crm-surface-muted);
    color: var(--crm-text-muted);
    white-space: nowrap;
    transition: opacity 0.12s;
    user-select: none;
}
.ms-pill:hover { opacity: 0.75; }
.ms-pill--ok     { background: var(--crm-success-soft); border-color: var(--crm-success); color: var(--crm-success-ink); }
.ms-pill--wait   { background: var(--crm-info-soft); border-color: var(--crm-info); color: var(--crm-info-ink); }
.ms-pill--warn   { background: var(--crm-danger-soft); border-color: var(--crm-danger); color: var(--crm-danger-ink); }
.ms-pill--salary { background: color-mix(in srgb, var(--ctp-mauve) 16%, var(--crm-surface)); border-color: var(--ctp-mauve); color: var(--ctp-mauve); }
.ms-pill--spb    { background: var(--crm-surface-muted); border-color: var(--crm-border); color: var(--crm-text-muted); }

/* Stanochka cross-reference badge in motorka list */
.ms-stanochka-link {
    display: inline-block;
    padding: 0.2rem 0.5rem;
    background: var(--crm-info-soft);
    border: 1px solid var(--crm-info);
    border-radius: 0.3rem;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--crm-info-ink);
    text-decoration: none;
    white-space: nowrap;
}
.ms-stanochka-link:hover { background: color-mix(in srgb, var(--crm-info) 20%, var(--crm-surface)); color: var(--crm-info-ink); }

.ms-flag-popup {
    position: absolute;
    z-index: 1080;
    background: var(--crm-surface);
    border: 1px solid var(--crm-border);
    border-radius: 0.5rem;
    box-shadow: 0 4px 16px rgba(0,0,0,0.14);
    padding: 0.5rem;
    display: none;
    flex-direction: column;
    gap: 0.4rem;
    width: 17rem;
}
.ms-flag-popup.is-open { display: flex; }

.ms-popup-date-row {
    display: flex;
    gap: 0.3rem;
    align-items: center;
}
.ms-popup-date-input {
    flex: 1;
    border: 1px solid var(--crm-border);
    border-radius: 0.3rem;
    padding: 0.22rem 0.4rem;
    font-size: 0.8rem;
    color: var(--crm-text);
    background: var(--crm-bg);
    min-width: 0;
}
.ms-popup-date-btn {
    flex-shrink: 0;
    width: 1.8rem;
    height: 1.8rem;
    border-radius: 0.3rem;
    border: 1px solid var(--crm-border);
    background: var(--crm-surface);
    cursor: pointer;
    font-size: 0.78rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.ms-popup-date-btn--save:hover  { background: var(--crm-success-soft); border-color: var(--crm-success); }
.ms-popup-date-btn--close:hover { background: var(--crm-surface-muted); border-color: var(--crm-border); }

.ms-popup-flags-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.ms-flag-btn {
    flex: 1 1 auto;
    min-width: 2.5rem;
    height: 1.9rem;
    border: 1.5px solid transparent;
    border-radius: 0.3rem;
    cursor: pointer;
    font-size: 0.7rem;
    font-weight: 700;
}
.ms-flag-btn--ok     { background: var(--crm-success-soft); border-color: var(--crm-success); color: var(--crm-success-ink); }
.ms-flag-btn--wait   { background: var(--crm-info-soft); border-color: var(--crm-info); color: var(--crm-info-ink); }
.ms-flag-btn--warn   { background: var(--crm-danger-soft); border-color: var(--crm-danger); color: var(--crm-danger-ink); }
.ms-flag-btn--salary { background: color-mix(in srgb, var(--ctp-mauve) 16%, var(--crm-surface)); border-color: var(--ctp-mauve); color: color-mix(in srgb, var(--ctp-mauve) 65%, var(--crm-text)); }
.ms-flag-btn--spb    { background: var(--crm-surface-muted); border-color: var(--crm-border); color: var(--crm-text); }
.ms-flag-btn--clear  {
    background: var(--crm-surface-muted);
    border-color: var(--crm-border);
    color: var(--crm-text-muted);
}

.ms-loc-badge {
    font-size: 0.68rem;
    font-weight: 700;
    padding: 0.15rem 0.45rem;
    border-radius: 0.3rem;
    display: inline-block;
}
.crm-badge-motorka {
    font-size: 75% !important;
    line-height: 1;
    padding: 0.12rem 0.34rem;
    vertical-align: baseline;
    position: relative;
    top: -0.18em;
}
.ms-loc-badge--ufa       { background: var(--crm-info-soft); color: var(--crm-info-ink); }
.ms-loc-badge--spb       { background: var(--crm-success-soft); color: var(--crm-success-ink); }

/* ── Назначение мастеров на операции (план vs факт) ── */
.op-assign { display: flex; gap: 6px; flex-shrink: 0; }
.op-assign .mbtn {
    position: relative; width: 38px; height: 38px; border-radius: 8px;
    border: 2px solid var(--crm-border); background: var(--crm-surface-muted); color: var(--crm-text-muted);
    font-weight: 700; font-size: 13px; cursor: pointer; transition: .12s;
    display: flex; align-items: center; justify-content: center;
}
.op-assign .mbtn[data-readonly="1"] { cursor: default; }
.op-assign .mbtn:hover:not([data-readonly]) { filter: brightness(.96); }
.op-assign .mbtn.assigned { border-color: var(--crm-info); color: var(--crm-info-ink); box-shadow: 0 0 0 1px var(--crm-info) inset; }
.op-assign .mbtn.work { background: var(--crm-warning-soft); border-color: var(--crm-warning); color: var(--crm-warning-ink); }
.op-assign .mbtn.done { background: var(--crm-success-soft); border-color: var(--crm-success); color: var(--crm-success-ink); }
.op-assign .mbtn.assigned.work,
.op-assign .mbtn.assigned.done { box-shadow: 0 0 0 2px var(--crm-info) inset; }
.op-assign .mbtn .dot {
    position: absolute; top: -5px; right: -5px; width: 14px; height: 14px;
    border-radius: 50%; border: 2px solid var(--crm-surface); font-size: 9px; line-height: 1;
    display: flex; align-items: center; justify-content: center;
}
.op-assign .mbtn.work .dot { background: var(--crm-warning); }
.op-assign .mbtn.done .dot { background: var(--crm-success); color: var(--crm-success-ink); }

.crm-op-fact-modal .modal-content {
    border-radius: 8px;
}

.crm-op-fact-summary {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(7rem, auto);
    gap: 0.75rem;
    padding: 0.85rem;
    border: 1px solid var(--crm-border);
    border-radius: 8px;
    background: var(--crm-surface-muted);
}

.crm-op-fact-summary > div {
    min-width: 0;
}

.crm-op-fact-summary .fw-semibold {
    overflow-wrap: anywhere;
}

@media (max-width: 575.98px) {
    .crm-op-fact-summary {
        grid-template-columns: 1fr;
    }
}

.assign-legend { display: flex; flex-wrap: wrap; gap: 6px 16px; font-size: 12px; color: var(--crm-text-muted); padding: 8px 0; }
.assign-legend .li { display: flex; align-items: center; gap: 6px; }
.assign-legend .chip { width: 20px; height: 20px; border-radius: 5px; border: 2px solid var(--crm-border); background: var(--crm-surface-muted); }
.assign-legend .chip.assigned { border-color: var(--crm-info); box-shadow: 0 0 0 1px var(--crm-info) inset; background: var(--crm-surface); }
.assign-legend .chip.work { background: var(--crm-warning-soft); border-color: var(--crm-warning); }
.assign-legend .chip.done { background: var(--crm-success-soft); border-color: var(--crm-success); }
.ms-loc-badge--outsource { background: var(--crm-danger-soft); color: var(--crm-danger-ink); }

/* ── Раздел «Помощь» (аккордеон) ── */
.help-accordion { max-width: 760px; margin: 0 auto; background: var(--crm-surface); border: 1px solid var(--crm-border); border-radius: 14px; overflow: hidden; }
.help-item { border-bottom: 1px solid var(--crm-border); }
.help-item:last-child { border-bottom: 0; }
.help-head { display: flex; align-items: center; gap: 14px; padding: 16px 18px; cursor: pointer; }
.help-ic { width: 40px; height: 40px; border-radius: 10px; background: var(--crm-info-soft); display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.help-title { font-weight: 700; font-size: 17px; color: var(--crm-text); }
.help-chev { margin-left: auto; color: var(--crm-text-muted); font-size: 24px; line-height: 1; transition: transform .15s; }
.help-body { padding: 0 18px 18px 72px; color: var(--crm-text); line-height: 1.6; }
.help-body p { margin: 0 0 10px; }
.help-tip { background: var(--crm-success-soft); border: 1px solid var(--crm-success); border-radius: 10px; padding: 10px 12px; font-size: 14px; color: var(--crm-success-ink); }
.help-item.closed .help-body { display: none; }
.help-item.closed .help-chev { transform: rotate(-90deg); }

/* ===== Станочка: компактный список заказов ===== */
.sq-table { font-size: 13px; }
.sq-table thead th {
    position: sticky; top: 0; z-index: 2;
    background: var(--sq-head-bg); font-size: 11px; text-transform: uppercase;
    letter-spacing: .02em; color: var(--sq-head-text); white-space: nowrap;
    border-bottom: 2px solid var(--sq-head-border);
}
.sq-table td { vertical-align: top; }
.sq-ordnum { font-weight: 700; font-size: 14px; text-decoration: none; }
.sq-sub { color: var(--sq-sub); font-size: 11.5px; }
.sq-line { min-height: 18px; }
.sq-chips { display: flex; gap: 5px; min-height: 18px; margin-top: 5px; }
.sq-tags  { display: flex; gap: 5px; min-height: 18px; margin-top: 5px; flex-wrap: wrap; }

.sq-chip { display: inline-flex; align-items: center; gap: 4px; font-size: 10.5px;
    line-height: 1; padding: 3px 7px; border-radius: 5px; border: 1px solid var(--sq-chip-border);
    background: var(--sq-chip-bg); color: var(--sq-chip-text); white-space: nowrap; }
.sq-chip--blue  { background: var(--sq-chip-blue-bg);  color: var(--sq-chip-blue-text);  border-color: var(--sq-chip-blue-border); }
.sq-chip--amber { background: var(--sq-chip-amber-bg); color: var(--sq-chip-amber-text); border-color: var(--sq-chip-amber-border); }
.sq-chip--green { background: var(--sq-chip-green-bg); color: var(--sq-chip-green-text); border-color: var(--sq-chip-green-border); }

.sq-track { display: grid; grid-template-columns: repeat(3, 1fr); gap: 5px; }
.sq-track .ms-pill {
    width: auto; min-width: 0; height: 30px; margin: 0;
    display: flex; align-items: center; justify-content: center; gap: 4px;
    font-size: 10.5px; line-height: 1; padding: 0 4px; border-radius: 5px;
    white-space: nowrap; overflow: hidden; box-sizing: border-box;
}
.ms-pill--auto { background: var(--sq-auto-bg); border: 1px dashed var(--sq-auto-border); color: var(--sq-auto-text); cursor: default; }
.ms-pill--cash { background: var(--sq-cash-bg); border: 1px solid var(--sq-cash-border); color: var(--sq-cash-text); }
.sq-calc { min-height: 20px; margin-top: 5px; }
.sq-payer { min-height: 18px; margin-top: 6px; font-size: 11.5px; color: var(--sq-sub); }

.sq-sum { font-weight: 700; font-size: 14px; }

.sq-make   { color: var(--sq-make); font-weight: 600; }
.sq-model  { color: var(--sq-model); }
.sq-engine { color: var(--sq-engine); }
.sq-plate  { color: var(--sq-plate); font-weight: 600; letter-spacing: .2px; }
.sq-phone  { color: var(--sq-phone); }
@media (max-width: 560px) { .help-body { padding-left: 18px; } }
