@charset "UTF-8";

@font-face {
  font-family: Swiss721BT;
  font-weight: normal;
  font-style: normal;
  src: url('../fonts/Swiss 721 BT.woff2') format('woff2'), url('../fonts/Swiss 721 BT.woff') format('woff'), url('../fonts/Swiss 721 BT.ttf') format('truetype');
}

@font-face {
  font-family: Noto Sans JP;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/NotoSansJP-Medium.woff2') format("woff2"), url('../fonts/NotoSansJP-Medium.woff') format("woff"), url('../fonts/NotoSansJP-Medium.ttf') format('truetype');
}

@font-face {
  font-family: Noto Sans JP;
  font-style: semi bold;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/NotoSansJP-SemiBold.woff2') format("woff2"), url('../fonts/NotoSansJP-SemiBold.woff') format("woff"), url('../fonts/NotoSansJP-SemiBold.ttf') format('truetype');
}

@font-face {
  font-family: Noto Sans JP;
  font-style: bold;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/NotoSansJP-Bold.woff2') format("woff2"), url('../fonts/NotoSansJP-Bold.woff') format("woff"), url('../fonts/NotoSansJP-Bold.ttf') format('truetype');
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/OpenSans-Regular.woff2') format("woff2"), url('../fonts/OpenSans-Regular.woff') format("woff"), url('../fonts/OpenSans-Regular.ttf') format('truetype');
}

@font-face {
  font-family: Open Sans;
  font-style: medium;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/OpenSans-Medium.woff2') format("woff2"), url('../fonts/OpenSans-Medium.woff') format("woff"), url('../fonts/OpenSans-Medium.ttf') format('truetype');
}

@font-face {
  font-family: Open Sans;
  font-style: bold;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/OpenSans-Bold.woff2') format("woff2"), url('../fonts/OpenSans-Bold.woff') format("woff"), url('../fonts/OpenSans-Bold.ttf') format('truetype');
}


body {
  min-height: 100%;
  color: #000000;
  font-family: Open Sans, Noto Sans JP, YuGothic, 游ゴシック, Hiragino Kaku Gothic ProN, Hiragino Sans, Meiryo, sans-serif;
  background-color: white;
  margin: 0;
  overflow-x: hidden;
}



/* ***************************** */
/* Layout */
/* ***************************** */
.container {
  margin-right: clamp(10px, 2vw, 80px);
  margin-left: clamp(10px, 2vw, 80px);
  padding: clamp(10px, 2vw, 180px);
}

.container-inner {
  margin: auto;
  max-width: 1000px;
}

section {
  padding-top: clamp(20px, 5vw, 50px);
  padding-bottom: clamp(20px, 5vw, 50px);
}


.card {
  background: #F3F0EE;
  border-radius: 50px;
  max-width: 1400px;
  margin: auto;
  box-sizing: border-box;
  padding-top: clamp(20px, 4vw, 150px);
  padding-bottom: clamp(20px, 4vw, 150px);
  padding-right: clamp(20px, 4vw, 200px);
  padding-left: clamp(20px, 4vw, 200px);
}

@media (max-width: 767px) {
  .card {
    border-radius: 15px;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .card {
    border-radius: 30px;
  }
}

button.popup-btn {
  height: clamp(27px, 5.4vw, 80px);
  width: clamp(44px, 8.8vw, 110px);
  background: transparent;
  border-radius: 90px;
  border: 3px solid rgba(112, 112, 112, 0.52);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

button.popup-btn img {
  width: clamp(12px, 2.4vw, 40px);
}

.login-btn-w {
  height: clamp(28px, 5.6vw, 46px);
  padding: 0 10px;
  border: 1px solid white;
  background: white;
  color: rgb(230, 21, 23);
  font-weight: 800;
  font-size: clamp(17px, 3.4vw, 30px);
  cursor: pointer;
  text-wrap: nowrap;
  text-align: center;
}

.login-btn-r {
  font-family: Open Sans;
  padding: 6px 20px;
  border: none;
  background: rgb(230, 21, 23);
  color: white;
  font-weight: 800;
  font-size: clamp(17px, 3.4vw, 42px);
  cursor: pointer;
  text-wrap: nowrap;
  text-align: center;
}

h2 {
  font-family: Noto Sans JP;
  font-weight: 100;
  letter-spacing: 0.1em;
  font-size: clamp(24px, 4.8vw, 80px);
  margin-top: 0;
  margin-bottom: clamp(20px, 4vw, 36px);
  display: inline-block;
}

h3 {
  font-size: clamp(22px, 3.2vw, 48px);
  font-family: Noto Sans JP;
  margin: 0;
}

h4 {
  font-size: clamp(20px, 4vw, 40px);
  font-family: Open Sans;
  font-weight: 500;
  margin: 0;
}



@media screen and (max-width: 767px) {
  ._pc {
    display: none !important
  }
}

@media screen and (min-width: 768px) {
  ._sp {
    display: none !important
  }
}

/* ***************************** */
/* Bottom */
/* ***************************** */
#bottomSection {
  text-align: center;
  padding-bottom: clamp(0, 0vw, 50px);
}

#bottomSection .catch {
  margin-bottom: clamp(72px, 14.4vw, 200px);
}

#bottomSection .catch img {
  width: clamp(169px, 33.8vw, 450px);
}

#bottomSection img.copy-logo {
  width: clamp(68px, 13.6vw, 120px);
}

#bottomSection p {
  font-size: clamp(11px, 2.2vw, 28px);
  margin-bottom:  clamp(30px, 6vw, 60px);
}

/* ***************************** */
/* List Triangle */
/* ***************************** */
ul.list-triangle {
  padding: 0.5em;
  list-style-type: none;
}

ul.list-triangle > li {
  position: relative;
  padding: 0em 0.3em 0.3em 1.3em;
}

ul.list-triangle > li:before {
  position: absolute;
  content: '';
  top: 0.3em;
  left: 0.2em;
  border-style: solid;
  border-width: 6px 0 6px 9px;
  border-color: transparent transparent transparent #707070;
  margin-top: 0;
  margin-bottom: 0;
}


ol.list-circle {
  list-style: none;
  counter-reset: number;
}
ol.list-circle > li {
  position: relative;
  padding-left: 1.5em;
}
ol.list-circle > li::before {
  counter-increment: number;
  content: counter(number);
  position: absolute;
  top: 5px;
  left: 0;
  width: 12px;
  height: 12px;
  border: 1px solid #000;
  border-radius: 50%;
  font-size: 10px;
  text-align: center;
  line-height: 1.2;
}