/* =========================================================================
   VibeSpot — Legal pages (Terms, Privacy Policy)
   Reuses brand tokens from styles.css. Static header + readable long-form text.
   ========================================================================= */

/* ---------- sticky header (no hero behind it, so not absolute) ---------- */
.vs-legalnav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--vs-border);
}
.vs-legalnav__inner {
  width: 100%;
  max-width: var(--vs-maxw);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 14px 28px;
}
.vs-legalnav__links {
  display: flex;
  align-items: center;
  gap: 26px;
  font-size: 15px;
  font-weight: 600;
  color: var(--vs-muted);
}
.vs-legalnav__links a { text-decoration: none; transition: color .15s ease; }
.vs-legalnav__links a:not(.vs-btn):hover { color: var(--vs-accent); }
.vs-legalnav__links .vs-btn { color: #fff; }

/* ---------- content ---------- */
.vs-legal { padding: 56px 28px 88px; }
.vs-legal__inner { width: 100%; max-width: 820px; margin: 0 auto; }

.vs-legal__back {
  display: inline-block;
  margin-bottom: 22px;
  font-size: 14px;
  font-weight: 700;
  color: var(--vs-accent);
  text-decoration: none;
}
.vs-legal__back:hover { text-decoration: underline; }

/* page title is the single <h2> migrated from the source */
.vs-legal h2 {
  margin: 0;
  font-size: 40px;
  line-height: 1.12;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--vs-ink);
}
/* the "Last updated" line directly under the title */
.vs-legal h2 + p {
  margin: 12px 0 0;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--vs-muted-2);
}

.vs-legal h3 {
  margin: 46px 0 0;
  font-size: 24px;
  line-height: 1.25;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--vs-ink);
}
.vs-legal h4 {
  margin: 30px 0 0;
  font-size: 18px;
  font-weight: 700;
  color: var(--vs-text);
}

.vs-legal p {
  margin: 14px 0 0;
  font-size: 16px;
  line-height: 1.75;
  font-weight: 400;
  color: var(--vs-text-2);
}
.vs-legal ul { margin: 14px 0 0; padding-left: 22px; }
.vs-legal li {
  margin: 9px 0 0;
  font-size: 16px;
  line-height: 1.7;
  color: var(--vs-text-2);
}
.vs-legal a {
  color: var(--vs-accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.vs-legal a:hover { color: var(--vs-accent-hover); }
.vs-legal em { font-style: italic; }
.vs-legal strong { font-weight: 700; color: var(--vs-text); }

/* first content block reads as a lead paragraph */
.vs-legal h2 + p + p { font-size: 17px; }

@media (max-width: 640px) {
  .vs-legalnav__links a:not(.vs-btn) { display: none; }
  .vs-legal { padding: 40px 20px 64px; }
  .vs-legal h2 { font-size: 31px; }
  .vs-legal h3 { font-size: 21px; }
}
