/* ===================== АВАНГАРД · дизайн-система B (планка Landshaften) ===================== */
:root{
  --bg:#FFFFFF; --paper:#F4F1EA; --paper-2:#EFEBE1;
  --ink:#16201B; --text:#3C4842; --muted:#6A756F;
  --green:#225C43; --green-h:#1a4936; --green-d:#16201B; --green-2:#1E2C26;
  --green-soft:rgba(34,92,67,.10);
  --clay:#C26A3A; --clay-soft:rgba(194,106,58,.12);
  --line:#E4E0D6; --line-dark:rgba(244,241,234,.14);
  --sans:'Manrope',sans-serif; --body:'Inter',sans-serif; --mono:'JetBrains Mono',monospace;
  --maxw:1280px; --r-lg:6px; --r:5px; --r-sm:4px;
  --shadow:0 18px 50px -24px rgba(20,40,30,.30);
}
*{margin:0;padding:0;box-sizing:border-box}
[hidden]{display:none!important}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--text);background:var(--paper);-webkit-font-smoothing:antialiased;overflow-x:hidden;font-weight:500}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.mono{font-family:var(--mono)}

/* Кикеры / лейблы */
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:12px}
.kicker::before{content:'';width:10px;height:10px;background:var(--clay);flex:none}

/* Кнопки */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);font-weight:700;font-size:14.5px;padding:12px 22px;border-radius:var(--r-sm);border:1.5px solid transparent;cursor:pointer;transition:.18s;white-space:nowrap}
.btn--green{background:var(--green);color:#fff}
.btn--green:hover{background:var(--green-h);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--green)}
.btn--lg{padding:16px 28px;font-size:15.5px}
.btn--block{width:100%}

/* ===== ШАПКА ===== */
.nav{position:sticky;top:0;z-index:40;background:rgba(244,241,234,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav__in{max-width:var(--maxw);margin:0 auto;padding:15px 40px;display:flex;align-items:center;gap:30px}
.brand{display:flex;flex-direction:column;line-height:1}
.brand b{font-family:var(--sans);font-weight:800;font-size:21px;letter-spacing:.04em;color:var(--ink)}
.brand small{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:5px}
.nav__links{display:flex;gap:24px;margin-left:18px}
.nav__links a{font-size:14.5px;font-weight:500;color:var(--text);opacity:.82}
.nav__links a:hover{opacity:1;color:var(--ink)}
.nav__right{margin-left:auto;display:flex;align-items:center;gap:16px}
.nav__phone{display:flex;flex-direction:column;line-height:1.15}
.nav__phone b{font-family:var(--mono);font-size:14px;color:var(--ink);font-weight:600}
.nav__phone small{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--muted);margin-top:2px}
.nav__phone:hover b{color:var(--green)}
.nav__msg{color:var(--green);display:flex}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;margin-left:auto}
.burger span{width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:.3s}
.burger.active span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.nav__mobile{display:none;flex-direction:column;background:var(--paper);border-bottom:1px solid var(--line)}
.nav__mobile a{padding:14px 40px;border-top:1px solid var(--line);font-weight:600;color:var(--ink)}
.nav__mobile.open{display:flex}
.nav__mobile-phone{font-family:var(--mono)}

/* ===== HERO ===== */
.hero{padding:60px 0 36px}
.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center}
.hero h1{font-family:var(--sans);font-weight:800;font-size:clamp(38px,5.2vw,70px);line-height:.98;letter-spacing:-.02em;color:var(--ink);margin:24px 0 0}
.hero h1 .g{color:var(--green)}
.hero__lead{font-size:19px;line-height:1.5;color:var(--text);max-width:46ch;margin:24px 0 32px}
.hero__ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:30px}
.hero__badges{display:flex;gap:22px;flex-wrap:wrap}
.hero__badge{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--text)}
.hero__badge b{color:var(--ink);font-weight:700}
.hero__media{position:relative;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;background:var(--green-d)}
.hero__media>img{width:100%;height:100%;object-fit:cover}
.hero__tag{position:absolute;top:18px;left:18px;right:18px;display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--clay);text-shadow:0 1px 4px rgba(0,0,0,.5)}

/* Квиз */
.quiz{position:absolute;left:16px;right:16px;bottom:16px;background:rgba(255,255,255,.97);backdrop-filter:blur(6px);border-radius:5px;padding:18px 18px 16px}
.quiz__k{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--clay);margin-bottom:10px}
.quiz__bar{height:4px;background:var(--line);border-radius:2px;overflow:hidden;margin-bottom:14px}
.quiz__bar i{display:block;height:100%;width:20%;background:var(--green);transition:width .3s}
.quiz__q{font-family:var(--sans);font-weight:800;font-size:18px;color:var(--ink);margin-bottom:13px;letter-spacing:-.01em}
.quiz__opts{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.quiz__opt{border:1.5px solid var(--line);border-radius:9px;padding:11px 12px;font-size:13.5px;font-weight:600;color:var(--ink);text-align:center;cursor:pointer;transition:.15s;background:#fff}
.quiz__opt:hover{border-color:var(--green);background:var(--paper)}
.quiz__opt.sel{border-color:var(--green);background:var(--green-soft)}
.quiz__next{background:var(--green);color:#fff;border-color:var(--green);font-weight:700}
.quiz__next:hover{background:var(--green-h);border-color:var(--green-h)}
.quiz__next:disabled{opacity:.45;cursor:not-allowed}
.quiz__next:disabled:hover{background:var(--green);border-color:var(--green)}
.quiz__note{font-size:12.5px;line-height:1.45;color:var(--muted);background:var(--green-soft);border-radius:9px;padding:10px 12px;margin-bottom:12px}
.quiz__field{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:9px;font-family:inherit;font-size:14px;margin-bottom:8px}
.quiz__field:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-soft)}
.quiz__submit{width:100%;margin-top:4px}
.quiz__foot{display:flex;justify-content:space-between;align-items:center;margin-top:13px}
.quiz__back{background:none;border:none;font-family:var(--mono);font-size:12px;color:var(--muted);cursor:pointer;letter-spacing:.05em}
.quiz__back:hover{color:var(--ink)}
.quiz__hint{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.06em}
.quiz__status{font-size:13px;text-align:center;padding:10px;border-radius:9px;margin-top:8px}
.quiz__status--ok{background:var(--green-soft);color:var(--green)}
.quiz__status--err{background:var(--clay-soft);color:var(--clay)}

/* ===== СТАТ-БЛОК ===== */
.stats{border-top:1px solid var(--line);margin-top:46px;padding-top:28px;display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding-right:24px;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat .n{font-family:var(--sans);font-weight:800;font-size:clamp(32px,3.4vw,46px);line-height:1;letter-spacing:-.03em;color:var(--ink);font-variant-numeric:tabular-nums}
.stat .n .u{font-size:17px;color:var(--green);font-weight:600;margin-left:3px}
.stat .t{font-family:var(--mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin-top:10px}

/* ===== СЕКЦИИ ===== */
.sec{padding:92px 0}
.sec--dark{background:var(--green-d);color:#fff}
.s-head{display:grid;grid-template-columns:200px 1fr;gap:40px;align-items:baseline;margin-bottom:48px}
.s-head .num{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:10px}
.s-head .num::before{content:'';width:10px;height:10px;background:var(--clay)}
.sec--dark .s-head .num{color:rgba(255,255,255,.6)}
.s-head h2{font-family:var(--sans);font-weight:800;font-size:clamp(28px,3.6vw,46px);letter-spacing:-.02em;line-height:1.04;color:var(--ink)}
.sec--dark .s-head h2{color:#fff}
.s-head .sub{font-size:17px;color:var(--muted);margin-top:14px;max-width:48ch;line-height:1.5}
.sec--dark .s-head .sub{color:rgba(255,255,255,.7)}

/* Оффер */
.offer__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ocard{background:var(--green-d);border:1px solid transparent;border-radius:var(--r);padding:28px;transition:.2s}
.ocard:hover{transform:translateY(-3px);box-shadow:var(--shadow);background:var(--green-2)}
.ocard__k{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--clay);margin-bottom:14px}
.ocard h3{font-family:var(--sans);font-weight:800;font-size:22px;color:#fff;margin-bottom:10px;letter-spacing:-.01em}
.ocard p{font-size:15px;color:rgba(255,255,255,.78);line-height:1.55}

/* Цены */
.price-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.pc{border-radius:5px;padding:26px;background:var(--bg);border:1px solid var(--line);display:flex;flex-direction:column;justify-content:space-between;min-height:168px;transition:.2s}
.pc:hover{border-color:var(--green);transform:translateY(-3px);box-shadow:var(--shadow)}
.pc .pk{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.pc h4{font-family:var(--sans);font-weight:700;font-size:19px;color:var(--ink);margin:10px 0 0;letter-spacing:-.01em;line-height:1.15}
.pc .p{font-family:var(--sans);font-weight:800;font-size:31px;color:var(--green);letter-spacing:-.02em;margin-top:14px}
.pc .p span{font-size:14px;color:var(--muted);font-weight:500}
.pc.a{grid-column:span 5}.pc.b{grid-column:span 4}.pc.c{grid-column:span 3}
.pc.gift{grid-column:span 12;background:var(--green-d);color:#fff;border:0;flex-direction:row;align-items:center;justify-content:space-between;min-height:auto;padding:24px 28px;gap:20px}
.pc.gift:hover{transform:none;box-shadow:none}
.pc.gift .gk{display:flex;gap:28px;flex-wrap:wrap}
.pc.gift .gi{display:flex;align-items:center;gap:10px;font-size:15px}
.pc.gift .gi b{color:#fff;font-weight:700}
.pc.gift .dot{width:8px;height:8px;border-radius:50%;background:var(--clay);flex:none}

/* Цены v2 (под ключ + раскрытие) */
.price2{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:14px}
.pc2{background:var(--bg);border:1px solid var(--line);border-radius:5px;padding:26px;transition:.2s}
.pc2:hover{border-color:var(--green);box-shadow:var(--shadow)}
.pc2__k{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.pc2__p{font-family:var(--sans);font-weight:800;font-size:34px;color:var(--green);letter-spacing:-.02em;margin:12px 0 16px}
.pc2__p span{font-size:15px;color:var(--muted);font-weight:500;margin-left:2px}
.pc2__d{border-top:1px solid var(--line);padding-top:12px}
.pc2__d summary{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--green);cursor:pointer;list-style:none;display:flex;align-items:center}
.pc2__d summary::-webkit-details-marker{display:none}
.pc2__d summary::after{content:'+';margin-left:auto;font-size:15px;font-weight:700}
.pc2__d[open] summary::after{content:'–'}
.pc2:hover .pc2__d summary::after,.pc2__d summary:hover::after{color:var(--clay)}
.pc2__d ul{list-style:none;margin-top:12px}
.pc2__d li{display:flex;justify-content:space-between;gap:12px;font-size:14px;color:var(--muted);padding:5px 0}
.pc2__d li b{color:var(--ink);font-weight:700;white-space:nowrap}
.price-add{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.pa{display:flex;justify-content:space-between;align-items:center;gap:14px;background:var(--bg-alt);border:1px solid var(--line);border-radius:5px;padding:18px 22px}
.pa span{font-family:var(--sans);font-weight:700;font-size:16px;color:var(--ink)}
.pa small{font-weight:400;color:var(--muted);font-size:13px}
.pa b{font-family:var(--sans);font-weight:800;font-size:20px;color:var(--green);white-space:nowrap}
@media(max-width:760px){.price2{grid-template-columns:1fr}.price-add{grid-template-columns:1fr}}

/* Галерея */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:14px}
.g-item{position:relative;border-radius:var(--r);overflow:hidden;cursor:pointer;background:var(--paper-2)}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.g-item::after{content:'';position:absolute;inset:0;background:rgba(22,32,27,0);transition:.3s}
.g-item:hover img{transform:scale(1.06)}
.g-item:hover::after{background:rgba(22,32,27,.16)}
.g-lg{grid-column:span 2;grid-row:span 2}

/* Кейсы */
.cases__grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.case{display:grid;grid-template-columns:1fr 1fr;background:var(--bg);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.case__img{overflow:hidden}
.case__img img{width:100%;height:100%;object-fit:cover;min-height:220px}
.case__body{padding:26px;display:flex;flex-direction:column;justify-content:center}
.case__nums{display:flex;gap:26px;margin-bottom:14px}
.case__nums b{font-family:var(--sans);font-weight:800;font-size:26px;color:var(--ink);display:block;letter-spacing:-.02em}
.case__nums span{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.case__body p{font-size:15px;color:var(--muted);line-height:1.5}

/* Кейс до/после */
.case-ba{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;display:grid;grid-template-columns:1fr 1fr 1.25fr;margin-bottom:20px}
.ba{position:relative;margin:0;aspect-ratio:3/4;overflow:hidden;background:var(--paper-2)}
.ba img{width:100%;height:100%;object-fit:cover}
.ba__tag{position:absolute;top:12px;left:12px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;background:rgba(22,32,27,.82);color:#fff;padding:5px 11px;border-radius:7px}
.ba--after .ba__tag{background:var(--green)}
.case-ba__body{padding:32px;display:flex;flex-direction:column;justify-content:center}
.case-ba__body h3{font-family:var(--sans);font-weight:800;font-size:25px;color:var(--ink);margin:12px 0 18px;letter-spacing:-.02em;line-height:1.1}
.case-ba__nums{display:flex;gap:26px;flex-wrap:wrap;margin-bottom:18px}
.case-ba__nums b{font-family:var(--sans);font-weight:800;font-size:22px;color:var(--ink);display:block;letter-spacing:-.02em;line-height:1.1}
.case-ba__nums span{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.case-ba__body>p{font-size:15px;color:var(--muted);line-height:1.55;margin-bottom:22px}
.ba__tag--g{background:var(--green)!important}
.case-ba__actions{display:flex;gap:12px;flex-wrap:wrap}
.case-more{margin-bottom:20px;animation:fade .3s}
.case-more__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.case-more__grid .g-item{position:relative;aspect-ratio:4/3;border-radius:var(--r);overflow:hidden;cursor:pointer;background:var(--paper-2);display:block}
.case-more__grid .g-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.case-more__grid .g-item:hover img{transform:scale(1.05)}

/* Почему мы */
.why__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.wcard{background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:28px}
.wcard__q{font-family:var(--sans);font-weight:700;font-size:18px;color:var(--ink);margin-bottom:12px;line-height:1.25}
.wcard p{font-size:15px;color:var(--muted);line-height:1.55}
.wcard--accent{background:var(--green-d);color:#fff;border:0}
.wcard--accent .wcard__q{color:#fff}
.wcard--accent p{color:rgba(255,255,255,.78)}

/* Заводы */
.factories__in{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);padding:44px}
.factories__text .num{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:10px;margin-bottom:18px}
.factories__text .num::before{content:'';width:10px;height:10px;background:var(--clay)}
.factories__text h2{font-family:var(--sans);font-weight:800;font-size:clamp(24px,3vw,34px);color:var(--ink);letter-spacing:-.02em;margin-bottom:14px;line-height:1.1}
.factories__text p{font-size:16px;color:var(--muted);line-height:1.55}
.factories__logos{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.flogo{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:22px;text-align:center;font-family:var(--sans);font-weight:700;font-size:17px;color:var(--ink);letter-spacing:.01em}

/* Карусель материалов */
.materials{padding-bottom:96px}
.mats__plants{margin-top:14px;font-size:15px;color:var(--muted)}
.mats__plants b{color:var(--ink);font-weight:700}
/* Бегущая лента */
.flow{overflow:hidden;padding:8px 0;margin-top:38px;-webkit-mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.flow__track{display:flex;gap:16px;width:max-content;animation:scroll-x 60s linear infinite}
.flow:hover .flow__track{animation-play-state:paused}
@keyframes scroll-x{to{transform:translateX(calc(-50% - 8px))}}
/* Строгая плашка-надпись материала */
.mchip{flex:none;display:inline-flex;align-items:center;padding:16px 26px;background:transparent;border:1px solid transparent;border-radius:4px;font-family:var(--sans);white-space:nowrap;cursor:default;transition:background-color .3s,border-color .3s,box-shadow .3s}
.mchip::before{content:'';width:8px;height:8px;background:var(--clay);flex:none}
.mchip__name{margin-left:13px;font-weight:700;font-size:19px;color:var(--ink);letter-spacing:-.01em}
.mchip__desc{max-width:0;opacity:0;overflow:hidden;font-family:var(--body);font-weight:500;font-size:14px;line-height:1.4;color:var(--muted);white-space:nowrap;transition:max-width .45s cubic-bezier(.4,.1,.2,1),opacity .35s ease,margin-left .45s ease}
.mchip:hover{background:var(--bg);border-color:var(--green);box-shadow:var(--shadow)}
.mchip:hover .mchip__desc{max-width:640px;opacity:1;margin-left:15px;padding-left:15px;border-left:1px solid var(--line)}
@media (prefers-reduced-motion:reduce){.flow__track{animation:none}.mchip__desc{transition:opacity .3s ease}}

/* Процесс */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.step{background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:24px;transition:.2s}
.step:hover{border-color:var(--green);transform:translateY(-3px);box-shadow:var(--shadow)}
.step__n{font-family:var(--mono);font-size:13px;color:var(--clay);letter-spacing:.1em;margin-bottom:14px}
.step h4{font-family:var(--sans);font-weight:700;font-size:18px;color:var(--ink);margin-bottom:8px;letter-spacing:-.01em}
.step p{font-size:13.5px;color:var(--muted);line-height:1.5}
.step--cta{display:block;background:var(--green);border-color:var(--green);cursor:pointer;text-decoration:none;will-change:transform;transition:transform .15s ease-out,background .2s}
.step--cta .step__n{color:rgba(255,255,255,.55)}
.step--cta h4{color:#fff}
.step--cta p{color:rgba(255,255,255,.85)}
.step--cta:hover{background:var(--green-h);border-color:var(--green-h);box-shadow:0 16px 36px -14px var(--green)}

/* Гарантия */
.guarantee__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gcard{background:var(--green-2);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:30px}
.gcard b{font-family:var(--sans);font-weight:800;font-size:22px;color:#fff;display:block;margin-bottom:10px;letter-spacing:-.01em}
.gcard p{font-size:15px;color:rgba(255,255,255,.72);line-height:1.55}

/* Руководитель */
.owner{background:var(--bg-alt)}
.owner__in{display:grid;grid-template-columns:380px 1fr;gap:56px;align-items:center}
.owner__photo{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);background:var(--green-d)}
.owner__photo img{width:100%;display:block}
.owner__text h2{font-family:var(--sans);font-weight:800;font-size:clamp(26px,3.4vw,40px);color:var(--ink);letter-spacing:-.02em;line-height:1.06;margin:14px 0 16px}
.owner__text p{font-size:17px;line-height:1.6;color:var(--text);max-width:50ch;margin-bottom:22px}
.owner__sign{margin-bottom:24px;padding-left:16px;border-left:3px solid var(--clay)}
.owner__sign b{display:block;font-family:var(--sans);font-weight:800;font-size:18px;color:var(--ink)}
.owner__sign span{font-family:var(--mono);font-size:12px;letter-spacing:.05em;color:var(--muted)}

/* Отзывы */
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:start}
.rev{border-radius:var(--r);overflow:hidden;background:var(--bg);border:1px solid var(--line);position:relative;display:block}
.rev img{width:100%;height:auto;display:block}
.rev__cap{display:block;padding:14px 18px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--clay)}
.rev--text{padding:30px;display:flex;flex-direction:column;gap:16px}
.rev__badge{display:inline-block;align-self:flex-start;background:var(--clay-soft);color:var(--clay);font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:7px 12px;border-radius:999px}
.rev__quote{font-size:17px;line-height:1.5;color:var(--ink);font-weight:500}
.rev__who{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--muted)}
.rev__link{font-family:var(--sans);font-weight:700;font-size:14px;color:var(--green);margin-top:auto}

/* Комплекс */
.complex__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.xc{background:var(--green-2);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:26px;font-family:var(--sans);font-weight:700;font-size:19px;color:#fff;letter-spacing:-.01em;transition:.2s;display:flex;align-items:center;min-height:96px}
.xc::before{content:'→';color:var(--clay);margin-right:12px;font-weight:800}
.xc:hover{background:var(--green);transform:translateY(-3px)}

/* FAQ */
.faq__list{max-width:880px}
.qa{border-bottom:1px solid var(--line)}
.qa__q{width:100%;background:none;border:none;text-align:left;padding:24px 40px 24px 0;font-family:var(--sans);font-weight:700;font-size:19px;color:var(--ink);cursor:pointer;position:relative;letter-spacing:-.01em}
.qa__q i{position:absolute;right:6px;top:50%;width:14px;height:14px;margin-top:-7px}
.qa__q i::before,.qa__q i::after{content:'';position:absolute;background:var(--green);transition:.25s}
.qa__q i::before{left:0;top:6px;width:14px;height:2px}
.qa__q i::after{left:6px;top:0;width:2px;height:14px}
.qa.open .qa__q i::after{transform:rotate(90deg);opacity:0}
.qa__a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.qa__a p{padding:0 40px 24px 0;font-size:16px;color:var(--muted);line-height:1.6}

/* CTA */
.cta__card{background:var(--green-d);border-radius:var(--r-lg);padding:56px;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.cta__text .kicker{color:rgba(255,255,255,.6)}
.cta__text h2{font-family:var(--sans);font-weight:800;font-size:clamp(28px,3.4vw,42px);color:#fff;letter-spacing:-.02em;line-height:1.05;margin:18px 0 16px}
.cta__text>p{font-size:16px;color:rgba(255,255,255,.75);line-height:1.55;margin-bottom:22px;max-width:44ch}
.cta__benefits{list-style:none;margin-bottom:26px}
.cta__benefits li{position:relative;padding-left:26px;margin-bottom:11px;color:rgba(255,255,255,.9);font-size:15px}
.cta__benefits li::before{content:'';position:absolute;left:0;top:8px;width:8px;height:8px;border-radius:50%;background:var(--clay)}
.cta__direct{border-top:1px solid rgba(255,255,255,.14);padding-top:22px}
.cta__phone{font-family:var(--sans);font-weight:800;font-size:26px;color:#fff;letter-spacing:-.01em}
.cta__msgs{display:flex;gap:14px;margin-top:8px}
.cta__msgs a{font-family:var(--mono);font-size:13px;color:var(--clay)}
.cta__hours{display:block;font-family:var(--mono);font-size:12px;color:rgba(255,255,255,.5);margin-top:8px;letter-spacing:.06em}
.form{background:#fff;border-radius:var(--r);padding:30px}
.form label{display:block;font-family:var(--sans);font-weight:700;font-size:14px;color:var(--ink);margin-bottom:16px}
.form label small{font-weight:400;color:var(--muted)}
.form input,.form textarea{width:100%;margin-top:8px;padding:13px 15px;border:1.5px solid var(--line);border-radius:9px;font-family:inherit;font-size:15px;background:#fff;transition:.2s;resize:vertical}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-soft)}
.form input.invalid,.form textarea.invalid{border-color:var(--clay);box-shadow:0 0 0 3px var(--clay-soft)}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden;opacity:0}
.form__note{font-size:12px;color:var(--muted);text-align:center;margin-top:14px}
.consent{display:flex;align-items:flex-start;gap:8px;font-family:var(--body);font-size:12px;line-height:1.4;color:var(--muted);margin-top:14px;font-weight:400;cursor:pointer;text-align:left}
.consent input{margin-top:1px;width:15px;height:15px;accent-color:var(--green);flex:none;cursor:pointer}
.consent a{color:var(--green);text-decoration:underline}
.consent.invalid{color:var(--clay)}
.consent.invalid input{outline:2px solid var(--clay);outline-offset:1px}
.form__status{margin-top:14px;padding:13px;border-radius:9px;font-weight:600;font-size:15px;text-align:center}
.form__status--ok{background:var(--green-soft);color:var(--green)}
.form__status--err{background:var(--clay-soft);color:var(--clay)}

/* Подвал */
.footer{background:var(--green-d);color:rgba(255,255,255,.7);padding:60px 0 0}
.footer__in{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;padding-bottom:44px}
.footer__brand .brand{margin-bottom:16px}
.footer__brand .brand b{color:#fff}
.footer__brand .brand small{color:rgba(255,255,255,.5)}
.footer__brand p{font-size:14.5px;line-height:1.6;max-width:280px}
.footer__col h4{color:#fff;font-size:15px;margin-bottom:16px;font-weight:700;font-family:var(--sans)}
.footer__col a,.footer__col span{display:block;color:rgba(255,255,255,.65);font-size:14.5px;margin-bottom:9px}
.footer__col a:hover{color:var(--clay)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding:22px 0;font-size:13px;color:rgba(255,255,255,.5);font-family:var(--mono);letter-spacing:.04em}

/* Лайтбокс */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(12,16,12,.94);display:flex;align-items:center;justify-content:center;padding:40px;animation:fade .25s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.lightbox__img{max-width:92vw;max-height:88vh;border-radius:8px;object-fit:contain}
.lightbox__close{position:absolute;top:20px;right:26px;background:none;border:none;color:#fff;font-size:42px;cursor:pointer;line-height:1;opacity:.85}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:none;color:#fff;font-size:36px;width:54px;height:54px;border-radius:50%;cursor:pointer;display:grid;place-items:center}
.lightbox__nav:hover{background:rgba(255,255,255,.22)}
.lightbox__prev{left:24px}.lightbox__next{right:24px}

/* FAB */
.fab{position:fixed;bottom:20px;right:20px;z-index:35;background:var(--green);color:#fff;font-family:var(--sans);font-weight:700;font-size:14px;padding:14px 22px;border-radius:999px;box-shadow:0 14px 30px -10px var(--green);display:none}

/* CTA-врезки */
.cta-band{background:var(--bg-alt);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:36px 0}
.cta-band--dark{background:var(--green-d);border-color:transparent}
.cta-band__in{display:flex;align-items:center;justify-content:space-between;gap:28px}
.cta-band__t{font-family:var(--sans);font-weight:700;font-size:clamp(18px,2.3vw,24px);color:var(--ink);letter-spacing:-.01em;max-width:62ch;line-height:1.2}
.cta-band--dark .cta-band__t{color:#fff}
.cta-band .btn{flex:none}

/* Срочность */
.season{background:var(--clay-soft);padding:26px 0}
.season__in{display:flex;align-items:center;gap:20px}
.season__icon{font-size:32px;flex:none;line-height:1}
.season__text b{font-family:var(--sans);font-weight:800;font-size:19px;color:var(--ink);display:block;margin-bottom:4px;letter-spacing:-.01em}
.season__text p{font-size:15px;color:var(--text);max-width:64ch;line-height:1.5}
.season .btn{margin-left:auto;flex:none}

/* Обратный звонок */
.callback-btn{position:fixed;bottom:22px;left:22px;z-index:36;width:58px;height:58px;border-radius:50%;background:var(--clay);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px -8px var(--clay);animation:pulse-clay 2.6s infinite}
@keyframes pulse-clay{0%{box-shadow:0 0 0 0 rgba(194,106,58,.5)}70%{box-shadow:0 0 0 16px rgba(194,106,58,0)}100%{box-shadow:0 0 0 0 rgba(194,106,58,0)}}
.callback{position:fixed;inset:0;z-index:110;background:rgba(12,16,12,.6);display:flex;align-items:center;justify-content:center;padding:20px;animation:fade .2s}
.callback__box{background:#fff;border-radius:var(--r-lg);padding:34px;max-width:400px;width:100%;position:relative;box-shadow:var(--shadow)}
.callback__close{position:absolute;top:14px;right:18px;background:none;border:none;font-size:32px;color:var(--muted);cursor:pointer;line-height:1}
.callback__box h3{font-family:var(--sans);font-weight:800;font-size:24px;color:var(--ink);margin:10px 0 8px;letter-spacing:-.01em}
.callback__box>p{font-size:15px;color:var(--muted);margin-bottom:18px;line-height:1.5}
.callback__box input[type=tel]{width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:9px;font-family:inherit;font-size:15px;margin-bottom:10px}
.callback__box input[type=tel]:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-soft)}
.callback__status{margin-top:12px;padding:12px;border-radius:9px;font-weight:600;font-size:14px;text-align:center}
.callback__status--ok{background:var(--green-soft);color:var(--green)}
.callback__status--err{background:var(--clay-soft);color:var(--clay)}

/* Плашка мессенджеров */
.msgr{position:fixed;right:18px;top:36%;z-index:36;display:flex;flex-direction:column;gap:10px}
.msgr__btn{position:relative;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;box-shadow:0 8px 20px -8px rgba(0,0,0,.45);transition:transform .2s,box-shadow .2s}
.msgr__btn svg{width:24px;height:24px}
.msgr__btn .glyph{font-family:var(--sans);font-weight:800;font-size:16px;letter-spacing:.02em}
.msgr__btn .lbl{position:absolute;right:62px;white-space:nowrap;background:var(--ink);color:#fff;font-family:var(--sans);font-weight:600;font-size:13px;padding:7px 12px;border-radius:8px;opacity:0;transform:translateX(8px);pointer-events:none;transition:.2s}
.msgr__btn .lbl::after{content:'';position:absolute;right:-5px;top:50%;margin-top:-5px;border:5px solid transparent;border-left-color:var(--ink)}
.msgr__btn:hover{transform:scale(1.12);box-shadow:0 12px 26px -8px rgba(0,0,0,.5)}
.msgr__btn:hover .lbl{opacity:1;transform:translateX(0)}
.msgr--tg,.msgr--vk,.msgr--max{background:linear-gradient(150deg,#2c7152,var(--green) 48%,var(--green-d))}
.msgr__btn{box-shadow:0 10px 22px -10px rgba(20,40,30,.55),inset 0 1px 0 rgba(255,255,255,.16)}
.msgr__btn svg,.msgr__btn .glyph{transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.msgr__btn:hover svg{transform:translate(2px,-2px) rotate(10deg)}
.msgr__btn:hover{box-shadow:0 14px 28px -10px rgba(20,40,30,.6),inset 0 1px 0 rgba(255,255,255,.22)}
@media(max-width:640px){.msgr{right:12px;gap:8px}.msgr__btn{width:44px;height:44px}.msgr__btn svg{width:21px;height:21px}}

/* Появление */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}

/* ===== АДАПТИВ ===== */
@media(max-width:1080px){
  .wrap{padding:0 24px}
  .nav__in{padding:14px 24px}
  .nav__links,.nav__right .nav__phone,.nav__right .btn{display:none}
  .nav__right{display:none}
  .burger{display:flex}
  .hero__grid{grid-template-columns:1fr;gap:32px}
  .hero__media{aspect-ratio:3/4;max-height:560px}
  .s-head{grid-template-columns:1fr;gap:10px}
  .offer__grid,.why__grid,.guarantee__grid,.complex__grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:repeat(2,1fr)}
  .factories__in{grid-template-columns:1fr;gap:28px;padding:32px}
  .owner__in{grid-template-columns:1fr;gap:28px;max-width:560px;margin:0 auto;text-align:center}
  .owner__photo{max-width:340px;margin:0 auto}
  .owner__sign{display:inline-block;text-align:left}
  .owner__text .kicker{justify-content:center}
  .reviews__grid{grid-template-columns:1fr 1fr}
  .cta__card{grid-template-columns:1fr;gap:32px;padding:36px}
  .fab{display:inline-block}
}
@media(max-width:760px){
  .case-ba{grid-template-columns:1fr 1fr}
  .case-ba__body{grid-column:1/-1}
  .ba{aspect-ratio:4/5}
  .price-grid{grid-template-columns:1fr 1fr}
  .pc.a,.pc.b,.pc.c{grid-column:span 1}
  .pc.gift{grid-column:span 2;flex-direction:column;align-items:flex-start;gap:16px}
}
@media(max-width:640px){
  .wrap{padding:0 16px}
  .nav__in{padding:13px 16px}
  .sec{padding:56px 0}
  .hero{padding:36px 0 24px}
  .hero__ctas{flex-direction:column}.hero__ctas .btn{width:100%}
  .hero__badges{gap:14px 20px}
  .stats{grid-template-columns:1fr 1fr;gap:20px 0;border-top:0;margin-top:32px;padding-top:0}
  .stat{border-right:0;padding:16px 0;border-top:1px solid var(--line)}
  .offer__grid,.why__grid,.guarantee__grid,.complex__grid,.price-grid,.cases__grid,.reviews__grid{grid-template-columns:1fr}
  .pc.gift{grid-column:span 1}
  .gallery{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .steps{grid-template-columns:1fr}
  .case{grid-template-columns:1fr}
  .cta__card,.form{padding:24px}
  .qa__q{font-size:17px}
  .cta-band__in{flex-direction:column;align-items:flex-start;gap:16px}
  .cta-band .btn{width:100%}
  .season__in{flex-direction:column;align-items:flex-start;gap:14px}
  .season .btn{margin-left:0;width:100%}
  .callback__box{padding:26px}
  .case-more__grid{grid-template-columns:1fr 1fr}
}

/* Cookie-плашка */
.cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:60;max-width:680px;margin:0 auto;background:var(--ink);color:#fff;border-radius:5px;padding:15px 20px;display:flex;align-items:center;gap:16px;box-shadow:0 18px 50px -20px rgba(0,0,0,.5);font-family:var(--body)}
.cookie p{font-size:13.5px;line-height:1.45;margin:0;flex:1}
.cookie a{color:#fff;text-decoration:underline}
.cookie .btn{flex:none;padding:10px 22px;font-size:14px}
@media(max-width:560px){.cookie{flex-direction:column;align-items:stretch;text-align:center;gap:10px;left:10px;right:10px;bottom:10px}}

/* Фикс: плашки цен раскрываются по отдельности (не тянут соседей) */
.price2{align-items:start}
