@charset "UTF-8";
/* CSS Document */
html {
  font-size: 62.5%;
  overflow-x: hidden;
  scroll-behavior: smooth; }
  @media screen and (min-width: 1920px) {
    html {
      font-size: calc( 10 * 100vw / 1920); } }

body {
  position: relative;
  background-color: #fff;
  width: 100%;
  overflow: hidden;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "liga", "dlig";
  font-size: 1.6rem;
  font-weight: 400;
  color: #111; }
  @media screen and (min-width: 600px) {
    body {
      font-size: 1.6rem; } }

.body--inner {
  position: relative; }

* {
  -ms-line-break: strict;
  line-break: strict;
  -ms-word-break: normal !important;
  word-break: normal !important;
  -ms-overflow-wrap: break-word;
  overflow-wrap: break-word;
  -ms-word-wrap: break-word;
  word-wrap: break-word; }

*, *:before, *:after {
  box-sizing: border-box; }

a {
  color: inherit; }

@media screen and (max-width: 600px) {
  .spOnly {
    display: block; } }
@media screen and (min-width: 600px) {
  .spOnly {
    display: none; } }

@media screen and (max-width: 600px) {
  .pcOnly {
    display: none; } }
@media screen and (min-width: 600px) {
  .pcOnly {
    display: block; } }

.area-base {
  position: relative;
  width: 100%;
  margin: 0 auto; }

.area-container {
  position: relative;
  width: 100%;
  margin: 0 auto; }
  @media screen and (min-width: 600px) {
    .area-container {
      width: 126rem;
      max-width: calc( 100% - (2rem*2) ); } }

img {
  width: 100%;
  height: auto; }

.img-cover {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  min-height: 10rem; }

.img-fit {
  object-fit: cover;
  width: 100%;
  height: 100%; }

.ly-full {
  width: 100%;
  height: 100vh; }

.ly-p--central {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1ch; }

.ly-p--centralchild {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1.1rem;
  transform: translate(-50%, -50%); }

@media screen and (max-width: 600px) {
  .ly-spArea {
    width: calc( 100% - (5% * 2) );
    margin: 0 auto; } }

.md-topbtn {
  position: fixed;
  right: 5%;
  bottom: 9rem;
  z-index: 990;
  display: none; }
  .md-topbtn a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    border-radius: 50%;
    background-color: #4a909d;
    text-align: center;
    color: #fff; }
    .md-topbtn a img {
      width: 1.3rem;
      transform: rotate(-90deg); }
    .md-topbtn a:hover {
      background-color: #47a5b4; }
  @media screen and (min-width: 900px) {
    .md-topbtn {
      transform: translateX(50%);
      bottom: 1.2rem; }
      .md-topbtn a {
        background-color: #fff;
        color: #4a909d; }
        .md-topbtn a:hover {
          background-color: #f3f171; } }

.text--left {
  text-align: left;
  text-align: justify; }
.text--right {
  text-align: right; }
@media screen and (min-width: 600px) {
  .text--pc-left {
    text-align: left;
    text-align: justify; } }
.text--center {
  text-align: center; }
@media screen and (min-width: 600px) {
  .text--pc-center {
    text-align: center; } }
.text--LL {
  font-size: 3.2rem;
  letter-spacing: 0.05em;
  line-height: 1.4;
  font-weight: 400; }
.text--L {
  font-size: 2rem;
  letter-spacing: 0.05em;
  line-height: 1.4;
  font-weight: 400; }
.text--M {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 2;
  font-weight: 400; }
.text--S {
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
  font-weight: 400; }
.text--Mincho {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 500; }
.text--underline {
  background: linear-gradient(transparent 40%, #f3f171 40%); }
.text--weight-b {
  font-weight: 500; }
.text--ls0 {
  letter-spacing: 0em !important; }
.text--ls50 {
  letter-spacing: 0.05em !important; }
.text--ls100 {
  letter-spacing: 0.1em !important; }
.text--ls150 {
  letter-spacing: 0.15em !important; }
.text--ls200 {
  letter-spacing: 0.2em !important; }
.text--uppercase {
  text-transform: uppercase !important; }
.text--cate {
  background-color: #111;
  color: #fff;
  font-size: 1.4rem;
  line-height: 1;
  padding: 0.2rem 0.4rem;
  border-radius: 0.5rem; }
.text--tate {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl; }

.mb_SS {
  margin-bottom: 2rem; }

.pd_SS {
  padding-top: 2rem;
  padding-bottom: 2rem; }

.mb_S {
  margin-bottom: 4rem; }

.pd_S {
  padding-top: 4rem;
  padding-bottom: 4rem; }

.mb_M {
  margin-bottom: 8rem; }

.pd_M {
  padding-top: 8rem;
  padding-bottom: 8rem; }

.mb_L {
  margin-bottom: 12rem; }

.pd_L {
  padding-top: 12rem;
  padding-bottom: 12rem; }

@media screen and (min-width: 600px) {
  .mb_SS {
    margin-bottom: 3rem; }

  .pd_SS {
    padding-top: 3rem;
    padding-bottom: 3rem; }

  .mb_S {
    margin-bottom: 5rem; }

  .pd_S {
    padding-top: 5rem;
    padding-bottom: 5rem; }

  .mb_M {
    margin-bottom: 10rem; }

  .pd_M {
    padding-top: 10rem;
    padding-bottom: 10rem; }

  .mb_L {
    margin-bottom: 15rem; }

  .pd_L {
    padding-top: 15rem;
    padding-bottom: 15rem; } }
.add_slash {
  position: relative; }
  .add_slash::before {
    content: '/';
    margin-right: 0.6em; }

.title_A010 {
  position: relative;
  text-align: center; }
  .title_A010::after {
    content: "";
    position: absolute;
    bottom: -9rem;
    left: 50%;
    width: 0.1rem;
    height: 7rem;
    background-color: #111; }
  .title_A010-sub {
    font-size: 1.4rem;
    letter-spacing: 0.2em;
    margin-bottom: 1.4rem; }
  .title_A010-main {
    font-size: 3.2rem;
    line-height: 1.3;
    font-weight: 400; }
  .title_A010-type02::after {
    display: none; }
  .title_A010-typeNoline::after {
    display: none; }
  @media screen and (min-width: 600px) {
    .title_A010-type02 {
      padding-top: 8rem; }
      .title_A010-type02 .title_A010-sub {
        position: relative; }
        .title_A010-type02 .title_A010-sub::after {
          content: "";
          position: absolute;
          top: -8rem;
          left: 50%;
          width: 0.1rem;
          height: 5rem;
          background-color: #111; } }

.circle--title {
  width: 9rem;
  height: 9rem;
  background-color: #47a5b4;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  margin: 0 auto; }
  .circle--title-inner {
    display: flex;
    flex-direction: column-reverse; }
  .circle--title-main {
    font-size: 2.6rem;
    letter-spacing: 0.2em;
    margin-left: 0.2em;
    margin-bottom: 1rem; }
  .circle--title-sub {
    font-size: 1.2rem;
    letter-spacing: 0.2em;
    margin-left: 0.2em; }

.block_curiculam {
  background-image: url(../img/bg_patern04.jpg);
  background-repeat: repeat;
  border-radius: 0.5rem;
  padding: 4rem 2rem; }
  .block_curiculam dl {
    margin-top: -0.1rem;
    border-top: 0.1rem solid #b0b0b0;
    border-bottom: 0.1rem solid #b0b0b0;
    padding: 1.2rem 0;
    display: flex;
    align-items: flex-start;
    line-height: 1.5; }
    .block_curiculam dl dt {
      width: 9rem;
      letter-spacing: -0.1em; }
    .block_curiculam dl dd {
      width: calc(100% - 9rem);
      font-size: 2rem; }
      .block_curiculam dl dd .text-s {
        font-size: 1.4rem; }
      .block_curiculam dl dd .text--cate {
        margin-right: 1em; }
  .block_curiculam--times {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap; }
    .block_curiculam--times span {
      min-width: 16rem;
      margin-right: 2rem; }
  @media screen and (min-width: 600px) {
    .block_curiculam dl {
      max-width: 55rem;
      margin-left: auto;
      margin-right: auto; }
      .block_curiculam dl dt {
        width: 12rem; }
      .block_curiculam dl dd {
        width: calc(100% - 12rem); } }

.block_contact {
  text-align: center; }
  .block_contact-010 {
    color: #fff;
    font-size: 1.8rem;
    margin-bottom: 2rem; }
  .block_contact-020 {
    margin-bottom: 2rem; }
  .block_contact-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 8rem;
    background-color: #f3f171;
    border-radius: 0.5rem;
    border: solid 0.2rem #fff;
    font-size: 1.8rem;
    transition: all 0.2s ease-in-out; }
    .block_contact-btn i {
      margin-left: 1rem; }
    .block_contact-btn:hover {
      letter-spacing: 0.03em;
      background-color: #f0ed3f; }
  .block_contact-tel {
    display: block;
    border: solid 0.2rem #fff;
    border-radius: 0.5rem;
    color: #fff;
    transition: all 0.4s ease-in-out; }
    .block_contact-tel:hover {
      background-color: #156f77; }
    .block_contact-tel-title {
      width: calc(100% - 2rem);
      margin: 0 auto;
      padding: 3rem 0.5rem;
      font-size: 2rem;
      border-bottom: solid 0.2rem #fff; }
    .block_contact-tel-info {
      padding: 3rem 0.5rem; }
      .block_contact-tel-info-tel {
        margin-bottom: 3rem; }
        .block_contact-tel-info-tel-title {
          display: flex;
          align-items: center;
          justify-content: center;
          margin-bottom: 1rem; }
          .block_contact-tel-info-tel-title-icon {
            margin-right: 1.2rem;
            width: 4rem; }
        .block_contact-tel-info-tel-num {
          font-size: 3.6rem;
          letter-spacing: 0.1em; }
      .block_contact-tel-info-time {
        display: flex;
        flex-wrap: wrap;
        justify-content: center; }
        .block_contact-tel-info-time dl {
          display: flex;
          align-items: center;
          justify-content: center;
          min-width: 16rem;
          margin-bottom: 0.6rem;
          margin-right: 0.6rem; }
          .block_contact-tel-info-time dl dt {
            margin-right: 1rem; }
  @media screen and (min-width: 600px) {
    .block_contact-tel {
      display: flex;
      align-items: center; }
      .block_contact-tel-title {
        width: 30%;
        border-bottom: none; }
      .block_contact-tel-info {
        width: 70%;
        margin-top: 3rem;
        margin-bottom: 3rem;
        padding: 0 5% 0 10%;
        border-left: solid 0.1rem #fff;
        text-align: left; }
        .block_contact-tel-info-tel {
          margin-bottom: 1rem; }
          .block_contact-tel-info-tel-title {
            justify-content: flex-start; }
        .block_contact-tel-info-time {
          justify-content: flex-start; }
          .block_contact-tel-info-time dl {
            justify-content: flex-start; } }

.accordion-area {
  list-style: none;
  margin: 0 auto;
  /*アコーディオンタイトル*/
  /*アコーディオンで現れるエリア*/ }
  .accordion-area li {
    margin: 1rem 0; }
  .accordion-area section {
    margin-bottom: 2rem; }
  .accordion-area--title {
    position: relative;
    /*+マークの位置基準とするためrelative指定*/
    cursor: pointer;
    transition: all .5s ease;
    font-size: 1.8rem;
    line-height: 1.7;
    padding: 2rem 6rem 1rem 8rem;
    border-bottom: solid 0.1rem #b0b0b0;
    /*アイコンの↓*/ }
    .accordion-area--title::before {
      position: absolute;
      content: '';
      top: 2rem;
      left: 1.2rem;
      width: 4.1rem;
      height: 4.8rem;
      background-image: url(../img/icon_Q.png);
      background-size: cover; }
    .accordion-area--title::after {
      position: absolute;
      content: '\f078';
      font-family: 'Font Awesome 5 Free';
      font-weight: 900;
      top: 2rem;
      right: 2.4rem;
      color: #47a5b4; }
    .accordion-area--title.close::after {
      content: '\f00d'; }
  .accordion-area--box {
    display: none;
    /*はじめは非表示*/
    padding: 1rem 2rem 0 8rem;
    color: #156f77; }
    .accordion-area--box a {
      text-decoration: underline; }

.displayNo {
  display: none; }

.header {
  position: absolute !important;
  z-index: 990; }
  .header--logo {
    width: 45%;
    max-width: 10rem;
    margin: 0 auto;
    padding-top: 6rem;
    transition: all 0.2s ease-in-out; }
    .header--logo:hover {
      opacity: 0.85; }
  .header--tel {
    position: relative;
    color: #515151;
    margin-left: 3.2rem;
    padding-left: 3.2rem;
    border-left: 0.1rem solid #111;
    width: initial;
    height: initial;
    transition: all 0.2s ease-in-out; }
    .header--tel-icon {
      width: 2.8rem;
      margin-right: 1rem; }
    .header--tel dl {
      display: flex;
      align-items: center; }
    .header--tel dt {
      display: flex;
      align-items: center;
      margin-bottom: rem;
      margin-right: 1rem; }
    .header--tel dd {
      font-size: 1.8rem;
      letter-spacing: 0.1em; }
    .header--tel:hover dd {
      color: #df2282; }
  @media screen and (min-width: 600px) {
    .header {
      padding: 3rem 4rem;
      display: flex;
      justify-content: space-between;
      align-items: center; }
      .header--left {
        display: flex;
        justify-content: flex-start;
        align-items: center; }
      .header--logo {
        width: 20rem;
        max-width: inherit;
        margin: inherit;
        padding: 0; }
      .header--btn_reserve {
        position: relative;
        background-color: #fff;
        color: #fff;
        width: inherit;
        height: inherit;
        padding: 1.2rem 2rem;
        border: solid #111 0.1rem; }
        .header--btn_reserve::after {
          content: "";
          position: absolute;
          width: calc(100% - 0.2rem);
          height: calc(100% - 0.2rem);
          top: 0.1rem;
          left: 0.1rem;
          background-color: #c26d98;
          z-index: 1;
          border: solid #111 0.1rem;
          transition: all 0.2s ease-in-out; }
        .header--btn_reserve-inner {
          display: flex;
          align-items: center;
          justify-content: center;
          position: relative;
          z-index: 10; }
        .header--btn_reserve i {
          margin-left: 0.8rem; }
        .header--btn_reserve:hover::after {
          background-color: #a34775; } }
  @media screen and (min-width: 600px) and (max-width: 900px) {
    .header--btn_reserve {
      display: none; } }

.fixed_bottom_btn {
  position: fixed;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 7rem;
  z-index: 990;
  display: none; }
  .fixed_bottom_btn--tel {
    position: fixed;
    z-index: 999;
    bottom: 0;
    left: 0;
    background-color: #4a909d;
    color: #fff;
    width: 50%;
    height: 7rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease-in-out; }
    .fixed_bottom_btn--tel-icon {
      width: 2.8rem;
      margin-right: 1rem; }
    .fixed_bottom_btn--tel dl {
      display: flex;
      align-items: center;
      flex-direction: column; }
    .fixed_bottom_btn--tel dt {
      display: flex;
      align-items: center;
      margin-bottom: 0.8rem; }
    .fixed_bottom_btn--tel dd {
      font-size: 1.8rem;
      letter-spacing: 0.1em; }
    .fixed_bottom_btn--tel:hover {
      background-color: #156f77; }
  .fixed_bottom_btn--reserve {
    position: fixed;
    bottom: 0;
    right: 0;
    background-color: #f3f171;
    color: #111;
    /*width: 50%;*/
    width: 100%;
    height: 7rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease-in-out; }
    .fixed_bottom_btn--reserve-inner {
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative; }
    .fixed_bottom_btn--reserve i {
      margin-left: 0.8rem; }
    .fixed_bottom_btn--reserve:hover {
      background-color: #f0ed3f; }
  @media screen and (min-width: 600px) {
    .fixed_bottom_btn {
      background-color: #4a909d;
      padding-top: 1rem; }
      .fixed_bottom_btn .area-container {
        display: flex;
        justify-content: center;
        align-items: center; }
      .fixed_bottom_btn--tel {
        position: relative;
        background-color: inherit;
        max-width: 38rem;
        transition: all 0.2s ease-in-out; }
        .fixed_bottom_btn--tel dl {
          flex-direction: row;
          justify-content: center;
          align-items: center; }
          .fixed_bottom_btn--tel dl dt {
            margin-bottom: 0;
            margin-right: 1.6rem; }
        .fixed_bottom_btn--tel:hover {
          background-color: #4a909d;
          color: #f3f171; }
      .fixed_bottom_btn--reserve {
        position: relative;
        height: 5rem;
        max-width: 38rem;
        border-radius: 0.5rem;
        border-color: 0.1rem solid #fff; } }

main.type010 .mv02 {
  display: none; }
main.type020 .mv01 {
  display: none; }

.mv01 {
  position: relative; }
  .mv01--area {
    position: relative;
    padding-top: 20rem;
    background-image: url(../img/decoration_dotted_righttop.png), url(../img/decoration_dotted_white_leftBottom.png), url(../img/mv01_bg_sp.jpg);
    background-position: top 0 right -86rem, bottom 0 left -21rem, center center;
    background-repeat: no-repeat,no-repeat,no-repeat;
    background-size: 300%,200%,cover; }
  .mv01--catch {
    position: relative; }
    .mv01--catch-main {
      text-align: center;
      font-weight: 400;
      color: #6b6b6c;
      margin-bottom: 2rem; }
      .mv01--catch-main-010 {
        display: block;
        font-size: 1.8rem;
        letter-spacing: 0.1em;
        padding-bottom: 0.6rem; }
      .mv01--catch-main-020 {
        display: block;
        font-size: 3.7rem;
        letter-spacing: -0.13em; }
        .mv01--catch-main-020-A010 {
          color: #48aabc;
          margin-right: -0.09em; }
          .mv01--catch-main-020-A010-01 {
            color: #7d92bd;
            font-size: 1.6em;
            margin-left: -0.07em;
            margin-right: -0.17em; }
        .mv01--catch-main-020-A020 {
          letter-spacing: 0.05em; }
    .mv01--catch-sub-text {
      margin: 0 auto;
      max-width: 50rem; }
      .mv01--catch-sub-text-inner {
        display: block;
        background-color: #c26d98;
        color: #fff;
        border-radius: 0.5rem;
        font-weight: 400;
        margin-bottom: 0.9rem;
        text-align: center;
        padding: 0.6rem;
        letter-spacing: -0.05em; }
  .mv01--visual {
    width: 70%;
    margin: 5rem auto 0; }
  .mv01--icon {
    position: relative; }
    .mv01--icon-content {
      width: 60%; }
      .mv01--icon-content--01 {
        margin: -9rem auto 0 0; }
      .mv01--icon-content--02 {
        margin: -4rem 0 0 auto; }
      .mv01--icon-content--03 {
        margin: -4rem auto 0 0; }
  @media screen and (min-width: 600px) {
    .mv01--icon {
      display: flex;
      justify-content: center;
      gap: 2rem;
      z-index: 10;
      margin-top: 2rem;
      margin-bottom: 2rem; }
      .mv01--icon-content {
        max-width: 24rem; }
        .mv01--icon-content--01 {
          margin: 0; }
        .mv01--icon-content--02 {
          margin: 0; }
        .mv01--icon-content--03 {
          margin: 0; }
    .mv01--banner {
      margin-bottom: 4rem; } }
  @media screen and (min-width: 800px) {
    .mv01 {
      background-image: url(../img/decoration_dotted_righttop.png), url(../img/decoration_dotted_white_leftBottom.png), url(../img/mv01_bg.jpg);
      background-position: top right, bottom left, center center;
      background-size: auto, auto, cover;
      background-repeat: no-repeat,no-repeat,no-repeat;
      padding: 20rem 0 10rem; }
      .mv01_2{
          padding: 20rem 0 18rem;
      }
      .mv01--inner {
        width: 50vw;
        min-width: 70rem;
        margin-left: auto; }
      .mv01--area {
        position: initial;
        background-image: none;
        padding-top: 0; }
      .mv01--catch {
        z-index: 10;
        margin-bottom: 2rem; }
        .mv01--catch-main {
          text-align: left; }
          .mv01--catch-main-010 {
            font-size: 2rem;
            padding: 0;
            padding-left: 1.4rem; }
          .mv01--catch-main-020 {
            font-size: 7.2rem;
            margin-top: -3rem; }
        .mv01--catch-sub-text {
          margin-left: 2rem;
          display: block; }
          .mv01--catch-sub-text-inner {
            font-size: 2rem;
            display: inline-block;
            letter-spacing: 0.03em;
            padding: 0.6rem 1.2rem; }
      .mv01--visual {
        position: absolute;
        bottom: 0;
        right: 55%;
        width: 63.4rem;
        z-index: 9; }
      .mv01--icon {
        margin-left: 2rem;
        justify-content: flex-start; }
      .mv01--banner {
        position: absolute;
        bottom: 2.4rem;
        left: 2.4rem;
        z-index: 20;
        max-width: 45.7rem;
        margin-bottom: 0rem;}
    .mv01--banner_2 {
        position: absolute;
        bottom: 2.4rem;
        left: 2.4rem;
        z-index: 20;
        /*max-width: 45.7rem;*/
          max-width: 92.7rem;
        margin-bottom: 0rem;
      display: flex;
      justify-content: space-around;}}
  @media screen and (min-width: 800px) and (max-width: 1160px) {
    .mv01 {
      padding: 20rem 0; }
      .mv01--inner {
        margin-left: 3rem;
        margin-right: auto; }
      .mv01--visual {
        right: calc(50% - 55rem);
        width: 56.4rem; }
      .mv01--icon-content {
        max-width: 20rem; }
      .mv01--banner {
        left: inherit;
        right: 0; } }

.mv02 {
  position: relative; }
  .mv02--area {
    position: relative;
    padding-top: 20rem;
    background-color: #eff2f7;
    background-image: url(../img/decoration_dotted_righttop.png), url(../img/decoration_dotted_white_leftBottom.png);
    background-position: top 0 right -86rem, bottom 0 left -21rem;
    background-repeat: no-repeat, no-repeat;
    background-size: 300%, 200%; }
  .mv02--catch-title01 {
    position: relative;
    text-align: center;
    font-size: 1.8rem;
    padding-bottom: 1.5rem; }
    .mv02--catch-title01-010 {
      display: block;
      margin-bottom: 1rem; }
    .mv02--catch-title01-020 {
      font-size: 1.1em;
      font-weight: 400; }
      .mv02--catch-title01-020-020 {
        color: #df2282; }
        .mv02--catch-title01-020-020-A {
          font-size: 2.25em; }
      .mv02--catch-title01-020-030 {
        font-size: 1.2em;
        margin-left: -0.1em; }
      .mv02--catch-title01-020-040 {
        font-size: 2.25em;
        color: #df2282;
        margin-left: -0.15em; }
    .mv02--catch-title01::after {
      content: "";
      position: absolute;
      bottom: -1.5rem;
      left: calc(50% - 16.8rem);
      background-image: url(../img/mv02_line.png);
      background-size: cover;
      background-repeat: no-repeat;
      background-position: center center;
      width: 33.6rem;
      height: 2.2rem; }
  .mv02--catch-title02 {
    color: #4a909d;
    font-size: 2.5rem;
    text-align: center;
    letter-spacing: -0.1em;
    padding-top: 2.4rem;
    padding-bottom: 2rem; }
    .mv02--catch-title02-020 {
      font-size: 0.62em;
      margin-left: -0.1em; }
    .mv02--catch-title02-040 {
      font-size: 1.28em; }
    .mv02--catch-title02-050 {
      margin-left: -0.2em; }
    .mv02--catch-title02-060 {
      font-size: 1.84em;
      color: #47a5b4;
      margin-left: -0.08em; }
    .mv02--catch-title02-070 {
      font-size: 1.28em;
      margin-left: -0.2em; }
  .mv02--catch-title03 {
    background-color: #f3f171;
    font-size: 1.8rem;
    padding-top: 1.4rem;
    padding-bottom: 1.4rem;
    text-align: center;
    line-height: 1.5;
    letter-spacing: -0.07em; }
    .mv02--catch-title03-010 {
      display: block; }
    .mv02--catch-title03-020 {
      display: block; }
      .mv02--catch-title03-020-A {
        color: #df2282; }
  .mv02--visual {
    width: 100%;
    padding-top: 3rem;
    margin-left: auto;
    margin-right: -2.5rem; }
  .mv02--price {
    padding-top: 1.5rem;
    padding-bottom: 1.2rem; }
    .mv02--price dl {
      display: flex;
      align-items: stretch;
      justify-content: center;
      gap: 1rem; }
    .mv02--price dt {
      display: flex;
      justify-content: center;
      align-items: center;
      background-color: #4d4d4d;
      color: #fff;
      font-size: 1.4rem;
      border-radius: 0.5rem;
      padding: 0.4rem;
      min-width: 8.7rem; }
    .mv02--price-info {
      font-size: 1.6rem;
      display: flex;
      flex-wrap: wrap;
      gap: 0.6rem; }
      .mv02--price-info-item {
        max-width: 30rem;
        /*margin-left: auto;*/
        margin:0 auto;}
      .mv02--price-info-price {
        color: #df2282;
        font-size: 2.1em;
        font-weight: 500; }
        .mv02--price-info-price-in {
          font-size: 0.5em; }
      .mv02--price-info-add {
        font-size: 0.8em;
        margin-left: -0.5em; }
  .mv02--icon {
    display: flex;
    flex-direction: column;
    gap: 1rem; }
  @media screen and (min-width: 600px) {
    .mv02--icon {
      flex-direction: row;
      justify-content: center; } }
  @media screen and (min-width: 800px) {
    .mv02 {
      background-color: #eff2f7;
      background-image: url(../img/decoration_dotted_righttop.png), url(../img/decoration_dotted_white_leftBottom.png);
      background-position: top right, bottom left;
      background-size: auto, auto;
      background-repeat: no-repeat,no-repeat,no-repeat;
      padding: 20rem 0 5rem; }
      .mv02--inner {
        display: flex;
        flex-direction: column;
        gap: 2rem; }
      .mv02--area {
        background-image: none;
        position: initial;
        padding: 0;
        order: 1; }
      .mv02--catch {
        position: relative;
        padding-left: 10vw;
        z-index: 10; }
        .mv02--catch-title01 {
          display: inline-block;
          text-align: left;
          padding-bottom: 0.8rem; }
          .mv02--catch-title01-010 {
            display: inline-block;
            margin-right: -0.15em; }
          .mv02--catch-title01::after {
            bottom: -1.5rem;
            left: 0;
            background-image: url(../img/mv02_decoration_line.png);
            background-size: cover;
            background-repeat: no-repeat;
            background-position: center center;
            width: 46.5rem;
            height: 0.5rem; }
        .mv02--catch-title02 {
          font-size: 5.3rem;
          text-align: left; }
          .mv02--catch-title02-020 {
            margin-left: -0.2em;
            font-size: 0.56em; }
          .mv02--catch-title02-030, .mv02--catch-title02-040 {
            font-size: 0.85em; }
          .mv02--catch-title02-050, .mv02--catch-title02-070 {
            font-size: 0.66em; }
          .mv02--catch-title02-060 {
            font-size: 1.245em; }
        .mv02--catch-title03 {
          font-size: 2rem;
          display: inline-block;
          padding: 0.3em 1em; }
          .mv02--catch-title03-010, .mv02--catch-title03-020 {
            display: inline-block; }
      .mv02--visual {
        position: absolute;
        bottom: 0;
        right: calc(50% - 90rem);
        width: 107.6rem;
        z-index: 9; }
      .mv02--price {
        background: white;
        background: linear-gradient(90deg, white 70%, rgba(255, 255, 255, 0) 100%);
        padding-right: 10rem;
        padding-left: 10vw;
        margin-top: 5rem;
        max-width: 70vw;
        order: 3;
        z-index: 10; }
        .mv02--price dl {
          gap: 4rem;
          justify-content: flex-start; }
          .mv02--price dl dt {
            font-size: 1.6rem;
            max-width: inherit;
            padding: 0.4rem 1rem; }
        .mv02--price-info-item {
          padding-left: 1em;
          padding-right: 1em; }
          .mv02--price-info-item:not(:last-of-type) {
            border-right: 0.1rem solid #b0b0b0; }
      .mv02--icon {
        padding-left: 10vw;
        justify-content: flex-start;
        z-index: 10;
        order: 2; }
        .mv02--icon-content {
          max-width: 16.8rem; }
      .mv02--banner {
        position: absolute;
        bottom: 2.4rem;
        right: 0;
        z-index: 20;
        /*max-width: 45.7rem;*/
          max-width: 92.7rem;
      display: flex;
      justify-content: space-around;} }
  @media screen and (min-width: 800px) and (max-width: 1300px) {
    .mv02 {
      padding-top: 15rem;
      padding-bottom: 25rem; }
      .mv02--catch {
        margin-left: 0;
        padding-left: 5%; }
      .mv02--visual {
        left: calc(10% + 40rem);
        right: initial; }
      .mv02--price {
        padding-left: 4%;
        margin-top: 0;
        max-width: inherit;
        width: 70rem;
        padding-right: 10rem; }
        .mv02--price dl {
          flex-direction: column;
          gap: 1rem; }
      .mv02--icon {
        left: 0;
        bottom: 30rem;
        padding-left: 5%; }
        .mv02--icon-content {
          max-width: 17rem; }
      .mv02--banner {
        position: absolute;
        left: 2rem;
        right: inherit;
        z-index: 20; } }

.block_start--title {
  position: relative;
  background-color: #eff2f7;
  padding: 4rem;
  min-height: 42rem;
  margin-bottom: 4rem; }
  .block_start--title-text {
    font-size: 3rem;
    font-weight: 400;
    line-height: 1.5;
    height: 36rem;
    text-align: right;
    margin-left: auto;
    margin-right: calc(50vw - 19rem); }
    .block_start--title-text-01 {
      display: block; }
    .block_start--title-text-02 {
      display: block;
      font-size: 0.8em; }
  .block_start--title-img {
    position: absolute;
    bottom: 0;
    left: calc(50% - 20rem);
    width: 25rem; }
.block_start--catch {
  text-align: center;
  font-size: 2.4rem;
  line-height: 1.5;
  margin-bottom: 4rem; }
.block_start--nayami-list-item {
  margin-bottom: 1rem; }
  .block_start--nayami-list-item-inner {
    display: block;
    line-height: 1.4;
    background-color: #ced5ea;
    padding: 1rem 2rem;
    border-radius: 0.5rem; }
.block_start--arrow {
  width: 1.6rem;
  margin: 0 auto; }
.block_start--banner {
  position: relative;
  margin-top: 5rem; }
  .block_start--banner::before {
    position: absolute;
    top: -1.6rem;
    content: "";
    width: 100%;
    height: 0.8rem;
    background-image: url(../img/diagonal_line.png); }
  .block_start--banner::after {
    position: absolute;
    bottom: -1.6rem;
    content: "";
    width: 100%;
    height: 0.8rem;
    background-image: url(../img/diagonal_line.png); }
  .block_start--banner-inner {
    background-image: url(../img/bg_mizuhiki.png), url(../img/bg_dotted_white.png), url(../img/bg_patenr01.jpg);
    background-repeat: no-repeat,no-repeat,repeat;
    background-position: right -10rem top,left bottom,center center;
    padding: 2rem; }
  .block_start--banner-text {
    font-size: 1.8rem;
    line-height: 1.4; }
    .block_start--banner-text-colorch {
      color: #47a5b4; }
    .block_start--banner-text-02 {
      color: #df2282;
      font-size: 1.5em; }
  .block_start--banner-img {
    position: absolute;
    bottom: -1.8rem;
    right: -15rem;
    width: 28rem; }
.top_bnr {
    display: flex;
    justify-content: center;
    padding:2rem 2rem 0;
    background: #eff2f7;
    }
@media screen and (min-width: 600px) {
  .block_start {
    /*margin-top: 5rem;*/ }
    .block_start--inner {
      background-color: #eff2f7;
      background-image: url(../img/kasinoha_decoration.png), url(../img/nami_decoration.png);
      background-position: top right, left bottom;
      background-repeat: no-repeat,no-repeat;
      background-size: auto ,auto;
      /*padding-top: 15rem;*/
        padding-top: 5rem;
      position: relative; }
    .top_bnr {
        width: 55%;
        margin: 0px auto;
        padding:0;
    }
    .block_start--title {
      position: initial;
      background-color: initial; }
      .block_start--title-text {
        font-size: 3.4rem;
        width: 10rem;
        height: 41rem;
        margin-left: auto;
        margin-right: auto; }
      .block_start--title-img {
        left: calc(50% - 50rem);
        width: 37rem; }
    .block_start--group {
      width: calc(50% - 13rem);
      margin-left: auto;
      margin-top: -30rem;
      padding-bottom: 8rem; }
    .block_start--catch {
      text-align: left;
      font-size: 2rem; }
    .block_start--nayami {
      margin-right: 2rem; }
      .block_start--nayami-list-item {
        margin-bottom: 1rem;
        display: block; }
        .block_start--nayami-list-item-inner {
          display: inline-block;
          line-height: 1.4;
          background-color: #fff;
          border: solid 0.1rem #111;
          padding: 1rem 2rem;
          border-radius: 0.5rem; }
    .block_start--banner-inner {
      padding: 3rem;
      background-position: right 16rem top,left bottom,center center; }
    .block_start--banner-text {
      padding-left: 14%;
      font-size: 2rem;
      line-height: 1.7; }
      .block_start--banner-text-01 {
        font-size: 1.2em; }
      .block_start--banner-text-02 {
        display: block;
        margin-top: -1rem;
        font-size: 2em; }
    .block_start--banner-img {
      bottom: -1.8rem;
      left: inherit;
      right: 10%;
      width: 28rem; } }
@media screen and (min-width: 600px) and (max-width: 1160px) {
  .block_start--group {
    width: calc(50% - 7rem);
    margin-right: 3rem; }
  .block_start--title-text {
    margin-left: auto;
    margin-right: calc(50% + 2rem); }
  .block_start--title-img {
    left: calc(50% - 42rem); } }
@media screen and (min-width: 600px) and (max-width: 715px) {
  .block_start--banner-text {
    padding-left: 0;
    padding-right: 11rem;
    font-size: 1.6rem; }
  .block_start--banner-img {
    right: -15rem; } }
@media screen and (min-width: 715px) and (max-width: 1120px) {
  .block_start--banner-text {
    padding-left: 10%;
    padding-right: 11rem;
    font-size: 1.6rem; }
  .block_start--banner-img {
    right: calc(10% - 15rem); } }

.reason--title {
  width: 100%;
  margin: 0;
  padding: 15rem 0 23rem;
  position: relative;
  text-align: center; }
  .reason--title .title_A010 {
    position: relative; }
    .reason--title .title_A010::before {
      content: "";
      position: absolute;
      top: -24rem;
      left: calc(50% - 30rem);
      width: 29.1rem;
      height: 25.5rem;
      background-image: url(../img/logo_mark_white.png);
      background-size: cover; }
  .reason--title::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-image: url(../img/bg_patern02.jpg);
    transform: skewY(-7deg);
    z-index: -1; }
.reason--content-group {
  margin-bottom: 10rem; }
  .reason--content-group-title {
    position: relative;
    margin-bottom: 5rem; }
    .reason--content-group-title-num {
      display: flex;
      justify-content: center;
      align-items: center;
      flex-direction: column-reverse;
      font-size: 1.2rem;
      letter-spacing: 0.2em;
      margin-bottom: 1.6rem; }
      .reason--content-group-title-num-num {
        display: flex;
        align-items: center;
        justify-content: center;
        background-color: #111;
        color: #fff;
        border-radius: 50%;
        width: 2.8rem;
        height: 2.8rem;
        margin-bottom: 0.4rem;
        padding-left: 0.4rem; }
    .reason--content-group-title-main {
      font-weight: 400;
      text-align: center;
      line-height: 1.3; }
      .reason--content-group-title-main-010 {
        display: block;
        color: #df2282;
        font-size: 3.2rem;
        margin-bottom: 0.8rem; }
      .reason--content-group-title-main-020 {
        font-size: 1.8rem; }
  .reason--content-group-img {
    margin-bottom: 5rem; }
  .reason--content-group-010 .reason--content-group-title::before {
    content: "";
    position: absolute;
    top: -10rem;
    left: calc(50% - 15rem);
    width: 30rem;
    height: 29.9rem;
    background-image: url(../img/reason_title_decoration010.png);
    background-size: cover;
    z-index: -1; }
  .reason--content-group-020 .reason--content-group-title::before {
    content: "";
    position: absolute;
    bottom: -9rem;
    left: -12rem;
    width: 20.6rem;
    height: 19.1rem;
    background-image: url(../img/circle_decoration02.png);
    background-size: cover;
    z-index: -1; }
  .reason--content-group-020 .reason--content-group-title::after {
    content: "";
    position: absolute;
    bottom: -18rem;
    right: -22rem;
    width: 31.2rem;
    height: 31.2rem;
    background-image: url(../img/circle_decoration03.png);
    background-size: cover;
    z-index: -1; }
  .reason--content-group-030 .reason--content-group-title::before {
    content: "";
    position: absolute;
    bottom: 8rem;
    left: 3rem;
    width: 8.2rem;
    height: 8.3rem;
    background-image: url(../img/circle_decoration04.png);
    background-size: cover;
    z-index: -1; }
  .reason--content-group-030 .reason--content-group-title::after {
    content: "";
    position: absolute;
    bottom: -18rem;
    right: -16rem;
    width: 27.7rem;
    height: 27.7rem;
    background-image: url(../img/circle_decoration05.png);
    background-size: cover;
    z-index: -1; }
  .reason--content-group-040 .reason--content-group-title::before {
    content: "";
    position: absolute;
    bottom: 1rem;
    left: -4rem;
    width: 16.5rem;
    height: 18.6rem;
    background-image: url(../img/circle_decoration06.png);
    background-size: cover;
    z-index: -1; }
  .reason--content-group-040 .reason--content-group-title::after {
    content: "";
    position: absolute;
    bottom: -18rem;
    right: -16rem;
    width: 27.7rem;
    height: 27.7rem;
    background-image: url(../img/circle_decoration05.png);
    background-size: cover;
    z-index: -1; }
@media screen and (min-width: 800px) {
  .reason--title {
    padding-bottom: 26rem; }
  .reason--content {
    margin-top: -10rem; }
    .reason--content-group {
      display: grid;
      grid-template-rows: max-content 1fr;
      grid-template-columns: 50% 50%;
      margin-bottom: 0; }
      .reason--content-group-title {
        grid-row: 1 / 2;
        grid-column: 1 / 2;
        padding: 10rem 10% 0; }
        .reason--content-group-title-main-010 {
          font-size: 3.2rem; }
        .reason--content-group-title-main-020 {
          font-size: 2rem; }
      .reason--content-group-img {
        grid-row: 1 / 3;
        grid-column: 2 / 3;
        height: 100%; }
      .reason--content-group-text {
        grid-row: 2 / 3;
        grid-column: 1 / 2;
        padding: 0 10% 10rem; }
      .reason--content-group-rev .reason--content-group-title {
        grid-row: 1 / 2;
        grid-column: 2 / 3; }
      .reason--content-group-rev .reason--content-group-img {
        grid-row: 1 / 3;
        grid-column: 1 / 2; }
      .reason--content-group-rev .reason--content-group-text {
        grid-row: 2 / 3;
        grid-column: 2 / 3; }
      .reason--content-group-010 .reason--content-group-title::before {
        top: -4rem;
        left: calc(50% - 15rem); }
      .reason--content-group-010 .reason--content-group-text::before {
        content: "";
        position: absolute;
        top: 50%;
        left: -10rem;
        width: 23.2rem;
        height: 23.4rem;
        background-image: url(../img/circle_decoration01.png);
        background-size: cover;
        z-index: -1; }
      .reason--content-group-020 .reason--content-group-title::before {
        bottom: 5rem;
        left: 4rem; }
      .reason--content-group-020 .reason--content-group-title::after {
        bottom: -28rem;
        right: -22rem; }
      .reason--content-group-030 .reason--content-group-title::before {
        bottom: 5rem;
        left: 6rem; }
      .reason--content-group-030 .reason--content-group-title::after {
        bottom: -28rem;
        right: -12rem; }
      .reason--content-group-040 .reason--content-group-title::before {
        bottom: -4rem;
        left: 7rem; }
      .reason--content-group-040 .reason--content-group-title::after {
        bottom: -34rem;
        right: -12rem; } }

.point {
  background-image: url(../img/decoration_dotted_white_leftBottom02.png), url(../img/decoration_dotted_white_rightTop02.png), url(../img/bg_patern03.jpg);
  background-repeat: no-repeat, no-repeat, repeat;
  background-position: left -6rem bottom -8rem, right -6rem top -8rem, center center;
  background-size: auto, auto, auto; }
  .point--title-inner {
    position: relative; }
  .point--title-main {
    position: relative;
    color: #fff;
    font-size: 2.6rem;
    font-weight: 400;
    z-index: 50; }
    .point--title-main-02 {
      display: block; }
      .point--title-main-02-text {
        font-size: 2.9em;
        color: #f3f171; }
      .point--title-main-02-text02 {
        font-size: 1.4em;
        color: #f3f171; }
      .point--title-main-02-text03 {
        font-size: 2em;
        color: #f3f171;
        margin-left: -0.1em;
        letter-spacing: -0.2em; }
  .point--title-catch {
    position: relative;
    margin-top: 1.6rem;
    color: #fff;
    line-height: 1.5;
    z-index: 50; }
  .point--title-img {
    position: absolute;
    right: calc(50% - 32rem);
    bottom: -5rem;
    width: 30rem; }
  .point--hyou {
    position: relative; }
    .point--hyou-overflow {
      position: relative;
      margin: 5rem 5% 0;
      z-index: 10;
      width: 100%;
      background-color: #257085;
      border-radius: 1rem;
      overflow-x: scroll; }
      .point--hyou-overflow::-webkit-scrollbar {
        height: 0.6rem; }
      .point--hyou-overflow::-webkit-scrollbar-track {
        background: #fff;
        border-radius: rem; }
      .point--hyou-overflow::-webkit-scrollbar-thumb {
        background: #999; }
    .point--hyou-inner {
      width: 89rem;
      margin: 2rem auto;
      padding: 3rem 2rem;
      display: flex;
      gap: 1rem; }
    .point--hyou-main {
      background-color: #f2e9f0;
      border-radius: 0.5rem;
      padding: 0 1rem 3rem;
      width: 38.2rem; }
      .point--hyou-main-title {
        width: 17rem;
        height: 7rem;
        margin: 0 auto; }
      .point--hyou-main-contents {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        background-color: #fff;
        padding: 0.8rem 2rem;
        height: 4rem;
        margin-bottom: 0.8rem; }
        .point--hyou-main-contents-name {
          font-size: 1.2rem;
          width: 12rem;
          color: #6b6b6b; }
        .point--hyou-main-contents-text {
          font-size: 2rem;
          color: #111; }
        .point--hyou-main-contents-text_s {
          color: #df2282; }
        .point--hyou-main-contents-text_cap {
          font-size: 1.2rem; }
    .point--hyou-sub {
      padding-top: 2rem;
      width: 21.2rem; }
      .point--hyou-sub-title {
        background-color: #3f4e4f;
        height: 4rem;
        margin-bottom: 1rem;
        border-radius: 0.5rem;
        color: #fff; }
      .point--hyou-sub-contents {
        display: flex;
        align-items: center;
        justify-content: center;
        background-color: #a1dee2;
        padding: 0.8rem 2rem;
        height: 4rem;
        margin-bottom: 0.8rem;
        border-radius: 0.5rem; }
        .point--hyou-sub-contents-text {
          font-size: 1.6rem;
          color: #111; }
        .point--hyou-sub-contents-text_cap {
          font-size: 1.2rem; }
  .point--cap p {
    margin: 3rem auto 0;
    color: #fff;
    text-align: center; }
  @media screen and (min-width: 600px) {
    .point--title {
      text-align: center; }
      .point--title-main-02 {
        margin-top: -0.4em; }
        .point--title-main-02-text {
          font-size: 3.7em; }
        .point--title-main-02-text02 {
          font-size: 1.7em; }
        .point--title-main-02-text03 {
          font-size: 2.7em;
          margin-left: 0.03em; }
      .point--title-img {
        right: calc(50% - 51rem);
        bottom: -12rem;
        width: 30rem;
        z-index: 20; }
    .point--hyou {
      margin-left: auto;
      margin-right: auto;
      z-index: 10; }
      .point--hyou-overflow {
        max-width: 126rem;
        margin-left: auto;
        margin-right: auto; } }
  @media screen and (min-width: 1000px) {
    .point--title-img {
      right: calc(50% - 47rem);
      bottom: -10rem; }
    .point--hyou-overflow {
      overflow-x: inherit; }
    .point--cap {
      display: none; } }

.item .ly-spArea {
  width: calc( 100% - (5% * 2) );
  margin: 0 auto; }
.item--title {
  width: 100%;
  margin: 0;
  padding: 0rem 0 15rem;
  position: relative;
  text-align: center; }
.item--contents-group-text-title {
  position: relative;
  line-height: 1.8;
  padding-top: 3rem;
  font-size: 2.2rem; }
  .item--contents-group-text-title-S {
    font-size: 2.6rem; }
  .item--contents-group-text-title::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 6.2rem;
    height: 1.2rem;
    background-image: url(../img/ribon_cyan.png);
    background-size: cover; }
.item--contents-group-item {
  width: 100%; }
.item--contents-group-01 .item--contents-group-text {
  padding-top: 5rem;
  padding-bottom: 5rem;
  background-color: #f1f1f2; }
  .item--contents-group-01 .item--contents-group-text-title {
    color: #13aab5; }
.item--contents-group-01 .item--contents-group-item {
  display: flex; }
  .item--contents-group-01 .item--contents-group-item .item--contents-group-01-img {
    width: 50%; }
.item--contents-group-02 {
  background-color: #a6a6a6;
  padding-top: 5rem;
  padding-bottom: 5rem; }
  .item--contents-group-02 .item--contents-group-text-title {
    color: #fff; }
    .item--contents-group-02 .item--contents-group-text-title::before {
      background-image: url(../img/ribon_white.png); }
  .item--contents-group-02 .item--contents-group-item {
    background-color: #fff;
    border-radius: 0.5rem;
    overflow: hidden;
    padding: 3rem;
    width: calc( 100% - (5% * 2)); }
    .item--contents-group-02 .item--contents-group-item ul {
      display: flex;
      flex-wrap: wrap;
      gap: 2rem; }
      .item--contents-group-02 .item--contents-group-item ul li {
        text-align: center;
        width: 15rem;
        max-width: calc(50% - 1rem);
        font-size: 1.4rem;
        line-height: 1.5; }
        .item--contents-group-02 .item--contents-group-item ul li img {
          border-radius: 1rem; }
        .item--contents-group-02 .item--contents-group-item ul li p {
          min-height: 4rem;
          display: flex;
          align-items: center;
          justify-content: center; }
.item--contents-group-03 .item--contents-group-text {
  padding-top: 5rem;
  padding-bottom: 5rem;
  background-color: #f1f1f2; }
  .item--contents-group-03 .item--contents-group-text-title {
    position: relative;
    color: #13aab5;
    margin-bottom: 8rem; }
    .item--contents-group-03 .item--contents-group-text-title-L {
      position: absolute;
      margin-top: -2.5rem;
      font-size: 7.2rem; }
.item--contents-group-03 .item--contents-group-item {
  display: flex; }
  .item--contents-group-03 .item--contents-group-item .item--contents-group-03-img {
    width: 100%; }
@media screen and (min-width: 800px) {
  .item--contents-group {
    display: flex;
    flex-direction: row-reverse; }
    .item--contents-group-text {
      width: 64rem;
      padding: 5rem 5%;
      background-color: initial !important; }
    .item--contents-group-02 {
      flex-direction: row; }
      .item--contents-group-02 .item--contents-group-item {
        border-radius: 1rem 0 0 1rem;
        padding-left: 4%;
        padding-right: 4%; }
        .item--contents-group-02 .item--contents-group-item ul {
          gap: 4rem; }
          .item--contents-group-02 .item--contents-group-item ul li {
            width: 12rem; } }

.bosyu {
  background-color: #13b1bf; }
  .bosyu .ly-spArea {
    width: calc( 100% - (5% * 2) );
    margin-left: auto;
    margin-right: auto; }
  .bosyu-area01 {
    padding-top: 15rem;
    padding-bottom: 5rem;
    background-image: url(../img/bosyuu_bg_sp.jpg);
    background-size: cover;
    background-position: center center; }
    .bosyu-area01--title-area {
      display: flex;
      justify-content: center;
      margin-bottom: 2rem; }
      .bosyu-area01--title-area-cat {
        background-color: #fff;
        color: #111;
        width: 7rem;
        text-align: center;
        padding: 0.6rem 0.4rem;
        letter-spacing: 0.2em;
        border-radius: 0.5rem;
        font-weight: 400;
        margin-left: 0.25em;
        margin-right: 0.25em; }
    .bosyu-area01--title-text {
      text-align: center;
      line-height: 1.1;
      margin-bottom: 2rem;
      font-weight: 400; }
      .bosyu-area01--title-text-010 {
        color: #fff;
        display: block;
        font-size: 4.4rem;
        letter-spacing: 0.05em; }
        .bosyu-area01--title-text-010-nentuki {
          font-weight: 500; }
        .bosyu-area01--title-text-010-tani {
          margin-right: -0.4em;
          margin-left: -0.4em;
          font-size: 2.6rem; }
      .bosyu-area01--title-text-020 {
        font-size: 5.4rem;
        letter-spacing: 0.05em;
        color: #f3f171; }
    .bosyu-area01--title-message {
      font-size: 1.6rem;
      letter-spacing: -0.1em;
      border-top: 0.1rem solid #fff;
      border-bottom: 0.1rem solid #fff;
      text-align: center;
      color: #fff;
      padding-top: 2rem;
      padding-bottom: 2rem;
      line-height: 1.6; }
  .bosyu-area02 {
    position: relative;
    background-color: #1d8892; }
    .bosyu-area02::before {
      content: "";
      position: absolute;
      top: -2.5rem;
      left: 50%;
      transform: translate(-50%) rotate(45deg);
      background-color: #13b1bf;
      width: 5rem;
      height: 5rem; }
    .bosyu-area02-naiyou-text {
      margin-top: 2rem;
      color: #fff;
      text-align: center;
      font-size: 1.6rem;
      letter-spacing: -0.1em;
      line-height: 1.5; }
    .bosyu-area02-link {
      text-align: center; }
      .bosyu-area02-link a {
        display: block;
        text-align: center;
        margin: 0 auto;
        width: 100%;
        background-color: #fff;
        text-align: center;
        color: #4a909d;
        margin-top: 4rem;
        padding: 1rem;
        border-radius: 0.5rem;
        transition: all 0.2s ease-in; }
        .bosyu-area02-link a:hover {
          background-color: #f3f171; }
  @media screen and (min-width: 600px) {
    .bosyu-area01 {
      background-image: url(../img/bosyuu_bg.jpg); }
      .bosyu-area01--title {
        position: relative;
        max-width: 65.2rem; }
        .bosyu-area01--title::after {
          content: "";
          position: absolute;
          right: -30.4rem;
          bottom: -5rem;
          width: 30.4rem;
          height: 34.9rem;
          background-image: url(../img/lady_kimono03.png);
          background-size: cover; }
        .bosyu-area01--title-area {
          margin-bottom: 0; }
        .bosyu-area01--title-text-010 {
          display: inline-block; }
        .bosyu-area01--title-text-020 {
          font-size: 7rem; }
        .bosyu-area01--title-message {
          font-size: 1.6rem; }
    .bosyu-area02--inner {
      width: 90%;
      max-width: 1540x;
      margin: 0 auto;
      display: flex;
      gap: 3rem; }
    .bosyu-area02 .bosyu-area02-naiyou {
      width: 55%;
      margin-top: 3.7rem; }
      .bosyu-area02 .bosyu-area02-naiyou .block_curiculam {
        margin-bottom: 2rem; }
    .bosyu-area02 .bosyu-area02-contact {
      width: 45%;
      min-width: 70rem; } }
  @media screen and (min-width: 600px) and (max-width: 1300px) {
    .bosyu-area02--inner {
      flex-direction: column; }
    .bosyu-area02-naiyou {
      width: 100% !important; }
    .bosyu-area02-contact {
      width: 100% !important;
      min-width: inherit !important; } }

.opinion {
  padding-bottom: 6rem; }
  .opinion--title {
    margin-bottom: 5rem; }
  .opinion--slider {
    width: calc(100% - 12rem);
    margin: 0 auto; }
    .opinion--slider .slick-prev {
      z-index: 20;
      left: -4rem;
      top: 28%; }
      .opinion--slider .slick-prev:before {
        content: '\f053';
        font-family: 'Font Awesome 5 Free';
        font-weight: 900;
        color: #111; }
    .opinion--slider .slick-next {
      z-index: 20;
      right: -4rem;
      top: 28%; }
      .opinion--slider .slick-next:before {
        content: '\f054';
        font-family: 'Font Awesome 5 Free';
        font-weight: 900;
        color: #111; }
    .opinion--slider-item {
      max-width: 30rem;
      margin-left: rem;
      margin-right: rem;
      padding-left: 2rem;
      padding-right: 2rem; }
      .opinion--slider-item-img {
        margin-bottom: 3rem; }
      .opinion--slider-item-title {
        font-size: 2.3rem;
        line-height: 1.3;
        color: #4a909d;
        margin-bottom: 2rem; }
      .opinion--slider-item-text {
        color: #333; }
  @media screen and (min-width: 600px) {
    .opinion {
      padding-bottom: 15rem; }
      .opinion--title {
        margin-bottom: 10rem; }
      .opinion--slider {
        width: 95%;
        margin: 0 auto; }
        .opinion--slider .slick-prev {
          left: calc(50% - 21rem); }
        .opinion--slider .slick-next {
          right: calc(50% - 21rem); }
        .opinion--slider-item {
          margin-left: 5rem;
          margin-right: 5rem; }
        .opinion--slider-voice {
          width: 100%;
          max-width: 30rem; } }

.instructor--title {
  padding-top: 15rem;
  padding-bottom: 15rem;
  background-image: url(../img/bg_patern02.jpg); }
.instructor--content {
  margin-top: -4rem; }
  .instructor--content-item {
    width: 70%;
    margin-left: auto;
    margin-right: auto; }
    .instructor--content-item-img {
      margin-bottom: 5rem; }
    .instructor--content-item-content-name {
      margin-bottom: 4rem; }
      .instructor--content-item-content-name-yaku {
        color: #4a909d;
        margin-bottom: 1.4rem; }
      .instructor--content-item-content-name-simei {
        display: block;
        font-size: 3.2rem;
        letter-spacing: 0.2em;
        padding-bottom: 2rem;
        border-bottom: solid 0.1rem #b0b0b0; }
        .instructor--content-item-content-name-simei span {
          font-size: 0.6em; }
    .instructor--content-item-content-text-profile {
      margin-bottom: 7rem;
      line-height: 2; }
      .instructor--content-item-content-text-profile dl {
        display: flex;
        gap: 2rem; }
        .instructor--content-item-content-text-profile dl dt {
          min-width: 8rem; }
    .instructor--content-item-content-text-message {
      color: #333; }
      .instructor--content-item-content-text-message dl {
        margin-bottom: 5rem;
        line-height: 1.5; }
      .instructor--content-item-content-text-message dt {
        border-bottom: dotted 0.1rem #4a909d;
        padding-bottom: 0.3em;
        color: #4a909d;
        font-size: 1.8rem;
        margin-bottom: 1rem; }
      .instructor--content-item-content-text-message dd {
        color: #111;
        font-size: 1.6rem;
        line-height: 2; }
@media screen and (min-width: 700px) {
  .instructor--content {
    margin-top: 15rem; }
    .instructor--content-item {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      width: 100%; }
      .instructor--content-item-img {
        width: 40%;
        margin-bottom: 0; }
      .instructor--content-item-content {
        width: 60%;
        padding-left: 10%;
        padding-top: 0rem; }
        .instructor--content-item-content-name-simei {
          display: inline-block;
          padding-right: 2em;
          font-size: 4rem; }
    .instructor--content-item--rev {
      flex-direction: row-reverse; }
      .instructor--content-item--rev .instructor--content-item-content {
        padding-left: 5%;
        padding-right: 5%; } }

.faq {
  background-color: #eff2f7; }
  .faq--title {
    margin-bottom: 5rem; }
  @media screen and (min-width: 600px) {
    .faq .area-container {
      display: flex;
      gap: 6rem; }
    .faq--title {
      padding-left: 5%;
      margin-top: -3rem;
      -ms-writing-mode: tb-rl;
      writing-mode: vertical-rl; }
      .faq--title .title_A010 {
        text-align: left;
        line-height: 2;
        position: relative; }
        .faq--title .title_A010-sub {
          position: relative; }
          .faq--title .title_A010-sub::after {
            content: "";
            position: absolute;
            top: -12rem;
            left: 50%;
            width: 0.1rem;
            height: 10rem;
            background-color: #111; }
    .faq--contents {
      width: 100%;
      max-width: 96rem;
      margin-left: auto; } }

.flow--title {
  margin-bottom: 10rem; }
.flow--content-item {
  position: relative;
  margin-bottom: 6rem; }
  .flow--content-item:not(:last-of-type)::after {
    position: absolute;
    content: '\f078';
    font-family: 'Font Awesome 5 Free';
    font-size: 2rem;
    font-weight: 600;
    bottom: -4rem;
    left: calc(50% - 0.9rem);
    color: #333; }
  .flow--content-item-flownum {
    position: relative;
    z-index: 11; }
  .flow--content-item-contents {
    background-image: url(../img/bg_patern05.jpg);
    background-repeat: repeat;
    border-radius: 0.5rem;
    padding: 8rem 2rem 4rem;
    margin-top: -4.5rem;
    z-index: 10; }
    .flow--content-item-contents-title {
      text-align: center;
      font-size: 2.2rem;
      color: #4a909d;
      margin-bottom: 2rem; }
    .flow--content-item-contents-text {
      font-size: 1.4rem;
      line-height: 2; }
@media screen and (min-width: 600px) {
  .flow--content-item {
    position: relative; }
    .flow--content-item-flownum {
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%); }
    .flow--content-item-contents {
      margin-left: 4.5rem;
      padding: 4rem 9rem;
      margin-bottom: 11rem; }
      .flow--content-item-contents-title {
        text-align: left;
        margin-bottom: 1rem; } }

.sanka {
  position: relative;
  background-image: url(../img/decoration_dotted_white_leftBottom02.png), url(../img/decoration_dotted_white_rightTop02.png), url(../img/sanka_bg.jpg), url(../img/bg_patern03.jpg);
  background-repeat: no-repeat, no-repeat, repeat, repeat;
  background-position: left -6rem bottom -8rem, right -6rem top -8rem, center center, center center;
  background-size: auto, auto, cover, auto;
  padding-top: 15rem; }
  .sanka--title {
    margin-bottom: 4rem;
    font-weight: 400; }
    .sanka--title-cate {
      display: flex;
      margin-bottom: 0.6rem; }
      .sanka--title-cate-item {
        display: flex;
        align-items: center;
        justify-content: center;
        background-color: #fff;
        width: 12rem;
        height: 2.6rem;
        border-radius: 0.5rem;
        letter-spacing: 0em;
        margin-left: 0.5em;
        margin-right: 0.5em; }
    .sanka--title-text {
      color: #fff;
      font-size: 2.7rem;
      letter-spacing: -0.02em;
      line-height: 1.4;
      display: inline-block;
      padding-bottom: 1.4rem;
      margin-left: -6%;
      padding-left: 6%;
      padding-right: 1rem;
      border-bottom: 0.1rem solid #fff; }
      .sanka--title-text-sub01 {
        font-size: 1.4em;
        color: #f3f171;
        margin-left: -0.1em;
        margin-right: -0.2em; }
      .sanka--title-text-sub02 {
        font-size: 1.4em;
        margin-left: -0.1em; }
  .sanka--list {
    color: #fff;
    margin-bottom: 8rem; }
    .sanka--list li {
      position: relative;
      padding: 1rem 0 1rem 3rem;
      border-bottom: 0.1rem solid #fff;
      font-size: 1.5rem; }
      .sanka--list li::after {
        content: "";
        position: absolute;
        top: calc(50% - 1rem);
        left: 0;
        width: 2.32rem;
        height: 1.6rem;
        background-image: url(../img/icon_check.png);
        background-size: cover; }
  .sanka--catch {
    position: relative;
    z-index: 11;
    color: #fff;
    font-size: 2rem;
    letter-spacing: -0.02em;
    line-height: 1.3;
    padding-bottom: 15rem; }
    .sanka--catch-sub {
      font-size: 1.6em;
      color: #f3f171; }
  .sanka--img {
    position: absolute;
    bottom: 0;
    right: -10rem;
    width: 28rem;
    z-index: 10; }
  @media screen and (min-width: 600px) {
    .sanka--area01 {
      position: relative;
      width: 100%;
      z-index: 11; }
    .sanka--title {
      margin-bottom: 5rem; }
      .sanka--title-cate-item {
        width: 14.4rem; }
      .sanka--title-text {
        font-size: 3.2rem;
        border-bottom: none; }
        .sanka--title-text-sub02 {
          margin-left: -0.25em; }
    .sanka--list {
      display: inline-block; }
      .sanka--list li {
        font-size: 1.8rem; }
    .sanka--catch {
      font-size: 3.2rem; }
      .sanka--catch-sub {
        font-size: 1.3em; }
    .sanka--img {
      position: absolute;
      bottom: 0;
      right: inherit;
      left: calc(50% + 12rem);
      width: 53.3rem;
      z-index: 10; } }
  @media screen and (min-width: 600px) and (max-width: 1000px) {
    .sanka--title-text-sub02 {
      display: block; }
    .sanka--img {
      left: calc(50% - 6rem); } }

.info {
  position: relative;
  z-index: 20;
  background-image: none;
  margin-top: -5rem; }
  .info--inner {
    position: relative;
    background-image: url(../img/bg_patern04.jpg);
    border-radius: 0.5rem; }
    .info--inner::before, .info--inner::after {
      content: "";
      position: absolute;
      background-image: url(../img/circle_decoration07.png);
      background-size: cover;
      z-index: -1; }
    .info--inner::before {
      top: 40rem;
      right: -22rem;
      width: 40rem;
      height: 40rem; }
    .info--inner::after {
      bottom: -10rem;
      left: -10rem;
      width: 27.7rem;
      height: 27.7rem; }
  .info--title {
    text-align: center;
    font-size: 2.4rem;
    letter-spacing: 0.2em; }
  .info--culc .block_curiculam dl {
    flex-direction: column; }
  .info--culc .block_curiculam dt,
  .info--culc .block_curiculam dd {
    width: 100%;
    font-size: 1.6rem; }
  .info--culc-dt span {
    font-size: 1.75em; }

.lesson--title {
  text-align: center;
  font-size: 2.4rem;
  letter-spacing: 0.2em;
  margin-bottom: 2.4rem; }
.lesson--time {
  margin-bottom: 2.4rem; }
  .lesson--time dl {
    width: 24rem;
    height: 5rem;
    background-color: #a59f94;
    border-radius: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    gap: 2rem;
    margin: 0 auto 0.8rem; }
.lesson--text {
  text-align: center;
  font-size: 1.6rem;
  line-height: 1.3;
  letter-spacing: -0.02em; }
.lesson--group02-area-title {
  position: relative;
  text-align: center;
  font-size: 2rem;
  letter-spacing: 0.2em;
  padding-bottom: 2.4rem;
  border-bottom: solid 0.1rem #111;
  margin: 8rem 0 4rem; }
  .lesson--group02-area-title::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 0.1rem;
    height: 1rem;
    background-color: #111; }
.lesson--group02-area-contents-item {
  padding-top: 4rem;
  padding-bottom: 4rem;
  border-bottom: dotted 0.1rem #b0b0b0; }
  .lesson--group02-area-contents-item-ver_01 {
    margin-bottom: 2em; }
    .lesson--group02-area-contents-item-ver_01 span {
      background: #5a7ab9;
      color: #fff;
      padding: 5px 8px; }
  .lesson--group02-area-contents-item-ver_02 {
    margin-bottom: 2em; }
    .lesson--group02-area-contents-item-ver_02 span {
      background: #9F8821;
      color: #fff;
      padding: 5px 8px; }
  .lesson--group02-area-contents-item-ver_03 {
    margin-bottom: 2em; }
    .lesson--group02-area-contents-item-ver_03 span {
      background: #7E7E7E;
      color: #fff;
      padding: 5px 8px; }
.lesson--group02-area-contents--name {
  font-size: 2.6rem;
  margin-bottom: 2rem; }
.lesson--group02_app_btn{
    margin-top:1.6rem;
}
    
.lesson--group02_app_btn a{
    display: inline-block;
    background: #47a5b4;
    color: #ffffff;
    font-size: 1.8rem;
    padding: 1rem;
    text-align: center;
    border-radius: 1rem;
    width:100%;
}
.lesson--group02-area-contents--adress {
  margin-bottom: 3rem;
  line-height: 1.3; }
  .lesson--group02-area-contents--adress-name {
    margin-bottom: 1rem; }
  .lesson--group02-area-contents--adress-adress {
    font-size: 1.4rem;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 2rem; }
    .lesson--group02-area-contents--adress-adress-cat {
      /*width: 6rem;*/
      /*height: 2rem;*/
      display: flex;
      align-items: center;
      justify-content: center;
      /*color: #fff;*/
        color: #47a5b4;
      /*border-radius: 0.5rem;*/
      /*background-color: #868686;*/
      margin-bottom: 1em;
        font-size: 2rem;
        font-weight: bold;
        border-bottom: dotted 2px #333333;
    padding-bottom: .5rem;
}
    .lesson--group02-area-contents--adress-adress-link {
      position: relative;
      display: block;
      padding-right: 1.8rem;
      transition: all 0.1s ease-in; }
      .lesson--group02-area-contents--adress-adress-link::after {
        content: "";
        position: absolute;
        width: 1rem;
        height: 1.4rem;
        right: 0;
        top: 0.2rem;
        background-image: url(../img/icon_map.png);
        background-size: cover; }
      .lesson--group02-area-contents--adress-adress-link:hover {
        color: #df2282; }
.lesson--group02-area-contents--setumeikai dl, .lesson--group02-area-contents--syokai dl {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  font-size: 1.4rem; }
  .lesson--group02-area-contents--setumeikai dl dt, .lesson--group02-area-contents--syokai dl dt {
    width: 13rem !important;
    position: relative; }
    .lesson--group02-area-contents--setumeikai dl dt::after, .lesson--group02-area-contents--syokai dl dt::after {
      content: "";
      font-size: 2em; }
  .lesson--group02-area-contents--setumeikai dl dd, .lesson--group02-area-contents--syokai dl dd {
    font-size: 1.8rem;
    line-height: 1.7;
    width: 60%; }
    .lesson--group02-area-contents--setumeikai dl dd p, .lesson--group02-area-contents--syokai dl dd p {
      font-size: 1.4rem;
      line-height: 1.5;
      margin-top: 1em; }
.lesson--group02-area-contents--setumeikai {
  margin-bottom: 1.6rem; }
.lesson--group02-area-contents--textL {
  margin-left: -0.1em;
  font-size: 2em; }
@media screen and (min-width: 600px) and (max-width: 750px) {
  .lesson .pcOnly {
    display: none; } }
@media screen and (min-width: 750px) {
  .lesson--time {
    display: flex;
    justify-content: center; }
    .lesson--time dl {
      margin-left: 1rem;
      margin-right: 1rem; }
  .lesson--group02 {
    width: 86.7rem; }
    .lesson--group02-area {
      margin-bottom: 15rem; }
    .lesson--group02-area-contents {
      position: relative; }
      .lesson--group02-area-contents-item {
        position: relative;
        padding-top: 2rem;
        padding-bottom: 2rem;
        display: flex;
        justify-content: space-between;
        gap: 2rem;
        align-items: flex-start;
        align-items: stretch; }
      .lesson--group02-area-contents--name {
        font-size: 1.8rem;
        width: 12rem; }
    
    .lesson--group02_app_btn{
        margin-top:1.6rem;
    }
    
    .lesson--group02_app_btn a{
        font-size: 1.6rem;
        padding: .5rem;
    }
      .lesson--group02-area-contents--adress {
        width: 20rem; }
        .lesson--group02-area-contents--adress-name {
          margin-bottom: 1.6rem; }
        .lesson--group02-area-contents--adress-adress {
          flex-direction: column;
          align-items: flex-start;
          gap: 0.6rem; }
      .lesson--group02-area-contents--setumeikai, .lesson--group02-area-contents--syokai {
        width: 20rem; }
        .lesson--group02-area-contents--setumeikai dl, .lesson--group02-area-contents--syokai dl {
          justify-content: center; }
          .lesson--group02-area-contents--setumeikai dl dt, .lesson--group02-area-contents--syokai dl dt {
            display: none; }
          .lesson--group02-area-contents--setumeikai dl dd, .lesson--group02-area-contents--syokai dl dd {
            width: auto; }
      .lesson--group02-area-contents--setumeikai {
        position: relative; }
        .lesson--group02-area-contents--setumeikai::after {
          content: "";
          position: absolute;
          width: 100%;
          height: calc(100% + 10rem);
          top: -4rem;
          left: 0;
          background-color: #eff2f7;
          z-index: -1; }
      .lesson--group02-area-contents--head .lesson--group02-area-contents-item {
        border: none; }
      .lesson--group02-area-contents--head .lesson--group02-area-contents--name {
        width: 12rem; }
      .lesson--group02-area-contents--head .lesson--group02-area-contents--adress {
        width: 22rem; }
      .lesson--group02-area-contents--head .lesson--group02-area-contents--setumeikai, .lesson--group02-area-contents--head .lesson--group02-area-contents--syokai {
        width: 20rem;
        text-align: center; }
        .lesson--group02-area-contents--head .lesson--group02-area-contents--setumeikai::after, .lesson--group02-area-contents--head .lesson--group02-area-contents--syokai::after {
          display: none; }
        .lesson--group02-area-contents--head .lesson--group02-area-contents--setumeikai span, .lesson--group02-area-contents--head .lesson--group02-area-contents--syokai span {
          display: inline-block;
          width: 80%;
          padding: 0.2rem 1rem;
          background-color: #6b93d5;
          color: #fff;
          border-radius: 0.5rem; } }

.contact {
  background-image: url(../img/bg_patern03.jpg); }
  @media screen and (min-width: 600px) {
    .contact-content {
      margin: 0 auto;
      max-width: 70rem; } }

.footer {
  text-align: center; }
  .footer--logo {
    margin: 0 auto;
    width: 12.2rem;
    margin-bottom: 5rem; }
  .footer--adress {
    margin-bottom: 3rem; }
  .footer--tel {
    margin-bottom: 2.4rem; }
    .footer--tel a {
      padding-top: 1.4rem;
      padding-bottom: 1.4rem;
      display: inline-block;
      border-top: solid 0.1rem #111;
      border-bottom: solid 0.1rem #111; }
    .footer--tel dl {
      display: flex;
      gap: 2rem; }
      .footer--tel dl dt {
        display: flex;
        gap: 1rem; }
      .footer--tel dl dd {
        font-size: 1.8rem;
        letter-spacing: 0.1em; }
    .footer--tel-icon {
      width: 2.8rem; }
    .footer--tel:hover {
      color: #df2282; }
  .footer--time {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-bottom: 10rem; }
    .footer--time dl {
      display: flex;
      align-items: center;
      justify-content: center; }
  .footer--link {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2rem;
    margin-bottom: 10rem; }
    .footer--link a:hover {
      color: #df2282; }
