.lp-root {
    --primary: #000c1e;
    --on-primary: #ffffff;
    --tertiary-fixed-dim: #e9c176;
    --on-tertiary-fixed-variant: #5d4201;
    --background: #f9f9f9;
    --surface-container-lowest: #ffffff;
    --surface-container-low: #f3f3f3;
    --surface-container-high: #e8e8e8;
    --on-surface: #1a1c1c;
    --on-surface-variant: #43474e;
    --outline-variant: #c3c6cf;
    --font-headline: "Newsreader", "Source Serif Pro", Georgia, serif;
    --font-body: "Manrope", "Inter", system-ui, -apple-system, sans-serif;

    background: var(--background);
    color: var(--on-surface);
    font-family: var(--font-body);
    scroll-behavior: smooth;
}
.lp-root *, .lp-root *::before, .lp-root *::after { box-sizing: border-box; }
.lp-root a { color: inherit; text-decoration: none; }
.lp-root .ico {
    font-family: 'Material Symbols Outlined';
    font-weight: 400; font-style: normal; display: inline-block;
    line-height: 1; vertical-align: middle;
    font-variation-settings: 'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;
}

/* NAV */
.lp-root nav.lp { position: sticky; top: 0; z-index: 50; background: rgba(249,249,249,0.94); backdrop-filter: saturate(140%) blur(8px); border-bottom: 1px solid var(--outline-variant); }
.lp-root nav.lp .inner { display: flex; justify-content: space-between; align-items: center; padding: 18px 32px; max-width: 1440px; margin: 0 auto; }
.lp-root nav.lp .brand { font-family: var(--font-headline); font-weight: 700; font-size: 24px; color: var(--primary); letter-spacing: -0.015em; }
.lp-root nav.lp .brand sup { font-family: var(--font-body); font-size: 9px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--on-tertiary-fixed-variant); margin-left: 8px; vertical-align: 8px; }
.lp-root nav.lp .links { display: flex; align-items: center; gap: 32px; }
.lp-root nav.lp .links a { font-family: var(--font-headline); font-style: italic; font-weight: 500; font-size: 15px; color: var(--primary); border-bottom: 1px solid transparent; padding-bottom: 2px; transition: border-color 200ms; letter-spacing: -0.005em; }
.lp-root nav.lp .links a:hover, .lp-root nav.lp .links a.active { border-bottom-color: var(--tertiary-fixed-dim); }
.lp-root nav.lp .right { display: flex; align-items: center; gap: 18px; }
.lp-root nav.lp a.cta { background: var(--primary); color: var(--on-primary); padding: 12px 22px; font-family: var(--font-body); font-weight: 700; font-size: 13px; display: inline-flex; align-items: center; gap: 8px; letter-spacing: 0.02em; transition: transform 200ms; }
.lp-root nav.lp a.cta:hover { transform: translateY(-2px); }
.lp-root nav.lp a.cta .ico { font-size: 16px; }

/* PAGE HEAD */
.lp-root .ph { padding: 80px 32px 48px; max-width: 1320px; margin: 0 auto; }
.lp-root .ph .crumb { font-size: 11px; font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase; color: var(--on-tertiary-fixed-variant); margin-bottom: 24px; display: flex; gap: 14px; align-items: center; }
.lp-root .ph .crumb a { color: var(--primary); }
.lp-root .ph .crumb span { color: var(--on-tertiary-fixed-variant); }
.lp-root .ph h1 { font-family: var(--font-headline); font-weight: 700; font-size: clamp(48px, 5.6vw, 80px); line-height: 1.0; letter-spacing: -0.028em; color: var(--primary); margin: 0 0 24px; text-wrap: balance; max-width: 18ch; }
.lp-root .ph h1 em { font-style: italic; font-weight: 400; }
.lp-root .ph .lead { font-size: clamp(17px, 1.2vw + 0.6rem, 21px); line-height: 1.55; color: var(--on-surface-variant); max-width: 60ch; margin: 0; }
.lp-root .ph .lead b { color: var(--primary); font-weight: 700; }

/* TOC */
.lp-root .toc { padding: 32px 32px 64px; max-width: 1320px; margin: 0 auto; }
.lp-root .toc .grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; background: var(--outline-variant); border: 1px solid var(--outline-variant); }
.lp-root .toc a { background: var(--surface-container-lowest); padding: 18px 16px; display: flex; flex-direction: column; gap: 6px; transition: background 200ms; }
.lp-root .toc a:hover { background: var(--background); }
.lp-root .toc a .num { font-family: var(--font-headline); font-style: italic; font-weight: 700; font-size: 13px; color: var(--tertiary-fixed-dim); letter-spacing: 0.04em; }
.lp-root .toc a .nm { font-family: var(--font-headline); font-weight: 700; font-size: 14.5px; color: var(--primary); letter-spacing: -0.005em; line-height: 1.2; }

/* CHAPTER */
.lp-root .ch { padding: 96px 32px; border-top: 1px solid var(--outline-variant); }
.lp-root .ch.alt { background: var(--surface-container-low); }
.lp-root .ch.dark { background: var(--primary); color: var(--on-primary); }
.lp-root .ch.dark .h .eyebrow, .lp-root .ch.dark .h h2, .lp-root .ch.dark .h .sub, .lp-root .ch.dark p, .lp-root .ch.dark .body { color: inherit; }
.lp-root .ch .inner { max-width: 1320px; margin: 0 auto; }
.lp-root .ch .h { display: grid; grid-template-columns: auto 1fr; gap: 48px; align-items: flex-end; margin-bottom: 48px; }
.lp-root .ch .h .num { font-family: var(--font-headline); font-style: italic; font-weight: 700; font-size: 140px; line-height: 0.85; color: var(--tertiary-fixed-dim); letter-spacing: -0.04em; opacity: 0.5; }
.lp-root .ch.dark .h .num { opacity: 0.45; }
.lp-root .ch .h .eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase; color: var(--on-tertiary-fixed-variant); margin: 0 0 14px; display: block; }
.lp-root .ch.dark .h .eyebrow { color: var(--tertiary-fixed-dim); opacity: 0.85; }
.lp-root .ch .h h2 { font-family: var(--font-headline); font-weight: 700; font-size: clamp(34px, 3.8vw, 52px); line-height: 1.05; letter-spacing: -0.022em; color: var(--primary); margin: 0 0 16px; max-width: 22ch; text-wrap: balance; }
.lp-root .ch.dark .h h2 { color: var(--on-primary); }
.lp-root .ch .h h2 em { font-style: italic; font-weight: 400; }
.lp-root .ch.dark .h h2 em { color: var(--tertiary-fixed-dim); }
.lp-root .ch .h .sub { font-size: 17px; line-height: 1.55; color: var(--on-surface-variant); max-width: 64ch; margin: 0; }
.lp-root .ch.dark .h .sub { color: rgba(255,255,255,0.72); }

.lp-root .ch .grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.lp-root .ch .grid2.flip { grid-template-columns: 1fr 1fr; }
.lp-root .ch h3 { font-family: var(--font-headline); font-weight: 700; font-size: clamp(24px, 2.4vw, 32px); line-height: 1.15; letter-spacing: -0.014em; color: var(--primary); margin: 0 0 16px; text-wrap: balance; }
.lp-root .ch.dark h3 { color: var(--on-primary); }
.lp-root .ch h3 em { font-style: italic; font-weight: 400; }
.lp-root .ch.dark h3 em { color: var(--tertiary-fixed-dim); }
.lp-root .ch p.body { font-size: 16px; line-height: 1.65; color: var(--on-surface-variant); margin: 0 0 22px; max-width: 54ch; }
.lp-root .ch.dark p.body { color: rgba(255,255,255,0.78); }
.lp-root .ch p.body b { color: var(--primary); font-weight: 700; }
.lp-root .ch.dark p.body b { color: var(--on-primary); }
.lp-root .ch p.body code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 0.9em; padding: 1px 6px; background: var(--surface-container-low); }
.lp-root .ch.dark p.body code { background: rgba(255,255,255,0.06); color: var(--tertiary-fixed-dim); }

/* point list */
.lp-root .points { list-style: none; margin: 0; padding: 0; border-top: 1px solid var(--outline-variant); }
.lp-root .ch.dark .points { border-top: 1px solid rgba(255,255,255,0.10); }
.lp-root .points li { display: grid; grid-template-columns: auto 1fr; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--outline-variant); align-items: flex-start; }
.lp-root .ch.dark .points li { border-bottom: 1px solid rgba(255,255,255,0.08); }
.lp-root .points li .ico { color: var(--primary); font-size: 20px; margin-top: 2px; }
.lp-root .ch.dark .points li .ico { color: var(--tertiary-fixed-dim); }
.lp-root .points li .txt { font-size: 14.5px; line-height: 1.55; color: var(--on-surface); }
.lp-root .ch.dark .points li .txt { color: rgba(255,255,255,0.85); }
.lp-root .points li .txt b { color: var(--primary); font-weight: 700; }
.lp-root .ch.dark .points li .txt b { color: var(--on-primary); }

/* DIAGRAMS — panel */
.lp-root .panel { background: var(--surface-container-lowest); border: 1px solid var(--outline-variant); box-shadow: 0 30px 60px -50px rgba(0,12,30,0.3); }
.lp-root .ch.dark .panel { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.10); }
.lp-root .panel .top { display: flex; align-items: center; gap: 12px; padding: 14px 20px; border-bottom: 1px solid var(--outline-variant); background: var(--surface-container-low); }
.lp-root .ch.dark .panel .top { border-bottom: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.02); }
.lp-root .panel .top .l { display: flex; gap: 5px; }
.lp-root .panel .top .l span { width: 9px; height: 9px; border-radius: 9999px; background: var(--surface-container-high); }
.lp-root .panel .top .l span:nth-child(1) { background: #d4615a; }
.lp-root .panel .top .l span:nth-child(2) { background: #d6a85d; }
.lp-root .panel .top .crumb { font-family: var(--font-headline); font-style: italic; font-size: 13px; color: var(--primary); letter-spacing: -0.005em; }
.lp-root .ch.dark .panel .top .crumb { color: var(--on-primary); }
.lp-root .panel .top .crumb b { font-style: normal; font-weight: 700; }
.lp-root .panel .top .stat { margin-left: auto; font-size: 10px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--on-tertiary-fixed-variant); }
.lp-root .ch.dark .panel .top .stat { color: var(--tertiary-fixed-dim); opacity: 0.85; }

/* RESEARCH — 5 levels diagram */
.lp-root .levels .row { display: grid; grid-template-columns: auto 1fr auto; gap: 18px; align-items: center; padding: 14px 20px; border-bottom: 1px solid var(--outline-variant); }
.lp-root .ch.dark .levels .row { border-bottom: 1px solid rgba(255,255,255,0.08); }
.lp-root .levels .row:last-child { border-bottom: 0; }
.lp-root .levels .rank { font-family: var(--font-headline); font-style: italic; font-weight: 700; font-size: 18px; color: var(--tertiary-fixed-dim); letter-spacing: 0.03em; width: 36px; }
.lp-root .levels .nm { font-family: var(--font-headline); font-weight: 700; font-size: 16.5px; color: var(--primary); letter-spacing: -0.01em; }
.lp-root .ch.dark .levels .nm { color: var(--on-primary); }
.lp-root .levels .nm small { display: block; font-family: var(--font-body); font-style: normal; font-weight: 500; font-size: 12px; color: var(--on-surface-variant); letter-spacing: 0; margin-top: 3px; }
.lp-root .ch.dark .levels .nm small { color: rgba(255,255,255,0.6); }
.lp-root .levels .src { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 11px; font-weight: 600; color: var(--on-tertiary-fixed-variant); letter-spacing: 0.02em; text-align: right; }
.lp-root .ch.dark .levels .src { color: rgba(233,193,118,0.78); }
.lp-root .levels .lvl-head { padding: 14px 20px; font-size: 10px; font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase; color: var(--on-tertiary-fixed-variant); background: var(--surface-container-low); border-bottom: 1px solid var(--outline-variant); }
.lp-root .ch.dark .levels .lvl-head { background: rgba(255,255,255,0.02); color: var(--tertiary-fixed-dim); border-bottom: 1px solid rgba(255,255,255,0.08); }

/* CASE TABS panel */
.lp-root .tabs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--outline-variant); }
.lp-root .ch.dark .tabs { background: rgba(255,255,255,0.10); }
.lp-root .tabs .t { background: var(--surface-container-lowest); padding: 18px 18px 16px; display: flex; flex-direction: column; gap: 6px; }
.lp-root .ch.dark .tabs .t { background: rgba(255,255,255,0.03); }
.lp-root .tabs .t .ic { color: var(--primary); font-size: 20px; margin-bottom: 6px; }
.lp-root .ch.dark .tabs .t .ic { color: var(--tertiary-fixed-dim); }
.lp-root .tabs .t .nm { font-family: var(--font-headline); font-weight: 700; font-size: 14.5px; color: var(--primary); letter-spacing: -0.005em; line-height: 1.15; }
.lp-root .ch.dark .tabs .t .nm { color: var(--on-primary); }
.lp-root .tabs .t .ds { font-size: 12px; line-height: 1.45; color: var(--on-surface-variant); }
.lp-root .ch.dark .tabs .t .ds { color: rgba(255,255,255,0.65); }
.lp-root .tabs .t.feat { background: var(--primary); color: var(--on-primary); }
.lp-root .tabs .t.feat .nm { color: var(--on-primary); }
.lp-root .tabs .t.feat .ic { color: var(--tertiary-fixed-dim); }
.lp-root .tabs .t.feat .ds { color: rgba(255,255,255,0.7); }

/* 3-PASS STRATEGY */
.lp-root .pass { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--outline-variant); }
.lp-root .pass .p { background: var(--surface-container-lowest); padding: 24px; position: relative; }
.lp-root .pass .p .ord { font-family: var(--font-headline); font-style: italic; font-weight: 700; font-size: 14px; color: var(--tertiary-fixed-dim); letter-spacing: 0.04em; display: block; margin-bottom: 8px; }
.lp-root .pass .p .h { font-family: var(--font-headline); font-weight: 700; font-size: 18px; color: var(--primary); margin: 0 0 10px; letter-spacing: -0.01em; }
.lp-root .pass .p .ds { font-size: 13px; line-height: 1.55; color: var(--on-surface-variant); }
.lp-root .pass .p.adv { background: var(--primary); color: var(--on-primary); }
.lp-root .pass .p.adv .h { color: var(--on-primary); }
.lp-root .pass .p.adv .ds { color: rgba(255,255,255,0.78); }

/* DOC TYPES grid (dark chapter) */
.lp-root .docs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(255,255,255,0.10); }
.lp-root .docs .d { background: rgba(255,255,255,0.04); padding: 24px 22px; }
.lp-root .docs .d .ic { color: var(--tertiary-fixed-dim); font-size: 22px; margin-bottom: 10px; }
.lp-root .docs .d h4 { font-family: var(--font-headline); font-weight: 700; font-size: 18px; color: var(--on-primary); margin: 0 0 8px; letter-spacing: -0.01em; }
.lp-root .docs .d p { font-size: 13px; line-height: 1.5; color: rgba(255,255,255,0.7); margin: 0; }

/* EMAIL pipeline */
.lp-root .pipe { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--outline-variant); border: 1px solid var(--outline-variant); }
.lp-root .pipe .s { background: var(--surface-container-lowest); padding: 24px 22px; position: relative; }
.lp-root .pipe .s .ord { font-family: var(--font-headline); font-style: italic; font-weight: 700; font-size: 13px; color: var(--tertiary-fixed-dim); letter-spacing: 0.04em; display: block; margin-bottom: 6px; }
.lp-root .pipe .s .h { font-family: var(--font-headline); font-weight: 700; font-size: 17px; color: var(--primary); margin: 0 0 10px; letter-spacing: -0.01em; }
.lp-root .pipe .s .ds { font-size: 13px; line-height: 1.55; color: var(--on-surface-variant); }
.lp-root .pipe .s .ds b { color: var(--primary); font-weight: 700; }

/* INTEGRATIONS strip */
.lp-root .ints { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--outline-variant); border: 1px solid var(--outline-variant); }
.lp-root .ints .i { background: var(--surface-container-lowest); padding: 22px 20px; }
.lp-root .ints .i .ic { color: var(--primary); font-size: 22px; margin-bottom: 10px; }
.lp-root .ints .i .nm { font-family: var(--font-headline); font-weight: 700; font-size: 14.5px; color: var(--primary); letter-spacing: -0.005em; margin-bottom: 4px; }
.lp-root .ints .i .ds { font-size: 12px; line-height: 1.45; color: var(--on-surface-variant); }

/* SECTION FOOT */
.lp-root .secfoot { margin-top: 48px; padding: 24px 0 0; border-top: 1px solid var(--outline-variant); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.lp-root .ch.dark .secfoot { border-top: 1px solid rgba(255,255,255,0.10); }
.lp-root .secfoot .quote { font-family: var(--font-headline); font-style: italic; font-size: 16px; color: var(--primary); max-width: 54ch; letter-spacing: -0.005em; margin: 0; }
.lp-root .ch.dark .secfoot .quote { color: rgba(255,255,255,0.78); }
.lp-root .secfoot .quote b { font-style: normal; font-weight: 700; }
.lp-root .ch.dark .secfoot .quote b { color: var(--on-primary); }
.lp-root .secfoot a { font-family: var(--font-body); font-weight: 700; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--primary); display: inline-flex; align-items: center; gap: 6px; }
.lp-root .ch.dark .secfoot a { color: var(--tertiary-fixed-dim); }
.lp-root .secfoot a .ico { font-size: 14px; }

/* TRIGGER LIST */
.lp-root .trig { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(255,255,255,0.10); }
.lp-root .trig .t { background: rgba(255,255,255,0.04); padding: 24px; }
.lp-root .trig .t .when { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 11px; color: var(--tertiary-fixed-dim); letter-spacing: 0.04em; display: block; margin-bottom: 10px; }
.lp-root .trig .t .h { font-family: var(--font-headline); font-weight: 700; font-size: 17px; color: var(--on-primary); margin: 0 0 8px; letter-spacing: -0.01em; }
.lp-root .trig .t .ds { font-size: 13px; line-height: 1.55; color: rgba(255,255,255,0.72); }
.lp-root .trig .t .ds b { color: var(--on-primary); font-weight: 700; }

/* CLIENT-PORTAL (inline panel under integrations) */
.lp-root .portal-card { padding: 24px 28px; }
.lp-root .portal-card .greet { font-family: var(--font-headline); font-style: italic; font-weight: 500; font-size: 18px; color: var(--primary); margin: 0 0 8px; }
.lp-root .portal-card .intro { font-size: 14px; color: var(--on-surface-variant); margin: 0 0 22px; line-height: 1.55; }
.lp-root .portal-card .item { display: grid; grid-template-columns: auto 1fr auto; gap: 14px; align-items: center; padding: 12px 0; border-top: 1px solid var(--outline-variant); }
.lp-root .portal-card .item:last-of-type { border-bottom: 1px solid var(--outline-variant); }
.lp-root .portal-card .item .ico { color: var(--primary); }
.lp-root .portal-card .item .body { font-size: 13px; color: var(--on-surface); }
.lp-root .portal-card .item .body b { color: var(--primary); font-weight: 700; }
.lp-root .portal-card .item .when { font-family: var(--font-body); font-size: 10px; font-weight: 700; letter-spacing: 0.18em; color: var(--on-tertiary-fixed-variant); }
.lp-root .portal-card .seal { font-size: 11px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--on-tertiary-fixed-variant); margin: 18px 0 0; }

/* FINAL CTA */
.lp-root .cta { padding: 120px 32px; background: var(--primary); color: var(--on-primary); text-align: center; }
.lp-root .cta h2 { font-family: var(--font-headline); font-weight: 700; font-size: clamp(38px, 4.2vw, 60px); line-height: 1.05; letter-spacing: -0.025em; color: var(--on-primary); margin: 0 0 24px; text-wrap: balance; max-width: 24ch; margin-inline: auto; }
.lp-root .cta h2 em { font-style: italic; font-weight: 400; color: var(--tertiary-fixed-dim); }
.lp-root .cta .body { font-size: 17px; line-height: 1.6; color: rgba(255,255,255,0.78); margin: 0 auto 36px; max-width: 52ch; }
.lp-root .cta .ctas { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }

.lp-root .btn { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-body); font-weight: 700; font-size: 14px; padding: 16px 28px; border: 0; cursor: pointer; transition: all 200ms; text-decoration: none; letter-spacing: 0.01em; }
.lp-root .btn-gold { background: var(--tertiary-fixed-dim); color: var(--primary); }
.lp-root .btn-gold:hover { transform: translateY(-2px); }
.lp-root .btn-on-dark { background: var(--on-primary); color: var(--primary); }
.lp-root .btn-outline-light { background: transparent; border: 1px solid rgba(255,255,255,0.4); color: var(--on-primary); padding: 15px 27px; }
.lp-root .btn-outline-light:hover { background: var(--on-primary); color: var(--primary); }

/* FOOTER */
.lp-root footer.lp { background: #06111d; color: #cbd5e1; padding: 56px 32px 32px; }
.lp-root footer.lp .grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 48px; max-width: 1320px; margin: 0 auto; }
.lp-root footer.lp .brand { font-family: var(--font-headline); font-weight: 700; font-size: 26px; color: #fff; margin-bottom: 10px; letter-spacing: -0.015em; }
.lp-root footer.lp .ety { font-family: var(--font-headline); font-style: italic; font-size: 14px; line-height: 1.6; color: #94a3b8; max-width: 48ch; margin: 0; }
.lp-root footer.lp .ety b { color: var(--tertiary-fixed-dim); font-style: normal; font-weight: 700; }
.lp-root footer.lp h5 { font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: #94a3b8; margin: 0 0 14px; font-weight: 700; }
.lp-root footer.lp ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.lp-root footer.lp ul a { font-size: 13.5px; color: #cbd5e1; }
.lp-root footer.lp ul a:hover { color: var(--tertiary-fixed-dim); }
.lp-root footer.lp .colofon { max-width: 1320px; margin: 36px auto 0; padding-top: 22px; border-top: 1px solid rgba(255,255,255,0.08); font-size: 11px; color: #64748b; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
.lp-root footer.lp .colofon a:hover { color: var(--tertiary-fixed-dim); }

@media (max-width: 1100px) {
    .lp-root .ch .grid2, .lp-root .ch .grid2.flip { grid-template-columns: 1fr; gap: 48px; }
    .lp-root .toc .grid { grid-template-columns: repeat(3, 1fr); }
    .lp-root .tabs, .lp-root .docs, .lp-root .pipe, .lp-root .pass, .lp-root .ints, .lp-root .trig { grid-template-columns: 1fr 1fr; }
    .lp-root footer.lp .grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
    .lp-root .ph { padding: 56px 20px 32px; }
    .lp-root .ph h1 { font-size: clamp(34px, 9vw, 52px); }
    .lp-root .ph .lead { font-size: 16px; }

    .lp-root .toc { padding: 24px 20px 48px; }
    .lp-root .toc .grid { grid-template-columns: repeat(2, 1fr); }
    .lp-root .toc a { padding: 14px 14px; }

    .lp-root .ch { padding: 64px 20px; }
    .lp-root .ch .h { grid-template-columns: 1fr; gap: 12px; margin-bottom: 32px; }
    .lp-root .ch .h .num { font-size: 72px; }
    .lp-root .ch .h h2 { font-size: clamp(28px, 7vw, 38px); }
    .lp-root .ch h3 { font-size: clamp(22px, 6vw, 28px); }

    .lp-root .panel .top { padding: 12px 16px; flex-wrap: wrap; gap: 8px; }
    .lp-root .panel .top .crumb { font-size: 12px; }
    .lp-root .panel .top .stat { margin-left: 0; }
    .lp-root .levels .row { padding: 12px 16px; gap: 12px; }
    .lp-root .levels .row .src { font-size: 10px; }
    .lp-root .levels .lvl-head { padding: 12px 16px; }

    .lp-root .tabs, .lp-root .docs, .lp-root .pipe, .lp-root .pass, .lp-root .ints, .lp-root .trig { grid-template-columns: 1fr; }
    .lp-root .tabs .t, .lp-root .docs .d, .lp-root .pipe .s, .lp-root .pass .p, .lp-root .ints .i, .lp-root .trig .t { padding: 20px 18px; }

    .lp-root .portal-card { padding: 18px 20px; }
    .lp-root .portal-card .item { grid-template-columns: auto 1fr; row-gap: 4px; }
    .lp-root .portal-card .item .when { grid-column: 2 / 3; justify-self: start; }

    .lp-root .secfoot { gap: 14px; padding-top: 20px; }
    .lp-root .secfoot .quote { font-size: 14.5px; }

    .lp-root .cta { padding: 80px 20px; }
    .lp-root .cta h2 { font-size: clamp(28px, 8vw, 44px); }
    .lp-root .cta .body { font-size: 16px; }

    .lp-root nav.lp .inner { padding: 12px 16px; flex-wrap: wrap; gap: 10px 14px; }
    .lp-root nav.lp .links { order: 3; flex-basis: 100%; justify-content: center; gap: 18px; }
    .lp-root nav.lp .links a { font-size: 13px; }
    .lp-root nav.lp a.cta { padding: 10px 16px; font-size: 12px; }

    .lp-root footer.lp { padding: 40px 20px 24px; }
    .lp-root footer.lp .grid { grid-template-columns: 1fr 1fr; gap: 32px; }
    .lp-root footer.lp .colofon { flex-direction: column; gap: 6px; }
}
@media (max-width: 420px) {
    .lp-root .toc .grid { grid-template-columns: 1fr; }
    .lp-root .ph h1 { font-size: clamp(28px, 11vw, 40px); }
    .lp-root .ch .h .num { font-size: 56px; }
    .lp-root .ch .h h2 { font-size: clamp(24px, 8vw, 32px); }
    .lp-root footer.lp .grid { grid-template-columns: 1fr; gap: 24px; }
    .lp-root .levels .nm { font-size: 14.5px; }
    .lp-root .levels .nm small { font-size: 11px; }
}

/* ═══════════════════════════════════════════════════
   MODPARTSANALYSE-SPECIFIC CLASSES
   (classes below are used only on /modpartsanalyse)
═══════════════════════════════════════════════════ */

/* LOGO IMAGE */
.lp-root nav.lp .logo-img  { height: 28px; width: auto; display: block; }
.lp-root footer.lp .logo-img { height: 32px; width: auto; display: block; filter: brightness(0) invert(1); }

/* RANK COLOURS */
.lp-root .levels .rank.red   { color: #d4615a; }
.lp-root .levels .rank.amber { color: var(--tertiary-fixed-dim); }
.lp-root .levels .rank.green { color: #52a87e; }
.lp-root .levels .src.gold   { color: var(--tertiary-fixed-dim); }

/* PROOF BAR (header trust strip) */
.lp-root .proof-bar { display: flex; gap: 24px; flex-wrap: wrap; margin-top: 28px; }
.lp-root .proof-bar span { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; letter-spacing: 0.05em; color: var(--on-surface-variant); }
.lp-root .proof-bar span .ico { font-size: 15px; color: var(--on-tertiary-fixed-variant); }

/* DEEP — light chapter section */
.lp-root .deep { padding: 96px 32px; border-top: 1px solid var(--outline-variant); }
.lp-root .deep.alt { background: var(--surface-container-low); }

/* ANON — dark chapter section */
.lp-root .anon { padding: 96px 32px; background: var(--primary); color: var(--on-primary); border-top: 1px solid var(--outline-variant); }

/* SEC-HEAD — section header (num + title-block) */
.lp-root .sec-head { display: grid; grid-template-columns: auto 1fr; gap: 48px; align-items: flex-end; margin-bottom: 48px; max-width: 1320px; margin-inline: auto; }
.lp-root .sec-head .num { font-family: var(--font-headline); font-style: italic; font-weight: 700; font-size: 80px; line-height: 0.85; color: var(--tertiary-fixed-dim); letter-spacing: -0.04em; opacity: 0.55; }
.lp-root .sec-head .eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase; color: var(--on-tertiary-fixed-variant); margin: 0 0 14px; display: block; }
.lp-root .anon .sec-head .eyebrow { color: rgba(233,193,118,0.78); }
.lp-root .sec-head h2 { font-family: var(--font-headline); font-weight: 700; font-size: clamp(34px, 3.8vw, 52px); line-height: 1.05; letter-spacing: -0.022em; color: var(--primary); margin: 0 0 16px; max-width: 22ch; text-wrap: balance; }
.lp-root .anon .sec-head h2 { color: var(--on-primary); }
.lp-root .sec-head h2 em { font-style: italic; font-weight: 400; }
.lp-root .anon .sec-head h2 em { color: var(--tertiary-fixed-dim); }
.lp-root .sec-head .sub { font-size: 17px; line-height: 1.55; color: var(--on-surface-variant); max-width: 64ch; margin: 0; }
.lp-root .anon .sec-head .sub { color: rgba(255,255,255,0.72); }

/* GRID — 2-column layout */
.lp-root .deep .grid,
.lp-root .anon .grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; max-width: 1320px; margin-inline: auto; }
.lp-root .deep .grid.flip { direction: rtl; }
.lp-root .deep .grid.flip > * { direction: ltr; }

/* h3 / body inside deep/anon */
.lp-root .deep h3,
.lp-root .anon h3 { font-family: var(--font-headline); font-weight: 700; font-size: clamp(24px, 2.4vw, 32px); line-height: 1.15; letter-spacing: -0.014em; color: var(--primary); margin: 0 0 16px; text-wrap: balance; }
.lp-root .anon h3 { color: var(--on-primary); }
.lp-root .deep h3 em, .lp-root .anon h3 em { font-style: italic; font-weight: 400; }
.lp-root .anon h3 em { color: var(--tertiary-fixed-dim); }
.lp-root .deep p.body,
.lp-root .anon p.body { font-size: 16px; line-height: 1.65; color: var(--on-surface-variant); margin: 0 0 22px; max-width: 54ch; }
.lp-root .anon p.body { color: rgba(255,255,255,0.78); }

/* .points inside anon (dark context) */
.lp-root .anon .points { border-top-color: rgba(255,255,255,0.10); }
.lp-root .anon .points li { border-bottom-color: rgba(255,255,255,0.08); }
.lp-root .anon .points li .ico { color: var(--tertiary-fixed-dim); }
.lp-root .anon .points li .txt { color: rgba(255,255,255,0.85); }
.lp-root .anon .points li .txt b { color: var(--on-primary); }

/* PIPELINE (.pipe) — override 3-col grid to vertical stack */
.lp-root .anon .pipe { display: block; border: 1px solid rgba(255,255,255,0.12); background: transparent; }
.lp-root .anon .pipe .stage { background: rgba(255,255,255,0.03); padding: 24px 22px; border-bottom: 1px solid rgba(255,255,255,0.08); }
.lp-root .anon .pipe .stage:last-child { border-bottom: 0; }
.lp-root .anon .pipe .stage .head { display: flex; align-items: baseline; gap: 10px; margin-bottom: 10px; }
.lp-root .anon .pipe .stage .head .num { font-family: var(--font-headline); font-style: italic; font-weight: 700; font-size: 15px; color: var(--tertiary-fixed-dim); letter-spacing: 0.03em; }
.lp-root .anon .pipe .stage .head .lbl { font-size: 10px; font-weight: 700; letter-spacing: 0.20em; text-transform: uppercase; color: rgba(255,255,255,0.5); }
.lp-root .anon .pipe .stage .h { font-family: var(--font-headline); font-weight: 700; font-size: 15px; color: var(--on-primary); margin: 0 0 8px; letter-spacing: -0.01em; }
.lp-root .anon .pipe .stage .text { font-size: 13px; line-height: 1.55; color: rgba(255,255,255,0.72); }
.lp-root .anon .pipe .stage.boundary { padding: 10px 22px; background: rgba(255,255,255,0.04); border-bottom-color: rgba(255,255,255,0.08); }
.lp-root .anon .pipe .stage .b-row { display: flex; align-items: center; justify-content: space-between; font-size: 10px; font-weight: 700; letter-spacing: 0.20em; text-transform: uppercase; color: rgba(255,255,255,0.5); }
.lp-root .anon .pipe .stage .b-row .ico { font-size: 15px; }

/* PROOF STATS STRIP */
.lp-root .proof { padding: 64px 32px; background: var(--surface-container-low); border-top: 1px solid var(--outline-variant); }
.lp-root .proof .row { display: flex; gap: 48px; align-items: center; flex-wrap: wrap; max-width: 1320px; margin: 0 auto; }
.lp-root .proof .lede { font-size: 15px; line-height: 1.65; color: var(--on-surface-variant); max-width: 44ch; flex: 1 1 280px; margin: 0; }
.lp-root .proof .lede b { color: var(--primary); font-weight: 700; }
.lp-root .proof .stat { display: flex; flex-direction: column; gap: 4px; }
.lp-root .proof .stat .num { font-family: var(--font-headline); font-weight: 700; font-size: clamp(32px, 3vw, 48px); line-height: 1; letter-spacing: -0.025em; color: var(--primary); }
.lp-root .proof .stat .lbl { font-size: 10px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--on-surface-variant); max-width: 14ch; }

/* FINAL CTA SECTION */
.lp-root section.final { padding: 120px 32px; background: var(--primary); color: var(--on-primary); border-top: 1px solid rgba(255,255,255,0.06); }
.lp-root section.final .inner { max-width: 1320px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.lp-root section.final .num { font-family: var(--font-headline); font-style: italic; font-weight: 700; font-size: 13px; color: var(--tertiary-fixed-dim); letter-spacing: 0.04em; display: block; margin-bottom: 16px; }
.lp-root section.final h2 { font-family: var(--font-headline); font-weight: 700; font-size: clamp(34px, 3.6vw, 52px); line-height: 1.05; letter-spacing: -0.022em; color: var(--on-primary); margin: 0 0 20px; text-wrap: balance; }
.lp-root section.final h2 em { font-style: italic; font-weight: 400; color: var(--tertiary-fixed-dim); }
.lp-root section.final p.body { font-size: 16px; line-height: 1.65; color: rgba(255,255,255,0.78); margin: 0 0 28px; max-width: 52ch; }
.lp-root section.final .ctas { display: flex; gap: 14px; flex-wrap: wrap; }
.lp-root section.final .micro { display: flex; gap: 20px; flex-wrap: wrap; margin-top: 24px; }
.lp-root section.final .micro span { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: rgba(255,255,255,0.65); }
.lp-root section.final .micro span .ico { font-size: 15px; color: rgba(255,255,255,0.40); }

/* PROOF CARD (aside.card) */
.lp-root aside.card { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.14); padding: 28px; align-self: start; }
.lp-root aside.card .legend { font-size: 10px; font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(255,255,255,0.45); margin: 0 0 16px; }
.lp-root aside.card .channels { list-style: none; margin: 0; padding: 0; }
.lp-root aside.card .channels li { display: grid; grid-template-columns: 8rem 1fr; gap: 10px; padding: 11px 0; border-top: 1px solid rgba(255,255,255,0.08); align-items: baseline; }
.lp-root aside.card .channels li:last-child { border-bottom: 1px solid rgba(255,255,255,0.08); }
.lp-root aside.card .channels .lbl { font-size: 10px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.40); }
.lp-root aside.card .channels .val { font-size: 13px; line-height: 1.5; color: rgba(255,255,255,0.85); }

/* RESPONSIVE — modpartsanalyse */
@media (max-width: 1100px) {
    .lp-root .deep .grid,
    .lp-root .anon .grid,
    .lp-root section.final .inner { grid-template-columns: 1fr; gap: 48px; }
    .lp-root .deep .grid.flip { direction: ltr; }
    .lp-root .sec-head { grid-template-columns: 1fr; gap: 12px; }
    .lp-root .sec-head .num { font-size: 56px; }
}
@media (max-width: 760px) {
    .lp-root .deep, .lp-root .anon { padding: 64px 20px; }
    .lp-root .proof { padding: 48px 20px; }
    .lp-root section.final { padding: 80px 20px; }
    .lp-root .proof .row { gap: 28px; }
    .lp-root section.final .ctas { flex-direction: column; }
    .lp-root section.final .micro { gap: 14px; }
    .lp-root aside.card .channels li { grid-template-columns: 6rem 1fr; }
}


/* ── PRODUCT SCREENSHOTS ──────────────────────────────────────────────────── */
.lp-root figure.product-shot {
    margin: 0;
    line-height: 0;
}
.lp-root figure.product-shot .screen-img {
    display: block;
    width: 100%;
    max-width: 680px;
    height: auto;
    border-radius: 10px;
    box-shadow: 0 4px 32px rgba(0,0,0,.18), 0 1px 6px rgba(0,0,0,.10);
    border: 1px solid rgba(255,255,255,0.08);
}
.lp-root .grid2 figure.product-shot,
.lp-root .grid.flip figure.product-shot { margin: 0 auto; }

/* LOGO IMAGE */
.lp-root nav.lp .logo-img  { height: 28px; width: auto; display: block; }
.lp-root footer.lp .logo-img { height: 32px; width: auto; display: block; filter: brightness(0) invert(1); }
