/* Zeemarq marketing v3. Shared layout vocabulary, extracted from landing.blade.php (#755). */

    /* ============================== Layout-frame override (#767) ==============================
       v3 marketing surfaces render inside the shared header's legacy .hero-section
       (lavender gradient + hero SVG overlays) and Bootstrap .container. Where a v3
       wrapper is present, neutralise that frame to the Bone page surface so the page
       reads on-brand edge to edge — no off-brand colour around the centred content.
       Scoped via :has() to v3 surfaces only; legacy (non-v3) marketing pages keep
       their existing hero treatment until #755 rebuilds them. */
    body:has(.zmq-landing-v3) .hero-section,
    body:has(.zmq-pricing-v3) .hero-section {
        background: var(--zmq-bone) !important;
    }
    body:has(.zmq-landing-v3) .hero-section::before,
    body:has(.zmq-landing-v3) .hero-section::after,
    body:has(.zmq-pricing-v3) .hero-section::before,
    body:has(.zmq-pricing-v3) .hero-section::after {
        display: none !important;
    }

    /* ============================== Reset ============================== */
    .zmq-landing-v3,
    .zmq-landing-v3 * {
        font-family: var(--zmq-font-body);
        box-sizing: border-box;
    }
    .zmq-landing-v3 {
        background: var(--zmq-bone);
        color: var(--zmq-ink);
        padding: 0;
        --zmq-bone-tinted-deep: #ECE7DC;
        --zmq-navy-tint-10: rgba(30, 58, 95, 0.10);
        --zmq-copper-tint-08: rgba(184, 106, 61, 0.08);
        --zmq-verdigris-tint-12: rgba(63, 107, 92, 0.12);
        --zmq-madder-tint-08: rgba(142, 58, 46, 0.08);
    }
    .zmq-landing-v3 a { color: inherit; }
    .zmq-landing-v3 .zmq-num {
        font-family: var(--zmq-font-mono);
        font-feature-settings: 'tnum' 1, 'lnum' 1;
    }
    .zmq-landing-v3 img { max-width: 100%; height: auto; }
    .zmq-landing-v3 svg { display: block; }

    /* ============================== Display ============================== */
    .zmq-landing-v3 .zmq-display {
        font-family: var(--zmq-font-display);
        font-style: normal;
        line-height: 0.96;
        letter-spacing: -0.02em;
    }
    .zmq-landing-v3 .zmq-display em,
    .zmq-landing-v3 .zmq-section-h2 em,
    .zmq-landing-v3 .zmq-close__h2 em,
    .zmq-landing-v3 .zmq-statement em,
    .zmq-landing-v3 .zmq-feature__claim em {
        font-family: var(--zmq-font-display);
        font-style: italic;
    }

    .zmq-landing-v3 .zmq-eyebrow {
        font-family: var(--zmq-font-mono);
        font-size: 11px;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: var(--zmq-slate-500);
        display: inline-flex;
        align-items: center;
        gap: 12px;
        margin: 0 0 24px;
    }
    .zmq-landing-v3 .zmq-eyebrow::before {
        content: '';
        display: inline-block;
        width: 24px;
        height: 1px;
        background: var(--zmq-slate-500);
    }

    .zmq-landing-v3 .zmq-section-h2 {
        font-family: var(--zmq-font-display);
        font-size: clamp(32px, 4vw, 44px);
        line-height: 1.08;
        margin: 0 0 12px;
        color: var(--zmq-ink);
    }
    .zmq-landing-v3 .zmq-section-sub {
        font-size: 16px;
        line-height: 1.55;
        color: var(--zmq-slate-500);
        margin: 0 0 32px;
        max-width: 640px;
    }

    /* ============================== Section frames ============================== */
    .zmq-landing-v3 section {
        padding: 80px 24px;
        max-width: 1240px;
        margin: 0 auto;
    }
    @media (max-width: 768px) {
        .zmq-landing-v3 section { padding: 56px 24px; }
    }

    /* ============================== CTA primitive ============================== */
    .zmq-landing-v3 .zmq-cta {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        font-family: var(--zmq-font-body);
        font-weight: 500;
        text-decoration: none;
        border-radius: 6px;
        border: 1px solid transparent;
        transition: background-color 150ms ease, color 150ms ease;
        cursor: pointer;
    }
    .zmq-landing-v3 .zmq-cta--primary { background: var(--zmq-copper-700); color: var(--zmq-bone); }
    .zmq-landing-v3 .zmq-cta--primary:hover { background: #874A2A; }
    /* Navy-fill primary. Used where Copper is taken by another seam in the
       composition (e.g. the hero rotating-word). Keeps the CTA visually
       dominant via fill weight without competing for Copper. */
    .zmq-landing-v3 .zmq-cta--primary-navy { background: var(--zmq-navy); color: var(--zmq-bone); }
    .zmq-landing-v3 .zmq-cta--primary-navy:hover { background: var(--zmq-navy-700); }
    .zmq-landing-v3 .zmq-cta--secondary-bone { background: transparent; color: var(--zmq-bone); border-color: var(--zmq-bone); }
    .zmq-landing-v3 .zmq-cta--secondary-bone:hover { background: rgba(242, 239, 232, 0.08); }
    .zmq-landing-v3 .zmq-cta--secondary-navy { background: transparent; color: var(--zmq-navy); border-color: var(--zmq-navy); }
    .zmq-landing-v3 .zmq-cta--secondary-navy:hover { background: rgba(30, 58, 95, 0.05); }
    .zmq-landing-v3 .zmq-cta--lg { height: 48px; padding: 0 24px; font-size: 16px; }
    .zmq-landing-v3 .zmq-cta--md { height: 40px; padding: 0 18px; font-size: 14px; }
    .zmq-landing-v3 .zmq-cta:focus-visible { outline: 2px solid var(--zmq-copper); outline-offset: 2px; }

    /* ============================== Stage (tilt + shadow) ============================== */
    .zmq-landing-v3 .zmq-stage {
        position: relative;
        width: 100%;
    }
    .zmq-landing-v3 .zmq-stage__fragment {
        background: var(--zmq-bone);
        border: 1px solid var(--zmq-slate-200);
        border-radius: 6px;
        overflow: hidden;
        box-shadow: 0 12px 40px rgba(107, 98, 88, 0.08), 0 1px 3px rgba(107, 98, 88, 0.04);
        transition: transform 280ms ease;
    }
    .zmq-landing-v3 .zmq-stage--tilt-l .zmq-stage__fragment { transform: rotate(-2deg); }
    .zmq-landing-v3 .zmq-stage--tilt-r .zmq-stage__fragment { transform: rotate(2deg); }
    .zmq-landing-v3 .zmq-stage--tilt-l-soft .zmq-stage__fragment { transform: rotate(-1.2deg); }
    .zmq-landing-v3 .zmq-stage--tilt-r-soft .zmq-stage__fragment { transform: rotate(1.2deg); }
    .zmq-landing-v3 .zmq-stage--flat .zmq-stage__fragment { transform: none; }
    .zmq-landing-v3 .zmq-stage__callout-wrap {
        position: absolute;
        z-index: 2;
    }
    .zmq-landing-v3 .zmq-stage__callout-wrap--tr { top: -14px; right: -16px; }
    .zmq-landing-v3 .zmq-stage__callout-wrap--br { bottom: -16px; right: -14px; }
    .zmq-landing-v3 .zmq-stage__callout-wrap--tl { top: -14px; left: -16px; }
    .zmq-landing-v3 .zmq-stage__callout-wrap--bl { bottom: -16px; left: -14px; }
    @media (max-width: 768px) {
        .zmq-landing-v3 .zmq-stage--tilt-l .zmq-stage__fragment,
        .zmq-landing-v3 .zmq-stage--tilt-r .zmq-stage__fragment,
        .zmq-landing-v3 .zmq-stage--tilt-l-soft .zmq-stage__fragment,
        .zmq-landing-v3 .zmq-stage--tilt-r-soft .zmq-stage__fragment {
            transform: none;
        }
        .zmq-landing-v3 .zmq-stage__callout-wrap--tr { top: -12px; right: -8px; }
        .zmq-landing-v3 .zmq-stage__callout-wrap--br { bottom: -12px; right: -8px; }
        .zmq-landing-v3 .zmq-stage__callout-wrap--tl { top: -12px; left: -8px; }
        .zmq-landing-v3 .zmq-stage__callout-wrap--bl { bottom: -12px; left: -8px; }
    }

    /* ============================== Callout primitive ============================== */
    .zmq-landing-v3 .zmq-callout {
        background: var(--zmq-bone);
        border: 1px solid var(--zmq-slate-200);
        border-top: 2px solid var(--zmq-copper);
        border-radius: 4px;
        padding: 10px 14px;
        display: inline-flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 2px;
        box-shadow: 0 4px 14px rgba(107, 98, 88, 0.10);
        min-width: 120px;
    }
    .zmq-landing-v3 .zmq-callout__value {
        font-family: var(--zmq-font-mono);
        font-size: 14px;
        line-height: 1.2;
        color: var(--zmq-ink);
        font-weight: 500;
    }
    .zmq-landing-v3 .zmq-callout__label {
        font-family: var(--zmq-font-mono);
        font-size: 10px;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        color: var(--zmq-slate-500);
    }

    /* ============================== Reveal ==============================
       The page reads from first paint with no JS gating. Tilt + shadow on
       fragments and tinted cards carry the visual energy; we don't need a
       scroll-triggered fade. .zmq-reveal is kept as a class hook in case a
       future enhancement wants to add scroll animation behind a feature flag.
       prefers-reduced-motion still disables fragment tilt for users who
       have asked for less motion. */
    @media (prefers-reduced-motion: reduce) {
        .zmq-landing-v3 .zmq-stage--tilt-l .zmq-stage__fragment,
        .zmq-landing-v3 .zmq-stage--tilt-r .zmq-stage__fragment,
        .zmq-landing-v3 .zmq-stage--tilt-l-soft .zmq-stage__fragment,
        .zmq-landing-v3 .zmq-stage--tilt-r-soft .zmq-stage__fragment { transform: none; }
    }

    /* ============================== Section 1: Hero ============================== */
    .zmq-landing-v3 .zmq-hero {
        padding: 96px 24px 80px;
        max-width: 1240px;
        margin: 0 auto;
        text-align: left;
    }

    /* Hero eyebrow: replace the default hairline rule with an inline SVG
       sparkle so the lead is a glyph, not a line. Sparkle inherits the
       eyebrow's slate-500 colour so the rotating-word below stays the
       single Copper seam in the composition (§18). flex-wrap lets the
       longer copy break onto a second line on narrow viewports. */
    .zmq-landing-v3 .zmq-hero__eyebrow {
        flex-wrap: wrap;
        row-gap: 4px;
    }
    .zmq-landing-v3 .zmq-hero__eyebrow::before { display: none; }
    .zmq-landing-v3 .zmq-hero__sparkle {
        width: 12px;
        height: 12px;
        color: var(--zmq-slate-500);
        flex-shrink: 0;
    }

    .zmq-landing-v3 .zmq-hero__h1 {
        font-size: clamp(48px, 8vw, 96px);
        margin: 0 0 24px;
        color: var(--zmq-ink);
    }

    /* Two-line headline. Anchor and rotator each render on their own
       line so the rotating-word width-changes never reflow line 1. The
       rotator-line reserves one line of height so the cycle cannot
       cause layout shift, even mid-delete when textContent is empty.
       Rotator + caret sit inside an aria-hidden region; the H1 itself
       carries the canonical SR reading via aria-label.

       font-family is set explicitly on each inner span because the
       `.zmq-landing-v3 *` reset at the top of this file forces every
       descendant to Inter Tight, and `.zmq-display` only catches the
       H1 element itself, not its children. Without these rules the
       headline renders in body sans-serif instead of Instrument Serif. */
    .zmq-landing-v3 .zmq-hero__anchor {
        display: block;
        font-family: var(--zmq-font-display);
    }
    .zmq-landing-v3 .zmq-hero__rotator-line {
        display: block;
        min-height: 1em;
        line-height: 0.96;
        font-family: var(--zmq-font-display);
    }
    .zmq-landing-v3 .zmq-hero__rotator {
        color: var(--zmq-copper-700);
        font-family: var(--zmq-font-display);
    }
    .zmq-landing-v3 .zmq-hero__caret {
        display: inline-block;
        color: var(--zmq-copper-700);
        margin-left: 0.05em;
        animation: zmq-hero-caret-blink 1s infinite;
        font-family: var(--zmq-font-display);
    }
    /* While the typewriter is actively typing or deleting, the inline
       JS adds .is-active to the caret to pause the blink. Solid caret
       during keystrokes, blinking caret while idle (hold + pause).
       Matches the antigravity.google typewriter pattern. */
    .zmq-landing-v3 .zmq-hero__caret.is-active {
        animation: none;
        opacity: 1;
    }
    @keyframes zmq-hero-caret-blink {
        0%, 49% { opacity: 1; }
        50%, 100% { opacity: 0; }
    }
    /* Founder lock 2026-05-28: the typewriter animation runs for every
       visitor regardless of `prefers-reduced-motion`. The earlier
       @media (prefers-reduced-motion: reduce) override on .zmq-hero__caret
       has been removed deliberately. This is a §19 / WCAG 2.2.2 deviation
       on the highest-visibility marketing surface; the animation is the
       brand surface. Note: the JS no longer early-returns under reduced
       motion either; both gates were removed in the same change. */

    .zmq-landing-v3 .zmq-hero__sub {
        font-size: clamp(18px, 1.6vw, 22px);
        line-height: 1.45;
        color: var(--zmq-ink);
        margin: 0 0 36px;
        max-width: 60ch;
    }
    .zmq-landing-v3 .zmq-hero__sub strong {
        font-weight: 600;
    }
    .zmq-landing-v3 .zmq-hero__cta-row {
        display: flex;
        align-items: center;
        gap: 16px;
        margin-bottom: 16px;
        flex-wrap: wrap;
    }
    /* Microcopy under the hero CTAs. Used on /features, /pricing,
       /omnichannel, /resources, /services/* etc. The homepage hero
       dropped its founder-seats line in the rotating-word rewrite,
       but other v3 marketing pages still render this microcopy. */
    .zmq-landing-v3 .zmq-hero__founder {
        font-family: var(--zmq-font-mono);
        font-size: 11px;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        color: var(--zmq-slate-500);
        margin: 0;
    }

    /* Centered hero modifier — opt-in via .zmq-hero--centered on the
       <section>. Scoped explicitly so the other v3 marketing heroes
       (/features, /omnichannel, /resources, /services/*, etc.) keep
       their existing left-aligned layout. The eyebrow inherits the
       centering via its inline-flex display; the sub paragraph centres
       via auto margins; the CTA row centres via flex justify. */
    .zmq-landing-v3 .zmq-hero--centered {
        text-align: center;
    }
    .zmq-landing-v3 .zmq-hero--centered .zmq-hero__sub {
        margin-left: auto;
        margin-right: auto;
    }
    .zmq-landing-v3 .zmq-hero--centered .zmq-hero__cta-row {
        justify-content: center;
    }

    /* Hero platform strip — the 5-second pitch. Renders directly under
       the CTA row inside the centered hero so a mobile visitor sees the
       headline, the value prop, the CTAs, AND the marketplace logos that
       visualise what "all your channels" actually means, all in the first
       viewport. Mobile-first: a 4-column grid that fits a 327px content
       width (375 viewport minus the 24px gutters) with a 2-row wrap;
       expands to a single 7-column row at 768px and above. Each cell is
       a centered logo with a fixed max-height; opacity is dialled back
       slightly so the strip reads as one quiet band, not a riot of brand
       colour. Real platform brand colours follow the section-5 exception. */
    .zmq-landing-v3 .zmq-hero__platforms {
        margin-top: 32px;
    }
    .zmq-landing-v3 .zmq-hero__platforms-label {
        font-family: var(--zmq-font-mono);
        font-size: 11px;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: var(--zmq-slate-500);
        margin: 0 0 16px;
    }
    /* Tile-card pattern. Each platform sits in its own white rounded
       card with a hairline border and a soft two-step shadow so the
       seven marks read as one clean grid of contained objects rather
       than a row of floating logos. Logos render at full colour inside
       the tile (the card chrome itself is the muting layer, replacing
       the prior opacity/grayscale treatment). The grid is constrained
       (~320px mobile / 600px desktop) so the cluster stays tight. */
    .zmq-landing-v3 .zmq-hero__platforms-grid {
        list-style: none;
        padding: 0;
        margin: 0 auto;
        max-width: 320px;
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 10px;
        align-items: stretch;
        justify-items: stretch;
    }
    .zmq-landing-v3 .zmq-hero__platform {
        display: flex;
        align-items: center;
        justify-content: center;
        height: 56px;
        width: 100%;
        background: var(--zmq-white);
        border: 1px solid var(--zmq-slate-200);
        border-radius: 12px;
        padding: 8px;
        box-shadow:
            0 1px 2px rgba(14, 16, 20, 0.04),
            0 4px 12px rgba(14, 16, 20, 0.06);
    }
    .zmq-landing-v3 .zmq-hero__platform img {
        max-height: 32px;
        max-width: 100%;
        width: auto;
        height: auto;
    }
    .zmq-landing-v3 .zmq-hero__platform--text {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        font-size: 12px;
        color: var(--zmq-ink);
        letter-spacing: -0.005em;
    }
    @media (min-width: 768px) {
        .zmq-landing-v3 .zmq-hero__platforms {
            margin-top: 40px;
        }
        .zmq-landing-v3 .zmq-hero__platforms-grid {
            grid-template-columns: repeat(7, minmax(0, 1fr));
            max-width: 600px;
            gap: 12px;
        }
        .zmq-landing-v3 .zmq-hero__platform {
            height: 64px;
            padding: 10px;
        }
        .zmq-landing-v3 .zmq-hero__platform img {
            max-height: 36px;
        }
    }

    /* ============================== Section 2: Large product shot ============================== */
    .zmq-landing-v3 .zmq-section-product {
        padding-top: 24px;
    }
    .zmq-landing-v3 .zmq-section-product__head {
        max-width: 760px;
        margin-bottom: 48px;
    }
    .zmq-landing-v3 .zmq-section-product__stage {
        max-width: 1180px;
        margin: 0 auto;
    }

    /* ============================== Section 3: Two-up ============================== */
    .zmq-landing-v3 .zmq-twoup {
        display: grid;
        gap: 32px;
        grid-template-columns: minmax(0, 1fr);
    }
    @media (min-width: 900px) {
        .zmq-landing-v3 .zmq-twoup {
            grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
            gap: 48px;
        }
    }
    .zmq-landing-v3 .zmq-card {
        background: var(--zmq-bone-tinted);
        border-radius: 12px;
        padding: 32px 24px 40px;
        position: relative;
    }
    .zmq-landing-v3 .zmq-card--copper-tint { background: var(--zmq-copper-tint-08); }
    .zmq-landing-v3 .zmq-card--verdigris-tint { background: var(--zmq-verdigris-tint-12); }
    .zmq-landing-v3 .zmq-card--madder-tint { background: var(--zmq-madder-tint-08); }
    .zmq-landing-v3 .zmq-card--navy-tint { background: var(--zmq-navy-tint-10); }
    .zmq-landing-v3 .zmq-card__stage-wrap {
        margin: 0 0 24px;
        padding: 12px 12px 20px;
    }
    .zmq-landing-v3 .zmq-card__h3 {
        font-family: var(--zmq-font-display);
        font-size: clamp(24px, 2.4vw, 30px);
        line-height: 1.2;
        margin: 0 0 12px;
        color: var(--zmq-ink);
    }
    .zmq-landing-v3 .zmq-card__body {
        font-size: 16px;
        line-height: 1.55;
        color: var(--zmq-ink);
        margin: 0 0 12px;
    }
    .zmq-landing-v3 .zmq-card__meta {
        font-family: var(--zmq-font-mono);
        font-size: 12px;
        color: var(--zmq-ink);
        margin: 0;
    }

    /* ============================== Section 4: Three-up ============================== */
    .zmq-landing-v3 .zmq-threeup {
        display: grid;
        gap: 24px;
        grid-template-columns: minmax(0, 1fr);
    }
    @media (min-width: 1180px) {
        .zmq-landing-v3 .zmq-threeup {
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 20px;
        }
    }

    /* Vertical spacing between two stacked grids (e.g. a second .zmq-twoup
       or .zmq-threeup row directly below the first). Shared utility so page
       rebuilds don't reach for inline margin. */
    .zmq-landing-v3 .zmq-grid-stack { margin-top: 24px; }

    /* ============================== Section 5: Integrations ============================== */
    .zmq-landing-v3 .zmq-integrations {
        background: var(--zmq-bone-tinted);
        border-radius: 12px;
        padding: 48px 32px;
    }
    .zmq-landing-v3 .zmq-integrations__grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }
    @media (min-width: 600px) { .zmq-landing-v3 .zmq-integrations__grid { grid-template-columns: repeat(4, 1fr); } }
    @media (min-width: 900px) { .zmq-landing-v3 .zmq-integrations__grid { grid-template-columns: repeat(8, 1fr); } }
    .zmq-landing-v3 .zmq-integration {
        background: var(--zmq-bone);
        border: 1px solid var(--zmq-slate-200);
        border-radius: 8px;
        padding: 16px;
        height: 76px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-family: var(--zmq-font-body);
        font-weight: 600;
        font-size: 13px;
    }
    .zmq-landing-v3 .zmq-integration img {
        max-height: 36px;
        max-width: 100%;
        object-fit: contain;
    }
    /* Real platform brand colours used here per the §5 exception in the
       founder's directive. Inside product chrome we use desaturated tints. */
    .zmq-landing-v3 .zmq-integration--tokopedia { color: #42b549; }
    .zmq-landing-v3 .zmq-integration--bukalapak { color: #e31e52; }

    /* ============================== Section 6: Use cases ============================== */
    .zmq-landing-v3 .zmq-usecases {
        display: grid;
        gap: 40px;
        grid-template-columns: 1fr;
    }
    @media (min-width: 900px) {
        .zmq-landing-v3 .zmq-usecases { grid-template-columns: 5fr 6fr; gap: 56px; align-items: center; }
    }
    .zmq-landing-v3 .zmq-usecases__tabs {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        margin: 0 0 24px;
    }
    .zmq-landing-v3 .zmq-usecases__tab {
        font-family: var(--zmq-font-mono);
        font-size: 11px;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        padding: 7px 12px;
        border: 1px solid var(--zmq-slate-200);
        border-radius: 999px;
        color: var(--zmq-slate-500);
        background: var(--zmq-bone);
    }
    .zmq-landing-v3 .zmq-usecases__tab--active {
        color: var(--zmq-bone);
        background: var(--zmq-navy);
        border-color: var(--zmq-navy);
    }
    .zmq-landing-v3 .zmq-usecases__h2 {
        font-family: var(--zmq-font-display);
        font-size: clamp(32px, 3.6vw, 44px);
        line-height: 1.1;
        margin: 0 0 16px;
        color: var(--zmq-ink);
    }
    .zmq-landing-v3 .zmq-usecases__body {
        font-size: 16px;
        line-height: 1.55;
        color: var(--zmq-ink);
        margin: 0 0 24px;
        max-width: 50ch;
    }
    .zmq-landing-v3 .zmq-usecases__photo-stage {
        position: relative;
        border-radius: 12px;
        overflow: visible;
    }
    .zmq-landing-v3 .zmq-usecases__photo {
        width: 100%;
        aspect-ratio: 3 / 4;
        object-fit: cover;
        border-radius: 8px;
        box-shadow: 0 16px 48px rgba(107, 98, 88, 0.14);
    }
    .zmq-landing-v3 .zmq-usecases__callout-wrap {
        position: absolute;
        z-index: 2;
    }
    .zmq-landing-v3 .zmq-usecases__callout-wrap--tr { top: 8%; right: -12px; }
    .zmq-landing-v3 .zmq-usecases__callout-wrap--br { bottom: 14%; right: -16px; }
    @media (max-width: 768px) {
        .zmq-landing-v3 .zmq-usecases__callout-wrap--tr { top: 4%; right: 8px; }
        .zmq-landing-v3 .zmq-usecases__callout-wrap--br { bottom: 8%; right: 8px; }
    }

    /* ============================== Section 7: Testimonials ============================== */
    .zmq-landing-v3 .zmq-testimonials {
        display: grid;
        grid-template-columns: 1fr;
        gap: 24px;
    }
    @media (min-width: 900px) {
        .zmq-landing-v3 .zmq-testimonials { grid-template-columns: repeat(3, 1fr); }
    }
    .zmq-landing-v3 .zmq-testimonial {
        background: var(--zmq-bone);
        border: 1px solid var(--zmq-slate-200);
        border-radius: 8px;
        padding: 28px 28px 24px;
        display: flex;
        flex-direction: column;
        gap: 16px;
    }
    .zmq-landing-v3 .zmq-testimonial__editorial {
        font-family: var(--zmq-font-mono);
        font-size: 11px;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: var(--zmq-copper);
        margin: 0;
    }
    .zmq-landing-v3 .zmq-testimonial__photo {
        width: 96px;
        height: 96px;
        border-radius: 8px;
        overflow: hidden;
    }
    .zmq-landing-v3 .zmq-testimonial__photo img {
        width: 100%;
        height: 100%;
        object-fit: contain;
        display: block;
    }
    .zmq-landing-v3 .zmq-testimonial__quote {
        font-family: var(--zmq-font-display);
        font-style: italic;
        font-size: 19px;
        line-height: 1.4;
        color: var(--zmq-ink);
        margin: 0;
    }
    .zmq-landing-v3 .zmq-testimonial__attribution {
        margin: auto 0 0;
        padding-top: 14px;
        border-top: 1px solid var(--zmq-slate-200);
        font-family: var(--zmq-font-body);
        font-size: 14px;
        color: var(--zmq-ink);
    }
    .zmq-landing-v3 .zmq-testimonial__attribution-meta {
        display: block;
        font-family: var(--zmq-font-mono);
        font-size: 12px;
        color: var(--zmq-slate-500);
        margin-top: 4px;
    }

    /* ============================== Section 8: Onboarding ============================== */
    .zmq-landing-v3 .zmq-onboarding {
        display: grid;
        gap: 32px;
        grid-template-columns: 1fr;
    }
    @media (min-width: 900px) {
        .zmq-landing-v3 .zmq-onboarding { grid-template-columns: 4fr 5fr; gap: 56px; }
    }
    .zmq-landing-v3 .zmq-onboarding__steps {
        display: grid;
        gap: 0;
    }
    .zmq-landing-v3 .zmq-step {
        display: grid;
        grid-template-columns: 56px 1fr;
        gap: 16px;
        padding: 20px 0;
        border-bottom: 1px solid var(--zmq-slate-200);
    }
    .zmq-landing-v3 .zmq-step:last-child { border-bottom: 0; }
    .zmq-landing-v3 .zmq-step__num {
        font-family: var(--zmq-font-mono);
        font-size: 14px;
        color: var(--zmq-slate-500);
        padding-top: 2px;
    }
    .zmq-landing-v3 .zmq-step__h4 {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        font-size: 16px;
        margin: 0 0 4px;
        color: var(--zmq-ink);
    }
    .zmq-landing-v3 .zmq-step__body {
        font-size: 15px;
        line-height: 1.55;
        color: var(--zmq-ink);
        margin: 0;
    }

    /* ============================== Section 9: Pricing ============================== */
    .zmq-landing-v3 .zmq-pricing {
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
    }
    @media (min-width: 768px) {
        .zmq-landing-v3 .zmq-pricing { grid-template-columns: repeat(3, 1fr); }
    }
    .zmq-landing-v3 .zmq-pricing__tier {
        background: var(--zmq-bone);
        border: 1px solid var(--zmq-slate-200);
        border-radius: 8px;
        padding: 28px 24px;
        display: flex;
        flex-direction: column;
        gap: 16px;
    }
    .zmq-landing-v3 .zmq-pricing__name {
        font-family: var(--zmq-font-display);
        font-size: 24px;
        line-height: 1.2;
        margin: 0;
        color: var(--zmq-ink);
    }
    .zmq-landing-v3 .zmq-pricing__sub {
        font-size: 15px;
        line-height: 1.55;
        color: var(--zmq-ink);
        margin: 0;
    }
    .zmq-landing-v3 .zmq-pricing__sub-meta {
        font-family: var(--zmq-font-mono);
        font-size: 11px;
        color: var(--zmq-slate-500);
        margin: 4px 0 0;
        text-transform: uppercase;
        letter-spacing: 0.04em;
    }
    .zmq-landing-v3 .zmq-pricing__cta { margin-top: auto; }

    /* ============================== Section 10: FAQ ============================== */
    .zmq-landing-v3 .zmq-faq {
        max-width: 880px;
    }
    .zmq-landing-v3 .zmq-faq__item {
        border-top: 1px solid var(--zmq-slate-200);
        padding: 24px 0;
    }
    .zmq-landing-v3 .zmq-faq__item:last-child { border-bottom: 1px solid var(--zmq-slate-200); }
    .zmq-landing-v3 .zmq-faq__q {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        font-size: 17px;
        margin: 0 0 6px;
        color: var(--zmq-ink);
    }
    .zmq-landing-v3 .zmq-faq__a {
        font-size: 15px;
        line-height: 1.55;
        color: var(--zmq-ink);
        margin: 0;
        max-width: 64ch;
    }

    /* ============================== Section 11: Closing CTA + peek ============================== */
    .zmq-landing-v3 .zmq-close {
        background: var(--zmq-navy-700);
        color: var(--zmq-bone);
        border-radius: 12px 12px 0 0;
        padding: 64px 32px 88px;
        text-align: center;
        margin: 32px auto 0;
        max-width: 1192px;
        position: relative;
        overflow: hidden;
    }
    .zmq-landing-v3 .zmq-close__h2 {
        font-family: var(--zmq-font-display);
        font-size: clamp(36px, 5vw, 56px);
        line-height: 1.05;
        margin: 0 0 18px;
        color: var(--zmq-bone);
    }
    .zmq-landing-v3 .zmq-close__sub {
        font-size: 17px;
        color: rgba(242, 239, 232, 0.86);
        margin: 0 auto 28px;
        max-width: 56ch;
    }
    .zmq-landing-v3 .zmq-close__caption {
        font-family: var(--zmq-font-mono);
        font-size: 11px;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        color: rgba(242, 239, 232, 0.62);
        margin: 16px 0 0;
    }
    .zmq-landing-v3 .zmq-peek {
        max-width: 1192px;
        margin: 0 auto;
        padding: 0 24px;
        margin-top: -64px;
        position: relative;
        z-index: 2;
    }
    .zmq-landing-v3 .zmq-peek .zmq-stage__fragment {
        max-height: 220px;
        overflow: hidden;
    }

    /* ============================== Section 13: Statement footer ============================== */
    .zmq-landing-v3 .zmq-statement {
        max-width: 1240px;
        margin: 80px auto 56px;
        padding: 0 24px;
        text-align: center;
    }
    .zmq-landing-v3 .zmq-statement__copy {
        font-family: var(--zmq-font-display);
        font-size: clamp(40px, 6vw, 80px);
        line-height: 1.05;
        margin: 0 0 24px;
        color: var(--zmq-ink);
        letter-spacing: -0.02em;
    }
    .zmq-landing-v3 .zmq-statement__period {
        color: var(--zmq-copper);
    }
    .zmq-landing-v3 .zmq-statement__caption {
        font-family: var(--zmq-font-mono);
        font-size: 11px;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: var(--zmq-slate-500);
        margin: 0;
    }

    /* ============================== Fragment: dashboard-hero ============================== */
    .zmq-landing-v3 .zmq-frag-dash {
        display: grid;
        grid-template-columns: 132px 1fr;
        font-size: 11px;
        line-height: 1.4;
        background: var(--zmq-bone);
        min-height: 460px;
    }
    .zmq-landing-v3 .zmq-frag-dash__rail {
        background: var(--zmq-navy);
        color: var(--zmq-bone);
        padding: 16px 0;
    }
    .zmq-landing-v3 .zmq-frag-dash__brand {
        display: flex;
        align-items: center;
        gap: 7px;
        padding: 0 14px 14px;
        border-bottom: 1px solid rgba(217, 211, 198, 0.18);
    }
    .zmq-landing-v3 .zmq-frag-dash__mark { width: 18px; height: 18px; }
    .zmq-landing-v3 .zmq-frag-dash__wordmark {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        font-size: 13px;
    }
    .zmq-landing-v3 .zmq-frag-dash__nav {
        list-style: none;
        margin: 12px 0 0;
        padding: 0;
    }
    .zmq-landing-v3 .zmq-frag-dash__nav-item {
        font-family: var(--zmq-font-body);
        font-size: 11px;
        padding: 7px 14px;
        color: rgba(242, 239, 232, 0.72);
        border-left: 2px solid transparent;
    }
    .zmq-landing-v3 .zmq-frag-dash__nav-item--active {
        color: var(--zmq-bone);
        border-left-color: var(--zmq-navy-300);
        background: rgba(90, 123, 160, 0.16);
    }
    .zmq-landing-v3 .zmq-frag-dash__main { padding: 16px 18px 20px; }
    .zmq-landing-v3 .zmq-frag-dash__top {
        display: flex;
        justify-content: space-between;
        align-items: flex-end;
        margin-bottom: 16px;
        border-bottom: 1px solid var(--zmq-slate-200);
        padding-bottom: 12px;
    }
    .zmq-landing-v3 .zmq-frag-dash__title {
        font-family: var(--zmq-font-display);
        font-size: 18px;
        margin: 0 0 2px;
        line-height: 1;
    }
    .zmq-landing-v3 .zmq-frag-dash__subtitle {
        font-family: var(--zmq-font-mono);
        font-size: 10px;
        color: var(--zmq-slate-500);
        margin: 0;
    }
    .zmq-landing-v3 .zmq-frag-dash__range {
        display: inline-flex;
        gap: 0;
        background: var(--zmq-bone-tinted);
        border-radius: 4px;
        padding: 2px;
    }
    .zmq-landing-v3 .zmq-frag-dash__range-tab {
        font-family: var(--zmq-font-mono);
        font-size: 10px;
        padding: 4px 8px;
        color: var(--zmq-slate-500);
        border-radius: 3px;
    }
    .zmq-landing-v3 .zmq-frag-dash__range-tab--active {
        background: var(--zmq-bone);
        color: var(--zmq-ink);
        box-shadow: 0 1px 2px rgba(107, 98, 88, 0.14);
    }
    .zmq-landing-v3 .zmq-frag-dash__kpis {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 8px;
        margin-bottom: 16px;
    }
    .zmq-landing-v3 .zmq-frag-dash__kpi {
        background: var(--zmq-bone-tinted);
        border-radius: 4px;
        padding: 10px 12px;
    }
    .zmq-landing-v3 .zmq-frag-dash__kpi-label {
        font-family: var(--zmq-font-body);
        font-size: 9px;
        color: var(--zmq-slate-500);
        text-transform: uppercase;
        letter-spacing: 0.04em;
        margin-bottom: 4px;
    }
    .zmq-landing-v3 .zmq-frag-dash__kpi-value {
        font-family: var(--zmq-font-mono);
        font-size: 18px;
        line-height: 1.1;
        color: var(--zmq-ink);
    }
    .zmq-landing-v3 .zmq-frag-dash__kpi-delta {
        font-family: var(--zmq-font-mono);
        font-size: 10px;
        color: var(--zmq-slate-500);
        margin-top: 2px;
    }
    .zmq-landing-v3 .zmq-frag-dash__kpi-delta--alert { color: var(--zmq-madder); }
    .zmq-landing-v3 .zmq-frag-dash__charts {
        display: grid;
        grid-template-columns: 1.4fr 1fr;
        gap: 12px;
        margin-bottom: 16px;
    }
    .zmq-landing-v3 .zmq-frag-dash__chart {
        background: var(--zmq-bone);
        border: 1px solid var(--zmq-slate-200);
        border-radius: 4px;
        padding: 10px 12px;
    }
    .zmq-landing-v3 .zmq-frag-dash__chart-head {
        display: flex;
        justify-content: space-between;
        align-items: baseline;
        margin-bottom: 8px;
    }
    .zmq-landing-v3 .zmq-frag-dash__chart-title {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        font-size: 11px;
        margin: 0;
    }
    .zmq-landing-v3 .zmq-frag-dash__chart-meta {
        font-family: var(--zmq-font-mono);
        font-size: 9px;
        color: var(--zmq-slate-500);
    }
    .zmq-landing-v3 .zmq-frag-dash__chart-tabs {
        display: flex;
        gap: 4px;
        margin-bottom: 8px;
        flex-wrap: wrap;
    }
    .zmq-landing-v3 .zmq-frag-dash__chip {
        font-family: var(--zmq-font-mono);
        font-size: 9px;
        padding: 2px 6px;
        background: var(--zmq-bone-tinted);
        border-radius: 2px;
        color: var(--zmq-slate-500);
    }
    .zmq-landing-v3 .zmq-frag-dash__chip--active {
        background: var(--zmq-navy);
        color: var(--zmq-bone);
    }
    .zmq-landing-v3 .zmq-frag-dash__chart-svg {
        width: 100%;
        height: 110px;
    }
    .zmq-landing-v3 .zmq-frag-dash__pressure {
        list-style: none;
        margin: 0;
        padding: 0;
        display: grid;
        gap: 6px;
    }
    .zmq-landing-v3 .zmq-frag-dash__pressure-row {
        display: grid;
        grid-template-columns: 1fr 60px 28px;
        gap: 8px;
        align-items: center;
        font-size: 10px;
    }
    .zmq-landing-v3 .zmq-frag-dash__pressure-name {
        color: var(--zmq-ink);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .zmq-landing-v3 .zmq-frag-dash__pressure-bar {
        background: var(--zmq-bone-tinted);
        height: 5px;
        border-radius: 2px;
        overflow: hidden;
    }
    .zmq-landing-v3 .zmq-frag-dash__pressure-fill { display: block; height: 100%; border-radius: 2px; }
    .zmq-landing-v3 .zmq-frag-dash__pressure-fill--alert { background: var(--zmq-madder); }
    .zmq-landing-v3 .zmq-frag-dash__pressure-fill--warn { background: var(--zmq-copper); }
    .zmq-landing-v3 .zmq-frag-dash__pressure-fill--ok { background: var(--zmq-verdigris); }
    .zmq-landing-v3 .zmq-frag-dash__pressure-days {
        font-family: var(--zmq-font-mono);
        font-size: 10px;
        text-align: right;
        color: var(--zmq-slate-500);
    }
    .zmq-landing-v3 .zmq-frag-dash__orders {
        background: var(--zmq-bone);
        border: 1px solid var(--zmq-slate-200);
        border-radius: 4px;
        overflow: hidden;
    }
    .zmq-landing-v3 .zmq-frag-dash__orders-head,
    .zmq-landing-v3 .zmq-frag-dash__orders-row {
        display: grid;
        grid-template-columns: 84px 78px 1fr 100px;
        gap: 12px;
        padding: 7px 12px;
        align-items: center;
        font-size: 10px;
    }
    .zmq-landing-v3 .zmq-frag-dash__orders-head {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        font-size: 9px;
        color: var(--zmq-slate-500);
        border-bottom: 1px solid var(--zmq-slate-200);
    }
    .zmq-landing-v3 .zmq-frag-dash__orders-row + .zmq-frag-dash__orders-row {
        border-top: 1px solid var(--zmq-slate-200);
    }
    .zmq-landing-v3 .zmq-frag-dash__orders-amount {
        text-align: right;
        font-family: var(--zmq-font-mono);
    }
    .zmq-landing-v3 .zmq-frag-dash__chip--shopee { background: var(--zmq-slate-200); color: var(--zmq-ink); padding: 2px 6px; border-radius: 2px; font-family: var(--zmq-font-mono); font-size: 9px; }
    .zmq-landing-v3 .zmq-frag-dash__chip--lazada { background: rgba(90, 123, 160, 0.30); color: var(--zmq-ink); padding: 2px 6px; border-radius: 2px; font-family: var(--zmq-font-mono); font-size: 9px; }
    .zmq-landing-v3 .zmq-frag-dash__chip--tiktok { background: rgba(14, 16, 20, 0.08); color: var(--zmq-ink); padding: 2px 6px; border-radius: 2px; font-family: var(--zmq-font-mono); font-size: 9px; }

    /* ============================== Fragment chips (shared) ============================== */
    .zmq-landing-v3 .zmq-frag-chip {
        display: inline-flex;
        align-items: center;
        font-family: var(--zmq-font-mono);
        font-size: 9px;
        padding: 1px 5px;
        border-radius: 3px;
        color: var(--zmq-ink);
        margin: 0 3px 2px 0;
        white-space: nowrap;
    }
    .zmq-landing-v3 .zmq-frag-chip--shopee { background: var(--zmq-slate-200); }
    .zmq-landing-v3 .zmq-frag-chip--lazada { background: rgba(90, 123, 160, 0.30); }
    .zmq-landing-v3 .zmq-frag-chip--tiktok { background: rgba(14, 16, 20, 0.08); }
    .zmq-landing-v3 .zmq-frag-chip--shopify { background: rgba(63, 107, 92, 0.20); }
    .zmq-landing-v3 .zmq-frag-chip--amazon { background: rgba(107, 98, 88, 0.18); }
    .zmq-landing-v3 .zmq-frag-chip--woo { background: rgba(107, 98, 88, 0.08); }
    .zmq-landing-v3 .zmq-frag-chip--insta { background: rgba(184, 106, 61, 0.10); }

    /* ============================== Fragment pins ============================== */
    .zmq-landing-v3 .zmq-frag-pin {
        font-family: var(--zmq-font-mono);
        font-size: 9px;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        padding: 3px 8px;
        border-radius: 999px;
    }
    .zmq-landing-v3 .zmq-frag-pin--ok { background: var(--zmq-verdigris-tint-12); color: var(--zmq-verdigris); }
    .zmq-landing-v3 .zmq-frag-pin--action { background: var(--zmq-copper-tint-08); color: var(--zmq-copper); }
    .zmq-landing-v3 .zmq-frag-pin--late { background: var(--zmq-madder-tint-08); color: var(--zmq-madder); }

    /* ============================== Fragment: inventory table ============================== */
    .zmq-landing-v3 .zmq-frag-table {
        font-size: 11px;
        line-height: 1.4;
    }
    .zmq-landing-v3 .zmq-frag-table__head,
    .zmq-landing-v3 .zmq-frag-table__row {
        display: grid;
        grid-template-columns: 70px 1fr 1.6fr 50px;
        gap: 10px;
        padding: 10px 14px;
        align-items: center;
    }
    .zmq-landing-v3 .zmq-frag-table__head {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        font-size: 10px;
        color: var(--zmq-slate-500);
        border-bottom: 1px solid var(--zmq-slate-200);
        background: var(--zmq-bone-tinted);
    }
    .zmq-landing-v3 .zmq-frag-table__row {
        border-bottom: 1px solid var(--zmq-slate-200);
        transition: background-color 200ms;
    }
    .zmq-landing-v3 .zmq-frag-table__row--dim { opacity: 0.55; }
    .zmq-landing-v3 .zmq-frag-table__row--focus { background: rgba(184, 106, 61, 0.04); }
    .zmq-landing-v3 .zmq-frag-table__col--stock { text-align: right; font-weight: 500; }

    /* ============================== Fragment: stock-channel matrix ============================== */
    .zmq-landing-v3 .zmq-frag-matrix {
        padding: 14px 16px;
    }
    .zmq-landing-v3 .zmq-frag-matrix__head,
    .zmq-landing-v3 .zmq-frag-matrix__row {
        display: grid;
        grid-template-columns: 1.2fr repeat(6, 1fr);
        align-items: center;
        gap: 3px;
        padding: 7px 0;
    }
    .zmq-landing-v3 .zmq-frag-matrix__head {
        font-family: var(--zmq-font-mono);
        font-size: 9px;
        color: var(--zmq-slate-500);
        text-transform: uppercase;
        letter-spacing: 0.04em;
        border-bottom: 1px solid var(--zmq-slate-200);
        margin-bottom: 6px;
    }
    .zmq-landing-v3 .zmq-frag-matrix__col-h { text-align: center; }
    .zmq-landing-v3 .zmq-frag-matrix__row + .zmq-frag-matrix__row { border-top: 1px dashed var(--zmq-slate-200); }
    .zmq-landing-v3 .zmq-frag-matrix__sku {
        display: flex;
        flex-direction: column;
        gap: 1px;
        font-size: 11px;
    }
    .zmq-landing-v3 .zmq-frag-matrix__sku-code { font-size: 9px; color: var(--zmq-slate-500); }
    .zmq-landing-v3 .zmq-frag-matrix__sku-name {
        color: var(--zmq-ink);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .zmq-landing-v3 .zmq-frag-matrix__cell {
        height: 24px;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: 3px;
    }
    .zmq-landing-v3 .zmq-frag-matrix__cell--ok { background: var(--zmq-verdigris-tint-12); color: var(--zmq-verdigris); }
    .zmq-landing-v3 .zmq-frag-matrix__cell--low { background: var(--zmq-copper-tint-08); color: var(--zmq-copper); }
    .zmq-landing-v3 .zmq-frag-matrix__cell--off { background: var(--zmq-bone-tinted); color: var(--zmq-slate-500); }

    /* ============================== Fragment: connect-oauth ============================== */
    .zmq-landing-v3 .zmq-frag-connect { padding: 16px 18px; font-size: 11px; }
    .zmq-landing-v3 .zmq-frag-connect__head {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 16px;
        gap: 8px;
    }
    .zmq-landing-v3 .zmq-frag-connect__title {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        font-size: 13px;
        color: var(--zmq-ink);
    }
    .zmq-landing-v3 .zmq-frag-connect__rail {
        list-style: none;
        margin: 0 0 18px;
        padding: 0;
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 6px;
        position: relative;
    }
    .zmq-landing-v3 .zmq-frag-connect__node {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 5px;
        text-align: center;
        position: relative;
    }
    /* connector line between nodes */
    .zmq-landing-v3 .zmq-frag-connect__node + .zmq-frag-connect__node::before {
        content: '';
        position: absolute;
        top: 11px;
        left: -50%;
        width: 100%;
        height: 1px;
        background: var(--zmq-slate-200);
        z-index: 0;
    }
    .zmq-landing-v3 .zmq-frag-connect__node-num {
        width: 22px;
        height: 22px;
        border-radius: 999px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 10px;
        background: var(--zmq-bone-tinted);
        color: var(--zmq-slate-500);
        border: 1px solid var(--zmq-slate-200);
        position: relative;
        z-index: 1;
    }
    .zmq-landing-v3 .zmq-frag-connect__node--done .zmq-frag-connect__node-num {
        background: var(--zmq-verdigris-tint-12);
        color: var(--zmq-verdigris);
        border-color: var(--zmq-verdigris);
    }
    .zmq-landing-v3 .zmq-frag-connect__node--active .zmq-frag-connect__node-num {
        background: var(--zmq-verdigris);
        color: var(--zmq-bone);
        border-color: var(--zmq-verdigris);
    }
    .zmq-landing-v3 .zmq-frag-connect__node-label {
        font-family: var(--zmq-font-body);
        font-size: 10px;
        color: var(--zmq-ink);
        line-height: 1.2;
    }
    .zmq-landing-v3 .zmq-frag-connect__regions-label {
        font-family: var(--zmq-font-body);
        font-size: 9px;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        color: var(--zmq-slate-500);
        display: block;
        margin-bottom: 8px;
    }
    .zmq-landing-v3 .zmq-frag-connect__regions-grid {
        display: flex;
        flex-wrap: wrap;
        gap: 5px;
    }
    .zmq-landing-v3 .zmq-frag-connect__region {
        font-size: 10px;
        padding: 3px 7px;
        border-radius: 3px;
        background: var(--zmq-bone-tinted);
        color: var(--zmq-ink);
        border: 1px solid var(--zmq-slate-200);
    }

    /* ============================== Fragment: sku-binding ============================== */
    .zmq-landing-v3 .zmq-frag-bind { padding: 16px 18px; font-size: 11px; }
    .zmq-landing-v3 .zmq-frag-bind__sources {
        display: flex;
        gap: 10px;
        margin-bottom: 10px;
    }
    .zmq-landing-v3 .zmq-frag-bind__source {
        flex: 1;
        background: var(--zmq-bone-tinted);
        border: 1px solid var(--zmq-slate-200);
        border-radius: 4px;
        padding: 8px 10px;
        display: flex;
        flex-direction: column;
        gap: 4px;
    }
    .zmq-landing-v3 .zmq-frag-bind__sku {
        font-size: 10px;
        color: var(--zmq-slate-500);
    }
    .zmq-landing-v3 .zmq-frag-bind__arrow {
        display: flex;
        justify-content: center;
        color: var(--zmq-slate-500);
        margin: 0 0 10px;
    }
    .zmq-landing-v3 .zmq-frag-bind__master {
        background: var(--zmq-navy);
        color: var(--zmq-bone);
        border-radius: 4px;
        padding: 10px 12px;
        display: flex;
        flex-direction: column;
        gap: 2px;
        margin-bottom: 12px;
    }
    .zmq-landing-v3 .zmq-frag-bind__master-label {
        font-family: var(--zmq-font-body);
        font-size: 9px;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        opacity: 0.72;
    }
    .zmq-landing-v3 .zmq-frag-bind__master-name {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        font-size: 12px;
    }
    .zmq-landing-v3 .zmq-frag-bind__master-sku {
        font-size: 10px;
        opacity: 0.86;
    }
    .zmq-landing-v3 .zmq-frag-bind__coverage {
        display: flex;
        flex-wrap: wrap;
        gap: 5px;
    }
    .zmq-landing-v3 .zmq-frag-bind__cov {
        font-family: var(--zmq-font-mono);
        font-size: 9px;
        padding: 3px 7px;
        border-radius: 3px;
    }
    .zmq-landing-v3 .zmq-frag-bind__cov--ok {
        background: var(--zmq-verdigris-tint-12);
        color: var(--zmq-verdigris);
    }
    .zmq-landing-v3 .zmq-frag-bind__cov--off {
        background: var(--zmq-bone-tinted);
        color: var(--zmq-slate-500);
    }

    /* ============================== Fragment: orders ============================== */
    .zmq-landing-v3 .zmq-frag-orders { font-size: 11px; }
    .zmq-landing-v3 .zmq-frag-orders__head,
    .zmq-landing-v3 .zmq-frag-orders__row {
        display: grid;
        grid-template-columns: 64px 72px minmax(0, 1fr) 84px 42px;
        gap: 8px;
        padding: 9px 14px 9px 18px;
        align-items: center;
    }
    .zmq-landing-v3 .zmq-frag-orders__col--customer {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .zmq-landing-v3 .zmq-frag-orders__head {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        font-size: 10px;
        color: var(--zmq-slate-500);
        border-bottom: 1px solid var(--zmq-slate-200);
        background: var(--zmq-bone-tinted);
    }
    .zmq-landing-v3 .zmq-frag-orders__row {
        border-bottom: 1px solid var(--zmq-slate-200);
        position: relative;
    }
    .zmq-landing-v3 .zmq-frag-orders__row--late::before {
        content: '';
        position: absolute;
        left: 0; top: 0; bottom: 0;
        width: 3px;
        background: var(--zmq-madder);
    }
    .zmq-landing-v3 .zmq-frag-orders__col--age {
        text-align: right;
        color: var(--zmq-slate-500);
    }

    /* ============================== Fragment: forecast ============================== */
    .zmq-landing-v3 .zmq-frag-forecast { padding: 14px 16px; }
    .zmq-landing-v3 .zmq-frag-forecast__head {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        margin-bottom: 10px;
        gap: 8px;
    }
    .zmq-landing-v3 .zmq-frag-forecast__title-block {
        min-width: 0;
        flex: 1 1 auto;
    }
    .zmq-landing-v3 .zmq-frag-forecast__title {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        font-size: 12px;
        line-height: 1.25;
        margin: 0;
        color: var(--zmq-ink);
    }
    .zmq-landing-v3 .zmq-frag-forecast__sub {
        font-family: var(--zmq-font-mono);
        font-size: 10px;
        color: var(--zmq-slate-500);
        margin: 4px 0 0;
    }
    .zmq-landing-v3 .zmq-frag-forecast__sku {
        font-size: 10px;
        color: var(--zmq-slate-500);
    }
    .zmq-landing-v3 .zmq-frag-forecast__svg {
        width: 100%;
        height: 110px;
        margin: 0 0 12px;
    }
    .zmq-landing-v3 .zmq-frag-forecast__foot {
        display: flex;
        gap: 18px;
        flex-wrap: wrap;
    }
    .zmq-landing-v3 .zmq-frag-forecast__legend {
        font-family: var(--zmq-font-mono);
        font-size: 10px;
        color: var(--zmq-slate-500);
        display: inline-flex;
        align-items: center;
        gap: 6px;
    }
    .zmq-landing-v3 .zmq-frag-forecast__legend-dot {
        width: 8px;
        height: 8px;
        border-radius: 999px;
        display: inline-block;
    }
    .zmq-landing-v3 .zmq-frag-forecast__legend-dot--navy { background: var(--zmq-navy); }
    .zmq-landing-v3 .zmq-frag-forecast__legend-dot--copper { background: var(--zmq-copper); }

    /* ============================== Fragment: inbox ============================== */
    .zmq-landing-v3 .zmq-frag-inbox {
        display: grid;
        grid-template-columns: 0.9fr 1.3fr;
        font-size: 11px;
        min-height: 260px;
    }
    .zmq-landing-v3 .zmq-frag-inbox__list {
        background: var(--zmq-bone-tinted);
        border-right: 1px solid var(--zmq-slate-200);
    }
    .zmq-landing-v3 .zmq-frag-inbox__convo {
        display: grid;
        grid-template-columns: auto 1fr auto;
        gap: 6px;
        padding: 8px 10px;
        border-bottom: 1px solid var(--zmq-slate-200);
        align-items: center;
    }
    .zmq-landing-v3 .zmq-frag-inbox__convo--unread { background: rgba(184, 106, 61, 0.05); }
    .zmq-landing-v3 .zmq-frag-inbox__convo--active { background: var(--zmq-bone); border-left: 2px solid var(--zmq-navy); }
    .zmq-landing-v3 .zmq-frag-inbox__convo-body {
        display: flex;
        flex-direction: column;
        gap: 1px;
        min-width: 0;
    }
    .zmq-landing-v3 .zmq-frag-inbox__convo-name {
        font-weight: 600;
        font-size: 10px;
        color: var(--zmq-ink);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .zmq-landing-v3 .zmq-frag-inbox__convo-snippet {
        font-size: 10px;
        color: var(--zmq-slate-500);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .zmq-landing-v3 .zmq-frag-inbox__convo-time {
        font-size: 9px;
        color: var(--zmq-slate-500);
    }
    .zmq-landing-v3 .zmq-frag-inbox__thread { padding: 12px 14px; display: flex; flex-direction: column; gap: 6px; min-width: 0; }
    .zmq-landing-v3 .zmq-frag-inbox__thread-head {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        padding-bottom: 8px;
        border-bottom: 1px solid var(--zmq-slate-200);
    }
    .zmq-landing-v3 .zmq-frag-inbox__thread-name {
        display: block;
        font-weight: 600;
        font-size: 13px;
    }
    .zmq-landing-v3 .zmq-frag-inbox__thread-meta {
        font-size: 10px;
        color: var(--zmq-slate-500);
    }
    .zmq-landing-v3 .zmq-frag-inbox__msg {
        max-width: 80%;
        padding: 8px 12px;
        border-radius: 6px;
        font-size: 11.5px;
        line-height: 1.45;
    }
    .zmq-landing-v3 .zmq-frag-inbox__msg--in {
        background: var(--zmq-bone-tinted);
        align-self: flex-start;
    }
    .zmq-landing-v3 .zmq-frag-inbox__msg--out {
        background: var(--zmq-navy);
        color: var(--zmq-bone);
        align-self: flex-end;
    }

    /* ============================== Sr-only ============================== */
    .zmq-landing-v3 .zmq-sr {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0,0,0,0);
        white-space: nowrap;
        border: 0;
    }

    /* ============================== Mobile (<= 768): fragment adaptations ==============================
       UI fragments are designed at desktop scale. On mobile we strip
       structural chrome (sidebar nav, secondary columns) and let the data
       payload: the KPIs, the late row, the chart, the chat thread: read
       at a comfortable scale on a phone. Intent is preserved; density is
       traded for legibility. */
    @media (max-width: 768px) {
        .zmq-landing-v3 .zmq-card { padding: 24px 18px 32px; }
        .zmq-landing-v3 .zmq-card__stage-wrap { padding: 8px 8px 16px; margin-bottom: 18px; }
        .zmq-landing-v3 .zmq-card__h3 { font-size: 22px; }
        .zmq-landing-v3 .zmq-card__body { font-size: 15px; }

        /* Dashboard: drop the sidebar rail entirely. The Phase C
           portal also collapses the rail to a top-bar at narrow widths
           so this matches future product behaviour. */
        .zmq-landing-v3 .zmq-frag-dash {
            grid-template-columns: 1fr;
            min-height: auto;
        }
        .zmq-landing-v3 .zmq-frag-dash__rail { display: none; }
        .zmq-landing-v3 .zmq-frag-dash__main { padding: 14px 14px 16px; }
        .zmq-landing-v3 .zmq-frag-dash__kpis {
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 6px;
        }
        .zmq-landing-v3 .zmq-frag-dash__charts {
            grid-template-columns: 1fr;
            gap: 10px;
        }
        .zmq-landing-v3 .zmq-frag-dash__orders-head,
        .zmq-landing-v3 .zmq-frag-dash__orders-row {
            grid-template-columns: 70px 70px minmax(0, 1fr) 80px;
            gap: 8px;
            font-size: 9px;
        }

        /* Inventory: hide the long product-name column: SKU + chips
           + stock tells the story. */
        .zmq-landing-v3 .zmq-frag-table__head,
        .zmq-landing-v3 .zmq-frag-table__row {
            grid-template-columns: 56px minmax(0, 1fr) 44px;
            gap: 8px;
            padding: 9px 12px;
        }
        .zmq-landing-v3 .zmq-frag-table__col--name { display: none; }

        /* Orders: drop the status pin column. The madder left edge on
           the late row + the callout already carry the "overdue" signal. */
        .zmq-landing-v3 .zmq-frag-orders__head,
        .zmq-landing-v3 .zmq-frag-orders__row {
            grid-template-columns: 60px 60px minmax(0, 1fr) 40px;
            gap: 6px;
            padding: 9px 12px 9px 16px;
        }
        .zmq-landing-v3 .zmq-frag-orders__col--status { display: none; }

        /* Inbox: stack the channel list above the open thread. */
        .zmq-landing-v3 .zmq-frag-inbox {
            grid-template-columns: 1fr;
            min-height: auto;
        }
        .zmq-landing-v3 .zmq-frag-inbox__list {
            border-right: 0;
            border-bottom: 1px solid var(--zmq-slate-200);
            display: grid;
            grid-template-columns: 1fr;
        }
        .zmq-landing-v3 .zmq-frag-inbox__convo:nth-child(n+3) { display: none; }

        /* Matrix: 6 channels still fit but with smaller cells. Drop the
           SKU code prefix; product name carries enough context. */
        .zmq-landing-v3 .zmq-frag-matrix {
            padding: 12px 10px;
        }
        .zmq-landing-v3 .zmq-frag-matrix__head,
        .zmq-landing-v3 .zmq-frag-matrix__row {
            grid-template-columns: 1fr repeat(6, minmax(0, 1fr));
            gap: 2px;
            padding: 6px 0;
        }
        .zmq-landing-v3 .zmq-frag-matrix__head { font-size: 8px; }
        .zmq-landing-v3 .zmq-frag-matrix__sku-code { display: none; }
        .zmq-landing-v3 .zmq-frag-matrix__sku-name { font-size: 10px; }
        .zmq-landing-v3 .zmq-frag-matrix__cell { height: 22px; }

        /* Callouts: smaller, anchored just inside the fragment edge so
           they don't clip against the section padding on phones. */
        .zmq-landing-v3 .zmq-stage__callout-wrap--tr { top: 6px; right: 6px; }
        .zmq-landing-v3 .zmq-stage__callout-wrap--br { bottom: 6px; right: 6px; }
        .zmq-landing-v3 .zmq-stage__callout-wrap--tl { top: 6px; left: 6px; }
        .zmq-landing-v3 .zmq-stage__callout-wrap--bl { bottom: 6px; left: 6px; }
        .zmq-landing-v3 .zmq-callout {
            min-width: auto;
            padding: 6px 10px;
        }
        .zmq-landing-v3 .zmq-callout__value { font-size: 12px; }
        .zmq-landing-v3 .zmq-callout__label { font-size: 9px; }

        /* Use-cases callouts pull tighter on the photo edge. */
        .zmq-landing-v3 .zmq-usecases__callout-wrap--tr { top: 12px; right: 12px; }
        .zmq-landing-v3 .zmq-usecases__callout-wrap--br { bottom: 16px; right: 12px; }

        /* Closing CTA peek: the dashboard graphic drops the rail too. */
        .zmq-landing-v3 .zmq-peek .zmq-stage__fragment { max-height: 160px; }

        /* Hero h1 size cap so it doesn't dominate the screen at 360-414. */
        .zmq-landing-v3 .zmq-hero { padding: 56px 24px 48px; }
        .zmq-landing-v3 .zmq-hero__h1 { font-size: 44px; }

        /* Statement footer: slightly smaller wordmark so it fits in two
           lines without clipping. */
        .zmq-landing-v3 .zmq-statement { margin: 56px auto 40px; }
    }

    /* ============================== Resources / blog landing ============================== */
    /* Dynamic blog-landing surface (/resources). The blog cards are REAL
       content, not UI-as-graphic. JS-targeted hooks (.filter-item,
       .filter-checkbox, .blog-card, .sidebar-col, #filterOverlay, etc.)
       keep their original names; these .zmq-resources-* / .zmq-blog-card*
       rules are layered alongside them. */
    .zmq-landing-v3 .zmq-resources-layout { display: grid; gap: 32px; grid-template-columns: 1fr; }
    @media (min-width: 992px) {
        .zmq-landing-v3 .zmq-resources-layout { grid-template-columns: 260px 1fr; gap: 40px; }
    }

    /* Sidebar */
    .zmq-landing-v3 .zmq-resources-sidebar {
        background: var(--zmq-bone);
        border: 1px solid var(--zmq-slate-200);
        border-radius: 12px;
        padding: 24px;
        height: fit-content;
    }
    .zmq-landing-v3 .zmq-resources-sidebar__title {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        font-size: 13px;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        color: var(--zmq-slate-500);
        margin: 0 0 16px;
    }
    .zmq-landing-v3 .zmq-resources-filter { list-style: none; margin: 0 0 8px; padding: 0; }
    .zmq-landing-v3 .zmq-resources-filter__item {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 7px 0;
        cursor: pointer;
        font-size: 14px;
        color: var(--zmq-slate-500);
    }
    .zmq-landing-v3 .zmq-resources-filter__item.active { color: var(--zmq-ink); font-weight: 600; }
    .zmq-landing-v3 .zmq-resources-filter__box {
        width: 16px;
        height: 16px;
        border: 1.5px solid var(--zmq-slate-200);
        border-radius: 4px;
        flex-shrink: 0;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .zmq-landing-v3 .zmq-resources-filter__item.active .zmq-resources-filter__box {
        background: var(--zmq-navy);
        border-color: var(--zmq-navy);
    }
    /* The whole row is a label wrapping a real (visually hidden, keyboard-focusable) checkbox. */
    .zmq-landing-v3 .zmq-resources-filter__label {
        display: flex;
        align-items: center;
        gap: 10px;
        width: 100%;
        cursor: pointer;
    }
    .zmq-landing-v3 .zmq-resources-filter__input {
        position: absolute;
        width: 16px;
        height: 16px;
        margin: 0;
        opacity: 0;
        cursor: pointer;
    }
    .zmq-landing-v3 .zmq-resources-filter__input:focus-visible + .zmq-resources-filter__box {
        outline: 2px solid var(--zmq-copper);
        outline-offset: 2px;
    }
    .zmq-landing-v3 .zmq-resources-reset {
        font-family: var(--zmq-font-body);
        font-size: 13px;
        color: var(--zmq-slate-500);
        text-decoration: none;
        display: inline-block;
        background: none;
        border: none;
        padding: 0;
        cursor: pointer;
    }
    .zmq-landing-v3 .zmq-resources-reset:hover { color: var(--zmq-navy); }
    .zmq-landing-v3 .zmq-resources-reset:focus-visible {
        outline: 2px solid var(--zmq-copper);
        outline-offset: 2px;
    }

    /* Blog card grid */
    .zmq-landing-v3 .zmq-resources-grid { display: grid; gap: 24px; grid-template-columns: 1fr; }
    @media (min-width: 640px) { .zmq-landing-v3 .zmq-resources-grid { grid-template-columns: repeat(2, 1fr); } }
    @media (min-width: 1180px) { .zmq-landing-v3 .zmq-resources-grid { grid-template-columns: repeat(3, 1fr); } }
    .zmq-landing-v3 .zmq-blog-card {
        background: var(--zmq-bone);
        border: 1px solid var(--zmq-slate-200);
        border-radius: 12px;
        overflow: hidden;
        height: 100%;
        display: flex;
        flex-direction: column;
        transition: transform 200ms ease, box-shadow 200ms ease;
    }
    .zmq-landing-v3 .zmq-blog-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 16px 40px rgba(107, 98, 88, 0.12);
    }
    .zmq-landing-v3 .zmq-blog-card__visual {
        height: 180px;
        display: flex;
        align-items: center;
        justify-content: center;
        overflow: hidden;
        padding: 20px;
        text-align: center;
    }
    .zmq-landing-v3 .zmq-blog-card__visual img { width: 100%; height: 100%; object-fit: cover; }
    .zmq-landing-v3 .zmq-blog-card__visual-text {
        color: var(--zmq-bone);
        font-family: var(--zmq-font-display);
        font-size: 22px;
        line-height: 1.15;
    }
    /* Category colour fills carry the #483 token mapping. */
    .zmq-landing-v3 .zmq-blog-card__visual--navy { background: var(--zmq-navy); }
    .zmq-landing-v3 .zmq-blog-card__visual--slate200 { background: var(--zmq-slate-200); }
    .zmq-landing-v3 .zmq-blog-card__visual--slate200 .zmq-blog-card__visual-text { color: var(--zmq-ink); }
    .zmq-landing-v3 .zmq-blog-card__visual--slate500 { background: var(--zmq-slate-500); }
    .zmq-landing-v3 .zmq-blog-card__visual--verdigris { background: var(--zmq-verdigris); }
    .zmq-landing-v3 .zmq-blog-card__visual--ink { background: var(--zmq-ink); }
    .zmq-landing-v3 .zmq-blog-card__visual--madder { background: var(--zmq-madder); }
    .zmq-landing-v3 .zmq-blog-card__body { padding: 18px 20px 20px; flex-grow: 1; display: flex; flex-direction: column; }
    .zmq-landing-v3 .zmq-blog-card__meta {
        font-family: var(--zmq-font-mono);
        font-size: 11px;
        color: var(--zmq-slate-500);
        text-transform: uppercase;
        letter-spacing: 0.04em;
        margin-bottom: 12px;
    }
    .zmq-landing-v3 .zmq-blog-card__author { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; gap: 8px; }
    .zmq-landing-v3 .zmq-blog-card__author-box { display: flex; align-items: center; gap: 8px; min-width: 0; }
    .zmq-landing-v3 .zmq-blog-card__avatar {
        width: 30px;
        height: 30px;
        border-radius: 999px;
        object-fit: cover;
        display: flex;
        align-items: center;
        justify-content: center;
        background: var(--zmq-slate-200);
        color: var(--zmq-ink);
        font-weight: 600;
        font-size: 11px;
        flex-shrink: 0;
    }
    .zmq-landing-v3 .zmq-blog-card__author-name {
        font-size: 13px;
        font-weight: 600;
        color: var(--zmq-ink);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .zmq-landing-v3 .zmq-blog-card__tag {
        font-family: var(--zmq-font-mono);
        font-size: 11px;
        color: var(--zmq-navy);
        background: var(--zmq-bone-tinted);
        padding: 3px 9px;
        border-radius: 999px;
        white-space: nowrap;
        flex-shrink: 0;
    }
    .zmq-landing-v3 .zmq-blog-card__title {
        font-family: var(--zmq-font-body);
        font-weight: 600;
        font-size: 14px;
        line-height: 1.4;
        color: var(--zmq-ink);
        margin: 0;
    }
    .zmq-landing-v3 .zmq-resources-empty {
        text-align: center;
        color: var(--zmq-slate-500);
        padding: 48px 0;
        font-size: 15px;
    }

    /* Mobile filter drawer. Ported from the retired page-local <style>.
       The slide-in drawer + overlay are behaviour-bound to the existing
       <script> (.sidebar-col, .sidebar-open, #filterOverlay, .filter-overlay,
       #mobileFilterCard, #sidebarCloseBtn). Desktop shows the sidebar inline. */
    .zmq-landing-v3 .zmq-resources-mobile-header { display: none; }
    .zmq-landing-v3 .zmq-resources-sidebar-close { display: none; }
    .zmq-landing-v3 .filter-overlay {
        display: none;
        position: fixed;
        inset: 0;
        background: rgba(14, 16, 20, 0.4);
        z-index: 1000;
        opacity: 0;
        transition: opacity 300ms ease;
    }
    @media (max-width: 991.98px) {
        .zmq-landing-v3 .zmq-resources-mobile-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            width: 100%;
            margin-bottom: 24px;
            background: var(--zmq-bone);
            border: 1px solid var(--zmq-slate-200);
            border-radius: 12px;
            padding: 14px 20px;
            cursor: pointer;
            font: inherit;
            text-align: left;
            color: var(--zmq-ink);
        }
        .zmq-landing-v3 .zmq-resources-mobile-header:focus-visible {
            outline: 2px solid var(--zmq-copper);
            outline-offset: 2px;
        }
        .zmq-landing-v3 .zmq-resources-mobile-header span {
            font-size: 13px;
            font-weight: 700;
            color: var(--zmq-ink);
        }
        .zmq-landing-v3 .zmq-resources-mobile-header__toggle {
            display: flex;
            color: var(--zmq-navy);
        }
        .zmq-landing-v3 .filter-overlay { display: block; visibility: hidden; pointer-events: none; }
        .zmq-landing-v3 .filter-overlay.active { opacity: 1; visibility: visible; pointer-events: all; }
        .zmq-landing-v3 .sidebar-col {
            position: fixed;
            top: 0;
            left: -320px;
            width: 300px;
            max-width: 300px;
            height: 100vh;
            z-index: 1050;
            overflow-y: auto;
            transition: left 300ms ease;
            padding: 0;
        }
        .zmq-landing-v3 .sidebar-col.sidebar-open { left: 0; }
        .zmq-landing-v3 .zmq-resources-sidebar-close {
            display: block;
            position: absolute;
            top: 16px;
            right: 20px;
            font-size: 28px;
            line-height: 1;
            color: var(--zmq-ink);
            background: none;
            border: none;
            z-index: 1060;
            cursor: pointer;
        }
    }

    /* Reduced-motion: still the blog-card hover lift + sidebar/overlay transitions. */
    @media (prefers-reduced-motion: reduce) {
        .zmq-landing-v3 .zmq-blog-card,
        .zmq-landing-v3 .sidebar-col,
        .zmq-landing-v3 .filter-overlay {
            transition: none;
        }
        .zmq-landing-v3 .zmq-blog-card:hover { transform: none; }
    }

    /* ============================================================ */
    /* /talk-to-sales — Zeemarq lead form (#797 follow-up).           */
    /* Two-column on >=900px: hero left, form card right. Wraps to    */
    /* single column under 900px. Type / tokens inherit from         */
    /* .zmq-landing-v3 by wrapping the page in both classes.         */
    /* Copper budget: one composition element only — the headline    */
    /* highlight pill. The submit CTA is Navy.                       */
    /* ============================================================ */
    .zmq-tts {
        background: var(--zmq-bone);
        min-height: 60vh;
        padding: 64px 24px 96px;
    }

    .zmq-tts__wrap {
        max-width: 1200px;
        margin: 0 auto;
        display: grid;
        grid-template-columns: 1fr;
        gap: 48px;
        align-items: start;
    }

    @media (min-width: 900px) {
        .zmq-tts__wrap {
            grid-template-columns: 1.05fr 1fr;
            gap: 64px;
            padding-top: 24px;
        }
    }

    .zmq-tts__hero-eyebrow {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        font-family: var(--zmq-font-mono);
        font-size: 12px;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        color: var(--zmq-slate-500);
        margin: 0 0 16px;
    }
    .zmq-tts__hero-eyebrow::before {
        content: '';
        width: 16px;
        height: 1px;
        background: var(--zmq-slate-500);
    }

    .zmq-tts__hero h1 {
        font-family: var(--zmq-font-display);
        font-weight: 400;
        color: var(--zmq-ink);
        font-size: clamp(40px, 4.6vw, 60px);
        line-height: 1.08;
        margin: 0 0 24px;
        letter-spacing: -0.01em;
    }

    .zmq-tts__highlight {
        display: inline-block;
        background: rgba(184, 106, 61, 0.32);
        color: var(--zmq-ink);
        padding: 0 10px;
        border-radius: 4px;
        box-decoration-break: clone;
        -webkit-box-decoration-break: clone;
    }

    .zmq-tts__hero-sub {
        font-family: var(--zmq-font-body);
        font-size: 18px;
        line-height: 1.55;
        color: var(--zmq-ink);
        max-width: 520px;
        margin: 0 0 32px;
    }

    .zmq-tts__bullets {
        list-style: none;
        padding: 0;
        margin: 0 0 32px;
        display: flex;
        flex-direction: column;
        gap: 12px;
        max-width: 520px;
    }
    .zmq-tts__bullets li {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 14px 20px 14px 16px;
        background: #FFFFFF;
        border: 1px solid var(--zmq-slate-200);
        border-radius: 999px;
        font-family: var(--zmq-font-body);
        font-size: 15px;
        color: var(--zmq-ink);
    }
    .zmq-tts__bullets svg {
        flex-shrink: 0;
        width: 22px;
        height: 22px;
    }

    .zmq-tts__trust {
        margin-top: 8px;
        padding-top: 24px;
        border-top: 1px solid var(--zmq-slate-200);
        display: flex;
        flex-wrap: wrap;
        gap: 24px 32px;
        font-family: var(--zmq-font-mono);
        font-size: 12px;
        letter-spacing: 0.1em;
        text-transform: uppercase;
        color: var(--zmq-slate-500);
        max-width: 520px;
    }

    .zmq-tts__card {
        background: #FFFFFF;
        border: 1px solid var(--zmq-slate-200);
        border-radius: 14px;
        padding: 32px 28px 28px;
    }

    @media (min-width: 600px) {
        .zmq-tts__card { padding: 40px 36px 32px; }
    }

    .zmq-tts__card-h {
        font-family: var(--zmq-font-display);
        font-weight: 400;
        font-size: 24px;
        color: var(--zmq-ink);
        margin: 0 0 4px;
    }
    .zmq-tts__card-sub {
        font-family: var(--zmq-font-body);
        font-size: 14px;
        color: var(--zmq-slate-500);
        margin: 0 0 24px;
    }

    .zmq-tts__grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 18px;
    }
    @media (min-width: 600px) {
        .zmq-tts__grid {
            grid-template-columns: 1fr 1fr;
            gap: 18px 20px;
        }
        .zmq-tts__field--wide { grid-column: 1 / -1; }
    }

    .zmq-tts__field { display: flex; flex-direction: column; gap: 6px; }
    .zmq-tts__label {
        font-family: var(--zmq-font-body);
        font-size: 13px;
        font-weight: 500;
        color: var(--zmq-ink);
    }
    .zmq-tts__label .zmq-tts__req {
        color: var(--zmq-copper);
        margin-left: 2px;
    }
    .zmq-tts__hint {
        font-family: var(--zmq-font-body);
        font-size: 12px;
        color: var(--zmq-slate-500);
    }
    .zmq-tts__input,
    .zmq-tts__select,
    .zmq-tts__textarea {
        font-family: var(--zmq-font-body);
        font-size: 15px;
        color: var(--zmq-ink);
        background: #FFFFFF;
        border: 1px solid var(--zmq-slate-200);
        border-radius: 8px;
        padding: 12px 14px;
        line-height: 1.4;
        width: 100%;
        transition: border-color 120ms ease, box-shadow 120ms ease;
    }
    .zmq-tts__textarea { min-height: 110px; resize: vertical; }
    .zmq-tts__input:hover,
    .zmq-tts__select:hover,
    .zmq-tts__textarea:hover {
        border-color: var(--zmq-navy-300);
    }
    .zmq-tts__input:focus,
    .zmq-tts__select:focus,
    .zmq-tts__textarea:focus {
        outline: 2px solid var(--zmq-copper);
        outline-offset: 2px;
        border-color: var(--zmq-navy);
    }
    .zmq-tts__select {
        appearance: none;
        -webkit-appearance: none;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%230E1014' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M1 1.5L6 6.5L11 1.5'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: right 14px center;
        background-size: 12px 8px;
        padding-right: 38px;
    }

    .zmq-tts__channels {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
    }
    .zmq-tts__chip {
        position: relative;
    }
    .zmq-tts__chip input {
        position: absolute;
        opacity: 0;
        pointer-events: none;
    }
    .zmq-tts__chip span {
        display: inline-flex;
        align-items: center;
        font-family: var(--zmq-font-body);
        font-size: 13px;
        color: var(--zmq-ink);
        background: var(--zmq-bone);
        border: 1px solid var(--zmq-slate-200);
        border-radius: 999px;
        padding: 8px 14px;
        cursor: pointer;
        transition: background 120ms ease, border-color 120ms ease;
    }
    .zmq-tts__chip:hover span {
        border-color: var(--zmq-navy-300);
    }
    .zmq-tts__chip input:checked + span {
        background: var(--zmq-navy);
        border-color: var(--zmq-navy);
        color: var(--zmq-bone);
    }
    .zmq-tts__chip input:focus-visible + span {
        outline: 2px solid var(--zmq-copper);
        outline-offset: 2px;
    }

    .zmq-tts__error {
        font-family: var(--zmq-font-body);
        font-size: 13px;
        color: var(--zmq-madder);
        margin-top: 4px;
    }
    .zmq-tts__error-summary {
        background: #FBEFEC;
        border: 1px solid var(--zmq-madder);
        border-radius: 8px;
        padding: 14px 16px;
        margin-bottom: 20px;
        font-family: var(--zmq-font-body);
        font-size: 14px;
        color: var(--zmq-madder);
    }
    .zmq-tts__error-summary ul { margin: 6px 0 0; padding-left: 20px; }

    .zmq-tts__submit-row {
        margin-top: 28px;
        display: flex;
        flex-direction: column;
        gap: 14px;
        align-items: flex-start;
    }
    .zmq-tts__legal {
        font-family: var(--zmq-font-body);
        font-size: 12px;
        color: var(--zmq-slate-500);
        line-height: 1.5;
        margin: 0;
        max-width: 480px;
    }
    .zmq-tts__legal a { color: var(--zmq-navy); text-decoration: underline; }

    .zmq-tts__honeypot {
        position: absolute;
        left: -9999px;
        width: 1px;
        height: 1px;
        opacity: 0;
        pointer-events: none;
    }

    /* Success panel — replaces the form after a 302-with-flash. */
    .zmq-tts__success {
        background: #FFFFFF;
        border: 1px solid var(--zmq-verdigris);
        border-radius: 14px;
        padding: 40px 36px;
        max-width: 560px;
    }
    .zmq-tts__success-h {
        font-family: var(--zmq-font-display);
        font-weight: 400;
        font-size: 28px;
        color: var(--zmq-ink);
        margin: 0 0 12px;
    }
    .zmq-tts__success p {
        font-family: var(--zmq-font-body);
        font-size: 15px;
        color: var(--zmq-ink);
        margin: 0 0 12px;
        line-height: 1.55;
    }
    .zmq-tts__success-mono {
        font-family: var(--zmq-font-mono);
        font-size: 12px;
        letter-spacing: 0.1em;
        text-transform: uppercase;
        color: var(--zmq-verdigris);
        margin-top: 16px;
    }
