@charset "UTF-8";
/* 共通(フロント)
================================================== */
/* Reset
================================================== */
/*! destyle.css v3.0.0 | MIT License | https://github.com/nicolas-cusan/destyle.min.css */
*, ::before, ::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

body {
  margin: 0;
}

main {
  display: block;
}

p, table, blockquote, address, pre, iframe, form, figure, dl {
  margin: 0;
}

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

ul, ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

dt {
  font-weight: 700;
}

dd {
  margin-left: 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

pre {
  font-family: monospace, monospace;
  font-size: inherit;
}

address {
  font-style: inherit;
}

a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

abbr[title] {
  text-decoration: underline dotted;
}

b, strong {
  font-weight: bolder;
}

code, kbd, samp {
  font-family: monospace, monospace;
  font-size: inherit;
}

small {
  font-size: 80%;
}

sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

svg, img, embed, object, iframe {
  vertical-align: bottom;
}

button, input, optgroup, textarea {
  -webkit-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit;
}

[type=checkbox] {
  -webkit-appearance: checkbox;
  appearance: checkbox;
}

[type=radio] {
  -webkit-appearance: radio;
  appearance: radio;
}

button, [type=button], [type=reset], [type=submit] {
  cursor: pointer;
}

button:disabled, [type=button]:disabled, [type=reset]:disabled, [type=submit]:disabled {
  cursor: default;
}

:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

option {
  padding: 0;
}

fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

legend {
  padding: 0;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=number]::-webkit-inner-spin-button, [type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

label[for] {
  cursor: pointer;
}

details {
  display: block;
}

summary {
  display: list-item;
}

[contenteditable]:focus {
  outline: auto;
}

table {
  border-color: inherit;
}

caption {
  text-align: left;
}

td, th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: 700;
}

/* Base
================================================== */
* {
  box-sizing: border-box;
}

html {
  font-size: 62.5%;
  scroll-behavior: smooth;
}

body {
  font-size: 1.6rem;
  font-family: "Zen Kaku Gothic New", "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  width: 100%;
  margin: 0 auto;
  padding: 0;
  font-style: normal;
  font-weight: normal;
  line-height: 1;
  background: #FFFFFF;
  color: #333333;
  -webkit-text-size-adjust: 100%;
}

img {
  max-width: 100%;
  width: auto;
  height: auto;
  vertical-align: bottom;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}

a {
  color: #333333;
  text-decoration: none;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
a[href^="tel:"] {
  cursor: default;
}

p {
  line-height: 1.75;
}

/* Layout
================================================== */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  opacity: 0;
  visibility: hidden;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  z-index: 4;
  pointer-events: none;
}
body.is-mega-open::before {
  opacity: 1;
  visibility: visible;
}

#container {
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding-block-start: 104px;
}
@media screen and (max-width: 1280px) {
  #container {
    padding-block-start: 114px;
  }
}
@media screen and (max-width: 980px) {
  #container {
    padding-block-start: 82px;
  }
}
@media screen and (max-width: 1300px) {
  #container {
    padding-block-end: 68px;
  }
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #FFFFFF;
  z-index: 4;
}
.header__wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block: 20px;
  padding-inline: 40px;
}
@media screen and (max-width: 980px) {
  .header__wrap {
    gap: 0 28px;
    padding-block: 12px;
    padding-inline: 15px 68px;
  }
}
.header__logo {
  max-width: 420px;
}
@media screen and (max-width: 1280px) {
  .header__logo {
    max-width: 200px;
  }
}
@media screen and (max-width: 980px) {
  .header__logo {
    max-width: 188px;
  }
}
.header__logo a {
  display: block;
}

.global-nav {
  font-weight: bold;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 980px) {
  .global-nav {
    display: none;
  }
}
.global-nav__subnav {
  display: flex;
  justify-content: end;
  align-items: center;
  gap: 0 40px;
}
.global-nav__main {
  display: flex;
  align-items: center;
  justify-content: end;
  gap: 0 20px;
}
.global-nav__menu {
  display: flex;
  justify-content: end;
  align-items: center;
  gap: 0 20px;
}
@media screen and (max-width: 1280px) {
  .global-nav__menu {
    gap: 0 12px;
  }
}
.global-nav__menu > li {
  position: static;
}
.global-nav__menu > li a:hover {
  color: #F4A300;
}
.global-nav__menu > li > a {
  display: block;
  padding-block: 8px;
}
.global-nav__menu > li:hover .global-nav__label::after, .global-nav__menu > li:focus-within .global-nav__label::after {
  background-color: #F4A300;
}
.global-nav__menu > li:hover .global-nav__submenu-item,
.global-nav__menu > li .global-nav__submenu-item.focused, .global-nav__menu > li:focus-within .global-nav__submenu-item {
  visibility: visible;
  opacity: 1;
  transform: translateY(0);
}
.global-nav__submenu {
  display: flex;
  gap: 0 8px;
  align-items: center;
}
.global-nav__submenu::after {
  content: "";
  background: url("../img/ico_arrow_bottom.svg") no-repeat center center/contain;
  display: inline-block;
  width: 8px;
  height: 5px;
}
.global-nav__submenu-item {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  width: 100%;
  padding: 40px;
  text-align: left;
  list-style: none;
  background: #FFFFFF;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  z-index: 4;
}
.global-nav__label {
  position: relative;
  display: inline-block;
}
.global-nav__label::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -11px;
  height: 3px;
  background-color: transparent;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
.global-nav__mega {
  display: flex;
  align-items: flex-start;
  gap: 0 32px;
}
.global-nav__mega-title {
  flex: 0 0 240px;
}
.global-nav__mega-title a {
  font-size: 2rem;
  font-weight: bold;
  display: inline-flex;
  align-items: center;
  gap: 0 8px;
  line-height: 1.5;
}
@media screen and (max-width: 1280px) {
  .global-nav__mega-title a {
    font-size: 1.6rem;
  }
}
.global-nav__mega-title a::after {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background: url("../img/ico_arrow-right-circle_01.svg") no-repeat;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
.global-nav__mega-links {
  flex: 1 1 auto;
  display: block;
}
.global-nav__mega-links ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, minmax(140px, 1fr));
  grid-auto-flow: row;
  gap: 12px;
}
@media screen and (max-width: 1280px) {
  .global-nav__mega-links ul {
    grid-template-columns: repeat(3, minmax(140px, 1fr));
  }
}
.global-nav__mega-links li a {
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 0 8px;
  padding-block-end: 12px;
  border-bottom: 1px solid #E6DACA;
  line-height: 1.5;
}
@media screen and (max-width: 1280px) {
  .global-nav__mega-links li a {
    font-size: 1.4rem;
  }
}
.global-nav__mega-links li a::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  background: rgba(244, 163, 0, 0.7);
  border-radius: 100%;
}
.global-nav__mega-links li a:hover {
  border-color: #F4A300;
  color: #F4A300;
}
.global-nav .c-list-subnav {
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  justify-content: end;
  gap: 0 12px;
}
.global-nav .c-list-subnav > li a:not(.c-btn):not(.search) {
  display: flex;
  gap: 0 8px;
  align-items: center;
}
.global-nav .c-list-subnav > li a:not(.c-btn):not(.search)::before {
  content: "";
  display: inline-block;
}
.global-nav .c-list-subnav > li a:not(.c-btn):not(.search).help::before {
  width: 12px;
  height: 12px;
  background: url("../img/ico_help.svg") no-repeat center center/contain;
}
.global-nav .c-list-subnav > li a:not(.c-btn):not(.search).pin::before {
  width: 10px;
  height: 12px;
  background: url("../img/ico_pin.svg") no-repeat center center/contain;
}
.global-nav .c-list-subnav > li a:not(.c-btn):not(.search).mail {
  margin-inline-end: 8px;
}
.global-nav .c-list-subnav > li a:not(.c-btn):not(.search).mail::before {
  width: 12px;
  height: 9px;
  background: url("../img/ico_mail.svg") no-repeat center center/contain;
}
.global-nav .c-list-subnav > li a:not(.c-btn):not(.search):hover {
  color: #F4A300;
}
.global-nav .c-list-subnav > li a.c-btn {
  font-size: 1.6rem;
  position: relative;
  display: inline-block;
  text-align: center;
  padding: 7px 50px 7px 40px;
  background: #F4A300;
  color: #FFFFFF;
  border-radius: 100vh;
}
@media screen and (max-width: 1280px) {
  .global-nav .c-list-subnav > li a.c-btn {
    font-size: 1.4rem;
    padding: 7px 40px 7px 30px;
  }
}
.global-nav .c-list-subnav > li a.c-btn:hover {
  opacity: 0.8;
}
.global-nav .c-list-subnav > li a.c-btn::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 8px;
  width: 20px;
  height: 20px;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  translate: 0 -50%;
}
.global-nav .c-list-subnav > li a.c-btn.green::after, .global-nav .c-list-subnav > li a.c-btn.orange::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 8px;
  width: 20px;
  height: 20px;
  margin-block-start: 0;
  background-color: #FCF4E8;
  mask: url("../img/ico_blank_circle_01.svg") no-repeat top right/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  translate: 0 -50%;
}
.global-nav .c-list-subnav > li a.c-btn.green {
  background: #7FBF2A;
}
.global-nav .c-list-subnav > li a.c-btn.orange {
  background: #F4A300;
}

.contents__wrap {
  position: relative;
  max-width: 1080px;
  margin: 0 auto;
}
@media screen and (max-width: 1280px) {
  .contents__wrap {
    width: 94%;
  }
}

.page .contents {
  margin-block-end: 80px;
}
@media screen and (max-width: 767px) {
  .page .contents {
    margin-block-end: 60px;
  }
}

.footer {
  position: relative;
  container-type: inline-size;
  background: url("../img/bg_01.webp") no-repeat center center/cover;
}
.footer::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #FCF4E8;
  mix-blend-mode: hard-light;
  opacity: 0.97;
  pointer-events: none;
  z-index: 1;
}
.footer__wrap {
  position: relative;
  max-width: 1200px;
  margin-inline: auto;
}
@container (max-width: 1280px) {
  .footer__wrap {
    width: 94%;
  }
}
.footer__wrap2 {
  position: relative;
  max-width: 800px;
  margin-inline: auto;
}
@media screen and (max-width: 1280px) {
  .footer__wrap2 {
    width: 94%;
  }
}
.footer__top, .footer__center, .footer__bottom {
  position: relative;
  z-index: 2;
}
.footer__top {
  position: relative;
  padding-block: 60px;
}
@media screen and (max-width: 767px) {
  .footer__top {
    padding-block: 40px;
  }
}
.footer__top p {
  margin-block-end: 32px;
}
.footer__top .p-footer-contact {
  display: grid;
  grid-template-columns: 352px 1fr;
  gap: 0 32px;
}
@container (max-width: 767px) {
  .footer__top .p-footer-contact {
    grid-template-columns: 1fr;
    gap: 20px 0;
  }
}
.footer__top .p-footer-contact__links {
  display: flex;
  flex-direction: column;
  gap: 12px 0;
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer__top .p-footer-contact__link {
  font-size: 1.8rem;
  font-weight: bold;
  position: relative;
  display: flex;
  align-items: center;
  gap: 0 12px;
  padding: 16px 48px 16px 20px;
  background: #FFFFFF;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(51, 51, 51, 0.08);
  line-height: 1.5;
  letter-spacing: 0.04em;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
@container (max-width: 767px) {
  .footer__top .p-footer-contact__link {
    font-size: 1.6rem;
  }
}
.footer__top .p-footer-contact__link:hover {
  color: #F4A300;
}
.footer__top .p-footer-contact__link::before {
  content: "";
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  background-color: #F4A300;
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
}
.footer__top .p-footer-contact__link::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 8px;
  height: 13px;
  background-color: #F4A300;
  mask: url("../img/ico_arrow_right.svg") no-repeat center/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  translate: 0 -50%;
}
.footer__top .p-footer-contact__link--calendar::before {
  mask-image: url("../img/ico_calendar_circle_01.svg");
}
.footer__top .p-footer-contact__link--mail::before {
  mask-image: url("../img/ico_mail_circle_01.svg");
}
.footer__bottom {
  padding-block: 40px;
}
.footer__bottom .p-two-block {
  gap: 0 60px;
}
@container (max-width: 1199px) {
  .footer__bottom .p-two-block {
    flex-direction: column;
    gap: 20px 0;
    margin-block-end: 32px;
  }
}
.footer__two-block {
  margin-block-end: 12px;
}
.footer__logo {
  max-width: 420px;
}
@media screen and (max-width: 1280px) {
  .footer__logo {
    max-width: 200px;
  }
}
@media screen and (max-width: 980px) {
  .footer__logo {
    max-width: 188px;
  }
}
.footer__logo + p {
  margin-block-start: 12px;
  line-height: 2;
}
.footer #footer-description .wp-block-buttons.is-layout-flex {
  flex-wrap: nowrap;
  gap: 0 12px;
}
@container (max-width: 767px) {
  .footer #footer-description .wp-block-buttons.is-layout-flex {
    display: flex;
    gap: 0 8px;
  }
}
@container (max-width: 767px) {
  .footer #footer-description .wp-block-buttons.is-layout-flex .is-style-link09,
  .footer #footer-description .wp-block-buttons.is-layout-flex .is-style-link07 {
    flex: 1 1 0;
  }
}
.footer #footer-description .wp-block-buttons.is-layout-flex .is-style-link09 .wp-block-button__link,
.footer #footer-description .wp-block-buttons.is-layout-flex .is-style-link07 .wp-block-button__link {
  padding: 4px 40px;
}
@container (max-width: 767px) {
  .footer #footer-description .wp-block-buttons.is-layout-flex .is-style-link09 .wp-block-button__link,
  .footer #footer-description .wp-block-buttons.is-layout-flex .is-style-link07 .wp-block-button__link {
    padding: 4px;
  }
}
.footer #footer-description .wp-block-buttons:not(:root) .is-style-link09 .wp-block-button__link,
.footer #footer-description .wp-block-buttons:not(:root) .is-style-link07 .wp-block-button__link {
  display: inline-block;
  max-width: auto;
  width: auto;
}
@container (max-width: 767px) {
  .footer #footer-description .wp-block-buttons:not(:root) .is-style-link09 .wp-block-button__link,
  .footer #footer-description .wp-block-buttons:not(:root) .is-style-link07 .wp-block-button__link {
    max-width: 100%;
    width: 100%;
    text-align: center;
  }
}
.footer .c-footer-subnav,
.footer .c-list-sns {
  margin-block-end: 20px;
}
@media screen and (max-width: 767px) {
  .footer .c-footer-subnav {
    width: 80%;
    margin-inline: auto;
  }
}
.footer__copyright {
  font-size: 1.4rem;
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  font-optical-sizing: auto;
  font-style: normal;
  text-transform: uppercase;
}
@media screen and (max-width: 767px) {
  .footer__copyright {
    text-align: center;
  }
}

/* Page */
.page-header {
  container-type: inline-size;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-block-end: 40px;
  background: #FCF4E8;
}
.page-header .page-title {
  position: relative;
  padding-block: 60px;
  width: 100%;
}
@container (max-width: 767px) {
  .page-header .page-title {
    padding-block: 40px;
  }
}

.p-accordion-detail {
  border: 1px solid #F4A300;
  border-radius: 8px;
}
.p-accordion-detail + .p-accordion-detail {
  margin-top: 12px;
}
.p-accordion-detail__heading {
  margin: 0;
}
.p-accordion-detail__trigger {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 16px 52px 16px 20px;
  background: transparent;
  border: none;
  color: #333333;
  cursor: pointer;
  font-family: inherit;
  line-height: 1.5;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .p-accordion-detail__trigger {
    font-size: 1.4rem;
    padding: 14px 44px 14px 16px;
  }
}
.p-accordion-detail__trigger::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  position: absolute;
  top: 50%;
  right: 16px;
  background: url("../img/ico_plus.svg") no-repeat center/contain;
  translate: 0 -50%;
  flex-shrink: 0;
}
.p-accordion-detail__trigger[aria-expanded=true]::after {
  background-image: url("../img/ico_minus.svg");
}
.p-accordion-detail__panel {
  overflow: hidden;
}
@media (prefers-reduced-motion: no-preference) {
  .p-accordion-detail__panel {
    transition: height 0.3s ease-out;
  }
}
.p-accordion-detail__content {
  padding: 0 20px 20px;
}
@media screen and (max-width: 767px) {
  .p-accordion-detail__content {
    padding: 0 16px 16px;
  }
}
.p-accordion-detail__content > * {
  margin: 0;
}
.p-accordion-detail__content > * + * {
  margin-top: 12px;
}

.c-accordion-qa__item {
  position: relative;
  display: block;
  overflow: visible;
  border: 1px solid #F2EDE6;
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(51, 51, 51, 0.08);
}
.c-accordion-qa__item + .c-accordion-qa__item {
  margin-top: 12px;
}
.c-accordion-qa__item::after {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  position: absolute;
  top: 24px;
  right: 16px;
  background: url("../img/ico_plus.svg") no-repeat top right/contain;
  transform-origin: top right;
  z-index: 2;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .c-accordion-qa__item::after {
    top: 22px;
  }
}
.c-accordion-qa__item.is-open::after {
  background-image: url("../img/ico_minus.svg");
}
.c-accordion-qa__heading {
  margin: 0;
}
.c-accordion-qa__trigger {
  font-size: 2rem;
  font-weight: bold;
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  padding: 22px 56px 22px 20px;
  cursor: pointer;
  line-height: 1.5;
  background: transparent;
  border: none;
  text-align: left;
  color: inherit;
  font-family: inherit;
}
@media screen and (max-width: 767px) {
  .c-accordion-qa__trigger {
    font-size: 1.6rem;
    padding: 18px 48px 18px 16px;
  }
}
.c-accordion-qa__trigger::before {
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-optical-sizing: auto;
  font-style: normal;
  content: "Q.";
  display: inline-block;
  min-width: 24px;
  margin-inline-end: 4px;
  color: #F4A300;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .c-accordion-qa__trigger::before {
    min-width: 18px;
  }
}
.c-accordion-qa__item.is-open .c-accordion-qa__trigger::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 20px;
  width: calc(100% - 40px);
  height: 0;
  border-bottom: 1px solid #E5E3E1;
  pointer-events: none;
}
.c-accordion-qa__title {
  flex: 1;
  min-width: 0;
  font-weight: bold;
  color: #333333;
}
.c-accordion-qa__panel {
  position: relative;
  overflow: hidden;
}
@media (prefers-reduced-motion: no-preference) {
  .c-accordion-qa__panel {
    transition: height 0.35s ease-out;
  }
}
.c-accordion-qa__inner {
  position: relative;
  z-index: 0;
  padding: 24px 50px 24px 20px;
  padding-inline-start: calc(20px + 20px + 10px);
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .c-accordion-qa__inner {
    padding: 20px 16px;
    padding-inline-start: calc(16px + 24px + 10px);
  }
}
.c-accordion-qa__inner::before {
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-optical-sizing: auto;
  font-style: normal;
  content: "A.";
  position: absolute;
  left: 20px;
  top: 24px;
  min-width: 20px;
  line-height: 1.75;
  color: #F4A300;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .c-accordion-qa__inner::before {
    left: 16px;
    top: 20px;
    min-width: 24px;
  }
}
.c-accordion-qa__content {
  min-width: 0;
}
.c-accordion-qa__content > * {
  margin: 0;
}
.c-accordion-qa__content > * + * {
  margin-top: 20px;
}
.c-accordion-qa__content ul,
.c-accordion-qa__content ol {
  margin-block: 12px 0;
}
.c-accordion-qa__content p {
  word-break: break-all;
}

/* バッジ */
.c-badge-group {
  display: flex;
  gap: 0 8px;
}

.c-badge {
  font-size: 1.4rem;
  font-weight: bold;
  display: inline-block;
  width: 120px;
  padding: 6px 8px;
  background: #FCF0DE;
  border-radius: 4px;
  color: #333333;
  text-align: center;
  line-height: 1.2;
}
.c-badge a {
  display: block;
  color: #333333;
}
.c-badge a:hover {
  color: #F4A300;
}

/* パンくずリスト */
.c-breadcrumbs {
  margin-block-end: 60px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-breadcrumbs {
    margin-block-end: 40px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
.c-breadcrumbs ul {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .c-breadcrumbs ul {
    flex-wrap: nowrap;
  }
}
.c-breadcrumbs ul li {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0 8px;
}
@media screen and (max-width: 767px) {
  .c-breadcrumbs ul li {
    white-space: nowrap;
  }
}
.c-breadcrumbs ul li:not(:last-child)::after {
  content: "/";
  display: inline-block;
  margin-inline-end: 8px;
}
.c-breadcrumbs ul li.home a {
  display: flex;
  align-items: center;
  gap: 0 8px;
  flex-direction: row;
}
.c-breadcrumbs ul li.home a::before {
  display: inline-block;
  content: "";
  width: 14px;
  height: 16px;
  background-color: #F4A300;
  mask: url("../img/ico_home.svg") no-repeat center center/contain;
}
.c-breadcrumbs ul li a {
  font-weight: 500;
  text-decoration: underline solid rgba(51, 51, 51, 0.3);
  text-decoration-skip-ink: none;
}
.c-breadcrumbs ul li a:hover {
  color: #F4A300;
  text-decoration: underline solid rgba(244, 163, 0, 0.3);
}

/* ボタンエリア */
.c-btn-area {
  position: fixed;
  top: 50%;
  left: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 12px 0;
  translate: 0 -50%;
  z-index: 3;
}
@media screen and (max-width: 1300px) {
  .c-btn-area {
    flex-direction: row;
    gap: 0 8px;
    top: initial;
    bottom: 0;
    width: 100%;
    padding: 8px;
    background: #FCF4E8;
    translate: 0;
  }
}
.c-btn-area .c-btn2 {
  font-size: 1.8rem;
  font-weight: bold;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px 8px;
  border-radius: 0 12px 12px 0;
  box-shadow: 0 4px 20px rgba(51, 51, 51, 0.08);
  color: #FFFFFF;
  letter-spacing: 0.2em;
  line-height: 1.5;
  cursor: pointer;
  white-space: nowrap;
  writing-mode: vertical-rl;
}
@media screen and (max-width: 1300px) {
  .c-btn-area .c-btn2 {
    flex: 1 1 0;
    padding: 7px 0;
    border-radius: 8px;
    letter-spacing: 0;
    transition: none;
    writing-mode: horizontal-tb;
  }
}
@media screen and (max-width: 767px) {
  .c-btn-area .c-btn2 {
    font-size: 1.4rem;
  }
}
.c-btn-area .c-btn2:hover {
  opacity: 0.8;
}
.c-btn-area .c-btn2__wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 12px;
}
.c-btn-area .c-btn2.phone {
  background: #F4A300;
}
.c-btn-area .c-btn2.phone .c-btn2__wrap::before {
  content: "";
  display: inline-block;
  width: 40px;
  height: 40px;
  background-color: #FFFFFF;
  mask: url("../img/ico_phone_circle_01.svg") no-repeat center/contain;
}
@media screen and (max-width: 1300px) {
  .c-btn-area .c-btn2.phone .c-btn2__wrap::before {
    width: 36px;
    height: 36px;
  }
}
.c-btn-area .c-btn2.calendar {
  background: #7FBF2A;
}
.c-btn-area .c-btn2.calendar .c-btn2__wrap::before {
  content: "";
  display: inline-block;
  width: 40px;
  height: 40px;
  background-color: #FFFFFF;
  mask: url("../img/ico_calendar_circle_01.svg") no-repeat center/contain;
}
@media screen and (max-width: 1300px) {
  .c-btn-area .c-btn2.calendar .c-btn2__wrap::before {
    width: 36px;
    height: 36px;
  }
}

/* コンタクトブロック　*/
.c-contact-block {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 16px 0;
  padding-block: 20px;
  padding-inline: 28px;
  background: #FFFFFF;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(51, 51, 51, 0.08);
}

/* フッターのサブナビゲーション */
.c-footer-subnav {
  font-size: 1.4rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 20px;
  justify-content: end;
  line-height: 1.5;
}
@media screen and (max-width: 1199px) {
  .c-footer-subnav {
    justify-content: center;
  }
}
.c-footer-subnav a {
  text-decoration: underline solid rgba(51, 51, 51, 0.3);
  text-decoration-skip-ink: none;
}
.c-footer-subnav a:hover {
  color: #F4A300;
  text-decoration: underline solid rgba(244, 163, 0, 0.3);
}

/* ------------------------------------------------------------
   Snow Monkey Forms
------------------------------------------------------------ */
:not(:root) .smf-progress-tracker__item[aria-current=true] .smf-progress-tracker__item__number {
  background-color: #F4A300;
}

:not(:root) .smf-progress-tracker__item[aria-current=true] .smf-progress-tracker__item__text {
  color: #333333;
}

input[type=button],
input[type=text],
input[type=email],
button[type=submit],
textarea {
  font-family: "Zen Kaku Gothic New", "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 1.6rem;
  border-radius: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  color: #333333;
}

::placeholder {
  color: #AAAAAA;
}

:focus-visible {
  outline: #F4A300 auto 1px;
}

input:not([type=radio]):not([type=checkbox]):not([type=button]):not([type=number]):not([type=date]),
textarea {
  display: block;
  width: 100%;
  padding: 11px 20px;
  background: #FFFFFF;
  border: 1px solid #E5E3E1;
  border-radius: 4px;
}
input:not([type=radio]):not([type=checkbox]):not([type=button]):not([type=number]):not([type=date]):focus-visible,
textarea:focus-visible {
  outline: #F4A300 auto 1px;
}

input[type=number],
input[type=date] {
  font-size: 1.6rem;
  display: inline-block;
  min-width: 145px;
  max-height: 49px;
  min-height: 49px;
  padding: 11px 20px;
  background: #FFFFFF;
  border: 1px solid #E5E3E1;
  border-radius: 4px;
}
input[type=number].full-width,
input[type=date].full-width {
  display: block;
  max-width: 100%;
  width: 100%;
}

input[type=tel] {
  font-size: 1.6rem;
  max-height: 49px;
  min-height: 49px;
}

:not(:root) .smf-form .smf-textarea-control__control {
  padding: 11px 20px;
  resize: vertical;
  line-height: 1.75;
  background: #FFFFFF;
  border: 1px solid #E5E3E1;
  border-radius: 4px;
}
:not(:root) .smf-form .smf-textarea-control__control:focus-visible {
  outline: #F4A300 auto 1px;
}

:not(:root) .smf-action button[type=submit].smf-button-control__control {
  all: unset;
  box-sizing: border-box;
  cursor: pointer;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  display: block;
  max-width: 280px;
  width: 280px;
  padding: 15px 32px;
  background: #F4A300;
  border-radius: 8px;
  color: #FFFFFF;
  text-align: left;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  :not(:root) .smf-action button[type=submit].smf-button-control__control {
    display: block;
    max-width: 100%;
    width: 100%;
  }
}
:not(:root) .smf-action button[type=submit].smf-button-control__control::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 20px;
  height: 20px;
  background-color: #FCF4E8;
  mask: url("../img/ico_arrow-right-circle_01.svg") no-repeat top right/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  translate: 0 -50%;
}
:not(:root) .smf-action button[type=submit].smf-button-control__control:hover {
  opacity: 0.8;
}
:not(:root) .smf-action button[type=submit].smf-button-control__control:focus-visible {
  outline: #F4A300 auto 1px;
}

:not(:root) .smf-action button[type=submit].smf-button-control__control[data-action=back] {
  padding: 15px 32px 15px 52px;
  background-color: #FFFFFF;
  border: 1px solid #F4A300;
  color: #333333;
}
:not(:root) .smf-action button[type=submit].smf-button-control__control[data-action=back]::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 20px;
  width: 20px;
  height: 20px;
  background-color: #F4A300;
  mask: url("../img/ico_arrow-right-circle_01.svg") no-repeat top left/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  translate: 0 -50%;
  scale: -1 1;
}
:not(:root) .smf-action button[type=submit].smf-button-control__control[data-action=back]:hover {
  border-color: #F4A300;
  color: #F4A300;
}

:not(:root) .smf-form--business + .smf-action {
  display: flex;
  justify-content: center;
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  :not(:root) .smf-form--business + .smf-action {
    flex-direction: column;
    gap: 20px;
  }
}

@media screen and (max-width: 767px) {
  :not(:root) .smf-action .smf-button-control + .smf-button-control {
    margin-left: 0;
  }
}

.smf-form .smf-select-control:has(select) {
  display: block;
}
.smf-form .smf-select-control:has(select) select {
  font-family: "Zen Kaku Gothic New", "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 1.6rem;
  display: block;
  width: 100%;
  min-height: 49px;
  padding: 11px 20px;
  border-color: #E5E3E1;
  border-radius: 4px;
}
.smf-form .smf-select-control:has(select) select:focus-visible {
  outline: #F4A300 auto 1px;
}

:not(:root) .smf-form .smf-select-control__toggle {
  right: 10px;
}

:not(:root) .smf-form--business .smf-item__col--controls {
  line-height: 1.5;
}

@media (min-width: 640px) {
  :not(:root) .smf-form--business .smf-item__col--label {
    flex: 0 0 16em;
    max-width: 16em;
  }
  :not(:root) .smf-form--business .smf-item__col--controls {
    flex: 1 1 calc(100% - 16em);
    max-width: calc(100% - 16em);
  }
}
:where(.wp-block-columns.is-layout-flex.group-range).wp-block-columns-is-layout-flex {
  gap: 0 10px;
}

.smf-progress-tracker__item__text:not(:root) {
  font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
  .smf-progress-tracker__item__text:not(:root) {
    white-space: nowrap;
  }
}

/* 必須ラベル */
.smf-item:has([data-validations~=required]) .smf-item__label__text::after {
  font-size: 1.4rem;
  font-weight: bold;
  content: "必須";
  display: inline-block;
  padding: 5px 6px;
  background-color: rgba(230, 106, 69, 0.2);
  border-radius: 4px;
  color: #E66A45;
  margin-left: 1em;
  line-height: 1;
}

:not(:root) .smf-form--business .smf-item {
  border: 1px solid #E5E3E1;
}

:not(:root) .smf-form--business .smf-label {
  line-height: 1.2;
}

:not(:root) .smf-form--business .smf-label + .smf-label {
  margin-top: 4px;
}

:not(:root) .smf-form--business .smf-item__col--label {
  font-weight: bold;
  background-color: #FCF4E8;
  line-height: 1.5;
}

:not(:root) .smf-item__description {
  font-size: 1.2rem;
}

:not(:root) .smf-form .smf-checkbox-control__control,
:not(:root) .smf-form .smf-radio-button-control__control {
  margin-top: calc(var(--_half-leading) * 0.25em);
}
:not(:root) .smf-form .smf-checkbox-control__control:focus-visible,
:not(:root) .smf-form .smf-radio-button-control__control:focus-visible {
  outline: #F4A300 auto 1px;
}

.flatpickr-calendar input,
.flatpickr-calendar select {
  display: inline-block;
  width: auto;
  min-width: 0;
  max-width: none;
  min-height: 0;
  max-height: none;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  appearance: auto;
  -webkit-appearance: auto;
  -moz-appearance: auto;
  color: inherit;
  font-family: inherit;
}
.flatpickr-calendar input:focus-visible,
.flatpickr-calendar select:focus-visible {
  outline: none;
}
.flatpickr-calendar .flatpickr-monthDropdown-months {
  -webkit-appearance: menulist;
  -moz-appearance: menulist;
  appearance: menulist;
}

form.snow-monkey-form[data-screen=confirm] .smf-placeholder[data-name=preferred-date-1] .smf-text-control,
form.snow-monkey-form[data-screen=confirm] .smf-placeholder[data-name=preferred-date-1] .flatpickr-wrapper,
form.snow-monkey-form[data-screen=confirm] .smf-placeholder[data-name=preferred-date-1] input:not([type=hidden]),
form.snow-monkey-form[data-screen=confirm] .smf-placeholder[data-name=preferred-date-2] .smf-text-control,
form.snow-monkey-form[data-screen=confirm] .smf-placeholder[data-name=preferred-date-2] .flatpickr-wrapper,
form.snow-monkey-form[data-screen=confirm] .smf-placeholder[data-name=preferred-date-2] input:not([type=hidden]),
form.snow-monkey-form[data-screen=confirm] .smf-placeholder[data-name=preferred-date-3] .smf-text-control,
form.snow-monkey-form[data-screen=confirm] .smf-placeholder[data-name=preferred-date-3] .flatpickr-wrapper,
form.snow-monkey-form[data-screen=confirm] .smf-placeholder[data-name=preferred-date-3] input:not([type=hidden]) {
  display: none !important;
}

:not(:root) .smf-form .flatpickr-input {
  font-size: 1.6rem;
  display: inline-block;
  min-width: 145px;
  max-height: 49px;
  min-height: 49px;
  padding: 11px 20px;
  background: #FFFFFF;
  border: 1px solid #E5E3E1;
  border-radius: 4px;
  color: #333333;
}
:not(:root) .smf-form .flatpickr-input.full-width {
  display: block;
  max-width: 100%;
  width: 100%;
}
:not(:root) .smf-form .flatpickr-input:focus-visible {
  outline: #F4A300 auto 1px;
}
:not(:root) .smf-form .flatpickr-calendar {
  border-radius: 4px;
  border-color: #E5E3E1;
  font-family: "Zen Kaku Gothic New", "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
:not(:root) .smf-form .flatpickr-day.selected,
:not(:root) .smf-form .flatpickr-day.startRange,
:not(:root) .smf-form .flatpickr-day.endRange {
  background: #F4A300;
  border-color: #F4A300;
}
:not(:root) .smf-form .flatpickr-day.disabled,
:not(:root) .smf-form .flatpickr-day.notAllowed {
  color: #AAAAAA;
}
:not(:root) .smf-form .smf-booking-date-error {
  margin-top: 8px;
}

.grecaptcha-badge {
  visibility: hidden;
}

/* グリッド */
.grid {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}

.grid > * {
  flex: 1 1 100%; /* デフォルトは縦並び（スマホ） */
}

/* 2列 */
@media (min-width: 768px) { /* タブレット以上 */
  .grid-2 > * {
    flex: 1 1 calc(50% - 8px); /* 50%幅、ギャップ考慮 */
  }
}
/* 3列 */
@media (min-width: 1200px) { /* PCサイズ */
  .grid-3 > * {
    flex: 1 1 calc(33.333% - 10.666px);
  }
}
/* 4列 */
@media (min-width: 1501px) { /* 大きいPCサイズ */
  .grid-4 > * {
    flex: 1 1 calc(25% - 12px);
  }
}
/* レイアウトボックス */
.one-block {
  margin: 0 auto 40px;
}
.one-block__image {
  margin: 0 auto;
  text-align: center;
}

.p-two-block,
.p-two-block-link,
.p-three-block,
.p-four-block,
.p-five-block {
  display: flex;
  justify-content: space-between;
}

.p-two-block__box {
  position: relative;
}
.p-two-block__image img {
  width: 100%;
}

.p-three-block {
  flex-wrap: wrap;
  gap: 32px;
  justify-content: start;
}
@media screen and (max-width: 1280px) {
  .p-three-block {
    gap: 20px;
  }
}
.p-three-block__box {
  position: relative;
  width: calc((100% - 64px) / 3);
}
@media screen and (max-width: 1280px) {
  .p-three-block__box {
    width: calc((100% - 40px) / 3);
  }
}
.p-three-block a {
  display: block;
}

.p-four-block {
  flex-wrap: wrap;
  gap: 20px;
  justify-content: start;
}
.p-four-block__box {
  position: relative;
  width: calc((100% - 60px) / 4);
}
@media screen and (max-width: 980px) {
  .p-four-block__box {
    width: calc((100% - 20px) / 2);
  }
}
@media screen and (max-width: 767px) {
  .p-four-block__box {
    width: 100%;
  }
}
.p-four-block a {
  display: block;
}
.p-four-block img {
  width: 100%;
}

.p-five-block {
  flex-wrap: wrap;
  gap: 12px;
  justify-content: start;
}
.p-five-block__box {
  position: relative;
  width: calc((100% - 48px) / 5);
}
@media screen and (max-width: 1280px) {
  .p-five-block__box {
    width: calc((100% - 36px) / 4);
  }
}
@media screen and (max-width: 980px) {
  .p-five-block__box {
    width: calc((100% - 24px) / 3);
  }
}
@media screen and (max-width: 767px) {
  .p-five-block__box {
    width: calc((100% - 12px) / 2);
  }
}
.p-five-block a {
  display: block;
}

/* リンクブロック */
.link-block {
  display: flex;
  gap: 0 20px;
}
@media screen and (max-width: 767px) {
  .link-block {
    flex-direction: column;
    gap: 12px 0;
  }
}
.link-block a {
  position: relative;
  display: flex;
  align-items: center;
  background: #FFFFFF;
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(51, 51, 51, 0.08);
  overflow: hidden;
}
.link-block a:hover .link-block__title {
  color: #F4A300;
  text-decoration: underline solid rgba(244, 163, 0, 0.3);
}
.link-block__image {
  max-width: 107px;
}
.link-block__text {
  padding: 20px;
}
.link-block__title {
  font-size: 1.4rem;
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 0 8px;
  text-decoration: underline solid rgba(51, 51, 51, 0.3);
  text-decoration-skip-ink: none;
  line-height: 1.5;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
.link-block__title::after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  background-color: #F4A300;
  mask: url("../img/ico_blank.svg") no-repeat center center/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}

/* カード一覧 */
.c-list-card {
  display: flex;
  flex-wrap: wrap;
  gap: 60px;
  justify-content: center;
}
@media screen and (max-width: 1280px) {
  .c-list-card {
    gap: 40px;
  }
}
.c-list-card__item {
  width: calc((100% - 60px) / 2);
}
@media screen and (max-width: 1280px) {
  .c-list-card__item {
    width: calc((100% - 40px) / 2);
  }
}
@media screen and (max-width: 767px) {
  .c-list-card__item {
    width: 100%;
  }
}
.c-list-card__item:only-child {
  max-width: 800px;
  width: 100%;
}
.c-list-card__item .c-list-card__body {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: #FFFFFF;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(51, 51, 51, 0.08);
  overflow: hidden;
}
.c-list-card__text {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding-block: 28px 32px;
  padding-inline: 28px;
}
@media screen and (max-width: 767px) {
  .c-list-card__text {
    padding-inline: 20px;
  }
}
.c-list-card__text p {
  line-height: 2;
}
.c-list-card__text .wp-block-buttons:where(.is-layout-flex):not(:root):not(:has(.is-style-link06)):has(> :nth-child(2)) {
  gap: 12px 24px;
}
.c-list-card__text .wp-block-buttons:not(:root) {
  margin-top: auto;
}
.c-list-card__text .wp-block-buttons:not(:root).is-layout-flex {
  flex-wrap: wrap;
  gap: 12px 24px;
  justify-content: center;
  align-items: center;
}
.c-list-card__text .wp-block-buttons:not(:root).is-layout-flex > .wp-block-button {
  flex: 1 1 0;
}
.c-list-card__text .wp-block-buttons:not(:root) .is-style-link01 .wp-block-button__link {
  max-width: 100%;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .c-list-card__text .wp-block-buttons:not(:root) {
    width: 100%;
    max-width: 100%;
  }
  .c-list-card__text .wp-block-buttons:not(:root).is-layout-flex {
    flex-direction: column;
  }
  .c-list-card__text .wp-block-buttons:not(:root).is-layout-flex > .wp-block-button {
    flex: 1 1 100%;
    min-width: 0;
    width: 100%;
  }
  .c-list-card__text .wp-block-buttons:not(:root) .is-style-link01 .wp-block-button__link {
    max-width: 100%;
    width: 100%;
    overflow-wrap: break-word;
  }
  .c-list-card__text .wp-block-buttons:not(:root) .is-style-link01:nth-child(2) .wp-block-button__link {
    margin-block-start: 20px;
  }
}
.c-list-card__text .orange {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-style: normal;
  color: #F4A300;
}
.c-list-card__title {
  font-size: 3rem;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-style: normal;
  margin-block-end: 20px;
  text-align: center;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  line-height: 1.5;
}
@media screen and (max-width: 1280px) {
  .c-list-card__title {
    font-size: 2.2rem;
  }
}

/* メニュー一覧 */
.c-list-menu {
  padding-block: 28px;
  background: #FFFFFF;
}
.c-list-menu__nav {
  margin-block-end: 18px;
}
.c-list-menu__nav > li {
  background: #FFFFFF;
  border-radius: 4px;
}
.c-list-menu__nav > li > a {
  font-size: 1.8rem;
  font-weight: bold;
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 15px;
  line-height: 1.5;
}
.c-list-menu__nav > li > a::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 22px;
  width: 6px;
  height: 9px;
  background: url("../img/ico_arrow_right.svg") no-repeat center center/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  translate: 0 -50%;
}
.c-list-menu__child li:last-child {
  padding-block-end: 8px;
}
.c-list-menu__child a {
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 0 8px;
  padding-block: 8px;
  padding-inline: 32px;
  text-decoration: underline solid rgba(51, 51, 51, 0.3);
  text-decoration-skip-ink: none;
  line-height: 1.5;
}
.c-list-menu__child a::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 4px;
  background: #F4A300;
  border-radius: 100%;
}
.c-list-menu__child a:hover {
  color: #F4A300;
  text-decoration: underline solid rgba(244, 163, 0, 0.3);
}
.c-list-menu .accordion-menu > div,
.c-list-menu .accordion-menu > a {
  position: relative;
  padding: 10px 15px;
  cursor: pointer;
  transition: max-height 0.3s ease;
}
.c-list-menu .accordion-menu > div::after,
.c-list-menu .accordion-menu > a::after {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  position: absolute;
  top: calc(50% + 1px);
  right: 15px;
  background: url("../img/ico_plus.svg") no-repeat top right/contain;
  transform-origin: top right;
  translate: 0 -50%;
}
.c-list-menu .accordion-menu.is-active > div::after, .c-list-menu .accordion-menu.is-active > a::after {
  width: 20px;
  height: 20px;
  background: url("../img/ico_minus.svg") no-repeat top right/contain;
}
.c-list-menu .accordion-menu .c-list-menu__child {
  visibility: hidden;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, opacity 0.3s ease, visibility 0.3s ease;
}
.c-list-menu .accordion-menu .c-list-menu__child.is-open {
  visibility: visible;
  opacity: 1;
}

/* お知らせ一覧 */
.c-list-news {
  display: flex;
  flex-direction: column;
  border-top: 1px solid #E6DACA;
}
.c-list-news__post a {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0 20px;
  width: 100%;
  padding-block: 16px;
  padding-inline-end: 40px;
  border-bottom: 1px solid #E6DACA;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-list-news__post a {
    align-items: initial;
    flex-direction: column;
    gap: 0;
    padding-block: 12px;
  }
}
.c-list-news__post a::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 8px;
  height: 14px;
  background: url("../img/ico_arrow_right.svg") no-repeat center center/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  translate: 0 -50%;
}
@media screen and (max-width: 767px) {
  .c-list-news__post a::after {
    right: 0;
  }
}
.c-list-news__post a:hover .c-list-news__post-title {
  color: #F4A300;
  text-decoration: underline solid rgba(244, 163, 0, 0.3);
}
.c-list-news__post-date-area {
  display: flex;
  align-items: center;
  gap: 0 20px;
}
@media screen and (max-width: 767px) {
  .c-list-news__post-date-area {
    gap: 0 12px;
  }
}
.c-list-news__post-date {
  font-family: "Roboto", sans-serif;
  font-weight: 400;
  font-optical-sizing: auto;
  font-style: normal;
  display: inline-block;
  color: #AAAAAA;
}
.c-list-news__post-title {
  font-weight: 500;
  display: inline-block;
  margin-block-start: -4px;
  text-decoration: underline solid rgba(51, 51, 51, 0.3);
  text-decoration-skip-ink: none;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
@media screen and (max-width: 767px) {
  .c-list-news__post-title {
    margin-block-start: 0;
  }
}

/* SNS一覧 */
.c-list-sns {
  display: flex;
  justify-content: end;
  align-self: center;
  gap: 0 12px;
}
@media screen and (max-width: 1199px) {
  .c-list-sns {
    justify-content: center;
  }
}
.c-list-sns li a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  background: #FFFFFF;
  border-radius: 100%;
  box-shadow: 0 4px 20px rgba(51, 51, 51, 0.08);
}
.c-list-sns li a:hover {
  opacity: 0.8;
}

/* さぽーと一覧 */
.c-list-support.p-page-link.p-three-block .p-three-block__image img {
  object-position: top center;
}
@media screen and (max-width: 767px) {
  .c-list-support.p-page-link.p-three-block .p-three-block__image img {
    object-position: top left;
  }
}

/* Google Map埋め込み　*/
.c-map iframe {
  max-width: 100%;
  width: 100%;
  margin-inline: auto;
}

/* オーバーレイメニュー */
.menu-btn {
  display: none;
  position: fixed;
  top: 0;
  right: 10px;
  width: 48px;
  height: 82px;
  cursor: pointer;
  text-align: center;
  z-index: 5;
}
@media screen and (max-width: 980px) {
  .menu-btn {
    display: block;
  }
}
.menu-btn__line {
  font-size: 0;
  position: absolute;
  top: 26px;
  left: 50%;
  width: 20px;
  height: 12px;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  translate: -50% 0;
  z-index: 5;
}
.menu-btn__line::before, .menu-btn__line::after {
  position: absolute;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background: #333333;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
.menu-btn__line::before {
  top: 0;
}
.menu-btn__line::after {
  bottom: 0;
}
.menu-btn__label {
  font-size: 1.2rem;
  font-weight: bold;
  display: inline-block;
  margin-block-start: 26px;
}
.menu-btn__label::after {
  display: inline-block;
  content: "メニュー";
  letter-spacing: -0.2em;
}

/* ハンバーガーメニューのアニメーション */
#js-sideMenuBtn.is-active .menu-btn__line::before {
  transform: translateY(5px) rotate(-45deg);
}
#js-sideMenuBtn.is-active .menu-btn__line::after {
  transform: translateY(-5px) rotate(45deg);
}
#js-sideMenuBtn.is-active .menu-btn__label::after {
  content: "閉じる";
  letter-spacing: -0.1em;
}

/* オーバーレイ */
.is-fixed {
  position: fixed;
  width: 100%;
  height: 100%;
}

.overlay {
  position: fixed;
  top: 0;
  display: none;
  width: 100%;
  height: 100%;
  background: #FCF4E8;
  opacity: 0;
  overflow-y: auto;
  pointer-events: none;
  transition: all 0.3s ease;
  visibility: hidden;
  -webkit-overflow-scrolling: touch;
  z-index: 4;
}
.overlay.is-visible {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}
@media screen and (min-width: 981px) {
  .overlay.is-visible {
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
  }
}
.overlay .header {
  position: relative;
  top: initial;
  z-index: initial;
  background: none;
}
.overlay__header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #FFFFFF;
  z-index: 2;
}
.overlay__contents {
  padding-block-start: 104px;
  z-index: 0;
}
@media screen and (max-width: 1280px) {
  .overlay__contents {
    padding-block-start: 114px;
  }
}
@media screen and (max-width: 980px) {
  .overlay__contents {
    padding-block-start: 82px;
  }
}
.overlay__action {
  padding: 20px 0;
  background: #FCF4E8;
}
.overlay__action .c-contact-block {
  width: 94%;
  margin-block-end: 20px;
  margin-inline: auto;
}
.overlay__action .c-btn-area {
  position: relative;
  top: initial;
  left: initial;
  width: 94%;
  margin-inline: auto;
  padding: 0;
  z-index: initial;
}
.overlay__links {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
  justify-content: center;
  padding: 20px;
}
.overlay__links .wp-block-buttons:where(.is-layout-flex):not(:root):not(:has(.is-style-link06)):has(> :nth-child(2)) {
  gap: 0 20px;
}
.overlay__links .wp-block-buttons:where(.is-layout-flex.vertical):not(:root):not(:has(.is-style-link06)):has(> :nth-child(2)) {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
}
.overlay__links .wp-block-buttons.is-layout-flex {
  display: flex;
  flex-wrap: nowrap;
  gap: 0 20px;
}
@media screen and (max-width: 767px) {
  .overlay__links .wp-block-buttons.is-layout-flex {
    display: flex;
  }
}
@media screen and (max-width: 1199px) {
  .overlay__links .wp-block-buttons.is-layout-flex .is-style-link01,
  .overlay__links .wp-block-buttons.is-layout-flex .is-style-link09,
  .overlay__links .wp-block-buttons.is-layout-flex .is-style-link10,
  .overlay__links .wp-block-buttons.is-layout-flex .is-style-link11 {
    display: block;
    max-width: 280px;
    margin-inline: 0;
  }
}
@media screen and (max-width: 767px) {
  .overlay__links .wp-block-buttons.is-layout-flex .is-style-link01,
  .overlay__links .wp-block-buttons.is-layout-flex .is-style-link09,
  .overlay__links .wp-block-buttons.is-layout-flex .is-style-link10,
  .overlay__links .wp-block-buttons.is-layout-flex .is-style-link11 {
    max-width: 100%;
    width: 100%;
  }
}
.overlay__links .wp-block-buttons.is-layout-flex .is-style-link09 .wp-block-button__link,
.overlay__links .wp-block-buttons.is-layout-flex .is-style-link11 .wp-block-button__link {
  margin-block-start: 0;
}

.page-title {
  font-size: 3.2rem;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-style: normal;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 1199px) {
  .page-title {
    font-size: 2.4rem;
  }
}

/* ページ */
.contents__wrap > * + *,
.wp-block-column > * + *,
.page-main > * + * {
  margin-block-start: 1em;
}
.contents__wrap > .wp-block-buttons + .wp-block-buttons,
.wp-block-column > .wp-block-buttons + .wp-block-buttons,
.page-main > .wp-block-buttons + .wp-block-buttons {
  margin-block-start: 0;
}

.contents__wrap--2col {
  display: flex;
  gap: 60px;
  align-items: flex-start;
}
.contents__wrap--2col .page-sidebar {
  order: 1;
}
.contents__wrap--2col .page-main {
  order: 2;
}
@media screen and (max-width: 767px) {
  .contents__wrap--2col {
    flex-direction: column;
    align-items: stretch;
  }
  .contents__wrap--2col .page-main {
    order: 1;
    flex: initial;
    width: 100%;
    min-width: 0;
  }
  .contents__wrap--2col .page-sidebar {
    order: 2;
    position: relative;
    top: initial;
    width: 100%;
    flex: initial;
  }
}

.page-sidebar {
  position: sticky;
  top: 106px;
  flex: 0 0 260px;
  border: 1px solid #E6DACA;
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(51, 51, 51, 0.08);
  overflow: hidden;
}
@media screen and (max-width: 980px) {
  .page-sidebar {
    top: 58px;
  }
}
@media screen and (max-width: 767px) {
  .page-sidebar {
    position: relative;
    top: initial;
    width: 100%;
    flex: 0 0 auto;
  }
}

.page-main {
  flex: 1 1 auto;
  min-width: 0;
}

.page-main--full {
  width: 100%;
}

.page-sidebar__item:not(:last-child) {
  border-bottom: 1px solid #E6DACA;
}
.page-sidebar__item.current .page-sidebar__link {
  color: #F4A300;
}

.page-sidebar__item--group .page-sidebar__link {
  font-size: 1.8rem;
  display: inline-flex;
  align-items: center;
  gap: 0 8px;
  background-color: #FCF4E8;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .page-sidebar__item--group .page-sidebar__link {
    font-size: 1.6rem;
  }
}
.page-sidebar__item--group .page-sidebar__link::after {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background-color: #F4A300;
  mask: url("../img/ico_arrow-right-circle_01.svg") no-repeat;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}

.page-sidebar__item--sibling .page-sidebar__link {
  font-size: 1.8rem;
  background-color: #FFFFFF;
}
@media screen and (max-width: 767px) {
  .page-sidebar__item--sibling .page-sidebar__link {
    font-size: 1.6rem;
  }
}

.page-sidebar__item--bullet .page-sidebar__link {
  justify-content: flex-start;
  padding-inline-start: 30px;
  font-size: 1.6rem;
}
@media screen and (max-width: 767px) {
  .page-sidebar__item--bullet .page-sidebar__link {
    font-size: 1.4rem;
  }
}
.page-sidebar__item--bullet .page-sidebar__link::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-inline-end: 12px;
  background: rgba(244, 163, 0, 0.7);
  border-radius: 100%;
  flex: 0 0 8px;
}
.page-sidebar__item--bullet .page-sidebar__link::after {
  content: none;
}

.page-sidebar__link {
  position: relative;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  min-width: 0;
  width: 100%;
  padding: 16px;
  color: #333333;
  line-height: 1.5;
  overflow-wrap: anywhere;
}
@media screen and (max-width: 767px) {
  .page-sidebar__link {
    padding: 12px;
  }
}
.page-sidebar__link::after {
  content: "";
  display: inline-block;
  flex-shrink: 0;
  width: 8px;
  height: 14px;
  margin-block-start: -2px;
  margin-inline-start: auto;
  margin-inline-end: 4px;
  background-color: #F4A300;
  mask: url("../img/ico_arrow_right.svg") no-repeat;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
.page-sidebar__link:hover {
  color: #F4A300;
}

/* ページャー */
.c-pager {
  position: relative;
  margin-block-start: 40px;
}
.c-pager__wrap {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .c-pager__wrap {
    flex-direction: column-reverse;
    flex-wrap: wrap;
    gap: 12px 0;
  }
}
.c-pager__wrap > a,
.c-pager__wrap > span {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 36px;
  height: 36px;
  text-align: center;
  border: 1px solid #E6DACA;
  border-radius: 100%;
}
.c-pager__wrap > a + a,
.c-pager__wrap > a + span,
.c-pager__wrap > span + a,
.c-pager__wrap > span + span {
  margin-inline-start: 12px;
}
.c-pager__wrap a {
  color: #333333;
  cursor: pointer;
}
.c-pager__wrap .current {
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-optical-sizing: auto;
  font-style: normal;
  background: #FCF4E8;
  border: none;
}
@media screen and (max-width: 767px) {
  .c-pager .page-numbers {
    display: none;
  }
}
.c-pager a.page-numbers:not(.next):not(.prev) {
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-optical-sizing: auto;
  font-style: normal;
}
.c-pager a.page-numbers:not(.next):not(.prev):hover {
  border-color: #F4A300;
  color: #F4A300;
}
.c-pager .next,
.c-pager .prev {
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 160px;
  height: auto;
  margin-block-start: 4px;
  padding-block-end: 8px;
  border: none;
  border-bottom: 1px solid #E6DACA;
  border-radius: 0;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-pager .next,
  .c-pager .prev {
    display: block;
    width: 100%;
    margin-block-start: 0;
    background: #FFFFFF;
    border: 1px solid #E6DACA;
    border-radius: 100vh;
    text-align: center;
  }
}
.c-pager .next:hover,
.c-pager .prev:hover {
  border-color: #F4A300;
  color: #F4A300;
}
.c-pager .next {
  position: absolute;
  top: 50%;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-left: auto;
  color: #333333;
  text-align: right;
  translate: 0 -50%;
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .c-pager .next {
    position: relative;
    top: initial;
    right: initial;
    display: block;
    padding: 15px;
    text-align: center;
    translate: 0;
  }
}
.c-pager .next::after {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-block-start: -2px;
  margin-inline-end: 12px;
  background-color: #F4A300;
  mask: url("../img/ico_arrow-right-circle_01.svg") no-repeat;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
@media screen and (max-width: 767px) {
  .c-pager .next::after {
    display: inline-block;
    position: absolute;
    top: 52%;
    right: 20px;
    margin-inline-end: 0;
    translate: 0 -50%;
    transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
    transform-origin: top right;
  }
}
.c-pager .prev {
  position: absolute;
  top: 50%;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-right: auto;
  color: #333333;
  translate: 0 -50%;
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .c-pager .prev {
    position: relative;
    top: initial;
    left: initial;
    display: block;
    padding: 15px;
    translate: 0;
  }
}
.c-pager .prev::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-block-start: -2px;
  margin-inline-start: 12px;
  background-color: #F4A300;
  mask: url("../img/ico_arrow-right-circle_01.svg") no-repeat;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  scale: -1 1;
}
@media screen and (max-width: 767px) {
  .c-pager .prev::before {
    display: inline-block;
    position: absolute;
    top: 52%;
    left: 40px;
    margin-inline-start: 0;
    translate: 0 -50%;
    transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
    transform-origin: top left;
  }
}

/* 電話番号　*/
.c-phone-number {
  display: flex;
  align-items: center;
}
.c-phone-number__number {
  font-size: 2.8rem;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-optical-sizing: auto;
  font-style: normal;
  position: relative;
  display: flex;
  width: fit-content;
  align-items: center;
  gap: 0 12px;
  white-space: nowrap;
}
.c-phone-number__number::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background: url("../img/ico_phone_01.svg") no-repeat center center/contain;
}
.c-phone-number__label {
  font-size: 1.8rem;
  font-weight: bold;
  font-family: "Zen Kaku Gothic New", "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

a.c-phone-number {
  cursor: pointer;
}

/* プラグイン */
/* Splide */
.splide__pagination {
  position: relative;
  top: initial;
  right: initial;
  bottom: initial;
  left: initial;
  gap: 0 8px;
  justify-content: center;
  margin: 0 auto;
  padding: 0;
  z-index: 2;
}
.splide__pagination__page {
  display: inline-block;
  position: relative;
  width: 12px;
  height: 12px;
  margin: 0;
  padding: 0;
  background: #FFFFFF;
  border: 2px solid #F4A300;
  opacity: 1;
}
.splide__pagination__page.is-active {
  background: #F4A300;
  transform: scale(1);
}
.splide__arrows {
  display: flex;
  align-items: center;
  justify-content: end;
  gap: 0 20px;
  max-width: 1200px;
  margin-bottom: 20px;
}
@media screen and (max-width: 1280px) {
  .splide__arrows {
    width: 97%;
  }
}
.splide__arrow {
  position: relative;
  top: initial;
  transform: translateY(0%);
  width: 36px;
  height: 36px;
  border-radius: 100%;
  box-shadow: 0 4px 20px rgba(244, 163, 0, 0.4);
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  opacity: 1;
  overflow: hidden;
}
.splide__arrow::after {
  content: "";
  display: inline-block;
  width: 36px;
  height: 36px;
  background: url("../img/ico_arrow-right-circle_03.svg") no-repeat center/contain;
  border-radius: 100%;
}
.splide__arrow:hover:not(:disabled) {
  opacity: 1;
}
.splide__arrow svg {
  display: none;
}
.splide__arrow--prev {
  left: initial;
  scale: -1;
}
.splide__arrow--next {
  right: initial;
}
.splide img {
  width: 100%;
}

/* MVスライダー */
.mv .splide__pagination {
  display: flex;
  position: absolute;
  bottom: 28px;
  left: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  .mv .splide__pagination {
    bottom: 20px;
  }
}
.mv .splide__pagination__page {
  background: none;
  border: 2px solid #FFFFFF;
}
.mv .splide__pagination__page.is-active {
  background: #FFFFFF;
}

/* コース一覧スライダー（SP のみ。PC はグリッド表示のためページネーション非表示） */
@media screen and (max-width: 767px) {
  #course-section #slider2.course.splide .splide__track {
    padding-block-end: 28px;
  }
  #course-section #slider2.course.splide .splide__pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    padding: 0 16px;
    gap: 0 8px;
    position: relative;
    inset: auto;
    bottom: auto;
    left: auto;
    right: auto;
    pointer-events: none;
  }
  #course-section #slider2.course.splide .splide__pagination li {
    pointer-events: auto;
    display: inline-block;
    margin: 0;
    list-style-type: none;
  }
}

/* 投稿 */
.post .is-style-headline03 + div {
  display: flex;
  align-items: center;
  gap: 0 12px;
}
.post__content * + * {
  margin-block-start: 20px;
}
.post__thumbnail {
  margin: 0 auto 40px;
  text-align: center;
}
.post__thumbnail img {
  border-radius: 8px;
  overflow: hidden;
}
.post .c-badge {
  width: auto;
}

/* スケジュールブロック　*/
.c-schedule-block {
  display: flex;
  flex-direction: column;
  gap: 12px 0;
}
.c-schedule-block .c-list-desc {
  font-weight: bold;
  width: fit-content;
  margin-inline: auto;
  padding-inline-start: 12px;
  border-left: 3px solid #F4A300;
  line-height: 1.75;
}
.c-schedule-block .c-list-desc__wrap {
  display: flex;
  gap: 0 16px;
}
.c-schedule-block .c-list-desc dt {
  min-width: 65px;
  color: #F4A300;
}
.c-schedule-block .c-list-desc dd {
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-optical-sizing: auto;
  font-style: normal;
}
.c-schedule-block .wp-block-buttons:where(.is-layout-flex):not(:root):not(:has(.is-style-link06)):has(> :nth-child(2)) {
  justify-content: center;
  gap: 0 20px;
}
@media screen and (max-width: 980px) {
  .c-schedule-block .wp-block-buttons:where(.is-layout-flex):not(:root):not(:has(.is-style-link06)):has(> :nth-child(2)) {
    display: flex;
  }
}
.c-schedule-block .wp-block-buttons:where(.is-layout-flex):not(:root):not(:has(.is-style-link06)) .is-style-link09 {
  flex: 1 1 0;
}
.c-schedule-block .wp-block-buttons:where(.is-layout-flex):not(:root):not(:has(.is-style-link06)) .is-style-link09 .wp-block-button__link {
  max-width: 180px;
  width: 100%;
  margin-block-start: 0;
  padding: 4px;
  text-align: center;
  white-space: nowrap;
}
@media screen and (max-width: 980px) {
  .c-schedule-block .wp-block-buttons:where(.is-layout-flex):not(:root):not(:has(.is-style-link06)) .is-style-link09 .wp-block-button__link {
    max-width: 100%;
  }
}

.section-title {
  font-size: 3.2rem;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-style: normal;
  position: relative;
  display: flex;
  align-items: center;
  gap: 0 12px;
  margin-block-end: 28px;
  letter-spacing: 0.04em;
  line-height: 1.5;
}
@media screen and (max-width: 1199px) {
  .section-title {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .section-title {
    display: block;
    text-align: center;
  }
}
.section-title::after {
  content: attr(data-title);
  font-size: 1.6rem;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-optical-sizing: auto;
  font-style: normal;
  display: inline-block;
  margin-block-start: 4px;
  color: #F4A300;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 1199px) {
  .section-title::after {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .section-title::after {
    display: block;
  }
}
.section-title.center {
  flex-direction: column;
  gap: 4px 0;
  justify-content: center;
  text-align: center;
}
.section-title.center::after {
  margin-block-start: 0;
}
.section-title.center-to-left {
  flex-direction: column;
  gap: 4px 0;
  justify-content: center;
  text-align: center;
}
.section-title.center-to-left::after {
  margin-block-start: 0;
}
@media screen and (max-width: 767px) {
  .section-title.center-to-left {
    flex-direction: row;
    justify-content: left;
    text-align: left;
  }
  .section-title.center-to-left::after {
    margin-inline-start: 4px;
  }
}

.section-title2 {
  font-size: 2.4rem;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-style: normal;
  margin-block-end: 28px;
  letter-spacing: 0.04em;
  line-height: 1.5;
}
@media screen and (max-width: 1199px) {
  .section-title2 {
    font-size: 2rem;
  }
}
.section-title2.center {
  text-align: center;
}
.section-title2 .orange {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-style: normal;
  color: #F4A300;
}
.section-title2 .green {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-style: normal;
  color: #7FBF2A;
}

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

.medium {
  font-weight: 500;
}

em,
.color-text {
  font-weight: bold;
  text-decoration: underline;
  text-decoration-thickness: 0.5em;
  text-decoration-color: rgba(244, 163, 0, 0.3);
  text-underline-offset: -0.2em;
  text-decoration-skip-ink: none;
}

em {
  font-style: normal;
}

.text-red {
  color: #E66A45;
}

.small-text {
  font-size: 1.2rem;
  line-height: 1.5;
}

.large-text {
  font-size: 1.8rem;
}

/* ユーティリティ */
/* ------------------------------------------------------------
   display
------------------------------------------------------------ */
.is-visible {
  display: block !important;
}

.is-hidden {
  display: none !important;
}

.visible-sp {
  display: none !important;
}
@media screen and (max-width: 767px) {
  .visible-sp {
    display: block !important;
  }
}

.hidden-sp {
  display: block !important;
}
@media screen and (max-width: 767px) {
  .hidden-sp {
    display: none !important;
  }
}

.visible-tb {
  display: none !important;
}
@media screen and (max-width: 1199px) {
  .visible-tb {
    display: block !important;
  }
}

.hidden-tb {
  display: block !important;
}
@media screen and (max-width: 1199px) {
  .hidden-tb {
    display: none !important;
  }
}

/* Container Query */
.cq-scope {
  container-type: inline-size;
}

@supports (container-type: inline-size) {
  @container (max-width: 767px) {
    .cq-scope .visible-sp {
      display: block !important;
    }
  }
  @container (min-width: 768px) {
    .cq-scope .visible-sp {
      display: none !important;
    }
  }
  @container (max-width: 767px) {
    .cq-scope .hidden-sp {
      display: none !important;
    }
  }
  @container (min-width: 768px) {
    .cq-scope .hidden-sp {
      display: block !important;
    }
  }
  @container (max-width: 1199px) {
    .cq-scope .visible-tb {
      display: block !important;
    }
  }
  @container (min-width: 1200px) {
    .cq-scope .visible-tb {
      display: none !important;
    }
  }
  @container (max-width: 1199px) {
    .cq-scope .hidden-tb {
      display: none !important;
    }
  }
  @container (min-width: 1200px) {
    .cq-scope .hidden-tb {
      display: block !important;
    }
  }
}
/* ------------------------------------------------------------
   text
------------------------------------------------------------ */
.text-left {
  text-align: left !important;
}

.text-right {
  text-align: right !important;
}

.text-center {
  text-align: center !important;
}

.text-center-to-left {
  text-align: center !important;
}
@media screen and (max-width: 767px) {
  .text-center-to-left {
    text-align: left !important;
  }
}

/* ------------------------------------------------------------
   width
------------------------------------------------------------ */
.wid0 {
  width: 0% !important;
}

.wid10 {
  width: 10% !important;
}

.wid20 {
  width: 20% !important;
}

.wid30 {
  width: 30% !important;
}

.wid40 {
  width: 40% !important;
}

.wid50 {
  width: 50% !important;
}

.wid60 {
  width: 60% !important;
}

.wid70 {
  width: 70% !important;
}

.wid80 {
  width: 80% !important;
}

.wid90 {
  width: 90% !important;
}

.wid100 {
  width: 100% !important;
}

@media screen and (max-width: 767px) {
  .spwid0 {
    width: 0% !important;
  }
}

@media screen and (max-width: 767px) {
  .spwid10 {
    width: 10% !important;
  }
}

@media screen and (max-width: 767px) {
  .spwid20 {
    width: 20% !important;
  }
}

@media screen and (max-width: 767px) {
  .spwid30 {
    width: 30% !important;
  }
}

@media screen and (max-width: 767px) {
  .spwid40 {
    width: 40% !important;
  }
}

@media screen and (max-width: 767px) {
  .spwid50 {
    width: 50% !important;
  }
}

@media screen and (max-width: 767px) {
  .spwid60 {
    width: 60% !important;
  }
}

@media screen and (max-width: 767px) {
  .spwid70 {
    width: 70% !important;
  }
}

@media screen and (max-width: 767px) {
  .spwid80 {
    width: 80% !important;
  }
}

@media screen and (max-width: 767px) {
  .spwid90 {
    width: 90% !important;
  }
}

@media screen and (max-width: 767px) {
  .spwid100 {
    width: 100% !important;
  }
}

/* ------------------------------------------------------------
   margin
------------------------------------------------------------ */
.mt0 {
  margin-top: 0 !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.mt60 {
  margin-top: 60px !important;
}

.mt70 {
  margin-top: 70px !important;
}

.mt80 {
  margin-top: 80px !important;
}

.mt90 {
  margin-top: 90px !important;
}

.mt100 {
  margin-top: 100px !important;
}

@media screen and (max-width: 767px) {
  .spmt0 {
    margin-top: 0 !important;
  }
}

@media screen and (max-width: 767px) {
  .spmt10 {
    margin-top: 10px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmt20 {
    margin-top: 20px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmt30 {
    margin-top: 30px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmt40 {
    margin-top: 40px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmt50 {
    margin-top: 50px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmt60 {
    margin-top: 60px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmt70 {
    margin-top: 70px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmt80 {
    margin-top: 80px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmt90 {
    margin-top: 90px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmt100 {
    margin-top: 100px !important;
  }
}

.mr0 {
  margin-right: 0 !important;
}

.mr10 {
  margin-right: 10px !important;
}

.mr20 {
  margin-right: 20px !important;
}

.mr30 {
  margin-right: 30px !important;
}

.mr40 {
  margin-right: 40px !important;
}

.mr50 {
  margin-right: 50px !important;
}

.mr60 {
  margin-right: 60px !important;
}

.mr70 {
  margin-right: 70px !important;
}

.mr80 {
  margin-right: 80px !important;
}

.mr90 {
  margin-right: 90px !important;
}

.mr100 {
  margin-right: 100px !important;
}

@media screen and (max-width: 767px) {
  .spmr0 {
    margin-right: 0 !important;
  }
}

@media screen and (max-width: 767px) {
  .spmr10 {
    margin-right: 10px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmr20 {
    margin-right: 20px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmr30 {
    margin-right: 30px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmr40 {
    margin-right: 40px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmr50 {
    margin-right: 50px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmr60 {
    margin-right: 60px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmr70 {
    margin-right: 70px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmr80 {
    margin-right: 80px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmr90 {
    margin-right: 90px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmr100 {
    margin-right: 100px !important;
  }
}

.mb0 {
  margin-bottom: 0 !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mb70 {
  margin-bottom: 70px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.mb90 {
  margin-bottom: 90px !important;
}

.mb100 {
  margin-bottom: 100px !important;
}

@media screen and (max-width: 767px) {
  .spmb0 {
    margin-bottom: 0 !important;
  }
}

@media screen and (max-width: 767px) {
  .spmb10 {
    margin-bottom: 10px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmb20 {
    margin-bottom: 20px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmb30 {
    margin-bottom: 30px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmb40 {
    margin-bottom: 40px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmb50 {
    margin-bottom: 50px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmb60 {
    margin-bottom: 60px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmb70 {
    margin-bottom: 70px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmb80 {
    margin-bottom: 80px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmb90 {
    margin-bottom: 90px !important;
  }
}

@media screen and (max-width: 767px) {
  .spmb100 {
    margin-bottom: 100px !important;
  }
}

.ml0 {
  margin-left: 0 !important;
}

.ml10 {
  margin-left: 10px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.ml50 {
  margin-left: 50px !important;
}

.ml60 {
  margin-left: 60px !important;
}

.ml70 {
  margin-left: 70px !important;
}

.ml80 {
  margin-left: 80px !important;
}

.ml90 {
  margin-left: 90px !important;
}

.ml100 {
  margin-left: 100px !important;
}

@media screen and (max-width: 767px) {
  .spml0 {
    margin-left: 0 !important;
  }
}

@media screen and (max-width: 767px) {
  .spml10 {
    margin-left: 10px !important;
  }
}

@media screen and (max-width: 767px) {
  .spml20 {
    margin-left: 20px !important;
  }
}

@media screen and (max-width: 767px) {
  .spml30 {
    margin-left: 30px !important;
  }
}

@media screen and (max-width: 767px) {
  .spml40 {
    margin-left: 40px !important;
  }
}

@media screen and (max-width: 767px) {
  .spml50 {
    margin-left: 50px !important;
  }
}

@media screen and (max-width: 767px) {
  .spml60 {
    margin-left: 60px !important;
  }
}

@media screen and (max-width: 767px) {
  .spml70 {
    margin-left: 70px !important;
  }
}

@media screen and (max-width: 767px) {
  .spml80 {
    margin-left: 80px !important;
  }
}

@media screen and (max-width: 767px) {
  .spml90 {
    margin-left: 90px !important;
  }
}

@media screen and (max-width: 767px) {
  .spml100 {
    margin-left: 100px !important;
  }
}

/* ------------------------------------------------------------
   padding
------------------------------------------------------------ */
.pt0 {
  padding-top: 0 !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pt60 {
  padding-top: 60px !important;
}

.pt70 {
  padding-top: 70px !important;
}

.pt80 {
  padding-top: 80px !important;
}

.pt90 {
  padding-top: 90px !important;
}

.pt100 {
  padding-top: 100px !important;
}

.pr0 {
  padding-right: 0 !important;
}

.pr10 {
  padding-right: 10px !important;
}

.pr20 {
  padding-right: 20px !important;
}

.pr30 {
  padding-right: 30px !important;
}

.pr40 {
  padding-right: 40px !important;
}

.pr50 {
  padding-right: 50px !important;
}

.pr60 {
  padding-right: 60px !important;
}

.pr70 {
  padding-right: 70px !important;
}

.pr80 {
  padding-right: 80px !important;
}

.pr90 {
  padding-right: 90px !important;
}

.pr100 {
  padding-right: 100px !important;
}

.pb0 {
  padding-bottom: 0 !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

.pb60 {
  padding-bottom: 60px !important;
}

.pb70 {
  padding-bottom: 70px !important;
}

.pb80 {
  padding-bottom: 80px !important;
}

.pb90 {
  padding-bottom: 90px !important;
}

.pb100 {
  padding-bottom: 100px !important;
}

.pl0 {
  padding-left: 0 !important;
}

.pl10 {
  padding-left: 10px !important;
}

.pl20 {
  padding-left: 20px !important;
}

.pl30 {
  padding-left: 30px !important;
}

.pl40 {
  padding-left: 40px !important;
}

.pl50 {
  padding-left: 50px !important;
}

.pl60 {
  padding-left: 60px !important;
}

.pl70 {
  padding-left: 70px !important;
}

.pl80 {
  padding-left: 80px !important;
}

.pl90 {
  padding-left: 90px !important;
}

.pl100 {
  padding-left: 100px !important;
}

/* ビデオ */
.c-video {
  position: relative;
  height: 0;
  padding: 0 0 56.5%;
  border: 8px solid #FFFFFF;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(51, 51, 51, 0.08);
  overflow: hidden;
  z-index: 1;
}
.c-video iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.c-video .start-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 68px;
  height: 68px;
  background: #F4A300;
  border-radius: 100%;
  cursor: pointer;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  transform: scale(1);
  translate: -50% -50%;
}
.c-video .start-btn:hover {
  transform: scale(1.1);
}
.c-video .start-btn img {
  max-width: 16px;
}

.wp-block-accordion-item {
  position: relative;
  display: block;
  overflow: hidden;
  border: 1px solid #F2EDE6;
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(51, 51, 51, 0.08);
}
.wp-block-accordion-item + .wp-block-accordion-item {
  margin-top: 12px;
}
.wp-block-accordion-item::after {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  position: absolute;
  top: 24px;
  right: 16px;
  background: url("../img/ico_plus.svg") no-repeat top right/contain;
  transform-origin: top right;
  z-index: 1;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .wp-block-accordion-item::after {
    top: 22px;
  }
}
.wp-block-accordion-item.is-open::after {
  background-image: url("../img/ico_minus.svg");
}
.wp-block-accordion-item.is-open .wp-block-accordion-heading__toggle::after {
  content: "";
  display: block;
  width: calc(100% - 40px);
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 20px;
  border-bottom: 1px solid #E5E3E1;
}
.wp-block-accordion-item .wp-block-accordion-heading {
  margin: 0;
}
.wp-block-accordion-item .wp-block-accordion-heading__toggle {
  font-size: 2rem;
  font-weight: bold;
  position: relative;
  display: flex;
  align-items: center;
  padding: 20px 50px 20px 20px;
  cursor: pointer;
  line-height: 1.5;
  background: transparent;
  border: none;
  width: 100%;
  text-align: left;
  color: inherit;
  font-family: inherit;
}
@media screen and (max-width: 767px) {
  .wp-block-accordion-item .wp-block-accordion-heading__toggle {
    font-size: 1.6rem;
  }
}
.wp-block-accordion-item .wp-block-accordion-heading__toggle-icon {
  display: none;
}
.wp-block-accordion-item .wp-block-accordion-heading__toggle-title {
  font-weight: bold;
  color: #333333;
}
.wp-block-accordion-item .wp-block-accordion-heading .wp-block-accordion-heading__toggle:hover .wp-block-accordion-heading__toggle-title {
  text-decoration: none;
}
.wp-block-accordion-item.js-accordion-anim .wp-block-accordion-panel[aria-hidden=true],
.wp-block-accordion-item.js-accordion-anim .wp-block-accordion-panel[inert] {
  display: block;
}
.wp-block-accordion-item .wp-block-accordion-panel {
  position: relative;
  overflow: hidden;
  padding: 0 20px;
}
@media (prefers-reduced-motion: no-preference) {
  .wp-block-accordion-item .wp-block-accordion-panel {
    transition: height 0.3s ease-out;
  }
}
@media screen and (max-width: 767px) {
  .wp-block-accordion-item .wp-block-accordion-panel {
    padding: 0 16px;
  }
}
.wp-block-accordion-item .wp-block-accordion-panel > * {
  margin: 0;
}
.wp-block-accordion-item .wp-block-accordion-panel > :first-child {
  margin-top: 20px;
}
.wp-block-accordion-item .wp-block-accordion-panel > :last-child {
  margin-bottom: 20px;
}
.wp-block-accordion-item .wp-block-accordion-panel > * + * {
  margin-top: 20px;
}
.wp-block-accordion-item .wp-block-accordion-panel p {
  word-break: break-all;
}

.c-anchor-link {
  font-size: 1.4rem;
  container-type: inline-size;
  margin-block-start: 40px;
  list-style: none;
  list-style-type: none;
}
@media screen and (max-width: 767px) {
  .c-anchor-link {
    margin-block-start: 32px;
  }
}
.c-anchor-link__wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 20px;
}
@media screen and (max-width: 980px) {
  .c-anchor-link__wrap {
    gap: 16px 12px;
  }
}
.c-anchor-link__item {
  width: calc((100% - 60px) / 4);
}
@media screen and (max-width: 980px) {
  .c-anchor-link__item {
    width: calc((100% - 12px) / 2);
  }
}
.c-anchor-link a {
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-block: 8px;
  background: none;
  border-bottom: 1px solid #E6DACA;
  border-radius: 0;
  color: #333333;
  line-height: 1.5;
}
.c-anchor-link a::after {
  content: "";
  flex-shrink: 0;
  display: block;
  width: 8px;
  height: 14px;
  margin-inline-end: 12px;
  background-color: #F4A300;
  rotate: 90deg;
  mask: url("../img/ico_arrow_right.svg") no-repeat center/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
.c-anchor-link a:hover {
  border-color: #F4A300;
  color: #F4A300;
}

.wp-block-columns.reverse {
  flex-direction: row-reverse;
}

:where(.wp-block-columns.is-layout-flex).wp-block-columns-is-layout-flex {
  gap: 28px 40px;
}

:where(.wp-block-columns).is-layout-flex {
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  :where(.wp-block-columns).is-layout-flex {
    margin-bottom: 32px;
  }
}
:where(.wp-block-columns).is-layout-flex .wp-block-image {
  margin: 0 auto;
}

:where(.wp-block-columns.is-layout-flex).wp-block-columns-is-layout-flex.is-style-gallery {
  gap: 10px;
  margin-bottom: 0;
}

.wp-block-image {
  margin: 0 auto 40px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .wp-block-image {
    text-align: center;
  }
}
.wp-block-image a:hover {
  opacity: 0.8;
}
.wp-block-image img {
  width: 100%;
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-radius: 8px;
  overflow: hidden;
}
.wp-block-image.height-auto img {
  aspect-ratio: initial;
  object-fit: initial;
}
.wp-block-image .components-resizable-box__container img {
  margin: 0 auto;
}

.wp-block-separator:not(:root) {
  margin: 28px auto;
  border-top: 2px solid #E5E3E1;
  border-bottom: none;
}

.is-style-box01, .is-style-box02, .is-style-box03 {
  position: relative;
  margin: 0 auto 32px;
  padding: 22px;
  border: 4px solid #F2EDE6;
  border-radius: 8px;
}
@media screen and (max-width: 767px) {
  .is-style-box01, .is-style-box02, .is-style-box03 {
    padding: 22px 14px;
  }
}
.is-style-box03 {
  border: 4px solid rgba(230, 106, 69, 0.15);
}

.c-flow {
  list-style: none;
  list-style-type: none;
  counter-reset: c-flow-step;
}
.c-flow > li {
  position: relative;
  counter-increment: c-flow-step;
}
.c-flow > li::after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 3px;
  height: calc(100% - 32px);
  border-right: 3px solid #F2EDE6;
  top: calc(32px - 5px);
  left: calc(32px * 0.5 - 3px * 0.5);
  height: calc(100% - 32px + 5px);
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .c-flow > li::after {
    top: calc(28px - 4px);
    left: calc(28px * 0.5 - 3px * 0.5);
    height: calc(100% - 28px + 4px);
  }
}
.c-flow > li:last-child::after {
  display: none;
}
.c-flow > li dl {
  display: flex;
  align-items: flex-start;
  margin: 0;
}
.c-flow > li dt {
  position: relative;
  z-index: 1;
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  width: 32px;
  height: 32px;
  min-width: 32px;
  margin-inline-end: 20px;
  background: rgba(244, 163, 0, 0.6);
  border-radius: 50%;
  text-align: center;
  font-variant-numeric: tabular-nums;
}
@media screen and (max-width: 767px) {
  .c-flow > li dt {
    width: 28px;
    height: 28px;
    min-width: 28px;
    margin-inline-end: 15px;
  }
}
.c-flow > li dt::before {
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: 1.4rem;
  content: counter(c-flow-step);
  line-height: 1;
  color: #333333;
}
.c-flow > li dd {
  width: 100%;
  margin-inline-start: 0;
  padding-block-end: 20px;
  padding-top: 10px;
}
@media screen and (max-width: 767px) {
  .c-flow > li dd {
    padding-top: 8px;
  }
}
.c-flow__title {
  display: block;
}
.c-flow .is-style-headline05 {
  margin-block-start: -10px;
}
@media screen and (max-width: 767px) {
  .c-flow .is-style-headline05 {
    margin: -8px 0 8px;
  }
}
.c-flow img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
}
.c-flow .p-two-block {
  gap: 0 40px;
  flex-direction: row;
}
@media screen and (max-width: 767px) {
  .c-flow .p-two-block {
    flex-direction: column;
    gap: 20px 0;
  }
}
.c-flow .p-two-block__box {
  flex: initial;
}
.c-flow .p-two-block__text {
  width: 64%;
}
@media screen and (max-width: 767px) {
  .c-flow .p-two-block__text {
    width: 100%;
  }
}
.c-flow .p-two-block__image {
  width: 36%;
}
@media screen and (max-width: 767px) {
  .c-flow .p-two-block__image {
    width: 100%;
  }
}
.c-flow .p-two-block__image img {
  border-radius: 8px;
  overflow: hidden;
}
.c-flow ul {
  margin-block: 12px 28px;
  line-height: 1.75;
  list-style: none;
  list-style-type: none;
}
.c-flow ul li {
  position: relative;
  padding-inline-start: 1.25em;
}

.wp-block-post-title {
  font-size: 3.6rem;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-style: normal;
}
@media screen and (max-width: 1199px) {
  .wp-block-post-title {
    font-size: 2.8rem;
  }
}

.is-style-default, .is-style-headline02, .is-style-headline03, .is-style-headline04, .is-style-headline04-comment-title, .is-style-headline04-alert-title, .is-style-headline05, .is-style-headline06 {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-style: normal;
  position: relative;
  line-height: 1.5;
  scroll-margin-top: 94px;
}
@media screen and (max-width: 980px) {
  .is-style-default, .is-style-headline02, .is-style-headline03, .is-style-headline04, .is-style-headline04-comment-title, .is-style-headline04-alert-title, .is-style-headline05, .is-style-headline06 {
    scroll-margin-top: 58px;
  }
}
.is-style-default a, .is-style-headline02 a, .is-style-headline03 a, .is-style-headline04 a, .is-style-headline04-comment-title a, .is-style-headline04-alert-title a, .is-style-headline05 a, .is-style-headline06 a {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-style: normal;
  text-decoration: underline solid rgba(51, 51, 51, 0.3);
  text-decoration-skip-ink: none;
}
.is-style-default a:hover, .is-style-headline02 a:hover, .is-style-headline03 a:hover, .is-style-headline04 a:hover, .is-style-headline04-comment-title a:hover, .is-style-headline04-alert-title a:hover, .is-style-headline05 a:hover, .is-style-headline06 a:hover {
  color: #F4A300;
  text-decoration: underline solid rgba(244, 163, 0, 0.3);
}
.is-style-default, .is-style-headline02 {
  font-size: 2.8rem;
  position: relative;
  margin-block: 60px 32px;
  padding-block: 12px;
  border-bottom: 2px solid #E6DACA;
}
@media screen and (max-width: 767px) {
  .is-style-default, .is-style-headline02 {
    font-size: 2.2rem;
  }
}
.is-style-default::before, .is-style-headline02::before {
  content: "";
  display: block;
  width: 15%;
  height: 2px;
  position: absolute;
  bottom: -2px;
  left: 0;
  background: #F4A300;
}
.is-style-headline03 {
  font-size: 2.4rem;
  position: relative;
  margin-block: 32px 20px;
  padding-inline-start: 32px;
}
.is-style-headline03::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 24px;
  position: absolute;
  top: 7px;
  left: 0;
  border: 3px solid rgba(244, 163, 0, 0.7);
  border-radius: 100%;
}
@media screen and (max-width: 767px) {
  .is-style-headline03::before {
    width: 20px;
    height: 20px;
    top: 6px;
  }
}
@media screen and (max-width: 767px) {
  .is-style-headline03 {
    font-size: 2rem;
    padding-inline-start: 28px;
  }
}
.is-style-headline04, .is-style-headline04-comment-title, .is-style-headline04-alert-title {
  font-size: 2.2rem;
  margin: 20px auto 12px;
  padding-block-end: 8px;
  border-bottom: 1px solid #E6DACA;
}
@media screen and (max-width: 767px) {
  .is-style-headline04, .is-style-headline04-comment-title, .is-style-headline04-alert-title {
    font-size: 1.8rem;
  }
}
.is-style-headline04.center, .is-style-headline04-comment-title.center, .is-style-headline04-alert-title.center {
  width: fit-content;
  text-align: center;
}
.is-style-headline04-comment-title, .is-style-headline04-alert-title {
  padding-inline-start: 32px;
  padding-bottom: 0;
  border-bottom: none;
}
.is-style-headline04-comment-title::before, .is-style-headline04-alert-title::before {
  display: inline-block;
  position: absolute;
  top: 0.2em;
  left: 0;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .is-style-headline04-comment-title::before, .is-style-headline04-alert-title::before {
    top: 0.1em;
  }
}
.is-style-headline04-comment-title::before {
  content: "";
  width: 24px;
  height: 24px;
  mask: url("../img/ico_chat.svg") no-repeat center center/contain;
  background-color: #7FBF2A;
}
.is-style-headline04-alert-title::before {
  content: "";
  width: 24px;
  height: 24px;
  mask: url("../img/ico_info.svg") no-repeat center center/contain;
  background-color: #E66A45;
}
.is-style-headline05 {
  font-size: 2rem;
  margin-block: 20px 8px;
}
@media screen and (max-width: 767px) {
  .is-style-headline05 {
    font-size: 1.8rem;
  }
}
.is-style-headline06 {
  font-size: 1.8rem;
  margin-block: 20px 8px;
}
@media screen and (max-width: 767px) {
  .is-style-headline06 {
    font-size: 1.6rem;
  }
}

.is-style-headline02.has-headline-step {
  display: flex;
  align-items: center;
  gap: 20px;
}
@media screen and (max-width: 767px) {
  .is-style-headline02.has-headline-step {
    gap: 15px;
  }
}
.is-style-headline02.has-headline-step .c-headline-step {
  display: inline-flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  width: 32px;
  height: 32px;
  min-width: 32px;
  background: rgba(244, 163, 0, 0.6);
  border-radius: 50%;
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: 1.4rem;
  line-height: 1;
  color: #333333;
}
@media screen and (max-width: 767px) {
  .is-style-headline02.has-headline-step .c-headline-step {
    width: 28px;
    height: 28px;
    min-width: 28px;
  }
}

.is-style-link01 .wp-block-button__link, .is-style-link02 .wp-block-button__link, .is-style-link03 .wp-block-button__link, .is-style-link04 .wp-block-button__link, .is-style-link05 .wp-block-button__link, .is-style-link07 .wp-block-button__link, .is-style-link08 .wp-block-button__link, .is-style-link09 .wp-block-button__link, .is-style-link10 .wp-block-button__link, .is-style-link11 .wp-block-button__link {
  font-size: 1.6rem;
  font-weight: bold;
  position: relative;
  display: block;
  max-width: 400px;
  width: 400px;
  margin-block-start: 32px;
  padding: 15px 32px;
  background: #FFFFFF;
  border: 1px solid #F4A300;
  border-radius: 8px;
  color: #333333;
  text-align: left;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .is-style-link01 .wp-block-button__link, .is-style-link02 .wp-block-button__link, .is-style-link03 .wp-block-button__link, .is-style-link04 .wp-block-button__link, .is-style-link05 .wp-block-button__link, .is-style-link07 .wp-block-button__link, .is-style-link08 .wp-block-button__link, .is-style-link09 .wp-block-button__link, .is-style-link10 .wp-block-button__link, .is-style-link11 .wp-block-button__link {
    display: block;
    max-width: 100%;
    width: 100%;
    margin-block-start: 28px;
    padding: 13px 40px 13px 20px;
  }
}
.is-style-link01 .wp-block-button__link::after, .is-style-link02 .wp-block-button__link::after, .is-style-link03 .wp-block-button__link::after, .is-style-link04 .wp-block-button__link::after, .is-style-link05 .wp-block-button__link::after, .is-style-link07 .wp-block-button__link::after, .is-style-link08 .wp-block-button__link::after, .is-style-link09 .wp-block-button__link::after, .is-style-link10 .wp-block-button__link::after, .is-style-link11 .wp-block-button__link::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 20px;
  height: 20px;
  background-color: #F4A300;
  mask: url("../img/ico_arrow-right-circle_01.svg") no-repeat top right/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  translate: 0 -50%;
}
.is-style-link01 .wp-block-button__link[target=_blank]::after, .is-style-link02 .wp-block-button__link[target=_blank]::after, .is-style-link03 .wp-block-button__link[target=_blank]::after, .is-style-link04 .wp-block-button__link[target=_blank]::after, .is-style-link05 .wp-block-button__link[target=_blank]::after, .is-style-link07 .wp-block-button__link[target=_blank]::after, .is-style-link08 .wp-block-button__link[target=_blank]::after, .is-style-link09 .wp-block-button__link[target=_blank]::after, .is-style-link10 .wp-block-button__link[target=_blank]::after, .is-style-link11 .wp-block-button__link[target=_blank]::after {
  mask: url("../img/ico_blank_circle_01.svg") no-repeat top right/contain;
}
.is-style-link01 .wp-block-button__link:hover, .is-style-link02 .wp-block-button__link:hover, .is-style-link03 .wp-block-button__link:hover, .is-style-link04 .wp-block-button__link:hover, .is-style-link05 .wp-block-button__link:hover, .is-style-link07 .wp-block-button__link:hover, .is-style-link08 .wp-block-button__link:hover, .is-style-link09 .wp-block-button__link:hover, .is-style-link10 .wp-block-button__link:hover, .is-style-link11 .wp-block-button__link:hover {
  color: #F4A300;
}
.is-style-link02 .wp-block-button__link::after {
  content: "";
  width: 20px;
  height: 20px;
  background-color: #F4A300;
  mask: url("../img/ico_blank_circle_01.svg") no-repeat top right/contain;
}
.is-style-link03 .wp-block-button__link::after, .is-style-link03 .wp-block-button__link[target=_blank]::after, .is-style-link04 .wp-block-button__link::after, .is-style-link04 .wp-block-button__link[target=_blank]::after, .is-style-link05 .wp-block-button__link::after, .is-style-link05 .wp-block-button__link[target=_blank]::after {
  width: 13px;
  height: 16px;
  background-color: #F4A300;
  mask: url("../img/ico_file.svg") no-repeat top right/contain;
}
.is-style-link03 .wp-block-button__link::after, .is-style-link03 .wp-block-button__link[target=_blank]::after {
  background-color: #E66A45;
}
.is-style-link04 .wp-block-button__link::after, .is-style-link04 .wp-block-button__link[target=_blank]::after {
  background-color: #397CBF;
}
.is-style-link05 .wp-block-button__link::after, .is-style-link05 .wp-block-button__link[target=_blank]::after {
  background-color: #7FBF2A;
}
.is-style-link06 .wp-block-button__link {
  font-size: 1.6rem;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-block-start: 32px;
  padding: 0 0 8px;
  background: none;
  border-bottom: 1px solid #E6DACA;
  border-radius: 0;
  color: #333333;
  line-height: 1.5;
}
.is-style-link06 .wp-block-button__link::after {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-block-start: -2px;
  margin-inline-end: 12px;
  background-color: #F4A300;
  mask: url("../img/ico_arrow-right-circle_01.svg") no-repeat;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
.is-style-link06 .wp-block-button__link[target=_blank]::after {
  mask: url("../img/ico_blank_circle_01.svg") no-repeat;
}
.is-style-link06 .wp-block-button__link:hover {
  border-color: #F4A300;
  color: #F4A300;
}
.is-style-link07 .wp-block-button__link {
  box-shadow: 0 4px 20px rgba(51, 51, 51, 0.08);
}
.is-style-link07 .wp-block-button__link.shadowless {
  box-shadow: none;
}
.is-style-link07 .wp-block-button__link.arrowless::after {
  display: none;
}
.is-style-link08 .wp-block-button__link {
  font-size: 2rem;
  max-width: 480px;
  width: 480px;
  padding: 26px 20px;
  border-radius: 8px;
}
@media screen and (max-width: 767px) {
  .is-style-link08 .wp-block-button__link {
    font-size: 1.6rem;
    max-width: 100%;
    width: 100%;
    padding: 19px 20px;
  }
}
.is-style-link09 .wp-block-button__link {
  background: #F4A300;
  border: none;
  box-shadow: 0 4px 20px rgba(244, 163, 0, 0.4);
  color: #FFFFFF;
}
.is-style-link09 .wp-block-button__link::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 20px;
  height: 20px;
  background-color: #FCF4E8;
  mask: url("../img/ico_arrow-right-circle_01.svg") no-repeat top right/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  translate: 0 -50%;
}
.is-style-link09 .wp-block-button__link:hover {
  color: #FFFFFF;
  opacity: 0.8;
}
.is-style-link09 .wp-block-button__link.fit-content {
  padding: 15px 70px 15px 32px;
}
.is-style-link09 .wp-block-button__link.shadowless {
  box-shadow: none;
}
.is-style-link09 .wp-block-button__link.arrowless::after {
  display: none;
}
.is-style-link10 .wp-block-button__link {
  background: #47B3B3;
  border: none;
  box-shadow: 0 4px 20px rgba(71, 179, 179, 0.4);
  color: #FFFFFF;
}
.is-style-link10 .wp-block-button__link::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 20px;
  height: 20px;
  background-color: #FCF4E8;
  mask: url("../img/ico_arrow-right-circle_01.svg") no-repeat top right/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  translate: 0 -50%;
}
.is-style-link10 .wp-block-button__link:hover {
  color: #FFFFFF;
  opacity: 0.8;
}
.is-style-link10 .wp-block-button__link.fit-content {
  padding: 15px 70px 15px 32px;
}
.is-style-link10 .wp-block-button__link.shadowless {
  box-shadow: none;
}
.is-style-link10 .wp-block-button__link.arrowless::after {
  display: none;
}
.is-style-link11 .wp-block-button__link {
  background: #7FBF2A;
  border: none;
  box-shadow: 0 4px 20px rgba(127, 191, 42, 0.4);
  color: #FFFFFF;
}
.is-style-link11 .wp-block-button__link::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 20px;
  height: 20px;
  background-color: #FCF4E8;
  mask: url("../img/ico_arrow-right-circle_01.svg") no-repeat top right/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  translate: 0 -50%;
}
.is-style-link11 .wp-block-button__link:hover {
  color: #FFFFFF;
  opacity: 0.8;
}
.is-style-link11 .wp-block-button__link.fit-content {
  padding: 15px 70px 15px 32px;
}
.is-style-link11 .wp-block-button__link.shadowless {
  box-shadow: none;
}
.is-style-link11 .wp-block-button__link.arrowless::after {
  display: none;
}

.wp-block-buttons > .wp-block-button.is-style-link08 {
  display: block;
}

.wp-block-buttons:not(:root) .is-style-link01 .wp-block-button__link,
.wp-block-buttons:not(:root) .is-style-link02 .wp-block-button__link,
.wp-block-buttons:not(:root) .is-style-link03 .wp-block-button__link,
.wp-block-buttons:not(:root) .is-style-link04 .wp-block-button__link,
.wp-block-buttons:not(:root) .is-style-link05 .wp-block-button__link,
.wp-block-buttons:not(:root) .is-style-link07 .wp-block-button__link,
.wp-block-buttons:not(:root) .is-style-link09 .wp-block-button__link,
.wp-block-buttons:not(:root) .is-style-link10 .wp-block-button__link,
.wp-block-buttons:not(:root) .is-style-link11 .wp-block-button__link {
  max-width: 400px;
  width: 400px;
}
@media screen and (max-width: 767px) {
  .wp-block-buttons:not(:root) .is-style-link01 .wp-block-button__link,
  .wp-block-buttons:not(:root) .is-style-link02 .wp-block-button__link,
  .wp-block-buttons:not(:root) .is-style-link03 .wp-block-button__link,
  .wp-block-buttons:not(:root) .is-style-link04 .wp-block-button__link,
  .wp-block-buttons:not(:root) .is-style-link05 .wp-block-button__link,
  .wp-block-buttons:not(:root) .is-style-link07 .wp-block-button__link,
  .wp-block-buttons:not(:root) .is-style-link09 .wp-block-button__link,
  .wp-block-buttons:not(:root) .is-style-link10 .wp-block-button__link,
  .wp-block-buttons:not(:root) .is-style-link11 .wp-block-button__link {
    max-width: 100%;
    width: 100%;
  }
}
.wp-block-buttons:not(:root) .is-style-link06 .wp-block-button__link {
  max-width: 180px;
  width: 180px;
}
.wp-block-buttons:not(:root) .is-style-link08 .wp-block-button__link {
  max-width: 480px;
  width: 480px;
}
@media screen and (max-width: 767px) {
  .wp-block-buttons:not(:root) .is-style-link08 .wp-block-button__link {
    max-width: 100%;
    width: 100%;
  }
}
.wp-block-buttons:not(:root) .is-style-link11 .wp-block-button__link.fit-content {
  max-width: 100%;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .wp-block-buttons:not(:root) .is-style-link11 .wp-block-button__link.fit-content {
    padding: 15px 20px;
  }
}

.wp-block-columns.is-layout-flex > .wp-block-column {
  min-width: 0;
}

.wp-block-columns .wp-block-buttons:not(:root) .is-style-link01 .wp-block-button__link,
.wp-block-columns .wp-block-buttons:not(:root) .is-style-link02 .wp-block-button__link,
.wp-block-columns .wp-block-buttons:not(:root) .is-style-link03 .wp-block-button__link,
.wp-block-columns .wp-block-buttons:not(:root) .is-style-link04 .wp-block-button__link,
.wp-block-columns .wp-block-buttons:not(:root) .is-style-link05 .wp-block-button__link,
.wp-block-columns .wp-block-buttons:not(:root) .is-style-link06 .wp-block-button__link,
.wp-block-columns .wp-block-buttons:not(:root) .is-style-link07 .wp-block-button__link,
.wp-block-columns .wp-block-buttons:not(:root) .is-style-link08 .wp-block-button__link,
.wp-block-columns .wp-block-buttons:not(:root) .is-style-link09 .wp-block-button__link,
.wp-block-columns .wp-block-buttons:not(:root) .is-style-link10 .wp-block-button__link,
.wp-block-columns .wp-block-buttons:not(:root) .is-style-link11 .wp-block-button__link {
  max-width: 100%;
  width: 100%;
  overflow-wrap: break-word;
}
@media screen and (max-width: 767px) {
  .wp-block-columns .wp-block-buttons:not(:root) .is-style-link01 .wp-block-button__link,
  .wp-block-columns .wp-block-buttons:not(:root) .is-style-link02 .wp-block-button__link,
  .wp-block-columns .wp-block-buttons:not(:root) .is-style-link03 .wp-block-button__link,
  .wp-block-columns .wp-block-buttons:not(:root) .is-style-link04 .wp-block-button__link,
  .wp-block-columns .wp-block-buttons:not(:root) .is-style-link05 .wp-block-button__link,
  .wp-block-columns .wp-block-buttons:not(:root) .is-style-link06 .wp-block-button__link,
  .wp-block-columns .wp-block-buttons:not(:root) .is-style-link07 .wp-block-button__link,
  .wp-block-columns .wp-block-buttons:not(:root) .is-style-link08 .wp-block-button__link,
  .wp-block-columns .wp-block-buttons:not(:root) .is-style-link09 .wp-block-button__link,
  .wp-block-columns .wp-block-buttons:not(:root) .is-style-link10 .wp-block-button__link,
  .wp-block-columns .wp-block-buttons:not(:root) .is-style-link11 .wp-block-button__link {
    margin-block-start: 0;
  }
}

.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons {
  flex: 1 1 auto;
  align-self: stretch;
  width: 100%;
  min-height: 0;
  align-items: stretch;
}
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link01,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link02,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link03,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link04,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link05,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link06,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link07,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link08,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link09,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link10,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link11 {
  flex: 1 1 auto;
  align-self: stretch;
  display: flex;
  min-width: 0;
  min-height: 0;
}
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link01 .wp-block-button__link,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link02 .wp-block-button__link,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link03 .wp-block-button__link,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link04 .wp-block-button__link,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link05 .wp-block-button__link,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link07 .wp-block-button__link,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link08 .wp-block-button__link,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link09 .wp-block-button__link,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link10 .wp-block-button__link,
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link11 .wp-block-button__link {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 100%;
}
.wp-block-columns.is-layout-flex > .wp-block-column:has(> .wp-block-buttons:only-child) > .wp-block-buttons > .wp-block-button.is-style-link06 .wp-block-button__link {
  flex: 1 1 auto;
  min-height: 100%;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .wp-block-buttons:where(.is-layout-flex):not(:root):not(:has(.is-style-link06)) {
    display: block;
  }
}
.wp-block-buttons:where(.is-layout-flex):not(:root):not(:has(.is-style-link06)):has(> :nth-child(2)) {
  gap: 0 60px;
}
@media screen and (max-width: 767px) {
  .wp-block-buttons:where(.is-layout-flex):not(:root):not(:has(.is-style-link06)) > .wp-block-button {
    display: block;
  }
}

.wp-block-buttons.is-content-justification-center {
  justify-content: center;
}

#container.page .contents__wrap p a:not(.wp-block-button__link),
#container.page .contents__wrap ul:not(.c-anchor-link__wrap):not(.c-list-news):not(.c-list-column):not(.c-list-support):not(.c-breadcrumbs__list):not(.page-sidebar__list) a:not(.wp-block-button__link),
#container.page .contents__wrap ol a:not(.wp-block-button__link),
#container.page .wp-block-paragraph a:not(.wp-block-button__link),
.wp-editor p:not([class]) > a:not(.wp-block-button__link),
#container.page ul[class*=is-style] a:not(.wp-block-button__link),
#container.page ol[class*=is-style] a:not(.wp-block-button__link),
#container.page table a:not(.wp-block-button__link) {
  position: relative;
  font-weight: bold;
  display: inline-block;
  color: rgb(203.2, 135.7442622951, 0);
  text-decoration: underline solid rgba(203.2, 135.7442622951, 0, 0.35);
  text-decoration-skip-ink: none;
}
#container.page .contents__wrap p a:not(.wp-block-button__link):hover,
#container.page .contents__wrap ul:not(.c-anchor-link__wrap):not(.c-list-news):not(.c-list-column):not(.c-list-support):not(.c-breadcrumbs__list):not(.page-sidebar__list) a:not(.wp-block-button__link):hover,
#container.page .contents__wrap ol a:not(.wp-block-button__link):hover,
#container.page .wp-block-paragraph a:not(.wp-block-button__link):hover,
.wp-editor p:not([class]) > a:not(.wp-block-button__link):hover,
#container.page ul[class*=is-style] a:not(.wp-block-button__link):hover,
#container.page ol[class*=is-style] a:not(.wp-block-button__link):hover,
#container.page table a:not(.wp-block-button__link):hover {
  color: #333333;
  text-decoration: underline solid rgba(51, 51, 51, 0.3);
}
#container.page .contents__wrap p a:not(.wp-block-button__link)[target=_blank]::after,
#container.page .contents__wrap ul:not(.c-anchor-link__wrap):not(.c-list-news):not(.c-list-column):not(.c-list-support):not(.c-breadcrumbs__list):not(.page-sidebar__list) a:not(.wp-block-button__link)[target=_blank]::after,
#container.page .contents__wrap ol a:not(.wp-block-button__link)[target=_blank]::after,
#container.page .wp-block-paragraph a:not(.wp-block-button__link)[target=_blank]::after,
.wp-editor p:not([class]) > a:not(.wp-block-button__link)[target=_blank]::after,
#container.page ul[class*=is-style] a:not(.wp-block-button__link)[target=_blank]::after,
#container.page ol[class*=is-style] a:not(.wp-block-button__link)[target=_blank]::after,
#container.page table a:not(.wp-block-button__link)[target=_blank]::after {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-inline: 4px;
  background-color: #F4A300;
  mask: url("../img/ico_blank.svg") no-repeat center center/contain;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  vertical-align: 1px;
}
#container.page .contents__wrap p a:not(.wp-block-button__link)[href$=".pdf"]::after, #container.page .contents__wrap p a:not(.wp-block-button__link)[href$=".doc"]::after, #container.page .contents__wrap p a:not(.wp-block-button__link)[href$=".xls"]::after,
#container.page .contents__wrap ul:not(.c-anchor-link__wrap):not(.c-list-news):not(.c-list-column):not(.c-list-support):not(.c-breadcrumbs__list):not(.page-sidebar__list) a:not(.wp-block-button__link)[href$=".pdf"]::after,
#container.page .contents__wrap ul:not(.c-anchor-link__wrap):not(.c-list-news):not(.c-list-column):not(.c-list-support):not(.c-breadcrumbs__list):not(.page-sidebar__list) a:not(.wp-block-button__link)[href$=".doc"]::after,
#container.page .contents__wrap ul:not(.c-anchor-link__wrap):not(.c-list-news):not(.c-list-column):not(.c-list-support):not(.c-breadcrumbs__list):not(.page-sidebar__list) a:not(.wp-block-button__link)[href$=".xls"]::after,
#container.page .contents__wrap ol a:not(.wp-block-button__link)[href$=".pdf"]::after,
#container.page .contents__wrap ol a:not(.wp-block-button__link)[href$=".doc"]::after,
#container.page .contents__wrap ol a:not(.wp-block-button__link)[href$=".xls"]::after,
#container.page .wp-block-paragraph a:not(.wp-block-button__link)[href$=".pdf"]::after,
#container.page .wp-block-paragraph a:not(.wp-block-button__link)[href$=".doc"]::after,
#container.page .wp-block-paragraph a:not(.wp-block-button__link)[href$=".xls"]::after,
.wp-editor p:not([class]) > a:not(.wp-block-button__link)[href$=".pdf"]::after,
.wp-editor p:not([class]) > a:not(.wp-block-button__link)[href$=".doc"]::after,
.wp-editor p:not([class]) > a:not(.wp-block-button__link)[href$=".xls"]::after,
#container.page ul[class*=is-style] a:not(.wp-block-button__link)[href$=".pdf"]::after,
#container.page ul[class*=is-style] a:not(.wp-block-button__link)[href$=".doc"]::after,
#container.page ul[class*=is-style] a:not(.wp-block-button__link)[href$=".xls"]::after,
#container.page ol[class*=is-style] a:not(.wp-block-button__link)[href$=".pdf"]::after,
#container.page ol[class*=is-style] a:not(.wp-block-button__link)[href$=".doc"]::after,
#container.page ol[class*=is-style] a:not(.wp-block-button__link)[href$=".xls"]::after,
#container.page table a:not(.wp-block-button__link)[href$=".pdf"]::after,
#container.page table a:not(.wp-block-button__link)[href$=".doc"]::after,
#container.page table a:not(.wp-block-button__link)[href$=".xls"]::after {
  display: inline-block;
  content: "";
  width: 13px;
  height: 16px;
  margin-inline: 4px;
  background-color: #F4A300;
  mask: url("../img/ico_file.svg") no-repeat top right/contain;
  vertical-align: -2px;
}
#container.page .contents__wrap p a:not(.wp-block-button__link)[href$=".pdf"]::after,
#container.page .contents__wrap ul:not(.c-anchor-link__wrap):not(.c-list-news):not(.c-list-column):not(.c-list-support):not(.c-breadcrumbs__list):not(.page-sidebar__list) a:not(.wp-block-button__link)[href$=".pdf"]::after,
#container.page .contents__wrap ol a:not(.wp-block-button__link)[href$=".pdf"]::after,
#container.page .wp-block-paragraph a:not(.wp-block-button__link)[href$=".pdf"]::after,
.wp-editor p:not([class]) > a:not(.wp-block-button__link)[href$=".pdf"]::after,
#container.page ul[class*=is-style] a:not(.wp-block-button__link)[href$=".pdf"]::after,
#container.page ol[class*=is-style] a:not(.wp-block-button__link)[href$=".pdf"]::after,
#container.page table a:not(.wp-block-button__link)[href$=".pdf"]::after {
  background-color: #E66A45;
}
#container.page .contents__wrap p a:not(.wp-block-button__link)[href$=".doc"]::after,
#container.page .contents__wrap ul:not(.c-anchor-link__wrap):not(.c-list-news):not(.c-list-column):not(.c-list-support):not(.c-breadcrumbs__list):not(.page-sidebar__list) a:not(.wp-block-button__link)[href$=".doc"]::after,
#container.page .contents__wrap ol a:not(.wp-block-button__link)[href$=".doc"]::after,
#container.page .wp-block-paragraph a:not(.wp-block-button__link)[href$=".doc"]::after,
.wp-editor p:not([class]) > a:not(.wp-block-button__link)[href$=".doc"]::after,
#container.page ul[class*=is-style] a:not(.wp-block-button__link)[href$=".doc"]::after,
#container.page ol[class*=is-style] a:not(.wp-block-button__link)[href$=".doc"]::after,
#container.page table a:not(.wp-block-button__link)[href$=".doc"]::after {
  background-color: #397CBF;
}
#container.page .contents__wrap p a:not(.wp-block-button__link)[href$=".xls"]::after,
#container.page .contents__wrap ul:not(.c-anchor-link__wrap):not(.c-list-news):not(.c-list-column):not(.c-list-support):not(.c-breadcrumbs__list):not(.page-sidebar__list) a:not(.wp-block-button__link)[href$=".xls"]::after,
#container.page .contents__wrap ol a:not(.wp-block-button__link)[href$=".xls"]::after,
#container.page .wp-block-paragraph a:not(.wp-block-button__link)[href$=".xls"]::after,
.wp-editor p:not([class]) > a:not(.wp-block-button__link)[href$=".xls"]::after,
#container.page ul[class*=is-style] a:not(.wp-block-button__link)[href$=".xls"]::after,
#container.page ol[class*=is-style] a:not(.wp-block-button__link)[href$=".xls"]::after,
#container.page table a:not(.wp-block-button__link)[href$=".xls"]::after {
  background-color: #7FBF2A;
}

.c-list-dl {
  container-type: inline-size;
  margin-block-end: 20px;
  line-height: 1.75;
}
.c-list-dl__wrap {
  display: flex;
  align-items: start;
  flex-wrap: nowrap;
}
@media screen and (max-width: 767px) {
  .c-list-dl__wrap {
    flex-direction: column;
    gap: 12px 0;
  }
}
.c-list-dl dt {
  font-weight: bold;
  min-width: 200px;
  flex-basis: 200px;
  padding: 4px 10px;
  background: #FCF0DE;
  border-radius: 4px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .c-list-dl dt {
    min-width: initial;
    flex-basis: 100%;
    width: 100%;
    text-align: left;
  }
}
.c-list-dl dd {
  width: calc(100% - 200px);
  margin-inline-start: 0;
  padding-inline-start: 12px;
  padding-block-start: 6px;
}
@media screen and (max-width: 767px) {
  .c-list-dl dd {
    width: 100%;
    padding: 0;
  }
}

ul,
ol {
  padding-left: 0;
  list-style: none;
  list-style-type: none;
}

ul:not([class]) a,
ol:not([class]) a {
  color: #333333;
  text-decoration: underline solid rgba(51, 51, 51, 0.3);
  text-decoration-skip-ink: none;
}
ul:not([class]) a:hover,
ol:not([class]) a:hover {
  color: #F4A300;
  text-decoration: underline solid rgba(244, 163, 0, 0.3);
}

.is-style-list01, .is-style-list05, .is-style-list06 {
  margin-block-end: 28px;
  line-height: 1.75;
}
.is-style-list01 li, .is-style-list05 li, .is-style-list06 li {
  position: relative;
  padding-inline-start: 1.25em;
}
.is-style-list01 li::before, .is-style-list05 li::before, .is-style-list06 li::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 0.65em;
  left: 0.5em;
  width: 8px;
  height: 8px;
  background: rgba(244, 163, 0, 0.7);
  border-radius: 100%;
}
.is-style-list01 li + li, .is-style-list05 li + li, .is-style-list06 li + li {
  margin-block-start: 4px;
}
.is-style-list01 ul, .is-style-list05 ul, .is-style-list06 ul {
  list-style: none;
}
.is-style-list01.row, .is-style-list05.row, .is-style-list06.row {
  display: flex;
  gap: 0 20px;
  flex-wrap: wrap;
}
.is-style-list01.row li + li, .is-style-list05.row li + li, .is-style-list06.row li + li {
  margin-block-start: 0;
}
.is-style-list01 a, .is-style-list05 a, .is-style-list06 a {
  color: #333333;
}
.is-style-list01 a:hover, .is-style-list05 a:hover, .is-style-list06 a:hover {
  color: #F4A300;
}
.is-style-list02 {
  margin-block-end: 28px;
  counter-reset: counter-name;
  line-height: 1.75;
}
.is-style-list02 li {
  position: relative;
  display: block;
  padding-inline-start: 1.25em;
}
.is-style-list02 li::before {
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-optical-sizing: auto;
  font-style: normal;
  counter-increment: counter-name;
  content: counter(counter-name) ".";
  display: inline-block;
  position: absolute;
  top: 1px;
  left: 0;
  width: 20px;
  color: #F4A300;
}
.is-style-list02 li + li {
  margin-block-start: 4px;
}
.is-style-list03 {
  margin-block-end: 28px;
  line-height: 1.75;
}
.is-style-list03 li {
  position: relative;
  padding-inline-start: 1.25em;
}
.is-style-list03 li::before {
  font-weight: bold;
  content: "※";
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  color: #E66A45;
}
.is-style-list03 li + li {
  margin-block-start: 4px;
}
.is-style-list04 {
  margin-block-end: 28px;
  line-height: 1.75;
}
.is-style-list04 li {
  position: relative;
  padding-inline-start: 1.25em;
}
.is-style-list04 li::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 0.4em;
  left: 0;
  width: 16px;
  height: 16px;
  background: url("../img/ico_check.svg") no-repeat center center/contain;
}
.is-style-list04 li + li {
  margin-block-start: 4px;
}
.is-style-list05 {
  margin-block-end: 28px;
  display: grid;
  justify-content: start;
  gap: 0 40px;
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (max-width: 767px) {
  .is-style-list05 {
    display: block;
  }
}
.is-style-list05 > li {
  width: 100%;
}
.is-style-list05 > li + li {
  margin-block-start: 4px;
}
.is-style-list06 {
  margin-block-end: 28px;
  display: grid;
  justify-content: start;
  gap: 0 20px;
  grid-template-columns: repeat(4, 1fr);
}
@media screen and (max-width: 767px) {
  .is-style-list06 {
    grid-template-columns: repeat(2, 1fr);
  }
}
.is-style-list06 > li {
  width: 100%;
}
.is-style-list06 > li + li {
  margin-block-start: 4px;
}

/* リッチエディター用 */
.wp-editor ul:not([class]),
.c-accordion ul {
  margin-block-end: 28px;
  line-height: 1.75;
  list-style: none;
  list-style-type: none;
}
.wp-editor ul:not([class]) li,
.c-accordion ul li {
  position: relative;
  padding-inline-start: 1.25em;
}
.wp-editor ul:not([class]) li::before,
.c-accordion ul li::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 0.65em;
  left: 0.5em;
  width: 8px;
  height: 8px;
  background: rgba(244, 163, 0, 0.7);
  border-radius: 100%;
}
.wp-editor ul:not([class]) ul,
.c-accordion ul ul {
  list-style: none;
}

.wp-editor ol:not([class]),
.c-accordion ol {
  margin-bottom: 28px;
  counter-reset: counter-name;
  line-height: 1.75;
}
.wp-editor ol:not([class]) li,
.c-accordion ol li {
  position: relative;
  display: block;
  padding-inline-start: 1.25em;
}
.wp-editor ol:not([class]) li::before,
.c-accordion ol li::before {
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-optical-sizing: auto;
  font-style: normal;
  counter-increment: counter-name;
  content: counter(counter-name) ".";
  display: inline-block;
  position: absolute;
  top: 1px;
  left: 0;
  width: 20px;
  color: #F4A300;
}

.c-modal {
  display: none;
}
.c-modal.is-open {
  display: block;
}
.c-modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background: rgba(0, 0, 0, 0.5);
  z-index: 5;
}
.c-modal__container {
  position: relative;
  width: 80%;
  max-height: 100vh;
  padding: 40px;
  background: #FFFFFF;
  border-radius: 8px;
  box-sizing: border-box;
  overflow-y: auto;
  z-index: 6;
}
@media screen and (max-width: 767px) {
  .c-modal__container {
    width: 90%;
    max-height: 88vh;
    padding: 32px;
  }
}
.c-modal__close {
  display: block;
  width: 40px;
  height: 40px;
  position: absolute;
  top: 0;
  right: 0;
  background-color: transparent;
  border: none;
  cursor: pointer;
  z-index: 6;
}
.c-modal__close::before, .c-modal__close::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2px;
  height: 33px;
  background: #FFFFFF;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
.c-modal__close::before {
  translate: -50% -50%;
  rotate: 45deg;
}
.c-modal__close::after {
  translate: -50% -50%;
  rotate: -45deg;
}
.c-modal__close:hover::before, .c-modal__close:hover::after {
  background: #F4A300;
}
@keyframes mmfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes mmfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes mmslideIn {
  from {
    translate: 0 15%;
  }
  to {
    translate: 0 0;
  }
}
@keyframes mmslideOut {
  from {
    translate: 0 0;
  }
  to {
    translate: 0 -10%;
  }
}
.c-modal[aria-hidden=false] .c-modal__overlay {
  animation: mmfadeIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.c-modal[aria-hidden=true] .c-modal__overlay {
  animation: mmfadeOut 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.c-modal[aria-hidden=false] .c-modal__container {
  animation: mmslideIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.c-modal[aria-hidden=true] .c-modal__container {
  animation: mmslideOut 0.3s cubic-bezier(0, 0, 0.2, 1);
}

.p-page-link.p-three-block {
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
  justify-content: start;
}
@media screen and (max-width: 1280px) {
  .p-page-link.p-three-block {
    gap: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-page-link.p-three-block {
    flex-direction: column;
    gap: 12px 0;
  }
}
.p-page-link.p-three-block .p-three-block__box {
  width: calc((100% - 64px) / 3);
}
@media screen and (max-width: 1280px) {
  .p-page-link.p-three-block .p-three-block__box {
    width: calc((100% - 40px) / 3);
  }
}
@media screen and (max-width: 767px) {
  .p-page-link.p-three-block .p-three-block__box {
    width: 100%;
  }
}
.p-page-link.p-three-block .p-three-block__image {
  border-radius: 8px;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .p-page-link.p-three-block .p-three-block__image {
    max-width: 120px;
    margin-bottom: 0;
    border: none;
  }
}
.p-page-link.p-three-block .p-three-block__image img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
}
@media screen and (max-width: 767px) {
  .p-page-link.p-three-block .p-three-block__image img {
    width: 100%;
    aspect-ratio: 1/1;
    object-fit: cover;
  }
}
@media screen and (max-width: 767px) {
  .p-page-link.p-three-block .p-three-block__text {
    width: calc(100% - 120px);
  }
}
.p-page-link.p-three-block .p-three-block__box.is-without-image a {
  gap: 0;
}
.p-page-link.p-three-block .p-three-block__box.is-without-image .p-three-block__image {
  display: none;
}
@media screen and (max-width: 767px) {
  .p-page-link.p-three-block .p-three-block__box.is-without-image .p-three-block__text {
    width: 100%;
  }
}
.p-page-link.p-three-block a {
  display: flex;
  flex-direction: column;
  gap: 8px 0;
}
@media screen and (max-width: 767px) {
  .p-page-link.p-three-block a {
    display: flex;
    align-items: center;
    flex-direction: row;
    gap: 0 20px;
  }
}
.p-page-link.p-three-block a:hover img {
  opacity: 0.8;
  scale: 1.05;
}
.p-page-link.p-three-block a:hover .item-text-link {
  border-color: #F4A300;
  color: #F4A300;
}
.p-page-link.p-three-block .item-text-link {
  font-size: 1.8rem;
  font-weight: bold;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: 8px;
  border-bottom: 1px solid #E6DACA;
  line-height: 1.5;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}
@media screen and (max-width: 767px) {
  .p-page-link.p-three-block .item-text-link {
    font-size: 1.6rem;
  }
}
.p-page-link.p-three-block .item-text-link::after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 14px;
  margin-block-start: -2px;
  margin-inline-end: 12px;
  background-color: #F4A300;
  mask: url("../img/ico_arrow_right.svg") no-repeat;
  transition: background 0.3s ease-out, border 0.3s ease-out, box-shadow 0.3s ease-out, color 0.3s ease-out, transform 0.3s ease-out, translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.3s ease-out, rotate 0.3s ease-out, margin 0.3s ease-out, top 0.3s ease-out, right 0.3s ease-out, bottom 0.3s ease-out, left 0.3s ease-out, flex 0.3s ease-out, visibility 0.3s ease-out;
}

table {
  line-height: 1.75;
}
table th {
  font-weight: bold;
}

.table-assignment table {
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .table-assignment table {
    font-size: 1.2rem;
  }
}

.is-style-table01 table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}
.is-style-table01 table tr:nth-child(odd) {
  background: #FCF4E8;
}
.is-style-table01 table th,
.is-style-table01 table td {
  padding: 16px 12px;
  text-align: left;
  border: none;
}
.is-style-table01 table th,
.is-style-table01 table td:first-child {
  font-weight: bold;
  width: 25%;
  padding-right: 10px;
}
@media screen and (max-width: 767px) {
  .is-style-table01 table th,
  .is-style-table01 table td:first-child {
    display: block;
    width: 100%;
    padding-top: 12px;
    padding-right: 0;
    padding-bottom: 0;
  }
}
.is-style-table01 table td {
  width: 75%;
}
@media screen and (max-width: 767px) {
  .is-style-table01 table td {
    display: block;
    width: 100%;
    padding-top: 4px;
  }
}
.is-style-table01 > .wp-element-caption {
  font-size: 1.4rem;
  margin-top: 20px;
  line-height: 1.5;
}

.accent {
  background: rgba(230, 106, 69, 0.15) !important;
}

.wp-block-flexible-table-block-table {
  overflow-y: auto;
}

.wp-block-flexible-table-block-table > table + figcaption {
  font-size: 1.4rem;
  margin-top: 20px;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table {
    border-collapse: separate;
    border-spacing: 0;
  }
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table th,
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table td {
    border-width: 0;
    border-style: solid;
    border-color: #ddd;
    border-top-width: 1px;
    border-left-width: 1px;
  }
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table tr > *:last-child {
    border-right-width: 1px;
  }
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table thead tr:last-child > *,
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table tbody tr:last-child > * {
    border-bottom-width: 1px;
  }
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table tr > :nth-child(1),
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table tr > :nth-child(2) {
    position: sticky;
    background-clip: padding-box;
  }
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table tr > :nth-child(1) {
    left: 0;
    z-index: 2;
    width: 3.5rem;
    min-width: 3.5rem;
    max-width: 3.5rem;
    white-space: nowrap;
  }
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table tr > :nth-child(2) {
    left: 3.5rem;
    z-index: 1;
    min-width: 7.5rem;
    box-shadow: 2px 0 4px rgba(0, 0, 0, 0.06);
  }
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table tbody tr > :nth-child(1),
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table tbody tr > :nth-child(2) {
    background-color: #FFFFFF;
  }
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table thead tr > :nth-child(1),
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table thead tr > :nth-child(2) {
    background-color: #FCF4E8;
  }
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table tr > .accent:nth-child(1),
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table tr > .accent:nth-child(2) {
    background-color: rgba(230, 106, 69, 0.15);
  }
  .wp-block-flexible-table-block-table.is-sticky-two-columns.is-scroll-on-mobile > table tr > .is-not-sticky {
    position: static;
    left: auto;
    z-index: auto;
    min-width: auto;
    box-shadow: none;
  }
}
table.tablepress {
  font-size: 1.4rem;
  --text-color: #333333;
  --padding: 0.75em 0.25em;
  --border-color: #E5E3E1;
  --head-bg-color: #FCF4E8;
  --odd-bg-color: transparent;
  --even-bg-color: transparent;
  border-collapse: collapse;
  border-spacing: 0;
  table-layout: fixed;
  border: 1px solid #E5E3E1;
}
table.tablepress > :not(caption) > * > * {
  border: 1px solid #E5E3E1;
  text-align: center;
  vertical-align: middle;
}
table.tablepress > thead > tr > th,
table.tablepress > thead > tr > td,
table.tablepress > tbody > tr > .column-1 {
  background-color: #FCF4E8;
}
table.tablepress > tbody > tr > .column-1 {
  font-weight: bold;
}

.table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}
@media screen and (max-width: 767px) {
  .table-scroll::before {
    content: "左右にスクロールできます";
    display: block;
    font-size: 1.4rem;
    margin-bottom: 12px;
  }
  .table-scroll > table.tablepress {
    min-width: 700px;
  }
}

.tablepress-table-description {
  font-size: 1.4rem;
  margin-top: 20px;
  line-height: 1.5;
}

.wp-block-embed.is-type-video + * {
  margin-block-start: 40px;
}
.wp-block-embed.is-type-video .wp-block-embed__wrapper {
  aspect-ratio: 16/9;
  width: 100%;
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  overflow: hidden;
}
.wp-block-embed.is-type-video .wp-block-embed__wrapper iframe {
  width: 100%;
  height: 100%;
}
