/* =====================================================================
   Services page — Hero (desktop only)
   Design: Figma 465:210 (desktop services — redesign)
   Width: 1920 (content zone: 1360, gutter: 280)
   ===================================================================== */

:root {
  --svc-text:            #222522;
  --svc-text-muted:      #4b514c;
  --svc-text-soft:       #6b706e;
  --svc-text-faint:      #7d858f;
  --svc-text-disabled:   #99a19c;
  --svc-text-dim:        #8c948f;

  --svc-green:           #00af57;
  --svc-green-dark:      #116b41;
  --svc-green-ink:       #4c534e;

  --svc-surface-card:    rgba(255, 255, 255, 0.6);
  --svc-surface-ghost:   #fdfdfb;
  --svc-surface-sidebar: rgba(255, 255, 255, 0.65);
  --svc-surface-item:    #f8fbf8;
  --svc-surface-item-active: #4c534e;

  --svc-border-card:     #eef2ee;
  --svc-border-sidebar:  rgba(255, 255, 255, 0.85);
  --svc-divider:         #eaeeea;

  --svc-star:            #ffc71c;

  --svc-shadow-chip:     0 6px 18px rgba(20, 26, 31, 0.10);
  --svc-shadow-cta:      0 10px 22px rgba(0, 175, 87, 0.26);
  --svc-shadow-sidebar:  0 4px 14px rgba(20, 26, 31, 0.03);
  --svc-shadow-active:   0 3px 8px rgba(0, 175, 87, 0.12);

  --svc-hover-scale-soft: 1.015;
  --svc-hover-scale-ui:   1.03;
}

/* Final CTA Bitrix layout fit */
@media (min-width: 768px) {
  body.services-page .svc-final-cta {
    height: 640px !important;
  }

  body.services-page .svc-final-cta__visual,
  body.services-page .svc-final-cta__fade {
    height: 100% !important;
  }

  body.services-page .svc-final-cta__content {
    height: 100% !important;
    padding: 38px 36px 34px 46px !important;
    gap: 12px !important;
  }

  body.services-page .svc-final-cta__title {
    font-size: 30px !important;
    line-height: 1.12 !important;
  }

  body.services-page .svc-final-cta__lead {
    font-size: 14px !important;
    line-height: 1.45 !important;
  }
}

body.services-page .svc-final-cta__form .b24-form-content form > div:first-child {
  gap: 8px 10px !important;
}

body.services-page .svc-final-cta__form .b24-form-field {
  min-height: 0 !important;
}

body.services-page .svc-final-cta__form .b24-form-control,
body.services-page .svc-final-cta__form input[type="text"],
body.services-page .svc-final-cta__form input[type="tel"],
body.services-page .svc-final-cta__form input[type="email"],
body.services-page .svc-final-cta__form select,
body.services-page .svc-final-cta__form textarea {
  height: 44px !important;
  min-height: 44px !important;
  padding: 16px 14px 6px !important;
  border-radius: 12px !important;
  font-size: 14px !important;
}

body.services-page .svc-final-cta__form textarea {
  height: 68px !important;
}

body.services-page .svc-final-cta__form .b24-form-btn-container {
  margin-top: 8px !important;
}

body.services-page .svc-final-cta__form .b24-form-btn {
  min-height: 50px !important;
  border-radius: 12px !important;
  font-size: 15px !important;
}

body.services-page .svc-final-cta__form .b24-form-field-agreement {
  margin-top: 8px !important;
  font-size: 9px !important;
  line-height: 1.25 !important;
}

@media (max-width: 767px) {
  body.services-page .svc-final-cta {
    height: auto !important;
  }

  body.services-page .svc-final-cta__form .b24-form-content form > div:first-child {
    grid-template-columns: 1fr !important;
  }
}

/* Bitrix24 form inside final CTA */
.svc-final-cta__form.home2-b24-wrap {
  width: 100%;
  min-height: 0;
}

.svc-final-cta__form .citystaff-wrapper-b24-form-inline,
.svc-final-cta__form .b24-form,
.svc-final-cta__form .b24-form-wrapper {
  width: 100% !important;
  max-width: 100% !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  min-height: 0 !important;
}

.svc-final-cta__form .b24-form-header,
.svc-final-cta__form .b24-form-sign {
  display: none !important;
}

.svc-final-cta__form .b24-form-content {
  padding: 0 !important;
}

.svc-final-cta__form .b24-form-content form > div:first-child {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 12px !important;
}

.svc-final-cta__form .b24-form-field {
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.svc-final-cta__form .b24-form-control-container {
  position: relative !important;
  margin-bottom: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.svc-final-cta__form .b24-form-control,
.svc-final-cta__form input[type="text"],
.svc-final-cta__form input[type="tel"],
.svc-final-cta__form input[type="email"],
.svc-final-cta__form select,
.svc-final-cta__form textarea {
  width: 100% !important;
  height: 50px !important;
  min-height: 50px !important;
  padding: 18px 18px 7px !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  border-radius: 14px !important;
  background: rgba(255, 255, 255, 0.08) !important;
  box-shadow: none !important;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif !important;
  font-size: 15px !important;
  line-height: 1.2 !important;
  color: #fff !important;
  outline: none !important;
}

.svc-final-cta__form textarea {
  height: 84px !important;
  padding-top: 22px !important;
}

.svc-final-cta__form .b24-form-field.home2-b24-route-hidden {
  display: none !important;
}

.svc-final-cta__form .b24-form-control-label,
.svc-final-cta__form .b24-form-control-label-name {
  color: rgba(255, 255, 255, 0.5) !important;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif !important;
}

.svc-final-cta__form .b24-form-control:focus,
.svc-final-cta__form input:focus,
.svc-final-cta__form textarea:focus {
  border-color: rgba(22, 165, 96, 0.78) !important;
  box-shadow: 0 0 0 3px rgba(22, 165, 96, 0.16) !important;
}

.svc-final-cta__form .b24-form-btn-container {
  margin-top: 14px !important;
}

.svc-final-cta__form .b24-form-btn-block {
  position: static !important;
  top: auto !important;
  right: auto !important;
  width: 100% !important;
}

.svc-final-cta__form .b24-form-btn {
  width: 100% !important;
  min-height: 55px !important;
  border: 0 !important;
  border-radius: 14px !important;
  background: #16a560 !important;
  box-shadow: 0 6px 20px rgba(22, 165, 96, 0.25) !important;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: #fff !important;
}

.svc-final-cta__form .b24-form-field-agreement {
  margin-top: 12px !important;
  color: rgba(255, 255, 255, 0.5) !important;
  font-size: 11px !important;
  line-height: 1.45 !important;
}

.svc-final-cta__form .b24-form-field-agreement-link {
  color: rgba(255, 255, 255, 0.72) !important;
}

.svc-final-cta__note {
  display: none !important;
}

@media (max-width: 767px) {
  .svc-final-cta__form .b24-form-content form > div:first-child {
    grid-template-columns: 1fr !important;
  }
}

/* override base page bg so hero glow sits on soft off-white like Figma */
body.services-page { background: #fafdfa; }
body.services-page .page-bg { display: none; }

/* ------------------------- Interactive hover scale ------------------------- */

body.services-page .header__logo,
body.services-page .header__nav-link,
body.services-page .header__phone,
.svc-breadcrumbs__link,
.svc-faq__contact,
.svc-reviews-link,
.svc-position__mainlink,
.svc-sidebar__sub-link {
  transform-origin: left center;
  transition: transform .15s ease, color .15s ease, background-color .15s ease, border-color .15s ease, box-shadow .2s ease;
}

body.services-page .header__logo:hover,
body.services-page .header__nav-link:hover,
body.services-page .header__phone:hover,
.svc-breadcrumbs__link:hover,
.svc-faq__contact:hover,
.svc-reviews-link:hover,
.svc-position__mainlink:hover,
.svc-sidebar__sub-link:hover {
  transform: scale(var(--svc-hover-scale-soft));
}

body.services-page .header__city,
body.services-page .header__search,
body.services-page .header__cta,
body.services-page .header__mobile-app,
body.services-page .header__mobile-phone,
body.services-page .header__burger,
.svc-btn,
.svc-positions__search,
.svc-position__btn,
.svc-position__chevron,
.svc-tag,
.svc-letters__arrow,
.svc-sidebar__group-head,
.svc-sidebar__expert-btn,
.svc-final-cta__field,
.svc-final-cta__button {
  transform-origin: center;
  transition: transform .15s ease, color .15s ease, background-color .15s ease, border-color .15s ease, box-shadow .2s ease;
}

body.services-page .header__city:hover,
body.services-page .header__search:hover,
body.services-page .header__cta:hover,
body.services-page .header__mobile-app:hover,
body.services-page .header__mobile-phone:hover,
body.services-page .header__burger:hover,
.svc-positions__search:hover,
.svc-sidebar__group-head:hover,
.svc-sidebar__expert-btn:hover,
.svc-final-cta__field:hover,
.svc-final-cta__button:hover,
.svc-tag:hover,
.svc-letters__arrow:hover {
  transform: scale(var(--svc-hover-scale-ui));
}

/* ------------------------- Section ------------------------- */

body.services-page .main-content {
  --svc-sidebar-sticky-top: 128px;
}

.header.header--hidden ~ .main-content {
  --svc-sidebar-sticky-top: 24px;
}

.svc-hero {
  position: relative;
  padding-top: 140px;
  padding-bottom: 80px;
  overflow: clip;
  isolation: isolate;
}

.svc-hero__glow {
  position: absolute;
  top: -140px;
  right: -120px;
  width: 900px;
  height: 900px;
  background: radial-gradient(circle at center,
                rgba(170, 224, 192, 0.55) 0%,
                rgba(170, 224, 192, 0.35) 28%,
                rgba(170, 224, 192, 0) 68%);
  filter: blur(40px);
  pointer-events: none;
  z-index: -1;
}

.svc-hero__container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 40px;
}

/* ------------------------- Breadcrumbs ------------------------- */

.svc-breadcrumbs {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 34px;
  font-size: 14px;
  line-height: 1.2;
}

.svc-breadcrumbs__link {
  color: var(--svc-text-soft);
  transition: transform .15s ease, color .15s ease;
}
.svc-breadcrumbs__link:hover { color: var(--svc-text); }

.svc-breadcrumbs__sep  { color: var(--svc-text-disabled); }
.svc-breadcrumbs__current {
  color: #212624;
  font-weight: 500;
}

/* ------------------------- Grid ------------------------- */

.svc-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  grid-template-rows: auto auto auto auto auto auto auto auto;
  column-gap: 24px;
  row-gap: 16px;
  align-items: start;
}

.svc-hero-card {
  grid-column: 1;
  grid-row: 1;
  align-self: start;
  margin: 0;
}

.svc-trustrow {
  grid-column: 1;
  grid-row: 2;
  align-self: start;
  margin-top: 64px;
}

.svc-positions {
  grid-column: 1;
  grid-row: 3;
  align-self: start;
  margin-top: 72px;
}

.svc-process {
  grid-column: 1;
  grid-row: 5;
  align-self: start;
  margin-top: 124px;
}

.svc-seo-text {
  grid-column: 1;
  grid-row: 4;
  align-self: start;
  width: 976px;
  max-width: 100%;
  margin-top: 84px;
}

.svc-seo-text__inner {
  color: #111;
  font-family: var(--svc-font);
}

.svc-seo-text__inner h2 {
  max-width: 780px;
  margin: 0 0 24px;
  color: #050706;
  font-size: 34px;
  font-weight: 700;
  line-height: 1.16;
  letter-spacing: -0.025em;
}

.svc-seo-text__inner p {
  max-width: 860px;
  margin: 0;
  color: #202624;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.62;
}

.svc-seo-text__inner p + p {
  margin-top: 14px;
}

.svc-geo {
  grid-column: 1;
  grid-row: 6;
  align-self: start;
  margin-top: 188px;
}

.svc-letters {
  grid-column: 1;
  grid-row: 7;
  align-self: start;
  margin-top: 80px;
}

.svc-faq {
  grid-column: 1;
  grid-row: 8;
  align-self: start;
  width: 976px;
  max-width: 100%;
  margin-top: 107px;
}

.svc-final-cta {
  grid-column: 1;
  grid-row: 9;
  align-self: start;
  position: relative;
  width: 976px;
  max-width: 100%;
  height: 520px;
  margin-top: 180px;
  background: #0E1820;
  border-radius: 32px;
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(13, 26, 38, 0.08);
  isolation: isolate;
}

.svc-sidebar {
  grid-column: 2;
  grid-row: 1 / span 9;
  align-self: stretch;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  height: 100%;
}

/* ------------------------- Hero Card ------------------------- */

.svc-hero-card {
  background: var(--svc-surface-card);
  border: 1px solid var(--svc-border-card);
  border-radius: 32px;
  overflow: hidden;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.svc-hero-card__photo {
  position: relative;
  height: 520px;
  width: 100%;
  overflow: hidden;
}

.svc-hero-card__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.svc-hero-card__photo::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 380px;
  background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.42) 34%, rgba(255,255,255,.88) 66%, #fff 100%);
  pointer-events: none;
  z-index: 1;
}

.svc-hero-card__chips {
  position: absolute;
  top: 24px;
  left: 24px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.svc-hero-card__chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 20px 13px 18px;
  background: rgba(255, 255, 255, 0.62);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 999px;
  box-shadow: var(--svc-shadow-chip);
  font-family: 'Golos Text', sans-serif;
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -0.16px;
  color: #2b302b;
  white-space: nowrap;
}

.svc-hero-card__chip-text--mobile,
.svc-hero-card__chip--price {
  display: none;
}

.svc-hero-card__chip-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--svc-green);
  flex-shrink: 0;
}

.svc-hero-card__body {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-top: -220px;
  padding: 36px 44px 40px;
}

.svc-hero-card__title {
  font-family: 'Golos Text', sans-serif;
  font-size: 42px;
  font-weight: 600;
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--svc-text);
  margin: 0;
}

.svc-hero-card__trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 18px;
  white-space: nowrap;
}

.svc-trust-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  line-height: 1.2;
}
.svc-trust-star {
  color: var(--svc-star);
  font-size: 16px;
  line-height: 1;
}
.svc-trust-value {
  font-weight: 600;
  color: var(--svc-text);
}
.svc-trust-check {
  color: var(--svc-green);
  font-weight: 600;
  font-size: 15px;
  line-height: 1;
}
.svc-trust-label {
  color: var(--svc-text-muted);
  font-weight: 500;
}

.svc-hero-card__lead {
  font-size: 17px;
  line-height: 1.5;
  color: var(--svc-text-muted);
  margin: 0;
  max-width: 820px;
}

.svc-hero-card__stack {
  display: flex;
  flex-direction: column;
  gap: 28px;
  margin-top: 8px;
}

.svc-hero-card__divider {
  height: 1px;
  background: var(--svc-divider);
  width: 100%;
}

.svc-hero-card__row {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: flex-start;
}

/* Price block */
.svc-price {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.svc-price__label {
  font-size: 14px;
  color: var(--svc-text-faint);
  font-weight: 400;
}
.svc-price__line {
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.svc-price__value {
  font-family: 'Golos Text', sans-serif;
  font-size: 44px;
  font-weight: 600;
  line-height: 1.1;
  color: var(--svc-text);
  letter-spacing: -0.01em;
}

.svc-ruble {
  position: relative;
  display: inline-block;
  margin-left: 0.03em;
  padding-right: 0.02em;
  font-family: inherit;
  font-size: 0.98em;
  font-weight: inherit;
  line-height: 1;
  letter-spacing: -0.02em;
}

.svc-ruble::after {
  content: "";
  position: absolute;
  top: 0.56em;
  left: 0.02em;
  width: 0.56em;
  height: 0.065em;
  border-radius: 999px;
  background: currentColor;
  box-shadow: 0 0.14em 0 currentColor;
  pointer-events: none;
}
.svc-price__unit {
  font-size: 20px;
  font-weight: 500;
  color: var(--svc-text-faint);
}

/* Buttons */
.svc-hero-card__cta {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.svc-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  height: 52px;
  padding: 0 20px;
  border-radius: 14px;
  font-family: 'Golos Text', sans-serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .2s ease, background-color .2s ease;
  white-space: nowrap;
  border: none;
}

.svc-btn--primary {
  background: var(--svc-green);
  color: #fff;
  box-shadow: var(--svc-shadow-cta);
  padding-right: 24px;
}
.svc-btn--primary:hover {
  background: #00a252;
  transform: translateY(-1px) scale(var(--svc-hover-scale-ui));
  box-shadow: 0 14px 26px rgba(0, 175, 87, 0.32);
}
.svc-btn__arrow { font-weight: 400; }

.svc-btn--ghost {
  background: var(--svc-surface-ghost);
  color: #2f3430;
  text-decoration: none;
}
.svc-btn--ghost:hover {
  background: #f3f6f3;
  transform: scale(var(--svc-hover-scale-ui));
}
.svc-btn--ghost svg { color: var(--svc-green); }

.svc-hero-card__note {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--svc-text-soft);
}
.svc-hero-card__note svg { color: var(--svc-text-soft); }

/* ------------------------- Sidebar ------------------------- */


.svc-sidebar__inner {
  background: var(--svc-surface-sidebar);
  border: 1px solid var(--svc-border-sidebar);
  border-radius: 28px;
  box-shadow: var(--svc-shadow-sidebar);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding: 24px 22px 16px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.svc-sidebar__title {
  font-family: 'Golos Text', sans-serif;
  font-weight: 600;
  font-size: 18px;
  letter-spacing: -0.18px;
  color: var(--svc-text);
  padding-bottom: 14px;
}

.svc-sidebar__group { display: flex; flex-direction: column; gap: 2px; }
.svc-sidebar__group + .svc-sidebar__group { margin-top: 6px; }

.svc-sidebar__group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  font-family: 'Golos Text', sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-align: left;
  background: var(--svc-surface-item);
  color: var(--svc-green-dark);
  cursor: pointer;
  transition: transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease, box-shadow .2s ease;
}
.svc-sidebar__group-head:hover { background: #eff6ef; }
.svc-sidebar__group-head[href] { text-decoration: none; }
.svc-sidebar__group-head--active {
  background: rgba(0, 175, 87, 0.08);
  color: var(--svc-green-dark);
  box-shadow: none;
}
.svc-sidebar__group-head--active .svc-sidebar__toggle {
  color: var(--svc-green);
}

.svc-sidebar__group-head--collapsed {
  background: transparent;
  color: var(--svc-text);
  font-weight: 500;
}
.svc-sidebar__group-head--collapsed .svc-sidebar__toggle {
  color: var(--svc-text-soft);
  font-weight: 600;
  font-size: 14px;
}
.svc-sidebar__group-head--collapsed:hover { background: #f3f6f3; }

.svc-sidebar__toggle {
  color: var(--svc-green);
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
}

.svc-sidebar__sub {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.svc-sidebar__sub-item { }

.svc-sidebar__sub-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px 10px 28px;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 400;
  color: var(--svc-text-muted);
  transition: transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease, box-shadow .2s ease;
}
.svc-sidebar__sub-link:hover {
  background: #f3f6f3;
  color: var(--svc-text);
}

.svc-sidebar__count {
  font-size: 13px;
  color: var(--svc-text-dim);
  margin-left: 10px;
}

.svc-sidebar__sub-item--active .svc-sidebar__sub-link {
  background: var(--svc-surface-item-active);
  color: #fff;
  font-weight: 600;
  box-shadow: var(--svc-shadow-active);
}
.svc-sidebar__sub-item--active .svc-sidebar__count {
  color: rgba(255, 255, 255, 0.95);
  font-size: 13px;
}

.svc-sidebar__sticky {
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: sticky;
  top: var(--svc-sidebar-sticky-top, 128px);
  z-index: 3;
  transition: top 0.22s ease;
}

.svc-sidebar__workers,
.svc-sidebar__info-card,
.svc-sidebar__accreditation {
  background: rgba(255, 255, 255, 0.65);
  border: 1px solid rgba(255, 255, 255, 0.85);
  border-radius: 22px;
  box-shadow: 0 4px 14px rgba(20, 26, 31, 0.03);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.svc-sidebar__workers {
  min-height: 90px;
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
}

.svc-sidebar__workers-live {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: 'Golos Text', sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.01em;
  color: #73808F;
}

.svc-sidebar__workers-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #00AF57;
  flex: 0 0 auto;
}

.svc-sidebar__workers-row {
  display: flex;
  align-items: baseline;
  gap: 6px;
}

.svc-sidebar__workers-value {
  font-family: 'Golos Text', sans-serif;
  font-size: 24px;
  line-height: 1.1;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: #16212E;
}

.svc-sidebar__workers-label {
  font-family: 'Golos Text', sans-serif;
  font-size: 14px;
  line-height: 1.2;
  font-weight: 400;
  color: #73808F;
}

.svc-sidebar__expert {
  background: rgba(28, 36, 31, 0.78);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 22px;
  box-shadow: 0 4px 14px rgba(20, 26, 31, 0.05);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.svc-sidebar__expert-head {
  display: flex;
  align-items: center;
  gap: 12px;
}

.svc-sidebar__avatars {
  display: flex;
  align-items: center;
  padding-right: 10px;
  flex: 0 0 auto;
}

.svc-sidebar__avatar,
.svc-sidebar__avatar-more {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  flex: 0 0 auto;
}

.svc-sidebar__avatar {
  display: block;
  margin-right: -10px;
  object-fit: cover;
}

.svc-sidebar__avatar-more {
  margin-right: -10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 3px solid #4B534E;
  background: rgba(255, 255, 255, 0.1);
  font-family: 'Golos Text', sans-serif;
  font-size: 11px;
  line-height: 1;
  font-weight: 600;
  color: #fff;
}

.svc-sidebar__expert-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.svc-sidebar__expert-title {
  margin: 0;
  font-family: 'Golos Text', sans-serif;
  font-size: 14px;
  line-height: 1.2;
  font-weight: 600;
  color: #fff;
}

.svc-sidebar__expert-status {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: 'Golos Text', sans-serif;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 400;
  color: #ADBDB2;
}

.svc-sidebar__expert-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #34D16F;
  flex: 0 0 auto;
}

.svc-sidebar__expert-text {
  margin: 0;
  font-family: 'Golos Text', sans-serif;
  font-size: 14px;
  line-height: 1.35;
  font-weight: 400;
  color: #D4DBD6;
}

.svc-sidebar__expert-text strong {
  font-weight: 600;
  color: #fff;
}

.svc-sidebar__expert-btn {
  width: 100%;
  height: 48px;
  border: 0;
  border-radius: 14px;
  background: #00AF57;
  box-shadow: 0 4px 14px rgba(0, 175, 87, 0.15);
  font-family: 'Golos Text', sans-serif;
  font-size: 15px;
  line-height: 1;
  font-weight: 600;
  color: #fff;
  cursor: pointer;
}

.svc-sidebar__expert-btn:hover {
  transform: scale(var(--svc-hover-scale-ui));
  box-shadow: 0 10px 22px rgba(0, 175, 87, 0.22);
}

.svc-sidebar__expert-note {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: 'Golos Text', sans-serif;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 400;
  color: #ADBDB2;
}

.svc-sidebar__expert-note img,
.svc-sidebar__info-check img {
  width: 14px;
  height: 14px;
  display: block;
  flex: 0 0 auto;
}

.svc-sidebar__info-card {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.svc-sidebar__info-title,
.svc-sidebar__accreditation-title {
  margin: 0;
  font-family: 'Golos Text', sans-serif;
  line-height: 1.2;
  font-weight: 600;
  color: #222522;
}

.svc-sidebar__info-title {
  font-size: 16px;
}

.svc-sidebar__info-text {
  margin: 0;
  font-family: 'Golos Text', sans-serif;
  font-size: 13px;
  line-height: 1.4;
  font-weight: 400;
  color: #6B706E;
}

.svc-sidebar__info-check {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: 'Golos Text', sans-serif;
  font-size: 13px;
  line-height: 1.2;
  font-weight: 500;
  color: #00AF57;
}

.svc-sidebar__accreditation {
  padding: 20px;
  display: flex;
  align-items: center;
}

.svc-sidebar__accreditation-copy {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

.svc-sidebar__accreditation-title {
  font-size: 14px;
}

.svc-sidebar__accreditation-text {
  margin: 0;
  font-family: 'Golos Text', sans-serif;
  font-size: 12px;
  line-height: 1.4;
  font-weight: 400;
  color: #6B706E;
}

/* =====================================================================
   Trust Row — widgets under hero card
   Figma: 566:219 — RD Trust Row
   ===================================================================== */

.svc-trustrow {
  display: grid;
  grid-template-columns: 504fr 456fr;
  column-gap: 16px;
  row-gap: 13px;
  width: 100%;
}

.svc-trust-widget {
  box-sizing: border-box;
  min-width: 0;
  height: 121px;
  padding: 20px 24px;
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
}
.svc-trust-widget--clients {
  background: #fbfbf9;
}
.svc-trust-widget--ratings {
  background: #fff;
  border: 1px solid #ebedf2;
}

.svc-reviews-link {
  grid-column: 2;
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  color: #1c73f2;
  text-decoration: none;
  font-family: 'Golos Text', sans-serif;
  font-size: 15px;
  line-height: 1.2;
  font-weight: 500;
  letter-spacing: -0.01em;
  transform-origin: right center;
}

.svc-reviews-link svg {
  display: block;
  flex: 0 0 auto;
}

.svc-trust-widget__head {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.svc-trust-widget__title {
  font-family: 'Golos Text', sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.02em;
  color: #0f172a;
  white-space: nowrap;
}

.svc-trust-widget__dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: #c9cfd9;
  flex-shrink: 0;
}

.svc-trust-widget__meta {
  font-size: 13px;
  color: #6b788c;
  white-space: nowrap;
}

/* ---- clients: logos row ---- */

.svc-trust-widget__logos {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  overflow: hidden;
  min-width: 0;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 10%, #000 90%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, #000 10%, #000 90%, transparent 100%);
}

.svc-trust-widget__logos-lanes {
  display: flex;
  align-items: center;
  width: max-content;
}

.svc-trust-widget__logos-track {
  display: flex;
  align-items: center;
  width: max-content;
  animation: svc-trust-logos-scroll 21s linear infinite;
}

.svc-trust-widget__logos-track--reverse {
  display: none;
  animation-name: svc-trust-logos-scroll-reverse;
}

.svc-trust-widget__logos-set {
  display: flex;
  align-items: center;
  gap: 18px;
  padding-right: 18px;
  flex-shrink: 0;
}

.svc-trust-widget__logos img {
  height: 32px;
  width: 84px;
  max-width: 100%;
  object-fit: contain;
  opacity: .6;
  filter: grayscale(100%);
  transition: opacity .15s ease, filter .15s ease;
}
.svc-trust-widget__logos img:hover {
  opacity: 1;
  filter: none;
}

@keyframes svc-trust-logos-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes svc-trust-logos-scroll-reverse {
  0% { transform: translateX(-50%); }
  100% { transform: translateX(0); }
}

@media (prefers-reduced-motion: reduce) {
  .svc-trust-widget__logos-track {
    animation: none;
  }
}

/* ---- ratings: 3 cards ---- */

.svc-ratings {
  flex: 1 1 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  min-width: 0;
}

.svc-rating {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: #fbfbf9;
  border: 1px solid #ebedf2;
  border-radius: 12px;
  min-width: 0;
  overflow: hidden;
}

.svc-rating__logo {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  border-radius: 6px;
  overflow: hidden;
}
.svc-rating__logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.svc-rating__body {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  line-height: 1;
}

.svc-rating__source {
  font-family: 'Golos Text', sans-serif;
  font-weight: 500;
  font-size: 12px;
  color: #6b788c;
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.svc-rating__score {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 2px;
  font-family: 'Golos Text', sans-serif;
  font-weight: 600;
  font-size: 16px;
  color: #0f172a;
  line-height: 1;
}

/* =====================================================================
   Positions & tariffs
   Figma: 500:210 — Positions + Sticky Section
   ===================================================================== */

.svc-positions {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.svc-positions__header {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.svc-positions__title {
  font-family: 'Golos Text', sans-serif;
  font-size: 34px;
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.015em;
  color: var(--svc-text);
  margin: 0;
}

.svc-positions__subtitle {
  font-size: 15px;
  color: var(--svc-text-soft);
  margin: 0;
}

.svc-positions__subtitle-text--mobile {
  display: none;
}

.svc-positions__card {
  background: #fff;
  border: 1px solid #e9edea;
  border-radius: 24px;
  box-shadow: 0 10px 30px rgba(26, 38, 31, 0.05);
  overflow: hidden;
}

/* ---- toolbar ---- */

.svc-positions__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 22px 20px 22px 28px;
  border-bottom: 1px solid #e9edea;
}

.svc-positions__heading {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.svc-positions__heading-text {
  font-family: 'Golos Text', sans-serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--svc-text);
}

.svc-positions__count {
  display: inline-flex;
  align-items: center;
  padding: 5px 10px;
  border-radius: 999px;
  background: #e8f5ee;
  color: var(--svc-green);
  font-size: 13px;
  font-weight: 600;
  line-height: 1;
}

.svc-positions__search {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: 300px;
  height: 40px;
  padding: 0 16px;
  background: #f6f8f6;
  border-radius: 12px;
  color: var(--svc-text-soft);
}
.svc-positions__search svg { color: var(--svc-text-soft); flex-shrink: 0; }
.svc-positions__search input {
  flex: 1;
  min-width: 0;
  background: transparent;
  border: none;
  outline: none;
  font-family: 'Golos Text', sans-serif;
  font-size: 14px;
  color: var(--svc-text);
}
.svc-positions__search input::placeholder { color: var(--svc-text-soft); }

.svc-position[hidden] {
  display: none !important;
}

.svc-positions__empty {
  padding: 28px;
  font-family: 'Golos Text', sans-serif;
  font-size: 15px;
  line-height: 1.45;
  color: var(--svc-text-soft);
  text-align: center;
  border-top: 1px solid #e9edea;
}

/* ---- list rows ---- */

.svc-positions__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.svc-position {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 16px 22px;
  border-bottom: 1px solid #e9edea;
  transition: background-color .15s ease;
}
.svc-position:last-child { border-bottom: none; }
.svc-position:hover { background: #e8f5ee; }

.svc-position__mainlink {
  display: flex;
  align-items: center;
  gap: 18px;
  flex: 1 1 0;
  min-width: 0;
  color: inherit;
  text-decoration: none;
}

.svc-position__mainlink:hover .svc-position__name {
  color: var(--svc-green-dark);
}

.svc-position__thumb {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  border-radius: 14px;
  overflow: hidden;
  background: #eef2ee;
}
.svc-position__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.svc-position__body {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.svc-position__name {
  font-family: 'Golos Text', sans-serif;
  font-weight: 600;
  font-size: 17px;
  line-height: 1.25;
  color: var(--svc-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.svc-position__price {
  font-weight: 500;
  font-size: 14px;
  color: var(--svc-text-soft);
}

.svc-position__cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.svc-position__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 37px;
  padding: 0 16px;
  border-radius: 11px;
  border: 1px solid var(--svc-green);
  background: transparent;
  color: var(--svc-green);
  font-family: 'Golos Text', sans-serif;
  font-weight: 500;
  font-size: 14px;
  line-height: 1;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .2s ease, background-color .15s ease, color .15s ease, border-color .15s ease;
  white-space: nowrap;
}
.svc-position__btn:hover {
  background: var(--svc-green);
  color: #fff;
  transform: scale(1.045);
  box-shadow: 0 8px 18px rgba(0, 175, 87, 0.18);
}
.svc-position__btn:active { transform: scale(1.015); }

.svc-position__chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  color: var(--svc-text-disabled);
  transition: color .15s ease, transform .15s ease;
}
.svc-position__chevron:hover {
  color: var(--svc-text);
  transform: translateX(2px) scale(var(--svc-hover-scale-ui));
}

/* ---- footer chips ---- */

.svc-positions__footer {
  padding: 22px 28px 26px;
  border-top: 1px solid #e9edea;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.svc-positions__footer-label {
  font-weight: 500;
  font-size: 15px;
  color: var(--svc-text-soft);
}

.svc-positions__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.svc-tag {
  display: inline-flex;
  align-items: center;
  padding: 10px 16px;
  background: #f6f8f6;
  border-radius: 999px;
  font-family: 'Golos Text', sans-serif;
  font-weight: 500;
  font-size: 15px;
  line-height: 1;
  color: var(--svc-text);
  cursor: pointer;
  transition: transform .15s ease, background-color .15s ease, color .15s ease, border-color .15s ease, box-shadow .2s ease;
}
.svc-tag:hover {
  background: #eef3ee;
  transform: scale(var(--svc-hover-scale-ui));
}

/* =====================================================================
   How we work (process)
   Figma: 511:* — title + Maria card + 4 step cards + soft glows
   ===================================================================== */

.svc-process {
  position: relative;
  padding: 72px 0 48px;
}

/* isolated halo-glows on transparent background */
.svc-process__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: visible;
}
.svc-process__glow {
  position: absolute;
  width: 420px;
  height: 420px;
  border-radius: 50%;
  filter: blur(110px);
  opacity: .55;
}
.svc-process__glow--1 { left: -8%;   top: -10%;                 background: #b8e8cf; }
.svc-process__glow--2 { left: 38%;   bottom: -20%;              background: #c7e8ef; }
.svc-process__glow--3 { right: -10%; top: 30%;                  background: #cfe8c0; }

/* grid: 3 equal columns × (title + 2 card rows) */
.svc-process__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-rows: auto 200px 200px;
  column-gap: 24px;
  row-gap: 24px;
}

/* -------- Maria card (col 1, spans all 3 rows) -------- */
.svc-maria {
  grid-column: 1;
  grid-row: 1 / -1;
  position: relative;
  align-self: stretch;
  margin-top: 140px;
  background: #fff;
  border-radius: 28px;
  box-shadow: 0 10px 30px rgba(20, 26, 31, 0.06);
  padding: 110px 28px 88px;
}

.svc-maria__photo {
  position: absolute;
  top: -140px;
  left: 50%;
  transform: translateX(-50%);
  width: 208px;
  height: 208px;
  border-radius: 50%;
  overflow: hidden;
  background: #eef2ee;
  z-index: 1;
}
.svc-maria__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.svc-maria__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.svc-maria__name {
  font-family: 'Golos Text', sans-serif;
  font-weight: 400;
  font-size: 16px;
  color: #5c5c5c;
  line-height: 1.4;
  margin-bottom: 4px;
}

.svc-maria__role {
  font-family: 'Golos Text', sans-serif;
  font-weight: 500;
  font-size: 18px;
  color: #2b2b2b;
  line-height: 1.3;
}

.svc-maria__quote {
  margin: 20px 0 0;
  font-family: 'Golos Text', sans-serif;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.45;
  color: #5c5c5c;
}
.svc-maria__quote strong {
  color: var(--svc-green);
  font-weight: 600;
}

/* decorative "99" quote mark (Figma SVG 511:226) */
.svc-maria__deco {
  position: absolute;
  right: 28px;
  bottom: 24px;
  width: 54px;
  height: auto;
  pointer-events: none;
  user-select: none;
}

/* -------- Title row (cols 2-3, row 1) -------- */
.svc-process__head {
  grid-column: 2 / span 2;
  grid-row: 1;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  align-self: center;
  padding-left: 4px;
}
.svc-process__head-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--svc-green);
  flex-shrink: 0;
}
.svc-process__title {
  font-family: 'Golos Text', sans-serif;
  font-weight: 600;
  font-size: 36px;
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: #2b2b2b;
  margin: 0;
}

/* -------- Step cards -------- */
.svc-step {
  position: relative;
  border-radius: 28px;
  padding: 28px 28px 28px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
  transition: transform .2s ease, box-shadow .2s ease;
}

.svc-step--light {
  background: #fff;
  box-shadow: 0 4px 14px rgba(20, 26, 31, 0.06);
}
.svc-step--dark {
  background: #0B2E27;
  color: #fff;
}
.svc-step--green {
  background: #00AF57;
  color: #fff;
}
.svc-step:hover {
  transform: translateY(-2px);
}

.svc-step__title {
  font-family: 'Golos Text', sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 1.2;
  color: #2b2b2b;
  margin: 0;
}
.svc-step--dark .svc-step__title,
.svc-step--green .svc-step__title { color: #fff; }

.svc-step__text {
  margin: 0;
  font-family: 'Golos Text', sans-serif;
  font-weight: 400;
  font-size: 15px;
  line-height: 1.4;
  color: rgba(92, 92, 92, 0.85);
}
.svc-step--dark .svc-step__text,
.svc-step--green .svc-step__text { color: rgba(255, 255, 255, 0.92); }

/* positions: 2×2 grid in cols 2-3, rows 2-3 */
.svc-step--1 { grid-column: 2; grid-row: 2; }
.svc-step--2 { grid-column: 3; grid-row: 2; }
.svc-step--4 { grid-column: 2; grid-row: 3; }
.svc-step--3 { grid-column: 3; grid-row: 3; }

/* -------- Decorative arrows (Figma SVGs) -------- */
.svc-process__arrows {
  grid-column: 2 / span 2;
  grid-row: 2 / span 2;
  position: relative;
  pointer-events: none;
  z-index: 2;
  align-self: stretch;
  justify-self: stretch;
  overflow: visible;
}
.svc-process__arrows > * {
  position: absolute;
}

/* Figma card grid: cols 2-3 total = 2×col + gap = 642px in 975-wide section
   Inside .svc-process__arrows container (which is the step-cards grid area,
   size 642×424 in Figma), position each arrow by its Figma offsets. */

/* Arrow 1→2 (Vector 40): Figma x=878.5..1035 y=2832..2882. Relative 265.5..422 × 14..64 */
.svc-arrow--12 {
  left: 41.4%;
  top: 3.3%;
  width: 24.4%;
  height: 11.8%;
}

/* Arrow 2→3 (Vector 41): Figma x=1223..1317 y=2857..3028. Relative 610..704 × 39..210. Right-overflow */
.svc-arrow--23 {
  left: 95%;
  top: 9.2%;
  width: 14.7%;
  height: 40.4%;
}

/* Arrow 3→4 (Vector 42): Figma x=863..1024 y=3209..3280. Relative 250..411 × 391..462. Bottom-overflow */
.svc-arrow--34 {
  left: 38.9%;
  top: 92.2%;
  width: 25.1%;
  height: 16.7%;
}


/* ======================================================================
   Geography section — «География наших проектов»
   ====================================================================== */

.svc-geo__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 40px;
  margin-bottom: 28px;
  padding: 0 4px;
}

.svc-geo__title {
  margin: 0;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 600;
  font-size: 48px;
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: #2B2B2B;
  display: flex;
  flex-direction: column;
  gap: 2px;
  max-width: 560px;
}

.svc-geo__title-accent {
  color: #00AF57;
}

.svc-geo__lead {
  margin: 10px 0 0;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.4;
  color: #5C5C5C;
  max-width: 330px;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.svc-geo__lead-accent {
  color: #00AF57;
}

.svc-geo__lead strong {
  font-weight: 600;
  color: #2B2B2B;
}

.svc-geo__map {
  position: relative;
  width: 100%;
  display: block;
  padding: 12px 0 0;
}

.svc-geo__map img {
  width: 100%;
  height: auto;
  display: block;
}

.svc-geo__map-object {
  width: 100%;
  height: auto;
  aspect-ratio: 954 / 492;
  display: block;
  border: 0;
}

.svc-geo__cities {
  list-style: none;
  margin: 24px 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.svc-geo__city {
  padding: 8px 16px;
  background: #ffffff;
  border-radius: 999px;
  box-shadow: 0 4px 14px rgba(20, 26, 31, 0.08), 0 1px 2px rgba(20, 26, 31, 0.06);
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.2;
  color: #2B2B2B;
  white-space: nowrap;
}


/* ======================================================================
   Recommendation letters — «Рекомендательные письма»
   ====================================================================== */

.svc-letters__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 32px;
  margin-bottom: 28px;
}

.svc-letters__head-left {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
}

.svc-letters__title {
  margin: 0;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 600;
  font-size: 40px;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: #16212E;
}

.svc-letters__stat {
  margin: 0;
  padding-left: 58px;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.4;
  color: #73808F;
}

.svc-letters__stat-pct {
  font-weight: 600;
  color: #3CBB72;
}

.svc-letters__pagination {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
  padding-top: 10px;
}

.svc-letters__thumbs {
  display: flex;
  align-items: center;
  gap: 4px;
}

.svc-letters__thumb {
  width: 10px;
  height: 14px;
  border-radius: 1.5px;
  background: #F7FAFA;
  border: 1px solid #D1D9DE;
  box-sizing: border-box;
  cursor: pointer;
}

.svc-letters__thumb--on {
  background: #16212E;
  border-color: #16212E;
}

.svc-letters__arrows {
  display: flex;
  align-items: center;
  gap: 8px;
}

.svc-letters__arrow {
  width: 40px;
  height: 40px;
  border-radius: 20px;
  border: 1px solid #E7EBEC;
  background: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: transform .15s ease, opacity .15s ease, background .15s ease, box-shadow .2s ease;
}

.svc-letters__arrow--prev {
  opacity: 0.45;
}

.svc-letters__arrow:disabled {
  opacity: 0.45;
  cursor: default;
}

.svc-letters__arrow:disabled:hover {
  transform: none;
  background: #ffffff;
}

.svc-letters__arrow:hover {
  background: #F7FAFA;
  transform: scale(var(--svc-hover-scale-ui));
}

.svc-letters__row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}

.svc-letter {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}

.svc-letter__top {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.svc-letter__logo {
  height: 26px;
  width: auto;
  max-width: 96px;
  object-fit: contain;
  flex-shrink: 0;
  display: block;
}

.svc-letter__logo--square {
  width: 26px;
  max-width: 26px;
}

.svc-letter__name {
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 500;
  font-size: 13px;
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: #16212E;
  min-width: 0;
}

.svc-letter__doc {
  width: 204px;
  max-width: 100%;
  height: 260px;
  border: 1px solid #E7EBEC;
  border-radius: 6px;
  box-shadow: 0 3px 8px rgba(23, 38, 56, 0.08);
  overflow: hidden;
  background: #fff;
}

.svc-letter__doc img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}


/* ======================================================================
   FAQ — «Частые вопросы»
   ====================================================================== */

.svc-faq__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 36px;
}

.svc-faq__title {
  margin: 0;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 600;
  font-size: 40px;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: #0F172A;
}

.svc-faq__contact {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 500;
  font-size: 15px;
  line-height: 1.2;
  color: #16A560;
  white-space: nowrap;
  text-decoration: none;
  transform-origin: right center;
  transition: transform .15s ease, color .15s ease;
}

.svc-faq__contact-arrow {
  display: inline-block;
  transform: translateY(-1px);
}

.svc-faq__heading {
  margin: 0;
}

.svc-faq__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.svc-faq__item {
  min-height: 80px;
  padding: 22px 24px 22px 28px;
  background: #FFFFFF;
  border: 1px solid #EBEDF0;
  border-radius: 20px;
  box-shadow: 0 4px 14px rgba(20, 26, 31, 0.03);
}

.svc-faq__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  text-align: left;
  cursor: pointer;
  font: inherit;
}

.svc-faq__question-text {
  margin: 0;
  flex: 1 1 auto;
  min-width: 0;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 500;
  font-size: 18px;
  line-height: 1.35;
  letter-spacing: -0.01em;
  color: #0F172A;
}

.svc-faq__question-text--open {
  font-weight: 600;
}

.svc-faq__toggle {
  width: 36px;
  height: 36px;
  border-radius: 18px;
  background: #F5F7FA;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  transition: transform .15s ease, background-color .15s ease;
}

.svc-faq__toggle img {
  width: 14px;
  height: 14px;
  display: block;
}

.svc-faq__toggle--open {
  background: #16A560;
}

.svc-faq__question:hover .svc-faq__toggle {
  transform: scale(var(--svc-hover-scale-ui));
}

.svc-faq__answer {
  display: grid;
  grid-template-rows: 0fr;
  margin-top: 0;
  opacity: 0;
  transition: grid-template-rows .28s cubic-bezier(0.22, 1, 0.36, 1), margin-top .28s cubic-bezier(0.22, 1, 0.36, 1), opacity .2s ease;
}

.svc-faq__item--open .svc-faq__answer {
  grid-template-rows: 1fr;
  margin-top: 16px;
  opacity: 1;
}

.svc-faq__answer-inner {
  min-height: 0;
  overflow: hidden;
}

.svc-faq__answer-copy {
  margin: 0;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: -0.005em;
  color: #576375;
}


/* ======================================================================
   Final CTA
   ====================================================================== */

.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;
}

.svc-final-cta__glow {
  position: absolute;
  left: -180px;
  top: -180px;
  width: 500px;
  height: 500px;
  z-index: 0;
  pointer-events: none;
}

.svc-final-cta__glow img {
  width: 100%;
  height: 100%;
  display: block;
}

.svc-final-cta__visual {
  position: absolute;
  top: 0;
  right: 0;
  width: 460px;
  height: 100%;
  z-index: 1;
}

.svc-final-cta__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.svc-final-cta__fade {
  position: absolute;
  top: 0;
  left: 516px;
  width: 460px;
  height: 100%;
  background: linear-gradient(90deg, #0E1820 0%, rgba(14, 24, 32, 0.25) 35%, rgba(14, 24, 32, 0) 100%);
  z-index: 2;
  pointer-events: none;
}

.svc-final-cta__content {
  position: relative;
  z-index: 3;
  width: 560px;
  height: 100%;
  padding: 52px 40px 44px 52px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 22px;
}

.svc-final-cta__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border: 1px solid rgba(22, 165, 96, 0.4);
  border-radius: 999px;
  background: rgba(22, 165, 96, 0.15);
  backdrop-filter: blur(12px);
}

.svc-final-cta__badge-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #85DBA3;
  flex: 0 0 auto;
}

.svc-final-cta__badge span:last-child {
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 500;
  font-size: 13px;
  line-height: 1.2;
  color: #85DBA3;
}

.svc-final-cta__title {
  margin: 0;
  max-width: 460px;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 600;
  font-size: 34px;
  line-height: 1.12;
  letter-spacing: -0.02em;
  color: #FFFFFF;
}

.svc-final-cta__lead {
  margin: 0;
  max-width: 430px;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 400;
  font-size: 15px;
  line-height: 1.5;
  color: #ADBAC7;
}

.svc-final-cta__fields {
  width: 100%;
  display: flex;
  gap: 12px;
}

.svc-final-cta__field {
  flex: 1 1 0;
  min-width: 0;
}

.svc-final-cta__input {
  width: 100%;
  padding: 16px 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(12px);
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 400;
  font-size: 15px;
  line-height: 1.2;
  color: #FFFFFF;
  outline: none;
  box-shadow: none;
}

.svc-final-cta__input::placeholder {
  color: #99A8B8;
  opacity: 1;
}

.svc-final-cta__button {
  width: 100%;
  padding: 18px 24px;
  border: 0;
  border-radius: 14px;
  background: #16A560;
  box-shadow: 0 6px 20px rgba(22, 165, 96, 0.25);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  cursor: pointer;
}

.svc-final-cta__button:hover {
  transform: scale(var(--svc-hover-scale-ui));
  box-shadow: 0 10px 24px rgba(22, 165, 96, 0.32);
}

.svc-final-cta__button span {
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.2;
  color: #FFFFFF;
}

.svc-final-cta__button img {
  width: 18px;
  height: 18px;
  display: block;
}

.svc-final-cta__note {
  margin: 0;
  width: 100%;
  font-family: 'Golos Text', 'Golos', system-ui, sans-serif;
  font-weight: 400;
  font-size: 12px;
  line-height: 1.5;
  color: #8594A6;
}


/* ------------------------- Narrow desktop ------------------------- */

@media (max-width: 1200px) {
  .svc-hero__grid { grid-template-columns: minmax(0, 1fr) 320px; }
  .svc-hero-card__title { font-size: 36px; }
  .svc-geo__title { font-size: 40px; }
  .svc-letters__title { font-size: 34px; }
  .svc-letters__stat { padding-left: 0; }
  .svc-faq__title { font-size: 34px; }
  .svc-faq__head { align-items: flex-start; }
}

/* ======================================================================
   MOBILE / NARROW layout (≤ 900px) — single column, no sidebar
   ====================================================================== */

@media (max-width: 900px) {
  html,
  body {
    overflow-x: clip;
  }

  /* Sidebar is only a desktop construct — always hide on narrow screens */
  .svc-sidebar { display: none !important; }

  /* Full-bleed single column, stack everything by source order */
  .svc-hero__container { padding: 0 20px; }
  .svc-hero__grid {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto;
    column-gap: 0;
    row-gap: 32px;
  }
  .svc-hero-card,
  .svc-trustrow,
  .svc-positions,
  .svc-seo-text,
  .svc-process,
  .svc-geo,
  .svc-letters,
  .svc-faq,
  .svc-final-cta {
    grid-column: 1;
    width: 100%;
    max-width: 100%;
    margin-top: 0;
  }

  .svc-seo-text__inner h2 {
    margin-bottom: 18px;
    font-size: 26px;
    line-height: 1.16;
  }

  .svc-seo-text__inner p {
    font-size: 15px;
    line-height: 1.58;
  }

  /* ---- Trust row ---- */
  .svc-trustrow {
    grid-template-columns: minmax(0, 1fr);
    row-gap: 12px;
  }
  .svc-trust-widget { height: auto; }
  .svc-ratings { gap: 8px; }
  .svc-trust-widget__logos-lanes {
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 100%;
  }
  .svc-trust-widget__logos-track--reverse {
    display: flex;
  }
  .svc-reviews-link {
    grid-column: 1;
    justify-self: center;
  }

  /* ---- Positions ---- */
  .svc-positions__toolbar {
    display: block;
    padding: 0;
    border-bottom: 0;
  }
  .svc-positions__heading { display: none; }
  .svc-positions__search { width: 100%; }
  .svc-positions__card {
    display: flex;
    flex-direction: column;
    gap: 20px;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    overflow: visible;
  }
  .svc-positions__list {
    background: #fff;
    border: 1px solid #e9edea;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(26, 38, 31, 0.05);
  }
  .svc-position {
    gap: 12px;
    padding: 14px 16px;
    flex-wrap: nowrap;
  }
  .svc-position__name {
    white-space: normal;
    font-size: 15px;
    line-height: 1.3;
  }
  .svc-position__cta { gap: 0; }
  .svc-position__btn { display: none; }
  .svc-positions__footer { padding: 20px 18px 22px; }

  /* ---- Process / Maria + steps ---- */
  .svc-process {
    padding: 56px 0 24px;
    overflow: clip;
  }
  .svc-process__bg { overflow: hidden; }
  .svc-process__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: auto 218px 99px 99px 154px;
    row-gap: 20px;
    column-gap: 12px;
  }
  .svc-maria {
    grid-column: 1 / -1;
    grid-row: 2;
    margin-top: 0;
    min-height: 218px;
    padding: 24px 24px 42px;
  }
  .svc-maria__photo {
    top: 24px;
    left: 24px;
    transform: none;
    width: 88px;
    height: 88px;
  }
  .svc-maria__body {
    min-height: 88px;
    padding-left: 104px;
  }
  .svc-maria__quote {
    margin-top: 18px;
    margin-left: -104px;
  }
  .svc-maria__deco { right: 24px; bottom: 18px; width: 40px; }
  .svc-process__head {
    grid-column: 1 / -1;
    grid-row: 1;
    padding-left: 0;
  }
  .svc-process__title { font-size: 28px; }
  .svc-step {
    padding: 18px;
    border-radius: 24px;
  }
  .svc-step--1 {
    grid-column: 1 / -1;
    grid-row: 3;
    min-height: 99px;
  }
  .svc-step--2 {
    grid-column: 1 / -1;
    grid-row: 4;
    min-height: 99px;
  }
  .svc-step--4 {
    grid-column: 1;
    grid-row: 5;
    min-height: 154px;
  }
  .svc-step--3 {
    grid-column: 2;
    grid-row: 5;
    min-height: 135px;
  }
  .svc-process__arrows { display: none; }

  /* ---- Geography ---- */
  .svc-geo__head {
    flex-direction: column;
    gap: 10px;
    padding: 0;
    margin-bottom: 20px;
  }
  .svc-geo__title { font-size: 34px; max-width: none; }
  .svc-geo__lead { margin-top: 0; max-width: none; }
  .svc-geo__cities { justify-content: flex-start; gap: 8px; margin-top: 16px; }

  /* ---- Recommendations / letters ---- */
  .svc-letters__head {
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 20px;
  }
  .svc-letters__pagination {
    width: 100%;
    justify-content: space-between;
    padding-top: 0;
  }
  .svc-letters__row {
    grid-template-columns: none;
    display: flex;
    gap: 16px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 4px 0 10px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  .svc-letters { overflow-x: clip; }
  .svc-letter {
    flex: 0 0 auto;
    width: 172px;
    scroll-snap-align: start;
  }
  .svc-letter__doc { width: 172px; height: 219px; }

  /* ---- FAQ ---- */
  .svc-faq__head {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 20px;
  }
  .svc-faq__title { font-size: 28px; }
  .svc-faq__item { padding: 18px 18px 18px 20px; }
  .svc-faq__question-text { font-size: 16px; }

  /* ---- Final CTA — image on top, content stacked ---- */
  .svc-final-cta {
    height: auto;
    border-radius: 24px;
  }
  .svc-final-cta__glow { display: none; }
  .svc-final-cta__visual {
    position: relative;
    right: auto;
    top: auto;
    width: 100%;
    height: 200px;
  }
  .svc-final-cta__visual img { object-position: center; }
  .svc-final-cta__fade {
    left: 0;
    top: auto;
    bottom: 0;
    width: 100%;
    height: 96px;
    background: linear-gradient(180deg, rgba(14, 24, 32, 0) 0%, #0E1820 85%);
  }
  .svc-final-cta__content {
    width: 100%;
    padding: 24px 22px 28px;
    gap: 16px;
  }
  .svc-final-cta__title { font-size: 26px; max-width: none; }
  .svc-final-cta__lead { max-width: none; }
  .svc-final-cta__fields { flex-direction: column; gap: 10px; }
}

/* ======================================================================
   TABLET layout (601–1200px) — desktop composition scaled, no sidebar
   ====================================================================== */

@media (min-width: 601px) and (max-width: 1200px) {
  html {
    zoom: 1 !important;
  }

  body.services-page {
    --svc-tablet-scale: 1;
  }

  body.services-page .main-content {
    zoom: 1 !important;
  }

  html,
  body {
    overflow-x: clip;
  }

  .svc-sidebar {
    display: none !important;
  }

  .svc-hero {
    padding-top: calc(140px * var(--svc-tablet-scale));
    padding-bottom: calc(80px * var(--svc-tablet-scale));
    overflow: clip;
  }

  .svc-hero__container {
    max-width: none;
    padding: 0 16px;
  }

  .svc-breadcrumbs {
    display: flex;
    width: 976px;
    max-width: none;
    margin: 0 auto 34px;
    font-size: 14px;
    zoom: var(--svc-tablet-scale);
  }

  .svc-hero__grid {
    width: 976px;
    max-width: none;
    margin: 0 auto;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto auto auto auto auto auto auto auto auto;
    column-gap: 0;
    row-gap: 16px;
    align-items: start;
    zoom: var(--svc-tablet-scale);
  }

  .svc-hero-card,
  .svc-trustrow,
  .svc-positions,
  .svc-seo-text,
  .svc-process,
  .svc-geo,
  .svc-letters,
  .svc-faq,
  .svc-final-cta {
    grid-column: 1;
    width: 100%;
    max-width: 100%;
  }

  .svc-hero-card {
    grid-row: 1;
    margin: 0;
  }

  .svc-hero-card__title {
    font-size: 42px;
  }

  .svc-trustrow {
    grid-row: 2;
    display: grid;
    grid-template-columns: 504fr 456fr;
    column-gap: 16px;
    row-gap: 13px;
    margin-top: 64px;
    padding: 0;
  }

  .svc-trust-widget {
    height: 121px;
    padding: 20px 24px;
    border-radius: 20px;
  }

  .svc-trust-widget__logos-lanes {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0;
    width: max-content;
  }

  .svc-trust-widget__logos-track--reverse {
    display: none;
  }

  .svc-ratings {
    gap: 10px;
  }

  .svc-reviews-link {
    grid-column: 2;
    justify-self: end;
  }

  .svc-positions {
    grid-row: 3;
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-top: 72px;
    padding: 0;
  }

  .svc-positions__title {
    font-size: 34px;
  }

  .svc-positions__subtitle {
    font-size: 15px;
  }

  .svc-positions__subtitle-text--desktop {
    display: inline;
  }

  .svc-positions__subtitle-text--mobile {
    display: none;
  }

  .svc-positions__card {
    display: block;
    background: #fff;
    border: 1px solid #e9edea;
    border-radius: 24px;
    box-shadow: 0 10px 30px rgba(26, 38, 31, 0.05);
    overflow: hidden;
  }

  .svc-positions__toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 22px 20px 22px 28px;
    border-bottom: 1px solid #e9edea;
  }

  .svc-positions__heading {
    display: inline-flex;
  }

  .svc-positions__search {
    width: 300px;
  }

  .svc-positions__list {
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    overflow: visible;
  }

  .svc-position {
    gap: 18px;
    padding: 16px 22px;
    flex-wrap: nowrap;
  }

  .svc-position__name {
    font-size: 17px;
    line-height: 1.25;
    white-space: nowrap;
  }

  .svc-position__btn {
    display: inline-flex;
  }

  .svc-position__chevron {
    width: 20px;
    height: 20px;
    border: 0;
    border-radius: 0;
    background: transparent;
  }

  .svc-positions__footer {
    padding: 22px 28px 26px;
  }

  .svc-process {
    grid-row: 5;
    position: relative;
    height: auto;
    margin-top: 124px;
    padding: 72px 0 48px;
    background: transparent;
    overflow: visible;
  }

  .svc-seo-text {
    grid-row: 4;
    margin-top: 84px;
  }

  .svc-process__bg {
    display: block;
    overflow: visible;
  }

  .svc-process__grid {
    position: relative;
    display: grid;
    width: auto;
    height: auto;
    margin: 0;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-template-rows: auto 200px 200px;
    column-gap: 24px;
    row-gap: 24px;
  }

  .svc-process__head {
    position: static;
    grid-column: 2 / span 2;
    grid-row: 1;
    width: auto;
    height: auto;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    align-self: center;
    padding-left: 4px;
  }

  .svc-process__head-icon {
    width: auto;
    height: auto;
    margin-top: 0;
  }

  .svc-process__head-icon svg {
    width: 28px;
    height: 28px;
  }

  .svc-process__title {
    width: auto;
    font-size: 36px;
    line-height: 1.1;
  }

  .svc-maria {
    position: relative;
    grid-column: 1;
    grid-row: 1 / -1;
    align-self: stretch;
    top: auto;
    left: auto;
    width: auto;
    height: auto;
    min-height: 0;
    margin: 140px 0 0;
    padding: 110px 28px 88px;
    border-radius: 28px;
    box-shadow: 0 10px 30px rgba(20, 26, 31, 0.06);
  }

  .svc-maria__photo {
    top: -140px;
    left: 50%;
    width: 208px;
    height: 208px;
    transform: translateX(-50%);
  }

  .svc-maria__body {
    min-height: 0;
    padding-left: 0;
    align-items: stretch;
    text-align: left;
  }

  .svc-maria__name {
    margin: 0 0 4px;
    font-size: 16px;
    line-height: 1.4;
  }

  .svc-maria__role {
    max-width: none;
    font-size: 18px;
    line-height: 1.3;
  }

  .svc-maria__quote {
    width: auto;
    margin: 20px 0 0;
    font-size: 16px;
    line-height: 1.45;
  }

  .svc-maria__deco {
    right: 28px;
    bottom: 24px;
    width: 54px;
  }

  .svc-step {
    position: relative;
    z-index: auto;
    width: auto;
    height: auto;
    min-height: 0;
    top: auto;
    left: auto;
    padding: 28px;
    border-radius: 28px;
    justify-content: center;
    gap: 8px;
  }

  .svc-step--1 { grid-column: 2; grid-row: 2; }
  .svc-step--2 { grid-column: 3; grid-row: 2; }
  .svc-step--4 { grid-column: 2; grid-row: 3; }
  .svc-step--3 { grid-column: 3; grid-row: 3; }

  .svc-step__title {
    font-size: 18px;
    line-height: 1.2;
  }

  .svc-step__text,
  .svc-step--3 .svc-step__text,
  .svc-step--4 .svc-step__text {
    font-size: 15px;
    line-height: 1.4;
  }

  .svc-process__arrows {
    display: block;
  }

  .svc-geo {
    grid-row: 6;
    margin-top: 188px;
    padding: 0;
  }

  .svc-geo__head {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: 40px;
    padding: 0 4px;
    margin-bottom: 28px;
  }

  .svc-geo__title {
    font-size: 48px;
    max-width: 560px;
  }

  .svc-geo__lead {
    margin: 10px 0 0;
    max-width: 330px;
  }

  .svc-geo__cities {
    justify-content: center;
    gap: 10px;
    margin-top: 24px;
  }

  .svc-letters {
    grid-row: 7;
    margin-top: 80px;
    padding: 0;
    overflow: visible;
  }

  .svc-letters__head {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: 32px;
    margin-bottom: 28px;
  }

  .svc-letters__title {
    font-size: 40px;
  }

  .svc-letters__stat {
    padding-left: 58px;
    font-size: 16px;
  }

  .svc-letters__pagination {
    width: auto;
    justify-content: flex-start;
    gap: 16px;
    padding-top: 10px;
  }

  .svc-letters__row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    overflow: visible;
    padding: 0;
    scroll-snap-type: none;
  }

  .svc-letter {
    width: auto;
    flex: initial;
    scroll-snap-align: none;
  }

  .svc-letter__doc {
    width: 204px;
    height: 260px;
  }

  .svc-faq {
    grid-row: 8;
    width: 976px;
    max-width: 100%;
    margin-top: 107px;
    padding: 0;
  }

  .svc-faq__head {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 36px;
  }

  .svc-faq__title {
    font-size: 40px;
  }

  .svc-faq__item {
    min-height: 80px;
    padding: 22px 24px 22px 28px;
    border-radius: 20px;
  }

  .svc-faq__question-text {
    font-size: 18px;
    line-height: 1.35;
  }

  .svc-final-cta {
    grid-row: 9;
    position: relative;
    width: 976px;
    max-width: 100%;
    height: 520px;
    margin-top: 180px;
    margin-bottom: 0;
    border-radius: 32px;
  }

  .svc-final-cta__glow {
    display: block;
  }

  .svc-final-cta__visual {
    position: absolute;
    top: 0;
    right: 0;
    width: 460px;
    height: 100%;
  }

  .svc-final-cta__fade {
    top: 0;
    left: 516px;
    bottom: auto;
    width: 460px;
    height: 100%;
    background: linear-gradient(90deg, #0E1820 0%, rgba(14, 24, 32, 0.25) 35%, rgba(14, 24, 32, 0) 100%);
  }

  .svc-final-cta__content {
    width: 560px;
    height: 100%;
    padding: 52px 40px 44px 52px;
    gap: 22px;
  }

  .svc-final-cta__title {
    font-size: 34px;
    line-height: 1.12;
  }

  .svc-final-cta__lead {
    font-size: 15px;
    max-width: 430px;
  }

  .svc-final-cta__fields {
    flex-direction: row;
    gap: 12px;
  }
}

@media (min-width: 1025px) and (max-width: 1200px) {
  body.services-page { --svc-tablet-scale: 1; }
}

@media (min-width: 981px) and (max-width: 1024px) {
  body.services-page { --svc-tablet-scale: .99; }
}

@media (min-width: 941px) and (max-width: 980px) {
  body.services-page { --svc-tablet-scale: .95; }
}

@media (min-width: 901px) and (max-width: 940px) {
  body.services-page { --svc-tablet-scale: .91; }
}

@media (min-width: 861px) and (max-width: 900px) {
  body.services-page { --svc-tablet-scale: .87; }
}

@media (min-width: 821px) and (max-width: 860px) {
  body.services-page { --svc-tablet-scale: .83; }
}

@media (min-width: 801px) and (max-width: 820px) {
  body.services-page { --svc-tablet-scale: .81; }
}

@media (min-width: 769px) and (max-width: 800px) {
  body.services-page { --svc-tablet-scale: .78; }
}

@media (min-width: 741px) and (max-width: 768px) {
  body.services-page { --svc-tablet-scale: .75; }
}

@media (min-width: 701px) and (max-width: 740px) {
  body.services-page { --svc-tablet-scale: .71; }
}

@media (min-width: 641px) and (max-width: 700px) {
  body.services-page { --svc-tablet-scale: .66; }
}

@media (min-width: 601px) and (max-width: 640px) {
  body.services-page { --svc-tablet-scale: .61; }
}


/* ======================================================================
   MOBILE polish (≤ 600px) — Figma mobile (390px)
   ====================================================================== */

@media (max-width: 600px) {
  body.services-page .main-content {
    padding-top: 92px !important;
  }

  .svc-hero {
    padding-top: 12px;
    padding-bottom: 36px;
    overflow: visible;
  }

  .svc-hero__glow,
  .svc-breadcrumbs {
    display: none;
  }

  .svc-hero__container {
    padding: 0 16px;
  }

  .svc-hero__grid {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto;
    row-gap: 0;
  }

  .svc-hero-card {
    width: calc(100vw - 32px);
    margin-left: calc(50% - 50vw + 16px);
    margin-right: calc(50% - 50vw + 16px);
    border-radius: 24px;
    background: #fff;
    border-color: #edf2ed;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: 0 8px 24px rgba(20, 26, 31, 0.04);
  }

  .svc-hero-card__photo {
    height: 320px;
    border-radius: 24px 24px 0 0;
  }

  .svc-hero-card__photo::after {
    height: 220px;
    background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.46) 36%, rgba(255,255,255,.9) 68%, #fff 100%);
  }

  .svc-hero-card__photo img {
    object-position: center top;
  }

  .svc-hero-card__chips {
    top: 16px;
    left: 16px;
    gap: 8px;
  }

  .svc-hero-card__chip {
    gap: 8px;
    padding: 7px 14px 7px 12px;
    font-size: 12px;
    letter-spacing: -0.12px;
    box-shadow: 0 4px 12px rgba(20, 26, 31, 0.12);
  }

  .svc-hero-card__chip-text--desktop {
    display: none;
  }

  .svc-hero-card__chip-text--mobile,
  .svc-hero-card__chip--price {
    display: inline-flex;
  }

  .svc-hero-card__chip-dot {
    width: 8px;
    height: 8px;
  }

  .svc-hero-card__chip--price {
    background: rgba(0, 175, 87, 0.82);
    color: #fff;
    box-shadow: 0 6px 12px rgba(0, 175, 87, 0.22);
  }

  .svc-hero-card__chip--price .svc-ruble::after {
    height: 0.075em;
  }

  .svc-hero-card__body {
    gap: 22px;
    margin-top: -132px;
    padding: 20px 20px 36px;
  }

  .svc-hero-card__title {
    font-size: 28px;
    line-height: 1.15;
    letter-spacing: -0.03em;
  }

  .svc-hero-card__trust {
    gap: 8px 14px;
    white-space: normal;
  }

  .svc-trust-item {
    gap: 4px;
    font-size: 12px;
    line-height: 1.2;
  }

  .svc-trust-star {
    font-size: 12px;
  }

  .svc-trust-value,
  .svc-trust-label {
    font-weight: 500;
    color: #4d524f;
  }

  .svc-trust-check {
    font-size: 12px;
  }

  .svc-hero-card__lead {
    max-width: none;
    font-size: 14px;
    line-height: 1.4;
    color: #4d524f;
  }

  .svc-hero-card__stack {
    width: 100%;
    gap: 22px;
    margin-top: 0;
  }

  .svc-hero-card__divider,
  .svc-price {
    display: none;
  }

  .svc-hero-card__row {
    width: 100%;
    gap: 0;
    align-items: stretch;
  }

  .svc-hero-card__cta {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  .svc-btn {
    width: 100%;
    height: 50px;
    padding: 0 18px;
    font-size: 15px;
    font-weight: 600;
    justify-content: center;
  }

  .svc-btn--primary {
    box-shadow: 0 6px 14px rgba(0, 175, 87, 0.22);
    padding-right: 18px;
  }

  .svc-btn--ghost {
    border: 1px solid #e0e8e3;
    background: #fff;
    color: #222522;
    box-shadow: none;
    gap: 8px;
  }

  .svc-btn--ghost svg {
    width: 15px;
    height: 15px;
    color: #5d6460;
  }

  .svc-btn__arrow {
    font-size: 1.05em;
  }

  .svc-hero-card__note {
    gap: 6px;
    font-size: 11px;
    line-height: 1.2;
    color: #98a1ab;
  }

  .svc-hero-card__note svg {
    width: 11px;
    height: 11px;
    color: #98a1ab;
  }

  /* ---- Section spacing (Figma mobile rhythm) ---- */
  .svc-hero__grid { row-gap: 4px; }
  .svc-trustrow,
  .svc-process {
    width: calc(100% + 32px);
    max-width: none;
    margin-left: -16px;
  }
  .svc-trustrow {
    row-gap: 22px;
    padding: 48px 20px 36px;
  }
  .svc-positions {
    padding-top: 56px;
    padding-bottom: 32px;
  }
  .svc-geo {
    padding-top: 64px;
    padding-bottom: 32px;
  }
  .svc-letters {
    padding-top: 64px;
    padding-bottom: 24px;
  }
  .svc-faq {
    padding-top: 64px;
    padding-bottom: 32px;
  }
  .svc-final-cta {
    margin-top: 56px;
    margin-bottom: 56px;
  }

  /* ---- Trust widgets (clients + ratings) ---- */
  .svc-trust-widget {
    padding: 22px 24px;
    border-radius: 18px;
  }
  .svc-trust-widget--clients { height: 173px; }
  .svc-trust-widget--ratings { height: 124px; }
  .svc-trust-widget__title { font-size: 15px; }
  .svc-rating { padding: 8px 10px; gap: 8px; }
  .svc-reviews-link { font-size: 14px; }

  /* ---- Positions ---- */
  .svc-positions__title { font-size: 22px; }
  .svc-positions__subtitle { font-size: 13px; }
  .svc-positions__subtitle-text--desktop { display: none; }
  .svc-positions__subtitle-text--mobile { display: inline; }
  .svc-position { padding: 12px 14px; gap: 10px; }
  .svc-position__thumb { width: 48px; height: 48px; border-radius: 10px; }
  .svc-position__name { font-size: 14px; }
  .svc-position__price { font-size: 13px; }
  .svc-position__chevron {
    width: 36px;
    height: 36px;
    border: 1px solid #e9edea;
    border-radius: 10px;
    background: #f8faf8;
  }
  .svc-positions__footer { padding: 18px 16px 20px; }
  .svc-positions__footer-label { font-size: 14px; }
  .svc-tag { padding: 8px 12px; font-size: 13px; }

  /* ---- Process: exact mobile frame 709:220 ---- */
  .svc-process {
    width: calc(100% + 32px);
    max-width: none;
    margin-left: -16px;
    height: 812px;
    padding: 64px 0 24px;
    background: #eaf8ef;
  }
  .svc-process__bg {
    display: none;
  }
  .svc-process__grid {
    position: relative;
    display: block;
    width: 358px;
    height: 724px;
    margin: 0 auto;
  }
  .svc-process__head {
    position: absolute;
    top: 0;
    left: 0;
    width: 358px;
    height: 52px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 0;
  }
  .svc-process__head-icon {
    width: 28px;
    height: 28px;
    margin-top: 12px;
  }
  .svc-process__head-icon svg {
    width: 28px;
    height: 28px;
  }
  .svc-process__title {
    width: 320px;
    margin: 0;
    font-size: 26px;
    line-height: 1;
    letter-spacing: -0.02em;
  }
  .svc-maria {
    position: absolute;
    top: 80px;
    left: 0;
    width: 358px;
    height: 240px;
    min-height: 0;
    margin: 0;
    padding: 24px;
    border-radius: 28px;
    box-shadow: 0 10px 30px rgba(20, 26, 31, 0.06);
    z-index: 1;
  }
  .svc-maria__photo {
    top: 24px;
    left: 24px;
    width: 88px;
    height: 88px;
    transform: none;
    box-shadow: none;
  }
  .svc-maria__body {
    min-height: 0;
    padding-left: 104px;
    align-items: flex-start;
    text-align: left;
  }
  .svc-maria__name {
    margin: 13px 0 4px;
    font-size: 16px;
    line-height: 1.35;
    color: #5c5c5c;
  }
  .svc-maria__role {
    max-width: 206px;
    font-size: 16px;
    line-height: 1.25;
    color: #2b2b2b;
  }
  .svc-maria__quote {
    display: block;
    width: 310px;
    margin: 48px 0 0 -104px;
    font-size: 18px;
    line-height: 1.28;
    color: #5c5c5c;
  }
  .svc-maria__quote strong {
    display: inline;
  }
  .svc-maria__deco {
    display: block;
    right: 22px;
    bottom: 10px;
    width: 42px;
  }
  .svc-step {
    position: absolute;
    z-index: 2;
    padding: 18px;
    border-radius: 24px;
    justify-content: flex-start;
    gap: 8px;
    box-shadow: 0 12px 24px rgba(20, 26, 31, 0.07);
  }
  .svc-step--1 {
    top: 348px;
    left: 0;
    width: 348px;
    height: 99px;
  }
  .svc-step--2 {
    top: 459px;
    left: 0;
    width: 348px;
    height: 99px;
  }
  .svc-step--4 {
    top: 570px;
    left: 0;
    width: 163px;
    height: 154px;
  }
  .svc-step--3 {
    top: 570px;
    left: 175px;
    width: 163px;
    height: 135px;
  }
  .svc-step--3,
  .svc-step--4 {
    padding: 16px 18px;
  }
  .svc-step__title {
    font-size: 16px;
    line-height: 1.15;
  }
  .svc-step__text {
    font-size: 14px;
    line-height: 1.3;
  }
  .svc-step--3 .svc-step__text,
  .svc-step--4 .svc-step__text {
    font-size: 13px;
    line-height: 1.23;
  }

  /* ---- Geography ---- */
  .svc-geo__title { font-size: 28px; }
  .svc-geo__lead { font-size: 14px; }
  .svc-geo__cities { gap: 8px; }
  .svc-geo__city { padding: 7px 12px; font-size: 13px; }

  /* ---- Recommendations ---- */
  .svc-letters__title { font-size: 22px; }
  .svc-letters__stat { font-size: 13px; }
  .svc-letter { width: 172px; }
  .svc-letter__doc { width: 172px; height: 219px; }
  .svc-letter__logo { height: 18px; max-width: 72px; }
  .svc-letter__logo--square { width: 18px; max-width: 18px; }
  .svc-letter__name { font-size: 12px; }
  .svc-letters__arrow { width: 32px; height: 32px; border-radius: 16px; }
  .svc-letters__arrow svg { width: 14px; height: 14px; }

  /* ---- FAQ ---- */
  .svc-faq__title { font-size: 22px; }
  .svc-faq__contact { font-size: 13px; }
  .svc-faq__item {
    padding: 16px 18px;
    border-radius: 16px;
    min-height: 0;
  }
  .svc-faq__question-text { font-size: 15px; line-height: 1.3; }
  .svc-faq__toggle { width: 28px; height: 28px; border-radius: 14px; }
  .svc-faq__toggle img { width: 12px; height: 12px; }
  .svc-faq__answer-copy { font-size: 14px; line-height: 1.45; }

  /* ---- Final CTA ---- */
  .svc-final-cta {
    background: #0e1820;
    border-radius: 28px;
  }
  .svc-final-cta__visual {
    height: 220px;
    padding: 0;
    overflow: hidden;
    border-radius: 28px 28px 0 0;
    background: #0e1820 url('/public/services-page/img/mobile-final-cta-workers.png') center center / cover no-repeat;
  }
  .svc-final-cta__visual img {
    display: none;
  }
  .svc-final-cta__fade {
    top: 0;
    bottom: auto;
    height: 220px;
    background: linear-gradient(180deg, rgba(14, 24, 32, 0) 0%, rgba(14, 24, 32, 0.25) 55%, #0e1820 100%);
  }
  .svc-final-cta__content { padding: 24px; gap: 16px; }
  .svc-final-cta__title { font-size: 22px; line-height: 1.15; }
  .svc-final-cta__lead { font-size: 14px; }
  .svc-final-cta__badge { padding: 6px 12px; }
  .svc-final-cta__badge span:last-child { font-size: 12px; }
  .svc-final-cta__input { padding: 14px 16px; font-size: 14px; }
  .svc-final-cta__button { padding: 15px 18px; }
  .svc-final-cta__button span { font-size: 15px; }
  .svc-final-cta__note { font-size: 11px; line-height: 1.4; }
}

/* Final override: fit full Bitrix form inside the dark CTA. */
@media (min-width: 768px) {
  body.services-page .svc-final-cta {
    height: 640px !important;
    overflow: hidden !important;
  }

  body.services-page .svc-final-cta__visual,
  body.services-page .svc-final-cta__fade {
    height: 100% !important;
  }

  body.services-page .svc-final-cta__content {
    height: 100% !important;
    padding: 38px 36px 34px 46px !important;
    gap: 12px !important;
  }

  body.services-page .svc-final-cta__title {
    font-size: 30px !important;
    line-height: 1.12 !important;
  }

  body.services-page .svc-final-cta__lead {
    font-size: 14px !important;
    line-height: 1.45 !important;
  }
}

body.services-page .svc-final-cta__form .b24-form-content form > div:first-child {
  gap: 8px 10px !important;
}

body.services-page .svc-final-cta__form .b24-form-control,
body.services-page .svc-final-cta__form input[type="text"],
body.services-page .svc-final-cta__form input[type="tel"],
body.services-page .svc-final-cta__form input[type="email"],
body.services-page .svc-final-cta__form select,
body.services-page .svc-final-cta__form textarea {
  height: 44px !important;
  min-height: 44px !important;
  padding: 16px 14px 6px !important;
  border-radius: 12px !important;
  font-size: 14px !important;
}

body.services-page .svc-final-cta__form textarea {
  height: 68px !important;
}

body.services-page .svc-final-cta__form .b24-form-btn-container {
  margin-top: 8px !important;
}

body.services-page .svc-final-cta__form .b24-form-btn {
  min-height: 50px !important;
  border-radius: 12px !important;
  font-size: 15px !important;
}

body.services-page .svc-final-cta__form .b24-form-field-agreement {
  margin-top: 8px !important;
  font-size: 9px !important;
  line-height: 1.25 !important;
}

@media (max-width: 767px) {
  body.services-page .svc-final-cta {
    height: auto !important;
  }
}

/* Final CTA visual tuning after real Bitrix fields render. */
@media (min-width: 768px) {
  body.services-page .svc-final-cta {
    height: 540px !important;
  }

  body.services-page .svc-final-cta__content {
    padding-top: 34px !important;
    padding-bottom: 30px !important;
    gap: 10px !important;
  }
}

body.services-page .svc-final-cta__form .b24-form-control,
body.services-page .svc-final-cta__form input[type="text"],
body.services-page .svc-final-cta__form input[type="tel"],
body.services-page .svc-final-cta__form input[type="email"],
body.services-page .svc-final-cta__form select,
body.services-page .svc-final-cta__form textarea {
  height: 46px !important;
  min-height: 46px !important;
  padding: 20px 14px 5px !important;
}

body.services-page .svc-final-cta__form .b24-form-control-label,
body.services-page .svc-final-cta__form .b24-form-control-label-name {
  top: 6px !important;
  left: 14px !important;
  transform: none !important;
  height: auto !important;
  font-size: 10px !important;
  line-height: 1 !important;
  pointer-events: none !important;
}

body.services-page .svc-final-cta__form .b24-form-field-agreement {
  max-width: 430px !important;
  font-size: 9px !important;
  line-height: 1.18 !important;
}

/* Final QA fixes: letters alignment/lightbox affordance and dark form readability. */
.svc-letters__stat {
  padding-left: 0 !important;
}

.svc-letter__doc {
  cursor: zoom-in;
}

body.services-page .svc-final-cta__fade {
  left: 470px !important;
  width: 560px !important;
  background: linear-gradient(90deg, #0e1820 0%, rgba(14, 24, 32, 0.94) 12%, rgba(14, 24, 32, 0.45) 55%, rgba(14, 24, 32, 0) 100%) !important;
}

body.services-page .svc-final-cta__form .b24-form-control,
body.services-page .svc-final-cta__form input[type="text"],
body.services-page .svc-final-cta__form input[type="tel"],
body.services-page .svc-final-cta__form input[type="email"],
body.services-page .svc-final-cta__form select,
body.services-page .svc-final-cta__form textarea {
  background: rgba(255, 255, 255, 0.13) !important;
  border-color: rgba(255, 255, 255, 0.2) !important;
  color: #ffffff !important;
}

body.services-page .svc-final-cta__form .b24-form-control-label,
body.services-page .svc-final-cta__form .b24-form-control-label-name {
  color: rgba(255, 255, 255, 0.78) !important;
  font-weight: 500 !important;
}

body.services-page .svc-final-cta__form .b24-form-field-agreement,
body.services-page .svc-final-cta__form .b24-form-field-agreement-link {
  color: rgba(255, 255, 255, 0.72) !important;
}

/* Compact final CTA after hidden Bitrix fields. */
@media (min-width: 768px) {
  body.services-page .svc-final-cta {
    height: 500px !important;
  }

  body.services-page .svc-final-cta__content {
    padding-top: 32px !important;
    padding-bottom: 22px !important;
    gap: 8px !important;
  }

  body.services-page .svc-final-cta__form .b24-form-btn-container {
    margin-top: 6px !important;
  }
}
