:root {
  --ocean-deep:#1B3A4B; --ocean-mid:#2E6171; --sand-light:#F5F0EB; --foam:#E8F4F8;
  --text-dark:#1A2A32; --text-body:#3D4F58; --text-muted:#5A6970;
  --sunset-gold:#E8B87D; --cta-orange:#B35E1B; --white:#fff;
  --font-heading:'Cormorant Garamond', Georgia, serif;
  --font-body:'Montserrat', 'Helvetica Neue', sans-serif;
}
* { margin:0; padding:0; box-sizing:border-box; }
html { -webkit-font-smoothing:antialiased; scroll-behavior:smooth; }
body { font-family:var(--font-body); font-size:16px; line-height:1.75; color:var(--text-body); background:var(--sand-light); }
a { color:var(--ocean-mid); text-decoration:none; transition:color .25s; }
a:hover { color:var(--cta-orange); }

.legal-header { background:var(--white); border-bottom:1px solid rgba(27,58,75,.08); position:sticky; top:0; z-index:10; }
.legal-header .wrap { max-width:880px; margin:0 auto; padding:0.85rem 1.5rem; display:flex; align-items:center; justify-content:space-between; }
.legal-header img { height:52px; width:auto; display:block; }
.back-link { font-size:.85rem; font-weight:600; color:var(--text-body); display:inline-flex; align-items:center; gap:.4rem; }
.back-link:hover { color:var(--cta-orange); }

.legal-main { max-width:780px; margin:0 auto; padding:3rem 1.5rem 4rem; }
.legal-main h1 { font-family:var(--font-heading); font-size:clamp(2.2rem,5vw,3rem); color:var(--text-dark); font-weight:600; line-height:1.1; margin-bottom:.4rem; }
.updated { font-size:.85rem; color:var(--text-muted); margin-bottom:1.5rem; }
.disclaimer { background:var(--foam); border:1px solid rgba(46,97,113,.2); border-radius:12px; padding:1rem 1.25rem; font-size:.85rem; color:var(--text-body); margin-bottom:2.5rem; }
.disclaimer strong { color:var(--ocean-deep); }
.legal-main h2 { font-family:var(--font-heading); font-size:1.6rem; color:var(--text-dark); font-weight:600; margin:2.2rem 0 .6rem; }
.legal-main h3 { font-size:.98rem; font-weight:600; color:var(--text-dark); margin:1.4rem 0 .4rem; }
.legal-main p { margin-bottom:1rem; }
.legal-main ul { margin:0 0 1rem 1.3rem; }
.legal-main li { margin-bottom:.5rem; }
.legal-main strong { color:var(--text-dark); }

.legal-footer { background:var(--ocean-deep); color:rgba(255,255,255,.7); padding:2rem 1.5rem; text-align:center; font-size:.82rem; }
.legal-footer nav a { color:rgba(255,255,255,.82); margin:0 .5rem; }
.legal-footer nav a:hover { color:var(--sunset-gold); }
.legal-footer .copy { margin-top:.75rem; opacity:.7; font-size:.78rem; }

@media (max-width:600px){ .legal-header img { height:42px; } .legal-main { padding-top:2rem; } }
