/* Terms page styles for G Roll-Offs. Inherits variables and global components from main.css. */

.legal-hero {
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--border);
  padding: 72px 24px 80px;
}

.legal-hero .inner {
  max-width: 980px;
}

.legal-hero h1 {
  font-family: var(--font-heading);
  font-style: italic;
  font-weight: 900;
  font-size: clamp(40px, 6vw, 72px);
  line-height: 0.95;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--text-on-dark);
  margin-bottom: 24px;
}

.legal-hero-sub {
  max-width: 760px;
  color: var(--text-muted-dark);
  font-size: 15px;
  line-height: 1.7;
}

.legal-updated {
  margin-top: 24px;
  color: var(--accent-bright);
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 1.4px;
  text-transform: uppercase;
}

.legal-date-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 24px;
  margin-top: 24px;
}

.legal-date-grid .legal-updated {
  margin-top: 0;
}

.legal-body-section {
  padding: 80px 24px 100px;
}

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

.legal-sidebar {
  position: sticky;
  top: 112px;
  border: 1px solid var(--border-dark);
  border-top: 4px solid var(--accent);
  border-radius: 6px;
  background: #fff;
  padding: 18px;
}

.legal-sidebar a {
  display: block;
  color: var(--text-muted-light);
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 1px;
  text-decoration: none;
  text-transform: uppercase;
  padding: 11px 0;
  border-bottom: 1px solid var(--border-dark);
}

.legal-sidebar a:last-child {
  border-bottom: none;
}

.legal-sidebar a:hover {
  color: var(--accent-deep);
}

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

.legal-block {
  padding: 0 0 42px;
  margin-bottom: 42px;
  border-bottom: 1px solid var(--border-dark);
}

.legal-block:last-child {
  border-bottom: none;
  margin-bottom: 0;
}

.legal-block h2 {
  color: var(--text-on-light);
  font-size: clamp(28px, 4vw, 42px);
  margin-bottom: 18px;
}

.legal-block h3 {
  color: var(--accent-deep);
  font-family: var(--font-heading);
  font-size: 22px;
  font-style: italic;
  font-weight: 900;
  line-height: 1.1;
  margin: 28px 0 10px;
  text-transform: uppercase;
}

.legal-block p,
.legal-block li {
  color: var(--text-muted-light);
  font-size: 15px;
  line-height: 1.75;
}

.legal-block p + p,
.legal-block p + ul,
.legal-block ul + p {
  margin-top: 16px;
}

.legal-block ul {
  padding-left: 20px;
}

.legal-block li {
  margin-bottom: 10px;
}

.legal-block a {
  color: var(--accent-deep);
  font-weight: 700;
  text-decoration: none;
}

.legal-block a:hover {
  text-decoration: underline;
}

.legal-company-card {
  background: #fff;
  border: 1px solid var(--border-dark);
  border-top: 4px solid var(--accent);
  border-radius: 6px;
  padding: 24px;
  margin-bottom: 22px;
}

.legal-company-card p {
  margin: 0 0 10px;
}

.legal-company-card p:last-child {
  margin-bottom: 0;
}

.legal-company-card strong {
  color: var(--text-on-light);
  font-family: var(--font-display);
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.legal-contact-card {
  background: #fff;
  border: 1px solid var(--border-dark);
  border-left: 6px solid var(--accent);
  border-radius: 6px;
  padding: 30px;
}

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

  .legal-sidebar {
    position: static;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 14px;
  }

  .legal-sidebar a {
    border: 1px solid var(--border-dark);
    border-radius: 4px;
    padding: 9px 11px;
  }
}

@media (max-width: 640px) {
  .legal-hero {
    padding: 54px 24px 62px;
  }

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