  /* Legal page typography */
  .legal-h1 {
    font-family: 'Big Shoulders Display', sans-serif;
    font-size: 36px; font-weight: 900;
    text-transform: uppercase; letter-spacing: -0.01em;
    color: #1C1C1C; margin-bottom: 8px;
  }
  .legal-intro {
    font-family: 'Outfit', sans-serif;
    font-size: 16px; color: #3D4A56; line-height: 1.6;
    margin-bottom: 6px;
  }
  .legal-dates {
    font-family: 'Outfit', sans-serif;
    font-size: 12px; color: #9CA3AF;
    margin-bottom: 28px;
  }

  /* Table of contents */
  .toc { background: #F9FAFB; border: 1px solid #E5E7EB; border-radius: 10px; padding: 20px 24px; margin-bottom: 32px; }
  .toc-title { font-family: 'Big Shoulders Display', sans-serif; font-size: 14px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: #1C1C1C; margin-bottom: 12px; }
  .toc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3px 24px; }
  .toc-link { font-family: 'Outfit', sans-serif; font-size: 13px; color: #C8700A; text-decoration: none; padding: 2px 0; }
  .toc-link:hover { text-decoration: underline; }

  /* Section headings */
  .legal-h2 {
    font-family: 'Big Shoulders Display', sans-serif;
    font-size: 22px; font-weight: 800;
    text-transform: uppercase; color: #1C1C1C;
    padding-top: 36px; margin-bottom: 14px;
    border-top: 2px solid #E5E7EB;
  }
  .legal-h3 {
    font-family: 'Outfit', sans-serif;
    font-size: 14px; font-weight: 700;
    color: #1C1C1C; margin-top: 16px; margin-bottom: 6px;
  }

  /* Body text */
  .legal-p {
    font-family: 'Outfit', sans-serif;
    font-size: 14px; color: #3D4A56; line-height: 1.7;
    margin-bottom: 10px;
  }
  .legal-ul {
    font-family: 'Outfit', sans-serif;
    font-size: 14px; color: #3D4A56; line-height: 1.6;
    padding-left: 20px; margin-bottom: 12px;
  }
  .legal-ul li { margin-bottom: 4px; }

  /* Quick summary banner */
  .legal-summary {
    background: #FFF8EE; border: 1px solid #FDDBA0;
    border-radius: 10px; padding: 14px 18px;
    display: flex; align-items: flex-start; gap: 12px;
    margin-bottom: 28px;
  }
  .legal-summary-icon { color: #F5A523; flex-shrink: 0; margin-top: 1px; }

  /* Callout box (green — "we do not sell data") */
  .legal-callout-green {
    background: #F0FDF4; border: 1px solid #BBF7D0;
    border-radius: 10px; padding: 12px 16px;
    display: flex; align-items: center; gap: 10px;
    margin: 16px 0;
  }
  .legal-callout-green-icon { color: #16A34A; flex-shrink: 0; }

  /* Callout box (citrus — exercise your rights) */
  .legal-callout-citrus {
    background: #FFF8EE; border: 1px solid #FDDBA0;
    border-radius: 10px; padding: 14px 18px;
    margin: 20px 0;
  }

  /* Two-column info grids */
  .legal-grid-2 {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 8px 24px; margin: 12px 0;
  }
  @media (max-width: 640px) { .legal-grid-2 { grid-template-columns: 1fr; } .toc-grid { grid-template-columns: 1fr; } }

  /* Grid cell */
  .legal-grid-cell { font-family: 'Outfit', sans-serif; font-size: 13px; color: #3D4A56; line-height: 1.5; }
  .legal-grid-label { font-weight: 700; color: #1C1C1C; margin-bottom: 2px; }

  /* Cookie/data table */
  .legal-table { width: 100%; border-collapse: collapse; font-family: 'Outfit', sans-serif; font-size: 13px; margin: 12px 0; }
  .legal-table th { font-weight: 600; color: #1C1C1C; text-align: left; padding: 8px 12px; background: #F9FAFB; border: 1px solid #E5E7EB; }
  .legal-table td { color: #3D4A56; padding: 8px 12px; border: 1px solid #E5E7EB; vertical-align: top; }

  /* Contact box */
  .contact-box {
    background: #F9FAFB; border: 1px solid #E5E7EB;
    border-radius: 10px; padding: 20px 24px; margin-top: 32px;
  }
  .contact-box-title { font-family: 'Big Shoulders Display', sans-serif; font-size: 16px; font-weight: 700; text-transform: uppercase; color: #1C1C1C; margin-bottom: 10px; }
