/* =========================================================================
   相性コラム — ハブ＆記事ページ
   ========================================================================= */

/* ---- ハブ ---- */
.col-hero { text-align: center; padding: clamp(54px, 8vw, 100px) 0 clamp(20px, 4vw, 44px); }
.col-hero h1 { font-family: var(--serif); font-weight: 800; font-size: clamp(1.9rem, 5vw, 3rem); margin: 12px 0 8px; }
.col-hero .lead { color: var(--ink-soft); max-width: 56ch; margin: 0 auto; }

.col-cats { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin: 28px 0 40px; }
.col-cats button { font-family: var(--sans); font-weight: 600; font-size: 0.86rem; padding: 0.55em 1.3em; border-radius: 100px; cursor: pointer; color: var(--ink-soft); background: rgba(255,255,255,0.03); border: 1px solid var(--line); transition: all 0.2s; }
.col-cats button:hover { color: var(--ink); border-color: var(--line-strong); }
.col-cats button.active { color: #1a1430; background: linear-gradient(120deg,#f6dd9a,var(--gold)); border-color: transparent; }

.col-grid { display: grid; gap: 20px; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }

/* カテゴリ別セクション（メインハブ） */
.col-sec { margin-top: 8px; }
.col-sec-head { display: flex; align-items: baseline; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin: 40px 0 18px; padding-bottom: 12px; border-bottom: 1px solid var(--line); }
.col-sec-head h2 { font-family: var(--serif); font-weight: 800; font-size: clamp(1.3rem, 3vw, 1.85rem); margin: 0; display: flex; align-items: center; gap: 12px; }
.col-sec-head h2::before { content: ""; width: 12px; height: 12px; border-radius: 4px; background: var(--c, var(--gold)); box-shadow: 0 0 16px var(--c, var(--gold)); }
.col-sec-head h2 .cnt { font-family: var(--sans); font-weight: 500; font-size: 0.8rem; color: var(--ink-faint); }
.col-sec-head .all { font-size: 0.86rem; font-weight: 700; color: var(--gold); white-space: nowrap; }
.col-sec-head .all:hover { color: var(--ink); }
.col-card { position: relative; display: flex; flex-direction: column; border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--line); background: linear-gradient(165deg, rgba(255,255,255,0.05), rgba(255,255,255,0.015)); transition: transform 0.3s, border-color 0.3s, box-shadow 0.3s; }
.col-card:hover { transform: translateY(-6px); border-color: var(--gold); box-shadow: 0 24px 50px rgba(0,0,0,0.45); }
.col-card .thumb { aspect-ratio: 16/9; display: grid; place-items: center; font-size: 3rem; background: radial-gradient(120% 100% at 70% 0%, var(--c, var(--accent-soft)), transparent 60%), rgba(255,255,255,0.02); border-bottom: 1px solid var(--line); }
.col-card .pad { padding: 22px 22px 24px; display: flex; flex-direction: column; flex-grow: 1; }
.col-card .tagrow { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.col-card .cat { font-family: var(--display); letter-spacing: 0.14em; font-size: 0.64rem; color: var(--gold); border: 1px solid var(--gold-soft); padding: 2px 8px; border-radius: 100px; }
.col-card .date { font-size: 0.72rem; color: var(--ink-faint); }
.col-card h2 { font-family: var(--serif); font-weight: 700; font-size: 1.18rem; line-height: 1.5; margin: 0 0 8px; }
.col-card p { color: var(--ink-soft); font-size: 0.86rem; line-height: 1.7; margin: 0; flex-grow: 1; }
.col-card .more { margin-top: 14px; font-size: 0.82rem; font-weight: 700; color: var(--gold); }
.col-card .stretched { position: absolute; inset: 0; }

/* ---- 記事ページ ---- */
.art-hero { padding: clamp(40px, 6vw, 78px) 0 clamp(8px, 2vw, 22px); text-align: center; }
.art-hero .meta { display: flex; align-items: center; gap: 12px; justify-content: center; margin-bottom: 14px; }
.art-hero .cat { font-family: var(--display); letter-spacing: 0.16em; font-size: 0.68rem; color: var(--gold); border: 1px solid var(--gold-soft); padding: 3px 10px; border-radius: 100px; }
.art-hero .date { font-size: 0.78rem; color: var(--ink-faint); }
.art-hero h1 { font-family: var(--serif); font-weight: 800; font-size: clamp(1.7rem, 4.4vw, 2.7rem); line-height: 1.4; margin: 0 auto; max-width: 22ch; }
.art-hero .emoji { font-size: clamp(2.4rem, 7vw, 4rem); margin-bottom: 6px; }

.article { padding: clamp(16px, 3vw, 32px) 0 clamp(56px, 8vw, 96px); }
.article .inner { max-width: 760px; margin: 0 auto; }

/* 目次 */
.toc { border: 1px solid var(--line); border-radius: var(--r-md); padding: 20px 24px; margin: 0 0 36px; background: rgba(255,255,255,0.02); }
.toc .ttl { font-family: var(--serif); font-weight: 700; font-size: 0.95rem; margin-bottom: 10px; color: var(--gold); }
.toc ol { margin: 0; padding-left: 1.3em; }
.toc li { margin-bottom: 6px; }
.toc a { color: var(--ink-soft); font-size: 0.92rem; text-decoration: none; }
.toc a:hover { color: var(--gold); }

.article h2 { font-family: var(--serif); font-weight: 700; font-size: clamp(1.3rem, 3vw, 1.7rem); margin: 44px 0 14px; scroll-margin-top: 90px; display: flex; align-items: center; gap: 12px; }
.article h2::before { content: ""; width: 7px; height: 1em; border-radius: 4px; background: linear-gradient(var(--gold), var(--accent)); flex: 0 0 auto; }
.article h3 { font-family: var(--serif); font-size: 1.15rem; margin: 30px 0 10px; }
.article p { color: var(--ink-soft); line-height: 2; margin: 0 0 16px; font-size: 1rem; }
.article .lead { color: var(--ink); font-size: 1.06rem; }
.article ul, .article ol { color: var(--ink-soft); line-height: 1.95; padding-left: 1.3em; margin: 0 0 16px; }
.article li { margin-bottom: 8px; }
.article a { color: var(--gold); text-decoration: underline; text-underline-offset: 3px; }
.article a:hover { color: var(--ink); }
.article strong { color: var(--ink); }

/* 表 */
.article .tbl { width: 100%; border-collapse: collapse; margin: 8px 0 20px; font-size: 0.92rem; }
.article .tbl th, .article .tbl td { border: 1px solid var(--line); padding: 11px 13px; text-align: left; }
.article .tbl th { background: rgba(255,255,255,0.04); color: var(--ink); font-weight: 700; }
.article .tbl td { color: var(--ink-soft); }

/* 引用・ポイント */
.article .point { border-left: 3px solid var(--gold); background: var(--gold-soft); border-radius: 0 var(--r-sm) var(--r-sm) 0; padding: 16px 20px; margin: 0 0 20px; }
.article .point p { margin: 0; color: var(--ink); font-size: 0.96rem; }

/* 関連占いCTA */
.related-oracles { margin: 36px 0; }
.related-oracles .rt { font-family: var(--serif); font-weight: 700; font-size: 1.05rem; margin-bottom: 14px; }
.ro-grid { display: grid; gap: 14px; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
.ro-card { position: relative; display: flex; gap: 14px; align-items: center; padding: 18px; border-radius: var(--r-md); border: 1px solid var(--line); background: linear-gradient(160deg, rgba(255,255,255,0.05), rgba(255,255,255,0.015)); transition: transform 0.25s, border-color 0.25s; text-decoration: none; }
.ro-card:hover { transform: translateY(-4px); border-color: var(--c, var(--gold)); }
.ro-card .ic { flex: 0 0 auto; width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; font-size: 1.4rem; color: var(--c, var(--gold)); border: 1px solid var(--line-strong); }
.ro-card .nm { font-family: var(--serif); font-weight: 700; font-size: 1rem; }
.ro-card .tg { font-size: 0.78rem; color: var(--ink-soft); margin-top: 2px; }

.art-bottom { text-align: center; margin-top: 44px; }

/* ---- 星座相性インタラクティブ ---- */
.seiza-tool { border: 1px solid var(--line-strong); border-radius: var(--r-lg); padding: clamp(20px,3vw,30px); margin: 8px 0 24px; background: linear-gradient(160deg, rgba(255,255,255,0.05), rgba(255,255,255,0.01)); }
.seiza-pickers { display: grid; grid-template-columns: 1fr auto 1fr; gap: 14px; align-items: end; }
.seiza-pickers .amp { align-self: center; color: var(--gold); font-family: var(--serif); font-size: 1.4rem; padding-bottom: 8px; }
.seiza-pickers label { display: block; font-size: 0.78rem; color: var(--ink-soft); margin-bottom: 6px; }
.seiza-pickers select { width: 100%; padding: 0.8em 1em; border-radius: var(--r-sm); background: rgba(0,0,0,0.25); border: 1px solid var(--line-strong); color: var(--ink); font-family: var(--sans); font-size: 0.96rem; }
.seiza-pickers select:focus { outline: none; border-color: var(--gold); }
.seiza-result { margin-top: 20px; display: none; }
.seiza-result.on { display: block; }
.seiza-score { text-align: center; }
.seiza-score .pair { font-family: var(--serif); font-size: 1.15rem; margin-bottom: 6px; }
.seiza-score .pair b { color: var(--gold); }
.seiza-score .pct { font-family: var(--serif); font-weight: 800; font-size: clamp(2.6rem,9vw,3.6rem); line-height: 1; color: transparent; -webkit-background-clip: text; background-clip: text; background-image: linear-gradient(120deg,#fff,var(--gold) 55%,var(--accent)); }
.seiza-score .verdict { color: var(--gold); font-weight: 700; margin-top: 4px; }
.seiza-bar { height: 10px; border-radius: 10px; background: rgba(255,255,255,0.08); overflow: hidden; margin: 16px 0; }
.seiza-bar .fill { height: 100%; border-radius: 10px; background: linear-gradient(90deg, var(--gold), var(--accent)); width: 0; transition: width 1s ease; }
.seiza-desc { color: var(--ink-soft); line-height: 1.95; font-size: 0.95rem; }

@media (max-width: 560px) {
  .seiza-pickers { grid-template-columns: 1fr; }
  .seiza-pickers .amp { display: none; }
}
