/*
 * Theme Name:  Sanctuary Divi Child
 * Theme URI:   https://sanctuary-h.com/
 * Description: 上野サンクチュアリ専用 Divi 子テーマ — Noir Elegance 配色
 *              2026年リデザイン / ラグジュアリーダークモード
 * Author:      Sanctuary Design Team
 * Author URI:  https://sanctuary-h.com/
 * Template:    Divi
 * Version:     1.2.4
 * License:     GNU General Public License v2 or later
 * License URI: http://www.gnu.org/licenses/gpl-2.0.html
 * Text Domain: sanctuary-divi-child
 *
 * ============================================================
 * NOIR ELEGANCE — カラーパレット定義
 * ============================================================
 *
 * ベースカラー
 *   --color-bg-base      : #0D0D0D  (Midnight Black)    — ページ背景
 *   --color-bg-surface   : #1A1A1A  (Charcoal Surface)  — カード・セクション背景
 *   --color-bg-elevated  : #242424  (Elevated Surface)  — ホバー・フォーカス背景
 *
 * アクセントカラー
 *   --color-gold         : #C9A96E  (Antique Gold)      — メインアクセント・CTA・見出し
 *   --color-gold-light   : #DFC08A  (Light Gold)        — ホバー時のゴールド
 *   --color-rose         : #C97B8A  (Dusty Rose)        — サブアクセント・バッジ・タグ
 *
 * ⚠️ 色覚バリアフリー注意事項（赤緑色盲対応）
 *   Dusty Rose (#C97B8A) は赤緑色盲（Deuteranopia/Protanopia）の方には
 *   くすみ緑〜グレー系に見えます。
 *   このカラーを「情報の識別」に単独使用することは避け、
 *   必ずアイコン・テキストラベル・形状と組み合わせて使用してください。
 *   CTAボタンの主色には --color-gold を使用し、
 *   --color-rose は装飾・タグ・バッジ等の補助的用途に限定してください。
 *
 * テキストカラー
 *   --color-text-primary : #F0EDE5  (Warm White)        — 本文・見出しテキスト
 *   --color-text-muted   : #8A93BD  (Stone Gray)        — 補助テキスト・キャプション
 *   --color-text-gold    : #C9A96E  (Antique Gold)      — 強調テキスト
 *
 * ボーダー
 *   --color-border       : rgba(201,169,110,0.2)        — 通常ボーダー
 *   --color-border-hover : rgba(201,169,110,0.6)        — ホバー時ボーダー
 *
 * フォント
 *   見出し : 'Noto Serif JP', 'Cormorant Garamond', serif
 *   本文   : 'Noto Sans JP', 'Inter', sans-serif
 *
 * ============================================================
 */

/* ============================================================
   0. CSS カスタムプロパティ（デザイントークン）
   ============================================================ */
:root {
  /* ベースカラー */
  --color-bg-base:      #0D0D0D;
  --color-bg-surface:   #1A1A1A;
  --color-bg-elevated:  #242424;

  /* アクセント */
  --color-gold:         #C9A96E;
  --color-gold-light:   #DFC08A;
  --color-gold-dark:    #A8834A;
  --color-rose:         #C97B8A;
  --color-rose-light:   #DFA0AE;

  /* テキスト */
  --color-text-primary: #F0EDE5;
  --color-text-muted:   #8A93BD;
  --color-text-gold:    #C9A96E;
  --color-text-dim:     #6B6B6B;

  /* ボーダー */
  --color-border:       rgba(201, 169, 110, 0.20);
  --color-border-hover: rgba(201, 169, 110, 0.60);
  --color-border-subtle:rgba(255, 255, 255, 0.06);

  /* グラスモーフィズム */
  --glass-bg:           rgba(26, 26, 26, 0.80);
  --glass-blur:         blur(20px);
  --glass-border:       rgba(201, 169, 110, 0.15);

  /* スペーシング */
  --space-xs:   0.5rem;
  --space-sm:   1rem;
  --space-md:   2rem;
  --space-lg:   4rem;
  --space-xl:   8rem;

  /* フォントサイズ */
  --text-xs:    0.75rem;
  --text-sm:    0.875rem;
  --text-base:  1rem;
  --text-lg:    1.125rem;
  --text-xl:    1.25rem;
  --text-2xl:   1.5rem;
  --text-3xl:   2rem;
  --text-4xl:   2.5rem;
  --text-5xl:   3.5rem;
  --text-display: clamp(2.5rem, 6vw, 5rem);

  /* ボーダーラジウス */
  --radius-sm:  4px;
  --radius-md:  8px;
  --radius-lg:  16px;
  --radius-full: 9999px;

  /* トランジション */
  --transition-fast:   150ms ease;
  --transition-base:   300ms ease;
  --transition-slow:   600ms ease;

  /* シャドウ */
  --shadow-gold:  0 0 30px rgba(201, 169, 110, 0.15);
  --shadow-card:  0 4px 24px rgba(0, 0, 0, 0.6);
  --shadow-hover: 0 8px 40px rgba(0, 0, 0, 0.8);
}


/* ============================================================
   1. リセット・ベーススタイル
   ============================================================ */
*,
*::before,
*::after {
  box-sizing: border-box;
}

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

/* Diviビジュアルビルダー・管理画面以外のbodyにのみ適用 */
body:not(.et-fb):not(.wp-admin) {
  color: var(--color-text-primary) !important;
  font-family: 'Noto Sans JP', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
  font-size: var(--text-base);
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* #page-container はDiviビルダーiframe外（フロントエンド）のみ適用 */
body:not(.et-fb):not(.wp-admin) #page-container,
body:not(.et-fb-root-ancestor):not(.wp-admin) #page-container {
  color: var(--color-text-primary) !important;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Diviビジュアルビルダー・管理画面以外のaタグにのみ適用 */
body:not(.et-fb):not(.wp-admin) a {
  color: var(--color-gold);
  text-decoration: none;
  transition: color var(--transition-base);
}

body:not(.et-fb):not(.wp-admin) a:hover {
  color: var(--color-gold-light);
}

/* フォーカス可視性（アクセシビリティ） */
:focus-visible {
  outline: 2px solid var(--color-gold);
  outline-offset: 3px;
}


/* ============================================================
   2. タイポグラフィ
   ============================================================ */

/* Google Fonts 読み込み（functions.php でも wp_enqueue_style 推奨） */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=Noto+Serif+JP:wght@300;400;600&family=Noto+Sans+JP:wght@300;400;500&family=Inter:wght@300;400;500&display=swap');

/* Diviビジュアルビルダー・管理画面以外のh1-h6・pにのみ適用 */
body:not(.et-fb):not(.wp-admin) h1,
body:not(.et-fb):not(.wp-admin) h2,
body:not(.et-fb):not(.wp-admin) h3,
body:not(.et-fb):not(.wp-admin) h4,
body:not(.et-fb):not(.wp-admin) h5,
body:not(.et-fb):not(.wp-admin) h6,
.et_pb_text h1,
.et_pb_text h2,
.et_pb_text h3,
.et_pb_text h4 {
  font-family: 'Noto Serif JP', 'Cormorant Garamond', Georgia, serif !important;
  color: var(--color-text-primary) !important;
  font-weight: 300 !important;
  letter-spacing: 0.05em;
  line-height: 1.3;
}

body:not(.et-fb):not(.wp-admin) h1, .et_pb_text h1 { font-size: clamp(2rem, 5vw, 3.5rem) !important; }
body:not(.et-fb):not(.wp-admin) h2, .et_pb_text h2 { font-size: clamp(1.5rem, 3.5vw, 2.5rem) !important; }
body:not(.et-fb):not(.wp-admin) h3, .et_pb_text h3 { font-size: clamp(1.25rem, 2.5vw, 1.75rem) !important; }
body:not(.et-fb):not(.wp-admin) h4, .et_pb_text h4 { font-size: var(--text-xl) !important; }

body:not(.et-fb):not(.wp-admin) p,
.et_pb_text p {
  font-family: 'Noto Sans JP', 'Inter', sans-serif !important;
  color: var(--color-text-primary) !important;
  font-size: var(--text-base) !important;
  line-height: 1.8 !important;
}

/* セクション英語サブラベル */
.sanctuary-section-label {
  font-family: 'Inter', sans-serif;
  font-size: var(--text-xs);
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-gold);
  display: block;
  margin-bottom: var(--space-xs);
}

/* 金色テキスト強調 */
.text-gold,
.et_pb_text .text-gold {
  color: var(--color-gold) !important;
}

/* ミュートテキスト */
.text-muted,
.et_pb_text .text-muted {
  color: var(--color-text-muted) !important;
  font-size: var(--text-sm) !important;
}


/* ============================================================
   3. Divi グローバル上書き
   ============================================================ */

/* ページ背景 */
#main-content,
.et_pb_section,
.et-l,
.et-l--post,
.et-l--footer {
  background-color: transparent !important;
}

/* Divi デフォルトのボーダー・シャドウをリセット */
.et_pb_module {
  border: none !important;
  box-shadow: none !important;
}

/* Divi のデフォルトリンク色 */
.et_pb_text a {
  color: var(--color-gold) !important;
}

/* Divi ブログモジュール */
.et_pb_post {
  background-color: var(--color-bg-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  overflow: hidden;
  transition: transform var(--transition-base), box-shadow var(--transition-base) !important;
}

.et_pb_post:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--shadow-hover) !important;
  border-color: var(--color-border-hover) !important;
}

.et_pb_post .post-content,
.et_pb_post .post-meta {
  color: var(--color-text-muted) !important;
}

/* Divi ギャラリー */
.et_pb_gallery_item {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  overflow: hidden;
}

/* Divi タブ */
.et_pb_tabs_controls {
  background-color: var(--color-bg-surface) !important;
  border-bottom: 1px solid var(--color-border) !important;
}

.et_pb_tabs_controls li {
  border: none !important;
  background: transparent !important;
}

.et_pb_tabs_controls li a {
  color: var(--color-text-muted) !important;
  font-family: 'Noto Sans JP', sans-serif !important;
  font-size: var(--text-sm) !important;
  letter-spacing: 0.1em;
  padding: 0.75rem 1.5rem !important;
  transition: color var(--transition-base) !important;
}

.et_pb_tabs_controls li.et_pb_tab_active a,
.et_pb_tabs_controls li:hover a {
  color: var(--color-gold) !important;
}

.et_pb_tabs_controls li.et_pb_tab_active {
  border-bottom: 2px solid var(--color-gold) !important;
}

.et_pb_tab {
  background-color: var(--color-bg-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-top: none !important;
  padding: var(--space-md) !important;
}

/* Divi アコーディオン */
.et_pb_accordion .et_pb_toggle {
  background-color: var(--color-bg-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-sm) !important;
  margin-bottom: 4px !important;
}

.et_pb_accordion .et_pb_toggle_title {
  color: var(--color-text-primary) !important;
  font-family: 'Noto Sans JP', sans-serif !important;
  font-size: var(--text-base) !important;
}

.et_pb_accordion .et_pb_toggle.et_pb_toggle_open {
  border-color: var(--color-border-hover) !important;
}

.et_pb_accordion .et_pb_toggle.et_pb_toggle_open .et_pb_toggle_title {
  color: var(--color-gold) !important;
}

/* Divi フォーム */
.et_pb_contact_form_container input,
.et_pb_contact_form_container textarea,
.et_pb_contact_form_container select,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
textarea,
select {
  background-color: var(--color-bg-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-sm) !important;
  color: var(--color-text-primary) !important;
  font-family: 'Noto Sans JP', sans-serif !important;
  padding: 0.75rem 1rem !important;
  transition: border-color var(--transition-base) !important;
  width: 100% !important;
}

.et_pb_contact_form_container input:focus,
.et_pb_contact_form_container textarea:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
textarea:focus {
  border-color: var(--color-gold) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(201, 169, 110, 0.15) !important;
}

.et_pb_contact_form_container input::placeholder,
.et_pb_contact_form_container textarea::placeholder {
  color: var(--color-text-dim) !important;
}


/* ============================================================
   4. ヘッダー（グラスモーフィズム・スティッキー）
   ============================================================ */
#main-header,
#top-header,
.et_header_style_centered #main-header,
.et_header_style_left #main-header {
  background: var(--glass-bg) !important;
  backdrop-filter: var(--glass-blur) !important;
  -webkit-backdrop-filter: var(--glass-blur) !important;
  border-bottom: 1px solid var(--glass-border) !important;
  box-shadow: 0 1px 20px rgba(0, 0, 0, 0.5) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 9999 !important;
  transition: background var(--transition-base) !important;
}

/* ロゴエリア */
#logo {
  max-height: 60px !important;
}

/* ヘッダー電話番号（カスタムHTML ウィジェット用） */
.header-tel {
  font-family: 'Inter', sans-serif;
  font-size: var(--text-xl);
  font-weight: 500;
  color: var(--color-gold) !important;
  letter-spacing: 0.05em;
}

.header-tel a {
  color: var(--color-gold) !important;
  text-decoration: none;
}

.header-hours {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.1em;
}

/* ナビゲーション */
#top-menu > li > a,
#et-top-navigation #top-menu > li > a {
  color: var(--color-text-primary) !important;
  font-family: 'Noto Sans JP', sans-serif !important;
  font-size: var(--text-sm) !important;
  font-weight: 400 !important;
  letter-spacing: 0.12em !important;
  padding: 0 1rem !important;
  transition: color var(--transition-base) !important;
}

#top-menu > li > a:hover,
#top-menu > li.current-menu-item > a,
#top-menu > li.current_page_item > a {
  color: var(--color-gold) !important;
}

/* ドロップダウンメニュー */
#top-menu .sub-menu {
  background-color: var(--color-bg-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-card) !important;
  padding: 0.5rem 0 !important;
}

#top-menu .sub-menu li a {
  color: var(--color-text-primary) !important;
  font-size: var(--text-sm) !important;
  padding: 0.5rem 1.25rem !important;
  transition: background var(--transition-fast), color var(--transition-fast) !important;
}

#top-menu .sub-menu li a:hover {
  background-color: var(--color-bg-elevated) !important;
  color: var(--color-gold) !important;
}

/* モバイルメニュー */
#et_mobile_nav_menu .mobile_nav {
  background-color: var(--color-bg-surface) !important;
  border-top: 1px solid var(--color-border) !important;
}

#et_mobile_nav_menu .mobile_nav ul li a {
  color: var(--color-text-primary) !important;
  border-bottom: 1px solid var(--color-border-subtle) !important;
  padding: 0.875rem 1.5rem !important;
}

.mobile_menu_bar::before {
  color: var(--color-gold) !important;
}


/* ============================================================
   5. ヒーローセクション
   ============================================================ */
.sanctuary-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.sanctuary-hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transform: scale(1.05);
  transition: transform 8s ease;
}

.sanctuary-hero:hover .sanctuary-hero__bg {
  transform: scale(1.0);
}

.sanctuary-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(13, 13, 13, 0.3) 0%,
    rgba(13, 13, 13, 0.5) 50%,
    rgba(13, 13, 13, 0.85) 100%
  );
}

.sanctuary-hero__content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: var(--space-md);
  max-width: 900px;
  margin: 0 auto;
}

.sanctuary-hero__eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: var(--text-xs);
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--color-gold);
  display: block;
  margin-bottom: 1.5rem;
}

.sanctuary-hero__title {
  font-family: 'Noto Serif JP', 'Cormorant Garamond', serif !important;
  font-size: var(--text-display) !important;
  font-weight: 300 !important;
  color: var(--color-text-primary) !important;
  line-height: 1.2 !important;
  letter-spacing: 0.08em;
  margin-bottom: 1.5rem;
}

.sanctuary-hero__subtitle {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  letter-spacing: 0.15em;
  margin-bottom: var(--space-md);
}

.sanctuary-hero__cta {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: var(--space-md);
}

/* ヒーロー内 Stats バー */
.sanctuary-stats {
  display: flex;
  justify-content: center;
  gap: var(--space-md);
  flex-wrap: wrap;
  margin-top: var(--space-lg);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
}

.sanctuary-stats__item {
  text-align: center;
}

.sanctuary-stats__number {
  font-family: 'Cormorant Garamond', 'Noto Serif JP', serif;
  font-size: var(--text-3xl);
  color: var(--color-gold);
  display: block;
  line-height: 1;
}

.sanctuary-stats__label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.15em;
  margin-top: 0.25rem;
}

/* スクロールインジケーター */
.sanctuary-scroll-indicator {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  animation: scrollBounce 2s infinite;
}

.sanctuary-scroll-indicator::after {
  content: '';
  display: block;
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, var(--color-gold), transparent);
}

@keyframes scrollBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(8px); }
}


/* ============================================================
   6. ボタン
   ============================================================ */

/* プライマリボタン（ゴールド） */
.btn-primary,
.et_pb_button.btn-primary,
.sanctuary-btn-primary {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  background: linear-gradient(135deg, var(--color-gold) 0%, var(--color-gold-dark) 100%) !important;
  color: var(--color-bg-base) !important;
  font-family: 'Noto Sans JP', sans-serif !important;
  font-size: var(--text-sm) !important;
  font-weight: 500 !important;
  letter-spacing: 0.15em !important;
  padding: 0.875rem 2rem !important;
  border: none !important;
  border-radius: var(--radius-sm) !important;
  cursor: pointer !important;
  transition: all var(--transition-base) !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.btn-primary:hover,
.et_pb_button.btn-primary:hover,
.sanctuary-btn-primary:hover {
  background: linear-gradient(135deg, var(--color-gold-light) 0%, var(--color-gold) 100%) !important;
  color: var(--color-bg-base) !important;
  transform: translateY(-2px) !important;
  box-shadow: var(--shadow-gold) !important;
}

/* セカンダリボタン（アウトライン） */
.btn-secondary,
.et_pb_button.btn-secondary,
.sanctuary-btn-secondary {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  background: transparent !important;
  color: var(--color-gold) !important;
  font-family: 'Noto Sans JP', sans-serif !important;
  font-size: var(--text-sm) !important;
  font-weight: 400 !important;
  letter-spacing: 0.15em !important;
  padding: 0.875rem 2rem !important;
  border: 1px solid var(--color-gold) !important;
  border-radius: var(--radius-sm) !important;
  cursor: pointer !important;
  transition: all var(--transition-base) !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.btn-secondary:hover,
.et_pb_button.btn-secondary:hover,
.sanctuary-btn-secondary:hover {
  background: rgba(201, 169, 110, 0.1) !important;
  color: var(--color-gold-light) !important;
  border-color: var(--color-gold-light) !important;
  transform: translateY(-2px) !important;
}

/* 電話CTAボタン */
.btn-tel,
.sanctuary-btn-tel {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.75rem !important;
  background: var(--color-bg-surface) !important;
  color: var(--color-gold) !important;
  font-family: 'Inter', 'Noto Sans JP', sans-serif !important;
  font-size: var(--text-xl) !important;
  font-weight: 500 !important;
  letter-spacing: 0.05em !important;
  padding: 1rem 2rem !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-sm) !important;
  cursor: pointer !important;
  transition: all var(--transition-base) !important;
  text-decoration: none !important;
}

.btn-tel:hover,
.sanctuary-btn-tel:hover {
  background: var(--color-bg-elevated) !important;
  border-color: var(--color-gold) !important;
  color: var(--color-gold-light) !important;
  box-shadow: var(--shadow-gold) !important;
}

/* Divi デフォルトボタン上書き */
.et_pb_button:not(.btn-primary):not(.btn-secondary):not(.btn-tel) {
  background: linear-gradient(135deg, var(--color-gold) 0%, var(--color-gold-dark) 100%) !important;
  color: var(--color-bg-base) !important;
  border: none !important;
  border-radius: var(--radius-sm) !important;
  font-family: 'Noto Sans JP', sans-serif !important;
  font-size: var(--text-sm) !important;
  letter-spacing: 0.12em !important;
  padding: 0.875rem 2rem !important;
  transition: all var(--transition-base) !important;
}

.et_pb_button:not(.btn-primary):not(.btn-secondary):not(.btn-tel):hover {
  background: linear-gradient(135deg, var(--color-gold-light) 0%, var(--color-gold) 100%) !important;
  transform: translateY(-2px) !important;
  box-shadow: var(--shadow-gold) !important;
}


/* ============================================================
   7. セクション共通スタイル
   ============================================================ */
.sanctuary-section {
  padding: var(--space-xl) var(--space-md);
}

.sanctuary-section--surface {
  background-color: var(--color-bg-surface) !important;
}

.sanctuary-section-header {
  text-align: center;
  margin-bottom: var(--space-lg);
}

.sanctuary-section-header__en {
  font-family: 'Cormorant Garamond', 'Inter', serif;
  font-size: var(--text-xs);
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--color-gold);
  display: block;
  margin-bottom: 0.75rem;
}

.sanctuary-section-header__title {
  font-family: 'Noto Serif JP', serif !important;
  font-size: clamp(1.5rem, 3vw, 2.25rem) !important;
  font-weight: 300 !important;
  color: var(--color-text-primary) !important;
  letter-spacing: 0.1em;
  margin: 0 0 1rem !important;
}

.sanctuary-section-header__divider {
  width: 60px;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--color-gold), transparent);
  margin: 0 auto;
}


/* ============================================================
   8. 女性カード（Girls Card）
   ============================================================ */
.sanctuary-girls-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1.5rem;
  max-width: 1280px;
  margin: 0 auto;
}

.sanctuary-girl-card {
  position: relative;
  background-color: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}

.sanctuary-girl-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-hover);
  border-color: var(--color-border-hover);
}

/* 縦長 3:4 比率の写真エリア */
.sanctuary-girl-card__image {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background-color: var(--color-bg-elevated);
}

.sanctuary-girl-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.sanctuary-girl-card:hover .sanctuary-girl-card__image img {
  transform: scale(1.05);
}

/* ホバーオーバーレイ */
.sanctuary-girl-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(13,13,13,0.9) 0%, transparent 50%);
  opacity: 0;
  transition: opacity var(--transition-base);
  display: flex;
  align-items: flex-end;
  padding: 1.25rem;
}

.sanctuary-girl-card:hover .sanctuary-girl-card__overlay {
  opacity: 1;
}

.sanctuary-girl-card__overlay-text {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.05em;
  line-height: 1.6;
}

/* カード情報エリア */
.sanctuary-girl-card__info {
  padding: 1rem;
}

.sanctuary-girl-card__name {
  font-family: 'Noto Serif JP', serif;
  font-size: var(--text-lg);
  color: var(--color-text-primary);
  font-weight: 400;
  letter-spacing: 0.08em;
  margin: 0 0 0.25rem;
}

.sanctuary-girl-card__age {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.1em;
}

.sanctuary-girl-card__catch {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: 0.5rem;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* NEW バッジ */
.sanctuary-girl-card__badge {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  background: var(--color-gold);
  color: var(--color-bg-base);
  font-family: 'Inter', sans-serif;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  padding: 0.2rem 0.5rem;
  border-radius: var(--radius-sm);
  text-transform: uppercase;
}

/* ⚠️ 色覚バリアフリー注意：
   NEW バッジには背景色(gold)+テキスト(black)の組み合わせを使用。
   ローズ色のバッジを使う場合は必ずテキストラベルを付けること。 */


/* ============================================================
   9. スケジュールセクション
   ============================================================ */
.sanctuary-schedule {
  background-color: var(--color-bg-surface);
}

/* タブ */
.sanctuary-schedule-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-md);
}

.sanctuary-schedule-tab {
  flex: 1;
  max-width: 160px;
  padding: 0.875rem 1.5rem;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: var(--text-sm);
  letter-spacing: 0.1em;
  color: var(--color-text-muted);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: all var(--transition-base);
  text-align: center;
}

.sanctuary-schedule-tab:hover {
  color: var(--color-text-primary);
}

.sanctuary-schedule-tab.is-active {
  color: var(--color-gold);
  border-bottom-color: var(--color-gold);
}

/* タブナビゲーション */
.sanctuary-schedule-tabs__nav {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-md);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.sanctuary-schedule-tabs__nav::-webkit-scrollbar {
  display: none;
}

.sanctuary-schedule-tab__label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.05em;
}

.sanctuary-schedule-tab__date {
  display: block;
  font-size: 0.7rem;
  letter-spacing: 0.03em;
  opacity: 0.8;
  white-space: nowrap;
}

/* スマホ用タブ調整 */
@media (max-width: 640px) {
  .sanctuary-schedule-tab {
    padding: 0.5rem 0.75rem;
    font-size: 0.75rem;
    max-width: none;
    min-width: 0;
    flex: 1;
  }
  .sanctuary-schedule-tab__label {
    font-size: 0.78rem;
  }
  .sanctuary-schedule-tab__date {
    font-size: 0.65rem;
  }
}

/* スケジュールグリッド */
.sanctuary-schedule-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
}

.sanctuary-schedule-card {
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: transform var(--transition-base), border-color var(--transition-base);
}

.sanctuary-schedule-card:hover {
  transform: translateY(-4px);
  border-color: var(--color-border-hover);
}

.sanctuary-schedule-card__image {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background-color: var(--color-bg-surface);
}

.sanctuary-schedule-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.sanctuary-schedule-card:hover .sanctuary-schedule-card__image img {
  transform: scale(1.04);
}

.sanctuary-schedule-card__info {
  padding: 0.875rem;
}

.sanctuary-schedule-card__name {
  font-family: 'Noto Serif JP', serif;
  font-size: var(--text-base);
  color: var(--color-text-primary);
  font-weight: 400;
  margin: 0 0 0.25rem;
}

.sanctuary-schedule-card__time {
  font-family: 'Inter', sans-serif;
  font-size: var(--text-xs);
  color: var(--color-gold);
  letter-spacing: 0.1em;
}

.sanctuary-schedule-card__status {
  display: inline-block;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  padding: 0.15rem 0.5rem;
  border-radius: var(--radius-full);
  margin-top: 0.5rem;
}

/* ステータスバッジ（色覚バリアフリー対応：色+テキストで識別） */
.sanctuary-schedule-card__status--available {
  background: rgba(201, 169, 110, 0.15);
  color: var(--color-gold);
  border: 1px solid rgba(201, 169, 110, 0.3);
}
/* 「受付中」はゴールドで表示（赤緑色盲でも識別可能） */

.sanctuary-schedule-card__status--reserved {
  background: rgba(138, 147, 189, 0.15);
  color: var(--color-text-muted);
  border: 1px solid rgba(138, 147, 189, 0.3);
}
/* 「予約済」はブルーグレーで表示（赤緑色盲でも識別可能） */


/* ============================================================
   10. お知らせセクション
   ============================================================ */
.sanctuary-news-list {
  list-style: none;
  padding: 0;
  margin: 0;
  max-width: 800px;
  margin: 0 auto;
}

.sanctuary-news-item {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
  padding: 1.25rem 0;
  border-bottom: 1px solid var(--color-border-subtle);
  transition: background var(--transition-fast);
}

.sanctuary-news-item:last-child {
  border-bottom: none;
}

.sanctuary-news-item:hover {
  background: rgba(201, 169, 110, 0.03);
}

.sanctuary-news-item__date {
  font-family: 'Inter', sans-serif;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.1em;
  white-space: nowrap;
  padding-top: 0.15rem;
  min-width: 90px;
}

.sanctuary-news-item__tag {
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  padding: 0.15rem 0.6rem;
  border-radius: var(--radius-full);
  background: rgba(201, 169, 110, 0.1);
  color: var(--color-gold);
  border: 1px solid rgba(201, 169, 110, 0.2);
  white-space: nowrap;
  align-self: flex-start;
  margin-top: 0.1rem;
}

.sanctuary-news-item__title {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  line-height: 1.6;
  flex: 1;
}

.sanctuary-news-item__title a {
  color: var(--color-text-primary) !important;
  transition: color var(--transition-base);
}

.sanctuary-news-item__title a:hover {
  color: var(--color-gold) !important;
}


/* ============================================================
   11. 写メ日記グリッド
   ============================================================ */
.sanctuary-diary-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  max-width: 1000px;
  margin: 0 auto;
}

.sanctuary-diary-item {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: var(--radius-md);
  background-color: var(--color-bg-surface);
  cursor: pointer;
}

.sanctuary-diary-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.sanctuary-diary-item:hover img {
  transform: scale(1.06);
}

.sanctuary-diary-item__overlay {
  position: absolute;
  inset: 0;
  background: rgba(13, 13, 13, 0.6);
  opacity: 0;
  transition: opacity var(--transition-base);
  display: flex;
  align-items: center;
  justify-content: center;
}

.sanctuary-diary-item:hover .sanctuary-diary-item__overlay {
  opacity: 1;
}

.sanctuary-diary-item__name {
  font-family: 'Noto Serif JP', serif;
  font-size: var(--text-base);
  color: var(--color-text-primary);
  letter-spacing: 0.1em;
}


/* ============================================================
   12. CTAバナーセクション
   ============================================================ */
.sanctuary-cta-banner {
  background: linear-gradient(135deg, var(--color-bg-surface) 0%, #1f1a12 100%);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-lg) var(--space-md);
  text-align: center;
}

.sanctuary-cta-banner__label {
  font-family: 'Inter', sans-serif;
  font-size: var(--text-xs);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  display: block;
  margin-bottom: 1rem;
}

.sanctuary-cta-banner__tel {
  font-family: 'Cormorant Garamond', 'Inter', serif;
  font-size: clamp(2rem, 5vw, 3.5rem);
  color: var(--color-gold);
  letter-spacing: 0.1em;
  display: block;
  margin-bottom: 0.5rem;
  line-height: 1;
}

.sanctuary-cta-banner__tel a {
  color: var(--color-gold) !important;
  text-decoration: none;
  transition: color var(--transition-base);
}

.sanctuary-cta-banner__tel a:hover {
  color: var(--color-gold-light) !important;
}

.sanctuary-cta-banner__hours {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  letter-spacing: 0.1em;
  margin-bottom: var(--space-md);
}

.sanctuary-cta-banner__badges {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: var(--space-md);
}

.sanctuary-cta-banner__badge {
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  padding: 0.35rem 1rem;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
  background: transparent;
}


/* ============================================================
   13. 料金システムテーブル
   ============================================================ */
.sanctuary-system-table {
  width: 100%;
  max-width: 700px;
  margin: 0 auto;
  border-collapse: collapse;
}

.sanctuary-system-table th,
.sanctuary-system-table td {
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--color-border-subtle);
  text-align: left;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: var(--text-sm);
}

.sanctuary-system-table th {
  color: var(--color-text-muted);
  font-weight: 400;
  letter-spacing: 0.1em;
  width: 40%;
}

.sanctuary-system-table td {
  color: var(--color-text-primary);
  font-weight: 400;
}

.sanctuary-system-table tr:last-child th,
.sanctuary-system-table tr:last-child td {
  border-bottom: none;
}

.sanctuary-system-table .price {
  font-family: 'Cormorant Garamond', serif;
  font-size: var(--text-xl);
  color: var(--color-gold);
  letter-spacing: 0.05em;
}


/* ============================================================
   14. アクセスセクション
   ============================================================ */
.sanctuary-access {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  align-items: start;
  max-width: 1100px;
  margin: 0 auto;
}

.sanctuary-access__map {
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--color-border);
}

.sanctuary-access__map iframe {
  width: 100%;
  height: 400px;
  display: block;
  filter: grayscale(100%) invert(90%) contrast(90%);
  /* ダークモードに合わせたマップフィルター */
}

.sanctuary-access__info {
  padding: var(--space-sm) 0;
}

.sanctuary-access__info dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.75rem 1.5rem;
  margin: 0;
}

.sanctuary-access__info dt {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.1em;
  padding-top: 0.15rem;
}

.sanctuary-access__info dd {
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  margin: 0;
  line-height: 1.6;
}


/* ============================================================
   15. 求人バナー
   ============================================================ */
.sanctuary-recruit-banner {
  background: linear-gradient(135deg, #1a0f1f 0%, var(--color-bg-surface) 100%);
  border: 1px solid rgba(201, 123, 138, 0.2);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  text-align: center;
  max-width: 900px;
  margin: 0 auto;
}

.sanctuary-recruit-banner__title {
  font-family: 'Noto Serif JP', serif !important;
  font-size: var(--text-2xl) !important;
  color: var(--color-text-primary) !important;
  font-weight: 300 !important;
  letter-spacing: 0.1em;
  margin-bottom: 0.5rem !important;
}

.sanctuary-recruit-banner__salary {
  font-family: 'Cormorant Garamond', serif;
  font-size: var(--text-3xl);
  color: var(--color-rose);
  letter-spacing: 0.05em;
  display: block;
  margin: 1rem 0;
}

/* ⚠️ 色覚バリアフリー注意：
   求人バナーの日給表示に --color-rose を使用していますが、
   赤緑色盲の方には識別しにくい場合があります。
   重要な数値のため、フォントサイズを大きくし、
   「日給保証」などのテキストラベルを必ず併記してください。 */

.sanctuary-recruit-banner__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.8;
  margin-bottom: var(--space-md);
}


/* ============================================================
   16. フッター
   ============================================================ */
#main-footer,
.et_pb_footer_tabbed_container {
  background-color: var(--color-bg-surface) !important;
  border-top: 1px solid var(--color-border) !important;
}

.et_pb_footer_tabbed_container .et_pb_widget_area {
  padding: var(--space-lg) var(--space-md) !important;
}

/* フッターナビ */
#footer-nav {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
  justify-content: center;
}

#footer-nav a {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: var(--text-xs);
  color: var(--color-text-muted) !important;
  letter-spacing: 0.1em;
  transition: color var(--transition-base);
}

#footer-nav a:hover {
  color: var(--color-gold) !important;
}

/* フッターコピーライト */
#footer-info {
  border-top: 1px solid var(--color-border-subtle) !important;
  padding: 1.5rem var(--space-md) !important;
}

#footer-info p,
#footer-info .et_pb_footer_tabbed_container p {
  font-size: var(--text-xs) !important;
  color: var(--color-text-dim) !important;
  letter-spacing: 0.1em;
  text-align: center !important;
}

/* フッターウィジェットタイトル */
.footer-widget h4,
.footer-widget .widgettitle {
  font-family: 'Noto Serif JP', serif !important;
  font-size: var(--text-sm) !important;
  color: var(--color-gold) !important;
  letter-spacing: 0.15em !important;
  font-weight: 400 !important;
  margin-bottom: 1rem !important;
  padding-bottom: 0.5rem !important;
  border-bottom: 1px solid var(--color-border) !important;
}


/* ============================================================
   17. フローティングCTAボタン（モバイル専用）
   ============================================================ */
.sanctuary-floating-cta {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9998;
  padding: 0.75rem 1rem;
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-top: 1px solid var(--glass-border);
  gap: 0.75rem;
}

.sanctuary-floating-cta__tel {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: linear-gradient(135deg, var(--color-gold) 0%, var(--color-gold-dark) 100%);
  color: var(--color-bg-base);
  font-family: 'Noto Sans JP', sans-serif;
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.1em;
  padding: 0.875rem;
  border-radius: var(--radius-sm);
  text-decoration: none;
  border: none;
  cursor: pointer;
}

.sanctuary-floating-cta__reserve {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: transparent;
  color: var(--color-gold);
  font-family: 'Noto Sans JP', sans-serif;
  font-size: var(--text-sm);
  font-weight: 400;
  letter-spacing: 0.1em;
  padding: 0.875rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-gold);
  text-decoration: none;
  cursor: pointer;
}


/* ============================================================
   18. スクロールアニメーション
   ============================================================ */
.sanctuary-fade-in {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.sanctuary-fade-in.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.sanctuary-fade-in--delay-1 { transition-delay: 0.1s; }
.sanctuary-fade-in--delay-2 { transition-delay: 0.2s; }
.sanctuary-fade-in--delay-3 { transition-delay: 0.3s; }
.sanctuary-fade-in--delay-4 { transition-delay: 0.4s; }
.sanctuary-fade-in--delay-5 { transition-delay: 0.5s; }


/* ============================================================
   19. ユーティリティ
   ============================================================ */
.text-center { text-align: center !important; }
.text-left   { text-align: left !important; }
.text-right  { text-align: right !important; }

.mt-sm { margin-top: var(--space-sm) !important; }
.mt-md { margin-top: var(--space-md) !important; }
.mt-lg { margin-top: var(--space-lg) !important; }
.mb-sm { margin-bottom: var(--space-sm) !important; }
.mb-md { margin-bottom: var(--space-md) !important; }
.mb-lg { margin-bottom: var(--space-lg) !important; }

.divider-gold {
  width: 60px;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--color-gold), transparent);
  margin: var(--space-sm) auto;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}


/* ============================================================
   20. レスポンシブ対応
   ============================================================ */

/* タブレット（〜1024px） */
@media (max-width: 1024px) {
  .sanctuary-girls-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .sanctuary-schedule-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .sanctuary-access {
    grid-template-columns: 1fr;
  }

  .sanctuary-access__map iframe {
    height: 300px;
  }
}

/* スマートフォン（〜768px） */
@media (max-width: 768px) {
  :root {
    --space-lg: 3rem;
    --space-xl: 5rem;
  }

  /* ヘッダー */
  #main-header {
    padding: 0.75rem 1rem !important;
  }

  /* ヒーロー */
  .sanctuary-hero__title {
    font-size: clamp(1.75rem, 8vw, 2.5rem) !important;
  }

  .sanctuary-hero__cta {
    flex-direction: column;
    align-items: center;
  }

  .sanctuary-stats {
    gap: var(--space-sm);
  }

  /* 女性グリッド → 横スクロールカルーセル */
  .sanctuary-girls-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
  }

  /* スケジュールグリッド */
  .sanctuary-schedule-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
  }

  /* 日記グリッド */
  .sanctuary-diary-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* CTAバナー */
  .sanctuary-cta-banner__tel {
    font-size: clamp(1.5rem, 8vw, 2.5rem);
  }

  /* アクセス */
  .sanctuary-access {
    grid-template-columns: 1fr;
  }

  /* フローティングCTA表示 */
  .sanctuary-floating-cta {
    display: flex;
  }

  /* フローティングCTAの分のパディング */
  body {
    padding-bottom: 80px !important;
  }

  /* ナビゲーション非表示 → ハンバーガー */
  #top-navigation-wrap {
    display: none !important;
  }

  /* システムテーブル */
  .sanctuary-system-table th,
  .sanctuary-system-table td {
    padding: 0.75rem 1rem;
    font-size: var(--text-xs);
  }
}

/* 小型スマートフォン（〜480px） */
@media (max-width: 480px) {
  .sanctuary-girls-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
  }

  .sanctuary-schedule-grid {
    grid-template-columns: 1fr 1fr;
  }

  .sanctuary-diary-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
  }

  .sanctuary-cta-banner__badges {
    gap: 0.5rem;
  }
}


/* ============================================================
   21. Divi ビジュアルビルダー内プレビュー調整
   ============================================================ */
.et-fb-root-ancestor .sanctuary-floating-cta {
  display: none !important;
}

.et-fb-root-ancestor #main-header {
  position: relative !important;
}


/* ============================================================
   22. WordPress コアUI（管理バー）
   ============================================================ */
#wpadminbar {
  background-color: #1a1a1a !important;
}

#wpadminbar .ab-item,
#wpadminbar a.ab-item {
  color: var(--color-text-muted) !important;
}

#wpadminbar .ab-item:hover,
#wpadminbar a.ab-item:hover {
  color: var(--color-gold) !important;
  background: transparent !important;
}


/* ============================================================
   23. DIVI テーマビルダー グローバルヘッダー 強制上書き
   ============================================================
   DIVIのメニューモジュールは白背景・黒文字がデフォルトのため
   !important で Noir Elegance カラーに上書きする
   ============================================================ */

/* ヘッダーセクション全体の背景 */
#et-boc .et-l--header .et_pb_section,
.et-db #et-boc .et-l--header .et_pb_section,
body:not(.et-fb) .et-l--header .et_pb_section {
  background-color: rgba(13, 13, 13, 0.92) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
}

/* ヘッダー行 */
#et-boc .et-l--header .et_pb_row,
.et-db #et-boc .et-l--header .et_pb_row {
  background-color: transparent !important;
}

/* DIVIメニューモジュールの背景 */
#et-boc .et-l--header .et_pb_menu,
#et-boc .et-l--header .et_pb_menu_inner,
#et-boc .et-l--header .et_pb_menu .et_pb_menu__wrap,
.et-db #et-boc .et-l--header .et_pb_menu {
  background-color: transparent !important;
}

/* ナビゲーションリンクの文字色 */
#et-boc .et-l--header .et_pb_menu nav ul li a,
#et-boc .et-l--header .et_pb_menu .et_pb_menu__menu > nav > ul > li > a,
.et-db #et-boc .et-l--header .et_pb_menu nav ul li a {
  color: var(--color-text-primary) !important;
  font-family: var(--font-sans) !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  transition: color 0.3s ease !important;
}

/* ナビゲーションリンクのホバー */
#et-boc .et-l--header .et_pb_menu nav ul li a:hover,
#et-boc .et-l--header .et_pb_menu .et_pb_menu__menu > nav > ul > li > a:hover,
.et-db #et-boc .et-l--header .et_pb_menu nav ul li a:hover {
  color: var(--color-gold) !important;
}

/* ハンバーガーメニューアイコン（モバイル） */
#et-boc .et-l--header .et_pb_menu .mobile_nav .mobile_menu_bar,
#et-boc .et-l--header .et_pb_menu .mobile_nav .mobile_menu_bar:before,
.et-db #et-boc .et-l--header .et_pb_menu .mobile_nav .mobile_menu_bar:before {
  background-color: var(--color-gold) !important;
}

/* モバイルドロップダウンメニューの背景 */
#et-boc .et-l--header .et_pb_menu .et_mobile_menu,
.et-db #et-boc .et-l--header .et_pb_menu .et_mobile_menu {
  background-color: rgba(13, 13, 13, 0.97) !important;
  border-top: 1px solid var(--color-gold) !important;
}

#et-boc .et-l--header .et_pb_menu .et_mobile_menu li a,
.et-db #et-boc .et-l--header .et_pb_menu .et_mobile_menu li a {
  color: var(--color-text-primary) !important;
  border-bottom-color: rgba(201, 169, 110, 0.15) !important;
}

#et-boc .et-l--header .et_pb_menu .et_mobile_menu li a:hover,
.et-db #et-boc .et-l--header .et_pb_menu .et_mobile_menu li a:hover {
  color: var(--color-gold) !important;
  background-color: rgba(201, 169, 110, 0.08) !important;
}

/* ドロップダウンサブメニューの背景 */
#et-boc .et-l--header .et_pb_menu nav ul li ul,
.et-db #et-boc .et-l--header .et_pb_menu nav ul li ul {
  background-color: rgba(13, 13, 13, 0.97) !important;
  border-top: 2px solid var(--color-gold) !important;
}

#et-boc .et-l--header .et_pb_menu nav ul li ul li a,
.et-db #et-boc .et-l--header .et_pb_menu nav ul li ul li a {
  color: var(--color-text-muted) !important;
}

#et-boc .et-l--header .et_pb_menu nav ul li ul li a:hover,
.et-db #et-boc .et-l--header .et_pb_menu nav ul li ul li a:hover {
  color: var(--color-gold) !important;
  background-color: rgba(201, 169, 110, 0.08) !important;
}

/* ヘッダーをスクロール時にスティッキー固定 */
#et-boc .et-l--header {
  position: sticky !important;
  top: 0 !important;
  z-index: 999 !important;
  width: 100% !important;
}

/* スクロール後の半透明ヘッダー（JSで .scrolled クラスが付与される場合） */
#et-boc .et-l--header.scrolled .et_pb_section {
  background-color: rgba(13, 13, 13, 0.98) !important;
}


/* ============================================================
   24. スケジュールカード リニューアル
       - メイン画像（統一サイズ・object-fit: cover）
       - サムネイル3枚切り替え
       - スペック・出勤時間表示
   ============================================================ */

/* グリッドレイアウト */
.sanctuary-schedule-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
  padding: 0;
}

@media (max-width: 1024px) {
  .sanctuary-schedule-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 640px) {
  .sanctuary-schedule-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
}

/* カード本体 */
.sanctuary-schedule-card {
  position: relative;
  background: #1a1a1a;
  border: 1px solid rgba(201, 169, 110, 0.15);
  border-radius: 4px;
  overflow: hidden;
  transition: border-color 0.3s ease, transform 0.3s ease;
}

.sanctuary-schedule-card:hover {
  border-color: rgba(201, 169, 110, 0.5);
  transform: translateY(-3px);
}

/* ── メイン画像エリア ── */
.sanctuary-schedule-card__main-link {
  display: block;
  text-decoration: none;
}

.sanctuary-schedule-card__main {
  position: relative;
  width: 100%;
  /* 縦横比 3:4 で統一 */
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: #111;
}

.sanctuary-schedule-card__main-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: top center !important;
  display: block;
  transition: opacity 0.3s ease;
}

/* 画像切り替え時のフェード */
.sanctuary-schedule-card__main-img.is-fading {
  opacity: 0;
}

/* ── サムネイルエリア ── */
.sanctuary-schedule-card__thumbs {
  display: flex;
  gap: 3px;
  padding: 4px;
  background: #111;
}

.sanctuary-schedule-card__thumb-btn {
  flex: 1;
  aspect-ratio: 1 / 1;
  padding: 0;
  border: 2px solid transparent;
  border-radius: 2px;
  overflow: hidden;
  cursor: pointer;
  background: #222;
  transition: border-color 0.2s ease;
}

.sanctuary-schedule-card__thumb-btn img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: top center !important;
  display: block;
  pointer-events: none;
}

.sanctuary-schedule-card__thumb-btn.is-active {
  border-color: var(--color-gold);
}

.sanctuary-schedule-card__thumb-btn:hover {
  border-color: rgba(201, 169, 110, 0.6);
}

/* ── スペック・テキストエリア ── */
.sanctuary-schedule-card__body {
  padding: 4px 6px 6px;
  text-align: center;
}

.sanctuary-schedule-card__name {
  margin: 0 0 1px;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-text-primary);
  line-height: 1.3;
}

.sanctuary-schedule-card__name a {
  color: inherit;
  text-decoration: none;
}

.sanctuary-schedule-card__name a:hover {
  color: var(--color-gold);
}

.sanctuary-schedule-card__age {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  font-weight: 400;
}

/* スリーサイズ：身長/バスト(カップ)/ウエスト/ヒップ */
.sanctuary-schedule-card__size {
  margin: 1px 0;
  font-size: 0.75rem;
  color: var(--color-text-muted);
  letter-spacing: 0.02em;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* スマホ用サイズ縮小 */
@media (max-width: 640px) {
  .sanctuary-schedule-card__size {
    font-size: 0.65rem;
    letter-spacing: 0;
  }
}

/* 出勤時間 */
.sanctuary-schedule-card__time {
  margin: 1px 0 0;
  font-size: 0.8rem;
  color: var(--color-gold);
  font-weight: 500;
  letter-spacing: 0.05em;
  white-space: nowrap;
  line-height: 1.3;
}

@media (max-width: 640px) {
  .sanctuary-schedule-card__time {
    font-size: 0.68rem;
    letter-spacing: 0;
  }
}

/* バッジ（NEW・ランク）の位置調整 */
.sanctuary-schedule-card .sanctuary-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 2;
  font-size: 0.65rem;
  padding: 2px 6px;
  border-radius: 2px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.sanctuary-schedule-card .sanctuary-badge--new {
  background: var(--color-gold);
  color: #0d0d0d;
}

.sanctuary-schedule-card .sanctuary-badge--rank {
  top: 8px;
  left: auto;
  right: 8px;
  background: rgba(13, 13, 13, 0.85);
  color: var(--color-gold);
  border: 1px solid var(--color-gold);
}

/* 本日出勤バッジ：左下に配置 */
.sanctuary-schedule-card .sanctuary-badge--today {
  top: auto;
  left: 0;
  bottom: 0;
  background: #cc2200;
  color: #fff;
  border-radius: 0 3px 0 0;
  font-size: 0.68rem;
  padding: 3px 8px;
  text-transform: none;
}

/* 本日出勤バッジ：画像内左下オーバーレイ表示（新人スライダー用） */
.sanctuary-schedule-card__main .sanctuary-badge--today-overlay {
  position: absolute;
  top: auto;
  bottom: 0;
  left: 0;
  right: auto;
  z-index: 3;
  background: #cc2200;
  color: #fff;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 0 3px 0 0;
  letter-spacing: 0.05em;
  text-transform: none;
  pointer-events: none;
}


/* ============================================================
   25. ヒーロースライダー
   ============================================================ */

/* ── スライダー本体 ── */
.sanctuary-hero-slider {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: #0d0d0d;
  /* ヘッダー分の padding-top でコンテンツが隠れないようにする */
  /* DIVIのテーマビルダーでヘッダーが fixed/sticky の場合に対応 */
}

/* ヒーローセクションがページ最上部に来る場合のオフセット */
.et-l--body .et_pb_section:first-child .sanctuary-hero-slider,
.sanctuary-hero-section .sanctuary-hero-slider {
  margin-top: 0;
}

/* DIVIのスティッキーヘッダーで隠れる対策：
   ページ最初のセクションに自動でpadding-topを付与 */
#page-container .et_pb_section:first-of-type {
  padding-top: 0 !important;
}

/* ── スライドトラック ── */
.sanctuary-hero-slider__track {
  position: relative;
  width: 100%;
}

/* ── 各スライド ── */
.sanctuary-hero-slider__slide {
  display: none;
  width: 100%;
  position: relative;
}

.sanctuary-hero-slider__slide.is-active {
  display: block;
}

/* フェードアニメーション */
.sanctuary-hero-slider__slide.is-active {
  animation: sliderFadeIn 0.6s ease forwards;
}

@keyframes sliderFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ── スライド内の画像 ── */
.sanctuary-hero-slider__slide img,
.sanctuary-hero-slider__link img {
  display: block;
  width: 100% !important;
  height: auto !important;
  /* 画像が小さい場合は拡大して全幅に合わせる */
  min-width: 100%;
  object-fit: cover;
  object-position: center;
}

/* 画像が縦長の場合は最大高さを制限 */
@media (min-width: 769px) {
  .sanctuary-hero-slider__slide img,
  .sanctuary-hero-slider__link img {
    max-height: 80vh;
    width: 100% !important;
    object-fit: cover;
  }
}

.sanctuary-hero-slider__link {
  display: block;
  text-decoration: none;
}

/* ── 前後ボタン ── */
.sanctuary-hero-slider__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  background: rgba(13, 13, 13, 0.55);
  color: #C9A96E;
  border: 1px solid rgba(201, 169, 110, 0.4);
  border-radius: 50%;
  width: 44px;
  height: 44px;
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.25s ease, border-color 0.25s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sanctuary-hero-slider__btn:hover {
  background: rgba(201, 169, 110, 0.25);
  border-color: #C9A96E;
}

.sanctuary-hero-slider__btn--prev { left: 16px; }
.sanctuary-hero-slider__btn--next { right: 16px; }

@media (max-width: 640px) {
  .sanctuary-hero-slider__btn {
    width: 34px;
    height: 34px;
    font-size: 0.9rem;
  }
  .sanctuary-hero-slider__btn--prev { left: 8px; }
  .sanctuary-hero-slider__btn--next { right: 8px; }
}

/* ── ドットインジケーター ── */
.sanctuary-hero-slider__dots {
  position: absolute;
  bottom: 14px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 10;
}

.sanctuary-hero-slider__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(240, 237, 229, 0.4);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background 0.25s ease, transform 0.25s ease;
}

.sanctuary-hero-slider__dot.is-active,
.sanctuary-hero-slider__dot:hover {
  background: #C9A96E;
  transform: scale(1.3);
}

/* ============================================================
   26. DIVIスティッキーヘッダー下のコンテンツ隠れ対策
   ============================================================ */

/* DIVIのテーマビルダーでヘッダーがstickyの場合、
   ボディに自動でpaddingが付くが、
   最初のセクションがヒーロースライダーの場合は不要なので除去 */
.et-fixed-header ~ #page-container .et_pb_section:first-of-type,
body.et_fixed_nav #page-container .et_pb_section:first-of-type {
  padding-top: 0 !important;
}

/* ヒーロースライダーのセクション自体のpadding除去 */
.et_pb_section.sanctuary-hero-section {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* DIVIのコードモジュール内のスライダーに余白が付く場合の対策 */
.et_pb_code .sanctuary-hero-slider {
  margin: 0;
  padding: 0;
}


/* ============================================================
   27. グローバルヘッダー 全面リニューアル（2026 Luxury Dark UI）
   ============================================================
   デザインコンセプト：
   - ネオン×ゴールドグラデーションの高級感
   - スクロールで縮小するスマートヘッダー
   - ナビリンクにアンダーラインアニメーション
   - ロゴにグローエフェクト
   ============================================================ */

/* ── ヘッダー本体 ── */
#main-header,
#et-boc .et-l--header .et_pb_section,
.et_pb_section.et_section_regular:has(.et_pb_menu),
body #page-container #top-header,
body #page-container #main-header {
  background: linear-gradient(
    135deg,
    rgba(8, 8, 8, 0.97) 0%,
    rgba(18, 12, 8, 0.97) 40%,
    rgba(12, 8, 18, 0.97) 100%
  ) !important;
  backdrop-filter: blur(20px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
  border-bottom: 1px solid transparent !important;
  border-image: linear-gradient(
    90deg,
    transparent 0%,
    #C9A96E 20%,
    #fff0c8 50%,
    #C9A96E 80%,
    transparent 100%
  ) 1 !important;
  box-shadow:
    0 4px 30px rgba(0, 0, 0, 0.8),
    0 1px 0 rgba(201, 169, 110, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 9999 !important;
}

/* スクロール後の縮小ヘッダー */
#main-header.sanctuary-header-scrolled,
#et-boc .et-l--header .et_pb_section.sanctuary-header-scrolled {
  background: linear-gradient(
    135deg,
    rgba(5, 5, 5, 0.99) 0%,
    rgba(12, 8, 5, 0.99) 100%
  ) !important;
  box-shadow:
    0 8px 40px rgba(0, 0, 0, 0.9),
    0 1px 0 rgba(201, 169, 110, 0.5) !important;
}

/* ── ロゴエリア ── */
#et-boc .et-l--header .et_pb_image,
#main-header .et_pb_image,
.et_pb_header_logo {
  filter: drop-shadow(0 0 12px rgba(201, 169, 110, 0.6))
          drop-shadow(0 0 24px rgba(201, 169, 110, 0.3)) !important;
  transition: filter 0.3s ease, transform 0.3s ease !important;
}

#et-boc .et-l--header .et_pb_image:hover,
#main-header .et_pb_image:hover {
  filter: drop-shadow(0 0 20px rgba(201, 169, 110, 0.9))
          drop-shadow(0 0 40px rgba(201, 169, 110, 0.5)) !important;
  transform: scale(1.03) !important;
}

/* ── ナビゲーション全体 ── */
#et-boc .et-l--header .et_pb_menu,
#main-header .et_pb_menu,
.et_pb_menu_0 {
  background: transparent !important;
}

/* ── ナビリンク ── */
#et-boc .et-l--header .et_pb_menu nav > ul > li > a,
#main-header nav > ul > li > a,
.et_pb_menu nav > ul > li > a {
  color: #E8E0D0 !important;
  font-family: 'Noto Serif JP', 'Cormorant Garamond', serif !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.12em !important;
  text-transform: none !important;
  padding: 8px 14px !important;
  position: relative !important;
  text-decoration: none !important;
  transition: color 0.3s ease !important;

  /* アンダーラインアニメーション用 */
  background-image: linear-gradient(
    90deg,
    #C9A96E 0%,
    #fff0c8 50%,
    #C9A96E 100%
  ) !important;
  background-size: 0% 1.5px !important;
  background-repeat: no-repeat !important;
  background-position: left bottom !important;
  transition:
    color 0.3s ease,
    background-size 0.35s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

#et-boc .et-l--header .et_pb_menu nav > ul > li > a:hover,
#main-header nav > ul > li > a:hover,
.et_pb_menu nav > ul > li > a:hover {
  color: #C9A96E !important;
  background-size: 100% 1.5px !important;
  text-shadow: 0 0 12px rgba(201, 169, 110, 0.5) !important;
}

/* アクティブページ */
#et-boc .et-l--header .et_pb_menu nav > ul > li.current-menu-item > a,
#main-header nav > ul > li.current-menu-item > a {
  color: #C9A96E !important;
  background-size: 100% 1.5px !important;
}

/* ── ドロップダウンメニュー ── */
#et-boc .et-l--header .et_pb_menu nav > ul > li > ul,
#main-header nav > ul > li > ul,
.et_pb_menu nav ul ul {
  background: rgba(8, 8, 8, 0.97) !important;
  backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(201, 169, 110, 0.25) !important;
  border-top: 2px solid #C9A96E !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.8) !important;
  border-radius: 0 0 8px 8px !important;
}

#et-boc .et-l--header .et_pb_menu nav > ul > li > ul li a,
#main-header nav > ul > li > ul li a,
.et_pb_menu nav ul ul li a {
  color: #C8BFA8 !important;
  font-size: 0.82rem !important;
  padding: 10px 20px !important;
  border-bottom: 1px solid rgba(201, 169, 110, 0.1) !important;
  transition: all 0.2s ease !important;
  background: transparent !important;
}

#et-boc .et-l--header .et_pb_menu nav > ul > li > ul li a:hover,
.et_pb_menu nav ul ul li a:hover {
  color: #C9A96E !important;
  background: rgba(201, 169, 110, 0.08) !important;
  padding-left: 28px !important;
}

/* ── モバイルハンバーガー ── */
#et-boc .et-l--header .et_pb_menu .mobile_nav .mobile_menu_bar,
#main-header .mobile_menu_bar,
.et_mobile_menu_icon,
.et_pb_menu .mobile_nav .mobile_menu_bar:before {
  color: #C9A96E !important;
  font-size: 1.6rem !important;
  text-shadow: 0 0 10px rgba(201, 169, 110, 0.6) !important;
}

/* モバイルメニュー展開時 */
#et-boc .et-l--header .et_pb_menu .et_mobile_menu,
.et_pb_menu .et_mobile_menu {
  background: rgba(5, 5, 5, 0.98) !important;
  border-top: 2px solid #C9A96E !important;
  backdrop-filter: blur(20px) !important;
}

.et_pb_menu .et_mobile_menu li a {
  color: #E8E0D0 !important;
  border-bottom: 1px solid rgba(201, 169, 110, 0.15) !important;
  padding: 14px 20px !important;
  font-size: 0.9rem !important;
  letter-spacing: 0.08em !important;
}

.et_pb_menu .et_mobile_menu li a:hover {
  color: #C9A96E !important;
  background: rgba(201, 169, 110, 0.08) !important;
}

/* ============================================================
   28. サイトタイトル・セクション見出し 全面リニューアル
   ============================================================ */

/* ── セクション見出し共通スタイル ── */
.et_pb_text h2,
.et_pb_text h3,
.sanctuary-section-title {
  position: relative !important;
  display: inline-block !important;
}

/* ── News & Topics 見出し ── */
.et_pb_text h2 {
  font-family: 'Cormorant Garamond', 'Noto Serif JP', serif !important;
  font-size: clamp(1.8rem, 4vw, 3rem) !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  line-height: 1.2 !important;

  /* グラデーションテキスト */
  background: linear-gradient(
    135deg,
    #C9A96E 0%,
    #fff0c8 35%,
    #C9A96E 65%,
    #8B6914 100%
  ) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;

  /* テキストシャドウ代わりにフィルター */
  filter: drop-shadow(0 2px 8px rgba(201, 169, 110, 0.4)) !important;
}

/* 見出し下のデコレーションライン */
.et_pb_text h2::after {
  content: '' !important;
  display: block !important;
  width: 60% !important;
  height: 2px !important;
  margin-top: 8px !important;
  background: linear-gradient(
    90deg,
    #C9A96E 0%,
    #fff0c8 50%,
    transparent 100%
  ) !important;
}

/* ── Today's Schedule 見出し ── */
.sanctuary-schedule-section .sanctuary-schedule-title,
.sanctuary-schedule-wrapper h2,
h2.sanctuary-schedule-heading {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(2rem, 5vw, 3.5rem) !important;
  font-weight: 700 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;

  /* ネオンゴールドグロー */
  background: linear-gradient(
    90deg,
    #8B6914 0%,
    #C9A96E 25%,
    #fff8e0 50%,
    #C9A96E 75%,
    #8B6914 100%
  ) !important;
  background-size: 200% auto !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  animation: goldShimmer 4s linear infinite !important;
  filter: drop-shadow(0 0 15px rgba(201, 169, 110, 0.5)) !important;
}

@keyframes goldShimmer {
  0%   { background-position: 0% center; }
  100% { background-position: 200% center; }
}

/* ── スケジュールタブボタン ── */
.sanctuary-schedule-tabs .sanctuary-tab-btn {
  background: linear-gradient(
    135deg,
    rgba(30, 20, 10, 0.9) 0%,
    rgba(20, 15, 8, 0.9) 100%
  ) !important;
  color: #C8BFA8 !important;
  border: 1px solid rgba(201, 169, 110, 0.3) !important;
  border-radius: 4px 4px 0 0 !important;
  font-family: 'Noto Serif JP', serif !important;
  font-size: 0.9rem !important;
  letter-spacing: 0.1em !important;
  padding: 12px 24px !important;
  transition: all 0.3s ease !important;
  position: relative !important;
  overflow: hidden !important;
}

/* タブボタンのシマーエフェクト */
.sanctuary-schedule-tabs .sanctuary-tab-btn::before {
  content: '' !important;
  position: absolute !important;
  top: -50% !important;
  left: -75% !important;
  width: 50% !important;
  height: 200% !important;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.08),
    transparent
  ) !important;
  transform: skewX(-20deg) !important;
  transition: left 0.5s ease !important;
}

.sanctuary-schedule-tabs .sanctuary-tab-btn:hover::before {
  left: 125% !important;
}

.sanctuary-schedule-tabs .sanctuary-tab-btn.is-active {
  background: linear-gradient(
    135deg,
    #1a1000 0%,
    #2a1e08 50%,
    #1a1000 100%
  ) !important;
  color: #C9A96E !important;
  border-color: #C9A96E !important;
  border-bottom-color: transparent !important;
  box-shadow:
    0 -2px 12px rgba(201, 169, 110, 0.3),
    inset 0 1px 0 rgba(201, 169, 110, 0.2) !important;
  text-shadow: 0 0 10px rgba(201, 169, 110, 0.5) !important;
}

/* ── バッジ・ステータス ── */
.sanctuary-cast-card .sanctuary-status-badge {
  background: linear-gradient(135deg, #C9A96E, #8B6914) !important;
  color: #0D0D0D !important;
  font-weight: 700 !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.1em !important;
  padding: 4px 10px !important;
  border-radius: 2px !important;
  text-transform: uppercase !important;
  box-shadow: 0 2px 8px rgba(201, 169, 110, 0.4) !important;
}

/* ── CTAボタン ── */
.sanctuary-cta-btn,
.et_pb_button.sanctuary-btn-primary {
  background: linear-gradient(
    135deg,
    #8B6914 0%,
    #C9A96E 40%,
    #fff0c8 60%,
    #C9A96E 80%,
    #8B6914 100%
  ) !important;
  background-size: 200% auto !important;
  color: #0D0D0D !important;
  font-family: 'Noto Serif JP', serif !important;
  font-weight: 700 !important;
  letter-spacing: 0.15em !important;
  border: none !important;
  border-radius: 3px !important;
  padding: 14px 36px !important;
  box-shadow:
    0 4px 20px rgba(201, 169, 110, 0.4),
    0 0 40px rgba(201, 169, 110, 0.1) !important;
  transition: all 0.4s ease !important;
  text-shadow: none !important;
}

.sanctuary-cta-btn:hover,
.et_pb_button.sanctuary-btn-primary:hover {
  background-position: right center !important;
  box-shadow:
    0 6px 30px rgba(201, 169, 110, 0.6),
    0 0 60px rgba(201, 169, 110, 0.2) !important;
  transform: translateY(-2px) !important;
}

/* ── フローティングCTAボタン（モバイル） ── */
.sanctuary-floating-cta {
  background: linear-gradient(
    135deg,
    #8B6914,
    #C9A96E,
    #fff0c8,
    #C9A96E,
    #8B6914
  ) !important;
  background-size: 300% auto !important;
  animation: floatingBtnShimmer 3s linear infinite !important;
  box-shadow:
    0 4px 20px rgba(201, 169, 110, 0.5),
    0 0 0 2px rgba(201, 169, 110, 0.2) !important;
}

@keyframes floatingBtnShimmer {
  0%   { background-position: 0% center; }
  100% { background-position: 300% center; }
}

/* ── セクション区切りデコレーション ── */
.et_pb_section::before {
  content: none !important;
}

/* ゴールドのセパレーターライン */
.sanctuary-divider {
  height: 1px !important;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(201, 169, 110, 0.2) 15%,
    rgba(201, 169, 110, 0.6) 50%,
    rgba(201, 169, 110, 0.2) 85%,
    transparent 100%
  ) !important;
  margin: 0 auto !important;
  width: 80% !important;
}

/* ── キャストカード ── */
.sanctuary-cast-card {
  border: 1px solid rgba(201, 169, 110, 0.15) !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  background: linear-gradient(
    180deg,
    rgba(20, 15, 10, 0.9) 0%,
    rgba(10, 8, 5, 0.95) 100%
  ) !important;
  transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1) !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5) !important;
}

.sanctuary-cast-card:hover {
  border-color: rgba(201, 169, 110, 0.5) !important;
  box-shadow:
    0 8px 40px rgba(0, 0, 0, 0.7),
    0 0 20px rgba(201, 169, 110, 0.15) !important;
  transform: translateY(-4px) !important;
}

/* キャスト名 */
.sanctuary-cast-card .sanctuary-cast-name {
  font-family: 'Noto Serif JP', serif !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: #F0EDE5 !important;
  letter-spacing: 0.08em !important;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.8) !important;
}

/* スリーサイズ */
.sanctuary-cast-card .sanctuary-cast-specs {
  color: #C8BFA8 !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.05em !important;
}

/* 出勤時間 */
.sanctuary-cast-card .sanctuary-cast-time {
  color: #C9A96E !important;
  font-weight: 600 !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.1em !important;
  text-shadow: 0 0 8px rgba(201, 169, 110, 0.4) !important;
}

/* ── ニュース・トピックスセクション ── */
.sanctuary-news-item {
  border-left: 3px solid #C9A96E !important;
  padding-left: 16px !important;
  margin-bottom: 16px !important;
  transition: border-color 0.3s ease !important;
}

.sanctuary-news-item:hover {
  border-left-color: #fff0c8 !important;
}

.sanctuary-news-item a {
  color: #C8BFA8 !important;
  text-decoration: none !important;
  transition: color 0.3s ease !important;
}

.sanctuary-news-item a:hover {
  color: #C9A96E !important;
}

/* ── スクロールバーカスタマイズ ── */
::-webkit-scrollbar {
  width: 6px !important;
}

::-webkit-scrollbar-track {
  background: #0D0D0D !important;
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #8B6914, #C9A96E) !important;
  border-radius: 3px !important;
}

::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #C9A96E, #fff0c8) !important;
}

/* ── テキスト選択時のハイライト ── */
::selection {
  background: rgba(201, 169, 110, 0.3) !important;
  color: #F0EDE5 !important;
}


/* ============================================================
   29. モバイル版ヘッダー修正
   ============================================================ */

/* ── ハンバーガーアイコンの背景色を除去 ── */
@media (max-width: 980px) {

  /* DIVIのモバイルメニューバーの背景・ボーダーをリセット */
  #et-boc .et-l--header .et_pb_menu .mobile_nav,
  #et-boc .et-l--header .et_pb_menu .mobile_nav .mobile_menu_bar,
  .et_pb_menu .mobile_nav,
  .et_pb_menu .mobile_nav .mobile_menu_bar,
  #main-header .mobile_nav,
  #main-header .mobile_nav .mobile_menu_bar {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
  }

  /* ハンバーガーアイコン本体 */
  #et-boc .et-l--header .et_pb_menu .mobile_nav .mobile_menu_bar:before,
  .et_pb_menu .mobile_nav .mobile_menu_bar:before,
  #main-header .mobile_menu_bar:before {
    color: #C9A96E !important;
    font-size: 1.6rem !important;
    text-shadow: 0 0 10px rgba(201, 169, 110, 0.7) !important;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    line-height: 1 !important;
  }

  /* ハンバーガーアイコンのコンテナ */
  #et-boc .et-l--header .et_pb_menu .mobile_nav .mobile_menu_bar,
  .et_pb_menu .mobile_nav .mobile_menu_bar {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    background: rgba(201, 169, 110, 0.1) !important;
    border: 1px solid rgba(201, 169, 110, 0.3) !important;
    border-radius: 4px !important;
  }

  /* ヘッダー全体のレイアウト（モバイル） */
  #et-boc .et-l--header .et_pb_row,
  #et-boc .et-l--header .et_pb_section .et_pb_row,
  #main-header .et_pb_row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 10px 16px !important;
    max-width: 100% !important;
    width: 100% !important;
  }

  /* ロゴのサイズ調整（モバイル） */
  #et-boc .et-l--header .et_pb_image img,
  #main-header .et_pb_image img,
  .et_pb_header_logo img {
    max-height: 50px !important;
    width: auto !important;
    max-width: 200px !important;
  }

  /* ロゴカラム */
  #et-boc .et-l--header .et_pb_column:first-child,
  #main-header .et_pb_column:first-child {
    flex: 1 !important;
    max-width: none !important;
    width: auto !important;
  }

  /* メニューカラム */
  #et-boc .et-l--header .et_pb_column:last-child,
  #main-header .et_pb_column:last-child {
    flex: 0 0 auto !important;
    width: auto !important;
  }

  /* モバイルメニュー展開時のスタイル */
  #et-boc .et-l--header .et_pb_menu .et_mobile_menu,
  .et_pb_menu .et_mobile_menu {
    background: rgba(5, 5, 5, 0.98) !important;
    border-top: 2px solid #C9A96E !important;
    border-bottom: 1px solid rgba(201, 169, 110, 0.2) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.8) !important;
    padding: 8px 0 !important;
  }

  /* モバイルメニューの各リンク */
  .et_pb_menu .et_mobile_menu li,
  #et-boc .et-l--header .et_pb_menu .et_mobile_menu li {
    border-bottom: 1px solid rgba(201, 169, 110, 0.1) !important;
  }

  .et_pb_menu .et_mobile_menu li a,
  #et-boc .et-l--header .et_pb_menu .et_mobile_menu li a {
    color: #E8E0D0 !important;
    font-family: 'Noto Serif JP', serif !important;
    font-size: 0.95rem !important;
    letter-spacing: 0.1em !important;
    padding: 16px 24px !important;
    display: block !important;
    transition: all 0.25s ease !important;
    background: transparent !important;
  }

  .et_pb_menu .et_mobile_menu li a:hover,
  #et-boc .et-l--header .et_pb_menu .et_mobile_menu li a:hover {
    color: #C9A96E !important;
    background: rgba(201, 169, 110, 0.08) !important;
    padding-left: 32px !important;
  }

  /* 電話番号リンク（モバイル専用） */
  .et_pb_menu .et_mobile_menu li.menu-tel a,
  .et_pb_menu .et_mobile_menu li a[href^="tel:"] {
    color: #C9A96E !important;
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.05em !important;
    text-align: center !important;
    background: rgba(201, 169, 110, 0.08) !important;
    border-top: 1px solid rgba(201, 169, 110, 0.3) !important;
    border-bottom: 1px solid rgba(201, 169, 110, 0.3) !important;
  }
}

/* ── 768px以下（スマートフォン） ── */
@media (max-width: 768px) {

  /* ヘッダーの高さを適切に */
  #et-boc .et-l--header .et_pb_section,
  #main-header {
    min-height: 64px !important;
  }

  /* ロゴをさらに小さく */
  #et-boc .et-l--header .et_pb_image img,
  #main-header .et_pb_image img {
    max-height: 44px !important;
    max-width: 160px !important;
  }

  /* ハンバーガーアイコンのサイズ */
  #et-boc .et-l--header .et_pb_menu .mobile_nav .mobile_menu_bar,
  .et_pb_menu .mobile_nav .mobile_menu_bar {
    width: 40px !important;
    height: 40px !important;
  }

  #et-boc .et-l--header .et_pb_menu .mobile_nav .mobile_menu_bar:before,
  .et_pb_menu .mobile_nav .mobile_menu_bar:before {
    font-size: 1.4rem !important;
  }
}


/* ============================================================
   30. スマホ用コンテンツナビゲーション [sanctuary_sp_nav]
   ============================================================ */

.sanctuary-sp-nav {
    background: #0D0D0D;
    border-top: 1px solid rgba(201, 169, 110, 0.3);
    border-bottom: 1px solid rgba(201, 169, 110, 0.3);
    padding: 4px 0;
}

.sanctuary-sp-nav__list {
    display: grid;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 1px;
    background: rgba(201, 169, 110, 0.15);
}

.sanctuary-sp-nav__list--col3 {
    grid-template-columns: repeat(3, 1fr);
}

.sanctuary-sp-nav__list--col4 {
    grid-template-columns: repeat(4, 1fr);
}

.sanctuary-sp-nav__item {
    background: #0D0D0D;
}

.sanctuary-sp-nav__link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 14px 8px 12px;
    text-decoration: none !important;
    color: #E8E0D0 !important;
    transition: all 0.2s ease;
    position: relative;
    overflow: hidden;
}

.sanctuary-sp-nav__link::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(201, 169, 110, 0.08), transparent);
    opacity: 0;
    transition: opacity 0.2s ease;
}

.sanctuary-sp-nav__link:hover::before,
.sanctuary-sp-nav__link:active::before {
    opacity: 1;
}

.sanctuary-sp-nav__link:active {
    transform: scale(0.96);
}

.sanctuary-sp-nav__icon {
    font-size: 1.5rem;
    line-height: 1;
    display: block;
    /* アイコンにゴールドのドロップシャドウ */
    filter: drop-shadow(0 0 4px rgba(201, 169, 110, 0.5));
}

.sanctuary-sp-nav__label {
    font-size: 0.65rem;
    font-family: 'Noto Serif JP', serif;
    letter-spacing: 0.05em;
    text-align: center;
    line-height: 1.3;
    color: #C9A96E;
    font-weight: 500;
}

/* 色覚バリアフリー対応: アクティブ状態は色だけでなく形状でも識別 */
.sanctuary-sp-nav__item--schedule .sanctuary-sp-nav__icon { filter: drop-shadow(0 0 6px rgba(201, 169, 110, 0.8)); }
.sanctuary-sp-nav__item--new .sanctuary-sp-nav__icon { filter: drop-shadow(0 0 6px rgba(201, 169, 110, 0.8)); }


/* ============================================================
   31. スマホ用 営業時間＋電話番号 CTAバー [sanctuary_sp_cta]
   ============================================================ */

.sanctuary-sp-cta {
    display: flex;
    align-items: stretch;
    gap: 0;
    background: #0D0D0D;
    border: 1px solid rgba(201, 169, 110, 0.2);
    border-radius: 8px;
    overflow: hidden;
    margin: 12px 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
}

.sanctuary-sp-cta__hours {
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 14px 16px;
    border-right: 1px solid rgba(201, 169, 110, 0.2);
    min-width: 130px;
}

.sanctuary-sp-cta__hours-label {
    font-size: 0.65rem;
    color: #8A93BD;
    letter-spacing: 0.1em;
    font-family: 'Noto Serif JP', serif;
    margin-bottom: 4px;
}

.sanctuary-sp-cta__hours-time {
    font-size: 0.95rem;
    font-weight: 700;
    color: #F0EDE5;
    font-family: 'Cormorant Garamond', 'Noto Serif JP', serif;
    letter-spacing: 0.05em;
    white-space: nowrap;
}

.sanctuary-sp-cta__hours-note {
    font-size: 0.6rem;
    color: #8A93BD;
    margin-top: 4px;
    letter-spacing: 0.05em;
}

.sanctuary-sp-cta__tel {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    background: linear-gradient(135deg, #C9A96E 0%, #E8C97A 50%, #C9A96E 100%);
    text-decoration: none !important;
    transition: all 0.2s ease;
    gap: 4px;
}

.sanctuary-sp-cta__tel:active {
    transform: scale(0.98);
    filter: brightness(0.9);
}

.sanctuary-sp-cta__tel-text {
    font-size: 0.6rem;
    color: #1A1008;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-align: center;
    line-height: 1.3;
}

.sanctuary-sp-cta__tel-number {
    font-size: 1.3rem;
    font-weight: 900;
    color: #1A1008;
    font-family: 'Inter', sans-serif;
    letter-spacing: 0.02em;
    white-space: nowrap;
    text-shadow: 0 1px 2px rgba(255, 255, 255, 0.3);
}


/* ============================================================
   32. スマホ用 TOPページコンテンツ目次 [sanctuary_sp_contents_menu]
   ============================================================ */

.sanctuary-sp-contents-menu {
    margin: 16px;
    border: 1px solid rgba(201, 169, 110, 0.3);
    border-radius: 8px;
    overflow: hidden;
    background: #0D0D0D;
}

.sanctuary-sp-contents-menu__header {
    background: linear-gradient(90deg, rgba(201, 169, 110, 0.15), rgba(201, 169, 110, 0.05));
    border-bottom: 1px solid rgba(201, 169, 110, 0.3);
    padding: 10px 16px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.sanctuary-sp-contents-menu__header::before {
    content: '';
    display: block;
    width: 3px;
    height: 16px;
    background: linear-gradient(180deg, #C9A96E, #E8C97A);
    border-radius: 2px;
    flex-shrink: 0;
}

.sanctuary-sp-contents-menu__title {
    font-size: 0.7rem;
    font-family: 'Cormorant Garamond', serif;
    letter-spacing: 0.2em;
    color: #C9A96E;
    font-weight: 600;
    text-transform: uppercase;
}

.sanctuary-sp-contents-menu__list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 1px;
    background: rgba(201, 169, 110, 0.1);
}

.sanctuary-sp-contents-menu__item {
    background: #0D0D0D;
}

.sanctuary-sp-contents-menu__link {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 14px 10px;
    text-decoration: none !important;
    color: #E8E0D0 !important;
    transition: all 0.2s ease;
    font-size: 0.7rem;
    font-family: 'Noto Serif JP', serif;
    letter-spacing: 0.05em;
    position: relative;
}

.sanctuary-sp-contents-menu__link:active {
    background: rgba(201, 169, 110, 0.1);
}

.sanctuary-sp-contents-menu__icon {
    font-size: 1rem;
    flex-shrink: 0;
}

.sanctuary-sp-contents-menu__label {
    flex: 1;
    line-height: 1.3;
    color: #C9A96E;
    font-size: 0.68rem;
}

.sanctuary-sp-contents-menu__arrow {
    font-size: 0.5rem;
    color: rgba(201, 169, 110, 0.5);
    flex-shrink: 0;
}


/* ============================================================
   33. スマホ版専用: PC では非表示にするコンポーネント
   ============================================================ */

@media (min-width: 769px) {
    .sanctuary-sp-nav,
    .sanctuary-sp-cta,
    .sanctuary-sp-contents-menu {
        display: none !important;
    }
}

/* スマホ版でのみ表示 */
@media (max-width: 768px) {
    .sanctuary-sp-nav,
    .sanctuary-sp-cta,
    .sanctuary-sp-contents-menu {
        display: block;
    }
}


/* ============================================================
   34. 新人キャスト スライダー（sanctuary_new_girls_slider）
   フォーカス型：中山大・金枠・サムネイル付き
   ============================================================ */

/* ラッパー：ボタンが左右にはみ出るので左右にパディング */
.sanctuary-new-girls-slider {
    position: relative;
    width: 100%;
    padding: 0 40px;
    box-sizing: border-box;
}

/* ビューポート：オーバーフローを隐す */
.sanctuary-new-girls-slider__viewport {
    overflow: hidden;
    width: 100%;
}

/* トラック：スライドを横並び */
.sanctuary-new-girls-slider__track {
    display: flex;
    gap: 12px;
    transition: transform 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    will-change: transform;
    align-items: flex-start;
}

/* 各スライド：PC 5枚表示、拡大縮小なし */
.sanctuary-new-girls-slider__slide {
    flex: 0 0 calc(20% - 10px); /* PC: 5枚表示 */
    min-width: 0;
    transform: none;
    opacity: 1;
    transform-origin: top center;
}

/* is-center：拡大なし（識別用にクラスは残す） */
.sanctuary-new-girls-slider__slide.is-center {
    transform: none;
    opacity: 1;
    z-index: 1;
}

/* カード本体：出勤情報カードと同じスタイルを使用（sanctuary-schedule-cardに従う） */
.sanctuary-new-girls-slider__card {
    /* sanctuary-schedule-cardのスタイルを継承 */
}

/* 画像ラッパー */
.sanctuary-new-girls-slider__img-wrap {
    position: relative;
    width: 100%;
    aspect-ratio: 2 / 3;
    overflow: hidden;
    background: #111;
}

.sngs-main-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
    transition: transform 0.4s ease;
}

.sanctuary-new-girls-slider__slide:hover .sngs-main-img {
    transform: scale(1.04);
}

/* バッジ共通 */
.sngs-badge {
    position: absolute;
    z-index: 3;
    font-size: 0.65rem;
    font-weight: 700;
    line-height: 1;
    padding: 3px 6px;
    border-radius: 3px;
    letter-spacing: 0.03em;
}

/* NEWバッジ：右上 */
.sngs-badge--new {
    top: 6px;
    right: 6px;
    background: linear-gradient(135deg, #C9A96E, #a07840);
    color: #0D0D0D;
    font-style: italic;
    font-size: 0.7rem;
    padding: 4px 8px;
    border-radius: 2px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.5);
}

/* 本日出勤バッジ：左下 */
.sngs-badge--today {
    bottom: 6px;
    left: 0;
    background: #cc2200;
    color: #fff;
    font-size: 0.68rem;
    padding: 4px 8px;
    border-radius: 0 3px 3px 0;
}

/* サムネイルコンテナ */
.sngs-thumbs {
    display: flex;
    gap: 4px;
    padding: 6px 6px 0;
    background: #1A1A1A;
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
}

.sngs-thumbs::-webkit-scrollbar { display: none; }

/* サムネイルボタン */
.sngs-thumb-btn {
    flex: 0 0 calc(33.333% - 3px);
    border: 2px solid transparent;
    border-radius: 2px;
    overflow: hidden;
    cursor: pointer;
    padding: 0;
    background: #111;
    transition: border-color 0.2s ease;
    aspect-ratio: 1 / 1;
}

.sngs-thumb-btn img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
}

.sngs-thumb-btn.is-active,
.sngs-thumb-btn:hover {
    border-color: #C9A96E;
}

/* テキストエリア */
.sngs-body {
    padding: 5px 6px 7px;
    text-align: center;
    background: #1A1A1A;
}

.sngs-course {
    font-size: 0.68rem;
    color: #8A93BD;
    margin: 0 0 3px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sngs-name {
    font-size: 0.9rem;
    font-weight: 700;
    color: #F0EDE5 !important;
    margin: 0 0 1px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.3;
}

.sngs-name a,
.sngs-name a:link,
.sngs-name a:visited,
.sngs-name a:hover {
    color: #F0EDE5 !important;
    text-decoration: none !important;
}

.sngs-age {
    font-size: 0.78rem;
    color: #C9A96E !important;
    font-weight: 400;
}

.sngs-size {
    font-size: 0.72rem;
    color: #C9A96E;
    margin: 0;
    line-height: 1.3;
}

/* 前後ボタン：スライダー左右に配置 */
.sanctuary-new-girls-slider__btn {
    position: absolute;
    top: 35%;
    transform: translateY(-50%);
    z-index: 20;
    background: rgba(13, 13, 13, 0.85);
    border: 2px solid #C9A96E;
    color: #C9A96E;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    font-size: 1.2rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease;
    line-height: 1;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    user-select: none;
}

.sanctuary-new-girls-slider__btn:hover {
    background: rgba(201, 169, 110, 0.25);
}
.sanctuary-new-girls-slider__btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
    pointer-events: none;
}

.sanctuary-new-girls-slider__btn--prev { left: 0; }
.sanctuary-new-girls-slider__btn--next { right: 0; }

/* タブレット: 3枚表示 */
@media (max-width: 1024px) {
    .sanctuary-new-girls-slider__slide {
        flex: 0 0 calc(33.333% - 8px);
    }
}

/* スマホ: Instagram風ネイティブスクロール方式 */
@media (max-width: 640px) {
    /* ラッパー: パディングなし */
    .sanctuary-new-girls-slider {
        padding: 0;
    }
    /* ビューポート: ネイティブ横スクロールに切り替え */
    .sanctuary-new-girls-slider__viewport {
        overflow-x: scroll;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scroll-snap-type: x mandatory;
        scrollbar-width: none;
    }
    .sanctuary-new-girls-slider__viewport::-webkit-scrollbar {
        display: none;
    }
    /* トラック: JSの制御を無効化してCSSスクロールに委ねる */
    .sanctuary-new-girls-slider__track {
        transform: none !important;
        transition: none !important;
        flex-wrap: nowrap;
        width: max-content;
        gap: 8px;
        padding: 0 4px;
    }
    /* 2カラム表示（正確に2枚并び、右端に次のカードが少し見える） */
    .sanctuary-new-girls-slider__slide {
        flex: 0 0 calc(46vw);
        scroll-snap-align: start;
        transform: none !important;
        opacity: 1 !important;
    }
    /* 矢印ボタンをスマホでは非表示 */
    .sanctuary-new-girls-slider__btn {
        display: none !important;
    }
    /* サイズ表示を1行に */
    .sngs-size {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        font-size: 0.65rem;
    }
    /* 名前・年齢フォントを小さく */
    .sngs-name {
        font-size: 0.78rem;
    }
    .sngs-age {
        font-size: 0.7rem;
    }
    /* 予約バッジを小さく */
    .sngs-availability {
        font-size: 0.68rem;
        padding: 5px 6px;
        min-height: 28px;
    }
    .sngs-availability__time {
        font-size: 0.72rem;
    }
}


/* ============================================================
   35. 全新人キャスト 一覧グリッド（sanctuary_new_girls_all）
   ============================================================ */

.sanctuary-new-girls-all {
    display: grid;
    grid-template-columns: repeat(var(--sngs-all-columns, 4), 1fr);
    gap: 16px;
    width: 100%;
}

.sanctuary-new-girls-all__card {
    background: #1A1A1A;
    border: 2px solid #C9A96E;
    border-radius: 4px;
    overflow: hidden;
    box-shadow: 0 0 10px rgba(201, 169, 110, 0.2);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.sanctuary-new-girls-all__card:hover {
    transform: translateY(-4px);
    box-shadow: 0 0 18px rgba(201, 169, 110, 0.45);
}

.sanctuary-new-girls-all__img-wrap {
    position: relative;
    width: 100%;
    aspect-ratio: 2 / 3;
    overflow: hidden;
    background: #111;
}

.sanctuary-new-girls-all__img-wrap .sngs-main-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
    transition: transform 0.4s ease;
}

.sanctuary-new-girls-all__card:hover .sanctuary-new-girls-all__img-wrap .sngs-main-img {
    transform: scale(1.04);
}

/* 出勤時間 */
.sngs-time {
    font-size: 0.78rem;
    color: #C9A96E;
    margin: 1px 0 0;
    line-height: 1.3;
}

/* タブレット: 3列 */
@media (max-width: 1024px) {
    .sanctuary-new-girls-all {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* スマホ: 2列 */
@media (max-width: 640px) {
    .sanctuary-new-girls-all {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }
}

/* ============================================================
   予約状況バッジ（sngs-availability）
   ============================================================ */

/* 共通ベース */
.sngs-availability {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 8px 0 0;
    padding: 8px 12px;
    border-radius: 3px;
    font-size: 0.82rem;
    font-weight: bold;
    letter-spacing: 0.05em;
    background: linear-gradient(135deg, #8B6914 0%, #C9A96E 50%, #8B6914 100%);
    color: #fff;
    text-align: center;
    min-height: 36px;
    width: 100%;
    box-sizing: border-box;
}

/* 受付終了 */
.sngs-availability--closed {
    background: rgba(80, 80, 80, 0.85);
    color: #ccc;
    font-size: 0.78rem;
}

/* 今すぐご案内可能 */
.sngs-availability--now {
    background: linear-gradient(135deg, #8B6914 0%, #C9A96E 50%, #8B6914 100%);
    color: #0d0d0d;
    font-weight: 800;
}

/* 次回ご案内 ○:○〜 */
.sngs-availability--next {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 4px;
    background: rgba(30, 50, 90, 0.9);
    color: #fff;
    padding: 6px 10px;
    border: 1px solid rgba(100, 140, 220, 0.4);
}

.sngs-availability__icon {
    font-size: 0.7rem;
    margin-right: 4px;
    flex-shrink: 0;
    line-height: 1;
}

.sngs-availability__label {
    font-size: 0.75rem;
    white-space: nowrap;
    flex-shrink: 0;
}

.sngs-availability__time {
    font-size: 0.85rem;
    font-weight: bold;
    white-space: nowrap;
    background: rgba(0, 0, 0, 0.25);
    padding: 2px 8px;
    border-radius: 3px;
}

/* 即ヒメ: 今すぐご案内（待ち時間なし）— 青系（色覚異常対応: P型・D型でも識別可能） */
.sngs-availability--free {
    background: linear-gradient(135deg, #004f8b 0%, #0072B2 50%, #004f8b 100%);
    color: #fff;
    font-weight: 800;
    box-shadow: 0 0 8px rgba(0, 114, 178, 0.5);
}

/* 即ヒメ: ご予約満了 — アンバーオレンジ（色覚異常対応: P型・D型でも青と区別可能） */
.sngs-availability--full {
    background: linear-gradient(135deg, #a06000 0%, #E69F00 50%, #a06000 100%);
    color: #1a1a1a;
    font-weight: 800;
}

/* sanctuary-schedule-card 側にも同じバッジを適用 */
.sanctuary-schedule-card .sngs-availability {
    margin: 6px 0 0;
    font-size: 0.78rem;
    padding: 7px 10px;
}

/* スマホ対応 */
@media (max-width: 640px) {
    .sngs-availability {
        font-size: 0.72rem;
        padding: 5px 6px;
        min-height: 28px;
    }
    .sngs-availability--next {
        padding: 5px 6px;
        gap: 3px;
    }
    .sngs-availability__label {
        font-size: 0.68rem;
    }
    .sngs-availability__time {
        font-size: 0.75rem;
        padding: 2px 6px;
    }
    /* sanctuary-schedule-card内のバッジ */
    .sanctuary-schedule-card .sngs-availability {
        font-size: 0.68rem;
        padding: 4px 6px;
    }
}


/* ============================================================
   Divi ビジュアルビルダー（編集画面）対応
   ============================================================ */
/* 編集画面でスライダー・カード画像が拡大されないよう制限 */
.et-fb-root-ancestor .sanctuary-new-girls-slider__img-wrap,
.et-fb-root-ancestor .sanctuary-schedule-card__main {
    max-height: 300px;
}
.et-fb-root-ancestor .sanctuary-new-girls-slider__img-wrap img,
.et-fb-root-ancestor .sanctuary-schedule-card__main-img {
    max-height: 300px;
    object-fit: cover;
    object-position: top center;
}
/* 編集画面でスライダーのトラックが正しく表示されるよう調整 */
.et-fb-root-ancestor .sanctuary-new-girls-slider__track {
    flex-wrap: wrap;
    transform: none !important;
}
.et-fb-root-ancestor .sanctuary-new-girls-slider__slide {
    flex: 0 0 calc(20% - 10px);
}
/* 編集画面でのヒーロースライダーの高さ制限 */
.et-fb-root-ancestor .sanctuary-hero-slider__slide {
    max-height: 400px;
    overflow: hidden;
}
.et-fb-root-ancestor .sanctuary-hero-slider__slide img {
    max-height: 400px;
    object-fit: cover;
}


/* ============================================================
   キャストシングルページ (sanctuary_cast_profile)
   ============================================================ */

/* ── ラッパー ── */
.scp-wrapper {
    background: var(--color-bg-base, #0D0D0D);
    color: var(--color-text-primary, #F0EAD6);
    font-family: 'Noto Serif JP', 'ヒラギノ明朝 ProN', 'HiraMinProN-W3', serif;
    max-width: 800px;
    margin: 0 auto;
    padding: 0 0 40px;
}

/* ── ① プロフィールヘッダー ── */
.scp-header {
    position: relative;
    background: var(--color-bg-surface, #1A1A1A);
    padding: 24px 20px 20px;
    border-bottom: 1px solid rgba(201,169,110,0.3);
}
.scp-header__badge-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
}
.scp-badge--working {
    display: inline-block;
    background: var(--color-gold, #C9A96E);
    color: #0D0D0D;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    padding: 3px 10px;
    border-radius: 2px;
}
.scp-badge--new {
    display: inline-block;
    background: var(--color-rose, #C97B8A);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    padding: 3px 10px;
    border-radius: 2px;
}
.scp-header__name {
    font-size: 28px;
    font-weight: 700;
    color: var(--color-gold, #C9A96E);
    letter-spacing: 0.12em;
    margin: 0 0 4px;
    line-height: 1.2;
}
.scp-header__name-ruby {
    font-size: 12px;
    color: var(--color-text-muted, #8B7355);
    letter-spacing: 0.15em;
    margin-bottom: 8px;
}
.scp-header__age {
    font-size: 14px;
    color: var(--color-text-secondary, #C8B89A);
    margin-bottom: 6px;
}
.scp-header__size {
    font-size: 13px;
    color: var(--color-text-secondary, #C8B89A);
    letter-spacing: 0.05em;
    margin-bottom: 10px;
}
.scp-header__catchphrase {
    font-size: 13px;
    color: var(--color-text-muted, #8B7355);
    font-style: italic;
    line-height: 1.6;
    border-left: 2px solid var(--color-gold, #C9A96E);
    padding-left: 10px;
}

/* ── ② メイン画像ギャラリー ── */
.scp-gallery {
    background: #000;
    position: relative;
}
.scp-gallery__main {
    position: relative;
    width: 100%;
    aspect-ratio: 3/4;
    overflow: hidden;
    background: #111;
}
.scp-gallery__main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    cursor: zoom-in;
    transition: opacity 0.3s ease;
}
.scp-gallery__main img:hover {
    opacity: 0.95;
}
.scp-gallery__main-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(0,0,0,0.5);
    border: 1px solid rgba(201,169,110,0.4);
    color: var(--color-gold, #C9A96E);
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 16px;
    z-index: 10;
    transition: background 0.2s;
    -webkit-tap-highlight-color: transparent;
}
.scp-gallery__main-nav:hover {
    background: rgba(201,169,110,0.3);
}
.scp-gallery__main-nav--prev { left: 10px; }
.scp-gallery__main-nav--next { right: 10px; }
.scp-gallery__main-nav.is-hidden { display: none; }

.scp-gallery__counter {
    position: absolute;
    bottom: 10px;
    right: 12px;
    background: rgba(0,0,0,0.6);
    color: var(--color-gold, #C9A96E);
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 10px;
}
.scp-gallery__thumbs {
    display: flex;
    gap: 4px;
    padding: 6px;
    background: #111;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.scp-gallery__thumbs::-webkit-scrollbar { display: none; }
.scp-gallery__thumb {
    flex: 0 0 70px;
    height: 70px;
    overflow: hidden;
    border: 2px solid transparent;
    cursor: pointer;
    transition: border-color 0.2s;
    border-radius: 2px;
}
.scp-gallery__thumb.is-active {
    border-color: var(--color-gold, #C9A96E);
}
.scp-gallery__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* ── ③ セクション共通 ── */
.scp-section {
    padding: 20px;
    border-bottom: 1px solid rgba(201,169,110,0.15);
}
.scp-section__title {
    font-size: 12px;
    letter-spacing: 0.2em;
    color: var(--color-gold, #C9A96E);
    text-transform: uppercase;
    margin: 0 0 14px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.scp-section__title::after {
    content: '';
    flex: 1;
    height: 1px;
    background: linear-gradient(to right, rgba(201,169,110,0.4), transparent);
}

/* ── ④ プロフィールテーブル ── */
.scp-profile-table {
    width: 100%;
    border-collapse: collapse;
}
.scp-profile-table tr {
    border-bottom: 1px solid rgba(201,169,110,0.1);
}
.scp-profile-table tr:last-child {
    border-bottom: none;
}
.scp-profile-table th {
    width: 38%;
    padding: 9px 8px 9px 0;
    font-size: 12px;
    color: var(--color-text-muted, #8B7355);
    font-weight: 400;
    text-align: left;
    vertical-align: top;
    white-space: nowrap;
}
.scp-profile-table td {
    padding: 9px 0;
    font-size: 13px;
    color: var(--color-text-secondary, #C8B89A);
    line-height: 1.5;
}

/* ── ⑤ キャストコメント / 店長コメント ── */
.scp-message {
    background: var(--color-bg-elevated, #242424);
    border-radius: 4px;
    padding: 16px;
    font-size: 13px;
    line-height: 1.8;
    color: var(--color-text-secondary, #C8B89A);
    position: relative;
}
.scp-message--cast::before {
    content: '"';
    position: absolute;
    top: -8px;
    left: 12px;
    font-size: 48px;
    color: var(--color-gold, #C9A96E);
    opacity: 0.3;
    font-family: Georgia, serif;
    line-height: 1;
}
.scp-message--manager {
    border-left: 3px solid var(--color-gold, #C9A96E);
    border-radius: 0 4px 4px 0;
}

/* ── ⑥ 7日間スケジュール ── */
.scp-schedule-table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
}
.scp-schedule-table th,
.scp-schedule-table td {
    text-align: center;
    padding: 8px 4px;
    font-size: 11px;
    border: 1px solid rgba(201,169,110,0.15);
}
.scp-schedule-table th {
    background: rgba(201,169,110,0.1);
    color: var(--color-gold, #C9A96E);
    font-weight: 600;
    letter-spacing: 0.05em;
}
.scp-schedule-table td {
    color: var(--color-text-secondary, #C8B89A);
    background: var(--color-bg-surface, #1A1A1A);
}
.scp-schedule-table td.is-working {
    background: rgba(201,169,110,0.12);
    color: var(--color-gold, #C9A96E);
    font-weight: 600;
}
.scp-schedule-table td.is-off {
    color: rgba(200,184,154,0.3);
}
.scp-schedule-table .day-sat { color: #7EC8E3; }
.scp-schedule-table .day-sun { color: var(--color-rose, #C97B8A); }

/* ── ⑦ オプション ── */
.scp-options {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.scp-option-tag {
    display: inline-block;
    padding: 5px 12px;
    border-radius: 20px;
    font-size: 12px;
    letter-spacing: 0.05em;
    transition: all 0.2s;
}
.scp-option-tag--available {
    background: rgba(201,169,110,0.15);
    color: var(--color-gold, #C9A96E);
    border: 1px solid rgba(201,169,110,0.4);
}
.scp-option-tag--unavailable {
    background: rgba(255,255,255,0.03);
    color: rgba(200,184,154,0.3);
    border: 1px solid rgba(255,255,255,0.08);
    text-decoration: line-through;
}

/* ── ⑧ 動画セクション ── */
.scp-movie-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.scp-movie-item {
    background: var(--color-bg-elevated, #242424);
    border-radius: 4px;
    overflow: hidden;
}
.scp-movie-item video,
.scp-movie-item iframe {
    width: 100%;
    aspect-ratio: 16/9;
    display: block;
    border: none;
}

/* ── ⑨ 口コミ・レビュー ── */
.scp-review-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.scp-review-item {
    background: var(--color-bg-elevated, #242424);
    border-radius: 4px;
    padding: 14px;
}
.scp-review-item__header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}
.scp-review-item__stars {
    color: var(--color-gold, #C9A96E);
    font-size: 13px;
    letter-spacing: 2px;
}
.scp-review-item__date {
    font-size: 11px;
    color: var(--color-text-muted, #8B7355);
    margin-left: auto;
}
.scp-review-item__text {
    font-size: 13px;
    color: var(--color-text-secondary, #C8B89A);
    line-height: 1.7;
}

/* ── ⑩ 予約CTAボタン ── */
.scp-cta {
    padding: 20px;
    text-align: center;
}
.scp-cta__btn {
    display: block;
    width: 100%;
    max-width: 320px;
    margin: 0 auto 12px;
    padding: 16px 24px;
    background: linear-gradient(135deg, #C9A96E, #DFC08A);
    color: #0D0D0D;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-decoration: none;
    border-radius: 3px;
    text-align: center;
    transition: opacity 0.2s;
}
.scp-cta__btn:hover {
    opacity: 0.85;
    color: #0D0D0D;
    text-decoration: none;
}
.scp-cta__tel {
    font-size: 20px;
    font-weight: 700;
    color: var(--color-gold, #C9A96E);
    letter-spacing: 0.1em;
    text-decoration: none;
    display: block;
}
.scp-cta__tel-label {
    font-size: 11px;
    color: var(--color-text-muted, #8B7355);
    margin-bottom: 4px;
}

/* ── ライトボックス ── */
.scp-lightbox {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.92);
    z-index: 99999;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.scp-lightbox.is-open {
    display: flex;
}
.scp-lightbox__img {
    max-width: 100%;
    max-height: 90vh;
    object-fit: contain;
    border: 1px solid rgba(201,169,110,0.3);
}
.scp-lightbox__close {
    position: absolute;
    top: 16px;
    right: 16px;
    background: none;
    border: none;
    color: var(--color-gold, #C9A96E);
    font-size: 28px;
    cursor: pointer;
    line-height: 1;
    padding: 4px 8px;
}

/* ── モバイル最適化 ── */
@media (max-width: 480px) {
    .scp-header { padding: 20px 16px 16px; }
    .scp-header__name { font-size: 24px; }
    .scp-section { padding: 16px; }
    .scp-gallery__thumb { flex: 0 0 60px; height: 60px; }
    .scp-schedule-table th,
    .scp-schedule-table td { font-size: 10px; padding: 6px 2px; }
    .scp-cta__btn { font-size: 14px; padding: 14px 20px; }
}


/* ============================================================
   キャストシングルページ: ヘッダー高さの修正
   ?cast=ID パラメータ時に body.cast-single-page が付与される
   一覧ページ（archive post-type-archive-girls）と同じ高さに統一
   ============================================================ */

/* gh-menu セクション（ナビゲーション部分）のpadding上書き */
body.cast-single-page #et-boc .et-l--header .et_pb_section,
body.cast-single-page .et-db #et-boc .et-l--header .et_pb_section,
body.cast-single-page body:not(.et-fb) .et-l--header .et_pb_section {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

body.cast-single-page #et-boc .et-l--header .et_pb_section.et_pb_section_1_tb_header,
body.cast-single-page .et-db #et-boc .et-l--header .et_pb_section.et_pb_section_1_tb_header {
    padding-top: 5px !important;
    padding-bottom: 15px !important;
}

/* ヘッダー内のロウ（行）のpadding上書き */
body.cast-single-page #et-boc .et-l--header .et_pb_row,
body.cast-single-page .et-db #et-boc .et-l--header .et_pb_row {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* ナビゲーション行のpadding */
body.cast-single-page #et-boc .et-l--header .et_pb_row_1_tb_header,
body.cast-single-page .et-db #et-boc .et-l--header .et_pb_row_1_tb_header {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}


/* ============================================================
   在籍女性一覧 [sanctuary_girls_list] スタイル
   ============================================================ */

.sgl-wrapper { width:100%; max-width:1400px; margin:0 auto; padding:0 10px; box-sizing:border-box; }
.sgl-filter-bar { background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.15); border-radius:8px; padding:16px 20px; margin-bottom:24px; backdrop-filter:blur(4px); }
.sgl-filter-row { display:flex; flex-wrap:wrap; align-items:center; gap:12px 16px; margin-bottom:10px; }
.sgl-filter-row:last-child { margin-bottom:0; }
.sgl-filter-row--actions { justify-content:center; margin-top:6px; }
.sgl-filter-label { display:flex; align-items:center; gap:6px; color:#e0c88a; font-size:13px; font-weight:600; white-space:nowrap; }
.sgl-filter-label--wide { flex:1 1 auto; }
.sgl-filter-icon { font-size:14px; color:#e0c88a; }
.sgl-filter-label select,
.sgl-sort,
.sgl-filter { background:rgba(0,0,0,0.5); border:1px solid rgba(255,255,255,0.25); border-radius:4px; color:#fff; font-size:13px; padding:5px 8px; cursor:pointer; min-width:100px; max-width:200px; }
.sgl-filter-label--wide select { flex:1 1 auto; max-width:300px; }
.sgl-filter-label select:focus,
.sgl-sort:focus,
.sgl-filter:focus { outline:2px solid #e0c88a; outline-offset:1px; }
.sgl-btn { padding:8px 28px; border:none; border-radius:4px; font-size:14px; font-weight:700; cursor:pointer; transition:opacity 0.2s; letter-spacing:0.05em; }
.sgl-btn:hover { opacity:0.85; }
.sgl-btn--search { background:linear-gradient(135deg,#0072B2,#005a8e); color:#fff; }
.sgl-btn--clear { background:linear-gradient(135deg,#c06090,#9b3060); color:#fff; }
.sgl-count { color:#aaa; font-size:13px; margin:0 0 12px; text-align:right; }
.sgl-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
@media (max-width:1024px) { .sgl-grid { grid-template-columns:repeat(3,1fr); } }
@media (max-width:640px) { .sgl-grid { grid-template-columns:repeat(2,1fr); gap:10px; } }
.sgl-card { background:#1a1a1a; border-radius:6px; overflow:hidden; transition:transform 0.2s,box-shadow 0.2s; }
.sgl-card:hover { transform:translateY(-3px); box-shadow:0 6px 20px rgba(0,0,0,0.5); }
.sgl-card__img-link { display:block; text-decoration:none; }
.sgl-card__img-wrap { position:relative; width:100%; aspect-ratio:3/4; overflow:hidden; background:#111; }
.sgl-card__img-wrap img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.3s; }
.sgl-card:hover .sgl-card__img-wrap img { transform:scale(1.04); }
.sgl-card__new { position:absolute; top:8px; left:8px; background:#e0c88a; color:#111; font-size:10px; font-weight:800; padding:2px 7px; border-radius:3px; letter-spacing:0.08em; z-index:2; }
.sgl-card__thumbs { display:flex; gap:2px; background:#111; }
.sgl-card__thumbs img { flex:1 1 0; width:0; aspect-ratio:1/1; object-fit:cover; display:block; }
.sgl-card__body { padding:10px 10px 12px; text-align:center; }
.sgl-card__name { color:#e0c88a; font-size:15px; font-weight:700; margin:0 0 4px; line-height:1.3; }
.sgl-card__age { font-size:12px; color:#bbb; font-weight:400; margin-left:3px; }
.sgl-card__size { color:#ccc; font-size:12px; margin:0 0 8px; line-height:1.4; }
.sgl-card__badge { margin-top:6px; }
.sgl-card__badge .sngs-availability { display:inline-flex; align-items:center; justify-content:center; gap:4px; padding:5px 12px; border-radius:4px; font-size:12px; font-weight:700; width:100%; box-sizing:border-box; }
.sgl-no-result { text-align:center; color:#aaa; font-size:14px; padding:40px 0; }
@media (max-width:640px) {
    .sgl-filter-bar { padding:12px 14px; }
    .sgl-filter-label { font-size:12px; }
    .sgl-filter-label select, .sgl-sort, .sgl-filter { font-size:12px; min-width:80px; padding:4px 6px; }
    .sgl-filter-label--wide select { max-width:100%; }
    .sgl-btn { padding:7px 20px; font-size:13px; }
    .sgl-card__name { font-size:13px; }
    .sgl-card__size { font-size:11px; }
}


/* ============================================================
   Divi Mobile 下部ナビ：中央突き出し予約ボタン
   ============================================================ */

/* --- 中央突き出しボタン本体 --- */
.sanctuary-nav-reserve-btn {
    display: none; /* PC は非表示 */
}

@media (max-width: 980px) {

    /* ナビ li のコンテナ */
    .sanctuary-nav-reserve-li {
        display: flex !important;
        align-items: flex-end !important;
        justify-content: center !important;
        position: relative;
        padding-bottom: 0 !important;
        margin-top: -22px !important;
    }

    /* ボタン本体 */
    .sanctuary-nav-reserve-btn {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 3px;
        width: 62px;
        height: 62px;
        border-radius: 50%;
        border: 3px solid rgba(255, 255, 255, 0.25);
        background: linear-gradient(145deg, #c8922a 0%, #e0b84a 40%, #9f6e1e 100%);
        box-shadow:
            0 -4px 16px rgba(202, 162, 79, 0.55),
            0 4px 12px rgba(0, 0, 0, 0.45),
            inset 0 1px 0 rgba(255, 255, 255, 0.3);
        color: #fff;
        cursor: pointer;
        position: relative;
        z-index: 1000000000;
        transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
        -webkit-tap-highlight-color: transparent;
        outline: none;
    }

    .sanctuary-nav-reserve-btn:active {
        transform: scale(0.93);
        filter: brightness(0.9);
    }

    .sanctuary-nav-reserve-btn.is-active {
        background: linear-gradient(145deg, #8b1a1a 0%, #c0392b 40%, #6e1010 100%);
        box-shadow:
            0 -4px 16px rgba(192, 57, 43, 0.55),
            0 4px 12px rgba(0, 0, 0, 0.45),
            inset 0 1px 0 rgba(255, 255, 255, 0.2);
    }

    .sanctuary-nav-reserve-btn__icon {
        display: flex;
        align-items: center;
        justify-content: center;
        line-height: 1;
    }

    .sanctuary-nav-reserve-btn__icon svg {
        width: 26px;
        height: 26px;
        filter: drop-shadow(0 1px 2px rgba(0,0,0,0.4));
    }

    .sanctuary-nav-reserve-btn__label {
        font-size: 10px;
        font-weight: 700;
        letter-spacing: 0.04em;
        line-height: 1;
        text-shadow: 0 1px 2px rgba(0,0,0,0.4);
    }

    /* --- CTA パネル：トグルバーを非表示にし、ナビの上からせり上がる --- */
    #sanctuary-bottom-cta {
        bottom: 55px !important;
    }


    /* is-open 時：パネルをナビの上に表示 */
    #sanctuary-bottom-cta.is-open .sanctuary-bottom-cta__panel {
        max-height: 500px !important;
        opacity: 1 !important;
        transform: translateY(0) !important;
    }

    /* Divi Mobile ナビの ul に中央ボタン用のスペースを確保 */
    #dm-menu {
        overflow: visible !important;
    }

    .divi-mobile-menu.bottom-navigation-menu {
        overflow: visible !important;
    }
}


/* ============================================================
   アルバム見学セクション（.sc-album-section）
   ============================================================ */
.sc-album-section {
  background: #1A1A1A;
  border: 1px solid rgba(201,169,110,0.20);
  border-radius: 12px;
  padding: 40px 16px;
  max-width: 100%;
  margin: 0 auto;
  font-family: 'Noto Sans JP', 'Inter', sans-serif;
  color: #F0EDE5;
}
.sc-album-section__head {
  text-align: center;
  margin-bottom: 32px;
}
.sc-album-section__eyebrow {
  display: inline-block;
  font-family: 'Noto Serif JP', serif;
  font-size: 11px;
  letter-spacing: 0.25em;
  color: #C9A96E;
  text-transform: uppercase;
  border-top: 1px solid rgba(201,169,110,0.4);
  border-bottom: 1px solid rgba(201,169,110,0.4);
  padding: 4px 16px;
  margin-bottom: 16px;
}
.sc-album-section__title {
  font-family: 'Noto Serif JP', serif;
  font-size: clamp(28px, 6vw, 44px);
  font-weight: 700;
  color: #C9A96E;
  line-height: 1.2;
  letter-spacing: 0.05em;
  margin: 0 0 8px;
  text-shadow: 0 0 30px rgba(201,169,110,0.3);
}
.sc-album-section__title em {
  font-style: normal;
  color: #F0EDE5;
}
.sc-album-section__subtitle {
  font-size: 13px;
  color: #8A93BD;
  letter-spacing: 0.1em;
  margin: 0;
  padding-bottom: 0;
}
.sc-album-section__features {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 32px;
  padding: 20px 24px;
  background: rgba(201,169,110,0.06);
  border-left: 3px solid #C9A96E;
  border-radius: 0 8px 8px 0;
}
.sc-album-section__feature {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  line-height: 1.6;
  color: #F0EDE5;
  padding-bottom: 0;
  margin-bottom: 0;
}
.sc-album-section__feature::before {
  content: '◆';
  color: #C9A96E;
  font-size: 10px;
  margin-top: 4px;
  flex-shrink: 0;
}
.sc-album-section__body {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 24px;
  align-items: start;
}
.sc-album-section__text-block {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(201,169,110,0.15);
  border-radius: 8px;
  padding: 20px;
}
.sc-album-section__text-label {
  display: inline-block;
  background: #C9A96E;
  color: #0D0D0D;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 3px 10px;
  border-radius: 3px;
  margin-bottom: 12px;
}
.sc-album-section__text-lead {
  font-family: 'Noto Serif JP', serif;
  font-size: 16px;
  font-weight: 700;
  color: #F0EDE5;
  line-height: 1.6;
  margin: 0 0 12px;
  padding-bottom: 0;
}
.sc-album-section__text-body {
  font-size: 13px;
  color: #8A93BD;
  line-height: 1.8;
  margin: 0 0 16px;
  padding-bottom: 0;
}
.sc-album-section__notice {
  font-size: 11px;
  color: #6B6B6B;
  line-height: 1.7;
  border-top: 1px solid rgba(255,255,255,0.06);
  padding-top: 12px;
  margin: 0;
  padding-bottom: 0;
}
.sc-album-section__gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(2, 1fr);
  gap: 6px;
}
.sc-album-section__gallery-item {
  aspect-ratio: 3/4;
  overflow: hidden;
  border-radius: 6px;
  border: 1px solid rgba(201,169,110,0.15);
  background: #242424;
}
.sc-album-section__gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.sc-album-section__gallery-item:hover img {
  transform: scale(1.05);
}
.sc-subsection-title {
  display: flex;
  align-items: center;
  gap: 0;
  margin: 40px 0 20px;
  position: relative;
}
.sc-subsection-title::before {
  content: '';
  display: block;
  width: 4px;
  height: 1.4em;
  background: linear-gradient(180deg, #D4AF37 0%, #C9A96E 100%);
  border-radius: 2px;
  margin-right: 12px;
  flex-shrink: 0;
}
.sc-subsection-title::after {
  content: '';
  display: block;
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, rgba(201,169,110,0.5) 0%, rgba(201,169,110,0.05) 100%);
  margin-left: 16px;
}
.sc-subsection-title__text {
  font-family: 'Noto Serif JP', serif;
  font-size: 15px;
  font-weight: 700;
  color: #F0EDE5;
  letter-spacing: 0.12em;
  white-space: nowrap;
  padding-bottom: 0;
  margin: 0;
}
@media (max-width: 767px) {
  .sc-album-section {
    padding: 28px 16px;
    border-radius: 8px;
  }
  .sc-album-section__body {
    grid-template-columns: 1fr;
  }
  .sc-album-section__gallery {
    grid-template-columns: repeat(3, 1fr);
  }
  .sc-album-section__title {
    font-size: 28px;
  }
}


/* ============================================================
   ニュースシングルページ
   ============================================================ */
.sc-news-single {
  max-width: 860px;
  margin: 0 auto;
  padding: 40px 24px 60px;
  color: #F0EDE5;
  font-family: 'Noto Sans JP', 'Inter', sans-serif;
}

.sc-news-single__tag {
  display: inline-block;
  background: linear-gradient(135deg, #D4AF37 0%, #C9A96E 100%);
  color: #0D0D0D;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  padding: 3px 12px;
  border-radius: 2px;
  margin-bottom: 16px;
  text-transform: uppercase;
}

.sc-news-single__title {
  font-family: 'Noto Serif JP', serif;
  font-size: clamp(20px, 4vw, 28px);
  font-weight: 700;
  color: #F0EDE5;
  line-height: 1.5;
  margin: 0 0 12px;
  padding: 0;
  border: none;
  background: none;
}

.sc-news-single__date {
  display: block;
  font-size: 13px;
  color: rgba(201,169,110,0.8);
  letter-spacing: 0.08em;
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(201,169,110,0.2);
}

.sc-news-single__banner {
  margin-bottom: 32px;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid rgba(201,169,110,0.15);
}

.sc-news-single__banner img {
  width: 100%;
  height: auto;
  display: block;
}

.sc-news-single__body {
  font-size: 15px;
  line-height: 1.9;
  color: #D8D4CC;
  margin-bottom: 48px;
}

.sc-news-single__body p {
  margin-bottom: 1.4em;
}

.sc-news-single__body a {
  color: #C9A96E;
  text-decoration: underline;
}

.sc-news-single__footer {
  text-align: center;
  padding-top: 16px;
  border-top: 1px solid rgba(201,169,110,0.15);
}

.sc-news-single__back-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, #D4AF37 0%, #C9A96E 100%);
  color: #0D0D0D;
  font-family: 'Noto Serif JP', serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 14px 36px;
  border-radius: 4px;
  text-decoration: none;
  transition: opacity 0.2s ease;
}

.sc-news-single__back-btn:hover {
  opacity: 0.85;
  color: #0D0D0D;
  text-decoration: none;
}

.sc-news-single__back-btn-icon {
  font-size: 10px;
}

.sc-news-single__error {
  text-align: center;
  color: #888;
  padding: 40px 0;
}

/* ============================================================
   ニュースリストページ
   ============================================================ */
.sc-news-list {
  max-width: 860px;
  margin: 0 auto;
  padding: 32px 24px 60px;
}

.sc-news-list__items {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.sc-news-list__item {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: 20px 0;
  border-bottom: 1px solid rgba(201,169,110,0.15);
  text-decoration: none;
  color: #F0EDE5;
  transition: background 0.2s ease;
}

.sc-news-list__item:hover {
  background: rgba(201,169,110,0.05);
  text-decoration: none;
  color: #F0EDE5;
}

.sc-news-list__item-thumb {
  flex-shrink: 0;
  width: 120px;
  height: 80px;
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid rgba(201,169,110,0.15);
  background: #1A1A1A;
}

.sc-news-list__item-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sc-news-list__item-noimg {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #1A1A1A 0%, #2a2a2a 100%);
}

.sc-news-list__item-noimg span {
  font-family: 'Noto Serif JP', serif;
  font-size: 12px;
  font-weight: 700;
  color: rgba(201,169,110,0.5);
  letter-spacing: 0.15em;
}

.sc-news-list__item-body {
  flex: 1;
  min-width: 0;
}

.sc-news-list__item-tag {
  display: inline-block;
  background: linear-gradient(135deg, #D4AF37 0%, #C9A96E 100%);
  color: #0D0D0D;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 2px 8px;
  border-radius: 2px;
  margin-bottom: 6px;
}

.sc-news-list__item-title {
  font-family: 'Noto Serif JP', serif;
  font-size: 15px;
  font-weight: 700;
  color: #F0EDE5;
  line-height: 1.5;
  margin: 0 0 6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sc-news-list__item-date {
  font-size: 12px;
  color: rgba(201,169,110,0.7);
  letter-spacing: 0.06em;
}

.sc-news-list__empty {
  text-align: center;
  color: #888;
  padding: 40px 0;
}

/* レスポンシブ */
@media (max-width: 767px) {
  .sc-news-single {
    padding: 24px 16px 48px;
  }
  .sc-news-single__title {
    font-size: 20px;
  }
  .sc-news-list {
    padding: 20px 16px 48px;
  }
  .sc-news-list__item {
    gap: 12px;
  }
  .sc-news-list__item-thumb {
    width: 90px;
    height: 60px;
  }
  .sc-news-list__item-title {
    font-size: 14px;
    white-space: normal;
  }
}

.sanctuary-schedule-card__body p,
.sgl-card__body p {
    padding-bottom: 0 !important;
    margin-bottom: 2px !important;
}

.sanctuary-schedule-card__name,
.sanctuary-schedule-card__name a,
.sgl-card__name,
.sgl-card__name a {
    font-family: 'Noto Serif JP', 'Yu Mincho', '游明朝', 'Hiragino Mincho ProN', serif !important;
}

.sanctuary-global-header {
  background-image: url("http://sanctuary-h.lily-first.net/wp-content/uploads/2026/03/bg.png") !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  background-color: #0b0b0f !important;
}