/* ── Legal Pages — Privacy, Terms, Refund ─────────────────────── */

/* Hero */
.legal-hero {
  background: var(--ink);
  padding: 100px 0 64px;
  position: relative;
  overflow: hidden;
}
.legal-hero::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(124,58,237,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124,58,237,.04) 1px, transparent 1px);
  background-size: 48px 48px;
}
.legal-kicker {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: .78rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--violet-soft);
  background: rgba(124,58,237,.1);
  border: 1px solid rgba(124,58,237,.2);
  padding: 5px 14px; border-radius: 20px;
  margin-bottom: 20px;
  position: relative; z-index: 1;
}
.legal-title {
  font-family: var(--serif);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  color: var(--d-heading);
  letter-spacing: -.03em;
  line-height: 1.15;
  margin-bottom: 12px;
  position: relative; z-index: 1;
}
.legal-meta {
  font-size: .83rem;
  color: var(--d-muted);
  position: relative; z-index: 1;
}

/* Body */
.legal-body {
  background: var(--bg);
  padding: 56px 0 80px;
}
.legal-layout {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 48px;
  align-items: flex-start;
}

/* TOC */
.legal-toc {
  position: sticky;
  top: 88px;
}
.legal-toc-title {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--l-light);
  margin-bottom: 12px;
}
.legal-toc nav {
  display: flex; flex-direction: column; gap: 4px;
}
.legal-toc nav a {
  font-size: .8rem;
  color: var(--l-muted);
  text-decoration: none;
  padding: 5px 10px;
  border-radius: 6px;
  border-left: 2px solid transparent;
  transition: all .15s;
  line-height: 1.4;
}
.legal-toc nav a:hover {
  color: var(--violet);
  background: var(--violet-bg);
  border-left-color: var(--violet);
}

/* Content */
.legal-content {
  background: var(--white);
  border: 1px solid var(--l-border);
  border-radius: 20px;
  padding: 44px 48px;
}
.legal-intro {
  font-size: .97rem;
  color: var(--l-body);
  line-height: 1.8;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--l-border);
  margin-bottom: 36px;
}
.legal-content section {
  margin-bottom: 36px;
  padding-bottom: 36px;
  border-bottom: 1px solid var(--l-border);
}
.legal-content section:last-child {
  border-bottom: none;
  margin-bottom: 0; padding-bottom: 0;
}
.legal-content h2 {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--l-heading);
  letter-spacing: -.02em;
  margin-bottom: 14px;
}
.legal-content h3 {
  font-size: .92rem;
  font-weight: 700;
  color: var(--l-heading);
  margin: 16px 0 8px;
}
.legal-content p {
  font-size: .88rem;
  color: var(--l-body);
  line-height: 1.8;
  margin-bottom: 12px;
}
.legal-content p:last-child { margin-bottom: 0; }
.legal-content ul {
  margin: 10px 0 12px 0;
  padding: 0;
  list-style: none;
  display: flex; flex-direction: column; gap: 8px;
}
.legal-content ul li {
  font-size: .87rem;
  color: var(--l-body);
  line-height: 1.65;
  display: flex; align-items: flex-start; gap: 10px;
  padding-left: 4px;
}
.legal-content ul li::before {
  content: '';
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--violet);
  opacity: .6;
  flex-shrink: 0;
  margin-top: 7px;
}
.legal-content a {
  color: var(--violet);
  text-decoration: none;
}
.legal-content a:hover { text-decoration: underline; }
.legal-content strong { color: var(--l-heading); font-weight: 600; }

/* Callout box */
.legal-callout {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 16px; border-radius: 10px;
  margin: 16px 0;
  font-size: .85rem; line-height: 1.65;
}
.legal-callout i { flex-shrink: 0; margin-top: 2px; font-size: 1rem; }
.legal-callout--info {
  background: rgba(96,165,250,.07);
  border: 1px solid rgba(96,165,250,.2);
  color: #1e40af;
}
.legal-callout--info i { color: #3b82f6; }

/* Contact box */
.legal-contact-box {
  display: flex; flex-direction: column; gap: 8px;
  margin-top: 14px;
  background: var(--bg);
  border: 1px solid var(--l-border);
  border-radius: 10px;
  padding: 16px 18px;
}
.legal-contact-box div {
  display: flex; align-items: center; gap: 10px;
  font-size: .87rem; color: var(--l-body);
}
.legal-contact-box i { color: var(--violet); font-size: .9rem; }
.legal-contact-box a { color: var(--violet); text-decoration: none; font-weight: 600; }
.legal-contact-box a:hover { text-decoration: underline; }

/* Responsive */
@media (max-width: 900px) {
  .legal-layout { grid-template-columns: 1fr; }
  .legal-toc { display: none; }
  .legal-content { padding: 28px 24px; }
}
@media (max-width: 480px) {
  .legal-content { padding: 22px 18px; border-radius: 14px; }
  .legal-hero { padding: 80px 0 48px; }
}
