/* =====================
   POLICY ページ専用 CSS
===================== */
.policy-main {
  padding-top: var(--hh);
  min-height: 100vh;
}

/* ページヘッダー */
.policy-hero {
  padding: 72px 0 56px;
  text-align: center;
  border-bottom: 1px solid rgba(255,255,255,.06);
  position: relative;
}
.policy-hero::after {
  content: '';
  position: absolute; bottom: -1px; left: 50%;
  transform: translateX(-50%);
  width: 60px; height: 2px;
  background: var(--gold);
}
.policy-label {
  font-family: var(--font-en);
  font-size: .65rem; letter-spacing: .35em;
  color: var(--gold); display: block; margin-bottom: 18px;
}
.policy-title {
  font-family: var(--font-jp);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 700; color: #fff;
  letter-spacing: .06em; line-height: 1.2;
}
.policy-date {
  margin-top: 16px; font-size: .8rem;
  color: rgba(255,255,255,.35); font-family: var(--font-mono);
}

/* 本文エリア */
.policy-body { padding: 72px 0 100px; }
.policy-wrap {
  max-width: 760px; margin: 0 auto;
  display: flex; flex-direction: column; gap: 0;
}

/* リード文 */
.policy-lead {
  font-size: 1rem; color: #c8c8c8; line-height: 2;
  padding: 0 0 48px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  margin-bottom: 48px;
  word-break: keep-all; overflow-wrap: break-word;
}

/* 各セクション */
.policy-section {
  padding: 40px 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.policy-section:last-of-type { border-bottom: none; }

.policy-section-title {
  display: flex; align-items: center; gap: 18px;
  font-size: 1.15rem; font-weight: 700; color: #fff;
  margin-bottom: 20px; line-height: 1.4;
}
.policy-num {
  font-family: var(--font-en);
  font-size: .72rem; font-weight: 700; letter-spacing: .1em;
  color: var(--bg); background: var(--gold);
  padding: 4px 10px; border-radius: 4px;
  flex-shrink: 0; line-height: 1;
}
.policy-content p {
  font-size: .97rem; color: #c0c0c0; line-height: 2;
  word-break: keep-all; overflow-wrap: break-word;
}

/* リスト */
.policy-list {
  margin-top: 16px; display: flex; flex-direction: column;
  gap: 10px; padding-left: 0; list-style: none;
}
.policy-list li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: .97rem; color: #c0c0c0; line-height: 1.75;
  word-break: keep-all; overflow-wrap: break-word;
}
.policy-list li::before {
  content: ''; display: block;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--gold); flex-shrink: 0; margin-top: .55em;
}

/* お問い合わせボックス */
.policy-contact-box {
  margin-top: 20px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(212,175,55,.22);
  border-radius: var(--r); overflow: hidden;
}
.policy-contact-row {
  display: flex; align-items: flex-start; gap: 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.policy-contact-row:last-child { border-bottom: none; }
.policy-contact-label {
  flex: 0 0 130px; padding: 16px 20px;
  font-size: .82rem; font-weight: 600; color: var(--gold);
  background: rgba(212,175,55,.06);
  border-right: 1px solid rgba(212,175,55,.14);
  word-break: keep-all;
}
.policy-contact-val {
  flex: 1; padding: 16px 20px;
  font-size: .9rem; color: #d0d0d0; line-height: 1.75;
  word-break: keep-all; overflow-wrap: break-word;
}
.policy-contact-link {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--gold); font-weight: 600; text-decoration: none;
  transition: opacity .2s;
}
.policy-contact-link:hover { opacity: .75; }

/* フッターアクション */
.policy-footer-actions {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 56px; margin-top: 8px;
  flex-wrap: wrap; gap: 16px;
}
.pagetop-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 24px;
  background: rgba(212,175,55,.1);
  border: 1px solid rgba(212,175,55,.35);
  border-radius: 50px; color: var(--gold);
  font-family: var(--font-en); font-size: .68rem; letter-spacing: .18em;
  cursor: pointer; transition: background .2s, transform .2s;
}
.pagetop-btn:hover { background: rgba(212,175,55,.2); transform: translateY(-2px); }
.back-home-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 28px; background: var(--gold);
  border-radius: 50px; color: #000;
  font-family: var(--font-jp); font-weight: 700; font-size: .88rem;
  text-decoration: none; transition: background .2s, transform .2s;
  box-shadow: 0 4px 20px rgba(212,175,55,.3);
}
.back-home-btn:hover { background: #e8c84a; transform: translateY(-2px); }

/* =====================
   COMPANY テーブル
===================== */
.company-table {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(212,175,55,.22);
  border-radius: var(--r); overflow: hidden; margin-bottom: 32px;
}
.company-row {
  display: flex; align-items: flex-start;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.company-row:last-child { border-bottom: none; }
.company-label {
  flex: 0 0 160px; padding: 20px 24px;
  font-size: .85rem; font-weight: 700; color: var(--gold);
  background: rgba(212,175,55,.06);
  border-right: 1px solid rgba(212,175,55,.14);
  word-break: keep-all; line-height: 1.6;
}
.company-val {
  flex: 1; padding: 20px 24px;
  font-size: .95rem; color: #d8d8d8; line-height: 1.85;
  word-break: keep-all; overflow-wrap: break-word;
}
.company-tel {
  font-family: var(--font-mono); font-size: 1.15rem;
  font-weight: 700; color: #fff; text-decoration: none;
  letter-spacing: .05em; transition: color .2s;
}
.company-tel:hover { color: var(--gold); }
.company-note {
  display: block; font-size: .78rem;
  color: rgba(255,255,255,.35); margin-top: 4px;
}
.company-note-box {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 16px 20px;
  background: rgba(212,175,55,.05);
  border: 1px solid rgba(212,175,55,.18);
  border-radius: 8px; margin-bottom: 48px;
}
.company-note-box svg { flex-shrink: 0; margin-top: 2px; }
.company-note-box p {
  font-size: .85rem; color: rgba(255,255,255,.5);
  line-height: 1.75; word-break: keep-all;
}

/* =====================
   MOBILE
===================== */
@media (max-width: 768px) {
  .policy-hero { padding: 48px 0 40px; }
  .policy-title { font-size: clamp(1.5rem, 6vw, 2rem); }
  .policy-body { padding: 48px 0 80px; }
  .policy-section { padding: 32px 0; }
  .policy-section-title { font-size: 1rem; gap: 12px; }
  .policy-contact-label {
    flex: 0 0 90px; padding: 12px 14px; font-size: .78rem;
  }
  .policy-contact-val { padding: 12px 14px; font-size: .85rem; }
  .policy-footer-actions {
    flex-direction: column; align-items: stretch; padding-top: 40px;
  }
  .pagetop-btn, .back-home-btn { justify-content: center; width: 100%; }
  .policy-lead { font-size: .92rem; }
  .policy-content p, .policy-list li { font-size: .9rem; }
  .company-label { flex: 0 0 100px; padding: 14px 14px; font-size: .78rem; }
  .company-val { padding: 14px 14px; font-size: .88rem; }
  .company-tel { font-size: 1rem; }
}


/* =====================
   背景を活かしたまま文字を読みやすくする修正
===================== */

/* 1. コンテンツエリア自体には色をつけず、背景画像を通す */
.policy-main {
  background: transparent !important; /* 透明にする */
  position: relative;
  z-index: 5; /* 背景画像より手前に */
}

/* 2. 文字が背景に溶け込まないよう、文字の後ろにうっすら「座布団」を敷く */
.policy-wrap {
  /* 文字エリア全体に、ごく薄い黒のガラスフィルターをかける */
  background: rgba(0, 0, 0, 0.4); 
  backdrop-filter: blur(4px);      /* 少しだけぼかして文字を浮き立たせる */
  -webkit-backdrop-filter: blur(4px);
  padding: 40px;                   /* 余白を作って窮屈にならないように */
  border-radius: 20px;             /* 角丸でデザインに馴染ませる */
  border: 1px solid rgba(255, 255, 255, 0.05); /* うっすら枠線 */
}

/* 3. スマホの時は余白を調整 */
@media (max-width: 768px) {
  .policy-wrap {
    padding: 24px 20px;
  }
}

/* =====================
   テーブル内の文字はみ出し防止修正
===================== */
.company-val {
  /* 日本語の改行ルールをリセットして、枠に合わせて折り返す */
  word-break: break-word !important; 
  overflow-wrap: break-word !important;
  white-space: normal !important;
  
  /* ついでに、上下中央揃えにして見た目を整える */
  align-self: center; 
}

/* もし「所在地」のラベル（左側）が上寄りになっているのを直したい場合 */
.company-row {
  align-items: center !important; /* 左の項目名と右の内容を上下中央揃えに */
}


