/*! Writen  by SCSS */
body .wrap {
  padding-top: 0 !important; }

header {
  background: none;
  transition: all 0.3s ease-in-out 0s; }
  body.scrolled header {
    background: rgba(0, 0, 0, 0.7); }
  header div.header {
    background: none; }

.main_bg {
  background: #000;
  position: relative;
  z-index: 50; }
  @media screen and (max-width: 480px) {
    .main_bg.bg_fix_end2 .main_img {
      position: absolute;
      top: auto;
      bottom: 0; } }

.main_wrap {
  position: relative;
  z-index: 60; }
  @media screen and (max-width: 480px) {
    .main_wrap {
      position: static;
      height: calc(100svh - 50px);
      background: none; } }
  @media screen and (max-width: 480px) {
    .main_wrap .main_img {
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      height: calc(100svh - 50px); }
      .main_wrap .main_img figure {
        height: 100%; }
      .main_wrap .main_img img {
        width: 100;
        height: 100%;
        object-fit: cover;
        object-position: bottom center; } }
  .main_wrap .main {
    position: absolute;
    height: auto;
    inset: 0;
    padding: 50px; }
    @media screen and (max-width: 480px) {
      .main_wrap .main {
        height: calc(100svh - 50px);
        padding: 20px;
        position: relative;
        z-index: 10; } }

.bread {
  position: relative; }
  .bread .breadlist {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 80;
    color: #fff; }

.sec_ttl_en {
  font-size: clamp(20px, calc(64vw / 16), 64px); }
  @media screen and (max-width: 480px) {
    .sec_ttl_en {
      font-size: calc(30vw / 3.9); } }
  .sec_ttl_en.l1 {
    font-size: clamp(20px, calc(68vw / 16), 68px); }
    @media screen and (max-width: 480px) {
      .sec_ttl_en.l1 {
        font-size: calc(36vw / 3.9); } }
  .sec_ttl_en.s2 {
    font-size: clamp(20px, calc(44vw / 16), 44px); }
    @media screen and (max-width: 480px) {
      .sec_ttl_en.s2 {
        font-size: calc(26vw / 3.9); } }

.sec_main {
  font-size: clamp(16px, calc(24vw / 16), 24px); }
  @media screen and (max-width: 480px) {
    .sec_main {
      font-size: calc(18vw / 3.9); } }

.sec_read {
  font-size: clamp(12px, calc(18vw / 16), 18px); }
  @media screen and (max-width: 480px) {
    .sec_read {
      font-size: calc(13vw / 3.9); } }

.sec_text {
  font-size: clamp(12px, calc(16vw / 16), 16px); }
  @media screen and (max-width: 480px) {
    .sec_text {
      font-size: calc(12vw / 3.9); } }

.sec01 {
  position: relative;
  z-index: 50; }
  @media screen and (max-width: 480px) {
    .sec01 {
      z-index: 70; } }
  .sec01 .bg {
    z-index: -1;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100lvh; }
    .sec01 .bg img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: top center; }
      @media screen and (max-width: 768px) {
        .sec01 .bg img {
          object-position: bottom center; } }
    @media screen and (max-width: 768px) {
      .sec01 .bg {
        position: fixed; } }
    @media screen and (max-width: 480px) {
      .sec01 .bg {
        display: none; } }
    .sec01 .bg .cap1 {
      opacity: 0.4; }
  .sec01.bg_fix .bg {
    position: fixed; }
  .sec01.bg_fix_end .bg {
    position: absolute;
    top: auto;
    bottom: 0; }
  .sec01 .inn {
    min-height: 100lvh;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 120px 0;
    color: #fff; }
    @media screen and (max-width: 480px) {
      .sec01 .inn {
        padding: 50px 0; } }
  @media screen and (max-width: 480px) {
    .sec01 .sec_ttl_en {
      margin-bottom: 1em; } }
  @media screen and (max-width: 480px) {
    .sec01 .sec_main {
      margin-bottom: 2em; } }
  .sec01 .sec_read {
    line-height: 3.2; }

.sec02 {
  position: relative;
  z-index: 40;
  background: #061e42; }
  .sec02 .bg {
    position: absolute;
    top: 0;
    left: 0;
    width: calc(720% / 16);
    height: 100vh;
    overflow: hidden; }
    @media screen and (max-width: 768px) {
      .sec02 .bg {
        position: relative;
        background: none;
        width: 100%;
        height: auto; } }
    .sec02 .bg figure {
      width: 100%;
      height: 100%;
      filter: brightness(300%) blur(30px);
      transition: all 0.6s linear; }
      .sec02 .bg figure img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: top center; }
  .sec02.p-view2 .bg figure {
    filter: brightness(100%) blur(0); }
  .sec02.bg_fix .bg {
    position: fixed; }
    @media screen and (max-width: 768px) {
      .sec02.bg_fix .bg {
        position: relative; } }
  .sec02.bg_fix_end .bg {
    position: absolute;
    top: auto;
    bottom: 0; }
    @media screen and (max-width: 768px) {
      .sec02.bg_fix_end .bg {
        position: relative; } }
  .sec02 .inn {
    width: calc(880% / 16);
    min-height: 100vh;
    background: url("../images/bg2.jpg") left center/cover;
    padding: 90px calc(40% / 16) 90px calc(70% / 16);
    margin-left: auto;
    color: #fff; }
    @media screen and (max-width: 768px) {
      .sec02 .inn {
        width: 100%;
        padding: 40px 20px 50px;
        text-align: center; } }
    .sec02 .inn .box {
      max-width: 770px; }
    .sec02 .inn .sec_ttl_en.ex1 {
      font-size: clamp(20px, calc(60vw / 16), 60px);
      margin-bottom: 0.6em;
      display: flex;
      gap: 0.5em; }
      @media screen and (max-width: 768px) {
        .sec02 .inn .sec_ttl_en.ex1 {
          justify-content: center;
          align-items: center; }
          .sec02 .inn .sec_ttl_en.ex1::before {
            content: "";
            flex: 1;
            height: 1px;
            background: #fff; }
          .sec02 .inn .sec_ttl_en.ex1::after {
            content: "";
            flex: 1;
            height: 1px;
            background: #fff; } }
      .sec02 .inn .sec_ttl_en.ex1 span.line {
        display: block;
        flex: 1;
        position: relative; }
        @media screen and (max-width: 768px) {
          .sec02 .inn .sec_ttl_en.ex1 span.line {
            display: none; } }
        .sec02 .inn .sec_ttl_en.ex1 span.line::after {
          content: "";
          position: absolute;
          top: 60%;
          left: 0;
          height: 1px;
          width: 50vw;
          background: #fff; }
      @media screen and (max-width: 480px) {
        .sec02 .inn .sec_ttl_en.ex1 {
          font-size: calc(28vw / 3.9); } }
    .sec02 .inn .box21 {
      position: relative; }
      .sec02 .inn .box21 .img {
        position: absolute;
        top: -3%;
        right: 0;
        width: calc(320% / 7.7);
        display: flex;
        justify-content: space-between;
        align-items: flex-end; }
        @media screen and (max-width: 1200px) {
          .sec02 .inn .box21 .img {
            position: static;
            margin-top: 30px;
            width: 100%;
            max-width: 320px; } }
        @media screen and (max-width: 768px) {
          .sec02 .inn .box21 .img {
            margin-inline: auto; } }
        .sec02 .inn .box21 .img .l {
          width: calc(140% / 3.2); }
        .sec02 .inn .box21 .img .r {
          width: calc(160% / 3.2); }
          @media screen and (max-width: 480px) {
            .sec02 .inn .box21 .img .r .cap {
              font-size: 8px; } }
          .sec02 .inn .box21 .img .r p {
            font-size: clamp(10px, calc(14vw / 16), 13px);
            line-height: 1.2;
            text-align: left; }
            @media screen and (max-width: 480px) {
              .sec02 .inn .box21 .img .r p {
                font-size: calc(11vw / 3.9); } }
            .sec02 .inn .box21 .img .r p .l1 {
              font-size: 128%; }
            .sec02 .inn .box21 .img .r p .l2 {
              font-size: 140%; }

.sec03_main {
  position: relative;
  z-index: 31; }
  .sec03_main .copy {
    position: absolute;
    inset: 0;
    padding: 50px;
    display: flex;
    justify-content: flex-start;
    align-items: flex-end; }
    @media screen and (max-width: 480px) {
      .sec03_main .copy {
        padding: 20px;
        pointer-events: none;
        justify-content: center; } }
  @media screen and (max-width: 480px) {
    .sec03_main .swipe1 {
      width: 720px; }
      .sec03_main .swipe1 img {
        width: 100%; } }

.sec03 {
  position: relative;
  z-index: 30; }
  .sec03 .bg {
    z-index: -1;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: url("../images/bg3.jpg") center center/cover; }
  .sec03.bg_fix .bg {
    position: fixed; }
  .sec03.bg_fix_end .bg {
    position: absolute;
    top: auto;
    bottom: 0; }
  .sec03 .inn {
    padding: 80px 0;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff; }
    @media screen and (max-width: 768px) {
      .sec03 .inn {
        padding: 60px 0 50px; } }
    @media screen and (max-width: 480px) {
      .sec03 .inn {
        padding: 60px 0 50px;
        min-height: inherit; } }
    .sec03 .inn .img301 {
      position: relative;
      max-width: 1000px;
      margin-inline: auto; }
      @media screen and (max-width: 480px) {
        .sec03 .inn .img301 {
          width: calc(100% + 40px);
          margin-inline: -20px; } }
      .sec03 .inn .img301 .copy {
        position: absolute;
        inset: 0;
        padding: 40px;
        display: flex;
        justify-content: center;
        align-items: flex-end; }
        @media screen and (max-width: 480px) {
          .sec03 .inn .img301 .copy {
            padding: 20px; } }

.sec04 {
  position: relative;
  z-index: 20;
  background: #000;
  color: #fff;
  padding: 90px 0; }
  @media screen and (max-width: 768px) {
    .sec04 {
      padding: 50px 0; } }
  .sec04 .inner {
    max-width: 1120px; }
  .sec04 .img4 {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    row-gap: 20px; }
    .sec04 .img4 li {
      width: calc(250% / 11.2); }
      @media screen and (max-width: 480px) {
        .sec04 .img4 li {
          width: 48%; } }
      .sec04 .img4 li p {
        font-size: clamp(12px, calc(16vw / 12), 16px);
        line-height: 1;
        letter-spacing: 0.05;
        font-weight: 600;
        margin-top: 0.4em;
        text-align: center; }
        @media screen and (max-width: 480px) {
          .sec04 .img4 li p {
            font-size: calc(12vw / 3.9); } }
  .sec04 .cap_r {
    margin-top: 30px; }
    @media screen and (max-width: 480px) {
      .sec04 .cap_r {
        margin-top: 20px; } }

.sec05 {
  position: relative;
  z-index: 10;
  background: url("../images/bg5.jpg") right center/cover; }
  .sec05 .bg {
    position: absolute;
    left: auto;
    top: 0;
    right: 0;
    width: calc(760% / 16);
    height: 100vh;
    padding-top: 120px; }
    @media screen and (max-width: 768px) {
      .sec05 .bg {
        padding-top: 40px;
        position: relative;
        background: none;
        width: 100%;
        max-width: 580px;
        height: auto;
        margin-inline: auto; } }
    @media screen and (max-width: 480px) {
      .sec05 .bg {
        width: 100%; } }
    .sec05 .bg figure {
      max-width: 100%;
      height: 100%;
      display: inline-block;
      margin-right: auto;
      filter: brightness(300%) blur(30px);
      transition: all 0.6s linear; }
      @media screen and (max-width: 768px) {
        .sec05 .bg figure {
          width: 100%;
          height: auto; } }
      .sec05 .bg figure img {
        width: 100%;
        max-width: none;
        height: 100%;
        object-fit: contain;
        object-position: bottom center; }
        @media screen and (max-width: 768px) {
          .sec05 .bg figure img {
            width: 100%;
            max-width: 100%;
            height: auto; } }
  .sec05.p-view2 .bg figure {
    filter: brightness(100%) blur(0); }
  .sec05.bg_fix .bg {
    position: fixed; }
    @media screen and (max-width: 768px) {
      .sec05.bg_fix .bg {
        position: relative; } }
  .sec05.bg_fix_end .bg {
    position: absolute;
    top: auto;
    bottom: 0; }
    @media screen and (max-width: 768px) {
      .sec05.bg_fix_end .bg {
        position: relative; } }
  .sec05 .inn {
    width: calc(840% / 16);
    min-height: 100vh;
    padding: 90px calc(80% / 16) 90px calc(80% / 16);
    margin-right: auto;
    color: #fff; }
    @media screen and (max-width: 768px) {
      .sec05 .inn {
        width: 100%;
        padding: 50px 20px;
        text-align: center; } }
    .sec05 .inn .box {
      max-width: 680px;
      margin-left: auto; }
      @media screen and (max-width: 768px) {
        .sec05 .inn .box {
          margin-inline: auto; } }
      .sec05 .inn .box .sec_main + .sec_main {
        margin-bottom: 0.4em; }
      .sec05 .inn .box .box52 {
        display: flex;
        justify-content: space-between; }
        .sec05 .inn .box .box52 .txt {
          width: calc(450% / 6.8); }
          @media screen and (max-width: 768px) {
            .sec05 .inn .box .box52 .txt {
              width: 100%; } }
        .sec05 .inn .box .box52 .img {
          width: calc(192% / 6.8); }
      .sec05 .inn .box .img5 {
        display: flex;
        flex-wrap: wrap;
        gap: 30px calc(25% / 6.8); }
        @media screen and (max-width: 480px) {
          .sec05 .inn .box .img5 {
            gap: 30px 4%; } }
        .sec05 .inn .box .img5 li {
          width: calc(210% / 6.8); }
          @media screen and (max-width: 480px) {
            .sec05 .inn .box .img5 li {
              width: 48%; }
              .sec05 .inn .box .img5 li.sp_f {
                width: 100%;
                display: flex;
                justify-content: space-between; }
                .sec05 .inn .box .img5 li.sp_f .img {
                  width: 48%; }
                .sec05 .inn .box .img5 li.sp_f .txt_box {
                  width: 48%; }
                  .sec05 .inn .box .img5 li.sp_f .txt_box .ttl {
                    text-align: left;
                    padding-top: 0; } }
          .sec05 .inn .box .img5 li .ttl {
            font-size: clamp(12px, calc(16vw / 16), 16px);
            line-height: 1.4;
            letter-spacing: 0.05;
            font-weight: 600;
            padding: 0.7em 0;
            text-align: center; }
            @media screen and (max-width: 480px) {
              .sec05 .inn .box .img5 li .ttl {
                font-size: calc(12vw / 3.9); } }
            .sec05 .inn .box .img5 li .ttl sup {
              font-size: 50%; }
          .sec05 .inn .box .img5 li .txt {
            font-size: clamp(12px, calc(16vw / 16), 16px);
            line-height: 1.7;
            letter-spacing: 0.05;
            font-weight: 600;
            text-align: left; }
            @media screen and (max-width: 480px) {
              .sec05 .inn .box .img5 li .txt {
                font-size: calc(12vw / 3.9); } }
      .sec05 .inn .box.colm {
        background: #eeefef;
        color: #221815;
        padding: 20px 40px; }
        @media screen and (max-width: 480px) {
          .sec05 .inn .box.colm {
            padding: 15px; } }
        .sec05 .inn .box.colm .t1 {
          font-size: clamp(18px, calc(31vw / 16), 31px);
          line-height: 1;
          letter-spacing: 0.3em;
          margin-bottom: 0.6em; }
          @media screen and (max-width: 480px) {
            .sec05 .inn .box.colm .t1 {
              font-size: calc(18vw / 3.9); } }
        .sec05 .inn .box.colm .t2 {
          font-size: clamp(16px, calc(20vw / 16), 20px);
          line-height: 1;
          letter-spacing: 0.05em;
          margin-bottom: 0.6em;
          font-weight: 600;
          color: rgba(51, 51, 51, 0.9); }
          @media screen and (max-width: 480px) {
            .sec05 .inn .box.colm .t2 {
              font-size: calc(16vw / 3.9); } }
        .sec05 .inn .box.colm .t3 {
          text-align: center;
          font-size: clamp(11px, calc(15vw / 16), 15px);
          line-height: 1.5;
          font-weight: 600;
          color: rgba(51, 51, 51, 0.9); }
          @media screen and (max-width: 480px) {
            .sec05 .inn .box.colm .t3 {
              font-size: calc(12vw / 3.9); } }
        .sec05 .inn .box.colm .box53 {
          display: flex;
          justify-content: space-between; }
          @media screen and (max-width: 480px) {
            .sec05 .inn .box.colm .box53 {
              display: block; } }
          .sec05 .inn .box.colm .box53 .logo {
            width: calc(180% / 6); }
            @media screen and (max-width: 480px) {
              .sec05 .inn .box.colm .box53 .logo {
                width: 45%;
                margin: 0 auto 15px; } }
          .sec05 .inn .box.colm .box53 ul {
            width: calc(390% / 6);
            display: flex;
            justify-content: space-between; }
            @media screen and (max-width: 480px) {
              .sec05 .inn .box.colm .box53 ul {
                width: 100%; } }
            .sec05 .inn .box.colm .box53 ul li {
              width: calc(184% / 3.9); }

.bnr_wrap {
  padding-top: 80px; }
  @media screen and (max-width: 480px) {
    .bnr_wrap {
      padding-top: 40px; } }
  @media screen and (max-width: 480px) {
    .bnr_wrap .bels {
      width: 70%;
      margin-inline: auto; } }

.banner_list {
  font-size: 0;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 7px; }
  @media screen and (max-width: 768px) {
    .banner_list {
      flex-wrap: wrap;
      gap: 7px 2%; } }
  @media screen and (max-width: 480px) {
    .banner_list {
      justify-content: space-between;
      gap: 5px; } }
  .banner_list li {
    box-sizing: border-box;
    display: inline-block; }
    @media screen and (max-width: 768px) {
      .banner_list li {
        width: 32%; } }
    @media screen and (max-width: 480px) {
      .banner_list li {
        width: 48%; } }

.cap.opa {
  color: #cccccc; }

/*# sourceMappingURL=style.css.map */
