@charset "UTF-8";
/* -------------------------------------------*/
html {
  overflow-x: clip;
  font-size: 62.5%;
  height: 100%;
}
body {
  display: flex;
  flex-direction: column;
  position: relative;
  overflow-x: clip;
  font-family: 'Noto Sans JP', sans-serif;
  height: 100%;
  color: #000000;
  font-weight: 500;
}
main {
  position: relative;
  width: 100%;
  margin: 0 auto;
  flex: 1;
}
section {
  margin-top: max(calc(-130 * var(--vw)), -130px);
  padding-top: min(calc(130 * var(--vw)), 130px);
  position: relative;
}
.no-link {
  opacity: 0.4 !important;
  pointer-events: none !important;
}
img {
  display: block;
}

/* -------------------------------------------*/
:root {
  --vw: calc(100vw / 1920);
}

.header {
  display: flex;
  align-items: center;
  width: 100%;
  height: min(calc(130 * var(--vw)), 130px);
  padding-left: 2.7%;
  position: fixed;
  top: 0;
  left: 0;
  background-color: #fff;
  z-index: 100;
}

.header-logo {
  max-width: min(calc(372 * var(--vw)), 372px);
  width: 100%;
  padding-top: 0.5vw;
}

.header-nav {
  display: flex;
  margin-left: auto;
  height: 100%;
}

.header-menu {
  display: flex;
  align-items: center;
  gap: min(calc(10 * var(--vw)), 10px);
  height: 100%;
  padding: 0.5vw 0 0;
}

.header-menu a {
  display: block;
  position: relative;
  padding: 0.6em 0.8em;
  font-size: min(calc(27 * var(--vw)), 27px);
  letter-spacing: 0.07em;
}

.header-menu a::after {
  content: '';
  display: block;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 0);
  width: 0;
  height: min(calc(2 * var(--vw)), 2px);
  background-color: #e60012;
  transition: 0.3s;
}

.header-menu a:hover::after {
  width: calc(100% - 1.6em);
}

.header-btns {
  display: flex;
  margin-left: min(calc(60 * var(--vw)), 60px);
}

.header-contact {
  width: min(calc(270 * var(--vw)), 270px);
  height: 100%;
}

.header-contact a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  border: solid 1px transparent;
  background-color: #000;
  color: #fff;
  font-size: min(calc(27 * var(--vw)), 27px);
  letter-spacing: 0.06em;
  transition: 0.3s;
}

.header-contact a:hover {
  border-color: #000;
  background-color: #fff;
  color: #000;
}

.header-order {
  width: min(calc(270 * var(--vw)), 270px);
  height: 100%;
}

.header-order a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background-color: #e60012;
  color: #fff;
  font-size: min(calc(27 * var(--vw)), 27px);
  letter-spacing: 0.06em;
  transition: 0.3s;
}

.header-order a:hover {
  background-color: #ef5a24;
}

.header-order a::before {
  content: '';
  display: inline-block;
  width: min(calc(32 * var(--vw)), 32px);
  aspect-ratio: 32/30;
  margin-right: min(calc(4 * var(--vw)), 4px);
  background: url(../images/ic_cart.svg) no-repeat top center/contain;
}

.main {
  margin-top: min(calc(130 * var(--vw)), 130px);
}

.btn01,
.btn02,
.btn03 {
  display: block;
  position: absolute;
  z-index: 1;
}

.btn01::before,
.btn02::before,
.btn03::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.btn01 img,
.btn02 img,
.btn03 img {
  transition: 0.3s;
}

.btn01:hover img,
.btn02:hover img,
.btn03:hover img {
  opacity: 0;
}

.btn01,
.btn02 {
  left: 50%;
  transform: translate(-50%, 0);
  width: 52%;
  aspect-ratio: 5/1;
}

.btn01::before {
  background: url(../images/btn01_on.webp?ver20250821) no-repeat top center/contain;
}

.btn02::before {
  background: url(../images/btn02_on.webp?ver20250821) no-repeat top center/contain;
}

.btn03 {
  width: min(calc(575 / 1920 * 100vw), 575px);
  aspect-ratio: 575/170;
}

.btn03::before {
  background: url(../images/btn03_on.webp) no-repeat top center/contain;
}

.sec01 .btn01 {
  bottom: 6vw;
}

.sec03 img {
  margin-top: -1px;
}

.sec03 .btn01 {
  bottom: 6vw;
}

.sec04 .btn03 {
  bottom: 7.9vw;
  left: 18.9vw;
}

.sec04 img {
  margin-top: -1px;
}

.sec05 img {
  margin-top: -1px;
}

.sec06 .btn02 {
  bottom: 6vw;
}

.sec06 .sec06-wrap {
  position: relative;
}

.sec06 .sec06-wrap ul {
  position: absolute;
  bottom: 26.5%;
  left: 22%;
}
.sec06 .sec06-wrap ul li {
  font-size: 0.87vw;
  line-height: 1.81;
}
.sec06 .sec06-wrap ul li a {
  color: #20aaff;
  text-decoration: underline;
}

.faq-body {
  position: relative;
  width: 52%;
  margin: -1.5vw auto 0;
}

.faq-body::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100%;
  margin: 0 calc(50% - 50vw);
  background-color: #ddedec;
  z-index: -1;
}

.faq-inner {
  position: relative;
}

.faq-inner::before {
  content: '';
  display: block;
  position: absolute;
  left: 0;
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  z-index: -1;
}

.faq-inner:nth-child(1) {
  padding: min(calc(138.24 * var(--vw)), 138.24px) 0 0;
}

.faq-inner:nth-child(1)::before {
  top: 0;
  background: url(../images/back01.webp) no-repeat top center/contain;
  aspect-ratio: 288/236;
}

.faq-inner:nth-child(2) {
  padding: min(calc(100 * var(--vw)), 100px) 0 22.3vw;
}

.faq-inner:nth-child(2)::before {
  bottom: 0;
  background: url(../images/back02.webp) no-repeat bottom center/contain;
  aspect-ratio: 288/230;
}

.faq-wrap:not(:first-child) {
  margin-top: min(calc(100 * var(--vw)), 100px);
}

.faq .btn02 {
  bottom: 5.5vw;
}

.faq-cat {
  font-size: min(calc(30 * var(--vw)), 30px);
  font-weight: 700;
  text-align: center;
}

.faq-list {
  margin-top: min(calc(48 * var(--vw)), 48px);
}

.faq-list dl {
  background-color: #fff;
}

.faq-list dl:not(:first-child) {
  margin-top: min(calc(28 * var(--vw)), 28px);
}

.faq-list dl.is-active dt .switch::after {
  transform: translate(0, -50%) rotate(0);
  opacity: 0;
}

.faq-list dl.is-active dd {
  opacity: 1;
}

.faq-list dt,
.faq-list dd p {
  position: relative;
  padding-inline-start: min(calc(95 * var(--vw)), 95px);
  padding-inline-end: min(calc(50 * var(--vw)), 50px);
}

.faq-list dt {
  padding-block: min(calc(18 * var(--vw)), 18px) min(calc(18 * var(--vw)), 18px);
  font-size: min(calc(24 * var(--vw)), 24px);
  font-weight: 700;
  line-height: 1.67;
  letter-spacing: -0.01em;
  cursor: pointer;
  overflow: hidden;
}

.faq-list dt::before {
  content: '';
  display: block;
  position: absolute;
  top: -0.5px;
  left: 0;
  height: 105%;
  aspect-ratio: 1/1;
  z-index: 1;
  background: url(../images/faq_q.svg) no-repeat center center/contain;
}

.faq-list dt .switch {
  position: absolute;
  top: 50%;
  right: min(calc(30 * var(--vw)), 30px);
  transform: translate(0, -50%);
  width: min(calc(20 * var(--vw)), 20px);
  aspect-ratio: 1/1;
}

.faq-list dt .switch::before,
.faq-list dt .switch::after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #000;
  z-index: 1;
}

.faq-list dt .switch::after {
  transform: translate(0, -50%) rotate(90deg);
  transition: 0.3s;
}

.faq-list dd {
  display: flex;
  align-items: center;
  height: 0;
  opacity: 0;
  transition: 0.3s;
  font-size: min(calc(18 * var(--vw)), 18px);
  line-height: 1.67;
}

.faq-list dd p {
  padding-block: min(calc(12 * var(--vw)), 12px) min(calc(18 * var(--vw)), 18px);
}

.faq-list dd p a {
  color: #20aaff;
  text-decoration: underline;
}

.faq-list dd p::before {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
  width: min(calc(75 * var(--vw)), 75px);
  aspect-ratio: 1/1;
  background: url(../images/faq_a.svg) no-repeat center center/contain;
}

.footer {
  background-color: #183d57;
}

.footer-top img {
  filter: brightness(0) invert(1);
}

.footer-inner {
  width: min(calc(1200 * var(--vw)), 1200px);
  margin: 0 auto;
}

.footer-top {
  padding: min(calc(38.4 * var(--vw)), 38.4px) 0;
}

.footer-top img {
  width: min(calc(375.936 * var(--vw)), 375.936px);
}

.footer-bottom {
  display: flex;
  align-items: end;
  position: relative;
  padding: min(calc(38.4 * var(--vw)), 38.4px) 0 min(calc(57.6 * var(--vw)), 57.6px);
}

.footer-bottom::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100vw;
  height: 1px;
  margin: 0 calc(50% - 50vw);
  background-color: #fff;
  z-index: 1;
}

.footer-menu {
  display: flex;
  align-items: center;
  gap: min(calc(68 * var(--vw)), 68px);
}

.footer-menu a {
  display: block;
  color: #fff;
  font-size: min(calc(20 * var(--vw)), 20px);
}

.copyright {
  margin-left: auto;
  color: #fff;
  font-size: min(calc(16 * var(--vw)), 16px);
  font-weight: 400;
}

.fixed-btn {
  position: fixed;
  top: 35%;
  right: 0;
  width: min(calc(220.8 * var(--vw)), 220.8px);
  aspect-ratio: 221/399;
  z-index: 100;
}

.fixed-btn a::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../images/fixed_btn_on.webp?ver20250821) no-repeat top center/contain;
  z-index: -1;
}

.fixed-btn a img {
  transition: 0.3s;
}

.fixed-btn a:hover img {
  opacity: 0;
}

.kv {
  position: relative;
  z-index: 1;
}

.page-body {
  position: relative;
  margin-top: -1.5vw;
}
.thanks-body {
  position: relative;
  height: 100%;
}
.page-body::before,
.thanks-body::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #e8f5e9 !important;
  z-index: -1;
}

.page-body iframe {
  margin: min(calc(68 * var(--vw)), 68px) 0;
  background-color: #e8f5e9 !important;
}

.contact-inner {
  background-color: #e8f5e9;
}

.thanks-body dl {
  padding: clamp(180px, 15vw, 200px) 0 clamp(150px, 12vw, 180px);
  text-align: center;
}

.thanks-body dl dt {
  font-size: clamp(22px, 1.6667vw, 32px);
  font-weight: 700;
}

.thanks-body dl dd {
  margin-top: clamp(28px, 2.0833vw, 40px);
  font-size: clamp(14px, 1.0938vw, 21px);
  line-height: 1.8;
}

.thanks-body dl dd span {
  font-weight: 700;
}

.thanks-body dl dd a {
  color: #20aaff;
  text-decoration: underline;
}

.thanks-body .thanks-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: clamp(200px, 15.625vw, 300px);
  height: clamp(48px, 3.6458vw, 70px);
  margin: clamp(34px, 2.6042vw, 50px) auto 0;
  color: #000;
  border: 1px solid #000;
  border-radius: clamp(6px, 0.5vw, 10px);
  background-color: #fff;
  font-size: clamp(16px, 1.25vw, 24px);
  font-weight: 700;
  transition: 0.3s;
}

.thanks-body .thanks-btn:hover {
  color: #fff;
  background-color: #000;
}
