/* CSS Document */
.title {
  font-size: 1.4rem;
  font-size: 14px;
  font-weight: bold;
  line-height: 2em;
  letter-spacing: 0.1em; }
  .title span {
    display: block;
    font-size: 3rem;
    font-size: 30px;
    letter-spacing: 0.13em; }

.desc h3 {
  font-size: 2.5rem;
  font-size: 25px;
  font-weight: 600;
  margin-bottom: 3rem;
  line-height: 1.5em; }
  @media screen and (max-width: 991px) {
    .desc h3 {
      font-size: 2.2rem;
      font-size: 22px;
      margin-bottom: 2rem; } }
  @media screen and (max-width: 575px) {
    .desc h3 {
      font-size: 2rem;
      font-size: 20px;
      margin-bottom: 1rem; } }

.blackzone {
  background: #1a1a1a;
  color: #fff; }

#heroimg .video-wrapper {
  position: relative;
  height: 90vh;
  width: 100%; }
  #heroimg .video-wrapper video {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: right;
    object-position: right; }
  #heroimg .video-wrapper .catch-container {
    width: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center; }
    #heroimg .video-wrapper .catch-container .main-catch {
      margin-bottom: 2rem; }
      @media screen and (max-width: 575px) {
        #heroimg .video-wrapper .catch-container .main-catch {
          margin-bottom: 1.5rem; } }
      #heroimg .video-wrapper .catch-container .main-catch p {
        padding: 0 1rem 1rem 2rem; }
    #heroimg .video-wrapper .catch-container .sub-catch p {
      font-size: 20px;
      font-size: 2rem;
      padding: 1rem; }
      @media screen and (max-width: 575px) {
        #heroimg .video-wrapper .catch-container .sub-catch p {
          font-size: 16px;
          font-size: 1.6rem;
          padding: 0.75rem;
          line-height: 2.75em; } }
    #heroimg .video-wrapper .catch-container .text-background {
      display: inline;
      font-size: 60px;
      font-size: 6rem;
      font-weight: 700;
      letter-spacing: 0.15em;
      color: #fff;
      background: linear-gradient(transparent 0%, #000 0%);
      -webkit-box-decoration-break: clone;
      box-decoration-break: clone; }
      @media screen and (max-width: 575px) {
        #heroimg .video-wrapper .catch-container .text-background {
          font-size: 40px;
          font-size: 4rem; } }
  #heroimg .video-wrapper::after {
    position: absolute;
    content: "";
    bottom: 0;
    left: 0;
    height: 100px;
    width: 100%;
    background-image: linear-gradient(0deg, #1a1a1a, rgba(26, 26, 26, 0)); }

#about {
  margin-bottom: 30rem; }
  @media screen and (max-width: 575px) {
    #about {
      margin-bottom: 15rem; } }
  #about .back-gray {
    width: 100%;
    margin-bottom: 15rem;
    position: relative; }
    @media screen and (max-width: 575px) {
      #about .back-gray {
        margin-bottom: 10rem; } }
    #about .back-gray::before {
      content: '';
      position: absolute;
      bottom: 60px;
      left: 0;
      right: 0;
      height: 300px;
      background-color: #333;
      transform: skewY(-15deg);
      z-index: 0; }
      @media screen and (max-width: 767px) {
        #about .back-gray::before {
          top: 60px; } }
    #about .back-gray .container {
      position: relative;
      z-index: 99; }
      #about .back-gray .container .title {
        margin-bottom: 5rem; }
      #about .back-gray .container .flex-container {
        margin-bottom: 6rem; }
        @media screen and (max-width: 767px) {
          #about .back-gray .container .flex-container {
            display: block; } }
        #about .back-gray .container .flex-container .column {
          width: 48%; }
          @media screen and (max-width: 767px) {
            #about .back-gray .container .flex-container .column {
              width: 100%; } }
          #about .back-gray .container .flex-container .column img {
            width: 100%; }
          #about .back-gray .container .flex-container .column .title {
            margin-bottom: 2rem; }
            #about .back-gray .container .flex-container .column .title span {
              color: #d9221f; }
          @media screen and (max-width: 767px) {
            #about .back-gray .container .flex-container .column dl {
              margin-bottom: 4rem; } }
          #about .back-gray .container .flex-container .column dl dd {
            text-align: justify; }
            #about .back-gray .container .flex-container .column dl dd span {
              font-size: 20px;
              font-size: 2rem;
              font-weight: 600; }
        #about .back-gray .container .flex-container .column-outside-left {
          flex: 1;
          margin-left: calc(50% - 50vw);
          margin-right: 4%; }
          @media screen and (max-width: 767px) {
            #about .back-gray .container .flex-container .column-outside-left {
              margin: 0; } }
        #about .back-gray .container .flex-container .column-outside-right {
          flex: 1;
          margin-right: calc(50% - 50vw);
          margin-left: 4%; }
          @media screen and (max-width: 991px) {
            #about .back-gray .container .flex-container .column-outside-right {
              margin-right: calc(50% - 60vw); } }
          @media screen and (max-width: 767px) {
            #about .back-gray .container .flex-container .column-outside-right {
              margin: 0; } }
        @media screen and (max-width: 767px) {
          #about .back-gray .container .flex-container .order-1 {
            order: 1; }
          #about .back-gray .container .flex-container .order-2 {
            order: 2; } }
  #about #philosophy, #about #award {
    margin-bottom: 12rem; }
    @media screen and (max-width: 575px) {
      #about #philosophy, #about #award {
        margin-bottom: 8rem; } }
    #about #philosophy dt, #about #award dt {
      font-weight: 500;
      margin-bottom: 1rem; }
    #about #philosophy dd, #about #award dd {
      position: relative; }
      #about #philosophy dd::before, #about #award dd::before {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        font-family: "Kumbh Sans", sans-serif;
        font-weight: 800;
        font-size: 10rem;
        font-size: 100px;
        color: #fff;
        opacity: 0.1;
        width: 100%; }
        @media screen and (max-width: 767px) {
          #about #philosophy dd::before, #about #award dd::before {
            font-size: 8rem;
            font-size: 80px; } }
        @media screen and (max-width: 575px) {
          #about #philosophy dd::before, #about #award dd::before {
            font-size: 5.2rem;
            font-size: 52px; } }
  #about #philosophy {
    text-align: center; }
    #about #philosophy dd {
      font-size: 3rem;
      font-size: 30px;
      font-weight: 600;
      letter-spacing: 0.2em; }
      #about #philosophy dd::before {
        content: "PHILOSOPHY"; }
      @media screen and (max-width: 575px) {
        #about #philosophy dd {
          letter-spacing: 0.1em;
          line-height: 1.5em; } }
  #about #award {
    text-align: center; }
    #about #award dd {
      display: flex;
      justify-content: center;
      gap: 2rem; }
      @media screen and (max-width: 575px) {
        #about #award dd {
          flex-direction: column;
          align-items: center; } }
      #about #award dd img {
        width: 200px;
        height: auto; }
      #about #award dd::before {
        content: "AWARD HISTORY";
        line-height: 1em; }

#sas {
  position: relative; }
  #sas::before {
    position: absolute;
    content: "";
    background-size: contain;
    background-repeat: no-repeat;
    width: 1000px;
    height: 900px;
    left: -40rem;
    top: -10rem;
    background-image: url("../img/backdeco-l.png"); }
    @media screen and (max-width: 767px) {
      #sas::before {
        width: 800px;
        left: -37rem; } }
    @media screen and (max-width: 575px) {
      #sas::before {
        width: 700px;
        left: -35rem; } }
  #sas .sas-title {
    letter-spacing: 0.1em;
    line-height: 5rem;
    margin-bottom: 3rem; }
    #sas .sas-title h2 {
      font-size: 14px;
      font-size: 1.4rem;
      font-weight: 500; }
    #sas .sas-title p {
      font-size: 50px;
      font-size: 5rem; }
      @media screen and (max-width: 575px) {
        #sas .sas-title p {
          font-size: 45px;
          font-size: 4.5rem;
          line-height: 1em; } }
      #sas .sas-title p span {
        color: #d9221f; }
  #sas .flex-container {
    gap: 5rem; }
    @media screen and (max-width: 767px) {
      #sas .flex-container {
        flex-direction: column; } }
    #sas .flex-container .desc {
      width: 40%;
      text-align: justify; }
      @media screen and (max-width: 767px) {
        #sas .flex-container .desc {
          width: 100%;
          margin-bottom: 6rem; } }
    #sas .flex-container .sas-img {
      width: 60%;
      text-align: center;
      position: relative;
      top: -7rem; }
      @media screen and (max-width: 767px) {
        #sas .flex-container .sas-img {
          width: 100%; } }
      @media screen and (max-width: 575px) {
        #sas .flex-container .sas-img {
          width: 75%;
          display: block;
          margin: 0 auto; } }
      #sas .flex-container .sas-img img {
        max-width: 600px; }

#monogress {
  margin-bottom: 7rem;
  position: relative; }
  #monogress::before {
    position: absolute;
    content: "";
    background-size: contain;
    background-repeat: no-repeat;
    width: 1000px;
    height: 900px;
    right: -40rem;
    bottom: 10rem;
    background-image: url("../img/backdeco-r.png"); }
    @media screen and (max-width: 767px) {
      #monogress::before {
        width: 800px;
        right: -37rem; } }
    @media screen and (max-width: 575px) {
      #monogress::before {
        width: 700px;
        right: -35rem; } }
  #monogress .container {
    background: #333333;
    padding: 5rem 6rem;
    position: relative;
    z-index: 1; }
    @media screen and (max-width: 767px) {
      #monogress .container {
        padding: 4rem; } }
  #monogress .monogress-lead {
    margin-bottom: 10rem;
    gap: 7rem; }
    @media screen and (max-width: 767px) {
      #monogress .monogress-lead {
        flex-direction: column;
        gap: 3rem; } }
    #monogress .monogress-lead .monogress-title h2 {
      font-size: 1.4rem;
      font-size: 14px;
      margin-bottom: 1rem; }
    #monogress .monogress-lead .monogress-title img {
      width: 320px; }
      @media screen and (max-width: 991px) {
        #monogress .monogress-lead .monogress-title img {
          width: 280px; } }
      @media screen and (max-width: 767px) {
        #monogress .monogress-lead .monogress-title img {
          width: 260px; } }
      @media screen and (max-width: 575px) {
        #monogress .monogress-lead .monogress-title img {
          width: 240px; } }
    #monogress .monogress-lead .desc {
      width: 100%;
      text-align: justify;
      position: relative; }
      #monogress .monogress-lead .desc::before {
        position: absolute;
        content: "";
        background-size: contain;
        background-repeat: no-repeat;
        width: 150px;
        height: 200px;
        right: 0;
        bottom: 0;
        background-image: url("../img/monogress-mark.svg"); }
        @media screen and (max-width: 767px) {
          #monogress .monogress-lead .desc::before {
            width: 120px;
            height: 170px;
            bottom: 6rem; } }
        @media screen and (max-width: 575px) {
          #monogress .monogress-lead .desc::before {
            width: 100px;
            bottom: 10rem; } }
  #monogress .keywords {
    border: 1px solid #fff;
    padding: 2rem 6rem;
    margin-bottom: 5rem;
    position: relative; }
    @media screen and (max-width: 767px) {
      #monogress .keywords {
        border: none;
        padding: 0; } }
    #monogress .keywords .title {
      text-align: center;
      line-height: 2.5em;
      width: 40%;
      margin: 0 auto;
      background: #333333;
      position: absolute;
      top: -5rem;
      right: 0;
      left: 0; }
      @media screen and (max-width: 1199px) {
        #monogress .keywords .title {
          width: 50%; } }
      @media screen and (max-width: 991px) {
        #monogress .keywords .title {
          width: 53%;
          line-height: 2em; } }
      @media screen and (max-width: 767px) {
        #monogress .keywords .title {
          width: 100%; } }
      #monogress .keywords .title span {
        font-size: 4rem;
        font-size: 40px;
        color: #d9221f; }
        @media screen and (max-width: 991px) {
          #monogress .keywords .title span {
            font-size: 3.2rem;
            font-size: 32px; } }
    #monogress .keywords .keyword-box {
      align-items: center;
      padding: 4rem 0;
      position: relative;
      gap: 2rem; }
      @media screen and (max-width: 767px) {
        #monogress .keywords .keyword-box {
          padding: 3.5rem 0; } }
      @media screen and (max-width: 575px) {
        #monogress .keywords .keyword-box {
          flex-direction: column; } }
      @media screen and (max-width: 575px) {
        #monogress .keywords .keyword-box dl {
          flex-direction: column; } }
      #monogress .keywords .keyword-box:not(:last-child) {
        border-bottom: 1px solid #fff; }
      #monogress .keywords .keyword-box::before {
        position: absolute;
        content: "";
        background-size: contain;
        background-repeat: no-repeat;
        width: 120px;
        height: 75px;
        right: 0;
        top: 3rem; }
        @media screen and (max-width: 991px) {
          #monogress .keywords .keyword-box::before {
            height: 60px;
            width: 90px; } }
        @media screen and (max-width: 575px) {
          #monogress .keywords .keyword-box::before {
            left: 0;
            height: 60px;
            top: 4rem; } }
      #monogress .keywords .keyword-box:nth-of-type(1)::before {
        background-image: url("../img/01.svg"); }
      #monogress .keywords .keyword-box:nth-of-type(2)::before {
        background-image: url("../img/02.svg"); }
      #monogress .keywords .keyword-box:nth-of-type(3)::before {
        background-image: url("../img/03.svg"); }
    #monogress .keywords .keyword-img {
      width: 23%;
      text-align: center; }
      @media screen and (max-width: 767px) {
        #monogress .keywords .keyword-img {
          width: 25%; } }
      @media screen and (max-width: 575px) {
        #monogress .keywords .keyword-img {
          width: 40%; } }
      #monogress .keywords .keyword-img img {
        width: auto;
        height: 100px; }
    #monogress .keywords dl {
      width: 80%;
      margin: 0;
      align-items: center;
      z-index: 1;
      gap: 2rem; }
      @media screen and (max-width: 767px) {
        #monogress .keywords dl {
          width: 75%; } }
      @media screen and (max-width: 575px) {
        #monogress .keywords dl {
          width: 90%;
          gap: 1rem; } }
      #monogress .keywords dl dt {
        width: 30%;
        font-size: 5rem;
        font-size: 50px;
        line-height: 0.6em;
        letter-spacing: 0.05em; }
        @media screen and (max-width: 1199px) {
          #monogress .keywords dl dt {
            font-size: 4.5rem;
            font-size: 45px; } }
        @media screen and (max-width: 991px) {
          #monogress .keywords dl dt {
            width: 40%;
            font-size: 4rem;
            font-size: 40px; } }
        @media screen and (max-width: 767px) {
          #monogress .keywords dl dt {
            width: 45%;
            font-size: 3.4rem;
            font-size: 34px; } }
        @media screen and (max-width: 575px) {
          #monogress .keywords dl dt {
            width: 100%;
            text-align: center; } }
        #monogress .keywords dl dt span {
          font-size: 2rem;
          font-size: 20px;
          color: #d9221f; }
          @media screen and (max-width: 991px) {
            #monogress .keywords dl dt span {
              font-size: 1.8rem;
              font-size: 18px; } }
          @media screen and (max-width: 767px) {
            #monogress .keywords dl dt span {
              font-size: 1.6rem;
              font-size: 16px; } }
      #monogress .keywords dl dd {
        width: 70%;
        margin: 0;
        text-align: justify; }
        @media screen and (max-width: 575px) {
          #monogress .keywords dl dd {
            width: 100%; } }
  #monogress .merit ul {
    list-style: none;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 0rem; }
    @media screen and (max-width: 1199px) {
      #monogress .merit ul {
        gap: 4rem; } }
    @media screen and (max-width: 767px) {
      #monogress .merit ul {
        grid-template-columns: 1fr 1fr; } }
    @media screen and (max-width: 575px) {
      #monogress .merit ul {
        gap: 2rem;
        grid-template-columns: 1fr; } }
    #monogress .merit ul li {
      flex: 1; }
      #monogress .merit ul li h4 {
        text-align: center;
        font-size: 21px;
        font-size: 2.1rem;
        line-height: 1.5em;
        margin-bottom: 2rem; }
        @media screen and (max-width: 575px) {
          #monogress .merit ul li h4 {
            font-size: 18px;
            font-size: 1.8rem;
            margin-bottom: 1rem; } }
        #monogress .merit ul li h4 span {
          display: block;
          font-size: 16px;
          font-size: 1.6rem;
          color: #d9221f; }
      #monogress .merit ul li p {
        text-align: center; }
        @media screen and (max-width: 1199px) {
          #monogress .merit ul li p {
            text-align: justify; } }

#improvement {
  margin-bottom: 10rem;
  position: relative; }
  #improvement::before {
    position: absolute;
    content: "";
    background-size: contain;
    background-repeat: no-repeat;
    width: 1000px;
    height: 900px;
    left: -40rem;
    bottom: -10rem;
    background-image: url("../img/backdeco-l.png"); }
    @media screen and (max-width: 767px) {
      #improvement::before {
        width: 800px;
        left: -37rem; } }
    @media screen and (max-width: 575px) {
      #improvement::before {
        width: 700px;
        left: -35rem;
        top: -10rem; } }
  #improvement .container {
    position: relative; }
    #improvement .container .title span {
      color: #d9221f; }
    @media screen and (max-width: 767px) {
      #improvement .container .flex-container {
        flex-direction: column; } }
    #improvement .container .improve-main {
      justify-content: space-between;
      margin-bottom: 7rem;
      gap: 70px; }
      @media screen and (max-width: 767px) {
        #improvement .container .improve-main {
          gap: 0; } }
      #improvement .container .improve-main .desc {
        width: 50%;
        padding-top: 4rem;
        text-align: justify; }
        @media screen and (max-width: 767px) {
          #improvement .container .improve-main .desc {
            padding-top: 1rem;
            width: 100%;
            margin-bottom: 4rem; } }
      #improvement .container .improve-main .improve-1-img {
        width: 50%;
        text-align: center; }
        @media screen and (max-width: 767px) {
          #improvement .container .improve-main .improve-1-img {
            width: 100%; } }
      #improvement .container .improve-main img {
        width: 310px;
        height: auto; }
        @media screen and (max-width: 991px) {
          #improvement .container .improve-main img {
            width: 250px; } }
        @media screen and (max-width: 767px) {
          #improvement .container .improve-main img {
            width: 230px;
            display: block;
            margin: 0 auto; } }
    #improvement .container .improve-sub {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 70px; }
      @media screen and (max-width: 767px) {
        #improvement .container .improve-sub {
          gap: 40px; } }
      @media screen and (max-width: 575px) {
        #improvement .container .improve-sub {
          grid-template-columns: repeat(1, 1fr);
          gap: 30px; } }
      #improvement .container .improve-sub img {
        width: 330px;
        height: auto; }
        @media screen and (max-width: 991px) {
          #improvement .container .improve-sub img {
            width: 250px; } }
        @media screen and (max-width: 767px) {
          #improvement .container .improve-sub img {
            width: 230px; } }
      #improvement .container .improve-sub dl {
        text-align: center; }
        #improvement .container .improve-sub dl dt {
          border: 1px solid #fff;
          border-radius: 100px;
          margin-bottom: 2rem; }

#movie {
  margin-bottom: 10rem; }
  #movie .title {
    margin-bottom: 3rem; }
    @media screen and (max-width: 575px) {
      #movie .title {
        margin-bottom: 2rem; } }
    #movie .title span {
      color: #d9221f; }
  #movie iframe[src*="youtube.com"],
  #movie iframe[src*="youtube-nocookie.com"] {
    aspect-ratio: 16 / 9;
    width: 100%;
    height: auto; }

#now {
  padding-bottom: 10rem;
  margin-bottom: 8rem;
  text-align: center; }
  @media screen and (max-width: 575px) {
    #now {
      margin-bottom: 5rem; } }
  #now .title {
    margin-bottom: 3rem; }
    #now .title span {
      color: #d9221f; }
  #now dl dt {
    font-size: 3rem;
    font-size: 30px;
    font-family: "Zen Old Mincho", serif;
    font-weight: 400;
    letter-spacing: 0.1em;
    line-height: normal;
    margin-bottom: 3rem; }
    @media screen and (max-width: 575px) {
      #now dl dt {
        font-size: 2.4rem;
        font-size: 24px; } }
  #now dl dd span {
    font-size: 1.9rem;
    font-size: 19px; }

#flow {
  margin-bottom: 8rem; }
  @media screen and (max-width: 575px) {
    #flow {
      margin-bottom: 5rem; } }
  #flow .title {
    margin-bottom: 5rem; }
    @media screen and (max-width: 575px) {
      #flow .title {
        margin-bottom: 3rem; } }
  #flow .flow_design {
    display: flex;
    justify-content: left;
    align-items: center; }
  #flow .flow {
    padding-left: 0; }
  #flow .flow > li {
    list-style-type: none;
    position: relative;
    padding-left: 100px; }
    @media screen and (max-width: 575px) {
      #flow .flow > li {
        padding-left: 90px; } }
  #flow .flow > li:not(:last-child) {
    padding-bottom: 30px; }
  #flow .flow > li .icon {
    width: 80px;
    height: 80px;
    line-height: 77px;
    text-align: center;
    border-radius: 100vh;
    border: 1px solid #8d8d8d;
    display: inline-block;
    background: #fff;
    color: #8d8d8d;
    position: absolute;
    left: 0; }
    @media screen and (max-width: 575px) {
      #flow .flow > li .icon {
        width: 75px;
        height: 75px;
        line-height: 73px; } }
  #flow .flow > li:not(:last-child)::before {
    content: '';
    background: #8d8d8d;
    width: 1px;
    height: 100%;
    position: absolute;
    top: calc(50% - -30px);
    left: 40px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%); }
  #flow .flow > li dl dt {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 600;
    letter-spacing: 0.05em; }
    #flow .flow > li dl dt span {
      font-size: 25px;
      font-size: 2.5rem; }
  #flow .flow > li dl dd {
    margin-left: 0; }

#faq {
  padding: 8rem 0;
  margin-bottom: 8rem;
  background: #efefef; }
  @media screen and (max-width: 767px) {
    #faq {
      padding: 5rem 0;
      margin-bottom: 5rem; } }
  #faq #accordion-container .title {
    margin-bottom: 5rem; }
    @media screen and (max-width: 767px) {
      #faq #accordion-container .title {
        margin-bottom: 2rem; } }
  #faq #accordion-container .accordion .accordion-item {
    margin-bottom: 1.5rem;
    border: none;
    border-radius: inherit;
    padding: 1rem 2rem;
    box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.05); }
    #faq #accordion-container .accordion .accordion-item .accordion-button {
      background-color: #fff;
      font-size: 16px;
      font-size: 1.6rem;
      font-weight: 600;
      padding: 1rem;
      transition: 0.1s; }
      #faq #accordion-container .accordion .accordion-item .accordion-button span {
        color: #a7a7a7;
        margin-right: 2rem; }
      #faq #accordion-container .accordion .accordion-item .accordion-button:hover {
        color: #aaa; }
      #faq #accordion-container .accordion .accordion-item .accordion-button:focus {
        border-color: inherit;
        box-shadow: none; }
      #faq #accordion-container .accordion .accordion-item .accordion-button::after {
        flex-shrink: 0;
        margin-left: auto;
        font-family: "Font Awesome 5 Free";
        content: "\f13a";
        color: #a7a7a7;
        font-weight: 900;
        font-size: 23px;
        font-size: 2.3rem;
        width: 23px;
        height: 27px;
        background-image: none; }
      #faq #accordion-container .accordion .accordion-item .accordion-button:not(.collapsed) {
        color: #333; }
    #faq #accordion-container .accordion .accordion-item .accordion-body dl {
      padding: 2.5rem 2rem 1.5rem; }
      @media screen and (max-width: 767px) {
        #faq #accordion-container .accordion .accordion-item .accordion-body dl {
          padding: 1.5rem 2rem 0.5rem; } }
      #faq #accordion-container .accordion .accordion-item .accordion-body dl dd {
        padding-left: 2rem;
        display: flex;
        flex-direction: column;
        margin-bottom: 0; }
        @media screen and (max-width: 767px) {
          #faq #accordion-container .accordion .accordion-item .accordion-body dl dd {
            padding: 1.5rem 0 0; } }
        #faq #accordion-container .accordion .accordion-item .accordion-body dl dd p {
          text-align: justify; }
          @media screen and (max-width: 767px) {
            #faq #accordion-container .accordion .accordion-item .accordion-body dl dd p {
              padding-bottom: 0.5rem; } }

#plan {
  margin-bottom: 15rem; }
  @media screen and (max-width: 767px) {
    #plan {
      margin-bottom: 10rem; } }
  #plan .title {
    margin-bottom: 3rem; }
    @media screen and (max-width: 767px) {
      #plan .title {
        margin-bottom: 2rem; } }
  #plan .plan-container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px; }
    @media screen and (max-width: 767px) {
      #plan .plan-container {
        gap: 20px; } }
    @media screen and (max-width: 575px) {
      #plan .plan-container {
        grid-template-columns: repeat(1, 1fr);
        gap: 10px; } }
    #plan .plan-container dl {
      box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15); }
      #plan .plan-container dl dt {
        text-align: center;
        font-size: 20px;
        font-size: 2rem;
        background-image: linear-gradient(150deg, #b21b1f, #620000);
        color: #fff; }
        @media screen and (max-width: 767px) {
          #plan .plan-container dl dt {
            font-size: 16px;
            font-size: 1.6rem; } }
        #plan .plan-container dl dt span {
          font-size: 40px;
          font-size: 4rem; }
          @media screen and (max-width: 767px) {
            #plan .plan-container dl dt span {
              font-size: 30px;
              font-size: 3rem; } }
      #plan .plan-container dl dd {
        padding: 3rem; }
        @media screen and (max-width: 767px) {
          #plan .plan-container dl dd {
            padding: 2rem; } }

#banner {
  margin-bottom: 8rem; }
  @media screen and (max-width: 575px) {
    #banner {
      margin-bottom: 5rem; } }
  #banner .flex-container {
    justify-content: center;
    gap: 50px;
    margin-bottom: 5rem; }
    @media screen and (max-width: 767px) {
      #banner .flex-container {
        gap: 20px; } }
    @media screen and (max-width: 575px) {
      #banner .flex-container {
        flex-direction: column;
        gap: 30px; } }
    #banner .flex-container .banner {
      text-align: center; }
      #banner .flex-container .banner p {
        font-weight: 600; }
        @media screen and (max-width: 575px) {
          #banner .flex-container .banner p {
            margin-bottom: 0.5rem; } }
  #banner a.link {
    font-size: 2rem;
    font-size: 20px;
    position: relative;
    display: inline-block;
    padding: 1rem 4rem;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: all 0.3s;
    vertical-align: middle;
    text-decoration: none;
    letter-spacing: 0.1em; }
    @media screen and (max-width: 575px) {
      #banner a.link {
        font-size: 1.8rem;
        font-size: 18px; } }
  #banner a.link-flat {
    width: 300px;
    overflow: hidden;
    padding: 1.5rem 2rem;
    text-align: left;
    color: #333;
    background: #fff;
    border: 1px solid #333;
    position: relative; }
    @media screen and (max-width: 767px) {
      #banner a.link-flat {
        width: 250px; } }
    @media screen and (max-width: 575px) {
      #banner a.link-flat {
        padding: 1rem 2rem; } }
    #banner a.link-flat::after {
      content: '';
      font-family: "Font Awesome 5 Free";
      content: "\f054";
      font-weight: 900;
      padding-right: 5px;
      color: #333;
      position: absolute;
      right: 10px;
      -webkit-transition: all .3s ease-in-out;
      transition: all .3s ease-in-out; }
    #banner a.link-flat:hover {
      background: #333;
      color: #fff; }
      #banner a.link-flat:hover::after {
        right: 3px;
        color: #fff; }
    #banner a.link-flat span {
      position: relative; }
