/* ============================================
   Riley's Roofing — Legal Page CSS
   Load AFTER riley-roofing.css and inner-pages.css.
   ============================================ */

.rr-legal-hero { min-height: 230px; }
.rr-legal-hero h1 { font-size: 36px; }

.rr-legal-grid { display: grid; grid-template-columns: 240px 1fr; gap: 50px; align-items: start; }

/* ── Table of contents ── */
.rr-legal-toc { position: sticky; top: 100px; }
.rr-legal-toc ol { list-style: none; margin: 14px 0 0; padding: 0; counter-reset: toc; display: flex; flex-direction: column; gap: 9px; }
.rr-legal-toc li { counter-increment: toc; font-size: 12.5px; }
.rr-legal-toc li::before { content: counter(toc) ". "; color: var(--rr-green-dark); font-weight: 900; }
.rr-legal-toc a { color: #444; text-decoration: none; font-weight: 700; }
.rr-legal-toc a:hover { color: var(--rr-green-dark); text-decoration: underline; }

/* ── Legal prose ── */
.rr-legal-copy h2 { font-size: 19px; margin: 34px 0 12px; color: #111; scroll-margin-top: 100px; }
.rr-legal-copy h2:first-of-type { margin-top: 0; }
.rr-legal-copy p { font-size: 14.5px; line-height: 1.7; color: #3a3a3a; margin-bottom: 14px; }
.rr-legal-copy ul { margin: 0 0 14px 20px; padding: 0; }
.rr-legal-copy li { font-size: 14.5px; line-height: 1.7; color: #3a3a3a; margin-bottom: 6px; }
.rr-legal-copy a { color: var(--rr-green-dark); font-weight: 700; text-decoration: underline; }
.rr-legal-address { line-height: 1.8; }

/* Placeholder highlight — remove once real content/legal review is complete */
.rr-todo { background: #fff3b0; color: #5a4a00; padding: 0 4px; border-radius: 3px; }

@media (max-width: 1024px) {
  .rr-legal-grid { grid-template-columns: 1fr; gap: 26px; }
  .rr-legal-toc { position: static; border: 1px solid #e2e2e2; border-radius: 8px; padding: 18px 20px; background: #fafafa; }
  .rr-legal-toc ol { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
}
@media (max-width: 480px) {
  .rr-legal-toc ol { grid-template-columns: 1fr; }
  .rr-legal-hero h1 { font-size: 28px; }
}
