.mobile-contact-bar { display: none; }
.responsive-home .hero__overlay { background: linear-gradient(90deg, rgba(16,37,28,.76), rgba(16,37,28,.28) 62%, rgba(16,37,28,.08)); }
.responsive-home .hero__content { display: none; max-width: 760px; margin: 0; text-align: left; transform: none; }
.responsive-home .hero__eyebrow { margin: 0 0 14px; color: #ead9b8; font-size: .82rem; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; }
.responsive-home .hero__title { margin-bottom: 20px; font-size: clamp(2.7rem,6vw,5.6rem); line-height: 1.02; }
.responsive-home .hero__subtitle { max-width: 650px; margin: 0 0 30px; text-align: left; }
.responsive-home .hero__actions { justify-content: flex-start; }
.responsive-home .hero__telegram { border: 1px solid rgba(255,255,255,.6); color: #fff; background: rgba(255,255,255,.1); }
.responsive-home .mobile-menu__email { color: var(--vine-dark); text-align: center; }

@media (max-width: 900px) {
  .responsive-home { overflow-x: hidden; }
  .responsive-home .header__container { height: 68px; padding: 8px 16px; }
  .responsive-home .header__logo-text { font-size: 1.8rem; }
  .responsive-home .header__logo-region { font-size: .62rem; }
  .responsive-home .header__nav, .responsive-home .header__actions { display: none; }
  .responsive-home .header__burger { display: flex; }
  .responsive-home .mobile-menu { top: 68px; }
}

@media (max-width: 767px) {
  .responsive-home { padding-bottom: 66px; }
  .responsive-home .hero { min-height: 540px; align-items: flex-end; }
  .responsive-home .hero__bg-img { object-position: 62% center; animation: none; }
  .responsive-home .hero__overlay { background: linear-gradient(0deg,rgba(12,31,23,.94),rgba(12,31,23,.18) 78%); }
  .responsive-home .hero__container { padding: 42px 18px; }
  .responsive-home .hero__content { display: block; }
  .responsive-home .hero__title { font-size: clamp(2.15rem,10vw,3rem); line-height: 1.08; }
  .responsive-home .hero__subtitle { margin-bottom: 24px; font-size: 1rem; line-height: 1.55; }
  .responsive-home .hero__actions { display: grid; grid-template-columns: 1fr; width: 100%; }
  .responsive-home .hero__actions .btn { min-height: 52px; }
  .responsive-home .section { padding: 38px 0; }
  .responsive-home .section__header { margin-bottom: 28px; }
  .responsive-home .section__title { font-size: clamp(2rem,9vw,2.55rem); }
  .responsive-home .why-us__grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 10px; }
  .responsive-home .why-us__card { min-height: 0; padding: 16px 12px; border-radius: 18px; }
  .responsive-home .why-us__icon { width: 38px; height: 38px; margin-bottom: 10px; }
  .responsive-home .why-us__icon svg { width: 24px; height: 24px; }
  .responsive-home .why-us__title { font-size: .94rem; line-height: 1.2; }
  .responsive-home .why-us__text { display: none; }

  .responsive-home .for-whom__grid,
  .responsive-home .services-overview__grid,
  .responsive-home .cases-preview__grid,
  .responsive-home .articles-preview__grid,
  .responsive-home .process-preview__steps {
    display: flex!important;
    flex-direction: row!important;
    flex-wrap: nowrap!important;
    align-items: stretch!important;
    gap: 14px!important;
    overflow-x: auto!important;
    overflow-y: hidden!important;
    padding: 2px 18px 16px!important;
    margin-inline: -18px!important;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }
  .responsive-home .for-whom__grid::-webkit-scrollbar,
  .responsive-home .services-overview__grid::-webkit-scrollbar,
  .responsive-home .cases-preview__grid::-webkit-scrollbar,
  .responsive-home .articles-preview__grid::-webkit-scrollbar,
  .responsive-home .process-preview__steps::-webkit-scrollbar { display: none; }
  .responsive-home .for-whom__card,
  .responsive-home .services-overview .service-card,
  .responsive-home .cases-preview .case-card,
  .responsive-home .articles-preview .article-card,
  .responsive-home .process-step {
    flex: 0 0 min(82vw,310px)!important;
    width: min(82vw,310px)!important;
    min-width: min(82vw,310px)!important;
    scroll-snap-align: start;
  }
  .responsive-home .for-whom__card { min-height: 370px; }
  .responsive-home .services-overview .service-card { height: 390px!important; min-height: 390px!important; }
  .responsive-home .cases-preview .case-card { min-height: 405px!important; }
  .responsive-home .articles-preview { --home-blog-grid-height: auto!important; }
  .responsive-home .articles-layout,
  .responsive-home .articles-main { display: block; min-height: 0!important; height: auto!important; }
  .responsive-home .articles-sidebar { display: none; }
  .responsive-home .articles-preview .article-card { min-height: 380px!important; }
  .responsive-home .process-step { min-height: 220px; }
  .responsive-home .process-preview__connector { display: none; }
  .responsive-home .field-video__layout { grid-template-columns: 1fr; }
  .responsive-home .field-video__list { display: flex; gap: 12px; overflow-x: auto; padding: 2px 2px 12px; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }
  .responsive-home .field-video__item { min-width: min(82vw,300px); scroll-snap-align: start; }
  .responsive-home .problems__grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 10px; }
  .responsive-home .problems__item { min-height: 0; padding: 14px 10px; }
  .responsive-home .problems__marker { width: 30px; height: 30px; }
  .responsive-home .problems__text { font-size: .82rem; line-height: 1.3; }
  .responsive-home .faq { min-height: 0; }
  .responsive-home .faq__image-wrapper { display: none; }
  .responsive-home .faq__content { width: 100%; }
  .responsive-home .faq__item:nth-of-type(n+5) { display: none; }
  .responsive-home .faq__question { min-height: 58px; padding: 14px 12px; }
  .responsive-home .faq__question-text { font-size: .9rem; }
  .responsive-home .geography__app-shell { height: 420px; }
  .responsive-home .footer { padding-bottom: 34px; }
  .mobile-contact-bar { position: fixed; z-index: 120; right: 8px; bottom: 8px; left: 8px; display: grid; grid-template-columns: repeat(4,1fr); padding: 7px; border: 1px solid rgba(197,160,89,.4); border-radius: 18px; background: rgba(247,242,230,.96); box-shadow: 0 12px 35px rgba(18,42,31,.22); backdrop-filter: blur(14px); }
  .mobile-contact-bar a { display: flex; min-height: 46px; align-items: center; justify-content: center; border-radius: 12px; color: #214031; font-size: .72rem; font-weight: 800; text-decoration: none; }
  .mobile-contact-bar a:first-child { color: #fff; background: #244c38; }
}
