/* Legal footer, banners, and document pages */

.site-legal-footer {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background: #000;
  padding: 1.5rem 1.25rem 2rem;
  margin-top: auto;
}

.site-legal-footer__inner {
  max-width: 72rem;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: center;
  text-align: center;
}

@media (min-width: 768px) {
  .site-legal-footer__inner {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    text-align: left;
    align-items: flex-start;
  }
}

.site-legal-footer__brand {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.site-legal-footer__name {
  font-family: "Space Grotesk", system-ui, sans-serif;
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--banana-primary-fixed, #ccff00);
}

.site-legal-footer__copy {
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(173, 170, 170, 0.9);
}

.site-legal-footer__disclaimer {
  flex: 1 1 280px;
  max-width: 42rem;
  font-size: 0.7rem;
  line-height: 1.5;
  color: rgba(173, 170, 170, 0.95);
}

.site-legal-footer__disclaimer p {
  margin: 0;
}

.site-legal-footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1.25rem;
  justify-content: center;
}

@media (min-width: 768px) {
  .site-legal-footer__links {
    justify-content: flex-end;
  }
}

.site-legal-footer__links a {
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #adaaaa;
  text-decoration: none;
  transition: color 0.15s ease;
}

.site-legal-footer__links a:hover {
  color: var(--banana-primary-fixed, #ccff00);
}

/* Fixed nav is out of document flow; banner immediately after it must offset downward. */
:root {
  --site-nav-fixed-height: 4.5rem;
}

.site-nav.site-nav--fixed + .site-legal-banner {
  margin-top: var(--site-nav-fixed-height);
  position: sticky;
  top: var(--site-nav-fixed-height);
  z-index: 45;
}

/* Analyst / Portfolios: banner scrolls away (sticky overlapped page content). */
.analyst-page main > .site-legal-banner:first-child,
.portfolios-page main > .site-legal-banner:first-child {
  margin-top: var(--site-nav-fixed-height);
}

/* portfolio detail main already uses pt-24 to clear the fixed nav */
.portfolio-detail-page main > .site-legal-banner:first-child {
  margin-top: 0;
  position: sticky;
  top: var(--site-nav-fixed-height);
  z-index: 45;
}

.site-legal-banner {
  background: rgba(202, 253, 0, 0.06);
  border-bottom: 1px solid rgba(202, 253, 0, 0.15);
  padding: 0.5rem 1rem;
}

.site-legal-banner__text {
  margin: 0;
  max-width: 90rem;
  margin-left: auto;
  margin-right: auto;
  font-size: 0.72rem;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.75);
  text-align: center;
}

.site-legal-banner__text p {
  display: inline;
  margin: 0;
}

.site-legal-banner__link {
  color: var(--banana-primary-fixed, #ccff00);
  text-decoration: underline;
  white-space: nowrap;
}

.site-legal-banner--editorial {
  margin-top: 2rem;
  border-radius: var(--banana-radius);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(32, 32, 31, 0.6);
}

.site-legal-banner--inline {
  margin: 0.75rem 0 0;
  border-radius: var(--banana-radius);
  text-align: center;
}

/* Legal document pages */
.legal-document-body h1 {
  font-family: "Space Grotesk", system-ui, sans-serif;
  font-size: 2rem;
  font-weight: 900;
  margin: 0 0 1rem;
}

.legal-document-body h2 {
  font-family: "Space Grotesk", system-ui, sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  margin: 1.75rem 0 0.5rem;
  color: var(--banana-primary-fixed, #ccff00);
}

.legal-document-body p,
.legal-document-body li {
  font-size: 0.95rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.82);
}

.legal-document-body ul {
  padding-left: 1.25rem;
  margin: 0.5rem 0 1rem;
}

.legal-draft-banner {
  padding: 0.75rem 1rem;
  margin-bottom: 1.5rem;
  border-radius: var(--banana-radius);
  border: 1px solid rgba(255, 180, 0, 0.35);
  background: rgba(255, 180, 0, 0.08);
  color: rgba(255, 220, 140, 0.95);
  font-size: 0.85rem;
}

.legend-legal-strip {
  flex-shrink: 0;
}

.legend-assistant-disclaimer {
  padding: 0.35rem 0.75rem 0;
  font-size: 0.65rem;
  line-height: 1.4;
  color: rgba(255, 255, 255, 0.55);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
