@charset "UTF-8";
/*! Writen by SCSS */
sup {
  font-size: 0.5em; }

.swiper-button-next,
.swiper-button-prev {
  transition: opacity 0.3s ease-in-out;
  height: auto; }
  @media (hover: hover) {
    .swiper-button-next:hover,
    .swiper-button-prev:hover {
      opacity: 0.7; } }
  .swiper-button-next::after,
  .swiper-button-prev::after {
    content: none; }

.wide_image {
  width: 100%; }

.cap_l {
  padding-left: 1em;
  text-indent: -1em; }

.lead {
  font-size: clamp(24px, 2.9vw, 38px);
  letter-spacing: 0.1em;
  line-height: 1.4; }
  @media screen and (max-width: 480px) {
    .lead {
      font-size: 20px;
      letter-spacing: 0; } }

.lead_min {
  font-size: clamp(18px, 2.41vw, 30px);
  line-height: 1.6; }

.read {
  font-size: clamp(13px, 1.37vw, 18px); }

.sec02 {
  margin-top: clamp(30px, 5%, 60px);
  padding-top: clamp(30px, 5%, 60px);
  position: relative;
  z-index: 1; }
  .sec02 .content_inner_left {
    margin-bottom: clamp(35px, 6.67%, 80px); }
  .sec02 .location_bg_box {
    position: absolute;
    inset: 0;
    z-index: -1; }
    .sec02 .location_bg_box::before {
      content: "";
      display: block;
      top: 0;
      left: 0;
      right: 0;
      position: sticky;
      height: 100lvh;
      background: url("../images/lp/bg_location.jpg") center/cover no-repeat; }

.sec03 {
  padding-top: clamp(30px, 5%, 60px); }

.sec04 {
  padding-bottom: clamp(60px, 10%, 120px); }
  .sec04 .inner > .cap_l {
    margin-top: 20px; }

.sec06 {
  background: #000;
  color: #fff;
  padding-bottom: clamp(50px, 8.34%, 100px); }
  .sec06 .sec_lead .lead_head {
    color: #fff; }

.sec07 {
  padding-top: clamp(60px, 10%, 120px);
  padding-bottom: clamp(60px, 10%, 120px); }

.sec_main img {
  width: 100%; }

.sec_main {
  position: relative;
  aspect-ratio: 1600 / 940;
  overflow: hidden; }
  @media screen and (max-width: 480px) {
    .sec_main {
      aspect-ratio: 4 / 3; } }
  .sec_main .main_head_wrap {
    z-index: 2;
    position: absolute;
    inset: 0;
    text-align: center;
    margin-top: 5.94%;
    line-height: 1; }
    @media screen and (max-width: 480px) {
      .sec_main .main_head_wrap {
        margin-top: 10%; } }
    .sec_main .main_head_wrap .main_head, .sec_main .main_head_wrap .main_lead {
      transition-property: transform,opacity;
      transition-duration: 1.2s;
      transition-timing-function: ease-in-out;
      opacity: 0;
      transform: translateY(30px);
      color: #fff; }
      .loaded .sec_main .main_head_wrap .main_head,
      .loaded .sec_main .main_head_wrap .main_lead {
        opacity: 1;
        transform: translateY(0px); }
    .sec_main .main_head_wrap .main_head {
      font-size: 4.69vw;
      text-shadow: 0 0 30px #fff,0 0 30px #fff; }
      @media screen and (max-width: 480px) {
        .sec_main .main_head_wrap .main_head {
          font-size: 5.32vw; } }
    .sec_main .main_head_wrap .main_lead {
      font-size: 2.38vw;
      margin-top: 1em;
      text-shadow: 0 0 10px #fff,0 0 10px #fff;
      transition-delay: 0.2s; }
      @media screen and (max-width: 480px) {
        .sec_main .main_head_wrap .main_lead {
          font-size: 3.39vw; } }
  .sec_main .main_image_wrap {
    position: relative;
    width: 100%; }
    .sec_main .main_image_wrap img {
      width: 100%; }
    @media screen and (max-width: 480px) {
      .sec_main .main_image_wrap .main_bg img {
        aspect-ratio: 4 / 3;
        object-fit: cover;
        object-position: 25% top;
        display: block;
        height: 100%; } }
    .sec_main .main_image_wrap .main_image_box {
      position: absolute;
      bottom: 0;
      width: 52.5%;
      transition-property: clip-path;
      transition-duration: 0.8s;
      transition-timing-function: ease-in-out;
      padding-top: 0.63%; }
      @media screen and (max-width: 480px) {
        .sec_main .main_image_wrap .main_image_box {
          width: 65%; } }
      .sec_main .main_image_wrap .main_image_box .main_image_text {
        position: absolute;
        width: 59.53%;
        top: 0; }
        @media screen and (max-width: 480px) {
          .sec_main .main_image_wrap .main_image_box .main_image_text {
            width: 65%; } }
      .sec_main .main_image_wrap .main_image_box.main_image_box_left {
        left: 0;
        clip-path: inset(0 100% 0 0);
        transition-delay: 1s; }
        .loaded .sec_main .main_image_wrap .main_image_box.main_image_box_left {
          clip-path: inset(0); }
        .sec_main .main_image_wrap .main_image_box.main_image_box_left .main_image_text {
          left: 9.53%; }
          @media screen and (max-width: 480px) {
            .sec_main .main_image_wrap .main_image_box.main_image_box_left .main_image_text {
              left: 2%; } }
      .sec_main .main_image_wrap .main_image_box.main_image_box_right {
        right: 0;
        clip-path: inset(0 0 0 100%);
        transition-delay: 1.4s; }
        .loaded .sec_main .main_image_wrap .main_image_box.main_image_box_right {
          clip-path: inset(0); }
        .sec_main .main_image_wrap .main_image_box.main_image_box_right .main_image_text {
          right: 9.53%; }
          @media screen and (max-width: 480px) {
            .sec_main .main_image_wrap .main_image_box.main_image_box_right .main_image_text {
              right: 2%; } }
  .sec_main .main_outer_image {
    position: absolute;
    width: 40%;
    left: 0;
    right: 0;
    margin-inline: auto;
    bottom: 0;
    z-index: 2;
    transition-property: transform,opacity;
    transition-duration: 1.2s;
    transition-timing-function: ease-in-out;
    transition-delay: 2s;
    opacity: 0;
    transform: translateY(30px); }
    @media screen and (max-width: 480px) {
      .sec_main .main_outer_image {
        width: 40%; } }
    .loaded .sec_main .main_outer_image {
      opacity: 1;
      transform: translateY(0px); }
    .sec_main .main_outer_image .twincle {
      position: absolute;
      inset: 0;
      transition-delay: 2s; }
      .sec_main .main_outer_image .twincle li {
        position: absolute;
        inset: 0;
        animation-name: hikari;
        animation-timing-function: linear;
        animation-iteration-count: infinite; }
        .sec_main .main_outer_image .twincle li img {
          width: 100%; }
          @media screen and (max-width: 480px) {
            .sec_main .main_outer_image .twincle li img {
              height: 100%;
              object-fit: cover;
              object-position: right bottom; } }
        .sec_main .main_outer_image .twincle li.tw01 {
          animation-delay: -2.5s;
          animation-duration: 4.5s; }
        .sec_main .main_outer_image .twincle li.tw02 {
          animation-delay: -3s;
          animation-duration: 6.5s; }
        .sec_main .main_outer_image .twincle li.tw03 {
          animation-delay: -3.5s;
          animation-duration: 3s; }
        .sec_main .main_outer_image .twincle li.tw04 {
          animation-delay: -4s;
          animation-duration: 4.5s; }
        .sec_main .main_outer_image .twincle li.tw05 {
          animation-delay: -4.5s;
          animation-duration: 6.5s; }
        .sec_main .main_outer_image .twincle li.tw06 {
          animation-delay: -5s;
          animation-duration: 3s; }

@keyframes bgL_R {
  0% {
    transform-origin: left;
    transform: scaleX(0); }
  50% {
    transform-origin: left;
    transform: scaleX(1); }
  50.001% {
    transform-origin: right; }
  100% {
    transform-origin: right;
    transform: scaleX(0); } }
@keyframes hikari {
  0% {
    opacity: 0;
    transform: translateY(0%); }
  10% {
    opacity: 1; }
  85% {
    opacity: 1; }
  100% {
    opacity: 0;
    transform: translateY(-60%); } }
.sec_info {
  padding-top: clamp(25px, 3.34%, 40px);
  padding-bottom: clamp(25px, 3.34%, 40px); }
  .sec_info .inner {
    max-width: 1100px; }
  .sec_info .head_name {
    font-size: clamp(24px, 3.63vw, 40px);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1; }
    @media screen and (max-width: 480px) {
      .sec_info .head_name {
        flex-direction: column;
        gap: 0.4em; } }
    .sec_info .head_name .text_min {
      font-size: 0.7em; }
  .sec_info .info_wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    border-top: 1px solid;
    border-bottom: 1px solid;
    margin-top: 30px;
    margin-bottom: 30px;
    padding-top: 20px;
    padding-bottom: 20px;
    line-height: 1; }
    @media screen and (max-width: 480px) {
      .sec_info .info_wrap {
        margin-top: 20px;
        margin-bottom: 20px;
        padding-top: 15px;
        padding-bottom: 15px;
        flex-direction: column; } }
    .sec_info .info_wrap .info {
      font-size: clamp(30px, 4.54vw, 50px);
      padding-right: 0.8em;
      margin-right: 0.8em;
      border-right: 1px solid #333; }
      @media screen and (max-width: 768px) {
        .sec_info .info_wrap .info {
          margin-right: 0.5em;
          padding-right: 0.5em; } }
      @media screen and (max-width: 480px) {
        .sec_info .info_wrap .info {
          width: 100%;
          padding-right: 0;
          margin-right: 0;
          text-align: center;
          padding-bottom: 15px;
          margin-bottom: 15px;
          border-right: none;
          border-bottom: 1px solid #333; } }
    .sec_info .info_wrap .info_price_box {
      font-size: clamp(18px, 3.09vw, 34px);
      display: flex;
      align-items: flex-end;
      justify-content: center;
      gap: 0.4em; }
      @media screen and (max-width: 480px) {
        .sec_info .info_wrap .info_price_box {
          gap: 0.2em; } }
      .sec_info .info_wrap .info_price_box .size_box {
        display: flex;
        flex-direction: column; }
        .sec_info .info_wrap .info_price_box .size_box .term {
          font-size: 0.38em;
          margin-bottom: 1em; }
      .sec_info .info_wrap .info_price_box .price {
        display: flex;
        align-items: baseline; }
        .sec_info .info_wrap .info_price_box .price .text_lg {
          font-size: 2.47em; }
  .sec_info .info_button_wrap {
    max-width: 1070px;
    margin-left: auto;
    margin-right: auto; }
    @media screen and (max-width: 480px) {
      .sec_info .info_button_wrap {
        flex-direction: column;
        gap: 15px 0; } }
    .sec_info .info_button_wrap .info_button {
      max-width: 525px;
      width: 49.07%; }
      @media screen and (max-width: 480px) {
        .sec_info .info_button_wrap .info_button {
          width: 100%; } }

.sec_main_wrap {
  position: relative;
  overflow: hidden; }

.sec_lead .lead_head,
.bg_lead .lead_head {
  font-size: clamp(32px, 7.9vw, 100px);
  line-height: 1;
  margin-bottom: clamp(30px, 5%, 60px); }
  @media screen and (max-width: 480px) {
    .sec_lead .lead_head,
    .bg_lead .lead_head {
      margin-bottom: 10px; } }
.sec_lead .lead,
.bg_lead .lead {
  line-height: 1.8; }

.sec_lead {
  padding-top: clamp(60px, 10%, 120px);
  padding-bottom: clamp(60px, 10%, 120px); }
  @media screen and (max-width: 480px) {
    .sec_lead {
      padding-top: 30px;
      padding-bottom: 30px; } }
  .sec01 .sec_lead {
    padding-top: clamp(30px, 5%, 60px); }

.bg_lead .lead {
  line-height: 1.8; }

.bg_content {
  padding-top: clamp(35px, 6.67%, 80px);
  padding-bottom: clamp(35px, 6.67%, 80px); }
  .bg_content .bg_wrap {
    overflow: hidden;
    max-width: 1600px;
    width: 97.5%;
    margin-left: auto; }
    @media screen and (max-width: 480px) {
      .bg_content .bg_wrap {
        max-width: 480px;
        width: 100%;
        flex-direction: column;
        gap: 30px 0; } }
    .bg_content .bg_wrap .bg_main_image {
      align-self: flex-start;
      max-width: 445px;
      width: 28.53%; }
      @media screen and (max-width: 480px) {
        .bg_content .bg_wrap .bg_main_image {
          width: 100%;
          align-self: center; } }
      .bg_content .bg_wrap .bg_main_image .cap_l {
        margin-top: 5px; }
    .bg_content .bg_wrap .text_box {
      width: 70.52%;
      display: flex;
      flex-direction: column;
      overflow: hidden; }
      @media screen and (max-width: 480px) {
        .bg_content .bg_wrap .text_box {
          width: 100%; } }
      .bg_content .bg_wrap .text_box .bg_head {
        font-size: clamp(32px, 5.25vw, 84px);
        line-height: 1;
        width: fit-content; }
        @media screen and (max-width: 480px) {
          .bg_content .bg_wrap .text_box .bg_head {
            padding-left: 20px;
            padding-right: 20px; } }
        .bg_content .bg_wrap .text_box .bg_head .text_sub {
          display: inline-block;
          font-size: 0.26em;
          letter-spacing: 0.1em;
          color: rgba(51, 51, 51, 0.8); }
        .bg_content .bg_wrap .text_box .bg_head.location_02_head {
          position: relative; }
          .bg_content .bg_wrap .text_box .bg_head.location_02_head .text_sub {
            position: absolute;
            top: 2.27em;
            right: 0;
            letter-spacing: -0.05em; }
      .bg_content .bg_wrap .text_box .bg_lead {
        font-size: clamp(18px, 1.68vw, 28px);
        line-height: 1.4;
        margin-top: 1em;
        padding-bottom: 0.6em; }
        @media screen and (max-width: 480px) {
          .bg_content .bg_wrap .text_box .bg_lead {
            padding-left: 20px;
            padding-right: 20px; } }
      .bg_content .bg_wrap .text_box .read {
        padding-bottom: 1em;
        margin-bottom: auto; }
        @media screen and (max-width: 480px) {
          .bg_content .bg_wrap .text_box .read {
            padding-left: 20px;
            padding-right: 20px; } }
      .bg_content .bg_wrap .text_box .access_02_lead {
        margin-top: auto;
        font-size: clamp(14px, 1.25vw, 20px);
        line-height: 1;
        margin-bottom: 0.8em; }
        @media screen and (max-width: 480px) {
          .bg_content .bg_wrap .text_box .access_02_lead {
            padding-left: 20px;
            padding-right: 20px; } }
    .bg_content .bg_wrap .slide_outer {
      margin-top: 15px;
      position: relative;
      width: 100%; }
      .bg_content .bg_wrap .slide_outer .swiper {
        width: 100%;
        overflow: visible; }
      .bg_content .bg_wrap .slide_outer .swiper-button-next,
      .bg_content .bg_wrap .slide_outer .swiper-button-prev {
        top: 0;
        bottom: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 20px;
        line-height: 0; }
        .bg_content .bg_wrap .slide_outer .swiper-button-next img,
        .bg_content .bg_wrap .slide_outer .swiper-button-prev img {
          width: 100%; }
          @media screen and (max-width: 480px) {
            .bg_content .bg_wrap .slide_outer .swiper-button-next img,
            .bg_content .bg_wrap .slide_outer .swiper-button-prev img {
              width: 15px; } }
      .bg_content .bg_wrap .slide_outer .pagination_box {
        margin-top: 3.64%;
        display: flex;
        align-items: center;
        font-size: clamp(14px, 1.61vw, 20px); }
        .bg_content .bg_wrap .slide_outer .pagination_box::before {
          content: "";
          width: 5em;
          height: 1px;
          background: currentColor; }
        .bg_content .bg_wrap .slide_outer .pagination_box .swiper-pagination {
          margin-left: 1em;
          width: fit-content;
          flex-shrink: 0;
          position: static;
          line-height: 1; }

.access_bg_content {
  display: grid;
  gap: clamp(40px, 5.2vw, 80px) 0; }
  .access_bg_content .access_slide_01 .swiper-wrapper {
    align-items: flex-end; }
  .access_bg_content .access_slide_01 .swiper-slide {
    max-width: 294px;
    width: 26.73%;
    text-align: center; }
    @media screen and (max-width: 480px) {
      .access_bg_content .access_slide_01 .swiper-slide {
        max-width: none;
        width: 100%; } }
    .access_bg_content .access_slide_01 .swiper-slide .slide_text {
      font-size: clamp(16px, 1.62vw, 26px);
      line-height: 1;
      display: flex;
      align-items: flex-end;
      justify-content: center;
      margin-bottom: 0.92em;
      gap: 0.2em; }
      .access_bg_content .access_slide_01 .swiper-slide .slide_text .station {
        display: flex;
        flex-direction: column-reverse;
        align-items: flex-end; }
        .access_bg_content .access_slide_01 .swiper-slide .slide_text .station .direct {
          font-size: 0.92em; }
        .access_bg_content .access_slide_01 .swiper-slide .slide_text .station .name {
          display: flex;
          align-items: flex-end;
          justify-content: center; }
          .access_bg_content .access_slide_01 .swiper-slide .slide_text .station .name .text_min {
            font-size: 0.7em; }
      .access_bg_content .access_slide_01 .swiper-slide .slide_text .time {
        display: flex;
        align-items: flex-end;
        justify-content: center;
        gap: 0.2em; }
        .access_bg_content .access_slide_01 .swiper-slide .slide_text .time .direct {
          font-size: 0.92em; }
        .access_bg_content .access_slide_01 .swiper-slide .slide_text .time .number {
          color: #e2d046;
          font-size: 3.46em; }
          @media screen and (max-width: 480px) {
            .access_bg_content .access_slide_01 .swiper-slide .slide_text .time .number {
              font-size: 2.5em; } }
      .access_bg_content .access_slide_01 .swiper-slide .slide_text.slide_text_row {
        flex-direction: column;
        align-items: center; }
  .access_bg_content .access_slide_02 {
    font-size: clamp(18px, 1.62vw, 26px); }
    .access_bg_content .access_slide_02 .swiper-slide {
      width: 20.91%;
      text-align: center; }
      @media screen and (max-width: 480px) {
        .access_bg_content .access_slide_02 .swiper-slide {
          width: 100%; } }
      .access_bg_content .access_slide_02 .swiper-slide .text_box {
        width: 100%;
        text-align: center;
        line-height: 1;
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        margin-top: 0.76em; }
        .access_bg_content .access_slide_02 .swiper-slide .text_box .station {
          font-size: 1.07em;
          display: flex;
          align-items: baseline;
          justify-content: center; }
          .access_bg_content .access_slide_02 .swiper-slide .text_box .station .text_min {
            font-size: 0.75em; }
        .access_bg_content .access_slide_02 .swiper-slide .text_box .time {
          display: flex;
          align-items: baseline;
          justify-content: center; }
          .access_bg_content .access_slide_02 .swiper-slide .text_box .time .text_lg {
            font-size: 2em; }

.location_bg_content {
  display: grid;
  gap: clamp(40px, 5.2vw, 80px) 0; }
  .location_bg_content .bg_wrap .slide_outer {
    margin-top: auto; }
  .location_bg_content .swiper .swiper-slide {
    max-width: 290px;
    width: 26.37%; }
    @media screen and (max-width: 480px) {
      .location_bg_content .swiper .swiper-slide {
        max-width: none;
        width: 100%; } }
    .location_bg_content .swiper .swiper-slide .slide_image {
      position: relative;
      line-height: 0; }
      .location_bg_content .swiper .swiper-slide .slide_image .badge {
        position: absolute;
        z-index: 2;
        max-width: 90px;
        width: 31.04%;
        top: -12%;
        left: 0; }
    .location_bg_content .swiper .swiper-slide .slide_text {
      font-size: clamp(12px, 1vw, 16px);
      margin-top: 1em; }
  .location_bg_content .swiper.future_slide .swiper-slide {
    max-width: 420px;
    width: 38.19%; }
    @media screen and (max-width: 480px) {
      .location_bg_content .swiper.future_slide .swiper-slide {
        max-width: none;
        width: 100%; } }
    .location_bg_content .swiper.future_slide .swiper-slide .year_head {
      display: flex;
      align-items: center;
      color: #fff;
      font-size: clamp(20px, 2.5vw, 40px);
      line-height: 1;
      gap: 0 0.5em;
      margin-bottom: 0.37em; }
      .location_bg_content .swiper.future_slide .swiper-slide .year_head .text {
        flex-shrink: 0; }
      .location_bg_content .swiper.future_slide .swiper-slide .year_head::after {
        content: "";
        width: 100%;
        height: 1px; }
    .location_bg_content .swiper.future_slide .swiper-slide .slide_image {
      position: relative;
      line-height: 0; }
      .location_bg_content .swiper.future_slide .swiper-slide .slide_image .cap_r {
        position: absolute;
        top: calc(100% + 3px);
        right: 0;
        left: 0;
        line-height: 1.2; }
        @media screen and (max-width: 480px) {
          .location_bg_content .swiper.future_slide .swiper-slide .slide_image .cap_r {
            padding-right: 10px; } }
    .location_bg_content .swiper.future_slide .swiper-slide .slide_text_box {
      text-align: center;
      display: grid;
      margin-top: 25px;
      gap: 8px; }
      @media screen and (max-width: 480px) {
        .location_bg_content .swiper.future_slide .swiper-slide .slide_text_box {
          gap: 5px; } }
      .location_bg_content .swiper.future_slide .swiper-slide .slide_text_box .read {
        font-size: clamp(12px, 0.87vw, 14px);
        line-height: 1.4;
        padding-bottom: 0; }
      .location_bg_content .swiper.future_slide .swiper-slide .slide_text_box .future_text_min {
        font-size: clamp(14px, 1.25vw, 20px);
        line-height: 1.4; }
      .location_bg_content .swiper.future_slide .swiper-slide .slide_text_box .future_text {
        font-size: clamp(18px, 1.62vw, 26px);
        line-height: 1.4; }
  .location_bg_content .bg_wrap_col {
    max-width: 1480px;
    margin-inline: auto;
    flex-direction: column;
    gap: clamp(40px, 5vw, 60px) 0;
    overflow: visible; }
    @media screen and (max-width: 480px) {
      .location_bg_content .bg_wrap_col {
        gap: 25px 0; } }
    .location_bg_content .bg_wrap_col .bg_wrap_inner {
      width: calc(100% - 40px);
      margin-inline: auto;
      align-items: flex-start; }
      @media screen and (max-width: 480px) {
        .location_bg_content .bg_wrap_col .bg_wrap_inner {
          flex-direction: column;
          gap: 30px 0; } }
    .location_bg_content .bg_wrap_col .bg_wrap_box {
      width: 47.3%; }
      @media screen and (max-width: 480px) {
        .location_bg_content .bg_wrap_col .bg_wrap_box {
          width: 100%; } }
      .location_bg_content .bg_wrap_col .bg_wrap_box .box_head {
        font-size: clamp(18px, 1.68vw, 28px);
        line-height: 1.4;
        margin-bottom: 1em;
        display: flex;
        align-items: center;
        gap: 0.5em; }
        .location_bg_content .bg_wrap_col .bg_wrap_box .box_head .point {
          text-align: center;
          display: flex;
          align-items: center;
          justify-content: center;
          line-height: 1;
          font-size: 0.71em;
          width: 4em;
          height: 4em;
          color: #fff68a;
          border: 1px solid;
          border-radius: 50%; }
          @media screen and (max-width: 480px) {
            .location_bg_content .bg_wrap_col .bg_wrap_box .box_head .point {
              flex-shrink: 0; } }
      .location_bg_content .bg_wrap_col .bg_wrap_box .cap_l {
        margin-top: 5px; }
      .location_bg_content .bg_wrap_col .bg_wrap_box .image_wrap {
        position: relative;
        display: flex;
        align-items: flex-start; }
        .location_bg_content .bg_wrap_col .bg_wrap_box .image_wrap .image_box_badge {
          position: absolute;
          z-index: 1;
          width: 17.15%;
          top: -5%;
          left: -4.28%; }
        .location_bg_content .bg_wrap_col .bg_wrap_box .image_wrap .image_box {
          width: 50%; }

.data_outer {
  position: relative;
  padding-top: clamp(50px, 8.34%, 100px);
  padding-bottom: clamp(50px, 8.34%, 100px);
  background: #000;
  color: #fff; }
  @media screen and (max-width: 480px) {
    .data_outer {
      padding-top: 30px;
      padding-bottom: 30px; } }
  .data_outer::before {
    content: "";
    display: block;
    position: absolute;
    inset: 1.25vw;
    z-index: 2;
    pointer-events: none;
    border: 1px solid #fff; }
    @media screen and (max-width: 480px) {
      .data_outer::before {
        inset: 2px; } }
  .data_outer .bg_lead {
    margin-bottom: clamp(30px, 5%, 60px); }
    .data_outer .bg_lead .lead_head {
      color: #fff;
      margin-bottom: clamp(25px, 3.34%, 40px); }
  .data_outer .data_list_wrap {
    max-width: 780px;
    width: calc(100% - 40px);
    margin-left: auto;
    margin-right: auto; }
    @media screen and (max-width: 480px) {
      .data_outer .data_list_wrap {
        width: 80%; } }
    .data_outer .data_list_wrap .data_list {
      display: grid;
      align-items: start;
      align-content: start;
      grid-template-columns: repeat(2, 1fr);
      gap: clamp(25px, 7.7vw, 60px) 7.43%;
      text-align: center; }
      @media screen and (max-width: 480px) {
        .data_outer .data_list_wrap .data_list {
          grid-template-columns: 1fr;
          gap: 30px 0; } }
      .data_outer .data_list_wrap .data_list .item .item_head {
        color: #333;
        text-align: left;
        font-size: clamp(18px, 2.92vw, 24px);
        line-height: 1;
        margin-bottom: 0.6em;
        padding: 0.5em 0.8em;
        background: linear-gradient(90deg, #dedede 0%, #fafafa 20%, #dedede 45%, whitesmoke 55%, #b0b0b0 80%, #fafafa 100%); }
      .data_outer .data_list_wrap .data_list .item .cap_l {
        margin-top: 5px;
        padding-left: 1em;
        text-indent: -1em; }

.desig_main_wrap .sec_main_image {
  position: relative; }
  .desig_main_wrap .sec_main_image .slide_in {
    position: relative; }
    @media screen and (max-width: 480px) {
      .desig_main_wrap .sec_main_image .slide_in img {
        height: 100%;
        display: block;
        line-height: 0;
        object-fit: cover;
        object-position: center;
        aspect-ratio: 1200 / 1420; } }
  .desig_main_wrap .sec_main_image .sec_lead {
    padding: 0;
    position: absolute;
    z-index: 2;
    top: 4.62%;
    right: 4.07%; }
    @media screen and (max-width: 480px) {
      .desig_main_wrap .sec_main_image .sec_lead {
        position: static;
        text-align: center;
        margin-bottom: 25px; } }
    .desig_main_wrap .sec_main_image .sec_lead .lead_head {
      font-size: 10vw;
      color: rgba(255, 255, 255, 0.5);
      margin-bottom: 0; }

.design_wrap {
  overflow: hidden; }
  .design_wrap .cap_r {
    padding-right: 5px; }
  .design_wrap .text_box {
    padding-top: clamp(30px, 5%, 60px);
    padding-bottom: clamp(60px, 10%, 120px); }
    .design_wrap .text_box .lead {
      letter-spacing: 0;
      margin-bottom: clamp(25px, 3.34%, 40px);
      line-height: 1; }
    .design_wrap .text_box .lead_min {
      margin-bottom: clamp(25px, 3.34%, 40px); }
    .design_wrap .text_box .read {
      line-height: 3; }
      @media screen and (max-width: 1200px) {
        .design_wrap .text_box .read {
          line-height: 2; } }
      @media screen and (max-width: 768px) {
        .design_wrap .text_box .read {
          line-height: 1.8; } }

.plan_figure_wrap {
  max-width: 1020px;
  margin-left: auto;
  margin-right: auto; }
  .plan_figure_wrap .figure {
    margin-bottom: clamp(35px, 6.67%, 80px); }

.plan_main_wrap {
  align-items: flex-start;
  overflow: hidden; }
  .plan_main_wrap .plan_main_image .cap {
    text-align: left;
    line-height: 1;
    display: grid;
    gap: 0.4em;
    font-size: 12px; }
    @media screen and (max-width: 480px) {
      .plan_main_wrap .plan_main_image .cap {
        font-size: 10px; } }
    .plan_main_wrap .plan_main_image .cap .en {
      font-size: 2em; }
      @media screen and (max-width: 480px) {
        .plan_main_wrap .plan_main_image .cap .en {
          font-size: 1.4em; } }
  .plan_main_wrap .plan_main_image_left {
    width: 68.13%; }
  .plan_main_wrap .plan_main_image_right {
    width: 31.25%; }

.equipment_list {
  margin-top: clamp(30px, 5%, 60px);
  display: grid;
  align-items: start;
  align-content: start;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(20px, 3.34vw, 40px) 2.16%; }
  @media screen and (max-width: 480px) {
    .equipment_list {
      grid-template-columns: repeat(2, 1fr);
      gap: 20px 3%; } }
  .equipment_list .item .item_head {
    text-align: center;
    background: #003b6a;
    font-size: clamp(13px, 1.29vw, 16px);
    line-height: 1;
    text-align: center;
    margin-bottom: 15px;
    padding: 0.43em 0.2em; }
  .equipment_list .item .read {
    font-size: clamp(11px, 1.12vw, 14px);
    line-height: 1.6;
    margin-bottom: 15px; }
    @media screen and (max-width: 480px) {
      .equipment_list .item .read {
        margin-bottom: 10px; } }
    .equipment_list .item .read .text_min {
      display: inline-block;
      font-size: 0.8em; }
  .equipment_list .item.item03, .equipment_list .item.item04, .equipment_list .item.item05 {
    grid-column: span 2; }
  .equipment_list .item.item03 .item_image_wrap, .equipment_list .item.item04 .item_image_wrap {
    align-items: flex-start; }
    .equipment_list .item.item03 .item_image_wrap .read, .equipment_list .item.item04 .item_image_wrap .read {
      width: 47.71%; }
    .equipment_list .item.item03 .item_image_wrap .item_image, .equipment_list .item.item04 .item_image_wrap .item_image {
      max-width: 280px;
      width: 47.71%; }
      .equipment_list .item.item03 .item_image_wrap .item_image .item_point, .equipment_list .item.item04 .item_image_wrap .item_image .item_point {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        color: #fff;
        font-size: clamp(10px, 1.12vw, 14px);
        background: #9b9998;
        line-height: 1;
        padding: 0.4em;
        text-align: center; }
  .equipment_list .item.item05 .item05_read_wrap {
    align-items: flex-start;
    margin-bottom: 3.41%; }
    @media screen and (max-width: 480px) {
      .equipment_list .item.item05 .item05_read_wrap {
        margin-bottom: 15px; } }
    .equipment_list .item.item05 .item05_read_wrap .read {
      width: 76.67%; }
      @media screen and (max-width: 480px) {
        .equipment_list .item.item05 .item05_read_wrap .read {
          width: 65%; } }
    .equipment_list .item.item05 .item05_read_wrap .read_image {
      max-width: 120px;
      width: 20.45%; }
      @media screen and (max-width: 480px) {
        .equipment_list .item.item05 .item05_read_wrap .read_image {
          width: 33%; } }
  .equipment_list .item.item05 .item05_wrap {
    align-items: flex-start; }
    @media screen and (max-width: 480px) {
      .equipment_list .item.item05 .item05_wrap {
        flex-direction: column;
        gap: 15px;
        align-items: center; } }
    .equipment_list .item.item05 .item05_wrap .item_image {
      max-width: 320px;
      width: 54.52%; }
      @media screen and (max-width: 480px) {
        .equipment_list .item.item05 .item05_wrap .item_image {
          width: 100%; } }
    .equipment_list .item.item05 .item05_wrap .text_box {
      width: 40.89%;
      position: relative; }
      @media screen and (max-width: 480px) {
        .equipment_list .item.item05 .item05_wrap .text_box {
          width: 100%; }
          .equipment_list .item.item05 .item05_wrap .text_box .cap_l {
            position: absolute;
            left: 0;
            bottom: 0; } }
      .equipment_list .item.item05 .item05_wrap .text_box .bg_head {
        background: #003b6a;
        font-size: clamp(13px, 1.29vw, 16px);
        line-height: 1;
        text-align: center;
        padding: 0.5em;
        margin-bottom: 10px; }
      .equipment_list .item.item05 .item05_wrap .text_box .text_in {
        align-items: flex-start;
        margin-bottom: 10px; }
        @media screen and (max-width: 480px) {
          .equipment_list .item.item05 .item05_wrap .text_box .text_in {
            margin-bottom: 0; } }
        .equipment_list .item.item05 .item05_wrap .text_box .text_in .read {
          width: 41.67%; }
          @media screen and (max-width: 480px) {
            .equipment_list .item.item05 .item05_wrap .text_box .text_in .read {
              width: 65%; } }
        .equipment_list .item.item05 .item05_wrap .text_box .text_in .image_box {
          max-width: 120px;
          width: 50%; }
          @media screen and (max-width: 480px) {
            .equipment_list .item.item05 .item05_wrap .text_box .text_in .image_box {
              width: 33%; } }
  .equipment_list .item.item07 .item_image {
    margin-bottom: 15px; }
    @media screen and (max-width: 480px) {
      .equipment_list .item.item07 .item_image {
        margin-bottom: 10px; } }

.iot_outer {
  position: relative;
  z-index: 1;
  padding-top: clamp(50px, 8.34%, 100px);
  padding-bottom: clamp(50px, 8.34%, 100px);
  color: #fff; }
  @media screen and (max-width: 480px) {
    .iot_outer {
      margin-top: 50px;
      padding-top: 40px;
      padding-bottom: 40px; } }
  .iot_outer::after {
    content: "";
    display: block;
    position: absolute;
    inset: 2.82vw;
    z-index: 2;
    pointer-events: none;
    border: 1px solid #e8d97a; }
    @media screen and (max-width: 1200px) {
      .iot_outer::after {
        inset: 10px; } }
    @media screen and (max-width: 480px) {
      .iot_outer::after {
        inset: 5px; } }
  .iot_outer .iot_inner {
    max-width: 930px;
    z-index: 2; }
    .iot_outer .iot_inner .lead_head {
      color: #e8d97a; }
    .iot_outer .iot_inner .bg_lead .lead {
      letter-spacing: 0;
      margin-bottom: clamp(25px, 3.34%, 40px); }
      @media screen and (max-width: 480px) {
        .iot_outer .iot_inner .bg_lead .lead {
          font-size: 20px;
          line-height: 1.4; } }
    .iot_outer .iot_inner .bg_lead .read {
      text-align: left;
      margin-top: clamp(30px, 5%, 60px); }
      @media screen and (max-width: 480px) {
        .iot_outer .iot_inner .bg_lead .read {
          margin-top: 30px;
          line-height: 1.6; } }
  .iot_outer .iot_life {
    margin-top: clamp(35px, 5.84%, 70px); }
    .iot_outer .iot_life .life_head {
      font-size: clamp(24px, 2.82vw, 35px);
      text-align: center;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      margin-bottom: clamp(25px, 3.34%, 40px);
      line-height: 1; }
      .iot_outer .iot_life .life_head .text_min {
        font-size: 0.68em;
        border-bottom: 1px solid;
        padding-bottom: 0.8em;
        margin-bottom: 0.8em; }
    .iot_outer .iot_life .life_image {
      width: fit-content;
      margin-left: auto;
      margin-right: auto; }
  .iot_outer .iot_content {
    margin-top: clamp(35px, 5.84%, 70px); }
    .iot_outer .iot_content .iot_head {
      font-size: clamp(20px, 3.19vw, 32px);
      text-align: center;
      line-height: 1;
      background: #fff;
      color: #4a5356;
      padding: 0.4em 0.5em 0.2em; }
    .iot_outer .iot_content .lead {
      margin-top: clamp(25px, 3.34%, 40px);
      margin-bottom: clamp(25px, 3.34%, 40px);
      color: #fff; }
    .iot_outer .iot_content .iot_list {
      margin-bottom: clamp(25px, 3.34%, 40px);
      display: grid;
      align-items: start;
      align-content: start;
      grid-template-columns: repeat(2, 1fr);
      gap: clamp(20px, 3.23vw, 30px) 4.08%; }
      @media screen and (max-width: 480px) {
        .iot_outer .iot_content .iot_list {
          grid-template-columns: 1fr;
          gap: 20px 0; } }
      .iot_outer .iot_content .iot_list .text_box {
        margin-top: 20px;
        text-align: center; }
        @media screen and (max-width: 480px) {
          .iot_outer .iot_content .iot_list .text_box {
            margin-top: 15px; } }
        .iot_outer .iot_content .iot_list .text_box .item_head {
          font-size: clamp(18px, 2.57vw, 26px);
          line-height: 1.2;
          margin-bottom: 15px; }
          @media screen and (max-width: 480px) {
            .iot_outer .iot_content .iot_list .text_box .item_head {
              margin-bottom: 10px; } }
        .iot_outer .iot_content .iot_list .text_box .read {
          font-size: clamp(13px, 1.64vw, 16px);
          line-height: 1.6; }

.brand_wrap_01 {
  max-width: 1050px;
  margin-bottom: clamp(30px, 5%, 60px);
  margin-left: auto;
  margin-right: auto;
  align-items: center; }
  @media screen and (max-width: 480px) {
    .brand_wrap_01 {
      width: 90%;
      display: block; } }
  .brand_wrap_01 .text_box {
    max-width: 520px;
    width: 49.53%; }
    @media screen and (max-width: 480px) {
      .brand_wrap_01 .text_box {
        width: 100%;
        margin-bottom: 15px; } }
  .brand_wrap_01 .result {
    max-width: 468px;
    width: 44.58%; }
    @media screen and (max-width: 480px) {
      .brand_wrap_01 .result {
        width: 90%;
        margin-left: auto;
        margin-right: auto; } }

.brand_wrap_02 {
  max-width: 1080px;
  margin-bottom: clamp(50px, 8.34%, 100px);
  margin-left: auto;
  margin-right: auto;
  padding-top: clamp(25px, 3.34%, 40px);
  padding-bottom: clamp(25px, 3.34%, 40px);
  background: #fff; }
  @media screen and (max-width: 480px) {
    .brand_wrap_02 {
      display: block;
      padding-top: 15px;
      padding-bottom: 15px; } }
  .brand_wrap_02 .brand_wrap_02_inner {
    max-width: 960px;
    width: calc(100% - 40px);
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
    align-items: center;
    gap: 0 8.33%; }
    @media screen and (max-width: 480px) {
      .brand_wrap_02 .brand_wrap_02_inner {
        width: 90%;
        display: block; } }
    .brand_wrap_02 .brand_wrap_02_inner .brand_02_left {
      max-width: 359px;
      width: 37.4%; }
      @media screen and (max-width: 480px) {
        .brand_wrap_02 .brand_wrap_02_inner .brand_02_left {
          width: 77.38%;
          margin-left: auto;
          margin-right: auto;
          margin-bottom: 15px; } }
    .brand_wrap_02 .brand_wrap_02_inner .brand_02_right {
      max-width: 464px;
      width: 48.34%; }
      @media screen and (max-width: 480px) {
        .brand_wrap_02 .brand_wrap_02_inner .brand_02_right {
          width: 100%; } }

.brand_bg_wrap {
  margin-top: clamp(25px, 4.17%, 50px);
  padding-top: clamp(35px, 5.84%, 70px);
  padding-bottom: clamp(35px, 5.84%, 70px);
  background: #fff; }
  .brand_bg_wrap .brand_list {
    display: grid;
    align-items: start;
    align-content: start;
    grid-template-columns: repeat(3, 1fr);
    gap: 0 2.41%;
    margin-bottom: 25px; }
    @media screen and (max-width: 480px) {
      .brand_bg_wrap .brand_list {
        max-width: 380px;
        width: 80%;
        margin-left: auto;
        margin-right: auto;
        grid-template-columns: 1fr;
        gap: 15px 0;
        margin-bottom: 20px; } }
  .brand_bg_wrap .cap_l {
    color: #333; }

.text_dummy {
  color: #e60012; }

.sec07 .sec_lead {
  padding-top: 0;
  padding-bottom: clamp(40px, 7.5%, 90px); }
  @media screen and (max-width: 480px) {
    .sec07 .sec_lead {
      padding-bottom: 40px; } }

.outline_wrap {
  font-size: clamp(10px, 1.12vw, 15px);
  line-height: 1.4;
  align-items: flex-start; }
  @media screen and (max-width: 480px) {
    .outline_wrap {
      display: block; } }
  .outline_wrap .outline_head {
    font-size: 1.2em;
    line-height: 1;
    margin-bottom: 5px; }
  .outline_wrap .outline_list .item {
    display: flex;
    align-items: baseline; }
    .outline_wrap .outline_list .item dt {
      display: flex;
      align-items: baseline;
      width: 11em;
      flex-shrink: 0; }
      .outline_wrap .outline_list .item dt::before {
        content: "●";
        display: block; }
      .outline_wrap .outline_list .item dt::after {
        content: "／";
        display: block; }
      .outline_wrap .outline_list .item dt .term {
        width: 9em;
        text-align: justify;
        text-align-last: justify;
        text-justify: inter-character; }
  .outline_wrap .outline_left {
    width: 48%; }
    @media screen and (max-width: 480px) {
      .outline_wrap .outline_left {
        width: 100%;
        margin-bottom: 20px; } }
  .outline_wrap .outline_right {
    width: 48%; }
    @media screen and (max-width: 480px) {
      .outline_wrap .outline_right {
        width: 100%; } }
    .outline_wrap .outline_right .outline_box:not(:last-child) {
      margin-bottom: 8.69%; }
      @media screen and (max-width: 480px) {
        .outline_wrap .outline_right .outline_box:not(:last-child) {
          margin-bottom: 20px; } }

.price_box {
  max-width: 900px;
  margin-top: clamp(30px, 5%, 60px);
  margin-left: auto;
  margin-right: auto;
  font-size: clamp(12px, 1.91vw, 18px);
  line-height: 1;
  margin-bottom: 25px;
  border-top: 1px solid #fff;
  border-left: 1px solid #fff; }
  @media screen and (max-width: 768px) {
    .price_box {
      margin-bottom: 15px; } }
  @media screen and (max-width: 480px) {
    .price_box {
      width: 80%; } }
  .price_box .price_list {
    display: grid;
    grid-auto-flow: column;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(4, 1fr); }
    @media screen and (max-width: 480px) {
      .price_box .price_list {
        grid-auto-flow: dense;
        grid-template-columns: 1fr;
        grid-template-rows: auto; } }
    .price_box .price_list .item {
      padding: 0.75em 0.5em;
      border-right: 1px solid #fff;
      border-bottom: 1px solid #fff;
      display: flex;
      align-items: center; }
      .price_box .price_list .item.item_col {
        grid-column: span 2;
        text-align: center;
        justify-content: center; }
        @media screen and (max-width: 480px) {
          .price_box .price_list .item.item_col {
            justify-content: flex-start;
            text-align: left;
            grid-column: auto; } }

.indent {
  text-indent: -1em;
  padding-left: 1em; }

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