:root {
  --viewport-width: min(100vw, 1600px);
  --b: calc(var(--viewport-width) / 160);
}

/* noto-sans-jp-400 - japanese_latin */
@font-face {
  font-display: swap;
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/noto-sans-jp-v53-japanese_latin-regular.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* noto-sans-jp-500 - japanese_latin */
@font-face {
  font-display: swap;
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 500;
  src: url("../fonts/noto-sans-jp-v53-japanese_latin-500.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* noto-sans-jp-600 - japanese_latin */
@font-face {
  font-display: swap;
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/noto-sans-jp-v53-japanese_latin-600.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* noto-sans-jp-700 - japanese_latin */
@font-face {
  font-display: swap;
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/noto-sans-jp-v53-japanese_latin-700.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* noto-sans-jp-800 - japanese_latin */
@font-face {
  font-display: swap;
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 800;
  src: url("../fonts/noto-sans-jp-v53-japanese_latin-800.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* noto-sans-jp-900 - japanese_latin */
@font-face {
  font-display: swap;
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 900;
  src: url("../fonts/noto-sans-jp-v53-japanese_latin-900.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
* {
  color: #3e3a39;
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-size: max(1.6rem, 14px);
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.1em;
}

a > *,
button > * {
  pointer-events: none;
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
}

a,
button {
  display: block;
}

span {
  display: inline-block;
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
}

.attention {
  font-size: max(1.4rem, 12px);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
.attention small {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
}

#header {
  position: absolute;
  top: 2%;
  left: 3%;
  z-index: 9999;
}
#header .header__logo {
  width: max(20vw, 200px);
}

#footer {
  background: #fff;
  padding: max(2rem, 10px);
  border-top: 3px solid #3e3a39;
}
#footer .footer__wrapper {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: space-around;
  gap: max(2rem, 20px) max(10rem, 50px);
  width: min(90%, 1600px);
}
@media screen and (max-width: 550px) {
  #footer .footer__wrapper {
    width: 95%;
  }
}
#footer .footer__wrapper .footer__list {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: max(4rem, 20px);
}
@media screen and (max-width: 550px) {
  #footer .footer__wrapper .footer__list {
    flex-direction: column;
    gap: 10px;
    width: 100%;
  }
}
#footer .footer__wrapper .footer__list .footer__item a {
  font-size: max(1.2rem, 10px);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.15em;
}
#footer .footer__wrapper .footer__copyright p {
  font-size: max(1.2rem, 8px);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.05em;
}

.titleBg {
  position: relative;
  display: grid;
  place-items: center;
  padding: max(3rem, 20px) 10px;
  z-index: 0;
}
.titleBg::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 55%;
  z-index: -1;
}
.titleBg span {
  position: relative;
  color: #fff;
  font-size: max(3rem, 22px);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  z-index: 10;
}
.titleBg.primary::before {
  -webkit-clip-path: polygon(calc(100% - 18vw) 0, 100% 0, 100% 100%, 0% 100%);
          clip-path: polygon(calc(100% - 18vw) 0, 100% 0, 100% 100%, 0% 100%);
}
@media screen and (min-width: 1600px) {
  .titleBg.primary::before {
    -webkit-clip-path: polygon(calc(100% - 350px) 0, 100% 0, 100% 100%, 0% 100%);
            clip-path: polygon(calc(100% - 350px) 0, 100% 0, 100% 100%, 0% 100%);
  }
}
@media screen and (max-width: 768px) {
  .titleBg.primary::before {
    -webkit-clip-path: polygon(calc(100% - 35vw) 0, 100% 0, 100% 100%, 0% 100%);
            clip-path: polygon(calc(100% - 35vw) 0, 100% 0, 100% 100%, 0% 100%);
  }
}
.titleBg.secondary::before {
  -webkit-clip-path: polygon(calc(100% - 40vw) 0, 100% 0, 100% 100%, 0% 100%);
          clip-path: polygon(calc(100% - 40vw) 0, 100% 0, 100% 100%, 0% 100%);
}
@media screen and (min-width: 1600px) {
  .titleBg.secondary::before {
    -webkit-clip-path: polygon(calc(100% - 800px) 0, 100% 0, 100% 100%, 0% 100%);
            clip-path: polygon(calc(100% - 800px) 0, 100% 0, 100% 100%, 0% 100%);
  }
}
@media screen and (max-width: 768px) {
  .titleBg.secondary::before {
    -webkit-clip-path: polygon(calc(100% - 35vw) 0, 100% 0, 100% 100%, 0% 100%);
            clip-path: polygon(calc(100% - 35vw) 0, 100% 0, 100% 100%, 0% 100%);
  }
}/*# sourceMappingURL=style.css.map */