/* =====================================================
   legal.css — shared layout for legal pages (privacy
   policy, terms of service). Builds on common.css.
   ===================================================== */

main {
  padding-left: clamp(1rem, 2.5vw, 3rem);
  padding-right: clamp(1rem, 2.5vw, 3rem);
}

.legal-hero {
  padding: clamp(3rem, 5vw, 6rem) clamp(2rem, 2.5vw, 3rem) clamp(2.5rem, 4vw, 4.5rem);
  background-color: #002e84;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  color: #ffffff;
}

.legal-hero-inner {
  width: min(calc(100% - 32px), 1100px);
  margin: 0 auto;
}

.legal-hero-eyebrow {
  color: var(--accent);
  font-size: clamp(1rem, 1.4vw, 1.6rem);
  letter-spacing: 0.08em;
  margin-bottom: 0.5rem;
}

.legal-hero-title {
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: 1.2;
  font-weight: bold;
  margin: 0;
}

.legal-hero-meta {
  margin-top: clamp(1rem, 1.5vw, 1.5rem);
  color: #c8c7c7;
  font-size: clamp(0.85rem, 1vw, 1rem);
}

.legal-hero-meta div + div {
  margin-top: 0.2rem;
}

.legal-content {
  padding: clamp(2.5rem, 4vw, 4rem) 0 clamp(4rem, 6vw, 6rem);
}

.legal-inner {
  width: min(calc(100% - 32px), 920px);
  margin: 0 auto;
}

.legal-lead {
  font-size: clamp(0.95rem, 1.05vw, 1.05rem);
  line-height: 1.9;
  color: var(--text);
  margin-bottom: clamp(2rem, 3vw, 3rem);
}

.legal-lead p {
  margin: 0 0 1rem;
}

.legal-lead p:last-child {
  margin-bottom: 0;
}

.legal-section {
  margin-bottom: clamp(2rem, 3vw, 3rem);
}

.legal-section h2 {
  font-size: clamp(1.25rem, 1.6vw, 1.5rem);
  line-height: 1.4;
  margin: 0 0 1rem;
  padding-bottom: 0.6rem;
  border-bottom: 2px solid var(--primary);
  color: var(--text);
}

.legal-section h3 {
  font-size: clamp(1.05rem, 1.3vw, 1.2rem);
  line-height: 1.5;
  margin: 1.75rem 0 0.75rem;
  color: var(--text);
}

.legal-section h4 {
  font-size: clamp(0.95rem, 1.1vw, 1.05rem);
  line-height: 1.5;
  margin: 1.25rem 0 0.5rem;
  color: var(--primary);
}

.legal-section p {
  margin: 0 0 1rem;
  font-size: clamp(0.9rem, 1vw, 1rem);
  line-height: 1.9;
}

.legal-section ul,
.legal-section ol {
  margin: 0 0 1rem;
  padding-left: 1.5rem;
  font-size: clamp(0.9rem, 1vw, 1rem);
  line-height: 1.9;
}

.legal-section li {
  margin-bottom: 0.4rem;
}

.legal-section a {
  color: var(--primary);
  text-decoration: underline;
}

.legal-section a:hover {
  color: var(--accent);
}

.legal-table-wrap {
  overflow-x: auto;
  margin: 0 0 1.25rem;
}

.legal-section table {
  width: 100%;
  border-collapse: collapse;
  font-size: clamp(0.85rem, 0.95vw, 0.95rem);
  line-height: 1.7;
  background: var(--surface);
}

.legal-section th,
.legal-section td {
  border: 1px solid var(--line);
  padding: 0.75rem 1rem;
  text-align: left;
  vertical-align: top;
}

.legal-section th {
  background: #f3f6fc;
  color: var(--text);
  font-weight: 600;
}

.legal-end {
  text-align: right;
  margin-top: clamp(2rem, 3vw, 3rem);
  color: var(--muted);
  font-size: 0.95rem;
}

@media (max-width: 640px) {
  .legal-section th,
  .legal-section td {
    padding: 0.6rem 0.7rem;
  }
}
