@charset "UTF-8";
@import url("//fonts.googleapis.com/css2?family=Bebas+Neue&family=Noto+Sans+JP:wght@400;500;600;700;900&display=swap");
/*
font-family: $font-gothic;
300 400 500 700
*/
/*
font-family: $font-min;
300 400 500 600 700
*/
/*
font-family: $font-en;
400
*/
/*
font-family: $font-en2;
400
*/
/*@include font-gothic();*/
/*@include font-min();*/
/*@include font-en();*/
/*@include font-en2();*/
/*@include incImg100();*/
/*@include incSmooth();*/
/*@include dropshadow;*/
/*@include boxshadow;*/
/*@include fs();*/
/*@include btm();*/
.class01 {
  background: #313B5D;
  padding: 80px 40px; }
  .class01 .inr {
    margin: 0 auto;
    max-width: 960px; }
    .class01 .inr .copy {
      color: #FFF;
      font-size: 20px;
      font-size: 2rem;
      line-height: 2;
      font-weight: 500;
      letter-spacing: 0.06em;
      line-height: 2.2;
      margin-bottom: 40px;
      text-align: center; }
      @media only screen and (max-width: 960px) {
        .class01 .inr .copy {
          font-size: 17px;
          font-size: 1.7rem; } }
    .class01 .inr .courseList {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; }
      .class01 .inr .courseList li {
        background: #FFF;
        border-radius: 16px;
        margin-bottom: 16px;
        padding: 24px;
        width: calc(50% - 8px); }
        .class01 .inr .courseList li dl dt {
          display: flex;
          align-items: center;
          justify-content: space-between;
          padding-bottom: 16px; }
          .class01 .inr .courseList li dl dt .img {
            width: 120px; }
          .class01 .inr .courseList li dl dt h3 {
            color: #ff8343;
            line-height: 1;
            width: calc(100% - 144px); }
            .class01 .inr .courseList li dl dt h3 .name {
              font-size: 24px;
              font-size: 2.4rem;
              line-height: 2;
              line-height: 1.8;
              text-transform: uppercase; }
              @media only screen and (max-width: 960px) {
                .class01 .inr .courseList li dl dt h3 .name {
                  font-size: 20px;
                  font-size: 2rem; } }
            .class01 .inr .courseList li dl dt h3 .old {
              font-size: 16px;
              font-size: 1.6rem;
              line-height: 2;
              font-weight: 500;
              margin-left: 8px;
              vertical-align: 2px; }
              @media only screen and (max-width: 960px) {
                .class01 .inr .courseList li dl dt h3 .old {
                  font-size: 14px;
                  font-size: 1.4rem; } }
            .class01 .inr .courseList li dl dt h3 .max {
              display: block;
              font-size: 20px;
              font-size: 2rem;
              line-height: 2;
              font-weight: 500;
              line-height: 1.2;
              padding: 4px 0 8px; }
              @media only screen and (max-width: 960px) {
                .class01 .inr .courseList li dl dt h3 .max {
                  font-size: 17px;
                  font-size: 1.7rem; } }
            .class01 .inr .courseList li dl dt h3 .for {
              display: block;
              font-size: 12px;
              font-size: 1.2rem;
              line-height: 2;
              font-weight: 400; }
              @media only screen and (max-width: 960px) {
                .class01 .inr .courseList li dl dt h3 .for {
                  font-size: 10px;
                  font-size: 1rem; } }
        .class01 .inr .courseList li dl dd {
          background: url("../img/class/bg_line.png") left top repeat-x;
          letter-spacing: 0.02em;
          padding-top: 16px; }
          .class01 .inr .courseList li dl dd span {
            font-size: 12px;
            font-size: 1.2rem;
            line-height: 2;
            display: block;
            padding-left: 1em;
            text-indent: -1em; }
            @media only screen and (max-width: 960px) {
              .class01 .inr .courseList li dl dd span {
                font-size: 10px;
                font-size: 1rem; } }
        .class01 .inr .courseList li:last-child {
          margin: auto; }
          .class01 .inr .courseList li:last-child dl dt h3 .old {
            margin-left: 0; }
    .class01 .inr .timeSchedule {
      border-bottom: 2px dashed rgba(255, 255, 255, 0.3);
      border-top: 2px dashed rgba(255, 255, 255, 0.3);
      margin: 40px 0;
      padding: 32px 0;
      text-align: center; }
      .class01 .inr .timeSchedule h3 {
        color: #FFF;
        font-size: 24px;
        font-size: 2.4rem;
        line-height: 2;
        line-height: 1.8;
        font-weight: 500;
        letter-spacing: 0.06em;
        line-height: 2.2;
        margin-bottom: 20px;
        text-align: center; }
        @media only screen and (max-width: 960px) {
          .class01 .inr .timeSchedule h3 {
            font-size: 20px;
            font-size: 2rem; } }
      .class01 .inr .timeSchedule ul {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        margin: 0 auto;
        max-width: 530px;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale; }
        .class01 .inr .timeSchedule ul li {
          padding-bottom: 24px;
          width: calc(50% - 24px); }
          .class01 .inr .timeSchedule ul li h4 {
            background: #FFF;
            border-radius: 3px;
            color: #ff8343;
            font-size: 16px;
            font-size: 1.6rem;
            line-height: 2;
            font-weight: 500;
            letter-spacing: 0.02em;
            line-height: 1.5;
            margin-bottom: 8px;
            padding: 12px 8px 8px; }
            @media only screen and (max-width: 960px) {
              .class01 .inr .timeSchedule ul li h4 {
                font-size: 14px;
                font-size: 1.4rem; } }
            .class01 .inr .timeSchedule ul li h4 span {
              color: #959090;
              display: block;
              font-family: "EB Garamond", serif;
              font-size: 14px;
              font-size: 1.4rem;
              line-height: 2;
              font-weight: 400;
              letter-spacing: 0.02em;
              line-height: 1.4;
              text-transform: uppercase; }
              @media only screen and (max-width: 960px) {
                .class01 .inr .timeSchedule ul li h4 span {
                  font-size: 12px;
                  font-size: 1.2rem; } }
          .class01 .inr .timeSchedule ul li dl {
            color: #FFF;
            display: flex;
            text-align: left; }
            .class01 .inr .timeSchedule ul li dl dt {
              line-height: 1.4;
              padding: 4px 8px;
              text-align: left;
              width: 6.5em; }
            .class01 .inr .timeSchedule ul li dl dd {
              line-height: 1.4;
              padding: 4px;
              width: calc(100% - 6.5em); }
              .class01 .inr .timeSchedule ul li dl dd.long {
                text-align: center;
                width: 100%; }
    .class01 .inr .freePay {
      border: 2px solid #FFF;
      color: #FFF;
      padding: 40px;
      text-align: center; }
      .class01 .inr .freePay p {
        margin-top: 12px; }
        .class01 .inr .freePay p a {
          color: #959090;
          font-size: 14px;
          font-size: 1.4rem;
          line-height: 2; }
          @media only screen and (max-width: 960px) {
            .class01 .inr .freePay p a {
              font-size: 12px;
              font-size: 1.2rem; } }
      .class01 .inr .freePay .fpTitle {
        font-size: 24px;
        font-size: 2.4rem;
        line-height: 2;
        line-height: 1.8;
        margin-top: 0; }
        @media only screen and (max-width: 960px) {
          .class01 .inr .freePay .fpTitle {
            font-size: 20px;
            font-size: 2rem; } }

.class02 {
  background: #EDE5DB;
  padding: 240px 40px 120px;
  position: relative; }
  .class02 .inr {
    max-width: 960px;
    margin: 0 auto;
    width: 100%; }
    .class02 .inr h2 {
      color: #ff8343;
      display: block;
      line-height: 1;
      margin-bottom: 24px;
      text-align: center; }
      .class02 .inr h2 .ja {
        display: block;
        font-size: 16px;
        font-size: 1.6rem;
        line-height: 2;
        font-weight: 500;
        letter-spacing: 0.1em;
        line-height: 1.4; }
        @media only screen and (max-width: 960px) {
          .class02 .inr h2 .ja {
            font-size: 14px;
            font-size: 1.4rem; } }
      .class02 .inr h2 .en {
        display: block;
        font-family: "EB Garamond", serif;
        font-size: 72px;
        font-size: 7.2rem;
        line-height: 2;
        line-height: 1.8;
        font-weight: 400;
        letter-spacing: 0.01em;
        line-height: 1.4;
        text-transform: uppercase; }
        @media only screen and (max-width: 960px) {
          .class02 .inr h2 .en {
            font-size: 61px;
            font-size: 6.1rem; } }
    .class02 .inr .tsTbl {
      border-radius: 10px;
      overflow: hidden;
      margin-bottom: 20px; }
      .class02 .inr .tsTbl table {
        background: #FFF; }
        .class02 .inr .tsTbl table th, .class02 .inr .tsTbl table td {
          border: 1px solid #EEE;
          padding: 12px 12px 20px;
          text-align: center; }
          .class02 .inr .tsTbl table th.clm1W, .class02 .inr .tsTbl table td.clm1W {
            width: 120px; }
          .class02 .inr .tsTbl table th.clm2W, .class02 .inr .tsTbl table td.clm2W {
            width: calc(50% - 60px); }
        .class02 .inr .tsTbl table th {
          font-family: "EB Garamond", serif;
          font-size: 24px;
          font-size: 2.4rem;
          line-height: 2;
          line-height: 1.8;
          font-weight: 400;
          letter-spacing: 0.04em;
          line-height: 1.4;
          text-transform: uppercase;
          -webkit-font-smoothing: antialiased;
          -moz-osx-font-smoothing: grayscale; }
          @media only screen and (max-width: 960px) {
            .class02 .inr .tsTbl table th {
              font-size: 20px;
              font-size: 2rem; } }
        .class02 .inr .tsTbl table td {
          font-size: 16px;
          font-size: 1.6rem;
          line-height: 2; }
          @media only screen and (max-width: 960px) {
            .class02 .inr .tsTbl table td {
              font-size: 14px;
              font-size: 1.4rem; } }
          .class02 .inr .tsTbl table td .en {
            color: #959090;
            display: block;
            font-family: "EB Garamond", serif;
            font-size: 14px;
            font-size: 1.4rem;
            line-height: 2;
            font-weight: 400;
            letter-spacing: 0.02em;
            line-height: 1.4;
            text-transform: uppercase;
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale; }
            @media only screen and (max-width: 960px) {
              .class02 .inr .tsTbl table td .en {
                font-size: 12px;
                font-size: 1.2rem; } }
        .class02 .inr .tsTbl table thead th, .class02 .inr .tsTbl table thead td {
          background: #ff8343;
          color: #FFF;
          font-family: "EB Garamond", serif;
          font-size: 24px;
          font-size: 2.4rem;
          line-height: 2;
          line-height: 1.8;
          font-weight: 400;
          letter-spacing: 0.04em;
          line-height: 1.4;
          text-transform: uppercase;
          -webkit-font-smoothing: antialiased;
          -moz-osx-font-smoothing: grayscale; }
          @media only screen and (max-width: 960px) {
            .class02 .inr .tsTbl table thead th, .class02 .inr .tsTbl table thead td {
              font-size: 20px;
              font-size: 2rem; } }
    .class02 .inr:before {
      background: url("../img/top/illust_14.png") center center no-repeat;
      background-size: cover;
      content: '';
      display: block;
      height: 12vw;
      min-height: 94px;
      width: 12vw;
      min-width: 151px;
      position: absolute;
      bottom: 255px;
      right: 3vw;
      z-index: 2; }
  .class02:before {
    background: url("../img/top/illust_04.png") center center no-repeat;
    background-size: cover;
    content: '';
    display: block;
    height: 12vw;
    min-height: 155px;
    width: 12vw;
    min-width: 115px;
    position: absolute;
    top: 75px;
    right: 4vw;
    z-index: 2; }
  .class02:after {
    background: url("../img/top/illust_13.png") center center no-repeat;
    background-size: cover;
    content: '';
    display: block;
    height: 12vw;
    min-height: 118px;
    width: 12vw;
    min-width: 165px;
    position: absolute;
    top: 40%;
    left: 2vw;
    z-index: 2; }

.class03 {
  padding: 120px 0 200px;
  position: relative;
  overflow: hidden; }
  .class03 .inr {
    position: relative;
    z-index: 2; }
  .class03 h2 {
    color: #ff8343;
    display: block;
    line-height: 1;
    margin-bottom: 24px;
    text-align: center; }
    .class03 h2 .ja {
      display: block;
      font-size: 16px;
      font-size: 1.6rem;
      line-height: 2;
      font-weight: 500;
      letter-spacing: 0.1em;
      line-height: 1.4; }
      @media only screen and (max-width: 960px) {
        .class03 h2 .ja {
          font-size: 14px;
          font-size: 1.4rem; } }
    .class03 h2 .en {
      display: block;
      font-family: "EB Garamond", serif;
      font-size: 72px;
      font-size: 7.2rem;
      line-height: 2;
      line-height: 1.8;
      font-weight: 400;
      letter-spacing: 0.01em;
      line-height: 1.4;
      text-transform: uppercase; }
      @media only screen and (max-width: 960px) {
        .class03 h2 .en {
          font-size: 61px;
          font-size: 6.1rem; } }
  .class03 .top04Box {
    padding-bottom: 80px; }
    .class03 .top04Box h3 {
      display: block;
      font-family: "Bebas Neue", sans-serif;
      font-size: 28px;
      font-size: 2.8rem;
      line-height: 2;
      line-height: 1.8;
      font-weight: bold;
      letter-spacing: 0.04em;
      line-height: 1.6;
      margin-bottom: 48px;
      text-transform: uppercase;
      text-align: center; }
      @media only screen and (max-width: 960px) {
        .class03 .top04Box h3 {
          font-size: 24px;
          font-size: 2.4rem; } }
      .class03 .top04Box h3.noApper {
        text-transform: none; }
    .class03 .top04Box .top04Flex {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin: 0 auto;
      max-width: 1600px; }
      .class03 .top04Box .top04Flex .img {
        width: 50%; }
      .class03 .top04Box .top04Flex .data {
        padding: 0 80px 0 40px;
        width: 50%; }
        .class03 .top04Box .top04Flex .data h4 {
          color: #6E0200;
          display: block;
          font-size: 24px;
          font-size: 2.4rem;
          line-height: 2;
          line-height: 1.8;
          font-weight: bold;
          letter-spacing: 0.02em;
          line-height: 2;
          margin-bottom: 24px; }
          @media only screen and (max-width: 960px) {
            .class03 .top04Box .top04Flex .data h4 {
              font-size: 20px;
              font-size: 2rem; } }
        .class03 .top04Box .top04Flex .data p {
          margin-bottom: 24px; }
      .class03 .top04Box .top04Flex.reverse {
        flex-direction: row-reverse; }
        .class03 .top04Box .top04Flex.reverse .data {
          padding: 0 40px 0 80px; }
    .class03 .top04Box .eylfList {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      margin: 0 auto;
      max-width: 960px;
      padding-top: 80px; }
      .class03 .top04Box .eylfList li {
        background: #FFF;
        border-radius: 10px;
        margin: 0 0 24px;
        padding: 16px 24px;
        text-align: center;
        width: calc(50% - 8px); }
        .class03 .top04Box .eylfList li img {
          max-width: 222px; }
        .class03 .top04Box .eylfList li p {
          font-size: 14px;
          font-size: 1.4rem;
          line-height: 2;
          letter-spacing: 0.04em;
          line-height: 1.4;
          padding-top: 12px;
          text-align: left; }
          @media only screen and (max-width: 960px) {
            .class03 .top04Box .eylfList li p {
              font-size: 12px;
              font-size: 1.2rem; } }
    .class03 .top04Box .eylfListSP {
      display: none; }

.class04 {
  background: #ff8343;
  padding: 60px 40px; }
  .class04 h2 {
    color: #FFF;
    display: block;
    line-height: 1;
    margin-bottom: 24px;
    text-align: center; }
    .class04 h2 .ja {
      display: block;
      font-size: 16px;
      font-size: 1.6rem;
      line-height: 2;
      font-weight: 500;
      letter-spacing: 0.1em;
      line-height: 1.4; }
      @media only screen and (max-width: 960px) {
        .class04 h2 .ja {
          font-size: 14px;
          font-size: 1.4rem; } }
    .class04 h2 .en {
      display: block;
      font-family: "EB Garamond", serif;
      font-size: 72px;
      font-size: 7.2rem;
      line-height: 2;
      line-height: 1.8;
      font-weight: 400;
      letter-spacing: 0.01em;
      line-height: 1.4;
      text-transform: uppercase; }
      @media only screen and (max-width: 960px) {
        .class04 h2 .en {
          font-size: 61px;
          font-size: 6.1rem; } }
  .class04 .inr {
    margin: 0 auto;
    max-width: 960px; }
    .class04 .inr .copy {
      color: #FFF;
      letter-spacing: 0.06em;
      line-height: 2.2;
      margin-bottom: 40px;
      text-align: center; }
    .class04 .inr ul {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between; }
      .class04 .inr ul li {
        color: #FFF;
        margin-bottom: 40px;
        width: calc(50% - 20px); }
        .class04 .inr ul li .img {
          margin-bottom: 12px; }
        .class04 .inr ul li .desc {
          line-height: 1.7;
          text-align: center; }

/*  /////////////////////////////////////////////////
Responsive Start 
*/
@media only screen and (max-width: 960px) {
  .class01 {
    padding: 40px 6vw 20px; }
    .class01 .inr {
      margin: 0;
      max-width: 100%; }
      .class01 .inr .copy {
        font-size: 14px;
        font-size: 1.4rem;
        line-height: 2;
        margin-bottom: 40px;
        text-align: left; }
      .class01 .inr .courseList {
        display: block; }
        .class01 .inr .courseList li {
          border-radius: 12px;
          margin-bottom: 24px;
          padding: 24px;
          width: 100%; }
          .class01 .inr .courseList li dl dt {
            padding-bottom: 16px; }
            .class01 .inr .courseList li dl dt .img {
              width: 64px; }
            .class01 .inr .courseList li dl dt h3 {
              line-height: 1;
              width: calc(100% - 76px); }
              .class01 .inr .courseList li dl dt h3 .name {
                font-size: 19px;
                font-size: 1.9rem;
                letter-spacing: -0.01em;
                text-transform: uppercase; }
              .class01 .inr .courseList li dl dt h3 .old {
                font-size: 16px;
                font-size: 1.6rem;
                line-height: 2;
                font-weight: 500;
                margin-left: 4px;
                vertical-align: 2px; } }
              @media only screen and (max-width: 960px) and (max-width: 960px) {
                .class01 .inr .courseList li dl dt h3 .old {
                  font-size: 14px;
                  font-size: 1.4rem; } }
@media only screen and (max-width: 960px) {
              .class01 .inr .courseList li dl dt h3 .max {
                display: block;
                font-size: 14px;
                font-size: 1.4rem;
                font-weight: 500;
                line-height: 1;
                padding: 4px 0 6px; }
              .class01 .inr .courseList li dl dt h3 .for {
                display: block;
                font-size: 10px;
                font-size: 1rem;
                font-weight: 400; }
          .class01 .inr .courseList li dl dd {
            letter-spacing: 0.02em;
            padding-top: 16px; }
            .class01 .inr .courseList li dl dd span {
              font-size: 10px;
              font-size: 1rem;
              display: block;
              line-height: 1.6;
              padding-left: 1em;
              text-indent: -1em;
              margin-top: 8px; }
      .class01 .inr .timeSchedule {
        margin: 40px 0;
        padding: 32px 0; }
        .class01 .inr .timeSchedule h3 {
          letter-spacing: 0.06em;
          line-height: 2;
          margin-bottom: 20px; }
        .class01 .inr .timeSchedule ul {
          display: block;
          margin: 0 auto;
          max-width: 240px; }
          .class01 .inr .timeSchedule ul li {
            padding-bottom: 24px;
            width: 100%; }
            .class01 .inr .timeSchedule ul li h4 {
              background: #FFF;
              border-radius: 3px;
              color: #ff8343;
              font-size: 16px;
              font-size: 1.6rem;
              font-weight: 500;
              letter-spacing: 0.02em;
              line-height: 1.5;
              margin-bottom: 8px;
              padding: 10px 8px 12px; }
              .class01 .inr .timeSchedule ul li h4 span {
                color: #959090;
                display: block;
                font-family: "EB Garamond", serif;
                font-size: 14px;
                font-size: 1.4rem;
                line-height: 2;
                font-weight: 400;
                letter-spacing: 0.02em;
                line-height: 1.4;
                text-transform: uppercase; } }
              @media only screen and (max-width: 960px) and (max-width: 960px) {
                .class01 .inr .timeSchedule ul li h4 span {
                  font-size: 12px;
                  font-size: 1.2rem; } }
@media only screen and (max-width: 960px) {
            .class01 .inr .timeSchedule ul li dl {
              color: #FFF;
              display: flex;
              text-align: left; }
              .class01 .inr .timeSchedule ul li dl dt {
                font-size: 16px;
                font-size: 1.6rem;
                line-height: 1.4;
                padding: 4px 8px 4px 12px;
                text-align: left;
                width: 6em; }
              .class01 .inr .timeSchedule ul li dl dd {
                font-size: 16px;
                font-size: 1.6rem;
                line-height: 1.4;
                padding: 4px;
                width: calc(100% - 6em); }
                .class01 .inr .timeSchedule ul li dl dd.long {
                  font-size: 16px;
                  font-size: 1.6rem;
                  text-align: center;
                  width: 100%; }
      .class01 .inr .freePay {
        padding: 40px 15px; }
        .class01 .inr .freePay p {
          font-size: 12px;
          line-height: 2;
          margin-top: 12px; }
          .class01 .inr .freePay p a {
            color: #959090;
            font-size: 12px; }
        .class01 .inr .freePay .fpTitle {
          font-size: 18px;
          margin-top: 0; }

  .class02 {
    padding: 120px 6vw 60px; }
    .class02 .inr {
      max-width: 100%;
      margin: 0; }
      .class02 .inr h2 {
        margin-bottom: 20px; }
        .class02 .inr h2 .ja {
          font-size: 14px;
          font-size: 1.4rem;
          letter-spacing: 0.06em; }
        .class02 .inr h2 .en {
          font-size: 32px;
          font-size: 3.2rem;
          letter-spacing: 0.02em;
          line-height: 1.4;
          text-transform: uppercase; }
      .class02 .inr .tsTbl {
        border-radius: 15px;
        margin-bottom: 12px; }
        .class02 .inr .tsTbl table th, .class02 .inr .tsTbl table td {
          padding: 12px 8px; }
          .class02 .inr .tsTbl table th.clm1W, .class02 .inr .tsTbl table td.clm1W {
            width: 20%; }
          .class02 .inr .tsTbl table th.clm2W, .class02 .inr .tsTbl table td.clm2W {
            width: 40%; }
        .class02 .inr .tsTbl table th {
          font-size: 14px;
          font-size: 1.4rem;
          line-height: 1.4;
          padding: 12px 4px; }
        .class02 .inr .tsTbl table td {
          font-size: 12px;
          font-size: 1.2rem;
          line-height: 1.4; }
          .class02 .inr .tsTbl table td .en {
            font-size: 10px;
            font-size: 1rem;
            font-weight: 400;
            letter-spacing: 0em;
            line-height: 1.3;
            margin-top: 2px; }
        .class02 .inr .tsTbl table thead th, .class02 .inr .tsTbl table thead td {
          font-size: 14px;
          font-size: 1.4rem;
          font-weight: 400;
          letter-spacing: -0.02em; }
      .class02 .inr:before {
        background: url("../img/top/illust_14.png") center center no-repeat;
        background-size: cover;
        content: '';
        display: block;
        height: 12vw;
        min-height: 94px;
        width: 12vw;
        min-width: 151px;
        position: absolute;
        bottom: 255px;
        right: 3vw;
        z-index: 2;
        display: none; }
      .class02 .inr .indList li {
        font-size: 12px;
        line-height: 1.5;
        letter-spacing: 0.02em;
        margin-top: 4px; }
    .class02:before {
      background: url("../img/top/illust_04.png") center center no-repeat;
      background-size: cover;
      content: '';
      display: block;
      height: 18vw;
      min-height: auto;
      min-height: none;
      width: 18vw;
      min-width: auto;
      min-width: none;
      position: absolute;
      top: 10vw;
      right: 4vw;
      z-index: 2; }
    .class02:after {
      background: url("../img/top/illust_13.png") center center no-repeat;
      background-size: cover;
      content: '';
      display: block;
      height: 12vw;
      min-height: 118px;
      width: 12vw;
      min-width: 165px;
      position: absolute;
      top: 40%;
      left: 2vw;
      z-index: 2;
      display: none; }

  .class03 {
    padding: 60px 0 100px; }
    .class03 h2 {
      margin-bottom: 24px; }
      .class03 h2 .ja {
        font-size: 14px;
        font-size: 1.4rem;
        letter-spacing: 0.06em;
        margin-bottom: 4px; }
      .class03 h2 .en {
        font-size: 32px;
        font-size: 3.2rem;
        letter-spacing: 0.02em;
        line-height: 1.2;
        text-transform: uppercase; }
    .class03 .top04Box {
      padding-bottom: 40px; }
      .class03 .top04Box.top04Box02 {
        padding-bottom: 0; }
      .class03 .top04Box h3 {
        background-size: 38px auto;
        font-size: 17px;
        line-height: 1.4;
        letter-spacing: -0.02em;
        margin-bottom: 24px;
        padding: 0 3vw 0; }
      .class03 .top04Box .top04Flex {
        display: block;
        margin: 0;
        padding: 0; }
        .class03 .top04Box .top04Flex .img {
          padding-right: 6vw;
          width: 100%; }
          .class03 .top04Box .top04Flex .img.imgR {
            padding-right: 0;
            padding-left: 6vw; }
        .class03 .top04Box .top04Flex .data {
          padding: 16px 6vw;
          width: 100%; }
          .class03 .top04Box .top04Flex .data h4 {
            color: #6E0200;
            display: block;
            font-size: 17px;
            font-weight: bold;
            letter-spacing: 0;
            line-height: 1.5;
            margin-bottom: 16px; }
          .class03 .top04Box .top04Flex .data p {
            margin-bottom: 16px; }
        .class03 .top04Box .top04Flex.reverse {
          flex-direction: row-reverse; }
          .class03 .top04Box .top04Flex.reverse .img {
            padding-right: 0;
            padding-left: 6vw; }
          .class03 .top04Box .top04Flex.reverse .data {
            padding: 16px 6vw; }
      .class03 .top04Box .eylfList {
        display: none;
        justify-content: space-between;
        margin: 16px 0 0;
        max-width: 100%;
        padding: 0 6vw; }
        .class03 .top04Box .eylfList li {
          margin: 0 0 16px;
          width: 48%; }
      .class03 .top04Box .eylfListSP {
        display: block;
        padding: 20px 0;
        position: relative;
        width: 100%; }
        .class03 .top04Box .eylfListSP > ul {
          margin: 0; }
          .class03 .top04Box .eylfListSP > ul > li {
            margin: 0;
            text-align: center;
            margin: 0;
            width: 100%; }
            .class03 .top04Box .eylfListSP > ul > li .block {
              background: #FFF;
              border-radius: 10px;
              padding: 16px 24px 24px; }
              .class03 .top04Box .eylfListSP > ul > li .block:first-child {
                margin-bottom: 12px; }
              .class03 .top04Box .eylfListSP > ul > li .block img {
                max-width: 222px; }
              .class03 .top04Box .eylfListSP > ul > li .block p {
                font-size: 14px;
                letter-spacing: 0.04em;
                line-height: 1.6;
                min-height: 10rem;
                padding-top: 12px;
                text-align: left; }
      .class03 .top04Box .swiper-button-prev, .class03 .top04Box .swiper-button-next {
        background: #ff8343;
        border-radius: 100%;
        display: flex;
        min-width: 32px;
        min-height: 32px;
        width: 3vw;
        height: 3vw;
        cursor: pointer;
        z-index: 1000;
        transition: 0.2s; }
        .class03 .top04Box .swiper-button-prev:hover, .class03 .top04Box .swiper-button-next:hover {
          background: #1494F2; }
      .class03 .top04Box .swiper-button-prev::before,
      .class03 .top04Box .swiper-button-next::before {
        content: "";
        border-radius: 50%;
        -webkit-box-shadow: var(--box-shadow);
        box-shadow: var(--box-shadow); }
      .class03 .top04Box .swiper-button-prev::after,
      .class03 .top04Box .swiper-button-next::after {
        width: 9px;
        height: 9px;
        content: "";
        border: solid #FFF;
        border-width: 3px 3px 0 0; }
      .class03 .top04Box .swiper-button-prev::after {
        margin-left: 0.1rem;
        -webkit-transform: rotate(-135deg);
        transform: rotate(-135deg); }
      .class03 .top04Box .swiper-button-next::after {
        margin-right: 0.4rem;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
      .class03 .top04Box .swiper-button-disabled {
        pointer-events: none;
        opacity: 0; }
      .class03 .top04Box .swiper-button-prev {
        top: calc(50%);
        left: 5vw; }
      .class03 .top04Box .swiper-button-next {
        top: calc(50%);
        right: 5vw; }
    .class03:before {
      min-height: auto;
      min-height: none;
      min-width: auto;
      min-width: none;
      height: 96px;
      width: 96px;
      bottom: -12px;
      left: 4vw; }
    .class03:after {
      min-height: auto;
      min-height: none;
      min-width: auto;
      min-width: none;
      height: 96px;
      width: 96px;
      bottom: -10px;
      right: 4vw; }

  .class04 {
    padding: 20px 0 40px; }
    .class04 h2 {
      margin-bottom: 24px; }
      .class04 h2 .ja {
        font-size: 14px;
        font-size: 1.4rem;
        letter-spacing: 0.06em;
        margin-bottom: 8px; }
      .class04 h2 .en {
        font-size: 30px;
        font-size: 3rem;
        letter-spacing: -0.02em;
        line-height: 1.2;
        text-transform: uppercase; }
    .class04 .inr {
      margin: 0;
      max-width: 100%; }
      .class04 .inr .copy {
        letter-spacing: 0.06em;
        line-height: 2;
        margin-bottom: 12px;
        padding: 0 6vw;
        text-align: left; }
        .class04 .inr .copy:after {
          content: '※フリックで横スクロールできます';
          color: #DDD;
          display: block;
          font-size: 11px;
          padding: 24px 0 0; }
      .class04 .inr .spScroll {
        padding-bottom: 20px;
        width: 100%;
        overflow-x: auto; }
      .class04 .inr ul {
        display: flex;
        flex-wrap: nowrap;
        justify-content: flex-start;
        padding: 0 0 0 6vw;
        width: 480vw; }
        .class04 .inr ul li {
          color: #FFF;
          margin: 0 6vw 0 0;
          width: 74vw; }
          .class04 .inr ul li .img {
            margin-bottom: 12px; }
          .class04 .inr ul li .desc {
            line-height: 1.7; } }
/* Animation Setting */
.class01 .courseList,
.class01 .timeSchedule,
.class01 .freePay,
.class02 h2,
.class02 .tsTbl,
.class03 .inr,
.class03 .top04Box,
.class04 h2,
.class04 .copy,
.class04 .spScroll {
  opacity: 0;
  -webkit-transform: translate(0, 35px);
  -ms-transform: translate(0, 35px);
  transform: translate(0px, 35px); }

.class01 .courseList.action {
  -webkit-animation: fadeInUpTop 0.6s ease 0.4s 1 forwards;
  animation: fadeInUpTop 0.6s ease 0.4s 1 forwards; }

.class01 .timeSchedule.action {
  -webkit-animation: fadeInUpTop 0.6s ease 0.4s 1 forwards;
  animation: fadeInUpTop 0.6s ease 0.4s 1 forwards; }

.class01 .freePay.action {
  -webkit-animation: fadeInUpTop 0.6s ease 0.4s 1 forwards;
  animation: fadeInUpTop 0.6s ease 0.4s 1 forwards; }

.class02 h2.action {
  -webkit-animation: fadeInUpTop 0.6s ease 0.4s 1 forwards;
  animation: fadeInUpTop 0.6s ease 0.4s 1 forwards; }

.class02 .tsTbl.action {
  -webkit-animation: fadeInUpTop 0.6s ease 0.4s 1 forwards;
  animation: fadeInUpTop 0.6s ease 0.4s 1 forwards; }

.class03 .inr.action {
  -webkit-animation: fadeInUpTop 0.6s ease 0.4s 1 forwards;
  animation: fadeInUpTop 0.6s ease 0.4s 1 forwards; }

.class03 .top04Box.action {
  -webkit-animation: fadeInUpTop 0.6s ease 0.4s 1 forwards;
  animation: fadeInUpTop 0.6s ease 0.4s 1 forwards; }

.class04 h2.action {
  -webkit-animation: fadeInUpTop 0.6s ease 0.4s 1 forwards;
  animation: fadeInUpTop 0.6s ease 0.4s 1 forwards; }

.class04 .copy.action {
  -webkit-animation: fadeInUpTop 0.6s ease 0.4s 1 forwards;
  animation: fadeInUpTop 0.6s ease 0.4s 1 forwards; }

.class04 .spScroll.action {
  -webkit-animation: fadeInUpTop 0.6s ease 0.4s 1 forwards;
  animation: fadeInUpTop 0.6s ease 0.4s 1 forwards; }

@-webkit-keyframes fadeInUpTop {
  0% {
    opacity: 0;
    -webkit-transform: translate(0, 35px);
    -ms-transform: translate(0, 35px);
    transform: translate(0px, 35px); }
  100% {
    opacity: 1;
    -webkit-transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    -o-transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), transform 0.8s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    -webkit-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0); } }
@keyframes fadeInUpTop {
  0% {
    opacity: 0;
    -webkit-transform: translate(0, 35px);
    -ms-transform: translate(0, 35px);
    transform: translate(0px, 35px); }
  100% {
    opacity: 1;
    -webkit-transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    -o-transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), transform 0.8s cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    -webkit-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0); } }
