@charset "utf-8";

/*****************************
* A Modern CSS Reset (https://github.com/hankchizljaw/modern-css-reset)
* 上記に、ul要素,ol要素,a要素への記述追加
*****************************/

/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd,
ul,
ol,
li {
  margin: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul,
ol {
  list-style: none;
  padding: 0;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100svh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}

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

/* Make images easier to work with */
img,
picture,
video {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

button {
  border: none;
  padding: 0;
  background-color: initial;
  cursor: pointer;
}

/* Remove all animations, transitions and smooth scroll for people that prefer not to see them */

@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}:root {
  --font-base: "Noto Sans JP", sans-serif;
  --font-en: "Barlow", sans-serif;
  --c-black: #231815;
  --c-main: #A65038;
  --c-gray: #F3F3F3;
  --transition-cubic: cubic-bezier(0.37, 0.88, 0.45, 0.97);
  --z-cta: 100;
  --inner-padding: 2.4rem;
}

html {
  font-family: var(--font-base);
  scroll-behavior: smooth;
  font-size: 12.3076923077px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
body {
  line-height: 1.6;
  letter-spacing: 0.04em;
  color: var(--c-black);
  font-feature-settings: "palt";
}

body.is-menu-open {
  overflow: clip;
}

a {
  transition: opacity 0.4s var(--transition-cubic);
}
sup {
  font-size: 0.8em;
  vertical-align: super;
}

svg {
  transition-property: fill, stroke;
  transition-duration: 0.4s;
  transition-timing-function: var(--transition-cubic);
  display: block;
}

.main {
  width: 100%;
  max-width: calc(390 * 0.1rem);
  margin-right: auto;
  margin-left: auto;
  box-shadow: 0 0 calc(45 * 0.1rem) 0 rgba(0, 0, 0, 0.1);
  overflow: hidden;
  min-height: 100vh;
  position: relative;
}

.main__bg {
  position: fixed;
  top: 0;
  width: calc(390 * 0.1rem);
  height: 100vh;
  overflow: hidden;
  z-index: -1;
  background-color: #fff;
}

.main__bg::before {
  content: "";
  display: block;
  aspect-ratio: 1/1;
  background: url(./images/bg_texture.png) center center/cover;
  position: absolute;
  animation: bg-texture 5s cubic-bezier(0.27, 0.64, 1, 1) alternate infinite;
}

@keyframes bg-texture {
  0% {
    width: calc(1061 * 0.1rem);
    top: calc(-149 * 0.1rem);
    left: calc(-323 * 0.1rem);
  }
  100% {
    width: calc(1173 * 0.1rem);
    top: calc(-205 * 0.1rem);
    left: calc(-329 * 0.1rem);
  }
}
.c-cta-btn {
  width: 100%;
  display: block;
  background: var(--c-main);
  padding: calc(21 * 0.1rem) calc(32 * 0.1rem) calc(20 * 0.1rem);
  border-radius: calc(4 * 0.1rem);
  box-shadow: calc(0 * 0.1rem) calc(8 * 0.1rem) calc(8 * 0.1rem) rgba(0, 0, 0, 0.15);
  position: relative;
  z-index: 0;
}

.c-cta-btn__tag {
  display: inline-block;
  padding: calc(3 * 0.1rem) calc(16 * 0.1rem) calc(5 * 0.1rem);
  background: #fff;
  border: calc(2 * 0.1rem) solid var(--c-main);
  border-radius: calc(999 * 0.1rem);
  font-size: calc(12 * 0.1rem);
  font-weight: bold;
  letter-spacing: 0.16em;
  line-height: 1.4166666667;
  color: var(--c-main);
  position: absolute;
  top: calc(3 * 0.1rem);
  left: 50%;
  translate: -50% -50%;
  z-index: 1;
}

.c-cta-btn__text {
  font-size: calc(16 * 0.1rem);
  font-weight: bold;
  color: #fff;
  text-align: center;
  letter-spacing: 0.16em;
}

.c-cta-btn::after {
  content: "";
  width: calc(24 * 0.1rem);
  aspect-ratio: 24/24;
  background: url(data:image/png;base64,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) center center/cover;
  position: absolute;
  top: 50%;
  right: calc(20 * 0.1rem);
  translate: 0 -50%;
  z-index: 1;
}

.c-cta-btn--pc {
  padding: 21px 32px 20px;
  border-radius: 4px;
  box-shadow: 0 8px 8px rgba(0, 0, 0, 0.15);
}

.c-cta-btn--pc .c-cta-btn__tag {
  padding: 3px 16px 5px;
  border: 2px solid var(--c-main);
  border-radius: 999px;
  font-size: 12px;
  top: 3px;
}

.c-cta-btn--pc .c-cta-btn__text {
  font-size: 16px;
}

.c-cta-btn--pc::after {
  width: 24px;
  aspect-ratio: 24/24;
  right: 20px;
}

.c-sub-title .text {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: calc(12 * 0.1rem);
  font-size: calc(18 * 0.1rem);
  font-weight: bold;
}

.c-sub-title .text::before,
.c-sub-title .text::after {
  content: "";
  width: calc(12 * 0.1rem);
  aspect-ratio: 12/16;
  display: inline-block;
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAgCAYAAAAIXrg4AAABEUlEQVR4AWIgBawMtf23MhRQS1ldsRUDMPQqzLBQO0Z37GZhZlA4/wU9RuuI/MP8wVLiD5Zysy1BDqDSbGOsIIMWAoIMWhAFaLWNCUrUaAkgajLgJAMkKR1TgjFtAkoCtCHfA0WnCgMEU9SU/xBCv3/9dK3bd7XTV7Xb436m1ulR6/Wf19XHdfd1rnS6+GqOmxWHxYz9csZhufB+MdPhfr2fzzgu5xzu+/3Zcy+AwN9k+Hvh9730vjJClvS8/v5nJDBXkIS//xv9aaa3k5G3k2HO5NNuYxws2nG9kqQgg80KqRBksFmDpCDAiqhE5+3GxlEGAkgCACKYog1hBksknI0pKCjRE4Bok42iKbLRHyHcAHsti8azHvFbAAAAAElFTkSuQmCC);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}

.c-titile-secondary {
  font-size: calc(18 * 0.1rem);
  font-weight: bold;
  letter-spacing: 0.08em;
  text-align: center;
}

.c-title {
  text-align: center;
}

.c-title__en {
  font-family: var(--font-en);
  font-size: calc(14 * 0.1rem);
  font-weight: 500;
  line-height: 1;
  color: var(--c-main);
}

.c-title__ja {
  margin-top: calc(12 * 0.1rem);
  padding-bottom: calc(14 * 0.1rem);
  font-size: calc(20 * 0.1rem);
  font-weight: bold;
  letter-spacing: 0.16em;
  position: relative;
}

.c-title__ja .small {
  font-size: calc(14 * 0.1rem);
  letter-spacing: 0.08em;
  font-weight: normal;
}

.c-title__ja::after {
  content: "";
  display: block;
  width: calc(22 * 0.1rem);
  aspect-ratio: 22/2;
  background-image: url('data:image/svg+xml;utf8,<svg width="22" height="2" viewBox="0 0 22 2" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M0 0.56936C0 0.119166 0.0706218 0 0.472265 0C0.684121 0 1.32411 0.0220686 1.88905 0.0485506C2.5511 0.0706189 3.80458 0.0706202 4.72704 0.0706202H16.5998C17.4958 0.0706202 18.3962 0.0706189 19.3892 0.0485506C19.9321 0.0264823 20.6913 0 20.8546 0C21.2562 0 21.3268 0.119166 21.3268 0.56936V0.948935C21.3268 1.39913 21.2562 1.5183 20.8546 1.5183C20.6868 1.5183 19.9586 1.49623 19.4113 1.46975C18.3962 1.44768 17.4958 1.44768 16.5998 1.44768H4.72704C3.80458 1.44768 2.57758 1.44768 1.91554 1.46975C1.34617 1.49182 0.688535 1.5183 0.472265 1.5183C0.0706218 1.5183 0 1.39913 0 0.948935V0.56936Z" fill="%23231815"/></svg>');
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  bottom: 0;
  left: 50%;
  translate: -50% 0;
}

.c-title--white .c-title__en,
.c-title--white .c-title__ja {
  color: #fff;
}
.c-title--white .c-title__ja::after {
  background-image: url('data:image/svg+xml;utf8,<svg width="22" height="2" viewBox="0 0 22 2" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M0 0.56936C0 0.119166 0.0706218 0 0.472265 0C0.684121 0 1.32411 0.0220686 1.88905 0.0485506C2.5511 0.0706189 3.80458 0.0706202 4.72704 0.0706202H16.5998C17.4958 0.0706202 18.3962 0.0706189 19.3892 0.0485506C19.9321 0.0264823 20.6913 0 20.8546 0C21.2562 0 21.3268 0.119166 21.3268 0.56936V0.948935C21.3268 1.39913 21.2562 1.5183 20.8546 1.5183C20.6868 1.5183 19.9586 1.49623 19.4113 1.46975C18.3962 1.44768 17.4958 1.44768 16.5998 1.44768H4.72704C3.80458 1.44768 2.57758 1.44768 1.91554 1.46975C1.34617 1.49182 0.688535 1.5183 0.472265 1.5183C0.0706218 1.5183 0 1.39913 0 0.948935V0.56936Z" fill="white"/></svg>');
}

.access {
  margin-top: calc(96 * 0.1rem);
  padding: calc(40 * 0.1rem) 0;
  position: relative;
  background: #f9f9f9;
}

.access::before {
  content: "";
  width: 100%;
  aspect-ratio: 390/32;
  position: absolute;
  top: 0;
  left: 0;
  transform: translateY(-100%);
  background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAwwAAABACAMAAACA0wDDAAAAM1BMVEX5+flHcEz////39/f09PT39/f4+Pj39/f19fX39/f39/f4+Pj39/f4+Pj4+Pj5+fn4+Pg8GTMUAAAAEXRSTlP/ABAgMEBQYHCAkJ+vv8/f73cCqtYAAAGTSURBVHja7dpBTsMwFEXR9z4S02T/q4QN/IeE01S0iKpSgSa5p47rSB36Jh7UFm6o775UulzI1lnpit90t0mXku9v+nLRX37Swg0+agx1muwvk0rr0m/amzkjjHVOlul8m+iYdhuDLZVkX196F26ZljyS89WSesexbDyGOg1b9rhht/+Bac0jWYZ662exrcRQUsmWfQqALf+cJqnXMTrZSiO2no2tWifb3uPZ/WjmrHGcp7scIYaSbauWBY/7A5lGIK0k+Vz8YIcx1Lrt2fq4MudUxlUdO4ihZJeWD3sfd5rU4zMC2VgMtl0qW2Vz2MdDzUmS32rDftz2t3n24y/No4tO1P1fMdh2LQmw/fEcpiTppNX9yzHY9TlcnH7w9KZWJ2M8KIZyjQB4AWCzplFFq/veGEYBpSreANiZuZMeafwQg/1ilykAB7F00elo8KurOAXh0KZOpzfyDyoAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAwAZ8ADcQuycqpCIYAAAAAElFTkSuQmCC) center center/cover no-repeat;
}

.access__map {
  margin-top: calc(32 * 0.1rem);
  aspect-ratio: 390/240;
}

.access__map iframe {
  width: 100%;
  height: 100%;
}

.access__info {
  margin-top: calc(32 * 0.1rem);
  margin-right: var(--inner-padding);
  margin-left: var(--inner-padding);
}

.access__info-item {
  display: grid;
  grid-template-columns: calc(64 * 0.1rem) 1fr;
  gap: calc(12 * 0.1rem);
  position: relative;
}

.access__info-item:not(:first-child) {
  padding-top: calc(14 * 0.1rem);
}

.access__info-item:not(:first-child)::after {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  top: 0;
  left: 0;
  background-image: radial-gradient(circle, #231815 0.5px, transparent 0.5px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 7px 1px;
}

.access__info-item + .access__info-item {
  margin-top: calc(14 * 0.1rem);
}

.access__info-title {
  font-size: calc(13 * 0.1rem);
  font-weight: bold;
  letter-spacing: 0.08em;
}

.access__info-text {
  font-size: calc(13 * 0.1rem);
  line-height: 1.6153846154;
  letter-spacing: 0.08em;
}

.access__info-text:has(.icon) {
  display: flex;
  gap: calc(8 * 0.1rem);
}

.access__info-text .icon {
  width: calc(16 * 0.1rem);
  height: calc(16 * 0.1rem);
  display: inline-block;
  margin-top: calc(3 * 0.1rem);
  margin-right: calc(-4 * 0.1rem);
  margin-left: calc(-4 * 0.1rem);
}

.access__info-text .icon svg {
  width: 100%;
  height: 100%;
}

.access__info-text .strong {
  font-weight: bold;
}

.access__info-text + .access__info-text {
  margin-top: calc(8 * 0.1rem);
}

.bg-white {
  position: relative;
}

.bg-white::before {
  content: "";
  display: block;
  width: 100%;
  background: #fff;
  position: absolute;
  top: calc(-70 * 0.1rem);
  bottom: calc(-90 * 0.1rem);
  left: 0;
  z-index: -1;
}

.booking {
  margin-top: calc(48 * 0.1rem);
  margin-right: var(--inner-padding);
  margin-left: var(--inner-padding);
  padding: calc(32 * 0.1rem) calc(24 * 0.1rem);
  background: #fff;
  box-shadow: calc(10 * 0.1rem) calc(10 * 0.1rem) calc(24 * 0.1rem) 0 rgba(0, 0, 0, 0.1);
}

.booking__lead {
  margin-top: calc(16 * 0.1rem);
  font-size: calc(14 * 0.1rem);
  letter-spacing: 0.08em;
  text-align: center;
}

.booking__form {
  margin-top: calc(24 * 0.1rem);
}

.js-fade-in {
  opacity: 0;
  filter: blur(10px);
  transition-duration: 0.45s;
  transition-property: opacity, filter;
  transition-timing-function: cubic-bezier(0.37, 0.88, 0.45, 0.97);
}

.js-fade-in.is-active {
  opacity: 1;
  filter: blur(0);
}

.fixed-cta {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  padding: 0 calc(8 * 0.1rem) calc(8 * 0.1rem) calc(8 * 0.1rem);
  transition-duration: 0.4s;
  transition-property: opacity, visibility;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
}

.fixed-cta .c-cta-btn {
  pointer-events: auto;
  max-width: calc(374 * 0.1rem);
  margin-right: auto;
  margin-left: auto;
}

.fixed-cta.is-disabled {
  opacity: 0;
  visibility: hidden;
}

.flow-item {
  display: grid;
  grid-template-columns: calc(132 * 0.1rem) 1fr;
  gap: calc(21 * 0.1rem);
  align-items: center;
  position: relative;
}

.flow-item:not(:last-child) {
  padding-bottom: calc(27 * 0.1rem);
}

.flow-item:not(:last-child)::after {
  content: "";
  width: calc(11 * 0.1rem);
  aspect-ratio: 11/11;
  display: block;
  background-image: url('data:image/svg+xml;utf8,<svg width="11" height="11" viewBox="0 0 11 11" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M10.165 0.616211L5.83301 10.2412H4.33203L0 0.616211L1.36914 0L5.08203 8.25293L8.7959 0L10.165 0.616211Z" fill="%23A65038"/></svg>');
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}

.flow-item__img {
  aspect-ratio: 1/1;
  border-radius: 2px;
  overflow: hidden;
  box-shadow: calc(10 * 0.1rem) calc(10 * 0.1rem) calc(24 * 0.1rem) 0 rgba(0, 0, 0, 0.1);
}

.flow-item__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.flow-item__min {
  display: grid;
  grid-template-columns: calc(16 * 0.1rem) 1fr;
  gap: calc(4 * 0.1rem);
  align-items: center;
}

.flow-item__min .icon {
  display: block;
  aspect-ratio: 1/1;
}

.flow-item__min .icon svg {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.flow-item__min .text {
  font-size: calc(14 * 0.1rem);
  font-weight: bold;
  line-height: 1;
  font-family: var(--font-en);
  font-weight: 500;
  color: var(--c-main);
}

.flow-item__title {
  margin-top: calc(2 * 0.1rem);
  font-size: calc(16 * 0.1rem);
  font-weight: bold;
}

.flow-item__text {
  margin-top: calc(8 * 0.1rem);
  font-size: calc(13 * 0.1rem);
  letter-spacing: 0.08em;
}

.flow-item__note {
  margin-top: calc(4 * 0.1rem);
  font-size: calc(11 * 0.1rem);
  letter-spacing: 0.08em;
}

.flow-item__step {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: calc(70 * 0.1rem);
  aspect-ratio: 64/56;
  padding-top: 1px;
  background: url(./images/bg_flow_step.png) center center/contain no-repeat;
  font-size: calc(12 * 0.1rem);
  line-height: 1;
  font-family: var(--font-en);
  font-weight: 500;
  text-transform: uppercase;
  position: absolute;
  top: calc(-31 * 0.1rem);
  left: calc(-20 * 0.1rem);
}

.flow-item__step--goal {
  background: url(./images/bg_flow_step_goal.png) center center/contain no-repeat;
  color: #fff;
}

.flow-item__step .num {
  font-size: calc(18 * 0.1rem);
}

.flow {
  padding-top: calc(64 * 0.1rem);
  padding-bottom: calc(64 * 0.1rem);
}

.flow__lead {
  margin-top: calc(12 * 0.1rem);
  margin-right: var(--inner-padding);
  margin-left: var(--inner-padding);
  font-size: calc(14 * 0.1rem);
  letter-spacing: 0.08em;
  text-align: center;
}

.flow__lead .strong {
  font-weight: bold;
}

.flow__list {
  margin-top: calc(40 * 0.1rem);
  margin-right: var(--inner-padding);
  margin-left: var(--inner-padding);
}

.flow__item + .flow__item {
  margin-top: calc(16 * 0.1rem);
}

.flow__point-container {
  margin-top: calc(32 * 0.1rem);
  margin-right: var(--inner-padding);
  margin-left: var(--inner-padding);
}

.flow__point-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: calc(6 * 0.1rem);
  padding-bottom: calc(12 * 0.1rem);
  position: relative;
}

.flow__point-list::after {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-image: radial-gradient(circle, #231815 0.5px, transparent 0.5px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 7px 1px;
}

.flow__point-note {
  margin-top: calc(12 * 0.1rem);
  font-size: calc(12 * 0.1rem);
  letter-spacing: 0.08em;
  padding-left: calc(17 * 0.1rem);
  text-indent: calc(-17 * 0.1rem);
}

.flow__point-note + .flow__point-note {
  margin-top: calc(8 * 0.1rem);
}

.flow__point-note .asterisk {
  padding-right: calc(4 * 0.1rem);
}

.footer {
  padding: calc(40 * 0.1rem) var(--inner-padding);
  background: var(--c-black);
}

.footer__logo {
  width: calc(188 * 0.1rem);
  aspect-ratio: 188/40;
  max-width: 100%;
}

.footer__logo img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.footer__contents {
  margin-top: calc(32 * 0.1rem);
  display: flex;
  align-items: flex-end;
}

.footer__sns {
  display: flex;
  gap: calc(11 * 0.1rem);
}

.sns__item {
  width: calc(24 * 0.1rem);
  aspect-ratio: 1/1;
}

.sns__item img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.footer__company {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: calc(4 * 0.1rem);
  font-size: calc(13 * 0.1rem);
  line-height: 1;
  letter-spacing: 0.08em;
  color: #fff;
}

.footer__company::after {
  content: "";
  width: calc(15 * 0.1rem);
  aspect-ratio: 15/13;
  display: block;
  background-image: url('data:image/svg+xml;utf8,<svg width="15" height="13" viewBox="0 0 15 13" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M11 12H0V5H11V12Z" fill="%23ffffff"/><path d="M15 8H13V3H4V1H15V8Z" fill="%23ffffff"/></svg>');
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}

.form__item + .form__item {
  margin-top: calc(10 * 0.1rem);
}

.form__label {
  display: block;
}

.form__label-text {
  display: flex;
  align-items: center;
  gap: calc(2 * 0.1rem);
  font-size: calc(14 * 0.1rem);
  font-weight: bold;
  letter-spacing: 0.08em;
}

.form__label-text .icon {
  width: calc(12 * 0.1rem);
  height: calc(12 * 0.1rem);
  display: block;
}

.form__label-text .icon svg {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.form__label-note {
  padding-left: calc(4 * 0.1rem);
  font-size: calc(12 * 0.1rem);
  font-weight: normal;
}

.form__input,
.form__select,
.form__textarea {
  margin-top: calc(8 * 0.1rem);
  width: 100%;
  background: #F2F2F2;
  border-radius: 2px;
  font-size: 16px;
  color: var(--c-black);
  border: none;
}

.form__input,
.form__select {
  height: calc(44 * 0.1rem);
  padding: calc(4 * 0.1rem) calc(16 * 0.1rem);
}

.form__textarea {
  min-height: calc(44 * 0.1rem);
  padding: calc(4 * 0.1rem) calc(16 * 0.1rem);
  resize: vertical;
}

.form__input::-moz-placeholder, .form__textarea::-moz-placeholder {
  color: #b9b9b9;
}

.form__input::placeholder,
.form__textarea::placeholder {
  color: #b9b9b9;
}

.form__select {
  padding-right: calc(40 * 0.1rem);
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-image: url("data:image/svg+xml,%3csvg%20width='11'%20height='11'%20viewBox='0%200%2011%2011'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20d='M10.165%200.616211L5.83301%2010.2412H4.33203L0%200.616211L1.36914%200L5.08203%208.25293L8.7959%200L10.165%200.616211Z'%20fill='%23A65038'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right calc(16 * 0.1rem) center;
  background-size: calc(11 * 0.1rem) auto;
}

.form__datetime-list {
  margin-top: calc(8 * 0.1rem);
}

.form__datetime-item {
  display: grid;
  grid-template-columns: calc(52 * 0.1rem) 1fr;
  gap: calc(8 * 0.1rem);
  align-items: center;
}

.form__datetime-item + .form__datetime-item {
  margin-top: calc(4 * 0.1rem);
}

.form__datetime-label {
  font-size: calc(13 * 0.1rem);
}

.form__input--datetime {
  margin-top: 0;
}

.form__radio-group {
  margin-top: calc(8 * 0.1rem);
  display: flex;
  flex-wrap: wrap;
  gap: calc(12 * 0.1rem) calc(24 * 0.1rem);
}

.form__radio-group--payment {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(8 * 0.1rem);
}

.form__radio {
  display: flex;
  align-items: center;
  -moz-column-gap: calc(10 * 0.1rem);
       column-gap: calc(10 * 0.1rem);
  width: -moz-fit-content;
  width: fit-content;
  line-height: 1;
  cursor: pointer;
}

.form__radio-input {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  position: relative;
  width: calc(24 * 0.1rem);
  height: calc(24 * 0.1rem);
  border-radius: calc(9999 * 0.1rem);
  background-color: #f2f2f2;
  cursor: pointer;
  margin: 0;
}

.form__radio-input:checked {
  background-color: #231815;
}

.form__radio-input:checked::after {
  content: "";
  position: absolute;
  inset: 0;
  width: calc(10 * 0.1rem);
  height: calc(10 * 0.1rem);
  margin: auto;
  border-radius: calc(9999 * 0.1rem);
  background-color: #ffffff;
}

.form__radio-text {
  font-size: calc(14 * 0.1rem);
  letter-spacing: 0.08em;
  line-height: 1;
  white-space: nowrap;
}

.form__check {
  margin-top: calc(8 * 0.1rem);
  display: flex;
  align-items: center;
  -moz-column-gap: calc(10 * 0.1rem);
       column-gap: calc(10 * 0.1rem);
  width: -moz-fit-content;
  width: fit-content;
  line-height: 1;
  cursor: pointer;
}

.form__check:not(:last-of-type) {
  margin-bottom: calc(16 * 0.1rem);
}

.form__check-input {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  position: relative;
  width: calc(24 * 0.1rem);
  height: calc(24 * 0.1rem);
  border-radius: 2px;
  background-color: #f2f2f2;
  cursor: pointer;
  margin: 0;
}

.form__check-input:checked {
  background-color: #a65038;
}

.form__check-input:checked::after {
  content: "";
  position: absolute;
  top: calc(6 * 0.1rem);
  left: calc(5 * 0.1rem);
  width: calc(14 * 0.1rem);
  height: calc(8 * 0.1rem);
  border-bottom: calc(2 * 0.1rem) solid #ffffff;
  border-left: calc(2 * 0.1rem) solid #ffffff;
  transform: rotate(-45deg);
}

.form__check-text {
  font-size: calc(13 * 0.1rem);
  letter-spacing: 0.08em;
  line-height: 1;
}

.form__check-text a {
  text-decoration: underline;
}

.form__privacy {
  margin-top: calc(20 * 0.1rem);
  padding-top: calc(20 * 0.1rem);
  position: relative;
}

.form__privacy .form__check-text {
  font-size: calc(14 * 0.1rem);
}

.form__privacy::after {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  top: 0;
  left: 0;
  background-image: radial-gradient(circle, #231815 0.5px, transparent 0.5px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 7px 1px;
}

.form__submit {
  margin-top: calc(20 * 0.1rem);
}

.kv__lead {
  font-size: calc(14 * 0.1rem);
  line-height: 2;
  letter-spacing: 0.08em;
  text-align: center;
}

.kv__point-list {
  margin-top: calc(4 * 0.1rem);
  padding: calc(36 * 0.1rem) calc(37 * 0.1rem) calc(33 * 0.1rem);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.kv__point-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: calc(2 * 0.1rem);
  position: relative;
  z-index: 0;
}

.kv__point-item::before {
  content: "";
  background: url(./images/bg_kv_points.png) center center/cover;
  width: calc(126 * 0.1rem);
  aspect-ratio: 126/115;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  z-index: -1;
}

.kv__point-item .icon {
  width: calc(24 * 0.1rem);
  aspect-ratio: 1/1;
}

.kv__point-item .icon img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.kv__point-item .text {
  min-height: calc(34 * 0.1rem);
  display: grid;
  place-content: center;
  font-size: calc(13 * 0.1rem);
  line-height: 1.2;
  font-weight: 500;
  text-align: center;
}

.kv__point-item .text .small {
  font-size: calc(11 * 0.1rem);
}

.kv__plan {
  margin-top: calc(28 * 0.1rem);
}

.kv__logo02 {
  margin-top: calc(-32 * 0.1rem);
  width: calc(136 * 0.1rem);
  aspect-ratio: 136/80;
  margin-right: auto;
  margin-left: auto;
  position: relative;
}

.kv__logo02::before {
  content: "";
  width: calc(184 * 0.1rem);
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff;
  position: absolute;
  top: calc(-31 * 0.1rem);
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}

.kv__logo02 img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.kv-plan {
  margin-left: var(--inner-padding);
  margin-right: var(--inner-padding);
  padding: calc(20 * 0.1rem) calc(16 * 0.1rem) calc(24 * 0.1rem);
  border: 1px solid #DBDBDB;
  border-radius: calc(4 * 0.1rem);
  background: #fff;
  position: relative;
  z-index: 1;
}

.kv-plan__title {
  font-size: calc(18 * 0.1rem);
  line-height: 1;
  font-weight: bold;
  text-align: center;
}

.kv-plan__list {
  margin-top: calc(14 * 0.1rem);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: calc(9 * 0.1rem);
}

.kv-plan__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(4 * 0.1rem);
}

.kv-plan__minutes {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: calc(2 * 0.1rem);
  min-width: calc(64 * 0.1rem);
  height: calc(24 * 0.1rem);
  padding: calc(3 * 0.1rem);
  border-radius: calc(999 * 0.1rem);
  background: var(--c-black);
  font-size: calc(12 * 0.1rem);
  line-height: 1;
  color: #fff;
}

.kv-plan__minutes .num {
  font-size: calc(18 * 0.1rem);
  font-family: var(--font-en);
}

.kv-plan__cnt {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  line-height: 1;
}

.kv-plan__cnt .unit {
  padding-bottom: calc(3 * 0.1rem);
  font-size: calc(10 * 0.1rem);
  line-height: 1.2;
  writing-mode: vertical-rl;
}

.kv-plan__cnt .num {
  padding-left: calc(5 * 0.1rem);
  padding-right: calc(3 * 0.1rem);
  font-size: calc(32 * 0.1rem);
  font-family: var(--font-en);
}

.kv-plan__cnt .yen {
  font-size: calc(14 * 0.1rem);
  padding-bottom: calc(5 * 0.1rem);
}

.kv-plan__line {
  width: 1px;
  background-image: radial-gradient(circle, #231815 0.5px, transparent 0.5px);
  background-position: left top;
  background-repeat: repeat-y;
  background-size: 1px 7px;
}

.kv-plan__btn {
  margin-top: calc(26 * 0.1rem);
}

.kv-plan__tags {
  margin-top: calc(16 * 0.1rem);
}

.kv-plan__balloon {
  width: calc(88 * 0.1rem);
  aspect-ratio: 88/75;
  background-position: center center;
  background-size: contain;
  background-repeat: no-repeat;
  background-image: url(data:image/png;base64,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);
  position: absolute;
  top: calc(-20 * 0.1rem);
  left: calc(-14 * 0.1rem);
}

.kv-plan__balloon-text {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  gap: calc(2 * 0.1rem);
  color: #fff;
  font-size: calc(12 * 0.1rem);
  font-weight: bold;
  line-height: 1;
}

.kv-plan__balloon-text .num {
  font-size: calc(16 * 0.1rem);
  font-family: var(--font-en);
  font-weight: 600;
}

.kv-plan__balloon-text .yen {
  font-size: calc(11 * 0.1rem);
}

.kv01 {
  padding-top: calc(16 * 0.1rem);
}

.kv01__logo {
  margin-top: calc(32 * 0.1rem);
  width: calc(136 * 0.1rem);
  aspect-ratio: 136/80;
  margin-right: auto;
  margin-left: auto;
}

.kv01__lead.kv__lead {
  margin-top: calc(14 * 0.1rem);
}

.kv01__logo img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.kv01__copy {
  margin-top: calc(32 * 0.1rem);
  margin-bottom: calc(20 * 0.1rem);
  width: calc(253 * 0.1rem);
  aspect-ratio: 253/132;
  margin-right: auto;
  margin-left: auto;
}

.kv01__copy img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.kv01__plan.kv__plan {
  margin-top: calc(-12 * 0.1rem);
}

.kv01__point-list {
  margin-top: calc(14 * 0.1rem);
}

.kv01__slider-bottom {
  margin-top: calc(12 * 0.1rem);
}

.kv02__slider-container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(2 * 0.1rem);
  height: calc(363 * 0.1rem);
  overflow: hidden;
  position: relative;
  z-index: -1;
}

.kv02__slider-container::after {
  content: "";
  width: 100%;
  height: calc(12 * 0.1rem);
  background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAwwAAAAYCAMAAABgDopZAAAAM1BMVEVHcEz////////////////////////////////////////////////////////////////P0YphAAAAEHRSTlMAECAwQFBgcICQoLDA0ODv2eilPQAAAXJJREFUeNrt2kmSwyAUA1DpL3qd+x9W6rKNm8o8p2Nbzz8Y2AYBqQp2ETHCLiIShoiEISJhiDiPP8ViFSI2y5YsExMWx1CwiIgtECTLko0RcaQKYyiSi1gfW7JlWThEXFLkUIXco2LBZHkq4QLiRmShpmJOjPh2tmVbY4vbEI8okjUWc2TEl7BtQfZQeADxtGKLBhKN+CxBPQJ4FvFaLRNTQnKfirfs/nZLAV6KeKOejenJuRH3Un9sCPsWFYZDhfoLSH6JxxHBtiG7ReDAmsJwJh3k2MnhsTHz0odwdePfQBiOkSRI1NxLQFZBsOcGmnr32GQYTiq0XLQuCrljfSl7KGGuNrEAi15R5FCoVm2Qk+QTbMyrXGPZEBay6tcYhgtqqJaQ/kEhWbmVANj7bwH2wpf89sJwRUtHj0hvWrvea5jd2rmr3vTOFq31G3+JHonqo/bq032mT3aFl7HPDXtXBzPqo9Vu6LECdUL+HhwR/+8XKUa0Ew4L0RYAAAAASUVORK5CYII=) center center/cover;
  position: absolute;
  bottom: -1px;
  left: 0;
  rotate: 180deg;
  z-index: 1;
}

.kv02__copy {
  margin-top: calc(40 * 0.1rem);
  margin-right: auto;
  margin-left: auto;
  width: calc(265 * 0.1rem);
  aspect-ratio: 265/110;
}

.kv02__copy img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.kv02__lead {
  margin-top: calc(32 * 0.1rem);
}

.kv03 {
  position: relative;
  z-index: 0;
}

.kv03__images {
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
  z-index: -1;
  border: calc(5 * 0.1rem) solid #fff;
  overflow: hidden;
}

.kv03__images::before {
  content: "";
  position: absolute;
  inset: calc(-5 * 0.1rem);
  box-shadow: inset 0px 0px 40px #231815;
  z-index: 2;
}

.kv03__images::after {
  content: "";
  width: 100%;
  height: calc(12 * 0.1rem);
  background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAwwAAAAYCAMAAABgDopZAAAAM1BMVEVHcEz////////////////////////////////////////////////////////////////P0YphAAAAEHRSTlMAECAwQFBgcICQoLDA0ODv2eilPQAAAXJJREFUeNrt2kmSwyAUA1DpL3qd+x9W6rKNm8o8p2Nbzz8Y2AYBqQp2ETHCLiIShoiEISJhiDiPP8ViFSI2y5YsExMWx1CwiIgtECTLko0RcaQKYyiSi1gfW7JlWThEXFLkUIXco2LBZHkq4QLiRmShpmJOjPh2tmVbY4vbEI8okjUWc2TEl7BtQfZQeADxtGKLBhKN+CxBPQJ4FvFaLRNTQnKfirfs/nZLAV6KeKOejenJuRH3Un9sCPsWFYZDhfoLSH6JxxHBtiG7ReDAmsJwJh3k2MnhsTHz0odwdePfQBiOkSRI1NxLQFZBsOcGmnr32GQYTiq0XLQuCrljfSl7KGGuNrEAi15R5FCoVm2Qk+QTbMyrXGPZEBay6tcYhgtqqJaQ/kEhWbmVANj7bwH2wpf89sJwRUtHj0hvWrvea5jd2rmr3vTOFq31G3+JHonqo/bq032mT3aFl7HPDXtXBzPqo9Vu6LECdUL+HhwR/+8XKUa0Ew4L0RYAAAAASUVORK5CYII=) center center/cover;
  position: absolute;
  bottom: -1px;
  left: 0;
  rotate: 180deg;
  z-index: 3;
}

.kv03__image {
  position: absolute;
  inset: 0;
  animation: image-switch-animation 8s infinite;
  z-index: 0;
}

.kv03__image:nth-child(1) {
  animation-delay: 0s;
}

.kv03__image:nth-child(2) {
  opacity: 0;
  animation-delay: 4s;
}

.kv03__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

@keyframes image-switch-animation {
  0% {
    opacity: 1;
    scale: 1;
  }
  50% {
    opacity: 1;
  }
  66% {
    opacity: 0;
    z-index: 1;
  }
  100% {
    opacity: 0;
    scale: 1.05;
  }
}
.kv03__label {
  display: block;
  background: #fff;
  padding: calc(5 * 0.1rem) 0;
  color: var(--c-main);
  font-size: calc(16 * 0.1rem);
  letter-spacing: 0.16em;
  writing-mode: vertical-rl;
  position: absolute;
  top: calc(19 * 0.1rem);
  left: calc(19 * 0.1rem);
  z-index: 2;
}

.kv03__copy {
  margin-top: calc(38 * 0.1rem);
  margin-right: auto;
  margin-left: auto;
  width: calc(315 * 0.1rem);
  aspect-ratio: 315/72;
}

.kv03__copy img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.kv03__lead {
  margin-top: calc(32 * 0.1rem);
}

.kv04__logo {
  margin: calc(15 * 0.1rem) auto;
  width: calc(169 * 0.1rem);
  aspect-ratio: 169/36;
}

.kv04__head {
  display: grid;
  grid-template-columns: 1fr calc(40 * 0.1rem);
}

.kv04__images {
  position: relative;
  aspect-ratio: 350/437;
  overflow: hidden;
}

.kv04__image {
  position: absolute;
  inset: 0;
  opacity: 0;
  animation: image-switch-animation02 12s infinite;
  z-index: 0;
}

.kv04__image:nth-child(1) {
  animation-delay: 0s;
}

.kv04__image:nth-child(2) {
  animation-delay: 3s;
}

.kv04__image:nth-child(3) {
  animation-delay: 6s;
}

.kv04__image:nth-child(4) {
  animation-delay: 9s;
}

.kv04__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

@keyframes image-switch-animation02 {
  0% {
    opacity: 1;
    scale: 1;
  }
  25% {
    opacity: 1;
  }
  38% {
    opacity: 0;
    z-index: 1;
  }
  100% {
    opacity: 0;
    scale: 1.05;
  }
}
.kv04__label {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: calc(14 * 0.1rem);
  color: var(--c-main);
  letter-spacing: 0.16em;
  writing-mode: vertical-rl;
}

.kv04__label .dot {
  padding-left: 0.5em;
}

_::-webkit-full-page-media, _:future, :root .kv04__label .dot {
  padding-left: 0;
}

.kv04__copy {
  width: calc(234 * 0.1rem);
  aspect-ratio: 234/100;
  position: absolute;
  bottom: calc(4 * 0.1rem);
  left: calc(4 * 0.1rem);
  z-index: 2;
}

.kv04__copy img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.kv04__lead {
  margin-top: calc(24 * 0.1rem);
  margin-right: var(--inner-padding);
  margin-left: var(--inner-padding);
}

.kv04__lead.kv__lead {
  text-align: left;
}

.kv05__images {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(4 * 0.1rem);
  position: relative;
  z-index: -1;
}

.kv05__images::after {
  content: "";
  width: 100%;
  height: calc(12 * 0.1rem);
  background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAwwAAAAYCAMAAABgDopZAAAAM1BMVEVHcEz////////////////////////////////////////////////////////////////P0YphAAAAEHRSTlMAECAwQFBgcICQoLDA0ODv2eilPQAAAXJJREFUeNrt2kmSwyAUA1DpL3qd+x9W6rKNm8o8p2Nbzz8Y2AYBqQp2ETHCLiIShoiEISJhiDiPP8ViFSI2y5YsExMWx1CwiIgtECTLko0RcaQKYyiSi1gfW7JlWThEXFLkUIXco2LBZHkq4QLiRmShpmJOjPh2tmVbY4vbEI8okjUWc2TEl7BtQfZQeADxtGKLBhKN+CxBPQJ4FvFaLRNTQnKfirfs/nZLAV6KeKOejenJuRH3Un9sCPsWFYZDhfoLSH6JxxHBtiG7ReDAmsJwJh3k2MnhsTHz0odwdePfQBiOkSRI1NxLQFZBsOcGmnr32GQYTiq0XLQuCrljfSl7KGGuNrEAi15R5FCoVm2Qk+QTbMyrXGPZEBay6tcYhgtqqJaQ/kEhWbmVANj7bwH2wpf89sJwRUtHj0hvWrvea5jd2rmr3vTOFq31G3+JHonqo/bq032mT3aFl7HPDXtXBzPqo9Vu6LECdUL+HhwR/+8XKUa0Ew4L0RYAAAAASUVORK5CYII=) center center/cover;
  position: absolute;
  bottom: 0;
  left: 0;
  rotate: 180deg;
  z-index: 1;
}

.kv05__image {
  aspect-ratio: 193/275;
}

.kv05__copy {
  margin-top: calc(40 * 0.1rem);
  margin-right: auto;
  margin-left: auto;
  width: calc(342 * 0.1rem);
  aspect-ratio: 342/76;
}

.kv05__lead {
  margin-top: calc(32 * 0.1rem);
}

.pc {
  display: none;
  position: relative;
}

.pc-bg {
  position: fixed;
  z-index: -1;
  inset: 0;
  background-color: #fff;
  overflow: hidden;
}

.pc-bg::before {
  content: "";
  width: 116.1805555556vw;
  aspect-ratio: 1/1;
  background: url(./images/bg_texture.png) center center/cover;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
}

.pc-logo,
.pc-nav {
  position: fixed;
  top: 0;
  width: calc((100% - 480px) / 2);
  height: 100%;
}

.pc-logo {
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-right: 24px;
  padding-left: 24px;
}

.pc-logo__img {
  width: 310px;
  max-width: 100%;
  aspect-ratio: 310/66;
}

.pc-logo__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.pc-nav {
  right: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-right: 24px;
  padding-left: 24px;
}

.pc-nav__list {
  width: 310px;
  max-width: 100%;
  margin-right: auto;
  margin-left: auto;
}

.pc-nav__item {
  position: relative;
}

.pc-nav__item::before {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  top: 0;
  left: 0;
  background-image: radial-gradient(circle, #231815 0.5px, transparent 0.5px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 7px 1px;
}

.pc-nav__item:last-child::after {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-image: radial-gradient(circle, #231815 0.5px, transparent 0.5px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 7px 1px;
}

.pc-nav__link {
  padding: clamp(10px, 2.5vh, 20px) 8px;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0.08em;
  display: flex;
  align-items: center;
  gap: 8px;
}

.pc-nav__link::before {
  content: "";
  width: calc(11 * 0.1rem);
  aspect-ratio: 11/11;
  display: block;
  background-image: url('data:image/svg+xml;utf8,<svg width="11" height="11" viewBox="0 0 11 11" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M10.165 0.616211L5.83301 10.2412H4.33203L0 0.616211L1.36914 0L5.08203 8.25293L8.7959 0L10.165 0.616211Z" fill="%23A65038"/></svg>');
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  rotate: -90deg;
}

.pc-nav__btn {
  margin-top: clamp(24px, 8vh, 64px);
  width: 310px;
  max-width: 100%;
  margin-right: auto;
  margin-left: auto;
}

.pics__item01 {
  width: calc(88 * 0.1rem);
  aspect-ratio: 88/88;
  margin-left: auto;
  margin-right: calc(23 * 0.1rem);
}

.pics__item02 {
  margin-top: calc(-64 * 0.1rem);
  width: 100%;
  aspect-ratio: 390/229;
}

.pics__item03 {
  margin-top: calc(-112 * 0.1rem);
  margin-left: calc(24 * 0.1rem);
  width: calc(96 * 0.1rem);
  aspect-ratio: 96/144;
}

.pics__item01,
.pics__item03 {
  border-radius: 2px;
  overflow: hidden;
  box-shadow: calc(10 * 0.1rem) calc(10 * 0.1rem) calc(24 * 0.1rem) 0 rgba(0, 0, 0, 0.1);
  position: relative;
  z-index: 1;
}

.plans-item {
  padding: calc(20 * 0.1rem) calc(24 * 0.1rem) calc(32 * 0.1rem);
  border-radius: calc(24 * 0.1rem) calc(2 * 0.1rem) calc(2 * 0.1rem) calc(2 * 0.1rem);
  background: #fff;
  box-shadow: calc(10 * 0.1rem) calc(10 * 0.1rem) calc(24 * 0.1rem) 0 rgba(0, 0, 0, 0.1);
  position: relative;
}

.plans-item--std {
  --head-color: var(--c-main);
}

.plans-item__en-title {
  color: var(--head-color, var(--c-black));
  font-size: calc(16 * 0.1rem);
  font-family: var(--font-en);
  font-weight: 500;
  text-align: center;
}

.plans-item__ja-title {
  margin-top: calc(24 * 0.1rem);
  color: var(--head-color, var(--c-black));
}

.plans-item__price {
  margin-top: calc(16 * 0.1rem);
  line-height: 1;
}

.plans-item__price-main {
  color: var(--head-color, var(--c-black));
  text-align: center;
}

.plans-item__price-main .tax {
  font-size: calc(14 * 0.1rem);
  font-weight: 500;
  line-height: 1.2;
  writing-mode: vertical-rl;
}

.plans-item__price-main .num {
  font-size: calc(48 * 0.1rem);
  font-family: var(--font-en);
  font-weight: 500;
  padding-left: calc(8 * 0.1rem);
  padding-right: calc(3 * 0.1rem);
}

.plans-item__price-main .yen {
  font-size: calc(20 * 0.1rem);
  font-weight: bold;
}

.plans-item__price-main .unit {
  font-size: calc(14 * 0.1rem);
  font-weight: bold;
}

.plans-item__price-sub {
  margin-top: calc(9 * 0.1rem);
  color: #636363;
  font-size: calc(14 * 0.1rem);
  text-align: center;
}

.plans-item__price-sub .text {
  letter-spacing: 0.08em;
  padding-right: calc(2 * 0.1rem);
}

.plans-item__price-sub .price {
  padding: 0 calc(3 * 0.1rem);
  position: relative;
}

.plans-item__price-sub .price::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  height: 1px;
  background: #636363;
}

.plans-item__price-sub .num {
  font-size: calc(18 * 0.1rem);
  font-family: var(--font-en);
  font-weight: 500;
}

.plans-item__list {
  margin-top: calc(32 * 0.1rem);
}

.plans-item__item {
  display: grid;
  grid-template-columns: calc(20 * 0.1rem) 1fr;
  gap: calc(4 * 0.1rem);
  padding-bottom: calc(12 * 0.1rem);
  align-items: center;
  font-size: calc(14 * 0.1rem);
  line-height: 1;
  letter-spacing: 0.08em;
  position: relative;
}

.plans-item__item::after {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-image: radial-gradient(circle, #231815 0.5px, transparent 0.5px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 7px 1px;
}

.plans-item__item .icon {
  width: 100%;
  aspect-ratio: 1/1;
}

.plans-item__item .icon svg {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.plans-item__item .strong {
  font-weight: bold;
}

.plans-item__item + .plans-item__item {
  margin-top: calc(12 * 0.1rem);
}

.plans-item__tag {
  width: calc(64 * 0.1rem);
  aspect-ratio: 64/57;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: calc(12 * 0.1rem);
  line-height: 1;
  color: #fff;
  position: absolute;
  top: calc(-6 * 0.1rem);
  left: calc(-6 * 0.1rem);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}

.plans-item--std .plans-item__tag {
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIAAAAByCAMAAACsuinrAAAAeFBMVEVHcEyfTzekTzWkTzelTzelUDimUDelUDilUDimUDilUDikTzimTzaiTzmmUDefTz+jTzekUDikTzejTzalUDelUDmjUDilUDelTzalTzemUDelTzmmTzenTzenTzelTzemUDimUDilTzijTzilTzemTzenTzelTzglo3RuAAAAKHRSTlMAIDBggJ+vz9//v5BwUO8QQH+gcO+PX49QsM9QwEAg4J/PsHCg4GDQCnJy3gAAAktJREFUeAHF14W6qzoUBOCBIJnQm7Bdm22V93/Ce3wdpQrM/wLLJnwtzlKUrqqb1nt+5X1ousV/JeZQuC5EDmhrV2JCydWR+/jGFZhCfxF4qDB6D+nC8zh1j/H0gSfwbqzh7e6KFqy8poXikueqC9X05gInuoochy9wgr7laK4djpVuaBRn6D1H1iTR+KYtcKii5YB5ongbSWUHF5xMm7BXqjmhoDq/udtX33NiV+L6vC5E9U2rqm8qWX07grT+8FtsOZse/3DD+YSB769yBSVnFQYCqFvBJWfW4DeOc7tOogOYK9EBTFAdwCQYT4V70SfIdJbASAmvSaCxEBRU6cULoJMmwFLoKPNg3wCRR3zWU8dbBEWu8VmkEIAnKtkFVOwNqNgb0IVwQSUPBCo9A1HcQEGpDj2lrrCg1BIdpTKC+DOgf4Uv4gwiijMI9YcYVHpVN3APgPIfhNoLaJ/hEp+9ad8A8E7xH9NOF8GML5w2gkBPlYyvknQBwncYMwBlCiv88EQFD5NU3wATRAk0C8EBMgCTougA5l10ANNLDyCIYQlIV1DBSFbQwUhW0OKfgiiAJkdRfVOp6ps3cX3kKKpvPlT1TcdJtRkwgre4Stgrvc32/R2QPacRHQ6Tvej8Jk9xhS7hcKnhyPwSx6lU4xsXOZp2iQGzRDFewQjOEKuEk+UVz/WacRbnR5he04KVV7XwvMR4liseZ10ljCu758Nnr5aYQnYPnvvE1SZhQqVbbQdrP3ebjDmUT4vu4Xm95lfr9fZhVW3K82p/Ah21nV4LnbW6AAAAAElFTkSuQmCC);
}

.plans-item--ult .plans-item__tag {
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIAAAAByCAMAAACsuinrAAAAqFBMVEVHcEwfFw8fFRUiFxUhFxMhGBMiFxQiFxQjGBQjGBUiGBQhFxMiGRQfFhMjGBUhGBQiFxIfDw8iGBQfFxMiGBQnFw8jFxQjFxUhGBUiGBIjGBQiGBUhFxUiFhQjFxMlGhUfFhYiFxQjGRMiFxUhGBUfFxcjFxQiGBUiGBQiGBQfHw8jFxUjFxUnFxckGRQjGBUjFxYjGBUiGBUkFhQjFxUiGBUhFxQiGBQKvso9AAAAOHRSTlMAIDBggJ+vz9//v5BwUO+fYBDfQH8goO+PX5+/j3BAMFCwUMCQIODfz7AQgJAgcJCg369w4LCg0F5lGZQAAAJgSURBVHgBxdYHmqM6EATgYuSxaOCJDBPx5Bwd73+yt7k3rxNy/RfoVOIDWwn2zGB/aMNQPgvDaBgn/+1hFwITR07+wqaZ1y5ys+9kmWKYBfChrCJZVdR7D3kVynrSss/hI9lAkfU1vN6d0IKWJ7VQN7KtNGBNrypsKHHSjyLYKPlWetNmWFd+IIpxhjKUng1z0vjKBlhVbWU5j1E8dCLMDirxxuZYKj8Sj45Z51cny+qH4tkpub60Aam+sqz6asCtr0dYUp/wFq3sTIc/OBBFWUElirKCkSjKCjSArBU0smND/CSTXWtz0gHUKekA6ph1AJVDhcJwRvoEqVgT6ISi4CRQaQhqYenIC5CMmgBNYSY05/oNILH4qBSeghRB1eIjJ0QALoSJdQHFegOK9wY0hIkwFUAkTJeAIzdQC1VMzqCcIhGqDldCdU1+BC34r/CGnEE4cgYhTLcgN5CyGzjjNsD/IUwB7jPs8NEd9w0A90Jj8MkVL4LX+MRwIwh0wnKNzx7IC6C9Q3cNgJnCR3xzQfwGEENgAHVMSqBKCAe4xg8eHOkA6p50ANVRD0CI4QigruARirKCJyjKCiz+6JgUQPXsSPXVgFVf3dHq6xFI9dULq756Fa/sj/UJb/Etx1IPd36/v8s9v4sfzgDMDvT8yz37uMJTjtU9jHt/fR3W88gaXxknvbEdlvMXRTeBIpzBPebY2HMj20qvsRXzzpm+hxa0PKuFyw796dbNwrSv4dWzuVx99scOPjyb2fJbuLnJ4dHINIu/1r6MTYBdGF0k8exyOpXPptPFbD4wo+1qfwC4lKkh3kCFfAAAAABJRU5ErkJggg==);
}

.plans-item__tag .num {
  font-size: calc(18 * 0.1rem);
  font-family: var(--font-en);
  font-weight: 500;
  padding-left: calc(2 * 0.1rem);
}

.plans {
  margin-top: calc(67 * 0.1rem);
  padding-top: calc(100 * 0.1rem);
  position: relative;
  z-index: 0;
}

.plans::before {
  content: "";
  width: 100%;
  aspect-ratio: 390/284;
  position: absolute;
  top: 0;
  left: 0;
  background: url(./images/bg_plans.png) center top/cover no-repeat;
  z-index: -1;
}

.plans__list {
  margin-top: calc(40 * 0.1rem);
  margin-right: var(--inner-padding);
  margin-left: var(--inner-padding);
}

.plans__item + .plans__item {
  margin-top: calc(32 * 0.1rem);
}

.plans__note-list {
  margin-top: calc(40 * 0.1rem);
  margin-right: var(--inner-padding);
  margin-left: var(--inner-padding);
  padding: calc(12 * 0.1rem);
  background: #f5f5f5;
  border-radius: 2px;
}

.plans__note-item {
  font-size: calc(12 * 0.1rem);
  letter-spacing: 0.08em;
}

.plans__note-item + .plans__note-item {
  margin-top: calc(4 * 0.1rem);
}

.point-item {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.point-item__icon {
  width: calc(20 * 0.1rem);
  height: calc(20 * 0.1rem);
}

.point-item__icon svg {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.point-item__title {
  margin-top: calc(4 * 0.1rem);
  font-size: calc(12 * 0.1rem);
  font-weight: bold;
  line-height: 1.4166666667;
  letter-spacing: 0.08em;
  min-height: calc(34 * 0.1rem);
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  color: var(--c-main);
}

.point-item__text {
  margin-top: calc(4 * 0.1rem);
  font-size: calc(12 * 0.1rem);
  letter-spacing: 0.08em;
  text-align: center;
}

.policy-item {
  display: grid;
  grid-template-columns: calc(40 * 0.1rem) 1fr;
  gap: calc(8 * 0.1rem);
  align-items: center;
}

.policy-item__icon {
  width: 100%;
  aspect-ratio: 1/1;
}

.policy-item__icon svg {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.policy-item__title {
  font-size: calc(13 * 0.1rem);
  letter-spacing: 0.08em;
  font-weight: bold;
  color: var(--c-main);
}

.policy-item__text {
  margin-top: calc(2 * 0.1rem);
  font-size: calc(13 * 0.1rem);
}

.policy {
  padding-top: calc(48 * 0.1rem);
  margin-right: var(--inner-padding);
  margin-left: var(--inner-padding);
}

.policy__list {
  margin-top: calc(24 * 0.1rem);
  background: #f5f5f5;
  padding: calc(12 * 0.1rem);
}

.policy__item:not(:last-child) {
  padding-bottom: calc(11 * 0.1rem);
  position: relative;
}

.policy__item:not(:last-child)::after {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-image: radial-gradient(circle, #231815 0.5px, transparent 0.5px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 7px 1px;
}

.policy__item + .policy__item {
  margin-top: calc(11 * 0.1rem);
}

.problems {
  padding-top: calc(64 * 0.1rem);
  padding-bottom: calc(64 * 0.1rem);
}

.problems__list {
  margin-top: calc(32 * 0.1rem);
  padding: 0 calc(8 * 0.1rem);
}

.problems__item {
  width: calc(210 * 0.1rem);
  aspect-ratio: 210/96;
  padding-bottom: calc(6 * 0.1rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-size: calc(13 * 0.1rem);
  position: relative;
  z-index: 0;
}

.problems__item::before {
  content: "";
  width: calc(230 * 0.1rem);
  aspect-ratio: 210/96;
  background: url(./images/bg_problems_item.png) center center/cover no-repeat;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  z-index: -1;
}

.problems__item .strong {
  font-size: calc(14 * 0.1rem);
  font-weight: bold;
}

.problems__item:nth-child(n+2) {
  margin-top: calc(-40 * 0.1rem);
}

.problems__item:nth-child(even) {
  margin-left: auto;
}

.problems__text01 {
  margin-top: calc(32 * 0.1rem);
  text-align: center;
  font-size: calc(14 * 0.1rem);
  line-height: 1.3;
  letter-spacing: 0.08em;
}

.problems__text01 .strong {
  font-size: calc(18 * 0.1rem);
  letter-spacing: 0.08em;
  font-weight: bold;
}

.problems__text02 {
  margin-top: calc(8 * 0.1rem);
  font-size: calc(14 * 0.1rem);
  text-align: center;
}

.problems__text02 .strong {
  font-weight: bold;
}

.problems__text03 {
  margin-top: calc(11 * 0.1rem);
  display: flex;
  flex-direction: column;
  gap: calc(11 * 0.1rem);
  align-items: center;
  font-size: calc(18 * 0.1rem);
  font-weight: bold;
  color: var(--c-main);
  text-align: center;
}

.problems__text03::before {
  content: "";
  content: "";
  width: calc(11 * 0.1rem);
  aspect-ratio: 11/11;
  display: block;
  background-image: url('data:image/svg+xml;utf8,<svg width="11" height="11" viewBox="0 0 11 11" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M10.165 0.616211L5.83301 10.2412H4.33203L0 0.616211L1.36914 0L5.08203 8.25293L8.7959 0L10.165 0.616211Z" fill="%23A65038"/></svg>');
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}

.qa {
  padding-top: calc(48 * 0.1rem);
  margin-right: var(--inner-padding);
  margin-left: var(--inner-padding);
}

.qa__list {
  margin-top: calc(24 * 0.1rem);
}

.qa__item + .qa__item {
  margin-top: calc(4 * 0.1rem);
}

.qa-item {
  border-radius: 2px;
  border: 1px solid #dbdbdb;
}

.qa-item__head {
  cursor: pointer;
}

.qa-item__title {
  display: grid;
  grid-template-columns: calc(13 * 0.1rem) 1fr;
  gap: calc(8 * 0.1rem);
  align-items: center;
  padding: calc(14 * 0.1rem) calc(30 * 0.1rem) calc(14 * 0.1rem) calc(18 * 0.1rem);
  position: relative;
}

.qa-item__title::after {
  content: "";
  width: calc(11 * 0.1rem);
  aspect-ratio: 11/11;
  display: block;
  background-image: url('data:image/svg+xml;utf8,<svg width="11" height="11" viewBox="0 0 11 11" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M10.165 0.616211L5.83301 10.2412H4.33203L0 0.616211L1.36914 0L5.08203 8.25293L8.7959 0L10.165 0.616211Z" fill="%23A65038"/></svg>');
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  right: calc(18 * 0.1rem);
  top: 50%;
  transform: translateY(-50%);
  transition: transform 0.3s;
}

.qa-item:not(.is-hidden) .qa-item__title::after {
  transform: translateY(-50%) rotate(180deg);
}

.qa-item__title-icon {
  width: 100%;
  aspect-ratio: 13/15;
}

.qa-item__title-icon svg {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.qa-item__title-text {
  font-size: calc(16 * 0.1rem);
  font-weight: bold;
}

.qa-item__body {
  display: grid;
  grid-template-rows: 1fr;
  background: #fff;
  transition-duration: 0.25s;
  transition-property: grid-template-rows;
}

.qa-item.is-hidden .qa-item__body {
  grid-template-rows: 0fr;
}

.qa-item__inner {
  overflow: hidden;
}

.qa-item__answer {
  display: block;
  margin-right: calc(18 * 0.1rem);
  margin-left: calc(18 * 0.1rem);
  padding-top: calc(14 * 0.1rem);
  padding-bottom: calc(20 * 0.1rem);
  position: relative;
  font-size: calc(13 * 0.1rem);
}

.qa-item__answer::before {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  top: 0;
  left: 0;
  background-image: radial-gradient(circle, #231815 0.5px, transparent 0.5px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 7px 1px;
}

.reasons {
  padding-top: calc(26 * 0.1rem);
  margin-right: var(--inner-padding);
  margin-left: var(--inner-padding);
}

.reasons__list {
  margin-top: calc(16 * 0.1rem);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(16 * 0.1rem) calc(23 * 0.1rem);
}

.reasons__icon {
  width: 64.375%;
  margin-right: auto;
  margin-left: auto;
}

.reasons__lead {
  margin-top: calc(12 * 0.1rem);
  font-size: calc(13 * 0.1rem);
  font-weight: bold;
  color: var(--c-main);
}

.reasons__title {
  margin-top: calc(2 * 0.1rem);
  font-size: calc(16 * 0.1rem);
  letter-spacing: 0.08em;
  font-weight: bold;
}

.reasons__text {
  margin-top: calc(8 * 0.1rem);
  font-size: calc(13 * 0.1rem);
  letter-spacing: 0.08em;
}

@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes infinity-scroll-right {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(0);
  }
}
@keyframes infinity-scroll-down {
  from {
    transform: translateY(-100%);
  }
  to {
    transform: translateY(0);
  }
}
@keyframes infinity-scroll-up {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-100%);
  }
}
.slider {
  display: flex;
}

.slider__list {
  display: flex;
  flex-shrink: 0;
  animation: infinity-scroll-right 35s infinite linear 0.5s both;
}

.slider--reverse .slider__list {
  animation: infinity-scroll-left 35s infinite linear 0.5s both;
}

.slider__item {
  width: calc(203 * 0.1rem);
  aspect-ratio: 408/272;
  flex-shrink: 0;
  margin-right: calc(30 * 0.1rem);
  box-shadow: calc(10 * 0.1rem) calc(10 * 0.1rem) calc(24 * 0.1rem) 0 rgba(0, 0, 0, 0.1);
  border-radius: 2px;
  overflow: hidden;
}

.slider__item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.slider--vertical {
  flex-direction: column;
  overflow: hidden;
}

.slider--vertical .slider__list {
  flex-direction: column;
  animation: infinity-scroll-down 25s infinite linear 0.5s both;
}

.slider--vertical .slider__item {
  margin-right: 0;
  margin-bottom: calc(2 * 0.1rem);
}

.slider--vertical-reverse .slider__list {
  animation: infinity-scroll-up 25s infinite linear 0.5s both;
}

.solution {
  padding: calc(76 * 0.1rem) 0;
  position: relative;
  background: url(./images/bg_solution.png) center center/auto 99% no-repeat;
}

.solution__coly {
  margin-top: calc(40 * 0.1rem);
  font-size: calc(32 * 0.1rem);
  line-height: 1;
  letter-spacing: 0.16em;
  text-align: center;
}

.solution__lead {
  margin-top: calc(16 * 0.1rem);
}

.solution__lead.c-sub-title {
  font-size: calc(16 * 0.1rem);
}

.solution__images {
  margin-top: calc(20 * 0.1rem);
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(4 * 0.1rem);
  position: relative;
  z-index: 0;
}

.solution__images::before,
.solution__images::after {
  content: "";
  width: 100%;
  height: calc(12 * 0.1rem);
  background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAwwAAAAYCAMAAABgDopZAAAAM1BMVEVHcEz////////////////////////////////////////////////////////////////P0YphAAAAEHRSTlMAECAwQFBgcICQoLDA0ODv2eilPQAAAXJJREFUeNrt2kmSwyAUA1DpL3qd+x9W6rKNm8o8p2Nbzz8Y2AYBqQp2ETHCLiIShoiEISJhiDiPP8ViFSI2y5YsExMWx1CwiIgtECTLko0RcaQKYyiSi1gfW7JlWThEXFLkUIXco2LBZHkq4QLiRmShpmJOjPh2tmVbY4vbEI8okjUWc2TEl7BtQfZQeADxtGKLBhKN+CxBPQJ4FvFaLRNTQnKfirfs/nZLAV6KeKOejenJuRH3Un9sCPsWFYZDhfoLSH6JxxHBtiG7ReDAmsJwJh3k2MnhsTHz0odwdePfQBiOkSRI1NxLQFZBsOcGmnr32GQYTiq0XLQuCrljfSl7KGGuNrEAi15R5FCoVm2Qk+QTbMyrXGPZEBay6tcYhgtqqJaQ/kEhWbmVANj7bwH2wpf89sJwRUtHj0hvWrvea5jd2rmr3vTOFq31G3+JHonqo/bq032mT3aFl7HPDXtXBzPqo9Vu6LECdUL+HhwR/+8XKUa0Ew4L0RYAAAAASUVORK5CYII=) center center/cover;
  position: absolute;
  left: 0;
  z-index: 1;
}

.solution__images::before {
  top: calc(-2 * 0.1rem);
}

.solution__images::after {
  bottom: calc(-2 * 0.1rem);
  rotate: 180deg;
}

.solution__image {
  width: 100%;
  aspect-ratio: 193/170;
  border-radius: 2px;
  overflow: hidden;
}

.solution__window {
  width: calc(60 * 0.1rem);
  aspect-ratio: 61/73;
  border: 2px solid #fff;
  background: #fff;
  position: absolute;
  border-radius: 2px;
  bottom: calc(-5 * 0.1rem);
  left: calc(17 * 0.1rem);
  z-index: 2;
}

.solution__image img,
.solution__window img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 2px;
}

.solution__contents {
  margin-top: calc(4 * 0.1rem);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(4 * 0.1rem);
  position: relative;
}

.solution__contents::before,
.solution__contents::after {
  content: "";
  width: calc(24 * 0.1rem);
  height: 1px;
  background: var(--c-black);
  position: absolute;
  top: calc(20 * 0.1rem);
  left: 50%;
  translate: -50% 0;
}

.solution__contents::before {
  rotate: 45deg;
}

.solution__contents::after {
  rotate: -45deg;
}

.solution__contents-text {
  font-size: calc(16 * 0.1rem);
  font-weight: bold;
  letter-spacing: 0.16em;
  text-align: center;
}

.solution__contents-sub {
  margin-top: calc(10 * 0.1rem);
  font-size: calc(12 * 0.1rem);
  text-align: center;
}

.solution__tags {
  margin-top: calc(24 * 0.1rem);
  margin-right: var(--inner-padding);
  margin-left: var(--inner-padding);
  padding-top: calc(16 * 0.1rem);
  position: relative;
}

.solution__tags::before {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  top: 0;
  left: 0;
  background-image: radial-gradient(circle, #231815 0.5px, transparent 0.5px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 7px 1px;
}

.tags {
  display: flex;
  justify-content: center;
  gap: calc(2 * 0.1rem);
}

.tags__item {
  display: inline-block;
  background: #ECECEC;
  padding: calc(6 * 0.1rem) calc(8 * 0.1rem);
  font-size: calc(12 * 0.1rem);
  font-weight: bold;
}

.thanks {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin-left: var(--inner-padding);
  margin-right: var(--inner-padding);
}

.thanks__text {
  margin-top: calc(32 * 0.1rem);
  font-size: calc(14 * 0.1rem);
  text-align: center;
  line-height: 2;
}

.thanks__button {
  margin-top: calc(40 * 0.1rem);
  margin-left: calc(16 * 0.1rem);
  margin-right: calc(16 * 0.1rem);
}

.u-sp-only {
  display: none;
}
.u-uppercase {
  text-transform: uppercase;
}

.u-sr-only {
  position: absolute;
  width: calc(1 * 0.1rem);
  height: calc(1 * 0.1rem);
  padding: 0;
  overflow: hidden;
  clip: rect(calc(1 * 0.1rem), calc(1 * 0.1rem), calc(1 * 0.1rem), calc(1 * 0.1rem));
  clip-path: inset(calc(0 * 0.1rem) calc(0 * 0.1rem) 99.9% 99.9%);
  border: 0;
}

@media screen and (min-width: 1240px) {
  .fixed-cta {
    display: none;
  }
  .pc {
    display: block;
  }
}

@media screen and (max-width: 480px) {
  html {
    font-size: 2.5641025641vw;
  }
  .u-pc-only {
    display: none;
  }
  .u-sp-only {
    display: block;
  }
}

@media (hover: hover) {
  a:hover {
    opacity: 0.7;
  }
}


.privacy-policy {
  margin-top: 20px;
  color: #555;
  font-size: 14px;
  border: 1px solid #ccc;
  border-radius: 4px;
  width: 100%;
  height: 200px;
  overflow-y: scroll;
  padding: 6px 12px;
}