/* Карточка «схема + описание» на странице Услуги — как «Автодоставка»: визуал на всю ширину, текст снизу */
.ac-services-hero-combo {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 0 0 28px;
  border-radius: var(--ac-radius);
  border: 1px solid var(--ac-border);
  overflow: hidden;
  background: linear-gradient(165deg, #ffffff 0%, #f1f5f9 100%);
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.06);
}

.ac-services-hero-viz {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: clamp(12px, 2vw, 20px) clamp(10px, 2.5vw, 28px) clamp(14px, 2.5vw, 24px);
  min-height: min(280px, 46vw);
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(56, 189, 248, 0.2) 0%, transparent 55%),
    linear-gradient(180deg, #e0f2fe 0%, #bae6fd 42%, #eff6ff 100%);
  overflow: hidden;
}

.ac-services-hero-viz .ac-services-train-svg {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: min(420px, 70vw);
  margin: 0 auto;
  filter: saturate(1.08) brightness(1.08);
}

.ac-services-hero-copy {
  width: 100%;
  max-width: none;
  padding: clamp(20px, 3.2vw, 32px) clamp(22px, 4vw, 40px) clamp(22px, 3.5vw, 36px);
  border-left: none;
  border-top: 1px solid var(--ac-border);
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 55%, #f1f5f9 100%);
  align-self: stretch;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.ac-services-hero-copy .ac-service-full-card-btn {
  align-self: flex-start;
}

@media screen and (max-width: 640px) {
  .ac-services-hero-combo {
    margin-bottom: 22px;
    border-radius: clamp(10px, 2.5vw, var(--ac-radius));
  }

  /* Иллюстрация на всю ширину карточки, без боковых полей */
  .ac-services-hero-viz {
    min-height: min(200px, 48vw);
    padding: 4px 0 12px;
  }

  .ac-services-hero-viz .ac-services-train-svg {
    max-height: min(280px, 52vw);
    width: 100%;
  }

  .ac-services-hero-copy {
    padding: 18px 16px 20px;
  }

  .ac-service-avia-stack {
    min-height: min(360px, 92vw);
  }

  .ac-service-full-card--avia .ac-service-full-card-inner {
    top: clamp(160px, 38vw, 240px);
    padding: 16px 16px 18px;
    overflow-y: auto;
    max-height: 55vh;
  }

  .ac-service-avia-daynight .ac-service-avia-plane {
    height: min(72px, 18vw);
    top: 56px;
  }

  .ac-service-avia-daynight .ac-service-avia-sun,
  .ac-service-avia-daynight .ac-service-avia-moon {
    width: min(72px, 16vw);
    height: min(72px, 16vw);
  }
}

/* --- SVG: фон сцены (небо / свечение заданы градиентами в разметке) --- */
.ac-services-hero-viz .ac-services-train-svg #land {
  fill: #0f1f35 !important;
}

.ac-services-hero-viz .ac-services-train-svg #bumps .st0 {
  fill: #152a42 !important;
}

.ac-services-hero-viz .ac-services-train-svg .st0 {
  fill: #122238;
}

.ac-services-hero-viz .ac-services-train-svg .st2 {
  fill: rgba(56, 189, 248, 0.95);
}

.ac-services-hero-viz .ac-services-train-svg .st3 {
  fill: rgba(148, 163, 184, 0.55);
  stroke: rgba(254, 240, 138, 0.35);
  stroke-width: 0.6;
}

/* Облака — белые, мягкая обводка */
.ac-services-hero-viz .ac-services-train-svg #cloudsAll .st4 {
  fill: rgba(255, 255, 255, 0.94) !important;
  stroke: rgba(255, 255, 255, 0.42) !important;
  stroke-width: 1.1;
  stroke-miterlimit: 10;
  filter: drop-shadow(0 3px 14px rgba(15, 23, 42, 0.35)) drop-shadow(0 0 20px rgba(255, 255, 255, 0.15));
}

.ac-services-hero-viz .ac-services-train-svg #train #wheels .st6 {
  fill: #1a2740 !important;
  stroke: rgba(56, 189, 248, 0.9) !important;
  stroke-width: 2;
  stroke-miterlimit: 10;
  filter: none;
}

.ac-services-hero-viz .ac-services-train-svg .st7,
.ac-services-hero-viz .ac-services-train-svg .st8,
.ac-services-hero-viz .ac-services-train-svg .st9 {
  stroke-miterlimit: 10;
}

.ac-services-hero-viz .ac-services-train-svg .st7 {
  stroke-width: 5;
  stroke-linecap: round;
  fill: none;
}

.ac-services-hero-viz .ac-services-train-svg .st8,
.ac-services-hero-viz .ac-services-train-svg .st9 {
  fill: rgba(36, 58, 92, 0.95);
}

.ac-services-hero-viz .ac-services-train-svg .st9 {
  fill: none;
}

.ac-services-hero-viz .ac-services-train-svg .st10 {
  fill: var(--ac-accent2);
  font-family: var(--ac-display), "Syne", system-ui, sans-serif;
  font-weight: 700;
}

/* Корпус поезда — металлический градиент (нижняя палуба — url(#ac-train-deck) в разметке) */
.ac-services-hero-viz .ac-services-train-svg #train path.st8 {
  fill: url(#ac-train-hull) !important;
  stroke: rgba(165, 243, 252, 0.85) !important;
  stroke-width: 1.35;
}

.ac-services-hero-viz .ac-services-train-svg #train #Text text {
  fill: #f0f9ff !important;
  stroke: rgba(14, 165, 233, 0.35) !important;
  stroke-width: 0.4px;
  paint-order: stroke fill;
}

.ac-services-hero-viz .ac-services-train-svg #train .st2 {
  fill: rgba(14, 165, 233, 0.95) !important;
}

.ac-services-hero-viz .ac-services-train-svg #train .st7 {
  fill: none !important;
  stroke: rgba(253, 224, 71, 0.55) !important;
}

.ac-services-hero-viz .ac-services-train-svg #train .st9 {
  fill: none !important;
  stroke: rgba(186, 230, 253, 0.55) !important;
}

/* Движение SVG-сцены: _ac_services_svg_motion_script.html (rAF, тайминги как в исходных keyframes) */

/* --- Карточка «Авиадоставка»: небо на весь фон + текст поверх; облака/луна видимы --- */
.ac-service-full-card--avia {
  position: relative;
  display: block;
  overflow: hidden;
}

.ac-service-avia-stack {
  position: relative;
  min-height: clamp(420px, 72vw, 560px);
}

.ac-service-avia-daynight {
  position: absolute;
  inset: 0;
  width: 100%;
  min-height: 100%;
  overflow: hidden;
  background-color: #61cadf;
  isolation: isolate;
  -webkit-animation: ac-hero-body 33.5s infinite linear;
  animation: ac-hero-body 33.5s infinite linear;
}

.ac-service-avia-daynight .ac-service-avia-sun,
.ac-service-avia-daynight .ac-service-avia-moon {
  position: absolute;
  width: 80px;
  height: 80px;
  border-radius: 80px;
  box-sizing: border-box;
  margin: 0;
  transform-origin: 50% 50%;
  will-change: transform;
}

.ac-service-avia-daynight .ac-service-avia-sun {
  top: 20px;
  left: min(300px, calc(100% - 96px));
  background-color: #f1c40f;
  box-shadow: 0 0 180px 2px #ffff75;
  z-index: 2;
  -webkit-animation: ac-service-avia-sun-move 33.5s infinite linear;
  animation: ac-service-avia-sun-move 33.5s infinite linear;
}

.ac-service-avia-daynight .ac-service-avia-moon {
  top: 24px;
  right: min(48px, 6vw);
  left: auto;
  background-color: #f1efa5;
  box-shadow: 0 0 180px 2px #ffffe7;
  z-index: 3;
  -webkit-animation: ac-service-avia-moon-move 33.5s infinite linear;
  animation: ac-service-avia-moon-move 33.5s infinite linear;
}

/* Солнце/луна: translateY (стабильнее, чем margin-top: 101% в узкой карточке) */
@-webkit-keyframes ac-service-avia-sun-move {
  0%,
  10% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }

  30%,
  75% {
    -webkit-transform: translateY(min(340px, 88vw));
    transform: translateY(min(340px, 88vw));
  }

  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@keyframes ac-service-avia-sun-move {
  0%,
  10% {
    transform: translateY(0);
  }

  30%,
  75% {
    transform: translateY(min(340px, 88vw));
  }

  100% {
    transform: translateY(0);
  }
}

@-webkit-keyframes ac-service-avia-moon-move {
  0% {
    -webkit-transform: translateY(min(300px, 78vw));
    transform: translateY(min(300px, 78vw));
  }

  25%,
  75% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }

  100% {
    -webkit-transform: translateY(min(300px, 78vw));
    transform: translateY(min(300px, 78vw));
  }
}

@keyframes ac-service-avia-moon-move {
  0% {
    transform: translateY(min(300px, 78vw));
  }

  25%,
  75% {
    transform: translateY(0);
  }

  100% {
    transform: translateY(min(300px, 78vw));
  }
}

.ac-service-avia-daynight .ac-service-avia-clouds-row {
  position: absolute;
  left: -6%;
  width: 112%;
  top: 0;
  min-height: max(46%, 160px);
  height: auto;
  overflow: visible;
  z-index: 1;
  pointer-events: none;
}

.ac-service-avia-daynight .ac-service-avia-clouds-row::after {
  content: "";
  display: table;
  clear: both;
}

.ac-service-avia-daynight .ac-service-avia-cloud {
  float: right;
  display: block;
  width: auto;
  min-width: 72px;
  max-width: none !important;
  height: auto;
  margin: 0;
  pointer-events: none;
  flex-shrink: 0;
  will-change: transform;
  object-fit: contain;
}

.ac-service-avia-daynight .ac-service-avia-cloud--1 {
  height: 100px;
  margin-top: 20px;
  margin-right: 102%;
  -webkit-animation: ac-hero-clouds 10s infinite linear;
  animation: ac-hero-clouds 10s infinite linear;
}

.ac-service-avia-daynight .ac-service-avia-cloud--2 {
  height: 70px;
  margin-top: 20px;
  margin-right: 115%;
  -webkit-animation: ac-hero-clouds 12s infinite linear;
  animation: ac-hero-clouds 12s infinite linear;
}

.ac-service-avia-daynight .ac-service-avia-cloud--3 {
  height: 80px;
  margin-top: 20px;
  margin-right: 120%;
  -webkit-animation: ac-hero-clouds 11.5s infinite linear;
  animation: ac-hero-clouds 11.5s infinite linear;
}

.ac-service-avia-daynight .ac-service-avia-cloud--4 {
  height: 50px;
  margin-top: 20px;
  margin-right: 110%;
  -webkit-animation: ac-hero-clouds 17s infinite linear;
  animation: ac-hero-clouds 17s infinite linear;
}

.ac-service-avia-daynight .ac-service-avia-cloud--5 {
  height: 30px;
  margin-top: 20px;
  margin-right: 120%;
  -webkit-animation: ac-hero-clouds 31s infinite linear;
  animation: ac-hero-clouds 31s infinite linear;
}

/* Только нижняя часть карточки — верх не перекрываем, иначе не видно облаков/анимации */
.ac-service-full-card--avia .ac-service-full-card-inner {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: clamp(210px, 40%, 320px);
  z-index: 5;
  max-width: none;
  padding: clamp(18px, 3vw, 28px) clamp(24px, 4vw, 40px) clamp(22px, 3vw, 32px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.92) 0%,
    rgba(248, 250, 252, 0.98) 40%,
    #f1f5f9 100%
  );
  border-top: 1px solid var(--ac-border);
  box-shadow: 0 -12px 36px rgba(15, 23, 42, 0.06);
}

/* Самолёт: transform (как ваш plane, но стабильнее с position:absolute + left:50%) */
.ac-service-avia-daynight .ac-service-avia-plane {
  position: absolute;
  left: 50%;
  top: 70px;
  margin: 0;
  display: block;
  height: 80px;
  width: auto;
  max-width: none !important;
  z-index: 4;
  transform: translateX(-50%);
  transform-origin: 50% 50%;
  will-change: transform;
  -webkit-animation: ac-service-avia-plane-move 6s infinite;
  animation: ac-service-avia-plane-move 6s infinite;
}

@-webkit-keyframes ac-service-avia-plane-move {
  0%,
  100% {
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
  }

  25% {
    -webkit-transform: translate(-50%, 15px);
    transform: translate(-50%, 15px);
  }

  50% {
    -webkit-transform: translate(calc(-50% + 2vw), 0);
    transform: translate(calc(-50% + 2vw), 0);
  }

  75% {
    -webkit-transform: translate(calc(-50% - 4vw), -10px);
    transform: translate(calc(-50% - 4vw), -10px);
  }
}

@keyframes ac-service-avia-plane-move {
  0%,
  100% {
    transform: translate(-50%, 0);
  }

  25% {
    transform: translate(-50%, 15px);
  }

  50% {
    transform: translate(calc(-50% + 2vw), 0);
  }

  75% {
    transform: translate(calc(-50% - 4vw), -10px);
  }
}
