/* Love Tap — legal pages (Privacy / Terms / EULA). Reuses lovetap.css tokens. */

.legal-main { position: relative; z-index: 1; padding-top: 132px; padding-bottom: 40px; }

/* doc header */
.legal-head { text-align: center; max-width: 760px; margin: 0 auto clamp(40px, 6vh, 64px); }
.legal-head .kicker { margin-bottom: 18px; }
.legal-head h1 { font-size: clamp(38px, 5.4vw, 64px); letter-spacing: -0.035em; line-height: 1.02; }
.legal-meta {
  display: inline-flex; align-items: center; gap: 9px; margin-top: 22px;
  padding: 8px 16px; border-radius: 999px; font-size: 13px; color: var(--text-2);
  background: rgba(255,255,255,0.05); border: 1px solid var(--hair);
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
}
.legal-meta .lt-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--pink); box-shadow: 0 0 10px 1px var(--pink); }

/* layout: TOC + content */
.legal-layout { display: grid; grid-template-columns: 240px minmax(0, 1fr); gap: 48px; align-items: start; max-width: 1000px; margin: 0 auto; }

/* sticky table of contents */
.toc { position: sticky; top: 116px; }
.toc__label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--text-3); padding: 0 14px 12px; }
.toc__list { display: flex; flex-direction: column; gap: 1px; }
.toc__list a {
  display: block; padding: 9px 14px; border-radius: 11px; font-size: 13.5px; line-height: 1.35;
  color: var(--text-2); transition: color .2s, background .2s, box-shadow .2s;
}
.toc__list a:hover { color: var(--text); background: rgba(255,255,255,0.05); }
.toc__list a.active {
  color: #2c0719; font-weight: 600; background: var(--pink);
  box-shadow: 0 1px 0 rgba(255,255,255,.35) inset, 0 8px 20px -10px rgba(255,165,232,.6);
}

/* the document card */
.doc { background: var(--card); border: 1px solid var(--hair); border-radius: var(--radius);
  box-shadow: 0 1px 0 rgba(255,255,255,.05) inset, 0 24px 50px -30px rgba(0,0,0,.7);
  padding: clamp(30px, 4vw, 56px); }
.doc__intro { color: var(--text-2); font-size: 16px; line-height: 1.65; max-width: 64ch; }
.doc__intro:not(:last-child) { margin-bottom: 8px; }

.sec { padding-top: 36px; margin-top: 36px; border-top: 1px solid var(--hair); scroll-margin-top: 116px; }
.sec:first-of-type { border-top: none; margin-top: 28px; padding-top: 0; }
.sec__h { display: flex; align-items: baseline; gap: 14px; margin: 0 0 16px; }
.sec__n {
  flex: 0 0 auto; font-family: var(--mono); font-size: 13px; font-weight: 600; color: var(--pink);
  min-width: 26px; padding-top: 2px;
}
.sec__h h2 { font-size: clamp(20px, 2.2vw, 25px); letter-spacing: -0.02em; line-height: 1.15; }
.sec p { color: var(--text-2); font-size: 15.5px; line-height: 1.68; margin: 0 0 14px; max-width: 66ch; }
.sec p:last-child { margin-bottom: 0; }
.sec strong, .sec b { color: var(--text); font-weight: 600; }

/* lists */
.sec ul { list-style: none; margin: 4px 0 16px; padding: 0; display: flex; flex-direction: column; gap: 11px; max-width: 64ch; }
.sec ul li { position: relative; padding-left: 26px; color: var(--text-2); font-size: 15.5px; line-height: 1.6; }
.sec ul li::before {
  content: ""; position: absolute; left: 6px; top: 10px; width: 6px; height: 6px; border-radius: 50%;
  background: var(--pink); box-shadow: 0 0 8px 1px rgba(255,165,232,0.6);
}

/* contact / emphasis links */
.sec a { color: var(--pink); font-weight: 500; overflow-wrap: anywhere; transition: color .2s; }
.sec a:hover { color: var(--pink-200); text-decoration: underline; }

/* back-to-top + other docs footer nav */
.legal-also { max-width: 1000px; margin: 40px auto 0; padding-left: 288px; }
.legal-also__row { display: flex; flex-wrap: wrap; gap: 12px; }
.legal-also a {
  display: inline-flex; align-items: center; gap: 8px; padding: 11px 18px; border-radius: 999px;
  font-size: 14px; font-weight: 500; color: var(--text-2);
  background: rgba(255,255,255,0.05); border: 1px solid var(--hair);
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px); transition: color .2s, background .2s, border-color .2s;
}
.legal-also a:hover { color: var(--text); background: rgba(255,255,255,0.09); border-color: var(--hair-2); }
.legal-also a.current { color: var(--pink-200); border-color: rgba(255,199,241,0.28); background: rgba(255,165,232,0.07); pointer-events: none; }

@media (max-width: 860px) {
  .legal-layout { grid-template-columns: 1fr; gap: 0; }
  .toc { display: none; }
  .legal-main { padding-top: 116px; }
  .doc { padding: 26px 22px; }
  .sec p, .sec ul { max-width: none; }
}
