/* Homologation SSI - interface v24 clean */
:root {
    --primary: #17416f;
    --primary-strong: #0f2d4f;
    --primary-soft: #eaf2fb;
    --accent: #257d6a;
    --accent-soft: #e9f6f2;
    --success: #16803c;
    --warning: #b56a00;
    --danger: #b42318;
    --info: #1f65b7;
    --bg: #f5f7fa;
    --surface: #ffffff;
    --surface-muted: #f8fafc;
    --line: #d8e0ea;
    --line-strong: #b9c5d3;
    --text: #172033;
    --text-muted: #637083;
    --shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);
    --shadow-md: 0 10px 24px rgba(15, 23, 42, .08);
    --radius: 8px;
    --radius-sm: 6px;
    --sidebar-width: 280px;
    color-scheme: light;
}

* { box-sizing: border-box; }

html {
    min-height: 100%;
    scroll-behavior: smooth;
}

body {
    margin: 0;
    min-height: 100vh;
    background: var(--bg);
    color: var(--text);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
    font-size: 15px;
    line-height: 1.5;
    letter-spacing: 0;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

body.drawer-open { overflow: hidden; }

a {
    color: var(--primary);
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

a:hover { color: var(--accent); }

img, svg { max-width: 100%; }

h1, h2, h3, h4 {
    margin: 0 0 12px;
    color: var(--primary-strong);
    line-height: 1.2;
    letter-spacing: 0;
}

h1 { font-size: 2rem; }
h2 { font-size: 1.45rem; }
h3 { font-size: 1.12rem; }
h4 { font-size: 1rem; }

p { margin: 0 0 12px; }
main { max-width: 1180px; margin: 28px auto 56px; padding: 0 24px; }

.muted, .help, .help-text, .password-strength {
    color: var(--text-muted);
}

.text-danger {
    color: var(--danger) !important;
}

.help, .help-text, .password-strength {
    margin-top: 5px;
    font-size: .88rem;
}

.required, .required-marker { color: var(--danger); }

.visually-hidden,
.honeypot {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    clip-path: inset(50%);
}

/* Public portal */
.topbar {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(255, 255, 255, .96);
    border-bottom: 1px solid var(--line);
}

.topbar-inner {
    max-width: 1180px;
    min-height: 64px;
    margin: 0 auto;
    padding: 0 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.brand,
.admin-sidebar-brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    color: var(--text);
    text-decoration: none;
}

.brand-logo,
.admin-sidebar-logo,
.login-brand-logo,
.login-brand-fallback,
.verify-logo-img,
.verify-logo-fallback,
.brand-mark {
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface);
    color: var(--primary-strong);
    font-weight: 800;
    object-fit: contain;
}

.brand-logo img,
.admin-sidebar-logo,
.login-brand-logo img,
.verify-logo-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 6px;
}

.brand-text,
.admin-sidebar-brand-text {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.brand-text > span,
.admin-sidebar-brand-name,
.login-brand-name {
    overflow: hidden;
    color: var(--primary-strong);
    font-weight: 800;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.brand-text small,
.admin-sidebar-brand-subtitle,
.login-brand-subtitle {
    color: var(--text-muted);
    font-size: .84rem;
}

.topnav {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.topnav a {
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    padding: 7px 10px;
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    text-decoration: none;
    font-weight: 700;
}

.topnav a:hover { background: var(--surface-muted); color: var(--primary); }
.topnav .btn-nav { background: var(--primary); color: #fff; }
.topnav .btn-nav:hover { background: var(--primary-strong); color: #fff; }

.hero {
    background: #edf3f8;
    border-bottom: 1px solid var(--line);
}

.hero-grid {
    max-width: 1180px;
    margin: 0 auto;
    padding: 64px 24px;
    display: grid;
    grid-template-columns: minmax(0, 1.04fr) minmax(300px, .96fr);
    gap: 44px;
    align-items: center;
}

.hero-eyebrow {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 4px 10px;
    margin-bottom: 16px;
    border: 1px solid #b9cbe0;
    border-radius: 999px;
    background: #fff;
    color: var(--primary);
    font-size: .84rem;
    font-weight: 800;
}

.hero h1 {
    max-width: 680px;
    margin-bottom: 18px;
    font-size: 2.45rem;
}

.hero h1 .accent { color: var(--accent); }

.hero-lead {
    max-width: 640px;
    color: var(--text-muted);
    font-size: 1.05rem;
}

.hero-cta,
.ui-actions,
.row-actions,
.register-actions,
.admin-create-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.hero-visual {
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-shield {
    max-width: 380px;
    color: var(--primary);
}

.stats {
    max-width: 1180px;
    margin: 24px auto 0;
    padding: 0 24px;
}

.stats-grid,
.info-grid,
.kpi-grid,
.admin-create-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 12px;
}

dialog.internal-user-dialog {
    width: min(760px, calc(100vw - 32px));
}

.internal-user-dialog .admin-create-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.internal-user-dialog .admin-create-actions {
    grid-column: 1 / -1;
    justify-content: flex-end;
}

.stat,
.kpi-card,
.admin-role-stat-card,
.info-grid > div {
    min-width: 0;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.stat-value,
.kpi-value,
.admin-role-stat-value,
.score-value {
    color: var(--primary-strong);
    font-size: 1.65rem;
    font-weight: 850;
    line-height: 1.1;
}

.stat-label,
.kpi-label,
.score-label,
.kpi-hint {
    color: var(--text-muted);
    font-size: .88rem;
}

.kpi-card {
    color: inherit;
    text-decoration: none;
}

.kpi-grid {
    margin-bottom: 24px;
}

.kpi-card:hover {
    border-color: var(--line-strong);
    box-shadow: var(--shadow-md);
}

.kpi-action {
    border-left: 4px solid var(--warning);
}

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

.section,
.security-section,
.cta-section {
    max-width: 1180px;
    margin: 0 auto;
    padding: 56px 24px;
}

.page-hero {
    padding: 48px 24px;
    border-bottom: 1px solid var(--line);
    background: #edf3f8;
}

.page-hero-inner {
    max-width: 980px;
    margin: 0 auto;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    margin-bottom: 14px;
    padding: 4px 10px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
    color: var(--primary);
    font-size: .82rem;
    font-weight: 850;
}

.content {
    max-width: 980px;
    margin: 0 auto;
    padding: 36px 24px 56px;
}

.section-header {
    max-width: 720px;
    margin-bottom: 28px;
}

.steps-grid,
.security-grid,
.security-features,
.security-certs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
}

.step,
.security-feature,
.cert-badge,
.cta-card {
    padding: 20px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.step-num,
.step-icon,
.security-feature-icon {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
    border-radius: var(--radius-sm);
    background: var(--primary-soft);
    color: var(--primary);
    font-weight: 800;
}

.lead { color: var(--text-muted); font-size: 1.02rem; }
.cert-badge-title { font-weight: 850; color: var(--primary-strong); }
.cert-badge-desc { margin-top: 4px; color: var(--text-muted); font-size: .9rem; }

.app-footer {
    padding: 28px 24px;
    color: var(--text-muted);
    text-align: center;
}

.footer {
    padding: 28px 24px;
    border-top: 1px solid var(--line);
    background: #fff;
    color: var(--text-muted);
}

.footer-inner {
    max-width: 1180px;
    margin: 0 auto 16px;
    display: grid;
    grid-template-columns: minmax(240px, 1fr) repeat(2, minmax(160px, 220px));
    gap: 24px;
    text-align: left;
}

.footer-col {
    display: grid;
    gap: 8px;
}

.footer-col strong,
.footer-brand { color: var(--primary-strong); }
.footer-bottom { border-top: 1px solid var(--line); padding-top: 16px; }

/* Layouts */
.admin-shell,
.supplier-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
}

.admin-sidebar,
.supplier-sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    display: flex;
    flex-direction: column;
    gap: 20px;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 20px 16px;
    border-right: 1px solid var(--line);
    background: #ffffff;
}

.admin-sidebar-logo-fallback {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
}

.admin-sidebar-brand {
    width: 100%;
}

img.admin-sidebar-logo + .admin-sidebar-brand-text {
    display: none;
}

.admin-sidebar-nav {
    display: grid;
    gap: 12px;
}

.admin-nav-section {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
}

.admin-nav-section-title {
    list-style: none;
    cursor: pointer;
    padding: 10px 12px;
    color: var(--text-muted);
    font-size: .78rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0;
}

.admin-nav-section-title::-webkit-details-marker { display: none; }

.app-nav-group-links {
    display: grid;
    gap: 3px;
    padding: 0 8px 8px;
}

.admin-nav-link {
    display: flex;
    align-items: center;
    min-height: 38px;
    padding: 8px 10px;
    border-radius: var(--radius-sm);
    color: var(--text);
    text-decoration: none;
    font-weight: 750;
}

.admin-nav-link:hover,
.admin-nav-link.is-active {
    background: var(--primary-soft);
    color: var(--primary-strong);
}

.admin-sidebar-footer {
    margin-top: auto;
    padding-top: 14px;
    border-top: 1px solid var(--line);
}

.admin-sidebar-user-name { font-weight: 850; color: var(--primary-strong); }
.admin-sidebar-user-role { color: var(--text-muted); font-size: .86rem; }

.admin-workspace,
.supplier-workspace {
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.admin-pagebar,
.supplier-pagebar {
    position: sticky;
    top: 0;
    z-index: 60;
    min-height: 72px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 24px;
    border-bottom: 1px solid var(--line);
    background: rgba(255, 255, 255, .96);
}

.admin-page-kicker {
    color: var(--text-muted);
    font-size: .78rem;
    font-weight: 850;
    text-transform: uppercase;
}

.admin-pagebar h1 {
    margin: 2px 0 0;
    font-size: 1.55rem;
}

.admin-page-actions { display: flex; align-items: center; justify-content: flex-end; }

.admin-content,
.supplier-content {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 24px;
}

.admin-footer { margin-top: auto; border-top: 1px solid var(--line); background: #fff; }

.admin-account-menu {
    position: relative;
}

.admin-account-menu > summary {
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 10px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    cursor: pointer;
    list-style: none;
    font-weight: 800;
}

.admin-account-menu > summary::-webkit-details-marker { display: none; }
.admin-account-menu > summary span { color: var(--text-muted); font-weight: 650; }

.admin-account-dropdown {
    position: absolute;
    right: 0;
    top: calc(100% + 8px);
    z-index: 200;
    min-width: 230px;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    box-shadow: var(--shadow-md);
}

.admin-account-dropdown a {
    display: block;
    padding: 9px 10px;
    border-radius: var(--radius-sm);
    color: var(--text);
    text-decoration: none;
    font-weight: 700;
}

.admin-account-dropdown a:hover { background: var(--surface-muted); color: var(--primary); }

/* Cards and sections */
.card,
.action-section,
.login-wrap,
.verify-card,
.register-card {
    margin-bottom: 18px;
    padding: 20px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.ui-toolbar,
.action-section-header,
.register-section-header,
.questionnaire-panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.action-section-header {
    align-items: center;
    margin-bottom: 12px;
}

.action-link {
    margin-left: auto;
    white-space: nowrap;
    font-weight: 800;
}

.empty-state {
    text-align: center;
}

.empty-state-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    margin-bottom: 12px;
    padding: 4px 10px;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--text-muted);
    font-size: .84rem;
    font-weight: 800;
}

/* Forms */
.form-row { margin-bottom: 15px; }

label {
    display: block;
    margin-bottom: 6px;
    color: var(--text);
    font-weight: 800;
}

input[type=text],
input[type=email],
input[type=password],
input[type=number],
input[type=date],
input[type=file],
input[type=search],
textarea,
select {
    width: 100%;
    min-height: 40px;
    padding: 9px 10px;
    border: 1px solid var(--line-strong);
    border-radius: var(--radius-sm);
    background: #fff;
    color: var(--text);
    font: inherit;
}

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

input:focus,
textarea:focus,
select:focus {
    outline: 3px solid rgba(37, 125, 106, .18);
    border-color: var(--accent);
}

input[readonly],
input:disabled,
textarea:disabled,
select:disabled {
    background: #f2f5f8;
    color: var(--text-muted);
}

input[type=checkbox],
input[type=radio] {
    width: auto;
    min-height: 0;
}

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

.full,
.register-grid .full,
.installer-full-row { grid-column: 1 / -1; }

.switch-line,
.checkbox-line {
    display: inline-flex;
    align-items: flex-start;
    gap: 8px;
    padding: 9px 10px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
    font-weight: 750;
}

.radio-group,
.radio-list {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.radio-group label,
.radio-list label,
.radio-item {
    display: inline-flex;
    align-items: flex-start;
    gap: 8px;
    margin: 0;
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
    font-weight: 750;
}

.checklist-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 10px;
}

.checklist-item {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    margin: 0;
    padding: 11px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
    font-weight: 650;
}

.checklist-item:hover,
.radio-item:hover,
.radio-group label:hover,
.radio-list label:hover {
    border-color: var(--line-strong);
    background: #fff;
}

/* Buttons */
button,
.btn,
.btn-primary,
.btn-secondary,
.btn-danger,
.btn-success,
.btn-submit {
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 9px 14px;
    border: 1px solid transparent;
    border-radius: var(--radius-sm);
    font: inherit;
    font-weight: 850;
    line-height: 1.2;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
}

button,
.btn,
.btn-primary,
.btn-submit,
.btn:not(.btn-secondary):not(.btn-danger):not(.btn-success) {
    background: var(--primary);
    color: #fff;
}

button:hover,
.btn:hover,
.btn-primary:hover,
.btn-submit:hover {
    background: var(--primary-strong);
    color: #fff;
}

.btn-secondary {
    border-color: var(--line-strong);
    background: #fff;
    color: var(--text);
}

.btn-secondary:hover {
    background: var(--surface-muted);
    color: var(--primary);
}

.btn-danger { background: var(--danger); color: #fff; }
.btn-danger:hover { background: #8f1d14; color: #fff; }
.btn-success { background: var(--success); color: #fff; }
.btn-success:hover { background: #10672f; color: #fff; }

.btn-sm {
    min-height: 32px;
    padding: 6px 10px;
    font-size: .86rem;
}

.full-width-action,
.full-width-warning-action { width: 100%; }

button:focus-visible,
.btn:focus-visible,
summary:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: 3px solid rgba(37, 125, 106, .2);
    outline-offset: 2px;
}

button[disabled],
.btn[disabled] {
    border-color: var(--line-strong);
    background: #e7edf3;
    color: var(--text-muted);
    opacity: 1;
    cursor: not-allowed;
}

/* Alerts and badges */
.alert,
.notice {
    margin-bottom: 16px;
    padding: 12px 14px;
    border: 1px solid transparent;
    border-radius: var(--radius);
    background: var(--surface-muted);
}

.alert-success { background: #ecf8ef; border-color: #bfe5c9; color: #0f5f2c; }
.alert-error { background: #fff0ee; border-color: #f3beb7; color: #8f1d14; }
.alert-warning { background: #fff6e6; border-color: #f2d39b; color: #7b4b00; }
.alert-info { background: #edf5ff; border-color: #bfd8f5; color: #164c8b; }

.badge,
.count-badge,
.code-pill,
code,
.role-token,
.score-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-height: 24px;
    max-width: 100%;
    padding: 3px 8px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--surface-muted);
    color: var(--text);
    font-size: .8rem;
    font-weight: 850;
    white-space: nowrap;
    word-break: keep-all;
    overflow-wrap: normal;
}

.badge-draft,
.badge-not-started,
.badge-draft-only { background: #f1f4f7; color: #526172; border-color: #d7e0ea; }
.badge-submitted { background: #e9f2ff; color: var(--info); border-color: #c1d8f3; }
.badge-under-review,
.badge-review { background: #fff3df; color: var(--warning); border-color: #f2d29a; }
.badge-approved,
.badge-active { background: #e9f7ef; color: var(--success); border-color: #bfe4cb; }
.badge-rejected,
.badge-revoked,
.badge-cancelled { background: #fff0ee; color: var(--danger); border-color: #f3beb7; }
.count-badge.urgent { background: #fff3df; color: var(--warning); border-color: #f2d29a; }

/* Tables */
.table-wrap,
.compact-table-wrap,
.audit-table-wrap,
.forms-table-wrap,
.homologations-table-wrap,
.scopes-table-wrap,
.supplier-scopes-table-wrap,
.suppliers-table-wrap {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: visible;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface);
}

table {
    width: 100%;
    min-width: 860px;
    border-collapse: separate;
    border-spacing: 0;
}

th,
td {
    padding: 11px 12px;
    border-bottom: 1px solid var(--line);
    text-align: left;
    vertical-align: top;
    font-size: .92rem;
    word-break: normal;
    overflow-wrap: break-word;
}

th {
    position: sticky;
    top: 0;
    z-index: 1;
    background: #f2f6fa;
    color: #536174;
    font-size: .76rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0;
}

tbody tr:last-child td { border-bottom: 0; }
tbody tr:hover td { background: #fbfdff; }

.table-tools {
    position: sticky;
    left: 0;
    z-index: 2;
    display: flex;
    justify-content: flex-end;
    margin: 0;
    padding: 10px;
    border-bottom: 1px solid var(--line);
    background: var(--surface);
}

.table-tools input {
    max-width: 320px;
}

.homologations-table {
    min-width: 1180px;
}

.compact-table-wrap table {
    min-width: 0;
    table-layout: fixed;
}

.compact-table-wrap th,
.compact-table-wrap td {
    overflow-wrap: anywhere;
}

.compact-table-wrap td:first-child {
    max-width: 0;
}

.audit-filter-actions {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 14px;
    margin-top: 2px;
}

.audit-limit-field {
    min-width: 170px;
    margin-bottom: 0;
}

.audit-filter-buttons {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

th[data-sortable="1"] {
    cursor: pointer;
}

th[data-sort-dir="asc"]::after { content: " ↑"; }
th[data-sort-dir="desc"]::after { content: " ↓"; }

.actions-cell {
    width: 1%;
    white-space: nowrap;
}

.row-action-menu {
    position: relative;
    display: inline-block;
}

.row-action-menu > summary {
    min-height: 32px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border: 1px solid var(--line-strong);
    border-radius: var(--radius-sm);
    background: #fff;
    color: var(--text);
    cursor: pointer;
    list-style: none;
    font-weight: 850;
}

.row-action-menu > summary::-webkit-details-marker { display: none; }
.row-action-menu[open] > summary { border-color: var(--accent); background: var(--accent-soft); color: var(--accent); }

.row-action-dropdown {
    display: none;
    width: 260px;
    min-width: 220px;
    max-width: calc(100vw - 20px);
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    box-shadow: var(--shadow-md);
    overflow: auto;
    z-index: 500;
}

.row-action-menu[open] .row-action-dropdown,
.row-action-dropdown[data-menu-portal="1"] {
    display: grid;
    gap: 5px;
}

.row-action-dropdown a,
.row-action-dropdown button,
.row-action-dropdown form {
    width: 100%;
    min-width: 0;
}

.row-action-dropdown a,
.row-action-dropdown button {
    justify-content: flex-start;
}

tr.action-menu-row-open,
td.actions-cell.action-menu-open {
    position: relative;
    z-index: 3;
}

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

/* Progress */
.completion-widget {
    display: grid;
    gap: 7px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
}

.completion-widget-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    color: var(--text-muted);
    font-size: .86rem;
    font-weight: 800;
}

.completion-widget-head strong { color: var(--primary-strong); }

.completion-progress,
progress {
    width: 100%;
    height: 8px;
    overflow: hidden;
    border: 0;
    border-radius: 999px;
    background: #e5ecf3;
}

progress::-webkit-progress-bar { background: #e5ecf3; border-radius: 999px; }
progress::-webkit-progress-value { background: var(--primary); border-radius: 999px; }
progress::-moz-progress-bar { background: var(--primary); border-radius: 999px; }
.progress-low::-webkit-progress-value { background: var(--danger); }
.progress-mid::-webkit-progress-value { background: var(--warning); }
.progress-high::-webkit-progress-value { background: var(--info); }
.progress-complete::-webkit-progress-value { background: var(--success); }
.progress-low::-moz-progress-bar { background: var(--danger); }
.progress-mid::-moz-progress-bar { background: var(--warning); }
.progress-high::-moz-progress-bar { background: var(--info); }
.progress-complete::-moz-progress-bar { background: var(--success); }

.progress-detail { color: var(--text-muted); font-size: .86rem; }

/* Dialogs and overlays */
dialog.modal-dialog,
dialog.modal-dialog[open] {
    width: min(920px, calc(100vw - 32px));
    max-width: calc(100vw - 32px);
    max-height: calc(100vh - 32px);
    padding: 0;
    border: 0;
    border-radius: var(--radius);
    background: transparent;
}

dialog.modal-dialog::backdrop {
    background: rgba(15, 23, 42, .46);
}

.modal-panel {
    max-height: calc(100vh - 32px);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    box-shadow: var(--shadow-md);
}

.modal-header {
    position: relative;
    padding: 18px 60px 16px 20px;
    border-bottom: 1px solid var(--line);
    background: #fff;
}

.modal-body {
    padding: 20px;
    overflow: auto;
}

.modal-close {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 36px;
    min-height: 36px;
    padding: 0;
    border-color: var(--line);
    background: #fff;
    color: var(--text);
}

.submit-overlay {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(15, 23, 42, .42);
}

.submit-overlay.is-visible {
    display: flex;
}

.submit-overlay-card {
    width: min(420px, 100%);
    padding: 20px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    box-shadow: var(--shadow-md);
}

.progress-shell {
    height: 8px;
    overflow: hidden;
    border-radius: 999px;
    background: #e5ecf3;
}

.progress-bar-indeterminate {
    width: 42%;
    height: 100%;
    border-radius: inherit;
    background: var(--primary);
    animation: progress-scan 1.1s ease-in-out infinite;
}

@keyframes progress-scan {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(240%); }
}

/* Login, registration and verification */
.login-wrap {
    max-width: 430px;
    margin: 56px auto;
}

.login-brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
    text-align: center;
}

.login-brand-logo,
.login-brand-fallback {
    width: 64px;
    height: 64px;
    flex-basis: 64px;
}

.login-brand-fallback {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
    font-size: 1.15rem;
}

.login-note,
.login-links,
.register-note,
.empty-message {
    text-align: center;
}

.register-wrap {
    max-width: 920px;
    margin: 42px auto 56px;
    padding: 0 20px;
}

.register-header {
    margin-bottom: 22px;
    text-align: center;
}

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

.wizard-step {
    min-height: 44px;
    justify-content: flex-start;
    border-color: var(--line);
    background: #fff;
    color: var(--text);
}

.wizard-step span,
.register-section-number {
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--surface-muted);
    color: var(--text-muted);
    font-weight: 900;
}

.wizard-step.is-active,
.wizard-step[aria-current="step"] {
    border-color: var(--primary);
    background: var(--primary-soft);
    color: var(--primary-strong);
}

.wizard-step.is-active span,
.wizard-step[aria-current="step"] span,
.register-section-number {
    background: var(--primary);
    color: #fff;
}

.wizard-step.is-done {
    border-color: #bfe4cb;
    background: #ecf8ef;
    color: var(--success);
}

.wizard-step.is-done span { background: var(--success); color: #fff; }

.register-step { display: none; }
.register-step.is-active { display: block; }

.register-section + .register-section {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--line);
}

.register-section-header {
    justify-content: flex-start;
    align-items: center;
    margin-bottom: 8px;
}

.register-section-title { font-weight: 850; color: var(--primary-strong); }
.register-section-hint { margin: 0 0 15px 38px; color: var(--text-muted); }
.register-actions { justify-content: space-between; padding-top: 16px; border-top: 1px solid var(--line); }
.register-actions-end { justify-content: flex-end; }
.register-actions-split { justify-content: space-between; }
.back-link { font-weight: 800; text-decoration: none; }

.verify-shell {
    width: min(900px, calc(100vw - 32px));
    max-width: none;
    padding: 0;
}

.verify-brand {
    max-width: 100%;
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
}

.verify-brand > div {
    min-width: 0;
}

.verify-brand h1,
.verify-brand p {
    overflow-wrap: break-word;
}

.verify-brand p {
    max-width: 68ch;
}

.verify-status { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.verify-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 10px;
}

.verify-grid div {
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
}

.verify-grid dt {
    margin: 0;
    color: var(--text-muted);
    font-size: .78rem;
    font-weight: 850;
    text-transform: uppercase;
}

.verify-grid dd { margin: 4px 0 0; font-weight: 800; }

/* Dashboard and supplier home */
.dashboard-priority-line {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.dashboard-priority-separator { color: var(--text-muted); }
.count-link { font-weight: 900; }

.supplier-task-section {
    margin-bottom: 24px;
}

.supplier-section-heading {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 8px;
}

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

.supplier-task-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-width: 0;
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    box-shadow: var(--shadow-sm);
}

.supplier-task-card.is-required {
    border-left: 4px solid var(--warning);
}

.supplier-task-card.is-draft {
    border-left: 4px solid var(--info);
}

.supplier-task-badge {
    align-self: flex-start;
}

.supplier-task-card h3 {
    padding-right: 0;
}

.supplier-task-meta {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--text-muted);
    font-size: .86rem;
}

.supplier-task-action {
    margin-top: auto;
}

.summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 12px;
}

.summary-tile {
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
}

.summary-tile-value {
    color: var(--primary-strong);
    font-size: 1.55rem;
    font-weight: 900;
}

.summary-tile-label {
    color: var(--text-muted);
    font-size: .86rem;
    font-weight: 750;
}

.result-notification-list {
    display: grid;
    gap: 10px;
    margin: 16px 0;
}

.result-notification-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
}

.result-notification-title { font-weight: 850; }
.result-notification-meta { color: var(--text-muted); font-size: .88rem; }

/* Questionnaire and analyst workbench */
.questionnaire-workspace-page {
    padding: 0;
    overflow: visible;
}

.questionnaire-topbar {
    position: sticky;
    top: 72px;
    z-index: 40;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 20px;
    border-bottom: 1px solid var(--line);
    border-radius: var(--radius) var(--radius) 0 0;
    background: rgba(255, 255, 255, .98);
}

.questionnaire-topbar > div:first-child {
    flex: 1 1 360px;
    min-width: min(360px, 100%);
}

.questionnaire-topbar-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
    max-width: 100%;
}

.questionnaire-workspace {
    display: grid;
    grid-template-columns: minmax(230px, 280px) minmax(0, 1fr);
    gap: 20px;
    padding: 20px;
    align-items: start;
}

.questionnaire-rail {
    position: sticky;
    top: 154px;
    display: grid;
    gap: 12px;
    max-height: calc(100vh - 176px);
    overflow-y: auto;
    overflow-x: hidden;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
}

.questionnaire-nav {
    display: grid;
    gap: 6px;
}

.questionnaire-nav a {
    min-height: 36px;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border: 1px solid transparent;
    border-radius: var(--radius-sm);
    color: var(--text);
    text-decoration: none;
    font-weight: 800;
    min-width: 0;
}

.questionnaire-nav a:hover,
.questionnaire-nav a.is-active {
    border-color: var(--line);
    background: #fff;
    color: var(--primary);
}

.questionnaire-nav a.is-complete {
    color: var(--success);
}

.questionnaire-nav small {
    min-width: 0;
    overflow: hidden;
    color: var(--text-muted);
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 650;
}

.questionnaire-main {
    display: grid;
    gap: 16px;
    min-width: 0;
}

.questionnaire-panel {
    min-width: 0;
    padding: 20px;
    scroll-margin-top: 160px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    box-shadow: var(--shadow-sm);
}

.question-grid,
.analysis-question-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}

.analysis-question-grid {
    grid-template-columns: minmax(0, 1fr);
}

.question-primary,
.analysis-fields {
    min-width: 0;
}

.review-wizard-meta,
.supplier-answer-meta {
    margin-bottom: 8px;
    color: var(--text-muted);
    font-size: .86rem;
    font-weight: 800;
}

.question-help-panel,
.analysis-help-panel,
.review-wizard-answer,
.supplier-answer-value,
.attachment-list-card,
.requirement-box,
.supplier-requirement,
.question-requirement-box,
.analyst-requirement,
.review-reference-box {
    min-width: 0;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
    word-break: normal;
    overflow-wrap: break-word;
}

.question-help-details + .question-help-details {
    margin-top: 10px;
}

.question-help-details summary {
    cursor: pointer;
    list-style: none;
    color: var(--primary-strong);
    font-weight: 850;
}

.question-help-details summary::-webkit-details-marker { display: none; }

.answer-zone {
    margin-top: 14px;
}

.question-primary h3 {
    max-width: 72ch;
    font-size: 1.22rem;
    line-height: 1.35;
    word-break: normal;
    overflow-wrap: break-word;
}

.question-card textarea {
    min-height: 180px;
}

.analysis-question-card .analysis-help-panel {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 12px;
}

.analysis-question-card .score-chip {
    min-height: 100%;
}

.analysis-question-card .question-help-details {
    margin: 0;
}

.analysis-question-card .analysis-fields {
    display: grid;
    grid-template-columns: minmax(180px, 240px) minmax(0, 1fr);
    gap: 16px;
    align-items: start;
}

.analysis-validate-row {
    grid-column: 1 / -1;
    display: flex;
    justify-content: flex-end;
    margin-bottom: 0;
}

.autosave-status {
    font-size: .86rem;
    line-height: 1.35;
}

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

.analysis-decision-grid-wide,
.analysis-decision-panel {
    grid-column: 1 / -1;
}

.score-card {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
}

.score-card > div {
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
}

.attachment-list {
    display: grid;
    gap: 8px;
    padding-left: 0;
    list-style: none;
}

.attachment-list li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: #fff;
}

.submission-error-banner {
    border-left: 4px solid var(--danger);
}

.submission-error-layout {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.submission-error-title {
    display: block;
    margin-bottom: 6px;
    font-size: 1rem;
}

.submission-error-help {
    margin: 8px 0 0;
    font-size: .92rem;
}

.readonly-score-panel {
    margin-top: 14px;
    padding: 16px;
    border-radius: var(--radius);
    background: var(--primary-strong);
    color: #fff;
}

.readonly-score-grid {
    display: flex;
    align-items: center;
    gap: 28px;
    flex-wrap: wrap;
}

.readonly-score-label {
    opacity: .82;
    font-size: .82rem;
}

.readonly-score-value {
    font-size: 1.35rem;
    font-weight: 900;
}

.review-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 12px;
    margin-top: 16px;
}

.review-summary-tile {
    padding: 14px;
    border-radius: var(--radius);
    background: var(--surface-muted);
}

.review-summary-label {
    color: var(--text-muted);
    font-size: .78rem;
    font-weight: 850;
}

.review-summary-value {
    margin-top: 4px;
    font-weight: 850;
}

.review-summary-score {
    color: var(--primary-strong);
    font-size: 1.25rem;
}

.management-form,
.stacked-form,
.spaced-form {
    margin-top: 16px;
}

.form-actions,
.action-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 16px;
}

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

.wide-actions-select {
    min-width: 180px;
}

.filter-input {
    max-width: 420px;
}

.selection-list-scroll {
    max-height: 300px;
    overflow: auto;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
}

.textarea-compact {
    min-height: 64px;
}

.password-output {
    display: block;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
    color: var(--primary-strong);
    font-size: 1.05rem;
    white-space: pre-wrap;
}

.password-change-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px 18px;
    max-width: 820px;
}

.password-change-form .form-row {
    margin-bottom: 0;
}

.password-current-row,
.password-actions {
    grid-column: 1 / -1;
}

.table-actions-column {
    width: 320px;
}

.content-preview {
    font-size: .86rem;
}

.status-approved { color: var(--success); }
.status-rejected,
.status-danger { color: var(--danger); }
.status-muted { color: var(--text-muted); }
.status-warning { color: var(--warning); }
.text-small { font-size: .86rem; }
.text-normal { font-weight: 400; }
.text-center { text-align: center; }
.mt-1 { margin-top: 8px; }
.mt-2 { margin-top: 14px; }
.mt-3 { margin-top: 20px; }
.mb-2 { margin-bottom: 14px; }

/* Settings and admin details */
.settings-accordion > summary {
    cursor: pointer;
    list-style: none;
    font-size: 1.1rem;
    font-weight: 900;
    color: var(--primary-strong);
}

.settings-accordion > summary::-webkit-details-marker { display: none; }
.settings-accordion-body { padding-top: 16px; }

.legal-logo-preview {
    width: 72px;
    max-height: 52px;
    object-fit: contain;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: #fff;
    padding: 6px;
}

.supplier-registration-toggle {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface-muted);
}

.supplier-registration-toggle.is-enabled { border-color: #bfe4cb; background: #ecf8ef; }
.supplier-registration-toggle.is-disabled { border-color: #f3beb7; background: #fff0ee; }

.password-policy-meter {
    display: grid;
    gap: 8px;
    margin-top: 8px;
}

.password-policy-meter-bar {
    height: 6px;
    overflow: hidden;
    border-radius: 999px;
    background: #e5ecf3;
}

.password-policy-meter-fill {
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: var(--warning);
}

.password-policy-meter-fill.is-strong { background: var(--success); }

.password-policy-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 5px 10px;
    margin: 0;
    padding: 0;
    list-style: none;
    color: var(--text-muted);
    font-size: .82rem;
}

.password-policy-list li.is-ok { color: var(--success); font-weight: 800; }
.password-confirm-meter { margin-top: 6px; font-size: .86rem; }
.password-confirm-meter.is-ok { color: var(--success); }
.password-confirm-meter.is-error { color: var(--danger); }

/* Install page helpers */
body.install-body {
    min-height: 100vh;
    background: #eef3f7;
}

.installer {
    width: min(1120px, calc(100vw - 32px));
    max-width: none;
    margin: 0 auto;
    padding: 32px 0 56px;
}

.installer-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 18px;
    padding: 24px 28px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.installer-kicker {
    margin: 0 0 6px;
    color: var(--primary);
    font-size: .82rem;
    font-weight: 900;
    text-transform: uppercase;
}

.installer-title {
    margin: 0;
    color: var(--primary-strong);
    font-size: 2rem;
    line-height: 1.15;
}

.installer-subtitle {
    max-width: 680px;
    margin: 10px 0 0;
    color: var(--text-muted);
    font-size: 1rem;
}

.installer-version {
    flex: 0 0 auto;
    padding: 7px 10px;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
    color: var(--text-muted);
    font-weight: 900;
}

.installer .card {
    padding: 28px 36px;
}

.installer .card > h2 {
    margin-bottom: 22px;
    color: var(--primary-strong);
    font-size: 1.35rem;
}

.installer .grid-2 {
    gap: 18px 26px;
}

.installer hr {
    margin: 24px 0 18px;
    border: 0;
    border-top: 1px solid var(--line);
}

.installer-option-line {
    margin-bottom: 16px;
    padding: 12px 14px;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
}

.installer-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 18px;
}

.installer-actions-end { justify-content: flex-end; }
.installer-actions-between { justify-content: space-between; }
.installer-grid-spaced { display: grid; gap: 16px; }
.installer-separator { border-top: 1px solid var(--line); margin-top: 16px; padding-top: 16px; }
.installer-success-title { color: var(--success); }

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

.installer-steps div {
    min-height: 68px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--text-muted);
    font-weight: 800;
    box-shadow: var(--shadow-sm);
}

.installer-step-number {
    width: 30px;
    height: 30px;
    flex: 0 0 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: #dfe7ef;
    color: var(--text);
    font-size: .9rem;
    font-weight: 900;
}

.installer-step-copy {
    min-width: 0;
    display: grid;
    gap: 2px;
}

.installer-step-copy strong {
    color: var(--text);
    font-size: .92rem;
    white-space: nowrap;
}

.installer-step-copy small {
    color: var(--text-muted);
    font-size: .78rem;
    font-weight: 700;
    white-space: nowrap;
}

.installer-steps .active {
    border-color: var(--primary);
    background: var(--primary-soft);
}

.installer-steps .active .installer-step-number {
    background: var(--primary);
    color: #fff;
}

.installer-steps .done {
    border-color: #bfe4cb;
    background: #ecf8ef;
}

.installer-steps .done .installer-step-number {
    background: var(--success);
    color: #fff;
}

.check-list {
    margin: 0;
    padding: 0;
    list-style: none;
}
.check-list li {
    padding: 9px 0;
    border-bottom: 1px solid var(--line);
}

.check-list li:last-child {
    border-bottom: 0;
}
.check-list .ok { color: var(--success); }
.check-list .ko { color: var(--danger); font-weight: 800; }

/* Responsive */
@media (max-width: 1080px) {
    .admin-shell,
    .supplier-shell {
        grid-template-columns: 1fr;
    }

    .admin-sidebar,
    .supplier-sidebar {
        position: static;
        height: auto;
        max-height: none;
        border-right: 0;
        border-bottom: 1px solid var(--line);
    }

    .admin-sidebar-nav {
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    }

    .admin-sidebar-footer { display: none; }
    .questionnaire-topbar { top: 0; }
    .questionnaire-workspace { grid-template-columns: 1fr; }
    .questionnaire-rail {
        position: sticky;
        top: 0;
        z-index: 35;
        max-height: none;
        overflow: visible;
    }
    .questionnaire-nav {
        display: flex;
        overflow-x: auto;
        padding-bottom: 4px;
    }
    .questionnaire-nav a {
        flex: 0 0 150px;
    }

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

@media (max-width: 820px) {
    body { font-size: 14px; }
    main,
    .admin-content,
    .supplier-content {
        padding: 16px;
    }

    .topbar-inner,
    .admin-pagebar,
    .supplier-pagebar,
    .hero-grid,
    .footer-inner {
        grid-template-columns: 1fr;
        flex-direction: column;
        align-items: flex-start;
    }

    .hero-grid {
        padding: 40px 20px;
    }

    .hero h1 {
        font-size: 2rem;
    }

    .hero-visual {
        justify-content: flex-start;
    }

    .grid-2,
    .register-grid,
    .admin-create-grid,
    .internal-user-dialog .admin-create-grid,
    .password-change-form,
    .analysis-question-card .analysis-fields,
    .analysis-decision-grid,
    .question-grid,
    .analysis-question-grid,
    .security-grid {
        grid-template-columns: 1fr;
    }

    .ui-toolbar,
    .action-section-header,
    .questionnaire-panel-head,
    .audit-filter-actions,
    .questionnaire-topbar {
        flex-direction: column;
    }

    .questionnaire-topbar-actions,
    .questionnaire-topbar-actions .btn,
    .questionnaire-topbar-actions button,
    .register-actions,
    .register-actions > *,
    .modal-body .btn,
    .modal-body button {
        width: 100%;
    }

    .verify-shell {
        width: calc(100vw - 24px);
    }

    .verify-brand {
        align-items: flex-start;
    }

    .wizard-steps {
        grid-template-columns: 1fr;
    }

    .installer {
        width: calc(100vw - 24px);
        padding: 16px 0 32px;
    }

    .installer-hero {
        flex-direction: column;
        padding: 20px;
    }

    .installer-title {
        font-size: 1.65rem;
    }

    .installer .card {
        padding: 20px;
    }

    .installer-steps {
        grid-template-columns: 1fr;
    }

    .installer-step-copy strong,
    .installer-step-copy small {
        white-space: normal;
    }

    .installer-actions-end,
    .installer-actions-between {
        align-items: stretch;
        flex-direction: column;
    }

    .installer-actions-end button,
    .installer-actions-between .btn,
    .installer-actions-between button {
        width: 100%;
    }

    .audit-limit-field,
    .audit-filter-buttons,
    .audit-filter-buttons .btn,
    .audit-filter-buttons button {
        width: 100%;
    }

    .footer-inner {
        display: grid;
        text-align: left;
    }

    table.responsive-table thead {
        display: none;
    }

    table.responsive-table {
        min-width: 0;
    }

    table.responsive-table tbody,
    table.responsive-table tr,
    table.responsive-table td {
        display: block;
        width: 100%;
    }

    table.responsive-table tr {
        margin-bottom: 12px;
        overflow: hidden;
        border: 1px solid var(--line);
        border-radius: var(--radius);
        background: #fff;
    }

    table.responsive-table td {
        min-width: 0;
        padding: 10px 12px;
        border-bottom: 1px solid var(--line);
        background: #fff;
        text-align: left;
        white-space: normal;
    }

    table.responsive-table td::before {
        content: attr(data-label);
        display: block;
        margin-bottom: 3px;
        color: var(--text-muted);
        font-size: .72rem;
        font-weight: 900;
        text-transform: uppercase;
    }

    table.responsive-table td:last-child {
        border-bottom: 0;
    }

    .actions-cell {
        width: 100%;
        white-space: normal;
    }

    .inline-form {
        width: 100%;
        flex-direction: column;
        align-items: stretch;
    }

    .attachment-list li,
    .result-notification-item,
    .readonly-score-grid {
        align-items: stretch;
        flex-direction: column;
    }
}

@media (max-width: 520px) {
    .card,
    .action-section,
    .register-card,
    .questionnaire-panel,
    .modal-body {
        padding: 14px;
    }

    .admin-sidebar,
    .supplier-sidebar,
    .questionnaire-workspace {
        padding: 14px;
    }

    .topnav,
    .hero-cta,
    .ui-actions,
    .row-actions,
    .form-actions,
    .action-row {
        width: 100%;
    }

    .topnav a,
    .hero-cta .btn,
    .hero-cta .btn-primary,
    .hero-cta .btn-secondary,
    .ui-actions .btn,
    .ui-actions button {
        width: 100%;
    }

    .verify-brand {
        flex-direction: column;
    }
}

.compact-list {
    margin: 8px 0 0;
    padding-left: 20px;
}

.compact-list li {
    margin: 4px 0;
}

.readonly-field {
    min-height: 42px;
    display: flex;
    align-items: center;
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--soft);
    color: var(--text);
    font-weight: 700;
}

@media (prefers-color-scheme: dark) {
    :root {
        color-scheme: dark;
        --bg: #0f172a;
        --surface: #111827;
        --surface-strong: #1f2937;
        --soft: #172033;
        --line: #334155;
        --text: #e5edf8;
        --text-muted: #a7b4c7;
        --primary: #60a5fa;
        --primary-dark: #93c5fd;
        --primary-soft: rgba(96, 165, 250, .18);
        --success: #34d399;
        --warning: #fbbf24;
        --danger: #f87171;
        --shadow: 0 18px 48px rgba(0, 0, 0, .42);
    }

    body,
    .admin-shell,
    .supplier-shell,
    .register-wrap,
    .public-page,
    .installer-page,
    .install-body,
    .installer {
        background: var(--bg);
        color: var(--text);
    }

    .card,
    .action-section,
    .register-card,
    .questionnaire-panel,
    .modal-panel,
    .modal-body,
    .topbar,
    .admin-sidebar,
    .supplier-sidebar,
    .attachment-list-card,
    .readonly-score-panel,
    .requirement-box,
    .score-card,
    .kpi-card,
    .installer-hero {
        background: var(--surface);
        border-color: var(--line);
        color: var(--text);
    }

    input,
    select,
    textarea,
    button,
    .filter-input {
        color: var(--text);
    }

    input,
    select,
    textarea {
        background: #0b1220;
        border-color: var(--line);
    }

    input::placeholder,
    textarea::placeholder {
        color: #7d8ca3;
    }

    table,
    thead,
    tbody,
    tr,
    th,
    td,
    table.responsive-table td {
        background: var(--surface);
        border-color: var(--line);
        color: var(--text);
    }

    th,
    .table-tools,
    .readonly-field,
    .question-help-panel,
    .row-action-dropdown,
    .completion-widget,
    .review-summary-tile,
    .admin-role-stat-card {
        background: var(--soft);
        border-color: var(--line);
    }

    .muted,
    .help,
    .help-text,
    .text-small {
        color: var(--text-muted);
    }

    .btn-secondary,
    .btn.btn-secondary,
    .row-action-menu > summary {
        background: #0b1220;
        border-color: var(--line);
        color: var(--text);
    }

    .alert-info {
        background: rgba(96, 165, 250, .14);
        border-color: rgba(96, 165, 250, .35);
        color: var(--text);
    }

    .alert-warning {
        background: rgba(251, 191, 36, .14);
        border-color: rgba(251, 191, 36, .38);
        color: var(--text);
    }

    .alert-success {
        background: rgba(52, 211, 153, .14);
        border-color: rgba(52, 211, 153, .38);
        color: var(--text);
    }

    .alert-error {
        background: rgba(248, 113, 113, .14);
        border-color: rgba(248, 113, 113, .38);
        color: var(--text);
    }
}
