/* VehKeep Auto Journal Premium redesign */
:root {
    --journal-bg: #f4f6f4;
    --journal-paper: #ffffff;
    --journal-paper-2: #f8faf8;
    --journal-ink: #171b18;
    --journal-muted: #66706a;
    --journal-soft: #e3e8e4;
    --journal-line: rgba(37, 43, 38, .12);
    --journal-accent: var(--mud-palette-primary);
    --journal-accent-soft: color-mix(in srgb, var(--journal-accent) 12%, transparent);
    --journal-shadow: 0 12px 34px rgba(27, 30, 25, .07);
    --journal-shadow-soft: 0 1px 0 rgba(27, 30, 25, .04), 0 10px 28px rgba(27, 30, 25, .05);
    --journal-radius-lg: 20px;
    --journal-radius-md: 14px;
    --journal-radius-sm: 10px;
    --journal-gutter: clamp(1rem, 1.8vw, 1.65rem);
    --journal-content: 1180px;
}

html, body {
    background: var(--journal-bg);
}

.page {
    min-height: 100vh;
    background: var(--journal-bg);
    color: var(--mud-palette-text-primary);
    font-family: Inter, "SF Pro Text", "Segoe UI", system-ui, sans-serif;
}

.page.public-workspace {
    background: #ffffff;
    color: #171b18;
}

.page.auth-workspace.sidebar-dark, .page.auth-workspace.sidebar-night {
    --journal-bg: color-mix(in srgb, var(--mud-palette-background) 94%, var(--mud-palette-primary) 6%);
    --journal-paper: color-mix(in srgb, var(--mud-palette-surface) 94%, white 6%);
    --journal-paper-2: color-mix(in srgb, var(--mud-palette-surface) 88%, var(--mud-palette-primary) 12%);
    --journal-ink: var(--mud-palette-text-primary);
    --journal-muted: var(--mud-palette-text-secondary);
    --journal-soft: color-mix(in srgb, var(--mud-palette-lines-default) 72%, transparent);
    --journal-line: color-mix(in srgb, var(--mud-palette-lines-default) 82%, transparent);
    --journal-shadow: 0 14px 38px rgba(0, 0, 0, .22);
    --journal-shadow-soft: 0 1px 0 rgba(255, 255, 255, .03), 0 10px 28px rgba(0, 0, 0, .18);
}

.page main {
    min-height: 100vh;
}

.page.auth-workspace main {
    padding-left: 0 !important;
}

.content {
    width: min(100%, calc(var(--journal-content) + (var(--journal-gutter) * 2)));
    margin: 0 auto;
    padding: 1.35rem var(--journal-gutter) 3.5rem;
}

.page.auth-workspace .content {
    width: 100%;
    max-width: none;
    margin: 0;
    box-sizing: border-box;
}

.page.auth-workspace article.content {
    padding: 1.25rem var(--journal-gutter) 3rem !important;
    width: 100% !important;
    margin: 0 !important;
    box-sizing: border-box;
}

.journal-topbar {
    min-height: 64px;
    position: sticky;
    top: 0;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid var(--journal-line);
    background: color-mix(in srgb, var(--journal-bg) 86%, transparent);
    backdrop-filter: blur(18px);
}

.page.auth-workspace .journal-topbar {
    padding-left: var(--journal-gutter) !important;
    padding-right: var(--journal-gutter) !important;
}

.top-row-context {
    display: flex;
    flex-direction: column;
    line-height: 1.15;
}

.top-row-title {
    font-size: .95rem;
    font-weight: 700;
    color: var(--mud-palette-text-primary);
}

.top-row-subtitle {
    margin-top: .18rem;
    font-size: .76rem;
    color: var(--journal-muted);
}

.top-row-actions {
    display: flex;
    align-items: center;
    gap: .45rem;
}

.public-top-links a.public-top-login {
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 .95rem;
    border: 1px solid rgba(37, 43, 38, .16);
    border-radius: 999px;
    background: rgba(255, 255, 255, .74);
    color: #253027;
    box-shadow: 0 1px 0 rgba(27, 30, 25, .04);
}

.public-top-links a.public-top-login:hover, .public-top-links a.public-top-login:focus-visible {
    border-color: color-mix(in srgb, var(--mud-palette-primary) 34%, rgba(37, 43, 38, .16));
    background: color-mix(in srgb, var(--mud-palette-primary) 8%, white);
    color: var(--mud-palette-primary);
}

.page.auth-workspace .journal-rail.sidebar {
    width: 88px !important;
    min-width: 88px !important;
    flex: 0 0 88px !important;
    border-right: 1px solid var(--journal-line);
    background: color-mix(in srgb, var(--journal-paper) 84%, var(--journal-bg));
    box-shadow: 1px 0 0 rgba(255, 255, 255, .35) inset;
}

.journal-rail-brand {
    min-height: 64px;
    display: grid;
    place-items: center;
    border-bottom: 1px solid var(--journal-line);
}

.journal-rail-brand .navbar-brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .36rem;
    color: var(--mud-palette-text-primary);
    text-decoration: none;
    font-weight: 800;
    font-size: .72rem;
    letter-spacing: 0;
}

.journal-brand-mark, .public-brand-mark {
    width: 42px;
    height: 42px;
    display: inline-grid;
    place-items: center;
    border-radius: 16px;
    background: color-mix(in srgb, var(--mud-palette-primary) 14%, var(--journal-paper));
    color: var(--mud-palette-primary);
    border: 1px solid color-mix(in srgb, var(--mud-palette-primary) 24%, transparent);
}

.journal-rail-section {
    margin: 1rem .7rem .45rem;
    color: var(--journal-muted);
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: 0;
    text-align: center;
}

.journal-rail .nav-scrollable {
    height: calc(100vh - 64px);
    overflow-y: auto;
    padding: .4rem 0 1rem;
}

.journal-rail .nav {
    gap: .18rem;
}

.journal-rail .nav-item {
    padding: 0 .55rem !important;
}

.journal-rail .nav-link, .journal-rail button.nav-link {
    min-height: 50px;
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: .26rem;
    border: 0;
    border-radius: 14px;
    background: transparent;
    color: var(--journal-muted);
    text-align: center;
    font-size: .68rem;
    font-weight: 700;
    line-height: 1.1;
    text-decoration: none;
}

.journal-rail .nav-link.active, .journal-rail .nav-link:hover, .journal-rail .nav-link:focus-visible {
    background: color-mix(in srgb, var(--mud-palette-primary) 12%, transparent);
    color: var(--mud-palette-primary);
    outline: none;
}

.journal-rail .nav-link-icon {
    margin: 0 !important;
}

.journal-rail .nav-link-text {
    max-width: 70px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.page.auth-workspace .mud-button-root {
    border-radius: 999px;
    text-transform: none;
    font-weight: 700;
    letter-spacing: 0;
}

.page.auth-workspace .global-add-event-button, .page.auth-workspace .mud-button-root.mud-button-filled-primary {
    box-shadow: 0 8px 20px color-mix(in srgb, var(--mud-palette-primary) 18%, transparent);
}

.journal-dashboard {
    display: grid;
    gap: 1rem;
}

.journal-dashboard-hero, .vehicle-collection-header, .vehicle-profile-hero {
    position: relative;
    display: grid;
    gap: 1rem;
    border-radius: var(--journal-radius-lg);
    padding: clamp(1rem, 1.6vw, 1.25rem);
    background: var(--journal-paper);
    border: 1px solid var(--journal-line);
    box-shadow: var(--journal-shadow-soft);
    overflow: hidden;
}

.journal-dashboard-copy, .vehicle-profile-main, .vehicle-profile-actions, .journal-hero-actions, .journal-dashboard-stats {
    position: relative;
    z-index: 1;
}

.journal-dashboard-hero {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
}

.journal-dashboard-copy h1, .vehicle-collection-header h1, .vehicle-profile-main h1 {
    max-width: 760px;
    font-size: clamp(2rem, 2.6vw, 2.35rem) !important;
    line-height: 1.08 !important;
    letter-spacing: 0 !important;
    font-weight: 800 !important;
}

.journal-lead, .vmt-page-header-subtitle {
    color: var(--journal-muted) !important;
    max-width: 680px;
    font-size: 1rem !important;
    line-height: 1.55 !important;
}

.journal-hero-actions, .vehicle-profile-actions {
    display: flex;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: .55rem;
}

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

.journal-dashboard-stats > div, .vehicle-profile-metrics > div, .vehicle-card-status, .dashboard-vehicle-cost, .journal-panel, .vehicle-journal-card, .vmt-section-panel, .vmt-form-section {
    border: 1px solid var(--journal-line);
    background: color-mix(in srgb, var(--journal-paper) 92%, transparent);
    border-radius: var(--journal-radius-md);
    box-shadow: none;
}

.journal-dashboard-stats > div, .vehicle-profile-metrics > div {
    padding: .85rem;
    display: grid;
    gap: .2rem;
}

.journal-dashboard-stats span, .vehicle-profile-metrics span, .vehicle-card-data span, .details-list span {
    color: var(--journal-muted);
    font-size: .75rem;
    font-weight: 700;
}

.journal-dashboard-stats strong, .vehicle-profile-metrics strong {
    font-size: 1.45rem;
    line-height: 1.18;
}

.journal-today-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: .85rem;
    padding: 1rem;
    border-radius: var(--journal-radius-lg);
    border: 1px solid color-mix(in srgb, var(--mud-palette-primary) 20%, var(--journal-line));
    background: color-mix(in srgb, var(--mud-palette-primary) 9%, var(--journal-paper));
}

.dashboard-next-step-icon, .dashboard-priority-icon, .vehicle-profile-icon {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    border-radius: 17px;
    color: var(--mud-palette-primary);
    background: color-mix(in srgb, var(--mud-palette-primary) 13%, transparent);
}

.journal-dashboard-layout {
    display: grid;
    grid-template-columns: minmax(260px, .4fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

.journal-dashboard-main, .journal-dashboard-sidebar {
    display: grid;
    gap: 1rem;
}

.journal-panel {
    padding: clamp(1rem, 1.6vw, 1.25rem);
}

.journal-panel-heading, .vmt-section-panel-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.journal-panel h2, .vmt-section-panel h2, .vmt-form-section h2, .vehicle-card h2 {
    font-size: 1.35rem !important;
    line-height: 1.08 !important;
    letter-spacing: 0 !important;
    font-weight: 800 !important;
}

.dashboard-priority-list, .vmt-mini-timeline, .reminder-list, .maintenance-list, .expense-list {
    display: grid;
    gap: .75rem;
}

.dashboard-priority-item, .timeline-item, .maintenance-record-card, .reminder-card, .expense-card {
    border-radius: var(--journal-radius-md) !important;
    border: 1px solid var(--journal-line) !important;
    background: color-mix(in srgb, var(--journal-paper) 88%, transparent) !important;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.dashboard-priority-item:hover, .timeline-item:hover, .vehicle-journal-card:hover, .dashboard-vehicle-cost:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--mud-palette-primary) 34%, var(--journal-line)) !important;
    box-shadow: var(--journal-shadow-soft);
}

.dashboard-priority-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: .8rem;
    padding: .9rem;
    text-decoration: none;
    color: inherit;
}

.status-chip {
    border-radius: 999px;
    padding: .3rem .6rem;
    font-size: .72rem;
    font-weight: 700;
}

.is-overdue .status-chip, .status-chip.is-overdue {
    color: #a93232;
    background: rgba(184, 74, 74, .13);
}

.status-chip.is-soon, .is-soon .status-chip {
    color: #9a680e;
    background: rgba(197, 139, 42, .16);
}

.status-chip.is-ok, .status-chip.is-mileage, .status-chip.is-completed {
    color: var(--mud-palette-primary);
    background: color-mix(in srgb, var(--mud-palette-primary) 14%, transparent);
}

.dashboard-cost-grid, .vehicle-collection-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

.vehicle-collection-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 360px), 520px));
    align-items: stretch;
}

.dashboard-vehicle-cost {
    padding: 1rem;
    display: grid;
    gap: .8rem;
    text-decoration: none;
    color: inherit;
}

.dashboard-cost-header, .vehicle-card-main, .expense-main, .reminder-main, .maintenance-record-main {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
}

.dashboard-cost-header small, .dashboard-priority-copy small, .vehicle-card-subtitle, .muted-text {
    color: var(--journal-muted) !important;
}

.dashboard-cost-amount {
    font-size: 1.35rem;
    font-weight: 800;
}

.dashboard-cost-bar, .expense-category-bar {
    height: .42rem;
    border-radius: 999px;
    overflow: hidden;
    background: color-mix(in srgb, var(--journal-muted) 13%, transparent);
}

.dashboard-cost-bar span, .expense-category-bar span {
    display: block;
    width: var(--bar-width, 0%);
    height: 100%;
    border-radius: inherit;
    background: var(--mud-palette-primary);
}

.vehicle-collection-header {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    margin-bottom: 1rem;
}

.vehicle-journal-card {
    position: relative;
    padding: 1rem;
    display: grid;
    gap: .75rem;
    box-shadow: none;
}

/* Cała karta pojazdu jest klikalna (stretched link); akcje leżą nad nakładką. */
.vehicle-card-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    border-radius: inherit;
}

.vehicle-card-overlay:focus-visible {
    outline: 2px solid var(--mud-palette-primary);
    outline-offset: 2px;
}

.vehicle-journal-card .vehicle-card-actions {
    position: relative;
    z-index: 2;
}

.vehicle-card-status {
    display: grid;
    gap: .2rem;
    padding: .65rem .75rem;
    background: color-mix(in srgb, var(--mud-palette-primary) 8%, var(--journal-paper));
}

.vehicle-card-status.is-empty {
    background: color-mix(in srgb, var(--journal-muted) 8%, var(--journal-paper));
}

.vehicle-card-status strong {
    font-size: 1rem;
}

.vehicle-card-data, .details-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .6rem;
}

.vehicle-card-data > div, .details-list > div {
    display: grid;
    gap: .2rem;
}

.page.auth-workspace:not(.route-pl):not(.route-en) .vehicle-card-data > div, .page.auth-workspace:not(.route-pl):not(.route-en) .details-list > div, .page.auth-workspace:not(.route-pl):not(.route-en) .vehicle-profile-metrics > div {
    background: color-mix(in srgb, var(--journal-paper) 88%, transparent) !important;
    border: 1px solid var(--journal-line);
    border-radius: var(--journal-radius-sm);
    padding: .65rem;
}

.vehicle-card-actions, .maintenance-record-actions, .expense-actions, .reminder-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: .35rem;
    flex-wrap: wrap;
}

.vehicle-profile-hero {
    grid-template-columns: minmax(0, 1fr) auto;
}

.page.auth-workspace:not(.route-pl):not(.route-en) .vehicle-profile-hero {
    grid-template-columns: minmax(0, 1fr) auto !important;
    padding: clamp(1rem, 1.6vw, 1.25rem) !important;
}

.vehicle-profile-main {
    display: flex;
    align-items: center;
    gap: .9rem;
}

.vehicle-profile-icon {
    width: 56px;
    height: 56px;
    border-radius: 16px;
}

.vehicle-profile-metrics {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .65rem;
}

.vehicle-profile-tags {
    grid-column: 1 / -1;
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.vehicle-profile-tags span {
    border-radius: 999px;
    padding: .36rem .65rem;
    background: color-mix(in srgb, var(--journal-muted) 10%, transparent);
    color: var(--journal-muted);
    font-weight: 700;
    font-size: .82rem;
}

.vehicle-primary-actions {
    display: flex;
    gap: .5rem;
    margin: .85rem 0 1rem;
}

.vehicle-workspace-grid {
    display: grid;
    gap: .75rem;
}

.vehicle-workspace-card {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .85rem;
    border-radius: var(--journal-radius-md);
    border: 1px solid var(--journal-line);
    color: inherit;
    text-decoration: none;
    background: color-mix(in srgb, var(--journal-paper) 86%, transparent);
}

.maintenance-timeline {
    position: relative;
}

.maintenance-timeline::before {
    content: "";
    position: absolute;
    left: 23px;
    top: .5rem;
    bottom: .5rem;
    width: 2px;
    background: var(--journal-line);
}

.maintenance-timeline-card {
    position: relative;
    margin-left: 2.7rem;
    padding: .9rem;
}

.maintenance-timeline-marker {
    position: absolute;
    left: -3.1rem;
    top: 1rem;
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    background: var(--journal-paper);
    border: 1px solid var(--journal-line);
    color: var(--mud-palette-primary);
}

.vmt-form-shell {
    max-width: 960px;
    margin: 0 auto;
}

.vmt-form-section {
    padding: clamp(1rem, 1.6vw, 1.2rem);
    box-shadow: none;
}

.vmt-form-section-heading {
    margin-bottom: 1rem;
}

.upload-panel {
    border-radius: 20px;
    border: 1px dashed color-mix(in srgb, var(--mud-palette-primary) 34%, var(--journal-line));
    padding: 1rem;
    background: color-mix(in srgb, var(--mud-palette-primary) 6%, transparent);
}

.vmt-sticky-form-footer {
    position: sticky;
    bottom: 1rem;
    z-index: 20;
    justify-content: flex-end;
    gap: .6rem;
    padding: .85rem;
    border-radius: 999px;
    border: 1px solid var(--journal-line);
    background: color-mix(in srgb, var(--journal-paper) 88%, transparent);
    backdrop-filter: blur(16px);
    box-shadow: var(--journal-shadow-soft);
}

/* Shared product surfaces */
.vmt-page-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    gap: 1rem;
    margin-bottom: 1rem;
    padding: clamp(1rem, 1.6vw, 1.25rem);
    border-radius: var(--journal-radius-lg);
    border: 1px solid var(--journal-line);
    background: var(--journal-paper);
    box-shadow: var(--journal-shadow-soft);
}

.vmt-page-header h1 {
    max-width: 760px;
    font-size: clamp(2rem, 2.6vw, 2.35rem) !important;
    line-height: 1.08 !important;
    letter-spacing: 0 !important;
    font-weight: 800 !important;
}

.vmt-page-header-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .55rem;
}

.vmt-empty-state {
    display: grid;
    justify-items: center;
    gap: .7rem;
    padding: clamp(1.5rem, 3vw, 2rem) !important;
    border-radius: var(--journal-radius-lg) !important;
    border: 1px dashed color-mix(in srgb, var(--mud-palette-primary) 28%, var(--journal-line)) !important;
    background: color-mix(in srgb, var(--journal-paper) 92%, var(--mud-palette-primary) 8%) !important;
    text-align: center;
}

.vmt-empty-state .mud-icon-root {
    width: 48px;
    height: 48px;
    padding: .65rem;
    border-radius: 15px;
    background: color-mix(in srgb, var(--mud-palette-primary) 12%, transparent);
}

.vmt-empty-state h2 {
    font-size: 1.3rem !important;
    line-height: 1.1 !important;
    letter-spacing: 0 !important;
    font-weight: 800 !important;
}

.vmt-empty-state-message {
    max-width: 38rem;
    color: var(--journal-muted) !important;
}

.vehicle-event-choice-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .9rem;
}

.vmt-event-card {
    min-height: 150px;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: start;
    gap: .9rem;
    padding: .95rem;
    border-radius: var(--journal-radius-md);
    border: 1px solid var(--journal-line);
    background: var(--journal-paper);
    color: var(--mud-palette-text-primary);
    text-decoration: none;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.vmt-event-card:hover, .vmt-event-card:focus-visible {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--mud-palette-primary) 34%, var(--journal-line));
    box-shadow: var(--journal-shadow-soft);
    outline: none;
}

.vmt-event-card-icon {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    border-radius: 17px;
    background: color-mix(in srgb, var(--mud-palette-primary) 12%, transparent);
    color: var(--mud-palette-primary);
}

.vmt-event-card-copy {
    display: grid;
    gap: .36rem;
}

.vmt-event-card-copy strong {
    font-size: 1rem;
    font-weight: 800;
}

.vmt-event-card-copy small, .vmt-event-card-copy em {
    color: var(--journal-muted);
    font-size: .84rem;
    line-height: 1.45;
    font-style: normal;
}

.vehicle-event-guidance {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: .9rem;
    padding: 1rem;
    border-radius: var(--journal-radius-md);
    border: 1px solid var(--journal-line);
    background: color-mix(in srgb, var(--journal-paper) 90%, var(--mud-palette-info) 10%);
}

.vehicle-event-guidance > .mud-icon-root {
    color: var(--mud-palette-info);
}

.vmt-timeline-item {
    min-height: 78px;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: .9rem;
    padding: .85rem 1rem;
    border-radius: var(--journal-radius-md);
    border: 1px solid var(--journal-line);
    background: var(--journal-paper);
    color: var(--mud-palette-text-primary);
    text-decoration: none;
}

.vmt-timeline-marker {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    background: color-mix(in srgb, var(--mud-palette-primary) 11%, transparent);
    color: var(--mud-palette-primary);
}

.vmt-timeline-copy {
    display: grid;
    gap: .24rem;
}

.vmt-timeline-copy strong, .vmt-timeline-value {
    font-weight: 800;
}

.vmt-timeline-copy small {
    color: var(--journal-muted);
    font-size: .82rem;
}

.landing-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .7rem;
}

.landing-section {
    display: grid;
    gap: 1.35rem;
}

.landing-section-heading {
    max-width: 760px;
}

.landing-section-heading h2, .landing-final-cta h2 {
    font-size: 3.45rem !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    font-weight: 800 !important;
}

.landing-problem-grid, .landing-solution-grid, .landing-role-grid, .landing-trust-grid, .landing-faq-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1rem;
}

.landing-problem-item, .landing-solution-item, .landing-role-card, .landing-trust-item, .landing-faq-item, .feature-showcase-surface {
    border-radius: 26px;
    border: 1px solid rgba(30, 37, 31, .12);
    background: #ffffff;
    padding: 1.25rem;
    box-shadow: 0 18px 52px rgba(30, 35, 28, .08);
}

.feature-showcase-surface {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(260px, .75fr);
    gap: 1rem;
    align-items: stretch;
}

.feature-showcase-list {
    display: grid;
    gap: .7rem;
}

.feature-showcase-item, .landing-problem-item {
    display: flex;
    gap: .8rem;
}

.landing-final-cta {
    border-radius: 34px;
    padding: clamp(1.5rem, 5vw, 3.5rem);
    background: #171b18;
    color: #ffffff;
    display: grid;
    gap: 1rem;
    margin-bottom: 2rem;
}

.mobile-bottom-nav {
    display: none;
}

@media (max-width: 720px) {
    .page.auth-workspace main {
        padding-left: 0 !important;
    }

    .page.auth-workspace .journal-rail.sidebar {
        display: none !important;
    }

    .journal-topbar {
        min-height: 64px;
    }

    .content, .page.auth-workspace article.content {
        padding: .9rem .85rem 6.25rem !important;
    }

    .top-row-subtitle {
        display: none;
    }

    .journal-dashboard-copy h1, .vehicle-collection-header h1, .vehicle-profile-main h1 {
        font-size: 1.9rem !important;
    }

    

    .landing-section-heading h2, .landing-final-cta h2 {
        font-size: 2.5rem !important;
    }

    .global-add-event-button {
        display: none !important;
    }

    .mobile-bottom-nav {
        position: fixed;
        left: .75rem;
        right: .75rem;
        bottom: calc(.75rem + env(safe-area-inset-bottom));
        z-index: 500;
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
        gap: .25rem;
        padding: .45rem;
        border-radius: 18px;
        border: 1px solid var(--journal-line);
        background: color-mix(in srgb, var(--journal-paper) 92%, transparent);
        backdrop-filter: blur(18px);
        box-shadow: var(--journal-shadow-soft);
    }

    .mobile-bottom-nav a {
        min-height: 48px;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: .15rem;
        border-radius: 14px;
        color: var(--journal-muted);
        text-decoration: none;
        font-size: .7rem;
        font-weight: 700;
    }

    .mobile-bottom-nav a.active, .mobile-bottom-nav a:hover, .mobile-bottom-nav a:focus-visible {
        background: color-mix(in srgb, var(--mud-palette-primary) 11%, transparent);
        color: var(--mud-palette-primary);
        outline: none;
    }

    .mobile-bottom-nav a.mobile-bottom-nav-primary {
        margin-top: -1.15rem;
        min-height: 58px;
        border-radius: 18px;
        background: var(--mud-palette-primary) !important;
        color: var(--mud-palette-primary-contrast-text, #fff) !important;
        box-shadow: 0 10px 22px color-mix(in srgb, var(--mud-palette-primary) 35%, transparent);
        font-weight: 800;
    }

    .mobile-bottom-nav a.mobile-bottom-nav-primary .mud-icon-root {
        font-size: 1.6rem;
    }

    .mobile-bottom-nav a.mobile-bottom-nav-primary:focus-visible {
        outline: 3px solid color-mix(in srgb, var(--mud-palette-primary) 35%, transparent);
        outline-offset: 2px;
    }

    .journal-dashboard-hero, .vehicle-collection-header, .vehicle-profile-hero, .vmt-page-header, .journal-dashboard-layout, .feature-showcase-surface, .vehicle-event-choice-grid {
        grid-template-columns: 1fr;
    }

    .page.auth-workspace:not(.route-pl):not(.route-en) .vehicle-profile-hero {
        grid-template-columns: 1fr !important;
        padding: 1rem !important;
        gap: .8rem;
    }

    .page.auth-workspace:not(.route-pl):not(.route-en) .vehicle-profile-main {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        gap: .7rem;
    }

    .page.auth-workspace:not(.route-pl):not(.route-en) .vehicle-profile-actions {
        order: 4;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .5rem;
        justify-content: stretch;
    }

    .page.auth-workspace:not(.route-pl):not(.route-en) .vehicle-profile-back-action {
        display: none;
    }

    .page.auth-workspace:not(.route-pl):not(.route-en) .vehicle-profile-actions .mud-button-root:not(.mud-icon-button) {
        width: 100%;
        justify-content: center;
    }

    .page.auth-workspace:not(.route-pl):not(.route-en) .vehicle-profile-actions .mud-icon-button {
        justify-self: center;
    }

    .journal-dashboard-stats, .vehicle-profile-metrics, .vehicle-card-data, .details-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .vehicle-profile-metrics > div, .journal-dashboard-stats > div {
        min-height: 72px !important;
        padding: .65rem !important;
    }

    .vehicle-profile-metrics strong, .journal-dashboard-stats strong {
        font-size: 1.05rem !important;
        line-height: 1.2 !important;
    }

    .vehicle-profile-metrics span, .journal-dashboard-stats span {
        font-size: .68rem !important;
        line-height: 1.25 !important;
    }

    .journal-today-card {
        grid-template-columns: 1fr;
    }

    .journal-hero-actions, .vehicle-profile-actions, .vehicle-primary-actions, .vmt-page-header-actions {
        justify-content: stretch;
    }

    .journal-hero-actions .mud-button-root, .vehicle-primary-actions .mud-button-root, .vmt-page-header-actions .mud-button-root, .dashboard-next-step-action {
        width: 100%;
    }
}

@media (min-width: 721px) {
    .page.auth-workspace main {
        padding-left: 0 !important;
    }

    .page.auth-workspace .journal-rail.sidebar {
        display: block !important;
        width: 88px !important;
        min-width: 88px !important;
        flex-basis: 88px !important;
    }

    .page.auth-workspace .mobile-bottom-nav {
        display: none !important;
    }
}

@media (max-width: 640px) {
    .journal-dashboard-copy h1, .vehicle-collection-header h1, .vehicle-profile-main h1 {
        font-size: 1.75rem !important;
    }

    

    .landing-section-heading h2, .landing-final-cta h2 {
        font-size: 2.15rem !important;
    }

    .journal-dashboard-hero, .vehicle-collection-header, .vehicle-profile-hero, .vmt-page-header {
        border-radius: 16px;
        padding: 1rem;
    }

    .vmt-page-header h1 {
        font-size: 1.75rem !important;
    }

    .vmt-event-card, .vmt-timeline-item, .vehicle-event-guidance {
        grid-template-columns: 1fr;
    }

    .vehicle-profile-main {
        align-items: flex-start;
    }

    .vehicle-profile-icon {
        width: 46px;
        height: 46px;
        border-radius: 14px;
    }
}

@media (max-width: 430px) {
    .today-studio-metrics, .journal-dashboard-stats, .vehicle-card-data, .details-list {
        grid-template-columns: 1fr;
    }

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

/* Layout regression guardrails after the Auto Journal remodel.
   Keep these scoped: public pages stay readable and authenticated desktop
   navigation has enough width for labels. */

.public-page .public-detail-hero {
    grid-template-columns: minmax(0, .9fr) minmax(280px, 1fr);
    gap: clamp(1.8rem, 4vw, 3rem);
    min-height: auto;
    padding: clamp(2.4rem, 5vw, 3.8rem) clamp(1.4rem, 4vw, 3.2rem);
}

.public-page .public-detail-copy .mud-typography-h1 {
    max-width: 13ch;
    font-size: clamp(2.35rem, 4vw, 3.35rem) !important;
    line-height: 1.02 !important;
    letter-spacing: 0 !important;
}

.public-page.is-pricing-page .public-detail-copy .mud-typography-h1 {
    max-width: 12ch;
    font-size: clamp(2.3rem, 3.7vw, 3.15rem) !important;
}

.public-page .public-detail-copy .mud-typography-body1, .public-page .landing-section-heading .mud-typography-body1 {
    font-size: clamp(.98rem, 1.05vw, 1.06rem) !important;
    line-height: 1.55 !important;
}

.public-page .landing-section-heading h2, .public-page .landing-final-cta h2 {
    font-size: clamp(1.9rem, 3.2vw, 2.65rem) !important;
    line-height: 1.05 !important;
}

.public-page .public-detail-media {
    min-width: 0;
}

.page.auth-workspace main {
    min-width: 0;
    overflow-x: hidden;
}

.page.auth-workspace .journal-dashboard, .page.auth-workspace .vehicle-collection, .page.auth-workspace .vehicle-profile-page {
    min-width: 0;
}

.journal-dashboard-hero {
    min-width: 0;
}

@media (min-width: 1180px) {
    .page.auth-workspace .journal-rail.sidebar {
        width: 232px !important;
        min-width: 232px !important;
        flex-basis: 232px !important;
        flex: 0 0 232px !important;
    }

    .journal-rail-brand {
        place-items: stretch;
        padding: 0 1rem;
    }

    .journal-rail-brand .navbar-brand {
        flex-direction: row;
        justify-content: flex-start;
        gap: .65rem;
        font-size: .98rem;
    }

    .journal-rail-section {
        margin: 1rem 1rem .45rem;
        text-align: left;
        font-size: .72rem;
    }

    .journal-rail .nav-item {
        padding: 0 .7rem !important;
    }

    .journal-rail .nav-link, .journal-rail button.nav-link {
        min-height: 48px;
        flex-direction: row;
        justify-content: flex-start;
        gap: .68rem;
        padding: 0 .85rem;
        text-align: left;
        font-size: .9rem;
    }

    .journal-rail .nav-link-text {
        max-width: 160px;
        min-width: 0;
        white-space: nowrap;
    }
}

@media (max-width: 1280px) and (min-width: 721px) {
    .journal-dashboard-hero, .vehicle-collection-header {
        grid-template-columns: minmax(0, 1fr);
        align-items: start;
    }

    .journal-hero-actions, .vmt-page-header-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 1020px) {
    .public-page .public-detail-hero {
        grid-template-columns: minmax(0, 1fr);
    }

    .public-page .public-detail-copy .mud-typography-h1 {
        max-width: 14ch;
        font-size: clamp(2.45rem, 8vw, 3.2rem) !important;
    }
}

@media (max-width: 720px) {
    .public-page .public-detail-hero {
        padding: 1.15rem !important;
    }

    .public-page .public-detail-copy .mud-typography-h1 {
        max-width: 100%;
        font-size: clamp(2.15rem, 11vw, 2.75rem) !important;
        line-height: 1.02 !important;
    }

    .public-page .landing-section-heading h2, .public-page .landing-final-cta h2 {
        font-size: clamp(1.8rem, 9vw, 2.25rem) !important;
    }
}

/* Strefa niebezpieczna na stronach edycji — jedyne miejsce akcji destrukcyjnych. */
.journal-danger-zone {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: 1.25rem;
    padding: 1rem 1.25rem;
    border: 1px solid color-mix(in srgb, var(--mud-palette-error) 35%, var(--journal-line));
    border-radius: var(--journal-radius-md);
    background: color-mix(in srgb, var(--mud-palette-error) 4%, var(--journal-paper));
}

.journal-danger-zone-copy h2 {
    margin: 0 0 .2rem;
    font-size: 1.05rem;
}

/* Shell pojazdu/aplikacji. Tokeny "garage" zostały skonsolidowane do --journal-*
   (jedno źródło prawdy; dark/night dziedziczą przez nadpisania --journal-* wyżej). */
.page.auth-workspace {
    background:
        radial-gradient(circle at 50% 0, color-mix(in srgb, var(--mud-palette-primary) 7%, transparent), transparent 34rem),
        var(--journal-bg);
}

.page.auth-workspace .journal-topbar {
    min-height: 68px;
    padding: 0 clamp(1rem, 2vw, 1.55rem) !important;
    background: color-mix(in srgb, var(--journal-paper) 82%, transparent);
    border-bottom: 1px solid var(--journal-line);
}

.app-topbar-context {
    min-width: 150px;
}

.app-topbar-search {
    width: min(42vw, 520px);
    min-width: 320px;
    min-height: 42px;
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: 0 .85rem;
    border: 1px solid var(--journal-line);
    border-radius: 12px;
    background: color-mix(in srgb, var(--journal-paper) 92%, transparent);
    box-shadow: 0 10px 30px rgba(18, 24, 38, .04);
}

.app-topbar-search .mud-icon-root {
    color: var(--journal-muted);
}

.app-topbar-search input {
    min-width: 0;
    flex: 1;
    border: 0;
    outline: 0;
    background: transparent;
    color: var(--journal-ink);
    font: inherit;
    font-size: .92rem;
}

.app-topbar-search input::placeholder {
    color: color-mix(in srgb, var(--journal-muted) 78%, transparent);
}

.plan-upgrade-panel {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 1rem;
    width: 100%;
    margin: 0 0 1rem;
    padding: 1.1rem;
    border: 1px solid color-mix(in srgb, var(--mud-palette-primary) 26%, var(--journal-line));
    border-radius: 18px;
    background:
        radial-gradient(circle at 0 0, color-mix(in srgb, var(--mud-palette-primary) 12%, transparent), transparent 18rem),
        color-mix(in srgb, var(--journal-paper) 96%, var(--mud-palette-primary) 4%);
    box-shadow: 0 16px 44px rgba(18, 24, 38, .06);
}

.plan-upgrade-panel.is-compact {
    grid-template-columns: auto minmax(0, 1fr);
    padding: .85rem;
    margin: .25rem 0;
    border-radius: 14px;
    box-shadow: none;
}

.plan-upgrade-panel-icon {
    width: 52px;
    height: 52px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    color: color-mix(in srgb, var(--mud-palette-primary) 90%, var(--journal-ink));
    background: color-mix(in srgb, var(--mud-palette-primary) 14%, transparent);
    border: 1px solid color-mix(in srgb, var(--mud-palette-primary) 18%, transparent);
}

.plan-upgrade-panel.is-compact .plan-upgrade-panel-icon {
    width: 44px;
    height: 44px;
    border-radius: 13px;
}

.plan-upgrade-panel-copy {
    min-width: 0;
    display: grid;
    gap: .28rem;
}

.plan-upgrade-panel-copy h2 {
    margin: 0 !important;
    color: var(--journal-ink) !important;
    font-size: clamp(1.1rem, 1.9vw, 1.45rem) !important;
    line-height: 1.15 !important;
    letter-spacing: 0 !important;
}

.plan-upgrade-panel.is-compact .plan-upgrade-panel-copy h2 {
    font-size: 1rem !important;
}

.plan-upgrade-panel-copy p {
    margin: 0 !important;
    color: var(--journal-muted) !important;
    max-width: 68ch;
}

.plan-upgrade-panel-action {
    white-space: nowrap;
    min-height: 42px !important;
}

.plan-upgrade-panel.is-compact .plan-upgrade-panel-action {
    grid-column: 1 / -1;
    justify-self: start;
}

.app-topbar-search kbd {
    min-width: 34px;
    min-height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--journal-line);
    border-radius: 7px;
    background: color-mix(in srgb, var(--journal-paper) 86%, var(--journal-bg));
    color: var(--journal-muted);
    font-size: .72rem;
    font-weight: 700;
    box-shadow: none;
}

.app-notification-button {
    border: 1px solid transparent !important;
}

.app-notification-button::after {
    content: "";
    position: absolute;
    top: 10px;
    right: 10px;
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: var(--mud-palette-primary);
    border: 2px solid var(--journal-paper);
}

.app-account-chip {
    min-height: 44px;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: .65rem;
    padding: .25rem .45rem .25rem .25rem;
    border-radius: 999px;
    color: var(--journal-ink);
    text-decoration: none;
}

.app-account-chip:hover, .app-account-chip:focus-visible {
    background: color-mix(in srgb, var(--mud-palette-primary) 9%, transparent);
    color: var(--journal-ink);
    outline: 2px solid color-mix(in srgb, var(--mud-palette-primary) 28%, transparent);
    outline-offset: 2px;
}

.app-account-avatar {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: color-mix(in srgb, var(--mud-palette-primary) 14%, var(--journal-paper));
    color: var(--mud-palette-primary);
    font-weight: 800;
}

.app-account-copy {
    min-width: 0;
    display: grid;
    line-height: 1.1;
}

.app-account-copy strong, .app-account-copy small {
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.app-account-copy strong {
    font-size: .9rem;
}

.app-account-copy small {
    color: var(--journal-muted);
    font-size: .74rem;
}

.page.auth-workspace .journal-rail.sidebar {
    width: 188px !important;
    min-width: 188px !important;
    flex-basis: 188px !important;
    background: color-mix(in srgb, var(--journal-paper) 92%, var(--journal-bg));
    border-right: 1px solid var(--journal-line);
}

.journal-rail-brand {
    min-height: 68px;
    padding: 0 1rem;
    place-items: stretch;
}

.journal-rail-brand .navbar-brand {
    flex-direction: row;
    justify-content: flex-start;
    font-size: 1.05rem;
    gap: .72rem;
}

.journal-brand-mark {
    width: 34px;
    height: 34px;
    border-radius: 12px;
}

.journal-rail .nav-scrollable {
    height: calc(100vh - 68px);
}

.journal-rail .nav {
    min-height: 100%;
    padding: .65rem 0;
}

.journal-rail .nav-item {
    padding: 0 .75rem !important;
}

.journal-rail .nav-link, .journal-rail button.nav-link {
    min-height: 50px;
    flex-direction: row;
    justify-content: flex-start;
    gap: .75rem;
    padding: 0 .85rem;
    border-radius: 10px;
    color: var(--journal-ink);
    font-size: .9rem;
    font-weight: 600;
}

.journal-rail .nav-link.active {
    background: color-mix(in srgb, var(--mud-palette-primary) 11%, var(--journal-paper));
    color: var(--mud-palette-primary);
}

.journal-rail .nav-link:hover, .journal-rail .nav-link:focus-visible {
    background: color-mix(in srgb, var(--mud-palette-primary) 8%, transparent);
}

.journal-rail-section {
    margin: .8rem 1rem .45rem;
    text-align: left;
    font-size: .72rem;
    color: var(--journal-muted);
}

.journal-rail-spacer {
    flex: 1 1 auto;
    min-height: 1rem;
}

.vehicle-studio-page {
    width: min(100%, 1280px);
    margin: 0 auto;
    display: grid;
    gap: 1rem;
}

.vehicle-studio-page > * {
    min-width: 0;
}

.vehicle-studio-hero, .vehicle-studio-card {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    border: 1px solid var(--journal-line);
    border-radius: 14px;
    background: color-mix(in srgb, var(--journal-paper) 96%, transparent);
    box-shadow: 0 18px 55px rgba(18, 24, 38, .06);
}

.vehicle-studio-hero {
    display: grid;
    grid-template-columns: minmax(320px, .8fr) minmax(0, 1.2fr);
    gap: 2rem;
    padding: 1.25rem;
    align-items: stretch;
}

.vehicle-studio-photo {
    position: relative;
    min-width: 0;
    min-height: 242px;
    overflow: hidden;
    border-radius: 10px;
    background: #dfe5df;
}

.vehicle-studio-photo img {
    width: 100%;
    height: 100%;
    min-height: 242px;
    display: block;
    object-fit: cover;
}

.vehicle-studio-photo-placeholder {
    position: relative;
    z-index: 1;
    width: 100%;
    min-height: 242px;
    height: 100%;
    display: grid;
    place-items: center;
    border: 1px solid color-mix(in srgb, var(--mud-palette-primary) 20%, transparent);
    background:
        radial-gradient(circle at 34% 24%, color-mix(in srgb, var(--mud-palette-primary) 18%, transparent), transparent 34%),
        linear-gradient(135deg, color-mix(in srgb, var(--mud-palette-primary) 10%, var(--journal-paper)), color-mix(in srgb, var(--journal-bg) 90%, var(--journal-paper)));
    color: color-mix(in srgb, var(--mud-palette-primary) 84%, var(--journal-ink));
}

.vehicle-studio-photo-placeholder .mud-icon-root {
    width: clamp(4.2rem, 9vw, 6.75rem);
    height: clamp(4.2rem, 9vw, 6.75rem);
    padding: 1.15rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--journal-paper) 86%, transparent);
    border: 1px solid color-mix(in srgb, var(--mud-palette-primary) 18%, var(--journal-line));
    box-shadow: 0 18px 45px rgba(18, 24, 38, .08);
}

.vehicle-studio-photo::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 58%, rgba(0, 0, 0, .26));
    pointer-events: none;
}

.vehicle-studio-photo-action {
    position: absolute !important;
    right: .8rem;
    bottom: .8rem;
    z-index: 1;
    background: rgba(255, 255, 255, .9) !important;
    color: #17201a !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, .16) !important;
}

.vehicle-studio-summary {
    min-width: 0;
    display: grid;
    align-content: center;
    gap: 1.35rem;
}

.vehicle-studio-title-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.vehicle-studio-title-row h1 {
    font-size: clamp(2rem, 3vw, 2.45rem) !important;
    line-height: 1.05 !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
}

.vehicle-studio-title-actions {
    display: flex;
    align-items: center;
    gap: .25rem;
}

.vehicle-studio-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem .9rem;
    margin-top: .45rem;
    color: var(--journal-muted);
    font-size: .92rem;
}

.vehicle-studio-meta span:not(:last-child)::after {
    content: "•";
    margin-left: .9rem;
    color: color-mix(in srgb, var(--journal-muted) 55%, transparent);
}

.vehicle-studio-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .85rem;
}

.vehicle-studio-metric {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: .75rem;
    align-items: center;
}

.vehicle-studio-metric-icon {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    color: var(--mud-palette-primary);
    background: color-mix(in srgb, var(--mud-palette-primary) 12%, var(--journal-paper));
}

.vehicle-studio-metric.is-cost .vehicle-studio-metric-icon {
    color: #a87316;
    background: rgba(197, 139, 42, .14);
}

.vehicle-studio-metric span:last-child {
    min-width: 0;
    display: grid;
    gap: .08rem;
}

.vehicle-studio-metric small, .vehicle-studio-metric em, .vehicle-studio-event small, .vehicle-studio-event em, .vehicle-studio-reminder small, .vehicle-studio-document small, .vehicle-studio-info-grid span, .vehicle-studio-cost-note {
    color: var(--journal-muted);
    font-size: .82rem;
    font-style: normal;
}

.vehicle-studio-metric strong {
    font-size: 1.18rem;
    color: var(--journal-ink);
}

.vehicle-studio-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

.vehicle-studio-actions .mud-button-root {
    flex: 1 1 142px;
    min-height: 42px;
    border-radius: 10px;
}

.vehicle-studio-actions .mud-button-root:first-child {
    flex-grow: 1.25;
}

.today-studio-card {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    display: grid;
    grid-template-columns: minmax(320px, .82fr) minmax(0, 1.18fr);
    gap: 2rem;
    align-items: stretch;
    padding: 1.25rem;
    border: 1px solid var(--journal-line);
    border-radius: 14px;
    background: color-mix(in srgb, var(--journal-paper) 96%, transparent);
    box-shadow: 0 18px 55px rgba(18, 24, 38, .06);
}

.today-studio-visual {
    position: relative;
    min-width: 0;
    min-height: 242px;
    overflow: hidden;
    display: grid;
    align-content: space-between;
    gap: 1rem;
    padding: 1.1rem;
    border-radius: 10px;
    border: 1px solid color-mix(in srgb, var(--mud-palette-primary) 18%, var(--journal-line));
    background:
        radial-gradient(circle at 18% 18%, color-mix(in srgb, var(--mud-palette-primary) 24%, transparent), transparent 30%),
        radial-gradient(circle at 88% 12%, color-mix(in srgb, #c58b2a 20%, transparent), transparent 28%),
        linear-gradient(135deg, color-mix(in srgb, var(--mud-palette-primary) 10%, var(--journal-paper)), color-mix(in srgb, var(--journal-bg) 88%, var(--journal-paper)));
}

.today-studio-visual::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 54%, color-mix(in srgb, var(--journal-paper) 62%, transparent));
    pointer-events: none;
}

.today-studio-date, .today-studio-status, .today-studio-preview {
    position: relative;
    z-index: 1;
}

.today-studio-date {
    display: inline-flex;
    width: fit-content;
    flex-direction: column;
    gap: .18rem;
    padding: .7rem .8rem;
    border-radius: 14px;
    border: 1px solid color-mix(in srgb, var(--journal-line) 86%, transparent);
    background: color-mix(in srgb, var(--journal-paper) 82%, transparent);
    backdrop-filter: blur(16px);
}

.today-studio-date span, .today-studio-status small {
    color: var(--journal-muted);
    font-size: .74rem;
    font-weight: 700;
}

.today-studio-date strong {
    color: var(--journal-ink);
    font-size: 1rem;
    line-height: 1.15;
    text-transform: capitalize;
}

.today-studio-status {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: .75rem;
    align-items: center;
    max-width: 360px;
    padding: .8rem;
    border-radius: 16px;
    border: 1px solid color-mix(in srgb, var(--journal-line) 88%, transparent);
    background: color-mix(in srgb, var(--journal-paper) 88%, transparent);
    backdrop-filter: blur(16px);
    box-shadow: 0 14px 36px rgba(18, 24, 38, .06);
}

.today-studio-status-icon {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    color: var(--mud-palette-primary);
    background: color-mix(in srgb, var(--mud-palette-primary) 12%, var(--journal-paper));
}

.today-studio-visual.is-overdue .today-studio-status-icon {
    color: #a87316;
    background: rgba(197, 139, 42, .16);
}

.today-studio-visual.is-ok .today-studio-status-icon {
    color: var(--mud-palette-primary);
    background: color-mix(in srgb, var(--mud-palette-primary) 14%, var(--journal-paper));
}

.today-studio-status strong {
    color: var(--journal-ink);
    font-size: 1.05rem;
    line-height: 1.2;
}

.today-studio-preview {
    max-width: 520px;
    padding: 1rem;
    border-radius: 18px;
    border: 1px solid color-mix(in srgb, var(--journal-line) 86%, transparent);
    background: color-mix(in srgb, var(--journal-paper) 90%, transparent);
    backdrop-filter: blur(18px);
}

.today-studio-preview h2 {
    margin: 0;
    color: var(--journal-ink);
    font-size: clamp(1.45rem, 2.4vw, 2rem) !important;
    line-height: 1.05 !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
}

.today-studio-preview .mud-typography-body2 {
    margin-top: .45rem;
    color: var(--journal-muted);
    line-height: 1.45;
}

.today-studio-summary {
    min-width: 0;
    display: grid;
    align-content: center;
    gap: 1.35rem;
}

.today-studio-summary h1 {
    font-size: clamp(2.15rem, 3.2vw, 2.75rem) !important;
    line-height: 1.02 !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
}

.today-studio-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .85rem;
}

.today-studio-metrics .vehicle-studio-metric {
    min-width: 0;
    padding: .75rem;
    border: 1px solid var(--journal-line);
    border-radius: 14px;
    background: color-mix(in srgb, var(--journal-paper) 88%, var(--journal-bg));
}

.today-studio-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

.today-studio-actions .mud-button-root {
    min-height: 44px;
    border-radius: 10px;
    padding-inline: 1rem;
}

.vehicle-studio-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(360px, .8fr);
    gap: 1rem;
}

.vehicle-studio-side {
    display: grid;
    gap: 1rem;
}

.vehicle-studio-card {
    padding: 1.25rem;
}

.vehicle-studio-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.vehicle-studio-card-header h2 {
    font-size: 1rem !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
}

.vehicle-studio-card-header a {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    color: var(--journal-muted) !important;
    font-size: .86rem;
    font-weight: 600;
}

.vehicle-studio-timeline {
    position: relative;
    display: grid;
    gap: .25rem;
}

.vehicle-studio-timeline::before {
    content: "";
    position: absolute;
    left: 23px;
    top: 1.2rem;
    bottom: 1.2rem;
    width: 2px;
    background: color-mix(in srgb, var(--mud-palette-primary) 28%, var(--journal-line));
}

.vehicle-studio-event, .vehicle-studio-reminder, .vehicle-studio-document {
    position: relative;
    display: grid;
    align-items: center;
    gap: .8rem;
    min-width: 0;
    border: 1px solid transparent;
    color: var(--journal-ink);
    text-decoration: none;
}

.vehicle-studio-event {
    grid-template-columns: auto minmax(0, 1fr) auto auto;
    padding: .75rem 0;
}

.vehicle-studio-event:not(:last-child) {
    border-bottom-color: var(--journal-line);
}

.vehicle-studio-event-icon, .vehicle-studio-reminder-icon, .vehicle-studio-document > span:first-child {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    color: var(--mud-palette-primary);
    background: color-mix(in srgb, var(--mud-palette-primary) 10%, var(--journal-paper));
    z-index: 1;
}

.vehicle-studio-event-copy, .vehicle-studio-reminder span:nth-child(2), .vehicle-studio-document span:nth-child(2) {
    min-width: 0;
    display: grid;
    gap: .18rem;
}

.vehicle-studio-event-copy strong, .vehicle-studio-reminder strong, .vehicle-studio-document strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 700;
}

.vehicle-studio-event-value {
    white-space: nowrap;
    font-weight: 700;
}

.vehicle-studio-reminders, .vehicle-studio-documents {
    display: grid;
    gap: .5rem;
    margin-bottom: .75rem;
}

.vehicle-studio-reminder, .vehicle-studio-document {
    grid-template-columns: auto minmax(0, 1fr) auto auto;
    min-height: 56px;
    padding: .7rem;
    border-color: var(--journal-line);
    border-radius: 10px;
    background: color-mix(in srgb, var(--journal-paper) 88%, var(--journal-bg));
}

.vehicle-studio-chip {
    white-space: nowrap;
    border-radius: 999px;
    padding: .25rem .55rem;
    font-size: .74rem;
    font-weight: 700;
}

.vehicle-studio-chip.is-overdue {
    color: #a93232;
    background: rgba(184, 74, 74, .13);
}

.vehicle-studio-chip.is-soon {
    color: #9a680e;
    background: rgba(197, 139, 42, .16);
}

.vehicle-studio-chip.is-ok {
    color: var(--mud-palette-primary);
    background: color-mix(in srgb, var(--mud-palette-primary) 12%, transparent);
}

.vehicle-studio-empty {
    margin: 0;
    padding: .85rem;
    border-radius: 10px;
    background: color-mix(in srgb, var(--journal-muted) 8%, transparent);
    color: var(--journal-muted);
}

.vehicle-studio-cost-total {
    display: block;
    margin-top: -.3rem;
    color: var(--journal-ink);
    font-size: 1.7rem;
    line-height: 1.1;
}

.vehicle-studio-chart {
    height: 164px;
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    align-items: end;
    gap: .45rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--journal-line);
}

.vehicle-studio-chart-bar {
    height: 100%;
    min-width: 0;
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    justify-items: center;
    gap: .45rem;
}

.vehicle-studio-chart-bar i {
    align-self: end;
    width: 100%;
    max-width: 18px;
    height: var(--bar-height);
    min-height: 5px;
    border-radius: 8px 8px 2px 2px;
    background: color-mix(in srgb, var(--mud-palette-primary) 24%, var(--journal-line));
}

.vehicle-studio-chart-bar.is-current i {
    background: var(--mud-palette-primary);
}

.vehicle-studio-chart-bar small {
    color: var(--journal-muted);
    font-size: .72rem;
}

.vehicle-studio-bottom-grid {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
    gap: 1rem;
}

.vehicle-studio-info-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.vehicle-studio-info-grid div {
    display: grid;
    gap: .25rem;
}

.vehicle-studio-info-grid strong {
    min-width: 0;
    overflow-wrap: anywhere;
}

.vehicle-studio-notes {
    margin: 1rem 0 0;
    padding-top: 1rem;
    border-top: 1px solid var(--journal-line);
    color: var(--journal-muted);
}

@media (max-width: 1180px) {
    .app-topbar-search {
        width: min(38vw, 420px);
        min-width: 260px;
    }

    .app-account-copy {
        display: none;
    }

    .page.auth-workspace .journal-rail.sidebar {
        width: 88px !important;
        min-width: 88px !important;
        flex-basis: 88px !important;
    }

    .journal-rail-brand .navbar-brand, .journal-rail .nav-link, .journal-rail button.nav-link {
        flex-direction: column;
        justify-content: center;
        gap: .28rem;
        text-align: center;
        font-size: .68rem;
    }

    .journal-rail-section {
        text-align: center;
        margin-inline: .5rem;
    }
}

@media (max-width: 980px) {
    .today-studio-card, .vehicle-studio-hero, .vehicle-studio-grid, .vehicle-studio-bottom-grid {
        grid-template-columns: 1fr;
    }

    .today-studio-metrics, .vehicle-studio-info-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 720px) {
    .page.auth-workspace .journal-topbar {
        gap: .5rem;
    }

    .app-topbar-context, .app-topbar-search kbd, .app-account-chip, .app-notification-button {
        display: none !important;
    }

    .app-topbar-search {
        min-width: 0;
        width: 100%;
    }

    .vehicle-studio-page {
        gap: .8rem;
    }

    .today-studio-card, .vehicle-studio-hero, .vehicle-studio-card {
        border-radius: 16px;
        padding: 1rem;
    }

    .today-studio-visual {
        order: 2;
        min-height: auto;
        padding: .85rem;
    }

    .today-studio-summary {
        order: 1;
    }

    .today-studio-date {
        display: none;
    }

    .today-studio-preview {
        padding: .85rem;
        border-radius: 16px;
    }

    .today-studio-summary {
        gap: 1rem;
    }

    .today-studio-summary h1 {
        font-size: 2rem !important;
    }

    .today-studio-actions, .today-studio-actions .mud-button-root {
        width: 100%;
    }

    .today-studio-actions .mud-button-root {
        justify-content: center;
    }

    .vehicle-studio-photo, .vehicle-studio-photo img, .vehicle-studio-photo-placeholder {
        min-height: 210px;
    }

    .vehicle-studio-photo-action {
        right: .55rem;
        bottom: .55rem;
        max-width: calc(100% - 1.1rem);
    }

    .vehicle-studio-title-row, .vehicle-studio-card-header {
        align-items: flex-start;
    }

    .vehicle-studio-metrics, .vehicle-studio-info-grid {
        grid-template-columns: 1fr;
    }

    .vehicle-studio-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .5rem;
    }

    .vehicle-studio-actions > .mud-button-root:first-child {
        grid-column: 1 / -1;
    }

    .vehicle-studio-event, .vehicle-studio-reminder, .vehicle-studio-document {
        grid-template-columns: auto minmax(0, 1fr) auto;
    }

    .vehicle-studio-event-value, .vehicle-studio-reminder .mud-icon-root:last-child, .vehicle-studio-document .mud-icon-root:last-child {
        display: none;
    }

    .vehicle-studio-chart {
        overflow-x: auto;
        grid-template-columns: repeat(12, minmax(32px, 1fr));
        padding-bottom: .2rem;
    }
}

/* Shared authenticated app primitives */
.journal-page {
    display: grid;
    gap: 1rem;
}

.journal-card, .journal-form-section, .journal-empty {
    border: 1px solid var(--journal-line);
    border-radius: var(--journal-radius-lg);
    background: var(--journal-paper);
    box-shadow: var(--journal-shadow-soft);
}

.journal-card, .journal-form-section {
    padding: clamp(1rem, 1.5vw, 1.35rem);
}

.journal-section-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: .9rem;
}

.journal-section-header h2 {
    margin: 0;
    font-size: clamp(1.15rem, 1.2vw, 1.45rem);
    line-height: 1.12;
    letter-spacing: 0;
}

.journal-section-header p, .journal-empty p {
    margin: .25rem 0 0;
    color: var(--journal-muted);
}

.journal-list {
    display: grid;
    gap: .65rem;
}

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

.journal-toolbar {
    display: grid;
    grid-template-columns: repeat(2, minmax(220px, 1fr));
    gap: .85rem;
}

.journal-timeline {
    position: relative;
    display: grid;
    gap: .75rem;
}

.vehicle-journal-timeline::before {
    content: "";
    position: absolute;
    left: 24px;
    top: 1rem;
    bottom: 1rem;
    width: 2px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--mud-palette-primary) 24%, var(--journal-line));
}

.journal-entry {
    position: relative;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: .85rem;
    min-width: 0;
    padding: 1rem;
    border: 1px solid var(--journal-line);
    border-radius: var(--journal-radius-md);
    background: color-mix(in srgb, var(--journal-paper) 94%, var(--journal-bg));
    box-shadow: var(--journal-shadow-soft);
}

.vehicle-journal-timeline .journal-entry {
    margin-left: 3rem;
}

.journal-entry-icon {
    width: 48px;
    height: 48px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    color: var(--mud-palette-primary);
    background: color-mix(in srgb, var(--mud-palette-primary) 11%, var(--journal-paper));
    border: 1px solid color-mix(in srgb, var(--mud-palette-primary) 20%, var(--journal-line));
    z-index: 1;
}

.vehicle-journal-timeline .journal-entry-icon {
    position: absolute;
    left: -3rem;
    top: .95rem;
}

.journal-entry-body {
    min-width: 0;
    display: grid;
    gap: .7rem;
}

.journal-entry-header, .journal-entry-footer {
    min-width: 0;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.journal-entry-header h2, .journal-entry-header h3 {
    margin: 0;
    color: var(--journal-ink);
    font-size: 1.05rem !important;
    line-height: 1.18 !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
}

.journal-entry-meta, .journal-entry-footnote {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .28rem .55rem;
    margin-top: .25rem;
    color: var(--journal-muted);
    font-size: .84rem;
}

.journal-entry-meta span:not(:last-child)::after {
    content: "•";
    margin-left: .55rem;
    color: color-mix(in srgb, var(--journal-muted) 45%, transparent);
}

.journal-entry-description {
    color: var(--journal-muted);
}

.journal-entry-amount {
    white-space: nowrap;
    color: var(--journal-ink);
    font-size: 1rem;
}

.journal-entry-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: .25rem;
    flex-wrap: wrap;
}

.journal-entry-actions-wide {
    gap: .35rem;
}

.journal-entry-reminder.is-overdue .journal-entry-icon, .journal-entry-expense.is-insurance .journal-entry-icon {
    color: #a93232;
    background: rgba(184, 74, 74, .12);
    border-color: rgba(184, 74, 74, .2);
}

.journal-entry-reminder.is-soon .journal-entry-icon, .journal-entry-expense.is-fees .journal-entry-icon, .journal-entry-expense.is-parts .journal-entry-icon {
    color: #9a680e;
    background: rgba(197, 139, 42, .14);
    border-color: rgba(197, 139, 42, .22);
}

.journal-entry-reminder.is-completed {
    opacity: .78;
}

.journal-entry-reminder.is-completed .journal-entry-icon {
    color: var(--journal-muted);
    background: color-mix(in srgb, var(--journal-muted) 10%, var(--journal-paper));
}

.journal-entry-expense.is-fuel .journal-entry-icon {
    color: #2f6f9f;
    background: rgba(47, 111, 159, .12);
}

.journal-entry-expense.is-service .journal-entry-icon {
    color: var(--mud-palette-primary);
}

.journal-month-group {
    display: grid;
    gap: .75rem;
}

.journal-month-divider {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin: .25rem 0 -.1rem 3rem;
    padding: .55rem .85rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--journal-paper) 88%, var(--journal-bg));
    border: 1px solid var(--journal-line);
    color: var(--journal-muted);
}

.journal-month-divider h2 {
    margin: 0;
    font-size: .86rem !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    text-transform: capitalize;
}

.journal-category-bars {
    gap: .7rem;
}

.journal-attachment-grid {
    margin-top: .1rem;
}

.journal-empty {
    padding: clamp(1rem, 2vw, 1.5rem);
}

/* Vehicle primary photo */
.vehicle-card-photo {
    display: flex;
    min-height: 168px;
    overflow: hidden;
    border: 1px solid var(--journal-line);
    border-radius: 16px;
    background:
        radial-gradient(circle at 30% 22%, color-mix(in srgb, var(--mud-palette-primary) 17%, transparent), transparent 38%),
        color-mix(in srgb, var(--journal-paper-2) 94%, var(--mud-palette-primary) 6%);
    color: inherit;
    text-decoration: none;
}

.vehicle-card-photo img, .vehicle-card-photo span {
    width: 100%;
    height: 100%;
    min-height: 168px;
}

.vehicle-card-photo img {
    display: block;
    object-fit: cover;
}

.vehicle-card-photo span {
    display: grid;
    place-items: center;
    color: var(--mud-palette-primary);
}

.vehicle-card-photo .mud-icon-root {
    width: 42px;
    height: 42px;
    opacity: .82;
}

.vehicle-photo-form-section {
    overflow: visible;
}

.vehicle-photo-uploader {
    display: grid;
    grid-template-columns: minmax(180px, 260px) minmax(0, 1fr);
    gap: 1rem;
    align-items: stretch;
}

.vehicle-photo-uploader-preview {
    min-height: 172px;
    overflow: hidden;
    border: 1px solid var(--journal-line);
    border-radius: 18px;
    background:
        radial-gradient(circle at 34% 22%, color-mix(in srgb, var(--mud-palette-primary) 18%, transparent), transparent 36%),
        color-mix(in srgb, var(--journal-paper-2) 94%, var(--mud-palette-primary) 6%);
}

.vehicle-photo-uploader-preview img, .vehicle-photo-uploader-fallback {
    width: 100%;
    height: 100%;
    min-height: 172px;
}

.vehicle-photo-uploader-preview img {
    display: block;
    object-fit: cover;
}

.vehicle-photo-uploader-fallback {
    display: grid;
    place-items: center;
    color: var(--mud-palette-primary);
}

.vehicle-photo-uploader-fallback .mud-icon-root {
    width: 46px;
    height: 46px;
    opacity: .8;
}

.vehicle-photo-uploader-copy {
    min-width: 0;
    display: grid;
    align-content: center;
    gap: .55rem;
}

.vehicle-photo-uploader-copy h3 {
    margin: 0;
    font-size: 1.05rem;
    line-height: 1.2;
}

.vehicle-photo-uploader-meta, .vehicle-photo-uploader-selected {
    margin: .1rem 0 0;
    color: var(--journal-muted);
    font-size: .88rem;
}

.vehicle-photo-uploader-selected {
    color: var(--mud-palette-primary);
    font-weight: 700;
}

.vehicle-photo-uploader-actions {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex-wrap: wrap;
    margin-top: .35rem;
}

.vehicle-photo-upload-button, .vehicle-photo-inline-upload {
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .45rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--mud-palette-primary) 32%, var(--journal-line));
    background: color-mix(in srgb, var(--mud-palette-primary) 10%, var(--journal-paper));
    color: var(--mud-palette-primary);
    cursor: pointer;
    font-weight: 800;
    font-size: .86rem;
    line-height: 1;
    padding: 0 .95rem;
    transition: border-color .18s ease, background-color .18s ease, transform .18s ease;
}

.vehicle-photo-upload-button:hover, .vehicle-photo-upload-button:focus-within, .vehicle-photo-inline-upload:hover, .vehicle-photo-inline-upload:focus-within {
    border-color: color-mix(in srgb, var(--mud-palette-primary) 56%, var(--journal-line));
    background: color-mix(in srgb, var(--mud-palette-primary) 16%, var(--journal-paper));
    transform: translateY(-1px);
}

.vehicle-photo-upload-button input, .vehicle-photo-inline-upload input {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
}

.vehicle-photo-inline-upload {
    z-index: 2;
    color: #17201a;
    border-color: rgba(255, 255, 255, .78);
    background: rgba(255, 255, 255, .92);
    box-shadow: 0 8px 24px rgba(0, 0, 0, .16);
}

.vehicle-studio-photo-loading {
    position: absolute;
    inset: 0;
    z-index: 3;
    display: grid;
    place-items: center;
    background: rgba(255, 255, 255, .48);
    backdrop-filter: blur(3px);
}

.vehicle-studio-photo-delete {
    position: absolute !important;
    top: .65rem;
    right: .65rem;
    z-index: 2;
    background: rgba(255, 255, 255, .88) !important;
    color: #17201a !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, .14) !important;
}

.vehicle-studio-photo-focus-action {
    position: absolute;
    left: .8rem;
    bottom: .8rem;
    z-index: 2;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .42rem;
    padding: 0 .9rem;
    border: 1px solid rgba(255, 255, 255, .78);
    border-radius: 999px;
    background: rgba(255, 255, 255, .9);
    color: #17201a;
    box-shadow: 0 8px 24px rgba(0, 0, 0, .16);
    font-weight: 800;
    font-size: .86rem;
    cursor: pointer;
}

.vehicle-photo-crop-title {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    color: var(--journal-ink);
    font-weight: 800;
}

.vehicle-photo-crop-shell {
    display: grid;
    gap: 1rem;
}

.vehicle-photo-crop-shell p {
    margin: 0;
    color: var(--journal-muted);
    font-size: .95rem;
}

.vehicle-photo-crop-stage {
    position: relative;
    overflow: hidden;
    width: 100%;
    aspect-ratio: 16 / 9;
    max-height: min(68vh, 620px);
    border: 1px solid var(--journal-line);
    border-radius: 18px;
    background: #101613;
}

.vehicle-photo-crop-host {
    width: 100%;
    height: 100%;
    min-height: 0;
}

.vehicle-photo-crop-source {
    display: block;
    max-width: 100%;
}

.vehicle-photo-crop-loading {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    z-index: 3;
    background: rgba(12, 17, 15, .45);
}

.vehicle-photo-crop-host cropper-canvas {
    width: 100%;
    height: 100%;
    background: #101613;
}

.vehicle-photo-crop-host cropper-selection {
    outline: 2px solid rgba(255, 255, 255, .92);
    outline-offset: -1px;
    cursor: grab;
    box-shadow: 0 0 0 999px rgba(4, 7, 6, .54);
}

.vehicle-photo-crop-host cropper-selection:active {
    cursor: grabbing;
}

.vehicle-photo-crop-host cropper-grid {
    border-color: rgba(255, 255, 255, .42);
}

.vehicle-photo-crop-host cropper-handle[action="move"] {
    cursor: grab;
}

.vehicle-photo-crop-host cropper-handle[action="move"]:active {
    cursor: grabbing;
}

.vehicle-photo-crop-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .75rem;
}

.vehicle-photo-crop-dialog .mud-dialog-actions {
    gap: .6rem;
    padding: 1rem 1.5rem 1.35rem;
}

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

    .vehicle-journal-timeline::before {
        display: none;
    }

    .vehicle-journal-timeline .journal-entry, .journal-month-divider {
        margin-left: 0;
    }

    .journal-entry {
        grid-template-columns: 1fr;
        gap: .75rem;
        padding: .9rem;
    }

    .vehicle-journal-timeline .journal-entry-icon {
        position: static;
    }

    .journal-entry-header, .journal-entry-footer {
        flex-direction: column;
        align-items: stretch;
    }

    .journal-entry-amount, .journal-entry-actions {
        align-self: flex-start;
    }

    .journal-entry-actions .mud-button-root {
        min-height: 44px;
    }

    .journal-entry-actions-wide {
        justify-content: flex-start;
    }

    .vehicle-studio-photo-focus-action {
        left: .55rem;
        bottom: 3.25rem;
        max-width: calc(100% - 1.1rem);
    }

    .vehicle-photo-crop-stage, .vehicle-photo-crop-host {
        min-height: 0;
        height: auto;
    }

    .vehicle-photo-crop-dialog .mud-dialog-actions {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    .vehicle-photo-crop-dialog .mud-dialog-actions .mud-button-root {
        width: 100%;
        min-height: 44px;
    }

    .vehicle-photo-crop-controls {
        justify-content: space-between;
    }

    .vehicle-photo-uploader {
        grid-template-columns: 1fr;
    }

    .vehicle-card-photo, .vehicle-card-photo img, .vehicle-card-photo span {
        min-height: 156px;
    }

    .vehicle-photo-uploader-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .vehicle-photo-upload-button, .vehicle-photo-uploader-actions .mud-button-root {
        width: 100%;
        min-height: 44px;
    }
}

/* Documents and global search */
.documents-page, .search-page {
    display: grid;
    gap: 1rem;
}

.documents-hero, .search-hero {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1.25rem;
}

.documents-hero p, .search-hero p {
    max-width: 64ch;
    margin: .35rem 0 0;
    color: var(--journal-muted);
}

.journal-hero-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: .65rem;
    flex-wrap: wrap;
}

.document-filter-card, .search-inline-card {
    padding: .85rem;
}

.document-filter-form {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: .7rem;
    width: 100%;
}

.document-filter-form > .mud-icon-root {
    color: var(--journal-muted);
}

.document-filter-form input {
    min-width: 0;
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    color: var(--journal-ink);
    font: inherit;
}

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

.document-card, .search-result-group {
    border: 1px solid var(--journal-line);
    border-radius: 22px;
    background: var(--journal-card);
    box-shadow: var(--journal-shadow-soft);
}

.document-card {
    display: grid;
    gap: .8rem;
    padding: .85rem;
}

.document-card-main, .search-result-card {
    color: inherit;
    text-decoration: none;
}

.document-card-main {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr);
    gap: .85rem;
    align-items: start;
    min-height: 64px;
}

.document-card-icon, .search-result-icon {
    width: 48px;
    height: 48px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    color: var(--mud-palette-primary);
    background: color-mix(in srgb, var(--mud-palette-primary) 11%, var(--journal-paper));
}

.document-card-icon.is-pdf {
    color: var(--journal-danger);
    background: color-mix(in srgb, var(--journal-danger) 10%, var(--journal-paper));
}

.document-card-icon.is-image {
    color: var(--journal-info);
    background: color-mix(in srgb, var(--journal-info) 10%, var(--journal-paper));
}

.document-card-copy, .search-result-copy {
    min-width: 0;
    display: grid;
    gap: .2rem;
}

.document-card-copy strong, .search-result-copy strong {
    overflow: hidden;
    color: var(--journal-ink);
    font-size: .98rem;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.document-card-copy small, .search-result-copy small, .document-card-copy em, .search-result-copy em {
    color: var(--journal-muted);
    font-size: .84rem;
    font-style: normal;
    line-height: 1.35;
}

.document-card-copy em, .search-result-copy em {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.document-card-actions {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: .35rem;
    flex-wrap: wrap;
    border-top: 1px solid var(--journal-line);
    padding-top: .65rem;
}

.search-results-stack {
    display: grid;
    gap: 1rem;
}

.search-result-group {
    padding: 1rem;
}

.search-result-list {
    display: grid;
    gap: .55rem;
}

.search-result-card {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) auto;
    align-items: center;
    gap: .85rem;
    min-height: 64px;
    border: 1px solid var(--journal-line);
    border-radius: 18px;
    padding: .7rem .8rem;
    transition: border-color .16s ease, transform .16s ease, background-color .16s ease;
}

.search-result-card:hover, .search-result-card:focus-visible, .document-card-main:focus-visible {
    border-color: color-mix(in srgb, var(--mud-palette-primary) 36%, var(--journal-line));
    background: color-mix(in srgb, var(--mud-palette-primary) 5%, var(--journal-card));
    outline: 0;
    transform: translateY(-1px);
}

.search-result-icon {
    width: 44px;
    height: 44px;
    border-radius: 14px;
}

@media (max-width: 900px) {
    .documents-hero, .search-hero {
        align-items: stretch;
        flex-direction: column;
    }

    .journal-hero-actions {
        justify-content: flex-start;
    }

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

@media (max-width: 720px) {
    .plan-upgrade-panel {
        grid-template-columns: auto minmax(0, 1fr);
        align-items: start;
        padding: .95rem;
    }

    .plan-upgrade-panel-action {
        grid-column: 1 / -1;
        width: 100%;
        min-height: 44px !important;
    }

    .document-filter-form {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .document-filter-form .mud-button-root {
        grid-column: 1 / -1;
        min-height: 44px;
    }

    .document-card-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .document-card-actions .mud-button-root, .journal-hero-actions .mud-button-root {
        width: 100%;
        min-height: 44px;
    }

    .search-result-card {
        grid-template-columns: 44px minmax(0, 1fr);
    }

    .search-result-card > .mud-icon-root:last-child {
        display: none;
    }
}

/* ============================================================
   V3 BOLD PASS — aligns the authenticated app with the new
   landing design language. Appended last so it wins the
   cascade. All colors flow through mud palette / journal vars,
   so dark, night, and accent personalization keep working.
   ============================================================ */

/* ---------- Tokens ---------- */

.page.auth-workspace {
    --journal-bg: #FAFAF7;
    --journal-line: rgba(22, 32, 27, .1);
    --journal-shadow-card: 0 1px 2px rgba(22, 32, 27, .05), 0 8px 24px rgba(22, 32, 27, .05);
    --journal-shadow-float: 0 2px 6px rgba(22, 32, 27, .07), 0 24px 64px rgba(22, 32, 27, .12);
    --journal-rail-ink: color-mix(in srgb, var(--mud-palette-primary) 16%, #121A16);
    --journal-rail-ink-2: color-mix(in srgb, var(--mud-palette-primary) 30%, #16211B);
}

.page.auth-workspace.sidebar-dark, .page.auth-workspace.sidebar-night {
    --journal-shadow-card: 0 1px 2px rgba(0, 0, 0, .2), 0 10px 28px rgba(0, 0, 0, .2);
    --journal-shadow-float: 0 2px 6px rgba(0, 0, 0, .26), 0 24px 64px rgba(0, 0, 0, .34);
}

/* ---------- Signature move: dark ink rail in every mode ---------- */

.page.auth-workspace .journal-rail.sidebar {
    background:
        radial-gradient(20rem 14rem at 0% 0%, rgba(255, 255, 255, .06), transparent 70%),
        linear-gradient(168deg, var(--journal-rail-ink), var(--journal-rail-ink-2));
    border-right: 0;
    box-shadow: 1px 0 0 rgba(255, 255, 255, .05) inset;
}

.page.auth-workspace .journal-rail-brand {
    border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.page.auth-workspace .journal-rail-brand .navbar-brand {
    color: #F4F7F5;
    font-weight: 700;
    letter-spacing: -.015em;
}

.page.auth-workspace .journal-brand-mark {
    background: var(--mud-palette-primary);
    border: 0;
    color: var(--mud-palette-primary-text, var(--mud-palette-primary-contrast-text, #FFFFFF));
    box-shadow: 0 6px 16px color-mix(in srgb, var(--mud-palette-primary) 45%, transparent);
}

.page.auth-workspace .journal-rail-section {
    color: rgba(244, 247, 245, .42);
    font-weight: 700;
    letter-spacing: .09em;
}

.page.auth-workspace .journal-rail .nav-link, .page.auth-workspace .journal-rail button.nav-link {
    color: rgba(244, 247, 245, .72);
    font-weight: 600;
    border-radius: 12px;
    transition: background-color .16s ease, color .16s ease;
}

.page.auth-workspace .journal-rail .nav-link:hover, .page.auth-workspace .journal-rail .nav-link:focus-visible {
    background: rgba(255, 255, 255, .07);
    color: #FFFFFF;
}

.page.auth-workspace .journal-rail .nav-link.active {
    background: var(--mud-palette-primary);
    color: var(--mud-palette-primary-text, var(--mud-palette-primary-contrast-text, #FFFFFF));
    box-shadow: 0 8px 20px color-mix(in srgb, var(--mud-palette-primary) 38%, transparent);
}

.page.auth-workspace .journal-rail .nav-link.active .mud-icon-root {
    color: var(--mud-palette-primary-text, var(--mud-palette-primary-contrast-text, #FFFFFF));
}

/* ---------- Topbar: lighter, glassier ---------- */

.page.auth-workspace .journal-topbar {
    background: color-mix(in srgb, var(--journal-bg) 70%, transparent);
    backdrop-filter: blur(20px) saturate(1.4);
    border-bottom: 1px solid var(--journal-line);
}

.page.auth-workspace.sidebar-dark .journal-topbar, .page.auth-workspace.sidebar-night .journal-topbar {
    background: color-mix(in srgb, var(--journal-bg) 78%, transparent);
}

.app-topbar-search {
    border-radius: 999px;
    box-shadow: none;
}

.app-topbar-search:focus-within {
    border-color: color-mix(in srgb, var(--mud-palette-primary) 45%, var(--journal-line));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--mud-palette-primary) 14%, transparent);
}

.app-topbar-search kbd {
    border-radius: 999px;
}

/* ---------- Typography: tighter, heavier display ---------- */

.today-studio-summary h1, .vehicle-studio-title-row h1, .journal-dashboard-copy h1, .vehicle-collection-header h1, .vehicle-profile-main h1 {
    letter-spacing: -.035em !important;
}

.journal-panel h2, .vmt-section-panel h2, .vmt-form-section h2, .vehicle-card h2, .today-studio-preview h2 {
    letter-spacing: -.025em !important;
}

/* ---------- Cards: bigger radius, layered elevation ---------- */

.today-studio-card, .vehicle-studio-hero, .vehicle-studio-card, .journal-dashboard-hero, .vehicle-collection-header, .vehicle-profile-hero {
    border-radius: 22px;
    box-shadow: var(--journal-shadow-card);
}

.journal-panel, .vmt-section-panel, .vmt-form-section, .vehicle-journal-card {
    border-radius: 18px;
    background: var(--journal-paper);
    box-shadow: var(--journal-shadow-card);
}

/* ---------- Dashboard hero: dark gradient panel (echoes landing) ---------- */

.page.auth-workspace .today-studio-visual {
    border: 0;
    background:
        radial-gradient(26rem 16rem at 86% -8%, rgba(255, 255, 255, .1), transparent 65%),
        linear-gradient(152deg,
            color-mix(in srgb, var(--mud-palette-primary) 22%, #131C17),
            color-mix(in srgb, var(--mud-palette-primary) 42%, #1A2620) 70%,
            color-mix(in srgb, var(--mud-palette-primary) 55%, #20302A));
    border-radius: 16px;
    box-shadow: 0 18px 44px color-mix(in srgb, var(--mud-palette-primary) 22%, rgba(0, 0, 0, .18));
}

.page.auth-workspace .today-studio-visual::after {
    background: none;
}

.page.auth-workspace .today-studio-date, .page.auth-workspace .today-studio-status, .page.auth-workspace .today-studio-preview {
    border: 1px solid rgba(255, 255, 255, .14);
    background: rgba(255, 255, 255, .08);
    backdrop-filter: blur(14px);
    box-shadow: none;
}

.page.auth-workspace .today-studio-date span, .page.auth-workspace .today-studio-status small, .page.auth-workspace .today-studio-preview .mud-typography-body2 {
    color: rgba(255, 255, 255, .68);
}

.page.auth-workspace .today-studio-date strong, .page.auth-workspace .today-studio-status strong, .page.auth-workspace .today-studio-preview h2 {
    color: #FFFFFF;
}

.page.auth-workspace .today-studio-status-icon {
    color: #FFFFFF;
    background: rgba(255, 255, 255, .14);
}

.page.auth-workspace .today-studio-visual.is-overdue .today-studio-status-icon {
    color: #FFD9A0;
    background: rgba(217, 164, 65, .26);
}

.page.auth-workspace .today-studio-visual.is-ok .today-studio-status-icon {
    color: #FFFFFF;
    background: color-mix(in srgb, var(--mud-palette-primary) 55%, rgba(255, 255, 255, .1));
}

/* ---------- Dashboard metrics: solid cards, bold numerals ---------- */

.today-studio-metrics .vehicle-studio-metric {
    border-radius: 16px;
    background: var(--journal-paper);
    box-shadow: var(--journal-shadow-card);
}

.today-studio-metrics .vehicle-studio-metric strong, .vehicle-studio-metric strong {
    font-weight: 800;
    letter-spacing: -.02em;
}

.today-studio-metrics .vehicle-studio-metric strong {
    font-size: 1.32rem;
}

/* ---------- Buttons: landing-style lift ---------- */

.page.auth-workspace .mud-button-root {
    transition: transform .16s ease, box-shadow .16s ease, background-color .16s ease;
}

.page.auth-workspace .mud-button-root.mud-button-filled-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(22, 32, 27, .14), 0 12px 26px color-mix(in srgb, var(--mud-palette-primary) 32%, transparent);
}

/* ---------- Status chips: bolder ---------- */

.status-chip {
    padding: .32rem .7rem;
    font-weight: 700;
    letter-spacing: .005em;
}

/* ---------- Cost bars: gradient fill ---------- */

.dashboard-cost-bar span, .expense-category-bar span {
    background: linear-gradient(90deg,
        var(--mud-palette-primary),
        color-mix(in srgb, var(--mud-palette-primary) 62%, #7AB8A1));
}

/* ---------- List rows: calmer borders, clearer hover ---------- */

.dashboard-priority-item, .timeline-item, .maintenance-record-card, .reminder-card, .expense-card {
    border-radius: 14px !important;
    background: var(--journal-paper) !important;
}

.dashboard-priority-item:hover, .timeline-item:hover, .vehicle-journal-card:hover, .dashboard-vehicle-cost:hover {
    transform: translateY(-2px);
    box-shadow: var(--journal-shadow-card);
}

/* ---------- Mobile dock: pill, deeper glass ---------- */

@media (max-width: 720px) {
    .mobile-bottom-nav {
        border-radius: 999px;
        padding: .4rem;
        background: color-mix(in srgb, var(--journal-paper) 86%, transparent);
        backdrop-filter: blur(22px) saturate(1.4);
        box-shadow: 0 2px 6px rgba(22, 32, 27, .08), 0 18px 44px rgba(22, 32, 27, .16);
    }

    .mobile-bottom-nav a {
        border-radius: 999px;
    }

    .mobile-bottom-nav a.active {
        background: var(--mud-palette-primary);
        color: var(--mud-palette-primary-text, var(--mud-palette-primary-contrast-text, #FFFFFF));
    }

    /* Mobile-first: the decorative status section moves below the
       summary (vehicles, reminders, quick action) and keeps natural height. */
    .page.auth-workspace .today-studio-visual {
        order: 2;
        min-height: auto;
    }
}

@media (prefers-reduced-motion: reduce) {
    .page.auth-workspace .mud-button-root, .dashboard-priority-item, .timeline-item {
        transition: none;
    }

    .page.auth-workspace .mud-button-root.mud-button-filled-primary:hover, .dashboard-priority-item:hover, .timeline-item:hover {
        transform: none;
    }
}

/* ============================================================
   V3 BOLD PASS — feature pages.
   Covers: vehicle list/details, maintenance, expenses,
   reminders, documents, search, forms, onboarding, account.
   ============================================================ */

/* ---------- Page headers: unboxed, oversized display type ---------- */

.page.auth-workspace .vmt-page-header, .page.auth-workspace .vehicle-collection-header {
    border: 0;
    background: transparent;
    box-shadow: none;
    padding-left: 0;
    padding-right: 0;
    padding-top: .5rem;
}

.vmt-page-header h1, .vehicle-collection-header h1, .documents-hero h1, .search-hero h1, .journal-hero h1 {
    font-size: clamp(2.1rem, 3.4vw, 2.9rem) !important;
    letter-spacing: -.038em !important;
    font-weight: 800 !important;
    line-height: 1.02 !important;
}

.journal-section-header h2 {
    letter-spacing: -.025em;
    font-weight: 800;
}

.journal-eyebrow {
    color: var(--mud-palette-primary);
    font-size: .74rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

/* ---------- Shared cards: solid surfaces, soft float ---------- */

.journal-card, .journal-form-section, .journal-empty, .document-card, .search-result-group, .vehicle-journal-card {
    border-radius: 20px;
    background: var(--journal-paper);
    box-shadow: var(--journal-shadow-card);
}

/* ---------- Entry rows (maintenance / expenses / reminders) ---------- */

.journal-entry {
    border-radius: 16px;
    background: var(--journal-paper);
    box-shadow: var(--journal-shadow-card);
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.journal-entry:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--mud-palette-primary) 30%, var(--journal-line));
    box-shadow: var(--journal-shadow-float);
}

.journal-entry-icon {
    border-radius: 14px;
}

.journal-entry-header h2, .journal-entry-header h3 {
    letter-spacing: -.018em !important;
}

.journal-entry-amount {
    font-size: 1.08rem;
    font-weight: 800;
    letter-spacing: -.02em;
}

/* month dividers: quiet uppercase labels instead of boxed pills */
.journal-month-divider {
    border: 0;
    background: transparent;
    padding: .4rem 0 0;
    color: var(--journal-muted);
}

.journal-month-divider h2 {
    font-size: .78rem !important;
    letter-spacing: .09em !important;
    text-transform: uppercase;
}

/* ---------- Vehicle collection ---------- */

.vehicle-journal-card {
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.vehicle-journal-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--journal-shadow-float);
}

.vehicle-card-photo {
    border-radius: 14px;
}

.vehicle-card-status {
    border-radius: 12px;
}

/* ---------- Vehicle details (studio) ---------- */

.vehicle-studio-card-header a {
    color: var(--mud-palette-primary) !important;
    font-weight: 700;
}

.vehicle-studio-photo {
    border-radius: 14px;
}

.vehicle-studio-timeline::before {
    background: linear-gradient(180deg,
        color-mix(in srgb, var(--mud-palette-primary) 45%, transparent),
        color-mix(in srgb, var(--mud-palette-primary) 10%, transparent));
}

/* ---------- Event type picker: bigger, livelier cards ---------- */

.vmt-event-card {
    border-radius: 18px;
    background: var(--journal-paper);
    box-shadow: var(--journal-shadow-card);
}

.vmt-event-card:hover, .vmt-event-card:focus-visible {
    transform: translateY(-3px);
    box-shadow: var(--journal-shadow-float);
}

.vmt-event-card-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
}

.vmt-event-card-copy strong {
    letter-spacing: -.015em;
}

/* ---------- Timeline items ---------- */

.vmt-timeline-item {
    background: var(--journal-paper);
    border-radius: 14px;
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.vmt-timeline-item:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--mud-palette-primary) 30%, var(--journal-line));
    box-shadow: var(--journal-shadow-card);
}

.vmt-timeline-marker {
    border-radius: 14px;
}

/* ---------- Forms ---------- */

.vmt-form-section, .journal-form-section {
    border-radius: 20px;
    background: var(--journal-paper);
    box-shadow: var(--journal-shadow-card);
}

.vmt-form-section h2, .journal-form-section h2 {
    letter-spacing: -.022em !important;
}

.upload-panel {
    border-radius: 18px;
    border-width: 1.5px;
}

.vmt-sticky-form-footer {
    background: color-mix(in srgb, var(--journal-paper) 84%, transparent);
    backdrop-filter: blur(20px) saturate(1.3);
    box-shadow: var(--journal-shadow-float);
}

/* ---------- Empty states ---------- */

.vmt-empty-state, .journal-empty {
    border-radius: 20px !important;
}

.vmt-empty-state .mud-icon-root {
    border-radius: 14px;
    color: var(--mud-palette-primary);
}

/* ---------- Documents & search ---------- */

.document-filter-card, .search-inline-card {
    border-radius: 999px;
    padding: .6rem .6rem .6rem 1.1rem;
}

.document-filter-card:focus-within, .search-inline-card:focus-within {
    border-color: color-mix(in srgb, var(--mud-palette-primary) 45%, var(--journal-line));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--mud-palette-primary) 14%, transparent);
}

.document-card {
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.document-card:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--mud-palette-primary) 30%, var(--journal-line));
    box-shadow: var(--journal-shadow-float);
}

.document-card-icon {
    border-radius: 14px;
}

.search-result-card {
    border-radius: 14px;
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.search-result-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--journal-shadow-card);
}

/* ---------- Onboarding ---------- */

.onboarding-step-number {
    border-radius: 12px;
    background: var(--mud-palette-primary);
    color: var(--mud-palette-primary-text, var(--mud-palette-primary-contrast-text, #FFFFFF));
    font-weight: 800;
}

/* ---------- Account / manage ---------- */

.account-manage-nav {
    border-radius: 18px;
    background: var(--journal-paper);
    box-shadow: var(--journal-shadow-card);
}

.account-manage-nav .nav-link {
    border-radius: 12px;
    font-weight: 600;
    transition: background-color .15s ease, color .15s ease;
}

.account-manage-nav .nav-link.active {
    background: var(--mud-palette-primary);
    color: var(--mud-palette-primary-text, var(--mud-palette-primary-contrast-text, #FFFFFF)) !important;
}

/* ---------- Plan upgrade panel: align with landing dark accents ---------- */

.plan-upgrade-panel {
    border-radius: 20px;
    box-shadow: var(--journal-shadow-card);
}

/* ---------- MudBlazor surfaces: dialogs, menus, inputs ---------- */

.mud-dialog {
    border-radius: 20px !important;
    box-shadow: var(--journal-shadow-float) !important;
}

/* Phones: dialogs become bottom sheets — anchored to the thumb,
   full width, rounded only at the top. */
@media (max-width: 720px) {
    .mud-dialog-container {
        align-items: flex-end !important;
    }

    .mud-dialog:not(.vehicle-photo-crop-dialog) {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        max-height: 88dvh;
        border-radius: 20px 20px 0 0 !important;
        padding-bottom: env(safe-area-inset-bottom);
    }

    .mud-dialog:not(.vehicle-photo-crop-dialog) .mud-dialog-content {
        max-height: calc(88dvh - 8rem);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    .mud-dialog .mud-dialog-actions {
        flex-wrap: wrap;
        gap: .5rem;
    }

    .mud-dialog .mud-dialog-actions .mud-button-root {
        min-height: 48px;
        flex: 1 1 auto;
    }
}

/* Snackbars must never hide behind the bottom dock. */
@media (max-width: 720px) {
    .mud-snackbar-location-bottom-left,
    .mud-snackbar-location-bottom-center,
    .mud-snackbar-location-bottom-right,
    .mud-snackbar-location-bottom-start,
    .mud-snackbar-location-bottom-end {
        bottom: calc(5.4rem + env(safe-area-inset-bottom)) !important;
    }
}

.mud-popover {
    border-radius: 14px !important;
    box-shadow: var(--journal-shadow-float) !important;
}

.page.auth-workspace .mud-input-control .mud-input.mud-input-outlined .mud-input-outlined-border {
    border-radius: 12px;
}

.page.auth-workspace .mud-table, .page.auth-workspace .mud-paper:not(.mud-dialog):not(.mud-popover):not(.mud-menu-list) {
    border-radius: 16px;
}

/* ---------- Reduced motion ---------- */

@media (prefers-reduced-motion: reduce) {
    .journal-entry, .vehicle-journal-card, .vmt-event-card, .vmt-timeline-item, .document-card, .search-result-card {
        transition: none;
    }

    .journal-entry:hover, .vehicle-journal-card:hover, .vmt-event-card:hover, .vmt-timeline-item:hover, .document-card:hover, .search-result-card:hover {
        transform: none;
    }
}

/* ---------- Mobile refinements for feature pages ---------- */

@media (max-width: 720px) {
    .vmt-page-header h1, .vehicle-collection-header h1, .documents-hero h1, .search-hero h1 {
        font-size: 1.9rem !important;
    }

    .journal-entry {
        border-radius: 14px;
    }

    .document-filter-card, .search-inline-card {
        border-radius: 18px;
    }
}

/* ============================================================
   V3 FINISHING TOUCHES — micro-interactions & first-run UX
   ============================================================ */

/* Brand selection color */
::selection {
    background: color-mix(in srgb, var(--mud-palette-primary) 24%, transparent);
}

/* Smooth anchor scrolling (landing #product etc.) */
@media (prefers-reduced-motion: no-preference) {
    html {
        scroll-behavior: smooth;
    }
}

/* Thin, calm scrollbars */
* {
    scrollbar-width: thin;
    scrollbar-color: color-mix(in srgb, var(--mud-palette-text-secondary) 32%, transparent) transparent;
}

*::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

*::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: color-mix(in srgb, var(--mud-palette-text-secondary) 32%, transparent);
}

*::-webkit-scrollbar-track {
    background: transparent;
}

/* Snackbars match the card language */
.mud-snackbar {
    border-radius: 14px !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .12), 0 16px 40px rgba(0, 0, 0, .18) !important;
}

/* ---------- Onboarding: the first impression after signup ---------- */

.onboarding-page {
    display: grid;
    gap: 1.5rem;
    padding-top: clamp(1rem, 4vw, 2.5rem);
}

.onboarding-simple-header {
    display: grid;
    justify-items: center;
    gap: .6rem;
    text-align: center;
}

.onboarding-simple-header h1 {
    font-size: clamp(2rem, 4vw, 2.7rem) !important;
    font-weight: 800 !important;
    letter-spacing: -.035em !important;
    line-height: 1.04 !important;
}

.onboarding-simple-header .vmt-eyebrow {
    color: var(--mud-palette-primary);
    font-weight: 700;
    letter-spacing: .08em;
}

.onboarding-lead {
    max-width: 46rem;
    color: var(--journal-muted) !important;
}

.onboarding-form-panel {
    border-radius: 22px !important;
    box-shadow: var(--journal-shadow-float) !important;
}

.onboarding-skip-row {
    display: flex;
    justify-content: center;
    margin-top: .75rem;
}

.onboarding-complete {
    display: grid;
    justify-items: center;
    gap: .9rem;
    padding: clamp(2rem, 5vw, 3.5rem);
    border: 1px solid var(--journal-line);
    border-radius: 24px;
    background: var(--journal-paper);
    box-shadow: var(--journal-shadow-card);
    text-align: center;
}

.onboarding-complete > .mud-icon-root {
    width: 64px;
    height: 64px;
    padding: .9rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--mud-palette-primary) 14%, transparent);
}

.onboarding-complete h1 {
    font-size: clamp(1.7rem, 3.4vw, 2.2rem) !important;
    font-weight: 800 !important;
    letter-spacing: -.03em !important;
}

.onboarding-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .7rem;
    margin-top: .4rem;
}

/* ---------- Error / 404 state ---------- */

.error-state {
    display: grid;
    justify-items: center;
    gap: .9rem;
    margin-top: clamp(2rem, 8vw, 5rem);
    padding: clamp(2rem, 5vw, 3.5rem) !important;
    border: 1px solid #E4E9E4 !important;
    border-radius: 28px !important;
    background: #FFFFFF !important;
    box-shadow: 0 2px 6px rgba(22, 32, 27, .06), 0 24px 64px rgba(22, 32, 27, .1) !important;
    text-align: center;
}

.error-state .mud-icon-root {
    width: 64px;
    height: 64px;
    padding: .9rem;
    border-radius: 999px;
    background: rgba(47, 111, 94, .12);
}

.error-state h1, .error-state .mud-typography-h1 {
    font-size: clamp(1.8rem, 4vw, 2.4rem) !important;
    font-weight: 800 !important;
    letter-spacing: -.034em !important;
    line-height: 1.06 !important;
}

.error-state p {
    max-width: 38rem;
    margin: 0;
    color: #66736C;
}

.error-state .form-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .7rem;
    margin-top: .4rem;
}

/* ============================================================
   V3 MOBILE PASS — fixes reported issues: crowded public
   navbar, oversized buttons in the app, overlapping sticky
   elements. Mobile-first corrections, appended last.
   ============================================================ */

@media (max-width: 720px) {
    /* ---------- Public topbar: keep brand + CTA on one tight row ---------- */
    .page.public-workspace .journal-topbar {
        min-height: 56px;
        flex-wrap: nowrap;
        gap: .5rem;
        padding-left: .8rem !important;
        padding-right: .8rem !important;
    }

    .public-brand {
        min-width: 0;
        flex-shrink: 1;
    }

    .public-brand .top-row-title {
        font-size: .92rem;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .public-brand-mark {
        width: 34px;
        height: 34px;
        border-radius: 11px;
        flex: none;
    }

    .public-top-links {
        gap: .3rem;
        flex: none;
    }

    .page.public-workspace .top-row-actions {
        gap: .15rem;
        flex: none;
    }

    /* compact language menu trigger */
    .page.public-workspace .top-row-actions .mud-button-root {
        min-width: 0;
        min-height: 36px;
        padding: 4px 8px;
        font-size: .8rem;
    }

    /* ---------- Authenticated app: compact, consistent buttons ---------- */
    .page.auth-workspace .mud-button-root:not(.mud-icon-button) {
        min-height: 40px;
        padding: 5px 14px;
        font-size: .88rem;
    }

    .page.auth-workspace .mud-button-root:not(.mud-icon-button) .mud-button-label {
        white-space: normal;
        line-height: 1.2;
        text-align: center;
    }

    .page.auth-workspace .mud-icon-button {
        padding: 7px;
    }

    /* action rows share width instead of stacking giant buttons */
    .vehicle-studio-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .5rem;
    }

    .vehicle-studio-actions .mud-button-root {
        flex: none;
        width: 100%;
        min-height: 48px;
    }

    .vehicle-studio-actions .mud-button-root:first-child {
        grid-column: 1 / -1;
    }

    .vmt-page-header-actions, .journal-hero-actions {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
        gap: .5rem;
        width: 100%;
        justify-content: stretch;
    }

    .vmt-page-header-actions .mud-button-root, .journal-hero-actions .mud-button-root {
        width: 100%;
        justify-content: center;
    }

    .vehicle-card-actions, .maintenance-record-actions, .expense-actions, .reminder-actions, .journal-entry-actions {
        gap: .25rem;
    }

    /* dashboard hero: less dominant on a phone */
    .page.auth-workspace .today-studio-visual {
        min-height: 178px;
        gap: .7rem;
    }

    .today-studio-date {
        padding: .5rem .65rem;
    }

    .today-studio-preview h2 {
        font-size: 1.3rem !important;
    }

    .today-studio-metrics {
        gap: .5rem;
    }

    .today-studio-metrics .vehicle-studio-metric {
        padding: .6rem;
    }

    .today-studio-metrics .vehicle-studio-metric strong {
        font-size: 1.1rem;
    }

    .vehicle-studio-metric-icon {
        width: 38px;
        height: 38px;
    }

    /* sticky form footer must clear the bottom dock */
    .vmt-sticky-form-footer {
        position: sticky;
        bottom: calc(5.4rem + env(safe-area-inset-bottom));
        padding: .6rem;
        border-radius: 18px;
    }

    .vmt-sticky-form-footer .mud-button-root {
        flex: 1 1 auto;
        justify-content: center;
    }

    /* unboxed page headers: tighter rhythm on mobile */
    .page.auth-workspace .vmt-page-header, .page.auth-workspace .vehicle-collection-header {
        gap: .7rem;
        margin-bottom: .5rem;
        padding-top: .25rem;
        padding-bottom: .25rem;
    }

    /* tables / chips */
    .status-chip {
        padding: .26rem .55rem;
        font-size: .68rem;
    }
}

@media (max-width: 430px) {
    /* ultra narrow: drop the language label spacing, keep CTA visible */
    .page.public-workspace .journal-topbar {
        padding-left: .6rem !important;
        padding-right: .6rem !important;
    }

    .public-top-links a.public-top-cta {
        padding: .4rem .7rem;
        font-size: .8rem;
    }

    .page.auth-workspace .today-studio-visual {
        min-height: auto;
    }

    .vehicle-studio-actions {
        grid-template-columns: 1fr;
    }
}

/* ---------- Activation checklist (new-user dashboard) ---------- */

.activation-checklist {
    display: grid;
    gap: 1rem;
    padding: clamp(1.1rem, 2vw, 1.5rem);
    border: 1px solid color-mix(in srgb, var(--mud-palette-primary) 24%, var(--journal-line));
    border-radius: 20px;
    background:
        radial-gradient(24rem 12rem at 100% 0%, color-mix(in srgb, var(--mud-palette-primary) 9%, transparent), transparent 70%),
        var(--journal-paper);
    box-shadow: var(--journal-shadow-card);
}

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

.activation-head h2 {
    font-size: 1.25rem !important;
    font-weight: 800 !important;
    letter-spacing: -.022em !important;
    line-height: 1.15 !important;
}

.activation-progress {
    flex: none;
    padding: .35rem .75rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--mud-palette-primary) 14%, transparent);
    color: var(--mud-palette-primary);
    font-size: .82rem;
    font-weight: 700;
    white-space: nowrap;
}

.activation-steps {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .65rem;
}

.activation-step {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: .7rem;
    padding: .8rem .85rem;
    border: 1px solid var(--journal-line);
    border-radius: 14px;
    background: var(--journal-paper);
    color: inherit;
    text-decoration: none;
    transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.activation-step:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--mud-palette-primary) 34%, var(--journal-line));
    box-shadow: var(--journal-shadow-card);
    color: inherit;
}

.activation-step-ico {
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background: color-mix(in srgb, var(--mud-palette-primary) 12%, transparent);
    color: var(--mud-palette-primary);
    flex: none;
}

.activation-step.is-done {
    border-style: dashed;
    opacity: .72;
}

.activation-step.is-done .activation-step-ico {
    background: color-mix(in srgb, var(--mud-palette-primary) 85%, transparent);
    color: var(--mud-palette-primary-text, var(--mud-palette-primary-contrast-text, #fff));
}

.activation-step.is-done strong {
    text-decoration: line-through;
    text-decoration-thickness: 1.5px;
}

.activation-step-copy {
    min-width: 0;
    display: grid;
    gap: .12rem;
}

.activation-step-copy strong {
    font-size: .92rem;
    font-weight: 700;
    letter-spacing: -.01em;
    line-height: 1.25;
    color: var(--journal-ink);
}

.activation-step-copy small {
    color: var(--journal-muted);
    font-size: .78rem;
    line-height: 1.35;
}

.activation-step-arrow {
    color: var(--journal-muted);
}

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

@media (max-width: 600px) {
    .activation-steps {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (prefers-reduced-motion: reduce) {
    .activation-step,
    .activation-step:hover {
        transition: none;
        transform: none;
    }
}

/* ---------- Vehicle history report (printable) ---------- */

.vmt-report-page {
    width: min(100%, 880px);
    margin: 0 auto;
    display: grid;
    gap: 1rem;
}

.vmt-report-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.vmt-report {
    border: 1px solid var(--journal-line);
    border-radius: 20px;
    background: var(--journal-paper);
    box-shadow: var(--journal-shadow-card);
    padding: clamp(1.4rem, 3vw, 2.4rem);
    display: grid;
    gap: 1.6rem;
}

.vmt-report-header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 1rem;
    padding-bottom: 1.2rem;
    border-bottom: 2px solid var(--journal-ink);
}

.vmt-report-brand {
    display: flex;
    align-items: center;
    gap: .55rem;
    font-weight: 800;
    font-size: 1.05rem;
    letter-spacing: -.015em;
    color: var(--journal-ink);
}

.vmt-report-brand-mark {
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border-radius: 11px;
    background: var(--mud-palette-primary);
    color: var(--mud-palette-primary-text, var(--mud-palette-primary-contrast-text, #fff));
}

.vmt-report-headline h1 {
    margin: 0;
    font-size: clamp(1.3rem, 2.6vw, 1.7rem) !important;
    font-weight: 800 !important;
    letter-spacing: -.025em !important;
    line-height: 1.1 !important;
}

.vmt-report-headline p {
    margin: .2rem 0 0;
    color: var(--journal-muted);
    font-size: .95rem;
}

.vmt-report-generated {
    color: var(--journal-muted);
    font-size: .82rem;
    white-space: nowrap;
}

.vmt-report-section {
    display: grid;
    gap: .8rem;
}

.vmt-report-section h2 {
    margin: 0;
    font-size: 1.05rem !important;
    font-weight: 800 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase;
    color: var(--journal-muted);
}

.vmt-report-facts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: .6rem;
    margin: 0;
}

.vmt-report-facts > div {
    border: 1px solid var(--journal-line);
    border-radius: 12px;
    padding: .65rem .75rem;
}

.vmt-report-facts dt {
    color: var(--journal-muted);
    font-size: .74rem;
    font-weight: 600;
    letter-spacing: .02em;
}

.vmt-report-facts dd {
    margin: .15rem 0 0;
    color: var(--journal-ink);
    font-weight: 700;
}

.vmt-report-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .6rem;
}

.vmt-report-summary > div {
    display: grid;
    gap: .15rem;
    padding: .75rem .8rem;
    border: 1px solid var(--journal-line);
    border-radius: 12px;
    background: color-mix(in srgb, var(--mud-palette-primary) 5%, var(--journal-paper));
}

.vmt-report-summary small {
    color: var(--journal-muted);
    font-size: .74rem;
    font-weight: 600;
}

.vmt-report-summary strong {
    color: var(--journal-ink);
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: -.01em;
}

.vmt-report-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .88rem;
}

.vmt-report-table th,
.vmt-report-table td {
    padding: .55rem .6rem;
    border-bottom: 1px solid var(--journal-line);
    text-align: left;
    vertical-align: top;
    color: var(--journal-ink);
}

.vmt-report-table th {
    color: var(--journal-muted);
    font-size: .74rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.vmt-report-table .is-num {
    text-align: right;
    white-space: nowrap;
}

.vmt-report-empty {
    margin: 0;
    color: var(--journal-muted);
}

.vmt-report-footer {
    padding-top: 1rem;
    border-top: 1px solid var(--journal-line);
    color: var(--journal-muted);
    font-size: .8rem;
}

@media (max-width: 720px) {
    .vmt-report-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .vmt-report-header {
        grid-template-columns: minmax(0, 1fr);
        gap: .6rem;
    }

    .vmt-report-table {
        display: block;
        overflow-x: auto;
    }
}

/* ---------- Print rules ---------- */

@media print {
    .journal-rail,
    .journal-topbar,
    .app-footer,
    .mobile-bottom-nav,
    .vmt-report-toolbar,
    .personalization-anchor,
    #blazor-error-ui {
        display: none !important;
    }

    html,
    body,
    .page,
    .page.auth-workspace {
        background: #FFFFFF !important;
    }

    .page.auth-workspace article.content {
        padding: 0 !important;
    }

    .vmt-report {
        border: 0;
        border-radius: 0;
        box-shadow: none;
        padding: 0;
    }

    .vmt-report-table {
        font-size: .8rem;
    }

    .vmt-report-section,
    .vmt-report-summary > div,
    .vmt-report-facts > div {
        break-inside: avoid;
    }

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