/* ==========================================================================
   Perform — Legal pages (Privacy Policy + Terms of Service)
   Built on the Perform design system (perform.css). Shares the site header
   and footer; a navy intro band drops into a white "document" card on paper.
   This only restyles the pages — the legal copy itself is unchanged.
   ========================================================================== */

html { overflow-x: hidden; }

/* skip link ----------------------------------------------------------------- */
.skip-link {
  position: absolute; left: 1rem; top: -3.5rem; z-index: 200;
  padding: 0.6rem 1rem; font-size: 0.85rem; font-weight: 700;
  background: var(--blue); color: #fff;
  transition: top 0.22s var(--ease);
}
.skip-link:focus-visible { top: 1rem; }

/* ----------------------------------------------------------- intro band --- */
.legal-hero {
  position: relative;
  color: #fff;
  background:
    radial-gradient(115% 85% at 86% -12%, var(--navy-700), transparent 60%),
    linear-gradient(180deg, var(--navy) 0%, var(--navy-900) 100%);
  padding-top: calc(76px + clamp(2.4rem, 6vw, 4.4rem));
  padding-bottom: clamp(5rem, 11vw, 8.5rem);
  overflow: hidden;
}
.legal-hero::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: -1px;
  height: 6vw; background: var(--paper);
  clip-path: polygon(0 100%, 100% 0, 100% 101%);
}
.legal-hero > .wrap { position: relative; z-index: 2; max-width: 58rem; }
.legal-hero .eyebrow { color: var(--blue-300); }

.legal-deco {
  position: absolute; pointer-events: none;
  background: var(--blue); transform: skewX(var(--skew));
}
.legal-deco--1 { width: 210px; height: 13px; top: 30%; right: -44px; opacity: 0.5; }
.legal-deco--2 { width: 104px; height: 13px; top: 36%; right: 138px; opacity: 0.2; }
.legal-deco--3 { width: 9px; height: 190px; bottom: 8%; left: 6%; opacity: 0.12; transform: none; }

.legal-title {
  margin: 1.15rem 0 0.95rem;
  font-weight: 800; letter-spacing: -0.035em; line-height: 1.03;
  font-size: clamp(2.3rem, 5.4vw, 3.7rem);
}
.legal-meta {
  display: inline-flex; align-items: center; gap: 0.6rem;
  font-size: 0.74rem; font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--mist);
}
.legal-meta::before {
  content: ""; width: 1.5rem; height: 0.5rem;
  background: var(--blue); transform: skewX(var(--skew));
}
.legal-hero .lead { margin-top: 1.2rem; color: #c6d2e6; max-width: 52rem; }

/* --------------------------------------------------------- document card -- */
.legal {
  position: relative; z-index: 5;
  padding-bottom: clamp(3.5rem, 8vw, 6.5rem);
}
.legal .wrap { max-width: 62rem; }
.legal-doc {
  margin-top: clamp(-6rem, -8vw, -4rem);
  background: var(--surface);
  padding: clamp(1.6rem, 4.5vw, 3.6rem);
  clip-path: polygon(0 0, calc(100% - var(--bevel)) 0, 100% var(--bevel), 100% 100%, 0 100%);
  filter: drop-shadow(0 30px 44px rgba(8, 24, 47, 0.24));
}

.legal-doc section { margin-top: clamp(2rem, 3.6vw, 2.9rem); }
.legal-doc section:first-child { margin-top: 0; }

.legal-doc h2 {
  position: relative;
  margin-bottom: 0.85rem; padding-left: 1.15rem;
  font-size: clamp(1.32rem, 2.3vw, 1.85rem); font-weight: 800;
  letter-spacing: -0.022em; line-height: 1.2; color: var(--ink);
}
.legal-doc h2::before {
  content: ""; position: absolute; left: 0; top: 0.16em;
  width: 0.5rem; height: 1.04em;
  background: var(--blue); transform: skewX(var(--skew));
}
.legal-doc h3 {
  margin: 1.5rem 0 0.5rem;
  font-size: 1.04rem; font-weight: 700; letter-spacing: -0.01em; color: var(--navy);
}
.legal-doc p { margin-top: 0.7rem; color: var(--steel); }
.legal-doc h2 + p,
.legal-doc h3 + p { margin-top: 0; }

.legal-doc ul {
  margin-top: 0.85rem;
  display: flex; flex-direction: column; gap: 0.5rem;
  list-style: none;
}
.legal-doc li {
  position: relative; padding-left: 1.4rem;
  color: var(--steel); line-height: 1.6;
}
.legal-doc li::before {
  content: ""; position: absolute; left: 0; top: 0.62em;
  width: 0.8rem; height: 0.42rem;
  background: var(--blue); opacity: 0.6; transform: skewX(var(--skew));
}
.legal-doc a { color: var(--blue); font-weight: 600; }
.legal-doc a:hover { text-decoration: underline; }

/* ----------------------------------------------------------- callout box -- */
.callout {
  margin-top: 1.1rem; padding: 1.25rem 1.4rem;
  background: var(--paper);
  border-left: 3px solid var(--blue);
  display: flex; flex-direction: column; gap: 0.32rem;
}
.callout p { margin-top: 0; color: var(--ink); font-weight: 500; }
.callout p:first-child { color: var(--steel); font-weight: 400; margin-bottom: 0.3rem; }

@media (max-width: 620px) {
  .legal-doc {
    clip-path: polygon(0 0, calc(100% - 16px) 0, 100% 16px, 100% 100%, 0 100%);
  }
}
