@charset "UTF-8";
/* Normalize.css
======================================================== */
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

main {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: transparent;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

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

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;
}

img {
  border-style: none;
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  padding: 0;
}

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

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

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

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

details {
  display: block;
}

summary {
  display: list-item;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

/* Soft reset */
figure {
  margin: 0;
}

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

dd {
  margin-left: 0;
}

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

p {
  margin: 0;
}

/* Common
======================================================== */
html {
  margin-top: 0 !important;
}

body {
  color: #3d4448;
  font-family: "Zen Old Mincho", "Hiragino Mincho ProN", "Yu Mincho", serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: clamp(1.5rem, 1.32rem + 0.2vw, 1.6rem);
  letter-spacing: 0;
  line-height: 1.6;
  overflow-x: hidden;
  position: relative;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
@media screen and (max-width: 768px) {
  body {
    line-height: 1.5;
  }
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  text-decoration: none;
}

.l-header {
  position: fixed !important;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding-left: 10px;
  padding-right: 10px;
}
@media screen and (min-width: 1200px) {
  .l-header {
    position: static !important;
    padding-left: 20px;
    padding-right: 20px;
  }
}
.l-header .wp-block-site-logo img {
  width: clamp(133px, 38.9px + 25.1vw, 350px);
  height: auto;
  margin-top: 5px;
}
@media screen and (min-width: 768px) {
  .l-header .wp-block-site-logo img {
    margin-top: 0;
  }
}

.l-header_inner {
  flex-wrap: nowrap;
  padding-top: 10px;
  padding-bottom: 20px;
}
@media screen and (min-width: 768px) {
  .l-header_inner {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}

.wp-block-site-logo {
  width: clamp(133px, 58.9px + 19.8vw, 304px);
  height: auto;
  flex: 1;
}

.l-header_right {
  flex-direction: row-reverse;
}
@media screen and (min-width: 1200px) {
  .l-header_right {
    flex-direction: row;
  }
}

.wp-block-navigation.is-style-l-header_nav {
  -moz-column-gap: clamp(8px, 4.5px + 0.9vw, 16px);
       column-gap: clamp(8px, 4.5px + 0.9vw, 16px);
}
@media screen and (min-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav {
    background-color: var(--wp--preset--color--white);
    border-radius: 44px;
    padding: 1em 1.25em;
  }
}
.wp-block-navigation.is-style-l-header_nav > li {
  font-size: clamp(12px, 9.7px + 0.3vw, 14px);
}
@media screen and (max-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav {
    background-color: transparent;
    border-radius: 0;
    padding: 0;
  }
  .wp-block-navigation.is-style-l-header_nav > .wp-block-navigation__container {
    display: none !important;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container-open {
    display: flex !important;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container:not(.is-menu-open) {
    display: none !important;
  }
}
@media screen and (min-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container-open {
    display: none !important;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container:not(.is-menu-open) {
    display: flex !important;
    position: static !important;
    background: transparent !important;
  }
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content {
  display: flex;
  align-items: center;
  color: var(--wp--preset--color--text-dark-brown);
  background-color: transparent;
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content::before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 0.35em;
  background-color: var(--wp--preset--color--main-orange);
}
@media screen and (min-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content,
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item .wp-block-navigation-item__content[aria-current=page] {
    position: relative;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content::after,
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item .wp-block-navigation-item__content[aria-current=page]::after {
    position: absolute;
    bottom: -15px;
    left: 50%;
    transform: translateX(-50%);
    display: block;
    width: 60px;
    height: 3px;
    background-color: var(--wp--preset--color--main-orange) !important;
    content: "" !important;
  }
}
.wp-block-navigation.is-style-l-header_nav li.has-main-orange-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-header_nav li.has-main-orange-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--main-orange);
}
@media screen and (min-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav li.has-main-orange-background-color.current-menu-item > .wp-block-navigation-item__content::after,
  .wp-block-navigation.is-style-l-header_nav li.has-main-orange-background-color > .wp-block-navigation-item__content[aria-current=page]::after {
    background-color: var(--wp--preset--color--main-orange) !important;
  }
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-main-orange-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-main-orange-background-color::before {
  background-color: var(--wp--preset--color--main-orange);
}
.wp-block-navigation.is-style-l-header_nav li.has-main-yellow-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-header_nav li.has-main-yellow-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--main-yellow);
}
@media screen and (min-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav li.has-main-yellow-background-color.current-menu-item > .wp-block-navigation-item__content::after,
  .wp-block-navigation.is-style-l-header_nav li.has-main-yellow-background-color > .wp-block-navigation-item__content[aria-current=page]::after {
    background-color: var(--wp--preset--color--main-yellow) !important;
  }
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-main-yellow-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-main-yellow-background-color::before {
  background-color: var(--wp--preset--color--main-yellow);
}
.wp-block-navigation.is-style-l-header_nav li.has-main-red-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-header_nav li.has-main-red-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--main-red);
}
@media screen and (min-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav li.has-main-red-background-color.current-menu-item > .wp-block-navigation-item__content::after,
  .wp-block-navigation.is-style-l-header_nav li.has-main-red-background-color > .wp-block-navigation-item__content[aria-current=page]::after {
    background-color: var(--wp--preset--color--main-red) !important;
  }
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-main-red-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-main-red-background-color::before {
  background-color: var(--wp--preset--color--main-red);
}
.wp-block-navigation.is-style-l-header_nav li.has-main-blue-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-header_nav li.has-main-blue-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--main-blue);
}
@media screen and (min-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav li.has-main-blue-background-color.current-menu-item > .wp-block-navigation-item__content::after,
  .wp-block-navigation.is-style-l-header_nav li.has-main-blue-background-color > .wp-block-navigation-item__content[aria-current=page]::after {
    background-color: var(--wp--preset--color--main-blue) !important;
  }
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-main-blue-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-main-blue-background-color::before {
  background-color: var(--wp--preset--color--main-blue);
}
.wp-block-navigation.is-style-l-header_nav li.has-main-cyan-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-header_nav li.has-main-cyan-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--main-cyan);
}
@media screen and (min-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav li.has-main-cyan-background-color.current-menu-item > .wp-block-navigation-item__content::after,
  .wp-block-navigation.is-style-l-header_nav li.has-main-cyan-background-color > .wp-block-navigation-item__content[aria-current=page]::after {
    background-color: var(--wp--preset--color--main-cyan) !important;
  }
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-main-cyan-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-main-cyan-background-color::before {
  background-color: var(--wp--preset--color--main-cyan);
}
.wp-block-navigation.is-style-l-header_nav li.has-main-lightgreen-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-header_nav li.has-main-lightgreen-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--main-lightgreen);
}
@media screen and (min-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav li.has-main-lightgreen-background-color.current-menu-item > .wp-block-navigation-item__content::after,
  .wp-block-navigation.is-style-l-header_nav li.has-main-lightgreen-background-color > .wp-block-navigation-item__content[aria-current=page]::after {
    background-color: var(--wp--preset--color--main-lightgreen) !important;
  }
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-main-lightgreen-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-main-lightgreen-background-color::before {
  background-color: var(--wp--preset--color--main-lightgreen);
}
.wp-block-navigation.is-style-l-header_nav li.has-text-dark-brown-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-header_nav li.has-text-dark-brown-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--text-dark-brown);
}
@media screen and (min-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav li.has-text-dark-brown-background-color.current-menu-item > .wp-block-navigation-item__content::after,
  .wp-block-navigation.is-style-l-header_nav li.has-text-dark-brown-background-color > .wp-block-navigation-item__content[aria-current=page]::after {
    background-color: var(--wp--preset--color--text-dark-brown) !important;
  }
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-text-dark-brown-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-text-dark-brown-background-color::before {
  background-color: var(--wp--preset--color--text-dark-brown);
}
.wp-block-navigation.is-style-l-header_nav li.has-white-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-header_nav li.has-white-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--white);
}
@media screen and (min-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav li.has-white-background-color.current-menu-item > .wp-block-navigation-item__content::after,
  .wp-block-navigation.is-style-l-header_nav li.has-white-background-color > .wp-block-navigation-item__content[aria-current=page]::after {
    background-color: var(--wp--preset--color--white) !important;
  }
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-white-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-white-background-color::before {
  background-color: var(--wp--preset--color--white);
}
.wp-block-navigation.is-style-l-header_nav li.has-soft-beige-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-header_nav li.has-soft-beige-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--soft-beige);
}
@media screen and (min-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav li.has-soft-beige-background-color.current-menu-item > .wp-block-navigation-item__content::after,
  .wp-block-navigation.is-style-l-header_nav li.has-soft-beige-background-color > .wp-block-navigation-item__content[aria-current=page]::after {
    background-color: var(--wp--preset--color--soft-beige) !important;
  }
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-soft-beige-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content.has-soft-beige-background-color::before {
  background-color: var(--wp--preset--color--soft-beige);
}
@media screen and (max-width: 1200px) {
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container-open {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 4px;
    font-family: "Josefin Sans", sans-serif;
    transition: opacity 0.2s ease;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container-open:hover {
    opacity: 0.7;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container-open .hamburger-bar {
    display: block;
    width: 30px;
    height: 2px;
    background-color: var(--wp--preset--color--text-dark-brown);
    border-radius: 2px;
    transition: transform 0.3s ease, opacity 0.3s ease;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container-open::before {
    content: "MENU";
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    line-height: 1;
    color: var(--wp--preset--color--main-orange);
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container.is-menu-open {
    position: fixed !important;
    inset: 0 !important;
    z-index: 99999 !important;
    background-color: var(--wp--preset--color--soft-beige) !important;
    color: var(--wp--preset--color--text-dark-brown) !important;
    display: flex !important;
    flex-direction: column;
    align-items: center;
    padding: 12px 16px 40px;
    overflow-y: auto;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-close {
    width: 100%;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-dialog {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container-close {
    display: flex;
    flex-direction: column;
    align-items: center;
    align-self: flex-end;
    gap: 2px;
    padding: 4px 8px;
    font-family: "Josefin Sans", sans-serif;
    color: var(--wp--preset--color--main-orange) !important;
    background: none;
    border: none;
    transition: opacity 0.2s ease;
    margin-bottom: 16px;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container-close:hover {
    opacity: 0.7;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container-close svg {
    width: 22px;
    height: 22px;
    color: var(--wp--preset--color--text-dark-brown) !important;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container-close svg path {
    fill: var(--wp--preset--color--text-dark-brown) !important;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container-close::before {
    content: "MENU";
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    line-height: 1;
    color: var(--wp--preset--color--main-orange);
    order: -1;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__responsive-container-content {
    width: 100%;
    background-color: #fff;
    border-radius: 20px;
    padding: 8px 20px;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation__container.is-responsive {
    width: 100% !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item {
    border-bottom: 1px solid #ede8df;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item:last-child {
    border-bottom: none;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content {
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
    padding: 16px 4px !important;
    background-color: transparent !important;
    color: var(--wp--preset--color--text-dark-brown) !important;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content::before {
    content: "";
    display: inline-block !important;
    width: 40px !important;
    height: 40px !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center left !important;
    background-color: transparent !important;
    border-radius: 0 !important;
    flex-shrink: 0;
    margin-right: 12px;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content .wp-block-navigation-item__label {
    flex: 1;
    text-align: left;
  }
  .wp-block-navigation.is-style-l-header_nav .wp-block-navigation-item__content::after {
    content: "→";
    flex-shrink: 0;
    margin-left: auto;
    padding-left: 8px;
    font-size: 14px;
    color: var(--wp--preset--color--text-dark-brown);
    background: none !important;
    width: auto !important;
    height: auto !important;
    position: static !important;
    transform: none !important;
  }
  .wp-block-navigation.is-style-l-header_nav li.has-main-yellow-background-color > .wp-block-navigation-item__content::before {
    background-image: url(../img/common/img-about_pagetitle.png) !important;
  }
  .wp-block-navigation.is-style-l-header_nav li.has-main-orange-background-color > .wp-block-navigation-item__content::before {
    background-image: url(../img/common/img-lessons_pagetitle.png) !important;
  }
  .wp-block-navigation.is-style-l-header_nav li.has-main-red-background-color > .wp-block-navigation-item__content::before {
    background-image: url(../img/common/img-instructors_pagetitle.png) !important;
  }
  .wp-block-navigation.is-style-l-header_nav li.has-main-blue-background-color > .wp-block-navigation-item__content::before {
    background-image: url(../img/common/img-voices_pagetitle.png) !important;
  }
  .wp-block-navigation.is-style-l-header_nav li.has-main-cyan-background-color > .wp-block-navigation-item__content::before {
    background-image: url(../img/common/img-blog_pagetitle.png) !important;
  }
  .wp-block-navigation.is-style-l-header_nav li.has-main-lightgreen-background-color > .wp-block-navigation-item__content::before {
    background-image: url(../img/common/img-access_pagetitle.png) !important;
  }
}

@media screen and (min-width: 1200px) {
  .l-header_nav-pcno {
    display: none !important;
  }
}

.is-style-l-header_contact {
  width: min(236px, 100%);
}
@media screen and (max-width: 768px) {
  .is-style-l-header_contact {
    width: min(133px, 100%);
  }
}
.is-style-l-header_contact > .wp-block-button__link {
  position: relative;
  padding-top: clamp(5px, 1.1px + 1vw, 14px);
  padding-bottom: clamp(5px, 1.1px + 1vw, 14px);
  padding-right: clamp(30px, 17px + 3.5vw, 60px);
  padding-left: clamp(20px, 22.2px + -0.6vw, 15px);
  font-size: clamp(8px, 4.5px + 0.9vw, 16px);
  transition: opacity 0.25s ease;
}
.is-style-l-header_contact > .wp-block-button__link::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: clamp(37px, 28.8px + 2.2vw, 56px);
  height: clamp(66px, 54.3px + 3.1vw, 93px);
  background-image: url("../img/common/icon-mail.png");
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
  transition: transform 0.3s ease;
}
@media screen and (min-width: 768px) {
  .is-style-l-header_contact > .wp-block-button__link::after {
    right: 5px;
  }
}
.is-style-l-header_contact > .wp-block-button__link:hover {
  opacity: 0.85;
}
.is-style-l-header_contact > .wp-block-button__link:hover::after {
  transform: translateY(calc(-50% - 4px)) rotate(10deg);
}

@media screen and (max-width: 768px) {
  [data-unitone-layout="both-sides -align-items:center -column-gap:-1 -row-gap:-2"] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    -moz-column-gap: clamp(8px, 0.4px + 2vw, 16px);
         column-gap: clamp(8px, 0.4px + 2vw, 16px);
  }
  [data-unitone-layout="both-sides -align-items:center -column-gap:-1 -row-gap:-2"] > [data-unitone-block-list="block layout"] {
    display: flex;
    align-items: center;
  }
  [data-unitone-layout="both-sides -align-items:center -column-gap:-1 -row-gap:-2"] > [data-unitone-block-list="block layout"]:last-child {
    -moz-column-gap: clamp(8px, 0.4px + 2vw, 16px);
         column-gap: clamp(8px, 0.4px + 2vw, 16px);
  }
}
.wp-block-navigation.is-style-l-footer_nav {
  display: none;
}
@media screen and (min-width: 768px) {
  .wp-block-navigation.is-style-l-footer_nav {
    display: block;
    background-color: transparent;
    padding: 0;
  }
  .wp-block-navigation.is-style-l-footer_nav .wp-block-navigation__container {
    gap: 40px !important;
  }
  .wp-block-navigation.is-style-l-footer_nav .wp-block-navigation__container > li:last-child {
    margin-bottom: 0;
  }
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content {
  display: flex;
  align-items: center;
  background-color: transparent;
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content::before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-right: 0.35em;
  background-color: var(--wp--preset--color--main-orange);
}
.wp-block-navigation.is-style-l-footer_nav li.has-main-orange-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-footer_nav li.has-main-orange-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--main-orange);
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-main-orange-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-main-orange-background-color::before {
  background-color: var(--wp--preset--color--main-orange);
}
.wp-block-navigation.is-style-l-footer_nav li.has-main-yellow-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-footer_nav li.has-main-yellow-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--main-yellow);
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-main-yellow-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-main-yellow-background-color::before {
  background-color: var(--wp--preset--color--main-yellow);
}
.wp-block-navigation.is-style-l-footer_nav li.has-main-red-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-footer_nav li.has-main-red-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--main-red);
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-main-red-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-main-red-background-color::before {
  background-color: var(--wp--preset--color--main-red);
}
.wp-block-navigation.is-style-l-footer_nav li.has-main-blue-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-footer_nav li.has-main-blue-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--main-blue);
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-main-blue-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-main-blue-background-color::before {
  background-color: var(--wp--preset--color--main-blue);
}
.wp-block-navigation.is-style-l-footer_nav li.has-main-cyan-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-footer_nav li.has-main-cyan-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--main-cyan);
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-main-cyan-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-main-cyan-background-color::before {
  background-color: var(--wp--preset--color--main-cyan);
}
.wp-block-navigation.is-style-l-footer_nav li.has-main-lightgreen-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-footer_nav li.has-main-lightgreen-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--main-lightgreen);
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-main-lightgreen-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-main-lightgreen-background-color::before {
  background-color: var(--wp--preset--color--main-lightgreen);
}
.wp-block-navigation.is-style-l-footer_nav li.has-text-dark-brown-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-footer_nav li.has-text-dark-brown-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--text-dark-brown);
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-text-dark-brown-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-text-dark-brown-background-color::before {
  background-color: var(--wp--preset--color--text-dark-brown);
}
.wp-block-navigation.is-style-l-footer_nav li.has-white-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-footer_nav li.has-white-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--white);
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-white-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-white-background-color::before {
  background-color: var(--wp--preset--color--white);
}
.wp-block-navigation.is-style-l-footer_nav li.has-soft-beige-background-color {
  background-color: transparent !important;
}
.wp-block-navigation.is-style-l-footer_nav li.has-soft-beige-background-color > .wp-block-navigation-item__content::before {
  background-color: var(--wp--preset--color--soft-beige);
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-soft-beige-background-color {
  background-color: transparent;
}
.wp-block-navigation.is-style-l-footer_nav .wp-block-navigation-item__content.has-soft-beige-background-color::before {
  background-color: var(--wp--preset--color--soft-beige);
}

.l-footer_logo {
  width: min(100%, 235px);
  height: auto;
}
@media screen and (min-width: 768px) {
  .l-footer_logo {
    width: min(100%, 304px);
    height: auto;
  }
}

main {
  flex: 1;
}

.l-main {
  padding-top: 70px;
}
@media screen and (min-width: 1200px) {
  .l-main {
    padding-top: 0;
  }
}

.l-main_page {
  background-color: var(--wp--preset--color--soft-beige);
  background-image: url(../img/common/bg-page-sp.png);
  background-size: 100% auto;
  background-position: center 240px;
  background-repeat: repeat-y;
  padding-top: 80px;
}
@media screen and (min-width: 1200px) {
  .l-main_page {
    padding-top: 0;
  }
}
@media screen and (min-width: 768px) {
  .l-main_page {
    background-image: url(../img/common/bg-page.png);
    background-repeat: no-repeat;
    background-position: center top;
  }
}

.l-content {
  width: min(100%, 1000px) !important;
  border-radius: 27px;
  padding: clamp(15px, -0.2px + 4vw, 50px);
}
.entry-content .l-content {
  margin-left: auto !important;
  margin-right: auto !important;
}
.l-main_page:has(.l-content.space) {
  padding-top: 80px;
}
@media screen and (min-width: 768px) {
  .l-main_page:has(.l-content.space) {
    padding-top: 150px;
  }
}
.l-content.space {
  padding-top: clamp(30px, 12.2px + 2.3vw, 40px);
  padding-bottom: clamp(30px, 12.2px + 2.3vw, 40px);
}

.l-inner {
  width: min(100%, 1200px);
  margin-left: auto;
  margin-right: auto;
}

.l-inner_page {
  width: min(100%, 1200px);
  margin-left: auto;
  margin-right: auto;
  padding-left: 16px;
  padding-right: 16px;
}
@media screen and (min-width: 768px) {
  .l-inner_page {
    padding-left: 20px;
    padding-right: 20px;
  }
}

/* アニメーション
======================================================== */
/* 初期状態（非表示） */
.js-fadein,
.js-slideup,
.js-slidedown,
.js-slideleft,
.js-slideright {
  opacity: 0;
  transition: all 0.5s ease;
}

/* フェードイン */
.js-fadein.is-active {
  opacity: 1;
}

/* スライドアップ */
.js-slideup {
  transform: translateY(50px);
}
.js-slideup.is-active {
  opacity: 1;
  transform: translateY(0);
}

/* スライドダウン */
.js-slidedown {
  transform: translateY(-50px);
}
.js-slidedown.is-active {
  opacity: 1;
  transform: translateY(0);
}

/* スライドレフト */
.js-slideleft {
  opacity: 0;
  transform: translateX(30px);
}
.js-slideleft.is-active {
  opacity: 1;
  transform: translateX(0);
}

/* スライドライト */
.js-slideright {
  opacity: 0;
  transform: translateX(-30px);
}
.js-slideright.is-active {
  opacity: 1;
  transform: translateX(0);
}

/* 左右スライド用の親要素 */
.js-slide-container {
  overflow: hidden;
}

/* スケールイン */
.js-scalein {
  opacity: 0;
  transform: scale(0.8);
  transition: all 1s ease;
}
.js-scalein.is-active {
  opacity: 1;
  transform: scale(1);
}

/* 回転イン */
.js-rotatein {
  opacity: 0;
  transform: rotate(-10deg) scale(0.8);
  transition: all 1.2s ease;
}
.js-rotatein.is-active {
  opacity: 1;
  transform: rotate(0deg) scale(1);
}

/* バウンスイン */
.js-bouncein {
  opacity: 0;
  transform: scale(0.3);
  transition: all 1s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}
.js-bouncein.is-active {
  opacity: 1;
  transform: scale(1);
}

/* 遅延アニメーション */
.js-delay-1 {
  transition-delay: 0.1s;
}

.js-delay-2 {
  transition-delay: 0.2s;
}

.js-delay-3 {
  transition-delay: 0.3s;
}

.js-delay-4 {
  transition-delay: 0.4s;
}

.js-delay-5 {
  transition-delay: 0.5s;
}

/* ホバーアニメーション */
.js-hover-scale {
  transition: transform 0.3s ease;
}
.js-hover-scale:hover {
  transform: scale(1.05);
}

.js-hover-lift {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.js-hover-lift:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
}

.js-hover-rotate {
  transition: transform 0.3s ease;
}
.js-hover-rotate:hover {
  transform: rotate(5deg);
}

/* テキストアニメーション */
.js-text-reveal {
  overflow: hidden;
}
.js-text-reveal .js-text-reveal-inner {
  display: inline-block;
  transform: translateY(100%);
  transition: transform 1.2s ease;
}
.js-text-reveal.is-active .js-text-reveal-inner {
  transform: translateY(0);
}

/* カウンターアニメーション */
.js-counter {
  opacity: 0;
  transform: translateY(20px);
  transition: all 1s ease;
}
.js-counter.is-active {
  opacity: 1;
  transform: translateY(0);
}

/* 背景スライド */
.js-bg-slide {
  position: relative;
  overflow: hidden;
}
.js-bg-slide::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
  transition: left 1.2s ease;
}
.js-bg-slide.is-active::before {
  left: 100%;
}

/* パララックス効果 */
.js-parallax {
  transition: transform 0.1s ease-out;
}

/* スクロールトリガー用のオフセット */
.js-scroll-trigger {
  margin-top: -50px;
  padding-top: 50px;
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .js-slideup,
  .js-slidedown,
  .js-slideleft,
  .js-slideright {
    transform: translateY(30px);
  }
  .js-slideup.is-active,
  .js-slidedown.is-active,
  .js-slideleft.is-active,
  .js-slideright.is-active {
    transform: translateY(0);
  }
  .js-slideleft,
  .js-slideright {
    transform: translateX(30px);
  }
  .js-slideleft.is-active,
  .js-slideright.is-active {
    transform: translateX(0);
  }
}
/* -------------------------
メインビジュアル専用アニメーション
-------------------------*/
/* 初期状態（非表示） */
.js-mainvisual-catch {
  opacity: 0;
  transform: scale(0.9) translateY(20px);
  transition: all 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.js-mainvisual-catch.is-active {
  opacity: 1;
  transform: scale(1) translateY(0);
}

.js-mainvisual-description {
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.8s ease;
}
.js-mainvisual-description.is-active {
  opacity: 1;
  transform: translateY(0);
}

.js-mainvisual-message {
  opacity: 0;
  transform: translateY(20px) rotate(-1deg);
  transition: all 0.6s ease;
}
.js-mainvisual-message.is-active {
  opacity: 1;
  transform: translateY(0) rotate(0deg);
}

.js-mainvisual-title {
  opacity: 0;
  transform: translateY(25px) scale(0.95);
  transition: all 0.7s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.js-mainvisual-title.is-active {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.js-mainvisual-text {
  opacity: 0;
  transform: translateY(15px);
  transition: all 0.5s ease;
}
.js-mainvisual-text.is-active {
  opacity: 1;
  transform: translateY(0);
}

.js-mainvisual-list {
  opacity: 0;
  transform: translateY(40px) scale(0.9);
  transition: all 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.js-mainvisual-list.is-active {
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* 円形要素はバウンスアニメーション */
.js-mainvisual-circle {
  opacity: 0;
  transform: scale(0.3) translateY(50px);
  transition: all 1.2s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}
.js-mainvisual-circle.is-active {
  opacity: 1;
  transform: scale(1) translateY(0);
}

/* Utility classes
======================================================== */
.pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .pc {
    display: block;
  }
}

.sp {
  display: block;
}
@media screen and (min-width: 768px) {
  .sp {
    display: none;
  }
}

/* 矢印付きボタン
======================================================== */
.is-style-btn-arrow .wp-block-button__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  -moz-column-gap: 0.75em;
       column-gap: 0.75em;
  max-width: 100%;
  border: 2px solid currentColor;
  padding-left: clamp(30px, 17px + 3.5vw, 60px);
  padding-right: clamp(30px, 17px + 3.5vw, 60px);
  background-color: #fff;
  font-size: clamp(14px, 12.3px + 0.5vw, 18px);
  transition: background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}
.is-style-btn-arrow .wp-block-button__link::after {
  content: "";
  display: inline-block;
  width: 0.4em;
  height: 0.4em;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
  flex-shrink: 0;
  transition: border-color 0.25s ease;
}
.is-style-btn-arrow .wp-block-button__link:hover {
  background-color: var(--wp--preset--color--main-orange) !important;
  border-color: var(--wp--preset--color--main-orange) !important;
  color: #fff !important;
}

.is-style-btn-arrow .wp-block-button__link.has-main-orange-color:hover {
  background-color: var(--wp--preset--color--main-orange) !important;
  border-color: var(--wp--preset--color--main-orange) !important;
  color: #fff !important;
}

.is-style-btn-arrow .wp-block-button__link.has-main-yellow-color:hover {
  background-color: var(--wp--preset--color--main-yellow) !important;
  border-color: var(--wp--preset--color--main-yellow) !important;
  color: #fff !important;
}

.is-style-btn-arrow .wp-block-button__link.has-main-red-color:hover {
  background-color: var(--wp--preset--color--main-red) !important;
  border-color: var(--wp--preset--color--main-red) !important;
  color: #fff !important;
}

.is-style-btn-arrow .wp-block-button__link.has-main-blue-color:hover {
  background-color: var(--wp--preset--color--main-blue) !important;
  border-color: var(--wp--preset--color--main-blue) !important;
  color: #fff !important;
}

.is-style-btn-arrow .wp-block-button__link.has-main-cyan-color:hover {
  background-color: var(--wp--preset--color--main-cyan) !important;
  border-color: var(--wp--preset--color--main-cyan) !important;
  color: #fff !important;
}

.is-style-btn-arrow .wp-block-button__link.has-main-lightgreen-color:hover {
  background-color: var(--wp--preset--color--main-lightgreen) !important;
  border-color: var(--wp--preset--color--main-lightgreen) !important;
  color: #fff !important;
}

.is-style-btn-arrow .wp-block-button__link.has-text-dark-brown-color:hover {
  background-color: var(--wp--preset--color--text-dark-brown) !important;
  border-color: var(--wp--preset--color--text-dark-brown) !important;
  color: #fff !important;
}

.is-style-btn-arrow .wp-block-button__link.has-text-black-color:hover {
  background-color: var(--wp--preset--color--text-black) !important;
  border-color: var(--wp--preset--color--text-black) !important;
  color: #fff !important;
}

.is-style-btn-arrow .wp-block-button__link.has-white-color:hover {
  background-color: var(--wp--preset--color--white) !important;
  border-color: var(--wp--preset--color--white) !important;
  color: #fff !important;
}

.is-style-btn-arrow .wp-block-button__link.has-soft-beige-color:hover {
  background-color: var(--wp--preset--color--soft-beige) !important;
  border-color: var(--wp--preset--color--soft-beige) !important;
  color: #fff !important;
}

/* cta
======================================================== */
.c-cta {
  position: relative;
  background-color: #009944;
  padding-top: 80px;
  padding-bottom: clamp(120px, 107px + 3.5vw, 150px);
  padding-left: 10px;
  padding-right: 10px;
}
@media screen and (min-width: 768px) {
  .c-cta {
    padding-left: 20px;
    padding-right: 20px;
  }
}
.c-cta::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 70%;
  height: 100%;
  transform: translate(-50%, -50%);
  background-image: url("../img/common/bg-cta_star-sp.png");
  background-size: 100%;
  background-position: center center;
  background-repeat: no-repeat;
}
@media screen and (min-width: 768px) {
  .c-cta::before {
    width: 100%;
    height: 100%;
    background-image: url("../img/common/bg-cta_star.png");
    background-size: 100%;
  }
}

.c-cta_description {
  font-size: clamp(19px, 16.2px + 0.8vw, 24px);
}

.wp-block-buttons .wp-block-button.is-style-c-cta_button {
  width: min(100%, 300px) !important;
}
@media screen and (min-width: 768px) {
  .wp-block-buttons .wp-block-button.is-style-c-cta_button {
    width: min(75%, 750px) !important;
  }
}

.is-style-c-cta_button {
  position: relative;
  z-index: 0;
}
.is-style-c-cta_button::before {
  content: "";
  position: absolute;
  bottom: -20px;
  left: 0;
  width: clamp(45px, 32px + 3.5vw, 75px);
  height: clamp(90px, 62.7px + 7.3vw, 153px);
  background-image: url("../img/common/icon-contact_left.png");
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 1;
  transition: transform 0.3s ease;
}
@media screen and (min-width: 768px) {
  .is-style-c-cta_button::before {
    top: 30px;
  }
}
.is-style-c-cta_button::after {
  content: "";
  position: absolute;
  top: 20px;
  right: -10px;
  width: clamp(40px, 27.9px + 3.2vw, 68px);
  height: clamp(80px, 58.3px + 5.8vw, 130px);
  background-image: url("../img/common/icon-contact_right.png");
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 1;
  transition: transform 0.3s ease;
}
@media screen and (min-width: 768px) {
  .is-style-c-cta_button::after {
    top: 10px;
    right: 20px;
  }
}
.is-style-c-cta_button:hover::before {
  transform: translate(-4px, 4px) rotate(-5deg);
}
.is-style-c-cta_button:hover::after {
  transform: translate(4px, -4px) rotate(5deg);
}
.is-style-c-cta_button .wp-block-button__link {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  -moz-column-gap: clamp(20px, 11.3px + 2.3vw, 40px);
       column-gap: clamp(20px, 11.3px + 2.3vw, 40px);
  background-color: var(--wp--preset--color--soft-beige);
  border-radius: clamp(28px, 1.6px + 7.1vw, 89px);
  color: var(--wp--preset--color--main-orange);
  font-size: clamp(14px, 8.8px + 1.4vw, 26px);
  margin-top: clamp(40px, 33.9px + 1.6vw, 54px);
  width: 100% !important;
  padding: clamp(10px, 5.7px + 1.2vw, 20px);
}
.is-style-c-cta_button .wp-block-button__link::after {
  content: "";
  width: clamp(5px, 3.7px + 0.3vw, 8px);
  height: clamp(7px, 4.8px + 0.6vw, 12px);
  background-image: url("../img/common/icon-arrow.png");
  background-size: contain;
  background-repeat: no-repeat;
  transition: transform 0.3s ease;
}
.is-style-c-cta_button .wp-block-button__link:hover::after {
  transform: translateX(4px);
}

/* headin
======================================================== */
.is-style-heading-dot {
  display: flex;
  align-items: center;
  gap: 10px;
}
.is-style-heading-dot::before {
  display: block;
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background-color: var(--wp--preset--color--main-lightgreen);
}
.is-style-heading-dot.has-background::before {
  background-color: inherit;
}

.is-style-heading-dot-orange {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 20px;
}
.is-style-heading-dot-orange::before {
  display: block;
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background-color: var(--wp--preset--color--main-yellow);
}
.is-style-heading-dot-orange.has-background::before {
  background-color: inherit;
}

/* list
======================================================== */
.wp-block-list.is-style-list-dot {
  list-style: none;
  padding-left: 0;
}
.wp-block-list.is-style-list-dot > li {
  position: relative;
  padding-left: clamp(10px, 5.7px + 1.2vw, 20px);
  margin-left: 0;
}
.wp-block-list.is-style-list-dot > li::before {
  position: absolute;
  left: 0;
  top: 0.6em;
  display: block;
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: var(--unitone--marker-color, var(--wp--preset--color--main-lightgreen));
}
@media screen and (min-width: 768px) {
  .wp-block-list.is-style-list-dot > li::before {
    top: 0.7em;
  }
}

/* pagevisual
======================================================== */
.c-pagetitle_en {
  position: relative;
}
.c-pagetitle_en::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 13px;
  height: 13px;
  content: "";
  background-color: currentColor;
  -webkit-mask: url(../img/common/icon-pagetitle.svg) no-repeat center/contain;
  mask: url(../img/common/icon-pagetitle.svg) no-repeat center/contain;
}

.c-breadcrumb {
  padding: 0 16px 40px;
}
@media screen and (min-width: 768px) {
  .c-breadcrumb {
    padding: 0 16px 80px;
  }
}
.c-breadcrumb a {
  font-size: clamp(1.2rem, 0.49rem + 0.9vw, 1.6rem);
}

.c-breadcrumb_inner {
  font-size: 12px;
  width: 100%;
  max-width: 1100px;
  overflow-x: auto;
  /* --------------------
  画面幅以上の場合は「…」 ここから
  -------------------- */
  /* --------------------
  画面幅以上の場合は「…」 ここまで
  -------------------- */
  /* --------------------
  画面幅以上の場合はスクロール ここから
  -------------------- */
  overflow-x: scroll;
  white-space: nowrap;
  scrollbar-width: none;
}
.c-breadcrumb_inner::-webkit-scrollbar {
  display: none;
}
.c-breadcrumb_inner {
  /* --------------------
  画面幅以上の場合はスクロール ここまで
  -------------------- */
}
.c-breadcrumb_inner i {
  font-size: 1.125rem;
  margin-right: -0.3em;
  vertical-align: middle;
  color: #757575;
}
.c-breadcrumb_inner a {
  text-decoration: none;
  color: #fff;
}
.c-breadcrumb_inner a:hover {
  text-decoration: underline;
}
.c-breadcrumb_inner span::before {
  display: inline-block;
  width: 6px;
  height: 6px;
  margin-right: 10px;
  margin-left: 4px;
  content: "";
  transform: rotate(45deg);
  vertical-align: middle;
  border-style: solid;
  border-top-width: 1px;
  border-right-width: 1px;
  border-bottom-width: 0;
  border-left-width: 0;
}
.c-breadcrumb_inner span:first-child::before {
  display: none;
}

.c-post_icon {
  width: clamp(10px, 9.1px + 0.2vw, 12px);
  height: auto;
}

.c-post_title {
  border-bottom: 2px dotted #00A0C1;
  padding-top: 25px;
  padding-bottom: 25px;
  padding-left: 30px;
}

.c-post_content {
  margin-top: 40px;
  margin-bottom: 200px;
}
.c-post_content > * {
  max-width: 100%;
}

.c-post_btn-archive a {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  -moz-column-gap: 10px;
       column-gap: 10px;
}
.c-post_btn-archive a::after {
  display: inline-block;
  content: "";
  width: clamp(10px, 9.1px + 0.2vw, 12px);
  height: clamp(10px, 9.1px + 0.2vw, 12px);
  background-image: url(../img/common/icon-triangle.png);
  background-size: contain;
  background-repeat: no-repeat;
  transition: transform 0.3s ease;
}
.c-post_btn-archive a:hover {
  opacity: 0.8;
}
.c-post_btn-archive a:hover::after {
  transform: translateX(5px);
}

.c-pagenavi_prev {
  position: relative;
}
.c-pagenavi_prev::before {
  position: absolute;
  top: 50%;
  left: -20px;
  transform: translateY(-50%) rotate(180deg);
  width: clamp(10px, 9.1px + 0.2vw, 12px);
  height: clamp(10px, 9.1px + 0.2vw, 12px);
  background-image: url(../img/common/icon-triangle.png);
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
}

.c-pagenavi_next {
  position: relative;
}
.c-pagenavi_next::after {
  position: absolute;
  top: 50%;
  right: -20px;
  transform: translateY(-50%);
  width: clamp(10px, 9.1px + 0.2vw, 12px);
  height: clamp(10px, 9.1px + 0.2vw, 12px);
  background-image: url(../img/common/icon-triangle.png);
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
}

/* table
======================================================== */
.c-table {
  width: min(100%, 600px);
  margin-left: auto;
  margin-right: auto;
}
.c-table tr {
  border: solid 1px #ffe4be !important;
}
@media screen and (min-width: 768px) {
  .c-table tr {
    border: none !important;
  }
}

.c-table_th {
  font-size: clamp(15px, 14.6px + 0.1vw, 16px);
  font-weight: 400;
  padding: 1em;
  border: none !important;
  text-align: center !important;
}
@media screen and (min-width: 768px) {
  .c-table_th {
    border: solid 1px #ffe4be !important;
    text-align: left !important;
  }
}

.c-table_th-large {
  font-size: clamp(15px, 13.7px + 0.3vw, 18px);
  font-family: "M PLUS 1p", sans-serif;
  font-weight: 700;
}

.c-table_td {
  font-size: clamp(15px, 14.6px + 0.1vw, 16px);
  padding: 1em;
  border: none !important;
  text-align: center !important;
}
@media screen and (min-width: 768px) {
  .c-table_td {
    border: solid 1px #ffe4be !important;
    text-align: left !important;
  }
}
.c-table_td.cell-line {
  border: solid 1px #ffe4be !important;
}
.c-table_td.cell-center {
  text-align: center !important;
}

/* top
======================================================== */
@keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fade-in-blur {
  0% {
    opacity: 0;
    filter: blur(12px);
  }
  100% {
    opacity: 1;
    filter: blur(0);
  }
}
@keyframes fade-in-drop {
  0% {
    opacity: 0;
    transform: translateX(50%) translateY(-30px);
  }
  70% {
    opacity: 1;
    transform: translateX(50%) translateY(6px);
  }
  100% {
    opacity: 1;
    transform: translateX(50%) translateY(0);
  }
}
@keyframes fade-in-up-after {
  0% {
    opacity: 0;
    transform: translateX(-50%) translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}
@keyframes bounce-in {
  0% {
    opacity: 0;
    transform: translateY(30px) scale(0.95);
  }
  60% {
    opacity: 1;
    transform: translateY(-8px) scale(1.02);
  }
  80% {
    transform: translateY(4px) scale(0.99);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@keyframes float {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-12px);
  }
}
@keyframes float-before {
  0%, 100% {
    transform: translateX(50%) translateY(0);
  }
  50% {
    transform: translateX(50%) translateY(-12px);
  }
}
.top-mainvisual {
  position: relative;
  background-color: var(--wp--preset--color--soft-beige);
  overflow: hidden;
  z-index: 0;
  padding-bottom: 60px;
}
@media screen and (min-width: 768px) {
  .top-mainvisual {
    padding-bottom: 200px;
  }
}
.top-mainvisual::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: auto;
  aspect-ratio: 750/254;
  background-image: url(../img/page/top/img-mainvisual_bottom-sp.png);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  content: "";
  opacity: 0;
  animation: fade-in-up-after 0.8s ease 1.8s both;
}
@media screen and (min-width: 768px) {
  .top-mainvisual::after {
    bottom: -215px;
    aspect-ratio: auto;
    background-size: contain;
    background-position: center;
    width: 100%;
    height: min(100%, 1200px);
    background-image: url(../img/page/top/img-mainvisual_bottom.png);
  }
}
.top-mainvisual .unitone-section > [data-unitone-layout~=gutters] > [data-unitone-layout~=container] {
  padding-left: 10px;
  padding-right: 10px;
}

.top-mainvisual_content {
  position: relative;
  width: min(100%, 1800px);
  background-color: #fff;
  border-radius: clamp(18px, -5.4px + 6.2vw, 72px);
  padding-top: clamp(60px, 42.7px + 4.6vw, 100px);
  padding-bottom: clamp(0px, -34.7px + 9.2vw, 80px);
}
.top-mainvisual_content::before {
  display: none;
}
@media screen and (min-width: 768px) {
  .top-mainvisual_content::before {
    display: block;
    content: "";
    position: absolute;
    top: 0;
    right: 20%;
    width: clamp(200px, 113.3px + 23.1vw, 400px);
    height: clamp(100px, 78.3px + 5.8vw, 150px);
    background-image: url(../img/page/top/img-mainvisual_top.png);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0;
    animation: fade-in 1.2s ease 2s forwards, fade-in-blur 1.2s ease 1.6s forwards, float 3s ease-in-out 2.8s infinite;
  }
}
.top-mainvisual_content::after {
  content: "";
  position: absolute;
  bottom: min(10px, 0.2vw);
  right: -9px;
  width: min(28%, 100px);
  height: min(100%, 280px);
  background-image: url(../img/page/top/img-mainvisual_right-sp.png);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 1;
  opacity: 0;
  animation: fade-in-blur 1.2s ease 1.6s forwards, float 3.5s ease-in-out 2.8s infinite;
}
@media screen and (min-width: 768px) {
  .top-mainvisual_content::after {
    bottom: -28px;
    right: -80px;
    width: clamp(300px, 256.6px + 11.6vw, 400px);
    height: 100%;
    background-image: url(../img/page/top/img-mainvisual_right.png);
  }
}

.top-mainvisual_heading {
  position: relative;
  font-size: clamp(24px, 17.1px + 1.8vw, 40px);
  font-weight: 700;
  line-height: 1.5;
  color: var(--wp--preset--color--text-dark-brown);
  margin-bottom: clamp(30px, 17px + 3.5vw, 60px);
  opacity: 0;
  animation: bounce-in 0.7s cubic-bezier(0.34, 1.56, 0.64, 1) 0.1s both;
}
.top-mainvisual_heading::before {
  content: "";
  position: absolute;
  top: clamp(-60px, -51.3px + -2.3vw, -80px);
  left: clamp(10px, 40.3px + -8.1vw, -60px);
  transform: translateX(-50%);
  width: 60px;
  height: 62px;
  background-image: url(../img/page/top/img-mainvisual_star.png);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.top-mainvisual_content .unitone-grid .wp-block-image {
  opacity: 0;
  animation: bounce-in 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
.top-mainvisual_content .unitone-grid .wp-block-image:nth-child(1) {
  animation-delay: 0.6s;
}
.top-mainvisual_content .unitone-grid .wp-block-image:nth-child(2) {
  animation-delay: 0.9s;
}
.top-mainvisual_content .unitone-grid .wp-block-image:nth-child(3) {
  animation-delay: 1.2s;
}

.top-message {
  position: relative;
  background-color: #FFFAEB;
  background-image: url(../img/page/top/bg-top_message.png);
  background-size: cover;
  background-position: bottom;
  background-repeat: no-repeat;
  z-index: 0;
  padding-top: 40px;
  padding-bottom: 80px;
}
.top-message::after {
  position: absolute;
  bottom: 89px;
  left: 0;
  font-family: "M PLUS 1p", sans-serif;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.26);
  font-size: clamp(73px, 16.6px + 15vw, 203px);
  content: "KISD MUSIC LAB";
  white-space: nowrap;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .top-message::after {
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
  }
}

.top-message_title {
  font-size: clamp(30px, 21.3px + 2.3vw, 50px);
  margin-bottom: clamp(30px, 8.3px + 5.8vw, 80px);
}

.top-message_content-title {
  font-size: clamp(22px, 16.4px + 1.5vw, 35px);
}

.top-message_content {
  width: min(100%, 1840px);
  margin-left: auto;
  margin-right: 0;
}

.top-message_columns {
  padding-left: 0;
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  .top-message_columns {
    -moz-column-gap: clamp(40px, 4.4px + 4.6vw, 60px) !important;
         column-gap: clamp(40px, 4.4px + 4.6vw, 60px) !important;
    width: min(100%, 1240px);
    margin-inline: auto;
    padding-left: max(var(--unitone--global--gutters), 20px, calc((100vw - min(1240px, 100vw)) / 2));
  }
}
@media screen and (min-width: 1241px) {
  .top-message_columns {
    width: 100vw;
    max-width: none;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: max(var(--unitone--global--gutters), 20px, calc((100vw - min(1240px, 100vw)) / 2));
  }
}

.top-message_text-col {
  padding-left: 20px;
  padding-right: 20px;
}
@media screen and (min-width: 1241px) {
  .top-message_text-col {
    flex-basis: auto !important;
    flex-grow: 0;
    flex-shrink: 0;
    width: 558px;
    max-width: 558px;
    padding-left: 0;
    padding-right: 0;
  }
}

@media screen and (min-width: 768px) {
  .top-message_image-col {
    overflow: hidden;
    margin-right: min(0px, (1240px - 100vw) / 2);
  }
}
@media screen and (min-width: 1241px) {
  .top-message_image-col {
    flex: 1 1 auto !important;
    flex-basis: auto !important;
    min-width: 0;
    margin-right: 0;
    overflow: hidden;
  }
}

.top-message_text {
  font-size: clamp(15px, 13.7px + 0.3vw, 18px);
  line-height: 1.6;
}
@media screen and (min-width: 768px) {
  .top-message_text {
    line-height: 2;
  }
}
.top-message_text + .top-message_text {
  margin-top: clamp(16px, 12.5px + 0.9vw, 24px);
}

.top-message_text {
  padding-right: var(--unitone--global--gutters);
}
@media screen and (min-width: 768px) {
  .top-message_text {
    padding-right: 0;
  }
}

.top-message_image {
  width: calc(100% - var(--unitone--global--gutters));
  height: min(100%, 170px);
  margin-left: auto;
  margin-right: 0;
  border-radius: 16px 0 0 16px;
  overflow: hidden;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .top-message_image {
    width: min(100%, 978px);
    height: 420px;
    margin: 0 !important;
  }
}
@media screen and (min-width: 1241px) {
  .top-message_image {
    width: 100%;
    max-width: none;
    height: 420px;
  }
}
.top-message_image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.top-about {
  position: relative;
  overflow: hidden;
  padding-bottom: 200px;
}
.top-about::before {
  content: "";
  position: absolute;
  inset: -20px;
  background-image: url(../img/page/top/bg-top_about-sp.png);
  background-size: cover;
  background-position: bottom;
  filter: blur(3px);
  z-index: 0;
}
@media screen and (min-width: 768px) {
  .top-about::before {
    background-image: url(../img/page/top/bg-top_about.png);
  }
}
.top-about::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  background-image: url(../img/page/top/bg-top_blog-bubble.png);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  width: max(100%, 1440px);
  aspect-ratio: 2890/397;
  height: auto;
}
.top-about > * {
  position: relative;
  z-index: 2;
}
.top-about.unitone-section > [data-unitone-layout~=gutters] > [data-unitone-layout~=container] {
  padding-right: 0 !important;
  padding-left: 0 !important;
  margin-right: auto;
  margin-left: auto;
}
.top-about [data-unitone-layout~=cluster] {
  justify-content: center !important;
}
.top-about [data-unitone-layout~=cluster] > [data-unitone-layout~=container] {
  flex: 1;
  min-width: 0;
}

.top-about_label {
  height: 100%;
  padding: clamp(40px, -31.1px + 9.3vw, 80px) clamp(16px, -44.4px + 7.9vw, 50px);
  align-items: center !important;
  -moz-column-gap: 8px !important;
       column-gap: 8px !important;
}

.top-about_heading {
  font-size: clamp(30px, 6.2px + 6.4vw, 85px);
  line-height: 1 !important;
  letter-spacing: 0.1em;
  margin: 0 !important;
}

.top-about_label-text {
  font-size: clamp(14px, 13.1px + 0.2vw, 16px);
  letter-spacing: 0.15em;
  line-height: 1.8;
  margin: 0 !important;
}

.top-about_card {
  position: relative;
  padding: clamp(16px, 1.8px + 1.9vw, 24px);
  z-index: 0;
}

.top-about_card-number {
  position: absolute;
  top: 25px;
  left: calc(50% - min(50%, 155px));
  width: -moz-fit-content;
  width: fit-content;
  height: auto;
  font-size: clamp(42px, 32px + 2.7vw, 65px);
  font-weight: 700;
  line-height: 1;
  margin-bottom: clamp(8px, 0.9px + 0.9vw, 12px);
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .top-about_card-number {
    top: 25px;
    left: 20px;
  }
}

.top-about_card-image {
  width: min(100%, 310px);
  height: auto;
  margin-bottom: clamp(12px, 4.9px + 0.9vw, 16px);
  aspect-ratio: 477/439 !important;
}
@media screen and (min-width: 768px) {
  .top-about_card-image {
    width: 100%;
  }
}
.top-about_card-image img {
  width: 100%;
  height: auto;
  aspect-ratio: 310/285;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .top-about_card-image img {
    aspect-ratio: 477/439;
  }
}

.top-about_card-title {
  display: none;
}
@media screen and (min-width: 768px) {
  .top-about_card-title {
    display: block;
    font-size: clamp(16px, 11.7px + 1.2vw, 26px);
    font-weight: 500;
    margin-top: 30px;
  }
}

.top-blog {
  position: relative;
  margin-top: -120px !important;
  z-index: 1;
  overflow-x: clip;
}
.top-blog::after {
  content: "";
  position: absolute;
  bottom: -120px;
  left: 50%;
  transform: translateX(-50%) scaleY(-1);
  background-image: url(../img/page/top/bg-top_blog-bubble.png);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  width: max(100%, 1440px);
  aspect-ratio: 2890/397;
  height: auto;
  z-index: -1;
}

.top-blog_title-wrapper {
  margin-bottom: 60px;
}

.top-blog_title {
  font-size: clamp(30px, 21.3px + 2.3vw, 50px);
}

.top-blog_list {
  display: flex !important;
  justify-content: center;
  flex-wrap: wrap;
  -moz-column-gap: 30px !important;
       column-gap: 30px !important;
}
@media screen and (min-width: 768px) {
  .top-blog_list {
    flex-wrap: nowrap;
  }
}
.top-blog_list > li {
  width: min(100%, 310px);
}
@media screen and (min-width: 768px) {
  .top-blog_list > li {
    width: min(100%, 240px);
  }
}

.top-blog_list-description > .wp-block-post-excerpt__excerpt {
  font-size: clamp(12px, 11.1px + 0.2vw, 14px) !important;
}

.top-blog_button > .wp-block-button__link {
  padding-top: 10px;
  padding-bottom: 10px;
}

.top-access {
  background-color: transparent;
  background-image: url(../img/page/top/bg-top_access.png);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding-top: 120px;
  padding-bottom: 40px;
}
@media screen and (min-width: 768px) {
  .top-access {
    padding-bottom: 120px;
  }
}

.top-access_title {
  display: flex;
  align-items: center;
  -moz-column-gap: 100px;
       column-gap: 100px;
  font-size: clamp(30px, 27.8px + 0.6vw, 35px);
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: clamp(50px, 28.3px + 5.8vw, 100px);
  z-index: 1;
}
.top-access_title::before {
  display: none;
}
@media screen and (min-width: 768px) {
  .top-access_title::before {
    content: "";
    display: inline-block;
    background-image: url(../img/page/top/bg-top_access-title_left.png);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    width: 140px;
    height: 10px;
  }
}
.top-access_title::after {
  display: none;
}
@media screen and (min-width: 768px) {
  .top-access_title::after {
    content: "";
    display: inline-block;
    background-image: url(../img/page/top/bg-top_access-title_right.png);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    width: 140px;
    height: 10px;
  }
}

.top-access_content {
  width: min(100%, 1240px);
  margin-left: auto;
  margin-right: 0;
  justify-content: center;
}

.top-access_map {
  width: min(100%, 470px) !important;
  height: auto;
  aspect-ratio: 477/440;
  overflow: hidden;
  flex: 0 0 auto !important;
}
.top-access_map iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 16px;
}
@media screen and (min-width: 768px) {
  .top-access_map {
    width: min(100%, 360px);
    height: auto;
  }
}

.p-about_top_inner {
  width: 100%;
  box-sizing: border-box;
}
@media screen and (min-width: 768px) {
  .p-about_top_inner {
    width: min(100%, 700px);
    padding-left: 30px;
    padding-right: 30px;
    flex-wrap: nowrap;
  }
}

@media screen and (min-width: 768px) {
  .p-about_top_content {
    flex-wrap: nowrap;
  }
}

.p-about_image {
  margin-left: auto !important;
  margin-right: auto !important;
}
@media screen and (min-width: 768px) {
  .p-about_image {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}

.p-about_line {
  padding-top: 50px;
  padding-bottom: 50px;
}
@media screen and (min-width: 768px) {
  .p-about_line {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

.p-lesson_pagetitle-img {
  width: clamp(68px, 68px + 0vw, 68px);
  height: auto;
}

.p-lesson_sectiontitle {
  font-size: clamp(18px, 16.3px + 0.5vw, 22px);
}

.p-blog_info {
  font-size: clamp(16px, 13.4px + 0.7vw, 22px);
}
@media screen and (min-width: 768px) {
  .p-blog_info {
    text-align: center;
  }
}

/* instructor
======================================================== */
.p-instructor_page-title {
  font-size: clamp(26px, 19.9px + 1.6vw, 40px) !important;
}

.p-instructor_page-title-en {
  padding-bottom: 20px;
}

.p-instructor_list {
  display: flex;
  flex-direction: column;
  gap: clamp(30px, 21.3px + 2.3vw, 50px);
}

.p-instructor_card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(20px, 14.8px + 1.4vw, 32px);
  background-color: #fff;
  border-radius: 20px;
  padding-left: clamp(13px, 10px + 0.8vw, 20px);
  padding-right: clamp(13px, 10px + 0.8vw, 20px);
  padding-top: clamp(20px, 11.3px + 2.3vw, 40px);
  padding-bottom: clamp(20px, 11.3px + 2.3vw, 40px);
}
@media screen and (min-width: 768px) {
  .p-instructor_card {
    flex-direction: row;
    align-items: flex-start;
    justify-content: flex-start;
  }
}

.p-instructor_image {
  width: min(100%, 228px);
  height: min(100%, 210px);
  aspect-ratio: 300/276;
  border-radius: 16px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-instructor_image {
    width: min(100%, 300px);
    height: min(100%, 276px);
    aspect-ratio: 300/276;
    border-radius: 16px;
  }
}
.p-instructor_image img {
  width: 100%;
  height: auto;
}

.p-instructor_body {
  flex: 1;
}

.p-instructor_role {
  color: var(--wp--preset--color--main-red);
  font-size: clamp(14px, 13.1px + 0.2vw, 16px);
  font-weight: 700;
  letter-spacing: 0.05em;
  margin: 0 0 8px;
}

.p-instructor_name {
  font-size: clamp(18px, 15.4px + 0.7vw, 24px);
  color: #47331C;
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
}

.p-instructor_separator {
  display: block;
  width: 100%;
  height: auto;
  margin: clamp(14px, 11.4px + 0.7vw, 20px) 0;
}

.p-instructor_comment {
  font-size: clamp(15px, 14.6px + 0.1vw, 16px);
  color: #47331C;
  line-height: 1.7;
  margin: 0 0 clamp(12px, 9.4px + 0.7vw, 18px);
}

.p-instructor_content {
  list-style: none;
  padding: 0;
  margin: 0;
}
.p-instructor_content > li {
  position: relative;
  margin-left: 0;
  padding-left: 1rem;
  color: #47331C;
  font-size: clamp(13px, 12.1px + 0.2vw, 15px);
  line-height: 1.7;
  letter-spacing: 0;
}
.p-instructor_content > li::before {
  content: "・";
  position: absolute;
  left: 0;
}

.p-instructor_highlight {
  background-color: #FFF5F7;
  border: 1px solid #E3003D;
  padding: clamp(10px, 10px + 0vw, 10px);
  margin-top: clamp(16px, 12.5px + 0.9vw, 24px);
  font-size: clamp(15px, 14.6px + 0.1vw, 16px);
  color: #47331C;
  line-height: 1.63;
}
@media screen and (min-width: 768px) {
  .p-instructor_highlight {
    background-color: #FFFAEB;
    border: 1px solid #E3003D;
  }
}

.p-voice_description {
  font-size: clamp(18px, 15.4px + 0.7vw, 24px);
}

.p-voice_sectiontitle {
  font-size: clamp(18px, 15.4px + 0.7vw, 24px);
}

.p-access_sectiontitle {
  font-size: clamp(18px, 17.1px + 0.2vw, 20px);
}

/* 共通部分 */
.case-detail .l-inner_page {
  background-color: #FDFDFD;
  padding-top: 40px;
  padding-bottom: 40px;
}
@media screen and (min-width: 768px) {
  .case-detail .l-inner_page {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}

.case-detail_inner {
  width: min(100%, 890px);
  padding-left: 20px;
  padding-right: 20px;
  margin-left: auto;
  margin-right: auto;
  background-color: #FDFDFD;
}

.case-detail_header {
  margin-bottom: 40px;
}
.case-detail_header .c-post_category {
  display: inline-block;
  font-size: clamp(1.4rem, 1.04rem + 0.5vw, 1.6rem);
  margin-bottom: 16px;
}
.case-detail_header .c-post_municipality {
  font-size: clamp(1.4rem, 1.04rem + 0.5vw, 1.6rem);
}
.case-detail_header .c-post_title {
  font-size: clamp(2.4rem, 0.98rem + 1.9vw, 3.2rem);
}

.case-detail_content .c-post_thumbnail {
  width: 100%;
}
.case-detail_content .c-post_thumbnail img {
  transition: none;
}
.case-detail_content .c-post_thumbnail:hover img {
  transform: none;
}
.case-detail_content .c-post_point {
  font-size: clamp(1.8rem, 0.73rem + 1.4vw, 2.4rem);
  margin-bottom: 20px;
}
.case-detail_content .c-post_point::before {
  content: "◆";
  display: inline-block;
  font-size: clamp(1.8rem, 0.73rem + 1.4vw, 2.4rem);
  color: #C2A878;
}
.case-detail_content .c-post_point::after {
  content: "◆";
  display: inline-block;
  font-size: clamp(1.8rem, 0.73rem + 1.4vw, 2.4rem);
  color: #C2A878;
}
.case-detail_content .c-post_point-detail {
  font-size: clamp(1.4rem, 1.04rem + 0.5vw, 1.6rem);
}

.case-detail_article {
  margin-top: 40px;
}
.case-detail_article h2 {
  font-size: clamp(2rem, 1.29rem + 0.9vw, 2.4rem);
  margin-top: 40px;
  margin-bottom: 20px;
}
.case-detail_article h2:first-child {
  margin-top: 0;
}
.case-detail_article h2::before {
  content: "◆";
  display: inline-block;
  font-size: clamp(2rem, 1.29rem + 0.9vw, 2.4rem);
  color: #C2A878;
}
.case-detail_article h2::after {
  content: "◆";
  display: inline-block;
  font-size: clamp(2rem, 1.29rem + 0.9vw, 2.4rem);
  color: #C2A878;
}
.case-detail_article h3 {
  font-size: clamp(1.8rem, 1.44rem + 0.5vw, 2rem);
  margin-top: 32px;
  margin-bottom: 16px;
}
.case-detail_article h3::before {
  content: "◆";
  display: inline-block;
  font-size: clamp(1.8rem, 1.44rem + 0.5vw, 2rem);
  color: #C2A878;
}
.case-detail_article h3::after {
  content: "◆";
  display: inline-block;
  font-size: clamp(1.8rem, 1.44rem + 0.5vw, 2rem);
  color: #C2A878;
}
.case-detail_article h4 {
  font-size: clamp(1.6rem, 1.24rem + 0.5vw, 1.8rem);
  margin-top: 24px;
  margin-bottom: 12px;
}
.case-detail_article h5, .case-detail_article h6 {
  font-size: clamp(1.4rem, 1.04rem + 0.5vw, 1.6rem);
  margin-top: 20px;
  margin-bottom: 12px;
}
.case-detail_article p {
  font-size: clamp(1.4rem, 1.04rem + 0.5vw, 1.6rem);
  line-height: 1.8;
  color: #3d4448;
  margin-top: 16px;
  margin-bottom: 16px;
}
.case-detail_article p:first-child {
  margin-top: 0;
}
.case-detail_article p:last-child {
  margin-bottom: 0;
}
.case-detail_article ul, .case-detail_article ol {
  margin-top: 16px;
  margin-bottom: 16px;
  padding-left: 24px;
}
.case-detail_article ul {
  list-style-type: disc;
}
.case-detail_article ol {
  list-style-type: decimal;
}
.case-detail_article li {
  font-size: clamp(1.4rem, 1.04rem + 0.5vw, 1.6rem);
  line-height: 1.8;
  color: #3d4448;
  margin-top: 8px;
  margin-bottom: 8px;
}
.case-detail_article li:first-child {
  margin-top: 0;
}
.case-detail_article li:last-child {
  margin-bottom: 0;
}
.case-detail_article a {
  color: #3188A5;
  text-decoration: underline;
  transition: opacity 0.3s ease;
}
.case-detail_article a:hover {
  opacity: 0.7;
}
.case-detail_article strong, .case-detail_article b {
  font-weight: 700;
  color: #3d4448;
}
.case-detail_article em, .case-detail_article i {
  font-style: italic;
}
.case-detail_article blockquote {
  margin: 24px 0;
  padding: 16px 20px;
  border-left: 4px solid #C2A878;
  background-color: #f9f9f9;
  font-size: clamp(1.4rem, 1.04rem + 0.5vw, 1.6rem);
  line-height: 1.8;
  color: #3d4448;
}
.case-detail_article blockquote p {
  margin: 0;
}
.case-detail_article blockquote p:not(:last-child) {
  margin-bottom: 12px;
}
.case-detail_article figure {
  margin: 24px 0;
}
.case-detail_article figure img {
  width: 100%;
  height: auto;
  display: block;
}
.case-detail_article figcaption {
  font-size: clamp(1.2rem, 0.84rem + 0.5vw, 1.4rem);
  color: #3d3b54;
  text-align: center;
  margin-top: 8px;
}
.case-detail_article table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: clamp(1.4rem, 1.04rem + 0.5vw, 1.6rem);
}
.case-detail_article th, .case-detail_article td {
  padding: 12px 16px;
  border: 1px solid #ddd;
  text-align: left;
}
.case-detail_article th {
  background-color: #f5f5f5;
  font-weight: 700;
  color: #3d4448;
}
.case-detail_article hr {
  margin: 32px 0;
  border: none;
  border-top: 1px solid #ddd;
}
.case-detail_article code {
  font-family: monospace;
  font-size: clamp(1.3rem, 0.94rem + 0.5vw, 1.5rem);
  background-color: #f5f5f5;
  padding: 2px 6px;
  border-radius: 3px;
  color: #3d4448;
}
.case-detail_article pre {
  margin: 24px 0;
  padding: 16px;
  background-color: #f5f5f5;
  border-radius: 4px;
  overflow-x: auto;
  font-size: clamp(1.3rem, 0.94rem + 0.5vw, 1.5rem);
  line-height: 1.6;
}
.case-detail_article pre code {
  background-color: transparent;
  padding: 0;
}
.case-detail_article .wp-block-image {
  margin: 24px 0;
}
.case-detail_article .wp-block-quote {
  margin: 24px 0;
}
.case-detail_article .wp-block-table {
  margin: 24px 0;
}

.case-detail_button-wrappper {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 40px;
}

.case-detail_button {
  display: flex;
  align-items: center;
  color: #314B70;
  font-size: clamp(1.4rem, 1.04rem + 0.5vw, 1.6rem);
  font-weight: 700;
  background-color: #F2F6FF;
  padding: 10px 60px;
  border-radius: 50px;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
  position: relative;
}
.case-detail_button::after {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background-image: url(../img/common/icon-arrow.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  margin-left: 10px;
  vertical-align: middle;
}
.case-detail_button:hover {
  transform: translateY(3px);
  transition: transform 0.3s ease;
}

.case-detail_url-wrapper {
  margin-top: 40px;
}

.case-detail_url {
  color: #314B70;
  font-size: clamp(1.4rem, 1.04rem + 0.5vw, 1.6rem);
  font-weight: 700;
  text-decoration: underline;
}

.case-filter_body {
  display: flex;
  flex-direction: column;
  row-gap: 30px;
}
@media screen and (min-width: 768px) {
  .case-filter_body {
    row-gap: 16px;
  }
}

.case-filter_categories {
  display: flex;
  flex-direction: column;
  -moz-column-gap: 10px;
       column-gap: 10px;
}
@media screen and (min-width: 768px) {
  .case-filter_categories {
    flex-direction: row;
  }
}

.case-filter_list {
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: 10px;
       column-gap: 10px;
  row-gap: 10px;
}

.case-filter_title {
  width: 10em;
  margin-bottom: 10px;
  color: #314B70;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .case-filter_title {
    margin-right: 10px;
    padding-top: 10px;
  }
}

.case-filter_item {
  background-color: #F2F6FF;
  padding: 5px 10px;
  border-radius: 50px;
  text-align: center;
  color: #314B70;
}
@media screen and (min-width: 768px) {
  .case-filter_item {
    padding: 10px 30px;
  }
}
.case-filter_item.active {
  background-color: #D9E6FF;
}

/* privacy
======================================================== */
.privacy-inner {
  width: min(100%, 1240px);
  margin-left: auto;
  margin-right: auto;
  padding-top: 150px;
  padding-bottom: 120px;
  padding-left: 16px;
  padding-right: 16px;
}
@media screen and (min-width: 768px) {
  .privacy-inner {
    padding-top: 200px;
    padding-left: 20px;
    padding-right: 20px;
  }
}

.privacy-title {
  font-size: clamp(2.4rem, 0.27rem + 2.8vw, 3.6rem);
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
  margin-bottom: 60px;
}

.privacy-content {
  margin-bottom: 40px;
}

.privacy-subtitle {
  font-size: clamp(1.8rem, 0.73rem + 1.4vw, 2.4rem);
  font-weight: 700;
  line-height: 1.33;
  margin-bottom: 20px;
}

.privacy-text {
  font-size: clamp(1.4rem, 1.22rem + 0.2vw, 1.5rem);
  line-height: 1.25;
  margin-bottom: 1rem;
}
.privacy-text.bold {
  font-weight: 700;
}
.privacy-text.space {
  margin-bottom: 2rem;
}
.privacy-text a {
  color: #3d4448;
  text-decoration: underline;
}

.privacy-list {
  padding-left: 2rem;
  margin-bottom: 1rem;
}
@media screen and (min-width: 768px) {
  .privacy-list {
    padding-left: 3rem;
  }
}
.privacy-list li {
  margin-bottom: 0.5rem;
  list-style: disc;
}
/*# sourceMappingURL=maps/style.css.map */
