/* =============================================================== */
/* --------------------- NEXON Lv1 Gothic OTF Font Family --------------------- */
/* =============================================================== */
@font-face {
  font-family: 'NEXON Lv1 Gothic OTF';
  src: url('../fonts/NEXON_Lv1_Gothic/NEXON Lv1 Gothic_OTF_TTF/OTF/NEXON Lv1 Gothic OTF.otf')
    format('opentype');
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: 'NEXON Lv1 Gothic OTF';
  src: url('../fonts/NEXON_Lv1_Gothic/NEXON Lv1 Gothic_OTF_TTF/OTF/NEXON Lv1 Gothic OTF Bold.otf')
    format('opentype');
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: 'NEXON Lv1 Gothic OTF';
  src: url('../fonts/NEXON_Lv1_Gothic/NEXON Lv1 Gothic_OTF_TTF/OTF/NEXON Lv1 Gothic OTF Light.otf')
    format('opentype');
  font-weight: 300;
  font-style: normal;
}
/* ======================================================================== */
/* --------------------- NEXON Lv1 Gothic Font Family --------------------- */
/* ======================================================================== */
@font-face {
  font-family: 'NEXON Lv1 Gothic';
  src: url('../fonts/NEXON_Lv1_Gothic/NEXON Lv1 Gothic Low_OTF/NEXON Lv1 Gothic Low OTF Bold.otf')
    format('opentype');
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: 'NEXON Lv1 Gothic';
  src: url('../fonts/NEXON_Lv1_Gothic/NEXON Lv1 Gothic Low_OTF/NEXON Lv1 Gothic Low OTF Light.otf')
    format('opentype');
  font-weight: 300;
  font-style: normal;
}
@font-face {
  font-family: 'NEXON Lv1 Gothic';
  src: url('../fonts/NEXON_Lv1_Gothic/NEXON Lv1 Gothic Low_OTF/NEXON Lv1 Gothic Low OTF.otf')
    format('opentype');
  font-weight: 400;
  font-style: normal;
}
/* ======================================================================== */
/* --------------------- Hanwha Font Family ---------------------========== */
/* ======================================================================== */
@font-face {
  font-family: 'Hanwha';
  src: url('../fonts/HanwhaL.otf') format('opentype');
  font-weight: 300;
  font-style: normal;
}
@font-face {
  font-family: 'Hanwha';
  src: url('../fonts/HanwhaR.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: 'Hanwha';
  src: url('../fonts/HanwhaB.otf') format('opentype');
  font-weight: 700;
  font-style: normal;
}
/* ========================================================================== */
/* ========================= section_1 ====================================== */
/* ========================================================================== */
.section_1 {
  width: 100%;
  height: auto;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  overflow: hidden;
  background: #34596d;
  padding-top: 72px;
}
.section_1 .swiper_wrapper {
  width: 100%;
  max-height: 860px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.main_swiper_controls_wrapper {
  width: 1440px;
  height: 288px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.moto_wrapper {
  padding: 0;
  width: 576px;
  height: 150px;
}
.moto_wrapper p {
  padding: 0;
  margin: 0;
}
.moto_wrapper p span:first-child {
  color: #b1fafd;
  font-family: 'Righteous';
  font-size: 26.729px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 40.093px */
}
.moto_wrapper p span:last-child {
  color: #b1fafd;
  font-family: 'Righteous';
  font-size: 60px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%; /* 90px */
}
.right_controls_wrapper {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: flex-end;
  padding: 0;
  margin: 0;
}
.right_controls_wrapper .section_1_car_image {
  width: 150px;
  height: 150px;
  aspect-ratio: 1/1;
  object-fit: contain;
  padding: 0;
  margin: 0;
}
/* ========================================================================== */
/* ========================= Main Visual Swiper ============================= */
/* ========================================================================== */
.main_visual_swiper {
  width: 100%;
  height: auto;
  min-height: 580px;
  padding: 0;
  margin: 0;
}
.main_visual_swiper .slide_item {
  width: 100%;
  height: 100%;
}
.main_visual_swiper .slide_item img {
  width: 100%;
  height: 100%;
  aspect-ratio: 7680/2320;
  object-fit: auto;
}
/* ========================================================================== */
/* ========================= Main Visual Swiper Controls ==================== */
/* ========================================================================== */
.main_swiper_controls {
  width: 356px;
  height: calc(38.8px + 32px);
  display: inline-flex;
  padding: 0;
  align-items: center;
  gap: 68px;
}
.main_swiper_controls .swiper_progress {
  width: 203px;
  height: auto;
  display: flex;
  align-items: center;
  gap: 16px;
}
.main_swiper_controls .number_indicator {
  color: #fff;
  font-family: 'Hanwha', sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 300;
  line-height: normal;
}
.main_swiper_controls .progress_bar {
  display: flex;
  width: 150px;
  height: 0.75px;
  background-color: rgba(255, 255, 255, 0.3);
}
.main_swiper_controls .progress_bar .bar_segment {
  flex: 1;
  background-color: rgba(255, 255, 255, 0.3);
  transition: background-color 0.3s ease;
}
.main_swiper_controls .progress_bar .bar_segment.active {
  background-color: #fff;
}
.main_swiper_controls .nav_arrows {
  width: auto;
  height: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  cursor: pointer;
  transition: opacity 0.3s;
}
.main_swiper_controls .nav_arrows .prev_btn:hover,
.main_swiper_controls .nav_arrows .next_btn:hover {
  opacity: 0.7;
}
.main_swiper_controls .nav_arrows .prev_btn,
.main_swiper_controls .nav_arrows .next_btn {
  width: 29px;
  height: 29px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  transition: opacity 0.3s;
}
.main_swiper_controls .nav_arrows .prev_btn:hover,
.main_swiper_controls .nav_arrows .next_btn:hover {
  opacity: 0.7;
}
.main_swiper_controls .nav_arrows .prev_btn img,
.main_swiper_controls .nav_arrows .next_btn img {
  height: 100%;
  width: 100%;
}
/* ========================================================================== */
/* ========================= Mobile Responsive ============================== */
/* ========================================================================== */
/* content overrides removed to support HTML picture tag */
@media all and (max-width: 459px) {
  .section_1 {
    width: 100%;
    height: auto;
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    overflow: hidden;
    background: #34596d;
  }
  .section_1 .swiper_wrapper {
    width: 100%;
    max-height: 860px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding-top: 40px;
  }
  .main_swiper_controls_wrapper {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  .moto_wrapper {
    padding: 0 16px;
    width: 100%;
    height: auto;
  }
  .moto_wrapper p {
    padding: 0;
    margin: 0;
  }
  .moto_wrapper p span:first-child {
    color: #b1fafd;
    font-family: 'Righteous';
    font-size: 16.386px;
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
  }
  .moto_wrapper p span:last-child {
    color: #b1fafd;
    font-family: 'Righteous';
    font-size: 36.783px;
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
  }
  /* ========================================================================== */
  /* ========================= right_controls_wrapper ========================= */
  /* ========================================================================== */
  .right_controls_wrapper {
    width: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 0 16px;
    margin: 0;
  }
  .right_controls_wrapper .section_1_car_image {
    width: 150px;
    height: 150px;
    aspect-ratio: 1/1;
    object-fit: contain;
    padding: 0;
    margin: 0;
  }
  .main_visual_swiper .slide_item img {
    aspect-ratio: auto;
    object-fit: cover;
  }
  /* ========================================================================== */
  /* ========================= Main Visual Swiper Controls ==================== */
  /* ========================================================================== */
  .main_swiper_controls {
    width: auto;
    height: auto;
    display: inline-flex;
    padding: 16px 0;
    align-items: center;
    gap: 16px;
  }
  .main_swiper_controls .swiper_progress {
    width: 203px;
    height: auto;
    display: flex;
    align-items: center;
    gap: 16px;
  }
  .main_swiper_controls .number_indicator {
    color: #fff;
    font-family: 'Hanwha', sans-serif;
    font-size: 16px;
    font-style: normal;
    font-weight: 300;
    line-height: normal;
  }
  .main_swiper_controls .progress_bar {
    display: flex;
    width: 150px;
    height: 0.75px;
    background-color: rgba(255, 255, 255, 0.3);
  }
  .main_swiper_controls .progress_bar .bar_segment {
    flex: 1;
    background-color: rgba(255, 255, 255, 0.3);
    transition: background-color 0.3s ease;
  }
  .main_swiper_controls .progress_bar .bar_segment.active {
    background-color: #fff;
  }
  .main_swiper_controls .nav_arrows {
    width: auto;
    height: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    cursor: pointer;
    transition: opacity 0.3s;
  }
  .main_swiper_controls .nav_arrows .prev_btn:hover,
  .main_swiper_controls .nav_arrows .next_btn:hover {
    opacity: 0.7;
  }
  .main_swiper_controls .nav_arrows .prev_btn,
  .main_swiper_controls .nav_arrows .next_btn {
    width: 29px;
    height: 29px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    transition: opacity 0.3s;
  }
  .main_swiper_controls .nav_arrows .prev_btn:hover,
  .main_swiper_controls .nav_arrows .next_btn:hover {
    opacity: 0.7;
  }
  .main_swiper_controls .nav_arrows .prev_btn img,
  .main_swiper_controls .nav_arrows .next_btn img {
    height: 100%;
    width: 100%;
  }
}
@media all and (max-width: 1400px) {
  .main_swiper_controls {
    left: 100px;
  }
}
@media all and (max-width: 1200px) {
  .main_swiper_controls {
    left: 70px;
  }
}
