@charset "utf-8";
@import url("https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic:wght@300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&display=swap");

/* ======================================================================
/* Google Fonts [zen-maru]
====================================================================== */
.zen-maru-gothic-light {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.zen-maru-gothic-regular {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.zen-maru-gothic-medium {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.zen-maru-gothic-bold {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.zen-maru-gothic-black {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 900;
  font-style: normal;
}

/* ======================================================================
/* Google Fonts [Lato]
====================================================================== */
.lato-thin {
  font-family: "Lato", sans-serif;
  font-weight: 100;
  font-style: normal;
}

.lato-light {
  font-family: "Lato", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.lato-regular {
  font-family: "Lato", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.lato-bold {
  font-family: "Lato", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 40px;
}

.lato-black {
  font-family: "Lato", sans-serif;
  font-weight: 900;
  font-style: normal;
}

/* ======================================================================
/* root
====================================================================== */
:root {
  --color-brand: #00a9c8;
  --color-white: #ffffff;
  --color-black: #000000;
  --color-gray: #f7f7f7;
  --color-navy: #141f3f;
  --color-yellow: #ffeb31;
  --color-orange: #ee713a;
}

/* ======================================================================
/* body
====================================================================== */
body {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 16px;
  color: var(--color-black);
  text-align: justify;
  letter-spacing: 0.05em;
  line-height: 1.8;
}

@media screen and (width <= 768px) {
  body {
    font-size: 14px;
  }
}

/* ======================================================================
/* #container
====================================================================== */
#container {
  position: relative;
  inline-size: 500px;
  block-size: auto;
  margin-inline: auto;
  box-shadow: 0 0 30px 0px rgb(0 0 0 / 10%);
}

@media screen and (width <= 768px) {
  #container {
    inline-size: 100%;
  }
}

/* ======================================================================
/* .inner
====================================================================== */
.inner {
  max-inline-size: 100%;
  block-size: auto;
  margin: 0 auto;
  padding: 50px 15px;
}

@media screen and (width <= 768px) {
  .inner {
    inline-size: 100%;
    block-size: auto;
    padding: 30px 15px;
  }
}

/* ======================================================================
/* #nav03
====================================================================== */
#nav03 {
  content: "";
  inline-size: 100%;
  block-size: 100% !important;
  background: url(../img/pickup/pickUp_bg.svg) center center / cover no-repeat;
}

@media screen and (width <= 768px) {
  #nav03 {
    block-size: 110% !important;
  }
}

/* ======================================================================
/* fluidImg
====================================================================== */
@media screen and (width <= 768px) {
  .fluidImg {
    inline-size: 100%;
    block-size: auto;
  }
}

/* ======================================================================
/* relative
====================================================================== */
.relative {
  position: relative;
}

/* ======================================================================
/* bgColor
====================================================================== */
.bgColor-gray {
  box-sizing: border-box;
  border-block-start: solid 5px var(--color-navy);
  background: var(--color-gray);
}

/* ======================================================================
/* mapFrame
====================================================================== */
.mapFrame {
  position: absolute;
  bottom: 13%;
  left: 50%;
  transform: translate(-50%, -13%);
  max-inline-size: 100%;
  block-size: auto;

  & iframe {
    max-inline-size: 380px;
    block-size: 310px;
  }
}

@media screen and (width <= 768px) {
  .mapFrame {
    bottom: 16%;
    left: 50%;
    transform: translate(-50%, -16%);

    & iframe {
      max-inline-size: 260px;
      block-size: auto;
    }
  }
}

/* ======================================================================
/* Swiper
====================================================================== */
.swiper {
  position: relative;
  inline-size: 100%;
  block-size: 100%;
  margin-block-start: 50px;

  & .swiper-slide {
    inline-size: 100%;

    & img {
      inline-size: 92%;
      block-size: auto;
    }
  }

  & .swiper-button-prev {
    position: absolute;
    inset-block-start: 50%;
    inset-inline-start: 0;
    content: "";
    display: block;
    inline-size: 40px;
    block-size: 40px;
    background: url(../img/common/slidePrev.svg) center center / cover no-repeat;
  }

  & .swiper-button-next {
    inset-block-start: 50%;
    inset-inline-end: 0;
    content: "";
    display: block;
    inline-size: 40px;
    block-size: 40px;
    background: url(../img/common/slideNext.svg) center center / cover no-repeat;
  }
}

@media screen and (width <= 768px) {
  .swiper {
    position: relative;

    & .swiper-slide {
      inline-size: 100%;
    }

    & .swiper-button-next,
    & .swiper-button-prev {
      inline-size: 30px;
      block-size: 30px;
    }
  }
}

/* ======================================================================
/* target_nav
====================================================================== */
.target_nav {
  display: none;
  position: fixed;
  z-index: 100;
  top: 50%;
  right: 50%;
  transform: translate(calc(-50% + 300px), -50%);
  z-index: 49;
}
.header__link {
  display: block;
  width: 6px;
  height: 32px;
  background-color: transparent;
  border: 1px solid #d0c1c1;
  margin-top: 20px;
}
.header__link.is-active {
  background-color: #626262;
}
li.header__item {
  position: relative;
}

.t_nav_tex {
  display: block;
  width: 28px;
  text-align: center;
  position: absolute;
  top: 50%;
  color: #d0c1c1;
  transform: translate(15%, -50%);
}

@media screen and (max-width: 768px) {
  .target_nav {
    right: 5%;
    transform: translate(0, -50%);
  }
  .header__link {
    width: 4px;
    height: 24px;
    margin-top: 15px;
    border: 1px solid #c8c8c8;
  }
  .header__link.is-active {
    background-color: #c8c8c8;
  }

  .t_nav_tex {
    width: 20px;
  }
} /*END*/

@media screen and (max-width: 599px) {
  .target_nav {
    display: none !important;
  }
} /*END*/

/* =====================================================
/* header
===================================================== */
header {
  position: relative;
}

/* =====================================================
/* footer
===================================================== */
footer {
  inline-size: 100%;
}
