/* style.css — 棒手裏剣技術認定試験 共通スタイル（和風・公式感） */

:root{
  --accent:#b8860b;   /* 金色（落ち着いた） */
  --ink:#111111;
  --paper:#fffef8;
  --muted:#666;
  --maxw:1100px;
}

/* 背景にさりげない和紙風テクスチャ（CSSグラデーション利用） */
body{
  margin:0;
  font-family: "Noto Serif JP", "Yu Mincho", serif;
  background-color: var(--paper);
  color: var(--ink);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  background-image:
    radial-gradient(rgba(0,0,0,0.02) 1px, transparent 1px),
    linear-gradient(180deg, rgba(0,0,0,0.01), transparent 60%);
  background-size: 20px 20px, 100% 200px;
}

/* テキストロゴ（墨文字風） */
header{
  background: linear-gradient(90deg, #111 0%, #222 100%);
  color: var(--accent);
  padding: 1.2rem 0;
  text-align:center;
  font-size:1.6rem;
  font-weight:700;
  letter-spacing:0.06em;
  box-shadow: 0 2px 0 rgba(0,0,0,0.15);
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", serif;
}

/* ナビ */
nav{
  background:#f8f6f3;
  border-bottom:1px solid rgba(0,0,0,0.06);
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:0.25rem;
  padding:0.4rem;
}
nav a{
  color:var(--ink);
  text-decoration:none;
  padding:0.6rem 1rem;
  border-radius:6px;
  font-weight:600;
  transition:all .18s ease;
  font-size:0.95rem;
}
nav a:hover{
  background:var(--accent);
  color:#111;
  box-shadow:0 2px 6px rgba(0,0,0,0.08);
}

/* コンテナ */
.container{
  max-width:var(--maxw);
  margin:2rem auto;
  padding:0 1rem;
}

/* セクションタイトル — 墨のラインと和風アクセント */
h1,h2{
  font-family: "Noto Serif JP", serif;
  color:var(--ink);
  margin:0 0 0.8rem 0;
}
h2{
  padding-left:1rem;
  border-left:6px solid var(--accent);
  font-size:1.25rem;
  margin-top:1.2rem;
}

/* ニュース（お知らせ） */
.news{
  background:#fff;
  border:1px solid rgba(0,0,0,0.06);
  padding:1rem;
  border-radius:6px;
  margin-bottom:1.2rem;
}
.news ul{ margin:0; padding-left:1.2rem; color:var(--muted); }

/* 団体紹介 */
.intro{
  font-size:1rem;
  line-height:1.9;
  color:var(--ink);
  background: linear-gradient(180deg, rgba(255,255,255,0.6), rgba(255,255,255,0.9));
  padding:1rem;
  border-radius:6px;
  border:1px solid rgba(0,0,0,0.04);
  margin-bottom:1.2rem;
}

/* 写真 */
.photo{ text-align:center; margin-bottom:1.2rem; }
.photo img{ width:100%; max-width:900px; border:1px solid var(--accent); border-radius:1px; display:block; margin:0 auto; }

/* ボタン（資格制度リンク等） */
.link-btn{
  display:inline-block;
  background:var(--accent);
  color:#111;
  padding:0.7rem 1.4rem;
  font-weight:700;
  text-decoration:none;
  border-radius:6px;
  transition:all .18s;
}
.link-btn:hover{
  background:#111;
  color:var(--accent);
}

/* テーブル風昇級表 */
.table{
  background:#fff;
  border-radius:6px;
  padding:1rem;
  border:1px solid rgba(0,0,0,0.06);
}
.table ul{ margin:0; padding-left:1.1rem; }

/* フォーム */
form{ max-width:680px; margin:0 auto; display:flex; flex-direction:column; gap:0.9rem; }
label{ font-weight:700; font-size:0.95rem; color:var(--ink); }
input[type="text"], input[type="email"], textarea {
  padding:0.9rem;
  border-radius:6px;
  border:1px solid rgba(0,0,0,0.12);
  font-size:1rem;
  font-family:inherit;
  background: #fff;
}
textarea{ min-height:140px; resize:vertical; }
button[type="submit"]{
  background:var(--accent);
  color:#111;
  padding:0.9rem 1rem;
  border:none;
  border-radius:6px;
  font-weight:800;
  cursor:pointer;
}
button[type="submit"]:hover{ background:#111; color:var(--accent); }

/* footer */
footer{
  background:#111;
  color:var(--accent);
  text-align:center;
  padding:1.1rem 0;
  margin-top:2rem;
  font-size:0.9rem;
}

/* レスポンシブ調整 */
@media(max-width:800px){
  header{ font-size:1.2rem; }
  .photo img{ max-width:100%; }
  nav a{ font-size:0.92rem; padding:0.5rem 0.8rem; }
  .container{ margin:1rem auto; }
}
/* ===== rank section (responsive) ===== */
.rank-section { margin-top:1.2rem; }
.rank-note { font-size:0.95rem; color: #5b5b5b; margin-bottom:0.8rem; }

/* グループごとのグリッド表示（デスクトップ） */
.rank-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  align-items: start;
  margin-bottom: 1rem;
}

/* 各カード */
.rank-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,0.06);
  padding: 0.9rem;
  border-radius: 8px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.03);
}

/* 見出し */
.rank-card h3 { margin:0 0 0.5rem 0; font-size:1.05rem; }
.rank-card p, .rank-card ul { margin:0; color: #222; line-height:1.8; }

/* 級と合格基準の簡潔表示（リスト） */
.rank-list { padding-left:1.1rem; margin-top:0.6rem; }

/* 2級〜1級の三段表示用の小テーブル */
.rank-subtable {
  width:100%;
  border-collapse: collapse;
  margin-top:0.6rem;
}
.rank-subtable th, .rank-subtable td {
  border: 1px solid rgba(0,0,0,0.06);
  padding: 0.5rem 0.6rem;
  text-align: center;
  font-size:0.95rem;
}
.rank-subtable th { background: rgba(184,134,11,0.08); font-weight:700; }

/* 初段以降の説明 */
.rank-dan { margin-top:0.6rem; }

/* レスポンシブ：小画面では1列 */
@media (max-width:900px){
  .rank-grid { grid-template-columns: 1fr; }
}
/* 規約・条文スタイル */
.article {
  margin-bottom: 1.5em;
}

.article h3 {
  margin-bottom: 0.3em;
  font-size: 1.1em;
  color: #001a33; /* 濃紺など */
  font-weight: bold;
}

/* 本文全体を下げる */
.article-body {
  margin-left: 2em;    /* ← 全体を下げる */
  text-indent: 0;      /* ← 最初の1文字下げは不要 */
  line-height: 1.8;    /* 読みやすい行間 */
  color: #222;
}
/* 合格者一覧 */
.pass-note {
  font-size: 0.95rem;
  color: #555;
  margin-bottom: 1rem;
}

.pass-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.2rem;
}

.pass-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,0.1);
  border-left: 5px solid #001a33; /* 濃紺ライン */
  border-radius: 6px;
  padding: 1rem;
  box-shadow: 0 2px 6px rgba(0,0,0,0.04);
}

.pass-card h3 {
  margin-top: 0;
  margin-bottom: 0.6rem;
  font-size: 1.1rem;
  color: #001a33;
  border-bottom: 1px solid rgba(0,0,0,0.1);
  padding-bottom: 0.3rem;
}

.pass-card ul {
  list-style: none;
  margin: 0;
  padding-left: 0;
}

.pass-card li {
  padding: 0.3rem 0;
  border-bottom: 1px dotted rgba(0,0,0,0.1);
}

.pass-card li:last-child {
  border-bottom: none;
}

@media (max-width: 600px) {
  .pass-card {
    padding: 0.8rem;
  }
}
/* 料金表 */
.fee-table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0;
  background: #fff;
  font-size: 0.95rem;
}

.fee-table th, .fee-table td {
  border: 1px solid #ccc;
  padding: 0.8rem;
  text-align: center;
}

.fee-table th {
  background-color: #001a33;
  color: #fff;
  font-weight: bold;
}

.fee-table td strong {
  color: #001a33;
}

.fee-table .note {
  text-align: left;
  background: #f9f9f9;
  font-size: 0.9rem;
  color: #444;
}

.fee-note {
  font-size: 0.9rem;
  color: #333;
  background: #f7f7f7;
  border-left: 4px solid #001a33;
  padding: 1rem;
  border-radius: 4px;
}

