/* Legal pages — v3 matching editorial palette */

.site-header--solid { background: var(--deep); }

.nav__back {
  font-size: .85rem; font-weight: 700;
  color: rgba(255,255,255,.7); letter-spacing: .04em;
  text-transform: uppercase;
}
.nav__back:hover { color: var(--white); }

.legal {
  padding: 6.5rem var(--gap) 4rem;
  background: var(--cream); min-height: 100vh;
}

.legal__container {
  max-width: 680px; margin: 0 auto;
  background: var(--white); border-radius: var(--r);
  padding: 2.5rem; box-shadow: 0 2px 8px rgba(0,0,0,.04);
}

.legal__container h1 {
  font-size: clamp(1.4rem, 3.5vw, 1.8rem);
  font-weight: 900; color: var(--text); margin-bottom: .4rem;
}

.legal__updated {
  font-size: .8rem; color: var(--text-light);
  margin-bottom: 1.75rem; font-style: italic;
}

.legal__container h2 {
  font-size: 1.1rem; font-weight: 800;
  color: var(--text); margin-top: 1.75rem; margin-bottom: .5rem;
}

.legal__container h3 {
  font-size: .95rem; font-weight: 700;
  color: var(--text); margin-top: 1.25rem; margin-bottom: .35rem;
}

.legal__container p {
  font-size: .9rem; color: var(--text-mid);
  line-height: 1.75; margin-bottom: .6rem;
}

.legal__container ul { margin-bottom: .75rem; padding-left: 1.2rem; }

.legal__container li {
  font-size: .9rem; color: var(--text-mid);
  line-height: 1.75; padding-left: .35rem; list-style: disc;
}

.legal__container a { color: var(--teal); text-decoration: underline; }
.legal__container a:hover { color: var(--teal-light); }
.legal__container strong { color: var(--text); }

.download-link {
  display: inline-block; padding: .6rem 1.2rem;
  background: var(--teal); color: var(--white) !important;
  border-radius: 6px; font-weight: 700; font-size: .85rem;
  text-decoration: none !important; letter-spacing: .02em;
  transition: background .2s;
}
.download-link:hover { background: var(--deep); color: var(--white) !important; }

.legal__container table {
  width: 100%; border-collapse: collapse;
  margin: .75rem 0 1rem; font-size: .85rem;
}

.legal__container th,
.legal__container td {
  text-align: left; padding: .5rem .65rem;
  border-bottom: 1px solid var(--cream-dark); color: var(--text-mid);
}

.legal__container th {
  font-weight: 700; color: var(--text); background: var(--cream);
}

@media (max-width: 600px) {
  .legal__container { padding: 1.5rem 1.15rem; border-radius: 0; }
  .legal { padding: 5rem 0 2rem; }
}
