/*=============================================
 * HOME
*=============================================*/
#mv {
  display: flex;
  align-items: center;
  width: 100%;
  height: 100vh;
  min-height: 900px;
  position: relative; }
  #mv video {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    object-fit: cover; }
  #mv .wrap {
    z-index: 1; }
  #mv .deco {
    width: 46.5%;
    position: absolute;
    top: 0;
    right: 0;
    opacity: 0.7; }
  #mv h2 {
    color: #fff;
    font-weight: 600;
    font-style: italic;
    font-size: 128px;
    letter-spacing: 0.06em;
    line-height: 1.5;
    text-transform: uppercase; }
    #mv h2 span {
      font-style: italic;
      color: transparent;
      -webkit-text-stroke-width: 1px;
      -webkit-text-stroke-color: #fff; }
  #mv .txt {
    color: #fff;
    font-weight: 700;
    font-size: 28px;
    letter-spacing: 0.12em;
    line-height: 76px;
    padding-top: 20px; }
  #mv .txt-en {
    width: 416px;
    font-weight: 600;
    font-size: 16px;
    line-height: 1.62;
    position: absolute;
    top: 50px;
    right: 0; }
    #mv .txt-en:before {
      content: '';
      display: block;
      width: 60px;
      height: 3px;
      background-color: #9B060C;
      margin-bottom: 15px; }

@media screen and (max-width: 1200px) {
  #mv h2 {
    font-size: 100px; }
  #mv .txt {
    font-size: 24px;
    line-height: 2; }
  #mv .txt-en {
    width: 366px;
    top: 38px; } }
@media screen and (max-width: 1023px) {
  #mv .wrap {
    padding-bottom: 20vw; }
  #mv .txt-en {
    width: 100%;
    position: static;
    margin-top: 50px; } }
@media screen and (max-width: 767px) {
  #mv {
    min-height: inherit; }
    #mv .wrap {
      padding-bottom: 0; }
    #mv h2 {
      font-size: 50px; }
    #mv .txt {
      font-size: 18px;
      padding-top: 10px; }
    #mv .txt-en {
      font-size: 14px;
      margin-top: 20px; } }
@media screen and (min-width: 1441px) {
  #mv .wrap {
    max-width: 1240px; } }
#concept {
  background-image: url("../img/index/concept-bg.webp");
  font-weight: 700;
  font-size: 28px;
  line-height: 3.13;
  letter-spacing: 0.16em;
  padding: 350px 0;
  position: relative; }
  #concept .wrap {
    z-index: 1; }
  #concept .txt p + p {
    padding-top: 90px; }
  #concept .photo-1 {
    width: 531px;
    position: absolute;
    top: -300px;
    left: 0; }
  #concept .photo-2 {
    width: 225px;
    position: absolute;
    top: 235px;
    left: calc(50% + 515px); }
  #concept .photo-3 {
    width: 176px;
    position: absolute;
    bottom: 210px;
    left: calc(50% - 590px); }

@media screen and (max-width: 1500px) {
  #concept .photo-2 {
    right: 0;
    left: auto; } }
@media screen and (max-width: 1200px) {
  #concept .photo-3 {
    right: auto;
    left: 0; } }
@media screen and (max-width: 1023px) {
  #concept .photo-1 {
    top: -200px; } }
@media screen and (max-width: 767px) {
  #concept {
    min-height: 100%;
    font-size: 18px;
    line-height: 2;
    padding: 50vw 0 35vw; }
    #concept .txt p + p {
      padding-top: 30px; }
    #concept .photo-1 {
      width: 50%;
      top: -10vw; }
    #concept .photo-2 {
      width: 30%;
      top: 5vw; }
    #concept .photo-3 {
      width: 30%;
      bottom: 5vw; } }
#about {
  position: relative;
  padding: 150px 0 0;
  overflow: hidden; }
  #about .swiper {
    width: 100%;
    position: absolute;
    top: 180px;
    left: 0; }
    #about .swiper-wrapper {
      transition-timing-function: linear; }
    #about .swiper-slide {
      width: 3572px;
      margin-right: 100px; }
  #about .wrap {
    z-index: 1; }
  #about h2 {
    font-weight: 700;
    font-size: 40px;
    letter-spacing: 0.06em;
    line-height: 2.2; }
    #about h2 span {
      display: inline-block; }
    #about h2 > span {
      background-image: linear-gradient(#000, #000);
      background-size: 0% 100%;
      background-repeat: no-repeat;
      background-position: left bottom;
      padding: 0 15px;
      transition: background-size 1s cubic-bezier(0.4, 0, 0.2, 1); }
      #about h2 > span:not(:last-child) {
        margin-bottom: 24px; }
    #about h2[style*="visible"] > span {
      background-size: 100% 100%; }
  #about .box {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    margin-right: -200px;
    padding-top: 75px; }
  #about .txt {
    width: 810px;
    font-weight: 700; }
    #about .txt p:not(:last-child) {
      padding-bottom: 40px; }
    #about .txt span {
      background-image: linear-gradient(#9B060C, #9B060C);
      background-size: 0% 100%;
      background-repeat: no-repeat;
      background-position: left bottom;
      margin: 0 5px;
      padding: 0 5px;
      transition: background-size 0.5s cubic-bezier(0.4, 0, 0.2, 1); }
      #about .txt span[style*="visible"] {
        background-size: 100% 100%; }
  #about figure {
    width: 498px;
    padding-top: 20px; }

@media screen and (max-width: 1440px) {
  #about h2 {
    font-size: 38px; }
  #about .box {
    margin-right: 0; }
    #about .box figure {
      width: 320px; } }
@media screen and (max-width: 1200px) {
  #about .swiper {
    top: 160px; }
  #about h2 {
    font-size: 32px; } }
@media screen and (max-width: 1023px) {
  #about .swiper {
    top: 40px; }
  #about h2 span {
    padding: 0; }
  #about h2 span:not(:last-child) {
    margin-bottom: 12px; }
  #about h2 > span {
    background: transparent; }
    #about h2 > span span {
      background-image: linear-gradient(#000, #000);
      background-size: 0% 100%;
      background-repeat: no-repeat;
      background-position: left bottom;
      padding: 0 10px;
      transition: background-size 1s cubic-bezier(0.4, 0, 0.2, 1);
      color: transparent; }
  #about h2[style*="visible"] > span span {
    background-size: 100% 100%;
    color: #fff; }
  #about .box {
    flex-direction: column;
    align-items: center; }
    #about .box .txt {
      width: 100%; }
    #about .box figure {
      width: 468px; } }
@media screen and (max-width: 767px) {
  #about {
    padding-top: 110px; }
    #about .swiper {
      top: 20px; }
      #about .swiper-slide {
        width: 1786px;
        margin-right: 50px; }
    #about h2 {
      font-size: 20px; }
    #about .box {
      padding-top: 30px; }
      #about .box .txt {
        width: 100%; }
        #about .box .txt p:not(:last-child) {
          padding-bottom: 20px; }
      #about .box figure {
        width: 94%; margin-left:6%;} }
#numbers {
  padding: 250px 0 175px;
  position: relative; }
  #numbers:before {
    content: '';
    width: 100%;
    padding-top: 104%;
    background: url("../img/index/numbers-bg.webp") no-repeat center bottom/100% auto;
    position: absolute;
    bottom: 0;
    left: 0; }
  #numbers [class*="box"] {
    line-height: 1.5; }
  #numbers [class*="col"] {
    background-color: #393939;
    padding: 15px 15px 0;
    position: relative; }
    #numbers [class*="col"] .txt {
      position: relative; }
    #numbers [class*="col"] .deco-1,
    #numbers [class*="col"] .deco-2,
    #numbers [class*="col"] .deco-3 {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%); }
    #numbers [class*="col"] .deco-1 {
      width: 248px; }
    #numbers [class*="col"] .deco-2 {
      width: 228px; }
    #numbers [class*="col"] .deco-3 {
      width: 207px; }
  #numbers h3 {
    background-color: #000;
    font-weight: 700;
    font-size: 22px;
    line-height: 42px;
    letter-spacing: 0.07em;
    text-align: center;
    padding: 15px; }
  #numbers .number {
    font-weight: 700;
    font-size: 36px;
    letter-spacing: 0.07em;
    line-height: 1; }
    #numbers .number span {
      font-size: 90px; }
  #numbers .box-1 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    padding-top: 100px; }
    #numbers .box-1 .col-1 .txt {
      padding: 25px 0; }
    #numbers .box-1 .col-1 .number {
      padding: 40px 0; }
    #numbers .box-1 .col-1 .note {
      font-weight: 500;
      font-size: 20px;
      letter-spacing: 0.07em; }
    #numbers .box-1 .col-2 .txt {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 67px 0; }
      #numbers .box-1 .col-2 .txt dl dt {
        font-size: 22px; }
    #numbers .box-1 .col-3 .txt {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 0 20px;
      padding: 50px 0; }
    #numbers .box-1 .col-3 dl {
      display: flex;
      justify-content: space-between;
      align-items: baseline; }
      #numbers .box-1 .col-3 dl dt {
        font-weight: 700;
        font-size: 22px; }
      #numbers .box-1 .col-3 dl dd {
        width: 95px;
        font-weight: 700;
        font-size: 32px;
        text-align: center; }
        #numbers .box-1 .col-3 dl dd span {
          font-size: 50px; }
  #numbers .box-2 {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 10px;
    padding-top: 10px; }
    #numbers .box-2 .col-1 .txt {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 20px 80px;
      padding: 19px 0; }
    #numbers .box-2 .col-1 dl {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      font-size: 20px;
      line-height: 1;
      letter-spacing: 0.07em; }
      #numbers .box-2 .col-1 dl dd {
        width: 50px;
        font-size: 38px;
        color: #fff;
        text-align: center; }
    #numbers .box-2 .col-2 .txt {
      padding: 80px 0; }
  #numbers .box-3 {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 10px;
    padding-top: 10px; }
    #numbers .box-3 .col-1 .txt {
      font-size: 24px;
      line-height: 2.5;
      letter-spacing: 0.07em;
      color: #fff;
      text-align: center;
      padding: 79px 0; }
    #numbers .box-3 .col-2 .txt {
      padding: 25px 0; }
    #numbers .box-3 .col-2 dl {
      display: grid;
      grid-template-columns: 220px 1fr;
      font-size: 18px;
      line-height: 2;
      letter-spacing: 0.02em; }

@media screen and (max-width: 1200px) {
  #numbers .number span {
    font-size: 80px; }
  #numbers .box-1 .col-3 .txt {
    gap: 0 10px; }
  #numbers .box-1 .col-3 dl dd {
    width: 70px;
    font-size: 20px; }
    #numbers .box-1 .col-3 dl dd span {
      font-size: 40px; }
  #numbers .box-2 .col-1 .txt {
    gap: 20px; }
  #numbers .box-3 .col-2 dl {
    grid-template-columns: 180px 1fr;
    font-size: 16px; } }
@media screen and (max-width: 1023px) {
  #numbers .box-1,
  #numbers .box-2,
  #numbers .box-3 {
    grid-template-columns: 1fr; }
  #numbers .box-1 .col-2 .txt {
    justify-content: center;
    gap: 30px; }
  #numbers .box-1 .col-3 .txt {
    gap: 0 40px; } }
@media screen and (max-width: 767px) {
  #numbers {
    padding: 80px 0; }
    #numbers [class*='col'] {
      padding: 10px 10px 0; }
    #numbers h3 {
      font-size: 18px;
      line-height: 30px;
      padding: 10px; }
    #numbers .number {
      font-size: 25px; }
      #numbers .number span {
        font-size: 80px; }
    #numbers .box-1 {
      padding-top: 50px; }
      #numbers .box-1 .col-2 .txt {
        gap: 0 20px;
        padding: 20px 0; }
        #numbers .box-1 .col-2 .txt dl dt {
          font-size: 18px; }
      #numbers .box-1 .col-3 .txt {
        gap: 0 20px;
        padding: 20px 0; }
    #numbers .box-2 .col-1 .txt {
      grid-template-columns: 1fr;
      gap: 10px;
      padding: 20px 0; }
    #numbers .box-3 .col-2 .txt {
      padding: 20px 0; }
    #numbers .box-3 .col-2 dl {
      grid-template-columns: 1fr;
      font-size: 14px; }
      #numbers .box-3 .col-2 dl + dl {
        padding-top: 10px; }
    #numbers .box-3 .col-1 .txt {
      font-size: 19px;}

}
#program {
  background: url("../img/index/program-bg.webp") no-repeat center/cover;
  padding: 150px 0; }
  #program .box {
    font-size: 22px;
    padding-top: 75px; }
    #program .box .item {
      display: grid;
      grid-template-columns: 220px 1fr;
      align-items: center;
      min-height: 114px;
      background-color: rgba(0, 0, 0, 0.85);
      position: relative;
      padding: 0 120px 0 30px; }
      #program .box .item:not(:last-child) {
        margin-bottom: 60px; }
        #program .box .item:not(:last-child):after {
          content: '';
          width: 15px;
          height: 9px;
          background: url("../img/index/arrow-down.webp") no-repeat center top/100% auto;
          position: absolute;
          top: 100%;
          left: 50%;
          transform: translateX(-50%);
          margin-top: 24px; }
      #program .box .item dt {
        color: #fff; }
      #program .box .item dd {
        font-weight: 500;
        line-height: 1.5; }
      #program .box .item .no {
        color: #2D2D2D;
        font-weight: 600;
        font-size: 32px;
        line-height: 1;
        position: absolute;
        top: 50%;
        right: 30px;
        transform: translateY(-50%); }

@media screen and (max-width: 767px) {
  #program {
    padding: 80px 0; }
    #program .box {
      font-size: 18px;
      line-height: 1;
      padding-top: 30px; }
      #program .box .item {
        grid-template-columns: 1fr;
        align-items: center;
        gap: 10px;
        min-height: inherit;
        padding: 20px 80px 20px 20px; }
        #program .box .item:not(:last-child) {
          margin-bottom: 20px; }
          #program .box .item:not(:last-child):after {
            margin-top: 5px; }
        #program .box .item .no {
          font-size: 24px;
          right: 10px; } }
#business-leadership {
  padding: 150px 0; }
  #business-leadership h2 {
    padding-bottom: 60px; }
  #business-leadership h3 {
    display: inline-block;
    background-image: linear-gradient(#000, #000);
    background-size: 0% 100%;
    background-repeat: no-repeat;
    background-position: left bottom;
    font-weight: 700;
    font-size: 30px;
    letter-spacing: 0.06em;
    padding: 4px 30px;
    transition: background-size 0.5s cubic-bezier(0.4, 0, 0.2, 1); }
    #business-leadership h3[style*="visible"] {
      background-size: 100% 100%; }
  #business-leadership .desc {
    font-size: 22px;
    line-height: 3.13;
    padding-top: 30px; }
  #business-leadership .box {
    padding-top: 64px; }
    #business-leadership .box .item {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 20px;
      background-color: #2C2C29;
      position: relative;
      padding: 50px 85px 50px 50px; }
      #business-leadership .box .item:not(:last-child) {
        margin-bottom: 10px; }
    #business-leadership .box .no {
      color: #9B060C;
      font-weight: 600;
      font-size: 32px;
      letter-spacing: 0.06em;
      line-height: 1;
      position: absolute;
      top: 20px;
      right: 20px; }
    #business-leadership .box h4 {
      font-weight: 700;
      font-size: 24px;
      letter-spacing: 0.08em;
      color: #fff; }
      #business-leadership .box h4 span {
        display: block;
        font-weight: 700;
        font-style: italic;
        font-size: 17px;
        color: #585858; }
    #business-leadership .box .txt {
      font-weight: 500;
      font-size: 18px;
      padding-top: 15px; }
    #business-leadership .box figure {
      width: 312px;
      text-align: center; }
      #business-leadership .box figure img {
        max-width: inherit;
        max-height: 195px; }

@media screen and (max-width: 1023px) {
  #business-leadership h3 {
    font-size: 25px; }
  #business-leadership .box .item {
    flex-direction: column;
    padding: 50px; }
  #business-leadership .box .txt br.pc {
    display: none; }
  #business-leadership .box h4 {
    text-align: center; }
  #business-leadership .box figure {
    margin: 0 auto; } }
@media screen and (max-width: 767px) {
  #business-leadership {
    padding: 80px 0; }
    #business-leadership h2 {
      padding-bottom: 20px; }
    #business-leadership h3 {
      display: block;
      font-size: 20px;
      padding: 5px; }
    #business-leadership .desc {
      font-size: 18px;
      line-height: 2;
      padding-top: 20px; }
    #business-leadership .box .item {
      padding: 40px 20px 20px; }
    #business-leadership .box .no {
      top: 10px;
      right: 10px; }
    #business-leadership .box h4 {
      font-size: 20px;
      margin: 0 -10px; }
      #business-leadership .box h4 span {
        font-size: 16px; }
    #business-leadership .box .txt {
      font-size: 14px; }
    #business-leadership .box figure img {
      max-height: 120px; } }
#evaluation-growth {
  padding-bottom: 150px; }
  #evaluation-growth .swiper {
    padding-bottom: 150px; }
    #evaluation-growth .swiper-wrapper {
      transition-timing-function: linear; }
    #evaluation-growth .swiper-slide {
      width: 640px; }
  #evaluation-growth .box {
    background-color: #2C2C29;
    margin-top: 65px;
    padding: 48px 80px 80px; }
    #evaluation-growth .box h3 {
      font-weight: 700;
      font-size: 22px;
      letter-spacing: 0.05em; }
    #evaluation-growth .box h4 {
      display: inline-block;
      color: #fff;
      font-weight: 700;
      font-size: 24px;
      letter-spacing: 0.14em;
      border-bottom: 3px solid #9B060C;
      padding-top: 50px; }
    #evaluation-growth .box ul {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      gap: 10px;
      padding-top: 50px; }
      #evaluation-growth .box ul li {
        background-color: #353535;
        font-size: 21px;
        letter-spacing: 0.04em;
        line-height: 1.5;
        color: #fff;
        padding: 27px 0; }
        #evaluation-growth .box ul li span {
          font-style: italic;
          font-size: 16px;
          color: #545454; }
        #evaluation-growth .box ul li small {
          font-size: 16px;
          color: #ccc; }
    #evaluation-growth .box .txt {
      font-weight: 500;
      font-size: 18px;
      letter-spacing: 0.05em;
      padding-top: 80px; }

@media screen and (max-width: 1023px) {
  #evaluation-growth .box {
    padding: 50px 40px; }
    #evaluation-growth .box ul {
      display: flex;
      justify-content: center;
      flex-wrap: wrap; }
      #evaluation-growth .box ul li {
        width: 170px; } }
@media screen and (max-width: 767px) {
  #evaluation-growth {
    padding-bottom: 80px; }
    #evaluation-growth .swiper {
      padding-bottom: 50px; }
      #evaluation-growth .swiper-slide {
        width: 320px; }
    #evaluation-growth .box {
      padding: 30px 20px; }
      #evaluation-growth .box h3 {
        font-size: 18px; }
      #evaluation-growth .box ul {
        padding-top: 15px; }
        #evaluation-growth .box ul li {
          width: 100%; }
      #evaluation-growth .box .txt {
        font-size: 14px;
        padding-top: 30px; } }
#works-roles {
  background: url("../img/index/works-bg.webp") no-repeat center/cover;
  padding: 150px 0; }
  #works-roles .box {
    padding-top: 64px; }
    #works-roles .box .item {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 20px;
      background-color: #2C2C29;
      position: relative;
      padding: 50px 85px 50px 50px; }
      #works-roles .box .item:not(:last-child) {
        margin-bottom: 10px; }
    #works-roles .box .no {
      color: #9B060C;
      font-weight: 600;
      font-size: 32px;
      letter-spacing: 0.06em;
      line-height: 1;
      position: absolute;
      top: 20px;
      right: 20px; }
    #works-roles .box h4 {
      font-weight: 700;
      font-size: 24px;
      letter-spacing: 0.08em;
      color: #fff; }
      #works-roles .box h4 span {
        display: block;
        font-weight: 700;
        font-style: italic;
        color: #585858; }
    #works-roles .box .txt {
      font-size: 18px;
      padding-top: 15px; }
    #works-roles .box figure {
      width: 312px;
      text-align: center; }
      #works-roles .box figure img {
        max-width: inherit;
        max-height: 191px; }

@media screen and (max-width: 1023px) {
  #works-roles .box .item {
    flex-direction: column;
    padding: 50px; }
  #works-roles .box .txt br.pc {
    display: none; }
  #works-roles .box h4 {
    text-align: center; }
  #works-roles .box figure {
    margin: 0 auto; } }
@media screen and (max-width: 767px) {
  #works-roles {
    padding: 80px 0; }
    #works-roles .box {
      padding-top: 30px; }
      #works-roles .box .item {
        padding: 40px 20px 20px; }
      #works-roles .box .no {
        top: 10px;
        right: 10px; }
      #works-roles .box h4 {
        font-size: 20px;
        margin: 0 -10px; }
        #works-roles .box h4 span {
          font-size: 16px; }
      #works-roles .box .txt {
        font-size: 14px; } }
#support-culture {
  padding: 150px 0; }
  #support-culture .box {
    background-color: #2C2C29;
    margin-top: 65px;
    padding: 50px 50px; }
    #support-culture .box figure {
      max-width: 467px;
      margin: 0 auto; }
    #support-culture .box .txt {
      font-size: 22px;
      padding-top: 20px; }

@media screen and (max-width: 767px) {
  #support-culture {
    padding: 80px 0; }
    #support-culture .box {
      margin-top: 40px;
      padding: 30px 20px; }
      #support-culture .box .txt {
        font-size: 16px; } }
#schedule {
  background-color: #000;
  padding: 150px 0; }
  #schedule .wrap {
    width: 86.5%;
    max-width: 1660px; }
  #schedule .tabs-switch {
    background-color: #252525;
    margin-top: 65px;
    padding: 50px 48px; }
  #schedule .tab-link {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 50px;
    font-weight: 700;
    font-size: 27px;
    color: #fff; }
    #schedule .tab-link li {
      display: flex;
      flex-direction: column;
      justify-content: center;
      background-color: #9B060C;
      height: 170px;
      padding: 0 35px;
      transition: all 0.3s;
      position: relative;
      line-height: 1.5; }
      #schedule .tab-link li:after {
        content: '';
        width: 15px;
        height: 9px;
        background: url("../img/index/arrow-down.webp") no-repeat center top/100% auto;
        position: absolute;
        top: 50%;
        right: 30px;
        transform: translateY(-50%) rotate(-90deg);
        transition: all 0.3s; }
      #schedule .tab-link li span {
        color: rgba(255, 255, 255, 0.5);
        font-weight: 700;
        font-style: italic;
        font-size: 17px;
        text-transform: uppercase; }
      #schedule .tab-link li small {
        font-weight: 500;
        font-size: 17px;
        color: #ccc;
        padding-top: 10px; }
      #schedule .tab-link li:hover, #schedule .tab-link li.active {
        background-color: #353535; }
        #schedule .tab-link li:hover span, #schedule .tab-link li.active span {
          color: #585858; }
        #schedule .tab-link li:hover:after, #schedule .tab-link li.active:after {
          transform: translateY(0) rotate(0); }
  #schedule .tab-content {
    text-align: center;
    padding-top: 136px; }

@media screen and (max-width: 1600px) {
  #schedule .tab-link {
    gap: 20px; }
    #schedule .tab-link li {
      padding: 0 40px 0 20px; }
      #schedule .tab-link li:after {
        right: 15px; } }
@media screen and (max-width: 1440px) {
  #schedule .wrap {
    width: 100%;
    max-width: 1140px; }
  #schedule .tab-link {
    font-size: 25px; }
  #schedule .tab-content {
    padding-top: 50px; } }
@media screen and (max-width: 767px) {
  #schedule .tabs-switch {
    margin-top: 30px;
    padding: 20px; }
  #schedule .tab-link {
    grid-template-columns: 1fr;
    gap: 10px;
    font-size: 20px; }
    #schedule .tab-link li {
      height: 100px; }
      #schedule .tab-link li span {
        font-size: 14px; }
      #schedule .tab-link li small {
        font-size: 14px;
        padding-top: 0; }
  #schedule .tab-content {
    padding-top: 20px; }
    #schedule .tab-content figure {
      width: 720px; }
  #schedule .scroll-hint-icon-wrap {
    display: block !important; } }
#voice {
  background: url("../img/index/voice-bg.webp") no-repeat center/cover;
  padding: 150px 0; }
  #voice .txt {
    font-size: 32px;
    letter-spacing: 0.06em;
    padding-top: 70px; }
  #voice .button {
    padding-top: 105px; }
    #voice .button a {
      width: 480px;
      height: 100px;
      font-size: 26px; }
      #voice .button a span {
        font-style: italic;
        border-bottom: 1px solid; }
      #voice .button a small {
        font-weight: 700;
        font-style: normal;
        font-size: 17px;
        margin-left: 25px; }

@media screen and (max-width: 767px) {
  #voice {
    padding: 80px 0; }
    #voice .txt {
      font-size: 18px;
      padding-top: 40px; }
    #voice .button {
      padding-top: 40px; }
      #voice .button a {
        width: 100%;
        height: 70px;
        font-size: 18px;
        padding: 0 20px; }
        #voice .button a small {
          font-size: 14px;
          margin-left: 10px; } }
#overview-faq {
  padding: 150px 0; }
  #overview-faq .txt-info {
    padding-top: 65px;
    font-size: 20px; }
    #overview-faq .txt-info dl {
      display: grid;
      grid-template-columns: 130px 1fr;
      border-bottom: 1px solid #5B5B5B;
      padding-bottom: 20px; }
      #overview-faq .txt-info dl + dl {
        padding-top: 20px; }
      #overview-faq .txt-info dl dt {
        color: #fff; }
  #overview-faq .box-1 {
    background-color: #1E1E1E;
    margin-top: 110px;
    padding: 50px 80px; }
    #overview-faq .box-1 h3 {
      display: inline-block;
      color: #fff;
      font-weight: 700;
      font-size: 24px;
      letter-spacing: 0.14em;
      border-bottom: 3px solid #9B060C; }
    #overview-faq .box-1 .list {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 60px;
      padding-top: 50px; }
      #overview-faq .box-1 .list .col {
        background-color: #353535;
        position: relative;
        padding: 12px 12px 30px;
        position: relative; }
        #overview-faq .box-1 .list .col:not(:last-child):after {
          content: '';
          width: 28px;
          height: 23px;
          background: url("../img/index/arrow-right.png") no-repeat center top/cover;
          position: absolute;
          top: 50%;
          left: 100%;
          transform: translateY(-50%);
          margin-left: 17px; }
      #overview-faq .box-1 .list .no {
        color: #454545;
        font-weight: 600;
        font-size: 32px;
        line-height: 1;
        letter-spacing: 0.06em;
        text-align: left; }
      #overview-faq .box-1 .list figure {
        width: 100%;
        height: 100px; }
        #overview-faq .box-1 .list figure img {
          max-height: 100%; }
      #overview-faq .box-1 .list h4 {
        font-weight: 700;
        font-size: 22px;
        line-height: 1.5;
        padding-top: 20px; }
        #overview-faq .box-1 .list h4 small {
          font-size: 16px; }
    #overview-faq .box-1 .txt {
      font-weight: 500;
      font-size: 18px;
      padding-top: 50px; }
  #overview-faq .box-qa {
    margin-top: 110px; }
    #overview-faq .box-qa .item:not(:last-child) {
      margin-bottom: 12px; }
    #overview-faq .box-qa .txt-q,
    #overview-faq .box-qa .txt-a {
      font-size: 20px;
      line-height: 32px;
      position: relative;
      padding: 31px 30px 31px 60px; }
      #overview-faq .box-qa .txt-q:before,
      #overview-faq .box-qa .txt-a:before {
        font-weight: 300;
        font-size: 22px;
        position: absolute;
        top: 30px;
        left: 30px; }
    #overview-faq .box-qa .txt-q {
      background-color: #000;
      color: #fff;
      cursor: pointer; }
      #overview-faq .box-qa .txt-q:before {
        content: 'Q.'; }
      #overview-faq .box-qa .txt-q .icon {
        width: 22px;
        height: 22px;
        position: absolute;
        top: 50%;
        right: 25px;
        transform: translateY(-50%); }
        #overview-faq .box-qa .txt-q .icon:before, #overview-faq .box-qa .txt-q .icon:after {
          content: '';
          position: absolute;
          top: 50%;
          left: 50%;
          transform: translate(-50%, -50%);
          transition: all 0.3s; }
        #overview-faq .box-qa .txt-q .icon:before {
          width: 100%;
          height: 0;
          border-top: 4px solid #9B060C; }
        #overview-faq .box-qa .txt-q .icon:after {
          width: 0;
          height: 100%;
          border-left: 4px solid #9B060C; }
    #overview-faq .box-qa .txt-a {
      display: none;
      font-weight: 500; }
      #overview-faq .box-qa .txt-a:before {
        content: 'A.'; }
    #overview-faq .box-qa .item.is-active .txt-q .icon:after {
      transform: translate(-50%, -50%) rotate(90deg); }

@media screen and (max-width: 1023px) {
  #overview-faq .box-1 {
    padding: 50px 40px; } }
@media screen and (max-width: 767px) {
  #overview-faq {
    padding: 80px 0; }
    #overview-faq .txt-info {
      font-size: 16px;
      padding-top: 20px; }
      #overview-faq .txt-info dl {
        grid-template-columns: 70px 1fr;
        padding-bottom: 10px; }
        #overview-faq .txt-info dl + dl {
          padding-top: 10px; }
    #overview-faq .box-1 {
      margin-top: 50px;
      padding: 20px; }
      #overview-faq .box-1 .list {
        display: flex;
        flex-direction: column; }
        #overview-faq .box-1 .list .col:not(:last-child):after {
          top: 100%;
          left: 50%;
          transform: translateX(-50%) rotate(90deg);
          margin-top: 20px;
          margin-left: 0; }
      #overview-faq .box-1 .txt {
        font-size: 14px;
        padding-top: 20px; }
    #overview-faq .box-qa {
      margin-top: 50px; }
      #overview-faq .box-qa .txt-q,
      #overview-faq .box-qa .txt-a {
        font-size: 16px;
        padding: 15px 40px 15px 40px; }
        #overview-faq .box-qa .txt-q:before,
        #overview-faq .box-qa .txt-a:before {
          top: 13px;
          left: 10px; }
        #overview-faq .box-qa .txt-q .icon,
        #overview-faq .box-qa .txt-a .icon {
          right: 10px; } }
#entry {
  width: 96%;
  max-width: 1586px;
  background: url("../img/index/entry-bg.webp") no-repeat center/cover;
  margin: 0 auto;
  padding: 140px 0 80px; }
  #entry h2 {
    font-weight: 700;
    font-size: 28px;
    letter-spacing: 0.12em;
    line-height: 2.5;
    text-align: center; }
    #entry h2 .sub {
      display: inline-block;
      font-weight: 700;
      font-style: italic;
      font-size: 111px;
      line-height: 1.4;
      text-transform: uppercase; }
  #entry .button {
    padding-top: 50px; }

@media screen and (max-width: 1023px) {
  #entry h2 {
    font-size: 24px; } }
@media screen and (max-width: 767px) {
  #entry {
    width: 100%;
    padding: 50px 0; }
    #entry h2 {
		line-height:1.9;
      font-size: 18px; }
      #entry h2 .sub {
        font-size: 50px;margin-bottom:10px; }
    #entry .button {
      padding-top: 30px; } }

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