/* 별빛 타로 — 콘텐츠 페이지 공용 스타일 */
:root {
  --bg: #0d0a1f;
  --gold: #e8c168;
  --gold-dim: #b89a52;
  --text: #ece6f7;
  --text-dim: #a99cc9;
  --accent: #9d7bff;
  --card-bg: rgba(255,255,255,.04);
  --line: rgba(157,123,255,.18);
}
* { margin: 0; padding: 0; box-sizing: border-box; }
body {
  font-family: "Apple SD Gothic Neo", "Noto Sans KR", sans-serif;
  background: radial-gradient(ellipse at 50% -20%, #241a4a 0%, var(--bg) 60%) fixed;
  min-height: 100vh;
  color: var(--text);
  line-height: 1.85;
}
.site-header {
  text-align: center;
  padding: 36px 20px 0;
}
.site-header .logo {
  font-size: 1.5rem; letter-spacing: .25em; font-weight: 600;
  color: var(--gold); text-decoration: none;
  text-shadow: 0 0 25px rgba(232,193,104,.35);
}
.site-header nav { margin-top: 18px; font-size: .9rem; }
.site-header nav a {
  color: var(--text-dim); text-decoration: none; margin: 0 10px;
  padding-bottom: 4px; transition: color .2s;
}
.site-header nav a:hover { color: var(--gold); }
.site-header nav a.active { color: var(--gold); border-bottom: 1px solid var(--gold); }

main.page {
  max-width: 780px; margin: 0 auto; padding: 48px 20px 80px;
}
main.page h1 {
  color: var(--gold); font-size: 1.7rem; letter-spacing: .08em;
  margin-bottom: 10px; text-align: center;
}
.page-desc { text-align: center; color: var(--text-dim); font-size: .92rem; margin-bottom: 44px; }
main.page h2 {
  color: var(--gold); font-size: 1.25rem; margin: 44px 0 14px; letter-spacing: .05em;
}
main.page h3 { color: var(--accent); font-size: 1.02rem; margin: 26px 0 8px; }
main.page p { margin-bottom: 14px; }
main.page ul, main.page ol { margin: 0 0 14px 22px; }
main.page li { margin-bottom: 8px; }
main.page strong { color: var(--gold); font-weight: 600; }
main.page a { color: var(--accent); }
.note {
  background: var(--card-bg); border: 1px solid var(--line); border-radius: 12px;
  padding: 16px 18px; font-size: .88rem; color: var(--text-dim); margin: 20px 0;
}

/* 카드 사전 */
.suit-section h2 { text-align: center; margin-top: 60px; }
.suit-intro { text-align: center; color: var(--text-dim); font-size: .9rem; margin-bottom: 28px; }
.card-entry {
  background: var(--card-bg); border: 1px solid var(--line); border-radius: 14px;
  padding: 22px 22px 18px; margin-bottom: 18px;
}
.card-entry .head { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
.card-entry .emoji { font-size: 2rem; filter: drop-shadow(0 0 12px rgba(232,193,104,.3)); }
.card-entry .names .kr { color: var(--gold); font-weight: 700; font-size: 1.08rem; }
.card-entry .names .en { color: var(--text-dim); font-size: .75rem; letter-spacing: .12em; text-transform: uppercase; }
.card-entry .meaning-row { font-size: .9rem; margin-bottom: 8px; }
.card-entry .tag {
  display: inline-block; font-size: .72rem; letter-spacing: .1em;
  padding: 2px 10px; border-radius: 999px; margin-right: 8px; vertical-align: 2px;
}
.card-entry .tag.up { color: #8fd9a8; border: 1px solid rgba(143,217,168,.4); }
.card-entry .tag.rev { color: #e8918f; border: 1px solid rgba(232,145,143,.4); }
.card-entry .kw { color: var(--accent); font-size: .8rem; margin-right: 6px; }

/* 목차 */
.toc {
  display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-bottom: 10px;
}
.toc a {
  color: var(--text-dim); text-decoration: none; font-size: .85rem;
  border: 1px solid var(--line); border-radius: 999px; padding: 6px 16px;
  transition: all .2s;
}
.toc a:hover { color: var(--gold); border-color: var(--gold); }

/* 문의 폼 */
.contact-form {
  background: var(--card-bg); border: 1px solid var(--line); border-radius: 14px;
  padding: 26px 24px; margin: 24px 0;
}
.contact-form label {
  display: block; color: var(--gold); font-size: .85rem; letter-spacing: .05em;
  margin: 18px 0 6px;
}
.contact-form label:first-child { margin-top: 0; }
.contact-form input, .contact-form select, .contact-form textarea {
  width: 100%; background: rgba(255,255,255,.06);
  border: 1px solid rgba(157,123,255,.35); border-radius: 10px;
  padding: 12px 14px; color: var(--text); font-size: .95rem;
  font-family: inherit; outline: none;
  transition: border-color .3s, box-shadow .3s;
}
.contact-form select option { background: #1a1333; color: var(--text); }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus {
  border-color: var(--accent); box-shadow: 0 0 16px rgba(157,123,255,.2);
}
.contact-form textarea { min-height: 140px; resize: vertical; }
.contact-form button {
  margin-top: 22px;
  background: linear-gradient(135deg, #7c5cd9, #9d7bff);
  border: none; border-radius: 999px;
  padding: 13px 40px; color: #fff; font-size: .98rem; font-weight: 600;
  letter-spacing: .08em; cursor: pointer;
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 6px 22px rgba(124,92,217,.4);
}
.contact-form button:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(124,92,217,.55); }
.contact-form button:disabled { opacity: .6; cursor: default; transform: none; }
.form-status { margin-top: 16px; font-size: .9rem; display: none; }
.form-status.ok { display: block; color: #8fd9a8; }
.form-status.err { display: block; color: #e8918f; }

.site-footer {
  border-top: 1px solid var(--line);
  padding: 36px 20px 44px; text-align: center;
  color: var(--text-dim); font-size: .85rem;
}
.site-footer nav { margin-bottom: 14px; }
.site-footer a { color: var(--text-dim); text-decoration: none; margin: 0 12px; transition: color .2s; }
.site-footer a:hover { color: var(--gold); }
