/* ════════════════════════════════════════════════════════════════════
   Mobile navigation panel — Cameron Square / ELANBY
   Editorial drawer, sticky head + foot, identity card, staggered list,
   lighting picker. Tokens come from Landing.css.
════════════════════════════════════════════════════════════════════════ */

/* ── Burger trigger ────────────────────────────────────────────────── */
.lp-burger {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid var(--rule-soft);
    background: color-mix(in srgb, var(--canvas) 92%, transparent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: border-color var(--ease-swift),
                background var(--ease-swift),
                transform var(--ease-swift),
                box-shadow var(--ease-swift);
}

.lp-burger:hover {
    border-color: var(--rule);
    background: var(--canvas);
    box-shadow: 0 6px 18px -10px rgba(9, 12, 18, 0.32);
}

.lp-burger:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--brand) 64%, transparent);
    outline-offset: 2px;
}

.lp-burger:active {
    transform: scale(0.96);
}

.lp-burger__lines {
    position: relative;
    width: 20px;
    height: 14px;
    display: inline-block;
}

.lp-burger__lines span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 1.6px;
    background: var(--ink);
    border-radius: 999px;
    transition: transform 0.32s cubic-bezier(0.22, 1, 0.36, 1),
                opacity 0.18s ease,
                top 0.32s cubic-bezier(0.22, 1, 0.36, 1),
                width 0.32s cubic-bezier(0.22, 1, 0.36, 1);
}

.lp-burger__lines span:nth-child(1) { top: 0; }
.lp-burger__lines span:nth-child(2) { top: 6px; width: 70%; }
.lp-burger__lines span:nth-child(3) { top: 12px; }

.lp-burger:hover .lp-burger__lines span:nth-child(2) { width: 100%; }

.lp-burger.is-open {
    background: color-mix(in srgb, var(--canvas) 80%, transparent);
    border-color: var(--rule);
}

.lp-burger.is-open .lp-burger__lines span:nth-child(1) {
    top: 6px;
    transform: rotate(45deg);
}

.lp-burger.is-open .lp-burger__lines span:nth-child(2) {
    opacity: 0;
    width: 100%;
}

.lp-burger.is-open .lp-burger__lines span:nth-child(3) {
    top: 6px;
    transform: rotate(-45deg);
}


/* ── Drawer container ──────────────────────────────────────────────── */
.lp-mnav {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: flex;
    pointer-events: none;
    visibility: hidden;
    opacity: 0;
    /* content-visibility keeps the panel and its backdrop-filter out of the
       compositor while the drawer is closed, preventing the flash that occurs
       when the browser creates a new layer for a fixed+backdrop-filter subtree. */
    content-visibility: hidden;
    transition: opacity 0.28s ease, visibility 0s linear 0.34s;
}

.lp-mnav.is-open {
    content-visibility: visible;
    pointer-events: auto;
    visibility: visible;
    opacity: 1;
    transition: opacity 0.22s ease, visibility 0s linear 0s;
}

.lp-mnav__backdrop {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at top right,
            rgba(184, 115, 51, 0.06) 0%,
            transparent 55%),
        rgba(10, 12, 18, 0.46);
    backdrop-filter: blur(6px) saturate(120%);
    -webkit-backdrop-filter: blur(6px) saturate(120%);
    opacity: 0;
    transition: opacity 0.34s ease;
}

.lp-mnav.is-open .lp-mnav__backdrop {
    opacity: 1;
}

html.is-dark .lp-mnav__backdrop {
    background:
        radial-gradient(ellipse at top right,
            rgba(216, 145, 92, 0.10) 0%,
            transparent 55%),
        rgba(0, 0, 0, 0.62);
}


/* ── Panel ─────────────────────────────────────────────────────────── */
.lp-mnav__panel {
    position: relative;
    margin-left: auto;
    width: min(94vw, 400px);
    height: 100%;
    background: var(--canvas);
    border-left: 1px solid var(--rule-soft);
    box-shadow:
        -32px 0 60px -28px rgba(9, 12, 18, 0.32),
        -1px 0 0 0 var(--rule-soft);
    transform: translateX(100%);
    transition: transform 0.46s cubic-bezier(0.22, 1, 0.36, 1),
                background 0.4s ease;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    /* Subtle paper-grain wash on the side */
}

.lp-mnav__panel::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 88% -10%,
            color-mix(in srgb, var(--amber) 14%, transparent) 0%,
            transparent 42%),
        radial-gradient(circle at -20% 110%,
            color-mix(in srgb, var(--brand) 10%, transparent) 0%,
            transparent 46%);
    opacity: 0.55;
}

.lp-mnav.is-open .lp-mnav__panel {
    transform: translateX(0);
}

/* ── Diagonal ribbon: amber thread that sweeps in on open ─────────── */
.lp-mnav__ribbon {
    position: absolute;
    top: -20%;
    right: -10%;
    width: 220px;
    height: 1px;
    background: linear-gradient(to right,
        transparent 0%,
        color-mix(in srgb, var(--amber) 60%, transparent) 30%,
        color-mix(in srgb, var(--amber) 100%, transparent) 50%,
        color-mix(in srgb, var(--amber) 60%, transparent) 70%,
        transparent 100%);
    transform: rotate(-32deg) scaleX(0);
    transform-origin: right center;
    opacity: 0;
    pointer-events: none;
    z-index: 3;
    box-shadow: 0 0 22px color-mix(in srgb, var(--amber) 35%, transparent);
}

.lp-mnav.is-open .lp-mnav__ribbon {
    opacity: 1;
    transform: rotate(-32deg) scaleX(1);
    transition: transform 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.1s,
                opacity 0.4s ease 0.1s;
}

html.is-dark .lp-mnav__ribbon {
    background: linear-gradient(to right,
        transparent 0%,
        color-mix(in srgb, var(--amber) 70%, transparent) 30%,
        color-mix(in srgb, var(--amber) 100%, transparent) 50%,
        color-mix(in srgb, var(--amber) 70%, transparent) 70%,
        transparent 100%);
    box-shadow: 0 0 28px color-mix(in srgb, var(--amber) 50%, transparent);
}


/* ── Sticky header: brand + close ──────────────────────────────────── */
.lp-mnav__head {
    position: relative;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    padding: clamp(20px, 5vw, 26px) clamp(18px, 6vw, 28px) clamp(18px, 4vw, 22px);
    padding-top: max(clamp(20px, 5vw, 26px), env(safe-area-inset-top));
    border-bottom: 1px solid var(--rule-soft);
    background: color-mix(in srgb, var(--canvas) 96%, transparent);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 2;
}

.lp-mnav__brand {
    display: inline-flex;
    flex-direction: column;
    gap: 8px;
    text-decoration: none;
    color: var(--ink);
    transition: opacity var(--ease-swift);
    line-height: 1;
}

.lp-mnav__brand:hover { opacity: 0.85; }

.lp-mnav__brand-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.62rem;
    text-transform: uppercase;
    letter-spacing: 0.28em;
    color: var(--ink-3);
    font-weight: 500;
    opacity: 0;
    transform: translateY(-4px);
}

.lp-mnav.is-open .lp-mnav__brand-eyebrow {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.5s ease 0.34s,
                transform 0.5s cubic-bezier(0.22, 1, 0.36, 1) 0.34s;
}

.lp-mnav__brand-dot {
    width: 5px;
    height: 5px;
    border-radius: 999px;
    background: var(--amber);
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--amber) 60%, transparent);
    animation: lp-mnav-pulse 2.6s ease-in-out infinite;
}

@keyframes lp-mnav-pulse {
    0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--amber) 60%, transparent); }
    50%      { box-shadow: 0 0 0 6px color-mix(in srgb, var(--amber) 0%, transparent); }
}

.lp-mnav__brand-words {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: baseline;
    font-family: var(--serif);
    font-size: 1.4rem;
    color: var(--ink);
    line-height: 1;
    letter-spacing: 0.005em;
}

.lp-mnav__brand-word {
    display: inline-block;
    overflow: hidden;
    position: relative;
    /* Mask-reveal: the word sits inside an inline-block that clip-path's
       from a thin slit to full reveal as the drawer opens. */
    clip-path: inset(0 100% 0 0);
    transform: translateY(0.35em);
}

.lp-mnav.is-open .lp-mnav__brand-word {
    clip-path: inset(0 0 0 0);
    transform: translateY(0);
    transition: clip-path 0.7s cubic-bezier(0.22, 1, 0.36, 1) 0.18s,
                transform 0.7s cubic-bezier(0.22, 1, 0.36, 1) 0.18s;
}

.lp-mnav.is-open .lp-mnav__brand-word--em {
    transition-delay: 0.30s;
}

.lp-mnav__brand-word--em {
    font-style: italic;
    color: var(--amber);
}

.lp-mnav__close {
    position: relative;
    width: 40px;
    height: 40px;
    border-radius: 999px;
    border: 1px solid var(--rule-soft);
    background: var(--canvas);
    color: var(--ink-2);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    overflow: hidden;
    flex-shrink: 0;
    align-self: flex-start;
    transition: border-color var(--ease-swift),
                color var(--ease-swift),
                background var(--ease-swift),
                transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Animated ring that traces the close button on open */
.lp-mnav__close-arc {
    position: absolute;
    inset: 2px;
    border-radius: 999px;
    border: 1.5px solid transparent;
    background:
        conic-gradient(from 0deg,
            transparent 0deg,
            color-mix(in srgb, var(--amber) 60%, transparent) 90deg,
            transparent 180deg) border-box;
    -webkit-mask:
        linear-gradient(#000 0 0) padding-box,
        linear-gradient(#000 0 0);
            mask:
        linear-gradient(#000 0 0) padding-box,
        linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
            mask-composite: exclude;
    opacity: 0;
    transform: rotate(-90deg) scale(0.6);
    transition: opacity 0.5s ease, transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
    pointer-events: none;
}

.lp-mnav.is-open .lp-mnav__close-arc {
    opacity: 1;
    transform: rotate(270deg) scale(1);
    transition-delay: 0.42s;
}

.lp-mnav__close svg {
    position: relative;
    z-index: 1;
    transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

.lp-mnav__close:hover {
    border-color: var(--rule);
    color: var(--ink);
    background: color-mix(in srgb, var(--canvas-2) 80%, transparent);
    transform: scale(1.06);
}

.lp-mnav__close:hover svg {
    transform: rotate(90deg);
}

.lp-mnav__close:active { transform: scale(0.94); }

.lp-mnav__close:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--brand) 56%, transparent);
    outline-offset: 2px;
}


/* ── Body / scroll region ──────────────────────────────────────────── */
.lp-mnav__body {
    position: relative;
    padding: clamp(20px, 4.5vw, 28px) clamp(18px, 6vw, 28px) 28px;
    overflow-y: auto;
    overscroll-behavior: contain;
    flex: 1;
    z-index: 1;
}

.lp-mnav__body::-webkit-scrollbar { width: 6px; }
.lp-mnav__body::-webkit-scrollbar-thumb {
    background: var(--rule-soft);
    border-radius: 999px;
}


/* ── Identity card (logged in) ─────────────────────────────────────── */
.lp-mnav__user {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 14px;
    padding: 14px 14px 14px 14px;
    border-radius: 18px;
    background:
        linear-gradient(135deg,
            color-mix(in srgb, var(--canvas-2) 80%, transparent) 0%,
            color-mix(in srgb, var(--canvas-3) 36%, transparent) 100%);
    border: 1px solid var(--rule-soft);
    text-decoration: none;
    color: var(--ink);
    margin-bottom: 22px;
    transition: border-color var(--ease-swift),
                box-shadow var(--ease-swift),
                transform var(--ease-swift);
    opacity: 0;
    transform: translateY(8px);
}

.lp-mnav.is-open .lp-mnav__user {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.4s ease 0.18s,
                transform 0.4s cubic-bezier(0.22, 1, 0.36, 1) 0.18s,
                border-color var(--ease-swift),
                box-shadow var(--ease-swift);
}

.lp-mnav__user:hover {
    border-color: var(--rule);
    box-shadow: 0 10px 26px -18px rgba(9, 12, 18, 0.30);
}

.lp-mnav__user-ring {
    position: relative;
    width: 46px;
    height: 46px;
    border-radius: 999px;
    padding: 2px;
    background: conic-gradient(from 140deg,
        var(--amber),
        var(--brand),
        var(--amber));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.lp-mnav__user-avatar {
    width: 100%;
    height: 100%;
    border-radius: 999px;
    object-fit: cover;
    border: 2px solid var(--canvas);
    background: var(--canvas);
}

.lp-mnav__user-meta {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.lp-mnav__user-name {
    font-family: var(--serif);
    font-size: 1.08rem;
    color: var(--ink);
    letter-spacing: 0.01em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.lp-mnav__user-email {
    font-size: 0.78rem;
    color: var(--ink-3);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.lp-mnav__user-chev {
    color: var(--ink-3);
    transition: transform var(--ease-swift), color var(--ease-swift);
}

.lp-mnav__user:hover .lp-mnav__user-chev {
    color: var(--ink-2);
    transform: translateX(2px);
}


/* ── Section labels ────────────────────────────────────────────────── */
.lp-mnav__section-label {
    display: grid;
    grid-template-columns: auto auto 1fr;
    align-items: center;
    gap: 12px;
    font-family: var(--serif);
    font-style: italic;
    color: var(--ink-3);
    margin: 4px 0 14px;
    opacity: 0;
    transform: translateY(6px);
}

.lp-mnav.is-open .lp-mnav__section-label {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.36s ease 0.22s,
                transform 0.36s cubic-bezier(0.22, 1, 0.36, 1) 0.22s;
}

.lp-mnav.is-open .lp-mnav__section-label + ul + .lp-mnav__section-label {
    transition-delay: 0.34s;
}

.lp-mnav__section-num {
    font-size: 0.92rem;
    letter-spacing: 0.06em;
    color: color-mix(in srgb, var(--amber) 90%, var(--ink-3));
}

.lp-mnav__section-text {
    font-size: 1.04rem;
    color: var(--ink);
}

.lp-mnav__section-rule {
    height: 1px;
    background: linear-gradient(to right,
        var(--rule),
        transparent);
    align-self: center;
    transform: scaleX(0);
    transform-origin: left center;
}

.lp-mnav.is-open .lp-mnav__section-rule {
    transform: scaleX(1);
    transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1) 0.36s;
}

.lp-mnav.is-open .lp-mnav__section-label + ul + .lp-mnav__section-label .lp-mnav__section-rule {
    transition-delay: 0.48s;
}


/* ── Link list & items ─────────────────────────────────────────────── */
.lp-mnav__list {
    list-style: none;
    padding: 0;
    display: grid;
    gap: 8px;
    margin-bottom: 24px;
}

.lp-mnav__list li {
    opacity: 0;
    transform: translateX(14px);
}

.lp-mnav.is-open .lp-mnav__list li {
    opacity: 1;
    transform: translateX(0);
    transition: opacity 0.42s ease,
                transform 0.42s cubic-bezier(0.22, 1, 0.36, 1);
}

.lp-mnav.is-open .lp-mnav__list li:nth-child(1) { transition-delay: 0.20s; }
.lp-mnav.is-open .lp-mnav__list li:nth-child(2) { transition-delay: 0.26s; }
.lp-mnav.is-open .lp-mnav__list li:nth-child(3) { transition-delay: 0.32s; }
.lp-mnav.is-open .lp-mnav__list li:nth-child(4) { transition-delay: 0.38s; }
.lp-mnav.is-open .lp-mnav__list li:nth-child(5) { transition-delay: 0.44s; }
.lp-mnav.is-open .lp-mnav__list li:nth-child(6) { transition-delay: 0.50s; }

.lp-mnav__link {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 14px;
    align-items: center;
    padding: 13px 14px;
    border-radius: 16px;
    border: 1px solid transparent;
    background: color-mix(in srgb, var(--canvas-2) 50%, transparent);
    color: var(--ink);
    text-decoration: none;
    transition: border-color var(--ease-swift),
                background var(--ease-swift),
                transform var(--ease-swift),
                box-shadow var(--ease-swift);
}

.lp-mnav__link:hover {
    transform: translateX(3px);
    border-color: var(--rule-soft);
    background: color-mix(in srgb, var(--canvas-2) 78%, transparent);
}

.lp-mnav__link:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--brand) 56%, transparent);
    outline-offset: 2px;
}

.lp-mnav__link.is-active {
    background: color-mix(in srgb, var(--amber-lt) 60%, transparent);
    border-color: color-mix(in srgb, var(--amber) 32%, transparent);
    box-shadow: 0 8px 22px -16px color-mix(in srgb, var(--amber) 70%, transparent);
}

.lp-mnav__link.is-active::before {
    content: "";
    position: absolute;
    left: -1px;
    top: 22%;
    bottom: 22%;
    width: 3px;
    border-radius: 0 4px 4px 0;
    background: linear-gradient(to bottom, var(--amber), var(--amber-d));
}

.lp-mnav__ico {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--ink-4);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--ink-4) 18%, transparent);
    transition: background var(--ease-swift), box-shadow var(--ease-swift);
}

.lp-mnav__link:hover .lp-mnav__ico {
    background: var(--brand);
    box-shadow: 0 0 0 5px color-mix(in srgb, var(--brand) 18%, transparent);
}

.lp-mnav__link.is-active .lp-mnav__ico {
    background: var(--amber);
    box-shadow: 0 0 0 5px color-mix(in srgb, var(--amber) 22%, transparent);
    animation: lp-mnav-pulse 2.6s ease-in-out infinite;
}

/* Active link gets a slow shimmer sweep */
.lp-mnav__link.is-active::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(115deg,
        transparent 0%,
        transparent 38%,
        color-mix(in srgb, var(--amber) 22%, transparent) 50%,
        transparent 62%,
        transparent 100%);
    background-size: 220% 100%;
    background-position: 120% 0;
    pointer-events: none;
    animation: lp-mnav-shimmer 4.2s ease-in-out infinite;
    animation-delay: 1.4s;
}

@keyframes lp-mnav-shimmer {
    0%   { background-position: 120% 0; }
    55%  { background-position: -40% 0; }
    100% { background-position: -40% 0; }
}

.lp-mnav__label {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.lp-mnav__label-main {
    font-weight: 600;
    font-size: 0.99rem;
    color: var(--ink);
    letter-spacing: 0.005em;
}

.lp-mnav__label-sub {
    font-size: 0.76rem;
    color: var(--ink-3);
    line-height: 1.35;
}

.lp-mnav__arrow {
    position: relative;
    width: 30px;
    height: 30px;
    border-radius: 999px;
    border: 1px solid var(--rule-soft);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--ink-3);
    background: color-mix(in srgb, var(--canvas) 60%, transparent);
    transition: border-color var(--ease-swift),
                color var(--ease-swift),
                background var(--ease-swift),
                transform 0.34s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Glow ring that swells behind the arrow on hover */
.lp-mnav__arrow::before {
    content: "";
    position: absolute;
    inset: -4px;
    border-radius: 999px;
    background: radial-gradient(circle,
        color-mix(in srgb, var(--brand) 28%, transparent) 0%,
        transparent 70%);
    opacity: 0;
    transform: scale(0.6);
    transition: opacity var(--ease-swift),
                transform 0.34s cubic-bezier(0.22, 1, 0.36, 1);
    pointer-events: none;
    z-index: -1;
}

.lp-mnav__link:hover .lp-mnav__arrow::before {
    opacity: 1;
    transform: scale(1);
}

.lp-mnav__link:hover .lp-mnav__arrow {
    color: var(--ink);
    border-color: var(--rule);
    transform: translate(3px, -3px) rotate(-4deg);
}

.lp-mnav__link.is-active .lp-mnav__arrow {
    color: var(--amber-d);
    border-color: color-mix(in srgb, var(--amber) 38%, transparent);
    background: color-mix(in srgb, var(--canvas) 80%, transparent);
}


/* ── Sticky footer ─────────────────────────────────────────────────── */
.lp-mnav__foot {
    position: relative;
    padding: 18px clamp(18px, 6vw, 28px) 22px;
    padding-bottom: max(22px, env(safe-area-inset-bottom));
    border-top: 1px solid var(--rule-soft);
    background: color-mix(in srgb, var(--canvas-2) 70%, transparent);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    z-index: 2;
}


/* ── Theme picker ──────────────────────────────────────────────────── */
.lp-mnav__theme {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 14px;
}

.lp-mnav__theme-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: var(--ink-3);
    font-weight: 500;
}

.lp-mnav__theme-btns {
    display: inline-flex;
    gap: 4px;
    padding: 4px;
    border-radius: 999px;
    border: 1px solid var(--rule-soft);
    background: var(--canvas);
}

.lp-mnav__theme-btn {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    border: 0;
    background: transparent;
    color: var(--ink-3);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    transition: background var(--ease-swift),
                color var(--ease-swift);
}

.lp-mnav__theme-btn:hover {
    color: var(--ink);
    background: color-mix(in srgb, var(--canvas-2) 70%, transparent);
}

.lp-mnav__theme-btn:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--brand) 56%, transparent);
    outline-offset: 1px;
}

.lp-mnav__theme-btn.is-active {
    color: var(--ink);
    background: color-mix(in srgb, var(--canvas-2) 95%, var(--ink) 5%);
    box-shadow: inset 0 0 0 1px var(--rule);
}


/* ── Primary CTA / sign-out / sign-in ──────────────────────────────── */
.lp-mnav__logout-form { margin: 0; }

.lp-mnav__cta {
    width: 100%;
    border-radius: 14px;
    border: 1px solid transparent;
    padding: 13px 16px;
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    cursor: pointer;
    text-decoration: none;
    font-size: 0.95rem;
    font-weight: 500;
    transition: border-color var(--ease-swift),
                background var(--ease-swift),
                color var(--ease-swift),
                transform var(--ease-swift),
                box-shadow var(--ease-swift);
}

.lp-mnav__cta:active { transform: scale(0.98); }

.lp-mnav__cta-label {
    letter-spacing: 0.01em;
}

/* Primary (sign in) — dark ink button matching desktop .lp-signin */
.lp-mnav__cta--primary {
    background: var(--ink);
    color: var(--canvas);
    border-color: var(--ink);
}

.lp-mnav__cta--primary:hover {
    background: var(--ink-2);
    box-shadow: 0 12px 28px -16px rgba(9, 12, 18, 0.46);
}

.lp-mnav__cta--primary svg { transition: transform var(--ease-swift); }
.lp-mnav__cta--primary:hover svg { transform: translateX(3px); }

/* Danger (logout) */
.lp-mnav__cta--danger {
    background: color-mix(in srgb, #b43535 8%, var(--canvas));
    border-color: color-mix(in srgb, #b43535 28%, transparent);
    color: #b43535;
}

.lp-mnav__cta--danger:hover {
    background: color-mix(in srgb, #b43535 14%, var(--canvas));
    border-color: color-mix(in srgb, #b43535 42%, transparent);
    box-shadow: 0 10px 24px -16px rgba(180, 53, 53, 0.4);
}

.lp-mnav__cta:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--brand) 56%, transparent);
    outline-offset: 2px;
}


/* ── Legal line ────────────────────────────────────────────────────── */
.lp-mnav__legal {
    margin: 14px 0 0;
    text-align: center;
    font-size: 0.7rem;
    color: var(--ink-4);
    letter-spacing: 0.04em;
}

.lp-mnav__legal-em {
    font-family: var(--serif);
    font-style: italic;
    color: var(--ink-3);
}


/* ── Body lock ─────────────────────────────────────────────────────── */
body.lp-mnav-open {
    overflow: hidden;
}


/* ── Dark-mode tuning ──────────────────────────────────────────────── */
html.is-dark .lp-mnav__panel {
    box-shadow:
        -32px 0 60px -28px rgba(0, 0, 0, 0.6),
        -1px 0 0 0 var(--rule-soft);
}

html.is-dark .lp-mnav__brand-mark {
    box-shadow: 0 0 0 1px var(--rule), 0 6px 14px -8px rgba(0, 0, 0, 0.6);
}

html.is-dark .lp-mnav__cta--danger {
    background: color-mix(in srgb, #ff6b6b 12%, var(--canvas-2));
    border-color: color-mix(in srgb, #ff6b6b 32%, transparent);
    color: #ff8a8a;
}

html.is-dark .lp-mnav__cta--danger:hover {
    background: color-mix(in srgb, #ff6b6b 18%, var(--canvas-2));
}

html.is-dark .lp-mnav__cta--primary {
    background: var(--canvas-3);
    color: var(--ink);
    border-color: var(--rule);
}

html.is-dark .lp-mnav__cta--primary:hover {
    background: color-mix(in srgb, var(--canvas-3) 70%, var(--ink) 8%);
}

html.is-dark .lp-mnav__theme-btn.is-active {
    background: color-mix(in srgb, var(--canvas-3) 70%, var(--ink) 4%);
    box-shadow: inset 0 0 0 1px var(--rule);
}


/* ── Responsive show/hide ──────────────────────────────────────────── */
@media (min-width: 901px) {
    .lp-burger { display: none; }
    .lp-mnav  { display: none; }
}

@media (max-width: 900px) {
    .lp-nav__links { display: none; }
    .lp-nav__right { gap: 10px; }
    /* Explicit show — overrides any cascade that could set display:none
       on the button (e.g. button reset rules from Landing.css). */
    .lp-burger { display: inline-flex; }
}



/* ── Reduced motion ────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .lp-mnav,
    .lp-mnav__panel,
    .lp-mnav__backdrop,
    .lp-mnav__list li,
    .lp-mnav__user,
    .lp-mnav__section-label,
    .lp-mnav__section-rule,
    .lp-mnav__close,
    .lp-mnav__close-arc,
    .lp-mnav__brand-word,
    .lp-mnav__brand-eyebrow,
    .lp-mnav__ribbon,
    .lp-burger__lines span {
        transition-duration: 0.01ms !important;
        transition-delay: 0ms !important;
    }
    .lp-mnav__brand-dot,
    .lp-mnav__link.is-active .lp-mnav__ico,
    .lp-mnav__link.is-active::after {
        animation: none !important;
    }
    .lp-mnav__close:hover { transform: none; }
}
