/* =========================================================
   HEDGEHOGS Profile — "Warm Editorial" edition
   Planhat系のレイアウト言語（贅沢な余白・大型タイポ・交互
   セクション・3カラム罫線・プロダクトUI埋め込み・上品な
   フェード演出）を、クリーム×テラコッタ/琥珀の暖色で再構成。
   コンテンツは米田徳邦の自前内容。
   ========================================================= */

/* ---------- 1. トークン ---------- */
:root {
  /* 「最先端で都会的（トレンド＆メトロポリタン）」パレット — 明るめ
     dark aqua #488A99 / gold #DBAE58 / blush #FBE9E7 / gray #B4B4B4
     ※ 全体を明るく。ダーク面はディープ・アクア(黒は使わない)
     ※ 変数名は前テーマを踏襲（役割は下記コメント参照） */
  --cream:    #eef3ea;  /* 主背景 = 明るいオフホワイト(セージ寄り) */
  --cream-2:  #e5eede;  /* 仕切りの淡いセージ帯 */
  --paper:    #fcfefb;  /* カード最明面 */
  --espresso: #3a6b43;  /* 「ダーク」面・フッター = ディープセージグリーン */
  --espresso-2: #4f8055;

  /* テキスト */
  --ink:        #2d3739;       /* チャコール・スレート(本文) */
  --ink-soft:   #5f6b6d;
  --paper-ink:  #ffffff;       /* アクア面の主文字 = 白 */
  --paper-soft: rgba(255,255,255,0.78);

  /* アクセント */
  --terra:     #4a7c50;   /* HEDGEHOGS sage（主アクセント／見出し強調・CTA） */
  --terra-dim: #3c6541;
  --amber:     #dbae58;   /* gold（緑面のアクセント・統計単位） */
  --sand:      #b4b4b4;   /* gray */
  --aqua:      #4f8055;
  --gold:      #dbae58;
  --blush:     #e5eede;

  /* 罫線 */
  --line:      #e1e8da;
  --line-2:    #e9efe1;
  --line-dark: rgba(255,255,255,0.18);

  /* フォント */
  --font-display: "Hanken Grotesk", "Zen Kaku Gothic New", system-ui, sans-serif;
  --font-body:    "Inter", "Zen Kaku Gothic New", "Helvetica Neue", Arial, sans-serif;
  --font-jp:      "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;

  /* レイアウト */
  --maxw: 1280px;
  --gutter: clamp(2rem, 5vw, 7rem);
  --sec-y: clamp(7rem, 12vw, 16rem);

  /* モーション */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

*, *::before, *::after { box-sizing: border-box; }

html { font-size: 62.5%; -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 1.7rem;
  line-height: 1.6;
  color: var(--ink);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  word-break: auto-phrase;
  line-break: strict;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: 0; background: none; }
::selection { background: var(--terra); color: #fff; }

.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }
.skip-link { position: absolute; top: -200%; left: 0; background: var(--espresso); color: var(--paper-ink); padding: 1rem 1.6rem; z-index: 1000; }
.skip-link:focus { top: 0; }
.nowrap { white-space: nowrap; }

/* ---------- 2. タイポグラフィ ---------- */
.eyebrow {
  font-family: var(--font-body);
  font-size: 1.25rem; font-weight: 600;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--terra);
  display: inline-flex; align-items: center; gap: 1rem;
}
.eyebrow::before { content: ""; width: 2.4rem; height: 1px; background: currentColor; opacity: 0.6; }
.sec--dark .eyebrow { color: var(--amber); }

.display {
  font-family: var(--font-display);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 0.98;
  margin: 0;
  text-wrap: balance;
}
.d-hero { font-size: clamp(4.4rem, 9vw, 12rem); line-height: 0.92; letter-spacing: -0.04em; }
.d-1    { font-size: clamp(3.2rem, 5.5vw, 6.4rem); }
.d-2    { font-size: clamp(2.6rem, 3.6vw, 4rem); }
.lead   { font-size: clamp(1.7rem, 1.9vw, 2.1rem); line-height: 1.65; color: var(--ink-soft); max-width: 52ch; }
.sec--dark .lead { color: var(--paper-soft); }
em.hl { font-style: normal; color: var(--terra); }
.sec--dark em.hl { color: var(--amber); }

/* ---------- 3. ナビ ---------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: clamp(1.6rem, 2vw, 2.2rem) var(--gutter);
  transition: background 0.4s var(--ease), box-shadow 0.4s var(--ease), padding 0.4s var(--ease);
}
.nav.scrolled {
  background: rgba(238,243,234,0.9);
  backdrop-filter: saturate(1.1) blur(10px);
  box-shadow: 0 1px 0 var(--line);
  padding-top: 1.3rem; padding-bottom: 1.3rem;
}
.nav__brand { font-family: var(--font-display); font-weight: 800; font-size: 2rem; letter-spacing: -0.02em; display: flex; align-items: center; gap: 0.9rem; color: var(--ink); }
.nav__brand .dot { width: 1rem; height: 1rem; border-radius: 50%; background: var(--terra); }
.nav__links { display: flex; align-items: center; gap: clamp(1.8rem, 2.4vw, 3.2rem); }
.nav__links a { font-size: 1.45rem; font-weight: 500; color: var(--ink); opacity: 0.82; transition: opacity 0.2s, color 0.2s; }
.nav__links a:hover { opacity: 1; color: var(--terra); }
.nav__cta { display: inline-flex; }
.nav__burger { display: none; width: 4rem; height: 4rem; align-items: center; justify-content: center; font-size: 1.8rem; color: var(--ink); }

@media (max-width: 860px) {
  .nav__links { display: none; }
  .nav__burger { display: inline-flex; }
}

/* モバイルメニュー */
.mobile-menu {
  position: fixed; inset: 0; z-index: 199; background: var(--espresso); color: var(--paper-ink);
  display: flex; flex-direction: column; justify-content: center; padding: var(--gutter);
  clip-path: inset(0 0 100% 0); transition: clip-path 0.7s var(--ease); pointer-events: none;
}
.mobile-menu.open { clip-path: inset(0 0 0 0); pointer-events: auto; }
.mobile-menu a { font-family: var(--font-display); font-weight: 800; font-size: clamp(3.4rem, 9vw, 6rem); letter-spacing: -0.03em; padding: 0.6rem 0; transition: color 0.2s; }
.mobile-menu a:hover { color: var(--amber); }

/* ---------- 4. ボタン ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 0.9rem;
  font-family: var(--font-body); font-size: 1.4rem; font-weight: 600;
  padding: 1.15rem 1.8rem; border-radius: 6px; border: 1px solid transparent;
  transition: background 0.25s var(--ease), color 0.25s var(--ease), border-color 0.25s, transform 0.12s;
  letter-spacing: 0.01em;
}
.btn:active { transform: scale(0.97); }
.btn .arr { transition: transform 0.25s var(--ease); }
.btn:hover .arr { transform: translateX(4px); }
.btn--solid { background: var(--terra); color: #fff; border-color: var(--terra); }
.btn--solid:hover { background: var(--terra-dim); border-color: var(--terra-dim); }
.btn--dark { background: var(--espresso); color: var(--paper-ink); border-color: var(--espresso); }
.btn--dark:hover { background: #000; }
.btn--ghost { color: var(--ink); border-color: var(--line); }
.btn--ghost:hover { border-color: var(--ink); }
.sec--dark .btn--ghost { color: var(--paper-ink); border-color: var(--line-dark); }
.sec--dark .btn--ghost:hover { border-color: var(--paper-ink); }
.btn--light { background: var(--cream); color: var(--ink); border-color: var(--cream); }
.btn--light:hover { background: #fff; }

/* ---------- 5. セクション ---------- */
.sec { padding: var(--sec-y) 0; }
.sec--cream { background: var(--cream); }
.sec--paper { background: var(--paper); }
.sec--alt { background: var(--cream-2); }
.sec--dark { background: var(--espresso); color: var(--paper-ink); }

.sec__head { max-width: 80rem; margin-bottom: clamp(4rem, 6vw, 7rem); }
.sec__head .eyebrow { margin-bottom: 2.2rem; }
.sec__head .lead { margin-top: 2.4rem; }

/* ---------- 6. ヒーロー (明るい・都会的) ---------- */
.hero {
  position: relative; min-height: 100svh; display: flex; align-items: flex-end;
  background: var(--cream); color: var(--ink); overflow: hidden;
  padding: 14rem var(--gutter) clamp(5rem, 8vw, 9rem);
}
.hero__bg { position: absolute; inset: 0; z-index: 0; }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; opacity: 1; }
/* 明るい都会写真の上に、文字部(下/左)を明るくするライトスクリム */
.hero__bg::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(238,243,234,0.15) 0%, rgba(238,243,234,0.55) 48%, rgba(238,243,234,0.93) 100%),
    linear-gradient(100deg, rgba(238,243,234,0.88) 0%, rgba(238,243,234,0.45) 52%, rgba(238,243,234,0.05) 100%);
}
.hero__inner { position: relative; z-index: 1; width: 100%; max-width: var(--maxw); margin: 0 auto; }
.hero .eyebrow { color: var(--terra); margin-bottom: clamp(2.4rem, 3.5vw, 3.6rem); }
.hero__title { color: var(--ink); margin-bottom: clamp(2.6rem, 3.5vw, 3.6rem); }
.hero__foot { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: clamp(2.4rem, 4vw, 5rem); }
.hero__lead { color: var(--ink-soft); max-width: 46ch; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 1.2rem; margin-top: 2.8rem; }
.hero__scroll { font-size: 1.2rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-soft); display: inline-flex; align-items: center; gap: 0.9rem; }
.hero__scroll .ln { width: 3rem; height: 1px; background: var(--gold); display: inline-block; transform-origin: left; animation: scrollLn 1.8s var(--ease) infinite; }
@keyframes scrollLn { 0%,100%{ transform: scaleX(0.4);} 50%{ transform: scaleX(1);} }

/* ---------- 7. ロゴ/能力ストリップ ---------- */
.strip { background: var(--espresso-2); color: var(--paper-soft); border-top: 1px solid var(--line-dark); }
.strip__row { display: flex; flex-wrap: nowrap; justify-content: space-between; gap: clamp(1.2rem, 2vw, 2.4rem); padding: clamp(2rem, 2.6vw, 3rem) 0; align-items: center; }
.strip__row span { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.3rem, 1.5vw, 1.9rem); letter-spacing: -0.01em; opacity: 0.9; white-space: nowrap; }
.strip__row .sep { flex: 0 0 auto; width: 6px; height: 6px; border-radius: 50%; background: var(--amber); opacity: 0.9; }
@media (max-width: 700px) {
  .strip__row { flex-wrap: wrap; justify-content: center; gap: 1.2rem 2rem; }
  .strip__row .sep { display: none; }
}

/* ---------- 8. 3カラム (罫線区切り) ---------- */
.cols3 { display: grid; grid-template-columns: 1fr; gap: 0; }
@media (min-width: 800px) { .cols3 { grid-template-columns: repeat(3, 1fr); } }
.cols3 .col { padding: clamp(2.8rem, 3vw, 3.6rem) 0; border-top: 1px solid var(--line); }
@media (min-width: 800px) {
  .cols3 .col { padding: 0 clamp(2.4rem, 3vw, 4rem); border-top: 0; border-left: 1px solid var(--line); }
  .cols3 .col:first-child { padding-left: 0; border-left: 0; }
  .cols3 .col:last-child { padding-right: 0; }
}
.sec--dark .cols3 .col { border-color: var(--line-dark); }
.col__n { font-family: var(--font-body); font-size: 1.25rem; font-weight: 600; letter-spacing: 0.18em; color: var(--terra); margin-bottom: 1.6rem; }
.sec--dark .col__n { color: var(--amber); }
.col__h { font-family: var(--font-display); font-weight: 800; font-size: clamp(2rem, 2.4vw, 2.6rem); letter-spacing: -0.02em; margin: 0 0 1rem; }
.col__p { font-size: 1.5rem; color: var(--ink-soft); line-height: 1.65; }
.sec--dark .col__p { color: var(--paper-soft); }

/* ---------- 9. プロダクトUI埋め込みカード ---------- */
.uicard {
  border-radius: 12px; overflow: hidden; background: var(--paper);
  border: 1px solid var(--line); box-shadow: 0 30px 60px rgba(60,40,20,0.10);
}
.uicard__bar { display: flex; align-items: center; gap: 0.7rem; padding: 1.2rem 1.6rem; background: var(--cream-2); border-bottom: 1px solid var(--line); }
.uicard__bar i { width: 1.1rem; height: 1.1rem; border-radius: 50%; background: var(--sand); display: inline-block; }
.uicard__bar i:nth-child(1){ background:#e0795f; } .uicard__bar i:nth-child(2){ background:#e6b95a; } .uicard__bar i:nth-child(3){ background:#9cc08a; }
.uicard__bar .url { margin-left: 1rem; font-size: 1.2rem; color: var(--ink-soft); font-family: var(--font-body); }
.uicard__media { aspect-ratio: 16/10; overflow: hidden; background: var(--cream-2); }
.uicard__media img { width: 100%; height: 100%; object-fit: cover; }

.split { display: grid; gap: clamp(3rem, 5vw, 6rem); grid-template-columns: 1fr; align-items: center; }
@media (min-width: 940px) { .split { grid-template-columns: 1fr 1.05fr; } .split.rev { grid-template-columns: 1.05fr 1fr; } }

/* ---------- 10. 統計 ---------- */
.stats { display: grid; grid-template-columns: 1fr; gap: 0; }
@media (min-width: 900px) { .stats { grid-template-columns: repeat(3, 1fr); } }
.stat { padding: clamp(2.4rem, 3vw, 3rem) 0; border-top: 1px solid var(--line-dark); }
@media (min-width: 900px) { .stat { padding: 0 clamp(2rem, 2.5vw, 3rem); border-top: 0; border-left: 1px solid var(--line-dark); } .stat:first-child { padding-left: 0; border-left: 0; } }
.stat__num { font-family: var(--font-display); font-weight: 800; font-size: clamp(4rem, 6vw, 7.6rem); line-height: 0.92; letter-spacing: -0.04em; color: var(--paper-ink); }
.stat__num .u { color: var(--amber); }
.stat__label { font-size: 1.45rem; color: var(--paper-soft); margin-top: 1.2rem; line-height: 1.5; }

/* ---------- 11. ワークス (罫線リスト) ---------- */
.works { border-top: 1px solid var(--line); }
.work {
  display: grid; grid-template-columns: 1fr; gap: 1rem; align-items: center;
  border-bottom: 1px solid var(--line); padding: clamp(2.4rem, 3.5vw, 4rem) 0;
  transition: padding 0.4s var(--ease);
}
@media (min-width: 860px) { .work { grid-template-columns: 4.5rem 1.4fr 1.6fr auto; gap: clamp(2rem,3vw,4rem); } }
.work:hover { padding-left: 1.4rem; padding-right: 1.4rem; }
.work__n { font-size: 1.3rem; font-weight: 600; color: var(--ink-soft); letter-spacing: 0.1em; }
.work__title { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.4rem, 3.4vw, 4rem); letter-spacing: -0.03em; line-height: 1.02; margin: 0; transition: color 0.25s; }
.work:hover .work__title { color: var(--terra); }
.work__desc { font-size: 1.5rem; color: var(--ink-soft); max-width: 44ch; }
.work__tags { display: flex; flex-wrap: wrap; gap: 0.7rem; margin-top: 1rem; }
.work__tags span { font-size: 1.15rem; font-weight: 500; color: var(--ink-soft); border: 1px solid var(--line); border-radius: 50px; padding: 0.4rem 1.1rem; }
.work__go { font-size: 1.3rem; font-weight: 600; color: var(--terra); display: inline-flex; align-items: center; gap: 0.7rem; white-space: nowrap; }
.work__go .arr { transition: transform 0.25s var(--ease); }
.work:hover .work__go .arr { transform: translate(4px,-4px); }
/* ホバープレビュー */
.work-preview { position: fixed; top: 0; left: 0; width: 30rem; height: 20rem; border-radius: 10px; overflow: hidden; pointer-events: none; z-index: 150; opacity: 0; transform: translate(-50%,-50%) scale(0.92); transition: opacity 0.3s var(--ease), transform 0.3s var(--ease); box-shadow: 0 24px 60px rgba(0,0,0,0.3); }
.work-preview img { width: 100%; height: 100%; object-fit: cover; }
.work-preview.show { opacity: 1; }
@media (hover: none) { .work-preview { display: none; } }

/* ---------- 12. 映像ギャラリー ---------- */
.gallery { display: grid; gap: clamp(1rem, 1.4vw, 1.6rem); grid-template-columns: repeat(2, 1fr); }
@media (min-width: 700px) { .gallery { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1100px){ .gallery { grid-template-columns: repeat(5, 1fr); } }
.gtile { position: relative; aspect-ratio: 16/10; overflow: hidden; border-radius: 8px; display: block; background: var(--cream-2); }
.gtile img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s var(--ease); }
.gtile:hover img { transform: scale(1.06); }
.gtile__play { position: absolute; inset: 0; display: grid; place-items: center; color: #fff; font-size: 2.6rem; text-shadow: 0 2px 12px rgba(0,0,0,0.4); transition: transform 0.3s var(--ease), color 0.3s; }
.gtile:hover .gtile__play { transform: scale(1.15); color: var(--amber); }

/* ---------- 13. G.A.I.N.S. ---------- */
.gains { display: grid; gap: 0; grid-template-columns: 1fr; border-top: 1px solid var(--line); }
@media (min-width: 700px) { .gains { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1100px){ .gains { grid-template-columns: repeat(3,1fr); } }
.gcard {
  padding: clamp(2.6rem, 3vw, 3.6rem) clamp(2rem,2.5vw,3rem);
  border-bottom: 1px solid var(--line); border-right: 1px solid var(--line);
  cursor: pointer; min-height: 22rem; display: flex; flex-direction: column; gap: 1.2rem;
  transition: background 0.35s var(--ease), color 0.35s var(--ease);
}
.gcard:hover { background: var(--espresso); color: var(--paper-ink); }
.gcard__l { font-family: var(--font-display); font-weight: 800; font-size: clamp(3.4rem,4vw,5rem); line-height: 1; color: var(--terra); transition: color 0.3s; }
.gcard:hover .gcard__l { color: var(--amber); }
.gcard__t { font-family: var(--font-display); font-weight: 800; font-size: 2.1rem; letter-spacing: -0.01em; margin-top: auto; }
.gcard__t small { display: block; font-weight: 500; font-size: 1.3rem; color: var(--ink-soft); margin-top: 0.3rem; }
.gcard:hover .gcard__t small { color: var(--paper-soft); }
.gcard__go { font-size: 1.25rem; font-weight: 600; color: var(--terra); display: inline-flex; align-items: center; gap: 0.6rem; }
.gcard:hover .gcard__go { color: var(--amber); }
.gcard__go .arr { transition: transform 0.25s var(--ease); }
.gcard:hover .gcard__go .arr { transform: translateX(4px); }

/* ---------- 14. プロフィール ---------- */
.profile { display: grid; gap: clamp(3rem,5vw,6rem); grid-template-columns: 1fr; align-items: start; }
@media (min-width: 920px) { .profile { grid-template-columns: 0.85fr 1.15fr; } }
.profile__photo { position: relative; aspect-ratio: 4/5; border-radius: 12px; overflow: hidden; background: var(--espresso-2); }
.profile__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 18%; }
.profile__photo .badge { position: absolute; left: 1.4rem; bottom: 1.4rem; font-size: 1.2rem; font-weight: 600; letter-spacing: 0.06em; background: var(--terra); color: #fff; padding: 0.6rem 1.2rem; border-radius: 50px; }
.profile__name { font-family: var(--font-display); font-weight: 800; font-size: clamp(3.4rem,5vw,6rem); letter-spacing: -0.03em; line-height: 1; margin: 0 0 0.6rem; }
.profile__roma { font-size: 1.3rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--terra); margin-bottom: 2.6rem; }
.dtable { width: 100%; border-collapse: collapse; }
.dtable tr { border-top: 1px solid var(--line); }
.dtable tr:last-child { border-bottom: 1px solid var(--line); }
.dtable th, .dtable td { text-align: left; padding: 1.5rem 0; vertical-align: top; font-size: 1.5rem; line-height: 1.55; }
.dtable th { width: 26%; font-size: 1.2rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-soft); }
.profile__actions { display: flex; flex-wrap: wrap; gap: 1.2rem; align-items: center; margin-top: 2.6rem; }
.icon-btn { width: 4.6rem; height: 4.6rem; border-radius: 50%; border: 1px solid var(--line); display: grid; place-items: center; font-size: 1.6rem; color: var(--ink); transition: background 0.25s, color 0.25s, border-color 0.25s; }
.icon-btn:hover { background: var(--terra); border-color: var(--terra); color: #fff; }

/* ---------- 15. 予約 CTA ---------- */
.cta-big { font-family: var(--font-display); font-weight: 800; font-size: clamp(3.4rem, 7vw, 9rem); letter-spacing: -0.04em; line-height: 0.98; margin: 0; }
.booking__embed { margin-top: clamp(3rem,5vw,5rem); border-radius: 12px; overflow: hidden; background: var(--paper); border: 1px solid var(--line-dark); }
.booking__embed .scheduler-inline-widget, .booking__embed iframe { width: 100% !important; min-height: 680px; border: 0; }

/* ---------- 16. フッター ---------- */
.footer { background: var(--espresso); color: var(--paper-ink); padding: clamp(5rem,7vw,8rem) 0 clamp(3rem,4vw,4rem); }
.footer__top { display: flex; flex-wrap: wrap; justify-content: space-between; gap: clamp(3rem,5vw,6rem); align-items: flex-start; }
.footer__word { font-family: var(--font-display); font-weight: 800; font-size: clamp(4rem, 9vw, 11rem); letter-spacing: -0.04em; line-height: 0.9; }
.footer__word .dot { color: var(--terra); }
.footer__cols { display: grid; grid-template-columns: 1fr 1fr; gap: 2.4rem 4rem; }
.footer__col h4 { font-size: 1.15rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--paper-soft); margin: 0 0 1.4rem; }
.footer__col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.9rem; }
.footer__col a { font-size: 1.5rem; color: var(--paper-ink); opacity: 0.85; transition: color 0.2s, opacity 0.2s; }
.footer__col a:hover { color: var(--amber); opacity: 1; }
.footer__meta { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1.4rem; margin-top: clamp(4rem,6vw,6rem); padding-top: 2.4rem; border-top: 1px solid var(--line-dark); font-size: 1.25rem; color: var(--paper-soft); }

/* ---------- 17. モーダル ---------- */
.modal { position: fixed; inset: 0; z-index: 500; display: none; }
.modal.open { display: block; }
.modal__bg { position: absolute; inset: 0; background: rgba(20,16,12,0.62); backdrop-filter: blur(4px); }
.modal__panel { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: min(68rem, 92vw); max-height: 88vh; overflow: auto; background: var(--paper); border-radius: 14px; }
.modal__media { aspect-ratio: 16/9; overflow: hidden; background: var(--cream-2); }
.modal__media img { width: 100%; height: 100%; object-fit: cover; }
.modal__body { padding: clamp(2.6rem,3vw,4rem); }
.modal__body h3 { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.6rem,3.4vw,3.8rem); letter-spacing: -0.02em; margin: 0 0 0.3rem; display: flex; align-items: baseline; gap: 1rem; }
.modal__body h3 .l { color: var(--terra); }
.modal__body .sub { font-size: 1.2rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 2rem; }
.modal__body p { font-size: 1.6rem; line-height: 1.75; color: var(--ink-soft); }
.modal__body p b { color: var(--ink); }
.modal__close { position: absolute; top: 1.4rem; right: 1.4rem; z-index: 2; width: 4.4rem; height: 4.4rem; border-radius: 50%; background: var(--paper); border: 1px solid var(--line); font-size: 2rem; display: grid; place-items: center; }
.modal__close:hover { background: var(--cream-2); }

/* ---------- 18. リビール ---------- */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity 0.85s var(--ease-out), transform 0.85s var(--ease-out); }
.reveal.in { opacity: 1; transform: none; }
.rd-1 { transition-delay: 0.08s; } .rd-2 { transition-delay: 0.16s; } .rd-3 { transition-delay: 0.24s; }
.line-mask { overflow: hidden; display: block; }
.line-mask > * { display: block; transform: translateY(110%); transition: transform 1s var(--ease); }
.line-mask.in > * { transform: none; }

/* 「動きを減らす」OS設定でも、登場フェード/見出しスライド等の控えめな演出は活かす。
   連続・大振りな動き（装飾ループ・パララックス）だけ抑制する。
   → Windows等で「アニメーション効果OFF」のときに全演出が消える問題を解消（方針A）。 */
@media (prefers-reduced-motion: reduce) {
  .hero__scroll .ln { animation: none !important; }
  [data-parallax] { transform: none !important; }
}

/* 進捗バー */
.progress { position: fixed; top: 0; left: 0; height: 2px; width: 0%; background: var(--terra); z-index: 220; transition: width 0.1s linear; }
@media (prefers-reduced-motion: reduce) { .progress { display: none; } }

/* ---------- ワークス: サムネイルカードグリッド (クリックで開く) ---------- */
.workcards { display: grid; gap: clamp(1.6rem,2vw,2.6rem); grid-template-columns: 1fr; }
@media (min-width: 760px) { .workcards { grid-template-columns: repeat(2, 1fr); } }
.workcard {
  display: flex; flex-direction: column; background: var(--paper);
  border: 1px solid var(--line); border-radius: 14px; overflow: hidden;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), border-color .3s;
}
.workcard:hover { transform: translateY(-5px); box-shadow: 0 24px 50px rgba(47,49,49,0.13); border-color: var(--terra); }
.workcard__media { position: relative; aspect-ratio: 16/9; overflow: hidden; background: var(--cream-2); }
.workcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.workcard:hover .workcard__media img { transform: scale(1.05); }
.workcard__icon {
  position: absolute; right: 1.2rem; bottom: 1.2rem;
  width: 4.6rem; height: 4.6rem; border-radius: 50%;
  background: rgba(47,49,49,0.80); color: #fff; display: grid; place-items: center; font-size: 1.8rem;
  transition: background .3s, transform .3s var(--ease);
}
.workcard:hover .workcard__icon { background: var(--terra); transform: scale(1.08); }
.workcard__body { padding: clamp(2rem,2.4vw,2.8rem); display: flex; flex-direction: column; gap: 1rem; flex: 1; }
.workcard__n { font-size: 1.2rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--terra); }
.workcard__title { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.2rem,2.8vw,3.2rem); letter-spacing: -0.02em; margin: 0; line-height: 1.05; }
.workcard__desc { font-size: 1.5rem; color: var(--ink-soft); line-height: 1.62; }
.workcard__tags { display: flex; flex-wrap: wrap; gap: .7rem; }
.workcard__tags span { font-size: 1.15rem; font-weight: 500; color: var(--ink-soft); border: 1px solid var(--line); border-radius: 50px; padding: .4rem 1.1rem; }
.workcard__go { margin-top: auto; padding-top: .4rem; font-size: 1.3rem; font-weight: 600; color: var(--terra); display: inline-flex; align-items: center; gap: .7rem; }
.workcard__go .arr { transition: transform .25s var(--ease); }
.workcard:hover .workcard__go .arr { transform: translate(4px,-4px); }

/* レスポンシブ改行: PC専用<br>（スマホでは無効化し自然な折返しに） */
.br-pc { display: none; }
@media (min-width: 768px) { .br-pc { display: inline; } }

/* ヒーロー見出し: 行マスクのoverflow:hiddenで開き括弧「の上が切れるのを防ぐ
   （上側に余白を確保し、margin相殺で見た目の位置は維持） */
.hero__title .line-mask { padding-top: 0.14em; margin-top: -0.14em; }
