/* HAAK LEGAL — Editorial White Design System v4 (Magazine layout)
   System fonts only. */

: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', 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.94);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-top:10px;padding-bottom:10px;gap:24px}

/* Logo 02 SVG — flush-left with wrap */
.brand{display:inline-flex;align-items:center;color:var(--ink);flex-shrink:0;line-height:0}
.brand img{height:44px;width:auto;display:block}
.brand:hover{opacity:.85}

.nav-right{display:flex;align-items:center;gap:24px}

.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)}

/* Single language toggle component — switches position via media queries */
.lang{font-size:12px;letter-spacing:1px;color:var(--muted);display:inline-flex;align-items:center;gap:6px;white-space:nowrap;margin-left:32px}
.lang a{color:var(--muted);padding:2px 0;margin-left:0}
.lang a.active{color:var(--ink);font-weight:600}
.lang a:hover{color:var(--ink)}
.lang .sep{color:var(--line);margin:0 2px}

.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;font-size:24px;color:var(--ink);line-height:1}
.menu-toggle:hover{opacity:.7}

/* ============ MAGAZINE HERO + INTRO (Grid-Layout) ============ */
/* Two-column grid: photo left, all text + button right. Text stays in its column
   even if shorter than the photo — no orphan lines flow under the image. */
.magazine{padding:76px 0 60px}

.magazine-row{
  display:grid;
  grid-template-columns: 38% 1fr;
  gap: 56px;
  align-items: start;
  margin-bottom: 60px;
}

.magazine-photo{margin:0}
.magazine-photo picture{display:block}
.magazine-photo img{
  width:100%;
  aspect-ratio: 3 / 4;
  object-fit:cover;
  filter:grayscale(12%) contrast(1.02);
  box-shadow:0 1px 0 var(--line);
}
.magazine-photo .caption{
  margin-top:14px;
  font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);
  text-indent:-1px;
}
.magazine-photo .caption .accent{color:var(--accent);font-weight:600}

.magazine-text{min-width:0}

/* Eyebrow + Hero */
/* text-indent: -1px compensates for letter-spacing visual drift of the first glyph */
.eyebrow{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin:0 0 28px;font-weight:500;text-indent:-1px}

/* H1 — NO italic per client request */
h1{font-family:var(--serif);font-weight:400;font-size:56px;line-height:1.08;letter-spacing:-0.5px;color:var(--ink);margin:0 0 28px}

.lede{font-size:20px;color:var(--muted);line-height:1.6;margin:0 0 40px;font-weight:300}

.cta-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:64px}

.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}

/* Intro block within magazine */
.intro-label{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin:0 0 20px;font-weight:500;text-indent:-1px}
.intro-headline{font-family:var(--serif);font-weight:400;font-size:34px;line-height:1.22;color:var(--ink);margin:0 0 22px;letter-spacing:-0.3px;text-indent:-1px}
.intro-text{font-size:17px;color:#33384a;line-height:1.7;font-weight:300;margin:0 0 56px}

/* Differentiators row — full wrap width, sits below the magazine-row */
.diffs{display:grid;grid-template-columns:repeat(3,1fr);gap:0;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}

/* ============ SECTIONS (after magazine) ============ */
section{padding:60px 0;scroll-margin-top:80px}
.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;text-indent:-1px}
h3{font-family:var(--serif);font-weight:400;font-size:24px;color:var(--ink);margin:0 0 12px;letter-spacing:-0.2px;text-indent:-1px}

.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{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;text-indent:-1px}
.industry p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.6}

/* About (text only, no photo) */
.about-text{max-width:780px}
.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;text-indent:-1px}
.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%;text-decoration:none;color:inherit}
.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 0 16px;line-height:1.65;flex:1}
.topic .read-more{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);font-weight:600;margin-top:auto}
.topic .read-more::after{content:" →"}

/* FAQ */
.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:'\2212'}
.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{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{padding:48px 0;background:#fff}
.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-top:80px;padding-bottom:80px}
.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}

/* Topic detail page — full wrap width (text/headlines run to the right edge, in line with the nav) */
.topic-detail{padding-top:80px;padding-bottom:80px}
.topic-detail .back-link{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:32px;display:inline-block}
.topic-detail .back-link:hover{color:var(--accent)}
.topic-detail .meta{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:18px;font-weight:600}
.topic-detail h1{font-size:42px;margin-bottom:24px;line-height:1.12}
.topic-detail .lede{font-size:19px;color:#33384a;line-height:1.65;margin-bottom:48px;font-weight:300}
.topic-detail h2{font-family:var(--serif);font-size:28px;font-weight:400;margin:48px 0 18px;color:var(--ink);letter-spacing:-0.2px}
.topic-detail h3{font-family:var(--serif);font-size:21px;font-weight:500;margin:32px 0 12px;color:var(--ink)}
.topic-detail p{font-size:16.5px;color:#33384a;line-height:1.75;margin:0 0 18px;font-weight:300}
.topic-detail ul, .topic-detail ol{padding-left:22px;color:#33384a;font-size:16px;line-height:1.85;font-weight:300;margin-bottom:18px}
.topic-detail ul li, .topic-detail ol li{margin-bottom:6px}
.topic-detail blockquote{margin:32px 0;padding:24px 28px;border-left:2px solid var(--accent);background:var(--bg-2);font-style:italic;color:var(--ink);font-size:17px;line-height:1.6;font-weight:400}
.topic-detail .cta-card{margin-top:64px;padding:32px;background:var(--bg-2);border:1px solid var(--line)}
.topic-detail .cta-card h3{font-family:var(--serif);font-size:22px;font-weight:400;margin:0 0 8px;color:var(--ink)}
.topic-detail .cta-card p{font-size:15px;color:var(--muted);margin:0 0 18px}

.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 ============ */

/* Tablet + Mobile: burger menu activates, language toggle moves outside */
@media (max-width:980px){
  h1{font-size:46px}
  h2{font-size:32px}
  .topic-grid{grid-template-columns:repeat(2,1fr)}
  .industries{grid-template-columns:repeat(2,1fr);gap:24px}
  .magazine-row{grid-template-columns:36% 1fr;gap:40px}
  .intro-headline{font-size:30px}
  .brand img{height:38px}

  /* Burger menu kicks in here so menu items don't collide with the larger logo */
  .lang{margin-left:0;font-size:12px;gap:6px}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;padding:24px var(--pad);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{display:none}  /* Hide duplicate lang inside menu (we use the standalone one) */
  .menu-toggle{display:block}
}

@media (max-width:720px){
  :root{--pad:20px}
  h1{font-size:36px;letter-spacing:-0.3px}
  h2{font-size:26px}
  h3{font-size:20px}
  section{padding:44px 0}

  /* Mobile nav: tighter padding, smaller logo */
  .nav-row{padding-top:10px;padding-bottom:10px;gap:12px;min-width:0}
  .brand img{height:32px}
  .nav-right{gap:12px;flex-shrink:0}
  .lang{font-size:11px;gap:4px}

  /* Magazine: stack — photo on top, text below */
  .magazine{padding:36px 0 44px}
  .magazine-row{grid-template-columns:1fr;gap:32px;margin-bottom:36px}
  .magazine-photo{max-width:280px;margin:0}
  .magazine-photo img{aspect-ratio:4/5}
  h1{font-size:34px}
  .lede{font-size:17px;margin-bottom:32px}
  .intro-headline{font-size:24px}
  .intro-text{font-size:16px;margin-bottom:40px}
  .cta-row{margin-bottom:0}

  .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)}
  .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}
  .topic-detail h1{font-size:32px}
  .topic-detail .lede{font-size:17px}
}

/* Desktop only — hide standalone .lang since it lives inside the .menu */
@media (min-width:981px){
  .nav-right > .lang{display:none}
}

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