@charset "UTF-8";@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@500&family=Zen+Kaku+Gothic+New:wght@400;500;700&display=swap");
/*
Typography
*/

/*
Reset
*/
*,
*::before,
*::after {
  box-sizing: border-box;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    -webkit-animation-delay: 0s !important;
            animation-delay: 0s !important;
    -webkit-animation-duration: 1ms !important;
            animation-duration: 1ms !important;
    -webkit-animation-iteration-count: 1 !important;
            animation-iteration-count: 1 !important;
    background-attachment: scroll !important;
    scroll-behavior: auto !important;
    transition-delay: 0s !important;
    transition-duration: 1ms !important;
  }
}
html {
  overflow-x: clip;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
   -ms-text-size-adjust: 100%;
       text-size-adjust: 100%;
}

a, abbr, acronym, address, applet, article, aside, audio, b, big, blockquote, body, canvas, caption, center, cite, code, dd, del, details, dfn, dialog, div, dl, dt, em, embed, fieldset, figcaption, figure, font, footer, form, header, hgroup, hr, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, meter, nav, object, ol, output, p, pre, progress, q, rp, rt, ruby, s, samp, section, small, span, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, tt, u, ul, var, video, xmp {
  border: 0;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

audio, embed, img, object {
  height: auto;
  max-width: 100%;
  vertical-align: middle;
  width: auto;
}

img, picture {
  display: block;
  max-width: 100%;
}

button {
  -webkit-appearance: none;
          appearance: none;
  background-color: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  text-transform: none;
}

button, input, select, textarea {
  -webkit-appearance: none;
          appearance: none;
  font-family: inherit;
  font-size: 100%;
  margin: 0;
}

button, [type=button], [type=reset], [type=submit], label[for], select,
summary, [role=tab], [role=button] {
  cursor: pointer;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
  margin: 0;
  padding: 0;
}

iframe {
  border: 0;
  display: block;
  height: auto;
  max-width: 100%;
}

ol, ul {
  list-style: none;
  list-style-type: "";
}

sub,
sup {
  font-size: 0.75em;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

summary {
  display: block;
}
summary::-webkit-details-marker {
  display: none;
}

svg {
  vertical-align: bottom;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

td, th {
  padding: 0;
  text-align: left;
}

textarea {
  field-sizing: content;
}

a, area, button, input, label, select, summary, textarea, [tabindex] {
  touch-action: manipulation;
}

a {
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

*:focus:not(:focus-visible),
*::before:focus:not(:focus-visible),
*::after:focus:not(:focus-visible) {
  outline: none;
}

button::-moz-focus-inner {
  border: 0;
}

* {
  -webkit-touch-callout: none;
}

input[type=text], select, textarea {
  font-size: 1rem;
}

input[type=text], input[type=tel], input[type=email], textarea {
  -webkit-appearance: none;
  -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
  appearance: none;
}

input[type=submit] {
  -webkit-appearance: none;
  appearance: none;
  border-radius: 0;
}

:where(button, [type=button], [type=reset], [type=submit]) {
  touch-action: manipulation;
}

.fb_iframe_widget > span {
  vertical-align: baseline !important;
}

#map-canvas img {
  max-width: none;
}

#map-canvas label {
  display: inline;
  width: auto;
}

/*
Basic style
*/
:root {
  --primary: #FFFB00;
  --secondary: #344FFF;
  --tertiary: #FE8F00;
  --black: #333;
  --white: #FFF;
  --white-rgb: 255,255,255;
  --gray: #EEE;
  --border: var(--primary);
  --leading-trim: calc((1em - 1lh) / 2);
  --leading-trim-en: calc((1cap - 1lh) / 2);
}

body {
  background-color: var(--white);
  color: var(--black);
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-break: strict;
  line-height: 1.5;
  overflow-x: clip;
  overscroll-behavior-y: none;
  text-autospace: normal;
  min-height: 100svh;
  text-align: left;
}

a {
  color: var(--primary);
  text-decoration: none;
}
a:focus-visible {
  text-decoration: none;
}
@media (any-hover: hover) {
  a:hover {
    text-decoration: none;
  }
}

b,
strong,
.-bold {
  font-weight: 500;
}

sup {
  display: inline-block;
  -webkit-transform: scale(0.8) translateX(-0.2em);
  margin-right: -0.2em;
          transform: scale(0.8) translateX(-0.2em);
}

.svg-spacer {
  fill: transparent;
}

@media (768px <= width) {
  .-sm {
    display: none !important;
  }
}

@media (1024px <= width) {
  .-smd {
    display: none !important;
  }
}

@media (width < 768px) {
  .-md {
    display: none !important;
  }
}

@media (width < 1024px) {
  .-lg {
    display: none !important;
  }
}

@media (width < 1440px) {
  .-xl {
    display: none !important;
  }
}

@media (1024px <= width) {
  .spOnly {
    display: none !important;
  }
}

.pcOnly {
  display: none !important;
}
@media (1024px <= width) {
  .pcOnly {
    display: block !important;
  }
}

/*
loader
*/
@media (scripting: none) {
  .loader {
    display: none;
  }
}
.loader {
  background-color: var(--primary);
  height: 100vh;
  left: 0;
  position: fixed;
  top: 0;
  transition: height 0.3s ease-in-out 0.1s;
  width: 100vw;
  z-index: calc(infinity);
}
.loader.is-loaded {
  height: 0;
}

.loader::after {
  background-color: var(--primary);
  bottom: 0;
  content: "";
  display: block;
  height: 0;
  left: 0;
  position: absolute;
  transition: height 0.3s ease-in-out;
  width: 100vw;
}
.loader.is-active {
  background-color: transparent;
  bottom: 0;
  height: 100vh;
  top: auto;
}
.loader.is-active::after {
  height: 100vh;
}

/*
header
*/
.is-fixed {
  position: fixed;
  width: 100%;
}

.header {
  background-color: var(--primary);
  left: 0;
  padding: 2.6666666667vw;
  position: fixed;
  top: 0;
  transition: top 0.6s;
  width: 100%;
  z-index: 5;
}
@media (1024px <= width) {
  .header {
    padding: 15px 36px;
  }
}
.header__inner {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-inline: auto;
  max-width: 1440px;
}
.header__logo {
  width: 13.3333333333vw;
}
@media (1024px <= width) {
  .header__logo {
    width: 80px;
  }
}

.headerNav {
  display: none;
}
@media (1024px <= width) {
  .headerNav {
    display: block;
  }
}
.headerNav__list {
  display: flex;
  gap: 8px;
}
@media (1024px <= width) {
  .headerNav__list {
    gap: 32px;
  }
}
.headerNav__list a {
  -webkit-font-feature-settings: "palt";
  color: var(--secondary);
          font-feature-settings: "palt";
  font-size: 18px;
  font-weight: 700;
  line-height: 1.25;
}
.headerNav__list a:focus-visible {
  -webkit-text-decoration: underline var(--white) 4px;
          text-decoration: underline var(--white) 4px;
  text-underline-offset: 5px;
}
@media (any-hover: hover) {
  .headerNav__list a:hover {
    -webkit-text-decoration: underline var(--white) 4px;
            text-decoration: underline var(--white) 4px;
    text-underline-offset: 5px;
  }
}

.navTrigger {
  align-items: center;
  cursor: pointer;
  display: flex;
  height: 4.5333333333vw;
  width: 6.4vw;
}
@media (1024px <= width) {
  .navTrigger {
    display: none;
  }
}
.navTrigger span {
  background-color: var(--secondary);
  display: block;
  height: 0.8vw;
  position: relative;
  transition: background-color 0.5s, width 0.5s;
  width: 100%;
}
.navTrigger span::before, .navTrigger span::after {
  background-color: var(--secondary);
  content: "";
  display: block;
  height: 0.8vw;
  position: absolute;
  transition: translate 0.5s, rotate 0;
  width: 6.4vw;
}
.navTrigger span::before {
  -webkit-transform: translateY(-2.1333333333vw);
          transform: translateY(-2.1333333333vw);
}
.navTrigger span::after {
  -webkit-transform: translateY(2.1333333333vw);
          transform: translateY(2.1333333333vw);
}
.navTrigger:focus-visible span {
  width: 3.2vw;
}
.navTrigger:focus-visible span::before,
.navTrigger:focus-visible span::after {
  translate: 0;
  width: 6.4vw;
}
@media (any-hover: hover) {
  .navTrigger:hover span {
    width: 3.2vw;
  }
  .navTrigger:hover span::before,
  .navTrigger:hover span::after {
    translate: 0;
    width: 6.4vw;
  }
}
.navTrigger.is-open span {
  background-color: transparent;
}
.navTrigger.is-open span::before {
  rotate: 30deg;
  transition: rotate 0.5s;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.navTrigger.is-open span::after {
  rotate: -30deg;
  transition: rotate 0.5s;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

/*
nav
*/
.nav {
  position: fixed;
  right: 0;
  top: 0;
  transition: visibility 0s 1.2s;
  visibility: hidden;
  z-index: 4;
}
@media (1024px <= width) {
  .nav {
    display: none;
  }
}
.nav.is-open {
  transition: visibility 0s;
  visibility: visible;
}
.nav::before {
  background-color: rgba(var(--white-rgb), 0.5);
  content: "";
  height: 100vh;
  opacity: 0;
  position: absolute;
  right: 0;
  top: 0;
  transition: opacity 0.4s 0.8s;
  width: 100vw;
  z-index: 3;
}
.nav.is-open::before {
  opacity: 1;
  transition: opacity 0.4s;
}
.nav__inner {
  background-color: var(--primary);
  display: grid;
  height: 100vh;
  padding-block: 40.5333333333vw 12.8vw;
  place-content: space-between center;
  position: relative;
  transition: translate 0.8s cubic-bezier(0.77, 0, 0.175, 1);
  translate: 100%;
  width: 82.4vw;
  z-index: 4;
}
.nav.is-open .nav__inner {
  transition: translate 0.8s 0.4s cubic-bezier(0.77, 0, 0.175, 1);
  translate: 0;
}
.nav__list {
  display: grid;
  gap: 9.6vw;
}
.nav__list a {
  -webkit-font-feature-settings: "palt";
  color: var(--secondary);
  display: block;
          font-feature-settings: "palt";
  font-size: 5.3333333333vw;
  font-weight: 700;
  line-height: 1.2;
  -webkit-text-decoration: underline var(--white) 1.0666666667vw;
          text-decoration: underline var(--white) 1.0666666667vw;
  text-underline-offset: 1.3333333333vw;
}
.nav__btns {
  display: flex;
  flex-direction: column;
  gap: 3.2vw;
  width: 100%;
}
@media (1024px <= width) {
  .nav__btns {
    gap: 16px;
  }
}
.nav__btns {
  align-items: center;
}
.nav__btn {
  align-items: center;
  border-radius: 100vmax;
  display: flex;
  font-size: 3.4666666667vw;
  font-weight: 700;
  gap: 3.4666666667vw;
  height: 10.6666666667vw;
  justify-content: center;
  transition: background-color 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  width: 42.6666666667vw;
}
@media (1024px <= width) {
  .nav__btn {
    font-size: 24px;
    gap: 30px;
    height: 64px;
    width: 300px;
  }
}
.nav__btn span::after {
  border-right: 0.5333333333vw solid;
  border-top: 0.5333333333vw solid;
  content: "";
  display: block;
  -webkit-transform: rotate(45deg);
  height: 0.5em;
          transform: rotate(45deg);
  width: 0.5em;
}
@media (1024px <= width) {
  .nav__btn span::after {
    border-width: 4px;
    height: 0.6em;
    width: 0.6em;
  }
}
.nav__btn.-contact {
  background-color: var(--tertiary);
  border: 0.5333333333vw solid var(--black);
}
@media (1024px <= width) {
  .nav__btn.-contact {
    border-width: 2px;
  }
}
.nav__btn.-contact span {
  background: url(../img/icon_mail.svg) center no-repeat;
  background-size: contain;
  height: 3.7333333333vw;
  width: 4.6666666667vw;
}
@media (1024px <= width) {
  .nav__btn.-contact span {
    height: 24px;
    width: 30px;
  }
}
.nav__btn.-contact span::after {
  border-color: var(--white);
  translate: 5.2vw 1.0666666667vw;
}
@media (1024px <= width) {
  .nav__btn.-contact span::after {
    translate: 36px 5px;
  }
}
.nav__btn.-contact:focus-visible {
  background-color: #FED400;
}
@media (any-hover: hover) {
  .nav__btn.-contact:hover {
    background-color: #FED400;
  }
}
.nav__btn.-guide {
  background-color: var(--white);
  border: 0.5333333333vw solid var(--tertiary);
}
@media (1024px <= width) {
  .nav__btn.-guide {
    border-width: 2px;
  }
}
.nav__btn.-guide span {
  background: url(../img/icon_pdf.svg) center no-repeat;
  background-size: contain;
  height: 4.2666666667vw;
  width: 4.2666666667vw;
}
@media (1024px <= width) {
  .nav__btn.-guide span {
    height: 30px;
    width: 30px;
  }
}
.nav__btn.-guide span::after {
  border-color: var(--tertiary);
  translate: 4.8vw 1.0666666667vw;
}
@media (1024px <= width) {
  .nav__btn.-guide span::after {
    translate: 36px 8px;
  }
}
.nav__btn.-guide:focus-visible {
  background-color: #FED400;
}
@media (any-hover: hover) {
  .nav__btn.-guide:hover {
    background-color: #FED400;
  }
}

/*
cta
*/
.cta {
  background-color: var(--white);
  padding-block: 8.5333333333vw 16vw;
}
@media (1024px <= width) {
  .cta {
    padding-block: 64px 96px;
  }
}
.cta.-y {
  background-color: var(--primary);
  padding-block: 8.5333333333vw;
}
@media (1024px <= width) {
  .cta.-y {
    padding-block: 64px;
  }
}
.cta__btns {
  align-items: center;
  display: flex;
  gap: 3.2vw;
  justify-content: center;
}
@media (1024px <= width) {
  .cta__btns {
    gap: 16px;
  }
}
.cta__btns {
  align-items: center;
}
.cta__btn {
  align-items: center;
  border-radius: 100vmax;
  display: flex;
  font-size: 3.4666666667vw;
  font-weight: 700;
  gap: 3.4666666667vw;
  height: 10.6666666667vw;
  justify-content: center;
  transition: background-color 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  width: 42.6666666667vw;
}
@media (1024px <= width) {
  .cta__btn {
    font-size: 24px;
    gap: 30px;
    height: 64px;
    width: 300px;
  }
}
.cta__btn span::after {
  border-right: 0.5333333333vw solid;
  border-top: 0.5333333333vw solid;
  content: "";
  display: block;
  -webkit-transform: rotate(45deg);
  height: 0.5em;
          transform: rotate(45deg);
  width: 0.5em;
}
@media (1024px <= width) {
  .cta__btn span::after {
    border-width: 4px;
    height: 0.6em;
    width: 0.6em;
  }
}
.cta__btn.-contact {
  background-color: var(--tertiary);
  border: 0.5333333333vw solid var(--black);
}
@media (1024px <= width) {
  .cta__btn.-contact {
    border-width: 2px;
  }
}
.cta__btn.-contact span {
  background: url(../img/icon_mail.svg) center no-repeat;
  background-size: contain;
  height: 3.7333333333vw;
  width: 4.6666666667vw;
}
@media (1024px <= width) {
  .cta__btn.-contact span {
    height: 24px;
    width: 30px;
  }
}
.cta__btn.-contact span::after {
  border-color: var(--white);
  translate: 5.2vw 1.0666666667vw;
}
@media (1024px <= width) {
  .cta__btn.-contact span::after {
    translate: 36px 5px;
  }
}
.cta__btn.-contact:focus-visible {
  background-color: #FED400;
}
@media (any-hover: hover) {
  .cta__btn.-contact:hover {
    background-color: #FED400;
  }
}
.cta__btn.-guide {
  background-color: var(--white);
  border: 0.5333333333vw solid var(--tertiary);
}
@media (1024px <= width) {
  .cta__btn.-guide {
    border-width: 2px;
  }
}
.cta__btn.-guide span {
  background: url(../img/icon_pdf.svg) center no-repeat;
  background-size: contain;
  height: 4.2666666667vw;
  width: 4.2666666667vw;
}
@media (1024px <= width) {
  .cta__btn.-guide span {
    height: 30px;
    width: 30px;
  }
}
.cta__btn.-guide span::after {
  border-color: var(--tertiary);
  translate: 4.8vw 1.0666666667vw;
}
@media (1024px <= width) {
  .cta__btn.-guide span::after {
    translate: 36px 8px;
  }
}
.cta__btn.-guide:focus-visible {
  background-color: #FED400;
}
@media (any-hover: hover) {
  .cta__btn.-guide:hover {
    background-color: #FED400;
  }
}

/*
breadcrumb
*/
.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  margin-inline: auto;
  max-width: 1080px;
  padding-block: 12.8vw 4.2666666667vw;
  width: calc(100% - 10.6666666667vw);
}
@media (1024px <= width) {
  .breadcrumb {
    padding-block: 64px 24px;
  }
}
.breadcrumb li {
  font-size: 3.2vw;
  font-weight: 700;
}
@media (1024px <= width) {
  .breadcrumb li {
    font-size: 14px;
  }
}
.breadcrumb li:last-child::after {
  content: "";
}
.breadcrumb li::after {
  content: "＞";
  margin-inline: 0.5em;
}
.breadcrumb a {
  color: var(--secondary);
  text-decoration: underline;
}
.breadcrumb a:focus-visible {
  color: var(--tertiary);
}
@media (any-hover: hover) {
  .breadcrumb a:hover {
    color: var(--tertiary);
  }
}

.fix__btns {
  align-items: center;
  display: flex;
  gap: 3.2vw;
  justify-content: center;
}
@media (1024px <= width) {
  .fix__btns {
    gap: 16px;
  }
}
.fix__btns {
  bottom: -5.3333333333vw;
  opacity: 0;
  position: fixed;
  transition: opacity 0.6s cubic-bezier(0.19, 1, 0.22, 1), bottom 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  width: 100%;
  z-index: 2;
}
@media (1024px <= width) {
  .fix__btns {
    bottom: -20px;
    display: flex;
    flex-direction: column;
    gap: 3.2vw;
    right: 20px;
    width: 100%;
    width: auto;
  }
}
@media (1024px <= width) and (1024px <= width) {
  .fix__btns {
    gap: 16px;
  }
}
.fix__btns.is-show {
  bottom: 5.3333333333vw;
  opacity: 1;
}
@media (1024px <= width) {
  .fix__btns.is-show {
    bottom: 20px;
  }
}

.fix__btn {
  align-items: center;
  border-radius: 100vmax;
  display: flex;
  font-size: 3.4666666667vw;
  font-weight: 700;
  gap: 3.4666666667vw;
  height: 10.6666666667vw;
  justify-content: center;
  transition: background-color 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  width: 42.6666666667vw;
}
@media (1024px <= width) {
  .fix__btn {
    font-size: 24px;
    gap: 30px;
    height: 64px;
    width: 300px;
  }
}
.fix__btn span::after {
  border-right: 0.5333333333vw solid;
  border-top: 0.5333333333vw solid;
  content: "";
  display: block;
  -webkit-transform: rotate(45deg);
  height: 0.5em;
          transform: rotate(45deg);
  width: 0.5em;
}
@media (1024px <= width) {
  .fix__btn span::after {
    border-width: 4px;
    height: 0.6em;
    width: 0.6em;
  }
}
.fix__btn.-contact {
  background-color: var(--tertiary);
  border: 0.5333333333vw solid var(--black);
}
@media (1024px <= width) {
  .fix__btn.-contact {
    border-width: 2px;
  }
}
.fix__btn.-contact span {
  background: url(../img/icon_mail.svg) center no-repeat;
  background-size: contain;
  height: 3.7333333333vw;
  width: 4.6666666667vw;
}
@media (1024px <= width) {
  .fix__btn.-contact span {
    height: 24px;
    width: 30px;
  }
}
.fix__btn.-contact span::after {
  border-color: var(--white);
  translate: 5.2vw 1.0666666667vw;
}
@media (1024px <= width) {
  .fix__btn.-contact span::after {
    translate: 36px 5px;
  }
}
.fix__btn.-contact:focus-visible {
  background-color: #FED400;
}
@media (any-hover: hover) {
  .fix__btn.-contact:hover {
    background-color: #FED400;
  }
}
.fix__btn.-guide {
  background-color: var(--white);
  border: 0.5333333333vw solid var(--tertiary);
}
@media (1024px <= width) {
  .fix__btn.-guide {
    border-width: 2px;
  }
}
.fix__btn.-guide span {
  background: url(../img/icon_pdf.svg) center no-repeat;
  background-size: contain;
  height: 4.2666666667vw;
  width: 4.2666666667vw;
}
@media (1024px <= width) {
  .fix__btn.-guide span {
    height: 30px;
    width: 30px;
  }
}
.fix__btn.-guide span::after {
  border-color: var(--tertiary);
  translate: 4.8vw 1.0666666667vw;
}
@media (1024px <= width) {
  .fix__btn.-guide span::after {
    translate: 36px 8px;
  }
}
.fix__btn.-guide:focus-visible {
  background-color: #FED400;
}
@media (any-hover: hover) {
  .fix__btn.-guide:hover {
    background-color: #FED400;
  }
}

.video {
  height: 80svh;
  margin-inline: auto;
  padding-top: 45%;
  position: relative;
  width: 45svh;
}
.video iframe {
  height: 100% !important;
  position: absolute;
  right: 0;
  top: 0;
  width: 100% !important;
}
.video {
  border-radius: 2.6666666667vw;
  overflow: hidden;
}
@media (1024px <= width) {
  .video {
    border-radius: 20px;
  }
}

body.no-scroll {
  overflow: hidden;
  position: fixed;
  width: 100%;
}
body.no-scroll main {
  overflow: auto;
  scrollbar-gutter: stable;
}

.modal__bg, .modal__container {
  height: 100vh;
  left: 0;
  opacity: 0;
  position: fixed;
  top: 0;
  transition: opacity 0.6s ease, visibility 0.6s ease;
  visibility: hidden;
  width: 100vw;
  z-index: 6;
}
.modal__bg.is-active, .modal__container.is-active {
  opacity: 1;
  visibility: visible;
}
.modal__bg {
  background-color: var(--white);
}
.modal__container {
  overflow-y: auto;
}
.modal__content {
  display: none;
  min-height: 100dvh;
  opacity: 0;
  padding-block: 80px;
  transition: opacity 0.6s ease, visibility 0.6s ease;
  visibility: hidden;
}
.modal__content.is-active {
  align-items: center;
  display: flex;
  justify-content: center;
  opacity: 1;
  visibility: visible;
}
.modal__close {
  align-items: center;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  display: flex;
  height: 4.5333333333vw;
  justify-content: center;
  position: fixed;
  right: 2.6666666667vw;
  top: 2.6666666667vw;
  width: 6.4vw;
}
@media (1024px <= width) {
  .modal__close {
    height: 34px;
    right: 24px;
    top: 24px;
    width: 48px;
  }
}
.modal__close::before, .modal__close::after {
  background-color: var(--secondary);
  content: "";
  display: block;
  height: 0.8vw;
  position: absolute;
  width: 100%;
}
@media (1024px <= width) {
  .modal__close::before, .modal__close::after {
    height: 6px;
  }
}
.modal__close::before {
  rotate: 30deg;
}
.modal__close::after {
  rotate: -30deg;
}
/*
fv
*/
.fv {
  background-color: var(--primary);
  background-image: url("../img/y_w.png");
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: 100%;
  overflow-x: clip;
  padding-bottom: 80vw;
  padding-top: 18.6666666667vw;
}
@media (1024px <= width) {
  .fv {
    padding-bottom: 444px;
    padding-top: 125px;
  }
}
.fv__inner {
  position: relative;
}
@media (1024px <= width) {
  .fv__inner {
    margin-inline: auto;
    max-width: 1392px;
    width: 100%;
  }
}
.fv__title {
  margin-inline: auto;
  width: 76.5333333333vw;
}
@media (1024px <= width) {
  .fv__title {
    -webkit-transform: translateX(-124px);
            transform: translateX(-124px);
    width: 687px;
  }
}
.fv__text {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.5;
  padding: 4.2666666667vw 2.6666666667vw;
  padding-left: calc(2.6666666667vw + 0.5em);
  text-indent: -0.5em;
}
@media (1024px <= width) {
  .fv__text {
    padding-left: 0;
    text-indent: 0;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 32px;
    font-weight: 700;
    letter-spacing: 0.025em;
    line-height: 1.312;
    margin-right: calc((100% - 600px) / 2);
    padding: 16px 0;
    text-align: center;
  }
}
.fv__i {
  position: absolute;
  right: 0;
  top: 48.2666666667vw;
  width: 47.4666666667vw;
}
@media (1024px <= width) {
  .fv__i {
    right: calc((100% - 950px) / 2);
    top: 245px;
    width: 395px;
  }
}
.fv__mark {
  align-items: center;
  background-color: var(--white);
  border-radius: 2.1333333333vw;
  display: flex;
  gap: 0vw;
  margin-inline: auto;
  margin-top: 7.4666666667vw;
  padding-block: 0 8.5333333333vw;
  padding-inline: 2.6666666667vw;
  width: 88.5333333333vw;
}
@media (1024px <= width) {
  .fv__mark {
    border-radius: 10px;
    gap: 4px;
    margin-top: 16px;
    padding-block: 16px;
    padding-inline: 16px;
    width: 480px;
  }
}
@media (1440px <= width) {
  .fv__mark {
    flex-direction: column;
    margin-top: 0;
    position: absolute;
    right: calc((100% - 1390px) / 2);
    top: 375px;
    width: 186px;
  }
}
.fv__mark img {
  width: 20.8vw;
}
@media (1024px <= width) {
  .fv__mark img {
    width: 120px;
  }
}
.fv__mark dt {
  color: var(--secondary);
  font-size: 4.2666666667vw;
  font-weight: 700;
  text-align: center;
  -webkit-text-decoration: underline var(--tertiary) 1.0666666667vw;
          text-decoration: underline var(--tertiary) 1.0666666667vw;
}
@media (1024px <= width) {
  .fv__mark dt {
    font-size: 18px;
    text-decoration-thickness: 4px;
    white-space: nowrap;
  }
}
.fv__mark dt span {
  font-size: 6.9333333333vw;
}
@media (1024px <= width) {
  .fv__mark dt span {
    font-size: 27px;
  }
}
.fv__mark dd {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 3.7333333333vw;
  font-weight: 700;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.357;
  margin-top: 0.2666666667vw;
  text-align: center;
}
@media (1024px <= width) {
  .fv__mark dd {
    font-size: 14px;
    letter-spacing: 0;
    line-height: 1.286;
  }
}
@media (1440px <= width) {
  .fv__mark dd {
    text-align: left;
  }
}
.fv__voice {
  align-items: top;
  background-color: var(--white);
  border: 0.5333333333vw solid var(--secondary);
  border-radius: 1.3333333333vw;
  display: flex;
  gap: 2.6666666667vw;
  margin-inline: auto;
  margin-top: -6.4vw;
  padding-block: 2.6666666667vw 2.1333333333vw;
  padding-inline: 2.6666666667vw;
  width: 79.4666666667vw;
}
@media (1024px <= width) {
  .fv__voice {
    align-items: center;
    border-radius: 10px;
    border-width: 2px;
    gap: 12px;
    margin-top: 16px;
    padding-block: 10px 8px;
    padding-inline: 16px;
    width: 592px;
  }
}
@media (1440px <= width) {
  .fv__voice {
    margin-top: 0;
    position: absolute;
    right: calc((100% - 1390px) / 2);
    top: 662px;
  }
}
.fv__voice dt {
  width: 15.4666666667vw;
}
@media (1024px <= width) {
  .fv__voice dt {
    width: 52px;
  }
}
.fv__voice dt img {
  margin-inline: auto;
  width: 9.6vw;
}
@media (1024px <= width) {
  .fv__voice dt img {
    width: 52px;
  }
}
.fv__voice dt span {
  display: block;
  font-size: 2.6666666667vw;
  line-height: 1.1;
  margin-top: 2.1333333333vw;
  text-align: center;
  white-space: nowrap;
}
@media (1024px <= width) {
  .fv__voice dt span {
    display: none;
  }
}
.fv__voice dd {
  flex: 1;
  font-size: 3.2vw;
  font-weight: 500;
  line-height: 1.167;
  text-align: justify;
}
@media (1024px <= width) {
  .fv__voice dd {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 16px;
    font-weight: 500;
    line-height: 1.333;
  }
}

/*
about
*/
.about {
  padding-bottom: 13.3333333333vw;
}
@media (1024px <= width) {
  .about {
    padding-bottom: 28px;
  }
}
.about {
  position: relative;
  z-index: 1;
}
.about__inner {
  margin-top: -64vw;
}
@media (1024px <= width) {
  .about__inner {
    margin-top: -360px;
  }
}
.about__title {
  -webkit-font-feature-settings: "palt";
  background-color: var(--white);
  border-radius: 1.3333333333vw;
  color: var(--secondary);
          font-feature-settings: "palt";
  font-size: 5.3333333333vw;
  font-weight: 700;
  line-height: 1.2;
  margin-block: var(--leading-trim);
  margin-inline: auto;
  padding-block: 1.6vw;
  position: relative;
  text-align: center;
  width: 72vw;
}
@media (1024px <= width) {
  .about__title {
    -webkit-font-feature-settings: "palt";
    border-radius: 6px;
            font-feature-settings: "palt";
    font-size: 32px;
    font-weight: 700;
    letter-spacing: 0.025em;
    line-height: 1.312;
    padding-block: 6px;
    width: 430px;
  }
}
.about__title::before {
  border-bottom: 3.7333333333vw solid var(--white);
  border-left: 2.4vw solid transparent;
  border-right: 2.4vw solid transparent;
  bottom: -2.6666666667vw;
  content: "";
  left: calc((100% - 3.7333333333vw) / 2);
  position: absolute;
  rotate: 180deg;
}
@media (1024px <= width) {
  .about__title::before {
    border-bottom-width: 14px;
    border-left-width: 9px;
    border-right-width: 9px;
    bottom: -10px;
    left: calc((100% - 14px) / 2);
  }
}
.about__modal {
  display: block;
  margin-inline: auto;
  margin-top: 10.6666666667vw;
  position: relative;
  -webkit-transform: translateX(6.4vw);
          transform: translateX(6.4vw);
  transition: scale 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  width: 61.3333333333vw;
}
@media (1024px <= width) {
  .about__modal {
    margin-top: 40px;
    -webkit-transform: translateX(24px);
            transform: translateX(24px);
    width: 222px;
  }
}
.about__modal::after {
  -webkit-animation: rotateCCW 8s linear infinite;
          animation: rotateCCW 8s linear infinite;
  background: url(../img/m_00_text.png) center no-repeat;
  background-size: contain;
  content: "";
  height: 16.5333333333vw;
  left: -5.3333333333vw;
  position: absolute;
  top: -5.3333333333vw;
  width: 16.5333333333vw;
}
@media (1024px <= width) {
  .about__modal::after {
    height: 73px;
    left: -30px;
    top: -30px;
    width: 73px;
  }
}
.about__modal:focus-visible {
  scale: 1.02;
}
@media (any-hover: hover) {
  .about__modal:hover {
    scale: 1.02;
  }
}
.about__point {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-inline: auto;
  margin-top: 9.0666666667vw;
  row-gap: 4.2666666667vw;
  width: 85.3333333333vw;
}
@media (1024px <= width) {
  .about__point {
    margin-top: 58px;
    row-gap: 26px;
    width: 700px;
  }
}
.about__point li {
  width: 24.8vw;
}
@media (1024px <= width) {
  .about__point li {
    width: 203px;
  }
}
.about__text {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 1.6vw;
  text-align: center;
  -webkit-text-decoration: dashed underline var(--secondary);
          text-decoration: dashed underline var(--secondary);
  text-underline-offset: 1.3333333333vw;
}
@media (1024px <= width) {
  .about__text {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 24px;
    font-weight: 700;
    line-height: 1.333;
    margin-top: 16px;
    text-underline-offset: 5px;
  }
}
.about__links {
  margin-top: 4.2666666667vw;
  text-align: center;
}
@media (1024px <= width) {
  .about__links {
    margin-top: 16px;
  }
}
.about__link {
  -webkit-font-feature-settings: "palt";
  color: var(--secondary) !important;
          font-feature-settings: "palt";
  font-size: 3.7333333333vw;
  font-weight: 700;
  line-height: 1.357;
  text-decoration: underline !important;
}
.about__link::after {
  background: url(../img/icon_blank.svg) center no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  height: 3.2vw;
  margin-inline: 0.25em;
  width: 3.2vw;
}
@media (768px <= width) {
  .about__link::after {
    -webkit-transform: translateY(0.1lh);
    height: 16px;
            transform: translateY(0.1lh);
    width: 16px;
  }
}
.about__link:focus-visible {
  color: var(--tertiary) !important;
}
.about__link:focus-visible::after {
  background: url(../img/icon_blank_o.svg) center no-repeat;
  background-size: contain;
}
@media (any-hover: hover) {
  .about__link:hover {
    color: var(--tertiary) !important;
  }
  .about__link:hover::after {
    background: url(../img/icon_blank_o.svg) center no-repeat;
    background-size: contain;
  }
}
@media (1024px <= width) {
  .about__link {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 16px;
    font-weight: 700;
    line-height: 1.333;
  }
}
.about__wrap {
  margin-inline: auto;
  margin-top: 22.4vw;
  position: relative;
  width: 85.3333333333vw;
}
@media (1024px <= width) {
  .about__wrap {
    margin-top: 120px;
    max-width: 960px;
  }
}
.about__catch {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 6.4vw;
  font-weight: 700;
  line-height: 1.667;
  line-height: 1.8;
  -webkit-text-decoration: underline var(--primary) 1.6vw;
          text-decoration: underline var(--primary) 1.6vw;
  text-underline-offset: 0.5333333333vw;
}
@media (1024px <= width) {
  .about__catch {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 32px;
    font-weight: 700;
    letter-spacing: 0.025em;
    line-height: 1.312;
    line-height: 1.9;
    text-decoration-thickness: 6px;
    text-underline-offset: 2px;
  }
}
.about__i {
  left: 56vw;
  position: absolute;
  top: -4.2666666667vw;
  width: 30.4vw;
}
@media (1024px <= width) {
  .about__i {
    left: 420px;
    top: -42px;
    width: 243px;
  }
}
@media (1024px <= width) {
  .about__i {
    left: 688px;
  }
}
.about__i .-star1 {
  left: 0vw;
  position: absolute;
  top: -2.1333333333vw;
  -webkit-animation: starScale 0.8s ease-in-out infinite alternate;
          animation: starScale 0.8s ease-in-out infinite alternate;
}
@media (1024px <= width) {
  .about__i .-star1 {
    left: 16px;
    top: -16px;
  }
}
.about__i .-star2 {
  left: -3.2vw;
  position: absolute;
  top: 2.6666666667vw;
  -webkit-animation: starScale 0.8s ease-in-out infinite alternate;
          animation: starScale 0.8s ease-in-out infinite alternate;
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}
@media (1024px <= width) {
  .about__i .-star2 {
    left: 0;
    top: 20px;
  }
}
.about__i .-star3 {
  bottom: -5.3333333333vw;
  position: absolute;
  right: -2.1333333333vw;
  -webkit-animation: starScale 0.8s ease-in-out 0.6s infinite alternate;
          animation: starScale 0.8s ease-in-out 0.6s infinite alternate;
}
@media (1024px <= width) {
  .about__i .-star3 {
    bottom: -16px;
    right: -16px;
  }
}

@-webkit-keyframes starScale {
  from {
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
  }
  to {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes starScale {
  from {
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
  }
  to {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@-webkit-keyframes rotateCCW {
  from {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(-360deg);
            transform: rotate(-360deg);
  }
}
@keyframes rotateCCW {
  from {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(-360deg);
            transform: rotate(-360deg);
  }
}
/*
merit
*/
.merit {
  margin-left: 8vw;
  margin-top: 9.0666666667vw;
}
@media (1024px <= width) {
  .merit {
    margin-inline: auto;
    margin-top: 82px;
    max-width: 960px;
    width: 85.3333333333vw;
  }
}
.merit__en img {
  width: 18.4vw;
}
@media (1024px <= width) {
  .merit__en img {
    width: 107px;
  }
}
.merit__list {
  margin-top: 5.8666666667vw;
}
@media (1024px <= width) {
  .merit__list {
    margin-top: 26px;
  }
}
@media (1024px <= width) {
  .merit__list {
    align-items: center;
    display: flex;
    gap: 48px;
  }
}
.merit__list dt {
  align-items: center;
  display: flex;
  gap: 2.6666666667vw;
}
@media (1024px <= width) {
  .merit__list dt {
    gap: 16px;
  }
}
@media (1024px <= width) {
  .merit__list dt {
    width: 377px;
  }
}
.merit__list dt img {
  width: 5.3333333333vw;
}
@media (1024px <= width) {
  .merit__list dt img {
    width: 40px;
  }
}
.merit__list dt span {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 5.3333333333vw;
  font-weight: 700;
  line-height: 1.2;
  line-height: 1.8;
  -webkit-text-decoration: underline var(--primary) 1.6vw;
          text-decoration: underline var(--primary) 1.6vw;
  text-underline-offset: 0.5333333333vw;
}
@media (1024px <= width) {
  .merit__list dt span {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 24px;
    font-weight: 700;
    line-height: 1.333;
    line-height: 1.9;
    text-decoration-thickness: 6px;
    text-underline-offset: 2px;
  }
}
.merit__list dd {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.5;
  line-height: 1.375;
  padding-left: 8vw;
}
@media (1024px <= width) {
  .merit__list dd {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 20px;
    font-weight: 700;
    line-height: 1.4;
    padding-left: 56px;
  }
}
@media (1024px <= width) {
  .merit__list dd {
    flex: 1;
    min-width: 0;
    overflow: visible;
    padding-left: 0;
    white-space: nowrap;
  }
}

/*
movie
*/
.movie {
  background-color: var(--primary);
  background-image: url("../img/w_y.png");
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 100%;
  padding-bottom: 14.6666666667vw;
}
@media (1024px <= width) {
  .movie {
    padding-bottom: 0;
    padding-top: 70px;
  }
}
.movie__wrap {
  height: 65.6vw;
  position: relative;
}
@media (1024px <= width) {
  .movie__wrap {
    height: 288px;
  }
}
.movie__i {
  left: 4.8vw;
  position: absolute;
  width: 40.1333333333vw;
}
@media (1024px <= width) {
  .movie__i {
    left: calc((100% - 750px) / 2);
    width: 248px;
  }
}
.movie__en {
  position: absolute;
  right: 8vw;
  top: 20.8vw;
  width: 30.1333333333vw;
}
@media (1024px <= width) {
  .movie__en {
    right: 30px;
    top: 68px;
    width: 180px;
  }
}
@media (1024px <= width) {
  .movie__en {
    right: calc((100% - 255px) / 2);
    top: 142px;
  }
}
.movie__text {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 5.3333333333vw;
  font-weight: 700;
  line-height: 1.2;
  position: absolute;
  right: 9.0666666667vw;
  text-align: right;
  top: 26.1333333333vw;
}
@media (1024px <= width) {
  .movie__text {
    font-size: 28px;
    right: calc((100% - 1012px) / 2);
    text-align: left;
    top: 172px;
  }
}
.movie__title {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 6.4vw;
  font-weight: 700;
  line-height: 1.667;
  position: absolute;
  text-align: right;
  -webkit-text-decoration: underline var(--tertiary) 1.6vw;
  right: 9.0666666667vw;
          text-decoration: underline var(--tertiary) 1.6vw;
  text-underline-offset: 0.5333333333vw;
  top: 45.8666666667vw;
}
@media (1024px <= width) {
  .movie__title {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 32px;
    font-weight: 700;
    letter-spacing: 0.025em;
    line-height: 1.312;
    right: calc((100% - 1004px) / 2);
    text-align: left;
    text-decoration-thickness: 6px;
    text-underline-offset: 2px;
    top: 212px;
  }
}
.movie__list {
  display: grid;
  gap: 7.4666666667vw 4vw;
  grid-template-columns: repeat(auto-fit, minmax(42.6666666667vw, 1fr));
  margin-inline: auto;
  padding-top: 13.8666666667vw;
  width: 90vw;
}
@media (1024px <= width) {
  .movie__list {
    gap: 40px 0;
    grid-template-columns: repeat(3, 1fr);
    max-width: 1040px;
    padding-top: 58px;
  }
}
.movie__list li {
  text-align: center;
  width: 42.6666666667vw;
}
@media (1024px <= width) {
  .movie__list li {
    width: 280px;
  }
}
.movie__list dl {
  background-color: var(--white);
  border-radius: 1.3333333333vw;
  display: block;
  margin-top: -7.2vw;
  padding-block: 9.6vw 2.9333333333vw;
}
@media (1024px <= width) {
  .movie__list dl {
    border-radius: 10px;
    margin-top: -31px;
    padding-block: 46px 27px;
  }
}
.movie__list dt img {
  display: block;
  height: 2.2666666667vw;
  margin-inline: auto;
}
@media (1024px <= width) {
  .movie__list dt img {
    height: 14px;
  }
}
.movie__list dd {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.5;
  line-height: 1.1875;
  margin-top: 1.0666666667vw;
}
@media (1024px <= width) {
  .movie__list dd {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 24px;
    font-weight: 700;
    line-height: 1.333;
    margin-top: 6px;
  }
}
.movie__modal {
  display: block;
  margin-inline: auto;
  transition: scale 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  width: 33.0666666667vw;
}
@media (1024px <= width) {
  .movie__modal {
    width: 164px;
  }
}
.movie__modal:focus-visible {
  scale: 1.02;
}
@media (any-hover: hover) {
  .movie__modal:hover {
    scale: 1.02;
  }
}

/*
voice
*/
.voice {
  background-color: var(--white);
  background-image: url("../img/y_w.png");
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 100%;
  padding-top: 10.1333333333vw;
}
@media (1024px <= width) {
  .voice {
    padding-top: 70px;
  }
}
.voice__inner {
  margin-top: -12vw;
}
@media (1024px <= width) {
  .voice__inner {
    margin-top: 10px;
  }
}
.voice__wrap {
  height: 60.2666666667vw;
  position: relative;
}
@media (1024px <= width) {
  .voice__wrap {
    height: 305px;
  }
}
.voice__i {
  position: absolute;
  right: 5.3333333333vw;
  width: 58.8vw;
}
@media (1024px <= width) {
  .voice__i {
    right: calc((100% - 580px) / 2);
    width: 392px;
  }
}
.voice__texts {
  margin-inline: auto;
  max-width: 1080px;
  position: relative;
  top: 47.4666666667vw;
  width: calc(100% - 8.5333333333vw);
}
@media (1024px <= width) {
  .voice__texts {
    top: 200px;
  }
}
.voice__en {
  width: 28vw;
}
@media (1024px <= width) {
  .voice__en {
    width: 167px;
  }
}
.voice__title {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 6.4vw;
  font-weight: 700;
  line-height: 1.667;
  -webkit-text-decoration: underline var(--primary) 1.6vw;
          text-decoration: underline var(--primary) 1.6vw;
  text-underline-offset: 0.5333333333vw;
}
@media (1024px <= width) {
  .voice__title {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 32px;
    font-weight: 700;
    letter-spacing: 0.025em;
    line-height: 1.312;
    margin-top: 14px;
    text-decoration-thickness: 6px;
    text-underline-offset: 2px;
  }
}
.voice__small {
  display: block;
  font-size: 2.6666666667vw;
  font-weight: 700;
  -webkit-transform: translateX(36vw) translateY(-5.8666666667vw);
          transform: translateX(36vw) translateY(-5.8666666667vw);
}
@media (1024px <= width) {
  .voice__small {
    font-size: 10px;
    margin-top: 10px;
    -webkit-transform: none;
            transform: none;
  }
}
.voice__text {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 3.7333333333vw;
  font-weight: 700;
  line-height: 1.357;
  margin-top: 8vw;
  text-align: center;
}
@media (1024px <= width) {
  .voice__text {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 24px;
    font-weight: 700;
    line-height: 1.333;
    margin-top: 40px;
  }
}
.voice__wrap2 {
  margin-inline: auto;
  margin-top: 3.2vw;
  max-width: 1080px;
  width: calc(100% - 8.5333333333vw);
}
@media (1024px <= width) {
  .voice__wrap2 {
    display: flex;
    gap: 10px;
    margin-top: 35px;
  }
}

.voiceGrade {
  border: 2px solid var(--secondary);
  border-radius: 1.3333333333vw;
  padding: 5.3333333333vw 5.3333333333vw;
}
@media (1024px <= width) {
  .voiceGrade {
    border-radius: 10px;
    flex: 1;
    padding: 30px 40px 36px;
  }
}
@media (1024px <= width) {
  .voiceGrade__head {
    align-items: center;
    display: flex;
    gap: 20px;
    justify-content: center;
  }
}
.voiceGrade__head dt {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.5;
  line-height: 1;
  text-align: center;
  -webkit-text-decoration: underline var(--secondary) 0.2666666667vw;
          text-decoration: underline var(--secondary) 0.2666666667vw;
  text-underline-offset: 0.5333333333vw;
}
@media (1024px <= width) {
  .voiceGrade__head dt {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 20px;
    font-weight: 700;
    line-height: 1.4;
    text-decoration-thickness: 2px;
    text-underline-offset: 2px;
  }
}
.voiceGrade__head dd {
  align-items: center;
  -webkit-font-feature-settings: "palt";
  display: flex;
          font-feature-settings: "palt";
  font-size: 4.2666666667vw;
  font-weight: 700;
  justify-content: center;
  line-height: 1.5;
  margin-top: 1.0666666667vw;
}
@media (1024px <= width) {
  .voiceGrade__head dd {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 18px;
    font-weight: 700;
    line-height: 1.25;
    margin-top: 0;
  }
}
.voiceGrade__head dd span {
  -webkit-font-feature-settings: "palt";
  color: var(--tertiary);
          font-feature-settings: "palt";
  font-size: 5.3333333333vw;
  font-weight: 700;
  letter-spacing: 0.125em;
  line-height: 1.2;
  margin-inline: 0.5em;
}
@media (1024px <= width) {
  .voiceGrade__head dd span {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 24px;
    font-weight: 700;
    line-height: 1.333;
  }
}
.voiceGrade__list {
  margin-top: 5.3333333333vw;
}
@media (1024px <= width) {
  .voiceGrade__list {
    margin-top: 28px;
  }
}
.voiceGrade__list li {
  -webkit-font-feature-settings: "palt";
  align-items: start;
  display: flex;
          font-feature-settings: "palt";
  font-size: 4.2666666667vw;
  font-weight: 700;
  gap: 1.6vw;
  line-height: 1.5;
  margin-top: 2.6666666667vw;
}
@media (1024px <= width) {
  .voiceGrade__list li {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 18px;
    font-weight: 700;
    gap: 8px;
    line-height: 1.25;
    margin-top: 16px;
  }
}
.voiceGrade__list img {
  width: 5.3333333333vw;
}
@media (1024px <= width) {
  .voiceGrade__list img {
    width: 20px;
  }
}
.voiceGrade__list span {
  flex: 1;
  line-height: 5.3333333333vw;
}
@media (1024px <= width) {
  .voiceGrade__list span {
    line-height: 20px;
  }
}

.voiceGraph {
  background: url(../img/g_base.png) center no-repeat;
  background-size: cover;
  height: 85.7866666667vw;
  margin-inline: auto;
  margin-top: 3.2vw;
  position: relative;
  width: 84vw;
}
@media (1024px <= width) {
  .voiceGraph {
    height: 358.5px;
    margin-top: 0;
    width: 351px;
  }
}
.voiceGraph__main, .voiceGraph__dot, .voiceGraph__num {
  height: 85.7866666667vw;
  inset: 0;
  position: absolute;
  width: 84vw;
}
@media (1024px <= width) {
  .voiceGraph__main, .voiceGraph__dot, .voiceGraph__num {
    height: 358.5px;
    width: 351px;
  }
}

.voiceList {
  display: flex;
  flex-direction: column;
  gap: 3.2vw;
  margin-inline: auto;
  margin-top: 11.2vw;
  max-width: 1080px;
  width: calc(100% - 8.5333333333vw);
}
@media (1024px <= width) {
  .voiceList {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 16px 0;
    justify-content: space-between;
    margin-top: 54px;
  }
}

@scope (.voiceList__item) {
  :scope {
    border: 2px solid var(--secondary);
    border-radius: 1.3333333333vw;
    padding: 4.2666666667vw 4.2666666667vw 3.7333333333vw;
    width: 100%;
  }
  @media (1024px <= width) {
    :scope {
      border-radius: 10px;
      max-width: 528px;
      padding: 20px 20px 24px;
      width: 49%;
    }
  }
  :scope {
    align-items: center;
    display: grid;
    grid-template-columns: 11.7333333333vw 1fr auto;
    grid-template-rows: 11.7333333333vw auto;
    grid-column-gap: 2.6666666667vw;
    grid-row-gap: 1.3333333333vw;
  }
  @media (1024px <= width) {
    :scope {
      grid-template-columns: 40px 1fr auto;
      grid-template-rows: 40px 1fr;
      grid-column-gap: 16px;
      grid-row-gap: 8px;
    }
  }
  .img {
    grid-area: 1/1/2/2;
  }
  .name {
    grid-area: 1/2/2/3;
  }
  .tag {
    grid-area: 1/3/2/4;
  }
  .text {
    grid-area: 2/1/3/4;
  }
  .name {
    font-size: 4vw;
    font-weight: 700;
  }
  @media (1024px <= width) {
    .name {
      -webkit-font-feature-settings: "palt";
              font-feature-settings: "palt";
      font-size: 18px;
      font-weight: 700;
      line-height: 1.25;
    }
  }
  .tag {
    background-color: var(--primary);
    font-size: 3.2vw;
    font-weight: 700;
    padding: 2.1333333333vw;
  }
  @media (1024px <= width) {
    .tag {
      font-size: 14px;
      padding: 8px;
    }
  }
  .text {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 4.2666666667vw;
    font-weight: 700;
    line-height: 1.5;
    line-height: 1.375;
    margin-block: var(--leading-trim);
  }
  @media (1024px <= width) {
    .text {
      -webkit-font-feature-settings: "palt";
      align-self: flex-start;
              font-feature-settings: "palt";
      font-size: 18px;
      font-weight: 700;
      letter-spacing: -0.02em;
      line-height: 1.25;
    }
  }
  .text span {
    color: var(--tertiary);
  }
}
/*
howto
*/
.howto {
  background-color: var(--gray);
  padding-top: 12.8vw;
}
@media (1024px <= width) {
  .howto {
    padding-top: 96px;
  }
}
.howto__inner {
  margin-inline: auto;
  max-width: 1080px;
  width: calc(100% - 8.5333333333vw);
}
.howto__en {
  width: 28.8vw;
}
@media (1024px <= width) {
  .howto__en {
    width: 171px;
  }
}
.howto__title {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 6.4vw;
  font-weight: 700;
  line-height: 1.667;
  margin-top: 1.3333333333vw;
}
@media (1024px <= width) {
  .howto__title {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 32px;
    font-weight: 700;
    letter-spacing: 0.025em;
    line-height: 1.312;
    margin-top: 10px;
  }
}
.howto__col {
  margin-top: 5.8666666667vw;
}
@media (1024px <= width) {
  .howto__col {
    margin-top: 30px;
  }
}
.howto__col2 {
  margin-top: 12.8vw;
}
@media (1024px <= width) {
  .howto__col2 {
    margin-top: 56px;
  }
}
.howto__col3 {
  margin-top: 14.6666666667vw;
}
@media (1024px <= width) {
  .howto__col3 {
    margin-top: 64px;
  }
}
.howto__col4 {
  margin-top: 13.8666666667vw;
}
@media (1024px <= width) {
  .howto__col4 {
    margin-top: 64px;
  }
}
.howto__col5 {
  margin-top: 10.1333333333vw;
}
@media (1024px <= width) {
  .howto__col5 {
    margin-top: 74px;
  }
}
.howto__col6 {
  margin-top: 16vw;
}
@media (1024px <= width) {
  .howto__col6 {
    margin-top: 72px;
  }
}
.howto__col7 {
  margin-top: 16.8vw;
}
@media (1024px <= width) {
  .howto__col7 {
    margin-top: 72px;
  }
}
.howto__col8 {
  margin-top: 16vw;
}
@media (1024px <= width) {
  .howto__col8 {
    margin-top: 72px;
  }
}
.howto__title2 {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 5.3333333333vw;
  font-weight: 700;
  line-height: 1.2;
  -webkit-text-decoration: underline var(--primary) 1.6vw;
          text-decoration: underline var(--primary) 1.6vw;
  text-underline-offset: -0.5333333333vw;
}
@media (1024px <= width) {
  .howto__title2 {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 24px;
    font-weight: 700;
    line-height: 1.333;
    text-decoration-thickness: 6px;
    text-underline-offset: -2px;
  }
}
.howto__text {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.5;
  line-height: 1.375;
  margin-top: 2.9333333333vw;
  text-align: justify;
}
@media (1024px <= width) {
  .howto__text {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 18px;
    font-weight: 700;
    line-height: 1.25;
    line-height: 1.333;
    margin-top: 18px;
  }
}
.howto__text .-color {
  color: var(--secondary);
}
.howto__link {
  color: var(--secondary) !important;
  text-decoration: underline !important;
}
.howto__link::after {
  background: url(../img/icon_pdf_b.svg) center no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  margin-inline: 0.25em;
  -webkit-transform: translateY(0.1lh);
  height: 3.7333333333vw;
          transform: translateY(0.1lh);
  width: 3.7333333333vw;
}
@media (768px <= width) {
  .howto__link::after {
    -webkit-transform: translateY(0.2lh);
    height: 20px;
            transform: translateY(0.2lh);
    width: 20px;
  }
}
.howto__link:focus-visible {
  color: var(--tertiary) !important;
}
.howto__link:focus-visible::after {
  background: url(../img/icon_pdf_o.svg) center no-repeat;
  background-size: contain;
}
@media (any-hover: hover) {
  .howto__link:hover {
    color: var(--tertiary) !important;
  }
  .howto__link:hover::after {
    background: url(../img/icon_pdf_o.svg) center no-repeat;
    background-size: contain;
  }
}
.howto__link {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 3.7333333333vw;
  font-weight: 700;
  line-height: 1.357;
}
@media (1024px <= width) {
  .howto__link {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 16px;
    font-weight: 700;
    line-height: 1.333;
  }
}
.howto__notes {
  margin-top: 2.6666666667vw;
}
@media (1024px <= width) {
  .howto__notes {
    margin-top: 14px;
  }
}
.howto__notes p {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 3.7333333333vw;
  font-weight: 700;
  font-weight: 500;
  line-height: 1.357;
  text-indent: hanging 1em;
}
@media (1024px <= width) {
  .howto__notes p {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 16px;
    font-weight: 700;
    font-weight: 500;
    line-height: 1.333;
    line-height: 1.25;
  }
}
.howto__note {
  -webkit-font-feature-settings: "palt";
  background-color: var(--primary);
  border-radius: 1.3333333333vw;
          font-feature-settings: "palt";
  font-size: 3.7333333333vw;
  font-weight: 700;
  font-weight: 500;
  line-height: 1.357;
  margin-top: 5.3333333333vw;
  padding: 4.2666666667vw 2.6666666667vw 3.2vw;
  text-align: justify;
  text-indent: hanging 1em;
}
@media (1024px <= width) {
  .howto__note {
    -webkit-font-feature-settings: "palt";
    border-radius: 10px;
            font-feature-settings: "palt";
    font-size: 16px;
    font-weight: 700;
    font-weight: 500;
    line-height: 1.333;
    margin-top: 20px;
    padding: 6px 15px;
  }
}
.howto__wrap {
  display: flex;
  flex-direction: column;
  gap: 13.3333333333vw;
  margin-top: 8.5333333333vw;
}
@media (1024px <= width) {
  .howto__wrap {
    flex-direction: row;
    gap: 50px;
    justify-content: space-between;
    margin-top: 46px;
  }
}
.howto__type {
  position: relative;
}
.howto__type dt {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 5.3333333333vw;
  font-weight: 700;
  line-height: 1.2;
  -webkit-text-decoration: underline var(--secondary) 0.5333333333vw;
  text-align: center;
          text-decoration: underline var(--secondary) 0.5333333333vw;
  text-underline-offset: 1.6vw;
}
@media (1024px <= width) {
  .howto__type dt {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 24px;
    font-weight: 700;
    line-height: 1.333;
    text-decoration-thickness: 2px;
    text-underline-offset: 6px;
  }
}
.howto__type dd {
  margin-top: 5.3333333333vw;
}
@media (1024px <= width) {
  .howto__type dd {
    margin-inline: auto;
    margin-top: 40px;
  }
}
.howto__type.-border::after {
  border-bottom: 0.2666666667vw dashed var(--secondary);
  bottom: -6.6666666667vw;
  content: "";
  display: block;
  height: 0.2666666667vw;
  position: relative;
  width: 100%;
}
@media (1024px <= width) {
  .howto__type.-border::after {
    border-bottom: none;
    border-right: 1px dashed var(--secondary);
    bottom: auto;
    height: 100%;
    position: absolute;
    right: -25px;
    top: 0;
    width: 1px;
  }
}
.howto__wrap2 {
  display: flex;
  flex-direction: column;
  gap: 6.9333333333vw;
  margin-bottom: 5.3333333333vw;
}
@media (1024px <= width) {
  .howto__wrap2 {
    align-items: center;
    flex-direction: row;
    gap: 0;
    justify-content: space-between;
    margin-bottom: 22px;
  }
  .howto__wrap2 img {
    width: 503px;
  }
}
.howto__small {
  -webkit-font-feature-settings: "palt";
  display: block;
          font-feature-settings: "palt";
  font-size: 3.7333333333vw;
  font-weight: 700;
  font-weight: 500;
  line-height: 1.357;
  margin-top: 1.3333333333vw;
  text-indent: hanging 1em;
}
@media (1024px <= width) {
  .howto__small {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 16px;
    font-weight: 700;
    font-weight: 500;
    line-height: 1.333;
    margin-top: 5px;
  }
}
@media (1024px <= width) {
  .howto__notes2 {
    margin-inline: auto 0;
    width: 257px;
  }
}
.howto__small2 {
  -webkit-font-feature-settings: "palt";
  display: block;
          font-feature-settings: "palt";
  font-size: 3.7333333333vw;
  font-weight: 700;
  font-weight: 500;
  line-height: 1.357;
  margin-top: 1.3333333333vw;
  text-indent: hanging 1em;
}
@media (1024px <= width) {
  .howto__small2 {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 12px;
    font-weight: 700;
    font-weight: 500;
    line-height: 1.333;
    margin-top: 5px;
  }
}

.howtoCards {
  display: grid;
  gap: 12px;
  grid-template-rows: repeat(4, auto);
  margin-top: 8vw;
}
@media (1024px <= width) {
  .howtoCards {
    gap: 16px;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: 1fr;
    margin-top: 20px;
  }
}

@scope (.howtoCard) {
  :scope {
    background-color: var(--white);
    border-radius: 1.3333333333vw;
    padding: 4.2666666667vw 6.4vw;
    width: 100%;
  }
  @media (1024px <= width) {
    :scope {
      border-radius: 10px;
      display: grid;
      grid-row: span 4;
      grid-template-rows: subgrid;
      padding: 24px 16px 18px;
    }
  }
  .title {
    -webkit-font-feature-settings: "palt";
    color: var(--secondary);
            font-feature-settings: "palt";
    font-size: 5.3333333333vw;
    font-weight: 700;
    line-height: 1.2;
    -webkit-text-decoration: underline var(--primary) 0.5333333333vw;
            text-decoration: underline var(--primary) 0.5333333333vw;
  }
  @media (1024px <= width) {
    .title {
      -webkit-font-feature-settings: "palt";
              font-feature-settings: "palt";
      font-size: 18px;
      font-weight: 700;
      line-height: 1.25;
      text-align: center;
      text-decoration-thickness: 4px;
    }
  }
  .text {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 4.2666666667vw;
    font-weight: 700;
    line-height: 1.5;
    line-height: 1.375;
    margin-top: 2.1333333333vw;
    text-align: justify;
  }
  @media (1024px <= width) {
    .text {
      -webkit-font-feature-settings: "palt";
              font-feature-settings: "palt";
      font-size: 18px;
      font-weight: 700;
      line-height: 1.25;
      margin-top: 0;
    }
  }
  .wrap {
    align-items: center;
    display: grid;
    gap: 2.1333333333vw;
    grid-template-columns: 32vw 1fr;
    margin-top: 2.6666666667vw;
  }
  @media (1024px <= width) {
    .wrap {
      gap: 5px;
      grid-template-columns: 1fr;
      grid-template-rows: 160px auto;
      margin-top: 0;
    }
  }
  @media (1024px <= width) {
    .img {
      margin-inline: auto;
      width: 160px;
    }
  }
  .tags li {
    background-color: var(--gray);
    border: 1px solid #C7C5C5;
    border-radius: 100vmax;
    display: inline-block;
    font-size: 3.2vw;
    font-weight: 500;
    margin-bottom: 3.2vw;
    margin-right: 1.6vw;
    padding: 0.5333333333vw 2.4vw;
  }
  @media (1024px <= width) {
    .tags li {
      -webkit-font-feature-settings: "palt";
              font-feature-settings: "palt";
      font-size: 12px;
      font-weight: 700;
      line-height: 1.333;
      margin-bottom: 12px;
      margin-right: 6px;
      padding: 2px 12px;
    }
  }
  .price {
    align-items: center;
    border: 2px solid var(--secondary);
    border-radius: 1.3333333333vw;
    display: flex;
    gap: 5.3333333333vw;
    justify-content: center;
    margin-top: 3.2vw;
    padding: 1.0666666667vw 3.2vw;
    width: 100%;
  }
  @media (1024px <= width) {
    .price {
      border-radius: 10px;
      flex-direction: column;
      gap: 4px;
      margin-top: 0;
      padding: 4px 0;
    }
  }
  .price .-label {
    -webkit-font-feature-settings: "palt";
    color: var(--secondary);
            font-feature-settings: "palt";
    font-size: 4.2666666667vw;
    font-weight: 700;
    line-height: 1.5;
  }
  @media (1024px <= width) {
    .price .-label {
      -webkit-font-feature-settings: "palt";
              font-feature-settings: "palt";
      font-size: 16px;
      font-weight: 700;
      line-height: 1.333;
    }
  }
  .price .-amount {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 4.2666666667vw;
    font-weight: 700;
    line-height: 1.5;
  }
  @media (1024px <= width) {
    .price .-amount {
      -webkit-font-feature-settings: "palt";
              font-feature-settings: "palt";
      font-size: 18px;
      font-weight: 700;
      line-height: 1.25;
    }
  }
}
.howtoSteps {
  display: grid;
  gap: 10.6666666667vw;
  grid-template-rows: repeat(4, auto);
  margin-top: 8vw;
}
@media (1024px <= width) {
  .howtoSteps {
    gap: 16px;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: 1fr;
    margin-top: 20px;
  }
}

@scope (.howtoStep) {
  :scope {
    background-color: var(--white);
    border: 4px solid var(--secondary);
    border-radius: 1.3333333333vw;
    padding: 4.2666666667vw 6.4vw;
    position: relative;
    width: 100%;
  }
  @media (1024px <= width) {
    :scope {
      border-radius: 10px;
      padding: 24px 16px 18px;
    }
  }
  :scope {
    align-items: center;
    display: grid;
    grid-template-columns: 1fr 29.3333333333vw;
    grid-template-rows: 29.3333333333vw auto;
  }
  :scope .title {
    grid-area: 1/1/2/2;
  }
  :scope .img {
    grid-area: 1/2/2/3;
  }
  :scope .text {
    grid-area: 2/1/3/3;
  }
  @media (1024px <= width) {
    :scope {
      grid-row: span 3;
      grid-template-columns: 1fr;
      grid-template-rows: subgrid;
    }
    :scope .title {
      grid-area: auto;
    }
    :scope .img {
      grid-area: auto;
    }
    :scope .text {
      grid-area: auto;
    }
  }
  :scope::before {
    background-color: var(--secondary);
    bottom: -8vw;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: "";
    height: 4.2666666667vw;
    left: calc((100% - 6.4vw) / 2);
    position: absolute;
    width: 6.4vw;
  }
  @media (1024px <= width) {
    :scope::before {
      bottom: auto;
      height: 8px;
      left: auto;
      right: -18px;
      rotate: -90deg;
      top: calc((100% - 12px) / 2);
      width: 12px;
    }
  }
  :scope:nth-child(4)::before {
    display: none;
  }
  :scope::after {
    content: "";
    height: 13.3333333333vw;
    left: -4vw;
    position: absolute;
    top: -4vw;
    width: 13.3333333333vw;
  }
  @media (1024px <= width) {
    :scope::after {
      height: 50px;
      left: -15px;
      top: -15px;
      width: 50px;
    }
  }
  :scope:nth-child(1)::after {
    background: url(../img/step01.svg) center no-repeat;
    background-size: cover;
  }
  :scope:nth-child(2)::after {
    background: url(../img/step02.svg) center no-repeat;
    background-size: cover;
  }
  :scope:nth-child(3)::after {
    background: url(../img/step03.svg) center no-repeat;
    background-size: cover;
  }
  :scope:nth-child(4)::after {
    background: url(../img/step04.svg) center no-repeat;
    background-size: cover;
  }
  .title {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 5.3333333333vw;
    font-weight: 700;
    line-height: 1.2;
  }
  @media (1024px <= width) {
    .title {
      -webkit-font-feature-settings: "palt";
              font-feature-settings: "palt";
      font-size: 20px;
      font-weight: 700;
      line-height: 1.4;
      text-align: center;
    }
  }
  .text {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 4.2666666667vw;
    font-weight: 700;
    line-height: 1.5;
    line-height: 1.375;
    margin-top: 2.1333333333vw;
    text-align: justify;
  }
  @media (1024px <= width) {
    .text {
      -webkit-font-feature-settings: "palt";
      align-self: start;
              font-feature-settings: "palt";
      font-size: 18px;
      font-weight: 700;
      line-height: 1.25;
      margin-top: 0;
    }
  }
  .text span {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 3.7333333333vw;
    font-weight: 700;
    font-weight: 500;
    line-height: 1.357;
  }
  @media (1024px <= width) {
    .text span {
      -webkit-font-feature-settings: "palt";
              font-feature-settings: "palt";
      font-size: 16px;
      font-weight: 700;
      font-weight: 500;
      line-height: 1.333;
    }
  }
  .text a {
    color: var(--secondary) !important;
    text-decoration: underline !important;
  }
  .text a::after {
    background: url(../img/icon_pdf_b.svg) center no-repeat;
    background-size: contain;
    content: "";
    display: inline-block;
    margin-inline: 0.25em;
    -webkit-transform: translateY(0.1lh);
    height: 3.7333333333vw;
            transform: translateY(0.1lh);
    width: 3.7333333333vw;
  }
  @media (768px <= width) {
    .text a::after {
      -webkit-transform: translateY(0.2lh);
      height: 20px;
              transform: translateY(0.2lh);
      width: 20px;
    }
  }
  .text a:focus-visible {
    color: var(--tertiary) !important;
  }
  .text a:focus-visible::after {
    background: url(../img/icon_pdf_o.svg) center no-repeat;
    background-size: contain;
  }
  @media (any-hover: hover) {
    .text a:hover {
      color: var(--tertiary) !important;
    }
    .text a:hover::after {
      background: url(../img/icon_pdf_o.svg) center no-repeat;
      background-size: contain;
    }
  }
  .text a {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 3.7333333333vw;
    font-weight: 700;
    font-weight: 500;
    line-height: 1.357;
  }
  @media (1024px <= width) {
    .text a {
      -webkit-font-feature-settings: "palt";
              font-feature-settings: "palt";
      font-size: 16px;
      font-weight: 700;
      font-weight: 500;
      letter-spacing: -0.05em;
      line-height: 1.333;
    }
  }
}
.howtoCompare2 {
  margin-top: 6.4vw;
}
@media (1024px <= width) {
  .howtoCompare2 {
    margin-top: 40px;
  }
}
.howtoCompare2__table {
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
  width: 100%;
}
.howtoCompare2__col-label {
  width: 18.1333333333vw;
}
@media (1024px <= width) {
  .howtoCompare2__col-label {
    width: 192px;
  }
}
.howtoCompare2__col-rental {
  width: 40.5333333333vw;
}
@media (1024px <= width) {
  .howtoCompare2__col-rental {
    width: 400px;
  }
}
.howtoCompare2__col-purchase {
  width: 30.6666666667vw;
}
@media (1024px <= width) {
  .howtoCompare2__col-purchase {
    width: 300px;
  }
}
.howtoCompare2__th {
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: center;
  vertical-align: middle;
}
.howtoCompare2__th.-rental {
  background-color: var(--secondary);
  border-radius: 3.2vw 3.2vw 0 0;
  color: var(--white);
  font-size: 4.8vw;
  height: 13.8666666667vw;
}
@media (1024px <= width) {
  .howtoCompare2__th.-rental {
    border-radius: 16px 16px 0 0;
    font-size: 32px;
    height: 80px;
  }
}
.howtoCompare2__th.-purchase {
  background: linear-gradient(to bottom, var(--gray) 3.2vw, #ced4ff 3.2vw);
  font-size: 3.4666666667vw;
  padding-bottom: 2.6666666667vw;
  position: relative;
  vertical-align: bottom;
}
@media (1024px <= width) {
  .howtoCompare2__th.-purchase {
    background: linear-gradient(to bottom, var(--gray) 19px, #ced4ff 19px);
    font-size: 24px;
    padding-bottom: 14px;
  }
}
.howtoCompare2__th.-purchase::before {
  border: 1px solid #c7c5c5;
  bottom: 0;
  content: "";
  left: 0;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 3.2vw;
}
@media (1024px <= width) {
  .howtoCompare2__th.-purchase::before {
    top: 19px;
  }
}
.howtoCompare2__label {
  background: var(--white);
  border: 1px solid #c7c5c5;
  font-size: 3.2vw;
  font-weight: 700;
  text-align: center;
  vertical-align: middle;
}
@media (1024px <= width) {
  .howtoCompare2__label {
    font-size: 18px;
  }
}
.howtoCompare2__cell {
  background: var(--white);
  border: 1px solid #c7c5c5;
  font-weight: 700;
  text-align: center;
  vertical-align: middle;
}
.howtoCompare2__cell.-rental {
  border-left: 3px solid var(--secondary);
  border-right: 3px solid var(--secondary);
  font-size: 4.2666666667vw;
  height: 13.8666666667vw;
  letter-spacing: 0.03em;
}
@media (1024px <= width) {
  .howtoCompare2__cell.-rental {
    border-left-width: 6px;
    border-right-width: 6px;
    font-size: 32px;
    height: 80px;
  }
}
.howtoCompare2__cell.-rental.-best {
  color: var(--secondary);
}
.howtoCompare2__cell.-purchase {
  font-size: 3.4666666667vw;
  letter-spacing: 0.03em;
}
@media (1024px <= width) {
  .howtoCompare2__cell.-purchase {
    font-size: 24px;
  }
}
.howtoCompare2__cell.-purchase.-worse {
  color: #ff0404;
}
.howtoCompare2 tbody tr:last-child .howtoCompare2__cell.-rental {
  border-bottom: 0.8vw solid var(--secondary);
}
@media (1024px <= width) {
  .howtoCompare2 tbody tr:last-child .howtoCompare2__cell.-rental {
    border-bottom-width: 6px;
  }
}
.howtoCompare2__price {
  align-items: baseline;
  display: flex;
  gap: 0.8vw;
  justify-content: center;
}
@media (1024px <= width) {
  .howtoCompare2__price {
    gap: 8px;
  }
}
.howtoCompare2__price .-label {
  font-size: 3.2vw;
  font-weight: 700;
}
@media (1024px <= width) {
  .howtoCompare2__price .-label {
    font-size: 32px;
  }
}
.howtoCompare2__price .-num {
  font-size: 4.8vw;
  font-weight: 700;
}
@media (1024px <= width) {
  .howtoCompare2__price .-num {
    font-size: 48px;
  }
}
.howtoCompare2__balloon {
  background: var(--primary);
  border-radius: 2.1333333333vw;
  color: var(--secondary);
  font-size: 3.7333333333vw;
  font-weight: 700;
  line-height: 1.538;
  margin-inline: auto;
  margin-top: 4.2666666667vw;
  padding: 4vw 3.2vw;
  position: relative;
  text-align: center;
  width: 68.2666666667vw;
}
@media (1024px <= width) {
  .howtoCompare2__balloon {
    border-radius: 16px;
    font-size: 18px;
    line-height: 1.333;
    margin-left: 133px;
    margin-top: 26px;
    padding: 30px 0;
    width: 606px;
  }
}
.howtoCompare2__balloon::before {
  border-bottom: 3.7333333333vw solid var(--primary);
  border-left: 2.4vw solid transparent;
  border-right: 2.4vw solid transparent;
  content: "";
  left: 24vw;
  position: absolute;
  top: -2.6666666667vw;
}
@media (1024px <= width) {
  .howtoCompare2__balloon::before {
    border-bottom-width: 14px;
    border-left-width: 9px;
    border-right-width: 9px;
    left: 292px;
    top: -10px;
  }
}

/*
faq
*/
.faq {
  background-color: var(--white);
  background-image: url("../img/g_w.png");
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 100%;
  padding-block: 10.1333333333vw;
}
@media (1024px <= width) {
  .faq {
    padding-block: 70px;
  }
}
.faq__inner {
  margin-inline: auto;
  max-width: 1080px;
  padding-top: 10.6666666667vw;
  width: calc(100% - 8.5333333333vw);
}
@media (1024px <= width) {
  .faq__inner {
    padding-top: 160px;
  }
}
.faq__en {
  width: 14vw;
}
@media (1024px <= width) {
  .faq__en {
    width: 87px;
  }
}
.faq__title {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 6.4vw;
  font-weight: 700;
  line-height: 1.667;
  margin-top: 1.3333333333vw;
}
@media (1024px <= width) {
  .faq__title {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 32px;
    font-weight: 700;
    letter-spacing: 0.025em;
    line-height: 1.312;
    margin-top: 10px;
  }
}

.faqItems {
  display: flex;
  flex-direction: column;
  gap: 8.5333333333vw;
  margin-top: 5.3333333333vw;
}
@media (1024px <= width) {
  .faqItems {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 40px 0;
    justify-content: space-between;
    margin-top: 40px;
  }
}

@scope (.faqItem) {
  :scope {
    width: 100%;
  }
  @media (1024px <= width) {
    :scope {
      max-width: 524px;
      width: 49%;
    }
  }
  dt img {
    display: block;
    width: 6.9333333333vw;
  }
  @media (1024px <= width) {
    dt img {
      width: 26px;
    }
  }
  dt span {
    -webkit-font-feature-settings: "palt";
    color: var(--secondary);
    display: block;
            font-feature-settings: "palt";
    font-size: 5.3333333333vw;
    font-weight: 700;
    line-height: 1.2;
    margin-top: 1.0666666667vw;
  }
  @media (1024px <= width) {
    dt span {
      -webkit-font-feature-settings: "palt";
              font-feature-settings: "palt";
      font-size: 20px;
      font-weight: 700;
      line-height: 1.4;
      margin-top: 8px;
    }
  }
  dd {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 4.2666666667vw;
    font-weight: 700;
    line-height: 1.5;
    line-height: 1.375;
    margin-top: 2.1333333333vw;
    text-align: justify;
  }
  @media (1024px <= width) {
    dd {
      -webkit-font-feature-settings: "palt";
              font-feature-settings: "palt";
      font-size: 18px;
      font-weight: 700;
      line-height: 1.25;
      margin-top: 8px;
    }
  }
  dd a {
    -webkit-font-feature-settings: "palt";
    color: var(--secondary) !important;
            font-feature-settings: "palt";
    font-size: 3.7333333333vw;
    font-weight: 700;
    line-height: 1.357;
    text-decoration: underline !important;
  }
  dd a::after {
    background: url(../img/icon_blank.svg) center no-repeat;
    background-size: contain;
    content: "";
    display: inline-block;
    height: 3.2vw;
    margin-inline: 0.25em;
    width: 3.2vw;
  }
  @media (768px <= width) {
    dd a::after {
      -webkit-transform: translateY(0.1lh);
      height: 16px;
              transform: translateY(0.1lh);
      width: 16px;
    }
  }
  dd a:focus-visible {
    color: var(--tertiary) !important;
  }
  dd a:focus-visible::after {
    background: url(../img/icon_blank_o.svg) center no-repeat;
    background-size: contain;
  }
  @media (any-hover: hover) {
    dd a:hover {
      color: var(--tertiary) !important;
    }
    dd a:hover::after {
      background: url(../img/icon_blank_o.svg) center no-repeat;
      background-size: contain;
    }
  }
  @media (1024px <= width) {
    dd a {
      -webkit-font-feature-settings: "palt";
              font-feature-settings: "palt";
      font-size: 16px;
      font-weight: 700;
      line-height: 1.333;
    }
  }
}
/*
ex
*/
.ex {
  background-color: var(--white);
  padding-block: 10.1333333333vw;
}
@media (1024px <= width) {
  .ex {
    padding-block: 70px;
  }
}
.ex__inner {
  margin-inline: auto;
  max-width: 1080px;
  width: calc(100% - 8.5333333333vw);
}
.ex__en {
  width: 38.5333333333vw;
}
@media (1024px <= width) {
  .ex__en {
    width: 240px;
  }
}
.ex__title {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 6.4vw;
  font-weight: 700;
  line-height: 1.667;
  margin-top: 1.3333333333vw;
}
@media (1024px <= width) {
  .ex__title {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 32px;
    font-weight: 700;
    letter-spacing: 0.025em;
    line-height: 1.312;
    margin-top: 10px;
  }
}

/*
print
*/
@media print {
  * {
    background: transparent !important;
    border-color: black !important;
    box-shadow: none !important;
    color: black !important;
    text-shadow: none !important;
  }
  body {
    width: 210mm;
  }
  header,
  footer {
    display: none !important;
  }
  footer::after {
    content: "";
  }
  .-noprint {
    display: none;
  }
}
@page {
  margin: 0;
  size: A4;
}