﻿@charset "utf-8";
/*--------------------------------------------------------------------------------
 
  main

--------------------------------------------------------------------------------*/
.top-main {
  position: relative;
  z-index: 1;
  background-color: var(--bg-color);
}

/*--------------------------------------------------------------------------------
 
  main visual

--------------------------------------------------------------------------------*/
.mv {
  width: 100%;
  height: clamp(180px, calc(920 / 1400 * 100vw), 1000px);
  padding-left: var(--side-space);
  padding-right: var(--side-space);
  transition: padding 1s var(--cubic-bezier);
}
.mv.is-scroll {
  padding-left: 0;
  padding-right: 0;
}
/*
.mv {
  width: 100%;
  padding-left: var(--side-space);
  padding-right: var(--side-space);
  transition: padding 1s var(--cubic-bezier);
  position: sticky;
  left: 0;
  top: 0;
}
.mv.is-scroll {
  padding-left: 0;
  padding-right: 0;
}
@media (min-width: 1000px) {
  .mv { height: clamp(640px, calc(800 / 1400 * 100vw), 800px); }
}
@media (max-width: 999px) {
  .mv { height: clamp(240px, calc(800 / 1000 * 100vw), 800px); }
  .mv { aspect-ratio: 1.25 / 1; max-height: 640px; }
}
*/

/*--------------------------------------------------------------------------------
  .mv-slider
--------------------------------------------------------------------------------*/
.mv-slider {
  width: 100%;
  height: 100%;
}
.mv-slider_item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/*--------------------------------------------------------------------------------
 
  event

--------------------------------------------------------------------------------*/
.event-sec {
  padding-top: var(--space-2l);
  padding-bottom: var(--space-3l);
  overflow: hidden;
}
.event { display: grid; }
.event_hd { grid-area: event_hd; }
.event_btn { grid-area: event_btn; }
.event_content { grid-area: event_content; padding-top: var(--space-m); }
@media (min-width: 1000px) {
  .event {
    grid-template-columns: auto 1fr;
    grid-template-areas: 
      "event_hd event_btn"
      "event_content event_content";
  }
  .event_btn {
    justify-self: end;
    align-self: end;
    padding-bottom: 1rem;
  }
}
@media (max-width: 999px) {
  .event {
    grid-template-areas: 
      "event_hd"
      "event_content"
      "event_btn";
  }
  .event_btn { justify-self: center; padding-top: var(--space-l); }
}

/*--------------------------------------------------------------------------------
  .event-list
--------------------------------------------------------------------------------*/
.event-slider {
  --archive-item-wrap: nowrap;
  width: calc(100% + (var(--archive-item-gap) * 2));
  overflow: visible;
  margin-left: calc(-1 * var(--archive-item-gap));
}
.event-slider:has(.swiper-scrollbar-horizontal) {
  padding-bottom: var(--space-m);
}
.event-slider .swiper-scrollbar {
  width: calc(100% - (var(--archive-item-gap) * 2));
  left: var(--event-item-gap);
}
.event-slider .swiper-slide {
  width: calc(100% / var(--archive-column));
}

/*--------------------------------------------------------------------------------
 
  concept

--------------------------------------------------------------------------------*/
@media (min-width: 1000px) { :root { --concept-content-mgt: calc(var(--space-2l) * 2); } }
@media (max-width: 999px) { :root { --concept-content-mgt: var(--space-3l); } }
.concept-sec {
  overflow: crip;
  position: relative;
}

/*--------------------------------------------------------------------------------
  .concept-hd
--------------------------------------------------------------------------------*/
.concept-hd {
  padding-top: calc(var(--space-l) * 2);
  padding-bottom: calc(var(--space-2l) + var(--concept-content-mgt));
  position: sticky;
  left: 0;
  top: 0;
}
.concept-hd_parallax {
  width: 100%;
  height: 100%;
  clip-path: inset(0);
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}
.concept-hd_parallax:before {
  content: "";
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100lvh;
  background: url("../../image/concept_bg.webp") no-repeat center center;
  background-size: cover;
}

/*--------------------------------------------------------------------------------
  .concept-content
--------------------------------------------------------------------------------*/
.concept-content {
  color: #FFF;
  position: relative;
  margin-top: calc(-1 * var(--concept-content-mgt));
}
.concept-content:before {
  content: "";
  width: 100%;
  height: calc(100% - var(--concept-content-mgt));
  background-color: var(--color-secondary);
  position: absolute;
  left: 0;
  bottom: 0;
}
.concept {
  display: grid;
  grid-template-columns: minmax(var(--side-space), 1fr) repeat(6, minmax(0, calc((var(--base-width) / 6) * 1px))) minmax(var(--side-space), 1fr);
  grid-template-rows: repeat(3, auto);
}
.concept:before {
  content: "";
  background-color: var(--color-secondary);
  position: relative;
  z-index: 1;
  grid-area: 1 / 1 / 3 / 8;
}
@media (min-width: 1000px) {
  .concept_img { grid-area: 1 / 1 / 4 / 4; padding-top: var(--space-2l); }
  .concept_lead { grid-area: 1 / 4 / 2 / 8; padding-top: var(--space-2l); padding-right: var(--space-l); }
  .concept_txt { grid-area: 2 / 4 / 3 / 8; padding-right: var(--space-m); width: min(100%, 720px); }
  .concept_btn { grid-area: 3 / 4 / 4 / 8; }
  .concept_lead,
  .concept_txt,
  .concept_btn { padding-left: var(--space-l); }
}
@media (max-width: 999px) {
  .concept_img { grid-area: 2 / 6 / 4 / 9; }
  .concept_lead { grid-area: 1 / 2 / 2 / 8; padding-top: var(--space-m); padding-right: var(--side-space); width: min(100%, 640px); }
  .concept_txt { grid-area: 2 / 2 / 3 / 7; }
  .concept_btn { grid-area: 3 / 2 / 4 / 7; }
  .concept_txt,
  .concept_btn { padding-right: 35%; }
}
@media (max-width: 640px) {
  .concept_img { grid-area: 2 / 2 / 3 / 8; justify-self: center; }
  .concept_lead { grid-area: 1 / 2 / 2 / 8; }
  .concept_txt { grid-area: 3 / 2 / 4 / 8; padding-top: var(--space-m); }
  .concept_btn { grid-area: 4 / 2 / 5 / 8; justify-self: center; }
  .concept_img img { max-width: 400px; }
  .concept_txt,
  .concept_btn { padding-right: 0; }
}
.concept_img {
  position: relative;
  z-index: 3;
}
.concept_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 25% top;
}
.concept_lead,
.concept_txt,
.concept_btn {
  position: relative;
  z-index: 4;
}
.concept_lead {
  font-size: clamp(var(--fs-m), 4.4vw, var(--fs-l));
  font-weight: bold;
  padding-bottom: var(--space-m);
}
.concept_txt { padding-bottom: var(--space-l); }
.concept_btn { padding-bottom: var(--space-m); }
.concept_btn .c-link-btn.-bg-white:hover { background-color: var(--color-secondary); }

/*--------------------------------------------------------------------------------
  .concept-loop
--------------------------------------------------------------------------------*/
.concept-loop {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding-bottom: var(--space-2l);
  margin-top: calc(-1 * var(--space-2l));
}
.concept-loop:before,
.concept-loop:after {
  content: "";
  flex-shrink: 0;
  width: clamp(640px, calc(2000 / 1400 * 100vw), 2000px);
  aspect-ratio: 10 / 1.33;
  background: url("../../image/concept-loop_logo.svg") no-repeat center center;
  background-size: auto 100%;
  opacity: 0.08;
  animation: concept-loop 25s infinite linear;
}
@keyframes concept-loop {
  from { transform: translateX(0); }
  to { transform: translateX(-100%); }
}
@media (max-width: 800px) {
  .concept-loop { padding-bottom: var(--space-l); }
}

/*--------------------------------------------------------------------------------
 
  feature

--------------------------------------------------------------------------------*/
.feature { display: grid; }
.feature_hd { grid-area: feature_hd; padding-top: var(--space-2l); }
.feature_btn { grid-area: feature_btn; }
.feature_content { grid-area: feature_content; }
@media (min-width: 1200px) {
  .feature {
    column-gap: var(--space-l);
    row-gap: var(--space-m);
    grid-template-columns: auto 1fr;
    grid-template-areas: 
      "feature_hd feature_content";
  }
  .feature_hd {
    align-self: start;
    position: sticky;
    top: 0;
    left: 0;
    padding-bottom: var(--space-m);
  }
  .feature_btn { display: none; }
  .feature_hd-btn { margin-top: var(--space-m); }
  .feature_content { padding-top: var(--space-2l); }
}
@media (max-width: 1199px) {
  .feature {
    grid-template-areas: 
      "feature_hd"
      "feature_content"
      "feature_btn";
  }
  .feature_content { padding-top: var(--space-m); }
}
@media (min-width: 1000px) and (max-width: 1199px) {
  .feature_hd {
    display: flex;
    align-items: flex-end;
  }
  .feature_hd-btn {
    align-self: flex-end;
    padding-bottom: 1rem;
    margin-left: auto;
  }
  .feature_btn { display: none; }
}
@media (max-width: 999px) {
  .feature_btn { justify-self: center; padding-top: var(--space-l);  }
  .feature_hd-btn { display: none; }
}

/*--------------------------------------------------------------------------------
  .feature-list
--------------------------------------------------------------------------------*/
.feature-list {
  counter-reset: number 0;
  display: flex;
  flex-direction: column;
  row-gap: var(--space-2s);
}
.feature-list_item {
  background-color: #FFF;
  padding: var(--box-space-l);
  display: grid;
  column-gap: calc(var(--box-space-l) + 1rem);
  row-gap: 1.5rem;
}
.feature-list_item .img {
  grid-area: feature-list_img;
  align-content: center;
}
.feature-list_item .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.feature-list_item .ttl {
  grid-area: feature-list_ttl;
  font-weight: bold;
  font-size: var(--fs-2l);
}
.feature-list_item .ttl:before {
  counter-increment: number 1;
  content: counter(number, decimal-leading-zero);
  display: block;
  color: rgba(var(--color-primary-rgb), 0.6);
  font-weight: 300;
  font-size: var(--fs-l-rem);
  padding-bottom: 0.5rem;
}
.feature-list_item .txt {
  grid-area: feature-list_txt;
  padding-bottom: 1rem;
}
@media (max-width: 999px) {
  .feature-list { margin: 0 calc(-1 * (var(--side-space) / 2)); }
}
@media (min-width: 641px) {
  .feature-list_item {
    grid-template-columns: 1fr minmax(200px, 40%);
    grid-template-rows: auto 1fr;
    grid-template-areas: 
      "feature-list_ttl feature-list_img"
      "feature-list_txt feature-list_img";
  }
  .feature-list_item .img { margin: -1rem; }
  .feature-list_item .img img { height: min(100%, 260px); }
}
@media (max-width: 640px) {
  .feature-list_item {
    grid-template-areas: 
      "feature-list_ttl"
      "feature-list_img"
      "feature-list_txt";
  }
}

/*--------------------------------------------------------------------------------
 
  gallery

--------------------------------------------------------------------------------*/
.gallery-sec {
  padding-top: calc(var(--space-3l) + var(--space-s));
  overflow: hidden;
}
.gallery { display: grid; }
.gallery_hd { grid-area: gallery_hd; }
.gallery_btn { grid-area: gallery_btn; }
.gallery_content { grid-area: gallery_content; padding-top: var(--space-m); }
@media (min-width: 1000px) {
  .gallery {
    grid-template-columns: auto 1fr;
    grid-template-areas: 
      "gallery_hd gallery_btn"
      "gallery_content gallery_content";
  }
  .gallery_btn {
    justify-self: end;
    align-self: end;
    padding-bottom: 1rem;
  }
}
@media (max-width: 999px) {
  .gallery {
    grid-template-areas: 
      "gallery_hd"
      "gallery_content"
      "gallery_btn";
  }
  .gallery_btn { justify-self: center; padding-top: var(--space-l); }
}

/*--------------------------------------------------------------------------------
  .gallery-list
--------------------------------------------------------------------------------*/
:root { --gallery-item-gap: 0.75rem; }
@media (min-width: 1200px) { :root { --gallery-list-column: 3; } }
@media (max-width: 1199px) { :root { --gallery-list-column: 2; } }
@media (max-width: 640px) { :root { --gallery-list-column: 1; } }
.gallery-slider {
  width: calc(100% + (var(--gallery-item-gap) * 2));
  overflow: visible;
  margin-left: calc(-1 * var(--gallery-item-gap));
}
.gallery-slider:has(.swiper-scrollbar-horizontal) {
  padding-bottom: var(--space-m);
}
.gallery-slider .swiper-scrollbar {
  width: calc(100% - (var(--gallery-item-gap) * 2));
  left: var(--gallery-item-gap);
}
.gallery-list {
  display: flex;
}
.gallery-list_item {
  width: calc(100% / var(--gallery-list-column));
  height: 100%;
  padding: 0 var(--gallery-item-gap);
}
.gallery-list_item .inner {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  background-color: #FFF;
}
.gallery-list_item .photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 3 / 2;
}
.gallery-list_item .txt {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  padding: var(--box-space);
}
.gallery-list_item .txt_ttl {
  flex-grow: 1;
  font-weight: bold;
  font-size: var(--fs-m);
  line-height: 1.6;
}
.gallery-list_item .inner:hover .txt_ttl { text-decoration: none; }
.gallery-list_item .txt_tag { font-size: var(--fs-2s); padding-top: 2rem; }

/*--------------------------------------------------------------------------------
 
  ainavi

--------------------------------------------------------------------------------*/
@media (min-width: 1000px) { :root { --ainavi-min-width: 1000px; --ainavi-logo-size: 90%; --ainavi-logo-size-max: 360px; } }
@media (max-width: 999px) { :root { --ainavi-min-width: 400px; --ainavi-logo-size: 70%; --ainavi-logo-size-max: 320px; } }
.ainavi-sec {
  padding-top: var(--space-2l);
}
.ainavi {
  width: min(100%, calc(var(--base-width) * 1px));
  min-width: var(--ainavi-min-width);
  margin: 0 auto;
  background-color: #41BE82;
  background-size: cover;
  color: #FFF;
  display: grid;
  grid-template-columns: 1fr minmax(320px, 1fr);
  column-gap: var(--box-space-l);
  padding: var(--box-space-l);
}
.ainavi_logo img { width: min(var(--ainavi-logo-size), var(--ainavi-logo-size-max)); }
.ainavi_txt { padding-top: 1.5rem; font-size: 0.95rem; }
.ainavi_btn {
  background-color: #FFF;
  padding: 1rem;
  display: flex;
  flex-wrap: wrap;
  column-gap: 1.5rem;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-m);
  font-weight: bold;
  position: relative;
}
.ainavi_btn,
.ainavi_btn:hover { color: var(--txt-color); text-decoration: none; }
.ainavi_btn .txt {
  width: fit-content;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  column-gap: 0.75rem;
  line-height: 1.4;
  padding-right: 3.5rem;
  position: relative;
}
.ainavi_btn .txt1 {
  font-weight: 800;
  color: #19BC66;
  font-size: var(--fs-2l);
  text-align: left;
}
.ainavi_btn .txt2 .c-arrow {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
@media (min-width: 1000px) {
  .ainavi-sec {
    padding-left: var(--side-space);
    padding-right: var(--side-space);
  }
  .ainavi_txt { padding-top: 1.5rem; }
  .ainavi_btn .qr img { width: 90px; }
}
@media (max-width: 999px) {
  .ainavi-sec {
    padding-left: calc(var(--side-space) / 2);
    padding-right: calc(var(--side-space) / 2);
  }
  .ainavi {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }
  .ainavi_txt { padding: var(--space-s) 0; }
  .ainavi_btn { align-self: center; width: max(70%, calc(var(--ainavi-min-width) - (var(--box-space-l) * 2))); }
  .ainavi_btn .qr img { width: clamp(50px, calc(70 / 800 * 100vw), 70px); }
}
@media (max-width: 640px) {
  .ainavi-sec {
    padding-left: 0;
    padding-right: 0;
  }
}

/*--------------------------------------------------------------------------------
 
  pickup

--------------------------------------------------------------------------------*/
.pickup-sec {
  padding-top: calc(var(--space-3l) + var(--space-s));
  overflow: hidden;
}
.pickup { display: grid; }
.pickup_hd { grid-area: pickup_hd; }
.pickup_btn { grid-area: pickup_btn; }
.pickup_content { grid-area: pickup_content; padding-top: var(--space-m); }
.pickup_msg { grid-area: pickup_msg; padding-top: var(--space-m); }

@media (min-width: 1000px) {
  .pickup {
    grid-template-columns: auto 1fr;
    grid-template-areas: 
      "pickup_hd pickup_btn"
      "pickup_content pickup_content"
      "pickup_msg pickup_msg";
  }
  .pickup_btn {
    justify-self: end;
    align-self: end;
    padding-bottom: 1rem;
  }
}
@media (max-width: 999px) {
  .pickup {
    grid-template-areas: 
      "pickup_hd"
      "pickup_content"
      "pickup_btn"
      "pickup_msg";
  }
  .pickup_btn { justify-self: center; padding-top: var(--space-l); }
}

.pickup_msg {
  width: auto;
  max-width: 780px;
  padding: var(--box-space-l);
  margin-top: var(--box-space-l);
  background-color: #41BE82;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.pickup_msg .pickup_msgintro {
  margin-bottom: 1em;
  color: #fff;
  font-size: var(--fs-m);
  text-align: center;
}
.pickup_msg .pickup_msgintro span {
  display: inline-block;
}
.pickup_msg .pickup_btn {
  background-color: #FFF;
  padding: 1rem;
  display: flex;
  flex-wrap: wrap;
  column-gap: 1.5rem;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-m);
  font-weight: bold;
  position: relative;
}
.pickup_msg .pickup_btn,
.pickup_msg .pickup_btn:hover { color: var(--txt-color); text-decoration: none; }
.pickup_msg .pickup_btn .txt {
  width: fit-content;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  column-gap: 0.75rem;
  line-height: 1.4;
  padding-right: 3.5rem;
  position: relative;
}
.pickup_msg .pickup_btn .c-arrow {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}

/*--------------------------------------------------------------------------------
  .pickup-list
--------------------------------------------------------------------------------*/
:root { --pickup-item-gap: 0.75rem; }
@media (min-width: 1200px) { :root { --pickup-list-column: 3; } }
@media (max-width: 1199px) { :root { --pickup-list-column: 2; } }
@media (max-width: 640px) { :root { --pickup-list-column: 1; } }
.pickup-slider {
  width: calc(100% + (var(--pickup-item-gap) * 2));
  overflow: visible;
  margin-left: calc(-1 * var(--pickup-item-gap));
}
.pickup-slider:has(.swiper-scrollbar-horizontal) {
  padding-bottom: var(--space-m);
}
.pickup-slider .swiper-scrollbar {
  width: calc(100% - (var(--pickup-item-gap) * 2));
  left: var(--pickup-item-gap);
}
.pickup-list {
  display: flex;
}
.pickup-list_item {
  width: calc(100% / var(--pickup-list-column));
  height: 100%;
  padding: 0 var(--pickup-item-gap);
}
.pickup-list_item .inner {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  background-color: #FFF;
}
.pickup-list_item .photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 3 / 2;
}
.pickup-list_item .txt {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  padding: var(--box-space);
}
.pickup-list_item .txt_ttl {
  flex-grow: 1;
  font-weight: bold;
  font-size: var(--fs-m);
  line-height: 1.6;
}
.pickup-list_item .inner:hover .txt_ttl { text-decoration: none; }
.pickup-list_item .txt_tag { font-size: var(--fs-2s); padding-top: 2rem; }

/*--------------------------------------------------------------------------------
 
  company

--------------------------------------------------------------------------------*/
.company-sec {
  padding-top: var(--space-2l);
  padding-bottom: var(--space-3l);
}
.company { display: grid; }
.company_hd { grid-area: company_hd; }
.company_btn { grid-area: company_btn; }
.company_content { grid-area: company_content; }
@media (min-width: 1000px) {
  .company {
    column-gap: var(--space-l);
    row-gap: var(--space-m);
    grid-template-columns: minmax(25%, auto) minmax(auto, 920px);
    grid-template-rows: auto 1fr;
    grid-template-areas: 
      "company_hd company_content"
      "company_btn company_content";
  }
  .company_content { padding: 2rem 0; }
}
@media (max-width: 999px) {
  .company {
    grid-template-areas: 
      "company_hd"
      "company_content"
      "company_btn";
  }
  .company_content {
    padding-top: var(--space-2s);
  }
  .company_btn { justify-self: center; padding-top: var(--space-l); }
}

/*--------------------------------------------------------------------------------
 
  parallax

--------------------------------------------------------------------------------*/
.parallax {
  height: clamp(240px, 50vh, 640px);
  height: clamp(240px, 50dvh, 640px);
  clip-path: inset(0);
}
.parallax:before {
  content: "";
  position: fixed;
  left: 0;
  top: 0;
  z-index: -999;
  width: 100%;
  height: 100lvh;
  background: url("../../image/parallax.webp") no-repeat center center;
  background-size: cover;
}
