/* ===================================================================
   apt ホームページ 共通スタイルシート（style.css）
   ===================================================================
   このファイルは「サイト全体の見た目」をまとめて管理するファイルです。
   全ページがこのファイルを読み込んでいるので、
   ここを変えると全ページのデザインが一括で変わります。

   ▼ 色を変えたいとき
   すぐ下の「:root」の中の色コードを書き換えてください。
   例：--sage（メインの緑）を変えると、ボタンやロゴの色が全部変わります。
   =================================================================== */

:root {
  /* ▼▼▼ ブランドカラー（ここを変えると全ページの色が変わります）▼▼▼ */
  --bg: #FFFFFF;          /* 背景（白）*/
  --bg-soft: #F7F8F5;     /* やわらかい背景（うすいグレージュ）*/
  --bg-sage: #EEF1EB;     /* セージ系のうすい背景 */
  --sage: #8DA088;        /* メインのセージグリーン（少し明るめに調整）*/
  --sage-mid: #AEBCAA;    /* 中間のセージ */
  --sage-light: #CFD9CB;  /* うすいセージ */
  --sage-deep: #6E8268;   /* 濃いセージ（ボタンなどに使用／前より明るく）*/
  --sage-footer: #3F4A3C; /* フッター背景用（黒に近い緑→やわらかい深緑に）*/
  --text: #33352F;        /* 文字の基本色（チャコール系。真っ黒を避けた）*/
  --text-mid: #5F665A;    /* 中間の文字色 */
  --text-light: #939C8E;  /* うすい文字色（補足など）*/
  --line: rgba(51,53,47,0.1); /* 区切り線の色 */
  /* ▲▲▲ ここまでが色の設定 ▲▲▲ */

  /* ▼ 余白の基準（変更不要）*/
  --pad-side: 56px;       /* 左右の余白（パソコン）*/
}

/* ===================================================================
   基本設定（触らなくてOK）
   =================================================================== */

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--text);
  /* 和文：丸みのある読みやすいフォント／英文：シンプルなサンセリフ */
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-weight: 300;
  line-height: 1.7;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* ===================================================================
   ヘッダー（全ページ共通の上部メニュー）
   =================================================================== */

.site-header {
  position: fixed;          /* スクロールしても上に固定 */
  top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 8px var(--pad-side);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: rgba(255,255,255,0.9);
  backdrop-filter: blur(12px); /* 背景をうっすらぼかす */
  border-bottom: 1px solid transparent;
  transition: border-color 0.3s;
}
.site-header.scrolled { border-bottom-color: var(--line); }

/* ロゴ（apt の文字）*/
.site-logo {
  font-family: 'Cormorant', serif;
  font-size: 22px;
  font-weight: 400;
  letter-spacing: 0.4em;
  color: var(--sage-deep);
}
/* ロゴを画像にしたとき用（縦長ロゴなので高さ基準で調整）*/
.logo-img { height: 64px; width: auto; display: block; }

/* ============================================================
   写真プレースホルダー用の共通クラス（.ph-photo）
   各プレースホルダーに入れた写真が、枠にぴったり収まるよう調整。
   写真ファイルが無いときは onerror で自動的に隠れ、緑の枠が見えます。
   ============================================================ */
.ph-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover; /* 枠に合わせてトリミング（はみ出さない）*/
  z-index: 1;
}

/* パソコン用メニュー */
.site-nav {
  display: flex;
  gap: 36px;
  align-items: center;
  list-style: none;
}
.site-nav a {
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--text-light);
  text-transform: uppercase;
  transition: color 0.3s;
  position: relative;
}
.site-nav a::after {
  content: '';
  position: absolute;
  bottom: -5px; left: 0;
  width: 0; height: 1px;
  background: var(--sage);
  transition: width 0.3s;
}
.site-nav a:hover { color: var(--sage-deep); }
.site-nav a:hover::after { width: 100%; }

/* ヘッダー右の「撮影のご相談」ボタン（サイトのセージに馴染ませた色）*/
.header-line-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 22px;
  background: var(--sage-deep);  /* サイトのセージグリーンに統一 */
  color: #fff !important;
  font-size: 11px;
  letter-spacing: 0.1em;
  border-radius: 4px;
  transition: background 0.3s;
}
.header-line-btn:hover { background: var(--sage); }

/* ハンバーガーメニュー（スマホで出る三本線。パソコンでは隠す）*/
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 6px; }
.hamburger span { display: block; width: 24px; height: 1.5px; background: var(--sage-deep); transition: 0.3s; }

/* スマホ用の全画面メニュー（最初は隠れている）*/
.mobile-menu {
  position: fixed; inset: 0;
  background: #fff; z-index: 200;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 32px;
  transform: translateX(100%); /* 画面の外に隠しておく */
  transition: transform 0.4s ease;
}
.mobile-menu.open { transform: translateX(0); } /* openが付くと出てくる */
.mobile-menu a { font-family: 'Cormorant', serif; font-size: 26px; font-weight: 400; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sage-deep); }
.mobile-menu-close { position: absolute; top: 24px; right: 28px; font-size: 32px; color: var(--text-light); background: none; border: none; cursor: pointer; }

/* ===================================================================
   ボタンの共通デザイン
   =================================================================== */

/* メインボタン（濃いセージ）*/
.btn {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 16px 40px;
  background: var(--sage-deep);
  color: #fff;
  font-size: 12px;
  letter-spacing: 0.2em;
  transition: background 0.3s;
  cursor: pointer;
  border: none;
}
.btn:hover { background: var(--sage); }

/* 枠線だけのボタン */
.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 15px 38px;
  border: 1px solid var(--sage-deep);
  color: var(--sage-deep);
  font-size: 12px;
  letter-spacing: 0.2em;
  transition: all 0.3s;
}
.btn-outline:hover { background: var(--sage-deep); color: #fff; }

/* ===================================================================
   セクション共通（各まとまりの余白や見出し）
   =================================================================== */

section { padding: 110px var(--pad-side); }

/* 小さなラベル見出し（例：「— ABOUT」）*/
.section-label {
  display: flex; align-items: center; gap: 16px;
  font-size: 10px; letter-spacing: 0.35em;
  text-transform: uppercase; color: var(--sage);
  margin-bottom: 36px;
}
.section-label::before { content: ''; width: 28px; height: 1px; background: var(--sage); }

/* 大きな見出し（日本語）→ Klee One（手書き風）に統一 */
.section-title {
  font-family: 'Klee One', cursive;
  font-weight: 400;
  font-size: clamp(24px, 3.4vw, 38px);
  line-height: 1.7;
  letter-spacing: 0.04em;
  color: var(--text-mid);    /* チャコール寄り */
}

/* ===================================================================
   フッター（全ページ共通の最下部）
   =================================================================== */

.site-footer { background: var(--sage-footer); padding: 52px var(--pad-side) 36px; }
.footer-top {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding-bottom: 36px; border-bottom: 1px solid rgba(255,255,255,0.08); margin-bottom: 28px;
}
.footer-logo { font-family: 'Cormorant', serif; font-size: 26px; font-weight: 300; letter-spacing: 0.4em; color: #fff; }
/* フッターのロゴ画像（白版）用サイズ */
.footer-logo-img { height: 72px; width: auto; display: block; margin-bottom: 4px; }
.footer-tagline { font-size: 11px; letter-spacing: 0.15em; color: rgba(255,255,255,0.3); margin-top: 8px; }
.footer-nav { display: flex; flex-wrap: wrap; gap: 28px; }
.footer-nav a { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255,255,255,0.45); transition: color 0.3s; }
.footer-nav a:hover { color: var(--sage-light); }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.footer-copy { font-size: 10px; letter-spacing: 0.15em; color: rgba(255,255,255,0.25); }
.footer-line { display: inline-flex; align-items: center; gap: 8px; padding: 9px 20px; background: var(--sage); color: #fff; font-size: 11px; border-radius: 4px; transition: opacity 0.3s; }
.footer-line:hover { opacity: 0.85; }

/* ===================================================================
   スクロールでふわっと出てくる動き（共通）
   =================================================================== */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.9s ease, transform 0.9s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ===================================================================
   スマホ表示の調整（画面幅768px以下のとき適用）
   ===================================================================
   スマホで見る人が多いので、ここで見やすく整えています。
   =================================================================== */
@media (max-width: 768px) {
  :root { --pad-side: 22px; } /* 左右の余白を狭く */

  .site-nav { display: none; }   /* パソコン用メニューは隠す */
  .header-line-btn { display: none; } /* ヘッダーのLINEボタンも隠す（メニュー内に入れる）*/
  .hamburger { display: flex; }  /* 三本線メニューを表示 */

  section { padding: 72px var(--pad-side); }

  .footer-top { flex-direction: column; gap: 24px; }
}

/* パソコンのときはハンバーガーとスマホメニューを隠す */
@media (min-width: 769px) {
  .hamburger, .mobile-menu { display: none; }
}
