/* HAAK LEGAL — Editorial White Design System
   System fonts only (DSGVO-clean, no external requests).
   Production: self-host Source Serif 4 + Inter as woff2 if desired. */

:root{
  --ink:#0F1F3A;
  --ink-2:#1A1A1A;
  --muted:#5C6470;
  --line:#E6E6E6;
  --bg:#FFFFFF;
  --bg-2:#FAFAF7;
  --accent:#B08A3E;
  --ok:#1B5E20;
  --err:#B91C1C;
  --serif: ui-serif, Charter, 'Source Serif 4', 'Source Serif Pro', 'Iowan Old Style', 'Apple Garamond', Georgia, 'Times New Roman', serif;
  --sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Inter', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --maxw: 1180px;
  --pad: 32px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  color:var(--ink-2);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  font-size:16px;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
hr{border:none;border-top:1px solid var(--line);margin:0}
:focus-visible{outline:2px solid var(--ink);outline-offset:3px;border-radius:2px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ============ NAV ============ */
.nav{position:sticky;top:0;background:rgba(255,255,255,0.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line);z-index:50}
.nav-row{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:24px}
.brand{font-family:var(--serif);font-size:22px;letter-spacing:6px;color:var(--ink);font-weight:500}
.brand span{color:var(--muted);font-weight:400}
.brand:hover{opacity:.85}
.menu{display:flex;align-items:center;gap:0}
.menu a{margin-left:32px;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-2)}
.menu a:hover{color:var(--ink)}
.menu .sep{margin-left:32px;color:var(--line)}
.lang{font-size:12px;letter-spacing:1.5px;color:var(--muted);margin-left:24px;display:inline-flex;gap:8px;align-items:center}
.lang a{color:var(--muted)}
.lang a.active{color:var(--ink);font-weight:600}
.lang a:hover{color:var(--ink)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;font-size:24px;color:var(--ink)}
.menu-toggle:hover{opacity:.7}

/* ============ HERO ============ */
.hero{padding:120px 0 100px;border-bottom:1px solid var(--line)}
.eyebrow{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-bottom:32px;font-weight:500}
h1{font-family:var(--serif);font-weight:400;font-size:64px;line-height:1.08;letter-spacing:-0.5px;color:var(--ink);margin:0 0 28px;max-width:920px}
h1 em{font-style:italic;color:var(--ink)}
.lede{font-size:20px;color:var(--muted);max-width:680px;line-height:1.6;margin:0 0 48px;font-weight:300}
.cta-row{display:flex;gap:16px;flex-wrap:wrap}

.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;font-size:13px;letter-spacing:2px;text-transform:uppercase;border:1px solid var(--ink);color:var(--ink);background:transparent;cursor:pointer;font-family:inherit;font-weight:500;transition:.2s ease}
.btn:hover{background:var(--ink);color:#fff}
.btn.primary{background:var(--ink);color:#fff}
.btn.primary:hover{background:#000}
.btn[disabled]{opacity:.6;cursor:not-allowed}

/* ============ SECTIONS ============ */
section{padding:96px 0;border-bottom:1px solid var(--line)}
.label{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-bottom:24px;font-weight:500}
h2{font-family:var(--serif);font-weight:400;font-size:40px;line-height:1.2;color:var(--ink);margin:0 0 24px;letter-spacing:-0.3px;max-width:900px}
h3{font-family:var(--serif);font-weight:400;font-size:24px;color:var(--ink);margin:0 0 12px;letter-spacing:-0.2px}
.intro p{font-size:18px;color:#33384a;max-width:780px;line-height:1.7;font-weight:300}
.intro p+p{margin-top:18px}

/* ============ DIFFERENTIATORS ============ */
.diffs{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:48px;border-top:1px solid var(--line)}
.diff{padding:32px 24px 32px 0;border-bottom:1px solid var(--line)}
.diff:nth-child(3n+2),.diff:nth-child(3n+3){padding-left:32px;border-left:1px solid var(--line)}
.diff:nth-child(3n+3){padding-right:0}
.diff h4{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--ink);margin:0 0 10px}
.diff p{font-size:14.5px;color:var(--muted);margin:0;line-height:1.6}

/* ============ SERVICES ============ */
.services{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line);margin-top:48px}
.service{padding:48px 32px 48px 0;border-bottom:1px solid var(--line)}
.service:nth-child(odd){padding-right:48px}
.service:nth-child(even){padding-left:48px;border-left:1px solid var(--line)}
.service .num{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:13px;margin-bottom:18px;display:block;letter-spacing:.5px}
.service p{color:var(--muted);font-size:15px;margin:0 0 18px;line-height:1.65}
.service ul{padding-left:18px;margin:0;color:#33384a;font-size:14.5px;line-height:1.9}

/* ============ INDUSTRIES ============ */
.industries{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-top:48px}
.industry{padding:32px 0 0;border-top:1px solid var(--ink)}
.industry h4{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--ink);margin:0 0 10px;letter-spacing:-0.2px}
.industry p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.6}

/* ============ ABOUT ============ */
.about{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:center}
.about-photo{position:relative}
.about-photo img{width:100%;max-width:380px;filter:grayscale(15%) contrast(1.02);box-shadow:0 1px 0 var(--line)}
.about-text p{color:#33384a;font-size:16.5px;line-height:1.75;font-weight:300}
.about-text p+p{margin-top:18px}
.about-text .name{font-family:var(--serif);font-size:36px;color:var(--ink);margin:0 0 6px;font-weight:400}
.about-text .role{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:24px;display:block}

/* ============ TOPICS ============ */
.topics-section{background:var(--bg-2)}
.topic-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.topic{background:#fff;padding:32px;border:1px solid var(--line);transition:.2s ease;display:flex;flex-direction:column;height:100%}
.topic:hover{border-color:var(--ink);transform:translateY(-2px)}
.topic .meta{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-weight:500}
.topic h4{font-family:var(--serif);font-weight:400;font-size:20px;color:var(--ink);margin:0 0 12px;line-height:1.3;letter-spacing:-0.2px}
.topic p{font-size:14px;color:var(--muted);margin:0;line-height:1.65;flex:1}

/* ============ FAQ (Schema-friendly) ============ */
.faq{margin-top:48px;border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line);padding:0}
.faq summary{padding:28px 0;font-family:var(--serif);font-size:20px;color:var(--ink);cursor:pointer;font-weight:400;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px;letter-spacing:-0.2px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-family:var(--sans);font-size:22px;font-weight:300;color:var(--muted);transition:.2s}
.faq details[open] summary::after{content:'−'}
.faq details[open] summary{color:var(--ink)}
.faq .answer{padding:0 0 28px;color:#33384a;font-size:15.5px;line-height:1.75;max-width:820px;font-weight:300}

/* ============ CONTACT ============ */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.contact-intro p{color:var(--muted);max-width:480px;font-size:17px;line-height:1.7}
.contact-info{padding:32px;background:var(--bg-2);border:1px solid var(--line)}
.contact-info dt{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:18px;font-weight:500}
.contact-info dt:first-child{margin-top:0}
.contact-info dd{margin:6px 0 0;font-size:15px;color:var(--ink)}
.contact-info dd a:hover{color:var(--accent)}

/* Form */
.form{margin-top:48px;border-top:1px solid var(--line);padding-top:48px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1 / -1}
.field label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);font-weight:500}
.field input, .field textarea, .field select{
  font-family:inherit;font-size:15px;color:var(--ink-2);
  background:#fff;border:none;border-bottom:1px solid var(--line);
  padding:12px 0;outline:none;transition:.2s
}
.field input:focus,.field textarea:focus,.field select:focus{border-bottom-color:var(--ink)}
.field textarea{min-height:120px;resize:vertical;font-family:inherit}
.field.consent{flex-direction:row;gap:12px;align-items:flex-start;font-size:13.5px;color:var(--muted);line-height:1.55}
.field.consent input{width:auto;margin-top:3px}
.field.consent a{color:var(--ink);text-decoration:underline}
.form-actions{display:flex;justify-content:space-between;align-items:center;margin-top:8px;gap:16px;flex-wrap:wrap}
.form-status{font-size:13.5px;min-height:20px}
.form-status.ok{color:var(--ok)}
.form-status.err{color:var(--err)}
.turnstile-placeholder{margin:0 0 8px;padding:14px;background:var(--bg-2);border:1px dashed var(--line);font-size:12px;color:var(--muted);text-align:center}

/* ============ FOOTER ============ */
footer{padding:48px 0;background:#fff;border-top:1px solid var(--line)}
.foot-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px}
.foot-meta{font-size:13px;color:var(--muted)}
.foot-links{display:flex;gap:24px;flex-wrap:wrap}
.foot-links a{font-size:13px;color:var(--muted)}
.foot-links a:hover{color:var(--ink)}

/* ============ LEGAL PAGES ============ */
.legal-page{padding:80px 0;max-width:820px;margin:0 auto}
.legal-page h1{font-size:42px;margin-bottom:32px}
.legal-page h2{font-size:24px;font-family:var(--serif);font-weight:500;margin:48px 0 16px;color:var(--ink)}
.legal-page h3{font-size:18px;font-weight:600;font-family:var(--sans);margin:32px 0 12px;color:var(--ink)}
.legal-page p{font-size:15.5px;color:#33384a;line-height:1.75;margin:0 0 16px;font-weight:300}
.legal-page ul{padding-left:22px;color:#33384a;font-size:15px;line-height:1.85;font-weight:300}
.legal-page a{color:var(--ink);text-decoration:underline}
.legal-page a:hover{color:var(--accent)}
.legal-page strong{color:var(--ink);font-weight:500}

/* ============ REVEAL ANIMATION ============ */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ============ RESPONSIVE ============ */
@media (max-width:980px){
  h1{font-size:48px}
  h2{font-size:32px}
  .topic-grid{grid-template-columns:repeat(2,1fr)}
  .industries{grid-template-columns:repeat(2,1fr);gap:24px}
}

@media (max-width:720px){
  :root{--pad:20px}
  h1{font-size:36px;letter-spacing:-0.3px}
  h2{font-size:26px}
  h3{font-size:20px}
  .lede{font-size:17px}
  section{padding:64px 0}
  .hero{padding:64px 0 56px}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;padding:24px var(--pad);border-bottom:1px solid var(--line);gap:16px;box-shadow:0 8px 16px rgba(0,0,0,0.04)}
  .menu.open{display:flex}
  .menu a{margin-left:0;padding:8px 0}
  .menu .lang{margin-left:0}
  .menu-toggle{display:block}
  .diffs{grid-template-columns:1fr}
  .diff,.diff:nth-child(3n+2),.diff:nth-child(3n+3){padding:24px 0;border-left:none}
  .services{grid-template-columns:1fr}
  .service:nth-child(odd),.service:nth-child(even){padding:32px 0;border-left:none}
  .industries{grid-template-columns:1fr;gap:0}
  .industry{padding:24px 0;border-top:1px solid var(--line)}
  .industry:first-child{border-top:1px solid var(--ink)}
  .about{grid-template-columns:1fr;gap:32px}
  .about-photo img{max-width:240px;margin:0 auto}
  .topic-grid{grid-template-columns:1fr;gap:16px}
  .contact{grid-template-columns:1fr;gap:32px}
  .form-grid{grid-template-columns:1fr;gap:20px}
  .foot-row{flex-direction:column;text-align:center}
}

/* Print */
@media print{
  .nav,.cta-row,.menu-toggle,.theme-badge,.form{display:none}
  body{font-size:11pt}
  a{color:#000;text-decoration:none}
}
