@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@500;700&family=Noto+Sans+JP:wght@100..900&display=swap");

/*==========================================================================
# reset - ブラウザの差異や不要なスタイルを無くすためのスタイル
========================================================================== */
* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
small,
button,
time,
figure {
  border: 0;
  font: inherit;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

html {
  line-height: 1;
}

@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}

ol,
ul {
  list-style: none;
}

li,
dd {
  list-style-type: none;
}

header,
footer,
nav,
section,
article,
aside,
figure,
figcaption {
  display: block;
}

img {
  border: none;
  vertical-align: bottom;
}

a {
  cursor: pointer;
  text-decoration: none;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  color: #000000;
  font-size: 17px;
  background-color: #f6f6f6;
  letter-spacing: 0.05rem;
}

@media screen and (max-width: 767px) {
  body {
    font-size: 14px;
  }
}

.breadcrumb {
  margin-bottom: 90px;
}

@media screen and (max-width: 767px) {
  .breadcrumb {
    margin-bottom: 60px;
  }
}

.breadcrumb a {
  color: #000;
  margin-left: 5%;
}

.top-content {
  position: relative;
  padding-bottom: 100px;
  z-index: 2;
  background: url(../img/top-bg.jpg) no-repeat top center/cover;
}

.schedule-content {
  position: relative;
  z-index: 2;
  background: url(../img/schedule/schedule-bg.jpg) no-repeat top -10px center/cover;
}

@media screen and (max-width: 767px) {
  .schedule-content {
    background: url(../img/schedule/schedule-bg-sp.jpg) no-repeat top -10px center/cover;
  }
}

.inner {
  padding: 0 60px;
  max-width: 1500px;
  margin: 0 auto;
}

@media (min-width: 768px) and (max-width:1160px) {
  .inner {
    padding: 0 40px;
  }
}

@media screen and (max-width: 767px) {
  .inner {
    padding: 0 20px;
  }
}

.inner-s {
  padding: 0 100px;
  max-width: 1320px;
  margin: 0 auto;
}

@media (min-width: 768px) and (max-width:1160px) {
  .inner-s {
    padding: 0 40px;
  }
}

@media screen and (max-width: 767px) {
  .inner-s {
    padding: 0 20px;
  }
}

img {
  width: 100%;
}

.pc-none {
  display: none;
}

@media (min-width: 768px) and (max-width:1160px) {
  .pc-none {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  .pc-none {
    display: block;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .sp-none {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .sp-none {
    display: none;
  }
}

.section-title {
  font-size: 24px;
  font-weight: 500;
  letter-spacing: 0.05rem;
  text-align: center;
  line-height: 2;
  padding-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .section-title {
    font-size: 20px;
  }
}

.screen-out {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 0 !important;
  height: 0 !important;
  line-height: 0 !important;
  overflow: hidden !important;
  text-indent: -9999px !important;
  white-space: nowrap !important;
}

.cookie__section {
  display: none;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  background: #f9eae8;
  z-index: 20000;
}

.cookie__area {
  max-width: 1200px;
  margin: 0 auto;
  padding: 16px 20px;
}

.cookie__group {
  position: relative;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.2);
  padding: 18px 20px 16px;
}

.cookie__msg__title {
  display: block;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.5;
}

.cookie__msg__desc {
  margin-top: 10px;
  font-size: 14px;
  line-height: 1.7;
}

.cookie__msg__desc__btn {
  display: inline;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  text-decoration: underline;
  cursor: pointer;
}

.cookie__btns__section {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 14px;
}

.cookie__btns__section .js-cookie-popbtn {
  border: 0;
  border-radius: 999px;
  padding: 10px 14px;
  background: #111;
  color: #fff;
  cursor: pointer;
}

.cookie__btns__section .js-cookie-popbtn[data-cookie="1"] {
  background: #fff;
  color: #111;
  border: 1px solid #111;
}

.cookie__close {
  width: 24px;
  height: 24px;
  position: absolute;
  top: 14px;
  right: 14px;
  background: url(https://japanese.visitkorea.or.kr/static/front/images/ico/ico_X_24_warmGrey.svg) no-repeat center/contain;
}

.popup__cookie__section {
  z-index: 30000;
}

.popup__cookie__section.is-active {
  display: block;
}

.popup__section {
  width: 100%;
  height: calc(var(--vh, 1vh) * 100);
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 20000;
}

.popup__dim {
  background: #000;
  opacity: 0.55;
}

.popup__inner,
.popup__dim {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.popup__cookie__section .popup__inner {
  justify-content: flex-start;
}

.popup__inner {
  display: flex;
  justify-content: center;
  align-items: center;
}

@media (max-width: 1200px) {
  .popup__inner {
    align-items: flex-end;
  }
}

@keyframes cookiePopOpen {
  from {
    opacity: 0;
    transform: translate3d(-12px, 0, 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes popupYmove {
  from {
    transform: translate3d(0, 18px, 0);
    opacity: 0;
  }

  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

.popup__cookie__section .popup__container__group {
  width: 100%;
  height: 100%;
  max-width: 420px;
  max-height: 100%;
  background: transparent;
  border-radius: 0;
  overflow: hidden;
  animation: cookiePopOpen 0.3s forwards;
}

@media (max-width: 1200px) {
  .popup__container__group {
    max-height: 95%;
    border-radius: 20px 20px 0 0;
    animation: popupYmove 0.5s 0.2s forwards;
  }
}

.popup__container__group {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  background: #fff;
  overflow-y: auto;
  opacity: 1;
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.2);
}

.popup__cookie__header {
  margin-top: 44px;
  flex-shrink: 0;
  padding: 0 20px;
}

.popup__cookie__header .title {
  display: block;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.5;
}

.popup__cookie__header .desc {
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.7;
}

.popup__cookie__header+.popup__cookie__btns {
  margin-top: 30px;
}

.popup__cookie__btns {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  gap: 12px;
  padding: 0 20px;
  flex-wrap: wrap;
}

.popup__cookie__btns button {
  border: 0;
  background: transparent;
  cursor: pointer;
}

.popup__cookie__btns button.rounded {
  border-radius: 999px;
  padding: 10px 14px;
  background: #111;
  color: #fff;
  min-width: 220px;
}

.popup__cookie__btns button.underline {
  text-decoration: underline;
}

.popup__cookie__btns+.popup__cookie__conts {
  margin-top: 30px;
}

@media (max-width: 1200px) {
  .popup__cookie__btns+.popup__cookie__conts {
    margin-top: 40px;
  }
}

.popup__cookie__conts {
  margin-top: 30px !important;
  overflow-y: auto;
  padding: 0 20px 20px;
}

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

.popup__cookie__conts__item {
  border-top: 1px solid rgba(0, 0, 0, 0.08);
  padding: 16px 0;
}

.popup__cookie__conts__item .item-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.popup__cookie__conts__item .item-title .title {
  font-weight: 700;
  font-size: 15px;
}

.popup__cookie__conts__item .item-desc {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.7;
  color: rgba(0, 0, 0, 0.78);
}

.popup__cookie__conts__item a {
  color: inherit;
  text-decoration: underline;
}

.toggle__group input[type=checkbox] {
  width: 44px;
  height: 24px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.12);
  position: relative;
  appearance: none;
  cursor: pointer;
}

.toggle__group input[type=checkbox]::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
  transition: transform 0.2s ease;
}

.toggle__group input[type=checkbox]:checked {
  background: #111;
}

.toggle__group input[type=checkbox]:checked::after {
  transform: translateX(20px);
}

.popup__cookie__group {
  display: flex;
  flex-direction: column;
  position: relative;
  min-height: 100%;
  background: #fff;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.16);
  padding-top: 52px;
}

@media (max-width: 1200px) {
  .popup__cookie__group {
    padding: 104px 20px 0;
  }
}

.popup__cookie__close {
  width: 24px;
  height: 24px;
  position: absolute;
  z-index: 10;
  top: 20px;
  right: 20px;
  background: url(https://japanese.visitkorea.or.kr/static/front/images/ico/ico_X_24_warmGrey.svg) no-repeat center/contain;
}

header {
  position: fixed;
  z-index: 800;
  width: 90%;
  min-width: 1080px;
  left: 50%;
  transform: translateX(-50%);
  top: 40px;
  background-color: rgba(255, 255, 255, 0.9);
  border-radius: 50px;
  padding: 15px 30px;
}

@media (min-width: 768px) and (max-width:1160px) {
  header {
    min-width: auto;
    width: 95%;
    top: 30px;
  }
}

@media screen and (max-width: 767px) {
  header {
    width: calc(100% - 30px);
    min-width: auto;
    top: 20px;
  }
}

.header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.header-inner .header-left {
  width: 22%;
}

@media (min-width: 768px) and (max-width:1160px) {
  .header-inner .header-left {
    width: 40%;
  }
}

@media screen and (max-width: 767px) {
  .header-inner .header-left {
    width: 100%;
  }
}

.header-inner .header-right {
  display: flex;
  align-items: center;
  justify-content: end;
  gap: 12px;
}

.header-nav {
  display: flex;
  align-items: center;
  gap: 30px;
}

@media (min-width: 768px) and (max-width:1160px) {
  .header-nav {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .header-nav {
    display: none;
  }
}

.header-nav li {
  position: relative;
}

.header-nav li:not(:first-child)::after {
  position: absolute;
  content: "";
  width: 1px;
  height: 20px;
  background-color: #000000;
  left: -15px;
}

.header-nav li a {
  color: #000000;
  font-size: 17px;
}

.header-right-logo {
  width: 15%;
  margin-left: 15px;
}

@media (min-width: 768px) and (max-width:1160px) {
  .header-right-logo {
    width: 25%;
  }
}

@media screen and (max-width: 767px) {
  .header-right-logo {
    width: 50%;
  }
}

/*-------------=====
mobile menu
=================*/
.header-hamburger {
  display: none;
  width: 20px;
  height: 18px;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  position: relative;
  z-index: 1001;
}

@media screen and (max-width: 767px) {
  .header-hamburger {
    display: flex;
  }
}

.header-hamburger .hb-line {
  position: absolute;
  left: 0;
  width: 20px;
  height: 2px;
  background-color: #000;
  border-radius: 2px;
  transform-origin: center;
  transition: transform 0.25s ease, opacity 0.2s ease;
}

.header-hamburger .hb-line:nth-child(1) {
  top: 0;
}

.header-hamburger .hb-line:nth-child(2) {
  top: 8px;
}

.header-hamburger .hb-line:nth-child(3) {
  bottom: 0;
}

.mobile-content {
  display: none;
  flex-direction: column;
  align-items: center;
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  min-height: 100vh;
  z-index: 900;
  padding: 100px 12px calc(12px + env(safe-area-inset-bottom, 0px));
  border-radius: 0;
  border: 0;
  background: url(../img/top-bg.jpg) no-repeat center/cover;
  overflow: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: contain;
}

@supports (height: 100dvh) {
  .mobile-content {
    min-height: 100dvh;
  }
}

.mobile-menu {
  display: none;
  position: fixed;
  top: 100px;
  left: 50%;
  transform: translateX(-50%);
  width: 90%;
  max-height: calc(100vh - 100px - env(safe-area-inset-bottom, 0px));
  z-index: 900;
  padding: 0;
  border-radius: 0;
  background: #fff;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: contain;
}

@supports (height: 100dvh) {
  .mobile-menu {
    max-height: calc(100dvh - 100px - env(safe-area-inset-bottom, 0px));
  }
}

.mobile-content .mobile-menu {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  width: 90%;
  max-width: 100%;
  position: static;
  transform: none;
  left: auto;
  top: auto;
  background: #fff;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: contain;
  z-index: auto;
}

.mobile-menu-nav {
  display: flex;
  flex-direction: column;
}

.mobile-menu-nav .mobile-menu-li {
  padding: 15px 0;
}

.mobile-menu-nav .mobile-menu-li a {
  padding-left: 20px;
}

.mobile-menu-nav .mobile-menu-li:not(:last-child) {
  border-bottom: 1px solid #999999;
}

.mobile-menu-nav .mobile-menu-li li {
  list-style-type: disc;
}

.mobile-menu-nav a {
  color: #000;
  font-size: 17px;
  font-weight: 700;
}

.mobile-menu-nav-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.mobile-menu-nav-link {
  flex: 1;
  min-width: 0;
}

.mobile-menu-subtoggle {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  padding: 0;
  -webkit-appearance: none;
  appearance: none;
  border: 0;
  background: transparent;
  cursor: pointer;
  position: relative;
}

.mobile-menu-subtoggle::before,
.mobile-menu-subtoggle::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 14px;
  height: 2px;
  background: #6eaaff;
  transform: translate(-50%, -50%);
}

.mobile-menu-subtoggle::after {
  transform: translate(-50%, -50%) rotate(90deg);
  transition: opacity 0.2s ease;
}

.mobile-menu-nav-item.is-open .mobile-menu-subtoggle::after {
  opacity: 0;
}

.mobile-menu-sub {
  padding: 15px 20px 15px 30px;
  background: linear-gradient(to bottom, #ffe7dd, #ffffea);
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

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

.mobile-menu-sub li {
  padding-bottom: 10px;
}

.mobile-menu-sub a {
  font-size: 15px;
  font-weight: 600;
  padding-left: 0 !important;
}

.mobile-menu-nav .mobile-menu-li .mobile-menu-sub--plan {
  list-style: none;
}

.mobile-menu-nav .mobile-menu-li .mobile-menu-sub--plan li {
  list-style: none;
}

.mobile-menu-plan-item {
  padding-bottom: 0;
}

.mobile-menu-plan-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
  text-decoration: none;
  color: inherit;
}

.mobile-menu-plan-card:focus-visible {
  outline: 2px solid #6eaaff;
  outline-offset: 2px;
}

.mobile-menu-plan-title {
  display: block;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.35;
}

.mobile-menu-plan-drawer {
  display: flex;
  flex-direction: row;
  gap: 8px;
  align-items: stretch;
}

.mobile-menu-plan-thumb {
  flex: 1;
  min-width: 0;
  border-radius: 4px;
  overflow: hidden;
  line-height: 0;
  background: rgba(0, 0, 0, 0.04);
}

.mobile-menu-plan-thumb img {
  width: 100%;
  object-fit: cover;
  display: block;
}

header.is-menu-open {
  z-index: 1000;
}

header.is-menu-open .mobile-content {
  display: flex;
}

header.is-menu-open .mobile-menu {
  display: block;
}

header.is-menu-open {
  /* 3本線 -> 2本だけにして回転し、バツに */
}

header.is-menu-open .header-hamburger .hb-line:nth-child(1) {
  top: 8px;
  transform: rotate(45deg);
}

header.is-menu-open .header-hamburger .hb-line:nth-child(2) {
  opacity: 0;
}

header.is-menu-open .header-hamburger .hb-line:nth-child(3) {
  top: 8px;
  transform: rotate(-45deg);
}

header.is-menu-open .mobile-content .mobile-menu,
.mobile-content.is-active .mobile-menu {
  display: flex;
  flex-direction: column;
}

/* jQuery風の is-active 制御（バツが見えない時の保険） */
.mobile-content.is-active {
  display: flex;
}

.mobile-menu.is-active {
  display: block;
}

.header-hamburger.is-active .hb-line:nth-child(1) {
  top: 8px;
  transform: rotate(45deg);
}

.header-hamburger.is-active .hb-line:nth-child(2) {
  opacity: 0;
}

.header-hamburger.is-active .hb-line:nth-child(3) {
  top: 8px;
  transform: rotate(-45deg);
}

/*-------------=====

footer-banner

=================*/
.footer-banner {
  padding: 60px 0;
  background-color: #fAFAFA;
}

@media screen and (max-width: 767px) {
  .footer-banner {
    padding: 40px 0;
  }
}

.footer-banner-wrap {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  gap: 10px 20px;
  margin-top: 40px;
}

.banner-item {
  width: calc((100% - 60px) / 4);
  flex-shrink: 0;
}

@media screen and (max-width: 767px) {
  .banner-item {
    width: calc((100% - 20px) / 2);
  }
}

/*-------------=====

footer

=================*/
footer {
  background-color: #fAFAFA;
  padding: 60px 0;
}

@media screen and (max-width: 767px) {
  footer {
    padding: 30px 0;
  }

  footer p {
    font-size: 10px;
    padding-bottom: 5px;
  }
}

.footer-wrap {
  display: flex;
  justify-content: space-between;
}

.footer-column1 {
  width: 30%;
  position: relative;
}

@media screen and (max-width: 767px) {
  .footer-column1 {
    width: auto;
  }
}

.footer-column1 p {
  font-size: 14px;
  line-height: 1.5;
  color: #999999;
}

@media screen and (max-width: 767px) {
  .footer-column1 p {
    font-size: 10px;
  }
}

.footer-logo {
  display: inline-block;
  width: 40%;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .footer-logo {
    width: 70%;
    margin-top: 20px;
  }
}

.footer-sns-wrap {
  display: flex;
  gap: 5px;
  position: absolute;
  bottom: 0;
  left: 0;
}

@media screen and (max-width: 767px) {
  .footer-sns-wrap {
    position: static;
    margin-top: 20px;
  }
}

.footer-sns-item {
  width: 35px;
}

.footer-column-title {
  font-size: 18px;
  font-weight: 500;
  padding-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .footer-column-title {
    font-size: 12px;
    padding-top: 20px;
  }
}

.footer-column-content li {
  padding-top: 13px;
}

.footer-column-content li.list-bold {
  font-weight: 700;
}

.footer-column-content li.list-bold a {
  color: #000;
}

@media screen and (max-width: 767px) {
  .footer-column-content li.list-bold a {
    font-size: 11px;
  }
}

.footer-column-content li a {
  color: #999999;
}

@media screen and (max-width: 767px) {
  .footer-column-content li a {
    font-size: 11px;
  }
}

.footer-column-content li a {
  transition: 0.3s;
}

.footer-column-content li a:hover {
  opacity: 0.6;
}

.footer-column-content li a img {
  width: 15px;
  margin-left: 5px;
}

@media screen and (max-width: 767px) {
  .footer-column-content li a img {
    width: 10px;
  }
}

/*-------------=====

fv

=================*/
@keyframes fv-content-fade-in {
  from {
    opacity: 0;
    transform: translateY(18px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.fv {
  width: 95%;
  position: relative;
  margin: 0 auto;
  height: calc(100vh - 60px);
  display: flex;
  flex-direction: column;
}

@media screen and (max-width: 767px) {
  .fv {
    width: calc(100% - 40px);
  }
}

.fv-swiper-wrap {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  position: relative;
}

.fv-swiper {
  flex: 1;
  min-height: 0;
  width: 100%;
  position: relative;
}

.fv-swiper .swiper-wrapper {
  height: 100%;
}

.fv-slide {
  height: 100%;
  position: relative;
}

.fv-slide-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 0 0 40px 40px;
}

.fv-slide.fv-1 .fv-slide-bg {
  background-image: url(../img/fv-3.png);
}

.fv-slide.fv-2 .fv-slide-bg {
  background-image: url(../img/fv4.png);
}

.fv4-sp {
  display: none;
}

.fv4-pc {
  display: block;
}

@media screen and (max-width: 767px) {
  .fv4-pc {
    display: none;
  }
}

.fv-slide.fv-2 .fv4-pc {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px 8px 40px;
}

.fv-slide.fv-2 .fv4-pc .fv4-content {
  width: 100%;
  height: auto;
}

.fv-slide.fv-2 .fv4-pc .fv4-pc-btn {
  position: absolute;
  right: 32px;
  bottom: 52px;
  width: 288px;
  max-width: 40vw;
  height: auto;
  cursor: pointer;
  display: block;
  line-height: 0;
  text-decoration: none;
}

.fv-slide.fv-2 .fv4-pc .fv4-pc-btn img {
  width: 100%;
  height: auto;
  display: block;
}

@media screen and (max-width: 767px) {
  .fv4-sp {
    display: block;
  }

  .fv-slide.fv-2 .fv4-pc {
    display: none;
  }

  /* スマホ用FV画像に差し替え */
  .fv-slide.fv-1 .fv-slide-bg {
    background-image: url(../img/fv-3-sp.png);
  }

  .fv-slide.fv-2 .fv-slide-bg {
    background-image: url(../img/fv4-sp.png);
  }

  .fv-slide.fv-2 .fv4-sp {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 28px;
    padding: 24px 8px 40px;
  }

  .fv-slide.fv-2 .fv4-sp .fv4-sp-content {
    width: min(96%, 440px);
    height: auto;
  }

  .fv-slide.fv-2 .fv4-sp .fv4-sp-btn {
    width: min(78%, 300px);
    max-width: none;
    height: auto;
    cursor: pointer;
    display: block;
    line-height: 0;
    text-decoration: none;
  }

  .fv-slide.fv-2 .fv4-sp .fv4-sp-btn img {
    width: 100%;
    height: auto;
    display: block;
  }
}

.fv-slide-nav {
  position: absolute;
  right: 40px;
  bottom: 0px;
  z-index: 10;
  display: flex;
  gap: 2px;
  align-items: center;
}

.fv-prev,
.fv-next {
  width: 44px;
  height: 44px;
  padding: 0;
  border: none;
  border-radius: 0;
  background: #333;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.12);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, opacity 0.2s;
}

.fv-prev:hover,
.fv-next:hover {
  background: #333;
}

.fv-prev::after,
.fv-next::after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
}

.fv-prev::after {
  transform: rotate(135deg);
  margin-left: 4px;
}

.fv-next::after {
  transform: rotate(-45deg);
  margin-right: 4px;
}

.fv-prev.swiper-button-disabled,
.fv-next.swiper-button-disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.fv-pagination-wrap {
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 14px 16px;
}

.fv-pagination.swiper-pagination-horizontal {
  position: relative !important;
  bottom: auto !important;
  left: auto !important;
  width: auto !important;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}

.fv-pagination .swiper-pagination-bullet {
  width: 40px;
  height: 4px;
  margin: 0 !important;
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.2);
  opacity: 1;
  transition: background 0.25s;
}

.fv-pagination .swiper-pagination-bullet-active {
  background: #ff87a0;
}

.fv-content {
  position: absolute;
  width: 490px;
  bottom: 100px;
  left: 80px;
  z-index: 1;
  opacity: 0;
  animation: fv-content-fade-in 1.1s ease-out 0.25s forwards;
}

@media (prefers-reduced-motion: reduce) {
  .fv-content {
    opacity: 1;
    animation: none;
    transform: none;
  }
}

@media screen and (max-width: 767px) {
  .fv-content {
    width: 100%;
    bottom: auto;
    top: 100px;
    left: 0;
  }
}

.fv-content .fv-logo {
  width: 72%;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .fv-content .fv-logo {
    width: 55%;
  }
}

.fv-content p {
  padding-top: 40px;
  text-align: center;
  line-height: 2;
}

@media screen and (max-width: 767px) {
  .fv-content p {
    padding-top: 20px;
    letter-spacing: 0.01rem;
    font-size: 11.5px;
  }
}

/*-------------=====

type

=================*/
@keyframes type-cloud-float-pc {

  0%,
  100% {
    transform: translate(0, 0);
  }

  25% {
    transform: translate(14px, -12px);
  }

  50% {
    transform: translate(-10px, 14px);
  }

  75% {
    transform: translate(12px, 8px);
  }
}

@keyframes type-cloud-float-sp1 {

  0%,
  100% {
    transform: translate(0, 0);
  }

  33% {
    transform: translate(10px, -10px);
  }

  66% {
    transform: translate(-12px, 8px);
  }
}

@keyframes type-cloud-float-sp2 {

  0%,
  100% {
    transform: translate(0, 0);
  }

  33% {
    transform: translate(-12px, 12px);
  }

  66% {
    transform: translate(14px, -8px);
  }
}

.type {
  position: relative;
  padding: 180px 0;
  z-index: 1;
}

@media (min-width: 768px) and (max-width:1160px) {
  .type {
    padding: 120px 0;
  }
}

@media screen and (max-width: 767px) {
  .type {
    padding: 100px 0;
  }
}

.type-bg {
  position: absolute;
  z-index: -1;
  width: 100%;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
}

.type-bg .type-bg-sp {
  display: none;
}

.type-bg .type-bg-pc {
  display: block;
  width: 100%;
  height: auto;
  animation: type-cloud-float-pc 24s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
  .type-bg .type-bg-pc {
    animation: none;
  }
}

@media screen and (max-width: 767px) {
  .type-bg {
    top: 0;
    width: 100%;
    height: 100%;
    transform: none;
  }

  .type-bg .type-bg-pc {
    display: none;
  }

  .type-bg .type-bg-sp {
    display: block;
    width: 100%;
    height: auto;
  }

  .type-bg .type-bg-sp-1 {
    position: absolute;
    top: 0;
    left: 0;
    animation: type-cloud-float-sp1 28s ease-in-out infinite;
  }
}

@media screen and (max-width: 767px) and (prefers-reduced-motion: reduce) {
  .type-bg .type-bg-sp-1 {
    animation: none;
  }
}

@media screen and (max-width: 767px) {
  .type-bg .type-bg-sp-2 {
    position: absolute;
    bottom: 0;
    left: 0;
    animation: type-cloud-float-sp2 34s ease-in-out infinite;
  }
}

@media screen and (max-width: 767px) and (prefers-reduced-motion: reduce) {
  .type-bg .type-bg-sp-2 {
    animation: none;
  }
}

.type-box {
  width: 800px;
  margin: 0 auto;
  border: 3px solid #ff87a0;
  border-radius: 40px;
  padding: 60px 40px;
  background-color: rgba(255, 255, 255, 0.6);
}

@media (min-width: 768px) and (max-width:1160px) {
  .type-box {
    width: calc(100% - 40px);
  }
}

@media screen and (max-width: 767px) {
  .type-box {
    width: calc(100% - 40px);
    padding: 40px 20px;
  }
}

.type-box p {
  text-align: center;
  line-height: 2;
  padding-bottom: 30px;
}

@media screen and (max-width: 767px) {
  .type-box p {
    padding-bottom: 20px;
    font-size: 12px;
  }
}

.type-message {
  text-align: center;
  line-height: 2;
  font-size: 24px;
  font-weight: 500;
  padding-bottom: 30px;
}

@media screen and (max-width: 767px) {
  .type-message {
    padding-bottom: 20px;
  }
}

.type-title {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 80%;
  margin: 0 auto;
  padding-bottom: 10px;
  position: relative;
}

@media (min-width: 768px) and (max-width:1160px) {
  .type-title {
    gap: 8px 12px;
  }
}

@media screen and (max-width: 767px) {
  .type-title {
    gap: 6px 8px;
  }
}

.type-title img {
  display: block;
  width: calc((100% - 30px) / 7);
  height: auto;
  flex-shrink: 0;
}

.type-title .type-glass {
  position: absolute;
  width: 50px;
  right: -30px;
  bottom: 0;
}

@media screen and (max-width: 767px) {
  .type-title .type-glass {
    width: 30px;
    right: -40px;
  }
}

.type-title .type-glass img {
  width: 100%;
}

.type-btn {
  width: 270px;
  height: 50px;
  border: 2px solid #ff87a0;
  border-radius: 30px;
  margin: 0 auto;
  background: linear-gradient(to right, #d0ffff, #e7ecff, #ffd8ff);
}

.type-btn a {
  width: 100%;
  height: 100%;
  display: inline-block;
  text-align: center;
  padding-top: 15px;
  letter-spacing: 0.2rem;
  color: #000;
}

.type-btn a img {
  width: 15px;
  vertical-align: middle;
  margin-bottom: 5px;
}

/*-------------=====

travel

=================*/
.travel {
  position: relative;
  z-index: 1;
}

.travel.travel--no-type {
  padding-top: 140px;
}

@media screen and (max-width: 767px) {
  .travel.travel--no-type {
    padding-top: 80px;
  }
}

.travel-title-wrap {
  width: 1000px;
  margin: 0 auto;
  display: flex;
  align-items: start;
  justify-content: center;
  gap: 20px;
  padding-bottom: 30px;
}

@media (min-width: 768px) and (max-width:1160px) {
  .travel-title-wrap {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .travel-title-wrap {
    width: 100%;
    align-items: center;
    gap: 2%;
    padding-bottom: 10px;
  }
}

.travel-title-right {
  width: 220px;
  position: relative;
  height: 295px;
}

@media screen and (max-width: 767px) {
  .travel-title-right {
    width: 45%;
    height: 200px;
  }
}

.travel-title-left {
  width: 260px;
  position: relative;
  height: 300px;
  margin-top: -15px;
}

@media screen and (max-width: 767px) {
  .travel-title-left {
    width: 53%;
    height: 200px;
  }
}

.travel-line {
  position: absolute;
  inset: 0;
  height: 260px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  z-index: 0;
}

@media screen and (max-width: 767px) {
  .travel-line {
    height: 180px;
  }
}

.travel-line img {
  width: auto;
  height: 100%;
  display: block;
}

.travel-line-left {
  top: 10px;
}

@media screen and (max-width: 767px) {
  .travel-line-left {
    top: -10px;
    right: 0;
    width: 90%;
  }
}

@media screen and (max-width: 767px) {
  .travel-line-right {
    top: -15px;
    left: 0;
    width: 110%;
  }
}

.travel-icons-left,
.travel-icons-right {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

.travel-icons-left img,
.travel-icons-right img {
  position: absolute;
  width: 56px;
  height: auto;
  display: block;
  transform-origin: center center;
}

@media screen and (max-width: 767px) {

  .travel-icons-left img,
  .travel-icons-right img {
    width: 34px;
  }
}

.travel-icons-left img:nth-child(1) {
  right: 10px;
  top: -60px;
}

.travel-icons-left img:nth-child(2) {
  top: 15%;
  right: 30%;
}

.travel-icons-left img:nth-child(3) {
  top: 20%;
  width: 25px;
  right: 0;
}

.travel-icons-left img:nth-child(4) {
  top: 35%;
  width: 50px;
}

.travel-icons-left img:nth-child(5) {
  top: 45%;
  width: 80px;
  left: 40%;
}

.travel-icons-left img:nth-child(6) {
  bottom: 12%;
  right: 30%;
  width: 100px;
}

.travel-icons-right img:nth-child(1) {
  top: -10%;
  left: 0;
  width: 65px;
}

.travel-icons-right img:nth-child(2) {
  left: 20%;
  top: 38%;
  width: 90px;
}

.travel-icons-right img:nth-child(3) {
  top: 33%;
  width: 45px;
  right: -20px;
}

.travel-icons-right img:nth-child(4) {
  bottom: 0;
  left: 40%;
}

@media screen and (max-width: 767px) {
  .travel-icons-left img:nth-child(1) {
    right: 40px;
    top: -55px;
  }

  .travel-icons-left img:nth-child(2) {
    top: 10%;
    right: 35%;
  }

  .travel-icons-left img:nth-child(3) {
    top: 17%;
    width: 18px;
    right: 10%;
  }

  .travel-icons-left img:nth-child(4) {
    top: 31%;
    width: 32px;
  }

  .travel-icons-left img:nth-child(5) {
    top: 37%;
    width: 50px;
    left: 34%;
  }

  .travel-icons-left img:nth-child(6) {
    bottom: 18%;
    right: 25%;
    width: 60px;
  }

  .travel-icons-right img:nth-child(1) {
    top: -20%;
    left: 10%;
    width: 45px;
  }

  .travel-icons-right img:nth-child(2) {
    left: 25%;
    top: 35%;
    width: 52px;
  }

  .travel-icons-right img:nth-child(3) {
    top: 29%;
    width: 28px;
    right: -10px;
  }

  .travel-icons-right img:nth-child(4) {
    bottom: 5%;
    left: 34%;
  }
}

.travel-title-icon {
  position: absolute;
  left: 50%;
  bottom: 32px;
  transform: translateX(-50%);
  z-index: 1;
  max-width: 100%;
  height: auto;
  display: block;
}

.travel-title-center {
  width: 540px;
}

@media (min-width: 768px) and (max-width:1160px) {
  .travel-title-center {
    margin: -40px auto 40px auto;
  }
}

@media screen and (max-width: 767px) {
  .travel-title-center {
    margin: -20px auto 0 auto;
    width: auto;
  }
}

.travel-title-center h2 {
  font-size: 24px;
  font-weight: 500;
  text-align: center;
  line-height: 2;
  padding-bottom: 30px;
}

@media screen and (max-width: 767px) {
  .travel-title-center h2 {
    font-size: 20px;
    padding-bottom: 20px;
  }
}

.border-text {
  width: 100%;
  font-weight: 500;
  font-size: 17px;
  text-align: center;
  padding: 15px 0;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
}

.travel-content {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 60px 30px;
}

@media (min-width: 768px) and (max-width:1160px) {
  .travel-content {
    gap: 40px 20px;
  }
}

@media screen and (max-width: 767px) {
  .travel-content {
    display: block;
    margin-top: 30px;
  }
}

.travel-item {
  width: calc((100% - 60px) / 3);
}

@media (min-width: 768px) and (max-width:1160px) {
  .travel-item {
    width: calc((100% - 20px) / 2);
  }
}

@media screen and (max-width: 767px) {
  .travel-item {
    width: 100%;
    margin-bottom: 40px;
  }
}

.travel-item-title {
  width: 80%;
  margin: 0 auto;
  position: relative;
  z-index: 3;
}

.travel-item-img {
  border-radius: 30px;
  aspect-ratio: 10/6;
  margin-top: -20px;
}

.travel-item-img img {
  border-radius: 30px;
  object-fit: cover;
  height: 100%;
}

.travel-tag-wrap {
  width: 100%;
  padding-top: 10px;
}

.travel-tag-wrap span {
  padding-left: 7px;
  letter-spacing: 0.01rem;
  font-size: 12px;
  line-height: 1.4;
  font-weight: 300;
}

.travel-btn-wrap {
  display: flex;
  gap: 10px;
  padding-top: 10px;
  justify-content: center;
}

.travel-item-btn {
  width: 50%;
  text-align: center;
  border: 2px solid #000;
  border-radius: 30px;
  max-width: 190px;
  transition: opacity 0.3s ease;
}

.travel-item-btn:hover {
  opacity: 0.85;
}

@media (prefers-reduced-motion: no-preference) {
  .travel-item-btn:hover a img {
    transform: translateX(6px);
  }
}

.travel-item-btn:first-child {
  background-color: #f6c8c7;
}

.travel-item-btn:last-child {
  background-color: #c5ddc2;
}

.travel-item-btn {
  /* ボタン1つのときは :first と :last が同一で緑が勝つため、おすすめコースと同じピンクに */
}

.travel-item-btn:first-child:last-child {
  background-color: #f6c8c7;
}

.travel-item-btn a {
  width: 100%;
  padding: 12px 0;
  display: inline-block;
  text-align: center;
  color: #000;
}

@media (min-width: 768px) and (max-width:1160px) {
  .travel-item-btn a {
    font-size: 12px;
  }
}

.travel-item-btn a img {
  display: inline-block;
  width: 15px;
  vertical-align: middle;
  margin-bottom: 5px;
  transition: transform 0.3s ease;
}

@media (min-width: 768px) and (max-width:1160px) {
  .travel-item-btn a img {
    width: 12px;
  }
}

/*-------------=====

plane

=================*/
.plane {
  position: relative;
  padding-top: 180px;
}

.plane h2 {
  width: 60%;
  margin: 0 auto;
  max-width: 900px;
}

@media screen and (max-width: 767px) {
  .plane h2 {
    width: 100%;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .plane {
    padding-top: 120px;
  }
}

@media screen and (max-width: 767px) {
  .plane {
    padding-top: 80px;
  }
}

.plane-content {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 15px;
  padding-top: 40px;
  padding-bottom: 10px;
}

.plane-item {
  width: calc((100% - 75px) / 6);
  position: relative;
  display: block;
  text-decoration: none;
}

@media (min-width: 768px) and (max-width:1160px) {
  .plane-item {
    width: calc((100% - 45px) / 4);
  }
}

@media screen and (max-width: 767px) {
  .plane-item {
    width: calc((100% - 15px) / 2);
  }
}

.plane-item img:first-child {
  position: relative;
  z-index: -1;
  width: 100%;
  height: auto;
}

.plane-item:nth-child(1) .plane-logo {
  top: 30%;
}

.plane-item:nth-child(2) .plane-logo {
  top: 30%;
}

.plane-item:nth-child(3) .plane-logo {
  top: 36%;
}

.plane-item:nth-child(4) .plane-logo {
  top: 28%;
}

.plane-item:nth-child(5) .plane-logo {
  top: 34%;
}

.plane-item:nth-child(6) .plane-logo {
  top: 25%;
}

.plane-item:nth-child(7) .plane-logo {
  top: 34%;
}

.plane-item:nth-child(8) .plane-logo {
  top: 28%;
}

.plane-item:nth-child(9) .plane-logo {
  top: 30%;
}

.plane-item:nth-child(10) .plane-logo {
  top: 35%;
}

.plane-item:nth-child(11) .plane-logo {
  top: 30%;
}

.plane-item:nth-child(12) .plane-logo {
  top: 20%;
}

.plane-item:nth-child(1) .plane-logo,
.plane-item:nth-child(2) .plane-logo,
.plane-item:nth-child(3) .plane-logo,
.plane-item:nth-child(4) .plane-logo,
.plane-item:nth-child(5) .plane-logo,
.plane-item:nth-child(6) .plane-logo,
.plane-item:nth-child(7) .plane-logo,
.plane-item:nth-child(8) .plane-logo,
.plane-item:nth-child(9) .plane-logo,
.plane-item:nth-child(10) .plane-logo,
.plane-item:nth-child(11) .plane-logo,
.plane-item:nth-child(12) .plane-logo {
  top: auto;
}

.plane-item .plane-inner {
  position: absolute;
  inset: 0;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
}

.plane-item .plane-logo {
  position: static;
  transform: none;
  margin-top: -15px;
  width: 100%;
  height: auto;
  display: block;
  max-height: 52px;
  object-fit: contain;
}

@media screen and (max-width: 767px) {
  .plane-item .plane-logo {
    max-height: 44px;
  }
}

.plane-item .plane-name {
  position: absolute;
  left: 50%;
  bottom: 38%;
  transform: translateX(-50%);
  display: block;
  width: 92%;
  text-align: center;
  font-weight: 700;
  color: #000;
  font-size: 14px;
  line-height: 1.2;
}

@media screen and (max-width: 767px) {
  .plane-item .plane-name {
    font-size: 10px;
  }
}

.plane-schedule {
  width: 300px;
  margin: 0 auto;
}

/*-------------=====

tour

=================*/
.tour {
  position: relative;
  padding-top: 180px;
  padding-bottom: 120px;
}

@media (min-width: 768px) and (max-width:1160px) {
  .tour {
    padding-top: 120px;
    padding-bottom: 80px;
  }
}

@media screen and (max-width: 767px) {
  .tour {
    padding-top: 100px;
    padding-bottom: 60px;
  }
}

.tour h2 {
  width: 60%;
  margin: 0 auto;
  max-width: 900px;
}

@media screen and (max-width: 767px) {
  .tour h2 {
    width: 100%;
  }
}

.tour-schedule {
  width: 300px;
  margin: 0 auto;
}

.tour-content {
  padding-top: 30px;
  display: flex;
  flex-wrap: wrap;
  gap: 30px 15px;
}

.tour-item {
  display: block;
  width: calc((100% - 45px) / 4);
  text-decoration: none;
  color: inherit;
  transition: opacity 0.3s ease;
}

@media screen and (max-width: 767px) {
  .tour-item {
    width: calc((100% - 15px) / 2);
  }
}

.tour-item:hover {
  opacity: 0.85;
}

.tour-item:hover .shadow {
  opacity: 0;
}

.tour-item-img {
  position: relative;
}

.tour-item-img>img {
  display: block;
  width: 100%;
  position: relative;
  z-index: 3;
}

.shadow {
  position: absolute;
  bottom: -8px;
  left: 50%;
  transform: translateX(-50%);
  width: 102%;
  height: 100%;
  z-index: 2;
  opacity: 1;
  transition: opacity 0.3s ease;
}

.more-btn {
  text-align: center;
  margin-top: 15px;
  color: #000;
}

.more-btn img {
  width: 12px;
  margin-left: 5px;
  vertical-align: middle;
}

/*-------------=====

instagram

=================*/
.instagram h2 {
  width: 50%;
  margin: 0 auto;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .instagram h2 {
    width: 100%;
  }
}

.instagram-box {
  padding: 60px;
  border-radius: 40px;
  background: url(../img/insta-bg.jpg) no-repeat center center/cover;
  text-align: center;
}

@media (min-width: 768px) and (max-width:1160px) {
  .instagram-box {
    padding: 40px;
  }
}

@media screen and (max-width: 767px) {
  .instagram-box {
    padding: 40px 15px;
  }
}

.instagram-box h2 {
  font-weight: 500;
  font-size: 24px;
  padding-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .instagram-box h2 {
    font-size: 18px;
  }
}

.instagram-box p {
  font-size: 17px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .instagram-box p {
    font-size: 14px;
  }
}

/*-------------=====

news

=================*/
.news {
  padding-top: 120px;
  padding-bottom: 120px;
}

@media screen and (max-width: 767px) {
  .news {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

.news-box {
  width: 700px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .news-box {
    width: calc(100% - 40px);
  }
}

.news-box h2 {
  width: 200px;
  margin: 0 auto;
  border-radius: 20px 20px 0 0;
  padding-top: 15px;
  text-align: center;
  font-size: 24px;
  letter-spacing: 0.1rem;
  background-color: #fff;
  border-top: 2px solid #999999;
  border-left: 2px solid #999999;
  border-right: 2px solid #999999;
  padding-bottom: 2px;
  margin-bottom: -2px;
  position: relative;
}

.news-wrap {
  background-color: #fff;
  border-top: 2px solid #999999;
  border-bottom: 2px solid #999999;
  padding: 50px 60px 20px 60px;
}

@media screen and (max-width: 767px) {
  .news-wrap {
    padding: 30px 20px 10px 20px;
  }
}

.news-item {
  display: block;        /* ←これが重要 */
  margin-bottom: 30px;   /* ←間隔 */
}

.news-item p {
  color: #ff87a0;
  font-weight: 500;
}

.news-date {
  font-size: 14px;
  padding-bottom: 5px;
}

/*-------------=====

campaign

=================*/
.campaign {
  padding-bottom: 120px;
}

@media screen and (max-width: 767px) {
  .campaign {
    padding-bottom: 80px;
  }
}

.campaign-title {
  font-size: 24px;
  margin: 0 auto;
  border-radius: 20px 20px 0 0;
  padding-top: 15px;
  text-align: center;
}

.campaign-content {
  padding-top: 30px;
}

.campaign-item-big {
  display: inline-block;
  width: 100%;
  aspect-ratio: 10/3;
  overflow: hidden;
  border-radius: 40px;
}

@media screen and (max-width: 767px) {
  .campaign-item-big {
    aspect-ratio: 10/10;
    border-radius: 30px;
  }
}

.campaign-item-big img {
  display: block;
  width: 100%;
  object-fit: cover;
  height: 100%;
  border-radius: inherit;
  transition: transform 0.45s ease;
}

@media (prefers-reduced-motion: no-preference) {
  .campaign-item-big:hover img {
    transform: scale(1.06);
  }
}

.campaign-small-wrap {
  margin-top: 30px;
  display: flex;
  gap: 30px;
}

@media screen and (max-width: 767px) {
  .campaign-small-wrap {
    margin-top: 15px;
    flex-wrap: wrap;
    gap: 15px;
  }
}

.campaign-item-small {
  width: 100%;
  aspect-ratio: 10/5;
  overflow: hidden;
  border-radius: 30px;
}

@media screen and (max-width: 767px) {
  .campaign-item-small {
    aspect-ratio: 10/8;
    width: calc((100% - 15px) / 2);
    border-radius: 20px;
  }
}

.campaign-item-small img {
  display: block;
  width: 100%;
  object-fit: cover;
  height: 100%;
  border-radius: inherit;
  transition: transform 0.45s ease;
}

@media (prefers-reduced-motion: no-preference) {
  .campaign-item-small:hover img {
    transform: scale(1.06);
  }
}

/*-------------=====

type

=================*/
.type-content {
  padding: 200px 0 160px 0;
  position: relative;
  background: url(../img/type/type-bg.png) no-repeat center center/cover;
}

@media screen and (max-width: 767px) {
  .type-content {
    padding: 120px 0 100px 0;
  }
}

.type-plane {
  position: absolute;
  width: 200px;
  bottom: 40px;
  left: 120px;
}

@media screen and (max-width: 767px) {
  .type-plane {
    width: 120px;
    left: 20px;
    bottom: 20px;
  }
}

.type-container {
  border: 6px solid #ff87a0;
  border-radius: 43px;
  background-color: #fff;
  padding: 80px 0;
  width: 80%;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .type-container {
    padding: 40px 20px;
    width: 100%;
  }
}

.page-type-title {
  width: 40%;
  margin: 0 auto;
  position: relative;
}

@media screen and (max-width: 767px) {
  .page-type-title {
    width: 80%;
  }
}

.type-number {
  position: absolute;
  width: 13%;
  right: -13%;
  top: 50%;
  transform: translateY(-50%);
}

.type-question {
  font-size: 24px;
  line-height: 2;
  font-weight: 500;
  padding-top: 60px;
  padding-bottom: 60px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .type-question {
    font-size: 17px;
    padding: 40px 0;
  }
}

.yes-no-wrap {
  display: flex;
  justify-content: center;
  gap: 40px;
  width: 50%;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .yes-no-wrap {
    width: 100%;
    flex-direction: column;
    gap: 20px;
  }
}

.type-flow {
  width: 50%;
  margin: 60px auto 0 auto;
}

@media screen and (max-width: 767px) {
  .type-flow {
    width: 100%;
    margin-top: 40px;
  }
}

.type-back {
  width: 200px;
  margin: 60px auto;
}

@media screen and (max-width: 767px) {
  .type-back {
    width: 140px;
    margin-top: 40px;
  }
}

.type-result {
  display: flex;
  gap: 40px;
  padding: 0 40px;
}

@media screen and (max-width: 767px) {
  .type-result {
    gap: 20px;
    display: flex;
    flex-direction: column;
    padding: 0 20px;
  }
}

@media screen and (max-width: 767px) {

  .type-result .result-left,
  .type-result .result-right {
    display: contents;
  }

  .type-result .result-title {
    order: 1;
  }

  .type-result .type-name {
    order: 2;
  }

  .type-result .result-img {
    order: 3;
  }

  .type-result .result-left p {
    order: 4;
  }

  .type-result .type-x {
    order: 5;
  }
}

.result-left {
  width: 50%;
}

@media screen and (max-width: 767px) {
  .result-left {
    width: 100%;
  }
}

.result-left p {
  line-height: 2;
  padding-top: 40px;
}

@media screen and (max-width: 767px) {
  .result-left p {
    padding-top: 10px;
  }
}

.result-title {
  width: 80%;
  margin: 0 auto 20px auto;
}

.result-right {
  width: 50%;
}

@media screen and (max-width: 767px) {
  .result-right {
    width: 100%;
    margin-top: 20px;
  }
}

.type-x {
  width: 80%;
}

@media screen and (max-width: 767px) {
  .type-x {
    width: 100%;
  }
}

.type-recommend {
  width: 860px;
  margin: 40px auto 0 auto;
  display: flex;
  align-items: center;
}

@media (min-width: 768px) and (max-width:1160px) {
  .type-recommend {
    width: 700px;
  }
}

@media screen and (max-width: 767px) {
  .type-recommend {
    width: 100%;
  }
}

.type-recommend a {
  display: inline-block;
  flex-shrink: 0;
}

@media screen and (max-width: 767px) {
  .type-recommend a {
    width: 100%;
  }
}

.type-recommend img {
  height: 80px;
  width: auto;
  margin-right: -40px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .type-recommend img {
    height: auto;
    width: 100%;
    margin-right: 0;
    margin-bottom: -20px;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .type-recommend img {
    height: 70px;
  }
}

.type-recommend .recommend-plan {
  font-size: 26px;
  height: 80px;
  letter-spacing: 0.01rem;
  font-weight: 500;
  padding-left: 60px;
  padding-right: 40px;
  border-radius: 0 40px 40px 0;
  background: linear-gradient(to right, #ffdfb5, #ffddea);
}

@media screen and (min-width: 768px) {
  .type-recommend .recommend-plan {
    display: flex;
    align-items: center;
    flex: 1 1 auto;
    width: auto;
    min-width: 0;
    white-space: nowrap;
  }
}

@media screen and (max-width: 767px) {
  .type-recommend .recommend-plan {
    border-radius: 0 0 30px 30px;
    font-size: 16px;
    height: auto;
    padding: 30px 0 20px 0;
    text-align: center;
    width: 100%;
    display: block;
    white-space: normal;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .type-recommend .recommend-plan {
    font-size: 18px;
    height: 70px;
    padding-right: 20px;
    padding-left: 40px;
  }
}

.type-recommend .recommend-plan span {
  font-size: 16px;
}

@media (min-width: 768px) and (max-width:1160px) {
  .type-recommend .recommend-plan span {
    font-size: 14px;
  }
}

@media screen and (max-width: 767px) {
  .type-recommend .recommend-plan span {
    font-size: 12px;
  }
}

@media screen and (max-width: 767px) {
  .type-recommend {
    width: 100%;
    display: block;
  }
}

.type-content a {
  display: inline-block;
}

.type-content a img {
  display: block;
  transition: transform 0.35s ease, opacity 0.35s ease;
  transform-origin: center;
}

@media (prefers-reduced-motion: no-preference) {
  .type-content a:hover img {
    transform: scale(1.04);
  }
}

.type-content a:hover img {
  opacity: 0.9;
}

.share-wrap {
  display: flex;
  align-items: center;
  gap: 40px;
  margin: 40px 40px 0 40px;
  border-radius: 30px;
  padding: 40px;
  background: url(../img/type/share-bg.png) no-repeat center center/cover;
}

@media screen and (max-width: 767px) {
  .share-wrap {
    display: block;
    margin: 0;
    margin-top: 20px;
    padding: 20px;
  }
}

.share-left {
  position: relative;
}

.share-top .share-top__img {
  display: block;
  max-width: 100%;
  height: auto;
}

.share-top .share-top__img--pc {
  display: none;
}

@media screen and (min-width: 768px) {
  .share-top .share-top__img--pc {
    display: block;
  }
}

.share-top .share-top__img--sp {
  display: block;
}

@media screen and (min-width: 768px) {
  .share-top .share-top__img--sp {
    display: none;
  }
}

.share-voice {
  position: absolute;
  width: 30%;
  right: -100px;
  top: 0;
  pointer-events: none;
}

@media screen and (max-width: 767px) {
  .share-voice {
    width: 100px;
    right: auto;
    left: -30px;
    top: auto;
    bottom: -70px;
  }
}

.share-btn {
  margin: 20px auto 0 auto;
  width: 50%;
  position: relative;
  z-index: 1;
}

.share-btn a {
  display: block;
}

@media screen and (max-width: 767px) {
  .share-btn {
    width: 80%;
    margin-bottom: 20px;
  }
}

.share-more {
  width: 50%;
  margin: 10px auto 0 auto;
}

.page {
  position: relative;
}

.page-top {
  height: 70vh;
  width: 95%;
  border-radius: 0 0 30px 30px;
  margin: 0 auto;
}

@media (min-width: 768px) and (max-width:1160px) {
  .page-top {
    height: 50vh;
  }
}

@media screen and (max-width: 767px) {
  .page-top {
    width: 90%;
    border-radius: 0 0 20px 20px;
    height: 40vh;
  }
}

#seoul .page-top {
  background: url(../img/page-top1.png) no-repeat bottom right/cover;
}

@media screen and (max-width: 767px) {
  #seoul .page-top {
    background: url(../img/page-top1-sp.png) no-repeat bottom right/cover;
  }
}

#busan .page-top {
  background: url(../img/plan/busan-top.png) no-repeat bottom right/cover;
}

@media screen and (max-width: 767px) {
  #busan .page-top {
    background: url(../img/plan/busan-top-sp.png) no-repeat center right/cover;
  }
}

#daegu .page-top {
  background: url(../img/plan/daegu-top.png) no-repeat bottom right/cover;
}

@media screen and (max-width: 767px) {
  #daegu .page-top {
    background: url(../img/plan/daegu-top-sp.png) no-repeat bottom right/cover;
  }
}

#cheongju .page-top {
  background: url(../img/plan/cheongju-top.png) no-repeat bottom right/cover;
}

@media screen and (max-width: 767px) {
  #cheongju .page-top {
    background: url(../img/plan/cheongju-top-sp.png) no-repeat bottom right/cover;
  }
}

#jeju .page-top {
  background: url(../img/plan/jeju-top.png) no-repeat bottom right/cover;
}

@media screen and (max-width: 767px) {
  #jeju .page-top {
    background: url(../img/plan/jeju-top-sp.png) no-repeat bottom right/cover;
  }
}

#jeju .plan-content.plan-content1 .plan-point {
  position: relative;
  z-index: 0;
}

#jeju .plan-content.plan-content1 .plan-route {
  position: relative;
  z-index: 1;
}

#jeju .plan-content.plan-content1 .plan-route>.route-row:first-child:has(> .route-start) .route-start {
  z-index: 2;
}

#jeju .plan-content.plan-content1 .plan-route>.route-row:first-child:has(> .route-start) .route-number {
  position: relative;
  z-index: 2;
}

.page-cloudy {
  position: absolute;
  width: 100%;
  z-index: -1;
  top: 60vh;
  left: 0;
}

.page-cloudy .page-cloudy-sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .page-cloudy {
    top: 45vh;
    overflow: hidden;
  }

  .page-cloudy .page-cloudy-pc {
    display: none;
  }

  .page-cloudy .page-cloudy-sp {
    display: block;
  }
}

.page-plan {
  position: relative;
  z-index: 1;
}

.page-title {
  text-align: center;
  font-size: 40px;
  margin-top: 100px;
  font-weight: 700;
}

@media (min-width: 768px) and (max-width:1160px) {
  .page-title {
    font-size: 35px;
  }
}

@media screen and (max-width: 767px) {
  .page-title {
    font-size: 24px;
    margin-top: 60px;
  }
}

.page-title span {
  font-size: 28px;
  padding-top: 20px;
}

@media screen and (max-width: 767px) {
  .page-title span {
    font-size: 20px;
    padding-top: 10px;
  }
}

.plan-tabs {
  position: relative;
  z-index: 3;
  display: flex;
  gap: 30px;
  margin: 40px auto 0px;
  padding: 0;
  list-style: none;
}

@media screen and (max-width: 767px) {
  .plan-tabs {
    width: 100%;
    gap: 0;
  }

  .plan-tabs li {
    width: 50%;
  }
}

.plan-body {
  position: relative;
  z-index: 2;
}

.plan-gradient-bg {
  position: absolute;
  pointer-events: none;
  z-index: 0;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% + 20px);
  top: -10px;
  bottom: -10px;
  border-radius: 0 30px 30px 30px;
}

@media screen and (max-width: 767px) {
  .plan-gradient-bg {
    width: calc(100% + 10px);
    top: -5px;
    bottom: -5px;
  }
}

.plan-body:has(.plan-content1.is-active) .plan-gradient-bg {
  background: linear-gradient(to right, #b6e5f8, #c1caff);
}

.plan-body:has(.plan-content2.is-active) .plan-gradient-bg {
  background: linear-gradient(to right, #ffdfb5, #ffddea);
}

.plan-tab {
  font-size: 25px;
  appearance: none;
  font-weight: 500;
  color: #fff;
  padding: 15px 60px;
  border-radius: 16px 16px 0 0;
  cursor: pointer;
}

@media screen and (max-width: 767px) {
  .plan-tab {
    padding: 10px 20px;
    width: calc(100% - 20px);
    font-size: 20px;
    flex: 1;
  }
}

.plan-tab1 {
  background-color: #6eaaff;
  position: relative;
  margin-bottom: 10px;
}

.plan-tab1::after {
  content: "";
  position: absolute;
  width: calc(100% + 20px);
  height: calc(100% + 10px);
  border-radius: 20px 20px 0 0;
  background: #b6e5f8;
  top: -10px;
  left: -10px;
  z-index: -1;
}

@media screen and (max-width: 767px) {
  .plan-tab1::after {
    width: calc(100% + 10px);
    height: calc(100% + 5px);
    top: -5px;
    left: -5px;
  }
}

@media screen and (max-width: 767px) {
  .plan-tab1 {
    margin-bottom: 5px;
  }
}

.plan-tab2 {
  background-color: #f79373;
  position: relative;
}

.plan-tab2::after {
  content: "";
  position: absolute;
  width: calc(100% + 20px);
  height: calc(100% + 10px);
  border-radius: 20px 20px 0 0;
  background: linear-gradient(to right, #ffdfb5, #ffddea);
  top: -10px;
  left: -10px;
  z-index: -1;
}

@media screen and (max-width: 767px) {
  .plan-tab2::after {
    width: calc(100% + 10px);
    height: calc(100% + 5px);
    top: -5px;
    left: -5px;
  }
}

.plan-content {
  display: none;
  position: relative;
  z-index: 1;
  padding: 60px 80px;
  background-color: #fff;
  border-radius: 0 20px 20px 20px;
}

@media screen and (max-width: 767px) {
  .plan-content {
    padding: 40px 10px;
  }
}

.plan-content.is-active {
  display: block;
}

.plan-content h2 {
  font-size: 40px;
  text-align: center;
  line-height: 1.6;
  font-weight: 700;
}

@media (min-width: 768px) and (max-width:1160px) {
  .plan-content h2 {
    font-size: 30px;
  }
}

@media screen and (max-width: 767px) {
  .plan-content h2 {
    font-size: 16px;
  }
}

.plan-content2 {
  position: relative;
}

.plan-content2 .plan-point {
  border-top: 1px solid #f79373;
  border-bottom: 1px solid #f79373;
}

.plan-content2 .route-row {
  border-left: 3px dotted #f79373;
}

.plan-content2 .route-row .route-start {
  color: #f79373;
}

.plan-content2 .route-row:first-child {
  margin-top: 30px;
}

.plan-content2 .route-row:first-child .plan-route-day {
  top: 0;
}

.plan-content2 .route-row:first-child:has(> .route-start) {
  border-left: none;
  padding-top: 100px;
}

.plan-content2 .route-row:first-child:has(> .route-start)::after {
  content: "";
  position: absolute;
  left: 0;
  top: 160px;
  bottom: 0;
  width: 0;
  border-left: 3px dotted #f79373;
  pointer-events: none;
  z-index: 0;
}

@media screen and (max-width: 767px) {
  .plan-content2 .route-row:first-child:has(> .route-start) {
    padding-top: 80px;
  }

  .plan-content2 .route-row:first-child:has(> .route-start)::after {
    top: 106px;
  }
}

.plan-content2 .route-row:first-child:has(> .route-start) .plan-route-day {
  top: 0;
}

.plan-content2 .route-row:first-child:has(> .route-start) .route-start {
  top: 58px;
  left: -35px;
}

@media screen and (max-width: 767px) {
  .plan-content2 .route-row:first-child:has(> .route-start) .route-start {
    top: 52px;
    left: -20px;
  }
}

.plan-content2 .route-row-day .plan-route-day {
  top: 0;
  bottom: auto;
}

.plan-content2 .route-number {
  background-color: #f79373;
}

.plan-content2 .route-title {
  background-color: #f79373;
}

.plan-content2 .route-box {
  background-color: #ffefee;
}

.plan-content2 .route-title::after {
  background-color: #f79373;
}

.plan-point {
  margin: 60px;
  padding: 40px 60px;
  border-top: 1px solid #6eaaff;
  border-bottom: 1px solid #6eaaff;
}

@media (min-width: 768px) and (max-width:1160px) {
  .plan-point {
    padding: 30px 0;
    margin: 40px 0;
  }
}

@media screen and (max-width: 767px) {
  .plan-point {
    padding: 20px 0;
    margin: 30px 0;
  }
}

.recommend {
  width: 25%;
}

@media screen and (max-width: 767px) {
  .recommend {
    width: 45%;
  }
}

.plan-point-wrap {
  display: flex;
  gap: 20px;
}

@media screen and (max-width: 767px) {
  .plan-point-wrap {
    gap: 10px;
    align-items: center;
  }
}

.plan-point-wrap p {
  width: 80%;
  line-height: 2;
  padding-top: 20px;
}

@media screen and (max-width: 767px) {
  .plan-point-wrap p {
    line-height: 1.4;
    padding-top: 10px;
    font-size: 12px;
  }
}

.plan-point-img {
  width: 20%;
  text-align: center;
}

.plan-point-img span {
  font-size: 14px;
  font-weight: 600;
}

@media screen and (max-width: 767px) {
  .plan-point-img span {
    font-size: 9px;
    line-height: 1.2;
  }
}

.plan-route-day {
  position: absolute;
  top: 0;
  z-index: 2;
  text-align: center;
  font-size: 23px;
  width: calc(100% + 200px);
  padding: 10px 0;
  left: -120px;
  font-weight: 700;
  background: linear-gradient(to right, #ffdfb5, #ffddea);
}

@media screen and (max-width: 767px) {
  .plan-route-day {
    width: calc(100% + 40px);
    left: -30px;
    font-size: 17px;
  }
}

.plan-route-day span {
  font-size: 14px;
  display: block;
  margin-top: 20px;
  text-align: left;
  padding: 0 100px;
  line-height: 1.4;
}

@media screen and (max-width: 767px) {
  .plan-route-day span {
    padding: 0 20px;
    margin-top: 10px;
    font-size: 11px;
  }
}

.route-row:has(> .plan-route-day) {
  padding-top: 72px;
}

@media screen and (max-width: 767px) {
  .route-row:has(> .plan-route-day) {
    padding-top: 60px;
  }
}

.plan-route-day-jeju {
  padding: 10px 0;
}

@media screen and (max-width: 767px) {
  .plan-route-day-jeju {
    padding: 10px 0;
  }
}

.route-row:has(> .plan-route-day-jeju) {
  padding-top: 72px;
}

@media screen and (max-width: 767px) {
  .route-row:has(> .plan-route-day-jeju) {
    padding-top: 60px;
  }
}

.route-row {
  display: flex;
  align-items: flex-start;
  gap: 30px;
  position: relative;
  border-left: 3px dotted #6eaaff;
  margin-left: 30px;
}

@media screen and (max-width: 767px) {
  .route-row {
    margin-left: 10px;
    width: 100%;
    gap: 5px;
  }
}

.route-row:not(:last-child) {
  padding-bottom: 60px;
}

@media screen and (max-width: 767px) {
  .route-row:not(:last-child) {
    padding-bottom: 30px;
  }
}

.route-row:last-child {
  border: none;
}

.route-row p {
  line-height: 2;
}

@media screen and (max-width: 767px) {
  .route-row p {
    font-size: 12px;
    padding-top: 15px;
  }
}

.route-row .route-start {
  position: absolute;
  font-size: 24px;
  font-weight: 500;
  color: #6eaaff;
  left: -35px;
  top: -30px;
  font-weight: 700;
}

@media screen and (max-width: 767px) {
  .route-row .route-start {
    font-size: 17px;
    left: -10px;
    top: -20px;
  }
}

.route-row h3 {
  font-size: 24px;
  padding-top: 16px;
  padding-bottom: 20px;
  font-weight: 700;
}

.route-row h3 ruby {
  ruby-position: over;
  ruby-align: center;
}

.route-row h3 rt {
  font-size: 0.48em;
  line-height: 1.1;
}

.route-row h3 span {
  font-size: 0.75em;
}

@media screen and (max-width: 767px) {
  .route-row h3 {
    font-size: 12px;
    min-height: 26px;
    padding-top: 0;
    padding-bottom: 0;
    margin-top: 0;
    margin-bottom: 10px;
  }

  .route-row h3 rt {
    font-size: 5px;
  }

  .route-row h3 span {
    font-size: 10px;
  }
}

@media screen and (max-width: 767px) {
  .route-row h3:not(.route-title) {
    margin-top: 5px;
  }
}

@media screen and (max-width: 767px) {
  .route-row h3:not(.route-title):where(:has(ruby), :has(span)) {
    line-height: 1.15;
    min-height: 0;
    margin-top: 1px;
    transform: translateY(0px);
  }

  .route-row h3:not(.route-title):where(:has(ruby), :has(span)) ruby {
    line-height: 1;
  }

  .route-row h3:not(.route-title):where(:has(ruby), :has(span)) rt {
    line-height: 1;
  }

  .route-row h3:not(.route-title):where(:has(ruby), :has(span)) span {
    line-height: 1;
    vertical-align: 0.05em;
  }
}

.route-row .route-n {
  display: flex;
  align-items: center;
  color: #000;
}

@media screen and (max-width: 767px) {
  .route-row .route-n {
    font-size: 11px;
  }
}

.route-row .route-n img {
  width: 35px;
}

@media screen and (max-width: 767px) {
  .route-row .route-n img {
    width: 20px;
  }
}

.plan-content2 .plan-route.plan-route--busan-2n3d>.route-row:last-child {
  border-left: none;
  position: relative;
}

.plan-content2 .plan-route.plan-route--busan-2n3d>.route-row:last-child::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 0;
  height: 132px;
  border-left: 3px dotted #f79373;
  pointer-events: none;
  z-index: 0;
}

@media screen and (max-width: 767px) {
  .plan-content2 .plan-route.plan-route--busan-2n3d>.route-row:last-child::before {
    height: 86px;
  }
}

.route-number {
  position: relative;
  z-index: 1;
  flex: 0 0 auto;
  width: 60px;
  height: 60px;
  background-color: #6eaaff;
  border-radius: 50%;
  color: #fff;
  font-weight: 700;
  font-size: 28px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 1px;
  box-sizing: border-box;
  margin-left: -31.5px;
}

@media screen and (max-width: 767px) {
  .route-number {
    width: 26px;
    height: 26px;
    font-size: 16px;
    padding-top: 0;
    margin-left: -12.5px;
  }
}

.route-number.route-number--dot {
  font-size: 0;
  line-height: 0;
  color: transparent;
  letter-spacing: 0;
  padding-top: 0;
}

@media screen and (max-width: 767px) {
  .plan-route>.route-row:not(:first-child):not(:last-child) .route-number {
    transform: translateX(-1px);
  }
}

.plan-route>.route-row:first-child:has(> .route-start) .route-number {
  padding-left: 4px;
}

@media screen and (max-width: 767px) {
  .plan-route>.route-row:first-child:has(> .route-start) .route-number {
    padding-left: 3px;
  }
}

.plan-content.plan-content1 .plan-route>.route-row:first-child:has(> .route-start) {
  border-left: none;
}

.plan-content.plan-content1 .plan-route>.route-row:first-child:has(> .route-start)::after {
  content: "";
  position: absolute;
  left: 0;
  top: 30px;
  bottom: 0;
  width: 0;
  border-left: 3px dotted #6eaaff;
  pointer-events: none;
  z-index: 0;
}

@media screen and (max-width: 767px) {
  .plan-content.plan-content1 .plan-route>.route-row:first-child:has(> .route-start)::after {
    top: 13px;
  }
}

.route-text-wrap {
  width: calc(100% - 90px);
}

@media screen and (max-width: 767px) {
  .route-text-wrap {
    width: calc(100% - 36px);
  }
}

.route-title {
  color: #fff;
  background-color: #6eaaff;
  border-radius: 40px;
  position: relative;
  padding-left: 30px;
  padding-right: 0;
  margin-left: auto;
  margin-bottom: 20px;
  position: relative;
  line-height: 1.4;
}

.route-title span {
  font-size: 0.75em;
}

@media screen and (min-width: 768px) {
  .route-title:has(ruby) {
    position: relative;
    top: -7px;
  }
}

@media screen and (max-width: 767px) {
  .route-title:has(ruby) {
    position: relative;
    top: -5px;
  }
}

@media screen and (max-width: 767px) {
  .route-title {
    padding: 7px 15px !important;
    padding-right: 15px !important;
    margin-bottom: 10px;
    font-size: 14px;
    letter-spacing: 0.01rem;
  }

  .route-title span {
    font-size: 10px;
  }
}

.route-title::after {
  position: absolute;
  content: "";
  width: 30px;
  height: 3px;
  background-color: #6eaaff;
  top: 50%;
  transform: translateY(-50%);
  left: -30px;
}

@media screen and (max-width: 767px) {
  .route-title::after {
    width: 10px;
    left: -10px;
  }
}

.route-title img {
  width: 20px;
  position: absolute;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
  transition: transform 0.25s ease;
}

@media screen and (max-width: 767px) {
  .route-title img {
    width: 10px;
    right: 15px;
  }
}

.route-title .route-title-parking {
  font-size: 0.62em;
  font-weight: 500;
}

@media screen and (max-width: 767px) {
  .route-title .route-title-parking {
    font-size: 8px;
  }
}

.route-text-wrap.route-expand:not(.is-open) .route-expand-panel {
  display: none;
}

.route-text-wrap.route-expand .route-title {
  cursor: pointer;
  user-select: none;
}

.route-text-wrap.route-expand.is-open .route-title img {
  transform: translateY(-50%) rotate(180deg);
}

.route-text-wrap.route-expand>a.route-n {
  display: flex;
  margin-top: 14px;
}

@media screen and (max-width: 767px) {
  .route-text-wrap.route-expand>a.route-n {
    margin-top: 10px;
  }
}

@media screen and (max-width: 767px) {
  .route-row-b .route-number {
    margin-top: 5px;
  }
}

@media screen and (max-width: 767px) {
  .route-row-b .route-title {
    font-size: 12px !important;
    letter-spacing: 0.01rem;
  }
}

@media screen and (max-width: 767px) {
  .route-img-wide {
    aspect-ratio: 5/4;
  }

  .route-img-wide img {
    border-radius: 20px;
    height: 100%;
    object-fit: cover;
  }
}

.route-bottom-wrap {
  display: flex;
  gap: 30px;
  padding-top: 15px;
}

@media screen and (max-width: 767px) {
  .route-bottom-wrap {
    flex-direction: column-reverse;
    gap: 0;
  }
}

.route-bottom-content {
  width: 100%;
}

.route-bottom-content p {
  line-height: 2;
  padding-bottom: 10px;
}

.route-bottom-img {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .route-bottom-img {
    aspect-ratio: 5/4;
  }

  .route-bottom-img img {
    border-radius: 20px;
    height: 100%;
    object-fit: cover;
  }
}

.route-box {
  margin-top: 80px;
  background-color: #ddeffb;
  border-radius: 40px;
  padding: 60px;
}

@media screen and (max-width: 767px) {
  .route-box {
    margin-top: 30px;
    border-radius: 20px;
    padding: 30px 20px;
  }
}

#jeju .route-box {
  position: relative;
  overflow: visible;
}

#jeju .route-jeju-car {
  position: absolute;
  right: 60px;
  top: -20px;
  width: 260px;
  pointer-events: none;
}

#jeju .route-jeju-car img {
  width: 100%;
  height: auto;
  display: block;
}

@media screen and (max-width: 767px) {
  #jeju .route-jeju-car {
    right: 10px;
    top: -32px;
    width: 138px;
  }
}

.route-box-title {
  display: flex;
  align-items: center;
  gap: 20px;
  border-bottom: 1px solid #000;
  padding-bottom: 15px;
}

@media screen and (max-width: 767px) {
  .route-box-title {
    gap: 10px;
    line-height: 1.4;
    padding-bottom: 10px;
  }
}

.route-good {
  width: 40px;
}

@media screen and (max-width: 767px) {
  .route-good {
    width: 25px;
  }
}

.route-taxi-title {
  font-size: 21px;
}

@media screen and (max-width: 767px) {
  .route-taxi-title {
    font-size: 14px;
  }
}

.route-box-content {
  display: flex;
  gap: 40px;
  padding-top: 20px;
}

@media screen and (max-width: 767px) {
  .route-box-content {
    gap: 20px;
    padding-top: 10px;
  }
}

.route-box-img {
  text-align: center;
  width: 90px;
}

@media screen and (max-width: 767px) {
  .route-box-img {
    width: 62px;
  }
}

.route-box-img span {
  line-height: 1.6;
  margin-top: 10px;
  font-size: 14px;
  display: block;
}

@media screen and (max-width: 767px) {
  .route-box-img span {
    font-size: 9px;
  }
}

.route-box-text {
  line-height: 2;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .route-box-text {
    width: 100%;
    font-size: 12px;
    line-height: 1.6;
  }
}

.route-box-text a {
  color: #000;
}

.route-box-text a:hover {
  opacity: 0.7;
}

.plan-map {
  padding-top: 120px;
}

@media screen and (max-width: 767px) {
  .plan-map {
    padding-top: 60px;
  }
}

.plan-box {
  background-color: #fff;
  border-radius: 30px;
  padding: 20px 40px 40px 40px;
}

@media screen and (max-width: 767px) {
  .plan-box {
    border-radius: 20px;
    padding: 10px;
  }
}

.plan-box .plan-map-title {
  width: 300px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .plan-box .plan-map-title {
    width: 150px;
  }
}

.plan-box .plan-vworld-map {
  margin-top: 24px;
  width: 100%;
  height: 500px;
  border-radius: 16px;
  overflow: hidden;
  z-index: 0;
}

@media screen and (max-width: 767px) {
  .plan-box .plan-vworld-map {
    height: 320px;
    border-radius: 12px;
    margin-top: 16px;
  }
}

.plan-number-marker {
  background: transparent !important;
  border: none !important;
}

.number-icon {
  width: 28px;
  height: 28px;
  border: 2px solid white;
  border-radius: 50%;
  color: white;
  font-weight: bold;
  font-size: 13px;
  text-align: center;
  line-height: 24px;
  box-sizing: border-box;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
}

.number-icon--daytrip {
  background-color: #2563eb;
}

.number-icon--trip2n3d {
  background-color: #f97316;
}

.plan-map-popup {
  text-align: center;
  line-height: 1.5;
}

.plan-map-popup-link {
  display: inline-block;
  margin-top: 4px;
  background: #03c75a;
  color: #fff;
  padding: 5px 10px;
  text-decoration: none;
  border-radius: 4px;
  font-size: 12px;
}

.plan-map-popup-link:hover {
  opacity: 0.92;
}

.page-tour {
  padding-top: 80px;
  padding-bottom: 120px;
}

.page-tour h2 {
  width: 60%;
  margin: 0 auto;
  max-width: 900px;
}

@media screen and (max-width: 767px) {
  .page-tour h2 {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .page-tour {
    padding-top: 40px;
    padding-bottom: 80px;
  }
}

.page-tour-content {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 15px;
  margin-top: 30px;
}

@media screen and (max-width: 767px) {
  .page-tour-content {
    display: block;
  }
}

.page-tour-item {
  width: calc((100% - 30px) / 3);
  background-color: #fff;
  padding: 10px 40px 20px 40px;
  border-radius: 50px;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.12);
  transition: box-shadow 0.3s ease;
}

.page-tour-item:hover {
  box-shadow: none;
}

@media screen and (max-width: 767px) {
  .page-tour-item {
    width: 100%;
    margin-bottom: 15px;
    border-radius: 40px;
  }
}

.page-tour-item p {
  line-height: 1.6;
}

.page-tour-name {
  width: 60%;
  margin: 0 auto;
}

.page-tour-toggle {
  display: none;
}

@media screen and (max-width: 767px) {
  .page-tour-toggle {
    display: block;
    width: 250px;
    margin: 8px auto 0 auto;
    padding: 12px 18px;
    border-radius: 999px;
    border: 0;
    background: #9b9b9b;
    box-shadow: none;
    font-size: 16px;
    font-weight: 700;
    color: #fff;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    position: relative;
    padding-right: 38px;
  }

  .page-tour-toggle:hover {
    opacity: 0.92;
  }

  .page-tour-toggle::after {
    content: "";
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-35%);
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 8px solid #fff;
    /* ▼ */
  }

  .page-tour-toggle[data-state=open]::after {
    transform: translateY(-65%);
    border-top: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-bottom: 8px solid #fff;
    /* ▲ */
  }
}

.travel-btn {
  border-radius: 25px;
  padding-top: 45px;
  width: 671px;
  margin: 0 auto;
  height: 167px;
  background: url(../img/plan/travel-btn-bg.png) no-repeat center center/cover;
  transition: opacity 0.3s ease;
}

@media screen and (max-width: 767px) {
  .travel-btn {
    width: 333px;
    height: 177px;
    padding-top: 35px;
  }
}

.travel-btn:hover {
  opacity: 0.85;
}

@media (prefers-reduced-motion: no-preference) {
  .travel-btn:hover .travel-pink img {
    transform: translateX(6px);
  }
}

.travel-btn p {
  text-align: center;
  font-weight: 700;
  color: #000;
  font-size: 22px;
  padding-bottom: 15px;
}

@media screen and (max-width: 767px) {
  .travel-btn p {
    line-height: 1.4;
    font-size: 20px;
    padding-bottom: 0;
  }
}

.travel-btn .travel-pink {
  text-align: center;
  width: 300px;
  height: 36px;
  background-color: #ffa0a0;
  border-radius: 20px;
  margin: 0 auto;
  color: #fff;
  padding-top: 7px;
}

.travel-btn .travel-pink img {
  display: inline-block;
  vertical-align: middle;
  width: 17px;
  margin-left: 5px;
  transition: transform 0.3s ease;
}

@media (min-width: 768px) and (max-width:1160px) {
  .travel-btn .travel-pink {
    margin-top: 20px;
  }
}

@media screen and (max-width: 767px) {
  .travel-btn .travel-pink {
    width: 250px;
    margin-top: 20px;
    padding-top: 9px;
  }
}

.airport-content {
  padding-top: 200px;
  padding-bottom: 80px;
  position: relative;
  z-index: 0;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .airport-content {
    padding-top: 110px;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-content {
    padding-top: 160px;
  }
}

.airport-content h1 {
  width: 320px;
  margin: 0 auto 60px auto;
}

@media screen and (max-width: 767px) {
  .airport-content h1 {
    width: 220px;
    margin-bottom: 30px;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-content h1 {
    width: 220px;
    margin-bottom: 30px;
  }
}

.airport-bg {
  position: absolute;
  width: 80%;
  top: 80px;
  z-index: -1;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .airport-bg {
    top: 70px;
    width: 180%;
    left: 50%;
    transform: translateX(-50%);
  }
}

.airport-message {
  width: 420px;
  margin: 0 auto;
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-message {
    line-height: 1.5;
    width: 260px;
  }
}

@media screen and (max-width: 767px) {
  .airport-message {
    line-height: 1.5;
    width: 260px;
  }
}

.airport-anchor-wrap {
  display: flex;
  justify-content: center;
  padding-top: 40px;
  gap: 20px;
}

@media screen and (max-width: 767px) {
  .airport-anchor-wrap {
    flex-wrap: wrap;
    gap: 5px;
    margin: 0 auto;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-anchor-wrap {
    flex-wrap: wrap;
    justify-content: start;
    gap: 5px;
    margin: 0 auto;
  }
}

.airport-anchor-item {
  width: 130px;
  text-align: center;
  padding: 10px 0;
  border-radius: 15px;
  border: 3px solid #fff;
  font-size: 20px;
  font-weight: 700;
  color: #000;
}

@media screen and (max-width: 767px) {
  .airport-anchor-item {
    width: 100px;
    font-size: 18px;
  }
}

.airport-anchor-item.is-orange {
  background: linear-gradient(to right, #ffdfb5, #ffddea);
}

.airport-anchor-item.is-green {
  background: linear-gradient(to right, #a2ffc9, #c8e6ef);
}

.airport-anchor-item.is-blue {
  background: linear-gradient(to right, #b6e5f8, #c1caff);
}

.airport-anchor-item.is-lightblue {
  background: linear-gradient(to bottom, #65e3ff, #ffdfcc);
}

.airport-anchor-item.is-yellow {
  background: linear-gradient(to right, #e1fff2, #caffc8);
}

.airport-anchor-item.is-purple {
  background: linear-gradient(to bottom, #ffcef7, #ff84de);
}

.airport-content-box h2 {
  width: 400px;
  padding-left: 70px;
  font-size: 26px;
  z-index: 1;
  font-weight: 700;
  position: relative;
}

@media screen and (max-width: 767px) {
  .airport-content-box h2 {
    width: 300px;
    font-size: 22px;
    padding-left: 60px;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-content-box h2 {
    width: 300px;
    font-size: 22px;
    padding-left: 60px;
  }
}

.airport-content-box h2::before {
  content: "";
  position: absolute;
  width: 20px;
  height: 20px;
  background-color: #fff;
  border-radius: 5px;
  left: 30px;
  top: 0px;
  border: 1px solid #000;
}

.airport-content-box h2 img {
  position: absolute;
  left: 0;
  top: -24px;
  z-index: -1;
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-content-box h2 img {
    top: -15px;
  }
}

@media screen and (max-width: 767px) {
  .airport-content-box h2 img {
    top: -15px;
  }
}

.airport-content-wrap .airport-content-box.is-orange .airport-content-row {
  padding: 30px;
  position: relative;
  z-index: -1;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to right, #ffdfb5, #ffddea);
}

@media screen and (max-width: 767px) {
  .airport-content-wrap .airport-content-box.is-orange .airport-content-row {
    padding: 20px;
    background: linear-gradient(to bottom, #ffdfb5, #ffddea);
  }
}

.airport-content-wrap .airport-content-box.is-green .airport-content-row {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to right, #a2ffc9, #c8e6ef);
}

@media screen and (max-width: 767px) {
  .airport-content-wrap .airport-content-box.is-green .airport-content-row {
    padding: 20px;
    background: linear-gradient(to bottom, #a2ffc9, #c8e6ef);
  }
}

.airport-content-wrap .airport-content-box.is-blue .airport-content-row {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to right, #b6e5f8, #c1caff);
}

@media screen and (max-width: 767px) {
  .airport-content-wrap .airport-content-box.is-blue .airport-content-row {
    padding: 20px;
    background: linear-gradient(to bottom, #b6e5f8, #c1caff);
  }
}

.airport-content-wrap .airport-content-box.is-lightblue .airport-content-row {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to bottom, #65e3ff, #ffdfcc);
}

@media screen and (max-width: 767px) {
  .airport-content-wrap .airport-content-box.is-lightblue .airport-content-row {
    padding: 20px;
    background: linear-gradient(to bottom, #65e3ff, #ffdfcc);
  }
}

.airport-content-wrap .airport-content-box.is-yellow .airport-content-row {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to right, #def8be, #caffc8);
}

@media screen and (max-width: 767px) {
  .airport-content-wrap .airport-content-box.is-yellow .airport-content-row {
    padding: 20px;
    background: linear-gradient(to bottom, #def8be, #caffc8);
  }
}

.airport-content-wrap .airport-content-box.is-purple .airport-content-row {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to bottom, #ffcef7, #ff84de);
}

@media screen and (max-width: 767px) {
  .airport-content-wrap .airport-content-box.is-purple .airport-content-row {
    padding: 20px;
    background: linear-gradient(to bottom, #ffcef7, #ff84de);
  }
}

.airport-content-box {
  padding-top: 60px;
}

.airport-row-labels {
  display: flex;
  background-color: #e6e6e6;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
}

.airport-row-label {
  text-align: center;
}

@media screen and (max-width: 767px) {
  .airport-row-label {
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-row-label {
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
  }
}

.airport-row-label:first-child {
  width: 250px;
  border-right: 1px solid #000;
  padding: 10px 0;
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-row-label:first-child {
    width: 100%;
    border-right: none;
  }
}

@media screen and (max-width: 767px) {
  .airport-row-label:first-child {
    width: 100%;
    border-right: none;
  }
}

.airport-row-label:last-child {
  width: calc(100% - 250px);
  padding: 10px 0;
}

@media screen and (max-width: 767px) {
  .airport-row-label:last-child {
    width: 100%;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-row-label:last-child {
    width: 100%;
  }
}

.airport-row-label:only-child {
  width: 100%;
  border-right: none;
  padding: 10px 0;
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-row-label:only-child {
    width: 100%;
    border-right: none;
  }
}

@media screen and (max-width: 767px) {
  .airport-row-label:only-child {
    width: 100%;
    border-right: none;
  }
}

.airport-row-body {
  display: flex;
  background-color: #fff;
  padding: 0 40px;
}

@media screen and (max-width: 767px) {
  .airport-row-body {
    display: block;
    padding: 0 20px;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-row-body {
    display: block;
    padding: 0 20px;
  }
}

.airport-row-box-wrap {
  width: 250px;
  padding: 40px 0;
}

@media screen and (max-width: 767px) {
  .airport-row-box-wrap {
    width: 100%;
    padding: 20px 0 0 0;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-row-box-wrap {
    width: 100%;
    padding: 20px 0 0 0;
  }
}

.airport-row-right {
  width: calc(100% - 250px);
  display: flex;
  gap: 30px;
  padding: 40px 0;
}

@media screen and (max-width: 767px) {
  .airport-row-right {
    display: block;
    width: 100%;
    padding: 20px 0 40px 0;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-row-right {
    display: block;
    width: 100%;
    padding: 20px 0 40px 0;
  }
}

.airport-row-center {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 60%;
}

@media screen and (max-width: 767px) {
  .airport-row-center {
    width: 100%;
  }
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-row-center {
    width: 100%;
  }
}

.airport-row-img {
  width: 40%;
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-row-img {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .airport-row-img {
    width: 100%;
  }
}

.airport-row-h3 {
  font-size: 22px;
  line-height: 2;
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-row-h3 {
    padding: 10px 0;
  }
}

@media screen and (max-width: 767px) {
  .airport-row-h3 {
    padding: 10px 0;
  }
}

.airport-row-box {
  width: 165px;
  background-color: #eaf6fd;
  text-align: center;
  padding: 60px 0;
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-row-box {
    width: 100%;
    margin-top: 20px;
    padding: 20px 0;
  }
}

@media screen and (max-width: 767px) {
  .airport-row-box {
    width: 100%;
    margin-top: 20px;
    padding: 20px 0;
  }
}

.airport-name {
  text-align: center;
  font-size: 18px;
  padding-bottom: 10px;
}

.airport-tab-wrap {
  display: flex;
  justify-content: center;
  gap: 5px;
  margin-top: 5px;
}

.airport-tab {
  background-color: #666666;
  border-radius: 10px;
  width: 80px;
  height: 20px;
  margin: 0 auto 5px auto;
  text-align: center;
  display: flex;
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-tab {
    margin: 0;
  }
}

@media screen and (max-width: 767px) {
  .airport-tab {
    margin: 0;
  }
}

.airport-tab span {
  color: #fff;
}

.airport-tab span:first-child {
  font-size: 9px;
  width: 30px;
  height: 100%;
  border-right: 1px solid #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.airport-tab span:last-child {
  font-size: 12px;
  width: 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.airport-row-btn {
  width: 360px;
  height: 36px;
  background-color: #ffa0a0;
  border-radius: 20px;
  margin-left: auto;
}

@media (min-width: 768px) and (max-width:1160px) {
  .airport-row-btn {
    margin-top: 20px;
  }
}

@media screen and (max-width: 767px) {
  .airport-row-btn {
    width: 100%;
    margin-top: 20px;
  }
}

.airport-row-btn a {
  display: inline-block;
  text-align: center;
  padding-top: 7px;
  width: 100%;
  height: 100%;
  color: #fff;
}

@media screen and (max-width: 767px) {
  .airport-row-btn a {
    padding-top: 9px;
  }
}

.airport-row-btn a img {
  width: 15px;
}

@media screen and (max-width: 767px) {
  .airport-content-row .is-border {
    margin-top: 50px;
    position: relative;
  }

  .airport-content-row .is-border::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 5px;
    background-color: #fff;
    top: -25px;
    left: 0;
  }
}

.airport-content-row .is-border .airport-row-box-wrap {
  border-top: 1px solid #000;
}

@media screen and (max-width: 767px) {
  .airport-content-row .is-border .airport-row-box-wrap {
    border: none;
  }
}

.airport-content-row .is-border .airport-row-right {
  border-top: 1px solid #000;
}

@media screen and (max-width: 767px) {
  .airport-content-row .is-border .airport-row-right {
    border: none;
  }
}

.schedule-content {
  padding-top: 180px;
  padding-bottom: 100px;
}

@media (min-width: 768px) and (max-width:1160px) {
  .schedule-content {
    padding-top: 150px;
  }
}

@media screen and (max-width: 767px) {
  .schedule-content {
    padding-top: 120px;
  }
}

.schedule-top {
  display: flex;
}

@media screen and (max-width: 767px) {
  .schedule-top {
    display: block;
  }
}

.schedule-top-left {
  width: 50%;
}

@media (min-width: 768px) and (max-width:1160px) {
  .schedule-top-left {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .schedule-top-left {
    width: 100%;
  }
}

.schedule-top-left-inner {
  width: 305px;
  margin: 0 auto;
}

.schedule-top-logo {
  width: 100%;
  margin: 0 auto 40px auto;
}

.schedule-top-logo img {
  width: 100%;
  height: auto;
  display: block;
}

.schedule-top-logo.logo-s {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .schedule-top-logo {
    margin-bottom: 20px;
  }
}

.schedule-content--peach .schedule-top-logo {
  width: 80%;
}

.schedule-anchor-wrap {
  margin-top: 20px;
  gap: 20px;
  display: flex;
  justify-content: center;
  flex-wrap: nowrap;
}

@media screen and (max-width: 767px) {
  .schedule-anchor-wrap {
    gap: 5px;
    flex-wrap: wrap;
  }
}

.five-anchor-wrap {
  gap: 5px;
}

.five-anchor-wrap .schedule-anchor-item {
  width: 120px;
}

@media screen and (max-width: 767px) {
  .five-anchor-wrap .schedule-anchor-item {
    width: 100px;
  }
}

.schedule-anchor-item {
  width: 130px;
  text-align: center;
  padding: 10px 0;
  border-radius: 15px;
  border: 3px solid #fff;
  font-size: 20px;
  font-weight: 700;
  color: #000;
  transition: opacity 0.25s ease;
}

@media screen and (max-width: 767px) {
  .schedule-anchor-item {
    width: 98px;
  }
}

.schedule-anchor-item:hover {
  opacity: 0.75;
}

.schedule-anchor-item.is-orange {
  background: linear-gradient(to right, #ffdfb5, #ffddea);
}

.schedule-anchor-item.is-purple {
  background: linear-gradient(to bottom, #ffcef7, #ff84de);
}

.schedule-anchor-item.is-green {
  background: linear-gradient(to right, #9df8ed, #8fceff);
}

.schedule-anchor-item.is-green2 {
  background: linear-gradient(to bottom, #d7f2c3, #a2ffc9);
}

.schedule-anchor-item.is-green3 {
  background: linear-gradient(to bottom, #a2ffc9, #c8e6ef);
}

.schedule-anchor-item.is-blue {
  background: linear-gradient(to bottom, #b6e5f8, #c1caff);
}

.schedule-anchor-item.is-blue2 {
  background: linear-gradient(to bottom, #65e3ff, #ffdfcc);
}

.schedule-anchor-item.is-pink {
  background: linear-gradient(to bottom, #ffb5b8, #ffc9ff);
}

.schedule-anchor-item.is-yellow {
  background: linear-gradient(to bottom, #fff992, #ffd3ba);
}

.schedule-top-right {
  width: 50%;
}

@media (min-width: 768px) and (max-width:1160px) {
  .schedule-top-right {
    width: 90%;
    margin: 0 auto 40px auto;
  }
}

@media screen and (max-width: 767px) {
  .schedule-top-right {
    width: 90%;
    margin: 0 auto 40px auto;
  }
}

@media screen and (max-width: 767px) {
  .schedule-content--miracle .schedule-top-left-inner .schedule-top-right.pc-none {
    width: 100%;
    margin: 0 0 28px 0;
    transform: translateX(-48px) scale(1.12);
    transform-origin: left center;
  }

  .schedule-content--miracle .schedule-top-left-inner .schedule-top-right.pc-none img {
    width: 100%;
    height: auto;
    display: block;
  }
}

.airport-content-box .font-s {
  font-size: 21px;
}

@media screen and (max-width: 767px) {
  .airport-content-box .font-s {
    top: -5px;
  }
}

.airport-content-box .font-s img.schedule-h2-illust {
  width: auto;
  max-width: 100%;
  vertical-align: middle;
}

.airport-content-box .font-s .schedule-h2-illust--sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .airport-content-box .font-s .schedule-h2-illust--sp {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  .airport-content-box .font-s .schedule-h2-illust--pc {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-h2-hero {
    display: block;
    position: relative;
    width: 100%;
    margin: 0 0 -28px;
  }
}

.airport-content-box .schedule-h2-hero__text {
  display: inline;
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-h2-hero__text {
    display: block;
    position: absolute;
    left: 0;
    top: 10px;
    z-index: 2;
    max-width: 78%;
    padding: 0 10px 0 0;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.35;
    color: #fff;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
  }
}

.airport-content-box .schedule-h2-hero__illust {
  display: inline;
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-h2-hero__illust {
    display: block;
    position: relative;
    width: 80%;
    margin: 0;
    z-index: 0;
  }

  .airport-content-box .schedule-h2-hero__illust img.schedule-h2-illust {
    width: 100%;
    height: auto;
    display: block;
    vertical-align: top;
    position: static;
    top: auto;
    max-width: none;
  }
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-h2-hero+.schedule-content-wrap {
    margin-top: -20px;
    position: relative;
    z-index: 1;
  }
}

.airport-content-box .schedule-content-wrap.is-orange {
  padding: 30px;
  position: relative;
  z-index: -1;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to right, #ffdfb5, #ffddea);
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-content-wrap.is-orange {
    padding: 20px;
    background: linear-gradient(to bottom, #ffdfb5, #ffddea);
  }
}

.airport-content-box .schedule-content-wrap.is-light-green {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to right, #9df8ed, #8fceff);
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-content-wrap.is-light-green {
    padding: 20px;
    background: linear-gradient(to bottom, #9df8ed, #8fceff);
  }
}

.airport-content-box .schedule-content-wrap.is-purple {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to bottom, #ffcef7, #ff84de);
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-content-wrap.is-purple {
    padding: 20px;
    background: linear-gradient(to bottom, #ffcef7, #ff84de);
  }
}

.airport-content-box .schedule-content-wrap.is-green {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to bottom, #d7f2c3, #a2ffc9);
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-content-wrap.is-green {
    padding: 20px;
    background: linear-gradient(to bottom, #d7f2c3, #a2ffc9);
  }
}

.airport-content-box .schedule-content-wrap.is-green2 {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to right, #a2ffc9, #c8e6ef);
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-content-wrap.is-green2 {
    padding: 20px;
    background: linear-gradient(to bottom, #a2ffc9, #c8e6ef);
  }
}

.airport-content-box .schedule-content-wrap.is-green3 {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to bottom, #a2ffc9, #c8e6ef);
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-content-wrap.is-green3 {
    padding: 20px;
    background: linear-gradient(to bottom, #a2ffc9, #c8e6ef);
  }
}

.airport-content-box .schedule-content-wrap.is-blue {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to bottom, #b6e5f8, #c1caff);
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-content-wrap.is-blue {
    padding: 20px;
    background: linear-gradient(to bottom, #b6e5f8, #c1caff);
  }
}

.airport-content-box .schedule-content-wrap.is-blue2 {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to bottom, #65e3ff, #ffdfcc);
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-content-wrap.is-blue2 {
    padding: 20px;
    background: linear-gradient(to bottom, #65e3ff, #ffdfcc);
  }
}

.airport-content-box .schedule-content-wrap.is-pink {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to bottom, #ffb5b8, #ffc9ff);
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-content-wrap.is-pink {
    padding: 20px;
    background: linear-gradient(to bottom, #ffb5b8, #ffc9ff);
  }
}

.airport-content-box .schedule-content-wrap.is-yellow {
  position: relative;
  z-index: -1;
  padding: 30px;
  border-radius: 0 30px 30px 30px;
  border: 3px solid #fff;
  background: linear-gradient(to bottom, #fff992, #ffd3ba);
}

@media screen and (max-width: 767px) {
  .airport-content-box .schedule-content-wrap.is-yellow {
    padding: 20px;
    background: linear-gradient(to bottom, #fff992, #ffd3ba);
  }
}

.schedule-content-wrap {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

@media screen and (max-width: 767px) {
  .schedule-content-wrap {
    display: block;
  }
}

.schedule-item {
  width: calc(50% - 10px);
  border-left: 1px solid #000;
}

@media screen and (max-width: 767px) {
  .schedule-item {
    width: 100%;
  }

  .schedule-item:not(:last-child) {
    margin-bottom: 20px;
  }

  .schedule-item:nth-child(3) {
    margin-top: 60px;
    position: relative;
  }

  .schedule-item:nth-child(3)::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 3px;
    background-color: #fff;
    top: -30px;
  }

  .schedule-item:nth-child(5) {
    margin-top: 60px;
    position: relative;
  }

  .schedule-item:nth-child(5)::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 3px;
    background-color: #fff;
    top: -30px;
  }

  .schedule-item:nth-child(7) {
    margin-top: 60px;
    position: relative;
  }

  .schedule-item:nth-child(7)::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 3px;
    background-color: #fff;
    top: -30px;
  }

  .schedule-item:nth-child(9) {
    margin-top: 60px;
    position: relative;
  }

  .schedule-item:nth-child(9)::before {
    position: absolute;
    content: "";
    width: 100%;
    height: 3px;
    background-color: #fff;
    top: -30px;
  }
}

.schedule-item.is-b .schedule-title {
  background-color: #649cb9;
}

.schedule-item.is-b .schedule-time {
  background-color: #eaf6fd;
}

.schedule-item.is-g .schedule-title {
  background-color: #78a587;
}

.schedule-item.is-g .schedule-time {
  background-color: #f1fae7;
}

.schedule-excerpt {
  text-align: right;
  margin-top: 60px;
  margin-bottom: -60px;
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .schedule-excerpt {
    text-align: center;
    margin-bottom: 0;
    margin-top: 20px;
  }
}

.schedule-title {
  text-align: center;
  font-size: 23px;
  color: #fff;
  padding: 15px 0;
  border: 1px solid #000;
  border-left: none;
  font-weight: 700;
}

@media screen and (max-width: 767px) {
  .schedule-title {
    font-size: 20px;
  }
}

.schedule-line {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  padding: 30px 0;
  gap: 40px;
  border-right: 1px solid #000;
}

@media (min-width: 768px) and (max-width:1160px) {
  .schedule-line {
    gap: 20px;
  }
}

@media screen and (max-width: 767px) {
  .schedule-line {
    gap: 20px;
  }
}

.schedule-line p {
  font-size: 22px;
  text-align: center;
  line-height: 1.2;
  font-weight: 700;
}

@media screen and (max-width: 767px) {
  .schedule-line p {
    font-size: 17px;
  }
}

.schedule-line p span {
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

.schedule-plane-icon {
  width: 30px;
}

.schedule-columns {
  display: flex;
  border-top: 1px solid #000;
}

.schedule-column {
  text-align: center;
}

.schedule-column:first-child {
  width: 50%;
  border-right: 1px dotted #000;
  border-bottom: 1px solid #000;
}

.schedule-column:nth-child(2) {
  width: 25%;
  border-right: 1px dotted #000;
  border-bottom: 1px solid #000;
}

.schedule-column:nth-child(3) {
  width: 25%;
  border-right: 1px solid #000;
  border-bottom: 1px solid #000;
}

.schedule-label {
  background-color: #e6e6e6;
  font-size: 11px;
  padding: 15px 0;
}

.schedule-time {
  font-size: 17px;
  height: 50px;
  padding-top: 13px;
  border-top: 1px solid #000;
}

@media screen and (max-width: 767px) {
  .schedule-time {
    font-size: 14px;
  }
}

.schedule-text {
  font-size: 14px;
  background-color: #fff;
  height: 50px;
  padding: 0 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1.2;
  white-space: normal;
  word-break: keep-all;
  border-top: 1px solid #000;
}

@media screen and (max-width: 767px) {
  .schedule-text {
    font-size: 10px;
    padding: 0 6px;
  }
}

.schedule-more-btn {
  background-color: #6eb4f0;
  width: 560px;
  height: 70px;
  margin: 60px auto 0 auto;
  text-align: center;
  border-radius: 35px;
  transition: background-color 0.3s ease;
}

@media screen and (max-width: 767px) {
  .schedule-more-btn {
    width: 90%;
    height: 50px;
  }
}

.schedule-more-btn:hover {
  background-color: #9ccdf7;
}

@media (prefers-reduced-motion: no-preference) {
  .schedule-more-btn:hover a img {
    transform: translateX(6px);
  }
}

.schedule-more-btn a {
  font-size: 23px;
  padding-top: 22px;
  width: 100%;
  height: 100%;
  text-align: center;
  display: inline-block;
  color: #fff;
}

@media screen and (max-width: 767px) {
  .schedule-more-btn a {
    padding-top: 14px;
    font-size: 17px;
    letter-spacing: 0.05rem;
  }
}

.schedule-more-btn a img {
  display: inline-block;
  vertical-align: middle;
  width: 20px;
  margin-left: 10px;
  transition: transform 0.3s ease;
}

@media screen and (max-width: 767px) {
  .schedule-more-btn a img {
    width: 15px;
    margin-left: 10px;
  }
}

.note-wrap {
  display: flex;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .note-wrap {
    padding-bottom: 10px;
  }
}

.schedule-note {
  width: calc(50% + 10px);
  font-size: 12px;
  margin-top: -10px;
  line-height: 1.2;
  display: block;
}

.schedule-note.note-wide {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .schedule-note {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .schedule-note:last-child:not(:only-child) {
    display: none;
  }
}