@charset "UTF-8";
/* =========================================================
   LAUGHTUS 再現クローン  style.css
   - 原典 laughtus.jp の見た目／アニメーションを自作コードで再現
   - 設計基準幅: 1520px（vwスケーリング）/ 768px以下はSP
   ========================================================= */

/* =========================================================
   ★デザイントークン★  ここだけ変えれば全体の色・フォントが変わります
   （自分のサイト用に色を差し替えるときは、まずこの :root を編集）
   ========================================================= */
:root {
  /* --- 基本色（いろは：ウォームアイボリー × ディープエメラルド × ゴールド）--- */
  --c-ink:      #221d18; /* 基本の文字色 / ウォームダーク */
  --c-bg:       #f4f0e9; /* ページ背景（暖かいアイボリー） */
  --c-kv-bg:    #e9e2d6; /* KV（ヒーロー）の背景（ウォームストーン） */
  --c-muted:    #9b8e79; /* 補助テキスト（トープ） */
  /* --- アクセント色 --- */
  --c-accent:   #1f6f64; /* メインアクセント（ディープエメラルド） */
  --c-accent-2: #c9a24f; /* サブアクセント（シャンパンゴールド） */
  --c-yellow:   #d8b14a; /* 採用バナーなどのゴールド */
  --c-tan:      #b39a76; /* 見出しバッジ・WORKS等のストーン */
  --c-green:    #4e8a78; /* SERVICE 運営：エメラルド */
  --c-orange:   #cca35a; /* SERVICE 設営：ゴールド */
  --c-purple:   #b07a5c; /* SERVICE 制作：テラコッタ */
  --c-slate:    #5f7d86; /* SERVICE 進行：スレートティール */
  /* --- フォント --- */
  --font-jp:      "Noto Sans JP", sans-serif;          /* 本文（日本語） */
  --font-en:      "Montserrat", "Noto Sans JP", sans-serif; /* 英字見出し */
  --font-display: "Barlow Condensed", "Montserrat", sans-serif; /* 大きな英字ロゴ */
}

/* ---------- reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html {
  margin: 0;
  font-size: 10px;
  color: #000;
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
}
body {
  margin: 0;
  width: 100%;
  position: relative;
  overflow-x: hidden;
  font-family: var(--font-jp);
  font-weight: 400;
  font-size: 1.4rem;
  letter-spacing: .04em;
  line-height: 2;
  color: var(--c-ink);
}
img { display: block; max-width: 100%; height: auto; }
ul { list-style: none; margin: 0; padding: 0; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4, p { margin: 0; }
.en { font-family: var(--font-en); }
.t-bold { font-weight: 700; }

/* ---------- placeholder（画像の代替ブロック） ---------- */
.ph {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.85);
  font-family: var(--font-en);
  font-weight: 700; letter-spacing: .15em; font-size: 1.3rem;
  background: linear-gradient(135deg, #d9d4cb 0%, #b9b1a3 100%);
}
.ph-intro { background: linear-gradient(135deg,#8fa9d8,var(--c-accent) 80%); }
.ph-about { background: linear-gradient(135deg,#e7c9a0,var(--c-tan)); }
.ph-flow-1 { background: linear-gradient(135deg,#a6e7bf,var(--c-green)); }
.ph-flow-2 { background: linear-gradient(135deg,#f0d3ab,var(--c-orange)); }
.ph-flow-3 { background: linear-gradient(135deg,#d2bdf5,var(--c-purple)); }

/* =========================================================
   LOADING（phase-0 → phase-1 → phase-2 → phase-3）
   ========================================================= */
#loading {
  position: absolute; left: 0; top: 0; z-index: 10001;
  background: #000; width: 100%; height: 100vh;
  transition: background 1s ease-in-out, opacity 1s ease-in-out;
}

/* シンボル（S+L マーク）= 最後に登場し、そのままヒーローに残る */
#symbol {
  position: absolute; top: 9.86vw; left: 50%; translate: -50% 0;
  max-width: 0; opacity: 0; overflow: hidden;
  width: 75.13vw; height: 22.63vw;
}
#symbol, #symbol-wrapper, .symbol { transition: 1.5s cubic-bezier(.6,.04,.98,1); }
#symbol-wrapper { min-width: 75.13vw; min-height: 22.63vw; display: flex; align-items: center; justify-content: center; }
.symbol { width: 75.13vw; height: 22.63vw; }
#loading svg path, #loading svg rect { fill: #fff; transition: fill .6s; }
/* IROHA ワードマーク（ヒーローに残る大きなマーク・中抜きでコピーを透かす） */
.symbol-text {
  font-family: var(--font-display); font-weight: 600; letter-spacing: .04em;
  font-size: 16vw; line-height: 1; white-space: nowrap;
  color: transparent; -webkit-text-stroke: 1.5px #fff; text-stroke: 1.5px #fff;
  transition: -webkit-text-stroke-color .6s;
}
/* 表示完了後はヒーローの邪魔をしないよう、少し淡いアウトラインに */
body.is-transit #loading .symbol-text { -webkit-text-stroke-color: rgba(26,19,17,.42); text-stroke-color: rgba(26,19,17,.42); }

/* ローディングロゴ（縦ロゴ）= 最初に登場 */
#loading-logo {
  position: absolute; top: 50%; left: 50%; translate: -50% -50%; z-index: 10002;
  max-width: 0; overflow: hidden; opacity: 1; white-space: nowrap;
  display: flex; flex-direction: column; align-items: center; gap: 1.6vw;
  transition: max-width 2.4s cubic-bezier(.6,.04,.98,1), opacity 1.3s ease;
}
#loading-logo .loading-logo-mark { width: 8vw; height: auto; }
#loading-logo .loading-logo-mark path, #loading-logo .loading-logo-mark rect { fill: #fff; }
#loading-logo .logo-wordmark {
  font-family: var(--font-display);
  font-weight: 600; letter-spacing: .18em; color: #fff;
  font-size: 3.5vw; line-height: 1; white-space: nowrap;
}

/* --- phase 制御（原典準拠の順序）--- */
/* phase-0: 黒画面のまま */
#pagetop.phase-0 #loading { background: #000; }
/* phase-1: 縦ロゴが横ワイプで開く */
#pagetop.phase-1 #loading-logo { max-width: 60vw; }
/* phase-2: 縦ロゴがフェードアウト */
#pagetop.phase-2 #loading-logo { opacity: 0; }
/* phase-3: 黒幕が引けてページ出現 + シンボルマークが拡大 */
#pagetop.phase-3 #symbol { max-width: 75.13vw; opacity: 1; }
#pagetop.phase-3 #loading { background: none; }
/* is-transit: シンボルをダークに（白背景に合わせる）。黒幕除去後はクリック透過＋
   ヘッダー背面へ。シンボルマークはヒーローのグラフィックとして残す */
body.is-transit #loading svg path, body.is-transit #loading svg rect { fill: var(--c-ink); }
body.is-transit #loading { pointer-events: none; z-index: 5; }

/* ページ遷移用の白幕 */
#transition {
  position: fixed; left: 0; top: 0; z-index: 99; background: #fff;
  width: 100%; height: 100%; opacity: 0; pointer-events: none;
  transition: all .2s ease-in-out;
}

/* =========================================================
   HEADER
   ========================================================= */
#header {
  position: fixed; left: 0; top: 0; z-index: 9000;
  width: 100%; height: 5.2vw; min-height: 64px;
  opacity: 0; pointer-events: none;
  transition: opacity .6s ease, background .4s ease;
}
body.is-transit #header { opacity: 1; pointer-events: auto; }
#header-inner {
  display: flex; align-items: center; position: relative;
  width: 100%; height: 100%; padding-left: 1.97vw; padding-right: 0;
}
#header-logo { display: flex; align-items: center; gap: .6vw; height: 100%; }
#header-logo .logo-mark { display: block; width: 3.2vw; min-width: 40px; }
#header-logo .logo-mark svg { width: 100%; height: auto; }
#header-logo .logo-mark svg path, #header-logo .logo-mark svg rect { fill: var(--c-ink); transition: fill .4s; }
#header-logo .logo-text {
  font-family: var(--font-display); font-weight: 600;
  letter-spacing: .14em; font-size: 1.78vw; min-font-size: 18px;
  color: var(--c-ink); transition: color .4s;
}
/* スクロール時：半透明バー（可読性確保） */
#header.is-scrolled { background: rgba(248,248,248,.88); backdrop-filter: blur(8px); box-shadow: 0 1px 12px rgba(0,0,0,.05); }
/* メニュー展開中はバー非表示 */
#header.is-open { background: none; box-shadow: none; }

/* burger */
/* バーガー（SPのみ表示） */
.burger-btn {
  display: none; flex-direction: column; justify-content: center; gap: 6px;
  width: 60px; height: 100%; padding: 0 18px; margin-left: auto;
  cursor: pointer; z-index: 9100;
}
.burger-btn-line { display: block; width: 100%; height: 2px; background: var(--c-ink); transition: all .35s ease; }
.burger-btn.is-open .burger-btn-line { background: var(--c-ink); }
.burger-btn.is-open .burger-btn-line:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.burger-btn.is-open .burger-btn-line:nth-child(2) { opacity: 0; }
.burger-btn.is-open .burger-btn-line:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* ===== PC: 横並びのヘッダーナビ ===== */
#header-nav { margin-left: auto; height: 100%; display: flex; align-items: center; }
.header-nav__inner { display: flex; align-items: center; height: 100%; }
.header-nav__corporate { display: flex; flex-direction: row; align-items: center; gap: 1.7vw; }
.header-nav__item {
  font-size: 1.12vw; font-weight: 700; letter-spacing: .06em; color: var(--c-ink);
  position: relative; white-space: nowrap; transition: opacity .3s;
}
.header-nav__item::after {
  content: ""; position: absolute; left: 0; bottom: -.5em; width: 0; height: 1px;
  background: var(--c-ink); transition: width .3s ease;
}
.header-nav__item:hover::after { width: 100%; }
.header-nav__btn { display: flex; gap: .7vw; margin-left: 1.2vw; }
.header-nav__btn-item {
  display: inline-flex; align-items: center; justify-content: center;
  padding: .55em 1.5em; border-radius: 999px; font-weight: 700; font-size: 1.08vw; color: #fff;
  white-space: nowrap; transition: transform .3s ease, opacity .3s ease;
}
.header-nav__btn-item:hover { transform: translateY(-2px); }
.header-nav__btn-item.recruit { background: var(--c-accent); }
.header-nav__btn-item.contact { background: var(--c-ink); }

/* =========================================================
   LAYOUT
   ========================================================= */
.l-container { width: 75.65vw; margin: 0 auto; box-sizing: border-box; }
.l-content { display: flex; }
.l-content__gr-1 { width: 26.31vw; flex-shrink: 0; }
.l-content__gr-2 { width: 49.34vw; }

#wrapper { overflow: hidden; }

/* =========================================================
   KV
   ========================================================= */
#kv { position: relative; background: var(--c-kv-bg); height: 61vw; overflow: hidden; }
#kv-content { padding-top: 11.5vw; padding-left: 12.5vw; position: relative; z-index: 3; }
#kv-copy, #kv-subcopy { width: 0; white-space: nowrap; overflow: hidden; }
#kv-copy {
  font-weight: 700; font-size: 2.35vw; line-height: 1.5; margin-bottom: 1.6vw;
  letter-spacing: .08em; color: var(--c-ink);
}
#kv-subcopy {
  font-family: var(--font-en); font-weight: 700;
  font-size: 1.28vw; line-height: 1.45; letter-spacing: .1em; color: var(--c-ink);
}
#kv-img {
  position: absolute; bottom: 0; left: 0; z-index: 2;
  width: 0; height: 25.52vw; overflow: hidden;
  background-image: url(../images/hero.jpg);
  background-size: 100vw auto; background-position: center 35%; background-repeat: no-repeat;
}
#kv-img::after {
  content: "EVENT KEY VISUAL"; position: absolute; right: 4vw; bottom: 2vw;
  color: rgba(255,255,255,.85); font-family: "Montserrat",sans-serif; font-weight: 700; letter-spacing: .2em; font-size: 1.32vw;
  text-shadow: 0 1px 8px rgba(0,0,0,.4);
}
/* phase-3 + is-transit でワイプ表示 */
body.is-transit.phase-3 #kv-copy { width: 100%; transition: width 1.5s ease-in-out 1.1s; }
body.is-transit.phase-3 #kv-subcopy { width: 100%; transition: width 1.5s ease-in-out 1.9s; }
body.is-transit.phase-3 #kv-img { width: 100%; transition: width 1.6s ease-in-out 2.7s; }

/* セクション画像（いろは実写真）を枠いっぱいに */
.intro-fig-1 img, .about-fig-1 img, .flow-fig img,
.works-item__fig img, .member-list__item .fig img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}

/* =========================================================
   共通アニメーション（is-inview で発火）
   ========================================================= */
.anim { opacity: 0; }
.anim.is-inview { opacity: 1; transition: opacity 1s cubic-bezier(.16,1,.3,1) .1s; }

.anim-fadeUp { transform: translateY(34px); }
.anim-fadeUp.is-inview { transform: translateY(0); transition: all 1.6s cubic-bezier(.16,1,.3,1) .3s; }

.anim-zoomOutImg { overflow: hidden; }
.anim-zoomOutImg .ph, .anim-zoomOutImg img {
  transform: scale(1.2);
  transition: opacity 1.4s ease-in-out 0s, transform .4s ease-in-out 0s;
}
.anim-zoomOutImg.is-inview .ph, .anim-zoomOutImg.is-inview img {
  transform: scale(1);
  transition: opacity 1.4s ease-in-out 0s, transform 2.4s ease-in-out 0s;
}

/* 文字バラバラ → 整列（js-word-divider） */
.js-word-divider span {
  display: inline-block; opacity: 0; transform-origin: center center;
  /* 散らばり初期値は JS が --r/--x/--y/--s で与える */
  transform: translate3d(var(--x,120%), var(--y,80%), 0) scale(var(--s,1.2));
  rotate: var(--r, 200deg);
}
.js-word-divider.is-inview span {
  opacity: 1; transform: translateZ(0) scale(1); rotate: 0deg;
  transition:
    opacity 1s cubic-bezier(.16,1,.3,1),
    transform 2.4s cubic-bezier(.16,1,.3,1),
    rotate 1.5s cubic-bezier(.16,1,.3,1);
  transition-delay: calc(var(--i, 0) * .05s);
}

/* 区切り線 */
.m-line-1, .m-line-2 {
  width: 0; height: 1px; background: var(--c-ink); margin: 7vw auto 0;
  transition: width 1.9s cubic-bezier(.16,1,.3,1);
}
.m-line-1.is-inview, .m-line-2.is-inview { width: 75.65vw; }

/* =========================================================
   見出し m-head-1
   ========================================================= */
.m-head-1 .ja { display: block; font-weight: 700; letter-spacing: .1em; font-size: 2.2vw; margin-bottom: 1.05vw; }
.m-head-1 .en {
  display: inline-block; font-weight: 700; letter-spacing: .1em;
  background: var(--c-tan); color: #fff; font-size: 1.0vw;
  padding: .2vw .66vw; border-radius: .52vw;
}

/* =========================================================
   INTRO
   ========================================================= */
#intro { position: relative; padding: 9vw 0 7vw; overflow: hidden; }
#intro .home-intro__container { position: relative; z-index: 2; }
#intro-head {
  font-family: var(--font-en); font-weight: 700;
  letter-spacing: .1em; font-size: 3.8vw; line-height: 1.3;
}
#home .intro-body { font-weight: 700; letter-spacing: .1em; font-size: 1.28vw; line-height: 2.4; }
.intro-fig-1 {
  width: 50vw; height: 26vw; margin: 5vw auto 0; position: relative; z-index: 2;
}
#intro-bg { position: absolute; left: 0; top: 0; width: 100%; height: 100%; z-index: 1; pointer-events: none; }
#intro-circle-1, #intro-circle-2 {
  width: 21.25vw; height: 21.25vw; border-radius: 50%; position: absolute; left: 0; bottom: 2.56vw;
  transform-origin: bottom right;
}
#intro-circle-1 { background: #e7ddc6; z-index: 2; animation: circleMove 7s linear infinite; }
#intro-circle-2 { background: #fff; }
#intro-circle-3 {
  width: 21.25vw; height: 21.25vw; background: #fff; border-radius: 50%;
  position: absolute; left: 100%; bottom: 2.56vw; translate: -100% 12%; scale: 2.24;
  transform-origin: bottom right;
}
#intro-line-1, #intro-line-2 {
  height: 1px; width: 60vw; border-top: 1px dashed #c8c8c8; position: absolute;
  transform-origin: left bottom; left: 8vw;
}
#intro-line-1 { top: 22vw; rotate: -20.7deg; }
#intro-line-2 { top: 30vw; rotate: 2.4deg; }
@keyframes circleMove {
  0%   { opacity: 0;  left: 0;    translate: 0 0;        scale: 1; }
  20%  { opacity: .6; left: 0;    translate: 0 0;        scale: 1; }
  30%  { opacity: .6; left: 0;    translate: 0 0;        scale: 1; }
  70%  { opacity: .6; left: 100%; translate: -100% 12%;  scale: 2.24; }
  80%  { opacity: .6; left: 100%; translate: -100% 12%;  scale: 2.24; }
  100% { opacity: 0;  left: 100%; translate: -100% 12%;  scale: 2.24; }
}

/* =========================================================
   ABOUT
   ========================================================= */
#about { position: relative; padding: 7vw 0; }
.home-about__container { position: relative; z-index: 2; }
.about-lead { font-weight: 700; letter-spacing: .1em; font-size: 2.55vw; line-height: 1.5; margin-bottom: 2vw; }
.about-body { font-weight: 400; letter-spacing: .04em; font-size: 1.28vw; line-height: 2.2; }
.about-body .emphasize { display: block; font-weight: 700; margin-top: 1.5em; }
.about-fig-1 { width: 50vw; height: 24vw; margin: 5vw auto 0; position: relative; z-index: 2; }

/* =========================================================
   SERVICE
   ========================================================= */
#service { position: relative; padding: 7vw 0; }
.home-service__container { position: relative; z-index: 2; }
.service-lead { font-weight: 700; letter-spacing: .1em; font-size: 2.55vw; line-height: 1.5; margin-bottom: 1.5vw; }
.service-lead .en { display: block; font-size: 1.65vw; color: var(--c-accent); }
.service-body { font-weight: 400; letter-spacing: .04em; font-size: 1.28vw; line-height: 2.2; margin-bottom: 4vw; }

/* 3つの円が左右に展開 */
/* 4つの丸を大きく見せるため、テキスト列より少し横に広げる */
.service-info { position: relative; height: 12.5vw; width: 56vw; margin: 6vw 0 6vw -3.5vw; }
.service-info__item {
  position: absolute; top: 0; width: 12.5vw; height: 12.5vw; border-radius: 50%;
  border: 1px solid #cabfa8; display: flex; flex-direction: column; align-items: center; justify-content: center;
  /* 初期: 4つとも中央に重なる。is-inview で left のみ変化（translate は据え置き）→なめらか */
  left: 50%; translate: -50% 0;
  transition: left 1.3s cubic-bezier(.16,1,.3,1) 1.2s;
}
.service-info__item .ja { font-weight: 700; letter-spacing: .1em; font-size: 1.45vw; }
.service-info__item .en {
  font-weight: 700; letter-spacing: .08em; font-size: .85vw; color: #fff;
  padding: .12em .8em; border-radius: 999px; margin-top: .35em; white-space: nowrap;
  opacity: 0; translate: 0 50%; transition: all .9s ease-in-out 2.4s;
}
.service-info__item .ja { opacity: 0; translate: 0 50%; transition: all .9s ease-in-out 2.4s; }
.service-info__item:nth-of-type(1) .en { background: var(--c-green); }
.service-info__item:nth-of-type(2) .en { background: var(--c-orange); }
.service-info__item:nth-of-type(3) .en { background: var(--c-purple); }
.service-info__item:nth-of-type(4) .en { background: var(--c-slate); }
.service-info.is-inview .service-info__item .ja,
.service-info.is-inview .service-info__item .en { opacity: 1; translate: 0 0; }
/* 中央から4等分の位置へ展開（すべて left＋translate:-50% で統一） */
.service-info.is-inview .service-info__item:nth-of-type(1) { left: 12.5%; }
.service-info.is-inview .service-info__item:nth-of-type(2) { left: 37.5%; }
.service-info.is-inview .service-info__item:nth-of-type(3) { left: 62.5%; }
.service-info.is-inview .service-info__item:nth-of-type(4) { left: 87.5%; }

.service-event { background: #fff; box-sizing: border-box; padding: 2vw 2.5vw; }
.service-event__ttl { font-weight: 700; letter-spacing: .1em; margin-bottom: 1vw; }
.service-event__list-item {
  font-weight: 700; letter-spacing: .1em; padding: .8vw 0; border-bottom: 1px solid var(--c-kv-bg); display: flex; align-items: center;
}
.service-event__list-item::before { content: ""; width: 1.2em; height: 2px; background: var(--c-tan); display: inline-block; margin-right: .8em; }

/* FLOW */
#flow { margin-top: 7vw; }
.flow-item { margin-bottom: 5vw; }
.flow-fig { position: relative; width: 100%; height: 22vw; overflow: hidden; }
.flow-fig .ph { width: 100%; height: 100%; }
.flow-fig .cap {
  position: absolute; left: 0; top: 0; z-index: 2; font-weight: 700; letter-spacing: .1em;
  padding: .7vw 1.6vw; font-size: 1.32vw; color: var(--c-ink);
}
.flow-fig .cap.green { background: var(--c-green); }
.flow-fig .cap.yellow { background: var(--c-orange); }
.flow-fig .cap.purple { background: var(--c-purple); }
.flow-step { display: flex; gap: 2vw; padding: 2.5vw 0; border-bottom: 1px solid #e6e6e6; }
.flow-step__gr-1 { flex-shrink: 0; }
.flow-label {
  font-family: var(--font-en); font-weight: 700; letter-spacing: .1em;
  display: inline-block; padding: .4vw 1.2vw; border-radius: 999px; font-size: 1.2vw; color: var(--c-ink);
}
.flow-label.green { background: var(--c-green); }
.flow-label.yellow { background: var(--c-orange); }
.flow-label.purple { background: var(--c-purple); }
.flow-step__lead { font-weight: 700; letter-spacing: .1em; font-size: 1.55vw; margin-bottom: .8vw; }
.flow-step__lead .en { display: block; font-size: 1.0vw; color: var(--c-muted); margin-top: .2em; }
.flow-step__body { font-weight: 400; letter-spacing: .04em; font-size: 1.2vw; line-height: 2; }

/* =========================================================
   WORKS
   ========================================================= */
#works { position: relative; padding: 7vw 0; }
.home-works__container { position: relative; z-index: 2; }
.works-lead { font-weight: 700; letter-spacing: .1em; font-size: 2.55vw; line-height: 1.4; margin-bottom: 1vw; }
.works-lead .en { display: block; font-size: 1.32vw; color: var(--c-accent); margin-top: .4em; }
.works-body { font-weight: 400; letter-spacing: .04em; font-size: 1.28vw; line-height: 2.2; margin-bottom: 4vw; }

.works-meta { background: #fff; overflow: hidden; position: relative; display: flex; margin: 4vw 0 2vw; }
.works-meta::before { content: ""; width: 100%; height: 4px; background: var(--c-tan); position: absolute; left: 0; top: 0; }
.works-meta__gr-1 {
  flex-shrink: 0; width: 12vw; display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 2vw 0; border-right: 1px solid var(--c-kv-bg);
}
.works-meta__gr-1 .en { font-family: var(--font-en); font-weight: 700; font-size: 3.5vw; line-height: 1; color: var(--c-tan); }
.works-meta__gr-1 .ja { font-weight: 700; letter-spacing: .1em; font-size: 1.2vw; margin-top: .5em; }
.works-meta__gr-2 { padding: 2vw; }
.works-meta__body { letter-spacing: .03em; font-weight: 400; font-size: 1.12vw; line-height: 2; }

.works-list { display: flex; flex-wrap: wrap; gap: 1.2vw; margin-bottom: 2vw; }
.works-item {
  background: #fff; overflow: hidden; position: relative; display: flex; flex-direction: column;
  width: calc((100% - 2.4vw) / 3); box-sizing: border-box;
}
.works-item__fig { overflow: hidden; height: 11vw; }
.works-item__fig .ph { font-size: 1rem; }
.works-item__gr-1 { padding: 1vw 1.2vw 1.4vw; }
.works-item__gr-1 .type {
  font-family: var(--font-en); font-weight: 700; letter-spacing: .1em; font-size: 1.08vw;
  display: flex; align-items: center; gap: .4em; color: var(--c-muted);
}
.works-item__gr-1 .type .size {
  display: inline-flex; align-items: center; justify-content: center; width: 1.6em; height: 1.6em; border-radius: 50%;
  background: var(--c-tan); color: #fff; font-size: .8em;
}
.works-item__gr-1 .name { font-weight: 700; letter-spacing: .04em; font-size: 1.28vw; margin: .4em 0 .2em; line-height: 1.5; }
.works-item__gr-1 .detail { letter-spacing: .04em; font-size: 1.0vw; color: var(--c-muted); }

/* =========================================================
   MEMBER
   ========================================================= */
#member { position: relative; padding: 7vw 0; }
.home-member__container { position: relative; z-index: 2; }
.member-lead { font-weight: 700; letter-spacing: .1em; font-size: 2.55vw; line-height: 1.4; margin-bottom: 1vw; }
.member-lead .en { display: block; font-size: 1.32vw; color: var(--c-accent); margin-top: .4em; }
.member-body { font-weight: 400; letter-spacing: .04em; font-size: 1.28vw; line-height: 2.2; }

.member-list {
  display: flex; flex-direction: column; gap: 3.5vw; width: 75.65vw; margin: 5vw auto 0; box-sizing: border-box;
}
/* 段（上＝共同代表 / 下＝社員）。各段は中央寄せ */
.member-row { display: flex; flex-wrap: wrap; justify-content: center; gap: 2.4vw 3vw; width: 100%; }
.member-row.is-rep { position: relative; }
.member-list__item { cursor: pointer; width: calc((100% - 7.2vw) / 4); }
/* 共同代表の段は少し大きめに見せる */
.member-row.is-rep .member-list__item { width: calc((100% - 9vw) / 3.6); }
.member-list__item .fig {
  overflow: hidden; border-radius: 50%; position: relative; width: 100%; padding-top: 100%;
}
.member-list__item .fig .def, .member-list__item .fig .hover {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-en); font-weight: 700; color: #fff; letter-spacing: .1em; font-size: 1.2vw;
  transition: all .6s ease-in-out;
}
.member-list__item .fig .def { background: linear-gradient(135deg,#d9cfbe,#b6a98f); }
.member-list__item .fig .hover { z-index: 2; opacity: 0; background: linear-gradient(135deg,var(--c-accent),var(--c-accent-2)); }
.member-list__item:hover .fig .hover { opacity: 1; }
.member-list__item:hover .fig .def { transform: scale(1.05); }
.member-list__item .label { display: flex; flex-direction: column; align-items: center; margin-top: 1vw; text-align: center; }
.member-list__item .role { letter-spacing: .04em; font-size: .95vw; color: var(--c-muted); min-height: 1.2em; }
.member-list__item .name { font-weight: 700; letter-spacing: .04em; font-size: 1.32vw; }
.member-list__item .en { font-family: var(--font-en); font-weight: 700; letter-spacing: .1em; font-size: .9vw; color: var(--c-muted); }

/* =========================================================
   RECRUIT BANNER
   ========================================================= */
#recruit-bnr {
  position: relative; padding: 8vw 12.5vw; margin-top: 7vw;
  background: linear-gradient(120deg,var(--c-yellow) 0%,#e6bf55 100%); overflow: hidden;
}
#recruit-bnr .inner { position: relative; z-index: 2; }
#recruit-bnr .label { font-family: var(--font-en); font-weight: 700; letter-spacing: .2em; font-size: 1.2vw; color: var(--c-ink); }
#recruit-bnr .head { font-weight: 700; letter-spacing: .1em; font-size: 2.15vw; margin: .4em 0 1vw; }
#recruit-bnr .copy {
  font-family: var(--font-display); font-weight: 600; letter-spacing: .05em;
  font-size: 7vw; line-height: .95; color: var(--c-ink); margin-bottom: 2vw;
}
#recruit-bnr .btn {
  display: inline-flex; align-items: center; gap: 1em; background: var(--c-ink); color: #fff;
  padding: 1.2em 2.5em; border-radius: 999px; font-weight: 700; letter-spacing: .04em; font-size: 1rem;
  transition: transform .4s ease, background .4s ease;
}
#recruit-bnr .btn::after { content: "→"; font-family: var(--font-en); }
#recruit-bnr .btn:hover { transform: translateX(6px); background: #000; }

/* =========================================================
   FOOTER BANNER
   ========================================================= */
#footer-bnr { display: flex; }
#footer-bnr .item {
  width: 50%; padding: 7vw 6vw; box-sizing: border-box; position: relative; overflow: hidden;
  transition: background .4s;
}
#footer-bnr .item.company { background: #ece4d4; }
#footer-bnr .item.contact { background: #dde8e3; }
#footer-bnr .item .logo-mark.dark {
  width: 4vw; height: 4vw; border-radius: 50%; background: var(--c-ink); margin-bottom: 2vw;
}
#footer-bnr .item .head { display: flex; flex-direction: column; margin-bottom: 1.2vw; }
#footer-bnr .item .head .ja { font-weight: 700; letter-spacing: .1em; font-size: 1.9vw; }
#footer-bnr .item .head .en { font-family: var(--font-en); font-weight: 700; letter-spacing: .15em; font-size: 1.08vw; color: var(--c-muted); }
#footer-bnr .item .body { font-size: 1.2vw; line-height: 2; margin-bottom: 2vw; }
#footer-bnr .item .btn {
  display: inline-flex; align-items: center; gap: 1em; background: var(--c-ink); color: #fff;
  padding: 1.1em 2.4em; border-radius: 999px; font-weight: 700; font-size: 1rem; transition: transform .4s;
}
#footer-bnr .item .btn::after { content: "→"; }
#footer-bnr .item .btn:hover { transform: translateX(6px); }

/* =========================================================
   FOOTER
   ========================================================= */
footer { background: var(--c-ink); color: #fff; padding: 6vw 12.5vw; }
.footer-inner { display: flex; gap: 6vw; }
#footer-logo .logo-wordmark { font-family: var(--font-display); font-weight: 600; letter-spacing: .14em; font-size: 3.5vw; color: #fff; }
.footer-gr-2 { flex: 1; }
#footer-nav { display: flex; gap: 5vw; margin-bottom: 3vw; }
.footer-nav__item { display: block; font-size: 1rem; line-height: 2.4; color: rgba(255,255,255,.85); transition: color .3s; }
.footer-nav__item:hover { color: var(--c-yellow); }
.copyright { font-size: .9rem; color: rgba(255,255,255,.5); letter-spacing: .05em; }

/* =========================================================
   レスポンシブ（768px以下 = SP）基準幅 750
   ========================================================= */
.m-sm { display: none; }

@media (max-width: 768px) {
  body { font-size: 3.4vw; }
  .m-sm { display: inline; }
  .l-container { width: 92vw; }
  .l-content { flex-direction: column; }
  .l-content__gr-1, .l-content__gr-2 { width: 100%; }

  #symbol, #symbol-wrapper, .symbol { width: 90.9vw; height: 34.5vw; }
  #pagetop.phase-3 #symbol { max-width: 90.9vw; }
  #loading-logo .loading-logo-mark { width: 22vw; }
  #loading-logo .logo-wordmark { font-size: 7.5vw; }
  #pagetop.phase-1 #loading-logo { max-width: 80vw; }

  #header { height: 60px; min-height: 60px; }
  #header-inner { padding-left: 4vw; }
  #header-logo .logo-mark { width: 34px; }
  #header-logo .logo-text { font-size: 18px; }

  /* ===== SP: バーガー＋全画面ドロワー ===== */
  .burger-btn { display: flex; }
  #header-nav {
    position: fixed; top: 0; right: 0; width: 100%; height: 100%; margin-left: 0;
    display: block; background: #fff; opacity: 0; pointer-events: none; z-index: 9000;
    transition: all .6s ease .3s;
  }
  #header-nav.is-open { opacity: 1; pointer-events: auto; transition: all .6s ease .1s; }
  .header-nav__inner { width: 100%; height: 100%; justify-content: center; }
  .header-nav__corporate { flex-direction: column; align-items: flex-start; gap: 4vw; }
  .header-nav__item {
    font-size: 6vw;
    opacity: 0; translate: 0 20px; transition: all .5s ease-in-out .3s;
  }
  .header-nav__item::after { display: none; }
  #header-nav.is-open .header-nav__item { opacity: 1; translate: 0 0; }
  #header-nav.is-open .header-nav__item:nth-of-type(1){ transition-delay:.35s; }
  #header-nav.is-open .header-nav__item:nth-of-type(2){ transition-delay:.40s; }
  #header-nav.is-open .header-nav__item:nth-of-type(3){ transition-delay:.45s; }
  #header-nav.is-open .header-nav__item:nth-of-type(4){ transition-delay:.50s; }
  #header-nav.is-open .header-nav__item:nth-of-type(5){ transition-delay:.55s; }
  .header-nav__btn {
    flex-direction: column; width: 100%; gap: 3vw; margin: 5vw 0 0;
    opacity: 0; translate: 0 20px; transition: all .5s .6s;
  }
  #header-nav.is-open .header-nav__btn { opacity: 1; translate: 0 0; }
  .header-nav__btn-item { font-size: 4vw; padding: 1em 2.4em; }

  #kv { height: 203.2vw; }
  #kv-content { padding-top: 50vw; padding-left: 4vw; }
  #kv-copy { font-size: 6vw; line-height: 1.5; margin-bottom: 3vw; white-space: normal; }
  #kv-subcopy { font-size: 3.2vw; line-height: 1.5; white-space: normal; }
  #kv-img { height: 101vw; }
  #kv-img::after { font-size: 3vw; }
  body.is-transit.phase-3 #kv-copy,
  body.is-transit.phase-3 #kv-subcopy,
  body.is-transit.phase-3 #kv-img { width: 100%; }

  .m-line-1.is-inview, .m-line-2.is-inview { width: 92vw; }

  #intro-head { font-size: 9vw; }
  #home .intro-body { font-size: 3.6vw; line-height: 2; }
  .intro-fig-1, .about-fig-1 { width: 92vw; height: 56vw; }
  #intro-circle-1, #intro-circle-2, #intro-circle-3 { width: 43vw; height: 43vw; }

  .m-head-1 .ja { font-size: 8vw; margin-bottom: 3vw; }
  .m-head-1 .en { font-size: 3.4vw; padding: .4vw 2.6vw; border-radius: 2.6vw; }

  .about-lead, .service-lead, .works-lead, .member-lead { font-size: 6vw; }
  .about-body, .service-body, .works-body, .member-body, .service-lead .en, .works-lead .en, .member-lead .en { font-size: 3.6vw; }

  .service-info { height: 20vw; }
  .service-info__item { width: 20vw; height: 20vw; }
  .service-info__item .ja { font-size: 3vw; }
  .service-info__item .en { font-size: 1.7vw; }
  .service-event { padding: 6vw; }
  .flow-fig { height: 50vw; }
  .flow-fig .cap { font-size: 3.4vw; padding: 1.6vw 3vw; }
  .flow-step { flex-direction: column; gap: 2vw; }
  .flow-label { font-size: 3vw; padding: 1vw 3vw; }
  .flow-step__lead { font-size: 4vw; }
  .flow-step__lead .en { font-size: 2.8vw; }
  .flow-step__body { font-size: 3.4vw; }

  .works-meta { flex-direction: column; }
  .works-meta__gr-1 { width: 100%; flex-direction: row; gap: 1em; border-right: none; border-bottom: 1px solid var(--c-kv-bg); }
  .works-meta__gr-1 .en { font-size: 8vw; }
  .works-meta__gr-1 .ja { font-size: 3.4vw; margin-top: 0; }
  .works-meta__body { font-size: 3.2vw; }
  .works-item { width: calc((100% - 4vw) / 2); }
  .works-item__fig { height: 28vw; }
  .works-item__gr-1 .type { font-size: 2.8vw; }
  .works-item__gr-1 .name { font-size: 3.4vw; }
  .works-item__gr-1 .detail { font-size: 2.8vw; }

  .member-list { width: 92vw; gap: 9vw; }
  .member-row { gap: 6vw 6vw; }
  .member-list__item, .member-row.is-rep .member-list__item { width: calc((100% - 6vw) / 2); }
  .member-list__item .name { font-size: 3.4vw; }
  .member-list__item .en { font-size: 2.4vw; }
  .member-list__item .role { font-size: 2.6vw; }
  .member-list__item .fig .def, .member-list__item .fig .hover { font-size: 3vw; }

  #recruit-bnr { padding: 14vw 4vw; }
  #recruit-bnr .label { font-size: 3vw; }
  #recruit-bnr .head { font-size: 5vw; }
  #recruit-bnr .copy { font-size: 16vw; }
  #footer-bnr { flex-direction: column; }
  #footer-bnr .item { width: 100%; padding: 12vw 6vw; }
  #footer-bnr .item .logo-mark.dark { width: 12vw; height: 12vw; }
  #footer-bnr .item .head .ja { font-size: 5vw; }
  #footer-bnr .item .head .en { font-size: 3vw; }
  #footer-bnr .item .body { font-size: 3.4vw; }

  footer { padding: 12vw 6vw; }
  .footer-inner { flex-direction: column; gap: 8vw; }
  #footer-logo .logo-wordmark { font-size: 10vw; }
  #footer-nav { gap: 10vw; }
}
