/* =========================================================
   STEINER architekten + ingenieure — Global stylesheet
   Self-hosted fonts (DSGVO-konform), shared across all pages.
   Typografie-System:
   - Source Sans Pro     → Fließtext, alle Textebenen
   - Source Code Pro     → große Überschriften (Hero, Sec-Titles)
   - JetBrains Mono      → Navigation, Labels, Meta-Info
   ========================================================= */

/* ---------- Source Sans Pro (Fließtext) ---------- */
@font-face {
  font-family: "Source Sans";
  src: url("fonts/source-sans-400.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Source Sans";
  src: url("fonts/source-sans-500.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Source Sans";
  src: url("fonts/source-sans-600.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Source Sans";
  src: url("fonts/source-sans-700.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Source Sans";
  src: url("fonts/source-sans-400-italic.woff2") format("woff2");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

/* ---------- Source Code Pro (Überschriften) ---------- */
@font-face {
  font-family: "Source Code Pro";
  src: url("fonts/source-code-pro-400.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Source Code Pro";
  src: url("fonts/source-code-pro-500.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Source Code Pro";
  src: url("fonts/source-code-pro-700.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Source Code Pro";
  src: url("fonts/source-code-pro-400-italic.woff2") format("woff2");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

/* ---------- JetBrains Mono (Navigation, Labels, Meta) ---------- */
@font-face {
  font-family: "JetBrains Mono";
  src: url("fonts/jetbrains-mono-400.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "JetBrains Mono";
  src: url("fonts/jetbrains-mono-500.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

/* ---------- Brand tokens ---------- */
:root{
  --paper:        #FAF8F5;
  --paper-2:      #F2EEE8;
  --ink:          #1A1917;
  --ink-2:        #1A1A1A;
  --brand-gray:   #555555;
  --gray-mid:     #8A8782;
  --gray-soft:    #C8C6C2;
  --gray-line:    #D9D5CF;
  --accent:       #A40E0E;
  --accent-deep:  #7F0B0B;
  --accent-soft:  #A40E0E;
  --sans:         "Source Sans", "Helvetica Neue", Arial, sans-serif;
  /* Überschriften groß (Hero, Sec-Titles, Legal-Headings) */
  --serif:        "Source Code Pro", ui-monospace, monospace;
  /* Fallback für Stellen, die früher Fraunces waren → jetzt Source Sans */
  --serif-legacy: "Source Sans", "Helvetica Neue", Arial, sans-serif;
  /* Navigation, Labels, Meta */
  --mono:         "JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;
  /* Alias: wird in einigen Selektoren verwendet, zeigt auf Source Code Pro */
  --mono-accent:  "Source Code Pro", ui-monospace, monospace;
  --col: min(1320px, 92vw);
}

*,*::before,*::after{ box-sizing:border-box }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:16.5px;
  line-height:1.65;
  letter-spacing:0.005em;
  overflow-x:hidden;
}
img{ max-width:100%; display:block }
a{ color:inherit; text-decoration:none }
::selection{ background:var(--accent); color:#fff }

/* subtle page grain */
body::before{
  content:"";
  position:fixed; inset:0;
  background-image: radial-gradient(rgba(0,0,0,0.018) 1px, transparent 1px);
  background-size:3px 3px;
  pointer-events:none;
  z-index:1;
  mix-blend-mode:multiply;
}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0;
  z-index:50;
  padding:18px 0;
  background:rgba(250,248,245,0.82);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .35s ease, padding .35s ease, background .35s ease;
}
.nav.scrolled{ border-bottom-color:var(--gray-line); padding:12px 0 }
.nav-inner{
  width:var(--col); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px;
}
.nav-logo{ display:flex; align-items:center; gap:14px }
.nav-logo img{ height:80px; width:auto; transition:height .35s ease }
.nav.scrolled .nav-logo img{ height:68px }
.nav-menu{
  display:flex; gap:30px;
  font-family:var(--mono);
  font-size:13px;
  font-weight:500;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--brand-gray);
}
.nav-menu a{ position:relative; padding:4px 0; transition:color .25s ease }
.nav-menu a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-2px;
  height:1px; background:var(--accent);
  transition:right .35s cubic-bezier(.2,.7,.2,1);
}
.nav-menu a:hover{ color:var(--ink) }
.nav-menu a:hover::after{ right:0 }
.nav-cta{
  font-family:var(--mono);
  font-size:13px; font-weight:500;
  letter-spacing:0.12em; text-transform:uppercase;
  padding:10px 18px;
  border:1px solid var(--ink);
  color:var(--ink);
  transition:background .25s ease, color .25s ease;
  white-space:nowrap;
}
.nav-cta:hover{ background:var(--ink); color:var(--paper) }
.nav-burger{ display:none }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;
  min-height:100vh;
  padding:180px 0 80px;
  display:flex; align-items:center;
  overflow:hidden;
}
.hero-grid{
  width:var(--col); margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(0,0.9fr);
  gap:clamp(28px, 5vw, 72px);
  align-items:end;
}
.hero-eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--brand-gray);
  margin-bottom:32px;
  display:flex; align-items:center; gap:14px;
}
.hero-eyebrow .dash{ width:40px; height:1px; background:var(--accent); }
.hero h1{
  font-family:var(--mono-accent);
  font-weight:500;
  font-size:clamp(38px, 5vw, 76px);
  line-height:1.05;
  letter-spacing:-0.02em;
  margin:0;
  color:var(--ink);
}
.hero h1 em{ font-style:italic; font-weight:400; color:var(--brand-gray) }
.hero h1 .accent{ color:var(--accent) }

.hero-right{
  align-self:end;
  padding-bottom:12px;
  border-left:1px solid var(--gray-line);
  padding-left:clamp(24px, 3vw, 44px);
}
.hero-lead{
  font-family:var(--sans);
  font-weight:400;
  font-size:clamp(17px, 1.35vw, 21px);
  line-height:1.55;
  color:var(--ink-2);
  margin:0 0 28px 0;
  max-width:42ch;
}
.hero-sub{
  font-family:var(--sans);
  font-size:14px;
  line-height:1.7;
  color:var(--brand-gray);
  margin:0 0 36px 0;
  max-width:44ch;
}
.hero-meta{
  display:flex; flex-wrap:wrap; gap:28px 36px;
  padding-top:24px;
  border-top:1px solid var(--gray-line);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--gray-mid);
}
.hero-meta span strong{ color:var(--ink); font-weight:500 }

.hero::before, .hero::after{
  content:""; position:absolute; top:0; bottom:0; width:1px;
  background:var(--gray-line); opacity:0.6; pointer-events:none;
}
.hero::before{ left:calc(50% - var(--col)/2) }
.hero::after{ right:calc(50% - var(--col)/2) }

.scroll-cue{
  position:absolute;
  bottom:32px; left:50%;
  transform:translateX(-50%);
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--brand-gray);
  display:flex; align-items:center; gap:12px;
}
.scroll-cue .line{
  width:1px; height:32px;
  background:linear-gradient(to bottom, transparent, var(--brand-gray));
  animation:cue 2.4s ease-in-out infinite;
}
@keyframes cue{
  0%,100%{ transform:scaleY(1); opacity:1 }
  50%{ transform:scaleY(0.6); opacity:0.4 }
}

/* =========================================================
   SECTIONS
   ========================================================= */
section{ position:relative; padding:clamp(90px,11vw,160px) 0; }
.wrap{ width:var(--col); margin:0 auto }
.sec-head{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:clamp(32px,5vw,80px);
  margin-bottom:clamp(48px,6vw,90px);
}
.sec-tag{
  font-family:var(--mono);
  font-size:11.5px;
  letter-spacing:0.24em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:500;
  padding-top:14px;
  white-space:nowrap;
}
.sec-tag .num{ color:var(--brand-gray); margin-right:10px }
.sec-title{
  font-family:var(--mono-accent);
  font-weight:500;
  font-size:clamp(34px, 4.4vw, 64px);
  line-height:1.04;
  letter-spacing:-0.015em;
  color:var(--ink);
  margin:0;
  max-width:22ch;
}
.sec-title em{ font-style:italic; color:var(--brand-gray); font-weight:400 }

.divider{
  width:var(--col); margin:0 auto;
  height:1px; background:var(--gray-line);
}

/* PROFILE */
.profile-grid{ display:grid; grid-template-columns:auto 1fr; gap:clamp(32px,5vw,80px); }
.profile-spacer{ width:0 }
.profile-body{ max-width:62ch }
.profile-body p{ font-size:17px; line-height:1.72; color:var(--ink-2); margin:0 0 22px 0; }
.profile-body p:first-child{
  font-family:var(--sans);
  font-size:clamp(22px, 2vw, 28px);
  line-height:1.5; font-weight:400;
  color:var(--ink); margin-bottom:36px;
}

.kpi-row{
  margin-top:72px;
  display:grid; grid-template-columns:repeat(4, 1fr);
  border-top:1px solid var(--gray-line);
}
.kpi{ padding:28px 24px 24px 0; border-right:1px solid var(--gray-line); }
.kpi:last-child{ border-right:none }
.kpi-num{
  font-family:var(--sans); font-weight:400;
  font-size:clamp(32px,3vw,48px); line-height:1;
  letter-spacing:-0.005em; color:var(--ink);
}
.kpi-num sup{ font-size:0.4em; color:var(--accent); margin-left:6px; top:-1em; }
.kpi-label{
  margin-top:12px;
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:0.22em; text-transform:uppercase;
  color:var(--brand-gray); line-height:1.5;
}

/* SERVICES */
.services{ background:var(--paper-2); position:relative }
.services::before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(to right, var(--gray-line) 1px, transparent 1px) 0 0/calc(var(--col)/12 + 1px) 100%,
    linear-gradient(to right, var(--gray-line) 1px, transparent 1px) calc(50% - var(--col)/2) 0/var(--col) 100%;
  opacity:0.35; pointer-events:none;
}
.services > *{ position:relative; z-index:1 }

.svc-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:0;
  border-top:1px solid var(--ink); border-left:1px solid var(--ink);
}
.svc{
  padding:42px 38px 44px;
  border-right:1px solid var(--ink); border-bottom:1px solid var(--ink);
  background:var(--paper);
  position:relative;
  transition:background .35s ease;
  overflow:hidden;
}
.svc::before{
  content:""; position:absolute; left:0; right:0; top:0; height:2px;
  background:var(--accent);
  transform:scaleX(0); transform-origin:left;
  transition:transform .55s cubic-bezier(.2,.7,.2,1);
}
.svc:hover{ background:#fff }
.svc:hover::before{ transform:scaleX(1) }
.svc-num{ font-family:var(--mono); font-size:11.5px; letter-spacing:0.22em; color:var(--brand-gray) }
.svc-title{
  margin:16px 0 18px 0;
  font-family:var(--sans); font-weight:400;
  font-size:clamp(22px,1.9vw,30px); line-height:1.2;
  letter-spacing:-0.005em; color:var(--ink);
}
.svc-body{ font-size:15.5px; line-height:1.7; color:var(--brand-gray); max-width:46ch }

/* GENERAL PLANNING */
.gp{
  display:grid; grid-template-columns:minmax(0,5fr) minmax(0,7fr);
  gap:clamp(32px,5vw,88px); align-items:start;
}
.gp-claim{
  position:sticky; top:140px;
  font-family:var(--sans); font-weight:400;
  font-size:clamp(30px,3vw,46px); line-height:1.1;
  letter-spacing:-0.005em; color:var(--ink);
}
.gp-claim em{ color:var(--accent); font-style:italic; font-weight:400 }
.gp-body p{ font-size:17px; line-height:1.72; color:var(--ink-2); margin:0 0 22px 0 }
.gp-list{
  margin-top:42px; padding-top:32px;
  border-top:1px solid var(--gray-line);
  list-style:none; padding-left:0;
}
.gp-list li{
  display:grid; grid-template-columns:42px 1fr; gap:16px;
  padding:18px 0; border-bottom:1px solid var(--gray-line);
  align-items:baseline; font-size:16px; color:var(--ink-2);
}
.gp-list li .mk{ font-family:var(--mono); font-size:11px; letter-spacing:0.18em; color:var(--accent); padding-top:4px }

/* INTERNATIONAL (dark) */
.intl{ background:var(--ink); color:#EDEBE6 }
.intl .sec-title{ color:#F5F2ED }
.intl .sec-title em{ color:#BDB6AB }
.intl .sec-tag{ color:var(--accent-soft) }
.intl .intl-lead{
  font-family:var(--sans); font-weight:400;
  font-size:clamp(22px,2vw,30px); line-height:1.45;
  color:#F5F2ED; max-width:52ch; margin:0 0 48px 0;
}
.intl-grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:#2A2A2A; border:1px solid #2A2A2A;
}
.intl-cell{ background:var(--ink); padding:36px 32px 40px }
.intl-cell h3{ font-family:var(--sans); font-weight:400; font-size:22px; line-height:1.25; color:#F5F2ED; margin:0 0 16px 0 }
.intl-cell p{ font-size:15px; line-height:1.7; color:#B8B3AA; margin:0 }
.intl-cell .ix{
  font-family:var(--mono); font-size:10.5px; letter-spacing:0.24em;
  color:var(--accent-soft); margin-bottom:14px; display:block;
}

/* TYPES */
.types-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px }
.type{ padding:28px 0 28px 0; border-top:1px solid var(--ink); position:relative }
.type .n{ font-family:var(--mono); font-size:10.5px; letter-spacing:0.22em; color:var(--accent); margin-bottom:14px }
.type h4{ font-family:var(--sans); font-weight:400; font-size:22px; line-height:1.2; margin:0 0 10px 0; color:var(--ink) }
.type p{ font-size:14.5px; line-height:1.65; color:var(--brand-gray); margin:0 }

/* VALUES */
.values{ background:var(--paper-2) }
.vals{
  display:grid; grid-template-columns:repeat(5,1fr); gap:0;
  border-top:1px solid var(--ink);
}
.val{ padding:36px 24px 40px 0; border-right:1px solid var(--gray-line) }
.val:last-child{ border-right:none; padding-right:0 }
.val .k{
  font-family:var(--sans); font-size:clamp(28px,2.6vw,42px);
  font-weight:400; line-height:1; color:var(--accent); letter-spacing:0;
}
.val h5{
  margin:18px 0 10px 0;
  font-family:var(--sans); font-size:14px; font-weight:600;
  letter-spacing:0.06em; text-transform:uppercase; color:var(--ink);
}
.val p{ font-size:14px; line-height:1.65; color:var(--brand-gray); margin:0 }

/* REFERENCES */
.refs{ background:var(--ink); color:#EDEBE6 }
.refs .sec-title{ color:#F5F2ED }
.refs .sec-title em{ color:#BDB6AB }
.refs .sec-tag{ color:var(--accent-soft) }
.refs-grid{
  display:grid; grid-template-columns:minmax(0,5fr) minmax(0,7fr);
  gap:clamp(32px,5vw,80px); align-items:start;
}
.refs-claim{
  font-family:var(--sans); font-weight:400;
  font-size:clamp(26px,2.4vw,38px); line-height:1.2;
  color:#F5F2ED; letter-spacing:-0.005em;
}
.refs-claim em{ color:var(--accent-soft); font-style:italic; font-weight:400 }
.refs-body p{ font-size:16.5px; line-height:1.75; color:#C4BFB6; margin:0 0 22px 0 }
.refs-contact{
  margin-top:40px; padding:28px 32px;
  border:1px solid #3A3A3A;
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:16px;
}
.refs-contact .lbl{ font-family:var(--mono); font-size:11px; letter-spacing:0.22em; text-transform:uppercase; color:#9B9690 }
.refs-contact .mail{ font-family:var(--sans); font-size:22px; color:#F5F2ED; letter-spacing:0 }
.refs-contact .mail:hover{ color:var(--accent-soft) }

/* STANDORTE (offices) */
.offices{
  margin-top:48px;
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:1px; background:var(--ink);
  border:1px solid var(--ink);
}
.office{
  background:var(--paper); padding:38px 36px 40px;
  display:flex; flex-direction:column;
}
.office .loc{
  font-family:var(--mono); font-size:10.5px; letter-spacing:0.24em;
  text-transform:uppercase; color:var(--accent);
  margin-bottom:14px;
}
.office .city{
  font-family:var(--sans); font-weight:400;
  font-size:clamp(28px,2.4vw,40px); line-height:1;
  letter-spacing:-0.005em; color:var(--ink);
  margin:0 0 20px 0;
}
.office .addr{
  font-size:15.5px; line-height:1.65;
  color:var(--ink-2);
  margin:0 0 20px 0;
  font-style:normal;
}
.office .lines{
  margin-top:auto; padding-top:20px;
  border-top:1px solid var(--gray-line);
  display:grid; gap:10px;
  font-size:14px;
}
.office .lines .row{ display:grid; grid-template-columns:80px 1fr; gap:12px; align-items:baseline }
.office .lines .k{
  font-family:var(--mono); font-size:10px; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--brand-gray);
}
.office .lines a{ color:var(--ink); transition:color .2s ease }
.office .lines a:hover{ color:var(--accent) }

/* CONTACT */
.contact-grid{ display:grid; grid-template-columns:minmax(0,5fr) minmax(0,7fr); gap:clamp(32px,5vw,80px); }
.contact-lead{
  font-family:var(--sans); font-weight:400;
  font-size:clamp(26px,2.4vw,38px); line-height:1.2;
  letter-spacing:-0.005em; color:var(--ink);
}
.contact-lead em{ color:var(--accent); font-style:italic; font-weight:400 }

.form{
  display:grid; grid-template-columns:1fr 1fr; gap:0;
  border-top:1px solid var(--ink); border-left:1px solid var(--ink);
}
.field{
  position:relative;
  border-right:1px solid var(--ink); border-bottom:1px solid var(--ink);
  background:var(--paper);
}
.field.full{ grid-column:1/-1 }
.field label{
  position:absolute; top:12px; left:18px;
  font-family:var(--mono); font-size:10px; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--brand-gray); pointer-events:none;
}
.field input, .field textarea, .field select{
  width:100%; background:transparent; border:0;
  padding:32px 18px 16px;
  font-family:var(--sans); font-size:15px; color:var(--ink);
  outline:none; resize:none;
}
.field textarea{ min-height:140px }
.field:focus-within{ background:#fff }
.field:focus-within label{ color:var(--accent) }
.field .check{
  padding:20px 18px; display:flex; gap:12px; align-items:flex-start;
  font-size:13.5px; color:var(--ink-2); line-height:1.55;
}
.field .check input{ width:auto; padding:0; margin-top:4px }
.form-foot{
  grid-column:1/-1; padding:22px 22px;
  border-right:1px solid var(--ink); border-bottom:1px solid var(--ink);
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px;
  background:var(--paper-2);
}
.form-foot .note{
  font-family:var(--mono); font-size:10.5px; letter-spacing:0.16em;
  text-transform:uppercase; color:var(--brand-gray); max-width:52ch;
}
.btn{
  font-family:var(--sans); font-size:13px; font-weight:600;
  letter-spacing:0.14em; text-transform:uppercase;
  padding:16px 28px; background:var(--ink); color:var(--paper);
  border:0; cursor:pointer;
  display:inline-flex; align-items:center; gap:12px;
  transition:background .25s ease;
  text-decoration:none;
}
.btn:hover{ background:var(--accent) }
.btn .arr{ transition:transform .25s ease }
.btn:hover .arr{ transform:translateX(4px) }
.btn.soft{ background:var(--accent-soft); color:var(--ink) }
.btn.soft:hover{ background:#fff; color:var(--ink) }

.contact-info{
  margin-top:40px; display:grid; grid-template-columns:repeat(3,1fr); gap:0;
  border-top:1px solid var(--gray-line);
}
.contact-info > div{ padding:22px 24px 22px 0; border-right:1px solid var(--gray-line) }
.contact-info > div:last-child{ border-right:none }
.contact-info .lbl{
  font-family:var(--mono); font-size:10.5px; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--brand-gray); margin-bottom:10px;
}
.contact-info .val{
  font-family:var(--sans); font-size:17px; color:var(--ink);
  line-height:1.5; padding:0; border:0;
}

/* =========================================================
   NEWSLETTER
   ========================================================= */
.newsletter{
  background:var(--ink);
  color:#EDEBE6;
  padding:clamp(72px, 9vw, 120px) 0;
  position:relative;
}

/* Dezente Logo-Signatur am oberen Rand der Sektion */
.nl-signature{
  margin-bottom:clamp(48px, 6vw, 72px);
  padding-bottom:clamp(32px, 4vw, 48px);
  border-bottom:1px solid #2A2A2A;
}
.nl-signature-logo{
  height:38px; width:auto;
  opacity:0.75;
  transition:opacity .4s ease;
}
.nl-signature-logo:hover{ opacity:1 }

.nl-grid{
  display:grid; grid-template-columns:minmax(0,5fr) minmax(0,7fr);
  gap:clamp(32px, 5vw, 80px); align-items:center;
}
.nl-tag{
  font-family:var(--mono); font-size:11.5px;
  letter-spacing:0.24em; text-transform:uppercase;
  color:var(--accent-soft); font-weight:500;
  margin-bottom:18px;
  display:flex; align-items:center; gap:14px;
}
.nl-tag .dash{ width:40px; height:1px; background:var(--accent-soft) }
.nl-tag .num{ color:#8F8A82; margin-right:4px }
.nl-title{
  font-family:var(--sans); font-weight:400;
  font-size:clamp(30px, 3.4vw, 48px); line-height:1.08;
  letter-spacing:-0.005em; color:#F5F2ED;
  margin:0 0 20px 0; max-width:16ch;
}
.nl-title em{ color:var(--accent-soft); font-style:italic; font-weight:400 }
.nl-text{
  font-size:15.5px; line-height:1.7;
  color:#B8B3AA; max-width:42ch; margin:0;
}
.nl-form{
  display:grid; grid-template-columns:1fr; gap:0;
  border-top:1px solid #2A2A2A; border-left:1px solid #2A2A2A;
  background:#0C0C0C;
}
.nl-form .field{
  border-right:1px solid #2A2A2A; border-bottom:1px solid #2A2A2A;
  background:#0C0C0C;
}
.nl-form .field label{ color:#8F8A82 }
.nl-form .field input, .nl-form .field textarea{ color:#F5F2ED }
.nl-form .field:focus-within{ background:#151515 }
.nl-form .field:focus-within label{ color:var(--accent-soft) }
.nl-form .check{ color:#C4BFB6 }
.nl-form .check a{ color:var(--accent-soft); text-decoration:underline; text-underline-offset:3px }
.nl-form .form-foot{
  background:#0C0C0C;
  border-right:1px solid #2A2A2A; border-bottom:1px solid #2A2A2A;
}
.nl-form .form-foot .note{ color:#8F8A82 }

/* =========================================================
   FORM SUCCESS STATE (after submission)
   ========================================================= */
.form-success{
  padding:clamp(44px, 5vw, 72px) clamp(28px, 3vw, 48px);
  text-align:center;
  background:var(--paper);
  border:1px solid var(--ink);
  animation:fadeInUp .5s ease;
}
.form-success-icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:64px; height:64px;
  border-radius:50%;
  background:var(--accent); color:var(--paper);
  font-family:var(--sans); font-size:34px; font-weight:300;
  margin-bottom:24px;
}
.form-success h3{
  font-family:var(--sans); font-weight:400;
  font-size:clamp(26px, 2.4vw, 38px); line-height:1.2;
  letter-spacing:-0.005em; color:var(--ink);
  margin:0 0 14px 0;
}
.form-success p{
  font-size:16px; line-height:1.6;
  color:var(--brand-gray);
  margin:0 auto; max-width:46ch;
}

/* Dark variant inside the Newsletter section */
.newsletter .form-success{
  background:#0C0C0C;
  border-color:#2A2A2A;
}
.newsletter .form-success h3{ color:#F5F2ED }
.newsletter .form-success p{ color:#B8B3AA }
.newsletter .form-success-icon{
  background:var(--accent-soft);
  color:var(--ink);
}

@keyframes fadeInUp{
  from{ opacity:0; transform:translateY(16px); }
  to{   opacity:1; transform:none; }
}

/* FOOTER */
footer{
  background:var(--paper);
  border-top:1px solid var(--gray-line);
  padding:64px 0 32px;
}
.foot{
  width:var(--col); margin:0 auto;
  display:grid; grid-template-columns:minmax(0,5fr) minmax(0,7fr);
  gap:clamp(32px,5vw,80px); align-items:start;
  padding-bottom:48px; border-bottom:1px solid var(--gray-line);
}
.foot-logo img{ height:90px; width:auto }
.foot-claim{
  margin-top:18px;
  font-family:var(--sans); font-style:italic;
  font-size:16px; color:var(--brand-gray);
  line-height:1.5; max-width:42ch;
}
.foot-offices{
  margin-top:24px;
  display:grid; grid-template-columns:1fr 1fr; gap:20px;
  font-size:13.5px; line-height:1.6; color:var(--brand-gray);
}
.foot-offices strong{ display:block; color:var(--ink); font-weight:500; margin-bottom:4px }
.foot-nav{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px }
.foot-nav h6{
  font-family:var(--mono); font-size:10.5px; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--brand-gray);
  margin:0 0 16px 0; font-weight:500;
}
.foot-nav ul{ list-style:none; padding:0; margin:0 }
.foot-nav li{ margin:8px 0; font-size:14.5px; color:var(--ink-2) }
.foot-nav a:hover{ color:var(--accent) }
.foot-bottom{
  width:var(--col); margin:24px auto 0;
  display:flex; flex-wrap:wrap; gap:18px;
  align-items:center; justify-content:space-between;
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--gray-mid);
}
.foot-bottom a:hover{ color:var(--accent) }
.foot-bottom .lang{ display:flex; gap:12px }
.foot-bottom .lang a.active{ color:var(--ink) }
.foot-bottom .legal-links{ display:flex; gap:20px; flex-wrap:wrap }

/* =========================================================
   CONSENT BANNER
   ========================================================= */
.consent{
  position:fixed; left:24px; right:24px; bottom:24px;
  max-width:640px; margin:0 auto;
  z-index:100;
  background:var(--ink); color:#EDEBE6;
  padding:26px 28px;
  border:1px solid #2A2A2A;
  box-shadow:0 24px 60px rgba(0,0,0,0.25);
  transform:translateY(120%);
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
  font-size:14px; line-height:1.6;
}
.consent.show{ transform:translateY(0) }
.consent h4{
  font-family:var(--mono-accent); font-weight:400;
  font-size:20px; line-height:1.2;
  margin:0 0 10px 0; color:#F5F2ED;
  letter-spacing:-0.01em;
}
.consent p{ margin:0 0 18px 0; color:#C4BFB6 }
.consent a{ color:var(--accent-soft); text-decoration:underline; text-underline-offset:3px }
.consent a:hover{ color:#F5F2ED }
.consent .opts{
  display:grid; gap:12px;
  margin:0 0 20px 0;
  padding:16px 0;
  border-top:1px solid #2A2A2A;
  border-bottom:1px solid #2A2A2A;
}
.consent .opts label{
  display:flex; align-items:flex-start; gap:12px;
  font-size:13.5px; color:#D4CFC5;
  cursor:pointer;
}
.consent .opts input{ margin-top:3px }
.consent .opts .locked{ opacity:0.6; cursor:not-allowed }
.consent .opts small{ display:block; color:#8F8A82; font-size:12px; margin-top:2px; line-height:1.45 }
.consent .actions{
  display:flex; flex-wrap:wrap; gap:10px; justify-content:flex-end;
}
.consent .btn-ghost{
  font-family:var(--sans); font-size:12px; font-weight:500;
  letter-spacing:0.1em; text-transform:uppercase;
  padding:12px 18px; background:transparent;
  color:#C4BFB6; border:1px solid #3A3A3A; cursor:pointer;
  transition:color .2s ease, border-color .2s ease;
}
.consent .btn-ghost:hover{ color:#F5F2ED; border-color:#8A8782 }
.consent .btn-primary{
  font-family:var(--sans); font-size:12px; font-weight:600;
  letter-spacing:0.1em; text-transform:uppercase;
  padding:12px 20px; background:var(--paper); color:var(--ink);
  border:1px solid var(--paper); cursor:pointer;
  transition:background .2s ease, color .2s ease;
}
.consent .btn-primary:hover{ background:var(--accent); color:var(--paper); border-color:var(--accent) }

.consent-trigger{
  position:fixed; left:16px; bottom:16px; z-index:40;
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:0.18em; text-transform:uppercase;
  padding:8px 12px; background:rgba(17,17,17,0.85); color:#EDEBE6;
  border:0; cursor:pointer;
  display:none;
}
.consent-trigger.show{ display:inline-flex }
.consent-trigger:hover{ background:var(--accent) }

/* =========================================================
   LEGAL PAGE LAYOUT (impressum / datenschutz)
   ========================================================= */
.legal-wrap{
  width:min(860px, 92vw); margin:0 auto;
  padding:160px 0 100px;
}
.legal-eyebrow{
  font-family:var(--mono); font-size:11.5px;
  letter-spacing:0.24em; text-transform:uppercase;
  color:var(--accent); margin-bottom:18px;
  display:flex; align-items:center; gap:14px;
}
.legal-eyebrow .dash{ width:40px; height:1px; background:var(--accent) }
.legal-wrap h1{
  font-family:var(--mono-accent); font-weight:500;
  font-size:clamp(40px, 5vw, 68px);
  line-height:1.02; letter-spacing:-0.018em;
  margin:0 0 40px 0; color:var(--ink);
}
.legal-wrap h2{
  font-family:var(--mono-accent); font-weight:400;
  font-size:clamp(22px, 2vw, 28px);
  line-height:1.25; letter-spacing:-0.01em;
  color:var(--ink);
  margin:52px 0 18px 0;
  padding-top:30px;
  border-top:1px solid var(--gray-line);
}
.legal-wrap h2:first-of-type{ padding-top:0; border-top:0; margin-top:24px }
.legal-wrap h3{
  font-family:var(--sans); font-weight:600;
  font-size:15px; letter-spacing:0.04em;
  text-transform:uppercase; color:var(--ink-2);
  margin:32px 0 12px 0;
}
.legal-wrap p, .legal-wrap li{
  font-size:16px; line-height:1.72; color:var(--ink-2);
  margin:0 0 16px 0;
}
.legal-wrap ul, .legal-wrap ol{ padding-left:22px; margin:0 0 22px 0 }
.legal-wrap li{ margin:0 0 8px 0 }
.legal-wrap strong{ color:var(--ink); font-weight:500 }
.legal-wrap a{ color:var(--accent); text-decoration:underline; text-underline-offset:3px }
.legal-wrap a:hover{ color:var(--accent-deep) }
.legal-wrap .placeholder{
  display:inline-block;
  padding:1px 8px; margin:0 2px;
  background:#FFF6CC; color:#7A5500;
  font-family:var(--mono); font-size:0.88em;
  border:1px dashed #D9B848;
  letter-spacing:0;
}
.legal-wrap .block{
  padding:20px 24px; margin:24px 0;
  background:var(--paper-2); border-left:3px solid var(--accent);
  font-size:15px;
}
.legal-wrap .two-col{
  display:grid; grid-template-columns:1fr 1fr; gap:32px;
  margin:18px 0 32px 0;
}
.legal-wrap .back{
  display:inline-flex; align-items:center; gap:10px;
  margin-top:60px; padding-top:28px;
  border-top:1px solid var(--gray-line);
  font-family:var(--mono); font-size:11.5px;
  letter-spacing:0.18em; text-transform:uppercase;
  color:var(--brand-gray);
}
.legal-wrap .back:hover{ color:var(--accent) }
.legal-wrap .updated{
  font-family:var(--mono); font-size:11px;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--gray-mid); margin:-20px 0 40px 0;
}

/* =========================================================
   REVEAL
   ========================================================= */
[data-reveal]{ opacity:0; transform:translateY(24px); transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1) }
[data-reveal].in{ opacity:1; transform:none }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1024px){
  .hero-grid{ grid-template-columns:1fr; gap:48px }
  .hero-right{ border-left:0; border-top:1px solid var(--gray-line); padding-left:0; padding-top:32px }
  .gp, .refs-grid, .contact-grid{ grid-template-columns:1fr }
  .gp-claim{ position:static }
  .svc-grid{ grid-template-columns:1fr }
  .types-grid, .intl-grid{ grid-template-columns:1fr 1fr }
  .kpi-row, .vals{ grid-template-columns:1fr 1fr }
  .kpi:nth-child(2), .val:nth-child(2){ border-right:none }
  .contact-info{ grid-template-columns:1fr }
  .contact-info > div{ border-right:none; border-bottom:1px solid var(--gray-line) }
  .foot{ grid-template-columns:1fr; gap:40px }
  .foot-nav{ grid-template-columns:repeat(3,1fr) }
  .offices{ grid-template-columns:1fr }
  .legal-wrap .two-col{ grid-template-columns:1fr }
}
@media (max-width: 640px){
  .nav-menu, .nav-cta{ display:none }
  .nav-burger{ display:flex; flex-direction:column; gap:5px; padding:10px; background:transparent; border:0; cursor:pointer; }
  .nav-burger span{ width:26px; height:1.5px; background:var(--ink) }
  .nav-logo img{ height:60px }
  .nav.scrolled .nav-logo img{ height:52px }
  .hero{ padding:140px 0 80px }
  .hero h1{ font-size:48px }
  .sec-head{ grid-template-columns:1fr; gap:18px }
  .sec-title{ font-size:32px }
  .svc-grid, .types-grid, .intl-grid, .vals, .kpi-row, .foot-nav, .foot-offices{ grid-template-columns:1fr }
  .svc{ padding:32px 26px }
  .val, .kpi, .contact-info > div{ border-right:none; border-bottom:1px solid var(--gray-line); padding-right:0 }
  .form{ grid-template-columns:1fr }
  .consent{ left:12px; right:12px; bottom:12px; padding:22px 20px }
  .refs-contact{ flex-direction:column; align-items:flex-start }
}
