@charset "utf-8";

/* ============================================================
   432hz Tuning Guitar  -  style.css
   テーマ：上品な宇宙（luxury × cosmic） 藍 × 金
   ※色・余白・フォントは下の :root（CSS変数）で一括管理します。
============================================================ */

/* フォント読み込み（英字＝Cormorant Garamond／和文＝Noto Serif JP） */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Noto+Serif+JP:wght@300;400;500&display=swap');

/* スクロール表示アニメ（流用） */
@import url("inview.css");


/* ------------------------------------------------------------
   デザイントークン（ここを変えるとサイト全体の印象が変わります）
------------------------------------------------------------ */
:root {
  --c-bg:        #0d1b2e;  /* メイン背景：深い藍 */
  --c-bg-2:      #16263f;  /* やや明るい藍（セクション切替に） */
  --c-bg-3:      #0a1422;  /* さらに暗い藍（フッター等） */
  --c-gold:      #e0a942;  /* アクセントの金 */
  --c-gold-2:    #f0b94e;  /* 明るい金（ホバー等） */
  --c-glow:      #d98a3d;  /* 温かい光の差し色 */
  --c-text:      #f3eee2;  /* 文字（温かいクリーム） */
  --c-text-mut:  rgba(243, 238, 226, 0.68); /* 控えめな文字 */
  --c-line:      rgba(224, 169, 66, 0.22);  /* 金の細い罫線 */

  --max-w:  1200px;  /* コンテンツ最大幅 */
  --space:  6vw;     /* 左右の余白（一括管理） */
  --header-h: 72px;  /* ヘッダーの高さ */

  --font-en: "Cormorant Garamond", serif;
  --font-jp: "Noto Serif JP", serif;
}

@media screen and (max-width: 640px) {
  :root { --space: 22px; --header-h: 60px; }
}


/* ------------------------------------------------------------
   ベース / リセット
------------------------------------------------------------ */
* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--c-bg);
  color: var(--c-text);
  font-family: var(--font-jp);
  font-weight: 300;
  line-height: 1.9;
  letter-spacing: 0.02em;
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; vertical-align: middle; border: 0; }
ul { margin: 0; padding: 0; list-style: none; }
a  { color: inherit; text-decoration: none; transition: 0.3s; }

/* 固定ヘッダー分だけ、アンカー移動先に余白をつける */
section[id], main > section { scroll-margin-top: calc(var(--header-h) + 16px); }


/* ------------------------------------------------------------
   ヘッダー（ヒーローに重なる半透明バー → スクロールで濃くなる）
------------------------------------------------------------ */
#header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  height: var(--header-h);
  display: flex;
  align-items: center;
  background: transparent;
  transition: background 0.4s, backdrop-filter 0.4s, border-color 0.4s;
  border-bottom: 1px solid transparent;
}
/* スクロール後（main.js が .scrolled を付与） */
#header.scrolled {
  background: rgba(10, 20, 34, 0.82);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--c-line);
}

.header-inner {
  width: 100%;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--space);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* ロゴ（テキスト版） */
.logo {
  font-family: var(--font-en);
  font-size: 1.5rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--c-text);
  white-space: nowrap;
}
.logo span { color: var(--c-gold); font-style: italic; }

/* グローバルナビ */
#nav ul { display: flex; gap: 1.7rem; }
#nav a {
  position: relative;
  font-size: 0.92rem;
  color: var(--c-text);
  padding: 4px 0;
}
/* ホバーで金の下線がのびる */
#nav a::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 0; height: 1px;
  background: var(--c-gold);
  transition: width 0.3s;
}
#nav a:hover { color: var(--c-gold-2); }
#nav a:hover::after { width: 100%; }

/* ハンバーガー（スマホのみ表示） */
#hamburger {
  display: none;
  position: relative;
  width: 40px; height: 32px;
  padding: 0; border: 0;
  background: transparent;
  cursor: pointer;
  z-index: 110;
}
#hamburger span {
  position: absolute;
  left: 6px;
  width: 28px; height: 2px;
  background: var(--c-text);
  transition: 0.35s;
}
#hamburger span:nth-child(1) { top: 9px; }
#hamburger span:nth-child(2) { top: 16px; }
#hamburger span:nth-child(3) { top: 23px; }
#hamburger.open span:nth-child(1) { top: 16px; transform: rotate(45deg); }
#hamburger.open span:nth-child(2) { opacity: 0; }
#hamburger.open span:nth-child(3) { top: 16px; transform: rotate(-45deg); }


/* ------------------------------------------------------------
   ① ヒーローセクション
------------------------------------------------------------ */
.hero {
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  align-items: center;
  background-image: url("../images/hero.jpg");
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

/* スマホ用の縦長画像を用意したら、下のコメントを外して使えます
@media screen and (max-width: 640px) {
  .hero { background-image: url("../images/hero-sp.jpg"); }
}
*/

/* 文字を読みやすくする為の、左を暗くするグラデーション */
.hero-scrim {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(100deg,
      rgba(8, 16, 30, 0.80) 0%,
      rgba(8, 16, 30, 0.45) 38%,
      rgba(8, 16, 30, 0.05) 66%,
      transparent 100%);
  pointer-events: none;
}

.hero-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--space);
}

/* 小見出し（金） */
.hero-kicker {
  margin: 0 0 1.2rem;
  font-family: var(--font-en);
  font-size: 1.05rem;
  font-style: italic;
  letter-spacing: 0.18em;
  color: var(--c-gold);
  opacity: 0;
  animation: heroUp 1s ease 0.3s forwards;
}

/* メインタイトル */
.hero-title {
  margin: 0;
  font-family: var(--font-en);
  font-weight: 500;
  font-size: clamp(2.8rem, 8vw, 5.6rem);
  line-height: 1.05;
  letter-spacing: 0.01em;
  text-shadow: 0 2px 30px rgba(0, 0, 0, 0.45);
  opacity: 0;
  animation: heroUp 1.1s ease 0.55s forwards;
}

/* サブ（guitarist : Masura） */
.hero-sub {
  margin: 1rem 0 2.2rem;
  font-size: 1.05rem;
  letter-spacing: 0.22em;
  color: var(--c-text-mut);
  opacity: 0;
  animation: heroUp 1.1s ease 0.8s forwards;
}

/* 金の細い区切り線 */
.hero-sub::before {
  content: "";
  display: inline-block;
  width: 38px; height: 1px;
  margin-right: 16px;
  vertical-align: middle;
  background: var(--c-gold);
}

/* 3つのTuning名が入れ替わる枠 */
.tuning-rotator {
  position: relative;
  height: 2.4em;
  margin: 0;
  font-family: var(--font-en);
  font-style: italic;
  font-size: clamp(1.4rem, 3.4vw, 2.1rem);
  letter-spacing: 0.06em;
  opacity: 0;
  animation: heroUp 1.1s ease 1.05s forwards;
}
.tuning-rotator span {
  position: absolute;
  left: 0; top: 0;
  white-space: nowrap;
  color: var(--c-gold-2);
  opacity: 0;
  animation: tuneCycle 9s ease-in-out infinite;
}
.tuning-rotator span:nth-child(1) { animation-delay: 1.4s; }
.tuning-rotator span:nth-child(2) { animation-delay: 4.4s; }
.tuning-rotator span:nth-child(3) { animation-delay: 7.4s; }

/* 下へスクロールを促す矢印 */
.hero-scroll {
  position: absolute;
  left: 50%; bottom: 26px;
  transform: translateX(-50%);
  z-index: 2;
  font-size: 1.3rem;
  color: var(--c-text);
  opacity: 0;
  animation: heroUp 1s ease 1.4s forwards, floatY 2.2s ease-in-out 1.4s infinite;
}

/* --- ヒーロー用キーフレーム --- */
@keyframes heroUp {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes tuneCycle {
  0%   { opacity: 0; transform: translateY(10px); }
  7%   { opacity: 1; transform: translateY(0); }
  28%  { opacity: 1; transform: translateY(0); }
  35%  { opacity: 0; transform: translateY(-10px); }
  100% { opacity: 0; }
}
@keyframes floatY {
  0%, 100% { transform: translate(-50%, 0); }
  50%      { transform: translate(-50%, 8px); }
}


/* ------------------------------------------------------------
   汎用パーツ（ボタン・見出しなど。各セクションで使い回します）
------------------------------------------------------------ */
.section {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 5vw var(--space);
}

/* セクション見出し（英字サブ付き） */
.heading {
  text-align: center;
  margin: 0 0 3rem;
}
.heading .en {
  display: block;
  font-family: var(--font-en);
  font-style: italic;
  font-size: 1rem;
  letter-spacing: 0.2em;
  color: var(--c-gold);
  margin-bottom: 0.4rem;
}
.heading .jp {
  font-size: 1.7rem;
  font-weight: 400;
  letter-spacing: 0.08em;
}

/* 金枠の上品なボタン */
.btn {
  display: inline-block;
  padding: 0.7rem 2.6rem;
  font-family: var(--font-en);
  font-size: 1rem;
  letter-spacing: 0.12em;
  color: var(--c-gold-2);
  border: 1px solid var(--c-gold);
  border-radius: 100px;
}
.btn:hover { background: var(--c-gold); color: var(--c-bg); }


/* ------------------------------------------------------------
   ② ご挨拶セクション
------------------------------------------------------------ */
.greeting-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5vw;
  align-items: center;
}

/* 写真（金の細枠＋左上にさりげない金のアクセント） */
.greeting-photo {
  margin: 0;
  position: relative;
}
.greeting-photo img {
  display: block;
  width: 100%;
  border: 1px solid var(--c-line);
}
.greeting-photo::before {
  content: "";
  position: absolute;
  left: -10px; top: -10px;
  width: 56px; height: 56px;
  border-left: 1px solid var(--c-gold);
  border-top: 1px solid var(--c-gold);
}
.greeting-photo::after {
  content: "";
  position: absolute;
  right: -10px; bottom: -10px;
  width: 56px; height: 56px;
  border-right: 1px solid var(--c-gold);
  border-bottom: 1px solid var(--c-gold);
}

/* 本文 */
.greeting-text p { margin: 0 0 1.4rem; }
.greeting-sign {
  font-family: var(--font-en);
  font-style: italic;
  letter-spacing: 0.1em;
  color: var(--c-gold);
}

/* スマホでは縦積み（写真→文章） */
@media screen and (max-width: 768px) {
  .greeting-grid { grid-template-columns: 1fr; gap: 2.6rem; }
}


/* ------------------------------------------------------------
   ③ 使用ギターセクション（自動スライド）
------------------------------------------------------------ */
.guitars { padding: 5vw 0; }

/* 見出しだけ左右に余白をつける（スライダーは横いっぱい） */
.section-pad { padding-left: var(--space); padding-right: var(--space); }

/* スライダーの外枠（はみ出しを隠す） */
.guitar-marquee {
  width: 100%;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}

/* 流れる帯（画像2セット分が横に並ぶ） */
.guitar-track {
  display: flex;
  align-items: flex-start;   /* 段違いにする為、上揃え */
  width: max-content;
  padding: 10px 0 58px;      /* 段違いで下にずれる分の余白 */
  animation: guitarScroll 55s linear infinite;
}
/* マウスを乗せると一時停止 */
.guitar-marquee:hover .guitar-track { animation-play-state: paused; }

/* 1枚あたり（装飾なし・あっさりギャラリー風） */
.guitar-card {
  flex: 0 0 auto;
  width: 248px;
  margin: 0 26px 0 0;   /* 右マージンで等間隔（ループを途切れさせない為） */
}
/* 偶数番目を下にずらして段違いに */
.guitar-card:nth-child(even) { margin-top: 48px; }

.guitar-card img {
  display: block;
  width: 100%;
  aspect-ratio: 2 / 3;   /* 縦長 600×900 に対応 */
  object-fit: cover;
}

/* 2セット分の幅のちょうど半分だけ動かすと、継ぎ目なくループします */
@keyframes guitarScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* スマホでは少し小さく＆速さ控えめに */
@media screen and (max-width: 640px) {
  .guitar-card { width: 168px; margin-right: 16px; }
  .guitar-card:nth-child(even) { margin-top: 30px; }
  .guitar-track { animation-duration: 42s; padding-bottom: 40px; }
}


/* ------------------------------------------------------------
   ④ 使用機材セクション
------------------------------------------------------------ */
.gear-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.6vw;
}

/* 上段：アンプセット（横長2点） */
.amp-grid {
  grid-template-columns: repeat(2, 1fr);
  margin-bottom: 2.6vw;
}
.amp-grid .gear-card figure.wide {
  aspect-ratio: 3 / 2;   /* 横長 1200×800 に対応 */
}

.gear-card figure {
  margin: 0 0 1rem;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border: 1px solid var(--c-line);
}
.gear-card img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.7s ease;
}
.gear-card:hover img { transform: scale(1.06); }

.gear-name {
  margin: 0;
  font-size: 1.05rem;
  letter-spacing: 0.04em;
}
.gear-cat {
  margin: 0.2rem 0 0;
  font-family: var(--font-en);
  font-style: italic;
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  color: var(--c-gold);
}

/* 7点目以降は最初は隠しておく */
.gear-card.is-more { display: none; }
/* 「もっとみる」展開時に表示してフェードイン */
.gear-grid.expanded .gear-card.is-more {
  display: block;
  animation: gearFade 0.6s ease both;
}
@keyframes gearFade {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* もっとみるボタンの配置 */
.gear-more-wrap { text-align: center; margin-top: 3.2rem; }

/* レスポンシブ */
@media screen and (max-width: 768px) {
  .gear-grid { grid-template-columns: repeat(2, 1fr); gap: 4vw; }
  .amp-grid { grid-template-columns: 1fr; }
}


/* ------------------------------------------------------------
   ⑤ オリジナルTuning紹介セクション
------------------------------------------------------------ */
.tuning-block {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 5vw;
  align-items: center;
  margin-bottom: 6vw;
}
.tuning-block:last-child { margin-bottom: 0; }

/* 偶数（reverse）は画像を右に。
   列幅も入れ替えて、写真が常に同じ幅（狭い方の列）になるようにする */
.tuning-block.reverse { grid-template-columns: 1.15fr 0.85fr; }
.tuning-block.reverse .tuning-photo { order: 2; }

/* メインギター写真（縦長＋金のコーナーアクセント） */
.tuning-photo {
  margin: 0;
  position: relative;
}
.tuning-photo img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border: 1px solid var(--c-line);
}
.tuning-photo::before {
  content: "";
  position: absolute;
  left: -10px; top: -10px;
  width: 50px; height: 50px;
  border-left: 1px solid var(--c-gold);
  border-top: 1px solid var(--c-gold);
}

/* テキスト側 */
.tuning-no {
  display: block;
  font-family: var(--font-en);
  font-style: italic;
  font-size: 3.6rem;
  line-height: 1;
  color: var(--c-gold);
  opacity: 0.4;
}
.tuning-name {
  margin: 0.3rem 0 1.2rem;
  font-family: var(--font-en);
  font-weight: 500;
  font-size: 2.2rem;
  letter-spacing: 0.03em;
  color: var(--c-text);
}
/* 名前の下の金の細線 */
.tuning-name::after {
  content: "";
  display: block;
  width: 54px; height: 1px;
  margin-top: 1rem;
  background: var(--c-gold);
}
.tuning-text p { margin: 0 0 1.1rem; }
.tuning-text p:last-child { margin-bottom: 0; }

/* 試聴ボタン */
.tuning-audio { margin: 1.6rem 0 0.6rem; }
.audio-btn {
  -webkit-appearance: none; appearance: none; cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.55rem 1.6rem;
  font-family: var(--font-en);
  font-size: 0.95rem;
  letter-spacing: 0.1em;
  color: var(--c-gold-2);
  background: transparent;
  border: 1px solid var(--c-gold);
  border-radius: 100px;
  transition: 0.3s;
}
.audio-btn:hover,
.audio-btn.is-playing {
  background: var(--c-gold);
  color: var(--c-bg);
}

/* 詳しく見る（テキストリンク風トグル） */
.detail-toggle {
  -webkit-appearance: none; appearance: none; cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 1.4rem;
  padding: 0;
  font-family: var(--font-jp);
  font-size: 0.95rem;
  color: var(--c-gold);
  background: none;
  border: 0;
  border-bottom: 1px solid var(--c-line);
  transition: 0.3s;
}
.detail-toggle::after {
  content: "›";
  font-family: var(--font-en);
  transform: rotate(90deg);
  transition: transform 0.3s;
}
.detail-toggle[aria-expanded="true"]::after { transform: rotate(-90deg); }
.detail-toggle:hover { color: var(--c-gold-2); border-color: var(--c-gold); }

/* 展開される詳細 */
.tuning-detail { display: none; margin-top: 1.3rem; }
.tuning-detail.is-open {
  display: block;
  animation: gearFade 0.5s ease both;
}

/* スマホでは縦積み（写真→文章。reverseでも順序を統一） */
@media screen and (max-width: 768px) {
  .tuning-block,
  .tuning-block.reverse {
    grid-template-columns: 1fr;
    gap: 2rem;
    margin-bottom: 3.5rem;
  }
  .tuning-block.reverse .tuning-photo { order: 0; }
  .tuning-no { font-size: 3rem; }
  .tuning-name { font-size: 1.8rem; }
}


/* ------------------------------------------------------------
   ⑥ アラン・ホールズワースとの物語セクション
------------------------------------------------------------ */
.story {
  background: var(--c-bg-2);              /* 一段明るい藍で特別感 */
  border-top: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
  padding: 6vw 0;
}
.story-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--space);
}

.story-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5vw;
  align-items: center;
}

/* 貴重な写真（比率は実写真のまま。コーナーアクセント付き） */
.story-photo {
  margin: 0;
  position: relative;
}
.story-photo img {
  display: block;
  width: 100%;
  height: auto;
  border: 1px solid var(--c-line);
}
.story-photo::after {
  content: "";
  position: absolute;
  right: -12px; bottom: -12px;
  width: 60px; height: 60px;
  border-right: 1px solid var(--c-gold);
  border-bottom: 1px solid var(--c-gold);
}
.story-photo figcaption {
  margin-top: 0.9rem;
  font-family: var(--font-en);
  font-style: italic;
  font-size: 0.9rem;
  letter-spacing: 0.1em;
  color: var(--c-gold);
  text-align: right;
}

/* 本文 */
.story-lead {
  font-family: var(--font-en);
  font-style: italic;
  font-size: 1.5rem;
  line-height: 1.6;
  color: var(--c-gold-2);
  margin: 0 0 1.6rem;
}
.story-text p { margin: 0 0 1.3rem; }
.story-text p:last-child { margin-bottom: 0; }

/* スマホでは縦積み */
@media screen and (max-width: 768px) {
  .story-grid { grid-template-columns: 1fr; gap: 2.4rem; }
  .story-lead { font-size: 1.3rem; }
}


/* ------------------------------------------------------------
   ⑦ 音源紹介セクション
------------------------------------------------------------ */
.music-lead {
  text-align: center;
  margin: -1.5rem 0 3rem;
  color: var(--c-text-mut);
}

.music-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.6vw;
}

.music-card { display: block; }

/* サムネイル枠（16:9） */
.music-thumb {
  position: relative;
  margin: 0 0 1rem;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border: 1px solid var(--c-line);
  background: var(--c-bg-2);
}
.music-thumb img,
.music-thumb iframe {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border: 0;
  transition: transform 0.7s ease;
}
.music-card:hover .music-thumb img { transform: scale(1.05); }

/* 再生ボタン */
.music-play {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 64px; height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  color: var(--c-text);
  background: rgba(10, 20, 34, 0.55);
  border: 1px solid var(--c-line);
  border-radius: 50%;
  transition: 0.3s;
}
.music-play i { margin-left: 3px; }   /* 三角を少し中央寄せ */
.music-card:hover .music-play {
  background: var(--c-gold);
  color: var(--c-bg);
  border-color: var(--c-gold);
}

/* テキスト */
.music-title { margin: 0; font-size: 1.05rem; letter-spacing: 0.04em; }
.music-meta {
  margin: 0.2rem 0 0;
  font-family: var(--font-en);
  font-style: italic;
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  color: var(--c-gold);
}

/* href が付いた（公開済みの）カードはリンクとして手のひらカーソルに */
a.music-card[href] { cursor: pointer; }

/* レスポンシブ */
@media screen and (max-width: 768px) {
  .music-grid { grid-template-columns: 1fr; gap: 2rem; max-width: 420px; margin: 0 auto; }
}


/* ------------------------------------------------------------
   ⑧ お問い合わせセクション
------------------------------------------------------------ */
.contact-lead {
  text-align: center;
  margin: -1.5rem 0 3rem;
  color: var(--c-text-mut);
}

.contact-form {
  max-width: 600px;
  margin: 0 auto;
}
.form-row { margin-bottom: 1.5rem; }
.form-row label {
  display: block;
  margin-bottom: 0.5rem;
  font-size: 0.9rem;
  letter-spacing: 0.08em;
  color: var(--c-text-mut);
}
.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: 0.9rem 1rem;
  font-family: var(--font-jp);
  font-size: 1rem;
  color: var(--c-text);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--c-line);
  border-radius: 4px;
  transition: border-color 0.3s, background 0.3s;
}
.contact-form input:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--c-gold);
  background: rgba(255, 255, 255, 0.06);
}
.contact-form textarea { resize: vertical; min-height: 150px; line-height: 1.8; }

/* 送信ボタン（金の塗りCTA） */
.contact-submit { text-align: center; margin-top: 2.4rem; }
.btn-send {
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
  display: inline-block;
  padding: 0.8rem 3.6rem;
  font-family: var(--font-en);
  font-size: 1.05rem;
  letter-spacing: 0.14em;
  color: var(--c-bg);
  background: var(--c-gold);
  border: 1px solid var(--c-gold);
  border-radius: 100px;
  transition: 0.3s;
}
.btn-send:hover { background: var(--c-gold-2); border-color: var(--c-gold-2); }


/* ------------------------------------------------------------
   フッター
------------------------------------------------------------ */
#footer {
  background: var(--c-bg-3);
  border-top: 1px solid var(--c-line);
  padding: 4rem var(--space) 0;
}
.footer-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: space-between;
  align-items: flex-start;
}
.footer-logo {
  margin: 0 0 0.6rem;
  font-family: var(--font-en);
  font-size: 1.5rem;
  font-weight: 500;
  letter-spacing: 0.04em;
}
.footer-logo span { color: var(--c-gold); font-style: italic; }
.footer-note { margin: 0; font-size: 0.85rem; color: var(--c-text-mut); }
.footer-contact p { margin: 0 0 0.3rem; font-size: 0.9rem; color: var(--c-text-mut); }

.footer-sns { display: flex; gap: 1.1rem; margin-top: 1rem; font-size: 1.25rem; }
.footer-sns a:hover { color: var(--c-gold); }

.copyright {
  display: block;
  max-width: var(--max-w);
  margin: 3rem auto 0;
  padding-bottom: 1.4rem;
  font-family: var(--font-en);
  font-size: 0.78rem;
  letter-spacing: 0.05em;
  color: var(--c-text-mut);
  text-align: center;
}

/* テンプレート著作表示（控えめに） */
.pr a {
  display: block;
  text-align: right;
  padding: 0.4rem var(--space);
  font-size: 0.72rem;
  color: rgba(243, 238, 226, 0.4);
  background: rgba(0, 0, 0, 0.25);
}
.pr a:hover { color: var(--c-gold); }


/* ------------------------------------------------------------
   ページトップへ戻るボタン
------------------------------------------------------------ */
.pagetop {
  position: fixed;
  right: 22px; bottom: 22px;
  z-index: 90;
  width: 46px; height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--c-text);
  border: 1px solid var(--c-line);
  border-radius: 50%;
  background: rgba(10, 20, 34, 0.6);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  opacity: 0;
  pointer-events: none;
  transition: 0.4s;
}
.pagetop.show { opacity: 1; pointer-events: auto; }
.pagetop:hover { color: var(--c-gold); border-color: var(--c-gold); }


/* ------------------------------------------------------------
   レスポンシブ：スマホ用ナビ（ハンバーガー展開）
------------------------------------------------------------ */
@media screen and (max-width: 900px) {
  #hamburger { display: block; }

  #nav {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(10, 20, 34, 0.97);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.4s;
  }
  #nav.open { opacity: 1; pointer-events: auto; }

  #nav ul {
    flex-direction: column;
    align-items: center;
    gap: 1.6rem;
  }
  #nav a { font-size: 1.3rem; font-family: var(--font-en); letter-spacing: 0.1em; }

  /* メニュー展開中は背面スクロールを止める */
  body.noscroll { overflow: hidden; }
}
