@charset "euc-jp";

h3 {
  margin: 0 0 6px 0;
  padding: 0;
}

p {
  /* margin-bottom: 40px; */
}

div#policy {
    margin: 110px 0 0 0;
}

@media (max-width: 480px) {

div#policy {
    margin: 150px 0 0 0;
}
  
}
/* ================================
   Privacy Policy Styles
   for <div id="policy" class="container-section"> … </div>
   ================================ */

/* --- Design Tokens --- */
:root{
  --bg: #0b0c10;          /* ページ背景（ダーク寄りで引き締め） */
  --surface: #121317;     /* カード背景 */
  --text: #e8eaed;        /* 本文色 */
  --muted: #a6adbb;       /* 補助テキスト */
  --line: #252733;        /* 罫線 */
  --accent: #3ecf8e;      /* アクセント（ブランドに合わせて変更） */
  --accent-2: #6ee7c8;    /* アクセントのグラデ影 */
  --link: #7cc5ff;        /* リンク色（必要なら） */
  --radius: 16px;
  --space-1: 6px;
  --space-2: 10px;
  --space-3: 16px;
  --space-4: 24px;
  --space-5: 36px;
  --space-6: 56px;
  --maxw: 960px;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --font: "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

/* 自動ダーク/ライト切替（必要なら） */
@media (prefers-color-scheme: light){
  :root{
    --bg: #f6f7f9;
    --text: #111318;
    --muted: #60646c;
    --line: #e9edf2;
    --shadow: 0 8px 24px rgba(16,24,40,.08);
  }
}


/* コンテナ */
#policy.container-section{
  box-sizing: border-box;
  max-width: var(--maxw);
  margin: clamp(24px, 5vw, 60px) auto;
  padding: clamp(18px, 4vw, 40px);
  /* background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0)) , var(--surface); */
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

/* セクションタイトル */
#policy .ttl-h2{
  margin: 0 0 var(--space-4);
  position: relative;
}

#policy .ttl-h2 span{
  display: inline-block;
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 800;
  letter-spacing: .02em;
  padding: 8px 14px 10px;
  border-radius: 12px;
  color: var(--text);
  /* background:
    linear-gradient(120deg, rgba(62,207,142,.20), rgba(110,231,200,.10)) padding-box,
    linear-gradient(120deg, var(--accent), var(--accent-2)) border-box; */
  border: 2px solid transparent;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
}

/* 各項目見出し */
#policy h3{
  margin: var(--space-5) 0 var(--space-2);
  font-size: clamp(18px, 2.1vw, 22px);
  font-weight: 700;
  letter-spacing: .01em;
  position: relative;
  padding-left: 14px;
}

#policy h3::before{
  content: "";
  position: absolute;
  left: 0;
  top: .45em;
  width: 6px;
  height: 1.2em;
  border-radius: 4px;
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  /* box-shadow: 0 0 0 4px rgba(62,207,142,.12); */
}

/* 段落 */
#policy p{
  /* margin: 0 0 var(--space-3); */
  /* color: var(--text); */
  /* font-size: clamp(14px, 1.6vw, 16px); */
}

/* 改行 <br> が続くブロックの読みやすさ向上 */
#policy p br{
  /* line-height: 2.2; */
}

/* 注意テキストっぽい行（全角＃で始まる文）を目立たせる */
#policy p:has(> br) {
  /* 段落全体には何も付けず、＃の行だけスタイル */
}
#policy p{
  /* 行頭＃を擬似的に強調（CSSだけでの完全判定は難しいため簡易表現） */
  line-height: 25px;
}
#policy p:contains("＃"){
  /* :contains は実装非推奨なので代替として below を用意 */
}

/* 代替：#note クラスを使いたい場合（HTML側で付与推奨） */
#policy .note{
  margin: var(--space-3) 0;
  padding: 12px 14px;
  border-radius: 10px;
  background: rgba(255,255,255,.04);
  border: 1px dashed var(--line);
  color: var(--muted);
}

/* リンク（メールアドレスなど） */
#policy a{
  color: var(--link);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}
#policy a:hover{
  opacity: .9;
}

/* テーブルが入る場合の初期化（将来拡張用） */
#policy table{
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-3) 0;
  font-size: 14px;
}
#policy th, #policy td{
  border: 1px solid var(--line);
  padding: 10px 12px;
}
#policy th{
  background: rgba(255,255,255,.04);
  text-align: left;
}

/* 引用 or 重要情報ボックス（メール先などに） */
#policy .callout{
  margin: var(--space-4) 0;
  padding: 14px 16px;
  border-radius: 12px;
  background:
   linear-gradient(180deg, rgba(62,207,142,.12), rgba(110,231,200,.06));
  border: 1px solid rgba(110,231,200,.22);
}

/* アンカー遷移時のハイライト（#h3に飛んだ時） */
:target{
  scroll-margin-top: 18vh;
}
#policy h3:target{
  background: linear-gradient(180deg, rgba(255,255,255,.04), transparent);
  border-radius: 10px;
  padding: 8px 14px 8px 14px;
}

/* 細かな余白調整 */
#policy h3 + p{
  /* margin-top: var(--space-2); */
  line-height: 28px;
  font-size: 110%;
}

/* レスポンシブ微調整 */
@media (max-width: 640px){
  #policy.container-section{
    padding: 18px 16px;
    border-radius: 14px;
  }
}

/* 印刷最適化（背景や影を控えめに） */
@media print{
  body{ background: #fff; }
  #policy.container-section{
    box-shadow: none;
    border: 1px solid #ddd;
    background: #fff;
  }
  #policy .ttl-h2 span{
    color: #000;
    background: none;
    border: 0;
    padding-left: 0;
  }
}
