:root {
    --bg: #f5f7fa;
    --surface: #ffffff;
    --surface-2: #f9fafb;
    --ink: #172033;
    --muted: #667085;
    --line: #d7dde7;
    --line-soft: #e8edf3;
    --primary: #0b5cad;
    --primary-700: #084a8c;
    --teal: #0f766e;
    --amber: #b7791f;
    --red: #b42318;
    --green: #11845b;
    --shadow: 0 10px 24px rgba(16, 24, 40, .06);
}

* { box-sizing: border-box; }
html { background: var(--bg); }
body {
    margin: 0;
    color: var(--ink);
    background: var(--bg);
    font-family: Inter, "Segoe UI", Roboto, Arial, Helvetica, sans-serif;
    font-size: 14px;
    line-height: 1.45;
}

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

.global-topbar {
    height: 64px;
    position: sticky;
    top: 0;
    z-index: 20;
    display: grid;
    grid-template-columns: minmax(220px, 320px) minmax(0, 1fr) auto;
    align-items: center;
    gap: 18px;
    padding: 0 22px;
    background: rgba(255,255,255,.97);
    border-bottom: 1px solid var(--line);
    box-shadow: 0 2px 8px rgba(16,24,40,.05);
    backdrop-filter: blur(10px);
}

.topbar-brand {
    display: flex;
    align-items: center;
    gap: 16px;
    min-width: 0;
}

.topbar-brand img {
    width: auto;
    min-width: 80px;
    max-width: 180px;
    height: 44px;
    object-fit: contain;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    background: #fff;
    padding: 3px 8px;
}

.topbar-brand strong,
.global-topbar-title strong {
    display: block;
    color: var(--ink);
}

.topbar-brand small {
    display: block;
    color: var(--muted);
    font-size: 12px;
}

.topbar-toggle {
    width: 34px;
    height: 34px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    color: #344054;
    display: inline-grid;
    place-items: center;
    cursor: pointer;
    margin-left: 8px;
}

.workspace {
    min-height: calc(100vh - 64px);
    display: grid;
    grid-template-columns: 248px minmax(0, 1fr);
}

body.sidebar-collapsed .workspace {
    grid-template-columns: 76px minmax(0, 1fr);
}

.sidebar {
    position: sticky;
    top: 64px;
    height: calc(100vh - 64px);
    background: #101828;
    color: #e5e7eb;
    border-right: 1px solid #1f2937;
    padding: 20px 16px;
    display: flex;
    flex-direction: column;
    gap: 18px;
}

body.sidebar-collapsed .sidebar {
    padding: 20px 10px;
}

body.sidebar-collapsed .nav-caption,
body.sidebar-collapsed .app-nav a span:last-child {
    display: none;
}

body.sidebar-collapsed .app-nav > li > a {
    justify-content: center;
    padding: 0;
}

.brand {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 56px;
    padding: 8px;
}

.brand img {
    width: 48px;
    height: 48px;
    object-fit: contain;
    border-radius: 8px;
    background: #fff;
    padding: 4px;
}

.brand-mark {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    border-radius: 8px;
    background: #e8f1fb;
    color: var(--primary-700);
    font-weight: 800;
    font-size: 13px;
}

.brand strong {
    display: block;
    color: #fff;
    font-size: 15px;
    line-height: 1.2;
}

.brand small {
    display: block;
    color: #98a2b3;
    font-size: 12px;
    margin-top: 3px;
}

.nav-caption {
    color: #98a2b3;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    padding: 0 10px;
    letter-spacing: .08em;
}

.app-nav > li > a,
.uk-nav-default > li > a {
    min-height: 40px;
    display: flex;
    align-items: center;
    gap: 10px;
    color: #d0d5dd;
    border-radius: 8px;
    padding: 0 10px;
    font-weight: 600;
}

.menu-svg {
    width: 22px;
    height: 22px;
    flex: 0 0 22px;
    color: currentColor;
    opacity: .95;
}

.app-nav > li.uk-active > a,
.uk-nav-default > li.uk-active > a {
    color: #fff;
    background: #1d4f86;
}

.app-nav > li > a:hover,
.uk-nav-default > li > a:hover {
    color: #fff;
    background: #1f2937;
}

.sidebar-footer {
    margin-top: auto;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    padding: 10px;
    border-top: 1px solid #243044;
}

.sidebar-footer .uk-button-text,
.sidebar-footer .uk-button-link {
    color: #d0d5dd;
}

.content { min-width: 0; padding: 26px 30px 38px; }

.topbar-kicker {
    display: block;
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}

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

.topbar-actions form { margin: 0; }
.topbar-actions a { text-decoration: none; }
.logout-pill { cursor: pointer; }

.pill {
    min-height: 30px;
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--line);
    background: #fff;
    color: #344054;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 12px;
    font-weight: 700;
}

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

.page-head .uk-button {
    min-height: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 0 14px;
    font-size: 14px;
    line-height: 1;
    white-space: nowrap;
}

.page-head > div { min-width: 0; }

.page-head h1 {
    margin: 0;
    font-size: 24px;
    font-weight: 750;
    letter-spacing: 0;
}

.page-head span {
    color: var(--muted);
    display: block;
    margin-top: 4px;
}

.panel,
.metric,
.report-card,
.login-card {
    background: var(--surface);
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    box-shadow: var(--shadow);
}

.panel {
    padding: 18px;
}

.panel h2 {
    margin: 0 0 14px;
    font-size: 16px;
}

.panel-title,
.table-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--line-soft);
}

.panel-title {
    justify-content: flex-start;
    color: #344054;
}

.panel-title.small {
    margin-top: 2px;
}

.table-header strong,
.panel-title strong {
    display: block;
    font-size: 14px;
}

.table-header small {
    display: block;
    color: var(--muted);
    margin-top: 2px;
}

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

.metric {
    min-height: 132px;
    padding: 18px 18px 16px;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 4px;
}

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

.metric > span {
    position: absolute;
    right: 16px;
    top: 16px;
    color: var(--primary);
    opacity: .8;
}

.metric small {
    display: block;
    color: var(--muted);
    margin-bottom: 0;
    font-weight: 700;
}

.metric strong {
    display: block;
    color: var(--ink);
    font-size: 28px;
    font-weight: 780;
    line-height: 1.1;
    margin-top: 4px;
}

.metric em {
    display: block;
    color: var(--muted);
    font-style: normal;
    font-size: 12px;
    margin-top: 2px;
}

.dashboard-kpis {
    grid-template-columns: repeat(4, minmax(220px, 1fr));
}

.executive-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin: 14px 0;
}

.exec-card {
    min-height: 118px;
    display: grid;
    align-content: end;
    gap: 4px;
    position: relative;
    padding: 16px;
    border: 1px solid var(--line-soft);
    border-radius: 10px;
    background: #fff;
    box-shadow: var(--shadow);
    color: var(--ink);
    text-decoration: none;
}

.exec-card:hover {
    color: var(--ink);
    border-color: #b8c7db;
}

.exec-card > span {
    position: absolute;
    top: 14px;
    right: 14px;
    color: var(--primary);
}

.exec-card small {
    color: var(--muted);
    font-weight: 800;
}

.exec-card strong {
    font-size: 30px;
    line-height: 1;
}

.exec-card em {
    color: var(--muted);
    font-size: 12px;
    font-style: normal;
}

.exec-card.danger {
    border-left: 4px solid var(--red);
}

.exec-card.danger > span {
    color: var(--red);
}

.exec-card.success {
    border-left: 4px solid var(--green);
}

.exec-card.success > span {
    color: var(--green);
}

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

.process-step {
    min-height: 92px;
    display: grid;
    gap: 5px;
    align-content: start;
    background: #fff;
    border: 1px solid var(--line-soft);
    border-radius: 10px;
    padding: 14px;
    position: relative;
}

.process-step::after {
    content: "";
    position: absolute;
    right: -10px;
    top: 42px;
    width: 10px;
    border-top: 2px solid var(--line);
}

.process-step:last-child::after {
    display: none;
}

.process-step span {
    width: 28px;
    height: 28px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: #e8f1fb;
    color: var(--primary);
    font-weight: 900;
}

.process-step strong {
    font-size: 14px;
}

.process-step small {
    color: var(--muted);
}

.insight-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 12px;
    margin-bottom: 14px;
}

.insight-card {
    min-height: 96px;
    background: var(--surface);
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    box-shadow: var(--shadow);
    padding: 14px;
    position: relative;
}

.insight-card > span {
    position: absolute;
    right: 14px;
    top: 14px;
    color: var(--primary);
}

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

.insight-card strong {
    display: block;
    font-size: 26px;
    margin-top: 12px;
}

.compact-panel {
    margin-bottom: 14px;
}

.chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.info-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 32px;
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 5px 10px;
    color: #344054;
    background: #fff;
    font-weight: 700;
}

.info-chip strong {
    color: var(--primary);
}

.role-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
    gap: 14px;
}

.role-card {
    display: flex;
    flex-direction: column;
}

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

.role-head h2 {
    margin: 0;
}

.role-head small {
    color: var(--muted);
}

.flow-board {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 12px;
    margin-bottom: 14px;
}

.flow-step-card {
    background: #fff;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    box-shadow: var(--shadow);
    padding: 14px;
    display: grid;
    gap: 6px;
}

.flow-step-card > span {
    width: 30px;
    height: 30px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: #e8f1fb;
    color: var(--primary);
    font-weight: 900;
}

.flow-step-card strong {
    font-size: 15px;
}

.flow-step-card small,
.flow-step-card em {
    color: var(--muted);
    font-style: normal;
}

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

.quality-grid div {
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    padding: 12px;
    background: #fbfcfe;
}

.quality-grid small {
    display: block;
    color: var(--muted);
    font-weight: 800;
}

.quality-grid strong {
    display: block;
    font-size: 22px;
    margin-top: 6px;
}

.login-page {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 24px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.65), rgba(255,255,255,.45)),
        radial-gradient(circle at 20% 20%, #e8f1fb 0, transparent 34%),
        #f3f6fa;
}

.login-card {
    width: min(430px, 100%);
    padding: 30px;
}

.login-card h1 {
    margin: 0 0 8px;
    font-size: 26px;
}

.login-card p {
    color: var(--muted);
}

.login-logo {
    max-width: 180px;
    max-height: 72px;
    object-fit: contain;
    display: block;
    margin: 0 0 18px;
}

.uk-form-label {
    color: #344054;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin: 10px 0 5px;
}

.uk-input,
.uk-select,
.uk-textarea {
    min-height: 40px;
    border-radius: 7px;
    border-color: var(--line);
    color: var(--ink);
    background: #fff;
    font-size: 14px;
    margin-bottom: 10px;
}

.uk-input:focus,
.uk-select:focus,
.uk-textarea:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(11, 92, 173, .12);
}

.form-separator,
hr {
    border-top-color: var(--line-soft);
}

.uk-button {
    border-radius: 7px;
    font-weight: 750;
    text-transform: none;
    letter-spacing: 0;
}

.uk-button-primary {
    background: var(--primary);
}

.uk-button-primary:hover {
    background: var(--primary-700);
}

.uk-icon-button {
    width: 34px;
    height: 34px;
    border: 1px solid var(--line);
    background: #fff;
    color: #344054;
}

.uk-icon-button:hover {
    background: #eef5fb;
    color: var(--primary);
}

.upload-panel {
    display: grid;
    gap: 14px;
    justify-items: start;
    max-width: 720px;
    border-style: dashed;
    background: #fbfcfe;
}

.supplier-upload-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 320px);
    gap: 18px;
    align-items: center;
    background: linear-gradient(135deg, #0b5cad, #0f766e);
    color: #fff;
    border-radius: 10px;
    padding: 24px;
    margin-bottom: 14px;
    box-shadow: var(--shadow);
}

.supplier-upload-hero h2 {
    color: #fff;
    margin: 6px 0 8px;
    font-size: 26px;
}

.supplier-upload-hero p,
.supplier-upload-hero .topbar-kicker {
    color: rgba(255,255,255,.8);
}

.supplier-upload-hero p {
    margin: 0;
    max-width: 780px;
}

.supplier-help-card {
    border: 1px solid rgba(255,255,255,.24);
    border-radius: 10px;
    padding: 16px;
    background: rgba(255,255,255,.12);
}

.supplier-help-card strong,
.supplier-help-card span {
    display: block;
    color: #fff;
}

.supplier-help-card span {
    margin-top: 6px;
    color: rgba(255,255,255,.82);
}

.upload-workspace {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr);
    gap: 14px;
    align-items: start;
}

.guided-upload {
    max-width: none;
    padding: 22px;
}

.upload-dropzone {
    width: 100%;
    min-height: 210px;
    display: grid;
    place-items: center;
    text-align: center;
    gap: 8px;
    border: 2px dashed #bfd0e5;
    border-radius: 12px;
    background: #f7fbff;
    color: var(--ink);
    padding: 22px;
    cursor: pointer;
}

.upload-dropzone:hover {
    border-color: var(--primary);
    background: #eef6ff;
}

.upload-dropzone > span {
    color: var(--primary);
}

.upload-dropzone strong {
    font-size: 18px;
}

.upload-dropzone small {
    color: var(--muted);
}

.upload-dropzone input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.selected-file {
    width: 100%;
    min-height: 38px;
    display: flex;
    align-items: center;
    color: #344054;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    padding: 8px 10px;
    font-weight: 700;
}

.supplier-guidance {
    min-height: 100%;
}

.check-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 12px;
}

.check-list li {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr);
    gap: 9px;
    color: #344054;
}

.check-list span {
    color: var(--green);
}

.supplier-flow {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
    margin-top: 14px;
}

.supplier-flow div {
    border: 1px solid var(--line-soft);
    border-radius: 10px;
    background: #fff;
    padding: 14px;
    display: grid;
    gap: 5px;
}

.supplier-flow span {
    width: 28px;
    height: 28px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: #e8f1fb;
    color: var(--primary);
    font-weight: 900;
}

.supplier-flow small {
    color: var(--muted);
}

.dashboard-hero {
    min-height: 170px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(240px, 360px);
    gap: 24px;
    align-items: end;
    background: linear-gradient(135deg, #0b5cad, #0f766e);
    color: #fff;
    border-radius: 10px;
    padding: 26px;
    margin-bottom: 16px;
    box-shadow: var(--shadow);
}

.dashboard-hero .topbar-kicker,
.dashboard-hero p,
.dashboard-hero small {
    color: rgba(255,255,255,.78);
}

.dashboard-hero h1 {
    margin: 6px 0 8px;
    color: #fff;
    font-size: 30px;
}

.dashboard-hero p {
    margin: 0;
    max-width: 720px;
}

.dashboard-hero-value {
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 10px;
    padding: 18px;
}

.dashboard-hero-value strong {
    display: block;
    color: #fff;
    font-size: 28px;
    margin-top: 6px;
}

.dashboard-grid {
    display: grid;
    grid-template-columns: minmax(300px, .85fr) minmax(0, 1.4fr);
    gap: 14px;
}

.status-bars {
    display: grid;
    gap: 14px;
}

.status-row {
    display: grid;
    gap: 8px;
}

.status-row div {
    display: flex;
    justify-content: space-between;
    gap: 14px;
}

.status-row small {
    color: var(--muted);
}

.status-row span {
    height: 8px;
    min-width: 18px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--primary), var(--teal));
}

.empty-state {
    margin: 0;
    color: var(--muted);
}

.modal-card {
    width: min(760px, calc(100vw - 36px));
    border-radius: 10px;
    padding: 24px;
}

.modal-card h2 {
    margin: 0 0 16px;
    font-size: 20px;
}

.modal-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid var(--line-soft);
}

.modal-actions .uk-button {
    min-height: 38px;
    height: 38px;
    padding: 0 14px;
    line-height: 38px;
}

.data-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 0 0 12px;
    padding: 8px 0 10px;
}

.data-toolbar input {
    max-width: 320px;
    min-height: 36px;
    height: 36px;
    margin: 0;
}

.data-meta {
    color: var(--muted);
    font-size: 12px;
    font-weight: 700;
}

.data-pager {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 12px;
}

.data-pager button {
    min-width: 34px;
    height: 32px;
    border: 1px solid var(--line);
    background: #fff;
    color: #344054;
    border-radius: 7px;
    cursor: pointer;
}

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

.data-table th {
    cursor: pointer;
    user-select: none;
    padding-right: 28px;
}

.data-table th:last-child {
    cursor: default;
}

.sort-indicator {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    color: #98a2b3;
    font-size: 11px;
    font-weight: 900;
}

.data-table th.sorted .sort-indicator {
    color: var(--primary);
}

.record-view-list {
    display: grid;
    grid-template-columns: 180px minmax(0, 1fr);
    gap: 10px 14px;
}

.record-view-list dt {
    color: var(--muted);
    font-weight: 800;
}

.record-view-list dd {
    margin: 0;
    min-width: 0;
    word-break: break-word;
}

.uk-table {
    margin: 0;
}

.uk-table th {
    color: #475467;
    font-size: 11px;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: .05em;
    background: var(--surface-2);
    border-bottom: 1px solid var(--line-soft);
    white-space: nowrap;
    position: relative;
}

.uk-table td {
    vertical-align: middle;
    border-top: 1px solid var(--line-soft);
}

.uk-table tbody tr:hover {
    background: #fbfdff;
}

.status {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 3px 9px;
    border-radius: 999px;
    background: #e8f1fb;
    color: var(--primary-700);
    font-size: 12px;
    font-weight: 800;
}

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

.actions form {
    display: inline;
}

.uk-label {
    white-space: normal;
    margin: 2px;
    border-radius: 999px;
    font-weight: 750;
}

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

.report-card {
    min-height: 130px;
    padding: 18px;
    color: var(--ink);
    text-decoration: none;
    display: grid;
    gap: 8px;
    align-content: start;
}

.report-card:hover {
    color: var(--ink);
    border-color: #b8c7db;
    box-shadow: 0 12px 28px rgba(16, 24, 40, .08);
}

.report-card > span {
    color: var(--primary);
}

.report-card strong {
    font-size: 17px;
}

.report-card small {
    color: var(--muted);
}

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

.permission-grid label {
    min-height: 32px;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: #344054;
    background: #fbfcfe;
    border: 1px solid var(--line-soft);
    border-radius: 7px;
    padding: 6px 8px;
}

code {
    color: #25466a;
    background: #edf3f8;
    padding: 2px 6px;
    border-radius: 5px;
}

pre {
    white-space: pre-wrap;
    font-size: 12px;
}

.uk-alert-primary,
.uk-alert-warning,
.uk-alert-success,
.uk-alert-danger {
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 16px;
}

.uk-alert-primary {
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    color: #1e40af;
}

.uk-alert-success {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    color: #166534;
}

.uk-alert-danger {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #991b1b;
}

.uk-alert-warning {
    background: #fffbeb;
    border: 1px solid #fde68a;
    color: #92400e;
}

/* ── Settings page ───────────────────────────────────────── */
.settings-layout {
    display: grid;
    grid-template-columns: 320px minmax(0, 1fr);
    grid-template-rows: auto auto;
    gap: 16px;
    align-items: start;
}

.settings-logo-panel {
    grid-row: 1 / 3;
}

.settings-data-panel {
    grid-row: 1;
}

.settings-info-panel {
    grid-row: 2;
}

.logo-preview {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100px;
    margin-bottom: 16px;
    padding: 12px;
    background: #f9fafb;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
}

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

.logo-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    min-height: 100px;
    justify-content: center;
    margin-bottom: 16px;
    padding: 12px;
    background: #f9fafb;
    border: 1px dashed var(--line);
    border-radius: 8px;
    color: var(--muted);
}

.logo-upload-form .upload-dropzone--compact {
    min-height: 110px;
}

.remove-logo-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--red);
    margin-top: 6px;
    cursor: pointer;
}

/* ── Dashboard redesign ──────────────────────────────────────── */

.db-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--line-soft);
}

.db-header h1 {
    margin: 0 0 4px;
    font-size: 22px;
    font-weight: 750;
}

.db-header p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
}

.db-total-box {
    text-align: right;
    flex-shrink: 0;
}

.db-total-box small {
    display: block;
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
}

.db-total-box strong {
    display: block;
    font-size: 24px;
    font-weight: 780;
    color: var(--ink);
    line-height: 1.15;
    margin-top: 2px;
}

.db-total-box em {
    display: block;
    font-style: normal;
    color: var(--muted);
    font-size: 12px;
    margin-top: 2px;
}

/* Action strip */
.action-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}

.action-card {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: #fff;
    border: 1px solid var(--line-soft);
    border-radius: 10px;
    text-decoration: none;
    color: var(--ink);
    transition: box-shadow .15s, border-color .15s;
    cursor: pointer;
}

.action-card:hover {
    color: var(--ink);
    border-color: #b8c7db;
    box-shadow: 0 4px 12px rgba(16,24,40,.07);
}

.action-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: grid;
    place-items: center;
    border-radius: 10px;
    background: #f3f6fa;
    color: var(--muted);
}

.action-urgent .action-icon { background: #fef9ec; color: #d97706; }
.action-risk .action-icon   { background: #fef2f2; color: var(--red); }
.action-ready .action-icon  { background: #f0fdf4; color: var(--green); }

.action-card.action-urgent { border-left: 3px solid #d97706; }
.action-card.action-risk   { border-left: 3px solid var(--red); }
.action-card.action-ready  { border-left: 3px solid var(--green); }

.action-body { flex: 1; min-width: 0; }

.action-body strong {
    display: block;
    font-size: 22px;
    font-weight: 780;
    line-height: 1.1;
}

.action-body span {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--ink);
    margin-top: 1px;
}

.action-body small {
    display: block;
    color: var(--muted);
    font-size: 12px;
    margin-top: 1px;
}

.action-arrow { color: var(--muted); flex-shrink: 0; }


/* ── Dashboard redesign ──────────────────────────────────────── */

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

.kpi {
    background: #fff;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    padding: 14px 16px;
    border-left: 3px solid var(--line);
}

.kpi-blue  { border-left-color: #6366f1; }
.kpi-green { border-left-color: var(--green); }
.kpi-teal  { border-left-color: var(--teal); }

.kpi small {
    display: block;
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
}

.kpi strong {
    display: block;
    font-size: 26px;
    font-weight: 780;
    margin-top: 4px;
    line-height: 1;
    color: var(--ink);
}

.kpi span {
    display: block;
    color: var(--muted);
    font-size: 12px;
    margin-top: 4px;
}

/* Main grid */
.db-main-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr);
    gap: 14px;
    align-items: start;
}

.db-right-col {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

/* Pipeline */
.pipeline-stages {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 14px;
}

.pipeline-stage {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.ps-meta {
    display: flex;
    align-items: center;
    gap: 10px;
}

.ps-icon {
    flex-shrink: 0;
    color: var(--muted);
    width: 22px;
}

.ps-meta div {
    flex: 1;
    min-width: 0;
}

.ps-meta div strong {
    font-size: 18px;
    font-weight: 780;
    line-height: 1;
}

.ps-meta div small {
    display: block;
    color: var(--muted);
    font-size: 12px;
    margin-top: 2px;
}

.ps-value {
    color: var(--muted);
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
}

.ps-bar-track {
    height: 6px;
    background: var(--line-soft);
    border-radius: 999px;
    overflow: hidden;
}

.ps-bar {
    height: 100%;
    border-radius: 999px;
    transition: width .4s ease;
}

.ps-conversion {
    text-align: right;
    font-size: 11px;
    font-weight: 700;
    color: var(--muted);
    margin: 2px 0 6px;
}

.ps-conversion .conv-low {
    color: var(--red);
}

/* Quality inline */
.quality-inline {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    padding-top: 14px;
    border-top: 1px solid var(--line-soft);
}

.qi-item {
    text-align: center;
    padding: 10px 6px;
    border-radius: 8px;
    border: 1px solid var(--line-soft);
}

.qi-item strong {
    display: block;
    font-size: 20px;
    font-weight: 780;
    line-height: 1;
}

.qi-item small {
    display: block;
    font-size: 11px;
    color: var(--muted);
    margin-top: 3px;
}

.qi-ok   { background: #f0fdf4; }
.qi-ok strong { color: var(--green); }
.qi-warn { background: #fffbeb; }
.qi-warn strong { color: #d97706; }
.qi-att  { background: #fff7ed; }
.qi-att strong { color: #ea580c; }
.qi-err  { background: #fef2f2; }
.qi-err strong { color: var(--red); }

/* Supplier rank */
.supplier-rank {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.sr-row {
    display: flex;
    align-items: center;
    gap: 10px;
}

.sr-rank {
    width: 22px;
    height: 22px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: var(--line-soft);
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    flex-shrink: 0;
}

.sr-body {
    flex: 1;
    min-width: 0;
}

.sr-name-line {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 8px;
    margin-bottom: 4px;
}

.sr-name-line strong {
    font-size: 13px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.sr-name-line span {
    font-size: 12px;
    color: var(--muted);
    white-space: nowrap;
}

.sr-bar-track {
    height: 4px;
    background: var(--line-soft);
    border-radius: 999px;
    overflow: hidden;
}

.sr-bar {
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--primary), var(--teal));
}

.sr-count {
    font-size: 11px;
    color: var(--muted);
    font-weight: 700;
    white-space: nowrap;
}

/* Alert & activity lists */
.panel-alert {
    border-left: 3px solid #fde68a;
}

.alert-list,
.activity-list {
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.alert-row,
.activity-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 9px 0;
    border-bottom: 1px solid var(--line-soft);
}

.alert-row:last-child,
.activity-row:last-child {
    border-bottom: none;
}

.alert-row div,
.activity-row div {
    min-width: 0;
}

.alert-row code,
.activity-row code {
    display: block;
    font-size: 12px;
}

.alert-row small,
.activity-row small {
    display: block;
    color: var(--muted);
    font-size: 11px;
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 160px;
}

.alert-right,
.activity-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 3px;
    flex-shrink: 0;
}

.alert-right span:first-child,
.activity-right span:first-child {
    font-size: 12px;
    font-weight: 700;
    color: var(--ink);
}

/* Status badge variants */
.status-approved         { background: #dcfce7; color: #166534; }
.status-in_approval      { background: #e0e7ff; color: #4338ca; }
.status-exported_datasul { background: #ccfbf1; color: #0f766e; }
.status-attention        { background: #fff7ed; color: #c2410c; }
.status-rejected         { background: #fee2e2; color: #991b1b; }

/* ── CFDI/XML Documents page ─────────────────────────────────── */

.doc-tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.doc-tab {
    height: 34px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0 14px;
    border: 1px solid var(--line);
    background: #fff;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    color: var(--muted);
    cursor: pointer;
    transition: background .12s, color .12s, border-color .12s;
}

.doc-tab:hover { background: #f0f5fb; color: var(--ink); }
.doc-tab.active { background: var(--primary); color: #fff; border-color: var(--primary); }

.tab-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 18px;
    padding: 0 5px;
    border-radius: 999px;
    background: rgba(0,0,0,.08);
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
}

.doc-tab.active .tab-count { background: rgba(255,255,255,.25); }
.tab-count-urgent { background: #fef9ec; color: #d97706; }
.tab-count-warn   { background: #fff7ed; color: #ea580c; }
.tab-count-ok     { background: #dcfce7; color: #166534; }
.tab-count-err    { background: #fee2e2; color: #991b1b; }

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

/* Table cells */
.doc-table td, .doc-table th { vertical-align: middle; }

.td-doc { min-width: 140px; }

.uuid-short {
    font-size: 12px;
    font-family: monospace;
    color: var(--primary);
    background: #eff6ff;
    padding: 2px 6px;
    border-radius: 4px;
}

.doc-meta {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-top: 3px;
}

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

.alert-badge {
    font-size: 11px;
    font-weight: 700;
    color: #d97706;
    background: #fef9ec;
    border: 1px solid #fde68a;
    border-radius: 999px;
    padding: 1px 7px;
    cursor: help;
}

.td-date small,
.doc-table td strong + small,
.doc-table td strong ~ small {
    display: block;
    color: var(--muted);
    font-size: 11px;
    margin-top: 2px;
}

.td-value { white-space: nowrap; }
.td-value strong { display: block; }
.td-value small  { color: var(--muted); font-size: 11px; }

.step-pill {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    color: #4338ca;
    background: #e0e7ff;
    border-radius: 999px;
    padding: 2px 8px;
    white-space: nowrap;
}

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

/* SAT badges */
.sat-badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 800;
    border-radius: 999px;
    padding: 2px 8px;
    white-space: nowrap;
}

.sat-ok      { background: #dcfce7; color: #166534; }
.sat-cancel  { background: #fee2e2; color: #991b1b; }
.sat-missing { background: #f3f4f6; color: #6b7280; }
.sat-error   { background: #fef2f2; color: #b91c1c; }
.sat-none    { color: var(--muted); }

/* Inline action buttons */
.td-actions { display: flex; gap: 5px; align-items: center; white-space: nowrap; }
.inline-form { display: inline; }

.btn-detail  { color: var(--primary) !important; }
.btn-sat     { color: #6366f1 !important; }
.btn-approve { color: var(--green) !important; border-color: #bbf7d0 !important; }
.btn-reject  { color: var(--red) !important; border-color: #fecaca !important; }
.btn-datasul { color: var(--teal) !important; border-color: #99f6e4 !important; }

.uk-button-danger {
    background: var(--red);
    color: #fff;
    border-radius: 7px;
    font-weight: 750;
}

.uk-button-danger:hover { background: #9b1d17; color: #fff; }

/* Detail modal */
.detail-modal-inner { max-width: 860px; }

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

.detail-title { margin: 0 0 4px; font-size: 18px; }

.detail-uuid {
    font-size: 11px;
    word-break: break-all;
    color: var(--muted);
    background: none;
    padding: 0;
}

.detail-alerts { margin-bottom: 12px; }
.detail-alerts .uk-label { margin: 2px; }

.detail-sat {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
    padding: 10px 14px;
    background: #f9fafb;
    border-radius: 8px;
    border: 1px solid var(--line-soft);
}

.detail-sat small { color: var(--muted); font-size: 12px; }

.detail-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.detail-section h3 {
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--muted);
    margin: 0 0 10px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--line-soft);
}

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

.form-hint {
    display: block;
    color: var(--muted);
    font-size: 12px;
    margin-top: -6px;
    margin-bottom: 10px;
}

.sat-info-box {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    margin-top: 14px;
    padding: 12px 14px;
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 8px;
    color: #1e40af;
}

.sat-info-box > span { flex-shrink: 0; margin-top: 2px; }

.sat-info-box strong {
    display: block;
    font-size: 13px;
    margin-bottom: 3px;
}

.sat-info-box p {
    margin: 0;
    font-size: 12px;
    line-height: 1.5;
    color: #1e3a8a;
}

.btn-download { color: var(--teal) !important; text-decoration: none; }
.btn-download:hover { background: #f0fdfa; border-color: #99f6e4 !important; }

/* Inline SVG buttons — center the SVG inside uk-icon-button */
.uk-icon-button > svg {
    display: block;
    margin: auto;
    pointer-events: none;
}

/* ── Toast notifications ────────────────────────────────────── */

#toast-container {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 8px;
    pointer-events: none;
}

.toast {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-width: 280px;
    max-width: 420px;
    padding: 12px 16px;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    box-shadow: 0 8px 24px rgba(16,24,40,.14);
    pointer-events: all;
    animation: toast-in .25s ease;
}

.toast-out { animation: toast-out .3s ease forwards; }

@keyframes toast-in {
    from { opacity: 0; transform: translateY(12px) scale(.96); }
    to   { opacity: 1; transform: none; }
}

@keyframes toast-out {
    to { opacity: 0; transform: translateY(8px) scale(.95); }
}

.toast-success { background: #166534; color: #fff; }
.toast-error   { background: #991b1b; color: #fff; }
.toast-warning { background: #92400e; color: #fff; }
.toast-primary { background: #1e40af; color: #fff; }

.toast-close {
    flex-shrink: 0;
    background: none;
    border: none;
    color: rgba(255,255,255,.7);
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    padding: 0 2px;
}

.toast-close:hover { color: #fff; }

/* ── Row update flash ────────────────────────────────────────── */

@keyframes row-flash {
    0%   { background: #eff6ff; }
    100% { background: transparent; }
}

tr.row-updated { animation: row-flash 1.2s ease; }


/* ── Multi-file upload ───────────────────────────────────────── */

.upload-dropzone.drag-over {
    border-color: var(--primary);
    background: #e8f1fb;
    transform: scale(1.01);
}

.selected-file.files-selected {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    min-height: 38px;
    height: auto;
    padding: 8px 10px;
    align-items: flex-start;
}

.file-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    color: var(--primary);
    border-radius: 6px;
    padding: 3px 8px;
    font-size: 12px;
    font-weight: 600;
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ── Upload layout ───────────────────────────────────────────── */

.upload-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(280px, .9fr);
    gap: 16px;
    align-items: start;
}

.upload-form-panel {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

/* ── User / Supplier status badges ──────────────────────────── */

.user-status-badge {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 2px 9px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
}

.status-active   { background: #dcfce7; color: #166534; }
.status-inactive { background: #f3f4f6; color: #6b7280; }

/* ── Help page ───────────────────────────────────────────────── */

.help-layout {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 20px;
    align-items: start;
}

.help-cards {
    display: flex;
    flex-direction: column;
    gap: 8px;
    position: sticky;
    top: 80px;
}

.help-card {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 12px 14px;
    background: #fff;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    text-decoration: none;
    color: var(--ink);
    transition: border-color .12s, box-shadow .12s;
}

.help-card:hover {
    border-color: var(--primary);
    box-shadow: 0 2px 8px rgba(11,92,173,.08);
    color: var(--ink);
}

.help-card > span { color: var(--primary); margin-bottom: 4px; }
.help-card strong { font-size: 13px; }
.help-card small  { color: var(--muted); font-size: 12px; }

.help-content { display: flex; flex-direction: column; gap: 16px; }

.help-section { scroll-margin-top: 80px; }
.help-section h2 { margin: 0 0 12px; font-size: 18px; font-weight: 750; }
.help-section p  { margin: 0 0 10px; color: #344054; line-height: 1.6; }

.help-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin: 14px 0;
}

.help-info-box {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 8px;
    padding: 12px 14px;
}

.help-info-box strong { display: block; margin-bottom: 6px; font-size: 13px; }
.help-info-box p      { margin: 0; font-size: 13px; color: #344054; }
.help-info-box ul     { margin: 4px 0 0 16px; padding: 0; font-size: 12px; color: #344054; }
.help-info-box li     { margin-bottom: 3px; }

.workflow-steps {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin: 14px 0;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    overflow: hidden;
}

.workflow-step {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    padding: 14px 16px;
    border-bottom: 1px solid var(--line-soft);
    background: #fff;
}

.workflow-step:last-child { border-bottom: none; }
.workflow-step:hover { background: #f9fafb; }

.wf-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: grid;
    place-items: center;
    flex-shrink: 0;
}

.wf-body { flex: 1; min-width: 0; }
.wf-body strong { display: block; font-size: 14px; margin-bottom: 3px; }
.wf-body p      { margin: 0 0 4px; font-size: 13px; color: #344054; line-height: 1.5; }
.wf-body small  { color: var(--muted); font-size: 12px; }

.uk-accordion-title {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--ink) !important;
    padding: 12px 0 !important;
    border-bottom: 1px solid var(--line-soft);
}

.uk-accordion-content p { color: #344054; line-height: 1.6; }

/* ── Responsive additions ─────────────────────────────────────── */

@media (max-width: 1000px) {
    .upload-layout,
    .help-layout { grid-template-columns: 1fr; }
    .help-cards   { position: static; flex-direction: row; flex-wrap: wrap; }
    .help-card    { flex: 1 1 140px; }
    .help-grid    { grid-template-columns: 1fr; }
}

/* ── data-table toolbar/pager inside zero-padding panels ─── */

.panel > .data-toolbar {
    padding-left: 18px;
    padding-right: 18px;
    margin: 0;
    border-bottom: 1px solid var(--line-soft);
}

.panel > .data-pager {
    padding: 10px 18px 14px;
    margin-top: 0;
    border-top: 1px solid var(--line-soft);
}

/* Hide single-page pager */
.data-pager:has(button:only-child) { display: none; }

/* ── Responsive ─────────────────────────────────────────────── */

@media (max-width: 1000px) {
    .global-topbar {
        height: auto;
        grid-template-columns: 1fr;
        padding: 12px 16px;
    }
    .workspace { grid-template-columns: 1fr; }
    body.sidebar-collapsed .workspace { grid-template-columns: 1fr; }
    .sidebar {
        position: static;
        height: auto;
    }
    .dashboard-grid,
    .dashboard-hero,
    .supplier-upload-hero,
    .upload-workspace,
    .db-main-grid,
    .settings-layout { grid-template-columns: 1fr; }
    .settings-logo-panel,
    .settings-data-panel,
    .settings-info-panel { grid-row: auto; }
    .executive-strip,
    .process-map,
    .supplier-flow { grid-template-columns: 1fr 1fr; }
    .process-step::after { display: none; }
    .metric-grid,
    .report-grid { grid-template-columns: 1fr 1fr; }
    .action-strip { grid-template-columns: 1fr 1fr; }
    .kpi-row { grid-template-columns: 1fr 1fr; }
    .db-header { flex-direction: column; align-items: flex-start; gap: 8px; }
    .db-total-box { text-align: left; }
}

@media (max-width: 680px) {
    .content { padding: 18px; }
    .topbar-actions { justify-content: flex-start; }
    .page-head { display: block; }
    .metric-grid,
    .report-grid,
    .executive-strip,
    .process-map,
    .supplier-flow,
    .action-strip,
    .kpi-row,
    .permission-grid { grid-template-columns: 1fr; }
    .responsive-table,
    .panel .uk-table { display: block; overflow-x: auto; white-space: nowrap; }
}

/* ── Paginação de documentos ─────────────────────────────────────── */
.doc-pager { display:flex; gap:4px; justify-content:center; margin:16px 0 4px; flex-wrap:wrap; }
.doc-pager-btn {
    display:inline-flex; align-items:center; justify-content:center;
    min-width:34px; height:34px; padding:0 8px; border-radius:6px;
    border:1px solid var(--line-soft); background:#fff;
    color:var(--ink); font-size:13px; font-weight:500; text-decoration:none;
    transition:background .15s, border-color .15s;
}
.doc-pager-btn:hover { background:var(--primary-pale,#eef4ff); border-color:var(--primary); color:var(--primary); }
.doc-pager-btn.active { background:var(--primary); border-color:var(--primary); color:#fff; pointer-events:none; }
.doc-pager-ellipsis { display:inline-flex; align-items:center; height:34px; padding:0 6px; color:var(--muted); }

/* ── Tab de documentos como link ────────────────────────────────── */
a.doc-tab { text-decoration:none; }

/* ── Botão workflow (play) ──────────────────────────────────────── */
.btn-workflow { color:var(--primary) !important; border-color:#bfdbfe !important; }
.btn-workflow-urgent { color:#fff !important; background:var(--primary) !important; border-color:var(--primary) !important; }

/* ── Modal de workflow — step tracker ───────────────────────────── */
.wf-header { display:flex; justify-content:space-between; align-items:flex-start; gap:16px; margin-bottom:20px; padding-bottom:16px; border-bottom:1px solid var(--line-soft); }
.wf-header-left h3 { font-size:15px; font-weight:800; margin:0 0 4px; }
.wf-header-left code { font-size:11px; color:var(--muted); }
.wf-header-right { text-align:right; flex-shrink:0; }
.wf-header-right .wf-value { font-size:22px; font-weight:900; color:var(--ink); }
.wf-header-right small { display:block; color:var(--muted); font-size:12px; }

.wf-pipeline { display:flex; align-items:flex-start; gap:0; margin:20px 0 24px; overflow-x:auto; padding-bottom:4px; }
.wf-step { display:flex; flex-direction:column; align-items:center; flex:1; min-width:80px; position:relative; }
.wf-step:not(:last-child)::after {
    content:''; position:absolute; top:17px; left:calc(50% + 20px);
    width:calc(100% - 40px); height:2px; background:var(--line-soft);
}
.wf-step:not(:last-child).done::after,
.wf-step:not(:last-child).current::after { background:var(--primary); }
.wf-step-circle {
    width:34px; height:34px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:13px; font-weight:800; border:2px solid var(--line-soft);
    background:#fff; color:var(--muted); position:relative; z-index:1;
}
.wf-step.done   .wf-step-circle { background:var(--primary); border-color:var(--primary); color:#fff; }
.wf-step.current .wf-step-circle { background:#fff; border-color:var(--primary); color:var(--primary); box-shadow:0 0 0 4px #dbeafe; }
.wf-step-label { font-size:11px; font-weight:600; margin-top:6px; text-align:center; color:var(--muted); max-width:90px; line-height:1.3; }
.wf-step.done    .wf-step-label { color:var(--primary); }
.wf-step.current .wf-step-label { color:var(--ink); font-weight:800; }
.wf-step-here { font-size:10px; font-weight:700; color:var(--primary); margin-top:2px; }

.wf-info-row { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-bottom:20px; }
.wf-info-item { background:var(--surface,#f8fafc); border-radius:8px; padding:10px 12px; }
.wf-info-item small { display:block; font-size:11px; color:var(--muted); margin-bottom:2px; }
.wf-info-item strong { font-size:13px; }

.wf-actions { border-top:1px solid var(--line-soft); padding-top:16px; margin-top:4px; }
.wf-actions h4 { font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); margin:0 0 12px; }
.wf-action-row { display:flex; gap:10px; align-items:flex-start; flex-wrap:wrap; }
.wf-reject-area { width:100%; margin-top:12px; display:none; }
.wf-reject-area.open { display:block; }
.wf-reject-area textarea { width:100%; min-height:72px; border:1px solid var(--line-soft); border-radius:6px; padding:8px 10px; font-size:13px; resize:vertical; }
.wf-next-label { font-size:12px; color:var(--muted); align-self:center; }
