/* ===========================
   Base / tokens
=========================== */
:root{
    --bg: #ffffff;
    --page-bg: #f3f4f6;
    --surface-soft: #E9F1F8;
    --text: #1f2937;
    --small-text: #334155;
    --muted: #6b7280;
    --border: #e5e7eb;

    --primary: #1A83D4;
    --primary-600: #1b49bf;

    --radius-xl: 14px;
    --radius-lg: 12px;
    --radius-md: 10px;

    --shadow-sm: 0 1px 2px rgba(16,24,40,.06), 0 1px 1px rgba(16,24,40,.04);

    --container: 1200px;
    --page-gutter: clamp(16px, 3vw, 36px);
    --header-h: 76px;
}

:root{
    --font-heading: "IBM Plex Serif", ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
    --font-body: "Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
    --font-serif: "IBM Plex Serif";
}

.hidden {
    display: none !important;
}

/* базово для всего текста */
html, body{
    font-family: var(--font-body);
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

/* заголовки */
h1, h2, h3, h4, h5, h6{
    font-family: var(--font-serif);
    font-weight: 500;
    /*letter-spacing: -0.02em;*/
    color: var(--text);
}

h1{
  margin: 0 0 var(--s-16) 0;
  font-weight: 500;
  font-size: 56px;
  line-height: 1.15;
  letter-spacing: -0.02em;
}

h2{
    margin: 0 0 var(--s-12) 0;
    font-weight: 500;
    font-size: 48px;
    line-height: 1.2;
    text-align: center;
}

h3{
  margin: 0 0 var(--s-8) 0;
  font-weight: 500;
  font-size: 28px;
  line-height: 1.3;
}

h4{
    font-family: var(--font-body);
    font-weight: 500;
    font-size: 20px;
}

/* мелкая косметика: ссылки/кнопки тоже читаемыми */
button, input, textarea, select{
    font-family: inherit;
}

*{ box-sizing: border-box; }
html, body{ height: 100%; }
body{
    margin: 0;
    color: var(--small-text);
    background: var(--bg);
}

a{ color: inherit; text-decoration: none; }
button{ font: inherit; }

.container{
    width: min(var(--container), calc(100% - (var(--page-gutter) * 2)));
    margin: 0 auto;
}

.no-scroll{
    overflow: hidden;
}

/* ===========================
   Header
=========================== */
#site-header-placeholder {
    height: var(--header-h);
}

.site-header{
    position: fixed;
    width: 100%;
    top: 0;
    z-index: 30;
    background: var(--bg);
    border-bottom: 1px solid var(--border);
}

.header__inner{
    height: var(--header-h);
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 24px;
}

/* Logo */
.header__logo{
    display: inline-flex;
    align-items: center;
    gap: 12px;
    white-space: nowrap;
}

.logo__badge{
    width: 104px;
    height: 36px;
    border-radius: 10px;
    background: #d1d5db;
}

.logo__badge--mark{
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #dbe2f4;
    position: relative;
}
.logo__badge--mark::before{
    content: "";
    position: absolute;
    inset: 8px;
    border-radius: 6px;
    background: rgba(34,90,227,.25);
}

.logo__text{
    font-weight: 500;
    font-size: 18px;
}

/* Desktop nav */
.header__nav--desktop{
    display: flex;
    align-items: center;
    gap: 34px;
    justify-content: center;
}

.nav__link{
    font-weight: 500;
    font-size: 14px;
}
.nav__link:hover{
}
.nav__link.is-active{
    color: var(--primary);
}

/* Actions */
.header__actions--desktop{
    display: flex;
    align-items: center;
    gap: 12px;
    justify-self: end;
}

/* Buttons */
.btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 38px;
    padding: 0 14px;
    border-radius: 12px;
    font-weight: 500;
    font-size: 14px;
    border: 1px solid transparent;
    cursor: pointer;
    user-select: none;
    transition: transform .08s ease, background-color .12s ease, border-color .12s ease, color .12s ease;
}
.btn:active{
    transform: translateY(1px);
}

.btn--ghost{
    background: #ffffff;
    border: 1px solid var(--border);
    color: var(--primary);
}

.btn--ghost:hover{
    border-color: var(--border);
    background: #f8fafc;
}

.btn--primary{
    background: var(--primary);
    border-color: var(--primary);
    color: #ffffff;
}
.btn--primary:hover{
    background: var(--primary-600);
    border-color: var(--primary-600);
}

.btn--block{
    width: 100%;
}

@media (max-width: 900px) {
    .btn {
        height: 44px;
        width: 65%;
        max-width: 320px;
    }
}

/* Language dropdown (simple) */
.lang{
    position: relative;
}
.lang__btn{
    height: 38px;
    padding: 0 12px;
    border-radius: 12px;
    border: 1px solid #cbd5e1;
    background: #ffffff;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}
.lang__value{
    font-weight: 500;
    font-size: 13px;
    color: #111827;
}
.lang__chev{
    width: 8px;
    height: 8px;
    border-right: 2px solid #6b7280;
    border-bottom: 2px solid #6b7280;
    transform: rotate(45deg);
    margin-top: -2px;
}

.lang__list{
    position: absolute;
    right: 0;
    top: calc(100% + 8px);
    width: 152px;
    padding: 8px;
    margin: 0;
    list-style: none;
    border-radius: 12px;
    background: #ffffff;
    border: 1px solid var(--border);
    box-shadow: var(--shadow-sm);
}

.lang__item{
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 44px;
    border: 0;
    background: transparent;
    border-radius: 10px;
    cursor: pointer;
    text-align: left;
    padding: 0 12px;
    font-weight: 500;
    color: #111827;
    text-decoration: none;
    transition: background-color .18s ease, color .18s ease;
}
.lang__item:hover,
.lang__item:focus-visible,
.lang__item.is-current{
    background: #eaf4ff;
    color: var(--primary);
    outline: none;
}

/* Desktop language switcher style like header design */
.header__actions--desktop .lang__btn{
    height: auto;
    padding: 0 2px;
    border: 0;
    border-radius: 0;
    background: transparent;
}
.header__actions--desktop .lang__value{
    font-size: 14px;
    font-weight: 500;
}
.header__actions--desktop .lang__chev{
    width: 7px;
    height: 7px;
    border-right-width: 1.5px;
    border-bottom-width: 1.5px;
    margin-top: -1px;
}
.header__actions--desktop .lang__list{
    top: calc(100% + 10px);
}

/* Burger (mobile) */
.burger{
    display: none;
    width: 44px;
    height: 44px;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
    background: #ffffff;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    justify-self: end;
}
.burger__icon{
    width: 18px;
    height: 12px;
    position: relative;
    display: inline-block;
}
.burger__icon::before,
.burger__icon::after,
.burger__icon span{
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    height: 2px;
    border-radius: 2px;
    background: #111827;
}
.burger__icon::before{ top: 0; }
.burger__icon::after{ bottom: 0; }
.burger__icon span{ top: 5px; }


.img-logo {
    width: 218px;
}

.img-footer-logo {
    width: 156px;
}


/* ===========================
   Mobile menu overlay
=========================== */
.mobile-menu{
    position: fixed;
    inset: 0;
    z-index: 60;
    background: rgba(17,24,39,.22);
    opacity: 0;
    pointer-events: none;
    transition: opacity .16s ease;
}

.mobile-menu.is-open{
    opacity: 1;
    pointer-events: auto;
}

/* White full-screen panel */
.mobile-menu__panel{
    position: absolute;
    inset: 0;
    background: #ffffff;
    display: flex;
    flex-direction: column;
    height: 100dvh;
    max-height: 100dvh;
    overflow: hidden;
    padding: max(12px, env(safe-area-inset-top)) 16px calc(16px + env(safe-area-inset-bottom));
}

.mobile-menu__top{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--border);
}

.mobile-menu__top .header__logo{
    min-width: 0;
    max-width: calc(100% - 56px);
}

.mobile-menu__top .img-logo{
    width: min(218px, 100%);
    max-width: 100%;
    height: auto;
}

.mobile-menu__close{
    width: 44px;
    height: 44px;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
    background: #ffffff;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.close__icon{
    width: 16px;
    height: 16px;
    position: relative;
}
.close__icon::before,
.close__icon::after{
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 16px;
    height: 2px;
    background: #111827;
    border-radius: 2px;
    transform-origin: center;
}
.close__icon::before{ transform: translate(-50%,-50%) rotate(45deg); }
.close__icon::after{ transform: translate(-50%,-50%) rotate(-45deg); }

.mobile-menu__nav{
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    gap: 12px;
    padding: 18px 0;
}

.mobile-link{
    font-weight: 500;
    font-size: 18px;
    padding: 6px 6px;
    border-radius: 12px;
    color: #111827;
}
.mobile-link:hover{
    background: #f3f4f6;
}
.mobile-link.is-active{
    color: var(--primary);
}

.mobile-menu__actions{
    margin-top: 12px;
    display: grid;
    gap: 12px;
}

.lang--mobile .lang__btn{
    width: 100%;
    min-height: 68px;
    justify-content: space-between;
    padding: 0 18px;
    border: 0;
    border-radius: 16px;
    background: #f1f5f9;
}

.lang--mobile .lang__label{
    font-size: 18px;
    font-weight: 600;
    color: #0f172a;
}

.lang--mobile .lang__chev{
    width: 10px;
    height: 10px;
    margin-top: -4px;
    border-right-width: 2px;
    border-bottom-width: 2px;
    border-color: #0f172a;
    transition: transform .18s ease;
}

.lang--mobile .lang__btn[aria-expanded="true"] .lang__chev{
    transform: rotate(-135deg);
    margin-top: 2px;
}

.lang--mobile .lang__list{
    position: static;
    width: 100%;
    margin-top: 8px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
}

.lang--mobile .lang__item{
    display: block;
    height: auto;
    padding: 10px 12px;
    border-radius: 12px;
    font-size: 18px;
    line-height: 1.4;
    text-decoration: none;
}

.lang--mobile .lang__item:hover{
    background: #f1f5f9;
}


/* ===========================
   Mobile menu (new layout like the design)
=========================== */
.mobile-menu__brand{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
}

.mobile-menu__brand-logo{
  width: 38px;
  height: 38px;
  object-fit: contain;
  flex: 0 0 auto;
}

.mobile-menu__brand-text{
  font-weight: 700;
  font-size: 20px;
  line-height: 1.05;
  color: #1A83D4;
}

.mobile-menu__divider{
  height: 1px;
  background: #e5e7eb;
  margin: 10px 0;
}

.mobile-link--section{
  margin-top: 4px;
}

/* Products accordion */
.mobile-accordion{
  border-radius: 12px;
}

.mobile-accordion__toggle{
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 12px;
  border-radius: 12px;
  border: 0;
  background: #F1F5F9;
  font-weight: 600;
  font-size: 18px;
  color: #0F172A;
  cursor: pointer;
}

.mobile-accordion__chev{
  width: 18px;
  height: 18px;
  position: relative;
}

.mobile-accordion__chev::before{
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 8px;
  height: 8px;
  border-right: 2px solid #0F172A;
  border-bottom: 2px solid #0F172A;
  transform: rotate(45deg);
}

.mobile-accordion__toggle[aria-expanded="true"] .mobile-accordion__chev::before{
  transform: rotate(-135deg);
}

.mobile-accordion__content{
  display: grid;
  gap: 2px;
  padding: 6px 0 0;
}

.mobile-accordion__content[hidden]{
  display: none;
}

.mobile-sublink{
  display: block;
  padding: 10px 12px 10px 26px;
  border-radius: 12px;
  font-size: 18px;
  text-decoration: none;
}

.mobile-sublink:hover{
  background: #F1F5F9;
}

/* Bottom CTA */
.mobile-menu__footer{
  margin-top: 12px;
  padding-top: 0;
}

.mobile-menu__cta{
  display: block;
  width: 100%;
  text-align: center;
  padding: 14px 16px;
  border-radius: 16px;
  background: #1A83D4;
  color: #fff;
  font-weight: 600;
  text-decoration: none;
}

/* ===========================
   Responsive
=========================== */
@media (max-width: 980px){
    h1{
        font-size: 48px !important;
    }

    h2{
        font-size: 32px !important;
    }

    h3{
        font-size: 24px !important;
    }

    h4{
        font-size: 20px !important;
    }

    .header__inner{
        grid-template-columns: 1fr auto;
    }

    .header__nav--desktop,
    .header__actions--desktop{
        display: none;
    }

    .burger{
        display: inline-flex;
    }

    .container{
        width: min(var(--container), calc(100% - (var(--page-gutter) * 2)));
    }
}


/* =========================
   Shared Logo Carousel (Solution section 2 / Company trusted logos)
========================= */
.sol-logos{
  background: #ffffff;
  padding: 54px 0;
}

.sol-logos__inner{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}

.logo-marquee{
  position: relative;
  overflow: hidden;
  width: 100%;
  --fade: 64px;
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent 0,
    #000 var(--fade),
    #000 calc(100% - var(--fade)),
    transparent 100%
  );
  mask-image: linear-gradient(
    90deg,
    transparent 0,
    #000 var(--fade),
    #000 calc(100% - var(--fade)),
    transparent 100%
  );
}

.logo-marquee__track{
  display: flex;
  width: max-content;
  animation: solLogoMarquee 28s linear infinite;
  will-change: transform;
}

.logo-marquee__row{
  display: flex;
  align-items: center;
  gap: 86px;
  padding-right: 86px;
  width: max-content;
}

.logo-marquee__logo{
  height: 100px;
  width: auto;
  display: block;
  opacity: 0.95;
  user-select: none;
  -webkit-user-drag: none;
}

.sol-logos--solutions .logo-marquee__row{
  gap: 36px;
  padding-right: 36px;
}

.sol-logos--solutions .logo-marquee__logo{
  height: 90px;
}

@media (hover:hover){
  .logo-marquee:hover .logo-marquee__track{
    animation-play-state: paused;
  }
}

@keyframes solLogoMarquee{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}

@media (max-width: 980px){
  .sol-logos{
    padding: 36px 0;
  }
  .logo-marquee{
    --fade: 34px;
  }
  .logo-marquee__row{
    gap: 56px;
    padding-right: 56px;
  }
  .logo-marquee__logo{
    height: 80px;
  }

  .sol-logos--solutions .logo-marquee__row{
    gap: 36px;
    padding-right: 36px;
  }

  .sol-logos--solutions .logo-marquee__logo{
    height: 72px;
  }
}

@media (prefers-reduced-motion: reduce){
  .logo-marquee__track{
    animation: none;
  }
}

/* =========================
   Shared Solution FAQ section
========================= */
.sol-faq{
  padding: 40px 0 50px;
  background: #fff;
}

.sol-faq__head{
  text-align: center;
  margin: 0 auto;
}

.sol-faq__subtitle{
  margin: 14px auto 0;
  max-width: 760px;
  font-size: 18px;
  line-height: 1.6;
  font-weight: 400;
}

.sol-faq .faq{
  margin: 56px auto 0;
  max-width: 1040px;
  border-top: 1px solid rgba(12,22,48,0.14);
}

.sol-faq .faq-item{
  border-bottom: 1px solid rgba(12,22,48,0.14);
}

.sol-faq .faq-q{
  width: 100%;
  background: transparent;
  border: 0;
  padding: 22px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  cursor: pointer;
  text-align: left;
  line-height: 1.25;
}

.sol-faq .faq-q__text{
  margin: 0;
  flex: 1 1 auto;
  min-width: 0;
}

.sol-faq .faq-q__icon{
  flex: 0 0 auto;
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  color: rgba(11,26,55,0.70);
  transition: transform .25s ease;
}

.sol-faq .faq-item.is-open .faq-q__icon{
  transform: rotate(180deg);
}

.sol-faq .faq-a{
  height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-6px);
  transition: height .32s ease, opacity .22s ease, transform .22s ease;
  will-change: height;
}

.sol-faq .faq-item.is-open .faq-a{
  opacity: 1;
  transform: translateY(0);
}

.sol-faq .faq-a__inner{
  padding: 0 0 22px 0;
  font-size: 16px;
  line-height: 1.7;
  max-width: 980px;
}

@media (hover:hover){
  .sol-faq .faq-q:hover .faq-q__icon{
    color: rgba(37,99,235,0.90);
  }
}

@media (max-width: 980px){
  .sol-faq{
    padding: 78px 0 88px;
  }
  .sol-faq .faq{
    margin-top: 28px;
  }
  .sol-faq .faq-q{
    padding: 18px 0;
    font-size: 18px;
  }
  .sol-faq .faq-a__inner{
    font-size: 15px;
    padding-bottom: 18px;
  }
}

@media (prefers-reduced-motion: reduce){
  .sol-faq .faq-a,
  .sol-faq .faq-q__icon{
    transition: none !important;
  }
}



/* ========== SUBSCRIBE CTA (shared) ========== */
.subscribe{
    padding: 72px 0 96px;
}

.subscribe__box{
    background: #1A83D4;
    border-radius: 22px;
    padding: 42px 48px;
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: 28px;
    align-items: center;
    position: relative;
    overflow: visible;
}

.subscribe__box::after{
    content: "";
    position: absolute;
    top: 0;
    right: 0;

    width: 863px;
    height: 863px;
    opacity: 1;
    /*border-radius: 579px;*/


    background-image: url("../images/subscribe/frame-6.png");
    background-repeat: no-repeat;
    background-position: top right;
    background-size: contain;

    pointer-events: none;
    z-index: 0;
}

.subscribe__left,
.subscribe__form{
    position: relative;
    z-index: 1;
}

.subscribe__badge{
    display: inline-flex;
    align-items: center;
    height: 26px;
    padding: 0 12px;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,.35);
    color: rgba(255,255,255,.92);
    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
    font-weight: 500;
    font-size: 14px;
}

.subscribe__title{
    margin: 14px 0 0;
    color: #ffffff;
}



.subscribe__text{
    margin: 12px 0 0;
    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
    font-weight: 400;
    font-size: 18px;
    line-height: 1.3;
    color: rgba(255,255,255,.85);
    max-width: 520px;
}

/* Form */
.subscribe__form{
    justify-self: end;
    width: 400px;              /* можно 380–420px подогнать */
    max-width: 100%;

    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;

    background: #ffffff;       /* <-- общий белый блок */
    border-radius: 12px;
    box-sizing: border-box;
    height: 64px;
    opacity: 1;
    gap: 12px;
    padding: 12px;
    border-width: 2px;
}

.subscribe__field{
    width: 100%;
}

.subscribe__input{
    width: 100%;
    height: 44px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,.25);
    background: #ffffff;
    padding: 0 14px;
    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
    font-weight: 500;
    font-size: 14px;
    color: #0f172a;
    outline: none;
}

.subscribe__btn{
    height: 44px;
    padding: 0 18px;
    border-radius: 12px;
    border: 0;
    background: var(--primary);
    color: #ffffff;
    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
    font-weight: 500;
    font-size: 14px;
    cursor: pointer;
    white-space: nowrap;
}

.subscribe__btn:hover{
    background: var(--primary-600);
}

.subscribe__msg{
    grid-column: 1 / -1;
    margin-top: 6px;
    min-height: 18px;
    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
    font-size: 12px;
    color: rgba(255,255,255,.90);
}


/* Shared visually-hidden helper */
.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;
}

/* Mobile */
@media (max-width: 900px){
    .subscribe{
        padding: 44px 0 72px;
    }

    .subscribe__box{
        grid-template-columns: 1fr;
        padding: 28px 22px;
        gap: 18px;
    }

    .subscribe__title{
        font-size: 45px;
    }

    .subscribe__form{
        width: 100%;
        grid-template-columns: 1fr auto;
        gap: 10px;
        justify-self: stretch;
    }

    .subscribe__input{
        height: 46px;
        border-radius: 12px;
    }

    .subscribe__btn{
        height: 46px;
        border-radius: 12px;
        padding: 0 16px;
    }

    .hero-card,
    .hero__card,
    .cta-card,
    .subscribe-card {
      width: 100%;
      max-width: 100%;
    }

}




/* ========== SUBSCRIBE PILOT (feedback form: blue left + white form right, like photo) ========== */
.subscribe--pilot .subscribe__box{
    grid-template-columns: 1.05fr 0.85fr;
    justify-items: stretch;
    text-align: left;
    position: relative;
    overflow: hidden;
    padding: 0;
    border-radius: 24px;
    min-height: 383px; /* как в SVG */
    align-items: center;
}

.subscribe--pilot .subscribe__box::before{
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 100%;
    height: 100%;
    background-image: url("../images/subscribe/frame-13.png");
    background-repeat: no-repeat;
    background-position: left center;
    transform-origin: left center;
    pointer-events: none;
    z-index: 0;
}

.subscribe--pilot .subscribe__decor{
    display: none;
}

.subscribe--pilot .subscribe__content{
    position: relative;
    z-index: 1;
    padding: 40px 36px 40px 36px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;     /* центрируем содержимое */
    text-align: center;      /* центрируем текст */
    max-width: none;
}

.subscribe--pilot .subscribe__badge{
    margin: 0;
}

/*.subscribe--pilot .subscribe__title{*/
/*    font-size: 48px;*/
/*    line-height: 1.2;*/
/*    max-width: 500px;*/
/*    margin: 0;*/
/*    text-align: center;*/
/*}*/

.subscribe--pilot .subscribe__text{
    max-width: 480px;
    margin: 16px 0 0;
    text-align: center;
}

/* Right: white form panel (inset with blue visible on sides, like Figma) */
.subscribe--pilot .subscribe__form-panel{
    background: #ffffff;
    border: 2px solid rgba(26, 131, 212, 0.35);
    border-radius: 16px;

    /* размеры по макету SVG */
    width: 486px;
    max-width: calc(100% - 24px);
    min-height: 335px;

    /* позиционирование внутри синего блока */
    margin: 24px 24px 24px 0;
    align-self: center;

    /* внутренние отступы близко к SVG */
    padding: 22px 22px 18px;

    display: flex;
    align-items: flex-start;
    justify-content: center;

    box-sizing: border-box;
    min-width: 0;
    position: relative;
    z-index: 1;
}

.subscribe--pilot .subscribe__form{
    width: 100%;
    max-width: 100%;
    min-width: 0;

    display: flex;
    flex-direction: column;
    gap: 14px;

    margin: 0;
    padding: 0;

    background: transparent;
    border: 0;
    border-radius: 0;

    /* сбрасываем общие стили subscribe__form */
    height: auto;
    min-height: 0;
    grid-template-columns: none;
    align-items: stretch;
    justify-self: stretch;
    box-sizing: border-box;
}

/* Two-column grid: same full width as textarea/button below (name | company, email | phone) */
.subscribe--pilot .subscribe__form-row{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    align-items: stretch;
    width: 100%;
    min-width: 0;
}

.subscribe--pilot .subscribe__field{
    min-width: 0;
    display: flex;
    flex-direction: column;
    width: 100%;
}

/*.subscribe--pilot .subscribe__input,*/
/*.subscribe--pilot .subscribe__form textarea{*/
/*    width: 100%;*/
/*    height: 46px;*/
/*    border-radius: 12px;*/
/*    border: 1px solid rgba(15,23,42,.18);*/
/*    background: #ffffff;*/
/*    padding: 0 14px;*/
/*    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);*/
/*    font-weight: 500;*/
/*    font-size: 14px;*/
/*    color: #0f172a;*/
/*    outline: none;*/
/*    box-sizing: border-box;*/
/*}*/

.subscribe--pilot .subscribe__input,
.subscribe--pilot .subscribe__form textarea{
    width: 100%;
    height: 40px; /* SVG ближе к ~40 */
    border-radius: 14px;
    border: 1px solid #E5E7EB;
    background: #F8FAFC;
    padding: 0 18px;

    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
    font-weight: 400;
    font-size: 14px;
    color: #334155;
    outline: none;
    box-sizing: border-box;
}

/*.subscribe--pilot .subscribe__form textarea{*/
/*    height: 100px;*/
/*    padding: 12px 14px;*/
/*    resize: vertical;*/
/*    min-height: 100px;*/
/*}*/

.subscribe--pilot .subscribe__form textarea{
    height: 70px;       /* в SVG ~69px */
    min-height: 70px;
    max-height: 70px;
    padding: 12px 18px;
    resize: none;       /* чтобы макет не “ломался” */
}

.subscribe--pilot .subscribe__form textarea::placeholder{
    color: #94a3b8;
}

.subscribe--pilot .subscribe__input::placeholder{
    font-size: 14px;
}

/*.subscribe--pilot .subscribe__btn{*/
/*    height: 48px;*/
/*    width: 100%;*/
/*    border-radius: 12px;*/
/*    display: inline-flex;*/
/*    align-items: center;*/
/*    justify-content: center;*/
/*    gap: 0;*/
/*    background: var(--primary);*/
/*    margin-top: 4px;*/
/*}*/

.subscribe--pilot .subscribe__btn{
    width: 100%;
    height: 40px; /* SVG ~39 */
    border-radius: 12px;

    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0;

    background: #1A83D4;
    border: 1px solid #F1F5F9;
    margin-top: 2px;

    font-size: 14px;
    font-weight: 500;
}

.subscribe--pilot .subscribe__btn-ic{
    display: none;
}

/*.subscribe--pilot .subscribe__privacy{*/
/*    margin: 12px 0 0;*/
/*    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);*/
/*    font-size: 12px;*/
/*    line-height: 1.4;*/
/*    color: #64748b;*/
/*    text-align: center;*/
/*}*/

.subscribe--pilot .subscribe__privacy{
    margin: 6px 0 0;
    padding: 0 4px;

    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
    font-size: 12px;
    line-height: 1.35;
    color: rgba(51, 65, 85, 0.6);
    text-align: center;

    width: 100%;
    box-sizing: border-box;
}

.subscribe--pilot .subscribe__privacy a{
    color: #1A83D4;
    text-decoration: none;
}

.subscribe--pilot .subscribe__privacy a:hover{
    text-decoration: underline;
}

.subscribe--pilot .subscribe__msg{
    margin-top: 8px;
    text-align: center;
    color: #0f172a;
}

.subscribe--pilot .subscribe__msg:empty{
    display: none;
}

@media (max-width: 900px){
    .subscribe--pilot .subscribe__box{
        grid-template-columns: 1fr;
        padding: 0;
        border-radius: 20px;
        min-height: 0;
    }

    .subscribe--pilot .subscribe__content{
        padding: 36px 24px 28px;
        text-align: center;
    }

    .subscribe--pilot .subscribe__badge{
        margin: 0 auto;
    }

    .subscribe--pilot .subscribe__title{
        font-size: 32px !important;
        max-width: none;
        margin-left: auto;
        margin-right: auto;
    }

    .subscribe--pilot .subscribe__text{
        margin-left: auto;
        margin-right: auto;
    }

    .subscribe--pilot .subscribe__form-panel{
        padding: 28px 24px 32px;
        margin: 0 20px 24px;
        border-radius: 16px;
    }

    .subscribe--pilot .subscribe__form-row{
        grid-template-columns: 1fr;
    }
}

.hero__form,
.subscribe-form {
  display: flex;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}




/* ========== FOOTER ========== */
.footer{
    padding: 64px 0 64px;
    background: #ffffff;
    border-top: 1px solid rgba(15,23,42,.06);
}

.footer__grid{
    display: grid;
    grid-template-columns: 1.18fr 0.7fr 0.9fr 1fr 1.5fr;
    gap: 42px;
    align-items: start;
}

.footer__logo{
    display: inline-flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    color: #0f172a;
}

.footer__brand-copy{
    margin-top: 26px;
    color: #334155;
    font-size: 14px;
    line-height: 1.35;
}

.footer__brand-copy p{
    margin: 0;
}

.footer__logo-text{
    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
    font-weight: 500;
    font-size: 14px;
}


.footer__divider{
    margin: 18px 0 14px;
    height: 1px;
    width: 220px;
    max-width: 100%;
    background: rgba(15,23,42,.10);
}

.footer__network{
    display: flex;
    gap: 14px;
    align-items: center;
}

.footer__network-link{
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    text-decoration: none;
    background: transparent;
}

.footer__network-link--community{
    width: auto;
    height: auto;
    border-radius: 0;
}

.footer__network-mark{
    width: 92px;
    height: 23.36px;
    display: block;
}

@media (max-width: 480px){
    .footer__network-mark{
        width: 80px;
        height: 20.31px;
    }
}

.footer__heading{
    margin: 0 0 14px;
}

.footer__links{
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px;
}

.footer__links a{
    text-decoration: none;
    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
    font-weight: 400;
    font-size: 14px;
}

.footer__links a:hover{
}

.footer__col--subscribe{
    min-width: 260px;
}

.footer__subscribe{
    margin-top: 10px;
}

/* Footer subscribe form (reuse subscribe JS classes) */
.footer__subscribe-form{
    display: grid;
    grid-template-columns: 1fr 38px;
    gap: 10px;
    align-items: center;
    position: relative;
}

.footer__subscribe-input{
    height: 40px;
    border-radius: 10px;
    border: 1px solid rgba(15,23,42,.10);
    padding: 0 12px;
    outline: none;
    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
    font-size: 14px;
    color: #0f172a;
    background: #ffffff;
}

.footer__subscribe-btn{
    width: 38px;
    height: 40px;
    border-radius: 10px;
    border: 0;
    background: #1A83D4;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}

.footer__subscribe-arrow{
    width: 16px;
    height: 16px;
    position: relative;
    display: inline-block;
}
.footer__subscribe-arrow::before{
    content:"";
    position:absolute;
    left: 1px;
    top: 50%;
    width: 9px;
    height: 9px;
    border-right: 2px solid rgba(255,255,255,.95);
    border-bottom: 2px solid rgba(255,255,255,.95);
    transform: translateY(-50%) rotate(-45deg);
}

/* message line under input */
.footer__subscribe-msg{
    grid-column: 1 / -1;
    margin-top: 6px;
    font-family: var(--font-sans, "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
    font-size: 12px;
    line-height: 1.35;
    opacity: 0;
}

/* Responsive */
@media (max-width: 980px){
    .footer{
        padding: 44px 0 56px;
    }

    .footer__grid{
        grid-template-columns: 1fr 1fr;
        gap: 26px 28px;
    }

    .footer__col--subscribe{
        grid-column: 1 / -1;
    }
}

@media (max-width: 1280px){
    .subscribe--pilot .subscribe__input{
        padding: 0 16px;
    }

    .subscribe--pilot .subscribe__form textarea{
        padding: 12px 16px;
    }

    .subscribe--pilot .subscribe__input::placeholder{
        font-size: 13px;
    }
}

@media (max-width: 1279px) and (min-width: 981px){
    .header__inner{
        gap: 18px;
        grid-template-columns: auto minmax(0, 1fr) auto;
    }

    .header__nav--desktop{
        gap: 22px;
        min-width: 0;
    }

    .header__actions--desktop{
        gap: 8px;
    }

    .btn{
        padding: 0 12px;
    }

    .img-logo{
        width: 190px;
    }

    .footer__grid{
        grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr) minmax(0, 0.9fr);
        gap: 26px 24px;
    }

    .footer__brand{
        grid-column: 1;
    }

    .footer__col--subscribe{
        grid-column: 1 / -1;
        min-width: 0;
    }
}

@media (max-width: 620px){
    .footer__grid{
        grid-template-columns: 1fr 1fr;
        gap: 22px 22px;
    }

    .footer__brand{
        grid-column: 1 / -1;
    }

    .footer__divider{
        width: 100%;
    }

    .footer__brand-copy{
        margin-top: 20px;
    }
}


/* ===== HERO: make person photo big like Figma ===== */

/* контейнер с фигурами/картинкой (правый визуал) */
.product-hero__visual,
.company-hero__visual{
  position: relative;
  overflow: visible;
  min-height: 420px; /* дает место для большого персонажа как в Figma */
}

/* сама картинка человека */
.product-hero__visual .hero-person,
.company-hero__visual .hero-person{
  position: absolute;
  right: 18px;
  bottom: 0;
  width: clamp(300px, 32vw, 560px);
  height: auto;
  max-width: none;
  z-index: 3;
  transform: none !important;
  pointer-events: none;
  display: block;
}

/* mobile */
@media (max-width: 980px){
  .product-hero__visual,
  .company-hero__visual{
    min-height: 0;
  }

  .product-hero__visual .hero-person,
  .company-hero__visual .hero-person{
    position: relative;
    right: auto;
    bottom: auto;
    left: 50%;
    transform: translateX(-50%) !important;
    width: min(88vw, 380px);
    margin-top: 18px;
  }
}

/* ===== HERO (product/company): make person big + on top of blue blocks ===== */

/* 1) wrapper must be positioning context and NOT clip the person */
.hero-visual,
.company-hero__visual,
.product-hero__visual{
  position: relative;
  overflow: visible; /* важно: чтобы фото не пряталось/не обрезалось */
}

/* 2) blue blocks / shapes must stay behind */
.hero-shape,
.hero-visual__shape,
.company-hero__shape,
.product-hero__shape,
.hero-visual__bg,
.company-hero__bg,
.product-hero__bg{
  position: absolute;
  z-index: 1 !important;
}

/* 3) person must be above shapes and large */
.hero-person,
.hero-visual__person,
.company-hero__person,
.product-hero__person{
  position: absolute;
  z-index: 5 !important;
  bottom: 0;
  left: 70%;
  transform: translateX(-50%);
  width: min(1960px, 46vw);
  max-width: none;
  height: auto;
  pointer-events: none;
}

/* if the image is inside the person wrapper */
.hero-person img,
.hero-visual__person img,
.company-hero__person img,
.product-hero__person img{
  width: 100%;
  height: auto;
  display: block;
}

/* mobile sizing like figma */
@media (max-width: 680px){
  .hero-person,
  .hero-visual__person,
  .company-hero__person,
  .product-hero__person{
    left: 50%;
    width: min(360px, 92vw);
  }
}

.site-header{
    transition: transform .22s ease;
    will-change: transform;
}

.site-header.is-hidden{
    transform: translateY(-110%);
}


/* ===========================
   DCS MODAL (Request a demo)
=========================== */
.dcs-modal{
    position: fixed;
    inset: 0;
    z-index: 80;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(15, 23, 42, 0.42);
    opacity: 0;
    pointer-events: none;
    transition: opacity .18s ease;
}

.dcs-modal.is-open{
    opacity: 1;
    pointer-events: auto;
}

.dcs-modal__dialog{
    width: min(960px, 100%);
    background: #ffffff;
    border-radius: 18px;
    border: 1px solid rgba(15,23,42,.10);
    overflow: hidden;
    display: grid;
    grid-template-columns: 1fr 1fr;
    position: relative;
}

.dcs-modal__close{
    position: absolute;
    right: 14px;
    top: 14px;
    width: 32px;
    height: 32px;
    border-radius: 10px;
    border: 1px solid rgba(15,23,42,.10);
    background: rgba(255,255,255,.92);
    cursor: pointer;
}

.dcs-modal__close:before,
.dcs-modal__close:after{
    content:"";
    position:absolute;
    left: 50%;
    top: 50%;
    width: 14px;
    height: 2px;
    background: rgba(15,23,42,.65);
    transform-origin: center;
}

.dcs-modal__close:before{ transform: translate(-50%,-50%) rotate(45deg); }
.dcs-modal__close:after{ transform: translate(-50%,-50%) rotate(-45deg); }

.dcs-modal__media{
    background: #f3f4f6;
}

.dcs-modal__media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.dcs-modal__body{
    padding: 28px 28px 24px;
}

.dcs-modal__title{
    margin: 0;
    font-family: var(--font-serif, "Georgia", serif);
    font-weight: 500;
    font-size: 51px;
    line-height: 1.12;
    letter-spacing: -0.02em;
    color: #0f172a;
}

.dcs-modal__subtitle{
    margin: 12px 0 0;
    font-size: 14px;
    line-height: 1.55;
}

.dcs-modal__form{
    margin-top: 18px;
    display: grid;
    gap: 10px;
}

.dcs-modal__input{
    width: 100%;
    height: 44px;
    border-radius: 10px;
    border: 1px solid rgba(15,23,42,.12);
    padding: 0 12px;
    font-size: 14px;
    outline: none;
}

.dcs-modal__input:focus{
    border-color: rgba(34,90,227,.55);
}

.dcs-modal__submit{
    margin-top: 6px;
    height: 44px;
    border-radius: 12px;
}

.dcs-modal__foot{
    margin-top: 12px;
    color: rgba(15,23,42,.58);
    font-size: 12px;
    line-height: 1.35;
}

@media (max-width: 820px){
    .dcs-modal__dialog{ grid-template-columns: 1fr; }
    .dcs-modal__media{ display: none; }
    .dcs-modal__title{ font-size: 42px; }
}
.site-header{ transition: transform .22s ease; will-change: transform; }
.site-header.is-hidden{ transform: translateY(-110%); }

/* ===== Shared subscribe bridge (company / projects) ===== */

.subscribe-bridge {
  padding: 52px 0 70px;
}

.subscribe-bridge__card {
  position: relative;
  background: #1A83D4;
  border-radius: 22px;
  text-align: center;
  padding: 34px 28px 92px;
  overflow: visible;
}

.subscribe-bridge__card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 32%;
  pointer-events: none;
  z-index: 0;
  background: url("../images/subscribe/frame-13.png") no-repeat left center / contain;
  transform-origin: left center;
}

.subscribe-bridge__card::after {
  content: "";
  position: absolute;
  inset: 0 0 0 auto;
  width: 34%;
  pointer-events: none;
  z-index: 0;
  background: url("../images/subscribe/subR.png") no-repeat right center / contain;
  transform-origin: right center;
}

.subscribe-bridge__badge,
.subscribe-bridge__copy,
.subscribe-bridge__form {
  position: relative;
  z-index: 1;
}

.subscribe-bridge__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-radius: 8px;
  font-size: 12px;
  line-height: 1;
  color: #fff;
  margin: 0 auto 18px;
}

.subscribe-bridge__title {
  margin: 0 auto 10px;
  color: #fff;
}

.subscribe-bridge__text {
  margin: 0 auto;
  font-size: 12px;
  line-height: 1.6;
  color: #fff;
  opacity: 0.95;
  max-width: 720px;
}

.subscribe-bridge__copy--mobile {
  display: none;
}

.subscribe-bridge__form {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 50%);
  width: min(360px, calc(100% - 64px));
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
  background: #fff;
  border-radius: 12px;
  padding: 8px;
  border: 2px solid #1a83d4;
}

.subscribe-bridge__input {
  width: 100%;
  height: 34px;
  border: 1px solid #d8e0ea;
  border-radius: 10px;
  padding: 0 12px;
  font-size: 12px;
  outline: none;
  box-sizing: border-box;
}

.subscribe-bridge__btn {
  height: 34px;
  border: 0;
  border-radius: 10px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #1a83d4;
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
}

.subscribe-bridge__btn:hover {
  background: #1a83d4;
}

.subscribe-bridge__status {
  grid-column: 1 / -1;
  font-size: 11px;
  text-align: center;
  margin-top: 6px;
  color: #5b6b7c;
}

.subscribe-bridge__status:empty {
  display: none;
}

/* Optional variant kept for other pages */
.subscribe-bridge--mobile-only {
  padding: 52px 0 70px;
}

@media (max-width: 960px) {
  .subscribe-bridge:not(.subscribe-bridge--mobile-only) .subscribe-bridge__copy--desktop {
    display: none !important;
  }

  .subscribe-bridge:not(.subscribe-bridge--mobile-only) .subscribe-bridge__copy--mobile {
    display: block !important;
  }

  .subscribe-bridge:not(.subscribe-bridge--mobile-only) .subscribe-bridge__card {
    padding: 24px 16px 18px !important;
    border-radius: 18px;
    overflow: visible;
  }

  .subscribe-bridge:not(.subscribe-bridge--mobile-only) .subscribe-bridge__title {
    font-size: 28px;
    line-height: 1.12;
    max-width: 300px;
    margin-left: auto;
    margin-right: auto;
  }

  .subscribe-bridge:not(.subscribe-bridge--mobile-only) .subscribe-bridge__text {
    max-width: 300px;
    margin-left: auto;
    margin-right: auto;
    font-size: 12px;
    line-height: 1.5;
  }

  .subscribe-bridge:not(.subscribe-bridge--mobile-only) .subscribe-bridge__card::before,
  .subscribe-bridge:not(.subscribe-bridge--mobile-only) .subscribe-bridge__card::after {
    opacity: 0.08;
    width: 40%;
    background-size: contain;
  }

  .subscribe-bridge:not(.subscribe-bridge--mobile-only) .subscribe-bridge__form {
    position: relative !important;
    left: auto !important;
    bottom: auto !important;
    transform: none !important;
    margin: 18px auto 0 !important;
    width: 100% !important;
    grid-template-columns: 1fr !important;
    gap: 8px;
  }

  .subscribe-bridge:not(.subscribe-bridge--mobile-only) .subscribe-bridge__btn {
    width: 100%;
    justify-content: center;
  }

  .subscribe-bridge:not(.subscribe-bridge--mobile-only) .subscribe-bridge__btn-ico {
    display: none;
  }

  .subscribe-bridge:not(.subscribe-bridge--mobile-only) .subscribe-bridge__status {
    color: rgba(255,255,255,0.9);
    text-align: center;
  }
}

/* ...и т.д. для input/btn/status/title/text/::before/::after */

@media (max-width: 960px) {
  .subscribe-bridge--mobile-only {
    padding: 36px 0 54px;
  }

  .subscribe-bridge--mobile-only .subscribe-bridge__card {
    padding: 24px 16px 18px;
    border-radius: 18px;
  }

  .subscribe-bridge--mobile-only .subscribe-bridge__copy--desktop {
    display: none;
  }

  .subscribe-bridge--mobile-only .subscribe-bridge__copy--mobile {
    display: block;
  }

  .subscribe-bridge--mobile-only .subscribe-bridge__card::before,
  .subscribe-bridge--mobile-only .subscribe-bridge__card::after {
    opacity: 0.08;
    width: 40%;
    background-size: contain;
  }

  .subscribe-bridge--mobile-only .subscribe-bridge__form {
    position: relative;
    left: auto;
    bottom: auto;
    transform: none;
    margin: 18px auto 0;
    width: 100%;
    grid-template-columns: 1fr;
  }

  .subscribe-bridge--mobile-only .subscribe-bridge__btn {
    width: 100%;
    justify-content: center;
  }

  .subscribe-bridge--mobile-only .subscribe-bridge__status {
    color: rgba(255,255,255,0.9);
    text-align: center;
  }
}

/* Shared hero media block */
.hero-media {
  justify-self: end;
  width: 100%;
  max-width: 820px;
  margin-right: 0;
  min-width: 0;
}

.hero-media__frame {
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  border-radius: 22px 0 0 22px;
  overflow: hidden;
}

.hero-media__img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 22px 0 0 22px;
  object-fit: cover;
}

.hero-media__badgebar {
  margin: 12px auto 0;
  width: fit-content;
  max-width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--border);
  border: 1px var(--muted);
  border-radius: 999px;
}

.hero-media__badge {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: #fff;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}

.hero-media__badge img {
  width: 18px;
  height: 18px;
  display: block;
}

@media (min-width: 980px) {
  .hero-media {
    justify-self: end;
    width: min(820px, calc(100% + 24px));
    max-width: none;
    margin-right: 0px;
    margin-top: 0;
    overflow: hidden;
  }

  .hero-media__frame {
    padding: 0;
    border-radius: 22px 0 0 22px;
    overflow: hidden;
  }

  .hero-media__img {
    display: block;
    width: 100%;
    min-height: 500px;
    height: 100%;
    border-radius: 16px 0 0 16px;
    object-fit: cover;
    object-position: left top;
  }
}

@media (max-width: 979.98px) {
  .hero-media {
    order: 2;
    justify-self: stretch;
    width: 100%;
    max-width: none;
    margin-right: 0 !important;
    overflow: visible;
  }

  .hero-media__frame {
    margin: 0;
    padding: 0;
    border: 1px solid rgba(11, 26, 55, 0.14);
    background: #ffffff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: none;
  }

  .hero-media__img {
    width: 100%;
    height: auto !important;
    min-height: 0 !important;
    aspect-ratio: 336 / 259;
    display: block;
    object-fit: cover;
    object-position: center;
    border-radius: 12px;
  }

  .hero-media__badgebar {
    margin-top: 10px;
    padding: 4px 8px;
    gap: 6px;
  }

  .hero-media__badge {
    width: 24px;
    height: 24px;
    background: #ffffff;
  }

  .hero-media__badge img {
    width: 12px;
    height: 12px;
  }
}

@media (max-width: 380px) {
  .hero-media__badgebar {
    padding: 4px 7px;
    gap: 5px;
  }

  .hero-media__badge {
    width: 22px;
    height: 22px;
  }
}

/* Shared mobile behavior for final CTA on index/solution:
   keep full desktop pilot form, hide simplified bridge. */
@media (max-width: 960px) {
  .subscribe--desktop-only {
    display: block !important;
  }

  .subscribe-bridge--mobile-only {
    display: none !important;
  }

  .subscribe--pilot .subscribe__form-row {
    grid-template-columns: 1fr;
  }

  .subscribe--pilot .subscribe__form-panel {
    width: calc(100% - (var(--page-gutter) * 2));
    margin-left: var(--page-gutter);
    margin-right: var(--page-gutter);
    padding: clamp(16px, 4vw, 24px);
  }

  .subscribe--pilot .subscribe__form,
  .subscribe--pilot .subscribe__field,
  .subscribe--pilot .subscribe__input,
  .subscribe--pilot .subscribe__form textarea,
  .subscribe--pilot .subscribe__btn {
    width: 100%;
  }
}

/* Shared first section layout across non-project pages (based on index) */
.first-screen.first-screen {
  padding: 32px 0 64px;
}

.first-screen .first-screen__inner.first-screen__inner {
  display: grid;
  grid-template-columns: 1.15fr 0.95fr;
  gap: 0;
  align-items: center;
}

.first-screen .first-screen__content.first-screen__content {
  min-width: 0;
}

.first-screen .first-screen__text.first-screen__text {
  margin: 50px 0 0;
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 20px;
  color: var(--text);
}

.first-screen .first-screen__actions.first-screen__actions {
  margin-top: 26px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.first-screen .first-screen__actions.first-screen__actions > * {
  margin: 0;
}

.first-screen .first-screen__actions.first-screen__actions .btn {
  width: auto;
  min-width: 166px;
  max-width: 100%;
  min-height: 38px;
  height: auto;
  white-space: normal;
  text-align: center;
  line-height: 1.2;
}

.first-screen .first-screen__media.first-screen__media {
  min-width: 0;
}

@media (max-width: 1279px) and (min-width: 981px) {
  .first-screen.first-screen {
    padding: 28px 0 48px;
  }

  .first-screen .first-screen__inner.first-screen__inner {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: 24px;
  }

  .first-screen .first-screen__actions.first-screen__actions .btn {
    width: auto;
  }
}

@media (max-width: 980px) {
  .first-screen.first-screen {
    padding: 28px 0 40px;
  }

  .first-screen .first-screen__inner.first-screen__inner {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .first-screen .first-screen__actions.first-screen__actions {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .first-screen .first-screen__actions.first-screen__actions .btn {
    width: auto;
  }
}
