/* ============================================
 * PlayPop 条款 / 政策 / 支持页面共用样式
 * ============================================ */

:root {
  --bg: #0f0a2e;
  --bg-2: #1a1245;
  --neon-pink: #ff6ec7;
  --neon-cyan: #4fc3f7;
  --neon-purple: #7b61ff;
  --text: #e8e6f0;
  --muted: #8a85b0;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: 'Be Vietnam Pro', sans-serif;
  line-height: 1.75;
  min-height: 100vh;
}
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(123, 97, 255, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(123, 97, 255, 0.06) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 0;
}
body::after {
  content: '';
  position: fixed;
  top: -240px; right: -240px;
  width: 700px; height: 700px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 110, 199, 0.16), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.legal-page {
  position: relative;
  max-width: 920px;
  margin: 0 auto;
  padding: 60px 32px 80px;
  z-index: 1;
}
.legal-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 56px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(123, 97, 255, 0.2);
}
.legal-logo {
  font-family: 'Major Mono Display', monospace;
  font-size: 1.45rem;
  letter-spacing: 0.25em;
  color: var(--neon-pink);
  text-shadow: 0 0 10px rgba(255, 110, 199, 0.6), 0 0 20px rgba(123, 97, 255, 0.4);
  text-decoration: none;
}
.legal-back {
  font-family: 'Orbitron', sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  color: var(--muted);
  text-decoration: none;
  text-transform: uppercase;
  transition: color 0.25s, text-shadow 0.25s;
}
.legal-back:hover {
  color: var(--neon-pink);
  text-shadow: 0 0 6px rgba(255, 110, 199, 0.5);
}

h1.legal-title {
  font-family: 'Orbitron', sans-serif;
  font-size: 2.1rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  color: #fff;
  text-shadow: 0 0 20px rgba(255, 110, 199, 0.45), 0 0 40px rgba(123, 97, 255, 0.3);
  margin: 0 0 8px;
  line-height: 1.2;
}
.legal-subtitle {
  color: var(--neon-cyan);
  font-family: 'VT323', monospace;
  font-size: 1.05rem;
  letter-spacing: 0.05em;
  margin: 0 0 40px;
}

h2 {
  font-family: 'Orbitron', sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--neon-pink);
  margin: 56px 0 18px;
  text-transform: uppercase;
  scroll-margin-top: 24px;
}
h2 .num {
  color: var(--neon-purple);
  margin-right: 14px;
}
h3 {
  font-family: 'Orbitron', sans-serif;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--neon-cyan);
  margin: 24px 0 10px;
  text-transform: uppercase;
}

p { margin: 0 0 16px; color: var(--text); }
strong { color: #fff; font-weight: 700; }
a { color: var(--neon-pink); }
a:hover { text-shadow: 0 0 8px rgba(255, 110, 199, 0.6); }

ul, ol {
  padding-left: 24px;
  margin: 12px 0 18px;
}
ul li, ol li {
  margin-bottom: 10px;
  color: var(--text);
}
ul li::marker, ol li::marker { color: var(--neon-purple); }

.toc {
  background: rgba(123, 97, 255, 0.06);
  border: 1px solid rgba(123, 97, 255, 0.25);
  padding: 24px 32px;
  margin: 32px 0 48px;
  position: relative;
}
.toc::before {
  content: '';
  position: absolute;
  top: -1px; left: -1px;
  width: 14px; height: 14px;
  border-top: 2px solid var(--neon-pink);
  border-left: 2px solid var(--neon-pink);
}
.toc::after {
  content: '';
  position: absolute;
  bottom: -1px; right: -1px;
  width: 14px; height: 14px;
  border-bottom: 2px solid var(--neon-pink);
  border-right: 2px solid var(--neon-pink);
}
.toc-title {
  font-family: 'Orbitron', sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  color: var(--neon-pink);
  margin: 0 0 14px;
  text-transform: uppercase;
}
.toc ol {
  columns: 2;
  column-gap: 32px;
  margin: 0;
  padding-left: 22px;
  line-height: 1.6;
}
.toc ol li {
  margin-bottom: 6px;
  break-inside: avoid;
}
.toc a {
  color: var(--text);
  text-decoration: none;
  font-size: 0.9rem;
  transition: color 0.2s;
}
.toc a:hover { color: var(--neon-pink); }

.contact-card {
  background: rgba(15, 10, 46, 0.6);
  border-left: 3px solid var(--neon-pink);
  padding: 18px 24px;
  margin: 16px 0 24px;
  font-family: 'VT323', monospace;
  font-size: 1.1rem;
  letter-spacing: 0.04em;
  line-height: 1.5;
}
.contact-card strong {
  display: block;
  color: var(--neon-pink);
  font-family: 'Orbitron', sans-serif;
  font-size: 0.9rem;
  letter-spacing: 0.1em;
  margin-bottom: 6px;
}

.callout {
  background: linear-gradient(135deg, rgba(255, 110, 199, 0.08), rgba(123, 97, 255, 0.08));
  border-left: 3px solid var(--neon-purple);
  padding: 18px 24px;
  margin: 24px 0;
  position: relative;
}
.callout-title {
  font-family: 'Orbitron', sans-serif;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--neon-cyan);
  margin: 0 0 10px;
  text-transform: uppercase;
}

@media (max-width: 700px) {
  .legal-page { padding: 36px 20px; }
  .legal-nav { flex-direction: column; gap: 18px; align-items: flex-start; padding-bottom: 18px; margin-bottom: 36px; }
  h1.legal-title { font-size: 1.55rem; }
  .toc { padding: 18px 22px; }
  .toc ol { columns: 1; }
  h2 { font-size: 0.95rem; margin-top: 40px; }
}
