/* =========================
   Kobe Safe Deposit Center - style.css（整理版 / 最適化）
   - SPファースト
   - 基本構成は維持（見た目の骨格は変えない）
   - 変更点：運営体制（ops）の文字サイズを少し上げて可読性改善
   - 重複/不要なパッチを削除して整理
========================= */

/* =========================
   Tokens
========================= */
:root{
  --bg:#0b2a21;
  --bg2:#082018;

  --text:#f3f1ea;
  --muted:rgba(243,241,234,.78);

  --gold:#d7b56d;
  --gold2:#b8923f;

  --line:rgba(215,181,109,.22);
  --line-strong:rgba(215,181,109,.35);

  --panel:rgba(6,18,14,.45);
  --panel-strong:rgba(6,18,14,.55);

  --shadow:0 12px 30px rgba(0,0,0,.35);
  --radius:18px;
}

/* =========================
   Base
========================= */
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }

body{
  font-family: system-ui, -apple-system, "Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", sans-serif;
  background: linear-gradient(180deg, var(--bg2), var(--bg));
  color: var(--text);
  line-height: 1.85;
  -webkit-text-size-adjust: 100%;
}

img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
a:focus-visible{ outline:2px solid rgba(215,181,109,.7); outline-offset:3px; }

.container{
  width: min(1100px, 92%);
  margin: 0 auto;
}
.center{ text-align:center; }

/* =========================
   Buttons（共通）
========================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;

  padding:.9rem 1.1rem;
  border-radius:999px;
  border:1px solid rgba(243,241,234,.22);

  background:rgba(255,255,255,.06);
  box-shadow:0 10px 26px rgba(0,0,0,.20);
  font-weight:700;
  letter-spacing:.02em;

  transition:transform .15s ease, background .15s ease, border-color .15s ease, opacity .15s ease;
  cursor:pointer;
  user-select:none;
}

.btn:hover{ transform:translateY(-1px); border-color:rgba(215,181,109,.50); background:rgba(255,255,255,.09); }
.btn:active{ transform:translateY(0); opacity:.95; }

.btn-wide{ width:100%; }

.btn-gold{
  background:linear-gradient(180deg, var(--gold), var(--gold2));
  color:#1a1a1a;
  border:1px solid rgba(0,0,0,.10);
}
.btn-gold:hover{ background:linear-gradient(180deg, #e3c27a, #c39b45); }

.btn-ghost{
  background:rgba(8,32,24,.45);
  border:1px solid var(--line-strong);
}

/* =========================
   Header（固定 / CTAは必ずボタン表示）
========================= */
.site-header{
  position: fixed;
  top:0;
  left:0;
  width:100%;
  z-index: 2000;

  background: rgba(7,22,17,.65);
  border-bottom: 1px solid rgba(215,181,109,.18);
  backdrop-filter: blur(10px);
}

.header-inner{
  width: min(1100px, 92%);
  margin: 0 auto;

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 10px 0;
}

.header-left{
  display:flex;
  align-items:center;
  gap:14px;
  flex:1 1 auto;
  min-width:0;
}

.header-cta{
  display:flex;
  align-items:center;
  gap:8px;
  flex:0 0 auto;
}

/* header CTA（btnクラスを使っていないので、ここでボタン化） */
.site-header .header-cta a{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  height: 36px;
  padding: 0 14px;
  border-radius: 999px;

  font-size: 13px;
  font-weight: 800;
  letter-spacing: .02em;
  white-space: nowrap;

  border: 1px solid rgba(212,170,79,.55);
  background: rgba(6,18,14,.62);
  box-shadow: 0 8px 18px rgba(0,0,0,.25);
  cursor:pointer;
}

.site-header .header-cta a.btn-gold{
  background: linear-gradient(180deg, #e3c27a 0%, #c39b45 100%);
  color: #1a1a1a;
  border-color: rgba(0,0,0,.10);
}

/* Header nav (left) */
.header-nav{
  display:flex;
  align-items:center;
  gap:14px;
}

.header-link{
  display:inline-flex;
  align-items:center;
  padding:8px 10px;
  border-radius:10px;
  color:var(--text);
  text-decoration:none;
  font-weight:600;
  letter-spacing:.02em;
  opacity:.92;
  transition:opacity .15s ease, background-color .15s ease, transform .15s ease;
}

/* Mobile: prevent header items from collapsing */
@media (max-width: 520px){
  .header-inner{
    flex-wrap: wrap;
    gap: 10px;
  }
  .header-cta{
    order: 1;
    margin-left: auto;
  }
  .header-left{
    order: 2;
    flex: 1 1 100%;
  }
  .header-nav{
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .header-nav::-webkit-scrollbar{ display:none; }
  .header-link{
    padding: 8px 8px;
    font-size: 14px;
  }
  .site-header .header-cta a{
    height: 34px;
    padding: 0 12px;
    font-size: 12.5px;
  }
}

.header-link:hover{
  opacity:1;
  background:rgba(215,181,109,.10);
}

.header-link:active{
  transform:translateY(1px);
}

/* スマホ：ナビは詰めて、必要なら横スクロール */
@media (max-width: 640px){
  .header-nav{
    gap:8px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .header-nav::-webkit-scrollbar{ display:none; }
  .header-link{
    padding:8px 8px;
    white-space:nowrap;
  }
}

/* 固定ヘッダー分のオフセット */
main#top{ padding-top: 64px; }

/* =========================
   Hero / FV
========================= */
.hero{
  position:relative;
  min-height: 560px;
  display:flex;
  align-items:center;
  justify-content:center;

  padding: 48px 0 46px;
  overflow:hidden;
  border-bottom:1px solid rgba(215,181,109,.18);
}

.hero-bg{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(90deg, rgba(8,32,24,.62) 0%, rgba(8,32,24,.34) 45%, rgba(8,32,24,.12) 70%, rgba(8,32,24,.04) 100%),
    url("/assets/img/fv/fv-bg.png");
  background-size: cover, cover;
  background-position: center, center;
  filter: brightness(1.12) contrast(1.03) saturate(1.02);
  transform: scale(1.02);
  pointer-events:none;
}

.hero-overlay{
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 500px at 28% 40%, rgba(0,0,0,.06), rgba(0,0,0,.42)),
    linear-gradient(90deg, rgba(8,32,24,.62) 0%, rgba(8,32,24,.34) 44%, rgba(8,32,24,.12) 72%, rgba(8,32,24,.04) 100%);
  pointer-events:none;
}

.hero-inner{
  position:relative;
  z-index:2;
  width:100%;
  display:flex;
  justify-content:center;
}

.hero-panel{
  width: min(560px, 100%);
  padding: 24px 20px;
  border-radius: var(--radius);
  background: rgba(6,18,14,.40);
  border: none;
  box-shadow: var(--shadow);
}

.fv-brand{ margin: 0 0 12px; text-align:center; }
.fv-brand img{
  width:100%;
  max-width: 380px;
  margin: 0 auto;
}

.hero-kicker{
  margin:0 0 8px;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(215,181,109,.90);
  text-align:center;
}

.hero-title{
  margin:0 0 10px;
  font-size: clamp(26px, 7vw, 40px);
  line-height:1.18;
  letter-spacing:.03em;
  text-align:center;
}
.hero-title .gold{ color: var(--gold); }

.fv-lead{
  margin: 12px 0 6px;
  font-size: 16px;
  letter-spacing: .08em;
  color: rgba(243,241,234,.92);
  text-align:center;
}

.fv-desc{
  margin: 0 0 12px;
  font-size: 14px;
  line-height: 1.9;
  color: rgba(243,241,234,.86);
  text-align:center;
}

.hero-cta{ margin-top: 14px; }
.hero-cta-row{
  display:grid;
  grid-template-columns: 1fr;
  gap:10px;
  margin-top:10px;
}
.hero-note{
  margin:10px 0 0;
  font-size:12px;
  color: rgba(243,241,234,.72);
  text-align:center;
}

/* =========================
   Story
========================= */
.story-section{ width:100%; padding:72px 0; }
.story-inner{ max-width:880px; margin:0 auto; padding:0 24px; }
.story-inner h2{ font-size:26px; font-weight:700; margin:0 0 18px; line-height:1.4; }
.story-lead{ color: var(--gold); margin:0 0 22px; }
.story-inner p{ line-height:2.0; margin:0 0 16px; color: rgba(243,241,234,.86); }

/* =========================
   Sections（汎用）
========================= */
.section{ padding:54px 0; }
.section-soft{
  background: rgba(0,0,0,.12);
  border-top: 1px solid rgba(215,181,109,.14);
  border-bottom: 1px solid rgba(215,181,109,.14);
}
.section-title{
  margin:0 0 10px;
  font-size: clamp(22px, 5.2vw, 30px);
  line-height:1.25;
  letter-spacing:.03em;
}
.section-sub{
  margin:0 0 22px;
  color: var(--muted);
  font-size:14px;
}
.section-text{
  margin:0;
  color: rgba(243,241,234,.80);
}
.section-text--note{
  margin-top:14px;
  color: rgba(243,241,234,.72);
  font-size:12px;
}

/* =========================
   Ops（運営体制） ※ここだけ可読性UP（文字サイズ微増）
========================= */
.ops{ padding:72px 0; }
.ops-inner{ width:min(980px, 100%); }

.ops-head, .ops-body{
  max-width: 72ch;
  margin-left:auto;
  margin-right:auto;
}

.ops-highlights{
  display:grid;
  grid-template-columns: 1fr;
  gap:14px;
  margin:22px 0 26px;
}

.ops-hl{
  border:1px solid var(--line-strong);
  border-radius:16px;
  padding:16px 16px;
  background: rgba(0,0,0,.16);
}

.ops-hl-label{
  margin:0 0 4px;
  font-size:12px;
  letter-spacing:.12em;
  opacity:.85;
}

/* ★変更：14px → 15px */
.ops-hl-value{
  margin:0;
  font-size:15px;
  line-height:1.85;
}

/* ★変更：14px → 15px（SPでも読み疲れ軽減） */
.ops-body p{
  margin:0 0 14px;
  font-size:15px;
  line-height:2.05;
  opacity:.92;
}
.ops-body strong{ color: var(--gold); font-weight:700; }

/* ★変更：14px → 15px（引用ブロックも同じ階調に揃える） */
.ops-quote{
  margin-top:22px;
  padding:18px 16px;
  border-left:3px solid rgba(215,181,109,.55);
  background: rgba(0,0,0,.12);
  border-radius:12px;
  font-size:15px;
  line-height:2.05;
}

/* Ops visual（既存の見た目維持） */
.ops-visual{
  margin: 18px 0 22px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.12);
  box-shadow: 0 10px 28px rgba(0,0,0,0.35);
}
.ops-visual img{
  width: 100%;
  height: auto;
  display: block;
}

/* =========================
   Promise（3つの約束 / 代理人ポイント共用）
========================= */
.promise{
  padding: 54px 0;
  width: min(1100px, 92%);
  margin: 0 auto;
}

.promise-cards{
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;
  margin-top: 18px;
}

.promise-card{
  position: relative;
  border-radius:16px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
  padding:18px 14px 16px;
}

.promise-card-head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
}

.promise-no{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 44px;
  height: 28px;
  padding: 0 10px;

  border-radius:999px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;

  color: #1a1a1a;
  background: linear-gradient(180deg, var(--gold), var(--gold2));
  border: 1px solid rgba(0,0,0,.12);

  box-shadow: 0 6px 18px rgba(0,0,0,.28);
}

.promise-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 60px;
  height: 28px;
  padding: 0 12px;

  border-radius:999px;
  background: rgba(215,181,109,.18);
  border:1px solid rgba(215,181,109,.35);
  color: rgba(243,241,234,.92);
  font-weight:900;
  font-size:12px;
  letter-spacing:.06em;
}

.promise-title,
.promise-card-title{
  margin:0;
  font-size:16px;
  line-height:1.35;
  color:#fff;
}

.promise-text,
.promise-card-text{
  margin:0;
  font-size:14px;
  line-height:1.7;
  color: rgba(243,241,234,.78);
}

.promise-box{
  margin-top:22px;
  padding:22px 16px;
  border-radius:var(--radius);
  background: var(--panel-strong);
  border:1px solid var(--line-strong);
  box-shadow: 0 14px 32px rgba(0,0,0,.35);
}

.promise-title--compact{ margin-bottom:14px; text-align:center; }

/* 登録代理人制度：要点強調 */
.agent-emphasis{
  color: #d4b36a;
  font-weight: 600;
}

/* =========================
   Band（画像＋コピー）
========================= */
.band{ padding:44px 0; }
.band-inner{
  display:grid;
  grid-template-columns: 1fr;
  gap:14px;
  align-items:center;
}
.band-media{
  border-radius: var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow: var(--shadow);
}
.band-media img{
  width:100%;
  height:260px;
  object-fit:cover;
}
.band-body{ padding:0 4px; }

/* =========================
   Plans（料金）
========================= */
.plans{ padding:72px 0; }
.plans-inner{ width: min(1100px, 92%); margin:0 auto; }

.plan-note{
  margin:0 0 22px;
  font-size:14px;
  line-height:1.8;
  opacity:.9;
}

.plans-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap:16px;
  align-items:stretch;
}

.plan-card{
  position:relative;
  border:1px solid rgba(215,181,109,.35);
  border-radius:18px;
  padding:22px 18px;
  background: rgba(0,0,0,.16);
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
  display:flex;
  flex-direction:column;
}

.plan-head{
  padding-bottom:14px;
  margin-bottom:14px;
  border-bottom:1px solid rgba(215,181,109,.18);
}

.plan-title{ font-size:18px; margin:0 0 6px; line-height:1.4; }
.plan-sub{ margin:0; font-size:13px; opacity:.85; }

.plan-badge{
  position:absolute;
  top:14px;
  right:14px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  border:1px solid rgba(215,181,109,.55);
  color: var(--gold);
  background: rgba(0,0,0,.25);
  letter-spacing:.06em;
}

.plan-card--recommend{
  border-color: rgba(215,181,109,.55);
  box-shadow: 0 12px 34px rgba(0,0,0,.22);
}

.plan-price{
  margin:14px 0 12px;
  font-weight:700;
  letter-spacing:.02em;
}
.price-main{ font-size:34px; color: var(--gold); }
.price-unit{ font-size:15px; margin-left:6px; opacity:.92; }

.plan-list{
  margin: 0;
  padding-left: 18px;
  font-size:14px;
  line-height:1.9;
}
.plan-list li{ margin:6px 0; opacity:.92; }

/* 創設会員：強調 */
.plan-card--founder{
  border-color: rgba(215,181,109,.70);
  box-shadow: 0 16px 40px rgba(0,0,0,.30), 0 0 0 2px rgba(215,181,109,.18);
  background: linear-gradient(180deg, rgba(215,181,109,.08), rgba(0,0,0,.16));
}
.plan-card--founder::before{
  content: "先着100名限定";
  position:absolute;
  top:14px;
  left:14px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.06em;
  color:#1a1a1a;
  background: linear-gradient(180deg, var(--gold), var(--gold2));
  border: 1px solid rgba(0,0,0,.10);
}

/* 創設会員を「下段フル幅」にするクラス */
.plan-card--full{ grid-column: 1 / -1; }

.plan-founder-title{
  display:inline-block;
  margin:6px 0 12px;
  padding:6px 12px;
  border-radius:999px;
  border:1px solid rgba(215,181,109,.55);
  color: var(--gold);
  font-weight:800;
  font-size:13px;
  letter-spacing:.08em;
  background: rgba(215,181,109,.10);
}

/* 創設会員（2行価格） */
.founder-prices{
  margin: 12px 0 12px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(215,181,109,.55);
  background: linear-gradient(180deg, rgba(215,181,109,.14), rgba(0,0,0,.10));
  box-shadow: 0 10px 22px rgba(0,0,0,.20), inset 0 0 0 1px rgba(255,255,255,.05);
  display: grid;
  gap: 10px;
}
.founder-price + .founder-price{
  border-top: 1px solid rgba(215,181,109,.18);
  padding-top: 12px;
}
.founder-row{
  display:grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  gap:10px;
}
.founder-label{ font-weight:900; color: rgba(243,241,234,.92); }
.founder-price-big{ display:inline-flex; align-items:baseline; gap:6px; white-space:nowrap; }
.founder-num{
  font-size: 38px;
  font-weight: 900;
  letter-spacing: .04em;
  color: var(--gold);
  line-height: 1;
  text-shadow: 0 2px 0 rgba(0,0,0,.35), 0 0 18px rgba(215,181,109,.22);
}
.founder-unit{ font-size:14px; color: rgba(243,241,234,.88); }
.founder-note{ font-size:12px; color: rgba(243,241,234,.72); }

.plan-legal-note{
  margin-top: 18px;
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
  font-size: 12px;
  line-height: 1.8;
  color: rgba(243,241,234,.70);
}
.plan-legal-note p{ margin: 0; }

/* =========================
   Case size（ケースサイズ）
========================= */
.case-layout{
  margin-top:18px;
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;
  align-items:stretch;
}

.case-visual,
.case-card{
  border-radius: var(--radius);
  border:1px solid var(--line);
  background: rgba(6,18,14,.45);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
  padding:16px 14px;
}

.case-visual{ background: rgba(6,18,14,.35); }
.case-visual img{ width:100%; height:200px; object-fit:contain; }
.case-visual-caption{ margin:10px 0 0; font-size:12px; color: rgba(243,241,234,.72); text-align:center; }

.case-card-main{ border-color: rgba(215,181,109,.45); }

.case-card-head{ display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.case-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:64px;
  height:28px;
  padding:0 12px;

  border-radius:999px;
  background: rgba(215,181,109,.18);
  border:1px solid rgba(215,181,109,.35);
  color: rgba(243,241,234,.92);
  font-weight:900;
  font-size:12px;
  letter-spacing:.06em;
}
.case-card-title{ margin:0; font-size:16px; line-height:1.35; }
.case-card-text{ margin:0 0 10px; font-size:14px; line-height:1.75; color: rgba(243,241,234,.78); }
.case-card-size{ margin:0; font-size:14px; color: rgba(243,241,234,.88); }
.case-note{ margin-top:14px; font-size:12px; color: rgba(243,241,234,.72); }

/* =========================
   FAQ（details）
========================= */
.faq{ margin-top:14px; max-width:860px; margin-left:auto; margin-right:auto; }

.faq-item{
  border-radius:14px;
  border:1px solid var(--line);
  background: rgba(6,18,14,.40);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
  margin:10px 0;
  overflow:hidden;
}

.faq-item summary{
  cursor:pointer;
  padding:14px 14px;
  font-weight:800;
  list-style:none;
}
.faq-item summary::-webkit-details-marker{ display:none; }

.faq-body{
  padding:14px 18px 18px;
  color: rgba(243,241,234,.80);
  border-top:1px solid rgba(215,181,109,.14);
}

/* FAQ：faq-a でも faq-body と同じ見た目にする（互換パッチ） */
.faq-a{
  padding:14px 18px 18px;
  color: rgba(243,241,234,.80);
  border-top: 1px solid rgba(215,181,109,.14);
}

/* 読みやすさ（行幅・行間） */
.faq-a p,
.faq-body p{
  margin: 0;
  max-width: 62ch;
  line-height: 1.9;
  font-size: 15px;
}

@media (min-width: 900px) {
  .faq-a p,
  .faq-body p{
    max-width: 68ch;
  }
}

/* =========================
   Access
========================= */
section#access{
  padding-top: 80px;
  padding-bottom: 72px;
}
@media (max-width: 768px){
  section#access{
    padding-top: 56px;
    padding-bottom: 56px;
  }
}

.access-inner{ max-width: 1100px; }

.access-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap:16px;
  margin-top: 18px;
}

.access-photo img{
  width: 100%;
  height: auto;
  border-radius: 16px;
  border:1px solid rgba(215,181,109,.20);
}

.access-list{
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 10px 14px;
  font-size: 14px;
}

.access-list dt{ color: var(--gold); font-weight: 800; }
.access-map{
  margin-top: 18px;
  border-radius: 16px;
  overflow: hidden;
  border:1px solid rgba(215,181,109,.20);
}
.access-map iframe{
  width: 100%;
  height: 300px;
  border: 0;
}

/* =========================
   Contact
========================= */
.contact{ padding:56px 0; }
.contact-inner{
  border-radius: var(--radius);
  border:1px solid var(--line);
  background: var(--panel);
  box-shadow: var(--shadow);
  padding:26px 18px;
}
.contact-cta{
  margin-top:16px;
  max-width:720px;
  margin-left:auto;
  margin-right:auto;
}
.contact .hero-cta-row{ grid-template-columns: 1fr; }

/* =========================
   Law（特商法：折りたたみ）
========================= */
.law-details{
  max-width: 860px;
  margin: 0 auto;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: rgba(6,18,14,.40);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
  overflow: hidden;
}

.law-summary{
  cursor: pointer;
  padding: 16px 18px;
  font-weight: 900;
  text-align: center;
  list-style: none;
  color: #fff;
  position: relative;
}
.law-summary::-webkit-details-marker{ display:none; }

.law-summary::after{
  content: "＋";
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 18px;
  color: var(--gold);
}
.law-details[open] .law-summary::after{ content:"－"; }

.law-body{
  border-top: 1px solid rgba(215,181,109,.14);
  padding: 18px 16px 20px;
}

.law-list{
  max-width: 860px;
  margin: 0 auto;
}
.law-list dt{
  margin-top: 16px;
  font-weight: 900;
  color: #fff;
}
.law-list dd{
  margin: 6px 0 0;
  color: rgba(243,241,234,.82);
  line-height: 1.8;
}

/* =========================
   Footer
========================= */
.site-footer{
  padding:26px 0;
  border-top:1px solid rgba(215,181,109,.18);
  background: rgba(6,18,14,.55);
}
.footer-inner{ text-align:center; }
.footer-small{
  margin:4px 0;
  color: rgba(243,241,234,.72);
  font-size:12px;
}
.footer-copy{
  margin:10px 0 0;
  color: rgba(243,241,234,.62);
  font-size:12px;
}

/* =========================
   金庫室保管セクション
========================= */
.vault-keep{ padding: 72px 0; }
.vault-keep-inner{
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  align-items: center;
}
.vault-keep-media{
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
}
.vault-keep-media img{ width: 100%; height: auto; display: block; }
.vault-keep-body p{ margin-top: 12px; line-height: 1.9; }
.vault-keep-points{ margin: 14px 0 0; padding-left: 1.2em; line-height: 1.9; }
.vault-keep-points li{ margin: 6px 0; }

/* =========================
   Tablet（768〜）
========================= */
@media (min-width: 768px){
  main#top{ padding-top: 72px; }

  .site-header .header-cta a{
    height: 40px;
    padding: 0 18px;
    font-size: 14px;
  }

  .hero-cta-row{ grid-template-columns: 1fr 1fr; }

  .ops-highlights{ grid-template-columns: repeat(3, minmax(0, 1fr)); }

  .promise-cards{ grid-template-columns: repeat(3, minmax(0, 1fr)); }

  .band-inner{ grid-template-columns: 1.05fr .95fr; gap:18px; }
  .band-media img{ height:320px; }

  /* 料金：2カラム＋下段フル幅（創設会員） */
  .plans-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px;
  }
  .plans-grid .plan-card--full{
    grid-column: 1 / -1;
    grid-row: 2;
  }

  .case-layout{ grid-template-columns: .95fr 1fr 1fr; gap:16px; }

  .access-grid{ grid-template-columns: 1.1fr 1fr; gap: 32px; margin-top: 28px; }
  .access-map iframe{ height: 360px; }

  /* 金庫室：PC/タブレットは横並び */
  .vault-keep-inner{
    grid-template-columns: 1.05fr 0.95fr;
    gap: 28px;
  }
}

/* Ops visual：PCでは最大幅を絞って品を出す */
@media (min-width: 900px){
  .ops-visual{
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* =========================
   PC（1000〜）：FVを“センターから少し左”
========================= */
@media (min-width: 1000px){
  .hero-inner{ justify-content: center; }
  .hero-panel{
    max-width: 560px;
    transform: translateX(-40%);
  }
}
/* 仮申込セクションの補足文（PCでの視認性調整） */
@media (min-width: 768px) {
  .contact .section-lead {
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 768px) {
  .contact .contact-lead {
    font-size: 1.15em;
    line-height: 1.8;
  }
}
/* 画像注記（セキュリティ配慮） */
.vault-keep-media { position: relative; }

.vault-keep-media .image-note{
  display: block;
  width: 100%;
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.4;
  text-align: right !important;
  color: rgba(255, 255, 255, 0.75) !important;
}
/* =========================
   Column (Blog) - add-on
   末尾に追記
========================= */

/* Hero */
.column-hero{
  padding: 90px 0 38px;
  border-bottom: 1px solid rgba(215,181,109,.18);
}
.column-hero__inner{
  width: min(1100px, 92%);
  margin: 0 auto;
  text-align: center;
}
.column-hero__title{
  margin: 0 0 6px;
  font-size: clamp(28px, 6vw, 44px);
  letter-spacing: .08em;
}
.column-hero__lead{
  margin: 0 0 18px;
  color: rgba(243,241,234,.82);
}
.column-search{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  max-width: 720px;
  margin: 0 auto 14px;
  padding: 14px;
  border-radius: 999px;
  border: 1px solid rgba(215,181,109,.22);
  background: rgba(6,18,14,.40);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
}
.column-search__input{
  width: 100%;
  background: transparent;
  border: 0;
  outline: 0;
  color: #fff;
  font-size: 14px;
  padding: 6px 10px;
}

/* Tags */
.column-tags{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}
.tag{
  display:inline-flex;
  align-items:center;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid rgba(215,181,109,.28);
  background: rgba(215,181,109,.10);
  font-size: 12px;
  font-weight: 800;
  color: rgba(243,241,234,.90);
}

/* Sections */
.column-section{ padding: 54px 0; }
.column-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 16px;
}

/* Cards */
.post-card a{
  display:block;
  border-radius: 18px;
  border: 1px solid rgba(215,181,109,.22);
  background: rgba(6,18,14,.40);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
  overflow:hidden;
}
.post-card__thumb{
  width: 100%;
  height: 200px;
  object-fit: cover;
}
.post-card__body{
  padding: 14px 14px 10px;
}
.meta{
  margin: 0 0 6px;
  font-size: 12px;
  color: rgba(243,241,234,.72);
  display:flex;
  gap:10px;
  align-items:center;
}
.badge{
  display:inline-flex;
  align-items:center;
  height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(215,181,109,.35);
  background: rgba(215,181,109,.12);
  color: rgba(243,241,234,.92);
  font-weight: 900;
  letter-spacing: .06em;
}
.post-card__title{
  margin: 0 0 8px;
  font-size: 16px;
  line-height: 1.45;
}
.post-card__excerpt{
  margin: 0 0 12px;
  font-size: 14px;
  color: rgba(243,241,234,.80);
  line-height: 1.8;
}
.btn-gold-sm{
  height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  border: 1px solid rgba(0,0,0,.10);
  background: linear-gradient(180deg, var(--gold), var(--gold2));
  color: #1a1a1a;
  margin: 0 14px 14px;
}

/* Featured */
.featured-card{
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(215,181,109,.25);
  background: rgba(6,18,14,.40);
  box-shadow: 0 14px 34px rgba(0,0,0,.35);
}
.featured-card__link{
  display:grid;
  grid-template-columns: 1fr;
}
.featured-card__media img{
  width: 100%;
  height: 240px;
  object-fit: cover;
}
.featured-card__body{ padding: 16px; }
.featured-card__title{
  margin: 6px 0 10px;
  font-size: 18px;
  line-height: 1.4;
}
.featured-card__excerpt{
  margin: 0 0 14px;
  color: rgba(243,241,234,.82);
}

/* Article */
.article-hero{
  padding: 92px 0 22px;
  border-bottom: 1px solid rgba(215,181,109,.18);
}
.article-title{
  margin: 10px 0 10px;
  font-size: clamp(24px, 5.6vw, 36px);
  line-height: 1.25;
}
.article-lead{
  margin: 0;
  color: rgba(243,241,234,.84);
}
.article-eyecatch{
  margin: 22px 0;
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(215,181,109,.18);
  box-shadow: 0 10px 26px rgba(0,0,0,.25);
}
.article-body{
  max-width: 78ch;
  margin: 0 auto;
  padding: 10px 0 54px;
}
.article-body h2{
  margin: 30px 0 12px;
  padding-left: 12px;
  border-left: 3px solid rgba(215,181,109,.55);
  font-size: 20px;
}
.article-body h3{
  margin: 18px 0 10px;
  font-size: 16px;
  color: rgba(243,241,234,.95);
}
.callout{
  margin: 16px 0;
  padding: 16px;
  border-radius: 14px;
  border: 1px solid rgba(215,181,109,.22);
  background: rgba(0,0,0,.12);
}

@media (min-width: 768px){
  .column-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .post-card__thumb{ height: 180px; }
  .featured-card__link{ grid-template-columns: 1.05fr .95fr; }
  .featured-card__media img{ height: 100%; min-height: 280px; }
}


/* =========================
   Lovable-like polish layer (overrides)
   - section rhythm + gold dividers
   - type hierarchy (serif-like headings)
   - glass cards consistency
========================= */

/* Layout rhythm */
.lp{ padding-top: 72px; } /* fixed header offset */
.lp > section{
  padding: 84px 0;
}
.lp > section.hero{ padding: 0; }
.lp > section + section{
  border-top: 1px solid rgba(215,181,109,.16);
}

/* Headings */
.hero-title,
.section-title,
.story-section h2,
.vault-keep h2,
.ops h2,
.pricing h2,
.faq h2,
.columns h2,
.access h2,
.cta h2{
  font-family: ui-serif, "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", serif;
  letter-spacing: .02em;
}

.section-title{
  font-size: clamp(26px, 3.2vw, 38px);
  line-height: 1.25;
  color: var(--gold);
  margin: 0 0 22px;
}

/* Kicker style */
.kicker,
.hero-kicker{
  font-size: 12px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: rgba(215,181,109,.78);
}

/* Hero refinement */
.hero{
  position: relative;
  min-height: 86vh;
  display: grid;
  place-items: center;
}
.hero-inner{ padding: 90px 0 68px; }
.hero-panel{
  border-radius: 28px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 24px 70px rgba(0,0,0,.45);
  backdrop-filter: blur(8px);
}
.hero-title{ font-size: clamp(38px, 4.4vw, 56px); line-height: 1.08; }
.hero .fv-lead{ font-size: 16px; opacity: .95; }
.hero .fv-desc{ opacity: .82; }

/* Buttons: align with lovable */
.btn{
  box-shadow: 0 14px 34px rgba(0,0,0,.26);
}
.btn-ghost{
  background: rgba(6,18,14,.50);
  border-color: rgba(215,181,109,.32);
}
.btn-ghost:hover{ border-color: rgba(215,181,109,.55); }

/* Glass card utility */
.card-glass{
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 20px 60px rgba(0,0,0,.40);
  backdrop-filter: blur(10px);
  border-radius: 24px;
}

/* Story section: two-column friendly defaults */
.story-section .story-inner{
  width: min(1100px, 92%);
  margin: 0 auto;
}

/* Pricing image with consistent framing (prevents white background from popping) */
.pricing img{
  border-radius: 20px;
}
.pricing .case-image,
.pricing .case-photo,
.pricing .case-wrap{
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(215,181,109,.18);
  border-radius: 24px;
  padding: 18px;
  display: grid;
  place-items: center;
}

/* FAQ: tighter, clearer */
.faq .faq-list{
  margin-top: 22px;
}
.faq-item{
  border-color: rgba(215,181,109,.16);
  background: rgba(0,0,0,.10);
}
.faq-q{
  font-weight: 700;
}
.faq-a p{ opacity: .90; }

/* Section containers: keep consistent width */
.story-section .story-inner,
.vault-keep .container,
.faq .container,
.ops .container,
.pricing .container,
.columns .container,
.access .container,
.cta .container{
  width: min(1100px, 92%);
}

/* Responsive tune */
@media (max-width: 640px){
  .lp > section{ padding: 64px 0; }
  .hero-inner{ padding: 86px 0 56px; }
  .hero-panel{ border-radius: 22px; }
}



/* =========================
   Lovable polish v2 (mobile + key sections)
========================= */

/* Hero CTA: side-by-side on larger screens */
@media (min-width: 640px){
  .hero-cta-row{
    grid-template-columns: 1fr 1fr;
    gap:12px;
  }
}

/* Case visual: tame the white background image */
.case-visual{
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(215,181,109,.18);
  border-radius: 24px;
  padding: 16px;
  box-shadow: 0 18px 50px rgba(0,0,0,.35);
}
.case-visual img{
  width: 100%;
  height: auto;
  border-radius: 18px;
  display:block;
}

/* Plans: keep cards consistent spacing on mobile */
.plans-inner{
  width: min(1100px, 92%);
  margin: 0 auto;
}
@media (max-width: 640px){
  .plan-grid{ gap:14px; }
  .plan-card{ border-radius: 22px; }
}

/* Section dividers: slightly softer */
.lp > section + section{
  border-top-color: rgba(215,181,109,.12);
}

/* FAQ tap targets */
.faq-q{
  padding: 18px 14px;
}
.faq-item[open] .faq-q{
  color: rgba(243,241,234,.96);
}

/* =========================
   Columns insert (FORCE OVERRIDE)
   貼る場所：style.css の一番最後
========================= */

/* セクション見出しの呼吸 */
#columns.columns .section-lead{
  color: var(--muted);
  margin: 0 0 24px;
}

/* 3列→1列（スマホ）を強制 */
#columns .columns-grid{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
  margin-top: 18px;
}

/* カードのガラス感を強制 */
#columns .col-card{
  position: relative;
  display: block !important;
  padding: 18px 18px 16px !important;
  border-radius: 24px !important;
  background: rgba(0,0,0,.18) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,.40) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  text-decoration: none !important;
}

/* タイトル・本文 */
#columns .col-title{
  margin: 0 0 10px !important;
  color: rgba(243,241,234,.94) !important;
  font-size: 16px !important;
  line-height: 1.35 !important;
  font-weight: 700 !important;
}
#columns .col-excerpt{
  margin: 0 0 12px !important;
  color: rgba(243,241,234,.72) !important;
  font-size: 13px !important;
  line-height: 1.7 !important;
}

/* タグ */
#columns .col-tags{
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 10px !important;
}
#columns .tag{
  display: inline-block !important;
  font-size: 12px !important;
  padding: 6px 10px !important;
  border-radius: 999px !important;
  background: rgba(215,181,109,.10) !important;
  border: 1px solid rgba(215,181,109,.22) !important;
  color: rgba(215,181,109,.90) !important;
}

/* 矢印 */
#columns .col-arrow{
  position: absolute !important;
  right: 16px !important;
  top: 16px !important;
  color: rgba(215,181,109,.85) !important;
}

/* hover */
#columns .col-card:hover{
  border-color: rgba(215,181,109,.35) !important;
  transform: translateY(-1px);
  transition: .18s ease;
}

/* 下のボタン */
#columns .columns-more{
  margin-top: 18px;
  display: flex;
  justify-content: center;
}

/* レスポンシブ */
@media (max-width: 900px){
  #columns .columns-grid{
    grid-template-columns: 1fr !important;
  }
}
/* ===== Mincho polish: “大きすぎ”を抑えて上品に ===== */

/* 見出し（共通） */
.hero-title,
.section-title{
  letter-spacing: .01em;      /* 広すぎると間延び */
  line-height: 1.12;          /* 見出しは詰める方が締まる */
}

/* H1（FV）を控えめに */
.hero-title{
  font-size: clamp(32px, 3.6vw, 48px); /* 以前より-1段 */
}

/* セクション見出し（H2）も-1段 */
.section-title{
  font-size: clamp(22px, 2.4vw, 32px);
}

/* 本文は読みやすさ優先：明朝にしない（または薄く） */
body{
  font-family: -apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic","Noto Sans JP","Meiryo",sans-serif;
}

/* 見出しだけ明朝にする（上品さはここで出す） */
.hero-title,
.section-title,
.col-title{
  font-family: ui-serif,"Noto Serif JP","Hiragino Mincho ProN","Yu Mincho",serif;
  font-weight: 550; /* 700だと“ドン”と重い */
}

/* スマホはさらに一段抑える */
@media (max-width: 640px){
  .hero-title{ font-size: 34px; line-height: 1.10; }
  .section-title{ font-size: 24px; line-height: 1.12; }
}