/* ============================================================
   LegalnyMedyk — Landing Page Styles (v4 — sky-blue + gold, logo-aligned)
   landing.css — loaded only on / and /zostan-autorem/
   Never modify main.css — all new rules go here.
   ============================================================ */

/* ---- Design tokens (sky-blue + warm-gold theme, logo-aligned) ---- */
:root {
    /* Primary — sky blue (logo-aligned, medical) */
    --lm-primary: #27A3DC;
    --lm-primary-soft: #4FBEEC;
    --lm-primary-dark: #1A86B8;
    --lm-primary-tint: #D9F0FB;
    --lm-primary-gradient: linear-gradient(135deg, #4FBEEC 0%, #27A3DC 50%, #1A86B8 100%);

    /* Accent — warm gold (highlighter, premium classic) */
    --lm-accent: #F4BD37;
    --lm-accent-soft: #FBE08C;
    --lm-accent-dark: #C99820;

    /* Ink — deep navy instead of pure black */
    --lm-ink: #0B1F3A;
    --lm-ink-2: #14294A;
    --lm-ink-3: #1F3658;
    --lm-ink-4: #4A5C7A;
    --lm-ink-5: #7A8AA5;

    /* Neutral */
    --lm-paper: #FFFFFF;
    --lm-bg-soft: #F1F5F9;
    --lm-border: #E2E8F0;

    /* Semantic — success / danger / error */
    --lm-success: #2E7D32;
    --lm-danger: #DC2626;
    --lm-danger-soft: rgba(220, 38, 38, 0.10);
    --lm-error: #FCA5A5;
    --lm-error-soft: rgba(252, 165, 165, 0.12);
    --lm-error-border: rgba(252, 165, 165, 0.32);

    /* Highlight — driven by --hl-stroke (mask) and --hl-marker-bg (wash) */
    --hl-stroke: var(--lm-accent);
    --hl-marker-bg: var(--lm-primary-tint);

    /* Radii / shadows / spacing */
    --lm-radius-sm: 10px;
    --lm-radius: 16px;
    --lm-radius-lg: 28px;
    --lm-radius-xl: 40px;
    --lm-shadow-sm: 0 1px 2px rgba(11, 31, 58, 0.05), 0 2px 8px rgba(11, 31, 58, 0.05);
    --lm-shadow: 0 6px 20px rgba(11, 31, 58, 0.08), 0 1px 3px rgba(11, 31, 58, 0.05);
    --lm-shadow-lg: 0 24px 60px rgba(11, 31, 58, 0.16), 0 4px 16px rgba(11, 31, 58, 0.08);
    --lm-section-y: 110px;
    --lm-section-y-mobile: 64px;
    --lm-container: 1180px;
}

/* ---- Reduced motion ---- */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
    }
}

/* ---- Highlight draw animation ---- */
@keyframes hl-draw {
    from { clip-path: inset(0 100% 0 0); }
    to   { clip-path: inset(0 0% 0 0); }
}

/* ============================================================
   Page-level override
   ============================================================ */
body.landing-page {
    background: var(--lm-paper);
    color: var(--lm-ink);
    font-family: 'Montserrat', system-ui, -apple-system, "Segoe UI", sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
body.landing-page .main-content { padding: 0; margin: 0; }

/* Default footer (slim) hidden — we render footer_rich */
body.landing-page > footer.footer { display: none; }

/* ---- Skip link ---- */
.skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    z-index: 9999;
    background: var(--lm-ink);
    color: var(--lm-accent);
    padding: 12px 16px;
    font-weight: 700;
    font-size: 0.9rem;
    text-decoration: none;
    border-radius: 0 0 8px 0;
}
.skip-link:focus {
    left: 0;
    outline: 3px solid var(--lm-accent);
    outline-offset: 2px;
}

.lm-hp { position: absolute; left: -9999px; opacity: 0; pointer-events: none; }

/* ============================================================
   GLOBAL focus-visible
   ============================================================ */
.landing-page a:focus-visible,
.landing-page button:focus-visible,
.landing-page input:focus-visible,
.landing-page textarea:focus-visible,
.landing-page [tabindex]:focus-visible,
.landing-page details summary:focus-visible {
    outline: 3px solid var(--lm-primary);
    outline-offset: 2px;
    border-radius: 4px;
}

/* ============================================================
   SECTION wrapper
   ============================================================ */
.landing-section {
    padding: var(--lm-section-y) 0;
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}
.landing-section.is-visible { opacity: 1; transform: translateY(0); }
.landing-hero { opacity: 1; transform: none; }

.landing-page .container,
.landing-section > .container,
.landing-hero__inner.container {
    max-width: var(--lm-container);
    margin: 0 auto;
    padding: 0 24px;
}

/* Section headings */
.landing-section__heading {
    text-align: center;
    margin-bottom: 56px;
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
}
.landing-section__eyebrow {
    display: inline-flex;
    align-items: center;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--lm-ink-4);
    margin-bottom: 14px;
}
.landing-section__stage {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 26px;
    height: 26px;
    padding: 0 8px;
    margin-right: 10px;
    font-size: 0.78rem;
    font-weight: 800;
    color: var(--lm-ink, #0F0F10);
    background: var(--lm-accent, #F4BD37);
    border-radius: 999px;
    letter-spacing: 0;
    vertical-align: middle;
}
.landing-section__title {
    font-size: clamp(1.8rem, 3.4vw, 2.6rem);
    font-weight: 800;
    color: var(--lm-ink);
    line-height: 1.18;
    letter-spacing: -0.01em;
    margin: 0 0 14px;
}

/* ---- .hl — marker wash + wavy underline (token-driven) ---- */
.landing-section__title .hl,
.hl {
    position: relative;
    display: inline-block;
    z-index: 0;
    padding: 0 0.1em;
    color: var(--lm-primary);
}
.hl::before {
    content: "";
    position: absolute;
    inset: 14% -4% 14% -4%;
    background: var(--hl-marker-bg);
    z-index: -1;
    border-radius: 60% 30% 50% 40% / 40% 50% 30% 60%;
    transform: rotate(-1deg) skew(-2deg);
    pointer-events: none;
}
.hl::after {
    content: "";
    position: absolute;
    left: -2%;
    right: -2%;
    bottom: -10px;
    height: 10px;
    background-color: var(--hl-stroke);
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 220 12' preserveAspectRatio='none'%3E%3Cpath d='M3 8 Q 25 2%2C 50 7 T 100 7 T 150 6 T 200 8 Q 210 9%2C 217 6' fill='none' stroke='black' stroke-width='3' stroke-linecap='round'/%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 220 12' preserveAspectRatio='none'%3E%3Cpath d='M3 8 Q 25 2%2C 50 7 T 100 7 T 150 6 T 200 8 Q 210 9%2C 217 6' fill='none' stroke='black' stroke-width='3' stroke-linecap='round'/%3E%3C/svg%3E");
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    animation: hl-draw 0.6s ease-out both;
    pointer-events: none;
}

/* Variant for blue/dark sections — only the two driving vars + text color */
.landing-hero__title .hl,
.landing-newsletter__title .hl {
    color: var(--lm-paper);
    --hl-stroke: var(--lm-accent-soft);
    --hl-marker-bg: rgba(255, 255, 255, 0.18);
}

.landing-section__lead {
    font-size: 1.02rem;
    color: var(--lm-ink-4);
    line-height: 1.7;
    max-width: 640px;
    margin: 0 auto;
}

.landing-section__cta-wrap {
    text-align: center;
    margin-top: 48px;
}

/* ============================================================
   CTA BUTTONS (pill style)
   ============================================================ */
.btn-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 26px;
    border-radius: 999px;
    font-size: 0.95rem;
    font-weight: 700;
    font-family: inherit;
    text-decoration: none;
    cursor: pointer;
    border: 1.5px solid transparent;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.18s ease, box-shadow 0.2s ease;
    line-height: 1;
    white-space: nowrap;
}
.btn-cta--primary {
    background: var(--lm-ink);
    color: var(--lm-paper);
    border-color: var(--lm-ink);
}
.btn-cta--primary:hover {
    background: var(--lm-paper);
    color: var(--lm-ink);
    border-color: var(--lm-ink);
    transform: translateY(-1px);
    box-shadow: var(--lm-shadow);
}
/* Override for blue-bg sections (hero, newsletter) */
.landing-hero .btn-cta--primary,
.landing-newsletter .btn-cta--primary {
    background: var(--lm-paper);
    color: var(--lm-primary);
    border-color: var(--lm-paper);
}
.landing-hero .btn-cta--primary:hover,
.landing-newsletter .btn-cta--primary:hover {
    background: var(--lm-accent);
    color: var(--lm-ink);
    border-color: var(--lm-accent);
    transform: translateY(-1px);
    box-shadow: var(--lm-shadow);
}
.btn-cta--ghost {
    background: transparent;
    color: var(--lm-ink);
    border-color: var(--lm-ink);
}
.btn-cta--ghost:hover {
    background: var(--lm-ink);
    color: var(--lm-paper);
    transform: translateY(-1px);
}
/* Ghost override for blue-bg sections */
.landing-hero .btn-cta--ghost,
.landing-newsletter .btn-cta--ghost {
    color: var(--lm-paper);
    border-color: var(--lm-paper);
}
.landing-hero .btn-cta--ghost:hover,
.landing-newsletter .btn-cta--ghost:hover {
    background: var(--lm-paper);
    color: var(--lm-primary);
}
.btn-cta--lg { padding: 17px 34px; font-size: 1rem; }
.btn-cta--icon-leading svg { margin-right: 4px; }

/* ============================================================
   HERO — sky-blue gradient background with mockup
   ============================================================ */
.landing-hero {
    background: var(--lm-primary-gradient);
    position: relative;
    padding: 64px 0 80px;
    overflow: hidden;
}
.landing-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 8% 18%, rgba(255, 255, 255, 0.28) 0, transparent 24%),
        radial-gradient(circle at 92% 6%, rgba(251, 224, 140, 0.34) 0, transparent 26%),
        radial-gradient(circle at 50% 110%, rgba(11, 31, 58, 0.08) 0, transparent 42%);
    pointer-events: none;
}
.landing-hero__inner {
    position: relative;
    z-index: 1;
    text-align: center;
    max-width: 880px;
    margin: 0 auto;
}
.landing-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255, 255, 255, 0.15);
    border: 1px solid rgba(255, 255, 255, 0.25);
    color: var(--lm-paper);
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-bottom: 22px;
}
.landing-hero__eyebrow .dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--lm-accent);
}
.landing-hero__title {
    font-size: clamp(2.2rem, 5.6vw, 4.1rem);
    font-weight: 800;
    line-height: 1.04;
    letter-spacing: -0.025em;
    color: var(--lm-paper);
    margin: 0 0 22px;
}
.landing-hero__lead {
    font-size: clamp(1rem, 1.4vw, 1.15rem);
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.6;
    max-width: 640px;
    margin: 0 auto 32px;
    font-weight: 500;
}
.landing-hero__actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 12px;
}
.landing-hero__bullets {
    list-style: none;
    padding: 0;
    margin: 28px 0 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 16px 32px;
    font-size: 0.92rem;
    color: rgba(255, 255, 255, 0.9);
}
.landing-hero__bullets li {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
}
.landing-hero__bullets li::before {
    content: "✓";
    width: 18px; height: 18px;
    background: var(--lm-paper);
    color: var(--lm-primary);
    border-radius: 50%;
    font-size: 11px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
}

/* Hero mockup (decorative app preview) */
.landing-hero__mockup {
    position: relative;
    margin: 60px auto 0;
    max-width: 920px;
    aspect-ratio: 16 / 10;
    background: var(--lm-ink);
    border-radius: var(--lm-radius-lg);
    box-shadow: 0 30px 80px rgba(11, 31, 58, 0.5), 0 8px 24px rgba(11, 31, 58, 0.28);
    overflow: hidden;
    border: 6px solid var(--lm-ink);
}
.landing-hero__mockup-bar {
    background: var(--lm-ink-2);
    height: 30px;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 0 14px;
}
.landing-hero__mockup-bar span {
    width: 11px; height: 11px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
}
.landing-hero__mockup-bar span:nth-child(1) { background: #FF5F57; }
.landing-hero__mockup-bar span:nth-child(2) { background: #FEBC2E; }
.landing-hero__mockup-bar span:nth-child(3) { background: #28C840; }
.landing-hero__mockup-body {
    background: var(--lm-paper);
    height: calc(100% - 30px);
    display: grid;
    grid-template-columns: 220px 1fr;
}
.landing-hero__mockup-side {
    background: var(--lm-bg-soft);
    border-right: 1px solid var(--lm-border);
    padding: 18px 14px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.landing-hero__mockup-side .row {
    height: 12px;
    background: var(--lm-border);
    border-radius: 4px;
}
.landing-hero__mockup-side .row.active {
    background: var(--lm-primary);
}
.landing-hero__mockup-side .row.short { width: 60%; }
.landing-hero__mockup-side .row.medium { width: 80%; }
.landing-hero__mockup-main {
    padding: 22px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: auto 1fr;
    gap: 16px;
}
.landing-hero__mockup-main .stat {
    background: var(--lm-bg-soft);
    border-radius: 12px;
    padding: 12px 14px;
    border: 1px solid var(--lm-border);
}
.landing-hero__mockup-main .stat .v {
    font-size: 1.4rem; font-weight: 800; color: var(--lm-ink);
    line-height: 1;
}
.landing-hero__mockup-main .stat .l {
    font-size: 0.62rem; font-weight: 600; color: var(--lm-ink-5);
    margin-top: 6px; letter-spacing: 0.04em; text-transform: uppercase;
}
.landing-hero__mockup-main .chart {
    grid-column: 1 / -1;
    background: var(--lm-bg-soft);
    border-radius: 12px;
    border: 1px solid var(--lm-border);
    padding: 16px;
    display: flex;
    align-items: flex-end;
    gap: 10px;
    min-height: 110px;
}
.landing-hero__mockup-main .chart .bar {
    flex: 1;
    background: var(--lm-primary);
    border-radius: 4px 4px 0 0;
    opacity: 0.85;
}
.landing-hero__mockup-main .chart .bar:nth-child(1) { height: 38%; }
.landing-hero__mockup-main .chart .bar:nth-child(2) { height: 65%; }
.landing-hero__mockup-main .chart .bar:nth-child(3) { height: 50%; background: var(--lm-accent); }
.landing-hero__mockup-main .chart .bar:nth-child(4) { height: 85%; }
.landing-hero__mockup-main .chart .bar:nth-child(5) { height: 70%; }
.landing-hero__mockup-main .chart .bar:nth-child(6) { height: 95%; background: var(--lm-accent); }
.landing-hero__mockup-main .chart .bar:nth-child(7) { height: 80%; }
.landing-hero__mockup-badge {
    position: absolute;
    top: 18%;
    right: -22px;
    background: var(--lm-ink);
    color: var(--lm-accent);
    padding: 14px 18px;
    border-radius: 14px;
    font-weight: 800;
    font-size: 0.85rem;
    box-shadow: var(--lm-shadow-lg);
    transform: rotate(4deg);
    border: 2px solid var(--lm-accent);
}
.landing-hero__mockup-badge small {
    display: block;
    font-size: 0.65rem;
    color: rgba(255, 255, 255, 0.7);
    font-weight: 600;
    margin-top: 2px;
}

/* ============================================================
   HERO mockup — 3-card cluster (overlapping app previews)
   ============================================================ */
.landing-hero__mockup--cluster {
    background: transparent;
    border: none;
    border-radius: 0;
    box-shadow: none;
    overflow: visible;
    aspect-ratio: auto;
    height: 460px;
    max-width: 920px;
}

.landing-hero__app-card {
    position: absolute;
    width: 340px;
    height: 320px;
    background: var(--lm-paper);
    border: 1px solid var(--lm-border);
    border-radius: 14px;
    overflow: hidden;
    box-shadow:
        0 28px 60px rgba(11, 31, 58, 0.18),
        0 12px 24px rgba(11, 31, 58, 0.10);
    transition: transform 0.45s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
}

.landing-hero__app-card .app-card__bar {
    height: 28px;
    background: var(--lm-bg-soft);
    border-bottom: 1px solid var(--lm-border);
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 0 12px;
    flex-shrink: 0;
}
.landing-hero__app-card .app-card__bar > span:not(.app-card__bar-label) {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--lm-border);
}
.landing-hero__app-card .app-card__bar > span:nth-child(1) { background: #FF5F57; }
.landing-hero__app-card .app-card__bar > span:nth-child(2) { background: #FEBC2E; }
.landing-hero__app-card .app-card__bar > span:nth-child(3) { background: #28C840; }
.landing-hero__app-card .app-card__bar-label {
    margin-left: auto;
    font-size: 0.6rem;
    font-weight: 700;
    color: var(--lm-ink-5);
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.landing-hero__app-card .app-card__body {
    padding: 14px 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow: hidden;
    background: var(--lm-paper);
    min-height: 0;
}

/* Diagonal cascade — overlapping stack (back-to-front: feed → experts → shop) */
.landing-hero__app-card--feed {
    top: 0;
    left: 0;
    transform: rotate(-3deg);
    z-index: 1;
}
.landing-hero__app-card--experts {
    top: 70px;
    left: 290px;
    transform: rotate(1deg);
    z-index: 2;
    box-shadow:
        0 32px 70px rgba(11, 31, 58, 0.20),
        0 14px 28px rgba(11, 31, 58, 0.11);
}
.landing-hero__app-card--shop {
    top: 140px;
    left: 580px;
    transform: rotate(-2deg);
    z-index: 3;
    box-shadow:
        0 40px 80px rgba(11, 31, 58, 0.24),
        0 18px 36px rgba(11, 31, 58, 0.14);
}

/* Hover — subtle cascade spread (elegant, not dramatic) */
.landing-hero__mockup--cluster:hover .landing-hero__app-card--feed {
    transform: translate(-18px, -10px) rotate(-5deg);
}
.landing-hero__mockup--cluster:hover .landing-hero__app-card--experts {
    transform: translateY(-6px) rotate(1deg);
}
.landing-hero__mockup--cluster:hover .landing-hero__app-card--shop {
    transform: translate(18px, 10px) rotate(-3deg);
}

/* Avatar gradient placeholders */
.app-card__avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    flex-shrink: 0;
}
.app-card__avatar--g1 { background: linear-gradient(135deg, #4FBEEC, #1A86B8); }
.app-card__avatar--g2 { background: linear-gradient(135deg, #F4BD37, #E8821A); }
.app-card__avatar--g3 { background: linear-gradient(135deg, #34D399, #047857); }
.app-card__avatar--g4 { background: linear-gradient(135deg, #A78BFA, #6D28D9); }
.app-card__avatar--g5 { background: linear-gradient(135deg, #F472B6, #BE185D); }

/* CARD 1 — Feed-specific */
.app-card__post-head {
    display: flex;
    align-items: center;
    gap: 10px;
}
.app-card__post-meta { line-height: 1.2; min-width: 0; }
.app-card__post-author {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--lm-ink);
}
.app-card__post-time {
    font-size: 0.64rem;
    color: var(--lm-ink-5);
    margin-top: 2px;
}
.app-card__post-title {
    font-size: 0.92rem;
    font-weight: 800;
    color: var(--lm-ink);
    margin: 4px 0 0;
    line-height: 1.3;
    letter-spacing: -0.005em;
}
.app-card__post-body {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.app-card__post-body span {
    height: 7px;
    background: var(--lm-bg-soft);
    border-radius: 3px;
}
.app-card__post-body span.w-70 { width: 70%; }
.app-card__chips {
    display: flex;
    gap: 5px;
    margin-top: 2px;
}
.app-card__chip {
    font-size: 0.6rem;
    font-weight: 600;
    color: var(--lm-primary);
    background: var(--lm-primary-tint);
    padding: 3px 8px;
    border-radius: 999px;
}
.app-card__reactions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: auto;
    padding-top: 10px;
    border-top: 1px solid var(--lm-border);
    font-size: 0.7rem;
    color: var(--lm-ink-4);
    font-weight: 600;
}
.app-card__reaction {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.app-card__reaction svg { color: var(--lm-ink-5); }
.app-card__reaction:first-child svg { color: #DC2626; }
.app-card__reaction--mute {
    margin-left: auto;
    color: var(--lm-primary);
    font-weight: 700;
}

/* CARD 2 — Experts-specific (center, in front) */
.app-card__experts-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.app-card__title {
    margin: 0;
    font-size: 0.85rem;
    font-weight: 800;
    color: var(--lm-ink);
}
.app-card__pulse {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #34D399;
    box-shadow: 0 0 0 4px rgba(52, 211, 153, 0.18);
}
.app-card__experts-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-top: 4px;
}
.app-card__expert {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 9px;
    background: var(--lm-bg-soft);
    border-radius: 9px;
    min-width: 0;
}
.app-card__expert .app-card__avatar {
    width: 26px;
    height: 26px;
}
.app-card__expert > div:not(.app-card__avatar) {
    min-width: 0;
    flex: 1;
}
.app-card__expert-name {
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--lm-ink);
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.app-card__expert-role {
    font-size: 0.58rem;
    color: var(--lm-ink-5);
    margin-top: 1px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.app-card__experts-footer {
    margin-top: auto;
    padding-top: 10px;
    border-top: 1px solid var(--lm-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.68rem;
    font-weight: 600;
    color: var(--lm-ink-5);
}
.app-card__link {
    color: var(--lm-primary);
    font-weight: 700;
}

/* CARD 3 — Shop-specific */
.app-card__product-thumb {
    width: 100%;
    height: 88px;
    background: linear-gradient(135deg, var(--lm-bg-soft) 0%, #DCE7F0 100%);
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--lm-primary);
    position: relative;
    flex-shrink: 0;
}
.app-card__product-badge {
    position: absolute;
    top: 8px;
    right: 8px;
    background: linear-gradient(135deg, #F4BD37, #E8821A);
    color: var(--lm-ink);
    font-size: 0.56rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    padding: 3px 7px;
    border-radius: 999px;
    box-shadow: 0 4px 10px rgba(244, 189, 55, 0.4);
}
.app-card__product-title {
    margin: 6px 0 0;
    font-size: 0.92rem;
    font-weight: 800;
    color: var(--lm-ink);
    line-height: 1.25;
    letter-spacing: -0.005em;
}
.app-card__product-desc {
    margin: 0;
    font-size: 0.72rem;
    color: var(--lm-ink-5);
    line-height: 1.5;
}
.app-card__product-meta {
    margin-top: auto;
    padding-top: 10px;
    border-top: 1px solid var(--lm-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.app-card__product-price .value {
    display: block;
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--lm-ink);
    letter-spacing: -0.02em;
    line-height: 1;
}
.app-card__product-price .label {
    display: block;
    font-size: 0.58rem;
    color: var(--lm-ink-5);
    margin-top: 3px;
}
.app-card__product-btn {
    background: var(--lm-primary);
    color: var(--lm-paper);
    border: none;
    border-radius: 8px;
    padding: 8px 14px;
    font-size: 0.72rem;
    font-weight: 800;
    cursor: default;
    pointer-events: none;
    font-family: inherit;
}

/* ============================================================
   Mockup cards v2 — wireframe-fidelity to real /feed/, /products/, /feed/author/
   ============================================================ */

/* Body modifier: flush content (no padding, layout fills card) */
.landing-hero__app-card .app-card__body--flush {
    padding: 0;
    gap: 0;
}

/* ---------- CARD 1: Feed wireframe ---------- */
.feed-mini__topbar {
    height: 28px;
    background: var(--lm-primary);
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 10px;
    flex-shrink: 0;
    box-shadow: 0 1px 4px rgba(11, 31, 58, 0.08);
}
.feed-mini__logo {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}
.feed-mini__logo svg { display: block; }
.feed-mini__nav-list {
    display: flex;
    align-items: center;
    gap: 9px;
}
.feed-mini__nav {
    position: relative;
    font-size: 0.54rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.78);
    letter-spacing: 0.01em;
    padding: 4px 0;
    line-height: 1.2;
}
.feed-mini__nav--active {
    color: #fff;
    font-weight: 700;
}
.feed-mini__nav--active::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -2px;
    height: 1.5px;
    background: var(--lm-accent);
    border-radius: 1px;
}
.feed-mini__topbar-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-left: auto;
}
.feed-mini__icon-btn {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.feed-mini__icon-btn svg { display: block; }
.feed-mini__avatar--mini {
    width: 16px;
    height: 16px;
    border: 1.5px solid #fff;
}
.feed-mini__page {
    flex: 1;
    background: #F2F5F8;
    display: grid;
    grid-template-columns: 28% 1fr 19%;
    gap: 5px;
    padding: 6px;
    min-height: 0;
    overflow: hidden;
}
.feed-mini__rail-left {
    display: flex;
    flex-direction: column;
    gap: 5px;
    min-width: 0;
}
.feed-mini__card {
    background: var(--lm-paper);
    border: 1px solid var(--lm-border);
    border-radius: 6px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 1px 2px rgba(11, 31, 58, 0.03);
}
.feed-mini__card-header {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 5px 7px 4px;
    font-size: 0.5rem;
    font-weight: 700;
    color: var(--lm-ink);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}
.feed-mini__star {
    color: var(--lm-accent);
    font-size: 0.6rem;
    line-height: 1;
}
.feed-mini__card-body {
    padding: 3px 5px 6px;
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}
.feed-mini__card-body--cats { gap: 2px; }
.feed-mini__sb-row {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 1px 2px;
    min-width: 0;
}
.feed-mini__cat-row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 4px;
    padding: 2px 4px;
    border-radius: 3px;
    background: var(--lm-bg-soft);
    min-width: 0;
}
.feed-mini__cat-name {
    font-size: 0.5rem;
    font-weight: 600;
    color: var(--lm-ink);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
    line-height: 1.3;
}
.feed-mini__cat-count {
    font-size: 0.45rem;
    font-weight: 700;
    color: var(--lm-primary);
    flex-shrink: 0;
    font-variant-numeric: tabular-nums;
}
.feed-mini__col {
    display: flex;
    flex-direction: column;
    gap: 5px;
    min-width: 0;
}
.feed-mini__filters {
    display: flex;
    align-items: center;
    gap: 4px;
}
.feed-mini__filter {
    font-size: 0.5rem;
    font-weight: 600;
    color: var(--lm-ink-4);
    background: var(--lm-paper);
    border: 1px solid var(--lm-border);
    padding: 2px 7px;
    border-radius: 999px;
    line-height: 1.4;
}
.feed-mini__filter--active {
    background: var(--lm-primary);
    border-color: var(--lm-primary);
    color: #fff;
}
.feed-mini__search-icon {
    margin-left: auto;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--lm-paper);
    border: 1px solid var(--lm-border);
    color: var(--lm-ink-5);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.feed-mini__search-icon svg { display: block; }
.feed-mini__post {
    background: var(--lm-paper);
    border: 1px solid var(--lm-border);
    border-radius: 6px;
    padding: 7px 8px 6px;
    display: flex;
    flex-direction: column;
    gap: 5px;
    box-shadow: 0 1px 2px rgba(11, 31, 58, 0.03);
}
.feed-mini__post-head {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
}
.feed-mini__post-meta {
    display: flex;
    flex-direction: column;
    line-height: 1.15;
    min-width: 0;
    flex: 1;
}
.feed-mini__post-time {
    font-size: 0.45rem;
    font-weight: 500;
    color: var(--lm-ink-5);
    margin-top: 1px;
    letter-spacing: 0.01em;
}
.feed-mini__post-foot {
    display: flex;
    align-items: center;
    gap: 8px;
    padding-top: 4px;
    border-top: 1px solid var(--lm-border-2);
    color: var(--lm-ink-5);
}
.feed-mini__post-foot .feed-mini__post-react:first-child { color: #DC2626; }
.feed-mini__post-react svg { display: block; }
.feed-mini__avatar {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    flex-shrink: 0;
    overflow: hidden;
    background: linear-gradient(135deg, #4FBEEC, #1A86B8);
}
.feed-mini__avatar--md {
    width: 18px;
    height: 18px;
}
.feed-mini__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 22%;
    display: block;
}
.feed-mini__avatar--g1 { background: linear-gradient(135deg, #4FBEEC, #1A86B8); }
.feed-mini__avatar--g2 { background: linear-gradient(135deg, #F4BD37, #E8821A); }
.feed-mini__avatar--g3 { background: linear-gradient(135deg, #34D399, #047857); }
.feed-mini__avatar--g4 { background: linear-gradient(135deg, #A78BFA, #6D28D9); }

/* Real text (replaces placeholder lines) */
.feed-mini__sb-title-text {
    font-size: 0.5rem;
    font-weight: 700;
    color: var(--lm-ink);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 3px;
    line-height: 1.2;
}
.feed-mini__sb-name {
    font-size: 0.52rem;
    font-weight: 600;
    color: var(--lm-ink);
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
    min-width: 0;
}
.feed-mini__post-name {
    font-size: 0.55rem;
    font-weight: 700;
    color: var(--lm-ink);
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
    min-width: 0;
}
.feed-mini__post-snippet {
    font-size: 0.52rem;
    color: var(--lm-ink-4);
    line-height: 1.45;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.feed-mini__post-author {
    flex: 1;
    height: 4px;
    background: var(--lm-ink-3);
    border-radius: 2px;
    opacity: 0.4;
}
.feed-mini__post-author--60 { max-width: 60%; }
.feed-mini__post-body {
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.feed-mini__line {
    height: 4px;
    background: var(--lm-border);
    border-radius: 2px;
}
.feed-mini__line--80 { width: 80%; }
.feed-mini__rail-right {
    background: var(--lm-paper);
    border: 1px solid var(--lm-border);
    border-radius: 5px;
    padding: 5px;
    overflow: hidden;
}
.feed-mini__ad {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #1A86B8 0%, #4FBEEC 100%);
    border-radius: 4px;
    position: relative;
    min-height: 80px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 6px 5px;
}
.feed-mini__ad-label {
    position: absolute;
    top: 3px;
    left: 4px;
    font-size: 0.42rem;
    font-weight: 700;
    color: #fff;
    background: rgba(0, 0, 0, 0.45);
    padding: 1px 4px;
    border-radius: 2px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    z-index: 2;
}
.feed-mini__ad-content {
    display: flex;
    flex-direction: column;
    gap: 1px;
    color: #fff;
    z-index: 1;
    line-height: 1.15;
}
.feed-mini__ad-brand {
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: -0.005em;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.18);
}
.feed-mini__ad-tagline {
    font-size: 0.46rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.88);
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.18);
}

/* ---------- CARD 2: Author profile wireframe ---------- */
.app-card__body--author {
    padding: 14px 14px 12px;
    gap: 9px;
}
.author-mini__hero {
    display: flex;
    align-items: center;
    gap: 11px;
}
.author-mini__avatar {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    flex-shrink: 0;
    border: 2px solid var(--lm-paper);
    box-shadow: 0 2px 8px rgba(11, 31, 58, 0.12);
    overflow: hidden;
    background: linear-gradient(135deg, #4FBEEC, #1A86B8);
}
.author-mini__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 20%;
    display: block;
}
.author-mini__avatar--g3 { background: linear-gradient(135deg, #4FBEEC, #1A86B8); }
.author-mini__post-snippet {
    font-size: 0.66rem;
    color: var(--lm-ink-3);
    line-height: 1.45;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.author-mini__meta {
    min-width: 0;
    flex: 1;
    line-height: 1.25;
}
.author-mini__name {
    margin: 0;
    font-size: 0.92rem;
    font-weight: 800;
    color: var(--lm-ink);
    letter-spacing: -0.01em;
}
.author-mini__role {
    display: block;
    font-size: 0.68rem;
    font-weight: 600;
    color: var(--lm-primary);
    margin-top: 2px;
}
.author-mini__verified {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.54rem;
    font-weight: 700;
    color: var(--lm-primary);
    margin-top: 5px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.author-mini__verified svg { color: var(--lm-primary); flex-shrink: 0; }
.author-mini__bio {
    margin: 0;
    font-size: 0.68rem;
    line-height: 1.5;
    color: var(--lm-ink-4);
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}
.author-mini__stats {
    display: flex;
    gap: 4px;
    padding: 9px 0;
    border-top: 1px solid var(--lm-border);
    border-bottom: 1px solid var(--lm-border);
}
.author-mini__stat {
    flex: 1;
    text-align: center;
    position: relative;
}
.author-mini__stat:not(:last-child)::after {
    content: "";
    position: absolute;
    right: 0;
    top: 18%;
    bottom: 18%;
    width: 1px;
    background: var(--lm-border);
}
.author-mini__stat-value {
    display: block;
    font-size: 1rem;
    font-weight: 800;
    color: var(--lm-ink);
    line-height: 1;
    letter-spacing: -0.02em;
    font-variant-numeric: tabular-nums;
}
.author-mini__stat-value small {
    font-size: 0.65em;
    font-weight: 700;
    color: var(--lm-primary);
    margin-left: 1px;
}
.author-mini__stat--primary .author-mini__stat-value {
    color: var(--lm-primary);
}
.author-mini__stat-label {
    display: block;
    font-size: 0.54rem;
    color: var(--lm-ink-5);
    margin-top: 3px;
    letter-spacing: 0.03em;
    font-weight: 500;
}
.author-mini__posts-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    font-size: 0.6rem;
    font-weight: 700;
    color: var(--lm-ink-5);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.author-mini__posts-link {
    text-transform: none;
    letter-spacing: 0;
    color: var(--lm-primary);
    font-weight: 700;
    font-size: 0.6rem;
}
.author-mini__posts {
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin-top: -2px;
}
.author-mini__post-item {
    display: flex;
    align-items: flex-start;
    gap: 7px;
    padding: 6px 8px;
    background: var(--lm-bg-soft);
    border-radius: 6px;
    border-left: 2px solid var(--lm-primary);
}
.author-mini__post-dot {
    display: none; /* legacy stub — replaced by border-left accent */
}
.author-mini__post-line {
    height: 4px;
    background: var(--lm-border);
    border-radius: 2px;
}
.author-mini__post-line--60 { width: 60%; }

/* ---------- CARD 3: Shop hero wireframe (Netflix-style) ---------- */
.shop-mini__hero {
    flex: 1;
    position: relative;
    background: #1a3550;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 0;
}
.shop-mini__bg-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
    filter: saturate(1.05);
}
.shop-mini__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        radial-gradient(circle at 75% 30%, rgba(79, 190, 236, 0.35), transparent 55%),
        radial-gradient(circle at 25% 75%, rgba(244, 189, 55, 0.18), transparent 50%),
        linear-gradient(135deg, #1a3550 0%, #0E1F35 100%);
}
.shop-mini__overlay {
    position: absolute;
    inset: 0;
    z-index: 2;
    background: linear-gradient(180deg, rgba(11, 20, 35, 0.10) 0%, rgba(11, 20, 35, 0.55) 50%, rgba(11, 20, 35, 0.92) 100%);
}
.shop-mini__arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.15);
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: rgba(255, 255, 255, 0.85);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 4;
    cursor: default;
    pointer-events: none;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.shop-mini__arrow--left { left: 8px; }
.shop-mini__arrow--right { right: 8px; }
.shop-mini__content {
    position: relative;
    z-index: 3;
    padding: 12px 14px 30px;
    color: #fff;
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.shop-mini__badge {
    align-self: flex-start;
    font-size: 0.5rem;
    font-weight: 800;
    color: var(--lm-ink);
    background: var(--lm-accent);
    padding: 3px 8px;
    border-radius: 999px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    box-shadow: 0 4px 10px rgba(244, 189, 55, 0.35);
    margin-bottom: 1px;
}
.shop-mini__tags {
    display: flex;
    gap: 5px;
}
.shop-mini__tag {
    font-size: 0.5rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.92);
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.22);
    padding: 2px 7px;
    border-radius: 3px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.shop-mini__title {
    margin: 2px 0 0;
    font-size: 0.98rem;
    font-weight: 800;
    line-height: 1.15;
    color: #fff;
    letter-spacing: -0.015em;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}
.shop-mini__desc {
    margin: 0;
    font-size: 0.62rem;
    line-height: 1.45;
    color: rgba(255, 255, 255, 0.82);
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.shop-mini__bottom {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 8px;
    margin-top: 6px;
}
.shop-mini__price {
    display: flex;
    flex-direction: column;
    line-height: 1;
}
.shop-mini__price-value {
    font-size: 1.1rem;
    font-weight: 800;
    color: #fff;
    letter-spacing: -0.02em;
    font-variant-numeric: tabular-nums;
    text-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
}
.shop-mini__price-label {
    font-size: 0.5rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.65);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-top: 3px;
}
.shop-mini__actions {
    display: flex;
    gap: 5px;
    flex-shrink: 0;
}
.shop-mini__btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 11px;
    border-radius: 5px;
    font-size: 0.6rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.02em;
}
.shop-mini__btn--primary {
    background: #fff;
    color: var(--lm-ink);
}
.shop-mini__btn--secondary {
    background: rgba(255, 255, 255, 0.14);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.28);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.shop-mini__dots {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 4px;
    z-index: 3;
}
.shop-mini__dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.35);
}
.shop-mini__dot--active {
    width: 14px;
    border-radius: 3px;
    background: #fff;
}

@media (max-width: 1024px) {
    .landing-hero__mockup--cluster { height: 420px; max-width: 760px; }
    .landing-hero__app-card { width: 280px; height: 290px; }
    .landing-hero__app-card--feed   { top: 0;    left: 0; }
    .landing-hero__app-card--experts { top: 60px; left: 230px; }
    .landing-hero__app-card--shop   { top: 120px; left: 460px; }
}
@media (max-width: 880px) {
    .landing-hero__mockup--cluster { max-width: 100%; height: 400px; }
    .landing-hero__app-card { width: 240px; height: 280px; }
    .landing-hero__app-card--feed   { top: 0;    left: 4%; }
    .landing-hero__app-card--experts { top: 55px; left: 30%; }
    .landing-hero__app-card--shop   { top: 110px; right: 4%; left: auto; }
}
@media (max-width: 720px) {
    .landing-hero__mockup--cluster {
        height: auto;
        display: flex;
        flex-direction: column;
        gap: 14px;
        align-items: center;
    }
    .landing-hero__app-card {
        position: static;
        width: 100%;
        max-width: 360px;
        height: auto;
        min-height: 290px;
        margin: 0;
        transform: none !important;
        z-index: auto;
        left: auto !important;
        right: auto !important;
        top: auto !important;
    }
    .landing-hero__mockup--cluster:hover .landing-hero__app-card { transform: none !important; }
}
@media (prefers-reduced-motion: reduce) {
    .landing-hero__app-card { transition: none; }
}

/* ============================================================
   STATS — compact navy band
   ============================================================ */
.landing-stats {
    background: var(--lm-ink);
    color: var(--lm-paper);
    padding: 56px 0;
    border: none;
}
.landing-stats__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
    text-align: center;
}
.landing-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 0 10px;
    border-right: 1px solid rgba(255, 255, 255, 0.1);
}
.landing-stat:last-child { border-right: none; }
.landing-stat__value {
    font-size: clamp(2rem, 3.4vw, 2.8rem);
    font-weight: 800;
    color: var(--lm-accent);
    line-height: 1;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
}
.landing-stat__label {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.7);
    font-weight: 600;
    line-height: 1.4;
    letter-spacing: 0.02em;
}
/* ============================================================
   PERSONAS — tabbed (pill tabs)
   ============================================================ */
.landing-personas { background: var(--lm-paper); }
.landing-personas__tabs {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    padding: 8px;
    background: var(--lm-bg-soft);
    border-radius: 999px;
    border: 1px solid var(--lm-border);
    max-width: 100%;
    margin: 0 auto 36px;
    width: fit-content;
}
.landing-personas__tab {
    padding: 11px 20px;
    border-radius: 999px;
    border: none;
    background: transparent;
    color: var(--lm-ink-4);
    font-size: 0.88rem;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: background 0.2s ease, color 0.2s ease;
    white-space: nowrap;
}
.landing-personas__tab:hover { color: var(--lm-ink); }
.landing-personas__tab[aria-selected="true"] {
    background: var(--lm-primary);
    color: var(--lm-paper);
}
.landing-personas__tab i { font-size: 0.92rem; }

.landing-personas__panel {
    background: var(--lm-bg-soft);
    border: 1px solid var(--lm-border);
    border-radius: var(--lm-radius-lg);
    padding: 48px;
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: 48px;
    align-items: center;
    position: relative;
    overflow: hidden;
}
.landing-personas__panel[hidden] { display: none; }
.landing-personas__panel::before {
    content: "";
    position: absolute;
    top: -40px; right: -40px;
    width: 160px; height: 160px;
    background: var(--lm-primary-tint);
    border-radius: 50%;
    pointer-events: none;
}
.landing-personas__panel-text { position: relative; z-index: 1; }
.landing-personas__panel-text h3 {
    font-size: clamp(1.4rem, 2.4vw, 1.9rem);
    font-weight: 800;
    color: var(--lm-ink);
    margin: 0 0 14px;
    line-height: 1.2;
    letter-spacing: -0.01em;
}
.landing-personas__panel-text > p {
    font-size: 1rem;
    color: var(--lm-ink-4);
    line-height: 1.7;
    margin: 0 0 20px;
}
.landing-personas__bullets {
    list-style: none;
    padding: 0;
    margin: 0 0 28px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.landing-personas__bullets li {
    position: relative;
    padding-left: 28px;
    font-size: 0.92rem;
    color: var(--lm-ink-3);
    line-height: 1.55;
}
.landing-personas__bullets li::before {
    content: "";
    position: absolute;
    left: 0; top: 6px;
    width: 16px; height: 16px;
    background: var(--lm-primary);
    border-radius: 50%;
}
.landing-personas__bullets li::after {
    content: "✓";
    position: absolute;
    left: 3px; top: 4px;
    color: var(--lm-paper);
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
}
.landing-personas__illustration {
    background: var(--lm-paper);
    border-radius: var(--lm-radius-lg);
    border: 1px solid var(--lm-border);
    padding: 0;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    position: relative;
    z-index: 1;
    box-shadow: var(--lm-shadow);
}
.landing-personas__illustration img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* ============================================================
   KPI — split: blue left + dark cards right
   ============================================================ */
.landing-kpi { background: var(--lm-ink); padding: 80px 0; }
.landing-kpi .container {
    display: grid;
    grid-template-columns: 0.85fr 1.55fr;
    gap: 28px;
    align-items: stretch;
}
.landing-kpi__left {
    background: var(--lm-primary);
    border-radius: var(--lm-radius-lg);
    padding: 36px 32px;
    color: var(--lm-paper);
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.landing-kpi__left::after {
    content: "";
    position: absolute;
    top: -50px; right: -50px;
    width: 140px; height: 140px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.22);
    pointer-events: none;
}
.landing-kpi__left .landing-section__eyebrow {
    background: rgba(255, 255, 255, 0.18);
    color: var(--lm-paper);
    padding: 5px 11px;
    border-radius: 999px;
    align-self: flex-start;
}
.landing-kpi__left h2 {
    font-size: clamp(1.4rem, 2.2vw, 1.85rem);
    font-weight: 800;
    color: var(--lm-paper);
    line-height: 1.2;
    letter-spacing: -0.01em;
    margin: 12px 0 12px;
    position: relative;
    z-index: 1;
}
.landing-kpi__left p {
    font-size: 0.92rem;
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.55;
    margin: 0 0 20px;
    position: relative;
    z-index: 1;
}
.landing-kpi__left .landing-kpi__actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    position: relative;
    z-index: 1;
}
.landing-kpi__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    align-self: stretch;
}
.landing-kpi__card {
    background: var(--lm-ink-2);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--lm-radius);
    padding: 18px 18px;
    color: var(--lm-paper);
    transition: border-color 0.2s ease, transform 0.2s ease;
}
.landing-kpi__card:hover {
    border-color: var(--lm-accent);
    transform: translateY(-3px);
}
.landing-kpi__value {
    font-size: clamp(2.2rem, 4vw, 2.8rem);
    font-weight: 800;
    color: var(--lm-accent);
    line-height: 1;
    font-variant-numeric: tabular-nums;
    margin: 0 0 12px;
    letter-spacing: -0.02em;
}
.landing-kpi__suffix { font-size: 0.7em; color: var(--lm-accent); }
.landing-kpi__label {
    font-size: 0.95rem;
    font-weight: 800;
    color: var(--lm-paper);
    margin: 0 0 8px;
    letter-spacing: -0.01em;
}
.landing-kpi__desc {
    font-size: 0.84rem;
    color: rgba(255, 255, 255, 0.65);
    line-height: 1.55;
    margin: 0;
}
/* Button overrides for KPI left (on --lm-primary bg) */
.landing-kpi__left .btn-cta--primary {
    background: var(--lm-paper);
    color: var(--lm-primary);
    border-color: var(--lm-paper);
}
.landing-kpi__left .btn-cta--primary:hover {
    background: var(--lm-accent);
    color: var(--lm-ink);
    border-color: var(--lm-accent);
    transform: translateY(-1px);
}
.landing-kpi__left .btn-cta--ghost {
    color: var(--lm-paper);
    border-color: rgba(255, 255, 255, 0.5);
}
.landing-kpi__left .btn-cta--ghost:hover {
    background: var(--lm-paper);
    color: var(--lm-primary);
}

/* ---- Areas variant: 6 service-area cards (compact, equal-height grid) ---- */
.landing-kpi__grid--areas {
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 1fr;
    gap: 10px;
    align-self: stretch;
}
.landing-kpi__card--area {
    padding: 16px 16px 14px;
    display: flex;
    flex-direction: column;
    gap: 7px;
    height: 100%;
}
.landing-kpi__icon {
    width: 36px;
    height: 36px;
    border-radius: 9px;
    background: rgba(244, 189, 55, 0.14);
    color: var(--lm-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background 0.2s ease, color 0.2s ease, transform 0.25s ease;
}
.landing-kpi__icon svg { display: block; width: 19px; height: 19px; }
.landing-kpi__card--area:hover .landing-kpi__icon {
    background: var(--lm-accent);
    color: var(--lm-ink);
    transform: scale(1.06);
}
.landing-kpi__card--area .landing-kpi__label {
    font-size: 0.92rem;
    margin: 1px 0 0;
    line-height: 1.25;
}
.landing-kpi__card--area .landing-kpi__desc {
    font-size: 0.76rem;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.62);
}

@media (max-width: 1024px) {
    .landing-kpi__grid--areas { grid-template-columns: 1fr 1fr; grid-auto-rows: auto; }
}
@media (max-width: 640px) {
    .landing-kpi__grid--areas { grid-template-columns: 1fr; gap: 8px; }
    .landing-kpi__card--area { padding: 14px 14px 12px; }
}
@media (prefers-reduced-motion: reduce) {
    .landing-kpi__icon { transition: none; }
}

/* ============================================================
   CATEGORIES — chip grid with banner
   ============================================================ */
.landing-categories { background: var(--lm-paper); }
.landing-categories-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
.landing-category-card {
    --cat-color: var(--lm-ink);
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 24px 22px;
    border-radius: var(--lm-radius);
    border: 1px solid var(--lm-border);
    background: var(--lm-paper);
    text-decoration: none;
    transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
    position: relative;
    overflow: hidden;
}
.landing-category-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--lm-primary);
    transform: translateY(100%);
    transition: transform 0.25s ease;
    z-index: 0;
}
.landing-category-card:hover {
    border-color: var(--lm-primary);
    transform: translateY(-3px);
    box-shadow: var(--lm-shadow);
}
.landing-category-card:hover::before { transform: translateY(0); }
.landing-category-card > * { position: relative; z-index: 1; }
.landing-category-card__icon {
    width: 44px; height: 44px;
    border-radius: 12px;
    background: var(--lm-primary-tint);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    color: var(--lm-primary);
    transition: background 0.2s ease, color 0.2s ease;
}
.landing-category-card:hover .landing-category-card__icon {
    background: var(--lm-paper);
    color: var(--lm-primary);
}
.landing-category-card__name {
    font-size: 0.98rem;
    font-weight: 800;
    color: var(--lm-ink);
    margin: 0;
    line-height: 1.3;
    letter-spacing: -0.005em;
    transition: color 0.2s ease;
}
.landing-category-card:hover .landing-category-card__name { color: var(--lm-paper); }
.landing-category-card__meta {
    font-size: 0.78rem;
    color: var(--lm-ink-4);
    margin: 0;
    font-weight: 600;
    transition: color 0.2s ease;
}
.landing-category-card:hover .landing-category-card__meta { color: rgba(255, 255, 255, 0.75); }

/* ============================================================
   AUTHORS — card grid (avatar top)
   ============================================================ */
.landing-authors { background: var(--lm-bg-soft); }
.landing-authors-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}
.landing-author-card {
    background: var(--lm-paper);
    border: 1px solid var(--lm-border);
    border-radius: var(--lm-radius);
    padding: 28px 24px;
    text-decoration: none;
    transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    position: relative;
}
.landing-author-card:hover {
    border-color: var(--lm-primary);
    transform: translateY(-4px);
    box-shadow: var(--lm-shadow);
}
.landing-author-card__avatar {
    position: relative;
}
.landing-author-card__avatar img {
    width: 76px;
    height: 76px;
    border-radius: 50%;
    object-fit: cover;
    object-position: 50% 20%;
    border: 3px solid var(--lm-accent);
}
.landing-author-card__avatar::after {
    content: "✓";
    position: absolute;
    bottom: -2px;
    right: -2px;
    width: 24px; height: 24px;
    background: var(--lm-ink);
    color: var(--lm-accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 800;
    border: 2px solid var(--lm-paper);
}
.landing-author-card__body {
    display: flex;
    flex-direction: column;
    gap: 6px;
    width: 100%;
    flex-grow: 1;
}
.landing-author-card__name {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--lm-ink);
    margin: 0;
    letter-spacing: -0.005em;
}
.landing-author-card__specialization {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--lm-primary);
    margin: 0;
    background: var(--lm-primary-tint);
    padding: 3px 10px;
    border-radius: 999px;
    align-self: flex-start;
}
.landing-author-card__bio {
    font-size: 0.86rem;
    color: var(--lm-ink-4);
    line-height: 1.6;
    margin: 4px 0 0;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}
/* Stats row — 2 metryki (artykuly + produkty) z separatorem */
.landing-author-card__stats {
    list-style: none;
    margin: auto 0 0;
    padding: 14px 0 0;
    border-top: 1px solid var(--lm-border);
    width: 100%;
    display: flex;
    align-items: center;
    gap: 14px;
}
.landing-author-card__stat {
    display: inline-flex;
    align-items: baseline;
    gap: 5px;
    font-size: 0.8rem;
    line-height: 1.3;
}
.landing-author-card__stat:not(:last-child) {
    padding-right: 14px;
    border-right: 1px solid var(--lm-border);
}
.landing-author-card__stat i {
    color: var(--lm-primary);
    font-size: 0.78rem;
    margin-right: 1px;
    transform: translateY(1px);
}
.landing-author-card__stat .value {
    color: var(--lm-ink);
    font-weight: 800;
    font-feature-settings: 'tnum' 1;
}
.landing-author-card__stat .label {
    color: var(--lm-ink-5);
    font-weight: 500;
}

/* ============================================================
   PRODUCTS — featured cards
   ============================================================ */
.landing-products { background: var(--lm-paper); }
.landing-products-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
}
.landing-product-card-mini {
    display: flex;
    flex-direction: column;
    background: var(--lm-paper);
    border: 1px solid var(--lm-border);
    border-radius: var(--lm-radius);
    text-decoration: none;
    overflow: hidden;
    transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
.landing-product-card-mini:hover {
    border-color: var(--lm-primary);
    transform: translateY(-4px);
    box-shadow: var(--lm-shadow);
}
.landing-product-card-mini__img {
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: var(--lm-primary-tint);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.landing-product-card-mini__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}
.landing-product-card-mini:hover .landing-product-card-mini__img img { transform: scale(1.05); }
.landing-product-card-mini__img-placeholder {
    font-size: 2.2rem;
    color: var(--lm-primary);
    opacity: 0.5;
}
.landing-product-card-mini__body {
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}
.landing-product-card-mini__name {
    font-size: 0.96rem;
    font-weight: 800;
    color: var(--lm-ink);
    margin: 0;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    letter-spacing: -0.005em;
}
.landing-product-card-mini__desc {
    font-size: 0.82rem;
    color: var(--lm-ink-4);
    margin: 0;
    line-height: 1.55;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.landing-product-card-mini__price {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--lm-ink);
    margin-top: auto;
    padding-top: 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.landing-product-card-mini__price::after {
    content: "→";
    width: 28px; height: 28px;
    background: var(--lm-primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    color: var(--lm-paper);
    transition: transform 0.2s ease;
}
.landing-product-card-mini:hover .landing-product-card-mini__price::after { transform: translateX(4px); }
/* Keep green semantic colour for "free" */
.landing-product-card-mini__price--free { color: var(--lm-success); font-weight: 800; }

/* ============================================================
   AUTHOR CTA BANNER — blue split panel
   ============================================================ */
/* Author CTA — full-width premium hero (single column, glassmorphism cards) */
/* ===== Author CTA: black/gold (etap 5) ===== */
.landing-author-cta {
    background: #0F0F10;
    color: var(--lm-paper);
    padding: 96px 0 88px;
    position: relative;
    overflow: hidden;
    isolation: isolate;
}
.landing-author-cta__grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 56px;
    align-items: center;
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 24px;
}
.landing-author-cta__copy { min-width: 0; }
.landing-author-cta__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px 6px 12px;
    margin-bottom: 18px;
    background: rgba(244, 189, 55, 0.12);
    border: 1px solid rgba(244, 189, 55, 0.35);
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--lm-accent);
}
.landing-author-cta__eyebrow-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--lm-accent);
    box-shadow: 0 0 8px rgba(244, 189, 55, 0.6);
}
.landing-author-cta__title {
    margin: 0 0 18px;
    font-size: clamp(1.9rem, 3.2vw, 2.8rem);
    line-height: 1.15;
    font-weight: 800;
    color: var(--lm-paper);
    letter-spacing: -0.02em;
}
.landing-author-cta__title-em {
    display: block;
    margin-top: 4px;
    color: var(--lm-accent);
}
.landing-author-cta__desc {
    margin: 0 0 28px;
    font-size: 1.05rem;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.78);
    max-width: 540px;
}
.landing-author-cta__cta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}
.landing-author-cta__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 26px;
    border-radius: 12px;
    font-size: 0.98rem;
    font-weight: 700;
    text-decoration: none;
    transition: transform 0.15s ease, box-shadow 0.2s ease, background 0.2s ease, color 0.2s ease;
    border: 2px solid transparent;
}
.landing-author-cta__btn--primary {
    background: var(--lm-accent);
    color: #0F0F10;
    box-shadow: 0 8px 24px rgba(244, 189, 55, 0.32);
}
.landing-author-cta__btn--primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(244, 189, 55, 0.42);
    background: #FFD060;
}
.landing-author-cta__btn--ghost {
    background: transparent;
    color: var(--lm-paper);
    border-color: rgba(255, 255, 255, 0.35);
}
.landing-author-cta__btn--ghost:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: var(--lm-paper);
}
.landing-author-cta__photo-wrap {
    border: 4px solid var(--lm-accent);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.45);
    aspect-ratio: 4 / 3;
    background: #1a1a1a;
}
.landing-author-cta__photo-img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

@media (max-width: 960px) {
    .landing-author-cta { padding: 72px 0 64px; }
    .landing-author-cta__grid { grid-template-columns: 1fr; gap: 40px; }
    .landing-author-cta__desc { max-width: none; }
}
@media (max-width: 640px) {
    .landing-author-cta { padding: 56px 0 48px; }
    .landing-author-cta__cta-row { flex-direction: column; align-items: stretch; }
    .landing-author-cta__btn { width: 100%; }
    .landing-author-cta__photo-wrap { border-width: 3px; border-radius: 14px; }
}

/* ============================================================
   PROBLEMS — 3x2 minimal cards (blue border-left)
   ============================================================ */
.landing-problems { background: var(--lm-bg-soft); }
.landing-problems-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.landing-problem-card {
    background: var(--lm-paper);
    border: 1px solid var(--lm-border);
    border-left: 4px solid var(--lm-primary);
    border-radius: var(--lm-radius-sm);
    padding: 24px 22px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.landing-problem-card:hover {
    border-color: var(--lm-primary);
    border-left-color: var(--lm-primary);
    transform: translateY(-3px);
    box-shadow: var(--lm-shadow);
}
.landing-problem-card__problem,
.landing-problem-card__solution {
    background: transparent;
    padding: 0;
    border: none;
}
.landing-problem-card__badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 3px 10px;
    border-radius: 999px;
    margin-bottom: 10px;
}
.landing-problem-card__badge--problem {
    background: var(--lm-danger-soft);
    color: var(--lm-danger);
}
.landing-problem-card__badge--solution {
    background: var(--lm-primary);
    color: var(--lm-paper);
}
.landing-problem-card__problem p {
    font-size: 0.95rem;
    line-height: 1.55;
    color: var(--lm-ink-3);
    margin: 0 0 16px;
    font-weight: 600;
}
.landing-problem-card__solution p {
    font-size: 0.88rem;
    line-height: 1.6;
    color: var(--lm-ink-4);
    margin: 0;
}
.landing-problem-card__arrow { display: none; }

/* ============================================================
   HOW-TO — steps on blue background
   ============================================================ */
/* ===== Slim bar: "Wystarczą 3 kroki" (etap 5) ===== */
.landing-howto {
    background: var(--lm-ink);
    color: var(--lm-paper);
    padding: 56px 0;
    border: none;
}
.landing-howto__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    text-align: center;
}
.landing-howto__step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 0 12px;
    border-right: 1px solid rgba(255, 255, 255, 0.10);
}
.landing-howto__step:last-child { border-right: none; }
.landing-howto__num {
    font-size: clamp(2rem, 3.4vw, 2.8rem);
    font-weight: 800;
    color: var(--lm-accent);
    line-height: 1;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
}
.landing-howto__step-title {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.78);
    font-weight: 600;
    line-height: 1.4;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

/* ============================================================
   FAQ — accordion on white
   ============================================================ */
.landing-faq { background: var(--lm-paper); }
.landing-faq__list {
    max-width: 880px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.landing-faq__item {
    border: 1px solid var(--lm-border);
    border-radius: var(--lm-radius-sm);
    background: var(--lm-paper);
    overflow: hidden;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.landing-faq__item[open] {
    border-color: var(--lm-primary);
    box-shadow: var(--lm-shadow-sm);
}
.landing-faq__question {
    list-style: none;
    padding: 18px 22px;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--lm-ink);
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    user-select: none;
    line-height: 1.4;
    letter-spacing: -0.005em;
}
.landing-faq__question::-webkit-details-marker { display: none; }
.landing-faq__question::marker { display: none; }
.landing-faq__icon {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    border-radius: 50%;
    background: var(--lm-bg-soft);
    border: 1px solid var(--lm-border);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}
.landing-faq__icon::before,
.landing-faq__icon::after {
    content: '';
    position: absolute;
    background: var(--lm-ink);
    border-radius: 2px;
}
.landing-faq__icon::before { width: 10px; height: 2px; }
.landing-faq__icon::after { width: 2px; height: 10px; transition: transform 0.2s ease; }
.landing-faq__item[open] .landing-faq__icon {
    background: var(--lm-primary);
    border-color: var(--lm-primary);
}
.landing-faq__item[open] .landing-faq__icon::before,
.landing-faq__item[open] .landing-faq__icon::after {
    background: var(--lm-paper);
}
.landing-faq__item[open] .landing-faq__icon::after { transform: rotate(90deg); }
.landing-faq__answer {
    padding: 4px 22px 22px;
}
.landing-faq__answer p {
    margin: 0;
    font-size: 0.92rem;
    color: var(--lm-ink-4);
    line-height: 1.7;
}
.landing-faq__answer a {
    color: var(--lm-ink);
    font-weight: 700;
    text-decoration: none;
    border-bottom: 2px solid var(--lm-accent);
}

/* ============================================================
   NEWSLETTER / CONTACT — blue panel + dark form
   ============================================================ */
.landing-newsletter {
    background: var(--lm-primary);
    padding: 100px 0;
    position: relative;
    overflow: hidden;
}
.landing-newsletter::before {
    content: "";
    position: absolute;
    top: 50%; left: 50%;
    width: 800px; height: 800px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
}
.landing-newsletter__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
    position: relative;
    z-index: 1;
}
.landing-newsletter__title {
    font-size: clamp(1.7rem, 3.2vw, 2.4rem);
    font-weight: 800;
    color: var(--lm-paper);
    margin: 0 0 14px;
    line-height: 1.2;
    letter-spacing: -0.01em;
}
.landing-newsletter__desc {
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.65;
    margin: 0;
    font-weight: 500;
}
.landing-newsletter__form-wrap {
    background: var(--lm-ink);
    border-radius: var(--lm-radius-lg);
    padding: 36px 32px;
    box-shadow: var(--lm-shadow-lg);
}
.landing-newsletter__form {
    display: flex;
    flex-direction: column;
    gap: 18px;
    position: relative;
}
.landing-newsletter__field-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.landing-newsletter__label {
    font-size: 0.78rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.7);
    display: block;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.landing-newsletter__input {
    width: 100%;
    padding: 14px 18px;
    border-radius: 10px;
    border: 1.5px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.04);
    color: var(--lm-paper);
    font-size: 0.95rem;
    font-family: inherit;
    outline: none;
    transition: border-color 0.2s ease, background 0.2s ease;
}
.landing-newsletter__input::placeholder { color: rgba(255, 255, 255, 0.4); }
.landing-newsletter__input:focus {
    border-color: var(--lm-accent);
    background: rgba(255, 255, 255, 0.08);
}
.landing-newsletter__field-error {
    font-size: 0.78rem;
    color: var(--lm-error);
    min-height: 16px;
    font-weight: 600;
}
.landing-newsletter__consent-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.landing-newsletter__checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    cursor: pointer;
}
.landing-newsletter__checkbox {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    margin-top: 2px;
    accent-color: var(--lm-accent);
    cursor: pointer;
}
.landing-newsletter__checkbox-text {
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.65);
    line-height: 1.55;
}
.landing-newsletter__link {
    color: var(--lm-accent);
    text-decoration: underline;
    text-underline-offset: 2px;
    font-weight: 600;
}
.landing-newsletter__submit {
    width: 100%;
    margin-top: 4px;
    padding: 16px 24px;
    background: var(--lm-accent);
    color: var(--lm-ink);
    border-color: var(--lm-accent);
    font-size: 0.98rem;
    font-weight: 800;
}
.landing-newsletter__submit:hover {
    background: var(--lm-accent-dark);
    border-color: var(--lm-accent-dark);
    color: var(--lm-paper);
    transform: translateY(-1px);
}
.landing-newsletter__feedback {
    margin: 0;
    padding: 10px 14px;
    border-radius: 8px;
    font-size: 0.86rem;
    text-align: center;
    min-height: 0;
}
.landing-newsletter__feedback:empty { display: none; }
.landing-newsletter__feedback--success {
    background: rgba(244, 189, 55, 0.18);
    color: var(--lm-accent);
    border: 1px solid rgba(244, 189, 55, 0.32);
}
.landing-newsletter__feedback--error {
    background: var(--lm-error-soft);
    color: var(--lm-error);
    border: 1px solid var(--lm-error-border);
}

/* ============================================================
   FOOTER — rich dark navy
   ============================================================ */
.landing-footer-rich {
    background: var(--lm-ink);
    color: rgba(255, 255, 255, 0.75);
    padding: 72px 0 28px;
}
.landing-footer-rich .container {
    max-width: var(--lm-container);
    margin: 0 auto;
    padding: 0 24px;
}
.landing-footer-rich__grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: 48px;
    margin-bottom: 56px;
}
.landing-footer-rich__col {}
.landing-footer-rich__logo {
    display: inline-block;
    margin-bottom: 16px;
    text-decoration: none;
}
.landing-footer-rich__logo img {
    height: 36px;
    width: auto;
    filter: brightness(0) invert(1);
}
.landing-footer-rich__tagline {
    font-size: 0.92rem;
    line-height: 1.6;
    margin: 0 0 18px;
    color: rgba(255, 255, 255, 0.6);
    max-width: 320px;
}
.landing-footer-rich__contact a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--lm-accent);
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 600;
}
.landing-footer-rich__contact a:hover { text-decoration: underline; }
.landing-footer-rich__col-title {
    color: var(--lm-paper);
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin: 0 0 18px;
}
.landing-footer-rich__links {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.landing-footer-rich__links a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    font-size: 0.92rem;
    transition: color 0.18s ease;
}
.landing-footer-rich__links a:hover { color: var(--lm-accent); }
.landing-footer-rich__bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
    padding-top: 28px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.landing-footer-rich__copy {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.5);
    margin: 0;
}
.landing-footer-rich__bottom nav {
    display: flex;
    align-items: center;
    gap: 14px;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.4);
}
.landing-footer-rich__bottom-link {
    color: rgba(255, 255, 255, 0.6);
    text-decoration: none;
}
.landing-footer-rich__bottom-link:hover { color: var(--lm-accent); }

/* ============================================================
   RESPONSIVE — tablet + mobile
   ============================================================ */
@media (max-width: 1024px) {
    .landing-section { padding: 84px 0; }
    .landing-hero { padding: 56px 0 56px; }
    .landing-hero__mockup { max-width: 720px; }
    .landing-pillars__grid,
    .landing-problems-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .landing-categories-grid { grid-template-columns: repeat(3, 1fr); }
    .landing-products-grid { grid-template-columns: repeat(2, 1fr); }
    .landing-authors-grid { grid-template-columns: repeat(2, 1fr); }
    .landing-personas__panel { grid-template-columns: 1fr; padding: 36px; }
    .landing-personas__illustration { aspect-ratio: 1 / 1; max-width: 480px; margin: 0 auto; }
    .landing-kpi .container { grid-template-columns: 1fr; gap: 32px; }
    .landing-newsletter__inner { grid-template-columns: 1fr; gap: 32px; }
    .landing-footer-rich__grid { grid-template-columns: 1fr 1fr; gap: 36px; }
}

@media (max-width: 720px) {
    :root { --lm-section-y: 64px; }
    .landing-section { padding: var(--lm-section-y-mobile) 0; }
    .landing-page .container,
    .landing-section > .container,
    .landing-hero__inner.container,
    .landing-footer-rich .container { padding: 0 16px; }
    .landing-hero { padding: 40px 0 48px; }
    .landing-hero__title { font-size: clamp(2rem, 9vw, 2.6rem); }
    .landing-hero__lead { font-size: 0.98rem; }
    .landing-hero__mockup { margin-top: 40px; aspect-ratio: 4 / 3; }
    .landing-hero__mockup-body { grid-template-columns: 1fr; }
    .landing-hero__mockup-side { display: none; }
    .landing-hero__mockup-badge { right: -10px; padding: 10px 14px; font-size: 0.72rem; }
    .landing-stats__grid { grid-template-columns: repeat(2, 1fr); gap: 28px; }
    .landing-stat { border-right: none; border-bottom: 1px solid rgba(255, 255, 255, 0.08); padding-bottom: 20px; }
    .landing-stat:nth-last-child(-n+2) { border-bottom: none; padding-bottom: 0; }
    .landing-pillars__grid,
    .landing-problems-grid,
    .landing-categories-grid,
    .landing-products-grid,
    .landing-authors-grid {
        grid-template-columns: 1fr;
    }
    .landing-howto__grid { grid-template-columns: 1fr; gap: 28px; }
    .landing-howto__step { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.08); padding-bottom: 18px; }
    .landing-howto__step:last-child { border-bottom: none; padding-bottom: 0; }
    .landing-faq__list { grid-template-columns: 1fr; }
    .landing-personas__tabs { padding: 6px; gap: 4px; }
    .landing-personas__tab { padding: 8px 14px; font-size: 0.82rem; }
    .landing-personas__panel { padding: 28px 22px; }
    .landing-kpi__grid { grid-template-columns: 1fr 1fr; gap: 12px; }
    .landing-kpi__left { padding: 36px 28px; }
    .landing-kpi__card { padding: 22px 18px; }
    .landing-newsletter { padding: 64px 0; }
    .landing-newsletter__form-wrap { padding: 28px 22px; }
    .landing-section__heading { margin-bottom: 36px; }
    .landing-footer-rich { padding: 48px 0 24px; }
    .landing-footer-rich__grid { grid-template-columns: 1fr; gap: 28px; margin-bottom: 36px; }
    .landing-footer-rich__bottom { flex-direction: column; align-items: flex-start; }
    body.landing-page .topbar .nav { display: none; }
}

/* ============================================================
   AUTHORS — multi-visible carousel (3 desktop / 2 tablet / 1 mobile)
   ============================================================ */
.landing-authors--carousel { background: var(--lm-bg-soft); }

.authors-carousel {
    --slides-visible: 3;
    --slide-gap: 24px;
    position: relative;
    margin: 0 auto;
    max-width: 1100px;
}

.authors-carousel__track {
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    gap: var(--slide-gap);
    padding: 8px 4px 28px;
    scrollbar-width: none;
    -ms-overflow-style: none;
    -webkit-overflow-scrolling: touch;
}
.authors-carousel__track::-webkit-scrollbar { display: none; }
.authors-carousel__track:focus-visible {
    outline: 2px solid var(--lm-primary);
    outline-offset: 4px;
    border-radius: var(--lm-radius);
}

.author-slide {
    flex: 0 0 calc((100% - (var(--slides-visible) - 1) * var(--slide-gap)) / var(--slides-visible));
    scroll-snap-align: start;
    scroll-snap-stop: always;
    min-width: 0;
}

.author-slide__link {
    display: flex;
    flex-direction: column;
    gap: 18px;
    background: var(--lm-paper);
    border: 1px solid var(--lm-border);
    border-radius: var(--lm-radius-lg);
    padding: 22px 22px 26px;
    text-decoration: none;
    color: inherit;
    box-shadow: 0 1px 3px rgba(11, 31, 58, 0.04);
    transition: border-color 0.2s ease, box-shadow 0.25s ease, transform 0.25s ease;
    height: 100%;
}
.author-slide__link:hover {
    border-color: var(--lm-primary);
    box-shadow: 0 12px 36px rgba(11, 31, 58, 0.10);
    transform: translateY(-3px);
}
.author-slide__link:focus-visible {
    outline: 3px solid var(--lm-primary);
    outline-offset: 4px;
}

.author-slide__portrait {
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 5;
    border-radius: var(--lm-radius);
    overflow: hidden;
    background:
        radial-gradient(circle at 30% 20%, rgba(79, 190, 236, 0.18), transparent 60%),
        linear-gradient(180deg, var(--lm-bg-soft) 0%, #E2EBF3 100%);
    box-shadow: 0 8px 24px rgba(11, 31, 58, 0.10);
}
.author-slide__portrait img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 18%;
    display: block;
    transition: transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.author-slide__link:hover .author-slide__portrait img {
    transform: scale(1.04);
}
.author-slide__verified {
    position: absolute;
    bottom: 12px;
    right: 12px;
    width: 32px;
    height: 32px;
    background: var(--lm-primary);
    color: #fff;
    border: 3px solid var(--lm-paper);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(11, 31, 58, 0.18);
}

.author-slide__content {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 0;
    flex-grow: 1;
}
.author-slide__name {
    margin: 0;
    font-size: 1.25rem;
    line-height: 1.2;
    font-weight: 800;
    color: var(--lm-ink);
    letter-spacing: -0.015em;
}
.author-slide__role {
    margin: 0;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--lm-primary);
    letter-spacing: 0.005em;
}
/* .author-slide__bio — usuniete w etap 4 KROK B
   (karta odchudzona do imie + specjalizacja + stats; focus wizualny na portret) */
.author-slide__stats {
    list-style: none;
    margin: 6px 0 0;
    padding: 0;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.author-slide__stat {
    display: inline-flex;
    align-items: baseline;
    gap: 5px;
    padding: 4px 10px;
    background: var(--lm-bg-soft);
    border: 1px solid var(--lm-border);
    border-radius: 999px;
    font-size: 0.75rem;
}
.author-slide__stat-value {
    font-weight: 800;
    color: var(--lm-ink);
    font-feature-settings: 'tnum' 1;
}
.author-slide__stat-label {
    color: var(--lm-ink-5);
    font-weight: 500;
}
.author-slide__cta {
    margin-top: auto;
    padding-top: 8px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--lm-primary);
    letter-spacing: 0.01em;
    transition: gap 0.2s ease;
    align-self: flex-start;
}
.author-slide__link:hover .author-slide__cta { gap: 10px; }

/* Nav arrows */
.authors-carousel__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    border: 1px solid var(--lm-border);
    background: var(--lm-paper);
    color: var(--lm-ink);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(11, 31, 58, 0.10);
    transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease, opacity 0.2s ease;
}
.authors-carousel__nav:hover {
    background: var(--lm-primary);
    color: #fff;
    transform: translateY(-50%) scale(1.05);
}
.authors-carousel__nav:focus-visible {
    outline: 2px solid var(--lm-primary);
    outline-offset: 3px;
}
.authors-carousel__nav:disabled,
.authors-carousel__nav[aria-disabled="true"] {
    opacity: 0.35;
    cursor: not-allowed;
    pointer-events: none;
}
.authors-carousel__nav:disabled:hover,
.authors-carousel__nav[aria-disabled="true"]:hover {
    background: var(--lm-paper);
    color: var(--lm-ink);
    transform: translateY(-50%);
}
.authors-carousel__nav--prev { left: -24px; }
.authors-carousel__nav--next { right: -24px; }

/* Dots */
.authors-carousel__dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 14px;
}
.authors-carousel__dot {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    border: 0;
    padding: 0;
    background: var(--lm-border);
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease, width 0.25s ease;
}
.authors-carousel__dot:hover { background: var(--lm-ink-5); }
.authors-carousel__dot.is-active {
    background: var(--lm-primary);
    width: 26px;
    border-radius: 6px;
}
.authors-carousel__dot:focus-visible {
    outline: 2px solid var(--lm-primary);
    outline-offset: 3px;
}

/* Tablet (≤1024px) — 2 visible */
@media (max-width: 1024px) {
    .authors-carousel { --slides-visible: 2; max-width: 760px; }
    .authors-carousel__nav--prev { left: -8px; }
    .authors-carousel__nav--next { right: -8px; }
}

/* Mobile (≤640px) — 1 visible */
@media (max-width: 640px) {
    .authors-carousel { --slides-visible: 1; --slide-gap: 16px; max-width: 100%; }
    .author-slide__link { padding: 20px 18px 22px; }
    .author-slide__portrait { max-width: 280px; margin: 0 auto; }
    .author-slide__content { text-align: center; align-items: center; }
    .author-slide__stats { justify-content: center; }
    .author-slide__cta { align-self: center; }
    .authors-carousel__nav { width: 40px; height: 40px; }
    .authors-carousel__nav--prev { left: 0; }
    .authors-carousel__nav--next { right: 0; }
}

@media (prefers-reduced-motion: reduce) {
    .authors-carousel__track { scroll-behavior: auto; }
    .author-slide__link,
    .author-slide__portrait img,
    .author-slide__cta,
    .authors-carousel__nav,
    .authors-carousel__dot { transition: none; }
}

/* ============================================================
   HERO browser-frame mockup z karuzelą iframe.
   Każdy slajd to iframe z prawdziwą podstroną (?embed=1 ukrywa
   topbar/footer w base.html) — treść aktualizowana na żywo.
   ============================================================ */
.hero-mockup {
    margin: 56px auto 0;
    max-width: 720px;
    width: 100%;
    position: relative;
    z-index: 2;
}

.hero-mockup-frame {
    position: relative;
    background: #FFFFFF;
    border-radius: 18px;
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.4) inset,
        0 30px 60px rgba(11, 31, 58, 0.22),
        0 8px 20px rgba(11, 31, 58, 0.10);
    border: 1px solid rgba(11, 31, 58, 0.08);
    overflow: hidden;
}

.hero-mockup-chrome {
    display: flex;
    align-items: center;
    gap: 14px;
    height: 38px;
    padding: 0 16px;
    background: linear-gradient(180deg, #F7F8FA 0%, #EEF1F5 100%);
    border-bottom: 1px solid rgba(11, 31, 58, 0.08);
}
.hero-mockup-chrome__dots {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.hero-mockup-chrome__dots i {
    width: 11px;
    height: 11px;
    border-radius: 50%;
    display: inline-block;
}
.hero-mockup-chrome__dots i:nth-child(1) { background: #FF5F57; }
.hero-mockup-chrome__dots i:nth-child(2) { background: #FEBC2E; }
.hero-mockup-chrome__dots i:nth-child(3) { background: #28C840; }
.hero-mockup-chrome__url {
    flex: 1;
    height: 22px;
    line-height: 22px;
    padding: 0 12px;
    background: #FFFFFF;
    border-radius: 11px;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: 11px;
    color: var(--lm-ink-3, #5a6b7d);
    border: 1px solid rgba(11, 31, 58, 0.08);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    transition: color 0.3s ease;
}

.hero-mockup-screen {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 10;
    background: #F4F6F8;
    overflow: hidden;
}
.hero-mockup-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transform: translateX(20px);
    transition: opacity 0.5s ease, transform 0.5s ease;
    pointer-events: none;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.hero-mockup-slide.is-active {
    opacity: 1;
    transform: none;
    pointer-events: auto;
}
/* iframe live preview — renderuje prawdziwą podstronę (?embed=1).
   Skala 0.5 + width 200% = wnętrze renderowane jako desktop 1440px,
   wyświetlone jako 720px. pointer-events: none żeby user nie scrollował
   wewnątrz iframe. */
.hero-mockup-iframe {
    position: absolute;
    inset: 0;
    width: 200%;
    height: 200%;
    border: 0;
    transform: scale(0.5);
    transform-origin: top left;
    pointer-events: none;
    background: #FFFFFF;
}

.resources-mini {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: #FFFFFF;
    color: var(--lm-ink, #0F0F10);
    font-family: 'Montserrat', system-ui, sans-serif;
}
.resources-mini__topbar {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    background: #27A3DC;
    color: #FFFFFF;
    font-size: 11px;
    font-weight: 700;
    flex-shrink: 0;
}
.resources-mini__title {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.resources-mini__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    background: rgba(255, 255, 255, 0.15);
    border-radius: 4px;
    color: #FFFFFF;
}
.resources-mini__search {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(255, 255, 255, 0.18);
    padding: 4px 10px;
    border-radius: 14px;
    font-size: 9px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.85);
}
.resources-mini__lead {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 8px;
    padding: 10px 16px 6px;
    flex-shrink: 0;
}
.resources-mini__lead-eyebrow {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--lm-ink-4, #6a7787);
}
.resources-mini__lead-count {
    font-size: 9px;
    color: var(--lm-ink-3, #5a6b7d);
}
.resources-mini__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px;
    padding: 6px 16px 16px;
    flex: 1 1 auto;
    min-height: 0;
}
.resources-mini__tile {
    background: #FFFFFF;
    border: 1px solid rgba(11, 31, 58, 0.10);
    border-left: 3px solid var(--cat-color, #27A3DC);
    border-radius: 8px;
    padding: 8px 8px 6px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    box-shadow: 0 1px 2px rgba(11, 31, 58, 0.04);
    min-height: 0;
    overflow: hidden;
}
.resources-mini__tile-icon {
    width: 20px;
    height: 20px;
    border-radius: 6px;
    background: color-mix(in srgb, var(--cat-color, #27A3DC) 14%, #FFFFFF);
    color: var(--cat-color, #27A3DC);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
}
.resources-mini__tile-name {
    font-size: 10px;
    font-weight: 700;
    color: var(--lm-ink, #0F0F10);
    line-height: 1.2;
}
.resources-mini__tile-count {
    font-size: 9px;
    color: var(--lm-ink-4, #6a7787);
}

/* Controls (prev/dots/next) — pod ramką */
.hero-mockup-controls {
    margin-top: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
}
.hero-mockup-ctrl {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid rgba(11, 31, 58, 0.14);
    background: #FFFFFF;
    color: var(--lm-ink, #0F0F10);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
    padding: 0;
}
.hero-mockup-ctrl:hover {
    background: var(--lm-primary, #27A3DC);
    color: #FFFFFF;
    border-color: var(--lm-primary, #27A3DC);
    transform: translateY(-1px);
}
.hero-mockup-dots {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.hero-mockup-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 0;
    background: rgba(11, 31, 58, 0.20);
    cursor: pointer;
    padding: 0;
    transition: background 0.25s ease, transform 0.25s ease;
}
.hero-mockup-dot:hover { background: rgba(11, 31, 58, 0.35); }
.hero-mockup-dot.is-active {
    background: var(--lm-primary, #27A3DC);
    transform: scale(1.2);
}

/* Hero overlap — mockup delikatnie nachodzi na ciemną belkę statystyk pod
   sekcją hero (.landing-stats). Belka jest ciemna (var(--lm-ink)), więc
   dolna część ramki naturalnie wbija się w nią.
   Scope: TYLKO body.landing-page — `/zostan-autorem/` też używa
   .landing-hero ale bez mockupu i bez statystyk pod spodem. */
body.landing-page .landing-hero {
    position: relative;
    z-index: 2;
    padding-bottom: 60px;
    margin-bottom: -40px;
}
/* Stats: kompensacja overlap — zwiększony padding-top żeby cyferki
   nie wchodziły pod ramkę mockupu. */
body.landing-page .landing-stats {
    padding-top: 110px;
}

/* Responsive */
@media (max-width: 900px) {
    .hero-mockup { margin-top: 40px; max-width: 100%; }
    .hero-mockup-screen { aspect-ratio: 16 / 11; }
    .resources-mini__grid { grid-template-columns: repeat(4, 1fr); gap: 6px; padding: 6px 12px 12px; }
}

@media (max-width: 640px) {
    .hero-mockup-chrome { height: 32px; padding: 0 12px; gap: 10px; }
    .hero-mockup-chrome__dots i { width: 9px; height: 9px; }
    .hero-mockup-chrome__url { font-size: 10px; }
    .hero-mockup-screen { aspect-ratio: 4 / 3; }
    .hero-mockup-ctrl { width: 32px; height: 32px; }
    .resources-mini__grid { grid-template-columns: repeat(2, 1fr); }
    .resources-mini__topbar { padding: 8px 10px; font-size: 10px; }
    .resources-mini__lead { padding: 8px 10px 4px; }
    body.landing-page .landing-hero { padding-bottom: 50px; margin-bottom: -30px; }
    body.landing-page .landing-stats { padding-top: 80px; }
}

@media (prefers-reduced-motion: reduce) {
    .hero-mockup-slide { transition: none; }
    .hero-mockup-ctrl, .hero-mockup-dot { transition: none; }
}

/* ============================================================
   SECTION: Co otrzymujesz? — 3 kafelki (FEED / ZASOBY / SKLEP)
   ============================================================ */
.landing-co-otrzymujesz {
    background: var(--lm-paper, #FBFBFB);
}
.landing-co-otrzymujesz__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.landing-co-otrzymujesz__tile {
    position: relative;
    display: flex;
    flex-direction: column;
    background: #FFFFFF;
    border-radius: 18px;
    border: 1px solid rgba(11, 31, 58, 0.08);
    box-shadow: 0 4px 16px rgba(11, 31, 58, 0.04);
    text-decoration: none;
    color: inherit;
    overflow: hidden;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.landing-co-otrzymujesz__tile:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 38px rgba(11, 31, 58, 0.12);
    border-color: rgba(39, 163, 220, 0.30);
}
.landing-co-otrzymujesz__tile:focus-visible {
    outline: 3px solid var(--lm-primary, #27A3DC);
    outline-offset: 3px;
}

.landing-co-otrzymujesz__preview {
    position: relative;
    aspect-ratio: 16 / 9;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--lm-primary) 0%, var(--lm-primary-dark) 100%);
    color: rgba(255, 255, 255, 0.95);
    overflow: hidden;
}
.landing-co-otrzymujesz__tile--resources .landing-co-otrzymujesz__preview {
    background: linear-gradient(135deg, var(--lm-primary-soft) 0%, var(--lm-primary) 100%);
}
.landing-co-otrzymujesz__tile--shop .landing-co-otrzymujesz__preview {
    background: linear-gradient(135deg, var(--lm-primary-dark) 0%, #0F0F10 100%);
}
.landing-co-otrzymujesz__preview-icon {
    font-size: 4.5rem;
    opacity: 0.85;
    transition: transform 0.4s ease, opacity 0.4s ease;
}
.landing-co-otrzymujesz__tile:hover .landing-co-otrzymujesz__preview-icon {
    transform: scale(1.08);
    opacity: 1;
}

.landing-co-otrzymujesz__body {
    padding: 28px 26px 30px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 1 1 auto;
}
.landing-co-otrzymujesz__tile-title {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    color: var(--lm-ink, #0F0F10);
}
.landing-co-otrzymujesz__tile-desc {
    margin: 0;
    font-size: 1rem;
    color: var(--lm-ink-3, #5a6b7d);
    line-height: 1.55;
    flex: 1 1 auto;
}
.landing-co-otrzymujesz__tile-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--lm-primary, #27A3DC);
    transition: gap 0.2s ease;
}
.landing-co-otrzymujesz__tile:hover .landing-co-otrzymujesz__tile-link {
    gap: 12px;
}

@media (max-width: 900px) {
    .landing-co-otrzymujesz__grid { grid-template-columns: 1fr; gap: 20px; }
    .landing-co-otrzymujesz__heading { margin-bottom: 36px; }
    .landing-co-otrzymujesz__preview-icon { font-size: 3.8rem; }
}

@media (prefers-reduced-motion: reduce) {
    .landing-co-otrzymujesz__tile,
    .landing-co-otrzymujesz__preview-icon,
    .landing-co-otrzymujesz__tile-link { transition: none; }
}

/* ============================================================
   SECTION: Zobacz przykłady naszej pracy — 04 (etap 3, 50/50)
   Lewo: sklep (landing_products inner-only)
   Prawo: kategorie (landing_categories inner-only)
   ============================================================ */
.landing-examples { background: var(--lm-paper); }
.landing-examples__split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 36px;
    align-items: start;
}
.landing-examples__col {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.landing-examples__col-title {
    margin: 0 0 4px;
    font-size: clamp(1.1rem, 2vw, 1.35rem);
    font-weight: 800;
    color: var(--lm-ink);
    letter-spacing: -0.01em;
    line-height: 1.25;
}
.landing-examples__col .landing-products-grid,
.landing-examples__col .landing-categories-grid {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.landing-examples__col .btn-cta { align-self: flex-start; }

@media (max-width: 900px) {
    .landing-examples__split { grid-template-columns: 1fr; gap: 28px; }
}
@media (max-width: 720px) {
    .landing-examples__col .landing-products-grid,
    .landing-examples__col .landing-categories-grid { grid-template-columns: 1fr; }
}


