/*
Theme Name: SPACE.OS Rental Space
Theme URI: https://example.com/
Author: SPACE.OS
Author URI: https://example.com/
Description: レンタルスペース・貸し会議室向けモダンWordPressテーマ。新大阪・心斎橋・なんばのスペース紹介に最適化。リアルタイム空き表示・AIコンシェルジュ導線・インタラクティブカレンダーを標準搭載。
Version: 3.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: spaceos-rental
*/

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,500;0,9..40,700;1,9..40,300&family=Noto+Sans+JP:wght@300;500;700;900&family=DM+Mono:wght@400;500&display=swap');

/* ═══════════════ TOKENS ═══════════════ */
:root {
  --ink:      #0e0f11;
  --ink-2:    #444750;
  --ink-3:    #9ea3ad;
  --bg:       #f7f5f0;
  --bg-2:     #eeeae2;
  --white:    #ffffff;
  --accent:   #2563ff;
  --accent-2: #1246cc;
  --green:    #00b87a;
  --amber:    #f5a623;
  --card-r:   20px;
  --card-r-lg:28px;
  --max:      1200px;
  --font:     'DM Sans','Noto Sans JP',system-ui,sans-serif;
  --mono:     'DM Mono','Courier New',monospace;
  --sh-sm:    0 1px 4px rgba(14,15,17,.05),0 4px 16px rgba(14,15,17,.04);
  --sh-md:    0 2px 12px rgba(14,15,17,.06),0 16px 40px rgba(14,15,17,.06);
  --sh-lg:    0 4px 24px rgba(14,15,17,.08),0 32px 64px rgba(14,15,17,.08);
  --article-max:820px;
  --article-sidebar:280px;
}

/* ═══════════════ RESET ═══════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}
body{font-family:var(--font);background:var(--bg);color:var(--ink);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}
button{font-family:var(--font);cursor:pointer}
.container{width:min(calc(100% - 40px),var(--max));margin:0 auto}
.skip-link{position:absolute;top:-100%;left:8px;z-index:9999;padding:10px 18px;background:var(--ink);color:var(--bg);border-radius:0 0 var(--card-r) var(--card-r);font-weight:700;transition:top .2s}
.skip-link:focus{top:0}

/* ═══════════════ HEADER ═══════════════ */
.site-header{position:sticky;top:0;z-index:100;background:rgba(247,245,240,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(14,15,17,.08);transition:box-shadow .2s}
.site-header.is-scrolled{box-shadow:0 4px 24px rgba(14,15,17,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:38px;height:38px;border-radius:10px;background:var(--ink);display:grid;place-items:center;color:var(--bg);font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:-.02em;flex-shrink:0}
.brand-text strong{font-size:1.05rem;font-weight:700;letter-spacing:-.03em;display:block}
.brand-text small{font-size:.68rem;color:var(--ink-3);letter-spacing:.12em;display:block;margin-top:1px}
.desktop-nav{display:flex;align-items:center;gap:2px}
.desktop-nav a{padding:8px 14px;border-radius:999px;font-size:.88rem;font-weight:500;color:var(--ink-2);transition:background .18s,color .18s}
.desktop-nav a:hover{background:rgba(14,15,17,.06);color:var(--ink)}
.desktop-nav .nav-column{position:relative}
.desktop-nav .nav-column::after{content:'NEW';position:absolute;top:-10px;right:-4px;background:var(--accent);color:#fff;font-size:.55rem;font-weight:800;letter-spacing:.06em;padding:2px 6px;border-radius:999px}
.header-actions{display:flex;align-items:center;gap:10px}
.btn-ghost{padding:9px 18px;border-radius:999px;font-size:.85rem;font-weight:600;border:1.5px solid rgba(14,15,17,.18);background:none;color:var(--ink);transition:border-color .18s,background .18s}
.btn-ghost:hover{border-color:var(--ink);background:rgba(14,15,17,.04)}
.header-cta{padding:10px 22px;border-radius:999px;font-size:.88rem;font-weight:700;background:var(--ink);color:var(--bg);display:inline-flex;align-items:center;gap:8px;transition:background .18s,transform .15s;border:none}
.header-cta:hover{background:#1a1c20;transform:translateY(-1px)}
.mobile-toggle{display:none;border:none;background:none;font-size:1.4rem;color:var(--ink);padding:4px}
.mobile-nav{display:none;flex-direction:column;gap:6px;padding:12px 20px 18px;border-top:1px solid rgba(14,15,17,.06)}
.mobile-nav.open{display:flex}
.mobile-nav a{display:block;padding:12px 16px;border-radius:14px;font-size:.95rem;font-weight:600;background:rgba(255,255,255,.7);border:1px solid rgba(14,15,17,.07);transition:background .18s}
.mobile-nav a:hover{background:var(--white)}
.mobile-nav .mobile-cta{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 16px;border-radius:14px;font-weight:700;background:var(--ink);color:var(--bg);margin-top:4px}

/* ═══════════════ HERO ═══════════════ */
.hero{padding:80px 0 60px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;right:-200px;top:-100px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,255,.07) 0%,transparent 65%);pointer-events:none}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;background:rgba(37,99,255,.08);border:1px solid rgba(37,99,255,.18);font-size:.78rem;font-weight:700;color:var(--accent);margin-bottom:24px}
.hero-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}
.hero h1{font-size:clamp(2.8rem,6vw,5.6rem);font-weight:700;line-height:1.06;letter-spacing:-.05em;margin-bottom:28px}
.hero h1 em{font-style:normal;background:linear-gradient(135deg,var(--accent),#5b8bff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-lead{font-size:1.1rem;color:var(--ink-2);max-width:560px;line-height:1.8;margin-bottom:36px;font-weight:300}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:52px}
.btn-hero-primary{display:inline-flex;align-items:center;gap:10px;padding:15px 30px;border-radius:999px;font-size:.98rem;font-weight:700;background:var(--ink);color:var(--bg);border:none;transition:background .2s,transform .15s}
.btn-hero-primary svg{transition:transform .2s}
.btn-hero-primary:hover{background:#1a1c20;transform:translateY(-2px)}
.btn-hero-primary:hover svg{transform:translateX(4px)}
.btn-hero-secondary{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;border-radius:999px;font-size:.95rem;font-weight:600;border:1.5px solid rgba(14,15,17,.18);color:var(--ink-2);background:none;transition:border-color .2s,color .2s}
.btn-hero-secondary:hover{border-color:var(--ink);color:var(--ink)}
.hero-stats{display:flex;flex-wrap:wrap;gap:36px}
.hero-stat strong{display:block;font-size:2.2rem;font-weight:700;letter-spacing:-.04em;line-height:1}
.hero-stat span{display:block;font-size:.8rem;color:var(--ink-3);margin-top:6px}

/* ═══════════════ AVAIL BAR ═══════════════ */

/* ═══════════════ SEARCH ═══════════════ */
.search-section{padding:52px 0}
.search-card{background:var(--white);border-radius:var(--card-r-lg);padding:32px 36px;border:1px solid rgba(14,15,17,.06);box-shadow:var(--sh-md)}
.search-card-title{font-size:1.3rem;font-weight:700;margin-bottom:22px;letter-spacing:-.03em}
.search-form{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:14px;align-items:end}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:.75rem;font-weight:700;color:var(--ink-3);letter-spacing:.1em}
.select-wrap{position:relative}
.select-wrap::after{content:'';position:absolute;right:14px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid var(--ink-3);pointer-events:none}
.form-control{height:48px;border-radius:12px;border:1.5px solid rgba(14,15,17,.12);padding:0 16px;font-size:.92rem;font-family:var(--font);background:var(--bg);color:var(--ink);outline:none;transition:border-color .18s;appearance:none;width:100%}
.form-control:focus{border-color:var(--accent)}
.search-btn{height:48px;padding:0 26px;border-radius:12px;font-size:.92rem;font-weight:700;background:var(--ink);color:var(--bg);border:none;display:flex;align-items:center;gap:9px;white-space:nowrap;transition:background .18s,transform .15s}
.search-btn:hover{background:#1a1c20;transform:translateY(-1px)}

/* ═══════════════ SECTIONS ═══════════════ */
.section{padding:80px 0;position:relative;z-index:1}
.section.alt{background:rgba(255,255,255,.6);border-top:1px solid rgba(14,15,17,.05);border-bottom:1px solid rgba(14,15,17,.05)}
.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:36px;gap:20px}
.section-label,.eyebrow{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;color:var(--ink-3);margin-bottom:8px;display:block}
.section-title{font-size:clamp(1.9rem,3.5vw,2.9rem);font-weight:700;letter-spacing:-.04em;line-height:1.12}
.section-heading{max-width:760px;margin-bottom:36px}
.section-heading.center{text-align:center;margin:0 auto 36px}
.section-heading h2{font-size:clamp(1.9rem,3.5vw,2.9rem);font-weight:700;letter-spacing:-.04em;line-height:1.12}
.section-heading p,.heading-lead{color:var(--ink-2);margin-top:14px;font-size:.98rem;line-height:1.75}
.split-heading{max-width:none;display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:end;margin-bottom:36px}
.section-link{display:inline-flex;align-items:center;gap:8px;font-size:.88rem;font-weight:700;color:var(--ink-2);border-bottom:1.5px solid rgba(14,15,17,.15);padding-bottom:2px;transition:color .18s,border-color .18s;white-space:nowrap}
.section-link:hover{color:var(--ink);border-color:var(--ink)}

/* ═══════════════ BUTTONS ═══════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 24px;border-radius:999px;font-size:.9rem;font-weight:700;transition:background .18s,transform .15s,border-color .18s;cursor:pointer;border:none}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:#1a1c20;transform:translateY(-1px)}
.btn-secondary{background:rgba(255,255,255,.8);color:var(--ink);border:1.5px solid rgba(14,15,17,.14)}
.btn-secondary:hover{background:var(--white);border-color:rgba(14,15,17,.25)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-2);transform:translateY(-1px)}
.btn-compact{padding:10px 18px;font-size:.83rem}
.text-link{display:inline-flex;align-items:center;gap:6px;font-weight:700;color:var(--accent);transition:gap .18s}
.text-link::after{content:'→'}
.text-link:hover{gap:10px}

/* ═══════════════ ROOMS ═══════════════ */
.room-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.room-card{overflow:hidden;border-radius:var(--card-r);background:var(--white);border:1px solid rgba(14,15,17,.06);box-shadow:var(--sh-sm);transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s}
.room-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
/* 画像リンク化対応: display:block と cursor:pointer を追加 */
.room-visual{height:280px;position:relative;overflow:hidden;background:linear-gradient(135deg,#d4e3ff,#b8d0ff);display:block;cursor:pointer}
.room-visual img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.room-card:hover .room-visual img{transform:scale(1.04)}
.room-visual[style]{background-size:cover!important;background-position:center!important}
.room-badge,.room-tags{position:absolute;top:16px;left:16px;display:flex;gap:8px;flex-wrap:wrap}
.tag,.pill,.room-badge{display:inline-flex;align-items:center;padding:5px 12px;border-radius:999px;font-size:.72rem;font-weight:700}
.tag-popular,.tag-new{background:rgba(0,184,122,.92);color:#fff}
.tag-new{background:rgba(37,99,255,.92)}
.tag-private{background:rgba(14,15,17,.78);color:rgba(247,245,240,.92)}
.tag-party{background:rgba(236,72,153,.92);color:#fff}
.tag-large{background:rgba(245,166,35,.92);color:#fff}
.pill{background:rgba(37,99,255,.1);color:var(--accent);border:1px solid rgba(37,99,255,.18)}
.room-body{padding:24px}
.room-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}
.room-header-row h3{font-size:1.28rem;font-weight:700;letter-spacing:-.03em;line-height:1.3}
.room-copy{font-size:.88rem;color:var(--ink-2);line-height:1.7;margin-bottom:16px}
.room-meta{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.room-meta li{padding:6px 12px;border-radius:8px;background:var(--bg);border:1px solid rgba(14,15,17,.08);font-size:.8rem;font-weight:600;color:var(--ink-2)}
.room-footer{display:flex;align-items:center;justify-content:space-between}
.room-price{font-size:.82rem;color:var(--ink-3)}
.room-price strong{font-size:1.4rem;color:var(--ink);font-weight:700;letter-spacing:-.03em}
.room-price strong::after{content:'/h';font-size:.68rem;font-weight:500;color:var(--ink-3);margin-left:2px}
.btn-room{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:999px;font-size:.83rem;font-weight:700;background:var(--ink);color:var(--bg);border:none;transition:background .18s}
.btn-room:hover{background:#1a1c20}

/* ═══════════════ CALENDAR ═══════════════ */
.cal-card{background:var(--white);border-radius:var(--card-r-lg);border:1px solid rgba(14,15,17,.06);overflow:hidden;box-shadow:var(--sh-md)}
.cal-header{padding:26px 32px 22px;border-bottom:1px solid rgba(14,15,17,.06);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.cal-header-left{display:flex;align-items:center;gap:14px}
.cal-nav-btn{width:34px;height:34px;border-radius:10px;border:1.5px solid rgba(14,15,17,.12);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--ink-2);transition:background .18s,border-color .18s}
.cal-nav-btn:hover{background:var(--bg);border-color:rgba(14,15,17,.2)}
.cal-month{font-size:1.2rem;font-weight:700;letter-spacing:-.03em}
.cal-legend{display:flex;gap:16px;flex-wrap:wrap}
.cal-legend-item{display:flex;align-items:center;gap:7px;font-size:.78rem;color:var(--ink-3);font-weight:500}
.legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}
.ld-avail{background:var(--green)}
.ld-partial{background:var(--amber)}
.ld-full{background:rgba(14,15,17,.15)}
.cal-grid-header{display:grid;grid-template-columns:repeat(7,1fr);padding:0 32px;gap:3px}
.cal-day-label{padding:12px 6px;text-align:center;font-size:.7rem;font-weight:700;letter-spacing:.1em;color:var(--ink-3)}
.cal-day-label.sun{color:#e53e3e}
.cal-day-label.sat{color:var(--accent)}
.cal-body{padding:0 32px 26px}
.cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:3px}
.cal-day{min-height:76px;border-radius:12px;padding:9px 10px;border:1.5px solid transparent;cursor:pointer;transition:border-color .18s,background .18s}
.cal-day:hover{border-color:rgba(14,15,17,.1);background:rgba(14,15,17,.02)}
.cal-day.today{border-color:var(--accent);background:rgba(37,99,255,.04)}
.cal-day.other-month{opacity:.3;pointer-events:none}
.cal-day-num{font-size:.78rem;font-weight:700;margin-bottom:7px}
.today .cal-day-num{color:var(--accent)}
.cal-room-dots{display:flex;flex-direction:column;gap:3px}
.room-dot{display:flex;align-items:center;gap:4px;font-size:.64rem;font-weight:600;padding:2px 5px;border-radius:4px}
.rd-avail{background:rgba(0,184,122,.1);color:#008858}
.rd-partial{background:rgba(245,166,35,.12);color:#b77c0a}
.rd-full{background:rgba(14,15,17,.06);color:var(--ink-3)}
.cal-footer{padding:18px 32px;background:var(--bg);border-top:1px solid rgba(14,15,17,.06);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.cal-footer-note{font-size:.82rem;color:var(--ink-3)}

/* ═══════════════ FEATURES ═══════════════ */
.feature-grid,.premium-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.feature-card{padding:26px;border-radius:var(--card-r);border:1px solid rgba(14,15,17,.07);background:var(--white);transition:transform .22s,box-shadow .22s}
.feature-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.feature-icon{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;margin-bottom:16px;font-size:1.3rem}
.fi-blue{background:rgba(37,99,255,.1)}
.fi-green{background:rgba(0,184,122,.1)}
.fi-amber{background:rgba(245,166,35,.1)}
.fi-purple{background:rgba(124,58,237,.1)}
.fi-pink{background:rgba(236,72,153,.1)}
.fi-cyan{background:rgba(6,182,212,.1)}
.feature-card h3{font-size:1.05rem;font-weight:700;letter-spacing:-.02em;margin-bottom:9px}
.feature-card p{font-size:.87rem;color:var(--ink-2);line-height:1.7}
.icon-box{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;background:rgba(37,99,255,.1);font-weight:800;font-family:var(--mono);font-size:.82rem;color:var(--accent);margin-bottom:16px}

/* ═══════════════ COMPARISON TABLE ═══════════════ */
/* 比較テーブル: max-width:100%でコンテナ外にはみ出さないようにする */
.table-wrap{overflow-x:auto;border-radius:var(--card-r);background:var(--white);border:1px solid rgba(14,15,17,.06);box-shadow:var(--sh-sm);max-width:100%}
.comparison-table{width:100%;border-collapse:collapse;min-width:720px}
.comparison-table th,.comparison-table td{padding:16px 20px;text-align:left;border-bottom:1px solid rgba(14,15,17,.06);font-size:.9rem}
.comparison-table th{font-size:.7rem;font-weight:700;letter-spacing:.1em;color:var(--ink-3);background:var(--bg);padding-top:18px;padding-bottom:18px}
.comparison-table tbody tr:hover{background:rgba(14,15,17,.015)}
.comparison-table tbody tr:last-child td{border-bottom:none}
.comparison-table td:first-child{font-weight:700}
.comparison-table a{color:var(--accent);font-weight:700}

/* ═══════════════ AI CARD ═══════════════ */
.ai-section-card{background:var(--ink);border-radius:var(--card-r-lg);padding:52px 56px;display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center;overflow:hidden;position:relative}
.ai-section-card::before{content:'';position:absolute;right:-100px;bottom:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,255,.2) 0%,transparent 60%);pointer-events:none}
.ai-badge{display:inline-flex;align-items:center;gap:8px;padding:5px 14px;border-radius:999px;background:rgba(247,245,240,.1);border:1px solid rgba(247,245,240,.12);font-size:.7rem;font-weight:700;color:rgba(247,245,240,.65);letter-spacing:.1em;margin-bottom:18px}
.ai-copy h2{font-size:clamp(1.9rem,3.5vw,3rem);font-weight:700;color:var(--bg);letter-spacing:-.04em;line-height:1.1;margin-bottom:14px}
.ai-copy p{font-size:.92rem;color:rgba(247,245,240,.6);line-height:1.8;margin-bottom:26px}
.btn-ai{display:inline-flex;align-items:center;gap:10px;padding:13px 26px;border-radius:999px;font-size:.88rem;font-weight:700;background:var(--bg);color:var(--ink);border:none;transition:background .18s,transform .15s}
.btn-ai:hover{background:var(--white);transform:translateY(-2px)}
.ai-chat{background:rgba(247,245,240,.06);border-radius:var(--card-r);padding:22px;border:1px solid rgba(247,245,240,.1)}
.chat-msg{display:flex;gap:10px;margin-bottom:14px}
.chat-msg:last-of-type{margin-bottom:0}
.chat-avatar{width:30px;height:30px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700}
.av-ai{background:var(--accent);color:#fff}
.av-user{background:rgba(247,245,240,.15);color:rgba(247,245,240,.8)}
.chat-bubble{padding:11px 15px;border-radius:13px;font-size:.83rem;line-height:1.65;max-width:290px}
.bubble-ai{background:rgba(247,245,240,.1);color:rgba(247,245,240,.9)}
.bubble-user{background:var(--accent);color:#fff;margin-left:auto}
.chat-msg.user{flex-direction:row-reverse}
.chat-input-bar{display:flex;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid rgba(247,245,240,.08)}
.chat-input{flex:1;background:rgba(247,245,240,.08);border:1px solid rgba(247,245,240,.12);border-radius:10px;padding:9px 13px;font-size:.8rem;color:rgba(247,245,240,.8);font-family:var(--font);outline:none}
.chat-input::placeholder{color:rgba(247,245,240,.32)}
.chat-send{width:34px;height:34px;border-radius:10px;background:var(--accent);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:background .18s;flex-shrink:0;font-size:.9rem}
.chat-send:hover{background:var(--accent-2)}

/* ═══════════════ STATS ═══════════════ */
.stats-band{padding:8px 0 20px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stat-card{padding:22px 20px;border-radius:var(--card-r);background:var(--white);border:1px solid rgba(14,15,17,.06);box-shadow:var(--sh-sm)}
.stat-label{display:block;font-family:var(--mono);color:var(--ink-3);letter-spacing:.12em;font-size:.68rem;font-weight:700;margin-bottom:8px}
.stat-card strong{display:block;font-size:1.1rem;font-weight:700;margin-bottom:4px}
.stat-card p{color:var(--ink-2);font-size:.88rem;margin:0}

/* ═══════════════ ACCESS ═══════════════ */
.access-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:start}
.access-info-card{background:var(--white);border-radius:var(--card-r-lg);padding:36px;border:1px solid rgba(14,15,17,.06)}
.access-info-card h2{font-size:clamp(1.8rem,3vw,2.5rem);font-weight:700;letter-spacing:-.04em;margin-bottom:22px;line-height:1.2}
.access-list{list-style:none;display:grid;gap:12px;margin-bottom:26px}
.access-list li{display:flex;align-items:flex-start;gap:14px;padding:15px;border-radius:14px;background:var(--bg);font-size:.88rem;line-height:1.65}
.access-icon{width:32px;height:32px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;font-size:1rem}
.bullet-list{list-style:none;display:grid;gap:10px;margin-bottom:22px}
.bullet-list li{padding-left:18px;position:relative;color:var(--ink-2);font-size:.9rem}
.bullet-list li::before{content:'';position:absolute;left:0;top:.6em;width:6px;height:6px;border-radius:50%;background:var(--accent)}
.access-card{border-radius:var(--card-r-lg);overflow:hidden;box-shadow:var(--sh-md);border:1px solid rgba(14,15,17,.06)}
.map-visual{position:relative;height:340px;overflow:hidden;background:var(--bg-2)}
.map-visual.has-embed{background:#e0ddd7}
.map-embed,.map-embed iframe{width:100%;height:100%;display:block;border:0}
.map-placeholder-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--ink-3);font-size:.82rem}
.map-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(14,15,17,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(14,15,17,.08) 1px,transparent 1px);background-size:44px 44px}
.map-pin{position:absolute;width:30px;height:30px;border-radius:999px 999px 999px 0;transform:rotate(-45deg);background:var(--accent);left:50%;top:50%;margin-left:-15px;margin-top:-15px;z-index:1;box-shadow:0 8px 20px rgba(37,99,255,.3)}
.map-pin::after{content:'';position:absolute;inset:8px;border-radius:50%;background:white}
.address-box{padding:22px 24px;background:var(--white);border-top:1px solid rgba(14,15,17,.06)}
.address-box strong{font-size:1.05rem;font-weight:700;letter-spacing:-.02em;display:block;margin-bottom:8px}
.address-box p{color:var(--ink-2);font-size:.87rem;line-height:1.7;margin-bottom:14px}
.address-box small{color:var(--ink-3);font-size:.82rem}
.map-actions{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}
.btn-map{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:999px;font-size:.82rem;font-weight:700;border:1.5px solid rgba(14,15,17,.14);color:var(--ink);background:none;transition:border-color .18s,background .18s}
.btn-map:hover{border-color:var(--ink);background:rgba(14,15,17,.03)}

/* ═══════════════ FAQ ═══════════════ */
.faq-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.faq-list{display:grid;gap:8px}
details.faq-item{border-radius:16px;background:var(--white);border:1.5px solid rgba(14,15,17,.07);overflow:hidden;transition:border-color .2s}
details.faq-item[open]{border-color:rgba(14,15,17,.14)}
.faq-item summary{padding:19px 22px;font-weight:700;font-size:.93rem;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:14px;transition:background .18s}
.faq-item summary:hover{background:rgba(14,15,17,.02)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-toggle{width:26px;height:26px;border-radius:8px;flex-shrink:0;display:grid;place-items:center;background:var(--bg);font-size:1.2rem;color:var(--ink-3);font-weight:300;transition:transform .2s,background .2s}
details[open] .faq-toggle{transform:rotate(45deg);background:rgba(14,15,17,.08)}
.faq-answer{padding:16px 22px 19px;font-size:.88rem;color:var(--ink-2);line-height:1.8;border-top:1px solid rgba(14,15,17,.06)}
.faq-cta-card{background:var(--white);border-radius:var(--card-r-lg);padding:34px;border:1px solid rgba(14,15,17,.06);position:sticky;top:90px}
.faq-cta-card h3{font-size:1.55rem;font-weight:700;letter-spacing:-.04em;margin-bottom:12px;line-height:1.2}
.faq-cta-card>p{font-size:.88rem;color:var(--ink-2);line-height:1.7;margin-bottom:22px}
.cta-actions{display:grid;gap:10px}
.btn-cta-primary{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 22px;border-radius:14px;font-size:.92rem;font-weight:700;background:var(--ink);color:var(--bg);border:none;transition:background .18s}
.btn-cta-primary:hover{background:#1a1c20}
.btn-cta-secondary{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 22px;border-radius:14px;font-size:.88rem;font-weight:600;border:1.5px solid rgba(14,15,17,.14);color:var(--ink-2);background:none;transition:border-color .18s,color .18s}
.btn-cta-secondary:hover{border-color:var(--ink);color:var(--ink)}
.contact-info{margin-top:22px;padding:18px;border-radius:14px;background:var(--bg)}
.contact-info p{font-size:.78rem;color:var(--ink-3);margin-bottom:4px}
.contact-info strong{font-size:1.45rem;font-weight:700;letter-spacing:-.03em;display:block}
.contact-hours{font-size:.76rem;color:var(--ink-3);margin-top:4px}

/* ═══════════════ RESERVE ═══════════════ */
.reserve-section{padding-top:0}
.reserve-box{border-radius:var(--card-r-lg);overflow:hidden;position:relative;background:var(--ink);padding:60px 52px;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.reserve-box::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(37,99,255,.18) 0%,transparent 45%),radial-gradient(circle at 80% 20%,rgba(0,184,122,.12) 0%,transparent 40%);pointer-events:none}
.reserve-copy{position:relative;z-index:1}
.reserve-copy .eyebrow{color:rgba(247,245,240,.38)}
.reserve-copy h2{font-size:clamp(2.2rem,4vw,3.6rem);font-weight:700;color:var(--bg);letter-spacing:-.05em;line-height:1.06;margin-bottom:14px}
.reserve-copy p{color:rgba(247,245,240,.6);font-size:1rem;font-weight:300;max-width:560px}
.reserve-actions{display:flex;flex-wrap:wrap;gap:12px;position:relative;z-index:1;flex-shrink:0}
.btn-reserve-primary{display:inline-flex;align-items:center;gap:10px;padding:15px 30px;border-radius:999px;font-size:.95rem;font-weight:700;background:var(--bg);color:var(--ink);border:none;transition:background .18s,transform .15s}
.btn-reserve-primary:hover{background:var(--white);transform:translateY(-2px)}
.btn-reserve-secondary{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;border-radius:999px;font-size:.9rem;font-weight:600;border:1.5px solid rgba(247,245,240,.18);color:rgba(247,245,240,.8);background:none;transition:border-color .18s,color .18s}
.btn-reserve-secondary:hover{border-color:rgba(247,245,240,.4);color:var(--bg)}

/* ═══════════════ PARTY / SECONDARY ═══════════════ */
.secondary-destination-box{padding:34px 36px;border-radius:var(--card-r-lg);background:var(--white);border:1px solid rgba(14,15,17,.06);box-shadow:var(--sh-sm);display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
.secondary-destination-actions{display:flex;justify-content:flex-end}

/* ═══════════════ BLOG ═══════════════ */
.blog-footer-strip{padding-top:12px;padding-bottom:36px}
.blog-footer-box{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;padding:22px 26px;border-radius:var(--card-r-lg);background:var(--white);border:1px solid rgba(14,15,17,.06);box-shadow:var(--sh-sm)}
.blog-footer-copy{flex:1;min-width:0}
.blog-footer-actions{flex-shrink:0}
.blog-footer-copy h2{margin:8px 0 6px;font-size:clamp(1.2rem,2vw,1.7rem);font-weight:700;letter-spacing:-.03em}
.blog-footer-lead{color:var(--ink-2);font-size:.92rem}
.blog-footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:12px}
.blog-footer-item a{display:block;padding:16px 18px;border-radius:16px;background:var(--white);border:1px solid rgba(14,15,17,.07);box-shadow:var(--sh-sm);transition:transform .18s,box-shadow .18s}
.blog-footer-item a:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.blog-footer-item-date{display:block;margin-bottom:6px;color:var(--accent);font-size:.76rem;font-weight:700;letter-spacing:.08em}
.blog-footer-item strong{display:block;color:var(--ink);font-size:.92rem;line-height:1.6}
.blog-footer-empty{margin-top:12px;padding:16px 18px;border-radius:16px;background:var(--white);border:1px solid rgba(14,15,17,.07);color:var(--ink-3)}
.blog-highlight-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:24px}
.blog-panel{background:var(--white);border:1px solid rgba(14,15,17,.07);border-radius:var(--card-r-lg);box-shadow:var(--sh-md);padding:34px;position:relative;overflow:hidden}
.blog-panel::before{content:'';position:absolute;inset:auto -10% -40% auto;width:320px;height:320px;background:radial-gradient(circle,rgba(37,99,255,.1),transparent 60%);pointer-events:none}
.blog-panel h2{margin:10px 0 12px;font-size:clamp(1.8rem,3.5vw,2.7rem);line-height:1.15;letter-spacing:-.04em;font-weight:700}
.blog-panel p{color:var(--ink-2)}
.blog-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.blog-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:24px}
.blog-stat{padding:16px;border-radius:var(--card-r);background:var(--bg);border:1px solid rgba(14,15,17,.06)}
.blog-stat strong{display:block;font-size:1rem;font-weight:700}
.blog-stat span{display:block;color:var(--ink-3);font-size:.85rem;margin-top:5px}
.posts-stack{display:grid;gap:16px}
.post-card-large,.post-card-mini,.archive-card{display:block;background:var(--white);border:1px solid rgba(14,15,17,.07);border-radius:var(--card-r);overflow:hidden;box-shadow:var(--sh-sm);transition:transform .18s,box-shadow .18s}
.post-card-large:hover,.post-card-mini:hover,.archive-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.post-card-media,.archive-card-media{background:var(--bg-2);overflow:hidden}
.post-card-media{aspect-ratio:16/9}
.archive-card-media{aspect-ratio:16/10}
.post-card-media img,.archive-card-media img{width:100%;height:100%;object-fit:cover}
.post-card-content,.archive-card-content{padding:22px}
.post-card-content h3{margin:0 0 9px;font-size:1.28rem;line-height:1.38;font-weight:700;letter-spacing:-.02em}
.post-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;color:var(--ink-3);font-size:.82rem;margin-bottom:10px}
.post-meta .category-pill,.category-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:rgba(37,99,255,.08);color:var(--accent);font-weight:700;font-size:.72rem;letter-spacing:.04em}
.posts-mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.post-card-mini .post-card-content{padding:18px}
.post-card-mini h3{font-size:1rem;line-height:1.5;margin:0 0 7px}
.column-hero,.archive-hero{padding:30px 0 16px}
.column-hero-box,.archive-hero-box{background:var(--white);border:1px solid rgba(14,15,17,.07);box-shadow:var(--sh-md);border-radius:var(--card-r-lg);padding:40px}
.column-hero-box h1,.archive-hero-box h1{font-size:clamp(2rem,3.5vw,2.9rem);font-weight:700;letter-spacing:-.04em;margin:8px 0 10px}
.category-row,.archive-categories{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.category-chip{background:var(--white);border:1px solid rgba(14,15,17,.1);color:var(--ink-2)}
.category-chip.active,.category-chip:hover{background:var(--ink);color:var(--bg);border-color:transparent}
.column-layout,.archive-layout{display:grid;grid-template-columns:minmax(0,1fr) var(--article-sidebar);gap:30px;align-items:start}
.archive-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.archive-card h3{font-size:1.12rem;line-height:1.45;font-weight:700;letter-spacing:-.02em;margin:0 0 8px}
.archive-card .readmore{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-weight:700;color:var(--accent)}
.column-sidebar,.article-sidebar{position:sticky;top:90px}
.sidebar-card{background:var(--white);border:1px solid rgba(14,15,17,.07);border-radius:var(--card-r);padding:22px;box-shadow:var(--sh-sm);margin-bottom:16px}
.sidebar-card h3{margin:0 0 13px;font-size:1rem;font-weight:700}
.sidebar-list{display:grid;gap:9px}
.sidebar-list a{color:var(--ink-2);font-weight:500;font-size:.9rem;transition:color .18s}
.sidebar-list a:hover{color:var(--ink)}
.article-wrap{padding:36px 0 68px}
.article-layout{display:grid;grid-template-columns:minmax(0,1fr) var(--article-sidebar);gap:30px;align-items:start}
.article-main{min-width:0}
.article-shell{background:var(--white);border:1px solid rgba(14,15,17,.07);box-shadow:var(--sh-md);border-radius:var(--card-r-lg);overflow:hidden}
.article-hero-media{aspect-ratio:16/8;background:var(--bg-2);overflow:hidden}
.article-hero-media img{width:100%;height:100%;object-fit:cover}
.article-head{padding:36px 40px 20px;border-bottom:1px solid rgba(14,15,17,.07)}
.article-head h1{margin:10px 0 0;font-size:clamp(1.9rem,3.5vw,2.8rem);line-height:1.2;font-weight:700;letter-spacing:-.04em}
.article-excerpt{margin:16px 0 0;color:var(--ink-2);font-size:1rem}
.article-content{padding:8px 40px 42px;max-width:var(--article-max)}
.article-content p{margin:1.1em 0;color:#2e2c29;line-height:2;font-size:1rem}
.article-content a{text-decoration:underline;text-underline-offset:3px;color:var(--accent)}
.article-content h2{font-size:1.65rem;line-height:1.35;margin:2.2em 0 .9em;padding:0 0 .5em;position:relative;font-weight:700}
.article-content h2::after{content:'';position:absolute;left:0;bottom:0;width:60px;height:3px;border-radius:999px;background:var(--accent)}
.article-content h3{font-size:1.22rem;line-height:1.45;margin:1.9em 0 .75em;padding-left:14px;position:relative;font-weight:700}
.article-content h3::before{content:'';position:absolute;left:0;top:.35em;width:4px;height:1em;border-radius:999px;background:var(--accent)}
.article-content h4{font-size:1.04rem;margin:1.5em 0 .7em;padding:10px 14px;border-radius:12px;background:rgba(37,99,255,.06);font-weight:700}
.article-content ul,.article-content ol{padding-left:1.3em;margin:.95em 0 1.1em}
.article-content li{margin:.4em 0;line-height:1.9}
.article-content blockquote{margin:1.6em 0;padding:20px 22px;border-left:3px solid var(--accent);background:rgba(255,255,255,.95);border-radius:0 16px 16px 0;box-shadow:var(--sh-sm);color:#302925}
.article-content table{width:100%;border-collapse:collapse;overflow:hidden;border-radius:var(--card-r);box-shadow:var(--sh-sm);margin:1.6em 0}
.article-content th,.article-content td{padding:14px 16px;border:1px solid rgba(14,15,17,.07);text-align:left;background:var(--white)}
.article-content th{background:var(--bg);font-weight:700}
.article-content img{border-radius:var(--card-r);box-shadow:var(--sh-sm)}
.article-inline-toc{margin:0 0 26px;border:1px solid rgba(37,99,255,.15);background:rgba(37,99,255,.04);border-radius:var(--card-r);padding:22px}
.article-inline-toc h3{margin:0 0 10px;font-size:1.05rem;font-weight:700}
.article-inline-toc ol{margin:0;padding-left:1.1em;display:grid;gap:9px}
.article-inline-toc li.level-3{margin-left:.8em;font-size:.94em}
.article-toc{padding:22px}
.article-toc ol{margin:9px 0 0;padding-left:1.1em;display:grid;gap:9px}
.article-toc li{color:var(--ink-2)}
.article-toc a{color:#4a4640;font-weight:600}
.article-toc a:hover{color:var(--ink)}
.article-cta-box,.ssrs-shortcode-cta,.ssrs-room-cta,.ssrs-point-box{margin:1.8em 0;padding:22px;border-radius:var(--card-r);background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(247,245,240,.96));border:1px solid rgba(14,15,17,.07);box-shadow:var(--sh-sm)}
.article-cta-box h3,.ssrs-shortcode-cta h3,.ssrs-room-cta h3,.ssrs-point-box h3{margin:0 0 8px;padding:0;font-size:1.1rem;font-weight:700}
.article-cta-box h3::before,.article-cta-box h3::after,.ssrs-shortcode-cta h3::before,.ssrs-shortcode-cta h3::after,.ssrs-room-cta h3::before,.ssrs-room-cta h3::after,.ssrs-point-box h3::before,.ssrs-point-box h3::after{display:none}
.article-cta-box p,.ssrs-shortcode-cta p,.ssrs-room-cta p,.ssrs-point-box p{margin:.4em 0;color:var(--ink-2)}
.article-cta-actions,.ssrs-shortcode-cta .actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.pagination-nav{display:flex;justify-content:center;gap:8px;margin-top:28px;flex-wrap:wrap}
.pagination-nav .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 12px;border-radius:999px;background:var(--white);border:1px solid rgba(14,15,17,.08);font-weight:700;box-shadow:var(--sh-sm)}
.pagination-nav .current{background:var(--ink);color:var(--bg);border-color:transparent}
.post-empty{padding:36px;border-radius:var(--card-r-lg);background:var(--white);border:1px solid rgba(14,15,17,.07);box-shadow:var(--sh-sm)}
.share-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.share-btn{display:inline-flex;align-items:center;padding:8px 18px;border-radius:999px;font-size:.83rem;font-weight:700;border:1.5px solid rgba(14,15,17,.12);color:var(--ink);transition:background .18s}
.share-btn:hover{background:var(--bg)}
.related-posts{margin-top:20px}
.related-posts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.article-breadcrumbs{padding:14px 22px;font-size:.8rem;color:var(--ink-3);border-bottom:1px solid rgba(14,15,17,.06)}
.article-breadcrumbs a{color:var(--ink-3)}
.article-breadcrumbs a:hover{color:var(--ink)}

/* ═══════════════ ROOM DETAIL ═══════════════ */
.room-hero{padding:60px 0 26px;position:relative;z-index:1;overflow-x:hidden}
.room-hero-grid{display:grid;grid-template-columns:1fr .95fr;gap:28px;align-items:center}
.room-hero-copy h1{font-size:clamp(2.2rem,4vw,4rem);font-weight:700;letter-spacing:-.05em;line-height:1.1}
.room-lead{color:var(--ink-2);margin-top:16px;font-size:.98rem;line-height:1.75}
.back-link{display:inline-flex;align-items:center;gap:8px;margin-bottom:14px;color:var(--accent);font-weight:700;font-size:.88rem}
.room-alert{margin-top:16px;padding:14px 16px;border-radius:12px;background:rgba(245,166,35,.1);border:1px solid rgba(245,166,35,.2)}
.room-alert strong{display:block;margin-bottom:4px;font-size:.88rem}
.room-alert p{color:var(--ink-2);font-size:.85rem;margin:0}
.room-showcase,.room-gallery{height:420px;border-radius:var(--card-r-lg);position:relative;overflow:hidden;box-shadow:var(--sh-lg);border:1px solid rgba(14,15,17,.07);background:var(--bg-2)}
.room-gallery-track{display:flex;width:100%;height:100%;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-ms-overflow-style:none;scrollbar-width:none}
.room-gallery-track::-webkit-scrollbar{display:none}
.room-gallery-slide{flex:0 0 100%;width:100%;height:100%;scroll-snap-align:start}
.room-gallery-slide img{width:100%;height:100%;object-fit:cover;display:block}
.room-gallery-slide.is-fallback{background:var(--bg-2)}
.room-gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.6);background:rgba(14,15,17,.4);color:#fff;font-size:1.6rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;z-index:2;backdrop-filter:blur(8px);box-shadow:0 8px 20px rgba(14,15,17,.18);cursor:pointer;transition:background .18s}
.room-gallery-nav:hover{background:rgba(14,15,17,.6)}
.room-gallery-nav.prev{left:14px}
.room-gallery-nav.next{right:14px}
.room-gallery-dots{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);display:flex;gap:7px;z-index:2}
.room-gallery-dot{width:9px;height:9px;border-radius:999px;border:none;background:rgba(255,255,255,.5);box-shadow:inset 0 0 0 1px rgba(14,15,17,.12);transition:width .2s,background .2s;cursor:pointer}
.room-gallery-dot.is-active{width:24px;background:#fff}
.room-gallery.is-single .room-gallery-nav,.room-gallery.is-single .room-gallery-dots{display:none}
.room-detail-grid{display:grid;grid-template-columns:1fr .9fr;gap:22px;align-items:start}
.info-card,.side-card{padding:28px;border-radius:var(--card-r-lg);background:var(--white);border:1px solid rgba(14,15,17,.07);box-shadow:var(--sh-sm)}
.side-card{align-self:start}
.detail-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;padding:0;margin:22px 0 0}
.detail-list div{padding:15px;border-radius:var(--card-r);background:var(--bg);border:1px solid rgba(14,15,17,.07)}
.detail-list dt{color:var(--ink-3);font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700}
.detail-list dd{margin:7px 0 0;font-weight:700}
.facility-grid{margin-top:14px}
.facility-list{list-style:none;display:flex;flex-wrap:wrap;gap:7px}
.facility-list li{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:var(--bg);border:1px solid rgba(14,15,17,.08);font-size:.83rem;font-weight:600;color:var(--ink-2)}
.scene-list{list-style:none;display:grid;gap:6px}
.scene-list li{position:relative;padding-left:.9rem;color:var(--ink-2);font-size:.9rem;line-height:1.5}
.scene-list li::before{content:'';position:absolute;left:0;top:.6em;width:5px;height:5px;border-radius:50%;background:var(--accent)}
.note-box{margin-top:16px;padding:14px 16px;border-radius:14px;color:var(--ink-2);background:rgba(37,99,255,.06);border:1px solid rgba(37,99,255,.14);font-size:.88rem}
.detail-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}
.readme-box{margin-top:16px;padding:14px 16px;border-radius:14px;background:var(--bg);border:1px solid rgba(14,15,17,.07);color:var(--ink-2);font-size:.87rem;line-height:1.7}
.room-map-section{padding-top:0}
.room-map-card{border-radius:var(--card-r-lg);overflow:hidden;box-shadow:var(--sh-md);border:1px solid rgba(14,15,17,.07);display:grid;grid-template-columns:1fr 1fr}
.room-map-copy{padding:32px;background:var(--white)}
.room-map-copy h2{font-size:1.6rem;font-weight:700;letter-spacing:-.04em;margin:10px 0 12px}
.room-map-text{color:var(--ink-2);font-size:.9rem;line-height:1.7;margin-bottom:18px}
.room-map-embed{background:var(--bg-2)}
.room-map-embed iframe{width:100%;height:100%;min-height:280px;display:block;border:0}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.related-card{padding:18px;border-radius:var(--card-r);background:var(--white);border:1px solid rgba(14,15,17,.07);box-shadow:var(--sh-sm)}
.related-card strong{display:block;margin-bottom:7px;font-weight:700}
.related-card p{color:var(--ink-2);font-size:.88rem;margin:0 0 12px}
/* 固定CTAボタン: max-width + left/right 指定でモバイルでの幅溢れを防止 */
.floating-reserve-cta{position:fixed;bottom:-80px;left:50%;transform:translateX(-50%);z-index:80;transition:bottom .3s cubic-bezier(.4,0,.2,1);max-width:calc(100vw - 32px);box-sizing:border-box}
.floating-reserve-cta.is-visible{bottom:24px}
.showcase-1{background:linear-gradient(135deg,#d4e3ff,#b8d0ff)}
.showcase-2{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}
.showcase-3{background:linear-gradient(135deg,#fef3c7,#fde68a)}
.showcase-4{background:linear-gradient(135deg,#fce7f3,#fbcfe8)}
.showcase-5{background:linear-gradient(135deg,#e0e7ff,#c7d2fe)}
.showcase-6{background:linear-gradient(135deg,#fff7ed,#fed7aa)}

/* ═══════════════ FOOTER ═══════════════ */
.site-footer{background:var(--ink);color:rgba(247,245,240,.6);padding:60px 0 34px}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:48px}
.footer-branding strong,.footer-brand strong{display:block;font-size:1.15rem;font-weight:700;color:var(--bg);letter-spacing:-.03em;margin-bottom:12px}
.footer-branding p,.footer-brand p{font-size:.86rem;line-height:1.8;margin-bottom:18px}
.footer-meta{display:flex;flex-wrap:wrap;gap:8px 16px;color:rgba(247,245,240,.5);font-size:.85rem;margin-top:10px}
.footer-social{display:flex;gap:9px}
.social-btn{width:34px;height:34px;border-radius:10px;border:1px solid rgba(247,245,240,.12);display:grid;place-items:center;font-size:.85rem;transition:background .18s,border-color .18s;color:rgba(247,245,240,.65)}
.social-btn:hover{background:rgba(247,245,240,.08);border-color:rgba(247,245,240,.2)}
.footer-links{display:flex;flex-direction:column;gap:9px}
.footer-links a,.footer-col a{font-size:.85rem;color:rgba(247,245,240,.6);transition:color .18s}
.footer-links a:hover,.footer-col a:hover{color:var(--bg)}
.footer-col h4{font-size:.68rem;font-weight:700;letter-spacing:.14em;color:rgba(247,245,240,.38);margin-bottom:16px}
.footer-col ul{list-style:none;display:grid;gap:9px}
.footer-bottom{padding-top:26px;border-top:1px solid rgba(247,245,240,.08);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-bottom p,.footer-bottom small{font-size:.78rem;color:rgba(247,245,240,.35)}
.footer-legal{display:flex;gap:18px;flex-wrap:wrap}
.footer-legal a{font-size:.78rem;color:rgba(247,245,240,.35);transition:color .18s}
.footer-legal a:hover{color:rgba(247,245,240,.65)}

/* ═══════════════ MISC ═══════════════ */
.generic-page{padding:28px;border-radius:var(--card-r-lg);background:var(--white);border:1px solid rgba(14,15,17,.07);box-shadow:var(--sh-sm)}
.generic-page h1{margin-top:0;font-size:2rem;font-weight:700;letter-spacing:-.04em}
.generic-page-content{color:var(--ink-2)}
.ssrs-list-editor-target{white-space:pre-line;line-height:1.5;margin:0}
[data-ssrs-editable]:focus{outline:2px dashed var(--accent);outline-offset:4px;border-radius:4px}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .55s ease,transform .55s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.section-cta-inline{margin-top:28px;display:flex;justify-content:center}

/* ═══════════════ RESPONSIVE ═══════════════ */
@media(max-width:1100px){
  .search-form{grid-template-columns:1fr 1fr}
  .search-btn{grid-column:1/-1;justify-content:center}
  .ai-section-card{grid-template-columns:1fr;padding:36px;gap:32px}
  .footer-inner{grid-template-columns:1fr 1fr;gap:24px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .split-heading{grid-template-columns:1fr}
  .room-map-card{grid-template-columns:1fr}
  .blog-highlight-grid,.column-layout,.archive-layout,.article-layout{grid-template-columns:1fr}
  .column-sidebar,.article-sidebar{position:static}
  .blog-stats{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:860px){
  .desktop-nav,.header-actions .btn-ghost{display:none}
  .mobile-toggle{display:block}
  .hero{padding:52px 0 36px}
  .room-grid,.feature-grid,.premium-grid{grid-template-columns:1fr}
  .table-wrap{overflow-x:auto}
  .comparison-table{min-width:640px}
  .faq-layout{grid-template-columns:1fr}
  .faq-cta-card{position:static}
  .reserve-box{padding:36px 28px;flex-direction:column}
  .cal-header{flex-direction:column;align-items:flex-start}
  .blog-stats{grid-template-columns:repeat(2,1fr)}
  .related-grid,.related-posts-grid{grid-template-columns:1fr 1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
  .access-layout{grid-template-columns:1fr}
  .room-hero-grid,.room-detail-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .container{width:calc(100% - 32px)}
  .hero h1{font-size:2.5rem}
  .hero-actions,.reserve-actions,.blog-actions{flex-direction:column}
  .btn-hero-primary,.btn-hero-secondary,.btn-reserve-primary,.btn-reserve-secondary{width:100%;justify-content:center}
  .feature-grid,.premium-grid,.stats-grid{grid-template-columns:1fr}
  .blog-footer-links{grid-template-columns:1fr}
  .blog-footer-box{flex-direction:column;align-items:stretch;gap:20px;padding:20px 20px}
  .blog-footer-copy h2{font-size:1.3rem}
  .blog-footer-actions{width:100%}
  .blog-footer-actions .btn{display:flex;width:100%;justify-content:center;padding:14px 20px;font-size:.95rem;white-space:nowrap}
  .archive-grid,.posts-mini-grid,.related-grid,.related-posts-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .cal-body,.cal-grid-header{padding:0 16px 16px}
  .cal-day{min-height:58px}
  .room-dot span{display:none}
  .detail-list{grid-template-columns:1fr}
  .search-card{padding:22px}
  .search-form{grid-template-columns:1fr}
  .secondary-destination-box{grid-template-columns:1fr;padding:22px}
  .article-head{padding:24px 22px 18px}
  .article-content{padding:8px 22px 32px}
  .article-head h1{font-size:1.75rem}
  .blog-stats{grid-template-columns:1fr 1fr}
  .room-showcase,.room-gallery{height:280px}
}

/* ═══════════════════════════════════════════
   ROOM AVAILABILITY CALENDAR (ssrs_render_room_calendar)
═══════════════════════════════════════════ */
:root{--calendar-row-height:68px;--calendar-row-height-mobile:52px}
.availability-shell{padding:32px;border-radius:var(--card-r-lg);background:var(--white);border:1px solid rgba(14,15,17,.07);box-shadow:var(--sh-md)}
.availability-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-end;margin-bottom:18px;flex-wrap:wrap}
.availability-title{margin:6px 0 0;font-size:clamp(1.7rem,2.4vw,2.5rem);font-weight:700;letter-spacing:-.04em;line-height:1.2}
.availability-note{margin:12px 0 0;color:var(--ink-2);max-width:720px;font-size:.9rem}
.availability-tools{display:flex;flex-direction:column;gap:10px;align-items:flex-end}
.availability-week-switcher{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:999px;background:var(--bg);border:1px solid rgba(14,15,17,.1);white-space:nowrap}
.availability-week-switcher strong{font-size:.9rem;font-weight:700}
.week-nav-btn,.week-today-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border-radius:999px;font-weight:700;font-size:.85rem;background:var(--white);border:1.5px solid rgba(14,15,17,.12);color:var(--ink-2);transition:border-color .18s,color .18s}
.week-nav-btn:hover,.week-today-btn:hover{border-color:var(--accent);color:var(--accent)}
.availability-legend{display:flex;flex-wrap:wrap;gap:10px;align-items:center;font-size:.88rem;color:var(--ink-3);margin-bottom:18px}
.legend-pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 14px;border-radius:999px;font-size:.78rem;font-weight:700;color:#fff;background:var(--accent)}
.availability-empty{padding:22px 20px;border-radius:var(--card-r);background:var(--bg);border:1px solid rgba(14,15,17,.08);color:var(--ink-3);font-size:.9rem}
.availability-board{border-radius:var(--card-r);overflow:hidden;border:1px solid rgba(14,15,17,.08);background:var(--white)}
.availability-header-row{display:grid;grid-template-columns:82px repeat(7,minmax(0,1fr));border-bottom:1px solid rgba(14,15,17,.08);background:var(--bg)}
.time-header,.day-header{padding:14px 10px;min-height:66px}
.time-header{display:flex;align-items:flex-end;justify-content:center;color:var(--ink-3);font-size:.78rem;font-weight:700;font-family:var(--mono)}
.day-header{display:flex;flex-direction:column;justify-content:flex-end;gap:2px;border-left:1px solid rgba(14,15,17,.07);text-align:center}
.day-header span{font-size:.78rem;color:var(--ink-3)}
.day-header strong{font-size:.95rem;font-weight:700}
.day-header.is-today{background:rgba(37,99,255,.06)}
.day-header.is-today strong{color:var(--accent)}
.day-header.is-today span{color:var(--accent);font-weight:700}
.availability-grid-wrap{display:grid;grid-template-columns:82px 1fr}
.time-axis{position:relative;height:calc(var(--calendar-hours) * var(--calendar-row-height));background:var(--bg);border-right:1px solid rgba(14,15,17,.07)}
.time-axis-item{height:var(--calendar-row-height);position:relative;border-bottom:1px solid rgba(14,15,17,.06)}
.time-axis-item span{position:absolute;top:-11px;right:8px;display:inline-block;padding:2px 7px;font-size:.7rem;color:var(--ink-3);background:var(--bg);border-radius:999px;font-family:var(--mono);min-width:42px;text-align:right}
.day-columns{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));height:calc(var(--calendar-hours) * var(--calendar-row-height))}
.day-column{position:relative;height:calc(var(--calendar-hours) * var(--calendar-row-height));border-left:1px solid rgba(14,15,17,.06);background:var(--white)}
.day-column.is-today{background:rgba(37,99,255,.03);box-shadow:inset 0 0 0 1.5px rgba(37,99,255,.12)}
.day-grid-lines{position:absolute;inset:0;background-image:repeating-linear-gradient(to bottom,rgba(14,15,17,.04) 0,rgba(14,15,17,.04) 1px,transparent 1px,transparent calc(var(--calendar-row-height) / 2)),repeating-linear-gradient(to bottom,rgba(14,15,17,.07) 0,rgba(14,15,17,.07) 1px,transparent 1px,transparent var(--calendar-row-height));pointer-events:none}
.day-empty-text{position:absolute;left:50%;top:18px;transform:translateX(-50%);padding:5px 10px;border-radius:999px;font-size:.72rem;font-weight:700;color:var(--ink-3);background:var(--bg);border:1px solid rgba(14,15,17,.08);white-space:nowrap}
.day-closed-mask{position:absolute;left:0;right:0;bottom:0;background:repeating-linear-gradient(-45deg,rgba(14,15,17,.025) 0,rgba(14,15,17,.025) 4px,transparent 4px,transparent 10px);pointer-events:none;z-index:0}
.day-closed-mask.before-open{top:0;bottom:auto}
.booking-block{position:absolute;left:6px;right:6px;box-sizing:border-box;border-radius:12px;padding:9px 10px 8px;min-height:48px;color:#fff;background:var(--accent);box-shadow:0 8px 20px rgba(37,99,255,.22);overflow:hidden;z-index:1;display:flex;flex-direction:column;justify-content:flex-start}
.booking-block strong{display:block;font-size:.78rem;font-weight:700;letter-spacing:.03em;white-space:nowrap}
.booking-block span{display:block;margin-top:3px;font-size:.72rem;opacity:.88;white-space:nowrap}
.room-calendar-section .availability-shell{padding:0;background:none;border:none;box-shadow:none}
@media(max-width:980px){.availability-head{flex-direction:column;align-items:flex-start}.availability-tools{align-items:flex-start;width:100%}.availability-week-switcher{width:100%;justify-content:space-between}.availability-board{overflow-x:auto}.availability-header-row,.availability-grid-wrap{min-width:760px}}
@media(max-width:640px){.availability-shell{padding:0}.availability-header-row,.availability-grid-wrap{min-width:640px}.time-axis,.day-column{height:calc(var(--calendar-hours) * var(--calendar-row-height-mobile))}.day-columns{height:calc(var(--calendar-hours) * var(--calendar-row-height-mobile))}.time-axis-item{height:var(--calendar-row-height-mobile)}.booking-block{left:4px;right:4px;padding:7px 8px 6px;border-radius:8px}}

/* ═══════════════════════════════════════════
   TOC 目次 — リデザイン
═══════════════════════════════════════════ */
.article-inline-toc {
  margin: 0 0 32px;
  background: var(--white);
  border: 1.5px solid rgba(14,15,17,.09);
  border-radius: var(--card-r);
  overflow: hidden;
  box-shadow: var(--sh-sm);
}
.article-inline-toc-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 22px;
  background: var(--ink);
  cursor: pointer;
  user-select: none;
}
.article-inline-toc h3 {
  margin: 0;
  font-size: .88rem;
  font-weight: 700;
  color: var(--bg);
  letter-spacing: .06em;
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 16px 22px;
  background: var(--ink);
}
.article-inline-toc h3::before {
  content: '≡';
  font-size: 1.15rem;
  opacity: .7;
}
.article-inline-toc ol {
  margin: 0;
  padding: 12px 0;
  list-style: none;
  display: grid;
  gap: 0;
  counter-reset: toc-counter;
}
.article-inline-toc li {
  counter-increment: toc-counter;
  margin: 0;
}
.article-inline-toc li a {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 9px 22px;
  color: var(--ink-2);
  font-size: .88rem;
  font-weight: 500;
  text-decoration: none;
  transition: background .14s, color .14s;
  border-left: 2.5px solid transparent;
}
.article-inline-toc li a::before {
  content: counter(toc-counter);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  border-radius: 6px;
  background: var(--bg);
  color: var(--ink-3);
  font-size: .72rem;
  font-weight: 700;
  font-family: var(--mono);
  flex-shrink: 0;
}
.article-inline-toc li a:hover {
  background: rgba(37,99,255,.04);
  color: var(--accent);
  border-left-color: var(--accent);
}
.article-inline-toc li a:hover::before {
  background: rgba(37,99,255,.1);
  color: var(--accent);
}
/* h3（サブ見出し） */
.article-inline-toc li.level-3 a {
  padding-left: 42px;
  font-size: .84rem;
  color: var(--ink-3);
}
.article-inline-toc li.level-3 a::before {
  display: none;
}
.article-inline-toc li.level-3 a::after {
  content: '';
  display: none;
}
.article-inline-toc li + li {
  border-top: 1px solid rgba(14,15,17,.04);
}
/* compact variant */
.article-inline-toc-compact h3 {
  padding: 13px 18px;
}
.article-inline-toc-compact li a {
  padding: 8px 18px;
  font-size: .85rem;
}
.article-inline-toc-compact li.level-3 a {
  padding-left: 38px;
}

/* ═══════════════════════════════════════════
   コンテンツパーツ — ショートコード共通
═══════════════════════════════════════════ */
.ssrs-box {
  margin: 1.8em 0;
  border-radius: var(--card-r);
  overflow: hidden;
  border: 1px solid transparent;
}
.ssrs-box-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 18px;
  font-weight: 700;
  font-size: .82rem;
  letter-spacing: .08em;
}
.ssrs-box-icon { font-size: 1rem; }
.ssrs-box-label { }
.ssrs-box-body {
  padding: 16px 18px;
  font-size: .93rem;
  line-height: 1.8;
}
.ssrs-box-body p { margin: .4em 0; color: var(--ink-2); }
.ssrs-box-body p:first-child { margin-top: 0; }
.ssrs-box-body p:last-child { margin-bottom: 0; }

/* ─ ポイント ─ */
.ssrs-box-point {
  background: rgba(37,99,255,.04);
  border-color: rgba(37,99,255,.2);
}
.ssrs-box-point .ssrs-box-head {
  background: rgba(37,99,255,.1);
  color: var(--accent);
}

/* ─ 注意 ─ */
.ssrs-box-warning {
  background: rgba(245,166,35,.04);
  border-color: rgba(245,166,35,.3);
}
.ssrs-box-warning .ssrs-box-head {
  background: rgba(245,166,35,.12);
  color: #92670a;
}

/* ─ メモ ─ */
.ssrs-box-memo {
  background: rgba(100,116,139,.04);
  border-color: rgba(100,116,139,.2);
}
.ssrs-box-memo .ssrs-box-head {
  background: rgba(100,116,139,.1);
  color: #475569;
}

/* ─ まとめ ─ */
.ssrs-box-summary {
  background: rgba(0,184,122,.04);
  border-color: rgba(0,184,122,.25);
}
.ssrs-box-summary .ssrs-box-head {
  background: rgba(0,184,122,.1);
  color: #007a51;
}

/* ─ チェックリスト ─ */
.ssrs-box-check {
  background: var(--white);
  border-color: rgba(14,15,17,.08);
  padding: 18px 20px;
}
.ssrs-check-title {
  font-weight: 700;
  margin-bottom: 12px;
  font-size: .9rem;
  color: var(--ink);
}
.ssrs-check-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 8px;
}
.ssrs-check-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 10px;
  background: var(--bg);
  font-size: .9rem;
  line-height: 1.6;
}
.ssrs-check-list li::before {
  content: '✓';
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 6px;
  background: var(--green);
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ═══════════════════════════════════════════
   吹き出し [bubble]
═══════════════════════════════════════════ */
.ssrs-bubble {
  display: flex;
  gap: 14px;
  margin: 1.6em 0;
  align-items: flex-start;
}
.ssrs-bubble.ssrs-bubble-right {
  flex-direction: row-reverse;
}
.bubble-person {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.bubble-avatar {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid rgba(14,15,17,.1);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-2);
}
.bubble-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.bubble-avatar-icon {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ink-2);
}
.bubble-name {
  font-size: .72rem;
  font-weight: 700;
  color: var(--ink-3);
  white-space: nowrap;
  letter-spacing: .04em;
}
.bubble-body {
  position: relative;
  max-width: calc(100% - 80px);
}
.bubble-text {
  background: var(--white);
  border: 1.5px solid rgba(14,15,17,.1);
  border-radius: 18px;
  border-top-left-radius: 4px;
  padding: 13px 16px;
  font-size: .9rem;
  line-height: 1.75;
  color: var(--ink);
  box-shadow: var(--sh-sm);
  position: relative;
}
.bubble-text::before {
  content: '';
  position: absolute;
  top: 10px;
  left: -9px;
  width: 0;
  height: 0;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-right: 9px solid rgba(14,15,17,.1);
}
.bubble-text::after {
  content: '';
  position: absolute;
  top: 11px;
  left: -7px;
  width: 0;
  height: 0;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-right: 8px solid var(--white);
}
/* 右吹き出し */
.ssrs-bubble-right .bubble-text {
  border-radius: 18px;
  border-top-right-radius: 4px;
  background: rgba(37,99,255,.06);
  border-color: rgba(37,99,255,.2);
}
.ssrs-bubble-right .bubble-text::before {
  left: auto;
  right: -9px;
  border-right: none;
  border-left: 9px solid rgba(37,99,255,.2);
}
.ssrs-bubble-right .bubble-text::after {
  left: auto;
  right: -7px;
  border-right: none;
  border-left: 8px solid rgba(37,99,255,.06);
}
@media(max-width:640px) {
  .ssrs-bubble { gap: 10px; }
  .bubble-avatar { width: 42px; height: 42px; }
  .bubble-text { font-size: .85rem; padding: 11px 13px; }
  .bubble-body { max-width: calc(100% - 64px); }
}

/* ═══════════════════════════════════════════
   記事スタイル改善
═══════════════════════════════════════════ */
/* heading前後の余白バランス改善 */
.article-content h2 { margin-top: 2.8em; margin-bottom: 1em; }
.article-content h3 { margin-top: 2.2em; margin-bottom: .8em; }
.article-content h4 { margin-top: 1.8em; margin-bottom: .7em; }
/* 段落・リスト間隔 */
.article-content p { margin: .9em 0; }
.article-content ul, .article-content ol { margin: 1em 0 1.2em; }
.article-content li { margin: .5em 0; }
/* 引用ブロック */
.article-content blockquote { font-style: italic; }
.article-content blockquote p { color: #4a4640; }
/* 水平線 */
.article-content hr { border: none; border-top: 2px solid rgba(14,15,17,.08); margin: 2em 0; }
/* 画像キャプション */
.article-content figcaption, .article-content .wp-caption-text {
  text-align: center; color: var(--ink-3); font-size: .8rem; margin-top: 8px;
}
/* コード */
.article-content code {
  font-family: var(--mono); font-size: .85em;
  background: rgba(14,15,17,.06); padding: 2px 7px; border-radius: 6px;
}
.article-content pre {
  background: var(--ink); color: rgba(247,245,240,.88); padding: 20px; border-radius: var(--card-r);
  overflow-x: auto; font-family: var(--mono); font-size: .85rem; line-height: 1.7; margin: 1.5em 0;
}
.article-content pre code { background: none; padding: 0; color: inherit; font-size: inherit; }
/* 太字・マーカー */
.article-content strong { font-weight: 700; color: var(--ink); }
.article-content mark { background: rgba(245,166,35,.2); padding: 1px 4px; border-radius: 3px; }

/* ═══════════════════════════════════════════
   カレンダー DatePicker UI
═══════════════════════════════════════════ */
.cal-date-picker-wrap {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 12px; border-radius: 999px;
  background: var(--white); border: 1.5px solid rgba(14,15,17,.12);
  cursor: pointer; transition: border-color .18s;
}
.cal-date-picker-wrap:hover { border-color: var(--accent); }
.cal-picker-icon { font-size: 1rem; flex-shrink: 0; }
.cal-date-picker {
  border: none; outline: none; font-family: var(--font); font-size: .85rem; font-weight: 600;
  color: var(--ink); background: transparent; cursor: pointer; min-width: 130px;
}
.cal-date-picker::-webkit-calendar-picker-indicator { opacity: 0; position: absolute; width: 100%; cursor: pointer; }

/* ═══════════════════════════════════════════
   コンテンツパーツ CSS（全14種）
═══════════════════════════════════════════ */
/* 共通ボックス */
.ssrs-box { margin: 1.8em 0; border-radius: var(--card-r); overflow: hidden; border: 1px solid transparent; }
.ssrs-box-head { display: flex; align-items: center; gap: 8px; padding: 11px 18px; font-weight: 700; font-size: .82rem; letter-spacing: .08em; }
.ssrs-box-body { padding: 16px 18px; font-size: .92rem; line-height: 1.8; }
.ssrs-box-body > p { margin: .4em 0; color: var(--ink-2); }
.ssrs-box-body > p:first-child { margin-top: 0; }
.ssrs-box-body > p:last-child { margin-bottom: 0; }
/* ポイント */
.ssrs-box-point { background: rgba(37,99,255,.04); border-color: rgba(37,99,255,.2); }
.ssrs-box-point .ssrs-box-head { background: rgba(37,99,255,.1); color: var(--accent); }
/* 注意 */
.ssrs-box-warning { background: rgba(245,166,35,.04); border-color: rgba(245,166,35,.3); }
.ssrs-box-warning .ssrs-box-head { background: rgba(245,166,35,.12); color: #92670a; }
/* メモ */
.ssrs-box-memo { background: rgba(100,116,139,.04); border-color: rgba(100,116,139,.2); }
.ssrs-box-memo .ssrs-box-head { background: rgba(100,116,139,.1); color: #475569; }
/* まとめ */
.ssrs-box-summary { background: rgba(0,184,122,.04); border-color: rgba(0,184,122,.25); }
.ssrs-box-summary .ssrs-box-head { background: rgba(0,184,122,.1); color: #007a51; }
/* チェックリスト */
.ssrs-box-check { background: var(--white); border-color: rgba(14,15,17,.08); padding: 18px 20px; }
.ssrs-check-title { font-weight: 700; margin-bottom: 12px; font-size: .9rem; }
.ssrs-check-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.ssrs-check-list li { display: flex; align-items: flex-start; gap: 10px; padding: 10px 14px; border-radius: 10px; background: var(--bg); font-size: .9rem; line-height: 1.6; }
.ssrs-check-list li::before { content: '✓'; display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 6px; background: var(--green); color: #fff; font-size: .72rem; font-weight: 700; flex-shrink: 0; margin-top: 1px; }

/* 吹き出し */
.ssrs-bubble { display: flex; gap: 14px; margin: 1.6em 0; align-items: flex-start; }
.ssrs-bubble-right { flex-direction: row-reverse; }
.bubble-person { display: flex; flex-direction: column; align-items: center; gap: 6px; flex-shrink: 0; }
.bubble-avatar { width: 52px; height: 52px; border-radius: 50%; overflow: hidden; border: 2px solid rgba(14,15,17,.1); display: flex; align-items: center; justify-content: center; background: var(--bg-2); }
.bubble-avatar-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bubble-avatar-icon { font-size: 1.4rem; font-weight: 700; color: var(--ink-2); }
.bubble-name { font-size: .72rem; font-weight: 700; color: var(--ink-3); white-space: nowrap; letter-spacing: .04em; text-align: center; }
.bubble-body { position: relative; max-width: calc(100% - 80px); }
.bubble-text { background: var(--white); border: 1.5px solid rgba(14,15,17,.1); border-radius: 18px; border-top-left-radius: 4px; padding: 13px 16px; font-size: .9rem; line-height: 1.75; color: var(--ink); box-shadow: var(--sh-sm); position: relative; }
.bubble-text::before { content: ''; position: absolute; top: 10px; left: -9px; width: 0; height: 0; border-top: 6px solid transparent; border-bottom: 6px solid transparent; border-right: 9px solid rgba(14,15,17,.1); }
.bubble-text::after { content: ''; position: absolute; top: 11px; left: -7px; width: 0; height: 0; border-top: 5px solid transparent; border-bottom: 5px solid transparent; border-right: 8px solid var(--white); }
.ssrs-bubble-right .bubble-text { border-radius: 18px; border-top-right-radius: 4px; background: rgba(37,99,255,.06); border-color: rgba(37,99,255,.2); }
.ssrs-bubble-right .bubble-text::before { left: auto; right: -9px; border-right: none; border-left: 9px solid rgba(37,99,255,.2); }
.ssrs-bubble-right .bubble-text::after { left: auto; right: -7px; border-right: none; border-left: 8px solid rgba(37,99,255,.06); }

/* ステップ */
.ssrs-steps { display: grid; gap: 0; margin: 1.8em 0; position: relative; }
.ssrs-steps::before { content: ''; position: absolute; left: 19px; top: 20px; bottom: 20px; width: 2px; background: rgba(14,15,17,.08); z-index: 0; }
.ssrs-step { display: flex; gap: 16px; align-items: flex-start; padding: 0 0 24px; position: relative; z-index: 1; }
.ssrs-step:last-child { padding-bottom: 0; }
.ssrs-step-num { width: 40px; height: 40px; border-radius: 50%; background: var(--ink); color: var(--bg); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: .88rem; font-family: var(--mono); flex-shrink: 0; box-shadow: 0 4px 12px rgba(14,15,17,.18); }
.ssrs-step-body { flex: 1; padding-top: 8px; }
.ssrs-step-title { font-weight: 700; font-size: .98rem; margin-bottom: 7px; color: var(--ink); }
.ssrs-step-text p { margin: .3em 0; color: var(--ink-2); font-size: .9rem; line-height: 1.7; }

/* 2カラム */
.ssrs-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin: 1.6em 0; }
.ssrs-col { background: var(--white); border-radius: var(--card-r); padding: 18px; border: 1px solid rgba(14,15,17,.07); }
.ssrs-col p { margin: .4em 0; font-size: .9rem; color: var(--ink-2); }

/* FAQ */
.ssrs-faq-item { border-radius: var(--card-r); background: var(--white); border: 1.5px solid rgba(14,15,17,.07); margin: .8em 0; overflow: hidden; transition: border-color .18s; }
.ssrs-faq-item[open] { border-color: rgba(14,15,17,.14); }
.ssrs-faq-item summary { padding: 15px 18px; font-weight: 600; font-size: .92rem; cursor: pointer; list-style: none; display: flex; align-items: center; gap: 10px; }
.ssrs-faq-item summary::-webkit-details-marker { display: none; }
.ssrs-faq-q-label { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 7px; background: var(--accent); color: #fff; font-size: .78rem; font-weight: 700; flex-shrink: 0; }
.ssrs-faq-toggle { margin-left: auto; font-size: 1.2rem; color: var(--ink-3); flex-shrink: 0; transition: transform .2s; }
.ssrs-faq-item[open] .ssrs-faq-toggle { transform: rotate(45deg); }
.ssrs-faq-answer { display: flex; gap: 10px; padding: 14px 18px 16px; border-top: 1px solid rgba(14,15,17,.06); background: var(--bg); }
.ssrs-faq-a-label { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 7px; background: var(--green); color: #fff; font-size: .78rem; font-weight: 700; flex-shrink: 0; margin-top: 2px; }
.ssrs-faq-answer > div { font-size: .9rem; color: var(--ink-2); line-height: 1.75; flex: 1; }
.ssrs-faq-answer > div p { margin: .3em 0; }

/* プロフィール */
.ssrs-profile { display: flex; gap: 18px; align-items: flex-start; margin: 1.8em 0; padding: 20px; border-radius: var(--card-r); background: var(--white); border: 1px solid rgba(14,15,17,.07); box-shadow: var(--sh-sm); }
.ssrs-profile-avatar { width: 72px; height: 72px; border-radius: 50%; overflow: hidden; border: 2.5px solid rgba(14,15,17,.1); flex-shrink: 0; background: var(--bg-2); display: flex; align-items: center; justify-content: center; }
.ssrs-profile-avatar img { width: 100%; height: 100%; object-fit: cover; }
.profile-avatar-icon { font-size: 2rem; font-weight: 700; color: var(--ink-2); }
.ssrs-profile-body { flex: 1; min-width: 0; }
.ssrs-profile-meta { display: flex; align-items: baseline; gap: 10px; margin-bottom: 10px; flex-wrap: wrap; }
.ssrs-profile-name { font-size: 1.05rem; font-weight: 700; letter-spacing: -.02em; }
.ssrs-profile-role { font-size: .8rem; color: var(--ink-3); font-weight: 500; }
.ssrs-profile-text p { margin: .3em 0; font-size: .9rem; color: var(--ink-2); line-height: 1.75; }

/* リンクカード */
.ssrs-link-card { display: flex; align-items: center; gap: 14px; padding: 16px; border-radius: var(--card-r); background: var(--white); border: 1.5px solid rgba(14,15,17,.09); box-shadow: var(--sh-sm); text-decoration: none; margin: 1.4em 0; transition: border-color .18s, transform .15s, box-shadow .18s; }
.ssrs-link-card:hover { border-color: var(--accent); transform: translateY(-2px); box-shadow: var(--sh-md); }
.ssrs-link-img { width: 80px; height: 60px; border-radius: 10px; overflow: hidden; flex-shrink: 0; background: var(--bg-2); }
.ssrs-link-img img { width: 100%; height: 100%; object-fit: cover; }
.ssrs-link-arrow { width: 40px; height: 40px; border-radius: 12px; background: var(--bg); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0; color: var(--accent); font-weight: 700; }
.ssrs-link-body { flex: 1; min-width: 0; }
.ssrs-link-title { font-size: .95rem; font-weight: 700; color: var(--ink); margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ssrs-link-desc { font-size: .82rem; color: var(--ink-2); line-height: 1.5; margin-bottom: 4px; }
.ssrs-link-url { font-size: .75rem; color: var(--ink-3); font-family: var(--mono); }

/* 関連投稿カード */
.ssrs-related-post { display: flex; gap: 14px; align-items: center; padding: 14px; border-radius: var(--card-r); background: var(--white); border: 1px solid rgba(14,15,17,.07); box-shadow: var(--sh-sm); text-decoration: none; margin: 1.2em 0; transition: transform .18s, box-shadow .18s; }
.ssrs-related-post:hover { transform: translateY(-2px); box-shadow: var(--sh-md); }
.ssrs-rp-img { width: 72px; height: 52px; border-radius: 8px; overflow: hidden; flex-shrink: 0; background: var(--bg-2); }
.ssrs-rp-img img { width: 100%; height: 100%; object-fit: cover; }
.ssrs-rp-body { flex: 1; min-width: 0; }
.ssrs-rp-cat { display: inline-block; padding: 2px 8px; border-radius: 999px; background: rgba(37,99,255,.08); color: var(--accent); font-size: .7rem; font-weight: 700; margin-bottom: 5px; }
.ssrs-rp-title { font-size: .9rem; font-weight: 700; color: var(--ink); line-height: 1.45; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ssrs-rp-date { font-size: .74rem; color: var(--ink-3); margin-top: 4px; }

/* 比較表 */
.ssrs-compare { border-radius: var(--card-r); overflow: hidden; border: 1px solid rgba(14,15,17,.08); margin: 1.8em 0; }
.ssrs-compare-head { display: grid; grid-template-columns: 1.2fr 1fr 1fr; background: var(--ink); }
.ssrs-compare-head > div { padding: 12px 16px; text-align: center; font-size: .8rem; font-weight: 700; }
.ssrs-compare-col span { display: inline-block; padding: 5px 14px; border-radius: 999px; color: #fff; background: rgba(255,255,255,.15); font-size: .82rem; }
.ssrs-compare-row { display: grid; grid-template-columns: 1.2fr 1fr 1fr; border-top: 1px solid rgba(14,15,17,.06); }
.ssrs-compare-row:nth-child(even) { background: rgba(14,15,17,.015); }
.ssrs-compare-label { padding: 13px 16px; font-weight: 700; font-size: .88rem; color: var(--ink-2); border-right: 1px solid rgba(14,15,17,.06); }
.ssrs-compare-cell { padding: 13px 16px; text-align: center; font-size: .88rem; color: var(--ink-2); }

/* タイムライン */
.ssrs-timeline { margin: 1.8em 0; position: relative; padding-left: 28px; }
.ssrs-timeline::before { content: ''; position: absolute; left: 7px; top: 8px; bottom: 8px; width: 2px; background: rgba(14,15,17,.1); }
.ssrs-timeline-item { position: relative; padding-bottom: 22px; }
.ssrs-timeline-item:last-child { padding-bottom: 0; }
.ssrs-tl-dot { position: absolute; left: -24px; top: 5px; width: 16px; height: 16px; border-radius: 50%; background: var(--accent); border: 3px solid var(--white); box-shadow: 0 0 0 2px rgba(37,99,255,.3); }
.ssrs-tl-date { font-family: var(--mono); font-size: .74rem; color: var(--accent); font-weight: 700; letter-spacing: .06em; margin-bottom: 4px; }
.ssrs-tl-title { font-size: .95rem; font-weight: 700; color: var(--ink); margin-bottom: 4px; }
.ssrs-tl-desc { font-size: .87rem; color: var(--ink-2); line-height: 1.65; }

/* フッター CTA リンク */
.footer-cta-link { display: inline-flex; align-items: center; gap: 8px; padding: 10px 20px; border-radius: 999px; background: rgba(247,245,240,.12); color: rgba(247,245,240,.85); font-size: .85rem; font-weight: 700; border: 1px solid rgba(247,245,240,.18); transition: background .18s; margin-top: 14px; }
.footer-cta-link:hover { background: rgba(247,245,240,.2); }

/* ═══════════════════════════════════════════
   モバイル最適化（追加・強化）
═══════════════════════════════════════════ */
@media(max-width:860px) {
  /* ヒーロー */
  .hero { padding: 40px 0 30px; }
  .hero h1 { font-size: clamp(2.2rem, 7vw, 3.2rem); }
  .hero-stats { gap: 24px; }
  .hero-stat strong { font-size: 1.8rem; }
  /* セクション */
  .section { padding: 56px 0; }
  /* フッター */
  .footer-inner { grid-template-columns: 1fr 1fr; gap: 20px; }
  .footer-branding { grid-column: 1 / -1; }
  /* コンテンツパーツ */
  .ssrs-two-col { grid-template-columns: 1fr; }
  .ssrs-compare-head, .ssrs-compare-row { grid-template-columns: 1fr 1fr 1fr; }
  /* カレンダーdatepicker */
  .cal-date-picker-wrap { padding: 6px 10px; }
  .cal-date-picker { min-width: 110px; font-size: .8rem; }
}
@media(max-width:640px) {
  /* 記事 */
  .article-content { padding: 8px 18px 28px; }
  .article-head { padding: 20px 18px 16px; }
  .article-head h1 { font-size: 1.6rem; }
  /* TOC */
  .article-inline-toc h3 { padding: 12px 16px; font-size: .82rem; }
  .article-inline-toc li a { padding: 8px 16px; font-size: .82rem; }
  .article-inline-toc li.level-3 a { padding-left: 32px; }
  /* バブル */
  .ssrs-bubble { gap: 8px; }
  .bubble-avatar { width: 40px; height: 40px; }
  .bubble-text { font-size: .84rem; padding: 10px 12px; }
  .bubble-body { max-width: calc(100% - 60px); }
  /* ステップ */
  .ssrs-steps::before { left: 16px; }
  .ssrs-step-num { width: 34px; height: 34px; font-size: .82rem; }
  /* プロフィール */
  .ssrs-profile { flex-direction: column; gap: 12px; }
  .ssrs-profile-avatar { width: 60px; height: 60px; }
  /* 比較表 */
  .ssrs-compare { overflow-x: auto; }
  .ssrs-compare-head, .ssrs-compare-row { min-width: 360px; }
  /* リンクカード */
  .ssrs-link-img { width: 60px; height: 48px; }
  /* カレンダー週switcher */
  .availability-week-switcher { flex-wrap: wrap; gap: 6px; }
  .cal-date-picker-wrap { width: 100%; justify-content: center; }
  .cal-date-picker { min-width: 150px; }
  /* フッター */
  .footer-inner { grid-template-columns: 1fr; }
  .footer-branding { grid-column: auto; }
}

/* ═══════════════════════════════════════════
   モバイル週次カレンダー 時間ズレ修正
   ── PHPが68pxで計算するため、CSSも68px固定に統一
      モバイルはボードを水平+垂直スクロールで対応
═══════════════════════════════════════════ */
/* mobile overrideを完全リセット */
@media(max-width:640px) {
  :root {
    --calendar-row-height: 68px !important;
    --calendar-row-height-mobile: 68px !important;
  }
  .time-axis,
  .day-column,
  .day-columns {
    height: calc(var(--calendar-hours, 14) * 68px) !important;
  }
  .time-axis-item {
    height: 68px !important;
  }
  .availability-board {
    overflow-x: auto;
    overflow-y: auto;
    max-height: 72vh;
    -webkit-overflow-scrolling: touch;
  }
  .availability-header-row,
  .availability-grid-wrap {
    min-width: 600px;
  }
}
@media(max-width:980px) {
  .availability-board {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .availability-header-row,
  .availability-grid-wrap { min-width: 600px; }
}

/* ═══════════════════════════════════════════
   AIチャット — 動作版スタイル
═══════════════════════════════════════════ */
.ai-chat-messages {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: 280px;
  overflow-y: auto;
  margin-bottom: 0;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}
.ai-chat-messages::-webkit-scrollbar { width: 4px; }
.ai-chat-messages::-webkit-scrollbar-track { background: transparent; }
.ai-chat-messages::-webkit-scrollbar-thumb { background: rgba(247,245,240,.2); border-radius: 999px; }
.ai-chat .chat-msg { margin-bottom: 0; }
@keyframes ai-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .45; }
}
.ai-thinking { animation: ai-pulse 1.2s ease infinite; }
.ai-no-key-notice {
  margin-top: 16px; padding: 14px 16px; border-radius: 12px;
  background: rgba(245,166,35,.1); border: 1px solid rgba(245,166,35,.3);
  font-size: .82rem; color: rgba(247,245,240,.8); line-height: 1.65;
}
.ai-no-key-notice code {
  font-family: var(--mono); font-size: .78rem; background: rgba(247,245,240,.1);
  padding: 2px 6px; border-radius: 4px;
}
/* input 非readonly化 */
.chat-input:not([readonly]) { cursor: text; }

/* ═══════════════════════════════════════════
   空き状況ナビゲーション（フロントページ）
═══════════════════════════════════════════ */
.room-avail-nav {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}
.room-avail-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 22px;
  border-radius: var(--card-r);
  background: var(--white);
  border: 1.5px solid rgba(14,15,17,.08);
  box-shadow: var(--sh-sm);
  text-decoration: none;
  transition: border-color .18s, transform .18s, box-shadow .18s;
}
.room-avail-card:hover {
  border-color: var(--accent);
  transform: translateY(-3px);
  box-shadow: var(--sh-md);
}
.room-avail-card-icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: rgba(37,99,255,.08);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; flex-shrink: 0;
}
.room-avail-card-body { flex: 1; min-width: 0; }
.room-avail-card-name { font-weight: 700; font-size: .95rem; color: var(--ink); margin-bottom: 3px; }
.room-avail-card-cap { font-size: .8rem; color: var(--ink-3); }
.room-avail-card-cta {
  font-size: .82rem; font-weight: 700; color: var(--accent);
  white-space: nowrap; flex-shrink: 0;
}
@media(max-width:640px) {
  .room-avail-nav { grid-template-columns: 1fr; }
  .room-avail-card { padding: 16px 18px; }
}

/* ═══════════════════════════════════════════
   週次カレンダー ナビゲーション リデザイン
═══════════════════════════════════════════ */

/* 予約済みレジェンドピルを非表示 */
.availability-legend { display: none !important; }

/* availability-head をシンプルに */
.availability-head {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 20px;
}
.availability-head > div:first-child { flex: 1; }

/* tools を横一列に */
.availability-tools {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

/* 週ナビ バー — 横一列レイアウト */
.availability-week-switcher {
  display: inline-flex;
  align-items: center;
  gap: 0;
  background: var(--white);
  border: 1.5px solid rgba(14,15,17,.1);
  border-radius: 999px;
  padding: 4px;
  box-shadow: var(--sh-sm);
  height: 44px;
}
.availability-week-switcher strong {
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink-2);
  padding: 0 12px;
  white-space: nowrap;
  letter-spacing: .02em;
  min-width: 160px;
  text-align: center;
}

/* 前週・次週ボタン */
.week-nav-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  padding: 0 16px;
  border-radius: 999px;
  font-size: .82rem;
  font-weight: 700;
  color: var(--ink);
  background: none;
  border: none;
  text-decoration: none;
  transition: background .15s, color .15s;
  white-space: nowrap;
  cursor: pointer;
}
.week-nav-btn:hover {
  background: var(--bg);
  color: var(--accent);
}

/* DatePicker ラップ — switcher の外に出す */
.cal-date-picker-wrap {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  background: var(--white);
  border: 1.5px solid rgba(14,15,17,.1);
  box-shadow: var(--sh-sm);
  cursor: pointer;
  transition: border-color .18s;
}
.cal-date-picker-wrap:hover { border-color: var(--accent); }
.cal-picker-icon { font-size: .95rem; flex-shrink: 0; }
.cal-date-picker {
  border: none;
  outline: none;
  font-family: var(--font);
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink-2);
  background: transparent;
  cursor: pointer;
  min-width: 110px;
  max-width: 120px;
}

/* 今週に戻るボタン */
.week-today-btn {
  display: inline-flex;
  align-items: center;
  height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  font-size: .8rem;
  font-weight: 700;
  color: var(--accent);
  background: rgba(37,99,255,.07);
  border: 1.5px solid rgba(37,99,255,.2);
  text-decoration: none;
  transition: background .15s;
  white-space: nowrap;
}
.week-today-btn:hover { background: rgba(37,99,255,.12); }

/* モバイル対応 */
@media(max-width:640px) {
  .availability-tools {
    gap: 8px;
  }
  .availability-week-switcher {
    width: 100%;
    justify-content: space-between;
    height: 44px;
    padding: 4px 6px;
  }
  .availability-week-switcher strong {
    font-size: .78rem;
    min-width: 0;
    flex: 1;
  }
  .week-nav-btn { padding: 0 12px; font-size: .8rem; }
  .cal-date-picker-wrap {
    width: 100%;
    justify-content: center;
    height: 44px;
  }
  .cal-date-picker { min-width: 140px; max-width: none; font-size: .85rem; }
  .week-today-btn { width: 100%; justify-content: center; }
}

/* DatePicker ラベルテキスト */
.cal-picker-label {
  font-size: .8rem;
  font-weight: 600;
  color: var(--ink-2);
  white-space: nowrap;
}
@media(max-width:640px) {
  .cal-picker-label { display: none; }
}

/* ═══════════════════════════════════════════
   HERO — 画像付きスプリットレイアウト
═══════════════════════════════════════════ */
.hero-split {
  padding: 52px 0 48px;
  position: relative;
  overflow: hidden;
  max-width: 100%;
  width: 100%;
}
.hero-split::before {
  content: '';
  position: absolute;
  right: -10%;
  top: -20%;
  width: 55%;
  height: 140%;
  background: linear-gradient(145deg, rgba(37,99,255,.04) 0%, transparent 60%);
  border-radius: 50%;
  pointer-events: none;
}
.hero-split-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}

/* ─ コピー側 ─ */
.hero-copy { min-width: 0; }
.hero-copy .hero-badge { margin-bottom: 20px; }
.hero-copy h1 {
  font-size: clamp(2.4rem, 4.2vw, 4.8rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -.05em;
  margin-bottom: 20px;
}
.hero-copy .hero-lead {
  font-size: .98rem;
  max-width: 480px;
  margin-bottom: 28px;
}
.hero-copy .hero-stats { margin-top: 32px; gap: 28px; }

/* ─ ビジュアル側 ─ */
.hero-visual-col { position: relative; }
.hero-visual-grid {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto;
  gap: 12px;
}
/* メイン画像 */
.hero-img-main {
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  aspect-ratio: 4/3;
  background: linear-gradient(135deg, #c7d8ff 0%, #d4e3ff 50%, #e8f0ff 100%);
  box-shadow: 0 20px 60px rgba(14,15,17,.12), 0 4px 16px rgba(14,15,17,.06);
}
.hero-img-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* バッジ */
.hero-img-badge {
  position: absolute;
  bottom: 14px;
  left: 14px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(14,15,17,.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: rgba(247,245,240,.9);
  font-size: .8rem;
  font-weight: 700;
  border: 1px solid rgba(247,245,240,.12);
}
/* サブ画像2枚 */
.hero-img-sub {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  width: 100%;
  min-width: 0;
  overflow: hidden;
}
.hero-img-thumb {
  border-radius: 16px;
  overflow: hidden;
  aspect-ratio: 3/2;
  min-width: 0;
  background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
  box-shadow: 0 8px 24px rgba(14,15,17,.08);
}
.hero-img-thumb:nth-child(2) {
  background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
}
.hero-img-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* プレースホルダー */
.hero-img-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 20px;
  text-align: center;
}
.hero-img-placeholder .placeholder-icon { font-size: 2.6rem; }
.hero-img-placeholder p {
  font-size: .78rem;
  color: rgba(14,15,17,.4);
  line-height: 1.5;
  margin: 0;
}
.hero-img-placeholder.small .placeholder-icon { font-size: 1.8rem; }
.hero-img-placeholder.small p { font-size: .72rem; }

/* 画像なし時は左右均等を崩す */
.hero-split:not(.has-image) .hero-split-inner {
  grid-template-columns: 1fr;
}
.hero-split:not(.has-image) .hero-visual-col { display: none; }
.hero-split:not(.has-image) .hero-copy h1 { font-size: clamp(2.8rem, 6vw, 5.6rem); }
.hero-split:not(.has-image) .hero-copy .hero-lead { max-width: 560px; }

/* ─ レスポンシブ ─ */
@media(max-width:1000px) {
  .hero-split-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .hero-copy h1 { font-size: clamp(2.4rem, 6vw, 4rem); }
  .hero-visual-col { order: -1; }
  .hero-img-main { aspect-ratio: 16/9; }
  .hero-split:not(.has-image) .hero-visual-col { display: none; }
}
@media(max-width:640px) {
  .hero-split { padding: 32px 0 28px; }
  .hero-copy h1 { font-size: 2.2rem; }
  .hero-copy .hero-lead { font-size: .92rem; }
  .hero-copy .hero-actions { flex-direction: column; gap: 10px; }
  .btn-hero-primary, .btn-hero-secondary { width: 100%; justify-content: center; }
  .hero-img-main { aspect-ratio: 16/9; border-radius: 16px; }
  .hero-img-thumb { border-radius: 12px; }
  .hero-img-badge { font-size: .74rem; padding: 6px 11px; }
}

/* ═══════════════════════════════════════════
   モバイル レイアウト修正 v9
═══════════════════════════════════════════ */

/* ── section-header 縦積み（モバイル） ──
   flex横並びのままだと h2 が極細になるため縦に切り替え */
@media(max-width:860px) {
  .section-header {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
  }
  .section-header > div { width: 100%; }
  .section-header .heading-lead,
  .section-header > p {
    max-width: 100% !important;
    font-size: .92rem;
  }
  /* section-titleも全幅に */
  .section-title {
    font-size: clamp(1.7rem, 5vw, 2.4rem) !important;
    line-height: 1.2 !important;
    letter-spacing: -.04em !important;
  }
  /* split-headingも縦積み */
  .split-heading {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
}

/* ── ヒーロー モバイル最適化 ── */
@media(max-width:1000px) {
  /* 画像ビジュアルはモバイルでは テキストの下 に出す */
  .hero-visual-col {
    order: 1 !important;   /* テキスト(order:0) の後ろ */
  }
  .hero-copy { order: 0; }
}

@media(max-width:640px) {
  /* ヒーロー全体 */
  .hero-split { padding: 24px 0 20px !important; }
  .hero-split-inner { gap: 20px !important; }

  /* コピー */
  .hero-copy h1 {
    font-size: clamp(1.9rem, 7vw, 2.4rem) !important;
    letter-spacing: -.04em !important;
    line-height: 1.15 !important;
  }
  .hero-copy .hero-lead {
    font-size: .88rem !important;
    line-height: 1.7 !important;
    margin-bottom: 20px !important;
  }
  .hero-badge { font-size: .72rem !important; margin-bottom: 14px !important; }
  .hero-copy .hero-actions {
    flex-direction: column !important;
    gap: 10px !important;
    margin-bottom: 20px !important;
  }
  .btn-hero-primary,
  .btn-hero-secondary { width: 100% !important; justify-content: center !important; }

  /* ステータス — 横並び・コンパクト */
  .hero-copy .hero-stats {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 0 !important;
    padding: 14px 0 !important;
    border-top: 1px solid rgba(14,15,17,.08) !important;
    border-bottom: 1px solid rgba(14,15,17,.08) !important;
    margin-top: 16px !important;
  }
  .hero-stat {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    padding: 8px 4px !important;
    border-right: 1px solid rgba(14,15,17,.08) !important;
  }
  .hero-stat:last-child { border-right: none !important; }
  .hero-stat strong {
    font-size: 1.35rem !important;
    letter-spacing: -.03em !important;
    line-height: 1 !important;
  }
  .hero-stat span {
    font-size: .68rem !important;
    margin-top: 4px !important;
    color: var(--ink-3) !important;
    line-height: 1.3 !important;
  }

  /* ビジュアル — メイン画像のみ表示、サブ非表示 */
  .hero-img-main {
    aspect-ratio: 16/9 !important;
    border-radius: 14px !important;
  }
  .hero-img-sub { display: none !important; }
  .hero-visual-grid { gap: 0 !important; }
  .hero-img-badge {
    font-size: .72rem !important;
    padding: 5px 10px !important;
    bottom: 10px !important;
    left: 10px !important;
  }
}

/* ═══════════════════════════════════════════
   ヒーロー モバイル — 3枚画像を上部に表示
═══════════════════════════════════════════ */
@media(max-width:1000px) {
  /* ビジュアルを上（テキストより先）に */
  .hero-split-inner {
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
  }
  .hero-visual-col {
    order: -1 !important;   /* 最上部 */
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;   /* clip: 同等、sticky は親に依存しない */
  }
  .hero-visual-grid {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
  .hero-copy { order: 1; }
}

@media(max-width:640px) {
  /* ── 3枚画像グリッド（モバイル用） ── */
  .hero-visual-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    gap: 8px !important;
  }
  /* メイン画像：16:9 全幅 */
  .hero-img-main {
    aspect-ratio: 16/9 !important;
    border-radius: 14px !important;
    grid-row: 1 !important;
  }
  /* サブ画像2枚：横並び・表示復活 */
  .hero-img-sub {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    grid-row: 2 !important;
    width: 100% !important;
    min-width: 0 !important;
  }
  .hero-img-thumb {
    min-width: 0 !important;
  }
  .hero-img-thumb {
    aspect-ratio: 4/3 !important;
    border-radius: 10px !important;
  }
  /* バッジ */
  .hero-img-badge {
    font-size: .72rem !important;
    padding: 5px 10px !important;
    bottom: 10px !important;
    left: 10px !important;
  }
  /* ビジュアルコルの余白 */
  .hero-visual-col {
    margin-bottom: 4px;
  }
}

/* ═══════════════════════════════════════════
   検索フィルター 結果メッセージ
═══════════════════════════════════════════ */
.search-result-msg {
  margin-top: 14px;
  padding: 11px 16px;
  border-radius: 10px;
  font-size: .88rem;
  font-weight: 600;
}
.search-result-msg.has-result {
  background: rgba(0,184,122,.08);
  color: #007a51;
  border: 1px solid rgba(0,184,122,.2);
}
.search-result-msg.no-result {
  background: rgba(245,166,35,.08);
  color: #92670a;
  border: 1px solid rgba(245,166,35,.25);
}
.room-card.search-hidden { display: none !important; }

/* カレンダーセクション（詳細ページ）上部余白を詰める */
.room-hero + .room-calendar-section,
.room-hero ~ .room-calendar-section:first-of-type {
  padding-top: 0;
}

/* ═══════════════════════════════════════════
   共有パネル
═══════════════════════════════════════════ */
.share-panel {
  padding: 48px 0;
}
.share-panel-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 20px;
}
.share-panel-header {
  margin-bottom: 20px;
}
.share-panel-title {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: -.02em;
  margin-bottom: 6px;
}
.share-icon-label { font-size: 1.1rem; }
.share-panel-sub {
  font-size: .84rem;
  color: var(--ink-3);
  margin-left: 28px;
}

/* コピーボタン群 */
.share-copy-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
}
.share-copy-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 18px;
  border-radius: 12px;
  border: 1.5px solid rgba(14,15,17,.12);
  background: var(--white);
  color: var(--ink);
  font-size: .86rem;
  font-weight: 600;
  cursor: pointer;
  transition: border-color .18s, background .18s, transform .15s;
  font-family: var(--font);
  box-shadow: var(--sh-sm);
}
.share-copy-btn:hover {
  border-color: var(--accent);
  background: rgba(37,99,255,.04);
  transform: translateY(-1px);
}
.share-copy-btn.copied {
  border-color: var(--green);
  background: rgba(0,184,122,.06);
  color: #007a51;
}
.share-btn-icon { font-size: 1rem; flex-shrink: 0; }
.share-btn-status {
  font-size: .75rem;
  font-weight: 700;
  color: var(--green);
  max-width: 0;
  overflow: hidden;
  white-space: nowrap;
  transition: max-width .25s ease, opacity .2s;
  opacity: 0;
}
.share-copy-btn.copied .share-btn-status {
  content: '✓ コピー済';
  max-width: 80px;
  opacity: 1;
}
.share-copy-btn.copied .share-btn-status::after {
  content: '✓ コピー済';
}

/* SNS共有 */
.share-sns-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 20px;
}
.share-sns-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 999px;
  font-size: .85rem;
  font-weight: 700;
  transition: transform .15s, opacity .18s;
  text-decoration: none;
}
.share-sns-btn:hover { transform: translateY(-1px); opacity: .88; }
.share-line  { background: #06C755; color: #fff; }
.share-x     { background: #000; color: #fff; }
.share-mail  { background: var(--ink); color: var(--bg); }
.share-gmap  { background: #EA4335; color: #fff; }

/* 埋め込みセクション */
.share-embed-section {
  border: 1.5px solid rgba(14,15,17,.09);
  border-radius: var(--card-r);
  background: var(--white);
  overflow: hidden;
  box-shadow: var(--sh-sm);
}
.share-embed-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  cursor: pointer;
  font-weight: 700;
  font-size: .9rem;
  list-style: none;
  user-select: none;
  transition: background .18s;
}
.share-embed-toggle::-webkit-details-marker { display: none; }
.share-embed-toggle:hover { background: rgba(14,15,17,.02); }
.embed-toggle-icon {
  font-size: 1.2rem;
  color: var(--ink-3);
  transition: transform .2s;
}
.share-embed-section[open] .embed-toggle-icon { transform: rotate(90deg); }
.share-embed-body {
  padding: 0 20px 20px;
  border-top: 1px solid rgba(14,15,17,.06);
}
.share-embed-desc {
  font-size: .84rem;
  color: var(--ink-2);
  line-height: 1.7;
  margin: 14px 0 16px;
}
.embed-preview-wrap {
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 16px;
  border: 1px solid rgba(14,15,17,.07);
  background: var(--bg);
}
.embed-code-wrap { }
.embed-code-label {
  font-size: .75rem;
  font-weight: 700;
  color: var(--ink-3);
  letter-spacing: .1em;
  margin-bottom: 8px;
}
.embed-code-box {
  background: var(--ink);
  border-radius: 12px;
  padding: 16px 18px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  overflow: hidden;
}
#embedCodeText {
  flex: 1;
  font-family: var(--mono);
  font-size: .76rem;
  color: rgba(247,245,240,.8);
  word-break: break-all;
  line-height: 1.7;
  white-space: pre-wrap;
}
.embed-copy-btn {
  flex-shrink: 0;
  background: rgba(247,245,240,.12) !important;
  border-color: rgba(247,245,240,.15) !important;
  color: rgba(247,245,240,.9) !important;
  padding: 8px 14px !important;
  font-size: .78rem !important;
}
.embed-copy-btn:hover {
  background: rgba(247,245,240,.2) !important;
  border-color: rgba(247,245,240,.25) !important;
}
.embed-seo-note {
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 10px;
  background: rgba(37,99,255,.05);
  border: 1px solid rgba(37,99,255,.15);
  font-size: .82rem;
  color: var(--ink-2);
  line-height: 1.65;
}
.embed-seo-note strong { color: var(--accent); }

@media(max-width:640px) {
  .share-copy-row { flex-direction: column; }
  .share-copy-btn { width: 100%; justify-content: flex-start; }
  .share-sns-row { gap: 8px; }
  .share-sns-btn { padding: 9px 14px; font-size: .8rem; }
  .share-embed-body { padding: 0 14px 16px; }
}

/* ═══════════════════════════════════════════
   記事デザイン完全リニューアル
═══════════════════════════════════════════ */

/* ── アイキャッチ（ヒーロー画像） ── */
.article-hero-media {
  aspect-ratio: 16/7 !important;
  border-radius: 0 !important;
  position: relative;
  overflow: hidden;
  background: var(--bg-2);
}
.article-hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .6s ease;
}

/* ── パンくずリスト ── */
.article-breadcrumbs {
  padding: 12px 28px !important;
  font-size: .78rem !important;
  color: var(--ink-3) !important;
  border-bottom: none !important;
  background: transparent;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
}
.article-breadcrumbs a {
  color: var(--ink-3) !important;
  transition: color .15s;
}
.article-breadcrumbs a:hover { color: var(--accent) !important; }
/* セパレータ > を付与 */
.article-breadcrumbs span + span::before,
.article-breadcrumbs a + a::before,
.article-breadcrumbs a + span::before,
.article-breadcrumbs span + a::before {
  content: '›';
  margin: 0 4px;
  color: var(--ink-3);
  opacity: .5;
}
/* WordPress標準パンくず */
.breadcrumb-trail,
nav.breadcrumb { font-size: .78rem; color: var(--ink-3); padding: 12px 28px; }

/* ── 記事ヘッダー ── */
.article-head {
  padding: 32px 40px 24px !important;
  border-bottom: none !important;
}
.article-head .post-meta {
  margin-bottom: 14px;
}
.article-head h1 {
  font-size: clamp(1.75rem, 3.2vw, 2.6rem) !important;
  line-height: 1.25 !important;
  letter-spacing: -.04em !important;
  margin: 0 0 16px !important;
  font-weight: 700;
}
.article-excerpt {
  margin: 0 !important;
  color: var(--ink-2);
  font-size: .96rem;
  line-height: 1.75;
  border-top: 1px solid rgba(14,15,17,.06);
  padding-top: 16px;
}

/* ── 記事本文エリア ── */
.article-content {
  padding: 32px 40px 48px !important;
  max-width: var(--article-max);
}

/* ── 目次 完全リデザイン ── */
.article-inline-toc {
  margin: 0 0 36px !important;
  background: var(--white) !important;
  border: 1.5px solid rgba(14,15,17,.09) !important;
  border-radius: var(--card-r) !important;
  overflow: hidden !important;
  box-shadow: var(--sh-sm) !important;
  padding: 0 !important;
}
/* 目次ヘッダー */
.article-inline-toc h3 {
  margin: 0 !important;
  font-size: .85rem !important;
  font-weight: 700 !important;
  color: var(--bg) !important;
  letter-spacing: .08em !important;
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  padding: 14px 22px !important;
  background: var(--ink) !important;
}
.article-inline-toc h3::before {
  content: '≡' !important;
  font-size: 1.1rem !important;
  opacity: .7 !important;
  display: inline !important;
  position: static !important;
  width: auto !important;
  height: auto !important;
  background: none !important;
  border-radius: 0 !important;
}
/* 目次リスト */
.article-inline-toc ol {
  margin: 0 !important;
  padding: 8px 0 !important;
  list-style: none !important;
  display: block !important;
  counter-reset: toc-h2 !important; /* h2専用カウンター */
  gap: 0 !important;
}
/* h2 アイテム */
.article-inline-toc li {
  counter-increment: toc-h2 !important; /* h2だけカウント */
  margin: 0 !important;
  border-top: 1px solid rgba(14,15,17,.04);
}
.article-inline-toc li:first-child { border-top: none; }
.article-inline-toc li a {
  display: flex !important;
  align-items: baseline !important;
  gap: 10px !important;
  padding: 9px 22px !important;
  color: var(--ink-2) !important;
  font-size: .87rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: background .14s, color .14s !important;
  border-left: 2.5px solid transparent !important;
}
/* h2の番号バッジ */
.article-inline-toc li a::before {
  content: counter(toc-h2) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 22px !important;
  height: 22px !important;
  border-radius: 6px !important;
  background: var(--bg) !important;
  color: var(--ink-3) !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  font-family: var(--mono) !important;
  flex-shrink: 0 !important;
}
.article-inline-toc li a:hover {
  background: rgba(37,99,255,.04) !important;
  color: var(--accent) !important;
  border-left-color: var(--accent) !important;
}
.article-inline-toc li a:hover::before {
  background: rgba(37,99,255,.1) !important;
  color: var(--accent) !important;
}
/* h3（level-3）: カウンター増加させず、バッジなし・インデント */
.article-inline-toc li.level-3 {
  counter-increment: none !important; /* ← カウンター増加しない */
  border-top: 1px solid rgba(14,15,17,.03) !important;
}
.article-inline-toc li.level-3 a {
  padding-left: 54px !important;
  font-size: .83rem !important;
  font-weight: 500 !important;
  color: var(--ink-3) !important;
}
.article-inline-toc li.level-3 a::before {
  display: none !important; /* h3には番号バッジなし */
}
.article-inline-toc li.level-3 a::after {
  content: '' !important;
  display: inline-block !important;
  width: 5px !important;
  height: 5px !important;
  border-radius: 50% !important;
  background: rgba(14,15,17,.2) !important;
  margin-right: 8px !important;
  order: -1 !important;
  flex-shrink: 0 !important;
  align-self: center !important;
}

/* コンパクト版も同様 */
.article-inline-toc-compact li.level-3 a {
  padding-left: 48px !important;
  font-size: .82rem !important;
}
.article-inline-toc-compact h3 { padding: 12px 18px !important; }
.article-inline-toc-compact li a { padding: 8px 18px !important; }

/* ── 記事本文 見出しデザイン ── */
.article-content h2 {
  font-size: 1.5rem !important;
  line-height: 1.38 !important;
  margin: 2.6em 0 1em !important;
  padding: 14px 18px !important;
  background: linear-gradient(135deg, rgba(37,99,255,.05) 0%, rgba(37,99,255,.02) 100%) !important;
  border-left: 4px solid var(--accent) !important;
  border-radius: 0 var(--card-r) var(--card-r) 0 !important;
  font-weight: 700 !important;
}
.article-content h2::after { display: none !important; }

.article-content h3 {
  font-size: 1.15rem !important;
  line-height: 1.45 !important;
  margin: 2em 0 .8em !important;
  padding: 0 0 .5em 14px !important;
  border-bottom: 1px solid rgba(14,15,17,.07) !important;
  font-weight: 700 !important;
}
.article-content h3::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important;
  top: .2em !important;
  bottom: 0 !important;
  width: 4px !important;
  height: auto !important;
  border-radius: 999px !important;
  background: var(--accent) !important;
}

/* ── 記事の段落・リスト ── */
.article-content p { font-size: .97rem !important; line-height: 2 !important; }
.article-content ul li, .article-content ol li { line-height: 1.85 !important; }

/* ── サイドバー ── */
.article-sidebar .sidebar-card h3 { font-size: .9rem !important; }

/* ── モバイル ── */
@media(max-width:640px) {
  .article-head { padding: 20px 18px 18px !important; }
  .article-head h1 { font-size: 1.5rem !important; }
  .article-content { padding: 24px 18px 36px !important; }
  .article-breadcrumbs { padding: 10px 18px !important; }
  .article-inline-toc li a { padding: 9px 16px !important; }
  .article-inline-toc li.level-3 a { padding-left: 38px !important; }
  .article-inline-toc h3 { padding: 12px 16px !important; }
  .article-content h2 { font-size: 1.25rem !important; padding: 11px 14px !important; }
  .article-content h3 { font-size: 1.05rem !important; }
}

/* ═══════════════════════════════════════════
   SpaceMarket 風ギャラリーグリッド
═══════════════════════════════════════════ */
.room-gallery-spacemarket {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr;
  gap: 6px;
  border-radius: 20px;
  overflow: hidden;
  height: 420px;
  background: var(--bg-2);
}
/* メイン画像（左半分・全高） */
.rg-main {
  grid-column: 1;
  grid-row: 1;
  overflow: hidden;
  cursor: zoom-in;
  background: var(--bg-2);
}
.rg-main img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .45s ease;
}
.rg-main:hover img { transform: scale(1.03); }
/* サブグリッド（右半分・2×2） */
.rg-sub-grid {
  grid-column: 2;
  grid-row: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 6px;
}
/* サブ画像1枚の時 — 全幅 */
.rg-sub-1 { grid-template-columns: 1fr; grid-template-rows: 1fr; }
/* サブ画像2枚の時 — 縦2枚 */
.rg-sub-2 { grid-template-columns: 1fr; grid-template-rows: 1fr 1fr; }
/* サブ画像3枚の時 — 右上1枚＋下2枚 */
.rg-sub-3 .rg-sub-cell:first-child { grid-column: 1 / -1; }

.rg-sub-cell {
  overflow: hidden;
  cursor: zoom-in;
  position: relative;
  background: var(--bg-2);
}
.rg-sub-cell img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}
.rg-sub-cell:hover img { transform: scale(1.05); }
.rg-sub-empty { cursor: default; background: var(--bg-2); }
/* プレースホルダー */
.rg-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem; color: rgba(14,15,17,.15);
}
/* 枚数が多い場合のオーバーレイ */
.rg-more-overlay {
  position: absolute;
  right: 10px;
  bottom: 10px;
  background: rgba(14,15,17,.72);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 999px;
  color: #fff;
  font-size: .82rem;
  font-weight: 700;
  padding: 6px 13px;
  display: inline-flex;
  align-items: center;
  pointer-events: none;
  z-index: 3;
}
/* 枚数バッジボタン */
.rg-count-btn {
  position: absolute;
  right: 16px; bottom: 16px;
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px;
  background: rgba(14,15,17,.72);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 999px;
  color: #fff;
  font-size: .82rem; font-weight: 700;
  cursor: pointer;
  transition: background .18s;
  z-index: 3;
}
.rg-count-btn:hover { background: rgba(14,15,17,.88); }

/* ═══ ライトボックス ═══ */
.rg-lightbox {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(10,10,12,.96);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 0;
  overscroll-behavior: contain;
}
.rg-lightbox[hidden] { display: none; }
.rg-lb-close {
  position: absolute; top: 18px; right: 22px;
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2);
  color: #fff; font-size: 1.1rem;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; z-index: 2;
  transition: background .18s;
}
.rg-lb-close:hover { background: rgba(255,255,255,.24); }
.rg-lb-stage {
  flex: 1;
  display: flex; align-items: center; justify-content: center;
  width: 100%; position: relative;
  padding: 60px 80px 0;
}
.rg-lb-img {
  max-width: 100%; max-height: 72vh;
  object-fit: contain;
  border-radius: 10px;
  box-shadow: 0 24px 60px rgba(0,0,0,.6);
  display: block;
  user-select: none;
}
.rg-lb-counter {
  position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%);
  color: rgba(255,255,255,.55); font-size: .78rem; font-family: var(--mono);
  letter-spacing: .1em;
}
.rg-lb-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 50px; height: 50px; border-radius: 50%;
  background: rgba(255,255,255,.1); border: 1.5px solid rgba(255,255,255,.2);
  color: #fff; font-size: 2rem; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; z-index: 2;
  transition: background .18s;
}
.rg-lb-nav:hover { background: rgba(255,255,255,.22); }
.rg-lb-prev { left: 18px; }
.rg-lb-next { right: 18px; }
/* サムネイル帯 */
.rg-lb-thumbs {
  display: flex; gap: 8px;
  padding: 16px 20px;
  overflow-x: auto;
  max-width: 100%;
  scroll-behavior: smooth;
  -ms-overflow-style: none; scrollbar-width: none;
}
.rg-lb-thumbs::-webkit-scrollbar { display: none; }
.rg-lb-thumb {
  width: 64px; height: 48px; border-radius: 8px; flex-shrink: 0;
  background-size: cover; background-position: center;
  border: 2.5px solid transparent;
  cursor: pointer; transition: border-color .18s, opacity .18s;
  opacity: .55;
}
.rg-lb-thumb.is-active { border-color: #fff; opacity: 1; }
.rg-lb-thumb:hover { opacity: .85; }

/* モバイル */
@media(max-width:860px) {
  .room-gallery-spacemarket { height: 320px; border-radius: 16px; }
  .rg-lb-stage { padding: 50px 60px 0; }
  .rg-lb-nav { width: 40px; height: 40px; font-size: 1.6rem; }
  .rg-lb-prev { left: 10px; }
  .rg-lb-next { right: 10px; }
}
@media(max-width:640px) {
  .room-gallery-spacemarket {
    grid-template-columns: 1fr;
    height: 280px;
    border-radius: 14px;
  }
  /* モバイルではメイン1枚のみ、サブグリッド非表示 */
  .rg-sub-grid { display: none; }
  .rg-main { grid-column: 1; }
  .rg-lb-stage { padding: 44px 44px 0; }
  .rg-lb-thumb { width: 52px; height: 40px; }
}

/* ═══════════════════════════════════════════
   Room Hero v2 — コピー上・ギャラリー全幅下
═══════════════════════════════════════════ */
.room-hero-v2 { padding: 40px 0 0 !important; }

.room-hero-head {
  padding-bottom: 24px;
}
.room-hero-head .eyebrow { margin-bottom: 6px; }
.room-hero-head h1 {
  font-size: clamp(2rem, 4vw, 3.4rem);
  font-weight: 700;
  letter-spacing: -.05em;
  line-height: 1.1;
  margin-bottom: 14px;
}
.room-hero-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.room-meta-chip {
  display: inline-flex;
  align-items: center;
  padding: 5px 14px;
  border-radius: 999px;
  background: rgba(14,15,17,.06);
  border: 1px solid rgba(14,15,17,.1);
  font-size: .85rem;
  font-weight: 600;
  color: var(--ink-2);
}

.room-hero-gallery-wrap {
  width: 100%;
  padding-bottom: 20px;
}
.room-hero-gallery-wrap .container {
  /* コンテナ内でギャラリーを最大幅に */
}

/* ── SpaceMarket 風ギャラリー（フル幅版）
   PC: メイン左大 + サブ右3段縦並び
   モバイル: メイン上 + サブ下3枚横並び
── */
.room-gallery-spacemarket {
  display: grid !important;
  grid-template-columns: 63% 37% !important;
  grid-template-rows: 460px !important;
  gap: 6px !important;
  border-radius: 20px !important;
  overflow: hidden !important;
  background: var(--bg-2) !important;
  height: auto !important;
}
.rg-main {
  grid-column: 1 !important;
  grid-row: 1 !important;
  height: 460px !important;
}
/* サブグリッド: 縦1列・3段 */
.rg-sub-grid {
  grid-column: 2 !important;
  grid-row: 1 !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  grid-template-rows: 1fr 1fr 1fr !important;
  gap: 6px !important;
  height: 460px !important;
}
.rg-sub-cell { height: 100% !important; }
.rg-sub-1 { grid-template-rows: 1fr !important; }
.rg-sub-2 { grid-template-rows: 1fr 1fr !important; }
.rg-sub-3 { grid-template-rows: 1fr 1fr 1fr !important; }
/* 横2列レイアウト時の名残を解除 */
.rg-sub-3 .rg-sub-cell:first-child { grid-column: auto !important; }

/* ── ライトボックス修正（完全前面・スクロール防止） ── */
.rg-lightbox {
  position: fixed !important;
  inset: 0 !important;
  z-index: 99999 !important;
  background: rgba(8,8,10,.95) !important;
  display: grid !important;
  grid-template-rows: 1fr auto !important;
  grid-template-columns: 56px 1fr 56px !important;
  align-items: center !important;
  justify-items: center !important;
}
.rg-lightbox[hidden] { display: none !important; }
.rg-lb-close {
  position: fixed !important;
  top: 16px !important;
  right: 16px !important;
  z-index: 100000 !important;
  width: 42px !important; height: 42px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.15) !important;
  border: 1.5px solid rgba(255,255,255,.25) !important;
  color: #fff !important; font-size: 1.1rem !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  cursor: pointer !important;
  transition: background .18s !important;
}
.rg-lb-close:hover { background: rgba(255,255,255,.28) !important; }
.rg-lb-stage {
  grid-column: 2 !important;
  grid-row: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 100% !important;
  padding: 16px 0 !important;
  position: relative !important;
}
.rg-lb-img {
  max-width: 100% !important;
  max-height: calc(100vh - 140px) !important;
  object-fit: contain !important;
  border-radius: 8px !important;
  box-shadow: 0 20px 60px rgba(0,0,0,.7) !important;
  display: block !important;
  user-select: none !important;
}
.rg-lb-counter {
  position: absolute !important;
  bottom: -4px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  color: rgba(255,255,255,.45) !important;
  font-size: .74rem !important;
  font-family: var(--mono) !important;
  letter-spacing: .1em !important;
  white-space: nowrap !important;
}
.rg-lb-nav {
  position: static !important;
  transform: none !important;
  width: 44px !important; height: 44px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.12) !important;
  border: 1.5px solid rgba(255,255,255,.2) !important;
  color: #fff !important; font-size: 1.8rem !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  cursor: pointer !important; z-index: 2 !important;
  transition: background .18s !important;
}
.rg-lb-nav:hover { background: rgba(255,255,255,.24) !important; }
.rg-lb-prev { grid-column: 1 !important; grid-row: 1 !important; }
.rg-lb-next { grid-column: 3 !important; grid-row: 1 !important; }
.rg-lb-thumbs {
  grid-column: 1 / -1 !important;
  grid-row: 2 !important;
  display: flex !important;
  gap: 8px !important;
  padding: 12px 20px !important;
  overflow-x: auto !important;
  max-width: 100% !important;
  scroll-behavior: smooth !important;
  -ms-overflow-style: none !important;
  scrollbar-width: none !important;
  justify-content: center !important;
}
.rg-lb-thumbs::-webkit-scrollbar { display: none; }
.rg-lb-thumb {
  width: 64px !important; height: 48px !important;
  border-radius: 6px !important; flex-shrink: 0 !important;
  background-size: cover !important; background-position: center !important;
  border: 2.5px solid transparent !important;
  cursor: pointer !important;
  transition: border-color .18s, opacity .18s !important;
  opacity: .5 !important;
}
.rg-lb-thumb.is-active { border-color: #fff !important; opacity: 1 !important; }
.rg-lb-thumb:hover { opacity: .8 !important; }

/* モバイル */
@media(max-width:860px) {
  .room-gallery-spacemarket {
    grid-template-columns: 60% 40% !important;
    grid-template-rows: 320px !important;
  }
  .rg-main { height: 320px !important; }
  .rg-sub-grid {
    height: 320px !important;
    grid-template-rows: 1fr 1fr 1fr !important;
    gap: 5px !important;
  }
}
@media(max-width:640px) {
  .room-hero-v2 { padding: 24px 0 0 !important; }
  /* モバイル: メイン上 + サブ3枚横並び */
  .room-gallery-spacemarket {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    height: auto !important;
    border-radius: 14px !important;
    gap: 4px !important;
  }
  .rg-main {
    grid-column: 1 !important;
    grid-row: 1 !important;
    height: 52vw !important;
    min-height: 200px !important;
    max-height: 320px !important;
  }
  /* サブグリッド: モバイルは横3列 */
  .rg-sub-grid {
    grid-column: 1 !important;
    grid-row: 2 !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr !important;
    grid-template-rows: 28vw !important;
    height: auto !important;
    min-height: 100px !important;
    max-height: 180px !important;
    gap: 4px !important;
  }
  .rg-sub-1 { grid-template-columns: 1fr !important; }
  .rg-sub-2 { grid-template-columns: 1fr 1fr !important; }
  .rg-sub-3 { grid-template-columns: 1fr 1fr 1fr !important; }
  .rg-sub-cell { height: 100% !important; }
  .rg-lb-nav { width: 36px !important; height: 36px !important; font-size: 1.4rem !important; }
  /* 枚数バッジ位置調整（メイン右下） */
  .rg-count-btn { right: 10px !important; bottom: 10px !important; }
}

/* ═══════════════════════════════════════════
   ライトボックス 完全修正版
═══════════════════════════════════════════ */

/* ライトボックス本体 — 初期は非表示 */
.rg-lightbox {
  display: none !important; /* 常に非表示（is-openで表示） */
  position: fixed !important;
  inset: 0 !important;
  z-index: 999999 !important;
}
.rg-lightbox.is-open {
  display: flex !important;
  align-items: stretch !important;
  justify-content: center !important;
}

/* 背景オーバーレイ */
.rg-lb-overlay {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(8,8,10,.97) !important;
  z-index: 0 !important;
  cursor: default !important;
}

/* メインパネル */
.rg-lb-panel {
  position: relative !important;
  z-index: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 1200px !important;
}

/* ツールバー（上部：枚数＋閉じるボタン） */
.rg-lb-toolbar {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 14px 20px !important;
  flex-shrink: 0 !important;
}
.rg-lb-counter-top {
  color: rgba(255,255,255,.5) !important;
  font-size: .8rem !important;
  font-family: var(--mono) !important;
  letter-spacing: .1em !important;
}
.rg-lb-close {
  position: static !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 8px 16px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.1) !important;
  border: 1.5px solid rgba(255,255,255,.18) !important;
  color: rgba(255,255,255,.9) !important;
  font-size: .85rem !important;
  font-weight: 700 !important;
  font-family: var(--font) !important;
  cursor: pointer !important;
  transition: background .18s !important;
  width: auto !important;
  height: auto !important;
}
.rg-lb-close:hover {
  background: rgba(255,255,255,.2) !important;
}

/* 画像エリア */
.rg-lb-stage {
  flex: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  padding: 0 16px !important;
  min-height: 0 !important;
  position: relative !important;
}
.rg-lb-img-wrap {
  flex: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
}
.rg-lb-img {
  max-width: 100% !important;
  max-height: calc(100vh - 170px) !important;
  object-fit: contain !important;
  border-radius: 8px !important;
  box-shadow: 0 20px 60px rgba(0,0,0,.6) !important;
  display: block !important;
  user-select: none !important;
}

/* ナビボタン */
.rg-lb-nav {
  flex-shrink: 0 !important;
  width: 48px !important;
  height: 48px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.08) !important;
  border: 1.5px solid rgba(255,255,255,.15) !important;
  color: rgba(255,255,255,.8) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  transition: background .18s !important;
  position: static !important;
  transform: none !important;
  font-size: 1rem !important;
}
.rg-lb-nav:hover { background: rgba(255,255,255,.18) !important; }
.rg-lb-prev { margin-right: 12px !important; }
.rg-lb-next { margin-left: 12px !important; }

/* サムネイル帯 */
.rg-lb-thumbs {
  display: flex !important;
  gap: 8px !important;
  padding: 14px 20px !important;
  overflow-x: auto !important;
  scroll-behavior: smooth !important;
  -ms-overflow-style: none !important;
  scrollbar-width: none !important;
  flex-shrink: 0 !important;
  justify-content: center !important;
}
.rg-lb-thumbs::-webkit-scrollbar { display: none; }
.rg-lb-thumb {
  width: 64px !important;
  height: 48px !important;
  border-radius: 6px !important;
  flex-shrink: 0 !important;
  background-size: cover !important;
  background-position: center !important;
  border: 2.5px solid transparent !important;
  cursor: pointer !important;
  transition: border-color .18s, opacity .18s !important;
  opacity: .45 !important;
}
.rg-lb-thumb.is-active {
  border-color: #fff !important;
  opacity: 1 !important;
}
.rg-lb-thumb:hover { opacity: .8 !important; }

/* モバイル */
@media(max-width:640px) {
  .rg-lb-nav { width: 40px !important; height: 40px !important; }
  .rg-lb-prev { margin-right: 6px !important; }
  .rg-lb-next { margin-left: 6px !important; }
  .rg-lb-img { max-height: calc(100vh - 160px) !important; }
  .rg-lb-thumb { width: 52px !important; height: 40px !important; }
  .rg-lb-close { font-size: .8rem !important; padding: 7px 12px !important; }
}

/* ライトボックス body直下移動後の確実な前面表示 */
body > .rg-lightbox.is-open {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  z-index: 2147483647 !important; /* int最大値 */
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
}
body > .rg-lightbox.is-open .rg-lb-overlay {
  position: fixed !important;
  inset: 0 !important;
  z-index: 0 !important;
}
body > .rg-lightbox.is-open .rg-lb-panel {
  position: relative !important;
  z-index: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  height: 100% !important;
}

/* ═══════════════════════════════════════════
   ギャラリー右下 料金＋予約ボタン
═══════════════════════════════════════════ */
.rg-reserve-bar {
  position: absolute;
  left: 16px;
  bottom: 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  z-index: 4;
  flex-wrap: wrap;
}
.rg-price {
  display: flex;
  flex-direction: column;
  background: rgba(14,15,17,.68);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px;
  padding: 7px 14px;
  color: #fff;
  line-height: 1.2;
}
.rg-price strong {
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: -.02em;
}
.rg-price span {
  font-size: .72rem;
  opacity: .7;
  margin-top: 1px;
}
.rg-reserve-btn {
  display: inline-flex;
  align-items: center;
  padding: 11px 22px;
  border-radius: 999px;
  background: var(--ink);
  color: var(--bg);
  font-size: .88rem;
  font-weight: 700;
  text-decoration: none;
  border: 2px solid rgba(255,255,255,.15);
  box-shadow: 0 4px 20px rgba(14,15,17,.4);
  transition: background .18s, transform .15s;
  white-space: nowrap;
}
.rg-reserve-btn:hover {
  background: #1a1c20;
  transform: translateY(-1px);
}

/* ─── モバイル ライトボックス完全対応 ─── */
@media(max-width:640px) {
  /* ギャラリー 料金バー */
  .rg-reserve-bar {
    left: 10px;
    bottom: 10px;
    gap: 8px;
  }
  .rg-price { padding: 5px 10px; }
  .rg-price strong { font-size: 1rem; }
  .rg-reserve-btn { padding: 9px 16px; font-size: .82rem; }

  /* モバイル ライトボックス */
  body > .rg-lightbox.is-open .rg-lb-panel {
    justify-content: space-between !important;
  }
  body > .rg-lightbox.is-open .rg-lb-stage {
    padding: 0 8px !important;
    flex: 1 !important;
  }
  body > .rg-lightbox.is-open .rg-lb-img {
    max-height: calc(100svh - 130px) !important;
  }
  body > .rg-lightbox.is-open .rg-lb-nav {
    width: 36px !important;
    height: 36px !important;
    flex-shrink: 0 !important;
  }
  body > .rg-lightbox.is-open .rg-lb-prev { margin-right: 4px !important; }
  body > .rg-lightbox.is-open .rg-lb-next { margin-left: 4px !important; }
  body > .rg-lightbox.is-open .rg-lb-thumbs {
    padding: 10px 12px !important;
    gap: 6px !important;
  }
  body > .rg-lightbox.is-open .rg-lb-thumb {
    width: 48px !important;
    height: 36px !important;
  }
  body > .rg-lightbox.is-open .rg-lb-toolbar {
    padding: 10px 14px !important;
  }
  body > .rg-lightbox.is-open .rg-lb-close {
    padding: 6px 12px !important;
    font-size: .78rem !important;
  }
  /* 枚数バッジ：モバイルでも表示（タップで写真一覧モーダルを開く） */
  .rg-count-btn { display: inline-flex !important; }
}

/* ═══════════════════════════════════════════
   SpaceMarket風ギャラリー v2
   PC: 左大1枚 + 右2×2グリッド
   スマホ: 上1枚全幅 + 下3枚横並び
═══════════════════════════════════════════ */

/* PC レイアウトはそのまま維持 */

/* ─ ギャラリー下の料金・予約バー ─ */
.rg-below-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 0 8px;
  flex-wrap: wrap;
}
.rg-below-price {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.rg-below-price-label {
  font-size: .72rem;
  font-weight: 700;
  color: var(--ink-3);
  letter-spacing: .1em;
  font-family: var(--mono);
}
.rg-below-price strong {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.02em;
}
.rg-below-reserve-btn {
  display: inline-flex;
  align-items: center;
  padding: 13px 28px;
  border-radius: 999px;
  background: var(--ink);
  color: var(--bg);
  font-size: .92rem;
  font-weight: 700;
  text-decoration: none;
  transition: background .18s, transform .15s;
  white-space: nowrap;
}
.rg-below-reserve-btn:hover {
  background: #1a1c20;
  transform: translateY(-1px);
}

/* ─ スマホ用ギャラリー: 上1枚全幅 + 下3枚横並び ─ */
@media(max-width:640px) {
  .room-gallery-spacemarket {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    height: auto !important;
    border-radius: 0 !important;
    gap: 3px !important;
  }
  /* メイン画像：全幅・16:9 */
  .rg-main {
    grid-column: 1 !important;
    grid-row: 1 !important;
    height: 56vw !important;
    min-height: 220px !important;
    max-height: 320px !important;
    border-radius: 0 !important;
  }
  /* サブグリッド：下段に3枚横並び */
  .rg-sub-grid {
    display: grid !important;
    grid-column: 1 !important;
    grid-row: 2 !important;
    grid-template-columns: repeat(3, 1fr) !important;
    grid-template-rows: 1fr !important;
    height: 28vw !important;
    min-height: 100px !important;
    max-height: 160px !important;
    border-radius: 0 !important;
  }
  /* サブ枚数が4枚の場合も3列で表示（4枚目は3列目） */
  .rg-sub-3 .rg-sub-cell:first-child { grid-column: auto !important; }
  /* 4枚目（index 3）は非表示 */
  .rg-sub-4 .rg-sub-cell:nth-child(4) { display: none !important; }
  .rg-sub-cell { border-radius: 0 !important; height: 100% !important; }
  /* 画像の下バー */
  .rg-below-bar {
    padding: 12px 0 4px;
  }
  .rg-below-price strong { font-size: 1.1rem; }
  .rg-below-reserve-btn {
    flex: 1;
    justify-content: center;
    padding: 12px 20px;
    font-size: .88rem;
  }
}

/* ─ ギャラリー内 rg-reserve-bar（もし残っていれば非表示） ─ */
.rg-reserve-bar { display: none !important; }

/* ═══════════════════════════════════════════
   料金 + 予約ボタン 統合カード
═══════════════════════════════════════════ */
.rg-reserve-card {
  display: flex;
  align-items: stretch;   /* ← 両カラムを同じ高さに */
  gap: 0;
  background: var(--white);
  border: 1.5px solid rgba(14,15,17,.1);
  border-radius: 22px;
  box-shadow: 0 4px 24px rgba(14,15,17,.08), 0 1px 4px rgba(14,15,17,.04);
  margin-top: 14px;
  overflow: hidden;
  width: 100%;           /* ← 全幅 */
}

/* ── 料金ブロック（左） ── */
.rg-rc-price-block {
  flex: 0 0 auto;
  padding: 24px 32px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  min-width: 0;
}
.rg-rc-price-main {
  display: flex;
  align-items: baseline;
  gap: 0;
  flex-wrap: wrap;
}
.rg-rc-price-val {
  font-size: clamp(1.2rem, 2vw, 1.55rem);
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.03em;
  line-height: 1.2;
}
.rg-rc-price-note {
  font-size: .74rem;
  color: var(--ink-3);
  line-height: 1.5;
  margin: 0;
}

/* ── 仕切り ── */
.rg-rc-divider {
  width: 1px;
  align-self: stretch;
  background: rgba(14,15,17,.08);
  flex-shrink: 0;
  margin: 16px 0;
}

/* ── 予約アクションブロック（右） ── */
.rg-rc-action-block {
  flex: 1;
  min-width: 0;          /* ← はみ出し防止 */
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
}
.rg-rc-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.rg-rc-chip {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: 999px;
  background: var(--bg);
  border: 1px solid rgba(14,15,17,.09);
  font-size: .78rem;
  font-weight: 600;
  color: var(--ink-2);
}
.rg-rc-reserve-btn {
  display: flex;          /* ← inline-flex → flex で全幅に */
  align-items: center;
  justify-content: center;
  gap: 9px;
  padding: 15px 24px;
  border-radius: 14px;
  background: var(--ink);
  color: var(--bg);
  font-size: .95rem;
  font-weight: 700;
  text-decoration: none;
  transition: background .18s, transform .15s, box-shadow .18s;
  box-shadow: 0 4px 14px rgba(14,15,17,.18);
  width: 100%;            /* ← 全幅 */
}
.rg-rc-reserve-btn:hover {
  background: #1a1c20;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(14,15,17,.22);
}
.rg-rc-reserve-btn svg {
  flex-shrink: 0;
  opacity: .75;
}
.rg-rc-sub {
  font-size: .76rem;
  color: var(--ink-3);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 6px;
}
.rg-rc-sub::before {
  content: '✓';
  color: var(--green);
  font-weight: 700;
  font-size: .8rem;
}

/* モバイル */
@media(max-width:720px) {
  .rg-reserve-card {
    flex-direction: column;
    gap: 0;
    border-radius: 18px;
  }
  .rg-rc-price-block {
    width: 100%;
    padding: 20px 22px 16px;
    min-width: 0;
    border-bottom: 1px solid rgba(14,15,17,.08);
  }
  .rg-rc-divider { display: none; }
  .rg-rc-action-block {
    width: 100%;
    padding: 16px 22px 20px;
  }
  .rg-rc-reserve-btn {
    width: 100%;
    justify-content: center;
    padding: 15px;
  }
}

/* ═══════════════════════════════════════════
   料金＋予約カード SpaceMarket風リデザイン
═══════════════════════════════════════════ */
.rg-reserve-card {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 24px !important;
  background: var(--white) !important;
  border: 1.5px solid rgba(14,15,17,.1) !important;
  border-radius: 18px !important;
  box-shadow: 0 2px 16px rgba(14,15,17,.07) !important;
  margin-top: 14px !important;
  padding: 18px 24px !important;
  overflow: visible !important;
  width: 100% !important;
}
/* 左：料金＋チップ */
.rg-rc-left {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
}
.rg-rc-price-val {
  font-size: clamp(1.15rem, 2vw, 1.45rem) !important;
  font-weight: 700 !important;
  color: var(--ink) !important;
  letter-spacing: -.03em !important;
  line-height: 1.2 !important;
}
.rg-rc-chips {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
}
.rg-rc-chip {
  display: inline-flex !important;
  align-items: center !important;
  padding: 3px 10px !important;
  border-radius: 999px !important;
  background: var(--bg) !important;
  border: 1px solid rgba(14,15,17,.09) !important;
  font-size: .75rem !important;
  font-weight: 600 !important;
  color: var(--ink-2) !important;
}
/* 右：ボタン */
.rg-rc-right {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
}
.rg-rc-reserve-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 13px 24px !important;
  border-radius: 12px !important;
  background: var(--green) !important;
  color: #fff !important;
  font-size: .92rem !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  transition: background .18s, transform .15s !important;
  box-shadow: 0 4px 14px rgba(0,184,122,.25) !important;
  width: auto !important;
}
.rg-rc-reserve-btn:hover {
  background: #008858 !important;
  transform: translateY(-1px) !important;
}
.rg-rc-sub {
  font-size: .73rem !important;
  color: var(--ink-3) !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  white-space: nowrap !important;
}
.rg-rc-sub::before {
  content: '✓' !important;
  color: var(--green) !important;
  font-weight: 700 !important;
}
/* 旧クラスは非表示 */
.rg-rc-price-block, .rg-rc-action-block, .rg-rc-divider,
.rg-rc-price-main, .rg-rc-price-note { display: none !important; }

/* モバイル */
@media(max-width:640px) {
  .rg-reserve-card {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 14px !important;
    padding: 16px 18px !important;
  }
  .rg-rc-right { align-items: stretch !important; }
  .rg-rc-reserve-btn { width: 100% !important; padding: 14px !important; }
  .rg-rc-sub { justify-content: center !important; }
}

/* ═══════════════════════════════════════════
   OVERVIEW セクション リデザイン
═══════════════════════════════════════════ */
.room-overview-section { padding-top: 0; }

/* ── スペックバー（横並びチップ） ── */
.ov-spec-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 20px 0 28px;
  border-bottom: 1px solid rgba(14,15,17,.07);
  margin-bottom: 32px;
}
.ov-spec-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: var(--white);
  border: 1px solid rgba(14,15,17,.09);
  border-radius: 12px;
  box-shadow: var(--sh-sm);
}
.ov-spec-icon { font-size: 1rem; flex-shrink: 0; }
.ov-spec-body { display: flex; flex-direction: column; gap: 1px; }
.ov-spec-label { font-size: .66rem; color: var(--ink-3); font-weight: 700; letter-spacing: .08em; font-family: var(--mono); }
.ov-spec-val   { font-size: .85rem; font-weight: 700; color: var(--ink); line-height: 1.2; }

/* ── 2カラムグリッド ── */
.ov-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 28px;
  align-items: start;
}

/* ── 左：説明文ブロック ── */
.ov-intro { margin-bottom: 28px; }
.ov-title {
  font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  font-weight: 700;
  letter-spacing: -.04em;
  line-height: 1.3;
  margin: 8px 0 14px;
}
.ov-text {
  color: var(--ink-2);
  font-size: .95rem;
  line-height: 1.85;
  margin: 0;
}

/* ── 設備 ── */
.ov-facilities { margin-bottom: 24px; }
.ov-block-label {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--ink-3);
  margin-bottom: 10px;
  font-family: var(--mono);
}
.ov-facility-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  list-style: none;
  padding: 0; margin: 0;
}
.ov-facility-list li {
  display: inline-flex;
  align-items: center;
  padding: 5px 12px;
  background: var(--bg);
  border: 1px solid rgba(14,15,17,.08);
  border-radius: 999px;
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink-2);
}

/* ── 注意書き ── */
.ov-note {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 12px 14px;
  border-radius: 10px;
  background: rgba(245,166,35,.06);
  border: 1px solid rgba(245,166,35,.2);
  font-size: .84rem;
  color: var(--ink-2);
  line-height: 1.65;
  margin-bottom: 24px;
}
.ov-note svg { flex-shrink: 0; margin-top: 2px; color: var(--amber); }

/* ── ボタン ── */
.ov-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 8px;
}
.ov-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 24px;
  border-radius: 12px;
  background: var(--green);
  color: #fff;
  font-size: .92rem;
  font-weight: 700;
  text-decoration: none;
  transition: background .18s, transform .15s;
  box-shadow: 0 4px 14px rgba(0,184,122,.25);
}
.ov-btn-primary:hover { background: #008858; transform: translateY(-1px); }
.ov-btn-secondary {
  display: inline-flex;
  align-items: center;
  font-size: .85rem;
  font-weight: 700;
  color: var(--ink-3);
  text-decoration: none;
  transition: color .18s;
}
.ov-btn-secondary:hover { color: var(--ink); }

/* ── 右：利用シーンカード ── */
.ov-side {
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: sticky;
  top: 90px;
}
.ov-scenes-card {
  background: var(--white);
  border: 1px solid rgba(14,15,17,.08);
  border-radius: var(--card-r);
  overflow: hidden;
  box-shadow: var(--sh-sm);
}
.ov-scenes-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 18px;
  background: var(--ink);
  color: var(--bg);
  font-size: .85rem;
  font-weight: 700;
}
.ov-scenes-icon { font-size: 1rem; }
.ov-scenes-list {
  list-style: none;
  padding: 12px 0;
  margin: 0;
}
.ov-scenes-list li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 9px 18px;
  font-size: .88rem;
  color: var(--ink-2);
  border-top: 1px solid rgba(14,15,17,.04);
  line-height: 1.5;
}
.ov-scenes-list li:first-child { border-top: none; }
.ov-scenes-list li::before {
  content: '✓';
  color: var(--green);
  font-weight: 700;
  font-size: .78rem;
  flex-shrink: 0;
  margin-top: 2px;
}
.ov-readme-card {
  background: rgba(37,99,255,.04);
  border: 1px solid rgba(37,99,255,.15);
  border-radius: var(--card-r);
  padding: 16px 18px;
}
.ov-readme-head {
  font-size: .8rem;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 8px;
}
.ov-readme-text {
  font-size: .85rem;
  color: var(--ink-2);
  line-height: 1.7;
  margin: 0;
}

/* モバイル */
@media(max-width:860px) {
  .ov-grid { grid-template-columns: 1fr; }
  .ov-side { position: static; }
}
@media(max-width:640px) {
  .ov-spec-chip { padding: 7px 12px; }
  .ov-spec-val { font-size: .8rem; }
  .ov-actions { flex-direction: column; align-items: stretch; }
  .ov-btn-primary { justify-content: center; width: 100%; }
}

/* ═══════════════════════════════════════════
   スペックバー + 料金予約カード 横並びレイアウト
═══════════════════════════════════════════ */
.ov-top-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 20px;
  align-items: start;
  padding-bottom: 28px;
  border-bottom: 1px solid rgba(14,15,17,.07);
  margin-bottom: 32px;
}

/* スペックバー（左） */
.ov-spec-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0;
  border: none;
  margin: 0;
}

/* 料金＋予約（右） */
.ov-price-action {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  flex-shrink: 0;
  min-width: 200px;
  background: var(--white);
  border: 1.5px solid rgba(14,15,17,.1);
  border-radius: 16px;
  padding: 16px 18px;
  box-shadow: 0 2px 12px rgba(14,15,17,.06);
}
.opa-price {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.03em;
  line-height: 1.2;
  text-align: right;
}
.opa-note {
  font-size: .7rem;
  color: var(--ink-3);
  margin: 0;
  text-align: right;
}
.opa-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 11px 18px;
  border-radius: 10px;
  background: var(--green);
  color: #fff;
  font-size: .85rem;
  font-weight: 700;
  text-decoration: none;
  width: 100%;
  transition: background .18s, transform .15s;
  box-shadow: 0 3px 10px rgba(0,184,122,.22);
  white-space: nowrap;
}
.opa-btn:hover { background: #008858; transform: translateY(-1px); }
.opa-sub {
  font-size: .72rem;
  color: var(--ink-3);
  margin: 0;
  text-align: center;
}

/* 古い料金カード系クラスを非表示 */
.rg-reserve-card,
.rg-rc-price-block, .rg-rc-action-block, .rg-rc-divider,
.rg-rc-left, .rg-rc-right { display: none !important; }

/* モバイル */
@media(max-width:860px) {
  .ov-top-row {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .ov-price-action {
    align-items: stretch;
    min-width: 0;
    width: 100%;
  }
  .opa-price, .opa-note { text-align: left; }
}

/* ═══════════════════════════════════════════
   スペックバー + 料金予約パネル 横並びレイアウト
═══════════════════════════════════════════ */
.ov-top-row, .ov-spec-row {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: 20px 0 28px;
  border-bottom: 1px solid rgba(14,15,17,.07);
  margin-bottom: 32px;
}
/* 左：チップをwrapしながら伸張 */
.ov-top-row .ov-spec-bar,
.ov-spec-row .ov-spec-bar {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 0;
  border-bottom: none;
  margin-bottom: 0;
}

/* 右：料金＋予約パネル */
.ov-price-action, .ov-reserve-panel {
  flex-shrink: 0;
  width: 220px;
  background: var(--white);
  border: 1.5px solid rgba(14,15,17,.1);
  border-radius: 16px;
  padding: 16px 18px;
  box-shadow: var(--sh-sm);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
/* 料金 */
.opa-price, .ov-price-val {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.03em;
  line-height: 1.2;
  display: block;
}
.opa-note, .ov-price-note {
  font-size: .71rem;
  color: var(--ink-3);
  margin: -4px 0 2px;
  display: block;
}
.ov-price {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
/* 予約ボタン */
.opa-btn, .ov-reserve-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 11px 14px;
  border-radius: 10px;
  background: var(--green);
  color: #fff;
  font-size: .84rem;
  font-weight: 700;
  text-decoration: none;
  transition: background .18s, transform .15s;
  box-shadow: 0 3px 10px rgba(0,184,122,.22);
  width: 100%;
  text-align: center;
}
.opa-btn:hover, .ov-reserve-btn:hover {
  background: #008858;
  transform: translateY(-1px);
}
/* サブテキスト */
.opa-sub, .ov-reserve-sub {
  font-size: .72rem;
  color: var(--ink-3);
  text-align: center;
  margin: 0;
}

/* モバイル：縦積みに戻す */
@media(max-width:860px) {
  .ov-top-row, .ov-spec-row {
    flex-direction: column;
    gap: 16px;
  }
  .ov-price-action, .ov-reserve-panel {
    width: 100%;
    flex-direction: row;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
  }
  .ov-price, .opa-price { flex: 1; }
  .opa-btn, .ov-reserve-btn { width: auto; flex: 1; }
}

/* ─── spec-row 横並び余白ゼロ・予約パネル拡大 ─── */
.ov-top-row,
.ov-spec-row {
  gap: 0 !important;
  align-items: stretch !important;
}
.ov-top-row .ov-spec-bar,
.ov-spec-row .ov-spec-bar {
  padding-right: 20px !important;
}
.ov-price-action,
.ov-reserve-panel {
  width: 260px !important;
  padding: 20px 22px !important;
  border-radius: 18px !important;
  gap: 12px !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
.opa-price,
.ov-price-val {
  font-size: 1.45rem !important;
}
.opa-btn,
.ov-reserve-btn {
  padding: 13px 16px !important;
  font-size: .88rem !important;
  border-radius: 12px !important;
}
@media(max-width:860px) {
  .ov-top-row .ov-spec-bar,
  .ov-spec-row .ov-spec-bar { padding-right: 0 !important; }
  .ov-price-action,
  .ov-reserve-panel { width: 100% !important; }
}

/* ─── スペックチップ バランス改善 ─── */
.ov-top-row .ov-spec-bar,
.ov-spec-row .ov-spec-bar {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)) !important;
  gap: 10px !important;
  align-items: stretch !important;
}
.ov-spec-chip {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 14px !important;
  background: var(--white) !important;
  border: 1px solid rgba(14,15,17,.09) !important;
  border-radius: 14px !important;
  box-shadow: var(--sh-sm) !important;
  min-height: 58px !important;
}
.ov-spec-icon { font-size: 1.3rem !important; flex-shrink: 0 !important; }
.ov-spec-label { font-size: .67rem !important; color: var(--ink-3) !important; font-weight: 700 !important; letter-spacing: .08em !important; }
.ov-spec-val   { font-size: .88rem !important; font-weight: 700 !important; color: var(--ink) !important; line-height: 1.3 !important; }

/* ─── 料金パネル：左寄せ ─── */
.ov-price-action,
.ov-reserve-panel {
  align-items: flex-start !important;
}
.opa-price,
.ov-price-val {
  text-align: left !important;
}
.opa-note,
.ov-price-note {
  text-align: left !important;
}
.opa-sub,
.ov-reserve-sub {
  text-align: left !important;
}

/* ─── 料金パネルをov-sideと同幅に ─── */
.ov-price-action,
.ov-reserve-panel {
  width: 360px !important;
}

/* ─── スペース詳細説明 ─── */
.ov-detail-desc {
  margin-bottom: 24px;
  padding: 20px;
  background: var(--white);
  border: 1px solid rgba(14,15,17,.08);
  border-radius: var(--card-r);
}
.ov-detail-desc-body {
  font-size: .92rem;
  color: var(--ink-2);
  line-height: 1.85;
}
.ov-detail-desc-body p { margin: .5em 0; }
.ov-detail-desc-body a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.ov-detail-desc-body strong { color: var(--ink); font-weight: 700; }

/* ─── 利用規約・禁止事項 ─── */
.ov-rules {
  margin-bottom: 24px;
  border: 1.5px solid rgba(245,166,35,.25);
  border-radius: var(--card-r);
  overflow: hidden;
  background: rgba(245,166,35,.03);
}
.ov-rules-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 16px;
  background: rgba(245,166,35,.1);
  font-size: .82rem;
  font-weight: 700;
  color: #7a5500;
  border-bottom: 1px solid rgba(245,166,35,.15);
}
.ov-rules-body {
  padding: 14px 16px;
  font-size: .88rem;
  color: var(--ink-2);
  line-height: 1.8;
}
.ov-rules-body p { margin: .4em 0; }
.ov-rules-body p:first-child { margin-top: 0; }
.ov-rules-body p:last-child { margin-bottom: 0; }
.ov-rules-body a { color: var(--accent); text-decoration: underline; }
.ov-rules-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 0 16px 14px;
  font-size: .82rem;
  font-weight: 700;
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: opacity .15s;
}
.ov-rules-link:hover { opacity: .75; }

@media(max-width:860px) {
  .ov-price-action,
  .ov-reserve-panel { width: 100% !important; }
}

/* ─── スペックバー（料金なし版） ─── */
.ov-spec-only-row {
  padding: 20px 0 28px;
  border-bottom: 1px solid rgba(14,15,17,.07);
  margin-bottom: 32px;
}
.ov-spec-only-row .ov-spec-bar {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)) !important;
  gap: 10px !important;
  padding: 0 !important;
  border: none !important;
  margin: 0 !important;
}

/* ─── ov-side：料金パネルを含む全体をsticky ─── */
.ov-side {
  position: sticky !important;
  top: 90px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  align-self: start !important;
}

/* ─── 料金パネルをov-sideの幅に合わせる ─── */
.ov-side .ov-price-action {
  width: 100% !important;
  align-items: flex-start !important;
  padding: 20px 22px !important;
  border-radius: 18px !important;
}

/* ─── スペース名（h1）を少し小さく ─── */
.room-hero-head h1 {
  font-size: clamp(1.7rem, 3.2vw, 2.8rem) !important;
}

/* ─── モバイル ─── */
@media(max-width:860px) {
  .ov-spec-only-row .ov-spec-bar {
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)) !important;
  }
  .ov-side {
    position: static !important;
  }
  .ov-side .ov-price-action { width: 100% !important; }
}

/* ─── お知らせバナー リデザイン ─── */
.room-notice-banner {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-top: 16px;
  padding: 16px 20px;
  background: linear-gradient(135deg, rgba(37,99,255,.06) 0%, rgba(37,99,255,.03) 100%);
  border: 1.5px solid rgba(37,99,255,.18);
  border-radius: 16px;
  box-shadow: 0 2px 10px rgba(37,99,255,.07);
}
.rnb-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--accent);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.rnb-body { flex: 1; min-width: 0; }
.rnb-title {
  display: block;
  font-size: .88rem;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 5px;
  letter-spacing: -.01em;
}
.rnb-text {
  font-size: .87rem;
  color: var(--ink-2);
  line-height: 1.7;
  margin: 0;
}

/* 旧room-alertは非表示 */
.room-alert { display: none; }

/* ═══════════════════════════════════════════
   スペース詳細: モバイル スティッキーボトムバー
   （SpaceMarket風 - スマホのみ表示）
═══════════════════════════════════════════ */
.mobile-sticky-bar {
  display: none; /* PCでは非表示 */
}
@media(max-width:860px) {
  .mobile-sticky-bar {
    display: block;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 9000;
    background: var(--white);
    border-top: 1px solid rgba(14,15,17,.1);
    box-shadow: 0 -4px 20px rgba(14,15,17,.12);
    padding: env(safe-area-inset-bottom, 0px) 0 0; /* iPhoneホームバー対応 */
  }
  .msb-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 18px 14px;
  }
  .msb-left {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
  }
  .msb-label {
    font-size: .65rem;
    color: var(--ink-3);
    font-weight: 600;
    letter-spacing: .05em;
    font-family: var(--mono);
  }
  .msb-price {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--ink);
    letter-spacing: -.03em;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .msb-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 13px 20px;
    border-radius: 12px;
    background: var(--green);
    color: #fff;
    font-size: .88rem;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
    box-shadow: 0 3px 12px rgba(0,184,122,.3);
    transition: background .18s, transform .15s;
    -webkit-tap-highlight-color: transparent;
  }
  .msb-btn:active { transform: scale(.97); }
  /* スティッキーバーの高さ分だけ本文（main）の下余白を確保 */
  main { padding-bottom: 80px; }
  /* 既存のfloating CTAは非表示 */
  .floating-reserve-cta { display: none !important; }
}

/* ═══════════════════════════════════════════
   トップページ ヒーロー trust bar リデザイン
═══════════════════════════════════════════ */
.hero-trust-bar {
  display: flex;
  align-items: center;
  gap: 0;
  margin-top: 24px;
  border-top: 1px solid rgba(14,15,17,.08);
  padding-top: 18px;
}
.hero-trust-item {
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex: 1;
  padding: 0 16px;
  border-right: 1px solid rgba(14,15,17,.08);
}
.hero-trust-item:first-child { padding-left: 0; }
.hero-trust-item:last-child { border-right: none; }
.htb-value {
  font-size: clamp(.88rem, 1.6vw, 1.05rem);
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.02em;
  line-height: 1.25;
}
.htb-label {
  font-size: .65rem;
  color: var(--ink-3);
  font-weight: 600;
  letter-spacing: .1em;
  font-family: var(--mono);
  text-transform: uppercase;
}

/* モバイル: trust bar を横スクロール帯に
   修正: ネガティブマージンを親paddingに合わせて調整しoverflow-xで閉じる */
@media(max-width:640px) {
  .hero-trust-bar {
    overflow-x: auto;
    overflow-y: visible;
    -ms-overflow-style: none;
    scrollbar-width: none;
    gap: 0;
    /* ネガティブマージンはcontainerの左右padding(20px)と一致させる */
    margin-left: -20px;
    margin-right: -20px;
    padding: 14px 20px;
    border-top: 1px solid rgba(14,15,17,.07);
    border-bottom: 1px solid rgba(14,15,17,.07);
    background: var(--white);
    border-radius: 0;
    /* はみ出しを自分自身で切る */
    max-width: calc(100vw);
    box-sizing: border-box;
  }
  .hero-trust-bar::-webkit-scrollbar { display: none; }
  .hero-trust-item {
    flex-shrink: 0;
    min-width: 120px;
    padding: 0 16px;
    border-right: 1px solid rgba(14,15,17,.07);
  }
  .hero-trust-item:first-child { padding-left: 0; }
  .htb-value {
    font-size: .92rem;
    white-space: nowrap;
  }
  .htb-label {
    font-size: .62rem;
    white-space: nowrap;
  }
}

/* ═══════════════════════════════════════════
   モバイルヒーロー 完全修正
═══════════════════════════════════════════ */
@media(max-width:640px) {
  /* ヒーロー全体 */
  .hero-split, .hero-split-inner {
    overflow: visible !important;
  }
  .hero-copy {
    padding: 0 !important;
    width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }
  /* h1: 左端切れ防止 */
  .hero-copy h1 {
    font-size: clamp(1.85rem, 8.5vw, 2.4rem) !important;
    letter-spacing: -.04em !important;
    line-height: 1.2 !important;
    word-break: auto-phrase !important;
    overflow-wrap: break-word !important;
    margin-bottom: 14px !important;
  }
  /* hero-badge */
  .hero-badge {
    font-size: .7rem !important;
    padding: 5px 12px !important;
    white-space: normal !important;
  }
  /* リード文 */
  .hero-copy .hero-lead {
    font-size: .86rem !important;
    line-height: 1.75 !important;
  }
  /* trust bar モバイル */
  .hero-trust-bar {
    margin-top: 20px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 14px 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
    overflow-x: auto !important;
    scrollbar-width: none !important;
  }
  .hero-trust-bar::-webkit-scrollbar { display: none; }
  .hero-trust-item {
    min-width: 0 !important;
    flex: 1 !important;
    padding: 0 12px !important;
  }
  .hero-trust-item:first-child { padding-left: 0 !important; }
  .htb-value {
    font-size: .85rem !important;
    white-space: nowrap !important;
  }
  .htb-label {
    font-size: .6rem !important;
    white-space: nowrap !important;
  }
}
/* ご利用にあたってセクション余白 */
.room-rules-section { padding-top: 0 !important; }
.room-rules-section .ov-rules { max-width: 760px; margin: 0 auto; }

/* ── ov-side の sticky停止ポイントをJS制御に対応 ── */
.ov-side.is-stuck-bottom {
  position: absolute !important;
  bottom: 0 !important;
  top: auto !important;
}
.ov-grid {
  position: relative !important; /* 親をrelativeに */
}

/* ═══════════════════════════════════════════
   予約状況カレンダー リデザイン
═══════════════════════════════════════════ */
.room-calendar-section {
  background: var(--bg) !important;
  padding: 40px 0 !important;
}
.cal-header-bar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.cal-header-left { flex: 1; min-width: 0; }
.cal-title {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: -.04em;
  line-height: 1.25;
  margin: 6px 0 8px;
}
.cal-note {
  font-size: .84rem;
  color: var(--ink-3);
  line-height: 1.6;
  margin: 0;
  max-width: 420px;
}
.cal-nav-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  flex-wrap: wrap;
}
/* 週ナビ */
.availability-week-switcher {
  display: inline-flex;
  align-items: center;
  gap: 0;
  background: var(--white) !important;
  border: 1.5px solid rgba(14,15,17,.1) !important;
  border-radius: 999px !important;
  box-shadow: var(--sh-sm) !important;
  padding: 4px !important;
  height: 42px !important;
}
.availability-week-switcher strong {
  font-size: .8rem;
  font-weight: 700;
  color: var(--ink-2);
  padding: 0 14px;
  white-space: nowrap;
  min-width: 140px;
  text-align: center;
  letter-spacing: .02em;
}
.week-nav-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 700;
  color: var(--ink-2);
  background: none;
  text-decoration: none;
  transition: background .15s, color .15s;
  white-space: nowrap;
}
.week-nav-btn:hover { background: var(--bg); color: var(--accent); }
.week-today-btn {
  display: inline-flex;
  align-items: center;
  height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 700;
  color: var(--accent);
  background: rgba(37,99,255,.07);
  border: 1.5px solid rgba(37,99,255,.18);
  text-decoration: none;
  transition: background .15s;
  white-space: nowrap;
}
.week-today-btn:hover { background: rgba(37,99,255,.12); }
/* 凡例 */
.cal-legend-row {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
}
.cal-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  color: var(--ink-3);
  font-weight: 600;
}
.cal-legend-dot {
  width: 10px;
  height: 10px;
  border-radius: 3px;
}
.cal-legend-item.booked .cal-legend-dot { background: var(--accent); }
.cal-legend-item.free   .cal-legend-dot { background: rgba(14,15,17,.08); border: 1px solid rgba(14,15,17,.12); }

/* カレンダーボード */
.availability-shell {
  background: var(--white) !important;
  border: 1px solid rgba(14,15,17,.08) !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  box-shadow: var(--sh-sm) !important;
}

/* 予約ブロック */
.booking-block {
  background: linear-gradient(135deg, var(--accent) 0%, #1d4ed8 100%) !important;
  border-radius: 6px !important;
  border: none !important;
  box-shadow: 0 2px 8px rgba(37,99,255,.25) !important;
}
.booking-block strong { color: #fff !important; font-size: .75rem !important; font-weight: 700 !important; }
.booking-block span   { color: rgba(255,255,255,.8) !important; font-size: .68rem !important; }

/* ─── マップセクション リデザイン ─── */
.room-map-section { padding-top: 0 !important; }
.section-label-row { margin-bottom: 16px; }
.section-label-title {
  font-size: clamp(1.3rem, 2.5vw, 1.8rem);
  font-weight: 700;
  letter-spacing: -.04em;
  margin: 6px 0 12px;
}
.map-meta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.map-meta-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  background: var(--white);
  border: 1px solid rgba(14,15,17,.09);
  border-radius: 999px;
  font-size: .82rem;
  color: var(--ink-2);
  font-weight: 500;
}
.map-meta-chip svg { color: var(--ink-3); flex-shrink: 0; }
.map-open-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 14px;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  font-size: .8rem;
  font-weight: 700;
  text-decoration: none;
  transition: background .18s;
}
.map-open-btn:hover { background: #1d4ed8; }
.room-map-embed-full {
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--sh-md);
  aspect-ratio: 16/7;
  background: var(--bg-2);
  position: relative;   /* ピン overlay のための基準 */
}
.room-map-embed-full iframe {
  width: 100% !important;
  height: 100% !important;
  display: block;
}

/* モバイル */
@media(max-width:640px) {
  .cal-header-bar { flex-direction: column; gap: 14px; }
  .cal-nav-wrap { width: 100%; }
  .availability-week-switcher { width: 100%; justify-content: space-between; }
  .room-map-embed-full { aspect-ratio: 4/3; border-radius: 14px; }
  .map-meta-row { gap: 6px; }
}

/* ═══════════════════════════════════════════
   ページ全体 2カラム構造（サイドバー全域追従）
═══════════════════════════════════════════ */
.page-two-col {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 32px;
  align-items: start;
  position: relative;
  max-width: var(--container-width, 1200px);
  margin: 0 auto;
  padding: 0 var(--container-pad, 24px);
}
.ptc-main { min-width: 0; }
.ptc-side  { min-width: 0; }
.ptc-side-inner {
  position: sticky;
  top: 90px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.ptc-side-inner .ov-price-action {
  width: 100% !important;
}

/* ov-grid は右カラムなし（1カラム） */
.ov-grid {
  display: block !important;
}
.ov-side { display: none !important; } /* ptc-sideに統合 */

/* マップ・共有・rulesを左カラム内で表示 */
.ptc-main .room-map-section,
.ptc-main .room-rules-section,
.ptc-main .room-calendar-section {
  max-width: 100%;
}
.ptc-main .room-map-section .container,
.ptc-main .room-rules-section .container {
  max-width: 100%;
  padding: 0 !important;
}

/* ═══ カレンダー カードデザイン ═══ */
.room-calendar-section {
  padding: 40px 0 32px;
}
.cal-card {
  background: var(--white);
  border: 1px solid rgba(14,15,17,.09);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(14,15,17,.07);
}
.cal-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 24px 16px;
  border-bottom: 1px solid rgba(14,15,17,.06);
  flex-wrap: wrap;
}
.cal-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: .67rem;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--ink-3);
  font-family: var(--mono);
  margin-bottom: 6px;
}
.cal-live-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--green);
  animation: live-pulse 2.2s ease infinite;
}
.cal-card-title {
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: -.04em;
  margin: 0 0 5px;
}
.cal-card-note {
  font-size: .8rem;
  color: var(--ink-3);
  margin: 0;
  line-height: 1.6;
}
.cal-nav-block {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  flex-shrink: 0;
}
.cal-week-nav {
  display: inline-flex;
  align-items: center;
  gap: 0;
  border: 1.5px solid rgba(14,15,17,.1);
  border-radius: 999px;
  overflow: hidden;
  background: var(--white);
}
.cal-nav-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  color: var(--ink-2);
  text-decoration: none;
  transition: background .15s;
  flex-shrink: 0;
}
.cal-nav-btn:hover { background: var(--bg); }
.cal-week-label {
  font-size: .82rem;
  font-weight: 700;
  color: var(--ink-2);
  padding: 0 14px;
  white-space: nowrap;
  font-family: var(--mono);
  border-left: 1px solid rgba(14,15,17,.08);
  border-right: 1px solid rgba(14,15,17,.08);
}
.cal-today-btn {
  display: inline-flex;
  align-items: center;
  height: 32px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(37,99,255,.07);
  border: 1px solid rgba(37,99,255,.18);
  color: var(--accent);
  font-size: .78rem;
  font-weight: 700;
  text-decoration: none;
  transition: background .15s;
}
.cal-today-btn:hover { background: rgba(37,99,255,.13); }
/* 凡例 */
.cal-legend-strip {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 10px 24px;
  background: var(--bg);
  border-bottom: 1px solid rgba(14,15,17,.06);
}
.cal-leg {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .75rem;
  font-weight: 600;
  color: var(--ink-3);
}
.cal-leg span {
  width: 10px; height: 10px;
  border-radius: 3px;
  flex-shrink: 0;
}
.cal-leg-free span     { background: rgba(0,184,122,.18); border: 1.5px solid rgba(0,184,122,.4); }
.cal-leg-booked span   { background: var(--accent); }
.cal-leg-closed span   { background: rgba(14,15,17,.07); border: 1px solid rgba(14,15,17,.12); }
/* カレンダー内部 */
.cal-card .availability-shell {
  padding: 0 !important;
}
.cal-card .availability-board {
  margin: 0;
  border: none;
  border-radius: 0;
}
/* モバイル */
@media(max-width:860px) {
  .page-two-col {
    grid-template-columns: 1fr !important;
    padding: 0 !important;
  }
  .ptc-side { display: none; } /* モバイルはスティッキーボトムバーで代替 */
  .cal-card-head { flex-direction: column; }
  .cal-nav-block { align-items: flex-start; }
}
@media(max-width:640px) {
  /* room-meta-chip: モバイルでコンパクトに */
  .room-meta-chip { font-size: .78rem !important; padding: 4px 10px !important; }
  .room-hero-meta-row { gap: 6px !important; }
  /* spec-chip: スマホで2列をキープ */
  .ov-spec-only-row .ov-spec-bar,
  .ov-spec-bar {
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)) !important;
  }
  /* spec-chip の最小幅制限 */
  .ov-spec-chip { min-width: 0 !important; }
    .cal-card { border-radius: 14px; border-left: none; border-right: none; border-radius: 0; }
  .cal-card-head { padding: 16px 16px 12px; }
  .cal-legend-strip { padding: 8px 16px; gap: 12px; }
  .cal-week-label { font-size: .76rem; padding: 0 10px; }
}

/* ─── page-two-col: ヒーロー直後から開始 ─── */
.page-two-col {
  max-width: var(--container-width, 1200px) !important;
  margin: 0 auto !important;
  padding: 0 var(--container-pad, 24px) !important;
}
/* 左カラム内のsectionはcontainerなし（ptc-innerで余白制御） */
.ptc-main .room-overview-section .ptc-inner,
.ptc-main .room-map-section .container,
.ptc-main .room-rules-section .container,
.ptc-main .room-calendar-section {
  padding-left: 0 !important;
  padding-right: 0 !important;
  max-width: 100% !important;
}
.ptc-main .room-overview-section { padding-top: 20px; }
.ptc-main .room-overview-section .ptc-inner { width: 100%; }
/* ov-spec-only-rowの下線調整 */
.ptc-main .ov-spec-only-row {
  padding-top: 0 !important;
}

/* ─── sticky 追従修正 ─── */
/* グリッド子要素が stretch されるとstickyが効かないため align-items:start を明示 */
.page-two-col {
  align-items: start !important;
}
/* ptc-side は左カラムと同じ高さに伸ばす（stickyの追従範囲を確保） */
.ptc-side {
  align-self: stretch !important;
}
.ptc-side-inner {
  position: sticky !important;
  top: 96px !important;   /* ヘッダー高さ + 余白 */
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  overflow-y: visible !important;
}
.ptc-side-inner::-webkit-scrollbar { display: none; }

/* ═══ sticky 純CSSのみで完全実装（JS不使用） ═══
   要件：
   1. page-two-col = グリッドコンテナ（align-items:start 推奨）
   2. ptc-side = グリッドアイテム（align-self:stretch 必須 ← stickyの追従高さを確保）
   3. ptc-side-inner = sticky要素
   ★ ptc-sideをstretchにしないと追従範囲がゼロになりstickyが効かない
   親にoverflow:hidden/auto があるとstickyは効かないので注意
════════════════════════════════════════════ */

/* コンテナ：必ず align-items:start */
.page-two-col {
  display: grid !important;
  grid-template-columns: 1fr 360px !important;
  gap: 32px !important;
  align-items: start !important;   /* ← これが必須 */
  position: relative !important;
}

/* サイドバー列：左カラムと同じ高さに伸ばす（sticky追従に必須） */
.ptc-side {
  align-self: stretch !important;  /* ← stretchでrow全体の高さを確保 */
  min-width: 0 !important;
}

/* スティッキー本体 */
.ptc-side-inner {
  position: sticky !important;
  top: 96px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  /* 高さ制限は設けない（max-heightはstickyを壊すことがある） */
  max-height: none !important;
  overflow-y: visible !important;
}

/* スクロール停止：other-spacesの前で自然に止まる
   → page-two-colが終わると sticky の基準も終わるため自動停止 */

@media(max-width:860px) {
  .page-two-col {
    grid-template-columns: 1fr !important;
  }
  .ptc-side { display: none !important; }
}


/* ═══════════════════════════════════════════
   Note.com風 記事ページ (single.php)
═══════════════════════════════════════════ */

/* ── ラッパー ── */
.note-article-wrap {
  background: var(--bg);
  min-height: 100vh;
  padding-bottom: 60px;
}

/* ── ヒーロー画像 ── */
.note-hero-img {
  width: 100%;
  max-height: 520px;
  overflow: hidden;
  background: var(--bg-2);
}
.note-hero-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ── 本文レイアウト ── */
.note-article-body {
  max-width: 1080px;
  margin: 0 auto;
  padding: 40px 24px 0;
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 48px;
  align-items: start;
}

/* ── メインカラム ── */
.note-main-col { min-width: 0; }

/* ── カテゴリタグ ── */
.note-category-tag {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 999px;
  background: rgba(37,99,255,.08);
  border: 1px solid rgba(37,99,255,.18);
  color: var(--accent);
  font-size: .75rem;
  font-weight: 700;
  text-decoration: none;
  letter-spacing: .05em;
  margin-bottom: 16px;
}
.note-category-tag:hover { background: rgba(37,99,255,.14); }

/* ── タイトル ── */
.note-article-title {
  font-size: clamp(1.7rem, 3.5vw, 2.6rem);
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: -.04em;
  color: var(--ink);
  margin: 0 0 16px;
}

/* ── リード文 ── */
.note-article-lead {
  font-size: 1rem;
  color: var(--ink-2);
  line-height: 1.8;
  margin: 0 0 16px;
}

/* ── メタ情報 ── */
.note-article-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  font-size: .82rem;
  color: var(--ink-3);
  padding-bottom: 28px;
  border-bottom: 1px solid rgba(14,15,17,.07);
  margin-bottom: 32px;
}
.note-meta-sep { color: rgba(14,15,17,.2); }

/* ── 目次 ── */
.note-toc {
  background: var(--white);
  border: 1px solid rgba(14,15,17,.08);
  border-radius: 16px;
  padding: 22px 24px;
  margin-bottom: 36px;
}
.note-toc-head {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: .8rem;
  font-weight: 700;
  color: var(--ink-3);
  letter-spacing: .06em;
  margin-bottom: 14px;
}
.note-toc-list {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: toc-counter;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.note-toc-item { counter-increment: toc-counter; }
.note-toc-item a {
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-size: .88rem;
  color: var(--ink-2);
  text-decoration: none;
  line-height: 1.5;
  transition: color .15s;
}
.note-toc-item a::before {
  content: counter(toc-counter);
  font-size: .72rem;
  font-weight: 700;
  color: var(--accent);
  min-width: 18px;
  flex-shrink: 0;
}
.note-toc-item a:hover { color: var(--accent); }
.note-toc-item.level-3 { padding-left: 20px; }
.note-toc-item.level-3 a { font-size: .84rem; color: var(--ink-3); }

/* ── 本文 ── */
.note-article-content {
  font-size: 1rem;
  line-height: 2;
  color: var(--ink);
}
.note-article-content p { margin: 1.2em 0; color: #2e2c29; }
.note-article-content a { color: var(--accent); text-underline-offset: 3px; }
.note-article-content h2 {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -.03em;
  margin: 2.8em 0 .9em;
  padding-bottom: .5em;
  border-bottom: 2px solid var(--accent);
}
.note-article-content h3 {
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.45;
  margin: 2em 0 .75em;
  padding-left: 14px;
  position: relative;
}
.note-article-content h3::before {
  content: '';
  position: absolute;
  left: 0; top: .3em;
  width: 4px; height: 1em;
  border-radius: 999px;
  background: var(--accent);
}
.note-article-content h4 {
  font-size: 1rem;
  font-weight: 700;
  margin: 1.6em 0 .6em;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(37,99,255,.05);
}
.note-article-content ul,
.note-article-content ol { padding-left: 1.4em; margin: 1em 0 1.2em; }
.note-article-content li { margin: .45em 0; line-height: 1.9; }
.note-article-content blockquote {
  margin: 1.8em 0;
  padding: 18px 22px;
  border-left: 3px solid var(--accent);
  background: rgba(255,255,255,.95);
  border-radius: 0 14px 14px 0;
  box-shadow: var(--sh-sm);
  color: #4a4845;
}
.note-article-content img {
  width: 100%;
  border-radius: 12px;
  box-shadow: var(--sh-sm);
  margin: .8em 0;
}
.note-article-content table {
  width: 100%;
  border-collapse: collapse;
  border-radius: var(--card-r);
  overflow: hidden;
  box-shadow: var(--sh-sm);
  margin: 1.6em 0;
  font-size: .92rem;
}
.note-article-content th,
.note-article-content td { padding: 12px 16px; border: 1px solid rgba(14,15,17,.07); }
.note-article-content th { background: var(--bg); font-weight: 700; }

/* ── シェアバー ── */
.note-share-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  padding: 24px 0;
  margin-top: 40px;
  border-top: 1px solid rgba(14,15,17,.07);
  border-bottom: 1px solid rgba(14,15,17,.07);
}
.note-share-label {
  font-size: .8rem;
  font-weight: 700;
  color: var(--ink-3);
  flex-shrink: 0;
}
.note-share-btns { display: flex; gap: 8px; flex-wrap: wrap; }
.note-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: 999px;
  font-size: .8rem;
  font-weight: 700;
  text-decoration: none;
  transition: opacity .18s, transform .15s;
}
.note-share-btn:hover { opacity: .85; transform: translateY(-1px); }
.note-share-x        { background: #000; color: #fff; }
.note-share-line     { background: #06C755; color: #fff; }
.note-share-facebook { background: #1877F2; color: #fff; }

/* ── 関連記事 ── */
.note-related { margin-top: 44px; }
.note-related-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 18px;
  padding-bottom: 10px;
  border-bottom: 2px solid rgba(14,15,17,.07);
}
.note-related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
}
.note-related-card {
  display: block;
  border-radius: 14px;
  overflow: hidden;
  background: var(--white);
  border: 1px solid rgba(14,15,17,.07);
  box-shadow: var(--sh-sm);
  text-decoration: none;
  transition: transform .18s, box-shadow .18s;
}
.note-related-card:hover { transform: translateY(-3px); box-shadow: var(--sh-md); }
.note-related-img { width: 100%; aspect-ratio: 16/9; overflow: hidden; background: var(--bg-2); }
.note-related-img img { width: 100%; height: 100%; object-fit: cover; }
.note-related-img--empty { background: var(--bg-2); }
.note-related-body { padding: 14px 16px; }
.note-related-cat {
  font-size: .7rem;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: .06em;
  display: block;
  margin-bottom: 5px;
}
.note-related-ttl {
  font-size: .88rem;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.55;
  margin: 0 0 8px;
}
.note-related-date { font-size: .74rem; color: var(--ink-3); }

/* ── 戻るリンク ── */
.note-back-link {
  margin-top: 32px;
  padding-top: 24px;
}
.note-back-link a {
  font-size: .88rem;
  color: var(--ink-3);
  text-decoration: none;
  transition: color .15s;
}
.note-back-link a:hover { color: var(--accent); }

/* ── サイドバー ── */
.note-sidebar { min-width: 0; }
.note-sidebar-card {
  background: var(--white);
  border: 1px solid rgba(14,15,17,.07);
  border-radius: 16px;
  box-shadow: var(--sh-sm);
  padding: 20px 22px;
  margin-bottom: 20px;
}
/* サイドバー全体をstickyに（カード個別にsticky→重なりバグを修正） */
.note-sidebar {
  position: sticky;
  top: 90px;
  align-self: start;
}
.note-sidebar-head {
  font-size: .78rem;
  font-weight: 700;
  color: var(--ink-3);
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.note-sidebar-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.note-sidebar-item {
  display: flex;
  gap: 10px;
  text-decoration: none;
  align-items: flex-start;
}
.note-sidebar-thumb {
  width: 60px;
  height: 44px;
  border-radius: 8px;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--bg-2);
}
.note-sidebar-thumb img { width: 100%; height: 100%; object-fit: cover; }
.note-sidebar-item-body p {
  font-size: .84rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.45;
  margin: 0 0 3px;
}
.note-sidebar-item-body span { font-size: .74rem; color: var(--ink-3); }
.note-sidebar-cats {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.note-sidebar-cats a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  font-size: .88rem;
  color: var(--ink-2);
  text-decoration: none;
  border-bottom: 1px solid rgba(14,15,17,.05);
  transition: color .15s;
}
.note-sidebar-cats a:hover { color: var(--accent); }
.note-sidebar-cats a span {
  font-size: .74rem;
  color: var(--ink-3);
  background: var(--bg-2);
  padding: 2px 8px;
  border-radius: 999px;
}
.note-sidebar-cta {
  background: var(--ink);
  border-radius: 16px;
  padding: 22px;
  text-align: center;
}
.note-sidebar-cta-title {
  font-size: .82rem;
  color: rgba(247,245,240,.65);
  margin: 0 0 14px;
  line-height: 1.55;
}
.note-sidebar-cta-btn {
  display: block;
  padding: 13px 16px;
  border-radius: 12px;
  background: var(--green);
  color: #fff;
  font-size: .88rem;
  font-weight: 700;
  text-decoration: none;
  transition: background .18s, transform .15s;
  box-shadow: 0 4px 14px rgba(0,184,122,.3);
}
.note-sidebar-cta-btn:hover { background: #008858; transform: translateY(-1px); }

/* ── モバイル対応 ── */
@media(max-width:860px) {
  .note-article-body {
    grid-template-columns: 1fr;
    padding: 28px 18px 0;
    gap: 0;
  }
  .note-sidebar { display: none; }
  .note-hero-img { max-height: 280px; }
  .note-article-title { font-size: 1.6rem; }
  .note-toc { padding: 18px 18px; }
  .note-related-grid { grid-template-columns: 1fr; }
  .note-share-bar { gap: 8px; }
}
@media(max-width:640px) {
  .note-article-body { padding: 20px 16px 0; }
  .note-article-title { font-size: 1.45rem; letter-spacing: -.03em; }
  .note-hero-img { max-height: 220px; }
  .note-share-btns { gap: 6px; }
  .note-share-btn { padding: 7px 13px; font-size: .76rem; }
}


/* ═══════════════════════════════════════════
   Note.com風 コラム一覧 (archive.php)
═══════════════════════════════════════════ */

.note-archive-wrap {
  background: var(--bg);
  min-height: 100vh;
}

/* ── トップバー ── */
.note-archive-top {
  background: var(--white);
  border-bottom: 1px solid rgba(14,15,17,.08);
  padding: 32px 0 0;
}
.note-archive-top-inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 24px;
}
.note-archive-title {
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 700;
  letter-spacing: -.04em;
  margin: 0 0 8px;
}
.note-archive-lead {
  font-size: .9rem;
  color: var(--ink-3);
  margin: 0 0 20px;
}

/* ── カテゴリタブ ── */
.note-cat-tabs {
  display: flex;
  gap: 0;
  overflow-x: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
  border-top: 1px solid rgba(14,15,17,.06);
  margin: 0 -24px;
  padding: 0 24px;
}
.note-cat-tabs::-webkit-scrollbar { display: none; }
.note-cat-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 12px 16px;
  font-size: .86rem;
  font-weight: 600;
  color: var(--ink-3);
  text-decoration: none;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color .15s, border-color .15s;
  flex-shrink: 0;
}
.note-cat-tab:hover { color: var(--ink); }
.note-cat-tab.is-active { color: var(--ink); border-bottom-color: var(--ink); }
.note-cat-count {
  font-size: .72rem;
  background: rgba(14,15,17,.06);
  padding: 1px 7px;
  border-radius: 999px;
  font-weight: 700;
  color: var(--ink-3);
}

/* ── メインレイアウト ── */
.note-archive-body {
  max-width: 1080px;
  margin: 0 auto;
  padding: 36px 24px 60px;
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 40px;
  align-items: start;
}
.note-archive-main { min-width: 0; }

/* ── フィーチャーカード（1枚目） ── */
.note-feature-card {
  margin-bottom: 32px;
}
.note-feature-card-link {
  display: block;
  background: var(--white);
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(14,15,17,.07);
  box-shadow: var(--sh-md);
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
}
.note-feature-card-link:hover { transform: translateY(-4px); box-shadow: 0 12px 36px rgba(14,15,17,.14); }
.note-feature-img { width: 100%; aspect-ratio: 16/7; overflow: hidden; background: var(--bg-2); }
.note-feature-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.note-feature-card-link:hover .note-feature-img img { transform: scale(1.03); }
.note-feature-body { padding: 24px 28px 28px; }
.note-feature-meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 10px; }
.note-feature-title {
  font-size: clamp(1.3rem, 2.5vw, 1.8rem);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -.03em;
  color: var(--ink);
  margin: 0 0 12px;
}
.note-feature-excerpt {
  font-size: .92rem;
  color: var(--ink-2);
  line-height: 1.8;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── 通常カードグリッド ── */
.note-posts-grid {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.note-post-card {
  border-bottom: 1px solid rgba(14,15,17,.07);
}
.note-post-card:first-child { border-top: none; }
.note-post-card-link {
  display: grid;
  grid-template-columns: 1fr 140px;
  gap: 16px;
  align-items: start;
  padding: 20px 0;
  text-decoration: none;
  transition: opacity .18s;
}
.note-post-card-link:hover { opacity: .75; }
.note-post-img {
  width: 140px;
  aspect-ratio: 4/3;
  border-radius: 10px;
  overflow: hidden;
  background: var(--bg-2);
  flex-shrink: 0;
  order: 2;
}
.note-post-img img { width: 100%; height: 100%; object-fit: cover; }
.note-post-img--empty { background: linear-gradient(135deg, var(--bg-2) 0%, rgba(14,15,17,.04) 100%); }
.note-post-body { order: 1; min-width: 0; }
.note-post-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 6px; }
.note-post-title {
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.55;
  letter-spacing: -.02em;
  color: var(--ink);
  margin: 0 0 8px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.note-post-excerpt {
  font-size: .84rem;
  color: var(--ink-3);
  line-height: 1.7;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── 共通タグ・日付 ── */
.note-tag {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(37,99,255,.07);
  color: var(--accent);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-decoration: none;
}
.note-date { font-size: .78rem; color: var(--ink-3); }
.note-readtime { font-size: .78rem; color: var(--ink-3); }

/* ── ページネーション ── */
.note-pagination { margin-top: 32px; }
.note-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  font-size: .88rem;
  font-weight: 700;
  color: var(--ink-2);
  text-decoration: none;
  border: 1.5px solid rgba(14,15,17,.1);
  margin: 0 3px;
  transition: background .15s, border-color .15s;
}
.note-pagination .page-numbers:hover { background: var(--white); border-color: var(--ink); }
.note-pagination .page-numbers.current { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.note-pagination ul { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 4px; }
.note-pagination li { display: inline; }
.note-pagination .prev,
.note-pagination .next { width: auto; padding: 0 16px; border-radius: 10px; }

/* ── 空状態 ── */
.note-empty { text-align: center; padding: 60px 20px; }
.note-empty-icon { font-size: 2.5rem; margin-bottom: 16px; }
.note-empty h2 { font-size: 1.3rem; margin-bottom: 8px; }
.note-empty p { color: var(--ink-3); font-size: .92rem; }

/* ── サイドバー ── */
.note-archive-sidebar {
  position: sticky;
  top: 90px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.note-aside-card {
  background: var(--white);
  border: 1px solid rgba(14,15,17,.07);
  border-radius: 16px;
  box-shadow: var(--sh-sm);
  padding: 20px 22px;
}
.note-aside-head {
  font-size: .72rem;
  font-weight: 700;
  color: var(--ink-3);
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.note-aside-cats {
  list-style: none;
  padding: 0;
  margin: 0;
}
.note-aside-cats a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 9px 0;
  font-size: .88rem;
  color: var(--ink-2);
  text-decoration: none;
  border-bottom: 1px solid rgba(14,15,17,.05);
  transition: color .15s;
  font-weight: 500;
}
.note-aside-cats a:last-child { border-bottom: none; }
.note-aside-cats a:hover,
.note-aside-cats a.is-active { color: var(--ink); font-weight: 700; }
.note-aside-cats a span {
  font-size: .72rem;
  color: var(--ink-3);
  background: var(--bg-2);
  padding: 2px 8px;
  border-radius: 999px;
  font-weight: 600;
}
.note-aside-recent {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.note-aside-recent-item {
  display: flex;
  gap: 10px;
  text-decoration: none;
  align-items: flex-start;
}
.note-aside-thumb {
  width: 58px;
  height: 42px;
  border-radius: 8px;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--bg-2);
}
.note-aside-thumb img { width: 100%; height: 100%; object-fit: cover; }
.note-aside-recent-body p {
  font-size: .84rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.45;
  margin: 0 0 3px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.note-aside-recent-body span { font-size: .74rem; color: var(--ink-3); }
.note-aside-cta {
  background: var(--ink);
  border-radius: 16px;
  padding: 22px;
  text-align: center;
}
.note-aside-cta-label {
  font-size: .84rem;
  font-weight: 700;
  color: var(--bg);
  margin: 0 0 4px;
}
.note-aside-cta-sub {
  font-size: .76rem;
  color: rgba(247,245,240,.5);
  margin: 0 0 16px;
}
.note-aside-cta-btn {
  display: block;
  padding: 13px 16px;
  border-radius: 12px;
  background: var(--green);
  color: #fff;
  font-size: .88rem;
  font-weight: 700;
  text-decoration: none;
  transition: background .18s, transform .15s;
  box-shadow: 0 4px 14px rgba(0,184,122,.3);
}
.note-aside-cta-btn:hover { background: #008858; transform: translateY(-1px); }

/* ── モバイル ── */
@media(max-width:860px) {
  .note-archive-body {
    grid-template-columns: 1fr;
    padding: 24px 18px 48px;
    gap: 0;
  }
  .note-archive-sidebar { display: none; }
  .note-archive-top-inner { padding: 0 18px; }
  .note-cat-tabs { margin: 0 -18px; padding: 0 18px; }
  .note-post-card-link { grid-template-columns: 1fr 110px; gap: 12px; }
  .note-post-img { width: 110px; }
  .note-feature-body { padding: 18px 20px 22px; }
}
@media(max-width:640px) {
  .note-archive-top { padding: 20px 0 0; }
  .note-archive-title { font-size: 1.4rem; }
  .note-feature-img { aspect-ratio: 16/9; }
  .note-post-card-link { grid-template-columns: 1fr 88px; }
  .note-post-img { width: 88px; }
  .note-post-title { font-size: .92rem; }
  .note-post-excerpt { display: none; }
}

/* ─── ギャラリーキャプション ─── */
/* グリッド上のキャプションは表示しない（ライトボックス内のみ） */

/* ライトボックス内キャプション */
.rg-lb-img-wrap { position: relative !important; }
.rg-lb-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(to top, rgba(0,0,0,.82) 0%, rgba(0,0,0,0) 100%);
  color: #fff;
  font-size: .9rem;
  font-weight: 600;
  line-height: 1.65;
  padding: 32px 28px 16px;
  letter-spacing: .02em;
  text-align: center;
  pointer-events: none;
  border-radius: 0 0 8px 8px;
  display: none;
}

/* ═══════════════════════════════════════════
   写真一覧モーダル（枚数バッジクリックで表示）
═══════════════════════════════════════════ */
.rg-photo-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 999998;
}
.rg-photo-modal.is-open {
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
@media (min-width: 641px) {
  .rg-photo-modal.is-open {
    align-items: center;
  }
}

/* オーバーレイ */
.rg-pm-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 0;
  cursor: pointer;
}

/* パネル */
.rg-pm-panel {
  position: relative;
  z-index: 1;
  background: #fff;
  width: 100%;
  max-width: 860px;
  max-height: 92dvh;
  max-height: 92vh;
  border-radius: 16px 16px 0 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 -8px 40px rgba(0,0,0,.18);
}
@media (min-width: 641px) {
  .rg-pm-panel {
    border-radius: 16px;
    max-height: 88vh;
  }
}
/* モバイル専用調整 */
@media (max-width: 640px) {
  .rg-pm-panel {
    max-height: 85dvh;
    max-height: 85vh;
    border-radius: 20px 20px 0 0;
  }
  .rg-pm-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 4px;
  }
  .rg-pm-body {
    padding: 12px 10px 20px;
  }
}

/* ヘッダー */
.rg-pm-header {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px 20px 14px;
  border-bottom: 1px solid rgba(0,0,0,.08);
  flex-shrink: 0;
  position: relative;
}
.rg-pm-title {
  font-size: .95rem;
  font-weight: 700;
  color: #0d1117;
  letter-spacing: -.01em;
}
.rg-pm-close {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: none;
  background: rgba(0,0,0,.06);
  color: #0d1117;
  font-size: .9rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .16s;
}
.rg-pm-close:hover { background: rgba(0,0,0,.12); }

/* スクロールボディ */
.rg-pm-body {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 16px 16px 24px;
  flex: 1;
}

/* 画像グリッド */
.rg-pm-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}
@media (min-width: 641px) {
  .rg-pm-grid {
    grid-template-columns: repeat(5, 1fr);
    gap: 8px;
  }
}

/* セル */
.rg-pm-cell {
  position: relative;
  aspect-ratio: 1;
  border-radius: 8px;
  overflow: hidden;
  cursor: pointer;
  background: #f0f2f7;
}
.rg-pm-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s ease;
}
.rg-pm-cell:hover img { transform: scale(1.05); }

/* セル内キャプションは写真一覧では非表示（ライトボックス内のみ表示） */
.rg-pm-cap { display: none; }

/* ─────────────────────────────────────────
   リンクのスタイル（説明文・補足メモ内）
   ───────────────────────────────────────── */
.ov-text a,
.ov-note a,
.ov-detail-desc-body a,
.ov-rules-body a {
  color: #1a56db;
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: 600;
  word-break: break-all;
  transition: color .15s;
}
.ov-text a:hover,
.ov-note a:hover,
.ov-detail-desc-body a:hover,
.ov-rules-body a:hover {
  color: #1e40af;
}

/* ─────────────────────────────────────────
   Leaflet マップ（Airbnb風 divIcon マーカー）
   ───────────────────────────────────────── */

/* Leaflet コンテナ */
.room-map-leaflet {
  position: relative;
}

/* 読み込みローディング */
.rmap-leaflet-loading {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-size: .84rem;
  font-weight: 600;
  color: var(--ink-2, #4b5260);
  background: var(--bg-2, #f0f2f7);
  border-radius: inherit;
}
@keyframes rmap-spin {
  to { transform: rotate(360deg); }
}
.rmap-spinner {
  animation: rmap-spin .9s linear infinite;
}

/* Airbnb風 divIcon ピル */
.rmap-lf-pin {
  /* iconSize:[0,0] で親は幅高ゼロ → absolute で尾の先端をマーカー点に合わせる */
  position: absolute;
  bottom: 10px;          /* 尾(10px)分を下に伸ばすので、尾先端=マーカー点 */
  left: 0;
  transform: translateX(-50%);  /* 水平方向だけ中央揃え */
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #fff;
  color: #0d1117;
  font-size: .82rem;
  font-weight: 700;
  font-family: 'Hiragino Kaku Gothic ProN','Noto Sans JP','Meiryo',sans-serif;
  letter-spacing: -.01em;
  white-space: nowrap;
  padding: 8px 14px;
  border-radius: 999px;
  box-shadow:
    0 2px 8px rgba(0,0,0,.14),
    0 6px 24px rgba(0,0,0,.16),
    0 0 0 1.5px rgba(0,0,0,.06);
  cursor: pointer;
  transition: box-shadow .15s, bottom .15s;
}
.rmap-lf-pin:hover {
  bottom: 13px;
  box-shadow:
    0 4px 14px rgba(0,0,0,.18),
    0 10px 32px rgba(0,0,0,.2),
    0 0 0 1.5px rgba(0,0,0,.1);
}
.rmap-lf-pin svg {
  color: #ff385c;
  flex-shrink: 0;
}
/* 吹き出し尾 */
.rmap-lf-pin::after {
  content: '';
  position: absolute;
  bottom: -9px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 10px solid #fff;
  filter: drop-shadow(0 2px 2px rgba(0,0,0,.1));
}

/* Leaflet デフォルト UI を整える */
.leaflet-control-attribution {
  font-size: .68rem !important;
  background: rgba(255,255,255,.82) !important;
  backdrop-filter: blur(4px) !important;
}
.leaflet-control-zoom a {
  font-size: 1rem !important;
  font-weight: 700 !important;
}

/* ════════════════════════════════════════════════════
   トップページ検索：時間帯フィールド
════════════════════════════════════════════════════ */
.ssrs-time-group .form-label { margin-bottom: 5px; }
.ssrs-time-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
}
.ssrs-time-wrap .select-wrap { flex: 1; min-width: 0; }
.ssrs-time-sep {
  font-size: .82rem;
  color: var(--ink-3, #888);
  flex-shrink: 0;
}

/* ── 空き確認バッジ（room-card 上） ── */
.room-card { position: relative; }
.ssrs-avail-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 10;
  font-size: .72rem;
  font-weight: 800;
  padding: 4px 10px;
  border-radius: 999px;
  letter-spacing: .02em;
  pointer-events: none;
}
.avail-ok {
  background: #dcfce7;
  color: #15803d;
  border: 1px solid rgba(21,128,61,.2);
}
.avail-busy {
  background: #fee2e2;
  color: #b91c1c;
  border: 1px solid rgba(185,28,28,.2);
}
.avail-checking {
  background: #fffbeb;
  color: #b45309;
  border: 1px solid rgba(180,83,9,.2);
}
.avail-err {
  background: #f4f4f5;
  color: #71717a;
  border: 1px solid rgba(0,0,0,.1);
}

/* ════════════════════════════════════════════════════
   月間空室カレンダー（◎○△×）
════════════════════════════════════════════════════ */
.ssrs-avail-cal-wrap { background: var(--bg, #f8f8f5); }
.ssrs-avail-cal {
  background: #fff;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 20px;
  box-shadow: 0 4px 32px rgba(0,0,0,.07);
  overflow: hidden;
}

/* ヘッダー */
.ssrs-acal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 28px 28px 16px;
  flex-wrap: wrap;
}
.ssrs-acal-eyebrow {
  font-size: .65rem;
  font-weight: 800;
  letter-spacing: .18em;
  color: var(--accent, #1a56db);
  margin: 0 0 4px;
}
.ssrs-acal-title {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--ink, #0d1117);
  letter-spacing: -.02em;
  margin: 0 0 4px;
  padding: 0;
  border: none;
  background: none;
}
.ssrs-acal-sub {
  font-size: .76rem;
  color: var(--ink-3, #888);
  margin: 0;
}
.ssrs-acal-nav {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}
.ssrs-acal-nav-btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1.5px solid rgba(0,0,0,.1);
  background: #fafafa;
  display: flex; align-items: center; justify-content: center;
  color: var(--ink, #0d1117);
  transition: all .16s;
  text-decoration: none;
}
.ssrs-acal-nav-btn:hover { border-color: var(--accent, #1a56db); color: var(--accent, #1a56db); background: #f0f4ff; }
.ssrs-acal-ym {
  font-size: .95rem;
  font-weight: 800;
  color: var(--ink, #0d1117);
  min-width: 96px;
  text-align: center;
}

/* 凡例 */
.ssrs-acal-legend {
  display: flex;
  gap: 16px;
  padding: 8px 28px 12px;
  flex-wrap: wrap;
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.ssrs-leg {
  font-size: .73rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 999px;
}
.ssrs-leg-ex { background: #dbeafe; color: #1d4ed8; }
.ssrs-leg-ok { background: #dcfce7; color: #15803d; }
.ssrs-leg-lt { background: #fef9c3; color: #a16207; }
.ssrs-leg-ng { background: #fee2e2; color: #b91c1c; }

/* グリッド */
.ssrs-acal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  padding: 12px 16px 20px;
  gap: 4px;
}
.ssrs-acal-dow {
  text-align: center;
  font-size: .7rem;
  font-weight: 800;
  color: var(--ink-3, #888);
  padding: 6px 0;
}
.ssrs-acal-dow.is-sat { color: #2563eb; }
.ssrs-acal-dow.is-sun { color: #dc2626; }

/* 日付セル */
.ssrs-acal-cell {
  position: relative;
  aspect-ratio: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  cursor: pointer;
  transition: transform .14s, box-shadow .14s;
  border: 1.5px solid transparent;
  user-select: none;
  min-height: 52px;
}
.ssrs-acal-cell:not(.is-past):not(.is-empty):hover {
  transform: scale(1.06);
  box-shadow: 0 4px 16px rgba(0,0,0,.14);
  z-index: 2;
}
.ssrs-acal-cell.is-past { cursor: default; opacity: .45; }
.ssrs-acal-cell.is-empty { cursor: default; }
.ssrs-acal-cell.is-today { border-color: var(--accent, #1a56db); }
.ssrs-acal-cell.is-sat .ssrs-acal-d { color: #2563eb; }
.ssrs-acal-cell.is-sun .ssrs-acal-d { color: #dc2626; }

/* 空き状態の背景色 */
.ssrs-acal-cell.avail-ex { background: #dbeafe; }
.ssrs-acal-cell.avail-ok { background: #dcfce7; }
.ssrs-acal-cell.avail-lt { background: #fef9c3; }
.ssrs-acal-cell.avail-ng { background: #fee2e2; }

.ssrs-acal-d {
  font-size: .82rem;
  font-weight: 800;
  color: var(--ink, #0d1117);
  line-height: 1;
}
.ssrs-acal-sym {
  font-size: .88rem;
  font-weight: 900;
  line-height: 1;
  margin-top: 3px;
}
.ssrs-acal-cell.avail-ex .ssrs-acal-sym { color: #1d4ed8; }
.ssrs-acal-cell.avail-ok .ssrs-acal-sym { color: #15803d; }
.ssrs-acal-cell.avail-lt .ssrs-acal-sym { color: #a16207; }
.ssrs-acal-cell.avail-ng .ssrs-acal-sym { color: #b91c1c; }
.ssrs-sym-past { color: #ccc !important; font-weight: 400 !important; }

@media(max-width: 480px) {
  .ssrs-acal-grid { gap: 2px; padding: 10px 10px 16px; }
  .ssrs-acal-cell { border-radius: 7px; min-height: 44px; }
  .ssrs-acal-d { font-size: .74rem; }
  .ssrs-acal-sym { font-size: .8rem; }
  .ssrs-acal-head { padding: 20px 16px 12px; }
  .ssrs-acal-legend { padding: 6px 16px 10px; gap: 8px; }
  .ssrs-acal-title { font-size: 1rem; }
}

/* 詳細パネル */
.ssrs-acal-detail {
  margin: 0 16px 20px;
  background: #f8faff;
  border: 1.5px solid rgba(26,86,219,.18);
  border-radius: 14px;
  position: relative;
  overflow: hidden;
}
.ssrs-acd-inner { padding: 20px 22px; }
.ssrs-acd-close {
  position: absolute;
  top: 12px; right: 14px;
  font-size: .88rem;
  color: var(--ink-3, #888);
  cursor: pointer;
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: rgba(0,0,0,.06);
  transition: background .15s;
}
.ssrs-acd-close:hover { background: rgba(0,0,0,.12); }
.ssrs-acd-date {
  font-size: .96rem;
  font-weight: 800;
  color: var(--ink, #0d1117);
  margin-bottom: 8px;
}
.ssrs-acd-status {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .88rem;
  font-weight: 700;
  margin-bottom: 10px;
}
.ssrs-acd-sym { font-size: 1.2rem; }
.ssrs-acd-status small { font-size: .76rem; font-weight: 400; color: var(--ink-3,#888); }
.status-ex .ssrs-acd-sym { color: #1d4ed8; }
.status-ok .ssrs-acd-sym { color: #15803d; }
.status-lt .ssrs-acd-sym { color: #a16207; }
.status-ng .ssrs-acd-sym { color: #b91c1c; }

.ssrs-acd-slots { margin-bottom: 14px; }
.ssrs-acd-slots-label { font-size: .72rem; font-weight: 700; color: var(--ink-3,#888); margin-bottom: 6px; }
.ssrs-acd-slot {
  display: inline-block;
  background: #fff;
  border: 1px solid rgba(26,86,219,.2);
  color: #1d4ed8;
  font-size: .78rem;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 999px;
  margin: 0 4px 4px 0;
}
.ssrs-acd-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--accent, #1a56db);
  color: #fff;
  font-size: .85rem;
  font-weight: 800;
  padding: 11px 20px;
  border-radius: 10px;
  text-decoration: none;
  transition: background .18s, transform .14s;
  box-shadow: 0 4px 16px rgba(26,86,219,.28);
}
.ssrs-acd-btn:hover { background: #1e40af; transform: translateY(-1px); color: #fff; }

/* 固定CTAボタン（モバイルのみ） */
.ssrs-acal-fixed-cta {
  display: none;
  position: fixed;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9000;
  background: var(--accent, #1a56db);
  color: #fff;
  font-size: .9rem;
  font-weight: 800;
  padding: 15px 28px;
  border-radius: 999px;
  text-decoration: none;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  box-shadow: 0 6px 28px rgba(26,86,219,.4);
  transition: background .18s;
  max-width: calc(100vw - 32px);
}
.ssrs-acal-fixed-cta:hover { background: #1e40af; color: #fff; }
@media(max-width: 640px) { .ssrs-acal-fixed-cta { display: inline-flex !important; } }

/* ════════════════════════════════════════════════════
   メインCTA（今すぐ予約）・銀行振込サブリンク
════════════════════════════════════════════════════ */
/* メインCTAの色 */
.ssrs-cta-main,
.opa-btn.ssrs-cta-main {
  background: linear-gradient(135deg, #059669 0%, #047857 100%) !important;
  box-shadow: 0 4px 18px rgba(5,150,105,.36) !important;
}
.ssrs-cta-main:hover { background: linear-gradient(135deg,#047857 0%,#065f46 100%) !important; }

/* フルワイドCTAボタン */
.ssrs-cta-full {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 18px;
  background: linear-gradient(135deg, #059669 0%, #047857 100%);
  color: #fff !important;
  font-size: 1.05rem;
  font-weight: 800;
  border-radius: 16px;
  text-decoration: none !important;
  box-shadow: 0 6px 28px rgba(5,150,105,.32);
  letter-spacing: -.01em;
  transition: transform .14s, box-shadow .14s;
}
.ssrs-cta-full:hover { transform: translateY(-2px); box-shadow: 0 10px 36px rgba(5,150,105,.4); }
.ssrs-cta-note { text-align:center; font-size:.72rem; color:var(--ink-3,#888); margin:6px 0 0; }

/* OR区切り */
.ssrs-divider-or {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 24px 0;
  color: var(--ink-3,#888);
  font-size: .82rem;
}
.ssrs-divider-or::before,
.ssrs-divider-or::after { content:''; flex:1; height:1px; background:rgba(0,0,0,.1); }

/* 銀行振込テキストリンク */
.ssrs-bank-toggle-link {
  display: block;
  text-align: center;
  font-size: .78rem;
  font-weight: 700;
  color: var(--ink-3,#888);
  margin-top: 10px;
  text-decoration: underline;
}
.ssrs-bank-toggle-link:hover { color: var(--ink,#0d1117); }

/* ════════════════════════════════════════════════════
   銀行振込 仮予約フォーム
════════════════════════════════════════════════════ */
/* ════════════════════════════════════════════════════
   銀行振込フォーム - 実際のclass名に合わせたCSS
   ラッパー: .ssrs-v2bk-wrap / フォーム: .ssrs-v2bk-form
════════════════════════════════════════════════════ */
.ssrs-v2bk-section { background: var(--bg,#f8f8f5); }
.ssrs-v2bk-section .container { padding-top: 0; }

/* ── カード本体 ── */
.ssrs-v2bk-wrap {
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 2px 16px rgba(0,0,0,.07);
  max-width: 820px;
  margin: 0 auto;
}
@media(max-width:640px) { .ssrs-v2bk-wrap { border-radius: 12px; margin: 0 2px; } }

/* ── ヘッダー ── */
.ssrs-bk-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 18px 28px;
  background: linear-gradient(135deg,#f0f4ff 0%,#fafbfc 100%);
  border-bottom: 1px solid rgba(0,0,0,.07);
  font-weight: 800;
  font-size: .95rem;
  color: var(--ink,#0d1117);
  letter-spacing: -.01em;
}
@media(max-width:640px) { .ssrs-bk-head { padding: 14px 18px; font-size: .88rem; } }

/* ── フォーム本体 ── */
.ssrs-v2bk-form {
  padding: 28px 32px 32px;
}
@media(max-width:640px) { .ssrs-v2bk-form { padding: 18px 16px 24px; } }

/* legacy .ssrs-bk-body は未使用のため無効化 */
.ssrs-bk-body { padding: 0; }

/* 注意事項ボックス */
.ssrs-v2bk-form .ssrs-bk-warn,
.ssrs-bk-warn {
  background: #fffbf0;
  border: 1px solid #fde68a;
  border-left: 4px solid #f59e0b;
  border-radius: 10px;
  padding: 16px 18px;
  font-size: .82rem;
  line-height: 1.75;
  color: #78350f;
  margin-bottom: 24px;
}
.ssrs-v2bk-form .ssrs-bk-warn strong,
.ssrs-bk-warn strong { display:block; margin-bottom:8px; font-size:.86rem; color:#92400e; }
.ssrs-v2bk-form .ssrs-bk-warn ul,
.ssrs-bk-warn ul { margin:0; padding-left:18px; }
.ssrs-v2bk-form .ssrs-bk-warn li,
.ssrs-bk-warn li { margin-bottom:3px; }

/* フォームフィールド */
.ssrs-v2bk-form .ssrs-bk-row,
.ssrs-bk-row {
  display: grid;
  gap: 20px;
  margin-bottom: 20px;
}
.ssrs-v2bk-form .ssrs-bk-row-2,
.ssrs-bk-row-2 { grid-template-columns: 1fr 1fr; }
@media(max-width:640px) {
  .ssrs-v2bk-form .ssrs-bk-row-2,
  .ssrs-bk-row-2 { grid-template-columns: 1fr; gap: 16px; }
}

.ssrs-v2bk-form .ssrs-bk-field,
.ssrs-bk-field {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: 20px;
}
.ssrs-v2bk-form .ssrs-bk-row .ssrs-bk-field,
.ssrs-bk-row .ssrs-bk-field { margin-bottom: 0; }

.ssrs-v2bk-form .ssrs-bk-lbl,
.ssrs-bk-lbl {
  font-size: .8rem;
  font-weight: 700;
  color: #374151;
  letter-spacing: .01em;
}
.ssrs-req::after { content: ' *'; color: #dc2626; }

/* ── 入力欄（.ssrs-v2bk-form 内で確実に適用） ── */
.ssrs-v2bk-form .ssrs-bk-inp,
.ssrs-bk-inp {
  width: 100%;
  height: 48px;
  border: 1.5px solid #e5e7eb;
  border-radius: 10px;
  padding: 0 14px;
  font-size: .92rem;
  font-family: inherit;
  color: var(--ink,#0d1117);
  background: #fff;
  outline: none;
  transition: border-color .18s, box-shadow .18s, background .18s;
  -webkit-appearance: none;
  box-sizing: border-box;
  display: block;
}
.ssrs-v2bk-form .ssrs-bk-inp::placeholder,
.ssrs-bk-inp::placeholder { color: #9ca3af; }
.ssrs-v2bk-form .ssrs-bk-inp:hover,
.ssrs-bk-inp:hover { border-color: #9ca3af; }
.ssrs-v2bk-form .ssrs-bk-inp:focus,
.ssrs-bk-inp:focus {
  border-color: #059669;
  box-shadow: 0 0 0 3px rgba(5,150,105,.12);
  background: #fff;
}
.ssrs-v2bk-form .ssrs-bk-ta,
.ssrs-bk-ta {
  height: auto;
  min-height: 90px;
  padding: 12px 14px;
  resize: vertical;
  line-height: 1.7;
}

/* セレクト */
.ssrs-v2bk-form .ssrs-bk-sel-wrap,
.ssrs-bk-sel-wrap { position: relative; }
.ssrs-v2bk-form .ssrs-bk-sel,
.ssrs-bk-sel {
  width: 100%;
  height: 48px;
  border: 1.5px solid #e5e7eb;
  border-radius: 10px;
  padding: 0 40px 0 14px;
  font-size: .92rem;
  font-family: inherit;
  color: var(--ink,#0d1117);
  background: #fff;
  -webkit-appearance: none;
  appearance: none;
  outline: none;
  cursor: pointer;
  transition: border-color .18s, box-shadow .18s;
  box-sizing: border-box;
  display: block;
}
.ssrs-v2bk-form .ssrs-bk-sel:hover,
.ssrs-bk-sel:hover { border-color: #9ca3af; }
.ssrs-v2bk-form .ssrs-bk-sel:focus,
.ssrs-bk-sel:focus { border-color: #059669; box-shadow: 0 0 0 3px rgba(5,150,105,.12); }
.ssrs-v2bk-form .ssrs-bk-sel-wrap::after,
.ssrs-bk-sel-wrap::after {
  content: '';
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  border: 5px solid transparent;
  border-top-color: #6b7280;
  border-bottom: none;
  pointer-events: none;
}

/* セクション区切り */
.ssrs-v2bk-section-label {
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(135deg,#059669,#047857);
  display: inline-block;
  padding: 4px 12px;
  border-radius: 5px;
  margin: 28px 0 14px;
}

/* 振込先ボックス */
.ssrs-v2bk-bank-box {
  background: linear-gradient(135deg,#eff6ff,#f0f9ff);
  border: 1px solid rgba(26,86,219,.15);
  border-radius: 12px;
  padding: 16px 18px;
  margin-bottom: 20px;
  display: flex;
  gap: 12px;
  align-items: baseline;
}
.ssrs-v2bk-bank-lbl {
  font-size: .74rem;
  font-weight: 800;
  color: #1e40af;
  white-space: nowrap;
  flex-shrink: 0;
}
.ssrs-v2bk-bank-val {
  font-size: .86rem;
  line-height: 1.8;
  color: var(--ink,#0d1117);
}

/* 同意チェック */
.ssrs-v2bk-form .ssrs-bk-agree,
.ssrs-bk-agree {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: .84rem;
  line-height: 1.65;
  color: #374151;
  margin-bottom: 20px;
  cursor: pointer;
  padding: 14px 16px;
  background: #f9fafb;
  border-radius: 10px;
  border: 1px solid #e5e7eb;
  transition: background .15s;
}
.ssrs-v2bk-form .ssrs-bk-agree:hover,
.ssrs-bk-agree:hover { background: #f0fdf4; border-color: #a7f3d0; }
.ssrs-v2bk-form .ssrs-bk-agree input,
.ssrs-bk-agree input {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: 2px;
  accent-color: #059669;
  cursor: pointer;
}

/* エラー */
.ssrs-bk-err {
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 9px;
  padding: 12px 15px;
  font-size: .83rem;
  color: #b91c1c;
  margin-bottom: 14px;
}

/* 送信ボタン */
.ssrs-v2bk-form .ssrs-bk-submit,
.ssrs-bk-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 16px;
  background: linear-gradient(135deg, #059669 0%, #047857 100%);
  color: #fff;
  font-size: .95rem;
  font-weight: 800;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  font-family: inherit;
  box-shadow: 0 4px 20px rgba(5,150,105,.35);
  transition: transform .15s, box-shadow .15s;
  letter-spacing: -.01em;
}
.ssrs-v2bk-form .ssrs-bk-submit:hover,
.ssrs-bk-submit:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(5,150,105,.42); }
.ssrs-v2bk-form .ssrs-bk-submit:disabled,
.ssrs-bk-submit:disabled { opacity:.6; transform:none; cursor:not-allowed; box-shadow:none; }

/* 成功メッセージ */
.ssrs-bk-success {
  text-align: center;
  padding: 32px 20px;
  color: var(--ink,#0d1117);
}
.ssrs-bk-success svg { color: #059669; margin-bottom: 12px; }
.ssrs-bk-success h3 { font-size: 1.1rem; font-weight:800; margin:0 0 10px; }
.ssrs-bk-success p { font-size:.86rem; color:var(--ink-2,#3d4452); line-height:1.8; margin:0 0 10px; }
.ssrs-bk-code-lbl { font-size:.82rem; color:var(--ink-3,#888); }
.ssrs-bk-code-lbl strong { color:var(--accent,#1a56db); font-size:1rem; }

/* ════════════════════════════════════════════
   仮予約フォーム v2 デザイン修正
════════════════════════════════════════════ */

/* セクションラベル */
.ssrs-v2bk-section-label {
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent, #1a56db);
  background: #e8efff;
  display: inline-block;
  padding: 3px 10px;
  border-radius: 4px;
  margin: 18px 0 10px;
}

/* 振込先ボックス */
.ssrs-v2bk-bank-box {
  background: #f0f4ff;
  border: 1px solid rgba(26,86,219,.16);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 16px;
  display: flex;
  gap: 10px;
  align-items: baseline;
}
.ssrs-v2bk-bank-lbl {
  font-size: .76rem;
  font-weight: 800;
  color: var(--accent, #1a56db);
  white-space: nowrap;
  flex-shrink: 0;
}
.ssrs-v2bk-bank-val {
  font-size: .86rem;
  line-height: 1.75;
  color: var(--ink, #0d1117);
}

/* 注意事項（フォーム下部） */
.ssrs-bk-warn-bottom {
  margin-top: 20px !important;
  margin-bottom: 14px !important;
}

/* オプション無料バッジ */
.ssrs-v2bk-opt-free {
  font-size: .72rem;
  font-weight: 700;
  color: #059669;
  background: #dcfce7;
  padding: 1px 7px;
  border-radius: 999px;
  margin-left: 4px;
}

/* キャンセルボタン（成功画面内） */
.ssrs-v2bk-cancel-req-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: 1px solid #d1d5db;
  color: #6b7280;
  font-size: .78rem;
  font-weight: 600;
  padding: 8px 16px;
  border-radius: 8px;
  cursor: pointer;
  margin-top: 14px;
  font-family: inherit;
  transition: border-color .16s, color .16s;
}
.ssrs-v2bk-cancel-req-btn:hover { border-color: #dc2626; color: #dc2626; }

/* キャンセルモーダル */
/* ════ 仮予約キャンセルモーダル（body直下・z-index最前面） ════ */
.ssrs-modal-open {
  overflow: hidden !important;
  height: 100vh !important;
}
[id^="ssrs-cancel-modal-"] {
  position: fixed;
  inset: 0;
  z-index: 9999999 !important;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.ssrs-cm-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 0;
  cursor: pointer;
}
.ssrs-cm-panel {
  position: relative;
  z-index: 1;
  background: #fff;
  width: 100%;
  max-width: 600px;
  max-height: calc(100vh - 48px);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,.25);
  display: flex;
  flex-direction: column;
}
.ssrs-cm-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid #f0f0ee;
  flex-shrink: 0;
}
.ssrs-cm-title {
  font-size: 1rem;
  font-weight: 800;
  margin: 0;
  color: var(--ink,#0d1117);
}
.ssrs-cm-close-btn {
  width: 30px; height: 30px;
  border-radius: 50%; border: none;
  background: rgba(0,0,0,.07);
  cursor: pointer; font-size: .9rem;
  display: flex; align-items: center; justify-content: center;
}
.ssrs-cm-body {
  padding: 20px 24px;
  overflow-y: auto;
  flex: 1;
}
.ssrs-cm-info-box {
  background: #f0fdf4; border: 1px solid #bbf7d0;
  border-radius: 12px; padding: 16px 18px; margin-bottom: 16px;
}
.ssrs-cm-info-label { font-size:.8rem; font-weight:800; color:#059669; margin-bottom:8px; }
.ssrs-cm-info-text  { font-size:.84rem; color:#374151; line-height:1.75; }
.ssrs-cm-note       { font-size:.8rem; color:#6b7280; line-height:1.7; margin:0; }
.ssrs-cm-footer {
  background: #fff;
  padding: 16px 24px;
  border-top: 1px solid #e5e7eb;
  display: flex; gap: 10px;
  flex-shrink: 0;
}
.ssrs-cm-btn-cancel {
  flex: 1; display:flex; align-items:center; justify-content:center;
  background:#dc2626; color:#fff !important;
  font-size:.88rem; font-weight:800; padding:12px 20px;
  border-radius:10px; text-decoration:none !important; text-align:center;
}
.ssrs-cm-btn-close {
  padding:12px 20px; border:1px solid #d1d5db; border-radius:10px;
  background:#fff; cursor:pointer; font-size:.88rem; font-weight:700;
  font-family:inherit; color:var(--ink-2,#3d4452);
}
@media(max-width:640px) {
  [id^="ssrs-cancel-modal-"] { align-items:flex-end; padding:0; }
  .ssrs-cm-panel { max-width:100%; max-height:90vh; border-radius:20px 20px 0 0; }
  .ssrs-cm-body { padding:16px 18px; }
  .ssrs-cm-footer { padding:14px 18px; flex-direction:column; }
  .ssrs-cm-btn-cancel, .ssrs-cm-btn-close { width:100%; text-align:center; }
}

/* ════ 料金ボックス改善 ════ */
.ssrs-v2bk-price-box { border: 1.5px solid rgba(26,86,219,.18) !important; }
.ssrs-v2bk-price-box-noset { border: 1.5px solid #e5e7eb !important; background: #f8f8f5 !important; }
.ssrs-v2bk-price-err {
  background: #fff8f0;
  border: 1px solid #fbbf24;
  border-radius: 8px;
  padding: 9px 12px;
  font-size: .8rem;
  font-weight: 700;
  color: #92400e;
  margin-top: 10px;
}

/* ════ 月間カレンダー: 本日バッジ・選択強調 ════ */
.ssrs-acal-today-badge {
  position: absolute;
  top: 4px;
  left: 50%;
  transform: translateX(-50%);
  font-size: .56rem;
  font-weight: 800;
  color: var(--accent, #1a56db);
  letter-spacing: .04em;
  white-space: nowrap;
  line-height: 1;
}
/* 本日セルのdを少し下げてバッジと重ならないように */
.ssrs-acal-cell.is-today .ssrs-acal-d { margin-top: 6px; }

/* クリック選択された日付のハイライト */
.ssrs-acal-cell.is-selected {
  border: 2.5px solid var(--accent, #1a56db) !important;
  box-shadow:
    0 0 0 3px rgba(26,86,219,.13),
    0 4px 16px rgba(26,86,219,.16) !important;
  z-index: 3;
  transform: scale(1.07);
}
/* is-today はアクセント色枠のまま維持 */
.ssrs-acal-cell.is-today.is-selected {
  border-color: var(--accent, #1a56db) !important;
}

/* ════════════════════════════════════════════════════
   ssrs-v2bk-form 内部: 実際のHTML要素向け確実適用CSS
════════════════════════════════════════════════════ */

/* 日付・時間ブロック */
.ssrs-v2bk-datetime-block {
  margin-bottom: 20px;
}

/* 時間の横並び */
.ssrs-v2bk-time-row {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: end;
  gap: 10px;
  margin-top: 14px;
}
.ssrs-v2bk-time-sep {
  font-size: 1.1rem;
  color: #9ca3af;
  padding-bottom: 12px;
  text-align: center;
}
@media(max-width:480px) {
  .ssrs-v2bk-time-row { grid-template-columns: 1fr 20px 1fr; gap: 6px; }
}

/* スロット読み込みメッセージ */
.ssrs-v2bk-slot-msg {
  font-size: .8rem;
  padding: 6px 2px;
  line-height: 1.5;
}

/* お客様情報セクション */
.ssrs-v2bk-section-label {
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(135deg,#059669,#047857);
  display: inline-block;
  padding: 4px 12px;
  border-radius: 5px;
  margin: 28px 0 14px;
}

/* 料金ボックス */
.ssrs-v2bk-price-box {
  background: linear-gradient(135deg,#f0fdf4,#ecfdf5);
  border: 1.5px solid #6ee7b7;
  border-radius: 12px;
  padding: 16px 18px;
  margin-bottom: 20px;
}
.ssrs-v2bk-price-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .9rem;
  padding: 5px 0;
  color: #374151;
}
.ssrs-v2bk-price-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 1.05rem;
  font-weight: 800;
  color: #059669;
  border-top: 1.5px solid #a7f3d0;
  margin-top: 10px;
  padding-top: 10px;
}
.ssrs-v2bk-price-err {
  background: #fff8f0;
  border: 1px solid #fbbf24;
  border-radius: 8px;
  padding: 9px 12px;
  font-size: .8rem;
  font-weight: 700;
  color: #92400e;
  margin-top: 10px;
}

/* オプション */
.ssrs-v2bk-opts { margin-top: 12px; }
.ssrs-v2bk-opts-lbl { font-size: .78rem; font-weight: 700; color: #6b7280; margin-bottom: 8px; }
.ssrs-v2bk-opt-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .86rem;
  padding: 8px 0;
  cursor: pointer;
  border-bottom: 1px solid #f3f4f6;
}
.ssrs-v2bk-opt-free {
  font-size: .72rem;
  font-weight: 700;
  color: #059669;
  background: #dcfce7;
  padding: 1px 7px;
  border-radius: 999px;
}

/* 振込先ボックス */
.ssrs-v2bk-bank-box {
  background: linear-gradient(135deg,#eff6ff,#f0f9ff);
  border: 1px solid rgba(26,86,219,.15);
  border-radius: 12px;
  padding: 16px 18px;
  margin-bottom: 20px;
  display: flex;
  gap: 12px;
  align-items: baseline;
  flex-wrap: wrap;
}
.ssrs-v2bk-bank-lbl {
  font-size: .74rem;
  font-weight: 800;
  color: #1e40af;
  white-space: nowrap;
  flex-shrink: 0;
}
.ssrs-v2bk-bank-val {
  font-size: .86rem;
  line-height: 1.8;
  color: var(--ink,#0d1117);
  word-break: break-all;
}

/* 成功画面 */
.ssrs-bk-success {
  text-align: center;
  padding: 36px 20px;
  color: var(--ink,#0d1117);
}
.ssrs-bk-success svg { color: #059669; margin-bottom: 14px; }
.ssrs-bk-success h3 { font-size: 1.15rem; font-weight: 800; margin-bottom: 10px; }
.ssrs-bk-success p { font-size: .88rem; color: #6b7280; line-height: 1.75; margin-bottom: 6px; }
.ssrs-bk-code-lbl { font-size: .9rem; margin-top: 12px; }

/* スマホ全体最適化 */
@media(max-width:640px) {
  .ssrs-v2bk-section .container { padding-left: 12px; padding-right: 12px; }
  .ssrs-v2bk-wrap { margin: 0; border-radius: 12px; }
  .ssrs-v2bk-form { padding: 16px 14px 24px !important; }
  .ssrs-v2bk-form .ssrs-bk-row-2 { grid-template-columns: 1fr !important; }
}
