/* ============================================================================
   Pizzeria Filipo — Layout für Rechtsseiten (Impressum, Datenschutz)
   Nutzt die Design-Tokens aus style.css (muss davor geladen werden).
   ==========================================================================*/
body.legal {
  background: var(--navy-900);
  background-image:
    radial-gradient(900px 500px at 80% -10%, rgba(228,98,42,.10), transparent 60%),
    radial-gradient(800px 500px at 5% 0%, rgba(44,69,113,.30), transparent 55%);
}

.legal-top {
  position: sticky; top: 0; z-index: 100;
  background: rgba(10,17,32,.9); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line-soft);
}
.legal-top__inner { max-width: 860px; margin: 0 auto; display: flex; align-items: center; gap: 1rem; padding: .8rem var(--pad); }
.legal-top .brand { margin-right: auto; }
.legal-top .brand img { width: 42px; height: 42px; }
.legal-top .home { font-size: .85rem; color: var(--cream-dim); }
.legal-top .home:hover { color: var(--gold); }

.legal-wrap { max-width: 800px; margin: 0 auto; padding: clamp(2.2rem, 5vw, 3.5rem) var(--pad) 4rem; }
.legal-wrap h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(2rem, 5vw, 2.9rem); color: var(--cream); letter-spacing: -.02em; }
.legal-wrap .updated { color: var(--faint); font-size: .76rem; text-transform: uppercase; letter-spacing: .16em; margin-top: .6rem; margin-bottom: 2.4rem; }
.legal-wrap h2 { font-family: var(--font-display); font-weight: 700; font-size: 1.35rem; color: var(--gold-bright); margin: 2.4rem 0 .7rem; }
.legal-wrap h3 { font-size: 1rem; color: var(--cream); margin: 1.4rem 0 .3rem; }
.legal-wrap p, .legal-wrap li { color: var(--cream-dim); font-size: .95rem; line-height: 1.75; }
.legal-wrap p { margin: .5rem 0; }
.legal-wrap ul { padding-left: 1.2rem; margin: .5rem 0; display: grid; gap: .3rem; }
.legal-wrap a { color: var(--gold); border-bottom: 1px solid transparent; transition: border-color .25s; word-break: break-word; }
.legal-wrap a:hover { border-color: var(--gold); }
.legal-wrap address { font-style: normal; color: var(--cream); line-height: 1.8; }

.legal-wrap .box { border: 1px solid var(--line); border-radius: var(--radius); padding: 1.1rem 1.3rem; background: var(--navy-850); margin: 1.2rem 0; }
.legal-wrap .note { border-color: rgba(228,98,42,.35); background: rgba(228,98,42,.08); }
.legal-wrap .note p { color: var(--cream); }
.legal-wrap .muted { color: var(--faint); font-size: .82rem; }

.legal-foot { border-top: 1px solid var(--line-soft); padding: 2.2rem var(--pad); text-align: center; }
.legal-foot .links a { color: var(--cream-dim); font-size: .85rem; }
.legal-foot .links a:hover { color: var(--gold); }
.legal-foot .sep { color: var(--faint); margin: 0 .5rem; }
.legal-foot .muted { color: var(--faint); font-size: .78rem; margin-top: .8rem; }

/* Light theme: keep the sticky header readable on the pale page */
html[data-theme="light"] .legal-top { background: rgba(245, 238, 222, .92); }
