/* ===== Landing Pages (LP) — общий стиль для всех посадочных ===== */
:root {
    --lp-bg: #0b1020;
    --lp-bg-soft: #0f1730;
    --lp-card: #141c34;
    --lp-border: #263049;
    --lp-text: #e8ecf7;
    --lp-muted: #9aa4c0;
    --lp-primary: #7dd3fc;
    --lp-primary-2: #a78bfa;
    --lp-accent: #34d399;
    --lp-warn: #fbbf24;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.lp-body {
    margin: 0;
    background: var(--lp-bg);
    color: var(--lp-text);
    font-family: 'Onest', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    font-weight: 400;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
}

.lp-container { max-width: 1180px; margin: 0 auto; padding: 0 1.2rem; }

/* ===== Nav ===== */
.lp-nav {
    position: sticky; top: 0; z-index: 50;
    background: rgba(11,16,32,.85);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--lp-border);
}
.lp-nav .lp-container { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.lp-brand { color: var(--lp-text); text-decoration: none; font-weight: 800; font-size: 1.15rem; display: flex; align-items: center; gap: .5rem; }
.lp-brand i { color: var(--lp-primary); }
.lp-nav-links { display: flex; gap: 1.5rem; }
.lp-nav-links a { color: var(--lp-muted); text-decoration: none; font-weight: 500; font-size: .92rem; }
.lp-nav-links a:hover { color: var(--lp-text); }
.lp-nav-actions { display: flex; gap: .6rem; align-items: center; }
@media (max-width: 640px) { .lp-nav-links { display: none; } }

/* ===== Buttons ===== */
.lp-btn-primary, .lp-btn-ghost {
    display: inline-flex; align-items: center; gap: .5rem; justify-content: center;
    border-radius: .6rem; font-weight: 600; text-decoration: none; cursor: pointer;
    transition: transform .15s, box-shadow .15s, background .15s, border-color .15s;
    border: 1px solid transparent; white-space: nowrap;
}
.lp-btn-primary {
    background: linear-gradient(135deg, #7dd3fc 0%, #a78bfa 100%);
    color: #0b1020; padding: .75rem 1.3rem; font-size: .98rem;
    box-shadow: 0 8px 24px rgba(125,211,252,.25);
}
.lp-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 12px 28px rgba(125,211,252,.35); color: #0b1020; }
.lp-btn-ghost {
    background: transparent; color: var(--lp-text); border-color: var(--lp-border); padding: .7rem 1.2rem;
}
.lp-btn-ghost:hover { border-color: var(--lp-primary); color: var(--lp-primary); }
.lp-btn-sm { padding: .45rem .9rem; font-size: .88rem; }
.lp-btn-lg { padding: .9rem 1.6rem; font-size: 1.05rem; border-radius: .7rem; }
.lp-btn-xl { padding: 1.1rem 2.2rem; font-size: 1.15rem; border-radius: .8rem; }
.lp-btn-gift {
    margin-left: .6rem; background: rgba(11,16,32,.18); color: #0b1020;
    padding: .15rem .55rem; border-radius: .4rem; font-size: .75rem; font-weight: 700;
}

/* ===== Hero ===== */
.lp-hero { position: relative; padding: 3.5rem 0 4rem; overflow: hidden; }
.lp-hero-particles {
    position: absolute; inset: 0; z-index: 0;
    pointer-events: none;
    opacity: .85;
    mix-blend-mode: screen;
}
.lp-hero-bg {
    position: absolute; inset: 0; z-index: 0;
    background:
        radial-gradient(700px 400px at 20% 10%, rgba(125,211,252,.12), transparent 60%),
        radial-gradient(600px 360px at 80% 60%, rgba(167,139,250,.12), transparent 60%);
    pointer-events: none;
}
.lp-hero-inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 2.2rem; align-items: center; }
.lp-hero-inner > .lp-hero-visual { justify-self: end; width: 100%; max-width: 460px; }
@media (max-width: 900px) {
    .lp-hero-inner { grid-template-columns: 1fr; }
    .lp-hero-inner > .lp-hero-visual { justify-self: stretch; max-width: none; }
}

.lp-eyebrow {
    display: inline-block; padding: .35rem .8rem; border-radius: 1rem;
    background: rgba(125,211,252,.1); color: var(--lp-primary);
    font-size: .78rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
    margin-bottom: 1rem;
}
.lp-h1 {
    font-size: clamp(2rem, 4vw, 3.2rem); font-weight: 800; line-height: 1.12;
    margin: 0 0 1rem; letter-spacing: -.02em;
}
.lp-h1 .lp-accent-grad { background: linear-gradient(90deg, #7dd3fc, #a78bfa); -webkit-background-clip: text; background-clip: text; color: transparent; }
.lp-hero-sub { color: var(--lp-muted); font-size: 1.1rem; margin: 0 0 1.6rem; max-width: 580px; }

.lp-hero-points { list-style: none; padding: 0; margin: 0 0 1.6rem; display: grid; gap: .5rem; }
.lp-hero-points li { display: flex; gap: .55rem; align-items: flex-start; color: var(--lp-text); }
.lp-hero-points li i { color: var(--lp-accent); margin-top: .2rem; }

.lp-cta-row { display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; margin-bottom: .8rem; }
.lp-cta-note { color: var(--lp-muted); font-size: .85rem; }
.lp-cta-note i { color: var(--lp-accent); }

.lp-hero-visual { position: relative; }
.lp-demo-card {
    background: var(--lp-card); border: 1px solid var(--lp-border);
    border-radius: 1rem; padding: 1.2rem; box-shadow: 0 20px 60px rgba(0,0,0,.4);
}
.lp-demo-head { display: flex; gap: .5rem; align-items: center; margin-bottom: 1rem; padding-bottom: .8rem; border-bottom: 1px solid var(--lp-border); }
.lp-demo-dots span { display: inline-block; width: 9px; height: 9px; border-radius: 50%; background: #ef4444; margin-right: 4px; }
.lp-demo-dots span:nth-child(2) { background: #fbbf24; }
.lp-demo-dots span:nth-child(3) { background: #34d399; }
.lp-demo-title { color: var(--lp-muted); font-size: .85rem; margin-left: .4rem; }
.lp-demo-title-slot { color: var(--lp-muted); font-size: .85rem; margin-left: .4rem; transition: opacity .35s ease; }

/* ===== Hero-слайдер примеров ===== */
.lp-demo-slider { position: relative; padding-bottom: 1.4rem; }
.lp-demo-viewport { overflow: hidden; }
.lp-demo-track { display: flex; transition: transform .65s cubic-bezier(.22, .61, .36, 1); will-change: transform; }
.lp-demo-slide {
    flex: 0 0 100%;
    display: grid;
    gap: .55rem;
    min-height: 270px;
    opacity: .35;
    transition: opacity .55s ease;
}
.lp-demo-slide.is-active { opacity: 1; }
.lp-demo-stage {
    padding: .7rem .9rem;
    border-radius: .55rem;
    background: rgba(var(--rgb), .08);
    border: 1px solid rgba(var(--rgb), .25);
    transform: translateY(8px);
    opacity: 0;
    transition: transform .5s ease, opacity .5s ease;
}
.lp-demo-slide.is-active .lp-demo-stage { transform: translateY(0); opacity: 1; }
.lp-demo-slide.is-active .lp-demo-stage:nth-child(1) { transition-delay: .05s; }
.lp-demo-slide.is-active .lp-demo-stage:nth-child(2) { transition-delay: .15s; }
.lp-demo-slide.is-active .lp-demo-stage:nth-child(3) { transition-delay: .25s; }
.lp-demo-slide.is-active .lp-demo-stage:nth-child(4) { transition-delay: .35s; }
.lp-demo-stage.s-blue   { --rgb: 125, 211, 252; }
.lp-demo-stage.s-purple { --rgb: 167, 139, 250; }
.lp-demo-stage.s-amber  { --rgb: 251, 191,  36; }
.lp-demo-stage.s-green  { --rgb:  52, 211, 153; }
.lp-demo-stage-label {
    color: rgb(var(--rgb));
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    margin-bottom: .2rem;
    font-weight: 600;
}
.lp-demo-stage-text { font-size: .88rem; line-height: 1.4; }

/* Точки-индикаторы */
.lp-demo-pager {
    position: absolute; left: 0; right: 0; bottom: .35rem;
    display: flex; justify-content: center; gap: .45rem;
}
.lp-demo-dot {
    width: 7px; height: 7px; padding: 0; border: 0; border-radius: 50%;
    background: rgba(148, 163, 184, .35); cursor: pointer;
    transition: background .25s ease, width .25s ease;
}
.lp-demo-dot:hover { background: rgba(148, 163, 184, .65); }
.lp-demo-dot.is-active { background: var(--lp-primary-2, #a78bfa); width: 22px; border-radius: 4px; }

@media (prefers-reduced-motion: reduce) {
    .lp-demo-track { transition: none; }
    .lp-demo-stage { transition: none; transform: none; opacity: 1; }
    .lp-demo-slide { opacity: 1; }
}

/* ===== Sections общие ===== */
.lp-section { padding: 3.5rem 0; }
.lp-section.lp-pain { background: var(--lp-bg-soft); }
.lp-section.lp-features { background: var(--lp-bg-soft); }
.lp-section.lp-pricing { background: var(--lp-bg-soft); }
.lp-h2 {
    font-size: clamp(1.5rem, 3vw, 2.2rem); font-weight: 800;
    text-align: center; margin: 0 0 .4rem; letter-spacing: -.01em;
}
.lp-section-sub { color: var(--lp-muted); text-align: center; margin: 0 auto 2rem; max-width: 720px; font-size: 1.02rem; }

/* ===== Pain ===== */
.lp-pain-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1rem; margin-top: 1.8rem; }
.lp-pain-card {
    background: var(--lp-card); border: 1px solid var(--lp-border); border-radius: .8rem;
    padding: 1.2rem; display: flex; gap: .9rem; align-items: flex-start;
}
.lp-pain-icon {
    width: 40px; height: 40px; border-radius: .55rem; flex: 0 0 40px;
    background: rgba(248,113,113,.12); color: #f87171;
    display: flex; align-items: center; justify-content: center; font-size: 1.2rem;
}
.lp-pain-text { color: var(--lp-text); }

/* ===== Audience ===== */
.lp-audience-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: .9rem; margin-top: 1.8rem; }
.lp-audience-card {
    background: var(--lp-card); border: 1px solid var(--lp-border); border-radius: .8rem;
    padding: 1.2rem; transition: border-color .2s, transform .2s;
}
.lp-audience-card:hover { border-color: var(--lp-primary); transform: translateY(-2px); }
.lp-audience-card i { font-size: 1.8rem; color: var(--lp-primary); display: block; margin-bottom: .6rem; }
.lp-audience-title { font-weight: 700; margin-bottom: .3rem; }
.lp-audience-desc { color: var(--lp-muted); font-size: .88rem; line-height: 1.4; }

/* ===== Steps ===== */
.lp-steps-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; margin-top: 1.8rem; }
.lp-step {
    background: var(--lp-card); border: 1px solid var(--lp-border); border-radius: .8rem;
    padding: 1.3rem 1.2rem; position: relative;
}
.lp-step-num {
    width: 34px; height: 34px; border-radius: 50%;
    background: linear-gradient(135deg, #7dd3fc, #a78bfa); color: #0b1020;
    display: flex; align-items: center; justify-content: center; font-weight: 800;
    margin-bottom: .7rem;
}
.lp-step-title { font-weight: 700; margin-bottom: .3rem; }
.lp-step-desc { color: var(--lp-muted); font-size: .9rem; line-height: 1.45; }
.lp-steps-cta { text-align: center; margin-top: 2rem; }

/* ===== Features ===== */
.lp-features-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1rem; margin-top: 1.8rem; }
.lp-feature {
    background: var(--lp-card); border: 1px solid var(--lp-border); border-radius: .8rem;
    padding: 1.3rem; transition: transform .2s, border-color .2s;
}
.lp-feature:hover { transform: translateY(-3px); border-color: var(--lp-primary); }
.lp-feature-ico {
    width: 44px; height: 44px; border-radius: .5rem;
    background: rgba(125,211,252,.12); color: var(--lp-primary);
    display: flex; align-items: center; justify-content: center; font-size: 1.4rem;
    margin-bottom: .7rem;
}
.lp-feature-title { font-weight: 700; margin-bottom: .3rem; }
.lp-feature-desc { color: var(--lp-muted); font-size: .9rem; line-height: 1.5; }

/* ===== Samples ===== */
.lp-samples-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1rem; margin-top: 1.8rem; }
.lp-sample {
    background: var(--lp-card); border: 1px solid var(--lp-border); border-radius: .8rem;
    padding: 1.2rem;
}
.lp-sample-label { font-size: .78rem; color: var(--lp-primary); text-transform: uppercase; letter-spacing: .06em; margin-bottom: .5rem; font-weight: 600; }
.lp-sample-title { font-weight: 700; margin-bottom: .35rem; }
.lp-sample-text { color: var(--lp-muted); font-size: .9rem; line-height: 1.5; }

/* ===== Pricing ===== */
.lp-pricing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; margin-top: 1.8rem; }
.lp-pricing-card {
    background: var(--lp-card); border: 1px solid var(--lp-border); border-radius: .9rem;
    padding: 1.6rem 1.4rem; position: relative; text-align: center;
}
.lp-pricing-popular { border-color: var(--lp-primary); box-shadow: 0 0 0 1px var(--lp-primary); }
.lp-pricing-badge {
    position: absolute; top: -10px; left: 50%; transform: translateX(-50%);
    background: linear-gradient(135deg, #7dd3fc, #a78bfa); color: #0b1020;
    padding: .25rem .8rem; border-radius: 1rem; font-size: .72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .04em;
}
.lp-pricing-title { font-weight: 700; margin-bottom: .4rem; color: var(--lp-muted); }
.lp-pricing-price { font-size: 2rem; font-weight: 800; background: linear-gradient(135deg, #7dd3fc, #a78bfa); -webkit-background-clip: text; background-clip: text; color: transparent; }
.lp-pricing-unit { font-size: .8rem; color: var(--lp-muted); margin-bottom: .7rem; }
.lp-pricing-desc { color: var(--lp-muted); font-size: .85rem; line-height: 1.5; }
.lp-pricing-note { text-align: center; margin-top: 1.6rem; color: var(--lp-accent); font-weight: 500; }

/* ===== FAQ ===== */
.lp-faq-list { max-width: 780px; margin: 2rem auto 0; display: grid; gap: .5rem; }
.lp-faq-item {
    background: var(--lp-card); border: 1px solid var(--lp-border); border-radius: .7rem;
    padding: 1rem 1.2rem;
}
.lp-faq-item summary {
    cursor: pointer; font-weight: 600; list-style: none; position: relative; padding-right: 2rem;
}
.lp-faq-item summary::-webkit-details-marker { display: none; }
.lp-faq-item summary::after {
    content: '+'; position: absolute; right: 0; top: 0; font-size: 1.4rem; color: var(--lp-primary);
    transition: transform .2s;
}
.lp-faq-item[open] summary::after { content: '−'; }
.lp-faq-a { color: var(--lp-muted); margin-top: .7rem; line-height: 1.55; }

/* ===== Final CTA ===== */
.lp-final-cta { background: linear-gradient(180deg, var(--lp-bg) 0%, #12193a 100%); }
.lp-final-box {
    background: linear-gradient(135deg, rgba(125,211,252,.08), rgba(167,139,250,.08));
    border: 1px solid var(--lp-border); border-radius: 1.2rem;
    padding: 3rem 2rem; text-align: center;
}
.lp-final-box p { color: var(--lp-muted); margin: 0 auto 1.4rem; max-width: 560px; font-size: 1.05rem; }

/* ===== Footer ===== */
.lp-footer { padding: 1.8rem 0; border-top: 1px solid var(--lp-border); color: var(--lp-muted); font-size: .88rem; text-align: center; }
.lp-footer a { color: var(--lp-muted); text-decoration: none; margin: 0 .3rem; }
.lp-footer a:hover { color: var(--lp-primary); }

/* ===== Home landing (main) ===== */
.lp-modules-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1rem; margin-top: 1.8rem; }
.lp-module-card {
    background: var(--lp-card); border: 1px solid var(--lp-border); border-radius: 1rem;
    padding: 1.5rem; text-decoration: none; color: var(--lp-text);
    transition: transform .25s, border-color .25s, box-shadow .25s;
    display: block; position: relative;
}
.lp-module-card:hover { transform: translateY(-4px); border-color: var(--lp-primary); box-shadow: 0 16px 40px rgba(125,211,252,.15); color: var(--lp-text); }
.lp-module-icon {
    width: 52px; height: 52px; border-radius: .7rem;
    background: linear-gradient(135deg, rgba(125,211,252,.18), rgba(167,139,250,.18));
    color: var(--lp-primary); font-size: 1.6rem;
    display: flex; align-items: center; justify-content: center; margin-bottom: .8rem;
}
.lp-module-title { font-weight: 700; font-size: 1.1rem; margin-bottom: .35rem; }
.lp-module-desc { color: var(--lp-muted); font-size: .9rem; line-height: 1.45; margin-bottom: .6rem; }
.lp-module-link { color: var(--lp-primary); font-weight: 600; font-size: .88rem; }
.lp-module-link i { transition: transform .2s; }
.lp-module-card:hover .lp-module-link i { transform: translateX(3px); }

/* Кейсы/аудитория на главной */
.lp-use-cases { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 1rem; margin-top: 1.8rem; }
.lp-use-case {
    background: var(--lp-card); border: 1px solid var(--lp-border); border-radius: .9rem;
    padding: 1.3rem;
}
.lp-use-case-title { font-weight: 700; margin-bottom: .4rem; display: flex; align-items: center; gap: .5rem; }
.lp-use-case-title i { color: var(--lp-primary); }
.lp-use-case ul { padding-left: 1.1rem; margin: 0; color: var(--lp-muted); font-size: .9rem; line-height: 1.55; }

/* Соц. доказательство */
.lp-social {
    display: flex; flex-wrap: wrap; gap: 2rem; justify-content: center; align-items: center;
    padding: 1.5rem 0; border-top: 1px solid var(--lp-border); border-bottom: 1px solid var(--lp-border);
    margin-top: 2rem;
}
.lp-social-item { color: var(--lp-muted); font-size: .88rem; display: flex; align-items: center; gap: .4rem; }
.lp-social-item strong { color: var(--lp-text); font-size: 1.1rem; }

@media (max-width: 600px) {
    .lp-section { padding: 2.5rem 0; }
    .lp-hero { padding: 2rem 0 2.5rem; }
}

/* === /lp/videos/ — рамка-окно с авто-листанием 3 мокапов 1:1 === */
.lp-vd-frame { padding: 1rem; }
.lp-vd-viewport { overflow: hidden; border-radius: .75rem; }
.lp-vd-viewport .lp-demo-track { display: flex; transition: transform .65s cubic-bezier(.22, .61, .36, 1); will-change: transform; }
.lp-vd-slide {
    flex: 0 0 100%;
    aspect-ratio: 1 / 1;
    position: relative;
    overflow: hidden;
    border-radius: .55rem;
    opacity: .35;
    transition: opacity .55s ease;
}
.lp-vd-slide.is-active { opacity: 1; }
.lp-vd-mock {
    position: absolute; inset: 0;
    overflow: hidden;
    border-radius: .55rem;
}
.lp-vd-tag {
    position: absolute; top: .7rem; right: .7rem; z-index: 5;
    background: rgba(15, 23, 42, .65);
    color: #e2e8f0;
    border: 1px solid rgba(255, 255, 255, .12);
    backdrop-filter: blur(6px);
    padding: .25rem .55rem;
    border-radius: 999px;
    font-size: .72rem;
    letter-spacing: .02em;
    display: inline-flex; align-items: center; gap: .35rem;
}
.lp-vd-tag i { font-size: .8rem; color: #a78bfa; }

/* ── Mock 1: карточка товара (флакон, имитация поворота 360°) ── */
.lp-vd-bg-product {
    position: absolute; inset: 0;
    background: radial-gradient(circle at 50% 60%, #f5f3ff 0%, #ddd6fe 65%, #c4b5fd 100%);
}
.lp-vd-shadow {
    position: absolute; left: 50%; bottom: 18%;
    width: 38%; height: 4%;
    background: radial-gradient(ellipse, rgba(0,0,0,.3) 0%, rgba(0,0,0,0) 70%);
    transform: translateX(-50%);
    filter: blur(2px);
    animation: vdShadowPulse 4s ease-in-out infinite alternate;
}
@keyframes vdShadowPulse {
    from { opacity: .55; transform: translateX(-50%) scaleX(.95); }
    to   { opacity: .8;  transform: translateX(-50%) scaleX(1.08); }
}
.lp-vd-bottle {
    position: absolute; left: 50%; top: 22%;
    width: 26%; height: 58%;
    transform: translateX(-50%);
    transform-origin: 50% 50%;
    animation: vdBottleSpin 4s ease-in-out infinite alternate;
}
@keyframes vdBottleSpin {
    from { transform: translateX(-50%) perspective(400px) rotateY(-22deg); }
    to   { transform: translateX(-50%) perspective(400px) rotateY( 22deg); }
}
.lp-vd-bottle-cap {
    position: absolute; left: 25%; top: 0;
    width: 50%; height: 14%;
    background: linear-gradient(180deg, #1e1b4b, #4c1d95);
    border-radius: 6px 6px 2px 2px;
    box-shadow: inset 0 -2px 0 rgba(0,0,0,.3);
}
.lp-vd-bottle-body {
    position: absolute; left: 0; top: 14%;
    width: 100%; height: 86%;
    background: linear-gradient(180deg, #7c3aed 0%, #5b21b6 60%, #4c1d95 100%);
    border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    box-shadow: inset -8px 0 16px rgba(0,0,0,.25), inset 8px 0 16px rgba(255,255,255,.08);
}
.lp-vd-bottle-body span {
    color: #fff;
    font-size: .82rem;
    font-weight: 800;
    letter-spacing: .15em;
    text-shadow: 0 1px 2px rgba(0,0,0,.3);
}
.lp-vd-bottle-shine {
    position: absolute; left: 8%; top: 18%;
    width: 14%; height: 70%;
    background: linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,0));
    border-radius: 50%;
    filter: blur(2px);
}

/* ── Mock 2: тур по интерьеру (плавный pan) ── */
.lp-vd-bg-room {
    position: absolute; inset: 0;
    background:
        linear-gradient(180deg, #fef3c7 0%, #fde68a 100%);
}
.lp-vd-room-pan {
    position: absolute; inset: 0;
    animation: vdRoomPan 8s ease-in-out infinite alternate;
}
@keyframes vdRoomPan {
    from { transform: translateX(-6%); }
    to   { transform: translateX( 6%); }
}
.lp-vd-room-window {
    position: absolute; left: 18%; top: 14%;
    width: 36%; height: 38%;
    background: linear-gradient(180deg, #bae6fd 0%, #e0f2fe 100%);
    border: 4px solid #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.08), inset 0 0 0 1px #fbbf24;
    border-radius: 4px;
}
.lp-vd-room-window::before, .lp-vd-room-window::after {
    content: ""; position: absolute; background: #fff;
}
.lp-vd-room-window::before { left: 50%; top: 0; bottom: 0; width: 4px; transform: translateX(-50%); }
.lp-vd-room-window::after  { left: 0; right: 0; top: 50%; height: 4px; transform: translateY(-50%); }
.lp-vd-room-sofa {
    position: absolute; left: 14%; bottom: 14%;
    width: 56%; height: 22%;
    background: linear-gradient(180deg, #c4b5fd, #8b5cf6);
    border-radius: 14px 14px 6px 6px;
    box-shadow: 0 8px 14px rgba(76, 29, 149, .25);
}
.lp-vd-room-sofa::before {
    content: ""; position: absolute; left: 6%; top: 12%;
    width: 25%; height: 50%;
    background: rgba(255,255,255,.18);
    border-radius: 8px;
}
.lp-vd-room-sofa::after {
    content: ""; position: absolute; right: 6%; top: 12%;
    width: 25%; height: 50%;
    background: rgba(255,255,255,.18);
    border-radius: 8px;
}
.lp-vd-room-lamp {
    position: absolute; right: 12%; top: 10%;
    width: 8%; height: 38%;
    background: linear-gradient(180deg, #fbbf24 0%, #fbbf24 18%, #1e293b 18%, #1e293b 100%);
    border-radius: 50% 50% 4px 4px / 30% 30% 4px 4px;
}
.lp-vd-room-plant {
    position: absolute; right: 16%; bottom: 14%;
    width: 12%; height: 22%;
    background:
        radial-gradient(circle at 50% 30%, #16a34a 0%, #15803d 60%, transparent 65%),
        linear-gradient(180deg, transparent 60%, #78350f 60%, #78350f 100%);
    border-radius: 50% 50% 6px 6px / 60% 60% 6px 6px;
}

/* ── Mock 3: бьюти-ролик (shimmer) ── */
.lp-vd-bg-beauty {
    position: absolute; inset: 0;
    background: radial-gradient(circle at 50% 30%, #fce7f3 0%, #f9a8d4 60%, #db2777 100%);
}
.lp-vd-portrait {
    position: absolute; left: 50%; top: 18%;
    width: 50%; height: 70%;
    transform: translateX(-50%);
}
.lp-vd-portrait-hair {
    position: absolute; left: -8%; top: 0;
    width: 116%; height: 60%;
    background: radial-gradient(ellipse at 50% 50%, #1e1b4b 0%, #312e81 60%, transparent 70%);
    animation: vdHairWave 5s ease-in-out infinite alternate;
}
@keyframes vdHairWave {
    from { transform: translateX(-2%) skewX(-3deg); }
    to   { transform: translateX( 2%) skewX( 3deg); }
}
.lp-vd-portrait-face {
    position: absolute; left: 18%; top: 22%;
    width: 64%; aspect-ratio: 3 / 4;
    background: linear-gradient(180deg, #fce7f3 0%, #fbcfe8 100%);
    border-radius: 50% 50% 45% 45% / 60% 60% 40% 40%;
    box-shadow: inset -8px -12px 22px rgba(190, 24, 93, .18);
}
.lp-vd-portrait-face::before {
    content: ""; position: absolute; left: 22%; top: 35%;
    width: 12%; height: 6%; background: #1e1b4b; border-radius: 50%;
}
.lp-vd-portrait-face::after {
    content: ""; position: absolute; right: 22%; top: 35%;
    width: 12%; height: 6%; background: #1e1b4b; border-radius: 50%;
}
.lp-vd-shimmer {
    position: absolute; inset: 0;
    background: linear-gradient(115deg,
        rgba(255,255,255,0) 30%,
        rgba(255,255,255,.5) 50%,
        rgba(255,255,255,0) 70%);
    animation: vdShimmer 2.6s linear infinite;
    mix-blend-mode: screen;
    pointer-events: none;
}
@keyframes vdShimmer {
    from { transform: translateX(-120%); }
    to   { transform: translateX( 120%); }
}

@media (prefers-reduced-motion: reduce) {
    .lp-vd-bottle, .lp-vd-room-pan, .lp-vd-portrait-hair, .lp-vd-shimmer, .lp-vd-shadow {
        animation: none !important;
    }
}

/* === Лого Асора — ограничение размера === */
.lp-brand-logo {
    height: 32px;
    width: auto;
    display: block;
    max-width: 180px;
}
@media (max-width: 640px) {
    .lp-brand-logo { height: 28px; }
}
/* ========== Cookie banner ========== */
.cc-banner {
    position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 10000;
    max-width: 860px; margin: 0 auto;
    background: #111827; color: #e5e7eb;
    border: 1px solid rgba(167,139,250,.4); border-radius: 12px;
    padding: 14px 18px; display: flex; gap: 14px; align-items: center;
    box-shadow: 0 20px 40px rgba(0,0,0,.35);
    font-family: 'Onest', system-ui, sans-serif; font-size: .9rem; line-height: 1.5;
    transition: opacity .25s ease;
}
.cc-banner .cc-text { flex: 1; }
.cc-banner a { color: #c4b5fd; text-decoration: none; border-bottom: 1px solid rgba(196,181,253,.4); }
.cc-banner a:hover { color: #ddd6fe; }
.cc-actions { flex: 0 0 auto; }
.cc-btn { padding: .5rem 1.1rem; border: 0; border-radius: 8px; cursor: pointer; font-weight: 600; font-size: .9rem; font-family: inherit; }
.cc-btn-primary { background: linear-gradient(135deg, #a78bfa, #7dd3fc); color: #111827; }
.cc-btn-primary:hover { filter: brightness(1.1); }
@media (max-width: 640px) {
    .cc-banner { flex-direction: column; align-items: stretch; left: 8px; right: 8px; bottom: 8px; padding: 12px 14px; }
    .cc-actions { display: flex; justify-content: flex-end; }
}

/* ========== Legal footer (full) — landing + lp + legal pages ========== */
.lp-footer-legal { background: #0f172a; color: #cbd5e1; padding: 2.5rem 0 1.5rem; font-size: .9rem; margin-top: 3rem; }
.lp-footer-legal .lp-container { max-width: 1100px; margin: 0 auto; padding: 0 1.25rem; }
.lp-footer-grid { display: grid; grid-template-columns: 1.3fr 1fr 1fr; gap: 2rem; padding-bottom: 1.5rem; border-bottom: 1px solid rgba(148,163,184,.2); }
.lp-footer-legal .lp-footer-brand { font-size: 1.25rem; font-weight: 700; color: #fff; }
.lp-footer-legal .lp-footer-tagline { color: #94a3b8; font-size: .85rem; margin-top: .25rem; }
.lp-footer-legal .lp-footer-h { color: #fff; font-weight: 600; margin-bottom: .75rem; font-size: .9rem; }
.lp-footer-legal a { color: #cbd5e1; text-decoration: none; display: block; padding: .2rem 0; }
.lp-footer-legal a:hover { color: #fff; }
.lp-footer-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 1rem; color: #94a3b8; font-size: .82rem; flex-wrap: wrap; gap: .5rem; }
.lp-footer-req { color: #94a3b8; font-size: .82rem; }
@media (max-width: 980px) {
    .lp-footer-grid { grid-template-columns: 1fr 1fr; gap: 1.5rem; }
}
@media (max-width: 600px) {
    .lp-footer-grid { grid-template-columns: 1fr; gap: 1.25rem; }
    .lp-footer-bottom { flex-direction: column; align-items: flex-start; }
}

/* Кейсы/аудитория — фиксированно 3 в ряд на десктопе */
.lp-use-cases.lp-use-cases-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 900px) {
    .lp-use-cases.lp-use-cases-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
    .lp-use-cases.lp-use-cases-3 { grid-template-columns: 1fr; }
}
