/* -----------------------------------------
	Homepage header (solid bar above hero, no overlap)
----------------------------------------- */
.header-area.header_v1.header-home-primary {
  position: relative;
  top: auto;
  left: auto;
  width: 100%;
  background-color: var(--color-primary);
}

.header-area.header_v1.header-home-primary .nav-link.active {
  color: var(--text-white);
}

.header-area.header_v1.header-home-primary.is-sticky {
  position: fixed;
  top: 0;
  left: 0;
}

@media (max-width: 1199px) {
  .header-area.header_v1.header-home-primary:not(.is-sticky) {
    background-color: var(--color-primary);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
}

/* -----------------------------------------
	Hero Banner 2 — 1920×880 frame, responsive scale
----------------------------------------- */
.hero-banner.hero-banner_v5 {
  padding: 0;
  min-height: 0;
  overflow: hidden;
  background-color: var(--bg-2);
}

.hero-banner.hero-banner_v5 .hero-banner__media {
  position: relative;
  width: 100%;
  max-width: 1920px;
  margin-inline: auto;
  aspect-ratio: 1920 / 880;
  max-height: 880px;
  overflow: hidden;
  line-height: 0;
}

@supports not (aspect-ratio: 1920 / 880) {
  .hero-banner.hero-banner_v5 .hero-banner__media::before {
    content: "";
    display: block;
    padding-top: 45.833333%;
  }
}

.hero-banner.hero-banner_v5 .home-img-slider {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.hero-banner.hero-banner_v5 .home-img-slider .swiper-wrapper,
.hero-banner.hero-banner_v5 .home-img-slider .swiper-slide,
.hero-banner.hero-banner_v5 .hero-banner__slide {
  height: 100%;
}

.hero-banner.hero-banner_v5 .home-img-slider .swiper-slide,
.hero-banner.hero-banner_v5 .hero-banner__slide {
  position: relative;
  overflow: hidden;
}

.hero-banner.hero-banner_v5 .home-slider {
  overflow: hidden;
  height: 100%;
}

.hero-banner.hero-banner_v5 .home-slider .swiper-wrapper,
.hero-banner.hero-banner_v5 .home-slider .swiper-slide {
  height: 100%;
}

.hero-banner.hero-banner_v5 .hero-banner__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
}

.hero-banner.hero-banner_v5 .hero-banner__overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  pointer-events: none;
}

.hero-banner.hero-banner_v5 .hero-banner__content {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  padding: 40px 0;
  line-height: normal;
  pointer-events: none;
}

.hero-banner.hero-banner_v5 .hero-banner__content .container,
.hero-banner.hero-banner_v5 .hero-banner__content a,
.hero-banner.hero-banner_v5 .hero-banner__content button {
  pointer-events: auto;
}

.hero-banner.hero-banner_v5 .hero-banner__pagination {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 24px;
  top: auto !important;
  z-index: 3;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0 15px;
  line-height: 1;
  pointer-events: auto;
}
.hero-banner.hero-banner_v5 .banner-content .subtitle {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.hero-banner.hero-banner_v5 .banner-content .subtitle .line {
  position: relative;
  overflow: hidden;
  display: inline-block;
  border-inline-start: 6px solid var(--color-primary);
  width: 26px;
  height: 18px;
  margin-inline-start: 4px;
  transform: skewX(-10deg);
}
.hero-banner.hero-banner_v5 .banner-content .subtitle .line::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  bottom: 0;
  width: 6px;
  height: 100%;
  margin-inline-start: 4px;
  background-color: var(--color-primary);
}
.hero-banner.hero-banner_v5 .banner-content .subtitle .line::after {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 6px;
  height: 100%;
  margin-inline-start: auto;
  margin-inline-end: 0;
  background-color: var(--color-primary);
}
.hero-banner.hero-banner_v5 .banner-content .product-price {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}
.hero-banner.hero-banner_v5 .banner-content .product-price h6 {
  width: 100%;
}
.hero-banner.hero-banner_v5 .banner-content .product-price * {
  margin: 0;
  line-height: 1;
}
.hero-banner.hero-banner_v5 .banner-content .product-price .prev-price {
  text-decoration: line-through;
  font-weight: var(--font-semi-bold);
}
.hero-banner.hero-banner_v5 .form-wrapper {
  background-color: var(--bg-white);
  z-index: 3;
}
.hero-banner.hero-banner_v5 .right-content {
  position: relative;
  overflow: hidden;
}
.hero-banner.hero-banner_v5 .right-content .overlap {
  position: absolute;
  overflow: hidden;
  content: "";
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin-inline-start: auto;
  width: 57.1428571429%;
  height: 100%;
  background-color: var(--color-primary);
  z-index: -1;
}
.hero-banner.hero-banner_v5 .right-content .overlap::before, .hero-banner.hero-banner_v5 .right-content .overlap::after {
  position: absolute;
  content: "";
  left: 0;
  right: 0;
  width: 100px;
  height: 100px;
  border-radius: var(--radius-circle);
  border: 10px solid var(--color-white);
}
.hero-banner.hero-banner_v5 .right-content .overlap::after {
  top: 0;
  margin-inline-start: auto;
  margin-inline-end: 20px;
  margin-top: -15%;
}
.hero-banner.hero-banner_v5 .right-content .overlap::before {
  bottom: 0;
  margin-inline-end: auto;
  margin-inline-start: 20px;
  margin-bottom: -15%;
}
.hero-banner.hero-banner_v5 .right-content .swiper-slide {
  position: relative;
  overflow: hidden;
}
.hero-banner.hero-banner_v5 .right-content .home-img-slider {
  position: relative;
}
.hero-banner.hero-banner_v5 .pagination-fraction .swiper-pagination-bullet {
  color: var(--text-white);
}
.hero-banner.hero-banner_v5 .shape > * {
  position: absolute;
  z-index: -1;
}
.hero-banner.hero-banner_v5 .shape > *.shape-1 {
  top: 14%;
  left: 35%;
  animation: moveLeftRight 10s linear infinite;
}
.hero-banner.hero-banner_v5 .shape > *.shape-2 {
  top: 45%;
  left: 45%;
  animation: moveUpDown 5s linear infinite;
}
.hero-banner.hero-banner_v5 .shape > *.shape-3 {
  bottom: 10%;
  left: 10%;
  animation: moveLeftRight 10s linear infinite;
}
.hero-banner.hero-banner_v5 .shape > *.shape-4 {
  bottom: 5%;
  left: 36%;
  animation: moveLeftRight 8s linear infinite;
}
.hero-banner.hero-banner_v5 .shape > *.shape-5 {
  top: 40%;
  right: 10%;
  animation: moveUpDown 10s linear infinite;
}
.hero-banner.hero-banner_v5 .shape > *.shape-6 {
  top: 40%;
  right: 25%;
  animation: moveLeftRight 10s linear infinite;
}
.hero-banner.hero-banner_v5 .shape > *.shape-7 {
  top: 65%;
  right: 5%;
  animation: moveUpDown 10s linear infinite;
}

/* About section — admin color pickers */
.choose-area_v4.about-section-themed .subtitle,
.choose-area_v4.about-section-themed .subtitle_v3 {
  color: var(--about-subtitle-color) !important;
}

.choose-area_v4.about-section-themed .image .about-text .h1 {
  color: var(--about-subtitle-color);
  -webkit-text-stroke-color: var(--about-subtitle-color);
}

.choose-area_v4.about-section-themed .content-title .title {
  color: var(--about-title-color) !important;
}

.choose-area_v4.about-section-themed .item-list .card_text {
  color: var(--about-text-color) !important;
}

/* Blog section — admin overlay color & opacity (theme 5) */
.blog-area_v5.blog-area-themed .overlay::before {
  background-color: var(--blog-overlay-color, var(--color-dark)) !important;
  opacity: var(--blog-overlay-opacity, 0.8) !important;
}

/* Innovation split section (replaces counter on theme 5) */
.innovation-split {
  padding: 0;
  background-color: var(--bg-2);
  overflow: hidden;
}

.innovation-split__frame {
  display: grid;
  grid-template-columns: minmax(0, 77.083%) minmax(0, 22.917%);
  width: 100%;
  max-width: 1920px;
  margin-inline: auto;
  aspect-ratio: 1920 / 880;
  max-height: 880px;
  min-height: 360px;
  overflow: hidden;
}

.innovation-split__visual {
  position: relative;
  min-width: 0;
  min-height: 100%;
  overflow: hidden;
}

.innovation-split__image,
.innovation-split__video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

.innovation-split__video {
  border: 0;
  pointer-events: none;
}

.innovation-split__overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  pointer-events: none;
  background-color: var(--innovation-overlay-color, #000000);
  opacity: var(--innovation-overlay-opacity, 0.25);
}

.innovation-split__title {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: clamp(20px, 4vw, 48px);
  text-align: center;
  font-size: clamp(1.875rem, 4.2vw, 4.5rem);
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: 0.01em;
  white-space: pre-line;
  pointer-events: none;
  color: var(--innovation-title-color, #ffffff) !important;
}

.innovation-split__panel {
  position: relative;
  z-index: 2;
  min-width: 0;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: clamp(32px, 5vw, 72px) clamp(28px, 3.5vw, 56px);
  box-sizing: border-box;
  background-color: var(--innovation-panel-bg, #1a2d4a);
}

.innovation-split__icon {
  margin-bottom: clamp(24px, 3.5vw, 40px);
  max-width: min(200px, 100%);
}

.innovation-split__icon img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 110px;
  object-fit: contain;
  object-position: left center;
}

.innovation-split__subtitle {
  margin: 0 0 20px;
  font-size: clamp(1.25rem, 2.2vw, 1.875rem);
  font-weight: 600;
  line-height: 1.25;
  color: var(--innovation-subtitle-color, #6fa8dc) !important;
}

.innovation-split__text {
  margin: 0;
  font-size: clamp(0.875rem, 1.15vw, 1.0625rem);
  font-weight: 400;
  line-height: 1.7;
  max-width: 100%;
  color: var(--innovation-text-color, #ffffff) !important;
}

@media (max-width: 991.98px) {
  .innovation-split__frame {
    aspect-ratio: auto;
    max-height: none;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto auto;
  }

  .innovation-split__visual,
  .innovation-split__panel {
    width: 100%;
    max-width: 100%;
  }

  .innovation-split__visual {
    aspect-ratio: 1920 / 620;
    min-height: 280px;
    height: auto;
  }

  .innovation-split__panel {
    min-height: 280px;
    padding: 40px 28px;
  }
}