/* ============================================================
   Christian Luder — Zertifizierter Bausachverständiger
   Design system: near-black ink, brand red from logo,
   filigree / blueprint line motif as the signature element.
   ============================================================ */

@import url("https://use.typekit.net/dgk7qbn.css");

:root{
  /* brand */
  --red:#c93c3c;
  --red-bright:#d85a5a;
  --steel:#4a4a4a;            /* brand neutral (Wand-Icon) */
  --green:#3cc994;            /* accent */
  --green-bright:#54d9a6;
  --ink:#161717;
  --ink-soft:#2a2b2b;
  --paper:#ffffff;
  --paper-2:#f4f2ef;          /* warm off-white alt section */
  --paper-3:#ece9e4;
  --line:#e1ddd6;             /* hairline on light */
  --muted:#6c6a66;            /* secondary text on light */
  --muted-2:#9a9893;

  /* dark surfaces */
  --night:#101111;
  --night-2:#171818;
  --d-line:rgba(255,255,255,.13);
  --d-muted:#a9a7a3;

  /* tunable via Tweaks */
  --accent:var(--red);
  --accent-bright:var(--red-bright);

  --font-display:'aktiv-grotesk-thin',-apple-system,system-ui,sans-serif;
  --font-body:'aktiv-grotesk',-apple-system,system-ui,sans-serif;

  --maxw:1400px;
  --gut:clamp(20px,5vw,72px);

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.04;margin:0;letter-spacing:-.015em;}
p{margin:0;text-wrap:pretty;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut);}
.section{padding-block:clamp(72px,10vw,140px);position:relative;}
.section--alt{background:var(--paper-2);}
.section--ink{background:var(--night);color:#fff;}

/* ---------- shared bits ---------- */
.eyebrow{
  font-family:var(--font-body);
  font-weight:500;
  font-size:18px;
  letter-spacing:4px;
  line-height:.95;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;align-items:center;gap:20px;
  margin:0 0 22px;
}
.eyebrow::before{content:"";width:44px;height:44px;background:url("assets/wand-icon.svg") center/contain no-repeat;display:inline-block;}
.eyebrow--center{justify-content:center;}

.section-head{max-width:760px;}
.section-head h2{
  font-size:clamp(32px,4.6vw,58px);
  letter-spacing:-.02em;
}
.section-head p{margin-top:22px;color:var(--muted);font-size:clamp(17px,1.4vw,20px);max-width:62ch;}
.section--ink .section-head p{color:var(--d-muted);}
/* eyebrow must keep its own token styling even inside a section-head */
.section-head .eyebrow{color:var(--accent);font-size:18px;margin-top:0;}
.section--ink .section-head .eyebrow{color:var(--accent);}

/* buttons */
.btn{
  --bg:var(--green);
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-display);font-weight:600;
  font-size:15px;letter-spacing:.02em;
  padding:17px 30px;border:none;border-radius:0;
  background:var(--bg);color:#fff;cursor:pointer;
  position:relative;overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.btn .arr{transition:transform .4s var(--ease);}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 34px -14px rgba(60,201,148,.6);}
.btn:hover .arr{transform:translateX(5px);}
.btn--ghost{
  background:transparent;color:inherit;
  box-shadow:inset 0 0 0 1.5px currentColor;
}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.5px var(--green);color:var(--green);}
.section--ink .btn--ghost:hover{color:#fff;box-shadow:inset 0 0 0 1.5px #fff;}

/* filigree / blueprint marks ---------------------------------- */
.bp-cross{
  position:absolute;width:18px;height:18px;pointer-events:none;
  opacity:var(--motif,1);
}
.bp-cross::before,.bp-cross::after{content:"";position:absolute;background:currentColor;}
.bp-cross::before{left:50%;top:0;width:1px;height:100%;transform:translateX(-.5px);}
.bp-cross::after{top:50%;left:0;height:1px;width:100%;transform:translateY(-.5px);}

.hairline{height:1px;background:var(--line);border:none;margin:0;}
.section--ink .hairline{background:var(--d-line);}

/* reveal animation */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
[data-reveal].in{opacity:1;transform:none;}
[data-reveal-d="1"]{transition-delay:.08s;}
[data-reveal-d="2"]{transition-delay:.16s;}
[data-reveal-d="3"]{transition-delay:.24s;}
[data-reveal-d="4"]{transition-delay:.32s;}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none;}}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:60;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
  padding-block:22px;
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.site-header.scrolled{background:rgba(16,17,17,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--d-line);padding-block:13px;}

.brand{display:flex;align-items:center;gap:14px;color:#fff;flex:none;}
.brand__mark{width:46px;height:auto;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4));}
.brand__txt{display:flex;flex-direction:column;line-height:1;width:max-content;}
.brand__name{font-family:var(--font-display);font-weight:300;font-size:21px;letter-spacing:.14em;text-transform:uppercase;}
.brand__name b{font-weight:600;}
.brand__rule{height:2px;width:100%;background:var(--accent);margin:5px 0 4px;}
.brand__sub{font-size:8.5px;letter-spacing:.155em;text-transform:uppercase;color:var(--d-muted);white-space:nowrap;}

.nav{display:flex;align-items:center;gap:34px;}
.nav a{font-family:var(--font-display);font-weight:500;font-size:15px;color:rgba(255,255,255,.82);letter-spacing:.01em;position:relative;padding:6px 0;}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--green);transition:width .35s var(--ease);}
.nav a:hover{color:#fff;}
.nav a:hover::after{width:100%;}
/* 01·Entwurf only: menu text turns green on hover */
body:not(.v2) .nav a:not(.btn):hover{color:var(--green);}
body:not(.v2)[data-hero="light"] .site-header:not(.scrolled) .nav a:not(.btn):hover{color:var(--green);}
.nav .btn{padding:12px 22px;}
.btn--phone{font-size:14px;letter-spacing:.01em;}
.btn--phone svg{flex:none;}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;}
.burger span{width:26px;height:2px;background:#fff;transition:.3s var(--ease);}

/* mobile nav */
.mnav{position:fixed;inset:0;z-index:55;background:var(--night);transform:translateY(-100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;justify-content:center;padding:var(--gut);gap:8px;}
.mnav.open{transform:none;}
.mnav a{font-family:var(--font-display);font-weight:600;font-size:30px;color:#fff;padding:14px 0;border-bottom:1px solid var(--d-line);}
.mnav a span{color:var(--accent);font-size:15px;margin-right:14px;}

/* ============================================================
   HERO  (default = cinematic dark)
   ============================================================ */
.hero{position:relative;background:var(--night);color:#fff;overflow:hidden;isolation:isolate;}
.hero__grid{position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(var(--d-line) 1px,transparent 1px),linear-gradient(90deg,var(--d-line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(120% 90% at 75% 25%,#000 0%,transparent 72%);
          mask-image:radial-gradient(120% 90% at 75% 25%,#000 0%,transparent 72%);
  opacity:calc(.5 * var(--motif,1));
}
.hero__sketch{
  position:absolute;z-index:1;pointer-events:none;
  right:-4%;top:50%;transform:translateY(-46%);
  width:min(60vw,860px);
  opacity:.9;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 22%);
          mask-image:linear-gradient(90deg,transparent,#000 22%);
  filter:drop-shadow(0 30px 60px rgba(0,0,0,.5));
}
.hero__glow{position:absolute;z-index:0;width:60vw;height:60vw;right:-10%;top:-10%;
  background:radial-gradient(circle,rgba(255,255,255,1),transparent 48%);pointer-events:none;}

.hero__inner{position:relative;z-index:2;
  min-height:100svh;display:flex;flex-direction:column;justify-content:center;
  padding-top:140px;padding-bottom:60px;
}
.hero__loc{font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:#fff;display:flex;align-items:center;gap:13px;margin-bottom:26px;}
.hero__loc::before{content:"";width:22px;height:22px;flex:none;background:url("assets/wand-icon.svg") center/contain no-repeat;}
.hero__loc i{width:7px;height:7px;background:var(--green);border-radius:50%;display:inline-block;box-shadow:0 0 0 4px rgba(60,201,148,.25);}
.hero h1{
  font-size:clamp(42px,7.4vw,108px);
  font-weight:600;letter-spacing:-.03em;line-height:.98;
  max-width:15ch;
}
.hero h1 em{font-style:normal;color:var(--accent);}
.hero__sub{margin-top:30px;max-width:54ch;font-size:clamp(17px,1.55vw,22px);color:var(--d-muted);}
.hero__sub b{color:#fff;font-weight:600;}
.hero__cta{margin-top:42px;display:flex;flex-wrap:wrap;gap:16px;}

.hero__trust{margin-top:58px;display:flex;flex-wrap:wrap;gap:0;border-top:1px solid var(--d-line);max-width:780px;}
.hero__trust div{padding:22px 34px 0 0;margin-right:34px;}
.hero__trust .n{font-family:var(--font-display);font-weight:600;font-size:30px;color:#fff;line-height:1;}
.hero__trust .l{font-size:13.5px;color:var(--d-muted);margin-top:8px;letter-spacing:.02em;}
.hero__trust .n em{color:var(--accent);font-style:normal;}

.scroll-cue{position:absolute;bottom:26px;left:var(--gut);z-index:3;display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--d-muted);}
.scroll-cue i{width:1px;height:42px;background:linear-gradient(var(--green),transparent);display:block;animation:cue 2.2s var(--ease) infinite;transform-origin:top;}
@keyframes cue{0%{transform:scaleY(0);}40%{transform:scaleY(1);}100%{transform:scaleY(0);transform-origin:bottom;}}

/* ---- Hero variant B : EDITORIAL SPLIT ---- */
body[data-hero="split"] .hero__inner{display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:0;min-height:100svh;padding-bottom:60px;}
body[data-hero="split"] .hero__grid{-webkit-mask-image:none;mask-image:none;opacity:calc(.35*var(--motif,1));}
body[data-hero="split"] .hero__sketch{position:relative;right:auto;top:auto;transform:none;width:115%;margin-left:-6%;-webkit-mask-image:none;mask-image:none;justify-self:end;order:2;}
body[data-hero="split"] .hero__col{order:1;padding-right:5%;}
body[data-hero="split"] .hero__glow{right:30%;}
body[data-hero="split"] .hero h1{font-size:clamp(40px,5.4vw,80px);}

/* ---- Hero variant C : BLUEPRINT LIGHT ---- */
body[data-hero="light"] .hero{background:var(--paper);color:var(--ink);}
body[data-hero="light"] .hero__grid{
  background-image:linear-gradient(rgba(22,23,23,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(22,23,23,.07) 1px,transparent 1px);
  -webkit-mask-image:radial-gradient(120% 90% at 78% 30%,#000,transparent 72%);
          mask-image:radial-gradient(120% 90% at 78% 30%,#000,transparent 72%);
}
body[data-hero="light"] .hero__glow{background:radial-gradient(circle,rgba(255,255,255,1),transparent 48%);}
body[data-hero="light"] .hero__sub{color:var(--muted);}
body[data-hero="light"] .hero__sub b{color:var(--ink);}
body[data-hero="light"] .hero__loc{color:var(--ink);}
body[data-hero="light"] .hero__trust{border-top-color:var(--line);}
body[data-hero="light"] .hero__trust .n{color:var(--ink);}
body[data-hero="light"] .hero__trust .l{color:var(--muted);}
body[data-hero="light"] .scroll-cue{color:var(--muted);}
/* light hero uses dark-line sketch (swapped in JS) */

/* brand mark toggle + light-mode header (Entwurf 01 default = Blueprint hell) */
.brand__mark--dark{display:none;}
body[data-hero="light"] .site-header:not(.scrolled) .brand__mark--white{display:none;}
body[data-hero="light"] .site-header:not(.scrolled) .brand__mark--dark{display:block;}
body[data-hero="light"] .site-header:not(.scrolled) .brand{color:var(--ink);}
body[data-hero="light"] .site-header:not(.scrolled) .brand__sub{color:var(--muted);}
body[data-hero="light"] .site-header:not(.scrolled) .nav a{color:var(--ink-soft);}
body[data-hero="light"] .site-header:not(.scrolled) .nav a:hover{color:var(--accent);}
body[data-hero="light"] .site-header:not(.scrolled) .burger span{background:var(--ink);}
body[data-hero="light"] .bp-cross{color:rgba(22,23,23,.22)!important;}

/* ============================================================
   INTRO STRIP  (Holz spotlight)
   ============================================================ */
.intro{background:var(--paper);}
.intro .wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,7vw,110px);align-items:center;}
.intro__lead{font-family:var(--font-display);font-weight:500;font-size:clamp(24px,2.7vw,38px);line-height:1.22;letter-spacing:-.02em;}
.intro__lead em{font-style:normal;color:var(--accent);}
.intro__body p+p{margin-top:18px;}
.intro__body{color:var(--muted);font-size:17.5px;}
.tag{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:600;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:20px;}
.tag::before{content:"";width:21.6px;height:21.6px;background:url("assets/wand-icon.svg") center/contain no-repeat;display:inline-block;}

/* ============================================================
   LEISTUNGEN
   ============================================================ */
.serv-top{display:flex;flex-direction:column;align-items:flex-start;gap:18px;margin-bottom:56px;}
.serv-top>p.section-head{max-width:60ch;}
.serv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.scard{
  background:var(--paper);padding:42px 36px 46px;position:relative;
  transition:background .4s var(--ease),color .4s var(--ease),transform .4s var(--ease);
  min-height:300px;display:flex;flex-direction:column;
}
.scard__no{font-family:var(--font-display);font-weight:600;font-size:14px;letter-spacing:.1em;color:var(--red);}
.scard__ic{margin:26px 0 22px;color:var(--red);}
.scard h3{font-size:24px;letter-spacing:-.01em;}
.scard p{margin-top:14px;color:var(--muted);font-size:16px;flex:1;}
.scard__more{margin-top:22px;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--green);display:inline-flex;align-items:center;gap:9px;opacity:0;transform:translateY(6px);transition:.4s var(--ease);}
.scard::before{content:"";position:absolute;left:0;top:0;width:0;height:3px;background:var(--green);transition:width .45s var(--ease);}
.scard:hover{transform:translateY(-4px);z-index:2;box-shadow:0 30px 60px -34px rgba(22,23,23,.4);}
.scard:hover::before{width:100%;}
.scard:hover .scard__ic{color:var(--green);}
.scard:hover .scard__more{opacity:1;transform:none;}
.scard--accent{background:var(--steel);color:#fff;}
.scard--accent .scard__no{color:var(--red);}
.scard--accent .scard__ic{color:var(--red);}
.scard--accent p{color:var(--d-muted);}
.scard--accent .scard__more{opacity:1;color:#fff;}

.ic{width:40px;height:40px;stroke:currentColor;fill:none;stroke-width:1.4;}

/* ============================================================
   ZIELGRUPPEN
   ============================================================ */
.aud-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:54px;}
.acard{background:#171818;border:1px solid var(--d-line);padding:32px 26px;position:relative;transition:.4s var(--ease);}
.acard .num{font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--accent);letter-spacing:.12em;}
.acard h3{font-size:21px;margin-top:18px;color:#fff;}
.acard p{margin-top:12px;font-size:15px;color:var(--d-muted);}
.acard:hover{background:var(--night-2);border-color:rgba(255,255,255,.28);transform:translateY(-4px);}

/* ============================================================
   HOLZ SPEZIALGEBIET
   ============================================================ */
.holz{background:var(--paper);}
.holz .wrap{display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(40px,6vw,90px);align-items:start;}
.holz__intro{position:sticky;top:120px;}
.holz__lead{color:var(--muted);margin-top:22px;max-width:42ch;}
.holz__note{margin-top:24px;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.04em;color:var(--muted-2);max-width:38ch;}
.mlist{display:flex;flex-direction:column;}
.mitem{display:grid;grid-template-columns:auto 1fr;gap:22px;padding:26px 0;border-top:1px solid var(--line);}
.mitem:last-child{border-bottom:1px solid var(--line);}
.mitem__mark{width:18px;height:18px;flex:none;margin-top:1px;background:url("assets/wand-icon.svg") center/contain no-repeat;}
.mitem h3{font-size:20px;letter-spacing:-.01em;}
.mitem p{margin-top:8px;color:var(--muted);font-size:16px;}
@media (max-width:900px){
  .holz .wrap{grid-template-columns:1fr;gap:40px;}
  .holz__intro{position:static;}
}

/* ============================================================
   PROFIL
   ============================================================ */
.profile .wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(40px,6vw,90px);align-items:start;}
.profile__media{position:relative;}
.ph{position:relative;background:
   repeating-linear-gradient(135deg,var(--paper-3) 0 10px,var(--paper-2) 10px 20px);
   border:1px solid var(--line);display:flex;align-items:flex-end;overflow:hidden;}
.ph__label{font-family:'Saira',monospace;font-size:11.5px;letter-spacing:.06em;color:var(--muted);background:rgba(255,255,255,.86);padding:9px 13px;margin:14px;border:1px solid var(--line);}
.ph__label b{color:var(--accent);font-weight:600;}
.profile__media .ph{aspect-ratio:4/5;}
.ph--photo{background:var(--night);}
.ph--photo img{width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block;}
.ph--photo::after{content:"";position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);background:linear-gradient(180deg,transparent 55%,rgba(16,17,17,.28));}
.profile__media .badge{position:absolute;right:-14px;bottom:34px;background:var(--accent);color:#fff;padding:18px 22px;max-width:200px;box-shadow:0 24px 50px -22px rgba(201,60,60,.6);}
.profile__media .badge .b1{font-family:var(--font-display);font-weight:600;font-size:34px;line-height:1;}
.profile__media .badge .b2{font-size:13px;margin-top:6px;line-height:1.3;}

.timeline{margin-top:42px;border-left:1.5px solid var(--line);padding-left:0;list-style:none;}
.tl{position:relative;padding:0 0 30px 34px;}
.tl::before{content:"";position:absolute;left:-10px;top:2px;width:18px;height:18px;background:var(--paper) url("assets/wand-icon.svg") center/contain no-repeat;padding:1px 0;}
.tl:last-child{padding-bottom:0;}
.tl .yr{font-family:var(--font-display);font-weight:600;font-size:14px;letter-spacing:.06em;color:var(--accent);}
.tl h4{font-size:19px;margin-top:5px;font-weight:600;}
.tl p{color:var(--muted);font-size:15.5px;margin-top:5px;}

.quals{margin-top:30px;display:grid;grid-template-columns:1fr 1fr;gap:14px 30px;}
.quals li{list-style:none;display:flex;gap:12px;align-items:flex-start;font-size:15.5px;color:var(--ink-soft);}
.quals li::before{content:"";width:7px;height:7px;background:var(--accent);margin-top:9px;flex:none;}
.quals{padding:0;}

/* ============================================================
   ABLAUF
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--d-line);border:1px solid var(--d-line);margin-top:56px;}
.step{background:var(--night);padding:40px 32px 46px;position:relative;}
.step .no{font-family:var(--font-display);font-weight:600;font-size:60px;color:#BABABA;line-height:.8;letter-spacing:-.03em;}
.step h3{color:#fff;font-size:23px;margin-top:18px;}
.step p{color:var(--d-muted);font-size:15.5px;margin-top:14px;}
.step .tick{position:absolute;top:46px;right:38px;color:var(--accent);}

/* ============================================================
   ZERTIFIKATE
   ============================================================ */
.cert-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:54px;}
.cert{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:start;border:1px solid var(--line);background:var(--paper);padding:34px 36px;transition:.4s var(--ease);}
.cert:hover{box-shadow:0 26px 54px -32px rgba(22,23,23,.45);transform:translateY(-3px);}
.cert__seal{width:70px;height:70px;border:1.5px solid var(--green);border-radius:50%;display:grid;place-items:center;color:var(--green);position:relative;flex:none;}
.cert__seal::after{content:"";position:absolute;inset:6px;border:1px dashed rgba(60,201,148,.45);border-radius:50%;}
.cert .kr{font-family:var(--font-display);font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);}
.cert h3{font-size:21px;margin-top:9px;letter-spacing:-.01em;}
.cert p{margin-top:11px;color:var(--muted);font-size:15px;}

/* ============================================================
   KONTAKT
   ============================================================ */
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start;}
.contact .section-head h2{color:#fff;}
.contact-list{margin-top:40px;display:flex;flex-direction:column;gap:2px;}
.cl{display:flex;gap:20px;align-items:flex-start;padding:24px 0;border-top:1px solid var(--d-line);}
.cl:last-child{border-bottom:1px solid var(--d-line);}
.cl .ic-wrap{color:var(--green);margin-top:2px;}
.cl .k{font-family:var(--font-display);font-weight:600;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--d-muted);}
.cl .v{font-size:19px;color:#fff;margin-top:5px;}
.cl a.v:hover{color:var(--green) !important;}

.form{background:#fff;color:var(--ink);padding:clamp(30px,4vw,50px);}
.form h3{font-size:24px;}
.form p.sub{color:var(--muted);margin-top:8px;font-size:15.5px;}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:28px;}
.field{display:flex;flex-direction:column;gap:8px;}
.field.full{grid-column:1/-1;}
.field label{font-family:var(--font-display);font-weight:600;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}
.field input,.field textarea{font-family:var(--font-body);font-size:16px;padding:14px 16px;border:1px solid var(--line);background:var(--paper-2);color:var(--ink);border-radius:0;transition:.3s var(--ease);}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(201,60,60,.12);}
.field textarea{resize:vertical;min-height:120px;}
.form .btn{margin-top:24px;width:100%;justify-content:center;}
.form .note{margin-top:16px;font-size:12.5px;color:var(--muted-2);text-align:center;}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#0a0b0b;color:#fff;padding-block:70px 36px;}
.footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;align-items:start;}
.footer__logo img{width:200px;margin-bottom:22px;}
.footer__logo p{color:var(--d-muted);font-size:15px;max-width:34ch;}
.fcol h4{font-family:var(--font-display);font-weight:600;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--d-muted);margin-bottom:20px;}
.fcol a,.fcol p{display:block;color:rgba(255,255,255,.82);font-size:15.5px;padding:7px 0;}
.fcol a:hover{color:var(--green);}
.footer .bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-top:54px;padding-top:26px;border-top:1px solid var(--d-line);color:var(--muted-2);font-size:13.5px;}
.footer .bottom a:hover{color:#fff;}

/* ============================================================
   DRAFT SWITCHER (compares Entwurf 01 / 02 / 03)
   ============================================================ */
.draft-switch{
  position:fixed;z-index:70;left:50%;bottom:18px;transform:translateX(-50%);
  display:flex;align-items:center;gap:4px;
  background:rgba(16,17,17,.9);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.14);
  padding:6px 6px 6px 16px;border-radius:100px;
  box-shadow:0 18px 50px -18px rgba(0,0,0,.6);
  font-family:var(--font-display,'Saira',sans-serif);
}
.draft-switch__lbl{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:#7e7d7a;margin-right:8px;}
.draft-switch a{
  font-size:12.5px;font-weight:600;letter-spacing:.02em;color:rgba(255,255,255,.7);
  padding:8px 14px;border-radius:100px;transition:.25s var(--ease,ease);white-space:nowrap;
}
.draft-switch a:hover{color:#fff;background:rgba(255,255,255,.08);}
.draft-switch a.is-active{background:var(--red,#c93c3c);color:#fff;}
@media (max-width:600px){
  .draft-switch{gap:2px;padding:5px 5px 5px 12px;}
  .draft-switch__lbl{display:none;}
  .draft-switch a{font-size:11px;padding:7px 10px;}
}
@media print{.draft-switch{display:none;}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .serv-grid{grid-template-columns:repeat(2,1fr);}
  .aud-grid{grid-template-columns:repeat(2,1fr);}
  .steps{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:1060px){
  .nav{display:none;}
  .burger{display:flex;}
}
@media (max-width:900px){
  .intro .wrap,.profile .wrap,.contact .wrap{grid-template-columns:1fr;}
  .cert-grid{grid-template-columns:1fr;}
  body[data-hero="split"] .hero__inner{grid-template-columns:1fr;}
  body[data-hero="split"] .hero__sketch{display:none;}
  .profile__media{max-width:440px;}
}
@media (max-width:680px){
  body{font-size:17px;}
  .serv-grid{grid-template-columns:1fr;}
  .aud-grid{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .quals{grid-template-columns:1fr;}
  .fgrid{grid-template-columns:1fr;}
  .hero__sketch{opacity:.35;width:115vw;right:-30%;}
  .hero__trust div{padding-right:24px;margin-right:24px;}
  .footer .top{grid-template-columns:1fr;gap:36px;}
}

/* ============================================================
   MOBILE HARDENING (<=760px)
   Tame fixed pixel widths left by direct edits so nothing
   overflows the viewport on phones. Inline styles → !important.
   ============================================================ */
@media (max-width:760px){
  html,body{overflow-x:hidden;}

  h1,h2,h3,h4,.intro__lead,.cert h3,.mitem h3,.hero__sub{
    overflow-wrap:break-word;word-break:normal;hyphens:auto;
  }

  /* hero headline + sub had hardcoded width:700px / 600px */
  .hero h1{width:auto!important;max-width:100%!important;
    font-size:clamp(34px,8.6vw,46px)!important;line-height:1.08!important;}
  .hero__sub{width:auto!important;max-width:100%!important;font-size:17px!important;}
  .hero__loc{margin-left:0!important;}

  /* stack hero: image ON TOP, text below */
  .hero__inner{min-height:0!important;padding-top:20px!important;padding-bottom:48px!important;}
  .hero__grid{opacity:.18!important;}
  .hero__sketch{
    position:relative!important;right:auto!important;top:auto!important;
    transform:none!important;opacity:1!important;
    width:auto!important;max-width:80%!important;height:auto!important;
    margin:104px auto 8px!important;display:block!important;
    -webkit-mask-image:none!important;mask-image:none!important;
    filter:drop-shadow(0 16px 38px rgba(0,0,0,.16))!important;
  }
  .scroll-cue{display:none!important;}

  /* header brand: relax fixed name/sub/rule/mark sizes so it stays one tidy row */
  .brand{align-items:center!important;gap:11px!important;}
  .brand__mark{width:auto!important;height:46px!important;}
  .brand__txt{width:max-content!important;}
  .brand__name{width:auto!important;height:auto!important;
    font-size:21px!important;line-height:1.05!important;white-space:nowrap!important;}
  .brand__rule{width:100%!important;}
  .brand__sub{width:auto!important;height:auto!important;
    font-size:10px!important;white-space:nowrap!important;}

  /* certificate cards: stack seal over text, allow text to shrink */
  .cert{grid-template-columns:1fr!important;gap:16px!important;padding:26px 24px!important;min-width:0;}
  .cert>*{min-width:0;}
  .cert__seal{width:56px;height:56px;}
}
