@charset "utf-8";
/*
Theme Name: ABCMusicKIDS
Description: 
Author: ON Co., Ltd.
Version: 1.0
*/
/*-root*/ :root {
  --clr-base: #333333;
  --clr-blu: #2089d2;
  --head1: clamp(1.875rem, 1.648rem + 1.14vw, 2.5rem); /*30-40*/
  --head2min: clamp(1.125rem, 0.989rem + 0.68vw, 1.5rem); /*18-24*/
  --head2: clamp(1.5rem, 1.318rem + 0.91vw, 2rem); /*24-32*/
  --fs-mid16: clamp(0.875rem, 0.83rem + 0.23vw, 1rem); /*14/16*/
  --fs-mid18: clamp(1rem, 0.955rem + 0.23vw, 1.125rem); /*16-18*/
  --fs-wid20: clamp(1.125rem, 1.08rem + 0.23vw, 1.25rem); /*18-20*/
  --wall-base: #eff9fd;
  --wall-ylw: #f4c82d;
  --wall-wblu: #c8e7ef;
  --wall-blu: #479cd7;
  --wall-gry: #e2e8f5;
  --bdr-blu: #c8e7ef;
  --boxSdw: 0 10px 0px var(--wall-wblu);
  --boxSdw_min: 0 3px 0px var(--wall-wblu);
  --easing: cubic-bezier(0.45, 0.05, 0.55, 0.95);
  --transition: .3s var(--easing);
}
/*base=====*/
body {
  font-family: 'dnp-shuei-mgothic-std', 'メイリオ', 'Meiryo', 'ＭＳ ゴシック', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
  font-size: min(3.6vw, 14px);
  width: 100%;
  overflow-x: hidden;
  background: var(--wall-base);
  color: var(--clr-base);
}
.fl {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
.jc_c {
  justify-content: center;
}
.fl_c {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
}
.ai_c {
  -ms-align-items: center;
  align-items: center;
}
figure {
  margin-bottom: 0 !important;
}
.grecaptcha-badge {
  visibility: hidden;
}
/*container
========================================================*/
#container {
  width: 100%;
  min-height: 100vh;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  overflow-x: hidden;
  background: url("images/wall-gra.png") no-repeat center top/100%;
}
#container::before {
  content: "";
  width: min(200px, 30vw);
  height: 100%;
  background: url("images/sidelogo.svg") repeat-y left top/100%;
  position: absolute;
  top: 0;
  left: min(20px, 4vw);
  opacity: .6;
}
#container > * {
  width: 100%;
}
a.cvr {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1;
}
a.udl {
  text-decoration: underline;
  text-underline-offset: 2px;
  color: var(--clr-blu);
}
#fix-contact {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) translateY(100%);
  z-index: 10;
  -webkit-transition: transform var(--transition);
  -o-transition: transform var(--transition);
  transition: transform var(--transition);
}
#fix-contact.is-show {
  transform: translateX(-50%) translateY(5%);
}
#fix-contact .contact-btn {
  width: min(110px, 15vw);
  aspect-ratio: 1/0.8505;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  margin-left: auto;
  background: var(--wall-ylw);
  clip-path: inset(0 0 round min(110px, 15vw) min(110px, 15vw) 0px 0px);
  justify-content: center;
  -ms-align-items: center;
  align-items: center;
}
#fix-contact .contact-btn span {
  width: 46%;
}
/*hum
=====================================*/
#hum-btn {
  position: fixed;
  top: 10px;
  right: 10px;
  width: min(60px, 13vw);
  aspect-ratio: 1/1;
  background: var(--clr-blu);
  z-index: 100;
  cursor: pointer;
  display: none;
  border-radius: min(20px, 3vw);
}
#hum-btn button {
  width: 50%;
  height: 3px;
  background: #fff;
  border-radius: 2px;
  position: relative;
  -webkit-transition: background var(--transition);
  -o-transition: background var(--transition);
  transition: background var(--transition);
}
#hum-btn button::before, #hum-btn button::after {
  content: "";
  width: 100%;
  height: 3px;
  border-radius: 2px;
  position: absolute;
  left: 0;
  background: #fff;
  -webkit-transition: transform var(--transition);
  -o-transition: transform var(--transition);
  transition: transform var(--transition);
  transform-origin: center;
}
#hum-btn button::before {
  top: -10px;
}
#hum-btn button::after {
  bottom: -10px;
}
#hum-btn.open button {
  background: none;
}
#hum-btn.open button::before, #hum-btn.open button::after {
  top: calc(50% - 2px);
}
#hum-btn.open button::before {
  transform: rotate(-45deg);
}
#hum-btn.open button::after {
  transform: rotate(45deg);
}
#l-nav {
  position: fixed;
  width: 100vw;
  height: 100vh;
  top: 0;
  left: 0;
  background: rgba(239, 249, 253, .8);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  z-index: 99;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: all var(--transition);
  -o-transition: all var(--transition);
  transition: all var(--transition);
  overflow-y: scroll;
}
#l-nav.is-view {
  opacity: 1;
  visibility: visible;
}
.l-nav_inner {
  width: 100%;
  min-height: 100%;
  padding: min(80px, 15vw) min(40px, 6vw) 150px;
}
.l-nav_menu li a {
  font-size: var(--fs-mid18);
  padding: min(20px, 5vw) 1em;
  display: block;
  font-weight: 600;
  letter-spacing: .05em;
}
.l-nav_menu li a::after {
  content: "";
  position: absolute;
  right: 1em;
  top: 50%;
  background: #00a9e3;
  height: calc(20px / 2);
  width: 10px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  transform: translateY(-50%) rotate(90deg);
  transform-origin: center;
}
.l-nav_btn {
  margin-top: min(50px, 10vw);
  justify-content: center;
}
.l-nav_btn .round-btn {
  width: min(400px, 100%);
}
.l-nav_btn .round-btn a {
  font-size: 1.125em;
  font-weight: 600;
  padding: 15px 10px;
}
/*header
=====================================*/
header {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
}
.head-inner {
  width: 100%;
  padding-left: min(40px, 5vw);
  padding-right: min(40px, 5vw);
  min-height: 100px;
  -ms-align-items: center;
  align-items: center;
  justify-content: space-between;
  margin-left: auto;
  margin-right: auto;
}
header .logo {
  font-size: var(--fs-mid18);
  line-height: calc(25/18);
  color: var(--clr-blu);
  letter-spacing: .05em;
}
header .logo span {
  font-size: 1.125em;
  font-weight: 700;
  padding-left: 3px;
}
.fix-nav {
  width: 100vw;
  position: fixed;
  left: 50%;
  transform: translateX(-50%) translateY(-100%);
  top: 0;
  height: 80px;
  padding: 10px;
  -webkit-transition: transform var(--transition);
  -o-transition: transform var(--transition);
  transition: transform var(--transition);
}
.fix-nav.is-show {
  transform: translateX(-50%) translateY(0);
}
.g-nav {
  height: 100%;
  -ms-align-items: center;
  align-items: center;
  justify-content: center;
}
.g-nav ul {
  gap: 10px 20px;
  background: rgba(255, 255, 255, .6);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: min(20px, 5vw) min(50px, 10vw);
  border-radius: 30px;
  border: 1px solid var(--clr-blu);
}
.g-nav a {
  color: var(--clr-blu);
  font-weight: 600;
}
/*main
=====================================*/
.wrapper {
  width: min(1300px, 100%);
  margin-left: auto;
  margin-right: auto;
  padding-left: min(20px, 3vw);
  padding-right: min(20px, 3vw);
}
.inner {
  width: min(1200px, 100%);
  margin-left: auto;
  margin-right: auto;
  padding-left: min(50px, 4vw);
  padding-right: min(50px, 4vw);
}
/*btn setting*/
.btn-wrap {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
}
.btn-wrap.cnt {
  -ms-align-items: center;
  align-items: center;
}
.round-btn {
  width: min(320px, 100%);
  font-size: var(--fs-mid18);
}
.round-btn a {
  display: block;
  background: var(--wall-ylw);
  color: #fff;
  padding: 10px;
  border-radius: 30px;
  text-align: center;
}
.round-btn.blu a {
  background: var(--wall-blu)
}
.round-btn.more a {
  padding: 15px 10px;
  font-size: var(--head2min);
}
.round-btn.mail a span {
  padding-left: 2.25em;
}
.round-btn.mail a span::before {
  content: "";
  width: 1.5em;
  aspect-ratio: 1/0.7537;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  background: url("images/icn_mail.svg") no-repeat center/100%;
}
.round-btn.arrow a::after {
  content: "";
  position: absolute;
  right: 1em;
  top: 50%;
  background: #ffffff;
  height: calc(20px / 2);
  width: 10px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  transform: translateY(-50%) rotate(90deg);
  transform-origin: center;
}
/*title setting*/
.sec-title {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
  font-weight: 600;
  gap: min(15px, 5vw);
  line-height: calc(46/32);
  text-align: center;
}
.sec-title.left {
  -ms-align-items: flex-start;
  align-items: flex-start;
  text-align: left;
}
.sec-title .min {
  color: var(--clr-blu);
  font-size: var(--head2min);
  letter-spacing: .05em;
  text-indent: .1em;
  border-bottom: 2px solid var(--wall-ylw);
}
.sec-title .mid {
  font-size: var(--head2);
  letter-spacing: .05em;
  text-indent: .1em;
}
/*border setting*/
.dot-bdr {
  background-image: radial-gradient(circle, #00a9e3 2.5px, transparent 2px);
  background-size: 15px 10px;
  background-repeat: repeat-x;
  background-position: left bottom;
  line-height: 1.5;
}
.dot-bdr.min {
  background-image: radial-gradient(circle, #00a9e3 2px, transparent 1.5px);
  background-size: 10px 5px;
}
.dot-bdr.bdr-gry {
  background-image: radial-gradient(circle, #bbcdd4 2.5px, transparent 2px);
}
/*#key
============================*/
.index-key-wrapper {
  width: 100%;
  /*   aspect-ratio:1/0.46;*/
  height: 645px;
}
.key-slide-wrap {
  width: min(calc(100vw - 300px), calc(100vw - (((100vw - 1300px)/2) + 300px)));
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
}
.key-slide-wrap::before {
  content: "";
  width: 156px;
  aspect-ratio: 1/0.5705;
  position: absolute;
  top: 0;
  left: 0;
  background: url("images/bluebird.png") no-repeat center/100%;
  transform: translateX(-100%) translateY(100%);
  transform-origin: right bottom;
  -webkit-transition: transform .3s var(--transition);
  -o-transition: transform .3s var(--transition);
  transition: transform .3s var(--transition);
}
#key-slider {
  width: 100%;
  height: 100%;
  border-top-left-radius: min(80px, 10vw);
  border-bottom-left-radius: min(80px, 10vw);
  border: 2px solid var(--wall-wblu);
  border-right: none;
  box-shadow: var(--boxSdw);
  background: var(--wall-wblu);
}
.key-inner {
  justify-content: space-between;
  height: 100%;
  z-index: 2;
}
.key-nav {
  width: 240px;
  justify-content: center;
  height: 100%;
  gap: min(20px, 3vw);
  transform: translateY(10%);
}
.key-nav .social-btn {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: flex-end;
}
.key-nav .social-btn a {
  width: min(40px, 10vw);
}
.key-nav a {
  font-size: var(--fs-mid18);
  color: var(--clr-blu);
  font-weight: 600;
  letter-spacing: .1em;
}
.slide-title {
  margin-top: auto;
  margin-left: auto;
  padding-bottom: min(75px, 20vw);
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: flex-end;
  align-items: flex-end;
  gap: 10px;
}
.slide-title p {
  font-size: var(--head1);
  /*  line-height: calc(60/40);*/
  letter-spacing: .1em;
  padding: 10px .5em;
  background: linear-gradient(90deg, #4dd3e3, #5db0ea, #2089d2);
  color: #fff;
}
.slide-title p:first-child {
  transform: translateX(-2.5em);
}
/*#index content
==============================================================*/
.index-contents {
  padding-top: min(120px, 20vw);
  padding-bottom: min(120px, 20vw);
}
.in-text, .top-text {
  letter-spacing: .025em;
  text-indent: .1em;
  line-height: 30px;
}
.top-text {
  text-align: center;
}
/*cta
========================================*/
.sec-cta-box {
  padding-bottom: min(30px, 10vw);
}
.cta-target {
  width: 20%;
}
.cta-detail-box {
  width: 80%;
  padding-left: min(30px, 5vw);
}
.cta-comment {
  -ms-align-items: flex-start;
  align-items: flex-start;
  padding-top: min(25px, 3vw);
}
.cta-comment p.in-text {
  font-size: var(--fs-mid18);
  width: calc(100% - 320px);
  padding-right: min(30px, 5vw);
}
.cta-comment .round-btn {
  width: 320px;
}
.cta-comment .round-btn a {
  font-size: 1.3333em;
}
/*index about
=======================================*/
.index-about-blc {
  padding-top: min(80px, 10vw);
}
.index-about-detail {
  gap: min(55px, 5vw);
  margin-top: min(40px, 5vw);
}
.index-about-detail .about-item {
  width: calc((100% - min(110px, 6vw))/3);
}
.about-item figure {
  overflow: hidden;
  isolation: isolate;
  border-radius: 30px;
  border: 2px solid #c8e7ef;
  box-shadow: var(--boxSdw);
}
.about-item .cmnt {
  margin-top: min(40px, 6vw);
}
.about-item .cmnt .in-title {
  font-size: var(--head2min);
  text-align: center;
  line-height: calc(36/24);
  color: var(--clr-blu);
  font-weight: 600;
}
.about-item .cmnt .in-text {
  margin-top: min(20px, 3vw);
}
/*カリキュラム*/
.index-about-curriculum {
  margin-top: min(80px, 15vw);
}
.about-curriculum-box {
  margin-top: min(50px, 5vw);
}
.about-curriculum-box .top-text span.mid {
  font-size: 1.4em;
  font-weight: 600;
}
/*index greeting
=======================================*/
.index-greeting-blc {
  padding-top: min(80px, 20vw);
  padding-bottom: min(100px, 15vw);
}
.index-greeting-blc::before {
  content: "";
  width: min(320px, 42%);
  aspect-ratio: 1/0.8478;
  position: absolute;
  top: 0;
  right: 0;
  background: url("images/thumb_curriculum.png") no-repeat center/100%;
  transform: translateY(calc(-100% + min(80px, 26vw))) translateX(10%);
  z-index: -1;
}
.index-greeting-box {
  background: #fff;
  border-radius: 30px;
  padding: min(65px, 8vw) min(65px, 5vw);
  -ms-align-items: flex-start;
  align-items: flex-start;
}
.greeting-thumb {
  width: 30%;
  border-radius: 30px;
  overflow: hidden;
  border: 1px solid var(--wall-wblu);
  aspect-ratio: 1/1.4036;
  box-shadow: var(--boxSdw);
  background: #fafafa;
}
.greeting-detail {
  width: 70%;
  padding-left: min(50px, 5vw);
}
.greeting-detail .sec-title .mid {
  font-size: clamp(1.55rem, 1.318rem + 0.5vw, 2rem);
}
.greeting-detail > * + * {
  margin-top: min(35px, 5vw);
}
.greeting-detail .sign-box {
  width: 100%;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}
.greeting-detail .sign-box .name {
  min-width: 130px;
}
.greeting-detail .sign-box .name .ja, .greeting-detail .sign-box .name .en {
  color: var(--clr-blu);
}
.greeting-detail .sign-box .name .ja {
  font-size: var(--head2min);
  margin-top: min(15px, 3vw);
}
.greeting-detail .sign-box .name .en {
  margin-top: min(10px, 2vw);
}
.greeting-detail .sign-box .sns-link {
  width: min(40px, 10vw);
}
.greeting-detail .sign-box .career {
  width: min(calc(100% - 130px));
  padding-left: min(20px, 3vw);
}
.greeting-detail .sign-box .career p {
  font-size: min(12px, 3.4vw);
  line-height: calc(18/12);
  text-align: justify;
}
/*index teacher
=======================================*/
.index-teacher-blc {
  padding-top: min(80px, 15vw);
}
.index-teacher-box {
  background: #fff;
  border-radius: 30px;
  padding: min(80px, 10vw) min(30px, 5vw);
}
.index-teacher-box .top-text {
  margin-top: min(25px, 5vw);
}
.index-teacher-box .waiting {
  margin-top: min(50px, 8vw);
  font-weight: 900;
  font-size: min(30px, 8vw);
  opacity: .8;
}
.teacher-list {
  width: min(930px, 100%);
  margin-top: min(50px, 10vw);
  gap: min(20px, 5vw) min(20px, 5vw);
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
}
.teacher-list > article {
  width: calc((100% - min(60px, 15vw))/4);
  border-radius: 30px;
  overflow: hidden;
  isolation: isolate;
  background: var(--wall-base);
}
.teacher-list > article .teacher-thumb {
  width: 100%;
  aspect-ratio: 1/0.6651;
  background: #fafafa;
}
.teacher-list > article .teacher-thumb img {
  object-fit: cover;
  height: 100%;
}
.teacher-list > * .teacher-data {
  padding: min(20px, 5vw) min(20px, 5vw) min(40px, 8vw);
}
.teacher-list > article .teacher-data > * + * {
  margin-top: 8px;
}
/*modal*/
.modal-koushi_inner {
  width: 100%;
  min-height: 100vh;
  overflow-y: scroll;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  -ms-align-items: center;
  align-items: center;
  padding: min(100px, 20vw) min(30px, 5vw) 150px;
}
.modal-koushi-detail {
  width: min(600px, 100%);
  background: #fff;
  border: 1px solid var(--bdr-blu);
  padding: min(50px, 10vw) 0 min(30px, 5vw);
  border-radius: 30px;
  box-shadow: var(--boxSdw_min);
}
.koushi-detail-head {
  padding: 0 min(50px, 5vw);
}
.koushi-detail-head::before {
  content: "";
  width: min(150px, 25%);
  aspect-ratio: 1/0.5759;
  background: url("images/glass.png") no-repeat center/100%;
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translateY(50%);
  opacity: .8;
}
.koushi-detail-head .thumb {
  width: 25%;
  aspect-ratio: 1/1;
  overflow: auto;
  border: 1px solid var(--wall-wblu);
  border-radius: 20px;
}
.koushi-detail-head .thumb img {
  object-fit: cover;
  height: 100%;
}
.koushi-detail-head .data {
  width: 75%;
  padding-left: min(30px, 5vw);
  gap: min(20px, 3vw);
}
.koushi-detail-head .data .koushi-name {
  font-weight: 600;
  line-height: 1.4;
}
.koushi-detail-head .data .koushi-name .ja {
  font-size: var(--head2);
  letter-spacing: .05em;
  color: var(--clr-blu);
}
.koushi-detail-head .data .koushi-name .en {
  font-size: var(--head2min);
  letter-spacing: .05em;
  color: var(--wall-gry);
}
.koushi-detail-head .data .links {
  justify-content: flex-end;
  gap: 10px;
  margin-top: auto;
}
.koushi-detail-head .data .links a {
  width: 2em;
  aspect-ratio: 1/1;
  border-radius: 50%;
  overflow: hidden;
  background: var(--clr-blu);
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  -ms-align-items: center;
  align-items: center;
}
.koushi-detail-head .data .links a img {
  width: 60%;
}
.koushi-detail-body {
  margin-top: min(30px, 5vw);
  padding: 0 min(50px, 5vw);
}
.koushi-detail-body > * + * {
  margin-top: min(20px, 5vw);
}
.koushi-detail-body dt {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: flex-start;
}
.koushi-detail-body dt p {
  font-size: var(--fs-mid18);
  font-weight: 600;
  padding-bottom: 5px;
  border-bottom: 2px solid var(--wall-ylw);
  border-radius: 1px;
  color: var(--clr-blu);
  letter-spacing: .05em;
}
.koushi-detail-body dd {
  margin-top: 10px;
}
.koushi-detail-body dd p {
  line-height: calc(20/14);
}
.modal-koushi-detail .btn-wrap {
  margin-top: min(30px, 10vw);
  justify-content: center;
}
/*index plan
=======================================*/
.index-plan-blc {
  padding-top: min(80px, 15vw);
  gap: min(50px, 10vw);
}
.plan-list {
  width: min(1040px, 100%);
  gap: min(80px, 15vw);
}
.plan-list::before {
  content: "";
  width: 10px;
  height: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  background-image: radial-gradient(circle, #bbcdd4 2.5px, transparent 2px);
  background-size: 10px 15px;
  background-repeat: repeat-y;
  background-position: left bottom;
  line-height: 1.5;
  transform: translate(-50%, -50%);
}
.plan-list > div {
  width: calc((100% - min(80px, 10vw))/2);
  gap: min(40px, 8vw);
}
.plan-list dt {
  font-size: var(--head2);
  color: var(--clr-blu);
  font-weight: 600;
  letter-spacing: .05em;
}
.plan-list dd {
  background: #fff;
  width: 100%;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
  padding: min(40px, 12vw) min(20px, 4vw) min(40px, 8vw);
  border-radius: 30px;
}
.plan-list dd .in-title {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%) translateY(-25%);
  border-radius: 20px;
  border: 2px solid var(--clr-blu);
  padding: 8px;
  font-weight: 600;
  background: #fff;
  width: min(200px, 100%);
  text-align: center;
}
.plan-list dd .check-list {
  width: min(400px, 100%);
}
.plan-list dd .check-list li {
  font-size: var(--fs-wid20);
  padding-left: 1.71em;
  line-height: calc(30/20);
  font-weight: 600;
}
.plan-list dd .check-list li::before {
  content: "";
  width: 1.2em;
  aspect-ratio: calc(24/25);
  background: url("images/icn_check.svg") no-repeat center/100%;
  position: absolute;
  left: 0;
  top: .15em;
}
.plan-list dd .check-list li + li {
  margin-top: 15px;
}
/*price*/
.price-box {
  gap: min(30px, 5vw);
  -ms-align-items: center;
  align-items: center;
  font-weight: 600;
}
.price-box .tag {
  font-size: var(--fs-mid18);
  gap: 10px;
}
.price-box .tag p {
  background: var(--wall-gry);
  border-radius: 10px;
  padding: min(15px, 2.5vw) min(30px, 5vw);
}
.price-box .price {
  font-size: var(--head2min);
  letter-spacing: .1em;
}
.price-box .price span {
  font-size: 1.6667em;
}
/*index studio
=======================================*/
.index-studio-blc {
  padding-top: min(80px, 15vw);
  padding-bottom: min(80px, 15vw);
}
.index-studio-box {
  border-radius: 30px;
  background: #fff;
  padding: min(80px, 10vw) min(20px, 4vw);
}
.index-studio-box .top-text {
  margin-top: min(25px, 5vw);
}
.studio-detail {
  margin-top: min(50px, 5vw);
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  width: min(870px, 100%);
  gap: min(30px, 5vw);
}
.studio-movie-box {
  width: 100%;
  aspect-ratio: 1/0.5655;
  background: var(--wall-gry);
  border-radius: 30px;
}
.studio-thumb {
  width: calc((100% - min(30px, 5vw))/2);
  aspect-ratio: 1/0.6226;
  background: var(--wall-gry);
}
.studio-movie-box img {
  object-fit: cover;
  height: 100%;
}
/*index news 
=======================================*/
.sec-info-blc {
  padding-top: min(80px, 15vw);
}
.info-tab-swich {
  justify-content: center;
  gap: min(20px, 5vw);
  margin-top: min(40px, 10vw);
}
.info-tab-swich li p {
  font-size: var(--fs-mid18);
  padding: 10px 2em;
  border-radius: 25px;
  background: #fff;
  cursor: pointer;
}
.info-tab-swich li.active p {
  background: var(--wall-ylw);
  color: #fff;
}
.tab-container {
  margin-top: min(50px, 10vw);
}
.acv-info-list {
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: min(25px, 5vw);
}
article.acv_post {
  width: calc((100% - min(50px, 10vw))/3);
}
article.acv_post .thumb {
  border-top-left-radius: 30px;
  border-top-right-radius: 30px;
  overflow: hidden;
  isolation: isolate;
  aspect-ratio: 1/.67;
}
article.acv_post .thumb img {
  object-fit: cover;
  height: 100%;
}
article.acv_post .cmnt {
  background: #fff;
  border-bottom-left-radius: 30px;
  border-bottom-right-radius: 30px;
  padding: min(20px, 5vw) min(20px, 3vw) min(40px, 8vw);
}
article .data {
  color: var(--clr-blu);
  gap: 5px 1.5em;
}
article .data .date::before {
  content: "";
  width: 1px;
  height: 1em;
  background: var(--clr-blu);
  position: absolute;
  left: -.75em;
  top: 0;
}
article .post-title {
  margin-top: 10px;
  line-height: calc(30/20);
  font-size: var(--fs-wid20);
}
.tab-panel .btn-wrap {
  margin-top: min(50px, 10vw);
}
/*index form
=====================================*/
.index-form-blc {
  padding-top: min(80px, 15vw);
}
.index-form-box {
  background: #fff;
  border-radius: 30px;
  padding: min(80px, 10vw) min(30px, 5vw);
}
.index-form-box .top-text {
  margin-top: min(30px, 5vw);
}
.form-wrap {
  width: min(940px, 100%);
  margin-top: min(50px, 10vw);
}
.form-list {}
.form-list > * + *, .form-list > .inquiry-hide > div + div {
  margin-top: min(40px, 5vw);
}
.form-list > div:not(.inquiry-hide) {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
.form-list > .inquiry-hide > div {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  width: 100%;
}
.form-list dt {
  width: 21em;
  padding-top: min(15px, 4vw);
  padding-bottom: min(15px, 4vw);
  padding-right: min(40px, 5vw);
  font-weight: 600;
}
.form-list dt p {
  padding-right: 3.5em;
  line-height: calc(26/14);
}
.form-list dt p::after {
  content: "任意";
  position: absolute;
  right: 0;
  top: 0;
  font-size: min(0.8571em, 3.4vw);
  background: var(--wall-gry);
  padding: 5px 1em;
  border-radius: 1em;
  line-height: 1;
}
.form-list dt p.must::after {
  content: "必須";
  background: var(--wall-ylw);
  color: #fff;
}
.form-list dd {
  width: calc(100% - 21em);
}
/*form setting*/
.form-list input[type="text"], .form-list input[type="email"], .form-list input[type="tel"], .form-list input[type="date"], .form-list textarea {
  background: var(--wall-base);
  font-size: 16px;
  border-radius: 5px;
  padding: min(15px, 3vw) min(20px, 4vw);
  font-family: sans-serif;
}
.form-list input[type="text"], .form-list input[type="email"], .form-list input[type="tel"] {
  width: min(400px, 100%);
}
.form-list textarea {
  width: 100%;
  height: 260px;
}
/*select*/
.form-list dd.select {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
}
.select-wrap {
  width: min(450px, 100%);
  background: var(--wall-base);
  font-size: 16px;
  border-radius: 5px;
}
.select-wrap::before {
  content: "";
  width: 6px;
  aspect-ratio: 1/1;
  border: 2px solid;
  border-color: transparent var(--clr-blu) var(--clr-blu) transparent;
  position: absolute;
  right: min(30px, 10vw);
  top: calc(50% - 5px);
  border-radius: 1px;
  transform: translateY(-50%) rotate(45deg) translateX(100%);
  transform-origin: top right;
}
.select-wrap select {
  width: 100%;
  padding: min(16px, 3vw) min(30px, 10vw) min(16px, 3vw) min(20px, 4vw);
  font-size: 16px;
  color: var(--clr-base);
}
/*date select*/
.lesson-date > * + * {
  margin-top: min(20px, 5vw);
}
.lesson-date .date-item {}
.lesson-date .date-item > * {
  width: 50%;
  -ms-align-items: center;
  align-items: center;
}
.lesson-date .date-item .date p {
  width: 5em;
}
.lesson-date .date-item .date .wpcf7-form-control-wrap {
  width: calc(100% - calc(min(14px, 3.6vw)*5));
}
.lesson-date .date-item .date input {
  width: 100%;
  min-height: 45px;
}
.lesson-date .date-item .time {
  padding-left: min(40px, 5vw);
}
.lesson-date .date-item .time p {
  width: 3.5em;
}
.lesson-date .date-item .time .select-wrap {
  width: calc((100% - calc(min(14px, 3.6vw)*3.5))/2);
}
.lesson-date .date-item .time .select-wrap::before {
  right: 1.5em;
}
.lesson-date .date-item .time .select-wrap select {
  padding-right: 1em;
}
/*radio*/
.form-list dd.radio {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
}
.form-list dd.radio .wpcf7-form-control-wrap {
  width: 100%;
}
.form-list dd.radio .wpcf7-form-control {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-align-items: center;
  align-items: center;
  gap: 15px min(30px, 5vw);
}
.form-list dd.radio .wpcf7-form-control .wpcf7-list-item {
  margin-left: 0;
}
.input.radio span.wpcf7-list-item-label {
  display: block;
  padding-left: 2.5em;
  font-size: 16px;
}
.input.radio span.wpcf7-list-item-label::before, .input.radio span.wpcf7-list-item-label::after {
  content: "";
  width: 1.5em;
  aspect-ratio: 1/1;
  background: var(--wall-base);
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.input.radio span.wpcf7-list-item-label::after {
  background: var(--clr-blu);
  width: calc(1.5em - 8px);
  left: 4px;
  opacity: 0;
}
.input.radio input:checked + span::after {
  opacity: 1;
}
/*form btn wrap*/
.form-btn-wrap {
  margin-top: min(50px, 10vw);
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
  gap: min(20px, 5vw);
}
.agree-check-wrap {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  gap: 5px;
  -ms-align-items: center;
  align-items: center;
}
.agree-check-wrap .wpcf7-list-item {
  margin-left: 0;
}
.agree-check-wrap label{
  cursor: pointer;
}
.agree-check-wrap label span{
  padding-left: 2em;
}
.agree-check-wrap label > span::before
,.agree-check-wrap label > span::after{
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  translate:0 -50%;
  width: 1.25em;
  aspect-ratio:1/1;
}
.agree-check-wrap label > span::before{
  border: 1px solid var(--clr-base);
  border-radius: 2px;
}
.agree-check-wrap label > span::after{
  background: url("images/check.svg") no-repeat center right/100%;
  translate: 25% -70%;
  scale: 1.15;
  opacity: 0;
}
.agree-check-wrap label > input:checked + span::after{
  opacity: 1;
}
.form-btn-wrap .agree {
  font-size: .875em;
  line-height: 1.4;
}
.form-btn-wrap .agree a {
  text-decoration: underline;
}
.form-btn-wrap .wpcf7-spinner {
  display: none;
}
.form-btn > div {
  display: block;
}
.form-btn > div::after {
  content: "";
  position: absolute;
  right: 1em;
  top: 50%;
  background: #ffffff;
  height: calc(20px / 2);
  width: 10px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  transform: translateY(-50%) rotate(90deg);
  transform-origin: center;
}
.form-btn > div input:disabled {
  opacity: .5;
}
.form-btn > div input {
  width: 100%;
  font-size: var(--head2min);
  background: var(--wall-ylw);
  color: #fff;
  padding: 5px;
  border-radius: 30px;
  text-align: center;
}
/*error*/
.form-list .wpcf7-not-valid-tip {
  font-size: min(0.8571em, 3.4vw);
  margin-top: 5px;
}
::placeholder {
  font-size: min(14px, 3.6vw);
  color: #c2c9c1;
}
/*footer
===========================================================================*/
footer {
  margin-top: auto;
  background: var(--wall-blu);
  color: #fff;
  padding-top: min(80px, 15vw);
}
.foot-inner {
  padding-bottom: min(80px, 20vw);
}
.footer-detail-wrap {
  justify-content: space-between;
  padding-bottom: min(60px, 10vw);
}
.footer-about {
  gap: min(30px, 5vw);
  /*  width: 56.55%;*/
  width: 50%;
}
.footer-about .site-name {
  -ms-align-items: flex-start;
  align-items: flex-start;
}
.footer-about .site-name .logo {
  width: 8em;
  background: #fff;
  border-radius: 10px;
  /*  aspect-ratio:1/.8595;*/
  aspect-ratio: 1/.75;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  -ms-align-items: center;
  align-items: center;
}
.footer-about .site-name .logo, .footer-links-wrap > .links-item.abcms .logo {
  background-size: min(1.71em, 25%);
  background-position: bottom -2px right;
  background-repeat: no-repeat;
}
.footer-about .site-name .logo {
  background-image: url("images/icn_tadpole_bl.svg");
}
.footer-links-wrap > .links-item.abcms .logo {
  background-image: url("images/icn_tadpole_grn.svg");
}
.footer-about .site-name .logo span {
  width: 55%;
}
.footer-about .site-name .cmnt {
  width: calc(100% - 8em);
  padding-left: 1em;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  gap: 10px;
}
.footer-about .site-name .cmnt p.txt {
  font-size: var(--fs-mid18);
}
.footer-about .site-name .cmnt p.txt span {
  padding-left: 5px;
  font-size: 1.333em;
  display: inline-block;
}
.footer-about .site-name .cmnt a {
  margin-left: auto;
}
.footer-about .site-name .cmnt a {
  width: min(28px, 8vw);
}
.footer-about .site-name .cmnt a.insta .st0 {
  fill: #fff;
}
.footer-about .site-name .cmnt a.insta .st1 {
  fill: var(--wall-blu);
}
.footer-cta-area {
  margin-top: auto;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: flex-start;
  align-items: flex-start;
  gap: 10px;
}
.footer-cta-area p.in-title {
  font-size: var(--head2min);
  font-weight: 600;
  letter-spacing: .1em;
}
.foot-cta-link {
  width: min(320px, 100%);
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  padding: 5px 10px;
  border-radius: 20px;
  font-size: var(--fs-mid18);
  background: var(--wall-ylw);
  letter-spacing: .05em;
}
.foot-cta-link span {
  padding-left: 2.25em;
}
.foot-cta-link span::before {
  content: "";
  width: 1.3333em;
  aspect-ratio: 18/24;
  background: url("images/icn_mail.svg") no-repeat center/100%;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.other-links {
  gap: 1em;
}
.other-links a {
  font-size: .875em;
  letter-spacing: .05em;
}
.footer-nav {
  width: 43.45%;
}
.footer-nav li a {
  font-size: var(--fs-mid18);
  padding-bottom: min(20px, 4vw);
  display: block;
}
.footer-nav li:not(:first-child) a {
  padding-top: min(15px, 3.5vw);
}
.footer-nav li a span {
  display: block;
  padding-right: 2em;
  padding-left: 1em;
}
.footer-nav li a span::after {
  content: "";
  position: absolute;
  right: 1em;
  top: 50%;
  background: #ffffff;
  height: calc(20px / 2);
  width: 10px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  transform: translateY(-50%) rotate(90deg);
  transform-origin: center;
}
.footer-links-wrap {
  gap: min(60px, 5vw);
  padding-top: min(60px, 10vw);
}
.footer-links-wrap > .links-item {
  width: calc((100% - min(60px, 5vw))/2);
  -ms-align-items: flex-start;
  align-items: flex-start;
}
.footer-links-wrap > .links-item .logo {
  width: 8em;
  background: #fff;
  border-radius: 10px;
  /*  aspect-ratio:1/.8595;*/
  aspect-ratio: 1/.75;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
  justify-content: center;
}
.footer-links-wrap > .links-item .logo span {
  width: 55%;
}
.footer-links-wrap > .links-item .cmnt {
  width: calc(100% - 8em);
  padding-left: min(30px, 5vw);
}
.footer-links-wrap > .links-item .cmnt .in-title {
  font-size: var(--fs-mid18);
  font-weight: 600;
}
.footer-links-wrap > .links-item .cmnt .in-text {
  padding-top: 1em;
  font-size: min(13px, 3.4vw);
  line-height: 1.71;
}
footer p.copy {
  font-size: .875em;
  color: #bbcdd4;
  padding: 1em;
  text-align: center;
}