/* =========================================================
   PLUSULTRA renewal — Studio edition
   方向性: 禁欲 / 格調 / アーティストが運営するスタジオ
   参照したトーン: 静謐なコマーシャル（装飾でなく削りで攻める）
   ========================================================= */

:root {
  --bg:        #0c0c0b;   /* ほぼ黒（わずかに温かい） */
  --bg-2:      #121211;
  --ink:       #f7f5f0;   /* 本文（生成りの白・コントラスト強化） */
  --ink-soft:  #b3afa4;   /* サブ・キャプション（暗さを持ち上げ可読性UP） */
  --ink-faint: #6a665c;   /* 罫線文字・極小注記 */
  --line:      #2f2d29;   /* 罫線 */

  --serif-en: "Cormorant Garamond", "Times New Roman", serif;
  --mincho:   "Shippori Mincho", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --mincho-thin: "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", serif; /* 見出し・リード用の細い明朝 */

  /* ---- タイポグラフィ・スケール（新素材研究所を基準に抑制的・格調重視）----
     見出しと本文の差を控えめに。叫ばず、字間広め、ウェイト軽め。 */
  --fs-hero:    clamp(1.45rem, 3.8vw, 2.4rem);   /* ヒーロー大見出し */
  --fs-title:   clamp(1.75rem, 4.2vw, 2.6rem);   /* セクションタイトル（英斜体） */
  --fs-lead-l:  clamp(1.45rem, 3.6vw, 2.2rem);   /* 大リード（Philosophy） */
  --fs-lead-m:  clamp(1.25rem, 2.8vw, 1.7rem);   /* 中リード（eye-lead / statement / process-en / field-en） */
  --fs-lead-s:  clamp(1.1rem, 2.2vw, 1.35rem);   /* 小リード（approach導入 / dual-head） */
  --fs-body:    clamp(0.95rem, 1.5vw, 1.02rem);  /* 本文（全セクション共通） */
  --fs-small:   0.82rem;                          /* 注記・キャプション・小ラベル */
  --fs-label:   0.8rem;                           /* 英ラベル（section-no / nav） */

  /* 字間 */
  --ls-wide:   0.24em;   /* 英ラベル・サブ */
  --ls-mid:    0.1em;    /* 見出し英・小ラベル */
  --ls-body:   0.08em;   /* 和文本文・和文見出し */

  /* 行間 */
  --lh-body:   2.0;      /* 本文 */
  --lh-lead:   1.8;      /* リード */
  --lh-tight:  1.5;      /* 大見出し */

  --maxw: 1040px;
  --gutter: clamp(1.5rem, 6vw, 6rem);
  --section-y: clamp(6rem, 16vw, 14rem);

  --ease: cubic-bezier(0.19, 1, 0.22, 1);
}

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

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

body {
  font-family: var(--mincho);
  font-weight: 400;            /* 繊細に。暗背景の細りはスムージングで補う */
  color: var(--ink);
  background: var(--bg);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  letter-spacing: var(--ls-body);
  font-feature-settings: "palt";
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
img { max-width: 100%; display: block; }

/* 画像のカジュアル保護：ドラッグ・選択を抑止（完全防止は不可） */
.hero-img, .eye-img, img {
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  user-select: none;
  -webkit-touch-callout: none;   /* iOS の長押し保存メニューを抑止 */
}

/* ---------- Reveal（拘束的な動き：静かに、ゆっくり） ---------- */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1.4s var(--ease), transform 1.4s var(--ease);
  will-change: opacity, transform;
}
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  html { scroll-behavior: auto; }
}

/* =========================================================
   Header
   ========================================================= */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.75rem var(--gutter);
  transition: background .6s var(--ease), padding .6s var(--ease), border-color .6s var(--ease);
  border-bottom: 1px solid transparent;
}
.site-header.scrolled {
  background: rgba(12, 12, 11, 0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 1.1rem var(--gutter);
  border-bottom: 1px solid var(--line);
}
.brand {
  font-family: var(--serif-en);
  font-size: 1.15rem;
  font-weight: 400;
  letter-spacing: 0.3em;
}
.nav {
  display: flex;
  gap: clamp(1.25rem, 3vw, 2.5rem);
  font-family: var(--serif-en);
  font-size: var(--fs-label);
  letter-spacing: var(--ls-mid);
}
.nav a { position: relative; padding-bottom: 2px; color: var(--ink-soft); transition: color .4s var(--ease); }
.nav a:hover { color: var(--ink); }
.nav-toggle { display: none; }

/* =========================================================
   Hero
   ========================================================= */
.hero {
  position: relative;
  min-height: 78svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: var(--gutter);
  overflow: hidden;
}
.hero-media { position: absolute; inset: 0; z-index: -1; }
.hero-img {
  width: 100%; height: 100%;
  /* ヒーロー実写。差し替える場合は url() のファイル名を変更。 */
  background: #14161a url("images/M10M6948.jpg") center center / cover no-repeat;
  filter: saturate(0.92);
}
.hero-img::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(12,12,11,.2), rgba(12,12,11,.7));
}
.hero-title {
  font-family: var(--mincho-thin);
  font-weight: 300;
  font-size: var(--fs-hero);
  line-height: var(--lh-tight);
  letter-spacing: 0.3em;
  text-indent: 0.3em;
  white-space: nowrap;
}
.hero-eyebrow {
  position: absolute;
  bottom: clamp(2rem, 5vw, 3.5rem);
  left: var(--gutter);
  font-family: var(--serif-en);
  font-style: italic;
  font-size: var(--fs-small);
  letter-spacing: var(--ls-wide);
  color: var(--ink-soft);
}
.hero-caption {
  position: absolute;
  top: clamp(6rem, 14vw, 8rem);
  left: var(--gutter);
  font-family: var(--serif-en);
  font-size: var(--fs-small);
  letter-spacing: var(--ls-wide);
  color: var(--ink-soft);
  font-style: italic;
}
.scroll-cue {
  position: absolute;
  bottom: clamp(2rem, 5vw, 3.5rem);
  right: var(--gutter);
}
.scroll-line {
  display: block;
  width: 1px; height: 64px;
  background: var(--ink-faint);
  position: relative; overflow: hidden;
}
.scroll-line::after {
  content: ""; position: absolute; top: -100%; left: 0;
  width: 100%; height: 100%; background: var(--ink);
  animation: scrollMove 2.6s var(--ease) infinite;
}
@keyframes scrollMove { 0% { top: -100% } 65%,100% { top: 100% } }

/* =========================================================
   Statement
   ========================================================= */
.statement {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: var(--section-y) var(--gutter);
  text-align: center;
}
.statement-lead {
  font-family: var(--mincho-thin);
  font-size: clamp(1.45rem, 3.8vw, 2.4rem);   /* 冒頭の語りかけ。Philosophy大リードと同等〜やや上 */
  font-weight: 300;
  letter-spacing: 0.04em;
  line-height: 1.65;
  margin-bottom: clamp(2.25rem, 4.5vw, 3rem);
  white-space: nowrap;   /* 広い画面では1行に強制（折り返し防止） */
}
.sp-only { display: none; }   /* スマホ専用の改行。広い画面では非表示 */
.statement-body {
  max-width: 720px;
  margin: 0 auto;
  font-size: var(--fs-body);
  color: var(--ink-soft);
  line-height: var(--lh-body);
}

/* =========================================================
   共通セクション
   ========================================================= */
.section {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: var(--section-y) var(--gutter);
  border-top: 1px solid var(--line);
}
.section-head {
  display: flex;
  align-items: baseline;
  gap: 1.5rem;
  margin-bottom: clamp(3.5rem, 8vw, 6rem);
  flex-wrap: wrap;
}
.section-no {
  font-family: var(--serif-en);
  font-size: var(--fs-label);
  letter-spacing: var(--ls-wide);
  color: var(--ink-faint);
}
.section-title {
  font-family: var(--serif-en);
  font-size: var(--fs-title);
  font-weight: 400;
  font-style: italic;
  letter-spacing: 0.04em;
}
.section-sub {
  font-size: var(--fs-small);
  letter-spacing: var(--ls-wide);
  color: var(--ink-soft);
}

/* =========================================================
   PHILOSOPHY
   ========================================================= */
.philosophy-lead {
  font-family: var(--mincho-thin);
  font-size: var(--fs-lead-l);
  font-weight: 300;
  line-height: var(--lh-lead);
  letter-spacing: 0.04em;
  margin-bottom: clamp(2.5rem, 6vw, 4rem);
  white-space: nowrap;   /* 広い画面では1行に強制 */
}
.philosophy-body {
  max-width: 660px;
  display: grid;
  gap: 1.6rem;
}
.philosophy-body p {
  font-size: var(--fs-body);
  color: var(--ink-soft);
  line-height: var(--lh-body);
}
.philosophy-body strong {
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--ls-body);
}

/* =========================================================
   STORY
   ========================================================= */
.story-body {
  max-width: 660px;
  display: grid;
  gap: 1.6rem;
}
.story-body p {
  font-size: var(--fs-body);
  color: var(--ink-soft);
  line-height: var(--lh-body);
}
.story-sign {
  margin-top: 1.5rem;
  text-align: right;
  color: var(--ink) !important;
  letter-spacing: var(--ls-mid);
}

/* =========================================================
   ABOUT
   ========================================================= */
.about-note {
  max-width: 660px;
  font-size: var(--fs-body);
  color: var(--ink-soft);
  line-height: var(--lh-body);
}

/* =========================================================
   EYE
   ========================================================= */
.eye-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: clamp(2.5rem, 7vw, 6rem);
  align-items: start;
}
.eye-photo figcaption {
  margin-top: 1rem;
  font-family: var(--serif-en);
  font-size: var(--fs-small);
  font-style: italic;
  letter-spacing: var(--ls-mid);
  color: var(--ink-soft);
  line-height: 1.8;
}
.eye-img {
  aspect-ratio: 2 / 3;   /* 画像の比率に一致（840×1261）。トリミング構図を切らず表示 */
  /* 代表写真。差し替える場合は url() のファイル名を変更。 */
  background: #161512 url("images/DaisukeKinoshita-profile.jpg") center center / cover no-repeat;
}
.eye-lead {
  font-family: var(--mincho-thin);
  font-size: var(--fs-lead-m);
  font-weight: 300;
  line-height: var(--lh-lead);
  letter-spacing: 0.04em;
  margin-bottom: 2rem;
  white-space: nowrap;   /* 広い画面では1行に強制 */
}
.eye-body {
  font-size: var(--fs-body);
  color: var(--ink-soft);
  line-height: var(--lh-body);
  margin-bottom: 1.5rem;
}
.dual {
  margin-top: clamp(2.5rem, 5vw, 3.5rem);
  padding-top: clamp(2rem, 4vw, 2.75rem);
  border-top: 1px solid var(--line);
}
.dual-head {
  font-family: var(--mincho-thin);
  font-size: var(--fs-lead-s);
  font-weight: 300;
  letter-spacing: 0.04em;
  margin-bottom: 1.25rem;
}
.dual-body {
  font-size: var(--fs-body);
  color: var(--ink-soft);
  line-height: var(--lh-body);
}

/* =========================================================
   APPROACH
   ========================================================= */
/* セクション導入文（Approach / Fields 共用） */
.approach-lead {
  max-width: 660px;
  margin-bottom: clamp(3rem, 7vw, 5rem);
  font-family: var(--mincho-thin);
  font-size: var(--fs-lead-s);
  font-weight: 300;
  line-height: var(--lh-lead);
  letter-spacing: 0.04em;
  color: var(--ink);
}

.process { display: grid; }
.process-step {
  display: grid;
  grid-template-columns: 64px 1fr;
  grid-template-areas: "num en" ". ja" ". note";
  column-gap: clamp(1.5rem, 4vw, 3rem);
  padding: clamp(1.5rem, 3.5vw, 2.5rem) 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.process-step:first-child { border-top: 1px solid var(--line); }
.process-num {
  grid-area: num;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 1rem;
  color: var(--ink-faint);
}
.process-en {
  grid-area: en;
  font-family: var(--serif-en);
  font-size: var(--fs-lead-m);
  font-weight: 400;
  letter-spacing: 0.04em;
  transition: transform .6s var(--ease), color .6s var(--ease);
  color: var(--ink);
}
.process-step:hover .process-en { transform: translateX(14px); }
.process-ja {
  grid-area: ja;
  font-size: var(--fs-body);
  color: var(--ink);
  margin-top: 0.4rem;
}
.process-note {
  grid-area: note;
  max-width: 36em;
  font-size: var(--fs-small);
  color: var(--ink-soft);
  line-height: 1.9;
  margin-top: 0.6rem;
}

/* =========================================================
   FIELDS
   ========================================================= */
.fields-list { display: grid; }
.field {
  display: grid;
  grid-template-columns: 2.5rem 1fr;
  grid-template-areas: "no en" ". ja";
  column-gap: clamp(1.25rem, 3vw, 2.25rem);
  row-gap: 0.5rem;
  padding: clamp(1.6rem, 3.5vw, 2.5rem) 0;
  border-bottom: 1px solid var(--line);
}
.field:first-child { border-top: 1px solid var(--line); }
.field-no {
  grid-area: no;
  font-family: var(--serif-en);
  font-style: italic;
  font-size: 1rem;
  color: var(--ink-faint);
  padding-top: 0.4rem;
}
.field-en {
  grid-area: en;
  font-family: var(--serif-en);
  font-size: var(--fs-lead-m);
  font-weight: 400;
  letter-spacing: 0.04em;
  line-height: 1.3;
}
.field-ja {
  grid-area: ja;
  font-size: var(--fs-body);
  color: var(--ink-soft);
  letter-spacing: var(--ls-body);
}

/* =========================================================
   CONTACT
   ========================================================= */
.contact { text-align: center; border-bottom: 1px solid var(--line); }
.contact-inner { max-width: 640px; margin: 0 auto; }
.contact-title {
  font-family: var(--mincho-thin);
  font-size: var(--fs-lead-l);
  font-weight: 300;
  letter-spacing: 0.04em;
  line-height: var(--lh-lead);
  margin-bottom: 1.75rem;
}
.contact-note {
  font-size: var(--fs-body);
  color: var(--ink-soft);
  margin-bottom: 3rem;
  letter-spacing: var(--ls-body);
  line-height: var(--lh-body);
}
.contact-btn {
  display: inline-block;
  font-family: var(--serif-en);
  font-size: var(--fs-small);
  font-style: italic;
  letter-spacing: var(--ls-wide);
  color: var(--ink);
  border: 1px solid var(--ink-faint);
  border-radius: 999px;
  padding: 1rem 3.5rem;
  transition: background .45s var(--ease), color .45s var(--ease), border-color .45s var(--ease);
}
.contact-btn:hover {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}

/* =========================================================
   Footer
   ========================================================= */
.site-footer {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: clamp(3rem, 6vw, 4.5rem) var(--gutter);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 2rem;
  flex-wrap: wrap;
}
.footer-brand {
  font-family: var(--serif-en);
  font-size: 1.05rem;
  letter-spacing: 0.28em;
}
.footer-meta { text-align: right; font-size: var(--fs-small); color: var(--ink-soft); line-height: 1.9; }
.footer-link { border-bottom: 1px solid var(--line); transition: border-color .4s var(--ease); }
.footer-link:hover { border-color: var(--ink-soft); }
.footer-copy { font-family: var(--serif-en); font-style: italic; letter-spacing: var(--ls-mid); }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 768px) {
  .sp-only { display: inline; }           /* スマホでは改行を有効化 */
  .statement-lead,
  .philosophy-lead,
  .eye-lead { white-space: normal; } /* スマホでは折り返し許可 */

  .nav { display: none; }
  .nav.open {
    display: flex;
    position: fixed; inset: 0;
    background: var(--bg);
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 2.5rem;
    font-size: 1.3rem;
    z-index: 90;
  }
  .nav.open a { color: var(--ink); }
  .nav-toggle {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
    width: 32px; height: 32px;
    background: none; border: none; cursor: pointer;
    z-index: 110;
  }
  .nav-toggle span {
    display: block; width: 26px; height: 1px; background: var(--ink);
    transition: transform .4s var(--ease), opacity .4s var(--ease);
  }
  .nav-toggle.open span:nth-child(1) { transform: translateY(3.5px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2) { transform: translateY(-3.5px) rotate(-45deg); }

  .eye-grid { grid-template-columns: 1fr; }
  .eye-photo { max-width: 360px; }
  .process-step { grid-template-columns: 40px 1fr; }
  .field { grid-template-columns: 2rem 1fr; }
  .field-no { padding-top: 0.3rem; }
  .footer-meta { text-align: left; }
  .hero-caption { right: var(--gutter); left: var(--gutter); }
}
