/**
 * KAITALK Compliance / Legal Pages
 * Applied to: privacy, terms, cookies, dsr, baa, iso27001, refund pages
 * Imports design-system.css tokens
 */

/* ── Nav ──────────────────────────────────────────────────────── */
.legal-nav {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  z-index: 50;
}
.legal-nav-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 16px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.legal-logo {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: -0.01em;
  text-decoration: none;
}
.legal-logo span { color: var(--color-accent); }
.legal-nav-back {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color var(--duration-fast);
}
.legal-nav-back:hover { color: var(--color-text); }

/* ── Page layout ──────────────────────────────────────────────── */
.legal-wrap {
  max-width: 760px;
  margin: 0 auto;
  padding: var(--space-6) var(--space-4) var(--space-15);
}

/* ── Lang toggle ──────────────────────────────────────────────── */
.legal-lang-toggle {
  display: flex;
  gap: 6px;
  margin-bottom: var(--space-4);
}
.legal-lang-btn {
  padding: 5px 14px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: all var(--duration-fast);
}
.legal-lang-btn.active {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
}
.legal-lang-btn:hover:not(.active) {
  border-color: var(--color-border-strong);
  color: var(--color-text);
}

/* ── Document header ──────────────────────────────────────────── */
.legal-header { margin-bottom: var(--space-6); }
.legal-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  height: 22px;
  padding: 0 10px;
  border-radius: var(--radius-full);
  background: var(--color-accent-light);
  color: var(--color-accent);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}
.legal-title {
  font-size: var(--text-4xl);
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  color: var(--color-text);
  line-height: var(--leading-tight);
  margin-bottom: var(--space-1);
}
.legal-subtitle {
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
}
.legal-meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-2);
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
  flex-wrap: wrap;
}
.legal-meta-sep { color: var(--color-border-strong); }

/* ── Document divider ─────────────────────────────────────────── */
.legal-divider {
  height: 1px;
  background: var(--color-border);
  margin: var(--space-4) 0;
}

/* ── Body typography ──────────────────────────────────────────── */
.legal-body {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text);
}
.legal-body h2 {
  font-size: var(--text-xl);
  font-weight: 700;
  letter-spacing: var(--tracking-snug);
  color: var(--color-text);
  margin: var(--space-4) 0 var(--space-1);
  padding-top: var(--space-1);
  scroll-margin-top: 80px;
}
.legal-body h3 {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-text);
  margin: var(--space-3) 0 8px;
}
.legal-body p {
  margin-bottom: var(--space-2);
  color: var(--color-text);
}
.legal-body ul, .legal-body ol {
  margin: 10px 0 var(--space-2) var(--space-3);
}
.legal-body li {
  margin-bottom: 6px;
  line-height: var(--leading-relaxed);
}
.legal-body strong { font-weight: 700; color: var(--color-text); }
.legal-body a {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.legal-body a:hover { text-decoration: none; }
.legal-body table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-2) 0 var(--space-3);
  font-size: var(--text-sm);
}
.legal-body th {
  background: var(--color-surface-inset);
  padding: 10px 14px;
  text-align: left;
  font-weight: 700;
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text-secondary);
  border-bottom: 2px solid var(--color-border);
}
.legal-body td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
}
.legal-body tr:last-child td { border-bottom: none; }

/* ── Info/warning callouts ────────────────────────────────────── */
.callout {
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border-left: 3px solid;
  margin: var(--space-2) 0;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}
.callout-info   { background: var(--color-info-bg);    border-color: var(--color-info);    color: var(--color-text); }
.callout-warning { background: var(--color-warning-bg); border-color: var(--color-warning); color: var(--color-text); }
.callout-success { background: var(--color-success-bg); border-color: var(--color-success); color: var(--color-text); }

/* ── Section anchor links ─────────────────────────────────────── */
.legal-body h2 .anchor {
  display: none;
  color: var(--color-text-tertiary);
  text-decoration: none;
  margin-left: 8px;
  font-weight: 400;
}
.legal-body h2:hover .anchor { display: inline; }

/* ── Print styles ─────────────────────────────────────────────── */
@media print {
  .legal-nav, .legal-lang-toggle, .legal-nav-back { display: none !important; }
  .legal-wrap { padding: 0; }
  .legal-body h2 { page-break-after: avoid; }
  .legal-body p  { orphans: 3; widows: 3; }
}

/* ── Mobile ───────────────────────────────────────────────────── */
@media (max-width: 600px) {
  .legal-nav-inner { padding: 14px 16px; }
  .legal-wrap { padding: var(--space-3) var(--space-2) var(--space-10); }
  .legal-title { font-size: var(--text-3xl); }
  .legal-body h2 { font-size: var(--text-lg); }
}
