* {
  margin: 0;
  padding: 0;
  min-height: 0;
  min-width: 0;
  box-sizing: border-box
}

html, body, div, article, section, aside, header, footer, hgroup, nav, h1, h2, h3, ul, li, a, p, small, img {
  border: none;
  display: block;
}

h1, h2, h3, ul, li, a, p{
font-family: "Noto Sans JP", sans-serif;
}

html {
  width: 100%;
  height: 100%;
  font-size: clamp(14px, calc(12.8px + 0.375vw), 16px);
  position: static;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  text-size-adjust: 100%
}



@media (min-width: 1200px){
  html { font-size: clamp(16px, calc(4px + 0.8333vw), 20px); }
}

/* 入力ズーム対策（iOS） */
input, select, textarea { font-size: 16px; }

.bold{
	font-weight: 600!important;
}


body {
  height: 100%;
  width: 100%;
  position: relative;
  color: #666666;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  line-height: 1.6;
letter-spacing: 0.05em;
  font-style: normal;
}


body::before {
  visibility: hidden;
  opacity: 0;
  position: absolute
}


@media screen and (max-width: calc(576px - 0.2px)) {
  body::before {
    content: "sm"
  }
}

@media screen and (min-width: 768px)and (max-width: calc(992px - 0.2px)) {
  body::before {
    content: "lg"
  }
}

@media screen and (min-width: 1200px) {
  body::before {
    content: "xl"
  }
}

a {
  zoom: 1;
  outline: 0;
  color: #009DE0;
  text-decoration: none
}

li a{
    display: block;
    height: 100%;
    width: 100%
}

img {
width: auto;
  outline: 0;
  border: 0;
  border-style: none
}

@media screen and (max-width: calc(992px - 0.2px)) {
  img {
    max-width: 100%;
    height: auto;
    -o-object-fit: cover;
    object-fit: cover
  }
 .cps-sv__slide img{
	 height: revert-layer;
 }
}

ul, li {
  list-style: none;
  list-style-image: none
}

dl, ol, ul {
  margin-bottom: 0
}

label {
  display: inline-block;
  vertical-align: middle
}

ul, li, a, small {
  display: block
}

iframe {
  border: 0
}

.hide {
  display: none !important
}

.show-block {
  display: block !important
}

.show-inline {
  display: inline !important
}

.show-inline-block {
  display: inline-block !important
}

.show-flex {
  display: flex !important
}

.text-left {
  text-align: left !important
}

.text-center {
  text-align: center !important
}

.text-right {
  text-align: right !important
}


@media screen and (max-width: 575.8px) {
  .xs-none {
    display: none !important
  }
    .xs-block {
    display: block !important
  }
}

    .msd-block {
    display: none !important
  }

@media screen and (max-width: 767.8px) {
  .msd-none {
    display: none !important
  }
    .msd-block {
    display: flex !important
  }
}



@media screen and (min-width: 576px) {
  .sm-hide {
    display: none !important
  }
  .sm-show-block {
    display: block !important
  }
  .sm-show-inline {
    display: inline !important
  }
  .sm-show-inline-block {
    display: inline-block !important
  }
  .sm-show-flex {
    display: flex !important
  }
  .sm-text-left {
    text-align: left !important
  }
  .sm-text-center {
    text-align: center !important
  }
  .sm-text-right {
    text-align: right !important
  }
}

@media screen and (min-width: 768px) {
  .md-hide {
    display: none !important
  }
  .md-show-block {
    display: block !important
  }
  .md-show-inline {
    display: inline !important
  }
  .md-show-inline-block {
    display: inline-block !important
  }
  .md-show-flex {
    display: flex !important
  }
  .md-text-left {
    text-align: left !important
  }
  .md-text-center {
    text-align: center !important
  }
  .md-text-right {
    text-align: right !important
  }
}

@media screen and (min-width: 992px) {
  .lg-hide {
    display: none !important
  }
  .lg-show-block {
    display: block !important
  }
  .lg-show-inline {
    display: inline !important
  }
  .lg-show-inline-block {
    display: inline-block !important
  }
  .lg-show-flex {
    display: flex !important
  }
  .lg-text-left {
    text-align: left !important
  }
  .lg-text-center {
    text-align: center !important
  }
  .lg-text-right {
    text-align: right !important
  }
}

iframe {
  max-width: 100%
}




/* 共通 inner（1440時1200） */
.section__inner {
    max-width: 78rem;
    margin-inline: auto;
}

.section__container{
    padding: 7.5rem 2.5rem;
	position: relative;
}

section.base-level__lower {
    /*background: linear-gradient(to bottom, #FFBFBF 0%, #FFBFBF 70%, #FF9F9F 85%, #FF6F6F 100%);*/
    background: linear-gradient(to bottom, #F9CFC6 0%, #FAD6CD 40%, #FBE1D9 70%, #fff6e8 100%);
}








/* =======================================================
  Under Hero（下層MV） + Hero内 Breadcrumb（完全版）
  - 背景：pictureでPC/SP切替（1枚画像）
  - パンくず：hero内に表示（白系 + shadowで可読性担保）
  - 共通CSSの a{display:block} 対策込み
  - rem運用（1440時の左右余白は hero側でclamp）
======================================================= */

/* ===== Hero base ===== */
.hero__under{
  position: relative;
  overflow: hidden;
    min-height: 28.75rem;
}

/* 背景画像（picture） */
.hero__bg{
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
}

.hero__bgImg{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right center;
  display: block;
}

/* ※画像自体にグラデが焼き込みなら削除OK */
/*.hero__under::after{
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  /*background: linear-gradient(
    to right,
    rgba(199, 72, 72, 0.88) 0%,
    rgba(199, 72, 72, 0.70) 45%,
    rgba(255, 255, 255, 0.10) 100%
  );
}*/

/* コンテンツ（左寄せ） */
.hero__inner{
  position: relative;
  z-index: 2;
  max-width: 78rem;
  margin-inline: auto;
  padding-inline: 2.5rem;
  padding-block: 7.5rem 6rem;
}

.hero__under .section__container {
    padding: 0 2.5rem;
    padding-bottom: 0;
    top: 12rem;
}

/* 1440px以上：左右余白を約65pxに寄せる */
@media (min-width: 1440px){
  .hero__inner{
    padding-inline: clamp(3.25rem, 4.0625rem, 4.0625rem);
  }
}

/* タイトル */
.section__subtitle{
    color: #ffffff;
    font-weight: 500;
    font-size: max(1rem, 14px);
    font-size: max(0.875rem, 12px);
    margin-top: 0.6rem;
}

.section__title{
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0em;
    font-family: "Lexend Mega", sans-serif;
    font-size: max(3rem, 40px);
    background: linear-gradient(to right, #FFBFBF 0%, #FFBFBF 70%, #FF9F9F 85%, #FF6F6F 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

/* ===== Hero内 Breadcrumb ===== */
.hero__breadcrumb{
  margin-top: 2.5rem;
  font-size: max(0.875rem, 12px);
  font-weight: 500;
  color: #ffffff;
      white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.hero__under .section__container.bread {
    padding: 0 2.5rem;
    /* position: absolute; */
    position: relative;
    top: 21rem;
}

/* 共通CSS対策：aがblockなので、breadcrumb内だけインラインに戻す */
.hero__breadcrumb,
.hero__breadcrumb *{
  display: inline;
  line-height: 1.6;
}

/* リスト出力（bcn_display_list）対策 */
.hero__breadcrumb ol,
.hero__breadcrumb ul{
  display: inline;
  margin: 0;
  padding: 0;
}

/* 区切り */
.hero__breadcrumb li+li::before{
  content: " / ";
  margin: 0 0.4rem;
  color: #ffffff;
}

/* リンク */
.hero__breadcrumb a{
  color: #ffffff;
  text-decoration: none;
}

.hero__breadcrumb a:hover{
  text-decoration: underline;
}

.section__inner.bread {

}

/* ===== SP ===== */
@media (max-width: 575.8px){
  .hero__under{
    min-height: 28.75rem;
  }

  .hero__bgImg{
    object-position: center top;
  }

  .hero__inner{
    padding-inline: 1.25rem;
    padding-block: 5rem 4rem;
  }

  .section__title{
    font-size: max(2.25rem, 34px);
  }

  /* 明るい画像でも読める保険（必要なら残す） */
  .hero__breadcrumb{
    margin-top: 0rem;
        max-width: 22rem;
		display: inline-block;
  }
}

/* ===== Optional: 画像が明るすぎてbreadcrumbが沈む時だけON ===== */
/*
@media (max-width: 575.8px){
  .hero__breadcrumb{
    display: inline-block;
    padding: 0.4rem 0.8rem;
    border-radius: 0.5rem;
    background: rgba(0,0,0,0.15);
  }
}
*/





/* =======================================================
  Menbers Archive - FINAL
  - Card width === Image width
  - 1440px〜：344pxカード × 3列
  - No animation
======================================================= */


.base-level__lower.single-menbers .section__container {
    padding-bottom: 0;
}

.base-level__lower.single-menbers .section__inner {
    padding-bottom: 0;
    position: relative;
}

.menber-single__sections .section__container ,.menber-single__schedule .section__container,.menber-single__offday .section__container{
    padding-top: 0;
}

.menber-schedule-slide {
    margin-top: 4rem;
}

/* =========================
  Grid
========================= */
.menbers-archive__list{
  display: grid;
  grid-template-columns: 1fr; /* SP */
  gap: 1.6rem;
  justify-content: center; /* 固定幅時の中央寄せ */
}

/* 576px〜：2列（リキッド） */
@media screen and (min-width: 576px){
  .menbers-archive__list{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.8rem;
  }
}

/* 992px〜：3列（リキッド） */
@media screen and (min-width: 992px){
  .menbers-archive__list{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 2.2rem;
  }
}

/* 1440px〜：3列 固定幅（344px） */
@media screen and (min-width: 1440px){
  .menbers-archive__list{
grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 4rem 6.75rem;
        justify-content: center;
  }
}

/* =========================
  Card
========================= */
.menber-card{
  width: 100%; /* グリッド幅に追従 */
      border-bottom: 1px solid #666666;
}

/* リンク全体 */
.menber-card__link{
  display: block;
  width: 100%;
  text-decoration: none;
  position: relative;
}

/* =========================
  Job badge
========================= */
.menber-card__job{
    /*position: absolute;
    top: 1.1rem;
    left: 1.1rem;
    z-index: 3;*/
    font-size: max(0.75rem, 11px);
    line-height: 1;
    padding: 0.35rem 1.7065rem;
    border-radius: 999px;
    background: #EAEAEA;
    color: #666666;
	    display: inline-block;
    margin-bottom: 0.5rem;
}

.menber-card__media-inner {
    position: absolute;
    left: 1.1rem;
    right: 1.1rem;
    bottom: 1.3rem;
    z-index: 2;
}

/* =========================
  Media
========================= */
.menber-card__media{
  position: relative;
  width: 100%;
  overflow: hidden;
  border-radius: 1.25rem;
}

/* 画像（カード幅＝画像幅） */
.menber-card__img,
.menber-card__img--empty{
  width: 100%;
  height: auto;
  aspect-ratio: 344 / 458;
  object-fit: cover;
  display: block;
}

/* 画像オーバーレイ */
.menber-card__media::after{
  content: "";
  position: absolute;
  inset: 0;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 60%, rgba(87, 65, 65, 0.54) 100%);
  z-index: 1;
}

/* 画像を重ねられるように */
.menber-card__media{
  position: relative;
}

/* OFF画像は重ねて非表示 */
.menber-card__img--off{
  position:absolute;
  inset:0;
  opacity:0;
  transition:opacity .2s ease;
  pointer-events:none;
}

/* ホバー可能なデバイスのみ切替（スマホ誤動作防止） */
@media (hover: hover) and (pointer: fine){
  .menber-card:hover .menber-card__img--off{
    opacity:1;
  }
}


/* =========================
  Catch copy
========================= */
.menber-card__catch{
    /*position: absolute;
    left: 1.1rem;
    right: 1.1rem;
    bottom: 1.3rem;
    z-index: 2;*/
    color: #fff;
    font-size: max(1rem, 1rem);
    line-height: 1.68;
    font-weight: 500;
}

/* =========================
  Body
========================= */
.menber-card__body{
  padding-top: 1rem;
}

.menber-card__base{
    font-size: max(0.75rem, 11px);
    color: #666666;
    margin-bottom: 0.35rem;
    font-weight: 500;
}

.menber-card__name {
    font-size: max(1.375rem, 1.25rem);
    line-height: 1.3;
    font-weight: 600;
    color: #666666;
}

.menber-card__name__flex {
    display: flex;
    gap: 1rem;
    align-items: center;
    margin-bottom: 0.85rem;
}

.menber-card__meta{
    display: flex;
    gap: 0.3rem;
    font-size: max(0.875rem, 12px);
    color: #666666;
    font-weight: 500;
}

/* =========================
  SP adjustments
========================= */
@media screen and (max-width: 575.8px){
  .menber-card__job{
    top: 0.9rem;
    left: 0.9rem;
    padding: 0.5rem 0.7rem;
  }

  .menber-card__catch{
    left: 0.9rem;
    right: 0.9rem;
    bottom: 0.9rem;
  }

  .menber-card__media{
    border-radius: 1rem;
  }

  .menber-card__body{
    padding-top: 0.9rem;
  }
}












/* =========================
  HERO（背景なし・remベース）
  要件：
  - 1440時左右余白 ≒ 65px
  - quote は grid 外（独立して被せる）
  - 1440時 画像 ≒ 755×458
========================= */

.menber-hero{
  position: relative;
}

/* 余白管理用の内枠 */
.menber-hero__inner{
  position: relative;

  /* 基本：共通の 2.5rem を踏襲 */
  padding-inline: 2.5rem;
}

/*
  1440px以上：
  rootが16→20へ可変するので、remだけだとpxがズレる。
  そこで clamp() で「見た目のpx」を65付近に寄せる。

  - root=16px のとき：4.0625rem ≒ 65px
  - root=20px のとき：3.25rem  ≒ 65px
*/
@media (min-width: 1440px){
  .menber-hero__inner{
    padding-inline: clamp(3.25rem, 4.0625rem, 4.0625rem);
  }
}

/* レイアウト：左情報 / 右画像 */
.menber-hero__grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 2rem;
  align-items: start;
  padding-top: 3.25rem;
  padding-bottom: 4.5rem; /* quote が被さっても破綻しない下余白 */
}

@media (min-width: 992px){
  .menber-hero__grid{
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.5fr);
    gap: 3rem;
  }
}

/* -------- 左：情報 -------- */
.menber-hero__label{
    font-size: max(0.875rem, 12px);
    letter-spacing: 0.18em;
    font-weight: 500;
    color: #FD8B8B;
    margin-bottom: 1rem;
    font-family: "Lexend Mega", sans-serif;
    letter-spacing: 0;
}

.menber-hero__nameRow{
  /*display: grid;*/
  display: block;
  grid-template-columns: auto 1px 1fr;
  gap: 1.2rem;
      flex-wrap: wrap;
  align-items: center;
}

.menber-hero__name{
    font-size: max(2.25rem, 28px);
    font-weight: 600;
    line-height: 1.1;
    color: #666666;
	    white-space: nowrap;
}

.menber-hero__divider{
    width: 1px;
    height: 100%;
    background: #ffffff;
    display: block;
}

.menber-hero__meta{
  display: grid;
  gap: 0.4rem;
      margin-top: 1rem;
}

.menber-hero__metaLine{
    display: flex;
    flex-wrap: wrap;
    gap: 0.1rem 0.5rem;
    font-size: max(0.875rem, 12px);
    color: #666666;
    font-weight: 500;
}

/* SP：縦線なし */
@media (max-width: 575.8px){
  .menber-hero__grid{
    padding-top: 0rem;
    padding-bottom: 3rem;
  }
  .menber-hero__nameRow{
    grid-template-columns: 1fr;
    gap: 0.8rem;
    align-items: start;
  }
  .menber-hero__name{
    white-space: normal;
  }
  .menber-hero__divider{
    display: none;
  }
}

/* -------- 右：画像 -------- */
.menber-hero__media{
  justify-self: end;
  width: 100%;
    max-width: 45rem;
}

/* ベース：比率で保持 */
.menber-hero__img{
  width: 100%;
  height: auto;
      min-height: 27rem;
  aspect-ratio: 755 / 458;
  object-fit: cover;
  border-radius: 1.6rem;
  display: block;
  background: #fff;
}

/* 1440px以上：見た目を 755×458 に“寄せる”
   ※root可変でもpx見た目が崩れにくいよう、remをclampで制御 */
@media (min-width: 1440px){
  .menber-hero__img{
    width: 100%;
    aspect-ratio: 755 / 458; /* 高さは比率で追従 */
  }
}

/* -------- quote（grid外・独立して被せる） -------- */
.menber-hero__quote{
  position: absolute;
  left: 0;
  right: 0;
  z-index: 3;

  /* 被せ位置：画像に重なるように調整 */
    bottom: 6rem;

  pointer-events: none;
}



@media (max-width: 575.8px){

  .menber-hero__quote{
    bottom: 1.5rem;
	        position: relative;
  }
}

/* 白帯（1行＝1帯 / 背景が横いっぱいにならない） */
.menber-hero__quoteLine{
    display: block;
    /*background: rgba(255, 255, 255, 1);*/
    /*padding: 0.5rem 1.3rem;*/
    font-size: max(2rem, 18px);
    font-weight: 600;
    line-height: 1.5;
    color: #666666;
    margin-bottom: 0.9rem;
    max-width: 100%;
    width: max-content;
	    text-shadow: #ffffff 1px 0 10px;
}

@media (max-width: 575.8px){
  .menber-hero__quoteLine{
    font-size: max(1.125rem, 18px);
    padding: 0.75rem 1rem;
	        padding: 0;
        margin: 0;
  }
}









/* =======================================================
  Single Menbers - 本文セクション（交互）
  - 背景色なし
  - 左右交互
======================================================= */

/* セクション全体 */
.menber-single__sections{
  padding: 5rem 0 5.5rem;
}

.menber-single__sections-inner{
  display: grid;
  gap: 7.5rem; /* ブロック間はかなり広め */
}

/* -----------------------
  1ブロック
------------------------ */
.menber-block{
  width: 100%;
}

.menber-block__inner{
  display: grid;
  gap: 2rem;
  align-items: start;
}

/* PC：左右2カラム */
@media (min-width: 992px){
  .menber-block__inner{
        grid-template-columns: minmax(0, 1fr) minmax(0, 1.1449fr);
        gap: 4rem;
        align-items: start;
  }

  section.menber-block.is-image-right .menber-block__inner{
        grid-template-columns: minmax(0, 1.1449fr) minmax(0, 1fr);
        gap: 4rem;
        align-items: start;
  }

  /* 左右反転 */
  .menber-block.is-image-left .menber-block__media{ order: 0; }
  .menber-block.is-image-left .menber-block__content{ order: 1; }

  .menber-block.is-image-right .menber-block__media{ order: 1; }
  .menber-block.is-image-right .menber-block__content{ order: 0; }
}

/* -----------------------
  画像
------------------------ */
.menber-block__media{
  width: 100%;
}

.menber-block__img,
.menber-block__img--empty{
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10; /* デザインに近い横長 */
  object-fit: cover;
  border-radius: 1.25rem;
  display: block;
  background: #f3f3f3;
}

/* -----------------------
  テキスト側
------------------------ */


/* 見出し（左線＋ピンク文字） */
.menber-block__title{
    position: relative;
    padding-left: 2.2rem;
    margin-bottom: 2.1rem;
    font-size: max(1.625rem, 18px);
    font-weight: 600;
    color: #FD8B8B;
}

/* 左の短い線 */
.menber-block__title::before{
    content: "";
    position: absolute;
    left: 0;
    top: 0.8em;
    width: 1.2rem;
    height: 3px;
  background: #FD8B8B;
}

/* 本文 */
.menber-block__text{
  font-size: max(1rem, 14px);
  font-weight: 400;
  line-height: 1.9;
  color: #666666;
}

/* 本文内段落 */
.menber-block__text p + p{
  margin-top: 1.6rem;
}

/* -----------------------
  SP調整
------------------------ */
@media (max-width: 575.8px){
  .menber-single__sections{
    padding: 0;
  }

  .menber-single__sections-inner{
    gap: 4.5rem;
  }

  .menber-block__inner{
    gap: 1.75rem;
  }

  .menber-block__title{
    padding-left: 1.8rem;
    margin-bottom: 1.4rem;
  }

  .menber-block__title::before{
    width: 1rem;
  }

  .menber-block__img{
    border-radius: 1rem;
  }
}












/* =======================================================
  Schedule（ある一日のスケジュール）
  - 背景色なし
  - 左ラインは親の高さに追従（擬似要素）
======================================================= */

.menber-single__schedule{
  padding: 5rem 0 5.5rem;
  background-color: #ffffff;
}

.menber-single__schedule-title{
  text-align: center;
  color: #666666;
  font-size: max(2rem, 22px);
  font-weight: 600;
    margin-bottom: 4.5rem;
}

/* 縦ラインの“親” */
.menber-schedule{
    position: relative;
    max-width: 48.75rem;
    /* margin-inline: auto; */
    padding-left: 2.75rem;
    margin: 0 auto;
}

/* 左の縦ライン（高さは .menber-schedule の高さに自動追従） */
.menber-schedule::before{
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;              /* ←これで自動伸長 */
  left: 1.15rem;          /* ドット中心と合わせる */
  width: 1px;
  background: #A4A4A4;
}

/* 1行 */
.menber-schedule__row{
  position: relative;
  display: block;
  grid-template-columns: 10rem 1fr;
  column-gap: 0rem;
  row-gap: 0.5rem;

  padding: 0.9rem 0 2.2rem;
}

/* 最後だけ下余白を少し詰める */
.menber-schedule__row:last-child{
  padding-bottom: 0;
}

/* 赤ドット */
.menber-schedule__row::before{
content: "";
    position: absolute;
    left: 0%;
    transform: translate(-1.9rem, -190%);
    top: 1.05rem;
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: #F85656;
}

/* 時刻 */
.menber-schedule__time{
    grid-column: 1 / 2;
    color: #666666;
    font-size: max(1.125rem, 14px);
    font-weight: 500;
    line-height: 1.4;
	    position: relative;
    top: -1.5rem;
}

/* 右本文 */
.menber-schedule__body{
  grid-column: 2 / 3;
      position: relative;
    top: -1rem;
}

.menber-schedule__label{
    color: #666666;
    font-size: max(1.125rem, 14px);
    font-weight: 600;
    line-height: 1.5;
    margin-bottom: 0.25rem;
}

.menber-schedule__desc{
    color: #666666;
    font-size: max(1rem, 1rem);
    font-weight: 500;
    line-height: 1.65;
}

.menber-schedule__desc br{
  display: block;
  content: "";
  margin-top: 0.45rem;
}

/* （画像のような）段差セパレータが必要なら：特定行の後に入れる用 */
.menber-schedule__separator{
  margin: 2.25rem 0;
  height: 1px;
  background: rgba(255,255,255,0); /* デフォは透明 */
}

/* SP調整 */
@media (max-width: 575.8px){
  .menber-single__schedule{
    padding: 4rem 0 4.5rem;
  }

  .menber-single__schedule-title{
    font-size: max(1.5rem, 20px);
    margin-bottom: 2.25rem;
  }

  .menber-schedule{
    padding-left: 2.25rem;
  }

  .menber-schedule::before{
    left: 0.95rem;
  }

  .menber-schedule__row{
    grid-template-columns: 4.25rem 1fr;
    padding: 0.8rem 0 1.8rem;
  }

  .menber-schedule__row::before{
        left: 0%;
        transform: translate(-1.68rem, -190%);
        top: 0.95rem;
  }
  .menber-schedule__time,.menber-schedule__body {
    position: relative;
    top: -1.5rem;
}
}






/* =======================================================
  Single Menbers - オフの日の過ごし方（交互）
  - 本文セクションと同仕様（数値も揃える）
  - 背景色なし
  - 左右交互
======================================================= */

/* セクション全体 */
.menber-single__offday{
  padding: 5rem 0 5.5rem;
}

/* タイトル */
.menber-single__offday-title{
    text-align: center;
    color: #666666;
    font-size: max(2rem, 22px);
    font-weight: 600;
    margin-bottom: 4.5rem;
}

.menber-single__offday-inner{
  display: grid;
  gap: 7.5rem; /* 本文と同じ */
}

/* -----------------------
  1ブロック
------------------------ */
.menber-off{
  width: 100%;
}

.menber-off__inner{
  display: grid;
  gap: 2rem;
  align-items: start;
}

.menber-off.is-image-right.is-no-image .menber-off__inner {
    grid-template-columns: 1fr;
}

/* PC：左右2カラム（本文と同じ比率） */
@media (min-width: 992px){
  .menber-off__inner{
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.1449fr);
    gap: 4rem;
    align-items: start;
  }

  /* 右画像ブロックは列比率を逆転（本文と同じやり方） */
  section.menber-off.is-image-right .menber-off__inner{
    grid-template-columns: minmax(0, 1.1449fr) minmax(0, 1fr);
    gap: 4rem;
    align-items: start;
  }

  /* 左右反転（HTML orderも維持） */
  .menber-off.is-image-left  .menber-off__media{ order: 0; }
  .menber-off.is-image-left  .menber-off__content{ order: 1; }

  .menber-off.is-image-right .menber-off__media{ order: 1; }
  .menber-off.is-image-right .menber-off__content{ order: 0; }
}

/* -----------------------
  画像
------------------------ */
.menber-off__media{
  width: 100%;
}

.menber-off__img,
.menber-off__img--empty{
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10; /* 本文と同じ */
  object-fit: cover;
  border-radius: 1.25rem;
  display: block;
  background: #f3f3f3;
}

/* -----------------------
  テキスト側
------------------------ */

/* 見出し（左線＋ピンク文字） */
.menber-off__title{
  position: relative;
  padding-left: 2.2rem;
  margin-bottom: 2.1rem;
  font-size: max(1.625rem, 18px);
  font-weight: 600;
  color: #FD8B8B;
}

/* 左の短い線 */
.menber-off__title::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0.8em;
  width: 1.2rem;
  height: 3px;
  background: #FD8B8B;
}

/* 本文 */
.menber-off__text{
  font-size: max(1rem, 14px);
  font-weight: 400;
  line-height: 1.9;
  color: #666666;
}

/* 本文内段落 */
.menber-off__text p + p{
  margin-top: 1.6rem;
}

/* -----------------------
  SP調整（本文と同じ）
------------------------ */
@media (max-width: 575.8px){
  .menber-single__offday{
padding: 0;
  }

  .menber-single__offday-title{
    margin-bottom: 2.25rem;
    font-size: max(1.5rem, 20px);
  }

  .menber-single__offday-inner{
    gap: 4.5rem;
  }

  .menber-off__inner{
    gap: 1.75rem;
  }

  .menber-off__title{
    padding-left: 1.8rem;
    margin-bottom: 1.4rem;
  }

  .menber-off__title::before{
    width: 1rem;
  }

  .menber-off__img{
    border-radius: 1rem;
  }
}











section.menber-single__more .section__container {
    padding-top: 4rem;
}

h2.menber-single__more-title {
    border-top: 1px solid #666666;
    padding-top: 3rem;
}


/* =======================================================
  Footer（完全版・SVG対応）
  - ENTRY / BACK TO TOP：同一アニメーション思想
  - hoverで文字＆矢印色 #F85656
  - ENTRY：矢印 → 右へ
  - BACK TO TOP：矢印 ← 左へ
  - SVGは currentColor 追従
======================================================= */

:root{
  --cta-accent: #F85656;
}

/* =========================
  BACK TO TOP（下層のみ）
========================= */
.footer-cta{
  display: flex;
  justify-content: center;
  padding: 6.5rem 0 8.5rem;
}

.footer-cta__btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 1.25rem;
    min-width: 22rem;
    padding: 1.05rem 2.25rem;
    border-radius: 999px;
    background: #ffffff;
    color: #A4A4A4;
    text-decoration: none;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0;
    font-family: "Lexend Mega", sans-serif;
    border: 1px solid #A4A4A4;
  transition: color 220ms ease, border-color 220ms ease;
}

/* 矢印（SVGラッパー） */
.footer-cta__icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;

  transform: translateX(0);
  transition: transform 240ms ease;
}

.footer-cta__icon .icon{
  display: block;
}

/* =========================
  Footer base
========================= */
.site-footer{
  background: #ffffff;
      margin-top: -1rem;
    border-radius: 1.25rem;
	    position: relative;
    z-index: 1;
}

.site-footer__inner{

  margin-inline: auto;
  padding: 2.25rem 2.5rem 1.25rem;
}

@media (min-width: 1440px){

  .menber-schedule__row::before {
        transform: translate(-1.89rem, -1.05rem);
}
}

@media (min-width: 1920px){
  .menber-schedule__row::before {
        transform: translate(-1.84rem, -1.05rem);
}
}

/* =========================
  上段（ロゴ / ナビ / ENTRY）
========================= */
.site-footer__top{
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 2rem;
  align-items: center;
  padding-bottom: 1.5rem;
border-bottom: 1px solid #A4A4A4;
}

/* ブランド */
.site-footer__brand{
  display: grid;
  gap: 0.6rem;
}

.site-footer__logo{
  width: 6.75rem;
  height: auto;
}

.site-footer__brandSub{
    font-size: max(0.625rem, 10px);
    font-weight: 400;
    letter-spacing: 0.1em;
    text-align: center;
    color: #A4A4A4;
    font-family: "Lexend Mega", sans-serif;
}

/* ナビ */
.site-footer__navList{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 3.5rem;
}

.site-footer__navLink{
    font-size: max(0.875rem, 12px);
    font-weight: 500;
    letter-spacing: -0.07em;
    color: #A4A4A4;
    text-decoration: none;
    font-family: "Lexend Mega", sans-serif;
}

/* =========================
  ENTRY（SVG + hoverアニメ）
========================= */
.site-footer__entry{
  display: inline-flex;
  align-items: center;
  gap: 1.1rem;
  padding: 0.67529rem 2.2rem;
  border-radius: 999px;
  border: 1px solid rgba(102,102,102,0.35);
  background: #ffffff;

  color: #A4A4A4; /* 初期色 */
  text-decoration: none;

  font-size: max(0.875rem, 12px);
  font-weight: 600;
  letter-spacing: 0.12em;

  transition: color 220ms ease, border-color 220ms ease;
}

.site-footer__entryText{
  display: inline-block;
}

.site-footer__entryArrow{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;

  transform: translateX(0);
  transition: transform 240ms ease;
}

.site-footer__entryArrow .icon{
  display: block;
}

/* =========================
  Hover animation（PCのみ）
========================= */
@media (hover:hover){

  /* ENTRY */
  .site-footer__entry:hover{
    color: var(--cta-accent);
    border-color: var(--cta-accent);
  }

  .site-footer__entry:hover .site-footer__entryArrow{
    transform: translateX(0.25rem); /* → 右へ */
  }

  /* BACK TO TOP */
  .footer-cta__btn:hover{
    color: var(--cta-accent);
    border-color: var(--cta-accent);
  }

  .footer-cta__btn:hover .footer-cta__icon{
    transform: translateX(-0.25rem); /* ← 左へ */
  }

  .footer-cta__btn.is-arrow-right:hover .footer-cta__icon{
    transform: translateX(0.25rem); /* → 右へ */
  }

}

/* =========================
  下段
========================= */
.site-footer__bottom{
  padding-top: 1rem;
}

.site-footer__copy{
  font-size: max(0.75rem, 11px);
    color: #A4A4A4;
}

/* =========================
  SP
========================= */
@media (max-width: 767.8px){
  .footer-cta{
    padding: 3.5rem 0 2.75rem;
  }

  .footer-cta__btn{
    width: 100%;
    max-width: 22rem;
  }

  .site-footer__inner{
    padding: 2rem 1.25rem 1.25rem;
  }

  .site-footer__top{
    grid-template-columns: 1fr;
    gap: 1.5rem;
    text-align: center;
  }

  .site-footer__navList{
    gap: 2rem;
    flex-wrap: wrap;
  }
}











/* =======================================================
  Requirements（募集要項一覧） COMPLETE CSS
  - 新卒 / 中途 タブ
  - 中途×複数のみアコーディオン
  - チラ見せ：PC 12rem / SP 10rem
  - 閉じ：フェード + ぼかし（blur）
  - 開き：フェード/ぼかし解除
  - 背景色なし
======================================================= */

/* =========================
  Tabs
========================= */
.requirements-tabs{
  display: flex;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 3.5rem;
}

.requirements-tabs__btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 12rem;
    padding: 0.7rem 1rem;
    border-radius: 999px;
    background: #ffffff;
    border: 1px solid rgba(102, 102, 102, 0.25);
    color: rgba(102, 102, 102, 0.65);
    text-decoration: none;
    font-size: max(1.125rem, 12px);
    font-weight: 500;
}

.requirements-tabs__btn.is-active{
    border-color: #F85656;
    color: #F85656;
}

@media (max-width: 575.8px){
  .requirements-tabs{
    gap: 0.75rem;
    margin-bottom: 2.75rem;
  }
  .requirements-tabs__btn{
    min-width: 0;
    width: 100%;
    max-width: 12.5rem;
    padding: 0.85rem 1.2rem;
  }
}

/* =========================
  List / Card
========================= */
.requirements-list{
  display: grid;
  gap: 2.5rem;

  /* チラ見せ量（ここだけ調整） */
  --req-peek: 12rem; /* PC */
}

@media (max-width: 575.8px){
  .requirements-list{
    --req-peek: 10rem; /* SP */
  }
}

.requirements-card {
    border-radius: 1.25rem;
    background: rgb(255 255 255 / 70%);
    border: 1px solid #ffffff;
}

.requirements-card__inner {
    padding: 4rem 4.25rem 4.5rem;
	    padding-bottom: 0;
}

.requirements-card__title{
  font-size: max(1.375rem, 18px);
  font-weight: 600;
  line-height: 1.35;
  color: #666666;
  margin-bottom: 1.5rem;
}

/* =========================
  DL（ラベル / 内容）
========================= */
.requirements-dl{
  display: grid;
  gap: 1.2rem;
}

.requirements-dl__row{
  display: grid;
  grid-template-columns: 10.5rem 1fr;
  gap: 1.5rem;
  align-items: start;
  padding-bottom: 1.2rem;
}

.requirements-dl__row:last-child{
  border-bottom: none;
  padding-bottom: 0;
}

.requirements-dl__dt{
    font-size: max(1rem, 14px);
  font-weight: 600;
}

.requirements-dl__dd{
    font-size: max(1rem, 14px);
    font-weight: 400;
    line-height: 2;
    color: #666666;
    position: relative;
    top: -0.2rem;
}

.requirements-dl__dd br{
  display: block;
  margin-top: 0.45rem;
}

@media (max-width: 767.8px){
.requirements-card__inner {
    padding: 3rem 2.25rem 4.5rem;
    padding-bottom: 0;
}
}

/* SP：1カラム */
@media (max-width: 575.8px){
.requirements-card__inner {
    padding: 1.8rem 1.5rem 1.5rem;
}
  .requirements-card__title{
    margin-bottom: 1.25rem;
  }
  .requirements-dl__row{
    grid-template-columns: 1fr;
    padding-bottom: 1rem;
  }
  .requirements-card__more {
    width: 100%;
    margin-top: 0.8rem;
    padding-top: 1.1rem;
}
}

/* =========================
  Accordion body（アニメ + チラ見せ + ぼかし）
  - JSが max-height(px) を制御する前提
========================= */
.requirements-card__body{
  position: relative;
  overflow: hidden;
  transition:
    max-height 280ms ease,
    filter 200ms ease;
  will-change: max-height, filter;
}

/* 閉じ：チラ見せ + ぼかし */
.requirements-card__body.is-collapsed{
  max-height: var(--req-peek);
}

/* 開き：ぼかし解除（max-heightはJSがpx指定） */
.requirements-card__body.is-open{
  filter: blur(0);
}

/* フェード（閉じ時のみ） */
/*.requirements-card__body.is-collapsed::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 4.5rem;
  background: linear-gradient(
    to bottom,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,1) 100%
  );
  pointer-events: none;
}*/

/* 開いたらフェードも消す */
.requirements-card__body.is-open::after{
  content: none;
}

/* =========================
  VIEW MORE（中途×複数のみ）
  - 矢印SVG：指定（stroke #FD8B8B）
========================= */
.requirements-card__more{
    width: 100%;
    margin-top: 1.8rem;
    padding-top: 1.1rem;
    border: none;
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0rem 0rem 1.25rem 1.25rem;
    padding-bottom: 1rem;
    gap: 0.75rem;
    cursor: pointer;
    font-size: max(0.875rem, 12px);
    font-weight: 500;
    letter-spacing: 0;
    color: #FD8B8B;
    background: #ffffff;
    font-family: "Lexend Mega", sans-serif;
}

.requirements-card__moreIcon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* 閉：下向き / 開：上向き（縦矢印SVGの回転） */
.requirements-card__more .requirements-icon{
  display: block;
  transform: rotate(180deg);
  transition: transform 220ms ease;
}

.requirements-card__more[aria-expanded="true"] .requirements-icon{
  transform: rotate(0deg);
}

/* =========================
  Entry button
========================= */
.requirements-entry{
  display: flex;
  justify-content: center;
  margin-top: 4.5rem;
}

.requirements-entry__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;

  min-width: 18rem;
  padding: 1.05rem 2.25rem;
  border-radius: 999px;

  background: #ffffff;
  border: 1px solid rgba(102,102,102,0.35);

  color: rgba(102,102,102,0.75);
  text-decoration: none;

  font-size: max(0.875rem, 12px);
  font-weight: 600;
  letter-spacing: 0.12em;
}

@media (max-width: 575.8px){
  .requirements-entry{
    margin-top: 3.5rem;
  }
  .requirements-entry__btn{
    width: 100%;
    max-width: 22rem;
  }
}

/* =========================
  Empty
========================= */
.requirements-empty{
  text-align: center;
  color: rgba(102,102,102,0.70);
  font-size: max(1rem, 14px);
  font-weight: 500;
  padding: 2rem 0;
}





/* =======================================================
  Requirements Flow（採用の流れ：カード型）
  - PCもSPも flex
  - 背景色はここでは指定しない（ページ側で管理）
  - 矢印はSVG（base64）を background-image で表示
======================================================= */

.requirements-flow{
  margin-top: 2.5rem;
  padding-top: 2rem;
  padding-bottom: 4rem;
  border-top: 1px solid rgba(102,102,102,0.10);
}

.requirements-flow__heading{
  font-size: max(1rem, 14px);
  font-weight: 600;
  color: #666666;
  margin-bottom: 1.75rem;
}

/* -------------------------------------------------------
  List（flex）
  - PC: 折り返し（必要なら）
  - SP: 横スクロール
------------------------------------------------------- */
.requirements-flow__list{
  display: flex;
  flex-wrap:nowrap;
  gap: 2.4rem;
  align-items: stretch;

  /* 5以下でも左詰めで自然に並ぶ */
  justify-content: flex-start;
  min-width: 0;
}

/* Item（カード幅をコントロール）
   5列相当： (100% - gap*4) / 5 */
.requirements-flow__item{
  position: relative;
  min-width: 0;

  flex: 0 1 calc((100% - (1.25rem * 4)) / 5);
}

/* 画面が狭くて5列が厳しいときは自動で4→3→2に落とす */
@media (max-width: 1199.8px){
  .requirements-flow__item{
    flex-basis: calc((100% - (1.25rem * 3)) / 4);
  }
}
@media (max-width: 991.8px){
  .requirements-flow__item{
    flex-basis: calc((100% - (1.25rem * 2)) / 3);
  }
}
@media (max-width: 767.8px){
  .requirements-flow__item{
    flex-basis: auto; /* SPは後段で横スクロール用に固定幅 */
  }
}

/* -------------------------------------------------------
  Card
------------------------------------------------------- */
.requirements-flow__card{
    position: relative;
    height: 100%;
    padding: 1.25rem 1rem 1.4rem;
    border-radius: 1rem;
    background: #ffffff;
    text-align: center;
}

/* STEP番号 */
.requirements-flow__step{
    display: block;
    font-size: max(0.75rem, 11px);
    font-weight: 500;
    color: #FD8B8B;
    margin-bottom: 0.5rem;
    font-family: "Lexend Mega", sans-serif;
}

/* アイコン */
.requirements-flow__icon{
    width: 5rem;
    height: 5rem;
    margin: 0 auto 0.85rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.requirements-flow__img{
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
}

/* タイトル */
.requirements-flow__title{
  font-size: max(0.875rem, 12px);
  font-weight: 600;
  color: #666666;
  line-height: 1.4;
}

/* -------------------------------------------------------
  Arrow（最後以外に表示）
  ※折り返し時の「行末矢印」はCSSだけでは完全に消せません
------------------------------------------------------- */
.requirements-flow__item:not(:last-child) .requirements-flow__card::after{
  content: "";
  position: absolute;
  top: 50%;
  right: -1.9rem;
  transform: translateY(-50%);

  width: 1.4rem;
  height: 1.4rem;

  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2224%22%20height%3D%2213%22%20viewBox%3D%220%200%2024%2013%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%0A%3Cpath%20d%3D%22M16%200C16%200.689%2016.733%201.71786%2017.475%202.58143C18.429%203.69571%2019.569%204.66793%2020.876%205.40986C21.856%205.96607%2023.044%206.5%2024%206.5M24%206.5C23.044%206.5%2021.855%207.03393%2020.876%207.59014C19.569%208.333%2018.429%209.30521%2017.475%2010.4176C16.733%2011.2821%2016%2012.3129%2016%2013M24%206.5H0%22%20stroke%3D%22%23A4A4A4%22%2F%3E%0A%3C%2Fsvg%3E%0A');
}

/* -------------------------------------------------------
  SP：横スクロール
------------------------------------------------------- */
@media (max-width: 991.8px){
  .requirements-flow__list{
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 0.5rem;

    -webkit-overflow-scrolling: touch;
    scroll-padding-inline: 1rem;
  }

  .requirements-flow__item{
    flex: 0 0 10rem;
  }

}

/* Optional: スクロールバー軽く整える（任意） */
@media (max-width: 991.8px){
  .requirements-flow__list::-webkit-scrollbar{
    height: 6px;
  }
  .requirements-flow__list::-webkit-scrollbar-thumb{
    background: rgba(0,0,0,0.12);
    border-radius: 999px;
  }
}











.p-entry-form{
  --ef-text: #666666;
    --ef-muted: #A4A4A4;
    --ef-line: #A4A4A4;

  --ef-card-bg: rgb(255 255 255 / 70%);
  --ef-card-bd: rgb(255 255 255 / 70%);

  --ef-req-bg: #FD8B8B;

  max-width: 62.5rem;
  margin-inline: auto;
}

input.wpcf7-form-control.wpcf7-date.wpcf7-validates-as-required.wpcf7-validates-as-date.p-entry-form__input {
width: auto;
    padding-top: 0;
    padding-left: 0;
}

input:-webkit-autofill {
  box-shadow: 0 0 0 1000px rgb(254 243 240) inset;
}

.entry-form-btn.confrm {
    margin-top: 5rem;
}

.wpcf7 form .wpcf7-response-output{
	    border: none !important;
		    text-align: center;
}

.p-entry-form__lead{
    text-align: center;
    color: var(--ef-text);
    font-size: 1rem;
    line-height: 2;
    font-weight: 500;
    margin: 6.25rem 0 5rem;
    margin-top: 0;
}

.p-entry-form__card{
  background: var(--ef-card-bg);
  border: 1px solid var(--ef-card-bd);
  border-radius: 1.25rem;
  padding: 2.75rem 3.25rem;
}

.p-entry-form__row{
  display: grid;
  grid-template-columns: 13rem 1fr;
  gap: 2.75rem;
  align-items: start;
  padding: 1.25rem 0 2rem;
}

.p-entry-form__label{
  display: inline-flex;
  align-items: center;
  gap: 0.9rem;
  color: var(--ef-text);
  font-weight: 600;
  font-size:1rem;
  letter-spacing: 0.06em;
  line-height: 1.6;
}

.p-entry-form__req{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.15rem 0.6rem;
    border-radius: 999px;
    background: var(--ef-req-bg);
    color: #fff;
    font-size: max(0.625rem, 10px);
    font-weight: 600;
    letter-spacing: 0.06em;
}

.p-entry-form__field{ min-width: 0; }

.p-entry-form__field--split{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}

.p-entry-form__field--stack{
  display: grid;
  gap: 1.35rem;
}

.p-entry-form__grid2{
  display: grid;
  grid-template-columns: 1fr 1fr; /* 常に横並び */
  gap: 2rem;
}

.p-entry-form__split{ min-width: 0; }

/* 住所フル幅 */
.p-entry-form__split--wide{
  grid-column: 1 / -1;
}

.p-entry-form__sub{
  color: var(--ef-muted);
  font-size: max(0.75rem, 11px);
  font-weight: 600;
  letter-spacing: 0.08em;
  margin-bottom: 0.55rem;
  display: none;
}

/* underline inputs */
.p-entry-form input[type="text"],
.p-entry-form input[type="email"],
.p-entry-form input[type="tel"],
.p-entry-form input[type="date"],
.p-entry-form select{
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--ef-line);
  border-radius: 0;
  padding: 0.55rem 0.1rem 0.65rem;
  color: var(--ef-text);
  font-size: 1rem;
  line-height: 1.4;
  outline: none;
      padding-top: 0;
}

.p-entry-form textarea{
    width: 100%;
    min-height: 3.5rem;
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--ef-line);
    padding: 0.55rem 0.1rem 0.65rem;
    color: var(--ef-text);
    font-size: 1rem;
    line-height: 1.6;
    outline: none;
    resize: vertical;
    height: 5.5rem;
	    padding-top: 0;
}

.p-entry-form ::placeholder{
  color: rgba(102,102,102,0.42);
}

/* select caret (thin V) + placeholder */
.p-entry-form select{
  appearance: none;
  padding-right: 1.75rem;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(102,102,102,0.35) 50%),
    linear-gradient(135deg, rgba(102,102,102,0.35) 50%, transparent 50%);
  background-position:
    calc(100% - 0.95rem) 62%,
    calc(100% - 0.70rem) 62%;
  background-size: 0.28rem 0.28rem, 0.28rem 0.28rem;
  background-repeat: no-repeat;
  width: auto;
}

/* 「選択してください」や未入力を薄く（select* の先頭 value="" 前提） */
.p-entry-form select:invalid{
  color: rgba(102,102,102,0.42);
}

/* date 未入力を薄く */
.p-entry-form input[type="date"]:invalid{
  color: rgba(102,102,102,0.42);
}

/* focus */
.p-entry-form input:focus,
.p-entry-form select:focus,
.p-entry-form textarea:focus{
  border-bottom-color: rgba(102,102,102,0.65);
}

/* radios */
.p-entry-form .wpcf7-list-item{ margin: 0 !important; }
.p-entry-form .wpcf7-form-control.wpcf7-radio{
  display: inline-flex;
  align-items: center;
  gap: 2.5rem;
  flex-wrap: wrap;
}
.p-entry-form .wpcf7-radio label{
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  cursor: pointer;
}
.p-entry-form input[type="radio"]{
    accent-color: rgba(102, 102, 102, 0.75);
    width: 1rem;
    height: 1rem;
    position: relative;
    top: 0.1rem;
}

/* agree */
.p-entry-form__agree{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.6rem;
  margin: 1.85rem 0 1.35rem;
  color: var(--ef-text);
  font-size: max(0.875rem, 12px);
  font-weight: 600;
  letter-spacing: 0.04em;
}
.p-entry-form__agree a {
    color: #2797FF;
    text-decoration: underline;
    text-underline-offset: 0.25em;
    display: inline-block;
}

span.wpcf7-form-control.wpcf7-acceptance span label {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.6rem;
    margin: 1.85rem 0 1.35rem;
    color: var(--ef-text);
    font-size: max(0.875rem, 12px);
    font-weight: 600;
    letter-spacing: 0.04em;
}

/* actions */
.p-entry-form__actions{
  display: flex;
  justify-content: center;
}
.p-entry-form__submit,
.p-entry-form .wpcf7-submit{
  min-width: 22rem;
}

/* back link */
.p-entry-form__back{
  text-align: center;
  margin-top: 1rem;
  font-size: max(0.875rem, 12px);
  font-weight: 600;
  letter-spacing: 0.04em;
}
.p-entry-form__back a {
color: #666666;
    text-decoration: underline;
    font-weight: 500;
    margin-top: 1.5rem;
    display: inline-block;
}

.p-entry-form__back a:hover{
	text-decoration: none;
	opacity: 0.8;
}

/* confirm value (optional: make it look like text, not input) */
.p-entry-form__value{
  display: block;
  padding: 0.55rem 0.1rem 0.65rem;
  border-bottom: 1px solid rgba(102,102,102,0.22);
  color: var(--ef-text);
  font-size: max(1rem, 16px);
}
.p-entry-form__value--textarea{
  white-space: pre-wrap;
}



/* responsive */
@media (max-width: 767.8px){
  .p-entry-form{ padding-inline: 1.25rem; }
  .p-entry-form__card{
    padding: 1.75rem 1.35rem;
    border-radius: 1rem;
  }
  .p-entry-form__row{
    grid-template-columns: 1fr;
    gap: 0.85rem;
    padding: 1.15rem 0;
  }
  .p-entry-form__field--split{
    grid-template-columns: 1fr;
    gap: 1.1rem;
  }

  /* 郵便番号＋都道府県はSPでも横並び維持 */
  .p-entry-form__grid2{
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }

  .p-entry-form .wpcf7-form-control.wpcf7-radio{ gap: 1.6rem; }
  .p-entry-form__submit,
  .p-entry-form .wpcf7-submit{
    min-width: 18rem;
  }
}


/* =======================================================
  Entry Form Button Wrapper (final)
  - works with your current markup
  - default: arrow moves to right on hover
  - add .is-arrow-left to move left
======================================================= */

.entry-form-btn{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.25rem;
    max-width: 22rem;
    margin: 0 auto;
    padding: 1.05rem 2.25rem;
    border-radius: 999px;
    background: #ffffff;
    color: #A4A4A4;
    border: 1px solid #A4A4A4;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0;
  font-family: "Lexend Mega", sans-serif;

  transition: color 220ms ease, border-color 220ms ease;

  position: relative;
}

.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output {
    border-color: #FD8B8B !important;
}

/* クリック面（inputを全面に敷く） */
.entry-form-btn > input.wpcf7-submit{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;

  appearance: none;
  background: transparent;
  border: none;

  /* 文字はspan側で出すので透明 */
  color: transparent;

  cursor: pointer;
}

/* スピナーは右側に置く（必要なら） */
.entry-form-btn > .wpcf7-spinner {
    margin-left: 0.25rem;
    position: absolute;
    display: none;
}

/* テキスト・矢印はクリックの邪魔をしない */
.entry-form-btn .footer-cta__text,
.entry-form-btn .footer-cta__icon{
  pointer-events: none;
}

/* 矢印（あなたの class に合わせて c-arrow-btn__icon を対象にする） */
.entry-form-btn .c-arrow-btn__icon{
  transform: translateX(0);
  transition: transform 240ms ease;
  will-change: transform;
}

/* hover: 色 */
@media (hover:hover){
  .entry-form-btn:hover{
    color: var(--cta-accent);
    border-color: var(--cta-accent);
  }

  /* default（=右へ） */
  .entry-form-btn:hover .c-arrow-btn__icon{
    transform: translateX(0.25rem);
  }

  /* 左にしたい場合：.is-arrow-left を wrapper に付ける */
  .entry-form-btn.is-arrow-left:hover .c-arrow-btn__icon{
    transform: translateX(-0.25rem);
  }
}

/* disabled（inputがdisabledなら見た目も止める） */
.entry-form-btn:has(input.wpcf7-submit:disabled){
  opacity: 0.55;
}
.entry-form-btn:has(input.wpcf7-submit:disabled) input.wpcf7-submit{
  cursor: not-allowed;
}
@media (hover:hover){
  .entry-form-btn:has(input.wpcf7-submit:disabled):hover{
    color: #A4A4A4;
    border-color: #A4A4A4;
  }
  .entry-form-btn:has(input.wpcf7-submit:disabled):hover .c-arrow-btn__icon{
    transform: translateX(0);
  }
}

/* focus */
.entry-form-btn:has(input.wpcf7-submit:focus-visible){
  outline: 2px solid rgba(164,164,164,0.45);
  outline-offset: 3px;
}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  .entry-form-btn .c-arrow-btn__icon{
    transition: none;
  }
}












/* =======================================================
  Work Environment : Intro
  - background : not set
  - border     : #666666
======================================================= */

.we-intro{

}

/* 中央コピー（3行） */
.we-intro__lead{
  max-width: 56rem;
  margin: 0 auto;
  text-align: center;

  color: #666666;
  font-size: max(1.125rem, 12px);
  font-weight: 500;
  line-height: 2.05;
  letter-spacing: 0.04em;
}

/* チップ群（中央揃え） */
.we-intro__chips{
  display: flex;
  justify-content: center;
  gap: 1.25rem;
  margin-top: 4.5rem;
  flex-wrap: wrap;
}

/* チップ本体 */
.we-chip{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.9rem;
    min-width: 12.75rem;
    padding: 1.0625rem 1.35rem;
    border-radius: 999px;
    border: 1px solid #666666;
    background: transparent;
    color: #666666;
    text-decoration: none;
    font-size: 1rem;
    font-weight: 500;

  transition:
    color 220ms ease,
    border-color 220ms ease;
}

/* テキスト */
.we-chip__text{
  line-height: 1;
}

/* 下矢印（SVG） */
.we-chip__icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;

  transform: translateY(0);
  transition: transform 240ms cubic-bezier(.2,.8,.2,1);
  will-change: transform;
}

/* SVGサイズ固定 */
.we-chip__svg{
  display: block;
  width: 0.5625rem; /* 9px */
  height: 0.875rem; /* 14px */
}

/* hover（PCのみ）：色追従＋下へスッ */
@media (hover:hover){
  .we-chip:hover{
    color: var(--cta-accent);
    border-color: var(--cta-accent);
  }

  .we-chip:hover .we-chip__icon{
    transform: translateY(0.25rem);
  }
}

/* フォーカス（キーボード操作） */
.we-chip:focus-visible{
  outline: 2px solid rgba(102,102,102,0.4);
  outline-offset: 4px;
}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  .we-chip__icon{
    transition: none;
  }
}

/* SP調整 */
@media (max-width: 578.8px){


  .we-intro__chips{
	          gap: 2rem;
  }

  .we-chip{
        width: 100%;
        padding: 0.9rem 1.15rem;
  }
}









/* =======================================================
  Work Environment : Training Section
  - background : not set
  - border     : #666666
======================================================= */

.we-training .section__container {
    padding-top: 0;
}

.we-training{
  padding: 0;
  color: #666666;
}

/* ===== タイトル ===== */
.we-training__title{
    font-size: max(2rem, 24px);
    font-weight: 600;
    margin: 0 0 0.5rem;
}

/* 下線（点線） */
.we-training__line{
  width: 100%;
  height: 1px;
  border-bottom: 1px dotted #666666;
    margin-bottom: 2.2rem;
}

/* サブ見出し */
.we-training__subttl{
    font-size: max(1.5rem, 20px);
    font-weight: 500;
    margin: 0 0 1rem;
}

.we-training__subttl--mt{
  margin-top: 3rem;
}

/* =======================================================
  上段：横長カード（3枚・縦並び）
======================================================= */

.we-training__list{
  display: grid;
  gap: 1.25rem;
}

.we-trainingWide{
    display: grid;
    grid-template-columns: 26.875rem 1fr;
    gap: 3rem;
    align-items: center;
    padding: 1.5rem;
    border: 0;
    border-radius: 1.25rem;
    background: #ffffff;
}

/* 画像 */
.we-trainingWide__img{
    border-radius: 1.25rem;
    overflow: hidden;
    aspect-ratio: 430 / 220;
}

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

/* テキスト */
.we-trainingWide__ttl{
    font-size: max(1.5rem, 20px);
    font-weight: 500;
    margin: 0 0 0.9rem;
}

.we-trainingWide__txt{
    font-size: 1rem;
    line-height: 1.8;
    font-weight: 400;
    margin: 0;
	    max-width: 41rem;
}

/* =======================================================
  下段：3×2 グリッドカード
======================================================= */

.we-training__grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
}

.we-trainingMini{
border-radius: 1.25rem;
    overflow: hidden;
    background: #ffffff;
	    padding: 1.5rem;
}

/* 画像 */
.we-trainingMini__img{
    aspect-ratio: 319 / 220;
  overflow: hidden;
      margin-bottom: 0rem;
}

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

/* 本文 */


.we-trainingMini__ttl{
    font-size: max(1.125rem, 14px);
    font-weight: 600;
    line-height: 1.5;
    margin-bottom: 1rem;
}

.we-trainingMini__txt{
font-size: 1rem;
    line-height: 1.8;
    font-weight: 400;
    margin: 0;
}

/* =======================================================
  Responsive
======================================================= */

/* Tablet */
@media (max-width: 991.8px){
  .we-trainingWide{
    grid-template-columns: 14rem 1fr;
	        gap: 2rem;
  }

  .we-training__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767.8px){
  .we-training__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .we-trainingMini__img {
    aspect-ratio: 319 / 140;
}
.we-trainingWide__img {
    aspect-ratio: 430 / 360;
}
}

/* SP */
@media (max-width: 567.8px){

  .we-trainingWide{
    grid-template-columns: 1fr;
    gap: 1.1rem;
  }

  .we-trainingMini__img{
    aspect-ratio: 319 / 220;
}

.we-trainingWide__img {
    aspect-ratio: 430 / 220;
}

  .we-training__grid{
    grid-template-columns: 1fr;
  }

  .we-training__subttl--mt{
    margin-top: 2.25rem;
  }
}








/* =======================================================
  Work Environment : Numbers Section
  - background : not set
  - border     : #666666
  - h2/line    : we-training__title / we-training__line を流用
======================================================= */

.we-numbers .section__container{
  padding-top: 0;
}

.we-numbers{
  padding: 0;
  color: #666666;
}

/* lead text */
.we-numbers__lead{
  margin: 0 0 2.25rem;
}

.we-numbers__lead p{
  margin: 0;
  font-size: 1rem;
  line-height: 1.8;
  font-weight: 400;
}

.we-numbers__lead p + p{
  margin-top: 0.75rem;
}

/* =======================================================
  Grid : 3 cols x 2 rows (lines, not cards)
======================================================= */

.we-numbers__grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border-left: 1px solid #666666;
}

/* cell */
.we-num{
  padding: 2.25rem 1.5rem 2.25rem;
      padding-top: 0.2rem;
    padding-bottom: 0.5rem;
  border-right: 1px solid #666666;

  display: grid;
  grid-template-rows: auto 1fr auto auto;
  align-content: start;
}

.we-numbers__grid {
    margin-top: 4rem;
}

/* title (top left) */
.we-num__ttl{
  margin: 0 0 1.75rem;
  font-size: max(1.5rem, 20px);
  font-weight: 600;
  text-align: center;
}

.we-num__ttl span.sml {
    display: block;
    font-size: max(1rem, 14px);
}

/* icon */
.we-num__icon{
  height: 5.5rem;
  display: grid;
  place-items: center;
    margin-bottom: 2.25rem;
    margin-top: 1.5rem;
}

/* value */
.we-num__val{
    margin: 0 0 1.25rem;
    text-align: center;
    font-family: "Lexend Mega", sans-serif;
    font-size: clamp(2.5rem, 1.75vw, 2.5rem);
    font-weight: 500;
    letter-spacing: 0;
    line-height: 1.05;
}

.we-num__unit{
  font-family: inherit;
    font-size: max(1.125rem, 16px);
    margin-left: 0.125rem;
}

span.we-num__unit.f-noto {
    font-family: "Noto Sans JP", sans-serif;
}

/* description */
.we-num__desc{
  margin: 0;
  text-align: center;
  font-size: 1rem;
  line-height: 1.8;
  font-weight: 400;
}

/* pair layout (45% / 55%) */
.we-num__val--pair{
  display: flex;
  justify-content: center;
  gap: 2.25rem;
  align-items: flex-end;
}

.we-num__pair{
  display: grid;
    justify-items: baseline;
}

.we-num__pairLabel{
    font-size: 1rem;
    font-weight: 500;
}

.we-num__pairVal{
  font-family: "Lexend Mega", sans-serif;
    font-size: clamp(2.5rem, 1.75vw, 2.5rem);
  font-weight: 500;
  line-height: 1.05;
}

/* =======================================================
  Responsive
======================================================= */

@media (max-width: 1199.8px){
  .we-numbers__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .we-num {
    padding: 2.25rem 1.2rem 2.25rem;
}
.we-num__pairVal,.we-num__val {
    font-size: clamp(3.125rem, 2.75vw, 3.5rem);
}
}

@media (max-width: 567.8px){
  .we-numbers__grid{
    grid-template-columns: 1fr;
  }

  .we-num{
    padding: 2rem 1.5rem;
  }

  .we-num__ttl{
    margin-bottom: 2.25rem;
  }

  .we-num__icon{
    height: 4.5rem;
  }

  .we-num__val{
    font-size: max(3rem, 40px);
	        margin-top: 1rem;
  }

  .we-num__val--pair{
    gap: 1.5rem;
  }
}













/* =======================================================
  Work Environment : Benefits Section
  - background : not set
  - border     : #666666
  - h2/line    : we-training__title / we-training__line を流用
======================================================= */

.we-benefits .section__container{
  padding-top: 0;
}

.we-benefits{
  padding: 0;
  color: #666666;
}

/* lead */
.we-benefits__lead{
  margin: 0 0 3.25rem;
}

.we-benefits__lead p{
  margin: 0;
  font-size: 1rem;
  line-height: 1.8;
  font-weight: 400;
}

.we-benefits__lead p + p{
  margin-top: 0.75rem;
}

/* white rounded box */
.we-benefits__box{
    background: rgb(255 255 255 / 70%);
    border: 1px solid #ffffff;
  border-radius: 1.25rem;
  overflow: hidden; /* 罫線が角丸からはみ出さない */
      padding-top: 2.7rem;
    padding-bottom: 2.7rem;
}

/* dl reset */
.we-benefits__list{
  margin: 0;
  padding: 0;
}

/* row as two columns */
.we-benefits__row {
    display: grid;
    grid-template-columns: 18rem 1fr;
    gap: 2.5rem;
    padding: 1.65rem 0rem;
    margin: 1.65rem 3rem;
    margin-bottom: 0;
    padding-bottom: 0;
}

.we-benefits__row:first-of-type{
    margin-top: 0;
    padding-top: 0;
}

.we-benefits__row:last-of-type{
	    margin-bottom: 0;
    padding-bottom: 0;
}

/* horizontal dividers */
.we-benefits__row + .we-benefits__row{
  border-top: 1px solid #A4A4A4;
}

/* dt / dd */
.we-benefits__dt{
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.7;
}

.we-benefits__dd{
  margin: 0;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.8;
}

/* =======================================================
  Responsive
======================================================= */

@media (max-width: 991.8px){
  .we-benefits__row{
    grid-template-columns: 14rem 1fr;
    gap: 2rem;
  }
}

@media (max-width: 567.8px){
  .we-benefits__row{
    grid-template-columns: 1fr;
    gap: 0.75rem;
        padding: 1.35rem 0.25rem;
        margin: 1.35rem 2rem;
  }
}



section#facility .section__container {
    padding-top: 0;
	padding-bottom: 0;
}

.we-facility-slide {
    /* padding-top: 0rem; */
    /* margin-top: 4rem; */
    /* margin-bottom: 10rem; */
}

.requirements-entry.btm {
    padding-bottom: 7rem;
}


/* =======================================================
  Common Splide Slider (reusable)
======================================================= */

.common-splide{
  margin-top: 2.25rem;
}

.common-splide__track{
  overflow: visible; /* 端の見切れを出す */
}

.common-splide__slide{
  width: 21rem; /* 画像の見た目に近い幅。必要なら調整 */
}

.menber-single__more .common-splide__slide{ width: 22rem; }

.common-splide__frame{
  border-radius: 1.5rem;
  overflow: hidden;
}

.common-splide__img{
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.we-facility-slide .common-splide__img{
	  aspect-ratio: 306 / 325;
}


@media (max-width: 991.8px){
  .common-splide__slide{ width: 18rem; }
}
@media (max-width: 767.8px){
  .common-splide__slide{ width: 15.5rem; }
  .common-splide{ margin-top: 1.75rem; }
}
@media (max-width: 567.8px){
  .common-splide__slide{ width: 13.5rem; }
  .menber-single__more .common-splide__slide{ width: 22rem; }
}











/* =======================================================
  Header (fixed + responsive drawer)
======================================================= */

.site-header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: transparent; /* 背景はページ側で */
}

.site-header__inner{
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 2rem;
  margin-inline: auto;
  padding: 1.25rem 2.5rem;
}

/* ===== Brand ===== */
.site-header__brand{
  display: grid;
  gap: 0.35rem;
  text-decoration: none;
  color: #666666;
  position: relative;
    z-index: 9999;
}

.site-header__logo{
  font-weight: 700;
  line-height: 1;
}

.site-header__brandSub{
    font-size: max(0.625rem, 10px);
    font-weight: 400;
    letter-spacing: 0.1em;
    text-align: center;
    color: #ffffff;
    font-family: "Lexend Mega", sans-serif;
}

/* ===== Center nav pill (PC) ===== */
.site-header__nav{
  display: flex;
  justify-content: center;
}

.site-header__navList{
  display: inline-flex;
  align-items: center;
  justify-content: center;
    gap: 3.1rem;
    /*padding: 0.95rem 2.1rem;*/
	 padding: 0.65rem 2.1rem;
  border-radius: 999px;

  background: rgba(255,255,255,0.35);
  backdrop-filter: blur(10px);
}



.site-header__navLink{
  text-decoration: none;
  font-family: "Lexend Mega", sans-serif;

  color: #ffffff; /* 初期は白 */
  transition: color 220ms ease;
      font-size: max(0.875rem, 12px);
    font-weight: 500;
    letter-spacing: -0.07em;
    text-decoration: none;
	text-align: center;
}

.site-header__navLink span.sml {
    display: block;
    font-size: max(0.75rem, 10px);
    letter-spacing: 0.05em;
	    margin-top: -0.1rem;
}

/* scroll後：中央メニュー文字色だけ変更 */
.site-header.is-scrolled .site-header__navLink{
  color: rgba(102,102,102,0.75);
}

/* ===== Right area ===== */
.site-header__right{
  display: inline-flex;
  align-items: center;
  gap: 1rem;
      position: relative;
    z-index: 9999;
	    margin-left: auto;
}

/* PC ENTRY（フッターbtn流用） */
.site-header__entry{
  display: inline-flex;
}

/* ヘッダー内でだけ、フッターボタンのサイズ微調整（必要なら） */
.site-header__entry.footer-cta__btn{
    min-width: 0;
    display: inline-flex;
    align-items: center;
    gap: 1.1rem;
    padding: 0.67529rem 2.2rem;
    border-radius: 999px;
    text-decoration: none;
    font-size: max(0.875rem, 12px);
    font-weight: 500;
}

/* ===== Hamburger ===== */
.site-header__toggle{
  display: none; /* SPで表示 */
  appearance: none;
  border: 0;
  background: transparent;
  padding: 0.5rem;
  cursor: pointer;
}

.site-header__toggleLines{
  width: 2.25rem;
  height: 1.5rem;
  display: grid;
  align-content: space-between;
}

.site-header__line{
  height: 2px;
  width: 100%;
  border-radius: 999px;

  background: #ffffff;
  transition:
    transform 240ms cubic-bezier(.2,.8,.2,1),
    opacity 240ms cubic-bezier(.2,.8,.2,1),
    background-color 240ms ease;
}

/* scroll後：ハンバーガー色（任意） */
.site-header.is-scrolled .site-header__line{
  background: #a4a4a4;
}

/* open -> X */
.site-header.is-open .site-header__line:nth-child(1){
  transform: translateY(0.62rem) rotate(45deg);
      background: #a4a4a4;
}
.site-header.is-open .site-header__line:nth-child(2){
  opacity: 0;
}
.site-header.is-open .site-header__line:nth-child(3){
  transform: translateY(-0.8rem) rotate(-45deg);
      background: #a4a4a4;
}

/* ===== Drawer default (PC/Tablet: dropdown) ===== */
.site-drawer{
  max-height: 0;
  overflow: hidden;

  opacity: 0;
  pointer-events: none;

  transition:
    max-height 320ms cubic-bezier(.2,.8,.2,1),
    opacity 220ms ease;
}

.site-header.is-open .site-drawer{
  opacity: 1;
  pointer-events: auto;
}

.site-drawer__inner{
  max-width: 78rem;
  margin-inline: auto;
  padding: 1.5rem 2.5rem 2rem;

  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(12px);
  border-radius: 1.25rem;
}

.site-drawer__nav{
  display: grid;
    justify-items: baseline;
  gap: 0.9rem;
  margin-bottom: 1.25rem;
}

.site-drawer__link{
  text-decoration: none;
  font-family: "Lexend Mega", sans-serif;
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: 0;
  color: rgba(102,102,102,0.85);
}

.site-drawer__cta{
  display: flex;
  justify-content: center;
}

/* ===== Focus visible ===== */
.site-header__toggle:focus-visible,
.site-drawer__link:focus-visible,
.site-header__navLink:focus-visible,
.site-header__entry:focus-visible{
  outline: 2px solid rgba(102,102,102,0.35);
  outline-offset: 4px;
}

/* =======================================================
  Responsive
======================================================= */

@media (max-width: 991.8px){
  .site-header__inner{
    gap: 0.5rem;
    padding: 1.05rem 1.25rem;
  }

  .site-header__navList{
        gap: 0.5rem;
		    padding: 0.65rem 1.5rem;
  }

  .site-header__navLink{
    font-size: 0.875rem;
  }

  .site-header__entry.footer-cta__btn{
    padding: 0.8rem 1.35rem;
  }
}

/* =======================================================
  SP: fullscreen overlay drawer
======================================================= */
@media (max-width: 767.8px){
  /* SP：中央ピル非表示、右はハンバーガーのみ */
  .site-header__nav{ display: none; }

  .site-header__entry.footer-cta__btn{ display: none; }
  .site-header__toggle{ display: inline-flex; }

  /* SP: drawer fullscreen overlay */
  .site-drawer{
    position: fixed;
    inset: 0;
    z-index: 999; /* headerより上 */

    max-height: none; /* JSのmax-height制御は使わない */
    height: 100vh;
    overflow: auto;

    background: rgba(255,255,255,0.75);
    backdrop-filter: blur(12px);

    opacity: 0;
    pointer-events: none;

    transition: opacity 220ms ease;
  }

  .site-drawer__link span.sml {
    display: block;
    font-size:max(0.875rem, 12px);
    letter-spacing: 0.1em;
	    margin-top: -0.1rem;
}

  .site-header.is-open .site-drawer{
    opacity: 1;
    pointer-events: auto;
  }

  /* SP: drawer inner */
  .site-drawer__inner{
    max-width: none;
    height: 100%;
    margin: 0;
    padding: 7.5rem 1.25rem 2rem; /* 上はヘッダー分余白 */

    background: transparent;
    border-radius: 0;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
  }

  .site-drawer__nav{
    gap: 1.25rem;
    margin-bottom: 2rem;
  }

  .site-drawer__link{
    font-size: 1.2rem;
  }

  /* drawer内のENTRY */
  .site-drawer__cta .footer-cta__btn{
    min-width: 18rem;
  }
}












/* =======================================================
  TOP MV
======================================================= */

.top-mv{
  position: relative;
  /*min-height: 100vh;*/
height: 56.25rem;
  display: grid;
  place-items: center;

  background: linear-gradient(to bottom, #ffc1b3 0%, #FAD6CD 40%, #FBE1D9 70%, #fff6e8 100%);
  /*    background: linear-gradient(to bottom, #F9CFC6 0%, #FAD6CD 40%, #FBE1D9 70%, #fff6e8 100%);*/
  background-size: 100% 260%;
  background-position: 50% 0%;
  animation: mv-gradient 12s ease-in-out infinite;

  overflow: hidden;
}

@keyframes mv-gradient{
  0%   { background-position: 50% 0%; }
  50%  { background-position: 50% 100%; }
  100% { background-position: 50% 0%; }
}

@media (prefers-reduced-motion: reduce){
  .top-mv{ animation: none; }
}

.top-mv__inner{
    text-align: center;
    color: #666666;
    position: relative;
    z-index: 2;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
}

.top-mv__title{
    margin: 0;
    font-family: "Lexend Mega", sans-serif;
    font-weight: 500;
    /* letter-spacing: 0.08em; */
    line-height: 1.45;
    font-size: clamp(2.75rem, 3vw, 3.5rem);
}

.top-mv__line{
  display: block;
}

.top-mv__sub{
    margin: 1.35rem 0 0;
    font-size: max(1.3125rem, 16px);
    font-weight: 400;
}

/* pill（枠のみ） */
.top-mv__pill{
/*    display: inline-block;
    padding: 0em 0.5em;
    border-radius: 999px;
    border: 1px solid #ffffff;
    color: #666666;
    background: rgba(255, 255, 255, 0.35);
    backdrop-filter: blur(10px);*/
    display: inline-block;
    padding: 0;
    color: #F85656;
}

.top-mv__pill--sm {
/*    padding: 0em 0.6em;*/
    padding: 0;
    font-weight: 500;
}

/* =======================================================
  Common Splide Marquee (Reusable)
======================================================= */

.common-marquee{
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1.42em; /* 見切れ */
  z-index: 1;

  pointer-events: none;
  user-select: none;
}

.common-marquee .splide__track{
  overflow: visible; /* 端見切れ */
}

.common-marquee__slide{
  width: auto;
}

section.top-auto-slide{
	    position: relative;

    overflow: hidden;
	    margin-top: -10rem;
}

.common-marquee__text{
  display: inline-block;
  white-space: nowrap;

  font-family: "Lexend Mega", sans-serif;
  letter-spacing: 0;
  line-height: 1;
    font-weight: 600;
    line-height: 1;
	  font-size: clamp(4rem, 11vw, 11rem);
    letter-spacing: 0em;
    /*background: linear-gradient(to right, #AB6262F 0%, #FFBFBF 70%, #FF9F9F 85%, #FF6F6F 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;*/
    color: #AB6262;
	opacity: 0.2;
}

div#mv-marquee {
    position: absolute;
}

/* MVでの微調整（必要なら） */
.top-mv__marquee{
  --mv-gap: 5rem;
}
.top-mv__marquee .splide__list{
 /* gap: var(--mv-gap);*/
}







/* =======================================================
  TOP Sec02 (left text + right glass cards)
  - arrow: transform 240ms ease
  - card: no translate (do not move)
======================================================= */

.top-sec02{
  position: relative;
  overflow: hidden;
  color: #fff;
}

.top-sec02__bg{
  position: absolute;
  inset: 0;
  z-index: 0;
}

.top-sec02__bgImg{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* dark overlay */
.top-sec02::before{
	/*
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: rgba(0,0,0,0.42);*/
}

.top-sec02__inner{
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: 3rem;
}

.top-sec02 .section__container {
    padding: 11.5rem 2.5rem;
}

/* left */
.top-sec02__title{
    margin: 0 0 1.75rem;
    font-size: max(2rem, 24px);
    font-weight: 600;
    line-height: 1.875;
}

.top-sec02__text p{
    margin: 0;
    color: #ffffff;
    font-size: max(1.125rem, 14px);
    font-weight: 500;
    line-height: 2;
}

.top-sec02__text p + p{
  margin-top: 1rem;
}

/* right cards */
.top-sec02__right{
  display: grid;
  gap: 2rem;
}

/* glass card */
.top-sec02__card{
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 1.5rem;
    padding: 2.25rem 2.25rem;
    border-radius: 1.5rem;
    text-decoration: none;
    color: #a4a4a4;
    background: rgba(255, 255, 255, 0.72);
    backdrop-filter: blur(10px);
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(10px);
    border: 2px solid #ffffff;
}

/* texts */
.top-sec02__cardBody{
  display: grid;
  gap: 0.45rem;
}

.top-sec02__cardEn{
    font-weight: 500;
    letter-spacing: 0em;
    font-family: "Lexend Mega", sans-serif;
    font-size: max(2rem, 20px);
    background: linear-gradient(to right, #FFBFBF 0%, #FFBFBF 70%, #FF9F9F 85%, #FF6F6F 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.top-sec02__cardJa{
  margin: 0;
  font-size: max(0.875rem, 12px);
  font-weight: 600;
  letter-spacing: 0.08em;
  color: rgba(102,102,102,0.6);
}

/* arrow */
.top-sec02__arrow{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 2.75rem;
  height: 2.75rem;

  color: rgba(102,102,102,0.55);
  transform: translateX(0);

  /* 指定どおり */
  transition: transform 240ms ease, color 220ms ease;
}

.top-sec02__arrow .icon{
  display: block;
}

/* hover: arrow only (no card movement) */
@media (hover:hover){
  .top-sec02__card:hover .top-sec02__arrow{
    transform: translateX(0.25rem);
    color: rgba(102,102,102,0.8);
  }
}

/* responsive */
@media (max-width: 991.8px){
  .top-sec02__inner{
    grid-template-columns: 1fr;
    gap: 2.5rem;
    padding: 4.25rem 0;
  }

  .top-sec02__right{
    gap: 1.5rem;
  }

  .top-sec02__card{
    padding: 2rem 1.75rem;
  }
}

@media (max-width: 567.8px){
  .top-sec02__inner{

  }

  .top-sec02__card{
    padding: 1.65rem 1.35rem;
    border-radius: 1.25rem;
  }

  .top-sec02__cardEn{
    font-size: max(1.75rem, 22px);
  }

  .top-sec02__arrow{
    width: 2.35rem;
    height: 2.35rem;
  }
}







/* =========================
   TOP: Our People (sec03) - Scale Active
   ========================= */

   section.section.top-people {
    background: linear-gradient(to bottom, #F9CFC6 0%, #FAD6CD 40%, #FBE1D9 70%, #fff6e8 100%);
}

.top-people__sliderWrap { position: relative; 
padding-bottom: 9rem;
}

/* Splide本体はコンテナ基準（100vw固定はしない） */
.top-people .js-people-splide {
  width: 100%;
  margin-inline: auto;
}

/* 見切れはSplide側のpaddingで作る想定なので通常はhidden */
.top-people .splide__track {
  overflow: hidden;
}

/* =========================
   中央だけ拡大（参考実装の考え方）
   - “slide”ではなく “中身（カード）”を変形させる
   - Splideの位置計算を壊しにくい
   ========================= */

/* 左右：薄く小さく（参考は img に適用） :contentReference[oaicite:2]{index=2} */
.top-people .splide__slide .menber-card--people {
  opacity: .3;
  transform: scale(.92);
  transition: .7s; /* ゆっくり */
}

/* 中央：通常表示（参考は is-active img を戻す） :contentReference[oaicite:3]{index=3} */
.top-people .splide__slide.is-active .menber-card--people {
  opacity: 1;
  transform: scale(1);
  z-index: 1;
}

/* ---- card base ---- */



.top-people .menber-card--people .menber-card__media { position: relative; }



/* ---- arrows（白・右反転） ---- */
.top-people__nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
    width: 3.375rem;
    height: 1.2rem;
  display: grid;
  place-items: center;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  z-index: 3;
  opacity: 0.95;
  transition: transform 240ms ease, opacity 240ms ease;
}
.top-people__nav--prev { left: 2rem; }
.top-people__nav--next { right: 2rem; }
.top-people__nav--prev:hover { transform: translateY(-50%) translateX(-0.15rem); opacity: 1; }
.top-people__nav--next:hover { transform: translateY(-50%) translateX(0.15rem);  opacity: 1; }

.top-people__navIcon{
  display: block;
    width: 3.375rem;
    height: 1.2rem;
  color: #FF6F6F; /* currentColor */
}
.top-people__nav--next .top-people__navIcon { transform: scaleX(-1); }



@media (max-width: 991.98px){
  .top-people__nav--prev { left: 30%; }
  .top-people__nav--next { right: 30%; }
}

@media (max-width: 575.8px){
  .top-people__nav{
    top: auto;
    bottom: 9.8rem;
    transform: none;
  }
  .top-people__nav--prev:hover,
  .top-people__nav--next:hover{
    transform: translateX(0);
  }
  .top-people__nav--prev { left: 1.2rem; }
  .top-people__nav--next { right: 1.2rem; }
}









/* =========================
   TOP sec04: Environment
   ========================= */

.top-env{
  position: relative;
  overflow: hidden;
  color: #fff;

  /* PHPの inline style で background-image を入れる前提 */
  background-color: #222; /* 画像が無い時の保険 */
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

/* 可読性オーバーレイ */
/*.top-env::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.30) 0%,
    rgba(0,0,0,0.30) 45%,
    rgba(0,0,0,0.18) 100%
  );
  z-index:0;
  pointer-events:none;
}*/

.top-env .section__inner{
  position: relative;
  z-index: 1;
  text-align: center;
}

.top-env__content{
  max-width: 88rem;
  margin-inline: auto;
}

/* 見出し */
.top-env__en{
  font-size: clamp(3.2rem, 5vw, 6rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.05;
  color: rgba(255, 180, 190, 0.9);
}

.top-env__jp{
    font-weight: 500;
    font-size: max(0.875rem, 12px);
    margin-top: 0.6rem;
}

/* 本文 */
.top-env__lead{
margin-top: 3rem;
    max-width: 70rem;
    margin-inline: auto;
    color: #ffffff;
    font-size: max(1rem, 14px);
    font-weight: 500;
    line-height: 2;
}

.top-env__lead p + p{ margin-top: 1.1rem; }

/* =========================
   VIEW MORE（専用UI）
   ========================= */

.top-env__more{
  margin-top: 3.5rem;
  display: inline-flex;
  align-items: center;
  gap: 1.4rem;
  text-decoration: none;
  color: rgba(255,255,255,0.92);
}

/* テキスト側：下線（一切アニメーションしない） */
.top-env__moreText{
  position: relative;
  font-weight: 800;
  letter-spacing: 0.12em;
  font-size: max(1.2rem, 14px);
  padding-bottom: .6rem;
}
.top-env__moreText::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:2px;
  background: rgba(255,255,255,0.45);
}

/* 右のピル：完全に固定（動かさない） */
.top-env__morePill{
  width: 5.4rem;
  height: 2.6rem;
  border-radius: 9999px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,0.75);
}

/* ★矢印（SVG）のみアニメーション */
.top-env__moreIcon{
  display: block;
  transition: transform 240ms ease; /* 統一ルール */
}

/* ★hover時：矢印だけ右に動く */
.top-env__more:hover .top-env__moreIcon{
  transform: translateX(0.25rem);
}

/* Responsive */
@media (max-width: 575.8px){
  .top-env .section__inner{

  }
  .top-env__lead{
    padding-inline: 1.5rem;
  }
}


/* =========================
   TOP sec05: Corporate Information
   ========================= */

.top-corp{
  position: relative;
      background: linear-gradient(to bottom, #F9CFC6 0%, #FAD6CD 40%, #FBE1D9 70%, #fff6e8 100%);
	      z-index: 0;
    overflow: hidden;
}

.top-corp .section__container {
    padding-top: 11rem;
}

.top-corp #mv-marquee {
    top: -3rem;
    /* z-index: 0; */
}

/* セクション全体を「大きな角丸パネル」に */
.top-corp .section__inner {
    overflow: hidden;
    /*background: linear-gradient(180.02deg, #A5C055 0.02%, #7CC493 99.98%);*/
background: linear-gradient(267.81deg, #B8CF73 0.75%, #FAB99F 56.72%, #FFB9AF 96.98%);

	    border-radius: 2.5rem;
}

.top-corp__content{
  position: relative;
  border-radius: 3.2rem;
  padding: 5rem 6rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 3rem;
}

/* ===== Titles ===== */
.top-corp__en{
    color: #fff;
    letter-spacing: 0;
    line-height: 1.05;
    font-weight: 500;
    font-size: max(3rem, 40px);
    font-family: "Lexend Mega", sans-serif;
}

.top-corp__jp{
    font-weight: 500;
    font-size: max(0.875rem, 12px);
    margin-top: 0.6rem;
	color: #ffffff;
}

/* ===== VIEW MORE（sec04と同一挙動） ===== */
.top-corp__more{
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  text-decoration: none;
  color: #fff;
}

/* テキスト＋下線（動かない） */
.top-corp__moreText{
    position: relative;
    padding-bottom: .6rem;
    font-size: max(0.875rem, 12px);
    font-weight: 500;
}
.top-corp__moreText::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:1px;
  background:#ffffff;
}

.top-env .top-corp__more {
    margin-top: 3rem;
}

/* ピル（固定） */
.top-corp__morePill{
    width: 4rem;
    height: 2rem;
  border-radius: 9999px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,0.85);
}

/* 矢印だけ動かす */
.top-corp__moreIcon{
  display: block;
  transition: transform 240ms ease;
}

/* hover時：矢印のみ右へ */
.top-corp__more:hover .top-corp__moreIcon{
  transform: translateX(0.25rem);
}

/* ===== Responsive ===== */
@media (max-width: 991.98px){
  .top-corp__content{
    padding: 4rem 4rem;
  }
}

@media (max-width: 575.8px){
  .top-corp__content{
    flex-direction: column;
    align-items: flex-start;
    padding: 3.5rem 3rem;
  }

  .top-corp__more{
    margin-top: 2.4rem;
  }
}


.requirements-entry.btm .footer-cta {
    padding: 0;
}

/* =========================
   TOP sec03: Our People head
   ========================= */

.top-people__head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}

.top-people__titles{
  min-width: 0;
}

/* タイトル（見本に寄せ） */
.top-people__en{
    letter-spacing: 0;
    line-height: 1.05;
    font-weight: 500;
    color: rgba(255, 200, 210, 0.95);
    font-size: max(3rem, 40px);
    color: #FD8B8B;
    font-family: "Lexend Mega", sans-serif;
}

.top-people__jp{
    color: #ffffff;
    font-weight: 500;
    font-size: max(1rem, 14px);
    font-size: max(0.875rem, 12px);
    margin-top: 0.6rem;
}

/* 右側のVIEW MORE（top-env__moreを流用して“右寄せ固定”） */
.top-people__head .top-env__more{
  margin-top: .4rem;        /* タイトルとの縦位置合わせ（必要なら微調整） */
  flex-shrink: 0;
}

/* SP：縦積み */
@media (max-width: 575.8px){
  .top-people__head{
    flex-direction: column;
    align-items: flex-start;
    gap: 1.2rem;
    margin-bottom: 2.4rem;
  }

  .top-people__head .top-env__more{
    margin-top: 0;
  }
}


@media (max-width: 767.8px){
.top-corp #mv-marquee{
	top: -1rem;
}
}

@media (max-width: 575.8px){
.top-corp .section__container,.top-sec02 .section__container{
	padding: 7.5rem 1.5rem;
}

.base-level__lower.single-menbers .section__container {
    padding-bottom: 4rem;
    padding-top: 4rem;
}

.base-level__lower.single-menbers .menber-single__schedule .section__container {
    padding: 0;
}

.base-level__lower.single-menbers header.menber-hero .section__container {
    padding-bottom: 0;
}

.top-env .section__inner{
	padding:0;
}

.section__container {
    padding: 5.5rem 1.5rem;
    position: relative;
}

section.section.top-people .section__container {
    padding-bottom: 2rem;
}

    .top-sec02__inner {
        padding: 0;
    }
.hero__under .section__container {
    padding: 0 1.5rem;
}

.hero__under .section__container.bread {
    padding: 0 1.5rem;
}

.top-people__sliderWrap {
    position: relative;
    padding-bottom: 6rem;
}

.top-corp__en ,.top-people__en{
    font-size: max(2rem, 25px);
}

.menbers-archive__list {
    gap: 3.6rem;
}

section.base-level__lower {
    padding-bottom: 5rem;
}

.we-facility-slide {
    /* padding-top: 0rem; */
    /* margin-top: 4rem; */
    /* margin-bottom: 10rem; */
    padding-bottom: 0rem;
}

.requirements-entry.btm {
    padding-bottom: 4rem;
}

}




.base-level__lower.archive .footer-cta {
    padding-bottom: 0;
}

.requirements-other-entry .flex a img {
    width: 100%;
}

.requirements-other-entry .flex {
    display: flex;
    gap: 1rem;
    max-width: 32rem;
    margin: 0 auto;
}

.other-entry-ttl {
    font-weight: 500;
    margin-bottom: 1rem;
}

.requirements-other-entry {
    text-align: center;
    margin-top: 5rem;
}

.requirements-other-entry a.tel {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.875rem;
    color: #FD8B8B;
    gap: 0.5rem;
}

.requirements-other-entry p.other-entry-text {
    margin-bottom: 3rem;
}

.scroll_down {
    display: block;
    left: 0;
    right: 0;
    text-align: center;
    bottom: 0;
	    top: 140%;
    position: absolute;
}

.scroll_down p {
letter-spacing: 0;
    font-family: "Lexend Mega", sans-serif;
    font-size: max(0.725rem, 11px);
	    color: #A4A4A4;
}

.scroll_down a{
    display: inline-block;
    text-decoration: none;
	    pointer-events: none;
}

.scroll_down .mouse {
    position: relative;
    display: block;
    width: 1.5rem;
    height: 3.25rem;
    margin: 0.5rem auto 0;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    border: 1px solid #A4A4A4;
    border-radius: 1.25rem;
}

.scroll_down .mouse > * {
    position: absolute;
    display: block;
    top: 29%;
    left: 50%;
    width: 0.725rem;
    height: 0.725rem;
    margin: -0.35rem 0 0 -0.35rem;
    background: #A4A4A4;
    border-radius: 50%;
    animation: ani-mouse 2.5s linear infinite;
}

@keyframes ani-mouse {
	0% {
	opacity: 0;
	top: 70%;
	}
	40% {
	opacity: 0;
	top: 30%;
	}
	70% {
	opacity: 1;
	top: 30%;
	}
	100% {
	opacity: 1;
	top: 70%;
	}
}


@media (max-width: 575.8px){

.scroll_down {
    top: 130%;
}

}


.site-header__navLink {
   /* min-width: 12rem;*/
}


.site-header__navLink {
  position: relative;
  display: inline-block; /* blockでもOK */
}

/* タイトル共通 */
.site-header__navLink .nav-ttl {
  display: inline-block;
  transition: opacity .25s ease;
}

/* 日本語は重ねて非表示 */
.site-header__navLink .nav-ttl--jp {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
      font-weight: 600;
    letter-spacing: 0;
}

/* hoverが使える端末のみフェード */
@media (hover: hover) and (pointer: fine) {
  .site-header__navLink:hover .nav-ttl--en {
    opacity: 0;
  }
  .site-header__navLink:hover .nav-ttl--jp {
    opacity: 1;
  }
}


.sub-text {
    text-align: right;
    margin-top: 2rem;
}




.p-entry-form__field.check-filed span.wpcf7-form-control.wpcf7-checkbox.wpcf7-validates-as-required.p-entry-form__check {
    display: flex;
    gap: 0.8rem;
    flex-wrap: wrap;
}

.p-entry-form__field.comment {
    margin-top: 1rem;
}



.p-entry-form__field.check-filed.gap-filed span.wpcf7-form-control-wrap span.wpcf7-form-control.wpcf7-checkbox.p-entry-form__check span.wpcf7-list-item {
    padding-right: 1rem;
}