/* Shared styles for legal subpages (imprint, privacy, accessibility). */
/* Subordinate to the homepage: narrower max-width, smaller heading scale,
   generous line-height. Same palette and fonts as index.html. */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#0a0908;--bg2:#14110f;--bg3:#1e1a16;
  --fg:#f4ece1;--fg2:#a8a094;--fg3:#9a9388;
  --accent:#7acb86;--accent2:#b8e8a8;--accent-dim:#1d3a1e;
  --border:#2a2520;--radius:3px;
  --mono:'IBM Plex Mono',SFMono-Regular,ui-monospace,Menlo,monospace;
  --sans:'IBM Plex Sans',-apple-system,BlinkMacSystemFont,sans-serif;
}

html{scroll-behavior:smooth}
body{
  font-family:var(--sans);background:var(--bg);color:var(--fg);
  line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;
  display:flex;flex-direction:column;min-height:100vh;
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.04;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/></filter><rect width='240' height='240' filter='url(%23n)' opacity='0.9'/></svg>");
  mix-blend-mode:overlay;
}

a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
:focus{outline:none}
:focus-visible{outline:2px solid var(--accent2);outline-offset:3px;border-radius:2px}

.skip-link{
  position:absolute;top:-40px;left:8px;z-index:1000;
  background:var(--accent-dim);color:var(--accent2);
  padding:10px 16px;font-family:var(--mono);font-size:.82rem;
  border:1px solid var(--accent);text-decoration:none;
}
.skip-link:focus{top:8px;text-decoration:none}

/* ---- NAV (matches homepage chrome) ---- */
nav{
  position:sticky;top:0;z-index:100;
  background:rgba(10,9,8,.88);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);padding:14px 0;
}
nav .container{display:flex;align-items:center;justify-content:space-between}
nav .wordmark{
  font-family:var(--mono);font-size:.85rem;font-weight:600;
  letter-spacing:.06em;color:var(--fg);text-transform:uppercase;
  text-decoration:none;
}
nav .wordmark:hover{text-decoration:none;color:var(--accent2)}
nav .wordmark span{color:var(--accent)}
nav .links{display:flex;gap:22px;font-size:.78rem;color:var(--fg2);text-transform:lowercase;letter-spacing:.02em}
nav .links a{color:var(--fg2)}
nav .links a:hover{color:var(--fg)}

/* ---- LAYOUT ---- */
.container{max-width:1200px;margin:0 auto;padding:0 32px;position:relative;z-index:2}
main{flex:1 0 auto}
.legal-wrap{max-width:720px;margin:0 auto;padding:64px 32px 72px;position:relative;z-index:2}

/* ---- LABEL ---- */
.label{
  font-family:var(--mono);font-size:.7rem;font-weight:500;color:var(--accent);
  text-transform:uppercase;letter-spacing:.22em;margin-bottom:18px;display:block;
}

/* ---- HEADINGS ---- */
.legal-wrap h1{
  font-family:var(--mono);font-size:1.7rem;font-weight:500;
  letter-spacing:-.02em;line-height:1.2;color:var(--fg);
  margin-bottom:12px;
}
.legal-wrap .updated{
  font-family:var(--mono);font-size:.78rem;color:var(--fg3);
  letter-spacing:.02em;margin-bottom:32px;
}
.legal-wrap h2{
  font-family:var(--mono);font-size:1.1rem;font-weight:500;
  letter-spacing:-.01em;color:var(--fg);
  margin:36px 0 12px;
}
.legal-wrap h3{
  font-family:var(--mono);font-size:.95rem;font-weight:500;
  color:var(--fg);margin:24px 0 10px;
}

/* ---- BODY TEXT ---- */
.legal-wrap p{
  font-family:var(--sans);font-size:1rem;color:var(--fg2);
  line-height:1.7;margin-bottom:14px;
}
.legal-wrap p a,.legal-wrap li a,.legal-wrap .contact-block a{
  text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;
}
.legal-wrap ul,.legal-wrap ol{
  margin:0 0 16px 22px;color:var(--fg2);font-family:var(--sans);line-height:1.7;
}
.legal-wrap li{margin-bottom:6px}
.legal-wrap strong{color:var(--fg);font-weight:500}
.legal-wrap em{font-style:italic;color:var(--fg2)}
.legal-wrap hr{
  border:none;border-top:1px solid var(--border);margin:40px 0;
}

/* ---- CONTACT BLOCK ---- */
.legal-wrap .contact-block{
  background:var(--bg2);border:1px solid var(--border);
  padding:18px 22px;margin:18px 0 28px;
  font-family:var(--mono);font-size:.88rem;line-height:1.7;color:var(--fg2);
}
.legal-wrap .contact-block strong{color:var(--fg)}

/* ---- FOOTER ---- */
footer{
  padding:36px 0;text-align:center;font-size:.78rem;
  color:var(--fg2);font-family:var(--mono);letter-spacing:.04em;
  border-top:1px solid var(--border);
}
footer .container{display:flex;flex-direction:column;gap:14px;align-items:center}
footer a{color:var(--fg2)}
footer a:hover{color:var(--accent)}
footer .sep{margin:0 10px;opacity:.7;color:var(--accent)}
footer .legal a{color:var(--fg2)}
footer .legal a:hover{color:var(--accent)}

/* ---- RESPONSIVE ---- */
@media(max-width:640px){
  .container{padding:0 20px}
  .legal-wrap{padding:48px 20px 56px}
  .legal-wrap h1{font-size:1.4rem}
  .legal-wrap h2{font-size:1rem}
  nav .links{font-size:.72rem;gap:14px}
}
