/* ═══════════════════════════════════════════════════════════
   LEGAL / CONTENT PAGES
═══════════════════════════════════════════════════════════ */
.legal-page { padding: 50px 0 80px; }
.legal-header { text-align: center; margin-bottom: 50px; }
.legal-header h1 {
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: 14px;
}
.legal-date {
  color: var(--text-dim);
  font-size: 14px;
}

.legal-content {
  max-width: 760px;
  margin: 0 auto;
  padding: 44px 36px;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: 20px;
  backdrop-filter: blur(10px);
  line-height: 1.8;
}

.legal-notice {
  padding: 14px 18px;
  background: rgba(251, 191, 36, 0.1);
  border: 1px solid rgba(251, 191, 36, 0.35);
  border-radius: 12px;
  color: #fde68a;
  font-size: 14px;
  margin-bottom: 30px;
}

.legal-content section { margin-bottom: 30px; }
.legal-content h2 {
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}
.legal-content p,
.legal-content li {
  color: var(--text-soft);
  font-size: 15px;
}
.legal-content ul {
  margin: 10px 0;
  padding-right: 22px;
}
.legal-content ul li { margin-bottom: 6px; }
.legal-content a { color: var(--accent-1); }
.legal-content a:hover { color: var(--accent-2); }
.legal-content strong { color: var(--text); }

.legal-footer {
  text-align: center;
  padding: 30px 20px;
  color: var(--text-dim);
  font-size: 13px;
  border-top: 1px solid var(--border);
}
.legal-footer a { color: var(--text-soft); margin: 0 4px; }
.legal-footer a:hover { color: var(--accent-1); }

/* About — contact grid */
.contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 16px;
}
.contact-card {
  padding: 22px 16px;
  background: var(--surface-strong);
  border: 1px solid var(--border-strong);
  border-radius: 14px;
  text-align: center;
  transition: all 0.2s;
}
a.contact-card:hover { border-color: var(--accent-1); transform: translateY(-2px); }
.contact-icon { font-size: 32px; margin-bottom: 8px; }
.contact-title { font-weight: 700; font-size: 14px; margin-bottom: 4px; }
.contact-detail { color: var(--text-soft); font-size: 13px; direction: ltr; unicode-bidi: embed; }
@media (max-width: 600px) { .contact-grid { grid-template-columns: 1fr; } }
