@charset "UTF-8";
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* style */
/* 目次 */
/* __00: 初期設定 */
/* __10: 共通設定 */
/* __20: 外部ファイル読み込み */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 初期設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* settings */
/* 目次 */
/* __00: 共通設定 */
/* __10: リセット用のプレイスフォルダ */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* module */
/* 目次 */
/* __00: mixin */
/* __10: 共通ファイル読み込み */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: mixin */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute;
}

/* __10: 共通ファイル読み込み */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* settings-media */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* settings-vw */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* settings-vh */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
@font-face {
  font-display: swap;
  font-style: normal;
  font-family: "Noto Sans JP";
  src: url("../fonts/NotoSansJP-VariableFont_wght.ttf") format("truetype");
}
:root {
  --font-family: "Noto Sans JP", sans-serif;
  --font-size: 62.5%;
  --font-weight: 500;
  --letter-spacing: 0;
  --line-height: 1.8;
  --transiton-timing-function: cubic-bezier(0.46, 0.03, 0.23, 0.98);
}

/* __10: リセット用のプレイスフォルダ */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
body, html, div,
span,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
q,
a,
code,
del,
em,
small,
b,
strong,
sub,
sup,
dl,
dt,
dd,
ol,
ul,
li,
form,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
  font-family: var(--font-family);
  font-size: var(--font-size);
  letter-spacing: var(--letter-spacing);
  margin: 0;
  padding: 0;
}

body, html {
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

body {
  font-family: var(--font-family);
  font-size: var(--font-size);
}

body {
  color: var(--font-color);
  background-color: var(--background-color);
}

/* リセット処理関数 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* typography */
/* 目次 */
/* __00: 共通設定 */
/* __10: Typography */
/* __20: Headline Design */
/* __30: WordPress Editor Size */
/* __40: InputTag */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
:root {
  --font-size-text: clamp(1.4rem, 1.3243rem + 0.2018vw, 1.6rem);
  --font-size-input: 16px;
  --font-size-xxl: clamp(3rem, 2.6216rem + 1.0091vw, 4rem);
  --font-size-xl: clamp(2.6rem, 2.2216rem + 1.0091vw, 3.6rem);
  --font-size-lg: clamp(2rem, 1.773rem + 0.6054vw, 2.6rem);
  --font-size-md: clamp(1.4rem, 1.3243rem + 0.2018vw, 1.6rem);
  --font-size-sm: clamp(1rem, 0.8944rem + 0.2817vw, 1.3rem);
  --font-size-xs: 1rem;
  --font-size-h1: clamp(2.7rem, 2.5944rem + 0.2817vw, 3rem);
  --font-size-h2: clamp(2.4rem, 2.2944rem + 0.2817vw, 2.7rem);
  --font-size-h3: clamp(2.1rem, 1.9944rem + 0.2817vw, 2.4rem);
  --font-size-h4: clamp(1.8rem, 1.6944rem + 0.2817vw, 2.1rem);
  --font-size-h5: clamp(1.6rem, 1.5296rem + 0.1878vw, 1.8rem);
  --font-size-h6: 1.6rem;
  --font-color: #3c3c3c;
  --font-caption: #323232;
  --font-link: #8c37c8;
  --font-link-hover: #8c37c8;
  --border-color: #e6e6e6;
  --background-color: #ffffff;
  --pink: #e63c78;
  --green: #3ca096;
  --yellow: #fffcb2;
  --main-color: #8c37c8;
  --accent-color01: #e8d7f4;
  --accent-color02: #2da050;
  --accent-color03: #826eeb;
  --white: #fff;
  --red: #ff3656;
  --NotoSerifJp: YakuHanJP, "Noto Serif JP", serif;
}

/* __10: Typography */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __20: Headline Design */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __30: WordPress Editor Size */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __40: InputTag */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
:focus {
  outline: 0;
}

/* 見出し */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
h1 {
  font-size: var(--font-size-h1);
  line-height: 1.4;
}

h2 {
  font-size: var(--font-size-h2);
  line-height: 1.4;
}

h3 {
  font-size: var(--font-size-h3);
  line-height: 1.4;
}

h4 {
  font-size: var(--font-size-h4);
  line-height: 1.4;
}

h5 {
  font-size: var(--font-size-h5);
  line-height: 1.4;
}

h6 {
  font-size: var(--font-size-h6);
  line-height: 1.4;
}

/* テキスト */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
p {
  font-size: var(--font-size-text);
}

a {
  font-size: var(--font-size-text);
  color: var(--main-color);
  text-decoration: underline;
}
a[class] {
  color: var(--font-color);
  text-decoration: none;
}

span {
  font-size: 1em;
}

b,
strong {
  font-family: var(--ff-bold);
  font-size: 1em;
  font-weight: 700;
}

i,
em {
  font-size: 1em;
  font-style: italic;
}

u {
  font-size: 1em;
  text-decoration: underline;
}

small {
  font-size: 0.866666em;
}

sub {
  font-size: 0.5em;
  vertical-align: sub;
}

sup {
  font-size: 0.5em;
  vertical-align: super;
}

del {
  font-size: 1em;
}

mark {
  font-size: 1em;
}

code {
  font-size: 0.866666em;
}

blockquote {
  font-size: var(--font-size-text);
  padding: 1em 0 1em 2em;
  border-left: 2px solid #afafaf;
}
blockquote > * {
  font-family: serif;
  font-style: italic;
  color: #afafaf;
}
blockquote > * + * {
  margin-top: 1em;
}

figure {
  max-width: 100%;
}
figure a {
  display: block;
}

figcaption {
  font-size: var(--font-size-sm);
}

/* リスト */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
ul[class] {
  list-style: none;
}

ol[class] {
  list-style: none;
}

li {
  font-size: var(--font-size-text);
}

/* 定義リスト */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
dt {
  font-size: var(--font-size-text);
}

dd {
  font-size: var(--font-size-text);
}

/* テーブル */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--main-color);
}

thead td {
  font-weight: 700;
}

th {
  border: 1px solid var(--main-color);
  background-color: #dcf0e5;
  font-size: var(--font-size-text);
  vertical-align: middle;
  padding: 0.5em;
}

td {
  border: 1px solid var(--main-color);
  font-size: var(--font-size-text);
  vertical-align: middle;
  padding: 0.5em;
}

/* その他 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
img,
picture {
  max-width: 100%;
  height: auto;
}
img:not([class*=wp-image]),
picture:not([class*=wp-image]) {
  width: auto;
  vertical-align: middle;
  pointer-events: none;
}

figure {
  margin: 0;
}

form input[type=text],
form input[type=email],
form input[type=tel],
form input[type=date],
form input[type=number],
form textarea,
form select,
form input[type=file],
form input[type=radio],
form input[type=checkbox],
form input[type=button],
form input[type=submit] {
  all: unset;
  outline: revert;
  -webkit-tap-highlight-color: transparent;
  font-family: var(--font-family);
  font-size: var(--font-size-input);
  box-sizing: border-box;
}
form input[type=text]::-webkit-input-placeholder,
form input[type=email]::-webkit-input-placeholder,
form input[type=tel]::-webkit-input-placeholder,
form input[type=date]::-webkit-input-placeholder,
form input[type=number]::-webkit-input-placeholder,
form textarea::-webkit-input-placeholder,
form select::-webkit-input-placeholder,
form input[type=file]::-webkit-input-placeholder,
form input[type=radio]::-webkit-input-placeholder,
form input[type=checkbox]::-webkit-input-placeholder,
form input[type=button]::-webkit-input-placeholder,
form input[type=submit]::-webkit-input-placeholder {
  font-size: 1em;
  color: #b3b3b3;
}
form input[type=text]:-webkit-autofill,
form input[type=email]:-webkit-autofill,
form input[type=tel]:-webkit-autofill,
form input[type=date]:-webkit-autofill,
form input[type=number]:-webkit-autofill,
form textarea:-webkit-autofill,
form select:-webkit-autofill,
form input[type=file]:-webkit-autofill,
form input[type=radio]:-webkit-autofill,
form input[type=checkbox]:-webkit-autofill,
form input[type=button]:-webkit-autofill,
form input[type=submit]:-webkit-autofill {
  box-shadow: 0 0 0 1000px #ebebeb inset;
  -webkit-text-fill-color: var(--font-color) !important;
}
form textarea {
  resize: none;
}
form input[type=checkbox] {
  appearance: none;
  display: none;
}
form input[type=checkbox] + span, form input[type=checkbox] + .wpcf7c-conf-hidden + span {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  cursor: pointer;
  padding: 0 0 0 1.5em;
  font-size: var(--font-size-input);
  font-weight: 500;
  line-height: 1.2;
}
form input[type=checkbox] + span::before, form input[type=checkbox] + span::after, form input[type=checkbox] + .wpcf7c-conf-hidden + span::before, form input[type=checkbox] + .wpcf7c-conf-hidden + span::after {
  position: absolute;
  content: "";
  display: block;
  top: 0;
  bottom: 0;
  margin: auto 1.5em auto 0;
  box-sizing: border-box;
  border-radius: 2px;
}
form input[type=checkbox] + span::before, form input[type=checkbox] + .wpcf7c-conf-hidden + span::before {
  width: 1em;
  height: 1em;
  background: transparent;
  border: 1px solid var(--main-color);
  left: 0;
}
form input[type=checkbox] + span::after, form input[type=checkbox] + .wpcf7c-conf-hidden + span::after {
  opacity: 0;
  width: 0.4em;
  height: 0.8em;
  border-right: 2px solid var(--main-color);
  border-bottom: 2px solid var(--main-color);
  transform: rotateZ(45deg);
  left: 0.35em;
  bottom: 0.2em;
}
form input[type=checkbox]:checked + span::after {
  opacity: 1;
}
form input[type=checkbox] + .wpcf7c-conf-hidden + span {
  cursor: auto;
}
form input[type=checkbox] + .wpcf7c-conf-hidden + span::after {
  opacity: 1;
}
form input[type=radio] {
  appearance: none;
  display: none;
}
form input[type=radio] + span, form input[type=radio] + .wpcf7c-conf-hidden + span {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  cursor: pointer;
  padding: 0 0 0 1.5em;
  font-size: var(--font-size-input);
  font-weight: 500;
  line-height: 1.2;
}
form input[type=radio] + span::before, form input[type=radio] + span::after, form input[type=radio] + .wpcf7c-conf-hidden + span::before, form input[type=radio] + .wpcf7c-conf-hidden + span::after {
  position: absolute;
  content: "";
  display: block;
  top: 0;
  bottom: 0;
  margin: auto 1.5em auto 0;
  box-sizing: border-box;
  border-radius: 50%;
}
form input[type=radio] + span::before, form input[type=radio] + .wpcf7c-conf-hidden + span::before {
  width: 1em;
  height: 1em;
  background: transparent;
  border: 1px solid var(--main-color);
  left: 0;
}
form input[type=radio] + span::after, form input[type=radio] + .wpcf7c-conf-hidden + span::after {
  opacity: 0;
  width: 0.5em;
  height: 0.5em;
  background: var(--main-color);
  left: 0.25em;
}
form input[type=radio]:checked + span::after {
  opacity: 1;
}
form input[type=radio] + .wpcf7c-conf-hidden + span {
  cursor: auto;
}
form input[type=radio] + .wpcf7c-conf-hidden + span::after {
  opacity: 1;
}
form label {
  display: inline-block;
}
form input[type=button],
form input[type=submit] {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  text-align: center;
  cursor: pointer;
}
form .disabled {
  pointer-events: none;
  filter: opacity(0.5);
}

/* __10: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
html {
  scroll-behavior: smooth;
  overscroll-behavior-y: contain;
  -webkit-overflow-scrolling: touch;
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}
html[data-state=loading] {
  touch-action: none;
  -webkit-overflow-scrolling: none;
  overflow: hidden;
  overscroll-behavior: none;
  cursor: wait;
}
html[data-state=navOpen] {
  touch-action: none;
  -webkit-overflow-scrolling: none;
  overflow: hidden;
  overscroll-behavior: none;
}
html * {
  box-sizing: border-box;
  font-feature-settings: "palt";
  word-break: break-all;
  line-break: strict;
}

body {
  line-height: 1.8;
  background-image: url("../images/common/bg.webp");
  background-size: contain;
  background-position: center;
}

@media screen and (max-width: 865px) {
  .nosp {
    display: none !important;
  }
}

.nopc {
  display: none;
}
@media screen and (max-width: 865px) {
  .nopc {
    display: block;
  }
}

.grecaptcha-badge {
  visibility: hidden;
}

/* __20: 外部ファイル読み込み */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* module */
/* 目次 */
/* __00: 共通設定 */
/* __10: moduleファイル読み込み */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.acdn-toggle {
  position: relative;
  border-top: 2px solid var(--main-color);
}
.acdn-toggle:last-child {
  border-bottom: 2px solid var(--main-color);
}
.acdn-btn {
  all: unset;
  box-sizing: border-box;
  cursor: pointer;
  position: relative;
  width: 100%;
  min-height: 80px;
  display: flex;
  align-items: center;
  text-align: justify;
  padding: 1.2rem;
  padding-right: calc(2.4rem + 28px);
  transition: opacity 0.3s var(--transiton-timing-function);
}
@media screen and (max-width: 865px) {
  .acdn-btn {
    min-height: 70px;
    padding: 1rem 0.5rem;
    padding-right: calc(2rem + 20px);
  }
}
@media (hover: hover) and (pointer: fine) {
  .acdn-btn[aria-expanded=false]:hover {
    opacity: 0.7;
  }
}
.acdn-btn[aria-expanded=true] .acdn-icon {
  transform: rotateZ(45deg);
}
.acdn-icon {
  display: block;
  width: 28px;
  height: 28px;
  position: absolute;
  z-index: 1;
  right: 1.2rem;
  top: 0;
  bottom: 0;
  border: 2px solid var(--main-color);
  border-radius: 50%;
  margin: auto 0 !important;
  transition: transform 0.3s var(--transiton-timing-function);
}
@media screen and (max-width: 865px) {
  .acdn-icon {
    width: 20px;
    height: 20px;
    right: 0.5rem;
  }
}
.acdn-icon::before, .acdn-icon::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 45%;
  height: 2px;
  background-color: var(--main-color);
}
.acdn-icon::after {
  transform: rotateZ(90deg);
}
.acdn-box {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.2s ease-out;
}
.acdn-box[aria-hidden=false] {
  grid-template-rows: 1fr;
}
.acdn-inner {
  overflow: hidden;
}
.acdn-contents {
  width: 100%;
  display: flex;
  align-items: baseline;
  padding: 0 1.2rem 3.2rem;
}
@media screen and (max-width: 865px) {
  .acdn-contents {
    padding: 0 0.5rem 1.6rem;
  }
}

/* __10: moduleファイル読み込み */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* animation.module */
/* 目次 */
/* __00: 共通設定 */
/* __10: ホバーアクション - 下線 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.--js_fadeIn__item,
.--js_fadeUp__item,
.--js_fadeDown__item,
.--js_scaleDown__item,
.--js_scaleUpX__item {
  will-change: transform, opacity;
}

/* __10: ホバーアクション - 下線 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* button */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.button {
  margin-top: 48px;
}
@media screen and (max-width: 865px) {
  .button {
    margin-top: 32px;
  }
}
.button {
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}
.button.--center {
  justify-content: center;
}
.button.--center > * {
  margin: 0 auto;
}
.button.--comingsoon {
  flex-direction: column;
  gap: 10px;
}
.button.--comingsoon .label {
  font-weight: 700;
  font-size: clamp(1.2rem, 1.1713030747vw, 1.6rem);
  width: 200px;
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto;
  border-radius: calc(infinity * 1px);
  transition: 0.3s var(--transiton-timing-function);
  text-align: center;
  background-color: #b3b3b3;
  color: var(--white);
}
@media screen and (max-width: 640px) {
  .button.--comingsoon .label {
    font-size: 16px;
  }
}
.button.--comingsoon .notes {
  color: var(--red);
  font-size: 1.2rem;
  display: block;
  text-align: center;
}
.button.--right > * {
  margin-left: auto;
}
.button-el {
  min-width: 300px;
  min-height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  border-radius: calc(infinity * 1px);
  transition: 0.3s var(--transiton-timing-function);
  padding: 1rem 2rem;
  text-align: center;
}
@media screen and (max-width: 865px) {
  .button-el {
    min-height: 50px;
  }
}
@media screen and (max-width: 640px) {
  .button-el {
    min-height: 40px;
    min-width: 230px;
    padding: 1rem 1.5rem;
  }
  .button-el.spMax {
    width: 100%;
  }
}
@media (hover: hover) and (pointer: fine) {
  .button-el:hover {
    opacity: 0.7;
  }
}
.button-el .label {
  font-weight: 700;
  font-size: clamp(1.2rem, 1.1713030747vw, 1.6rem);
  transition: 0.3s var(--transiton-timing-function);
}
@media screen and (max-width: 640px) {
  .button-el .label {
    font-size: 16px;
  }
}
.button-el-comingsoon {
  border-color: #b3b3b3 !important;
  background-color: #b3b3b3 !important;
}
.button-el-comingsoon .label {
  color: var(--white) !important;
}
@media (hover: hover) and (pointer: fine) {
  .button-el-comingsoon:hover {
    cursor: default;
  }
}
.button-el-arrow {
  padding-left: 5rem;
  padding-right: 5rem;
}
@media screen and (max-width: 865px) {
  .button-el-arrow {
    padding-left: 4rem;
    padding-right: 4rem;
  }
}
@media screen and (max-width: 640px) {
  .button-el-arrow {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}
.button-el-arrow::after {
  content: "";
  display: block;
  width: 30px;
  aspect-ratio: 1/1;
  position: absolute;
  right: 1rem;
  top: 0;
  bottom: 0;
  margin: auto;
  background-image: url("../images/common/arrow/arrow_right.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
@media screen and (max-width: 865px) {
  .button-el-arrow::after {
    width: 30px;
  }
}
@media screen and (max-width: 640px) {
  .button-el-arrow::after {
    width: 20px;
  }
}
.button-el-radius {
  background-color: var(--white);
  border: 2px solid var(--main-color);
}
.button-el-radius .label {
  color: var(--main-color);
}
@media (hover: hover) and (pointer: fine) {
  .button-el-radius:hover {
    background-color: var(--main-color);
    opacity: 1;
  }
  .button-el-radius:hover .label {
    color: var(--white);
  }
}
.button-el-radius.--pink {
  border-color: var(--pink);
  background-color: var(--pink);
}
.button-el-radius.--pink::after {
  display: none;
}
@media (hover: hover) and (pointer: fine) {
  .button-el-radius.--pink:hover {
    background-color: #fff;
  }
  .button-el-radius.--pink:hover .label {
    color: var(--pink);
  }
}
.button-el-radius.--green {
  border-color: var(--white);
  background-color: var(--green);
}
.button-el-radius.--green::after {
  display: none;
}
.button-el-radius.--green .label {
  color: var(--white);
}
@media (hover: hover) and (pointer: fine) {
  .button-el-radius.--green:hover {
    background-color: #fff;
  }
  .button-el-radius.--green:hover .label {
    color: var(--green);
  }
}
.button-el-radius.--cs {
  border-color: #aaa;
  background-color: #aaa;
  pointer-events: none;
}
.button-el-radius.--cs::after {
  display: none;
}
.button-el-radius-re {
  background-color: #fff;
  border: 2px solid var(--main-color);
}
.button-el-radius-re::after {
  display: none;
}
.button-el-radius-re .label {
  color: var(--main-color);
}
@media (hover: hover) and (pointer: fine) {
  .button-el-radius-re:hover {
    background-color: var(--main-color);
    opacity: 1;
  }
  .button-el-radius-re:hover .label {
    color: var(--white);
  }
}
.button-el-radius-re.--pink {
  border-color: var(--pink);
}
.button-el-radius-re.--pink .label {
  color: var(--pink);
}
@media (hover: hover) and (pointer: fine) {
  .button-el-radius-re.--pink:hover {
    background-color: var(--pink);
  }
  .button-el-radius-re.--pink:hover .label {
    color: var(--white);
  }
}
.button-el-radius-re.--green {
  border-color: var(--green);
}
.button-el-radius-re.--green .label {
  color: var(--green);
}
@media (hover: hover) and (pointer: fine) {
  .button-el-radius-re.--green:hover {
    background-color: var(--green);
  }
  .button-el-radius-re.--green:hover .label {
    color: var(--white);
  }
}
.button-el-radius-big {
  background-color: var(--main-color);
}
.button-el-radius-big .label {
  color: var(--white);
  font-size: clamp(1.3rem, 1.8301610542vw, 2.5rem);
}
@media (hover: hover) and (pointer: fine) {
  .button-el-radius-big:hover {
    opacity: 0.7;
  }
}
.button-el-radius-left {
  padding-left: 5rem;
  padding-right: 5rem;
}
@media screen and (max-width: 865px) {
  .button-el-radius-left {
    padding-left: 4rem;
    padding-right: 4rem;
  }
}
.button-el-radius-left::after {
  content: "";
  display: block;
  width: 40px;
  aspect-ratio: 1/1;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  left: 1rem;
  background-image: url("../images/common/arrow/arrow_left.svg");
}
@media screen and (max-width: 865px) {
  .button-el-radius-left::after {
    width: 30px;
  }
}
@media screen and (max-width: 640px) {
  .button-el-radius-left::after {
    width: 20px;
  }
}
.button-el-radius-link {
  background-color: #fff;
  border: 2px solid var(--main-color);
}
.button-el-radius-link::before {
  content: "";
  display: block;
  width: 1.2em;
  height: 1.2em;
  margin-right: 0.5em;
  background-image: url("../images/common/icon/icon_link.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.button-el-radius-link::after {
  content: none;
}
.button-el-radius-link .label {
  color: var(--main-color);
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* drawerButton */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.drawerButton {
  all: unset;
  box-sizing: border-box;
  display: none;
  width: 60px;
  height: 60px;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 99;
  pointer-events: all;
  cursor: pointer;
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.1));
  transition: background-color 0.5s var(--transiton-timing-function);
}
[data-state=navOpen] .drawerButton {
  background-color: var(--main-color);
}
@media screen and (max-width: 865px) {
  .drawerButton {
    display: block;
  }
}
.drawerButton-el {
  width: 48%;
  height: 48%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  margin: auto;
}
.drawerButton-el__bar {
  display: block;
  width: 100%;
  height: 3px;
  margin: 0 auto;
  border-radius: 3px;
  background-color: var(--main-color);
  transition: opacity 0.5s var(--transiton-timing-function);
}
.drawerButton-el__bar.--close {
  opacity: 1;
}
[data-state=navOpen] .drawerButton-el__bar.--close {
  opacity: 0;
}
.drawerButton-el__bar.--open {
  width: 45%;
  position: absolute;
  inset: 0;
  margin: auto;
  background-color: #fff;
  opacity: 0;
}
[data-state=navOpen] .drawerButton-el__bar.--open {
  opacity: 1;
}
.drawerButton-el__bar.--open:nth-child(1) {
  transform: rotateZ(45deg);
}
.drawerButton-el__bar.--open:nth-child(2) {
  transform: rotateZ(-45deg);
}
.drawerButton-el__text {
  display: block;
  font-size: 8px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  color: var(--main-color);
  opacity: 1;
  transition: opacity 0.5s var(--transiton-timing-function);
  white-space: nowrap;
}
[data-state=navOpen] .drawerButton-el__text {
  opacity: 0;
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* toTopButton */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.toTopBtn {
  all: unset;
  display: block;
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 88;
  width: 90px;
  height: 90px;
  cursor: pointer;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s var(--transiton-timing-function);
}
@media screen and (max-width: 865px) {
  .toTopBtn {
    width: 60px;
    height: 60px;
  }
}
@media screen and (max-width: 640px) {
  .toTopBtn {
    position: static;
    width: 100%;
    height: auto;
    margin: 3.2rem auto;
    opacity: 1;
    pointer-events: all;
  }
}
.toTopBtn[data-state=show] {
  pointer-events: all;
  opacity: 1;
}
@media (hover: hover) and (pointer: fine) {
  .toTopBtn:hover img {
    opacity: 0.7;
  }
}
.toTopBtn img {
  display: block;
  transition: opacity 0.3s var(--transiton-timing-function);
}
@media screen and (max-width: 640px) {
  .toTopBtn img {
    width: 68px;
    margin: 0 auto;
  }
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* globalNav */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.globalNav .nav-menu {
  align-items: center;
  display: flex;
  justify-content: center;
  padding: 1rem 0;
}
.globalNav .nav-menu .mega-menu {
  position: absolute;
  padding-top: 10px;
  z-index: 1;
  pointer-events: none;
  opacity: 0;
  transform: translateX(15%);
  transition: all 0.3s var(--transiton-timing-function);
}
.globalNav .nav-menu__item.--shopinfo > a {
  background-color: var(--background-color);
  border: 2px solid var(--main-color);
  color: var(--main-color);
  margin-left: 2rem;
  line-height: 1.2;
  text-align: center;
  transition: transform 0.3s var(--transiton-timing-function);
}
@media (hover: hover) and (pointer: fine) {
  .globalNav .nav-menu__item.--shopinfo > a:hover {
    color: var(--main-color);
    transform: scale(1.1);
  }
}
.globalNav .nav-menu__item.--comingsoon > a {
  color: #b3b3b3;
  line-height: 1.4;
}
@media (hover: hover) and (pointer: fine) {
  .globalNav .nav-menu__item.--comingsoon > a:hover {
    cursor: default;
    color: #b3b3b3;
  }
}
.globalNav .nav-menu__item.--cs > a {
  background-color: #aaa;
  border-color: #aaa;
  pointer-events: none !important;
}
.globalNav .nav-menu__item a {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  font-weight: 700;
  text-decoration: none;
  padding: 0.5em 1em;
  color: var(--font-color);
  transition: color 0.3s var(--transiton-timing-function);
  text-align: center;
}
@media screen and (min-width: 1366px) {
  .globalNav .nav-menu__item a {
    font-size: 14px;
    font-size: 1.0248901903vw;
  }
}
@media screen and (max-width: 1024px) {
  .globalNav .nav-menu__item a {
    font-size: 1.1rem;
  }
}
.globalNav .nav-menu__item a[href="javascript:void(0);"] {
  cursor: inherit;
}
.globalNav .nav-menu__item a[aria-current=true] {
  color: var(--main-color);
}
@media (hover: hover) and (pointer: fine) {
  .globalNav .nav-menu__item a:hover {
    color: var(--main-color);
  }
}
.globalNav .nav-menu__item > a {
  pointer-events: all;
}
.globalNav .nav-menu__item.--active > a {
  color: var(--main-color);
}
.globalNav .nav-menu__item.--active .mega-menu {
  pointer-events: all;
  opacity: 1;
  transform: translateX(0);
}
.globalNav .nav-menu__item.--active .mega-menu a {
  pointer-events: all;
}
.globalNav .nav-menu-sub {
  background-color: #fff;
  padding: 10px 20px;
  border-radius: 20px;
}
.globalNav .nav-menu-sub__item a {
  padding: 0.5em 0;
  justify-content: flex-start;
}
.globalNav .nav-menu-sub__item a::before {
  content: "";
  width: 0.4em;
  height: 0.4em;
  border-top: 2px solid var(--font-color);
  border-right: 2px solid var(--font-color);
  margin: auto 0.5em auto 0;
  transform: rotateZ(45deg);
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* drawerNav */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.drawerNav {
  display: none;
  width: 100%;
  height: 100%;
  position: fixed;
  left: 0;
  bottom: 0;
  z-index: 88;
  background-color: var(--background-color);
  overflow-y: auto;
  transition: opacity 0.5s var(--transiton-timing-function);
  opacity: 0;
  pointer-events: none;
}
@media screen and (max-width: 865px) {
  .drawerNav {
    display: block;
  }
}
[data-state=navOpen] .drawerNav {
  pointer-events: all;
  opacity: 1;
}
.drawerNav-inner {
  width: 300px;
  width: 80vw;
  min-width: 300px;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin: 0 auto;
}
.drawerNav-block__nav p {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 150px;
  width: 40vw;
  min-width: 150px;
  font-size: 26px;
  font-weight: 700;
  text-align: center;
  color: #fff;
  background-color: var(--main-color);
  border-radius: calc(infinity * 1px);
  margin: 0 auto 1em;
}
.drawerNav-block__nav .nav-menu__item a {
  font-size: 16px;
  font-weight: 700;
  color: var(--main-color);
  display: block;
  text-align: center;
  text-decoration: none;
  padding: 0.5em 0;
  position: relative;
}
.drawerNav-block__nav .nav-menu__item a::after {
  background: radial-gradient(circle farthest-side, var(--main-color), var(--main-color) 20%, transparent 20%, transparent);
  background-size: 8px;
  content: "";
  display: inline-block;
  height: 16px;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: -8px;
}
@media screen and (max-width: 640px) {
  .drawerNav-block__nav .nav-menu__item a::after {
    background: radial-gradient(circle farthest-side, var(--main-color), var(--main-color) 15%, transparent 20%, transparent);
    background-size: 9px;
    height: 15px;
  }
}
.drawerNav-block__nav .nav-menu__item a.acdn-btn {
  padding: 0.5em 0 0.5em;
  min-height: inherit;
}
.drawerNav-block__nav .nav-menu__item.acdn-toggle::before {
  content: none;
}
.drawerNav-block__nav .nav-menu__item.--comingsoon > a {
  color: #b3b3b3;
}
@media (hover: hover) and (pointer: fine) {
  .drawerNav-block__nav .nav-menu__item.--comingsoon > a:hover {
    cursor: default;
    color: #b3b3b3;
  }
}
.drawerNav-block__nav .nav-menu__item.--cs a {
  color: #aaa;
  pointer-events: none !important;
}
.drawerNav-block__nav .acdn-box[aria-hidden=false] .sub-menu {
  padding-bottom: 4px;
}
.drawerNav-block__nav .sub-menu {
  background-color: var(--accent-color03);
}
.drawerNav-block__nav .sub-menu .nav-menu-sub {
  display: block;
  padding: 0;
}
.drawerNav-block__nav .sub-menu .nav-menu-sub__item:not(:last-child) a {
  border-bottom: none;
}
.drawerNav-block__nav .sub-menu .nav-menu-sub__item a {
  color: var(--font-color);
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* form.module */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.form .hidden {
  display: none;
}
.form .plus-btn {
  position: relative;
  border-radius: 5px;
  border: 2px solid var(--main-color);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 15px;
  margin: 3rem 0;
  font-size: 18px;
  font-weight: bold;
  color: var(--main-color);
  max-width: 180px;
  height: 50px;
  line-height: 1;
}
@media screen and (max-width: 640px) {
  .form .plus-btn {
    margin-left: auto;
    margin-right: auto;
    font-size: 16px;
    height: 40px;
    max-width: 160px;
    padding: 0 10px;
  }
}
.form .plus-btn .wpcf7-form-control-wrap {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  border: none;
}
.form .plus-btn .wpcf7-list-item {
  margin: 0;
}
.form .plus-btn input[type=checkbox] + .wpcf7c-conf-hidden + span,
.form .plus-btn input[type=checkbox] + span {
  font-size: 0;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  border: none;
}
.form .plus-btn input[type=checkbox] + .wpcf7c-conf-hidden + span::before, .form .plus-btn input[type=checkbox] + .wpcf7c-conf-hidden + span::after,
.form .plus-btn input[type=checkbox] + span::before,
.form .plus-btn input[type=checkbox] + span::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: unset;
  margin: auto;
  line-height: 1;
}
.form .plus-btn input[type=checkbox] + .wpcf7c-conf-hidden + span::before,
.form .plus-btn input[type=checkbox] + span::before {
  content: "";
  width: 20px;
  height: 2px;
  right: 10px;
  line-height: 1;
}
.form .plus-btn input[type=checkbox] + .wpcf7c-conf-hidden + span::after,
.form .plus-btn input[type=checkbox] + span::after {
  content: "";
  width: 2px;
  height: 20px;
  line-height: 1;
  transform: rotate(0);
  right: 19px;
  opacity: 1;
}
.form .plus-btn input[type=checkbox] + .wpcf7c-conf-hidden + span::before, .form .plus-btn input[type=checkbox]:checked + span::before {
  content: "";
  width: 20px;
  height: 2px;
  right: 10px;
  line-height: 1;
}
.form .plus-btn input[type=checkbox] + .wpcf7c-conf-hidden + span::after, .form .plus-btn input[type=checkbox]:checked + span::after {
  content: "";
  width: 2px;
  height: 0;
  line-height: 1;
  transform: rotate(0);
  right: 19px;
}
.form .lead {
  margin-top: -1rem;
  margin-bottom: 2rem;
  font-weight: bold;
}
.form h3.plus-btn {
  max-width: unset;
  display: inline-block;
  vertical-align: middle;
  padding: 15px;
  height: auto;
  margin-top: 0;
}
@media screen and (max-width: ) {
  .form h3.plus-btn {
    padding: 10px;
  }
}
.form dl:not(:last-child) {
  padding-bottom: 2rem;
}
.form dl.--column {
  display: grid;
  align-items: baseline;
  grid-template-columns: 160px 1fr;
  gap: 20px;
}
@media screen and (max-width: 640px) {
  .form dl.--column {
    display: block;
  }
}
.form div.--column {
  display: grid;
  align-items: baseline;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 20px;
}
@media screen and (max-width: 640px) {
  .form div.--column {
    display: block;
  }
}
.form div.--column dl {
  padding-bottom: 2rem;
}
.form div.--column dl.--column {
  display: grid;
  align-items: baseline;
}
@media screen and (max-width: 640px) {
  .form div.--column dl.--column {
    display: block;
  }
}
.form div:first-child {
  align-items: center;
}
.form .--age input {
  width: 5em !important;
}
.form h3,
.form h4 {
  font-size: 15px;
  margin-bottom: 2rem;
}
.form .check_title {
  margin-top: 1rem;
  display: block;
}
.form dt {
  font-size: 1.4rem;
  font-weight: 700;
}
@media screen and (max-width: 640px) {
  .form dt {
    font-size: 13px;
  }
}
.form dt span {
  display: inline-block;
}
.form dd {
  width: 100%;
}
.form dd .input {
  display: block;
}
.form dd .input + .input {
  margin-top: 1rem;
}
.form dd .placeholder {
  font-size: 12px;
  display: block;
}
@media screen and (max-width: 640px) {
  .form dd .placeholder {
    font-size: 10px;
  }
}
.form dd .select {
  display: flex;
  gap: 5px;
  align-items: center;
}
.form dd .select > span .wpcf7-select {
  width: 100%;
  white-space: nowrap;
}
.form dd.--column {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.form dd.--column br {
  display: none !important;
}
.form dd.--column .input {
  font-size: 1em;
  line-height: 2.4;
  position: relative;
}
.form dd.--column .input:not(.fr) {
  width: 49%;
}
.form dd.--column .input.fr {
  width: 100%;
}
.form dd.--column .input + .fr {
  padding-top: 1.5rem;
}
@media screen and (max-width: 1024px) {
  .form dd.--column .input + .fr {
    padding-top: 1rem;
  }
}
.form dd.--column .input.zip {
  width: calc(98% - 100px);
}
.form dd.--column .input.code {
  width: 100px;
}
.form .acceptance {
  text-align: center;
  margin-block: 30px;
}
@media screen and (max-width: 865px) {
  .form .acceptance {
    margin-block: 30px;
  }
}
.form .acceptance a {
  color: var(--font-color);
  font-size: 1em;
}
.form .acceptance a > span {
  display: inline-block;
  position: relative;
  padding: 0 0.2em;
}
.form .acceptance a > span::before, .form .acceptance a > span::after {
  content: "";
  background-color: #000000;
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 4px;
  border-radius: 4px;
  transition: transform 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.form .acceptance a > span::before {
  transform: scaleX(1);
  transform-origin: left;
  transition-delay: 0s;
}
.form .acceptance a > span::after {
  transform: scaleX(0);
  transform-origin: right;
  transition-delay: 0s;
}
@media (hover: hover) and (pointer: fine) {
  .form .acceptance a:hover:hover > span::before {
    transform: scaleX(0);
    transform-origin: right;
    transition-delay: 0s;
  }
  .form .acceptance a:hover:hover > span::after {
    transform: scaleX(1);
    transform-origin: left;
    transition-delay: 0.3s;
  }
}
.form .acceptance a > span::before, .form .acceptance a > span::after {
  height: 1px;
}
.form .acceptance input[type=checkbox] + span {
  font-size: clamp(1.575rem, 1.756954612vw, 2.4rem);
  font-weight: bold;
}
.form .re_captcha {
  text-align: center;
  padding-top: 30px;
}
@media screen and (max-width: 865px) {
  .form .re_captcha {
    padding-top: 20px;
  }
}
.form .re_captcha p {
  font-size: 1.3rem;
  line-height: 1.6;
}
@media screen and (min-width: 1366px) {
  .form .re_captcha p {
    font-size: var(--max-font-size-sm);
  }
}
.form .re_captcha a {
  color: var(--font-color);
  font-size: 1em;
}
.form .re_captcha a > span {
  display: inline-block;
  position: relative;
  padding: 0 0.2em;
}
.form .re_captcha a > span::before, .form .re_captcha a > span::after {
  content: "";
  background-color: #000000;
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 4px;
  border-radius: 4px;
  transition: transform 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.form .re_captcha a > span::before {
  transform: scaleX(1);
  transform-origin: left;
  transition-delay: 0s;
}
.form .re_captcha a > span::after {
  transform: scaleX(0);
  transform-origin: right;
  transition-delay: 0s;
}
@media (hover: hover) and (pointer: fine) {
  .form .re_captcha a:hover:hover > span::before {
    transform: scaleX(0);
    transform-origin: right;
    transition-delay: 0s;
  }
  .form .re_captcha a:hover:hover > span::after {
    transform: scaleX(1);
    transform-origin: left;
    transition-delay: 0.3s;
  }
}
.form .re_captcha a > span::before, .form .re_captcha a > span::after {
  height: 1px;
}
.form .hissu {
  color: var(--main-color);
  margin-right: 5px;
}
.form .text-box p {
  line-height: 2;
}

.form input[type=text],
.form input[type=tel],
.form input[type=email],
.form textarea {
  border: 1px solid var(--border-color);
  background-color: var(--accent-color02);
  width: 100%;
}
.form input[type=text]:focus,
.form input[type=tel]:focus,
.form input[type=email]:focus,
.form textarea:focus {
  outline: none;
}
.form select {
  -webkit-appearance: none;
  appearance: none;
  align-items: center;
  background-color: #e6e6e6;
  width: 50%;
  background-size: 10px;
  background-repeat: no-repeat;
  background-position: center right 1rem;
}
@media screen and (max-width: 640px) {
  .form select {
    width: 100%;
  }
}
.form select:focus {
  outline: none;
}
.form input[type=text],
.form input[type=tel],
.form input[type=email],
.form select {
  height: 40px;
  padding: 0 5px;
}
.form input[name=count] {
  width: 4em;
  text-align: right;
  margin-right: 0.5em;
}
.form textarea {
  height: 150px;
  padding: 0.5em;
}
.form .button {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2rem 0;
}
@media screen and (max-width: 640px) {
  .form .button {
    flex-direction: column;
  }
}
.form .confirm,
.form .submit,
.form .back {
  margin: 0 1rem;
}
.form .confirm input[type=submit],
.form .confirm input[type=button],
.form .submit input[type=submit],
.form .submit input[type=button],
.form .back input[type=submit],
.form .back input[type=button] {
  all: unset;
  box-sizing: border-box;
  display: block;
  max-width: 210px;
  min-width: 210px;
  width: 100%;
  height: 100%;
  border-radius: 999px;
  background-color: var(--main-color);
  border: 2px solid var(--main-color);
  color: #fff;
  font-family: var(--ff-bold);
  font-size: 1em;
  font-weight: bold;
  text-align: center;
  cursor: pointer;
  transition: background-color 0.3s var(--transiton-timing-function), color 0.3s var(--transiton-timing-function);
  height: 60px;
}
@media screen and (max-width: 640px) {
  .form .confirm input[type=submit],
  .form .confirm input[type=button],
  .form .submit input[type=submit],
  .form .submit input[type=button],
  .form .back input[type=submit],
  .form .back input[type=button] {
    height: 40px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .form .confirm input[type=submit]:hover:hover,
  .form .confirm input[type=button]:hover:hover,
  .form .submit input[type=submit]:hover:hover,
  .form .submit input[type=button]:hover:hover,
  .form .back input[type=submit]:hover:hover,
  .form .back input[type=button]:hover:hover {
    background-color: #fff;
    color: var(--main-color);
  }
}
.form .back input[type=button] {
  background-color: #a0a0a0;
  border-color: #a0a0a0;
}
@media (hover: hover) and (pointer: fine) {
  .form .back input[type=button]:hover:hover {
    color: #a0a0a0;
  }
}

.form .wpcf7c-conf {
  border: none;
}
.form .wpcf7-list-item {
  margin: 0 1em 0 0;
}
@media screen and (max-width: 640px) {
  .form .wpcf7-radio .wpcf7-list-item {
    display: block;
  }
}
.form .wpcf7 .wpcf7-response-output {
  margin-top: 1rem;
  padding: 0;
  text-align: center;
  border: none;
  color: #dc3232;
  font-size: 1.5rem;
  font-weight: normal;
  display: block;
}
.form .wpcf7-spinner {
  position: fixed;
  right: 4rem;
  bottom: 1.8rem;
  background-color: var(--font-link);
  opacity: 1;
}
@media screen and (max-width: 640px) {
  .form .wpcf7-spinner {
    right: 0;
    bottom: 24px;
  }
}

[data-name=nameBox] {
  display: none;
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* blocks */
/* 目次 */
/* __00: blocksファイル読み込み */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: blocksファイル読み込み */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content */
/* 目次 */
/* __00: 初期設定 */
/* __10: contentファイル読み込み */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 初期設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content */
/* 目次 */
/* __00: 初期設定 */
/* __10: 固定ページ */
/* __20: 投稿ページ */
/* __30: 投稿カテゴリーページ */
/* __40: 投稿アーカイブページ */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 初期設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __10: 固定ページ */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __20: 投稿ページ */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __30: 投稿カテゴリーページ */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __40: 投稿アーカイブページ */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __50: 404 Not Faund */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
main .content-inner {
  padding-block: 100px;
}
@media screen and (max-width: 865px) {
  main .content-inner {
    padding-block: 50px;
  }
}
main .content-block {
  width: calc(100% - 50px);
  max-width: 850px;
  margin: 0 auto;
}
main .content-block.--mw-full {
  width: 100%;
  max-width: inherit;
}
main .content-block.--mw-full .--mw-base {
  width: calc(100% - 50px);
  max-width: 850px;
  margin: 0 auto;
}
main .content-block.--mw-sm {
  max-width: 810px;
}
main.single .content-post {
  position: relative;
  width: calc(100% - 50px);
  max-width: 1050px;
  margin: 0 auto;
  padding-block: 50px;
}
@media screen and (max-width: 865px) {
  main.single .content-post {
    padding-block: 32px;
  }
}
main.single .content-post .inner {
  width: calc(100% - 50px);
  max-width: 960px;
  margin: 0 auto;
  padding-top: 40px;
}
@media screen and (max-width: 640px) {
  main.single .content-post .inner {
    padding-top: 20px;
  }
}
main.single .content-post .title {
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 20px;
}
@media screen and (max-width: 865px) {
  main.single .content-post .title {
    padding-bottom: 10px;
  }
}
main.single .content-post .title {
  margin-bottom: 50px;
}
@media screen and (max-width: 865px) {
  main.single .content-post .title {
    margin-bottom: 32px;
  }
}
main.single .content-post .title {
  width: 90%;
  position: relative;
}
main.single .content-post .title::after {
  background: radial-gradient(circle farthest-side, var(--main-color), var(--main-color) 20%, transparent 20%, transparent);
  background-size: 8px;
  content: "";
  display: inline-block;
  height: 16px;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: -8px;
}
main.single .content-post .title .meta {
  display: flex;
  align-items: center;
  gap: 1.6rem;
  margin-bottom: 10px;
}
main.single .content-post .title .meta .date {
  color: var(--main-color);
  font-size: 24px;
}
main.single .content-post .title .meta .category {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  width: fit-content;
  min-width: 70px;
  gap: 6px;
}
main.single .content-post .title .meta .category .label {
  font-size: 18px;
  text-align: center;
  font-weight: 700;
  color: #fff;
  background-color: var(--main-color);
  border-radius: 3px;
  padding: 0 0.5em;
  line-height: 1.8;
}
main.single .content-post .title h1 {
  font-size: 28px;
  font-weight: 500;
  line-height: 1.8;
  word-break: break-word;
}
main.single .content-post .container {
  margin-left: auto;
  margin-right: auto;
  width: 90%;
}
main.single .content-post .container ul:not(.block-editor-block-variation-picker__variations) {
  list-style: revert;
  padding-left: 20px;
}
main.single .content-post .container ul:not(.block-editor-block-variation-picker__variations) li::marker {
  color: var(--main-color);
}
main.single .content-post .container ol {
  list-style: revert;
  padding-left: 20px;
}
main.single .content-post .container ol li::marker {
  color: var(--main-color);
}
main.single .content-post .container h2 {
  background-color: #f7f7f7;
  border-bottom: 3px solid var(--main-color);
  padding: 0.25em 0.5em;
}
main.single .content-post .container h3 {
  border-left: 3px solid var(--main-color);
  padding-left: 0.5em;
}
main.single .content-post .container h4 {
  display: flex;
  align-items: center;
}
main.single .content-post .container h4::before {
  content: "";
  display: block;
  width: 1em;
  height: 3px;
  background-color: var(--main-color);
  margin-right: 0.5em;
}
main.single .content-post .container > * + * {
  margin-top: 30px;
}
@media screen and (max-width: 865px) {
  main.single .content-post .container > * + * {
    margin-top: 20px;
  }
}
main.single .content-post .container > *:first-child {
  margin-top: 0;
}
main.single .content-post .container iframe {
  width: 100%;
  aspect-ratio: 3/2;
}
main.single .content-post .container p,
main.single .content-post .container a,
main.single .content-post .container li {
  font-size: 20px;
}
@media screen and (max-width: 640px) {
  main.single .content-post .container p,
  main.single .content-post .container a,
  main.single .content-post .container li {
    font-size: 16px;
  }
}
@media (hover: hover) and (pointer: fine) {
  main.single .content-post .container a:not([class]):hover:hover {
    opacity: 0.7;
  }
}
main.single .content-post-shop {
  width: calc(100% - 50px);
  max-width: 1050px;
  margin: 0 auto;
  padding-top: 30px;
}
@media screen and (max-width: 865px) {
  main.single .content-post-shop {
    padding-top: 20px;
  }
}
main.single .content-post-shop h2 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  font-size: var(--font-size-lg);
  font-weight: 700;
  text-align: center;
  text-wrap: balance;
  letter-spacing: 0.1em;
  color: var(--main-color);
  margin: 10px auto 40px;
  max-width: 86%;
}
@media screen and (max-width: 640px) {
  main.single .content-post-shop h2 {
    margin-bottom: 20px;
    max-width: 100%;
  }
}
main.single .content-post-shop h2::before, main.single .content-post-shop h2::after {
  content: "";
  display: block;
  width: 2em;
  height: 2px;
  background-color: var(--main-color);
}
@media screen and (max-width: 640px) {
  main.single .content-post-shop h2::before, main.single .content-post-shop h2::after {
    flex-grow: 1;
  }
}
main.single .content-post-shop .inner {
  display: grid;
  grid-template-columns: auto 330px;
  gap: 2rem;
}
@media screen and (max-width: 640px) {
  main.single .content-post-shop .inner {
    grid-template-columns: 1fr;
    row-gap: 2.4rem;
  }
}
main.single .content-post-shop .border {
  width: calc(100% - 50px);
  max-width: 800px;
  margin: 0 auto;
  background: var(--white);
  position: relative;
}
@media screen and (max-width: 640px) {
  main.single .content-post-shop .border {
    width: 100%;
  }
}
main.single .content-post-shop .border::before {
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: var(--main-color);
  position: absolute;
}
main.single .content-post-shop .border::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  right: -15px;
  bottom: -15px;
  background: linear-gradient(90deg, rgb(214, 135, 226) 0%, rgb(143, 58, 201) 100%);
  z-index: -1;
}
main.single .content-post-shop .border-inner {
  position: relative;
  padding: 20px 30px;
  display: flex;
  flex-direction: column;
  height: 100%;
}
@media screen and (max-width: 640px) {
  main.single .content-post-shop .border-inner {
    padding: 20px;
  }
}
main.single .content-post-shop .border-inner::before {
  content: "";
  top: 0;
  left: 0;
  width: 2px;
  height: 100%;
  background-color: var(--main-color);
  position: absolute;
}
main.single .content-post-shop .outline .ticket {
  display: flex;
  align-items: center;
  gap: 4px;
  padding-top: 10px;
  flex-wrap: wrap;
}
main.single .content-post-shop .outline .ticket .label {
  display: flex;
  align-items: center;
}
main.single .content-post-shop .outline .ticket .label.denomination {
  gap: 10px;
}
@media screen and (max-width: 640px) {
  main.single .content-post-shop .outline .ticket .label.denomination {
    gap: 5px;
  }
}
main.single .content-post-shop .outline .ticket .label.denomination span {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 70px;
  font-size: 17px;
  height: 26px;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  background-color: var(--pink);
}
main.single .content-post-shop .outline .ticket .label.denomination span.denomination02 {
  background-color: var(--green);
}
main.single .content-post-shop .outline .ticket .label.ticketType {
  gap: 10px;
}
@media screen and (max-width: 640px) {
  main.single .content-post-shop .outline .ticket .label.ticketType {
    gap: 5px;
  }
}
main.single .content-post-shop .outline .ticket .label.ticketType span {
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: 700;
  line-height: 1;
  font-size: 17px;
  height: 26px;
  padding: 0 15px;
  white-space: nowrap;
  background-color: var(--accent-color02);
  color: var(--white);
}
@media screen and (max-width: 640px) {
  main.single .content-post-shop .outline .ticket .label.ticketType span {
    font-size: 12px;
    height: 20px;
    padding: 0 8px;
  }
}
main.single .content-post-shop .outline .ticket .label.ticketType span.type02 {
  background-color: inherit;
  padding: 0;
  color: var(--white);
  gap: 10px;
}
main.single .content-post-shop .outline .ticket .label.ticketType span.type02 span {
  background-color: var(--accent-color02);
}
main.single .content-post-shop .outline .ticket .label.ticketType span.type02 span + span {
  background-color: var(--accent-color03);
}
main.single .content-post-shop .outline h1 {
  display: block;
  width: fit-content;
  font-size: clamp(1.95rem, 1.9033674963vw, 2.6rem);
  line-height: 1.4;
  font-weight: 700;
  padding: 0.5em 0 1em;
}
main.single .content-post-shop .outline .area {
  width: fit-content;
  padding: 0.2em 0.5em;
  margin-bottom: 0.5em;
  color: var(--main-color);
  font-size: clamp(1.275rem, 1.2445095168vw, 1.7rem);
  font-weight: 700;
  line-height: 1.2;
  border: 2px solid var(--main-color);
}
main.single .content-post-shop .outline .address {
  font-size: clamp(1.35rem, 1.317715959vw, 1.8rem);
}
main.single .content-post-shop .outline .tel {
  font-size: clamp(1.5rem, 1.4641288433vw, 2rem);
}
main.single .content-post-shop .outline .button {
  margin-top: 10px;
}
@media screen and (max-width: 640px) {
  main.single .content-post-shop .outline .button-el {
    margin-inline: auto;
  }
}
main.single .content-post-shop .outline .comment {
  margin-top: 2.4rem;
}
main.single .content-post-shop .outline .comment h2 {
  width: 60px;
  transform: translateX(-70%);
}
@media screen and (max-width: 865px) {
  main.single .content-post-shop .outline .comment h2 {
    transform: translateX(-20px);
  }
}
main.single .content-post-shop .outline .comment p {
  font-weight: 700;
  border-bottom: 4px dotted var(--main-color);
  line-height: 1.6;
  padding-bottom: 0.5em;
}
main.single .content-post-shop .map {
  width: 100%;
  height: 330px;
  background-color: #fff;
  padding: 10px;
}
@media screen and (max-width: 640px) {
  main.single .content-post-shop .map {
    height: 100%;
    aspect-ratio: 1;
  }
}
main.single .content-post-shop .map iframe {
  display: block;
  width: 100%;
  height: 100%;
}
main.category .content-archive {
  width: calc(100% - 50px);
  max-width: 1050px;
  margin: 0 auto;
  padding-top: 50px;
}
@media screen and (max-width: 865px) {
  main.category .content-archive {
    padding-top: 20px;
  }
}
main.category .content-archive-shop {
  width: calc(100% - 50px);
  max-width: 1050px;
  margin: 0 auto;
}
main.archive .content-archive {
  width: calc(100% - 50px);
  max-width: 1050px;
  margin: 0 auto;
  padding-top: 50px;
}
@media screen and (max-width: 865px) {
  main.archive .content-archive {
    padding-top: 20px;
  }
}
main.archive .content-archive-shop {
  width: calc(100% - 50px);
  max-width: 1050px;
  margin: 0 auto;
}
main.index__404 .p-404 .p-contents-block {
  width: calc(100% - 50px);
  max-width: 850px;
  margin: 0 auto;
}
main.index__404 .p-404 p {
  text-align: center;
}

/* __10: contentファイル読み込み */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-pagenation */
/* 目次 */
/* __00: 初期設定 */
/* __10: ページャー */
/* __20: 次・前・一覧ボタン */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 初期設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.content-pagination {
  width: calc(100% - 50px);
  max-width: 690px;
  margin: 0 auto;
  padding-bottom: 100px;
}
@media screen and (max-width: 865px) {
  .content-pagination {
    padding-bottom: 50px;
  }
}
.content-pagination .page-nav {
  display: flex;
  justify-content: center;
  gap: var(--font-size-text);
}
@media screen and (max-width: 640px) {
  .content-pagination .page-nav {
    gap: 8px;
  }
}
.content-pagination .page-nav .page-numbers {
  display: flex;
  width: 2em;
  height: 2em;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-text);
  text-decoration: none;
  border-radius: 50%;
  color: var(--main-color);
  transition: 0.3s var(--transiton-timing-function);
  background-color: var(--accent-color01);
}
@media (hover: hover) and (pointer: fine) {
  .content-pagination .page-nav .page-numbers:hover {
    background-color: var(--main-color);
    color: #fff;
  }
}
.content-pagination .page-nav .page-numbers.current {
  background-color: var(--main-color);
  color: #fff;
  pointer-events: none;
}
.content-pagination .post-nav {
  display: flex;
  justify-content: space-between;
  gap: var(--font-size-text);
}
@media screen and (max-width: 640px) {
  .content-pagination .post-nav {
    display: grid;
  }
}
.content-pagination .post-nav .post-next,
.content-pagination .post-nav .post-prev {
  display: flex;
  align-items: center;
  gap: 0.5em;
  font-size: var(--font-size-text);
  transition: opacity 0.3s var(--transiton-timing-function);
}
.content-pagination .post-nav .post-next[disabled],
.content-pagination .post-nav .post-prev[disabled] {
  cursor: not-allowed;
  opacity: 0.5;
}
.content-pagination .post-nav .post-next img,
.content-pagination .post-nav .post-prev img {
  width: 25px;
  pointer-events: none;
}
.content-pagination .post-nav .post-next .label,
.content-pagination .post-nav .post-prev .label {
  font-weight: 600;
  color: var(--font-caption);
}
@media (hover: hover) and (pointer: fine) {
  .content-pagination .post-nav .post-next:not([disabled]):hover {
    opacity: 0.7;
  }
}
@media (hover: hover) and (pointer: fine) {
  .content-pagination .post-nav .post-prev:not([disabled]):hover {
    opacity: 0.7;
  }
}
.content-pagination .post-nav .button {
  margin: 0;
}
@media screen and (max-width: 640px) {
  .content-pagination .post-nav .button {
    grid-row: 2;
    grid-column: 1/3;
    width: auto;
  }
}
.content-pagination .post-nav .button-el::after {
  content: none;
}
.content-pagination .button {
  margin-top: 0;
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-title */
/* 目次 */
/* __00: 初期設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 初期設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.content-title {
  position: relative;
}
.content-title .bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  margin: auto;
  pointer-events: none;
  mix-blend-mode: multiply;
}
.content-title .bg img {
  width: 100%;
}
.content-title .head {
  padding-top: 150px;
}
@media screen and (max-width: 865px) {
  .content-title .head {
    padding-top: 60px;
  }
}
.content-title .head {
  width: calc(100% - 50px);
  max-width: 850px;
  margin: 0 auto;
  position: relative;
}
.content-title .head .icon {
  width: 55px;
  display: block;
  margin: 0 auto 10px;
}
@media screen and (max-width: 640px) {
  .content-title .head .icon {
    width: 35px;
  }
}
.content-title .head .icon img {
  aspect-ratio: 1/1;
}
.content-title .head h1 {
  font-size: var(--font-size-xxl);
  font-weight: 700;
  text-align: center;
  text-wrap: balance;
  letter-spacing: 0.1em;
  color: var(--main-color);
}
@media screen and (max-width: 640px) {
  .content-title .head h1 {
    font-size: var(--font-size-xl);
  }
}
.content-title .head h2 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  margin-top: 48px;
}
@media screen and (max-width: 865px) {
  .content-title .head h2 {
    margin-top: 24px;
  }
}
.content-title .head h2 {
  font-size: var(--font-size-lg);
  font-weight: 700;
  text-align: center;
  text-wrap: balance;
  letter-spacing: 0.1em;
  color: var(--main-color);
}
.content-title .head h2::before, .content-title .head h2::after {
  content: "";
  display: block;
  width: 2em;
  height: 2px;
  background-color: var(--main-color);
}
@media screen and (max-width: 640px) {
  .content-title .head h2::before, .content-title .head h2::after {
    width: auto;
    flex-grow: 1;
  }
}
.index__overview .content-title .head {
  background-color: var(--accent-color02);
}
.index__overview .content-title .head h1 {
  width: calc(100% - 40px);
  max-width: 730px;
  margin: 0 auto;
  border-bottom: 3px dashed var(--main-color);
  padding-bottom: 0.3em;
}
.content-title .head .count {
  text-align: center;
  padding-top: 1em;
}
.content-title .head .count span {
  font-size: 1.5em;
  font-weight: 700;
  color: var(--main-color);
  padding: 0 0.2em;
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-faq */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.faq-box-el__title .faq-btn .label {
  font-size: var(--font-size-text);
  font-weight: 700;
  line-height: 1.4;
  word-break: break-word;
  color: var(--main-color);
}
.faq-box-el .unit {
  font-size: 1.6rem;
  font-weight: 700;
  margin-right: 0.5em;
  color: var(--main-color);
  word-break: keep-all;
}
.faq-box-el .text {
  font-size: 1.6rem;
}
.faq-box-el .text .note {
  display: inline-block;
  padding-left: 1em;
  text-indent: -1em;
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-app */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.app-box .head h4 {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1em;
  font-size: var(--font-size-text);
  font-weight: 700;
}
.app-box .head h4::before, .app-box .head h4::after {
  content: "";
  display: block;
  width: 6em;
  height: 2px;
  background-color: var(--main-color);
}
@media screen and (max-width: 640px) {
  .app-box .head h4::before, .app-box .head h4::after {
    width: auto;
    flex-grow: 1;
  }
}
.app-box .app {
  display: flex;
  padding-top: 48px;
}
@media screen and (max-width: 865px) {
  .app-box .app {
    padding-top: 32px;
  }
}
.app-box .app {
  column-gap: 1.6rem;
  justify-content: center;
}
.app-box .app-item {
  width: fit-content;
}
.app-box .app a {
  display: block;
  height: 50px;
  transition: opacity 0.3s var(--transiton-timing-function);
}
@media screen and (max-width: 865px) {
  .app-box .app a {
    height: 40px;
    height: 12.5vw;
    max-height: 50px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .app-box .app a:hover {
    opacity: 0.7;
  }
}
.app-box .app a img {
  display: block;
  height: 100%;
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-search-form */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.content-page .shoplist .p-contents-block {
  width: calc(100% - 50px);
  max-width: 1050px;
  margin: 0 auto;
}

.search-form {
  width: 90%;
  margin: auto;
  display: grid;
  grid-template-columns: 1fr;
  column-gap: 32px;
  column-gap: 2.3426061493vw;
  row-gap: 64px;
  row-gap: 4.6852122987vw;
}
@media screen and (min-width: 1366px) {
  .search-form {
    column-gap: 3.2rem;
    row-gap: 6.4rem;
  }
}
@media screen and (max-width: 865px) {
  .search-form {
    grid-template-columns: 1fr;
    row-gap: 3.2rem;
  }
}
@media screen and (max-width: 640px) {
  .search-form {
    width: 100%;
  }
}
.search-form .search-item-title {
  background-color: var(--main-color);
  border-radius: 10px 10px 0 0;
  margin-bottom: 0;
  padding: 1rem 2rem 0;
  text-align: center;
  width: 250px;
}
.search-form .search-item-title .label {
  border-bottom: 3px dotted var(--white);
  color: var(--white);
  display: block;
  font-size: clamp(1.6rem, 1.4486rem + 0.4036vw, 2rem);
  font-weight: 700;
  padding-bottom: 1rem;
}
@media screen and (max-width: 640px) {
  .search-form .search-item-title {
    padding: 15px 10px 0;
    width: 200px;
  }
}
.search-form .search-item.free-word .search-item-title {
  background-color: inherit;
  border-bottom: 3px dotted var(--main-color);
  margin-bottom: 2rem;
  padding: 0;
  text-align: center;
  width: auto;
}
.search-form .search-item.free-word .search-item-title .label {
  color: var(--main-color);
  font-size: clamp(1.6rem, 1.4486rem + 0.4036vw, 2rem);
  font-weight: 700;
}
.search-form .search-item hr {
  all: unset;
  display: block;
  position: relative;
  width: 100%;
  margin: auto;
}
.search-form .search-item-note {
  margin-top: 2rem;
  font-size: 14px;
}
@media screen and (max-width: 640px) {
  .search-form .search-item-note {
    display: block;
    font-size: 12px;
  }
}
.search-form .search-item-content.border-content {
  border: 20px solid var(--main-color);
}
@media screen and (max-width: 640px) {
  .search-form .search-item-content.border-content {
    border-width: 10px;
  }
}
.search-form .search-item-content__inner {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  width: 90%;
  margin: 1rem auto;
}
@media screen and (max-width: 640px) {
  .search-form .search-item-content__inner {
    display: block;
  }
}
.search-form .search-item-content__inner label {
  cursor: pointer;
  display: block;
  margin-right: 1rem;
  padding: 10px 0;
}
.search-form .search-item-content__inner label:first-of-type {
  grid-column: 1/3;
  margin: 0 0 5px;
  padding-bottom: 1.5rem;
  border-bottom: 2px solid var(--main-color);
}
.search-form .search-item-content__inner label:first-of-type span::before {
  border-width: 2px;
}
@media screen and (max-width: 640px) {
  .search-form .search-item-content__inner label {
    display: block;
    margin-right: 0;
  }
}
.search-form .search-item-content__inner .text {
  grid-column: 1/3;
  margin-bottom: 2rem;
}
.search-form .search-item-content__inner .text p {
  color: var(--main-color);
  padding-left: 1em;
  text-indent: -1em;
}
.search-form .free-word {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  border: unset;
  gap: 2rem;
  padding: 0;
}
@media screen and (max-width: 640px) {
  .search-form .free-word {
    display: block;
    margin-bottom: 0;
  }
}
.search-form .free-word .search-item-title {
  margin: 0;
}
@media screen and (max-width: 640px) {
  .search-form .free-word .search-item-title {
    margin: 1rem 0;
  }
}
.search-form .free-word label {
  display: block;
  width: 100%;
  position: relative;
}
@media screen and (max-width: 640px) {
  .search-form .free-word label {
    margin: 0 auto;
  }
}
.search-form .free-word label::before {
  content: "";
  display: block;
  width: 22px;
  height: 22px;
  background-image: url("../images/common/icon/icon_search.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  left: 1rem;
  top: 0;
  bottom: 0;
  margin: auto 0;
}
.search-form .free-word label input[type=text] {
  border: 2px solid var(--main-color);
  border-radius: calc(infinity * 1px);
  background-color: #fff;
  width: 100%;
  height: 40px;
  padding-left: calc(1.5rem + 22px);
}
@media screen and (max-width: 640px) {
  .search-form .free-word label input[type=text] {
    width: 100%;
  }
}
.search-form .free-word .search-item-content {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 25px;
}
@media screen and (max-width: 640px) {
  .search-form .free-word .search-item-content {
    grid-template-columns: unset;
  }
}
.search-form .free-word .search-item-content .all-shop {
  width: 160px;
  position: relative;
}
@media screen and (max-width: 640px) {
  .search-form .free-word .search-item-content .all-shop {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    gap: 1rem;
  }
}
.search-form .free-word .search-item-content .all-shop a {
  background-color: var(--yellow);
  border: 2px solid var(--main-color);
  border-radius: 10px;
  color: var(--main-color);
  display: block;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 1rem;
  padding: 1rem 0;
  transition: opacity 0.3s var(--transiton-timing-function);
  text-align: center;
  text-decoration: none;
}
@media screen and (max-width: 640px) {
  .search-form .free-word .search-item-content .all-shop a {
    width: 100px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .search-form .free-word .search-item-content .all-shop a:hover {
    opacity: 0.7;
  }
}
.search-form .free-word .search-item-content .all-shop p {
  color: var(--main-color);
  text-align: center;
  line-height: 1.2;
}
@media screen and (max-width: 640px) {
  .search-form .free-word .search-item-content .all-shop p {
    position: static;
    transform: unset;
    width: auto;
    font-size: 13px;
    margin: 5px 0;
  }
}
.search-form .free-word .search-item-content .all-shop p span {
  font-size: 1.2em;
  font-weight: 700;
  line-height: 1;
  padding: 0 0.2em;
}
.search-form .search-submit {
  position: sticky;
  border: unset;
  bottom: 3rem;
  padding: 0;
}
@media screen and (max-width: 640px) {
  .search-form .search-submit {
    bottom: 10px;
  }
}
.search-form .search-submit .button {
  margin-top: 0;
  position: relative;
  z-index: 1;
  max-width: 300px;
}
.search-form .search-submit .button input[type=submit] {
  position: absolute;
  display: block;
  width: 230px;
  inset: 0;
  margin: auto;
  z-index: 2;
  opacity: 0;
  border-radius: calc(infinity * 1px);
}
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* contents */
/* 目次 */
/* __00: 初期設定 */
/* __10: 追加コンテンツ */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __10: 追加コンテンツ */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* contents-post */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.post-list {
  display: grid;
}
.post-list__item a {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  text-decoration: none;
  gap: 15px;
  padding: 20px 15px;
  transition: opacity 0.3s var(--transiton-timing-function);
  position: relative;
  border-bottom: 3px dotted var(--main-color);
}
@media screen and (max-width: 1024px) {
  .post-list__item a {
    padding: 2rem 0.5em;
    border-bottom-width: 2px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .post-list__item a:hover .title {
    color: var(--main-color);
  }
}
.post-list__item a .category {
  display: flex;
  flex-wrap: wrap;
  width: fit-content;
  min-width: 70px;
  gap: 0.25em;
}
.post-list__item a .category .label {
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  background-color: var(--main-color);
  border-radius: 3px;
  padding: 0 0.5em;
  line-height: 1.8;
}
.post-list__item a .date {
  color: var(--main-color);
  display: block;
  font-weight: 700;
  text-align: center;
  line-height: 1.2;
  font-size: 16px;
}
@media screen and (max-width: 1024px) {
  .post-list__item a .date {
    min-width: inherit;
  }
}
@media screen and (max-width: 640px) {
  .post-list__item a .date {
    font-size: 14px;
  }
}
.post-list__item a .title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  line-height: 1.2;
  color: var(--font-color);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.6;
  width: 100%;
  transition: opacity 0.3s var(--transiton-timing-function);
}
@media screen and (max-width: 640px) {
  .post-list__item a .title {
    font-size: 14px;
  }
}
.post-none {
  text-align: center;
}

/* __10: post-news */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.category .post-list {
  width: calc(100% - 50px);
  max-width: 800px;
  margin: 0 auto;
}

/* __20: 加盟店一覧 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.shop .count {
  text-align: center;
  margin-bottom: 30px;
}
.shop .count span {
  color: var(--main-color);
  font-size: clamp(1.875rem, 1.8301610542vw, 2.5rem);
  font-weight: bold;
}

.shop-list {
  width: calc(100% - 50px);
  max-width: 870px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
}
@media screen and (max-width: 865px) {
  .shop-list {
    grid-template-columns: 1fr;
  }
}
@media screen and (max-width: 640px) {
  .shop-list {
    width: 100%;
  }
}

.shop-list__item {
  display: flex;
  flex-direction: column;
  position: relative;
}
.shop-list__item .border {
  background-color: var(--white);
  border: 2px solid var(--main-color);
  border-radius: 15px;
  position: relative;
  padding: 20px;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.shop-list__item .meta {
  position: relative;
  padding-right: 90px;
}
.shop-list__item .meta .industry {
  display: flex;
  align-items: center;
  gap: 0.3em;
  font-weight: 700;
  line-height: 1.2;
  color: var(--main-color);
}
.shop-list__item .meta .area {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: absolute;
  top: 0;
  right: 0;
}
.shop-list__item .meta .area span {
  font-size: var(--font-size-sm);
  font-weight: 700;
  line-height: 1.2;
  border: 1px solid var(--main-color);
  color: var(--main-color);
  padding: 0.2em;
  max-width: 7em;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .shop-list__item .meta .area span {
    max-width: 80px;
  }
}
.shop-list__item .ticket {
  display: flex;
  align-items: center;
  gap: 4px;
  padding-top: 10px;
  padding-right: 90px;
  flex-wrap: wrap;
}
.shop-list__item .ticket .label {
  display: flex;
  align-items: center;
  font-size: 1rem;
  font-weight: 700;
}
.shop-list__item .ticket .label.denomination {
  gap: 4px;
}
.shop-list__item .ticket .label.denomination span {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 55px;
  height: 18px;
  font-weight: 700;
  line-height: 1;
  font-size: 12px;
  color: #fff;
  background-color: var(--pink);
}
.shop-list__item .ticket .label.denomination span.denomination02 {
  background-color: var(--green);
}
.shop-list__item .ticket .label.ticketType {
  gap: 4px;
}
.shop-list__item .ticket .label.ticketType span {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 18px;
  font-weight: 700;
  line-height: 1;
  font-size: 12px;
  background-color: var(--accent-color02);
  color: #fff;
  padding: 0 8px;
  white-space: nowrap;
}
.shop-list__item .ticket .label.ticketType span.type02 {
  background: #fff;
  color: var(--main-color);
  gap: 10px;
  padding: 0;
}
.shop-list__item .ticket .label.ticketType span.type02 span {
  background-color: var(--accent-color02);
}
.shop-list__item .ticket .label.ticketType span.type02 span + span {
  background-color: var(--accent-color03);
}
.shop-list__item .title {
  display: block;
  width: fit-content;
  font-size: clamp(1.6rem, 1.4486rem + 0.4036vw, 2rem);
  line-height: 1.4;
  font-weight: 700;
  padding: 0.5em 0 1em;
}
.shop-list__item .address {
  display: flex;
  align-items: center;
  line-height: 1.2;
  font-size: clamp(1.05rem, 1.0248901903vw, 1.4rem);
  margin-top: auto;
}
.shop-list__item .address a {
  flex: none;
  width: 32px;
  text-align: center;
  margin-left: 1em;
  font-size: clamp(0.9rem, 0.878477306vw, 1.2rem);
  font-weight: 700;
  line-height: 1.2;
  text-decoration: none;
  color: var(--main-color);
  border: 2px solid var(--main-color);
  border-radius: calc(infinity * 1px);
  transition: all 0.3s var(--transiton-timing-function);
}
@media (hover: hover) and (pointer: fine) {
  .shop-list__item .address a:hover {
    background-color: var(--main-color);
    color: #fff;
  }
}
.shop-list__item .tel {
  font-size: clamp(1.35rem, 1.317715959vw, 1.8rem);
  font-weight: bold;
  margin-bottom: 10px;
}
.shop-list__item .button {
  margin: 0;
}
@media screen and (max-width: 640px) {
  .shop-list__item .button {
    margin-left: auto;
    margin-right: auto;
  }
}
.shop-list__item .button-el {
  padding-top: 0;
  padding-bottom: 0;
  min-height: 40px;
  min-width: 200px;
}
.shop-list__item .button-el .label {
  font-size: 16px;
}
.shop-list__item .button-el::after {
  width: 24px;
}
.shop-list__item .hp-link {
  position: absolute;
  left: 15px;
  bottom: 15px;
  display: flex;
  align-items: center;
  font-weight: 700;
  line-height: 1.4;
  color: var(--main-color);
  transition: opacity 0.3s var(--transiton-timing-function);
}
@media screen and (max-width: 640px) {
  .shop-list__item .hp-link {
    position: static;
    margin-top: 10px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .shop-list__item .hp-link:hover {
    opacity: 0.7;
  }
}
.shop-list__item .hp-link::before {
  content: "";
  display: block;
  width: 1em;
  height: 1em;
  margin-right: 0.2em;
  background-image: url("../images/common/icon/icon_link.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* _header.scss */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.header {
  width: 100%;
  position: fixed;
  z-index: 99;
  top: 0;
  left: 0;
  background: linear-gradient(-180deg, rgba(247, 238, 255, 0.8) 0%, rgba(229, 199, 255, 0.8) 100%);
}
@media screen and (max-width: 865px) {
  .header {
    display: none;
  }
}
.header-inner {
  margin: 0 auto;
}
.admin-bar .header {
  top: 32px !important;
}
@media screen and (max-width: 865px) {
  .admin-bar {
    margin-top: 32px !important;
  }
  .admin-bar .drawerButton {
    top: 37px !important;
  }
}
@media screen and (max-width: 782px) {
  .admin-bar main {
    margin-top: 46px !important;
  }
  .admin-bar .drawerButton {
    top: 56px !important;
  }
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* _footer.scss */
/* 目次 */
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.footer {
  position: relative;
  background: var(--main-color);
  color: var(--white);
  margin-top: 100px;
}
@media screen and (max-width: 640px) {
  .footer {
    margin-top: 0;
  }
}
.footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../images/common/footer_deco.png) no-repeat center/cover;
  mix-blend-mode: multiply;
}
.footer-inner {
  padding: 5rem 0 7rem;
  position: relative;
  width: calc(100% - 50px);
  max-width: 950px;
  margin: 0 auto;
  margin: auto;
}
@media screen and (max-width: 865px) {
  .footer-inner {
    padding: 4rem 0;
  }
}
.footer h2 {
  font-size: clamp(1.2rem, 1.1713030747vw, 1.6rem);
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 0.5em;
}
.footer h2.border {
  font-size: clamp(1.35rem, 1.317715959vw, 1.8rem);
  font-size: 18px;
  border: 1.5px solid var(--white);
  border-radius: 4px;
  width: fit-content;
  padding: 0.15em 0.5em;
}
.footer .lg {
  font-size: clamp(1.1rem, 1.6105417277vw, 2.2rem);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.2;
}
.footer .lg span {
  display: inline-block;
  font-size: 18px;
  padding-left: 1em;
}
@media screen and (max-width: 640px) {
  .footer .lg span {
    display: block;
    padding-left: 0;
  }
}
.footer-block-inner {
  display: grid;
  grid-template-columns: repeat(2, auto);
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
}
@media screen and (max-width: 865px) {
  .footer-block-inner {
    display: block;
  }
}
.footer-block + .footer-block {
  padding-top: 2rem;
}
@media screen and (max-width: 865px) {
  .footer-block + .footer-block {
    padding-top: 3.2rem;
  }
}
.footer-block a {
  color: var(--white);
}
.footer-block .md {
  font-size: clamp(1.35rem, 1.317715959vw, 1.8rem);
  font-size: 18px;
  line-height: 1.4;
}
@media screen and (max-width: 640px) {
  .footer-block .md {
    font-size: 14px;
  }
}
.footer-block .sm {
  font-size: clamp(1.05rem, 1.0248901903vw, 1.4rem);
  font-size: 14px;
  display: inline-block;
}
@media screen and (max-width: 640px) {
  .footer-block .sm {
    font-size: 12px;
  }
}
.footer-block .note {
  font-size: 14px;
  display: inline-block;
}
.footer-block .note2 {
  font-size: 10px;
  display: inline-block;
  text-indent: 3em;
}
.footer-block .num {
  display: inline-block;
  margin-top: 0.5em;
  font-size: clamp(2.625rem, 2.5622254758vw, 3.5rem);
  font-size: 35px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1;
}
.footer-block .mail {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 1rem;
}
@media screen and (max-width: 640px) {
  .footer-block .mail {
    margin-bottom: 1rem;
  }
}
.footer-block .mail span {
  font-size: 16px;
}
@media screen and (max-width: 640px) {
  .footer-block .mail span {
    font-size: 12px;
  }
}
.footer-block .mail img {
  width: 28px;
  aspect-ratio: 28/18;
}

.closeLabel {
  width: 200px;
  height: auto;
  aspect-ratio: 200/52;
  position: absolute;
  inset: 0;
  margin: auto;
}

.footer-cta {
  border-bottom: 5px solid var(--white);
}
.footer-cta .footer-inner {
  width: 95%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-end;
  padding: 2rem 0;
  gap: 1.5rem;
}
.footer-cta .footer-inner.--close {
  position: relative;
}
.footer-cta .footer-inner.--close p {
  opacity: 0.8;
}
.footer-cta .label {
  background: #ffee6f;
  border-radius: 999px;
  color: var(--main-color);
  font-size: clamp(2.25rem, 2.196193265vw, 3rem);
  font-weight: bold;
  padding: 1rem 1.5rem;
  line-height: 1;
}
.footer-cta .date {
  font-size: clamp(3rem, 2.9282576867vw, 4rem);
  font-weight: 700;
  line-height: 1;
  display: flex;
  align-items: baseline;
}
.footer-cta .md {
  font-size: 1.25em;
  margin: auto 0 0;
  line-height: 1;
}
.footer-cta .lg {
  font-size: 1.75em;
  line-height: 1;
  padding-left: 4px;
}
.footer-cta .week {
  background: var(--white);
  border-radius: 999px;
  color: var(--main-color);
  font-size: 0.6em;
  line-height: 1;
  width: 1.5em;
  height: 1.5em;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto 0 0;
}
.footer-cta .sm {
  font-size: clamp(1.05rem, 1.0248901903vw, 1.4rem);
  font-weight: 700;
}
.footer-cta .sm span {
  line-height: 1.4;
  display: block;
}
@media screen and (max-width: 640px) {
  .footer-cta .sm span {
    display: inline-block;
  }
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* pages */
/* 目次 */
/* __00: 初期設定 */
/* __10: 共通設定 */
/* __20: pagesファイル読み込み */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 初期設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __10: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.top-contents-inner {
  padding-block: 100px;
}
@media screen and (max-width: 865px) {
  .top-contents-inner {
    padding-block: 50px;
  }
}
.top-contents-block {
  width: calc(100% - 50px);
  max-width: 850px;
  margin: 0 auto;
}
.top-contents-block.--mw-full {
  width: 100%;
  max-width: inherit;
}
.top-contents-block.--mw-full .--mw-base {
  width: calc(100% - 50px);
  max-width: 850px;
  margin: 0 auto;
}
.top-contents-block.--mw-sm {
  max-width: 810px;
}

.p-contents-inner {
  padding-top: 50px;
}
@media screen and (max-width: 865px) {
  .p-contents-inner {
    padding-top: 30px;
  }
}
.p-contents-block {
  width: calc(100% - 50px);
  max-width: 850px;
  margin: 0 auto;
}
.p-contents-block + .p-contents-block {
  padding-top: 100px;
}
@media screen and (max-width: 865px) {
  .p-contents-block + .p-contents-block {
    padding-top: 50px;
  }
}

.head .design04 span, .head .design03 span, .text_line {
  border-bottom: 5px solid #000;
  display: inline-block;
}
.head .design04 span.--pink, .head .design03 span.--pink, .--pink.text_line {
  border-color: var(--pink);
}
.head .design04 span.--green, .head .design03 span.--green, .--green.text_line {
  border-color: var(--green);
}

.head.comingsoon {
  background-color: #b3b3b3 !important;
}
.head.comingsoon .design01 {
  background-color: #b3b3b3;
}
.head .design01 {
  background-color: var(--main-color);
  color: var(--background-color);
  font-size: clamp(1.625rem, 1.6105417277vw, 2.2rem);
  font-weight: bold;
  display: flex;
  gap: 2rem;
  justify-content: center;
  align-items: center;
  padding: 0.3em 0;
  position: relative;
}
@media screen and (max-width: 640px) {
  .head .design01 {
    gap: 1rem;
  }
}
.head .design01 span {
  font-size: 0.8333em;
}
.head .design02 {
  border-top: 2px solid var(--main-color);
  border-bottom: 2px solid var(--main-color);
  color: var(--main-color);
  font-size: clamp(1.625rem, 1.6105417277vw, 2.2rem);
  font-weight: bold;
  display: flex;
  gap: 2rem;
  justify-content: center;
  align-items: center;
  padding: 0.3em 0;
  position: relative;
}
.head .design02 span {
  font-size: 0.8333em;
}
.head .design03 {
  font-size: clamp(1.56rem, 1.9033674963vw, 2.6rem);
  font-weight: 700;
  text-align: center;
  line-height: 1.8;
}
.head .design03 span {
  font-size: 1.08em;
  font-weight: 700;
}
.head .design04 {
  background: var(--white);
  color: var(--main-color);
  font-size: clamp(1.56rem, 1.9033674963vw, 2.6rem);
  font-weight: 700;
  padding: 5px;
  text-align: center;
}
.head .design04 span {
  font-size: 1.08em;
}

.--has-bg-color-01 {
  background-color: var(--accent-color01);
}
.--has-bg-color-02 {
  background-color: var(--accent-color02);
}
.--has-bg-color-03 {
  background-color: var(--accent-color03);
}
.--has-bg .bg {
  padding: 2px 0 40px;
  position: relative;
  background-color: var(--white);
  filter: drop-shadow(0px 5px 10px rgba(120, 59, 153, 0.5));
}
.--has-bg .bg::before, .--has-bg .bg::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  width: calc(100% - 80px);
  height: 41px;
  background-color: var(--white);
}
@media screen and (max-width: 640px) {
  .--has-bg .bg::before, .--has-bg .bg::after {
    width: calc(100% - 40px);
    height: 21px;
  }
}
.--has-bg .bg::before {
  top: -40px;
}
@media screen and (max-width: 640px) {
  .--has-bg .bg::before {
    top: -20px;
  }
}
.--has-bg .bg::after {
  bottom: -40px;
}
@media screen and (max-width: 640px) {
  .--has-bg .bg::after {
    bottom: -20px;
  }
}
.--has-bg .bg_frame {
  border: 6px solid var(--main-color);
  padding: 6px;
}
@media screen and (max-width: 640px) {
  .--has-bg .bg_frame {
    border-width: 3px;
    padding: 3px;
  }
}
.--has-bg .bg_frame-inner {
  border: 2px solid var(--main-color);
  background-color: var(--white);
}
/* __20: pagesファイル読み込み */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* home */
/* 目次 */
/* __00: 共通設定 */
/* __10: mv */
/* __20: バナースライダー */
/* __30: プレミアム付商品券とは */
/* __40: 利用方法 */
/* __50: よくある質問 */
/* __60: アプリのダウンロード */
/* __70: ご利用マニュアル */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* __00: 共通設定 */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.top-contents-inner .text p {
  font-weight: 700;
  text-align: center;
  line-height: 1.8;
  letter-spacing: 0.1em;
}

/* __10: mv */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.top-mv {
  background: linear-gradient(-180deg, rgb(247, 238, 255) 0%, rgb(229, 199, 255) 100%);
  position: relative;
  max-height: 100dvh;
  height: 100vw;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.top-mv .bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  margin: auto;
  pointer-events: none;
  mix-blend-mode: multiply;
}
.top-mv .bg img {
  width: 100%;
}
@media screen and (max-width: 1280px) {
  .top-mv {
    height: auto;
  }
}
@media screen and (max-width: 865px) {
  .top-mv {
    height: auto;
  }
}
@media screen and (max-width: 640px) {
  .top-mv {
    max-height: fit-content;
  }
}

.top-mv-img {
  display: flex;
  justify-content: center;
  position: absolute;
  margin: 0 auto;
  left: 0;
  right: 0;
  top: 0;
  z-index: 2;
  pointer-events: none;
  max-height: 100dvh;
  height: 100vw;
  padding-top: 7.3206442167vw;
  padding-bottom: 6.9546120059vw;
}
.top-mv-img picture {
  display: block;
  max-width: 880px;
  margin-left: 70px;
}
@media screen and (max-width: 1280px) {
  .top-mv-img {
    position: relative;
    height: auto;
  }
}
@media screen and (max-width: 865px) {
  .top-mv-img {
    padding-bottom: 0;
    position: static;
    height: auto;
    width: calc(100% - 50px);
  }
  .top-mv-img picture {
    margin-left: 30px;
    margin-right: -30px;
  }
}
@media screen and (max-width: 640px) {
  .top-mv-img {
    position: relative;
    padding: 5rem 0 0;
    width: calc(100% - 25px);
  }
  .top-mv-img picture {
    margin-left: 0;
    margin-right: 0;
  }
}
.top-mv-img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.top-mv-link {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 20px;
  margin: auto;
  z-index: 2;
}
.top-mv-link .button {
  justify-content: center;
}
.top-mv-link .button-el {
  min-height: 40px;
}
@media screen and (max-width: 1024px) {
  .top-mv-link {
    bottom: 10px;
  }
}
@media screen and (max-width: 865px) {
  .top-mv-link {
    position: relative;
    bottom: inherit;
    margin-bottom: 32px;
  }
}

.top-mv-bg {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  height: 100%;
  display: flex;
  align-items: baseline;
  justify-content: flex-end;
}
.top-mv-bg picture {
  display: block;
  margin: auto 0 0;
}

/* __20: お知らせ */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.top-post__wrapper {
  background-image: url("../images/common/bg.webp");
  background-size: contain;
  background-position: center;
  padding-top: 75px;
}
@media screen and (max-width: 865px) {
  .top-post__wrapper {
    padding-top: 35px;
  }
}
.top-post__wrapper {
  padding-bottom: 75px;
}
@media screen and (max-width: 865px) {
  .top-post__wrapper {
    padding-bottom: 35px;
  }
}

.top-post {
  width: calc(100% - 50px);
  max-width: 800px;
  margin: 0 auto;
}
@media screen and (max-width: 865px) {
  .top-post {
    width: calc(100% - 110px);
  }
}
@media screen and (max-width: 640px) {
  .top-post {
    width: calc(100% - 50px);
  }
}
.top-post .post {
  width: calc(100% - 50px);
  max-width: 560px;
  margin: 0 auto;
}
@media screen and (max-width: 865px) {
  .top-post .post {
    width: 100%;
  }
}
.top-post .post-list {
  margin-top: 3rem;
  display: grid;
  gap: 3rem;
}
@media screen and (max-width: 640px) {
  .top-post .post-list {
    margin-top: 2rem;
    gap: 2rem;
  }
}
.top-post .post-list__item a {
  display: flex;
  padding: 0;
  gap: 1rem;
  background: unset;
  border: none;
}
.top-post .post-list__item a::after {
  content: none;
}
@media screen and (max-width: 1024px) {
  .top-post .post-list__item a .title {
    width: 100%;
  }
}
.top-post .button {
  margin-top: 3rem;
}
@media screen and (max-width: 640px) {
  .top-post .button {
    margin-top: 2rem;
  }
}
.top-post .button-el {
  min-width: unset;
}
.top-post .button-el .label {
  padding: 0 1rem;
}
@media screen and (max-width: 640px) {
  .top-post .button-el .label {
    font-size: 13px;
  }
}
.top-post .button-el::after {
  width: 28px;
}
@media screen and (max-width: 640px) {
  .top-post .button-el::after {
    width: 22px;
  }
}

#home {
  /* __30:  */
  /*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
}
#home .about .top-contents-inner {
  padding-top: 0;
  padding-bottom: 75px;
}
@media screen and (max-width: 865px) {
  #home .about .top-contents-inner {
    padding-bottom: 40px;
  }
}
#home .about .top-contents-block {
  position: relative;
  z-index: 1;
  width: calc(100% - 50px);
  max-width: 800px;
  margin: 0 auto;
}
@media screen and (max-width: 865px) {
  #home .about .top-contents-block {
    width: calc(100% - 110px);
  }
}
@media screen and (max-width: 640px) {
  #home .about .top-contents-block {
    width: calc(100% - 50px);
  }
}
#home .about .text {
  margin: 30px auto;
}
#home .about .text p {
  font-weight: 500;
}
@media screen and (max-width: 640px) {
  #home .about .text {
    margin: 15px auto;
  }
  #home .about .text p {
    text-align: left;
  }
}
#home .about .movie {
  width: calc(100% - 50px);
  max-width: 560px;
  margin: 0 auto;
}
#home .about .movie iframe {
  width: 100%;
  height: 310px;
}
#home .about .movie .notes {
  color: var(--red);
  font-size: clamp(0.84rem, 1.0248901903vw, 1.4rem);
  font-size: 14px;
  text-align: center;
}
@media screen and (max-width: 865px) {
  #home .about .movie {
    width: calc(100% - 25px);
  }
  #home .about .movie iframe {
    height: 50%;
  }
  #home .about .movie .notes {
    font-size: 12px;
  }
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-about */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.content-page .about .p-contents-block .movie {
  width: calc(100% - 50px);
  max-width: 560px;
  margin: 0 auto;
}
.content-page .about .p-contents-block .movie iframe {
  width: 100%;
  height: 310px;
}
.content-page .about .p-contents-block .movie .notes {
  color: var(--red);
  font-size: clamp(0.84rem, 1.0248901903vw, 1.4rem);
  font-size: 14px;
  text-align: center;
}
@media screen and (max-width: 865px) {
  .content-page .about .p-contents-block .movie {
    width: calc(100% - 25px);
  }
  .content-page .about .p-contents-block .movie iframe {
    height: 50%;
  }
  .content-page .about .p-contents-block .movie .notes {
    font-size: 12px;
  }
}
.content-page .about .p-contents-block.--block-01 .text {
  margin: 2rem 0;
}
.content-page .about .p-contents-block.--block-01 .text p {
  text-align: center;
}
@media screen and (max-width: 640px) {
  .content-page .about .p-contents-block.--block-01 .text p {
    text-align: left;
  }
}
.content-page .about .p-contents-block.--block-01 .image {
  width: calc(100% - 50px);
  max-width: 595px;
  margin: 0 auto;
  margin-top: 5rem;
}
.content-page .about .p-contents-block.--block-01 .image picture {
  display: block;
  margin-left: -2rem;
}
@media screen and (max-width: 865px) {
  .content-page .about .p-contents-block.--block-01 .image {
    margin-top: 2rem;
    width: 100%;
  }
  .content-page .about .p-contents-block.--block-01 .image picture {
    margin-left: -1rem;
  }
}
.content-page .about .p-contents-block.--block-01 .image-text {
  width: calc(100% - 50px);
  max-width: 555px;
  margin: 0 auto;
  background-color: var(--yellow);
  margin: 2rem auto 5rem;
  padding: 1rem;
}
.content-page .about .p-contents-block.--block-01 .image-text p {
  color: var(--main-color);
  font-weight: bold;
  line-height: 1.4;
  text-align: center;
}
.content-page .about .p-contents-block.--block-01 .image-text p.title {
  font-size: clamp(1.5rem, 1.8301610542vw, 2.5rem);
  font-size: 25px;
}
@media screen and (max-width: 865px) {
  .content-page .about .p-contents-block.--block-01 .image-text {
    margin: 1rem auto 4rem;
    width: calc(100% - 25px);
  }
  .content-page .about .p-contents-block.--block-01 .image-text p {
    font-size: 10px;
  }
  .content-page .about .p-contents-block.--block-01 .image-text p.title {
    font-size: 14px;
  }
}
.content-page .about .p-contents-block.--block-01 .period {
  width: calc(100% - 50px);
  max-width: 595px;
  margin: 0 auto;
  background-color: var(--main-color);
  border-radius: 30px;
  padding: 2rem 2rem 1.5rem;
}
@media screen and (max-width: 865px) {
  .content-page .about .p-contents-block.--block-01 .period {
    border-radius: 10px;
    padding: 10px;
    width: calc(100% - 25px);
  }
}
.content-page .about .p-contents-block.--block-01 .flex {
  width: calc(100% - 50px);
  max-width: 350px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  margin-top: 5rem;
}
.content-page .about .p-contents-block.--block-01 .flex .num {
  font-size: 135%;
}
@media screen and (max-width: 865px) {
  .content-page .about .p-contents-block.--block-01 .flex {
    margin-top: 3rem;
  }
}
.content-page .about .p-contents-block.--block-02 .text {
  margin: 3rem 0;
  text-align: center;
}
.content-page .about .p-contents-block.--block-02 .text span {
  background-color: var(--accent-color01);
  font-size: clamp(1.2rem, 1.4641288433vw, 2rem);
  font-size: 20px;
  font-weight: 600;
  padding: 0.5rem 2rem;
}
@media screen and (max-width: 865px) {
  .content-page .about .p-contents-block.--block-02 .text {
    margin: 2rem 0;
  }
  .content-page .about .p-contents-block.--block-02 .text span {
    font-size: 16px;
  }
}
.content-page .about .p-contents-block.--block-02 dl {
  width: calc(100% - 50px);
  max-width: 500px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 105px auto;
  gap: 1rem;
  align-items: flex-start;
  font-weight: 600;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 865px) {
  .content-page .about .p-contents-block.--block-02 dl {
    grid-template-columns: 55px auto;
    margin-bottom: 1rem;
    width: 100%;
  }
}
.content-page .about .p-contents-block.--block-02 dl dt {
  color: var(--white);
  font-size: clamp(1.2rem, 1.4641288433vw, 2rem);
  font-size: 20px;
  text-align: center;
}
.content-page .about .p-contents-block.--block-02 dl dt.bg-color-01 {
  background-color: var(--accent-color02);
}
.content-page .about .p-contents-block.--block-02 dl dt.bg-color-02 {
  background-color: var(--accent-color03);
}
@media screen and (max-width: 865px) {
  .content-page .about .p-contents-block.--block-02 dl dt {
    font-size: 14px;
  }
}
.content-page .about .p-contents-block.--block-02 dl dd {
  font-size: clamp(1.08rem, 1.317715959vw, 1.8rem);
  font-size: 18px;
}
.content-page .about .p-contents-block.--block-02 dl dd span {
  display: block;
  font-size: 0.8em;
  font-weight: inherit;
}
@media screen and (max-width: 865px) {
  .content-page .about .p-contents-block.--block-02 dl dd {
    font-size: 14px;
  }
}
.content-page .about .p-contents-block.--block-02 .note {
  font-size: clamp(0.72rem, 0.878477306vw, 1.2rem);
  font-size: 12px;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .content-page .about .p-contents-block.--block-02 .note {
    font-size: 10px;
    text-align: left;
  }
}
.content-page .about .p-contents-block.--block-03 .image {
  width: calc(100% - 50px);
  max-width: 650px;
  margin: 0 auto;
  margin: 3rem auto 5rem;
}
@media screen and (max-width: 640px) {
  .content-page .about .p-contents-block.--block-03 .image {
    margin: 1rem auto 3rem;
    width: 100%;
  }
}
.content-page .about .p-contents-block.--block-03 .block {
  width: calc(100% - 50px);
  max-width: 650px;
  margin: 0 auto;
  border: 3px solid var(--main-color);
  border-radius: 15px;
  padding: 3rem 7rem;
}
.content-page .about .p-contents-block.--block-03 .block picture {
  display: block;
  margin: 0 auto 2rem;
  width: 90%;
}
@media screen and (max-width: 640px) {
  .content-page .about .p-contents-block.--block-03 .block {
    border-width: 2px;
    border-radius: 8px;
    padding: 15px 10px 10px;
    width: 100%;
  }
}
.content-page .about .p-contents-block.--block-03 .note {
  font-size: clamp(0.72rem, 0.878477306vw, 1.2rem);
  font-size: 12px;
  padding-left: 1em;
  text-indent: -1em;
}
@media screen and (max-width: 640px) {
  .content-page .about .p-contents-block.--block-03 .note {
    font-size: 10px;
  }
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-manual */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.content-page .manual {
  overflow: hidden;
}
.content-page .manual .p-contents-block {
  position: relative;
}
.content-page .manual .p-contents-block:not(:has(.text)) {
  width: calc(100% - 50px);
  max-width: 560px;
  margin: 0 auto;
}
.content-page .manual .button {
  max-width: 560px;
  margin: 4rem auto 0;
}
@media screen and (max-width: 640px) {
  .content-page .manual .button {
    margin-top: 2rem;
  }
}
.content-page .manual .button .btn-pdf {
  background: var(--main-color);
  align-items: center;
  border: 2px solid var(--main-color);
  border-radius: calc(infinity * 1px);
  display: flex;
  height: 72px;
  justify-content: space-between;
  position: relative;
  transition: all 0.2s ease;
  padding: 0 3em;
  width: 100%;
}
.content-page .manual .button .btn-pdf.comingsoon {
  background-color: #ababab;
  border-color: #ababab;
}
.content-page .manual .button .btn-pdf.comingsoon .label {
  color: var(--white);
}
.content-page .manual .button .btn-pdf.comingsoon .icon {
  background: url(../images/common/icon/icon_cs_pdf.svg) no-repeat center/contain;
}
@media (hover: hover) and (pointer: fine) {
  .content-page .manual .button .btn-pdf.comingsoon:hover {
    cursor: default;
    opacity: 1;
  }
}
.content-page .manual .button .btn-pdf .label {
  color: #fff;
  font-size: var(--font-size-h3);
  transform: translateY(-2px);
  transition: all 0.2s ease;
  line-height: 1.2;
}
.content-page .manual .button .btn-pdf .icon {
  content: "";
  position: absolute;
  right: 3em;
  bottom: 0.5em;
  aspect-ratio: 60/75;
  width: 60px;
  height: auto;
  background: url(../images/common/icon/icon_pdf.svg) no-repeat center/contain;
}
@media (hover: hover) and (pointer: fine) {
  .content-page .manual .button .btn-pdf:hover {
    opacity: 0.7;
  }
}
@media screen and (max-width: 640px) {
  .content-page .manual .button .btn-pdf {
    height: 55px;
    padding: 0 2em;
  }
  .content-page .manual .button .btn-pdf .label {
    font-size: var(--font-size-h5);
  }
  .content-page .manual .button .btn-pdf .icon {
    right: 1.5em;
    width: 40px;
  }
}
.content-page .manual .text p {
  font-size: clamp(1.7rem, 1.6243rem + 0.2018vw, 1.9rem);
  font-weight: 700;
  text-align: center;
  line-height: 1.8;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 640px) {
  .content-page .manual .text p {
    font-size: 14px;
  }
}
.content-page .manual .head {
  border-left: 2px solid var(--main-color);
  border-right: 2px solid var(--main-color);
  margin-top: 48px;
}
@media screen and (max-width: 865px) {
  .content-page .manual .head {
    margin-top: 32px;
  }
}
.content-page .manual .movie {
  width: calc(100% - 50px);
  max-width: 560px;
  margin: 0 auto;
  height: 100%;
  aspect-ratio: 16/9;
  margin-top: 48px;
}
@media screen and (max-width: 865px) {
  .content-page .manual .movie {
    margin-top: 22px;
  }
}
@media screen and (max-width: 865px) {
  .content-page .manual .movie {
    width: calc(100% - 25px);
  }
}
.content-page .manual .movie iframe {
  width: 100%;
  height: 100%;
}
.content-page .manual .movie img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.content-page .manual .notes {
  color: var(--red);
  font-size: clamp(0.84rem, 1.0248901903vw, 1.4rem);
  font-size: 14px;
  margin-top: 10px;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .content-page .manual .notes {
    font-size: 12px;
  }
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-download */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
body.download {
  background: #fff;
}

.index__download .content-title .head {
  width: calc(100% - 50px);
  max-width: 700px;
  margin: 0 auto;
  display: grid;
  gap: 15px;
  text-align: center;
}
.index__download .content-title .head .outline__head {
  position: relative;
  z-index: 9;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}
.index__download .content-title .head .outline__head::after, .index__download .content-title .head .outline__head::before {
  content: "";
  flex: 1;
  height: 2px;
  background: var(--main-color);
}
@media screen and (max-width: 640px) {
  .index__download .content-title .head h1 span {
    display: block;
  }
}
.index__download .content-title .head .lead {
  font-size: clamp(1.5rem, 1.756954612vw, 2.4rem);
  font-weight: bold;
}

.content-page {
  position: relative;
}
.content-page .download {
  --color: var(--main-color);
  overflow: hidden;
}
.content-page .download .p-contents-inner {
  padding-top: 3rem;
}
.content-page .download .p-contents-block {
  position: relative;
  width: calc(100% - 50px);
  max-width: 624px;
  margin: 0 auto;
}
.content-page .download .download_bg {
  width: calc(100% - 50px);
  max-width: 900px;
  margin: 0 auto;
  background-image: url("../images/common/bg.webp");
  background-size: contain;
  background-position: center;
  margin: 60px auto;
  padding: 80px 30px 40px;
}
@media screen and (max-width: 640px) {
  .content-page .download .download_bg {
    width: 100%;
    margin: 30px auto 50px;
    padding: 30px 0 20px;
  }
}
.content-page .download .download_bg .p-contents-block {
  padding: 0;
}
@media screen and (max-width: 640px) {
  .content-page .download .download_bg .p-contents-block {
    padding: 30px 0;
    width: 90%;
    max-width: 400px;
  }
}
.content-page .download .download_bg .head {
  position: relative;
}
.content-page .download .download_bg h2 {
  background-image: url(../images/page/download/title.svg);
  background-repeat: no-repeat;
  background-position: center;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 160px;
  aspect-ratio: 254/122;
  margin: auto;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  transform: translateY(-50%);
  font-size: clamp(1.575rem, 1.5373352855vw, 2.1rem);
}
@media screen and (max-width: 640px) {
  .content-page .download .download_bg h2 {
    max-width: 150px;
  }
}
.content-page .download .download_bg .download_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 5rem 4%;
}
@media screen and (max-width: 640px) {
  .content-page .download .download_bg .download_list {
    margin: auto;
    gap: 0;
  }
}
.content-page .download .download_bg .download_list > * {
  width: 30%;
  margin: 0;
}
@media screen and (max-width: 640px) {
  .content-page .download .download_bg .download_list > * {
    width: 90%;
  }
}
.content-page .download .download_bg .outline {
  background: #fff;
  border: 4px solid var(--color);
  border-width: 4px 0;
  padding: 15px 0;
}
@media screen and (max-width: 640px) {
  .content-page .download .download_bg .outline {
    background: unset;
    border-width: 3px 0;
    padding: 10px 0;
  }
}
@media screen and (max-width: 640px) {
  .content-page .download .download_bg .outline__body {
    border: 4px solid var(--color);
    border-width: 0 3px;
    padding: 0 10px;
  }
}
.content-page .download .download_bg .detail {
  text-align: center;
  padding: 50px 15px 15px;
  display: grid;
  gap: 1rem;
}
@media screen and (max-width: 640px) {
  .content-page .download .download_bg .detail {
    background: #fff;
    padding: 40px 15px 20px;
    gap: 1.5rem;
  }
}
.content-page .download .download_bg p {
  font-size: clamp(1.125rem, 1.0980966325vw, 1.5rem);
  text-align: center;
  min-height: 5.4em;
}
@media screen and (max-width: 640px) {
  .content-page .download .download_bg p {
    font-size: clamp(1.2rem, 1.1713030747vw, 1.6rem);
    min-height: unset;
  }
}
.content-page .download .download_bg figure {
  height: 100px;
  width: 100%;
  aspect-ratio: 1/1.3;
  margin: auto;
}
@media screen and (max-width: 640px) {
  .content-page .download .download_bg figure {
    max-height: 200px;
    height: 100%;
  }
}
.content-page .download .download_bg figure img {
  width: 100%;
  height: 100%;
}
.content-page .download .download_bg .button {
  margin: 0;
}
.content-page .download .download_bg .button-el {
  min-width: unset;
  max-width: 300px;
  min-height: unset;
  width: 100%;
  padding: 1rem;
  margin-top: 2rem;
}
@media screen and (max-width: 640px) {
  .content-page .download .download_bg .button-el {
    margin-top: 1rem;
  }
}
.content-page .download .download_bg .button-el .label {
  font-size: clamp(1.2rem, 1.1713030747vw, 1.6rem);
  font-weight: bold;
  letter-spacing: 0.1em;
}
.content-page .download .text p {
  font-size: clamp(1.5rem, 1.6243rem + 0.2018vw, 1.9rem);
  font-weight: 700;
  text-align: center;
  line-height: 1.8;
  letter-spacing: 0.1em;
}
.content-page .download .text p span {
  display: inline-block;
}
.content-page .--password p {
  font-size: 18px;
  margin-bottom: 30px;
}
@media screen and (max-width: 640px) {
  .content-page .--password p {
    font-size: 15px;
    margin-bottom: 20px;
  }
}
.content-page .--password p span {
  display: inline-block;
}
.content-page .--password .post_password {
  display: flex;
  justify-content: flex-start;
  gap: 1rem;
  align-items: center;
}
@media screen and (max-width: 640px) {
  .content-page .--password .post_password {
    flex-direction: column;
    align-items: center;
  }
}
.content-page .--password .post_password_input {
  font-size: 16px;
  padding: 5px;
  border: 2px solid #000;
  border-radius: 4px;
}
.content-page .--password .post_password_submit {
  width: auto;
  border-radius: 4px;
  padding: 7px 20px;
  line-height: 1;
  text-align: center;
  border: 2px solid var(--color);
  color: var(--color);
  font-weight: bold;
  transition: 0.7s;
  cursor: pointer;
  white-space: nowrap;
}
.content-page .--password .post_password_submit:hover {
  background: var(--color);
  border-color: var(--color);
  color: #fff;
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-faq */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.content-page .faq {
  position: relative;
}
.content-page .faq .page-nav {
  width: calc(100% - 50px);
  max-width: 800px;
  margin: 0 auto;
  padding-bottom: 50px;
}
@media screen and (max-width: 865px) {
  .content-page .faq .page-nav {
    padding-bottom: 25px;
  }
}
.content-page .faq .page-nav-menu {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  list-style: none;
  padding: 0;
}
@media screen and (max-width: 865px) {
  .content-page .faq .page-nav-menu {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 640px) {
  .content-page .faq .page-nav-menu {
    grid-template-columns: 1fr;
    gap: 0.8rem;
  }
}
.content-page .faq .page-nav-menu__item a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 100px;
  padding: 10px 1rem;
  font-weight: bold;
  background-color: var(--white);
  border: 2px solid var(--main-color);
  border-radius: 10px;
  box-sizing: border-box;
  color: var(--main-color);
  text-decoration: none;
  transition: all 0.3s var(--transiton-timing-function);
  position: relative;
  line-height: 1.6;
  gap: 5px;
}
@media screen and (max-width: 640px) {
  .content-page .faq .page-nav-menu__item a {
    border-radius: 6px;
    min-height: auto;
    padding: 10px 30px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .content-page .faq .page-nav-menu__item a:hover {
    background-color: var(--main-color);
    color: var(--white);
  }
}
.content-page .faq .page-nav-menu__item a::after {
  content: "";
  display: block;
  margin: auto 0 0;
  width: 28px;
  height: 28px;
  background-image: url(../images/common/arrow/arrow_right.svg);
  background-repeat: no-repeat;
  transition: all 0.3s var(--transiton-timing-function);
  transform: rotate(90deg);
}
@media screen and (max-width: 640px) {
  .content-page .faq .page-nav-menu__item a::after {
    width: 20px;
    height: 20px;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 1em;
    margin: auto 0;
  }
}
.content-page .faq .page-nav-menu__item a .label {
  display: block;
  font-size: clamp(1.5rem, 1.0248901903vw, 1.4rem);
  text-align: center;
}
.content-page .faq .page-nav-menu__item a .label span {
  display: inline-block;
  line-height: 1;
}
.content-page .faq .page-nav-menu__item a .label .small {
  font-size: 0.85em;
}
.content-page .faq .p-contents-block {
  width: calc(100% - 50px);
  max-width: 800px;
  margin: 0 auto;
  padding-block: 2px;
}
@media screen and (max-width: 865px) {
  .content-page .faq .p-contents-block {
    padding-block: 50px;
  }
}
.content-page .faq .p-contents-block {
  padding-bottom: 40px;
}
@media screen and (max-width: 865px) {
  .content-page .faq .p-contents-block {
    padding-bottom: 20px;
  }
}
.content-page .faq .p-contents-block {
  position: relative;
  background-color: var(--white);
  border: 2px solid var(--main-color);
}
.content-page .faq .p-contents-block::after {
  content: "";
  position: absolute;
  right: -20px;
  bottom: -20px;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, rgb(214, 135, 226) 0%, rgb(143, 58, 201) 100%);
  z-index: -1;
}
.content-page .faq .p-contents-block + .p-contents-block {
  margin-top: 100px;
}
@media screen and (max-width: 865px) {
  .content-page .faq .p-contents-block + .p-contents-block {
    margin-top: 40px;
  }
}
@media screen and (max-width: 640px) {
  .content-page .faq .p-contents-block {
    padding-top: 0;
  }
  .content-page .faq .p-contents-block::after {
    right: -10px;
    bottom: -10px;
  }
}
.content-page .faq .head {
  width: calc(100% - 50px);
  max-width: 730px;
  margin: 0 auto;
  width: calc(100% - 40px);
  padding-top: 20px;
}
@media screen and (max-width: 640px) {
  .content-page .faq .head {
    padding-top: 0;
  }
}
.content-page .faq .head h2 {
  background-color: inherit;
  font-size: 24px;
  text-align: center;
  color: var(--main-color);
  padding: 25px 0;
}
@media screen and (max-width: 640px) {
  .content-page .faq .head h2 {
    font-size: 21px;
  }
}
.content-page .faq .head h2 span {
  display: inline-block;
}
.content-page .faq .head h3 {
  font-size: 24px;
  color: var(--main-color);
  padding-block: 24px;
}
@media screen and (max-width: 865px) {
  .content-page .faq .head h3 {
    padding-block: 16px;
  }
}
.content-page .faq .head h3 {
  text-align: center;
}
@media screen and (max-width: 640px) {
  .content-page .faq .head h3 {
    font-size: 18px;
  }
}
.content-page .faq .head h3 span {
  font-size: 0.8em;
}
.content-page .faq-box {
  width: calc(100% - 50px);
  max-width: 730px;
  margin: 0 auto;
  width: calc(100% - 40px);
}
.content-page .faq .faq-box .acdn-toggle {
  border-top: 5px dotted var(--main-color);
}
.content-page .faq .faq-box .acdn-toggle:last-child {
  border-bottom: 5px dotted var(--main-color);
}
@media screen and (max-width: 640px) {
  .content-page .faq .faq-box .acdn-toggle {
    border-top-width: 3px;
  }
  .content-page .faq .faq-box .acdn-toggle:last-child {
    border-bottom-width: 3px;
  }
}
.content-page .faq .faq-box .acdn-btn {
  display: grid;
  grid-template-columns: 32px auto;
  gap: 10px;
}
.content-page .faq .faq-box .acdn-contents {
  align-items: center;
  display: grid;
  grid-template-columns: 20px auto;
  gap: 10px;
  padding: 0 5.2rem 2.2rem;
}
.content-page .faq .faq-box .faq-btn .unit {
  content: "";
  aspect-ratio: 1/1;
  width: 32px;
  background: url(../images/page/shopinfo/icon_q.svg) no-repeat center/cover;
}
.content-page .faq .faq-box .faq-box-el__contents .unit {
  content: "";
  aspect-ratio: 1/1;
  width: 20px;
  background: url(../images/page/shopinfo/icon_a.svg) no-repeat center/cover;
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-flow */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.contents-flow + .contents-flow {
  padding-top: 50px;
}
@media screen and (max-width: 865px) {
  .contents-flow + .contents-flow {
    padding-top: 20px;
  }
}
.contents-flow .p-contents-block {
  width: calc(100% - 50px);
  max-width: 850px;
  margin: 0 auto;
}
@media screen and (max-width: 865px) {
  .contents-flow .p-contents-block + .p-contents-block {
    padding-top: 80px;
  }
}
@media screen and (max-width: 640px) {
  .contents-flow .p-contents-block + .p-contents-block {
    padding-top: 60px;
  }
}
.contents-flow .head {
  background-color: var(--main-color);
  padding: 15px 0;
  position: relative;
}
.contents-flow .head::after {
  content: "";
  position: absolute;
  bottom: -19px;
  left: 0;
  right: 0;
  margin: auto;
  width: 30px;
  height: 20px;
  background-color: var(--main-color);
  clip-path: polygon(50% 20px, 0% 0%, 30px 0%);
}
@media screen and (max-width: 640px) {
  .contents-flow .head {
    padding: 10px 0;
  }
  .contents-flow .head::after {
    bottom: -9px;
    width: 20px;
    height: 10px;
    clip-path: polygon(50% 10px, 0% 0%, 20px 0%);
  }
}
.contents-flow .head h3 {
  text-align: center;
}
.contents-flow .head h3 img {
  width: auto;
  height: 65px;
}
@media screen and (max-width: 640px) {
  .contents-flow .head h3 img {
    width: 85%;
    height: auto;
  }
}
.contents-flow .head.line2 h3 img {
  height: 130px;
}
@media screen and (max-width: 640px) {
  .contents-flow .head.line2 h3 img {
    width: 85%;
    height: auto;
  }
}
.contents-flow .--lead .step {
  width: calc(100% - 50px);
  max-width: 885px;
  margin: 0 auto;
}
.contents-flow .--lead .text {
  width: calc(100% - 50px);
  max-width: 650px;
  margin: 0 auto;
  position: relative;
}
.contents-flow .--lead .text > picture {
  position: absolute;
  width: 128px;
  left: -8rem;
  top: -2rem;
}
.contents-flow .--lead .text > p {
  width: calc(100% - 200px);
  margin: 8rem auto 3rem;
}
.contents-flow .--lead .text .box {
  border: 1px solid var(--font-color);
  padding: 1.5rem 8rem;
}
@media screen and (max-width: 640px) {
  .contents-flow .--lead .text > picture {
    display: none;
  }
  .contents-flow .--lead .text > p {
    margin: 5rem auto 2rem;
    width: 100%;
  }
  .contents-flow .--lead .text .box {
    border: inherit;
    padding: 0;
  }
}
.contents-flow.--flow .p-contents-block {
  padding-top: 50px;
}
@media screen and (max-width: 865px) {
  .contents-flow.--flow .p-contents-block {
    padding-top: 30px;
  }
}
.contents-flow.--flow .ttl {
  border-top: 1px solid var(--main-color);
  border-bottom: 1px solid var(--main-color);
  margin-bottom: 30px;
}
.contents-flow.--flow .ttl h3 {
  color: var(--main-color);
  font-size: clamp(1.32rem, 1.6105417277vw, 2.2rem);
  font-size: 22px;
  padding: 10px 0;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .ttl {
    margin-bottom: 20px;
  }
  .contents-flow.--flow .ttl h3 {
    font-size: 16px;
    padding: 5px 0;
  }
}
.contents-flow.--flow .--block01 .text {
  font-weight: bold;
  text-align: center;
}
.contents-flow.--flow .--block01 .text .red {
  color: var(--red);
}
.contents-flow.--flow .--block01 .bnr {
  width: calc(100% - 50px);
  max-width: 300px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  column-gap: 2rem;
}
.contents-flow.--flow .--block01 .bnr a {
  color: var(--font-color);
  display: block;
  margin: 30px auto;
  text-align: center;
  text-decoration: none;
  transition: opacity 0.3s var(--transiton-timing-function);
}
@media (hover: hover) and (pointer: fine) {
  .contents-flow.--flow .--block01 .bnr a:hover {
    opacity: 0.7;
  }
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block01 .bnr a {
    margin: 15px auto 30px;
  }
}
.contents-flow.--flow .--block01 .box {
  background-color: #eee1f7;
  padding: 20px 50px;
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block01 .box {
    padding: 10px 20px;
  }
}
.contents-flow.--flow .--block01 .box .text1 {
  font-size: clamp(1.08rem, 1.317715959vw, 1.8rem);
  font-size: 18px;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block01 .box .text1 {
    font-size: 15px;
  }
}
.contents-flow.--flow .--block01 .box .text2 {
  border-bottom: 1px solid var(--font-color);
  font-weight: bold;
  margin-bottom: 15px;
  padding-bottom: 10px;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block01 .box .text2 {
    font-size: 12px;
  }
}
.contents-flow.--flow .--block01 .box ul {
  margin-left: 2rem;
}
.contents-flow.--flow .--block01 .box ul li {
  font-weight: bold;
}
.contents-flow.--flow .--block01 .box ul li span {
  font-weight: 500;
  font-size: 0.9em;
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block01 .box ul li {
    font-size: 12px;
  }
}
.contents-flow.--flow .--block01 .box .border {
  border: 1px solid var(--font-color);
  font-size: 1.4rem;
  margin-top: 10px;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block01 .box .border {
    font-size: 12px;
    line-height: 1.5;
    padding: 5px;
  }
}
.contents-flow.--flow .--block01 .box .notes {
  font-size: 1.2rem;
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block01 .box .notes {
    font-size: 10px;
  }
}
.contents-flow.--flow .--block02 .list ul {
  font-weight: bold;
  width: calc(100% - 100px);
  margin: auto;
}
.contents-flow.--flow .--block02 .list ul .red {
  color: var(--red);
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block02 .list ul {
    padding-left: 2rem;
    width: 100%;
  }
  .contents-flow.--flow .--block02 .list ul li {
    font-size: 12px;
  }
}
.contents-flow.--flow .--block03 {
  width: calc(100% - 50px);
  max-width: 540px;
  margin: 0 auto;
}
.contents-flow.--flow .--block03 ul {
  margin-left: 2rem;
}
.contents-flow.--flow .--block03 ul li {
  font-weight: bold;
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block03 ul li {
    font-size: 12px;
  }
}
.contents-flow.--flow .--block03 .notes {
  color: var(--red);
  font-weight: bold;
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block03 .notes {
    font-size: 12px;
  }
}
.contents-flow.--flow .--block04 p {
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block04 p {
    font-size: 12px;
  }
}
.contents-flow.--flow .--block05 {
  width: calc(100% - 50px);
  max-width: 500px;
  margin: 0 auto;
}
.contents-flow.--flow .--block05 ul {
  font-weight: bold;
}
.contents-flow.--flow .--block05 ul li {
  line-height: 2;
}
.contents-flow.--flow .--block05 ul p {
  font-size: 0.8em;
  font-weight: 500;
  text-indent: -1em;
  padding-left: 1em;
}
.contents-flow.--flow .--block05 ul.red {
  list-style: disc;
  color: var(--red);
  margin-top: 2rem;
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block05 ul {
    padding-left: 2rem;
  }
  .contents-flow.--flow .--block05 ul li {
    font-size: 12px;
    line-height: 1.5;
  }
}
.contents-flow.--flow .--block06 {
  width: calc(100% - 50px);
  max-width: 600px;
  margin: 0 auto;
}
.contents-flow.--flow .--block06 ul {
  font-weight: bold;
}
.contents-flow.--flow .--block06 ul li {
  line-height: 2;
}
.contents-flow.--flow .--block06 ul li.red {
  color: var(--red);
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block06 ul {
    padding-left: 2rem;
  }
  .contents-flow.--flow .--block06 ul li {
    font-size: 12px;
    line-height: 1.5;
  }
}
.contents-flow.--flow .--block06 .red-box {
  border: 1px solid var(--red);
  margin-top: 1rem;
  padding: 1rem 3rem;
}
.contents-flow.--flow .--block06 .red-box p {
  color: var(--red);
  font-weight: bold;
}
@media screen and (max-width: 640px) {
  .contents-flow.--flow .--block06 .red-box {
    padding: 0.5rem 1rem;
  }
  .contents-flow.--flow .--block06 .red-box p {
    font-size: 12px;
  }
}
.contents-flow.--notes .head::after {
  content: none;
}
.contents-flow.--notes .head h3 {
  color: var(--white);
  font-size: clamp(1.44rem, 1.756954612vw, 2.4rem);
  font-size: 24px;
}
.contents-flow.--notes .p-contents-block {
  padding-top: 50px;
}
@media screen and (max-width: 865px) {
  .contents-flow.--notes .p-contents-block {
    padding-top: 20px;
  }
}
.contents-flow.--notes ul {
  width: calc(100% - 50px);
  max-width: 700px;
  margin: 0 auto;
}
.contents-flow.--notes ul li {
  font-size: 1.4rem;
}
@media screen and (max-width: 640px) {
  .contents-flow.--notes ul li {
    font-size: 12px;
  }
}
.contents-flow.--notes .nouse-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4rem;
}
.contents-flow.--notes .nouse p {
  color: var(--main-color);
  font-size: clamp(1.2rem, 1.4641288433vw, 2rem);
  font-size: 20px;
  font-weight: bold;
  margin: 5rem auto 2rem;
  text-align: center;
}
.contents-flow.--notes .nouse ol {
  list-style: none;
  margin: 5rem auto;
}
.contents-flow.--notes .nouse ol li {
  display: grid;
  grid-template-columns: 28px auto;
  font-size: 1.4rem;
}
@media screen and (max-width: 865px) {
  .contents-flow.--notes .nouse-list {
    gap: 0;
  }
}
@media screen and (max-width: 640px) {
  .contents-flow.--notes .nouse-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }
  .contents-flow.--notes .nouse-list picture {
    display: block;
    width: 50%;
  }
  .contents-flow.--notes .nouse p {
    font-size: 16px;
    line-height: 1.5;
    margin: 3rem auto 1rem;
  }
  .contents-flow.--notes .nouse ol {
    margin: 3rem auto;
  }
  .contents-flow.--notes .nouse ol li {
    font-size: 12px;
  }
}
.contents-flow.--notes .privacy p {
  font-size: 1.4rem;
}
.contents-flow.--notes .privacy p.border {
  border: 1px solid var(--main-color);
  color: var(--main-color);
  font-size: clamp(1.2rem, 1.4641288433vw, 2rem);
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 10px;
  padding: 5px;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .contents-flow.--notes .privacy p {
    font-size: 12px;
  }
  .contents-flow.--notes .privacy p.border {
    font-size: 16px;
  }
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-shopinfo */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.contents-shopinfo {
  --color: var(--main-color);
}
.contents-shopinfo .p-contents-block {
  width: calc(100% - 50px);
  max-width: 1050px;
  margin: 0 auto;
}
.contents-shopinfo .p-contents-block + .p-contents-block {
  padding-top: 80px;
}
@media screen and (max-width: 865px) {
  .contents-shopinfo .p-contents-block + .p-contents-block {
    padding-top: 32px;
  }
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .p-contents-block + .p-contents-block {
    padding-top: 60px;
  }
}
.contents-shopinfo .bnr {
  margin-top: 60px;
}
@media screen and (max-width: 865px) {
  .contents-shopinfo .bnr {
    margin-top: 30px;
  }
}
.contents-shopinfo .button a {
  width: 30.7467057101vw;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .button a {
    width: 100%;
    max-width: 300px;
  }
}
.contents-shopinfo .button.--row {
  gap: 30px;
  width: 55%;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .button.--row {
    gap: 20px;
  }
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .button.--row {
    width: 65%;
  }
}
.contents-shopinfo .button.--row a {
  width: calc(50% - 15px);
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .button.--row a {
    width: 100%;
  }
}
.contents-shopinfo .button.--row a .label {
  font-size: clamp(1.3125rem, 1.2811127379vw, 1.75rem);
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .button.--row a .label {
    font-size: 16px;
  }
}
.contents-shopinfo .detail {
  margin: 0 auto;
}
.contents-shopinfo .detail .lead {
  font-size: clamp(1.05rem, 1.1713030747vw, 1.6rem);
  font-weight: bold;
  text-align: center;
  margin: 3rem auto;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .detail .lead {
    margin: 2rem auto;
  }
}
.contents-shopinfo .detail .box {
  border: 2px solid var(--color);
  text-align: center;
  padding: 1rem;
  margin: 5rem auto;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .detail .box {
    margin: 2rem auto;
  }
}
.contents-shopinfo .detail .box h4 {
  display: flex;
  align-items: center;
  gap: 1rem;
  justify-content: center;
  color: var(--color);
  font-size: clamp(1.8rem, 2.635431918vw, 3.6rem);
  font-weight: 700;
  margin: 2rem auto;
}
.contents-shopinfo .detail .box h4::after, .contents-shopinfo .detail .box h4::before {
  content: "";
  background: var(--color);
  display: inline-block;
  width: 13px;
  height: 13px;
  transform: rotate(45deg);
}
.contents-shopinfo .detail .box dl {
  max-width: 664px;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 1rem;
  margin: 2rem auto;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .detail .box dl {
    grid-template-columns: unset;
    justify-content: center;
  }
}
.contents-shopinfo .detail .box dl dt {
  background: var(--main-color);
  color: #fff;
  font-size: clamp(1.35rem, 1.4641288433vw, 2rem);
  font-weight: bold;
  padding: 2px 1rem;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .detail .box dl dd img {
    width: 100%;
  }
}
.contents-shopinfo .detail p {
  font-size: clamp(1.2rem, 1.1713030747vw, 1.6rem);
  margin: 0 auto 1rem;
}
.contents-shopinfo .detail .note {
  color: var(--color);
  font-size: clamp(0.825rem, 1.0248901903vw, 1.4rem);
}
.contents-shopinfo .outline {
  width: calc(100% - 50px);
  max-width: 800px;
  margin: 0 auto;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .outline {
    width: 100%;
  }
}
.contents-shopinfo .outline:last-child {
  margin-bottom: 3rem;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .outline:last-child {
    margin-bottom: 0;
  }
}
.contents-shopinfo .outline__head {
  background-color: var(--main-color);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.contents-shopinfo .outline__head h2 {
  font-size: clamp(1.65rem, 1.6105417277vw, 2.2rem);
  white-space: nowrap;
  color: var(--white);
}
.contents-shopinfo .outline.--03 {
  margin: 0 auto;
}
.contents-shopinfo .outline.--03 .detail .box {
  max-width: 625px;
  margin: auto;
}
.contents-shopinfo .outline.--03 .detail .box h4 {
  margin: 1rem 0 0;
}
.contents-shopinfo .border {
  border: 6px solid var(--color);
  padding: 3px;
  max-width: 560px;
  margin: auto;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .border {
    max-width: 320px;
  }
}
.contents-shopinfo .border .box {
  margin: 0;
  padding: 0 10px;
}
.contents-shopinfo .border .box .table-scroll {
  overflow-x: auto;
}
.contents-shopinfo .border .box table {
  margin: auto;
  width: auto;
  border: unset;
  margin-bottom: 20px;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .border .box table {
    margin-bottom: 10px;
  }
}
.contents-shopinfo .border .box table th,
.contents-shopinfo .border .box table td {
  border: unset;
  padding: 5px 20px;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .border .box table th,
  .contents-shopinfo .border .box table td {
    padding: 5px;
    font-size: clamp(10px, 2.9333333333vw, 1.2rem);
  }
}
.contents-shopinfo .border .box table th {
  background: var(--color);
  color: #fff;
}
.contents-shopinfo .border .box table td {
  color: var(--color);
}
.contents-shopinfo .border .box table tr:not(:first-child) td {
  border-bottom: 1px solid var(--color);
}
.contents-shopinfo .border .box table tr td {
  white-space: nowrap;
}
.contents-shopinfo .border .box table tr td:first-child {
  text-align: right;
}
.contents-shopinfo .border .box table tr.--end td {
  color: #000;
}
.contents-shopinfo .border .box table tr.--end td:not(:last-child) {
  text-decoration: line-through;
}
.contents-shopinfo .news_list {
  max-width: 700px;
  margin: 30px auto;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .news_list {
    margin: 15px auto;
  }
}
.contents-shopinfo .news_list a {
  background: none;
  border-bottom: 5px dotted var(--main-color) !important;
  gap: 5px 1rem;
  padding: 1rem 0;
}
.contents-shopinfo .news_list a:last-child {
  border: none;
}
.contents-shopinfo .news_list .button {
  display: none;
}
.contents-shopinfo .about-flex {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .about-flex {
    grid-template-columns: 1fr;
    gap: 20px;
    width: calc(100% - 50px);
    margin: auto;
  }
}
.contents-shopinfo .date-list {
  width: calc(100% - 50px);
  max-width: 640px;
  margin: 0 auto;
  display: grid;
  gap: 2rem;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .date-list {
    gap: 10px;
    width: 100%;
  }
}
.contents-shopinfo .apply-flex {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 48px;
}
@media screen and (max-width: 865px) {
  .contents-shopinfo .apply-flex {
    margin-top: 32px;
  }
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .apply-flex {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px 10px;
  }
}
.contents-shopinfo .faq-box {
  margin: 30px auto;
  max-width: 700px;
  width: 100%;
  display: grid;
}
.contents-shopinfo .faq-box .acdn-toggle {
  border-top: 2px dotted var(--main-color);
}
.contents-shopinfo .faq-box .acdn-toggle:last-child {
  border-bottom-style: dotted;
}
.contents-shopinfo .faq-box .acdn-btn {
  display: grid;
  grid-template-columns: 32px auto;
  gap: 10px;
}
.contents-shopinfo .faq-box .acdn-contents {
  align-items: center;
  display: grid;
  grid-template-columns: 20px auto;
  gap: 10px;
  padding: 0 5.2rem 2.2rem;
}
.contents-shopinfo .faq-box .faq-btn .unit {
  content: "";
  aspect-ratio: 1/1;
  width: 32px;
  background: url(../images/page/shopinfo/icon_q.svg) no-repeat center/cover;
}
.contents-shopinfo .faq-box .faq-box-el__contents .unit {
  content: "";
  aspect-ratio: 1/1;
  width: 20px;
  background: url(../images/page/shopinfo/icon_a.svg) no-repeat center/cover;
}
.contents-shopinfo .list {
  max-width: 580px;
  margin: 30px auto;
  display: grid;
  gap: 2rem;
  justify-content: center;
}
.contents-shopinfo .list li {
  font-size: clamp(1.35rem, 1.317715959vw, 1.8rem) !important;
}
.contents-shopinfo .list .link {
  color: var(--main-color);
  font-weight: bold;
  text-decoration: underline;
  font-size: inherit;
  transition: 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .contents-shopinfo .list .link:hover {
    opacity: 0.8;
  }
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .list {
    margin: 20px auto;
  }
}
.contents-shopinfo .download-notes {
  width: calc(100% - 50px);
  max-width: 500px;
  margin: 0 auto;
  margin-top: 28px;
}
@media screen and (max-width: 865px) {
  .contents-shopinfo .download-notes {
    margin-top: 14px;
  }
}
.contents-shopinfo .download-notes .notes {
  font-size: 1.2rem;
  text-indent: -1em;
  padding-left: 1em;
}
@media screen and (max-width: 640px) {
  .contents-shopinfo .download-notes {
    width: 100%;
  }
  .contents-shopinfo .download-notes .notes {
    font-size: 10px;
  }
}

.contact_box {
  border: 3px solid var(--color);
  text-align: center;
  padding: 1rem;
  max-width: 625px;
  margin: auto;
  color: var(--color);
}
.contact_box h4 {
  color: var(--color);
  font-size: clamp(1.35rem, 1.4641288433vw, 2rem);
  font-weight: 700;
}
.contact_box .note {
  color: var(--color);
  font-size: clamp(0.825rem, 1.0248901903vw, 1.4rem);
  margin: 0;
}
.contact_box p.time {
  color: var(--color);
  font-size: clamp(1.05rem, 1.1713030747vw, 1.6rem);
  font-weight: bold;
  margin: 1em 0 0;
}
.contact_box .tel {
  color: var(--color);
  font-size: clamp(2.25rem, 2.9282576867vw, 4rem);
  font-weight: bold;
  line-height: 1;
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
  display: inline-block;
}
@media screen and (max-width: 640px) {
  .contact_box h4 {
    font-size: 18px;
  }
  .contact_box .note {
    font-size: 10px !important;
  }
  .contact_box p.time {
    font-size: 14px;
  }
  .contact_box .tel {
    font-size: 30px;
  }
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-premium */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.content-page .premium-support {
  background-color: var(--yellow);
  padding-block: 20px;
}
@media screen and (max-width: 865px) {
  .content-page .premium-support {
    padding-block: 10px;
  }
}
.content-page .premium-support {
  margin-top: 100px;
}
@media screen and (max-width: 865px) {
  .content-page .premium-support {
    margin-top: 50px;
  }
}
.content-page .premium-support .p-contents-inner {
  border-top: 5px solid #fff;
  border-bottom: 5px solid #fff;
  padding-block: 50px;
}
@media screen and (max-width: 865px) {
  .content-page .premium-support .p-contents-inner {
    padding-block: 50px;
  }
}
.content-page .premium-support .p-contents-block {
  background-image: url("../images/common/item/bird.png");
  background-size: 50px;
  background-position: right top;
  background-repeat: no-repeat;
}
@media screen and (max-width: 640px) {
  .content-page .premium-support .p-contents-block {
    background-image: none;
  }
}
.content-page .premium-support .support .head {
  padding-bottom: 24px;
}
@media screen and (max-width: 865px) {
  .content-page .premium-support .support .head {
    padding-bottom: 24px;
  }
}
.content-page .premium-support .support .head h2 {
  max-width: 400px;
  margin: auto;
}
.content-page .premium-support .support .head h2 img {
  width: 100%;
}
.content-page .premium-support .support__body .outline + .outline {
  padding-top: 48px;
}
@media screen and (max-width: 865px) {
  .content-page .premium-support .support__body .outline + .outline {
    padding-top: 32px;
  }
}
.content-page .premium-support .support__body .outline + .outline .outline__head {
  background-color: #00c8d2;
}
.content-page .premium-support .support__body .outline + .outline .outline__head h3 {
  font-size: 2rem;
}
@media screen and (max-width: 640px) {
  .content-page .premium-support .support__body .outline + .outline .outline__head h3 {
    font-size: 1.8rem;
  }
}
.content-page .premium-support .support__body .outline:first-child table td {
  width: 33.3333333333%;
}
.content-page .premium-support .support__body .outline__head {
  background-color: #00aa9b;
  text-align: center;
  border-radius: 20px 20px 0 0;
  padding: 10px;
}
.content-page .premium-support .support__body .outline__head h3 {
  font-size: var(--font-size-h2);
  letter-spacing: 0.1em;
  line-height: 1.4;
  color: var(--white);
}
@media screen and (max-width: 640px) {
  .content-page .premium-support .support__body .outline__head h3 {
    font-size: 1.8rem;
  }
}
.content-page .premium-support .support__body .outline__head .date {
  font-size: var(--font-size-h3);
  line-height: 1.4;
  letter-spacing: 0.1em;
  color: var(--white);
  justify-content: center;
}
.content-page .premium-support .support__body .outline__head .date span {
  font-size: 0.7em;
}
@media screen and (max-width: 640px) {
  .content-page .premium-support .support__body .outline__head .date span {
    display: block;
  }
}
@media screen and (max-width: 640px) {
  .content-page .premium-support .support__body .outline__head .date {
    font-size: 1.6rem;
  }
}
.content-page .premium-support .support__body .outline__body {
  background-color: #fff;
  border-radius: 0 0 20px 20px;
  padding: 10px;
  overflow-x: auto;
}
@media screen and (max-width: 640px) {
  .content-page .premium-support .support__body .outline__body {
    padding: 10px;
  }
}
.content-page .premium-support .support__body .outline__body table {
  border: none;
  min-width: 810px;
}
.content-page .premium-support .support__body .outline__body table tr:not(:last-child) td span {
  position: relative;
}
.content-page .premium-support .support__body .outline__body table tr:not(:last-child) td span::after {
  background: radial-gradient(circle farthest-side, #00c8d2, #00c8d2 20%, transparent 20%, transparent);
  background-size: 8px;
  content: "";
  display: inline-block;
  height: 16px;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: -8px;
}
@media screen and (max-width: 640px) {
  .content-page .premium-support .support__body .outline__body table tr:not(:last-child) td span::after {
    background: radial-gradient(circle farthest-side, #00c8d2, #00c8d2 15%, transparent 20%, transparent);
    background-size: 9px;
    height: 15px;
  }
}
.content-page .premium-support .support__body .outline__body table td {
  font-size: var(--font-size-h5);
  border: none;
  padding: 0 0.5em;
}
.content-page .premium-support .support__body .outline__body table td:not(:first-child) {
  border-left: 2px solid #00c8d2;
}
.content-page .premium-support .support__body .outline__body table td span {
  font-size: 1.4rem;
  display: block;
  padding: 1em 0;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
.content-page .premium-support .support__body .outline__body table.table01 tr:first-child td:first-child {
  border-right: 2px solid #00c8d2;
}
.content-page .premium-support .support__body .outline__body table.table01 td {
  text-align: center;
}
.content-page .premium-support .support__body .outline__body table.table01 td:not(:first-child) {
  border: inherit;
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*index: 注意事項 */
.flow-attention {
  overflow: hidden;
}
.flow-attention .p-contents-inner {
  padding-top: 0;
}
.flow-attention .flow__head {
  background-color: var(--main-color);
  padding: 1.6rem 0;
  position: relative;
  z-index: 1;
}
.flow-attention .flow__head::before, .flow-attention .flow__head::after {
  content: "";
  width: 100%;
  height: 100%;
  background-color: var(--main-color);
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}
.flow-attention .flow__head::before {
  transform: translateX(-100%);
}
.flow-attention .flow__head::after {
  transform: translateX(100%);
}
.flow-attention .flow__head h3 {
  font-size: var(--font-size-lg);
  font-weight: 500;
  text-align: center;
  color: #fff;
}
.flow-attention .flow__body {
  position: relative;
  max-width: 650px;
  margin: 0 auto;
  padding-top: 64px;
}
@media screen and (max-width: 865px) {
  .flow-attention .flow__body {
    padding-top: 32px;
  }
}
.flow-attention .flow.flow05 .flow__body {
  max-width: 850px;
  position: relative;
}
.flow-attention .flow.flow05 .flow__body::before {
  content: none;
}
.flow-attention .flow.flow05 .flow__body .character {
  position: absolute;
  left: -10%;
  bottom: 0;
  width: 132px;
  pointer-events: none;
}
.flow-attention .flow .text p {
  font-weight: 700;
  text-align: center;
  line-height: 1.8;
  letter-spacing: 0.1em;
}
.flow-attention .attention {
  padding-top: 48px;
}
@media screen and (max-width: 865px) {
  .flow-attention .attention {
    padding-top: 32px;
  }
}
.flow-attention .attention .head .design02 {
  width: 100%;
}
.flow-attention .attention__body {
  padding-top: 24px;
}
@media screen and (max-width: 865px) {
  .flow-attention .attention__body {
    padding-top: 16px;
  }
}
.flow-attention .attention__body {
  max-width: 800px;
  margin: auto;
}
.flow-attention .attention__body > ul li {
  margin-left: 1em;
  font-size: 16px;
}
@media screen and (max-width: 640px) {
  .flow-attention .attention__body > ul li {
    font-size: 14px;
  }
}
.flow-attention .attention__body > ul li::marker {
  content: "●";
}
.flow-attention .attention__body h5:not(:first-child) {
  margin-top: 20px;
}
@media screen and (max-width: 865px) {
  .flow-attention .attention__body h5:not(:first-child) {
    margin-top: 20px;
  }
}
.flow-attention .attention__body h5 {
  background: var(--main-color);
  border-radius: 999px;
  color: #fff;
  font-size: 16px;
  padding: 2px 10px;
  display: inline-block;
  min-width: 60px;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .flow-attention .attention__body h5 {
    font-size: 14px;
  }
}
.flow-attention .attention__body h5.--pink {
  background: var(--pink);
}
.flow-attention .attention__body h5.--green {
  background: var(--green);
}
.flow-attention .attention__body p {
  font-size: clamp(1.2rem, 1.1243rem + 0.2018vw, 1.4rem);
}
.flow-attention .attention__body .border {
  margin-top: 24px;
}
@media screen and (max-width: 865px) {
  .flow-attention .attention__body .border {
    margin-top: 16px;
  }
}
.flow-attention .attention__body .border {
  background-color: var(--accent-color02);
  border: 2px solid var(--main-color);
  border-radius: 28px;
}
@media screen and (max-width: 640px) {
  .flow-attention .attention__body .border {
    border-radius: 20px;
  }
}
.flow-attention .attention__body .border__inner {
  padding: 2.8rem;
}
@media screen and (max-width: 640px) {
  .flow-attention .attention__body .border__inner {
    padding: 2rem;
  }
}
.flow-attention .attention__body .border h5 {
  font-size: clamp(1.6rem, 1.373rem + 0.6054vw, 2.2rem);
  text-align: center;
  color: var(--main-color);
  margin-bottom: 0.5em;
}
.flow-attention .attention__body .border ul {
  padding-left: calc(var(--font-size-sm) / 2);
}
.flow-attention .attention__body .border ul li {
  font-size: var(--font-size-sm);
}
.flow-attention .attention__body .border ul li::marker {
  content: "・";
}
.flow-attention .dl-box {
  display: flex;
  justify-content: space-around;
  align-items: center;
}
@media screen and (max-width: 640px) {
  .flow-attention .dl-box {
    flex-direction: column-reverse;
  }
}
.flow-attention .dl-box .pamphlet {
  width: 156px;
  height: 156px;
}
@media screen and (max-width: 640px) {
  .flow-attention .dl-box .pamphlet {
    width: 125px;
    height: 125px;
    orphans: -1;
    margin: 0 auto 3.2rem;
  }
}
.flow-attention .dl-box .pamphlet a {
  display: block;
  border-radius: 50%;
  transition: opacity 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .flow-attention .dl-box .pamphlet a:hover {
    opacity: 0.7;
  }
}
.flow-attention .dl-box .pamphlet a img {
  border-radius: 50%;
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-point */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.content-page .point .lead p {
  font-size: clamp(1.7rem, 1.6243rem + 0.2018vw, 1.9rem);
  font-weight: 700;
  text-align: center;
  line-height: 1.8;
  letter-spacing: 0.1em;
}
.content-page .point .service .img {
  padding-top: 48px;
}
@media screen and (max-width: 865px) {
  .content-page .point .service .img {
    padding-top: 32px;
  }
}
.content-page .point .attention .head {
  padding-bottom: 48px;
}
@media screen and (max-width: 865px) {
  .content-page .point .attention .head {
    padding-bottom: 32px;
  }
}
.content-page .point .attention .head h2 {
  font-size: var(--font-size-lg);
  font-weight: 700;
  text-align: center;
  color: var(--main-color);
}
.content-page .point .attention .scroll-area {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 550px;
  background-color: var(--border-color);
}
.content-page .point .attention .scroll-area .text-box p {
  text-align: center;
  font-weight: 700;
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/* content-form */
/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
.index__form .content-title .head h1 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  text-align: left;
}
@media screen and (max-width: 640px) {
  .index__form .content-title .head h1 {
    gap: 0.5rem;
  }
}
.index__form .content-title .head h1 .icon-label {
  width: 150px;
  aspect-ratio: 90/47;
  display: flex;
}
@media screen and (max-width: 640px) {
  .index__form .content-title .head h1 .icon-label {
    width: 100px;
  }
}

@media screen and (max-width: 865px) {
  .ticket-form {
    margin-top: 40px;
  }
}
.ticket-form .p-contents-inner {
  width: calc(100% - 50px);
  max-width: 1050px;
  margin: 0 auto;
}
.ticket-form .p-contents-block {
  width: calc(100% - 50px);
  max-width: 690px;
  margin: 0 auto;
  padding-top: 40px;
}
.ticket-form .text p {
  font-size: clamp(1.95rem, 1.9033674963vw, 2.6rem);
  font-weight: 700;
  text-align: center;
}
.ticket-form .head {
  margin: 0 auto 30px;
}
.ticket-form .head:not(:first-child) {
  margin-top: 40px;
}
.ticket-form .head h2 {
  font-size: clamp(1.575rem, 1.756954612vw, 2.4rem);
  text-align: center;
}
.ticket-form .head h3 {
  font-size: clamp(1.5rem, 1.4641288433vw, 2rem);
}
.ticket-form .detail h3 {
  color: var(--color);
  font-size: clamp(1.5rem, 1.4641288433vw, 2rem);
  font-weight: 700;
  margin: 2rem auto 1rem;
}
.ticket-form .detail p {
  font-size: clamp(1.2rem, 1.1713030747vw, 1.6rem);
  margin: 0 auto 1rem;
}
.ticket-form .detail a {
  font-size: clamp(1.2rem, 1.1713030747vw, 1.6rem);
}
.ticket-form .detail ul {
  padding-left: 1.5rem;
  margin-bottom: 2rem;
}
.ticket-form .detail ul li {
  font-size: clamp(1.2rem, 1.1713030747vw, 1.6rem);
}

/*━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━*/
/*index: 完了画面 */
.ticket-form.--complete .head .design01::before, .ticket-form.--complete .head .design01::after {
  display: none;
}
.ticket-form.--complete .head h2 span {
  font-size: clamp(1.575rem, 2.196193265vw, 3rem);
  display: inline-block;
}
.ticket-form.--complete .detail h3 {
  color: var(--color);
  font-size: clamp(1.5rem, 1.4641288433vw, 2rem);
  font-weight: 700;
  margin: 2rem auto 1rem;
}
.ticket-form.--complete .detail p {
  font-size: clamp(1.2rem, 1.1713030747vw, 1.6rem);
  margin: 0 auto 1rem;
}
.ticket-form.--complete .detail p b {
  color: var(--main-color);
}
.ticket-form.--complete .detail a {
  font-size: clamp(1.2rem, 1.1713030747vw, 1.6rem);
}
.ticket-form.--complete .detail ul {
  padding-left: 1.5rem;
  margin-bottom: 2rem;
}
.ticket-form.--complete .detail ul li {
  font-size: clamp(1.2rem, 1.1713030747vw, 1.6rem);
}
.ticket-form.--complete .detail .number {
  font-size: clamp(1.5rem, 2.196193265vw, 3rem);
  font-weight: bold;
  text-align: center;
  margin-bottom: 20px;
}
.ticket-form.--complete .detail .number span {
  color: var(--main-color);
  padding: 0 5px;
}/*# sourceMappingURL=style.css.map */