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

  wrapper

--------------------------------------------------------------------------------*/
.l-wrapper {
  position: relative;
  min-height: 100%;
}

/*--------------------------------------------------------------------------------

  header

--------------------------------------------------------------------------------*/
header {
  width: 100%;
  position: sticky;
  left: 0;
  top: 0;
  z-index: 900;
}
header .scroll-hide { transition: opacity 0.2s ease-in-out; }
header.is-scroll .scroll-hide { opacity: 0; }
.l-hd { grid-area: hd; }
.l-hd-logo { grid-area: hd-logo; }
.l-hd-sns { grid-area: hd-sns; }
.l-hd-nav { grid-area: hd-nav; }
.l-hd-btn { grid-area: hd-btn; }
.l-gnav-btn { grid-area: gnav-btn; }
.l-hd {
  width: 100%;
  position: relative;
  padding: max(1.5rem, calc(var(--side-space) - 1.25rem));
  transition: padding 1s var(--cubic-bezier);
  display: grid;
  align-items: center;
  grid-template-columns: auto 1fr auto auto;
  grid-template-areas: 
    "hd-logo hd-sns hd-btn gnav-btn";
}
header.is-scroll .l-hd { padding: 1.5rem; }
@media (min-width: 641px) {
  .l-hd:before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    transition: background 0.2s ease-in-out, padding 0.4s var(--cubic-bezier);
    z-index: -1;
  }
  header.is-scroll .l-hd:before {
    background-color: rgba(255,255,255,0.6);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
  }
}
@media (max-width: 640px) {
  header { margin-bottom: calc(var(--side-space) / 2); }
}

/*--------------------------------------------------------------------------------
  .l-hd-logo
--------------------------------------------------------------------------------*/
@media (min-width: 1000px) { :root { --hd-logo-min: 140; --hd-logo-max: 180; --hd-logo-break-point: 1200; } }
@media (max-width: 999px) { :root { --hd-logo-min: 140; --hd-logo-max: 160; --hd-logo-break-point: 1000; } }
@media (max-width: 640px) { :root { --hd-logo-min: 120; --hd-logo-max: 140; --hd-logo-break-point: 480; } }
.l-hd-logo img {
  width: clamp((var(--hd-logo-min) * 1px), (var(--hd-logo-max) / var(--hd-logo-break-point) * 100vw), (var(--hd-logo-max) * 1px));
}
@media (max-width: 640px) {
  header .l-hd-logo { transition: opacity 0.2s ease-in-out; }
  header.is-scroll .l-hd-logo { opacity: 0; }
}

/*--------------------------------------------------------------------------------
  .l-hd-sns
--------------------------------------------------------------------------------*/
.l-hd-sns {
  justify-self: end;
  display: flex;
  align-items: center;
  column-gap: 2rem;
  padding-right: 2rem;
}
.l-hd-sns a {
  font-size: var(--fs-2s);
  display: flex;
  align-items: center;
  column-gap: 0.5rem;
}
.l-hd-sns a,
.l-hd-sns a:hover { text-decoration: none; }
@media (max-width: 999px) {
  .l-hd-sns { display: none !important; }
}

/*--------------------------------------------------------------------------------
  .l-hd-btn
--------------------------------------------------------------------------------*/
.l-hd-btn {
  justify-self: end;
  display: flex;
  align-items: center;
  column-gap: 1rem;
  padding-right: 1.5rem;
}
.l-hd-btn .btn {
  font-size: var(--fs-s);
  padding: 0.65rem clamp(1.5rem, 3.6vw, 3rem);
}
@media (max-width: 640px) {
  .l-hd-btn { display: none !important; }
}

/*--------------------------------------------------------------------------------
  .l-hd-nav
--------------------------------------------------------------------------------*/
.l-hd-nav {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: -0.5rem;
  padding-bottom: calc(var(--side-space) - 1.5rem);
  padding-left: var(--side-space);
  padding-right: var(--side-space);
}
.l-hd-nav a,
.l-hd-nav a:hover { text-decoration: none; }
.l-hd-nav a {
  display: block;
  padding: 0.5rem clamp(1rem, 2.4vw, 2rem);
}
.l-hd-nav li:first-of-type a { padding-left: 0; }
.l-hd-nav li:last-of-type a { padding-right: 0; }
@media (max-width: 999px) {
  .l-hd-nav { display: none; }
}

/*--------------------------------------------------------------------------------

  global navigation

--------------------------------------------------------------------------------*/
.l-gnav {
  display: none;
  pointer-events: none;
  width: 100%;
  min-width: 300px;
  height: 100dvh;
  overflow-x: hidden;
  overflow-y: auto;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 900;
}

/* open
----------------------------------------*/
html.is-gnav-open { overflow: hidden; }
.l-gnav.is-open,
.l-gnav.is-close { display: grid; pointer-events: auto; }

/* background
----------------------------------------*/
.l-gnav:before {
  content: "";
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  right: 0;
  z-index: -1;
  background-color: rgba(var(--color-secondary-rgb), 0.4);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  opacity: 0;
}
.l-gnav.is-open:before { animation: 0.4s gnav-open-bg forwards; }
.l-gnav.is-close:before { animation: 0.2s gnav-close-bg forwards; }
:root { --gnav-close-duration: 400; }
@keyframes gnav-open-bg { from { opacity: 0; } to { opacity: 1; } }
@keyframes gnav-close-bg { from { opacity: 1; } to { opacity: 0; } }

/*--------------------------------------------------------------------------------
  .l-gnav-content
--------------------------------------------------------------------------------*/
.l-gnav-content {
  opacity: 0;
  height: 100%;
  display: grid;
  position: relative;
  padding: calc(var(--space-2l) + 1rem) var(--side-space) var(--space-l) var(--side-space);
  color: #FFF;
}
.l-gnav-content a,
.l-gnav-content a:hover { color: #FFF; text-decoration: none; }
.l-gnav-content a:hover { opacity: 0.6; }
@media (min-width: 1000px) {
  .l-gnav-content { width: max(640px, 50%); margin-left: auto; }
}
@media (max-width: 999px) {
  .l-gnav-content { width: 100%; }
}

/* .l-gnav_inner
----------------------------------------*/
.l-gnav_inner {
  width: min(100%, 640px);
  margin: 0 auto;
  display: grid;
  grid-template-column: 1fr;
  grid-template-rows: 1fr auto;
  row-gap: var(--space-l);
  opacity: 0;
}
@media (max-width: 640px) {
  .l-gnav_inner {
    width: 100%;
    grid-auto-flow: row;
  }
}

/* open
----------------------------------------*/
.l-gnav.is-open .l-gnav-content { animation: 0.6s gnav-open-content forwards; }
.l-gnav.is-open .l-gnav_inner { animation: 0.8s gnav-open-content forwards; animation-delay: 0.4s; }
.l-gnav.is-close .l-gnav-content,
.l-gnav.is-close .l-gnav_inner { animation: 0.4s gnav-close-content forwards; }
@keyframes gnav-open-content { from { opacity: 0; } to { opacity: 1; } }
@keyframes gnav-close-content { from { opacity: 1; } to { opacity: 0; } }

/* background
----------------------------------------*/
.l-gnav-content:before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
  background-color: var(--color-tertiary);
}
.l-gnav.is-open .l-gnav-content:before { animation: 0.8s gnav-open-content-bg var(--cubic-bezier) forwards; }
@media (min-width: 1000px) {
  @keyframes gnav-open-content-bg { from { transform: translateX(100%); } to { transform: translateX(0); } }
}
@media (max-width: 999px) {
  @keyframes gnav-open-content-bg { from { transform: translateY(100%); } to { transform: translateY(0); } }
}

/*--------------------------------------------------------------------------------
  .l-gnav-list
--------------------------------------------------------------------------------*/
.l-gnav-list {
  align-self: start;
  font-size: var(--fs-m);
  font-weight: bold;
  display: grid;
  grid-gap: 0.5rem var(--space-3l);
  opacity: 0;
}
.l-gnav-list a {
  display: block;
  padding: 0.5rem 0;
}
.l-gnav-list .c-icon { margin: 0 0.5rem 0.15rem 0.5rem; }
@media (min-width: 641px) {
  .l-gnav-list {
    grid-template-columns: repeat(2, auto);
  }
}

/* open
----------------------------------------*/
.l-gnav.is-open .l-gnav-list { animation: 0.8s gnav-open-menu var(--cubic-bezier) forwards; animation-delay: 0.4s; }
@media (min-width: 1000px) {
  @keyframes gnav-open-menu { from { opacity: 0; transform: translateX(2em); } to { opacity: 1; transform: translateX(0); } }
}
@media (max-width: 999px) {
  @keyframes gnav-open-menu { from { opacity: 0; transform: translateY(1em); } to { opacity: 1; transform: translateY(0); } }
}

/*--------------------------------------------------------------------------------
  .l-gnav-btm
--------------------------------------------------------------------------------*/
.l-gnav-btm {
  border-top: 1px solid rgba(255,255,255,0.2);
  padding-top: var(--space-s);
  align-self: end;
}

/* .l-gnav-btm_link
----------------------------------------*/
.l-gnav-btm_link {
  font-size: var(--fs-s);
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.5rem;
}

/* .l-gnav-btm_sns
----------------------------------------*/
.l-gnav-btm_sns {
  padding-top: var(--space-s);
  font-size: var(--fs-s);
  display: flex;
  flex-direction: column;
  row-gap: 0.75rem;
}
.l-gnav-btm_sns a {
  display: flex;
  align-items: center;
  column-gap: 0.5rem;
}

/*--------------------------------------------------------------------------------
  .l-gnav-btn
--------------------------------------------------------------------------------*/
:root {
  --gnav-btn-bg-color: #FFF;
  --gnav-btn-bg-hover-color: var(--color-tertiary);
  --gnav-btn-outline-color: #FFF;
  --gnav-btn-outline-hover-color: var(--color-tertiary);
  --gnav-btn-line-color: var(--color-secondary);
  --gnav-btn-line-hover-color: #FFF;
  --gnav-btn-close-bg-color: rgba(255,255,255,0.2);
  --gnav-btn-close-outline-color: transparent;
  --gnav-btn-close-line-color: #FFF;
  --gnav-btn-line-height: 2px;
}
@media (min-width: 1000px) { :root { --gnav-btn-icon-width: 22px; --gnav-btn-icon-height: 8px; } }
@media (max-width: 999px) { :root { --gnav-btn-icon-width: 18px; --gnav-btn-icon-height: 8px; } }
@media (max-width: 640px) { :root { --gnav-btn-icon-width: 16px; --gnav-btn-icon-height: 6px; } }
.l-gnav-btn {
  position: relative;
  z-index: 1000;
  pointer-events: auto;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  border: 1px solid var(--gnav-btn-outline-color);
  background-color: var(--gnav-btn-bg-color);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  transition: var(--hover-trans);
}
.l-gnav-btn.is-close { background-color: var(--gnav-btn-close-bg-color); border-color: var(--gnav-btn-close-outline-color); }
.l-gnav-btn_icon {
  position: relative;
  width: var(--gnav-btn-icon-width);
  height: var(--gnav-btn-icon-height);
  transition: all 0.1s ease-out;
}
.l-gnav-btn_line {
  position: absolute;
  right: 0;
  height: var(--gnav-btn-line-height);
  transition: all 0.2s ease-out;
  background-color: var(--gnav-btn-line-color);
}
.l-gnav-btn.is-close .l-gnav-btn_line { background-color: var(--gnav-btn-close-line-color); }
.l-gnav-btn_line:nth-of-type(1) { width: 100%; top: 0; }
.l-gnav-btn_line:nth-of-type(3) { width: 100%; top: 100%; }
.l-gnav-btn.is-close .l-gnav-btn_line:nth-of-type(1) {
  width: 100%;
  top: 0;
  transform: translateY(calc((var(--gnav-btn-icon-height) / 2))) rotate(-45deg);
}
.l-gnav-btn.is-close .l-gnav-btn_line:nth-of-type(3) {
  width: 100%;
  bottom: 0;
  transform: translateY(calc(-1 * (var(--gnav-btn-icon-height) / 2))) rotate(45deg);
}
@media (hover: hover) {
  .l-gnav-btn:not(.is-close):hover { background-color: var(--gnav-btn-bg-hover-color); border-color: var(--gnav-btn-outline-hover-color); }
  .l-gnav-btn:not(.is-close):hover .l-gnav-btn_line { background-color: var(--gnav-btn-line-hover-color); }
}

/*--------------------------------------------------------------------------------

  footer

--------------------------------------------------------------------------------*/
footer {
  background-color: var(--color-tertiary);
  color: #FFF;
  position: sticky;
  top: 100dvh;
}
footer a,
footer a:hover { color: #FFF; text-decoration: none; }
footer a:not(.l-ft_logo):hover { opacity: 0.6; text-decoration: none; }
@media (min-width: 641px) {
  footer { padding-bottom: 0 !important; }
}

/*--------------------------------------------------------------------------------
  .l-ft
--------------------------------------------------------------------------------*/
.l-ft {
  padding: var(--space-2l) var(--side-space);
  display: flex;
}
@media (min-width: 1201px) {
  .l-ft {
    justify-content: space-between;
    column-gap: var(--space-2l);
  }
}
@media (max-width: 1200px) {
  .l-ft {
    flex-direction: column;
    row-gap: var(--space-l);
  }
}

/* .l-ft_logo
----------------------------------------*/
@media (min-width: 1000px) { :root { --ft-logo-min: 180; --ft-logo-max: 200; --ft-logo-break-point: 1200; } }
@media (max-width: 999px) { :root { --ft-logo-min: 160; --ft-logo-max: 160; --ft-logo-break-point: 1000; } }
@media (max-width: 640px) { :root { --ft-logo-min: 120; --ft-logo-max: 140; --ft-logo-break-point: 480; } }
.l-ft_logo img {
  width: clamp((var(--ft-logo-min) * 1px), (var(--ft-logo-max) / var(--ft-logo-break-point) * 100vw), (var(--ft-logo-max) * 1px));
}

/* .l-ft_nav
----------------------------------------*/
.l-ft_nav {
  flex: 1;
  max-width: 1000px;
  display: grid;
  grid-template-columns: repeat(2, auto);
  gap: 1rem 3rem;
}
.l-ft_nav .c-icon { margin: 0 0.5rem 0.15rem 0.5rem; }
@media (min-width: 1201px) {
  .l-ft_nav {
    padding-top: 1rem;
    grid-template-columns: repeat(3, auto);
  }
}
@media (max-width: 640px) {
  .l-ft_nav { grid-template-columns: 1fr; }
}

/*--------------------------------------------------------------------------------
  .l-ft-btm
--------------------------------------------------------------------------------*/
.l-ft-btm {
  margin: 0 var(--side-space);
  border-top: 1px solid rgba(255,255,255,0.2);
  padding: var(--space-s) 0 var(--space-m) 0;
  display: grid;
  gap: var(--space-s);
}
@media (min-width: 1000px) {
  .l-ft-btm {
    grid-template-columns: 1fr auto;
    grid-template-areas: 
      "ft-link ft-copyright"
      "ft-sns ft-copyright";
  }
  .l-ft-btm_link { grid-area: ft-link; }
  .l-ft-btm_sns { grid-area: ft-sns; }
  .l-ft-btm_copyright { grid-area: ft-copyright; align-self: end; }
}
@media (max-width: 999px) {
  .l-ft-btm_copyright { padding-top: var(--space-2s); }
}

/* .l-ft-btm_link
----------------------------------------*/
.l-ft-btm_link {
  font-size: var(--fs-2s);
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.5rem;
}
@media (min-width: 1000px) {
  .l-ft-btm_link { flex: 1; }
}

/* .l-ft-btm_sns
----------------------------------------*/
.l-ft-btm_sns {
  font-size: var(--fs-s);
  display: flex;
  gap: 0.75rem 2rem;
}
.l-ft-btm a {
  display: flex;
  align-items: center;
  column-gap: 0.5rem;
}
@media (max-width: 1000px) {
  .l-ft-btm_sns { flex-direction: column; }
}

/* .l-ft-btm_copyright
----------------------------------------*/
.l-ft-btm_copyright { font-size: var(--fs-3s); }

/*--------------------------------------------------------------------------------
  .l-sp-fixbtn
--------------------------------------------------------------------------------*/
@media (min-width: 641px) {
  .l-sp-fixbtn { display: none; }
}
:root { --sp_ft_fixbtn_breakpoint: 800px; }
@media (max-width: 640px) {
  .l-sp-fixbtn {
    width: 100%;
    min-width: 300px;
    position: fixed;
    left: 0;
    bottom: 0;
    z-index: 800;
    display: flex;
  }
  .l-sp-fixbtn li,
  .l-sp-fixbtn .btn {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }
  .l-sp-fixbtn .btn {
    text-align: center;
    align-items: center;
    line-height: 1.6;
    padding: 1.25rem 1.5rem;
  }
  .l-sp-fixbtn .btn:hover { text-decoration: none; }
  .l-sp-fixbtn .btn { background-color: var(--btn-bg); color: var(--btn-txt); }
  .l-sp-fixbtn .btn.-primary { background-color: var(--btn-primary-bg); color: var(--btn-primary-txt); }
}
@media (hover: hover) {
  .l-sp-fixbtn .btn { transition: var(--hover-trans); }
  .l-sp-fixbtn .btn:hover { background-color: var(--btn-bg-hover); color: var(--btn-txt-hover); }
  .l-sp-fixbtn .btn.-primary:hover { background-color: var(--btn-primary-bg-hover); color: var(--btn-primary-txt-hover); }
}

/*--------------------------------------------------------------------------------

  page visual

--------------------------------------------------------------------------------*/
.l-pv {
  padding: 0 var(--side-space);
}
.l-pv-ttl {
  padding: var(--space-s) 0 var(--space-l) 0;
  border-bottom: 1px solid var(--border-color);
  line-height: 1.6;
}
.l-pv-ttl_main {
  font-family: var(--ff-go);
  font-weight: 700;
  font-size: clamp(var(--fs-3l), 8vw, var(--fs-4l));
  line-height: 1.4;
  padding-top: 1.25rem;
}
.l-pv-ttl_sub {
  font-weight: 400;
  line-height: 1;
  position: relative;
  padding-left: 1.25rem;
}
.l-pv-ttl_sub:before {
  content: "";
  width: 0.5rem;
  height: 0.5rem;
  position: absolute;
  left: 0;
  top: 0.35rem;
  border-radius: 50%;
  background-color: var(--color-primary);
}

/*--------------------------------------------------------------------------------

  main

--------------------------------------------------------------------------------*/
.l-main {
  padding-top: var(--space-m);
  padding-bottom: var(--space-3l);
}
body:has(.l-pv) .l-main {
  padding-top: var(--space-2l);
}

/*--------------------------------------------------------------------------------

  container

--------------------------------------------------------------------------------*/
.l-content {
  width: var(--content-width, calc(var(--base-width) * 1px));
  max-width: calc(100% - (var(--side-space) * 2));
  margin: 0 auto;
}
