/* ============================================================
   Андрей Ванишевский — стили секций 3–9
   (использует переменные и .wrap/.btn/.eyebrow/.reveal из index.html)
   ============================================================ */

.section-head{max-width:680px;margin:0 0 clamp(36px,5vw,56px);}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head h2{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:16px;}
.section-head h2 em{font-style:italic;font-weight:500;color:var(--terra);}
.section-head .lead{font-size:1.18rem;line-height:1.55;color:var(--ink-soft);}

.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid rgba(34,51,47,.32);box-shadow:none;}
.btn-ghost:hover{background:rgba(34,51,47,.06);border-color:var(--ink);transform:translateY(-2px);}

/* плавающая кнопка консультации */
.float-cta{position:fixed;right:clamp(16px,3vw,30px);bottom:clamp(16px,3vw,30px);z-index:55;
  opacity:0;transform:translateY(18px) scale(.96);pointer-events:none;transition:opacity .4s,transform .4s;}
.float-cta.show{opacity:1;transform:none;pointer-events:auto;}
@media (prefers-reduced-motion:no-preference){.float-cta.show .btn{animation:btnPulse 3s ease-in-out infinite;}}

/* ============================================================
   3. РЕЗУЛЬТАТЫ — тёмная секция
   ============================================================ */
.results{position:relative;background:#2e4640;color:var(--cream);padding:clamp(84px,12vh,150px) 0;overflow:hidden;}
.results::before{content:'';position:absolute;top:0;left:0;right:0;height:130px;
  background:linear-gradient(to bottom,var(--sky),transparent);opacity:.45;pointer-events:none;}
.results::after{content:'';position:absolute;bottom:0;left:0;right:0;height:130px;
  background:linear-gradient(to top,var(--sand),transparent);opacity:.35;pointer-events:none;}
.results .eyebrow{color:var(--terra-soft);}
.results .eyebrow::before{background:var(--terra-soft);}
.results h2{color:var(--cream);}
.results h2 em{color:var(--terra-soft);}
.results .section-head .lead{color:rgba(251,248,240,.82);}

.filter-row{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 36px;}
.chip{font-family:var(--body);font-weight:500;font-size:.96rem;padding:9px 19px;border-radius:100px;cursor:pointer;
  background:rgba(251,248,240,.1);color:var(--cream);border:1.5px solid rgba(251,248,240,.18);transition:.2s;}
.chip:hover{background:rgba(251,248,240,.2);}
.chip.active{background:var(--cream);color:#2e4640;border-color:var(--cream);}

.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.results-empty{display:none;margin:8px 0 0;font-family:var(--body);font-size:1.02rem;color:rgba(251,248,240,.78);}
.results-empty.show{display:block;}
.r-card{background:var(--cream);color:var(--ink);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 30px 60px -38px rgba(0,0,0,.6);transition:transform .35s,box-shadow .35s;}
.r-card:hover{transform:translateY(-6px);box-shadow:0 40px 70px -38px rgba(0,0,0,.65);}
.r-card.hide{display:none;}
.r-photos{display:grid;grid-template-columns:1fr 1fr;gap:3px;background:rgba(34,51,47,.1);}
.r-ph{position:relative;aspect-ratio:3/4;overflow:hidden;}
.r-ph img{width:100%;height:100%;object-fit:cover;object-position:center 18%;display:block;}
.r-ph .tag{position:absolute;left:10px;bottom:10px;font-family:var(--body);font-weight:600;font-size:.72rem;letter-spacing:.04em;
  padding:4px 10px;border-radius:100px;background:rgba(13,30,39,.7);color:var(--cream);backdrop-filter:blur(3px);}
.r-ph.after .tag{background:var(--terra);}
.r-body{padding:20px 22px 24px;flex:1;display:flex;flex-direction:column;}
.r-meta{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:8px;}
.r-name{font-family:var(--display);font-weight:600;font-size:1.32rem;line-height:1;}
.r-loss{font-family:var(--display);font-weight:600;font-size:1.45rem;color:var(--terra);white-space:nowrap;line-height:1;}
.r-quote{color:var(--ink-soft);font-size:1rem;line-height:1.5;margin:0;flex:1;}
.r-time{font-size:.85rem;color:var(--ink-soft);opacity:.8;margin-top:12px;padding-top:12px;border-top:1px solid rgba(34,51,47,.12);}

.counters{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:60px;padding-top:48px;border-top:1px solid rgba(251,248,240,.16);}
.counter{text-align:center;}
.counter .cnum{font-family:var(--display);font-weight:600;font-size:clamp(2.4rem,4.5vw,3.6rem);color:var(--terra-soft);line-height:1;}
.counter .clbl{font-size:.96rem;color:rgba(251,248,240,.82);margin-top:8px;}
.results-cta{text-align:center;margin-top:52px;}

/* ============================================================
   4. СИСТЕМА — песочная секция
   ============================================================ */
.system{background:transparent;padding:clamp(84px,12vh,150px) 0;}
.system .eyebrow{color:var(--sage);}
.philosophy{max-width:62ch;font-size:1.24rem;line-height:1.6;color:var(--ink);margin:14px 0 0;}
.philosophy .kw{color:var(--terra);font-style:italic;}
.levels{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:clamp(40px,5vw,56px);}
.level-card{background:var(--cream);border-radius:20px;padding:30px 26px 32px;box-shadow:0 24px 50px -38px rgba(34,51,47,.5);
  position:relative;}
.level-num{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;
  font-family:var(--display);font-weight:600;font-size:1.45rem;background:var(--terra);color:var(--cream);}
.lc-top{position:relative;height:138px;margin-bottom:14px;}
.lc-top .level-num{position:absolute;left:0;top:0;z-index:2;}
.level-img{position:absolute;right:-10px;bottom:-8px;height:150px;width:auto;max-width:82%;
  object-fit:contain;object-position:bottom right;pointer-events:none;
  transition:transform .35s ease;}
.level-card:hover .level-img{transform:translateY(-3px) scale(1.02);}
.level-card h3{font-size:1.34rem;margin-bottom:10px;}
.level-card p{color:var(--ink-soft);font-size:1.02rem;line-height:1.55;margin:0;}

/* Награды — спотлайт */
.awards{margin-top:30px;background:linear-gradient(120deg,rgba(234,169,131,.22),rgba(194,96,60,.12));
  border:1.5px solid var(--terra-soft);border-radius:26px;padding:clamp(30px,4vw,52px);
  display:grid;grid-template-columns:auto 1fr;gap:clamp(28px,4vw,52px);align-items:center;}
.awards-badge{width:120px;height:120px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  background:var(--terra);color:var(--cream);font-family:var(--display);font-size:3rem;box-shadow:0 20px 40px -16px rgba(194,96,60,.6);}
.awards h3{font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:12px;}
.awards h3 em{font-style:italic;font-weight:500;color:var(--terra);}
.awards p{color:var(--ink-soft);font-size:1.1rem;line-height:1.6;margin:0;}

/* ============================================================
   5. КАК РАБОТАЮ — таймлайн (светлая прохладная)
   ============================================================ */
.process{background:transparent;padding:clamp(84px,12vh,150px) 0;}
.process .eyebrow{color:var(--sage);}
.timeline{position:relative;max-width:820px;margin-top:clamp(32px,4vw,48px);}
.tl-line{position:absolute;left:31px;top:18px;bottom:18px;width:3px;background:rgba(34,51,47,.16);border-radius:3px;}
.tl-fill{position:absolute;left:0;top:0;width:100%;height:0;background:var(--terra);border-radius:3px;transition:height .25s linear;}
.tl-step{display:grid;grid-template-columns:64px 1fr;gap:24px;padding:18px 0;position:relative;}
.tl-dot{width:64px;height:64px;border-radius:50%;z-index:1;display:grid;place-items:center;
  font-family:var(--display);font-weight:600;font-size:1.55rem;background:var(--cream);color:var(--ink);
  border:3px solid #b9ccce;transition:background-color .4s,color .4s,border-color .4s;}
.tl-step.active .tl-dot{background:var(--terra);color:var(--cream);border-color:var(--terra);}
.tl-content{padding-top:6px;}
.tl-content h3{font-size:1.4rem;margin-bottom:8px;}
.tl-content p{color:var(--ink-soft);font-size:1.06rem;line-height:1.55;margin:0;max-width:54ch;}
.tl-content .micro{display:inline-block;margin-top:12px;font-size:.88rem;color:var(--terra);background:rgba(194,96,60,.1);padding:5px 14px;border-radius:100px;}

/* ============================================================
   6. ФОРМАТЫ — кремовая
   ============================================================ */
.formats{background:transparent;padding:clamp(84px,12vh,150px) 0;}
.formats .eyebrow{color:var(--sage);}
.formats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:clamp(32px,4vw,48px);}
.fmt-card{display:flex;flex-direction:column;margin:0;background:rgba(239,232,216,.42);
  border-radius:22px;padding:14px 14px 34px;transition:transform .35s,box-shadow .35s;}
.fmt-card:hover{transform:translateY(-5px);box-shadow:0 30px 60px -40px rgba(34,51,47,.45);}
.fmt-media{display:block;width:100%;aspect-ratio:5/4;margin:0;padding:0;border:none;
  border-radius:14px;overflow:hidden;background:var(--sand);position:relative;}
.fmt-media img{width:100%;height:100%;object-fit:cover;display:block;}
.fmt-card.zoomable .fmt-media{cursor:zoom-in;}
.fmt-card.zoomable .fmt-media img{transition:transform .6s cubic-bezier(.22,1,.36,1);}
.fmt-card.zoomable .fmt-media:hover img{transform:scale(1.045);}
.fmt-zoom-hint{position:absolute;right:12px;bottom:12px;width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;background:rgba(34,51,47,.55);backdrop-filter:blur(4px);
  color:var(--cream);opacity:0;transform:scale(.85);transition:opacity .3s,transform .3s;pointer-events:none;}
.fmt-card.zoomable .fmt-media:hover .fmt-zoom-hint{opacity:1;transform:scale(1);}
.fmt-zoom-hint svg{width:18px;height:18px;}
.fmt-body{padding:26px 18px 0;}
.fmt-num{font-family:var(--body);font-weight:600;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--terra);margin-bottom:14px;}
.fmt-card h3{font-size:1.5rem;margin-bottom:14px;}
.fmt-card p{color:var(--ink-soft);font-size:1.04rem;line-height:1.6;margin:0;}

/* Лайтбокс для фото форматов */
.lightbox{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  padding:clamp(20px,5vw,64px);background:rgba(20,30,27,.86);backdrop-filter:blur(6px);
  opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s;cursor:zoom-out;}
.lightbox.open{opacity:1;visibility:visible;}
.lightbox img{max-width:100%;max-height:100%;border-radius:16px;box-shadow:0 40px 90px -30px rgba(0,0,0,.7);
  transform:scale(.96);transition:transform .35s cubic-bezier(.22,1,.36,1);}
.lightbox.open img{transform:scale(1);}
.lightbox-close{position:absolute;top:max(20px,3vh);right:max(20px,3vw);width:48px;height:48px;border-radius:50%;
  border:none;background:rgba(251,248,240,.14);color:var(--cream);font-size:1.6rem;line-height:1;cursor:pointer;
  display:grid;place-items:center;transition:background .2s;}
.lightbox-close:hover{background:rgba(251,248,240,.28);}

/* ============================================================
   7. СТОИМОСТЬ — терракотовая рамка (песочная)
   ============================================================ */
.price{background:transparent;padding:clamp(84px,12vh,150px) 0;}
.price-box{position:relative;border:2.5px solid var(--terra);border-radius:30px;padding:clamp(40px,6vw,76px);
  text-align:center;max-width:900px;margin:0 auto;background:var(--cream);
  box-shadow:0 40px 80px -50px rgba(34,51,47,.5);}
.price-box .eyebrow{color:var(--sage);}
.price-box h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:18px;}
.price-box h2 em{font-style:italic;font-weight:500;color:var(--terra);}
.price-box .lead{font-size:1.2rem;line-height:1.6;color:var(--ink-soft);max-width:56ch;margin:0 auto 32px;}
.price-pills{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:34px;}
.price-pill{background:var(--sand);border:1.5px solid rgba(194,96,60,.4);border-radius:100px;padding:10px 22px;
  font-family:var(--body);font-weight:500;font-size:1rem;display:inline-flex;align-items:center;gap:9px;}
.price-pill::before{content:'✓';color:var(--terra);font-weight:700;}

/* ============================================================
   8. FAQ — светлая
   ============================================================ */
.faq{background:transparent;padding:clamp(84px,12vh,150px) 0;position:relative;}
.faq::after{content:"";position:absolute;left:0;right:0;bottom:0;height:150px;z-index:0;pointer-events:none;
  background:linear-gradient(to bottom,transparent,var(--veil-col,#ecddbc));}
.faq>.wrap{position:relative;z-index:1;}
.faq .eyebrow{color:var(--sage);}
.faq-list{max-width:820px;margin:0 auto;}
.faq-item{border-bottom:1px solid rgba(34,51,47,.16);}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;display:block;position:relative;
  font-family:var(--display);font-weight:600;font-size:clamp(1.2rem,2vw,1.5rem);color:var(--ink);padding:26px 52px 26px 0;}
.faq-q::after{content:'+';position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:1.7rem;font-weight:400;color:var(--terra);transition:transform .3s;font-family:var(--body);}
.faq-item.open .faq-q::after{transform:translateY(-50%) rotate(45deg);}
.faq-a{overflow:hidden;max-height:0;transition:max-height .4s ease;}
.faq-a-inner{padding:0 52px 26px 0;color:var(--ink-soft);font-size:1.1rem;line-height:1.6;}

/* ============================================================
   9. КОНТАКТЫ + ФОРМА — песочная
   ============================================================ */
.contact{position:relative;padding:clamp(40px,5vh,72px) 22px;display:flex;align-items:center;justify-content:center;min-height:100vh;overflow:hidden;background:var(--veil-col,#ecddbc);}
.contact-bg{position:absolute;inset:0;background-image:url(assets/zapis-bg.jpg);background-repeat:no-repeat;background-size:cover;background-position:center var(--bg-fy,32%);}
.contact-bg::after{content:"";position:absolute;inset:0;background:
  radial-gradient(120% 90% at 62% 50%,transparent 35%,rgba(60,40,18,.16) 100%);}
/* медовая вуаль сверху — тонкая, перекрывает жёсткий стык: плотная у самой кромки, быстро тает */
.contact-veil{position:absolute;top:-1px;left:0;right:0;height:var(--veil-h,22%);z-index:1;pointer-events:none;
  background:linear-gradient(to bottom,
    var(--veil-col,#ecddbc) 0%,
    color-mix(in srgb,var(--veil-col,#ecddbc) var(--veil-int,85%),transparent) 45%,
    transparent 100%);}
.contact-stage{position:relative;z-index:2;width:min(560px,100%);display:flex;flex-direction:column;gap:12px;transform:translate(var(--card-x,16vw),var(--card-y,8vh));}
.contact .eyebrow{color:var(--c-eye,var(--terra));display:block;text-align:center;}
.contact h2{font-size:clamp(1.7rem,2.8vw,2.4rem);margin-bottom:8px;color:var(--c-h,var(--ink));text-align:center;}
.contact h2 em{font-style:italic;font-weight:500;color:var(--c-em,var(--terra));}
.contact .lead{font-size:1.02rem;line-height:1.45;color:var(--ink-soft);max-width:40ch;margin:0 auto 16px;text-align:center;}

/* плавающая карточка формы */
.form-card{background:rgba(250,246,237,.82);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.55);border-radius:24px;padding:clamp(18px,2.2vw,28px);
  box-shadow:0 60px 120px -45px rgba(60,40,18,.65),0 8px 30px -16px rgba(60,40,18,.4);}
.form-card #formBody{background:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.6);
  border-radius:16px;padding:clamp(16px,1.8vw,22px);}
.form-card h3{font-size:1.5rem;margin-bottom:8px;text-align:center;}
.field{margin-bottom:11px;}
.field label{display:block;font-family:var(--body);font-weight:500;font-size:.9rem;margin-bottom:5px;}
.field input,.field textarea{width:100%;font-family:var(--body);font-size:1rem;padding:11px 14px;border-radius:11px;
  border:1.5px solid rgba(34,51,47,.18);background:rgba(255,255,255,.85);color:var(--ink);transition:border-color .2s,background .2s;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--terra);background:#fff;}
.field textarea{resize:vertical;min-height:58px;}
.form-card .btn{width:100%;justify-content:center;margin-top:2px;}
.form-toggle{display:none;}
/* рамка-заголовок (кликабельная) — показывается на телефоне/планшете вместо большой формы */
.form-card .form-toggle{flex-direction:row;align-items:center;justify-content:space-between;gap:14px;width:100%;cursor:pointer;text-align:left;font-family:var(--body);
  background:rgba(250,246,237,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:2.5px solid var(--c-em,#af3528);border-radius:15px;padding:10px 12px 10px 18px;
  box-shadow:0 20px 46px -32px rgba(60,40,18,.7);transition:transform .2s,border-color .2s,box-shadow .2s;}
.form-card .form-toggle:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--c-em,#af3528),#000 12%);}
.form-card .form-toggle:active{transform:translateY(0);}
.ft-title{font-family:var(--display);font-weight:600;font-size:clamp(1.2rem,4.4vw,1.5rem);line-height:1.1;color:var(--c-h,var(--ink));}
.ft-title em{font-style:italic;font-weight:500;color:var(--c-em,var(--terra));}
.ft-ar{flex:none;display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:var(--c-em,#af3528);color:#fff;font-size:1.2rem;line-height:1;}
/* eyebrow «Бесплатная консультация» — внутри раскрытой формы */
.form-eyebrow{display:none;font-size:.78rem;letter-spacing:.09em;text-transform:uppercase;font-weight:600;color:var(--c-em,#af3528);text-align:center;margin-bottom:2px;}
/* узкие экраны (телефон + планшет): форма сворачивается в рамку-заголовок, чтобы не закрывать фото */
@media (max-width:980px){
  .contact-stage{justify-content:space-between;}
  .form-card:not(.expanded){background:transparent;border:none;box-shadow:none;padding:0;backdrop-filter:none;-webkit-backdrop-filter:none;}
  .form-card:not(.expanded) .form-eyebrow,
  .form-card:not(.expanded) h2,.form-card:not(.expanded) .lead,.form-card #formBody{display:none;}
  .form-card .form-toggle{display:flex;animation:ftPulse 2.6s ease-in-out infinite;}
  .form-card .form-toggle .ft-ar{animation:ftBounce 1.5s ease-in-out infinite;}
  .form-card.expanded #formBody{display:block;animation:formReveal .35s ease both;}
  .form-card.expanded .form-eyebrow{display:block;}
  .form-card.expanded h2,.form-card.expanded .lead{display:block;}
  .form-card.expanded .form-toggle{display:none;}
}
@keyframes formReveal{from{opacity:0;transform:translateY(-8px);}to{opacity:1;transform:none;}}
@keyframes ftPulse{0%,100%{box-shadow:0 20px 46px -32px rgba(60,40,18,.7),0 0 0 0 rgba(175,53,40,.30);}55%{box-shadow:0 20px 46px -32px rgba(60,40,18,.7),0 0 0 12px rgba(175,53,40,0);}}
@keyframes ftBounce{0%,100%{transform:translateY(0);}50%{transform:translateY(3px);}}
@media (prefers-reduced-motion:reduce){.form-card .form-toggle,.form-card .form-toggle .ft-ar{animation:none;}}
.contact .btn{background:var(--terra);box-shadow:0 16px 40px -14px color-mix(in srgb,var(--terra),transparent 30%);}
.contact .btn:hover{background:color-mix(in srgb,var(--terra),#000 12%);}

/* компактные мессенджеры под карточкой */
.contact-direct{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px;
  background:rgba(255,255,255,.86);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.6);border-radius:18px;padding:10px 18px;
  box-shadow:0 30px 60px -40px rgba(60,40,18,.6);}
.contact-direct .cd-label{font-size:.96rem;color:var(--ink-soft);}
.cd-icons{display:flex;gap:10px;}
.cd-ic{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;text-decoration:none;
  background:var(--c-ic,var(--terra));color:var(--cream);font-size:1.3rem;font-family:var(--display);font-weight:600;
  box-shadow:0 12px 26px -14px color-mix(in srgb,var(--c-ic,var(--terra)),transparent 25%);transition:transform .2s,filter .2s;}
.cd-ic:hover{transform:translateY(-3px);filter:brightness(1.08);}
.form-note{font-size:.82rem;color:var(--ink-soft);margin-top:10px;text-align:center;}

/* широкие экраны: голова не должна упираться в верх — поднимаем фокус фото (больше воздуха сверху) */
@media (min-aspect-ratio:1.9/1){ .contact-bg{--bg-fy:16%;} }
@media (min-aspect-ratio:2.2/1){ .contact-bg{--bg-fy:8%;} }
.form-success{display:none;text-align:center;padding:24px 0;}
.form-success.show{display:block;}
.form-success .ok{width:64px;height:64px;border-radius:50%;background:var(--terra);color:var(--cream);display:grid;place-items:center;font-size:2rem;margin:0 auto 18px;}
.form-success h3{font-size:1.5rem;margin-bottom:8px;}
.form-success p{color:var(--ink-soft);}

/* ============================================================
   Footer
   ============================================================ */
.foot{background:#2e4640;color:rgba(251,248,240,.82);padding:54px 0 60px;text-align:center;}
.foot .fbrand{font-family:var(--display);font-weight:600;font-size:1.5rem;color:var(--cream);margin-bottom:10px;}
.foot p{font-size:.96rem;line-height:1.6;margin:0 auto;max-width:60ch;}
.foot a{color:var(--terra-soft);text-decoration:none;}
.foot .fdisc{font-size:.82rem;opacity:.6;margin-top:18px;}

/* ============================================================
   Адаптив
   ============================================================ */
@media (max-width:980px){
  .results-grid{grid-template-columns:repeat(2,1fr);}
  .levels{grid-template-columns:repeat(2,1fr);}
  .formats-grid{grid-template-columns:1fr;}
  .counters{grid-template-columns:repeat(2,1fr);gap:34px 24px;}
  .awards{grid-template-columns:1fr;text-align:center;justify-items:center;}
  .contact{padding:18px 16px clamp(40px,6vh,72px);min-height:100svh;align-items:stretch;background-attachment:scroll;--card-x:0;--card-y:0;}
  .contact-bg{background-position:28% 50%;}
}
/* низкие экраны / альбомная ориентация: Андрей слева — уводим рамку и форму вправо, на открытую зону, чтобы не перекрывать голову */
@media (max-width:980px) and (max-height:560px){
  .contact-stage{width:min(400px,56%);margin-left:auto;transform:none;}
  .contact-bg{background-position:16% 34%;}
}
@media (max-width:600px){
  .contact-direct{flex-direction:column;gap:10px;}
  .results-grid{grid-template-columns:1fr;}
  .levels{grid-template-columns:1fr;}
  .counters{grid-template-columns:1fr;gap:28px;}
  .tl-step{grid-template-columns:52px 1fr;gap:18px;}
  .tl-dot{width:52px;height:52px;font-size:1.3rem;}
  .tl-line{left:25px;}
}
