/* =========================================================
   FluxCore Pro - Global & Base CSS (SaaS Generic Edition)
========================================================= */
:root {
  --bg-black:#030303; --bg-black-2:#070604; --bg-paper:#f4efe8;
  --text-main:#f6f1e8; --text-sub:rgba(246,241,232,.78); --text-muted:rgba(246,241,232,.52); --text-dark:#151515;
  --gold:#b99a54; --gold-light:#d7c28a; --red:#a3392b; --cyan:#3caeb2;
  --line:rgba(255,255,255,.14); --line-soft:rgba(255,255,255,.07);
  --shadow-dark:0 34px 100px rgba(0,0,0,.62); --shadow-photo:0 30px 90px rgba(0,0,0,.55);
  --font-serif:'Shippori Mincho','Noto Serif JP','Yu Mincho',serif;
  --font-sans:'Noto Sans JP','Yu Gothic','Hiragino Sans',sans-serif;
  --font-en:'Cormorant Garamond','Playfair Display',serif;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  margin:0; width:100%; max-width:100vw; overflow-x:hidden;
  background:var(--bg-black); color:var(--text-main); font-family:var(--font-serif);
  line-height:2; letter-spacing:.08em; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}

/* 汎用的な背景パターン（特定の文字の透かし等は排除） */
body::before{
  content:""; position:fixed; inset:0; z-index:-3; pointer-events:none;
  background: radial-gradient(circle at 22% 12%,rgba(185,154,84,.08),transparent 28%), radial-gradient(circle at 80% 20%,rgba(163,57,43,.08),transparent 25%), linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px), linear-gradient(0deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:auto,auto,90px 90px,90px 90px;
}

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

/* 共通アニメーション */
.fade-up{opacity:0;transform:translateY(42px);transition:opacity 1.05s var(--ease),transform 1.05s var(--ease)}
.fade-up.is-visible{opacity:1;transform:translateY(0)}
.delay-1{transition-delay:.18s}

.section-header{text-align:center;margin-bottom:74px}
.section-header h2{margin:0;color:inherit;font-size:clamp(1.7rem,3vw,2.8rem);letter-spacing:.18em;font-weight:800}
.section-header p{margin:14px 0 0;color:var(--text-muted);font-family:var(--font-en);letter-spacing:.22em}

/* GLOBAL HEADER & MOBILE NAV */
.global-header{position:fixed; top:0; right:0; left:auto; z-index:1000; height:118px; padding:34px 42px 0 0; display:flex; justify-content:flex-end; align-items:flex-start; gap:34px; background:transparent; color:var(--text-main); pointer-events:none;}

/* ロゴ（汎用的な横書き・シンプルスタイルにリセット） */
.header-logo{position:fixed; top:48px; left:48px; z-index:1001; color:#fff; font-size:1.8rem; font-weight:900; letter-spacing:.1em; line-height:1.2; pointer-events:auto; text-shadow:0 8px 26px rgba(0,0,0,.7);}

.desktop-nav{display:flex; flex-direction:row-reverse; align-items:flex-start; gap:22px; pointer-events:auto;}
.desktop-nav a{position:relative; writing-mode:vertical-rl; color:rgba(255,255,255,.78); font-size:.84rem; line-height:1.4; letter-spacing:.16em; font-weight:700; transition:.28s;}
.desktop-nav a:hover,.desktop-nav a.active{color:#fff}
.desktop-nav a::after{content:""; position:absolute; top:0; right:-8px; width:1px; height:0; background:var(--gold); transition:.28s var(--ease);}
.desktop-nav a:hover::after,.desktop-nav a.active::after{height:100%}

.header-btns{display:flex;flex-direction:column;gap:10px;pointer-events:auto;align-items:flex-end}
.btn-header-tel{color:#fff;font-family:var(--font-serif);font-size:1rem;font-weight:800;letter-spacing:.08em;text-align:right;text-shadow:0 6px 18px rgba(0,0,0,.5);}
.btn-header-tel::before{content:"ご予約・お問い合わせ";display:block;color:rgba(255,255,255,.72);font-size:.65rem;font-weight:500;letter-spacing:.1em;line-height:1.2;}
.btn-header-reserve{display:inline-flex; justify-content:center; align-items:center; min-width:112px; height:42px; padding:0 18px; border:1px solid rgba(255,255,255,.28); background:rgba(255,255,255,.08); color:#fff; font-size:.72rem; font-weight:800; letter-spacing:.16em; cursor:pointer; backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); transition:.3s;}
.btn-header-reserve:hover{background:#fff;color:#000}
.menu-trigger{display:none;position:fixed;top:18px;right:18px;z-index:1100;width:44px;height:44px;border:1px solid var(--line);background:rgba(0,0,0,.7);color:#fff;cursor:pointer;font-size:24px}

.mobile-nav-overlay{position:fixed;inset:0;z-index:1050;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:18px;background:rgba(0,0,0,.97);transform:translateX(100%);opacity:0;pointer-events:none;transition:.45s var(--ease)}
.mobile-nav-overlay.active{transform:translateX(0);opacity:1;pointer-events:auto}
.mobile-nav-overlay a{color:#fff;font-size:1.35rem;letter-spacing:.18em;font-weight:800}

/* GLOBAL FOOTER (レガシー互換用ベース) */
.footer{position:relative;overflow:hidden;padding:120px 20px 78px;background:#050505;color:#fff}
.info-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:.82fr 1.18fr;gap:70px;align-items:start;position:relative;z-index:3}
.shop-info h2{margin:0 0 34px;color:#fff;font-size:clamp(1.8rem,3.6vw,3.4rem);font-weight:800;letter-spacing:.18em;border-bottom:1px solid rgba(255,255,255,.32);display:inline-block;padding-bottom:14px}
.shop-info table{width:100%;border-collapse:collapse;margin-top:20px;font-size:.9rem}
.shop-info th,.shop-info td{padding:15px 0;border-bottom:1px solid rgba(255,255,255,.14);text-align:left;vertical-align:top}
.shop-info th{width:110px;color:rgba(255,255,255,.58);font-weight:600}
.shop-info td{color:rgba(255,255,255,.84);line-height:1.9}
.gmap-wrap{height:420px;overflow:hidden;border:1px solid rgba(255,255,255,.14);box-shadow:0 22px 66px rgba(0,0,0,.34)}
.gmap-wrap iframe{width:100%;height:100%;border:none;filter:grayscale(.42) brightness(.72) contrast(1.08)}

/* GLOBAL RESPONSIVE */
@media (max-width:1024px){
  .info-grid{grid-template-columns:1fr}
}
@media (max-width:768px){
  .global-header{height:64px;padding:0 20px;left:0;right:0;background:rgba(0,0,0,.72);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);justify-content:space-between;align-items:center}
  .header-logo{position:relative;top:auto;left:auto;writing-mode:horizontal-tb;font-size:1.1rem}
  .desktop-nav,.header-btns{display:none}
  .menu-trigger{display:block}
  .footer{padding:90px 20px}
  .info-grid{grid-template-columns:1fr;gap:40px}
  .gmap-wrap{height:300px}
}