/* ******************************
 *
 * RESPONSIVE MIXIN
 *
 * ****************************** */
/* ******************************
 *
 * FONT SETTINGS
 *
 * ****************************** */
@font-face {
  font-family: "tsukuhou";
  src: url("../font/Tsukuhou-35Point-Gothic.ttf") format("truetype");
}
/* ******************************
 *
 * FONT SETTINGS
 *
 * ****************************** */
@-webkit-keyframes loopCl {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes loopCl {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@-webkit-keyframes loopClRv {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}
@keyframes loopClRv {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}
@-webkit-keyframes loopCircle {
  from {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes loopCircle {
  from {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
:root {
  --color-base: #FFFFFF;
  --color-main: #212121;
  --color-accent: #b68a5f;
  --color-white: #FFFFFF;
  --color-black: #22282a;
  --color-gray: #F0F0F0;
  --font-main: "neue-haas-grotesk-text", "ryo-gothic-plusn", sans-serif;
  --font-unique: "times-new-roman", sans-serif;
  --burger-size: 48px;
  --burger-line: 2px;
  --burger-color: var(--text-color, #111);
  --burger-bg: transparent;
  --burger-shadow: 0 6px 20px rgba(0,0,0,.08);
  --ease-squish: cubic-bezier(.2,.7,.2,1.1);
}

html {
  color: var(--color-main);
  scroll-behavior: smooth;
  scrollbar-width: none;
  margin-top: 0 !important;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}
@media screen and (min-width: 320px) {
  html {
    font-size: 2.56411vw;
  }
}
@media screen and (min-width: 600px) {
  html {
    font-size: 1.5vw;
  }
}
@media screen and (min-width: 1025px) {
  html {
    font-size: 0.5208335vw;
  }
}
@media screen and (min-width: 1921px) {
  html {
    font-size: 0.5208335vw;
  }
}
html::-webkit-scrollbar {
  display: none;
}

a {
  color: inherit;
  text-decoration: none;
}

.img {
  overflow: hidden;
}
.imgWrapper {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 66.67%;
  background: var(--color-accent);
}
.imgWrapper img, .imgWrapper video {
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.globalBg, .globalFrame {
  pointer-events: none;
}

.globalBg {
  position: fixed;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100vh;
  height: 100lvh;
  background: url("../images/bg_common.webp") center center/cover no-repeat;
}

.globalFrame {
  position: fixed;
  inset: 0;
  z-index: 3;
  width: 100%;
}
.globalFrame__inner {
  width: 100%;
  height: 100%;
}
.globalFrame picture {
  display: block;
  width: 100%;
  height: 100%;
}
.globalFrame img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: fill;
     object-fit: fill;
}

.globalMain {
  position: relative;
  z-index: 2;
}

.fixedNav {
  --nav-blue: #0071bc;
  --nav-sky: #2eb3c8;
  --nav-yellow: #f8cf3f;
  --nav-red: #e94b5f;
  --nav-black: #111;
  --nav-white: #fff;
  position: fixed;
  left: 50%;
  bottom: clamp(18px, 2.4vw, 34px);
  z-index: 900;
  display: grid;
  grid-template-columns: repeat(3, auto);
  gap: 10px;
  padding: 10px;
  border: 3px solid var(--nav-black);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  -webkit-box-shadow: 6px 6px 0 var(--nav-black);
          box-shadow: 6px 6px 0 var(--nav-black);
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  backdrop-filter: blur(8px);
}

.fixedNav__item {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
  min-height: 48px;
  padding: 8px 16px 8px 10px;
  border: 2px solid var(--nav-black);
  border-radius: 999px;
  background: var(--nav-white);
  color: var(--nav-black);
  text-decoration: none;
  font-size: clamp(12px, 1.15vw, 15px);
  font-weight: 900;
  line-height: 1.2;
  white-space: nowrap;
  -webkit-transition: background 0.18s ease, -webkit-transform 0.18s ease, -webkit-box-shadow 0.18s ease;
  transition: background 0.18s ease, -webkit-transform 0.18s ease, -webkit-box-shadow 0.18s ease;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, -webkit-transform 0.18s ease, -webkit-box-shadow 0.18s ease;
}

.fixedNav__item:nth-child(1) {
  background: var(--nav-yellow);
}

.fixedNav__item:nth-child(2) {
  background: var(--nav-blue);
  color: var(--nav-white);
}

.fixedNav__item:nth-child(3) {
  background: var(--nav-red);
  color: var(--nav-white);
}

.fixedNav__item:hover {
  -webkit-transform: translate(2px, 2px);
          transform: translate(2px, 2px);
  -webkit-box-shadow: 3px 3px 0 var(--nav-black);
          box-shadow: 3px 3px 0 var(--nav-black);
}

.fixedNav__icon {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  border: 2px solid var(--nav-black);
  border-radius: 50%;
  background: var(--nav-white);
  color: var(--nav-black);
}

.fixedNav__icon svg {
  width: 19px;
  height: 19px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.fixedNav__text {
  -webkit-transform: translateY(-0.02em);
          transform: translateY(-0.02em);
}

@media (max-width: 600px) {
  .fixedNav {
    left: 50%;
    right: auto;
    bottom: 14px;
    width: 95vw;
    grid-template-columns: repeat(3, 1fr);
    gap: 4px;
    padding: 4px;
    border-width: 2px;
    -webkit-box-shadow: 4px 4px 0 var(--nav-black);
            box-shadow: 4px 4px 0 var(--nav-black);
  }
  .fixedNav__item {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    min-height: unset;
    padding: 4px 0;
    gap: 4px;
    border-width: 2px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    font-size: 10px;
    white-space: normal;
    text-align: center;
  }
  .fixedNav__icon {
    width: 28px;
    height: 28px;
  }
  .fixedNav__icon svg {
    width: 16px;
    height: 16px;
  }
}
.gFooter {
  position: relative;
}
@media screen and (min-width: 320px) {
  .gFooter {
    margin-top: 6rem;
  }
}
@media screen and (min-width: 600px) {
  .gFooter {
    margin-top: 14rem;
  }
}
.gFooter__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.gFooter__bg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.gFooter__main {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 320px) {
  .gFooter__main {
    padding: 6rem 12.5vw 12rem;
  }
}
@media screen and (min-width: 600px) {
  .gFooter__main {
    padding: 12rem 20vw 25rem;
  }
}
.gFooter__main img {
  display: block;
  width: 100%;
  height: auto;
}/*# sourceMappingURL=style.css.map */