@charset "utf-8";


/* =========================================================
 * basic-page header
 * ========================================================= */
.basic-page--editorial{
  --basic-page-bg: #F4F1EB;
  --basic-page-fg: #17171B;
  --basic-page-fg-soft: rgba(23, 23, 27, 0.74);
  --basic-page-fg-muted: rgba(23, 23, 27, 0.48);
  --basic-page-line: rgba(23, 23, 27, 0.10);
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.78), rgba(255,255,255,0) 38%),
    linear-gradient(180deg, #F8F4EE 0%, var(--basic-page-bg) 100%);
  color: var(--basic-page-fg);
}

.section--basic-page-header{
  --section-space-top: 0;
}

.basic-page-header{
  padding-top: clamp(5.25rem, 10vh, 7.5rem);
  padding-bottom: clamp(2.5rem, 5vw, 4rem);
}

.basic-page-header__rail{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 1rem;
  position: relative;
}

.basic-page-header__rail::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background: var(--basic-page-line);
}

.basic-page-header__kicker{
  margin: 0;
  color: var(--basic-page-fg-muted);
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: .12em;
  line-height: 1.45;
  text-transform: uppercase;
}

.basic-page-header__title-en{
  margin: 0;
  color: var(--basic-page-fg-muted);
  font-family: var(--font-en);
  font-size: clamp(0.75rem, 0.9vw, 0.875rem);
  font-weight: 600;
  letter-spacing: .18em;
  line-height: 1.8;
  text-transform: uppercase;
  text-align: right;
}

.basic-page-header__body{
  display: grid;
  grid-template-columns: 100%;
  gap: clamp(1.25rem, 2.8vw, 2.25rem);
  padding-top: clamp(1.5rem, 3vw, 2rem);
}

.basic-page-header__heading{
  display: grid;
  gap: 0;
}

.basic-page-header__title{
  margin: 0;
  max-width: 12em;
  font-size: clamp(2rem, 4vw, 3.75rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.045em;
  text-wrap: balance;
}

.basic-page-header__copy{
  display: grid;
  gap: .9rem;
  max-width: 42rem;
}

.basic-page-header__intro-head{
  display: grid;
  gap: .35rem;
}

.basic-page-header__intro-ja{
  margin: 0;
  color: var(--basic-page-fg);
  font-size: clamp(1rem, 1.25vw, 1.25rem);
  font-weight: 700;
  line-height: 1.7;
}

.basic-page-header__intro-en{
  margin: 0;
  color: var(--basic-page-fg-muted);
  font-family: var(--font-en);
  font-size: .875rem;
  font-weight: 600;
  letter-spacing: .16em;
  line-height: 1.8;
  text-transform: uppercase;
}

.basic-page-header__lead p{
  margin: 0;
  color: var(--basic-page-fg-soft);
  font-size: clamp(1rem, 1.02vw, 1.0625rem);
  line-height: 1.95;
}

.basic-page-content{
  color: var(--basic-page-fg);
}

@media (min-width: 1025px){
  .basic-page-header--has-copy .basic-page-header__body{
    grid-template-columns: minmax(0, 1.05fr) minmax(280px, .95fr);
    column-gap: clamp(2rem, 4vw, 4rem);
    align-items: start;
  }

  .basic-page-header--has-copy .basic-page-header__heading{
    grid-column: 1 / 2;
  }

  .basic-page-header--has-copy .basic-page-header__copy{
    grid-column: 2 / 3;
    padding-top: .4rem;
  }
}

@media (max-width: 767px){
  .basic-page-header{
    padding-top: clamp(4.5rem, 10vh, 6rem);
    padding-bottom: clamp(2rem, 6vw, 3rem);
  }

  .basic-page-header__rail{
    gap: .75rem;
    flex-direction: column;
    align-items: flex-start;
  }

  .basic-page-header__title-en{
    text-align: left;
  }

  .basic-page-header__title{
    max-width: 100%;
  }

  .basic-page-header__copy{
    max-width: 100%;
  }
}







/* ==================================================
 * page-hero
 * ==================================================
.page-hero{
  width: 100%;
  position: relative;
}
.page-hero__header{
  position: relative;
  overflow: hidden;
}
.page-hero__content{
  color: #FFF;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
  z-index: 2;
}
.page-hero__inner{
  width: 100%;
  max-width: var(--layout-inner-width);
  height: 100%;
  padding-inline: var(--layout-inner-padding);
  margin-inline: auto;
}
.page-hero__title-ja{
  font-size: clamp(2rem, 2.5vw, 2.5rem) !important;
}
.page-hero__title-en{
  font-family: var(--font-en);
  font-size: 2rem;
  font-weight: 700 !important;
}
.page-hero__visual.ui-parallax{
  height: clamp(500px, 60vw, 600px);
}
.page-hero__visual-media.ui-parallax-image{
  width: 100%;
  height: 100%;
  position: relative;
}
.page-hero__visual-media.ui-parallax-image::after{
  content: '';
  background: rgba(0,0,0,0.4);
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}

.page-hero__panel{
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.page-hero__body{
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
  flex: 1 1 auto;
}
.page-hero__marquee{
  color: rgba(255,255,255,1);
  flex: 0 0 auto;
}



@media screen and (min-width: 1025px){
  .page-hero__content{
    padding-right: var(--layout-rail-width);
  }
  .page-hero__visual.ui-parallax{
    height: 100vh;
    min-height: 600px;
  }
} */

/* --------------------------------------------------
 * page-hero modifier: stack
 * --------------------------------------------------
.page-hero--stack .page-hero__header{
  min-height: 200vh;
}
@supports (height: 100svh){
  .page-hero--stack .page-hero__header{
    min-height: 200svh;
  }
}

.page-hero--stack .page-hero__visual.ui-parallax{
  width: 100%;
  height: 100%;
  min-height: 0;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 0;
}

.page-hero--stack .page-hero__content{
  height: auto;
  display: block;
  position: relative;
  inset: auto;
  z-index: 2;
}
.page-hero--stack .page-hero__inner{
  width: 100%;
  max-width: none;
  height: auto;
  padding-inline: 0;
}

.page-hero--stack .page-hero__panel{
  min-height: 100vh;
  display: flex;
  align-items: center;
}
@supports (min-height: 100svh){
  .page-hero--stack .page-hero__panel{
    min-height: 100svh;
  }
}

.page-hero--stack .page-hero__panel-inner{
  width: 100%;
  max-width: var(--layout-inner-width);
  padding-inline: var(--layout-inner-padding);
  margin-inline: auto;
} */

/* タイトル面 
.page-hero--stack .page-hero__panel--title .page-hero__panel-inner{
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.page-hero--stack .page-hero__title{
  font-size: clamp(1.2rem, 2.2vw, 1.6rem);
  margin: 0.5rem 0 0;
  order: 2;
}
.page-hero--stack .page-hero__title-en{
  font-size: clamp(2rem, 6vw, 4.8rem);
  line-height: 1.1;
  font-weight: 900;
  margin: 0;
  order: 1;
}
.page-hero--stack .page-hero__lead{
  font-family: var(--font-en);
  font-size: clamp(1rem, 2.2vw, 1.4rem);
  line-height: 1.4;
  max-width: 42rem;
  margin: 1rem 0 0;
  order: 3;
}*/

/* テキスト面 
.page-hero--stack .page-hero__panel--text .page-hero__panel-inner{
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.page-hero--stack .page-hero__text{
  max-width: 720px;
  font-weight: 700;
}*/




/* ==================================================
 * page-header
 * ================================================== */
.page-header{
  background: linear-gradient(180deg, #FFF 0%, #F6F6F6 100%);
  width: 100%;
}
.page-header--offset{
  padding-top: var(--layout-header-height);
}
.page-header__content{
  width: 100%;
}
.page-header__inner{
  max-width: var(--layout-inner-width);
  padding-inline: var(--layout-inner-padding);
  margin-inline: auto;
}
.page-header__panel{
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-block: var(--space-panel-block);
}
.page-header__title-ja{
  font-size: var(--font-size-heading-md);
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  order: 2;
}
.page-header__title-rule{
  background: rgba(0,0,0,.10);
  flex: 0 0 auto;
  width: clamp(32px, 3vw, 48px);
  height: 1px;
  position: relative;
  overflow: hidden;
}
.page-header__title-rule > span{
  position: absolute;
  inset: 0;
}
.page-header__title-rule > span::after{
  content: '';
  background: currentColor;
  position: absolute;
  inset: 0;
  transform: translateX(-100%);
  animation: rule-infinite 4.4s ease-in-out infinite;
}
.page-header__title-text{
  display: inline-block;
}
.page-header__title-en{
  color: #969696;
  font-family: var(--font-en);
  font-size: var(--fs-2xs);
  letter-spacing: 0.15em;
  line-height: 1;
  text-transform: uppercase;
  order: 1;
}
.page-header__marquee{
  color: rgba(0,0,0,.40);
  font-family: var(--font-en);
  order: 3;
}
@media screen and (min-width: 1025px){
  .page-header__content{
    padding-right: var(--layout-rail-width);
  }
}





/* ==================================================
 * block-intro
 * ================================================== */
.block-intro{
  display: flex;flex-direction: column;gap: 3rem;
}
.block-intro__inner{
  display: flex;flex-direction: column;gap: 2rem;
}
.block-intro__title{
  display: flex;flex-direction: column;gap: 1rem;
}
.block-intro__title-ja{
  font-size: clamp(2rem, 2.5vw, 2.5rem);
  line-height: 1.5;
  display: block;
}
.block-intro__title-en{
  font-family: var(--font-en);
  font-size: clamp(0.8125rem, 0.9vw, 0.9375rem);
  background: rgba(0,0,0,.05);
  display: inline-flex;
  width: fit-content;
  padding: 0.5rem 1rem;
  border-radius: var(--radius-pill);
}
.block-intro__lead{
  line-height: 1.9;
}
.block-intro__lead br{
  display: none;
}
@media screen and (min-width: 1025px){
  .block-intro__lead br{
    display: block;
  }
}


/* ==================================================
 * u-visually-hidden
 * ================================================== */
.u-visually-hidden{
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  border: 0;
  position: absolute;
  overflow: hidden;
  white-space: nowrap;
  clip: rect(0, 0, 0, 0);
}

/* ==================================================
 * u-min-h-screen
 * ================================================== */
.u-min-h-screen{
  min-height: 100vh;
  min-height: 100svh;
  min-height: 100dvh;
}



/* ==================================================
 * ui-tel
 * ================================================== */
.ui-tel{cursor: default;}

/* ================================================== *
   ui-sns
 * ================================================== */
/* ==================================================
 * ui-sns
 * ================================================== */
.ui-sns__label{
  font-family: var(--font-en);
  text-align: center;
  margin-bottom: 2rem;
}
.ui-sns__list{
  display: flex;align-items: center;justify-content: center;gap: 1.5rem;
}
.ui-sns__item{
  flex: 0 0 auto;
}
.ui-sns__link{
  display: flex;align-items: center;justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-pill);
  transition: color 200ms cubic-bezier(.2,.8,.2,1), border-color 200ms cubic-bezier(.2,.8,.2,1), transform 200ms cubic-bezier(.2,.8,.2,1), opacity 200ms cubic-bezier(.2,.8,.2,1);
}
.ui-sns__icon{
  width: 20px;
  height: 20px;
}
.ui-sns__icon svg{
  display: block;
  width: 100%;
  height: 100%;
}

/* ================================================== *
   ui-marquee
 * ================================================== */
.ui-marquee{
  white-space: nowrap;
  width: 100%;
  overflow: hidden;
  contain: paint;
}
.ui-marquee__track{
  display: flex;gap: 2rem;
  width: max-content;
  transform: translate3d(0,0,0);
  pointer-events: none;
  will-change: transform;
  backface-visibility: hidden;
  animation: ui-marquee-scroll 60s linear infinite;
}
.ui-marquee__group{
  display: flex;align-items: baseline;
  flex: 0 0 auto;
  position: relative;
  z-index: 1;
}
.ui-marquee__item{
  color: inherit;
  font-family: var(--font-en);
  font-size: clamp(5rem, 10vw, 10rem);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.15;
  flex: 0 0 auto;
  margin-right: 1rem;
}
@keyframes ui-marquee-scroll{
  0%{transform: translate3d(0,0,0);}
  100%{transform: translate3d(-50%,0,0);}
}
@media (prefers-reduced-motion: reduce){
  .ui-marquee__track{
    animation: none;
    transform: none;
  }
}

/* ================================================== *
   ui-reveal
 * ================================================== */
.ui-reveal{
  will-change: transform, opacity;
}
.ui-reveal--fade-in{
  transform: translateY(20px);
  opacity: 0;
  transition: opacity 0.8s ease-out, transform .8s ease-out;
}
.ui-reveal--slide-top{
  transform: translateY(40px);
  opacity: 0;
  transition: opacity 0.8s ease-out, transform .8s ease-out;
}
.ui-reveal--slide-bottom{
  transform: translateY(-40px);
  opacity: 0;
  transition: opacity 0.8s ease-out, transform .8s ease-out;
}
.ui-reveal--slide-left{
  transform: translateX(40px);
  opacity: 0;
  transition: opacity 0.8s ease-out, transform .8s ease-out;
}
.ui-reveal--slide-right{
  transform: translateX(-40px);
  opacity: 0;
  transition: opacity 0.8s ease-out, transform .8s ease-out;
}
.ui-reveal--fade-in.is-revealed,
.ui-reveal--slide-top.is-revealed,
.ui-reveal--slide-bottom.is-revealed{
  transform: translateY(0);
  opacity: 1;
}
.ui-reveal--slide-left.is-revealed,
.ui-reveal--slide-right.is-revealed{
  transform: translateX(0);
  opacity: 1;
}


/* ==================================================
 * wrapper（ここで重なりと前後関係を“強制”）
 * ================================================== */
.stackWrap{
  position: relative;
  overflow: visible; /* 画像をまたがせる */
}

/* ①は下に余白を持つ（②が上に被さるスペース） */
.section--stack-a{
  position: relative;
  z-index: 1;
  padding-bottom: 220px; /* 重なり代 */
}

/* ②は①に被さる（これで必ず重なる） */
.section--stack-b{
  position: relative;
  z-index: 2;
  margin-top: -220px; /* ①に被せる量（上と同値） */
}

/* ==================================================
 * stack（背景ブロック）
 * ================================================== */
.stack{
  position: relative;
  overflow: clip;
  padding-block: clamp(2.5rem, 6vw, 4rem);
  padding-inline: max(2rem, calc((100vw - 1400px) / 2 + 2rem));
}

.stack--black{ background: #000; color: #fff;min-height: 100vh; padding-bottom: 400px;}
.stack--brown{ background: #452424; color: rgba(255,255,255,.92); min-height: 100vh; margin-top: -400px;}

.stack__panel{
  max-width: 60ch;
  line-height: 2;
}

/* ==================================================
 * media（必ず②より前に出す＝ラッパー直下＋z-index最大）
 * ================================================== */
.stackWrap__media{
  position: absolute;
  z-index: 999; /* ←②より前を保証 */
  right: 0;     /* 画面右ピッタリ */
  top:  clamp(2.5rem, 6vw, 4rem); /* ①と②の境界付近（確実にまたぐ） */

  width: min(46vw, 560px);
  aspect-ratio: 4 / 3;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(0,0,0,0.35);
}

.stackWrap__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ==================================================
 * SP（またぎはやめて下へ）
 * ================================================== */
@media (max-width: 1024px){
  .section--stack-a{ padding-bottom: 96px; }
  .section--stack-b{ margin-top: -96px; }

  .stackWrap__media{
    position: static;
    width: 100%;
    margin-top: 1.25rem;
  }
}



/* ==================================================
 * masonry
 * ================================================== */
[data-masonry="root"] [data-masonry="list"]{
  display: flex;flex-direction: column;
}
[data-masonry="root"] [data-masonry="col"]{
  display: block;
}
@media (min-width: 1025px){
  [data-masonry="root"] [data-masonry="list"]{
    flex-direction: row;
  }
  [data-masonry="root"] [data-masonry="col"]{
    display: flex;flex-direction: column;gap: clamp(1.5rem, 3vw, 3rem);
    flex: 1;  
  }
}
















/* ================================================== 
 * block-privacy / block-terms
 * ================================================== */
.block-privacy,
.block-terms{
  background: #E6E6E6;
  padding-block: clamp(4rem, 8vw, 8rem);
  padding-inline: clamp(1.5rem, 6vw, 6rem);
}
.block-privacy__intro,
.block-terms__intro{
  padding-bottom: 2rem;
  margin-bottom: 2rem;
  border-bottom: 1px solid rgba(0,0,0,.20);
}
.block-privacy__items,
.block-terms__items{
  counter-reset: block-heading;
  display: flex;flex-direction: column;gap: 2rem;
}
.block-privacy__item,
.block-terms__item{
  display: flex;flex-direction: column;gap: 1rem;
}
.block-privacy__heading,
.block-terms__heading{
  counter-increment: block-heading;
  font-size: clamp(1.25rem, 1.5vw, 1.5rem);
  position: relative;
  padding-left: 2rem;
}
.block-privacy__heading::before,
.block-terms__heading::before{
  content: counter(block-heading) '.';
  position: absolute;
  left: 0;
  top: 0.9em;
  transform: translateY(-50%);
}
.block-privacy p,
.block-privacy ol,
.block-terms p,
.block-terms ol{
  font-size: clamp(0.875rem, 1vw, 1rem);
}
.block-privacy ol,
.block-terms ol{
  display: flex;flex-direction: column;gap: 1rem;
}
.block-privacy ul,
.block-terms ul{
  font-size: clamp(0.75rem, 0.875vw, 0.875rem);
}



/*----------------------------------- */
/*----------------------------------- */
/*-- .notfound-post ----------------- */
/*----------------------------------- */
/*----------------------------------- */
.notfound-post{color: var(--color-wht-base);background: var(--color-nvy-base);display: flex;flex-direction: column;align-items: center;justify-content: center;width: 100%;height: 100vh;min-height: 600px;padding: 0 clamp(20px, 5vw, 40px);margin-bottom: clamp(80px, 10vw, 120px);}
.notfound-post .title-ja{font-size: clamp(1.424rem, 2vw, 1.602rem);margin-bottom: clamp(30px, 5vw, 60px);order: 2;}
.notfound-post .title-en{font-size: clamp(3.653rem, 7vw, 6.584rem);line-height: 1;order: 1;}
.notfound-post p{display: flex;justify-content: center;order: 3;}

/*----------------------------------- */
/*-- .nav-number -------------------- */
/*----------------------------------- */
/*----------------------------------- */
.nav-number{width: 100%;padding: 0 clamp(20px, 5vw, 40px);margin-bottom: 30px;}
.nav-number ul{width: 100%;display: flex;justify-content: center;gap: 0 10px;margin-bottom: 0;}
.nav-number ul li a,
.nav-number ul li span{color: var(--color-slt-base);font-size: .889rem;background: var(--color-blk-alpha05);display: flex;align-items: center;justify-content: center;width: 40px;height: 50px;border-radius: 3px;position: relative;overflow: hidden;}
.nav-number ul li a:hover{background: var(--color-blu-tint);}
.nav-number ul li a.prev,
.nav-number ul li a.next,
.nav-number ul li a.prev:hover,
.nav-number ul li a.next:hover{background: transparent;width: 20px;border: none;position: relative;}
.nav-number ul li a.prev::after,
.nav-number ul li a.next::after{content: '';width: 8px;height: 8px;border-bottom: 2px solid var(--color-slt-base);border-left: 2px solid var(--color-slt-base);position: absolute;top: 50%;left: 50%;transition: border-color .3s ease;backface-visibility: hidden;will-change: transform;}
.nav-number ul li a.prev::after{transform: translate(-50%, -50%) rotate(45deg);}
.nav-number ul li a.next::after{transform: translate(-50%, -50%) rotate(-135deg);}
.nav-number ul li a.prev:hover::after,
.nav-number ul li a.next:hover::after{border-bottom-color: var(--color-blu-base);border-left-color: var(--color-blu-base);}
.nav-number ul li span.current{color: var(--color-wht-base);background: var(--color-blu-base);}
.nav-number ul li span.dots{background: transparent;width: 15px;border: none;border-radius: 0;}
/*----------------------------------- */
/*----------------------------------- */
/*-- .nav-post ---------------------- */
/*----------------------------------- */
/*----------------------------------- */
.nav-post{width: 100%;padding: 0 clamp(20px, 5vw, 40px);margin-bottom: 30px;}
.nav-post ul{width: 100%;display: flex;align-items: center;justify-content: center;gap: 0 10px;margin-bottom: 0;}
.nav-post ul li a{color: var(--color-slt-base);font-size: .889rem;background: var(--color-blk-alpha05);display: inline-flex;align-items: center;height: 50px;padding: 0 20px;border-radius: 3px;}
.nav-post ul li.prev a::before,
.nav-post ul li.next a::after{content: '';display: block;width: 8px;height: 8px;border-top: 2px solid var(--color-slt-base);border-right: 2px solid var(--color-slt-base);}
.nav-post ul li.prev a::before{margin-right: 10px;transform: rotate(-135deg);}
.nav-post ul li.next a::after{margin-left: 10px;transform: rotate(45deg);}
.nav-post ul li a:hover{background: var(--color-blu-tint);}
/*----------------------------------- */
/*----------------------------------- */
/*-- .btn-link ---------------------- */
/*----------------------------------- */
/*----------------------------------- */
.btn-link{width: 100%;margin-bottom: 30px;}
.btn-link a{color: var(--color-wht-base);background: var(--color-blu-base);display: inline-flex;align-items: center;width: 100%;max-width: 250px;min-width: 200px;height: 60px;border-radius: 3px;position: relative;overflow: hidden;}
.btn-link a .link-text{flex: 1;text-align: left;display: flex;flex-direction: column;padding-left: 20px;transform: translateX(0);transition: transform .5s ease, text-align .5s ease;z-index: 1;}
.btn-link a .link-arrow{width: 40px;height: 40px;background: var(--color-wht-alpha20);display: flex;align-items: center;justify-content: center;border-radius: 3px;position: absolute;top: 50%;transition: transform .5s ease, opacity .5s ease;z-index: 2;}
.btn-link a .link-arrow.right{right: 10px;opacity: 1;transform: translate(0, -50%);}
.btn-link a .link-arrow.left{left: 10px;opacity: 0;transform: translate(-100%, -50%);}
.btn-link a:hover .link-text{text-align: right;padding-left: 0;padding-right: 20px;transform: translateX(-10px);}
.btn-link a:hover .link-arrow.right{opacity: 0;transform: translate(120%, -50%);}
.btn-link a:hover .link-arrow.left{opacity: 1;transform: translate(0, -50%);}
.btn-link a .icon-arrow-wrap{color: var(--color-slt-deep);}
.btn-link a .icon-arrow-wrap .icon-arrow{display: block;width: 15px;height: 15px;}