/* ============================================================
   LevelUP — Mobile-First Design System (light mode only)
   ============================================================ */

/* ---------- Design Tokens ---------- */
:root {
    /* Brand */
    --brand-charcoal: #2A2F36;
    --brand-charcoal-700: #363C44;
    --brand-charcoal-800: #22262B;
    --brand-orange: #FF6A00;
    --brand-orange-600: #E55F00;
    --brand-orange-700: #CC5500;
    --brand-orange-soft: #FFF0E6;

    /* Semantic surfaces */
    --surface-bg: #F4F5F7;
    --surface-card: #FFFFFF;
    --surface-muted: #ECEEF2;
    --surface-inverse: var(--brand-charcoal);
    --text-primary: var(--brand-charcoal);
    --text-secondary: #6B7280;
    --text-on-brand: #ffffff;
    --border-color: #E5E7EB;
    --border-strong: #D1D5DB;

    /* Semantic outcomes (distinct from brand orange) */
    --semantic-pass: #198754;
    --semantic-pass-600: #157347;
    --semantic-pass-700: #146c43;
    --semantic-pass-soft: #e4f5ec;
    --semantic-fail: #D92D39;
    --danger: var(--semantic-fail);
    --danger-soft: #fdecee;
    --warning: #b8860b;
    --warning-soft: #fff7e6;
    --success: var(--semantic-pass);
    --success-soft: var(--semantic-pass-soft);

    /* Bootstrap overrides */
    --bs-primary: var(--brand-orange);
    --bs-primary-rgb: 255, 106, 0;
    --bs-body-color: var(--text-primary);
    --bs-body-bg: var(--surface-bg);
    --bs-border-color: var(--border-color);

    /* Radii */
    --radius-sm: 10px;
    --radius-md: 16px;
    --radius-lg: 22px;
    --radius-pill: 999px;

    /* Shadows */
    --shadow-xs: 0 1px 2px rgba(42, 47, 54, 0.06);
    --shadow-sm: 0 2px 8px rgba(42, 47, 54, 0.07);
    --shadow-md: 0 8px 24px rgba(42, 47, 54, 0.10);
    --shadow-lg: 0 16px 40px rgba(42, 47, 54, 0.16);
    --shadow-brand: 0 8px 20px rgba(255, 106, 0, 0.30);

    /* Motion */
    --ease: cubic-bezier(0.22, 1, 0.36, 1);
    --dur-fast: 120ms;
    --dur: 200ms;
    --dur-slow: 320ms;

    /* Layout */
    --header-h: 56px;
    --content-max: 720px;
    --scoring-tab-bar-h: 3.85rem;
    --section-nav-bar-h: 3.75rem;
    --safe-top: env(safe-area-inset-top, 0px);
    --safe-bottom: env(safe-area-inset-bottom, 0px);
}

/* ---------- Base ---------- */
html, body {
    font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    background-color: var(--surface-bg);
    color: var(--text-primary);
    -webkit-font-smoothing: antialiased;
    -webkit-tap-highlight-color: transparent;
    text-rendering: optimizeLegibility;
}

body {
    overscroll-behavior-y: none;
}

h1, h2, h3, h4 {
    color: var(--text-primary);
    letter-spacing: -0.01em;
}

h1:focus, h2:focus {
    outline: none;
}

a, .btn-link {
    color: var(--brand-orange);
    text-decoration: none;
}

a:hover {
    color: var(--brand-orange-700);
}

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

code {
    color: #c02d76;
}

::selection {
    background: var(--brand-orange-soft);
}

/* ---------- App Shell ---------- */
.page {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    min-height: 100dvh;
    background: var(--surface-bg);
}

.content {
    flex: 1;
    width: 100%;
    max-width: var(--content-max);
    margin: 0 auto;
    padding: 1.25rem 1.1rem calc(1.25rem + var(--safe-bottom));
    box-sizing: border-box;
    animation: page-in var(--dur-slow) var(--ease);
}

.content--home {
    display: flex;
    flex-direction: column;
    max-width: none;
    width: 100%;
    padding: 1.25rem 1.25rem calc(1.25rem + var(--safe-bottom));
}

.content--dashboard {
    display: flex;
    flex-direction: column;
    max-width: none;
    width: 100%;
    padding: 1.25rem 1.25rem calc(1.25rem + var(--safe-bottom));
}

@media (min-width: 768px) {
    .content--home,
    .content--dashboard {
        padding: 1.75rem 2.5rem calc(1.75rem + var(--safe-bottom));
    }
}

@media (min-width: 1200px) {
    .content--home,
    .content--dashboard {
        padding: 2rem 3rem calc(2rem + var(--safe-bottom));
    }
}

.content--plant-make {
    display: flex;
    flex-direction: column;
    max-width: none;
    width: 100%;
    padding: 1.25rem 1.25rem calc(1.25rem + var(--safe-bottom));
}

.content--setup-wizard {
    display: flex;
    flex-direction: column;
    max-width: none;
    width: 100%;
    padding: 1.25rem 1.25rem calc(1.25rem + var(--safe-bottom));
}

@media (min-width: 768px) {
    .content--plant-make,
    .content--setup-wizard {
        padding: 1.75rem 2.5rem calc(1.75rem + var(--safe-bottom));
    }
}

@media (min-width: 1200px) {
    .content--plant-make,
    .content--setup-wizard {
        padding: 2rem 3rem calc(2rem + var(--safe-bottom));
    }
}

/* When a page renders a sticky action bar, leave room so content isn't hidden */
.has-action-bar .content {
    padding-bottom: calc(108px + var(--safe-bottom));
}

@keyframes page-in {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ---------- Buttons ---------- */
.btn {
    border-radius: var(--radius-pill);
    font-weight: 600;
    transition: transform var(--dur-fast) var(--ease),
                box-shadow var(--dur) var(--ease),
                background-color var(--dur) var(--ease),
                border-color var(--dur) var(--ease),
                color var(--dur) var(--ease);
}

.btn:active {
    transform: scale(0.97);
}

.btn-lg {
    padding: 0.85rem 1.25rem;
    font-size: 1.02rem;
    min-height: 52px;
}

.btn-primary {
    color: var(--text-on-brand);
    background-color: var(--brand-orange);
    border-color: var(--brand-orange);
    box-shadow: var(--shadow-brand);
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--brand-orange-600);
    border-color: var(--brand-orange-600);
    color: var(--text-on-brand);
}

.btn-primary:active {
    background-color: var(--brand-orange-700);
    border-color: var(--brand-orange-700);
}

.btn-primary:disabled,
.btn-primary.disabled {
    background-color: var(--brand-orange);
    border-color: var(--brand-orange);
    box-shadow: none;
    opacity: 0.45;
}

.btn-outline-primary {
    color: var(--brand-orange);
    border-color: var(--brand-orange);
    background-color: transparent;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background-color: var(--brand-orange);
    border-color: var(--brand-orange);
    color: var(--text-on-brand);
}

.btn-outline-secondary {
    color: var(--text-secondary);
    border-color: var(--border-strong);
    background-color: var(--surface-card);
}

.btn-outline-secondary:hover,
.btn-outline-secondary:focus {
    background-color: var(--surface-muted);
    border-color: var(--border-strong);
    color: var(--text-primary);
}

.btn:focus, .btn:active:focus,
.form-control:focus, .form-select:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.22rem rgba(255, 106, 0, 0.28);
}

/* ---------- Cards ---------- */
.card {
    background-color: var(--surface-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
}

.card-body {
    padding: 1.1rem 1.15rem;
}

/* ---------- Forms ---------- */
.form-label {
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-bottom: 0.35rem;
}

.form-control, .form-select {
    background-color: var(--surface-card);
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    padding: 0.7rem 0.85rem;
    min-height: 48px;
    font-size: 1rem;
    transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

.form-control:focus, .form-select:focus {
    border-color: var(--brand-orange);
    background-color: var(--surface-card);
    color: var(--text-primary);
}

.form-control[readonly] {
    background-color: var(--surface-muted);
    color: var(--text-secondary);
}

.form-control::placeholder {
    color: var(--text-secondary);
    opacity: 0.7;
}

/* ---------- Alerts ---------- */
.alert {
    border: none;
    border-radius: var(--radius-md);
    padding: 0.9rem 1rem;
    box-shadow: var(--shadow-xs);
    display: flex;
    gap: 0.6rem;
    align-items: flex-start;
}

.alert-info { background-color: var(--surface-muted); color: var(--text-primary); }
.alert-success { background-color: var(--success-soft); color: var(--semantic-pass-700); }
.alert-warning { background-color: var(--warning-soft); color: var(--warning); }
.alert-danger { background-color: var(--danger-soft); color: var(--danger); }
.alert-secondary { background-color: var(--surface-muted); color: var(--text-secondary); }

/* ---------- Badges ---------- */
.badge.text-bg-secondary {
    background-color: var(--surface-muted) !important;
    color: var(--text-secondary) !important;
    border-radius: var(--radius-pill);
    font-weight: 600;
}

/* ---------- App Header ---------- */
.app-header {
    position: sticky;
    top: 0;
    z-index: 30;
    background: linear-gradient(135deg, var(--brand-charcoal) 0%, var(--brand-charcoal-700) 100%);
    color: #fff;
    padding: calc(0.7rem + var(--safe-top)) 1.1rem 0.7rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    box-shadow: var(--shadow-sm);
}

.app-header__brand {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    flex: 1;
    min-width: 0;
    text-decoration: none;
    color: inherit;
    border-radius: 0.65rem;
    transition: opacity 0.15s ease;
}

.app-header__brand:hover,
.app-header__brand:focus-visible {
    opacity: 0.92;
    outline: none;
}

.app-header__logo {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.12);
    display: grid;
    place-items: center;
    flex-shrink: 0;
    color: #fff;
}

.app-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.app-title__level {
    color: #fff;
}

.app-title__up {
    color: var(--brand-orange);
}

.app-subtitle {
    margin: 0;
    font-size: 0.72rem;
    opacity: 0.75;
    line-height: 1.1;
}

/* ---------- Setup header ---------- */
.setup-header__logo {
    display: block;
    flex-shrink: 0;
    border-radius: 10px;
    object-fit: contain;
}

.app-header__actions {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex-shrink: 0;
    margin-left: auto;
}

.server-status {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.3rem 0.55rem;
    border-radius: var(--radius-pill);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
    font-size: 0.68rem;
    font-weight: 600;
    line-height: 1;
    white-space: nowrap;
    color: rgba(255, 255, 255, 0.88);
}

.server-status__dot {
    width: 0.45rem;
    height: 0.45rem;
    border-radius: 50%;
    flex-shrink: 0;
    background: rgba(255, 255, 255, 0.45);
}

.server-status--connected .server-status__dot {
    background: #4ade80;
    box-shadow: 0 0 0 2px rgba(74, 222, 128, 0.25);
}

.server-status--unavailable .server-status__dot {
    background: #f87171;
    box-shadow: 0 0 0 2px rgba(248, 113, 113, 0.25);
}

.server-status--offline .server-status__dot {
    background: #fbbf24;
    box-shadow: 0 0 0 2px rgba(251, 191, 36, 0.25);
}

.server-status--checking .server-status__dot {
    background: rgba(255, 255, 255, 0.65);
    animation: server-status-pulse 1.1s ease-in-out infinite;
}

.server-status--unknown .server-status__dot {
    background: rgba(255, 255, 255, 0.35);
}

@keyframes server-status-pulse {
    0%, 100% { opacity: 0.45; transform: scale(0.92); }
    50% { opacity: 1; transform: scale(1); }
}

@media (max-width: 480px) {
    .server-status__label {
        display: none;
    }

    .server-status {
        padding: 0.35rem;
    }
}

/* ---------- Scoring Phase chrome ---------- */
.scoring-header {
    position: sticky;
    top: 0;
    z-index: 30;
    background: var(--brand-charcoal);
    color: #fff;
    padding: calc(0.55rem + var(--safe-top)) 0.65rem 0.55rem;
    box-shadow: var(--shadow-sm);
}

.scoring-header__inner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    min-height: 44px;
}

.scoring-header__leading,
.scoring-header__trailing {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    min-width: 0;
}

.scoring-header__trailing {
    justify-content: flex-end;
}

.scoring-header__brand {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    max-width: calc(100% - 11rem);
}

.scoring-header__logo {
    display: block;
    width: auto;
    height: 1.75rem;
    max-width: 100%;
    object-fit: contain;
}

.scoring-header__title {
    margin: 0;
    font-size: 0.88rem;
    font-weight: 700;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}

.scoring-header__action {
    appearance: none;
    border: none;
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    border-radius: var(--radius-sm);
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
    transition: background-color var(--dur) var(--ease);
}

.scoring-header__action:hover,
.scoring-header__action:focus-visible {
    background: rgba(255, 255, 255, 0.16);
    outline: none;
}

.scoring-header__action--text {
    min-width: auto;
    padding: 0 0.65rem;
    font-size: 0.76rem;
    font-weight: 600;
    white-space: nowrap;
}

.scoring-header__overflow {
    position: relative;
}

.scoring-header__backdrop {
    position: fixed;
    inset: 0;
    z-index: 31;
    background: transparent;
}

.scoring-overflow-menu {
    position: absolute;
    top: calc(100% + 0.35rem);
    right: 0;
    z-index: 32;
    min-width: 11.5rem;
    background: var(--surface-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    overflow: hidden;
    padding: 0.35rem 0;
}

.scoring-overflow-menu__item {
    appearance: none;
    border: none;
    background: transparent;
    width: 100%;
    text-align: left;
    padding: 0.75rem 1rem;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-primary);
    cursor: pointer;
    min-height: 44px;
    display: flex;
    align-items: center;
    gap: 0.55rem;
}

.scoring-overflow-menu__item:hover,
.scoring-overflow-menu__item:focus-visible {
    background: var(--surface-muted);
    outline: none;
}

.scoring-overflow-menu__item--danger {
    color: var(--semantic-fail);
}

.scoring-header__toast {
    position: absolute;
    left: 50%;
    bottom: -0.35rem;
    transform: translate(-50%, 100%);
    z-index: 33;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    background: var(--brand-orange);
    color: #fff;
    font-size: 0.78rem;
    font-weight: 700;
    padding: 0.45rem 0.85rem;
    border-radius: var(--radius-pill);
    box-shadow: var(--shadow-brand);
    white-space: nowrap;
    animation: scoring-toast-in var(--dur) var(--ease);
}

@keyframes scoring-toast-in {
    from { opacity: 0; transform: translate(-50%, calc(100% + 6px)); }
    to { opacity: 1; transform: translate(-50%, 100%); }
}

.scoring-tab-bar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 25;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    background: var(--surface-card);
    border-top: 1px solid var(--border-color);
    padding: 0.35rem 0.5rem calc(0.35rem + var(--safe-bottom));
    box-shadow: 0 -2px 12px rgba(42, 47, 54, 0.08);
}

.scoring-tab {
    appearance: none;
    border: none;
    background: transparent;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.15rem;
    min-height: 44px;
    min-width: 44px;
    font-size: 0.68rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-align: center;
    padding: 0.35rem 0.15rem;
    cursor: pointer;
    line-height: 1.1;
}

.scoring-tab:focus-visible {
    outline: 2px solid var(--brand-orange);
    outline-offset: -2px;
    border-radius: var(--radius-sm);
}

.scoring-tab--active {
    color: var(--brand-orange);
}

.scoring-tab--disabled {
    opacity: 0.45;
    cursor: default;
    user-select: none;
    pointer-events: none;
}

.content--scoring,
.content--scoring-assessment {
    max-width: none;
    width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
}

@media (min-width: 768px) {
    .content--scoring,
    .content--scoring-assessment {
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }
}

.content--scoring {
    padding-bottom: calc(var(--scoring-tab-bar-h) + var(--safe-bottom));
}

.content--scoring-assessment {
    padding-bottom: calc(var(--scoring-tab-bar-h) + var(--section-nav-bar-h) + var(--safe-bottom) + 0.35rem);
}

/* ---------- Section Navigation (Assessment tab) ---------- */
.section-nav-bar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: calc(var(--scoring-tab-bar-h) + var(--safe-bottom));
    z-index: 26;
    display: flex;
    gap: 0.65rem;
    padding: 0.65rem 0.85rem;
    background: color-mix(in srgb, var(--surface-card) 92%, transparent);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-top: 1px solid var(--border-color);
    box-shadow: 0 -2px 12px rgba(42, 47, 54, 0.06);
}

@supports not (backdrop-filter: blur(12px)) {
    .section-nav-bar { background: var(--surface-card); }
}

.section-nav-bar__btn {
    flex: 1;
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    font-size: 0.88rem;
    font-weight: 600;
}

.section-nav-bar__prev {
    flex: 0 1 auto;
    min-width: 44px;
    padding-left: 0.85rem;
    padding-right: 0.85rem;
}

.section-nav-bar__next {
    flex: 1.4;
}

@media (min-width: 768px) {
    .section-nav-bar {
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }
}

/* ---------- Setup stepper (wizard progress) ---------- */
.setup-stepper {
    position: sticky;
    top: var(--header-h);
    z-index: 29;
    background: var(--surface-bg);
    border-bottom: 1px solid var(--border-color);
}

.setup-stepper__list {
    display: flex;
    align-items: center;
    justify-content: center;
    list-style: none;
    margin: 0;
    padding: 0.95rem 1rem 1.05rem;
    width: 100%;
    box-sizing: border-box;
}

.setup-stepper__item {
    flex: 0 0 auto;
}

.setup-stepper__connector {
    position: relative;
    flex: 1 1 2rem;
    flex-shrink: 1;
    min-width: 1.25rem;
    max-width: 4.5rem;
    height: 2px;
    margin: 1.125rem 0.35rem 0;
    align-self: flex-start;
}

.setup-stepper__connector-track,
.setup-stepper__connector-fill {
    position: absolute;
    inset: 0;
    border-radius: var(--radius-pill);
}

.setup-stepper__connector-track {
    background: var(--border-color);
}

.setup-stepper__connector-fill {
    background: linear-gradient(90deg, var(--brand-orange) 0%, #FF8533 100%);
    transform-origin: left center;
    transform: scaleX(0);
    transition: transform 0.55s var(--ease);
}

.setup-stepper__connector.is-filled .setup-stepper__connector-fill {
    transform: scaleX(1);
}

.setup-stepper__row {
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.setup-stepper__marker {
    display: grid;
    place-items: center;
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    border: 1.5px solid var(--border-strong);
    background: var(--surface-card);
    color: var(--text-secondary);
    font-size: 0.8125rem;
    font-weight: 700;
    line-height: 1;
    flex-shrink: 0;
    transition:
        background-color 0.35s var(--ease),
        border-color 0.35s var(--ease),
        color 0.35s var(--ease),
        transform 0.35s var(--ease),
        box-shadow 0.35s var(--ease);
}

.setup-stepper__label {
    font-size: 0.8125rem;
    font-weight: 600;
    line-height: 1.2;
    color: var(--text-secondary);
    white-space: nowrap;
    transition: color 0.35s var(--ease), font-weight 0.35s var(--ease);
}

.setup-stepper__marker .icon {
    line-height: 0;
}

.setup-stepper__item.is-complete .setup-stepper__marker {
    border-color: var(--brand-orange);
    background: var(--brand-orange);
    color: #fff;
    box-shadow: 0 2px 8px rgba(255, 106, 0, 0.2);
}

.setup-stepper__item.is-complete .setup-stepper__label {
    color: var(--brand-charcoal);
}

.setup-stepper__item.is-active .setup-stepper__marker {
    border-color: var(--brand-orange);
    background: var(--brand-orange);
    color: #fff;
    transform: scale(1.06);
    box-shadow: 0 4px 14px rgba(255, 106, 0, 0.28);
    animation: stepper-marker-pop 0.45s var(--ease) both;
}

.setup-stepper__item.is-active .setup-stepper__label {
    color: var(--brand-charcoal);
    font-weight: 800;
}

.setup-stepper__item.is-upcoming .setup-stepper__label {
    color: color-mix(in srgb, var(--text-secondary) 82%, transparent);
}

@keyframes stepper-marker-pop {
    0% {
        transform: scale(0.92);
    }
    60% {
        transform: scale(1.1);
    }
    100% {
        transform: scale(1.06);
    }
}

@media (max-width: 767px) {
    .setup-stepper__list {
        justify-content: center;
        overflow: visible;
        padding: 0.85rem 1rem 0.95rem;
        gap: 0;
    }

    .setup-stepper__connector {
        display: none;
    }

    .setup-stepper__item:not(.is-active) {
        display: none;
    }

    .setup-stepper__item.is-active {
        flex: 0 1 auto;
    }

    .setup-stepper__item.is-active .setup-stepper__row {
        justify-content: center;
    }

    .setup-stepper__label {
        font-size: 0.8125rem;
    }

    .setup-stepper__marker {
        width: 1.875rem;
        height: 1.875rem;
        font-size: 0.8125rem;
    }
}

@media (min-width: 768px) {
    .setup-stepper__list {
        justify-content: space-between;
        padding: 1rem 2.5rem 1.15rem;
    }

    .setup-stepper__label {
        font-size: 0.875rem;
    }

    .setup-stepper__connector {
        flex: 1 1 auto;
        max-width: none;
        min-width: 2rem;
        margin: 1.125rem 1rem 0;
    }
}

@media (min-width: 1200px) {
    .setup-stepper__list {
        padding: 1rem 3rem 1.15rem;
    }

    .setup-stepper__connector {
        margin: 1.125rem 1.5rem 0;
    }

    .setup-stepper__label {
        font-size: 0.9375rem;
    }
}

/* ---------- Offline Banner ---------- */
.offline-banner {
    background-color: var(--surface-bg);
    color: var(--warning);
    border-bottom: 1px solid color-mix(in srgb, var(--warning) 28%, transparent);
    padding: 0.65rem 1.1rem;
    font-size: 0.82rem;
    font-weight: 600;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
}

/* ---------- Install Prompt ---------- */
.install-prompt {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex-shrink: 0;
}

.install-prompt__btn {
    appearance: none;
    border: 1px solid rgba(255, 255, 255, 0.45);
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    border-radius: var(--radius-pill);
    font-size: 0.76rem;
    font-weight: 600;
    padding: 0.45rem 0.75rem;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    cursor: pointer;
    transition: background-color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}

.install-prompt__btn:hover,
.install-prompt__btn:focus-visible {
    background: rgba(255, 255, 255, 0.18);
    border-color: rgba(255, 255, 255, 0.65);
    outline: none;
}

.install-hint {
    font-size: 0.72rem;
    opacity: 0.9;
    white-space: nowrap;
}

.install-prompt__dismiss {
    appearance: none;
    border: none;
    background: transparent;
    color: #fff;
    opacity: 0.85;
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 1rem;
    padding: 0;
}

.install-prompt__dismiss:hover,
.install-prompt__dismiss:focus-visible {
    opacity: 1;
    outline: none;
}

/* ---------- Action Bar (sticky bottom) ---------- */
.action-bar {
    position: sticky;
    bottom: 0;
    z-index: 20;
    margin: 1.5rem -1.1rem 0;
    padding: 0.85rem 1.1rem calc(0.85rem + var(--safe-bottom));
    background: color-mix(in srgb, var(--surface-card) 88%, transparent);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-top: 1px solid var(--border-color);
    display: flex;
    gap: 0.75rem;
}

.action-bar .btn {
    flex: 1;
    min-height: 54px;
}

.action-bar .btn--back {
    flex: 0 0 auto;
    min-width: 56px;
    padding-left: 1rem;
    padding-right: 1rem;
}

.action-bar .btn--primary {
    flex: 1;
}

@supports not (backdrop-filter: blur(12px)) {
    .action-bar { background: var(--surface-card); }
}

.action-bar--dock {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    margin: 0;
    z-index: 35;
    padding: 0.85rem 1.25rem calc(0.85rem + var(--safe-bottom));
    box-shadow: 0 -4px 16px rgba(42, 47, 54, 0.08);
}

@media (min-width: 768px) {
    .action-bar--dock {
        padding-left: 2.5rem;
        padding-right: 2.5rem;
    }
}

@media (min-width: 1200px) {
    .action-bar--dock {
        padding-left: 3rem;
        padding-right: 3rem;
    }
}

.operator-info-page.setup-page--with-nav {
    padding-bottom: calc(6.5rem + var(--safe-bottom));
}

/* ---------- Selection Cards (Home / Plant Make) ---------- */
.choice-grid {
    display: grid;
    gap: 0.9rem;
    margin-top: 1.25rem;
}

.choice-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    width: 100%;
    text-align: left;
    padding: 1.15rem 1.15rem;
    background: var(--surface-card);
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    color: var(--text-primary);
    cursor: pointer;
    transition: transform var(--dur) var(--ease),
                box-shadow var(--dur) var(--ease),
                border-color var(--dur) var(--ease);
}

.choice-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    border-color: var(--brand-orange);
}

.choice-card:active {
    transform: scale(0.985);
}

.choice-card__icon {
    width: 52px;
    height: 52px;
    border-radius: var(--radius-md);
    background: var(--brand-orange-soft);
    color: var(--brand-orange-700);
    display: grid;
    place-items: center;
    flex-shrink: 0;
}

.choice-card__body { flex: 1; min-width: 0; }

.choice-card__title {
    margin: 0;
    font-size: 1.08rem;
    font-weight: 700;
}

.choice-card__desc {
    margin: 0.15rem 0 0;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.choice-card__chevron {
    color: var(--text-secondary);
    flex-shrink: 0;
}

/* ---------- Setup page header (wizard steps) ---------- */
.setup-page-header {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 1.15rem;
    width: 100%;
    margin-bottom: 1.35rem;
}

.setup-page-header__intro {
    min-width: 0;
}

.setup-page-header__title {
    margin: 0;
    font-size: clamp(1.5rem, 2.2vw, 1.875rem);
    font-weight: 800;
    line-height: 1.15;
    color: var(--brand-charcoal);
    letter-spacing: -0.02em;
}

.setup-page-header__sub {
    margin: 0.35rem 0 0;
    font-size: 0.9375rem;
    line-height: 1.45;
    color: var(--text-secondary);
}

.setup-context-card {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.85rem 1rem;
    background: var(--brand-orange-soft);
    border: 1px solid color-mix(in srgb, var(--brand-orange) 14%, var(--border-color));
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-xs);
    flex-shrink: 0;
}

.setup-context-card__icon {
    width: 56px;
    height: 56px;
    object-fit: contain;
    flex-shrink: 0;
    opacity: 0.78;
    filter: grayscale(1) brightness(0.55) contrast(0.9);
}

.setup-context-card__body {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    min-width: 0;
}

.setup-context-card__type {
    font-size: 0.75rem;
    font-weight: 800;
    line-height: 1.2;
    color: var(--brand-orange);
    letter-spacing: 0.01em;
}

.setup-context-card__name {
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.2;
    color: var(--brand-charcoal);
}

.setup-context-card__desc {
    font-size: 0.8125rem;
    line-height: 1.3;
    color: var(--text-secondary);
}

@media (min-width: 768px) {
    .setup-page-header {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 2rem;
        margin-bottom: 1.5rem;
    }

    .setup-context-card {
        width: min(100%, 22rem);
        padding: 0.9rem 1.1rem;
    }

    .setup-context-card__icon {
        width: 64px;
        height: 64px;
    }

    .setup-context-card__name {
        font-size: 1.0625rem;
    }
}

/* ---------- Operator / equipment details pages ---------- */
.operator-info-page {
    display: flex;
    flex-direction: column;
    gap: 1.15rem;
}

.equipment-search__avatar {
    background: color-mix(in srgb, var(--brand-orange-soft) 70%, var(--surface-card));
    color: var(--brand-orange-700);
}

.equipment-search__avatar .icon {
    line-height: 0;
}

.operator-select-panel,
.operator-info-panel {
    background: var(--surface-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    padding: 1.15rem 1.15rem 1.2rem;
}

.operator-select-panel__label {
    display: block;
    margin: 0 0 0.75rem;
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--brand-charcoal);
}

.operator-select-panel__required {
    color: var(--semantic-fail);
}

.operator-search {
    position: relative;
}

.operator-search.is-open {
    z-index: 1;
}

.operator-select-panel.is-dropdown-open {
    position: relative;
    z-index: 26;
    overflow: visible;
}

.operator-search__icon {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-secondary);
    line-height: 0;
    pointer-events: none;
    z-index: 1;
}

.operator-search__input {
    width: 100%;
    min-height: 48px;
    padding: 0.75rem 2.75rem 0.75rem 2.75rem;
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-pill);
    background: var(--surface-card);
    color: var(--text-primary);
    font-size: 0.9375rem;
    box-sizing: border-box;
    transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

.operator-search__input::placeholder {
    color: color-mix(in srgb, var(--text-secondary) 72%, transparent);
}

.operator-search__input:focus {
    outline: none;
    border-color: var(--brand-orange);
    box-shadow: 0 0 0 0.22rem rgba(255, 106, 0, 0.16);
}

.operator-search.is-open .operator-search__input {
    border-color: var(--brand-orange);
    border-bottom-left-radius: var(--radius-sm);
    border-bottom-right-radius: var(--radius-sm);
}

.operator-search__toggle {
    position: absolute;
    right: 0.35rem;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    border: none;
    background: transparent;
    color: var(--text-secondary);
    display: grid;
    place-items: center;
    cursor: pointer;
    border-radius: 50%;
}

.operator-search__toggle:hover,
.operator-search__toggle:focus-visible {
    color: var(--brand-charcoal);
    outline: none;
    background: var(--surface-muted);
}

.operator-search__results {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% - 1px);
    z-index: 25;
    list-style: none;
    margin: 0;
    padding: 0.35rem;
    max-height: calc((3.75rem * 4) + 0.7rem);
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: color-mix(in srgb, var(--brand-orange) 45%, var(--border-color)) transparent;
    background: var(--surface-card);
    border: 1.5px solid var(--brand-orange);
    border-top: none;
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    box-shadow: var(--shadow-md);
}

.operator-search__results::-webkit-scrollbar {
    width: 6px;
}

.operator-search__results::-webkit-scrollbar-thumb {
    background: color-mix(in srgb, var(--brand-orange) 45%, var(--border-color));
    border-radius: var(--radius-pill);
}

.operator-search__option {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
    min-height: 3.75rem;
    padding: 0.65rem 0.75rem;
    box-sizing: border-box;
    border: none;
    border-radius: var(--radius-sm);
    background: transparent;
    text-align: left;
    cursor: pointer;
    color: inherit;
    transition: background-color var(--dur) var(--ease);
}

.operator-search__option:hover,
.operator-search__option:focus-visible,
.operator-search__option.is-selected {
    outline: none;
    background: var(--brand-orange-soft);
}

.operator-search__avatar,
.operator-selected-card__avatar {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: var(--brand-orange-soft);
    color: var(--brand-orange-700);
    font-size: 0.8125rem;
    font-weight: 800;
    display: grid;
    place-items: center;
    flex-shrink: 0;
}

.operator-search__option-body {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    min-width: 0;
}

.operator-search__option-name {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--brand-charcoal);
}

.operator-search__option-meta {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.operator-search__empty {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% - 1px);
    z-index: 25;
    margin: 0;
    padding: 0.85rem 1rem;
    background: var(--surface-card);
    border: 1.5px solid var(--brand-orange);
    border-top: none;
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.operator-search-backdrop {
    position: fixed;
    inset: 0;
    z-index: 24;
    background: transparent;
}

.operator-selected-card {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.85rem;
    margin-top: 1rem;
    padding: 0.85rem 1rem;
    border: 1.5px solid color-mix(in srgb, var(--brand-orange) 35%, var(--border-color));
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--brand-orange-soft) 55%, var(--surface-card));
}

.operator-selected-card__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.operator-selected-card__name {
    font-size: 0.9375rem;
    font-weight: 800;
    color: var(--brand-charcoal);
}

.operator-selected-card__meta {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.operator-selected-card__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.35rem 0.65rem;
    border: 1.5px solid var(--brand-orange);
    border-radius: var(--radius-pill);
    background: var(--surface-card);
    color: var(--brand-orange);
    font-size: 0.75rem;
    font-weight: 700;
    flex-shrink: 0;
    line-height: 1;
}

.operator-selected-card__badge .icon {
    line-height: 0;
}

.operator-info-panel__header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem 1rem;
    margin-bottom: 1rem;
}

.operator-info-panel__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 800;
    color: var(--brand-charcoal);
}

.operator-info-panel__note {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
}

.operator-info-panel__note .icon {
    line-height: 0;
    color: var(--text-secondary);
}

.operator-info-grid {
    display: grid;
    gap: 0.85rem;
    grid-template-columns: 1fr;
}

.operator-info-field {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.85rem 0.9rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: var(--surface-bg);
}

.operator-info-field__icon {
    width: 2rem;
    height: 2rem;
    border-radius: var(--radius-sm);
    background: var(--brand-orange-soft);
    color: var(--brand-orange-700);
    display: grid;
    place-items: center;
    flex-shrink: 0;
}

.operator-info-field__icon--text {
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: -0.02em;
}

.operator-info-field__icon .icon {
    line-height: 0;
}

.operator-info-field__body {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 0;
}

.operator-info-field__label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    line-height: 1.2;
}

.operator-info-field__value {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--brand-charcoal);
    line-height: 1.3;
    word-break: break-word;
}

@media (min-width: 768px) {
    .operator-select-panel,
    .operator-info-panel {
        padding: 1.25rem 1.35rem 1.3rem;
    }

    .operator-info-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1rem;
    }
}

/* ---------- Page Intro ---------- */
.page-intro {
    margin-bottom: 0.5rem;
}

.page-intro__title {
    font-size: 1.5rem;
    font-weight: 800;
    margin: 0;
    color: var(--brand-charcoal);
}

.page-intro__sub {
    color: var(--text-secondary);
    margin: 0.25rem 0 0;
    font-size: 0.92rem;
}

/* ---------- Setup Wizard ---------- */
.setup-page {
    max-width: 100%;
    overflow-x: hidden;
}

.setup-page.is-dropdown-open {
    overflow: visible;
}

.setup-page--with-nav {
    padding-bottom: calc(6rem + var(--safe-bottom));
}

.setup-loading {
    color: var(--text-secondary);
    font-size: 0.92rem;
    margin-top: 1.25rem;
}

.setup-form-card {
    background: var(--surface-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    margin-top: 1rem;
}

.setup-form-card .card-body {
    padding: 1.15rem 1.15rem 1.2rem;
}

.setup-form-card .form-label {
    color: var(--text-secondary);
}

.setup-form-card .form-control:focus,
.setup-form-card .form-select:focus {
    border-color: var(--brand-orange);
    box-shadow: 0 0 0 0.22rem rgba(255, 106, 0, 0.18);
}

.setup-page .alert {
    margin-top: 1rem;
}

.setup-page .alert code {
    font-size: 0.82em;
    word-break: break-word;
    color: inherit;
    opacity: 0.9;
}

.choice-card:focus-visible {
    outline: 2px solid var(--brand-orange);
    outline-offset: 2px;
    border-color: var(--brand-orange);
}

.choice-card:hover .choice-card__chevron,
.choice-card:focus-visible .choice-card__chevron {
    color: var(--brand-orange);
}

/* ---------- Home (New Assessment) ---------- */
.home-page {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0;
    width: 100%;
    min-height: 100%;
}

.home-hero {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-shrink: 0;
}

.home-hero__copy {
    width: 100%;
    text-align: left;
}

.home-hero__eyebrow {
    margin: 0 0 0.5rem;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--brand-orange);
}

.home-hero__title {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 800;
    line-height: 1.22;
    color: var(--brand-charcoal);
    letter-spacing: -0.025em;
}

.home-hero__sub {
    margin: 0.5rem 0 0;
    font-size: 0.9375rem;
    color: var(--text-secondary);
    line-height: 1.5;
}

.home-hero__logo {
    width: 80px;
    height: 80px;
    object-fit: contain;
    flex-shrink: 0;
}

.home-choice-grid {
    display: grid;
    gap: 1rem;
    flex: 0 0 auto;
    margin-bottom: 1.5rem;
}

.home-help-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.85rem 1.25rem;
    margin-top: auto;
    padding: 0.9rem 1.15rem;
    background: var(--surface-muted);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    flex-shrink: 0;
}

.home-help-bar__icon {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-sm);
    background: var(--brand-charcoal);
    color: #fff;
    display: grid;
    place-items: center;
    flex-shrink: 0;
}

.home-help-bar__text {
    flex: 1;
    min-width: min(100%, 14rem);
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.45;
    color: var(--text-secondary);
}

.home-help-bar__text strong {
    display: block;
    color: var(--text-primary);
    font-weight: 700;
    font-size: 0.9375rem;
    margin-bottom: 0.1rem;
}

.home-help-bar__link {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--brand-orange);
    white-space: nowrap;
}

.home-help-bar__link--placeholder {
    cursor: default;
    opacity: 0.85;
}

@media (min-width: 768px) {
    .home-hero {
        flex-direction: row;
        align-items: flex-start;
        justify-content: space-between;
        gap: 2rem;
        margin-bottom: 2rem;
    }

    .home-hero__copy {
        flex: 1;
        min-width: 0;
    }

    .home-hero__title {
        font-size: clamp(1.75rem, 2.1vw, 2.125rem);
    }

    .home-hero__sub {
        font-size: 1rem;
        max-width: 26rem;
    }

    .home-hero__logo {
        width: 104px;
        height: 104px;
        margin-top: 0.25rem;
    }

    .home-choice-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1.25rem;
    }

    .home-help-bar {
        flex-wrap: nowrap;
        margin-top: auto;
        padding-top: 1rem;
        padding-bottom: 1rem;
    }
}

@media (min-width: 1200px) {
    .home-hero__title {
        font-size: 2.125rem;
        white-space: nowrap;
    }

    .home-hero__logo {
        width: 112px;
        height: 112px;
    }

    .home-choice-grid {
        gap: 1.5rem;
    }
}

/* ---------- Dashboard ---------- */
.dashboard-page {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    width: 100%;
    min-height: 100%;
}

.dashboard-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.dashboard-header__copy {
    min-width: 0;
}

.dashboard-header__title {
    margin: 0;
    font-size: clamp(1.75rem, 2.4vw, 2.125rem);
    font-weight: 800;
    line-height: 1.15;
    color: var(--brand-charcoal);
    letter-spacing: -0.03em;
}

.dashboard-header__sub {
    margin: 0.35rem 0 0;
    font-size: 0.9375rem;
    color: var(--text-secondary);
}

.dashboard-header__new {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    flex-shrink: 0;
    padding: 0.55rem 0.9rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-pill);
    background: var(--surface-card);
    color: var(--text-primary);
    font-size: 0.8125rem;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
    box-shadow: var(--shadow-xs);
    transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

.dashboard-header__new:hover,
.dashboard-header__new:focus-visible {
    border-color: var(--border-strong);
    box-shadow: var(--shadow-sm);
}

.dashboard-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.dashboard-stat-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    min-height: 5.5rem;
    padding: 1rem 0.75rem;
    background: var(--surface-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-xs);
    text-align: center;
}

.dashboard-stat-card__value {
    font-size: clamp(1.75rem, 3vw, 2.125rem);
    font-weight: 800;
    line-height: 1;
    color: var(--brand-charcoal);
    letter-spacing: -0.03em;
}

.dashboard-stat-card__label {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-secondary);
    line-height: 1.3;
}

.dashboard-stat-card--progress .dashboard-stat-card__value {
    color: var(--brand-orange);
}

.dashboard-stat-card--completed .dashboard-stat-card__value {
    color: var(--semantic-pass);
}

.dashboard-recent {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    flex: 1;
}

.dashboard-recent__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.dashboard-recent__view-all {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--brand-orange);
    text-decoration: none;
    white-space: nowrap;
}

.dashboard-recent__view-all:hover,
.dashboard-recent__view-all:focus-visible {
    text-decoration: underline;
}

.dashboard-recent__heading {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 800;
    color: var(--brand-charcoal);
    letter-spacing: -0.02em;
}

.dashboard-recent-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.dashboard-recent-list__item {
    margin: 0;
}

.dashboard-recent-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto auto auto;
    align-items: center;
    gap: 0.85rem;
    width: 100%;
    padding: 0.95rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--surface-card);
    box-shadow: var(--shadow-xs);
    text-align: left;
    cursor: pointer;
    transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

.dashboard-recent-row:hover,
.dashboard-recent-row:focus-visible {
    border-color: var(--border-strong);
    box-shadow: var(--shadow-sm);
}

.dashboard-recent-row--static {
    cursor: default;
}

.dashboard-recent-row--static:hover,
.dashboard-recent-row--static:focus-visible {
    border-color: var(--border-color);
    box-shadow: var(--shadow-xs);
}

.dashboard-recent-row__icon {
    display: grid;
    place-items: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--radius-sm);
    background: var(--surface-muted);
    color: var(--text-secondary);
    flex-shrink: 0;
}

.dashboard-recent-row__body {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 0;
}

.dashboard-recent-row__name {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dashboard-recent-row__meta {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dashboard-recent-row__score {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--text-primary);
    white-space: nowrap;
}

.dashboard-recent-row__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.28rem 0.65rem;
    border-radius: var(--radius-pill);
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.dashboard-recent-row__badge--progress {
    color: var(--brand-orange);
    background: var(--brand-orange-soft);
}

.dashboard-recent-row__badge--completed {
    color: var(--semantic-pass);
    background: var(--semantic-pass-soft);
}

.dashboard-recent-row__chevron {
    color: var(--text-secondary);
    flex-shrink: 0;
}

.dashboard-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 2.5rem 1.25rem;
    border: 1px dashed var(--border-color);
    border-radius: var(--radius-md);
    background: var(--surface-card);
    text-align: center;
}

.dashboard-empty__icon {
    display: grid;
    place-items: center;
    width: 3.25rem;
    height: 3.25rem;
    margin-bottom: 0.25rem;
    border-radius: var(--radius-md);
    background: var(--surface-muted);
    color: var(--text-secondary);
}

.dashboard-empty__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-primary);
}

.dashboard-empty__text {
    margin: 0 0 0.75rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.dashboard-empty__cta {
    min-width: 10rem;
}

.dashboard-page-skeleton .dashboard-stat-card--skeleton,
.dashboard-recent-row--skeleton {
    pointer-events: none;
}

.skeleton-box--dashboard-new-btn {
    width: 8.5rem;
    height: 2.25rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--stat-value {
    width: 2.5rem;
    height: 2rem;
    border-radius: var(--radius-sm);
}

.skeleton-box--stat-label {
    width: 5.5rem;
    height: 0.75rem;
    border-radius: var(--radius-sm);
}

.skeleton-box--section-heading {
    width: 5rem;
    height: 1.25rem;
    border-radius: var(--radius-sm);
}

.skeleton-box--recent-icon {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--radius-sm);
}

.skeleton-box--recent-name {
    width: 9rem;
    height: 0.9rem;
    border-radius: var(--radius-sm);
}

.skeleton-box--recent-meta {
    width: 12rem;
    height: 0.75rem;
    border-radius: var(--radius-sm);
}

.skeleton-box--recent-score {
    width: 3rem;
    height: 0.9rem;
    border-radius: var(--radius-sm);
}

.skeleton-box--recent-badge {
    width: 5.5rem;
    height: 1.5rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--recent-chevron {
    width: 1.125rem;
    height: 1.125rem;
    border-radius: var(--radius-sm);
}

@media (max-width: 767px) {
    .dashboard-header {
        flex-direction: column;
        align-items: stretch;
    }

    .dashboard-header__new {
        align-self: flex-start;
    }

    .dashboard-recent-row {
        grid-template-columns: auto minmax(0, 1fr);
        grid-template-areas:
            "icon body"
            "icon meta-row";
        row-gap: 0.55rem;
    }

    .dashboard-recent-row__icon {
        grid-area: icon;
        align-self: start;
    }

    .dashboard-recent-row__body {
        grid-area: body;
    }

    .dashboard-recent-row__score,
    .dashboard-recent-row__badge,
    .dashboard-recent-row__chevron {
        grid-area: meta-row;
    }

    .dashboard-recent-row__score {
        justify-self: start;
    }

    .dashboard-recent-row__badge {
        justify-self: center;
    }

    .dashboard-recent-row__chevron {
        justify-self: end;
    }
}

@media (min-width: 768px) {
    .dashboard-page {
        gap: 1.75rem;
    }

    .dashboard-stats {
        gap: 1rem;
    }

    .dashboard-stat-card {
        min-height: 6.25rem;
        padding: 1.25rem 1rem;
    }

    .dashboard-recent-list {
        gap: 0.75rem;
    }

    .dashboard-recent-row {
        padding: 1rem 1.15rem;
    }
}

/* ---------- Assessments List ---------- */
.assessments-page {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    width: 100%;
    min-height: 100%;
}

.assessments-page__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.assessments-page__title {
    margin: 0;
    font-size: clamp(1.5rem, 2.2vw, 1.875rem);
    font-weight: 800;
    color: var(--brand-charcoal);
    letter-spacing: -0.025em;
}

.assessments-page__sub {
    margin: 0.35rem 0 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.assessments-toolbar {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.assessments-search {
    width: 100%;
}

.assessments-filters {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.assessments-filter {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-width: 0;
}

.assessments-filter__label {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.assessments-filter__select {
    width: 100%;
    padding: 0.65rem 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: var(--surface-card);
    color: var(--text-primary);
    font-size: 0.875rem;
}

.assessments-filter__select:focus {
    outline: 2px solid rgba(255, 106, 0, 0.25);
    border-color: var(--brand-orange);
}

.assessments-list {
    flex: 1;
}

.assessments-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 2.5rem 1.25rem;
    border: 1px dashed var(--border-color);
    border-radius: var(--radius-md);
    background: var(--surface-card);
    text-align: center;
}

.assessments-empty__icon {
    display: grid;
    place-items: center;
    width: 3.25rem;
    height: 3.25rem;
    margin-bottom: 0.25rem;
    border-radius: var(--radius-md);
    background: var(--surface-muted);
    color: var(--text-secondary);
}

.assessments-empty__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-primary);
}

.assessments-empty__text {
    margin: 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.skeleton-box--assessments-search {
    width: 100%;
    height: 2.75rem;
    border-radius: var(--radius-sm);
}

.skeleton-box--assessments-filter {
    width: 100%;
    height: 2.75rem;
    border-radius: var(--radius-sm);
}

@media (max-width: 767px) {
    .assessments-filters {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 768px) {
    .assessments-toolbar {
        gap: 1rem;
    }
}

/* ---------- Plant Make (Select Plant Type) ---------- */
.plant-make-page {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 100%;
}

.plant-make-intro {
    text-align: center;
    margin-bottom: 1.25rem;
}

.plant-make-intro .page-intro__title {
    font-size: clamp(1.5rem, 2.2vw, 1.875rem);
}

.plant-make-search {
    position: relative;
    margin-bottom: 1.5rem;
}

.plant-make-search__icon {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-secondary);
    pointer-events: none;
    line-height: 0;
}

.plant-make-search__input {
    width: 100%;
    min-height: 48px;
    padding: 0.75rem 1rem 0.75rem 2.75rem;
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-pill);
    background: var(--surface-card);
    color: var(--text-primary);
    font-size: 0.9375rem;
    box-shadow: var(--shadow-xs);
    transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

.plant-make-search__input::placeholder {
    color: color-mix(in srgb, var(--text-secondary) 72%, transparent);
}

.plant-make-search__input:focus {
    outline: none;
    border-color: var(--brand-orange);
    box-shadow: 0 0 0 0.22rem rgba(255, 106, 0, 0.16);
}

.plant-type-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.plant-make-empty {
    margin: 0.5rem 0 0;
    text-align: center;
    color: var(--text-secondary);
    font-size: 0.92rem;
}

.plant-type-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 148px;
    padding: 1.35rem 1rem 1.2rem;
    text-align: center;
    background: var(--surface-card);
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xs);
    color: var(--text-primary);
    cursor: pointer;
    transition: transform var(--dur) var(--ease),
                box-shadow var(--dur) var(--ease),
                border-color var(--dur) var(--ease);
}

.plant-type-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
    border-color: color-mix(in srgb, var(--brand-orange) 45%, var(--border-color));
}

.plant-type-card:active {
    transform: scale(0.985);
}

.plant-type-card.is-selected {
    border-color: var(--brand-orange);
    box-shadow: var(--shadow-sm);
}

.plant-type-card:focus-visible {
    outline: 2px solid var(--brand-orange);
    outline-offset: 2px;
}

.plant-type-card__badge {
    position: absolute;
    top: 0.65rem;
    right: 0.65rem;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--brand-orange);
    color: #fff;
    display: grid;
    place-items: center;
    line-height: 0;
}

.plant-type-card__icon {
    width: 72px;
    height: 72px;
    object-fit: contain;
    margin-bottom: 0.85rem;
    flex-shrink: 0;
    opacity: 0.78;
    filter: grayscale(1) brightness(0.55) contrast(0.9);
    transition: filter var(--dur) var(--ease), opacity var(--dur) var(--ease);
}

.plant-type-card:hover .plant-type-card__icon,
.plant-type-card:focus-visible .plant-type-card__icon {
    opacity: 0.88;
    filter: grayscale(1) brightness(0.58) contrast(0.92);
}

.plant-type-card.is-selected .plant-type-card__icon {
    opacity: 0.92;
    filter: grayscale(1) brightness(0.52) contrast(0.88);
}

.plant-type-card__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.2;
    color: var(--brand-charcoal);
}

.plant-type-card__sub {
    margin: 0.25rem 0 0;
    font-size: 0.8125rem;
    line-height: 1.3;
    color: var(--text-secondary);
}

.plant-make-action-bar {
    margin-top: auto;
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-top: none;
}

.plant-make-action-bar__btn {
    width: 100%;
    max-width: 100%;
    min-height: 52px;
    gap: 0.45rem;
    background: var(--surface-card);
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-pill);
    box-shadow: var(--shadow-xs);
    color: var(--text-secondary);
    font-weight: 600;
}

.plant-make-action-bar__btn:hover,
.plant-make-action-bar__btn:focus-visible {
    border-color: var(--brand-orange);
    color: var(--brand-charcoal);
}

@media (min-width: 768px) {
    .plant-type-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 1.15rem;
    }

    .plant-type-card {
        min-height: 160px;
        padding: 1.5rem 1.1rem 1.35rem;
    }

    .plant-type-card__icon {
        width: 80px;
        height: 80px;
    }

    .plant-type-card__title {
        font-size: 1.0625rem;
    }
}

@media (min-width: 1024px) {
    .plant-type-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 1.25rem;
    }
}

/* ---------- Rich choice card (shared) ---------- */
.rich-choice-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
    padding: 1.35rem 1.35rem 1.2rem;
    text-align: left;
    background: var(--surface-card);
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    color: var(--text-primary);
    cursor: pointer;
    overflow: hidden;
    transition: transform var(--dur) var(--ease),
                box-shadow var(--dur) var(--ease),
                border-color var(--dur) var(--ease);
}

.rich-choice-card__silhouette {
    position: absolute;
    right: 0;
    bottom: 0;
    width: min(52%, 200px);
    height: auto;
    opacity: 0.09;
    filter: grayscale(1) brightness(0.5);
    pointer-events: none;
    user-select: none;
    transition: opacity var(--dur) var(--ease), filter var(--dur) var(--ease);
}

.rich-choice-card__icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: #fff;
    box-shadow: var(--shadow-md);
    display: grid;
    place-items: center;
    color: var(--brand-charcoal);
    margin-bottom: 1rem;
    z-index: 1;
    flex-shrink: 0;
}

.rich-choice-card__content {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    z-index: 1;
    max-width: 85%;
}

.rich-choice-card__title {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 800;
    line-height: 1.28;
    color: var(--brand-charcoal);
    transition: color var(--dur) var(--ease);
}

.rich-choice-card__desc {
    margin: 0;
    font-size: 0.9375rem;
    line-height: 1.45;
    color: var(--text-secondary);
}

.rich-choice-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    width: 100%;
    margin-top: 1.15rem;
    z-index: 1;
}

.rich-choice-card__tag {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.75rem;
    border-radius: var(--radius-pill);
    background: var(--surface-muted);
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--text-secondary);
    line-height: 1.3;
    flex: 1;
    min-width: 0;
    transition: background-color var(--dur) var(--ease), color var(--dur) var(--ease);
}

.rich-choice-card__tag .icon {
    flex-shrink: 0;
    line-height: 0;
}

.rich-choice-card__tag-text {
    flex: 1;
    min-width: 0;
}

.rich-choice-card__arrow {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #fff;
    box-shadow: var(--shadow-sm);
    display: grid;
    place-items: center;
    color: var(--text-secondary);
    transition: color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

.rich-choice-card:hover,
.rich-choice-card:focus-visible {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    border-color: var(--brand-orange);
    outline: none;
}

.rich-choice-card:hover .rich-choice-card__title,
.rich-choice-card:focus-visible .rich-choice-card__title {
    color: var(--brand-orange);
}

.rich-choice-card:hover .rich-choice-card__silhouette,
.rich-choice-card:focus-visible .rich-choice-card__silhouette {
    opacity: 0.14;
    filter: grayscale(0) brightness(0) saturate(100%) invert(42%) sepia(98%) saturate(2800%) hue-rotate(360deg) brightness(103%) contrast(105%);
}

.rich-choice-card:hover .rich-choice-card__tag,
.rich-choice-card:focus-visible .rich-choice-card__tag {
    background: var(--brand-orange-soft);
    color: var(--brand-orange-700);
}

.rich-choice-card:hover .rich-choice-card__arrow,
.rich-choice-card:focus-visible .rich-choice-card__arrow {
    color: var(--brand-orange);
    box-shadow: var(--shadow-brand);
}

.rich-choice-card:active {
    transform: scale(0.985);
}

.rich-choice-card:focus-visible {
    outline: 2px solid var(--brand-orange);
    outline-offset: 2px;
}

@media (min-width: 768px) {
    .rich-choice-card {
        padding: 1.5rem 1.5rem 1.35rem;
    }

    .rich-choice-card__icon {
        width: 52px;
        height: 52px;
        margin-bottom: 1.1rem;
    }

    .rich-choice-card__title {
        font-size: 1.2rem;
    }

    .rich-choice-card__footer {
        margin-top: 1.35rem;
    }

    .rich-choice-card__silhouette {
        width: min(48%, 210px);
    }
}

.action-bar .btn--primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
}

.action-bar--back-only .btn--back {
    flex: 1;
    max-width: 100%;
}

/* ---------- Question Cards ---------- */
.question-block {
    background: var(--surface-card);
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 1.05rem 1.05rem 1.1rem;
    box-shadow: var(--shadow-xs);
    transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

.question-block .form-label {
    font-size: 0.98rem;
    color: var(--text-primary);
    font-weight: 600;
}

.question-block--invalid {
    border-color: var(--danger);
    box-shadow: 0 0 0 3px rgba(217, 45, 57, 0.12);
    animation: shake 0.4s var(--ease);
}

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    20% { transform: translateX(-5px); }
    40% { transform: translateX(5px); }
    60% { transform: translateX(-3px); }
    80% { transform: translateX(3px); }
}

/* Score option pills */
.score-options {
    display: grid;
    gap: 0.5rem;
    width: 100%;
}

.score-options[data-count="2"] { grid-template-columns: repeat(2, 1fr); }
.score-options[data-count="3"] { grid-template-columns: repeat(3, 1fr); }
.score-options[data-count="5"] { grid-template-columns: repeat(5, 1fr); }

.score-pill {
    appearance: none;
    border: 1.5px solid var(--border-strong);
    background: var(--surface-muted);
    color: var(--text-primary);
    border-radius: var(--radius-sm);
    padding: 0.7rem 0.4rem;
    min-height: 52px;
    font-weight: 700;
    font-size: 0.95rem;
    line-height: 1.15;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    transition: transform var(--dur-fast) var(--ease),
                background-color var(--dur) var(--ease),
                border-color var(--dur) var(--ease),
                color var(--dur) var(--ease),
                box-shadow var(--dur) var(--ease);
}

.score-pill:active {
    transform: scale(0.94);
}

.score-pill.is-selected {
    background: var(--brand-orange);
    border-color: var(--brand-orange);
    color: #fff;
    box-shadow: var(--shadow-brand);
}

/* Semantic colours for positive/negative answers */
.score-pill.is-selected[data-tone="positive"] {
    background: var(--semantic-pass);
    border-color: var(--semantic-pass);
    box-shadow: 0 8px 20px rgba(25, 135, 84, 0.28);
}
.score-pill.is-selected[data-tone="negative"] {
    background: var(--danger);
    border-color: var(--danger);
    box-shadow: 0 8px 20px rgba(217, 45, 57, 0.28);
}

.score-pill.is-selected[data-tone="neutral"] {
    background: var(--warning);
    border-color: var(--warning);
    box-shadow: 0 8px 20px rgba(184, 134, 11, 0.28);
}

.question-comment {
    margin-top: 0.85rem;
}

.question-comment .form-label {
    font-size: 0.78rem;
    color: var(--text-secondary);
    font-weight: 600;
}

/* ---------- Section Header ---------- */
.section-header {
    background: linear-gradient(135deg, var(--brand-charcoal) 0%, var(--brand-charcoal-700) 100%);
    color: #ffffff;
    padding: 1rem 1.15rem;
    margin: -1.25rem -1.1rem 1.25rem;
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

.section-subtitle {
    margin: 0 0 0.2rem;
    font-size: 0.78rem;
    opacity: 0.8;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.section-title {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 700;
}

.section-progress {
    margin: 0.5rem 0 0;
    font-size: 0.8rem;
    opacity: 0.85;
}

/* ---------- Section Total ---------- */
.section-total {
    background: var(--brand-orange-soft);
    border: 1.5px solid transparent;
    border-radius: var(--radius-md);
    box-shadow: none;
}

.section-total .card-body {
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: var(--brand-orange-700);
    font-weight: 600;
}

.section-total__value {
    font-size: 1.3rem;
    font-weight: 800;
}

/* ---------- Review & post-scoring ---------- */
.content--review {
    max-width: none;
    width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
}

.content--review.has-action-bar {
    padding-bottom: calc(6.5rem + var(--safe-bottom));
}

.content--complete {
    max-width: none;
    width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
}

.content--complete.has-action-bar {
    padding-bottom: calc(6.5rem + var(--safe-bottom));
}

@media (min-width: 768px) {
    .content--review {
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }

    .content--complete {
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }
}

.review-page-toolbar {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
    margin-bottom: 1.15rem;
}

.review-page-toolbar__intro {
    min-width: 0;
}

.review-page-toolbar__title {
    margin: 0;
    font-size: clamp(1.35rem, 2vw, 1.75rem);
    font-weight: 800;
    line-height: 1.15;
    color: var(--brand-charcoal);
    letter-spacing: -0.02em;
}

.review-page-toolbar__sub {
    margin: 0.35rem 0 0;
    font-size: 0.9375rem;
    line-height: 1.45;
    color: var(--text-secondary);
}

.review-page-toolbar__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.review-toolbar-btn {
    appearance: none;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    min-height: 44px;
    padding: 0.55rem 0.85rem;
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--surface-card);
    color: var(--brand-charcoal);
    font-size: 0.8125rem;
    font-weight: 600;
    line-height: 1.2;
    cursor: pointer;
    transition: border-color var(--dur) var(--ease),
                background-color var(--dur) var(--ease),
                color var(--dur) var(--ease),
                box-shadow var(--dur) var(--ease);
}

.review-toolbar-btn:hover,
.review-toolbar-btn:focus-visible {
    border-color: color-mix(in srgb, var(--brand-orange) 35%, var(--border-color));
    background: var(--surface-muted);
    outline: none;
}

.review-toolbar-btn .icon {
    line-height: 0;
    flex-shrink: 0;
}

.review-toolbar-btn--attention {
    border-color: color-mix(in srgb, var(--brand-orange) 30%, var(--border-color));
    background: var(--brand-orange-soft);
    color: var(--brand-orange-700);
}

.review-toolbar-btn--attention.is-active,
.review-toolbar-btn--attention:hover,
.review-toolbar-btn--attention:focus-visible {
    border-color: var(--brand-orange);
    background: color-mix(in srgb, var(--brand-orange-soft) 65%, #fff);
    color: var(--brand-orange-700);
    box-shadow: 0 0 0 0.15rem rgba(255, 106, 0, 0.12);
}

@media (min-width: 768px) {
    .review-page-toolbar {
        flex-direction: row;
        align-items: flex-start;
        justify-content: space-between;
        gap: 1.25rem;
    }

    .review-page-toolbar__actions {
        justify-content: flex-end;
        flex-shrink: 0;
        max-width: min(100%, 34rem);
    }
}

@media (min-width: 1024px) {
    .review-page-toolbar__actions {
        flex-wrap: nowrap;
    }
}

@media (min-width: 1024px) {
    .review-page-toolbar__actions {
        flex-wrap: nowrap;
    }
}

.review-summary-cards {
    display: grid;
    gap: 0.85rem;
    margin-bottom: 1rem;
}

@media (min-width: 1024px) {
    .review-summary-cards {
        grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
        align-items: stretch;
    }
}

.review-performance-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    grid-template-areas:
        "ring main"
        "insight insight";
    gap: 0.85rem 1rem;
    padding: 1rem 1.05rem;
    border-radius: var(--radius-md);
    background: linear-gradient(135deg, var(--brand-charcoal) 0%, var(--brand-charcoal-700) 100%);
    color: #fff;
    box-shadow: var(--shadow-sm);
}

@media (min-width: 768px) {
    .review-performance-card {
        grid-template-columns: auto minmax(0, 1fr) minmax(10rem, 0.95fr);
        grid-template-areas: "ring main insight";
        align-items: center;
        padding: 1.1rem 1.15rem;
    }
}

.review-performance-card--pass {
    background: linear-gradient(135deg, #168a52 0%, #1aa861 100%);
}

.review-performance-card--fail {
    background: linear-gradient(135deg, #d63b45 0%, #ef5560 100%);
}

.review-performance-card__ring {
    grid-area: ring;
    --score-percent: 0;
    position: relative;
    width: 4.75rem;
    height: 4.75rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    flex-shrink: 0;
    background:
        radial-gradient(farthest-side, var(--brand-charcoal) 72%, transparent 74% 100%),
        conic-gradient(var(--brand-orange) calc(var(--score-percent) * 1%), rgba(255, 255, 255, 0.14) 0);
}

.review-performance-card--pass .review-performance-card__ring {
    background:
        radial-gradient(farthest-side, #168a52 72%, transparent 74% 100%),
        conic-gradient(#fff calc(var(--score-percent) * 1%), rgba(255, 255, 255, 0.18) 0);
}

.review-performance-card--fail .review-performance-card__ring {
    background:
        radial-gradient(farthest-side, #d63b45 72%, transparent 74% 100%),
        conic-gradient(#fff calc(var(--score-percent) * 1%), rgba(255, 255, 255, 0.18) 0);
}

.review-performance-card__ring-value {
    font-size: 1rem;
    font-weight: 800;
    line-height: 1;
}

.review-performance-card__submitted-badge {
    position: absolute;
    top: -0.15rem;
    right: -0.15rem;
    width: 1.35rem;
    height: 1.35rem;
    border-radius: 50%;
    background: #fff;
    color: var(--brand-charcoal);
    display: grid;
    place-items: center;
    box-shadow: 0 2px 6px rgba(42, 47, 54, 0.18);
}

.review-performance-card--pass .review-performance-card__submitted-badge,
.review-performance-card--fail .review-performance-card__submitted-badge {
    color: inherit;
}

.review-performance-card--pass .review-performance-card__submitted-badge {
    color: #168a52;
}

.review-performance-card--fail .review-performance-card__submitted-badge {
    color: #d63b45;
}

.review-page-toolbar--complete {
    margin-bottom: 1rem;
}

.review-performance-card__main {
    grid-area: main;
    min-width: 0;
}

.review-performance-card__label {
    margin: 0;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    opacity: 0.82;
}

.review-performance-card__rating {
    margin: 0.2rem 0 0;
    font-size: clamp(1.25rem, 2vw, 1.55rem);
    font-weight: 800;
    line-height: 1.1;
    color: var(--brand-orange);
}

.review-performance-card--pass .review-performance-card__rating,
.review-performance-card--fail .review-performance-card__rating {
    color: #fff;
}

.review-performance-card__points {
    margin: 0.35rem 0 0;
    font-size: 0.8125rem;
    font-weight: 600;
    opacity: 0.92;
}

.review-performance-card__track {
    margin-top: 0.65rem;
    height: 0.45rem;
    border-radius: var(--radius-pill);
    background: rgba(255, 255, 255, 0.14);
    overflow: hidden;
}

.review-performance-card__fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--brand-orange) 0%, #ff8533 100%);
}

.review-performance-card--pass .review-performance-card__fill,
.review-performance-card--fail .review-performance-card__fill {
    background: rgba(255, 255, 255, 0.92);
}

.review-performance-card__scale {
    display: flex;
    justify-content: space-between;
    margin-top: 0.3rem;
    font-size: 0.68rem;
    font-weight: 600;
    opacity: 0.72;
}

.review-performance-card__insight {
    grid-area: insight;
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    padding-top: 0.65rem;
    border-top: 1px solid rgba(255, 255, 255, 0.14);
}

@media (min-width: 768px) {
    .review-performance-card__insight {
        padding-top: 0;
        padding-left: 0.85rem;
        border-top: none;
        border-left: 1px solid rgba(255, 255, 255, 0.14);
        align-self: stretch;
        align-items: center;
    }
}

.review-performance-card__insight-icon {
    width: 2rem;
    height: 2rem;
    border-radius: var(--radius-sm);
    background: rgba(255, 255, 255, 0.1);
    color: var(--brand-orange);
    display: grid;
    place-items: center;
    flex-shrink: 0;
}

.review-performance-card--pass .review-performance-card__insight-icon,
.review-performance-card--fail .review-performance-card__insight-icon {
    color: #fff;
    background: rgba(255, 255, 255, 0.16);
}

.review-performance-card__insight-text {
    margin: 0;
    font-size: 0.8125rem;
    line-height: 1.45;
    opacity: 0.92;
}

.review-info-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.85rem 1rem;
    padding: 1rem 1.05rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--surface-card);
    box-shadow: var(--shadow-sm);
}

.review-info-card__visual {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    min-width: 5.75rem;
}

.review-info-card__plant {
    width: 5.5rem;
    height: auto;
    max-height: 5.5rem;
    object-fit: contain;
    opacity: 0.88;
}

.review-info-card__make-logo {
    width: 4.5rem;
    height: auto;
    max-height: 1.75rem;
    object-fit: contain;
}

.review-info-card__fields {
    display: grid;
    gap: 0.75rem 1rem;
    grid-template-columns: 1fr;
    align-content: start;
}

@media (min-width: 640px) {
    .review-info-card__fields {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.review-info-card__field {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 0;
}

.review-info-card__label {
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.review-info-card__value {
    font-size: 0.875rem;
    font-weight: 700;
    line-height: 1.35;
    color: var(--brand-charcoal);
    word-break: break-word;
}

.post-scoring-page {
    max-width: 100%;
    overflow-x: hidden;
}

.post-scoring-page .result-hero {
    margin: 1rem 0;
}

.post-scoring-card {
    margin-top: 1rem;
}

.post-scoring-alert {
    margin-top: 1rem;
}

.post-scoring-alert--sync {
    background-color: var(--warning-soft);
    color: var(--warning);
    border: 1px solid color-mix(in srgb, var(--warning) 22%, transparent);
}

.sync-status-banner {
    margin-top: 1rem;
    padding: 0.85rem 1rem;
    border-radius: var(--radius-md);
    border: 1px solid transparent;
}

.sync-status-banner__header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.4;
}

.sync-status-banner__text {
    flex: 1;
}

.sync-status-banner__bar-wrap {
    margin-top: 0.65rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.sync-status-banner__bar {
    height: 0.45rem;
    border-radius: var(--radius-pill);
    background: rgba(42, 47, 54, 0.12);
    overflow: hidden;
}

.sync-status-banner__fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--brand-orange) 0%, #ff8533 100%);
    transition: width 0.35s var(--ease);
}

.sync-status-banner__percent {
    font-size: 0.75rem;
    font-weight: 700;
    opacity: 0.85;
}

.sync-status-banner--pending {
    background-color: var(--warning-soft);
    color: var(--warning);
    border-color: color-mix(in srgb, var(--warning) 22%, transparent);
}

.sync-status-banner--syncing {
    background-color: color-mix(in srgb, var(--brand-orange-soft) 80%, #fff);
    color: var(--brand-orange-700);
    border-color: color-mix(in srgb, var(--brand-orange) 22%, transparent);
}

.sync-status-banner--syncing .sync-status-banner__bar {
    background: color-mix(in srgb, var(--brand-orange) 14%, transparent);
}

.sync-status-banner--success {
    background-color: var(--success-soft);
    color: var(--semantic-pass-700);
    border-color: color-mix(in srgb, var(--semantic-pass) 22%, transparent);
}

.sync-status-banner--offline {
    background-color: var(--warning-soft);
    color: var(--warning);
    border-color: color-mix(in srgb, var(--warning) 22%, transparent);
}

.sync-status-banner--failed {
    background-color: var(--danger-soft);
    color: var(--semantic-fail);
    border-color: color-mix(in srgb, var(--semantic-fail) 22%, transparent);
}

.sync-status-banner--failed .sync-status-banner__fill {
    background: var(--semantic-fail);
}

.post-scoring-actions {
    margin-top: 1.25rem;
}

.post-scoring-actions .btn--primary {
    width: 100%;
}

.review-sections {
    display: grid;
    gap: 0.75rem;
    margin: 1rem 0 1.25rem;
}

.review-section {
    background: var(--surface-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-xs);
}

.review-section__summary {
    list-style: none;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.45rem;
    padding: 0.95rem 1rem;
    color: var(--text-primary);
    font-weight: 700;
    font-size: 0.92rem;
    cursor: pointer;
    background: var(--surface-card);
    transition: background-color var(--dur) var(--ease);
}

.review-section__summary::-webkit-details-marker { display: none; }

.review-section__summary::after {
    content: "⌄";
    margin-left: auto;
    font-size: 1.1rem;
    opacity: 0.55;
    transition: transform var(--dur) var(--ease);
}

.review-section[open] > .review-section__summary {
    background: var(--surface-muted);
    border-bottom: 1px solid var(--border-color);
}

.review-section[open] > .review-section__summary::after {
    transform: rotate(180deg);
}

.review-section__heading {
    flex: 1;
    min-width: 0;
    line-height: 1.3;
}

.review-section__badge {
    display: inline-flex;
    align-items: center;
    padding: 0.18rem 0.55rem;
    border-radius: var(--radius-pill);
    background: var(--brand-orange-soft);
    color: var(--brand-orange-700);
    font-size: 0.72rem;
    font-weight: 700;
}

.review-section__badge--warning {
    background: var(--warning-soft);
    color: var(--warning);
}

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

.review-table__row + .review-table__row .review-table__label,
.review-table__row + .review-table__row .review-table__score {
    border-top: 1px solid var(--border-color);
}

.review-table__label {
    padding: 0.75rem 0 0.75rem 1rem;
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--text-primary);
    vertical-align: top;
}

.review-table__score {
    padding: 0.75rem 1rem 0.75rem 0.5rem;
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--brand-charcoal);
    text-align: right;
    white-space: nowrap;
    vertical-align: top;
}

.review-table__row--unanswered {
    background: var(--warning-soft);
}

.review-table__row--unanswered .review-table__score {
    color: var(--warning);
}

.review-table__comment-row .review-table__comment {
    padding: 0 1rem 0.75rem;
    font-size: 0.82rem;
    color: var(--text-secondary);
    border-top: none;
}

.review-section__footer {
    padding: 0.75rem 1rem;
    border-top: 1px solid var(--border-color);
    background: var(--surface-muted);
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--brand-charcoal);
}

.summary-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

/* ---------- Result hero (Complete) ---------- */
.result-hero {
    text-align: center;
    padding: 1.75rem 1.25rem;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    color: #fff;
    animation: pop-in var(--dur-slow) var(--ease);
}

.result-hero--pass { background: linear-gradient(135deg, var(--semantic-pass) 0%, #1aa861 100%); }
.result-hero--fail { background: linear-gradient(135deg, var(--semantic-fail) 0%, #ef5560 100%); }
.result-hero--info { background: linear-gradient(135deg, var(--brand-charcoal) 0%, var(--brand-charcoal-700) 100%); }

.result-hero__icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.18);
    display: grid;
    place-items: center;
    margin: 0 auto 0.85rem;
}

.result-hero__title { font-size: 1.6rem; font-weight: 800; margin: 0; }
.result-hero__sub { opacity: 0.9; margin: 0.3rem 0 0; }

@keyframes pop-in {
    from { opacity: 0; transform: scale(0.92); }
    to { opacity: 1; transform: scale(1); }
}

/* ---------- Info / detail rows ---------- */
.detail-list { display: grid; gap: 0.85rem; }

.detail-row { display: flex; flex-direction: column; }

.detail-row__label {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-secondary);
    font-weight: 700;
}

.detail-row__value {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
}

/* ---------- Operator tab (Scoring Phase) ---------- */
.operator-tab {
    max-width: 100%;
}

.operator-info-page .page-intro {
    margin-bottom: 0.15rem;
}

/* ---------- Section Summary (Assessment tab) ---------- */
.section-summary {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 1rem 1.05rem;
    background: var(--surface-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    margin-bottom: 1rem;
}

.section-summary__gauge {
    --completion: 0;
    width: 64px;
    height: 64px;
    flex-shrink: 0;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background:
        radial-gradient(farthest-side, var(--surface-card) 76%, transparent 78% 100%),
        conic-gradient(var(--brand-orange) calc(var(--completion) * 1%), var(--surface-muted) 0);
}

.section-summary__gauge-value {
    font-size: 0.82rem;
    font-weight: 800;
    color: var(--brand-charcoal);
}

.section-summary__body {
    flex: 1;
    min-width: 0;
}

.section-summary__meta {
    margin: 0;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.section-summary__title {
    margin: 0.15rem 0 0;
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--brand-charcoal);
    line-height: 1.25;
}

.section-summary__score {
    margin: 0.35rem 0 0;
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--brand-orange);
}

.section-summary__track {
    margin-top: 0.65rem;
    height: 6px;
    border-radius: var(--radius-pill);
    background: var(--surface-muted);
    overflow: hidden;
}

.section-summary__fill {
    height: 100%;
    border-radius: var(--radius-pill);
    background: linear-gradient(90deg, var(--brand-orange) 0%, #FF8533 100%);
    transition: width var(--dur-slow) var(--ease);
}

/* ---------- Element table (Assessment tab) ---------- */
.assessment-tab {
    max-width: 100%;
}

.element-table {
    background: var(--surface-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    margin-bottom: 1rem;
}

.element-table__header,
.element-row__main {
    display: grid;
    grid-template-columns: 2rem minmax(0, 1fr) minmax(8.5rem, 42%) 44px;
    gap: 0.45rem;
    align-items: center;
}

.element-table__header {
    padding: 0.55rem 0.75rem;
    background: var(--surface-muted);
    border-bottom: 1px solid var(--border-color);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.element-row + .element-row .element-row__main {
    border-top: 1px solid var(--border-color);
}

.element-row__main {
    padding: 0.75rem;
}

.element-row__num {
    font-size: 0.82rem;
    font-weight: 800;
    color: var(--text-secondary);
    text-align: center;
}

.element-row__label {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.3;
}

.element-row__score {
    min-width: 0;
}

.element-row__comment-btn {
    appearance: none;
    border: none;
    background: transparent;
    color: var(--text-secondary);
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    cursor: pointer;
    padding: 0;
}

.element-row__comment-btn.is-active,
.element-row__comment-btn:hover,
.element-row__comment-btn:focus-visible {
    color: var(--brand-orange);
    background: var(--brand-orange-soft);
    outline: none;
}

.element-row__comment-spacer {
    width: 44px;
    height: 44px;
}

.element-row__comment {
    padding: 0 0.75rem 0.85rem 2.75rem;
    background: var(--surface-muted);
    border-top: 1px solid var(--border-color);
}

.element-row--expanded .element-row__main {
    background: var(--surface-muted);
}

.element-row__comment-label {
    display: block;
    margin: 0 0 0.35rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-secondary);
}

.element-row__comment-input {
    min-height: 72px;
    font-size: 0.9rem;
}

.element-row__comment-count {
    margin: 0.35rem 0 0;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-align: right;
}

.element-row--invalid .element-row__main {
    box-shadow: inset 0 0 0 2px var(--semantic-fail);
    animation: shake 0.4s var(--ease);
}

.score-options--table {
    display: grid;
    gap: 0.25rem;
    width: 100%;
}

.score-options--table-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

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

.score-options--table-stack {
    grid-template-columns: minmax(0, 1fr);
}

.score-pill--table {
    min-height: 44px;
    padding: 0.4rem 0.3rem;
    font-size: 0.72rem;
    line-height: 1.1;
}

.score-pill--table.is-selected:not([data-tone]) {
    background: var(--brand-orange);
    border-color: var(--brand-orange);
    color: #fff;
    box-shadow: var(--shadow-brand);
}

@media (min-width: 768px) {
    .score-pill--table {
        font-size: 0.78rem;
    }

    .element-table__header,
    .element-row__main {
        grid-template-columns: 2.25rem minmax(0, 1fr) minmax(10rem, 38%) 44px;
        gap: 0.65rem;
    }
}

/* ---------- Not Found ---------- */
.not-found-page {
    padding-top: 0.25rem;
}

.not-found-card {
    margin-top: 1rem;
}

.not-found-card__body {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.75rem;
    padding: 1.75rem 1.25rem 1.5rem !important;
}

.not-found-card__logo {
    width: 80px;
    height: 80px;
    object-fit: contain;
}

.not-found-card__code {
    margin: 0;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.not-found-card .btn--primary {
    width: 100%;
    margin-top: 0.25rem;
}

/* ---------- Icon helper ---------- */
.icon {
    display: inline-flex;
    vertical-align: middle;
}

.icon svg { display: block; }

/* ---------- Skeleton loading ---------- */
.skeleton-box {
    position: relative;
    overflow: hidden;
    background: var(--surface-muted);
    border-radius: var(--radius-sm);
}

.skeleton-box::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
        90deg,
        transparent 0%,
        rgba(255, 255, 255, 0.55) 50%,
        transparent 100%
    );
    transform: translateX(-100%);
    animation: skeleton-shimmer 1.5s ease-in-out infinite;
}

@keyframes skeleton-shimmer {
    100% { transform: translateX(100%); }
}

.skeleton-box--eyebrow {
    width: 7.5rem;
    height: 0.75rem;
    border-radius: var(--radius-pill);
    margin-bottom: 0.5rem;
}

.skeleton-box--hero-title {
    width: 100%;
    max-width: 28rem;
    height: 1.35rem;
    border-radius: var(--radius-pill);
    margin-bottom: 0.45rem;
}

.skeleton-box--hero-title-short {
    max-width: 18rem;
}

.skeleton-box--hero-sub {
    width: 100%;
    max-width: 16rem;
    height: 0.9rem;
    border-radius: var(--radius-pill);
    margin-top: 0.5rem;
}

.skeleton-box--hero-logo {
    width: 80px;
    height: 80px;
    border-radius: var(--radius-md);
    flex-shrink: 0;
}

.skeleton-rich-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
    padding: 1.35rem 1.35rem 1.2rem;
    background: var(--surface-card);
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

.skeleton-box--rich-icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    margin-bottom: 1rem;
}

.skeleton-box--rich-title {
    width: 72%;
    height: 1.15rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--rich-desc {
    width: 100%;
    height: 0.85rem;
    border-radius: var(--radius-pill);
    margin-top: 0.45rem;
}

.skeleton-box--rich-desc-short {
    width: 78%;
}

.skeleton-rich-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    width: 100%;
    margin-top: 1.15rem;
}

.skeleton-box--rich-tag {
    flex: 1;
    height: 2rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--rich-arrow {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    flex-shrink: 0;
}

.skeleton-help-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.85rem 1.25rem;
    margin-top: auto;
    padding: 0.9rem 1.15rem;
    background: var(--surface-muted);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
}

.skeleton-box--help-icon {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-sm);
    flex-shrink: 0;
}

.skeleton-help-bar__text {
    flex: 1;
    min-width: min(100%, 14rem);
}

.skeleton-box--help-line {
    width: 100%;
    height: 0.85rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--help-line-short {
    width: 72%;
    margin-top: 0.4rem;
}

.skeleton-box--help-link {
    width: 8.5rem;
    height: 0.85rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--intro-title {
    width: min(100%, 14rem);
    height: 1.5rem;
    border-radius: var(--radius-pill);
    margin: 0 auto;
}

.skeleton-box--intro-sub {
    width: min(100%, 20rem);
    height: 0.9rem;
    border-radius: var(--radius-pill);
    margin: 0.35rem auto 0;
}

.skeleton-box--search {
    width: 100%;
    height: 48px;
    border-radius: var(--radius-pill);
    margin-bottom: 1.5rem;
}

.skeleton-plant-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 148px;
    padding: 1.35rem 1rem 1.2rem;
    background: var(--surface-card);
    border: 1.5px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xs);
}

.skeleton-box--plant-icon {
    width: 72px;
    height: 72px;
    border-radius: var(--radius-md);
    margin-bottom: 0.85rem;
}

.skeleton-box--plant-title {
    width: 5.5rem;
    height: 1rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--plant-sub {
    width: 4.25rem;
    height: 0.75rem;
    border-radius: var(--radius-pill);
    margin-top: 0.25rem;
}

.skeleton-box--back-btn {
    width: 100%;
    height: 52px;
    border-radius: var(--radius-pill);
}

@media (min-width: 768px) {
    .skeleton-box--hero-logo {
        width: 104px;
        height: 104px;
    }

    .skeleton-rich-card {
        padding: 1.5rem 1.5rem 1.35rem;
    }

    .skeleton-plant-card {
        min-height: 160px;
        padding: 1.5rem 1.1rem 1.35rem;
    }

    .skeleton-box--plant-icon {
        width: 80px;
        height: 80px;
    }
}

/* ---------- Operator info skeleton ---------- */
.operator-info-skeleton {
    gap: 1.15rem;
}

.operator-info-skeleton .skeleton-box {
    background: color-mix(in srgb, var(--surface-muted) 88%, #fff);
}

.operator-info-skeleton .skeleton-box::after {
    background: linear-gradient(
        90deg,
        transparent 0%,
        rgba(255, 255, 255, 0.2) 30%,
        rgba(255, 255, 255, 0.85) 50%,
        rgba(255, 255, 255, 0.2) 70%,
        transparent 100%
    );
    animation: skeleton-shimmer 1.35s ease-in-out infinite;
}

.operator-info-skeleton .operator-select-panel,
.operator-info-skeleton .operator-info-panel,
.operator-info-skeleton .skeleton-setup-context-card,
.operator-info-skeleton .skeleton-operator-info-field {
    position: relative;
    overflow: hidden;
}

.operator-info-skeleton .operator-select-panel::before,
.operator-info-skeleton .operator-info-panel::before,
.operator-info-skeleton .skeleton-setup-context-card::before,
.operator-info-skeleton .skeleton-operator-info-field::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
        90deg,
        transparent 0%,
        rgba(255, 255, 255, 0.45) 50%,
        transparent 100%
    );
    transform: translateX(-100%);
    animation: skeleton-shimmer 1.6s ease-in-out infinite;
    pointer-events: none;
    z-index: 1;
}

.operator-info-skeleton .operator-select-panel > *,
.operator-info-skeleton .operator-info-panel > *,
.operator-info-skeleton .skeleton-setup-context-card > *,
.operator-info-skeleton .skeleton-operator-info-field > * {
    position: relative;
    z-index: 2;
}

.skeleton-setup-page-header {
    margin-bottom: 0;
}

.skeleton-box--page-header-title {
    width: min(100%, 12rem);
    height: 1.75rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--page-header-sub {
    width: min(100%, 16rem);
    height: 0.9rem;
    border-radius: var(--radius-pill);
    margin-top: 0.4rem;
}

.skeleton-setup-context-card {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    width: 100%;
    padding: 0.85rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--surface-card);
}

.skeleton-setup-context-card__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.skeleton-box--context-icon {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-md);
    flex-shrink: 0;
}

.skeleton-box--context-type {
    width: 6.5rem;
    height: 0.75rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--context-name {
    width: 4.5rem;
    height: 0.95rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--context-desc {
    width: 8.5rem;
    height: 0.75rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--operator-label {
    width: 7rem;
    height: 0.9rem;
    border-radius: var(--radius-pill);
    margin-bottom: 0.75rem;
}

.skeleton-box--operator-info-title {
    width: 9rem;
    height: 1rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--operator-info-note {
    width: 7.5rem;
    height: 0.75rem;
    border-radius: var(--radius-pill);
}

.skeleton-operator-info-field {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.85rem 0.9rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: var(--surface-bg);
}

.skeleton-box--operator-field-icon {
    width: 2rem;
    height: 2rem;
    border-radius: var(--radius-sm);
    flex-shrink: 0;
}

.skeleton-operator-info-field__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.skeleton-box--operator-field-label {
    width: 55%;
    height: 0.7rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--operator-field-value {
    width: 75%;
    height: 0.9rem;
    border-radius: var(--radius-pill);
}

.skeleton-nav-bar {
    pointer-events: none;
}

.skeleton-box--nav-back {
    width: 56px;
    height: 54px;
    border-radius: var(--radius-pill);
    flex-shrink: 0;
}

.skeleton-box--nav-next {
    flex: 1;
    height: 54px;
    border-radius: var(--radius-pill);
}

/* ---------- Review loading screen ---------- */
.review-loading-screen {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: min(32rem, calc(100dvh - 11rem));
    padding: 2.5rem 1.5rem;
    gap: 0.65rem;
    text-align: center;
}

.review-loading-screen__logo {
    width: 5rem;
    height: 5rem;
    object-fit: contain;
    margin-bottom: 0.15rem;
}

.review-loading-screen__title {
    margin: 0;
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--brand-charcoal);
}

.review-loading-screen__status {
    margin: 0 0 0.35rem;
    font-size: 0.92rem;
    font-weight: 500;
    color: var(--text-secondary);
}

.review-loading-screen__bar-wrap {
    width: min(100%, 22rem);
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.45rem;
}

.review-loading-screen__bar {
    height: 0.55rem;
    border-radius: var(--radius-pill);
    background: var(--border-color);
    overflow: hidden;
}

.review-loading-screen__fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--brand-orange) 0%, #ff8533 100%);
    transition: width 0.35s var(--ease);
}

.review-loading-screen__percent {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--text-secondary);
    letter-spacing: 0.02em;
}

/* ---------- Review page skeleton ---------- */
.review-page-skeleton .skeleton-box {
    background: color-mix(in srgb, var(--surface-muted) 88%, #fff);
}

.review-page-skeleton .skeleton-box::after {
    background: linear-gradient(
        90deg,
        transparent 0%,
        rgba(255, 255, 255, 0.2) 30%,
        rgba(255, 255, 255, 0.85) 50%,
        rgba(255, 255, 255, 0.2) 70%,
        transparent 100%
    );
    animation: skeleton-shimmer 1.35s ease-in-out infinite;
}

.skeleton-box--review-title {
    width: min(100%, 12rem);
    height: 1.55rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--review-sub {
    width: min(100%, 22rem);
    height: 0.9rem;
    border-radius: var(--radius-pill);
    margin-top: 0.45rem;
}

.skeleton-box--review-toolbar-btn {
    width: 6.5rem;
    height: 44px;
    border-radius: var(--radius-md);
}

.skeleton-box--review-toolbar-btn-wide {
    width: min(100%, 12rem);
}

.skeleton-review-performance-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    grid-template-areas:
        "ring main"
        "insight insight";
    gap: 0.85rem 1rem;
    padding: 1rem 1.05rem;
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--brand-charcoal) 92%, #000);
}

@media (min-width: 768px) {
    .skeleton-review-performance-card {
        grid-template-columns: auto minmax(0, 1fr) minmax(8rem, 0.9fr);
        grid-template-areas: "ring main insight";
        align-items: center;
    }
}

.skeleton-box--review-ring {
    grid-area: ring;
    width: 4.75rem;
    height: 4.75rem;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.12);
}

.skeleton-review-performance-card__main {
    grid-area: main;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.skeleton-box--review-performance-label {
    width: 7rem;
    height: 0.72rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--review-performance-rating {
    width: 6.5rem;
    height: 1.35rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--review-performance-points {
    width: 8.5rem;
    height: 0.82rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--review-performance-track {
    width: 100%;
    height: 0.45rem;
    border-radius: var(--radius-pill);
    margin-top: 0.15rem;
}

.skeleton-review-performance-card__insight {
    grid-area: insight;
    display: flex;
    align-items: center;
    gap: 0.55rem;
    padding-top: 0.65rem;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
}

@media (min-width: 768px) {
    .skeleton-review-performance-card__insight {
        padding-top: 0;
        padding-left: 0.85rem;
        border-top: none;
        border-left: 1px solid rgba(255, 255, 255, 0.12);
    }
}

.skeleton-box--review-insight-icon {
    width: 2rem;
    height: 2rem;
    border-radius: var(--radius-sm);
    flex-shrink: 0;
}

.skeleton-box--review-insight-text {
    flex: 1;
    height: 2.4rem;
    border-radius: var(--radius-sm);
}

.skeleton-review-info-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.85rem 1rem;
    padding: 1rem 1.05rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--surface-card);
}

.skeleton-box--review-plant {
    width: 5.5rem;
    height: 5.5rem;
    border-radius: var(--radius-md);
}

.skeleton-review-info-card__visual {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.55rem;
}

.skeleton-box--review-make-logo {
    width: 4.5rem;
    height: 1.25rem;
    border-radius: var(--radius-pill);
}

.skeleton-review-info-card__fields {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: 1fr;
}

@media (min-width: 640px) {
    .skeleton-review-info-card__fields {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.skeleton-review-info-card__field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.skeleton-box--review-info-label {
    width: 5.5rem;
    height: 0.68rem;
    border-radius: var(--radius-pill);
}

.skeleton-box--review-info-value {
    width: 85%;
    height: 0.9rem;
    border-radius: var(--radius-pill);
}

.skeleton-review-section {
    padding: 0.95rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--surface-card);
}

.skeleton-box--review-section-heading {
    width: min(100%, 18rem);
    height: 1rem;
    border-radius: var(--radius-pill);
}

@media (min-width: 768px) {
    .skeleton-setup-page-header {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 2rem;
    }

    .skeleton-setup-context-card {
        width: min(100%, 22rem);
    }

    .skeleton-box--context-icon {
        width: 64px;
        height: 64px;
    }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
        scroll-behavior: auto !important;
    }
}

/* ---------- Validation (Blazor default) ---------- */
.valid.modified:not([type=checkbox]) { outline: 1px solid var(--brand-orange); }
.invalid { outline: 1px solid var(--danger); }
.validation-message { color: var(--danger); }

/* ---------- Blazor error UI ---------- */
#blazor-error-ui {
    color-scheme: light only;
    background: var(--danger-soft);
    color: var(--text-primary);
    border-top: 2px solid var(--semantic-fail);
    bottom: 0;
    box-shadow: 0 -4px 16px rgba(42, 47, 54, 0.12);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.75rem 3.25rem 0.75rem 1.15rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
    font-size: 0.88rem;
    font-weight: 600;
}

#blazor-error-ui .blazor-error-ui__reload,
#blazor-error-ui .reload {
    color: var(--brand-orange);
    font-weight: 700;
    margin-left: 0.35rem;
}

#blazor-error-ui .blazor-error-ui__reload:hover,
#blazor-error-ui .reload:hover {
    color: var(--brand-orange-700);
}

#blazor-error-ui .dismiss,
#blazor-error-ui .blazor-error-ui__dismiss {
    appearance: none;
    border: none;
    background: transparent;
    cursor: pointer;
    position: absolute;
    right: 0.35rem;
    top: 50%;
    transform: translateY(-50%);
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    font-size: 1.1rem;
    padding: 0;
}

#blazor-error-ui .dismiss:hover,
#blazor-error-ui .blazor-error-ui__dismiss:hover {
    color: var(--text-primary);
}

.blazor-error-boundary {
    background: var(--danger-soft);
    border: 1px solid color-mix(in srgb, var(--semantic-fail) 35%, transparent);
    border-radius: var(--radius-md);
    padding: 1rem 1.15rem;
    color: var(--text-primary);
}

.blazor-error-boundary::after {
    content: "An error has occurred.";
    font-weight: 600;
}

/* ---------- Loading splash ---------- */
#app {
    min-height: 100dvh;
    background: var(--surface-bg);
}

.loading-splash {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100dvh;
    padding: 2rem 1.5rem;
    gap: 0.65rem;
}

.loading-splash__logo {
    width: 96px;
    height: 96px;
    object-fit: contain;
    margin-bottom: 0.15rem;
}

.loading-splash__brand {
    margin: 0 0 0.35rem;
    font-size: 1.45rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--brand-charcoal);
}

.loading-progress {
    position: relative;
    display: block;
    width: 8rem;
    height: 8rem;
    margin: 0;
    inset: unset;
}

    .loading-progress circle {
        fill: none;
        stroke: var(--border-color);
        stroke-width: 0.6rem;
        transform-origin: 50% 50%;
        transform: rotate(-90deg);
    }

        .loading-progress circle:last-child {
            stroke: var(--brand-orange);
            stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
            transition: stroke-dasharray 0.05s ease-in-out;
        }

.loading-progress-text {
    position: relative;
    text-align: center;
    font-weight: 600;
    font-size: 0.88rem;
    inset: unset;
    margin: 0;
    color: var(--text-secondary);
    letter-spacing: 0.01em;
}


/* ---------- Certificate & PDF ---------- */
.certificate-page .certificate-form {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    margin-top: 0.5rem;
}

.certificate-form__field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.certificate-form__label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin: 0;
}

.certificate-form__input {
    max-width: 28rem;
}

.certificate-form__readonly {
    margin: 0;
    font-weight: 600;
    color: var(--text-primary);
}

.certificate-form__signatures {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
}

@media (min-width: 768px) {
    .certificate-form__signatures {
        grid-template-columns: 1fr 1fr;
    }
}

.signature-pad {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.signature-pad__label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin: 0;
}

.signature-pad__surface {
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: #fff;
    overflow: hidden;
}

.signature-pad__canvas {
    display: block;
    width: 100%;
    height: auto;
    touch-action: none;
    cursor: crosshair;
}

.signature-pad__actions {
    display: flex;
    justify-content: flex-end;
}

.certificate-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1.25rem;
}

.certificate-actions--inline {
    margin-top: 1rem;
    padding-top: 0.5rem;
}

.certificate-form__error {
    margin: 0.75rem 0 0;
    color: var(--semantic-fail);
    font-size: 0.9rem;
    font-weight: 500;
}

.pdf-preview-modal {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.pdf-preview-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(42, 47, 54, 0.55);
}

.pdf-preview-modal__panel {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    width: min(960px, 100%);
    max-height: min(92dvh, 900px);
    background: var(--surface-card);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    overflow: hidden;
}

.pdf-preview-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 1rem;
    border-bottom: 1px solid var(--border-color);
}

.pdf-preview-modal__title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 700;
}

.pdf-preview-modal__close {
    border: 0;
    background: transparent;
    padding: 0.25rem;
    color: var(--text-secondary);
    cursor: pointer;
}

.pdf-preview-modal__body {
    flex: 1;
    min-height: 0;
    background: #f4f5f7;
}

.pdf-preview-modal__frame {
    width: 100%;
    height: min(70dvh, 720px);
    border: 0;
    display: block;
}

.pdf-preview-modal__footer {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.65rem;
    padding: 0.85rem 1rem;
    border-top: 1px solid var(--border-color);
}

/* ---------- Login ---------- */
.login-layout {
    min-height: 100dvh;
    background: var(--surface-bg);
    padding: max(1rem, var(--safe-top)) max(1rem, var(--safe-right)) max(1rem, var(--safe-bottom)) max(1rem, var(--safe-left));
}

.login-page {
    min-height: calc(100dvh - 2rem);
    display: flex;
    align-items: center;
    justify-content: center;
}

.login-card {
    width: min(100%, 28rem);
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 1rem;
    padding: 1.5rem;
    box-shadow: 0 8px 24px rgba(42, 47, 54, 0.08);
}

.login-card__brand {
    text-align: center;
    margin-bottom: 1.5rem;
}

.login-card__logo {
    margin-bottom: 0.75rem;
    display: block;
    margin-inline: auto;
    object-fit: contain;
}

.login-card__title .app-title__level {
    color: #000;
}

.login-card__title {
    margin: 0;
    font-size: 1.75rem;
}

.login-card__subtitle {
    margin: 0.35rem 0 0;
    color: var(--text-secondary);
}

.login-form {
    display: grid;
    gap: 1rem;
}

.login-form__field {
    display: grid;
    gap: 0.4rem;
}

.login-form__label {
    font-weight: 600;
    color: var(--text-primary);
}

.login-form__input {
    min-height: 44px;
    width: 100%;
    border: 1px solid var(--border-color);
    border-radius: 0.65rem;
    padding: 0.75rem 0.9rem;
    font-size: 1rem;
    background: #fff;
}

.login-form__submit {
    min-height: 48px;
    width: 100%;
    margin-top: 0.25rem;
}

.login-form__error {
    padding: 0.75rem 0.9rem;
    border-radius: 0.65rem;
    background: rgba(217, 45, 57, 0.08);
    color: var(--fail);
}

.login-form__notice {
    padding: 0.75rem 0.9rem;
    border-radius: 0.65rem;
    background: rgba(42, 47, 54, 0.06);
    color: var(--text-secondary);
}

.login-form__field--checkbox {
    margin-top: -0.25rem;
}

.login-form__remember {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    font-size: 0.92rem;
    color: var(--text-secondary);
    cursor: pointer;
}

.auth-loading {
    display: grid;
    place-items: center;
    min-height: 40vh;
    padding: 2rem;
    color: var(--text-secondary);
    text-align: center;
}

.offline-banner--grace {
    background: rgba(255, 167, 38, 0.12);
    color: #9a6700;
}

.session-expiry-banner,
.sync-conflict-banner {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.65rem 1rem;
    font-size: 0.92rem;
}

.session-expiry-banner--warning,
.sync-conflict-banner {
    background: rgba(255, 167, 38, 0.12);
    color: #9a6700;
}

.device-unlock {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: grid;
    place-items: center;
    padding: 1.5rem;
    background: rgba(42, 47, 54, 0.72);
    backdrop-filter: blur(4px);
}

.device-unlock__card {
    width: min(100%, 22rem);
    padding: 1.5rem;
    border-radius: 1rem;
    background: #fff;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.18);
}

.device-unlock__title {
    margin: 0;
    font-size: 1.35rem;
}

.device-unlock__subtitle {
    margin: 0.5rem 0 1rem;
    color: var(--text-secondary);
}

.device-unlock__input {
    width: 100%;
    min-height: 48px;
    margin-bottom: 1rem;
    padding: 0.75rem 0.9rem;
    border: 1px solid var(--border-color);
    border-radius: 0.65rem;
    font-size: 1.25rem;
    letter-spacing: 0.2em;
    text-align: center;
}

.device-unlock__submit {
    width: 100%;
    min-height: 48px;
}

.device-unlock__error {
    margin-bottom: 0.75rem;
    padding: 0.65rem 0.85rem;
    border-radius: 0.65rem;
    background: rgba(217, 45, 57, 0.08);
    color: var(--fail);
}

.device-security-page {
    max-width: 32rem;
    margin: 0 auto;
    padding: 1.5rem 1rem 2rem;
}

.device-security-page__header h1 {
    margin: 0.5rem 0;
}

.device-security-page__lead {
    color: var(--text-secondary);
}

.device-security-page__card {
    display: grid;
    gap: 0.85rem;
    margin-top: 1.25rem;
    padding: 1.25rem;
    border: 1px solid var(--border-color);
    border-radius: 0.85rem;
    background: #fff;
}

.device-security-page__field {
    display: grid;
    gap: 0.35rem;
}

.device-security-page__input {
    min-height: 44px;
    padding: 0.65rem 0.85rem;
    border: 1px solid var(--border-color);
    border-radius: 0.65rem;
}

.device-security-page__message {
    padding: 0.75rem 0.9rem;
    border-radius: 0.65rem;
    background: rgba(38, 166, 154, 0.1);
    color: #1b7f74;
}

.device-security-page__error {
    padding: 0.75rem 0.9rem;
    border-radius: 0.65rem;
    background: rgba(217, 45, 57, 0.08);
    color: var(--fail);
}

.app-header__user {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin-right: 0.35rem;
}

.app-header__profile {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.2rem 0.75rem 0.2rem 0.2rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.14);
}

.app-header__profile--link {
    text-decoration: none;
    color: inherit;
    cursor: pointer;
    transition: background 0.15s ease;
}

.app-header__profile--link:hover,
.app-header__profile--link:focus-visible {
    background: rgba(255, 255, 255, 0.16);
    outline: none;
}

.app-header__avatar {
    width: 36px;
    height: 36px;
    min-width: 36px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: #fff;
    text-transform: uppercase;
    flex-shrink: 0;
}

.app-header__user-copy {
    display: none;
    flex-direction: column;
    align-items: flex-start;
    padding: 0;
    border-radius: 0;
    background: transparent;
    border: 0;
}

.app-header__user-name {
    font-size: 0.8rem;
    font-weight: 600;
    color: #fff;
    line-height: 1.2;
}

.app-header__user-role {
    font-size: 0.7rem;
    color: rgba(255, 255, 255, 0.78);
    line-height: 1.2;
}

.app-header__icon-btn {
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 0.65rem;
    background: transparent;
    color: rgba(255, 255, 255, 0.82);
    text-decoration: none;
}

.app-header__icon-btn:hover,
.app-header__icon-btn:focus-visible {
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
}

@media (min-width: 768px) {
    .login-card {
        padding: 2rem;
    }

    .app-header__user-copy {
        display: flex;
    }
}

/* ---------- Admin users ---------- */
.admin-users__form-card,
.admin-users__list {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 0.85rem;
    padding: 1rem;
    margin-bottom: 1rem;
}

.admin-users__section-title {
    margin: 0 0 1rem;
    font-size: 1.1rem;
}

.admin-users__form {
    display: grid;
    gap: 0.85rem;
}

.admin-users__field {
    display: grid;
    gap: 0.35rem;
}

.admin-users__label {
    font-weight: 600;
}

.admin-users__input {
    min-height: 44px;
    border: 1px solid var(--border-color);
    border-radius: 0.65rem;
    padding: 0.65rem 0.85rem;
    font-size: 1rem;
}

.admin-users__submit {
    min-height: 48px;
    justify-self: start;
}

.admin-users__rows {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.65rem;
}

.admin-users__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.75rem;
    border: 1px solid var(--border-color);
    border-radius: 0.65rem;
}

.admin-users__row-name {
    display: block;
    font-weight: 600;
}

.admin-users__row-meta {
    display: block;
    color: var(--text-secondary);
    font-size: 0.85rem;
}

.admin-users__status {
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.25rem 0.5rem;
    border-radius: 999px;
    white-space: nowrap;
}

.admin-users__status--active {
    background: rgba(25, 135, 84, 0.12);
    color: var(--pass);
}

.admin-users__status--inactive {
    background: rgba(217, 45, 57, 0.1);
    color: var(--fail);
}

.auth-denied {
    padding: 2rem 1rem;
    text-align: center;
}
