/* ============================================================
   Wattly — Legal pages (Privacy / Terms)
   Builds on home.css tokens. Sticky TOC + numbered sections.
   ============================================================ */

/* home.css sets body{overflow-x:hidden}, which breaks position:sticky.
   overflow-x:clip prevents horizontal scroll WITHOUT creating a scroll
   container, so the sticky TOC works. */
body { overflow-x: clip; }

.legal-shell { padding-top: 120px; padding-bottom: var(--sect); }

/* Hero */
.legal-hero { max-width: 680px; margin: 0 auto 60px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 16px; }
.legal-hero .shield {
  width: 44px; height: 44px; color: var(--accent);
}
.legal-hero h1 { font-weight: 900; font-size: clamp(2.2rem, 5vw, 3.3rem); letter-spacing: -0.035em; line-height: 1.02; }
.legal-updated { font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.13em; text-transform: uppercase; color: var(--tx-3); }
.legal-hero .legal-intro { color: var(--tx-2); font-size: 1.08rem; line-height: 1.6; max-width: 52ch; }

/* Body layout */
.legal-body { display: grid; grid-template-columns: 232px 1fr; gap: 56px; max-width: 1060px; margin: 0 auto; align-items: start; }

/* TOC */
.legal-toc { position: sticky; top: 96px; max-height: calc(100vh - 124px); overflow-y: auto; scrollbar-width: none; }
.legal-toc::-webkit-scrollbar { display: none; }
.legal-toc-title { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--tx-3); margin-bottom: 14px; padding-left: 12px; }
.legal-toc ol { list-style: none; counter-reset: toc; display: flex; flex-direction: column; gap: 1px; }
.legal-toc a {
  display: flex; gap: 9px; padding: 7px 12px; font-size: 0.83rem; line-height: 1.35;
  color: var(--tx-3); border-left: 2px solid transparent; border-radius: 0 6px 6px 0;
  transition: color .15s ease, background .15s ease, border-color .15s ease;
}
.legal-toc li { counter-increment: toc; }
.legal-toc a::before { content: counter(toc, decimal-leading-zero); font-family: var(--mono); font-size: 0.72rem; color: var(--tx-3); flex: none; }
.legal-toc a:hover { color: var(--tx-2); background: var(--surface); }
.legal-toc a.active { color: var(--accent); border-left-color: var(--accent); background: var(--accent-dim); }
.legal-toc a.active::before { color: var(--accent); }

/* Content */
.legal-main { min-width: 0; }
.legal-section { padding: 30px 0; border-top: 1px solid var(--hair); scroll-margin-top: 92px; }
.legal-section:first-of-type { border-top: none; padding-top: 0; }
.legal-sec-head { display: flex; align-items: baseline; gap: 13px; margin-bottom: 14px; }
.legal-num { font-family: var(--mono); font-size: 0.8rem; font-weight: 500; color: var(--accent); letter-spacing: 0.04em; }
.legal-sec-head h2 { font-weight: 800; font-size: clamp(1.2rem, 2vw, 1.5rem); letter-spacing: -0.02em; line-height: 1.1; }
.legal-main p { color: var(--tx-2); line-height: 1.72; margin-bottom: 13px; }
.legal-main p:last-child { margin-bottom: 0; }
.legal-main h3 { color: var(--tx); font-weight: 700; font-size: 1rem; margin: 22px 0 9px; }
.legal-main ul, .legal-main ol { padding-left: 20px; margin: 4px 0 14px; }
.legal-main li { color: var(--tx-2); line-height: 1.65; margin-bottom: 8px; }
.legal-main li::marker { color: var(--accent); }
.legal-main strong { color: var(--tx); font-weight: 600; }
.legal-main a { color: var(--accent); text-decoration: none; }
.legal-main a:hover { text-decoration: underline; }

/* Callouts */
.legal-callout { margin: 18px 0; padding: 16px 19px; border-radius: 12px; background: var(--accent-dim); border: 1px solid var(--accent-line); font-size: 0.96rem; line-height: 1.6; color: var(--tx-2); }
.legal-callout strong { color: var(--accent); }
.legal-callout p { margin: 8px 0 0; }
.legal-callout.warn { background: rgba(245,184,66,0.08); border-color: rgba(245,184,66,0.28); }
.legal-callout.warn strong { color: #f5b842; }

/* Service cards */
.svc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; margin: 16px 0; }
.svc-card { display: flex; flex-direction: column; gap: 5px; padding: 16px 17px; border: 1px solid var(--hair); border-radius: var(--r-md); background: var(--surface); transition: border-color .2s ease; }
.svc-card:hover { border-color: var(--hair-2); }
.svc-name { font-weight: 700; font-size: 0.95rem; color: var(--tx); }
.svc-purpose { color: var(--tx-3); font-size: 0.82rem; line-height: 1.45; flex: 1; }
.svc-link { color: var(--accent); font-size: 0.8rem; font-weight: 600; margin-top: 4px; }
.svc-link:hover { text-decoration: underline; }

/* Security pills */
.sec-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 10px; margin: 16px 0; }
.sec-pill { padding: 14px 16px; border: 1px solid var(--hair); border-radius: var(--r-sm); background: var(--surface); font-size: 0.88rem; color: var(--tx-2); line-height: 1.45; }
.sec-pill strong { display: block; color: var(--accent); font-weight: 600; margin-bottom: 2px; }

/* Contact card */
.legal-contact { margin-top: 44px; padding: 30px; border: 1px solid var(--hair-2); border-radius: var(--r-lg); background: var(--bg-2); position: relative; overflow: hidden; }
.legal-contact::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 2px; background: var(--accent); }
.legal-contact h2 { font-weight: 800; font-size: 1.3rem; letter-spacing: -0.02em; margin-bottom: 6px; }
.legal-contact > p { color: var(--tx-2); margin-bottom: 20px; }
.legal-contact-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 12px; }
.lc-link { display: flex; flex-direction: column; gap: 4px; padding: 15px 17px; border: 1px solid var(--hair); border-radius: var(--r-md); background: var(--surface); transition: border-color .2s ease, background .2s ease; }
.lc-link:hover { border-color: var(--accent-line); background: var(--accent-dim); }
.lc-label { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--tx-3); }
.lc-email { color: var(--accent); font-weight: 600; font-size: 0.92rem; }

/* Related */
.legal-related { margin-top: 30px; padding-top: 22px; border-top: 1px solid var(--hair); color: var(--tx-3); font-size: 0.94rem; line-height: 1.6; }
.legal-related a { color: var(--accent); text-decoration: none; }
.legal-related a:hover { text-decoration: underline; }

/* Responsive */
@media (max-width: 920px) {
  .legal-body { grid-template-columns: 1fr; gap: 28px; }
  .legal-toc {
    position: static; max-height: none; overflow: visible;
    border-bottom: 1px solid var(--hair); padding-bottom: 18px;
  }
  .legal-toc ol { flex-direction: row; flex-wrap: nowrap; overflow-x: auto; gap: 6px; padding-bottom: 4px; scrollbar-width: none; }
  .legal-toc ol::-webkit-scrollbar { display: none; }
  .legal-toc a { white-space: nowrap; border-left: none; border-radius: 999px; border: 1px solid var(--hair); padding: 7px 13px; }
  .legal-toc a.active { border-color: var(--accent-line); }
}
@media (max-width: 600px) {
  .legal-shell { padding-top: 102px; }
}
