/* ===================== RESET & TOKENS ===================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;touch-action:manipulation}
:root{
  --green:#1ba83a;
  --green-dark:#13852d;
  --green-deep:#0d5e20;
  --green-soft:#eaf6ec;
  --green-mint:#f1f9f2;
  --ink:#13181a;
  --ink-soft:#2b3338;
  --muted:#6b7670;
  --line:#e4e9e4;
  --bg:#ffffff;
  --bg-soft:#f5f8f5;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 18px 50px -22px rgba(13,40,18,.28);
  --shadow-lg:0 40px 90px -34px rgba(13,40,18,.4);
  --font-display:'Wix Madefor Display',sans-serif;
  --font-body:'Manrope',sans-serif;
  --maxw:1200px;
}
html{scroll-behavior:smooth;scroll-padding-top:78px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.hp-field{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.lead-error{margin-top:12px;color:#d33b2f;font-size:14px;font-weight:600;line-height:1.4}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.accent{color:var(--green)}

/* ===================== BUTTONS ===================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-weight:700;letter-spacing:-.01em;
  border-radius:999px;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease;
  white-space:nowrap;
}
.btn--sm{padding:11px 20px;font-size:14px}
.btn--lg{padding:17px 34px;font-size:16px}
.btn--block{width:100%}
.btn--primary{
  background:var(--green);color:#fff;
  box-shadow:0 12px 26px -10px rgba(27,168,58,.7);
}
.btn--primary:hover{background:var(--green-dark);transform:translateY(-2px);box-shadow:0 18px 32px -12px rgba(27,168,58,.8)}
.btn--primary:active{transform:translateY(0)}
.btn--ghost{
  background:transparent;color:var(--ink);
  box-shadow:inset 0 0 0 2px var(--line);
}
.btn--ghost:hover{box-shadow:inset 0 0 0 2px var(--ink);transform:translateY(-2px)}
.linkbtn{
  color:var(--green);font-weight:700;text-decoration:underline;text-underline-offset:3px;
  font-size:inherit;
}
.linkbtn:hover{color:var(--green-dark)}

/* ===================== HEADER ===================== */
.header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .25s ease,box-shadow .25s ease;
}
.header.is-scrolled{border-color:var(--line);box-shadow:0 8px 30px -22px rgba(13,40,18,.5)}
.header__inner{display:flex;align-items:center;gap:28px;height:78px}
.logo{display:flex;align-items:center;gap:11px;flex-shrink:0}
/* content-box: padding добавляется СНАРУЖИ иконки (тёмная подложка-кружок),
   а не съедает её размер; итоговый кружок = height + padding*2 */
.logo__img{height:32px;width:auto;display:block;background:#13181a;padding:6px;border-radius:50%;box-sizing:content-box}
.logo--footer .logo__img{height:30px;box-shadow:0 0 0 1px rgba(255,255,255,.12)}
.logo__text{font-family:var(--font-display);font-weight:800;font-size:22px;letter-spacing:-.03em}
.logo__green{color:var(--green)}
.logo__dark{color:var(--ink)}
.logo__dark--light{color:#fff}
.nav{display:flex;gap:24px;margin-left:4px}
.nav__link{
  font-weight:600;font-size:15px;color:var(--ink-soft);white-space:nowrap;
  position:relative;padding:6px 0;transition:color .18s ease;
}
.nav__link::after{
  content:"";position:absolute;left:0;bottom:0;width:0;height:2px;
  background:var(--green);transition:width .22s ease;border-radius:2px;
}
.nav__link:hover{color:var(--ink)}
.nav__link:hover::after{width:100%}
.header__actions{display:flex;align-items:center;gap:14px;margin-left:auto}
.header__phone{
  display:flex;align-items:center;gap:8px;white-space:nowrap;
  font-family:var(--font-body);font-weight:800;font-size:15px;letter-spacing:-.01em;
  color:var(--ink);transition:color .18s ease;
}
.header__phone svg{color:var(--green)}
.header__phone:hover{color:var(--green)}
.burger{display:none;flex-direction:column;gap:5px;width:42px;height:42px;border-radius:11px;background:var(--green-soft);align-items:center;justify-content:center}
.burger span{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===================== HERO ===================== */
.hero{position:relative;padding:74px 0 90px;overflow:hidden}
.hero__bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(900px 520px at 88% -8%,rgba(27,168,58,.16),transparent 60%),
    radial-gradient(700px 600px at -6% 110%,rgba(27,168,58,.1),transparent 62%),
    var(--bg-soft);
}
.hero__bg::before{
  content:"";position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(0deg,transparent 0 38px,rgba(19,24,26,.035) 38px 39px),
    repeating-linear-gradient(90deg,transparent 0 38px,rgba(19,24,26,.035) 38px 39px);
  mask-image:radial-gradient(circle at 70% 30%,#000,transparent 75%);
}
.hero__inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center;
}
.badge{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1px solid var(--line);
  padding:8px 16px;border-radius:999px;
  font-weight:700;font-size:13px;color:var(--green-dark);
  text-transform:uppercase;letter-spacing:.04em;
}
.badge::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(27,168,58,.2)}
.hero__title{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(2.3rem,4.6vw,4rem);line-height:1.04;letter-spacing:-.035em;
  margin:22px 0 18px;
}
.hero__text{font-size:clamp(1rem,1.3vw,1.18rem);color:var(--muted);max-width:540px;margin-bottom:30px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:38px}
.hero__perks{display:flex;gap:14px;flex-wrap:wrap}
.hero__perks li{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:14px 20px;display:flex;flex-direction:column;
}
.hero__perks b{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--green)}
.hero__perks span{font-size:13px;color:var(--muted);font-weight:600}

.hero__card{
  background:#fff;border-radius:24px;box-shadow:var(--shadow-lg);
  border:1px solid var(--line);overflow:hidden;
  position:relative;
}
.hero__card-top{padding:24px 24px 8px}
.hero__card-tag{
  display:inline-block;background:var(--ink);color:#fff;
  font-size:12px;font-weight:700;padding:5px 12px;border-radius:999px;
  text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px;
}
.hero__card-top h3{font-family:var(--font-display);font-weight:700;font-size:21px;letter-spacing:-.02em}
.hero__card-sub{font-size:14px;color:var(--muted);margin-top:4px}
.hero__card img{
  width:78%;margin:6px auto -8px;
  filter:drop-shadow(0 26px 30px rgba(13,40,18,.22));
}
.hero__card-bottom{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:18px 24px;background:var(--green-mint);border-top:1px solid var(--line);
}
.hero__card-price{display:flex;flex-direction:column;line-height:1.1}
.hero__card-price span{font-size:12px;color:var(--muted);font-weight:600}
.hero__card-price b{font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--ink)}

/* ===================== SECTION HEAD ===================== */
.section-head{max-width:680px;margin:0 auto 50px;text-align:center}
.section-head__kicker{
  display:inline-block;font-weight:800;font-size:13px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--green);margin-bottom:14px;
}
.section-head__kicker--light{color:#7be08f}
.section-head__title{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.8rem,3.2vw,2.7rem);letter-spacing:-.03em;line-height:1.1;
}
.section-head__text{color:var(--muted);margin-top:14px;font-size:1.05rem}

/* ===================== ADVANTAGES ===================== */
.adv{padding:54px 0}
.adv__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.adv__item{
  background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px 24px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.adv__item:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent;background:#fff}
.adv__ico{
  display:inline-grid;place-items:center;width:46px;height:46px;border-radius:12px;
  background:var(--green);color:#fff;font-family:var(--font-display);font-weight:700;font-size:15px;
  margin-bottom:16px;
}
.adv__item h3{font-family:var(--font-display);font-weight:600;font-size:17px;letter-spacing:-.02em;margin-bottom:8px}
.adv__item p{font-size:14.5px;color:var(--muted)}

/* ===================== PRODUCTS ===================== */
.products{padding:70px 0;background:var(--bg-soft);position:relative}
.products__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .22s ease,box-shadow .22s ease;
}
.card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg)}
.card__media{
  position:relative;padding:22px;
  background:radial-gradient(circle at 50% 35%,#fff,var(--green-mint));
  display:flex;align-items:center;justify-content:center;min-height:220px;
}
.card__media img{
  width:auto;max-height:200px;
  filter:drop-shadow(0 20px 24px rgba(13,40,18,.2));
  transition:transform .3s ease;
}
.card:hover .card__media img{transform:scale(1.05)}
.card__body{padding:22px;display:flex;flex-direction:column;flex:1}
.card__tag{
  align-self:flex-start;
  font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;
  padding:5px 11px;border-radius:999px;margin-bottom:12px;
  background:var(--bg-soft);color:var(--ink-soft);border:1px solid var(--line);
}
.card__tag--green{background:var(--green-soft);color:var(--green-dark);border-color:transparent}
.card__tag--dark{background:var(--ink);color:#fff;border-color:transparent}
.card__title{font-family:var(--font-display);font-weight:700;font-size:19px;letter-spacing:-.02em;margin-bottom:8px}
.card__desc{font-size:14px;color:var(--muted);margin-bottom:14px}
.card__specs{display:flex;flex-direction:column;gap:7px;margin-bottom:18px}
.card__specs li{
  font-size:13.5px;font-weight:600;color:var(--ink-soft);
  padding-left:22px;position:relative;
}
.card__specs li::before{
  content:"";position:absolute;left:0;top:4px;width:14px;height:14px;border-radius:50%;
  background:var(--green-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 6.2l2.3 2.3 4.7-5' stroke='%231ba83a' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/10px no-repeat;
}
.card__foot{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-top:auto;padding-top:16px;border-top:1px dashed var(--line);
}
.card__price{display:flex;flex-direction:column;line-height:1.1}
.card__price span{font-size:11px;color:var(--muted);font-weight:600}
.card__price b{font-family:var(--font-display);font-weight:700;font-size:19px}
.products__note{text-align:center;margin-top:36px;color:var(--muted);font-size:1.02rem}

/* ===================== QUIZ ===================== */
.quiz{padding:78px 0;background:
  radial-gradient(700px 420px at 12% 0%,rgba(27,168,58,.16),transparent 60%),
  var(--ink);
}
.quiz__box{
  display:grid;grid-template-columns:.85fr 1.15fr;
  background:#fff;border-radius:26px;overflow:hidden;box-shadow:var(--shadow-lg);
}
.quiz__aside{
  background:linear-gradient(170deg,var(--green-deep),var(--green-dark));
  color:#fff;padding:44px 38px;position:relative;overflow:hidden;
}
.quiz__aside::after{
  content:"";position:absolute;right:-60px;bottom:-80px;width:240px;height:240px;
  border-radius:50%;background:rgba(255,255,255,.07);
}
.quiz__title{font-family:var(--font-display);font-weight:700;font-size:1.85rem;line-height:1.15;letter-spacing:-.03em;margin:14px 0 16px}
.quiz__title .accent{color:#7be08f}
.quiz__lead{color:rgba(255,255,255,.78);font-size:15px;margin-bottom:26px}
.quiz__benefits{display:flex;flex-direction:column;gap:12px;position:relative;z-index:1}
.quiz__benefits li{
  font-weight:600;font-size:14.5px;padding-left:30px;position:relative;
}
.quiz__benefits li::before{
  content:"✓";position:absolute;left:0;top:-1px;
  width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.16);
  display:grid;place-items:center;font-size:11px;color:#7be08f;font-weight:800;
}
.quiz__panel{padding:40px 40px 34px;position:relative}
.quiz__progress{height:6px;background:var(--bg-soft);border-radius:999px;overflow:hidden}
.quiz__progress-bar{height:100%;width:20%;background:var(--green);border-radius:999px;transition:width .35s cubic-bezier(.4,0,.2,1)}
.quiz__step-count{font-size:13px;font-weight:700;color:var(--muted);margin:14px 0 18px;letter-spacing:.02em}
.quiz__step{display:none;animation:fadeUp .35s ease both}
.quiz__step.is-active{display:block}
.quiz__q{font-family:var(--font-display);font-weight:600;font-size:1.35rem;letter-spacing:-.02em;margin-bottom:18px}
.quiz__hint{font-size:14px;color:var(--muted);margin:-8px 0 18px}
.quiz__opts{display:flex;flex-direction:column;gap:10px}
.quiz__opt{
  text-align:left;padding:16px 20px;border-radius:14px;
  background:var(--bg-soft);border:2px solid transparent;
  font-weight:600;font-size:15px;color:var(--ink);
  transition:.16s ease;display:flex;align-items:center;gap:12px;
}
.quiz__opt::before{
  content:"";width:20px;height:20px;border-radius:50%;flex-shrink:0;
  border:2px solid #c9d2cb;transition:.16s ease;
}
.quiz__opt:hover{border-color:var(--green);background:#fff}
.quiz__opt.is-picked{border-color:var(--green);background:var(--green-soft)}
.quiz__opt.is-picked::before{border-color:var(--green);background:var(--green) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 6.2l2.3 2.3 4.7-5' stroke='%23fff' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/11px no-repeat}
.quiz__nav{margin-top:18px}
.quiz__back{font-weight:700;font-size:14px;color:var(--muted);transition:color .16s ease}
.quiz__back:hover:not(:disabled){color:var(--ink)}
.quiz__back:disabled{opacity:.35;cursor:default}
.quiz__done{
  display:none;position:absolute;inset:0;background:#fff;
  flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;
}
.quiz__done.is-show{display:flex;animation:fadeUp .4s ease both}
.quiz__done-ico{
  width:68px;height:68px;border-radius:50%;background:var(--green-soft);
  display:grid;place-items:center;font-size:32px;color:var(--green);margin-bottom:18px;
}
.quiz__done h3{font-family:var(--font-display);font-weight:700;font-size:1.5rem;margin-bottom:10px}
.quiz__done p{color:var(--muted);max-width:340px}

/* ===================== FIELDS ===================== */
.field{margin-bottom:14px;position:relative}
.field input{
  width:100%;padding:15px 18px;border-radius:13px;
  border:2px solid var(--line);background:var(--bg-soft);
  font-family:var(--font-body);font-size:15px;font-weight:600;color:var(--ink);
  transition:border-color .16s ease,background .16s ease;
}
.field input::placeholder{color:#a3aea5;font-weight:500}
.field input:focus{outline:none;border-color:var(--green);background:#fff}
.field.is-invalid input{border-color:#e0413a;background:#fdeceb}
.field__error{display:none;color:#e0413a;font-size:12.5px;font-weight:600;margin-top:5px}
.field.is-invalid .field__error{display:block}
.check{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--muted);margin-bottom:16px;cursor:pointer;line-height:1.45;user-select:none}
.check input{position:absolute;opacity:0;width:0;height:0}
.check__box{flex-shrink:0;width:20px;height:20px;margin-top:1px;border:2px solid var(--line);border-radius:6px;background:#fff;display:grid;place-items:center;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease}
.check__box::after{content:"";width:9px;height:5px;margin-top:-2px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg) scale(0);transition:transform .18s ease}
.check input:checked + .check__box{background:var(--green);border-color:var(--green)}
.check input:checked + .check__box::after{transform:rotate(-45deg) scale(1)}
.check input:focus-visible + .check__box{box-shadow:0 0 0 3px rgba(27,168,58,.25)}
.check.is-invalid .check__box{border-color:#e0413a;box-shadow:0 0 0 3px rgba(224,65,58,.15)}
.check a{color:var(--green);text-decoration:underline;text-underline-offset:2px}
.check a:hover{color:var(--green-dark)}

/* ===================== MONTAGE ===================== */
.montage{padding:78px 0;background:var(--bg)}
.montage__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.montage__title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.8rem,3vw,2.5rem);letter-spacing:-.03em;margin:12px 0 14px}
.montage__text{color:var(--muted);font-size:1.05rem;margin-bottom:22px;max-width:500px}
.montage__list{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:30px}
.montage__list li{
  padding-left:30px;position:relative;font-weight:600;font-size:14.5px;color:var(--ink-soft);
}
.montage__list li::before{
  content:"";position:absolute;left:0;top:1px;width:20px;height:20px;border-radius:6px;
  background:var(--green-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'%3E%3Cpath d='M3 7.4l2.6 2.6L11 4' stroke='%231ba83a' stroke-width='2.2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/12px no-repeat;
}
.montage__cta{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.montage__price{display:flex;flex-direction:column;line-height:1.15}
.montage__price span{font-size:13px;color:var(--muted);font-weight:600}
.montage__price b{font-family:var(--font-display);font-weight:700;font-size:1.7rem;color:var(--green)}
.montage__free{display:flex;flex-direction:column;gap:16px}
.montage__free-card{
  background:var(--ink);color:#fff;border-radius:var(--radius);padding:26px 28px;
  position:relative;overflow:hidden;
}
.montage__free-card::after{
  content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;
  background:rgba(27,168,58,.22);
}
.montage__free-zero{
  font-family:var(--font-display);font-weight:800;font-size:2.4rem;color:var(--green);
  display:block;line-height:1;margin-bottom:8px;
}
.montage__free-card h3{font-family:var(--font-display);font-weight:600;font-size:18px;margin-bottom:6px}
.montage__free-card p{font-size:14px;color:rgba(255,255,255,.7);position:relative;z-index:1}

/* ===================== STEPS ===================== */
.steps{padding:70px 0;background:var(--bg-soft)}
.steps__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.step{position:relative;padding:30px 24px;background:#fff;border-radius:var(--radius);border:1px solid var(--line)}
.step__num{
  display:grid;place-items:center;width:52px;height:52px;border-radius:14px;
  background:var(--green-soft);color:var(--green-dark);
  font-family:var(--font-display);font-weight:800;font-size:22px;margin-bottom:16px;
}
.step h3{font-family:var(--font-display);font-weight:600;font-size:17px;letter-spacing:-.02em;margin-bottom:8px}
.step p{font-size:14px;color:var(--muted)}

/* ===================== CTA ===================== */
.cta{padding:78px 0}
.cta__inner{
  display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center;
  background:
    radial-gradient(540px 360px at 88% 110%,rgba(27,168,58,.18),transparent 60%),
    var(--ink);
  border-radius:28px;padding:54px 52px;
}
.cta__title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.7rem,2.7vw,2.4rem);color:#fff;letter-spacing:-.03em;line-height:1.13}
.cta__title .accent{color:#7be08f}
.cta__text{color:rgba(255,255,255,.72);margin:16px 0 24px;font-size:1.05rem}
.cta__contacts{display:flex;flex-direction:column;gap:4px}
.cta__phone{font-family:var(--font-display);font-weight:700;font-size:1.8rem;color:#fff;letter-spacing:-.02em}
.cta__phone:hover{color:#7be08f}
.cta__hours{color:rgba(255,255,255,.6);font-size:14px;font-weight:600}
.cta__form{background:#fff;border-radius:20px;padding:30px;position:relative}
.cta__form h3{font-family:var(--font-display);font-weight:700;font-size:1.25rem;margin-bottom:18px}
.cta__form-done{
  display:none;position:absolute;inset:0;background:#fff;border-radius:20px;
  flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:6px;padding:30px;
}
.cta__form-done.is-show{display:flex;animation:fadeUp .35s ease both}
.cta__form-done b{font-family:var(--font-display);font-size:1.3rem;color:var(--green)}
.cta__form-done span{color:var(--muted)}

/* ===================== FOOTER ===================== */
.footer{background:var(--ink);color:#fff;padding:54px 0 26px}
.footer__inner{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer__about{color:rgba(255,255,255,.6);font-size:14px;margin-top:14px;max-width:300px}
.footer__col h4{font-family:var(--font-display);font-weight:600;font-size:15px;margin-bottom:16px}
.footer__col{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.footer__col a,.footer__col span{color:rgba(255,255,255,.62);font-size:14px;font-weight:600;transition:color .16s ease}
.footer__col a:hover{color:#7be08f}
.footer__col a.footer__phone{font-family:var(--font-display);font-size:1.15rem;color:#fff}
.footer__col .btn{margin-top:6px}
.footer__bottom{
  display:flex;justify-content:space-between;gap:16px;padding-top:24px;
  color:rgba(255,255,255,.42);font-size:13px;font-weight:600;flex-wrap:wrap;
}
.footer__bottom a{color:rgba(255,255,255,.55);text-decoration:underline;text-underline-offset:2px;transition:color .16s ease}
.footer__bottom a:hover{color:#7be08f}

/* ===================== LEGAL / ERROR PAGES ===================== */
.page{padding:120px 0 80px;min-height:calc(100vh - 78px)}
.page--center{display:flex;align-items:center;justify-content:center;text-align:center}
.legal{max-width:820px;margin:0 auto}
.legal__kicker{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--green);margin-bottom:14px}
.legal h1{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,4vw,2.8rem);line-height:1.1;letter-spacing:-.03em;margin-bottom:10px}
.legal__updated{color:var(--muted);font-size:14px;margin-bottom:36px}
.legal h2{font-family:var(--font-display);font-weight:700;font-size:1.3rem;margin:32px 0 12px;letter-spacing:-.02em}
.legal p,.legal li{color:var(--ink-soft);font-size:15px;line-height:1.7}
.legal p{margin-bottom:14px}
.legal ul{margin:0 0 14px;padding-left:22px}
.legal li{margin-bottom:6px}
.legal a{color:var(--green);text-decoration:underline;text-underline-offset:2px}
.legal a:hover{color:var(--green-dark)}
.error-page{max-width:560px}
.error-page__code{font-family:var(--font-display);font-weight:800;font-size:clamp(5rem,18vw,9rem);line-height:1;color:var(--green);letter-spacing:-.04em}
.error-page h1{font-family:var(--font-display);font-weight:800;font-size:clamp(1.5rem,4vw,2.1rem);margin:8px 0 14px;letter-spacing:-.02em}
.error-page p{color:var(--muted);font-size:16px;margin-bottom:28px;line-height:1.6}
.error-page__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ===================== MODAL ===================== */
.modal{
  position:fixed;inset:0;z-index:100;display:none;
  align-items:center;justify-content:center;padding:20px;
}
.modal.is-open{display:flex}
.modal__overlay{position:absolute;inset:0;background:rgba(13,24,15,.62);backdrop-filter:blur(4px);animation:fade .25s ease both}
.modal__dialog{
  position:relative;background:#fff;border-radius:22px;
  width:100%;max-width:430px;padding:38px 34px;
  box-shadow:var(--shadow-lg);animation:popIn .3s cubic-bezier(.34,1.3,.5,1) both;
}
.modal__close{
  position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;
  background:var(--bg-soft);color:var(--ink-soft);font-size:15px;transition:.16s ease;
}
.modal__close:hover{background:var(--green-soft);color:var(--green-dark);transform:rotate(90deg)}
.modal__kicker{
  display:inline-block;font-weight:800;font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--green);margin-bottom:10px;
}
.modal__title{font-family:var(--font-display);font-weight:700;font-size:1.45rem;letter-spacing:-.02em;margin-bottom:10px}
.modal__text{color:var(--muted);font-size:14.5px;margin-bottom:22px}
.modal__done{display:none;text-align:center;flex-direction:column;align-items:center}
.modal__done.is-show{display:flex;animation:fadeUp .35s ease both}
.modal__done-ico{
  width:70px;height:70px;border-radius:50%;background:var(--green-soft);
  display:grid;place-items:center;font-size:34px;color:var(--green);margin-bottom:16px;
}
.modal__done h3{font-family:var(--font-display);font-weight:700;font-size:1.4rem;margin-bottom:8px}
.modal__done p{color:var(--muted);margin-bottom:22px}

/* ===================== FAB ===================== */
.fab{
  position:fixed;right:22px;bottom:22px;z-index:55;
  width:58px;height:58px;border-radius:50%;
  background:var(--green);color:#fff;display:none;
  align-items:center;justify-content:center;
  box-shadow:0 14px 30px -8px rgba(27,168,58,.8);
  animation:pulse 2.4s ease-in-out infinite;
}
.fab:hover{background:var(--green-dark)}

/* ===================== ANIMATIONS ===================== */
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes popIn{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes pulse{0%,100%{box-shadow:0 14px 30px -8px rgba(27,168,58,.8),0 0 0 0 rgba(27,168,58,.5)}50%{box-shadow:0 14px 30px -8px rgba(27,168,58,.8),0 0 0 14px rgba(27,168,58,0)}}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-in{opacity:1;transform:translateY(0)}
.reveal[data-d="1"]{transition-delay:.1s}
.reveal[data-d="2"]{transition-delay:.2s}
.reveal[data-d="3"]{transition-delay:.3s}
.reveal[data-d="4"]{transition-delay:.4s}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation-duration:.01ms!important}
}

/* ===================== RESPONSIVE ===================== */
@media(max-width:1080px){
  .hero__inner{grid-template-columns:1fr;gap:40px}
  .hero__card{max-width:420px}
  .adv__grid,.products__grid,.steps__grid{grid-template-columns:repeat(2,1fr)}
  .quiz__box{grid-template-columns:1fr}
  .montage__inner,.cta__inner{grid-template-columns:1fr;gap:34px}
  .cta__inner{padding:40px 32px}
}
@media(max-width:760px){
  .nav{
    position:fixed;top:78px;left:0;right:0;
    flex-direction:column;gap:0;background:#fff;
    padding:8px 24px 20px;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .3s ease;box-shadow:var(--shadow);
  }
  .nav.is-open{transform:translateY(0)}
  .nav__link{padding:14px 0;border-bottom:1px solid var(--line);font-size:16px}
  .header__phone span{display:none}
  .header__actions .btn--primary{display:none}
  .burger{display:flex}
  .fab{display:flex}
  .footer__inner{grid-template-columns:1fr;gap:30px}
  .montage__list{grid-template-columns:1fr}
  .quiz__aside,.quiz__panel{padding:32px 26px}
  .modal__dialog{padding:34px 24px}
  .footer__bottom{justify-content:flex-start}
}
@media(max-width:480px){
  .container{padding:0 20px}
  .adv__grid,.products__grid,.steps__grid{grid-template-columns:1fr}
  .hero__perks{width:100%}
  .hero__perks li{flex:1}
  .btn--lg{padding:15px 24px}
  .cta__inner{padding:32px 22px}
  .montage__cta{flex-direction:column;align-items:stretch}
}
