:root {
    color-scheme: light;
    --bg: #fff7f0;
    --card: #ffffff;
    --text: #8a3412;
    --muted: #b45309;
    --line: #f7c8a8;
    --primary: #f97316;
    --primary2: #ea580c;
    --soft: #fff0e6;
    --danger: #b42318;
    --success: #067647;
    --overlay: rgba(72, 36, 12, 0.52);
}

:root[data-theme="dark"] {
    color-scheme: dark;
    --bg: #0f1116;
    --card: #171c24;
    --text: #f4f7fb;
    --muted: #c3cfdd;
    --line: #2d3642;
    --primary: #fb923c;
    --primary2: #f97316;
    --soft: #1c222c;
    --danger: #fb7185;
    --success: #4ade80;
    --overlay: rgba(0, 0, 0, 0.74);
}

* {
    box-sizing: border-box;
}

[hidden] {
    display: none !important;
}

html {
    background: var(--bg);
}

body {
    margin: 0;
    font-family:
        Inter,
        ui-sans-serif,
        system-ui,
        -apple-system,
        Segoe UI,
        sans-serif;
    background:
        radial-gradient(
            circle at top left,
            rgba(249, 115, 22, 0.08),
            transparent 30%
        ),
        linear-gradient(180deg, var(--bg), var(--bg));
    color: var(--text);
    min-height: 100vh;
}

:root[data-theme="dark"] body {
    background: linear-gradient(180deg, var(--bg), var(--bg));
}

h1,
h2,
h3 {
    margin: 0;
}

.eyebrow {
    margin: 0 0 4px;
    color: var(--primary);
    font-size: 12px;
    text-transform: uppercase;
    font-weight: 800;
    letter-spacing: 0.08em;
}

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

.topbar {
    position: sticky;
    top: 0;
    z-index: 10;
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
    padding: 18px 28px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.08)),
        color-mix(in srgb, var(--card) 86%, transparent);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--line);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
}

:root[data-theme="dark"] .topbar {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
        rgba(15, 17, 22, 0.88);
}
.brand-wrap {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

.brand-logos {
    display: flex;
    gap: 10px;
    align-items: center;
}

.brand-logo {
    width: 46px;
    height: 46px;
    object-fit: contain;
    display: block;
}

.brand-copy {
    display: grid;
    gap: 2px;
}

.brand-copy small {
    color: var(--muted);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.02em;
}

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

.theme-toggle,
.logout {
    border: 1px solid var(--line);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.05)),
        color-mix(in srgb, var(--card) 80%, transparent);
    color: var(--primary);
    text-decoration: none;
    font-weight: 800;
    padding: 10px 14px;
    border-radius: 999px;
    cursor: pointer;
    transition:
        transform 0.15s ease,
        background 0.15s ease,
        color 0.15s ease;
}

.theme-toggle:hover,
.logout:hover {
    transform: translateY(-1px);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.06)),
        color-mix(in srgb, var(--primary) 18%, var(--card));
    color: var(--primary2);
}

.back-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--primary);
    text-decoration: none;
    font-weight: 800;
    margin-bottom: 16px;
    padding: 8px 14px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.04)),
        color-mix(in srgb, var(--card) 84%, transparent);
    backdrop-filter: blur(16px) saturate(130%);
}

.detail-page {
    display: grid;
    gap: 18px;
}

.detail-toolbar {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
    flex-wrap: wrap;
}

.detail-toolbar p {
    margin: 0;
    color: var(--muted);
}

.hero-card,
.identity-card,
.panel {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.04)),
        color-mix(in srgb, var(--card) 82%, transparent);
    border: 1px solid var(--line);
    border-radius: 22px;
    padding: 24px;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 12px 30px rgba(122, 72, 28, 0.08);
    backdrop-filter: blur(18px) saturate(140%);
}

:root[data-theme="dark"] .hero-card,
:root[data-theme="dark"] .identity-card,
:root[data-theme="dark"] .panel {
    box-shadow: 0 16px 38px rgba(0, 0, 0, 0.44);
}

.hero-card {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 28px;
    align-items: center;
    min-height: 360px;
}

.muted {
    color: var(--muted);
    margin: 8px 0 0;
}

.login-form,
.report-form {
    display: grid;
    gap: 14px;
}

.login-form input,
.report-form input,
.report-form select,
.report-form textarea {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 13px 14px;
    font-size: 15px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
        color-mix(in srgb, var(--card) 88%, transparent);
    color: var(--text);
}

.native-proxy {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    border: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    clip-path: inset(50%);
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
}

.bubble-control {
    position: relative;
    display: grid;
    gap: 10px;
}

.bubble-trigger {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 16px 18px;
    border-radius: 22px;
    border: 1px solid color-mix(in srgb, var(--primary) 18%, var(--line));
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03)),
        color-mix(in srgb, var(--card) 84%, transparent);
    color: var(--text);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 10px 28px rgba(0, 0, 0, 0.14);
    backdrop-filter: blur(18px) saturate(140%);
    transition:
        transform 0.15s ease,
        border-color 0.15s ease,
        background 0.15s ease,
        box-shadow 0.15s ease;
}

.bubble-trigger:hover,
.bubble-control.is-open .bubble-trigger {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--primary) 45%, var(--line));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.06),
        0 14px 32px rgba(0, 0, 0, 0.18);
}

.bubble-trigger__label {
    min-width: 0;
    text-align: left;
    font-weight: 800;
    font-size: 14px;
    line-height: 1.3;
}

.bubble-trigger__icon {
    flex: none;
    color: var(--primary);
    font-size: 18px;
    line-height: 1;
    transition: transform 0.15s ease;
}

.bubble-control.is-open .bubble-trigger__icon {
    transform: rotate(180deg);
}

.bubble-panel {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 10px);
    z-index: 20;
    border: 1px solid color-mix(in srgb, var(--primary) 20%, var(--line));
    border-radius: 24px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.04)),
        color-mix(in srgb, var(--card) 88%, transparent);
    box-shadow: 0 26px 60px rgba(0, 0, 0, 0.28);
    backdrop-filter: blur(22px) saturate(145%);
    padding: 14px;
}

.bubble-control.is-open .bubble-panel {
    animation: bubble-pop 0.14s ease-out;
}

.bubble-options {
    display: grid;
    gap: 8px;
    max-height: 320px;
    overflow: auto;
}

.bubble-option {
    width: 100%;
    border: 1px solid transparent;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.03);
    color: var(--text);
    padding: 12px 14px;
    text-align: left;
    font-weight: 700;
    line-height: 1.4;
}

.bubble-option:hover,
.bubble-option.is-active {
    border-color: color-mix(in srgb, var(--primary) 35%, var(--line));
    background: color-mix(in srgb, var(--primary) 14%, var(--card));
    color: var(--primary2);
}

.bubble-datepicker__panel {
    padding: 16px;
}

.datepicker-shell {
    display: grid;
    gap: 14px;
}

.datepicker-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.datepicker-head strong {
    font-size: 15px;
}

.datepicker-nav {
    display: flex;
    gap: 8px;
}

.datepicker-nav button {
    width: 38px;
    height: 38px;
    padding: 0;
    border-radius: 50%;
    background: color-mix(in srgb, var(--primary) 16%, var(--card));
    color: var(--primary2);
}

.datepicker-nav button:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.datepicker-weekdays,
.datepicker-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 8px;
}

.datepicker-weekdays span {
    text-align: center;
    font-size: 11px;
    font-weight: 800;
    color: var(--muted);
    letter-spacing: 0.03em;
}

.datepicker-day {
    min-height: 40px;
    padding: 0;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.03);
    color: var(--text);
    border: 1px solid transparent;
    font-weight: 800;
}

.datepicker-day--empty {
    background: transparent;
    border-color: transparent;
}

.datepicker-day:hover,
.datepicker-day.is-selected {
    background: color-mix(in srgb, var(--primary) 18%, var(--card));
    color: var(--primary2);
    border-color: color-mix(in srgb, var(--primary) 36%, var(--line));
}

.datepicker-day:disabled,
.bubble-option:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

@keyframes bubble-pop {
    from {
        opacity: 0;
        transform: translateY(-6px) scale(0.985);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

:root[data-theme="dark"] .bubble-trigger,
:root[data-theme="dark"] .bubble-panel {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
        rgba(17, 22, 32, 0.92);
    border-color: rgba(255, 255, 255, 0.1);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.03),
        0 16px 36px rgba(0, 0, 0, 0.35);
}

:root[data-theme="dark"] .bubble-option,
:root[data-theme="dark"] .datepicker-day {
    color: #f4f7fb;
}

:root[data-theme="dark"] .bubble-option:hover,
:root[data-theme="dark"] .bubble-option.is-active,
:root[data-theme="dark"] .datepicker-day:hover,
:root[data-theme="dark"] .datepicker-day.is-selected {
    background: rgba(249, 115, 22, 0.16);
    color: #fff7f0;
    border-color: rgba(249, 115, 22, 0.32);
}

:root[data-theme="dark"] .datepicker-weekdays span {
    color: #c7d2df;
}

.login-form label,
.report-form label {
    font-weight: 700;
    font-size: 13px;
}

button {
    border: 0;
    border-radius: 18px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.08)),
        var(--primary);
    color: white;
    padding: 13px 16px;
    font-weight: 800;
    cursor: pointer;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.2),
        0 10px 24px rgba(249, 115, 22, 0.28);
}

button:hover {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.1)),
        var(--primary2);
}

.button-secondary {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.06)),
        color-mix(in srgb, var(--primary) 18%, var(--card));
    color: var(--primary2);
}

.button-secondary:hover {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.06)),
        color-mix(in srgb, var(--primary) 28%, var(--card));
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 12px;
    margin: 18px 0;
}

.stat {
    background: linear-gradient(
        180deg,
        color-mix(in srgb, var(--card) 88%, transparent),
        color-mix(in srgb, var(--soft) 58%, var(--card))
    );
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 16px;
    backdrop-filter: blur(16px) saturate(130%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

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

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

.panel {
    margin-top: 18px;
}

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

.panel-head p {
    margin: 0;
    color: var(--muted);
}

.table-wrap {
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 18px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
        color-mix(in srgb, var(--card) 84%, transparent);
    backdrop-filter: blur(18px) saturate(140%);
    padding: 10px;
}

.panel table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 10px;
}

:root[data-theme="dark"] .table-wrap,
:root[data-theme="dark"] .panel table {
    background: #111620;
}

.panel th,
.panel td {
    padding: 10px 12px;
    text-align: left;
}

.panel tbody tr td {
    background: color-mix(in srgb, var(--card) 84%, transparent);
}

.panel tbody tr td:first-child {
    border-radius: 14px 0 0 14px;
}

.panel tbody tr td:last-child {
    border-radius: 0 14px 14px 0;
}

.panel tfoot tr td {
    background: color-mix(in srgb, var(--primary) 12%, var(--card));
    font-weight: 600;
    border-top: 2px solid var(--primary);
}

.panel tfoot tr td:first-child {
    border-radius: 14px 0 0 14px;
}

.panel tfoot tr td:last-child {
    border-radius: 0 14px 14px 0;
}

:root[data-theme="dark"] .panel tfoot tr td {
    background: color-mix(in srgb, var(--primary) 18%, #131923);
    color: #f4f7fb;
}

:root[data-theme="dark"] .panel th,
:root[data-theme="dark"] .panel td {
    border-bottom-color: #2a3442;
    color: #f4f7fb;
}

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

:root[data-theme="dark"] .panel th {
    background: rgba(22, 28, 38, 0.96);
    color: #ffd9bf;
}

:root[data-theme="dark"] .panel tr:nth-child(even) td {
    background: #131923;
}

:root[data-theme="dark"] .panel tr:hover td {
    background: #1a2230;
}

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

:root[data-theme="dark"] .empty,
:root[data-theme="dark"] .table-empty {
    color: #c3cfdd;
}

.clickable {
    cursor: pointer;
}

.accordion {
    margin-top: 10px;
    border: 1px solid var(--line);
    border-radius: 14px;
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.05)),
        color-mix(in srgb, var(--card) 84%, transparent);
    backdrop-filter: blur(16px) saturate(130%);
}

.accordion-head {
    display: flex;
    justify-content: space-between;
    padding: 12px 14px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.03)),
        color-mix(in srgb, var(--soft) 68%, var(--card));
    cursor: pointer;
    font-weight: 700;
}

.accordion-body {
    display: none;
    padding: 0 14px 14px;
}

.accordion.open .accordion-body {
    display: block;
}

.alert {
    padding: 14px 16px;
    border-radius: 14px;
    margin-bottom: 14px;
    backdrop-filter: blur(14px) saturate(130%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.alert.success {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
        color-mix(in srgb, #22c55e 12%, var(--card));
    color: var(--success);
}

.alert.danger {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
        color-mix(in srgb, #ef4444 12%, var(--card));
    color: var(--danger);
}

.report-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    align-items: start;
}

.field {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.field--full,
.repair-panel,
.form-actions {
    grid-column: 1 / -1;
}

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

:root[data-theme="dark"] .muted,
:root[data-theme="dark"] .field-help,
:root[data-theme="dark"] .panel-head p,
:root[data-theme="dark"] .detail-toolbar p,
:root[data-theme="dark"] .brand-copy small,
:root[data-theme="dark"] .repair-panel__header p,
:root[data-theme="dark"] .modal-card__body p {
    color: #c7d2df;
}

:root[data-theme="dark"] .panel th,
:root[data-theme="dark"] .stat span {
    color: #ffd9bf;
}

.report-form input[type="date"],
.report-form select,
.report-form input[type="number"],
.report-form textarea {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 13px 14px;
    font-size: 15px;
    transition:
        border-color 0.15s ease,
        box-shadow 0.15s ease;
}

.report-form input:focus,
.report-form select:focus,
.report-form textarea:focus {
    outline: none;
    border-color: color-mix(in srgb, var(--primary) 55%, var(--line));
    box-shadow: 0 0 0 4px rgba(249, 115, 22, 0.1);
}

.report-form textarea {
    min-height: 108px;
    resize: vertical;
}

.repair-panel {
    background: linear-gradient(
        180deg,
        color-mix(in srgb, var(--soft) 55%, var(--card)),
        var(--card)
    );
    border: 1px solid color-mix(in srgb, var(--primary) 30%, var(--line));
    border-radius: 18px;
    padding: 18px;
    display: grid;
    gap: 14px;
    backdrop-filter: blur(18px) saturate(140%);
}

.repair-panel__header p {
    margin: 6px 0 0;
    color: var(--muted);
}

.form-actions {
    display: flex;
    justify-content: flex-start;
    padding-top: 6px;
}

.modal-backdrop {
    position: fixed;
    inset: 0;
    display: grid;
    place-items: center;
    background: var(--overlay);
    padding: 18px;
    z-index: 50;
}

.modal-card {
    width: min(560px, 100%);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.04)),
        color-mix(in srgb, var(--card) 86%, transparent);
    border-radius: 22px;
    padding: 22px;
    border: 1px solid var(--line);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 26px 80px rgba(90, 38, 10, 0.18);
    backdrop-filter: blur(20px) saturate(140%);
}

.portal-note {
    margin-top: 14px;
    padding: 12px 16px;
    border: 1px dashed color-mix(in srgb, var(--primary) 50%, var(--line));
    border-radius: 16px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
        color-mix(in srgb, var(--soft) 66%, var(--card));
    color: color-mix(in srgb, var(--primary2) 75%, var(--text));
    font-size: 13px;
    font-weight: 600;
    backdrop-filter: blur(16px) saturate(130%);
}

:root[data-theme="dark"] .portal-note {
    background: color-mix(in srgb, var(--soft) 76%, var(--card));
    color: #ffd7bf;
    border-color: color-mix(in srgb, var(--primary) 45%, var(--line));
}

:root[data-theme="dark"] .alert.success {
    background: rgba(34, 197, 94, 0.12);
}

:root[data-theme="dark"] .alert.danger {
    background: rgba(239, 68, 68, 0.12);
}

:root[data-theme="dark"] .back-link,
:root[data-theme="dark"] .logout,
:root[data-theme="dark"] .theme-toggle,
:root[data-theme="dark"] .panel th,
:root[data-theme="dark"] .panel-head p,
:root[data-theme="dark"] .detail-toolbar p,
:root[data-theme="dark"] .field-help,
:root[data-theme="dark"] .muted,
:root[data-theme="dark"] .brand-copy small {
    color: #c7d2df;
}

:root[data-theme="dark"] .panel th,
:root[data-theme="dark"] .stat span,
:root[data-theme="dark"] .brand-copy small,
:root[data-theme="dark"] .field-help {
    opacity: 1;
}

:root[data-theme="dark"] .theme-toggle,
:root[data-theme="dark"] .logout {
    background: #1d2430;
    border-color: var(--line);
    color: #f8fbff;
}

:root[data-theme="dark"] .theme-toggle:hover,
:root[data-theme="dark"] .logout:hover {
    background: #273142;
    color: #ffffff;
}

:root[data-theme="dark"] .report-form input,
:root[data-theme="dark"] .report-form select,
:root[data-theme="dark"] .report-form textarea,
:root[data-theme="dark"] .login-form input {
    background: #111620;
    color: #f4f7fb;
}

:root[data-theme="dark"] .report-form input::placeholder,
:root[data-theme="dark"] .login-form input::placeholder {
    color: #9ca8b8;
}

:root[data-theme="dark"] .repair-panel {
    background: linear-gradient(180deg, #1a202a, #171c24);
    border-color: var(--line);
}

:root[data-theme="dark"] .portal-note {
    background: #171c24;
    color: #ffd7bf;
    border-color: #3a4656;
}

:root[data-theme="dark"] .accordion-head,
:root[data-theme="dark"] .stat {
    background: #1a202a;
}

:root[data-theme="dark"] .alert {
    background: #171c24;
}

:root[data-theme="dark"] .identity-card h2,
:root[data-theme="dark"] .identity-card .muted,
:root[data-theme="dark"] .identity-card .eyebrow {
    color: #f4f7fb;
}

.identity-card h2 {
    text-transform: uppercase;
}

.panel tbody td strong {
    text-transform: uppercase;
}

:root[data-theme="dark"] .identity-card .muted {
    color: #c7d2df;
}

:root[data-theme="dark"] .panel-head h3,
:root[data-theme="dark"] .hero-card h2,
:root[data-theme="dark"] .panel h3 {
    color: #f8fbff;
}

:root[data-theme="dark"] .report-form label,
:root[data-theme="dark"] .field label,
:root[data-theme="dark"] .panel td,
:root[data-theme="dark"] .panel th,
:root[data-theme="dark"] .stat strong {
    color: #f4f7fb;
}

.modal-card__body p {
    color: var(--muted);
}

.modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    margin-top: 20px;
}

@media (max-width: 1100px) {
    .stats-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 840px) {
    .hero-card {
        grid-template-columns: 1fr;
    }

    .panel-head,
    .topbar {
        flex-direction: column;
        align-items: flex-start;
    }

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

    .report-form {
        grid-template-columns: 1fr;
    }

    .field--full,
    .repair-panel,
    .form-actions {
        grid-column: auto;
    }

    .modal-card {
        padding: 18px;
    }
}

@media (max-width: 640px), (orientation: portrait) and (max-width: 820px) {
    html,
    body {
        width: 100%;
        overflow-x: hidden;
    }

    .topbar {
        position: static;
        padding: 14px 16px;
        gap: 12px;
    }

    .brand-wrap {
        width: 100%;
        align-items: flex-start;
        gap: 10px;
    }

    .brand-logos {
        gap: 8px;
    }

    .brand-logo {
        width: 38px;
        height: 38px;
    }

    .brand-copy h1 {
        font-size: 19px;
        line-height: 1.2;
    }

    .brand-copy small,
    .eyebrow {
        font-size: 11px;
    }

    .header-actions {
        width: 100%;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
        align-items: stretch;
    }

    .theme-toggle,
    .logout,
    .back-link,
    button {
        width: 100%;
        justify-content: center;
        text-align: center;
    }

    .container {
        padding: 12px;
    }

    .detail-page,
    .panel,
    .hero-card,
    .identity-card,
    .repair-panel,
    .modal-card {
        border-radius: 18px;
        max-width: 100%;
        box-sizing: border-box;
        overflow: hidden;
    }

    .detail-page {
        overflow: visible;
    }

    .hero-card,
    .identity-card,
    .panel {
        padding: 18px;
    }

    .detail-toolbar {
        align-items: flex-start;
    }

    .detail-toolbar > div {
        width: 100%;
    }

    .stats-grid {
        grid-template-columns: 1fr;
        gap: 10px;
        margin: 14px 0;
    }

    .stat {
        padding: 14px;
    }

    .report-form {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .field--full,
    .repair-panel,
    .form-actions {
        grid-column: auto;
    }

    .bubble-control,
    .bubble-trigger,
    .bubble-panel,
    .report-form input,
    .report-form select,
    .report-form textarea {
        width: 100%;
    }

    .bubble-control {
        position: relative;
    }

    .bubble-panel {
        position: absolute;
        left: 0;
        right: 0;
        top: calc(100% + 8px);
        bottom: auto;
        max-height: 58vh;
        overflow: auto;
        z-index: 30;
    }

    .bubble-options {
        max-height: 42vh;
    }

    .datepicker-shell {
        gap: 12px;
    }

    .datepicker-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .datepicker-nav {
        width: 100%;
        justify-content: space-between;
    }

    .datepicker-grid,
    .datepicker-weekdays {
        gap: 6px;
    }

    .datepicker-day {
        min-height: 36px;
        font-size: 13px;
    }

    .panel-head {
        gap: 8px;
        margin-bottom: 12px;
    }

    .panel-head h3 {
        font-size: 17px;
    }

    .panel-head p,
    .detail-toolbar p,
    .field-help,
    .portal-note {
        font-size: 12px;
    }

    .modal-backdrop {
        padding: 12px;
    }

    .modal-card {
        width: 100%;
        padding: 16px;
    }

    .modal-actions {
        flex-direction: column;
    }

    .modal-actions button {
        width: 100%;
    }

    .table-wrap {
        width: 100%;
        max-width: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior-x: contain;
        touch-action: pan-x;
        padding: 6px;
        border-radius: 18px;
        border: 1px solid var(--line);
        background:
            linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
            color-mix(in srgb, var(--card) 84%, transparent);
    }

    .panel table {
        width: max-content;
        min-width: 760px;
        table-layout: auto;
        border-collapse: separate;
        border-spacing: 0 8px;
    }

    .stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
        margin: 12px 0;
    }

    .stats-grid .stat:first-child {
        grid-column: 1 / -1;
    }

    .stats-grid .stat:first-child strong {
        font-size: 22px;
    }

    .panel th,
    .panel td {
        white-space: nowrap;
        overflow-wrap: normal;
        word-break: normal;
    }

    .panel th {
        font-size: 11px;
        line-height: 1.25;
    }

    .panel td {
        font-size: 11px;
        line-height: 1.35;
    }
}
