/* ═══════════════════════════════════════════════════════════
   style-v2.css — v2 デザイン専用の上書きCSS
   -----------------------------------------------------------
   適用範囲: index-v2.astro および今後v2デザインに切り替えるページのみ
   読み込み方: <Base> の ogImage 等の props 拡張で個別指定する、
              または該当ページで <link rel="stylesheet" href="/css/style-v2.css"> を追加する
   原則: style.css は絶対に触らない。差分はすべてここで上書きする。
   先生OK後、本番統合時にこのファイルの内容を style.css に反映する。
   ═══════════════════════════════════════════════════════════ */

/* ========== Header ========== */
.v2-apply .header {
  background: rgba(255,255,255,0.96);
  border-bottom: 1px solid rgba(232, 224, 216, 0.5);
  backdrop-filter: blur(12px);
}
.v2-apply .header-inner {
  padding: 18px 24px;
}
.v2-apply .logo {
  font-size: 17px;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1.4;
}
.v2-apply .logo span {
  font-size: 10px;
  letter-spacing: 0.3em;
  margin-bottom: 3px;
}

/* ========== Header CTA ボタン（緑LINEに統一） ========== */
.v2-apply .btn-reserve {
  background: #00B900;
  padding: 11px 22px;
  font-size: 13px;
  letter-spacing: 0.1em;
  border-radius: 999px;
  box-shadow: 0 4px 14px rgba(0,185,0,0.25);
}
.v2-apply .btn-reserve:hover {
  background: #00a300;
  box-shadow: 0 6px 18px rgba(0,185,0,0.35);
}

/* ========== Nav（ダークベージュ寄り） ========== */
.v2-apply .nav {
  background: #1f1a12;
}
.v2-apply .nav a {
  padding: 14px 22px;
  color: rgba(245, 239, 224, 0.82);
  letter-spacing: 0.12em;
}
.v2-apply .nav a:hover {
  color: #d4a84b;
  background: rgba(212, 168, 75, 0.08);
}
.v2-apply .dropdown-menu {
  background: #1f1a12;
  min-width: 600px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.25);
  padding: 20px 0;
}
.v2-apply .dropdown-columns {
  grid-template-columns: repeat(3, 1fr);
}

/* ========== ページヘッダー（施術詳細・料金等のサブページ上部） ========== */
.v2-apply .page-header {
  background: linear-gradient(180deg, #faf8f5 0%, #f2e9d6 100%);
  padding: 72px 20px 60px;
}
.v2-apply .page-header::after {
  content: none;
}
.v2-apply .page-header h1 {
  font-family: var(--serif);
  font-size: clamp(28px, 5vw, 38px);
  font-weight: 500;
  letter-spacing: 0.12em;
  margin-top: 6px;
}
.v2-apply .page-header .en {
  font-size: 12px;
  letter-spacing: 0.35em;
}

/* ========== パンくず ========== */
.v2-apply .breadcrumb {
  padding: 14px 20px;
  font-size: 11px;
  letter-spacing: 0.1em;
  background: transparent;
  border-bottom: 1px solid var(--border);
}

/* ========== CTA帯（フッター直上） ========== */
.v2-apply .cta {
  background: linear-gradient(135deg, #2c2418 0%, #3a2f20 100%);
  padding: 80px 20px;
}
.v2-apply .cta::before {
  content: none;
}
.v2-apply .cta-inner {
  max-width: 600px;
  margin: 0 auto;
}
.v2-apply .cta-decoration {
  margin-bottom: 16px;
  opacity: 0.8;
}
.v2-apply .cta-en {
  font-size: 12px;
  color: #d4a84b;
  letter-spacing: 0.35em;
  margin-bottom: 12px;
}
.v2-apply .cta h2 {
  font-family: var(--serif);
  font-size: clamp(24px, 4vw, 32px);
  margin-bottom: 18px;
  letter-spacing: 0.1em;
  font-weight: 500;
  line-height: 1.5;
}
.v2-apply .cta p {
  color: #e8d9b5;
  margin-bottom: 32px;
  line-height: 1.9;
}
.v2-apply .btn-reserve-cta {
  font-size: 16px;
  padding: 20px 64px;
  background: #00B900;
  border-radius: 999px;
  font-weight: 600;
  letter-spacing: 0.15em;
  box-shadow: 0 12px 32px rgba(0,185,0,0.35);
}
.v2-apply .btn-reserve-cta:hover { background: #00a300; }

/* ========== Footer ========== */
.v2-apply .footer {
  background: #1a1510;
  color: rgba(232, 217, 181, 0.55);
  padding: 64px 20px 28px;
}
.v2-apply .footer-inner {
  gap: 48px;
  margin: 0 auto 36px;
}
.v2-apply .footer-logo {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1.5;
  margin-bottom: 18px;
}
.v2-apply .footer-logo span {
  font-size: 10px;
  color: #d4a84b;
  letter-spacing: 0.3em;
  margin-bottom: 4px;
}
.v2-apply .footer-info p {
  color: rgba(232, 217, 181, 0.6);
}
.v2-apply .footer-nav a {
  color: rgba(232, 217, 181, 0.6);
  font-size: 12px;
  line-height: 2.3;
  letter-spacing: 0.05em;
}
.v2-apply .footer-nav a:hover {
  color: #d4a84b;
}
.v2-apply .footer-copy {
  font-size: 11px;
  letter-spacing: 0.15em;
  color: rgba(232, 217, 181, 0.35);
  padding-top: 24px;
  border-top: 1px solid rgba(232, 217, 181, 0.1);
}
