:root {
            --bs-primary: #f4511e;
            --bs-primary-rgb: 244, 81, 30;
            --bs-link-color: #f4511e;
            --bs-link-hover-color: #d84315;
            --bs-border-radius: 0.375rem;
            --ink: #18202f;
            --muted: #667085;
            --line: #d7dde8;
            --panel: #ffffff;
            --page: #f4f6f9;
            --nav: #172033;
            --nav-active: #f4511e;
            --accent: #f4511e;
            --accent-strong: #d84315;
            --accent-soft: #fff3ee;
            --accent-2: #b42318;
            --warn: #b54708;
            --good: #067647;
        }

        * {
            box-sizing: border-box;
        }

        body {
            margin: 0;
            min-height: 100vh;
            color: var(--ink);
            background: var(--page);
            font: 14px/1.45 var(--bs-font-sans-serif);
        }

        .app {
            display: grid;
            grid-template-columns: 250px 1fr;
            min-height: 100vh;
        }

        .app>aside {
            background: var(--nav);
            color: #e7edf7;
            padding: 18px 14px;
            position: sticky;
            top: 0;

        }

        .brand {
            padding: 6px 6px 18px;
            border-bottom: 1px solid rgba(255, 255, 255, .12);
            margin-bottom: 14px;
        }

        .brand img {
            display: block;
            width: 100%;
            max-width: 206px;
            height: auto;
            background: #fff;
            border-radius: 8px;
            padding: 8px;
        }

        .brand span {
            display: block;
            color: #a9b5c8;
            font-size: 12px;
            margin-top: 8px;
            padding: 0 4px;
        }

        nav button {
            width: 100%;
            min-height: 40px;
            border: 0;
            border-radius: 6px;
            color: inherit;
            background: transparent;
            text-align: left;
            padding: 10px 12px;
            cursor: pointer;
            font-weight: 600;
        }

        html[dir="rtl"] nav button,
        html[dir="rtl"] th,
        html[dir="rtl"] td {
            text-align: right;
        }

        html[dir="rtl"] .amount {
            text-align: left;
        }

        nav button:hover,
        nav button.active {
            background: var(--nav-active);
            color: #fff;
        }

        .nav-section {
            margin-top: 14px;
        }

        .nav-section:first-child {
            margin-top: 0;
        }

        .nav-heading {
            color: #a9b5c8;
            font-size: 18px;
            font-weight: 700;
            letter-spacing: .08em;
            padding: 10px 10px 6px;
            text-transform: uppercase;
        }

        main {
            min-width: 0;
        }

        header {
            min-height: 68px;
            background: #fff;
            border-bottom: 1px solid var(--line);
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 0 24px;
        }

        h1 {
            margin: 0;
            font-size: 22px;
            font-weight: 700;
        }

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

        .success-message {
            display: none;
            margin-top: 10px;
            border: 1px solid #86efac;
            border-radius: 6px;
            padding: 8px 10px;
            color: #166534;
            background: #f0fdf4;
            font-weight: 700;
        }

        .success-message.visible {
            display: block;
        }

        .content {
            padding: 22px 24px 40px;
        }

        .content-top {
            padding: 18px 24px 0;
        }

        .content-filter {
            display: inline-flex;
            align-items: center;
            gap: 8px;
        }

        .content-filter span {
            color: var(--muted);
            font-size: 13px;
            font-weight: 700;
        }

        .login-screen {
            min-height: 100vh;
            display: grid;
            place-items: center;
            padding: 24px;
            background: linear-gradient(135deg, #fff7f3, #f4f6f9);
        }

        .login-card {
            width: min(420px, 100%);
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
            padding: 28px;
            background: #fff;
            box-shadow: var(--bs-box-shadow-lg);
        }

        .login-logo {
            display: block;
            width: min(260px, 100%);
            height: auto;
            margin-bottom: 14px;
        }

        .login-card .status {
            margin-bottom: 18px;
        }

        .login-error {
            display: none;
            margin-top: 12px;
            border: 1px solid #fecaca;
            border-radius: var(--bs-border-radius);
            padding: 8px 10px;
            color: #991b1b;
            background: #fef2f2;
            font-weight: 700;
        }

        .login-error.visible {
            display: block;
        }

        .toast-stack {
            position: fixed;
            top: 18px;
            right: 18px;
            z-index: 2000;
            display: grid;
            gap: 10px;
            width: min(380px, calc(100vw - 36px));
        }

        html[dir="rtl"] .toast-stack {
            right: auto;
            left: 18px;
        }

        .app-toast {
            border: 1px solid var(--line);
            border-left: 5px solid var(--accent);
            border-radius: var(--bs-border-radius);
            padding: 12px 14px;
            color: var(--ink);
            background: #fff;
            box-shadow: var(--bs-box-shadow-lg);
            font-weight: 700;
        }

        .app-toast.success {
            border-left-color: #16a34a;
        }

        .app-toast.error {
            border-left-color: #dc2626;
        }

        .app-toast.warning {
            border-left-color: #f59e0b;
        }

        .toolbar {
            display: flex;
            gap: 10px;
            flex-wrap: wrap;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 14px;
        }

        .filter-form {
            display: flex;
            align-items: end;
            gap: 10px;
            flex-wrap: wrap;
            margin: -4px 0 14px;
            padding: 10px;
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
            background: #fff;
        }

        .filter-form label {
            display: grid;
            gap: 4px;
            min-width: min(320px, 100%);
            margin: 0;
        }

        .filter-form span {
            color: var(--muted);
            font-size: 12px;
            font-weight: 700;
        }

        .checkbox-dropdown {
            position: relative;
            display: grid;
            gap: 4px;
            min-width: 220px;
        }

        .checkbox-dropdown-toggle {
            width: 100%;
            text-align: left;
            background: #fff;
            color: var(--ink);
            border-color: var(--line);
        }

        .checkbox-dropdown-menu {
            position: absolute;
            z-index: 20;
            top: calc(100% + 4px);
            left: 0;
            width: 100%;
            max-height: 240px;
            overflow: auto;
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
            padding: 8px;
            background: #fff;
            box-shadow: var(--bs-box-shadow);
        }

        .checkbox-dropdown-menu label {
            display: flex;
            align-items: center;
            gap: 8px;
            min-width: 0;
            padding: 6px;
            border-radius: 4px;
            cursor: pointer;
        }

        .checkbox-dropdown-menu input {
            width: auto;
            min-height: auto;
            padding: 0;
        }

        .checkbox-dropdown-menu label:hover {
            background: var(--accent-soft);
        }

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

        .user-area {
            display: flex;
            align-items: center;
            gap: 8px;
            border-left: 1px solid var(--line);
            padding-left: 12px;
        }

        .user-pill {
            display: grid;
            line-height: 1.2;
        }

        .user-pill strong {
            font-size: 13px;
        }

        .user-pill span {
            color: var(--muted);
            font-size: 12px;
        }

        button.primary,
        button.secondary {
            border: 1px solid var(--accent);
            border-radius: var(--bs-border-radius);
            min-height: 36px;
            padding: 8px 12px;
            cursor: pointer;
            font-weight: 700;
            transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
        }

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

        button.primary:hover {
            border-color: var(--accent-strong);
            background: var(--accent-strong);
        }

        button.secondary {
            color: var(--accent);
            background: #fff;
        }

        button.secondary:hover {
            color: #fff;
            background: var(--accent);
        }

        .settings-tabs {
            display: flex;
            gap: 6px;
            flex-wrap: wrap;
            border-bottom: 1px solid var(--line);
            margin-bottom: 16px;
        }

        .settings-tab {
            border: 0;
            border-bottom: 3px solid transparent;
            border-radius: 0;
            padding: 10px 12px;
            color: var(--muted);
            background: transparent;
            cursor: pointer;
            font-weight: 700;
        }

        .settings-tab.active {
            border-bottom-color: var(--accent);
            color: var(--accent);
        }

        .mail-tab-panel {
            display: none;
        }

        .mail-tab-panel.active {
            display: block;
        }

        .import-export-panel {
            display: grid;
            gap: 14px;
        }

        .import-export-panel h2 {
            margin: 0;
            font-size: 1.05rem;
        }

        .template-actions,
        .import-form {
            display: flex;
            gap: 10px;
            flex-wrap: wrap;
            align-items: end;
        }

        .import-form label {
            min-width: min(360px, 100%);
        }

        .import-result {
            min-height: 24px;
        }

        .import-errors {
            margin: 8px 0 0;
            padding-left: 18px;
            color: #9f1239;
        }

        .email-template-grid textarea {
            min-height: 132px;
        }

        .icon-actions {
            display: flex;
            gap: 6px;
            justify-content: flex-end;
            white-space: nowrap;
        }

        .icon-button {
            width: 32px;
            height: 32px;
            min-height: 32px;
            padding: 0;
            display: inline-grid;
            place-items: center;
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
            color: var(--ink);
            background: #fff;
            cursor: pointer;
        }

        .icon-button:hover {
            border-color: var(--accent);
            color: var(--accent);
            background: var(--accent-soft);
        }

        .icon-button svg {
            width: 16px;
            height: 16px;
            stroke: currentColor;
            stroke-width: 2;
            fill: none;
            stroke-linecap: round;
            stroke-linejoin: round;
        }

        .customer-info-card {
            grid-column: 1 / -1;
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
            overflow: hidden;
            background: #fff;
        }

        .customer-info-card table {
            width: 100%;
            min-width: 0;
            border-collapse: collapse;
        }

        .customer-info-card th,
        .customer-info-card td {
            border: 1px solid var(--line);
            padding: 8px 10px;
            text-align: left;
            vertical-align: top;
        }

        .customer-info-card th {
            width: 220px;
            font-weight: 800;
            background: #f8fafc;
        }

        .customer-info-card .section-title th {
            background: #bfdbfe;
            color: #0f172a;
            text-align: center;
            font-size: 16px;
        }

        .customer-info-card .contact-title th {
            background: #fed7aa;
        }

        .template-preview {
            grid-column: 1 / -1;
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
            overflow: hidden;
            background: #fff;
        }

        .template-preview iframe {
            width: 100%;
            min-height: 680px;
            border: 0;
            background: #fff;
        }

        .soa-modal {
            padding: 16px;
            display: grid;
            gap: 14px;
        }

        .soa-filters {
            display: grid;
            grid-template-columns: minmax(220px, 1.5fr) minmax(150px, 1fr) minmax(150px, 1fr) auto;
            gap: 10px;
            align-items: end;
        }

        .soa-summary {
            display: grid;
            grid-template-columns: repeat(5, minmax(120px, 1fr));
            gap: 8px;
        }

        .soa-summary div {
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
            padding: 10px;
            background: #fff;
        }

        .soa-summary span {
            display: block;
            color: var(--muted);
            font-size: 12px;
        }

        .soa-summary strong {
            display: block;
            margin-top: 4px;
            font-size: 17px;
        }

        .soa-modal h3 {
            margin: 8px 0 -4px;
            font-size: 14px;
            font-weight: 800;
        }

        .soa-table-wrap {
            max-height: 220px;
            overflow: auto;
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
        }

        .soa-table {
            width: 100%;
            border-collapse: collapse;
            background: #fff;
        }

        .soa-table th,
        .soa-table td {
            padding: 8px;
            border-bottom: 1px solid var(--line);
            text-align: left;
            white-space: nowrap;
        }

        .soa-table th {
            position: sticky;
            top: 0;
            background: #f8fafc;
            z-index: 1;
        }

        .soa-table .num {
            text-align: right;
        }

        .soa-actions {
            display: flex;
            justify-content: flex-end;
            gap: 8px;
            padding-top: 4px;
        }

        .link-button {
            border: 0;
            padding: 0;
            background: transparent;
            color: var(--primary);
            font: inherit;
            font-weight: 700;
            text-align: inherit;
            cursor: pointer;
        }

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

        .company-logo-uploader {
            display: grid;
            grid-template-columns: 124px minmax(0, 1fr) auto;
            gap: 12px;
            align-items: center;
            margin: 8px 0 18px;
            padding-bottom: 16px;
            border-bottom: 1px solid var(--line);
        }

        .company-logo-preview {
            display: grid;
            place-items: center;
            min-height: 68px;
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
            background: #fff;
            overflow: hidden;
            color: var(--muted);
            font-size: 12px;
            text-align: center;
            padding: 8px;
        }

        .company-logo-preview img {
            max-width: 100%;
            max-height: 58px;
            object-fit: contain;
        }

        .logo-file-field span {
            display: block;
            margin-bottom: 6px;
            color: var(--muted);
            font-size: 12px;
            font-weight: 700;
        }

        .logo-file-field input {
            width: 100%;
        }

        input,
        select,
        textarea {
            width: 100%;
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
            min-height: 36px;
            padding: 8px 10px;
            font: inherit;
            background: #fff;
        }

        input:focus,
        select:focus,
        textarea:focus {
            border-color: rgba(var(--bs-primary-rgb), .65);
            box-shadow: 0 0 0 .2rem rgba(var(--bs-primary-rgb), .18);
            outline: 0;
        }

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

        .cards {
            display: grid;
            grid-template-columns: repeat(4, minmax(0, 1fr));
            gap: 12px;
            margin-bottom: 18px;
        }

        .two-col {
            display: grid;
            grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
            gap: 14px;
            align-items: start;
        }

        .stack {
            display: grid;
            gap: 14px;
        }

        .card,
        .panel {
            background: var(--panel);
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
            box-shadow: var(--bs-box-shadow-sm);
        }

        .card {
            padding: 16px;
        }

        .card span {
            color: var(--muted);
            display: block;
            margin-bottom: 8px;
        }

        .dashboard-toolbar {
            margin-bottom: 12px;
        }

        .dashboard-hero {
            display: grid;
            grid-template-columns: minmax(0, 1fr) minmax(180px, 260px);
            gap: 16px;
            align-items: center;
            border: 1px solid var(--line);
            border-left: 6px solid var(--bs-primary);
            background: var(--panel);
            border-radius: var(--bs-border-radius);
            padding: 18px;
            margin-bottom: 14px;
            box-shadow: var(--bs-box-shadow-sm);
        }

        .dashboard-hero.good {
            border-left-color: #168a4a;
        }

        .dashboard-hero.watch {
            border-left-color: #b7791f;
        }

        .dashboard-hero.risk {
            border-left-color: #c2410c;
        }

        .dashboard-hero span,
        .dashboard-card small,
        .dashboard-panel p {
            color: var(--muted);
        }

        .dashboard-hero strong {
            display: block;
            font-size: 28px;
            line-height: 1.1;
            margin: 4px 0 8px;
        }

        .dashboard-hero p,
        .dashboard-panel p {
            margin: 0;
        }

        .dashboard-score {
            border-left: 1px solid var(--line);
            padding-left: 16px;
        }

        .dashboard-score strong {
            font-size: 24px;
        }

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

        .dashboard-card strong {
            display: block;
            font-size: 22px;
            margin-bottom: 6px;
        }

        .dashboard-card small {
            display: block;
            line-height: 1.35;
        }

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

        .dashboard-panel {
            padding: 16px;
            overflow: hidden;
        }

        .dashboard-panel h2 {
            border: 0;
            padding: 0;
            margin: 0 0 4px;
        }

        .bar-chart {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(46px, 1fr));
            gap: 10px;
            min-height: 230px;
            align-items: end;
            padding-top: 18px;
        }

        .bar-row {
            display: grid;
            grid-template-rows: 1fr auto;
            min-height: 170px;
            gap: 8px;
            text-align: center;
            color: var(--muted);
            font-size: 11px;
        }

        .bar-pair {
            display: flex;
            align-items: end;
            justify-content: center;
            gap: 4px;
            min-height: 145px;
            border-bottom: 1px solid var(--line);
        }

        .bar-pair i,
        .chart-legend i {
            display: inline-block;
            width: 10px;
            border-radius: 4px 4px 0 0;
            background: #1f6feb;
        }

        .bar-pair i.bills,
        .chart-legend i.bills {
            background: #d97706;
        }

        .chart-legend {
            grid-column: 1 / -1;
            display: flex;
            gap: 16px;
            align-items: center;
            justify-content: center;
            color: var(--muted);
            font-size: 12px;
        }

        .chart-legend span {
            display: inline-flex;
            align-items: center;
            gap: 6px;
        }

        .activity-bars,
        .readout-list {
            display: grid;
            gap: 12px;
            margin-top: 16px;
        }

        .activity-row,
        .readout-list div {
            display: grid;
            gap: 6px;
        }

        .activity-row>div,
        .readout-list div {
            display: flex;
            justify-content: space-between;
            gap: 12px;
            align-items: baseline;
        }

        .activity-row span,
        .readout-list span {
            color: var(--muted);
        }

        .activity-row em {
            display: block;
            height: 9px;
            background: #eef2f7;
            border-radius: 999px;
            overflow: hidden;
        }

        .activity-row em i {
            display: block;
            height: 100%;
            background: #1f6feb;
            border-radius: inherit;
        }

        .card strong {
            font-size: 24px;
        }

        .panel {
            overflow: hidden;
        }

        .panel h2 {
            font-size: 16px;
            margin: 0;
            padding: 14px 16px;
            border-bottom: 1px solid var(--line);
        }

        table {
            width: 100%;
            border-collapse: collapse;
            background: #fff;
        }

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

        th {
            color: var(--muted);
            font-size: 12px;
            text-transform: uppercase;
            background: #fbfcfe;
        }

        tbody tr:hover {
            background: #f8fafc;
        }

        .role-permission-grid {
            overflow-x: auto;
        }

        .role-permission-grid table {
            min-width: 960px;
        }

        .role-permission-grid th,
        .role-permission-grid td {
            text-align: center;
            vertical-align: middle;
            white-space: nowrap;
        }

        .role-permission-grid .role-column {
            position: sticky;
            left: 0;
            z-index: 1;
            width: 150px;
            text-align: left;
            background: #fbfcfe;
        }

        html[dir="rtl"] .role-permission-grid .role-column {
            left: auto;
            right: 0;
            text-align: right;
        }

        .permission-cell input {
            width: 18px;
            height: 18px;
            accent-color: var(--accent);
            cursor: pointer;
        }

        .permission-cell select {
            width: 112px;
            min-height: 32px;
            border: 1px solid var(--line);
            border-radius: 6px;
            background: #fff;
            color: var(--ink);
            font: inherit;
            font-size: 12px;
            padding: 4px 6px;
        }

        .permission-cell select:disabled {
            color: var(--muted);
            background: #f3f5f8;
            cursor: not-allowed;
        }

        .amount {
            text-align: right;
            font-variant-numeric: tabular-nums;
        }

        tfoot td {
            border-top: 2px solid var(--line);
            background: var(--accent-soft);
            font-weight: 800;
        }

        .table-total-label {
            color: var(--ink);
            text-align: right;
        }

        .badge {
            display: inline-flex;
            align-items: center;
            min-height: 24px;
            padding: 3px 8px;
            border-radius: 6px;
            font-size: 12px;
            font-weight: 800;
            text-transform: capitalize;
            border: 1px solid transparent;
        }

        .status-open,
        .check-pass {
            background: #e8f5ee;
            color: #17623c;
            border-color: #bfe2ce;
        }

        .status-soft_closed,
        .check-warning {
            background: #fff7e6;
            color: #8a5200;
            border-color: #f2d29c;
        }

        .status-closed {
            background: #eef2ff;
            color: #3346a3;
            border-color: #c7d2fe;
        }

        .status-locked,
        .check-fail {
            background: #feecec;
            color: #a62020;
            border-color: #f4b7b7;
        }

        .action-buttons {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            min-width: 360px;
        }

        .action-buttons button {
            min-height: 32px;
            padding: 6px 9px;
            font-size: 12px;
        }

        .toolbar.compact {
            padding: 10px 14px;
            margin: 0;
            border-bottom: 1px solid var(--line);
        }

        .financial-year-workspace {
            margin-top: 14px;
        }

        .close-report-buttons {
            grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
            padding: 14px 16px;
            border-bottom: 1px solid var(--line);
        }

        .close-report-view > h2 {
            border-top: 1px solid var(--line);
        }

        .report-section {
            border-top: 1px solid var(--line);
        }

        .report-section:first-child {
            border-top: 0;
        }

        .report-section h3 {
            margin: 0;
            padding: 14px 16px 8px;
            font-size: 15px;
        }

        .report-library {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
            gap: 12px;
            margin-bottom: 16px;
        }

        .report-library h2 {
            font-size: .98rem;
            margin: 0 0 10px;
        }

        .report-buttons {
            display: grid;
            gap: 8px;
        }

        .report-buttons button {
            justify-content: flex-start;
            text-align: left;
            width: 100%;
        }

        .report-table td.report-reference {
            max-width: 260px;
            white-space: normal;
            overflow-wrap: anywhere;
            word-break: break-word;
        }

        .report-summary {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
            gap: 10px;
            margin: 10px 0 12px;
        }

        .report-summary-card {
            display: grid;
            gap: 4px;
            padding: 10px 12px;
            border: 1px solid var(--line);
            border-radius: 8px;
            background: #fff;
        }

        .report-summary-card span {
            color: var(--muted);
            font-size: 12px;
            font-weight: 800;
        }

        .report-summary-card strong {
            font-size: 18px;
            font-variant-numeric: tabular-nums;
        }

        .report-filter-panel {
            margin: 12px 0 14px;
            padding: 12px;
            border: 1px solid var(--line);
            border-radius: 8px;
            background: #fbfcfe;
        }

        .report-filter-title {
            display: flex;
            justify-content: space-between;
            gap: 12px;
            align-items: baseline;
            margin-bottom: 10px;
        }

        .report-filter-title span {
            color: var(--muted);
            font-size: 12px;
        }

        .report-filters {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
            gap: 10px;
            margin: 0;
        }

        .report-toolbar {
            display: flex;
            align-items: end;
            gap: 10px;
            flex-wrap: wrap;
            margin: 8px 0 10px;
        }

        .report-search {
            min-width: min(360px, 100%);
        }

        .report-filter-chips {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            margin: 10px 0 12px;
        }

        .report-filter-chips span {
            display: inline-flex;
            gap: 4px;
            align-items: baseline;
            max-width: 100%;
            padding: 5px 8px;
            border: 1px solid var(--line);
            border-radius: 999px;
            background: #fff;
            color: var(--muted);
            font-size: 12px;
        }

        .report-filter-chips strong {
            color: var(--ink);
            overflow-wrap: anywhere;
        }

        .report-filters label,
        .report-search label {
            display: grid;
            gap: 5px;
            color: var(--muted);
            font-size: 12px;
            font-weight: 700;
        }

        .report-filters input,
        .report-filters select,
        .report-search input {
            min-height: 36px;
        }

        .report-table-wrap {
            max-width: 100%;
            overflow: auto;
            border-top: 1px solid var(--line);
        }

        .report-table {
            min-width: 760px;
        }

        .report-table th {
            position: sticky;
            top: 0;
            z-index: 1;
        }

        th .sort-header {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            border: 0;
            background: transparent;
            color: inherit;
            padding: 0;
            font: inherit;
            font-weight: 800;
            cursor: pointer;
        }

        th .sort-header::after {
            content: "↕";
            color: var(--muted);
            font-size: 11px;
        }

        th .sort-header.asc::after {
            content: "↑";
            color: var(--accent);
        }

        th .sort-header.desc::after {
            content: "↓";
            color: var(--accent);
        }

        .report-total td {
            background: #fbfcfe;
            font-weight: 700;
        }

        .report-grand-total-wrap {
            margin-top: 10px;
            border-top: 2px solid var(--accent);
        }

        .report-grand-total td {
            background: var(--accent-soft);
            border-top: 2px solid var(--accent);
            font-weight: 800;
        }

        .badge {
            display: inline-block;
            border-radius: 999px;
            padding: 3px 8px;
            background: #eef2f6;
            color: #344054;
            font-size: 12px;
        }

        .badge.paid,
        .badge.posted {
            background: #dcfae6;
            color: var(--good);
        }

        .badge.overdue,
        .badge.void {
            background: #fee4e2;
            color: var(--accent-2);
        }

        .badge.partial,
        .badge.draft {
            background: #fef0c7;
            color: var(--warn);
        }

        dialog {
            width: min(980px, calc(100vw - 24px));
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
            padding: 0;
            box-shadow: var(--bs-box-shadow-lg);
        }

        dialog::backdrop {
            background: rgba(15, 23, 42, .45);
        }

        .modal-head,
        .modal-foot {
            padding: 14px 16px;
            border-bottom: 1px solid var(--line);
            display: flex;
            align-items: center;
            justify-content: space-between;
        }

        .modal-foot {
            border-bottom: 0;
            border-top: 1px solid var(--line);
            justify-content: flex-end;
            gap: 8px;
        }

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

        .inline-form {
            padding: 16px;
        }

        .inline-form .form-grid {
            padding: 0;
        }

        label span {
            display: block;
            color: var(--muted);
            font-size: 12px;
            font-weight: 700;
            margin-bottom: 5px;
        }

        .checkbox-field {
            display: flex;
            align-items: center;
            gap: 8px;
            min-height: 38px;
            padding-top: 18px;
        }

        .checkbox-field input {
            width: 16px;
            height: 16px;
        }

        .checkbox-field span {
            margin: 0;
            color: var(--ink);
        }

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

        .line-editor-head {
            align-items: center;
            display: flex;
            justify-content: space-between;
            gap: 12px;
            margin-bottom: 8px;
        }

        .document-line-table {
            overflow-x: auto;
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
        }

        .document-line-table table {
            margin: 0;
            min-width: 900px;
        }

        .document-line-table th,
        .document-line-table td {
            padding: 7px;
            vertical-align: middle;
        }

        .document-line-table input,
        .document-line-table select {
            min-height: 34px;
            padding: 6px 8px;
        }

        .document-line-table input[name="quantity"],
        .document-line-table input[name="unit_price"],
        .document-line-table input[name="discount_percent"],
        .document-line-table input[name="tax_amount"],
        .document-line-table input[name="line_total"] {
            text-align: right;
            width: 92px;
        }

        .document-line-table select[name="tax_code"] {
            min-width: 180px;
        }

        .document-totals {
            display: grid;
            grid-template-columns: repeat(4, minmax(0, 1fr));
            gap: 8px;
            margin-top: 10px;
        }

        .document-totals div {
            border: 1px solid var(--line);
            border-radius: var(--bs-border-radius);
            padding: 8px 10px;
            background: #f8fafc;
        }

        .document-totals span {
            color: var(--muted);
            display: block;
            font-size: 12px;
            font-weight: 700;
        }

        .document-totals strong {
            display: block;
            font-size: 15px;
            text-align: right;
        }

        .empty {
            padding: 30px 16px;
            color: var(--muted);
            text-align: center;
        }

        .ai-chat-panel {
            display: flex;
            flex-direction: column;
            min-height: 520px;
        }

        .ai-chat-log {
            display: flex;
            flex: 1;
            flex-direction: column;
            gap: 10px;
            max-height: 520px;
            overflow-y: auto;
            padding: 14px 16px;
            background: #f8fafc;
            border-bottom: 1px solid var(--line);
        }

        .ai-message {
            max-width: 78%;
            padding: 10px 12px;
            border: 1px solid var(--line);
            border-radius: 8px;
            white-space: pre-wrap;
        }

        .ai-message.assistant {
            align-self: flex-start;
            background: #fff;
        }

        .ai-message.user {
            align-self: flex-end;
            background: #e8f4f8;
            border-color: #b9dde8;
        }

        .ai-chat-form {
            display: grid;
            gap: 10px;
            padding: 14px 16px;
        }

        .floating-ai-chat {
            position: fixed;
            right: 24px;
            bottom: 24px;
            z-index: 80;
            display: flex;
            flex-direction: column;
            align-items: flex-end;
            gap: 12px;
        }

        .floating-ai-launcher {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 6px;
        }

        .floating-ai-launcher span {
            padding: 5px 9px;
            border: 1px solid var(--line);
            border-radius: 8px;
            background: #fff;
            box-shadow: 0 8px 20px rgba(15, 23, 42, .12);
            color: var(--text);
            font-size: 12px;
            font-weight: 800;
        }

        .floating-ai-launcher button {
            display: grid;
            place-items: center;
            width: 54px;
            height: 54px;
            border: 0;
            border-radius: 50%;
            background: var(--accent);
            color: #fff;
            box-shadow: 0 14px 34px rgba(15, 23, 42, .24);
            cursor: pointer;
        }

        .floating-ai-launcher button svg {
            width: 26px;
            height: 26px;
            fill: none;
            stroke: currentColor;
            stroke-width: 2;
            stroke-linecap: round;
            stroke-linejoin: round;
        }

        .floating-ai-panel {
            width: min(420px, calc(100vw - 32px));
            overflow: hidden;
            border: 1px solid var(--line);
            border-radius: 8px;
            background: #fff;
            box-shadow: 0 18px 46px rgba(15, 23, 42, .22);
        }

        .floating-ai-head {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            padding: 12px 14px;
            border-bottom: 1px solid var(--line);
        }

        .floating-ai-head .icon-button {
            width: 30px;
            height: 30px;
            font-size: 22px;
            line-height: 1;
        }

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

            .company-logo-uploader {
                grid-template-columns: 1fr;
            }

            .soa-filters,
            .soa-summary {
                grid-template-columns: 1fr;
            }

            .app>aside {
                position: relative;
                height: auto;
            }

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

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

            .two-col {
                grid-template-columns: 1fr;
            }

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

            .dashboard-score {
                border-left: 0;
                border-top: 1px solid var(--line);
                padding-left: 0;
                padding-top: 12px;
            }

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

            header {
                align-items: flex-start;
                flex-direction: column;
                gap: 6px;
                padding: 14px 16px;
            }

            .content {
                padding: 16px;
            }

            .floating-ai-chat {
                right: 16px;
                bottom: 16px;
            }
        }

        @media (max-width: 620px) {

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

            nav {
                grid-template-columns: 1fr;
            }

            table {
                min-width: 720px;
            }

            .panel {
                overflow-x: auto;
            }
        }
