@charset "UTF-8";
/* CSS Document */
@media (max-width: 667px) {
  body {
    font-size: 1.4rem;
  }
  .nav {
    display: none;
  }
  .sp-br {
    display: block;
  }
  .pc-br {
    display: none;
  }
  /*ハンバーガーメニュー*/
  .mobile {
    display: block;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 9999;
  }
  #panel-btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    position: relative;
    width: 50px;
    height: 50px;
    margin: 0;
    background: var(--b1);
  }
  .panel-btn-wrap {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    height: 25px;
    width: 20px;
  }
  .menu_text {
    font-size: 1rem;
    text-align: center;
    color: #fff;
    letter-spacing: 0;
  }
  #panel-btn-icon {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 20px;
    height: 1px;
    background-color: #fff;
    transition: .3s;
  }
  #panel-btn-icon:before {
    display: block;
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 20px;
    height: 1px;
    background: #fff;
    transition: .3s;
    margin-top: 5px;
  }
  #panel-btn .close {
    transform: rotate(-135deg);
    margin-top: 5px;
  }
  #panel-btn .close:before {
    transform: rotate(-90deg);
    margin-top: 0;
  }
  #panel {
    display: block;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: var(--g);
    position: fixed;
    top: 0;
    right: -100%;
    padding: 30% 5% 10%;
    z-index: 999;
    transition: 0.6s;
    font-size: 1.6rem;
  }
  #panel.block {
    right: 0;
    opacity: 1;
  }
  #panel ul {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: min(3vw, 20px);
    margin-bottom: 20%;
    li {
      font-size: 1.6rem;
      margin-right: 0;
    }
  }
  .sptel_button {
    background-color: #fff;
    color: var(--b1);
    display: flex;
    align-items: center;
    padding: 12px 25px 12px 12px;
    border-radius: 100px;
    width: fit-content;
    margin: 0 auto;
    gap: 10px;
  }
  .sptel-number {
    font-size: 2.2rem;
    font-weight: 700;
    display: block;
    line-height: 1;
    white-space: nowrap;
  }
  .sptel-hours {
    font-size: 1.2rem;
    line-height: 1;
  }
  .phone-icon {
    width: 44px;
    height: 44px;
  }
  .logo {
    width: 140px;
  }
  .head {
    margin: 3% 0 0 5%;
	width: auto;
  }
  .line_btn {
    padding: 8px 10px;
    font-size: 1.2rem;
    gap: 5px;
    img {
      width: 24px;
    }
  }
  .top_hero {
    display: block;
    margin-top: 90px;
  }
  .hero_textbox {
    width: 95%;
    margin-right: 5vw;
    padding-top: 0;
    margin-bottom: 45px;
  }
  .catch_bigtext {
    font-size: min(7.1vw, 3.5rem);
  }
  .catch_copy {
    font-size: clamp(1.4rem, 3.86vw, 2rem);
  }
  .fukidasi {
    right: 0;
    bottom: 95%;
  }
  .hero_pic {
    width: 80%;
    margin: 0 0 0 auto;
  }
  .hero_sub_copy_wrap {
    margin-bottom: 7px;
  }
  .top_eyecatch {
    width: clamp(95px, 25%, 150px);
    aspect-ratio: 4/3;
    overflow: clip;
    border-radius: 5px;
  }
  .top_list_date {
    font-size: 1.2rem;
    margin-bottom: 3px;
  }
  .top_news_text {
    width: 72%;
    font-size: 1.4rem;
  }
  .top_news_li {
    padding-bottom: 10px;
  }
  .top02_inner {
    margin-top: 35px;
  }
  .three_box {
    border-radius: 12vw;
    padding: 7%;
    display: block;
  }
  .three_pic {
    width: 30%;
    margin: 0 auto 2%;
  }
  .three_textbox {
    width: 100%;
  }
  .three_text {
    font-size: 1.4rem;
  }
  .three_title {
    display: flex;
    justify-content: center;
    line-height: 1.5;
  }
  .top03 {
    display: block;
  }
  .top03_pic {
    margin-right: 0;
    margin-bottom: 45px;
    width: 80%;
  }
  .top03_textbox {
    padding-top: 0;
    margin-left: 5%;
  }
  .top03_list {
    font-size: clamp(1.6rem, 4.35vw, 2.2rem);
    padding: 0.5em 0.7em 0.5em 38px;
    &::before {
      background-size: 22px;
      width: 22px;
      height: 22px;
    }
  }
  .girl01 {
    bottom: 5%;
    right: 0;
    width: min(17vw, 90px);
  }
  .top04 {
    width: 100%;
    padding-bottom: 10%;
  }
  .formula {
    margin: 40px 0;
    flex-direction: column;
    gap: 10px;
  }
  .formula_text {
    font-size: 5.8vw;
    padding: 1.2em 1em;
  }
  .kakeru {
    font-size: 9.6vw;
  }
  .equal {
    font-size: 9.6vw;
    writing-mode: vertical-rl;
  }
  .formula_circle {
    width: 39vw;
    height: 39vw;
    font-size: 9.6vw;
  }
  .top04_pic {
    width: 38.35%;
  }
  .top04_text {
    width: 58%;
    font-size: 1.4rem;
    line-height: 1.6;
  }
  .top04_inner {
    padding: 10% 5%;
    box-shadow: var(--b2) 5cqw 10cqw;
  }
  .pen {
    left: 5px;
    top: auto;
    bottom: 2%;
    width: 15vw;
  }
  .open_table th, .open_table td {
    padding: 15px 5px;
    line-height: 1.4;
    font-size: 1.2rem;
    width: 12%;
  }
  .open_table tbody tr :first-child {
    min-width: 8.5em;
  }
  .footer-content {
    flex-direction: column;
  }
  .footer-logo {
    margin-bottom: 30px;
    img {
      width: 164px;
    }
  }
  .copy {
    text-align: left;
  }
  .phone-button {
	width: 260px;
  gap: 10px;
}
  /* ////////////////sp-about//////////////////*/
  .sub_page_title {
    min-width: 210px;
    font-size: 2rem;
    box-shadow: var(--b2) 10px 10px;
  }
  .greet_text {
    font-size: 1.4rem;
  }
  .greet_pic {
    width: 36%;
    margin: 0 0 0.5em 0.7em;
  }
  .about01_greet {
    padding: 8% 3%;
  }
  .about01_pic_left {
    width: 77.6%;
  }
  .about01_pic {
    flex-direction: column;
  }
  .about01_pic_right {
    width: 77.6%;
    padding-top: 20px;
    margin: 0 0 0 auto;
  }
  .about02_illust {
    width: min(28vw, 120px);
    margin-bottom: 50px;
  }
  .about02_inner {
    padding-bottom: 80px;
  }
  .abou02_title {
    font-size: 2.2rem;
    margin-bottom: 20px;
  }
  .about02_box {
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    border-left-width: 5px;
    gap: 20px;
    margin-bottom: 60px;
  }
  .tuyomi_title {
    font-size: 1.4rem;
    ;
    margin: 0 0 0 2.5%;
    span {
      font-size: 3.5rem;
      letter-spacing: 0.1em;
    }
  }
  .tuyomi_textbox {
    width: 97.5%;
    margin-left: 2.5%;
  }
  .tuyomi_list {
    padding: 7% 7%;
    min-height: 140px;
    p {
      line-height: 1.6;
    }
  }
  .tuyomi_list_title {
    font-size: 1.6rem;
    line-height: 1.2;
  }
  .yowami_list {
    padding: 5%;
  }
  .five {
    font-size: 1.5em;
    line-height: 1;
  }
  .about03_text {
    font-size: 1.4rem;
  }
  .map_illust {
    width: min(15.5vw, 70px);
    bottom: 95%;
    right: 5%;
  }
  .map {
    aspect-ratio: 5/4;
  }
  /* ////////////////sp-lesson//////////////////*/
  .lesson01_inner {
    flex-direction: column;
  }
  .lesson01_textbox {
    width: auto;
    margin: 0 5vw 30px 0;
  }
  .lesson01_box_text {
    font-size: 1.4rem;
  }
  .lesson01_box_title {
    font-size: 1.8rem;
  }
  .lesson01_pic {
    width: 80%;
    margin: 0 0 0 auto;
  }
  .lesson02 {
    flex-direction: column-reverse;
  }
  .lesson_illust {
    left: 85%;
    top: auto;
    bottom: 0;
    width: min(14.7vw, 70px);
  }
  .lesson02_pic {
    width: 80%;
    margin-right: 0;
  }
  .lesson02_textbox {
    width: 95%;
    margin: 0 0 30px 5vw;
    padding-top: 0;
  }
  .lesson02_sub_section {
    margin-bottom: 30px;
  }
  .lesson02_text {
    margin: 20px 0;
    font-size: 1.4rem;
  }
  /* ////////////////sp-fee//////////////////*/
  .enter_price {
    font-size: 2.4rem;
  }
  .enter_fee_wrap {
    margin: 30px 0;
  }
  .fee_wrap {
    width: 90%;
  }
  .price_table th, .price_table td:not(:first-of-type) {
    padding: 15px 1%;
    font-size: clamp(1.2rem,3.38vw,1.4rem);
	font-weight: 700;
    width: auto;
    vertical-align: middle;
  }
  .price_table tbody tr :first-child {
    min-width: 1em;
    width: 1em;
	line-height: 1.2;
    padding: 10px 5px;
    font-size: 1.2rem;
  }
  .fee02_inner {
    padding: 10% 3%;
  }
  .fee02_text {
    font-size: 1.4rem;
  }
  .fee02_box {
    .formula_circle {
      width: 39vw;
      height: 39vw;
    }
  }
  .promise {
    font-size: 1.4rem;
  }
  /* ////////////////sp-contact//////////////////*/
  .contact01 {
    flex-direction: column;
    align-items: center;
  }
  .contact-button {
    width: 250px;
    gap: 10px;
    &:last-of-type {
      padding-left: 18px;
    }
  }
  .phone-number {
    font-size: 2rem;
  }
  .btn01 {
    min-width: 240px;
    height: 64px;
    &::after {
      background-size: 35px;
      width: 35px;
      height: 35px;
    }
  }
  .sumit_wrap {
    &::after {
      background-size: 35px;
      width: 35px;
      height: 35px;
    }
  }
  .submit_btn {
    width: 240px;
    height: 64px;
  }
  /* ////////////////sp-newslist//////////////////*/
  .news_eyecatch {
    width: clamp(95px, 25%, 150px);
    aspect-ratio: 4/3;
    overflow: clip;
    border-radius: 5px;
  }
  .top_list_date {
    font-size: 1.2rem;
    margin-bottom: 3px;
  }
  .newslist_li {
    padding-bottom: 10px;
    margin-bottom: 10px
  }
  .news_text {
    width: 72%;
    font-size: 1.4rem;
  }
}

