:root {
    --bg: #f6f7f4;
    --panel: #ffffff;
    --ink: #1e2420;
    --muted: #657069;
    --line: #dfe5de;
    --accent: #10284f;
    --accent-dark: #0a1b36;
    --advanced-navy: #0d1f33;
    --advanced-navy-soft: #163a5b;
    --advanced-blue: #0f5ea8;
    --advanced-page: #eef3f8;
    --danger: #b42318;
    --success: #147a3c;
    --shadow: 0 18px 60px rgba(22, 34, 29, 0.12);
}

/* mobile-focus-row-hard */

* { box-sizing: border-box; }

body {
    margin: 0;
    min-height: 100vh;
    background: var(--bg);
    color: var(--ink);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-dark); }

.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    min-height: 64px;
    padding: 0 32px;
    border-bottom: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.88);
}

.brand {
    color: var(--ink);
    font-size: 1.05rem;
    font-weight: 800;
}

.topnav {
    display: flex;
    align-items: center;
    gap: 18px;
    color: var(--muted);
    font-size: 0.94rem;
}

.messages {
    display: grid;
    gap: 8px;
    width: min(1080px, calc(100% - 32px));
    margin: 16px auto 0;
}

.message {
    border: 1px solid var(--line);
    border-left: 4px solid var(--accent);
    border-radius: 8px;
    background: var(--panel);
    padding: 12px 14px;
}

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

.auth-shell {
    display: grid;
    min-height: calc(100vh - 64px);
    place-items: center;
    padding: 48px 20px;
}

.auth-panel {
    width: min(430px, 100%);
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel);
    box-shadow: var(--shadow);
    padding: 34px;
}

.eyebrow {
    margin: 0 0 10px;
    color: var(--accent);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

h1, h2, p { margin-top: 0; }

h1 {
    margin-bottom: 10px;
    font-size: clamp(2rem, 4vw, 3.1rem);
    line-height: 1;
}

h2 {
    margin-bottom: 0;
    font-size: 1.08rem;
}

.muted {
    color: var(--muted);
    line-height: 1.55;
}

.form-stack {
    display: grid;
    gap: 12px;
    margin-top: 28px;
}

label {
    color: var(--ink);
    font-size: 0.9rem;
    font-weight: 700;
}

input, select, textarea {
    width: 100%;
    height: 48px;
    border: 1px solid #cbd6cf;
    border-radius: 8px;
    background: #fbfcfb;
    color: var(--ink);
    font: inherit;
    padding: 0 14px;
}

input:focus, select:focus, textarea:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(16, 40, 79, 0.16);
    outline: none;
}

button, .button-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    border: 0;
    border-radius: 8px;
    background: var(--accent);
    color: #ffffff;
    cursor: pointer;
    font: inherit;
    font-weight: 800;
    padding: 0 18px;
}

button:hover, .button-link:hover {
    background: var(--accent-dark);
    color: #ffffff;
}

.secondary-link {
    display: inline-block;
    margin-top: 20px;
    font-weight: 700;
}

.auth-action-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 16px;
    margin-top: 18px;
}

.auth-action-links .secondary-link {
    margin-top: 0;
}

.field-error {
    margin: -4px 0 0;
    color: var(--danger);
    font-size: 0.88rem;
}

select {
    appearance: none;
}

textarea {
    min-height: 112px;
    resize: vertical;
    padding-top: 12px;
}

.form-section {
    margin-top: 24px;
    padding: 24px;
}

.asset-form {
    margin-top: 0;
}

.form-field {
    display: grid;
    gap: 7px;
}

.field-help {
    margin: -2px 0 0;
    color: var(--muted);
    font-size: 0.86rem;
}

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

.dashboard {
    width: min(1360px, calc(100% - 32px));
    margin: 0 auto;
    padding: 42px 0 64px;
}

.page-heading, .section-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.button-group {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.dashboard-section {
    margin-top: 24px;
}



.maturity-guide {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 10px;
    margin: 28px 0;
}

.maturity-guide span {
    min-height: 82px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel);
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1.35;
    padding: 12px;
}

.maturity-guide strong {
    display: block;
    color: var(--ink);
    font-size: 1.4rem;
    line-height: 1;
    margin-bottom: 8px;
}

.control-review-form {
    margin-top: 0;
}

@media (max-width: 900px) {
    .maturity-guide {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

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

.quick-start-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    margin: 28px 0;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel);
    padding: 22px;
}

.quick-start-panel h2 {
    margin-bottom: 8px;
    font-size: 1.35rem;
}

.quick-start-panel p {
    margin: 0;
    color: var(--muted);
    line-height: 1.55;
}

.quick-review-form {
    margin-top: 28px;
}

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

.quick-review-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    min-height: 92px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel);
    cursor: pointer;
    padding: 14px;
}

.quick-review-item input {
    width: 18px;
    height: 18px;
    flex: 0 0 auto;
    margin-top: 2px;
}

.quick-review-item span {
    display: grid;
    gap: 6px;
}

.quick-review-item strong {
    line-height: 1.25;
}

.quick-review-item small {
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 700;
}

.quick-review-item:has(input:checked) {
    border-color: rgba(20, 122, 60, 0.42);
    background: #edf8f1;
}

@media (max-width: 900px) {
    .quick-start-panel {
        align-items: flex-start;
        flex-direction: column;
    }

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

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

.diagnostic-panel {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    gap: 20px;
    margin: 28px 0;
    border: 1px solid var(--line);
    border-left-width: 8px;
    border-radius: 8px;
    background: var(--panel);
    padding: 22px;
}

.diagnostic-panel h2 {
    margin-bottom: 8px;
    font-size: 1.55rem;
}

.diagnostic-panel p {
    max-width: 720px;
    margin: 0;
    color: var(--muted);
    line-height: 1.55;
}

.diagnostic-facts {
    display: grid;
    grid-template-columns: repeat(2, minmax(140px, 1fr));
    gap: 10px;
    min-width: 420px;
}

.diagnostic-facts span {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fbfcfb;
    color: var(--muted);
    font-size: 0.84rem;
    font-weight: 700;
    padding: 12px;
}

.diagnostic-facts strong {
    display: block;
    color: var(--ink);
    font-size: 1.35rem;
    line-height: 1;
    margin-bottom: 5px;
}

.diagnostic-gray { border-left-color: #69716d; }
.diagnostic-green { border-left-color: var(--success); }
.diagnostic-yellow { border-left-color: #c88719; }
.diagnostic-orange { border-left-color: #d85f1f; }
.diagnostic-red { border-left-color: var(--danger); }

@media (max-width: 900px) {
    .diagnostic-panel {
        flex-direction: column;
    }

    .diagnostic-facts {
        min-width: 0;
        width: 100%;
    }
}

@media (max-width: 480px) {
    .diagnostic-facts {
        grid-template-columns: 1fr;
    }
}

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

.metric {
    min-height: 120px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel);
    padding: 20px;
}

.metric span {
    display: block;
    color: var(--muted);
    font-size: 0.88rem;
    font-weight: 700;
}

.metric strong {
    display: block;
    margin-top: 14px;
    font-size: 2.5rem;
    line-height: 1;
}

.table-section {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel);
    overflow-x: auto;
}

.table-section table {
    min-width: 1040px;
}

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

.section-heading-compact {
    padding: 0;
    border-bottom: 0;
    margin-bottom: 18px;
}

table {
    width: 100%;
    border-collapse: collapse;
}

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

th {
    color: var(--muted);
    font-size: 0.78rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

tr:last-child td { border-bottom: 0; }


.status-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #f8faf8;
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 800;
    line-height: 1;
    padding: 0 9px;
    white-space: nowrap;
}

.status-applies {
    border-color: rgba(20, 122, 60, 0.34);
    background: #edf8f1;
    color: var(--success);
}

.status-not_applicable {
    border-color: #d8ddd8;
    background: #f0f2f0;
    color: #69716d;
}

.status-pending {
    border-color: rgba(200, 135, 25, 0.34);
    background: #fff7e8;
    color: #9a620f;
}

.assessment-not_applicable td {
    background: #f8f9f8;
    color: #8a928d;
}

.assessment-not_applicable a {
    color: #69716d;
}

.assessment-not_applicable td:first-child {
    border-left: 4px solid #cfd6cf;
}

.assessment-applies td:first-child {
    border-left: 4px solid var(--success);
}

.assessment-pending td:first-child {
    border-left: 4px solid #c88719;
}

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

.quick-actions form {
    margin: 0;
}

.link-button,
.quick-actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #ffffff;
    color: var(--accent);
    cursor: pointer;
    font-size: 0.84rem;
    font-weight: 800;
    line-height: 1;
    padding: 0 9px;
}

.link-button:hover,
.quick-actions a:hover {
    border-color: var(--accent);
    background: #eef3fa;
    color: var(--accent-dark);
}

.empty-state {
    display: grid;
    gap: 12px;
    justify-items: start;
    padding: 42px 20px;
}

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

@media (max-width: 760px) {
    .topbar, .page-heading, .section-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .topbar { padding: 16px 20px; }

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

    table {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }
}

@media (max-width: 480px) {
    .auth-panel { padding: 26px 20px; }

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

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

.detail-panel {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel);
    padding: 20px;
}

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

.detail-panel h2 {
    margin-bottom: 18px;
}

.detail-panel p {
    color: var(--muted);
    line-height: 1.6;
}

dl {
    display: grid;
    gap: 10px;
    margin: 0;
}

dt {
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

dd {
    margin: 0 0 8px;
    overflow-wrap: anywhere;
}

.metric strong {
    overflow-wrap: anywhere;
}

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

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

.notice-panel {
    width: min(760px, 100%);
}

.notice-copy {
    display: grid;
    gap: 12px;
    margin: 24px 0 0;
    color: var(--muted);
    line-height: 1.6;
}

.notice-copy p {
    margin: 0;
}

.checkbox-field {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    line-height: 1.45;
}

.checkbox-field input {
    width: 18px;
    height: 18px;
    flex: 0 0 auto;
    margin-top: 2px;
}



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

@media (max-width: 760px) {
    .risk-review-grid {
        grid-template-columns: 1fr;
    }
}

.risk-review-item {
    min-height: 150px;
}

.risk-likelihood-field {
    display: grid;
    gap: 6px;
    margin-top: 8px;
}

.risk-likelihood-field span {
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 800;
}

.risk-likelihood-field select {
    height: 38px;
    font-size: 0.9rem;
    padding: 0 10px;
}


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

.wizard-steps article {
    min-height: 220px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel);
    padding: 22px;
}

.wizard-steps span {
    color: var(--accent);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.wizard-steps h2 {
    margin: 14px 0 10px;
    font-size: 1.25rem;
}

.wizard-steps p {
    margin: 0;
    color: var(--muted);
    line-height: 1.55;
}

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

    .wizard-steps article {
        min-height: 0;
    }
}

.maturity-meter {
    margin-top: 18px;
    max-width: 620px;
}

.maturity-meter-track {
    position: relative;
    height: 14px;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #eef2ef;
}

.maturity-meter-track span {
    display: block;
    width: var(--maturity-percent);
    max-width: 100%;
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, #d8c078, #75a984);
}

.maturity-meter p {
    margin-top: 8px;
    color: var(--muted);
    font-size: 0.88rem;
    font-weight: 700;
}

.button-link-light {
    border: 1px solid var(--line);
    background: #ffffff;
    color: var(--accent);
}

.button-link-light:hover {
    border-color: var(--accent);
    background: #eef3fa;
    color: var(--accent-dark);
}

.whatsapp-float {
    position: fixed;
    right: 22px;
    bottom: 22px;
    z-index: 30;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 999px;
    background: #1f8f5f;
    color: #ffffff;
    box-shadow: 0 12px 32px rgba(31, 143, 95, 0.28);
    font-weight: 900;
    letter-spacing: 0;
    padding: 0;
}

.whatsapp-float:hover {
    background: #166f4a;
    color: #ffffff;
}

@media (max-width: 560px) {
    .whatsapp-float {
        right: 16px;
        bottom: 16px;
    }
}


.whatsapp-float svg {
    width: 26px;
    height: 26px;
    fill: currentColor;
}

.inline-form {
    display: inline-flex;
    margin: 0;
}

.advanced-cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    margin: 28px 0;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--panel);
    padding: 22px;
}

.advanced-cta h2 {
    margin-bottom: 8px;
    font-size: 1.35rem;
}

.advanced-cta p {
    margin: 0;
    color: var(--muted);
    line-height: 1.55;
}

@media (max-width: 900px) {
    .advanced-cta {
        align-items: flex-start;
        flex-direction: column;
    }
}

.brand-combo {
    display: inline-flex;
    flex: 0 0 auto;
    align-items: center;
    gap: 12px;
    color: var(--ink);
    margin-right: 12px;
}

.brand-combo img {
    display: block;
    width: 128px;
    height: auto;
}

.brand-combo span {
    width: 1px;
    height: 28px;
    background: var(--line);
}

.brand-combo strong {
    color: var(--ink);
    font-size: 1.05rem;
    font-weight: 900;
    letter-spacing: 0;
}

.onboarding-brand {
    display: block;
    width: min(260px, 72vw);
    height: auto;
    margin-bottom: 18px;
}


.advanced-dashboard {
    gap: 24px;
}

.advanced-summary {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 24px;
    align-items: center;
    background: linear-gradient(135deg, #0f5ea8 0%, #143d64 100%);
    color: #ffffff;
    border-radius: 8px;
    padding: 28px;
    box-shadow: 0 18px 45px rgba(15, 94, 168, 0.18);
}

.advanced-summary h2 {
    margin: 0 0 8px;
    font-size: 1.6rem;
}

.advanced-summary p {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
}

.advanced-summary .eyebrow {
    color: rgba(255, 255, 255, 0.76);
}

.advanced-score {
    min-width: 160px;
    border: 1px solid rgba(255, 255, 255, 0.28);
    border-radius: 8px;
    padding: 18px;
    text-align: center;
}

.advanced-score strong {
    display: block;
    font-size: 2rem;
    line-height: 1;
}

.advanced-score span {
    display: block;
    margin-top: 8px;
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.88rem;
}

.advanced-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
    gap: 24px;
}

.advanced-card {
    margin: 0;
}

.risk-matrix {
    display: grid;
    grid-template-columns: 42px repeat(5, minmax(48px, 1fr));
    gap: 8px;
    align-items: stretch;
}

.matrix-axis,
.matrix-corner {
    min-height: 42px;
    display: grid;
    place-items: center;
    color: #64748b;
    font-size: 0.82rem;
    font-weight: 700;
}

.matrix-cell {
    min-height: 58px;
    border-radius: 8px;
    display: grid;
    place-items: center;
    gap: 2px;
    border: 1px solid #e2e8f0;
    background: #f8fafc;
    text-decoration: none;
}

.matrix-cell strong {
    font-size: 1.1rem;
    line-height: 1;
}

.matrix-cell span {
    color: #64748b;
    font-size: 0.76rem;
}

.matrix-empty {
    background: #f8fafc;
}

.matrix-low {
    background: #e8f7ee;
    border-color: #b7e4c7;
    color: #166534;
}

.matrix-medium {
    background: #fff7d6;
    border-color: #fde68a;
    color: #92400e;
}

.matrix-high {
    background: #ffedd5;
    border-color: #fdba74;
    color: #9a3412;
}

.matrix-critical {
    background: #fee2e2;
    border-color: #fca5a5;
    color: #991b1b;
}

.action-list,
.compact-list {
    display: grid;
    gap: 12px;
}

.action-item,
.compact-list div {
    display: grid;
    gap: 6px;
    padding: 14px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #ffffff;
}

.action-item {
    grid-template-columns: 82px minmax(0, 1fr);
}

.action-item > span {
    color: #0f5ea8;
    font-weight: 800;
    font-size: 0.78rem;
    text-transform: uppercase;
}

.action-item strong,
.compact-list strong {
    color: #0f172a;
}

.action-item p,
.compact-list span {
    margin: 0;
    color: #64748b;
    font-size: 0.9rem;
}

.compact-empty {
    padding: 10px 0;
}

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

    .advanced-score {
        width: 100%;
    }
}

@media (max-width: 640px) {
    .risk-matrix {
        grid-template-columns: 34px repeat(5, minmax(38px, 1fr));
        gap: 5px;
    }

    .matrix-cell {
        min-height: 48px;
    }

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


.advanced-filter-panel {
    display: grid;
    grid-template-columns: repeat(3, minmax(160px, 1fr)) auto;
    gap: 16px;
    align-items: end;
    padding: 18px;
    border: 1px solid #dbe5ef;
    border-radius: 8px;
    background: #ffffff;
}

.advanced-filter-panel label {
    display: block;
    margin-bottom: 6px;
    color: #475569;
    font-size: 0.82rem;
    font-weight: 800;
}

.advanced-filter-panel select {
    width: 100%;
    min-height: 42px;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    padding: 0 12px;
    background: #ffffff;
    color: #0f172a;
}

.advanced-filter-actions {
    display: flex;
    gap: 12px;
    align-items: center;
    min-height: 42px;
}

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

    .advanced-filter-actions {
        align-items: flex-start;
    }
}

@media (max-width: 640px) {
    .advanced-filter-panel {
        grid-template-columns: 1fr;
    }
}


.risk-inline-update {
    display: grid;
    grid-template-columns: minmax(150px, 1fr) minmax(120px, 150px);
    gap: 8px;
    align-items: center;
    min-width: 320px;
    max-width: 520px;
}

.risk-inline-update input,
.risk-inline-update select {
    min-height: 38px;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    padding: 0 10px;
    background: #ffffff;
    color: #0f172a;
}

.risk-inline-update button {
    min-height: 38px;
    padding: 0 12px;
    grid-column: 1 / -1;
}

@media (max-width: 900px) {
    .risk-inline-update {
        grid-template-columns: 1fr;
        min-width: 220px;
    }
}


.follow-up-overview {
    display: grid;
    gap: 18px;
}

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

.follow-up-metrics article {
    padding: 16px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #f8fafc;
}

.follow-up-metrics span {
    display: block;
    color: #64748b;
    font-size: 0.82rem;
    font-weight: 800;
}

.follow-up-metrics strong {
    display: block;
    margin-top: 6px;
    color: #0f172a;
    font-size: 1.6rem;
}

.follow-up-progress {
    display: grid;
    gap: 12px;
}

.progress-row {
    display: grid;
    grid-template-columns: 150px minmax(0, 1fr) 52px;
    gap: 12px;
    align-items: center;
}

.progress-row strong {
    display: block;
    color: #0f172a;
}

.progress-row span {
    color: #64748b;
    font-size: 0.84rem;
}

.progress-track {
    height: 12px;
    overflow: hidden;
    border-radius: 999px;
    background: #e2e8f0;
}

.progress-track span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: #0f5ea8;
}

.progress-open .progress-track span {
    background: #f97316;
}

.progress-mitigating .progress-track span {
    background: #0f5ea8;
}

.progress-closed .progress-track span {
    background: #16a34a;
}

.progress-row b {
    color: #334155;
    font-size: 0.88rem;
    text-align: right;
}

.compact-heading {
    margin-top: 8px;
}

.compact-heading h3 {
    margin: 0;
    color: #0f172a;
    font-size: 1.05rem;
}

@media (max-width: 760px) {
    .follow-up-metrics,
    .progress-row {
        grid-template-columns: 1fr;
    }

    .progress-row b {
        text-align: left;
    }
}


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

.follow-up-watchlists article {
    display: grid;
    gap: 10px;
    align-content: start;
    padding: 14px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #ffffff;
}

.follow-up-watchlists h3 {
    margin: 0;
    color: #0f172a;
    font-size: 1rem;
}

.follow-up-watchlists a {
    display: grid;
    gap: 4px;
    padding: 10px;
    border-radius: 8px;
    background: #f8fafc;
    text-decoration: none;
}

.follow-up-watchlists a:hover {
    background: #eff6ff;
}

.follow-up-watchlists strong {
    color: #0f172a;
    font-size: 0.92rem;
}

.follow-up-watchlists span,
.follow-up-watchlists p {
    margin: 0;
    color: #64748b;
    font-size: 0.84rem;
}

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


.direction-progress-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 180px;
    gap: 18px;
    align-items: center;
    padding: 18px;
    border: 1px solid #dbeafe;
    border-radius: 8px;
    background: #f8fbff;
}

.direction-progress-panel h3 {
    margin: 0 0 6px;
    color: #0f172a;
    font-size: 1.35rem;
}

.direction-progress-panel p {
    margin: 0;
    color: #64748b;
}

.direction-chart {
    width: 150px;
    aspect-ratio: 1;
    justify-self: end;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background:
        radial-gradient(circle at center, #ffffff 0 58%, transparent 59%),
        conic-gradient(#16a34a 0 var(--closed), #e2e8f0 var(--closed) 100%);
    border: 1px solid #dbeafe;
}

.direction-chart strong,
.direction-chart span {
    grid-area: 1 / 1;
    text-align: center;
}

.direction-chart strong {
    margin-top: -12px;
    color: #0f172a;
    font-size: 1.7rem;
}

.direction-chart span {
    margin-top: 34px;
    color: #64748b;
    font-size: 0.82rem;
    font-weight: 800;
}

@media (max-width: 760px) {
    .direction-progress-panel {
        grid-template-columns: 1fr;
    }

    .direction-chart {
        justify-self: start;
    }
}


.advanced-mode {
    background: var(--advanced-page);
}

.advanced-mode .topbar {
    background: var(--advanced-navy);
    border-bottom-color: #1f3349;
    position: sticky;
    top: 0;
    z-index: 80;
}

.advanced-mode .brand-combo strong,
.advanced-mode .topnav a,
.advanced-mode .topnav span {
    color: #e5edf6;
}

.advanced-mode .topnav a:hover {
    background: rgba(255, 255, 255, 0.10);
    color: #ffffff;
}

.advanced-mode .brand-combo span {
    background: #35516b;
}

.advanced-mode main {
    background:
        linear-gradient(180deg, var(--advanced-navy) 0, var(--advanced-navy-soft) 340px, var(--advanced-page) 340px, var(--advanced-page) 100%);
    min-height: calc(100vh - 76px);
    padding-top: 18px;
}

.advanced-mode .dashboard {
    background: transparent;
}

.advanced-mode .page-heading {
    color: #ffffff;
}

.advanced-mode .page-heading h1 {
    color: #ffffff;
}

.advanced-mode .advanced-heading-copy {
    margin: 6px 0 0;
    max-width: 760px;
    color: #b9c7d6;
}

.advanced-mode-label {
    display: none;
}

.advanced-mode .table-section,
.advanced-mode .advanced-filter-panel,
.advanced-mode .metric,
.advanced-mode .follow-up-overview {
    border-color: #d6e0ea;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

.advanced-mode .advanced-summary {
    background: linear-gradient(135deg, var(--advanced-blue) 0%, var(--advanced-navy-soft) 100%);
    box-shadow: 0 22px 52px rgba(15, 23, 42, 0.24);
}

.advanced-mode .risk-register-summary {
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    padding: 14px;
}

.advanced-mode .risk-register-summary article {
    border: 1px solid rgba(255, 255, 255, 0.20);
    border-radius: 8px;
    min-height: 96px;
    padding: 12px 14px;
}

.advanced-mode .risk-register-summary span {
    color: #d9ecff;
    display: block;
    font-size: 0.84rem;
    font-weight: 900;
    margin-bottom: 6px;
}

.advanced-mode .risk-register-summary strong {
    color: #ffffff;
    display: block;
    font-size: 1.55rem;
    line-height: 1;
    margin-bottom: 6px;
}

.advanced-mode .risk-register-summary p {
    font-size: 0.84rem;
    font-weight: 800;
    line-height: 1.25;
}

.advanced-mode .button-link-light {
    background: #ffffff;
    color: #0f5ea8;
}

.advanced-mode .button-link-light:hover {
    background: #e8f2fb;
}


.treatment-dashboard {
    gap: 24px;
}

.treatment-list {
    display: grid;
    gap: 18px;
}

.treatment-card {
    display: grid;
    gap: 18px;
    padding: 22px;
    border: 1px solid #d6e0ea;
    border-left: 6px solid #0f5ea8;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

.treatment-critical {
    border-left-color: #dc2626;
}

.treatment-alto {
    border-left-color: #f97316;
}

.treatment-medio {
    border-left-color: #eab308;
}

.treatment-card-heading {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 16px;
    align-items: start;
}

.treatment-card-heading span {
    color: #0f5ea8;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.treatment-card-heading h2 {
    margin: 4px 0 6px;
    color: #0f172a;
    font-size: 1.25rem;
}

.treatment-card-heading p {
    margin: 0;
    color: #64748b;
}

.treatment-card-heading > strong {
    padding: 8px 12px;
    border-radius: 999px;
    background: #eef6ff;
    color: #0f5ea8;
}

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

.treatment-grid section {
    padding: 14px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #f8fafc;
}

.treatment-grid h3 {
    margin: 0 0 10px;
    color: #0f172a;
    font-size: 1rem;
}

.treatment-grid ul,
.treatment-grid ol {
    margin: 0;
    padding-left: 20px;
    color: #334155;
}

.treatment-grid li + li {
    margin-top: 6px;
}

.treatment-grid p {
    margin: 0 0 8px;
    color: #475569;
}

@media (max-width: 820px) {
    .treatment-card-heading,
    .treatment-grid {
        grid-template-columns: 1fr;
    }

    .treatment-card-heading > strong {
        width: fit-content;
    }
}


.asset-treatment-list {
    display: grid;
    gap: 18px;
}

.asset-treatment-card {
    display: grid;
    gap: 18px;
    padding: 22px;
    border: 1px solid #d6e0ea;
    border-left: 6px solid #0f5ea8;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

.asset-treatment-heading {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 16px;
    align-items: start;
}

.asset-treatment-heading span {
    color: #0f5ea8;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.asset-treatment-heading h2 {
    margin: 4px 0 6px;
    color: #0f172a;
    font-size: 1.25rem;
}

.asset-treatment-heading p {
    margin: 0;
    color: #64748b;
}

.asset-treatment-grid,
.implementation-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.8fr);
    gap: 16px;
}

.asset-treatment-grid section {
    padding: 14px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #f8fafc;
}

.asset-treatment-grid h3 {
    margin: 0 0 10px;
    color: #0f172a;
    font-size: 1rem;
}

.risk-mini-list,
.control-suggestion-list {
    display: grid;
    gap: 10px;
}

.risk-mini-list a,
.control-suggestion-list a {
    display: grid;
    gap: 4px;
    padding: 12px;
    border-radius: 8px;
    background: #ffffff;
    text-decoration: none;
    border: 1px solid #e2e8f0;
}

.risk-mini-list a:hover,
.control-suggestion-list a:hover {
    background: #eff6ff;
}

.risk-mini-list strong,
.control-suggestion-list strong {
    color: #0f172a;
}

.risk-mini-list span,
.control-suggestion-list span {
    color: #64748b;
    font-size: 0.86rem;
}

.implementation-steps {
    margin: 0;
    padding-left: 22px;
    color: #334155;
}

.implementation-steps li + li {
    margin-top: 10px;
}

.implementation-note {
    margin: 0;
    color: #475569;
    line-height: 1.6;
}

@media (max-width: 900px) {
    .asset-treatment-heading,
    .asset-treatment-grid,
    .implementation-grid {
        grid-template-columns: 1fr;
    }

    .asset-treatment-heading .button-link {
        width: fit-content;
    }
}


.control-audit-overview {
    display: grid;
    gap: 18px;
}













.control-executive-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 180px;
    gap: 18px;
    align-items: center;
    padding: 18px;
    border: 1px solid #dbeafe;
    border-radius: 8px;
    background: #f8fbff;
}

.control-executive-panel h3 {
    margin: 0 0 6px;
    color: #0f172a;
    font-size: 1.35rem;
}

.control-executive-panel p {
    margin: 0;
    color: #64748b;
}

.control-chart {
    background:
        radial-gradient(circle at center, #ffffff 0 58%, transparent 59%),
        conic-gradient(#0f5ea8 0 var(--closed), #e2e8f0 var(--closed) 100%);
}

@media (max-width: 760px) {
    .control-executive-panel {
        grid-template-columns: 1fr;
    }
}


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

.example-card {
    display: grid;
    gap: 8px;
    padding: 14px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #f8fafc;
}

.example-card span {
    width: fit-content;
    padding: 4px 8px;
    border-radius: 999px;
    background: #e8f2fb;
    color: #0f5ea8;
    font-size: 0.74rem;
    font-weight: 900;
    text-transform: uppercase;
}

.example-card h3 {
    margin: 0;
    color: #0f172a;
    font-size: 1rem;
}

.example-card p {
    margin: 0;
    color: #475569;
}

.example-card pre {
    margin: 0;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    padding: 10px;
    border-radius: 8px;
    background: #ffffff;
    color: #334155;
    font-family: inherit;
    font-size: 0.86rem;
    border: 1px solid #e2e8f0;
}

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




.treatment-small-note {
    margin: 12px 0 0;
    color: #64748b;
    font-size: 0.84rem;
    line-height: 1.45;
}


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

.priority-controls form {
    margin: 0;
}

.priority-controls button {
    min-height: 42px;
    padding: 0 12px;
}

@media (max-width: 900px) {
    .priority-controls {
        justify-content: flex-start;
    }
}


.asset-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    min-width: 180px;
}

.asset-chip-list a,
.asset-chip-list span {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 3px 8px;
    border-radius: 999px;
    background: #eef6ff;
    color: #0f5ea8;
    font-size: 0.76rem;
    font-weight: 800;
    text-decoration: none;
    white-space: nowrap;
}

.asset-chip-list a:hover {
    background: #dbeafe;
}


.risk-inline-update input[name="note"] {
    grid-column: 1 / -1;
}


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

.control-chip-list a {
    display: grid;
    gap: 4px;
    padding: 12px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #f8fafc;
    text-decoration: none;
}

.control-chip-list a:hover {
    background: #eff6ff;
}

.control-chip-list strong {
    color: #0f172a;
}

.control-chip-list span {
    color: #64748b;
    font-size: 0.86rem;
}

.asset-form .form-field ul {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    padding: 0;
    margin: 0;
    list-style: none;
}

.asset-form .form-field li label {
    display: flex;
    gap: 8px;
    align-items: flex-start;
    padding: 10px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #f8fafc;
}

@media (max-width: 760px) {
    .control-chip-list,
    .asset-form .form-field ul {
        grid-template-columns: 1fr;
    }
}


.enabled-control-list a {
    background: #ecfdf3;
    border-color: #bbf7d0;
}

.enabled-control-list a:hover {
    background: #dcfce7;
}

.enabled-control-list span {
    color: #166534;
}


.enabled-controls-compact {
    display: grid;
    gap: 8px;
    margin-bottom: 12px;
    padding: 10px;
    border: 1px solid #bbf7d0;
    border-radius: 8px;
    background: #ecfdf3;
}

.enabled-controls-compact h4 {
    margin: 0;
    color: #166534;
    font-size: 0.88rem;
}

.enabled-controls-compact div {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.enabled-controls-compact a {
    display: inline-flex;
    padding: 4px 8px;
    border-radius: 999px;
    background: #ffffff;
    color: #166534;
    font-size: 0.78rem;
    font-weight: 800;
    text-decoration: none;
}

.enabled-controls-compact p {
    margin: 0;
    color: #166534;
    font-size: 0.84rem;
}

.suggested-control-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: stretch;
}

.enable-control-form {
    display: flex;
    align-items: stretch;
    margin: 0;
}

.enable-control-form button {
    min-height: 100%;
    padding: 0 12px;
    white-space: nowrap;
}

@media (max-width: 760px) {
    .suggested-control-row {
        grid-template-columns: 1fr;
    }

    .enable-control-form button {
        min-height: 38px;
    }
}


.enable-control-form button {
    min-height: 30px;
    padding: 4px 9px;
    border: 1px solid #bfdbfe;
    border-radius: 999px;
    background: #eff6ff;
    color: #0f5ea8;
    font-size: 0.76rem;
    font-weight: 800;
    box-shadow: none;
}

.enable-control-form button:hover {
    background: #dbeafe;
    color: #0b4f8a;
    box-shadow: none;
}


.enable-warning-panel {
    padding: 18px;
    border: 1px solid #fed7aa;
    border-left: 6px solid #f97316;
    border-radius: 8px;
    background: #fff7ed;
}

.enable-warning-panel h2 {
    margin: 0 0 8px;
    color: #0f172a;
    font-size: 1.25rem;
}

.enable-warning-panel p {
    margin: 0;
    color: #475569;
}

.enable-warning-panel strong {
    display: block;
    margin-top: 10px;
    color: #9a3412;
}

.missing-evidence-acceptance label {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    padding: 12px;
    border: 1px solid #fed7aa;
    border-radius: 8px;
    background: #fff7ed;
}

.missing-evidence-acceptance input {
    width: auto;
    margin-top: 3px;
}

.missing-evidence-acceptance span {
    color: #7c2d12;
    font-size: 0.9rem;
}


.organization-switcher {
    margin: 0;
}

.organization-switcher select {
    max-width: 220px;
    min-height: 34px;
    border: 1px solid #cbd5e1;
    border-radius: 999px;
    padding: 0 10px;
    background: #ffffff;
    color: #0f172a;
    font-weight: 800;
}

.organization-badge {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    max-width: 220px;
    padding: 0 10px;
    border-radius: 999px;
    background: #eef6ff;
    color: #0f5ea8 !important;
    font-weight: 900;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.advanced-mode .organization-switcher select {
    border-color: #35516b;
    background: #13283d;
    color: #e5edf6;
}

.advanced-mode .organization-badge {
    background: #13283d;
    color: #e5edf6 !important;
}


.invite-user-form {
    max-width: 720px;
}


.app-nav {
    gap: 14px;
}

.nav-group-label {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 8px;
    border-radius: 999px;
    background: #eef6ff;
    color: #0f5ea8 !important;
    font-size: 0.72rem;
    font-weight: 900;
    text-transform: uppercase;
}

.nav-group-advanced {
    background: #fff7ed;
    color: #9a3412 !important;
}

.user-badge {
    display: inline-flex;
    align-items: center;
    max-width: 190px;
    min-height: 32px;
    padding: 0 10px;
    border-radius: 999px;
    background: #f8fafc;
    color: #475569 !important;
    font-size: 0.86rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.advanced-mode .nav-group-label {
    background: #13283d;
    color: #b9d8f4 !important;
}

.advanced-mode .nav-group-advanced {
    background: #3b2715;
    color: #fed7aa !important;
}

.advanced-mode .user-badge {
    background: #13283d;
    color: #e5edf6 !important;
}


.mode-switch {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    font-weight: 900;
    text-decoration: none;
}

.mode-switch-advanced {
    background: #0f5ea8;
    color: #ffffff !important;
}

.mode-switch-advanced:hover {
    background: #0b4f8a;
}

.mode-switch-basic {
    background: #ffffff;
    color: #0f5ea8 !important;
}

.mode-switch-basic:hover {
    background: #e8f2fb;
}


.audit-filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.audit-filter-bar a {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid #d6e0ea;
    border-radius: 999px;
    background: #ffffff;
    color: #0f5ea8;
    font-weight: 800;
    text-decoration: none;
}

.audit-filter-bar a.active,
.audit-filter-bar a:hover {
    background: #0f5ea8;
    border-color: #0f5ea8;
    color: #ffffff;
}


.brand-combo em {
    color: #64748b;
    font-style: normal;
    font-size: 0.95rem;
    font-weight: 800;
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.advanced-mode .brand-combo em {
    color: #b9c7d6;
}






.required-marker {
    color: #dc2626;
    font-weight: 900;
}

.asset-advanced-note {
    padding: 12px;
    border: 1px solid #bfdbfe;
    border-radius: 8px;
    background: #eff6ff;
}

.asset-advanced-note strong {
    display: block;
    color: #0f172a;
}

.asset-advanced-note p {
    margin: 4px 0 0;
    color: #64748b;
    font-size: 0.9rem;
}


.danger-link {
    color: #b91c1c !important;
}

.danger-link:hover {
    color: #7f1d1d !important;
}


.risk-matrix a.matrix-cell:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.12);
}


.matrix-control-panel {
    display: grid;
    gap: 16px;
}

.matrix-control-summary {
    display: grid;
    grid-template-columns: minmax(180px, 260px) minmax(0, 1fr);
    gap: 14px;
    align-items: center;
}

.matrix-control-summary strong {
    display: block;
    color: #0f172a;
    font-size: 1.2rem;
}

.matrix-control-summary span {
    color: #64748b;
    font-size: 0.88rem;
}

.matrix-control-list {
    display: grid;
    gap: 10px;
}

.matrix-control-list a {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #f8fafc;
    text-decoration: none;
}

.matrix-control-list a:hover {
    background: #eff6ff;
}

.matrix-control-list strong {
    display: block;
    color: #0f172a;
}

.matrix-control-list span {
    color: #64748b;
    font-size: 0.86rem;
}

.matrix-control-list em {
    color: #0f5ea8;
    font-style: normal;
    font-size: 0.86rem;
    font-weight: 800;
    text-align: right;
}

@media (max-width: 760px) {
    .matrix-control-summary,
    .matrix-control-list a {
        grid-template-columns: 1fr;
    }

    .matrix-control-list em {
        text-align: left;
    }
}


.matrix-asset-list {
    display: grid;
    gap: 18px;
}

.matrix-asset-card {
    display: grid;
    gap: 16px;
    padding: 20px;
    border: 1px solid #d6e0ea;
    border-left: 6px solid #0f5ea8;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

.matrix-asset-card.priority-critica {
    border-left-color: #dc2626;
}

.matrix-asset-card.priority-alta {
    border-left-color: #f97316;
}

.matrix-asset-card.priority-media {
    border-left-color: #eab308;
}

.matrix-asset-card.priority-controlada {
    border-left-color: #16a34a;
}

.matrix-asset-heading {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 150px;
    gap: 16px;
    align-items: start;
}

.matrix-asset-heading span {
    color: #0f5ea8;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.matrix-asset-heading h2 {
    margin: 4px 0 6px;
    color: #0f172a;
    font-size: 1.25rem;
}

.matrix-asset-heading p {
    margin: 0;
    color: #64748b;
}

.matrix-asset-progress {
    display: grid;
    place-items: center;
    min-height: 92px;
    border-radius: 8px;
    background: #eff6ff;
    color: #0f5ea8;
}

.matrix-asset-progress strong {
    font-size: 1.8rem;
    line-height: 1;
}

.matrix-asset-progress span {
    color: #64748b;
    font-size: 0.78rem;
    font-weight: 800;
}

.asset-attention-strip {
    display: grid;
    gap: 4px;
    padding: 12px;
    border-radius: 8px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.asset-attention-strip strong {
    color: #0f172a;
}

.asset-attention-strip span {
    color: #64748b;
    font-size: 0.9rem;
}

.matrix-asset-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 0.85fr) minmax(300px, 0.85fr);
    gap: 14px;
}

.matrix-asset-grid section {
    padding: 14px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #f8fafc;
}

.matrix-asset-grid h3 {
    margin: 0 0 10px;
    color: #0f172a;
    font-size: 1rem;
}

.compact-control-list a {
    grid-template-columns: minmax(0, 1fr);
}

.compact-control-list em {
    text-align: left;
}

@media (max-width: 1100px) {
    .matrix-asset-grid,
    .matrix-asset-heading {
        grid-template-columns: 1fr;
    }

    .matrix-asset-progress {
        width: 150px;
    }
}


.matrix-asset-list {
    display: grid;
    gap: 18px;
}

.matrix-asset-card {
    display: grid;
    gap: 16px;
    padding: 20px;
    border: 1px solid #d6e0ea;
    border-left: 6px solid #0f5ea8;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

.matrix-asset-card.priority-critica {
    border-left-color: #dc2626;
}

.matrix-asset-card.priority-alta {
    border-left-color: #f97316;
}

.matrix-asset-card.priority-media {
    border-left-color: #eab308;
}

.matrix-asset-card.priority-controlada {
    border-left-color: #16a34a;
}

.matrix-asset-heading {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 150px;
    gap: 16px;
    align-items: start;
}

.matrix-asset-heading span {
    color: #0f5ea8;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.matrix-asset-heading h2 {
    margin: 4px 0 6px;
    color: #0f172a;
    font-size: 1.25rem;
}

.matrix-asset-heading p {
    margin: 0;
    color: #64748b;
}

.matrix-asset-progress {
    display: grid;
    place-items: center;
    min-height: 92px;
    border-radius: 8px;
    background: #eff6ff;
    color: #0f5ea8;
}

.matrix-asset-progress strong {
    font-size: 1.8rem;
    line-height: 1;
}

.matrix-asset-progress span {
    color: #64748b;
    font-size: 0.78rem;
    font-weight: 800;
}

.asset-attention-strip {
    display: grid;
    gap: 4px;
    padding: 12px;
    border-radius: 8px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.asset-attention-strip strong {
    color: #0f172a;
}

.asset-attention-strip span {
    color: #64748b;
    font-size: 0.9rem;
}

.matrix-asset-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 0.85fr) minmax(300px, 0.85fr);
    gap: 14px;
}

.matrix-asset-grid section {
    padding: 14px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #f8fafc;
}

.matrix-asset-grid h3 {
    margin: 0 0 10px;
    color: #0f172a;
    font-size: 1rem;
}

.compact-control-list a {
    grid-template-columns: minmax(0, 1fr);
}

.compact-control-list em {
    text-align: left;
}

@media (max-width: 1100px) {
    .matrix-asset-grid,
    .matrix-asset-heading {
        grid-template-columns: 1fr;
    }

    .matrix-asset-progress {
        width: 150px;
    }
}


.coverage-badge-link {
    text-decoration: none;
    color: inherit;
    transition: transform 0.16s ease, box-shadow 0.16s ease;
}

.coverage-badge-link:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 32px rgba(15, 94, 168, 0.16);
}

.coverage-badge small {
    display: block;
    margin-top: 6px;
    color: #0f5ea8;
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: none;
}

.asset-treatment-list {
    display: grid;
    gap: 18px;
}

.asset-priority-note {
    display: grid;
    gap: 4px;
    margin: 18px 0;
    padding: 14px 16px;
    border: 1px solid #dfe7f1;
    border-radius: 8px;
    background: #f8fafc;
}

.asset-priority-note span {
    color: #667792;
}

.compact-list {
    display: grid;
    gap: 10px;
}

.compact-list article {
    padding: 12px;
    border: 1px solid #dfe7f1;
    border-radius: 8px;
    background: #fff;
}

.compact-list article strong,
.compact-list article span,
.compact-list article a {
    display: block;
}

.compact-list article span {
    margin-top: 4px;
    color: #667792;
}

.compact-list article a {
    margin-top: 8px;
    color: #0f5ea8;
    font-weight: 800;
    text-decoration: none;
}


/* RESTORE_ASSET_TREATMENT_LAYOUT_START */
.advanced-mode .metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(160px, 1fr));
    gap: 14px;
    margin: 18px 0 22px;
}

.advanced-mode .metric-grid article {
    display: grid;
    gap: 8px;
    min-height: 96px;
    padding: 18px 20px;
    border: 1px solid #dbe4f0;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 12px 28px rgba(15, 40, 79, 0.08);
}

.advanced-mode .metric-grid article span {
    color: #64748b;
    font-weight: 800;
}

.advanced-mode .metric-grid article strong {
    color: #172033;
    font-size: 2rem;
    line-height: 1;
}

.advanced-mode .asset-treatment-list {
    display: grid;
    gap: 22px;
}

.advanced-mode .matrix-asset-card {
    position: relative;
    display: block;
    padding: 26px 28px 28px;
    border: 1px solid #dbe4f0;
    border-left: 8px solid #0f5ea8;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 16px 38px rgba(15, 40, 79, 0.10);
}

.advanced-mode .matrix-asset-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 24px;
    margin-bottom: 18px;
}

.advanced-mode .matrix-asset-header h2 {
    margin: 4px 0 6px;
    color: #101828;
    font-size: 1.45rem;
    line-height: 1.15;
}

.advanced-mode .coverage-badge {
    display: grid;
    gap: 4px;
    min-width: 150px;
    max-width: 180px;
    padding: 12px 14px;
    border-radius: 8px;
    background: #eaf1fb;
    text-align: center;
    text-decoration: none;
}

.advanced-mode .coverage-badge strong {
    color: #0f5ea8;
    font-size: 2rem;
    line-height: 1;
}

.advanced-mode .coverage-badge span {
    color: #667792;
    font-size: 0.82rem;
    font-weight: 900;
    line-height: 1.05;
    text-transform: uppercase;
}

.advanced-mode .coverage-badge small {
    color: #0f5ea8;
    font-size: 0.78rem;
    font-weight: 900;
}

.advanced-mode .asset-priority-note {
    display: grid;
    gap: 4px;
    margin: 14px 0 18px;
    padding: 14px 16px;
    border: 1px solid #dfe7f1;
    border-radius: 8px;
    background: #f8fafc;
}

.advanced-mode .asset-priority-note span {
    color: #667792;
}

.advanced-mode .matrix-asset-columns {
    display: grid;
    grid-template-columns: minmax(280px, 1.15fr) minmax(260px, 1fr) minmax(280px, 1fr);
    gap: 16px;
    align-items: stretch;
}

.advanced-mode .matrix-asset-columns > section {
    min-width: 0;
    padding: 18px;
    border: 1px solid #dfe7f1;
    border-radius: 8px;
    background: #f8fafc;
}

.advanced-mode .matrix-asset-columns h3 {
    margin: 0 0 12px;
    color: #101828;
    font-size: 1.05rem;
}

.advanced-mode .compact-list {
    display: grid;
    gap: 10px;
}

.advanced-mode .compact-list article {
    padding: 12px;
    border: 1px solid #dfe7f1;
    border-radius: 8px;
    background: #fff;
}

.advanced-mode .compact-list article strong,
.advanced-mode .compact-list article span,
.advanced-mode .compact-list article a {
    display: block;
}

.advanced-mode .compact-list article span {
    margin-top: 4px;
    color: #667792;
}

.advanced-mode .compact-list article a {
    margin-top: 8px;
    color: #0f5ea8;
    font-weight: 900;
    text-decoration: none;
}

@media (max-width: 980px) {
    .advanced-mode .metric-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .advanced-mode .matrix-asset-header {
        display: grid;
    }

    .advanced-mode .coverage-badge {
        max-width: none;
    }

    .advanced-mode .matrix-asset-columns {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .advanced-mode .metric-grid {
        grid-template-columns: 1fr;
    }

    .advanced-mode .matrix-asset-card {
        padding: 20px 18px;
    }
}
/* RESTORE_ASSET_TREATMENT_LAYOUT_END */



.report-cover {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 24px;
    padding: 34px 38px;
    border-radius: 8px;
    background: linear-gradient(135deg, #081827, #12385d);
    color: #fff;
}

.report-cover h1 {
    margin: 6px 0;
    color: #fff;
    font-size: 2.7rem;
}

.report-cover p,
.report-cover .eyebrow {
    color: #dbeafe;
}

.report-executive {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    margin-top: 18px;
    padding: 26px 30px;
    border: 1px solid #dbe4f0;
    border-radius: 8px;
    background: #fff;
}

.report-executive h2 {
    max-width: 860px;
    margin: 0;
    color: #101828;
}

.report-score {
    display: grid;
    place-items: center;
    min-width: 160px;
    padding: 16px;
    border-radius: 8px;
    background: #eaf1fb;
    text-align: center;
}

.report-score strong {
    color: #0f5ea8;
    font-size: 2.4rem;
}

.report-score span {
    color: #667792;
    font-weight: 900;
    text-transform: uppercase;
}

.report-kpis,
.report-columns {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-top: 18px;
}

.report-kpis article,
.report-section {
    padding: 22px;
    border: 1px solid #dbe4f0;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 12px 28px rgba(15, 40, 79, 0.07);
}

.report-kpis span {
    color: #667792;
    font-weight: 900;
}

.report-kpis strong,
.report-big-number {
    display: block;
    margin-top: 8px;
    color: #101828;
    font-size: 2.1rem;
}

.report-section {
    margin-top: 18px;
}

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

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

.section-heading {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 16px;
}

.section-heading h2 {
    margin: 0;
}

.section-heading p {
    margin: 0;
    color: #667792;
}

.report-risk-matrix {
    display: grid;
    grid-template-columns: repeat(5, minmax(80px, 1fr));
    gap: 8px;
}

.matrix-mini-cell {
    display: grid;
    place-items: center;
    min-height: 74px;
    border: 1px solid #dbe4f0;
    border-radius: 8px;
    background: #f8fafc;
}

.matrix-mini-cell strong {
    color: #101828;
    font-size: 1.5rem;
}

.matrix-mini-cell span {
    color: #667792;
    font-size: 0.82rem;
    font-weight: 800;
}

.matrix-mini-cell.level-15,
.matrix-mini-cell.level-16 {
    background: #fff3cd;
    border-color: #f7d774;
}

.matrix-mini-cell.level-20,
.matrix-mini-cell.level-25 {
    background: #fde2e2;
    border-color: #fb8b8b;
}

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

.report-table table {
    width: 100%;
    border-collapse: collapse;
}

.report-table th,
.report-table td {
    padding: 12px;
    border-bottom: 1px solid #e5edf5;
    text-align: left;
}

.report-table th {
    color: #667792;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.report-table td span,
.report-list span {
    color: #667792;
}

.report-list {
    display: grid;
    gap: 10px;
}

.report-list article,
.next-steps article {
    padding: 12px;
    border: 1px solid #e5edf5;
    border-radius: 8px;
    background: #f8fafc;
}

.next-steps {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

@media (max-width: 900px) {
    .report-cover,
    .report-executive,
    .section-heading {
        display: grid;
    }

    .report-kpis,
    .report-columns,
    .report-columns.three,
    .next-steps {
        grid-template-columns: 1fr;
    }
}


/* REPORT_PRINT_STYLES_START */
.report-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
    align-items: center;
}

.report-actions form {
    margin: 0;
}

@media print {
    @page {
        size: A4 landscape;
        margin: 8mm;
    }

    body {
        background: #fff !important;
        color: #111827 !important;
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }

    .topbar,
    .messages,
    .whatsapp-float,
    .report-actions {
        display: none !important;
    }

    main {
        padding: 0 !important;
        max-width: none !important;
    }

    .report-cover,
    .report-executive,
    .report-kpis article,
    .report-section {
        box-shadow: none !important;
        break-inside: avoid;
        page-break-inside: avoid;
    }

    .report-cover {
        padding: 18px 22px !important;
    }

    .report-cover h1 {
        font-size: 2rem !important;
    }

    .report-executive {
        margin-top: 10px !important;
        padding: 16px 18px !important;
    }

    .report-kpis,
    .report-columns,
    .report-columns.three {
        gap: 8px !important;
        margin-top: 10px !important;
    }

    .report-kpis article,
    .report-section {
        padding: 12px !important;
    }

    .report-section {
        margin-top: 10px !important;
    }

    .report-table th,
    .report-table td {
        padding: 7px 8px !important;
        font-size: 0.82rem !important;
    }

    .report-list article,
    .next-steps article {
        padding: 8px !important;
    }

    a {
        color: inherit !important;
        text-decoration: none !important;
    }
}
/* REPORT_PRINT_STYLES_END */


.report-mail-note {
    flex-basis: 100%;
    margin: 0;
    color: #dbeafe;
    font-size: 0.82rem;
    text-align: right;
}

@media print {
    .report-mail-note {
        display: none !important;
    }
}





/* EXECUTIVE_RISK_SCORE_START */
.executive-risk-score {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.42fr);
    gap: 34px;
    align-items: start;
    margin: 18px 0 26px;
    padding: 34px 40px;
    border: 1px solid #dbe4f0;
    border-left: 9px solid #c62828;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 16px 38px rgba(15, 40, 79, 0.08);
}

.executive-risk-score h2 {
    margin: 4px 0 14px;
    color: #172033;
    font-size: 2rem;
    line-height: 1.08;
}

.executive-risk-score p {
    max-width: 980px;
    margin: 0 0 22px;
    color: #66736b;
    font-size: 1.08rem;
    line-height: 1.6;
}

.executive-risk-score strong {
    display: block;
    margin-top: 14px;
    color: #66736b;
    font-size: 1rem;
}

.executive-risk-copy {
    min-width: 0;
}

.score-progress {
    width: min(100%, 900px);
    height: 16px;
    overflow: hidden;
    border: 1px solid #d8e1da;
    border-radius: 999px;
    background: #eef3ef;
}

.score-progress span {
    display: block;
    min-width: 3%;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #d8c772, #80b48f);
}

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

.executive-risk-metrics article {
    min-height: 92px;
    padding: 16px 18px;
    border: 1px solid #dbe4f0;
    border-radius: 8px;
    background: #fbfcfd;
}

.executive-risk-metrics article strong {
    margin: 0;
    color: #172033;
    font-size: 1.8rem;
    line-height: 1;
}

.executive-risk-metrics article span {
    display: block;
    margin-top: 8px;
    color: #66736b;
    font-weight: 900;
    line-height: 1.15;
}

.report-risk-score {
    margin: 18px 0;
}

@media (max-width: 980px) {
    .executive-risk-score {
        grid-template-columns: 1fr;
        padding: 26px 24px;
    }
}

@media print {
    .executive-risk-score {
        grid-template-columns: minmax(0, 1fr) 260px !important;
        gap: 14px !important;
        margin: 10px 0 !important;
        padding: 16px 18px !important;
        box-shadow: none !important;
        break-inside: avoid;
        page-break-inside: avoid;
    }

    .executive-risk-score h2 {
        font-size: 1.5rem !important;
    }

    .executive-risk-score p {
        font-size: 0.9rem !important;
        margin-bottom: 10px !important;
    }

    .score-progress {
        height: 10px !important;
    }

    .executive-risk-metrics {
        gap: 7px !important;
    }

    .executive-risk-metrics article {
        min-height: 62px !important;
        padding: 8px !important;
    }

    .executive-risk-metrics article strong {
        font-size: 1.2rem !important;
    }

    .executive-risk-metrics article span {
        font-size: 0.72rem !important;
    }
}
/* EXECUTIVE_RISK_SCORE_END */


/* EXECUTIVE_RISK_SCORE_FIX_ADVANCED_START */
.advanced-mode .dashboard.advanced-dashboard > .executive-risk-score {
    position: relative;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.42fr) !important;
    gap: 34px !important;
    align-items: start !important;
    margin: 26px 0 26px !important;
    padding: 34px 40px !important;
    border: 1px solid #dbe4f0 !important;
    border-left: 9px solid #c62828 !important;
    border-radius: 8px !important;
    background: #fff !important;
    color: #172033 !important;
    box-shadow: 0 16px 38px rgba(15, 40, 79, 0.08) !important;
}

.advanced-mode .dashboard.advanced-dashboard > .executive-risk-score .eyebrow {
    color: #66736b !important;
}

.advanced-mode .dashboard.advanced-dashboard > .executive-risk-score h2 {
    margin: 4px 0 14px !important;
    color: #172033 !important;
    font-size: 2rem !important;
    line-height: 1.08 !important;
}

.advanced-mode .dashboard.advanced-dashboard > .executive-risk-score p {
    max-width: 980px !important;
    margin: 0 0 22px !important;
    color: #66736b !important;
    font-size: 1.08rem !important;
    line-height: 1.6 !important;
}

.advanced-mode .dashboard.advanced-dashboard > .executive-risk-score > .executive-risk-copy > strong {
    display: block !important;
    margin-top: 14px !important;
    color: #66736b !important;
    font-size: 1rem !important;
}

.advanced-mode .dashboard.advanced-dashboard > .executive-risk-score .score-progress {
    display: block !important;
    width: min(100%, 900px) !important;
    height: 16px !important;
    overflow: hidden !important;
    border: 1px solid #d8e1da !important;
    border-radius: 999px !important;
    background: #eef3ef !important;
}

.advanced-mode .dashboard.advanced-dashboard > .executive-risk-score .score-progress span {
    display: block !important;
    min-width: 3% !important;
    height: 100% !important;
    border-radius: inherit !important;
    background: linear-gradient(90deg, #d8c772, #80b48f) !important;
}

.advanced-mode .dashboard.advanced-dashboard > .executive-risk-score .executive-risk-metrics {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

.advanced-mode .dashboard.advanced-dashboard > .executive-risk-score .executive-risk-metrics article {
    display: block !important;
    min-height: 92px !important;
    padding: 16px 18px !important;
    border: 1px solid #dbe4f0 !important;
    border-radius: 8px !important;
    background: #fbfcfd !important;
    box-shadow: none !important;
}

.advanced-mode .dashboard.advanced-dashboard > .executive-risk-score .executive-risk-metrics article strong {
    display: block !important;
    margin: 0 !important;
    color: #172033 !important;
    font-size: 1.8rem !important;
    line-height: 1 !important;
}

.advanced-mode .dashboard.advanced-dashboard > .executive-risk-score .executive-risk-metrics article span {
    display: block !important;
    margin-top: 8px !important;
    color: #66736b !important;
    font-weight: 900 !important;
    line-height: 1.15 !important;
}

@media (max-width: 980px) {
    .advanced-mode .dashboard.advanced-dashboard > .executive-risk-score {
        grid-template-columns: 1fr !important;
        padding: 26px 24px !important;
    }
}
/* EXECUTIVE_RISK_SCORE_FIX_ADVANCED_END */


/* RISK_POSTURE_CARD_FINAL_START */
.risk-posture-card {
    box-sizing: border-box;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 420px;
    gap: 34px;
    align-items: start;
    width: 100%;
    margin: 24px 0 28px;
    padding: 34px 40px;
    border: 1px solid #dbe4f0;
    border-left: 9px solid #c62828;
    border-radius: 8px;
    background: #fff;
    color: #172033;
    box-shadow: 0 16px 38px rgba(15, 40, 79, 0.08);
}

.risk-posture-card .eyebrow {
    margin: 0 0 8px;
    color: #66736b;
    font-size: 0.86rem;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.risk-posture-copy h2 {
    margin: 0 0 14px;
    color: #172033;
    font-size: 2rem;
    line-height: 1.08;
}

.risk-posture-copy p {
    max-width: 980px;
    margin: 0 0 22px;
    color: #66736b;
    font-size: 1.08rem;
    line-height: 1.6;
}

.risk-posture-copy strong {
    display: block;
    margin-top: 14px;
    color: #66736b;
    font-size: 1rem;
}

.risk-posture-progress {
    width: min(100%, 900px);
    height: 16px;
    overflow: hidden;
    border: 1px solid #d8e1da;
    border-radius: 999px;
    background: #eef3ef;
}

.risk-posture-progress span {
    display: block;
    min-width: 3%;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #d8c772, #80b48f);
}

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

.risk-posture-metrics article {
    min-height: 92px;
    padding: 16px 18px;
    border: 1px solid #dbe4f0;
    border-radius: 8px;
    background: #fbfcfd;
}

.risk-posture-metrics article strong {
    display: block;
    margin: 0;
    color: #172033;
    font-size: 1.8rem;
    line-height: 1;
}

.risk-posture-metrics article span {
    display: block;
    margin-top: 8px;
    color: #66736b;
    font-weight: 900;
    line-height: 1.15;
}

.report-risk-posture {
    margin: 18px 0;
}

@media (max-width: 980px) {
    .risk-posture-card {
        grid-template-columns: 1fr;
        padding: 26px 24px;
    }
}

@media print {
    .risk-posture-card {
        grid-template-columns: minmax(0, 1fr) 260px !important;
        gap: 14px !important;
        margin: 10px 0 !important;
        padding: 16px 18px !important;
        box-shadow: none !important;
        break-inside: avoid;
        page-break-inside: avoid;
    }

    .risk-posture-copy h2 {
        font-size: 1.5rem !important;
    }

    .risk-posture-copy p {
        font-size: 0.9rem !important;
        margin-bottom: 10px !important;
    }

    .risk-posture-progress {
        height: 10px !important;
    }

    .risk-posture-metrics {
        gap: 7px !important;
    }

    .risk-posture-metrics article {
        min-height: 62px !important;
        padding: 8px !important;
    }

    .risk-posture-metrics article strong {
        font-size: 1.2rem !important;
    }

    .risk-posture-metrics article span {
        font-size: 0.72rem !important;
    }
}
/* RISK_POSTURE_CARD_FINAL_END */


/* ADVANCED_HEADER_BUTTONS_FIX_START */
.advanced-mode .advanced-dashboard .page-heading {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 28px;
    align-items: start;
}

.advanced-mode .advanced-dashboard .page-heading .button-group {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    gap: 12px;
    max-width: 760px;
}

.advanced-mode .advanced-dashboard .page-heading .button-group .button-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    white-space: nowrap;
}

@media (min-width: 1180px) {
    .advanced-mode .advanced-dashboard .page-heading .button-group {
        display: grid;
        grid-template-columns: repeat(4, max-content);
        max-width: none;
    }
}

@media (max-width: 980px) {
    .advanced-mode .advanced-dashboard .page-heading {
        grid-template-columns: 1fr;
    }

    .advanced-mode .advanced-dashboard .page-heading .button-group {
        justify-content: flex-start;
        max-width: none;
    }
}
/* ADVANCED_HEADER_BUTTONS_FIX_END */


/* ORG_ADMIN_STYLES_START */
.org-admin-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.82fr);
    gap: 14px;
    align-items: start;
}

.advanced-mode .organization-admin .muted {
    color: #b9c7d6;
}

.organization-admin .page-heading {
    margin-bottom: 8px;
}

.advanced-mode .organization-admin .table-section,
.advanced-mode .company-profile-page .table-section {
    background: #ffffff;
}

.advanced-mode .organization-admin .form-section,
.advanced-mode .company-profile-page .form-section {
    padding: 16px;
}

.org-overview-panel {
    display: grid;
    gap: 12px;
}

.org-current-card,
.organization-switch-card {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
    padding: 10px 12px;
    border: 1px solid #dbe4f0;
    border-radius: 8px;
    background: #f8fafc;
}

.org-current-card .button-link {
    min-height: 36px;
    padding: 0 12px;
    white-space: nowrap;
}

.org-current-card-main {
    min-height: 70px;
}

.org-inline-heading {
    align-items: center;
    border-top: 1px solid #e4edf6;
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding-top: 10px;
}

.org-inline-heading strong {
    color: #102a43;
    font-size: 0.96rem;
}

.org-inline-heading span {
    color: #667792;
    font-size: 0.86rem;
    font-weight: 800;
}

.org-current-card strong,
.organization-switch-card strong {
    display: block;
    color: #101828;
}

.org-current-card span,
.organization-switch-card span {
    display: block;
    margin-top: 4px;
    color: #667792;
}

.organization-switch-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 8px;
}

.organization-switch-list-compact {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.organization-switch-card {
    margin: 0;
    min-height: 58px;
}

.organization-switch-card .button-link {
    min-height: 34px;
    padding: 0 12px;
}

.org-create-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 12px;
    margin: 0;
}

.org-create-form .form-field {
    gap: 5px;
}

.org-create-form input,
.org-create-form select {
    height: 42px;
    min-height: 42px;
}

.org-create-form button {
    grid-column: 1 / -1;
}

.status-pill {
    display: inline-flex !important;
    align-items: center;
    min-height: 30px;
    padding: 4px 10px;
    border-radius: 999px;
    background: #eaf1fb;
    color: #0f5ea8 !important;
    font-weight: 900;
}

.inline-role-form,
.inline-delete-form {
    display: flex;
    gap: 8px;
    align-items: center;
    margin: 0;
}

.inline-role-form select {
    min-width: 150px;
}

.inline-role-form button,
.inline-delete-form button {
    min-height: 34px;
    padding: 6px 10px;
    border-radius: 8px;
    font-size: 0.82rem;
}

.inline-delete-form button {
    border: 1px solid #fecaca;
    background: #fff5f5;
    color: #b42318;
}

.permission-panel {
    display: grid;
    gap: 16px;
    margin-top: 18px;
    padding: 18px;
    border: 1px solid #dbe4f0;
    border-radius: 8px;
    background: #ffffff;
}

.permission-panel-heading {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: start;
    padding-bottom: 14px;
    border-bottom: 1px solid #edf2f7;
}

.permission-panel-heading h3 {
    margin: 0 0 4px;
    color: #101828;
    font-size: 1rem;
}

.permission-panel-heading span,
.permission-actions span {
    color: #667792;
    font-size: 0.88rem;
}

.permission-profile-form {
    display: grid;
    grid-template-columns: auto minmax(180px, 240px) auto;
    gap: 8px;
    align-items: center;
    margin: 0;
}

.permission-profile-form label {
    color: #475467;
    font-size: 0.82rem;
    font-weight: 800;
}

.permission-profile-form select,
.permission-profile-form button {
    min-height: 36px;
}

.permission-profile-form button,
.permission-actions button {
    padding: 7px 12px;
    border-radius: 8px;
    font-size: 0.84rem;
}

.permission-grid-form {
    display: grid;
    gap: 16px;
}

.permission-group {
    display: grid;
    gap: 10px;
}

.permission-group-title {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 28px;
    padding: 4px 10px;
    border-radius: 999px;
    background: #eaf1fb;
    color: #12325c;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.permission-grid {
    display: grid;
    grid-template-columns: minmax(140px, 1.15fr) repeat(7, minmax(92px, 0.85fr));
    gap: 6px;
    overflow-x: auto;
    padding-bottom: 4px;
}

.permission-grid-header,
.permission-grid-module,
.permission-check {
    min-height: 38px;
    border-radius: 8px;
}

.permission-grid-header {
    display: flex;
    align-items: center;
    padding: 8px 10px;
    background: #f1f5f9;
    color: #475467;
    font-size: 0.76rem;
    font-weight: 900;
    text-transform: uppercase;
}

.permission-grid-module {
    display: flex;
    align-items: center;
    padding: 8px 10px;
    background: #f8fafc;
    color: #172033;
    font-size: 0.86rem;
    font-weight: 800;
}

.permission-check {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 7px;
    border: 1px solid #dbe4f0;
    background: #ffffff;
    color: #667792;
    font-size: 0.76rem;
    font-weight: 800;
    cursor: pointer;
}

.permission-check input {
    width: 15px;
    height: 15px;
    margin: 0;
}

.permission-check span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.permission-check-active {
    border-color: #9fc7ee;
    background: #eef6ff;
    color: #12325c;
}

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

@media (max-width: 860px) {
    .org-admin-grid {
        grid-template-columns: 1fr;
    }

    .inline-role-form {
        flex-wrap: wrap;
    }

    .permission-panel-heading,
    .permission-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .permission-profile-form {
        grid-template-columns: 1fr;
    }
}
/* ORG_ADMIN_STYLES_END */

/* COMPANY_PROFILE_DOCUMENT_IDENTITY_START */
.company-profile-page {
    gap: 24px;
}

.company-profile-panel {
    max-width: 1180px;
}

.company-profile-form {
    display: grid;
    gap: 18px;
}

.company-logo-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(240px, 320px);
    gap: 16px;
    align-items: center;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    background: #f8fbff;
    padding: 16px;
}

.company-logo-card span {
    color: #52616b;
    display: block;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    margin-bottom: 8px;
    text-transform: uppercase;
}

.company-logo-card img {
    display: block;
    max-width: 220px;
    max-height: 82px;
    object-fit: contain;
}

.company-logo-card strong {
    color: #102a43;
    display: block;
    font-size: 1.1rem;
    margin-bottom: 6px;
}

.company-logo-card p {
    color: #52616b;
    margin: 0;
}

.company-logo-upload {
    display: grid;
    gap: 8px;
}

.company-logo-upload input {
    height: auto;
    min-height: 44px;
    padding: 10px;
}

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

.company-profile-grid > div {
    display: grid;
    gap: 7px;
}

.company-profile-grid > div:nth-child(1),
.company-profile-grid > div:nth-child(2) {
    grid-column: span 2;
}

@media (max-width: 900px) {
    .company-logo-card,
    .company-profile-grid {
        grid-template-columns: 1fr;
    }

    .company-profile-grid > div:nth-child(1),
    .company-profile-grid > div:nth-child(2) {
        grid-column: auto;
    }
}
/* COMPANY_PROFILE_DOCUMENT_IDENTITY_END */


/* ADVANCED_MODE_NAV_FLOW_START */
.advanced-mode .report-back-link {
    background: #fff;
    color: #0f5ea8;
}

.advanced-mode .advanced-dashboard .page-heading .button-group {
    align-items: center;
}
/* ADVANCED_MODE_NAV_FLOW_END */


/* COMPACT_ADVANCED_METRICS_START */
.advanced-mode .dashboard.advanced-dashboard > .metric-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: 14px !important;
}

.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article,
.advanced-mode .follow-up-metrics > article {
    min-height: 76px !important;
    padding: 14px 16px !important;
    gap: 6px !important;
}

.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article span,
.advanced-mode .follow-up-metrics > article span {
    font-size: 0.82rem !important;
    line-height: 1.2 !important;
}

.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article strong,
.advanced-mode .follow-up-metrics > article strong {
    font-size: 1.6rem !important;
    line-height: 1 !important;
}

.advanced-mode .follow-up-metrics {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 14px !important;
}

@media (max-width: 900px) {
    .advanced-mode .dashboard.advanced-dashboard > .metric-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }

    .advanced-mode .follow-up-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 640px) {
    .advanced-mode .dashboard.advanced-dashboard > .metric-grid,
    .advanced-mode .follow-up-metrics {
        grid-template-columns: 1fr !important;
    }
}
/* COMPACT_ADVANCED_METRICS_END */


/* SMART_TOPNAV_START */
.app-nav {
    gap: 12px;
}

.nav-current {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 10px;
    border: 1px solid rgba(15, 94, 168, 0.22);
    border-radius: 999px;
    background: #eaf1fb;
    color: #0f5ea8 !important;
    font-weight: 900;
}

.advanced-mode .nav-current {
    background: rgba(15, 94, 168, 0.28);
    border-color: rgba(184, 214, 245, 0.45);
    color: #ffffff !important;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
}

.nav-admin-link {
    border: 1px solid rgba(15, 94, 168, 0.22);
    border-radius: 999px;
    padding: 7px 10px;
}

.advanced-mode .nav-admin-link:not(.nav-current) {
    background: rgba(15, 94, 168, 0.18);
    border-color: rgba(184, 214, 245, 0.35);
    color: #d8ecff !important;
}

.advanced-mode .nav-admin-link:not(.nav-current):hover {
    background: rgba(15, 94, 168, 0.32);
    color: #ffffff !important;
}

.topnav .nav-menu {
    position: relative;
    display: inline-flex;
    flex: 0 0 auto;
}

.topnav .nav-menu-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    border: 1px solid rgba(15, 94, 168, 0.22);
    border-radius: 999px;
    background: transparent;
    color: var(--accent);
    padding: 0 10px;
    font-size: inherit;
    font-weight: 800;
    cursor: default;
}

.topnav .nav-menu-trigger::after {
    content: "";
    width: 0;
    height: 0;
    margin-left: 7px;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 5px solid currentColor;
}

.topnav .nav-menu-panel {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 120;
    display: none !important;
    flex-direction: column;
    gap: 2px;
    min-width: 250px;
    border: 1px solid rgba(184, 214, 245, 0.45);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 20px 44px rgba(13, 31, 51, 0.22);
    padding: 10px 8px 8px;
}

.topnav .nav-menu:hover .nav-menu-panel,
.topnav .nav-menu:focus-within .nav-menu-panel {
    display: flex !important;
}

.topnav .nav-menu-panel a {
    display: flex;
    align-items: center;
    min-height: 36px;
    border-radius: 7px;
    color: var(--accent) !important;
    font-weight: 800;
    padding: 10px 12px;
    white-space: nowrap;
}

.topnav .nav-menu-panel a:hover {
    background: #eaf1fb;
    color: var(--accent-dark) !important;
}

.topnav .nav-menu-section {
    color: #6b7785;
    display: block;
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    padding: 6px 12px 2px;
    text-align: left;
    text-transform: uppercase;
}

.topnav .nav-menu-empty {
    color: #6b7785;
    display: block;
    font-size: 0.82rem;
    font-weight: 700;
    padding: 8px 12px;
    text-align: left;
}

.topnav .nav-org-switch-form {
    margin: 0;
}

.topnav .nav-org-switch {
    align-items: flex-start;
    background: transparent;
    border: 0;
    border-radius: 7px;
    color: var(--accent);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-height: 40px;
    padding: 9px 12px;
    text-align: left;
    width: 100%;
}

.topnav .nav-org-switch:hover {
    background: #eaf1fb;
    color: var(--accent-dark);
}

.topnav .nav-org-switch span {
    font-size: 0.9rem;
    font-weight: 900;
    line-height: 1.15;
}

.topnav .nav-org-switch small {
    color: #64748b;
    font-size: 0.72rem;
    font-weight: 800;
    line-height: 1.15;
}

.topnav .nav-org-switch-current,
.topnav .nav-org-switch-current:hover {
    background: #dbeafe;
    color: var(--accent-dark);
    cursor: default;
}

.advanced-mode .topnav .nav-menu-trigger {
    border-color: rgba(184, 214, 245, 0.35);
    color: #d8ecff;
}

.advanced-mode .topnav .nav-menu-trigger:hover {
    background: rgba(15, 94, 168, 0.32);
    color: #ffffff;
}

.advanced-mode .topnav .nav-menu-panel {
    border-color: rgba(184, 214, 245, 0.34);
    background: #ffffff;
}

.topnav .nav-menu-note {
    color: #52616b !important;
    display: block;
    font-size: 0.82rem;
    font-weight: 800;
    line-height: 1.35;
    padding: 8px 12px 10px;
    white-space: normal;
}

.document-trace-card {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}

.document-trace-card > div {
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    background: #f8fbff;
    min-height: 72px;
    padding: 10px 12px;
}

.document-trace-card span {
    color: #52616b;
    display: block;
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    margin-bottom: 5px;
    text-transform: uppercase;
}

.document-trace-card strong {
    color: #102a43;
    display: block;
    font-size: 0.9rem;
    line-height: 1.25;
}

.document-trace-wide {
    grid-column: span 3;
}

.document-editor-form {
    display: grid;
    gap: 18px;
}

.document-meta-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 10px 12px;
}

.document-meta-grid > div,
.document-editor-panel > div {
    display: grid;
    gap: 7px;
}

.document-meta-grid > div {
    grid-column: span 2;
}

.document-meta-grid input,
.document-meta-grid select,
.document-meta-grid textarea {
    min-height: 42px;
    height: 42px;
    font-size: 0.94rem;
}

.document-meta-grid textarea {
    height: 74px;
    min-height: 74px;
}

.document-meta-wide {
    grid-column: span 3;
}

.document-editor-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
    align-items: start;
}

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

.document-editor-panel > div:last-child,
.document-editor-panel .document-sync-option {
    grid-column: 1 / -1;
}

.document-editor-panel textarea {
    min-height: 132px;
}

.document-editor-panel textarea[name="body"] {
    min-height: 320px;
    font-family: Arial, Helvetica, sans-serif;
    line-height: 1.45;
}

.document-sync-option {
    align-items: center;
    display: inline-flex;
    gap: 10px;
    min-height: 44px;
}

.document-sync-option input {
    flex: 0 0 auto;
    height: 18px;
    width: 18px;
}

.document-preview-panel {
    order: -1;
    position: static;
}

.document-preview-paper {
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.12);
    color: #1f2933;
    padding: 20px;
}

.document-preview-paper {
    max-width: 1120px;
    margin: 0 auto;
}

.document-view-page {
    gap: 22px;
}

.advanced-mode .document-view-page > .page-heading {
    align-items: start;
    gap: 22px;
    padding-bottom: 42px;
}

.advanced-mode .document-view-page > .page-heading h1 {
    font-size: clamp(2.2rem, 4.2vw, 4.2rem) !important;
    line-height: 1.02 !important;
    max-width: 980px;
}

.advanced-mode .document-view-page > .page-heading .advanced-heading-copy {
    font-size: 1rem;
    margin-top: 10px;
}

.document-view-actions {
    align-content: start;
    align-items: center;
    display: flex !important;
    gap: 8px !important;
    justify-content: flex-end;
    max-width: 520px !important;
}

.advanced-mode .document-view-page > .page-heading .document-view-actions .button-link,
.advanced-mode .document-view-page > .page-heading .document-view-actions .button-link-light {
    border-radius: 999px !important;
    font-size: 0.82rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    min-height: 0 !important;
    padding: 9px 12px !important;
}

.advanced-mode .document-view-page > .page-heading .document-view-actions .button-link-light {
    background: rgba(255, 255, 255, 0.92) !important;
}

.document-trace-card-compact {
    gap: 8px;
    margin-top: -16px;
}

.document-trace-card-compact > div {
    min-height: 56px;
    padding: 9px 10px;
}

.document-trace-card-compact span {
    font-size: 0.62rem;
    margin-bottom: 4px;
}

.document-trace-card-compact strong {
    font-size: 0.82rem;
}

.document-trace-card-compact .document-trace-wide {
    min-height: 58px;
}

.document-view-paper {
    width: min(100%, 1120px);
}

.document-preview-header {
    border-bottom: 2px solid #12355b;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 138px;
    gap: 16px;
    margin-bottom: 16px;
    padding-bottom: 14px;
}

.document-preview-header span {
    color: #52616b;
    display: block;
    font-size: 0.7rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    margin-bottom: 6px;
    text-transform: uppercase;
}

.document-preview-header h2 {
    color: #102a43;
    font-size: 1.15rem;
    line-height: 1.2;
    margin: 0 0 6px;
}

.document-preview-header p {
    color: #334e68;
    font-size: 0.84rem;
    margin: 0;
}

.document-preview-logo-box {
    align-items: center;
    align-self: start;
    background: #12355b;
    border-radius: 4px;
    display: flex;
    justify-content: center;
    justify-self: end;
    min-height: 58px;
    padding: 8px 10px;
    width: 138px;
}

.document-preview-logo-box img {
    align-self: start;
    max-height: 52px;
    max-width: 132px;
    object-fit: contain;
}

.document-preview-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0 0 16px;
}

.document-preview-meta div {
    border: 1px solid #cbd5e1;
    margin: -1px 0 0 -1px;
    padding: 8px 9px;
}

.document-preview-meta dt {
    color: #52616b;
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.document-preview-meta dd {
    color: #102a43;
    font-size: 0.82rem;
    font-weight: 800;
    margin: 3px 0 0;
}

.document-preview-paper section {
    margin-top: 16px;
}

.document-preview-paper h3 {
    border-bottom: 1px solid #cbd5e1;
    color: #102a43;
    font-size: 0.8rem;
    letter-spacing: 0.04em;
    margin: 0 0 8px;
    padding-bottom: 5px;
    text-transform: uppercase;
}

.document-preview-paper p,
.document-preview-body {
    border: 1px solid #cbd5e1;
    color: #334e68;
    font-size: 0.86rem;
    line-height: 1.48;
    margin: 0;
    max-height: 520px;
    overflow: auto;
    padding: 12px;
    white-space: pre-wrap;
}

.document-view-body {
    max-height: none;
    min-height: 320px;
}

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

.document-relation-grid > div {
    border: 1px solid #cbd5e1;
    padding: 12px;
}

.document-relation-grid strong {
    color: #102a43;
    display: block;
    font-size: 0.82rem;
    margin-bottom: 8px;
    text-transform: uppercase;
}

.document-relation-grid ul {
    margin: 0;
    padding-left: 18px;
}

.document-relation-grid li {
    color: #334e68;
    font-size: 0.86rem;
    line-height: 1.45;
}

.document-form-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.document-workbench-cards {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}

.advanced-mode .document-workbench > .page-heading .document-library-actions {
    align-items: center;
    justify-content: flex-end;
    max-width: 520px;
}

.advanced-mode .document-workbench > .page-heading .document-library-actions form {
    margin: 0;
}

.advanced-mode .document-workbench > .page-heading .document-library-actions .button-link {
    border-radius: 999px;
    font-size: 0.86rem;
    font-weight: 900;
    min-height: 0;
    padding: 10px 14px;
    white-space: nowrap;
}

.document-workbench-card {
    background: #f8fbff;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    color: #102a43;
    display: grid;
    gap: 4px;
    min-height: 104px;
    padding: 16px;
    text-decoration: none;
}

.document-workbench-card:hover,
.document-workbench-card.is-active {
    background: #12355b;
    border-color: #12355b;
    color: #ffffff;
}

.document-workbench-card span,
.document-workbench-card small {
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.document-workbench-card span {
    font-size: 0.72rem;
}

.document-workbench-card strong {
    font-size: 2rem;
    line-height: 1;
}

.document-workbench-card small {
    color: inherit;
    font-size: 0.68rem;
    opacity: 0.78;
}

.document-filter-panel .inline-form {
    align-items: end;
}

.document-workbench-table th,
.document-workbench-table td {
    vertical-align: middle;
}

.document-workbench-table th {
    white-space: nowrap;
}

.document-name-cell {
    display: grid;
    gap: 3px;
    min-width: 260px;
}

.document-name-cell strong {
    color: #1f2933;
}

.document-name-cell a {
    color: #0f5ea8;
    font-weight: 900;
    line-height: 1.15;
    text-decoration: none;
}

.document-name-cell span,
.document-review-cell span,
.document-approval-mini span {
    color: #52616b;
    display: block;
    font-size: 0.82rem;
    font-weight: 800;
    line-height: 1.25;
}

.document-status-pill {
    border-radius: 999px;
    display: inline-flex;
    font-size: 0.78rem;
    font-weight: 900;
    padding: 7px 10px;
    white-space: nowrap;
}

.document-status-review,
.document-status-draft {
    background: #e7f2ff;
    color: #0f5ea8;
}

.document-status-active {
    background: #e7f7ed;
    color: #1a7f37;
}

.document-status-retired {
    background: #f1f3f5;
    color: #52616b;
}

.document-review-cell {
    display: grid;
    gap: 3px;
    min-width: 112px;
}

.document-review-cell strong,
.document-approval-mini strong {
    color: #1f2933;
    font-size: 0.94rem;
}

.document-review-expired {
    color: #c92a2a !important;
}

.document-review-upcoming,
.document-review-missing {
    color: #b7791f !important;
}

.document-approval-mini {
    display: grid;
    gap: 3px;
    min-width: 96px;
}

.document-iso-summary {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    max-width: 210px;
}

.document-row-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: flex-start;
    max-width: 180px;
}

.document-row-actions a {
    background: #eef6ff;
    border: 1px solid #b8d6f5;
    border-radius: 999px;
    color: #0f5ea8;
    font-size: 0.78rem;
    font-weight: 900;
    padding: 6px 9px;
    text-decoration: none;
    white-space: nowrap;
}

.document-row-actions a:hover {
    background: #12355b;
    border-color: #12355b;
    color: #ffffff;
}

.document-version-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: none;
    width: min(100%, 280px);
}

.document-version-actions a {
    align-items: center;
    display: inline-flex;
    font-size: 0.76rem;
    justify-content: center;
    min-height: 34px;
    padding: 7px 10px;
    text-align: center;
}

.document-history-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.document-history-summary > div {
    background: #f8fbff;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    display: grid;
    gap: 4px;
    min-height: 96px;
    padding: 16px;
}

.document-history-summary span,
.document-history-summary small {
    color: #52616b;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.document-history-summary strong {
    color: #102a43;
    font-size: 2rem;
    line-height: 1;
}

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

.document-history-columns {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    align-items: start;
}

.document-history-column {
    background: #ffffff;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    display: grid;
    gap: 12px;
    padding: 14px;
}

.document-version-card {
    background: #ffffff;
    border: 1px solid #d5e2ef;
    border-left: 6px solid #0f5ea8;
    border-radius: 8px;
    display: grid;
    gap: 9px;
    padding: 14px;
}

.document-version-active {
    border-left-color: #1a7f37;
}

.document-version-retired {
    border-left-color: #9fb3c8;
    background: #f8fbff;
}

.document-version-card h3 {
    color: #102a43;
    font-size: 1rem;
    margin: 0;
}

.document-version-card p {
    color: #334e68;
    font-size: 0.9rem;
    line-height: 1.35;
    margin: 0;
}

.document-version-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.document-version-meta span {
    background: #eef6ff;
    border: 1px solid #b8d6f5;
    border-radius: 999px;
    color: #334e68;
    font-size: 0.74rem;
    font-weight: 900;
    padding: 5px 8px;
}

.document-empty-state {
    background: #f8fbff;
    border: 1px dashed #b8d6f5;
    border-radius: 8px;
    display: grid;
    gap: 6px;
    padding: 16px;
}

.document-empty-state strong {
    color: #102a43;
}

.document-empty-state p {
    color: #52616b;
    margin: 0;
}

.approval-matrix-form {
    display: grid;
    gap: 16px;
}

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

.approval-matrix-grid label,
.approval-decision-form label {
    display: grid;
    gap: 7px;
}

.approval-matrix-grid span {
    color: #102a43;
    font-weight: 900;
}

.approval-list {
    display: grid;
    gap: 12px;
}

.approval-list-compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.approval-card {
    align-items: start;
    background: #f8fbff;
    border: 1px solid #d5e2ef;
    border-left: 5px solid #9fb3c8;
    border-radius: 8px;
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(0, 1fr);
    padding: 14px;
}

.approval-card-approved {
    border-left-color: #1a7f37;
}

.approval-card-rejected {
    border-left-color: #c92a2a;
    background: #fff5f5;
}

.approval-card h3 {
    color: #102a43;
    font-size: 1rem;
    margin: 0 0 4px;
}

.approval-card p {
    margin: 0;
}

.approval-decision-form {
    display: grid;
    gap: 10px;
}

.document-support-links {
    border-top: 1px solid #d5e2ef;
    margin-top: 18px;
    padding-top: 18px;
}

.document-support-grid {
    display: grid;
    gap: 10px;
}

.document-support-grid a {
    background: #f8fbff;
    border: 1px solid #d5e2ef;
    border-left: 5px solid #0b5cab;
    border-radius: 8px;
    display: grid;
    gap: 5px;
    padding: 12px;
}

.document-support-grid strong {
    color: #0b5cab;
}

.document-support-grid span {
    color: #52616b;
    font-size: 0.9rem;
}

.document-related-panel {
    background: #ffffff;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    box-shadow: 0 18px 46px rgba(13, 31, 51, 0.08);
    margin-top: 18px;
    padding: 22px;
}

.document-related-sections {
    display: grid;
    gap: 18px;
}

.document-related-sections > article {
    background: #f8fbff;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    display: grid;
    gap: 14px;
    padding: 16px;
}

.document-related-sections header {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.document-related-sections h3 {
    color: #102a43;
    font-size: 1.05rem;
    line-height: 1.2;
    margin: 0;
}

.document-related-sections header span {
    color: #52616b;
    font-size: 0.82rem;
    font-weight: 900;
}

.document-related-button-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.document-related-button-grid a,
.document-related-button,
.document-related-empty {
    align-items: center;
    background: #eaf4ff;
    border: 1px solid #a9d2ff;
    border-left: 5px solid #0b5cab;
    border-radius: 8px;
    color: #0b5cab;
    display: grid;
    gap: 5px;
    justify-content: center;
    min-height: 74px;
    padding: 10px 12px;
    text-align: center;
    width: 100%;
}

.document-related-button-grid a strong {
    color: #0b2a4a;
    font-size: 0.92rem;
    line-height: 1.18;
}

.document-related-button-grid .document-related-button {
    text-decoration: none;
}

.document-related-button-grid .document-related-button strong,
.document-related-button-grid .document-related-button span {
    display: block;
}

.document-related-button-grid a span {
    color: #0b5cab;
    font-size: 0.78rem;
    font-weight: 850;
    line-height: 1.2;
}

.document-related-button-grid a:hover {
    background: #dbeafe;
    color: #063f78;
}

.document-related-empty {
    background: #f6f9fc;
    border-color: #d9e5f1;
    border-left-color: #94a3b8;
    color: #52616b;
    font-weight: 850;
}

.document-progress-mini {
    display: grid;
    gap: 2px;
}

.document-progress-mini strong {
    color: #0b5cab;
    font-size: 1.25rem;
}

.document-progress-mini span,
.operations-progress-breakdown {
    color: #52616b;
}

.operations-progress-note {
    background: #f8fbff;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    display: grid;
    gap: 6px;
    margin: 18px 0;
    padding: 14px 16px;
}

.operations-progress-note strong {
    color: #102a43;
}

.operations-progress-note span {
    color: #52616b;
}

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

    .document-editor-grid {
        grid-template-columns: 1fr;
    }

    .approval-list-compact,
    .approval-matrix-grid,
    .document-related-button-grid,
    .document-workbench-cards,
    .document-history-summary,
    .document-history-columns,
    .document-version-grid {
        grid-template-columns: 1fr;
    }

    .document-meta-grid > div,
    .document-meta-wide,
    .document-trace-wide {
        grid-column: auto;
    }
}

@media (max-width: 760px) {
    .document-meta-grid,
    .document-trace-card,
    .document-preview-meta {
        grid-template-columns: 1fr;
    }

    .document-meta-wide,
    .document-trace-wide {
        grid-column: auto;
    }

    .document-editor-panel {
        grid-template-columns: 1fr;
    }

    .document-preview-header {
        grid-template-columns: 1fr;
    }

    .document-preview-logo-box {
        justify-self: start;
    }

    .document-relation-grid {
        grid-template-columns: 1fr;
    }
}

.operations-policy-page .page-heading h1 {
    max-width: 920px;
}

.operations-policy-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 220px;
    gap: 18px;
    margin: 24px 0;
}

.operations-policy-hero article,
.operations-policy-panel {
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 18px 46px rgba(13, 31, 51, 0.08);
    padding: 24px;
}

.operations-policy-hero h2 {
    margin-bottom: 10px;
    font-size: 1.9rem;
}

.operations-policy-hero p {
    color: #52637a;
    font-weight: 700;
    line-height: 1.55;
}

.operations-policy-status {
    align-content: center;
    justify-items: center;
    position: relative;
    text-align: center;
}

.operations-policy-status[data-tooltip] {
    cursor: help;
}

.operations-policy-status[data-tooltip]::after {
    background: #102a43;
    border-radius: 8px;
    bottom: calc(100% + 12px);
    box-shadow: 0 16px 40px rgba(13, 31, 51, 0.22);
    color: #ffffff;
    content: attr(data-tooltip);
    font-size: 0.82rem;
    font-weight: 800;
    left: 50%;
    line-height: 1.35;
    max-width: min(420px, 72vw);
    opacity: 0;
    padding: 12px 14px;
    pointer-events: none;
    position: absolute;
    text-align: left;
    transform: translate(-50%, 8px);
    transition: opacity 0.16s ease, transform 0.16s ease;
    width: max-content;
    z-index: 20;
}

.operations-policy-status[data-tooltip]:hover::after,
.operations-policy-status[data-tooltip]:focus::after {
    opacity: 1;
    transform: translate(-50%, 0);
}

.operations-policy-status strong {
    color: #0f5ea8;
    font-size: 3rem;
    line-height: 1;
}

.operations-policy-status span,
.operations-policy-status small {
    display: block;
    color: #52637a;
    font-weight: 900;
    text-transform: uppercase;
}

.operations-policy-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
    gap: 18px;
    margin-bottom: 18px;
}

.operations-policy-panel {
    margin-bottom: 18px;
}

.operations-steps {
    margin: 18px 0 0;
    padding-left: 24px;
}

.operations-steps li {
    color: #52637a;
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.45;
    margin-bottom: 10px;
}

.operations-meta {
    display: grid;
    gap: 10px;
    margin: 18px 0 0;
}

.operations-meta div {
    display: grid;
    grid-template-columns: 140px minmax(0, 1fr);
    gap: 10px;
}

.operations-meta dt {
    color: #52637a;
    font-weight: 900;
}

.operations-meta dd {
    margin: 0;
    color: #13223a;
    font-weight: 800;
}

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

.operations-register-card {
    display: grid;
    gap: 8px;
    min-height: 170px;
    border: 1px solid #cfe0f1;
    border-left: 5px solid #0f5ea8;
    border-radius: 8px;
    background: #f7fbff;
    padding: 16px;
}

.operations-register-card span,
.operations-rule-card header span {
    color: #0f5ea8;
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.operations-register-card strong {
    color: #13223a;
    font-size: 1.15rem;
}

.operations-register-card small {
    color: #52637a;
    font-weight: 700;
    line-height: 1.35;
}

.operations-register-card em {
    align-self: end;
    color: #0f5ea8;
    font-style: normal;
    font-weight: 900;
}

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

.operations-rule-card {
    display: grid;
    gap: 10px;
    border: 1px solid #d9e5f1;
    border-left: 5px solid #0f5ea8;
    border-radius: 8px;
    background: #fbfdff;
    padding: 16px;
}

.operations-rule-card.tier-p0 {
    border-left-color: #dc2626;
}

.operations-rule-card.tier-p1 {
    border-left-color: #d97706;
}

.operations-rule-card.tier-p2 {
    border-left-color: #0f5ea8;
}

.operations-rule-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.operations-rule-header > div:first-child {
    display: grid;
    gap: 4px;
}

.operations-rule-header > div:first-child strong {
    color: #13223a;
    font-size: 1.05rem;
}

.operations-rule-progress {
    flex: 0 0 118px;
    border: 1px solid #b9d8f4;
    border-radius: 8px;
    background: #eaf1fb;
    padding: 10px;
    text-align: center;
}

.operations-rule-progress strong {
    display: block;
    color: #0f5ea8;
    font-size: 1.5rem;
    line-height: 1;
}

.operations-rule-progress small {
    color: #52637a;
    font-size: 0.72rem;
    font-weight: 900;
    text-transform: uppercase;
}

.operations-rule-card p,
.operations-rule-card small {
    margin: 0;
    color: #52637a;
    font-weight: 750;
    line-height: 1.4;
}

.operations-rule-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-top: 8px;
}

.operations-rule-actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 58px;
    border: 1px solid #c9dff3;
    border-left: 5px solid #0f5ea8;
    border-radius: 8px;
    background: #f7fbff;
    color: #0f5ea8;
    font-weight: 900;
    line-height: 1.1;
    padding: 10px 12px;
    text-align: center;
}

.operations-rule-actions a:hover {
    border-color: #9bc8f1;
    background: #eaf1fb;
    color: #0b4f8a;
}

.operations-rule-action-disabled {
    align-items: center;
    background: #eef3f8;
    border: 1px solid #d9e5f1;
    border-left: 5px solid #94a3b8;
    border-radius: 8px;
    color: #66788f;
    display: inline-flex;
    font-weight: 900;
    justify-content: center;
    line-height: 1.1;
    min-height: 58px;
    padding: 10px 12px;
    text-align: center;
}

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

.operations-evidence-card {
    background: #fbfdff;
    border: 1px solid #d9e5f1;
    border-left: 5px solid #0f5ea8;
    border-radius: 8px;
    display: grid;
    gap: 12px;
    padding: 16px;
    scroll-margin-top: 120px;
}

.operations-evidence-card.tier-p0 {
    border-left-color: #dc2626;
}

.operations-evidence-card.tier-p1 {
    border-left-color: #d97706;
}

.operations-evidence-card header {
    align-items: flex-start;
    display: flex;
    gap: 14px;
    justify-content: space-between;
}

.operations-evidence-card header div {
    display: grid;
    gap: 4px;
}

.operations-evidence-card header span {
    color: #0f5ea8;
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.operations-evidence-card header strong {
    color: #13223a;
    font-size: 1.05rem;
    line-height: 1.2;
}

.operations-evidence-card p,
.operations-evidence-card li span {
    color: #52637a;
    font-weight: 750;
    line-height: 1.4;
    margin: 0;
}

.operations-evidence-card ul {
    display: grid;
    gap: 8px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.operations-evidence-card li {
    background: #ffffff;
    border: 1px solid #dbe7f3;
    border-radius: 8px;
    display: grid;
    gap: 4px;
    padding: 10px 12px;
}

.operations-evidence-card li strong {
    color: #13223a;
}

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

.operations-evidence-card header a,
.operations-evidence-links a,
.operations-evidence-card li a {
    align-items: center;
    background: #eaf1fb;
    border: 1px solid #b9d8f4;
    border-radius: 8px;
    color: #0f5ea8;
    display: inline-flex;
    font-weight: 900;
    justify-content: center;
    min-height: 40px;
    padding: 8px 12px;
    text-align: center;
}

.operations-evidence-card li a {
    justify-self: start;
    min-height: 32px;
    padding: 6px 10px;
}

.operations-evidence-card header a:hover,
.operations-evidence-links a:hover,
.operations-evidence-card li a:hover {
    background: #dbeafe;
    color: #0b4f8a;
}

.operations-iso-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 16px;
}

.operations-iso-list a {
    border: 1px solid #b9d8f4;
    border-radius: 999px;
    background: #eaf1fb;
    color: #0f5ea8;
    font-weight: 900;
    padding: 8px 12px;
}

@media (max-width: 1100px) {
    .operations-policy-hero,
    .operations-policy-grid,
    .operations-evidence-map,
    .operations-rule-list {
        grid-template-columns: 1fr;
    }

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

@media (max-width: 620px) {
    .operations-register-grid {
        grid-template-columns: 1fr;
    }

    .operations-meta div {
        grid-template-columns: 1fr;
    }

    .operations-rule-header {
        display: grid;
    }

    .operations-rule-progress {
        width: 100%;
    }

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

    .operations-evidence-card header,
    .operations-evidence-links {
        grid-template-columns: 1fr;
        display: grid;
    }
}

.mode-switch-basic {
    border: 1px solid #b9d8f4;
    background: #eaf1fb;
    color: #0f5ea8 !important;
}

.mode-switch-basic:hover {
    border-color: #0f5ea8;
    background: #d8eafb;
    color: #0b4f8a !important;
}
/* SMART_TOPNAV_END */


/* ADVANCED_HERO_AND_LOGO_FIX_START */
.brand-logo-dark-bg {
    display: none !important;
}

.advanced-mode .brand-logo-light-bg {
    display: none !important;
}

.advanced-mode .brand-logo-dark-bg {
    display: block !important;
}

.advanced-mode .page-hero.advanced-hero {
    background: #0b1a2b;
    color: #ffffff;
}

.advanced-mode .page-hero.advanced-hero .eyebrow,
.advanced-mode .page-hero.advanced-hero h1,
.advanced-mode .page-hero.advanced-hero p {
    color: #ffffff;
}

.advanced-mode .page-hero.advanced-hero .eyebrow {
    color: #b9d8f4;
}

.advanced-mode .page-hero.advanced-hero .button-link,
.advanced-mode .page-hero.advanced-hero .button-link.secondary {
    border: 1px solid rgba(255, 255, 255, 0.28);
    background: #123456;
    color: #ffffff;
}

.advanced-mode .page-hero.advanced-hero .button-link:hover,
.advanced-mode .page-hero.advanced-hero .button-link.secondary:hover {
    background: #0f5ea8;
    color: #ffffff;
}
/* ADVANCED_HERO_AND_LOGO_FIX_END */


/* ADVANCED_RISK_COLORS_START */
.advanced-mode {
    --risk-critical: #b42318;
    --risk-critical-bg: #fee4e2;
    --risk-critical-line: #fda29b;
    --risk-high: #c2410c;
    --risk-high-bg: #ffedd5;
    --risk-high-line: #fdba74;
    --risk-medium: #a16207;
    --risk-medium-bg: #fef3c7;
    --risk-medium-line: #facc15;
    --risk-low: #15803d;
    --risk-low-bg: #dcfce7;
    --risk-low-line: #86efac;
    --risk-info: #0f5ea8;
    --risk-info-bg: #eaf1fb;
    --risk-info-line: #b9d8f4;
}

.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article {
    position: relative;
    overflow: hidden;
    border-width: 1px;
    box-shadow: 0 14px 32px rgba(15, 40, 79, 0.10);
}

.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article::before,
.advanced-mode .follow-up-metrics > article::before,
.advanced-mode .risk-posture-metrics article::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 6px;
    border-radius: 8px 0 0 8px;
}

.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(1) {
    border-color: var(--risk-info-line);
    background: linear-gradient(135deg, #ffffff 0%, var(--risk-info-bg) 100%);
}
.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(1)::before { background: var(--risk-info); }
.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(1) strong { color: var(--risk-info); }

.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(2) {
    border-color: var(--risk-medium-line);
    background: linear-gradient(135deg, #ffffff 0%, var(--risk-medium-bg) 100%);
}
.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(2)::before { background: var(--risk-medium); }
.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(2) strong { color: var(--risk-medium); }

.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(3),
.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(5) {
    border-color: var(--risk-high-line);
    background: linear-gradient(135deg, #ffffff 0%, var(--risk-high-bg) 100%);
}
.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(3)::before,
.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(5)::before { background: var(--risk-high); }
.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(3) strong,
.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(5) strong { color: var(--risk-high); }

.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(4) {
    border-color: var(--risk-critical-line);
    background: linear-gradient(135deg, #ffffff 0%, var(--risk-critical-bg) 100%);
}
.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(4)::before { background: var(--risk-critical); }
.advanced-mode .dashboard.advanced-dashboard > .metric-grid > article:nth-child(4) strong { color: var(--risk-critical); }

.advanced-mode .matrix-cell {
    min-height: 64px;
    border-width: 2px;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
    transition: transform 0.12s ease, box-shadow 0.12s ease, border-color 0.12s ease;
}

.advanced-mode a.matrix-cell:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.18);
}

.advanced-mode .matrix-empty {
    background: #f1f5f9;
    border-color: #e2e8f0;
    color: #94a3b8;
}

.advanced-mode .matrix-low {
    background: linear-gradient(135deg, #f0fdf4 0%, #bbf7d0 100%);
    border-color: #22c55e;
    color: #14532d;
}

.advanced-mode .matrix-medium {
    background: linear-gradient(135deg, #fef9c3 0%, #fde68a 100%);
    border-color: #eab308;
    color: #713f12;
}

.advanced-mode .matrix-high {
    background: linear-gradient(135deg, #ffedd5 0%, #fb923c 100%);
    border-color: #ea580c;
    color: #7c2d12;
}

.advanced-mode .matrix-critical {
    background: linear-gradient(135deg, #fee2e2 0%, #ef4444 100%);
    border-color: #b91c1c;
    color: #7f1d1d;
}

.advanced-mode .matrix-high span,
.advanced-mode .matrix-critical span {
    color: rgba(127, 29, 29, 0.82);
    font-weight: 900;
}

.advanced-mode .matrix-cell strong {
    font-size: 1.35rem;
    font-weight: 950;
}

.advanced-mode .follow-up-metrics > article {
    position: relative;
    overflow: hidden;
    border-width: 1px;
}

.advanced-mode .follow-up-metrics > article:nth-child(1),
.advanced-mode .follow-up-metrics > article:nth-child(3) {
    border-color: var(--risk-critical-line);
    background: linear-gradient(135deg, #ffffff 0%, var(--risk-critical-bg) 100%);
}
.advanced-mode .follow-up-metrics > article:nth-child(1)::before,
.advanced-mode .follow-up-metrics > article:nth-child(3)::before { background: var(--risk-critical); }
.advanced-mode .follow-up-metrics > article:nth-child(1) strong,
.advanced-mode .follow-up-metrics > article:nth-child(3) strong { color: var(--risk-critical); }

.advanced-mode .follow-up-metrics > article:nth-child(2) {
    border-color: var(--risk-high-line);
    background: linear-gradient(135deg, #ffffff 0%, var(--risk-high-bg) 100%);
}
.advanced-mode .follow-up-metrics > article:nth-child(2)::before { background: var(--risk-high); }
.advanced-mode .follow-up-metrics > article:nth-child(2) strong { color: var(--risk-high); }

.advanced-mode .follow-up-metrics > article:nth-child(4) {
    border-color: var(--risk-medium-line);
    background: linear-gradient(135deg, #ffffff 0%, var(--risk-medium-bg) 100%);
}
.advanced-mode .follow-up-metrics > article:nth-child(4)::before { background: var(--risk-medium); }
.advanced-mode .follow-up-metrics > article:nth-child(4) strong { color: var(--risk-medium); }

.advanced-mode .risk-posture-card {
    border: 1px solid rgba(185, 216, 244, 0.28);
    background:
        radial-gradient(circle at 85% 20%, rgba(239, 68, 68, 0.20), transparent 32%),
        linear-gradient(135deg, #081523 0%, #10284f 58%, #0b1a2b 100%);
}

.advanced-mode .risk-posture-metrics article {
    position: relative;
    overflow: hidden;
    border-color: rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, 0.10);
}

.advanced-mode .risk-posture-metrics article:nth-child(1)::before { background: var(--risk-info); }
.advanced-mode .risk-posture-metrics article:nth-child(2)::before { background: var(--risk-high); }
.advanced-mode .risk-posture-metrics article:nth-child(3)::before { background: var(--risk-critical); }
.advanced-mode .risk-posture-metrics article:nth-child(4)::before { background: var(--risk-medium); }
/* ADVANCED_RISK_COLORS_END */


/* ADVANCED_RISK_POSTURE_WHITE_START */
.advanced-mode .risk-posture-card {
    border: 1px solid #dbe4f0 !important;
    background: #ffffff !important;
    box-shadow: 0 14px 34px rgba(15, 40, 79, 0.10) !important;
}

.advanced-mode .risk-posture-card .eyebrow {
    color: #0f5ea8 !important;
}

.advanced-mode .risk-posture-copy h2 {
    color: #172033 !important;
}

.advanced-mode .risk-posture-copy p,
.advanced-mode .risk-posture-copy strong {
    color: #52637a !important;
}

.advanced-mode .risk-posture-progress {
    background: #eef3f8 !important;
}

.advanced-mode .risk-posture-progress span {
    background: linear-gradient(90deg, #22c55e 0%, #eab308 45%, #f97316 72%, #ef4444 100%) !important;
}

.advanced-mode .risk-posture-metrics article {
    border-color: #dbe4f0 !important;
    background: #f8fafc !important;
}

.advanced-mode .risk-posture-metrics article strong {
    color: #172033 !important;
}

.advanced-mode .risk-posture-metrics article span {
    color: #52637a !important;
}
/* ADVANCED_RISK_POSTURE_WHITE_END */



.maturity-meter-track {
    position: relative;
    overflow: visible;
    background: linear-gradient(
        90deg,
        #b91c1c 0%,
        #b91c1c 38%,
        #f97316 38%,
        #f97316 58%,
        #facc15 58%,
        #facc15 68%,
        #86efac 68%,
        #86efac 88%,
        #15803d 88%,
        #15803d 100%
    );
}

.maturity-meter-track span {
    width: var(--maturity-percent, 0%);
    background: rgba(255, 255, 255, 0.68);
    border-right: 4px solid #0f172a;
    box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.12);
}

.maturity-meter-track i {
    position: absolute;
    top: -5px;
    bottom: -5px;
    left: var(--target-percent, 60%);
    width: 2px;
    background: #111827;
    border-radius: 999px;
}

.maturity-scale {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    margin-top: 6px;
    color: #5f6b63;
    font-size: 0.78rem;
    font-weight: 800;
}

.maturity-scale small {
    text-align: center;
}

.maturity-immediate p {
    color: #991b1b;
}

.maturity-attention p {
    color: #c2410c;
}

.maturity-acceptable p {
    color: #854d0e;
}

.maturity-correct p {
    color: #166534;
}

.maturity-continuous p {
    color: #14532d;
}


/* Maturity meter: fill reflects current maturity level, not the full target palette. */
.maturity-meter .maturity-meter-track {
    background: #edf2ee;
    border: 1px solid #d8e1d9;
}

.maturity-meter .maturity-meter-track span {
    width: var(--maturity-percent, 0%);
    border-right: 0;
    box-shadow: none;
}

.maturity-meter.maturity-immediate .maturity-meter-track span {
    background: #b91c1c;
}

.maturity-meter.maturity-attention .maturity-meter-track span {
    background: #f97316;
}

.maturity-meter.maturity-acceptable .maturity-meter-track span {
    background: #facc15;
}

.maturity-meter.maturity-correct .maturity-meter-track span {
    background: #86efac;
}

.maturity-meter.maturity-continuous .maturity-meter-track span {
    background: #15803d;
}


/* Compact internal navigation for Controls ISO module */
.controls-subnav {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 18px;
}

.controls-subnav a {
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(190, 213, 238, 0.24);
    border-radius: 6px;
    color: #e8f2ff;
    display: inline-flex;
    font-size: 14px;
    font-weight: 700;
    line-height: 1;
    padding: 9px 11px;
    text-decoration: none;
}

.controls-subnav a:hover {
    background: rgba(255, 255, 255, 0.14);
}

.advanced-dashboard .page-heading {
    align-items: flex-start;
    gap: 20px;
    overflow: visible;
}

.advanced-dashboard .page-heading > div:first-child {
    min-width: 0;
}

.advanced-dashboard .page-heading .button-group {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
    max-width: 760px;
}

.advanced-dashboard .page-heading .button-group .button-link,
.advanced-dashboard .page-heading .button-group .button-link-light {
    border-radius: 6px;
    font-size: 14px;
    line-height: 1;
    min-height: 0;
    padding: 10px 12px;
    white-space: nowrap;
}

@media (max-width: 900px) {
    .advanced-dashboard .page-heading {
        display: block;
    }

    .advanced-dashboard .page-heading .button-group {
        justify-content: flex-start;
        margin-top: 14px;
        max-width: none;
    }
}


/* DISABLED: Force compact hero layout in advanced controls pages\n
.advanced-mode .treatment-dashboard > .page-heading {
    box-sizing: border-box;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    margin-left: 0 !important;
    max-width: none !important;
    overflow: visible !important;
    padding-left: 32px !important;
    padding-right: 32px !important;
    width: 100% !important;
}

.advanced-mode .treatment-dashboard > .page-heading > div:first-child {
    min-width: 0 !important;
    width: 100% !important;
}

.advanced-mode .treatment-dashboard > .page-heading h1 {
    font-size: clamp(38px, 5vw, 72px) !important;
    line-height: 1.05 !important;
    max-width: 980px !important;
    overflow-wrap: anywhere !important;
}

.advanced-mode .treatment-dashboard > .page-heading .button-group {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    justify-content: flex-start !important;
    margin-top: 14px !important;
    max-width: 100% !important;
    width: 100% !important;
}

.advanced-mode .treatment-dashboard > .page-heading .button-group a.button-link,
.advanced-mode .treatment-dashboard > .page-heading .button-group a.button-link-light {
    align-items: center !important;
    border-radius: 6px !important;
    display: inline-flex !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    justify-content: center !important;
    line-height: 1.1 !important;
    min-height: 0 !important;
    padding: 9px 11px !important;
    width: auto !important;
    white-space: nowrap !important;
}


/* Hide duplicated module subnav; the advanced topbar is the single navigation. */
.advanced-mode .controls-subnav {
    display: none !important;
}


/* SGSI home roadmap */
.sgsi-roadmap {
    background: #ffffff;
    border: 1px solid #d8e2ee;
    border-radius: 8px;
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.08);
    margin: 22px 0;
    overflow: hidden;
}

.sgsi-roadmap > .section-heading {
    border-bottom: 1px solid #d8e2ee;
    padding: 18px 22px;
}

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

.sgsi-step-card {
    border-bottom: 1px solid #e2e8f0;
    border-right: 1px solid #e2e8f0;
    display: grid;
    gap: 14px;
    grid-template-columns: 42px minmax(0, 1fr);
    min-height: 148px;
    padding: 18px 20px;
}

.sgsi-step-card:nth-child(2n) {
    border-right: 0;
}

.sgsi-step-number {
    align-items: center;
    background: #e8f2ff;
    border: 1px solid #b8d6f5;
    border-radius: 50%;
    color: #105da8;
    display: flex;
    font-size: 16px;
    font-weight: 800;
    height: 38px;
    justify-content: center;
    width: 38px;
}

.sgsi-step-done .sgsi-step-number {
    background: #e8f7ef;
    border-color: #9bd3b0;
    color: #166534;
}

.sgsi-step-body {
    min-width: 0;
}

.sgsi-step-body h3 {
    color: #132238;
    font-size: 18px;
    line-height: 1.2;
    margin: 2px 0 8px;
}

.sgsi-step-body p {
    color: #526173;
    margin: 0 0 12px;
}

.sgsi-step-footer {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.sgsi-step-footer strong {
    color: #132238;
    font-size: 13px;
}

.sgsi-step-footer a {
    color: #105da8;
    font-weight: 800;
    text-decoration: none;
}

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

    .sgsi-step-card {
        border-right: 0;
    }
}


/* Polished SGSI roadmap board */
.sgsi-roadmap-board {
    background: #ffffff !important;
    border: 1px solid #d7e0ea !important;
    border-radius: 8px !important;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.08) !important;
    margin: 22px 0 !important;
    overflow: hidden !important;
}

.sgsi-roadmap-board .section-heading {
    align-items: center !important;
    background: #f8fafc !important;
    border-bottom: 1px solid #d7e0ea !important;
    display: flex !important;
    justify-content: space-between !important;
    padding: 18px 22px !important;
}

.sgsi-roadmap-board-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 0 !important;
}

.sgsi-roadmap-board .sgsi-step-card {
    background: #ffffff !important;
    border: 0 !important;
    border-bottom: 1px solid #e2e8f0 !important;
    border-right: 1px solid #e2e8f0 !important;
    display: grid !important;
    grid-template-columns: 34px minmax(0, 1fr) !important;
    gap: 12px !important;
    min-height: 168px !important;
    padding: 18px !important;
}

.sgsi-roadmap-board .sgsi-step-card:nth-child(4n) {
    border-right: 0 !important;
}

.sgsi-roadmap-board .sgsi-step-number {
    align-items: center !important;
    background: #e8f2ff !important;
    border: 1px solid #9cc7ee !important;
    border-radius: 50% !important;
    color: #105da8 !important;
    display: flex !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    height: 32px !important;
    justify-content: center !important;
    line-height: 1 !important;
    width: 32px !important;
}

.sgsi-roadmap-board .sgsi-step-done .sgsi-step-number {
    background: #e8f7ef !important;
    border-color: #8fd0a8 !important;
    color: #166534 !important;
}

.sgsi-roadmap-board .sgsi-step-body .eyebrow {
    color: #516070 !important;
    font-size: 10px !important;
    letter-spacing: .8px !important;
    margin: 0 0 6px !important;
}

.sgsi-roadmap-board .sgsi-step-done .eyebrow {
    color: #166534 !important;
}

.sgsi-roadmap-board .sgsi-step-body h3 {
    color: #17212f !important;
    font-size: 17px !important;
    line-height: 1.2 !important;
    margin: 0 0 8px !important;
}

.sgsi-roadmap-board .sgsi-step-body p {
    color: #526173 !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
    margin: 0 0 12px !important;
}

.sgsi-roadmap-board .sgsi-step-footer {
    align-items: center !important;
    display: flex !important;
    gap: 10px !important;
    justify-content: space-between !important;
    margin-top: auto !important;
}

.sgsi-roadmap-board .sgsi-step-footer strong {
    color: #17212f !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
}

.sgsi-roadmap-board .sgsi-step-footer a {
    background: #12355b !important;
    border-radius: 6px !important;
    color: #ffffff !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    padding: 7px 9px !important;
    text-decoration: none !important;
    white-space: nowrap !important;
}

@media (max-width: 1200px) {
    .sgsi-roadmap-board-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .sgsi-roadmap-board .sgsi-step-card:nth-child(4n) {
        border-right: 1px solid #e2e8f0 !important;
    }

    .sgsi-roadmap-board .sgsi-step-card:nth-child(2n) {
        border-right: 0 !important;
    }
}

@media (max-width: 720px) {
    .sgsi-roadmap-board-grid {
        grid-template-columns: 1fr !important;
    }

    .sgsi-roadmap-board .sgsi-step-card {
        border-right: 0 !important;
    }
}


/* SGSI dashboard */
.sgsi-dashboard-hero {
    background: linear-gradient(135deg, #0f5ea8 0%, #17324f 100%);
    border-radius: 8px;
    color: #ffffff;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 520px);
    margin: 22px 0;
    padding: 28px;
}

.sgsi-dashboard-hero h2 {
    color: #ffffff;
    font-size: 64px;
    line-height: 1;
    margin: 6px 0;
}

.sgsi-dashboard-hero p {
    color: #e7f1ff;
    margin: 0 0 14px;
}

.sgsi-score-track {
    background: rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    height: 12px;
    max-width: 560px;
    overflow: hidden;
}

.sgsi-score-track span {
    background: #7dd3fc;
    display: block;
    height: 100%;
}

.sgsi-score-immediate .sgsi-score-track span { background: #dc2626; }
.sgsi-score-attention .sgsi-score-track span { background: #f97316; }
.sgsi-score-acceptable .sgsi-score-track span { background: #eab308; }
.sgsi-score-correct .sgsi-score-track span { background: #86efac; }
.sgsi-score-continuous .sgsi-score-track span { background: #16a34a; }

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

.sgsi-dashboard-metrics article {
    background: rgba(255, 255, 255, 0.10);
    border: 1px solid rgba(255, 255, 255, 0.20);
    border-radius: 8px;
    padding: 16px;
}

.sgsi-dashboard-metrics strong {
    color: inherit;
    display: block;
    font-size: 30px;
    line-height: 1;
    margin-bottom: 6px;
}

.sgsi-dashboard-metrics span {
    color: inherit;
    display: block;
    font-size: 13px;
}

.sgsi-dashboard-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    margin: 18px 0;
}

.risk-heatmap {
    display: grid;
    gap: 6px;
    grid-template-columns: repeat(5, minmax(54px, 1fr));
    padding: 18px;
}

.risk-heatmap-cell {
    align-items: center;
    border-radius: 6px;
    color: #17212f;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 58px;
    text-decoration: none;
}

.risk-heatmap-cell strong {
    font-size: 22px;
    line-height: 1;
}

.risk-heatmap-cell span {
    font-size: 11px;
}

.heatmap-low { background: #dcfce7; }
.heatmap-medium { background: #fef3c7; }
.heatmap-high { background: #fed7aa; }
.heatmap-critical { background: #fecaca; }

.sgsi-dashboard-metrics-light article {
    background: #f8fafc;
    border-color: #d8e2ee;
    color: #17212f;
}

@media (max-width: 980px) {
    .sgsi-dashboard-hero,
    .sgsi-dashboard-grid {
        grid-template-columns: 1fr;
    }
}


/* Professional risk assistant */
.risk-assistant-flow {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin: 0 0 18px;
}

.risk-assistant-step {
    background: #ffffff;
    border: 1px solid #d9e2ec;
    border-radius: 8px;
    padding: 16px;
}

.risk-assistant-step span {
    align-items: center;
    background: #e7eef8;
    border-radius: 999px;
    color: #12325c;
    display: inline-flex;
    font-weight: 800;
    height: 28px;
    justify-content: center;
    margin-bottom: 10px;
    width: 28px;
}

.risk-assistant-step strong {
    color: #14243b;
    display: block;
    font-size: 1rem;
}

.risk-assistant-step p {
    color: #5d6b7a;
    margin: 4px 0 0;
}

.risk-assistant-step.active {
    border-color: #2f7fca;
    box-shadow: 0 0 0 1px rgba(47, 127, 202, 0.12);
}

.risk-decision-panel {
    align-items: center;
    background: #eef6ff;
    border: 1px solid #c7dced;
    border-left: 6px solid #0f5ea8;
    border-radius: 8px;
    display: flex;
    gap: 18px;
    justify-content: space-between;
    margin: 0 0 18px;
    padding: 18px;
}

.risk-decision-panel h2 {
    color: #132238;
    font-size: 1.28rem;
    margin: 4px 0 6px;
}

.risk-decision-panel p {
    color: #526173;
    font-weight: 800;
    line-height: 1.35;
    margin: 0;
    max-width: 780px;
}

.risk-decision-panel .button-group {
    justify-content: flex-end;
    min-width: 360px;
}

.status-pill {
    border-radius: 999px;
    display: inline-flex;
    font-size: 0.78rem;
    font-weight: 800;
    padding: 5px 10px;
    text-transform: uppercase;
}

.status-ok {
    background: #e4f7ec;
    color: #17633a;
}

.status-pending {
    background: #fff1d6;
    color: #835400;
}

.risk-scenario-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}

.risk-scenario-card {
    background: #ffffff;
    border: 1px solid #d9e2ec;
    border-left: 5px solid #98a6b3;
    border-radius: 8px;
    padding: 14px;
}

.risk-scenario-card.risk-low {
    border-left-color: #2f855a;
}

.risk-scenario-card.risk-medium {
    border-left-color: #d69e2e;
}

.risk-scenario-card.risk-high {
    border-left-color: #dd6b20;
}

.risk-scenario-card.risk-critical {
    border-left-color: #c53030;
}

.risk-scenario-select {
    align-items: center;
    color: #425466;
    display: flex;
    font-size: 0.9rem;
    font-weight: 900;
    gap: 8px;
    margin-bottom: 10px;
}

.risk-scenario-header {
    align-items: start;
    display: flex;
    gap: 16px;
    justify-content: space-between;
}

.risk-scenario-header h3 {
    color: #14243b;
    font-size: 1.05rem;
    margin: 4px 0 0;
}

.risk-score-badge {
    border: 1px solid #d9e2ec;
    border-radius: 8px;
    min-width: 72px;
    padding: 8px;
    text-align: center;
}

.risk-score-badge strong {
    color: #14243b;
    display: block;
    font-size: 1.35rem;
    line-height: 1;
}

.risk-score-badge span {
    color: #5d6b7a;
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
}

.risk-method-grid {
    display: grid;
    gap: 10px;
    margin: 12px 0;
}

.risk-method-grid div {
    background: #f7fafc;
    border: 1px solid #e4ebf2;
    border-radius: 8px;
    padding: 10px;
}

.risk-method-grid dt,
.risk-treatment-note strong,
.risk-iso-list strong {
    color: #14243b;
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.risk-method-grid dd {
    color: #314154;
    margin: 4px 0 0;
}

.risk-rating-row {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.risk-rating-row div {
    border: 1px solid #d9e2ec;
    border-radius: 8px;
    padding: 12px;
}

.risk-rating-row span,
.risk-rating-row small {
    color: #5d6b7a;
    display: block;
}

.risk-rating-row strong {
    color: #14243b;
    display: block;
    font-size: 1.5rem;
}

.risk-treatment-note,
.risk-iso-list {
    border-top: 1px solid #e4ebf2;
    margin-top: 10px;
    padding-top: 10px;
}

.risk-treatment-note p,
.risk-iso-list p {
    color: #314154;
    margin: 5px 0 0;
}

@media (max-width: 900px) {
    .risk-assistant-flow,
    .risk-rating-row {
        grid-template-columns: 1fr;
    }

    .risk-decision-panel,
    .manual-risk-guide,
    .selected-asset-lock {
        align-items: stretch;
        display: grid;
    }

    .risk-decision-panel .button-group,
    .manual-risk-guide .button-group {
        justify-content: flex-start;
        min-width: 0;
    }

    .risk-scenario-grid {
        grid-template-columns: 1fr;
    }
}


/* Professional risk register */
.risk-register-list {
    display: grid;
    gap: 16px;
}

.risk-register-card {
    background: #ffffff;
    border: 1px solid #d9e2ec;
    border-radius: 8px;
    padding: 18px;
}

.risk-register-main {
    align-items: start;
    display: flex;
    gap: 16px;
    justify-content: space-between;
}

.risk-register-main h3 {
    color: #14243b;
    font-size: 1.3rem;
    margin: 4px 0;
}

.risk-register-main p {
    color: #5d6b7a;
    margin: 0;
}

.risk-register-score {
    border: 1px solid #d9e2ec;
    border-radius: 8px;
    min-width: 92px;
    padding: 10px;
    text-align: center;
}

.risk-register-score strong {
    color: #14243b;
    display: block;
    font-size: 1.9rem;
    line-height: 1;
}

.risk-register-score span {
    color: #5d6b7a;
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.risk-register-method {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 16px 0;
}

.risk-register-method div,
.risk-register-meta div,
.risk-register-notes {
    background: #f7fafc;
    border: 1px solid #e4ebf2;
    border-radius: 8px;
    padding: 12px;
}

.risk-register-method span,
.risk-register-meta span,
.risk-register-notes strong {
    color: #14243b;
    display: block;
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.risk-register-method p,
.risk-register-notes p {
    color: #314154;
    margin: 5px 0 0;
}

.risk-register-meta {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.risk-register-meta strong {
    color: #14243b;
    display: block;
    font-size: 1rem;
    margin-top: 4px;
}

.risk-register-notes {
    margin-top: 14px;
}

.risk-register-actions {
    border-top: 1px solid #e4ebf2;
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 14px;
    padding-top: 14px;
}

.risk-register-actions a {
    color: #0f5fa8;
    font-weight: 800;
}

.empty-state {
    background: #f7fafc;
    border: 1px dashed #cbd6e2;
    border-radius: 8px;
    padding: 24px;
}

@media (max-width: 900px) {
    .risk-register-main,
    .risk-register-actions {
        display: block;
    }

    .risk-register-method,
    .risk-register-meta {
        grid-template-columns: 1fr;
    }

    .risk-register-score {
        margin-top: 12px;
    }
}


.risk-assistant-panel {
    background: #ffffff;
    border: 1px solid #b8d5f2;
    border-radius: 8px;
    box-shadow: 0 18px 50px rgba(15, 35, 60, 0.16);
    margin: 18px 0;
    padding: 22px;
    position: relative;
    z-index: 2;
}

.risk-assistant-panel::before {
    background: #2f7fca;
    border-radius: 8px 0 0 8px;
    bottom: 0;
    content: "";
    left: 0;
    position: absolute;
    top: 0;
    width: 6px;
}

.risk-assistant-panel > * {
    position: relative;
}

.selected-asset-lock {
    align-items: center;
    background: #eef6ff;
    border: 1px solid #c7dced;
    border-left: 6px solid #0f5ea8;
    border-radius: 8px;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    padding: 16px;
}

.selected-asset-lock strong,
.selected-asset-lock span {
    display: block;
}

.selected-asset-lock strong {
    color: #132238;
    font-size: 1.08rem;
    margin-top: 4px;
}

.selected-asset-lock span {
    color: #526173;
    font-weight: 800;
    margin-top: 5px;
}

.manual-risk-guide {
    align-items: center;
    background: #ffffff;
    border: 1px solid #d7e5f2;
    border-radius: 8px;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    padding: 14px 16px;
}

.manual-risk-guide h3 {
    color: #132238;
    font-size: 1rem;
    margin: 3px 0 5px;
}

.manual-risk-guide p {
    color: #526173;
    font-weight: 800;
    line-height: 1.35;
    margin: 0;
}

.manual-existing-risks {
    background: #f8fbff;
    border: 1px solid #d7e5f2;
    border-radius: 8px;
    display: grid;
    gap: 10px;
    padding: 14px 16px;
}

.manual-existing-risks > strong {
    color: #132238;
    font-size: 0.95rem;
}

.manual-existing-risks div {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.manual-existing-risks a {
    background: #eef6ff;
    border: 1px solid #c7dced;
    border-radius: 999px;
    color: #0f5ea8;
    font-size: 0.78rem;
    font-weight: 900;
    padding: 7px 10px;
    text-decoration: none;
}

.manual-existing-risks a:hover {
    text-decoration: underline;
}

.maturity-score-red .report-score,
.maturity-score-red .risk-posture-progress span {
    background: #b42318;
}

.maturity-score-orange .report-score,
.maturity-score-orange .risk-posture-progress span {
    background: #d97706;
}

.maturity-score-green .report-score,
.maturity-score-green .risk-posture-progress span {
    background: #2f9e44;
}

.maturity-score-strong-green .report-score,
.maturity-score-strong-green .risk-posture-progress span {
    background: #147a3c;
}

/* Colores del score de madurez del diagnostico basico */
.report-risk-posture.maturity-score-red .risk-posture-progress span,
.maturity-score-red .risk-posture-progress span {
    background: #b42318 !important;
}

.report-risk-posture.maturity-score-orange .risk-posture-progress span,
.maturity-score-orange .risk-posture-progress span {
    background: #d97706 !important;
}

.report-risk-posture.maturity-score-green .risk-posture-progress span,
.maturity-score-green .risk-posture-progress span {
    background: #2f9e44 !important;
}

.report-risk-posture.maturity-score-strong-green .risk-posture-progress span,
.maturity-score-strong-green .risk-posture-progress span {
    background: #147a3c !important;
}

/* Barra central del score de madurez basico */
.report-risk-posture.maturity-score-red .risk-posture-progress {
    background: rgba(180, 35, 24, 0.14) !important;
}

.report-risk-posture.maturity-score-red .risk-posture-progress span {
    background: #b42318 !important;
}

.report-risk-posture.maturity-score-orange .risk-posture-progress {
    background: rgba(217, 119, 6, 0.16) !important;
}

.report-risk-posture.maturity-score-orange .risk-posture-progress span {
    background: #d97706 !important;
}

.report-risk-posture.maturity-score-green .risk-posture-progress {
    background: rgba(47, 158, 68, 0.16) !important;
}

.report-risk-posture.maturity-score-green .risk-posture-progress span {
    background: #2f9e44 !important;
}

.report-risk-posture.maturity-score-strong-green .risk-posture-progress {
    background: rgba(20, 122, 60, 0.18) !important;
}

.report-risk-posture.maturity-score-strong-green .risk-posture-progress span {
    background: #147a3c !important;
}

/* Encabezado blanco para resultado del diagnostico basico */
.basic-report-cover {
    background: #ffffff !important;
    color: var(--ink) !important;
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: none;
}

.basic-report-cover h1,
.basic-report-cover p,
.basic-report-cover .eyebrow {
    color: var(--ink) !important;
}

.basic-report-cover .eyebrow {
    color: var(--accent) !important;
}

.basic-report-cover .report-actions .button-link {
    background: var(--accent) !important;
    color: #ffffff !important;
}

.basic-report-cover .report-actions .button-link.secondary {
    background: #eef5f3 !important;
    color: var(--accent-dark) !important;
}

/* Colores suaves para mapa de madurez por control */
.report-risk-matrix .matrix-mini-cell.level-0,
.report-risk-matrix .matrix-mini-cell.level-1 {
    background: #fff1f0;
    border-color: #f4c7c2;
    color: #7a241c;
}

.report-risk-matrix .matrix-mini-cell.level-2 {
    background: #fff7ed;
    border-color: #fed7aa;
    color: #8a3f08;
}

.report-risk-matrix .matrix-mini-cell.level-3 {
    background: #effaf1;
    border-color: #bfe6c7;
    color: #245b35;
}

.report-risk-matrix .matrix-mini-cell.level-4 {
    background: #e6f6ea;
    border-color: #8fd19e;
    color: #176235;
}

.report-risk-matrix .matrix-mini-cell.level-5 {
    background: #dff3e5;
    border-color: #5fb879;
    color: #0f5132;
}

.report-risk-matrix .matrix-mini-cell.level-0 strong,
.report-risk-matrix .matrix-mini-cell.level-1 strong,
.report-risk-matrix .matrix-mini-cell.level-2 strong,
.report-risk-matrix .matrix-mini-cell.level-3 strong,
.report-risk-matrix .matrix-mini-cell.level-4 strong,
.report-risk-matrix .matrix-mini-cell.level-5 strong {
    color: inherit;
}

.report-risk-matrix .matrix-mini-cell.level-0 span,
.report-risk-matrix .matrix-mini-cell.level-1 span,
.report-risk-matrix .matrix-mini-cell.level-2 span,
.report-risk-matrix .matrix-mini-cell.level-3 span,
.report-risk-matrix .matrix-mini-cell.level-4 span,
.report-risk-matrix .matrix-mini-cell.level-5 span {
    color: inherit;
    opacity: 0.82;
}

/* Mapa ordenado de madurez: verde arriba, rojo abajo */
.maturity-ordered-map {
    display: grid;
    gap: 10px;
}

.maturity-map-row {
    display: grid;
    grid-template-columns: 180px minmax(0, 1fr);
    gap: 10px;
    align-items: stretch;
}

.maturity-row-label {
    display: grid;
    align-content: center;
    gap: 4px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #f8faf9;
    padding: 14px;
}

.maturity-row-label strong {
    font-size: 1.35rem;
    line-height: 1;
}

.maturity-row-label span {
    color: var(--muted);
    font-weight: 800;
}

.maturity-row-controls {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
}

.maturity-row-controls .matrix-mini-cell {
    min-height: 92px;
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 14px;
}

.maturity-row-controls .matrix-mini-cell strong {
    display: block;
    font-size: 0.98rem;
    line-height: 1.25;
}

.maturity-row-controls .matrix-mini-cell span {
    display: block;
    margin-top: 8px;
    font-size: 0.82rem;
    font-weight: 800;
}

.maturity-row-controls .empty-level {
    background: #f8faf9;
    color: var(--muted);
    opacity: 0.72;
}

@media (max-width: 760px) {
    .maturity-map-row {
        grid-template-columns: 1fr;
    }
}

/* Mapa compacto de madurez, ordenado como lectura tipo heatmap */
.maturity-heat-map {
    direction: rtl;
}

.maturity-heat-map .matrix-mini-cell {
    direction: ltr;
    min-height: 118px;
    border-radius: 8px;
    text-align: left;
}

.maturity-heat-map .matrix-mini-cell strong {
    display: block;
    font-size: 1.15rem;
}

.maturity-heat-map .matrix-mini-cell span {
    display: block;
    margin-top: 8px;
    font-weight: 900;
}

.maturity-heat-map .matrix-mini-cell small {
    display: block;
    margin-top: 10px;
    color: inherit;
    font-weight: 800;
    opacity: 0.72;
}
@media print {
    @page {
        size: A4 landscape;
        margin: 8mm;
    }

    body {
        background: #ffffff !important;
    }

    .topbar,
    .messages,
    .whatsapp-float,
    .report-actions,
    button,
    .button-link {
        display: none !important;
    }

    main,
    .dashboard,
    .report-cover,
    .report-section,
    .report-columns,
    .risk-posture-card,
    .report-risk-posture {
        break-inside: avoid !important;
        page-break-inside: avoid !important;
    }

    .report-section:has(.maturity-heat-map),
    .report-section:has(.report-risk-matrix) {
        break-before: auto !important;
        break-after: auto !important;
        break-inside: avoid !important;
        page-break-inside: avoid !important;
    }

    .maturity-heat-map,
    .report-risk-matrix.maturity-heat-map {
        display: grid !important;
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
        gap: 6px !important;
        direction: ltr !important;
        align-items: stretch !important;
        break-inside: avoid !important;
        page-break-inside: avoid !important;
    }

    .maturity-heat-map .matrix-mini-cell {
        direction: ltr !important;
        min-height: 72px !important;
        padding: 8px 10px !important;
        border-radius: 6px !important;
        break-inside: avoid !important;
        page-break-inside: avoid !important;
        overflow: hidden !important;
    }

    .maturity-heat-map .matrix-mini-cell strong {
        font-size: 0.9rem !important;
        line-height: 1.1 !important;
        margin: 0 !important;
    }

    .maturity-heat-map .matrix-mini-cell span {
        display: block !important;
        margin-top: 4px !important;
        font-size: 0.76rem !important;
        line-height: 1.12 !important;
        font-weight: 900 !important;
    }

    .maturity-heat-map .matrix-mini-cell small {
        display: block !important;
        margin-top: 4px !important;
        font-size: 0.68rem !important;
        line-height: 1.05 !important;
    }
}
.basic-entry-shell {
    place-items: stretch;
}

.basic-entry-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(360px, 0.7fr);
    gap: 28px;
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
    align-items: center;
}

.basic-entry-copy {
    display: grid;
    gap: 18px;
}

.basic-entry-copy h1 {
    max-width: 800px;
}

.basic-entry-copy .muted {
    max-width: 760px;
    font-size: 1.05rem;
}

.entry-highlights {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.entry-highlights span {
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #ffffff;
    color: var(--accent-dark);
    font-weight: 900;
    padding: 9px 14px;
}

.auth-panel h2 {
    font-size: 1.65rem;
}

@media (max-width: 860px) {
    .basic-entry-panel {
        grid-template-columns: 1fr;
    }
}

/* Login SGSI */
.basic-entry-shell {
    place-items: center;
}

.basic-entry-panel {
    display: flex;
    justify-content: center;
    width: min(520px, calc(100% - 32px));
}

.basic-entry-panel .auth-panel {
    width: 100%;
}

.basic-entry-shell {
    place-items: stretch;
}

.basic-entry-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(360px, 0.7fr);
    gap: 28px;
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
    align-items: center;
}

.basic-entry-copy {
    display: grid;
    gap: 18px;
}

.basic-entry-copy h1 {
    max-width: 800px;
}

.basic-entry-copy .muted {
    max-width: 760px;
    font-size: 1.05rem;
}

.entry-highlights {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.entry-highlights span {
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #ffffff;
    color: var(--accent-dark);
    font-weight: 900;
    padding: 9px 14px;
}

.auth-panel h2 {
    font-size: 1.65rem;
}

@media (max-width: 860px) {
    .basic-entry-panel {
        grid-template-columns: 1fr;
    }
}

/* Entrada publica del diagnostico basico */
.basic-entry-shell {
    place-items: stretch;
}

.basic-entry-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(360px, 0.7fr);
    gap: 28px;
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
    align-items: center;
}

.basic-entry-copy {
    display: grid;
    gap: 18px;
}

.basic-entry-copy h1 {
    max-width: 800px;
}

.basic-entry-copy .muted {
    max-width: 760px;
    font-size: 1.05rem;
}

.entry-highlights {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.entry-highlights span {
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #ffffff;
    color: var(--accent-dark);
    font-weight: 900;
    padding: 9px 14px;
}

.auth-panel h2 {
    font-size: 1.65rem;
}

@media (max-width: 860px) {
    .basic-entry-panel {
        grid-template-columns: 1fr;
    }
}

/* Ayudas y progreso para evaluacion de controles */
.detailed-maturity-guide span {
    position: relative;
    cursor: help;
}

.tooltip-wrap {
    position: relative;
    cursor: help;
}

.tooltip-wrap::after {
    position: absolute;
    left: 50%;
    bottom: calc(100% + 10px);
    z-index: 20;
    width: min(320px, 70vw);
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #172033;
    color: #ffffff;
    content: attr(data-tooltip);
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1.35;
    opacity: 0;
    padding: 10px 12px;
    pointer-events: none;
    transform: translate(-50%, 6px);
    transition: opacity 0.16s ease, transform 0.16s ease;
    white-space: normal;
}

.tooltip-wrap:hover::after,
.tooltip-wrap:focus-within::after {
    opacity: 1;
    transform: translate(-50%, 0);
}

.info-dot {
    display: inline-grid;
    place-items: center;
    width: 20px;
    height: 20px;
    margin-left: 6px;
    border-radius: 999px;
    background: #eef5f3;
    color: var(--accent-dark);
    font-size: 0.78rem;
    font-weight: 900;
    vertical-align: middle;
}

.assessment-progress {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    margin: 20px 0;
    color: var(--muted);
    font-size: 0.88rem;
    font-weight: 900;
}

.assessment-progress div {
    height: 10px;
    border-radius: 999px;
    background: #e8efec;
    overflow: hidden;
}

.assessment-progress strong {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #d97706, #2f9e44);
}

@media (max-width: 760px) {
    .tooltip-wrap::after {
        left: 0;
        transform: translate(0, 6px);
    }

    .tooltip-wrap:hover::after,
    .tooltip-wrap:focus-within::after {
        transform: translate(0, 0);
    }
}

/* Evaluacion por tarjetas */
.control-card-form {
    display: grid;
    gap: 18px;
}

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

.control-eval-card {
    display: grid;
    gap: 14px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #ffffff;
    padding: 18px;
}

.control-eval-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.control-eval-head span:not(.info-dot) {
    display: block;
    margin-bottom: 6px;
    color: var(--accent);
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.control-eval-head h2 {
    color: var(--ink);
    font-size: 1.08rem;
    line-height: 1.2;
}

.control-eval-card p {
    color: var(--muted);
    line-height: 1.45;
}

.level-button-group {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 6px;
}

.level-choice {
    display: grid;
}

.level-choice input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.level-choice span {
    display: grid;
    place-items: center;
    min-height: 42px;
    border: 1px solid #cbd6cf;
    border-radius: 8px;
    background: #fbfcfb;
    color: var(--ink);
    font-weight: 900;
}

.level-choice input:checked + span {
    border-color: var(--accent);
    background: var(--accent);
    color: #ffffff;
}

.sticky-form-actions {
    position: sticky;
    bottom: 0;
    z-index: 10;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.94);
    padding: 14px;
    backdrop-filter: blur(10px);
}

@media (max-width: 860px) {
    .control-card-grid {
        grid-template-columns: 1fr;
    }
}

/* Pulido de inicio del diagnostico */
.diagnosis-hero h1 {
    max-width: 860px;
}

.diagnosis-hero .muted {
    max-width: 820px;
    font-size: 1.05rem;
}

.diagnosis-hero a:not(.button-link) {
    font-weight: 900;
}

/* Pulido de resultado ejecutivo */
.result-scope-note {
    margin-top: 14px;
    color: var(--muted);
    font-size: 0.95rem;
    line-height: 1.45;
}

.report-list article span {
    line-height: 1.45;
}

/* Tono comercial: colores sobrios para resultados iniciales */
.maturity-score-red .report-score,
.maturity-score-red .risk-posture-progress span,
.report-risk-posture.maturity-score-red .risk-posture-progress span {
    background: #b85c38 !important;
}

.report-risk-posture.maturity-score-red .risk-posture-progress {
    background: #fff4ed !important;
}

.report-risk-posture.maturity-score-red {
    border-left-color: #b85c38 !important;
}

.report-risk-matrix .matrix-mini-cell.level-0,
.report-risk-matrix .matrix-mini-cell.level-1 {
    background: #fff4ed !important;
    border-color: #f1c9b8 !important;
    color: #7c2d12 !important;
}

.maturity-score-orange .report-score,
.maturity-score-orange .risk-posture-progress span,
.report-risk-posture.maturity-score-orange .risk-posture-progress span {
    background: #c97919 !important;
}

.report-risk-posture.maturity-score-orange .risk-posture-progress {
    background: #fff7ed !important;
}

.report-risk-matrix .matrix-mini-cell.level-2 {
    background: #fff8ed !important;
    border-color: #efd3a5 !important;
    color: #7a4208 !important;
}

/* Escala comercial gradual de madurez */
.maturity-score-red .report-score,
.maturity-score-red .risk-posture-progress span,
.report-risk-posture.maturity-score-red .risk-posture-progress span {
    background: #b85c38 !important;
}

.report-risk-posture.maturity-score-red .risk-posture-progress {
    background: #fff4ed !important;
}

.maturity-score-orange .report-score,
.maturity-score-orange .risk-posture-progress span,
.report-risk-posture.maturity-score-orange .risk-posture-progress span {
    background: #d97706 !important;
}

.report-risk-posture.maturity-score-orange .risk-posture-progress {
    background: #fff7ed !important;
}

.maturity-score-yellow .report-score,
.maturity-score-yellow .risk-posture-progress span,
.report-risk-posture.maturity-score-yellow .risk-posture-progress span {
    background: #c49a08 !important;
}

.report-risk-posture.maturity-score-yellow .risk-posture-progress {
    background: #fffbe6 !important;
}

.maturity-score-green .report-score,
.maturity-score-green .risk-posture-progress span,
.report-risk-posture.maturity-score-green .risk-posture-progress span {
    background: #2f9e44 !important;
}

.report-risk-posture.maturity-score-green .risk-posture-progress {
    background: #effaf1 !important;
}

.maturity-score-strong-green .report-score,
.maturity-score-strong-green .risk-posture-progress span,
.report-risk-posture.maturity-score-strong-green .risk-posture-progress span {
    background: #147a3c !important;
}

.report-risk-posture.maturity-score-strong-green .risk-posture-progress {
    background: #e6f6ea !important;
}

/* Contacto final en reporte y PDF */
.report-contact-card {
    display: grid;
    gap: 8px;
    padding: 20px;
    border-top: 1px solid var(--line);
}

.report-contact-card strong {
    color: var(--ink);
    font-size: 1.08rem;
}

.report-contact-card span {
    color: var(--muted);
    font-weight: 800;
}

.report-contact-card a {
    font-weight: 900;
}

@media print {
    .report-contact-section {
        break-inside: avoid !important;
        page-break-inside: avoid !important;
    }

    .report-contact-card {
        border: 1px solid #dbe4f0 !important;
        border-radius: 8px !important;
        padding: 14px !important;
    }

    .report-contact-card a {
        color: inherit !important;
        text-decoration: none !important;
    }
}

/* Landing publica */
.public-landing {
    min-height: calc(100vh - 72px);
    display: grid;
    align-items: center;
    padding: 48px 20px;
}

.public-landing-inner {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.6fr);
    gap: 32px;
    width: min(1180px, 100%);
    margin: 0 auto;
    align-items: center;
}

.public-landing-copy {
    display: grid;
    gap: 18px;
}

.public-landing-copy h1 {
    max-width: 860px;
    font-size: clamp(2.4rem, 5vw, 4.8rem);
}

.public-landing-copy p {
    max-width: 820px;
    color: var(--muted);
    font-size: 1.08rem;
    line-height: 1.55;
}

.public-landing-copy a:not(.button-link) {
    font-weight: 900;
}

.public-landing-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.public-landing-panel {
    display: grid;
    gap: 12px;
}

.public-landing-panel article {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #ffffff;
    padding: 22px;
}

.public-landing-panel strong {
    display: block;
    color: var(--ink);
    font-size: 2.2rem;
    line-height: 1;
}

.public-landing-panel span {
    display: block;
    margin-top: 8px;
    color: var(--muted);
    font-weight: 900;
}

@media (max-width: 860px) {
    .public-landing-inner {
        grid-template-columns: 1fr;
    }
}

/* Landing publica */
.public-landing {
    min-height: calc(100vh - 72px);
    display: grid;
    align-items: center;
    padding: 48px 20px;
}

.public-landing-inner {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.6fr);
    gap: 32px;
    width: min(1180px, 100%);
    margin: 0 auto;
    align-items: center;
}

.public-landing-copy {
    display: grid;
    gap: 18px;
}

.public-landing-copy h1 {
    max-width: 860px;
    font-size: clamp(2.4rem, 5vw, 4.8rem);
}

.public-landing-copy p {
    max-width: 820px;
    color: var(--muted);
    font-size: 1.08rem;
    line-height: 1.55;
}

.public-landing-copy a:not(.button-link) {
    font-weight: 900;
}

.public-landing-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.public-landing-panel {
    display: grid;
    gap: 12px;
}

.public-landing-panel article {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #ffffff;
    padding: 22px;
}

.public-landing-panel strong {
    display: block;
    color: var(--ink);
    font-size: 2.2rem;
    line-height: 1;
}

.public-landing-panel span {
    display: block;
    margin-top: 8px;
    color: var(--muted);
    font-weight: 900;
}

@media (max-width: 860px) {
    .public-landing-inner {
        grid-template-columns: 1fr;
    }
}

/* CTA de siguiente paso en resultado */
.result-next-step {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    margin: 20px 0;
    border: 1px solid #dbe7df;
    border-left: 5px solid var(--accent);
    border-radius: 8px;
    background: #ffffff;
    padding: 22px 24px;
}

.result-next-step h2 {
    margin-bottom: 8px;
    color: var(--ink);
    font-size: 1.35rem;
}

.result-next-step p {
    max-width: 780px;
    margin-bottom: 8px;
    color: var(--muted);
    line-height: 1.45;
}

.result-next-step span {
    color: var(--muted);
    font-size: 0.92rem;
    font-weight: 800;
}

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

@media (max-width: 860px) {
    .result-next-step {
        align-items: stretch;
        flex-direction: column;
    }

    .result-next-step-actions {
        justify-content: flex-start;
    }
}

@media print {
    .result-next-step {
        break-inside: avoid !important;
        page-break-inside: avoid !important;
        margin: 10px 0 !important;
        padding: 14px !important;
    }

    .result-next-step-actions {
        display: none !important;
    }
}


.auth-form {
    display: grid;
    gap: 16px;
    margin-top: 22px;
}

.form-field {
    display: grid;
    gap: 7px;
}

.form-field span {
    color: #14243b;
    font-weight: 800;
}

.form-field input {
    border: 1px solid #cbd6e2;
    border-radius: 8px;
    font-size: 1rem;
    padding: 12px 14px;
    width: 100%;
}

.auth-submit {
    justify-content: center;
    margin-top: 4px;
    width: 100%;
}

.form-errors {
    background: #fff1f1;
    border: 1px solid #f0b4b4;
    border-radius: 8px;
    color: #8a1f1f;
    font-weight: 700;
    margin-top: 16px;
    padding: 12px 14px;
}

/* CONTROL_ROUTE_BLUE_NORMALIZATION_START */
.advanced-mode .dashboard.advanced-dashboard {
    padding-top: 28px;
}

.advanced-mode .dashboard.advanced-dashboard > .page-heading {
    margin-bottom: 28px;
    min-height: 0;
}

.advanced-mode .dashboard.advanced-dashboard > .page-heading h1 {
    max-width: 980px;
}

.advanced-mode .dashboard.advanced-dashboard > .page-heading .advanced-heading-copy {
    color: #d9e7f7;
    font-size: 1rem;
    line-height: 1.45;
    max-width: 860px;
}

.advanced-mode .sgsi-dashboard-hero {
    margin-top: 8px;
}

.control-route-next-action {
    align-items: center;
    background: linear-gradient(135deg, #0f3558 0%, #0f5ea8 100%);
    border: 1px solid rgba(216, 236, 255, 0.28);
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(8, 20, 36, 0.18);
    color: #ffffff;
    display: flex;
    gap: 24px;
    justify-content: space-between;
    margin: 18px 0;
    padding: 24px 28px;
}

.control-route-next-action h2 {
    color: #ffffff;
    font-size: 1.55rem;
    line-height: 1.2;
    margin: 6px 0 8px;
}

.control-route-next-action p {
    color: #e4f1ff;
    line-height: 1.45;
    margin: 0 0 8px;
    max-width: 780px;
}

.control-route-next-action span,
.control-route-next-action .eyebrow {
    color: #cfe5fb;
}

.control-route-next-side {
    align-items: flex-end;
    display: grid;
    gap: 12px;
    min-width: 220px;
    text-align: right;
}

.control-route-next-side strong {
    color: #ffffff;
    font-size: 0.95rem;
}

.control-route-next-side .button-link {
    justify-content: center;
    white-space: nowrap;
}

.advanced-mode .sgsi-roadmap-board-grid .sgsi-step-card {
    min-height: 210px;
}

.advanced-mode .sgsi-roadmap-board-grid .sgsi-step-next {
    background: #eef7ff !important;
    box-shadow: inset 4px 0 0 #0f5ea8;
}

.advanced-mode .sgsi-roadmap-board-grid .sgsi-step-next .sgsi-step-number {
    background: #0f5ea8 !important;
    border-color: #0f5ea8 !important;
    color: #ffffff !important;
}

.advanced-mode .sgsi-roadmap-board-grid .sgsi-step-pending {
    background: #f8fafc !important;
}

.sgsi-step-outcome {
    color: #233b58 !important;
    display: block;
    font-size: 12px;
    font-weight: 800;
    line-height: 1.35;
    margin: 0 0 12px;
}

.control-route-board .sgsi-roadmap-board-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}

.advanced-mode .control-route-board .sgsi-roadmap-board-grid .sgsi-step-card,
.control-route-board .sgsi-step-card {
    gap: 9px !important;
    grid-template-columns: 28px minmax(0, 1fr) !important;
    min-height: 122px !important;
    padding: 12px 14px !important;
}

.control-route-board .sgsi-step-number {
    font-size: 13px !important;
    height: 28px !important;
    width: 28px !important;
}

.control-route-board .sgsi-step-body .eyebrow {
    font-size: 9px !important;
    margin-bottom: 4px !important;
}

.control-route-board .sgsi-step-body h3 {
    font-size: 14px !important;
    line-height: 1.15 !important;
    margin-bottom: 5px !important;
}

.control-route-board .sgsi-step-body p {
    font-size: 11px !important;
    line-height: 1.22 !important;
    margin-bottom: 8px !important;
}

.control-route-board .sgsi-step-footer {
    gap: 6px !important;
}

.control-route-board .sgsi-step-footer strong,
.control-route-board .sgsi-step-footer a {
    font-size: 10px !important;
}

.control-route-board .sgsi-step-footer a {
    padding: 5px 7px !important;
}

@media (max-width: 1100px) {
    .control-route-board .sgsi-roadmap-board-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 720px) {
    .control-route-board .sgsi-roadmap-board-grid {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 820px) {
    .control-route-next-action {
        align-items: stretch;
        flex-direction: column;
    }

    .control-route-next-side {
        align-items: flex-start;
        text-align: left;
    }
}

.advanced-mode.control-report-mode main {
    background:
        linear-gradient(180deg, var(--advanced-navy) 0, var(--advanced-navy-soft) 300px, var(--advanced-page) 300px, var(--advanced-page) 100%);
    padding-top: 20px;
}

.advanced-mode.control-report-mode .report-cover.basic-report-cover {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    color: #ffffff !important;
    margin: 0 auto 28px;
    padding: 26px 0 20px;
    width: min(1360px, calc(100% - 32px));
}

.advanced-mode.control-report-mode .report-cover.basic-report-cover h1,
.advanced-mode.control-report-mode .report-cover.basic-report-cover p,
.advanced-mode.control-report-mode .report-cover.basic-report-cover .eyebrow {
    color: #ffffff !important;
}

.advanced-mode.control-report-mode .report-cover.basic-report-cover .eyebrow {
    color: #d8ecff !important;
}

.advanced-mode.control-report-mode .report-actions .button-link {
    background: #0f5ea8 !important;
    color: #ffffff !important;
}

.advanced-mode.control-report-mode .report-actions .button-link.secondary,
.advanced-mode.control-report-mode .report-actions .report-back-link {
    background: #ffffff !important;
    color: #0f2a50 !important;
}

.advanced-mode.control-report-mode .report-executive,
.advanced-mode.control-report-mode .risk-posture-card,
.advanced-mode.control-report-mode .result-next-step,
.advanced-mode.control-report-mode .report-kpis,
.advanced-mode.control-report-mode .report-section,
.advanced-mode.control-report-mode .report-columns {
    margin-left: auto;
    margin-right: auto;
    width: min(1360px, calc(100% - 32px));
}

.advanced-mode.control-report-mode .report-executive,
.advanced-mode.control-report-mode .risk-posture-card,
.advanced-mode.control-report-mode .result-next-step,
.advanced-mode.control-report-mode .report-kpis article,
.advanced-mode.control-report-mode .report-section {
    border-color: #d6e0ea;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

@media print {
    .advanced-mode.control-report-mode main,
    .advanced-mode main {
        background: #ffffff !important;
        padding-top: 0 !important;
    }

    .advanced-mode.control-report-mode .report-cover.basic-report-cover {
        color: #172033 !important;
        padding: 0 !important;
        width: 100% !important;
    }

    .advanced-mode.control-report-mode .report-cover.basic-report-cover h1,
    .advanced-mode.control-report-mode .report-cover.basic-report-cover p,
    .advanced-mode.control-report-mode .report-cover.basic-report-cover .eyebrow {
        color: #172033 !important;
    }
}
/* CONTROL_ROUTE_BLUE_NORMALIZATION_END */

/* TREATMENT_RECOMMENDATION_GUIDE_START */
.treatment-recommendation-hero {
    align-items: center;
    background: linear-gradient(135deg, #0f3558 0%, #0f5ea8 100%);
    border: 1px solid rgba(216, 236, 255, 0.28);
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(8, 20, 36, 0.18);
    color: #ffffff;
    display: flex;
    gap: 24px;
    justify-content: space-between;
    margin: 18px 0;
    padding: 24px 28px;
}

.treatment-recommendation-hero h2 {
    color: #ffffff;
    font-size: 1.55rem;
    line-height: 1.2;
    margin: 6px 0 8px;
}

.treatment-recommendation-hero p {
    color: #e4f1ff;
    line-height: 1.45;
    margin: 0 0 8px;
    max-width: 820px;
}

.treatment-recommendation-hero span,
.treatment-recommendation-hero .eyebrow {
    color: #cfe5fb;
}

.treatment-decision-panel {
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 8px;
    min-width: 190px;
    padding: 18px;
    text-align: center;
}

.treatment-decision-panel strong {
    color: #ffffff;
    display: block;
    font-size: 1.45rem;
    line-height: 1;
    margin-bottom: 8px;
}

.treatment-decision-panel span {
    color: #d9ecff;
    display: block;
    font-weight: 900;
}

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

.treatment-decision-summary article {
    background: #ffffff;
    border: 1px solid #d7e0ea;
    border-radius: 8px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06);
    padding: 18px;
}

.treatment-decision-summary strong {
    color: #0f3558;
    display: block;
    font-size: 2rem;
    line-height: 1;
    margin-bottom: 8px;
}

.treatment-decision-summary span {
    color: #5b6978;
    font-weight: 900;
}

.treatment-recommendation-card {
    background: #eef7ff;
    border: 1px solid #b8d6f5;
    border-left: 5px solid #0f5ea8;
    border-radius: 8px;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 0.92fr) minmax(280px, 1.08fr);
    margin: 16px 0 20px;
    padding: 18px;
}

.treatment-recommendation-card h3 {
    color: #132238;
    font-size: 1.18rem;
    line-height: 1.2;
    margin: 4px 0 8px;
}

.treatment-recommendation-card p {
    color: #35465a;
    line-height: 1.42;
    margin: 0 0 8px;
}

.treatment-recommendation-card span {
    color: #526173;
    font-weight: 800;
}

.treatment-recommendation-card ol {
    display: grid;
    gap: 8px;
    margin: 0;
    padding-left: 20px;
}

.treatment-recommendation-card li {
    color: #17212f;
    font-weight: 800;
    line-height: 1.35;
}

@media (max-width: 980px) {
    .treatment-recommendation-hero,
    .treatment-recommendation-card {
        grid-template-columns: 1fr;
    }

    .treatment-recommendation-hero {
        align-items: stretch;
        flex-direction: column;
    }

    .treatment-decision-panel {
        text-align: left;
    }

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

@media (max-width: 620px) {
    .treatment-decision-summary {
        grid-template-columns: 1fr;
    }
}
/* TREATMENT_RECOMMENDATION_GUIDE_END */

/* TREATMENT_ACTION_PLAN_START */
.treatment-action-plan {
    background: #ffffff;
    border: 1px solid #d7e0ea;
    border-radius: 8px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06);
    margin: 16px 0 22px;
    overflow: hidden;
}

.treatment-action-plan > .section-heading {
    background: #f8fafc;
    border-bottom: 1px solid #d7e0ea;
}

.treatment-action-list {
    display: grid;
    gap: 0;
}

.treatment-action-card {
    border-bottom: 1px solid #e2e8f0;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(240px, 0.42fr) minmax(0, 1fr);
    padding: 18px;
}

.treatment-action-card:last-child {
    border-bottom: 0;
}

.treatment-action-card h4 {
    color: #132238;
    font-size: 1.05rem;
    line-height: 1.25;
    margin: 0 0 8px;
}

.treatment-action-card p {
    color: #526173;
    line-height: 1.38;
    margin: 0;
}

.treatment-action-form {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.treatment-action-form label {
    display: grid;
    gap: 6px;
}

.treatment-action-form label span {
    color: #526173;
    font-size: 0.78rem;
    font-weight: 900;
}

.treatment-action-form input,
.treatment-action-form select,
.treatment-action-form textarea {
    background: #ffffff;
    border: 1px solid #cbd6e2;
    border-radius: 8px;
    color: #17212f;
    font: inherit;
    min-height: 38px;
    padding: 9px 10px;
    width: 100%;
}

.treatment-action-notes,
.treatment-action-note {
    grid-column: span 2;
}

.treatment-action-form button {
    align-self: end;
    background: #0f5ea8;
    min-height: 38px;
    white-space: nowrap;
}

.treatment-action-readonly {
    background: #f8fafc;
    border: 1px solid #d7e0ea;
    border-radius: 8px;
    display: grid;
    gap: 8px;
    padding: 14px;
}

.treatment-action-readonly strong {
    color: #132238;
}

.treatment-action-readonly span {
    color: #526173;
    font-weight: 800;
}

@media (max-width: 1080px) {
    .treatment-action-card,
    .treatment-action-form {
        grid-template-columns: 1fr;
    }

    .treatment-action-notes,
    .treatment-action-note {
        grid-column: auto;
    }

    .treatment-action-form button {
        justify-self: start;
    }
}
/* TREATMENT_ACTION_PLAN_END */

/* SUGGESTED_CONTROL_PRIORITY_START */
.suggested-control-pills {
    display: grid;
    gap: 10px;
}

.treatment-workstream-list {
    display: grid;
    gap: 12px;
}

.treatment-workstream {
    background: #ffffff;
    border: 1px solid #d7e0ea;
    border-left: 6px solid #0f5ea8;
    border-radius: 8px;
    display: grid;
    gap: 12px;
    padding: 16px;
}

.treatment-workstream.priority-1 {
    border-left-color: #dc2626;
}

.treatment-workstream.priority-2 {
    border-left-color: #f97316;
}

.treatment-workstream header {
    align-items: start;
    display: flex;
    gap: 14px;
    justify-content: space-between;
}

.treatment-workstream header h4 {
    color: #132238;
    font-size: 1.08rem;
    margin: 2px 0 4px;
}

.treatment-workstream header span,
.treatment-workstream li {
    color: #526173;
    font-size: 0.88rem;
    font-weight: 750;
    line-height: 1.35;
}

.treatment-workstream header > strong {
    background: #e8f2ff;
    border: 1px solid #b8d6f5;
    border-radius: 999px;
    color: #0f5ea8;
    flex: 0 0 auto;
    font-size: 0.78rem;
    padding: 7px 10px;
}

.workstream-body {
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(260px, 0.9fr) minmax(260px, 1.1fr);
}

.workstream-body h5 {
    color: #132238;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    margin: 0 0 8px;
    text-transform: uppercase;
}

.workstream-body ol,
.workstream-body ul {
    margin: 0;
    padding-left: 20px;
}

.workstream-evidence {
    background: #f8fbff;
    border: 1px solid #d7e5f2;
    border-radius: 8px;
    padding: 10px;
}

.workstream-controls {
    border-top: 1px solid #e2e8f0;
    padding-top: 10px;
}

.workstream-controls summary {
    color: #0f5ea8;
    cursor: pointer;
    font-size: 0.82rem;
    font-weight: 900;
}

.workstream-controls div {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 8px;
}

.workstream-controls span {
    background: #f1f5f9;
    border: 1px solid #d7e0ea;
    border-radius: 999px;
    color: #475569;
    font-size: 0.76rem;
    font-weight: 850;
    padding: 6px 8px;
}

.iso-control-support {
    margin-top: 12px;
}

.suggested-control-pill {
    align-items: start;
    background: #f8fafc;
    border: 1px solid #d7e0ea;
    border-left: 5px solid #94a3b8;
    border-radius: 8px;
    display: grid;
    gap: 10px;
    padding: 14px;
}

.suggested-control-pill.priority-1 {
    border-left-color: #dc2626;
    background: #fff7f7;
}

.suggested-control-pill.priority-2 {
    border-left-color: #f97316;
    background: #fff8f1;
}

.suggested-control-pill.priority-3 {
    border-left-color: #0f5ea8;
}

.suggested-control-pill strong {
    color: #132238;
    display: block;
    line-height: 1.25;
}

.suggested-control-pill span {
    color: #526173;
    display: block;
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1.35;
    margin-top: 6px;
}

.suggested-control-pill > a {
    color: #0f5ea8;
    font-weight: 900;
}

.system-evidence-strip {
    border-top: 1px solid rgba(15, 94, 168, 0.12);
    display: grid;
    gap: 8px;
    margin-top: 10px;
    padding-top: 10px;
}

.system-evidence-strip small {
    color: #475569;
    display: -webkit-box;
    font-size: 0.78rem;
    font-weight: 800;
    line-height: 1.35;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.system-evidence-strip nav {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.system-evidence-strip nav a {
    background: #e8f2ff;
    border: 1px solid #b8d6f5;
    border-radius: 999px;
    color: #0f5ea8;
    font-size: 0.76rem;
    font-weight: 900;
    line-height: 1;
    padding: 7px 9px;
    text-decoration: none;
}

.system-evidence-strip nav a:hover {
    background: #d8eafb;
    color: #0b4f8a;
}

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

.priority-actions form {
    margin: 0;
}

.priority-actions button {
    background: #e8f2ff;
    border: 1px solid #b8d6f5;
    color: #0f3558;
    min-height: 30px;
    padding: 6px 10px;
}

.suggested-control-more {
    border: 1px dashed #b8d6f5;
    border-radius: 8px;
    background: #f8fbff;
    padding: 10px;
}

.suggested-control-more summary {
    color: #0f5ea8;
    cursor: pointer;
    font-weight: 900;
}

.suggested-control-more-list {
    display: grid;
    gap: 10px;
    margin-top: 10px;
}
/* SUGGESTED_CONTROL_PRIORITY_END */

/* GLOBAL_CONTROL_PRIORITY_START */
.form-section-note {
    background: #f3f7fb;
    border: 1px solid #d8e5f0;
    border-left: 5px solid #0f5ea8;
    border-radius: 8px;
    display: grid;
    gap: 4px;
    margin: 8px 0 2px;
    padding: 12px 14px;
}

.form-section-note strong {
    color: #132238;
}

.form-section-note span {
    color: #526173;
    font-weight: 700;
}

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

.asset-context-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 8px;
}

.asset-context-pills span {
    background: #eef6ff;
    border: 1px solid #c7dced;
    border-radius: 999px;
    color: #334963;
    display: inline-flex;
    font-size: 0.72rem;
    font-weight: 800;
    line-height: 1.2;
    padding: 5px 8px;
}

.risk-treatment-note small {
    color: #5c6c7d;
    display: block;
    font-weight: 800;
    margin-top: 6px;
}

.risk-register-meta small {
    color: #526173;
    display: block;
    font-size: 0.78rem;
    font-weight: 700;
    margin-top: 3px;
}

.global-priority-list {
    display: grid;
    gap: 14px;
}

.global-priority-card {
    background: #ffffff;
    border: 1px solid #d7e0ea;
    border-left: 6px solid #94a3b8;
    border-radius: 8px;
    padding: 18px;
}

.global-priority-card.priority-1 {
    border-left-color: #dc2626;
}

.global-priority-card.priority-2 {
    border-left-color: #f97316;
}

.global-priority-card.priority-3 {
    border-left-color: #0f5ea8;
}

.global-priority-main {
    align-items: start;
    display: flex;
    gap: 18px;
    justify-content: space-between;
}

.global-priority-main h2 {
    color: #132238;
    font-size: 1.3rem;
    margin: 4px 0;
}

.global-priority-main h2 small {
    color: #526173;
    display: block;
    font-size: 0.82rem;
    font-weight: 800;
    margin-top: 4px;
}

.global-priority-main p {
    color: #526173;
    font-weight: 700;
    margin: 0;
}

.global-priority-score {
    background: #edf5ff;
    border: 1px solid #c8dced;
    border-radius: 8px;
    min-width: 110px;
    padding: 12px;
    text-align: center;
}

.global-priority-score strong {
    color: #0f5ea8;
    display: block;
    font-size: 2rem;
    line-height: 1;
}

.global-priority-score span {
    color: #526173;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

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

.inline-action-form {
    display: inline-flex;
    margin: 0;
}

.inline-action-form button {
    cursor: pointer;
    font: inherit;
}

.risk-register-actions .inline-action-form button {
    background: transparent;
    border: 0;
    color: #0f5fa8;
    font-weight: 800;
    padding: 0;
}

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

.baseline-control-grid div {
    background: #f8fbff;
    border: 1px solid #d7e5f2;
    border-radius: 8px;
    padding: 12px;
}

.baseline-control-grid span {
    color: #132238;
    display: block;
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.baseline-control-grid p {
    color: #526173;
    font-weight: 700;
    line-height: 1.35;
    margin: 6px 0 0;
}

.global-priority-meta div {
    background: #f8fafc;
    border: 1px solid #e1e8f0;
    border-radius: 8px;
    padding: 12px;
}

.global-priority-meta span {
    color: #526173;
    display: block;
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.global-priority-meta strong {
    color: #132238;
    display: block;
    margin-top: 4px;
}

.global-priority-assets {
    background: #f8fbff;
    border: 1px dashed #c8dced;
    border-radius: 8px;
    padding: 10px 12px;
}

.global-priority-assets summary {
    color: #0f5ea8;
    cursor: pointer;
    font-weight: 900;
}

.global-priority-assets ul {
    color: #526173;
    font-weight: 700;
    margin: 10px 0 0 18px;
}

@media (max-width: 900px) {
    .global-priority-main {
        display: block;
    }

    .global-priority-score {
        margin-top: 12px;
    }

    .global-priority-meta {
        grid-template-columns: 1fr;
    }

    .baseline-control-grid {
        grid-template-columns: 1fr;
    }
}
/* GLOBAL_CONTROL_PRIORITY_END */

/* GUIDED_TREATMENT_FLOW_START */
.next-step-panel {
    align-items: center;
    background: #eef6ff;
    border: 1px solid #c7dced;
    border-left: 6px solid #0f5ea8;
    border-radius: 8px;
    display: flex;
    gap: 20px;
    justify-content: space-between;
    margin: 18px 0;
    padding: 18px 20px;
}

.next-step-panel h2 {
    color: #132238;
    font-size: 1.35rem;
    margin: 4px 0;
}

.next-step-panel p {
    color: #526173;
    font-weight: 700;
    margin: 0;
}

.treatment-asset-header {
    gap: 18px;
}

.asset-info-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
    max-width: 900px;
}

.asset-info-pills span {
    background: #eef6ff;
    border: 1px solid #c7dced;
    border-radius: 999px;
    color: #334963;
    font-size: 0.82rem;
    font-weight: 800;
    line-height: 1.2;
    padding: 6px 10px;
}

.asset-control-focus {
    background: #f8fbff;
    border: 1px solid #d7e5f2;
    border-radius: 8px;
    margin: 18px 0;
    padding: 16px;
}

.compact-heading {
    align-items: start;
    margin-bottom: 12px;
}

.compact-heading h3 {
    color: #132238;
    margin: 0 0 4px;
}

.compact-heading p {
    color: #526173;
    font-weight: 700;
    margin: 0;
}

.suggested-control-layout .suggested-control-pills {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.suggested-control-layout .suggested-control-more {
    grid-column: 1 / -1;
}

.treatment-support-columns {
    grid-template-columns: minmax(260px, 0.9fr) minmax(320px, 1.1fr);
}

.asset-related-risks h3 {
    margin-bottom: 8px;
}

.asset-related-risks .compact-list {
    gap: 6px;
}

.asset-related-risks .related-risk-row {
    align-items: center;
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 8px 10px;
}

.asset-related-risks .related-risk-row strong {
    font-size: 0.92rem;
    line-height: 1.25;
}

.asset-related-risks .related-risk-row span {
    font-size: 0.8rem;
    margin-top: 2px;
}

.asset-related-risks .related-risk-row a {
    align-self: center;
    font-size: 0.8rem;
    margin-top: 0;
    white-space: nowrap;
}

.asset-related-risks .related-risk-more {
    border-top: 1px solid #dfe7f1;
    margin-top: 2px;
    padding-top: 8px;
}

.asset-related-risks .related-risk-more summary {
    color: #0f5ea8;
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 900;
}

.asset-related-risks .related-risk-more-list {
    margin-top: 10px;
}

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

    .treatment-workstream header {
        flex-direction: column;
    }

    .next-step-panel {
        align-items: stretch;
        display: grid;
    }

    .treatment-support-columns {
        grid-template-columns: 1fr;
    }
}
/* GUIDED_TREATMENT_FLOW_END */

/* RISK_ASSET_DASHBOARD_START */
.risk-dashboard-split {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-bottom: 18px;
}

.compact-risk-matrix {
    grid-template-columns: 34px repeat(5, minmax(42px, 1fr));
    gap: 6px;
}

.compact-risk-matrix .matrix-axis,
.compact-risk-matrix .matrix-corner {
    min-height: 34px;
}

.compact-risk-matrix .matrix-cell {
    min-height: 52px;
}

.analysis-switch {
    background: #ffffff;
    border: 1px solid #d7e5f2;
    border-radius: 8px;
    display: grid;
    gap: 0;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0 0 18px;
    overflow: hidden;
}

.analysis-switch a {
    background: #f8fbff;
    color: #132238;
    display: grid;
    gap: 4px;
    min-height: 68px;
    padding: 14px 18px;
    text-decoration: none;
}

.analysis-switch a + a {
    border-left: 1px solid #d7e5f2;
}

.analysis-switch a.active {
    background: #132e50;
    color: #ffffff;
}

.analysis-switch strong {
    font-size: 1rem;
}

.analysis-switch span {
    color: inherit;
    font-size: 0.84rem;
    font-weight: 800;
    line-height: 1.3;
    opacity: 0.82;
}

.risk-search-panel {
    background: #ffffff;
    border: 1px solid #d7e5f2;
    border-radius: 8px;
    margin: 0 0 14px;
    padding: 14px 16px;
}

.risk-search-panel [data-live-filter="true"] {
    display: grid;
    gap: 8px;
}

.risk-search-panel label {
    color: #132238;
    font-size: 0.86rem;
    font-weight: 900;
}

.risk-search-panel [data-live-filter="true"] > div {
    align-items: center;
    display: flex;
    gap: 10px;
}

.risk-search-panel input[type="search"] {
    background: #f8fbff;
    border: 1px solid #c7dced;
    border-radius: 8px;
    color: #132238;
    flex: 1;
    font-size: 0.95rem;
    font-weight: 800;
    min-height: 44px;
    min-width: 220px;
    padding: 10px 12px;
}

.risk-search-submit {
    height: 1px;
    opacity: 0;
    overflow: hidden;
    padding: 0;
    pointer-events: none;
    position: absolute;
    width: 1px;
}

.risk-search-panel p {
    color: #526173;
    font-size: 0.84rem;
    font-weight: 800;
    margin: 0;
}

.asset-risk-card-list {
    display: grid;
    gap: 14px;
}

.asset-risk-card {
    background: #ffffff;
    border: 1px solid #d7e5f2;
    border-left: 6px solid #0f5ea8;
    border-radius: 8px;
    padding: 16px;
}

.asset-risk-card header {
    align-items: start;
    display: flex;
    gap: 16px;
    justify-content: space-between;
}

.asset-risk-card h3 {
    color: #132238;
    font-size: 1.22rem;
    margin: 4px 0;
}

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

.asset-risk-body section {
    background: #f8fbff;
    border: 1px solid #dbe8f4;
    border-radius: 8px;
    padding: 12px;
}

.asset-risk-body h4 {
    color: #132238;
    font-size: 0.86rem;
    letter-spacing: 0.04em;
    margin: 0 0 10px;
    text-transform: uppercase;
}

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

.risk-chip-list span {
    background: #eef6ff;
    border: 1px solid #c7dced;
    border-radius: 999px;
    color: #334963;
    font-size: 0.82rem;
    font-weight: 800;
    line-height: 1.25;
    padding: 7px 10px;
}

.asset-risk-related {
    grid-column: 1 / -1;
}

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

.asset-audit-risk-list {
    display: grid;
    gap: 12px;
    margin-top: 14px;
}

.asset-audit-risk-card {
    background: #f8fbff;
    border: 1px solid #dbe8f4;
    border-left: 5px solid #0f5ea8;
    border-radius: 8px;
    display: grid;
    gap: 12px;
    padding: 12px;
}

.asset-audit-risk-card.compact {
    gap: 10px;
    padding: 10px;
}

.asset-audit-risk-card header,
.asset-audit-risk-card footer {
    align-items: start;
    display: flex;
    gap: 14px;
    justify-content: space-between;
}

.compact-more-panel {
    background: #ffffff;
    border: 1px dashed #b8cfe4;
    border-radius: 8px;
    padding: 10px;
}

.compact-more-panel summary {
    color: #0f5ea8;
    cursor: pointer;
    font-weight: 900;
}

.compact-analysis-table {
    margin-top: 14px;
    overflow-x: auto;
}

.compact-analysis-table table {
    border-collapse: separate;
    border-spacing: 0;
    min-width: 1120px;
    width: 100%;
}

.compact-analysis-table th {
    background: #eef6ff;
    border-bottom: 1px solid #c7dced;
    color: #132238;
    font-size: 0.74rem;
    font-weight: 900;
    letter-spacing: 0.03em;
    padding: 10px 11px;
    text-align: left;
    text-transform: uppercase;
    vertical-align: bottom;
    white-space: nowrap;
}

.compact-analysis-table td {
    background: #ffffff;
    border-bottom: 1px solid #dbe8f4;
    color: #334963;
    font-size: 0.84rem;
    font-weight: 800;
    line-height: 1.32;
    padding: 11px;
    vertical-align: top;
}

.compact-analysis-table tbody tr:hover td {
    background: #f8fbff;
}

.compact-analysis-table .compact-more-panel {
    margin-top: 10px;
}

.asset-analysis-table table {
    min-width: 1020px;
}

.risk-analysis-table table {
    min-width: 1320px;
}

.risk-table-title {
    min-width: 150px;
}

.risk-table-title strong,
.risk-table-title span {
    display: block;
}

.risk-table-title strong {
    color: #132238;
    font-size: 0.9rem;
    line-height: 1.25;
}

.risk-table-title span {
    color: #5a6d82;
    font-size: 0.78rem;
    margin-top: 4px;
}

.risk-table-text {
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    color: #334963;
    display: -webkit-box;
    max-width: 230px;
    overflow: hidden;
}

.risk-table-score {
    color: #132238;
    font-size: 0.95rem;
    font-weight: 900;
    text-align: center;
    white-space: nowrap;
}

.risk-level-pill {
    background: #eef6ff;
    border: 1px solid #c7dced;
    border-radius: 999px;
    color: #0f5ea8;
    display: inline-flex;
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1;
    padding: 7px 9px;
    white-space: nowrap;
}

.risk-level-pill.risk-20,
.risk-level-pill.risk-25 {
    background: #fff1f2;
    border-color: #fecdd3;
    color: #b42318;
}

.risk-level-pill.risk-15,
.risk-level-pill.risk-16 {
    background: #fff7ed;
    border-color: #fed7aa;
    color: #c05621;
}

.risk-table-actions {
    display: grid;
    gap: 6px;
    justify-items: end;
    text-align: right;
    white-space: nowrap;
}

.risk-table-actions a {
    color: #0f5ea8;
    font-weight: 900;
    text-decoration: none;
}

.risk-table-actions a:hover {
    text-decoration: underline;
}

.risk-table-actions .risk-table-delete {
    color: #9f1239;
    font-size: 0.78rem;
}

.risk-table-assets-cell {
    min-width: 190px;
}

.compact-risk-line {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.compact-risk-line span {
    background: #ffffff;
    border: 1px solid #d7e5f2;
    border-radius: 8px;
    color: #526173;
    font-size: 0.82rem;
    font-weight: 800;
    line-height: 1.3;
    padding: 8px;
}

.compact-risk-line strong {
    color: #132238;
}

.compact-asset-list {
    display: grid;
    gap: 7px;
    max-width: 240px;
}

.compact-asset-list > strong {
    color: #132238;
    font-size: 0.9rem;
}

.compact-asset-list span {
    background: #eef6ff;
    border: 1px solid #c7dced;
    border-radius: 999px;
    color: #334963;
    display: inline-flex;
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1.2;
    max-width: 100%;
    overflow: hidden;
    padding: 6px 9px;
    text-overflow: ellipsis;
    white-space: nowrap;
    width: fit-content;
}

.compact-asset-list summary {
    color: #0f5ea8;
    cursor: pointer;
    font-size: 0.82rem;
    font-weight: 900;
}

.compact-asset-list details div {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin-top: 7px;
}

.asset-audit-risk-card h4 {
    color: #132238;
    font-size: 1rem;
    margin: 4px 0 0;
}

.asset-audit-score {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.asset-audit-score span {
    background: #eef6ff;
    border: 1px solid #c7dced;
    border-radius: 999px;
    color: #334963;
    font-size: 0.78rem;
    font-weight: 900;
    padding: 6px 9px;
}

.asset-audit-risk-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.asset-audit-risk-grid section {
    background: #ffffff;
    border: 1px solid #d7e5f2;
    border-radius: 8px;
    min-height: 104px;
    padding: 10px;
}

.asset-audit-risk-grid h5 {
    color: #132238;
    font-size: 0.74rem;
    letter-spacing: 0.04em;
    margin: 0 0 7px;
    text-transform: uppercase;
}

.asset-audit-risk-grid p,
.asset-audit-risk-card footer span {
    color: #526173;
    font-size: 0.84rem;
    font-weight: 800;
    line-height: 1.35;
    margin: 0;
}

.risk-pill-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}

.risk-pill {
    align-items: center;
    background: #ffffff;
    border: 1px solid #d7e5f2;
    border-left: 5px solid #0f5ea8;
    border-radius: 8px;
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(0, 1fr) auto;
    min-height: 86px;
    padding: 10px;
}

.risk-pill a:first-child {
    min-width: 0;
    text-decoration: none;
}

.risk-pill strong {
    color: #132238;
    display: block;
    font-size: 0.9rem;
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.risk-pill span {
    color: #526173;
    display: block;
    font-size: 0.78rem;
    font-weight: 900;
    margin-top: 4px;
}

.risk-pill-delete {
    background: #fff1f2;
    border: 1px solid #fecdd3;
    border-radius: 999px;
    color: #9f1239;
    font-size: 0.72rem;
    font-weight: 900;
    padding: 5px 8px;
    text-decoration: none;
}

.delete-confirmation-card {
    display: grid;
    gap: 18px;
}

.delete-confirmation-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.danger-button {
    background: #b42318;
    border: 1px solid #991b1b;
    border-radius: 8px;
    color: #ffffff;
    cursor: pointer;
    font-weight: 900;
    min-height: 42px;
    padding: 10px 16px;
}

.auditable-risk-list {
    display: grid;
    gap: 14px;
}

.auditable-risk-card {
    background: #ffffff;
    border: 1px solid #d7e5f2;
    border-left: 6px solid #0f5ea8;
    border-radius: 8px;
    display: grid;
    gap: 14px;
    padding: 16px;
}

.auditable-risk-card header,
.auditable-risk-card footer {
    align-items: start;
    display: flex;
    gap: 16px;
    justify-content: space-between;
}

.auditable-risk-card h3 {
    color: #132238;
    font-size: 1.18rem;
    margin: 4px 0;
}

.auditable-risk-scores {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(110px, 1fr));
    min-width: 250px;
}

.auditable-risk-scores div {
    background: #eef6ff;
    border: 1px solid #c7dced;
    border-radius: 8px;
    display: grid;
    gap: 2px;
    padding: 10px;
}

.auditable-risk-scores span,
.auditable-risk-scores small {
    color: #526173;
    font-size: 0.74rem;
    font-weight: 900;
    text-transform: uppercase;
}

.auditable-risk-scores strong {
    color: #132238;
    font-size: 1.05rem;
}

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

.auditable-risk-grid section {
    background: #f8fbff;
    border: 1px solid #dbe8f4;
    border-radius: 8px;
    min-height: 116px;
    padding: 12px;
}

.auditable-risk-grid h4 {
    color: #132238;
    font-size: 0.78rem;
    letter-spacing: 0.04em;
    margin: 0 0 8px;
    text-transform: uppercase;
}

.auditable-risk-grid p,
.auditable-risk-card footer span {
    color: #526173;
    font-size: 0.88rem;
    font-weight: 800;
    line-height: 1.35;
    margin: 0;
}

@media (max-width: 1000px) {
    .risk-dashboard-split,
    .asset-risk-body,
    .asset-audit-risk-grid,
    .compact-risk-line,
    .auditable-risk-grid,
    .analysis-switch,
    .advanced-mode .risk-register-summary {
        grid-template-columns: 1fr;
    }

    .analysis-switch a + a {
        border-left: 0;
        border-top: 1px solid #d7e5f2;
    }

    .risk-search-panel form > div {
        align-items: stretch;
        display: grid;
    }

    .asset-risk-card header {
        display: grid;
    }

    .asset-audit-risk-card header,
    .asset-audit-risk-card footer {
        display: grid;
    }

    .asset-audit-score {
        justify-content: flex-start;
    }

    .compact-analysis-table table,
    .asset-analysis-table table,
    .risk-analysis-table table {
        min-width: 980px;
    }

    .auditable-risk-card header,
    .auditable-risk-card footer {
        display: grid;
    }

    .auditable-risk-scores {
        min-width: 0;
    }

    .form-grid-two {
        grid-template-columns: 1fr;
    }
}
/* RISK_ASSET_DASHBOARD_END */

/* Login centrado */
.basic-entry-shell {
    place-items: center;
}

.basic-entry-panel {
    display: flex;
    justify-content: center;
    width: min(1180px, calc(100% - 32px));
}

.basic-entry-panel .auth-panel {
    width: min(430px, 100%);
}

/* Registro de incidentes */
.incident-kpi-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    margin-bottom: 18px;
}

.incident-kpi {
    border: 1px solid #cfe0f1;
    border-radius: 8px;
    background: #f7fbff;
    color: var(--ink);
    display: grid;
    min-height: 118px;
    padding: 18px;
    text-decoration: none;
}

.incident-kpi span {
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.incident-kpi strong {
    color: var(--accent);
    font-size: 2.45rem;
    line-height: 1;
}

.incident-kpi em {
    color: #526174;
    font-style: normal;
    font-weight: 800;
}

.incident-kpi-strong {
    background: #14375d;
    color: #ffffff;
}

.incident-kpi-strong span,
.incident-kpi-strong strong,
.incident-kpi-strong em {
    color: #ffffff;
}

.incident-kpi-alert {
    border-left: 6px solid #dc2626;
}

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

.incident-guide-card p,
.incident-guide-card li {
    color: #526174;
    font-weight: 700;
    line-height: 1.45;
}

.incident-compact-list,
.incident-steps {
    margin: 12px 0 0;
    padding-left: 20px;
}

.incident-tag {
    border: 1px solid #bfdbfe;
    border-radius: 999px;
    background: #eff6ff;
    color: #0f5ea8;
    display: inline-flex;
    font-weight: 900;
    padding: 5px 10px;
}

.incident-tag-high,
.incident-tag-critical {
    border-color: #fecaca;
    background: #fff1f2;
    color: #b91c1c;
}

.incident-file-header {
    align-items: center;
    border: 1px solid #cfe0f1;
    border-left: 8px solid var(--accent);
    border-radius: 8px;
    background: #ffffff;
    display: flex;
    justify-content: space-between;
    margin-bottom: 16px;
    padding: 22px;
}

.incident-file-header h2 {
    font-size: 1.8rem;
    margin-bottom: 8px;
}

.incident-file-score {
    border-radius: 8px;
    background: #e8f1fb;
    color: var(--accent);
    display: grid;
    min-width: 130px;
    padding: 16px;
    place-items: center;
    text-align: center;
}

.incident-file-score strong {
    font-size: 2.2rem;
    line-height: 1;
}

.incident-file-score span {
    font-size: 0.82rem;
    font-weight: 900;
    text-transform: uppercase;
}

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

.incident-step {
    border: 1px solid #cfe0f1;
    border-radius: 8px;
    background: #f8fbff;
    color: #526174;
    display: flex;
    gap: 10px;
    min-height: 64px;
    padding: 12px;
    align-items: center;
}

.incident-step strong {
    align-items: center;
    border-radius: 999px;
    background: #dbeafe;
    color: var(--accent);
    display: inline-flex;
    height: 32px;
    justify-content: center;
    min-width: 32px;
}

.incident-step span {
    font-weight: 900;
    line-height: 1.2;
}

.incident-step.is-active {
    border-color: #6aa7dd;
    background: #14375d;
    color: #ffffff;
}

.incident-form-grid {
    display: grid;
    gap: 16px;
}

.incident-dropzone {
    border: 2px dashed #9ecaf0;
    border-radius: 8px;
    background: #f8fbff;
    color: #405269;
    cursor: pointer;
    display: grid;
    gap: 8px;
    margin-bottom: 14px;
    padding: 24px;
    text-align: center;
}

.incident-dropzone:focus,
.incident-dropzone.is-dragging {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(16, 40, 79, 0.16);
    outline: none;
}

.incident-dropzone input {
    height: auto;
}

.incident-evidence-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.incident-evidence-card {
    border: 1px solid #cfe0f1;
    border-radius: 8px;
    background: #ffffff;
    padding: 16px;
}

.incident-evidence-card h3 {
    margin: 0 0 8px;
}

.incident-evidence-card small {
    color: #64748b;
    font-weight: 800;
}

.incident-save-bar {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
}

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

.project-card {
    border: 1px solid #cfe0f1;
    border-left: 6px solid var(--advanced-blue);
    border-radius: 8px;
    background: #ffffff;
    display: grid;
    gap: 14px;
    padding: 18px;
}

.project-card-header {
    align-items: flex-start;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr) auto;
}

.project-card h3 {
    margin: 0 0 8px;
}

.project-card p {
    color: #52616b;
    font-weight: 800;
    margin: 0;
}

.project-progress {
    border-radius: 8px;
    background: #eaf1fb;
    color: var(--advanced-blue);
    min-width: 96px;
    padding: 14px;
    text-align: center;
}

.project-progress strong {
    display: block;
    font-size: 2rem;
    line-height: 1;
}

.project-progress span {
    display: block;
    font-size: 0.76rem;
    font-weight: 950;
    text-transform: uppercase;
}

.project-meter {
    border: 1px solid #cfe0f1;
    border-radius: 999px;
    background: #f4f8fc;
    height: 12px;
    overflow: hidden;
}

.project-meter span {
    background: var(--advanced-blue);
    display: block;
    height: 100%;
}

.project-mini-stats {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin: 0;
}

.project-mini-stats div {
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    padding: 10px;
}

.project-mini-stats dt {
    color: #52616b;
    font-size: 0.72rem;
    font-weight: 950;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.project-mini-stats dd {
    color: #10284f;
    font-size: 1.15rem;
    font-weight: 950;
    margin: 0;
}

.project-meta {
    border-top: 1px solid #d5e2ef;
    padding-top: 12px;
}

.project-file-header {
    margin-bottom: 16px;
}

.project-subtask-row td:first-child {
    padding-left: 34px;
}

.project-subtask-row td:first-child strong::before {
    color: #6b7b8f;
    content: "-> ";
}

.project-workbench .page-heading {
    margin-bottom: 10px;
    padding-top: 10px;
    padding-bottom: 16px;
}

.project-workbench .page-heading h1 {
    font-size: clamp(30px, 3.4vw, 46px);
    line-height: 1.02;
}

.project-workbench .advanced-heading-copy {
    font-size: 1rem;
    margin-top: 5px;
}

.project-workbench .page-heading .button-group .button-link,
.project-workbench .page-heading .button-group .button-link-light {
    padding: 9px 11px;
}

.project-command-bar {
    align-items: center;
    background: #ffffff;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    display: flex;
    gap: 8px;
    justify-content: flex-start;
    margin-bottom: 14px;
    padding: 8px;
}

.project-command-bar a {
    border: 1px solid #cfe0f1;
    border-radius: 6px;
    color: var(--accent);
    font-weight: 950;
    padding: 9px 14px;
}

.project-command-bar a.is-active {
    background: var(--accent);
    color: #ffffff;
}

.project-command-bar span {
    color: #52616b;
    font-weight: 850;
    margin-left: auto;
}

.project-overview-grid {
    align-items: start;
    display: grid;
    gap: 16px;
    grid-template-columns: minmax(0, 1fr);
}

.project-summary-strip {
    align-items: stretch;
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(260px, 1.25fr) minmax(220px, 0.9fr) minmax(220px, 0.9fr);
    margin: 0 0 14px;
}

.project-summary-card {
    min-height: 112px;
}

.project-overview-grid.project-overview-diagram {
    grid-template-columns: 1fr;
}

.project-main-panel,
.project-side-card {
    background: #ffffff;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
}

.project-main-panel {
    overflow: visible;
}

.project-main-panel .section-heading {
    border-bottom: 1px solid #dbe6ef;
    margin: 0;
    padding: 12px 16px;
}

.project-main-panel .section-heading h2 {
    font-size: 1.1rem;
}

.project-main-panel .section-heading span {
    font-size: 0.95rem;
}

.project-task-table {
    position: relative;
}

.project-task-header,
.project-task-row {
    align-items: center;
    display: grid;
    gap: 7px;
    grid-template-columns: 22px minmax(220px, 1.75fr) minmax(130px, 0.78fr) minmax(104px, 0.52fr) minmax(112px, 0.55fr) minmax(112px, 0.55fr) minmax(104px, 0.5fr) 62px 30px;
}

.project-task-header {
    border-bottom: 1px solid #e5edf5;
    color: #52616b;
    font-size: 0.72rem;
    font-weight: 950;
    padding: 6px 12px;
    text-transform: uppercase;
}

.project-task-row {
    border-bottom: 1px solid #e8eef4;
    cursor: grab;
    min-height: 34px;
    padding: 3px 12px;
}

.project-task-row:hover {
    background: #f6f9fd;
}

.project-task-row.is-saving {
    background: #f7fbff;
    box-shadow: inset 3px 0 0 #8fbcea;
}

.project-task-row.is-saved {
    background: #f4fbf7;
    box-shadow: inset 3px 0 0 #16a34a;
}

.project-task-row.is-save-error {
    background: #fff7f7;
    box-shadow: inset 3px 0 0 #dc2626;
}

.project-task-row.is-calculated {
    background: #fbfcfe;
}

.project-task-row.priority-critical {
    box-shadow: inset 4px 0 0 #b42318;
}

.project-task-row.priority-critical:not(.is-saving):not(.is-saved):not(.is-save-error) {
    background: #fffafa;
}

.project-task-row.priority-high:not(.priority-critical) {
    box-shadow: inset 4px 0 0 #d97706;
}

.project-task-row.is-calculated .project-task-progress-input {
    background: #e8edf4;
    border-color: #cbd5e1;
    color: #334155;
    cursor: not-allowed;
    opacity: 1;
}

.project-task-row.is-calculated .project-task-progress-form::before {
    color: #64748b;
    content: "auto";
    font-size: 0.64rem;
    font-weight: 950;
    letter-spacing: 0;
    margin-right: 2px;
    text-transform: uppercase;
}

.project-task-row.is-calculated .project-check {
    background: #ffffff;
    border-color: #7a8798;
    cursor: pointer;
    opacity: 1;
}

.project-task-row.is-hidden-by-parent {
    display: none;
}

.project-task-row.is-collapsed .project-check {
    border-color: #1d62aa;
    box-shadow: 0 0 0 4px rgba(29, 98, 170, 0.08);
}

.project-task-row.is-calculated .project-check.is-done {
    background: #16a34a;
    border-color: #16a34a;
}

.project-task-row.is-dragging {
    cursor: grabbing;
    opacity: 0.62;
}

.project-task-row.is-drop-target {
    box-shadow: inset 0 2px 0 #1d62aa;
}

.project-task-row.is-subtask .project-task-name {
    padding-left: 28px;
}

.project-task-row.is-subtask .project-task-title-input {
    color: #26364f;
    font-weight: 780;
}

.project-task-row.is-subtask .project-task-title-input.is-done {
    color: #7b8492;
}

.project-task-row.is-subtask .project-task-assignee-input,
.project-task-row.is-subtask .project-task-date-input,
.project-task-row.is-subtask .project-task-hours-input,
.project-task-row.is-subtask .project-task-progress-input {
    font-weight: 760;
}

.project-task-row span {
    color: #52616b;
    font-size: 0.88rem;
    font-weight: 800;
}

.project-task-name {
    display: grid;
    gap: 2px;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
}

.project-task-title-form {
    grid-column: 1 / -1;
    margin: 0;
}

.project-caret + .project-task-title-form,
.project-indent + .project-task-title-form,
.project-caret + .project-task-title-link,
.project-indent + .project-task-title-link {
    grid-column: 2;
}

.project-task-title-link {
    display: inline;
    width: fit-content;
    max-width: 100%;
    min-width: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent !important;
    color: #17223b;
    font: inherit;
    font-size: 0.92rem;
    font-weight: 900;
    line-height: 1.25;
    text-align: left;
    text-decoration: none;
    cursor: pointer;
}

.project-task-title-link:hover,
.project-task-title-link:focus {
    color: #0d5ca6;
    background: transparent !important;
    box-shadow: none;
    outline: 0;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.project-task-title-input {
    background: transparent;
    border: 1px solid transparent;
    border-radius: 4px;
    color: #17223b;
    font: inherit;
    font-size: 0.92rem;
    font-weight: 900;
    min-width: 0;
    padding: 2px 5px;
    width: 100%;
}

.project-task-title-input:focus {
    background: #ffffff;
    border-color: #8fbcea;
    box-shadow: 0 0 0 3px rgba(143, 188, 234, 0.2);
    outline: 0;
}

.project-task-name a {
    color: #17223b;
    font-weight: 950;
}

.project-task-name a.is-done,
.project-task-title-link.is-done,
.project-task-title-input.is-done {
    color: #6f7785;
    text-decoration: line-through;
}

.project-task-date-form {
    justify-self: center;
    margin: 0;
    min-width: 0;
}

.project-task-date-input {
    background: #f8fbff;
    border: 1px solid transparent;
    border-radius: 7px;
    color: #52616b;
    cursor: pointer;
    font: inherit;
    font-size: 0.88rem;
    font-weight: 900;
    min-height: 32px;
    padding: 5px 4px;
    text-align: center;
    width: 116px;
}

.project-task-date-input:hover,
.project-task-date-input:focus {
    background: #ffffff;
    border-color: #8fbcea;
    box-shadow: 0 0 0 3px rgba(143, 188, 234, 0.18);
    outline: 0;
}

.project-task-inline-form {
    align-items: center;
    display: flex;
    gap: 4px;
    justify-self: center;
    margin: 0;
    min-width: 0;
}

.project-task-assignee-form {
    justify-self: stretch;
}

.project-task-assignee-input,
.project-task-priority-input,
.project-task-hours-input,
.project-task-progress-input {
    background: #f8fbff;
    border: 1px solid transparent;
    border-radius: 7px;
    color: #52616b;
    font: inherit;
    font-size: 0.86rem;
    font-weight: 900;
    min-height: 32px;
    padding: 5px 6px;
}

.project-task-assignee-input,
.project-task-priority-input {
    cursor: pointer;
    width: 100%;
}

.project-task-priority-form {
    justify-self: stretch;
}

.project-task-priority-input[value="critical"],
.project-task-row.priority-critical .project-task-priority-input {
    border-color: #fecaca;
    color: #b42318;
    background: #fff1f2;
}

.project-task-hours-form span {
    color: #6b7b8f;
    font-size: 0.82rem;
    font-weight: 900;
}

.project-task-hours-input {
    text-align: center;
    width: 42px;
}

.project-task-progress-input {
    text-align: center;
    width: 54px;
}

.project-task-progress-input::-webkit-outer-spin-button,
.project-task-progress-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.project-task-progress-input {
    appearance: textfield;
}

.project-task-progress-form::after {
    color: #6b7b8f;
    content: "%";
    font-size: 0.78rem;
    font-weight: 950;
    margin-left: -3px;
}

.project-task-assignee-input:hover,
.project-task-priority-input:hover,
.project-task-hours-input:hover,
.project-task-progress-input:hover,
.project-task-assignee-input:focus,
.project-task-priority-input:focus,
.project-task-hours-input:focus,
.project-task-progress-input:focus {
    background: #ffffff;
    border-color: #8fbcea;
    box-shadow: 0 0 0 3px rgba(143, 188, 234, 0.18);
    outline: 0;
}

.project-task-name small {
    color: #6b7b8f;
    font-weight: 750;
    grid-column: 1 / -1;
}

.project-caret,
.project-indent {
    display: inline-block;
    margin-right: 4px;
}

.project-caret {
    color: #1d62aa;
    cursor: pointer;
    font-weight: 950;
    min-width: 12px;
    text-align: center;
    user-select: none;
}

.project-check {
    background: #ffffff;
    border: 2px solid #7a8798;
    border-radius: 999px;
    box-sizing: border-box;
    cursor: pointer;
    height: 14px;
    min-height: 0;
    min-width: 0;
    padding: 0;
    width: 14px;
}

.project-check.is-done {
    background: #1d62aa;
    border-color: #1d62aa;
    position: relative;
}

.project-check.is-done::after {
    color: #ffffff;
    content: "✓";
    font-size: 0.56rem;
    font-weight: 950;
    left: 2px;
    position: absolute;
    top: -2px;
}

.project-task-menu {
    position: relative;
}

.project-task-menu summary {
    align-items: center;
    background: #eef4fb;
    border-radius: 4px;
    color: #10284f;
    cursor: pointer;
    display: flex;
    font-size: 1rem;
    font-weight: 950;
    height: 24px;
    min-height: 0;
    min-width: 0;
    padding: 0;
    justify-content: center;
    list-style: none;
    width: 24px;
}

.project-task-menu summary::-webkit-details-marker {
    display: none;
}

.project-task-menu[open] summary {
    background: #dbeafe;
    outline: 2px solid #8fbcea;
}

.project-task-menu-panel {
    background: #ffffff;
    border: 1px solid #d5dbe3;
    border-radius: 4px;
    box-shadow: 0 18px 42px rgba(16, 40, 79, 0.18);
    display: grid;
    min-width: 260px;
    padding: 8px 0;
    position: absolute;
    right: 0;
    top: 30px;
    z-index: 80;
}

.project-task-menu-panel a,
.project-task-menu-panel button {
    background: transparent;
    border: 0;
    color: #243244;
    cursor: pointer;
    display: block;
    font: inherit;
    font-weight: 750;
    padding: 10px 16px;
    text-align: left;
    width: 100%;
}

.project-task-menu-panel a:hover,
.project-task-menu-panel button:hover {
    background: #f2f6fb;
}

.project-task-menu-panel button.danger {
    color: #b42318;
}

.project-task-menu-panel hr {
    border: 0;
    border-top: 1px solid #e1e7ef;
    margin: 6px 0;
}

.project-add-row,
.project-task-empty {
    border-top: 1px solid #e8eef4;
    color: #1d62aa;
    display: block;
    font-weight: 950;
    padding: 10px 14px;
}

.project-add-row-form {
    margin: 0;
}

.project-quick-add-inline {
    align-items: center;
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(260px, 1fr) auto;
    margin: 0;
}

.project-quick-add-message {
    color: #991b1b;
    font-size: 0.78rem;
    font-weight: 900;
    grid-column: 1 / -1;
    min-height: 1rem;
}

.project-quick-add-inline input,
.project-add-row-form input {
    border: 1px solid #cfe0f1;
    border-radius: 8px;
    color: #17223b;
    font: inherit;
    font-weight: 850;
    min-height: 42px;
    min-width: 0;
    padding: 9px 12px;
    width: 100%;
}

.project-quick-add-inline input:focus,
.project-add-row-form input:focus {
    border-color: #8fbcea;
    box-shadow: 0 0 0 3px rgba(143, 188, 234, 0.2);
    outline: 0;
}

.project-quick-add-inline input.is-invalid,
.project-add-row-form input.is-invalid {
    border-color: #dc2626;
    box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.13);
}

.project-add-row-form {
    align-items: center;
    border-top: 1px solid #e8eef4;
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(220px, 1fr) 110px;
    padding: 8px 12px;
}

.project-add-row-form .project-add-row,
button.project-add-row {
    background: transparent;
    border: 1px solid #cfe0f1;
    border-radius: 8px;
    cursor: pointer;
    min-height: 40px;
    padding: 8px 12px;
    text-align: center;
    width: 100%;
}

.project-add-row-form .project-add-row:hover,
button.project-add-row:hover {
    background: #eaf1fb;
}

.project-side-panel {
    display: grid;
    gap: 10px;
}

.project-side-card {
    display: grid;
    gap: 8px;
    padding: 12px;
}

.project-side-card h2 {
    margin: 0;
}

.project-summary-card h2 {
    font-size: 1.02rem;
}

.project-side-card label {
    color: #52616b;
    font-size: 0.76rem;
    font-weight: 950;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.project-side-card strong {
    color: #17223b;
    font-size: 1rem;
}

.project-side-card p {
    color: #52616b;
    font-weight: 850;
    margin: 0;
}

.project-side-split {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
}

.project-progress-line {
    background: #e5e7eb;
    border-radius: 999px;
    height: 10px;
    overflow: hidden;
}

.project-progress-line span {
    background: #1d62aa;
    display: block;
    height: 100%;
}

.project-timeline-shell {
    overflow-x: auto;
}

.project-timeline-header,
.project-timeline-row {
    display: grid;
    grid-template-columns: minmax(260px, 34%) minmax(560px, 1fr);
}

.project-timeline-header {
    border-bottom: 1px solid #e5edf5;
    color: #52616b;
    font-weight: 950;
    min-width: 880px;
    padding: 10px 14px;
}

.project-timeline-scale,
.project-timeline-track {
    position: relative;
}

.project-timeline-scale {
    min-height: 24px;
}

.project-timeline-scale span {
    color: #52616b;
    font-size: 0.82rem;
    font-weight: 850;
    position: absolute;
    top: 0;
}

.project-timeline-row {
    border-bottom: 1px solid #e8eef4;
    min-height: 42px;
    min-width: 880px;
    padding: 5px 14px;
}

.project-timeline-row.is-subtask .project-timeline-title {
    padding-left: 28px;
}

.project-timeline-title {
    align-items: center;
    display: flex;
    gap: 10px;
}

.project-timeline-title a {
    color: #17223b;
    font-weight: 950;
}

.project-timeline-track {
    background-image: linear-gradient(90deg, rgba(213, 226, 239, 0.72) 1px, transparent 1px);
    background-size: 10% 100%;
}

.project-timeline-bar {
    background: #2f7bd4;
    border-radius: 6px;
    height: 12px;
    min-width: 18px;
    position: absolute;
    top: 14px;
}

.project-diagram-workbench {
    display: grid;
    gap: 8px;
    padding: 10px;
}

.project-diagram-toolbar {
    align-items: center;
    background: #f7fbff;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 6px;
}

.diagram-tool-group {
    align-items: center;
    border-right: 1px solid #d5e2ef;
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    padding-right: 6px;
}

.diagram-library-tools {
    background: #eef6ff;
    border-radius: 8px;
    padding: 5px 7px;
}

.diagram-properties {
    flex: 1 1 520px;
}

.diagram-tool-group:last-child {
    border-right: 0;
}

.project-diagram-toolbar button,
.project-diagram-toolbar label,
.project-diagram-toolbar select {
    align-items: center;
    background: #ffffff;
    border: 1px solid #bfd5ea;
    border-radius: 6px;
    color: #10284f;
    display: inline-flex;
    font-size: 0.72rem;
    font-weight: 900;
    gap: 5px;
    min-height: 28px;
    padding: 4px 7px;
}

.project-diagram-toolbar .diagram-upload-label {
    cursor: pointer;
}

.project-diagram-toolbar select {
    min-width: 178px;
}

.project-diagram-toolbar [data-diagram-custom] {
    min-width: 190px;
}

.project-diagram-toolbar button.is-active {
    background: #12355b;
    border-color: #12355b;
    color: #ffffff;
}

.project-diagram-toolbar button:disabled,
.project-diagram-toolbar input:disabled {
    cursor: not-allowed;
    opacity: 0.5;
}

.project-diagram-toolbar input[type="text"] {
    border: 0;
    color: #10284f;
    font-size: 0.72rem;
    font-weight: 850;
    min-width: 150px;
    outline: 0;
}

.project-diagram-toolbar input[type="number"] {
    border: 0;
    color: #10284f;
    font-size: 0.72rem;
    font-weight: 850;
    outline: 0;
    width: 58px;
}

.project-diagram-toolbar input[type="color"] {
    border: 0;
    height: 22px;
    padding: 0;
    width: 28px;
}

.project-diagram-toolbar input[type="range"] {
    width: 76px;
}

.project-diagram-canvas {
    background:
        linear-gradient(rgba(213, 226, 239, 0.65) 1px, transparent 1px),
        linear-gradient(90deg, rgba(213, 226, 239, 0.65) 1px, transparent 1px),
        #ffffff;
    background-size: 22px 22px;
    border: 1px solid #cfe0f1;
    border-radius: 8px;
    min-height: 640px;
    overflow: hidden;
    position: relative;
}

.project-diagram-canvas:focus {
    outline: none;
}

.project-diagram-svg {
    cursor: crosshair;
    display: block;
    height: 820px;
    width: 100%;
}

.project-diagram-canvas[data-tool="select"] .project-diagram-svg {
    cursor: default;
}

.project-diagram-canvas[data-tool="component"] .project-diagram-svg {
    cursor: copy;
}

.project-diagram-hint {
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    color: #52616b;
    font-size: 0.9rem;
    font-weight: 850;
    left: 18px;
    max-width: 560px;
    padding: 10px 12px;
    position: absolute;
    top: 18px;
    pointer-events: none;
}

.project-diagram-hint.is-hidden {
    display: none;
}

.project-diagram-element {
    cursor: move;
    pointer-events: all;
}

.project-diagram-element.is-selected {
    filter: drop-shadow(0 0 0.25rem rgba(29, 98, 170, 0.65));
    outline: 2px solid #1d62aa;
}

.diagram-selection-layer {
    pointer-events: none;
}

.diagram-resize-handle {
    cursor: nwse-resize;
    pointer-events: all;
}

.diagram-resize-handle[data-resize-handle="ne"],
.diagram-resize-handle[data-resize-handle="sw"] {
    cursor: nesw-resize;
}

.project-timeline-bar.is-done {
    background: #1d62aa;
}

.project-timeline-bar.is-blocked {
    background: #b42318;
}

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

@media (max-width: 1000px) {
    .incident-kpi-grid,
    .incident-guidance-grid,
    .incident-workflow,
    .form-grid-three {
        grid-template-columns: 1fr;
    }

    .incident-file-header {
        align-items: stretch;
        display: grid;
    }

    .project-card-header,
    .project-mini-stats,
    .project-overview-grid,
    .project-summary-strip {
        grid-template-columns: 1fr;
    }

    .project-task-header {
        display: none;
    }

    .project-task-row {
        grid-template-columns: 34px minmax(0, 1fr) 42px;
    }

    .project-task-row > span {
        display: none;
    }
}

/* Menu superior SGSI */
.topbar {
    align-items: flex-start;
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(250px, auto) minmax(0, 1fr);
    justify-content: stretch;
    padding: 8px 22px 10px;
}

.topnav.app-nav {
    align-items: flex-start;
    display: grid;
    gap: 6px 10px;
    grid-auto-flow: column;
    grid-auto-columns: minmax(126px, 158px);
    justify-content: center;
    text-align: center;
    width: 100%;
}

.topnav .nav-menu {
    display: grid;
    gap: 7px;
    justify-items: center;
    min-width: 0;
    position: relative;
}

.topnav.app-nav > a,
.topnav.app-nav .nav-menu-trigger {
    align-items: center;
    border: 1px solid rgba(184, 214, 245, 0.35);
    border-radius: 999px;
    color: #d8ecff !important;
    justify-content: center;
    min-height: 38px;
    min-width: 0;
    padding: 7px 10px;
    text-align: center;
    width: 100%;
}

.topnav.app-nav > a:hover,
.topnav.app-nav .nav-menu-trigger:hover {
    background: rgba(15, 94, 168, 0.28);
    color: #ffffff !important;
}

.topnav.app-nav > a.nav-current,
.topnav.app-nav .nav-menu-trigger.nav-current {
    background: rgba(15, 94, 168, 0.28);
    border-color: rgba(184, 214, 245, 0.58);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
    color: #ffffff !important;
}

.topnav .nav-menu-panel {
    background: transparent;
    border: 0;
    box-shadow: none;
    display: none !important;
    gap: 3px;
    left: 50%;
    min-width: 190px;
    padding-top: 2px;
    position: absolute;
    top: calc(100% - 2px);
    transform: translateX(-50%);
    width: max-content;
    z-index: 140;
}

.topnav.app-nav .nav-menu:hover .nav-menu-panel,
.topnav.app-nav .nav-menu:focus-within .nav-menu-panel {
    display: grid !important;
}

.topnav .nav-menu-panel a,
.topnav .nav-menu-note {
    align-items: center;
    border: 1px solid #cfe0f1;
    border-radius: 4px;
    display: flex;
    justify-content: center;
    line-height: 1.2;
    min-height: 34px;
    min-width: 190px;
    padding: 7px 10px;
    text-align: center;
    white-space: normal;
    width: 100%;
}

.topnav .nav-menu-assets .nav-menu-panel,
.topnav .nav-menu-library .nav-menu-panel {
    display: none !important;
    grid-template-columns: 1fr;
    min-width: 190px;
}

.topnav .nav-menu-assets:hover .nav-menu-panel,
.topnav .nav-menu-assets:focus-within .nav-menu-panel,
.topnav .nav-menu-library:hover .nav-menu-panel,
.topnav .nav-menu-library:focus-within .nav-menu-panel {
    display: grid !important;
}

.topnav .nav-menu-operations .nav-menu-panel,
.topnav .nav-admin-menu .nav-menu-panel {
    min-width: 230px;
}

.topnav .nav-menu-operations .nav-menu-panel a,
.topnav .nav-admin-menu .nav-menu-panel a,
.topnav .nav-admin-menu .nav-menu-note {
    min-width: 230px;
}

.topnav .nav-menu-trigger::after {
    display: none;
}

.topnav .nav-menu-panel a:hover {
    background: #eaf1fb;
    border-color: #9ecaf0;
}

.advanced-mode .topbar {
    align-items: flex-start;
}

.advanced-mode .topnav .nav-menu-panel {
    background: transparent;
    border: 0;
}

.advanced-mode .topnav .nav-menu-panel a,
.advanced-mode .topnav .nav-menu-note {
    background: #ffffff;
    color: var(--accent) !important;
}

@media (max-width: 1180px) {
    .topbar {
        align-items: center;
        grid-template-columns: 1fr;
        justify-content: stretch;
    }

    .topnav.app-nav {
        grid-auto-flow: row;
        grid-template-columns: repeat(2, minmax(150px, 1fr));
        justify-content: center;
    }
}

@media (max-width: 780px) {
    .topnav.app-nav {
        display: grid;
        grid-template-columns: 1fr;
        grid-auto-flow: row;
    }

    .topnav.app-nav > a,
    .topnav.app-nav .nav-menu-trigger {
        width: 100%;
    }
}

/* COMPANY_SWITCH_POLISH_START */
.advanced-mode .messages {
    display: none;
}

.advanced-mode .message {
    align-items: center;
    background: #ffffff;
    border: 1px solid #cfe0f1;
    border-left: 5px solid #15803d;
    border-radius: 8px;
    box-shadow: 0 10px 26px rgba(13, 31, 51, 0.08);
    color: #17223b;
    display: flex;
    font-size: 0.95rem;
    font-weight: 850;
    justify-content: center;
    line-height: 1.25;
    min-height: 42px;
    padding: 9px 14px;
    text-align: center;
}

.advanced-mode .message.error {
    border-left-color: #dc2626;
}

.advanced-mode .message.warning {
    border-left-color: #d97706;
}

.topnav.app-nav .nav-company-menu .nav-menu-panel {
    background: #ffffff;
    border: 1px solid #cfe0f1;
    border-radius: 8px;
    box-shadow: 0 18px 44px rgba(13, 31, 51, 0.24);
    gap: 8px;
    min-width: 270px;
    padding: 10px;
    width: 270px;
}

.topnav.app-nav .nav-company-menu .nav-menu-note {
    background: #f8fbff;
    border: 1px solid #d9e5f1;
    border-radius: 7px;
    color: #102a43 !important;
    display: block;
    font-size: 0.82rem;
    font-weight: 900;
    line-height: 1.25;
    min-height: 0;
    min-width: 0;
    padding: 9px 10px;
    text-align: center;
    width: 100%;
}

.topnav.app-nav .nav-company-menu .nav-menu-section {
    color: #64748b;
    font-size: 0.68rem;
    font-weight: 950;
    letter-spacing: 0.08em;
    padding: 2px 4px 0;
    text-align: left;
    text-transform: uppercase;
}

.topnav.app-nav .nav-company-menu .nav-org-switch-form {
    margin: 0;
    width: 100%;
}

.topnav.app-nav .nav-company-menu .nav-org-switch {
    align-items: center;
    background: #0f2a50;
    border: 1px solid rgba(184, 214, 245, 0.32);
    border-radius: 8px;
    color: #ffffff;
    display: grid;
    gap: 4px;
    justify-items: center;
    min-height: 58px;
    min-width: 0;
    padding: 9px 12px;
    text-align: center;
    width: 100%;
}

.topnav.app-nav .nav-company-menu .nav-org-switch:hover {
    background: #123b68;
    border-color: #8fbcea;
    color: #ffffff;
}

.topnav.app-nav .nav-company-menu .nav-org-switch span {
    color: inherit;
    display: block;
    font-size: 0.95rem;
    font-weight: 950;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.topnav.app-nav .nav-company-menu .nav-org-switch small {
    color: #bfdbfe;
    display: block;
    font-size: 0.72rem;
    font-weight: 850;
    line-height: 1.1;
}

.topnav.app-nav .nav-company-menu .nav-org-switch-current,
.topnav.app-nav .nav-company-menu .nav-org-switch-current:hover {
    background: #eaf1fb;
    border-color: #9ecaf0;
    color: #0f2a50;
}

.topnav.app-nav .nav-company-menu .nav-org-switch-current small {
    color: #52616b;
}
/* COMPANY_SWITCH_POLISH_END */

/* MFA_EVIDENCE_START */
.status-pill.status-ok {
    background: #dcfce7;
    border-color: #86efac;
    color: #166534;
}

.status-pill.status-danger {
    background: #fee2e2;
    border-color: #fecaca;
    color: #991b1b;
}

.status-pill.status-warning {
    background: #fef3c7;
    border-color: #fcd34d;
    color: #92400e;
}

.button-link.button-link-small {
    border-radius: 8px;
    font-size: 0.82rem;
    min-height: 34px;
    padding: 8px 12px;
}

.backup-register-table th,
.backup-register-table td {
    vertical-align: top;
}

.inline-evidence-panel {
    display: grid;
    gap: 8px;
    min-width: 230px;
}

.inline-evidence-panel summary {
    cursor: pointer;
    list-style: none;
    margin-bottom: 8px;
    text-align: center;
}

.inline-evidence-panel summary::-webkit-details-marker {
    display: none;
}

.compact-upload-form {
    background: #f8fbff;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    display: grid;
    gap: 8px;
    padding: 10px;
}

.compact-upload-form label {
    color: #2f3f4f;
    display: grid;
    font-size: 0.78rem;
    font-weight: 900;
    gap: 4px;
}

.compact-upload-form input {
    min-height: 34px;
}

.mfa-radio-field {
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    display: grid;
    gap: 8px;
    margin: 0;
    padding: 12px 14px;
}

.mfa-radio-field legend {
    color: #17223b;
    font-size: 0.9rem;
    font-weight: 900;
    padding: 0 5px;
}

.mfa-radio-field ul {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.mfa-radio-field li label {
    align-items: center;
    border: 1px solid #cfe0f1;
    border-radius: 999px;
    display: inline-flex;
    gap: 8px;
    min-height: 38px;
    padding: 7px 12px;
}

.mfa-radio-field input {
    height: auto;
    width: auto;
}

.mfa-evidence-form {
    align-items: end;
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(160px, 0.7fr) minmax(220px, 1fr) minmax(180px, 1fr) auto;
    margin-bottom: 18px;
}

.subtle-action-link {
    color: #52616b;
    font-size: 0.82rem;
    font-weight: 850;
    text-decoration: none;
}

.subtle-action-link:hover {
    color: #0f5fa8;
}

.mfa-evidence-dialog {
    border: 1px solid #cfe0f1;
    border-radius: 10px;
    box-shadow: 0 24px 70px rgba(15, 42, 80, 0.28);
    max-height: 92vh;
    max-width: 920px;
    overflow: auto;
    padding: 0;
    width: min(94vw, 920px);
}

.mfa-evidence-dialog::backdrop {
    background: rgba(8, 25, 43, 0.46);
}

.mfa-dialog-close-form {
    position: absolute;
    right: 12px;
    top: 10px;
    z-index: 2;
}

.mfa-dialog-close-form button {
    align-items: center;
    background: #ffffff;
    border: 1px solid #d5e2ef;
    border-radius: 999px;
    color: #102a43;
    cursor: pointer;
    display: inline-flex;
    font-size: 1.15rem;
    font-weight: 900;
    height: 34px;
    justify-content: center;
    width: 34px;
}

.mfa-dialog-header {
    align-items: flex-start;
    background: #f8fbff;
    border-bottom: 1px solid #d5e2ef;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    padding: 24px 58px 18px 22px;
}

.mfa-dialog-header h2 {
    color: #102a43;
    font-size: 1.35rem;
    margin: 0 0 4px;
}

.mfa-dialog-header span,
.mfa-dialog-latest {
    color: #52616b;
    font-weight: 850;
}

.evidence-view-section,
.evidence-upload-section {
    padding: 18px 22px;
}

.evidence-upload-section {
    border-top: 1px solid #d5e2ef;
    background: #fbfdff;
}

.evidence-modal-section-heading {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.evidence-modal-section-heading strong {
    color: #102a43;
    font-size: 0.98rem;
}

.evidence-modal-section-heading span {
    color: #52616b;
    font-size: 0.84rem;
    font-weight: 850;
}

.evidence-gallery {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) 42px;
    gap: 12px;
    align-items: center;
}

.evidence-gallery-stage {
    min-width: 0;
}

.evidence-gallery-slide {
    aspect-ratio: 16 / 10;
    display: none;
    height: clamp(260px, 46vh, 420px);
    overflow: hidden;
    place-items: center;
    position: relative;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    background: #f8fbff;
    text-decoration: none;
}

.evidence-gallery-slide.is-active {
    display: grid;
}

.evidence-gallery-slide img {
    display: block;
    height: 100%;
    object-fit: contain;
    width: 100%;
}

.evidence-gallery-slide span {
    position: absolute;
    right: 10px;
    bottom: 10px;
    border-radius: 999px;
    background: rgba(16, 42, 67, 0.88);
    color: #ffffff;
    font-size: 0.82rem;
    font-weight: 900;
    padding: 5px 9px;
}

.evidence-gallery-arrow {
    align-items: center;
    border: 1px solid #d5e2ef;
    border-radius: 999px;
    background: #ffffff;
    color: #102a43;
    cursor: pointer;
    display: inline-flex;
    font-size: 1.8rem;
    font-weight: 900;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.evidence-gallery-thumbs {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(82px, 1fr));
    gap: 8px;
    margin-top: 10px;
}

.evidence-gallery-thumb {
    display: block;
    height: 64px;
    overflow: hidden;
    border: 2px solid transparent;
    border-radius: 8px;
    background: #eef5fc;
    cursor: pointer;
    padding: 0;
}

.evidence-gallery-thumb.is-active {
    border-color: #0f5fa8;
}

.evidence-gallery-thumb img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.evidence-empty-state {
    border: 1px dashed #9ecaf0;
    border-radius: 8px;
    color: #52616b;
    font-weight: 900;
    padding: 22px;
    text-align: center;
}

.mfa-drop-form {
    display: grid;
    gap: 14px;
    padding: 0;
}

.mfa-drop-form label {
    color: #2f3f4f;
    display: grid;
    font-size: 0.84rem;
    font-weight: 900;
    gap: 6px;
}

.mfa-drop-zone {
    align-items: center;
    background: #f8fbff;
    border: 2px dashed #9ecaf0;
    border-radius: 8px;
    color: #102a43;
    cursor: pointer;
    min-height: 158px;
    padding: 18px;
    text-align: center;
}

.mfa-drop-zone input[type="file"] {
    margin: 0 auto;
    max-width: 100%;
}

.mfa-drop-zone strong {
    font-size: 1rem;
}

.mfa-drop-zone span {
    color: #52616b;
    font-size: 0.86rem;
}

.mfa-drop-zone img {
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    margin: 8px auto 0;
    max-height: 180px;
    object-fit: contain;
    width: min(100%, 420px);
}

.mfa-drop-zone-active,
.mfa-drop-zone-ready {
    background: #edf7ff;
    border-color: #0f5fa8;
}

.mfa-dialog-latest {
    border-top: 1px solid #d5e2ef;
    display: flex;
    justify-content: space-between;
    padding: 14px 22px 20px;
}

.mfa-page-upload {
    grid-template-columns: minmax(220px, 0.8fr) minmax(280px, 1.4fr) minmax(220px, 1fr) auto;
}

.mfa-evidence-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.mfa-evidence-grid article {
    background: #f8fbff;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    display: grid;
    gap: 8px;
    padding: 12px;
}

.mfa-evidence-grid img {
    aspect-ratio: 16 / 9;
    background: #ffffff;
    border: 1px solid #e1e7ef;
    border-radius: 6px;
    object-fit: cover;
    width: 100%;
}

.mfa-evidence-grid strong {
    color: #102a43;
}

.mfa-evidence-grid span,
.mfa-evidence-grid small {
    color: #52616b;
    font-weight: 800;
}

@media (max-width: 1100px) {
    .mfa-evidence-form,
    .mfa-page-upload,
    .mfa-evidence-grid {
        grid-template-columns: 1fr;
    }

    .mfa-dialog-header {
        display: grid;
        padding-right: 58px;
    }
}

@media (max-width: 720px) {
    .evidence-gallery {
        grid-template-columns: 1fr;
    }

    .evidence-gallery-arrow {
        display: none;
    }

    .evidence-gallery-slide {
        height: 280px;
    }
}

.evidence-action-stack {
    display: grid;
    gap: 6px;
    justify-items: start;
    min-width: 150px;
}

.evidence-action-stack .button-link,
.evidence-action-stack .button-link-light {
    width: 100%;
    text-align: center;
}

.evidence-view-dialog {
    max-width: 1180px;
    width: min(96vw, 1180px);
}

.evidence-upload-dialog {
    max-width: 680px;
    width: min(94vw, 680px);
}

.evidence-view-dialog .evidence-view-section {
    padding: 18px 22px 22px;
}

.evidence-view-dialog .evidence-gallery {
    align-items: stretch;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: 18px;
}

.evidence-gallery-main {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) 42px;
    gap: 12px;
    align-items: center;
    min-width: 0;
}

.evidence-view-dialog .evidence-gallery-stage {
    min-width: 0;
}

.evidence-view-dialog .evidence-gallery-slide {
    aspect-ratio: 4 / 3;
    height: clamp(380px, 58vh, 640px);
    background: #f7fafc;
}

.evidence-view-dialog .evidence-gallery-slide img {
    height: 100%;
    object-fit: contain;
    width: 100%;
}

.evidence-info-panel {
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    background: #fbfdff;
    padding: 16px;
}

.evidence-info-card {
    display: none;
}

.evidence-info-card.is-active {
    display: block;
}

.evidence-info-card strong {
    color: #102a43;
    display: block;
    font-size: 1.02rem;
    margin-bottom: 14px;
}

.evidence-info-card dl {
    display: grid;
    gap: 12px;
    margin: 0;
}

.evidence-info-card div {
    border-bottom: 1px solid #e3edf6;
    padding-bottom: 10px;
}

.evidence-info-card div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.evidence-info-card dt {
    color: #667783;
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.evidence-info-card dd {
    color: #223247;
    font-weight: 850;
    margin: 4px 0 0;
    overflow-wrap: anywhere;
}

.evidence-view-dialog .evidence-gallery-thumbs {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(86px, 1fr));
    gap: 9px;
    margin-top: 12px;
}

.evidence-view-dialog .evidence-gallery-thumb {
    height: 68px;
}


/* Evidence viewer fixed composition: main image + right info + bottom thumbnails. */
.evidence-view-dialog {
    max-width: 1240px;
    overflow: hidden;
    width: min(96vw, 1240px);
}

.evidence-view-dialog .mfa-dialog-header {
    min-height: 82px;
}

.evidence-view-dialog .evidence-view-section {
    padding: 14px 18px 18px;
}

.evidence-view-dialog .evidence-gallery {
    align-items: stretch;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 280px !important;
    grid-template-rows: minmax(0, 1fr) 76px;
    gap: 12px;
    height: min(68vh, 680px);
    min-height: 480px;
}

.evidence-view-dialog .evidence-gallery-main {
    display: grid;
    grid-column: 1;
    grid-row: 1;
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    gap: 10px;
    min-height: 0;
}

.evidence-view-dialog .evidence-gallery-stage {
    min-height: 0;
}

.evidence-view-dialog .evidence-gallery-slide {
    aspect-ratio: auto;
    height: 100%;
    min-height: 0;
}

.evidence-view-dialog .evidence-gallery-slide img {
    height: 100%;
    object-fit: contain;
    width: 100%;
}

.evidence-view-dialog .evidence-info-panel {
    grid-column: 2;
    grid-row: 1;
    min-height: 0;
    overflow: auto;
}

.evidence-view-dialog .evidence-gallery-thumbs {
    grid-column: 1 / -1;
    grid-row: 2;
    display: flex;
    gap: 9px;
    margin-top: 0;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 2px;
}

.evidence-view-dialog .evidence-gallery-thumb {
    flex: 0 0 92px;
    height: 64px;
}

@media (max-width: 760px) {
    .evidence-view-dialog .evidence-gallery {
        grid-template-columns: minmax(0, 1fr) 210px !important;
        min-height: 420px;
    }

    .evidence-view-dialog .evidence-gallery-main {
        grid-template-columns: minmax(0, 1fr);
    }

    .evidence-view-dialog .evidence-gallery-arrow {
        display: none;
    }
}

/* MFA_EVIDENCE_END */

/* Evidence viewer mock layout: image preview, bottom mosaic rail, fixed info panel. */
.evidence-view-dialog {
    max-width: 1280px;
    overflow: hidden;
    width: min(97vw, 1280px);
}

.evidence-view-dialog .evidence-gallery {
    align-items: stretch;
    display: grid !important;
    grid-template-columns: 74px minmax(0, 1fr) 74px 300px !important;
    grid-template-rows: minmax(0, 1fr) 92px;
    gap: 14px;
    height: min(70vh, 700px);
    min-height: 520px;
}

.evidence-view-dialog .evidence-gallery-main {
    display: contents !important;
}

.evidence-view-dialog .evidence-gallery-stage {
    grid-column: 1 / 4;
    grid-row: 1;
    min-height: 0;
}

.evidence-view-dialog .evidence-gallery-slide {
    aspect-ratio: auto;
    height: 100%;
    min-height: 0;
}

.evidence-view-dialog .evidence-gallery-slide img {
    height: 100%;
    object-fit: contain;
    width: 100%;
}

.evidence-view-dialog .evidence-info-panel {
    grid-column: 4;
    grid-row: 1 / 3;
    min-height: 0;
    overflow: auto;
}

.evidence-view-dialog .evidence-gallery-arrow[data-gallery-prev] {
    grid-column: 1;
    grid-row: 2;
}

.evidence-view-dialog .evidence-gallery-arrow[data-gallery-next] {
    grid-column: 3;
    grid-row: 2;
}

.evidence-view-dialog .evidence-gallery-arrow {
    align-self: center;
    border-radius: 8px;
    height: 78px;
    justify-self: stretch;
    width: auto;
}

.evidence-view-dialog .evidence-gallery-thumbs {
    grid-column: 2;
    grid-row: 2;
    display: flex;
    gap: 10px;
    margin: 0;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 2px;
}

.evidence-view-dialog .evidence-gallery-thumb {
    flex: 0 0 116px;
    height: 78px;
}

@media (max-width: 900px) {
    .evidence-view-dialog .evidence-gallery {
        grid-template-columns: 56px minmax(0, 1fr) 56px 230px !important;
        min-height: 460px;
    }

    .evidence-view-dialog .evidence-gallery-thumb {
        flex-basis: 94px;
    }
}

/* Evidence viewer final layout matching requested mock. */
.evidence-view-dialog.mfa-evidence-dialog {
    width: min(96vw, 1360px) !important;
    max-width: none !important;
    height: min(90vh, 860px) !important;
    max-height: none !important;
    overflow: hidden !important;
}

.evidence-view-dialog .mfa-dialog-header {
    box-sizing: border-box;
    min-height: 0 !important;
    height: 104px !important;
    padding: 18px 72px 14px 22px !important;
}

.evidence-view-dialog .evidence-view-section {
    box-sizing: border-box;
    height: calc(100% - 104px) !important;
    overflow: hidden !important;
    padding: 18px !important;
}

.evidence-view-dialog .evidence-modal-section-heading {
    display: none !important;
}

.evidence-view-dialog .evidence-gallery {
    box-sizing: border-box;
    display: grid !important;
    grid-template-columns: 82px minmax(0, 1fr) 82px 320px !important;
    grid-template-rows: minmax(0, 1fr) 96px !important;
    gap: 14px !important;
    height: 100% !important;
    min-height: 0 !important;
    overflow: hidden !important;
}

.evidence-view-dialog .evidence-gallery-main {
    display: contents !important;
}

.evidence-view-dialog .evidence-gallery-stage {
    align-self: stretch !important;
    box-sizing: border-box;
    display: grid !important;
    grid-column: 1 / 4 !important;
    grid-row: 1 !important;
    height: 100% !important;
    justify-self: stretch !important;
    min-height: 0 !important;
    min-width: 0 !important;
    overflow: hidden !important;
    border: 1px solid #d5e2ef;
    border-radius: 8px;
    background: #ffffff;
}

.evidence-view-dialog .evidence-gallery-slide {
    align-self: stretch !important;
    aspect-ratio: auto !important;
    box-sizing: border-box;
    height: 100% !important;
    justify-self: stretch !important;
    min-height: 0 !important;
    overflow: hidden !important;
    width: 100% !important;
}

.evidence-view-dialog .evidence-gallery-slide.is-active {
    display: grid !important;
    place-items: center !important;
}

.evidence-view-dialog .evidence-gallery-slide img {
    display: block !important;
    height: 100% !important;
    max-height: 100% !important;
    max-width: 100% !important;
    object-fit: contain !important;
    width: 100% !important;
}

.evidence-view-dialog .evidence-info-panel {
    box-sizing: border-box;
    grid-column: 4 !important;
    grid-row: 1 / 3 !important;
    height: 100% !important;
    min-height: 0 !important;
    overflow: auto !important;
}

.evidence-view-dialog .evidence-gallery-arrow[data-gallery-prev] {
    grid-column: 1 !important;
    grid-row: 2 !important;
}

.evidence-view-dialog .evidence-gallery-arrow[data-gallery-next] {
    grid-column: 3 !important;
    grid-row: 2 !important;
}

.evidence-view-dialog .evidence-gallery-arrow {
    align-self: stretch !important;
    border-radius: 8px !important;
    font-size: 2.4rem !important;
    height: auto !important;
    justify-self: stretch !important;
    width: auto !important;
}

.evidence-view-dialog .evidence-gallery-thumbs {
    box-sizing: border-box;
    grid-column: 2 !important;
    grid-row: 2 !important;
    display: flex !important;
    gap: 10px !important;
    height: 100% !important;
    margin: 0 !important;
    min-width: 0 !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    padding: 0 !important;
}

.evidence-view-dialog .evidence-gallery-thumb {
    flex: 0 0 128px !important;
    height: 100% !important;
}

/* Evidence viewer rebuilt as fixed preview + mosaic + info panel. */
.evidence-view-dialog.mfa-evidence-dialog {
    box-sizing: border-box;
    width: min(94vw, 1320px) !important;
    height: min(88vh, 820px) !important;
    max-width: none !important;
    max-height: none !important;
    padding: 0 !important;
    overflow: hidden !important;
}

.evidence-view-dialog::backdrop {
    background: rgba(4, 19, 35, 0.58);
}

.evidence-view-dialog .mfa-dialog-close-form {
    position: absolute;
    right: 18px;
    top: 18px;
    z-index: 5;
}

.evidence-view-dialog .mfa-dialog-header {
    align-items: center;
    box-sizing: border-box;
    display: flex;
    height: 108px !important;
    justify-content: space-between;
    min-height: 108px !important;
    padding: 20px 96px 18px 24px !important;
}

.evidence-view-dialog .mfa-dialog-header h2,
.evidence-view-dialog .mfa-dialog-header span,
.evidence-view-dialog .mfa-dialog-header .eyebrow {
    margin: 0;
}

.evidence-view-dialog .evidence-view-shell-wrap {
    box-sizing: border-box;
    height: calc(100% - 108px) !important;
    min-height: 0;
    overflow: hidden !important;
    padding: 18px 20px 20px !important;
}

.evidence-view-shell {
    box-sizing: border-box;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 18px;
    height: 100%;
    min-height: 0;
    overflow: hidden;
    width: 100%;
}

.evidence-view-main {
    box-sizing: border-box;
    display: grid;
    grid-template-rows: minmax(0, 1fr) 102px;
    gap: 14px;
    min-height: 0;
    min-width: 0;
    overflow: hidden;
}

.evidence-preview-frame {
    align-items: center;
    background: #ffffff;
    border: 2px solid #12385c;
    border-radius: 6px;
    box-sizing: border-box;
    display: grid;
    justify-items: center;
    min-height: 0;
    min-width: 0;
    overflow: hidden;
    padding: 16px;
}

.evidence-preview-slide {
    align-items: center;
    box-sizing: border-box;
    display: none;
    height: 100%;
    justify-items: center;
    min-height: 0;
    min-width: 0;
    overflow: hidden;
    width: 100%;
}

.evidence-preview-slide.is-active {
    display: grid !important;
}

.evidence-preview-slide img {
    display: block;
    height: 100% !important;
    max-height: 100% !important;
    max-width: 100% !important;
    object-fit: contain !important;
    width: 100% !important;
}

.evidence-mosaic-bar {
    align-items: stretch;
    box-sizing: border-box;
    display: grid;
    grid-template-columns: 78px minmax(0, 1fr) 78px;
    gap: 12px;
    min-height: 0;
    min-width: 0;
    overflow: hidden;
}

.evidence-mosaic-arrow {
    align-items: center;
    background: #12385c;
    border: 1px solid #062235;
    border-radius: 8px;
    color: #ffffff;
    cursor: pointer;
    display: flex;
    font-size: 2.6rem;
    font-weight: 800;
    justify-content: center;
    line-height: 1;
    min-width: 0;
}

.evidence-mosaic-strip {
    align-items: stretch;
    box-sizing: border-box;
    display: flex;
    gap: 12px;
    min-width: 0;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0 2px 4px;
}

.evidence-mosaic-thumb {
    background: #ffffff;
    border: 2px solid #12385c;
    border-radius: 4px;
    box-sizing: border-box;
    cursor: pointer;
    flex: 0 0 128px;
    height: 96px;
    overflow: hidden;
    padding: 4px;
}

.evidence-mosaic-thumb.is-active {
    border-color: #0b66b2;
    box-shadow: 0 0 0 3px rgba(11, 102, 178, 0.18);
}

.evidence-mosaic-thumb img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.evidence-detail-panel {
    background: #ffffff;
    border: 2px solid #12385c;
    border-radius: 6px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
}

.evidence-detail-heading {
    border-bottom: 1px solid #d7e1ea;
    padding: 18px;
}

.evidence-detail-heading strong {
    color: #102946;
    display: block;
    font-size: 1.25rem;
}

.evidence-detail-heading span {
    color: #5b6875;
    display: block;
    font-weight: 700;
    margin-top: 4px;
}

.evidence-detail-card {
    display: none;
    min-height: 0;
    overflow: auto;
    padding: 18px;
}

.evidence-detail-card.is-active {
    display: block;
}

.evidence-detail-card h3 {
    color: #102946;
    font-size: 1.35rem;
    margin: 4px 0 16px;
}

.evidence-detail-card dl {
    display: grid;
    gap: 12px;
    margin: 0;
}

.evidence-detail-card dt {
    color: #64717d;
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.evidence-detail-card dd {
    color: #172331;
    font-weight: 700;
    margin: 3px 0 0;
    overflow-wrap: anywhere;
}

.evidence-detail-actions {
    display: grid;
    gap: 10px;
    margin-top: 18px;
}

@media (max-width: 980px) {
    .evidence-view-dialog.mfa-evidence-dialog {
        width: 96vw !important;
        height: 90vh !important;
    }

    .evidence-view-shell {
        grid-template-columns: minmax(0, 1fr) 260px;
    }

    .evidence-mosaic-bar {
        grid-template-columns: 56px minmax(0, 1fr) 56px;
    }

    .evidence-mosaic-thumb {
        flex-basis: 104px;
    }
}

/* Symmetric evidence action buttons in table cells. */
.evidence-action-stack {
    align-items: stretch;
    display: grid;
    gap: 8px;
    justify-items: stretch;
    min-width: 188px;
    width: 100%;
}

.evidence-action-stack .button-link,
.evidence-action-stack .button-link-light,
.evidence-action-stack .subtle-action-link {
    align-items: center;
    border-radius: 8px;
    box-sizing: border-box;
    display: inline-flex;
    font-size: 0.92rem;
    font-weight: 900;
    justify-content: center;
    line-height: 1.15;
    min-height: 42px;
    padding: 9px 14px;
    text-align: center;
    width: 100%;
}

.evidence-action-stack .subtle-action-link {
    background: #f8fbff;
    border: 1px solid #d5e2ef;
    color: #52616b;
}

.evidence-action-stack .subtle-action-link:hover {
    background: #edf6ff;
    border-color: #b8d8f7;
    color: #0f5fa8;
}


/* Preserve visual context after project task menu reloads. */
.project-task-row.is-return-focus {
    animation: projectRowReturnFocus 1.4s ease-out;
}

@keyframes projectRowReturnFocus {
    0% {
        background: #e8f3ff;
        box-shadow: inset 4px 0 0 #1d62aa;
    }
    100% {
        background: transparent;
        box-shadow: inset 0 0 0 transparent;
    }
}

/* Visio-style implementation diagram editor */
.project-diagram-workbench-visio {
    display: block;
    min-height: 760px;
    padding: 0;
    overflow: hidden;
}

.project-visio-frame {
    display: block;
    width: 100%;
    min-height: 760px;
    height: calc(100vh - 290px);
    border: 0;
    border-radius: 12px;
    background: #f4f6f8;
}


/* Inventario avanzado compacto */
.asset-inventory-heading {
    margin-bottom: 1rem;
}

.asset-inventory-heading .advanced-heading-copy {
    max-width: 760px;
}

.asset-inventory-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1rem;
}

.asset-inventory-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(180px, 230px));
    gap: 0.75rem;
    margin-top: 0.9rem;
}

.asset-inventory-metrics article {
    min-height: 116px;
    border: 1px solid rgba(190, 215, 238, 0.45);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    padding: 1rem;
    display: grid;
    align-content: space-between;
}

.asset-inventory-metrics span {
    color: rgba(255, 255, 255, 0.76);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.asset-inventory-metrics strong {
    font-size: 2.15rem;
    line-height: 1;
}

.asset-inventory-metrics small {
    color: rgba(255, 255, 255, 0.8);
    font-weight: 700;
}

.asset-list-heading .button-group {
    align-items: center;
}

@media (max-width: 760px) {
    .asset-inventory-metrics {
        grid-template-columns: 1fr;
    }
}


/* Inventario avanzado: metricas en zona azul */
.advanced-mode .treatment-dashboard > .page-heading.asset-inventory-heading {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 500px) !important;
    align-items: end !important;
    column-gap: 2rem !important;
}

.advanced-mode .treatment-dashboard > .page-heading.asset-inventory-heading > div:first-child {
    width: auto !important;
}

.advanced-mode .treatment-dashboard > .page-heading.asset-inventory-heading .asset-inventory-metrics {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(165px, 1fr)) !important;
    gap: 0.85rem !important;
    margin-top: 0 !important;
    width: 100% !important;
}

.advanced-mode .treatment-dashboard > .page-heading.asset-inventory-heading .asset-inventory-metrics article {
    min-height: 126px !important;
    border: 1px solid rgba(190, 215, 238, 0.58) !important;
    border-radius: 8px !important;
    background: rgba(255, 255, 255, 0.09) !important;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04) !important;
    color: #fff !important;
    padding: 1.05rem !important;
}

@media (max-width: 980px) {
    .advanced-mode .treatment-dashboard > .page-heading.asset-inventory-heading {
        grid-template-columns: 1fr !important;
        row-gap: 1rem !important;
    }
}


/* Inventario avanzado: orden interno de tarjetas */
.advanced-mode .treatment-dashboard > .page-heading.asset-inventory-heading .asset-inventory-metrics article {
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    gap: 1rem !important;
}

.advanced-mode .treatment-dashboard > .page-heading.asset-inventory-heading .asset-inventory-metrics strong {
    display: block !important;
    font-size: clamp(42px, 4vw, 64px) !important;
    line-height: 0.95 !important;
}

.advanced-mode .treatment-dashboard > .page-heading.asset-inventory-heading .asset-inventory-metrics div {
    display: grid !important;
    gap: 0.25rem !important;
}

.advanced-mode .treatment-dashboard > .page-heading.asset-inventory-heading .asset-inventory-metrics span {
    display: block !important;
    font-size: 0.9rem !important;
    letter-spacing: 0.08em !important;
    line-height: 1.15 !important;
}

.advanced-mode .treatment-dashboard > .page-heading.asset-inventory-heading .asset-inventory-metrics small {
    display: block !important;
    font-size: 0.82rem !important;
    line-height: 1.25 !important;
}

/* NAV_SUBMENU_ELEGANT_20260626_START */
.topnav.app-nav .nav-menu-panel {
    background: rgba(255, 255, 255, 0.98) !important;
    border: 1px solid rgba(203, 213, 225, 0.92) !important;
    border-radius: 8px !important;
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.18) !important;
    gap: 4px !important;
    padding: 8px !important;
}

.topnav.app-nav .nav-menu-panel a,
.topnav.app-nav .nav-menu-note {
    border: 0 !important;
    border-radius: 6px !important;
    color: #1e3a5f !important;
    font-size: 0.86rem !important;
    font-weight: 760 !important;
    justify-content: flex-start !important;
    min-height: 34px !important;
    padding: 8px 10px !important;
    text-align: left !important;
}

.topnav.app-nav .nav-menu-panel a:hover {
    background: #f1f7fd !important;
    color: #0f5ea8 !important;
}

.topnav.app-nav .nav-company-menu .nav-menu-panel {
    border-radius: 8px !important;
    box-shadow: 0 22px 56px rgba(8, 22, 38, 0.22) !important;
    gap: 6px !important;
    min-width: 292px !important;
    padding: 12px !important;
    width: 292px !important;
}

.topnav.app-nav .nav-company-menu .nav-menu-note {
    background: #f8fafc !important;
    border: 1px solid #dbe7f3 !important;
    border-radius: 8px !important;
    color: #24364d !important;
    font-size: 0.78rem !important;
    font-weight: 760 !important;
    letter-spacing: 0 !important;
    line-height: 1.35 !important;
    padding: 10px 12px !important;
    text-align: left !important;
}

.topnav.app-nav .nav-company-menu .nav-menu-note::first-line {
    color: #64748b;
    font-size: 0.7rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.topnav.app-nav .nav-company-menu .nav-menu-section {
    color: #7a8797 !important;
    font-size: 0.66rem !important;
    font-weight: 850 !important;
    letter-spacing: 0.11em !important;
    padding: 8px 2px 3px !important;
}

.topnav.app-nav .nav-company-menu .nav-org-switch {
    background: transparent !important;
    border: 1px solid transparent !important;
    border-radius: 7px !important;
    color: #17223b !important;
    gap: 1px !important;
    justify-items: start !important;
    min-height: 46px !important;
    padding: 8px 10px !important;
    position: relative !important;
    text-align: left !important;
}

.topnav.app-nav .nav-company-menu .nav-org-switch:hover {
    background: #f1f7fd !important;
    border-color: #d6e8f8 !important;
    color: #0f5ea8 !important;
}

.topnav.app-nav .nav-company-menu .nav-org-switch span {
    color: inherit !important;
    font-size: 0.88rem !important;
    font-weight: 820 !important;
    line-height: 1.18 !important;
}

.topnav.app-nav .nav-company-menu .nav-org-switch small {
    color: #718096 !important;
    font-size: 0.72rem !important;
    font-weight: 680 !important;
}

.topnav.app-nav .nav-company-menu .nav-org-switch-current,
.topnav.app-nav .nav-company-menu .nav-org-switch-current:hover {
    background: #eef6ff !important;
    border-color: #b9d8f4 !important;
    color: #0f2a50 !important;
    box-shadow: inset 3px 0 0 #2b7bbb !important;
}

.topnav.app-nav .nav-company-menu .nav-org-switch-current small {
    color: #52616b !important;
}
/* NAV_SUBMENU_ELEGANT_20260626_END */

/* PROJECT_CARD_COMPACT_20260626_START */
.project-card-grid {
    gap: 10px;
}

.project-card {
    border-left-width: 4px;
    gap: 8px;
    padding: 12px 14px;
}

.project-card-header {
    gap: 10px;
}

.project-card .eyebrow {
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    margin-bottom: 3px;
}

.project-card h3 {
    font-size: 1.03rem;
    line-height: 1.12;
    margin: 0 0 5px;
}

.project-card p {
    font-size: 0.84rem;
    font-weight: 700;
    line-height: 1.18;
}

.project-progress {
    border-radius: 7px;
    min-width: 76px;
    padding: 8px 10px;
}

.project-progress strong {
    font-size: 1.55rem;
}

.project-progress span {
    font-size: 0.64rem;
    letter-spacing: 0.02em;
}

.project-meter {
    height: 8px;
    margin: 2px 0;
}

.project-mini-stats {
    gap: 6px;
}

.project-mini-stats div {
    border-radius: 7px;
    min-height: 48px;
    padding: 7px 8px;
}

.project-mini-stats dt {
    font-size: 0.64rem;
    letter-spacing: 0.06em;
    line-height: 1.1;
}

.project-mini-stats dd {
    font-size: 1rem;
    line-height: 1.05;
    margin-top: 2px;
}

.project-meta {
    font-size: 0.84rem;
    line-height: 1.2;
    padding-top: 8px;
}

.project-card-actions {
    margin-top: 0;
}

.project-card-actions .button-link-small {
    min-height: 32px;
    padding: 6px 10px;
}
/* PROJECT_CARD_COMPACT_20260626_END */


/* Dashboard 2.0: user work hub */
.dashboard-2-page { background: #f5f7fb; }
.dashboard-2-shell { display: grid; gap: 18px; }
.dashboard-2-header { display: flex; justify-content: space-between; gap: 20px; align-items: stretch; padding: 22px; border: 1px solid #dfe6ef; border-radius: 8px; background: #ffffff; box-shadow: 0 14px 35px rgba(15, 23, 42, 0.06); }
.dashboard-2-header h1 { margin: 0; color: #111827; font-size: 2rem; letter-spacing: 0; }
.dashboard-2-user-panel { min-width: 260px; display: grid; gap: 4px; align-content: center; padding: 16px; border-radius: 8px; background: #102033; color: #ffffff; }
.dashboard-2-user-panel span, .dashboard-2-user-panel small { color: #b8c7d9; }
.dashboard-2-user-panel strong { font-size: 1rem; }
.dashboard-2-company-strip { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 12px 16px; border: 1px solid #dfe6ef; border-radius: 8px; background: #ffffff; }
.dashboard-2-company-strip > div { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.dashboard-2-company { display: inline-flex; align-items: center; min-height: 30px; padding: 5px 10px; border: 1px solid #d8e1ec; border-radius: 999px; color: #405066; background: #f8fafc; font-size: 0.82rem; }
.dashboard-2-company-current { border-color: #1f7a6b; color: #0f5f53; background: #e8f6f2; }
.dashboard-2-stats { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 12px; }
.dashboard-2-stats article { display: grid; gap: 4px; padding: 16px; border: 1px solid #dfe6ef; border-radius: 8px; background: #ffffff; }
.dashboard-2-stats span, .dashboard-2-stats small { color: #64748b; font-size: 0.82rem; }
.dashboard-2-stats strong { color: #111827; font-size: 1.8rem; line-height: 1; }
.dashboard-2-stats .dashboard-2-danger strong { color: #b42318; }
.dashboard-2-main-grid { display: grid; grid-template-columns: minmax(0, 1.7fr) minmax(320px, 0.8fr); gap: 18px; align-items: start; }
.dashboard-2-secondary-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.dashboard-2-side-stack { display: grid; gap: 18px; }
.dashboard-2-panel { border: 1px solid #dfe6ef; border-radius: 8px; background: #ffffff; padding: 18px; box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05); }
.dashboard-2-panel-heading { display: flex; justify-content: space-between; gap: 12px; align-items: flex-start; margin-bottom: 14px; }
.dashboard-2-panel-heading h2 { margin: 0; color: #172033; font-size: 1.05rem; letter-spacing: 0; }
.dashboard-2-panel-heading > span { padding: 4px 8px; border-radius: 999px; background: #eef2f7; color: #405066; font-size: 0.78rem; white-space: nowrap; }
.dashboard-2-list { display: grid; gap: 10px; }
.dashboard-2-task { display: grid; grid-template-columns: 58px minmax(0, 1fr); gap: 12px; padding: 12px; border: 1px solid #edf1f5; border-radius: 8px; color: inherit; text-decoration: none; background: #fbfcfe; }
.dashboard-2-task:hover { border-color: #9cc7bd; background: #f4fbf8; }
.dashboard-2-task-date { display: grid; align-content: center; justify-items: center; min-height: 58px; border-radius: 8px; background: #eaf2ff; color: #1d4f91; }
.dashboard-2-task-date.is-overdue { background: #fff0ed; color: #b42318; }
.dashboard-2-task-date strong { font-size: 1.2rem; line-height: 1; }
.dashboard-2-task-date span { font-size: 0.72rem; text-transform: uppercase; }
.dashboard-2-task-title { display: flex; gap: 10px; justify-content: space-between; align-items: flex-start; }
.dashboard-2-task-title strong { color: #172033; }
.dashboard-2-task-title span { flex: 0 0 auto; color: #0f766e; font-size: 0.78rem; }
.dashboard-2-task p { margin: 4px 0; color: #64748b; }
.dashboard-2-task small { color: #405066; }
.dashboard-2-empty { padding: 18px; border-radius: 8px; background: #f8fafc; color: #64748b; }
.dashboard-2-agenda { display: grid; gap: 9px; }
.dashboard-2-agenda a { display: grid; gap: 3px; padding: 10px 0; border-bottom: 1px solid #edf1f5; color: inherit; text-decoration: none; }
.dashboard-2-agenda a:last-child { border-bottom: 0; }
.dashboard-2-agenda strong { color: #172033; }
.dashboard-2-agenda span, .dashboard-2-agenda p { color: #64748b; }
.dashboard-2-progress, .dashboard-2-mini-progress { overflow: hidden; height: 9px; border-radius: 999px; background: #e6ecf3; }
.dashboard-2-progress span, .dashboard-2-mini-progress span { display: block; height: 100%; border-radius: inherit; background: #1f7a6b; }
.dashboard-2-performance dl { display: grid; gap: 8px; margin: 14px 0; }
.dashboard-2-performance dl div { display: flex; justify-content: space-between; gap: 12px; color: #405066; }
.dashboard-2-performance dt { color: #64748b; }
.dashboard-2-performance dd { margin: 0; color: #172033; font-weight: 700; }
.dashboard-2-performance p { margin: 8px 0 0; color: #64748b; font-size: 0.86rem; }
.dashboard-2-projects { display: grid; gap: 12px; }
.dashboard-2-projects a { display: grid; gap: 8px; padding: 12px; border: 1px solid #edf1f5; border-radius: 8px; color: inherit; text-decoration: none; background: #fbfcfe; }
.dashboard-2-projects a > div:first-child { display: flex; justify-content: space-between; gap: 12px; }
.dashboard-2-projects strong { color: #172033; }
.dashboard-2-projects span, .dashboard-2-projects small { color: #64748b; }
.dashboard-2-connectors { display: grid; gap: 10px; }
.dashboard-2-connectors article { padding: 12px; border: 1px solid #edf1f5; border-radius: 8px; background: #fbfcfe; }
.dashboard-2-connectors article strong { color: #172033; }
.dashboard-2-connectors article span { float: right; color: #0f766e; font-size: 0.78rem; }
.dashboard-2-connectors article p { margin: 8px 0 0; color: #64748b; }
@media (max-width: 1100px) { .dashboard-2-stats, .dashboard-2-secondary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .dashboard-2-main-grid { grid-template-columns: 1fr; } }
@media (max-width: 720px) { .dashboard-2-header, .dashboard-2-company-strip, .dashboard-2-task-title, .dashboard-2-projects a > div:first-child { flex-direction: column; align-items: flex-start; } .dashboard-2-stats, .dashboard-2-secondary-grid { grid-template-columns: 1fr; } .dashboard-2-user-panel { min-width: 0; width: 100%; } .dashboard-2-task { grid-template-columns: 1fr; } }

.dashboard-2-team-panel { overflow: hidden; }
.dashboard-2-team-table { overflow-x: auto; }
.dashboard-2-team-table table { width: 100%; border-collapse: collapse; min-width: 820px; }
.dashboard-2-team-table th, .dashboard-2-team-table td { padding: 11px 10px; border-bottom: 1px solid #edf1f5; text-align: left; vertical-align: middle; }
.dashboard-2-team-table th { color: #64748b; font-size: 0.78rem; font-weight: 700; text-transform: uppercase; }
.dashboard-2-team-table td { color: #405066; }
.dashboard-2-team-table td strong { color: #172033; }
.dashboard-2-cell-danger { color: #b42318 !important; font-weight: 800; }
.dashboard-2-table-progress { width: 110px; max-width: 100%; height: 7px; margin-bottom: 4px; overflow: hidden; border-radius: 999px; background: #e6ecf3; }
.dashboard-2-table-progress span { display: block; height: 100%; border-radius: inherit; background: #1f7a6b; }
.dashboard-2-signal { display: inline-flex; align-items: center; min-height: 26px; padding: 4px 8px; border-radius: 999px; background: #eef2f7; color: #405066; font-size: 0.78rem; white-space: nowrap; }

.dashboard-2-company-form { margin: 0; }
.dashboard-2-company-form button { font: inherit; cursor: pointer; }
.dashboard-2-company-form button:disabled { cursor: default; }
.dashboard-2-modules-panel { overflow: hidden; }
.dashboard-2-modules-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.dashboard-2-modules-grid article { display: grid; gap: 8px; padding: 14px; border: 1px solid #edf1f5; border-radius: 8px; background: #fbfcfe; }
.dashboard-2-modules-grid article > div { display: flex; justify-content: space-between; gap: 10px; align-items: flex-start; }
.dashboard-2-modules-grid strong { color: #172033; }
.dashboard-2-modules-grid article > div span { flex: 0 0 auto; padding: 3px 7px; border-radius: 999px; background: #eef2f7; color: #405066; font-size: 0.74rem; }
.dashboard-2-modules-grid small { color: #0f766e; font-weight: 800; }
.dashboard-2-modules-grid p { margin: 0; color: #64748b; }
@media (max-width: 1100px) { .dashboard-2-modules-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 720px) { .dashboard-2-modules-grid { grid-template-columns: 1fr; } }

.dashboard-2-outlook-panel { display: grid; gap: 10px; }
.dashboard-2-outlook-panel p { margin: 0; color: #64748b; }
.dashboard-2-outlook-panel small, .dashboard-2-config-note { color: #405066; }
.dashboard-2-primary-button, .dashboard-2-secondary-button { display: inline-flex; align-items: center; justify-content: center; min-height: 36px; width: max-content; max-width: 100%; padding: 8px 12px; border-radius: 8px; border: 1px solid #1f7a6b; font-weight: 800; text-decoration: none; }
.dashboard-2-primary-button { color: #ffffff; background: #1f7a6b; }
.dashboard-2-secondary-button { color: #1f7a6b; background: #ffffff; cursor: pointer; }

.dashboard-2-action-row { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.dashboard-2-action-row form { margin: 0; }

.dashboard-2-manual-panel { display: grid; gap: 16px; }
.dashboard-2-quick-form { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; align-items: end; }
.dashboard-2-quick-form label { display: grid; gap: 5px; color: #64748b; font-size: 0.78rem; font-weight: 800; }
.dashboard-2-quick-form input, .dashboard-2-quick-form select, .dashboard-2-quick-form textarea { width: 100%; min-height: 38px; border: 1px solid #d8e1ec; border-radius: 8px; padding: 8px 10px; color: #172033; background: #ffffff; font: inherit; }
.dashboard-2-quick-form textarea { min-height: 68px; resize: vertical; }
.dashboard-2-form-wide { grid-column: span 3; }
.dashboard-2-manual-list { display: grid; gap: 10px; }
.dashboard-2-manual-list article { display: flex; justify-content: space-between; gap: 12px; align-items: center; padding: 12px; border: 1px solid #edf1f5; border-radius: 8px; background: #fbfcfe; }
.dashboard-2-manual-list article div { display: grid; gap: 3px; }
.dashboard-2-manual-list strong { color: #172033; }
.dashboard-2-manual-list span, .dashboard-2-manual-list small, .dashboard-2-manual-list p { color: #64748b; }
.dashboard-2-manual-list form { margin: 0; }
@media (max-width: 1100px) { .dashboard-2-quick-form { grid-template-columns: repeat(2, minmax(0, 1fr)); } .dashboard-2-form-wide { grid-column: span 2; } }
@media (max-width: 720px) { .dashboard-2-quick-form { grid-template-columns: 1fr; } .dashboard-2-form-wide { grid-column: span 1; } .dashboard-2-manual-list article { flex-direction: column; align-items: flex-start; } }

/* Dashboard 2.0 visual alignment: compact hub with percentage charts */
.dashboard-2-page {
    background: #f3f6fa;
}
.dashboard-2-shell {
    max-width: 1440px;
    margin: 0 auto;
}
.dashboard-2-header {
    border: 1px solid #d9e2ec;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
}
.dashboard-2-header h1 {
    font-size: 2.15rem;
}
.dashboard-2-focus-strip {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}
.dashboard-2-focus-card {
    display: grid;
    grid-template-columns: 74px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    min-height: 104px;
    padding: 16px;
    border: 1px solid #dfe6ef;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}
.dashboard-2-focus-card span {
    display: block;
    color: #172033;
    font-weight: 800;
}
.dashboard-2-focus-card small {
    display: block;
    margin-top: 4px;
    color: #64748b;
}
.dashboard-2-ring,
.dashboard-2-module-ring {
    --ring-color: #1f7a6b;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background:
        radial-gradient(circle at center, #ffffff 0 55%, transparent 56%),
        conic-gradient(var(--ring-color) calc(var(--value) * 1%), #e6edf4 0);
}
.dashboard-2-ring {
    width: 68px;
    height: 68px;
}
.dashboard-2-ring strong {
    color: #172033;
    font-size: 1.05rem;
}
.dashboard-2-focus-danger .dashboard-2-ring { --ring-color: #b42318; }
.dashboard-2-focus-week .dashboard-2-ring { --ring-color: #2563eb; }
.dashboard-2-focus-load .dashboard-2-ring { --ring-color: #7c3aed; }
.dashboard-2-focus-success .dashboard-2-ring { --ring-color: #15803d; }
.dashboard-2-main-grid {
    grid-template-columns: minmax(0, 1.55fr) minmax(340px, 0.85fr);
}
.dashboard-2-worklist .dashboard-2-list {
    max-height: 720px;
    overflow: auto;
    padding-right: 4px;
}
.dashboard-2-task {
    background: #ffffff;
    border-color: #e2e8f0;
}
.dashboard-2-task-date {
    background: #eef6ff;
}
.dashboard-2-side-stack {
    grid-auto-rows: auto;
}
.dashboard-2-module-progress-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.dashboard-2-module-card {
    display: grid;
    grid-template-columns: 78px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    min-height: 132px;
    padding: 15px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #fbfcfe;
}
.dashboard-2-module-ring {
    width: 74px;
    height: 74px;
}
.dashboard-2-module-ring strong {
    color: #172033;
    font-size: 0.95rem;
}
.dashboard-2-module-title {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: flex-start;
}
.dashboard-2-module-title strong {
    color: #172033;
}
.dashboard-2-module-title span {
    flex: 0 0 auto;
    padding: 3px 7px;
    border-radius: 999px;
    background: #eef2f7;
    color: #405066;
    font-size: 0.74rem;
}
.dashboard-2-module-card small {
    display: block;
    margin-top: 5px;
    color: #0f766e;
    font-weight: 800;
}
.dashboard-2-module-card p {
    margin: 6px 0 0;
    color: #64748b;
}
.dashboard-2-performance .dashboard-2-progress {
    height: 12px;
}
.dashboard-2-manual-panel {
    border-style: dashed;
    background: #ffffff;
}
.dashboard-2-team-panel {
    background: #ffffff;
}
@media (max-width: 1180px) {
    .dashboard-2-focus-strip,
    .dashboard-2-module-progress-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 720px) {
    .dashboard-2-focus-strip,
    .dashboard-2-module-progress-grid {
        grid-template-columns: 1fr;
    }
    .dashboard-2-focus-card,
    .dashboard-2-module-card {
        grid-template-columns: 64px minmax(0, 1fr);
    }
    .dashboard-2-ring {
        width: 60px;
        height: 60px;
    }
    .dashboard-2-module-ring {
        width: 62px;
        height: 62px;
    }
}


.training-page .dashboard-2-header .advanced-heading-copy { max-width: 780px; }
.training-actions { display: grid; gap: 14px; }
.training-filter-form { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; align-items: end; }
.training-filter-form label, .training-form p { display: grid; gap: 5px; color: #64748b; font-size: 0.78rem; font-weight: 800; }
.training-filter-form select, .training-form input, .training-form select, .training-form textarea { width: 100%; min-height: 38px; border: 1px solid #d8e1ec; border-radius: 8px; padding: 8px 10px; color: #172033; background: #ffffff; font: inherit; }
.training-form textarea { min-height: 86px; resize: vertical; }
.training-form ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 6px; color: #405066; }
.training-form li label { display: flex; gap: 8px; align-items: center; font-weight: 600; }
.training-table table { min-width: 1120px; }
.training-table small { color: #64748b; }
.training-signal { display: inline-flex; align-items: center; min-height: 26px; padding: 4px 8px; border-radius: 999px; background: #eef2f7; color: #405066; font-size: 0.78rem; font-weight: 800; white-space: nowrap; }
.training-signal-ok { background: #e8f6f2; color: #0f5f53; }
.training-signal-warning { background: #fff7e6; color: #9a5b00; }
.training-signal-danger { background: #fff0ed; color: #b42318; }
.training-signal-success { background: #edf8ef; color: #157347; }
.training-card-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; align-items: center; }
.training-card-actions a, .training-card-actions button { display: inline-flex; align-items: center; min-height: 28px; padding: 4px 8px; border: 1px solid #d8e1ec; border-radius: 8px; background: #ffffff; color: #1f7a6b; font: inherit; font-size: 0.78rem; font-weight: 800; text-decoration: none; cursor: pointer; }
.training-card-actions form { margin: 0; }
.training-report-panel { scroll-margin-top: 88px; }
.training-report-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.training-report-card { display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: center; min-height: 150px; padding: 14px; border: 1px solid #d8e1ec; border-left: 5px solid #0f766e; border-radius: 8px; background: #ffffff; }
.training-report-card-danger { border-left-color: #b42318; }
.training-report-card-warning { border-left-color: #d97706; }
.training-report-card-success { border-left-color: #15803d; }
.training-report-card-head { grid-column: 1 / -1; display: flex; justify-content: space-between; gap: 10px; align-items: flex-start; }
.training-report-card-head strong { display: block; color: #172033; font-size: 1rem; }
.training-report-card-head small { display: block; color: #64748b; font-weight: 700; margin-top: 2px; }
.training-report-card .dashboard-2-ring { width: 78px; height: 78px; }
.training-report-card .dashboard-2-ring strong { font-size: 1.05rem; }
.training-report-card dl { margin: 0; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 7px; }
.training-report-card dl div { padding: 7px 8px; border: 1px solid #e6edf5; border-radius: 8px; background: #f9fbfd; }
.training-report-card dt { color: #64748b; font-size: 0.68rem; font-weight: 900; text-transform: uppercase; letter-spacing: 0.06em; }
.training-report-card dd { margin: 2px 0 0; color: #0f2342; font-size: 1.1rem; font-weight: 900; }
.training-observations { display: grid; gap: 8px; }
.training-observations p { margin: 0; color: #405066; }
.training-form-panel { max-width: 980px; width: 100%; }
.training-form { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.training-form .dashboard-2-action-row { grid-column: 1 / -1; }
@media (max-width: 1100px) { .training-report-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 900px) { .training-filter-form, .training-form, .training-report-grid { grid-template-columns: 1fr; } }

/* Sidebar navigation refresh - 2026-06-27 */
body.sgsi-sidebar-layout {
    background: #eef4f8;
}

.sgsi-app-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 292px minmax(0, 1fr);
    background:
        linear-gradient(90deg, rgba(16, 40, 79, 0.04), rgba(255,255,255,0) 360px),
        #eef4f8;
}

.sgsi-sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    overflow-y: auto;
    border-right: 1px solid #d8e2ea;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 8px 0 28px rgba(13, 31, 51, 0.06);
    z-index: 30;
}

.sgsi-sidebar-head {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 84px;
    padding: 18px 16px;
    border-bottom: 1px solid #e1e8ee;
}

.sgsi-sidebar-brand {
    display: flex;
    align-items: center;
    min-width: 0;
    gap: 12px;
    color: #10284f;
}

.sgsi-sidebar-brand img {
    width: 122px;
    height: auto;
    object-fit: contain;
}

.sgsi-sidebar-brand span {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.sgsi-sidebar-brand strong {
    color: #10284f;
    font-size: 1rem;
    letter-spacing: 0.02em;
}

.sgsi-sidebar-brand small {
    max-width: 90px;
    overflow: hidden;
    color: #64717b;
    font-size: 0.74rem;
    font-weight: 800;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
}

.sgsi-sidebar-toggle,
.sgsi-mobile-toggle {
    width: 38px;
    min-width: 38px;
    height: 38px;
    min-height: 38px;
    border: 1px solid #d3dfe8;
    border-radius: 8px;
    background: #f8fbfd;
    color: #10284f;
    padding: 0;
    font-size: 1.45rem;
    line-height: 1;
}

.sgsi-sidebar-toggle:hover,
.sgsi-mobile-toggle:hover {
    background: #eaf2f9;
    color: #10284f;
}

.sgsi-sidebar-nav {
    display: grid;
    gap: 18px;
    padding: 18px 14px 28px;
}

.sgsi-nav-family {
    display: grid;
    gap: 6px;
}

.sgsi-nav-family p {
    margin: 0 0 4px;
    padding: 0 12px;
    color: #6d7a82;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.11em;
    text-transform: uppercase;
}

.sgsi-nav-family a,
.sgsi-nav-placeholder {
    position: relative;
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    min-height: 42px;
    border: 1px solid transparent;
    border-radius: 8px;
    color: #243344;
    font-weight: 800;
    padding: 6px 10px;
}

.sgsi-nav-family a::before {
    content: "";
    position: absolute;
    inset: 8px auto 8px 0;
    width: 3px;
    border-radius: 999px;
    background: transparent;
}

.sgsi-nav-family a:hover {
    border-color: #dbe7ef;
    background: #f5f9fc;
    color: #10284f;
}

.sgsi-nav-family a.is-active {
    border-color: #cbddeb;
    background: #edf5fb;
    color: #0f5ea8;
}

.sgsi-nav-family a.is-active::before {
    background: #0f5ea8;
}

.sgsi-nav-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border: 1px solid #d9e4ec;
    border-radius: 8px;
    background: #ffffff;
    color: #0f5ea8;
    font-size: 0.74rem;
    font-weight: 900;
}

.sgsi-nav-child {
    min-height: 34px;
    margin-left: 20px;
    color: #51616d !important;
    font-size: 0.9rem;
}

.sgsi-nav-child span:first-child {
    width: 8px;
    height: 8px;
    justify-self: center;
    border-radius: 999px;
    background: #c7d6e2;
}

.sgsi-nav-child.is-active span:first-child {
    background: #0f5ea8;
}

.sgsi-nav-group {
    display: grid;
    gap: 2px;
}

.sgsi-nav-placeholder {
    color: #9aa5ad;
    cursor: default;
}

.sgsi-content-shell {
    min-width: 0;
}

.sgsi-topbar {
    position: sticky;
    top: 0;
    z-index: 25;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    min-height: 72px;
    border-bottom: 1px solid #d8e2ea;
    background: rgba(255, 255, 255, 0.94);
    padding: 12px 28px;
    backdrop-filter: blur(12px);
}

.sgsi-topbar-title {
    display: grid;
    gap: 2px;
}

.sgsi-topbar-title span,
.sgsi-top-menu summary span {
    color: #697780;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sgsi-topbar-title strong,
.sgsi-top-menu summary strong {
    color: #10284f;
    font-size: 1rem;
}

.sgsi-topbar-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.sgsi-top-menu {
    position: relative;
}

.sgsi-top-menu summary {
    display: grid;
    gap: 2px;
    min-width: 178px;
    min-height: 48px;
    border: 1px solid #d8e2ea;
    border-radius: 8px;
    background: #ffffff;
    cursor: pointer;
    list-style: none;
    padding: 8px 12px;
}

.sgsi-top-menu summary::-webkit-details-marker {
    display: none;
}

.sgsi-top-menu-panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    z-index: 60;
    display: grid;
    gap: 8px;
    width: 280px;
    border: 1px solid #d8e2ea;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 22px 50px rgba(13, 31, 51, 0.16);
    padding: 10px;
}

.sgsi-top-menu-panel p {
    margin: 0;
    color: #6d7a82;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sgsi-top-menu-panel a,
.sgsi-company-option {
    display: grid;
    min-height: 42px;
    width: 100%;
    border: 1px solid #e0e8ef;
    border-radius: 8px;
    background: #ffffff;
    color: #10284f;
    font-weight: 900;
    padding: 9px 10px;
    text-align: left;
}

.sgsi-top-menu-panel a:hover,
.sgsi-company-option:hover {
    background: #eef6fb;
    color: #0f5ea8;
}

.sgsi-company-option small {
    color: #667680;
    font-size: 0.75rem;
}

.sgsi-company-option.is-current,
.sgsi-company-option.is-current:hover {
    border-color: #b8d4e9;
    background: #eef6fb;
    color: #0f5ea8;
    cursor: default;
}

.sgsi-menu-empty {
    color: #697780;
    font-weight: 800;
    padding: 8px 4px;
}

.sgsi-main-content {
    min-width: 0;
}

.sgsi-shell-messages {
    width: min(1080px, calc(100% - 32px));
}

.sgsi-sidebar-layout .controls-subnav {
    display: none !important;
}

body.sgsi-sidebar-collapsed .sgsi-app-shell {
    grid-template-columns: 84px minmax(0, 1fr);
}

body.sgsi-sidebar-collapsed .sgsi-sidebar-head {
    justify-content: center;
    padding-inline: 10px;
}

body.sgsi-sidebar-collapsed .sgsi-sidebar-brand span,
body.sgsi-sidebar-collapsed .sgsi-nav-text,
body.sgsi-sidebar-collapsed .sgsi-nav-family p,
body.sgsi-sidebar-collapsed .sgsi-nav-placeholder .sgsi-nav-text {
    display: none;
}

body.sgsi-sidebar-collapsed .sgsi-sidebar-brand img {
    width: 46px;
}

body.sgsi-sidebar-collapsed .sgsi-sidebar-toggle {
    position: absolute;
    right: -19px;
    top: 24px;
    box-shadow: 0 8px 18px rgba(13, 31, 51, 0.12);
    transform: rotate(180deg);
}

body.sgsi-sidebar-collapsed .sgsi-nav-family a,
body.sgsi-sidebar-collapsed .sgsi-nav-placeholder {
    grid-template-columns: 1fr;
    justify-items: center;
    margin-left: 0;
    padding-inline: 8px;
}

body.sgsi-sidebar-collapsed .sgsi-nav-child span:first-child {
    width: 30px;
    height: 30px;
    border: 1px solid #d9e4ec;
    border-radius: 8px;
    background: #ffffff;
}

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

    .sgsi-sidebar {
        position: fixed;
        left: 0;
        transform: translateX(-100%);
        transition: transform 0.18s ease;
        width: 292px;
    }

    body:not(.sgsi-sidebar-collapsed) .sgsi-sidebar {
        transform: translateX(0);
    }

    .sgsi-topbar {
        padding: 10px 14px;
    }

    .sgsi-topbar-actions {
        gap: 6px;
    }

    .sgsi-top-menu summary {
        min-width: 132px;
    }
}

/* Global authenticated UI scale - requested 75% */
body.sgsi-sidebar-layout {
    zoom: 0.75;
}

@supports not (zoom: 1) {
    body.sgsi-sidebar-layout .sgsi-app-shell {
        transform: scale(0.75);
        transform-origin: top left;
        width: 133.3333%;
        min-height: 133.3333vh;
    }
}

/* Keep the 75% visual scale while preserving full viewport coverage. */
body.sgsi-sidebar-layout {
    width: 133.3333%;
    min-height: 133.3333vh;
    overflow-x: hidden;
}

body.sgsi-sidebar-layout .sgsi-app-shell {
    min-height: 133.3333vh;
}

body.sgsi-sidebar-layout .sgsi-sidebar {
    height: 133.3333vh;
}

body.sgsi-sidebar-layout .sgsi-topbar {
    min-height: 78px;
}

/* Cleaner white workspace background. Keep blue only as accent/header color. */
body.sgsi-sidebar-layout,
body.sgsi-sidebar-layout .sgsi-app-shell,
body.sgsi-sidebar-layout .sgsi-content-shell,
body.sgsi-sidebar-layout .sgsi-main-content {
    background: #ffffff !important;
}

body.sgsi-sidebar-layout .advanced-dashboard,
body.sgsi-sidebar-layout .treatment-dashboard,
body.sgsi-sidebar-layout .control-center-page,
body.sgsi-sidebar-layout .asset-dashboard,
body.sgsi-sidebar-layout .project-dashboard,
body.sgsi-sidebar-layout .records-dashboard,
body.sgsi-sidebar-layout .document-library-page,
body.sgsi-sidebar-layout .dashboard-page {
    background-color: #ffffff !important;
}

body.sgsi-sidebar-layout .advanced-dashboard::before,
body.sgsi-sidebar-layout .treatment-dashboard::before,
body.sgsi-sidebar-layout .control-center-page::before,
body.sgsi-sidebar-layout .asset-dashboard::before,
body.sgsi-sidebar-layout .project-dashboard::before,
body.sgsi-sidebar-layout .records-dashboard::before,
body.sgsi-sidebar-layout .document-library-page::before,
body.sgsi-sidebar-layout .dashboard-page::before {
    background: #ffffff !important;
}

/* Compact white workspace after sidebar redesign. */
body.sgsi-sidebar-layout .sgsi-main-content {
    padding: 0 !important;
}

body.sgsi-sidebar-layout .dashboard,
body.sgsi-sidebar-layout .advanced-dashboard,
body.sgsi-sidebar-layout .treatment-dashboard,
body.sgsi-sidebar-layout .control-center-page,
body.sgsi-sidebar-layout .asset-dashboard,
body.sgsi-sidebar-layout .project-dashboard,
body.sgsi-sidebar-layout .records-dashboard,
body.sgsi-sidebar-layout .document-library-page,
body.sgsi-sidebar-layout .dashboard-page {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 20px 24px 36px !important;
}

body.sgsi-sidebar-layout .advanced-mode .dashboard.advanced-dashboard,
body.sgsi-sidebar-layout.advanced-mode .dashboard.advanced-dashboard {
    padding-top: 18px !important;
}

body.sgsi-sidebar-layout .page-heading,
body.sgsi-sidebar-layout .advanced-dashboard > .page-heading,
body.sgsi-sidebar-layout .treatment-dashboard > .page-heading {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: end !important;
    gap: 16px !important;
    min-height: 0 !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 0 18px !important;
    padding: 8px 0 12px !important;
    background: #ffffff !important;
    color: #1e2420 !important;
}

body.sgsi-sidebar-layout .page-heading h1,
body.sgsi-sidebar-layout .advanced-dashboard > .page-heading h1,
body.sgsi-sidebar-layout .treatment-dashboard > .page-heading h1 {
    color: #1e2420 !important;
    max-width: 1120px !important;
    font-size: clamp(2.1rem, 3.6vw, 4.2rem) !important;
    line-height: 1.02 !important;
}

body.sgsi-sidebar-layout .page-heading p,
body.sgsi-sidebar-layout .advanced-heading-copy,
body.sgsi-sidebar-layout .advanced-dashboard > .page-heading .advanced-heading-copy,
body.sgsi-sidebar-layout .treatment-dashboard > .page-heading .advanced-heading-copy {
    color: #526170 !important;
    max-width: 980px !important;
}

body.sgsi-sidebar-layout .advanced-mode-label,
body.sgsi-sidebar-layout .page-heading .eyebrow,
body.sgsi-sidebar-layout .advanced-dashboard > .page-heading .eyebrow {
    color: #6a7780 !important;
}

body.sgsi-sidebar-layout .operations-policy-page .page-heading {
    margin-bottom: 14px !important;
}

body.sgsi-sidebar-layout .operations-policy-hero,
body.sgsi-sidebar-layout .operations-progress-note,
body.sgsi-sidebar-layout .operations-policy-panel {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

body.sgsi-sidebar-layout .operations-policy-hero {
    margin-top: 0 !important;
}

body.sgsi-sidebar-layout .operations-policy-hero article,
body.sgsi-sidebar-layout .operations-progress-note,
body.sgsi-sidebar-layout .operations-policy-panel {
    background: #ffffff !important;
}

body.sgsi-sidebar-layout .operations-register-grid,
body.sgsi-sidebar-layout .operations-rule-list,
body.sgsi-sidebar-layout .operations-evidence-map {
    width: 100% !important;
    max-width: none !important;
}

@media (max-width: 980px) {
    body.sgsi-sidebar-layout .page-heading,
    body.sgsi-sidebar-layout .advanced-dashboard > .page-heading,
    body.sgsi-sidebar-layout .treatment-dashboard > .page-heading {
        grid-template-columns: 1fr !important;
        align-items: start !important;
    }
}

/* Clarify topbar label and keep operation cards symmetric. */
body.sgsi-sidebar-layout .sgsi-topbar {
    justify-content: flex-start !important;
}

body.sgsi-sidebar-layout .sgsi-topbar-title {
    margin-left: auto !important;
    margin-right: 18px !important;
    min-width: 190px !important;
    border-left: 3px solid #0f5ea8;
    padding-left: 12px;
    text-align: left;
}

body.sgsi-sidebar-layout .sgsi-topbar-title span {
    color: #65727c !important;
    font-size: 0.82rem !important;
    letter-spacing: 0.08em !important;
}

body.sgsi-sidebar-layout .sgsi-topbar-title strong {
    color: #10284f !important;
    font-size: 1.25rem !important;
}

body.sgsi-sidebar-layout .sgsi-topbar-actions {
    flex: 0 0 auto !important;
}

body.sgsi-sidebar-layout .operations-register-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
    gap: 14px !important;
    align-items: stretch !important;
    overflow: visible !important;
}

body.sgsi-sidebar-layout .operations-register-card {
    min-width: 0 !important;
    height: 100% !important;
}

body.sgsi-sidebar-layout .operations-policy-panel {
    overflow: visible !important;
}

body.sgsi-sidebar-layout .operations-policy-panel .section-heading {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Keep operation rule cards aligned inside the visible workspace. */
body.sgsi-sidebar-layout .operations-rule-list {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
}

body.sgsi-sidebar-layout .operations-rule-card {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
}

body.sgsi-sidebar-layout .operations-rule-header,
body.sgsi-sidebar-layout .operations-rule-header > div:first-child {
    min-width: 0 !important;
}

body.sgsi-sidebar-layout .operations-rule-header > div:first-child strong,
body.sgsi-sidebar-layout .operations-rule-card p,
body.sgsi-sidebar-layout .operations-rule-card small {
    overflow-wrap: anywhere !important;
}

body.sgsi-sidebar-layout .operations-rule-progress {
    flex-basis: 96px !important;
    min-width: 96px !important;
    padding: 8px !important;
}

body.sgsi-sidebar-layout .operations-rule-actions {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
}

body.sgsi-sidebar-layout .operations-rule-actions a,
body.sgsi-sidebar-layout .operations-rule-action-disabled {
    min-width: 0 !important;
    min-height: 46px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

@media (max-width: 1220px) {
    body.sgsi-sidebar-layout .operations-rule-list {
        grid-template-columns: 1fr !important;
    }
}

/* Production fix: operation rule cards must not overflow the sidebar layout. */
body.sgsi-sidebar-layout .operations-rule-list {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 14px !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
}

body.sgsi-sidebar-layout .operations-rule-card {
    box-sizing: border-box !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
}

body.sgsi-sidebar-layout .operations-rule-header {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 92px !important;
    align-items: start !important;
    gap: 12px !important;
}

body.sgsi-sidebar-layout .operations-rule-header > div:first-child,
body.sgsi-sidebar-layout .operations-rule-header > div:first-child strong {
    min-width: 0 !important;
    max-width: 100% !important;
}

body.sgsi-sidebar-layout .operations-rule-progress {
    width: 92px !important;
    min-width: 92px !important;
    max-width: 92px !important;
    padding: 8px 6px !important;
}

body.sgsi-sidebar-layout .operations-rule-progress strong {
    font-size: 1.35rem !important;
}

body.sgsi-sidebar-layout .operations-rule-progress small {
    display: block !important;
    overflow-wrap: anywhere !important;
    white-space: normal !important;
}

body.sgsi-sidebar-layout .operations-rule-actions {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    width: 100% !important;
}

body.sgsi-sidebar-layout .operations-rule-actions a,
body.sgsi-sidebar-layout .operations-rule-action-disabled {
    box-sizing: border-box !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
}

body.sgsi-sidebar-layout .operations-rule-card p,
body.sgsi-sidebar-layout .operations-rule-card small,
body.sgsi-sidebar-layout .operations-rule-card strong {
    overflow-wrap: anywhere !important;
}

body.sgsi-sidebar-layout .operations-policy-panel,
body.sgsi-sidebar-layout .operations-evidence-map,
body.sgsi-sidebar-layout .operations-register-grid {
    max-width: 100% !important;
    overflow: hidden !important;
}

/* Production visual scale correction: remove zoom canvas and use real compact sizing. */
body.sgsi-sidebar-layout {
    zoom: 1 !important;
    width: auto !important;
    min-height: 100vh !important;
    overflow-x: hidden !important;
    font-size: 75% !important;
}

body.sgsi-sidebar-layout .sgsi-app-shell {
    grid-template-columns: 232px minmax(0, 1fr) !important;
    width: 100% !important;
    min-height: 100vh !important;
    transform: none !important;
    background: #ffffff !important;
}

body.sgsi-sidebar-layout .sgsi-sidebar {
    width: 232px !important;
    height: 100vh !important;
}

body.sgsi-sidebar-layout .sgsi-sidebar-head {
    min-height: 66px !important;
    padding: 10px 10px !important;
}

body.sgsi-sidebar-layout .sgsi-sidebar-brand img {
    width: 96px !important;
}

body.sgsi-sidebar-layout .sgsi-sidebar-brand {
    gap: 8px !important;
}

body.sgsi-sidebar-layout .sgsi-sidebar-toggle,
body.sgsi-sidebar-layout .sgsi-mobile-toggle {
    width: 30px !important;
    min-width: 30px !important;
    height: 30px !important;
    min-height: 30px !important;
    font-size: 1.15rem !important;
}

body.sgsi-sidebar-layout .sgsi-sidebar-nav {
    gap: 10px !important;
    padding: 12px 8px 20px !important;
}

body.sgsi-sidebar-layout .sgsi-nav-family a,
body.sgsi-sidebar-layout .sgsi-nav-placeholder {
    min-height: 34px !important;
    grid-template-columns: 26px minmax(0, 1fr) !important;
    gap: 8px !important;
    padding: 5px 8px !important;
}

body.sgsi-sidebar-layout .sgsi-nav-mark {
    width: 24px !important;
    height: 24px !important;
    border-radius: 6px !important;
}

body.sgsi-sidebar-layout .sgsi-nav-child {
    min-height: 28px !important;
    margin-left: 12px !important;
}

body.sgsi-sidebar-layout .sgsi-topbar {
    min-height: 54px !important;
    padding: 8px 18px !important;
}

body.sgsi-sidebar-collapsed .sgsi-app-shell {
    grid-template-columns: 68px minmax(0, 1fr) !important;
}

body.sgsi-sidebar-collapsed .sgsi-sidebar {
    width: 68px !important;
}

body.sgsi-sidebar-collapsed .sgsi-sidebar-brand img {
    width: 38px !important;
}

body.sgsi-sidebar-layout .dashboard,
body.sgsi-sidebar-layout .advanced-dashboard,
body.sgsi-sidebar-layout .treatment-dashboard,
body.sgsi-sidebar-layout .control-center-page,
body.sgsi-sidebar-layout .asset-dashboard,
body.sgsi-sidebar-layout .project-dashboard,
body.sgsi-sidebar-layout .records-dashboard,
body.sgsi-sidebar-layout .document-library-page,
body.sgsi-sidebar-layout .dashboard-page {
    padding: 16px 18px 28px !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
}

body.sgsi-sidebar-layout .operations-rule-list {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    overflow: visible !important;
}

body.sgsi-sidebar-layout .operations-rule-card {
    min-width: 0 !important;
    overflow: hidden !important;
}

@media (max-width: 1320px) {
    body.sgsi-sidebar-layout .operations-rule-list {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 980px) {
    body.sgsi-sidebar-layout .sgsi-app-shell {
        grid-template-columns: 1fr !important;
    }
    body.sgsi-sidebar-layout .sgsi-sidebar {
        width: 232px !important;
    }
}

/* Remove duplicated active-company label and use circular operational progress. */
body.sgsi-sidebar-layout .sgsi-topbar-title {
    display: none !important;
}

body.sgsi-sidebar-layout .sgsi-topbar-actions {
    margin-left: auto !important;
}

body.sgsi-sidebar-layout .operations-policy-status {
    justify-self: center !important;
    align-self: center !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    width: 178px !important;
    height: 178px !important;
    min-width: 178px !important;
    min-height: 178px !important;
    aspect-ratio: 1 / 1 !important;
    border-radius: 50% !important;
    border: 10px solid #e5ece8 !important;
    background:
        radial-gradient(circle at center, #ffffff 58%, transparent 59%),
        conic-gradient(#0f5ea8 calc(var(--ops-progress, 29) * 1%), #e5ece8 0) !important;
    box-shadow: 0 10px 26px rgba(16, 40, 79, 0.10) !important;
    padding: 18px !important;
    text-align: center !important;
}

body.sgsi-sidebar-layout .operations-policy-status strong {
    color: #0f5ea8 !important;
    font-size: 2.75rem !important;
    line-height: 0.95 !important;
}

body.sgsi-sidebar-layout .operations-policy-status span {
    color: #526170 !important;
    font-size: 0.76rem !important;
    line-height: 1.05 !important;
    max-width: 120px !important;
}

body.sgsi-sidebar-layout .operations-policy-status small {
    color: #526170 !important;
    font-size: 0.64rem !important;
    line-height: 1.05 !important;
    max-width: 118px !important;
}

body.sgsi-sidebar-layout .operations-policy-status[data-tooltip]::after {
    border-radius: 8px !important;
}

/* Dynamic donut progress chart for operational policy. */
body.sgsi-sidebar-layout .operations-policy-status {
    position: relative !important;
    isolation: isolate !important;
    border: 0 !important;
    background: transparent !important;
    overflow: hidden !important;
}

body.sgsi-sidebar-layout .operations-policy-status::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: conic-gradient(#0f5ea8 calc(var(--ops-progress, 0) * 1%), #e5ece8 0) !important;
    z-index: -2;
}

body.sgsi-sidebar-layout .operations-policy-status::after {
    content: "";
    position: absolute;
    inset: 18px;
    border-radius: 50%;
    background: #ffffff;
    box-shadow: inset 0 0 0 1px rgba(16, 40, 79, 0.05);
    z-index: -1;
}

body.sgsi-sidebar-layout .operations-policy-status strong,
body.sgsi-sidebar-layout .operations-policy-status span,
body.sgsi-sidebar-layout .operations-policy-status small {
    position: relative;
    z-index: 1;
}

body.sgsi-sidebar-layout .operations-policy-status[data-tooltip]::after {
    inset: 18px;
    border-radius: 50%;
    width: auto;
    opacity: 1;
    transform: none;
    pointer-events: none;
}

body.sgsi-sidebar-layout .operations-policy-status[data-tooltip]:hover::after,
body.sgsi-sidebar-layout .operations-policy-status[data-tooltip]:focus::after {
    opacity: 1;
    transform: none;
}

/* White metric refresh and circular indicators. */
body.sgsi-sidebar-layout .sgsi-nav-family a.is-active {
    background: #ffffff !important;
    border-color: #cbddeb !important;
    color: #0f5ea8 !important;
    box-shadow: inset 3px 0 0 #0f5ea8 !important;
}

body.sgsi-sidebar-layout .sgsi-nav-family a.is-active::before {
    background: transparent !important;
}

body.sgsi-sidebar-layout .sgsi-nav-child.is-active span:first-child {
    background: #0f5ea8 !important;
}

body.sgsi-sidebar-layout .advanced-summary {
    background: #ffffff !important;
    color: #1e2420 !important;
    border: 1px solid #d5e2ef !important;
    box-shadow: 0 12px 28px rgba(16, 40, 79, 0.06) !important;
}

body.sgsi-sidebar-layout .advanced-summary h2,
body.sgsi-sidebar-layout .advanced-summary p,
body.sgsi-sidebar-layout .advanced-summary .eyebrow {
    color: #1e2420 !important;
}

body.sgsi-sidebar-layout .advanced-summary p {
    color: #526170 !important;
}

body.sgsi-sidebar-layout .advanced-score {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    width: 156px !important;
    height: 156px !important;
    min-width: 156px !important;
    border: 10px solid #e5ece8 !important;
    border-radius: 50% !important;
    background: #ffffff !important;
    color: #10284f !important;
    padding: 16px !important;
    text-align: center !important;
}

body.sgsi-sidebar-layout .advanced-score strong {
    color: #0f5ea8 !important;
    font-size: 2.6rem !important;
    line-height: 1 !important;
}

body.sgsi-sidebar-layout .advanced-score span {
    color: #526170 !important;
    font-size: 0.76rem !important;
    font-weight: 900 !important;
    line-height: 1.1 !important;
}

body.sgsi-sidebar-layout .incident-kpi-grid {
    align-items: stretch !important;
}

body.sgsi-sidebar-layout .incident-kpi,
body.sgsi-sidebar-layout .incident-kpi.incident-kpi-strong {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 178px !important;
    border: 1px solid #d5e2ef !important;
    border-left: 0 !important;
    border-radius: 8px !important;
    background: #ffffff !important;
    color: #1e2420 !important;
    box-shadow: 0 10px 22px rgba(16, 40, 79, 0.05) !important;
    text-align: center !important;
}

body.sgsi-sidebar-layout .incident-kpi strong {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 96px !important;
    height: 96px !important;
    border: 8px solid #e5ece8 !important;
    border-radius: 50% !important;
    color: #0f5ea8 !important;
    font-size: 2.3rem !important;
    line-height: 1 !important;
    margin: 4px 0 !important;
}

body.sgsi-sidebar-layout .incident-kpi span,
body.sgsi-sidebar-layout .incident-kpi em {
    color: #526170 !important;
}

body.sgsi-sidebar-layout .project-progress {
    position: relative !important;
    isolation: isolate !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    width: 112px !important;
    height: 112px !important;
    min-width: 112px !important;
    border-radius: 50% !important;
    background: transparent !important;
    color: #10284f !important;
    padding: 14px !important;
    overflow: hidden !important;
}

body.sgsi-sidebar-layout .project-progress::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: conic-gradient(#0f5ea8 calc(var(--project-progress, 0) * 1%), #e5ece8 0) !important;
    z-index: -2;
}

body.sgsi-sidebar-layout .project-progress::after {
    content: "";
    position: absolute;
    inset: 13px;
    border-radius: 50%;
    background: #ffffff;
    box-shadow: inset 0 0 0 1px rgba(16, 40, 79, 0.05);
    z-index: -1;
}

body.sgsi-sidebar-layout .project-progress strong {
    color: #0f5ea8 !important;
    font-size: 1.85rem !important;
}

body.sgsi-sidebar-layout .project-progress span {
    color: #526170 !important;
    font-size: 0.66rem !important;
}

body.sgsi-sidebar-layout .project-meter {
    display: none !important;
}

body.sgsi-sidebar-layout .project-mini-stats div {
    background: #ffffff !important;
}

/* Clean sidebar header: brand only, one menu toggle in topbar. */
body.sgsi-sidebar-layout .sgsi-sidebar-head {
    justify-content: center !important;
}

body.sgsi-sidebar-layout .sgsi-sidebar-brand span small,
body.sgsi-sidebar-layout .sgsi-sidebar-toggle {
    display: none !important;
}

body.sgsi-sidebar-layout .sgsi-sidebar-brand img {
    width: 112px !important;
}

body.sgsi-sidebar-layout .sgsi-sidebar-brand strong {
    font-size: 1.35rem !important;
}

body.sgsi-sidebar-collapsed .sgsi-sidebar-brand img {
    width: 42px !important;
}

/* Fix operational donut inner cutout: no square tooltip pseudo-element. */
body.sgsi-sidebar-layout .operations-policy-status[data-tooltip]::after,
body.sgsi-sidebar-layout .operations-policy-status[data-tooltip]:hover::after,
body.sgsi-sidebar-layout .operations-policy-status[data-tooltip]:focus::after {
    content: none !important;
    display: none !important;
}

body.sgsi-sidebar-layout .operations-policy-status {
    background:
        radial-gradient(circle at center, #ffffff 0 58%, transparent 59%),
        conic-gradient(#0f5ea8 calc(var(--ops-progress, 0) * 1%), #e5ece8 0) !important;
    border: 0 !important;
    border-radius: 50% !important;
    overflow: hidden !important;
}

body.sgsi-sidebar-layout .operations-policy-status::before {
    content: none !important;
    display: none !important;
}

/* Project KPI circles without outer boxes. */
body.sgsi-sidebar-layout .incident-kpi,
body.sgsi-sidebar-layout .incident-kpi.incident-kpi-strong {
    border: 0 !important;
    border-left: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    min-height: 150px !important;
    padding: 4px 8px !important;
}

body.sgsi-sidebar-layout .incident-kpi:hover {
    background: transparent !important;
    box-shadow: none !important;
}

body.sgsi-sidebar-layout .incident-kpi-grid {
    gap: 18px !important;
    padding: 8px 0 10px !important;
}

/* Remove project KPI card backgrounds completely. */
body.sgsi-sidebar-layout .project-dashboard .incident-kpi-grid {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

body.sgsi-sidebar-layout .project-dashboard .incident-kpi-grid > .incident-kpi,
body.sgsi-sidebar-layout .project-dashboard .incident-kpi-grid > .incident-kpi.incident-kpi-strong,
body.sgsi-sidebar-layout .project-dashboard .incident-kpi-grid > a.incident-kpi {
    background: transparent !important;
    border: 0 !important;
    border-left: 0 !important;
    outline: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}

body.sgsi-sidebar-layout .project-dashboard .incident-kpi-grid > .incident-kpi::before,
body.sgsi-sidebar-layout .project-dashboard .incident-kpi-grid > .incident-kpi::after {
    content: none !important;
    display: none !important;
}

/* Document library KPI circles without card boxes. */
body.sgsi-sidebar-layout .document-workbench-cards {
    gap: 18px !important;
    padding: 8px 0 10px !important;
    align-items: stretch !important;
}

body.sgsi-sidebar-layout .document-workbench-card,
body.sgsi-sidebar-layout .document-workbench-card:hover,
body.sgsi-sidebar-layout .document-workbench-card.is-active {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 150px !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: #1e2420 !important;
    padding: 4px 8px !important;
    text-align: center !important;
}

body.sgsi-sidebar-layout .document-workbench-card strong {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 96px !important;
    height: 96px !important;
    border: 8px solid #e5ece8 !important;
    border-radius: 50% !important;
    color: #0f5ea8 !important;
    font-size: 2.3rem !important;
    line-height: 1 !important;
    margin: 4px 0 !important;
}

body.sgsi-sidebar-layout .document-workbench-card.is-active strong {
    border-color: #cfe0f1 !important;
    box-shadow: 0 0 0 3px rgba(15, 94, 168, 0.08) !important;
}

body.sgsi-sidebar-layout .document-workbench-card span,
body.sgsi-sidebar-layout .document-workbench-card small {
    color: #526170 !important;
    opacity: 1 !important;
}

/* Risk analysis summary: clean circular metrics, no washed card. */
body.sgsi-sidebar-layout .advanced-mode .risk-register-summary,
body.sgsi-sidebar-layout .risk-register-summary {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(150px, 1fr)) !important;
    gap: 22px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 8px 0 18px !important;
    margin: 18px 0 24px !important;
}

body.sgsi-sidebar-layout .advanced-mode .risk-register-summary article,
body.sgsi-sidebar-layout .risk-register-summary article {
    min-height: 154px !important;
    padding: 4px 10px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    gap: 7px !important;
}

body.sgsi-sidebar-layout .advanced-mode .risk-register-summary article::before,
body.sgsi-sidebar-layout .advanced-mode .risk-register-summary article::after,
body.sgsi-sidebar-layout .risk-register-summary article::before,
body.sgsi-sidebar-layout .risk-register-summary article::after {
    content: none !important;
    display: none !important;
}

body.sgsi-sidebar-layout .advanced-mode .risk-register-summary span,
body.sgsi-sidebar-layout .risk-register-summary span {
    order: 1 !important;
    color: #5a6876 !important;
    opacity: 1 !important;
    font-size: 0.92rem !important;
    line-height: 1.05 !important;
    font-weight: 900 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

body.sgsi-sidebar-layout .advanced-mode .risk-register-summary strong,
body.sgsi-sidebar-layout .risk-register-summary strong {
    order: 2 !important;
    width: 96px !important;
    height: 96px !important;
    min-width: 96px !important;
    border-radius: 50% !important;
    border: 8px solid #e5ece8 !important;
    background: #fff !important;
    color: #0f5ea8 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 2.45rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    margin: 0 !important;
}

body.sgsi-sidebar-layout .advanced-mode .risk-register-summary p,
body.sgsi-sidebar-layout .risk-register-summary p {
    order: 3 !important;
    max-width: 210px !important;
    color: #526170 !important;
    opacity: 1 !important;
    font-size: 0.98rem !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    margin: 0 !important;
}

@media (max-width: 1100px) {
    body.sgsi-sidebar-layout .advanced-mode .risk-register-summary,
    body.sgsi-sidebar-layout .risk-register-summary {
        grid-template-columns: repeat(2, minmax(150px, 1fr)) !important;
    }
}

@media (max-width: 640px) {
    body.sgsi-sidebar-layout .advanced-mode .risk-register-summary,
    body.sgsi-sidebar-layout .risk-register-summary {
        grid-template-columns: 1fr !important;
    }
}

/* Operations policy register cards: four even columns. */
body.sgsi-sidebar-layout .operations-register-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 16px !important;
    align-items: stretch !important;
    width: 100% !important;
    max-width: 100% !important;
}

body.sgsi-sidebar-layout .operations-register-card {
    min-width: 0 !important;
    width: 100% !important;
    height: 100% !important;
    box-sizing: border-box !important;
}

@media (max-width: 1180px) {
    body.sgsi-sidebar-layout .operations-register-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 680px) {
    body.sgsi-sidebar-layout .operations-register-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Compact organization users screen. */
body.sgsi-sidebar-layout .organization-admin {
    padding-top: 22px !important;
}

body.sgsi-sidebar-layout .organization-admin .page-heading {
    margin-bottom: 10px !important;
    gap: 10px !important;
}

body.sgsi-sidebar-layout .organization-admin .page-heading h1 {
    font-size: clamp(2rem, 3.6vw, 3.6rem) !important;
    line-height: 0.98 !important;
}

body.sgsi-sidebar-layout .organization-admin .page-heading .muted {
    max-width: 760px !important;
    margin-top: 4px !important;
    color: #5f6f82 !important;
}

body.sgsi-sidebar-layout .organization-admin .org-admin-grid {
    grid-template-columns: minmax(0, 1.18fr) minmax(280px, 0.82fr) !important;
    gap: 10px !important;
    margin-bottom: 10px !important;
}

body.sgsi-sidebar-layout .organization-admin .table-section,
body.sgsi-sidebar-layout .organization-admin .form-section {
    border-radius: 8px !important;
    margin-bottom: 10px !important;
}

body.sgsi-sidebar-layout .organization-admin .form-section {
    padding: 12px !important;
}

body.sgsi-sidebar-layout .organization-admin .section-heading {
    min-height: auto !important;
    padding: 10px 12px !important;
    gap: 8px !important;
}

body.sgsi-sidebar-layout .organization-admin .section-heading h2 {
    font-size: 1.08rem !important;
    line-height: 1.12 !important;
}

body.sgsi-sidebar-layout .organization-admin .section-heading span,
body.sgsi-sidebar-layout .organization-admin .org-inline-heading span,
body.sgsi-sidebar-layout .organization-admin .org-current-card span,
body.sgsi-sidebar-layout .organization-admin .organization-switch-card span {
    font-size: 0.82rem !important;
    line-height: 1.2 !important;
}

body.sgsi-sidebar-layout .organization-admin .org-overview-panel {
    gap: 8px !important;
}

body.sgsi-sidebar-layout .organization-admin .org-current-card,
body.sgsi-sidebar-layout .organization-admin .organization-switch-card {
    min-height: 42px !important;
    padding: 8px 10px !important;
    gap: 10px !important;
}

body.sgsi-sidebar-layout .organization-admin .organization-switch-list-compact {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
}

body.sgsi-sidebar-layout .organization-admin .org-inline-heading {
    margin-top: 2px !important;
    min-height: auto !important;
}

body.sgsi-sidebar-layout .organization-admin .org-create-form,
body.sgsi-sidebar-layout .organization-admin .invite-user-form {
    display: grid !important;
    gap: 8px !important;
}

body.sgsi-sidebar-layout .organization-admin .org-create-form {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

body.sgsi-sidebar-layout .organization-admin .org-create-form button,
body.sgsi-sidebar-layout .organization-admin .invite-user-form button {
    min-height: 34px !important;
    padding: 6px 12px !important;
    border-radius: 8px !important;
    font-size: 0.88rem !important;
}

body.sgsi-sidebar-layout .organization-admin .org-create-form button {
    grid-column: 1 / -1 !important;
}

body.sgsi-sidebar-layout .organization-admin .org-invite-panel {
    padding: 12px !important;
}

body.sgsi-sidebar-layout .organization-admin .invite-user-form {
    max-width: none !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    align-items: end !important;
}

body.sgsi-sidebar-layout .organization-admin .invite-user-form .form-field {
    min-width: 0 !important;
}

body.sgsi-sidebar-layout .organization-admin .invite-user-form button {
    align-self: end !important;
}

body.sgsi-sidebar-layout .organization-admin .form-field {
    gap: 3px !important;
}

body.sgsi-sidebar-layout .organization-admin .form-field label {
    font-size: 0.78rem !important;
    line-height: 1.1 !important;
}

body.sgsi-sidebar-layout .organization-admin .form-field input,
body.sgsi-sidebar-layout .organization-admin .form-field select,
body.sgsi-sidebar-layout .organization-admin .form-field textarea,
body.sgsi-sidebar-layout .organization-admin .inline-role-form select,
body.sgsi-sidebar-layout .organization-admin .permission-profile-form select {
    min-height: 32px !important;
    padding: 5px 8px !important;
    border-radius: 7px !important;
    font-size: 0.86rem !important;
}

body.sgsi-sidebar-layout .organization-admin table th,
body.sgsi-sidebar-layout .organization-admin table td {
    padding: 7px 10px !important;
    line-height: 1.15 !important;
    vertical-align: middle !important;
}

body.sgsi-sidebar-layout .organization-admin table th {
    font-size: 0.76rem !important;
}

body.sgsi-sidebar-layout .organization-admin table td {
    font-size: 0.88rem !important;
}

body.sgsi-sidebar-layout .organization-admin .inline-role-form,
body.sgsi-sidebar-layout .organization-admin .inline-delete-form {
    gap: 6px !important;
}

body.sgsi-sidebar-layout .organization-admin .inline-role-form select {
    min-width: 118px !important;
}

body.sgsi-sidebar-layout .organization-admin .inline-role-form button,
body.sgsi-sidebar-layout .organization-admin .inline-delete-form button,
body.sgsi-sidebar-layout .organization-admin .permission-profile-form button,
body.sgsi-sidebar-layout .organization-admin .permission-actions button {
    min-height: 30px !important;
    padding: 5px 9px !important;
    border-radius: 7px !important;
    font-size: 0.8rem !important;
}

body.sgsi-sidebar-layout .organization-admin .permission-panel {
    gap: 10px !important;
    margin-top: 10px !important;
    padding: 12px !important;
}

body.sgsi-sidebar-layout .organization-admin .permission-panel-heading {
    gap: 10px !important;
    padding-bottom: 8px !important;
}

body.sgsi-sidebar-layout .organization-admin .permission-panel-heading h3 {
    font-size: 0.94rem !important;
}

body.sgsi-sidebar-layout .organization-admin .permission-profile-form {
    grid-template-columns: auto minmax(150px, 210px) auto !important;
    gap: 6px !important;
}

body.sgsi-sidebar-layout .organization-admin .permission-grid-form,
body.sgsi-sidebar-layout .organization-admin .permission-group {
    gap: 8px !important;
}

body.sgsi-sidebar-layout .organization-admin .permission-group-title {
    min-height: 24px !important;
    padding: 3px 8px !important;
    font-size: 0.72rem !important;
}

body.sgsi-sidebar-layout .organization-admin .permission-grid {
    grid-template-columns: minmax(118px, 1fr) repeat(7, minmax(76px, 0.72fr)) !important;
    gap: 4px !important;
}

body.sgsi-sidebar-layout .organization-admin .permission-grid-header,
body.sgsi-sidebar-layout .organization-admin .permission-grid-module,
body.sgsi-sidebar-layout .organization-admin .permission-check {
    min-height: 30px !important;
    border-radius: 6px !important;
    padding: 5px 7px !important;
    font-size: 0.72rem !important;
}

body.sgsi-sidebar-layout .organization-admin .permission-check input {
    width: 13px !important;
    height: 13px !important;
}

@media (max-width: 1080px) {
    body.sgsi-sidebar-layout .organization-admin .org-admin-grid,
    body.sgsi-sidebar-layout .organization-admin .invite-user-form {
        grid-template-columns: 1fr 1fr !important;
    }
}

@media (max-width: 760px) {
    body.sgsi-sidebar-layout .organization-admin .org-admin-grid,
    body.sgsi-sidebar-layout .organization-admin .organization-switch-list-compact,
    body.sgsi-sidebar-layout .organization-admin .org-create-form,
    body.sgsi-sidebar-layout .organization-admin .invite-user-form {
        grid-template-columns: 1fr !important;
    }
}

/* Sidebar separation: slightly stronger blue depth. */
body.sgsi-sidebar-layout .sgsi-sidebar {
    border-right-color: #c7d9e8 !important;
    box-shadow: 10px 0 30px rgba(15, 94, 168, 0.085) !important;
}

body.sgsi-sidebar-layout .sgsi-content-shell {
    box-shadow: inset 1px 0 0 rgba(15, 94, 168, 0.08) !important;
}

/* Sidebar menu v2: favorites and collapsible modules. */
body.sgsi-sidebar-layout .sgsi-sidebar-nav-v2 {
    gap: 8px !important;
    padding: 12px 8px 22px !important;
}

body.sgsi-sidebar-layout .sgsi-nav-favorites {
    display: grid !important;
    gap: 5px !important;
    margin-bottom: 4px !important;
    padding-bottom: 8px !important;
    border-bottom: 1px solid #e5edf4 !important;
}

body.sgsi-sidebar-layout .sgsi-nav-favorites p {
    margin: 0 0 2px !important;
    padding: 0 8px !important;
    color: #6f7d87 !important;
    font-size: 0.68rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
}

body.sgsi-sidebar-layout .sgsi-favorite-link {
    display: grid !important;
    grid-template-columns: 22px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 30px !important;
    border: 1px solid #dbe7ef !important;
    border-radius: 8px !important;
    background: #ffffff !important;
    color: #243344 !important;
    padding: 4px 8px !important;
    text-decoration: none !important;
    font-weight: 900 !important;
}

body.sgsi-sidebar-layout .sgsi-favorite-link span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 20px !important;
    height: 20px !important;
    border-radius: 50% !important;
    background: #edf5fb !important;
    color: #0f5ea8 !important;
    font-size: 0.68rem !important;
}

body.sgsi-sidebar-layout .sgsi-favorite-link strong {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: 0.82rem !important;
}

body.sgsi-sidebar-layout .sgsi-favorite-link:hover,
body.sgsi-sidebar-layout .sgsi-favorite-link.is-active {
    border-color: #bdd5e8 !important;
    color: #0f5ea8 !important;
    box-shadow: inset 3px 0 0 #0f5ea8 !important;
}

body.sgsi-sidebar-layout .sgsi-nav-module {
    display: grid !important;
    gap: 3px !important;
}

body.sgsi-sidebar-layout .sgsi-nav-module summary {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 26px minmax(0, 1fr) 18px !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 36px !important;
    border: 1px solid transparent !important;
    border-radius: 8px !important;
    color: #203044 !important;
    cursor: pointer !important;
    font-weight: 900 !important;
    list-style: none !important;
    padding: 5px 8px !important;
}

body.sgsi-sidebar-layout .sgsi-nav-module summary::-webkit-details-marker {
    display: none !important;
}

body.sgsi-sidebar-layout .sgsi-nav-module summary:hover {
    border-color: #dbe7ef !important;
    background: #ffffff !important;
    color: #0f5ea8 !important;
}

body.sgsi-sidebar-layout .sgsi-nav-module[open] > summary {
    border-color: #cbddeb !important;
    background: #ffffff !important;
    box-shadow: inset 3px 0 0 #0f5ea8 !important;
    color: #0f5ea8 !important;
}

body.sgsi-sidebar-layout .sgsi-nav-chevron {
    color: #7b8a96 !important;
    font-size: 0.95rem !important;
    text-align: center !important;
    transform: rotate(-90deg) !important;
    transition: transform 0.15s ease !important;
}

body.sgsi-sidebar-layout .sgsi-nav-module[open] .sgsi-nav-chevron {
    transform: rotate(0deg) !important;
}

body.sgsi-sidebar-layout .sgsi-nav-module-body {
    display: grid !important;
    gap: 2px !important;
    padding: 2px 0 6px 10px !important;
    margin-left: 12px !important;
    border-left: 1px solid #dce9f3 !important;
}

body.sgsi-sidebar-layout .sgsi-nav-item,
body.sgsi-sidebar-layout .sgsi-nav-module-body .sgsi-nav-placeholder {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 26px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 32px !important;
    border: 1px solid transparent !important;
    border-radius: 8px !important;
    color: #28384b !important;
    font-weight: 850 !important;
    padding: 4px 8px !important;
    text-decoration: none !important;
}

body.sgsi-sidebar-layout .sgsi-nav-item:hover,
body.sgsi-sidebar-layout .sgsi-nav-item.is-active {
    border-color: #dbe7ef !important;
    background: #ffffff !important;
    color: #0f5ea8 !important;
}

body.sgsi-sidebar-layout .sgsi-nav-module-body .sgsi-nav-child {
    min-height: 30px !important;
    margin-left: 16px !important;
    color: #556676 !important;
    font-size: 0.88rem !important;
    padding: 4px 8px !important;
    border-radius: 8px !important;
}

body.sgsi-sidebar-layout .sgsi-nav-module-body .sgsi-nav-child:hover,
body.sgsi-sidebar-layout .sgsi-nav-module-body .sgsi-nav-child.is-active {
    background: #ffffff !important;
    color: #0f5ea8 !important;
}

body.sgsi-sidebar-layout .sgsi-nav-module-body .sgsi-nav-child.is-active {
    box-shadow: inset 3px 0 0 #0f5ea8 !important;
}

body.sgsi-sidebar-collapsed .sgsi-nav-favorites,
body.sgsi-sidebar-collapsed .sgsi-nav-module-body,
body.sgsi-sidebar-collapsed .sgsi-nav-chevron {
    display: none !important;
}

body.sgsi-sidebar-collapsed .sgsi-nav-module summary {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    padding-inline: 6px !important;
}

body.sgsi-sidebar-collapsed .sgsi-nav-module[open] > summary {
    box-shadow: none !important;
}

body.sgsi-sidebar-collapsed .sgsi-nav-module summary .sgsi-nav-text {
    display: none !important;
}


/* Administration hub: integrated Admon shell. */
body.sgsi-sidebar-layout .sgsi-admon-hub {
    display: grid !important;
    gap: 18px !important;
}

body.sgsi-sidebar-layout .sgsi-admon-heading {
    display: flex !important;
    align-items: flex-end !important;
    justify-content: space-between !important;
    gap: 18px !important;
    border-bottom: 1px solid #dfe7ee !important;
    padding-bottom: 18px !important;
}

body.sgsi-sidebar-layout .sgsi-admon-heading h1 {
    margin: 0 !important;
    color: #1e2622 !important;
}

body.sgsi-sidebar-layout .sgsi-admon-heading p:not(.eyebrow) {
    max-width: 880px !important;
    margin: 6px 0 0 !important;
    color: #5d6c78 !important;
}

body.sgsi-sidebar-layout .sgsi-admon-status,
body.sgsi-sidebar-layout .sgsi-admon-grid,
body.sgsi-sidebar-layout .sgsi-admon-roadmap-grid {
    display: grid !important;
    gap: 12px !important;
}

body.sgsi-sidebar-layout .sgsi-admon-status {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

body.sgsi-sidebar-layout .sgsi-admon-status article,
body.sgsi-sidebar-layout .sgsi-admon-roadmap article,
body.sgsi-sidebar-layout .sgsi-admon-card {
    border: 1px solid #d7e4ee !important;
    border-radius: 10px !important;
    background: #ffffff !important;
    box-shadow: 0 12px 28px rgba(18, 45, 76, 0.045) !important;
}

body.sgsi-sidebar-layout .sgsi-admon-status article {
    min-height: 118px !important;
    padding: 18px !important;
    border-left: 5px solid #0f5ea8 !important;
}

body.sgsi-sidebar-layout .sgsi-admon-status span,
body.sgsi-sidebar-layout .sgsi-admon-card span,
body.sgsi-sidebar-layout .sgsi-admon-roadmap small {
    color: #667681 !important;
}

body.sgsi-sidebar-layout .sgsi-admon-status span,
body.sgsi-sidebar-layout .sgsi-admon-card span {
    display: block !important;
    font-size: 0.72rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
}

body.sgsi-sidebar-layout .sgsi-admon-status strong {
    display: block !important;
    margin-top: 8px !important;
    color: #11233d !important;
    font-size: 1.32rem !important;
}

body.sgsi-sidebar-layout .sgsi-admon-status small {
    display: block !important;
    margin-top: 8px !important;
    color: #62717d !important;
    line-height: 1.35 !important;
}

body.sgsi-sidebar-layout .sgsi-admon-panel {
    padding: 0 !important;
    overflow: hidden !important;
}

body.sgsi-sidebar-layout .sgsi-admon-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    padding: 18px !important;
}

body.sgsi-sidebar-layout .sgsi-admon-card {
    display: grid !important;
    min-height: 154px !important;
    align-content: start !important;
    gap: 10px !important;
    padding: 20px !important;
    border-left: 6px solid #0f5ea8 !important;
    color: #11233d !important;
    text-decoration: none !important;
}

body.sgsi-sidebar-layout .sgsi-admon-card:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 16px 34px rgba(18, 45, 76, 0.08) !important;
}

body.sgsi-sidebar-layout .sgsi-admon-card strong {
    font-size: 1.35rem !important;
    line-height: 1.12 !important;
}

body.sgsi-sidebar-layout .sgsi-admon-card small {
    color: #5a6b78 !important;
    line-height: 1.35 !important;
}

body.sgsi-sidebar-layout .sgsi-admon-roadmap-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    padding: 18px !important;
}

body.sgsi-sidebar-layout .sgsi-admon-roadmap article {
    min-height: 132px !important;
    padding: 18px !important;
}

body.sgsi-sidebar-layout .sgsi-admon-roadmap article strong {
    display: inline-flex !important;
    width: 34px !important;
    height: 34px !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    background: #eef5fb !important;
    color: #0f5ea8 !important;
}

body.sgsi-sidebar-layout .sgsi-admon-roadmap article span {
    display: block !important;
    margin-top: 12px !important;
    color: #16263b !important;
    font-weight: 900 !important;
}

@media (max-width: 1100px) {
    body.sgsi-sidebar-layout .sgsi-admon-status,
    body.sgsi-sidebar-layout .sgsi-admon-grid,
    body.sgsi-sidebar-layout .sgsi-admon-roadmap-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 720px) {
    body.sgsi-sidebar-layout .sgsi-admon-heading {
        align-items: stretch !important;
        flex-direction: column !important;
    }
    body.sgsi-sidebar-layout .sgsi-admon-status,
    body.sgsi-sidebar-layout .sgsi-admon-grid,
    body.sgsi-sidebar-layout .sgsi-admon-roadmap-grid {
        grid-template-columns: 1fr !important;
    }
}


/* Sidebar administration sections. */
body.sgsi-sidebar-layout .sgsi-nav-section-label {
    display: block !important;
    margin: 8px 8px 3px !important;
    color: #6f7f8b !important;
    font-size: 0.64rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.13em !important;
    line-height: 1.1 !important;
    text-transform: uppercase !important;
}

body.sgsi-sidebar-layout .sgsi-nav-section-label + .sgsi-nav-item {
    margin-top: 0 !important;
}


/* Operational profile switcher. */
body.sgsi-sidebar-layout .sgsi-profile-menu summary {
    border-left: 3px solid #0f5ea8 !important;
}

body.sgsi-sidebar-layout .sgsi-profile-menu .sgsi-company-option.is-current {
    border-color: #0f5ea8 !important;
    background: #eef6fc !important;
}


/* Dashboard 2.0 personal worklist: keep the user's own tasks quieter and easier to scan. */
.dashboard-2-worklist-subtle {
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.035);
}
.dashboard-2-work-heading {
    align-items: center;
    margin-bottom: 10px;
}
.dashboard-2-work-heading small {
    display: block;
    margin-top: 4px;
    color: #64748b;
    font-size: 0.82rem;
    font-weight: 700;
}
.dashboard-2-quiet-link {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 5px 10px;
    border: 1px solid #dce6ee;
    border-radius: 999px;
    background: #ffffff;
    color: #405066;
    font-size: 0.8rem;
    font-weight: 800;
    text-decoration: none;
    white-space: nowrap;
}
.dashboard-2-quiet-link:hover {
    border-color: #9fb8cf;
    color: #0f3b68;
}
.dashboard-2-work-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 8px;
}
.dashboard-2-scope-toggle {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 5px 10px;
    border: 1px solid #b9d2e8;
    border-radius: 999px;
    background: #f7fbff;
    color: #0f5ea8;
    font-size: 0.8rem;
    font-weight: 850;
    text-decoration: none;
    white-space: nowrap;
}
.dashboard-2-scope-toggle:hover {
    border-color: #0f5ea8;
    background: #eef7ff;
}
.dashboard-2-scope-toggle.is-active {
    border-color: #123a6f;
    background: #123a6f;
    color: #ffffff;
}
.dashboard-2-training-summary {
    display: grid;
    grid-template-columns: 76px minmax(0, 1fr);
    align-items: center;
    gap: 14px;
}
.dashboard-2-training-summary .dashboard-2-ring {
    --ring-color: #1f7a6b;
}
.dashboard-2-training-summary dl {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px 12px;
    margin: 0;
}
.dashboard-2-training-summary div {
    min-width: 0;
}
.dashboard-2-training-summary dt {
    color: #6b7785;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.dashboard-2-training-summary dd {
    margin: 2px 0 0;
    color: #172033;
    font-size: 1rem;
    font-weight: 900;
}
.dashboard-2-muted-note {
    margin: 12px 0 0;
    color: #64748b;
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1.35;
}
.dashboard-2-worklist-subtle .dashboard-2-list {
    gap: 8px;
}
.dashboard-2-worklist-subtle .dashboard-2-task {
    grid-template-columns: 48px minmax(0, 1fr);
    gap: 10px;
    padding: 10px 12px;
    border-color: #edf2f7;
    background: #ffffff;
    box-shadow: none;
}
.dashboard-2-worklist-subtle .dashboard-2-task:hover {
    border-color: #c9d9e8;
    background: #fbfdff;
}
.dashboard-2-worklist-subtle .dashboard-2-task:focus-visible {
    outline: 2px solid #7aa7d4;
    outline-offset: 2px;
}
.dashboard-2-worklist-subtle .dashboard-2-task-date {
    min-height: 48px;
    border-radius: 8px;
    border: 1px solid #d7e0ea;
    background: #ffffff;
    color: #253447;
}
.dashboard-2-worklist-subtle .dashboard-2-work-task.priority-critical:not(.is-overdue) .dashboard-2-task-date {
    border-color: #b42318;
    background: #fff7f5;
    color: #b42318;
}
.dashboard-2-worklist-subtle .dashboard-2-work-task.priority-high:not(.is-overdue) .dashboard-2-task-date {
    border-color: #e15f22;
    background: #fff7ed;
    color: #c2410c;
}
.dashboard-2-worklist-subtle .dashboard-2-work-task.priority-medium:not(.is-overdue) .dashboard-2-task-date {
    border-color: #0f5ea8;
    background: #ffffff;
    color: #0f5ea8;
}
.dashboard-2-worklist-subtle .dashboard-2-work-task.priority-low:not(.is-overdue) .dashboard-2-task-date {
    border-color: #15803d;
    background: #ffffff;
    color: #15803d;
}
.dashboard-2-worklist-subtle .dashboard-2-work-task.is-overdue .dashboard-2-task-date {
    border-color: #b42318;
    background: #fff0ed;
    color: #b42318;
}
.dashboard-2-worklist-subtle .dashboard-2-task-date strong {
    font-size: 1rem;
}
.dashboard-2-worklist-subtle .dashboard-2-task-date span {
    font-size: 0.64rem;
}
.dashboard-2-worklist-subtle .dashboard-2-task-title strong {
    font-size: 0.95rem;
}
.dashboard-2-worklist-subtle .dashboard-2-task-title span {
    color: #0f766e;
    font-size: 0.76rem;
}
.dashboard-2-worklist-subtle .dashboard-2-task p {
    margin: 3px 0;
    font-size: 0.84rem;
}
.dashboard-2-worklist-subtle .dashboard-2-task small {
    font-size: 0.78rem;
}
@media (max-width: 720px) {
    .dashboard-2-work-heading {
        align-items: flex-start;
    }
}


/* Dashboard 2.0 three-column daily workspace. */
.dashboard-2-main-grid-three {
    display: grid;
    grid-template-columns: minmax(260px, 0.72fr) minmax(430px, 1.45fr) minmax(250px, 0.72fr);
    gap: 14px;
    align-items: start;
}
.dashboard-2-column {
    display: grid;
    gap: 14px;
    align-content: start;
}
.dashboard-2-main-grid-three .dashboard-2-panel {
    padding: 16px;
}
.dashboard-2-calendar-panel .dashboard-2-agenda a {
    padding: 9px 0;
}
.dashboard-2-compact-panel p {
    margin: 0 0 10px;
    color: #64748b;
}
.dashboard-2-compact-panel .dashboard-2-primary-button,
.dashboard-2-compact-panel .dashboard-2-secondary-button {
    min-height: 36px;
    padding: 8px 12px;
    font-size: 0.82rem;
}
.dashboard-2-right-column .dashboard-2-performance dl {
    gap: 10px;
}
.dashboard-2-right-column .dashboard-2-performance p {
    font-size: 0.82rem;
    line-height: 1.35;
}
@media (max-width: 1320px) {
    .dashboard-2-main-grid-three {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1.35fr);
    }
    .dashboard-2-right-column {
        grid-column: 1 / -1;
    }
}
@media (max-width: 920px) {
    .dashboard-2-main-grid-three {
        grid-template-columns: 1fr;
    }
    .dashboard-2-center-column {
        order: 1;
    }
    .dashboard-2-left-column {
        order: 2;
    }
    .dashboard-2-right-column {
        order: 3;
    }
}


.responsible-checkbox-panel {
    border: 1px solid var(--border-color, #d6e2ec);
    border-radius: 8px;
    padding: 7px 10px;
    background: #fff;
    min-height: 48px;
}

.responsible-checkbox-panel ul,
.responsible-checkbox-panel .responsible-checkbox-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 4px 10px;
}

.responsible-checkbox-panel li,
.responsible-checkbox-panel label {
    margin: 0;
}

.responsible-checkbox-panel label {
    display: flex;
    align-items: center;
    gap: 6px;
    min-height: 24px;
    font-size: 0.92rem;
    font-weight: 700;
    color: #1b2a3d;
    line-height: 1.1;
}

.responsible-checkbox-panel input[type="checkbox"] {
    inline-size: 14px;
    block-size: 14px;
    accent-color: #0f7f72;
}


.dashboard-2-expiration-list {
    display: grid;
    gap: 10px;
}

.dashboard-2-expiration-item {
    display: grid;
    grid-template-columns: 58px 1fr;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid #dbe6ef;
    border-left: 4px solid #0f7f72;
    border-radius: 8px;
    color: inherit;
    text-decoration: none;
    background: #fff;
}

.dashboard-2-expiration-item.is-soon {
    border-left-color: #d6a100;
}

.dashboard-2-expiration-item.is-overdue {
    border-left-color: #bd2a22;
}

.dashboard-2-expiration-date {
    display: grid;
    place-items: center;
    min-height: 58px;
    border-radius: 8px;
    background: #f3f7fa;
    color: #0d5ca6;
    text-align: center;
}

.dashboard-2-expiration-date strong {
    font-size: 1.35rem;
    line-height: 1;
}

.dashboard-2-expiration-date span {
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.dashboard-2-expiration-item p,
.dashboard-2-expiration-item small {
    margin: 3px 0 0;
    color: #5c6b7b;
}

/* Mobile sidebar: starts hidden and uses the hamburger as the only drawer control. */
@media (max-width: 980px) {
    body.sgsi-sidebar-layout {
        zoom: 1 !important;
        width: 100% !important;
        min-height: 100vh !important;
        overflow-x: hidden !important;
    }

    body.sgsi-sidebar-layout .sgsi-app-shell,
    body.sgsi-sidebar-layout.sgsi-sidebar-collapsed .sgsi-app-shell {
        grid-template-columns: minmax(0, 1fr) !important;
        width: 100% !important;
        min-height: 100vh !important;
    }

    body.sgsi-sidebar-layout .sgsi-sidebar {
        position: fixed !important;
        inset: 0 auto 0 0 !important;
        width: min(86vw, 292px) !important;
        height: 100dvh !important;
        max-height: 100dvh !important;
        transform: translateX(-105%) !important;
        z-index: 1200 !important;
        box-shadow: 16px 0 34px rgba(13, 31, 51, 0.16) !important;
    }

    body.sgsi-sidebar-layout:not(.sgsi-sidebar-collapsed) .sgsi-sidebar {
        transform: translateX(0) !important;
    }

    body.sgsi-sidebar-layout .sgsi-main-content,
    body.sgsi-sidebar-layout .sgsi-topbar {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
    }

    body.sgsi-sidebar-layout .sgsi-topbar {
        position: sticky !important;
        top: 0 !important;
        z-index: 900 !important;
        min-height: 54px !important;
        padding: 8px 12px !important;
    }

    body.sgsi-sidebar-layout .dashboard,
    body.sgsi-sidebar-layout .advanced-dashboard,
    body.sgsi-sidebar-layout .treatment-dashboard,
    body.sgsi-sidebar-layout .control-center-page,
    body.sgsi-sidebar-layout .asset-dashboard,
    body.sgsi-sidebar-layout .project-dashboard,
    body.sgsi-sidebar-layout .records-dashboard,
    body.sgsi-sidebar-layout .document-library-page,
    body.sgsi-sidebar-layout .dashboard-page {
        padding: 12px !important;
    }
}

/* Invite scoped access: companies + modules/submodules */
body.sgsi-sidebar-layout .organization-admin .invite-scope-form {
    display: grid;
    gap: 16px;
}

body.sgsi-sidebar-layout .organization-admin .invite-scope-main-grid {
    display: grid;
    grid-template-columns: minmax(260px, 1.2fr) minmax(180px, .7fr) minmax(240px, 1fr);
    gap: 14px;
    align-items: start;
}

body.sgsi-sidebar-layout .organization-admin .invite-scope-grid {
    display: grid;
    grid-template-columns: minmax(260px, .8fr) minmax(460px, 1.8fr);
    gap: 16px;
    align-items: stretch;
}

body.sgsi-sidebar-layout .organization-admin .invite-scope-card {
    border: 1px solid #d8e4ee;
    border-radius: 8px;
    background: #fff;
    padding: 14px;
}

body.sgsi-sidebar-layout .organization-admin .invite-scope-card-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid #e3e9ee;
    color: #0f2544;
}

body.sgsi-sidebar-layout .organization-admin .invite-scope-card-heading span {
    color: #607080;
    font-size: 13px;
    font-weight: 800;
}

body.sgsi-sidebar-layout .organization-admin .invite-checkbox-list ul {
    list-style: none;
    margin: 10px 0 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 8px;
}

body.sgsi-sidebar-layout .organization-admin .invite-checkbox-list li {
    margin: 0;
}

body.sgsi-sidebar-layout .organization-admin .invite-checkbox-list label,
body.sgsi-sidebar-layout .organization-admin .invite-check-chip {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 38px;
    border: 1px solid #d8e4ee;
    border-radius: 8px;
    padding: 8px 10px;
    background: #fbfdff;
    color: #17263b;
    font-weight: 800;
}

body.sgsi-sidebar-layout .organization-admin .invite-checkbox-list input,
body.sgsi-sidebar-layout .organization-admin .invite-check-chip input {
    width: 15px;
    height: 15px;
    accent-color: #1263ad;
}

body.sgsi-sidebar-layout .organization-admin .invite-module-groups {
    display: grid;
    grid-template-columns: repeat(2, minmax(240px, 1fr));
    gap: 12px;
    margin-top: 10px;
}

body.sgsi-sidebar-layout .organization-admin .invite-module-group {
    border: 1px solid #e0e8f0;
    border-radius: 8px;
    padding: 12px;
    min-width: 0;
}

body.sgsi-sidebar-layout .organization-admin .invite-module-group legend {
    padding: 0 6px;
    color: #66727f;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

body.sgsi-sidebar-layout .organization-admin .invite-module-options {
    display: grid;
    gap: 8px;
}

body.sgsi-sidebar-layout .organization-admin .invite-scope-form > button[type="submit"] {
    justify-self: end;
    min-width: 220px;
}

@media (max-width: 1100px) {
    body.sgsi-sidebar-layout .organization-admin .invite-scope-main-grid,
    body.sgsi-sidebar-layout .organization-admin .invite-scope-grid,
    body.sgsi-sidebar-layout .organization-admin .invite-module-groups {
        grid-template-columns: 1fr;
    }
}

/* Production fix: scoped invite form alignment and small native checks */
.organization-admin .invite-user-form.invite-scope-form,
body.sgsi-sidebar-layout .organization-admin .invite-user-form.invite-scope-form {
    max-width: none;
    width: 100%;
    display: grid;
    gap: 16px;
}

.organization-admin .invite-scope-main-grid,
body.sgsi-sidebar-layout .organization-admin .invite-scope-main-grid {
    display: grid;
    grid-template-columns: minmax(260px, 1.2fr) minmax(180px, .7fr) minmax(260px, 1fr);
    gap: 14px;
    align-items: start;
}

.organization-admin .invite-scope-grid,
body.sgsi-sidebar-layout .organization-admin .invite-scope-grid {
    display: grid;
    grid-template-columns: minmax(300px, .75fr) minmax(620px, 1.65fr);
    gap: 16px;
    align-items: start;
}

.organization-admin .invite-scope-card,
body.sgsi-sidebar-layout .organization-admin .invite-scope-card {
    min-width: 0;
    border: 1px solid #d8e4ee;
    border-radius: 8px;
    background: #fff;
    padding: 14px;
}

.organization-admin .invite-scope-card-heading,
body.sgsi-sidebar-layout .organization-admin .invite-scope-card-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid #e3e9ee;
}

.organization-admin .invite-scope-card-heading strong,
body.sgsi-sidebar-layout .organization-admin .invite-scope-card-heading strong {
    color: #17263b;
    font-size: 16px;
}

.organization-admin .invite-scope-card-heading span,
body.sgsi-sidebar-layout .organization-admin .invite-scope-card-heading span {
    color: #607080;
    font-size: 13px;
    font-weight: 800;
}

.organization-admin .invite-checkbox-list > div,
.organization-admin .invite-checkbox-list ul,
body.sgsi-sidebar-layout .organization-admin .invite-checkbox-list > div,
body.sgsi-sidebar-layout .organization-admin .invite-checkbox-list ul {
    list-style: none;
    margin: 10px 0 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 8px;
}

.organization-admin .invite-checkbox-list > div > div,
.organization-admin .invite-checkbox-list li,
body.sgsi-sidebar-layout .organization-admin .invite-checkbox-list > div > div,
body.sgsi-sidebar-layout .organization-admin .invite-checkbox-list li {
    margin: 0;
    min-width: 0;
}

.organization-admin .invite-checkbox-list label,
.organization-admin .invite-check-chip,
body.sgsi-sidebar-layout .organization-admin .invite-checkbox-list label,
body.sgsi-sidebar-layout .organization-admin .invite-check-chip {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 34px;
    width: 100%;
    border: 1px solid #d8e4ee;
    border-radius: 8px;
    padding: 7px 9px;
    background: #fbfdff;
    color: #17263b;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.2;
    box-sizing: border-box;
}

.organization-admin .invite-checkbox-list input[type="checkbox"],
.organization-admin .invite-check-chip input[type="checkbox"],
body.sgsi-sidebar-layout .organization-admin .invite-checkbox-list input[type="checkbox"],
body.sgsi-sidebar-layout .organization-admin .invite-check-chip input[type="checkbox"] {
    appearance: auto;
    -webkit-appearance: checkbox;
    display: inline-block;
    width: 14px !important;
    height: 14px !important;
    min-width: 14px !important;
    max-width: 14px !important;
    min-height: 14px !important;
    max-height: 14px !important;
    flex: 0 0 14px;
    padding: 0 !important;
    margin: 0;
    border-radius: 2px;
    accent-color: #1263ad;
}

.organization-admin .invite-module-groups,
body.sgsi-sidebar-layout .organization-admin .invite-module-groups {
    display: grid;
    grid-template-columns: repeat(2, minmax(240px, 1fr));
    gap: 12px;
    margin-top: 10px;
}

.organization-admin .invite-module-group,
body.sgsi-sidebar-layout .organization-admin .invite-module-group {
    min-width: 0;
    border: 1px solid #e0e8f0;
    border-radius: 8px;
    padding: 12px;
}

.organization-admin .invite-module-group legend,
body.sgsi-sidebar-layout .organization-admin .invite-module-group legend {
    padding: 0 6px;
    color: #66727f;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.organization-admin .invite-module-options,
body.sgsi-sidebar-layout .organization-admin .invite-module-options {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 8px;
}

.organization-admin .invite-scope-form > button[type="submit"],
body.sgsi-sidebar-layout .organization-admin .invite-scope-form > button[type="submit"] {
    justify-self: end;
    min-width: 220px;
}

@media (max-width: 1180px) {
    .organization-admin .invite-scope-main-grid,
    .organization-admin .invite-scope-grid,
    .organization-admin .invite-module-groups,
    body.sgsi-sidebar-layout .organization-admin .invite-scope-main-grid,
    body.sgsi-sidebar-layout .organization-admin .invite-scope-grid,
    body.sgsi-sidebar-layout .organization-admin .invite-module-groups {
        grid-template-columns: 1fr;
    }
}

/* Compact controlled checkboxes for user invitation and Miguel module summary */
.organization-admin .invite-checkbox-list input[type="checkbox"],
.organization-admin .invite-check-chip input[type="checkbox"],
.organization-admin .compact-check-chip input[type="checkbox"] {
    position: absolute !important;
    inline-size: 1px !important;
    block-size: 1px !important;
    width: 1px !important;
    height: 1px !important;
    opacity: 0 !important;
    overflow: hidden !important;
    pointer-events: none;
}

.organization-admin .invite-checkbox-list label,
.organization-admin .invite-check-chip,
.organization-admin .compact-check-chip {
    position: relative;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 32px !important;
    padding: 7px 9px !important;
    border: 1px solid #d8e4ee !important;
    border-radius: 8px !important;
    background: #fff !important;
    color: #17263b !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
    box-sizing: border-box !important;
    cursor: pointer;
}

.organization-admin .invite-checkbox-list label::before,
.organization-admin .invite-check-chip::before,
.organization-admin .compact-check-chip::before {
    content: "";
    flex: 0 0 14px;
    width: 14px;
    height: 14px;
    border: 1.5px solid #8ca1b4;
    border-radius: 4px;
    background: #fff;
    box-sizing: border-box;
}

.organization-admin .invite-checkbox-list label:has(input[type="checkbox"]:checked),
.organization-admin .invite-check-chip:has(input[type="checkbox"]:checked),
.organization-admin .compact-check-chip:has(input[type="checkbox"]:checked),
.organization-admin .compact-check-chip.is-enabled {
    border-color: #b8d7f2 !important;
    background: #f4f9fd !important;
    color: #0f5ea8 !important;
}

.organization-admin .invite-checkbox-list label:has(input[type="checkbox"]:checked)::before,
.organization-admin .invite-check-chip:has(input[type="checkbox"]:checked)::before,
.organization-admin .compact-check-chip:has(input[type="checkbox"]:checked)::before,
.organization-admin .compact-check-chip.is-enabled::before {
    border-color: #1263ad;
    background: #1263ad;
    box-shadow: inset 0 0 0 3px #1263ad;
}

.organization-admin .invite-checkbox-list label:has(input[type="checkbox"]:checked)::after,
.organization-admin .invite-check-chip:has(input[type="checkbox"]:checked)::after,
.organization-admin .compact-check-chip:has(input[type="checkbox"]:checked)::after,
.organization-admin .compact-check-chip.is-enabled::after {
    content: "";
    position: absolute;
    left: 14px;
    top: 50%;
    width: 6px;
    height: 9px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: translateY(-60%) rotate(45deg);
}

.organization-admin .invite-checkbox-list > div,
.organization-admin .invite-checkbox-list ul {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(120px, 1fr)) !important;
    gap: 8px !important;
}

.organization-admin .invite-module-options {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(180px, 1fr)) !important;
    gap: 8px !important;
}

.permission-summary-list {
    display: grid;
    gap: 12px;
}

.permission-summary-card {
    border: 1px solid #d8e4ee;
    border-radius: 8px;
    padding: 14px;
    background: #fff;
}

.permission-summary-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

.permission-summary-heading strong,
.permission-summary-heading span {
    display: block;
}

.permission-summary-heading span {
    color: #5b6b7c;
    font-weight: 800;
}

.module-summary-form {
    display: grid;
    gap: 12px;
}

.module-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(140px, 1fr));
    gap: 8px;
}

.module-summary-form button {
    justify-self: end;
    min-width: 180px;
}

@media (max-width: 1100px) {
    .organization-admin .invite-checkbox-list > div,
    .organization-admin .invite-checkbox-list ul,
    .organization-admin .invite-module-options,
    .module-summary-grid {
        grid-template-columns: repeat(2, minmax(120px, 1fr)) !important;
    }
}

@media (max-width: 680px) {
    .organization-admin .invite-checkbox-list > div,
    .organization-admin .invite-checkbox-list ul,
    .organization-admin .invite-module-options,
    .module-summary-grid {
        grid-template-columns: 1fr !important;
    }
}

/* 2026-06-29: final alignment for invitation scope and Miguel permission matrix */
.organization-admin .org-invite-panel {
    overflow: hidden;
}

.organization-admin .invite-scope-form.invite-user-form {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: start !important;
}

.organization-admin .invite-scope-main-grid {
    display: grid !important;
    grid-template-columns: minmax(240px, 1.3fr) minmax(150px, .55fr) minmax(220px, .75fr) !important;
    gap: 12px !important;
    width: 100% !important;
}

.organization-admin .invite-scope-grid {
    display: grid !important;
    grid-template-columns: minmax(280px, 360px) minmax(0, 1fr) !important;
    gap: 14px !important;
    width: 100% !important;
    align-items: start !important;
}

.organization-admin .invite-scope-card,
.organization-admin .invite-module-scope-card {
    min-width: 0 !important;
    overflow: hidden !important;
}

.organization-admin .invite-checkbox-list > div,
.organization-admin .invite-checkbox-list ul {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
}

.organization-admin .invite-module-groups {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)) !important;
    gap: 10px !important;
}

.organization-admin .invite-module-options {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)) !important;
    gap: 8px !important;
}

.organization-admin .invite-check-chip,
.organization-admin .invite-checkbox-list label,
.organization-admin .compact-check-chip {
    min-width: 0 !important;
    min-height: 30px !important;
    padding: 6px 8px !important;
    font-size: 12.5px !important;
}

.organization-admin .invite-check-chip span,
.organization-admin .invite-checkbox-list label span,
.organization-admin .compact-check-chip span {
    min-width: 0 !important;
    overflow-wrap: anywhere;
}

.organization-admin .invite-scope-form > button[type="submit"] {
    justify-self: end !important;
    width: min(260px, 100%) !important;
}

.permission-matrix-section {
    overflow: hidden;
}

.permission-matrix-titlebar {
    align-items: flex-start !important;
}

.permission-profile-reference {
    display: grid;
    gap: 6px;
    justify-items: end;
    text-align: right;
    color: #5b6b7c;
    font-size: 12px;
    font-weight: 800;
}

.permission-profile-reference div {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: flex-end;
}

.permission-profile-reference span {
    border: 1px solid #d7e2ed;
    border-radius: 999px;
    padding: 4px 8px;
    background: #fff;
    color: #425364;
    white-space: nowrap;
}

.permission-matrix-toolbar {
    display: grid;
    grid-template-columns: minmax(260px, 420px) auto;
    gap: 12px;
    align-items: end;
    margin-bottom: 14px;
}

.permission-user-search {
    display: grid;
    gap: 6px;
    font-weight: 850;
    color: #17263b;
}

.permission-user-search input {
    min-height: 38px;
    border: 1px solid #d2dde7;
    border-radius: 8px;
    padding: 8px 10px;
    font: inherit;
}

.permission-user-matrix-list {
    display: grid;
    gap: 14px;
}

.permission-user-matrix-card {
    border: 1px solid #d7e2ed;
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
}

.permission-user-matrix-head,
.permission-matrix-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    border-bottom: 1px solid #e2e8ef;
}

.permission-user-matrix-head strong,
.permission-user-matrix-head span {
    display: block;
}

.permission-user-matrix-head strong {
    color: #11233b;
    font-size: 16px;
}

.permission-user-matrix-head span {
    color: #66727f;
    font-size: 12px;
    font-weight: 800;
}

.permission-matrix-actions {
    justify-content: flex-end;
    border-bottom: 0;
    padding-top: 10px;
    padding-bottom: 10px;
}

.permission-matrix-actions label {
    display: grid;
    grid-template-columns: auto minmax(180px, 240px);
    gap: 8px;
    align-items: center;
    color: #5b6b7c;
    font-size: 12px;
    font-weight: 900;
}

.permission-matrix-actions select {
    min-height: 34px;
    border: 1px solid #d2dde7;
    border-radius: 8px;
    padding: 6px 8px;
    font: inherit;
}

.permission-matrix-actions button {
    min-height: 34px;
    padding: 7px 14px;
}

.permission-matrix-scroll {
    width: 100%;
    overflow-x: auto;
    border-top: 1px solid #e2e8ef;
}

.permission-matrix-table {
    width: 100%;
    min-width: 980px;
    border-collapse: collapse;
    table-layout: fixed;
}

.permission-matrix-table th,
.permission-matrix-table td {
    border-bottom: 1px solid #e7edf3;
    padding: 8px 10px;
    vertical-align: middle;
    text-align: center;
}

.permission-matrix-table thead th {
    background: #f8fafc;
    color: #5e6b77;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.permission-matrix-table thead th:first-child,
.permission-matrix-table tbody th {
    width: 260px;
    text-align: left;
}

.permission-matrix-table tbody th {
    color: #17263b;
    font-size: 13px;
    font-weight: 850;
}

.permission-matrix-group-row td {
    background: #fff;
    color: #6a7783;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .09em;
    text-align: left;
    text-transform: uppercase;
}

.matrix-check {
    display: inline-grid;
    place-items: center;
    width: 22px;
    height: 22px;
    cursor: pointer;
}

.matrix-check input {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    opacity: 0 !important;
    overflow: hidden !important;
}

.matrix-check span {
    width: 14px;
    height: 14px;
    border: 1.5px solid #8ca1b4;
    border-radius: 4px;
    background: #fff;
    box-sizing: border-box;
    position: relative;
}

.matrix-check input:checked + span {
    border-color: #1263ad;
    background: #1263ad;
}

.matrix-check input:checked + span::after {
    content: "";
    position: absolute;
    left: 4px;
    top: 1px;
    width: 4px;
    height: 8px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.matrix-full-access,
.matrix-no-access {
    display: inline-flex;
    min-width: 54px;
    justify-content: center;
    border-radius: 999px;
    padding: 3px 7px;
    font-size: 11px;
    font-weight: 900;
}

.matrix-full-access {
    background: #e9f5ef;
    color: #14745f;
}

.matrix-no-access {
    background: #f2f5f7;
    color: #9aa7b3;
}

@media (max-width: 1180px) {
    .organization-admin .invite-scope-main-grid,
    .organization-admin .invite-scope-grid,
    .permission-matrix-toolbar {
        grid-template-columns: 1fr !important;
    }
    .organization-admin .invite-scope-form > button[type="submit"] {
        justify-self: stretch !important;
        width: 100% !important;
    }
    .permission-profile-reference,
    .permission-profile-reference div {
        justify-items: start;
        justify-content: flex-start;
        text-align: left;
    }
}

/* 2026-06-29: user selector and saved profiles for permission matrix */
.permission-profile-reference div {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(120px, 1fr));
    gap: 6px !important;
    min-width: 280px;
}

.permission-profile-reference button {
    min-height: 30px;
    border: 1px solid #d7e2ed;
    border-radius: 999px;
    padding: 5px 10px;
    background: #fff;
    color: #425364;
    font: inherit;
    font-size: 12px;
    font-weight: 850;
    cursor: pointer;
    text-align: center;
}

.permission-profile-reference button.is-active {
    border-color: #1263ad;
    background: #eef6fd;
    color: #0f5ea8;
}

.permission-user-search select {
    min-height: 40px;
    border: 1px solid #d2dde7;
    border-radius: 8px;
    padding: 8px 10px;
    background: #fff;
    color: #17263b;
    font: inherit;
    font-weight: 800;
}

.permission-matrix-actions {
    justify-content: space-between !important;
}

.permission-matrix-actions [data-selected-profile-label] {
    color: #5b6b7c;
    font-size: 12px;
    font-weight: 900;
}

.permission-user-matrix-card[hidden] {
    display: none !important;
}

@media (max-width: 1180px) {
    .permission-profile-reference div {
        grid-template-columns: repeat(2, minmax(110px, 1fr));
        min-width: 0;
    }
}

/* 2026-06-29: isolate invitation layout from permission matrix controls */
.organization-admin .org-invite-panel .invite-scope-form.invite-user-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
    width: 100% !important;
}

.organization-admin .org-invite-panel .invite-scope-main-grid {
    display: grid !important;
    grid-template-columns: minmax(260px, 1fr) minmax(160px, 220px) minmax(220px, 280px) !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: none !important;
}

.organization-admin .org-invite-panel .invite-scope-grid {
    display: grid !important;
    grid-template-columns: minmax(300px, 380px) minmax(0, 1fr) !important;
    gap: 16px !important;
    width: 100% !important;
    max-width: none !important;
    align-items: stretch !important;
    justify-content: stretch !important;
}

.organization-admin .org-invite-panel .invite-scope-card,
.organization-admin .org-invite-panel .invite-module-scope-card {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    overflow: visible !important;
    box-sizing: border-box !important;
}

.organization-admin .org-invite-panel .invite-module-groups {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 10px !important;
    width: 100% !important;
}

.organization-admin .org-invite-panel .invite-module-group {
    min-width: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.organization-admin .org-invite-panel .invite-module-options {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(145px, 1fr)) !important;
    gap: 8px !important;
}

.organization-admin .org-invite-panel .invite-check-chip,
.organization-admin .org-invite-panel .invite-checkbox-list label {
    width: 100% !important;
    max-width: none !important;
    box-sizing: border-box !important;
}

.organization-admin .org-invite-panel .invite-scope-form > button[type="submit"] {
    align-self: flex-end !important;
    width: min(260px, 100%) !important;
}

@media (max-width: 1280px) {
    .organization-admin .org-invite-panel .invite-module-groups {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 980px) {
    .organization-admin .org-invite-panel .invite-scope-main-grid,
    .organization-admin .org-invite-panel .invite-scope-grid,
    .organization-admin .org-invite-panel .invite-module-groups {
        grid-template-columns: 1fr !important;
    }
    .organization-admin .org-invite-panel .invite-scope-form > button[type="submit"] {
        align-self: stretch !important;
        width: 100% !important;
    }
}

/* 2026-06-29: stable single-column invitation scope to avoid clipped module panel */
.organization-admin .org-invite-panel .invite-scope-grid {
    grid-template-columns: 1fr !important;
}

.organization-admin .org-invite-panel .invite-checkbox-list > div,
.organization-admin .org-invite-panel .invite-checkbox-list ul {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)) !important;
}

.organization-admin .org-invite-panel .invite-module-groups {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
}

.organization-admin .org-invite-panel .invite-scope-card-heading,
.organization-admin .org-invite-panel .invite-module-group,
.organization-admin .org-invite-panel .invite-module-options {
    max-width: 100% !important;
}

/* 2026-06-29: permission summary toolbar as two aligned columns */
.permission-matrix-titlebar {
    min-height: auto !important;
}

.permission-matrix-toolbar.permission-matrix-toolbar-split {
    display: grid !important;
    grid-template-columns: minmax(320px, 1fr) minmax(320px, 520px) !important;
    gap: 18px !important;
    align-items: start !important;
    margin: 0 0 14px !important;
    padding: 14px 0 !important;
    border-top: 1px solid #e0e6ed;
}

.permission-user-select-panel {
    display: grid;
    gap: 8px;
    align-content: start;
}

.permission-user-select-panel > span {
    color: #5b6b7c;
    font-size: 12px;
    font-weight: 850;
}

.permission-matrix-toolbar-split .permission-user-search {
    max-width: 520px;
}

.permission-matrix-toolbar-split .permission-user-search select {
    width: 100%;
}

.permission-matrix-toolbar-split .permission-profile-reference {
    justify-items: end !important;
    align-self: start;
    text-align: right !important;
}

.permission-matrix-toolbar-split .permission-profile-reference div {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(140px, 1fr)) !important;
    gap: 8px !important;
    width: 100%;
    max-width: 500px;
    min-width: 0 !important;
}

.permission-matrix-toolbar-split .permission-profile-reference button {
    width: 100%;
}

@media (max-width: 1100px) {
    .permission-matrix-toolbar.permission-matrix-toolbar-split {
        grid-template-columns: 1fr !important;
    }
    .permission-matrix-toolbar-split .permission-profile-reference {
        justify-items: start !important;
        text-align: left !important;
    }
}

.manual-expiration-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 14px;
}

.manual-expiration-tabs a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 38px;
    padding: 8px 12px;
    border: 1px solid #dbe6ef;
    border-radius: 8px;
    color: #1c2b3a;
    background: #fff;
    text-decoration: none;
    font-weight: 800;
}

.manual-expiration-tabs a span {
    min-width: 24px;
    padding: 2px 7px;
    border-radius: 999px;
    background: #eef3f7;
    color: #506174;
    text-align: center;
    font-size: 0.82rem;
}

.manual-expiration-tabs a.active,
.manual-expiration-tabs a:hover {
    border-color: #0f7f72;
    color: #0f7f72;
    background: #f2fbf9;
}

.attention {
    display: inline-flex;
    align-items: center;
    margin-left: 8px;
    padding: 2px 8px;
    border-radius: 999px;
    border: 1px solid #fde68a;
    background: #fffbeb;
    color: #92400e;
    font-size: 0.74rem;
    font-weight: 900;
    text-transform: uppercase;
}

.attention.attention-danger {
    border-color: #fecaca;
    background: #fff1f2;
    color: #b42318;
}

.dashboard-2-expiration-item.is-overdue .dashboard-2-expiration-date {
    background: #fff1f2;
    color: #b42318;
}


.dashboard-2-user-actions { display: flex; align-items: stretch; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.dashboard-2-quick-task-open { border: 0; border-radius: 8px; background: #0f2b55; color: #fff; padding: 0 18px; min-height: 58px; font-weight: 800; cursor: pointer; box-shadow: none; }
.dashboard-2-quick-task-open:hover { background: #0b5dab; }
.dashboard-2-dialog { width: min(880px, calc(100vw - 32px)); border: 0; border-radius: 12px; padding: 0; box-shadow: 0 24px 70px rgba(13, 31, 51, 0.22); }
.dashboard-2-dialog::backdrop { background: rgba(13, 31, 51, 0.45); }
.dashboard-2-dialog-card { padding: 0; background: #fff; }
.dashboard-2-dialog-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding: 22px 24px; border-bottom: 1px solid #d8e2ea; }
.dashboard-2-dialog-head h2 { margin: 0; color: #172033; }
.dashboard-2-dialog-head small { color: #64748b; }
.dashboard-2-dialog-head button { width: 40px; height: 40px; border-radius: 999px; border: 1px solid #cfe0f1; background: #fff; color: #102033; font-size: 1.4rem; font-weight: 800; cursor: pointer; }
.dashboard-2-quick-task-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; padding: 22px 24px; }
.dashboard-2-quick-task-grid label { display: grid; gap: 6px; color: #172033; font-weight: 800; }
.dashboard-2-quick-task-grid input, .dashboard-2-quick-task-grid select, .dashboard-2-quick-task-grid textarea { width: 100%; border: 1px solid #cfdbe6; border-radius: 8px; padding: 12px; font: inherit; font-weight: 500; color: #172033; background: #fff; }
.dashboard-2-quick-task-grid input::placeholder, .dashboard-2-quick-task-grid textarea::placeholder { font-weight: 500; color: #94a3b8; }
.dashboard-2-quick-task-wide { grid-column: 1 / -1; }
.dashboard-2-dialog-actions { display: flex; justify-content: flex-end; gap: 10px; padding: 0 24px 24px; }
.dashboard-2-task.is-critical { border-color: #f2afa8; background: #fffafa; box-shadow: inset 4px 0 0 #b42318; }
.dashboard-2-task.is-critical .dashboard-2-task-title strong { color: #7f1d1d; }
.dashboard-2-task-date em { margin-top: 2px; font-size: 0.68rem; font-style: normal; font-weight: 800; color: inherit; }
@media (max-width: 720px) {
    .dashboard-2-user-actions { width: 100%; justify-content: stretch; }
    .dashboard-2-quick-task-open { width: 100%; min-height: 48px; }
    .dashboard-2-quick-task-grid { grid-template-columns: 1fr; padding: 18px; }
    .dashboard-2-dialog-actions { padding: 0 18px 18px; flex-direction: column; }
}

.status-pill.status-overdue {
    background: #fff1f2;
    color: #b42318;
    border-color: #fecaca;
}

/* Dashboard 2.0 compact header: user context already lives in the global bar. */
.dashboard-2-page .dashboard-2-header {
    align-items: center;
    min-height: 0;
    padding: 4px 0 14px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.dashboard-2-page .dashboard-2-header > div:first-child {
    min-width: 0;
}

.dashboard-2-page .dashboard-2-header h1 {
    font-size: clamp(2rem, 3vw, 3rem);
    line-height: 1;
}

.dashboard-2-page .dashboard-2-header .advanced-heading-copy {
    max-width: 980px;
    margin-top: 8px;
}

.dashboard-2-page .dashboard-2-user-actions {
    flex: 0 0 auto;
    align-items: center;
    justify-content: flex-end;
}

.dashboard-2-page .dashboard-2-quick-task-open {
    min-height: 52px;
    padding: 0 28px;
    white-space: nowrap;
}

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

    .dashboard-2-page .dashboard-2-user-actions {
        width: 100%;
        justify-content: flex-start;
    }
}

@media (max-width: 720px) {
    .dashboard-2-page .dashboard-2-quick-task-open {
        width: 100%;
    }
}

.project-task-dialog {
    width: min(720px, calc(100vw - 28px));
    border: 0;
    border-radius: 8px;
    padding: 0;
    background: transparent;
}

.project-task-dialog::backdrop {
    background: rgba(15, 23, 42, 0.48);
}

.project-task-dialog-card {
    display: grid;
    gap: 16px;
    margin: 0;
    padding: 20px;
    border: 1px solid #dbe6ef;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.28);
}

.project-task-dialog-head,
.project-task-dialog-actions {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.project-task-dialog-head h2 {
    margin: 0;
    color: #17223b;
    font-size: 1.25rem;
}

.project-task-dialog-close {
    display: inline-grid;
    place-items: center;
    width: 34px;
    height: 34px;
    min-height: 34px;
    border: 1px solid #dbe6ef;
    border-radius: 8px;
    background: #f8fbff;
    color: #17223b;
    font-size: 1.3rem;
    line-height: 1;
    cursor: pointer;
}

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

.project-task-dialog-grid label {
    display: grid;
    gap: 6px;
    color: #52616b;
    font-size: 0.78rem;
    font-weight: 900;
}

.project-task-dialog-wide {
    grid-column: 1 / -1;
}

.project-task-dialog-grid input,
.project-task-dialog-grid select,
.project-task-dialog-grid textarea {
    width: 100%;
    border: 1px solid #d8e1ec;
    border-radius: 8px;
    padding: 9px 10px;
    color: #17223b;
    background: #ffffff;
    font: inherit;
    font-size: 0.92rem;
    font-weight: 500;
}

.project-task-dialog-grid input::placeholder,
.project-task-dialog-grid textarea::placeholder {
    font-weight: 500;
    color: #94a3b8;
}

.project-task-dialog-grid textarea {
    resize: vertical;
}

.project-task-dialog-actions {
    align-items: center;
}

.project-task-dialog-actions span {
    min-height: 20px;
    color: #52616b;
    font-weight: 800;
}

@media (max-width: 760px) {
    .project-task-dialog-grid {
        grid-template-columns: 1fr;
    }
}

.project-priority-picker {
    position: relative;
    justify-self: center;
}

.project-priority-picker summary {
    display: inline-grid;
    place-items: center;
    width: 28px;
    height: 28px;
    min-height: 28px;
    padding: 0;
    border: 1px solid #cbd5e1;
    border-radius: 999px;
    background: #f8fbff;
    cursor: pointer;
    list-style: none;
}

.project-priority-picker summary::-webkit-details-marker {
    display: none;
}

.project-priority-check {
    color: #ffffff !important;
    font-size: 0.88rem !important;
    font-weight: 950 !important;
    line-height: 1;
}

.project-priority-dot {
    display: none;
}

.project-priority-picker.priority-low summary {
    background: #e8f7ef;
    border-color: #86cfa1;
}

.project-priority-picker.priority-low .project-priority-check {
    color: #15803d !important;
}

.project-priority-picker.priority-medium summary {
    background: #eef6ff;
    border-color: #9bc3eb;
}

.project-priority-picker.priority-medium .project-priority-check {
    color: #1d4f91 !important;
}

.project-priority-picker.priority-high summary {
    background: #fff7e6;
    border-color: #f4bf6a;
}

.project-priority-picker.priority-high .project-priority-check {
    color: #b45309 !important;
}

.project-priority-picker.priority-critical summary {
    background: #fff1f2;
    border-color: #f2afa8;
}

.project-priority-picker.priority-critical .project-priority-check {
    color: #b42318 !important;
}

.project-priority-picker[open] summary {
    box-shadow: 0 0 0 3px rgba(143, 188, 234, 0.18);
}

.project-priority-options {
    position: absolute;
    z-index: 30;
    top: calc(100% + 7px);
    left: 50%;
    display: grid;
    gap: 4px;
    width: 142px;
    padding: 7px;
    border: 1px solid #d8e1ec;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 16px 36px rgba(15, 23, 42, 0.16);
    transform: translateX(-50%);
}

.project-task-priority-option {
    display: flex;
    align-items: center;
    gap: 7px;
    width: 100%;
    min-height: 30px;
    padding: 5px 7px;
    border: 1px solid transparent;
    border-radius: 7px;
    background: #ffffff;
    color: #17223b;
    cursor: pointer;
    font: inherit;
    font-size: 0.82rem;
    font-weight: 850;
    text-align: left;
}

.project-task-priority-option span {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: #94a3b8;
}

.project-task-priority-option.priority-low span { background: #16a34a; }
.project-task-priority-option.priority-medium span { background: #1d4f91; }
.project-task-priority-option.priority-high span { background: #d97706; }
.project-task-priority-option.priority-critical span { background: #b42318; }

.project-task-priority-option:hover,
.project-task-priority-option.is-active {
    border-color: #cbd5e1;
    background: #f8fafc;
}

.project-task-priority-input[type="hidden"] {
    display: none;
}


.project-task-status-inline,
.project-task-status-badge {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    border: 1px solid #d7e0ea;
    border-radius: 999px;
    background: #f4f7fb;
    color: #536274;
    font-size: 0.76rem;
    font-weight: 800;
    line-height: 1;
    padding: 0.32rem 0.55rem;
    margin-top: 0.35rem;
}

.project-task-followup {
    border-top: 1px solid #e5edf5;
    margin-top: 1rem;
    padding-top: 1rem;
}

.project-task-followup-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.8rem;
}

.project-task-followup-head h3 {
    margin: 0;
    color: #15213a;
    font-size: 1rem;
}

.project-task-followup-head span {
    color: #6a7890;
    font-size: 0.82rem;
    font-weight: 700;
}

.project-task-activity-list {
    display: grid;
    gap: 0.65rem;
    max-height: 220px;
    overflow: auto;
    border: 1px solid #e1e9f2;
    border-radius: 10px;
    background: #f8fbff;
    padding: 0.75rem;
    margin-bottom: 0.9rem;
}

.project-task-activity-item {
    border: 1px solid #dbe6f0;
    border-radius: 8px;
    background: #ffffff;
    padding: 0.7rem 0.8rem;
}

.project-task-activity-item strong {
    display: block;
    color: #12264a;
    font-size: 0.88rem;
}

.project-task-activity-item span {
    display: block;
    color: #6a7890;
    font-size: 0.78rem;
    margin-top: 0.15rem;
}

.project-task-activity-item p {
    color: #25364f;
    margin: 0.45rem 0 0;
    white-space: normal;
}

.project-task-activity-item a {
    display: inline-flex;
    margin-top: 0.45rem;
    color: #0f766e;
    font-weight: 800;
}

.project-task-activity-empty {
    margin: 0;
    color: #738199;
    font-weight: 700;
}

.project-task-evidence-input input[type="file"] {
    border: 1px solid #d7e0ea;
    border-radius: 8px;
    padding: 0.75rem;
    background: #fff;
}

.project-task-workflow-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-top: 0.8rem;
}



.dashboard-2-recurrence-box {
    display: grid;
    grid-template-columns: minmax(260px, 1.15fr) minmax(260px, 1fr) minmax(170px, 0.7fr);
    align-items: end;
    gap: 8px 12px;
    padding: 10px 12px;
    border: 1px solid #dfe6ef;
    border-radius: 8px;
    background: #f8fbff;
}
.dashboard-2-recurrence-box > span {
    grid-column: 1 / -1;
    color: #172033;
    font-size: 0.86rem;
    font-weight: 850;
}
.dashboard-2-recurrence-modes,
.dashboard-2-weekday-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
}
.dashboard-2-recurrence-modes label,
.dashboard-2-weekday-row label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    min-height: 26px;
    padding: 4px 8px;
    border: 1px solid #d8e1ec;
    border-radius: 999px;
    background: #ffffff;
    color: #405066;
    font-size: 0.76rem;
    font-weight: 800;
    line-height: 1.1;
    white-space: nowrap;
}
.dashboard-2-weekday-row label {
    min-width: 32px;
    padding-inline: 7px;
}
.dashboard-2-recurrence-box input[type="radio"],
.dashboard-2-recurrence-box input[type="checkbox"] {
    flex: 0 0 14px;
    width: 14px !important;
    height: 14px !important;
    min-width: 14px !important;
    min-height: 14px !important;
    margin: 0 !important;
    padding: 0 !important;
    transform: none !important;
    accent-color: #1478e8;
}
.dashboard-2-recurrence-box input[type="checkbox"] {
    border-radius: 4px;
}
.dashboard-2-recurrence-end {
    display: grid;
    gap: 4px;
    max-width: none;
    color: #172033;
    font-size: 0.8rem;
    font-weight: 800;
}
.dashboard-2-recurrence-end input {
    width: 100%;
    min-height: 34px;
    padding: 5px 8px;
    border: 1px solid #d8e1ec;
    border-radius: 8px;
    font-size: 0.86rem;
}
.dashboard-2-recurrence-box small {
    grid-column: 1 / -1;
    color: #64748b;
    font-size: 0.74rem;
    font-weight: 700;
}
@media (max-width: 980px) {
    .dashboard-2-recurrence-box {
        grid-template-columns: 1fr;
    }
}


/* Dashboard 2.0 work queue: To Do style filters and color-coded counters. */
.dashboard-2-work-metrics {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 8px;
    margin: 10px 0 12px;
}
.dashboard-2-work-metric {
    min-height: 72px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #ffffff;
    padding: 10px 12px;
    appearance: none;
    cursor: pointer;
    font: inherit;
    text-align: left;
    transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease, background 0.16s ease;
}
.dashboard-2-work-metric:hover {
    border-color: #a9c6e6;
    box-shadow: 0 8px 18px rgba(15, 46, 89, 0.08);
    transform: translateY(-1px);
}
.dashboard-2-work-metric.is-active {
    border-color: #123a6f;
    background: #f8fbff;
    box-shadow: inset 0 0 0 2px #123a6f;
}
.dashboard-2-work-metric:focus-visible {
    outline: 3px solid rgba(15, 94, 168, 0.28);
    outline-offset: 2px;
}
.dashboard-2-work-metric strong {
    display: block;
    font-size: 1.75rem;
    line-height: 1;
    font-weight: 900;
    color: #405066;
}
.dashboard-2-work-metric span {
    display: block;
    margin-top: 7px;
    color: #64748b;
    font-size: 0.76rem;
    font-weight: 850;
    text-transform: uppercase;
}
.dashboard-2-work-metric.is-pending strong { color: #0f5ea8; }
.dashboard-2-work-metric.is-progress strong { color: #2563eb; }
.dashboard-2-work-metric.is-review strong { color: #7c3aed; }
.dashboard-2-work-metric.is-returned strong { color: #c2410c; }
.dashboard-2-work-metric.is-critical strong { color: #b42318; }
.dashboard-2-work-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin-bottom: 10px;
}
.dashboard-2-work-tab {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 32px;
    border: 1px solid #dce6ee;
    border-radius: 999px;
    background: #ffffff;
    color: #405066;
    font: inherit;
    font-size: 0.78rem;
    font-weight: 850;
    padding: 5px 10px;
    cursor: pointer;
}
.dashboard-2-work-tab strong {
    display: inline-grid;
    place-items: center;
    min-width: 22px;
    height: 22px;
    border-radius: 999px;
    background: #eef3f8;
    color: #405066;
    font-size: 0.72rem;
}
.dashboard-2-work-tab.is-active {
    border-color: #15335f;
    background: #15335f;
    color: #ffffff;
}
.dashboard-2-work-tab.is-active strong {
    background: #ffffff;
    color: #15335f;
}
.dashboard-2-work-tab.is-overdue strong,
.dashboard-2-work-tab.is-critical strong { color: #b42318; }
.dashboard-2-work-tab.is-review strong { color: #7c3aed; }
.dashboard-2-work-tab.is-returned strong { color: #c2410c; }
.dashboard-2-work-tab.is-week strong,
.dashboard-2-work-tab.is-today strong { color: #0f5ea8; }
.dashboard-2-worklist-subtle .dashboard-2-work-task {
    position: relative;
    grid-template-columns: 24px 48px minmax(0, 1fr) auto;
    align-items: center;
    border-left: 4px solid #d7e0ea;
}
.dashboard-2-work-task.priority-critical { border-left-color: #b42318; }
.dashboard-2-work-task.priority-high { border-left-color: #e15f22; }
.dashboard-2-work-task.priority-medium { border-left-color: #0f5ea8; }
.dashboard-2-work-task.priority-low { border-left-color: #15803d; }
.dashboard-2-work-task.is-overdue {
    background: #fffafa;
    border-color: #f0c8c4;
    border-left-color: #b42318;
}
.dashboard-2-task-check {
    width: 18px;
    height: 18px;
    border: 2px solid #91a1b5;
    border-radius: 50%;
    background: #ffffff;
}
.dashboard-2-work-task.priority-critical .dashboard-2-task-check { border-color: #b42318; }
.dashboard-2-work-task.priority-high .dashboard-2-task-check { border-color: #e15f22; }
.dashboard-2-work-task.priority-medium .dashboard-2-task-check { border-color: #0f5ea8; }
.dashboard-2-work-task.priority-low .dashboard-2-task-check { border-color: #15803d; }
.dashboard-2-work-task-body {
    min-width: 0;
}
.dashboard-2-work-status {
    justify-self: end;
    align-self: center;
    border: 1px solid #dce6ee;
    border-radius: 999px;
    background: #f8fafc;
    color: #405066;
    font-size: 0.72rem;
    font-weight: 850;
    line-height: 1;
    padding: 7px 9px;
    white-space: nowrap;
}
.dashboard-2-work-status.is-review {
    border-color: #ddd1fe;
    background: #f5f0ff;
    color: #6d28d9;
}
.dashboard-2-work-status.is-returned {
    border-color: #fed7aa;
    background: #fff7ed;
    color: #c2410c;
}
.dashboard-2-work-status.is-progress {
    border-color: #bfdbfe;
    background: #eff6ff;
    color: #1d4ed8;
}
.dashboard-2-work-status.is-blocked,
.dashboard-2-work-task.is-overdue .dashboard-2-work-status {
    border-color: #fecaca;
    background: #fef2f2;
    color: #b42318;
}
.dashboard-2-work-filter-empty {
    margin-top: 6px;
}
@media (max-width: 980px) {
    .dashboard-2-work-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .dashboard-2-worklist-subtle .dashboard-2-work-task {
        grid-template-columns: 22px 48px minmax(0, 1fr);
    }
    .dashboard-2-work-status {
        grid-column: 3;
        justify-self: start;
        margin-top: 4px;
    }
}


.project-task-dialog .button-link.is-disabled,
.project-task-dialog .button-link:disabled {
    opacity: 0.48;
    cursor: not-allowed;
    filter: grayscale(0.25);
}

.project-task-evidence-input {
    border: 1px dashed #b9c8d8;
    border-radius: 10px;
    background: #f8fbff;
    padding: 0.85rem;
    cursor: pointer;
    transition: border-color 0.16s ease, background 0.16s ease, box-shadow 0.16s ease;
}

.project-task-evidence-input:hover,
.project-task-evidence-input.is-dragging {
    border-color: #0f766e;
    background: #f1fbf8;
    box-shadow: 0 0 0 3px rgba(15, 118, 110, 0.1);
}

.project-task-evidence-input strong {
    display: block;
    color: #15213a;
    font-size: 0.9rem;
    margin-top: 0.2rem;
}

.project-task-evidence-input small {
    display: block;
    color: #64748b;
    margin-top: 0.2rem;
    font-weight: 700;
}

.project-task-evidence-input input[type="file"] {
    width: 100%;
    margin-top: 0.65rem;
}


.project-task-retro-box {
    border: 1px dashed #b9c8d8;
    border-radius: 10px;
    background: #f8fbff;
    padding: 0.85rem;
    transition: border-color 0.16s ease, background 0.16s ease, box-shadow 0.16s ease;
}

.project-task-retro-box:hover,
.project-task-retro-box.is-dragging,
.project-task-retro-box.has-pasted-evidence {
    border-color: #0f766e;
    background: #f1fbf8;
    box-shadow: 0 0 0 3px rgba(15, 118, 110, 0.1);
}

.project-task-retro-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.65rem;
}

.project-task-retro-head span {
    color: #15213a;
    font-weight: 850;
}

.project-task-camera-button {
    display: inline-grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border: 1px solid #cdd9e5;
    border-radius: 8px;
    background: #ffffff;
    color: #0f5ea8;
    cursor: pointer;
}

.project-task-camera-button:hover,
.project-task-camera-button:focus-visible {
    border-color: #0f766e;
    color: #0f766e;
    outline: 0;
}

.project-task-retro-editor {
    min-height: 96px;
    border: 1px solid #d7e0ea;
    border-radius: 8px;
    background: #ffffff;
    color: #172033;
    padding: 0.8rem;
    line-height: 1.45;
    outline: none;
    white-space: pre-wrap;
}

.project-task-retro-editor:focus {
    border-color: #86b7e6;
    box-shadow: 0 0 0 3px rgba(15, 94, 168, 0.12);
}

.project-task-retro-editor:empty::before {
    content: attr(data-placeholder);
    color: #8290a3;
}

.project-task-evidence-chips {
    min-height: 28px;
    margin-top: 0.65rem;
    border-radius: 8px;
    background: #eef6ff;
    color: #405066;
    font-size: 0.8rem;
    font-weight: 800;
    padding: 0.45rem 0.6rem;
    overflow-wrap: anywhere;
}


.sgsi-topbar-left {
    display: flex;
    align-items: center;
    gap: 10px;
}

.sgsi-notification-bell {
    position: relative;
}

.sgsi-notification-bell summary {
    position: relative;
    display: inline-grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border: 1px solid #d3dfe8;
    border-radius: 8px;
    background: #f8fbfd;
    color: #10284f;
    cursor: pointer;
    list-style: none;
}

.sgsi-notification-bell summary::-webkit-details-marker {
    display: none;
}

.sgsi-notification-bell summary:hover,
.sgsi-notification-bell[open] summary {
    border-color: #9fb8cf;
    background: #eef6ff;
}

.sgsi-notification-bell strong {
    position: absolute;
    top: -7px;
    right: -7px;
    display: inline-grid;
    min-width: 20px;
    height: 20px;
    place-items: center;
    border: 2px solid #ffffff;
    border-radius: 999px;
    background: #b42318;
    color: #ffffff;
    font-size: 0.68rem;
    line-height: 1;
    padding: 0 4px;
}

.sgsi-notification-bell.has-new summary {
    animation: sgsiBellPulse 1s ease-in-out 3;
}

@keyframes sgsiBellPulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(180, 35, 24, 0); }
    45% { box-shadow: 0 0 0 6px rgba(180, 35, 24, 0.16); }
}

.sgsi-notification-panel {
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    z-index: 45;
    width: min(360px, calc(100vw - 32px));
    border: 1px solid #d8e2ea;
    border-radius: 10px;
    background: #ffffff;
    box-shadow: 0 18px 38px rgba(15, 23, 42, 0.14);
    padding: 10px;
}

.sgsi-notification-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    padding: 4px 4px 10px;
}

.sgsi-notification-head span {
    color: #10284f;
    font-size: 0.9rem;
    font-weight: 900;
}

.sgsi-notification-head a {
    color: #0f766e;
    font-size: 0.78rem;
    font-weight: 850;
    text-decoration: none;
}

.sgsi-notification-item {
    display: grid;
    gap: 3px;
    border-left: 4px solid #d7e0ea;
    border-radius: 8px;
    color: inherit;
    padding: 9px 10px;
    text-decoration: none;
}

.sgsi-notification-item:hover {
    background: #f8fbfd;
}

.sgsi-notification-item.priority-critical { border-left-color: #b42318; }
.sgsi-notification-item.priority-high { border-left-color: #e15f22; }
.sgsi-notification-item.priority-medium { border-left-color: #0f5ea8; }
.sgsi-notification-item.priority-low { border-left-color: #15803d; }

.sgsi-notification-item strong {
    position: static;
    display: block;
    min-width: 0;
    height: auto;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: #172033;
    font-size: 0.86rem;
    line-height: 1.25;
    padding: 0;
}

.sgsi-notification-item span,
.sgsi-notification-item small {
    color: #64748b;
    font-size: 0.76rem;
    font-weight: 750;
}

.sgsi-notification-empty {
    margin: 0;
    border-radius: 8px;
    background: #f8fafc;
    color: #64748b;
    padding: 12px;
    font-weight: 750;
}

/* Mobile sidebar and compact responsive shell - 2026-07-02 */
.sgsi-sidebar-backdrop {
    display: none;
}

@media (min-width: 981px) {
    .sgsi-sidebar-backdrop {
        display: none !important;
    }
}

@media (max-width: 980px) {
    body.sgsi-sidebar-layout {
        width: auto !important;
        min-height: 100vh !important;
        overflow-x: hidden !important;
        font-size: 86% !important;
    }

    body.sgsi-sidebar-layout .sgsi-app-shell {
        display: block !important;
        grid-template-columns: 1fr !important;
        width: 100% !important;
        min-height: 100vh !important;
        overflow-x: hidden !important;
    }

    body.sgsi-sidebar-layout .sgsi-sidebar {
        position: fixed !important;
        inset: 0 auto 0 0 !important;
        width: min(84vw, 292px) !important;
        max-width: 292px !important;
        height: 100dvh !important;
        z-index: 1000 !important;
        transform: translateX(-106%) !important;
        transition: transform 0.18s ease !important;
        overflow-y: auto !important;
        overscroll-behavior: contain !important;
        background: #ffffff !important;
        border-right: 1px solid #c7d9e8 !important;
        box-shadow: 12px 0 36px rgba(13, 31, 51, 0.18) !important;
    }

    body.sgsi-sidebar-open .sgsi-sidebar {
        transform: translateX(0) !important;
    }

    body.sgsi-sidebar-layout .sgsi-sidebar-backdrop {
        position: fixed;
        inset: 0;
        z-index: 990;
        display: block;
        border: 0;
        background: rgba(13, 31, 51, 0.34);
        backdrop-filter: blur(1px);
        padding: 0;
    }

    body.sgsi-sidebar-layout .sgsi-sidebar-backdrop[hidden] {
        display: none !important;
    }

    body.sgsi-sidebar-layout .sgsi-content-shell,
    body.sgsi-sidebar-layout .sgsi-main-content {
        width: 100% !important;
        min-width: 0 !important;
        overflow-x: hidden !important;
    }

    body.sgsi-sidebar-layout .sgsi-topbar {
        position: sticky !important;
        top: 0 !important;
        z-index: 900 !important;
        min-height: 50px !important;
        padding: 8px 10px !important;
        gap: 8px !important;
        background: rgba(255, 255, 255, 0.96) !important;
    }

    body.sgsi-sidebar-layout .sgsi-topbar-left {
        flex: 0 0 auto !important;
        gap: 6px !important;
    }

    body.sgsi-sidebar-layout .sgsi-mobile-toggle,
    body.sgsi-sidebar-layout .sgsi-notification-bell summary {
        width: 34px !important;
        min-width: 34px !important;
        height: 34px !important;
        min-height: 34px !important;
    }

    body.sgsi-sidebar-layout .sgsi-topbar-actions {
        min-width: 0 !important;
        flex: 1 1 auto !important;
        margin-left: 0 !important;
        justify-content: flex-end !important;
        gap: 6px !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: none !important;
    }

    body.sgsi-sidebar-layout .sgsi-topbar-actions::-webkit-scrollbar {
        display: none;
    }

    body.sgsi-sidebar-layout .sgsi-top-menu {
        flex: 0 0 auto !important;
    }

    body.sgsi-sidebar-layout .sgsi-top-menu summary {
        min-width: 126px !important;
        min-height: 40px !important;
        padding: 6px 9px !important;
    }

    body.sgsi-sidebar-layout .sgsi-top-menu summary span {
        font-size: 0.58rem !important;
    }

    body.sgsi-sidebar-layout .sgsi-top-menu summary strong {
        max-width: 150px !important;
        overflow: hidden !important;
        font-size: 0.82rem !important;
        line-height: 1.12 !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    body.sgsi-sidebar-layout .sgsi-top-menu-panel {
        position: fixed !important;
        top: 52px !important;
        right: 10px !important;
        width: min(320px, calc(100vw - 20px)) !important;
        max-height: calc(100dvh - 70px) !important;
        overflow-y: auto !important;
    }

    body.sgsi-sidebar-layout .dashboard,
    body.sgsi-sidebar-layout .advanced-dashboard,
    body.sgsi-sidebar-layout .treatment-dashboard,
    body.sgsi-sidebar-layout .control-center-page,
    body.sgsi-sidebar-layout .asset-dashboard,
    body.sgsi-sidebar-layout .project-dashboard,
    body.sgsi-sidebar-layout .records-dashboard,
    body.sgsi-sidebar-layout .document-library-page,
    body.sgsi-sidebar-layout .dashboard-page {
        width: 100% !important;
        max-width: 100% !important;
        padding: 10px 10px 20px !important;
        overflow-x: hidden !important;
    }

    body.sgsi-sidebar-layout .page-heading,
    body.sgsi-sidebar-layout .advanced-dashboard > .page-heading,
    body.sgsi-sidebar-layout .treatment-dashboard > .page-heading,
    body.sgsi-sidebar-layout .dashboard-2-header {
        grid-template-columns: 1fr !important;
        gap: 8px !important;
        margin-bottom: 10px !important;
        padding: 4px 0 8px !important;
    }

    body.sgsi-sidebar-layout .page-heading h1,
    body.sgsi-sidebar-layout .advanced-dashboard > .page-heading h1,
    body.sgsi-sidebar-layout .treatment-dashboard > .page-heading h1,
    body.sgsi-sidebar-layout .dashboard-2-header h1 {
        font-size: clamp(1.7rem, 9vw, 2.55rem) !important;
        line-height: 1.04 !important;
    }

    body.sgsi-sidebar-layout .page-heading p,
    body.sgsi-sidebar-layout .advanced-heading-copy,
    body.sgsi-sidebar-layout .dashboard-2-header .advanced-heading-copy {
        font-size: 0.9rem !important;
        line-height: 1.28 !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-shell,
    body.sgsi-sidebar-layout .dashboard-2-page {
        gap: 10px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-user-actions {
        justify-content: stretch !important;
        width: 100% !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-quick-task-open {
        width: 100% !important;
        min-height: 42px !important;
        padding: 8px 12px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-company-strip {
        display: grid !important;
        gap: 8px !important;
        padding: 10px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-company-strip > div {
        display: flex !important;
        gap: 6px !important;
        width: 100% !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-company {
        flex: 0 0 auto !important;
        padding: 7px 11px !important;
        white-space: nowrap !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-focus-strip,
    body.sgsi-sidebar-layout .dashboard-2-module-progress-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 8px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-focus-card {
        min-height: 78px !important;
        padding: 9px !important;
        grid-template-columns: 48px minmax(0, 1fr) !important;
        gap: 8px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-ring {
        width: 48px !important;
        height: 48px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-ring strong {
        font-size: 1rem !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-main-grid,
    body.sgsi-sidebar-layout .dashboard-2-main-grid-three,
    body.sgsi-sidebar-layout .dashboard-2-secondary-grid {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-panel {
        padding: 12px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-task,
    body.sgsi-sidebar-layout .dashboard-2-worklist-subtle .dashboard-2-task,
    body.sgsi-sidebar-layout .dashboard-2-worklist-subtle .dashboard-2-work-task {
        padding: 9px !important;
        gap: 9px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-task-date,
    body.sgsi-sidebar-layout .dashboard-2-expiration-date {
        width: 50px !important;
        min-width: 50px !important;
        height: 50px !important;
        border-radius: 8px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-task-date strong,
    body.sgsi-sidebar-layout .dashboard-2-expiration-date strong {
        font-size: 1rem !important;
    }
}

@media (max-width: 560px) {
    body.sgsi-sidebar-layout .sgsi-topbar-actions {
        max-width: calc(100vw - 48px) !important;
    }

    body.sgsi-sidebar-layout .sgsi-top-menu summary {
        min-width: 116px !important;
    }

    body.sgsi-sidebar-layout .sgsi-user-menu summary {
        min-width: 150px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-focus-strip,
    body.sgsi-sidebar-layout .dashboard-2-module-progress-grid {
        grid-template-columns: 1fr !important;
    }
}


/* Quick task optional time shortcuts - 2026-07-02 */
.dashboard-2-time-field > small {
    display: inline-flex;
    width: fit-content;
    margin-left: 6px;
    padding: 2px 8px;
    border-radius: 999px;
    background: #edf3f8;
    color: #5c6d7b;
    font-size: .78rem;
    font-weight: 800;
    vertical-align: middle;
}
.dashboard-2-time-shortcuts {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 2px;
}
.dashboard-2-time-shortcuts button {
    border: 1px solid #cfdbe6;
    border-radius: 999px;
    background: #fff;
    color: #0b5dab;
    min-height: 32px;
    padding: 0 12px;
    font: inherit;
    font-size: .86rem;
    font-weight: 800;
    cursor: pointer;
}
.dashboard-2-time-shortcuts button:hover,
.dashboard-2-time-shortcuts button:focus-visible {
    border-color: #0b5dab;
    background: #eef6ff;
    outline: none;
}
@media (max-width: 560px) {
    .dashboard-2-time-shortcuts button { flex: 1 1 auto; }
}

/* Dashboard 2.0 operational rail layout - 2026-07-02 */
.dashboard-2-left-column .dashboard-2-rail-modules {
    overflow: visible;
}
.dashboard-2-left-column .dashboard-2-rail-modules .dashboard-2-module-progress-grid {
    grid-template-columns: 1fr;
    gap: 10px;
}
.dashboard-2-left-column .dashboard-2-rail-modules .dashboard-2-module-card {
    grid-template-columns: 58px minmax(0, 1fr);
    min-height: 104px;
    padding: 12px;
    align-items: center;
}
.dashboard-2-left-column .dashboard-2-rail-modules .dashboard-2-module-ring {
    width: 54px;
    height: 54px;
}
.dashboard-2-left-column .dashboard-2-rail-modules .dashboard-2-module-ring strong {
    font-size: 0.82rem;
}
.dashboard-2-left-column .dashboard-2-rail-modules .dashboard-2-module-title {
    align-items: center;
}
.dashboard-2-left-column .dashboard-2-rail-modules .dashboard-2-module-title strong {
    font-size: 0.88rem;
}
.dashboard-2-left-column .dashboard-2-rail-modules .dashboard-2-module-title span {
    font-size: 0.68rem;
    padding: 2px 6px;
}
.dashboard-2-left-column .dashboard-2-rail-modules .dashboard-2-module-card small {
    margin-top: 4px;
    font-size: 0.76rem;
}
.dashboard-2-left-column .dashboard-2-rail-modules .dashboard-2-module-card p {
    margin-top: 4px;
    font-size: 0.78rem;
    line-height: 1.25;
}
body.sgsi-sidebar-layout .dashboard-2-left-column .dashboard-2-rail-modules .dashboard-2-module-progress-grid {
    grid-template-columns: 1fr !important;
}
@media (max-width: 920px) {
    .dashboard-2-left-column .dashboard-2-rail-modules .dashboard-2-module-progress-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 640px) {
    .dashboard-2-left-column .dashboard-2-rail-modules .dashboard-2-module-progress-grid {
        grid-template-columns: 1fr;
    }
}

/* Training delete confirmation - 2026-07-02 */
.training-delete-link {
    color: #b42318;
    border-color: #fecaca !important;
    background: #fff7f7 !important;
}
.training-delete-panel {
    max-width: 920px;
}
.training-delete-warning {
    border-left: 4px solid #b42318;
    background: #fff7f7;
    padding: 14px 16px;
    margin-bottom: 18px;
    color: #14233a;
}
.training-delete-warning p {
    margin: 6px 0 0;
    color: #566474;
}
.training-delete-form {
    display: grid;
    gap: 16px;
}
.training-delete-form label {
    display: grid;
    gap: 8px;
    font-weight: 800;
    color: #14233a;
}
.training-delete-form input {
    max-width: 260px;
    border: 1px solid #cfe0ef;
    border-radius: 10px;
    padding: 13px 14px;
    font-size: 22px;
    font-weight: 800;
    letter-spacing: 6px;
}
.dashboard-2-danger-button {
    border: 0;
    border-radius: 10px;
    background: #b42318;
    color: #fff;
    padding: 12px 18px;
    font-weight: 900;
    cursor: pointer;
}
.training-delete-resend {
    margin-top: 14px;
}
.training-delete-resend button {
    border: 0;
    background: transparent;
    color: #0f5ea8;
    font-weight: 800;
    cursor: pointer;
    padding: 0;
}

/* Project task modal role workflow - 2026-07-02 */
.project-task-dialog {
    max-height: calc(100vh - 32px);
    overflow: auto;
}
.project-task-dialog-card {
    position: relative;
}
.project-task-dialog-head {
    position: sticky;
    top: 0;
    z-index: 8;
    margin: -20px -20px 0;
    padding: 18px 20px 14px;
    border-bottom: 1px solid #e6edf4;
    border-radius: 8px 8px 0 0;
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(8px);
}
.project-task-dialog-head-main {
    display: grid;
    gap: 8px;
    flex: 1 1 auto;
    min-width: 0;
}
.project-task-dialog-title-field {
    display: grid;
    gap: 5px;
    color: #52616b;
    font-size: 0.76rem;
    font-weight: 900;
}
.project-task-dialog-title-field input {
    width: 100%;
    min-height: 44px;
    border: 1px solid #d8e1ec;
    border-radius: 8px;
    background: #ffffff;
    color: #17223b;
    padding: 9px 10px;
    font: inherit;
    font-size: 1rem;
    font-weight: 850;
}
.project-task-dialog-title-field input:disabled,
.project-task-dialog-grid textarea:disabled,
.project-task-dialog-grid select:disabled {
    background: #f8fafc;
    color: #17223b;
    opacity: 1;
}
.project-task-dialog-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}
.project-task-generated-by {
    color: #8a98aa;
    font-size: 0.74rem;
    font-weight: 800;
}
.project-task-role-hidden {
    display: none !important;
}
.project-task-retro-tools {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.project-task-retro-save-button,
.project-task-camera-button {
    display: inline-grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border: 1px solid #cdd9e5;
    border-radius: 8px;
    background: #ffffff;
    color: #0f5ea8;
    cursor: pointer;
}
.project-task-retro-save-button {
    color: #0f766e;
}
.project-task-retro-save-button:hover,
.project-task-retro-save-button:focus-visible,
.project-task-camera-button:hover,
.project-task-camera-button:focus-visible {
    border-color: #0f766e;
    color: #0f766e;
    outline: 0;
    box-shadow: 0 0 0 3px rgba(15, 118, 110, 0.1);
}
.project-task-workflow-actions:empty {
    display: none;
}
@media (max-width: 760px) {
    .project-task-dialog-head {
        align-items: flex-start;
    }
    .project-task-dialog-close {
        flex: 0 0 auto;
    }
}

/* Project completed tasks tray - 2026-07-02 */
.project-active-tasks,
.project-completed-task-list {
    display: contents;
}
.project-completed-tasks {
    display: block;
    margin: 12px 12px 4px;
    border: 1px solid #dfe7ef;
    border-radius: 8px;
    background: #f8fafc;
    overflow: hidden;
}
.project-completed-tasks[hidden] {
    display: none !important;
}
.project-completed-tasks summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-height: 42px;
    padding: 9px 12px;
    color: #405066;
    font-weight: 900;
    cursor: pointer;
    list-style: none;
}
.project-completed-tasks summary::-webkit-details-marker {
    display: none;
}
.project-completed-tasks summary::before {
    content: "›";
    display: inline-grid;
    place-items: center;
    width: 20px;
    height: 20px;
    border-radius: 999px;
    background: #e8eef5;
    color: #405066;
    font-size: 1rem;
    transform: rotate(0deg);
    transition: transform .14s ease;
}
.project-completed-tasks[open] summary::before {
    transform: rotate(90deg);
}
.project-completed-tasks summary span {
    margin-left: auto;
    min-width: 28px;
    border-radius: 999px;
    background: #e8eef5;
    color: #405066;
    text-align: center;
    font-size: .76rem;
    padding: 3px 8px;
}
.project-completed-tasks .project-task-row {
    background: #ffffff;
    opacity: .86;
}
.project-completed-tasks .project-task-row:last-child {
    border-bottom: 0;
}
@media (max-width: 760px) {
    .project-completed-tasks {
        margin: 10px 0 4px;
    }
}


/* Mobile drawer hardening - 2026-07-02 */
.sgsi-sidebar-close {
    display: none;
}

@media (max-width: 980px) {
    body.sgsi-sidebar-layout {
        width: auto !important;
        overflow-x: hidden !important;
    }

    body.sgsi-sidebar-layout .sgsi-app-shell {
        display: block !important;
        width: 100% !important;
        overflow-x: hidden !important;
    }

    body.sgsi-sidebar-layout .sgsi-sidebar {
        position: fixed !important;
        inset: 0 auto 0 0 !important;
        width: min(86vw, 292px) !important;
        max-width: 292px !important;
        height: 100dvh !important;
        z-index: 1200 !important;
        transform: translateX(-108%) !important;
        transition: transform 0.18s ease !important;
        will-change: transform !important;
        overscroll-behavior: contain !important;
    }

    body.sgsi-sidebar-layout.sgsi-sidebar-open {
        overflow: hidden !important;
    }

    body.sgsi-sidebar-layout.sgsi-sidebar-open .sgsi-sidebar {
        transform: translateX(0) !important;
    }

    body.sgsi-sidebar-layout .sgsi-sidebar-head {
        justify-content: space-between !important;
    }

    body.sgsi-sidebar-layout .sgsi-sidebar-close {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 34px !important;
        min-width: 34px !important;
        height: 34px !important;
        min-height: 34px !important;
        border: 1px solid #d3dfe8 !important;
        border-radius: 999px !important;
        background: #f8fbfd !important;
        color: #10284f !important;
        font-size: 1.6rem !important;
        font-weight: 900 !important;
        line-height: 1 !important;
        padding: 0 !important;
    }

    body.sgsi-sidebar-layout .sgsi-sidebar-backdrop {
        position: fixed !important;
        inset: 0 !important;
        z-index: 1190 !important;
        display: block !important;
        border: 0 !important;
        background: rgba(13, 31, 51, 0.34) !important;
        padding: 0 !important;
    }

    body.sgsi-sidebar-layout .sgsi-sidebar-backdrop[hidden],
    body.sgsi-sidebar-layout:not(.sgsi-sidebar-open) .sgsi-sidebar-backdrop {
        display: none !important;
    }

    body.sgsi-sidebar-layout .sgsi-content-shell,
    body.sgsi-sidebar-layout .sgsi-main-content {
        width: 100% !important;
        min-width: 0 !important;
        overflow-x: hidden !important;
    }
}


/* Task review return modal cleanup - 2026-07-02 */
.project-task-dialog-actions {
    justify-content: flex-start !important;
    min-height: 0 !important;
    padding-top: 0 !important;
}
.project-task-dialog-actions:has(span:empty) {
    display: none !important;
}
.project-task-workflow-actions .button-link[data-return-workflow-button] {
    background: #eef6fb !important;
    color: #10284f !important;
    border-color: #cbddeb !important;
}


/* Task reassignment member panel - 2026-07-02 */
.project-task-dialog-grid select.project-task-assignee-select-open {
    min-height: 170px !important;
    overflow-y: auto !important;
    background: #ffffff !important;
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.14) !important;
}
.project-task-dialog-grid label[data-assignee-field]:not([hidden]) {
    grid-column: 1 / -1 !important;
}


/* Task reassignment inline popover - 2026-07-02 */
.project-task-reassign-control {
    position: relative;
    display: inline-flex;
    align-items: center;
}
.project-task-reassign-panel {
    position: absolute;
    left: 0;
    bottom: calc(100% + 8px);
    z-index: 30;
    width: min(360px, 78vw);
    padding: 8px;
    border: 1px solid #cbddeb;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 18px 34px rgba(15, 23, 42, 0.18);
}
.project-task-reassign-panel select {
    width: 100%;
    min-height: 168px;
    border: 1px solid #d7e0ea;
    border-radius: 7px;
    padding: 8px;
    color: #10284f;
    font-weight: 800;
    background: #ffffff;
}
.project-task-reassign-panel[hidden] {
    display: none !important;
}


/* Task reassignment compact dropdown - 2026-07-02 */
.project-task-reassign-control {
    position: static !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    flex-wrap: nowrap !important;
}
.project-task-reassign-panel {
    position: static !important;
    width: min(280px, 48vw) !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}
.project-task-reassign-panel select {
    width: 100% !important;
    min-height: 44px !important;
    height: 44px !important;
    border: 1px solid #cbddeb !important;
    border-radius: 8px !important;
    padding: 0 36px 0 12px !important;
    color: #10284f !important;
    font-weight: 800 !important;
    background: #ffffff !important;
}
.project-task-reassign-panel[hidden] {
    display: none !important;
}


/* Mobile sidebar toggle button - 2026-07-02 */
.sgsi-sidebar-menu-toggle {
    gap: 4px !important;
    flex-direction: column !important;
}
.sgsi-sidebar-menu-toggle span {
    display: block !important;
    width: 16px !important;
    height: 2px !important;
    border-radius: 999px !important;
    background: currentColor !important;
}
@media (max-width: 980px) {
    body.sgsi-sidebar-layout .sgsi-sidebar-close.sgsi-sidebar-menu-toggle {
        border-radius: 10px !important;
        font-size: 0 !important;
    }
}


/* Mobile sidebar close hamburger - 2026-07-02 */
@media (max-width: 980px) {
    body.sgsi-sidebar-layout .sgsi-sidebar-close.sgsi-sidebar-menu-toggle {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        border-radius: 10px !important;
        color: #10284f !important;
        font-size: 1.45rem !important;
        font-weight: 900 !important;
        line-height: 1 !important;
        text-indent: 0 !important;
    }
    body.sgsi-sidebar-layout .sgsi-sidebar-close.sgsi-sidebar-menu-toggle::before,
    body.sgsi-sidebar-layout .sgsi-sidebar-close.sgsi-sidebar-menu-toggle::after,
    body.sgsi-sidebar-layout .sgsi-sidebar-close.sgsi-sidebar-menu-toggle span {
        display: none !important;
        content: none !important;
    }
}


/* Mobile sidebar force close state - 2026-07-02 */
@media (max-width: 980px) {
    body.sgsi-sidebar-layout:not(.sgsi-sidebar-open) .sgsi-sidebar {
        transform: translateX(-108%) !important;
        pointer-events: none !important;
    }
    body.sgsi-sidebar-layout.sgsi-sidebar-open .sgsi-sidebar {
        transform: translateX(0) !important;
        pointer-events: auto !important;
    }
    body.sgsi-sidebar-layout:not(.sgsi-sidebar-open) .sgsi-sidebar-backdrop {
        display: none !important;
        pointer-events: none !important;
    }
}


/* Mobile sidebar touch close hardening - 2026-07-02 */
@media (max-width: 980px) {
    body.sgsi-sidebar-layout .sgsi-sidebar-close.sgsi-sidebar-menu-toggle {
        position: relative !important;
        z-index: 1305 !important;
        display: inline-flex !important;
        width: 44px !important;
        min-width: 44px !important;
        height: 44px !important;
        min-height: 44px !important;
        border: 1px solid #d3dfe8 !important;
        border-radius: 12px !important;
        background: #f8fbfd !important;
        color: #10284f !important;
        font-size: 1.55rem !important;
        line-height: 1 !important;
        cursor: pointer !important;
        pointer-events: auto !important;
        touch-action: manipulation !important;
        -webkit-tap-highlight-color: rgba(16, 40, 79, 0.12) !important;
    }
}


/* Mobile sidebar inline-close fallback - 2026-07-02 */
@media (max-width: 980px) {
    body.sgsi-sidebar-layout:not(.sgsi-sidebar-open) .sgsi-sidebar {
        visibility: hidden !important;
    }
    body.sgsi-sidebar-layout.sgsi-sidebar-open .sgsi-sidebar {
        visibility: visible !important;
    }
}

/* Dashboard 2.0 mobile density alignment - 2026-07-02 */
@media (max-width: 720px) {
    .dashboard-2-page .dashboard-2-focus-strip {
        display: grid !important;
        grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
        gap: 5px !important;
        align-items: stretch !important;
        width: 100% !important;
    }

    .dashboard-2-page .dashboard-2-focus-card {
        display: grid !important;
        grid-template-columns: 1fr !important;
        justify-items: center !important;
        align-content: start !important;
        min-width: 0 !important;
        min-height: 72px !important;
        padding: 6px 3px !important;
        gap: 4px !important;
        text-align: center !important;
    }

    .dashboard-2-page .dashboard-2-ring {
        width: 34px !important;
        height: 34px !important;
    }

    .dashboard-2-page .dashboard-2-ring strong {
        font-size: 0.76rem !important;
        line-height: 1 !important;
    }

    .dashboard-2-page .dashboard-2-focus-card > div:last-child {
        display: grid !important;
        justify-items: center !important;
        width: 100% !important;
        min-width: 0 !important;
    }

    .dashboard-2-page .dashboard-2-focus-card span {
        display: block !important;
        max-width: 100% !important;
        color: #172033 !important;
        font-size: 0 !important;
        line-height: 1 !important;
        white-space: nowrap !important;
    }

    .dashboard-2-page .dashboard-2-focus-card span::after {
        display: block !important;
        color: inherit !important;
        font-size: 0.58rem !important;
        font-weight: 900 !important;
        line-height: 1.05 !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    .dashboard-2-page .dashboard-2-focus-card:nth-child(1) span::after { content: "Hoy"; }
    .dashboard-2-page .dashboard-2-focus-card:nth-child(2) span::after { content: "Semana"; }
    .dashboard-2-page .dashboard-2-focus-card:nth-child(3) span::after { content: "Venc."; }
    .dashboard-2-page .dashboard-2-focus-card:nth-child(4) span::after { content: "Carga"; }
    .dashboard-2-page .dashboard-2-focus-card:nth-child(5) span::after { content: "Efic."; }

    .dashboard-2-page .dashboard-2-focus-card small {
        display: none !important;
    }

    .dashboard-2-page .dashboard-2-worklist {
        padding: 10px !important;
    }

    .dashboard-2-page .dashboard-2-work-heading {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        gap: 8px !important;
        align-items: start !important;
        margin-bottom: 8px !important;
    }

    .dashboard-2-page .dashboard-2-work-heading h2 {
        font-size: 1.08rem !important;
        line-height: 1.08 !important;
    }

    .dashboard-2-page .dashboard-2-work-heading .eyebrow {
        font-size: 0.58rem !important;
        line-height: 1.05 !important;
    }

    .dashboard-2-page .dashboard-2-work-heading small,
    .dashboard-2-page .dashboard-2-quiet-link {
        font-size: 0.68rem !important;
        line-height: 1.12 !important;
    }

    .dashboard-2-page .dashboard-2-quiet-link {
        min-height: 26px !important;
        padding: 4px 7px !important;
        white-space: nowrap !important;
    }

    .dashboard-2-page .dashboard-2-work-metrics {
        display: grid !important;
        grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
        gap: 5px !important;
        margin: 5px 0 8px !important;
        width: 100% !important;
    }

    .dashboard-2-page .dashboard-2-work-metric {
        display: grid !important;
        align-content: center !important;
        justify-items: center !important;
        min-width: 0 !important;
        min-height: 48px !important;
        padding: 5px 3px !important;
        text-align: center !important;
    }

    .dashboard-2-page .dashboard-2-work-metric strong {
        font-size: 1.05rem !important;
        line-height: 1 !important;
    }

    .dashboard-2-page .dashboard-2-work-metric span {
        margin-top: 3px !important;
        font-size: 0 !important;
        line-height: 1 !important;
        letter-spacing: 0 !important;
        white-space: nowrap !important;
    }

    .dashboard-2-page .dashboard-2-work-metric span::after {
        display: block !important;
        font-size: 0.5rem !important;
        font-weight: 900 !important;
        line-height: 1.05 !important;
    }

    .dashboard-2-page .dashboard-2-work-metric:nth-child(1) span::after { content: "Pend."; }
    .dashboard-2-page .dashboard-2-work-metric:nth-child(2) span::after { content: "Curso"; }
    .dashboard-2-page .dashboard-2-work-metric:nth-child(3) span::after { content: "Rev."; }
    .dashboard-2-page .dashboard-2-work-metric:nth-child(4) span::after { content: "Dev."; }
    .dashboard-2-page .dashboard-2-work-metric:nth-child(5) span::after { content: "Crit."; }

    .dashboard-2-page .dashboard-2-work-tabs {
        gap: 5px !important;
        margin-bottom: 8px !important;
    }

    .dashboard-2-page .dashboard-2-work-tab {
        min-height: 28px !important;
        padding: 4px 7px !important;
        font-size: 0.7rem !important;
    }

    .dashboard-2-page .dashboard-2-work-tab strong {
        min-width: 18px !important;
        height: 18px !important;
        font-size: 0.62rem !important;
    }
}

@media (max-width: 390px) {
    .dashboard-2-page .dashboard-2-focus-strip,
    .dashboard-2-page .dashboard-2-work-metrics {
        gap: 4px !important;
    }

    .dashboard-2-page .dashboard-2-focus-card {
        min-height: 68px !important;
        padding-inline: 2px !important;
    }

    .dashboard-2-page .dashboard-2-ring {
        width: 32px !important;
        height: 32px !important;
    }

    .dashboard-2-page .dashboard-2-focus-card span::after {
        font-size: 0.54rem !important;
    }

    .dashboard-2-page .dashboard-2-work-metric {
        min-height: 44px !important;
        padding-inline: 2px !important;
    }

    .dashboard-2-page .dashboard-2-work-metric strong {
        font-size: 0.98rem !important;
    }

    .dashboard-2-page .dashboard-2-work-metric span::after {
        font-size: 0.47rem !important;
    }
}

.project-member-grid ul {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
    margin: 0;
    padding: 0;
}

.project-member-grid li {
    margin: 0;
}

.project-member-grid label {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 46px;
    padding: 10px 12px;
    border: 1px solid #d7e5f2;
    border-radius: 10px;
    background: #fff;
    color: #172033;
    font-weight: 800;
}

.project-member-grid input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: #0f64b5;
}

/* Dashboard 2.0 module focus toggles - 2026-07-02 */
.dashboard-2-focus-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin: -4px 0 10px;
}
.dashboard-2-focus-toolbar > span {
    min-width: 0;
    color: #64748b;
    font-size: 0.72rem;
    font-weight: 800;
    line-height: 1.2;
}
.dashboard-2-focus-toolbar > div {
    display: flex;
    flex: 0 0 auto;
    gap: 5px;
}
.dashboard-2-focus-toolbar form,
.dashboard-2-module-toggle-form {
    margin: 0;
}
.dashboard-2-focus-toolbar button {
    min-height: 26px;
    border: 1px solid #dbe5ee;
    border-radius: 999px;
    background: #ffffff;
    color: #405066;
    cursor: pointer;
    font: inherit;
    font-size: 0.68rem;
    font-weight: 850;
    padding: 4px 8px;
}
.dashboard-2-focus-toolbar button:hover {
    border-color: #9cc7bd;
    background: #f4fbf8;
    color: #0f766e;
}
.dashboard-2-module-toggle-form .dashboard-2-module-card {
    width: 100%;
    color: inherit;
    cursor: pointer;
    font: inherit;
    text-align: left;
    appearance: none;
    -webkit-appearance: none;
}
.dashboard-2-module-toggle-form .dashboard-2-module-card:hover {
    border-color: #9cc7bd;
    background: #f8fcfb;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}
.dashboard-2-module-toggle-form .dashboard-2-module-card.is-active {
    border-color: #1f7a6b;
    background: #eef8f5;
    box-shadow: inset 0 0 0 2px rgba(31, 122, 107, 0.16), 0 12px 28px rgba(15, 23, 42, 0.07);
}
.dashboard-2-module-toggle-form .dashboard-2-module-card.is-active .dashboard-2-module-title > span {
    background: #1f7a6b;
    color: #ffffff;
}
.dashboard-2-module-toggle-form .dashboard-2-module-card.is-active .dashboard-2-module-ring {
    --ring-color: #1f7a6b;
}
.dashboard-2-module-detail {
    display: block;
    margin-top: 4px;
    color: #64748b;
    font-size: 0.78rem;
    line-height: 1.25;
}
@media (max-width: 720px) {
    .dashboard-2-focus-toolbar {
        align-items: stretch;
        flex-direction: column;
    }
    .dashboard-2-focus-toolbar > div {
        width: 100%;
    }
    .dashboard-2-focus-toolbar form,
    .dashboard-2-focus-toolbar button {
        flex: 1 1 0;
        width: 100%;
    }
}


/* Page favorite stars - 2026-07-02 */
.page-heading h1,
.dashboard-2-header h1 {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.sgsi-page-favorite-form {
    display: inline-flex;
    margin: 0;
    vertical-align: middle;
}

.sgsi-page-favorite {
    width: 2rem;
    height: 2rem;
    display: inline-grid;
    place-items: center;
    border: 1px solid #cfdbea;
    border-radius: 999px;
    background: #fff;
    color: #8a97a8;
    cursor: pointer;
    font-size: 1.15rem;
    line-height: 1;
    padding: 0;
    box-shadow: 0 8px 18px rgba(15, 38, 70, 0.08);
}

.sgsi-page-favorite:hover,
.sgsi-page-favorite:focus-visible {
    border-color: #0f5fa8;
    color: #0f5fa8;
    outline: none;
}

.sgsi-page-favorite.is-active {
    background: #fff7df;
    border-color: #e4b342;
    color: #b77905;
}

@media (max-width: 700px) {
    .sgsi-page-favorite {
        width: 1.8rem;
        height: 1.8rem;
        font-size: 1rem;
    }
}


/* Integration form errors - 2026-07-02 */
.form-errors,
.errorlist {
    color: #b42318;
    font-weight: 800;
}
.form-errors {
    background: #fff1f0;
    border: 1px solid #f5b5ad;
    border-radius: 8px;
    padding: 0.8rem 1rem;
    margin-bottom: 1rem;
}
.errorlist {
    list-style: none;
    margin: 0.35rem 0 0;
    padding: 0;
    font-size: 0.9rem;
}


/* Dashboard 2.0 mobile ticket workspace - 2026-07-03 */
.dashboard-2-mobile-ticket-hero {
    display: none;
}

@media (max-width: 820px) {
    body.sgsi-sidebar-layout .sgsi-content-shell,
    body.sgsi-sidebar-layout .sgsi-main-content {
        margin-left: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    body.sgsi-sidebar-layout .sgsi-topbar {
        position: sticky;
        top: 0;
        z-index: 60;
        min-height: 54px;
        padding: 8px 10px;
        gap: 8px;
        background: rgba(255, 255, 255, 0.96);
        backdrop-filter: blur(10px);
    }

    body.sgsi-sidebar-layout .sgsi-mobile-toggle,
    body.sgsi-sidebar-layout [data-sidebar-toggle] {
        width: 44px;
        height: 44px;
        min-width: 44px;
        min-height: 44px;
    }

    .dashboard-2-page.dashboard,
    .dashboard-2-page .dashboard-2-shell {
        padding: 10px !important;
        max-width: 100% !important;
        overflow-x: hidden;
    }

    .dashboard-2-page .dashboard-2-header {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 10px !important;
        padding: 12px !important;
        margin-bottom: 10px !important;
        min-height: 0 !important;
    }

    .dashboard-2-page .dashboard-2-header h1 {
        font-size: clamp(30px, 9vw, 42px) !important;
        line-height: 0.95 !important;
        margin: 0 0 6px !important;
    }

    .dashboard-2-page .advanced-heading-copy,
    .dashboard-2-page .dashboard-2-header p:not(.eyebrow) {
        font-size: 13px !important;
        line-height: 1.35 !important;
        max-width: 100% !important;
    }

    .dashboard-2-page .dashboard-2-user-actions {
        width: 100%;
        display: grid;
        grid-template-columns: 1fr;
    }

    .dashboard-2-page .dashboard-2-quick-task-open {
        width: 100%;
        min-height: 46px;
        padding: 10px 14px;
    }

    .dashboard-2-page .dashboard-2-company-strip {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 8px !important;
        padding: 10px !important;
        margin-bottom: 10px !important;
    }

    .dashboard-2-page .dashboard-2-company-strip > div {
        display: flex !important;
        gap: 8px !important;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 2px;
    }

    .dashboard-2-page .dashboard-2-company-strip a,
    .dashboard-2-page .dashboard-2-company-strip button,
    .dashboard-2-page .dashboard-2-company-strip .button {
        white-space: nowrap;
        flex: 0 0 auto;
    }

    .dashboard-2-page .dashboard-2-mobile-ticket-hero {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        gap: 12px;
        margin: 0 0 10px;
        padding: 12px;
        border: 1px solid #d8e2ea;
        border-left: 4px solid #0f5ea8;
        border-radius: 10px;
        background: #fff;
        box-shadow: 0 8px 22px rgba(13, 31, 51, 0.05);
    }

    .dashboard-2-page .dashboard-2-mobile-ticket-hero h2 {
        margin: 2px 0 4px;
        font-size: 22px;
        line-height: 1;
        color: #13223a;
    }

    .dashboard-2-page .dashboard-2-mobile-ticket-hero small {
        display: block;
        color: #5d6b7c;
        font-weight: 700;
        line-height: 1.3;
    }

    .dashboard-2-page .dashboard-2-mobile-ticket-count {
        width: 72px;
        height: 72px;
        border-radius: 999px;
        border: 10px solid #e8eef4;
        display: grid;
        place-items: center;
        text-align: center;
        color: #13223a;
        line-height: 1;
    }

    .dashboard-2-page .dashboard-2-mobile-ticket-count strong {
        display: block;
        font-size: 20px;
    }

    .dashboard-2-page .dashboard-2-mobile-ticket-count span {
        display: block;
        font-size: 9px;
        text-transform: uppercase;
        letter-spacing: .06em;
        color: #5d6b7c;
    }

    .dashboard-2-page .dashboard-2-focus-strip {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 8px !important;
        margin-bottom: 10px !important;
    }

    .dashboard-2-page .dashboard-2-focus-card {
        min-height: 76px !important;
        padding: 10px !important;
        gap: 8px !important;
    }

    .dashboard-2-page .dashboard-2-focus-card .metric-ring,
    .dashboard-2-page .dashboard-2-focus-card .metric-ring-sm {
        width: 56px !important;
        height: 56px !important;
        min-width: 56px !important;
    }

    .dashboard-2-page .dashboard-2-main-grid,
    .dashboard-2-page .dashboard-2-main-grid-three {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
    }

    .dashboard-2-page .dashboard-2-center-column {
        order: 1;
    }

    .dashboard-2-page .dashboard-2-right-column {
        order: 2;
    }

    .dashboard-2-page .dashboard-2-left-column {
        order: 3;
    }

    .dashboard-2-page .dashboard-2-panel,
    .dashboard-2-page .dashboard-2-card,
    .dashboard-2-page .dashboard-2-worklist-subtle {
        padding: 12px !important;
        border-radius: 10px !important;
    }

    .dashboard-2-page .dashboard-2-worklist-subtle .dashboard-2-work-task,
    .dashboard-2-page .dashboard-2-work-task {
        display: grid !important;
        grid-template-columns: 14px 52px minmax(0, 1fr) !important;
        gap: 8px !important;
        align-items: center !important;
        padding: 10px !important;
        border-radius: 10px !important;
        min-height: 82px !important;
    }

    .dashboard-2-page .dashboard-2-task-check {
        width: 14px !important;
        height: 14px !important;
        min-width: 14px !important;
        min-height: 14px !important;
        border-width: 2px !important;
    }

    .dashboard-2-page .dashboard-2-task-date {
        width: 52px !important;
        height: 58px !important;
        border-radius: 9px !important;
        padding: 5px 3px !important;
        align-self: center !important;
    }

    .dashboard-2-page .dashboard-2-task-date strong {
        font-size: 20px !important;
        line-height: 1 !important;
    }

    .dashboard-2-page .dashboard-2-task-date span,
    .dashboard-2-page .dashboard-2-task-date small {
        font-size: 10px !important;
        line-height: 1.05 !important;
    }

    .dashboard-2-page .dashboard-2-work-task-body,
    .dashboard-2-page .dashboard-2-task-body {
        min-width: 0 !important;
    }

    .dashboard-2-page .dashboard-2-work-title,
    .dashboard-2-page .dashboard-2-task-title {
        font-size: 15px !important;
        line-height: 1.1 !important;
        margin-bottom: 4px !important;
        overflow-wrap: anywhere;
    }

    .dashboard-2-page .dashboard-2-task-meta,
    .dashboard-2-page .dashboard-2-work-meta {
        font-size: 12px !important;
        line-height: 1.25 !important;
    }

    .dashboard-2-page .dashboard-2-work-status,
    .dashboard-2-page .dashboard-2-task-type {
        grid-column: 3 !important;
        justify-self: start !important;
        margin-top: 4px !important;
        font-size: 11px !important;
        padding: 4px 8px !important;
    }

    .dashboard-2-page .dashboard-2-dialog,
    .dashboard-2-page dialog.dashboard-2-dialog {
        padding: 0 !important;
    }

    .dashboard-2-page .dashboard-2-dialog-card {
        width: 100vw !important;
        max-width: 100vw !important;
        min-height: 100dvh !important;
        max-height: 100dvh !important;
        border-radius: 0 !important;
        overflow: auto !important;
    }

    .dashboard-2-page .dashboard-2-quick-task-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }

    .dashboard-2-page .dashboard-2-quick-task-actions {
        position: sticky;
        bottom: 0;
        background: #fff;
        padding-top: 10px;
    }
}

@media (max-width: 460px) {
    .dashboard-2-page .dashboard-2-focus-strip {
        grid-template-columns: 1fr !important;
    }

    .dashboard-2-page .dashboard-2-worklist-subtle .dashboard-2-work-task,
    .dashboard-2-page .dashboard-2-work-task {
        grid-template-columns: 12px 48px minmax(0, 1fr) !important;
        gap: 7px !important;
        padding: 9px !important;
    }

    .dashboard-2-page .dashboard-2-task-date {
        width: 48px !important;
        height: 54px !important;
    }

    .dashboard-2-page .dashboard-2-work-title,
    .dashboard-2-page .dashboard-2-task-title {
        font-size: 14px !important;
    }
}


/* Dashboard 2.0 mobile focus strip single row - 2026-07-03 */
@media (max-width: 820px) {
    .dashboard-2-page .dashboard-2-focus-strip {
        display: flex !important;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        gap: 8px !important;
        padding: 0 0 6px !important;
        margin-bottom: 10px !important;
        scroll-snap-type: x proximity;
        -webkit-overflow-scrolling: touch;
    }

    .dashboard-2-page .dashboard-2-focus-card {
        flex: 0 0 154px !important;
        width: 154px !important;
        min-height: 70px !important;
        padding: 9px !important;
        scroll-snap-align: start;
    }

    .dashboard-2-page .dashboard-2-focus-card .metric-ring,
    .dashboard-2-page .dashboard-2-focus-card .metric-ring-sm {
        width: 48px !important;
        height: 48px !important;
        min-width: 48px !important;
    }

    .dashboard-2-page .dashboard-2-focus-card strong,
    .dashboard-2-page .dashboard-2-focus-card b {
        font-size: 14px !important;
        line-height: 1.05 !important;
    }

    .dashboard-2-page .dashboard-2-focus-card span,
    .dashboard-2-page .dashboard-2-focus-card small {
        font-size: 11px !important;
        line-height: 1.15 !important;
    }
}

@media (max-width: 460px) {
    .dashboard-2-page .dashboard-2-focus-strip {
        display: flex !important;
        grid-template-columns: none !important;
        flex-wrap: nowrap !important;
    }

    .dashboard-2-page .dashboard-2-focus-card {
        flex-basis: 146px !important;
        width: 146px !important;
    }
}


/* Dashboard 2.0 mobile focus strip hard row - 2026-07-03-002 */
@media (max-width: 820px) {
    body.sgsi-sidebar-layout .dashboard-2-page .dashboard-2-focus-strip,
    .dashboard-2-page .dashboard-2-focus-strip {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        align-items: stretch !important;
        justify-content: flex-start !important;
        grid-template-columns: none !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        gap: 8px !important;
        padding: 0 2px 8px !important;
        margin: 0 0 10px !important;
        scroll-snap-type: x proximity !important;
        -webkit-overflow-scrolling: touch !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-page .dashboard-2-focus-strip > .dashboard-2-focus-card,
    .dashboard-2-page .dashboard-2-focus-strip > .dashboard-2-focus-card {
        flex: 0 0 136px !important;
        width: 136px !important;
        min-width: 136px !important;
        max-width: 136px !important;
        min-height: 64px !important;
        margin: 0 !important;
        padding: 8px !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 8px !important;
        text-align: left !important;
        box-sizing: border-box !important;
        scroll-snap-align: start !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-page .dashboard-2-focus-card .dashboard-2-ring,
    .dashboard-2-page .dashboard-2-focus-card .dashboard-2-ring {
        width: 42px !important;
        height: 42px !important;
        min-width: 42px !important;
        max-width: 42px !important;
        flex: 0 0 42px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-page .dashboard-2-focus-card .dashboard-2-ring strong,
    .dashboard-2-page .dashboard-2-focus-card .dashboard-2-ring strong {
        font-size: 0.82rem !important;
        line-height: 1 !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-page .dashboard-2-focus-card > div:last-child,
    .dashboard-2-page .dashboard-2-focus-card > div:last-child {
        display: block !important;
        min-width: 0 !important;
        width: auto !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-page .dashboard-2-focus-card span,
    .dashboard-2-page .dashboard-2-focus-card span {
        display: block !important;
        max-width: 72px !important;
        font-size: 0 !important;
        line-height: 1 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        color: #172033 !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-page .dashboard-2-focus-card span::after,
    .dashboard-2-page .dashboard-2-focus-card span::after {
        display: block !important;
        font-size: 0.64rem !important;
        line-height: 1.05 !important;
        font-weight: 900 !important;
        color: #172033 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-page .dashboard-2-focus-card small,
    .dashboard-2-page .dashboard-2-focus-card small {
        display: none !important;
    }
}

@media (max-width: 390px) {
    body.sgsi-sidebar-layout .dashboard-2-page .dashboard-2-focus-strip > .dashboard-2-focus-card,
    .dashboard-2-page .dashboard-2-focus-strip > .dashboard-2-focus-card {
        flex-basis: 126px !important;
        width: 126px !important;
        min-width: 126px !important;
        max-width: 126px !important;
        padding: 7px !important;
        gap: 7px !important;
    }

    body.sgsi-sidebar-layout .dashboard-2-page .dashboard-2-focus-card .dashboard-2-ring,
    .dashboard-2-page .dashboard-2-focus-card .dashboard-2-ring {
        width: 38px !important;
        height: 38px !important;
        min-width: 38px !important;
        flex-basis: 38px !important;
    }
}

/* Quick task compact modal - 2026-07-03 */
.dashboard-2-page .dashboard-2-dialog,
.dashboard-2-page dialog.dashboard-2-dialog {
    width: min(1040px, calc(100vw - 32px));
    max-height: calc(100dvh - 32px);
    overflow: hidden;
}
.dashboard-2-page .dashboard-2-dialog-card {
    display: flex;
    flex-direction: column;
    max-height: calc(100dvh - 32px);
}
.dashboard-2-page .dashboard-2-dialog-head {
    align-items: center;
    padding: 14px 18px;
    gap: 12px;
}
.dashboard-2-page .dashboard-2-dialog-head .eyebrow {
    margin-bottom: 3px;
    font-size: 0.74rem;
}
.dashboard-2-page .dashboard-2-dialog-head h2 {
    font-size: 1.35rem;
    line-height: 1.08;
}
.dashboard-2-page .dashboard-2-dialog-head small {
    display: block;
    margin-top: 2px;
    font-size: 0.82rem;
    line-height: 1.25;
}
.dashboard-2-page .dashboard-2-dialog-head button {
    width: 34px;
    height: 34px;
    flex: 0 0 34px;
    font-size: 1.2rem;
}
.dashboard-2-page .dashboard-2-quick-task-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px 12px;
    padding: 14px 18px;
    overflow: auto;
}
.dashboard-2-page .dashboard-2-quick-task-grid label {
    gap: 4px;
    font-size: 0.86rem;
    line-height: 1.15;
}
.dashboard-2-page .dashboard-2-quick-task-grid input,
.dashboard-2-page .dashboard-2-quick-task-grid select,
.dashboard-2-page .dashboard-2-quick-task-grid textarea {
    min-height: 38px;
    padding: 8px 10px;
    border-radius: 7px;
    font-size: 0.9rem;
    line-height: 1.2;
}
.dashboard-2-page .dashboard-2-quick-task-grid textarea {
    min-height: 70px;
    max-height: 92px;
    resize: vertical;
}
.dashboard-2-page .dashboard-2-time-field > small {
    margin-left: 4px;
    padding: 1px 7px;
    font-size: 0.7rem;
}
.dashboard-2-page .dashboard-2-time-shortcuts {
    gap: 5px;
    margin-top: 0;
}
.dashboard-2-page .dashboard-2-time-shortcuts button {
    min-height: 26px;
    padding: 0 9px;
    font-size: 0.76rem;
}
.dashboard-2-page .dashboard-2-recurrence-box {
    grid-template-columns: minmax(250px, 1.05fr) minmax(240px, 1fr) minmax(150px, 0.6fr);
    gap: 7px 10px;
    padding: 9px 10px;
}
.dashboard-2-page .dashboard-2-recurrence-box > span {
    font-size: 0.82rem;
}
.dashboard-2-page .dashboard-2-recurrence-modes,
.dashboard-2-page .dashboard-2-weekday-row {
    gap: 5px;
}
.dashboard-2-page .dashboard-2-recurrence-modes label,
.dashboard-2-page .dashboard-2-weekday-row label {
    min-height: 24px;
    padding: 3px 7px;
    font-size: 0.72rem;
}
.dashboard-2-page .dashboard-2-weekday-row label {
    min-width: 29px;
    padding-inline: 6px;
}
.dashboard-2-page .dashboard-2-recurrence-box input[type="radio"],
.dashboard-2-page .dashboard-2-recurrence-box input[type="checkbox"] {
    flex-basis: 12px;
    width: 12px !important;
    height: 12px !important;
    min-width: 12px !important;
    min-height: 12px !important;
}
.dashboard-2-page .dashboard-2-recurrence-end {
    gap: 3px;
    font-size: 0.76rem;
}
.dashboard-2-page .dashboard-2-recurrence-end input {
    min-height: 32px;
    padding: 5px 8px;
    font-size: 0.82rem;
}
.dashboard-2-page .dashboard-2-recurrence-box small {
    font-size: 0.7rem;
    line-height: 1.25;
}
.dashboard-2-page .dashboard-2-dialog-actions {
    position: sticky;
    bottom: 0;
    padding: 10px 18px 14px;
    border-top: 1px solid #e2e8f0;
    background: #fff;
}
.dashboard-2-page .dashboard-2-dialog-actions .dashboard-2-primary-button,
.dashboard-2-page .dashboard-2-dialog-actions .dashboard-2-secondary-button {
    min-height: 34px;
    padding: 7px 12px;
}
@media (max-width: 980px) {
    .dashboard-2-page .dashboard-2-quick-task-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .dashboard-2-page .dashboard-2-recurrence-box {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 720px) {
    .dashboard-2-page .dashboard-2-dialog,
    .dashboard-2-page dialog.dashboard-2-dialog {
        width: 100vw;
        max-height: 100dvh;
    }
    .dashboard-2-page .dashboard-2-dialog-card {
        max-height: 100dvh;
    }
    .dashboard-2-page .dashboard-2-quick-task-grid {
        grid-template-columns: 1fr;
        padding: 12px;
    }
    .dashboard-2-page .dashboard-2-dialog-head {
        padding: 12px;
    }
    .dashboard-2-page .dashboard-2-dialog-actions {
        padding: 10px 12px 12px;
    }
}

/* Friendly permission errors - 2026-07-03 */
.friendly-error-page {
    min-height: calc(100dvh - 120px);
    display: grid;
    place-items: center;
    padding: 32px 16px;
}
.friendly-error-card {
    width: min(560px, 100%);
    padding: 28px;
    border: 1px solid #dbe6f0;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 18px 50px rgba(15, 43, 85, 0.14);
}
.friendly-error-card h1 {
    margin: 0 0 10px;
    color: #172033;
    font-size: clamp(1.5rem, 4vw, 2.1rem);
    line-height: 1.08;
}
.friendly-error-card p:not(.eyebrow) {
    margin: 0;
    color: #5f6f80;
    font-weight: 650;
    line-height: 1.45;
}
.friendly-error-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 20px;
}
.friendly-error-actions button,
.friendly-error-actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 8px 14px;
    border-radius: 8px;
    border: 1px solid #0f766e;
    background: #0f766e;
    color: #fff;
    font-weight: 850;
    text-decoration: none;
    cursor: pointer;
}
.friendly-error-actions a {
    background: #fff;
    color: #0f766e;
}

/* Mobile topbar menus - keep profile/company/notifications usable on Safari */
.sgsi-topbar details > summary {
    touch-action: manipulation;
    -webkit-tap-highlight-color: rgba(15, 94, 168, 0.12);
}

@media (max-width: 820px) {
    body.sgsi-sidebar-layout .sgsi-topbar {
        overflow: visible !important;
        z-index: 1500 !important;
    }

    body.sgsi-sidebar-layout .sgsi-topbar-left,
    body.sgsi-sidebar-layout .sgsi-topbar-actions {
        position: static !important;
        overflow-y: visible !important;
    }

    body.sgsi-sidebar-layout .sgsi-notification-bell,
    body.sgsi-sidebar-layout .sgsi-top-menu {
        position: static !important;
    }

    body.sgsi-sidebar-layout .sgsi-notification-panel,
    body.sgsi-sidebar-layout .sgsi-top-menu-panel {
        position: fixed !important;
        top: 58px !important;
        left: 10px !important;
        right: 10px !important;
        z-index: 2600 !important;
        width: auto !important;
        min-width: 0 !important;
        max-width: calc(100vw - 20px) !important;
        max-height: calc(100dvh - 78px) !important;
        overflow-y: auto !important;
        overscroll-behavior: contain !important;
        transform: none !important;
    }

    body.sgsi-sidebar-layout .sgsi-top-menu-panel {
        display: grid !important;
    }

    body.sgsi-sidebar-layout .sgsi-notification-bell[open] summary,
    body.sgsi-sidebar-layout .sgsi-top-menu[open] summary {
        border-color: #0f5ea8 !important;
        box-shadow: 0 0 0 2px rgba(15, 94, 168, 0.12) !important;
    }
}

/* Incidentes operativos */
.incident-ops-page {
    background: #f6f8fb;
}

.incident-ops-shell {
    display: grid;
    gap: 16px;
}

.incident-ops-header {
    align-items: flex-end;
}

.incident-ops-company-strip,
.incident-ops-scope-row,
.incident-ops-board,
.incident-ops-priority,
.incident-ops-panel {
    border: 1px solid #dbe5ef;
    border-radius: 8px;
    background: #ffffff;
}

.incident-ops-scope-row {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 14px;
}

.incident-ops-scope-row > span {
    color: #516172;
    font-weight: 800;
}

.incident-ops-scope-row > div {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.incident-ops-kpis {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.incident-ops-kpi {
    border: 1px solid #dbe5ef;
    border-left: 5px solid #8bb7df;
    border-radius: 8px;
    background: #ffffff;
    color: #16243a;
    display: grid;
    gap: 5px;
    min-height: 104px;
    padding: 14px;
    text-decoration: none;
}

.incident-ops-kpi span {
    color: #637384;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.incident-ops-kpi strong {
    color: #1260a8;
    font-size: 2rem;
    line-height: 1;
}

.incident-ops-kpi small {
    color: #516172;
    font-weight: 800;
}

.incident-ops-kpi.is-strong {
    border-left-color: #12355b;
}

.incident-ops-kpi.is-danger {
    border-left-color: #dc2626;
}

.incident-ops-kpi.is-danger strong {
    color: #b91c1c;
}

.incident-ops-kpi.is-calm {
    border-left-color: #16a34a;
}

.incident-ops-kpi.is-calm strong {
    color: #15803d;
}

.incident-ops-main-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
}

.incident-ops-board,
.incident-ops-priority,
.incident-ops-panel {
    padding: 16px;
}

.incident-ops-section-heading {
    margin-bottom: 14px;
}

.incident-ops-kanban {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(210px, 1fr));
    overflow-x: auto;
    padding-bottom: 4px;
}

.incident-ops-column {
    border: 1px solid #e0e8f1;
    border-radius: 8px;
    background: #f8fafc;
    min-width: 210px;
    padding: 10px;
}

.incident-ops-column header {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}

.incident-ops-column header strong {
    color: #1f2937;
    font-size: 0.92rem;
}

.incident-ops-column header span {
    align-items: center;
    background: #e8f1fb;
    border-radius: 999px;
    color: #0f5ea8;
    display: inline-flex;
    font-size: 0.78rem;
    font-weight: 900;
    height: 24px;
    justify-content: center;
    min-width: 24px;
}

.incident-ops-card-list {
    display: grid;
    gap: 10px;
}

.incident-ops-card {
    border: 1px solid #dbe5ef;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
    display: grid;
    gap: 9px;
    padding: 12px;
}

.incident-ops-card.sla-overdue,
.incident-ops-priority-item.sla-overdue {
    border-color: #fecaca;
    background: #fff7f7;
}

.incident-ops-card.sla-today,
.incident-ops-priority-item.sla-today {
    border-color: #fed7aa;
    background: #fffaf4;
}

.incident-ops-card-top,
.incident-ops-card-foot {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 8px;
}

.incident-ops-card-top small,
.incident-ops-card-foot span,
.incident-ops-card-foot a {
    color: #536476;
    font-size: 0.78rem;
    font-weight: 900;
}

.incident-ops-card h3 {
    font-size: 0.98rem;
    line-height: 1.25;
    margin: 0;
}

.incident-ops-card h3 a {
    color: #172033;
    text-decoration: none;
}

.incident-ops-card p {
    color: #526173;
    font-weight: 700;
    line-height: 1.35;
    margin: 0;
}

.incident-ops-card dl {
    display: grid;
    gap: 7px;
    grid-template-columns: 1fr 1fr;
    margin: 0;
}

.incident-ops-card dl div {
    min-width: 0;
}

.incident-ops-card dt {
    color: #7b8794;
    font-size: 0.68rem;
    font-weight: 900;
    text-transform: uppercase;
}

.incident-ops-card dd {
    color: #253247;
    font-size: 0.82rem;
    font-weight: 900;
    margin: 2px 0 0;
    overflow-wrap: anywhere;
}

.incident-ops-priority-list,
.incident-ops-timeline {
    display: grid;
    gap: 10px;
}

.incident-ops-priority-item,
.incident-ops-timeline-item {
    border: 1px solid #dbe5ef;
    border-radius: 8px;
    background: #ffffff;
    color: #1f2937;
    display: grid;
    gap: 4px;
    padding: 12px;
    text-decoration: none;
}

.incident-ops-priority-item span,
.incident-ops-timeline-item span {
    color: #0f5ea8;
    font-size: 0.74rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.incident-ops-priority-item strong,
.incident-ops-timeline-item strong {
    line-height: 1.25;
}

.incident-ops-priority-item small,
.incident-ops-timeline-item small {
    color: #536476;
    font-weight: 800;
    line-height: 1.35;
}

.incident-ops-guidance {
    border-top: 1px solid #e2e8f0;
    display: grid;
    gap: 10px;
    margin-top: 14px;
    padding-top: 14px;
}

.incident-ops-guidance strong {
    color: #172033;
}

.incident-ops-guidance p {
    color: #536476;
    font-weight: 700;
    line-height: 1.45;
    margin: 0;
}

.incident-ops-guidance div {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.incident-ops-lower-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.8fr);
}

.incident-ops-filter-form {
    align-items: end;
}

.incident-ops-empty {
    color: #64748b;
    font-weight: 800;
    margin: 0;
}

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

.incident-closure-fields small,
.incident-form-grid label small {
    color: #64748b;
    display: block;
    font-size: 0.78rem;
    font-weight: 800;
    margin-top: 4px;
}

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

    .incident-ops-main-grid,
    .incident-ops-lower-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .incident-ops-header,
    .incident-ops-scope-row {
        align-items: flex-start;
        flex-direction: column;
    }

    .incident-ops-kpis {
        grid-template-columns: 1fr 1fr;
    }

    .incident-closure-fields {
        grid-template-columns: 1fr;
    }
}

/* Captura operativa de incidentes */
.incident-capture-page {
    background: #f6f8fb;
}

.incident-capture-shell,
.incident-capture-form {
    display: grid;
    gap: 16px;
}

.incident-capture-header {
    align-items: flex-end;
}

.incident-capture-hero,
.incident-capture-panel,
.incident-capture-side-panel {
    border: 1px solid #dbe5ef;
    border-radius: 8px;
    background: #ffffff;
}

.incident-capture-hero {
    align-items: stretch;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 280px);
    padding: 16px;
}

.incident-capture-title-block {
    align-items: flex-start;
    display: grid;
    gap: 14px;
    grid-template-columns: auto minmax(0, 1fr);
}

.incident-capture-step {
    align-items: center;
    background: #12355b;
    border-radius: 999px;
    color: #ffffff;
    display: inline-flex;
    font-size: 1rem;
    font-weight: 900;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.incident-capture-title-block label,
.incident-capture-panel label,
.incident-capture-evidence-fields label {
    color: #243247;
    display: grid;
    gap: 7px;
    font-weight: 900;
}

.incident-capture-title-block input {
    font-size: 1.15rem;
    min-height: 48px;
}

.incident-capture-sla {
    border: 1px solid #cfe0f1;
    border-left: 6px solid #1260a8;
    border-radius: 8px;
    background: #f8fbff;
    display: grid;
    gap: 5px;
    padding: 14px;
}

.incident-capture-sla span {
    color: #64748b;
    font-size: 0.74rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.incident-capture-sla strong {
    color: #0f5ea8;
    font-size: 1.55rem;
    line-height: 1;
}

.incident-capture-sla small,
.incident-capture-panel small {
    color: #64748b;
    font-weight: 800;
    line-height: 1.35;
}

.incident-capture-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
}

.incident-capture-panel,
.incident-capture-side-panel {
    padding: 16px;
}

.incident-capture-fields {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.incident-capture-hidden-lite {
    border-top: 1px solid #e2e8f0;
    margin-top: 14px;
    padding-top: 14px;
}

.incident-capture-side-panel {
    align-content: start;
    display: grid;
    gap: 14px;
}

.incident-capture-linked-task {
    border: 1px solid #cfe0f1;
    border-radius: 8px;
    background: #f8fbff;
    display: grid;
    gap: 8px;
    padding: 14px;
}

.incident-capture-linked-task strong {
    color: #172033;
    font-size: 1.05rem;
}

.incident-capture-linked-task span,
.incident-capture-rules li {
    color: #536476;
    font-weight: 800;
    line-height: 1.4;
}

.incident-capture-linked-task a {
    color: #0f5ea8;
    font-weight: 900;
    text-decoration: none;
}

.incident-capture-rules {
    display: grid;
    gap: 8px;
}

.incident-capture-rules strong {
    color: #172033;
}

.incident-capture-rules ul {
    margin: 0;
    padding-left: 18px;
}

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

.incident-capture-two-columns textarea {
    min-height: 128px;
}

.incident-capture-evidence-layout {
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(260px, 0.85fr) minmax(0, 1fr);
}

.incident-capture-dropzone {
    align-content: center;
    min-height: 230px;
}

.incident-capture-evidence-fields {
    display: grid;
    gap: 12px;
}

.incident-capture-close-panel {
    border-left: 6px solid #cbd5e1;
    opacity: 0.82;
}

.incident-capture-close-panel.is-closure-enabled {
    border-left-color: #16a34a;
    opacity: 1;
}

.incident-capture-close-panel:not(.is-closure-enabled) .incident-closure-fields,
.incident-capture-close-panel:not(.is-closure-enabled) .incident-capture-close-date {
    filter: grayscale(0.2);
    opacity: 0.62;
}

.incident-capture-close-date {
    margin-top: 12px;
}

.incident-capture-save-bar {
    align-items: center;
    border: 1px solid #dbe5ef;
    border-radius: 8px;
    background: #ffffff;
    bottom: 12px;
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    padding: 12px;
    position: sticky;
    z-index: 8;
}

@media (max-width: 1120px) {
    .incident-capture-hero,
    .incident-capture-grid,
    .incident-capture-evidence-layout {
        grid-template-columns: 1fr;
    }

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

@media (max-width: 720px) {
    .incident-capture-header,
    .incident-capture-save-bar {
        align-items: flex-start;
        flex-direction: column;
    }

    .incident-capture-fields,
    .incident-capture-two-columns {
        grid-template-columns: 1fr;
    }

    .incident-capture-title-block {
        grid-template-columns: 1fr;
    }
}
