.maintenance-shell {
    max-width: 1380px;
    margin: 0 auto;
}

.maintenance-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 0 0 18px;
}

.maintenance-nav a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px;
    border-radius: 999px;
    background: rgba(24, 33, 43, 0.06);
    color: #18212b;
    font-size: 13px;
    font-weight: 800;
}

.maintenance-nav a.active,
.maintenance-nav a:hover,
.maintenance-nav a:focus {
    background: linear-gradient(135deg, #0f7a36, #0a5927);
    color: #fff;
}

.maintenance-card,
.maintenance-hero,
.maintenance-empty,
.maintenance-job-card {
    border: 1px solid rgba(24, 33, 43, 0.08);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.08);
}

.maintenance-hero,
.maintenance-card,
.maintenance-job-card {
    padding: 20px 22px;
}

.maintenance-kicker {
    display: inline-flex;
    align-items: center;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(15, 122, 54, 0.08);
    color: #0a5927;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.maintenance-hero h2,
.maintenance-card h2,
.maintenance-card h3,
.maintenance-job-card h3 {
    margin: 12px 0 8px;
    color: #102a43;
    font-weight: 800;
}

.maintenance-hero p,
.maintenance-card p,
.maintenance-muted {
    color: #5f6b76;
}

.maintenance-metrics {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
    margin: 18px 0;
}

.maintenance-metric {
    padding: 16px 18px;
    border: 1px solid rgba(24, 33, 43, 0.08);
    border-radius: 18px;
    background: #f8fbfd;
}

.maintenance-metric strong {
    display: block;
    color: #102a43;
    font-size: 28px;
    line-height: 1;
}

.maintenance-metric span {
    display: block;
    margin-top: 8px;
    color: #6b7c93;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.maintenance-grid {
    display: grid;
    grid-template-columns: 1.35fr 0.95fr;
    gap: 18px;
}

.maintenance-list {
    display: grid;
    gap: 14px;
}

.maintenance-job-card .job-meta,
.maintenance-detail-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 10px;
}

.maintenance-chip {
    display: inline-flex;
    align-items: center;
    padding: 7px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
}

.maintenance-chip.status-new,
.maintenance-chip.status-triage,
.maintenance-chip.status-more_info_requested,
.maintenance-chip.status-quote_requested,
.maintenance-chip.status-in_progress {
    background: #fff7ed;
    color: #9a3412;
}

.maintenance-chip.status-owner_approval_required {
    background: #eef2ff;
    color: #1d4ed8;
}

.maintenance-chip.status-closed,
.maintenance-chip.status-paid {
    background: #ecfdf3;
    color: #166534;
}

.maintenance-chip.urgency-emergency,
.maintenance-chip.urgency-urgent {
    background: #fef2f2;
    color: #991b1b;
}

.maintenance-chip.urgency-routine,
.maintenance-chip.urgency-preventative {
    background: #eff6ff;
    color: #1d4ed8;
}

.maintenance-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 16px;
}

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

.maintenance-form-grid .full {
    grid-column: 1 / -1;
}

.maintenance-empty {
    padding: 22px;
    text-align: center;
    color: #6b7c93;
}

.maintenance-timeline {
    display: grid;
    gap: 12px;
}

.maintenance-timeline-item {
    padding: 12px 14px;
    border: 1px solid rgba(24, 33, 43, 0.08);
    border-radius: 16px;
    background: #fbfdff;
}

.maintenance-file-list,
.maintenance-vendor-list {
    display: grid;
    gap: 12px;
}

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

.maintenance-table {
    width: 100%;
}

.maintenance-table th,
.maintenance-table td {
    padding: 12px 10px;
    border-bottom: 1px solid rgba(24, 33, 43, 0.08);
    vertical-align: middle;
}

.maintenance-table th {
    color: #6b7c93;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

@media (max-width: 991px) {
    .maintenance-metrics,
    .maintenance-grid,
    .maintenance-form-grid,
    .maintenance-split {
        grid-template-columns: 1fr;
    }

    .maintenance-shell {
        max-width: 100%;
    }
}
