

.legal {
  padding: clamp(32px, 4vw, 72px) max(16px, env(safe-area-inset-left))
           clamp(48px, 6vw, 96px) max(16px, env(safe-area-inset-right));
  font-family: "Commissioner", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
  overflow-wrap: anywhere; 
}

.legal-hero {
  max-width: 72rem;
  margin: 0 auto clamp(20px, 3vw, 32px);
}

.legal-content {
  max-width: 60rem; 
  margin: 0 auto;
}

.legal h1,
.legal h2,
.legal h3 {
  color: #000;
  margin: 0 0 12px;
  line-height: 1.2;
  font-weight: 700;
}

.legal h1 {
  font-size: clamp(28px, 2.2rem + 0.6vw, 42px);
  letter-spacing: -0.01em;
}

.legal-updated { margin: 6px 0 0; color: #555; font-size: 14px; }

.legal h2 { font-size: clamp(18px, 1.05rem + 0.4vw, 24px); margin-top: clamp(20px, 3vw, 36px); }

.legal p,
.legal li {
  color: #000;
  font-size: clamp(15px, 0.95rem + 0.1vw, 17px);
  line-height: 1.7;
}

.legal p + p { margin-top: 10px; }

.legal ul,
.legal ol {
  margin: 10px 0 0 0;
  padding: 0;
  list-style: none;
}

.legal li {
  position: relative;
  padding-left: 18px;
  margin: 8px 0;
}

.legal li::before {
  content: "–";
  position: absolute;
  left: 0;
  top: 0;
  line-height: 1.7;
  color: #000;
}

.legal a {
  color: #003069;
  text-decoration: underline;
  text-underline-offset: 2px;
  word-break: break-word;
}

.legal .note {
  background: #f6f7f8;
  border-radius: 10px;
  padding: 12px 14px;
  margin: 16px 0;
}

.legal-content img,
.legal-content video,
.legal-content canvas {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 16px auto;
}

.legal-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0;
  font-size: 0.95em;
}

.legal-content th,
.legal-content td {
  border-bottom: 1px solid #e9ecef;
  padding: 10px 8px;
  text-align: left;
}

@media (max-width: 900px) {
  .legal-hero { text-align: center; }
}

:target { scroll-margin-top: 84px; }

@media print {
  .site-header, .site-footer { display: none !important; }
  .legal { padding: 0; }
  .legal-content { max-width: none; }
}

