/*--------------------------------------------------

    catch

--------------------------------------------------*/
.catch {
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  position: relative;
  z-index: 0; }
  .catch::before {
    content: '';
    width: 100%;
    max-width: 735px;
    height: 100%;
    background: url(../images/catch-shape.png) no-repeat right bottom/cover;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    pointer-events: none; }
  .catch-title {
    position: relative;
    z-index: 10; }
  .catch-slider {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1; }
    .catch-slider .flickity-viewport {
      height: 100% !important; }
  .catch-fig {
    width: 100%;
    height: 100%;
    transition: all 1.5s; }
  .catch-image {
    width: 100%;
    height: 100%; }
  @media screen and (min-width: 768px) {
    .catch {
      margin: 90px 0 0;
      height: calc(100vh - 90px);
      min-height: 680px; }
      .catch-title {
        padding-left: 6.09375%; } }
  @media screen and (max-width: 767px) {
    .catch {
      height: 60vh;
      margin: 50px 0 0;
      justify-content: center; }
      .catch::before {
        width: 77.14286vw; }
      .catch-title {
        width: 95%;
        max-width: 510px; } }

/*--------------------------------------------------

    greeting

--------------------------------------------------*/
.greeting {
  background: url(../images/shape01.png) no-repeat left top; }
  .greeting-subtitle {
    font-style: italic; }
  .greeting-fig {
    position: relative; }
    .greeting-fig::before, .greeting-fig::after {
      content: '';
      position: absolute;
      pointer-events: none; }
    .greeting-fig::before {
      width: 116px;
      height: 100px;
      background: url(../images/greeting/greeting-fig_shape01.svg) no-repeat center/contain;
      top: -20px;
      right: -30px; }
    .greeting-fig::after {
      width: 168px;
      height: 139px;
      background: url(../images/greeting/greeting-fig_shape02.svg) no-repeat center/contain;
      bottom: 35px;
      left: -40px; }
  @media screen and (min-width: 768px) {
    .greeting {
      padding-bottom: 200px; }
      .greeting-content {
        width: 650px; }
      .greeting-subtitle {
        margin: 0 0 25px; } }
  @media screen and (max-width: 767px) {
    .greeting {
      background-size: contain; }
      .greeting-fig {
        width: 100%;
        max-width: 585px;
        margin: 0 auto 20px;
        text-align: center; }
        .greeting-fig::before {
          width: 77.33px;
          height: 66.67px;
          right: 0; }
        .greeting-fig::after {
          width: 112px;
          height: 92.67px;
          bottom: 20px;
          left: -10px; }
      .greeting-content {
        width: 100%; }
      .greeting-subtitle {
        margin: 0 0 20px;
        font-size: 1.8rem; } }

/*--------------------------------------------------

    feature

--------------------------------------------------*/
.feature {
  z-index: 5; }
  .feature-inner {
    position: relative;
    z-index: 0; }
    .feature-inner::after {
      content: '';
      width: 100%;
      height: 100%;
      background-color: #004dac;
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      left: 0;
      z-index: -1; }
  .feature-wrap {
    position: relative; }
  .feature-title {
    color: #fff; }
    .feature-title::after {
      border-bottom-color: #ffea5e; }
    .feature-title span {
      color: #00baff; }
  .feature-subtitle {
    color: #fff;
    font-style: italic; }
    .feature-subtitle_cen {
      line-height: 2;
      padding: 0 0 8px;
      border-bottom: 1px solid; }
      .feature-subtitle_cen span {
        color: #ffea5e;
        font-weight: 700; }
  .feature-list {
    justify-content: flex-start; }
    .feature-list li {
      display: flex;
      flex-flow: column wrap;
      align-items: center;
      align-content: center;
      background-color: #fff;
      font-style: italic;
      text-align: center;
      letter-spacing: 0.12em;
      position: relative; }
      .feature-list li::after {
        content: '';
        width: 151px;
        height: 122px;
        position: absolute;
        top: -20px;
        left: -20px; }
      .feature-list li:nth-child(1)::after {
        background: url(../images/feature/feature-list_num01.png) no-repeat left top/contain; }
      .feature-list li:nth-child(2)::after {
        background: url(../images/feature/feature-list_num02.png) no-repeat left top/contain; }
      .feature-list li:nth-child(3)::after {
        background: url(../images/feature/feature-list_num03.png) no-repeat left top/contain; }
      .feature-list li:nth-child(4)::after {
        background: url(../images/feature/feature-list_num04.png) no-repeat left top/contain; }
      .feature-list li:nth-child(5)::after {
        background: url(../images/feature/feature-list_num05.png) no-repeat left top/contain; }
  .feature-icon {
    position: relative;
    z-index: 10; }
  .feature-text_em {
    padding: 0 0 4px;
    font-weight: 700;
    color: #185fb6;
    background: linear-gradient(to bottom, #ffea5e, #ffea5e) no-repeat bottom/100% 40%; }
  .feature-note {
    line-height: 1.3;
    margin: 10px 0 0; }
  .feature-fig {
    position: absolute;
    right: -165px;
    bottom: -190px; }
  @media screen and (min-width: 768px) {
    .feature {
      padding: 0 0 250px; }
      .feature-inner {
        padding: 40px 0 0; }
      .feature-subtitle {
        margin: 0 0 70px;
        text-align: center; }
      .feature-list li {
        width: 330px;
        height: 330px;
        padding: 65px 0 0;
        font-size: 2.2rem;
        line-height: 1.59091; }
        .feature-list li:nth-last-child(-n+2) {
          height: 408px; }
        .feature-list li:not(:nth-child(3n)) {
          margin-right: 45px; }
        .feature-list li:not(:nth-last-child(-n+3)) {
          margin-bottom: 80px; }
      .feature-icon {
        margin: 0 0 15px; }
      .feature-note {
        font-size: 1.6rem; } }
  @media all and (-ms-high-contrast: none) {
    *::-ms-backdrop, .feature-subtitle_cen {
      padding: 0; }
    *::-ms-backdrop, .feature-text_em {
      padding: 0;
      background-position: center bottom 5px; } }
  @media screen and (max-width: 1450px) and (min-width: 768px) {
    .feature-fig {
      right: -90px; } }
  @media screen and (max-width: 767px) {
    .feature {
      padding: 0 0 26.66667vw; }
      .feature-subtitle {
        margin: 0 0 40px;
        font-size: 1.8rem; }
      .feature-list {
        align-items: stretch;
        justify-content: space-between;
        line-height: 1.5;
        font-size: 1.8rem; }
        .feature-list li {
          width: 100%;
          padding: 30px 0 20px;
          margin: 0 0 30px; }
          .feature-list li::after {
            width: 75.5px;
            height: 61px;
            top: -10px;
            left: -10px; }
      .feature-icon {
        height: 75px;
        margin: 0 0 15px; }
        .feature-icon img {
          height: 100%; }
      .feature-note {
        font-size: 1.2rem; }
      .feature-fig {
        position: static; } }
  @media screen and (max-width: 767px) and (min-width: 540px) {
    .feature-list li {
      width: 48%; }
    .feature-fig {
      width: 48%;
      position: absolute;
      bottom: -12.96296vw;
      right: 0; } }

/*--------------------------------------------------

    program

--------------------------------------------------*/
.program-list {
  align-items: stretch;
  line-height: 1.6; }
  .program-list li {
    color: #fff;
    background-color: #004dac;
    position: relative; }

.program-subtitle {
  font-weight: 700;
  letter-spacing: 0.1em;
  position: relative; }
  .program-subtitle::before {
    content: '';
    width: 5px;
    height: 55px;
    background-color: #00baff;
    transform: skewX(-30deg);
    position: absolute;
    top: -20px;
    left: 0; }
  .program-subtitle span {
    display: block;
    margin: 8px 0 0;
    color: #00baff;
    font-weight: 700;
    font-family: "RobotoCondensed", "Noto Sans JP", sans-serif;
    letter-spacing: 0.07em; }

.program-banner:hover {
  opacity: 0.6; }

@media screen and (min-width: 768px) {
  .program {
    padding-top: 0;
    background: url(../images/shape02.png) no-repeat right, url(../images/shape03.png) no-repeat left bottom 220px; }
    .program-list li {
      width: 520px;
      min-height: 360px;
      margin: 0 0 70px; }
    .program-body {
      width: 540px;
      padding: 58px 45px 53px;
      margin-right: auto; }
    .program-subtitle {
      margin: 0 0 25px;
      padding-left: 22px;
      font-size: 2.6rem; }
      .program-subtitle span {
        font-size: 1.8rem; }
    .program-fig {
      margin: 0 0 30px; }
    .program-banner {
      margin-left: -70px; } }

@media screen and (max-width: 767px) {
  .program {
    padding-top: 0; }
    .program-list {
      margin: 0 0 30px;
      position: relative;
      z-index: 10; }
      .program-list li {
        width: 100%;
        padding: 30px 20px 20px; }
        .program-list li:not(:last-child) {
          margin-bottom: 30px; }
    .program-subtitle {
      padding-left: 20px;
      margin: 0 0 20px;
      font-size: 1.8rem; }
      .program-subtitle::before {
        height: 40px;
        top: -10px; }
      .program-subtitle span {
        margin: 0;
        font-size: 1.3rem; }
    .program-fig {
      margin: 0 0 20px;
      text-align: center; }
    .program-banner {
      margin-left: -20px; } }

/*--------------------------------------------------

    staff

--------------------------------------------------*/
.staff {
  padding: 0; }
  .staff-contentTable td {
    text-align: left; }
  .staff-contentText {
    width: 100%; }
  .staff .close-button {
    display: none; }
  @media screen and (min-width: 768px) {
    .staff-list {
      justify-content: flex-start; }
      .staff-list li {
        width: 330px;
        height: 440px;
        margin-bottom: 45px; }
        .staff-list li:not(:nth-child(3n)) {
          margin-right: 45px; }
    .staff-contentColumn {
      padding: 50px; }
    .staff-contentFig {
      width: 510px; }
    .staff-contentTable {
      width: 450px; }
      .staff-contentTable th {
        width: 150px;
        padding-left: 15px; }
      .staff-contentTable td {
        padding: 10px; }
    .staff-contentText {
      margin: 30px 0 0; } }
  @media screen and (max-width: 767px) {
    .staff-list {
      margin: 0 0 30px; }
      .staff-list li {
        width: 48%; }
        .staff-list li:not(:nth-last-child(-n+2)) {
          margin-bottom: 4%; }
    .staff-contentFig {
      margin: 0 0 20px; }
    .staff-contentTable {
      margin: 0 0 20px; } }

/*--------------------------------------------------

    price

--------------------------------------------------*/
.price {
  background: repeating-linear-gradient(-45deg, rgba(0, 186, 255, 0.09) 0%, rgba(0, 186, 255, 0.09) 10px, #fff 10px, #fff 20px) #fff;
  position: relative;
  z-index: 5; }
  .price::before {
    content: '';
    width: 100%;
    height: 260px;
    background: linear-gradient(to right bottom, #fff 50%, rgba(255, 255, 255, 0) 50.3%) no-repeat bottom;
    position: absolute;
    top: 0;
    left: 0;
    pointer-events: none;
    z-index: -1; }
  .price-subtitle_ja {
    vertical-align: middle; }
  .price-table th:empty::after, .price-table td:empty::after {
    content: '-'; }
  @media screen and (min-width: 768px) {
    .price {
      padding: 260px 0; }
      .price-content + .price-content {
        margin-top: 80px; }
      .price-subtitle_ja {
        font-size: 2.6rem; } }
  @media all and (-ms-high-contrast: none) {
    *::-ms-backdrop, .price::before {
      background: linear-gradient(to right bottom, #fff 50%, rgba(255, 255, 255, 0) 50%) no-repeat bottom; } }
  @media screen and (max-width: 767px) {
    .price {
      padding: 26.66667vw 0; }
      .price::before {
        height: 26.66667vw;
        background: linear-gradient(to right bottom, #fff 50%, rgba(255, 255, 255, 0) 50.5%) no-repeat bottom; }
      .price-content + .price-content {
        margin-top: 50px; }
      .price-subtitle_ja {
        font-size: 1.8rem; } }
  @media screen and (max-width: 539px) {
    .price-subtitle::before {
      margin-right: 15px; }
    .price-subtitle::after {
      margin-left: 15px; }
    .price .price_outer {
      display: block;
      width: calc(100% - 60px); } }

/*--------------------------------------------------

    voice

--------------------------------------------------*/
.voice-inner {
  background-color: #004dac; }

.voice-title {
  color: #fff; }
  .voice-title::after {
    border-bottom-color: #ffea5e; }
  .voice-title span {
    color: #00baff; }

.voice-cardTitle {
  background: linear-gradient(to left top, #00baff 50%, rgba(255, 255, 255, 0) 51.5%) no-repeat right top/100% 30px; }
  .voice-cardTitle::after {
    background: url(../images/icon-arrow02.svg) no-repeat center/contain; }
  .voice-cardTitle span {
    background-color: #00baff; }

.voice-contentBox {
  line-height: 1.8;
  border: 2px solid #185fb6; }
  .voice-contentBox:not(:last-child) {
    position: relative; }
    .voice-contentBox:not(:last-child)::after {
      content: '';
      width: 0;
      height: 0;
      border-top: 25px solid #185fb6;
      border-right: 20px solid transparent;
      border-left: 20px solid transparent;
      position: absolute;
      margin: auto;
      right: 0;
      bottom: -50px;
      left: 0; }

.voice-contentSubtitle {
  margin: 0 0 10px;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.1em;
  background-color: #185fb6; }

.voice-button {
  color: #fff;
  border-color: #fff;
  background-color: #004dac; }

.voice .close-button {
  display: none; }

.voice .empty-text {
  color: #fff;
  text-shadow: none; }

@media screen and (min-width: 768px) {
  .voice {
    padding: 0 0 250px; }
    .voice-list {
      justify-content: flex-start; }
      .voice-list li {
        width: 330px;
        height: 360px;
        margin-bottom: 45px; }
        .voice-list li:not(:nth-child(3n)) {
          margin-right: 45px; }
    .voice-cardTitle {
      padding-top: 30px; }
      .voice-cardTitle span {
        padding-bottom: 18px; }
    .voice-contentBox {
      padding: 0 30px 20px; }
      .voice-contentBox:not(:last-child) {
        margin-bottom: 70px; }
    .voice-contentSubtitle {
      width: 300px;
      padding: 6px;
      margin-left: -30px;
      text-align: center;
      font-size: 2.3rem; } }

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop, .voice-cardTitle {
    background: linear-gradient(to left top, #00baff 50%, rgba(255, 255, 255, 0) 50%) no-repeat right top/100% 30px; } }

@media screen and (max-width: 767px) {
  .voice {
    padding: 0 0 26.66667vw; }
    .voice-list {
      /* margin: 0 0 30px; */
     }
      .voice-list li {
        width: 48%; }
        .voice-list li:not(:nth-last-child(-n+2)) {
          margin-bottom: 4%; }
    .voice-cardTitle {
      padding-top: 15px;
      background: linear-gradient(to left top, #00baff 50%, rgba(255, 255, 255, 0) 52.6%) no-repeat right top/100% 15px; }
    .voice-contentBox {
      padding: 0 20px 10px; }
      .voice-contentBox:not(:last-child) {
        margin-bottom: 40px; }
        .voice-contentBox:not(:last-child)::after {
          border-top: 18px solid #185fb6;
          border-right: 13px solid transparent;
          border-left: 13px solid transparent;
          bottom: -30px; }
    .voice-contentSubtitle {
      width: 200px;
      padding: 5px 0;
      margin-left: -20px;
      text-align: center; } }

/*--------------------------------------------------

    news

--------------------------------------------------*/
.news-body {
  width: 100%; }

.news-list li {
  color: #fff;
  font-weight: 700; }
  .news-list li + li {
    margin-top: 15px; }

.news-card {
  align-items: center;
  background-color: #004dac;
  position: relative; }
  .news-card::after {
    content: '';
    width: 19px;
    height: 14px;
    margin: auto;
    background: url(../images/news/news-arrow.svg) no-repeat center/contain;
    position: absolute;
    top: 0;
    right: 40px;
    bottom: 0; }
  .news-card:hover {
    opacity: 0.6; }
  .news-cardTime {
    width: 113px;
    text-align: center;
    background-color: #00baff; }
  .news-cardSubtitle {
    font: inherit;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap; }

.news-content {
  color: #444; }
  .news-contentTime {
    display: block;
    width: 120px;
    margin: 0 0 10px;
    color: #fff;
    text-align: center;
    font-weight: 700;
    background-color: #00baff;
    font-size: 1.3rem; }
  .news-contentSubtitle {
    color: #185fb6;
    font-weight: 700;
    letter-spacing: 0.1em;
    border-bottom: 1px solid; }

.news .close-button {
  display: none; }

.news-sns {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  color: #fff;
  text-align: center;
  font-weight: 700;
  font-family: "RobotoCondensed", "Noto Sans JP", sans-serif;
  letter-spacing: 0.05em;
  background: url(../images/news/news-banner_bg.png) no-repeat left #00baff;
  position: relative; }
  .news-sns span {
    color: #fff; }
  .news-sns::after {
    content: '';
    width: calc(100% - 8px);
    height: calc(100% - 8px);
    margin: auto;
    border: 2px solid #fff;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    pointer-events: none; }
  .news-sns:hover {
    opacity: 0.6;
    transform: translateY(-5px); }

@media screen and (min-width: 768px) {
  .news {
    padding: 0 0 200px; }
    .news-body {
      margin: 0 0 80px; }
    .news-list {
      margin: 0 0 50px; }
    .news-card {
      padding: 20px 60px 20px 20px; }
      .news-cardSubtitle {
        flex: 1;
        margin-left: 25px; }
    .news-contentSubtitle {
      padding: 0 0 10px;
      margin: 0 0 20px; }
    .news-sns {
      width: 510px;
      height: 100px;
      font-size: 3.5rem; }
      .news-sns span {
        margin-right: 25px; } }

@media screen and (max-width: 767px) {
  .news {
    padding-bottom: 26vw; }
    .news-title {
      z-index: 20; }
    .news-body {
      margin: 0 0 40px; }
    .news-list {
      margin: 0 0 30px; }
    .news-card {
      padding: 10px 30px 10px 10px; }
      .news-card::after {
        right: 10px; }
      .news-cardSubtitle {
        width: 100%; }
    .news-contentTime {
      font-size: 1.2rem; }
    .news-contentSubtitle {
      padding: 0 0 10px;
      margin: 0 0 20px;
      font-size: 1.7rem; }
    .news-sns {
      width: 100%;
      height: 80px;
      font-size: 2.5rem; }
      .news-sns_insta {
        margin: 0 0 20px; }
      .news-sns span {
        margin-right: 10px; } }

/*--------------------------------------------------

    studio

--------------------------------------------------*/
.studio {
  background: repeating-linear-gradient(-45deg, rgba(0, 186, 255, 0.09) 0%, rgba(0, 186, 255, 0.09) 10px, #fff 10px, #fff 20px);
  position: relative;
  z-index: 5; }
  .studio::before {
    content: '';
    width: 100%;
    height: 260px;
    background: linear-gradient(to right bottom, #fff 50%, rgba(255, 255, 255, 0) 50.3%) no-repeat bottom;
    position: absolute;
    top: 0;
    left: 0;
    pointer-events: none;
    z-index: -1; }
  .studio-fig {
    width: 100%;
    text-align: center; }
  .studio-wrap {
    position: relative;
    z-index: 10; }
  .studio-table td {
    text-align: left; }
  .studio-map {
    width: 100%; }
  @media screen and (min-width: 768px) {
    .studio {
      padding: 260px 0;
      margin: 0 0 -260px; }
      .studio-fig {
        padding: 0 50px; }
      .studio-wrap {
        margin-top: -200px; }
      .studio-map {
        height: 450px;
        margin: 40px 0 0; } }
  @media screen and (max-width: 767px) {
    .studio {
      padding: 26.66667vw 0 50px; }
      .studio::before {
        height: 26.66667vw;
        background: linear-gradient(to right bottom, #fff 50%, rgba(255, 255, 255, 0) 50.5%) no-repeat bottom; }
      .studio-fig {
        padding: 0 2%; }
      .studio-wrap {
        margin-top: -10vw; }
      .studio-table {
        margin: 0 0 30px; }
      .studio-map {
        height: 58.66667vw; } }

/*--------------------------------------------------

    footer

--------------------------------------------------*/
footer {
  line-height: 1;
  color: #fff;
  text-align: center;
  letter-spacing: 0.04em;
  position: relative;
  z-index: 100; }
  footer::after {
    content: '';
    width: 624px;
    height: 535px;
    background: url(../images/ft-bg.png) no-repeat right bottom/contain;
    position: absolute;
    right: 0;
    bottom: 0;
    pointer-events: none; }
  footer a {
    display: inline-block; }
  footer .ft-inner {
    background-color: #00baff; }
  footer .ft-wrap {
    position: relative;
    z-index: 10; }
  footer .ft-tel {
    font-weight: 700;
    font-family: "RobotoCondensed", "Noto Sans JP", sans-serif;
    letter-spacing: 0.03em; }
  footer .ft-button {
    display: block;
    width: 215px;
    margin: auto;
    color: #fff;
    font-weight: 700;
    font-family: "RobotoCondensed", "Noto Sans JP", sans-serif;
    letter-spacing: 0.08em;
    font-size: 1.6rem;
    background: linear-gradient(to right, #004dac, #3e82e9); }
    footer .ft-button:hover {
      opacity: 0.6; }
  footer .copyright {
    font-size: 1.2rem; }
  @media screen and (min-width: 768px) {
    footer {
      padding: 260px 0 0;
      background: linear-gradient(to left top, #00baff 50%, rgba(255, 255, 255, 0) 50.3%) no-repeat top/100% 260px, linear-gradient(to right top, #004dac 50%, rgba(255, 255, 255, 0) 50.3%) no-repeat top 90px center/100% 170px; }
      footer .ft-inner {
        padding: 0 0 29px; }
      footer .ft-wrap {
        width: 320px; }
      footer .ft-logo {
        margin: 0 0 50px; }
      footer .ft-tel {
        font-size: 2.2rem; }
      footer .ft-adr {
        margin: 20px 0 35px; }
      footer .ft-button {
        padding: 18.5px 0;
        margin-bottom: 90px; } }
  @media all and (-ms-high-contrast: none) {
    *::-ms-backdrop, footer {
      background: linear-gradient(to left top, #00baff 50%, rgba(255, 255, 255, 0) 50%) no-repeat top/100% 260px, linear-gradient(to right top, #004dac 50%, rgba(255, 255, 255, 0) 50%) no-repeat top 90px center/100% 170px; } }
  @media screen and (max-width: 767px) {
    footer {
      padding: 70px 0 0;
      background: linear-gradient(to left top, #00baff 50%, rgba(255, 255, 255, 0) 50.8%) no-repeat top/100% 70px, linear-gradient(to right top, #004dac 50%, rgba(255, 255, 255, 0) 51%) no-repeat top 20px center/100% 50px, repeating-linear-gradient(-45deg, rgba(0, 186, 255, 0.09) 0%, rgba(0, 186, 255, 0.09) 10px, #fff 10px, #fff 20px); }
      footer::after {
        width: 60%;
        height: 100%;
        background-position: right top 30%; }
      footer .ft-inner {
        padding: 30px 0 20px; }
      footer .ft-wrap {
        max-width: 350px;
        margin: auto; }
      footer .ft-logo {
        height: 40px;
        margin: 0 0 30px; }
        footer .ft-logo img {
          height: 100%; }
      footer .ft-tel {
        font-size: 2rem; }
      footer .ft-adr {
        margin: 15px 0 25px; }
      footer .ft-button {
        padding: 17px 0;
        margin-bottom: 40px; } }

/*# sourceMappingURL=style.css.map */