:root {
    --bg: #efe6d7;
    --bg-soft: #f8f2e8;
    --bg-deep: #1a120d;
    --panel: rgba(255, 250, 242, 0.9);
    --panel-strong: rgba(255, 252, 247, 0.98);
    --text: #20120d;
    --muted: #725f4e;
    --line: rgba(119, 83, 51, 0.22);
    --line-strong: rgba(119, 83, 51, 0.36);
    --wine: #7a1f24;
    --gold: #c8904c;
    --ink: #0b0907;
    --cyan: #7a1f24;
    --violet: #7a1f24;
    --amber: #c8904c;
    --success: #2f6d42;
    --shell: min(1380px, calc(100vw - 44px));
    --radius-xl: 8px;
    --radius-lg: 8px;
    --radius-md: 8px;
    --shadow-lg: 0 32px 90px rgba(63, 39, 20, 0.18);
    --shadow-md: 0 18px 44px rgba(63, 39, 20, 0.14);
}

/* Landing v2: light-first public homepage redesign. */
.landing-v2 {
    --bg: #fbf7ef;
    --bg-soft: #f4eadb;
    --bg-deep: #1f130d;
    --panel: #fffdf8;
    --panel-strong: #ffffff;
    --text: #1e130e;
    --muted: #735f4e;
    --line: rgba(97, 67, 43, 0.2);
    --line-strong: rgba(97, 67, 43, 0.34);
    --wine: #741f25;
    --gold: #ba7a33;
    --green: #2f6f45;
    --shell: min(1240px, calc(100vw - 48px));
    color: var(--text);
    background:
        linear-gradient(180deg, #fbf7ef 0%, #f5ecdf 54%, #fbf7ef 100%);
}

body.landing-page {
    color: #1e130e;
    background: #fbf7ef !important;
}

.landing-v2 *,
.landing-v2 *::before,
.landing-v2 *::after {
    letter-spacing: 0;
}

.landing-v2 .site-header {
    background: rgba(251, 247, 239, 0.88);
    border-bottom-color: rgba(97, 67, 43, 0.16);
}

.landing-v2 .nav-shell {
    padding: 0.9rem 0;
}

.landing-v2 .brand-mark {
    border-radius: 10px;
    border-color: rgba(116, 31, 37, 0.22);
    background: #fffaf2;
    color: var(--wine);
}

.landing-v2 .brand-copy strong {
    font-family: "Syne", sans-serif;
    font-size: 1.1rem;
    font-weight: 800;
}

.landing-v2 .brand-copy span {
    color: var(--muted);
}

.landing-v2 .site-nav {
    gap: 1.2rem;
}

.landing-v2 .site-nav a {
    color: rgba(30, 19, 14, 0.78);
    font-size: 0.94rem;
    font-weight: 800;
}

.landing-v2 .site-nav a:hover {
    color: var(--wine);
}

.landing-v2 .nav-app {
    border-radius: 10px;
    border-color: rgba(116, 31, 37, 0.22);
    background: #fffaf2;
    color: var(--wine);
}

.lp-hero {
    position: relative;
    min-height: auto;
    padding: clamp(2.6rem, 4.8vw, 4.5rem) 0 clamp(0.8rem, 1.8vw, 1.4rem);
    overflow: clip;
    background:
        radial-gradient(circle at 84% 20%, rgba(186, 122, 51, 0.2), transparent 24rem),
        linear-gradient(180deg, #fbf7ef 0%, #f3e6d4 100%);
}

.lp-hero-grid {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(97, 67, 43, 0.07) 1px, transparent 1px),
        linear-gradient(90deg, rgba(97, 67, 43, 0.07) 1px, transparent 1px);
    background-size: 3.5rem 3.5rem;
    mask-image: linear-gradient(90deg, rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.95) 55%, rgba(0, 0, 0, 0.55));
    pointer-events: none;
}

.lp-hero-shell {
    position: relative;
    display: grid;
    grid-template-columns: minmax(31rem, 0.95fr) minmax(31rem, 1.05fr);
    gap: clamp(2rem, 3.6vw, 3.8rem);
    align-items: center;
}

.lp-hero-copy {
    max-width: 39rem;
}

.lp-hero-copy h1 {
    margin: 0;
    font-family: "Syne", sans-serif;
    font-size: clamp(2.8rem, 4.45vw, 4.75rem);
    line-height: 0.94;
    font-weight: 800;
    color: var(--text);
}

.lp-hero-copy p {
    margin: 1.1rem 0 0;
    max-width: 35rem;
    color: var(--muted);
    font-size: clamp(1.02rem, 1.35vw, 1.22rem);
    line-height: 1.65;
}

.landing-v2 .hero-actions,
.landing-v2 .access-actions {
    gap: 0.8rem;
    margin-top: 1.45rem;
}

.landing-v2 .btn {
    min-height: 3.35rem;
    border-radius: 10px;
    padding: 0.9rem 1.25rem;
    font-size: 0.95rem;
    font-weight: 850;
}

.landing-v2 .btn-primary {
    background: var(--wine);
    color: #fffaf2;
    box-shadow: 0 18px 34px rgba(116, 31, 37, 0.22);
}

.landing-v2 .btn-secondary {
    border-color: rgba(97, 67, 43, 0.22);
    background: rgba(255, 253, 248, 0.74);
    color: var(--text);
}

.lp-hero-proof {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem 1rem;
    margin-top: 1.25rem;
    color: rgba(30, 19, 14, 0.74);
    font-size: 0.92rem;
    font-weight: 800;
}

.lp-hero-proof span {
    display: flex;
    align-items: center;
    gap: 0.55rem;
}

.lp-hero-proof span::before {
    content: "";
    width: 0.45rem;
    height: 0.45rem;
    border-radius: 50%;
    background: var(--gold);
}

.lp-command-center {
    position: relative;
    min-width: 0;
    max-width: 41rem;
    margin-left: auto;
    border: 1px solid rgba(97, 67, 43, 0.2);
    border-radius: 18px;
    background: rgba(255, 253, 248, 0.82);
    box-shadow: 0 34px 90px rgba(83, 52, 29, 0.2);
    overflow: hidden;
    backdrop-filter: blur(14px);
}

.lp-command-top {
    min-height: 4rem;
    display: flex;
    align-items: center;
    gap: 0.8rem;
    padding: 0.85rem 1rem;
    border-bottom: 1px solid rgba(97, 67, 43, 0.14);
    background: rgba(244, 234, 219, 0.8);
}

.lp-command-top strong {
    font-size: 0.98rem;
}

.lp-command-top span:last-child {
    margin-left: auto;
    color: var(--muted);
    font-size: 0.86rem;
    font-weight: 800;
}

.lp-command-body {
    display: grid;
    grid-template-columns: 10.5rem minmax(0, 1fr);
}

.lp-command-nav {
    display: grid;
    align-content: start;
    gap: 0.45rem;
    padding: 1rem;
    border-right: 1px solid rgba(97, 67, 43, 0.14);
    background: rgba(239, 222, 201, 0.62);
}

.lp-command-nav span {
    padding: 0.7rem 0.8rem;
    border-radius: 10px;
    color: rgba(30, 19, 14, 0.7);
    font-size: 0.86rem;
    font-weight: 850;
}

.lp-command-nav .is-active {
    background: rgba(116, 31, 37, 0.11);
    color: var(--wine);
}

.lp-command-main {
    display: grid;
    gap: 1rem;
    padding: 1rem;
}

.lp-decision-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.lp-decision-header span,
.lp-decision-cards span {
    color: var(--wine);
    font-family: "IBM Plex Mono", monospace;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
}

.lp-decision-header h2 {
    margin: 0.25rem 0 0;
    font-size: clamp(1.45rem, 2vw, 2.15rem);
    line-height: 1.05;
}

.lp-decision-header > strong {
    flex: 0 0 auto;
    padding: 0.55rem 0.72rem;
    border-radius: 10px;
    background: rgba(47, 111, 69, 0.12);
    color: var(--green);
    font-size: 0.84rem;
}

.lp-decision-cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.lp-decision-cards article {
    min-height: 7rem;
    display: grid;
    align-content: space-between;
    gap: 0.5rem;
    padding: 0.95rem;
    border: 1px solid rgba(97, 67, 43, 0.16);
    border-radius: 14px;
    background: #fffdf8;
}

.lp-decision-cards article.is-selected {
    border-color: rgba(116, 31, 37, 0.32);
    background: #fff7ec;
}

.lp-decision-cards strong {
    font-size: clamp(1.25rem, 2vw, 2rem);
}

.lp-decision-cards small {
    color: var(--muted);
    font-weight: 700;
}

.lp-readiness-table {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) 0.65fr 0.8fr;
    border: 1px solid rgba(97, 67, 43, 0.16);
    border-radius: 14px;
    overflow: hidden;
    background: #fffdf8;
}

.lp-readiness-table span,
.lp-readiness-table strong {
    min-width: 0;
    padding: 0.68rem 0.75rem;
    border-right: 1px solid rgba(97, 67, 43, 0.1);
    border-bottom: 1px solid rgba(97, 67, 43, 0.1);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.lp-readiness-table span {
    background: #efe0cd;
    color: rgba(30, 19, 14, 0.82);
    font-size: 0.72rem;
    font-weight: 900;
    text-transform: uppercase;
}

.lp-readiness-table strong {
    font-size: 0.86rem;
}

.lp-readiness-table .warn {
    color: #9f5d14;
}

.lp-readiness-table .ok {
    color: var(--green);
}

.lp-strip {
    padding: 0.9rem 0;
    background: #1f130d;
    color: #fff9ef;
}

.lp-strip-inner {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.lp-strip-inner div {
    display: grid;
    gap: 0.35rem;
    padding: 1rem 0;
}

.lp-strip-inner strong {
    font-size: 1.15rem;
}

.lp-strip-inner span {
    color: rgba(255, 249, 239, 0.72);
}

.lp-section {
    padding: clamp(4.5rem, 8vw, 7rem) 0;
}

.lp-split,
.lp-proof-shell {
    display: grid;
    grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr);
    gap: clamp(2rem, 6vw, 5rem);
    align-items: start;
}

.lp-section-copy h2,
.lp-section-heading h2,
.lp-proof-copy h2,
.lp-cta h2 {
    margin: 0;
    font-family: "Syne", sans-serif;
    font-size: clamp(2.1rem, 4vw, 4.2rem);
    line-height: 0.96;
}

.lp-section-copy p,
.lp-section-heading p,
.lp-proof-copy p,
.lp-cta p {
    margin: 1rem 0 0;
    color: var(--muted);
    font-size: 1.05rem;
    line-height: 1.72;
}

.lp-workflow-list {
    display: grid;
    gap: 0;
    border-top: 1px solid var(--line);
}

.lp-workflow-list article {
    display: grid;
    grid-template-columns: 3rem minmax(0, 1fr);
    gap: 1.2rem;
    padding: 1.35rem 0;
    border-bottom: 1px solid var(--line);
}

.lp-workflow-list article > span {
    color: var(--wine);
    font-family: "IBM Plex Mono", monospace;
    font-size: 0.78rem;
    font-weight: 700;
}

.lp-workflow-list h3,
.lp-system-grid h3 {
    margin: 0;
    font-size: clamp(1.2rem, 1.8vw, 1.65rem);
}

.lp-workflow-list p,
.lp-system-grid p {
    margin: 0.45rem 0 0;
    color: var(--muted);
    line-height: 1.65;
}

.lp-operating-system {
    background: #fffdf8;
    border-block: 1px solid rgba(97, 67, 43, 0.13);
}

.lp-section-heading {
    max-width: 58rem;
}

.lp-system-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px;
    margin-top: 2.4rem;
    background: var(--line);
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
}

.lp-system-grid article {
    min-height: 14rem;
    padding: 1.35rem;
    background: #fffaf2;
}

.lp-proof {
    background:
        linear-gradient(120deg, rgba(116, 31, 37, 0.06), transparent 44%),
        #f4eadb;
}

.lp-proof-rows {
    display: grid;
    gap: 0.8rem;
}

.lp-proof-rows div {
    display: grid;
    grid-template-columns: 7rem minmax(0, 1fr);
    gap: 1rem;
    align-items: center;
    padding: 1.05rem 1.15rem;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: rgba(255, 253, 248, 0.72);
}

.lp-proof-rows strong {
    color: var(--wine);
    font-family: "IBM Plex Mono", monospace;
    font-size: 0.75rem;
    text-transform: uppercase;
}

.lp-proof-rows span {
    font-size: clamp(1.25rem, 2.6vw, 2.15rem);
    font-weight: 800;
    line-height: 1.12;
}

.lp-cta {
    padding: clamp(4rem, 8vw, 6.5rem) 0;
    text-align: center;
}

.lp-cta-shell {
    max-width: 54rem;
}

.lp-cta .access-actions {
    justify-content: center;
}

.landing-v2 .partner-disclaimer-prominent {
    max-width: 46rem;
    margin: 1.4rem auto 0;
    border-color: rgba(186, 122, 51, 0.28);
    background: #fffaf2;
    color: rgba(30, 19, 14, 0.68);
    text-align: left;
}

.landing-footer {
    background: #1f130d;
    color: #fff9ef;
    border-top: 0;
}

.landing-footer .brand-mark {
    background: rgba(255, 249, 239, 0.08);
    border-color: rgba(255, 249, 239, 0.2);
    color: #f1b45f;
}

.landing-footer .brand-copy span,
.landing-footer .footer-brand p,
.landing-footer .footer-links a {
    color: rgba(255, 249, 239, 0.68);
}

.landing-footer .footer-links span {
    color: #f1b45f;
}

.landing-footer .footer-meta {
    border-top-color: rgba(255, 249, 239, 0.12);
    color: rgba(255, 249, 239, 0.62);
}

@media (max-width: 1120px) {
    .lp-hero-shell,
    .lp-split,
    .lp-proof-shell {
        grid-template-columns: 1fr;
    }

    .lp-command-center {
        max-width: 48rem;
    }

    .lp-system-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 860px) {
    .landing-v2 {
        --shell: min(100vw - 28px, 1240px);
    }

    .landing-v2 .site-nav {
        background: #fffdf8;
        border-color: rgba(97, 67, 43, 0.18);
    }

    .lp-hero {
        min-height: auto;
        padding-top: 3.3rem;
    }

    .lp-hero-copy h1 {
        font-size: clamp(2.55rem, 11vw, 4rem);
    }

    .lp-command-body {
        grid-template-columns: 1fr;
    }

    .lp-command-nav {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        border-right: 0;
        border-bottom: 1px solid rgba(97, 67, 43, 0.14);
    }

    .lp-command-nav span {
        text-align: center;
    }

    .lp-decision-cards,
    .lp-strip-inner,
    .lp-system-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 560px) {
    .lp-command-nav {
        grid-template-columns: 1fr 1fr;
    }

    .lp-decision-header {
        display: grid;
    }

    .lp-readiness-table {
        grid-template-columns: 1fr 0.7fr;
    }

    .lp-readiness-table span:nth-child(3),
    .lp-readiness-table strong:nth-child(3n) {
        display: none;
    }

    .lp-proof-rows div,
    .lp-workflow-list article {
        grid-template-columns: 1fr;
    }
}

body.landing-page {
    color: #1e130e;
    background: #fbf7ef !important;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    min-width: 320px;
    font-family: "Manrope", sans-serif;
    color: var(--text);
    background:
        linear-gradient(180deg, #efe6d7 0%, #f8f2e8 42%, #eadac6 100%);
    line-height: 1.55;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input,
textarea {
    font: inherit;
}

button {
    color: inherit;
}

.shell {
    width: var(--shell);
    margin: 0 auto;
}

.site-shell {
    position: relative;
    overflow-x: clip;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    backdrop-filter: blur(18px);
    background: rgba(239, 230, 215, 0.84);
    border-bottom: 1px solid rgba(119, 83, 51, 0.18);
}

.nav-shell {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.4rem;
    padding: 1rem 0;
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: 0.95rem;
}

.brand-mark {
    width: 2.85rem;
    height: 2.85rem;
    display: grid;
    place-items: center;
    border-radius: 8px;
    border: 1px solid rgba(122, 31, 36, 0.24);
    background: #fff7ec;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
    font-family: "Syne", sans-serif;
    font-weight: 700;
}

.brand-copy {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.brand-copy strong {
    font-family: "Syne", sans-serif;
    font-size: 1.12rem;
    letter-spacing: 0;
}

.brand-copy span {
    color: var(--muted);
    font-size: 0.9rem;
}

.site-nav {
    display: flex;
    align-items: center;
    gap: 1.35rem;
}

.site-nav a {
    color: rgba(32, 18, 13, 0.82);
    font-size: 0.97rem;
    font-weight: 600;
}

.site-nav a:hover {
    color: var(--text);
}

.nav-app {
    padding: 0.82rem 1.15rem;
    border-radius: 999px;
    border: 1px solid rgba(122, 31, 36, 0.22);
    background: rgba(255, 248, 238, 0.7);
}

.nav-toggle {
    display: none;
    width: 2.9rem;
    height: 2.9rem;
    padding: 0;
    border: 1px solid rgba(119, 83, 51, 0.22);
    border-radius: 8px;
    background: rgba(255, 248, 238, 0.76);
}

.nav-toggle span {
    display: block;
    width: 1.15rem;
    height: 2px;
    margin: 0.3rem auto;
    background: var(--text);
}

.hero {
    padding: 6rem 0 3rem;
}

.hero-intro {
    max-width: 64rem;
}

.eyebrow,
.label,
.access-points span,
.footer-links span,
.step-no,
.rung-tag,
.stage-caption span,
.stage-note span {
    font-family: "IBM Plex Mono", monospace;
    font-size: 0.74rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--wine);
    font-weight: 800;
}

.hero h1,
.section-heading h2,
.shift-copy h2,
.growth-header h2,
.access-copy h2,
.page-hero h1 {
    margin: 1.4rem 0 1rem;
    font-family: "Syne", sans-serif;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 0.98;
}

.hero h1 {
    max-width: 14ch;
    font-size: clamp(2.35rem, 4.35vw, 4.35rem);
}

.hero-lead,
.section-heading p,
.shift-copy p,
.access-copy p,
.editorial-panel p,
.timeline-step p,
.growth-rung p,
.form-note,
.footer-brand p,
.page-hero p,
.page-card p {
    color: var(--muted);
    font-size: 0.97rem;
    line-height: 1.62;
}

.hero-lead {
    max-width: 46rem;
}

.hero-actions,
.form-actions,
.access-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.95rem;
    margin-top: 2rem;
}

.partner-disclaimer {
    margin: 0;
    color: rgba(32, 18, 13, 0.72);
    font-size: 0.9rem;
    line-height: 1.65;
}

.partner-disclaimer-prominent {
    margin-top: 1.1rem;
    max-width: 52rem;
    padding: 1rem 1.15rem;
    border: 1px solid rgba(200, 144, 76, 0.34);
    border-radius: 8px;
    background: rgba(255, 247, 236, 0.72);
}

.site-disclaimer {
    padding: 0 0 1rem;
    color: rgba(32, 18, 13, 0.66);
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 3.4rem;
    padding: 0.96rem 1.45rem;
    border-radius: 8px;
    border: 1px solid transparent;
    font-weight: 700;
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.btn:hover {
    transform: translateY(-1px);
}

.btn-primary {
    color: #fff8ed;
    background: var(--wine);
    box-shadow: 0 16px 34px rgba(122, 31, 36, 0.22);
}

.btn-secondary {
    border-color: rgba(119, 83, 51, 0.28);
    background: rgba(255, 248, 238, 0.78);
}

.hero-stage-shell {
    margin-top: 2.4rem;
}

.hero-stage {
    position: relative;
    min-height: 35rem;
    padding: clamp(1rem, 2vw, 1.4rem);
    border-radius: 8px;
    border: 1px solid rgba(119, 83, 51, 0.22);
    background: #d9c8b2;
    box-shadow: var(--shadow-lg);
    overflow: hidden;
    transform-style: preserve-3d;
}

.studio-frame {
    position: relative;
    min-height: 32rem;
    display: grid;
    grid-template-rows: auto 1fr;
    border-radius: 8px;
    border: 1px solid rgba(68, 43, 24, 0.24);
    background: #f7efe4;
    color: #1f120d;
    box-shadow: 0 24px 54px rgba(53, 30, 14, 0.22);
    overflow: hidden;
}

.studio-topbar {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    min-height: 3.5rem;
    padding: 0.65rem 0.9rem;
    border-bottom: 1px solid rgba(68, 43, 24, 0.18);
    background: #d6c5ad;
    font-size: 0.9rem;
    font-weight: 800;
}

.studio-brand-dot {
    width: 2rem;
    height: 2rem;
    display: grid;
    place-items: center;
    border-radius: 8px;
    border: 1px solid rgba(122, 31, 36, 0.22);
    background: #fff7ec;
    color: var(--wine);
    font-family: "Syne", sans-serif;
}

.studio-topbar strong {
    margin-left: auto;
    padding: 0.42rem 0.7rem;
    border-radius: 8px;
    background: var(--wine);
    color: #fff8ed;
    font-size: 0.78rem;
}

.studio-workspace {
    display: grid;
    grid-template-columns: 12.5rem minmax(0, 1fr);
    min-height: 0;
}

.studio-sidebar {
    display: grid;
    align-content: start;
    gap: 0.45rem;
    padding: 1rem;
    border-right: 1px solid rgba(68, 43, 24, 0.16);
    background: #cdbb9f;
}

.studio-sidebar span {
    padding: 0.7rem 0.8rem;
    border-radius: 8px;
    font-size: 0.88rem;
    font-weight: 800;
    color: rgba(31, 18, 13, 0.7);
}

.studio-sidebar .is-active {
    background: rgba(122, 31, 36, 0.13);
    color: var(--wine);
}

.studio-board {
    display: grid;
    gap: 1rem;
    align-content: start;
    padding: 1rem;
}

.studio-board-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.studio-board-header h2 {
    margin: 0.25rem 0 0;
    font-size: clamp(1.25rem, 2vw, 1.9rem);
    line-height: 1.08;
    letter-spacing: 0;
}

.studio-status {
    flex: 0 0 auto;
    padding: 0.48rem 0.7rem;
    border: 1px solid rgba(47, 109, 66, 0.24);
    border-radius: 8px;
    background: rgba(47, 109, 66, 0.12);
    color: #1f5a33;
    font-size: 0.82rem;
    font-weight: 800;
}

.decision-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.decision-grid article {
    display: grid;
    gap: 0.28rem;
    min-height: 8rem;
    padding: 0.95rem;
    border: 1px solid rgba(68, 43, 24, 0.16);
    border-radius: 8px;
    background: #fff9ef;
}

.decision-grid span {
    color: var(--wine);
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.decision-grid strong {
    font-size: clamp(1.25rem, 2.2vw, 2rem);
    line-height: 1.05;
}

.decision-grid small {
    color: #725f4e;
    font-weight: 700;
}

.studio-table {
    display: grid;
    grid-template-columns: 1.2fr 0.7fr 1fr 0.8fr;
    border: 1px solid rgba(68, 43, 24, 0.18);
    border-radius: 8px;
    overflow: hidden;
    font-size: 0.84rem;
}

.studio-table span,
.studio-table strong {
    min-width: 0;
    padding: 0.62rem 0.7rem;
    border-right: 1px solid rgba(68, 43, 24, 0.12);
    border-bottom: 1px solid rgba(68, 43, 24, 0.12);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.studio-table span {
    background: #decfb8;
    color: #4b2e21;
    font-size: 0.72rem;
    font-weight: 900;
    text-transform: uppercase;
}

.studio-table strong {
    background: #fff9ef;
    font-weight: 800;
}

.stage-grid {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(119, 83, 51, 0.08) 1px, transparent 1px),
        linear-gradient(90deg, rgba(119, 83, 51, 0.08) 1px, transparent 1px);
    background-size: 4rem 4rem;
    mask-image: radial-gradient(circle at center, rgba(0, 0, 0, 0.96), transparent 88%);
}

.stage-haze {
    position: absolute;
    border-radius: 999px;
    filter: blur(56px);
    opacity: 0.75;
}

.haze-a {
    top: 5rem;
    left: 9rem;
    width: 16rem;
    height: 16rem;
    background: rgba(186, 122, 51, 0.14);
}

.haze-b {
    right: 8rem;
    bottom: 7rem;
    width: 18rem;
    height: 18rem;
    background: rgba(116, 31, 37, 0.14);
}

.stage-core {
    position: absolute;
    inset: 12% 16%;
    display: grid;
    place-items: center;
}

.stage-ring,
.stage-axis {
    position: absolute;
    border-radius: 999px;
}

.stage-ring {
    border: 1px solid rgba(119, 83, 51, 0.2);
    box-shadow: inset 0 0 32px rgba(122, 31, 36, 0.04);
}

.ring-outer {
    width: min(36rem, 72vw);
    height: min(36rem, 72vw);
    animation: slow-spin 28s linear infinite;
}

.ring-mid {
    width: min(27rem, 56vw);
    height: min(27rem, 56vw);
    border-color: rgba(116, 31, 37, 0.22);
    animation: slow-spin-reverse 21s linear infinite;
}

.ring-inner {
    width: min(17rem, 36vw);
    height: min(17rem, 36vw);
    border-color: rgba(243, 183, 119, 0.24);
}

.stage-axis {
    background: linear-gradient(90deg, transparent, rgba(186, 122, 51, 0.28), transparent);
}

.axis-x {
    width: min(42rem, 80vw);
    height: 1px;
}

.axis-y {
    width: 1px;
    height: min(28rem, 52vw);
    background: linear-gradient(180deg, transparent, rgba(116, 31, 37, 0.22), transparent);
}

.axis-z {
    width: min(28rem, 56vw);
    height: 1px;
    transform: rotate(-28deg);
    background: linear-gradient(90deg, transparent, rgba(243, 183, 119, 0.24), transparent);
}

.stage-node {
    position: absolute;
    width: 1rem;
    height: 1rem;
    border-radius: 999px;
    box-shadow: 0 0 0 10px rgba(255, 255, 255, 0.02);
}

.node-a {
    top: 18%;
    left: 28%;
    background: var(--cyan);
}

.node-b {
    right: 18%;
    top: 32%;
    background: var(--violet);
}

.node-c {
    left: 22%;
    bottom: 20%;
    background: var(--amber);
}

.node-d {
    right: 30%;
    bottom: 16%;
    background: var(--success);
}

.stage-caption {
    position: relative;
    z-index: 2;
    width: min(29rem, 88%);
    padding: 1.5rem;
    border-radius: 8px;
    border: 1px solid rgba(119, 83, 51, 0.2);
    background: rgba(255, 249, 239, 0.9);
    backdrop-filter: blur(12px);
    text-align: center;
}

.stage-caption span,
.stage-note span {
    color: var(--cyan);
}

.stage-caption h2,
.editorial-panel h3,
.timeline-step h3,
.access-card h3,
.access-copy h2,
.growth-header h2,
.page-card h2,
.page-card h3 {
    margin: 0.8rem 0;
    font-family: "Syne", sans-serif;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 0.97;
}

.stage-caption h2 {
    font-size: clamp(1.65rem, 2.4vw, 2.55rem);
}

.stage-note {
    position: absolute;
    width: 15rem;
    padding: 1rem 1.05rem;
    border-radius: 8px;
    border: 1px solid rgba(119, 83, 51, 0.2);
    background: rgba(255, 249, 239, 0.9);
    backdrop-filter: blur(12px);
    box-shadow: var(--shadow-md);
}

.stage-note strong {
    display: block;
    margin-top: 0.55rem;
    font-size: 1rem;
    line-height: 1.35;
}

.stage-note-a {
    left: 4%;
    top: 18%;
}

.stage-note-b {
    right: 5%;
    top: 16%;
}

.stage-note-c {
    right: 8%;
    bottom: 19%;
}

.stage-floor {
    position: absolute;
    left: 2rem;
    right: 2rem;
    bottom: 1.6rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.8rem;
    color: rgba(236, 243, 255, 0.72);
    font-size: 0.96rem;
}

.signal-band {
    overflow: clip;
    padding: 0.5rem 0 1rem;
}

.signal-band-track {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.9rem;
    min-width: 0;
    padding-left: 0;
}

.signal-band-track span {
    padding: 0.72rem 1rem;
    border-radius: 999px;
    border: 1px solid rgba(119, 83, 51, 0.2);
    background: rgba(255, 248, 238, 0.72);
    white-space: nowrap;
    color: rgba(32, 18, 13, 0.82);
}

.platform,
.shift,
.growth,
.access,
.page-main {
    padding: 6rem 0;
}

.section-heading {
    max-width: 52rem;
}

.section-heading h2,
.shift-copy h2,
.growth-header h2,
.access-copy h2,
.page-hero h1 {
    font-size: clamp(1.55rem, 2.35vw, 2.75rem);
}

.editorial-layout {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 1.1rem;
    margin-top: 2.3rem;
}

.editorial-panel {
    border: 1px solid rgba(119, 83, 51, 0.2);
    background: rgba(255, 249, 239, 0.82);
    box-shadow: var(--shadow-md);
}

.editorial-panel-main {
    padding: 2rem;
    border-radius: var(--radius-xl);
    min-height: 26rem;
}

.editorial-panel-main h3 {
    font-size: clamp(1.3rem, 1.7vw, 2rem);
    max-width: 12ch;
}

.editorial-panel-tall {
    padding: 2rem;
    border-radius: var(--radius-xl);
    min-height: 26rem;
}

.editorial-panel-tall h3 {
    font-size: clamp(1.15rem, 1.45vw, 1.7rem);
    max-width: 10ch;
}

.editorial-panel-wide {
    grid-column: 1 / -1;
    padding: 1.75rem 2rem;
    border-radius: var(--radius-xl);
    display: grid;
    align-items: center;
}

.editorial-panel-wide h3 {
    font-size: clamp(1.22rem, 1.6vw, 1.95rem);
    max-width: 17ch;
}

.label,
.footer-links span,
.access-points span {
    color: var(--wine);
}

.panel-lines {
    display: grid;
    gap: 0.8rem;
    margin-top: 2rem;
}

.panel-lines span {
    display: block;
    height: 0.9rem;
    border-radius: 999px;
}

.panel-lines span:nth-child(1) {
    width: 100%;
    background: linear-gradient(90deg, rgba(122, 31, 36, 0.88), rgba(200, 144, 76, 0.24));
}

.panel-lines span:nth-child(2) {
    width: 78%;
    background: rgba(119, 83, 51, 0.22);
}

.panel-lines span:nth-child(3) {
    width: 54%;
    background: rgba(200, 144, 76, 0.24);
}

.shift-shell {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: 2rem;
}

.shift-timeline {
    display: grid;
    gap: 1rem;
}

.timeline-step {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem;
    padding: 1.3rem 0;
    border-top: 1px solid rgba(119, 83, 51, 0.22);
}

.step-no {
    color: var(--wine);
    padding-top: 0.35rem;
}

.timeline-step h3 {
    margin-top: 0;
    font-size: clamp(1.55rem, 2vw, 2.25rem);
}

.growth-shell {
    display: grid;
    gap: 2rem;
}

.growth-rail {
    display: grid;
    gap: 1.1rem;
}

.growth-rung {
    display: grid;
    grid-template-columns: minmax(14rem, 22rem) 1fr;
    gap: 1.5rem;
    align-items: start;
    padding: 1.4rem 0;
    border-top: 1px solid rgba(119, 83, 51, 0.22);
}

.rung-tag {
    color: var(--text);
    font-size: 0.92rem;
    letter-spacing: 0.08em;
}

.access-shell {
    display: grid;
    grid-template-columns: minmax(0, 0.82fr) minmax(0, 1fr);
    gap: 1.4rem;
    align-items: start;
}

.access-points {
    display: grid;
    gap: 1rem;
    margin-top: 2rem;
}

.access-points div {
    padding-top: 1rem;
    border-top: 1px solid rgba(119, 83, 51, 0.22);
}

.access-points a {
    display: inline-block;
    margin-top: 0.35rem;
    font-size: 1.28rem;
    font-weight: 700;
}

.access-card,
.page-card {
    padding: 1.75rem;
    border-radius: var(--radius-xl);
    border: 1px solid rgba(119, 83, 51, 0.2);
    background: rgba(255, 249, 239, 0.88);
    box-shadow: var(--shadow-md);
}

.form-grid,
.page-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.field {
    display: grid;
    gap: 0.55rem;
}

.field span {
    font-size: 0.98rem;
    font-weight: 700;
    color: rgba(32, 18, 13, 0.94);
}

.field input,
.field textarea {
    width: 100%;
    padding: 1rem 1.05rem;
    border-radius: 8px;
    border: 1px solid rgba(119, 83, 51, 0.22);
    background: rgba(255, 249, 239, 0.88);
    color: var(--text);
    outline: none;
    transition: border-color 180ms ease, box-shadow 180ms ease;
}

.field input:focus,
.field textarea:focus {
    border-color: rgba(122, 31, 36, 0.5);
    box-shadow: 0 0 0 3px rgba(122, 31, 36, 0.12);
}

.field textarea {
    min-height: 11rem;
    resize: vertical;
}

.hp-field {
    position: absolute;
    left: -9999px;
}

.form-status {
    min-height: 1.45rem;
    margin: 0.7rem 0 0;
    color: var(--success);
}

.site-footer {
    padding: 2rem 0 1rem;
    border-top: 1px solid rgba(119, 83, 51, 0.18);
}

.footer-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 2rem;
    padding-bottom: 1.5rem;
}

.footer-brand p {
    max-width: 28rem;
}

.footer-links {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, auto));
    gap: 2rem;
}

.footer-links div {
    display: grid;
    gap: 0.7rem;
}

.footer-links a {
    color: var(--muted);
}

.footer-links a:hover {
    color: var(--text);
}

.footer-meta {
    display: flex;
    justify-content: center;
    padding-top: 1rem;
    border-top: 1px solid rgba(119, 83, 51, 0.18);
    color: rgba(32, 18, 13, 0.72);
}

.page-hero {
    max-width: 52rem;
    margin-bottom: 2rem;
}

.page-hero p {
    max-width: 46rem;
}

.page-card h2 {
    font-size: 2rem;
}

.page-card h3 {
    font-size: 1.4rem;
}

.access-card h3 {
    font-size: clamp(1.35rem, 1.7vw, 2rem);
}

.pricing {
    padding: 0 0 6rem;
}

.pricing-shell {
    display: grid;
    gap: 2rem;
}

.pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.2rem;
}

.pricing-card {
    position: relative;
    display: grid;
    gap: 1rem;
    padding: 1.7rem;
    border-radius: 8px;
    border: 1px solid rgba(119, 83, 51, 0.2);
    background: rgba(255, 249, 239, 0.9);
    box-shadow: var(--shadow-sm);
}

.pricing-card-featured {
    border-color: rgba(92, 140, 255, 0.42);
    box-shadow: 0 28px 60px rgba(3, 10, 22, 0.34);
}

.pricing-card h3 {
    margin: 0;
    font-size: clamp(1.7rem, 2vw, 2.4rem);
}

.pricing-card p,
.pricing-card li {
    color: var(--muted);
}

.pricing-card ul {
    display: grid;
    gap: 0.7rem;
    margin: 0;
    padding-left: 1.1rem;
}

.reveal {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 520ms ease, transform 520ms ease;
}

.reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

@keyframes slow-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes slow-spin-reverse {
    from { transform: rotate(0deg); }
    to { transform: rotate(-360deg); }
}

@keyframes band-scroll {
    from { transform: translateX(0); }
    to { transform: translateX(-30%); }
}

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }

    .ring-outer,
    .ring-mid,
    .signal-band-track,
    .reveal {
        animation: none !important;
        transition: none !important;
    }
}

@media (prefers-color-scheme: dark) {
    :root {
        --bg: #090706;
        --bg-soft: #11100e;
        --bg-deep: #050403;
        --panel: rgba(18, 16, 14, 0.9);
        --panel-strong: rgba(22, 19, 16, 0.98);
        --text: #fff3e2;
        --muted: #c7ad90;
        --line: rgba(216, 177, 124, 0.2);
        --line-strong: rgba(216, 177, 124, 0.34);
        --wine: #e6b05f;
        --gold: #c8904c;
        --success: #8ccc9a;
        --shadow-lg: 0 32px 90px rgba(0, 0, 0, 0.34);
        --shadow-md: 0 18px 44px rgba(0, 0, 0, 0.24);
    }

    body {
        background: linear-gradient(180deg, #090706 0%, #11100e 48%, #050403 100%);
    }

    .site-header {
        background: rgba(9, 7, 6, 0.84);
        border-bottom-color: rgba(216, 177, 124, 0.14);
    }

    .brand-mark,
    .btn-secondary,
    .nav-app,
    .signal-band-track span,
    .editorial-panel,
    .access-card,
    .page-card,
    .pricing-card {
        background: rgba(22, 19, 16, 0.86);
        border-color: rgba(216, 177, 124, 0.18);
    }

    .site-nav a,
    .partner-disclaimer,
    .site-disclaimer,
    .footer-meta,
    .signal-band-track span {
        color: rgba(255, 243, 226, 0.78);
    }

    .hero-stage {
        background: #15110d;
        border-color: rgba(216, 177, 124, 0.18);
    }

    .studio-frame {
        background: #0c0a08;
        color: #fff3e2;
        border-color: rgba(216, 177, 124, 0.18);
    }

    .studio-topbar {
        background: #17120d;
        border-bottom-color: rgba(216, 177, 124, 0.16);
    }

    .studio-sidebar {
        background: #12100d;
        border-right-color: rgba(216, 177, 124, 0.14);
    }

    .studio-sidebar span {
        color: rgba(255, 243, 226, 0.68);
    }

    .studio-sidebar .is-active {
        background: rgba(230, 176, 95, 0.14);
        color: #f2c77e;
    }

    .decision-grid article,
    .studio-table strong {
        background: #14110e;
        border-color: rgba(216, 177, 124, 0.14);
    }

    .decision-grid small {
        color: #c7ad90;
    }

    .studio-status {
        color: #9fdda9;
    }

    .studio-table {
        border-color: rgba(216, 177, 124, 0.16);
    }

    .studio-table span {
        background: #211a12;
        color: #e9c48a;
    }

    .studio-table span,
    .studio-table strong {
        border-color: rgba(216, 177, 124, 0.12);
    }

    .field input,
    .field textarea {
        background: rgba(22, 19, 16, 0.88);
        color: var(--text);
        border-color: rgba(216, 177, 124, 0.18);
    }
}

@media (max-width: 1120px) {
    .editorial-layout,
    .shift-shell,
    .pricing-grid,
    .access-shell,
    .footer-shell {
        grid-template-columns: 1fr;
    }

    .growth-rung {
        grid-template-columns: 1fr;
        gap: 0.8rem;
    }
}

@media (max-width: 860px) {
    :root {
        --shell: min(100vw - 28px, 1380px);
    }

    .nav-toggle {
        display: inline-block;
    }

    .site-nav {
        position: absolute;
        top: calc(100% + 0.7rem);
        right: 14px;
        left: 14px;
        display: none;
        flex-direction: column;
        align-items: stretch;
        padding: 1rem;
        border-radius: 8px;
        border: 1px solid rgba(119, 83, 51, 0.22);
        background: rgba(255, 249, 239, 0.96);
        box-shadow: var(--shadow-md);
    }

    .site-nav.is-open {
        display: flex;
    }

    .hero {
        padding-top: 5rem;
    }

    .hero-stage {
        min-height: auto;
        padding: 1rem;
    }

    .studio-frame {
        min-height: auto;
    }

    .studio-workspace {
        grid-template-columns: 1fr;
    }

    .studio-sidebar {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        border-right: 0;
        border-bottom: 1px solid rgba(68, 43, 24, 0.16);
    }

    .decision-grid {
        grid-template-columns: 1fr;
    }

    .studio-table {
        grid-template-columns: 1fr 0.7fr;
    }

    .studio-table span:nth-child(n+3),
    .studio-table strong:nth-child(4n+3),
    .studio-table strong:nth-child(4n+4) {
        display: none;
    }

    .stage-core {
        inset: 18% 8%;
    }

    .stage-note {
        width: 12rem;
        padding: 0.9rem;
    }

    .stage-note-a {
        left: 3%;
        top: 10%;
    }

    .stage-note-b {
        right: 3%;
        top: 12%;
    }

    .stage-note-c {
        right: 7%;
        bottom: 17%;
    }

    .form-grid,
    .page-grid {
        grid-template-columns: 1fr;
    }

    .footer-links {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 560px) {
    .hero h1 {
        font-size: clamp(2.4rem, 12vw, 3.5rem);
    }

    .hero-stage {
        min-height: auto;
    }

    .studio-sidebar {
        grid-template-columns: 1fr 1fr;
    }

    .studio-board-header {
        display: grid;
    }

    .stage-note {
        display: none;
    }

    .stage-caption {
        width: 92%;
        padding: 1.2rem;
    }

    .access-card,
    .page-card,
    .editorial-panel-main,
    .editorial-panel-tall,
    .editorial-panel-wide {
        padding: 1.25rem;
    }

    .stage-floor {
        justify-content: flex-start;
    }
}


/* ============================================================
   LANDING PAGE — Ateliaro v7 (May 2026)
   Brand-aligned: cream surface, deep burgundy ink, warm accents
   ============================================================ */

.landing-page {
    --lp-cream: #f5f1ee;
    --lp-cream-2: #efeae5;
    --lp-cream-3: #e6dfd6;
    --lp-ink: #1a1212;
    --lp-ink-soft: #4a3c3c;
    --lp-ink-dim: #7a6c6c;
    --lp-wine: #3d1818;
    --lp-wine-2: #5a2424;
    --lp-gold: #b8882a;
    --lp-gold-soft: #e9c980;
    --lp-line: rgba(61, 24, 24, 0.12);
    --lp-line-2: rgba(61, 24, 24, 0.22);
    --lp-card: #fbf8f5;
    --lp-shadow-sm: 0 1px 2px rgba(26, 18, 18, .04), 0 4px 14px rgba(26, 18, 18, .06);
    --lp-shadow-md: 0 6px 18px rgba(26, 18, 18, .08), 0 24px 48px rgba(26, 18, 18, .07);
    --lp-radius: 18px;
    --lp-radius-sm: 12px;
    background: var(--lp-cream);
    color: var(--lp-ink);
    font-family: 'Manrope', system-ui, -apple-system, sans-serif;
    line-height: 1.55;
    font-size: 16.5px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.lp { width: 100%; overflow-x: hidden; }
.lp__shell { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 28px; }

.lp h1, .lp h2, .lp h3 { font-family: 'Fraunces', 'Manrope', serif; font-weight: 600; color: var(--lp-ink); letter-spacing: -0.01em; line-height: 1.12; margin: 0; }
.lp p { margin: 0; color: var(--lp-ink-soft); }
.lp a { color: inherit; text-decoration: none; }
.lp .lp__btn--primary, .lp .lp__cta-btn { color: var(--lp-cream); }
.lp .lp__btn--ghost { color: var(--lp-ink); }
.lp .lp__link-arrow { color: var(--lp-wine); }

.lp .lp__h2 { font-size: clamp(28px, 3.4vw, 44px); }
.lp__eyebrow {
    display: inline-block; font-family: 'Manrope', sans-serif; font-weight: 700;
    font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--lp-wine); padding: 6px 12px; border-radius: 999px;
    background: rgba(61, 24, 24, 0.07); margin-bottom: 14px;
}
.lp__lede { font-size: 17.5px; max-width: 720px; margin: 14px auto 0; color: var(--lp-ink-soft); }

/* Reveal animation */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-in, .lp .reveal { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { transition: none; } }

/* ---------- HEADER ---------- */
.lp__header {
    position: sticky; top: 0; z-index: 50;
    background: rgba(245, 241, 238, 0.85);
    backdrop-filter: saturate(140%) blur(10px);
    -webkit-backdrop-filter: saturate(140%) blur(10px);
    border-bottom: 1px solid var(--lp-line);
}
.lp__header-row { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 14px 28px; }
.lp__brand { display: flex; align-items: center; }
.lp__brand-logo { height: 30px; width: auto; display: block; }
.lp__nav { display: flex; align-items: center; gap: 28px; }
.lp__nav a { font-size: 14.5px; color: var(--lp-ink-soft); transition: color .2s; }
.lp__nav a:hover { color: var(--lp-wine); }
.lp__cta-btn {
    display: inline-flex; align-items: center; padding: 10px 18px;
    background: var(--lp-wine); color: var(--lp-cream);
    border-radius: 999px; font-weight: 600; font-size: 14.5px;
    transition: transform .2s, background .2s;
}
.lp__cta-btn:hover { background: var(--lp-wine-2); transform: translateY(-1px); }
.lp__nav-toggle { display: none; }

/* ---------- HERO ---------- */
.lp__hero { position: relative; padding: 72px 0 96px; overflow: hidden; }
.lp__hero-bg { position: absolute; inset: 0; pointer-events: none; }
.lp__hero-orb { position: absolute; border-radius: 50%; filter: blur(70px); opacity: .55; }
.lp__hero-orb--1 { width: 460px; height: 460px; background: radial-gradient(circle, rgba(184, 136, 42, .35), transparent 70%); top: -120px; left: -100px; }
.lp__hero-orb--2 { width: 540px; height: 540px; background: radial-gradient(circle, rgba(61, 24, 24, .22), transparent 70%); bottom: -160px; right: -120px; }
.lp__hero-grid {
    position: absolute; inset: 0;
    background-image: linear-gradient(rgba(61,24,24,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(61,24,24,.04) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}
.lp__hero-inner { position: relative; display: grid; grid-template-columns: 1.05fr 1fr; gap: 72px; align-items: center; }
.lp__hero-badge {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 7px 14px; border-radius: 999px;
    background: rgba(61, 24, 24, 0.06); border: 1px solid var(--lp-line);
    font-size: 13px; font-weight: 600; color: var(--lp-wine);
    letter-spacing: 0.04em;
}
.lp__hero-badge-dot {
    width: 7px; height: 7px; border-radius: 50%; background: var(--lp-gold);
    box-shadow: 0 0 0 0 rgba(184,136,42,.7); animation: lpPulse 2.4s ease-out infinite;
}
@keyframes lpPulse { 0%{ box-shadow: 0 0 0 0 rgba(184,136,42,.55);} 70%{ box-shadow: 0 0 0 10px rgba(184,136,42,0);} 100%{ box-shadow: 0 0 0 0 rgba(184,136,42,0);} }

.lp__hero-h1 { font-size: clamp(38px, 5.4vw, 64px); margin-top: 18px; color: var(--lp-ink); }
.lp__hero-h1 em { color: var(--lp-wine); font-style: italic; font-weight: 600; }
.lp__hero-p { margin-top: 20px; font-size: 18px; max-width: 560px; }

.lp__hero-btns { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 28px; }
.lp__btn {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 14px 24px; border-radius: 999px; font-weight: 600; font-size: 15px;
    transition: transform .2s, background .2s, box-shadow .2s, color .2s;
    cursor: pointer; border: none; line-height: 1;
}
.lp__btn--primary { background: var(--lp-wine); color: var(--lp-cream); box-shadow: var(--lp-shadow-sm); }
.lp__btn--primary:hover { background: var(--lp-wine-2); transform: translateY(-1px); box-shadow: var(--lp-shadow-md); }
.lp__btn--ghost { background: transparent; color: var(--lp-ink); border: 1.5px solid rgba(61,24,24,.35); }
.lp__btn--ghost:hover { background: rgba(61,24,24,.06); border-color: var(--lp-wine); color: var(--lp-wine); }

/* HERO MOCKUP */
.lp__hero-visual { position: relative; }
.lp__mock {
    background: var(--lp-card); border-radius: var(--lp-radius); overflow: hidden;
    box-shadow: var(--lp-shadow-md); border: 1px solid var(--lp-line);
    transform: rotate(0.6deg);
}
.lp__mock-toolbar { display: flex; align-items: center; gap: 8px; padding: 12px 16px; background: var(--lp-cream-2); border-bottom: 1px solid var(--lp-line); }
.lp__mock-dot { width: 10px; height: 10px; border-radius: 50%; }
.lp__mock-dot--r { background: #ed6a5e; }
.lp__mock-dot--y { background: #f5bf4f; }
.lp__mock-dot--g { background: #62c554; }
.lp__mock-url { margin-left: 12px; font-family: 'Manrope', monospace; font-size: 12px; color: var(--lp-ink-dim); }
.lp__mock-body { padding: 22px; display: flex; flex-direction: column; gap: 14px; }
.lp__mock-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.lp__mock-stat { background: var(--lp-cream); border: 1px solid var(--lp-line); border-radius: var(--lp-radius-sm); padding: 14px; display: flex; flex-direction: column; gap: 4px; }
.lp__mock-label { font-size: 11.5px; font-weight: 600; color: var(--lp-ink-dim); text-transform: uppercase; letter-spacing: 0.08em; }
.lp__mock-value { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 600; color: var(--lp-ink); }
.lp__mock-meta { font-size: 12px; color: var(--lp-ink-dim); }
.lp__mock-meta--ok { color: #2f7a3a; }
.lp__mock-meta--warn { color: #b8882a; font-weight: 600; }
.lp__mock-row { display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: var(--lp-cream); border: 1px solid var(--lp-line); border-radius: var(--lp-radius-sm); }
.lp__mock-row-bar { width: 4px; align-self: stretch; background: var(--lp-gold); border-radius: 2px; }
.lp__mock-row-bar--ok { background: #62c554; }
.lp__mock-row-text { flex: 1; display: flex; flex-direction: column; gap: 2px; font-size: 13px; }
.lp__mock-row-text strong { color: var(--lp-ink); font-weight: 600; }
.lp__mock-row-text span { color: var(--lp-ink-dim); font-size: 12px; }
.lp__mock-tag { padding: 4px 10px; background: rgba(184,136,42,.15); color: var(--lp-gold); border-radius: 999px; font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; }
.lp__mock-tag--ok { background: rgba(98,197,84,.15); color: #2f7a3a; }
.lp__mock-float {
    position: absolute; background: var(--lp-card); border: 1px solid var(--lp-line);
    border-radius: 14px; padding: 12px 16px; box-shadow: var(--lp-shadow-md);
    display: flex; flex-direction: column; gap: 2px;
}
.lp__mock-float--1 { top: 18%; left: -36px; transform: rotate(-3deg); }
.lp__mock-float--2 { bottom: 8%; right: -28px; transform: rotate(2deg); }
.lp__mock-float-label { font-size: 11px; font-weight: 600; color: var(--lp-ink-dim); text-transform: uppercase; letter-spacing: 0.08em; }
.lp__mock-float-value { font-family: 'Fraunces', serif; font-size: 22px; font-weight: 600; color: var(--lp-wine); }

/* ---------- BAND ---------- */
.lp__band { padding: 36px 0; background: var(--lp-cream-2); border-top: 1px solid var(--lp-line); border-bottom: 1px solid var(--lp-line); }
.lp__band-quote { font-family: 'Fraunces', serif; font-style: italic; font-size: clamp(18px, 2.2vw, 24px); color: var(--lp-ink); text-align: center; max-width: 920px; margin: 0 auto; }

/* ---------- FEATURES ---------- */
.lp__feat { padding: 96px 0 88px; }
.lp__feat-head { text-align: center; max-width: 760px; margin: 0 auto 56px; }
.lp__feat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; align-items: stretch; }
.lp__feat-card {
    background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: var(--lp-radius);
    padding: 28px; display: flex; flex-direction: column; gap: 12px;
    transition: transform .25s, box-shadow .25s, border-color .25s;
}
.lp__feat-card:hover { transform: translateY(-3px); box-shadow: var(--lp-shadow-md); border-color: var(--lp-line-2); }
.lp__feat-card--lg { grid-column: span 1; }
.lp__feat-card h3 { font-size: 22px; }
.lp__feat-card p { font-size: 15px; }
.lp__feat-icon {
    width: 48px; height: 48px; border-radius: 14px;
    background: rgba(61,24,24,.08); color: var(--lp-wine);
    display: inline-flex; align-items: center; justify-content: center;
}
.lp__feat-icon svg { width: 24px; height: 24px; }
.lp__feat-points { list-style: none; padding: 0; margin: 8px 0 0; display: flex; flex-direction: column; gap: 8px; }
.lp__feat-points li { position: relative; padding-left: 22px; font-size: 14px; color: var(--lp-ink-soft); }
.lp__feat-points li::before { content: ""; position: absolute; left: 0; top: 8px; width: 12px; height: 2px; background: var(--lp-gold); border-radius: 2px; }

/* Showcase strip inside features */
.lp__feat-show {
    margin-top: 64px; display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center;
    padding: 48px; background: var(--lp-cream-2); border-radius: 24px; border: 1px solid var(--lp-line);
}
.lp__feat-show-h { font-size: clamp(24px, 2.8vw, 32px); margin-top: 12px; }
.lp__feat-show-text p { margin-top: 14px; font-size: 16px; }
.lp__feat-show-visual { position: relative; display: flex; flex-direction: column; gap: 16px; }
.lp__mini-card { background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: var(--lp-radius); padding: 20px; box-shadow: var(--lp-shadow-sm); display: flex; flex-direction: column; gap: 10px; }
.lp__mini-head { display: flex; justify-content: space-between; font-size: 12.5px; font-weight: 700; color: var(--lp-ink-dim); letter-spacing: 0.05em; text-transform: uppercase; }
.lp__mini-card strong { font-family: 'Fraunces', serif; font-size: 20px; color: var(--lp-ink); font-weight: 600; }
.lp__mini-card p { font-size: 14px; }
.lp__mini-progress { width: 100%; height: 6px; border-radius: 3px; background: var(--lp-cream-3); overflow: hidden; }
.lp__mini-progress span { display: block; height: 100%; background: var(--lp-wine); border-radius: 3px; }
.lp__mini-meta { display: flex; justify-content: space-between; align-items: center; font-size: 12.5px; color: var(--lp-ink-dim); margin-top: 4px; }
.lp__mini-pill { padding: 4px 10px; background: rgba(184,136,42,.15); color: var(--lp-gold); border-radius: 999px; font-weight: 700; }
.lp__mini-card--alt { transform: translateX(24px) rotate(1deg); }
.lp__mini-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.lp__mini-chips span { padding: 4px 10px; background: var(--lp-cream-2); border: 1px solid var(--lp-line); border-radius: 999px; font-size: 12px; color: var(--lp-ink-soft); }

/* ---------- HOW IT WORKS ---------- */
.lp__how { padding: 88px 0; background: var(--lp-cream-2); border-top: 1px solid var(--lp-line); border-bottom: 1px solid var(--lp-line); }
.lp__how-grid { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; align-items: stretch; }
.lp__how-step {
    background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: var(--lp-radius);
    padding: 32px 28px 28px; display: flex; flex-direction: column; gap: 12px; height: 100%;
    position: relative;
}
.lp__how-num {
    font-family: 'Fraunces', serif; font-weight: 600; font-size: 32px;
    width: 56px; height: 56px; border-radius: 50%;
    background: var(--lp-wine); color: var(--lp-cream);
    display: inline-flex; align-items: center; justify-content: center;
    margin-bottom: 6px;
}
.lp__how-step h3 { font-size: 22px; }
.lp__how-step p { font-size: 15px; }
.lp__how-points { list-style: none; padding: 0; margin: auto 0 0; display: flex; flex-direction: column; gap: 8px; padding-top: 14px; border-top: 1px solid var(--lp-line); }
.lp__how-points li { position: relative; padding-left: 22px; font-size: 14px; color: var(--lp-ink-soft); }
.lp__how-points li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--lp-gold); font-weight: 700; }

/* ---------- CRAFTS / FOR MAKERS ---------- */
.lp__crafts { padding: 96px 0; }
.lp__crafts-split { display: grid; grid-template-columns: 1.1fr 1fr; gap: 56px; align-items: start; margin-top: 8px; }
.lp__crafts-copy h3 { font-size: 26px; margin-bottom: 14px; }
.lp__crafts-copy p { font-size: 16px; margin-bottom: 24px; }
.lp__crafts-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.lp__craft { display: flex; align-items: center; gap: 12px; padding: 14px 16px; background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: var(--lp-radius-sm); font-size: 14.5px; }
.lp__craft strong { font-weight: 600; color: var(--lp-ink); }
.lp__craft-icon { font-size: 20px; }
.lp__crafts-visual { display: flex; flex-direction: column; gap: 18px; padding-top: 24px; }
.lp__quote-card { background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: var(--lp-radius); padding: 24px; box-shadow: var(--lp-shadow-sm); }
.lp__quote-card p { font-family: 'Fraunces', serif; font-size: 18px; font-style: italic; color: var(--lp-ink); margin-bottom: 12px; }
.lp__quote-by { font-size: 13px; color: var(--lp-ink-dim); font-weight: 600; }
.lp__quote-card--alt { margin-left: 32px; transform: rotate(0.5deg); background: var(--lp-cream-2); }

/* ---------- ABOUT TEASER ---------- */
.lp__about-teaser { padding: 0 0 96px; }
.lp__about-card { background: linear-gradient(135deg, var(--lp-wine) 0%, #2a1010 100%); color: var(--lp-cream); border-radius: 24px; padding: 56px; position: relative; overflow: hidden; }
.lp__about-card::after { content: ""; position: absolute; right: -100px; top: -100px; width: 400px; height: 400px; border-radius: 50%; background: radial-gradient(circle, rgba(184,136,42,.25), transparent 70%); pointer-events: none; }
.lp__about-text { max-width: 660px; position: relative; z-index: 1; }
.lp__about-text .lp__eyebrow { background: rgba(245,241,238,.15); color: var(--lp-gold-soft); }
.lp__about-text h2 { color: var(--lp-cream); }
.lp__about-text p { color: rgba(245,241,238,.82); margin-top: 16px; font-size: 17px; }
.lp__link-arrow { display: inline-flex; align-items: center; margin-top: 22px; padding: 10px 20px; background: var(--lp-cream); color: var(--lp-wine); border-radius: 999px; font-weight: 600; font-size: 14.5px; transition: transform .2s; }
.lp__link-arrow:hover { transform: translateX(2px); }

/* ---------- BETA ---------- */
.lp__beta { padding: 96px 0 120px; background: var(--lp-cream-2); border-top: 1px solid var(--lp-line); }
.lp__beta-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; max-width: 920px; margin: 0 auto; align-items: stretch; }
.lp__beta-card { background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: var(--lp-radius); padding: 32px; display: flex; flex-direction: column; gap: 14px; }
.lp__beta-card--alt { background: var(--lp-cream); }
.lp__beta-tag { display: inline-flex; align-self: flex-start; padding: 5px 12px; background: var(--lp-wine); color: var(--lp-cream); font-size: 11.5px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; border-radius: 999px; }
.lp__beta-card--alt .lp__beta-tag { background: var(--lp-gold); color: var(--lp-ink); }
.lp__beta-card h3 { font-size: 24px; }
.lp__beta-card p { font-size: 15px; }
.lp__beta-points { list-style: none; padding: 0; margin: 4px 0; display: flex; flex-direction: column; gap: 8px; }
.lp__beta-points li { position: relative; padding-left: 20px; font-size: 14px; color: var(--lp-ink-soft); }
.lp__beta-points li::before { content: "→"; position: absolute; left: 0; color: var(--lp-wine); font-weight: 700; }
.lp__beta-card .lp__btn { margin-top: auto; align-self: flex-start; }

/* ---------- FOOTER ---------- */
.lp__footer { padding: 64px 0 40px; background: var(--lp-cream); border-top: 1px solid var(--lp-line); }
.lp__footer-grid { display: grid; grid-template-columns: 1.3fr repeat(3, 1fr); gap: 40px; }
.lp__footer-col h4 { font-family: 'Manrope', sans-serif; font-size: 13px; font-weight: 700; color: var(--lp-ink); text-transform: uppercase; letter-spacing: 0.1em; margin: 0 0 14px; }
.lp__footer-col a { display: block; font-size: 14.5px; color: var(--lp-ink-soft); padding: 4px 0; transition: color .2s; }
.lp__footer-col a:hover { color: var(--lp-wine); }
.lp__footer-col--brand p { font-size: 14px; color: var(--lp-ink-dim); margin-top: 10px; max-width: 280px; }
.lp__footer-logo { height: 28px; width: auto; }
.lp__footer-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 28px; margin-top: 40px; border-top: 1px solid var(--lp-line); font-size: 13px; color: var(--lp-ink-dim); }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1080px) {
    .lp__hero-inner { grid-template-columns: 1fr; gap: 56px; }
    .lp__feat-grid { grid-template-columns: repeat(2, 1fr); }
    .lp__feat-show { grid-template-columns: 1fr; gap: 36px; padding: 32px; }
    .lp__crafts-split { grid-template-columns: 1fr; gap: 36px; }
    .lp__crafts-visual { padding-top: 0; }
    .lp__quote-card--alt { margin-left: 0; }
    .lp__footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
    .lp__nav-toggle {
        display: inline-flex; flex-direction: column; gap: 5px;
        width: 40px; height: 40px; align-items: center; justify-content: center;
        background: transparent; border: 1px solid var(--lp-line-2); border-radius: 10px; cursor: pointer;
    }
    .lp__nav-toggle span { display: block; width: 18px; height: 2px; background: var(--lp-ink); border-radius: 2px; }
    .lp__nav { display: none; position: absolute; top: 100%; left: 0; right: 0; flex-direction: column; align-items: stretch; gap: 0; background: var(--lp-cream); border-bottom: 1px solid var(--lp-line); padding: 8px 28px 18px; }
    .lp__nav.is-open { display: flex; }
    .lp__nav a { padding: 12px 0; border-bottom: 1px solid var(--lp-line); }
    .lp__cta-btn { display: none; }
    .lp__header { position: relative; }
    .lp__hero { padding: 48px 0 64px; }
    .lp__hero-h1 { font-size: 36px; }
    .lp__feat, .lp__how, .lp__crafts, .lp__beta { padding: 64px 0; }
    .lp__feat-grid, .lp__how-grid, .lp__beta-grid { grid-template-columns: 1fr; }
    .lp__crafts-grid { grid-template-columns: 1fr; }
    .lp__about-card { padding: 36px 28px; }
    .lp__footer-grid { grid-template-columns: 1fr; gap: 28px; }
    .lp__footer-bottom { flex-direction: column; gap: 8px; align-items: flex-start; }
    .lp__mock-stats { grid-template-columns: 1fr 1fr; }
    .lp__mock-float { display: none; }
}

/* ============================================================
   PRICING PAGE
   ============================================================ */
.lp__pricing { padding: 80px 0 100px; }
.lp__pricing-head { text-align: center; max-width: 760px; margin: 0 auto 48px; }
.lp__pricing-head h1 { font-family: 'Fraunces', serif; font-size: clamp(36px, 5vw, 56px); font-weight: 600; color: var(--lp-ink); }
.lp__pricing-head p { margin-top: 16px; font-size: 18px; color: var(--lp-ink-soft); }
.lp__pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; max-width: 1100px; margin: 0 auto; }
.lp__plan { background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: var(--lp-radius); padding: 32px; display: flex; flex-direction: column; gap: 14px; position: relative; }
.lp__plan--feat { border: 2px solid var(--lp-wine); transform: translateY(-6px); box-shadow: var(--lp-shadow-md); }
.lp__plan-tag { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); padding: 5px 14px; background: var(--lp-wine); color: var(--lp-cream); font-size: 11.5px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; border-radius: 999px; }
.lp__plan-name { font-family: 'Manrope', sans-serif; font-weight: 700; font-size: 14px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--lp-wine); }
.lp__plan-price { font-family: 'Fraunces', serif; font-size: 36px; font-weight: 600; color: var(--lp-ink); }
.lp__plan-price small { font-family: 'Manrope', sans-serif; font-size: 14px; font-weight: 500; color: var(--lp-ink-dim); }
.lp__plan-desc { font-size: 14.5px; color: var(--lp-ink-soft); }
.lp__plan-list { list-style: none; padding: 16px 0 0; margin: 0; border-top: 1px solid var(--lp-line); display: flex; flex-direction: column; gap: 10px; }
.lp__plan-list li { position: relative; padding-left: 24px; font-size: 14px; color: var(--lp-ink-soft); }
.lp__plan-list li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--lp-gold); font-weight: 700; }
.lp__plan .lp__btn { margin-top: auto; align-self: stretch; }
.lp__pricing-note { max-width: 760px; margin: 56px auto 0; padding: 24px 28px; background: var(--lp-cream-2); border: 1px solid var(--lp-line); border-radius: var(--lp-radius); text-align: center; font-size: 14px; color: var(--lp-ink-soft); }
.lp__pricing-faq { max-width: 820px; margin: 80px auto 0; }
.lp__pricing-faq h2 { text-align: center; margin-bottom: 32px; }
.lp__faq { border-top: 1px solid var(--lp-line); padding: 20px 0; }
.lp__faq h3 { font-family: 'Manrope', sans-serif; font-weight: 700; font-size: 17px; }
.lp__faq p { margin-top: 8px; font-size: 15px; }

@media (max-width: 980px) { .lp__pricing-grid { grid-template-columns: 1fr; max-width: 480px; } .lp__plan--feat { transform: none; } }

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.lp__about-hero { padding: 80px 0 56px; text-align: center; }
.lp__about-hero h1 { font-family: 'Fraunces', serif; font-size: clamp(40px, 5.4vw, 60px); font-weight: 600; max-width: 880px; margin: 14px auto 0; line-height: 1.1; }
.lp__about-hero p { max-width: 720px; margin: 22px auto 0; font-size: 18px; color: var(--lp-ink-soft); }

.lp__story { padding: 40px 0 80px; }
.lp__story-grid { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 22px; }
.lp__story-grid p { font-size: 17px; line-height: 1.7; color: var(--lp-ink-soft); }
.lp__story-grid p strong { color: var(--lp-ink); font-weight: 600; }

.lp__team { padding: 80px 0; background: var(--lp-cream-2); border-top: 1px solid var(--lp-line); border-bottom: 1px solid var(--lp-line); }
.lp__team-head { text-align: center; max-width: 720px; margin: 0 auto 56px; }
.lp__team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.lp__founder { background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: 24px; overflow: hidden; display: flex; flex-direction: column; transition: transform .25s, box-shadow .25s; }
.lp__founder:hover { transform: translateY(-4px); box-shadow: var(--lp-shadow-md); }
.lp__founder-photo { aspect-ratio: 4/5; background: linear-gradient(135deg, var(--lp-wine), #2a1010); position: relative; display: flex; align-items: center; justify-content: center; color: var(--lp-cream); }
.lp__founder-photo::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 70% 30%, rgba(184,136,42,.2), transparent 60%); pointer-events: none; }
.lp__founder-initials { font-family: 'Fraunces', serif; font-size: 84px; font-weight: 600; color: rgba(245,241,238,.92); position: relative; z-index: 1; }
.lp__founder-body { padding: 22px 24px 26px; display: flex; flex-direction: column; gap: 6px; }
.lp__founder-name { font-family: 'Fraunces', serif; font-size: 22px; font-weight: 600; color: var(--lp-ink); }
.lp__founder-role { font-size: 13px; font-weight: 700; color: var(--lp-wine); text-transform: uppercase; letter-spacing: 0.1em; }
.lp__founder-bio { font-size: 14.5px; color: var(--lp-ink-soft); margin-top: 8px; }
.lp__founder--join .lp__founder-photo { background: var(--lp-cream); color: var(--lp-wine); border-bottom: 1px solid var(--lp-line); }
.lp__founder--join .lp__founder-photo::after { background: none; }
.lp__founder--join .lp__founder-initials { color: var(--lp-wine); font-size: 64px; }
.lp__founder--join { border-style: dashed; }

.lp__partners { padding: 80px 0; }
.lp__partners-head { text-align: center; max-width: 720px; margin: 0 auto 40px; }
.lp__partners-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; max-width: 980px; margin: 0 auto; }
.lp__partner { background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: var(--lp-radius-sm); padding: 22px 18px; text-align: center; display: flex; flex-direction: column; gap: 6px; align-items: center; }
.lp__partner-logo { width: 44px; height: 44px; border-radius: 50%; background: var(--lp-cream-2); display: inline-flex; align-items: center; justify-content: center; font-family: 'Fraunces', serif; font-size: 20px; font-weight: 600; color: var(--lp-wine); margin-bottom: 4px; }
.lp__partner strong { font-size: 14.5px; color: var(--lp-ink); font-weight: 600; }
.lp__partner span { font-size: 12.5px; color: var(--lp-ink-dim); }
.lp__partners-note { text-align: center; margin-top: 32px; font-size: 14px; color: var(--lp-ink-dim); }
.lp__partners-note a { color: var(--lp-wine); font-weight: 600; }

@media (max-width: 980px) {
    .lp__team-grid { grid-template-columns: 1fr; max-width: 380px; margin: 0 auto; }
    .lp__partners-grid { grid-template-columns: repeat(2, 1fr); }
}


/* ============================================================
   INNER PAGES — shared header / hero / footer for legal & info
   ============================================================ */

/* Fix about card link arrow explicit contrast */
.lp__about-card .lp__link-arrow { background: var(--lp-cream); color: var(--lp-wine) !important; }

/* Inner page hero (page title section) */
.lp__inner-hero { padding: 72px 0 52px; border-bottom: 1px solid var(--lp-line); }
.lp__inner-hero h1 { font-family: 'Fraunces', serif; font-size: clamp(30px, 4.2vw, 50px); font-weight: 600; max-width: 780px; margin: 12px 0 0; line-height: 1.1; color: var(--lp-ink); }
.lp__inner-hero p { max-width: 680px; margin: 16px 0 0; font-size: 17px; color: var(--lp-ink-soft); }
.lp__inner-hero .lp__eyebrow { margin-bottom: 8px; }

/* Legal pages */
.lp__legal { padding: 56px 0 100px; }
.lp__legal-body { max-width: 820px; display: flex; flex-direction: column; gap: 40px; }
.lp__legal-section { display: flex; flex-direction: column; gap: 10px; }
.lp__legal-section h2 { font-family: 'Fraunces', serif; font-size: 22px; font-weight: 600; color: var(--lp-ink); }
.lp__legal-section p { font-size: 15.5px; color: var(--lp-ink-soft); line-height: 1.72; }
.lp__legal-section ul { list-style: none; padding: 0; margin: 4px 0 0; display: flex; flex-direction: column; gap: 8px; }
.lp__legal-section ul li { position: relative; padding-left: 18px; font-size: 15px; color: var(--lp-ink-soft); line-height: 1.6; }
.lp__legal-section ul li::before { content: "-"; position: absolute; left: 0; color: var(--lp-wine); font-weight: 700; }
.lp__legal-meta { font-size: 13px; color: var(--lp-ink-dim); font-style: italic; }
.lp__legal-toc { background: var(--lp-cream-2); border: 1px solid var(--lp-line); border-radius: var(--lp-radius); padding: 24px 28px; }
.lp__legal-toc strong { display: block; font-size: 12px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--lp-ink-dim); margin-bottom: 12px; }
.lp__legal-toc ol { padding-left: 18px; margin: 0; display: flex; flex-direction: column; gap: 5px; }
.lp__legal-toc ol li { font-size: 14px; color: var(--lp-ink-soft); }
.lp__legal-toc ol li a { color: var(--lp-wine); }
.lp__legal-info { background: rgba(61,24,24,.05); border-left: 3px solid var(--lp-wine); padding: 14px 18px; border-radius: 0 var(--lp-radius-sm) var(--lp-radius-sm) 0; font-size: 14.5px; color: var(--lp-ink-soft); }
.lp__legal-divider { height: 1px; background: var(--lp-line); border: none; margin: 0; }

/* Contact page */
.lp__contact { padding: 56px 0 100px; }
.lp__contact-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: 48px; align-items: start; }
.lp__contact-info { display: flex; flex-direction: column; gap: 18px; }
.lp__contact-card { background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: var(--lp-radius); padding: 28px; display: flex; flex-direction: column; gap: 8px; }
.lp__contact-card h3 { font-size: 19px; }
.lp__contact-card p { font-size: 15px; }
.lp__contact-email { font-family: 'Fraunces', serif; font-size: 24px; font-weight: 600; color: var(--lp-wine); }
.lp__contact-email:hover { text-decoration: underline; }
.lp__contact-form { background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: var(--lp-radius); padding: 32px; }
.lp__contact-form h3 { font-size: 22px; margin-bottom: 6px; }
.lp__contact-form > p { font-size: 14.5px; color: var(--lp-ink-soft); margin-bottom: 24px; }
.lp__field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.lp__field label { font-size: 12.5px; font-weight: 700; color: var(--lp-ink-dim); text-transform: uppercase; letter-spacing: 0.09em; }
.lp__field input, .lp__field textarea, .lp__field select {
    font-family: 'Manrope', sans-serif; font-size: 15px; padding: 12px 16px;
    border: 1.5px solid var(--lp-line-2); border-radius: var(--lp-radius-sm);
    background: var(--lp-cream); color: var(--lp-ink); outline: none;
    transition: border-color .2s, box-shadow .2s;
}
.lp__field input:focus, .lp__field textarea:focus, .lp__field select:focus { border-color: var(--lp-wine); box-shadow: 0 0 0 3px rgba(61,24,24,.08); }
.lp__field textarea { min-height: 120px; resize: vertical; }
.lp__form-success { display: none; padding: 20px; background: rgba(98,197,84,.1); border: 1px solid rgba(98,197,84,.3); border-radius: var(--lp-radius-sm); color: #2f7a3a; font-weight: 600; text-align: center; }

/* Integration scope */
.lp__intscope { padding: 56px 0 100px; }
.lp__intscope-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 0; }
.lp__intscope-card { background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: var(--lp-radius); padding: 28px; display: flex; flex-direction: column; gap: 10px; }
.lp__intscope-card h3 { font-size: 20px; }
.lp__intscope-card p { font-size: 15px; }
.lp__intscope-channels { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.lp__intscope-channels span { padding: 5px 12px; background: var(--lp-cream-2); border: 1px solid var(--lp-line); border-radius: 999px; font-size: 13px; color: var(--lp-ink-soft); }
.lp__intscope-disclaimer { max-width: 100%; margin-top: 36px; padding: 16px 20px; background: var(--lp-cream-2); border: 1px solid var(--lp-line); border-radius: var(--lp-radius-sm); font-size: 13px; color: var(--lp-ink-dim); }

@media (max-width: 760px) {
    .lp__contact-grid { grid-template-columns: 1fr; }
    .lp__intscope-grid { grid-template-columns: 1fr; }
    .lp__legal-body { max-width: 100%; }
}


/* ============================================================
   LANGUAGE SWITCHER
   ============================================================ */
.lp__lang { position: relative; }
.lp__lang-btn {
    background: transparent; border: 1px solid var(--lp-line-2); color: var(--lp-ink-soft);
    padding: 7px 12px; border-radius: 8px; font-size: 13px; font-weight: 600; cursor: pointer;
    display: inline-flex; align-items: center; gap: 6px; font-family: 'Manrope', sans-serif;
    transition: color .2s, border-color .2s, background .2s;
}
.lp__lang-btn:hover { color: var(--lp-wine); border-color: var(--lp-wine); background: rgba(61,24,24,.04); }
.lp__lang-btn::after { content: "▾"; font-size: 10px; opacity: .7; }
.lp__lang-menu {
    position: absolute; top: calc(100% + 8px); right: 0;
    background: var(--lp-card); border: 1px solid var(--lp-line); border-radius: 12px;
    box-shadow: var(--lp-shadow-md); padding: 6px; min-width: 160px;
    display: none; z-index: 100;
}
.lp__lang.is-open .lp__lang-menu { display: block; }
.lp__lang-menu button {
    display: flex; width: 100%; align-items: center; justify-content: space-between;
    background: transparent; border: none; padding: 10px 12px; border-radius: 8px;
    cursor: pointer; font-size: 14px; color: var(--lp-ink); text-align: left;
    font-family: 'Manrope', sans-serif;
}
.lp__lang-menu button:hover { background: var(--lp-cream-2); }
.lp__lang-menu button.is-active { color: var(--lp-wine); font-weight: 700; background: rgba(61,24,24,.05); }
.lp__lang-menu button.is-active::after { content: "✓"; }

@media (max-width: 760px) {
    .lp__lang { order: 3; }
    .lp__lang-menu { right: auto; left: 0; }
}
