/* ============================================================
   ESTHETICA PRO - main.css
   ライトテーマ（白ベース × ゴールドアクセント）
   ============================================================ */

/* ── カラー変数 ─────────────────────────────── */
:root {
  /* 背景 */
  --bg:    #ffffff;
  --bg2:   #f8f7f4;
  --bg3:   #f0ede6;
  --bg4:   #e8e4db;

  /* ゴールド */
  --gold:       #b8923a;
  --gold-light: #d4a84e;
  --gold-dim:   #9a7830;
  --gold-pale:  #f5eed9;
  --gold-pale2: #fdf9ef;

  /* テキスト */
  --text:   #1a1a1a;
  --text-2: #4a4540;
  --text-3: #8a8278;

  /* ボーダー */
  --border:  rgba(184,146,58,0.25);
  --border2: rgba(184,146,58,0.12);
  --border3: #e8e4db;

  /* その他 */
  --rose:       #c4607a;
  --line-green: #06C755;
  --line-dark:  #049a42;
  --shadow:     0 2px 12px rgba(0,0,0,0.07);
  --shadow-md:  0 4px 24px rgba(0,0,0,0.10);
}

/* ── リセット・基本 ─────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 300;
  line-height: 1.7;
  overflow-x: hidden;
}
img { max-width:100%; height:auto; display:block; }
a { color:inherit; }
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--bg2); }
::-webkit-scrollbar-thumb { background:var(--gold-dim); border-radius:2px; }

/* ── ヘッダー ──────────────────────────────── */
#site-header {
  position: fixed; top:0; left:0; right:0; z-index:100;
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border3);
  box-shadow: var(--shadow);
  padding: 0 2.5rem;
  display: flex; align-items:center; justify-content:space-between;
  height: 64px;
}
.logo-wrap { margin:0; padding:0; font-size:inherit; font-weight:inherit; }
.logo {
  display:flex; align-items:center; gap:0.5rem; text-decoration:none;
}
.logo-img { height:28px; width:auto; display:block; }
.logo-sub {
  font-weight:300; color:var(--text-3);
  font-size:9px; display:block;
  letter-spacing:0.15em; line-height:1.4; max-width:160px;
}
.global-nav { display:flex; gap:0; align-items:stretch; height:64px; }

/* 通常リンク */
.global-nav > a {
  display:flex; align-items:center;
  padding:0 1.25rem;
  color:var(--text-2); text-decoration:none;
  font-size:12px; letter-spacing:0.12em;
  transition:color 0.2s; font-weight:400;
  position:relative;
}
.global-nav > a:hover { color:var(--gold); }
.global-nav > a::after {
  content:''; position:absolute; bottom:0; left:50%; right:50%;
  height:2px; background:var(--gold);
  transition:left 0.2s, right 0.2s;
}
.global-nav > a:hover::after { left:1.25rem; right:1.25rem; }

/* ドロップダウン親 */
.nav-item {
  position:relative;
  display:flex; align-items:stretch;
}
.nav-item > a {
  display:flex; align-items:center;
  padding:0 1.25rem;
  color:var(--text-2); text-decoration:none;
  font-size:12px; letter-spacing:0.12em;
  transition:color 0.2s; font-weight:400;
  gap:5px; cursor:pointer;
  position:relative;
}
.nav-item > a::after {
  content:''; position:absolute; bottom:0; left:50%; right:50%;
  height:2px; background:var(--gold);
  transition:left 0.2s, right 0.2s;
}
.nav-item:hover > a { color:var(--gold); }
.nav-item:hover > a::after { left:1.25rem; right:1.25rem; }

/* ドロップダウン本体（ホバー＋隙間埋めパディング） */
.nav-dropdown {
  display:none; position:absolute;
  top:calc(100% - 1px); left:50%;
  transform:translateX(-50%);
  background:#fff; border:1px solid var(--border3);
  border-radius:8px; min-width:200px;
  padding:0.75rem 0;
  z-index:300;
  box-shadow:0 8px 32px rgba(0,0,0,0.12);
  /* ホバー領域を上に拡張してメニューが消えにくく */
  padding-top:calc(0.75rem + 8px);
  margin-top:-8px;
}
.nav-item:hover .nav-dropdown { display:block; }
.nav-dropdown a {
  display:flex; align-items:center; gap:8px;
  padding:0.7rem 1.5rem;
  font-size:12px; color:var(--text-2);
  letter-spacing:0.08em; white-space:nowrap;
  transition:all 0.15s; text-decoration:none;
}
.nav-dropdown a:hover { color:var(--gold); background:var(--gold-pale2); padding-left:1.75rem; }
.nav-dropdown-arrow {
  font-size:8px; opacity:0.5; margin-left:2px;
  display:inline-block; transition:transform 0.2s;
}
.nav-item:hover .nav-dropdown-arrow { transform:rotate(180deg); opacity:1; color:var(--gold); }

.header-btns { display:flex; gap:0.75rem; align-items:center; }

/* ── ハンバーガー ──────────────────────────── */
.hamburger {
  display:none; flex-direction:column; justify-content:center;
  gap:5px; width:36px; height:36px;
  background:none; border:none; cursor:pointer; padding:4px; z-index:102;
}
.hamburger span {
  display:block; width:22px; height:1.5px;
  background:var(--text-2); transition:all 0.3s; transform-origin:center;
}
.hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); background:var(--gold); }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); background:var(--gold); }

/* ── モバイルメニュー ──────────────────────── */
.mobile-menu {
  position:fixed; top:64px; left:0; right:0; bottom:0;
  background:rgba(255,255,255,0.99); backdrop-filter:blur(16px);
  z-index:101; display:flex; flex-direction:column;
  padding:1.5rem 0;
  transform:translateX(100%);
  transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);
  overflow-y:auto; border-top:1px solid var(--border3);
}
.mobile-menu.open { transform:translateX(0); }
.mn-item { border-bottom:1px solid var(--border3); }
.mn-link {
  display:block; padding:1.1rem 2rem;
  font-size:16px; font-family:'Noto Serif JP',serif;
  color:var(--text-2); letter-spacing:0.06em;
  text-decoration:none; transition:color 0.2s; font-weight:400;
}
.mn-link:hover { color:var(--gold); }
.mn-trigger {
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem 2rem;
  font-size:16px; font-family:'Noto Serif JP',serif;
  color:var(--text-2); letter-spacing:0.06em;
  cursor:pointer; transition:color 0.2s; user-select:none; font-weight:400;
}
.mn-trigger:hover, .mn-trigger.open { color:var(--gold); }
.mn-chevron {
  width:20px; height:20px; border:1px solid var(--border3); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:8px; color:var(--text-3); flex-shrink:0;
  transition:transform 0.3s, border-color 0.2s, color 0.2s;
}
.mn-trigger.open .mn-chevron { transform:rotate(180deg); border-color:var(--gold); color:var(--gold); }
.mn-children {
  max-height:0; overflow:hidden;
  transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1), opacity 0.3s;
  opacity:0; background:var(--gold-pale2);
}
.mn-children.open { opacity:1; }
.mn-child-link {
  display:flex; align-items:center; gap:0.75rem;
  padding:0.75rem 2rem 0.75rem 2.75rem;
  font-size:13px; color:var(--text-3); letter-spacing:0.06em;
  text-decoration:none; border-bottom:1px solid var(--border3);
  transition:color 0.2s, background 0.15s;
}
.mn-child-link:last-child { border-bottom:none; }
.mn-child-link:hover { color:var(--gold); background:var(--gold-pale); }
.mn-child-dot { width:4px; height:4px; border-radius:50%; background:var(--gold); flex-shrink:0; }
.mn-bottom {
  padding:1.75rem 2rem; margin-top:auto;
  border-top:1px solid var(--border3);
  display:flex; flex-direction:column; gap:0.75rem;
}
.mn-footer { padding:1.25rem 2rem 0; font-size:11px; color:var(--text-3); letter-spacing:0.1em; line-height:1.9; }

/* ── ボタン ─────────────────────────────────── */
.btn-ghost {
  background:none; border:1px solid var(--border);
  color:var(--text-2); padding:6px 18px;
  font-size:12px; letter-spacing:0.1em;
  font-family:inherit; cursor:pointer;
  transition:all 0.2s; border-radius:3px;
  text-decoration:none; display:inline-block; font-weight:400;
}
.btn-ghost:hover { border-color:var(--gold); color:var(--gold); background:var(--gold-pale2); }
.btn-gold {
  background:var(--gold); border:none;
  color:#fff; padding:7px 20px;
  font-size:12px; letter-spacing:0.1em;
  font-family:inherit; font-weight:500;
  cursor:pointer; transition:all 0.2s; border-radius:3px;
  text-decoration:none; display:inline-block;
}
.btn-gold:hover { background:var(--gold-light); }
.btn-primary {
  background:var(--gold); color:#fff; border:none;
  padding:14px 36px; font-size:13px; letter-spacing:0.15em;
  font-family:inherit; font-weight:500; cursor:pointer;
  transition:all 0.25s; border-radius:3px;
  text-decoration:none; display:inline-block;
}
.btn-primary:hover { background:var(--gold-light); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn-outline {
  background:none; color:var(--text-2);
  border:1px solid var(--border);
  padding:13px 36px; font-size:13px; letter-spacing:0.12em;
  font-family:inherit; cursor:pointer;
  transition:all 0.25s; border-radius:3px;
  text-decoration:none; display:inline-block; font-weight:400;
}
.btn-outline:hover { border-color:var(--gold); color:var(--gold); background:var(--gold-pale2); }
.btn-line {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--line-green); border:none; color:#fff;
  padding:9px 20px; font-size:12px; letter-spacing:0.1em;
  font-family:inherit; font-weight:500; cursor:pointer;
  transition:background 0.2s; border-radius:4px;
  white-space:nowrap;
}
.btn-line:hover { background:var(--line-dark); }
.btn-line-lg {
  display:inline-flex; align-items:center; gap:12px;
  background:var(--line-green); border:none; color:#fff;
  padding:16px 40px; font-size:14px; letter-spacing:0.15em;
  font-family:inherit; font-weight:500; cursor:pointer;
  transition:all 0.25s; border-radius:4px; margin-bottom:1rem;
}
.btn-line-lg:hover { background:var(--line-dark); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn-line-sm {
  display:inline-flex;
  align-items:center;
  gap:7px;
  background:var(--line-green);
  border:none;
  color:#fff;
  padding: 14px 18px;
  font-size:12px;
  letter-spacing:0.1em;
  font-family:inherit;
  font-weight:500;
  cursor:pointer;
  transition:background 0.2s;
  border-radius:3px;
  white-space:nowrap;
  text-align: center;
  justify-content: center;
}
.btn-line-sm:hover { background:var(--line-dark); }
.btn-line-full {
  display:flex; align-items:center; justify-content:center; gap:10px;
  background:var(--line-green); border:none; color:#fff;
  padding:14px; font-size:13px; letter-spacing:0.15em;
  font-family:inherit; font-weight:500; cursor:pointer;
  transition:background 0.2s; border-radius:4px; width:100%;
}
.btn-line-full:hover { background:var(--line-dark); }
.btn-compare {
  display:flex; align-items:center; justify-content:center; gap:8px;
  background:none; border:1px solid var(--border); color:var(--text-2);
  padding:12px; font-size:12px; letter-spacing:0.12em;
  font-family:inherit; cursor:pointer;
  transition:all 0.2s; border-radius:3px; width:100%;
  text-decoration:none; font-weight:400;
}
.btn-compare:hover { border-color:var(--gold); color:var(--gold); background:var(--gold-pale2); }
.btn-ask {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--gold); border:none; color:#fff;
  padding:12px 24px; font-size:13px; letter-spacing:0.12em;
  font-family:inherit; font-weight:500; cursor:pointer;
  transition:all 0.2s; border-radius:3px;
}
.btn-ask:hover { background:var(--gold-light); }
.btn-line-modal {
  width:100%; display:flex; align-items:center; justify-content:center;
  gap:10px; background:var(--line-green); border:none; color:#fff;
  padding:13px; font-size:13px; letter-spacing:0.15em;
  font-family:inherit; font-weight:500; cursor:pointer;
  border-radius:4px; margin-bottom:1rem; transition:background 0.2s;
  text-decoration:none;
}
.btn-line-modal:hover { background:var(--line-dark); }
.form-submit {
  width:100%; background:var(--gold); border:none;
  color:#fff; padding:13px; font-size:13px; letter-spacing:0.2em;
  font-family:inherit; font-weight:500; cursor:pointer;
  border-radius:3px; margin-top:0.5rem; transition:background 0.2s;
}
.form-submit:hover { background:var(--gold-light); }

/* ── セクション共通 ─────────────────────────── */
.section { padding:6rem 2.5rem; max-width:1200px; margin:0 auto; }
.section-header { text-align:center; margin-bottom:4rem; }
.section-eyebrow { font-size:10px; letter-spacing:0.45em; color:var(--gold); margin-bottom:1rem; }
.section-title { font-family:'Cormorant Garamond',serif; font-size:clamp(28px,4vw,44px); font-weight:400; color:var(--text); letter-spacing:0.03em; line-height:1.2; }
.section-title em { font-style:normal; color:var(--gold); }
.section-sub {font-size: 14px;color:var(--text-3);margin-top:1rem;letter-spacing:0.05em;}
.divider { width:40px; height:2px; background:var(--gold); margin:1.5rem auto; border-radius:1px; }

/* ── ヒーロー（トップ） ─────────────────────── */
.hero {
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  padding:0 2rem;
  overflow:hidden;
  /* background:#0a0a0a; */
}
.hero-video {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; pointer-events:none;
}
@media (max-width: 768px) {
  .hero-video {object-position: 63%;}
}
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.35) 50%, rgba(0,0,0,0.6) 100%);
  pointer-events:none;
}
@keyframes slideUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
.hero-content {
  text-align:center;
  max-width:800px;
  position:relative;
  z-index:1;
  animation:slideUp 1s ease forwards;
  padding-top: 20%;
}
.hero-eyebrow {font-size:10px;letter-spacing:0.45em;color:var(--gold-light);margin-bottom:2rem;padding-top: 2rem;}
.hero-title {
  font-family:'Cormorant Garamond',serif;
  font-size: clamp(28px,7vw,62px);
  font-weight:300;
  line-height:1.15;
  color:#fff;
  margin-bottom:1.5rem;
  letter-spacing:0.04em;
}
.hero-title em { font-style:normal; color:var(--gold-light); }
.company-tag {
  display:inline-flex; align-items:center; gap:0.6rem;
  background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.25);
  backdrop-filter:blur(8px);
  padding:6px 16px; border-radius:20px; margin-bottom:1.5rem;
  font-size:11px; color:#fff; letter-spacing:0.1em;
}
.company-tag::before {/* content:''; */display:inline-block;width:6px;height:6px;background:var(--gold-light);border-radius:50%;}
.hero-sub {font-size: 15px;color:#fff;max-width:500px;margin:0 auto 2.5rem;letter-spacing:0.05em;line-height:2.1;}
.hero-cta { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-bottom:3rem; }
.btn-outline-light {
  display:inline-block; padding:14px 36px; border-radius:6px; font-size:13px;
  letter-spacing:0.15em; text-decoration:none; font-weight:400;
  border:1px solid rgba(255,255,255,0.4); color:#fff; transition:all 0.2s;
}
.btn-outline-light:hover { border-color:var(--gold-light); color:var(--gold-light); }

/* ヒーロー内統計 */
.hero-stats {
  display:flex; justify-content:center; gap:2.5rem; flex-wrap:wrap;
  padding:1.5rem 2rem; border-radius:12px;
  background:rgba(0,0,0,0.3); backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,0.15);
}
.hero-stat-item { text-align:center; min-width:80px; }
.hero-stat-num {
  font-family:'Noto Sans JP',sans-serif; font-size:32px; font-weight:700;
  color:var(--gold-light); line-height:1; margin-bottom:0.3rem;
}
.hero-stat-label { font-size:10px; color:#fff; letter-spacing:0.12em; }

.sp-only { display:none; }
@media (max-width: 768px) {
  .sp-only { display:inline; }
  .hero { min-height:90vh; }
  .hero-stats { gap:1.5rem; padding:1rem 1.25rem; }
  .hero-stat-num { font-size:24px; }
  .hero-stat-label { font-size:9px; }
  .company-tag {font-size: 14px;padding:8px 18px;line-height:1.6;text-align:center;}
}
.stat { text-align:center; }
.stat-num { font-family:'Noto Sans JP',sans-serif; font-size:30px; font-weight:400; color:var(--gold); line-height:1; }
.stat-label { font-size:11px; color:var(--text-3); letter-spacing:0.2em; margin-top:4px; }

/* ── カテゴリーグリッド ─────────────────────── */
.categories-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.category-card {
  position:relative; background:#fff;
  overflow:hidden; cursor:pointer;
  transition:all 0.3s; min-height:280px;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:2.5rem; border-radius:6px;
  border:1px solid var(--border3); box-shadow:var(--shadow);
}
.category-card:hover { border-color:var(--gold); box-shadow:var(--shadow-md); transform:translateY(-2px); }
.cat-pattern {
  position:absolute; top:0; left:0; right:0; height:55%; z-index:0;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, var(--gold-pale2) 0%, var(--gold-pale) 100%);
}
.cat-img {
  position:absolute; top:0; left:0; right:0; height:55%; z-index:0;
  overflow:hidden;
}
.cat-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.3s; }
.category-card:hover .cat-img img { transform:scale(1.05); }
.cat-pattern-num {
  font-size:80px; opacity:0.15; color:var(--gold);
  font-family:'Noto Sans JP',sans-serif; font-weight:300;
}
.cat-content { position:relative; z-index:2; }
.cat-num {font-family:'Noto Sans JP',sans-serif;font-size:11px;color: #ffffff;letter-spacing:0.3em;margin-bottom:0.5rem;}
.cat-title {font-family:'Noto Serif JP',serif;font-size: 20px;font-weight:400;color:var(--text);margin-bottom:0.4rem;letter-spacing:0.05em;}
.cat-sub { font-size:11px; color:var(--text-3); letter-spacing:0.1em; margin-bottom:1rem; }
.cat-count {display:inline-flex;align-items:center;gap:0.5rem;font-size: 14px;color:var(--gold);letter-spacing:0.15em;}
.cat-count::before { content:''; display:inline-block; width:14px; height:2px; background:var(--gold); border-radius:1px; }

/* ── 機器グリッド ──────────────────────────── */
.products-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
@media (max-width: 1024px) { .products-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width: 600px) { .products-grid { grid-template-columns:1fr; } }
.prod-card {
  background:#fff; padding:1.75rem; cursor:pointer;
  transition:all 0.2s; border-radius:6px;
  border:1px solid var(--border3); box-shadow:var(--shadow);
}
.prod-card:hover { border-color:var(--gold); box-shadow:var(--shadow-md); transform:translateY(-2px); }
.pc-badges { display:flex; gap:0.4rem; margin-bottom:1rem; flex-wrap:wrap; }
.pc-badge { font-size:9px; letter-spacing:0.15em; padding:2px 8px; border-radius:10px; border:1px solid; }
.pc-badge.top { color:var(--gold); border-color:var(--gold); background:var(--gold-pale); }
.pc-badge.new { color:var(--rose); border-color:var(--rose); background:#fdf0f3; }
.pc-badge.cat { color:var(--gold-dim); border-color:var(--border); background:var(--gold-pale2); }
.pc-img {
  height:140px; background:var(--gold-pale2); border-radius:4px;
  margin-bottom:1.25rem; display:flex; align-items:center; justify-content:center;
  font-size:14px; letter-spacing:0.12em; font-weight:500; color:var(--gold-dim);
  border:1px solid var(--border3); transition:opacity 0.2s;
  font-family:'Noto Sans JP',sans-serif;
}
.prod-card:hover .pc-img { opacity:0.85; }
.pc-name { font-family:'Noto Serif JP',serif; font-size:15px; font-weight:400; color:var(--text); margin-bottom:0.25rem; letter-spacing:0.02em; }
.pc-maker { font-size:11px; color:var(--text-3); letter-spacing:0.08em; margin-bottom:0.75rem; }
.pc-stars { display:flex; align-items:center; gap:2px; margin-bottom:0.6rem; }
.pc-star { color:var(--gold); font-size:13px; }
.pc-star.e { color:var(--bg4); }
.pc-rnum { font-family:'Noto Sans JP',sans-serif; font-size:13px; color:var(--gold); margin-left:3px; font-weight:500; }
.pc-rct { font-size:10px; color:var(--text-3); margin-left:2px; }
.pc-tags { display:flex; gap:0.4rem; flex-wrap:wrap; margin-bottom:0.875rem; }
.pc-tag { font-size:9px; letter-spacing:0.08em; color:var(--text-3); background:var(--bg2); padding:2px 8px; border-radius:10px; border:1px solid var(--border3); }
.pc-price { font-family:'Noto Sans JP',sans-serif; font-size:22px; color:var(--gold-dim); font-weight:700; letter-spacing:0.02em; }
.pc-price span { font-size:11px; color:var(--text-3); font-weight:400; }
.pc-repair { display:inline-flex; align-items:center; gap:4px; margin-top:0.5rem; font-size:10px; color:var(--gold-dim); background:var(--gold-pale2); border:1px solid var(--border2); border-radius:4px; padding:0.2rem 0.5rem; white-space:nowrap; }

/* ── 口コミ ─────────────────────────────────── */
.review-section { background:var(--bg2); border-top:1px solid var(--border3); border-bottom:1px solid var(--border3); padding:6rem 0; }
.review-inner { max-width:1200px; margin:0 auto; padding:0 2.5rem; box-sizing:border-box; }
@media (max-width: 768px) { .review-inner { padding:0 1.25rem; } }
.reviews-list { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-top:3rem; }
@media (max-width: 768px) { .reviews-list { grid-template-columns:1fr; } }
.review-teaser-card { background:#fff; border:1px solid var(--border3); border-radius:6px; overflow:hidden; box-shadow:var(--shadow); display:flex; flex-direction:column; }
.review-visible { padding:1.75rem 2rem 0; }
.review-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:1rem; }
.reviewer { display:flex; align-items:center; gap:0.75rem; }
.avatar {
  width:40px; height:40px; border-radius:50%;
  background:var(--gold-pale); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:13px; color:var(--gold); font-family:'Cormorant Garamond',serif; font-weight:500;
}
.reviewer-name { font-size:13px; color:var(--text); font-weight:500; }
.reviewer-type { font-size:11px; color:var(--text-3); letter-spacing:0.08em; }
.review-date { font-size:11px; color:var(--text-3); }
.review-product { font-size:11px; letter-spacing:0.12em; color:var(--gold-dim); margin-bottom:0.75rem; padding-bottom:0.75rem; border-bottom:1px solid var(--border3); }
.r-stars { display:flex; align-items:center; gap:3px; margin-bottom:0.75rem; }
.star { color:var(--gold); font-size:14px; }
.star.empty { color:var(--bg4); }
.rating-num { font-family:'Noto Sans JP',sans-serif; font-size:15px; color:var(--gold); margin-left:4px; font-weight:500; }
.review-open-text { font-size:13px; color:var(--text-2); line-height:2; padding-bottom:1.25rem; }
.review-fade-wrap { position:relative; }
.review-fade-text { font-size:13px; color:var(--text-2); line-height:2; padding:1rem 2rem 0; }
.review-fade-overlay { position:absolute; left:0; right:0; bottom:0; height:80px; background:linear-gradient(to bottom, transparent 0%, #fff 100%); pointer-events:none; }
.review-lock-bar { padding:1.25rem 2rem 1.75rem; display:flex; align-items:center; justify-content:space-between; gap:1rem; border-top:1px solid var(--border3); }
.lock-left { display:flex; align-items:center; gap:0.75rem; }
.lock-icon { font-size:16px; color:var(--gold); }
.lock-text { font-size:12px; color:var(--text-3); letter-spacing:0.04em; line-height:1.6; }
.lock-text strong { color:var(--text-2); font-weight:500; }

/* ── LINE セクション ─────────────────────────── */
.line-section { background:var(--gold-pale2); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:5rem 0; }
.line-inner { max-width:580px; margin:0 auto; padding:0 2.5rem; text-align:center; }
.line-eyebrow { font-size:10px; letter-spacing:0.4em; color:var(--line-green); margin-bottom:1rem; }
.line-title { font-family:'Cormorant Garamond',serif; font-size:clamp(26px,4vw,40px); font-weight:400; color:var(--text); margin-bottom:1rem; letter-spacing:0.04em; }
.line-sub { font-size:13px; color:var(--text-2); line-height:2; margin-bottom:2.5rem; letter-spacing:0.04em; }

/* ── トップページ共通セクション ──────────────── */
.fp-section { padding:6rem 0; }
.bg-alt { background:var(--bg2); }
@media (max-width: 768px) { .fp-section { padding:3.5rem 0; } }

/* ── カテゴリー別ランキング ────────────────── */
.cat-ranking-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.cat-rank-block { background:#fff; border:1px solid var(--border3); border-radius:10px; padding:1.5rem; }
.cat-rank-title { font-family:'Noto Serif JP',serif; font-size:16px; font-weight:400; margin-bottom:1rem; padding-bottom:0.75rem; border-bottom:1px solid var(--border3); }
.cat-rank-title a { text-decoration:none; color:var(--text); }
.cat-rank-title a:hover { color:var(--gold); }
.cat-rank-list { display:flex; flex-direction:column; gap:0.6rem; margin-bottom:1rem; }
.cat-rank-item { display:flex; align-items:center; gap:0.6rem; text-decoration:none; padding:0.5rem; border-radius:6px; transition:background 0.2s; }
.cat-rank-item:hover { background:var(--bg2); }
.cat-rank-medal { font-size:20px; flex-shrink:0; width:28px; text-align:center; }
.cat-rank-thumb { flex-shrink:0; width:50px; border-radius:4px; overflow:hidden; }
.cat-rank-info { flex:1; min-width:0; }
.cat-rank-name { font-size:13px; font-weight:500; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cat-rank-meta { font-size:10px; color:var(--text-3); }
.cat-rank-score { text-align:right; flex-shrink:0; }
.cat-rank-stars { font-size:14px; color:var(--gold); font-weight:600; }
.cat-rank-count { font-size:10px; color:var(--text-3); display:block; }
.cat-rank-more {display:block;text-align:center;font-size: 14px;color:var(--gold);text-decoration:none;letter-spacing:0.05em;}
.cat-rank-more:hover { text-decoration:underline; }
.cat-rank-block, .cat-rank-item { box-sizing:border-box; overflow:hidden; }
@media (max-width: 900px) { .cat-ranking-grid { grid-template-columns:1fr; } }

/* ── コラム最新記事 ────────────────────────── */
.column-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.25rem; }
.column-card { background:#fff; border:1px solid var(--border3); border-radius:8px; padding:1.25rem; text-decoration:none; transition:border-color 0.2s; display:flex; flex-direction:column; }
.column-card:hover { border-color:var(--gold); }
.column-card-cat {font-size: 13px;color:var(--gold);letter-spacing:0.1em;margin-bottom:0.5rem;font-weight:500;}
.column-card-title {font-size: 18px;color:var(--text);font-weight:500;line-height:1.5;margin-bottom:0.5rem;}
.column-card-excerpt {font-size: 14px;color:var(--text-3);line-height:1.7;flex:1;margin-bottom:0.75rem;}
.column-card-date { font-size:10px; color:var(--text-3); }
@media (max-width: 1024px) { .column-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width: 600px) { .column-grid { grid-template-columns:1fr; } }

/* ── 修理工場の強み ────────────────────────── */
.strength-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.25rem; }
.strength-card { background:#fff; border:1px solid var(--border3); border-radius:10px; padding:1.5rem; text-align:center; }
.strength-icon { font-size:32px; margin-bottom:0.75rem; }
.strength-title {font-size: 16px;font-weight:500;color:var(--text);margin-bottom:0.5rem;}
.strength-desc {font-size: 14px;color:var(--text-3);line-height:1.8;}
@media (max-width: 900px) { .strength-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width: 600px) { .strength-grid { grid-template-columns:1fr; } }

/* ── トップFAQ ─────────────────────────────── */
.top-faq-list { max-width:800px; margin:0 auto; }
.top-faq-item { border-bottom:1px solid var(--border3); }
.top-faq-item:first-child { border-top:1px solid var(--border3); }
.top-faq-q { display:flex; align-items:flex-start; gap:0.75rem; padding:1.25rem 0; cursor:pointer; transition:color 0.2s; }
.top-faq-q:hover .top-faq-q-text { color:var(--gold); }
.top-faq-q-icon { font-family:'Cormorant Garamond',serif; font-size:18px; color:var(--gold); font-weight:600; flex-shrink:0; line-height:1.5; }
.top-faq-q-text {font-size: 16px;color:var(--text-2);flex:1;line-height:1.7;}
.top-faq-arrow { font-size:9px; color:var(--text-3); transition:transform 0.3s; flex-shrink:0; margin-top:4px; }
.top-faq-item.open .top-faq-arrow { transform:rotate(180deg); color:var(--gold); }
.top-faq-a {display:none;padding:0 0 1.25rem 2rem;font-size: 14px;color:var(--text-2);line-height:2;}
.top-faq-item.open .top-faq-a { display:block; }

/* ── 修理依頼が少ない機器 ──────────────────── */
.low-repair-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; }
.lr-card { display:flex; align-items:center; gap:1rem; background:#fff; border:1px solid var(--border3); border-radius:10px; padding:1.25rem; text-decoration:none; transition:border-color 0.2s; }
.lr-card:hover { border-color:var(--gold); }
.lr-medal { font-size:28px; flex-shrink:0; }
.lr-thumb { flex-shrink:0; width:80px; border-radius:6px; overflow:hidden; }
.lr-body { flex:1; min-width:0; }
.lr-cat { font-size:9px; color:var(--gold); letter-spacing:0.1em; margin-bottom:0.2rem; }
.lr-name {font-size: 16px;font-weight:500;color:var(--text);margin-bottom:0.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lr-maker { font-size:11px; color:var(--text-3); margin-bottom:0.4rem; }
.lr-bottom { display:flex; align-items:center; gap:0.5rem; flex-wrap:wrap; }
.lr-rating { font-size:13px; color:var(--gold); font-weight:600; }
.lr-rating small { font-size:10px; color:var(--text-3); font-weight:400; }
.lr-repair-badge { font-size:10px; color:var(--gold-dim); background:var(--gold-pale2); border:1px solid var(--border2); border-radius:3px; padding:1px 6px; white-space:nowrap; }
@media (max-width: 900px) { .low-repair-cards { grid-template-columns:1fr; } }

/* ── 比較表（リッチテーブル） ──────────────── */
.cmp-block { margin-bottom:2.5rem; }
.mt-section { margin-top:3rem; }
.cmp-cat-title { font-family:'Noto Serif JP',serif; font-size:18px; font-weight:400; color:var(--text); margin-bottom:1.25rem; padding-left:0.75rem; border-left:3px solid var(--gold); }
.cmp-cat-sub {font-size: 14px;font-weight:400;color:var(--text-3);margin-left:0.5rem;}
.cmp-table-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; border:1px solid var(--border3); border-radius:10px; box-shadow:0 2px 12px rgba(0,0,0,0.05); background:#fff; }
.cmp-table { width:100%; border-collapse:collapse; min-width:800px; font-size:13px; }
.cmp-table thead { background:linear-gradient(135deg, #1a1a1a 0%, #2d2510 100%); }
.cmp-table th { padding:0.875rem 1rem; font-size:10px; font-weight:500; color:var(--gold-light); letter-spacing:0.12em; text-align:left; white-space:nowrap; text-transform:uppercase; }
.cmp-th-rank { text-align:center; width:50px; }
.cmp-table td { padding:0.625rem 0.875rem; border-bottom:1px solid var(--border3); color:var(--text-2); vertical-align:middle; }
.cmp-table tbody tr { transition:background 0.15s; }
.cmp-table tbody tr:hover { background:var(--gold-pale2); }
.cmp-table tbody tr:last-child td { border-bottom:none; }
/* TOP3行の背景 */
.cmp-row--top1 { background:linear-gradient(90deg, rgba(201,169,110,0.08) 0%, transparent 100%); }
.cmp-row--top1 td:first-child { border-left:3px solid var(--gold); }
.cmp-row--top2 { background:linear-gradient(90deg, rgba(176,176,184,0.06) 0%, transparent 100%); }
.cmp-row--top3 { background:linear-gradient(90deg, rgba(200,132,90,0.06) 0%, transparent 100%); }
/* セル個別 */
.cmp-td-rank { text-align:center; font-size:20px; width:50px; }
.cmp-td-name a { color:var(--text); font-weight:600; font-size:14px; text-decoration:none; white-space:nowrap; }
.cmp-td-name a:hover { color:var(--gold); }
.cmp-td-maker { font-size:11px; color:var(--text-3); white-space:nowrap; }
.cmp-td-method { font-size:11px; max-width:140px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cmp-td-price { font-family:'Noto Sans JP',sans-serif; font-weight:700; font-size:14px; color:var(--gold-dim); white-space:nowrap; }
.cmp-td-rental { font-size:11px; white-space:nowrap; color:var(--gold); }
.cmp-td-rating { white-space:nowrap; }
.cmp-stars { font-size:12px; letter-spacing:-1px; }
.cmp-rating-num { font-family:'Noto Sans JP',sans-serif; font-size:15px; font-weight:700; color:var(--gold); margin-left:0.3rem; }
.cmp-td-count { font-size:11px; color:var(--text-3); white-space:nowrap; }
.cmp-repair-tag { font-size:10px; color:var(--gold-dim); background:var(--gold-pale2); border:1px solid var(--border2); border-radius:3px; padding:2px 6px; white-space:nowrap; }
.cmp-td-repair { font-size:11px; }

/* ── エリア別修理対応 ──────────────────────── */
.area-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; }
.area-card { background:#fff; border:1px solid var(--border3); border-radius:10px; padding:1.75rem; }
.area-card--main { border-color:var(--gold); background:var(--gold-pale2); }
.area-icon {font-size:32px;margin-bottom:0.75rem;text-align: center;}
.area-title {font-size:16px;font-weight:500;color:var(--text);margin-bottom:0.4rem;text-align: center;}
.area-tag { display:inline-block; font-size:10px; color:var(--gold-dim); background:var(--gold-pale); border:1px solid var(--border); border-radius:3px; padding:2px 8px; margin-bottom:0.75rem; letter-spacing:0.05em; }
.area-desc {font-size: 14px;color:var(--text-2);line-height:1.8;margin-bottom:0.75rem;}
.area-list {font-size: 14px;color:var(--text-2);line-height:2;padding-left:1.25rem;margin:0;}
.area-cta { margin-top:1rem; }
.btn-primary-sm {display:inline-block;background:var(--gold);color:#fff;padding:10px 24px;border-radius:6px;font-size:12px;letter-spacing:0.1em;text-decoration:none;transition:background 0.2s;width: 100%;text-align: center;}
.btn-primary-sm:hover { background:var(--gold-dim); }
@media (max-width: 900px) { .area-grid { grid-template-columns:1fr; } }

/* ── About ──────────────────────────────────── */
.about-section { padding:6rem 0; border-top:1px solid var(--border3); background:var(--bg2); }
.about-inner { max-width:1200px; margin:0 auto; padding:0 2.5rem; box-sizing:border-box; }
@media (max-width: 768px) { .about-inner { padding:0 1.25rem; } }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; margin-top:4rem; }
.about-text p { font-size:13px; color:var(--text-2); line-height:2.2; margin-bottom:1.25rem; letter-spacing:0.04em; }
.about-row {display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--border3);font-size: 14px;}
.about-row:first-child { border-top:1px solid var(--border3); }
.about-key { color:var(--text-3); letter-spacing:0.1em; min-width:100px; flex-shrink:0; }
.about-val { color:var(--text-2); letter-spacing:0.04em; }

/* ── 機器詳細 ──────────────────────────────── */
.product-hero { max-width:1200px; margin:0 auto; padding:3rem 2.5rem 4rem; display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.product-visual { position:sticky; top:88px; }
.product-img-main { width:100%; aspect-ratio:4/3; background:#fff; border:1px solid var(--border3); border-radius:6px; display:flex; align-items:center; justify-content:center; overflow:hidden; margin-bottom:1px; }
.product-category { font-size:10px; letter-spacing:0.4em; color:var(--gold); margin-bottom:0.75rem; }
.product-name { font-family:'Noto Serif JP',serif; font-size:clamp(22px,3vw,32px); font-weight:400; color:var(--text); line-height:1.3; margin-bottom:0.4rem; letter-spacing:0.03em; }
.product-maker { font-size:13px; color:var(--text-3); letter-spacing:0.1em; margin-bottom:1.5rem; }
.rating-row { display:flex; align-items:center; gap:1rem; margin-bottom:1.5rem; flex-wrap:wrap; }
.big-stars { display:flex; gap:3px; }
.big-star { color:var(--gold); font-size:18px; }
.big-star.e { color:var(--bg4); }
.big-rating { font-family:'Noto Sans JP',sans-serif; font-size:28px; color:var(--gold); line-height:1; font-weight:500; }
.review-total { font-size:12px; color:var(--text-3); letter-spacing:0.08em; }
.tag-row { display:flex; gap:0.5rem; flex-wrap:wrap; margin-bottom:1.75rem; }
.tag { font-size:10px; letter-spacing:0.1em; color:var(--text-3); background:var(--bg2); padding:4px 12px; border-radius:10px; border:1px solid var(--border3); }
.price-row { padding:1.5rem; border-top:1px solid var(--border3); border-bottom:1px solid var(--border3); margin-bottom:1.75rem; background:var(--gold-pale2); border-radius:6px; border:1px solid var(--border); }
.price-label { font-size:11px; color:var(--gold-dim); letter-spacing:0.15em; margin-bottom:0.3rem; font-weight:500; }
.price-main { font-family:'Noto Sans JP',sans-serif; font-size:34px; color:var(--gold-dim); font-weight:700; }
.price-main span { font-size:14px; color:var(--text-3); font-weight:400; }
.price-sub { font-size:11px; color:var(--text-3); letter-spacing:0.08em; margin-top:4px; }
.repair-stat { display:flex; align-items:center; gap:0.75rem; background:var(--gold-pale2); border:1px solid var(--border); padding:1rem 1.25rem; border-radius:4px; margin-bottom:1.75rem; }
.repair-stat-icon { font-size:18px; }
.repair-stat-text { font-size:12px; color:var(--text-2); line-height:1.7; letter-spacing:0.04em; }
.repair-stat-text strong { color:var(--text); font-weight:500; display:block; }
.detail-actions { display:flex; flex-direction:column; gap:0.75rem; }
.detail-tabs-wrapper { max-width:1200px; margin:0 auto; padding:0 2.5rem; }
.detail-tabs { display:flex; border-bottom:2px solid var(--border3); overflow-x:auto; gap:0; }
.d-tab { flex-shrink:0; padding:0.875rem 1.75rem; font-size:13px; letter-spacing:0.12em; color:var(--text-3); cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-2px; transition:all 0.2s; white-space:nowrap; background:none; font-family:inherit; font-weight:400; }
.d-tab.active { color:var(--gold); border-bottom-color:var(--gold); font-weight:500; }
.d-tab:hover:not(.active) { color:var(--text-2); }
.d-panel { display:none; max-width:1200px; margin:0 auto; padding:3rem 2.5rem; }
.d-panel.active { display:block; }
.rating-breakdown { display:grid; grid-template-columns:auto 1fr; gap:2.5rem; align-items:start; margin-bottom:3rem; }
.rating-big { text-align:center; background:#fff; border:1px solid var(--border3); padding:2rem 2.5rem; border-radius:6px; box-shadow:var(--shadow); }
.rating-big-num { font-family:'Noto Sans JP',sans-serif; font-size:60px; color:var(--gold); line-height:1; font-weight:400; }
.rating-big-stars { display:flex; gap:4px; justify-content:center; margin:0.5rem 0; }
.rating-big-count { font-size:11px; color:var(--text-3); letter-spacing:0.1em; }
.rbar-row { display:flex; align-items:center; gap:1rem; margin-bottom:0.875rem; }
.rbar-label { font-size:12px; color:var(--text-3); letter-spacing:0.08em; min-width:100px; }
.rbar-track { flex:1; height:6px; background:var(--bg3); border-radius:3px; overflow:hidden; }
.rbar-fill { height:100%; border-radius:3px; background:var(--gold); transition:width 1s ease; }
.rbar-num { font-family:'Noto Sans JP',sans-serif; font-size:13px; color:var(--gold); min-width:24px; text-align:right; font-weight:500; }
.spec-section { margin-bottom:3rem; }
.spec-section-title { font-family:'Noto Serif JP',serif; font-size:14px; font-weight:500; color:var(--text); letter-spacing:0.08em; margin-bottom:0; padding:0.75rem 0; border-bottom:2px solid var(--gold); display:inline-block; }
.spec-table { width:100%; border-collapse:collapse; margin-top:1rem; }
.spec-table tr { border-bottom:1px solid var(--border3); }
.spec-table td { padding:0.875rem 0; font-size:13px; vertical-align:top; }
.spec-table td:first-child { width:160px; color:var(--text-3); letter-spacing:0.08em; }
.spec-table td:last-child { color:var(--text-2); }

/* ── フィルター・一覧 ─────────────────────── */
.breadcrumb-wrap { padding-top:64px; background:#fff; border-bottom:1px solid var(--border3); position:relative; z-index:10; }
.breadcrumb { max-width:1200px; margin:0 auto; padding:1rem 2.5rem; display:flex; align-items:center; gap:0.5rem; font-size:11px; color:var(--text-3); letter-spacing:0.1em; }
.breadcrumb a { color:var(--text-3); text-decoration:none; transition:color 0.2s; }
.breadcrumb a:hover { color:var(--gold); }
.bc-sep { opacity:0.4; }
.page-header { background:var(--gold-pale2); border-bottom:1px solid var(--border); padding:2.5rem 0 0; }
.page-header-inner { max-width:1200px; margin:0 auto; padding:0 2.5rem; }
.ph-row { display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-bottom:2rem; }
.ph-eyebrow { font-size:10px; letter-spacing:0.45em; color:var(--gold); margin-bottom:0.6rem; }
.ph-title { font-family:'Cormorant Garamond',serif; font-size:clamp(26px,4vw,40px); font-weight:400; color:var(--text); letter-spacing:0.04em; }
.ph-sub { font-size:12px; color:var(--text-3); letter-spacing:0.06em; }
.filter-bar { background:#fff; border-bottom:1px solid var(--border3); position:sticky; top:64px; z-index:50; box-shadow:var(--shadow); }
.filter-bar-inner { max-width:1200px; margin:0 auto; padding:0.875rem 2.5rem; display:flex; gap:0.75rem; align-items:center; flex-wrap:wrap; }
.filter-search { flex:1; min-width:180px; background:#fff; border:1px solid var(--border3); color:var(--text); padding:8px 14px; font-size:13px; font-family:inherit; border-radius:4px; outline:none; transition:border-color 0.2s; }
.filter-search:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(184,146,58,0.1); }
.filter-search::placeholder { color:var(--text-3); }
.filter-select { background:#fff; border:1px solid var(--border3); color:var(--text-2); padding:8px 12px; font-size:12px; font-family:inherit; border-radius:4px; outline:none; cursor:pointer; transition:border-color 0.2s; }
.filter-select:focus { border-color:var(--gold); }
.result-count { font-size:12px; color:var(--text-3); letter-spacing:0.08em; margin-left:auto; white-space:nowrap; }
.result-count strong { font-family:'Noto Sans JP',sans-serif; font-size:16px; color:var(--gold); font-weight:500; }
.filter-tabs { display:flex; gap:0; overflow-x:auto; -webkit-overflow-scrolling:touch; border-bottom:1px solid var(--border3); max-width:1200px; margin:0 auto; padding:0 2.5rem; }
@media (max-width: 768px) { .filter-tabs { padding:0 1rem; } }
.f-tab { flex-shrink:0; padding:0.75rem 1.5rem; font-size:12px; letter-spacing:0.12em; color:var(--text-3); cursor:pointer; border-bottom:2px solid transparent; transition:all 0.2s; white-space:nowrap; background:none; font-family:inherit; text-decoration:none; display:inline-block; font-weight:400; }
.f-tab.active { color:var(--gold); border-bottom-color:var(--gold); font-weight:500; }
.f-tab:hover:not(.active) { color:var(--text-2); }
.main-layout { max-width:1200px; margin:0 auto; padding:2.5rem 2.5rem 6rem; display:grid; grid-template-columns:220px 1fr; gap:2.5rem; align-items:start; }
.sidebar { position:sticky; top:120px; background:#fff; border:1px solid var(--border3); border-radius:6px; padding:1.5rem; box-shadow:var(--shadow); }
.sb-block { margin-bottom:1.75rem; }
.sb-block:last-of-type { margin-bottom:0; }
.sb-title { font-size:11px; letter-spacing:0.2em; color:var(--gold); margin-bottom:0.875rem; padding-bottom:0.5rem; border-bottom:2px solid var(--gold-pale); font-weight:500; }
.sb-opts { display:flex; flex-direction:column; gap:0.25rem; }
.sb-opt { display:flex; align-items:center; justify-content:space-between; padding:0.5rem 0; }
.sb-opt label { display:flex; align-items:center; gap:0.6rem; cursor:pointer; flex:1; }
.sb-opt input[type=checkbox] { appearance:none; width:16px; height:16px; border:2px solid var(--border3); border-radius:3px; background:#fff; cursor:pointer; position:relative; transition:all 0.15s; flex-shrink:0; }
.sb-opt input[type=checkbox]:checked { background:var(--gold); border-color:var(--gold); }
.sb-opt input[type=checkbox]:checked::after { content:'v'; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:9px; color:#fff; font-weight:700; }
.sb-opt-label { font-size:12px; color:var(--text-2); letter-spacing:0.06em; }
.sb-opt-count { font-family:'Noto Sans JP',sans-serif; font-size:12px; color:var(--text-3); background:var(--bg2); padding:1px 6px; border-radius:10px; }
.sb-reset { width:100%; background:none; border:1px solid var(--border3); color:var(--text-3); padding:7px; font-size:11px; letter-spacing:0.15em; font-family:inherit; cursor:pointer; border-radius:4px; transition:all 0.2s; margin-top:1rem; }
.sb-reset:hover { border-color:var(--gold); color:var(--gold); background:var(--gold-pale2); }
.products-area {}
.view-sort-bar { display:flex; align-items:center; justify-content:space-between; margin-bottom:1.25rem; gap:0.75rem; flex-wrap:wrap; }
.view-sort-left { font-size:12px; color:var(--text-3); }
.view-sort-right { display:flex; align-items:center; gap:0.75rem; }
.sort-sel { background:#fff; border:1px solid var(--border3); color:var(--text-2); padding:6px 12px; font-size:12px; font-family:inherit; border-radius:4px; outline:none; cursor:pointer; transition:border-color 0.2s; }
.sort-sel:focus { border-color:var(--gold); }
.pagination { display:flex; justify-content:center; align-items:center; gap:0.4rem; margin-top:3rem; }
.pagination ul { display:flex; gap:0.4rem; list-style:none; }
.pagination ul li a, .pagination ul li span { width:36px; height:36px; display:flex; align-items:center; justify-content:center; background:#fff; border:1px solid var(--border3); color:var(--text-3); font-size:12px; border-radius:4px; transition:all 0.2s; text-decoration:none; }
.pagination ul li.current span { background:var(--gold); border-color:var(--gold); color:#fff; font-weight:500; }
.pagination ul li a:hover { border-color:var(--gold); color:var(--gold); background:var(--gold-pale2); }

/* ── フォーム ───────────────────────────────── */
.form-group { margin-bottom:1.1rem; }
.form-label { display:block; font-size:11px; letter-spacing:0.15em; color:var(--text-3); margin-bottom:0.4rem; font-weight:500; }
.form-input { width:100%; background:#fff; border:1px solid var(--border3); color:var(--text); padding:10px 14px; font-size:13px; font-family:inherit; border-radius:4px; outline:none; transition:border-color 0.2s; }
.form-input:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(184,146,58,0.1); }
.form-input::placeholder { color:var(--text-3); }

/* ── FAQ ──────────────────────────────────── */
.faq-item { border-bottom:1px solid var(--border3); }
.faq-item:first-child { border-top:1px solid var(--border3); }
.faq-q { display:flex; align-items:flex-start; gap:1.25rem; padding:1.25rem 0; cursor:pointer; transition:color 0.2s; }
.faq-q:hover .faq-q-text { color:var(--gold); }
.faq-q-badge { font-family:'Cormorant Garamond',serif; font-size:20px; color:var(--gold); font-weight:500; flex-shrink:0; line-height:1.4; min-width:20px; }
.faq-q-text { font-size:14px; color:var(--text-2); letter-spacing:0.04em; flex:1; line-height:1.7; }
.faq-arrow { width:22px; height:22px; border:1px solid var(--border3); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:9px; color:var(--text-3); transition:all 0.3s; flex-shrink:0; margin-top:2px; }
.faq-item.open .faq-arrow { transform:rotate(180deg); border-color:var(--gold); color:var(--gold); background:var(--gold-pale2); }
.faq-item.open .faq-q-text { color:var(--text); }
.faq-a { display:none; padding:0 0 1.5rem 2.75rem; font-size:13px; color:var(--text-2); line-height:2.1; letter-spacing:0.04em; }
.faq-item.open .faq-a { display:block; }

/* ── モーダル ──────────────────────────────── */
.modal-backdrop { position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:200; display:none; align-items:center; justify-content:center; padding:2rem; backdrop-filter:blur(4px); }
.modal-backdrop.open { display:flex; }
@keyframes modalIn { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }
.modal { background:#fff; border:1px solid var(--border3); width:100%; max-width:450px; border-radius:8px; padding:2.5rem; position:relative; animation:modalIn 0.3s ease; max-height:90vh; overflow-y:auto; box-shadow:var(--shadow-md); }
.modal-close { position:absolute; top:1.25rem; right:1.25rem; background:none; border:none; color:var(--text-3); font-size:18px; cursor:pointer; transition:color 0.2s; line-height:1; }
.modal-close:hover { color:var(--text); }
.modal-header { text-align:center; margin-bottom:1.75rem; }
.modal-logo { font-family:'Cormorant Garamond',serif; font-size:22px; color:var(--gold); letter-spacing:0.2em; margin-bottom:0.4rem; }
.modal-divider { width:30px; height:2px; background:var(--gold); margin:0.875rem auto; border-radius:1px; }
.modal-sub { font-size:11px; color:var(--text-3); letter-spacing:0.1em; }
.modal-tabs { display:flex; border-bottom:2px solid var(--border3); margin-bottom:1.5rem; }
.modal-tab { flex:1; text-align:center; padding:0.65rem; font-size:12px; letter-spacing:0.1em; color:var(--text-3); cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-2px; transition:all 0.2s; font-weight:400; }
.modal-tab.active { color:var(--gold); border-bottom-color:var(--gold); font-weight:500; }
.tab-pane { display:none; }
.tab-pane.active { display:block; }
.modal-line-title { font-family:'Cormorant Garamond',serif; font-size:22px; color:var(--text); font-weight:400; margin-bottom:0.5rem; letter-spacing:0.04em; text-align:center; }
.modal-line-sub { font-size:12px; color:var(--text-2); line-height:2; margin-bottom:1.75rem; text-align:center; }
.modal-steps { display:flex; flex-direction:column; gap:0; margin-bottom:1.75rem; }
.modal-step { display:flex; align-items:flex-start; gap:0.75rem; padding:0.875rem 0; border-bottom:1px solid var(--border3); }
.modal-step:first-child { border-top:1px solid var(--border3); }
.mstep-num { font-family:'Cormorant Garamond',serif; font-size:20px; color:var(--gold); line-height:1; flex-shrink:0; min-width:22px; font-weight:500; }
.mstep-text { font-size:12px; color:var(--text-2); line-height:1.8; }
.mstep-text strong { color:var(--text); font-weight:500; }
.modal-note { font-size:11px; color:var(--text-3); text-align:center; line-height:1.9; }
.modal-note a { color:var(--gold); cursor:pointer; }

/* ── フッター ──────────────────────────────── */
#site-footer { border-top:1px solid var(--border3); padding:3rem 2.5rem; background:var(--bg2); }
.footer-inner { max-width:1200px; margin:0 auto; display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:2rem; }
.footer-logo { margin-bottom:0.6rem; }
.footer-logo a { display:inline-block; }
.footer-logo-img {height: 39px;width:auto;display:block;opacity:0.85;transition:opacity 0.2s;}
.footer-logo-img:hover { opacity:1; }
.footer-tagline {font-size: 14px;color:var(--text-3);letter-spacing:0.15em;}
.footer-co {font-size: 14px;color:var(--text-3);letter-spacing:0.1em;margin-top:4px;}
.footer-links { display:flex; gap:2rem; flex-wrap:wrap; }
.footer-links a { font-size:11px; color:var(--text-3); text-decoration:none; letter-spacing:0.15em; transition:color 0.2s; }
.footer-links a:hover { color:var(--gold); }
.footer-copy { max-width:1200px; margin:2rem auto 0; padding-top:1.5rem; border-top:1px solid var(--border3); font-size:11px; color:var(--text-3); text-align:center; letter-spacing:0.1em; }

/* ── レスポンシブ ──────────────────────────── */
@media (max-width: 960px) {
  .main-layout { grid-template-columns:1fr; }
  .sidebar { position:static; }
  .product-hero { grid-template-columns:1fr; gap:2.5rem; }
  .product-visual { position:static; }
  .about-grid { grid-template-columns:1fr; gap:3rem; }
  .rating-breakdown { grid-template-columns:1fr; gap:1.5rem; }
  .categories-grid { grid-template-columns:1fr 1fr; gap:1rem; }
}
@media (max-width: 768px) {
  #site-header { padding:0 1.25rem; }
  .global-nav { display:none; }
  .header-btns { display:none; }
  .hamburger { display:flex; }
  .hero { padding:0 1.25rem; }
  .section { padding:4rem 1.25rem; }
  .categories-grid { grid-template-columns:1fr; }
  .stats-bar { gap:2rem; padding:1.5rem; }
  .review-lock-bar { flex-direction:column; align-items:flex-start; }
  .filter-bar-inner { padding-left:1.25rem; padding-right:1.25rem; }
  .main-layout { padding:2rem 1.25rem 4rem; }
  .ph-row { flex-direction:column; align-items:flex-start; }
  .products-grid { grid-template-columns:1fr 1fr; gap:1rem; }
}
@media (max-width: 480px) {
  .products-grid { grid-template-columns:1fr; }
}
/* ── ワイドナビドロップダウン ─────────────────── */
.nav-dropdown--wide {
  display:none;
  position:absolute; top:calc(100% - 1px); left:50%;
  transform:translateX(-50%);
  background:#fff;
  border:1px solid var(--border3);
  border-radius:8px;
  min-width:620px;
  padding:1.75rem 1.5rem 1.5rem;
  z-index:300;
  /* 上に透明な橋を作ってマウスの抜けを防ぐ */
  margin-top:-8px;
  padding-top:calc(1.75rem + 8px);
  box-shadow:0 8px 32px rgba(0,0,0,0.12);
  grid-template-columns:repeat(3, 1fr);
  gap:0;
}
.nav-item:hover .nav-dropdown--wide {
  display:grid;
}
.nav-col {
  padding:0 1.25rem;
  border-right:1px solid var(--border3);
}
.nav-col:first-child { padding-left:0.5rem; }
.nav-col:last-child {
  border-right:none;
  padding-right:0.5rem;
}
.nav-col-title {
  font-size:9px; letter-spacing:0.35em; color:var(--gold);
  font-weight:600; margin-bottom:0.875rem; padding-bottom:0.625rem;
  border-bottom:2px solid var(--gold-pale);
  text-transform:uppercase;
}
.nav-col a {
  display:flex; align-items:center; gap:8px;
  padding:0.625rem 0.75rem;
  margin:0 -0.75rem;
  font-size:12px; color:var(--text-2);
  letter-spacing:0.06em; white-space:nowrap;
  transition:all 0.15s; text-decoration:none; border-bottom:none;
  border-radius:6px;
}
.nav-col a:hover {
  color:var(--gold);
  background:var(--gold-pale2);
  padding-left:1.25rem;
}
.nav-item-icon {
  color:var(--gold-dim); font-size:11px; flex-shrink:0;
}
.nav-all-link {
  font-size:11px !important; color:var(--gold-dim) !important;
  margin-top:0.75rem !important; padding-top:0.75rem !important;
  border-top:1px solid var(--border3) !important;
  font-weight:500 !important;
}
.nav-all-link:hover { color:var(--gold) !important; background:var(--gold-pale2) !important; }

/* ── PC検索バー ── */
.nav-search-wrap { display:flex; align-items:center; margin-right:auto; margin-left:1.5rem; }
.nav-search-form { display:flex; align-items:center; background:var(--bg2); border:1px solid var(--border3); border-radius:6px; overflow:hidden; transition:border-color 0.2s; }
.nav-search-form:focus-within { border-color:var(--gold); }
.nav-search-input { border:none; background:transparent; padding:6px 12px; font-size:12px; color:var(--text); width:180px; outline:none; font-family:inherit; }
.nav-search-input::placeholder { color:var(--text-3); }
.nav-search-btn { border:none; background:transparent; padding:6px 10px; cursor:pointer; font-size:14px; color:var(--text-3); transition:color 0.2s; }
.nav-search-btn:hover { color:var(--gold); }
@media (max-width: 768px) { .nav-search-wrap { display:none; } }

/* ── PCメガメニュー（リッチ版） ── */
.nav-dropdown--mega { display:none; position:absolute; top:100%; left:50%; transform:translateX(-50%); background:#fff; border:1px solid var(--border3); border-radius:12px; box-shadow:0 12px 40px rgba(0,0,0,0.12); padding:0; min-width:820px; z-index:200; }
.nav-item:hover .nav-dropdown--mega { display:block; animation:megaFadeIn 0.2s ease; }
@keyframes megaFadeIn { from { opacity:0; transform:translateX(-50%) translateY(8px); } to { opacity:1; transform:translateX(-50%) translateY(0); } }
.mega-inner { display:grid; grid-template-columns:1fr 1fr 1fr 1.2fr; gap:0; }
.mega-col { padding:1.5rem; border-right:1px solid var(--border3); }
.mega-col:last-child { border-right:none; }
.mega-col--featured { background:var(--bg2); border-radius:0 12px 12px 0; }
.mega-col-title { font-size:11px; font-weight:600; color:var(--gold-dim); letter-spacing:0.1em; margin-bottom:0.875rem; padding-bottom:0.5rem; border-bottom:1px solid var(--border3); }
.mega-link { display:flex; align-items:center; gap:0.5rem; padding:0.5rem 0.6rem; border-radius:6px; text-decoration:none; color:var(--text-2); font-size:13px; transition:all 0.15s; }
.mega-link:hover { background:var(--gold-pale2); color:var(--gold); padding-left:0.875rem; }
.mega-link-icon { font-size:12px; flex-shrink:0; width:18px; text-align:center; }
.mega-link-count { margin-left:auto; font-size:10px; color:var(--text-3); background:var(--bg3); padding:1px 6px; border-radius:8px; }
.mega-all-link { display:block; margin-top:0.75rem; padding-top:0.75rem; border-top:1px solid var(--border3); font-size:11px; color:var(--gold); text-decoration:none; letter-spacing:0.05em; }
.mega-all-link:hover { text-decoration:underline; }

/* メガメニュー内 人気機種カード */
.mega-machine-card { display:flex; align-items:center; gap:0.6rem; padding:0.6rem; border-radius:8px; text-decoration:none; transition:background 0.15s; margin-bottom:0.4rem; }
.mega-machine-card:hover { background:var(--gold-pale); }
.mega-machine-thumb { flex-shrink:0; width:48px; height:48px; border-radius:6px; overflow:hidden; background:#fff; border:1px solid var(--border3); }
.mega-machine-info { flex:1; min-width:0; }
.mega-machine-name { font-size:12px; font-weight:600; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mega-machine-meta { font-size:10px; color:var(--text-3); }
.mega-machine-rating { font-size:12px; color:var(--gold); font-weight:600; }
.mega-machine-rating small { font-size:10px; color:var(--text-3); font-weight:400; }

/* ── PCヘッダーアバター ── */
.header-avatar-btn { display:flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:50%; overflow:hidden; border:2px solid var(--gold); transition:box-shadow 0.2s; text-decoration:none; }
.header-avatar-btn:hover { box-shadow:0 0 0 3px var(--gold-pale); }
.header-avatar-img { width:100%; height:100%; object-fit:cover; }
.header-avatar-fallback { width:100%; height:100%; display:flex; align-items:center; justify-content:center; background:var(--gold-pale2); color:var(--gold); font-size:13px; font-weight:600; }

/* ── SP検索 ── */
.mn-search { padding:1rem 1.25rem 0.5rem; }
.mn-search-form { display:flex; }
.mn-search-input { flex:1; border:1px solid var(--border3); background:var(--bg2); border-radius:8px; padding:10px 14px; font-size:13px; font-family:inherit; color:var(--text); outline:none; }
.mn-search-input:focus { border-color:var(--gold); }

/* ── SPユーザーカード ── */
.mn-user-card { display:flex; align-items:center; gap:0.75rem; padding:1rem 1.25rem; border-bottom:1px solid var(--border3); background:var(--bg2); }
.mn-user-avatar { width:40px; height:40px; border-radius:50%; object-fit:cover; border:2px solid var(--gold); flex-shrink:0; }
.mn-user-avatar-fallback { width:40px; height:40px; border-radius:50%; background:var(--gold-pale2); border:2px solid var(--gold); display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:14px; font-weight:600; flex-shrink:0; }
.mn-user-info { flex:1; }
.mn-user-name { font-size:13px; font-weight:500; color:var(--text); }
.mn-user-link { font-size:11px; color:var(--gold); text-decoration:none; }

/* ── SPリンクアイコン ── */
.mn-link-icon { display:inline-block; width:22px; text-align:center; margin-right:0.4rem; font-size:14px; }
.mn-link { display:flex; align-items:center; padding:1rem 1.25rem; text-decoration:none; color:var(--text); font-size:14px; font-weight:400; transition:color 0.2s; }
.mn-link:hover { color:var(--gold); }

/* ── SP子メニュー件数 ── */
.mn-child-count { margin-left:auto; font-size:10px; color:var(--text-3); background:var(--bg3); padding:1px 6px; border-radius:8px; }
.mn-child-link--all { color:var(--gold); font-size:12px; padding-top:0.75rem; margin-top:0.25rem; border-top:1px solid var(--border3); }

/* ── SPボタン全幅 ── */
.mn-btn-full { display:block; width:100%; text-align:center; box-sizing:border-box; }

/* ── スマホ専用上書き (〜600px) ── */
@media (max-width: 600px) {
  /* ヘッダーロゴ */
  .logo-img {height: 36px;}
  .logo-sub { display:none; }
  .site-title { font-size: 16px !important; letter-spacing: 0.15em !important; }

  /* パンくず - padding-topはヘッダー高さ(64px)を維持 */
  .breadcrumb-wrap { padding: 64px 1rem 0.5rem !important; }
  .breadcrumb { padding: 0.625rem 0 !important; overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap; white-space: nowrap; scrollbar-width: none; }
  .breadcrumb::-webkit-scrollbar { display: none; }

  /* 機器カード一覧 */
  .products-grid { grid-template-columns: 1fr 1fr !important; gap: 0.75rem !important; }

  /* ランキングタブ */
  .rank-tabs a { padding: 0.5rem 0.75rem !important; font-size: 10px !important; }

  /* 機器詳細 */
  .machine-hero { grid-template-columns: 1fr !important; }
  .detail-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .detail-tabs a { padding: 0.625rem 1rem !important; font-size: 11px !important; }

  /* 口コミカード */
  .review-card { padding: 1.25rem !important; }

  /* フッター */
  .footer-grid { grid-template-columns: 1fr !important; gap: 2rem !important; }
}

@media (max-width: 480px) {
  .products-grid { grid-template-columns: 1fr !important; }
}

/* ══════════════════════════════════════════
   ランキング / カテゴリーページ レイアウト
══════════════════════════════════════════ */

/* ヒーローセクション */
.rk-hero { background:var(--gold-pale2); border-bottom:1px solid var(--border); padding:1.5rem 0 0; }
.rk-hero-inner { max-width:1200px; margin:0 auto; padding:0 2.5rem; }
.rk-hero-grid { display:grid; grid-template-columns:1fr auto; gap:1.5rem; align-items:start; margin-bottom:1.5rem; }
.rk-hero-label { font-size:9px; letter-spacing:0.4em; color:var(--gold); margin-bottom:0.4rem; }
.rk-hero-title { font-family:'Cormorant Garamond',serif; font-size:clamp(20px,4vw,42px); font-weight:400; color:var(--text); letter-spacing:0.03em; line-height:1.25; margin-bottom:0.5rem; }
.rk-hero-title span { color:var(--gold); }
.rk-hero-desc {font-size: 14px;color:var(--text-2);line-height:1.9;max-width:640px;margin-bottom:1.25rem;}
.rk-hero-badge {display:inline-flex;align-items:center;gap:6px;background:rgba(201,169,110,0.07);border:0.5px solid rgba(201,169,110,0.2);padding:6px 14px;border-radius:2px;font-size: 14px;color:var(--text-2);letter-spacing:0.08em;margin-top:1rem;}
.rk-counter {background:var(--bg3);border:0.5px solid var(--border2);padding:1rem 1.25rem;border-radius:2px;text-align:center;width: 100%;min-width:80px;}
.rk-counter-num { font-family:'Noto Sans JP',sans-serif; font-size:28px; color:var(--gold); font-weight:300; line-height:1; }
.rk-counter-label { font-size:10px; color:var(--text-3); letter-spacing:0.12em; margin-top:3px; }

/* 並び替えタブ */
.rk-tabs {display:flex;gap:0;border-bottom: 1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;}
.rk-tabs a { flex-shrink:0; padding:0.625rem 1.1rem; font-size:11px; letter-spacing:0.1em; text-decoration:none; white-space:nowrap; transition:all 0.2s; border-bottom:2px solid transparent; }
.rk-tabs a.active { color:var(--gold); border-bottom-color:var(--gold); font-weight:500; }
.rk-tabs a:not(.active) { color:var(--text-3); }

/* カテゴリーフィルターバー */
.rk-filter { background:#fff; border-bottom:1px solid var(--border3); position:sticky; top:64px; z-index:50; box-shadow:0 2px 8px rgba(0,0,0,0.05); }
.rk-filter-inner { max-width:1200px; margin:0 auto; padding:0.625rem 1.25rem; display:flex; gap:0.4rem; align-items:center; flex-wrap:wrap; }
.rk-filter-label { font-size:11px; color:var(--text-3); letter-spacing:0.1em; margin-right:0.25rem; flex-shrink:0; }
.rk-filter a { display:inline-block; padding:4px 12px; font-size:12px; letter-spacing:0.08em; border-radius:20px; text-decoration:none; transition:all 0.2s; border:1px solid var(--border3); color:var(--text-3); white-space:nowrap; }
.rk-filter a.active { background:var(--gold); color:#fff; border-color:var(--gold); font-weight:500; }
.rk-filter-count { margin-left:auto; font-size:12px; color:var(--text-3); white-space:nowrap; }
.rk-filter-count strong { font-family:'Noto Sans JP',sans-serif; font-size:16px; color:var(--gold); font-weight:500; }

/* ランキングリスト */
.rk-list { max-width:1200px; margin:0 auto; padding:1rem 2.5rem 4rem; box-sizing:border-box; overflow:hidden; }
.rk-list-inner { display:flex; flex-direction:column; gap:1rem; }

/* ランキングカード */
.rk-card { background:#fff; border:1px solid var(--border3); border-radius:8px; padding:1.1rem; box-shadow:0 2px 6px rgba(0,0,0,0.04); transition:all 0.2s; cursor:pointer; }
.rk-card.top3 { border-color:var(--gold); box-shadow:0 4px 16px rgba(184,146,58,0.12); }
.rk-card:hover { border-color:var(--gold); box-shadow:0 4px 16px rgba(184,146,58,0.15); }
.rk-card-top { display:flex; align-items:flex-start; gap:0.875rem; margin-top:0.75rem; margin-bottom:0.75rem; }
.rk-rank { display:flex; flex-direction:column; align-items:center; flex-shrink:0; padding-top:2px; min-width:32px; }
.rk-rank-num { font-family:'Noto Sans JP',sans-serif; font-size:20px; font-weight:400; line-height:1; }
.rk-rank-num.top3 { font-size:28px; }
.rk-rank-label { font-size:8px; letter-spacing:0.12em; color:var(--text-3); }
.rk-rank-bar { width:18px; height:2px; border-radius:1px; margin-top:3px; }
.rk-info { flex:1; min-width:0; }
.rk-badges { display:flex; gap:0.35rem; flex-wrap:wrap; margin-bottom:0.3rem; }
.rk-badge-cat { font-size:9px; letter-spacing:0.1em; color:var(--gold); background:var(--gold-pale); padding:1px 8px; border-radius:8px; border:1px solid var(--border); white-space:nowrap; }
.rk-badge-method { font-size:9px; letter-spacing:0.06em; color:var(--text-3); background:var(--bg2); padding:1px 8px; border-radius:8px; border:1px solid var(--border3); white-space:nowrap; }
.rk-card-title { font-family:'Noto Serif JP',serif; font-size:18px; font-weight:400; color:var(--text); line-height:1.3; margin-bottom:0.2rem; }
.rk-card-maker { font-size:11px; color:var(--text-3); }
.rk-price { flex-shrink:0; text-align:right; background:var(--gold-pale2); padding:0.4rem 0.75rem; border-radius:4px; border:1px solid var(--border2); }
.rk-price-label { font-size:9px; color:var(--gold-dim); margin-bottom:1px; font-weight:500; }
.rk-price-num { font-family:'Noto Sans JP',sans-serif; font-size:18px; color:var(--gold-dim); font-weight:700; }
.rk-price-ask { font-size:10px; color:var(--text-3); }
.rk-rental { font-size:11px; color:var(--gold-dim); font-weight:600; margin-top:0.35rem; border-top:1px solid var(--border); padding-top:0.35rem; }

/* 購入・レンタル一列表示 */
.rk-price-row { display:flex; align-items:center; gap:0; background:var(--gold-pale2); border:1px solid var(--border2); border-radius:6px; overflow:hidden; margin-top:0.75rem; }
.rk-price-item { display:flex; align-items:center; gap:0.4rem; padding:0.4rem 0.6rem; white-space:nowrap; }
.rk-price-item + .rk-price-item { border-left:1px solid var(--border2); }
.rk-price-tag { font-size:9px; font-weight:600; color:#fff; background:var(--gold-dim); border-radius:3px; padding:1px 6px; letter-spacing:0.05em; flex-shrink:0; }
.rk-price-tag--rental { background:var(--gold); }
.rk-price-val { font-family:'Noto Sans JP',sans-serif; font-size:14px; font-weight:700; color:var(--gold-dim); }
.rk-price-val--ask { font-size:11px; font-weight:500; color:var(--text-3); }
.rk-stars { display:flex; align-items:center; gap:0.5rem; margin-bottom:0.75rem; flex-wrap:wrap; }
.rk-star-wrap { display:flex; gap:2px; }
.rk-star { font-size:16px; }
.rk-star--filled { color:var(--gold); }
.rk-star--empty  { color:var(--bg4); }
.rk-rating-num { font-size:20px; color:var(--gold); font-weight:500; line-height:1; }
.rk-review-count { font-size:11px; color:var(--text-3); }
.rk-rating-bar { flex:1; height:4px; background:var(--bg3); border-radius:2px; overflow:hidden; min-width:30px; max-width:140px; }
.rk-rating-fill { height:100%; width:var(--rk-fill,0%); background:var(--gold); border-radius:2px; }
/* rank colors */
.rk-rank--1 { color:#b8923a; }
.rk-rank--2 { color:#9a9aa8; }
.rk-rank--3 { color:#b07040; }
.rk-rank--n  { color:#c8c0b8; }
/* medal */
.rk-medal { line-height:1; text-align:center; }
.rk-medal--1 { font-size:40px; }
.rk-medal--n { font-size:34px; }
/* misc */
.rk-price-unit { font-size:10px; color:var(--text-3); }
.rk-empty-msg  { text-align:center; padding:5rem 2rem; color:var(--text-3); font-size:13px; }
.bc-current    { color:var(--text-2); }
.rk-card-bottom { display:flex; align-items:center; justify-content:space-between; gap:0.5rem; flex-wrap:wrap; }
.rk-tags { display:flex; gap:0.3rem; flex-wrap:wrap; flex:1; }
.rk-tag { font-size:9px; color:var(--text-3); background:var(--bg2); padding:2px 7px; border-radius:8px; border:1px solid var(--border3); }
.rk-repair-tag { font-size:9px; color:var(--gold-dim); background:var(--gold-pale2); padding:2px 7px; border-radius:8px; border:1px solid var(--border); }
.rk-detail-btn { flex-shrink:0; display:inline-flex; align-items:center; gap:4px; background:none; border:1px solid var(--border); color:var(--text-2); padding:7px 14px; font-size:11px; letter-spacing:0.08em; border-radius:4px; text-decoration:none; white-space:nowrap; transition:all 0.2s; }
.rk-detail-btn:hover { background:var(--gold); border-color:var(--gold); color:#fff; }

/* カテゴリー taxonomy 専用 */
.rk-cat-hero { background:var(--bg2); border-bottom:0.5px solid var(--border2); padding:2rem 0 0; }
.rk-cat-inner { max-width:1200px; margin:0 auto; padding:0 1.25rem; }
.rk-cat-article { background:var(--bg2); padding:1.25rem; transition:background 0.2s; cursor:pointer; }
.rk-cat-article:hover { background:var(--bg3); }

/* スマホ対応 */
@media (max-width: 768px) {
  .rk-hero-inner { padding:0 1rem; }
  .rk-hero-grid { grid-template-columns:1fr; gap:0.75rem; }
  .rk-counter { display:inline-block; padding:0.6rem 1rem; }
  .rk-hero-title {font-size: clamp(18px,7.5vw,32px);}
  .rk-tabs a {padding:0.5rem 0.875rem;font-size: 14px;letter-spacing:0.06em;}
  .rk-filter-inner { padding:0.5rem 1rem; }
  .rk-list { padding:0.75rem 0.75rem 3rem; }
}

/* ══════════════════════════════════════
   ページネーション
══════════════════════════════════════ */
.rk-pager { display:flex; justify-content:center; align-items:center; gap:0.375rem; margin-top:2.5rem; flex-wrap:wrap; }
.rk-pager .page-numbers {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:40px; height:40px; padding:0 0.75rem;
  font-size:13px; color:var(--text-2);
  border:1px solid var(--border3); border-radius:6px;
  text-decoration:none; transition:all 0.2s; letter-spacing:0.05em;
}
.rk-pager .page-numbers:hover { border-color:var(--gold); color:var(--gold); }
.rk-pager .page-numbers.current {
  background:var(--gold); border-color:var(--gold); color:#fff; font-weight:500;
}
.rk-pager .page-numbers.dots { border:none; color:var(--text-3); min-width:24px; }
.rk-pager .prev, .rk-pager .next {
  font-size:16px; letter-spacing:0; color:var(--text-3);
  border-color:var(--border3);
}
.rk-pager .prev:hover, .rk-pager .next:hover { border-color:var(--gold); color:var(--gold); }

/* ══ Taxonomy variant overrides ══ */
.rk-hero--cat { background: var(--bg2); }
.rk-filter--cat { background: var(--bg2); }
.rk-list-inner--cat {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  background: transparent;
  min-width: 0;
}
.rk-list-inner--cat > * { min-width: 0; }
.rk-list-inner--cat .rk-card {
  border-radius: 8px;
  border: 1px solid var(--border3);
  margin-bottom: 0;
}
.rk-list-inner--cat .rk-card:hover {
  border-color: var(--gold);
  box-shadow: 0 4px 16px rgba(184,146,58,0.15);
}
/* タブレット以下は1列 */
@media (max-width: 900px) {
  .rk-list-inner--cat { grid-template-columns: 1fr; }
}
.rk-hero-subtitle { font-size: 0.72em; color: var(--text); display: block; }

/* ══ Pager - force override any cached styles ══ */
.rk-pager { display: flex !important; justify-content: center; align-items: center; gap: 0.375rem; margin-top: 2.5rem; flex-wrap: wrap; }
.rk-pager a.page-numbers,
.rk-pager span.page-numbers {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-width: 40px; height: 40px;
  padding: 0 0.75rem;
  font-size: 13px; font-family: 'Noto Sans JP', sans-serif;
  color: var(--text-2);
  background: #fff;
  border: 1px solid var(--border3);
  border-radius: 6px;
  text-decoration: none;
  transition: all 0.2s;
  letter-spacing: 0.05em;
}
.rk-pager a.page-numbers:hover {
  border-color: var(--gold);
  color: var(--gold);
  background: var(--gold-pale2);
}
.rk-pager span.page-numbers.current {
  background: var(--gold) !important;
  border-color: var(--gold) !important;
  color: #fff !important;
  font-weight: 600;
}
.rk-pager .page-numbers.dots {
  border: none !important;
  background: none !important;
  color: var(--text-3);
  min-width: 20px;
}

/* スマホ版ランキングカード */
@media (max-width: 768px) {
  .rk-list-inner--cat { grid-template-columns: 1fr; }
  .rk-card { overflow: hidden; }
  .rk-card-top { flex-wrap: wrap; }
  .rk-price-row { width: 100%; margin-top: 0.5rem; }
  .rk-price-val { font-size: 13px; }
  .rk-card-title { font-size: 15px; }
  .rk-card-bottom { gap: 0.4rem; }
  .rk-detail-btn { font-size: 10px; padding: 0.35rem 0.6rem; }
}

/* スマホ版ページャー */
@media (max-width: 480px) {
  .rk-pager a.page-numbers,
  .rk-pager span.page-numbers { min-width: 34px; height: 34px; font-size: 12px; }
}

/* ══════════════════════════════════════
   トップページ 注目機器 タブ付きセクション
══════════════════════════════════════ */

/* タブナビ */
.fp-tabs {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 2rem;
}
.fp-tab {
  padding: 0.5rem 1.5rem;
  font-size: 12px;
  letter-spacing: 0.12em;
  font-family: 'Noto Sans JP', sans-serif;
  border: 1px solid var(--border3);
  border-radius: 20px;
  background: #fff;
  color: var(--text-3);
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}
.fp-tab:hover { border-color: var(--gold); color: var(--gold); }
.fp-tab.active {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
  font-weight: 500;
}

/* タブパネル */
.fp-panel { display: none; }
.fp-panel.active { display: grid; }

/* もっと見るボタン */
.fp-more { text-align: center; margin-top: 2.5rem; }

/* カードの統一デザイン */
.pc-thumb {
  width: 100%;
  height: 160px;
  overflow: hidden;
  border-radius: 4px;
  margin-bottom: 1rem;
  background: var(--bg3);
}
.pc-thumb-img {
  width: 100%; height: 100%; object-fit: cover;
}
.pc-thumb--empty {
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--border3);
}
.pc-thumb--empty span {
  font-size: 11px; color: var(--text-3); letter-spacing: 0.1em;
}
.pc-name {
  font-family: 'Noto Serif JP', serif;
  font-size: 16px; font-weight: 400;
  color: var(--text); line-height: 1.4;
  margin-bottom: 0.25rem;
}
.pc-maker {
  font-size: 11px; color: var(--text-3);
  margin-bottom: 0.5rem; letter-spacing: 0.05em;
}
.pc-stars {
  display: flex; align-items: center; gap: 3px;
  margin-bottom: 0.5rem; flex-wrap: wrap;
}
.pc-rating-num {
  font-size: 16px; color: var(--gold);
  font-weight: 500; margin-left: 4px;
  font-family: 'Noto Sans JP', sans-serif;
}
.pc-review-ct {
  font-size: 11px; color: var(--text-3);
}
.pc-tags {
  display: flex; gap: 0.3rem; flex-wrap: wrap;
  margin-bottom: 0.5rem;
}
.pc-price {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 20px; color: var(--gold-dim);
  font-weight: 700; margin-top: 0.5rem; letter-spacing: 0.02em;
}
.pc-price span { font-size: 11px; color: var(--text-3); font-weight: 400; }
/* カード内レンタル価格 */
.pc-rental {
  display: flex; align-items: center; gap: 0.4rem;
  margin-top: 0.4rem; padding: 0.4rem 0.7rem;
  background: linear-gradient(135deg, var(--gold-pale2), var(--gold-pale));
  border: 1px solid var(--gold); border-radius: 5px;
  font-size: 11px; color: var(--gold-dim); white-space: nowrap;
}
.pc-rental span {
  font-family: 'Noto Sans JP', sans-serif; font-size: 14px;
  font-weight: 700; color: var(--gold-dim); white-space: nowrap;
}
.pc-repair-badge {
  display: none; /* タグに統合したので非表示 */
}

@media (max-width: 768px) {
  .fp-tabs { gap: 0.375rem; }
  .fp-tab { padding: 0.4rem 1rem; font-size: 11px; }
  .pc-thumb { height: 130px; }
}

/* ══ 口コミ本文 折りたたみ ══ */
.rv-body-wrap {
  position: relative;
}
/* collapsed はスマホのみ有効 */
@media (max-width: 768px) {
  .rv-body-wrap.collapsed .rv-body-text {
    max-height: 120px;
    overflow: hidden;
  }
  .rv-body-wrap.collapsed .rv-body-fade {
    display: block;
  }
}
.rv-body-fade {
  display: none;
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 60px;
  background: linear-gradient(to bottom, rgba(255,255,255,0), #fff);
  pointer-events: none;
}
.rv-toggle-btn {
  display: none;
  width: 100%;
  background: none;
  border: 1px solid var(--border3);
  border-radius: 6px;
  padding: 8px;
  font-size: 12px;
  color: var(--gold);
  cursor: pointer;
  font-family: inherit;
  letter-spacing: 0.08em;
  margin-top: 0.5rem;
  transition: all 0.2s;
}
.rv-toggle-btn:hover { background: var(--gold-pale2); }

/* スマホのみ折りたたみ有効 */
@media (max-width: 768px) {
  .rv-toggle-btn { display: block; }
  .rv-body-wrap.collapsed .rv-body-fade { display: block; }
}

/* ══ About ページ ヒーロー ══ */
.about-hero-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 5rem 2.5rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6rem;
  align-items: center;
}
.about-hero-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(40px, 5.5vw, 68px);
  font-weight: 300;
  color: var(--text);
  line-height: 1.1;
  letter-spacing: 0.03em;
  margin-bottom: 2rem;
}

@media (max-width: 768px) {
  .about-hero-inner {
    grid-template-columns: 1fr;
    gap: 2.5rem;
    padding: 3rem 1.25rem 2rem;
  }
  .about-hero-title {
    font-size: clamp(28px, 8vw, 44px);
    margin-bottom: 1.25rem;
  }
}

/* ══ お気に入りボタン ══ */
.fav-btn {
  position: absolute;
  top: 8px; right: 8px;
  width: 34px; height: 34px;
  background: rgba(255,255,255,0.9);
  border: 1px solid var(--border3);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: all 0.2s;
  z-index: 5;
  padding: 0;
  font-size: 18px;
  line-height: 1;
}
.fav-btn:hover { background: #fff; border-color: #e05c5c; transform: scale(1.1); }
.fav-btn[data-faved="1"] .fav-heart { color: #e05c5c; }
.fav-btn[data-faved="0"] .fav-heart { color: var(--text-3); }

/* ハート大きめ（機器詳細用） */
.fav-btn-lg {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: 1px solid var(--border3);
  border-radius: 6px;
  padding: 8px 16px;
  cursor: pointer;
  font-size: 14px;
  color: var(--text-3);
  transition: all 0.2s;
  font-family: inherit;
  justify-content: center;
}
.fav-btn-lg:hover { border-color: #e05c5c; color: #e05c5c; }
.fav-btn-lg[data-faved="1"] { border-color: #e05c5c; color: #e05c5c; background: #fff0f0; }

/* ══ 機器一覧 PC2列レイアウト ══ */
.products-grid--2col {
  /* PC: サイドバーの右側エリアで2列 */
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 1.25rem !important;
}

/* サイドバーなしの場合（max-widthで制御） */
@media (min-width: 1100px) {
  .products-grid--2col {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 1099px) and (min-width: 769px) {
  .products-grid--2col {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 768px) {
  .products-grid--2col {
    grid-template-columns: 1fr 1fr !important;
    gap: 0.75rem !important;
  }
}
@media (max-width: 480px) {
  .products-grid--2col {
    grid-template-columns: 1fr !important;
  }
}

/* ---- Utility classes (converted from inline styles) ---- */
.bc-current          { color:var(--text-2); }
.text-gold           { color:var(--gold); }
.text-error          { color:#e05c5c; }
.text-meta           {font-size: 14px;color:var(--text-3);}
.text-meta-13        { font-size:13px; color:var(--text-3); }
.text-body-sm        { font-size:14px; color:var(--text-2); line-height:2.2; }
.text-hint           { font-size:12px; font-weight:400; color:#888; }
.text-xs             { font-size:11px; }
.text-center         { text-align:center; }
.pos-rel             { position:relative; }
.mb-2  { margin-bottom:0.5rem; }
.mb-3  { margin-bottom:0.75rem; }
.mb-4  { margin-bottom:1rem; }
.mb-5  { margin-bottom:1.25rem; }
.mb-6  { margin-bottom:1.5rem; }
.mb-8  { margin-bottom:2rem; }
.icon-lg             { font-size:40px; margin-bottom:1rem; }
.eyebrow-label       {display:block;font-size: 14px;letter-spacing:0.15em;/* color: #ffffff; */font-weight:500;margin-bottom:0.4rem;}
.section-heading     { font-family:'Noto Serif JP',serif; font-size:18px; font-weight:400; border-left:3px solid var(--gold); padding-left:0.75rem; color:var(--text); margin-bottom:1.25rem; }
.section-heading-line{ font-family:'Noto Serif JP',serif; font-size:18px; font-weight:400; color:var(--text); margin-bottom:1.25rem; padding-bottom:0.75rem; border-bottom:1px solid var(--border3); }
.page-heading        { font-family:'Noto Serif JP',serif; font-size:28px; font-weight:400; color:var(--text); margin-bottom:0.5rem; }
.page-wrap           { max-width:800px; margin:0 auto; padding:2.5rem 1.25rem 5rem; }
.inner-wrap          { max-width:1200px; margin:0 auto; padding:0 2.5rem; box-sizing:border-box; }
@media (max-width: 768px) { .inner-wrap { padding:0 1.25rem; } }
.inner-wrap-sm       { max-width:900px; margin:0 auto; padding:0 1.25rem; }
.stat-num            { font-size:24px; color:var(--gold); font-weight:500; font-family:'Noto Sans JP',sans-serif; }
.stat-label          { font-size:11px; color:var(--text-3); margin-top:2px; }
.list-indent         { padding-left:1.5rem; margin:0.75rem 0; }
.form-input          { width:100%; background:#fff; border:1px solid var(--border3); color:var(--text); padding:10px 14px; font-size:14px; border-radius:6px; font-family:inherit; }
.form-input-sm       { width:100%; background:#fff; border:1px solid var(--border3); color:var(--text); padding:10px 14px; font-size:13px; border-radius:6px; font-family:inherit; }
.btn-submit          { width:100%; background:var(--gold); border:none; color:#fff; padding:15px; font-size:14px; letter-spacing:0.12em; border-radius:8px; cursor:pointer; font-family:inherit; }

/* ---- Round 2 utility classes ---- */
.mb-45               { margin-bottom:1.1rem; }
.mt-2                { margin-top:0.5rem; }
.mt-8                { margin-top:2rem; }
.mt-12               { margin-top:3rem; }
.section-card        { background:#fff; border:1px solid var(--border3); border-radius:12px; padding:2rem; }
.section-card-shadow { background:#fff; border:1px solid var(--border3); border-radius:12px; padding:2rem; margin-bottom:2rem; box-shadow:0 2px 12px rgba(0,0,0,0.06); }
.page-wrap-sm        { max-width:700px; margin:0 auto; padding:2.5rem 1.25rem 5rem; }
.page-wrap-lg        { max-width:1200px; margin:0 auto; padding:2.5rem 2.5rem 6rem; }
.page-heading-lg     { font-family:'Cormorant Garamond',serif; font-size:clamp(28px,4vw,44px); font-weight:400; color:var(--text); margin-bottom:0.5rem; }
.hero-section        { background:var(--gold-pale2); border-bottom:1px solid var(--border); padding:2rem 0; }
.divider             { height:0.5px; background:var(--border2); margin:1.5rem 0; }
.alert-success       { display:none; text-align:center; padding:2.5rem; background:var(--gold-pale2); border:2px solid var(--gold); border-radius:8px; margin-bottom:2rem; }
.alert-error         { display:none; background:#fff0f0; border:1px solid #e05c5c; border-radius:6px; padding:0.875rem; margin-bottom:1.25rem; font-size:13px; color:#e05c5c; }
.empty-state         { text-align:center; padding:5rem 2rem; }
.empty-state-dashed  { text-align:center; padding:3rem 2rem; background:var(--bg2); border-radius:8px; border:1px dashed var(--border3); }
.card-img-area       { height:140px; overflow:hidden; border-radius:4px; margin-bottom:1.25rem; border:1px solid var(--border3); }
.notice-box          { margin-top:2.5rem; padding:1.25rem; background:var(--bg2); border-radius:8px; font-size:13px; color:var(--text-3); }
.icon-xl             { font-size:48px; margin-bottom:1rem; }
.icon-md             { font-size:32px; margin-bottom:1rem; }
.icon-md-sm          { font-size:32px; margin-bottom:0.75rem; }
.icon-sm             {font-size:28px;text-align: center;margin-bottom:0.75rem;}
.icon-gold-dim       { font-size:20px; color:var(--gold-dim); }
.title-base          { font-size:17px; font-weight:500; color:var(--text); margin-bottom:0.5rem; }
.title-md            { font-size:16px; font-weight:500; color:var(--text); }
.title-sm            {font-size: 18px;font-weight:500;color:var(--text);margin-bottom:0.5rem;text-align: center;}
.title-xs            { font-size:14px; font-weight:500; color:var(--text); }
.label-sm            { font-size:13px; font-weight:500; color:var(--text); }
.text-14             { font-size:14px; }
.body-text           {font-size: 14px;color:var(--text-2);line-height:2.1;}
.text-meta-block     {font-size: 14px;color:var(--text-3);margin-bottom:1.75rem;line-height:1.9;}
.text-sm-quiet       { font-size:12px; color:var(--text-3); line-height:1.8; }
.text-micro-label    { font-size:11px; color:var(--text-3); letter-spacing:0.15em; margin-top:4px; }
.micro-heading       { font-size:10px; letter-spacing:0.45em; color:var(--gold); margin-bottom:0.75rem; }
.text-micro          { font-size:10px; color:var(--text-3); }
.text-sub            { font-size:14px; color:var(--text-2); margin-bottom:0.5rem; }
.text-sub-sm         { font-size:13px; color:var(--text-2); margin-top:0.5rem; }
.text-quiet-lg-mb    { font-size:12px; color:var(--text-3); margin-bottom:2.5rem; }
.text-gold-noto      { color:var(--gold); font-family:'Noto Sans JP',sans-serif; }
.link-quiet          { color:var(--text-3); text-decoration:none; }
.link-gold           { color:var(--gold); cursor:pointer; }
.stat-hero           { font-family:'Noto Sans JP',sans-serif; font-size:44px; font-weight:400; color:var(--gold); line-height:1; }
.tag-pill            { font-size:11px; color:var(--text-2); background:#fff; border:1px solid var(--border); border-radius:20px; padding:4px 12px; }
.tag-link            { display:inline-flex; align-items:center; gap:6px; background:#fff; border:1px solid var(--border); padding:6px 14px; border-radius:20px; font-size:12px; color:var(--text-2); text-decoration:none; }
.inline-mt-6         { display:inline-block; margin-top:1.5rem; }
.list-indent-sm      { padding-left:1.5rem; margin:0; font-size:13px; }
.flex-between        { display:flex; justify-content:space-between; align-items:center; }
.flex-center-gap     { display:flex; justify-content:center; gap:0.4rem; }
.flex-tags           { display:flex; gap:0.5rem; flex-wrap:wrap; }
.flex-row-sm         { display:flex; align-items:center; gap:4px; }
.grid-2col           { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }

/* section heading with wider padding */
.section-heading-2 { font-family:'Noto Serif JP',serif; font-size:18px; font-weight:400; border-left:3px solid var(--gold); padding-left:1rem; margin:2rem 0 1rem; }

/* ---- Round 4: per-page utility classes ---- */
/* advertising */
.adv-hero { background:linear-gradient(135deg,#1a1a1a 0%,#2d2510 100%); padding:4rem 0 3.5rem; }
.adv-hero-title { font-family:'Cormorant Garamond',serif; font-size:clamp(26px,4.5vw,48px); font-weight:400; color:#fff; line-height:1.2; margin-bottom:1rem; }
.adv-hero-desc { font-size:14px; color:rgba(255,255,255,0.7); line-height:1.9; max-width:600px; margin:0 auto 2rem; }
.adv-body { max-width:900px; margin:0 auto; padding:4rem 1.25rem 6rem; }
.adv-features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-bottom:4rem; }
.adv-feature-card { background:#fff; border:1px solid var(--border3); border-radius:8px; padding:1.75rem; text-align:center; }
.adv-flow-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; align-items:start; margin-bottom:4rem; }
.adv-flow-steps { display:flex; flex-direction:column; gap:1rem; }
.adv-step-row { display:flex; align-items:flex-start; gap:1rem; }
.adv-step-num { width:32px; height:32px; border-radius:50%; background:var(--gold); color:#fff; display:flex; align-items:center; justify-content:center; font-size:13px; flex-shrink:0; }
.adv-cta-box { background:var(--gold-pale2); border:2px solid var(--gold); border-radius:8px; padding:2.5rem; text-align:center; }
.adv-cta-title { font-family:'Noto Serif JP',serif; font-size:20px; font-weight:400; color:var(--text); margin-bottom:0.75rem; }
.adv-cta-btns { display:flex; flex-direction:column; align-items:center; gap:1rem; }
.icon-lg-36 { font-size:36px; margin-bottom:0.75rem; }
.btn-gold-lg { display:inline-block; background:var(--gold); color:#fff; padding:14px 40px; border-radius:4px; font-size:14px; letter-spacing:0.15em; text-decoration:none; }
.btn-gold-block { display:block; background:var(--gold); color:#fff; padding:14px 48px; border-radius:4px; font-size:14px; letter-spacing:0.15em; text-decoration:none; }
/* community */
.page-heading-md { font-family:'Cormorant Garamond',serif; font-size:clamp(22px,4vw,36px); font-weight:400; color:var(--text); margin-bottom:0.5rem; }
.page-wrap-md { max-width:1200px; margin:0 auto; padding:2rem 2.5rem 5rem; }
@media (max-width: 768px) { .page-wrap-md { padding:1.5rem 1rem 3rem; } }
.qa-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media (max-width: 768px) { .qa-grid { grid-template-columns:1fr; } }
.text-sm-body { font-size:12px; color:var(--text-2); line-height:1.9; }
.community-cta { background:#fff; border:2px solid var(--gold); border-radius:12px; padding:2.5rem; text-align:center; margin-bottom:3rem; }
.btn-line { display:inline-block; background:#06C755; color:#fff; padding:14px 36px; border-radius:8px; font-size:14px; letter-spacing:0.12em; text-decoration:none; margin-bottom:1rem; }
.qa-card-sm { background:#fff; border:1px solid var(--border3); border-radius:8px; padding:1.5rem; margin-bottom:0.75rem; }
.badge-gold-xs { font-size:9px; letter-spacing:0.3em; color:var(--gold); background:var(--gold-pale2); padding:3px 8px; border-radius:2px; }
.title-xs-flex { font-size:14px; font-weight:500; color:var(--text); flex:1; }
.body-text-sm { font-size:13px; color:var(--text-2); line-height:1.8; }
.flex-meta-row { display:flex; align-items:center; gap:0.75rem; font-size:12px; color:var(--text-3); }
.title-sm-line { font-size:15px; font-weight:500; color:var(--text); margin-bottom:0.5rem; line-height:1.5; }
/* mypage */
.user-header-row {display:flex;align-items:center;gap:1.25rem;margin-bottom:1.5rem;flex-wrap:wrap;flex-direction: column;}
.user-avatar { width:56px; height:56px; border-radius:50%; object-fit:cover; border:2px solid var(--gold); flex-shrink:0; }
.user-avatar-placeholder { width:56px; height:56px; border-radius:50%; background:var(--gold-pale); border:2px solid var(--gold); display:flex; align-items:center; justify-content:center; font-family:'Cormorant Garamond',serif; font-size:22px; color:var(--gold); flex-shrink:0; }
.flex-1-min0 { flex:1; min-width:0; }
.user-name { font-size:18px; font-weight:500; color:var(--text); margin-bottom:0.2rem; }
.badge-line-connected { display:flex; align-items:center; gap:6px; background:#f0faf4; border:1px solid #06C755; border-radius:20px; padding:4px 14px; font-size:11px; color:#049a42; white-space:nowrap; }
.user-stats-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; padding-top:1.25rem; border-top:1px solid var(--border3); text-align:center; }
.mypage-actions-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:2.5rem; }
.btn-action-primary { display:flex; align-items:center; justify-content:center; gap:0.5rem; background:var(--gold); color:#fff; padding:14px; border-radius:8px; text-decoration:none; font-size:13px; font-weight:500; letter-spacing:0.1em; }
.btn-action-secondary { display:flex; align-items:center; justify-content:center; gap:0.5rem; background:#fff; color:var(--text-2); padding:14px; border-radius:8px; text-decoration:none; font-size:13px; border:1px solid var(--border3); letter-spacing:0.08em; }
.fav-grid { display:grid; grid-template-columns:1fr 1fr; gap:0.75rem; }
.fav-card { display:block; background:#fff; border:1px solid var(--border3); border-radius:8px; overflow:hidden; text-decoration:none; transition:border-color 0.2s; }
.fav-card-body { padding:0.75rem; }
.fav-title { font-size:13px; font-weight:500; color:var(--text); margin-bottom:2px; line-height:1.3; }
.fav-maker { font-size:10px; color:var(--text-3); }
.fav-rating { font-size:12px; color:var(--gold); margin-top:3px; }
.link-gold-center { display:block; text-align:center; font-size:12px; color:var(--gold); margin-top:0.75rem; text-decoration:none; }
.review-card--clickable { cursor:pointer; }
.review-status-badge { font-size:10px; padding:2px 10px; border-radius:10px; }
.badge-pending { background:#fff3cd; color:#856404; border:1px solid #ffc107; }
.badge-published { background:#d4edda; color:#155724; border:1px solid #c3e6cb; }
.review-card { background:#fff; border:1px solid var(--border3); border-radius:8px; padding:1.25rem; margin-bottom:0.75rem; transition:border-color 0.2s; }
.review-header-row { display:flex; justify-content:space-between; align-items:flex-start; gap:1rem; flex-wrap:wrap; margin-bottom:0.75rem; }
.machine-label { font-size:10px; color:var(--gold); letter-spacing:0.15em; margin-bottom:0.25rem; }
.date-label { font-size:11px; color:var(--text-3); }
.star-row { display:flex; align-items:center; gap:3px; }
.rating-num-sm { font-size:14px; color:var(--gold); font-weight:500; margin-left:4px; }
.review-excerpt { font-size:13px; color:var(--text-2); line-height:1.9; }
.link-to-machine { font-size:11px; color:var(--gold); margin-top:0.75rem; letter-spacing:0.06em; }
.btn-gold-sm { display:inline-block; background:var(--gold); color:#fff; padding:10px 28px; border-radius:6px; font-size:13px; text-decoration:none; letter-spacing:0.1em; }
.qa-card-link { display:block; background:#fff; border:1px solid var(--border3); border-radius:8px; padding:1.1rem 1.25rem; margin-bottom:0.6rem; text-decoration:none; transition:border-color 0.2s; }
.flex-between-wrap { display:flex; justify-content:space-between; align-items:center; gap:0.75rem; flex-wrap:wrap; }
.text-quiet-mt { font-size:12px; color:var(--text-3); margin-top:0.3rem; }
.section-footer { text-align:center; padding-top:1.5rem; border-top:1px solid var(--border3); }
.btn-ghost {background:none;border:1px solid var(--border3);color:var(--text-3);padding:10px 28px;border-radius:6px;font-size:13px;cursor:pointer;font-family:inherit;letter-spacing:0.08em;transition:all 0.2s;text-align: center;}
/* register */
.page-wrap-xs { max-width:480px; margin:0 auto; padding:2.5rem 1.25rem 5rem; }
.steps-bar { display:flex; align-items:center; margin-bottom:2rem; }
.step-active { flex:1; text-align:center; padding:8px; font-size:11px; font-weight:500; background:var(--gold); color:#fff; }
.step-inactive { flex:1; text-align:center; padding:8px; font-size:11px; background:var(--bg3); color:var(--text-3); }
.form-card { background:#fff; border:1px solid var(--border3); border-radius:12px; padding:2rem; margin-bottom:1.5rem; }
.line-option-card { display:flex; align-items:center; gap:10px; padding:12px 16px; background:var(--gold-pale2); border:1px solid var(--gold); border-radius:6px; margin-bottom:0.5rem; }
.radio-gold { width:20px; height:20px; accent-color:var(--gold); }
.terms-box { background:#fff; border:1px solid var(--border3); border-radius:8px; padding:1rem; margin-bottom:1.25rem; font-size:12px; color:var(--text-3); line-height:1.9; }
.checkbox-row { display:flex; align-items:center; gap:8px; margin-bottom:1.5rem; font-size:13px; color:var(--text-2); }
.checkbox-gold { width:16px; height:16px; accent-color:var(--gold); flex-shrink:0; }
.form-footnote { text-align:center; margin-top:1rem; font-size:13px; color:var(--text-3); }
.dots-row { display:flex; justify-content:center; gap:0.5rem; margin-top:1.5rem; }
.dot-active { width:6px; height:6px; border-radius:50%; background:var(--gold); }
.dot-inactive { width:6px; height:6px; border-radius:50%; background:var(--bg3); }
/* single-machine */
.machine-img-placeholder { background:var(--bg2); border:0.5px solid var(--border2); aspect-ratio:4/3; display:flex; align-items:center; justify-content:center; border-radius:4px; }
.w-full { width:100%; }
.noto-gold-ml { font-family:'Noto Sans JP',sans-serif; color:var(--gold); margin-left:4px; }
.blur-overlay { filter:blur(4px); pointer-events:none; user-select:none; opacity:0.6; }
.spec-card { background:#fff; border:1px solid var(--border3); border-radius:8px; padding:1.75rem; margin-bottom:1.25rem; }
.spec-grid { display:grid; grid-template-columns:1fr 1fr; gap:0.5rem 1.5rem; }
.spec-row { display:flex; align-items:flex-start; gap:0.5rem; padding:0.5rem 0; border-bottom:0.5px solid var(--border2); }
.spec-label { font-size:11px; color:var(--text-3); letter-spacing:0.1em; flex-shrink:0; width:90px; padding-top:1px; }
.spec-value { font-size:13px; color:var(--text); line-height:1.6; }
.review-card { background:#fff; border:1px solid var(--border3); border-radius:8px; padding:1.5rem; margin-bottom:1rem; }
.review-card-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:0.75rem; flex-wrap:wrap; gap:0.5rem; }
.flex-row-gap-8 { display:flex; align-items:center; gap:8px; }
.user-avatar-sm { width:32px; height:32px; border-radius:50%; background:var(--gold-pale); display:flex; align-items:center; justify-content:center; font-size:14px; flex-shrink:0; }
.rating-num-xs { font-size:13px; color:var(--gold); font-weight:500; margin-left:4px; }
.review-body { font-size:13px; color:var(--text-2); line-height:1.9; margin-bottom:0.75rem; }
.badge-q { font-size:9px; font-weight:600; letter-spacing:0.2em; color:var(--gold); background:var(--gold-pale2); border:1px solid var(--gold); padding:2px 6px; border-radius:2px; flex-shrink:0; margin-top:2px; }
.badge-a { font-size:9px; font-weight:600; letter-spacing:0.2em; color:#fff; background:var(--gold); padding:2px 6px; border-radius:2px; flex-shrink:0; margin-top:2px; }
.qa-answer-row { display:flex; align-items:flex-start; gap:0.75rem; padding-top:0.75rem; border-top:0.5px solid var(--border2); }
.qa-answer-text { font-size:13px; color:var(--text-2); line-height:1.9; }
.flex-gap-sm { display:flex; gap:0.5rem; }
.btn-ghost-sm { display:inline-block; background:#fff; border:1px solid var(--border3); color:var(--text-2); padding:10px 24px; border-radius:6px; font-size:13px; text-decoration:none; letter-spacing:0.08em; }
.btn-fav { display:flex; align-items:center; gap:0.5rem; font-size:13px; color:var(--text-3); cursor:pointer; background:none; border:none; font-family:inherit; padding:0; }
.icon-18 { font-size:18px; }
.sidebar-box { background:var(--bg2); border-radius:8px; padding:1.5rem; }
.sidebar-label { font-size:12px; font-weight:500; color:var(--text-3); letter-spacing:0.15em; margin-bottom:1rem; }
.spec-item-row { display:flex; justify-content:space-between; align-items:center; padding:0.6rem 0; border-bottom:0.5px solid var(--border2); }
.spec-item-label { font-size:11px; color:var(--text-3); }
.spec-item-value { font-size:12px; color:var(--text); font-weight:500; }
/* about */
.pt-0 { padding-top:0; }
.text-gold-italic { font-style:italic; color:var(--gold); }
.body-text-wide { font-size:14px; color:var(--text-2); line-height:2.3; letter-spacing:0.05em; }
.about-quote-label { font-family:'Noto Serif JP',serif; font-size:15px; color:var(--gold-dim); letter-spacing:0.1em; margin-bottom:0.5rem; }
.hero-section-xl { background:var(--gold-pale2); border-bottom:1px solid var(--border); padding:4rem 0; }
.hero-section-lg { background:var(--gold-pale2); border-bottom:1px solid var(--border); padding:2.5rem 0; }
.about-hero-title { font-family:'Cormorant Garamond',serif; font-size:clamp(28px,5vw,52px); font-weight:400; color:var(--text); line-height:1.2; margin-bottom:1rem; }
.page-heading-hero { font-family:'Cormorant Garamond',serif; font-size:clamp(24px,4vw,40px); font-weight:400; color:var(--text); margin-bottom:0.5rem; }
.hero-desc { font-size:13px; color:var(--text-2); line-height:1.9; max-width:600px; }
.hero-desc-narrow {font-size:13px;color:var(--text-2);line-height:2;max-width:640px;margin-bottom: 0.75rem;}
.about-hero-desc { font-size:13px; color:var(--text-2); line-height:2.1; max-width:560px; }
.about-body { max-width:900px; margin:0 auto; padding:4rem 1.25rem 6rem; }
.about-2col { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:start; margin-bottom:4rem; }
.about-box { background:var(--gold-pale2); border-radius:8px; padding:2rem; }
.about-stat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-bottom:4rem; }
.stat-card { text-align:center; padding:1.5rem; background:#fff; border:1px solid var(--border3); border-radius:8px; }
.stat-num-lg { font-family:'Noto Sans JP',sans-serif; font-size:36px; font-weight:400; color:var(--gold); line-height:1; margin-bottom:0.25rem; }
.stat-label-sm { font-size:12px; color:var(--text-3); letter-spacing:0.1em; }
.about-principles { display:flex; flex-direction:column; gap:1.25rem; }
.principle-row { display:flex; align-items:flex-start; gap:1rem; }
.principle-icon { font-size:24px; flex-shrink:0; }
.principle-title { font-size:14px; font-weight:500; color:var(--text); margin-bottom:0.25rem; }
.text-quiet-sm { font-size:13px; color:var(--text-3); line-height:1.8; }
/* faq */
.faq-hero { background:var(--bg2); border-bottom:0.5px solid var(--border2); padding:2.5rem; }
.inner-wrap-sm-bare { max-width:900px; margin:0 auto; }
.faq-hero-title { font-family:'Cormorant Garamond',serif; font-size:clamp(32px,5vw,52px); font-weight:400; color:var(--text); line-height:1.2; }
.form-input-alt { width:100%; background:var(--bg3); border:0.5px solid var(--border2); color:var(--text); padding:11px 14px; font-size:13px; border-radius:6px; font-family:inherit; }
.faq-cat-btn { font-size:12px; padding:5px 14px; border-radius:20px; text-decoration:none; }
.faq-question-btn { width:100%; background:none; border:none; padding:1.25rem; display:flex; align-items:center; justify-content:space-between; gap:1rem; cursor:pointer; font-family:inherit; text-align:left; }
.faq-question-text { font-size:15px; font-weight:500; color:var(--text); line-height:1.5; }
.faq-toggle-icon { font-size:20px; color:var(--text-3); flex-shrink:0; line-height:1; }
.faq-answer { padding:0 1.25rem 1.25rem; font-size:13px; color:var(--text-2); line-height:2; }
/* login */
.login-page { min-height:100vh; background:var(--gold-pale2); padding:80px 1.5rem 4rem; display:flex; align-items:center; justify-content:center; }
.login-card { background:#fff; border:1px solid var(--border3); border-radius:12px; padding:2.5rem; width:100%; max-width:400px; }
.login-logo { font-family:'Cormorant Garamond',serif; font-size:24px; color:var(--gold); letter-spacing:0.1em; font-weight:400; margin-bottom:0.25rem; }
.login-divider { width:30px; height:2px; background:var(--gold); margin:0.75rem auto; border-radius:1px; }
.login-title { font-size:18px; font-weight:500; color:var(--text); }
.login-desc { font-size:12px; color:var(--text-3); margin-bottom:2rem; }
.btn-line-full { display:inline-block; background:#06C755; color:#fff; padding:14px 32px; border-radius:8px; font-size:14px; letter-spacing:0.12em; text-decoration:none; width:100%; box-sizing:border-box; text-align:center; margin-bottom:0.75rem; }
.login-note { font-size:11px; color:var(--text-3); text-align:center; margin-bottom:2rem; }
.login-footer-note { text-align:center; font-size:12px; color:var(--text-3); }
.link-gold-plain { color:var(--gold); text-decoration:none; }
/* single-question */
.question-heading { font-family:'Noto Serif JP',serif; font-size:clamp(18px,3vw,24px); font-weight:400; color:var(--text); margin-bottom:1rem; line-height:1.5; }
.question-body { font-size:14px; color:var(--text-2); line-height:2; padding-top:1rem; border-top:1px solid var(--border3); }
.answer-card { background:#fff; border:1px solid var(--border3); border-radius:8px; padding:1.5rem; margin-bottom:1rem; }
.answer-meta-row { display:flex; align-items:center; gap:8px; margin-bottom:1rem; }
.answer-body { font-size:14px; color:var(--text-2); line-height:2; }
.answer-meta-footer { display:flex; align-items:center; gap:0.5rem; font-size:12px; color:var(--text-3); }
.form-heading { font-family:'Noto Serif JP',serif; font-size:16px; font-weight:400; color:var(--text); margin-bottom:1rem; }
.resize-v { resize:vertical; }
.tag-pill-sm { font-size:11px; color:var(--text-2); background:#fff; border:1px solid var(--border); border-radius:20px; padding:4px 10px; }
/* taxonomy */
.cat-nav-pill { font-size:11px; color:var(--text-3); text-decoration:none; padding:6px 12px; border:0.5px solid var(--border2); border-radius:20px; }
.cat-filter-btn { display:inline-block; padding:5px 14px; font-size:12px; border-radius:20px; text-decoration:none; background:#fff; color:var(--text-2); border:1px solid var(--border); }
.cat-filter-btn--active { background:var(--gold); color:#fff; border-color:var(--gold); }
.btn-outline {display:inline-block;padding:10px 24px;border:0.5px solid var(--border);color:var(--text-2);text-decoration:none;font-size: 14px;border-radius:2px;letter-spacing:0.08em;}
.section-divider-top { margin-top:5rem; padding-top:3rem; border-top:0.5px solid var(--border2); }
/* front-page */
.pb-section { padding:0 0 6rem; }
.text-13 { font-size:13px; }
.btn-gold-pill { display:inline-flex; align-items:center; gap:6px; background:var(--gold-pale); border:1px solid var(--gold); padding:8px 18px; border-radius:20px; font-size:12px; color:var(--gold); text-decoration:none; letter-spacing:0.05em; }
.card-footer { padding:1rem 1.5rem; border-top:1px solid var(--border3); }
.flex-end-gap { display:flex; justify-content:flex-end; gap:0.5rem; }
/* repair-request */
.page-wrap-xl { max-width:1100px; margin:0 auto; padding:3rem 1.25rem 5rem; }
.grid-3col { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; }
.feature-card { background:#fff; border:1px solid var(--border3); border-radius:8px; padding:1.5rem; }
.machine-select-card { background:#fff; border:1px solid var(--border3); border-radius:4px; overflow:hidden; cursor:pointer; transition:border-color 0.2s; }
.machine-thumb { height:70px; overflow:hidden; }
.machine-label-sm { padding:0.4rem 0.5rem; font-size:11px; font-weight:500; color:var(--text); text-align:center; }
.machine-sublabel { font-size:11px; color:var(--text-3); font-weight:400; }
.note-box { font-size:13px; color:var(--text-3); line-height:1.9; padding:1rem; background:var(--bg2); border-radius:6px; }
.btn-gold-md { display:inline-block; background:var(--gold); color:#fff; padding:12px 32px; border-radius:6px; font-size:13px; text-decoration:none; letter-spacing:0.1em; }
.flex-1 { flex:1; }
.tags-row { display:flex; flex-wrap:wrap; gap:0.5rem; }
/* review-guidelines */
.highlight-box { background:var(--gold-pale2); border:2px solid var(--gold); border-radius:12px; padding:2rem; margin-bottom:2rem; }
.alert-danger { background:#fff0f0; border:1px solid #fcc; border-radius:6px; padding:1rem; font-size:13px; color:#c00; line-height:1.8; }
.flex-row-start { display:flex; align-items:flex-start; gap:1rem; }
.icon-sm-text { font-size:20px; flex-shrink:0; }
.mb-1 { margin-bottom:0.25rem; }
/* review-post */
.page-heading-sm { font-family:'Noto Serif JP',serif; font-size:24px; font-weight:400; color:var(--text); margin-bottom:0.5rem; }
.alert-box { background:var(--gold-pale2); border:2px solid var(--gold); border-radius:12px; padding:2rem; margin-bottom:2rem; }
.form-section { background:#fff; border:1px solid var(--border3); border-radius:8px; padding:1.5rem; margin-bottom:1.5rem; }
.machine-thumb-card { background:#fff; border:1px solid var(--border3); border-radius:4px; overflow:hidden; }
.thumb-img-area { height:80px; overflow:hidden; }
.thumb-label { padding:0.5rem; font-size:12px; font-weight:500; color:var(--text); }
.thumb-placeholder { display:flex; align-items:center; justify-content:center; height:80px; background:var(--bg2); color:var(--text-3); font-size:11px; }
.star-input-row { display:flex; gap:3px; }
.star-input { font-size:28px; cursor:pointer; color:var(--bg3); transition:color 0.1s; }
.text-quiet { font-size:12px; color:var(--text-3); }
/* recommended */
.grid-2col-lg { display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; }
.rec-card { background:#fff; border:1px solid var(--border3); border-radius:10px; overflow:hidden; }
.rec-card-body { padding:1.25rem; }
.rec-card-header { display:flex; align-items:flex-start; justify-content:space-between; gap:0.75rem; margin-bottom:0.75rem; }
.rec-cta-btn { flex-shrink:0; padding:0.75rem 1.5rem; font-size:12px; letter-spacing:0.1em; }
/* rk-star size variants */
.rk-star-sm { font-size:14px; }
.rk-star-xs { font-size:13px; }
/* qa-card answered */
.qa-card--answered { border-color:var(--gold-dim) !important; }
/* bar fill via CSS var */
.bar-fill-var { width:var(--bar-fill,0%); }

/* ---- Auto-generated utility classes (remaining inline styles) ---- */
.u1 { display:none;text-align:center;padding:2.5rem;background:var(--gold-pale2);border:2px solid var(--gold);border-radius:12px; }
.u2 { display:none;background:#fff0f0;border:1px solid #e05c5c;border-radius:6px;padding:0.875rem;margin-bottom:1.25rem;font-size:13px;color:#c00; }
.u3 { width:100%;background:#fff;border:1px solid var(--border3);color:var(--text);padding:10px 14px;font-size:14px;font-family:inherit;border-radius:6px;outline:none;box-sizing:border-box; }
.u4 { width:100%;background:#fff;border:1px solid var(--border3);color:var(--text);padding:10px 14px;font-size:14px;font-family:inherit;border-radius:6px;outline:none;cursor:pointer; }
.u5 { width:100%;background:#fff;border:1px solid var(--border3);color:var(--text);padding:10px 14px;font-size:14px;font-family:inherit;border-radius:6px;outline:none;resize:vertical;line-height:1.8;box-sizing:border-box; }
.u6 { width:100%;background:var(--gold);border:none;color:#fff;padding:15px;font-size:14px;letter-spacing:.12em;font-family:inherit;font-weight:500;cursor:pointer;border-radius:8px; }
.u7 { font-family:'Cormorant Garamond',serif;font-size:clamp(32px,5vw,52px);font-weight:400;color:var(--text);margin-bottom:1rem; }
.u8 { width:100%;background:var(--bg3);border:0.5px solid var(--border2);color:var(--text);padding:13px 44px 13px 18px;font-size:14px;font-family:inherit;border-radius:2px;outline:none; }
.u9 { position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none; }
.u10 { max-width:900px;margin:0 auto;padding:3rem 2.5rem 6rem; }
.u11 { background:var(--bg2);border:0.5px solid var(--border2);padding:2rem 2.5rem;border-radius:2px;display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;margin-top:4rem; }
@media (max-width: 768px) { .u11 { grid-template-columns:1fr; padding:1.5rem 1rem; gap:1rem; } .u13 { flex-direction:row; flex-wrap:wrap; } }
.u12 { font-family:'Noto Serif JP',serif;font-size:16px;color:var(--text);font-weight:400;margin-bottom:0.4rem; }
.u13 { display:flex;flex-direction:column;gap:0.75rem;flex-shrink:0; }
.u14 { text-align:center;text-decoration:none;padding:9px 20px;font-size:12px; }
.u15 { text-align:center;padding:3rem;color:var(--text-3); }
.u16 { margin-bottom:3rem; }
.u17 { font-size:10px;letter-spacing:0.35em;color:var(--gold-dim);margin-bottom:1rem;padding-bottom:0.6rem;border-bottom:0.5px solid var(--border2); }
.u18 { font-size:14px;color:var(--text-2);line-height:2.3;letter-spacing:0.05em;margin-bottom:2rem; }
.u19 {font-family:'Noto Serif JP',serif;font-size: 25px;color:var(--gold-dim);letter-spacing:0.12em;padding-top:1.5rem;border-top:0.5px solid var(--border2);}
.u20 {display:block;font-size: 14px;color:var(--text-3);letter-spacing:0.15em;margin-top:3px;margin-bottom: 10px;}
.u21 { background:var(--bg2);border:0.5px solid var(--border);border-radius:2px;padding:2.5rem;position:relative;overflow:hidden; }
.u22 { font-family:'Noto Sans JP',sans-serif;font-size:10px;letter-spacing:0.35em;color:var(--gold);margin-bottom:1.5rem; }
.u23 { border-top:0.5px solid var(--border2);padding:6rem 0; }
.u24 { font-family:'Cormorant Garamond',serif;font-size:clamp(30px,4vw,46px);font-weight:400;color:var(--text);margin-bottom:0.5rem; }
.u25 { font-style:normal;color:var(--gold); }
.u26 { width:40px;height:1px;background:var(--gold-dim);margin:1.5rem 0 3rem; }
.u27 { max-width:700px; }
.u28 { width:100%;border-collapse:collapse;font-size:13px; }
.u29 { border-bottom:0.5px solid var(--border2); }
.u30 { padding:1.1rem 0;color:var(--text-3);letter-spacing:0.1em;width:140px;vertical-align:top; }
.u31 { padding:1.1rem 0;color:var(--text-2); }
.u32 { background:var(--bg2);border-top:0.5px solid var(--border2);border-bottom:0.5px solid var(--border2);padding:5rem 0;text-align:center; }
.u33 { max-width:600px;margin:0 auto;padding:0 2.5rem; }
.u34 { font-family:'Cormorant Garamond',serif;font-size:clamp(26px,4vw,40px);color:var(--text);font-weight:400;margin-bottom:1rem; }
.u35 { font-size:13px;color:var(--text-2);line-height:2;margin-bottom:2.5rem; }
.u36 { font-size:11px;color:var(--text-2);background:#fff;border:1px solid var(--border);border-radius:20px;padding:4px 14px; }
.u37 { background:#fff;border-bottom:1px solid var(--border3);padding:0.75rem 0; }
.u38 { max-width:900px;margin:0 auto;padding:0 1.25rem;display:flex;gap:0.5rem;align-items:center;flex-wrap:wrap; }
.u39 { margin-left:auto;font-size:12px;color:var(--text-3); }
.u40 { max-width:900px;margin:0 auto;padding:1.5rem 1.25rem 4rem; }
.u41 { display:inline-flex;align-items:center;gap:4px;background:var(--gold-pale2);border:1px solid var(--border);border-radius:4px;padding:3px 10px;margin-top:0.4rem;font-size:11px;color:var(--gold-dim); }
.u42 { text-align:center;padding:4rem 2rem;color:var(--text-3);font-size:13px; }
.u43 { background:var(--gold-pale2);border-bottom:1px solid var(--border);padding:3rem 0 2rem; }
.u44 { font-family:'Cormorant Garamond',serif;font-size:clamp(28px,4vw,44px);font-weight:400;color:var(--text);margin-bottom:0.75rem;letter-spacing:0.03em; }
.u45 { background:#fff;border:2px solid var(--gold);border-radius:12px;padding:2.5rem;text-align:center;margin-bottom:2rem;box-shadow:0 4px 24px rgba(184,146,58,0.1); }
.u46 { display:inline-block;background:#06C755;color:#fff;padding:14px 36px;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none;letter-spacing:0.1em;margin-bottom:0.75rem;width:100%;max-width:280px; }
.u47 { position:relative;overflow:hidden;border-radius:12px; }
.u48 { filter:blur(5px);pointer-events:none;user-select:none; }
.u49 { background:#fff;border:1px solid var(--border3);border-radius:8px;padding:1.25rem;margin-bottom:0.75rem; }
.u50 { display:flex;gap:0.5rem;margin-bottom:0.75rem;flex-wrap:wrap; }
.u51 { font-size:9px;color:var(--gold);background:var(--gold-pale);padding:2px 8px;border-radius:8px;border:1px solid var(--border); }
.u52 { font-size:12px;color:var(--text-2);line-height:1.8;margin-bottom:0.75rem; }
.u53 { display:flex;justify-content:space-between;font-size:11px;color:var(--text-3); }
.u54 { position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,0.1),rgba(255,255,255,0.9)); }
.u55 { display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:0.75rem; }
.u56 { background:var(--gold);border:none;color:#fff;padding:10px 20px;border-radius:6px;font-size:12px;letter-spacing:0.1em;font-family:inherit;cursor:pointer; }
.u57 { display:none;background:var(--gold-pale2);border:1px solid var(--border);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem; }
.u58 { font-size:14px;font-weight:500;color:var(--text);margin-bottom:1rem; }
.u59 { display:none;background:#fff0f0;border:1px solid #e05c5c;border-radius:4px;padding:0.75rem;margin-bottom:1rem;font-size:12px;color:#c00; }
.u60 { width:100%;background:#fff;border:1px solid var(--border3);color:var(--text);padding:10px 14px;font-size:13px;font-family:inherit;border-radius:6px;margin-bottom:0.75rem;outline:none; }
.u61 { width:100%;background:#fff;border:1px solid var(--border3);color:var(--text);padding:10px 14px;font-size:13px;font-family:inherit;border-radius:6px;margin-bottom:0.75rem;resize:vertical;line-height:1.8;outline:none; }
.u62 { display:flex;gap:0.75rem;justify-content:flex-end; }
.u63 { background:none;border:1px solid var(--border3);color:var(--text-3);padding:8px 16px;border-radius:6px;font-size:12px;cursor:pointer;font-family:inherit; }
.u64 { background:var(--gold);border:none;color:#fff;padding:8px 20px;border-radius:6px;font-size:12px;cursor:pointer;font-family:inherit;letter-spacing:0.08em; }
.u65 { display:block;background:#fff;border:1px solid var(--border3);border-radius:8px;padding:1.25rem;text-decoration:none;transition:border-color 0.2s; }
.u66 { font-size:15px;font-weight:500;color:var(--text);line-height:1.4; }
.u67 { font-size:9px;background:#fff3cd;color:#856404;border:1px solid #ffc107;padding:1px 8px;border-radius:8px;white-space:nowrap; }
.u68 { font-size:11px;color:var(--text-3);white-space:nowrap;flex-shrink:0; }
.u69 { font-size:12px;color:var(--text-2);line-height:1.8;margin-bottom:0.5rem; }
.u70 { background:var(--gold);border:none;color:#fff;padding:10px 28px;border-radius:6px;font-size:13px;cursor:pointer;font-family:inherit;letter-spacing:0.1em; }
.u71 { background:#fff;border:1px solid var(--border3);border-radius:12px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 8px 32px rgba(0,0,0,0.10); }
.u72 { font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--gold);letter-spacing:0.2em;margin-bottom:0.4rem; }
.u73 { display:none;background:#fff0f0;border:1px solid #e05c5c;border-radius:6px;padding:0.75rem 1rem;margin-bottom:1.25rem;font-size:13px;color:#c00; }
.u74 { width:100%;background:#fff;border:1px solid var(--border3);color:var(--text);padding:10px 14px;font-size:13px;font-family:inherit;border-radius:6px;outline:none; }
.u75 { margin-bottom:1.75rem; }
.u76 { width:100%;background:var(--gold);border:none;color:#fff;padding:14px;font-size:14px;letter-spacing:0.15em;font-family:inherit;font-weight:500;cursor:pointer;border-radius:6px;transition:background 0.2s;margin-bottom:1rem; }
.u77 { font-size:11px;color:var(--text-3);text-align:center;line-height:2; }
.u78 { color:#06C755;font-weight:500; }
.u79 { font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:400;color:var(--text);margin-bottom:0.5rem; }
.u80 { flex:1;text-align:center;padding:8px;font-size:11px;font-weight:500;background:var(--gold);color:#fff;border-radius:6px 0 0 6px; }
.u81 { flex:1;text-align:center;padding:8px;font-size:11px;background:var(--bg3);color:var(--text-3);border-radius:0 6px 6px 0; }
.u82 { display:none;background:#fff0f0;border:1px solid #e05c5c;border-radius:6px;padding:.875rem 1rem;margin-bottom:1.25rem;font-size:13px;color:#c00; }
.u83 { background:#fff;border:1px solid var(--border3);border-radius:12px;padding:1.75rem;margin-bottom:1.25rem; }
.u84 { width:100%;background:#fff;border:1px solid var(--border3);color:var(--text);padding:11px 14px;font-size:14px;font-family:inherit;border-radius:6px;outline:none;box-sizing:border-box; }
.u85 { width:100%;background:#fff;border:1px solid var(--border3);color:var(--text);padding:11px 14px;font-size:14px;font-family:inherit;border-radius:6px;outline:none;cursor:pointer; }
.u86 { width:100%;background:#06C755;border:none;color:#fff;padding:16px;font-size:15px;letter-spacing:.1em;font-family:inherit;font-weight:500;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;gap:10px; }
.u87 { font-size:11px;color:var(--text-3);text-align:center;margin-top:.75rem; }
.u88 { color:var(--gold);cursor:pointer;text-decoration:underline; }
.u89 { display:none;text-align:center; }
.u90 { padding:2rem;background:#fff;border:1px solid var(--border3);border-radius:12px; }
.u91 { font-size:16px;font-weight:500;color:var(--text);margin-bottom:.5rem; }
.u92 { font-size:13px;color:var(--text-3);line-height:1.9;margin-bottom:1.5rem; }
.u93 { width:100%;background:#06C755;border:none;color:#fff;padding:14px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;margin-bottom:.75rem; }
.u94 { background:none;border:1px solid var(--border3);color:var(--text-3);padding:10px 20px;border-radius:6px;font-size:12px;cursor:pointer;font-family:inherit; }
.u95 { display:none;padding:3rem; }
.u96 { font-size:15px;color:var(--text); }
.u97 { display:none;text-align:center;padding:2.5rem 2rem;background:var(--gold-pale2);border:2px solid var(--gold);border-radius:12px; }
.u98 { font-size:52px;margin-bottom:1rem; }
.u99 { font-size:18px;font-weight:500;color:var(--text);margin-bottom:.5rem; }
.u100 { display:inline-block;background:var(--gold);color:#fff;padding:12px 32px;border-radius:6px;font-size:13px;text-decoration:none;letter-spacing:.1em; }
.u101 { background:var(--gold-pale2);border:2px solid var(--gold);border-radius:12px;padding:1.5rem;margin-bottom:2.5rem; }
.u102 {background:#fff0f0;border:1px solid #fcc;border-radius:6px;padding:1rem;font-size: 14px;color:#c00;}
.u103 { background:#fff;border:1px solid var(--border3);border-radius:8px;padding:1.25rem;margin-bottom:1rem; }
.u104 { font-size:12px;font-weight:600;color:var(--gold);letter-spacing:0.1em;margin-bottom:0.75rem; }
.u105 { background:#fff;border:1px solid #fcc;border-radius:8px;padding:1.25rem; }
.u106 { font-size:12px;font-weight:600;color:#c00;letter-spacing:0.1em;margin-bottom:0.75rem; }
.u107 { text-align:center;margin-top:2.5rem; }
.u108 { display:inline-block;background:var(--gold);color:#fff;padding:14px 40px;border-radius:8px;text-decoration:none;font-size:14px;font-weight:500;letter-spacing:0.1em; }
.u109 { background:var(--gold-pale2);border-bottom:1px solid var(--border);padding:3rem 0 0; }
.u110 { display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);padding:6px 14px;border-radius:20px;font-size:11px;color:var(--text-2); }
.u111 { display:flex;gap:0;border-bottom:1px solid var(--border);margin-top:2rem;overflow-x:auto; }
.u112 { background:var(--gold-pale2);border:2px solid var(--gold);border-radius:12px;padding:2.5rem;text-align:center; }
.u113 { display:inline-block;background:#06C755;color:#fff;padding:14px 36px;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none;letter-spacing:0.1em;margin-bottom:0.75rem; }
.u114 { display:none;background:#fff0f0;border:1px solid #e05c5c;border-radius:6px;padding:0.875rem 1rem;margin-bottom:1.5rem;font-size:13px;color:#c00; }
.u115 { width:100%;background:#fff;border:1px solid var(--border3);color:var(--text);padding:11px 14px;font-size:13px;font-family:inherit;border-radius:6px;outline:none;cursor:pointer; }
.u116 { display:flex;gap:0.5rem;align-items:center; }
.u117 { font-size:32px;background:none;border:none;cursor:pointer;color:var(--bg4);transition:color 0.15s;padding:0; }
.u118 { font-size:13px;color:var(--text-3);margin-left:0.5rem; }
.u119 { background:var(--bg2);border-radius:8px;padding:1.25rem;margin-bottom:1.5rem; }
.u120 { font-size:11px;letter-spacing:0.15em;color:var(--text-3);font-weight:500;margin-bottom:1rem; }
.u121 { display:flex;align-items:center;gap:1rem;margin-bottom:0.75rem;flex-wrap:wrap; }
.u122 { font-size:12px;color:var(--text-2);min-width:140px; }
.u123 { display:flex;gap:4px; }
.u124 { font-size:22px;background:none;border:none;cursor:pointer;color:var(--bg4);padding:0;transition:color 0.15s; }
.u125 { width:100%;background:#fff;border:1px solid var(--border3);color:var(--text);padding:11px 14px;font-size:13px;font-family:inherit;border-radius:6px;outline:none; }
.u126 { font-weight:400;color:var(--text-3); }
.u127 { width:100%;background:#fff;border:1px solid var(--border3);color:var(--text);padding:11px 14px;font-size:13px;font-family:inherit;border-radius:6px;outline:none;resize:vertical;line-height:1.8; }
.u128 { font-size:11px;color:var(--text-3);margin-top:4px;text-align:right; }
.u129 { width:100%;background:var(--gold);border:none;color:#fff;padding:15px;font-size:14px;letter-spacing:0.15em;font-family:inherit;font-weight:500;cursor:pointer;border-radius:8px;transition:background 0.2s; }
.u130 { font-size:11px;color:var(--text-3);text-align:center;margin-top:1rem;line-height:1.8; }
.u131 { display:none;text-align:center;padding:3rem 2rem;background:var(--gold-pale2);border:2px solid var(--gold);border-radius:12px; }
.u132 { font-size:18px;font-weight:500;color:var(--text);margin-bottom:0.5rem; }
.u133 { display:inline-block;background:var(--gold);color:#fff;padding:12px 32px;border-radius:6px;font-size:13px;text-decoration:none;letter-spacing:0.1em; }
.u134 { font-size:12px;color:var(--text-3); }
.u135 { display:flex;align-items:center;gap:0.5rem;flex-shrink:0; }
.u136 { background:var(--gold-pale2);border-bottom:1px solid var(--border);padding:2.5rem 0 2rem; }
.u137 { font-family:'Cormorant Garamond',serif;font-size:clamp(24px,4vw,40px);font-weight:400;color:var(--text);margin-bottom:0.75rem; }
.u138 { max-width:900px;margin:0 auto;padding:2.5rem 1.25rem 5rem; }
.u139 { display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:3rem; }
@media (max-width: 768px) { .u139 { grid-template-columns:1fr; gap:1rem; } .u136 { padding:1.5rem 0 1.25rem; } .u138 { padding:1.5rem 1rem 3rem; } }
.u140 { background:#fff;border:1px solid var(--border3);border-radius:10px;padding:1.25rem; }
.u141 { font-size:24px;margin-bottom:0.5rem; }
.u142 { font-size:14px;font-weight:500;color:var(--text);margin-bottom:0.4rem; }
.u143 { font-family:'Noto Serif JP',serif;font-size:20px;font-weight:400;color:var(--text);margin-bottom:1.5rem;padding-bottom:0.75rem;border-bottom:1px solid var(--border3); }
.u144 { display:none;text-align:center;padding:2.5rem;background:var(--gold-pale2);border:2px solid var(--gold);border-radius:12px;margin-bottom:2rem; }
.u145 { font-size:13px;color:var(--text-2);margin-top:0.5rem;line-height:1.9; }
.u146 { display:none;background:#fff0f0;border:1px solid #e05c5c;border-radius:6px;padding:0.875rem 1rem;margin-bottom:1.25rem;font-size:13px;color:#c00; }
.u147 { font-size:11px;color:var(--text-3);text-align:center;margin-top:0.75rem; }
.u148 {font-size:14px;color: rgb(255 255 255);line-height:1.9;max-width:600px;margin:0 auto 1.75rem;}
.u149 { display:inline-block;background:var(--gold);color:#fff;padding:14px 40px;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none;letter-spacing:0.1em; }
.u150 { max-width:900px;margin:0 auto;padding:3rem 1.25rem 5rem; }
.u151 { display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:3.5rem;text-align:center; }
.u152 { background:#fff;border:1px solid var(--border3);border-radius:10px;padding:1.75rem 1rem; }
.u153 {/* font-family:'Cormorant Garamond',serif; */font-size:36px;color:var(--gold);font-weight: 600;margin-bottom:0.25rem;}
.u154 {font-size: 14px;font-weight:500;color:var(--text);margin-bottom:0.25rem;}
.u155 { font-family:'Noto Serif JP',serif;font-size:22px;font-weight:400;color:var(--text);margin-bottom:1.5rem;text-align:center; }
.u156 { display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:3rem; }
.u157 { background:#fff;border:1px solid var(--border3);border-radius:10px;padding:1.5rem; }
.u158 {font-size: 16px;color:var(--text-3);line-height:1.8;margin-bottom:0.875rem;}
.u159 { font-size:12px;color:var(--gold);font-weight:500; }
.u160 { background:var(--gold-pale2);border:1px solid var(--border);border-radius:10px;padding:1.5rem;margin-bottom:3rem; }
.u161 {font-size: 16px;font-weight:500;color:var(--text);margin-bottom:1rem;}
.u162 {font-size: 14px;color:var(--text-2);line-height:1.9;}
.u163 { padding-left:1.5rem;margin:0; }
.u164 { font-family:'Noto Serif JP',serif;font-size:22px;font-weight:400;color:var(--text);margin-bottom:1.5rem; }
.u165 { display:flex;flex-wrap:wrap;gap:0.5rem;padding:0.75rem;background:var(--bg2);border-radius:6px; }
.u166 { display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-2);cursor:pointer; }
.u167 { accent-color:var(--gold); }

/* 広告掲載ページ SP対応 */
@media (max-width: 768px) {
  .adv-hero { padding: 2.5rem 0 2rem; }
  .adv-hero-title { font-size: clamp(20px, 5vw, 32px); }
  .u148 {font-size: 14px;}
  .u149 { padding: 12px 28px; font-size: 13px; }
  .u150 { padding: 2rem 1rem 3rem; }
  .u151 { grid-template-columns: 1fr; gap: 0.75rem; }
  .u153 {font-size: 33px;}
  .u155, .u164 {font-size: 20px;text-align: center;}
  .u156 { grid-template-columns: 1fr; gap: 0.75rem; }
  .grid-2col { grid-template-columns: 1fr; }
}
.u168 { background:var(--bg2);border:0.5px solid var(--border2);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:12px;letter-spacing:0.1em; }
.u169 { background:#fff;border:1px solid var(--border3);border-radius:8px;padding:1.75rem;margin-bottom:1rem; }
.u170 { display:flex;align-items:center;gap:0.75rem;margin-bottom:1rem; }
.u171 { font-size:18px;color:var(--gold);margin-left:6px;font-weight:500; }
.u172 { font-size:14px;line-height:2;color:var(--text); }
.u173 { position:absolute;left:0;right:0;bottom:0;height:120px;background:linear-gradient(to bottom,transparent,#fff);pointer-events:none; }
.u174 { position:relative;background:#fff;border:2px solid var(--gold);border-radius:12px;padding:2rem 2rem;margin-top:-20px;text-align:center;box-shadow:0 8px 32px rgba(184,146,58,0.12); }
.u175 { font-size:20px;margin-bottom:0.5rem; }
.u176 { font-size:16px;font-weight:500;color:var(--text);margin-bottom:0.4rem; }
.u177 { font-size:13px;color:var(--text-3);margin-bottom:1.5rem;line-height:1.8; }
.u178 { display:inline-block;background:#06C755;color:#fff;padding:14px 40px;border-radius:6px;font-size:15px;font-weight:500;letter-spacing:0.1em;text-decoration:none;margin-bottom:0.75rem;width:100%;max-width:320px; }
.u179 { background:#fff;border:1px solid var(--border3);border-radius:8px;padding:1.75rem;margin-bottom:1rem;box-shadow:0 2px 8px rgba(0,0,0,0.05); }
.u180 { display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem; }
.u181 { display:flex;align-items:center;gap:0.75rem; }
.u182 { font-size:11px;color:var(--text-3);letter-spacing:0.06em; }
.u183 { font-family:'Noto Sans JP',sans-serif;font-size:18px;color:var(--gold);margin-left:6px;font-weight:500; }
.u184 { font-size:14px;color:var(--text);line-height:2;font-weight:600;margin-bottom:1rem; }
.u185 { padding-top:1rem;border-top:1px solid var(--border3); }
.u186 { text-align:center;padding:3rem;color:var(--text-3);font-size:13px; }
.u187 { background:rgba(201,169,110,0.06);border:0.5px solid rgba(201,169,110,0.18);padding:1.75rem;border-radius:2px;margin-bottom:2rem;display:flex;gap:1.25rem;align-items:flex-start; }
.u188 { font-size:22px;flex-shrink:0; }
.u189 { font-size:15px;color:var(--text);margin-bottom:0.5rem; }
.u190 { background:var(--bg2);border:0.5px solid var(--border2);padding:1.75rem;border-radius:2px; }
.u191 { font-size:13px;color:var(--text-2);line-height:2;margin-bottom:1.25rem; }
.u192 { background:none;border:0.5px solid var(--border);color:var(--gold);padding:10px 24px;font-size:12px;letter-spacing:0.15em;display:inline-block;text-decoration:none;border-radius:2px;transition:all 0.2s; }
.u193 { background:var(--bg2);border-top:0.5px solid var(--border2);padding:4rem 0; }
.u194 { font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:400;color:var(--text);margin-bottom:2rem; }
.u195 { display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1px;background:var(--border2); }
.u196 { background:var(--bg2);padding:1.75rem;cursor:pointer; }
.u197 {height:100px;overflow:hidden;border-radius:1px;background: white;margin-bottom:1.25rem;}
.u198 { height:100px;background:var(--bg3);border:0.5px solid var(--border2);display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:11px;margin-bottom:1.25rem;border-radius:1px; }
.u199 { font-family:'Noto Serif JP',serif;font-size:14px;color:var(--text);margin-bottom:0.25rem; }
.u200 { font-size:11px;color:var(--text-3);margin-bottom:0.5rem; }
.u201 { display:flex;align-items:center;gap:2px; }
.u202 { font-size:13px;color:var(--gold);margin-left:4px;font-weight:500; }
.u203 { font-size:11px;color:var(--text-3);margin-left:2px; }
.u204 { font-size:9px;letter-spacing:0.3em;color:var(--gold);background:var(--gold-pale);padding:2px 10px;border-radius:8px;border:1px solid var(--border); }
.u205 { font-family:'Noto Serif JP',serif;font-size:clamp(18px,3vw,24px);font-weight:400;color:var(--text);line-height:1.5;margin-bottom:1.25rem; }
.u206 { background:#fff;border:2px solid var(--gold);border-radius:12px;padding:2.5rem;text-align:center;margin-bottom:2rem; }
.u207 { font-size:16px;font-weight:500;color:var(--text);margin-bottom:0.5rem; }
.u208 { font-size:12px;color:var(--text-3);margin-bottom:1.5rem;line-height:1.9; }
.u209 { display:inline-block;background:#06C755;color:#fff;padding:12px 32px;border-radius:6px;font-size:13px;font-weight:500;text-decoration:none;letter-spacing:0.1em; }
.u210 { background:var(--gold-pale2);border:1px solid var(--border);border-radius:8px;padding:1.5rem;margin-bottom:2rem; }
.u211 { font-size:13px;font-weight:500;color:var(--text);margin-bottom:0.75rem; }
.u212 { display:none;background:#fff0f0;border:1px solid #e05c5c;border-radius:4px;padding:0.75rem;margin-bottom:0.75rem;font-size:12px;color:#c00; }
.u213 { text-align:right; }
.u214 { background:var(--gold);border:none;color:#fff;padding:9px 24px;border-radius:6px;font-size:12px;cursor:pointer;font-family:inherit;letter-spacing:0.1em; }
.u215 { font-family:'Noto Serif JP',serif;font-size:17px;font-weight:400;color:var(--text);margin-bottom:1.25rem; }
.u216 { font-size:14px;color:var(--gold); }
.u217 { text-align:center;padding:2.5rem 2rem;background:var(--bg2);border-radius:8px;border:1px dashed var(--border3); }
.u218 { display:flex;align-items:center;gap:0.75rem;margin-bottom:0.75rem;flex-wrap:wrap; }
.u219 { width:32px;height:32px;border-radius:50%;background:var(--gold-pale);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--gold);font-weight:500;flex-shrink:0; }
.u220 { font-size:9px;background:var(--gold);color:#fff;padding:1px 7px;border-radius:8px;margin-left:4px;letter-spacing:0.1em; }
.u221 { margin-top:2rem;text-align:center; }
.u222 { display:inline-flex;align-items:center;gap:6px;color:var(--text-3);text-decoration:none;font-size:12px;letter-spacing:0.08em; }
.u223 { font-size:11px;color:var(--text-3);text-decoration:none;padding:6px 12px;border:0.5px solid var(--border2);border-radius:1px;transition:all 0.2s; }
.u224 { display:inline-block;padding:10px 24px;border:0.5px solid var(--border);color:var(--text-2);text-decoration:none;font-size:12px;letter-spacing:0.1em;border-radius:2px; }
.u225 { font-family:'Noto Serif JP',serif;font-size:18px;font-weight:400;color:var(--text);letter-spacing:0.04em;margin-bottom:1rem;padding-bottom:0.75rem;border-bottom:0.5px solid var(--border2);display:flex;align-items:center;gap:0.75rem; }
.u226 { display:inline-block;width:3px;height:18px;background:var(--gold-dim);border-radius:1px;flex-shrink:0; }
.u227 { font-size:13px;color:var(--text-2);line-height:2.3;letter-spacing:0.04em; }
.u228 { background:var(--bg2);border-top:0.5px solid var(--border2);border-bottom:0.5px solid var(--border2);padding:4rem 0;text-align:center; }
.u229 { max-width:560px;margin:0 auto;padding:0 2.5rem; }
.u230 { font-family:'Cormorant Garamond',serif;font-size:clamp(24px,4vw,36px);color:var(--text);font-weight:400;margin-bottom:1rem;letter-spacing:0.04em; }
.u231 { font-size:13px;color:var(--text-2);line-height:2;margin-bottom:2rem;letter-spacing:0.04em; }
.u232 { display:inline-flex;align-items:center;gap:6px;background:var(--gold-pale);border:1px solid var(--border);border-radius:4px;padding:4px 12px;margin-bottom:0.75rem;font-size:11px;color:var(--gold-dim);letter-spacing:0.1em;font-weight:500; }
.u233 { position:relative;overflow:hidden;max-height:80px;padding:0 1.5rem; }
.u234 { font-size:13px;color:var(--text-2);line-height:2.1;filter:blur(3px);user-select:none;pointer-events:none; }
.u235 { position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,0.2),rgba(255,255,255,0.95)); }
.u236 { background:var(--gold-pale2);border-top:1px solid var(--border);padding:0.875rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap; }
.u237 { display:flex;align-items:center;gap:0.5rem; }
.u238 { font-size:12px;color:var(--text-2); }
.u239 { font-weight:500;color:var(--text); }
.u240 { flex-shrink:0; }
.u241 { padding:8px 20px;font-size:12px; }
.u242 { max-width:1200px;margin:0 auto;padding:0 2.5rem;display:flex;border-bottom:0.5px solid var(--border2);overflow-x:auto; }
.u243 { display:inline; }

/* ============================
   口コミ一覧ページ (reviews.php)
   ============================ */
/* ヒーロー */
.rv-hero { background:var(--gold-pale2); border-bottom:1px solid var(--border); padding:3rem 0 2.5rem; }
.rv-hero-inner { max-width:900px; margin:0 auto; padding:0 1.25rem; }
.rv-hero-title { font-family:'Cormorant Garamond',serif; font-size:clamp(28px,4vw,44px); font-weight:400; color:var(--text); margin-bottom:0.75rem; line-height:1.25; }
.rv-hero-title span { color:var(--gold); font-style:italic; }
.rv-hero-desc { font-size:13px; color:var(--text-2); line-height:2; max-width:640px; margin-bottom:1.5rem; }
.rv-hero-stats { display:flex; gap:2rem; }
.rv-hero-stat { display:flex; align-items:baseline; gap:0.3rem; }
.rv-stat-num {/* font-family:'Cormorant Garamond',serif; */font-size:32px;font-weight: 600;color:var(--gold);line-height:1;}
.rv-stat-label { font-size:12px; color:var(--text-3); }

/* フィルターバー */
.rv-filter-bar { background:#fff; border-bottom:1px solid var(--border3); position:sticky; top:0; z-index:100; }
.rv-filter-inner { max-width:1200px; margin:0 auto; padding:0.75rem 2.5rem; display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.rv-filter-form { display:flex; align-items:center; gap:0.75rem; flex-wrap:wrap; flex:1; }
.rv-filter-group { display:flex; align-items:center; gap:0.4rem; }
.rv-filter-label { font-size:11px; color:var(--text-3); letter-spacing:0.1em; white-space:nowrap; }
.rv-filter-select { background:#fff; border:0.5px solid var(--border2); color:var(--text); padding:6px 10px; font-size:12px; border-radius:4px; font-family:inherit; cursor:pointer; }
.rv-filter-btn { background:var(--gold); border:none; color:#fff; padding:7px 16px; border-radius:4px; font-size:12px; cursor:pointer; font-family:inherit; }
.rv-result-count { font-size:12px; color:var(--text-3); white-space:nowrap; margin-left:auto; }
.rv-result-count strong { color:var(--text); }
.rv-reset-link { font-size:11px; color:var(--gold); text-decoration:none; margin-right:0.75rem; }

/* 口コミ一覧 */
.rv-list-wrap { padding:2rem 0 5rem; }
.rv-list-inner { max-width:1200px; margin:0 auto; padding:0 2.5rem; }
.rv-cards { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
@media (max-width: 900px) { .rv-cards { grid-template-columns:1fr; } }

/* 口コミカード */
.rv-card { background:#fff; border:1px solid var(--border3); border-radius:10px; padding:1.75rem; transition:border-color 0.2s; }
.rv-card:hover { border-color:var(--gold-dim); }
.rv-card-head { display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; margin-bottom:1rem; flex-wrap:wrap; }
.rv-card-author { display:flex; align-items:center; gap:0.75rem; }
.rv-avatar { width:36px; height:36px; border-radius:50%; background:var(--gold-pale); border:1px solid var(--gold); display:flex; align-items:center; justify-content:center; font-family:'Cormorant Garamond',serif; font-size:14px; color:var(--gold); flex-shrink:0; }
.rv-author-name { font-size:13px; font-weight:500; color:var(--text); }
.rv-author-type { font-size:11px; color:var(--text-3); }
.rv-card-meta { display:flex; flex-direction:column; align-items:flex-end; gap:0.4rem; }
.rv-machine-tag { display:inline-block; background:var(--gold-pale2); border:0.5px solid var(--gold); color:var(--gold); font-size:11px; padding:3px 10px; border-radius:3px; text-decoration:none; white-space:nowrap; }
.rv-machine-tag:hover { background:var(--gold); color:#fff; }
.rv-date { font-size:11px; color:var(--text-3); }
.rv-rating-row { display:flex; align-items:center; gap:0.5rem; margin-bottom:0.5rem; }
.rv-rating-num { font-size:18px; color:var(--gold); font-weight:500; font-family:'Cormorant Garamond',serif; line-height:1; }
.rv-card-title { font-family:'Noto Serif JP',serif; font-size:15px; font-weight:400; color:var(--text); margin-bottom:0.875rem; line-height:1.5; }
.rv-card-content { font-size:13px; color:var(--text-2); line-height:2; margin-bottom:1rem; }
.rv-card-excerpt { font-size:13px; color:var(--text-2); line-height:2; margin-bottom:0.75rem; }

/* ゲート */
.rv-gate { background:var(--gold-pale2); border:1px solid var(--gold); border-radius:6px; padding:1.25rem; text-align:center; }
.rv-gate-msg { font-size:12px; color:var(--text-2); margin-bottom:0.75rem; }
.rv-gate-btn { display:inline-block; background:var(--gold); color:#fff; padding:9px 28px; border-radius:4px; font-size:13px; text-decoration:none; letter-spacing:0.1em; }

/* サブ評価バー */
.rv-sub-ratings { margin-top:1rem; padding-top:1rem; border-top:0.5px solid var(--border2); display:grid; grid-template-columns:repeat(3,1fr); gap:0.5rem 1.5rem; }
.rv-sub-item { display:flex; align-items:center; gap:0.4rem; }
.rv-sub-label { font-size:10px; color:var(--text-3); flex-shrink:0; width:42px; }
.rv-sub-bar { flex:1; height:3px; background:var(--bg3); border-radius:2px; overflow:hidden; }
.rv-sub-fill { height:100%; width:var(--bar-fill,0%); background:var(--gold); border-radius:2px; }
.rv-sub-val { font-size:11px; color:var(--gold); flex-shrink:0; }

/* ページネーション */
.rv-pager { display:flex; justify-content:center; gap:0.4rem; margin-top:3rem; }
.rv-pager a.page-numbers, .rv-pager span.page-numbers { display:inline-flex; align-items:center; justify-content:center; min-width:38px; height:38px; font-size:13px; border:0.5px solid var(--border2); border-radius:4px; text-decoration:none; color:var(--text-2); }
.rv-pager a.page-numbers:hover { border-color:var(--gold); color:var(--gold); }
.rv-pager span.page-numbers.current { background:var(--gold); color:#fff; border-color:var(--gold); }

/* 空状態 */
.rv-empty { text-align:center; padding:5rem 2rem; color:var(--text-3); }
.rv-empty p { font-size:14px; margin:1rem 0 1.5rem; }

/* レスポンシブ */
@media (max-width:640px) {
  .rv-filter-form { gap:0.5rem; }
  .rv-sub-ratings { grid-template-columns:repeat(2,1fr); }
  .rv-card { padding:1.25rem; }
  .rv-hero-stats { gap:1.25rem; }
}

/* トップページ → 口コミ一覧ボタン */
.btn-reviews-more {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: transparent;
  border: 1px solid var(--gold);
  color: var(--gold);
  padding: 12px 36px;
  border-radius: 2px;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.btn-reviews-more:hover {
  background: var(--gold);
  color: #fff;
}

/* ============================
   コラム共通スタイル
   ============================ */

/* ── コラムトップ ── */
.col-hero { background:var(--gold-pale2); border-bottom:1px solid var(--border); padding:3rem 0 2.5rem; }
.col-hero-inner { max-width:900px; margin:0 auto; padding:0 1.25rem; }
.col-hero-title { font-family:'Cormorant Garamond',serif; font-size:clamp(28px,4vw,44px); font-weight:400; color:var(--text); margin-bottom:0.75rem; }
.col-hero-title span { color:var(--gold); font-style:italic; }
.col-hero-desc { font-size:13px; color:var(--text-2); line-height:2; max-width:640px; }

.col-cat-nav { background:#fff; border-bottom:1px solid var(--border3); padding:0.75rem 0; }
.col-cat-nav-inner { max-width:900px; margin:0 auto; padding:0 1.25rem; display:flex; gap:0.5rem; flex-wrap:wrap; }
.col-cat-pill { display:inline-flex; align-items:center; gap:0.35rem; background:var(--bg2); border:0.5px solid var(--border2); color:var(--text-2); font-size:12px; padding:5px 12px; border-radius:20px; text-decoration:none; transition:all 0.2s; white-space:nowrap; }
.col-cat-pill:hover { background:var(--gold-pale2); border-color:var(--gold); color:var(--gold); }

.col-top-wrap { padding:2.5rem 0 5rem; }
.col-top-inner { max-width:900px; margin:0 auto; padding:0 1.25rem; }

.col-section { margin-bottom:3.5rem; }
.col-section-head { display:flex; align-items:baseline; gap:1rem; flex-wrap:wrap; margin-bottom:1.25rem; padding-bottom:0.875rem; border-bottom:1px solid var(--border3); }
.col-section-title { font-family:'Noto Serif JP',serif; font-size:18px; font-weight:400; color:var(--text); flex-shrink:0; }
.col-section-icon { margin-right:0.3rem; }
.col-section-desc { font-size:12px; color:var(--text-3); flex:1; }
.col-section-more { font-size:12px; color:var(--gold); text-decoration:none; white-space:nowrap; }
.col-section-more:hover { text-decoration:underline; }

/* ── アーカイブページ ── */
.col-archive-hero { background:var(--gold-pale2); border-bottom:1px solid var(--border); padding:2.5rem 0; }
.col-archive-hero-inner { max-width:900px; margin:0 auto; padding:0 1.25rem; }
.col-archive-title { font-family:'Cormorant Garamond',serif; font-size:clamp(24px,4vw,38px); font-weight:400; color:var(--text); margin-bottom:0.5rem; }
.col-archive-desc { font-size:13px; color:var(--text-2); line-height:1.9; }

.col-archive-wrap { padding:2rem 0 5rem; }
.col-archive-inner { max-width:900px; margin:0 auto; padding:0 1.25rem; }

/* ── カードグリッド ── */
.col-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; }
.col-grid--4 { grid-template-columns:repeat(4,1fr); gap:1rem; }
.col-grid--3 { grid-template-columns:repeat(3,1fr); gap:1rem; }

/* ── カード ── */
.col-card { background:#fff; border:1px solid var(--border3); border-radius:8px; overflow:hidden; transition:border-color 0.2s, box-shadow 0.2s; }
.col-card:hover { border-color:var(--gold-dim); box-shadow:0 4px 16px rgba(0,0,0,0.06); }
.col-card-thumb { display:block; aspect-ratio:16/9; overflow:hidden; background:var(--bg2); }
.col-card-thumb img { width:100%; height:100%; object-fit:cover; transition:transform 0.3s; }
.col-card:hover .col-card-thumb img { transform:scale(1.03); }
.col-card-thumb--noimg { display:flex; align-items:center; justify-content:center; font-size:32px; color:var(--text-3); }
.col-card-body { padding:1rem; }
.col-card-cat { display:inline-block; background:var(--gold-pale2); color:var(--gold); font-size:10px; letter-spacing:0.1em; padding:2px 8px; border-radius:2px; margin-bottom:0.5rem; text-decoration:none; }
.col-card-cat:hover { background:var(--gold); color:#fff; }
.col-card-title { font-size:14px; font-weight:500; color:var(--text); margin-bottom:0.5rem; line-height:1.5; }
.col-card-title a { color:inherit; text-decoration:none; }
.col-card-title a:hover { color:var(--gold); }
.col-card-title--sm { font-size:13px; margin-bottom:0.4rem; }
.col-card-excerpt { font-size:12px; color:var(--text-3); line-height:1.8; margin-bottom:0.75rem; }
.col-card-foot { display:flex; align-items:center; justify-content:space-between; }
.col-card-date { font-size:11px; color:var(--text-3); }
.col-card-more { font-size:11px; color:var(--gold); text-decoration:none; }

/* ── ページネーション ── */
.col-pager { display:flex; justify-content:center; gap:0.4rem; margin-top:3rem; }
.col-pager .page-numbers { display:inline-flex; align-items:center; justify-content:center; min-width:38px; height:38px; font-size:13px; border:0.5px solid var(--border2); border-radius:4px; text-decoration:none; color:var(--text-2); }
.col-pager .page-numbers:hover { border-color:var(--gold); color:var(--gold); }
.col-pager .page-numbers.current { background:var(--gold); color:#fff; border-color:var(--gold); }

/* ── 記事詳細 ── */
.col-article-wrap { padding:2rem 0 5rem; }
.col-article-inner { max-width:780px; margin:0 auto; padding:0 1.25rem; }

.col-article-head { margin-bottom:1.5rem; }
.col-article-title { font-family:'Noto Serif JP',serif; font-size:clamp(20px,3vw,28px); font-weight:400; color:var(--text); margin:0.5rem 0 0.75rem; line-height:1.5; }
.col-article-meta { display:flex; align-items:center; gap:0.75rem; font-size:12px; color:var(--text-3); }
.col-article-updated { color:var(--text-3); }

.col-article-thumb { margin-bottom:1.75rem; border-radius:6px; overflow:hidden; }
.col-article-thumb img { width:100%; height:auto; display:block; }

.col-article-body { font-size:15px; color:var(--text-2); line-height:2.2; margin-bottom:2rem; }
.col-article-body h2 { font-family:'Noto Serif JP',serif; font-size:20px; font-weight:400; color:var(--text); border-left:3px solid var(--gold); padding-left:0.875rem; margin:2.5rem 0 1rem; }
.col-article-body h3 { font-size:17px; font-weight:500; color:var(--text); margin:2rem 0 0.75rem; padding-bottom:0.4rem; border-bottom:0.5px solid var(--border2); }
.col-article-body h4 { font-size:15px; font-weight:500; color:var(--text); margin:1.5rem 0 0.5rem; }
.col-article-body p { margin-bottom:1.25rem; }
.col-article-body ul, .col-article-body ol { padding-left:1.5rem; margin-bottom:1.25rem; }
.col-article-body li { margin-bottom:0.4rem; line-height:1.9; }
.col-article-body table { width:100%; border-collapse:collapse; margin-bottom:1.5rem; font-size:14px; }
.col-article-body th { background:var(--gold-pale2); border:1px solid var(--border3); padding:8px 12px; font-weight:500; }
.col-article-body td { border:1px solid var(--border3); padding:8px 12px; }
.col-article-body blockquote { background:var(--bg2); border-left:3px solid var(--gold); padding:1rem 1.25rem; margin:1.5rem 0; font-size:14px; color:var(--text-3); }
.col-article-body strong { color:var(--text); font-weight:600; }
.col-article-body a { color:var(--gold); }
.col-article-body img { max-width:100%; height:auto; border-radius:4px; }

.col-article-tags { display:flex; gap:0.4rem; flex-wrap:wrap; margin-bottom:2rem; }

.col-article-nav { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin:2.5rem 0; padding:1.5rem 0; border-top:0.5px solid var(--border2); border-bottom:0.5px solid var(--border2); }
.col-nav-prev a, .col-nav-next a { display:flex; flex-direction:column; gap:0.3rem; text-decoration:none; }
.col-nav-next { text-align:right; }
.col-nav-label { font-size:11px; color:var(--text-3); letter-spacing:0.1em; }
.col-nav-title { font-size:13px; color:var(--text); line-height:1.5; }
.col-nav-prev a:hover .col-nav-title, .col-nav-next a:hover .col-nav-title { color:var(--gold); }

.col-related { margin-top:3rem; }
.col-cta { background:var(--gold-pale2); border:1px solid var(--gold); border-radius:8px; padding:2rem; text-align:center; margin-top:3rem; }
.col-cta-label { font-size:10px; letter-spacing:0.4em; color:var(--gold); margin-bottom:0.4rem; }
.col-cta-text { font-size:15px; font-weight:500; color:var(--text); margin-bottom:1.25rem; }

/* レスポンシブ */
@media (max-width:768px) {
  .col-grid { grid-template-columns:repeat(2,1fr); }
  .col-grid--4 { grid-template-columns:repeat(2,1fr); }
  .col-grid--3 { grid-template-columns:repeat(2,1fr); }
  .col-article-nav { grid-template-columns:1fr; }
  .col-nav-next { text-align:left; }
}
@media (max-width:480px) {
  .col-grid { grid-template-columns:1fr; }
  .col-grid--4, .col-grid--3 { grid-template-columns:1fr; }
}

/* レンタル価格表示 */
.price-rental {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.5rem;
  padding: 0.5rem 0.875rem;
  background: var(--gold-pale2);
  border: 1px solid var(--gold);
  border-radius: 4px;
  width: fit-content;
}
.price-rental-label {
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.05em;
}
.price-rental-num {
  font-size: 16px;
  color: var(--gold);
  font-weight: 700;
  font-family: 'Noto Sans JP', sans-serif;
}
