/* ============================================================
   VehKeep landing — design system (scoped to .vk-landing)
   Premium, calm, mobile-first. Single source of truth for the
   public homepage. Does not leak into the app or other pages.
   ============================================================ */

/* Warm paper background for the public homepage only */
.page.public-workspace.route-home,
.page.public-workspace.route-pl,
.page.public-workspace.route-en {
    background: #FAFAF7;
}

.vk-landing {
    /* Ink & paper */
    --vk-ink: #16201B;
    --vk-ink-soft: #3D4A44;
    --vk-muted: #66736C;
    --vk-faint: #8E9A93;
    --vk-paper: #FAFAF7;
    --vk-card: #FFFFFF;
    --vk-wash: #F1F4F0;
    --vk-line: #E4E9E4;
    --vk-line-strong: #D3DBD4;

    /* Accent */
    --vk-accent: #2F6F5E;
    --vk-accent-deep: #245546;
    --vk-accent-ink: #1C4537;
    --vk-accent-soft: #E8F0EC;
    --vk-accent-softer: #F3F7F4;

    /* Status */
    --vk-amber: #A87316;
    --vk-amber-soft: #FAF1DF;
    --vk-blue: #2F6EA5;
    --vk-blue-soft: #EAF2F9;
    --vk-red: #B84A4A;
    --vk-red-soft: #F9ECEC;

    /* Elevation */
    --vk-shadow-card: 0 1px 2px rgba(22, 32, 27, .05), 0 8px 24px rgba(22, 32, 27, .05);
    --vk-shadow-float: 0 2px 6px rgba(22, 32, 27, .07), 0 24px 64px rgba(22, 32, 27, .13);
    --vk-shadow-pop: 0 1px 3px rgba(22, 32, 27, .1), 0 12px 36px rgba(22, 32, 27, .16);

    /* Shape */
    --vk-r-sm: 10px;
    --vk-r-md: 14px;
    --vk-r-lg: 20px;
    --vk-r-xl: 28px;

    /* Type */
    --vk-font: "Inter", "Inter var", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

    display: flex;
    flex-direction: column;
    gap: clamp(4.5rem, 9vw, 8rem);
    max-width: 1140px;
    margin: 0 auto;
    padding: clamp(.5rem, 2vw, 1.5rem) 0 2rem;
    font-family: var(--vk-font);
    color: var(--vk-ink);
    font-feature-settings: "cv05" 1, "cv11" 1, "ss01" 1;
}

.vk-landing *,
.vk-landing *::before,
.vk-landing *::after {
    box-sizing: border-box;
}

.vk-landing h1,
.vk-landing h2,
.vk-landing h3,
.vk-landing p,
.vk-landing ul {
    margin: 0;
}

.vk-landing ul {
    padding: 0;
    list-style: none;
}

.vk-landing a {
    text-decoration: none;
}

/* ---------- Buttons ---------- */

.vk-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    min-height: 3rem;
    padding: .72rem 1.5rem;
    border: 1px solid transparent;
    border-radius: 999px;
    font-family: inherit;
    font-size: .98rem;
    font-weight: 600;
    letter-spacing: -.005em;
    line-height: 1;
    cursor: pointer;
    white-space: nowrap;
    transition: background-color .18s ease, border-color .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease;
}

.vk-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--vk-paper), 0 0 0 6px color-mix(in srgb, var(--vk-accent) 45%, transparent);
}

.vk-btn-primary {
    background: var(--vk-accent);
    color: #FFFFFF;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .14), 0 1px 2px rgba(22, 32, 27, .2), 0 8px 20px color-mix(in srgb, var(--vk-accent) 28%, transparent);
}

.vk-btn-primary:hover {
    background: var(--vk-accent-deep);
    color: #FFFFFF;
    transform: translateY(-1px);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .14), 0 2px 4px rgba(22, 32, 27, .2), 0 12px 28px color-mix(in srgb, var(--vk-accent) 34%, transparent);
}

.vk-btn-primary:active {
    transform: translateY(0);
}

.vk-btn-ghost {
    background: transparent;
    border-color: var(--vk-line-strong);
    color: var(--vk-ink-soft);
}

.vk-btn-ghost:hover {
    border-color: var(--vk-accent);
    background: var(--vk-accent-softer);
    color: var(--vk-accent-ink);
}

.vk-btn-lg {
    min-height: 3.5rem;
    padding: .9rem 2rem;
    font-size: 1.05rem;
}

.vk-btn-arrow::after {
    content: "→";
    display: inline-block;
    margin-left: .15rem;
    transition: transform .18s ease;
}

.vk-btn-arrow:hover::after {
    transform: translateX(3px);
}

/* ---------- Shared section scaffolding ---------- */

.vk-section {
    display: flex;
    flex-direction: column;
    gap: clamp(1.8rem, 4vw, 2.8rem);
}

.vk-section-heading {
    display: flex;
    flex-direction: column;
    gap: .9rem;
    max-width: 620px;
}

.vk-section-heading.is-centered {
    align-items: center;
    margin: 0 auto;
    text-align: center;
}

.vk-h2 {
    font-size: clamp(1.9rem, 4.2vw, 2.9rem);
    font-weight: 700;
    line-height: 1.06;
    letter-spacing: -.034em;
    color: var(--vk-ink);
    text-wrap: balance;
}

.vk-sub {
    color: var(--vk-muted);
    font-size: 1.05rem;
    line-height: 1.65;
    text-wrap: pretty;
}

/* ============================================================
   HERO
   ============================================================ */

.vk-hero {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: center;
    padding: clamp(1.5rem, 4vw, 3.5rem) 0 0;
}

.vk-hero::before {
    content: "";
    position: absolute;
    inset: -10rem -20rem auto;
    height: 42rem;
    background:
        radial-gradient(46rem 26rem at 74% 20%, color-mix(in srgb, var(--vk-accent) 13%, transparent), transparent 70%),
        radial-gradient(32rem 22rem at 14% 8%, color-mix(in srgb, var(--vk-amber) 7%, transparent), transparent 70%);
    pointer-events: none;
    z-index: -1;
}

.vk-hero-copy {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1.3rem;
}

.vk-hero-title {
    font-size: clamp(2.7rem, 6.4vw, 4.6rem);
    font-weight: 800;
    line-height: 1.0;
    letter-spacing: -.042em;
    color: var(--vk-ink);
    text-wrap: balance;
}

.vk-hero-title em {
    font-style: normal;
    background-image: linear-gradient(96deg, var(--vk-accent) 10%, #4FA188 55%, #6FB89E 95%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.vk-hero-lead {
    max-width: 34rem;
    color: var(--vk-muted);
    font-size: clamp(1.05rem, 1.6vw, 1.18rem);
    line-height: 1.65;
    text-wrap: pretty;
}

.vk-hero-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .8rem;
    margin-top: .3rem;
}

.vk-hero-note {
    color: var(--vk-faint);
    font-size: .88rem;
    line-height: 1.5;
}

.vk-hero-proof {
    display: flex;
    flex-wrap: wrap;
    gap: 1.4rem;
    margin-top: .4rem;
    padding-top: 1.2rem;
    border-top: 1px solid var(--vk-line);
    width: 100%;
}

.vk-hero-proof span {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    color: var(--vk-ink-soft);
    font-size: .88rem;
    font-weight: 500;
}

.vk-hero-proof .mud-icon-root {
    width: 1.05rem;
    height: 1.05rem;
    font-size: 1.05rem;
    color: var(--vk-accent);
}

/* entrance */
@media (prefers-reduced-motion: no-preference) {
    .vk-hero-copy > * {
        animation: vk-rise .7s cubic-bezier(.2, .65, .25, 1) both;
    }

    .vk-hero-copy > *:nth-child(2) { animation-delay: .06s; }
    .vk-hero-copy > *:nth-child(3) { animation-delay: .12s; }
    .vk-hero-copy > *:nth-child(4) { animation-delay: .18s; }
    .vk-hero-copy > *:nth-child(5) { animation-delay: .22s; }
    .vk-hero-copy > *:nth-child(6) { animation-delay: .26s; }

    .vk-hero-media {
        animation: vk-rise .8s cubic-bezier(.2, .65, .25, 1) .15s both;
    }
}

@keyframes vk-rise {
    from {
        opacity: 0;
        transform: translateY(14px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ---------- Hero product mockup ---------- */

.vk-hero-media {
    position: relative;
    min-width: 0;
}

.vk-window {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-lg);
    background: var(--vk-card);
    box-shadow: var(--vk-shadow-float);
}

.vk-window-bar {
    display: flex;
    align-items: center;
    gap: .4rem;
    padding: .68rem .95rem;
    border-bottom: 1px solid var(--vk-line);
    background: linear-gradient(180deg, #FDFDFC, #F7F8F6);
}

.vk-window-bar i {
    width: .6rem;
    height: .6rem;
    border-radius: 999px;
    background: #E3E7E2;
}

.vk-window-bar i:nth-child(1) { background: #F2B8B5; }
.vk-window-bar i:nth-child(2) { background: #F4D9A6; }
.vk-window-bar i:nth-child(3) { background: #BCD9C8; }

.vk-window-bar span {
    margin-left: .55rem;
    color: var(--vk-faint);
    font-size: .74rem;
    font-weight: 500;
    letter-spacing: .01em;
}

.vk-app {
    display: grid;
    grid-template-columns: 3.1rem minmax(0, 1fr);
}

.vk-app-rail {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .9rem;
    padding: .95rem 0;
    border-right: 1px solid var(--vk-line);
    background: #FBFCFA;
}

.vk-app-rail .vk-rail-logo {
    display: grid;
    place-items: center;
    width: 1.75rem;
    height: 1.75rem;
    margin-bottom: .3rem;
    border-radius: 9px;
    background: var(--vk-accent);
    color: #fff;
}

.vk-app-rail .vk-rail-logo .mud-icon-root {
    width: 1.05rem;
    height: 1.05rem;
    font-size: 1.05rem;
}

.vk-app-rail .mud-icon-root {
    width: 1.15rem;
    height: 1.15rem;
    font-size: 1.15rem;
    color: #ABB6AF;
}

.vk-app-rail .is-active .mud-icon-root {
    color: var(--vk-accent);
}

.vk-app-rail span {
    display: grid;
    place-items: center;
    width: 2rem;
    height: 2rem;
    border-radius: 9px;
}

.vk-app-rail span.is-active {
    background: var(--vk-accent-soft);
}

.vk-app-main {
    display: flex;
    flex-direction: column;
    gap: .8rem;
    padding: 1rem 1.05rem 1.15rem;
    min-width: 0;
}

.vk-app-vehicle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .8rem;
}

.vk-app-vehicle small {
    display: block;
    color: var(--vk-faint);
    font-size: .7rem;
    font-weight: 500;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.vk-app-vehicle strong {
    display: block;
    color: var(--vk-ink);
    font-size: 1.02rem;
    font-weight: 700;
    letter-spacing: -.015em;
}

.vk-chip {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .28rem .62rem;
    border-radius: 999px;
    font-size: .73rem;
    font-weight: 600;
    white-space: nowrap;
}

.vk-chip.is-neutral {
    border: 1px solid var(--vk-line);
    background: var(--vk-wash);
    color: var(--vk-ink-soft);
}

.vk-chip.is-ok {
    background: var(--vk-accent-soft);
    color: var(--vk-accent-ink);
}

.vk-chip.is-warn {
    background: var(--vk-amber-soft);
    color: var(--vk-amber);
}

.vk-chip.is-info {
    background: var(--vk-blue-soft);
    color: var(--vk-blue);
}

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

.vk-app-stat {
    display: flex;
    flex-direction: column;
    gap: .22rem;
    min-width: 0;
    padding: .68rem .75rem;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-sm);
    background: #FCFDFC;
}

.vk-app-stat small {
    color: var(--vk-faint);
    font-size: .69rem;
    font-weight: 500;
    letter-spacing: .02em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vk-app-stat strong {
    color: var(--vk-ink);
    font-size: .92rem;
    font-weight: 700;
    letter-spacing: -.01em;
    white-space: nowrap;
}

.vk-app-stat.is-warn strong {
    color: var(--vk-amber);
}

.vk-app-section-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: .15rem;
    color: var(--vk-faint);
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .05em;
    text-transform: uppercase;
}

.vk-timeline {
    display: flex;
    flex-direction: column;
    gap: .45rem;
}

.vk-timeline-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: .7rem;
    padding: .62rem .7rem;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-sm);
    background: var(--vk-card);
}

.vk-timeline-ico {
    display: grid;
    place-items: center;
    width: 2.1rem;
    height: 2.1rem;
    border-radius: 9px;
    background: var(--vk-accent-soft);
    color: var(--vk-accent);
    flex: none;
}

.vk-timeline-ico .mud-icon-root {
    width: 1.1rem;
    height: 1.1rem;
    font-size: 1.1rem;
}

.vk-timeline-row.is-warn .vk-timeline-ico {
    background: var(--vk-amber-soft);
    color: var(--vk-amber);
}

.vk-timeline-row.is-info .vk-timeline-ico {
    background: var(--vk-blue-soft);
    color: var(--vk-blue);
}

.vk-timeline-row strong {
    display: block;
    color: var(--vk-ink);
    font-size: .85rem;
    font-weight: 600;
    letter-spacing: -.005em;
    line-height: 1.25;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vk-timeline-row small {
    display: block;
    color: var(--vk-faint);
    font-size: .73rem;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vk-timeline-row b {
    color: var(--vk-ink-soft);
    font-size: .8rem;
    font-weight: 600;
    white-space: nowrap;
}

/* floating reminder card */
.vk-float-card {
    position: absolute;
    right: -1rem;
    bottom: -1.4rem;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: .7rem;
    width: min(16.5rem, 78%);
    padding: .85rem .95rem;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-md);
    background: rgba(255, 255, 255, .92);
    backdrop-filter: blur(10px);
    box-shadow: var(--vk-shadow-pop);
}

.vk-float-card .vk-float-ico {
    display: grid;
    place-items: center;
    width: 2.4rem;
    height: 2.4rem;
    border-radius: 11px;
    background: var(--vk-amber-soft);
    color: var(--vk-amber);
}

.vk-float-card small {
    display: block;
    color: var(--vk-faint);
    font-size: .7rem;
    font-weight: 500;
    letter-spacing: .03em;
    text-transform: uppercase;
}

.vk-float-card strong {
    display: block;
    color: var(--vk-ink);
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: -.01em;
    line-height: 1.3;
}

@media (prefers-reduced-motion: no-preference) {
    .vk-float-card {
        animation: vk-float 6s ease-in-out 1.2s infinite;
    }

    @keyframes vk-float {
        0%, 100% { transform: translateY(0); }
        50% { transform: translateY(-6px); }
    }
}

/* ============================================================
   PROBLEM — "the scattered mess"
   ============================================================ */

.vk-chaos-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.3rem;
    padding: .6rem 0;
}

.vk-chaos-card {
    display: flex;
    flex-direction: column;
    gap: .9rem;
    padding: 1.35rem;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-lg);
    background: var(--vk-card);
    box-shadow: var(--vk-shadow-card);
    transition: transform .25s ease, box-shadow .25s ease;
}

/* scattered-papers effect */
.vk-chaos-card:nth-child(1) { transform: rotate(-1.4deg); }
.vk-chaos-card:nth-child(2) { transform: rotate(.9deg) translateY(.6rem); }
.vk-chaos-card:nth-child(3) { transform: rotate(-.7deg); }

.vk-chaos-card:hover {
    transform: rotate(0) translateY(0);
    box-shadow: var(--vk-shadow-pop);
}

@media (prefers-reduced-motion: reduce) {
    .vk-chaos-card,
    .vk-chaos-card:hover {
        transform: none;
    }
}

.vk-chaos-artifact {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: .65rem;
    padding: .72rem .8rem;
    border: 1px dashed var(--vk-line-strong);
    border-radius: var(--vk-r-sm);
    background: var(--vk-wash);
}

.vk-chaos-artifact .mud-icon-root {
    width: 1.2rem;
    height: 1.2rem;
    font-size: 1.2rem;
    color: var(--vk-faint);
}

.vk-chaos-artifact strong {
    display: block;
    color: var(--vk-ink-soft);
    font-size: .82rem;
    font-weight: 600;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vk-chaos-artifact small {
    display: block;
    color: var(--vk-faint);
    font-size: .73rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vk-chaos-card h3 {
    font-size: 1.08rem;
    font-weight: 700;
    letter-spacing: -.015em;
    line-height: 1.3;
    color: var(--vk-ink);
}

.vk-chaos-card p {
    color: var(--vk-muted);
    font-size: .94rem;
    line-height: 1.6;
}

.vk-chaos-resolve {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .7rem;
    margin-top: .4rem;
    padding: 1.05rem 1.4rem;
    border: 1px solid color-mix(in srgb, var(--vk-accent) 26%, var(--vk-line));
    border-radius: var(--vk-r-md);
    background: linear-gradient(135deg, var(--vk-accent-softer), var(--vk-accent-soft));
    color: var(--vk-accent-ink);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: -.01em;
    text-align: center;
    text-wrap: balance;
}

.vk-chaos-resolve .mud-icon-root {
    width: 1.25rem;
    height: 1.25rem;
    font-size: 1.25rem;
    color: var(--vk-accent);
    flex: none;
}

/* ============================================================
   PRODUCT SHOWCASE — realistic mini-mockups (on dark panel)
   ============================================================ */

.vk-dark-panel {
    padding: clamp(2.2rem, 5vw, 4rem);
    border-radius: var(--vk-r-xl);
    background:
        radial-gradient(38rem 22rem at 85% -5%, rgba(255, 255, 255, .07), transparent 65%),
        linear-gradient(155deg, #163028, #1D4438 60%, #245546);
    box-shadow: var(--vk-shadow-float);
}

.vk-dark-panel .vk-h2 {
    color: #FFFFFF;
}

.vk-dark-panel .vk-sub {
    color: rgba(255, 255, 255, .72);
}

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

.vk-demo-link {
    display: flex;
    justify-content: center;
}

.vk-dark-panel .vk-btn-ghost {
    border-color: rgba(255, 255, 255, .32);
    color: #FFFFFF;
}

.vk-dark-panel .vk-btn-ghost:hover {
    border-color: rgba(255, 255, 255, .6);
    background: rgba(255, 255, 255, .08);
    color: #FFFFFF;
}

.vk-showcase-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-lg);
    background: var(--vk-card);
    box-shadow: var(--vk-shadow-card);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.vk-showcase-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 2px 6px rgba(0, 0, 0, .2), 0 22px 52px rgba(0, 0, 0, .32);
}

.vk-dark-panel .vk-showcase-card {
    border-color: rgba(255, 255, 255, .1);
    box-shadow: 0 1px 3px rgba(0, 0, 0, .18), 0 14px 38px rgba(0, 0, 0, .26);
}

.vk-showcase-screen {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    min-height: 13.5rem;
    padding: 1.15rem 1.15rem 0;
    background:
        linear-gradient(180deg, var(--vk-wash), color-mix(in srgb, var(--vk-wash) 30%, var(--vk-card)));
    border-bottom: 1px solid var(--vk-line);
    overflow: hidden;
}

.vk-showcase-copy {
    display: flex;
    flex-direction: column;
    gap: .45rem;
    padding: 1.2rem 1.35rem 1.4rem;
}

.vk-showcase-copy h3 {
    font-size: 1.12rem;
    font-weight: 700;
    letter-spacing: -.018em;
    color: var(--vk-ink);
}

.vk-showcase-copy p {
    color: var(--vk-muted);
    font-size: .94rem;
    line-height: 1.6;
}

/* generic inner rows for showcase screens */
.vk-mini-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: .65rem;
    padding: .6rem .7rem;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-sm);
    background: var(--vk-card);
    box-shadow: 0 1px 2px rgba(22, 32, 27, .04);
}

.vk-mini-row .vk-mini-ico {
    display: grid;
    place-items: center;
    width: 1.9rem;
    height: 1.9rem;
    border-radius: 8px;
    background: var(--vk-accent-soft);
    color: var(--vk-accent);
    flex: none;
}

.vk-mini-row .vk-mini-ico .mud-icon-root {
    width: 1rem;
    height: 1rem;
    font-size: 1rem;
}

.vk-mini-row.is-warn .vk-mini-ico {
    background: var(--vk-amber-soft);
    color: var(--vk-amber);
}

.vk-mini-row.is-info .vk-mini-ico {
    background: var(--vk-blue-soft);
    color: var(--vk-blue);
}

.vk-mini-row.is-red .vk-mini-ico {
    background: var(--vk-red-soft);
    color: var(--vk-red);
}

.vk-mini-row strong {
    display: block;
    color: var(--vk-ink);
    font-size: .8rem;
    font-weight: 600;
    line-height: 1.25;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vk-mini-row small {
    display: block;
    color: var(--vk-faint);
    font-size: .7rem;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vk-mini-row b {
    color: var(--vk-ink-soft);
    font-size: .76rem;
    font-weight: 600;
    white-space: nowrap;
}

/* costs mini chart */
.vk-mini-chart {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    padding: .8rem .85rem;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-sm);
    background: var(--vk-card);
}

.vk-mini-chart-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: .6rem;
}

.vk-mini-chart-head small {
    color: var(--vk-faint);
    font-size: .7rem;
    font-weight: 500;
    letter-spacing: .03em;
    text-transform: uppercase;
}

.vk-mini-chart-head strong {
    color: var(--vk-ink);
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: -.02em;
}

.vk-mini-bar {
    display: grid;
    grid-template-columns: 5.4rem minmax(0, 1fr) auto;
    align-items: center;
    gap: .6rem;
}

.vk-mini-bar small {
    color: var(--vk-muted);
    font-size: .73rem;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vk-mini-bar span {
    display: block;
    height: .5rem;
    border-radius: 999px;
    background: var(--vk-wash);
    overflow: hidden;
}

.vk-mini-bar span i {
    display: block;
    width: var(--w, 50%);
    height: 100%;
    border-radius: inherit;
    background: var(--vk-accent);
}

.vk-mini-bar:nth-child(3) span i { background: var(--vk-blue); }
.vk-mini-bar:nth-child(4) span i { background: var(--vk-amber); }

.vk-mini-bar b {
    color: var(--vk-ink-soft);
    font-size: .73rem;
    font-weight: 600;
    white-space: nowrap;
}

/* documents mini grid */
.vk-mini-files {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .55rem;
}

.vk-mini-file {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: .55rem;
    padding: .6rem .65rem;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-sm);
    background: var(--vk-card);
}

.vk-mini-file .mud-icon-root {
    width: 1.15rem;
    height: 1.15rem;
    font-size: 1.15rem;
    color: var(--vk-blue);
}

.vk-mini-file.is-img .mud-icon-root {
    color: var(--vk-accent);
}

.vk-mini-file strong {
    display: block;
    color: var(--vk-ink);
    font-size: .76rem;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.vk-mini-file small {
    display: block;
    color: var(--vk-faint);
    font-size: .68rem;
}

/* ============================================================
   HOW IT WORKS
   ============================================================ */

.vk-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    counter-reset: vk-step;
}

.vk-step {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: .7rem;
    min-height: 14rem;
    padding: 1.6rem 1.5rem;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-lg);
    background: var(--vk-card);
    box-shadow: var(--vk-shadow-card);
    overflow: hidden;
}

.vk-step::before {
    counter-increment: vk-step;
    content: counter(vk-step);
    position: absolute;
    top: -1.6rem;
    right: .4rem;
    color: color-mix(in srgb, var(--vk-accent) 14%, transparent);
    font-size: 9rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -.05em;
    pointer-events: none;
}

.vk-step h3 {
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: -.015em;
    color: var(--vk-ink);
}

.vk-step p {
    color: var(--vk-muted);
    font-size: .94rem;
    line-height: 1.6;
}

/* ============================================================
   ROLES — for whom
   ============================================================ */

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

.vk-role {
    display: flex;
    flex-direction: column;
    gap: .65rem;
    padding: 1.3rem 1.25rem;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-lg);
    background: var(--vk-card);
}

.vk-role .mud-icon-root {
    width: 1.45rem;
    height: 1.45rem;
    font-size: 1.45rem;
    color: var(--vk-accent);
}

.vk-role h3 {
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: -.012em;
    line-height: 1.35;
    color: var(--vk-ink);
}

.vk-role p {
    color: var(--vk-muted);
    font-size: .9rem;
    line-height: 1.58;
}

/* ============================================================
   PRICING
   ============================================================ */

.vk-plans {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.2rem;
    max-width: 880px;
    width: 100%;
    margin: 0 auto;
}

.vk-plan {
    display: flex;
    flex-direction: column;
    gap: 1.15rem;
    padding: 1.9rem 1.8rem;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-xl);
    background: var(--vk-card);
}

.vk-plan.is-featured {
    border-color: color-mix(in srgb, var(--vk-accent) 38%, var(--vk-line));
    background: linear-gradient(180deg, var(--vk-accent-softer), var(--vk-card) 38%);
    box-shadow: var(--vk-shadow-float);
}

.vk-plan-head {
    display: flex;
    flex-direction: column;
    gap: .4rem;
}

.vk-plan-name {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-size: 1.15rem;
    font-weight: 700;
    letter-spacing: -.015em;
    color: var(--vk-ink);
}

.vk-plan-head p {
    color: var(--vk-muted);
    font-size: .92rem;
    line-height: 1.55;
}

.vk-plan-price {
    font-size: 1.9rem;
    font-weight: 700;
    letter-spacing: -.03em;
    color: var(--vk-ink);
    line-height: 1.1;
}

.vk-plan ul {
    display: flex;
    flex-direction: column;
    gap: .6rem;
    flex: 1;
}

.vk-plan li {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
    gap: .55rem;
    color: var(--vk-ink-soft);
    font-size: .92rem;
    line-height: 1.5;
}

.vk-plan li .mud-icon-root {
    width: 1.1rem;
    height: 1.1rem;
    font-size: 1.1rem;
    color: var(--vk-accent);
    margin-top: .14rem;
}

.vk-plan .vk-btn {
    width: 100%;
}

/* ============================================================
   TRUST strip
   ============================================================ */

.vk-trust {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    padding: 1.6rem;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-lg);
    background: var(--vk-wash);
}

.vk-trust-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
    gap: .75rem;
}

.vk-trust-item .mud-icon-root {
    width: 1.3rem;
    height: 1.3rem;
    font-size: 1.3rem;
    color: var(--vk-accent);
    margin-top: .1rem;
}

.vk-trust-item strong {
    display: block;
    color: var(--vk-ink);
    font-size: .95rem;
    font-weight: 700;
    letter-spacing: -.01em;
}

.vk-trust-item small {
    display: block;
    margin-top: .2rem;
    color: var(--vk-muted);
    font-size: .85rem;
    line-height: 1.5;
}

/* ============================================================
   FAQ — native accordion
   ============================================================ */

.vk-faq-list {
    display: flex;
    flex-direction: column;
    max-width: 760px;
    width: 100%;
    margin: 0 auto;
    border: 1px solid var(--vk-line);
    border-radius: var(--vk-r-lg);
    background: var(--vk-card);
    overflow: hidden;
}

.vk-faq-item + .vk-faq-item {
    border-top: 1px solid var(--vk-line);
}

.vk-faq-item summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.15rem 1.4rem;
    color: var(--vk-ink);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: -.01em;
    line-height: 1.4;
    cursor: pointer;
    list-style: none;
    transition: background-color .15s ease;
}

.vk-faq-item summary::-webkit-details-marker {
    display: none;
}

.vk-faq-item summary:hover {
    background: var(--vk-accent-softer);
}

.vk-faq-item summary::after {
    content: "+";
    flex: none;
    display: grid;
    place-items: center;
    width: 1.6rem;
    height: 1.6rem;
    border: 1px solid var(--vk-line);
    border-radius: 999px;
    color: var(--vk-muted);
    font-size: 1rem;
    font-weight: 500;
    transition: transform .2s ease, background-color .2s ease, color .2s ease;
}

.vk-faq-item[open] summary::after {
    transform: rotate(45deg);
    background: var(--vk-accent);
    border-color: var(--vk-accent);
    color: #fff;
}

.vk-faq-item p {
    padding: 0 3.6rem 1.25rem 1.4rem;
    color: var(--vk-muted);
    font-size: .95rem;
    line-height: 1.65;
}

/* ============================================================
   FINAL CTA
   ============================================================ */

.vk-final {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.2rem;
    padding: clamp(2.6rem, 6vw, 4.5rem) clamp(1.4rem, 5vw, 4rem);
    border-radius: var(--vk-r-xl);
    background: linear-gradient(150deg, #1D3B31, var(--vk-accent-deep) 55%, #2C6453);
    text-align: center;
    box-shadow: var(--vk-shadow-float);
}

.vk-final::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(34rem 18rem at 80% 0%, rgba(255, 255, 255, .1), transparent 65%);
    pointer-events: none;
}

.vk-final h2 {
    max-width: 22ch;
    color: #FFFFFF;
    font-size: clamp(1.7rem, 3.6vw, 2.5rem);
    font-weight: 700;
    line-height: 1.12;
    letter-spacing: -.028em;
    text-wrap: balance;
}

.vk-final p {
    max-width: 52ch;
    color: rgba(255, 255, 255, .78);
    font-size: 1.02rem;
    line-height: 1.65;
    text-wrap: pretty;
}

.vk-final .vk-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .8rem;
    margin-top: .4rem;
}

.vk-final .vk-btn-primary {
    background: #FFFFFF;
    color: var(--vk-accent-ink);
    box-shadow: 0 2px 6px rgba(0, 0, 0, .18), 0 12px 32px rgba(0, 0, 0, .22);
}

.vk-final .vk-btn-primary:hover {
    background: #F1F6F2;
    color: var(--vk-accent-ink);
}

.vk-final .vk-btn-ghost {
    border-color: rgba(255, 255, 255, .32);
    color: #FFFFFF;
}

.vk-final .vk-btn-ghost:hover {
    border-color: rgba(255, 255, 255, .6);
    background: rgba(255, 255, 255, .08);
    color: #FFFFFF;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1020px) {
    .vk-hero {
        grid-template-columns: minmax(0, 1fr);
        gap: 3rem;
        padding-top: 1rem;
    }

    .vk-hero-copy {
        align-items: center;
        text-align: center;
    }

    .vk-hero-lead {
        margin: 0 auto;
    }

    .vk-hero-actions {
        justify-content: center;
    }

    .vk-hero-proof {
        justify-content: center;
    }

    .vk-hero-media {
        max-width: 640px;
        margin: 0 auto;
        width: 100%;
    }

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

    .vk-roles {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .vk-trust {
        grid-template-columns: minmax(0, 1fr);
        gap: 1.3rem;
    }
}

@media (max-width: 760px) {
    .vk-landing {
        gap: 4rem;
    }

    .vk-showcase-grid,
    .vk-steps,
    .vk-roles,
    .vk-plans {
        grid-template-columns: minmax(0, 1fr);
    }

    .vk-hero-title {
        font-size: clamp(2.1rem, 9vw, 2.7rem);
    }

    .vk-hero-actions {
        width: 100%;
        flex-direction: column;
        align-items: stretch;
    }

    .vk-hero-actions .vk-btn {
        width: 100%;
    }

    .vk-hero-proof {
        gap: .8rem 1.2rem;
    }

    .vk-float-card {
        position: static;
        width: 100%;
        margin-top: .8rem;
        background: var(--vk-card);
    }

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

    .vk-app-rail {
        display: none;
    }

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

    .vk-app-stats .vk-app-stat:nth-child(3) {
        display: none;
    }

    .vk-showcase-screen {
        min-height: 11rem;
    }

    .vk-step {
        min-height: 10.5rem;
    }

    .vk-step::before {
        font-size: 7rem;
    }

    .vk-dark-panel {
        border-radius: var(--vk-r-lg);
    }

    .vk-plan {
        padding: 1.5rem 1.3rem;
    }

    .vk-faq-item p {
        padding-right: 1.4rem;
    }

    .vk-final .vk-actions {
        width: 100%;
        flex-direction: column;
    }

    .vk-final .vk-actions .vk-btn {
        width: 100%;
    }
}

/* ============================================================
   VK PUBLIC PASS — auth pages (login/register/reset) and
   public subpages (features, pricing, FAQ, help, legal,
   contact). Loaded last, so it wins over app.css and
   journal-premium.css. Public pages are forced light theme.
   ============================================================ */

/* Warm paper everywhere in the public workspace */
.page.public-workspace {
    background:
        radial-gradient(40rem 22rem at 80% -6rem, rgba(47, 111, 94, .06), transparent 70%),
        #FAFAF7;
}

/* Public buttons: pill, lifted — matches vk-btn */
.page.public-workspace .mud-button-root {
    border-radius: 999px;
    text-transform: none;
    font-weight: 600;
    letter-spacing: 0;
}

.page.public-workspace .mud-button-root.mud-button-filled-primary {
    box-shadow: 0 1px 2px rgba(22, 32, 27, .2), 0 8px 20px rgba(47, 111, 94, .28);
    transition: transform .16s ease, box-shadow .16s ease;
}

.page.public-workspace .mud-button-root.mud-button-filled-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(22, 32, 27, .2), 0 12px 28px rgba(47, 111, 94, .34);
}

/* Top nav CTA */
.public-top-links a.public-top-cta {
    border-radius: 999px;
    box-shadow: 0 1px 2px rgba(22, 32, 27, .18), 0 6px 16px rgba(47, 111, 94, .26);
}

/* ---------- Auth pages ---------- */

.auth-panel {
    border: 1px solid #E4E9E4;
    border-radius: 28px;
    background: #FFFFFF;
    box-shadow: 0 2px 6px rgba(22, 32, 27, .06), 0 24px 64px rgba(22, 32, 27, .1);
}

.auth-panel::before {
    background: var(--mud-palette-primary);
    height: 0; /* drop the multicolor stripe */
}

.auth-panel h1 {
    font-size: clamp(1.9rem, 4vw, 2.4rem);
    font-weight: 800;
    letter-spacing: -.034em;
    line-height: 1.04;
}

.auth-lead {
    color: #66736C !important;
}

.auth-panel .form-control {
    border-radius: 12px;
    background-color: #FCFDFC;
}

.auth-panel .form-control:focus {
    box-shadow: 0 0 0 3px rgba(47, 111, 94, .14);
}

.auth-panel .btn-primary,
.auth-panel .btn {
    border-radius: 999px;
    font-weight: 600;
}

.auth-panel .btn-primary {
    min-height: 3.3rem;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .14), 0 1px 2px rgba(22, 32, 27, .2), 0 8px 20px rgba(47, 111, 94, .28);
    transition: transform .16s ease, box-shadow .16s ease, background-color .16s ease;
}

.auth-panel .btn-primary:hover {
    transform: translateY(-1px);
}

.auth-link-stack a,
.auth-secondary-action a {
    color: var(--mud-palette-primary);
    font-weight: 600;
}

/* ---------- Public detail pages: heroes & headings ---------- */

.public-detail-hero {
    border: 1px solid #E4E9E4;
    border-radius: 28px;
    background: #FFFFFF;
    box-shadow: 0 1px 2px rgba(22, 32, 27, .05), 0 18px 52px rgba(22, 32, 27, .07);
}

.public-detail-copy .mud-typography-h1 {
    font-size: clamp(2.4rem, 5vw, 3.6rem) !important;
    font-weight: 800 !important;
    letter-spacing: -.04em !important;
    line-height: 1.02 !important;
}

.public-detail-copy .mud-typography-body1 {
    color: #66736C;
    font-size: 1.1rem;
    line-height: 1.65;
}

.public-page .landing-section-heading h2,
.help-page .landing-section-heading h2 {
    font-size: clamp(1.9rem, 4vw, 2.7rem) !important;
    font-weight: 700 !important;
    letter-spacing: -.034em !important;
    line-height: 1.06 !important;
}

.public-page .landing-section-heading .mud-typography-body1,
.help-page .landing-section-heading .mud-typography-body1 {
    color: #66736C;
}

/* ---------- Cards on public subpages ---------- */

.public-detail-card,
.landing-faq-item,
.landing-guide-card,
.public-plan-preview,
.public-faq-preview {
    border: 1px solid #E4E9E4 !important;
    border-radius: 20px !important;
    background: #FFFFFF !important;
    box-shadow: 0 1px 2px rgba(22, 32, 27, .05), 0 8px 24px rgba(22, 32, 27, .05) !important;
}

.landing-faq-panel .landing-faq-item {
    border-left: 1px solid #E4E9E4;
}

.landing-guide-card {
    overflow: hidden;
}

.landing-guide-card:hover,
.landing-guide-card:focus-visible {
    transform: translateY(-3px);
    border-color: rgba(47, 111, 94, .3) !important;
    box-shadow: 0 2px 6px rgba(22, 32, 27, .07), 0 22px 52px rgba(22, 32, 27, .12) !important;
}

/* ---------- Pricing page ---------- */

.public-pricing-card {
    border: 1px solid #E4E9E4;
    border-radius: 24px;
    background: #FFFFFF;
    box-shadow: 0 1px 2px rgba(22, 32, 27, .05), 0 8px 24px rgba(22, 32, 27, .05);
}

.public-pricing-card.is-pro {
    border-color: rgba(47, 111, 94, .38);
    background: linear-gradient(180deg, #F3F7F4, #FFFFFF 38%);
    box-shadow: 0 2px 6px rgba(22, 32, 27, .07), 0 24px 64px rgba(22, 32, 27, .12);
}

.public-pricing-meter {
    border-radius: 999px;
    overflow: hidden;
}

.public-pricing-meter span {
    border-radius: inherit;
    background: linear-gradient(90deg, var(--mud-palette-primary), #6FB89E);
}

/* ---------- Final CTA on subpages: dark gradient, like homepage ---------- */

.public-page .landing-final-cta,
.help-page .landing-final-cta {
    position: relative;
    overflow: hidden;
    border: 0;
    border-radius: 28px;
    padding: clamp(2.2rem, 5vw, 3.6rem);
    background:
        radial-gradient(34rem 18rem at 80% 0%, rgba(255, 255, 255, .1), transparent 65%),
        linear-gradient(150deg, #1D3B31, #245546 55%, #2C6453);
    box-shadow: 0 2px 6px rgba(22, 32, 27, .07), 0 24px 64px rgba(22, 32, 27, .13);
    text-align: center;
}

.public-page .landing-final-cta h2,
.help-page .landing-final-cta h2 {
    color: #FFFFFF !important;
    font-size: clamp(1.8rem, 4vw, 2.5rem) !important;
    font-weight: 700 !important;
    letter-spacing: -.03em !important;
    line-height: 1.1 !important;
}

.public-page .landing-final-cta .mud-typography-body1,
.help-page .landing-final-cta .mud-typography-body1 {
    color: rgba(255, 255, 255, .78) !important;
    margin-left: auto;
    margin-right: auto;
}

.public-page .landing-final-cta .landing-actions,
.help-page .landing-final-cta .landing-actions {
    justify-content: center;
}

.public-page .landing-final-cta .mud-button-filled-primary,
.help-page .landing-final-cta .mud-button-filled-primary {
    background: #FFFFFF !important;
    color: #1C4537 !important;
}

.public-page .landing-final-cta .mud-button-outlined-root,
.public-page .landing-final-cta .mud-button-text,
.help-page .landing-final-cta .mud-button-outlined-root,
.help-page .landing-final-cta .mud-button-text {
    border-color: rgba(255, 255, 255, .35) !important;
    color: #FFFFFF !important;
}

/* ---------- Help / legal / contact ---------- */

.help-article,
.public-legal-page .journal-card,
.legal-page .journal-card {
    border-radius: 20px;
}

.help-article-header h1,
.legal-page h1,
.public-legal-page h1 {
    letter-spacing: -.034em !important;
    font-weight: 800 !important;
}

.legal-meta {
    color: #8E9A93;
}

/* ---------- Public footer polish ---------- */

.app-footer.public-footer {
    border-top: 1px solid #E4E9E4;
    background: transparent;
}

.app-footer.public-footer nav a {
    color: #66736C;
    font-weight: 500;
}

.app-footer.public-footer nav a:hover {
    color: var(--mud-palette-primary);
}

@media (prefers-reduced-motion: reduce) {
    .page.public-workspace .mud-button-root.mud-button-filled-primary,
    .auth-panel .btn-primary,
    .landing-guide-card {
        transition: none;
    }

    .page.public-workspace .mud-button-root.mud-button-filled-primary:hover,
    .auth-panel .btn-primary:hover,
    .landing-guide-card:hover {
        transform: none;
    }
}

/* New mockup inside public subpage heroes (features/pricing) */
.public-detail-media .vk-hero-media {
    max-width: 100%;
}

.public-detail-media .vk-float-card {
    position: static;
    width: 100%;
    margin-top: .8rem;
    background: #FFFFFF;
}

@media (max-width: 720px) {
    .public-detail-media {
        max-height: none;
        overflow: visible;
    }
}

/* ---------- Small-phone refinements ---------- */

@media (max-width: 480px) {
    .vk-landing {
        gap: 3.4rem;
    }

    .vk-hero {
        padding-top: .75rem;
    }

    .vk-dark-panel {
        padding: 1.3rem 1rem;
    }

    .vk-final {
        padding: 2.1rem 1.2rem;
    }

    .vk-showcase-copy {
        padding: 1rem 1.05rem 1.15rem;
    }

    .vk-showcase-screen {
        padding: .85rem .85rem 0;
    }

    .vk-app-main {
        padding: .8rem .8rem .9rem;
    }

    .vk-chaos-card:nth-child(1),
    .vk-chaos-card:nth-child(2),
    .vk-chaos-card:nth-child(3) {
        transform: none;
    }

    .vk-step {
        min-height: 9rem;
        padding: 1.2rem 1.1rem;
    }

    .vk-plan {
        padding: 1.3rem 1.1rem;
    }

    .vk-trust {
        padding: 1.2rem 1rem;
    }

    .vk-faq-item summary {
        padding: 1rem 1.1rem;
    }

    .vk-faq-item p {
        padding: 0 1.1rem 1.1rem;
    }
}
