:root {
  --legal-primary: #0B4F78;
  --legal-secondary: #0B2341;
  --legal-accent: #00B4D8;
  --legal-text: #4B5F78;
  --legal-soft: #F4FAFD;
  --legal-border: rgba(11, 79, 120, .12);
  --legal-shadow: 0 12px 30px rgba(11, 79, 120, .05);
}

.legal-page {
  overflow-x: hidden;
  background: #fff;
  color: var(--legal-text);
}

.legal-page .container {
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto;
}

.legal-hero {
  padding: 92px 0 64px;
  background:
    radial-gradient(circle at 82% 18%, rgba(0, 180, 216, .10), transparent 28%),
    linear-gradient(180deg, #FFFFFF 0%, #F4FAFD 100%);
}

.legal-page .eyebrow {
  display: inline-flex;
  align-items: center;
  color: var(--legal-primary);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.legal-hero h1 {
  max-width: 820px;
  margin: 18px 0;
  color: var(--legal-secondary);
  font-size: clamp(42px, 4vw, 58px);
  line-height: 1.06;
  letter-spacing: -0.02em;
}

.legal-hero p {
  max-width: 780px;
  color: var(--legal-text);
  font-size: 18px;
  line-height: 1.65;
}

.legal-updated {
  margin-top: 20px;
  color: var(--legal-primary) !important;
  font-weight: 800;
}

.legal-section {
  padding: 74px 0 96px;
}

.legal-layout {
  display: grid;
  grid-template-columns: 260px minmax(0, 860px);
  gap: 56px;
  align-items: start;
}

.legal-index {
  position: sticky;
  top: 112px;
  padding: 22px;
  background: #fff;
  border: 1px solid var(--legal-border);
  border-radius: 18px;
  box-shadow: var(--legal-shadow);
}

.legal-index strong {
  display: block;
  margin-bottom: 14px;
  color: var(--legal-secondary);
}

.legal-index a {
  display: block;
  padding: 8px 0;
  color: var(--legal-text);
  text-decoration: none;
  font-weight: 700;
}

.legal-index a:hover {
  color: var(--legal-primary);
}

.legal-content {
  max-width: 860px;
}

.legal-content section:first-child h2 {
  margin-top: 0;
}

.legal-content h2 {
  margin: 48px 0 16px;
  color: var(--legal-secondary);
  font-size: clamp(26px, 2.2vw, 34px);
  line-height: 1.16;
  letter-spacing: -0.01em;
}

.legal-content h3 {
  margin: 28px 0 10px;
  color: var(--legal-secondary);
  font-size: 21px;
  line-height: 1.25;
}

.legal-content p,
.legal-content li {
  color: var(--legal-text);
  font-size: 17px;
  line-height: 1.75;
}

.legal-content a {
  color: var(--legal-primary);
  font-weight: 800;
}

.legal-content ul {
  padding-left: 22px;
}

.legal-summary {
  padding: 26px 30px;
  background: var(--legal-soft);
  border: 1px solid rgba(0, 180, 216, .20);
  border-radius: 18px;
}

.legal-notice {
  margin: 32px 0;
  padding: 22px 26px;
  border-left: 4px solid var(--legal-accent);
  border-radius: 16px;
  background: linear-gradient(90deg, rgba(0, 180, 216, .10), rgba(255,255,255,.75));
  color: var(--legal-secondary) !important;
  font-weight: 800;
}

.rights-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 24px 0;
}

.right-card {
  padding: 18px 20px;
  background: #fff;
  border: 1px solid var(--legal-border);
  border-radius: 14px;
  color: var(--legal-text);
  font-size: 16px;
  font-weight: 800;
  line-height: 1.45;
}

.legal-final {
  margin-top: 56px;
  padding: 30px;
  background: var(--legal-soft);
  border: 1px solid rgba(0, 180, 216, .20);
  border-radius: 18px;
}

.legal-final h2 {
  margin-top: 0;
}

.legal-final .btn {
  margin-top: 12px;
}

.legal-disclaimer {
  margin-top: 30px;
  padding-top: 22px;
  border-top: 1px solid var(--legal-border);
  font-size: 15px !important;
}

@media (max-width: 980px) {
  .legal-layout {
    grid-template-columns: 1fr;
  }

  .legal-index {
    position: static;
  }
}

@media (max-width: 640px) {
  .legal-page .container {
    width: min(calc(100% - 32px), 1180px);
  }

  .legal-hero {
    padding: 76px 0 52px;
  }

  .legal-index {
    display: none;
  }

  .legal-section {
    padding: 58px 0 76px;
  }

  .legal-summary,
  .legal-final {
    padding: 22px;
  }

  .rights-grid {
    grid-template-columns: 1fr;
  }
}
