 .legal-hero {
   min-height: 38svh;
   display: grid;
   place-items: center;
   text-align: center;
   padding: 48px 16px;
   background: url('assets/bg-gradent.jpg') center/cover no-repeat;
 }

 .legal-hero h1 {
   font-weight: 200;
   font-size: clamp(28px, 4vw, 48px);
   margin: 0;
   color: #fff;
 }

 .legal-hero p {
   margin: 8px 0 0;
   color: var(--muted);
   font-weight: 300;
 }

 .legal-main {
   width: min(960px, 100%);
   margin-inline: auto;
   padding: clamp(16px, 3vw, 28px);
 }

.legal-main section[id] {
  scroll-margin-top: 140px; /*  = navbar + TOC + un margen */
}

 .legal-card {
   background: rgba(255, 255, 255, 0.02);
   border: 1px solid rgba(255, 255, 255, 0.08);
   border-radius: 16px;
   padding: clamp(16px, 2.5vw, 24px);
   margin-bottom: 16px;
 }

 .legal-card.toc {
   position: sticky;
   top: 72px;
   /* ajusta según la altura real del header */
   z-index: 50;
   /* background: rgba(20, 25, 30, 0.75);  */
   backdrop-filter: blur(10px);
   padding: 10px 1rem;
   margin-bottom: 24px;
   border: 1px solid rgba(255, 255, 255, 0.08);
   border-radius: 12px;
   transition: background 0.3s ease;
 }

 .legal-card.toc:hover {
   /* background: rgba(30, 35, 40, 0.85); */
 }

 .legal-card h2 {
   margin: 0 0 8px;
   font-weight: 600;
   font-size: clamp(18px, 2.6vw, 24px);
 }

 .legal-card h3 {
   margin: 14px 0 6px;
   font-weight: 600;
   font-size: clamp(16px, 2.2vw, 20px);
 }

 .legal-card p,
 .legal-card li {
   color: var(--fg);
   font-weight: 200;
   font-size: clamp(14px, 2vw, 16px);
   line-height: 1.7;
 }

 .legal-note {
   color: var(--muted);
   font-size: .92rem;
 }

 .toc {
   display: flex;
   flex-wrap: wrap;
   gap: .35rem .75rem;
   padding: 10px 0 6px;

 }

 .toc a {
   color: var(--accent);
   text-decoration: none;
   font-weight: 400;
   /* border-bottom: 1px dashed color-mix(in oklab, var(--accent), transparent 60%); */
 }

 .toc a:hover {
   border-bottom-style: solid;
 }

 .legal-main a {
   color: var(--accent);
 }

 .legal-footer {
   text-align: center;
   padding: 24px 12px;
   color: var(--muted);
 }
