@charset "UTF-8";
/* //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

RESET CSS

html5doctor.com Reset Stylesheet

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////*/
abbr,
address,
article,
aside,
audio,
b,
blockquote,
body,
canvas,
caption,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
p,
pre,
q,
samp,
section,
small,
span,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
ul,
var,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
  width: 100%;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:after,
blockquote:before,
q:after,
q:before {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
} /* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
} /* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: 700;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: middle;
}

button {
  padding: 0;
}

@font-face {
  font-family: "Oxygen";
  font-display: swap;
  src: url("https://anrakuins.com/wp/wp-includes/fonts/num.woff2") format("woff2"), url("https://anrakuins.com/wp/wp-includes/fonts/num.woff") format("woff"), url("https://anrakuins.com/wp/wp-includes/fonts/num.eot") format("eot");
}
@font-face {
  font-family: "Zen Kaku Gothic New";
  font-display: swap;
  src: url("https://anrakuins.com/wp/wp-includes/fonts/Gothic-400.woff2") format("woff2"), url("https://anrakuins.com/wp/wp-includes/fonts/Gothic-400.woff") format("woff"), url("https://anrakuins.com/wp/wp-includes/fonts/Gothic-400.eot") format("eot");
  font-weight: 400;
}
@font-face {
  font-family: "Zen Kaku Gothic New";
  font-display: swap;
  src: url("https://anrakuins.com/wp/wp-includes/fonts/Gothic-500.woff2") format("woff2"), url("https://anrakuins.com/wp/wp-includes/fonts/Gothic-500.woff") format("woff"), url("https://anrakuins.com/wp/wp-includes/fonts/Gothic-500.eot") format("eot");
  font-weight: 500;
}
@font-face {
  font-family: "Zen Old Mincho";
  font-display: swap;
  src: url("https://anrakuins.com/wp/wp-includes/fonts/Mincho-400.woff2") format("woff2"), url("https://anrakuins.com/wp/wp-includes/fonts/Mincho-400.woff") format("woff"), url("https://anrakuins.com/wp/wp-includes/fonts/Mincho-400.eot") format("eot");
  font-weight: 400;
}
@font-face {
  font-family: "Zen Old Mincho";
  font-display: swap;
  src: url("https://anrakuins.com/wp/wp-includes/fonts/Mincho-500.woff2") format("woff2"), url("https://anrakuins.com/wp/wp-includes/fonts/Mincho-500.woff") format("woff"), url("https://anrakuins.com/wp/wp-includes/fonts/Mincho-500.eot") format("eot");
  font-weight: 500;
}
@font-face {
  font-family: "Cormorant Garamond";
  font-display: swap;
  src: url("https://anrakuins.com/wp/wp-includes/fonts/en-serif.woff2") format("woff2"), url("https://anrakuins.com/wp/wp-includes/fonts/en-serif.woff") format("woff"), url("https://anrakuins.com/wp/wp-includes/fonts/en-serif.eot") format("eot");
}
/* ------------------------- 使い方 ----------------------------------------------------------

    @include sizing(width, wide, 365px, sp, 276px);
    ==> width: clamp(276px, 7.46vw + 248px, 365px);
    （ビューポートがwide(1568px)のとき365px, sp(375px)のとき276pxになる自動補完値を上限下限をつけて設定）

    @include sizing(width, wide, 365px, sp, 276px, noClamp);
    ==> width: calc(7.46vw + 248px);
    （ビューポートがwide(1568px)のとき365px, sp(375px)のとき276pxになる自動補完値を設定）

    @include sizingRem(font-size, wide, 14px, sp, 12px);
    ==> font-size: clamp(0.75rem, 0.17vw + 0.70625rem, 0.875rem;
    （ビューポートがwide(1568px)のとき14px, sp(375px)のとき12pxになる自動補完値をremに変換して設定）
　　
    ※使いたいsassファイル上で@useしてください。
    ※scssファイル上での読みやすさ重視のため、mixinの引数に単位[px]が必要な仕様にしてあります。

// ---------------------------------------------------------------------------------------- */
/*
  Base
-----------------------------------------------------*/
.grecaptcha-badge {
  visibility: hidden;
}

*,
:before,
:after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  scroll-behavior: smooth;
  line-height: 2;
}
@media screen and (min-width: 1280px) {
  html {
    scroll-padding-top: 140px;
  }
}

body {
  font-family: "Oxygen", "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.75;
  color: #0f242f;
  text-rendering: optimizeLegibility;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  letter-spacing: 0.035em;
  scroll-padding-top: 100px;
  scroll-behavior: smooth;
}
@media screen and (min-width: 960px) {
  body {
    line-height: 2;
    scroll-padding-top: 150px;
  }
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: inherit;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
  -ms-interpolation-mode: nearest-neighbor;
  image-rendering: -webkit-optimize-contrast;
  image-rendering: -moz-crisp-edges;
  image-rendering: -o-crisp-edges;
}

video {
  max-width: 100%;
  height: auto;
}

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

a:active,
a:hover {
  color: inherit;
  text-decoration: none;
}

ul,
ol,
li {
  list-style-type: none;
}

dl,
dt,
dd {
  margin: 0;
  padding: 0;
}

p {
  margin: 0;
  padding: 0;
}

img {
  border: 0;
  line-height: 0;
  vertical-align: bottom;
}

svg {
  vertical-align: bottom;
}

hr {
  display: none;
}

table {
  margin: 0;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
  margin: 0;
}

td {
  margin: 0;
}

em {
  font-weight: bold;
  font-style: normal;
}

form {
  margin: 0;
  padding: 0;
}

label {
  margin: 0;
  padding: 0;
}

input.btn {
  margin: 0 0.5em;
  padding: 0 1em;
}

button {
  border: none;
  font: inherit;
  line-height: inherit;
  background: none;
  margin: 0;
  color: #0f242f;
}

/* キーボード操作"以外"でフォーカスされた際はoutlineを消す */
.js-focus-visible :focus:not(.focus-visible) {
  outline: 0;
}

/*
l-header
-----------------------------------------------------*/
.l-header {
  width: 100%;
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
}

/*
l-footer
-----------------------------------------------------*/
.l-footer > small {
  padding: 0 clamp(25px, 14vw - 27.5px, 192px) clamp(90px, 5.03vw + 71.1px, 150px);
  font-size: 10px;
  display: block;
}
@media screen and (min-width: 1568px) {
  .l-footer > small {
    width: 100%;
    max-width: 1184px;
    margin: 0 auto;
    padding-left: 0;
    padding-right: 0;
  }
}

/*
l-wrapper
-----------------------------------------------------*/
.l-wrapper--top {
  width: 100%;
  max-width: 1568px;
  margin: 0 auto;
}
.l-wrapper--2column {
  width: 100%;
  max-width: 1568px;
  margin: 0 auto;
}
.l-wrapper--2column > h1 {
  padding-left: clamp(29px, 16.79vw - 33.9px, 95px);
  padding-right: clamp(29px, 16.79vw - 33.9px, 95px);
}
@media screen and (min-width: 768px) {
  .l-wrapper--2column > h1 {
    padding-left: clamp(43px, 5.78vw + 21.4px, 112px);
    padding-right: clamp(43px, 5.78vw + 21.4px, 112px);
  }
}
.l-wrapper--2column__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: clamp(25px, 6.29vw + 1.4px, 100px);
  gap: clamp(50px, 5.75vw + 5.8px, 96px);
  padding: 0 clamp(29px, 16.79vw - 33.9px, 95px);
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 768px) {
  .l-wrapper--2column__inner {
    padding: 0 clamp(43px, 5.78vw + 21.4px, 112px);
  }
}
@media screen and (min-width: 960px) {
  .l-wrapper--2column__inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.l-wrapper--2column__left {
  position: relative;
  width: 85%;
  margin: 0 auto;
  display: block;
}
@media screen and (min-width: 960px) {
  .l-wrapper--2column__left {
    width: clamp(109px, 14.37vw - 1.3px, 224px);
  }
}
.l-wrapper--2column__right {
  position: relative;
  width: 100%;
}
@media screen and (min-width: 960px) {
  .l-wrapper--2column__right {
    width: clamp(495px, 56.13vw + 63.9px, 944px);
  }
}
.l-wrapper--2column__right .l-wrapper__container2 {
  padding: 0 clamp(43px, 5.78vw + 21.4px, 112px);
}
@media screen and (min-width: 960px) {
  .l-wrapper--2column__right .l-wrapper__container2 {
    padding: 0;
  }
}
.l-wrapper--2column__sticky {
  position: sticky;
  display: block;
  top: 22%;
}
.l-wrapper--1column {
  width: 100%;
  max-width: 1568px;
  margin: 0 auto;
}
.l-wrapper--1column__inner {
  padding: 0 clamp(43px, 16.76vw - 19.8px, 243px);
}
.l-wrapper--1column.--large__inner {
  padding: 0 clamp(43px, 14.25vw - 10.4px, 213px);
}
.l-wrapper--1column-2 {
  width: 100%;
  max-width: 1568px;
  margin: 0 auto;
}
.l-wrapper--1column-2__inner {
  padding: 0 clamp(43px, 16.76vw - 19.8px, 243px);
}
@media screen and (min-width: 520px) {
  .l-wrapper--1column-2__inner {
    padding: 0 clamp(50px, 18.61vw - 19.8px, 272px);
  }
}
.l-wrapper--1column-h1 {
  padding-left: clamp(12px, 8.38vw - 19.4px, 112px);
  padding-right: clamp(12px, 8.38vw - 19.4px, 112px);
}
.l-wrapper__container {
  margin-bottom: clamp(100px, 4.19vw + 84.3px, 150px);
}
.l-wrapper__inner {
  margin-bottom: clamp(64px, 5.36vw + 44px, 128px);
}
.l-wrapper__inner-inner {
  margin-bottom: clamp(50px, 2.1vw + 42.1px, 75px);
}
.l-wrapper__banner {
  margin: 0 auto clamp(100px, 4.19vw + 84.3px, 150px);
  min-width: 352px;
  width: 60%;
}
@media screen and (min-width: 1280px) {
  .l-wrapper__banner {
    margin: 0 auto clamp(100px, 4.19vw + 84.3px, 150px);
  }
}
.l-wrapper__thumb > img {
  width: 100%;
  height: auto;
}

/*
l-spacer
-----------------------------------------------------*/
.l-spacer.-medium {
  padding-top: 100px;
}
.l-spacer.-small {
  padding-top: 3vw;
}
.l-spacer.-em1 {
  margin-top: 1em;
}
.l-spacer.-em2 {
  margin-top: 2em;
}
.l-spacer.-em3 {
  margin-top: 3em;
}

/*
l-main
-----------------------------------------------------*/
.l-main {
  position: relative;
}
.l-main.noScroll {
  overflow: hidden;
}
.l-main__BG--top {
  display: block;
  position: fixed;
  z-index: -1000;
  width: 100%;
  height: 100dvh;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-color: hsl(201, 100%, 89%);
  background-image: radial-gradient(at 53% 35%, hsl(341, 100%, 100%) 0px, transparent 50%), radial-gradient(at 1% 4%, hsl(320.73, 100%, 95.05%) 0px, transparent 50%), radial-gradient(at 98% 63%, hsl(237, 100%, 92%) 0px, transparent 50%), radial-gradient(at 88% 2%, hsl(0, 100%, 100%) 0px, transparent 50%), radial-gradient(at 18% 40%, hsl(0, 100%, 100%) 0px, transparent 50%);
  top: 0;
  left: 0;
  opacity: 0.8;
}
.l-main__BG--lower {
  display: block;
  position: fixed;
  z-index: -1000;
  width: 100%;
  height: 100dvh;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-color: hsl(201, 100%, 89%);
  background-image: radial-gradient(at 53% 35%, hsl(341, 100%, 100%) 0px, transparent 50%), radial-gradient(at 1% 4%, hsl(320.73, 100%, 95.05%) 0px, transparent 50%), radial-gradient(at 98% 63%, hsl(237, 100%, 92%) 0px, transparent 50%), radial-gradient(at 88% 2%, hsl(0, 100%, 100%) 0px, transparent 50%), radial-gradient(at 18% 40%, hsl(0, 100%, 100%) 0px, transparent 50%);
  top: 0;
  left: 0;
  opacity: 0.6;
}
.l-main__ito-bottom {
  position: absolute;
  display: block;
  width: clamp(193px, 19.95vw + 118.2px, 431px);
  height: clamp(222px, 23.13vw + 135.3px, 498px);
  background-image: url(../img/top/ito-bottom.svg);
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: contain;
  bottom: clamp(-340px, -10.73vw - 171.8px, -212px);
  left: clamp(-35px, -0.42vw - 28.4px, -30px);
  opacity: 0.2;
}
.l-main__ito-bottom--multi {
  mix-blend-mode: multiply;
}
.l-main__ito-bottom--burn {
  mix-blend-mode: color-burn;
}
.l-main__top-denpo > a {
  width: clamp(288px, 8.05vw + 257.8px, 384px);
  display: block;
  margin: 0 auto;
}
.l-main__top-denpo > a > figure {
  width: 100%;
  height: auto;
}
.l-main__top-denpo > a > figure > img {
  width: 100%;
  height: auto;
}

/*
l-nav
-----------------------------------------------------*/
/*
c-text
-----------------------------------------------------*/
.c-text {
  font-family: "Oxygen", "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.75;
  letter-spacing: 0.04em;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
}
.c-text--center {
  text-align: center;
}
.c-text--key2 {
  color: #b55975 !important;
}
.c-text--white {
  color: #fff !important;
}
.c-text--toph2-a {
  font-family: "Zen Old Mincho";
  line-height: 150%;
  font-size: clamp(26px, 1.59vw + 20.1px, 45px);
  white-space: nowrap;
}
.c-text--toph2-b {
  font-family: "Zen Old Mincho";
  line-height: 150%;
  font-size: clamp(30px, 2.26vw + 21.6px, 57px);
  text-align: left;
}
@media screen and (min-width: 768px) {
  .c-text--toph2-b {
    text-align: center;
  }
}
.c-text--toph2-footer {
  font-family: "Zen Old Mincho";
  line-height: 150%;
  font-size: clamp(30px, 2.26vw + 21.6px, 57px);
  text-align: center;
}
.c-text--toph2-b-lead {
  text-align: left;
}
@media screen and (min-width: 768px) {
  .c-text--toph2-b-lead {
    text-align: center;
  }
}
.c-text--toph2-c {
  font-family: "Zen Old Mincho";
  line-height: 150%;
  font-size: clamp(24px, 1.01vw + 20.2px, 36px);
  text-align: center;
}
.c-text--heading-decoration {
  font-family: "Cormorant Garamond", serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(12px, 0.34vw + 10.7px, 16px);
  line-height: 1.5;
  display: block;
  color: #137caf;
}
.c-text--lower-h1 {
  font-family: "Zen Old Mincho";
  font-size: clamp(30px, 1.51vw + 24.3px, 48px);
  font-weight: 500;
  line-height: 155%;
}
.c-text--lower-h1 > span {
  display: block;
  font-size: 0.625rem;
  line-height: 2em;
}
@media screen and (min-width: 520px) {
  .c-text--lower-h1 > span {
    font-size: clamp(12px, 0.66vw + 9.6px, 18px);
    line-height: 2em;
  }
}
.c-text--lower-h2 {
  font-family: "Zen Old Mincho";
  font-size: clamp(26px, 1.59vw + 20.1px, 45px);
  font-weight: 400;
  line-height: 150%;
  margin-bottom: clamp(25px, 3.27vw + 12.7px, 64px);
  letter-spacing: -0.02em;
}
.c-text--lower-lead {
  font-family: "Zen Old Mincho";
  font-size: clamp(23px, 0.75vw + 20.2px, 32px);
  font-weight: 400;
  line-height: 150%;
}
.c-text--lower-h3n {
  font-size: clamp(20px, 1.01vw + 16.2px, 32px);
  font-weight: 500;
  margin-bottom: clamp(2px, 0.34vw + 0.7px, 6px);
}
.c-text--lower-h3 {
  font-size: clamp(16px, 0.67vw + 13.5px, 24px);
  font-weight: 500;
  margin-bottom: clamp(25px, 0.59vw + 22.7px, 32px);
}
.c-text--lower-h4 {
  font-size: clamp(14px, 0.5vw + 12.2px, 20px);
  font-weight: 500;
  margin-bottom: clamp(18px, 0.5vw + 16.2px, 24px);
}
.c-text--small {
  font-size: 0.75rem;
}
.c-text--h1-area {
  font-size: clamp(16px, 0.34vw + 14.7px, 20px);
  font-weight: 500;
}
.c-text--h1-date {
  font-family: "Zen Old Mincho";
  font-size: clamp(12px, 0.34vw + 10.7px, 16px);
  margin-left: 0.4em;
}
.c-text--form-head {
  font-family: "Zen Old Mincho";
  font-size: clamp(18px, 0.84vw + 14.8px, 28px);
  font-weight: 400;
  line-height: 150%;
  margin-top: clamp(64px, 3.02vw + 52.6px, 100px);
  margin-bottom: 0.6em;
}
.c-text--mincho-h3 {
  font-family: "Zen Old Mincho";
  font-size: clamp(22px, 0.67vw + 19.5px, 30px);
  font-weight: 400;
  line-height: 150%;
  margin-bottom: 1.8em;
  text-align: center;
}

/*
c-button
-----------------------------------------------------*/
.c-button {
  display: block;
  background-color: #005e8b;
  border-radius: 4px;
  min-width: clamp(171px, 7.12vw + 144.4px, 256px);
  height: clamp(50px, 1.17vw + 45.7px, 64px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  z-index: 0;
}
.c-button:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  border-radius: 4px;
  z-index: -1;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
  background-image: linear-gradient(to right, #65accf, #005e8b);
  -webkit-box-shadow: 3px 3px 5px 0px rgba(0, 61, 90, 0.3);
          box-shadow: 3px 3px 5px 0px rgba(0, 61, 90, 0.3);
  opacity: 0;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.c-button > p {
  position: absolute;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 100%;
  top: 50%;
  left: 50%;
  text-align: center;
  width: 100%;
  color: #fff;
  font-weight: 500;
  line-height: 1.43;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
}
.c-button > p > span {
  display: block;
  font-size: 12px;
  line-height: 1.33;
}
.c-button--no-hover {
  display: block;
  background-color: #005e8b;
  border-radius: 4px;
  min-width: clamp(171px, 7.12vw + 144.4px, 256px);
  height: clamp(50px, 1.17vw + 45.7px, 64px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  z-index: 0;
}
.c-button--no-hover:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  border-radius: 4px;
  z-index: -1;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
  background-image: linear-gradient(to right, #65accf, #005e8b);
  -webkit-box-shadow: 3px 3px 5px 0px rgba(0, 61, 90, 0.3);
          box-shadow: 3px 3px 5px 0px rgba(0, 61, 90, 0.3);
  opacity: 0;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.c-button--no-hover > p {
  position: absolute;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 100%;
  top: 50%;
  left: 50%;
  text-align: center;
  width: 100%;
  color: #fff;
  font-weight: 500;
  line-height: 1.43;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
}
.c-button--no-hover > p > span {
  display: block;
  font-size: 12px;
  line-height: 1.33;
}
.c-button--width {
  width: clamp(208px, 14.75vw + 152.7px, 384px);
  margin-right: auto;
  margin-left: auto;
}
.c-button--width256-171 {
  width: clamp(171px, 7.12vw + 144.4px, 256px);
  margin-right: auto;
  margin-left: auto;
}
.c-button--width256 {
  width: 256px;
  margin-right: auto;
  margin-left: auto;
  max-width: 100%;
}
.c-button--width340 {
  width: 340px;
  margin-right: auto;
  margin-left: auto;
  max-width: 100%;
}
.c-button--hurry {
  position: relative;
  display: block;
  background-color: #982c4d;
  border-radius: 4px;
  min-width: clamp(171px, 7.12vw + 144.4px, 256px);
  width: clamp(171px, 7.12vw + 144.4px, 256px);
  height: clamp(50px, 1.17vw + 45.7px, 64px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  z-index: 0;
  margin-left: auto;
  margin-right: auto;
}
.c-button--hurry:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  border-radius: 4px;
  z-index: -1;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  background-image: -webkit-gradient(linear, left top, right top, from(#ff587f), to(#982c4d));
  background-image: linear-gradient(to right, #ff587f, #982c4d);
  -webkit-box-shadow: 3px 3px 5px 0px rgba(90, 0, 56, 0.3);
          box-shadow: 3px 3px 5px 0px rgba(90, 0, 56, 0.3);
  opacity: 0;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.c-button--hurry > p {
  width: 100%;
  color: #fff;
  font-weight: 500;
  text-align: center;
}
.c-button--hurry-head {
  position: relative;
  display: block;
  background-color: #982c4d;
  border-radius: 4px;
  height: clamp(50px, 1.17vw + 45.7px, 64px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  z-index: 0;
  margin-left: auto;
  margin-right: auto;
}
.c-button--hurry-head:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  border-radius: 4px;
  z-index: -1;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  background-image: -webkit-gradient(linear, left top, right top, from(#ff587f), to(#982c4d));
  background-image: linear-gradient(to right, #ff587f, #982c4d);
  -webkit-box-shadow: 3px 3px 5px 0px rgba(90, 0, 56, 0.3);
          box-shadow: 3px 3px 5px 0px rgba(90, 0, 56, 0.3);
  opacity: 0;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.c-button--hurry-head > p {
  width: 100%;
  color: #fff;
  font-weight: 500;
  text-align: center;
}
.c-button--secondary {
  position: relative;
  z-index: 0;
  border: 1px solid #005e8b;
  border-radius: 4px;
  background-color: #fff;
  min-width: clamp(171px, 7.12vw + 144.4px, 256px);
  height: clamp(50px, 1.17vw + 45.7px, 64px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
.c-button--secondary > p {
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  width: 100%;
  color: #005e8b;
  font-weight: 500;
  text-align: center;
}
.c-button--tertiary {
  position: relative;
  display: block;
  width: -webkit-fit-content !important;
  width: -moz-fit-content !important;
  width: fit-content !important;
}
.c-button--tertiary > p {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: block;
}
.c-button--tertiary:before, .c-button--tertiary:after {
  position: absolute;
  left: 0;
  content: "";
  width: 100%;
  height: 1px;
  background-color: #0f242f;
  bottom: -1px;
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.c-button--tertiary:before {
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
}
.c-button--kumotsu, .c-button--contact {
  position: relative;
  display: block;
  width: clamp(171px, 7.12vw + 144.4px, 256px);
  height: 50px;
  background-color: #005e8b;
  border-radius: 4px;
  z-index: 0;
}
.c-button--kumotsu:after, .c-button--contact:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  border-radius: 4px;
  z-index: -1;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
  background-image: linear-gradient(to right, #65accf, #005e8b);
  -webkit-box-shadow: 3px 3px 5px 0px rgba(0, 61, 90, 0.3);
          box-shadow: 3px 3px 5px 0px rgba(0, 61, 90, 0.3);
  opacity: 0;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.c-button--kumotsu > p, .c-button--contact > p {
  position: absolute;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 100%;
  top: 50%;
  left: 50%;
  text-align: center;
  color: #fff;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.43;
}
.c-button--kumotsu > p > span, .c-button--contact > p > span {
  display: block;
  font-size: 12px;
  line-height: 1.33;
}
.c-button--simulator-start {
  position: relative;
  display: block;
  background-color: #005e8b;
  border-radius: 4px;
  z-index: 0;
  cursor: pointer;
}
.c-button--simulator-start > span {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  border-radius: 4px;
  z-index: -1;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
  background-image: linear-gradient(to right, #65accf, #005e8b);
  -webkit-box-shadow: 3px 3px 5px 0px rgba(0, 61, 90, 0.3);
          box-shadow: 3px 3px 5px 0px rgba(0, 61, 90, 0.3);
  opacity: 0;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.c-button--simulator-start > p {
  position: absolute;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 100%;
  top: 50%;
  left: 50%;
  text-align: center;
  color: #fff;
  font-weight: 500;
  font-size: clamp(16px, 1.01vw + 12.2px, 28px);
  line-height: 1.5;
}
.c-button--simulator-start > p > span {
  display: block;
  font-size: 12px;
  line-height: 1.33;
}
.c-button--card {
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
}
.c-button--plan-card {
  -webkit-transition: all 0.25s ease-in-out;
  transition: all 0.25s ease-in-out;
}
.c-button--news-item {
  position: relative;
  display: block;
  width: -webkit-fit-content !important;
  width: -moz-fit-content !important;
  width: fit-content !important;
}
.c-button--news-item > p {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: block;
}
.c-button--news-item > p:after {
  position: absolute;
  left: 0;
  content: "";
  width: 100%;
  height: 1px;
  background-color: #0f242f;
  bottom: -0.1em;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: right top;
          transform-origin: right top;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.c-button--column-item {
  position: relative;
  display: block;
}
.c-button--column-item > p {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: block;
}
.c-button--column-item > p:after {
  position: absolute;
  left: 0;
  content: "";
  width: 100%;
  height: 1px;
  background-color: #0f242f;
  bottom: -0.1em;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: right top;
          transform-origin: right top;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.c-button--column-item > figure > img {
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
.c-button--nav {
  position: relative;
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.c-button--nav:after {
  position: absolute;
  left: 0;
  content: "";
  width: 100%;
  height: 1px;
  background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
  background-image: linear-gradient(to right, #65accf, #005e8b);
  bottom: 7px;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: right top;
          transform-origin: right top;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.c-button--banner {
  -webkit-transition: opacity 0.2s ease-in-out;
  transition: opacity 0.2s ease-in-out;
}
.c-button--external > p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.3em;
}
.c-button--external > p:after {
  content: "";
  display: block;
  width: clamp(14px, 0.17vw + 13.3px, 16px);
  height: clamp(14px, 0.17vw + 13.3px, 16px);
  background-image: url(../img/common/external-link.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

@media (hover: hover) {
  .c-button:hover:after,
  .c-button--kumotsu:hover:after,
  .c-button--contact:hover:after,
  .c-button--hurry:hover:after,
  .c-button--hurry-head:hover:after,
  .c-button--hallcard:hover:before,
  .c-button--simulator-start:hover > span {
    opacity: 1;
    width: 100.5%;
    height: 100.5%;
  }
  .c-button--secondary:hover {
    scale: 1.005;
    -webkit-box-shadow: 3px 3px 5px 0px rgba(0, 61, 90, 0.3);
            box-shadow: 3px 3px 5px 0px rgba(0, 61, 90, 0.3);
  }
  .c-button--tertiary:hover {
    color: #005e8b;
  }
  .c-button--tertiary:hover:before {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transition: -webkit-transform 0 ease-out;
    transition: -webkit-transform 0 ease-out;
    transition: transform 0 ease-out;
    transition: transform 0 ease-out, -webkit-transform 0 ease-out;
    background-color: none;
    background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
    background-image: linear-gradient(to right, #65accf, #005e8b);
  }
  .c-button--tertiary:hover:after {
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform 0 ease-out;
    transition: -webkit-transform 0 ease-out;
    transition: transform 0 ease-out;
    transition: transform 0 ease-out, -webkit-transform 0 ease-out;
    background-color: none;
    background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
    background-image: linear-gradient(to right, #65accf, #005e8b);
  }
  .c-button--news-item:hover > p {
    color: #005e8b;
  }
  .c-button--news-item:hover > p:after {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transition: -webkit-transform 0 ease-out;
    transition: -webkit-transform 0 ease-out;
    transition: transform 0 ease-out;
    transition: transform 0 ease-out, -webkit-transform 0 ease-out;
    background-color: none;
    background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
    background-image: linear-gradient(to right, #65accf, #005e8b);
  }
  .c-button--column-item:hover > figure > img {
    scale: 1.015;
  }
  .c-button--column-item:hover > p {
    color: #005e8b;
  }
  .c-button--column-item:hover > p:after {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transition: -webkit-transform 0 ease-out;
    transition: -webkit-transform 0 ease-out;
    transition: transform 0 ease-out;
    transition: transform 0 ease-out, -webkit-transform 0 ease-out;
    background-color: none;
    background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
    background-image: linear-gradient(to right, #65accf, #005e8b);
  }
  .c-button--banner:hover {
    opacity: 0.7;
  }
  .c-button--card:hover {
    scale: 1.01;
    -webkit-box-shadow: 1px 1px 10px 0px rgba(0, 61, 90, 0.15);
            box-shadow: 1px 1px 10px 0px rgba(0, 61, 90, 0.15);
  }
  .c-button--plan-card:hover {
    scale: 1.01;
  }
  .c-button--plan-card:hover > a > div.c-button--no-hover:after {
    opacity: 1;
    width: 100.5%;
    height: 100.5%;
  }
  .c-button--nav:hover {
    color: #005e8b;
  }
  .c-button--nav:hover:after {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: left top;
            transform-origin: left top;
  }
}
/*
c-tag
-----------------------------------------------------*/
.c-tag--family {
  height: 24px;
  border-radius: 99px;
  padding: 2px 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: 500;
  letter-spacing: 0.01em;
  line-height: 1.5em;
  border: 1px solid #295818;
  color: #295818;
  font-size: 0.625rem;
}
@media screen and (min-width: 960px) {
  .c-tag--family {
    font-size: 0.75rem;
  }
}
.c-tag--general {
  height: 24px;
  border-radius: 99px;
  padding: 2px 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: 500;
  letter-spacing: 0.01em;
  line-height: 1.5em;
  border: 1px solid #57387f;
  color: #57387f;
  font-size: 0.625rem;
}
@media screen and (min-width: 960px) {
  .c-tag--general {
    font-size: 0.75rem;
  }
}
.c-tag--large {
  height: 24px;
  border-radius: 99px;
  padding: 2px 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: 500;
  letter-spacing: 0.01em;
  line-height: 1.5em;
  border: 1px solid #732a0b;
  color: #732a0b;
  font-size: 0.625rem;
}
@media screen and (min-width: 960px) {
  .c-tag--large {
    font-size: 0.75rem;
  }
}

/*
c-spacer
-----------------------------------------------------*/
.c-spacer--32 {
  margin-top: 32px;
}
.c-spacer--50 {
  margin-top: 50px;
}
.c-spacer--1em {
  margin-top: 1em;
}
.c-spacer--1o5em {
  margin-top: 1.5em;
}
.c-spacer--32-25 {
  margin-top: clamp(25px, 0.59vw + 22.7px, 32px) !important;
}
.c-spacer--48-32 {
  margin-top: clamp(32px, 1.34vw + 27px, 48px) !important;
}
.c-spacer--64-50 {
  margin-top: clamp(50px, 1.17vw + 45.7px, 64px) !important;
}
.c-spacer--72-32 {
  margin-top: clamp(32px, 3.35vw + 19.5px, 72px) !important;
}
.c-spacer--80-62 {
  margin-top: clamp(62px, 1.51vw + 56.3px, 80px);
}
.c-spacer--128-64 {
  margin-top: clamp(64px, 5.36vw + 44px, 128px);
}
.c-spacer--100-50 {
  margin-top: clamp(50px, 4.19vw + 34.3px, 100px);
}
.c-spacer--100-25 {
  margin-top: clamp(25px, 6.29vw + 1.4px, 100px);
}
.c-spacer--126-50 {
  margin-top: clamp(50px, 6.37vw + 26.1px, 126px);
}
.c-spacer--126-50-32 {
  margin-top: clamp(32px, 3.08vw + 20.4px, 50px);
}
@media screen and (min-width: 960px) {
  .c-spacer--126-50-32 {
    margin-top: clamp(50px, 6.37vw + 26.1px, 126px);
  }
}
.c-spacer--191-145 {
  margin-top: clamp(145px, 3.86vw + 130.5px, 191px);
}

/*
c-br
-----------------------------------------------------*/
@media screen and (min-width: 520px) {
  .c-br--wsp {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .c-br--tab {
    display: none;
  }
}
.c-br--tab-r {
  display: none;
}
@media screen and (min-width: 768px) {
  .c-br--tab-r {
    display: block;
  }
}
.c-br--lap-desk {
  display: none;
}
@media screen and (min-width: 960px) {
  .c-br--lap-desk {
    display: block;
  }
}
@media screen and (min-width: 1280px) {
  .c-br--lap-desk {
    display: none;
  }
}

/*
c-
-----------------------------------------------------*/
#mask .ito_mask {
  fill: none;
  stroke: #fff;
  stroke-width: 90; /*線の太さを指定する*/
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-miterlimit: 10;
  stroke-dasharray: 1500; /* 線の間隔を指定する */
  stroke-dashoffset: 1500; /* 線の位置を指定する */
}

/*
c-select-category
-----------------------------------------------------*/
.c-select-category {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border-radius: 4px;
  width: 100%;
  height: clamp(50px, 1.17vw + 45.7px, 64px);
  border: none;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  background-color: #fff;
  padding: clamp(16px, 0.17vw + 15.3px, 18px) clamp(30px, 0.17vw + 29.3px, 32px);
}
.c-select-category:-ms-expand {
  display: none;
}
.c-select-category__container--sp {
  position: relative;
  margin: clamp(25px, 6.29vw + 1.4px, 100px) clamp(43px, 5.78vw + 21.4px, 112px);
}
@media screen and (min-width: 960px) {
  .c-select-category__container--sp {
    display: none;
  }
}
.c-select-category__container--pc {
  position: relative;
  display: none;
  margin-top: 0.5em;
}
@media screen and (min-width: 960px) {
  .c-select-category__container--pc {
    display: block;
    margin-top: 0.5em;
  }
}
.c-select-category__v {
  position: absolute;
  display: block;
  top: 43%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 32px;
  background-image: url(../img/common/>.svg);
  width: 8px;
  height: 8px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  rotate: 90deg;
}

/*
c-list
-----------------------------------------------------*/
.c-list-dot {
  font-size: clamp(14px, 0.14vw + 13.3px, 16px);
  padding-left: 1.2em;
  position: relative;
}
.c-list-dot__item {
  line-height: 1.6;
  position: relative;
}
.c-list-dot__item::before {
  content: "";
  display: block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: #0f242f;
  position: absolute;
  left: -0.8em;
  line-height: 0;
  top: 0.8em;
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.c-list-dot__item:not(:last-child) {
  margin-bottom: 0.6em;
}
.c-list--dot-bold {
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  padding-left: 1.6em;
  position: relative;
}
.c-list--dot-bold__item {
  line-height: 1.6;
  position: relative;
}
.c-list--dot-bold__item::before {
  content: "";
  display: block;
  width: 1em;
  height: 1em;
  border-radius: 50%;
  background-image: url(../img/common/check.svg);
  background-size: contain;
  background-position: center;
  position: absolute;
  left: -1.5em;
  line-height: 0;
  top: 0.8em;
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.c-list--dot-bold__item:not(:last-child) {
  margin-bottom: 1em;
}
.c-list-num {
  padding-left: 1.5em;
  counter-reset: listnum;
}
.c-list-num__item {
  line-height: 1.6;
  counter-increment: listnum;
}
.c-list-num__item::before {
  content: counter(listnum) ".";
  margin-left: -1.5em;
  display: inline-block;
  width: 1.5em;
}
.c-list-num__item:not(:last-child) {
  margin-bottom: 1.2em;
}
.c-list-kome {
  padding-left: 1.5em;
  counter-reset: listnum;
}
.c-list-kome__item {
  line-height: 1.6;
  counter-increment: listnum;
}
.c-list-kome__item::before {
  content: "＊";
  margin-left: -1.5em;
  display: inline-block;
  width: 1.5em;
  font-size: clamp(10px, 0.14vw + 9.3px, 12px);
}
.c-list-kome__item:not(:last-child) {
  margin-bottom: 1.2em;
}
.c-list-dl-dot {
  font-size: clamp(14px, 0.14vw + 13.3px, 16px);
}
.c-list-dl-dot > div > dt {
  margin-top: clamp(24px, 1.01vw + 20.2px, 36px);
  margin-bottom: clamp(8px, 0.34vw + 6.7px, 12px);
  font-weight: 500;
  line-height: 1.6;
  position: relative;
  padding-left: clamp(17px, 0.42vw + 15.4px, 22px);
}
.c-list-dl-dot > div > dt:before {
  content: "";
  width: clamp(11px, 0.42vw + 9.4px, 16px);
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: #003d5a;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.c-list-dl-dot > div > dd {
  line-height: 1.6;
}

/*
c-chatbot
-----------------------------------------------------*/
.mwai-icon {
  opacity: 0;
  height: clamp(88px, 1.01vw + 84.2px, 100px);
  width: clamp(88px, 1.01vw + 84.2px, 100px);
  -webkit-transition: all 0.4s ease-out;
  transition: all 0.4s ease-out;
}

.mwai-chatgpt-theme.mwai-window.mwai-bottom-left {
  bottom: 64px !important;
  left: clamp(11px, 7.12vw - 15.6px, 96px) !important;
}
@media screen and (min-width: 768px) {
  .mwai-chatgpt-theme.mwai-window.mwai-bottom-left {
    bottom: 32px !important;
    left: 32px !important;
  }
}

/*
p-footer
-----------------------------------------------------*/
.p-footer {
  padding: clamp(75px, 2.1vw + 67.1px, 100px) clamp(25px, 14vw - 27.5px, 192px);
}
.p-footer__head-banner-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
  margin-bottom: 64px;
}
@media screen and (min-width: 768px) {
  .p-footer__head-banner-container {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 24px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.p-footer__banner-ambassador {
  position: relative !important;
  width: 100%;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
@media screen and (min-width: 768px) {
  .p-footer__banner-ambassador {
    width: clamp(306px, 37.89vw + 15px, 500px);
  }
}
@media screen and (min-width: 1280px) {
  .p-footer__banner-ambassador {
    width: clamp(306px, 13.75vw + 200.4px, 416px);
  }
}
.p-footer__banner-ambassador > figure {
  width: 100%;
  height: auto;
  aspect-ratio: 416/168;
}
.p-footer__banner-ambassador > figure:after {
  width: 100%;
  height: auto;
  aspect-ratio: 416/168;
}
.p-footer__banner-ambassador > figure > img {
  width: 100%;
  height: auto;
}
.p-footer__banner-ambassodor-text {
  -webkit-transform-origin: left bottom;
          transform-origin: left bottom;
  scale: 0.75;
}
@media screen and (min-width: 450px) {
  .p-footer__banner-ambassodor-text {
    scale: 0.9;
  }
}
@media screen and (min-width: 520px) {
  .p-footer__banner-ambassodor-text {
    scale: 1;
  }
}
@media screen and (min-width: 600px) {
  .p-footer__banner-ambassodor-text {
    scale: 1.2;
  }
}
@media screen and (min-width: 768px) {
  .p-footer__banner-ambassodor-text {
    scale: 0.73;
  }
}
@media screen and (min-width: 960px) {
  .p-footer__banner-ambassodor-text {
    scale: 1;
  }
}
.p-footer__banner-denpo {
  width: 100%;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
@media screen and (min-width: 768px) {
  .p-footer__banner-denpo {
    width: clamp(283px, 30.86vw + 46px, 441px);
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content;
  }
}
@media screen and (min-width: 1280px) {
  .p-footer__banner-denpo {
    width: clamp(283px, 57.63vw - 159.6px, 744px);
  }
}
.p-footer__banner-denpo > figure {
  width: 100%;
}
.p-footer__banner-denpo > figure > img {
  width: 100%;
  height: auto;
}
.p-footer__container {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (auto)[2];
  grid-template-columns: repeat(2, auto);
  -ms-grid-rows: (auto)[3];
  grid-template-rows: repeat(3, auto);
  max-width: 1184px;
  margin: 0 auto;
}
.p-footer__container > *:nth-child(1) {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
}
.p-footer__container > *:nth-child(2) {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
}
.p-footer__container > *:nth-child(3) {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
}
.p-footer__container > *:nth-child(4) {
  -ms-grid-row: 2;
  -ms-grid-column: 2;
}
.p-footer__container > *:nth-child(5) {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
}
.p-footer__container > *:nth-child(6) {
  -ms-grid-row: 3;
  -ms-grid-column: 2;
}
@media screen and (min-width: 1280px) {
  .p-footer__container {
    -ms-grid-columns: (auto)[3];
    grid-template-columns: repeat(3, auto);
    -ms-grid-rows: (auto)[2];
    grid-template-rows: repeat(2, auto);
  }
  .p-footer__container > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-footer__container > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .p-footer__container > *:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-footer__container > *:nth-child(4) {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .p-footer__container > *:nth-child(5) {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-footer__container > *:nth-child(6) {
    -ms-grid-row: 2;
    -ms-grid-column: 3;
  }
}
.p-footer__inner-A {
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
  grid-area: 1/1/2/2;
}
.p-footer__inner-A > figure {
  width: clamp(125px, 13.33vw + 75px, 284px);
  height: auto;
}
.p-footer__inner-A > figure > img {
  width: 100%;
  height: auto;
}
.p-footer__inner-A > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: clamp(125px, 13.33vw + 75px, 284px);
  margin-top: clamp(19px, 0.75vw + 16.2px, 28px);
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 8px;
}
@media screen and (min-width: 1280px) {
  .p-footer__inner-A > div {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.p-footer__inner-A > div > a {
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
@media screen and (min-width: 1280px) {
  .p-footer__inner-A > div > a {
    width: 49%;
  }
}
.p-footer__inner-A > div > a > figure {
  width: 100%;
  height: auto;
  position: relative;
}
.p-footer__inner-A > div > a > figure > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
.p-footer__inner-A > div > a:first-child > figure {
  aspect-ratio: 145/69;
}
.p-footer__inner-A > div > a:last-child > figure {
  aspect-ratio: 143/41;
}
.p-footer__inner-B {
  -ms-grid-row: 2;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
  grid-area: 2/1/3/2;
  margin-top: 28px;
}
@media screen and (min-width: 1280px) {
  .p-footer__inner-B {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-area: 1/3/3/4;
    margin-top: 0;
    width: 120px;
    margin-left: auto;
    margin-right: 0;
  }
}
.p-footer__inner-B > ul:last-child {
  margin-top: 1.6em;
}
.p-footer__inner-C--sp {
  -ms-grid-row: 1;
  -ms-grid-row-span: 2;
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  grid-area: 1/2/3/3;
  margin-left: 2em;
  margin-top: -0.9em;
}
@media screen and (min-width: 1280px) {
  .p-footer__inner-C--sp {
    display: none;
  }
}
.p-footer__inner-C--pc {
  display: none;
}
@media screen and (min-width: 1280px) {
  .p-footer__inner-C--pc {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 1/2/3/3;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    gap: 32px;
    gap: clamp(24px, 2.78vw - 11.6px, 32px);
    margin-right: -120px;
    margin-right: clamp(-120px, -6.94vw - 11.2px, -100px);
  }
}
.p-footer__inner-C--pc > ul:nth-child(2) {
  margin-left: 20px;
}
.p-footer__inner-D {
  -ms-grid-row: 3;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  grid-area: 3/1/4/3;
  margin-top: clamp(64px, 0.92vw + 60.6px, 75px);
}
@media screen and (min-width: 1280px) {
  .p-footer__inner-D {
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-area: 2/1/3/2;
  }
}
.p-footer__inner-D > p:first-child {
  font-size: clamp(16px, 0.34vw + 14.7px, 20px);
  font-weight: 500;
}
.p-footer__inner-D > p:last-child {
  font-size: clamp(12px, 0.17vw + 11.3px, 14px);
  margin-top: 1.5em;
}
.p-footer__list-1 {
  font-weight: 500;
  line-height: 280%;
  font-size: clamp(10px, 0.34vw + 8.7px, 14px);
}
@media screen and (min-width: 1280px) {
  .p-footer__list-1 {
    line-height: 240%;
    font-weight: 400;
  }
}
.p-footer__list-2 {
  font-size: clamp(12px, 0.34vw + 10.7px, 16px);
  font-weight: 500;
  line-height: 284%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: clamp(0px, 1.55vw - 5.8px, 14px);
}
@media screen and (min-width: 1280px) {
  .p-footer__list-2 {
    gap: 0;
  }
}
.p-footer__list-3 {
  margin-left: 1em;
  line-height: 260%;
  font-size: clamp(12px, 0.34vw + 10.7px, 16px);
  font-weight: 400;
}
.p-footer__item-2 > a, .p-footer__item-3 > a {
  display: block;
}
.p-footer__banner-zengo {
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}

@media (hover: hover) {
  .p-footer__banner-ambassador:hover {
    scale: 1.01;
  }
  .p-footer__banner-ambassador:hover > figure > div.c-button--no-hover:after {
    opacity: 1;
    width: 100.5%;
    height: 100.5%;
  }
  .p-footer__banner-denpo:hover {
    scale: 1.01;
    opacity: 0.8;
  }
  .p-footer__banner-zengo:hover {
    scale: 1.01;
    opacity: 0.8;
  }
}
/*
p-header-pc
-----------------------------------------------------*/
.p-header-pc {
  display: none;
  background-color: inherit;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
  position: relative;
}
@media screen and (min-width: 1280px) {
  .p-header-pc {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    z-index: 100;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: 100%;
    padding: clamp(11px, 1.17vw + 6.7px, 25px) clamp(16px, 1.34vw + 11px, 32px) 16px;
  }
  .p-header-pc:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    z-index: -1;
    background-color: inherit;
    opacity: 0;
    -webkit-transition: all 0.3s ease-out;
    transition: all 0.3s ease-out;
  }
}
.p-header-pc.scroll {
  visibility: hidden;
  opacity: 0;
  height: 0;
}
.p-header-pc.scroll.up {
  visibility: visible;
  opacity: 1;
  height: auto;
}
.p-header-pc.scroll.up:after {
  background-color: #fff;
  mix-blend-mode: screen;
  opacity: 0.8;
}
.p-header-pc__logo {
  width: clamp(167px, 10.9vw + 126.1px, 297px);
}
.p-header-pc__logo > a > p {
  font-size: clamp(10px, 0.5vw + 8.2px, 16px);
  white-space: nowrap;
}
.p-header-pc__logo > a > img {
  width: 100%;
  height: auto;
}

/*
p-header-sp
-----------------------------------------------------*/
.p-header-sp {
  position: relative;
  width: 100%;
}
@media screen and (min-width: 1280px) {
  .p-header-sp {
    display: none;
  }
}
.p-header-sp__front {
  position: relative;
  z-index: 1000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: clamp(11px, 1.17vw + 6.7px, 25px) clamp(12px, 1.68vw + 5.7px, 32px);
}
.p-header-sp__front-logo {
  width: clamp(167px, 9.81vw + 130.2px, 284px);
  opacity: 0;
  -webkit-transition: all 0.4s ease-out;
  transition: all 0.4s ease-out;
  display: block;
  pointer-events: none;
}
.p-header-sp__front-logo.active {
  opacity: 1;
  pointer-events: auto;
}
.p-header-sp__front-logo > a > p {
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
  font-size: 0.625rem;
  letter-spacing: -0.02em;
  white-space: nowrap;
}
.p-header-sp__front-button-container {
  height: 50px;
  position: fixed;
  right: clamp(12px, 1.68vw + 5.7px, 32px);
}
.p-header-sp__front-button {
  display: block;
  position: relative;
  width: 38px;
  height: 100%;
  cursor: pointer;
}
.p-header-sp__front-button-line {
  display: block;
  height: 2px;
  position: absolute;
  top: 19px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 32px;
  background-color: #0f242f;
  -webkit-transition: 0.4s all ease-out;
  transition: 0.4s all ease-out;
}
.p-header-sp__front-button-line:before, .p-header-sp__front-button-line:after {
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  width: 100%;
  background-color: #0f242f;
  -webkit-transition: inherit;
  transition: inherit;
}
.p-header-sp__front-button-line:before {
  top: -8px;
}
.p-header-sp__front-button-line:after {
  top: 8px;
}
.p-header-sp__front-button-line.active {
  background-color: transparent;
}
.p-header-sp__front-button-line.active:before {
  top: 0;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.p-header-sp__front-button-line.active:after {
  top: 0;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.p-header-sp__front-button-text {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  font-size: 0.625rem;
  white-space: nowrap;
  letter-spacing: -0.08em;
  font-weight: 500;
  top: 36px;
}
.p-header-sp__menu-BGbase {
  display: block;
  position: fixed;
  z-index: -1000;
  width: 100%;
  height: 100lvh;
  background-color: hsl(201, 100%, 89%);
  background-image: radial-gradient(at 53% 35%, hsl(341, 100%, 100%) 0px, transparent 50%), radial-gradient(at 1% 4%, hsl(320.73, 100%, 95.05%) 0px, transparent 50%), radial-gradient(at 98% 63%, hsl(237, 100%, 92%) 0px, transparent 50%), radial-gradient(at 88% 2%, hsl(0, 100%, 100%) 0px, transparent 50%), radial-gradient(at 18% 40%, hsl(0, 100%, 100%) 0px, transparent 50%);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  top: 0;
  left: 0;
}
.p-header-sp__menu-BG {
  display: block;
  position: fixed;
  width: 100%;
  height: 120vh;
  z-index: -900;
  top: -20vh;
  left: 0;
  background-color: #65accf;
  mix-blend-mode: screen;
}
.p-header-sp__menu {
  visibility: hidden;
  opacity: 0;
  height: 0;
  padding-bottom: 50px;
  position: absolute;
  z-index: 100;
  -webkit-transition: all 0.4s ease-out;
  transition: all 0.4s ease-out;
}
.p-header-sp__menu.active {
  visibility: visible;
  opacity: 1;
  height: calc(100vh - 120px);
  width: 100%;
  overflow-y: scroll;
  overscroll-behavior-y: contain;
}
.p-header-sp__menu-inner {
  display: block;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
.p-header-sp__menu-list {
  padding: 36px clamp(12px, 1.01vw + 8.2px, 24px) 0;
}
.p-header-sp__menu-item {
  width: 100%;
  position: relative;
  font-size: 1rem;
  line-height: 175%;
  font-weight: 500;
}
.p-header-sp__menu-item > a {
  display: block;
  width: 100%;
  height: 100%;
  padding: clamp(16px, 1.34vw + 11px, 32px) clamp(18px, 1.51vw + 12.3px, 36px);
}
.p-header-sp__menu-item:before, .p-header-sp__menu-item:after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  bottom: 0;
  left: 0;
}
.p-header-sp__menu-item:before {
  mix-blend-mode: color-burn;
}
.p-header-sp__menu-item:after {
  mix-blend-mode: multiply;
}
.p-header-sp__menu-item-button {
  position: relative;
  text-align: left;
  padding: clamp(16px, 1.34vw + 11px, 32px) clamp(18px, 1.51vw + 12.3px, 36px) clamp(20px, 1.34vw + 15px, 36px);
  width: 100%;
}
.p-header-sp__menu-item-button > span {
  display: block;
  position: absolute;
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
          transform: translate(-50%, -50%) rotate(90deg);
  top: 50%;
  -webkit-transform-origin: center center;
          transform-origin: center center;
  right: clamp(16px, 1.34vw + 11px, 32px);
  background-image: url(../img/common/>.svg);
  width: 12px;
  height: 12px;
  background-repeat: no-repeat;
  background-size: contain;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
.p-header-sp__menu-item-button.active > span {
  -webkit-transform: translate(-50%, -50%) rotate(-90deg);
          transform: translate(-50%, -50%) rotate(-90deg);
  right: clamp(16px, 1.34vw + 11px, 32px);
}
.p-header-sp__sub-list-container {
  visibility: hidden;
  text-align: left;
  padding: 0 clamp(18px, 1.51vw + 12.3px, 36px);
  margin-bottom: 0;
  height: 0;
  opacity: 0;
  width: 100%;
  -webkit-transition: opacity 0.2s ease-out, height 0.4s ease-out;
  transition: opacity 0.2s ease-out, height 0.4s ease-out;
}
.p-header-sp__sub-list-container.active {
  visibility: visible;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  opacity: 1;
  padding-bottom: clamp(24px, 0.67vw + 21.5px, 32px);
}
.p-header-sp__sub-list-h4 {
  margin-bottom: 1.5em;
  font-weight: 400;
  font-size: 14;
  text-decoration: underline;
  text-underline-offset: 0.3em;
  text-decoration-thickness: 1px;
}
.p-header-sp__sub-list-h5 {
  font-size: 0.75rem;
}
.p-header-sp__sub-list {
  padding-left: clamp(40px, 2.01vw + 32.5px, 64px);
  margin-top: 13px;
  padding-bottom: 11px;
}
.p-header-sp__sub-item {
  padding-bottom: 16px;
}
.p-header-sp__sub-item > a {
  display: block;
  width: 100%;
}
.p-header-sp__button-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 16px clamp(12px, 1.01vw + 8.2px, 24px) 0;
  gap: 8px;
}
.p-header-sp__info-list {
  padding: 50px clamp(52px, 1.01vw + 48.2px, 64px) 0;
}
.p-header-sp__info-item {
  font-size: 0.75rem;
  line-height: 280%;
  letter-spacing: 0.125em;
}
.p-header-sp__BGcontainer {
  visibility: hidden;
  opacity: 0;
  height: 0;
  -webkit-transition: 0.4s opacity ease-out;
  transition: 0.4s opacity ease-out;
  z-index: -100;
}
.p-header-sp__BGcontainer.active {
  visibility: visible;
  opacity: 1;
  height: 100lvh;
}
.p-header-sp__simulator {
  width: 100%;
  position: relative;
}
@media screen and (min-width: 520px) {
  .p-header-sp__simulator {
    max-width: 375px;
  }
}
.p-header-sp__simulator > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 64px;
  background-color: #dbeff8;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
  font-size: 1.125rem;
  font-family: "Zen Old Mincho";
  padding-left: clamp(0px, -11.03vw + 57.4px, 16px);
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 520px) {
  .p-header-sp__simulator > a {
    height: 100px;
    font-size: 1.25rem;
  }
}
.p-header-sp__simulator::before {
  content: "";
  display: block;
  position: absolute;
  background-image: url(../img/simulator/simu-character.webp);
  height: 55px;
  width: 55px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  bottom: 0;
  left: 37px;
}
@media screen and (min-width: 520px) {
  .p-header-sp__simulator::before {
    height: 75px;
    width: 75px;
    left: 20px;
  }
}

/*
p-top-mainvisial
-----------------------------------------------------*/
.p-top-mainvisual {
  position: relative;
  overflow: hidden;
  height: clamp(465px, 58.52vw + 245.6px, 695px);
}
@media screen and (min-width: 768px) {
  .p-top-mainvisual {
    height: clamp(465px, 17.6vw + 399px, 675px);
  }
}
.p-top-mainvisual > figure {
  position: absolute;
  display: block;
}
.p-top-mainvisual > figure > img {
  width: 100%;
  height: auto;
}
.p-top-mainvisual__new {
  height: clamp(614px, 29.52vw + 503.3px, 730px);
}
@media screen and (min-width: 768px) {
  .p-top-mainvisual__new {
    height: clamp(640px, 11.5vw + 551.7px, 732px);
  }
}
.p-top-mainvisual__mv-clip {
  z-index: -1;
}
.p-top-mainvisual__mv-ito {
  z-index: -2;
  rotate: 5deg;
  width: clamp(545px, 54.9vw + 339.2px, 1200px);
  height: clamp(500px, 50.96vw + 308.9px, 1108px);
  left: clamp(-90px, 32.69vw - 212.6px, 300px);
  top: clamp(-100px, -9.56vw + 49.9px, 14px);
  pointer-events: none;
  -webkit-transition: opacity 3.5s ease-out;
  transition: opacity 3.5s ease-out;
  opacity: 0;
}
@media screen and (min-width: 768px) {
  .p-top-mainvisual__mv-ito {
    rotate: -2deg;
  }
}
.p-top-mainvisual__mv-ito.burn {
  mix-blend-mode: color-burn;
}
.p-top-mainvisual__mv-ito.burn.active {
  opacity: 0.4;
}
.p-top-mainvisual__mv-ito.multi {
  mix-blend-mode: multiply;
}
.p-top-mainvisual__mv-ito.multi.active {
  opacity: 0.2;
  -webkit-transition: opacity 3.5s ease-out;
  transition: opacity 3.5s ease-out;
}
.p-top-mainvisual__mv-ito > svg {
  width: 100%;
  height: auto;
}
.p-top-mainvisual__mv {
  z-index: -3;
}
.p-top-mainvisual__mv-clip, .p-top-mainvisual__mv {
  width: clamp(600px, 81.14vw + 295.7px, 1568px);
  left: clamp(-150px, 12.57vw - 197.1px, 0px);
  top: clamp(0px, 1.84vw - 6.9px, 22px);
  pointer-events: none;
  -webkit-transition: opacity 3s ease-out;
  transition: opacity 3s ease-out;
  opacity: 0;
}
.p-top-mainvisual__mv-clip.active, .p-top-mainvisual__mv.active {
  opacity: 1;
  -webkit-transition: opacity 3s ease-out;
  transition: opacity 3s ease-out;
}
.p-top-mainvisual__h1 {
  font-weight: 500;
  line-height: 150%;
  font-size: clamp(12px, 0.34vw + 10.7px, 16px);
  margin-left: clamp(18px, 12.32vw - 28.2px, 165px);
  margin-top: clamp(305px, 41.48vw + 149.4px, 468px);
  pointer-events: none;
  -webkit-transition: opacity 3s ease-out;
  transition: opacity 3s ease-out;
  opacity: 0;
}
.p-top-mainvisual__h1.active {
  opacity: 1;
  -webkit-transition: opacity 3s ease-out;
  transition: opacity 3s ease-out;
}
@media screen and (min-width: 768px) {
  .p-top-mainvisual__h1 {
    margin-top: 349px;
  }
}
.p-top-mainvisual__h1 > img {
  width: clamp(317px, 34.2vw + 188.7px, 725px);
  height: auto;
}
.p-top-mainvisual__h1 > p {
  margin-top: clamp(18px, 1.17vw + 13.7px, 32px);
}
.p-top-mainvisual__button {
  width: clamp(192px, 2.68vw + 182px, 224px);
  margin-top: clamp(20px, 2.51vw + 10.6px, 50px);
  margin-left: clamp(18px, 12.32vw - 28.2px, 165px);
  z-index: 10;
  pointer-events: initial;
  -webkit-transition: opacity 1s ease-out;
  transition: opacity 1s ease-out;
  opacity: 0;
}
@media screen and (min-width: 768px) {
  .p-top-mainvisual__button {
    margin-top: clamp(20px, 3.75vw - 8.8px, 50px);
  }
}
.p-top-mainvisual__button.active {
  opacity: 1;
  -webkit-transition: opacity 3s ease-out;
  transition: opacity 3s ease-out;
}
.p-top-mainvisual__visually-hidden {
  visibility: hidden;
  position: absolute;
  width: 0;
  height: 0;
}

/*
p-top-plan
-----------------------------------------------------*/
.p-top-plan {
  position: relative;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  margin: 0 clamp(11px, 7.12vw - 15.6px, 96px);
  padding: clamp(30px, 2.85vw + 19.3px, 64px) clamp(16px, 6.71vw - 9.2px, 96px) clamp(75px, 2.1vw + 67.1px, 100px);
  display: block;
}
.p-top-plan::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: -1;
  background-color: #fff;
  mix-blend-mode: screen;
  opacity: 0.8;
  border-radius: 8px;
}
.p-top-plan__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: clamp(28px, 1.84vw + 21.1px, 50px);
}
@media screen and (min-width: 1280px) {
  .p-top-plan__head {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: clamp(90px, 3.94vw + 75.2px, 137px);
  }
}
.p-top-plan__card-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 16px;
  margin-top: 50px;
}
@media screen and (min-width: 768px) {
  .p-top-plan__card-container {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.p-top-plan__card-container:after {
  content: "";
  display: block;
  height: 0;
  width: clamp(321px, 31.55vw + 202.7px, 445px);
}
@media screen and (min-width: 768px) {
  .p-top-plan__card-container:after {
    width: clamp(294px, 35.94vw + 18px, 363px);
  }
}
@media screen and (min-width: 960px) {
  .p-top-plan__card-container:after {
    width: clamp(363px, 36.25vw + 15px, 479px);
  }
}
@media screen and (min-width: 1280px) {
  .p-top-plan__card-container:after {
    width: clamp(478px, 36.05vw + 16.6px, 509px);
  }
}
@media screen and (min-width: 1366px) {
  .p-top-plan__card-container:after {
    width: clamp(335px, 24.26vw + 3.6px, 384px);
  }
}
.p-top-plan__card-container--lower:after {
  content: "";
  display: block;
  height: 0;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-top-plan__card-container--lower:after {
    width: clamp(310px, 42.71vw - 18px, 392px);
  }
}
@media screen and (min-width: 960px) {
  .p-top-plan__card-container--lower:after {
    width: clamp(293px, 27.81vw + 26px, 382px);
  }
}
@media screen and (min-width: 1280px) {
  .p-top-plan__card-container--lower:after {
    width: clamp(382px, 27.91vw + 24.8px, 406px) !important;
  }
}
@media screen and (min-width: 1366px) {
  .p-top-plan__card-container--lower:after {
    width: clamp(406px, 28.22vw + 20.5px, 463px) !important;
  }
}
.p-top-plan__h3 {
  font-family: "Zen Old Mincho";
  font-size: clamp(22px, 1.17vw + 17.7px, 36px);
  letter-spacing: 0.01;
  margin-top: 100px;
}
.p-top-plan__simulator {
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  border-radius: 4px;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  background-color: #dbeff8;
  margin: clamp(50px, 3.86vw + 35.5px, 96px) auto 0;
}
@media screen and (min-width: 375px) {
  .p-top-plan__simulator {
    width: clamp(321px, 31.55vw + 202.7px, 445px);
  }
}
@media screen and (min-width: 768px) {
  .p-top-plan__simulator {
    width: 100%;
    max-width: 850px;
  }
}
@media screen and (min-width: 1366px) {
  .p-top-plan__simulator {
    width: 75%;
    max-width: 1008px;
  }
}
.p-top-plan__simulator-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 100%;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  position: relative;
  padding: 32px clamp(26px, 0.5vw + 24.2px, 32px);
}
@media screen and (min-width: 768px) {
  .p-top-plan__simulator-inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 20px;
  }
}
.p-top-plan__simulator-character {
  display: block;
  position: absolute;
  bottom: 0;
  left: 1em;
  background-image: url(../img/simulator/simu-character.webp);
  width: clamp(80px, 5.87vw + 58px, 150px);
  height: clamp(80px, 5.87vw + 58px, 150px);
  background-position: bottom center;
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (min-width: 768px) {
  .p-top-plan__simulator-character {
    position: relative;
    margin-left: clamp(-24px, 3vw - 47px, 0px);
    margin-bottom: -32px;
    margin-top: auto;
  }
}
.p-top-plan__simulator-text {
  width: 100%;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-top-plan__simulator-text {
    max-width: 324px;
    width: 38%;
    text-align: left;
  }
}
.p-top-plan__simulator-text > h3 {
  font-family: "Zen Old Mincho";
  font-size: clamp(22px, 1.17vw + 17.7px, 36px);
  line-height: 1.75;
}
.p-top-plan__simulator-text > span {
  font-size: clamp(14px, 0.34vw + 12.7px, 18px);
  line-height: 1.75;
  letter-spacing: -0.04em;
}
.p-top-plan__simulator-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  gap: 24px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .p-top-plan__simulator-button {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 2px;
  }
}
.p-top-plan__simulator-button > span {
  position: relative;
  display: block;
  background-color: #fff;
  padding: 7px clamp(16px, 1.84vw + 9.1px, 38px);
  border-radius: 4px;
  margin: 0 auto;
  text-align: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: 7em;
  font-size: clamp(12px, 0.5vw + 10.2px, 18px);
}
@media screen and (min-width: 768px) {
  .p-top-plan__simulator-button > span {
    margin: 0 auto;
  }
}
.p-top-plan__simulator-button > span:after {
  content: "";
  display: block;
  position: absolute;
  border: 7px solid transparent;
  border-right: 7px solid #fff;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  top: 50%;
  margin-left: -12px;
}
@media screen and (min-width: 768px) {
  .p-top-plan__simulator-button > span:after {
    -webkit-transform: translate(-50%, 0%);
            transform: translate(-50%, 0%);
    top: 95%;
    left: 50%;
    margin-left: -7px;
    border: 7px solid transparent;
    border-top: 7px solid #fff;
  }
}

@media (hover: hover) {
  .p-top-plan__simulator:hover {
    -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
            box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
    scale: 1.01;
  }
  .p-top-plan__simulator:hover > a > div > div.c-button--no-hover:after {
    opacity: 1;
    width: 100.5%;
    height: 100.5%;
  }
}
/*
p-plancard
-----------------------------------------------------*/
.p-plancard {
  border-radius: 8px;
  position: relative;
  height: clamp(378px, 12.32vw + 331.8px, 525px);
  background-color: #fff;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  width: clamp(321px, 31.55vw + 202.7px, 445px);
}
@media screen and (min-width: 768px) {
  .p-plancard {
    width: calc((100% - 16px) / 2);
  }
}
@media screen and (min-width: 1366px) {
  .p-plancard {
    width: calc((100% - 32px) / 3);
  }
}
.p-plancard > a {
  width: 100%;
  padding: 22px clamp(16px, 1.34vw + 11px, 32px) 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.p-plancard--lower {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-plancard--lower {
    width: clamp(310px, 42.71vw - 18px, 392px);
  }
}
@media screen and (min-width: 960px) {
  .p-plancard--lower {
    width: clamp(293px, 27.81vw + 26px, 382px);
  }
}
@media screen and (min-width: 1280px) {
  .p-plancard--lower {
    width: clamp(382px, 27.91vw + 24.8px, 406px) !important;
  }
}
@media screen and (min-width: 1366px) {
  .p-plancard--lower {
    width: clamp(406px, 28.22vw + 20.5px, 463px) !important;
  }
}
.p-plancard__figure {
  display: block;
  position: relative;
  aspect-ratio: 16/9;
  width: clamp(190px, 5.53vw + 169.3px, 256px);
  margin-top: clamp(15px, 0.17vw + 14.3px, 17px);
  height: auto;
  overflow: hidden;
  border-radius: 4px;
}
.p-plancard__figure > img {
  position: absolute;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
  width: 100%;
  height: auto;
}
.p-plancard__h4 {
  font-size: clamp(20px, 1.01vw + 16.2px, 32px);
  line-height: 150%;
  font-weight: 500;
  text-align: center;
  margin-bottom: clamp(8px, 0.84vw + 4.8px, 18px);
}
.p-plancard__description {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: clamp(5px, 0.34vw + 3.7px, 9px);
  font-size: clamp(12px, 0.34vw + 10.7px, 16px);
  font-weight: 500;
  line-height: 150%;
  letter-spacing: 0.01em;
}
@media screen and (min-width: 768px) {
  .p-plancard__description {
    width: 230px;
  }
}
@media screen and (min-width: 960px) {
  .p-plancard__description {
    width: clamp(225px, 4.69vw + 180px, 240px);
  }
}
@media screen and (min-width: 1280px) {
  .p-plancard__description {
    width: 240px;
  }
}
@media screen and (min-width: 1366px) {
  .p-plancard__description {
    width: clamp(240px, 7.43vw + 138.5px, 255px);
  }
}
.p-plancard__description:before {
  content: "";
  display: block;
  height: clamp(23px, 1.09vw + 18.9px, 36px);
  width: clamp(30px, 1.26vw + 25.2px, 45px);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.p-plancard__description--01:before {
  background-image: url(../img/plan/people_1.svg);
}
.p-plancard__description--02:before {
  background-image: url(../img/plan/people_2.svg);
}
.p-plancard__description--03:before {
  background-image: url(../img/plan/people_3.svg);
}
.p-plancard__description--04:before {
  background-image: url(../img/plan/people_4.svg);
}
.p-plancard__description--gojokai:before {
  content: none;
}
.p-plancard__price-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: clamp(6px, 0.17vw + 5.3px, 8px);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: clamp(12px, 0.67vw + 9.5px, 20px);
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.p-plancard__heavens-price {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 999px;
  background-color: #dbeff8;
  font-size: 0.625rem;
  line-height: 150%;
  text-align: center;
  width: clamp(100px, 0.84vw + 96.8px, 110px);
  height: clamp(36px, 0.5vw + 34.2px, 42px);
}
.p-plancard__price {
  font-family: Oxygen;
  font-size: clamp(24px, 1.01vw + 20.2px, 36px);
  white-space: nowrap;
}
.p-plancard__price > span {
  font-family: "Zen Kaku Gothic New";
  font-size: clamp(12px, 0.67vw + 9.5px, 20px);
  font-weight: 500;
}
.p-plancard__price > span > span {
  font-size: 0.75rem;
  margin-left: -0.3em;
}
.p-plancard__general-price {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: clamp(5px, 0.17vw + 4.3px, 7px);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.p-plancard__general-price > p {
  font-size: 0.75rem;
}
.p-plancard__general-price > p > span {
  font-family: Oxygen;
  font-size: 1rem;
}
.p-plancard__button {
  margin-top: clamp(12px, -0.34vw + 17.3px, 16px);
  width: clamp(272px, 4.02vw + 257px, 320px);
  max-width: 100%;
}
@media screen and (min-width: 768px) {
  .p-plancard__button {
    width: 100%;
  }
}
@media screen and (min-width: 960px) {
  .p-plancard__button {
    width: clamp(272px, 4.02vw + 257px, 320px);
  }
}
.p-plancard--heavens {
  position: relative;
  display: block;
  background-color: #dbeff8;
  padding: 22px clamp(25px, 0.59vw + 22.7px, 32px) 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-plancard--heavens__head {
  font-family: "Zen Old Mincho";
  font-size: clamp(22px, 0.5vw + 20.2px, 28px);
  margin-top: 1em;
}
.p-plancard--heavens__text {
  font-size: clamp(14px, 0.34vw + 12.7px, 18px);
  margin-top: clamp(16px, 1.34vw + 11px, 32px);
}
.p-plancard--heavens__price {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-plancard--heavens__price > p:first-child {
  font-size: 1rem;
  margin-top: 0.2em;
}
.p-plancard--heavens__price > p:nth-child(2) {
  font-family: Oxygen;
  font-size: 2.25rem;
  margin-left: 0.3em;
}
.p-plancard--heavens__price > p:nth-child(2) > span {
  font-family: "Zen Kaku Gothic New";
  font-size: 1.25rem;
  margin-left: -0.4em;
}
.p-plancard--heavens__price > p:nth-child(2) > span > span {
  font-size: 0.75rem;
}
.p-plancard--heavens__button {
  letter-spacing: -0.02em;
  margin-top: clamp(14px, 1.51vw + 8.3px, 32px);
}
.p-plancard--heavens__flower {
  position: absolute;
  display: block;
  height: 100%;
  width: 100%;
  pointer-events: none;
  overflow: hidden;
  left: 0;
  top: 0;
}
.p-plancard--heavens__flower:before, .p-plancard--heavens__flower:after {
  content: "";
  display: block;
  position: absolute;
  background-image: url(../img/common/heavens_flower.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  mix-blend-mode: color-burn;
}
.p-plancard--heavens__flower:before {
  width: clamp(156px, 2.68vw + 146px, 188px);
  height: clamp(137px, 2.26vw + 128.6px, 164px);
  top: clamp(-80px, 0vw - 80px, -80px);
  left: clamp(-21px, 0vw - 21px, -21px);
  rotate: 126.5deg;
}
.p-plancard--heavens__flower:after {
  width: clamp(188px, 3.19vw + 176px, 226px);
  height: clamp(176px, 2.93vw + 165.1px, 211px);
  bottom: clamp(-10px, 0vw - 10px, -10px);
  right: clamp(-40px, 0vw - 40px, -40px);
  rotate: 31.8deg;
}
.p-plancard__gojokai-price {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(5px, 0.42vw + 3.4px, 10px);
  margin-top: clamp(10px, 0.5vw + 8.2px, 16px);
}
.p-plancard__gojokai-price > p:first-child {
  font-size: clamp(12px, 0.34vw + 10.7px, 16px);
  font-weight: 500;
  margin-top: 0.2em;
}
.p-plancard__gojokai-price > p:nth-child(2) {
  font-family: Oxygen;
  font-size: clamp(24px, 1.01vw + 20.2px, 36px);
  letter-spacing: -0.02em;
}
.p-plancard__gojokai-price > p:nth-child(2) > span {
  font-family: "Zen Kaku Gothic New";
  font-size: clamp(12px, 0.67vw + 9.5px, 20px);
  font-weight: 500;
}
.p-plancard__gojokai-price > p:nth-child(2) > span > span {
  font-size: 0.75rem;
  margin-left: -0.3em;
}
.p-plancard--gojokai {
  position: relative;
  display: block;
  background-color: #ffeeed;
  padding: 50px clamp(25px, 0.59vw + 22.7px, 32px) 64px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: -webkit-fit-content !important;
  height: -moz-fit-content !important;
  height: fit-content !important;
}
.p-plancard--gojokai__head {
  font-family: "Zen Old Mincho";
  font-size: clamp(22px, 0.5vw + 20.2px, 28px);
}
.p-plancard--gojokai__text {
  font-size: clamp(14px, 0.34vw + 12.7px, 18px);
  margin-top: clamp(16px, 1.34vw + 11px, 32px);
}
.p-plancard--gojokai__button {
  text-align: left !important;
  -webkit-box-align: start !important;
      -ms-flex-align: start !important;
          align-items: flex-start !important;
  padding: 0 !important;
  margin-top: 34px;
}

/*
p-top-family
-----------------------------------------------------*/
.p-top-family {
  margin: 100px clamp(43px, 19.2vw - 29.1px, 272px) 0;
}
.p-top-family__container {
  margin-top: clamp(28px, 3.44vw + 15.1px, 69px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 32px;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (min-width: 960px) {
  .p-top-family__container {
    gap: clamp(16px, 2.63vw - 9.2px, 32px);
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.p-top-family__slider {
  aspect-ratio: 4/3;
  border-radius: 4px;
  width: 100%;
  height: auto;
}
@media screen and (min-width: 960px) {
  .p-top-family__slider {
    width: 46%;
  }
}
.p-top-family__slider-item {
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
  overflow: hidden;
}
.p-top-family__text {
  width: 100%;
  margin-top: 40px;
}
.p-top-family__text > h3 {
  font-size: clamp(20px, 1.01vw + 16.2px, 32px);
  font-weight: 500;
  margin-bottom: clamp(24px, 0.67vw + 21.5px, 32px);
}
.p-top-family__text > p {
  margin-bottom: clamp(25px, 1.42vw + 19.7px, 42px);
}
@media screen and (min-width: 1280px) {
  .p-top-family__text > a {
    max-width: 304px;
  }
}
@media screen and (min-width: 960px) {
  .p-top-family__text {
    width: 46.9%;
  }
}

/*
p-top-hall
-----------------------------------------------------*/
.p-top-hall {
  position: relative;
  padding: clamp(50px, 9.56vw + 14.1px, 164px) clamp(43px, 5.78vw + 21.4px, 112px);
  margin-top: clamp(75px, 6.29vw + 51.4px, 150px);
  width: 100%;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
.p-top-hall::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-color: #fff;
  mix-blend-mode: screen;
  opacity: 0.5;
  z-index: -1;
}
.p-top-hall__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: clamp(28px, 1.84vw + 21.1px, 50px);
  margin-bottom: clamp(25px, 0.59vw + 22.7px, 32px);
}
@media screen and (min-width: 960px) {
  .p-top-hall__head {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: clamp(0px, 22.53vw - 216.3px, 137px);
  }
}
.p-top-hall__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: clamp(25px, 6.67vw + 0px, 64px);
}
@media screen and (min-width: 960px) {
  .p-top-hall__container {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
.p-top-hall__map {
  min-width: 300px;
  max-width: 400px;
  width: 100%;
  margin: 0 auto;
  position: relative;
}
@media screen and (min-width: 960px) {
  .p-top-hall__map {
    position: sticky;
    top: 18%;
    margin-top: 16px;
    height: 100%;
    width: clamp(289px, 8.63vw + 256.7px, 392px);
  }
}
.p-top-hall__map > img {
  aspect-ratio: 392/376;
  width: 100%;
}
@media screen and (min-width: 960px) {
  .p-top-hall__map > img {
    width: clamp(289px, 8.63vw + 256.7px, 392px);
  }
}
.p-top-hall__map > a {
  position: absolute;
  aspect-ratio: 1/1;
  width: 19%;
  height: auto;
  border-radius: 50%;
  background-color: #dbeff8;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  mix-blend-mode: multiply;
  opacity: 0;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
.p-top-hall__map > a :focus-visible {
  outline: 2px solid blue;
}
.p-top-hall__map > a:focus {
  opacity: 1;
}
.p-top-hall__map > a > span {
  visibility: hidden;
}
.p-top-hall__map > a.chuo {
  top: 86%;
  left: 47.9%;
}
.p-top-hall__map > a.minami {
  top: 76%;
  left: 12.5%;
}
.p-top-hall__map > a.kiri {
  top: 42.7%;
  left: 8.3%;
}
.p-top-hall__map > a.s-kiri {
  top: 42.5%;
  left: 24.9%;
}
.p-top-hall__map > a.asahi {
  top: 84.7%;
  left: 91.6%;
}
.p-top-hall__map > a.s-waka {
  top: 12%;
  left: 53.8%;
}
.p-top-hall__map > a.mame {
  top: 91.4%;
  left: 73%;
}
.p-top-hall__map > a.suko {
  top: 40.5%;
  left: 91.8%;
}
.p-top-hall__map > a.s-suko {
  top: 40.7%;
  left: 74.8%;
}
.p-top-hall__map > a.s-naka {
  top: 8.3%;
  left: 91.8%;
}
.p-top-hall__hall-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: clamp(8px, -0.17vw + 10.7px, 10px);
  margin-bottom: clamp(32px, 0.67vw + 29.5px, 40px);
}
.p-top-hall__hall-list-container > h3 {
  font-size: clamp(22px, 0.5vw + 20.2px, 28px);
  font-family: "Zen Old Mincho";
  margin-bottom: 16px;
}
@media screen and (min-width: 960px) {
  .p-top-hall__hall-list-container {
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content;
    overflow: hidden;
    width: 63%;
  }
}
.p-top-hall__hall-list-container--lower {
  width: 100%;
}
.p-top-hall__hall-list-container > h4 {
  font-size: clamp(22px, 0.5vw + 20.2px, 28px);
  font-family: "Zen Old Mincho";
  margin-bottom: 16px;
}
@media screen and (min-width: 960px) {
  .p-top-hall__hall-list-container {
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content;
    overflow: hidden;
    width: 63%;
  }
}
.p-top-hall__hall-list-container--lower {
  width: 100%;
}

@media (hover: hover) {
  .p-top-hall__map > a:hover {
    opacity: 1;
  }
}
/*
p-hall-card
-----------------------------------------------------*/
.p-hall-card {
  border-radius: 4px;
  background-color: #fff;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
}
.p-hall-card__inner {
  display: -ms-grid;
  display: grid;
  padding: clamp(12px, -0.34vw + 17.3px, 16px);
  -ms-grid-columns: 3fr 5fr 1fr;
  grid-template-columns: 3fr 5fr 1fr;
  -ms-grid-rows: (auto)[3];
  grid-template-rows: repeat(3, auto);
}
.p-hall-card__inner > *:nth-child(1) {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
}
.p-hall-card__inner > *:nth-child(2) {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
}
.p-hall-card__inner > *:nth-child(3) {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
}
.p-hall-card__inner > *:nth-child(4) {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
}
.p-hall-card__inner > *:nth-child(5) {
  -ms-grid-row: 2;
  -ms-grid-column: 2;
}
.p-hall-card__inner > *:nth-child(6) {
  -ms-grid-row: 2;
  -ms-grid-column: 3;
}
.p-hall-card__inner > *:nth-child(7) {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
}
.p-hall-card__inner > *:nth-child(8) {
  -ms-grid-row: 3;
  -ms-grid-column: 2;
}
.p-hall-card__inner > *:nth-child(9) {
  -ms-grid-row: 3;
  -ms-grid-column: 3;
}
@media screen and (min-width: 600px) {
  .p-hall-card__inner {
    -ms-grid-columns: 4fr 5fr 9fr 1fr;
    grid-template-columns: 4fr 5fr 9fr 1fr;
    -ms-grid-rows: (auto)[2];
    grid-template-rows: repeat(2, auto);
  }
  .p-hall-card__inner > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-hall-card__inner > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .p-hall-card__inner > *:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-hall-card__inner > *:nth-child(4) {
    -ms-grid-row: 1;
    -ms-grid-column: 4;
  }
  .p-hall-card__inner > *:nth-child(5) {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .p-hall-card__inner > *:nth-child(6) {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-hall-card__inner > *:nth-child(7) {
    -ms-grid-row: 2;
    -ms-grid-column: 3;
  }
  .p-hall-card__inner > *:nth-child(8) {
    -ms-grid-row: 2;
    -ms-grid-column: 4;
  }
}
@media screen and (min-width: 960px) {
  .p-hall-card__inner {
    -ms-grid-columns: (auto)[3];
    grid-template-columns: repeat(3, auto);
    -ms-grid-rows: (auto)[3];
    grid-template-rows: repeat(3, auto);
  }
  .p-hall-card__inner > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-hall-card__inner > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .p-hall-card__inner > *:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-hall-card__inner > *:nth-child(4) {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .p-hall-card__inner > *:nth-child(5) {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-hall-card__inner > *:nth-child(6) {
    -ms-grid-row: 2;
    -ms-grid-column: 3;
  }
  .p-hall-card__inner > *:nth-child(7) {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-hall-card__inner > *:nth-child(8) {
    -ms-grid-row: 3;
    -ms-grid-column: 2;
  }
  .p-hall-card__inner > *:nth-child(9) {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
  }
}
@media screen and (min-width: 1280px) {
  .p-hall-card__inner {
    -ms-grid-columns: 4fr 3fr 6fr 1fr;
    grid-template-columns: 4fr 3fr 6fr 1fr;
    -ms-grid-rows: (auto)[2];
    grid-template-rows: repeat(2, auto);
  }
  .p-hall-card__inner > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-hall-card__inner > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .p-hall-card__inner > *:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-hall-card__inner > *:nth-child(4) {
    -ms-grid-row: 1;
    -ms-grid-column: 4;
  }
  .p-hall-card__inner > *:nth-child(5) {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .p-hall-card__inner > *:nth-child(6) {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-hall-card__inner > *:nth-child(7) {
    -ms-grid-row: 2;
    -ms-grid-column: 3;
  }
  .p-hall-card__inner > *:nth-child(8) {
    -ms-grid-row: 2;
    -ms-grid-column: 4;
  }
}
.p-hall-card__figure {
  -ms-grid-row: 1;
  -ms-grid-row-span: 2;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
  grid-area: 1/1/3/2;
  position: relative;
  aspect-ratio: 4/3;
  width: clamp(59px, 31.72vw - 59.9px, 105px);
  height: auto;
  border-radius: 4px;
  overflow: hidden;
}
@media screen and (min-width: 600px) {
  .p-hall-card__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-area: 1/1/3/2;
    width: clamp(64px, 7.63vw + 35.4px, 155px);
  }
}
@media screen and (min-width: 960px) {
  .p-hall-card__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-area: 1/1/4/2;
  }
}
@media screen and (min-width: 1280px) {
  .p-hall-card__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-area: 1/1/3/2;
    width: clamp(64px, 7.63vw + 35.4px, 155px);
  }
}
.p-hall-card__figure > img {
  position: absolute;
  width: 100%;
  height: auto;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
}
.p-hall-card__name {
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  grid-area: 1/2/2/3;
  font-size: clamp(16px, 0.67vw + 13.5px, 24px);
  font-weight: 500;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: -5px;
}
@media screen and (min-width: 600px) {
  .p-hall-card__name {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 1/2/3/3;
    margin-left: clamp(-32px, -3.51vw + 23px, 2px);
    margin-top: 0;
  }
}
@media screen and (min-width: 960px) {
  .p-hall-card__name {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 1/2/2/3;
    margin-left: -16px;
  }
}
@media screen and (min-width: 1280px) {
  .p-hall-card__name {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 1/2/3/3;
    margin-left: clamp(-32px, -3.51vw + 23px, 2px);
    margin-top: inherit;
  }
}
.p-hall-card__address {
  -ms-grid-row: 2;
  -ms-grid-row-span: 1;
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  grid-area: 2/2/3/3;
  position: relative;
  padding-left: clamp(12px, 0.92vw + 8.6px, 23px);
  font-size: clamp(10px, 0.67vw + 7.5px, 18px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 600px) {
  .p-hall-card__address {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-area: 1/3/2/4;
    height: clamp(32px, 1vw + 24.3px, 40px);
    margin-top: auto;
    margin-bottom: 0;
  }
}
@media screen and (min-width: 960px) {
  .p-hall-card__address {
    margin-left: -16px;
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 2/2/3/3;
  }
}
@media screen and (min-width: 1280px) {
  .p-hall-card__address {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-area: 1/3/2/4;
  }
}
.p-hall-card__address:before {
  content: "";
  position: absolute;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  top: 50%;
  display: block;
  background-image: url(../img/common/pin.svg);
  width: clamp(12px, 0.92vw + 8.6px, 23px);
  height: clamp(12px, 0.92vw + 8.6px, 23px);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.p-hall-card__tag-box {
  -ms-grid-row: 3;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  grid-area: 3/1/4/3;
  margin-top: clamp(12px, -0.17vw + 14.7px, 14px);
  margin-left: clamp(-12px, -0.5vw - 4.2px, -6px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: clamp(4px, 0.34vw + 2.7px, 8px);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 600px) {
  .p-hall-card__tag-box {
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-area: 2/3/3/4;
    height: clamp(32px, 1vw + 24.3px, 40px);
    margin-top: 0;
    margin-bottom: auto;
  }
}
@media screen and (min-width: 960px) {
  .p-hall-card__tag-box {
    -ms-grid-row: 3;
    -ms-grid-row-span: 1;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 3/2/4/3;
    margin-left: clamp(-12px, -1.03vw - 2.1px, -6px);
  }
}
@media screen and (min-width: 1280px) {
  .p-hall-card__tag-box {
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-area: 2/3/3/4;
    margin-top: 0;
  }
}
.p-hall-card__arrow {
  -ms-grid-row: 1;
  -ms-grid-row-span: 3;
  -ms-grid-column: 3;
  -ms-grid-column-span: 1;
  grid-area: 1/3/4/4;
  width: clamp(8px, 0.67vw + 5.5px, 16px);
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-right: 0;
  margin-left: auto;
}
@media screen and (min-width: 600px) {
  .p-hall-card__arrow {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 4;
    -ms-grid-column-span: 1;
    grid-area: 1/4/3/5;
    margin-right: clamp(8px, 2.22vw - 5.3px, 16px);
  }
}
@media screen and (min-width: 960px) {
  .p-hall-card__arrow {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-area: 1/3/4/4;
  }
}
@media screen and (min-width: 1280px) {
  .p-hall-card__arrow {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 4;
    -ms-grid-column-span: 1;
    grid-area: 1/4/3/5;
    margin-right: clamp(8px, 2.22vw - 5.3px, 16px);
  }
}
.p-hall-card__arrow > img {
  width: 100%;
  height: 100%;
}

/*
p-top-after
-----------------------------------------------------*/
.p-top-after {
  padding: clamp(50px, 9.56vw + 14.1px, 164px) clamp(43px, 5.78vw + 21.4px, 112px);
  margin-top: clamp(25px, 2.1vw + 17.1px, 50px);
}
.p-top-after > p {
  margin-top: clamp(32px, 1.51vw + 26.3px, 50px);
}
@media screen and (min-width: 768px) {
  .p-top-after > p {
    text-align: center;
  }
}
@media screen and (min-width: 960px) {
  .p-top-after > p {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
}
.p-top-after__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: clamp(16px, 1.34vw + 11px, 32px);
  margin-top: clamp(50px, 1.17vw + 45.7px, 64px);
}
.p-top-after__card {
  width: 100%;
  background-color: #fff;
  border-radius: 4px;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
}
@media screen and (min-width: 520px) {
  .p-top-after__card {
    width: calc((100% - (1.34vw + 11px)) / 2);
  }
}
@media screen and (min-width: 1280px) {
  .p-top-after__card {
    width: calc((100% - (1.34vw + 11px) * 2) / 3);
    border-radius: 8px;
  }
}
.p-top-after__card > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-top-after__card--about {
  width: 100%;
}
@media screen and (min-width: 520px) {
  .p-top-after__card--about {
    width: calc((100% - (1.34vw + 11px)) / 2);
  }
}
.p-top-after__card--after {
  width: 100%;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
@media screen and (min-width: 768px) {
  .p-top-after__card--after {
    width: calc((100% - (1.34vw + 11px)) / 2);
  }
}
.p-top-after__card-title {
  background-color: #005e8b;
  border-radius: 4px 4px 0 0;
  height: clamp(50px, 1.17vw + 45.7px, 64px);
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #fff;
  z-index: 2;
  font-weight: 500;
  font-size: clamp(20px, 0.34vw + 18.7px, 24px);
}
@media screen and (min-width: 520px) {
  .p-top-after__card-title {
    font-size: clamp(18px, 0.57vw + 15.1px, 24px);
  }
}
@media screen and (min-width: 960px) {
  .p-top-after__card-title {
    border-radius: 8px 8px 0 0;
  }
}
.p-top-after__card-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(6px, 2.54vw - 3.5px, 16px);
  padding: clamp(20px, 0.42vw + 18.4px, 25px) clamp(16px, 1.93vw + 8.7px, 39px);
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.p-top-after__text {
  position: relative;
  font-weight: 500;
  font-size: clamp(14px, 0.17vw + 13.3px, 16px);
  letter-spacing: 0.02em;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  letter-spacing: -0.02em;
}
@media screen and (min-width: 520px) {
  .p-top-after__text {
    width: 100%;
    text-align: center;
  }
}
.p-top-after__figure {
  aspect-ratio: 4/3;
  overflow: hidden;
  width: clamp(200px, 22.9vw + 114.1px, 290px);
  height: auto;
  position: relative;
  border-radius: 4px;
}
@media screen and (min-width: 520px) {
  .p-top-after__figure {
    width: clamp(172px, 10.31vw + 118.4px, 280px);
  }
}
.p-top-after__figure > img {
  position: absolute;
  width: 100%;
  height: auto;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
}
.p-top-after__more {
  position: relative;
  font-size: 1rem;
  font-weight: 500;
  margin-top: 0.8em;
}
.p-top-after__more:after {
  content: "";
  position: absolute;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: -15px;
  top: 50%;
  display: block;
  background-image: url(../img/common/>.svg);
  width: clamp(6px, 0.17vw + 5.3px, 8px);
  height: clamp(6px, 0.17vw + 5.3px, 8px);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.p-top-after__button {
  margin: clamp(50px, 1.17vw + 45.7px, 64px) auto 0;
}
@media screen and (min-width: 520px) {
  .p-top-after__button {
    width: 70%;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (min-width: 768px) {
  .p-top-after__button {
    max-width: 384px;
  }
}

/*
p-top-voice
-----------------------------------------------------*/
.p-top-voice {
  position: relative;
  padding: clamp(50px, 9.56vw + 14.1px, 164px) clamp(43px, 5.78vw + 21.4px, 112px);
  margin-top: clamp(25px, 2.1vw + 17.1px, 50px);
  width: 100%;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
.p-top-voice::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-color: #ffeeed;
  mix-blend-mode: multiply;
  z-index: -1;
}
.p-top-voice > p {
  margin-top: clamp(50px, 1.17vw + 45.7px, 64px);
  text-align: center;
}
@media screen and (min-width: 960px) {
  .p-top-voice > p {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
}
.p-top-voice__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: clamp(16px, 1.34vw + 11px, 32px);
  margin-top: clamp(32px, 1.51vw + 26.3px, 50px);
}
.p-top-voice__container > li:nth-child(n+4) {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-top-voice__container > li:nth-child(n+4) {
    display: block;
  }
}
@media screen and (min-width: 768px) {
  .p-top-voice__container {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.p-top-voice__item {
  border-radius: 8px;
  background-color: #fff;
  padding: clamp(25px, 0.34vw + 23.7px, 29px) clamp(25px, 0.59vw + 22.7px, 32px) clamp(25px, 1.59vw + 19.1px, 44px);
}
@media screen and (min-width: 768px) {
  .p-top-voice__item {
    width: calc((100% - (1.34vw + 11px) * 1) / 2);
  }
}
@media screen and (min-width: 960px) {
  .p-top-voice__item {
    width: calc((100% - (1.34vw + 11px) * 2) / 3);
  }
}
.p-top-voice__item-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-top-voice__hall {
  font-weight: 500;
  font-size: 0.75rem;
}
.p-top-voice__name {
  font-weight: 500;
  font-size: 1.25rem;
  margin-top: 16px;
}
.p-top-voice__text {
  font-size: 0.875rem;
  margin-top: 18px;
}

.p-top-voice__container.--after {
  gap: 16px;
}
@media screen and (min-width: 768px) {
  .p-top-voice__container.--after .p-top-voice__item {
    width: calc((100% - 16px) / 2);
  }
}
@media screen and (min-width: 960px) {
  .p-top-voice__container.--after .p-top-voice__item {
    width: calc((100% - 16px) / 2);
  }
}

/*
p-top-news
-----------------------------------------------------*/
.p-top-news {
  position: relative;
  padding: clamp(50px, 9.56vw + 14.1px, 164px) clamp(43px, 5.78vw + 21.4px, 112px);
  margin-top: clamp(25px, 2.1vw + 17.1px, 50px);
  width: 100%;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
.p-top-news__button-pc {
  display: none;
}
@media screen and (min-width: 960px) {
  .p-top-news__button-pc {
    display: block;
    margin-top: 50px;
  }
}
@media screen and (min-width: 960px) {
  .p-top-news__container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
.p-top-news__list {
  margin-top: clamp(37px, 1.09vw + 32.9px, 50px);
  position: relative;
}
.p-top-news__list:before, .p-top-news__list:after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  top: 0;
  left: 0;
}
.p-top-news__list:before {
  mix-blend-mode: color-burn;
}
.p-top-news__list:after {
  mix-blend-mode: multiply;
}
@media screen and (min-width: 960px) {
  .p-top-news__list {
    width: clamp(525px, 55.76vw - 10.3px, 864px);
    margin-top: 0;
  }
}
.p-top-news__item {
  position: relative;
}
.p-top-news__item:before, .p-top-news__item:after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  bottom: 0;
  left: 0;
}
.p-top-news__item:before {
  mix-blend-mode: color-burn;
}
.p-top-news__item:after {
  mix-blend-mode: multiply;
}
.p-top-news__item > a {
  padding: clamp(16px, 0.67vw + 13.5px, 24px) 0;
  display: block;
  width: 100% !important;
}
.p-top-news__date {
  display: block;
  font-family: "Zen Old Mincho";
  font-size: 0.75rem;
  font-weight: 500;
}
.p-top-news__title {
  display: block;
  margin-top: 8px;
  position: relative;
}
.p-top-news__button-sp {
  margin-top: clamp(50px, 1.17vw + 45.7px, 64px);
}
@media screen and (min-width: 520px) {
  .p-top-news__button-sp {
    width: 50%;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (min-width: 960px) {
  .p-top-news__button-sp {
    display: none;
  }
}

/*
p-contact
-----------------------------------------------------*/
.p-contact {
  position: relative;
  margin-top: clamp(150px, 4.19vw + 134.3px, 200px);
  width: 100%;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  background-color: #003d5a;
  padding: clamp(50px, 2.1vw + 42.1px, 75px) clamp(43px, 5.78vw + 21.4px, 112px) clamp(75px, 2.1vw + 67.1px, 100px);
}
@media screen and (min-width: 960px) {
  .p-contact {
    padding: clamp(75px, 2.1vw + 67.1px, 100px) clamp(43px, 5.78vw + 21.4px, 112px);
  }
}
.p-contact > p {
  margin-top: clamp(32px, 1.51vw + 26.3px, 50px);
  text-align: center;
}
@media screen and (min-width: 960px) {
  .p-contact > p {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
}
.p-contact--about {
  padding: clamp(25px, 2.1vw + 17.1px, 50px) clamp(43px, 5.78vw + 21.4px, 112px) clamp(50px, 1.17vw + 45.7px, 64px);
  margin-bottom: clamp(25px, 6.29vw + 1.4px, 100px);
  border-radius: clamp(4px, 0.42vw + 2.4px, 9px);
}
@media screen and (min-width: 960px) {
  .p-contact--about {
    padding: clamp(25px, 2.1vw + 17.1px, 50px) clamp(43px, 5.78vw + 21.4px, 112px) clamp(50px, 1.17vw + 45.7px, 64px);
  }
}
.p-contact__container {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  max-width: 1184px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 25px;
  margin-top: clamp(25px, 2.1vw + 17.1px, 50px);
}
@media screen and (min-width: 960px) {
  .p-contact__container {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.p-contact__container > div {
  width: 100%;
}
@media screen and (min-width: 1280px) {
  .p-contact__container > div {
    width: calc((100% - 50px) / 3);
  }
}
.p-contact__container--about > div {
  width: 100%;
}
.p-contact__tel, .p-contact__hurry, .p-contact__mail {
  border-radius: 8px;
  width: 100%;
  padding-top: 25px;
  padding-bottom: 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-contact__tel > a, .p-contact__hurry > a, .p-contact__mail > a {
  max-width: 400px;
  width: 65%;
}
@media screen and (min-width: 960px) {
  .p-contact__tel > a, .p-contact__hurry > a, .p-contact__mail > a {
    width: 50%;
  }
}
.p-contact__tel {
  background-color: #dbeff8;
  color: #003d5a;
  padding-left: 25px;
  padding-right: 25px;
}
.p-contact__tel > h3 {
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: -0.02em;
  text-align: center;
}
.p-contact__tel > h4 {
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: -0.02em;
  text-align: center;
}
.p-contact__tel > p:nth-child(2) {
  font-size: clamp(12px, 0.17vw + 11.3px, 14px);
  margin-top: clamp(10px, -0.5vw + 17.8px, 16px);
  text-align: center;
}
.p-contact__tel > p:last-child {
  font-size: clamp(32px, 0.5vw + 30.2px, 38px);
  margin-top: clamp(8px, 0.5vw + 6.2px, 14px);
  position: relative;
  padding-left: clamp(39px, 0.75vw + 36.2px, 48px);
  letter-spacing: -0.02em;
  font-family: Oxygen;
}
@media screen and (min-width: 960px) {
  .p-contact__tel > p:last-child {
    font-size: clamp(30px, 1.32vw + 17.3px, 38px);
  }
}
.p-contact__tel > p:last-child::before {
  content: "";
  position: absolute;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  top: 53%;
  display: block;
  background-image: url(../img/common/freedial_bl.svg);
  width: clamp(37px, 0.75vw + 34.2px, 46px);
  height: clamp(24px, 0.5vw + 22.2px, 30px);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.p-contact__tel--about > p {
  letter-spacing: -0.02em;
}
.p-contact__tel--about > p:last-child {
  font-size: clamp(23px, 0.75vw + 20.2px, 32px);
}
.p-contact__hurry {
  background-color: #fff;
  color: #982c4d;
}
.p-contact__hurry > h3 {
  font-size: clamp(20px, 0.34vw + 18.7px, 24px);
  font-weight: 500;
  text-align: center;
}
.p-contact__hurry > p {
  font-size: clamp(12px, 0.17vw + 11.3px, 14px);
  margin-top: clamp(8px, -0.34vw + 13.3px, 12px);
  text-align: center;
}
.p-contact__hurry > a {
  margin-top: 14px;
  width: clamp(220px, 15.27vw + 162.7px, 280px);
}
@media screen and (min-width: 1280px) {
  .p-contact__hurry > a {
    width: initial;
  }
}
.p-contact__mail {
  background-color: #fff;
  color: #005e8b;
  padding: 25px;
}
.p-contact__mail > h3 {
  font-size: clamp(20px, 0.34vw + 18.7px, 24px);
  font-weight: 500;
  text-align: center;
  line-height: 1.4;
}
.p-contact__mail > h4 {
  font-size: clamp(20px, 0.34vw + 18.7px, 24px);
  font-weight: 500;
  text-align: center;
  line-height: 1.4;
}
.p-contact__mail > p {
  font-size: clamp(12px, 0.17vw + 11.3px, 14px);
  margin-top: clamp(8px, -0.34vw + 13.3px, 12px);
  text-align: center;
}
.p-contact__mail > a {
  margin-top: 14px;
  width: clamp(220px, 15.27vw + 162.7px, 280px);
}
@media screen and (min-width: 1280px) {
  .p-contact__mail > a {
    width: initial;
  }
}
.p-contact__mail--about > a {
  width: clamp(200px, 15.27vw + 142.7px, 260px);
}

body.hurry .p-contact {
  display: none;
}

@media screen and (min-width: 1456px) {
  .p-contact__container--about > div {
    width: calc((100% - 25px) / 2);
  }
}
/*
p-banner-container
-----------------------------------------------------*/
.p-banner-container {
  padding: 0 clamp(25px, 14vw - 27.5px, 192px) clamp(50px, 4.19vw + 34.3px, 100px);
}
.p-banner-container__inner {
  max-width: 1184px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: clamp(10px, 0.5vw + 8.2px, 16px);
}
.p-banner-container__inner:before, .p-banner-container__inner:after {
  content: "";
  display: block;
  width: 48%;
  height: 0;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  width: calc((100% - (0.5vw + 8.2px) * 1) / 2);
}
@media screen and (min-width: 768px) {
  .p-banner-container__inner:before, .p-banner-container__inner:after {
    width: calc((100% - (0.5vw + 8.2px) * 2) / 3);
  }
}
@media screen and (min-width: 960px) {
  .p-banner-container__inner:before, .p-banner-container__inner:after {
    width: calc((100% - (0.5vw + 8.2px) * 3) / 4);
  }
}
.p-banner-container__inner > a {
  display: block;
  width: calc((100% - (0.5vw + 8.2px) * 1) / 2);
}
@media screen and (min-width: 768px) {
  .p-banner-container__inner > a {
    width: calc((100% - (0.5vw + 8.2px) * 2) / 3);
  }
}
@media screen and (min-width: 960px) {
  .p-banner-container__inner > a {
    width: calc((100% - (0.5vw + 8.2px) * 3) / 4);
  }
}
.p-banner-container__inner > a > img {
  width: 100%;
  height: auto;
  border: 1px solid #ccc;
}

/*
p-global-nav
-----------------------------------------------------*/
.p-global-nav__top {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 4px;
}
.p-global-nav__tel {
  font-size: 38px;
  font-family: Oxygen;
  color: #982c4d;
  position: relative;
  padding-left: clamp(39px, 0.75vw + 36.2px, 48px);
  letter-spacing: -0.02em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  height: 50px;
  margin-right: clamp(10px, 1.59vw + 4.1px, 29px);
}
.p-global-nav__tel::before {
  content: "";
  position: absolute;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  top: 53%;
  display: block;
  background-image: url(../img/common/freedial_rd.svg);
  width: clamp(37px, 0.75vw + 34.2px, 46px);
  height: clamp(24px, 0.5vw + 22.2px, 30px);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.p-global-nav__tel > span {
  display: block;
  font-family: "Zen Kaku Gothic New";
  font-size: 1.0625rem;
  letter-spacing: 0.055em;
  font-weight: 500;
  margin-top: 0.05em;
}
.p-global-nav__tel > span > span {
  display: block;
  font-size: 0.8125rem;
  letter-spacing: 0.09em;
  margin-top: -0.6em;
}
.p-global-nav__list {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  font-weight: 500;
  height: 50px;
  padding-right: 0.5em;
  margin-left: -0.2em;
}
.p-global-nav__item {
  position: relative;
  color: #0f242f;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
.p-global-nav__item:after {
  position: absolute;
  left: 0;
  content: "";
  width: 100%;
  height: 1px;
  background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
  background-image: linear-gradient(to right, #65accf, #005e8b);
  bottom: -1px;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: right top;
          transform-origin: right top;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.p-global-nav__item--parent {
  padding-right: 0.8em;
}
.p-global-nav__item--parent > span {
  position: absolute;
  top: 0.7em;
  right: 0px;
  rotate: 90deg;
  display: block;
  background-image: url(../img/common/>.svg);
  width: clamp(6px, 0.08vw + 5.7px, 7px);
  height: clamp(6px, 0.08vw + 5.7px, 7px);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.p-global-nav__item-button {
  cursor: pointer !important;
}
.p-global-nav__sub-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  row-gap: 16px;
  -webkit-column-gap: 32px;
     -moz-column-gap: 32px;
          column-gap: 32px;
  width: 100%;
  height: 100%;
  margin-top: 16px;
}
.p-global-nav__sub-list--plan {
  row-gap: 8px;
  height: 85%;
}
.p-global-nav__sub-list-container {
  z-index: 100;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: all 0.4s ease-out;
  transition: all 0.4s ease-out;
  height: 0;
  width: 100%;
}
.p-global-nav__sub-list-container.active {
  visibility: visible;
  opacity: 1;
}
.p-global-nav__sub-list-close {
  position: absolute;
  width: 100vw;
  height: 100vh;
  z-index: 1;
  top: 0;
  left: 0;
  background-color: #0f242f;
  opacity: 0.4;
  mix-blend-mode: multiply;
}
.p-global-nav__sub-list-outer {
  background-color: #fff;
  width: 919px;
  z-index: 100;
  top: 125px;
  z-index: 100;
  position: absolute;
  border-radius: 8px;
  padding: 50px 55px;
}
.p-global-nav__sub-list-link {
  margin-bottom: 1.5em;
  font-size: 15px;
  line-height: 1.7em;
}
.p-global-nav__sub-list-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-global-nav__sub-list-inner--plan {
  height: 345px;
}
.p-global-nav__sub-list-inner--hall {
  height: 435px;
}
.p-global-nav__sub-list-inner-sub {
  height: 100%;
}
.p-global-nav__sub-list-inner-sub--two {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
}
.p-global-nav__sub-list-h5 {
  font-weight: 500;
  font-size: 18px;
}
.p-global-nav__sub-list-simulator {
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
  width: 100%;
  position: relative;
  margin-bottom: -10px;
  background-color: #dbeff8;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
}
.p-global-nav__sub-list-simulator > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  width: 100%;
  height: 100px;
  background-color: #dbeff8;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  gap: 24px;
  margin-left: 28px;
}
.p-global-nav__sub-list-simulator > a > p {
  font-size: 1.625rem;
  font-family: "Zen Old Mincho";
  margin-right: 6px;
}
.p-global-nav__sub-list-simulator > a > span {
  font-size: 0.875rem;
  line-height: 1.6;
}
.p-global-nav__sub-list-simulator > a > p.do {
  font-family: "Zen Kaku Gothic New";
  font-size: 1rem;
  font-weight: 500;
  position: relative;
}
.p-global-nav__sub-list-simulator > a > p.do::after {
  content: "";
  display: block;
  position: absolute;
  top: 1em;
  right: -0.5em;
  display: block;
  background-image: url(../img/common/>.svg);
  width: 6px;
  height: 6px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.p-global-nav__sub-list-simulator::before {
  content: "";
  display: block;
  position: absolute;
  background-image: url(../img/simulator/simu-character.webp);
  height: 90px;
  width: 90px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  bottom: 0;
  left: 37px;
}
.p-global-nav__sub-item {
  width: 240px;
  height: 80px;
}
.p-global-nav__sub-item > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-radius: 4px;
  background: #fff;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  width: 100%;
  height: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 16px;
  padding: 16px;
}
.p-global-nav__sub-item--heavens {
  position: relative;
}
.p-global-nav__sub-item--heavens > a {
  background-color: #dbeff8;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.p-global-nav__heavens-flower {
  position: absolute;
  display: block;
  height: 100%;
  width: 100%;
  pointer-events: none;
  overflow: hidden;
  left: 0;
  top: 0;
}
.p-global-nav__heavens-flower:before, .p-global-nav__heavens-flower:after {
  content: "";
  display: block;
  position: absolute;
  background-image: url(../img/common/heavens_flower.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  mix-blend-mode: color-burn;
}
.p-global-nav__heavens-flower:before {
  width: 114px;
  height: 100px;
  top: -41px;
  left: -9px;
  rotate: 125.5deg;
}
.p-global-nav__heavens-flower:after {
  width: 93px;
  height: 87px;
  bottom: 0;
  right: -12px;
  rotate: 32.8deg;
}
.p-global-nav__sub-item-figure {
  aspect-ratio: 4/3;
  width: 64px;
  height: auto;
  position: relative;
  overflow: hidden;
  border-radius: 4px;
}
.p-global-nav__sub-item-figure > img {
  position: absolute;
  height: 100%;
  width: auto;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
}
.p-global-nav__sub-item-figure--after {
  width: 120px;
}
.p-global-nav__button {
  width: 160px !important;
  height: 50px !important;
}
.p-global-nav__sub-item-text {
  font-weight: 500;
  font-size: 16px;
  line-height: 1.35em;
}
.p-global-nav--after__sub-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  row-gap: 16px;
  -webkit-column-gap: 16px;
     -moz-column-gap: 16px;
          column-gap: 16px;
}
.p-global-nav--after__sub-item {
  width: calc((100% - 32px) / 3);
  height: 140px;
}
.p-global-nav--after__sub-item > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0px;
  height: 100%;
}

@media (hover: hover) {
  .p-global-nav__item:hover {
    color: #005e8b;
  }
  .p-global-nav__item:hover > button {
    color: #005e8b;
  }
  .p-global-nav__item:hover:after {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: left top;
            transform-origin: left top;
  }
}
.p-global-nav__item:has(.active) {
  color: #005e8b;
}
.p-global-nav__item:has(.active) > button {
  color: #005e8b;
}
.p-global-nav__item:has(.active):after {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}

/*
p-splide
-----------------------------------------------------*/
.splide {
  position: relative;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
.splide__slide > img {
  width: 100%;
  height: auto;
}
.splide__pagination__page {
  width: 12px;
  height: 12px;
  border: 1px solid #005e8b;
  border-radius: 99px;
  background-color: inherit;
  -webkit-transition: 0.2s all ease-out;
  transition: 0.2s all ease-out;
}
.splide__pagination__page.is-active {
  background-color: #005e8b;
}
.splide__pagination {
  gap: 18px;
  margin-top: 24px;
  cursor: pointer;
}
.splide__toggle {
  position: absolute;
  left: 0;
  bottom: -48px;
  cursor: pointer;
}
@media screen and (min-width: 960px) {
  .splide__toggle {
    bottom: -9px;
  }
}
.splide__arrow {
  position: absolute;
  -webkit-transform-origin: center center 0;
          transform-origin: center center 0;
  top: 45%;
  z-index: 1;
  cursor: pointer;
}
.splide__arrow > span {
  display: block;
  background-image: url(../img/common/slide-arrow.svg);
  width: 32px;
  height: 32px;
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: center;
}
.splide__arrow--prev {
  rotate: 180deg;
  left: 8px;
}
.splide__arrow--next {
  right: 8px;
}

/*
p-breadcrumb
-----------------------------------------------------*/
.p-breadcrumb {
  margin-left: clamp(12px, 8.38vw - 19.4px, 112px);
  margin-right: clamp(12px, 8.38vw - 19.4px, 112px);
  width: calc(100% - 2 * (8.38vw - 19.4px));
  overflow-x: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.p-breadcrumb::-webkit-scrollbar {
  display: none;
}
.p-breadcrumb__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 23px;
}
.p-breadcrumb__container > li:not(:last-child) {
  position: relative;
}
.p-breadcrumb__container > li:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 0.45em;
  right: -1.1em;
  display: block;
  background-image: url(../img/common/>.svg);
  width: 8px;
  height: 8px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.p-breadcrumb__item {
  font-size: 12px;
  font-weight: 400;
  line-height: 150%;
  position: relative;
  display: block;
  white-space: nowrap;
}
.p-breadcrumb__item:has(a):before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  width: 100%;
  height: 0.5px;
  background-color: #0f242f;
  bottom: 1px;
}
.p-breadcrumb__item > a {
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.p-breadcrumb__item > span {
  white-space: nowrap;
}
.p-breadcrumb__item > span > span {
  white-space: nowrap;
}

@media (hover: hover) {
  .p-breadcrumb > a:hover {
    opacity: 0.8;
  }
}
/*
p-anchor
-----------------------------------------------------*/
.p-anchor__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.2em;
  padding: 1em 0;
  border-top: 1px solid #65accf;
  border-bottom: 1px solid #65accf;
  margin-bottom: 50px;
}
@media screen and (min-width: 960px) {
  .p-anchor__list {
    padding: 0;
    border: none;
    margin-bottom: 0;
  }
}
.p-anchor__list--hall {
  border: none;
  margin-bottom: 0;
}
.p-anchor__item {
  position: relative;
  margin: 0.7em 0 0;
  padding-left: 1.6em;
}
@media screen and (min-width: 960px) {
  .p-anchor__item {
    padding-left: 0;
  }
}
.p-anchor__item:last-child {
  margin-bottom: 0.7em;
}
@media screen and (min-width: 960px) {
  .p-anchor__item.active > a {
    color: #005e8b;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
}
.p-anchor__item::before {
  content: "";
  display: block;
  position: absolute;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  top: 50%;
  left: 0;
  background-image: url(../img/common/anchor.svg);
  width: 11px;
  height: 11px;
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}
@media screen and (min-width: 960px) {
  .p-anchor__item::before {
    display: none;
  }
}
.p-anchor__item > a {
  display: inline;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  line-height: 1.3em;
  -webkit-transition: background-size 0.4s;
  transition: background-size 0.4s;
  background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
  background-image: linear-gradient(to right, #65accf, #005e8b);
  background-repeat: no-repeat;
  background-position: 100% 100%;
  background-size: 0 1px;
}
.p-anchor__item--button {
  width: 100% !important;
  min-width: inherit !important;
  margin-bottom: 1em;
  display: none;
}
@media screen and (min-width: 960px) {
  .p-anchor__item--button {
    display: block;
  }
}
.p-anchor__item--button > a {
  width: 100% !important;
  min-width: inherit !important;
}

@media (hover: hover) {
  .p-anchor__item > a:hover {
    color: #005e8b;
    background-position: 0 100%;
    background-size: 100% 1px;
  }
}
/*
p-plan
-----------------------------------------------------*/
.p-plan__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: clamp(16px, 1.34vw + 11px, 32px);
}
@media screen and (min-width: 1280px) {
  .p-plan__head {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: auto;
  }
}
.p-plan__head > p {
  width: 100%;
}
@media screen and (min-width: 1280px) {
  .p-plan__head > p {
    width: 58%;
  }
}
.p-plan__head > div {
  width: 100%;
}
@media screen and (min-width: 1280px) {
  .p-plan__head > div {
    width: clamp(279px, 7.29vw + 185.7px, 300px);
  }
}
.p-plan__gojokai-price {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.p-plan__gojokai-price > div:last-child {
  margin-top: -0.5em;
}
.p-plan__gojokai-price-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.8em;
  font-size: clamp(10px, 0.17vw + 9.3px, 12px);
  font-weight: 500;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (min-width: 1280px) {
  .p-plan__gojokai-price-inner {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}
.p-plan__gojokai-price-inner > p:first-child {
  font-size: clamp(10px, 0.5vw + 8.2px, 16px);
  font-weight: 500;
}
.p-plan__gojokai-price-inner > p:last-child {
  font-size: clamp(24px, 1.01vw + 20.2px, 36px);
}
.p-plan__gojokai-price-inner > p:last-child > span {
  font-size: clamp(12px, 0.67vw + 9.5px, 20px);
  margin-left: -0.2em;
}
.p-plan__gojokai-price-inner > p:last-child > span > span {
  font-size: 12px;
  margin-left: -0.2em;
}
@media screen and (min-width: 1280px) {
  .p-plan__slider {
    width: 76%;
  }
}
.p-plan__slider-item {
  aspect-ratio: 4/3;
  height: auto;
  border-radius: 4px;
  overflow: hidden;
}
.p-plan__slider-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 8px;
  margin-top: clamp(16px, 1.34vw + 11px, 32px);
}
@media screen and (min-width: 1280px) {
  .p-plan__slider-container {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    width: 100%;
  }
}
@media screen and (min-width: 1280px) {
  .p-plan__slider-thumbs {
    width: 24.2%;
  }
}
.p-plan__slider-thmb-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}
@media screen and (min-width: 1280px) {
  .p-plan__slider-thmb-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 12px;
  }
}
.p-plan__slider-thmb-item {
  aspect-ratio: 4/3;
  height: auto;
  border-radius: 4px;
  overflow: hidden;
  width: 100%;
  background-position: center;
  background-repeat: no-repeat;
}
.p-plan__icon-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  row-gap: calc(0.17vw + 7.3px);
  -webkit-column-gap: calc(0.17vw + 7.3px);
     -moz-column-gap: calc(0.17vw + 7.3px);
          column-gap: calc(0.17vw + 7.3px);
}
.p-plan__icon-item {
  position: relative;
  aspect-ratio: 90/83;
  height: auto;
  border-radius: 4px;
  overflow: hidden;
  width: calc((100% - (0.17vw + 7.3px) * 4) / 5);
}
@media screen and (min-width: 520px) {
  .p-plan__icon-item {
    width: calc((100% - (0.17vw + 7.3px) * 5) / 6);
  }
}
@media screen and (min-width: 600px) {
  .p-plan__icon-item {
    width: calc((100% - (0.17vw + 7.3px) * 6) / 7);
  }
}
@media screen and (min-width: 768px) {
  .p-plan__icon-item {
    width: calc((100% - (0.17vw + 7.3px) * 7) / 8);
  }
}
@media screen and (min-width: 960px) {
  .p-plan__icon-item {
    width: calc((100% - (0.17vw + 7.3px) * 6) / 7);
  }
}
@media screen and (min-width: 1280px) {
  .p-plan__icon-item {
    width: calc((100% - (0.17vw + 7.3px) * 7) / 8);
  }
}
.p-plan__icon-item:after {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 4px;
  z-index: -1;
  background-color: #dbeff8;
  mix-blend-mode: multiply;
  opacity: 0.5;
  top: 0;
  left: 0;
}
.p-plan__icon-item > img {
  width: 100%;
  height: auto;
}
.p-plan__icon-spacer {
  display: block;
  width: clamp(66px, 3.19vw + 54px, 104px);
  height: 0;
}
.p-plan__hall-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: clamp(8px, 0.5vw + 6.2px, 14px);
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-plan__hall-item {
  width: 100%;
}
@media screen and (min-width: 520px) {
  .p-plan__hall-item {
    width: calc((100% - (0.5vw + 6.2px)) / 2);
  }
}
@media screen and (min-width: 960px) {
  .p-plan__hall-item {
    width: calc((100% - (0.5vw + 6.2px)) / 2);
  }
}
@media screen and (min-width: 1280px) {
  .p-plan__hall-item {
    width: calc((100% - (0.5vw + 6.2px) * 2) / 3);
  }
}
.p-plan__hall-item > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-radius: 4px;
  background: #fff;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: clamp(12px, 0.34vw + 10.7px, 16px);
  width: 100%;
}
.p-plan__hall-item > a > img {
  width: 8px;
  height: 8px;
  margin-right: 0;
  margin-left: 0;
}
.p-plan__hall-item-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-plan__hall-item-inner > figure {
  width: clamp(50px, 1.17vw + 45.7px, 64px);
  aspect-ratio: 4/3;
  height: auto;
  position: relative;
  border-radius: 4px;
  overflow: hidden;
}
.p-plan__hall-item-inner > figure > img {
  position: absolute;
  display: block;
  width: 100%;
  height: auto;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
}
.p-plan__hall-item-inner > p {
  margin-left: 16px;
  font-weight: 500;
}
.p-plan__hall-item-spacer {
  height: 0;
  display: block;
  width: clamp(288px, 86.9vw - 37.9px, 414px);
}
@media screen and (min-width: 520px) {
  .p-plan__hall-item-spacer {
    width: clamp(202px, 43.86vw - 26.1px, 395px);
  }
}
@media screen and (min-width: 960px) {
  .p-plan__hall-item-spacer {
    width: clamp(294px, 27.81vw + 27px, 383px);
  }
}
@media screen and (min-width: 1280px) {
  .p-plan__hall-item-spacer {
    width: clamp(250px, 18.75vw + 10px, 304px);
  }
}
.p-plan__icon-list-caption {
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 175%;
  margin-top: 0.5em;
}
.p-plan__general-price {
  width: 100%;
}
@media screen and (min-width: 1280px) {
  .p-plan__general-price > div:first-child {
    margin-top: -12px !important;
    width: clamp(258px, 4.36vw + 241.6px, 310px) !important;
  }
}

/*
p-qa-list
-----------------------------------------------------*/
.p-qa-list {
  position: relative;
}
.p-qa-list:before, .p-qa-list:after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  top: 0;
  left: 0;
}
.p-qa-list__item {
  position: relative;
  padding-top: clamp(24px, 0.67vw + 21.5px, 32px);
  padding-bottom: clamp(24px, 0.67vw + 21.5px, 32px);
}
.p-qa-list__item:before, .p-qa-list__item:after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  bottom: 0;
  left: 0;
}
.p-qa-list__item--question {
  position: relative;
  font-weight: 500;
  font-size: clamp(16px, 0.67vw + 13.5px, 24px);
  padding-left: 2.2em;
  margin-bottom: clamp(18px, 0.34vw + 16.7px, 22px);
}
.p-qa-list__item--question > span {
  position: absolute;
  display: block;
  font-family: "Cormorant Garamond";
  color: #005e8b;
  font-size: clamp(24px, 1.51vw + 18.3px, 42px);
  font-weight: 400;
  margin-right: 0.4em;
  top: 0;
  left: 0;
  line-height: 1em;
}
.p-qa-list__item--answer {
  position: relative;
  font-size: clamp(14px, 0.34vw + 12.7px, 18px);
  padding-left: 2.75em;
}
.p-qa-list__item--answer > span {
  position: absolute;
  display: block;
  font-family: "Cormorant Garamond";
  color: #982c4d;
  font-size: clamp(24px, 1.51vw + 18.3px, 42px);
  margin-right: 0.4em;
  top: 0;
  left: 0.02em;
  line-height: 1em;
}

/*
p-news-list
-----------------------------------------------------*/
.p-news-list {
  position: relative;
}
.p-news-list:before, .p-news-list:after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  top: 0;
  left: 0;
}
.p-news-list__item {
  position: relative;
}
.p-news-list__item:before, .p-news-list__item:after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  bottom: 0;
  left: 0;
}
.p-news-list__item > a {
  width: 100% !important;
  padding-top: clamp(13px, 1.09vw + 8.9px, 26px);
  padding-bottom: clamp(13px, 1.09vw + 8.9px, 26px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.5em;
}
@media screen and (min-width: 960px) {
  .p-news-list__item > a {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 48px;
  }
}
.p-news-list__item > a > time {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 0.75rem;
}
.p-news-list__item > a > p {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
}

/*
p-pagination
-----------------------------------------------------*/
.p-pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 60%;
  min-width: 330px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .p-pagination {
    width: 100%;
  }
}
.p-pagination__button-dummy {
  visibility: hidden;
  pointer-events: none;
}
.p-pagination__button {
  width: clamp(48px, 2vw + 32.6px, 64px);
  height: clamp(48px, 2vw + 32.6px, 64px);
  border-radius: 99px;
  background-color: #fff;
  -webkit-filter: drop-shadow(1px 1px 5px rgba(0, 61, 90, 0.15));
          filter: drop-shadow(1px 1px 5px rgba(0, 61, 90, 0.15));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: 500;
  background-position: center;
  background-repeat: no-repeat;
  color: #003d5a;
}
.p-pagination__button--pages {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-pagination__button--pages {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
.p-pagination__button--first {
  background-image: url(../img/news/page-skip.svg);
  rotate: -180deg;
  background-size: 30%;
  background-position: 41% center;
}
.p-pagination__button--previous {
  background-image: url(../img/news/page-next.svg);
  rotate: -180deg;
  background-size: 16%;
  background-position: 51% center;
}
.p-pagination__button--next {
  background-image: url(../img/news/page-next.svg);
  background-size: 16%;
  background-position: 51% center;
}
.p-pagination__button--last {
  background-image: url(../img/news/page-skip.svg);
  background-size: 30%;
  background-position: 41% center;
}
.p-pagination__margin {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-pagination__margin {
    display: block;
  }
}

/*
p-company-profile
-----------------------------------------------------*/
.p-company-profile {
  position: relative;
}
.p-company-profile:before, .p-company-profile:after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  top: 0;
  left: 0;
}
.p-company-profile__item {
  position: relative;
  padding-top: clamp(13px, 1.09vw + 8.9px, 26px);
  padding-bottom: clamp(13px, 1.09vw + 8.9px, 26px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 0.5em;
}
@media screen and (min-width: 768px) {
  .p-company-profile__item {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.p-company-profile__item:before, .p-company-profile__item:after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  bottom: 0;
  left: 0;
}
.p-company-profile__item > dt {
  width: 100%;
  font-weight: 500;
  font-weight: clamp(14px, 0.17vw + 13.3px, 16px);
}
@media screen and (min-width: 960px) {
  .p-company-profile__item > dt {
    width: 18%;
  }
}
.p-company-profile__item > dd {
  width: 100%;
}
@media screen and (min-width: 960px) {
  .p-company-profile__item > dd {
    width: 80%;
  }
}
.p-company-profile__item > dd > a {
  text-decoration: underline;
  text-underline-offset: 0.3em;
  text-decoration-thickness: 1px;
}

/*
p-web-order

-----------------------------------------------------*/
#p-web-order {
  width: 100%;
  max-width: 688px;
  margin-top: clamp(50px, 1.17vw + 45.7px, 64px);
}

/*
p-fax-order
-----------------------------------------------------*/
.p-fax-order__selecter {
  margin-top: clamp(16px, 0.17vw + 15.3px, 18px);
}
.p-fax-order__info-container {
  position: relative;
  margin-top: clamp(16px, 1.34vw + 11px, 32px);
  border-radius: 8px;
}
.p-fax-order__info-container::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  opacity: 0.5;
  mix-blend-mode: multiply;
  background-color: #dbeff8;
  border-radius: 8px;
  left: 0;
  top: 0;
}
.p-fax-order__info {
  display: none;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: clamp(32px, 1.51vw + 26.3px, 50px) clamp(16px, 1.34vw + 11px, 32px);
}
.p-fax-order__info#chuou {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.p-fax-order__head {
  font-size: clamp(20px, 0.34vw + 18.7px, 24px);
  font-weight: 500;
}
.p-fax-order__head > span {
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  font-weight: 400;
}
.p-fax-order__text {
  text-align: center;
  margin-top: clamp(16px, 0.17vw + 15.3px, 18px);
}
.p-fax-order__fax {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.3em;
  font-family: Oxygen;
  font-size: calc(1.68vw + 21.7px);
  font-weight: 400;
}
.p-fax-order__fax > span {
  font-size: clamp(16px, 1.34vw + 11px, 32px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.2em;
  margin-top: 0.3em;
}
.p-fax-order__fax > span::before {
  content: "";
  display: block;
  background-image: url(../img/order/fax.svg);
  width: clamp(22px, 0.84vw + 18.8px, 32px);
  height: clamp(19px, 0.67vw + 16.5px, 27px);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.p-fax-order__button {
  width: 100%;
  margin-top: clamp(16px, 0.17vw + 15.3px, 18px);
}
@media screen and (min-width: 768px) {
  .p-fax-order__button {
    width: 464px;
  }
}

/*
p-tel-order
-----------------------------------------------------*/
.p-tel-order__selecter {
  margin-top: clamp(16px, 0.17vw + 15.3px, 18px);
  display: block !important;
}
.p-tel-order__info-container {
  position: relative;
  margin-top: clamp(16px, 1.34vw + 11px, 32px);
  border-radius: 8px;
  height: 240px;
}
.p-tel-order__info {
  position: absolute;
  visibility: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  opacity: 0;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: clamp(32px, 1.51vw + 26.3px, 50px) 0;
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
  mix-blend-mode: multiply;
  width: 100%;
}
.p-tel-order__info.active {
  visibility: visible;
  opacity: 1;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
.p-tel-order__info > a {
  z-index: 10;
}
.p-tel-order__info::after {
  position: absolute;
  content: "";
  width: 100%;
  height: clamp(237px, 8.3vw + 205.9px, 336px);
  opacity: 0.5;
  mix-blend-mode: multiply;
  background-color: #dbeff8;
  border-radius: 8px;
  left: 0;
  top: 0;
  z-index: -1;
  pointer-events: none;
}
.p-tel-order__head {
  font-size: clamp(20px, 0.34vw + 18.7px, 24px);
  font-weight: 500;
}
.p-tel-order__head > span {
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  font-weight: 400;
}
.p-tel-order__text {
  text-align: center;
  margin-top: clamp(8px, 0.17vw + 7.3px, 10px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.4em;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.p-tel-order__text > span {
  border-radius: 99px;
  color: #fff;
  background-color: #003d5a;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: clamp(69px, 2.26vw + 60.6px, 96px);
  height: clamp(26px, 0.34vw + 24.7px, 30px);
}
.p-tel-order__number {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.3em;
  font-family: Oxygen;
  font-size: clamp(32px, 1.34vw + 27px, 48px);
  font-weight: 400;
}
.p-tel-order__number > span {
  font-size: clamp(16px, 1.34vw + 11px, 32px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.3em;
}
.p-tel-order__number > span::before {
  content: "";
  display: block;
  background-image: url(../img/common/tel.svg);
  width: clamp(23px, 1.09vw + 18.9px, 36px);
  height: clamp(23px, 1.09vw + 18.9px, 36px);
  background-position: center 52%;
  background-repeat: no-repeat;
  background-size: contain;
}
.p-tel-order__button {
  width: 464px;
  margin-top: clamp(16px, 0.17vw + 15.3px, 18px);
}
.p-tel-order__caption {
  margin-top: 10px;
}

/*
p-heavens
-----------------------------------------------------*/
.p-heavens__price {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.p-heavens__price > span {
  font-size: 1rem;
  font-weight: 500;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 0.75rem;
}
.p-heavens__price > span > span {
  font-size: 2.25rem;
  font-weight: 400;
  margin-left: 0.3em;
}
.p-heavens__price--tax {
  margin-top: 1.5em;
}
.p-heavens__button {
  width: 100%;
  margin-top: 32px;
}
@media screen and (min-width: 520px) {
  .p-heavens__button {
    margin: 0 auto;
    width: 80%;
    max-width: 384px;
  }
}
.p-heavens__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
}
.p-heavens__item {
  background-color: #fff;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
  padding: 7px 5%;
}
@media screen and (min-width: 1366px) {
  .p-heavens__item {
    padding: 7px 4%;
  }
}
@media screen and (min-width: 1568px) {
  .p-heavens__item {
    padding: 7px 13px;
  }
}
.p-heavens__item > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-heavens__item-figure {
  overflow: hidden;
  border-radius: 4px;
  aspect-ratio: 4/3;
  width: clamp(64px, 5.28vw + 44.2px, 127px);
  height: auto;
  display: none;
}
.p-heavens__item-figure > img {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 1568px) {
  .p-heavens__item-figure {
    display: block;
  }
}
.p-heavens__item-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: 0.4em;
}
@media screen and (min-width: 768px) {
  .p-heavens__item-content {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
@media screen and (min-width: 1366px) {
  .p-heavens__item-content {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-bottom: 0;
  }
}
@media screen and (min-width: 1568px) {
  .p-heavens__item-content {
    width: 85%;
  }
}
.p-heavens__item-plan {
  font-weight: 500;
  font-size: clamp(20px, 0.34vw + 18.7px, 24px);
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 0.4em;
  margin-bottom: 0.4em;
}
@media screen and (min-width: 1366px) {
  .p-heavens__item-plan {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    width: 34%;
    margin-bottom: 0;
    margin-top: 0;
  }
}
.p-heavens__item-general {
  font-size: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  margin-top: 0.5em;
}
.p-heavens__item-general > span {
  font-size: 0.75rem;
  margin-right: 0.3em;
  margin-left: 0.3em;
}
@media screen and (min-width: 768px) {
  .p-heavens__item-general {
    margin-top: 0;
    width: 36%;
    margin-left: 4%;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: end;
  }
}
@media screen and (min-width: 960px) {
  .p-heavens__item-general {
    width: 35%;
    margin-left: 2%;
  }
}
@media screen and (min-width: 1366px) {
  .p-heavens__item-general {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: start;
    margin-left: 0;
    width: 28%;
  }
}
.p-heavens__arrow {
  display: block;
  min-width: clamp(14px, 0.17vw + 13.3px, 16px);
  height: clamp(14px, 0.17vw + 13.3px, 16px);
  background-image: url(../img/common/arrow1.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 50%;
  width: 3%;
  rotate: 90deg;
}
@media screen and (min-width: 768px) {
  .p-heavens__arrow {
    rotate: 0deg;
  }
}
@media screen and (min-width: 1366px) {
  .p-heavens__arrow {
    margin-right: 4px;
    margin-left: -5px;
  }
}
.p-heavens__item-member {
  font-size: clamp(22px, 0.84vw + 18.8px, 32px);
  font-weight: 500;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  letter-spacing: -0.03em;
  width: 100%;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 0.3em;
}
@media screen and (min-width: 768px) {
  .p-heavens__item-member {
    margin-bottom: 0;
    width: 54%;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: start;
  }
}
@media screen and (min-width: 960px) {
  .p-heavens__item-member {
    width: 57%;
  }
}
@media screen and (min-width: 1366px) {
  .p-heavens__item-member {
    width: 45%;
  }
}
.p-heavens__icon {
  text-align: center;
  font-size: 0.625rem;
  line-height: 150%;
  background-color: #dbeff8;
  border-radius: 99px;
  padding: 5px 10px;
  display: block;
  width: 92px;
  letter-spacing: -0.02em;
  margin-right: 0.7em;
}
@media screen and (min-width: 768px) {
  .p-heavens__icon {
    width: 105px;
    padding: 8px 16px;
  }
}
.p-heavens__tax {
  margin-left: 0.5em;
  font-size: 0.75rem;
  margin-top: 1em;
}
@media screen and (min-width: 768px) {
  .p-heavens__tax {
    margin-right: 2em;
  }
}
@media screen and (min-width: 1366px) {
  .p-heavens__tax {
    margin-top: 1.5em;
  }
}

/*
p-contact-form
-----------------------------------------------------*/
.p-form {
  margin-top: clamp(100px, 4.19vw + 84.3px, 150px);
  width: 100%;
  position: relative;
}
.p-form--contact > div {
  margin-top: -60px;
}
.p-form__BG {
  display: block;
  position: absolute;
  z-index: -1000;
  width: 120%;
  height: 107%;
  border-radius: 16px;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
  opacity: 0.5;
  background: #dbeff8;
  mix-blend-mode: multiply;
}
.p-form__BG--jizen {
  height: 103%;
}
.p-form__jizen-link {
  z-index: 0;
  border: 1px solid #005e8b;
  border-radius: 4px;
  background-color: #fff;
  min-width: clamp(171px, 7.12vw + 144.4px, 256px);
  width: 100%;
  height: clamp(50px, 1.17vw + 45.7px, 64px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  width: 100%;
  color: #005e8b;
  font-weight: 500;
  text-align: center;
  z-index: 1;
}
@media screen and (min-width: 960px) {
  .p-form__jizen-link {
    position: absolute;
    width: 40%;
    top: 1.8em;
    right: 0;
  }
}
.p-form__inner {
  margin-top: 40px;
}
.p-form__inner > dd > p {
  position: relative;
}
.p-form__inner > dt > p {
  font-weight: 500;
  margin-bottom: 12px;
}
.p-form__inner > dd > p > span > input {
  border: none;
  background-color: #fff;
  border-radius: 4px;
  height: clamp(50px, 0.84vw + 46.8px, 60px);
  width: 100%;
  padding: 0 1em;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
}
.p-form__inner > dd > div > p > span > input {
  border: none;
  background-color: #fff;
  border-radius: 4px;
  height: clamp(50px, 0.84vw + 46.8px, 60px);
  width: 100%;
  padding: 0 1em;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  margin-top: 1.2em;
}
.p-form__inner > dd > p > span input[type=checkbox] {
  border: none;
  background-color: #fff;
  border-radius: 4px;
  height: clamp(24px, 0.17vw + 23.3px, 26px);
  width: clamp(24px, 0.17vw + 23.3px, 26px);
  margin-right: 0.5em;
  margin-top: 0.5em;
}
.p-form__inner > dd > p > span input[type=checkbox] + span {
  margin-right: 1em;
}
.p-form__inner > dd > p > span > textarea {
  border: none;
  background-color: #fff;
  border-radius: 4px;
  height: clamp(205px, 17.18vw + 140.6px, 410px);
  width: 100%;
  padding: 1em 1em;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
}
.p-form__inner > div {
  margin-bottom: 12px;
}
.p-form__inner > div > dt > p {
  font-weight: 400;
  font-size: 0.875rem;
  margin-bottom: 8px;
}
.p-form__inner > div > dd > p > span > input {
  border: none;
  background-color: #fff;
  border-radius: 4px;
  height: clamp(50px, 0.84vw + 46.8px, 60px);
  width: 100%;
  padding: 0 1em;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
}
.p-form__inner--address > p:first-child > span, .p-form__inner--address > p:first-child > br {
  display: none;
}
.p-form__req {
  color: #982c4d;
  font-size: 0.875rem;
  font-weight: 400;
  margin-left: 0.3em;
}
.p-form__head {
  font-weight: 500;
  margin-bottom: 12px;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  display: block;
}
.p-form__reCAPTCHA {
  font-size: 0.625rem;
  font-weight: 400;
  text-align: center;
}
.p-form__box--submit {
  margin-top: clamp(50px, 1.17vw + 45.7px, 64px);
}
.p-form__input--checkbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1em;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
.p-form__input--checkbox > span {
  margin: 0;
}
.p-form__input--comment {
  text-align: center;
  line-height: 2.5em;
}
.p-form__input--comment > br {
  display: none;
}
.p-form__input--comment > a {
  text-decoration: underline;
  text-underline-offset: 0.3em;
}
.p-form__input--submit {
  max-width: 384px;
  width: 100%;
  display: block !important;
  border: none !important;
  color: #fff !important;
  margin: clamp(32px, 1.51vw + 26.3px, 50px) auto;
  font-family: "Oxygen", "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
  line-height: 1.75;
  letter-spacing: 0.04em;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  cursor: pointer;
  -webkit-transition: 0.4s all ease-out;
  transition: 0.4s all ease-out;
}

@media (hover: hover) {
  .p-form__input--submit:hover {
    opacity: 0.8;
  }
  .p-form__inner > dd > p > a:hover {
    scale: 1.005;
    -webkit-box-shadow: 3px 3px 5px 0px rgba(0, 61, 90, 0.3);
            box-shadow: 3px 3px 5px 0px rgba(0, 61, 90, 0.3);
  }
}
/*
p-hall-googlemap
-----------------------------------------------------*/
.p-hall-googlemap {
  overflow: hidden;
  aspect-ratio: 3/4;
  width: 100%;
  height: auto;
}
@media screen and (min-width: 768px) {
  .p-hall-googlemap {
    aspect-ratio: 4/3;
    width: 100%;
    height: auto;
  }
}
.p-hall-googlemap > iframe {
  width: 100%;
  height: 100%;
  border-radius: 8px;
}

/*
p-hall-card-lower
-----------------------------------------------------*/
.p-hall-card-lower {
  border-radius: 4px;
  background-color: #fff;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
}
.p-hall-card-lower__inner {
  display: -ms-grid;
  display: grid;
  padding: clamp(12px, -0.34vw + 17.3px, 16px);
  -ms-grid-columns: 3fr 5fr 1fr;
  grid-template-columns: 3fr 5fr 1fr;
  -ms-grid-rows: (auto)[3];
  grid-template-rows: repeat(3, auto);
}
.p-hall-card-lower__inner > *:nth-child(1) {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
}
.p-hall-card-lower__inner > *:nth-child(2) {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
}
.p-hall-card-lower__inner > *:nth-child(3) {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
}
.p-hall-card-lower__inner > *:nth-child(4) {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
}
.p-hall-card-lower__inner > *:nth-child(5) {
  -ms-grid-row: 2;
  -ms-grid-column: 2;
}
.p-hall-card-lower__inner > *:nth-child(6) {
  -ms-grid-row: 2;
  -ms-grid-column: 3;
}
.p-hall-card-lower__inner > *:nth-child(7) {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
}
.p-hall-card-lower__inner > *:nth-child(8) {
  -ms-grid-row: 3;
  -ms-grid-column: 2;
}
.p-hall-card-lower__inner > *:nth-child(9) {
  -ms-grid-row: 3;
  -ms-grid-column: 3;
}
@media screen and (min-width: 600px) {
  .p-hall-card-lower__inner {
    -ms-grid-columns: 4fr 5fr 9fr 1fr;
    grid-template-columns: 4fr 5fr 9fr 1fr;
    -ms-grid-rows: (auto)[2];
    grid-template-rows: repeat(2, auto);
  }
  .p-hall-card-lower__inner > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-hall-card-lower__inner > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .p-hall-card-lower__inner > *:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-hall-card-lower__inner > *:nth-child(4) {
    -ms-grid-row: 1;
    -ms-grid-column: 4;
  }
  .p-hall-card-lower__inner > *:nth-child(5) {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .p-hall-card-lower__inner > *:nth-child(6) {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-hall-card-lower__inner > *:nth-child(7) {
    -ms-grid-row: 2;
    -ms-grid-column: 3;
  }
  .p-hall-card-lower__inner > *:nth-child(8) {
    -ms-grid-row: 2;
    -ms-grid-column: 4;
  }
}
@media screen and (min-width: 960px) {
  .p-hall-card-lower__inner {
    -ms-grid-columns: 4fr 9fr 1fr;
    grid-template-columns: 4fr 9fr 1fr;
    -ms-grid-rows: (auto)[3];
    grid-template-rows: repeat(3, auto);
  }
  .p-hall-card-lower__inner > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-hall-card-lower__inner > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .p-hall-card-lower__inner > *:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-hall-card-lower__inner > *:nth-child(4) {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .p-hall-card-lower__inner > *:nth-child(5) {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-hall-card-lower__inner > *:nth-child(6) {
    -ms-grid-row: 2;
    -ms-grid-column: 3;
  }
  .p-hall-card-lower__inner > *:nth-child(7) {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-hall-card-lower__inner > *:nth-child(8) {
    -ms-grid-row: 3;
    -ms-grid-column: 2;
  }
  .p-hall-card-lower__inner > *:nth-child(9) {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
  }
}
@media screen and (min-width: 1280px) {
  .p-hall-card-lower__inner {
    -ms-grid-columns: 4fr 3fr 6fr 1fr;
    grid-template-columns: 4fr 3fr 6fr 1fr;
    -ms-grid-rows: (auto)[2];
    grid-template-rows: repeat(2, auto);
  }
  .p-hall-card-lower__inner > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-hall-card-lower__inner > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .p-hall-card-lower__inner > *:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-hall-card-lower__inner > *:nth-child(4) {
    -ms-grid-row: 1;
    -ms-grid-column: 4;
  }
  .p-hall-card-lower__inner > *:nth-child(5) {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .p-hall-card-lower__inner > *:nth-child(6) {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-hall-card-lower__inner > *:nth-child(7) {
    -ms-grid-row: 2;
    -ms-grid-column: 3;
  }
  .p-hall-card-lower__inner > *:nth-child(8) {
    -ms-grid-row: 2;
    -ms-grid-column: 4;
  }
}
.p-hall-card-lower__figure {
  -ms-grid-row: 1;
  -ms-grid-row-span: 2;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
  grid-area: 1/1/3/2;
  position: relative;
  aspect-ratio: 4/3;
  width: clamp(59px, 31.72vw - 59.9px, 105px);
  height: auto;
  border-radius: 4px;
  overflow: hidden;
}
@media screen and (min-width: 600px) {
  .p-hall-card-lower__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-area: 1/1/3/2;
    width: clamp(64px, 7.63vw + 35.4px, 155px);
  }
}
@media screen and (min-width: 960px) {
  .p-hall-card-lower__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-area: 1/1/4/2;
    width: 80%;
  }
}
@media screen and (min-width: 1280px) {
  .p-hall-card-lower__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-area: 1/1/3/2;
    width: clamp(64px, 7.63vw + 35.4px, 155px);
  }
}
.p-hall-card-lower__figure > img {
  position: absolute;
  width: 100%;
  height: auto;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
}
.p-hall-card-lower__name {
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  grid-area: 1/2/2/3;
  font-size: clamp(16px, 0.67vw + 13.5px, 24px);
  font-weight: 500;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: -5px;
}
@media screen and (min-width: 600px) {
  .p-hall-card-lower__name {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 1/2/3/3;
    margin-left: clamp(-32px, -3.51vw + 23px, 2px);
    margin-top: 0;
  }
}
@media screen and (min-width: 960px) {
  .p-hall-card-lower__name {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 1/2/2/3;
    margin-left: -16px;
  }
}
@media screen and (min-width: 1280px) {
  .p-hall-card-lower__name {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 1/2/3/3;
    margin-left: clamp(-32px, -3.51vw + 23px, 2px);
    margin-top: inherit;
  }
}
.p-hall-card-lower__address {
  -ms-grid-row: 2;
  -ms-grid-row-span: 1;
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  grid-area: 2/2/3/3;
  position: relative;
  padding-left: clamp(12px, 0.92vw + 8.6px, 23px);
  font-size: clamp(10px, 0.67vw + 7.5px, 18px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 600px) {
  .p-hall-card-lower__address {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-area: 1/3/2/4;
    height: clamp(32px, 1vw + 24.3px, 40px);
    margin-top: auto;
    margin-bottom: 0;
  }
}
@media screen and (min-width: 960px) {
  .p-hall-card-lower__address {
    margin-left: -16px;
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 2/2/3/3;
  }
}
@media screen and (min-width: 1280px) {
  .p-hall-card-lower__address {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-area: 1/3/2/4;
  }
}
.p-hall-card-lower__address:before {
  content: "";
  position: absolute;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  top: 50%;
  display: block;
  background-image: url(../img/common/pin.svg);
  width: clamp(12px, 0.92vw + 8.6px, 23px);
  height: clamp(12px, 0.92vw + 8.6px, 23px);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.p-hall-card-lower__tag-box {
  -ms-grid-row: 3;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  grid-area: 3/1/4/3;
  margin-top: clamp(12px, -0.17vw + 14.7px, 14px);
  margin-left: clamp(-12px, -0.5vw - 4.2px, -6px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: clamp(4px, 0.34vw + 2.7px, 8px);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 600px) {
  .p-hall-card-lower__tag-box {
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-area: 2/3/3/4;
    height: clamp(32px, 1vw + 24.3px, 40px);
    margin-top: 0;
    margin-bottom: auto;
  }
}
@media screen and (min-width: 960px) {
  .p-hall-card-lower__tag-box {
    -ms-grid-row: 3;
    -ms-grid-row-span: 1;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-area: 3/2/4/3;
    margin-left: clamp(-12px, -1.03vw - 2.1px, -6px);
  }
}
@media screen and (min-width: 1280px) {
  .p-hall-card-lower__tag-box {
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-area: 2/3/3/4;
    margin-top: 0;
  }
}
.p-hall-card-lower__arrow {
  -ms-grid-row: 1;
  -ms-grid-row-span: 3;
  -ms-grid-column: 3;
  -ms-grid-column-span: 1;
  grid-area: 1/3/4/4;
  width: clamp(8px, 0.67vw + 5.5px, 16px);
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-right: 0;
  margin-left: auto;
}
@media screen and (min-width: 600px) {
  .p-hall-card-lower__arrow {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 4;
    -ms-grid-column-span: 1;
    grid-area: 1/4/3/5;
    margin-right: clamp(8px, 2.22vw - 5.3px, 16px);
  }
}
@media screen and (min-width: 960px) {
  .p-hall-card-lower__arrow {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-area: 1/3/4/4;
  }
}
@media screen and (min-width: 1280px) {
  .p-hall-card-lower__arrow {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 4;
    -ms-grid-column-span: 1;
    grid-area: 1/4/3/5;
    margin-right: clamp(8px, 2.22vw - 5.3px, 16px);
  }
}
.p-hall-card-lower__arrow > img {
  width: 100%;
  height: 100%;
}

/*
p-head-box
-----------------------------------------------------*/
.p-head-box {
  margin: 0 clamp(29px, 16.79vw - 33.9px, 95px);
}
@media screen and (min-width: 768px) {
  .p-head-box {
    margin: 0 clamp(43px, 5.78vw + 21.4px, 112px);
  }
}
.p-head-box__inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1.1em;
}
@media screen and (min-width: 600px) {
  .p-head-box__inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.p-head-box__inner:before, .p-head-box__inner::after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  bottom: -16px;
  left: 0;
}
.p-head-box__inner:before {
  mix-blend-mode: color-burn;
}
.p-head-box__inner:after {
  mix-blend-mode: multiply;
}
.p-head-box__tag-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: clamp(4px, 1.01vw + 0.2px, 16px);
}
.p-head-box__description {
  margin-top: calc(16px + 1em);
}

/*
p-hall
-----------------------------------------------------*/
@media screen and (min-width: 1280px) {
  .p-hall__slider {
    width: 75.1%;
  }
}
.p-hall__slider-item {
  aspect-ratio: 4/3;
  height: auto;
  border-radius: 4px;
  overflow: hidden;
}
.p-hall__slider-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 8px;
}
@media screen and (min-width: 1280px) {
  .p-hall__slider-container {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    width: 100%;
  }
}
@media screen and (min-width: 1280px) {
  .p-hall__slider-thumbs {
    width: 24.2%;
  }
}
.p-hall__slider-thmb-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}
@media screen and (min-width: 1280px) {
  .p-hall__slider-thmb-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 8px;
  }
}
.p-hall__slider-thmb-item {
  aspect-ratio: 4/3;
  height: auto;
  border-radius: 4px;
  overflow: hidden;
  width: 100%;
  background-position: center;
  background-repeat: no-repeat;
}
.p-hall__access {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 32px;
}
@media screen and (min-width: 1280px) {
  .p-hall__access {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 0;
  }
}
.p-hall__access > dl {
  width: 100%;
}
@media screen and (min-width: 1280px) {
  .p-hall__access > dl {
    width: 49%;
  }
}
.p-hall__map {
  aspect-ratio: 3/4;
  width: 100%;
  border-radius: 4px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-hall__map {
    aspect-ratio: 16/9;
  }
}
@media screen and (min-width: 1280px) {
  .p-hall__map {
    aspect-ratio: 1/1;
    width: 45%;
  }
}
.p-hall__map > iframe {
  width: 100%;
  height: 100%;
}
.p-hall__list {
  position: relative;
}
.p-hall__list:before, .p-hall__list:after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  top: 0;
  left: 0;
}
.p-hall__list:before {
  mix-blend-mode: color-burn;
}
.p-hall__list:after {
  mix-blend-mode: multiply;
}
.p-hall__list-item {
  position: relative;
  padding: clamp(16px, 0.67vw + 13.5px, 24px) 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 600px) {
  .p-hall__list-item {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.p-hall__list-item:before, .p-hall__list-item:after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  bottom: 0;
  left: 0;
}
.p-hall__list-item:before {
  mix-blend-mode: color-burn;
}
.p-hall__list-item:after {
  mix-blend-mode: multiply;
}
.p-hall__list-item > dt {
  width: 100%;
  font-size: 1rem;
  font-weight: 500;
}
@media screen and (min-width: 600px) {
  .p-hall__list-item > dt {
    width: 25%;
  }
}
.p-hall__list-item > dt > span {
  display: block;
  font-size: 0.875rem;
  margin-left: -0.5em;
}
.p-hall__list-item > dd {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 600px) {
  .p-hall__list-item > dd {
    width: 73%;
  }
}
@media screen and (min-width: 600px) {
  .p-hall__list-item--tel {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.p-hall__list-tel {
  font-size: 1.5rem;
  font-weight: 500;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5em;
}
.p-hall__list-tel > span {
  font-size: 0.75rem;
  color: #005e8b;
  border: 1px solid #005e8b;
  border-radius: 99px;
  text-align: center;
  width: 87px;
  height: 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  letter-spacing: -0.02em;
}
.p-hall__facility {
  margin-top: clamp(32px, 2.68vw + 22px, 64px);
}
.p-hall__h3 {
  font-size: clamp(20px, 0.67vw + 17.5px, 28px);
  font-weight: 500;
  margin-bottom: 1em;
}
@media screen and (min-width: 1280px) {
  .p-hall__h3 {
    font-weight: 400;
    font-family: "Zen Old Mincho";
  }
}
.p-hall__figure-box {
  margin-top: clamp(20px, 0.25vw + 19.1px, 23px);
  margin-bottom: clamp(50px, 1.17vw + 45.7px, 64px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  row-gap: 36px;
}
.p-hall__figure {
  width: 100%;
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
  overflow: hidden;
}
@media screen and (min-width: 600px) {
  .p-hall__figure {
    width: 49.5%;
  }
}
.p-hall__figure > img {
  width: 100%;
  height: auto;
}
.p-hall__figure > figcaption {
  font-size: 1rem;
  font-weight: 500;
}
.p-hall__figure--single {
  aspect-ratio: 16/9;
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
  overflow: hidden;
  width: 100% !important;
  position: relative;
}
.p-hall__figure--single > img {
  position: absolute;
  width: 100%;
  height: auto;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
}
.p-hall__table-container {
  width: 100%;
  overflow-x: scroll;
}
.p-hall__table {
  position: relative;
}
.p-hall__table::after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.7;
  background-color: #fff;
  mix-blend-mode: screen;
  z-index: -1;
  border-radius: 0 0 4px 4px;
}
.p-hall__table > caption {
  position: absolute;
  visibility: hidden;
  height: 0;
}
.p-hall__table > tbody {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.p-hall__table-hr {
  height: clamp(64px, 1.17vw + 59.7px, 78px);
}
.p-hall__table-hr > th:first-child::after {
  border-radius: 4px 0 0 0;
}
.p-hall__table-hr > th:last-child::after {
  border-radius: 0 4px 0 0;
}
.p-hall__table-tr {
  height: clamp(64px, 1.17vw + 59.7px, 78px);
}
.p-hall__table-hr-th {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
  line-height: 1.5em;
  letter-spacing: 0.04em;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  padding: 0 23px;
  white-space: nowrap;
  text-align: center;
  vertical-align: middle;
  position: relative;
}
.p-hall__table-hr-th::after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.7;
  background-color: #137caf;
  mix-blend-mode: multiply;
  z-index: -1;
}
.p-hall__table-th {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.75;
  letter-spacing: 0.04em;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  white-space: nowrap;
  padding: 0 25px;
  text-align: center;
  vertical-align: middle;
  position: relative;
}
.p-hall__table-th > a {
  -webkit-transition: opacity 0.3s ease-in-out;
  transition: opacity 0.3s ease-in-out;
  text-underline-offset: 0.3em;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  display: block;
  width: 100%;
  height: 100%;
}
.p-hall__table-th:before, .p-hall__table-th::after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  top: 0;
  left: 0;
}
.p-hall__table-th:before {
  mix-blend-mode: color-burn;
}
.p-hall__table-th:after {
  mix-blend-mode: multiply;
}
.p-hall__table-td {
  font-family: "Oxygen", "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.75;
  letter-spacing: 0.04em;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  text-align: center;
  vertical-align: middle;
  position: relative;
}
.p-hall__table-td:before, .p-hall__table-td::after {
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  width: 100%;
  background-color: #137caf;
  opacity: 0.3;
  top: 0;
  left: 0;
}
.p-hall__table-td:before {
  mix-blend-mode: color-burn;
}
.p-hall__table-td:after {
  mix-blend-mode: multiply;
}
.p-hall__table-td > span {
  display: block;
  font-size: 12px;
  margin-top: -0.2em;
  line-height: 1.2em;
}
.p-hall__jump {
  max-width: 384px;
  margin-left: auto;
  margin-right: auto;
}

@media (hover: hover) {
  .p-hall__table-th > a:hover {
    opacity: 0.7;
  }
}
/*
p-after
-----------------------------------------------------*/
.p-after__support-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: calc(0.67vw + 5.5px);
}
.p-after__support-list:after {
  content: "";
  display: block;
  height: 0;
  width: calc((100% - (0.67vw + 5.5px) * 2) / 3);
}
@media screen and (min-width: 768px) {
  .p-after__support-list:after {
    width: calc((100% - (0.67vw + 5.5px) * 3) / 4);
  }
}
@media screen and (min-width: 960px) {
  .p-after__support-list:after {
    width: calc((100% - (0.67vw + 5.5px) * 3) / 4);
  }
}
.p-after__support-item {
  width: calc((100% - (0.67vw + 5.5px) * 2) / 3);
}
@media screen and (min-width: 768px) {
  .p-after__support-item {
    width: calc((100% - (0.67vw + 5.5px) * 3) / 4);
  }
}
@media screen and (min-width: 960px) {
  .p-after__support-item {
    width: calc((100% - (0.67vw + 5.5px) * 3) / 4);
  }
}
.p-after__support-icon {
  position: relative;
  width: 100%;
  height: auto;
  border-radius: 4px;
  overflow: hidden;
}
.p-after__support-icon:after {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 4px;
  z-index: -1;
  background-color: #dbeff8;
  mix-blend-mode: multiply;
  opacity: 0.5;
  top: 0;
  left: 0;
}
.p-after__support-icon > img {
  width: 100%;
  height: auto;
}
.p-after__support-icon > figcaption {
  position: absolute;
  text-align: center;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  left: 50%;
  bottom: clamp(-9px, 4.33vw - 25.2px, 8px);
  white-space: nowrap;
  font-size: 10px;
  line-height: 1.5em;
  letter-spacing: -0.05em;
}
@media screen and (min-width: 520px) {
  .p-after__support-icon > figcaption {
    letter-spacing: 0;
  }
}
@media screen and (min-width: 768px) {
  .p-after__support-icon > figcaption {
    bottom: clamp(-8px, 3.32vw - 33.5px, 9px);
    font-size: clamp(12px, 0.17vw + 11.3px, 14px);
  }
}
@media screen and (min-width: 960px) {
  .p-after__support-icon > figcaption {
    bottom: -8px;
  }
}
@media screen and (min-width: 1280px) {
  .p-after__support-icon > figcaption {
    bottom: clamp(-8px, 1vw - 15.7px, 0px);
  }
}
.p-after__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: clamp(25px, 0.59vw + 22.7px, 32px);
}
@media screen and (min-width: 600px) {
  .p-after__inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: none;
  }
}
.p-after__inner > figure {
  width: 100%;
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
  overflow: hidden;
  position: relative;
}
@media screen and (min-width: 600px) {
  .p-after__inner > figure {
    width: 50%;
  }
}
.p-after__inner > figure > img {
  width: 100%;
  height: auto;
}
.p-after__inner > p, .p-after__inner > div {
  width: 100%;
}
@media screen and (min-width: 600px) {
  .p-after__inner > p, .p-after__inner > div {
    width: 46%;
  }
}
.p-after__inner--additional {
  position: relative;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  padding: clamp(32px, 2.68vw + 22px, 64px);
}
.p-after__inner--additional::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 0.3;
  border-radius: 8px;
  mix-blend-mode: multiply;
  background-color: #dbeff8;
}
.p-after__inner--merit {
  position: relative;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  padding: clamp(32px, 2.68vw + 22px, 64px);
}
.p-after__inner--merit::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: -1;
  background-color: #fff;
  mix-blend-mode: screen;
  opacity: 0.5;
  border-radius: 8px;
}
.p-after__step-left {
  width: clamp(50px, 7.86vw + 20.5px, 96px);
  position: relative;
}
@media screen and (min-width: 960px) {
  .p-after__step-left {
    width: clamp(50px, 3.86vw + 35.5px, 96px);
  }
}
.p-after__step-left::before {
  content: "";
  display: block;
  position: absolute;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  top: clamp(50px, 7.86vw + 20.5px, 96px);
  left: 50%;
  width: 1px;
  height: calc(100% - clamp(50px, 7.86vw + 20.5px, 96px) + clamp(32px, 3.08vw + 20.4px, 50px) + 2px);
  background-color: #005e8b;
  opacity: 0.3;
}
@media screen and (min-width: 960px) {
  .p-after__step-left::before {
    top: clamp(50px, 3.86vw + 35.5px, 96px);
  }
}
.p-after__step-left--last::before {
  content: none;
}
.p-after__step-left.-red::before {
  background-color: #982c4d;
}
.p-after__step-num {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: #fff;
  width: clamp(50px, 7.86vw + 20.5px, 96px);
  height: clamp(50px, 7.86vw + 20.5px, 96px);
  aspect-ratio: 1/1;
  border-radius: 999px;
  border: 1px solid #005e8b;
  font-family: Oxygen;
  font-size: clamp(18px, 1.17vw + 13.7px, 32px);
  color: #005e8b;
}
@media screen and (min-width: 768px) {
  .p-after__step-num {
    border: 2px solid #005e8b;
  }
}
@media screen and (min-width: 960px) {
  .p-after__step-num {
    width: clamp(50px, 3.86vw + 35.5px, 96px);
    height: clamp(50px, 3.86vw + 35.5px, 96px);
  }
}
.p-after__step-num.-red {
  border: 1px solid #982c4d;
  color: #982c4d;
}
@media screen and (min-width: 768px) {
  .p-after__step-num.-red {
    border: 2px solid #982c4d;
  }
}
.p-after__step-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.p-after__step-item {
  padding-bottom: clamp(32px, 1.51vw + 26.3px, 50px);
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-after__step-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 77%;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: clamp(16px, 4.07vw + 0.7px, 32px);
}
@media screen and (min-width: 768px) {
  .p-after__step-inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    width: 83%;
    gap: none;
  }
}
.p-after__step-text {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-after__step-text {
    width: 50%;
  }
}
.p-after__step-text > h3 {
  font-size: clamp(16px, 0.34vw + 14.7px, 20px);
  font-weight: 500;
  margin-top: clamp(14px, 1.34vw + 9px, 30px);
  margin-bottom: 0.8em;
}
.p-after__step-text > h4 {
  font-size: clamp(16px, 0.34vw + 14.7px, 20px);
  font-weight: 500;
  margin-top: clamp(14px, 1.34vw + 9px, 30px);
  margin-bottom: 0.8em;
}
.p-after__step-text > p {
  font-size: 0.875rem;
  line-height: 175%;
}
.p-after__step-figure {
  width: 100%;
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
  overflow: hidden;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-after__step-figure {
    width: 45%;
  }
}
.p-after__step-figure > img {
  width: 100%;
  height: auto;
}
.p-after__button {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) {
  .p-after__button {
    width: 464px;
  }
}

/*
p-sptop-fixed
-----------------------------------------------------*/
.p-sptop-fixed {
  position: fixed;
  bottom: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  left: 50%;
  width: 350px;
  height: 50px;
  border-radius: 4px 4px 0 0;
  background-color: #982c4d;
  z-index: 100000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-sptop-fixed {
    -webkit-transform: inherit;
            transform: inherit;
    margin-right: clamp(12px, 1.68vw + 5.7px, 32px);
    right: 0;
    left: auto;
    height: 64px;
  }
}
@media screen and (min-width: 1280px) {
  .p-sptop-fixed {
    display: none;
  }
}
.p-sptop-fixed__tel {
  position: relative;
  font-size: 0.8125rem;
  height: 100%;
  width: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 9px;
}
.p-sptop-fixed__tel > span {
  display: block;
  background-image: url(../img/top/tel-wh.svg);
  width: 29px;
  height: 29px;
  margin-top: 0.2em;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  margin-left: -0.2em;
}
.p-sptop-fixed__tel > p {
  color: #fff;
}
.p-sptop-fixed__tel > p > span {
  margin-left: -0.3em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 99px;
  font-weight: 400;
  font-size: 0.625rem;
  border: 1px solid #fff;
  width: 86px;
  height: 16px;
  letter-spacing: -0.02em;
}
.p-sptop-fixed__tel::after {
  content: "";
  display: block;
  position: absolute;
  width: 1px;
  height: 100%;
  right: 0;
  top: 0;
  background-color: #fff;
}
.p-sptop-fixed__hurry {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 50%;
  height: 100%;
}
.p-sptop-fixed__hurry > p {
  font-size: 1rem;
  font-weight: 500;
  color: #fff;
}
.p-sptop-fixed__hurry > p > span {
  position: absolute;
  background-image: url(../img/top/>_wh.svg);
  width: 7.8px;
  height: 7.8px;
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  top: 50%;
  right: 1.4em;
}

/*
p-news-single
-----------------------------------------------------*/
@media screen and (min-width: 768px) {
  .p-news-single__head {
    margin-left: clamp(32px, 6vw - 14.1px, 80px);
    margin-right: clamp(32px, 6vw - 14.1px, 80px);
  }
}
.p-news-single__thumb {
  width: 100%;
  aspect-ratio: 4/3;
  height: auto;
}
.p-news-single__thumb > img {
  width: 100%;
  height: auto;
}
.p-news-single__text-box {
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
}
.p-news-single__text-box > p > a {
  text-decoration: underline;
  text-underline-offset: 0.3em;
  text-decoration-thickness: 1px;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
.p-news-single__text-box > p > em {
  font-style: italic;
  font-weight: 400;
}
.p-news-single__text-box > ul {
  margin-left: 2.2em;
}
.p-news-single__text-box > ul > li {
  list-style-type: disc !important;
}
.p-news-single__text-box > ol {
  margin-left: 2.2em;
}
.p-news-single__text-box > ol > li {
  list-style-type: decimal !important;
}
.p-news-single__text-box > h1 {
  font-size: clamp(30px, 1.01vw + 26.2px, 42px);
  font-family: "Zen Old Mincho";
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 1.5em;
}
.p-news-single__text-box > h1 > em {
  font-weight: 400;
}
.p-news-single__text-box > h2 {
  font-size: clamp(26px, 0.84vw + 22.8px, 36px);
  font-family: "Zen Old Mincho";
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 1.5em;
}
.p-news-single__text-box > h2 > em {
  font-weight: 400;
}
.p-news-single__text-box > h3 {
  font-size: clamp(22px, 0.84vw + 18.8px, 32px);
  font-family: "Zen Old Mincho";
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 1.5em;
}
.p-news-single__text-box > h3 > em {
  font-weight: 400;
}
.p-news-single__text-box > h4 {
  font-size: clamp(20px, 0.34vw + 18.7px, 24px);
  font-family: "Zen Old Mincho";
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 1.5em;
}
.p-news-single__text-box > h4 > em {
  font-weight: 400;
}
.p-news-single__text-box > blockquote {
  font-style: italic;
  opacity: 0.9;
  font-size: clamp(14px, 0.17vw + 13.3px, 16px);
  font-weight: 400;
}
.p-news-single__figure-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-column-gap: 2%;
     -moz-column-gap: 2%;
          column-gap: 2%;
  row-gap: 2em;
  margin-bottom: clamp(50px, 1.17vw + 45.7px, 64px);
}
.p-news-single__figure {
  width: 100%;
}
.p-news-single__figure > img {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 520px) {
  .p-news-single__figure {
    width: 49%;
  }
}

@media (hover: hover) {
  .p-news-single__text-box > p > a:hover {
    opacity: 0.3;
  }
}
h2.wp-block-heading {
  font-size: clamp(26px, 0.84vw + 22.8px, 36px);
  font-family: "Zen Old Mincho";
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 1.5em;
}
h2.wp-block-heading > em {
  font-weight: 400;
}

h3.wp-block-heading {
  font-size: clamp(22px, 0.84vw + 18.8px, 32px);
  font-family: "Zen Old Mincho";
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 1.5em;
}
h3.wp-block-heading > em {
  font-weight: 400;
}

h4.wp-block-heading {
  font-size: clamp(20px, 0.34vw + 18.7px, 24px);
  font-family: "Zen Old Mincho";
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 1.5em;
}
h4.wp-block-heading > em {
  font-weight: 400;
}

ol.wp-block-list {
  margin-left: 2.2em;
}
ol.wp-block-list > li {
  list-style-type: decimal !important;
}

ul.wp-block-list {
  margin-left: 2.2em;
}
ul.wp-block-list > li {
  list-style-type: disc !important;
}

blockquote.p-block-quote-is-layout-flow {
  font-style: italic;
  opacity: 0.9;
  font-size: clamp(14px, 0.17vw + 13.3px, 16px);
  font-weight: 400;
}

.wp-block-lazyblock-news-single ~ p > a {
  text-decoration: underline;
  text-underline-offset: 0.3em;
  text-decoration-thickness: 1px;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}

/*
p-banner
-----------------------------------------------------*/
.p-banner {
  position: relative;
}
.p-banner::after {
  content: "";
  display: block;
  position: absolute;
  background-color: #fff;
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
  opacity: 0.7;
  mix-blend-mode: screen;
}
.p-banner__inner {
  padding: 32px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: clamp(25px, 0.77vw + 22.1px, 32px);
}
@media screen and (min-width: 960px) {
  .p-banner__inner {
    gap: none;
    padding: clamp(32px, 1.51vw + 26.3px, 50px) clamp(32px, 2.68vw + 22px, 64px);
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.p-banner__text-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 960px) {
  .p-banner__text-box {
    width: 60%;
    min-height: 270px;
    height: auto;
  }
}
@media screen and (min-width: 1280px) {
  .p-banner__text-box {
    width: 46%;
  }
}
.p-banner__text-box > h4 {
  font-family: "Zen Old Mincho";
  font-size: clamp(26px, 0.84vw + 22.8px, 36px);
  font-weight: 500;
  line-height: 150%;
  margin-bottom: 30px;
}
.p-banner__text-box > p {
  margin-bottom: clamp(25px, 0.75vw + 22.2px, 34px);
}
.p-banner__img-box {
  width: 100%;
  position: relative;
  height: clamp(240px, 28.73vw + 132.3px, 500px);
}
@media screen and (min-width: 960px) {
  .p-banner__img-box {
    min-height: 270px;
    height: auto;
    width: 38%;
  }
}
@media screen and (min-width: 1280px) {
  .p-banner__img-box {
    width: 46%;
  }
}
.p-banner__img1 {
  position: relative;
  width: clamp(200px, 11.49vw + 156.9px, 304px);
  height: clamp(138px, 7.73vw + 109.1px, 208px);
  border-radius: 4px;
  overflow: hidden;
  margin-left: 0;
  margin-right: auto;
  margin-top: 0;
  margin-bottom: auto;
  width: 65%;
  height: auto;
}
.p-banner__img1 > img {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 960px) {
  .p-banner__img1 > img {
    width: auto;
    height: 100%;
    margin-left: auto;
    margin-right: 0;
  }
}
@media screen and (min-width: 1280px) {
  .p-banner__img1 > img {
    width: 100%;
    height: auto;
    position: relative;
  }
}
@media screen and (min-width: 960px) {
  .p-banner__img1 {
    top: 0;
    height: clamp(138px, 13.91vw + 85.9px, 304px);
    width: auto;
    aspect-ratio: 4/3;
  }
}
@media screen and (min-width: 1280px) {
  .p-banner__img1 {
    width: clamp(200px, 8.72vw + 167.3px, 304px);
    height: clamp(138px, 5.87vw + 116px, 208px);
  }
}
.p-banner__img2 {
  position: absolute;
  width: clamp(200px, 11.49vw + 156.9px, 304px);
  height: clamp(138px, 7.73vw + 109.1px, 208px);
  border-radius: 4px;
  overflow: hidden;
  right: 0;
  width: 45%;
  height: auto;
  bottom: 107px;
}
.p-banner__img2 > img {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 960px) {
  .p-banner__img2 {
    bottom: 0;
    width: clamp(148px, 6.37vw + 124.1px, 224px);
    height: clamp(99px, 4.19vw + 83.3px, 149px);
  }
}
.p-banner__button-pc {
  display: none;
}
@media screen and (min-width: 960px) {
  .p-banner__button-pc {
    display: block;
  }
}
.p-banner__button-sp {
  display: block;
  height: clamp(50px, 1.17vw + 45.7px, 64px);
  position: absolute;
  bottom: 0;
  width: 100%;
}
@media screen and (min-width: 960px) {
  .p-banner__button-sp {
    display: none;
  }
}

/*
p-after
-----------------------------------------------------*/
.p-about__lead {
  padding-top: clamp(32px, 2.68vw + 22px, 64px);
  text-align: center;
}
.p-about__lead h3 {
  font-family: "Zen Old Mincho";
  font-size: clamp(22px, 0.92vw + 18.6px, 33px);
  font-weight: 400;
  line-height: 150%;
  margin-bottom: clamp(32px, 1.84vw + 25.1px, 54px);
}
.p-about__lead ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 15px;
  width: 100%;
  margin: 0 auto;
  margin-bottom: clamp(32px, 1.84vw + 25.1px, 54px);
}
@media screen and (min-width: 768px) {
  .p-about__lead ul {
    gap: 20px;
    width: 80%;
  }
}
.p-about__lead ul li {
  background: #ffeeed;
  border-radius: 8px;
  mix-blend-mode: multiply;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  width: 100%;
  padding: 1rem 0.5rem;
  line-height: 1.5;
  letter-spacing: -0.02em;
}
@media screen and (min-width: 768px) {
  .p-about__lead ul li {
    width: calc((100% - 60px) / 2);
    padding: 2.5rem 0.5rem;
  }
}
@media screen and (min-width: 960px) {
  .p-about__lead ul li {
    width: calc((100% - 60px) / 3);
    padding: 2.5rem 0.5rem;
  }
}
@media screen and (min-width: 1280px) {
  .p-about__lead ul li {
    width: calc((100% - 60px) / 4);
    padding: 2.5rem 0.5rem;
  }
}
.p-about__lead ul + p {
  margin-bottom: clamp(32px, 1.84vw + 25.1px, 54px);
}
.p-about__features {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: clamp(32px, 5.2vw + 12.5px, 94px) 16px;
}
.p-about__features > div {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-about__features > div {
    width: calc((100% - 32px) / 2);
  }
}
@media screen and (min-width: 960px) {
  .p-about__features > div {
    width: calc((100% - 32px) / 3);
  }
}
.p-about__features > div > dt {
  position: relative;
  font-weight: 500;
  line-height: 1.6;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1em;
}
@media screen and (min-width: 960px) {
  .p-about__features > div > dt {
    gap: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    text-align: center;
  }
}
@media screen and (min-width: 1280px) {
  .p-about__features > div > dt {
    width: 100%;
    height: auto;
    aspect-ratio: 1/1;
    background-color: #dbeff8;
    mix-blend-mode: multiply;
    padding-top: 26%;
    border-radius: 50%;
  }
}
.p-about__features > div > dt:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: clamp(76px, 7.07vw + 49.5px, 140px);
  height: auto;
  aspect-ratio: 1/1;
  z-index: -1;
  border-radius: 50%;
  background-color: #dbeff8;
  opacity: 0.7;
  mix-blend-mode: multiply;
}
@media screen and (min-width: 960px) {
  .p-about__features > div > dt:after {
    margin-right: 0;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    left: 50%;
  }
}
@media screen and (min-width: 1280px) {
  .p-about__features > div > dt:after {
    display: none;
  }
}
.p-about__features > div > dt > span {
  position: relative;
  color: #005e8b;
  font-size: clamp(24px, 0.67vw + 21.5px, 32px);
  line-height: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  mix-blend-mode: multiply;
  min-width: clamp(76px, 7.07vw + 49.5px, 140px) !important;
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 50%;
}
@media screen and (min-width: 960px) {
  .p-about__features > div > dt > span {
    margin: 0 auto;
    margin-bottom: clamp(16px, 1.77vw + 9.3px, 32px);
  }
}
@media screen and (min-width: 1280px) {
  .p-about__features > div > dt > span {
    width: auto;
    aspect-ratio: unset;
    background: none;
    border-radius: unset;
    display: block;
    margin-bottom: 23px;
  }
}
.p-about__features > div > dt > span::before {
  font-size: clamp(12px, 0.34vw + 10.7px, 16px);
  font-family: "Zen Old Mincho";
  content: "Promise";
  line-height: 1;
  color: #005e8b;
  display: block;
  position: absolute;
  top: 60%;
  left: 50%;
  margin-top: clamp(-32px, -0.88vw - 20.7px, -24px);
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (min-width: 768px) {
  .p-about__features > div > dt > span::before {
    top: 50%;
  }
}
@media screen and (min-width: 1280px) {
  .p-about__features > div > dt > span::before {
    margin-top: -2rem;
  }
}
.p-about__features > div > dt > span::after {
  width: clamp(18px, 1.17vw + 13.7px, 32px);
  background: #005e8b;
  height: 1px;
  position: absolute;
  bottom: 50%;
  left: 50%;
  margin-bottom: clamp(-32px, -0.88vw - 20.7px, -24px);
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (min-width: 1280px) {
  .p-about__features > div > dt > span::after {
    content: "";
    display: block;
    margin-bottom: -1.6rem;
  }
}
.p-about__features > div > dt > span > span {
  width: 0;
  height: 0.8em;
}
.p-about__features > div dd {
  margin-top: clamp(24px, 0.67vw + 21.5px, 32px);
}

/*
p-hurry
-----------------------------------------------------*/
.p-hurry__tel {
  color: #982c4d;
  background: #ffeeed;
  border-radius: 8px;
  mix-blend-mode: multiply;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: clamp(24px, 2.01vw + 16.5px, 48px) clamp(12px, 0.34vw + 10.7px, 16px);
  margin-top: clamp(32px, 1.34vw + 27px, 48px);
}
.p-hurry__tel .p-global-nav__tel {
  font-size: clamp(30px, 2.18vw + 21.8px, 56px);
  padding-left: clamp(48px, 1.84vw + 41.1px, 70px);
}
.p-hurry__tel .p-global-nav__tel::before {
  top: 53%;
  display: block;
  width: clamp(36px, 2.01vw + 28.5px, 60px);
  height: clamp(24px, 1.34vw + 19px, 40px);
}
.p-hurry__tel .-reception {
  margin-top: clamp(18px, 0.67vw + 15.5px, 26px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.5rem;
}
.p-hurry__tel .-reception .-tag {
  color: #fff;
  background: #982c4d;
  border-radius: 9999px;
  padding: 0rem 1.2rem;
  line-height: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: clamp(14px, 0.17vw + 13.3px, 16px);
}
.p-hurry__tel .-reception .-txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: clamp(14px, 0.17vw + 13.3px, 16px);
}
.p-hurry__tel .-consultation {
  margin-top: clamp(12px, 0.17vw + 11.3px, 14px);
  margin-bottom: clamp(6px, 0.17vw + 5.3px, 8px);
  font-size: clamp(14px, 0.67vw + 11.5px, 22px);
  font-weight: 500;
}
.p-hurry__tel .-asterisk {
  font-size: clamp(11px, 0.25vw + 10.1px, 14px);
}
.p-hurry__tel .-telto {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  margin-bottom: clamp(10px, 0.17vw + 9.3px, 12px);
}
@media screen and (min-width: 768px) {
  .p-hurry__tel .-telto {
    display: none !important;
  }
}
.p-hurry__icon:after {
  width: clamp(50px, 1.17vw + 45.7px, 64px);
  height: clamp(45px, 4.02vw + 30px, 93px);
}
.p-hurry__icon--Q1:after {
  content: "";
  display: block;
  background: url(../img/hurry/Q_1.webp) no-repeat 50% 50%/contain;
  position: absolute;
  left: clamp(-80px, -7.38vw - 23.3px, -51px);
  top: clamp(2px, -0.84vw + 15.2px, 12px);
}
.p-hurry__icon--Q2:after {
  content: "";
  display: block;
  background: url(../img/hurry/Q_2.webp) no-repeat 50% 50%/contain;
  position: absolute;
  left: clamp(-80px, -7.38vw - 23.3px, -51px);
  top: clamp(2px, -0.84vw + 15.2px, 12px);
}
.p-hurry__icon--A1:after {
  content: "";
  display: block;
  background: url(../img/hurry/A_1.webp) no-repeat 50% 50%/contain;
  position: absolute;
  right: clamp(-80px, -7.12vw - 25.3px, -52px);
  top: clamp(-10px, -2.1vw + 22.9px, 15px);
}
.p-hurry__icon--A2:after {
  content: "";
  display: block;
  background: url(../img/hurry/A_2.webp) no-repeat 50% 50%/contain;
  position: absolute;
  right: clamp(-80px, -7.12vw - 25.3px, -52px);
  top: clamp(-10px, -2.1vw + 22.9px, 15px);
}
.p-hurry__farewell > div + div {
  margin-top: clamp(64px, 1.34vw + 59px, 80px);
}
.p-hurry__farewell > div {
  padding: 0 1.5em;
}
.p-hurry__farewell > div dt {
  background: #ffeeed;
  border-radius: 8px;
  mix-blend-mode: multiply;
  font-weight: 500;
  padding: 1rem 1.2rem;
  position: relative;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  letter-spacing: -0.02em;
}
@media screen and (min-width: 768px) {
  .p-hurry__farewell > div dt {
    padding: 1.2rem 2rem;
  }
}
.p-hurry__farewell > div dt:before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 3px solid transparent;
  border-bottom: 3px solid transparent;
  border-right: 6px solid #ffeeed;
  border-left: 0;
  mix-blend-mode: multiply;
  position: absolute;
  left: -6px;
  top: 30px;
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}
.p-hurry__farewell > div dd {
  margin-top: clamp(26px, 1.51vw + 20.3px, 44px);
  background: rgba(255, 255, 255, 0.7);
  border-radius: 8px;
  padding: 2rem 2rem;
  position: relative;
}
.p-hurry__farewell > div dd:before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 3px solid transparent;
  border-bottom: 3px solid transparent;
  border-left: 6px solid rgba(255, 255, 255, 0.7);
  border-right: 0;
  position: absolute;
  right: -6px;
  top: 2rem;
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
}

/*
p-hall-fixed
-----------------------------------------------------*/
.p-hall-fixed {
  position: fixed;
  bottom: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  left: 50%;
  width: 350px;
  height: 50px;
  border-radius: 4px 4px 0 0;
  background-color: #005e8b;
  z-index: 100000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 768px) {
  .p-hall-fixed {
    -webkit-transform: inherit;
            transform: inherit;
    margin-right: clamp(12px, 1.68vw + 5.7px, 32px);
    right: 0;
    left: auto;
  }
}
@media screen and (min-width: 960px) {
  .p-hall-fixed {
    display: none;
  }
}
.p-hall-fixed > a {
  height: 100%;
  width: 100%;
}

/*
p-scroll-top
-----------------------------------------------------*/
.p-scroll-top {
  position: fixed;
  z-index: 10000;
  bottom: 32px;
  right: 3%;
  width: clamp(48px, 2vw + 32.6px, 64px);
  height: clamp(48px, 2vw + 32.6px, 64px);
  border-radius: 99px;
  background-color: #fff;
  -webkit-filter: drop-shadow(1px 1px 5px rgba(0, 61, 90, 0.15));
          filter: drop-shadow(1px 1px 5px rgba(0, 61, 90, 0.15));
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: 500;
  background-position: center;
  background-repeat: no-repeat;
  color: #003d5a;
  background-image: url(../img/news/page-next.svg);
  rotate: -90deg;
  background-size: 16%;
  background-position: 51% center;
}
@media screen and (min-width: 960px) {
  .p-scroll-top {
    display: none;
  }
}
.p-scroll-top--hall {
  bottom: 64px;
}
.p-scroll-top > a {
  width: 100%;
  height: 100%;
}

/*
p-column
-----------------------------------------------------*/
.p-column {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.75;
  letter-spacing: 0.04em;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px) !important;
}
.p-column--highlight {
  position: relative;
  display: inline-block;
  padding: 0.5em;
}
.p-column--highlight::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  mix-blend-mode: multiply;
  background-color: #ffeeed;
}
.p-column > p > span {
  font-family: "Zen Kaku Gothic New", sans-serif !important;
  font-weight: 400 !important;
  font-style: normal !important;
  line-height: 1.75 !important;
  letter-spacing: 0.04em !important;
  font-size: clamp(16px, 0.17vw + 15.3px, 18px) !important;
}
.p-column > p > strong > span, .p-column > p > span > strong > span, .p-column > p > span > strong > span > span, .p-column > ul > li > span, .p-column > ul > li > span > span, .p-column > ul > li > span > span > strong > span, .p-column > ul > li > span > span > strong > span {
  font-size: 1em !important;
  background-color: transparent !important;
  color: #0f242f !important;
}
.p-column > p > u, .p-column > p > span, .p-column > p > span > span, .p-column > p > span > em > span, .p-column > p > span > strong, .p-column > p > span > strong > span, .p-column > ul > li > span {
  background-color: transparent !important;
  color: #0f242f !important;
  text-decoration: none !important;
}
.p-column > p > span > a, .p-column > p > a, .p-column > a {
  position: relative;
  display: block;
  width: -webkit-fit-content !important;
  width: -moz-fit-content !important;
  width: fit-content !important;
}
.p-column > p > span > a > p, .p-column > p > a > p, .p-column > a > p {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: block;
}
.p-column > p > span > a:before, .p-column > p > span > a:after, .p-column > p > a:before, .p-column > p > a:after, .p-column > a:before, .p-column > a:after {
  position: absolute;
  left: 0;
  content: "";
  width: 100%;
  height: 1px;
  background-color: #0f242f;
  bottom: -1px;
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.p-column > p > span > a:before, .p-column > p > a:before, .p-column > a:before {
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
}
.p-column > p > em {
  font-style: italic;
  font-weight: 400;
}
.p-column > ul {
  margin-left: 2.2em;
}
.p-column > ul > li {
  list-style-type: disc !important;
}
.p-column > ol {
  margin-left: 2.2em;
}
.p-column > ol > li {
  list-style-type: decimal !important;
}
.p-column > ol > li > strong > span {
  background-color: inherit !important;
}
.p-column > h1 {
  font-size: clamp(30px, 1.01vw + 26.2px, 42px);
  font-family: "Zen Old Mincho";
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 1.5em;
}
.p-column > h1 > em {
  font-weight: 400;
}
.p-column > h2 {
  font-size: clamp(26px, 0.84vw + 22.8px, 36px);
  font-family: "Zen Old Mincho";
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 1.5em;
}
.p-column > h2 > em {
  font-weight: 400;
}
.p-column > h3 {
  font-size: clamp(22px, 0.84vw + 18.8px, 32px);
  font-family: "Zen Old Mincho";
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 1.5em;
}
.p-column > h3 > em {
  font-weight: 400;
}
.p-column > h3 > strong > span {
  background-color: inherit !important;
}
.p-column > h3 > strong > span > span {
  background-color: inherit !important;
}
.p-column > h3 > span > strong > span {
  background-color: inherit !important;
}
.p-column > h4 {
  font-size: clamp(20px, 0.34vw + 18.7px, 24px);
  font-family: "Zen Old Mincho";
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 1.5em;
}
.p-column > h4 > em {
  font-weight: 400;
}
.p-column > h4 > span {
  background-color: inherit !important;
}
.p-column > blockquote {
  font-style: italic;
  opacity: 0.9;
  font-size: clamp(14px, 0.17vw + 13.3px, 16px);
  font-weight: 400;
}

@media (hover: hover) {
  .p-column > p > a:hover,
  .p-column > a:hover {
    color: #005e8b;
  }
  .p-column > p > a:hover:before,
  .p-column > a:hover:before {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transition: -webkit-transform 0 ease-out;
    transition: -webkit-transform 0 ease-out;
    transition: transform 0 ease-out;
    transition: transform 0 ease-out, -webkit-transform 0 ease-out;
    background-color: none;
    background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
    background-image: linear-gradient(to right, #65accf, #005e8b);
  }
  .p-column > p > a:hover:after,
  .p-column > a:hover:after {
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform 0 ease-out;
    transition: -webkit-transform 0 ease-out;
    transition: transform 0 ease-out;
    transition: transform 0 ease-out, -webkit-transform 0 ease-out;
    background-color: none;
    background-image: -webkit-gradient(linear, left top, right top, from(#65accf), to(#005e8b));
    background-image: linear-gradient(to right, #65accf, #005e8b);
  }
}
/*
p-ambassador
-----------------------------------------------------*/
.p-ambassador__top {
  margin-right: auto;
  margin-left: auto;
  width: 80%;
}
.p-ambassador__top > img {
  width: 100%;
  height: auto;
}
.p-ambassador__profile {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  gap: 2em;
}
@media screen and (min-width: 768px) {
  .p-ambassador__profile {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: auto;
  }
}
@media screen and (min-width: 768px) {
  .p-ambassador__profile > p, .p-ambassador__profile > div {
    width: 50%;
  }
}
@media screen and (min-width: 768px) {
  .p-ambassador__profile > figure {
    width: 44.6%;
    aspect-ratio: 3/4;
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content;
    overflow: hidden;
  }
}
.p-ambassador__profile > figure > img {
  height: 100%;
  width: auto;
}
.p-ambassador__message {
  width: 100%;
}
.p-ambassador__message > img {
  width: 100%;
  height: auto;
}

/*
p-column-list
-----------------------------------------------------*/
.p-column-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-column-gap: clamp(16px, 1.34vw + 11px, 32px);
     -moz-column-gap: clamp(16px, 1.34vw + 11px, 32px);
          column-gap: clamp(16px, 1.34vw + 11px, 32px);
  row-gap: clamp(32px, 2.68vw + 22px, 64px);
}
.p-column-list__item {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 520px) {
  .p-column-list__item {
    width: calc((100% - (1.34vw + 11px) * 1) / 2);
  }
}
@media screen and (min-width: 960px) {
  .p-column-list__item {
    width: calc((100% - (1.34vw + 11px) * 2) / 3);
  }
}
.p-column-list__item > a {
  width: 100%;
}
.p-column-list__figure {
  position: relative;
  aspect-ratio: 4/3;
  width: 100%;
  height: auto;
  overflow: hidden;
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
}
.p-column-list__figure > img {
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
  -webkit-transform-origin: 0% 0%;
          transform-origin: 0% 0%;
}
.p-column-list__date {
  display: block;
  font-family: "Zen Old Mincho";
  font-size: 0.75rem;
  font-weight: 500;
  margin-top: 1.5em;
}
.p-column-list__title {
  display: block;
  margin-top: 4px;
  position: relative;
}

/*
p-top-column
-----------------------------------------------------*/
.p-top-column > h2 {
  margin-bottom: clamp(32px, 2.68vw + 22px, 64px);
}

/*
p-banner-ambassador
-----------------------------------------------------*/
.p-banner-ambassador {
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
  position: absolute;
  scale: 0.7;
  bottom: 0;
  right: clamp(-50px, 7.63vw - 78.6px, -20px);
}
@media screen and (min-width: 768px) {
  .p-banner-ambassador {
    right: clamp(-21px, 6.05vw - 67.4px, 10px);
  }
}
@media screen and (min-width: 960px) {
  .p-banner-ambassador {
    scale: 0.8;
  }
}
@media screen and (min-width: 1280px) {
  .p-banner-ambassador {
    scale: 0.9;
    bottom: 50px;
    right: 32px;
  }
}
@media screen and (min-width: 1366px) {
  .p-banner-ambassador {
    scale: 1;
  }
}
.p-banner-ambassador__comment {
  display: block;
  font-size: 0.75rem;
  color: red;
  font-weight: 500;
  line-height: 1.5em;
}
.p-banner-ambassador__text {
  position: absolute;
  z-index: 1;
  width: 182px !important;
  min-width: 182px;
  height: 55px;
  left: 19px;
  bottom: 17px;
}
.p-banner-ambassador__box {
  position: relative;
  width: 416px;
  height: 199px;
}
.p-banner-ambassador__box > img {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 416px;
  height: auto;
  z-index: 0;
}
.p-banner-ambassador__box > figcaption {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
.p-banner-ambassador__box::after {
  content: "";
  display: block;
  position: absolute;
  width: 416px;
  height: 168px;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  border-radius: 12px;
  right: 0;
  bottom: 0;
}

@media (hover: hover) {
  .p-banner-ambassador:hover {
    scale: 0.71;
  }
}
@media screen and (hover: hover) and (min-width: 960px) {
  .p-banner-ambassador:hover {
    scale: 0.81;
  }
}
@media screen and (hover: hover) and (min-width: 1280px) {
  .p-banner-ambassador:hover {
    scale: 0.91;
  }
}
@media screen and (hover: hover) and (min-width: 1366px) {
  .p-banner-ambassador:hover {
    scale: 1.01;
  }
}
@media (hover: hover) {
  .p-banner-ambassador:hover > figure > div.c-button--no-hover:after {
    opacity: 1;
    width: 100.5%;
    height: 100.5%;
  }
}
/*
p-lp
-----------------------------------------------------*/
@media screen and (min-width: 520px) {
  .p-lp__button {
    width: 70%;
  }
}
@media screen and (min-width: 768px) {
  .p-lp__button {
    max-width: 384px;
  }
}
.p-lp__flex-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  gap: 2em;
}
@media screen and (min-width: 768px) {
  .p-lp__flex-container {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: auto;
  }
}
@media screen and (min-width: 768px) {
  .p-lp__flex-container > div {
    width: 50%;
  }
}
@media screen and (min-width: 768px) {
  .p-lp__flex-container > figure {
    width: 44.6%;
    aspect-ratio: 4/3;
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content;
    overflow: hidden;
  }
}
.p-lp__flex-container > figure > img {
  width: 100%;
  height: auto;
}

/*
p-simulator
-----------------------------------------------------*/
.p-simulator {
  display: block;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  position: relative;
  overflow: hidden;
  padding-top: 75px;
  padding-bottom: 75px;
  margin: 0 clamp(11px, 7.12vw - 15.6px, 96px);
  min-height: clamp(567px, 9.81vw + 530.2px, 684px);
  -webkit-transition: height 0.4s ease-out;
  transition: height 0.4s ease-out;
}
@media screen and (min-width: 960px) {
  .p-simulator {
    padding-top: clamp(32px, 2.68vw + 22px, 64px);
    padding-bottom: clamp(43px, 2.93vw + 32.1px, 78px);
  }
}
.p-simulator__page--height-fix {
  -webkit-transition: opacity 0.4s ease-out;
  transition: opacity 0.4s ease-out;
  height: clamp(492px, 4.19vw + 476.3px, 542px);
  text-align: center;
  display: none;
  opacity: 0;
}
.p-simulator__page--height-fix.active {
  display: block;
}
.p-simulator__page--height-fix.opacity1 {
  opacity: 1;
}
.p-simulator__page--height-stretch {
  -webkit-transition: opacity 0.4s ease-out;
  transition: opacity 0.4s ease-out;
  height: auto;
  text-align: center;
  display: none;
  opacity: 0;
}
.p-simulator__page--height-stretch.active {
  display: block;
}
.p-simulator__page--height-stretch.opacity1 {
  opacity: 1;
}
.p-simulator__h1 {
  font-family: "Zen Old Mincho";
  font-size: clamp(30px, 3.77vw + 15.9px, 75px);
  line-height: 1.5;
  padding-top: clamp(16px, 1.01vw + 12.2px, 28px);
  margin-bottom: clamp(45px, 1.26vw + 40.2px, 60px);
}
.p-simulator__start-text {
  font-family: "Zen Old Mincho";
  color: #005e8b;
  font-size: clamp(14px, 1.17vw + 9.7px, 28px);
  line-height: 1.8;
  margin-top: clamp(24px, 1.76vw + 17.4px, 45px);
  word-break: auto-phrase;
}
.p-simulator__start-button {
  min-width: clamp(272px, 17.02vw + 208.1px, 475px);
  height: clamp(75px, 1.68vw + 68.7px, 95px);
  margin: clamp(24px, 0.5vw + 22.2px, 30px) auto 0;
  margin-top: clamp(26px, 0.67vw + 23.5px, 34px);
}
.p-simulator__start-character {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transform-origin: bottom center;
          transform-origin: bottom center;
  left: clamp(16px, 1.17vw + 11.7px, 30px);
  bottom: 0;
  width: clamp(288px, 1.34vw + 283px, 304px);
  height: clamp(197px, 21.29vw + 117.2px, 451px);
  gap: clamp(16px, 0.67vw + 13.5px, 24px);
}
.p-simulator__start-character > p {
  display: block;
  position: relative;
  text-align: center;
  padding: clamp(32px, 0.34vw + 30.7px, 36px) clamp(16px, 0.84vw + 12.8px, 26px);
  font-size: clamp(14px, 0.34vw + 12.7px, 18px);
  line-height: 1.5;
  background-color: #fff;
  border-radius: clamp(6px, 0.34vw + 4.7px, 10px);
}
.p-simulator__start-character > p::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
  border-top: 10px solid #fff;
}
.p-simulator__start-character > figure {
  width: clamp(142px, 11.74vw + 97.9px, 282px);
  height: auto;
  margin-right: clamp(-58px, -2.35vw - 21.2px, -30px);
}
.p-simulator__start-ito {
  position: absolute;
  top: 0;
  right: 0;
  width: clamp(120px, 11.74vw + 75.9px, 260px);
  overflow: hidden;
  mix-blend-mode: multiply;
  opacity: 0.4;
}
.p-simulator__start-ito > img {
  width: 100%;
  height: auto;
}
.p-simulator__question-textbox {
  padding: 0 clamp(40px, 5.03vw + 21.1px, 100px);
}
.p-simulator__question-textbox > h2 {
  font-family: "Zen Old Mincho";
  font-size: clamp(16px, 0.67vw + 13.5px, 24px);
  line-height: 1.6;
  margin-top: clamp(12px, -0.34vw + 17.3px, 16px);
}
.p-simulator__question-textbox > h2 > span {
  display: block;
  font-size: clamp(14px, 0.34vw + 12.7px, 18px);
}
.p-simulator__Q {
  color: #005e8b;
  font-family: "Zen Old Mincho";
  font-size: clamp(18px, 0.5vw + 16.2px, 24px);
}
.p-simulator__Q > span {
  font-family: "Cormorant Garamond", serif;
}
.p-simulator__next-question-button {
  -webkit-transition: opacity 0.4s ease-out;
  transition: opacity 0.4s ease-out;
  margin-top: clamp(32px, 1.51vw + 26.3px, 50px);
  opacity: 0.3;
  pointer-events: none;
  margin: auto;
  min-width: clamp(192px, 16.09vw + 131.7px, 384px);
}
.p-simulator__next-question-button.is-loading {
  pointer-events: none;
}
.p-simulator__restart-button, .p-simulator__reset-button {
  margin: 2em auto 0;
  pointer-events: all;
  cursor: pointer;
}
.p-simulator__BG {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -100;
  background-color: #dbeff8;
  opacity: 0.8;
  mix-blend-mode: multiply;
  border-radius: clamp(8px, 1.01vw + 4.2px, 20px);
}

.p-simulator-question--3choice:has(input[type=radio]:checked) ~ .p-simulator__next-question-button,
.p-simulator-question--4choice:has(input[type=radio]:checked) ~ .p-simulator__next-question-button {
  opacity: 1;
  pointer-events: all;
  cursor: pointer;
}
.p-simulator-question--3choice:has(input[type=radio]:checked) ~ .p-simulator__next-question-button.is-loading,
.p-simulator-question--4choice:has(input[type=radio]:checked) ~ .p-simulator__next-question-button.is-loading {
  opacity: 0.3;
  pointer-events: none;
}

/*
p-simulator-question
-----------------------------------------------------*/
.p-simulator-question--3choice {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: clamp(12px, 0.67vw + 9.5px, 20px);
  margin: clamp(28px, 1.42vw + 22.7px, 45px) clamp(40px, 11.4vw - 2.8px, 176px) clamp(32px, 1.51vw + 26.3px, 50px);
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 960px) {
  .p-simulator-question--3choice {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: clamp(12px, 1.68vw + 5.7px, 32px);
  }
}
.p-simulator-question--3choice__label {
  border: 3px solid #fff;
  background-color: #fff;
  -webkit-transition: border 0.1s ease-out, -webkit-box-shadow 0.2s ease-out;
  transition: border 0.1s ease-out, -webkit-box-shadow 0.2s ease-out;
  transition: box-shadow 0.2s ease-out, border 0.1s ease-out;
  transition: box-shadow 0.2s ease-out, border 0.1s ease-out, -webkit-box-shadow 0.2s ease-out;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  position: relative;
  cursor: pointer;
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
  padding: 1em;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  min-height: 64px;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  width: 100%;
}
@media screen and (min-width: 960px) {
  .p-simulator-question--3choice__label {
    height: 249px;
    width: calc((100% - (1.68vw + 5.7px) * 2) / 3);
  }
}
.p-simulator-question--3choice__label::after {
  -webkit-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
  content: "";
  display: block;
  position: absolute;
  width: clamp(18px, 1.17vw + 13.7px, 32px);
  height: clamp(18px, 1.17vw + 13.7px, 32px);
  background-image: url(../img/simulator/simu-check.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  opacity: 0;
  left: 13px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  top: 50%;
}
@media screen and (min-width: 960px) {
  .p-simulator-question--3choice__label::after {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
    top: 13px;
  }
}
.p-simulator-question--3choice__label > input[type=radio] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.p-simulator-question--3choice__label:has(input[type=radio]:checked) {
  border-color: #005e8b;
  -webkit-box-shadow: 0px 0px 0px 0px rgba(0, 61, 90, 0);
          box-shadow: 0px 0px 0px 0px rgba(0, 61, 90, 0);
}
.p-simulator-question--3choice__label:has(input[type=radio]:checked)::after {
  opacity: 1;
}
.p-simulator-question--4choice {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: clamp(12px, 1.68vw + 5.7px, 32px);
  margin: clamp(28px, 1.42vw + 22.7px, 45px) clamp(40px, 11.4vw - 2.8px, 176px) clamp(32px, 1.51vw + 26.3px, 50px);
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 960px) {
  .p-simulator-question--4choice {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: clamp(12px, 1.68vw + 5.7px, 32px);
  }
}
.p-simulator-question--4choice__label {
  border: 3px solid #fff;
  background-color: #fff;
  -webkit-transition: border 0.1s ease-out, -webkit-box-shadow 0.2s ease-out;
  transition: border 0.1s ease-out, -webkit-box-shadow 0.2s ease-out;
  transition: box-shadow 0.2s ease-out, border 0.1s ease-out;
  transition: box-shadow 0.2s ease-out, border 0.1s ease-out, -webkit-box-shadow 0.2s ease-out;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  position: relative;
  cursor: pointer;
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
  padding: 1em;
  min-height: 64px;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  width: 100%;
}
@media screen and (min-width: 960px) {
  .p-simulator-question--4choice__label {
    height: 249px;
    width: calc((100% - (1.68vw + 5.7px) * 3) / 4);
  }
}
.p-simulator-question--4choice__label::after {
  -webkit-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
  content: "";
  display: block;
  position: absolute;
  top: 13px;
  left: 13px;
  width: clamp(18px, 1.17vw + 13.7px, 32px);
  height: clamp(18px, 1.17vw + 13.7px, 32px);
  background-image: url(../img/simulator/simu-check.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  opacity: 0;
}
.p-simulator-question--4choice__label > input[type=radio] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.p-simulator-question--4choice__label:has(input[type=radio]:checked) {
  border-color: #005e8b;
  -webkit-box-shadow: 0px 0px 0px 0px rgba(0, 61, 90, 0);
          box-shadow: 0px 0px 0px 0px rgba(0, 61, 90, 0);
}
.p-simulator-question--4choice__label:has(input[type=radio]:checked)::after {
  opacity: 1;
}
.p-simulator-question__option-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  width: 100%;
  height: 100%;
  font-size: clamp(16px, 0.5vw + 14.2px, 22px);
  font-weight: 500;
  word-break: auto-phrase;
  padding: 0.2em 2em;
  line-height: 1.45em;
}
@media screen and (min-width: 960px) {
  .p-simulator-question__option-text {
    text-align: center;
    padding: 1em;
    line-height: 1.6em;
  }
}

/*
p-simulator-result
-----------------------------------------------------*/
.p-simulator-result__top1 {
  font-family: "Zen Old Mincho";
  color: #005e8b;
  font-size: clamp(12px, 0.67vw + 9.5px, 20px);
  line-height: 1.5;
}
.p-simulator-result__top2 {
  font-family: "Zen Old Mincho";
  font-size: clamp(16px, 1.34vw + 11px, 32px);
  margin-top: clamp(6px, 1.17vw + 1.7px, 20px);
}
.p-simulator-result__heavens-plan-container {
  margin: clamp(24px, 2.18vw + 15.8px, 50px) clamp(14px, 13.58vw - 36.9px, 176px) clamp(54px, 0.84vw + 50.8px, 64px);
  border-radius: 8px;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
          box-shadow: 1px 1px 5px 0px rgba(0, 61, 90, 0.15);
  padding: clamp(24px, 3.19vw + 12px, 62px) clamp(26px, 11.23vw - 16.1px, 160px) clamp(46px, 2.68vw + 36px, 78px);
  background-color: #fff;
}
.p-simulator-result__plan-title {
  font-size: clamp(22px, 2.35vw + 13.2px, 50px);
  line-height: 1.5;
  font-family: "Zen Old Mincho";
  margin-bottom: clamp(13px, 3.52vw - 0.2px, 55px);
}
.p-simulator-result__detail-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 3%;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 960px) {
  .p-simulator-result__detail-container {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.p-simulator-result__image {
  position: relative;
  overflow: hidden;
  width: 100%;
  border-radius: 4px;
  aspect-ratio: 362/241;
}
@media screen and (min-width: 960px) {
  .p-simulator-result__image {
    width: 48.5%;
  }
}
.p-simulator-result__image > img {
  position: absolute;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  top: 0;
  left: 50%;
  width: 100%;
  height: auto;
}
.p-simulator-result__text-box {
  width: 100%;
  text-align: left;
}
@media screen and (min-width: 960px) {
  .p-simulator-result__text-box {
    width: 48.5%;
  }
}
.p-simulator-result__text-box-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 1em;
  gap: 0.7em;
}
@media screen and (min-width: 960px) {
  .p-simulator-result__text-box-inner {
    margin-top: 0;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    gap: 0;
  }
}
.p-simulator-result__text {
  margin-top: 0.8em;
}
.p-simulator-result__heavens-price {
  white-space: noWrap;
  font-size: clamp(24px, 2.26vw + 15.6px, 51px);
  letter-spacing: -0.02em;
  margin-top: clamp(-12px, -0.5vw - 4.2px, -6px);
}
@media screen and (min-width: 960px) {
  .p-simulator-result__heavens-price {
    margin-bottom: -0.5em;
  }
}
.p-simulator-result__heavens-price > span {
  font-size: clamp(12px, 1.34vw + 7px, 28px);
}
.p-simulator-result__heavens-price > span > span {
  font-size: clamp(12px, 0.34vw + 10.7px, 16px);
}
.p-simulator-result__heavens-price > span > span > span {
  font-size: clamp(12px, 1.01vw + 8.2px, 24px);
}
.p-simulator-result__text {
  font-size: clamp(16px, 0.17vw + 15.3px, 18px);
  line-height: 1.7;
}
.p-simulator-result__icon-container {
  margin-top: clamp(20px, 1.01vw + 16.2px, 32px);
}
.p-simulator-result__icon-item {
  z-index: 1;
  width: calc((100% - (0.17vw + 7.3px) * 3) / 4);
}
.p-simulator-result__icon-item > img::after {
  z-index: 0;
}
@media screen and (min-width: 520px) {
  .p-simulator-result__icon-item {
    width: calc((100% - (0.17vw + 7.3px) * 4) / 5);
  }
}
@media screen and (min-width: 600px) {
  .p-simulator-result__icon-item {
    width: calc((100% - (0.17vw + 7.3px) * 5) / 6);
  }
}
@media screen and (min-width: 768px) {
  .p-simulator-result__icon-item {
    width: calc((100% - (0.17vw + 7.3px) * 6) / 7);
  }
}
@media screen and (min-width: 960px) {
  .p-simulator-result__icon-item {
    width: calc((100% - (0.17vw + 7.3px) * 7) / 8);
  }
}
@media screen and (min-width: 1280px) {
  .p-simulator-result__icon-item {
    width: calc((100% - (0.17vw + 7.3px) * 7) / 8);
  }
}
.p-simulator-result__button-box {
  margin-top: clamp(32px, 1.51vw + 26.3px, 50px);
  gap: clamp(12px, 1.68vw + 5.7px, 32px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 960px) {
  .p-simulator-result__button-box {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.p-simulator-result__button-box > a {
  width: 100%;
  height: clamp(50px, 3.02vw + 38.6px, 86px);
}
@media screen and (min-width: 960px) {
  .p-simulator-result__button-box > a {
    width: calc((100% - (1.68vw + 5.7px)) / 2);
  }
}
.p-simulator-result__button-box > a > p {
  font-size: clamp(16px, 0.5vw + 14.2px, 22px);
  line-height: 1.4em;
}
.p-simulator-result__button-box > a > p > span {
  font-size: clamp(12px, 0.17vw + 11.3px, 14px);
  line-height: clamp(16px, 0.5vw + 14.2px, 22px);
}
.p-simulator-result__normal-badge {
  font-size: 12px;
}
.p-simulator-result__normal-price {
  font-size: clamp(20px, 1.01vw + 16.2px, 32px);
  line-height: 1.5;
  margin-top: -0.2em;
}
.p-simulator-result__normal-price > span {
  font-size: clamp(10px, 0.84vw + 6.8px, 20px);
}
.p-simulator-result__normal-price > span > span {
  font-size: clamp(10px, 0.42vw + 8.4px, 15px);
}
.p-simulator-result__recommend-container {
  background-color: #dbeff8;
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
  padding: clamp(24px, 1.76vw + 17.4px, 45px) clamp(12px, 4.27vw - 4px, 63px) clamp(45px, 0.42vw + 43.4px, 50px);
  margin-top: clamp(24px, 0.67vw + 21.5px, 32px);
}
.p-simulator-result__recommend-title {
  font-family: "Zen Old Mincho";
  color: #005e8b;
  font-size: clamp(20px, 0.42vw + 18.4px, 25px);
  line-height: 1.5;
  word-break: keep-all;
}
.p-simulator-result__recommend-title > span {
  position: relative;
  display: block;
  font-size: clamp(14px, 0.17vw + 13.3px, 16px);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 10px;
}
.p-simulator-result__recommend-title > span::after {
  content: "";
  position: absolute;
  display: block;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  left: 50%;
  bottom: -2px;
  border-bottom: 0.5px solid #005e8b;
  height: 1px;
  width: 100%;
}
.p-simulator-result__recommend-price-box {
  background-color: #fff;
  border-radius: 8px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: clamp(248px, 27.66vw + 144.3px, 578px);
  margin: clamp(13px, -0.25vw + 16.9px, 16px) auto;
  padding: clamp(15px, 0vw + 15px, 15px) clamp(6px, 1.51vw + 0.3px, 24px);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 0.5em;
}
@media screen and (min-width: 1568px) {
  .p-simulator-result__recommend-price-box {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 0;
  }
}
.p-simulator-result__normal-price-box {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 5px;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 1568px) {
  .p-simulator-result__normal-price-box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.p-simulator-result__normal-price-arrow {
  display: block;
  background-image: url(../img/simulator/arrow.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  width: clamp(9px, 0.08vw + 8.7px, 10px);
  height: clamp(8px, 0vw + 8px, 8px);
  rotate: 90deg;
}
@media screen and (min-width: 1568px) {
  .p-simulator-result__normal-price-arrow {
    rotate: 0deg;
  }
}
.p-simulator-result__normal-price-badge {
  font-size: 12px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  line-height: 1em;
}
.p-simulator-result__normal-price-amount {
  font-size: clamp(18px, 0.17vw + 17.3px, 20px);
}
.p-simulator-result__normal-price-amount > span {
  font-size: clamp(10px, 0.17vw + 9.3px, 12px);
}
.p-simulator-result__heavens-price-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: -0.5em;
}
@media screen and (min-width: 960px) {
  .p-simulator-result__heavens-price-box {
    margin-top: -1em;
  }
}
@media screen and (min-width: 1568px) {
  .p-simulator-result__heavens-price-box {
    margin-top: 0;
  }
}
.p-simulator-result__heavens-price-badge {
  font-size: 10px;
  background-color: #dbeff8;
  color: #005e8b;
  letter-spacing: -0.015em;
  border-radius: 99px;
  padding: clamp(5px, 0.25vw + 4.1px, 8px) clamp(11px, 0.5vw + 9.2px, 17px);
  white-space: noWrap;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  line-height: 1.5;
}
.p-simulator-result__heavens-price-amount {
  margin-left: 0.1em;
  font-size: clamp(25px, 1.68vw + 18.7px, 45px);
  letter-spacing: -0.03em;
  color: #005e8b;
}
.p-simulator-result__heavens-price-amount > span {
  font-size: clamp(10px, 1.01vw + 6.2px, 22px);
  white-space: noWrap;
}
.p-simulator-result__heavens-price-amount > span > span {
  font-size: clamp(10px, 0.34vw + 8.7px, 14px);
  margin-left: -0.5em;
}
.p-simulator-result__heavens-price-amount > span > span > span {
  margin-left: -0.5em;
}
.p-simulator-result__heavens-recommend-box {
  text-align: left;
  width: clamp(248px, 27.66vw + 144.3px, 578px);
  margin: clamp(20px, 0.5vw + 18.2px, 26px) auto 0;
}
.p-simulator-result__heavens-recommend-box > h4 {
  font-family: "Zen Old Mincho";
  font-size: clamp(16px, 0.34vw + 14.7px, 20px);
}
.p-simulator-result__heavens-recommend-box > p {
  font-size: clamp(14px, 0.17vw + 13.3px, 16px);
  margin-top: clamp(8px, 0.67vw + 5.5px, 16px);
  line-height: 1.6;
}
.p-simulator-result__heavens-button {
  margin: 32px auto 0;
  width: clamp(248px, 11.4vw + 205.2px, 384px);
  word-break: auto-phrase;
  padding: 0.8em;
  min-height: clamp(50px, 1.17vw + 45.7px, 64px);
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
.p-simulator-result__heavens-button > p {
  width: 90%;
  gap: 0.3em;
}
.p-simulator-result__gojokai-total {
  font-family: "Zen Old Mincho";
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  background-color: #dbeff8;
  color: #005e8b;
  border-radius: clamp(4px, 0.34vw + 2.7px, 8px);
  padding: clamp(5px, 0.42vw + 3.4px, 10px) clamp(24px, 6.37vw + 0.1px, 100px);
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5em;
  margin-top: 24px;
}
.p-simulator-result__gojokai-total-text {
  font-size: clamp(16px, 1.01vw + 12.2px, 28px);
  margin-top: 1.2em;
  margin-right: 0.2em;
}
.p-simulator-result__gojokai-total-amount {
  font-size: clamp(44px, 2.6vw + 34.2px, 75px) !important;
}
.p-simulator-result__gojokai-unit {
  font-size: clamp(18px, 1.17vw + 13.7px, 32px);
  margin-top: 1em;
}
.p-simulator-result__gojokai-unit > span {
  margin-bottom: 0.4em;
}
/*# sourceMappingURL=common.css.map */


/* //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

LP 健康＆終活キャンペーン

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////*/
/* セクションの背景 */
#lp_kenkou-shukatsu{
    background:#ebeae0;
}
#lp_kenkou-shukatsu .p-lp__flex-container{
    flex-direction:row;
}

/* PCのみ表示 */
.PConly{
    display:block;
}
/* スマホのみ表示 */
.SPonly{
    display:none;
}

/* フォント大 */
#lp_kenkou-shukatsu .font_L{
    font-size:150%;
}
/* リストに黒丸付ける */
#lp_kenkou-shukatsu .disc li{
    list-style-type:disc;
    margin:0 0 1rem 1rem;
}

/* 背景ブルー */
#lp_kenkou-shukatsu .bg_blue{
    background:#5982a8;
    color:#fff;
    display:inline-block;
    font-weight:600;
    padding:2px 20px;
    border-radius:100px;
}
/* 背景ホワイト ボックス */
#lp_kenkou-shukatsu .box_white{
    background:#fff;
    padding:1rem;
    border-radius:30px;
    margin-bottom:2rem;
}

/* 事前予約 */
#lp_kenkou-shukatsu .booking{
    background:#f4a56b;
    text-align:center;
    padding:0 0 3rem;
}
#lp_kenkou-shukatsu .booking .button a{
    display: inline-block;
    text-align: center;
    color: #fff;
    padding:10px;
    font-size:1.8rem;
    font-weight:600;
    letter-spacing:0.1rem;
    background-color: #ef803e;
    border-radius:100px;
    box-shadow: 0px 5px 0px #cc6633;
    transition: .3s;
    width:85%;
    margin:0 auto 1rem;
}
#lp_kenkou-shukatsu .booking .button a:hover {
    box-shadow: unset;
    transform: translateY(4px);
}
#lp_kenkou-shukatsu .booking .tokuten{
    width:70%;
    margin:0 auto 2rem;
}
#lp_kenkou-shukatsu .booking .tokuten div{
    margin-top:-70px;
}

/* ヘブンズ倶楽部 */
#lp_kenkou-shukatsu .heavensclub{
    background:#d5e4e4;
    text-align:center;
    padding:3rem 0;
}

/* お問い合わせ */
#lp_kenkou-shukatsu .contact{
    text-align:left;
    padding:3rem 0;
}
#lp_kenkou-shukatsu .contact .c-text--lower-h4{
    margin-bottom:0;
}

/* フローティングバナー */
#lp_kenkou-shukatsu .floating-banner{
    writing-mode:vertical-rl;
    font-size:1.2rem;
    font-weight:600;
    color:#fff;
}
#lp_kenkou-shukatsu .floating-banner .icon{
    height:25px;
    margin-bottom:10px;
}
#lp_kenkou-shukatsu .floating-banner .f_booking{
    position:fixed;
    bottom:55%;
    right:0;
    background:#ef803e;
    display:flex;
    align-items:center;
    padding:20px 10px;
    border-radius:20px 0 0 20px;
    transform: translate(5px,0);
    transition: .3s;
}
#lp_kenkou-shukatsu .floating-banner .f_booking:hover{
    transform: translate(0,0);
}
#lp_kenkou-shukatsu .floating-banner .f_contact{
    position:fixed;
    bottom:30%;
    right:0;
    background:#9ac937;
    display:flex;
    align-items:center;
    padding:20px 10px;
    border-radius:20px 0 0 20px;
    transform: translate(5px,0);
    transition: .3s;
}
#lp_kenkou-shukatsu .floating-banner .f_contact:hover{
    transform: translate(0,0);
}

/* スマホ用 */
@media screen and (max-width: 768px) {
/* PCのみ表示 */
    .PConly{
        display:none;
    }
/* スマホのみ表示 */
    .SPonly{
        display:block;
    }
    
    #lp_kenkou-shukatsu .c-text--lower-h4{
        font-size:1.2rem;
    }
    #lp_kenkou-shukatsu .p-lp__flex-container{
        flex-direction:column;
    }
    #lp_kenkou-shukatsu .p-ambassador__top{
        width:100%;
    }
    
    /* 事前予約 */
    #lp_kenkou-shukatsu .booking .tokuten{
        width:90%;   
    }
    #lp_kenkou-shukatsu .booking .tokuten div{
        margin-top:-50px;
    }
    #lp_kenkou-shukatsu .booking .l-wrapper--1column__inner{
        padding:0;
    }
    #lp_kenkou-shukatsu .booking .p-lp__flex-container{
        flex-direction:row;
        gap:0;
    }
    #lp_kenkou-shukatsu .booking .button a{
        width:85%;
        font-size:1.1rem;
    }
    
    /* お問い合わせ */
    #lp_kenkou-shukatsu .contact{
        padding:3rem 0 6rem;
    }
    
    /* フローティングバナー */
    #lp_kenkou-shukatsu .floating-banner{
        writing-mode:horizontal-tb;
        font-size:1.1rem;
    }
    #lp_kenkou-shukatsu .floating-banner .f_booking{
        bottom:0;
        left:0;
        height:50px;
        border-radius:0;
        width:50%;
        justify-content:center;
        transform: translate(0,0);
    }
    #lp_kenkou-shukatsu .floating-banner .f_contact{
        bottom:0;
        right:0;
        height:50px;
        border-radius:0;
        width:50%;
        justify-content:center;
        transform: translate(0,0);
    }
    #lp_kenkou-shukatsu .floating-banner .icon{
        height:25px;
        margin-bottom:0;
        margin-right:10px;
    }
}