/* =================================================================
   Strempel Fahrzeugbau · Stylesheet
   Industrial-friendly · keine Verläufe · größere Typo · Mega Menu
================================================================= */

:root{
  /* Farben. Flach, freundlich, kein Verlauf */
  --paper:        #FAF8F3;
  --paper-2:      #F1ECE2;
  --paper-3:      #E8E1D2;
  --ink:          #1A2236;
  --ink-2:        #2A3450;
  --ink-soft:     #3D4A6B;

  --brand:        #1B3A5C;
  --brand-soft:   #E4EAF1;
  --brand-deep:   #0F2240;

  --spark:        #E85A1A;
  --spark-soft:   #FCEEE3;
  --spark-deep:   #B33F0A;
  --spark-2:      #FF8050;  /* lighter spark, used in some kickers */

  --steel-light:  #DCDFE6;
  --steel:        #8993A8;
  --steel-dark:   #4A5572;

  --rule-light:   #DDD6C7;
  --rule-dark:    rgba(255,255,255,.18);

  --font-display: "Saira Condensed", "Arial Narrow", system-ui, sans-serif;
  --font-body:    "IBM Plex Sans", system-ui, -apple-system, sans-serif;
  --font-mono:    "IBM Plex Mono", ui-monospace, monospace;

  --gutter:       clamp(1.5rem, 4vw, 4.5rem);
  --section-y:    clamp(5rem, 9vw, 8.5rem);
}

*,*::before,*::after{box-sizing:border-box}
html{overflow-x:clip;scroll-behavior:smooth;font-size:17px}
body{margin:0;font-family:var(--font-body);font-size:1rem;line-height:1.7;color:var(--ink);background:var(--paper);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;overflow-x:clip;max-width:100vw}
img,svg{max-width:100%;display:block}
a{color:var(--brand);text-decoration:none;transition:color .15s ease}
a:hover{color:var(--brand-deep)}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.05;letter-spacing:-.005em;margin:0;text-transform:uppercase;overflow-wrap:normal;hyphens:none;color:var(--ink)}
h1{font-size:clamp(2.6rem,6.4vw,5.4rem);font-weight:800}
h2,.h2{font-size:clamp(2rem,4.4vw,3.6rem);font-weight:800}
h3{font-size:clamp(1.4rem,2.4vw,2rem)}
h4{font-size:clamp(1.05rem,1.5vw,1.25rem);letter-spacing:.01em}
p{margin:0 0 1rem}

.wrap{max-width:1280px;margin:0 auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-y);position:relative}
.section--tight{padding-block:clamp(2rem,4vw,3rem)}

.eyebrow,.kicker{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brand);font-weight:500}
.eyebrow.on-light{color:var(--brand)}
.eyebrow.on-dark{color:var(--spark)}
.lede{font-size:clamp(1.1rem,1.4vw,1.25rem);line-height:1.55;color:var(--steel-dark);font-weight:400;max-width:60ch}
.lede.on-dark{color:#D8DDE8}
.divider{display:block;width:54px;height:3px;background:var(--brand);margin:1.5rem 0}
.divider.spark{background:var(--spark)}
.accent{color:var(--spark)}

.btn{display:inline-flex;align-items:center;gap:.55rem;padding:1rem 1.5rem;font-family:var(--font-display);font-weight:700;font-size:1rem;text-transform:uppercase;letter-spacing:.06em;border:0;cursor:pointer;transition:background .18s ease,color .18s ease,transform .18s ease;text-decoration:none;line-height:1;border-radius:7px}
.btn--primary{background:var(--brand);color:#fff}
.btn--primary:hover{background:var(--brand-deep);color:#fff;transform:translateY(-1px)}
.btn--spark{background:var(--spark);color:#fff}
.btn--spark:hover{background:var(--spark-deep);color:#fff;transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn--ghost:hover{background:var(--ink);color:#fff}
.btn--ghost-light{background:transparent;color:#fff;border:1.5px solid #fff}
.btn--ghost-light:hover{background:#fff;color:var(--ink)}
.btn .arrow{transition:transform .18s ease}
.btn:hover .arrow{transform:translateX(3px)}

.tag-pill{display:inline-flex;align-items:center;padding:.5rem 1rem;font-family:var(--font-mono);font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);background:var(--paper-2);border:1px solid var(--rule-light);transition:background .15s ease,color .15s ease;border-radius:7px}
.tag-pill:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ------------ Floating tool icons ------------ */
.tool-float{position:absolute;display:block;pointer-events:none;color:var(--ink);opacity:.06;z-index:0}
.tool-float svg{display:block;width:100%;height:100%;fill:currentColor}
.tool-float--lg{width:160px;height:160px}
.tool-float--md{width:96px;height:96px}
.tool-float--sm{width:60px;height:60px}
.tool-float--brand{color:var(--brand);opacity:.07}
.tool-float--spark{color:var(--spark);opacity:.10}
.tool-float--on-dark{color:#fff;opacity:.05}
.tool-float--on-paper{color:var(--ink);opacity:.05}
@media (prefers-reduced-motion:no-preference){
  .tool-float--drift{animation:drift 14s ease-in-out infinite}
  .tool-float--drift-slow{animation:drift 22s ease-in-out infinite}
  @keyframes drift{
    0%,100%{transform:translateY(0) rotate(var(--rot,0deg))}
    50%{transform:translateY(-12px) rotate(calc(var(--rot,0deg) + 3deg))}
  }
}

/* ------------ Header ------------ */
.site-header{background:var(--ink);color:#fff;position:sticky;top:0;z-index:100;border-bottom:1px solid var(--rule-dark)}
.site-header__util{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;background:var(--ink-2);border-bottom:1px solid var(--rule-dark)}
.site-header__util .wrap{display:flex;justify-content:space-between;align-items:center;height:36px;color:#C7CCD8}
.site-header__util a{color:#C7CCD8}
.site-header__util a:hover{color:#fff}
.util-list{display:flex;gap:1.5rem;align-items:center}
.util-list a{display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap}
.util-meta{color:var(--spark)}

.site-header__bar{display:flex;justify-content:space-between;align-items:center;padding-block:1.1rem;gap:2rem}
.site-header__brand{display:flex;align-items:center;gap:.9rem;color:#fff;text-decoration:none;flex-shrink:0}
.site-header__brand img{height:40px;width:auto;flex-shrink:0}
.site-header__brand .word{font-family:var(--font-display);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;line-height:1.25;color:#fff;display:flex;flex-direction:column;white-space:nowrap}
.site-header__brand .word small{color:var(--spark);font-size:.62rem;letter-spacing:.18em;font-weight:500;font-family:var(--font-mono)}
@media (max-width:520px){.site-header__brand .word{display:none}}

.nav{display:flex;align-items:center;gap:.1rem}
.nav__group{position:relative}
.nav__link{font-family:var(--font-display);font-weight:600;font-size:1.05rem;text-transform:uppercase;letter-spacing:.05em;padding:.7rem 1rem;color:#E2E5EC;display:inline-flex;align-items:center;gap:.35rem;white-space:nowrap;position:relative;transition:color .12s ease;cursor:pointer;background:transparent;border:0}
.nav__link:hover,.nav__link[aria-current="page"]{color:#fff}
.nav__link[aria-current="page"]::after{content:"";position:absolute;left:1rem;right:1rem;bottom:.4rem;height:2px;background:var(--spark)}
.nav__chev{width:8px;height:8px;display:inline-block;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);transform-origin:center;transition:transform .15s ease;margin-left:.2rem;margin-bottom:3px}
.nav__group:hover .nav__chev,
.nav__group:focus-within .nav__chev,
.nav__link[aria-expanded="true"] .nav__chev{transform:rotate(-135deg);margin-bottom:-1px}

.nav-cta{margin-left:.6rem;background:var(--spark);color:#fff !important;padding:.85rem 1.2rem;font-family:var(--font-display);font-weight:700;font-size:1rem;text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:.5rem;transition:background .15s ease;border-radius:7px}
.nav-cta:hover{background:var(--spark-deep)}

/* ------------ MEGA MENU ------------ */
.megamenu{display:none;position:absolute;top:calc(100% + 1px);left:50%;transform:translateX(-50%) translateY(-8px);width:min(1100px,calc(100vw - 2rem));background:var(--paper);color:var(--ink);box-shadow:0 24px 48px -12px rgba(20,30,60,.18),0 2px 6px rgba(20,30,60,.06);border-top:3px solid var(--spark);padding:0;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,transform .2s ease,visibility .2s;z-index:99}
.nav__group:hover .megamenu,
.nav__group:focus-within .megamenu,
.nav__group[data-open="true"] .megamenu{display:block;opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.megamenu__inner{display:grid;grid-template-columns:1fr 1fr 1fr 1.1fr;gap:0;padding:2.4rem 2.4rem 2rem}
.megamenu__col{padding:0 1.4rem;border-right:1px solid var(--rule-light)}
.megamenu__col:first-child{padding-left:0}
.megamenu__col:last-child{padding-right:0;border-right:0;background:var(--paper-2);margin:-2.4rem -2.4rem -2rem 0;padding:2.4rem 2.4rem 2rem 1.6rem;display:flex;flex-direction:column;justify-content:center;gap:.5rem}
.megamenu__col h5{font-family:var(--font-mono);font-size:.74rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--brand);margin:0 0 1rem;padding-bottom:.6rem;border-bottom:1px solid var(--rule-light)}
.megamenu__item{display:flex;flex-direction:column;gap:.18rem;padding:.7rem 0;color:var(--ink);text-decoration:none;transition:padding .15s ease}
.megamenu__item strong{font-family:var(--font-display);font-weight:700;font-size:1.05rem;text-transform:uppercase;letter-spacing:.02em;color:var(--ink);display:flex;align-items:center;gap:.55rem;transition:color .15s ease}
.megamenu__item span{font-size:.88rem;color:var(--steel-dark);line-height:1.45}
.megamenu__item:hover{padding-left:.4rem}
.megamenu__item:hover strong{color:var(--brand)}
.megamenu__icon{width:18px;height:18px;color:var(--brand);flex-shrink:0;fill:currentColor}
.megamenu__col--cta h4{margin:.4rem 0 .6rem;font-size:1.4rem}
.megamenu__col--cta p{font-size:.9rem;color:var(--steel-dark);margin:0 0 .8rem}
.megamenu__col--cta .btn{align-self:flex-start;font-size:.85rem;padding:.7rem 1.1rem}

/* Hamburger (mobile) */
.nav-toggle{display:none;width:48px;height:48px;align-items:center;justify-content:center;border:1.5px solid var(--rule-dark);background:transparent;cursor:pointer}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:22px;height:2px;background:#fff;position:relative;transition:transform .18s ease,opacity .18s ease}
.nav-toggle span::before{position:absolute;top:-7px}
.nav-toggle span::after{position:absolute;top:7px}
.nav-toggle[aria-expanded="true"] span{background:transparent}
.nav-toggle[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}

@media (max-width:1080px){
  .nav-toggle{display:inline-flex}
  .nav{position:fixed;inset:0 0 0 auto;width:min(92vw,400px);background:var(--ink);flex-direction:column;align-items:stretch;gap:0;padding:5.5rem 1.5rem 2rem;transform:translateX(105%);visibility:hidden;transition:transform .3s ease,visibility .3s ease;border-left:1px solid var(--rule-dark);z-index:90;overflow-y:auto}
  .nav[data-open="true"]{transform:none;visibility:visible}
  .nav__link,.nav-cta{padding:1.1rem 0;border-bottom:1px solid var(--rule-dark);font-size:1.1rem}
  .nav__link[aria-current="page"]::after{display:none}
  .nav-cta{margin:1.2rem 0 0;justify-content:center;border-bottom:0;background:var(--spark)}
  .nav__group{position:static}
  .nav__link--has-mega{cursor:pointer;justify-content:space-between;width:100%}
  .megamenu{display:block;position:static;transform:none;width:100%;border-top:0;border-bottom:1px solid var(--rule-dark);box-shadow:none;background:var(--ink-2);max-height:0;overflow:hidden;opacity:1;visibility:hidden;pointer-events:none;transition:max-height .35s ease,visibility .35s}
  .nav__group[data-open="true"] .megamenu{display:block;max-height:1400px;visibility:visible;pointer-events:auto;transform:none}
  .megamenu__inner{display:flex;flex-direction:column;gap:1rem;padding:1rem 0}
  .megamenu__col{border-right:0;padding:0;border-bottom:1px solid var(--rule-dark);padding-bottom:1rem}
  .megamenu__col:last-child{margin:0;padding:1rem 0;background:transparent;border-bottom:0}
  .megamenu__col h5{color:var(--spark);border-bottom-color:var(--rule-dark)}
  .megamenu__item{color:#E2E5EC;padding:.5rem 0}
  .megamenu__item strong{color:#fff;font-size:1rem}
  .megamenu__item span{color:#B6BCC9;font-size:.82rem}
  .megamenu__col--cta h4{color:#fff}
  .megamenu__col--cta p{color:#B6BCC9}
  .megamenu__icon{color:var(--spark)}
  .site-header__util .util-meta{display:none}
  .site-header__util .util-list{gap:1rem;font-size:.7rem;overflow:hidden}
}

/* ------------ Hero ------------ */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden;isolation:isolate;border-bottom:5px solid var(--spark)}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;opacity:.32;filter:contrast(1.05)}
.hero__bg::after{content:"";position:absolute;inset:0;background:rgba(15,22,42,.62)}
.hero__grid,.hero__sidebar{display:none}
.hero > .wrap{position:relative;z-index:2;padding-block:clamp(5rem,11vw,9rem) clamp(4rem,8vw,7rem)}
.hero__meta{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--spark);margin-bottom:3rem;flex-wrap:wrap;gap:1rem}
.hero__title{max-width:18ch;font-size:clamp(2.8rem,7.2vw,6.2rem);color:#fff}
.hero__title .accent{color:var(--spark)}
.hero__sub{margin-top:2rem;color:#E8ECF3;font-size:clamp(1.1rem,1.4vw,1.25rem);max-width:54ch;line-height:1.65}
.hero__cta{margin-top:3rem;display:flex;gap:1rem;flex-wrap:wrap}
.hero__stats{margin-top:clamp(3.5rem,7vw,6rem);display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--rule-dark);padding-top:2.5rem}
.hero__stat{padding:0 1.4rem;border-right:1px solid var(--rule-dark)}
.hero__stat:first-child{padding-left:0}
.hero__stat:last-child{border-right:0}
.hero__stat .num{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,3.4vw,2.8rem);color:#fff;line-height:1;display:block}
.hero__stat .num .unit{color:var(--spark);font-size:.7em}
.hero__stat .lbl{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#A8B0C2;margin-top:.55rem;display:block}

@media (max-width:780px){.hero__stats{grid-template-columns:repeat(2,1fr);gap:1.5rem 0}.hero__stat{border-bottom:1px solid var(--rule-dark);padding:.8rem 1rem}.hero__stat:nth-child(2),.hero__stat:last-child{border-right:0}.hero__stat:nth-child(odd){padding-left:0}.hero__stat:nth-child(3),.hero__stat:nth-child(4){border-bottom:0;padding-bottom:0}}

/* ------------ Marquee ribbon ------------ */
.ribbon{background:var(--spark);color:#fff;border-block:1px solid rgba(0,0,0,.12);position:relative;height:3.6em;width:100%;overflow:hidden}
.ribbon__viewport{position:absolute;inset:0;overflow:hidden}
.ribbon__track{position:absolute;top:50%;left:0;transform:translate3d(0,-50%,0);display:flex;align-items:center;gap:3rem;font-family:var(--font-display);font-weight:700;font-size:1.05rem;text-transform:uppercase;letter-spacing:.12em;animation:marquee 38s linear infinite;white-space:nowrap;will-change:transform}
.ribbon__track span{display:inline-flex;align-items:center;gap:1.6rem}
.ribbon__track span::after{content:"●";color:rgba(255,255,255,.6);margin-left:1.6rem}
@keyframes marquee{from{transform:translate3d(0,-50%,0)}to{transform:translate3d(-50%,-50%,0)}}

/* ------------ Intro ------------ */
.intro{background:var(--paper);position:relative;overflow:hidden}
.intro__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:start;position:relative;z-index:1}
.intro__lead h2{margin-top:1rem}
.intro__copy{font-size:1.05rem;line-height:1.75;color:var(--steel-dark)}
.intro__copy p:first-child::first-letter{font-family:var(--font-display);font-weight:800;font-size:4.2rem;float:left;line-height:.85;padding:.2rem .8rem 0 0;color:var(--brand)}
.intro__quote{margin-top:1.6rem;padding:1.4rem 1.6rem;border-left:4px solid var(--spark);background:var(--paper-2);font-family:var(--font-display);font-weight:600;font-size:1.15rem;color:var(--ink);line-height:1.4}
.intro__sig{margin-top:1.4rem;padding-top:1.4rem;border-top:1px solid var(--rule-light)}
.intro__sig strong{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.04em;color:var(--ink);font-size:1rem}
.intro__sig span{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--steel)}
@media (max-width:880px){.intro__grid{grid-template-columns:1fr}}

/* ------------ Services grid (LIGHT theme) ------------ */
.services{background:var(--paper-2);position:relative;overflow:hidden;border-top:1px solid var(--rule-light);border-bottom:1px solid var(--rule-light)}
.services__head{display:grid;grid-template-columns:1.4fr 1fr;gap:2.5rem;align-items:end;margin-bottom:clamp(3rem,5vw,4.5rem);position:relative;z-index:1}
.services__head .lede{justify-self:end;text-align:right}
@media (max-width:760px){.services__head{grid-template-columns:1fr}.services__head .lede{justify-self:start;text-align:left}}
.services__grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1px;background:var(--rule-light);border:1px solid var(--rule-light);position:relative;z-index:1}

.svc{background:var(--paper);padding:2.4rem 2rem;display:flex;flex-direction:column;gap:1.2rem;position:relative;overflow:hidden;transition:background .25s ease;min-height:340px;color:var(--ink)}
.svc--span6{grid-column:span 6}
.svc--span4{grid-column:span 4}
.svc:hover{background:#fff}
.svc__num{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brand);display:flex;align-items:center;gap:.6rem}
.svc__num .id{color:var(--spark);font-weight:600}
.svc__num .id::after{content:"/";margin-left:.6rem;color:var(--rule-light)}
.svc__title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.4rem,2vw,1.8rem);text-transform:uppercase;letter-spacing:.005em;color:var(--ink);margin:0;line-height:1.05}
.svc__copy{color:var(--steel-dark);line-height:1.55;flex-grow:1;font-size:.98rem}
.svc__cta{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--brand);font-size:.92rem;margin-top:auto;padding-top:.8rem;border-top:1px solid var(--rule-light);justify-content:space-between}
.svc__cta .arrow{transition:transform .18s ease}
.svc:hover .svc__cta .arrow{transform:translateX(4px)}
.svc__media{margin:-2.4rem -2rem 0;height:200px;overflow:hidden;position:relative;border-bottom:1px solid var(--rule-light)}
.svc__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.svc:hover .svc__media img{transform:scale(1.04)}

@media (max-width:1024px){.svc--span6,.svc--span4{grid-column:span 12}}
@media (max-width:640px){.svc--span6,.svc--span4{grid-column:span 12}}

/* ------------ Feature ------------ */
.feature{background:var(--paper);position:relative;overflow:hidden}
.feature__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2.4rem,5vw,5rem);align-items:center;position:relative;z-index:1}
.feature__media{position:relative;overflow:hidden;background:var(--paper-2)}
.feature__media img{width:100%;height:auto;display:block}
.feature__media .tag{position:absolute;top:1rem;left:1rem;background:var(--spark);color:#fff;padding:.5rem .9rem;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;z-index:2}
.feature__list{margin-top:2rem;display:grid;gap:0}
.feature__item{display:flex;gap:1.2rem;padding:1.1rem 0;border-top:1px solid var(--rule-light)}
.feature__item:first-child{border-top:0}
.feature__item .num{font-family:var(--font-display);font-weight:700;color:var(--brand);font-size:1rem;flex-shrink:0;width:30px;padding-top:2px}
.feature__item h4{margin:0 0 .25rem;font-size:1.05rem}
.feature__item p{margin:0;color:var(--steel-dark);font-size:.95rem}
@media (max-width:880px){.feature__grid{grid-template-columns:1fr}}

/* ------------ Process ------------ */
.process{background:var(--paper);border-top:1px solid var(--rule-light);position:relative;overflow:hidden}
.process > .wrap{position:relative;z-index:1}
.process__list{margin-top:clamp(2rem,4vw,3rem);display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rule-light);border:1px solid var(--rule-light)}
.proc{padding:2rem 1.6rem;background:var(--paper);position:relative;display:flex;flex-direction:column;gap:.6rem}
.proc__num{font-family:var(--font-display);font-weight:800;font-size:2.4rem;color:var(--brand);line-height:1}
.proc h4{margin:0;font-size:1.1rem}
.proc p{margin:0;color:var(--steel-dark);font-size:.95rem;line-height:1.6}
@media (max-width:1024px){.process__list{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.process__list{grid-template-columns:1fr}}

/* ------------ Statband ------------ */
.statband{background:var(--brand);color:#fff;position:relative;overflow:hidden}
.statband > .wrap{position:relative;z-index:1}
.statband__head{display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:end;margin-bottom:4rem}
.statband__head h2{color:#fff}
.statband__head .lede{color:rgba(255,255,255,.85)}
.statband__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.statband__grid > div{padding:2.5rem 2.2rem;border:1px solid rgba(255,255,255,.18);margin:-1px;display:flex;flex-direction:column;gap:.8rem;background:rgba(255,255,255,.03)}
.statband__grid .num{font-family:var(--font-display);font-weight:800;font-size:clamp(2.4rem,4.4vw,3.4rem);line-height:1}
.statband__grid .num em{color:var(--spark);font-style:normal}
.statband__grid .lbl{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:#fff;font-weight:500}
.statband__grid p{margin:0;color:rgba(255,255,255,.85);font-size:.95rem;line-height:1.55}
@media (max-width:780px){.statband__grid{grid-template-columns:1fr}.statband__head{grid-template-columns:1fr}}

/* ------------ Trust strip (LIGHT) ------------ */
.trust{background:var(--paper);border-top:1px solid var(--rule-light);position:relative;overflow:hidden}
.trust > .wrap{position:relative;z-index:1}
.trust__head{margin-bottom:clamp(2.5rem,5vw,4rem);display:grid;grid-template-columns:1.4fr 1fr;gap:2.5rem;align-items:end}
.trust__head h3{font-size:clamp(1.8rem,2.8vw,2.4rem);text-transform:uppercase;color:var(--ink)}
.trust__list{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rule-light);border:1px solid var(--rule-light)}
.trust__item{background:var(--paper);padding:2.4rem 2rem;display:flex;flex-direction:column;gap:.9rem}
.trust__item .icn{width:48px;height:48px;display:grid;place-items:center;background:var(--brand-soft);color:var(--brand);font-family:var(--font-display);font-weight:800;font-size:1.6rem;border-radius:7px}
.trust__item h4{margin:.5rem 0 0;font-size:1.1rem}
.trust__item p{margin:0;color:var(--steel-dark);font-size:.98rem;line-height:1.6}
@media (max-width:780px){.trust__list{grid-template-columns:repeat(2,1fr)}.trust__head{grid-template-columns:1fr}}
@media (max-width:480px){.trust__list{grid-template-columns:1fr}}

/* ------------ Jobs CTA ------------ */
.jobscta{background:var(--paper-2);position:relative;overflow:hidden;border-top:1px solid var(--rule-light)}
.jobscta__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(2rem,5vw,4rem);align-items:center;position:relative;z-index:1}
.jobscta__media{position:relative;overflow:hidden;background:var(--ink-2)}
.jobscta__media img{width:100%;height:auto;display:block}
.jobscta__media .badge{position:absolute;left:1.4rem;bottom:1.4rem;background:var(--ink);color:#fff;padding:.7rem 1rem;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em;font-size:.85rem;display:flex;align-items:center;gap:.7rem;border-radius:7px}
.jobscta__media .badge em{color:var(--spark);font-style:normal}
.jobscta__media .badge .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--spark);box-shadow:0 0 0 4px rgba(232,90,26,.18)}
.jobscta__copy h2{font-size:clamp(2rem,4vw,3.4rem)}
.jobscta__list{margin:1.6rem 0;list-style:none;padding:0}
.jobscta__list li{padding:.7rem 0;border-bottom:1px solid var(--rule-light);font-size:1rem}
.jobscta__list li::before{content:"+";font-family:var(--font-display);color:var(--spark);margin-right:.7rem;font-weight:800;font-size:1.1em}
@media (max-width:880px){.jobscta__grid{grid-template-columns:1fr}}

/* ------------ Contact (dark, but clean) ------------ */
.contact{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.contact > .wrap{position:relative;z-index:1}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem)}
.contact__lead h2{color:#fff}
.contact__details{margin-top:2.4rem;display:grid;gap:0}
.contact__row{display:grid;grid-template-columns:140px 1fr;gap:1.4rem;padding:1.2rem 0;border-top:1px solid var(--rule-dark);align-items:start}
.contact__row .lbl{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--spark);padding-top:4px}
.contact__row .val{font-family:var(--font-display);font-weight:700;font-size:1.1rem;text-transform:uppercase;letter-spacing:.02em;color:#fff}
.contact__row .val a{color:#fff}
.contact__row .val a:hover{color:var(--spark)}
.contact__row .val .sub{display:block;font-family:var(--font-body);font-weight:400;font-size:.88rem;text-transform:none;letter-spacing:0;color:#B0B7C7;margin-top:.3rem}

.form{background:var(--ink-2);padding:clamp(1.8rem,3vw,2.4rem);border:1px solid var(--rule-dark)}
.form h3{color:#fff;font-size:1.3rem;margin-bottom:1.4rem}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form label{display:flex;flex-direction:column;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#B0B7C7;margin-bottom:1.1rem;font-weight:500}
.form input,.form textarea,.form select{margin-top:.45rem;background:transparent;border:0;border-bottom:1.5px solid var(--rule-dark);color:#fff;font-family:var(--font-body);font-size:1rem;padding:.7rem 0;outline:none;transition:border-color .15s ease;font-weight:400;letter-spacing:0;text-transform:none}
.form input:focus,.form textarea:focus,.form select:focus{border-bottom-color:var(--spark)}
.form textarea{min-height:130px;resize:vertical}
.form select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path fill='%23B0B7C7' d='M6 9L1 4h10z'/></svg>");background-repeat:no-repeat;background-position:right .5rem center;background-size:14px}
.form .check{display:grid;grid-template-columns:auto 1fr;gap:.7rem;align-items:start;font-family:var(--font-body);font-size:.86rem;text-transform:none;letter-spacing:0;color:#B0B7C7;font-weight:400;line-height:1.55}
.form .check input{margin-top:5px;accent-color:var(--spark);transform:scale(1.1)}
.form .check a{color:var(--spark)}
.form button{margin-top:.8rem;border:0}
@media (max-width:680px){.contact__grid{grid-template-columns:1fr}.form .row{grid-template-columns:1fr}.contact__row{grid-template-columns:1fr;gap:.4rem}}

/* ------------ Subhero ------------ */
.subhero{position:relative;background:var(--ink);color:#fff;overflow:hidden;border-bottom:5px solid var(--spark);padding-block:clamp(3rem,7vw,5.5rem)}
.subhero__bg{position:absolute;inset:0;z-index:0}
.subhero__bg img{width:100%;height:100%;object-fit:cover;opacity:.32}
.subhero__bg::after{content:"";position:absolute;inset:0;background:rgba(15,22,42,.65)}
.subhero .wrap{position:relative;z-index:2}
.subhero h1{color:#fff;max-width:22ch}
.subhero .lede{color:#D8DDE8;max-width:60ch;margin-top:1.4rem}
.subhero h1 .accent{color:var(--spark)}
.breadcrumbs{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;color:#A8B0C2;margin-bottom:1.6rem}
.breadcrumbs a{color:#A8B0C2}
.breadcrumbs a:hover{color:#fff}
.breadcrumbs .sep{margin:0 .7rem;color:var(--spark)}
.breadcrumbs [aria-current="page"]{color:#fff}

/* ------------ Service detail rows ------------ */
.svcdetail{background:var(--paper);padding-block:var(--section-y);position:relative;overflow:hidden}
.svcdetail > .wrap{position:relative;z-index:1}
.svcdetail__row{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,5rem);align-items:center;padding-block:clamp(2.4rem,5vw,4rem);border-bottom:1px solid var(--rule-light);scroll-margin-top:120px}
.svcdetail__row:last-child{border-bottom:0}
.svcdetail__row:nth-child(even) .svcdetail__media{order:2}
.svcdetail__media{position:relative;aspect-ratio:4/3;overflow:hidden}
.svcdetail__media img{width:100%;height:100%;object-fit:cover}
.svcdetail__media .tag{position:absolute;top:1rem;left:1rem;background:var(--ink);color:#fff;padding:.5rem .9rem;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase}
.svcdetail__media .tag em{color:var(--spark);font-style:normal;font-weight:700;margin-right:.3rem}
.svcdetail__copy h2{margin-bottom:1.4rem}
.svcdetail__copy h2 .num{display:block;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.22em;color:var(--brand);font-weight:500;text-transform:uppercase;margin-bottom:.8rem}
.svcdetail__copy>p{font-size:1.05rem;line-height:1.7;color:var(--steel-dark)}
.svcdetail__list{margin-top:1.6rem;list-style:none;padding:0}
.svcdetail__list li{padding:.85rem 0;border-top:1px solid var(--rule-light);display:flex;gap:.8rem;align-items:flex-start;font-size:.98rem;color:var(--ink);line-height:1.55}
.svcdetail__list li::before{content:"+";font-family:var(--font-display);font-weight:700;color:var(--spark);font-size:1.2rem;line-height:1.2;flex-shrink:0}
@media (max-width:880px){.svcdetail__row{grid-template-columns:1fr}.svcdetail__row:nth-child(even) .svcdetail__media{order:0}}

/* ------------ Map area ------------ */
.maparea{background:var(--paper-2);padding:0;position:relative;overflow:hidden}
.maparea__grid{display:grid;grid-template-columns:1fr 1.4fr;position:relative;z-index:1}
.maparea__info{padding:clamp(2rem,5vw,4rem) clamp(1.5rem,4vw,3rem)}
.maparea__map{aspect-ratio:1/1;background:var(--ink-2);position:relative;overflow:hidden}
.maparea__link{display:block;width:100%;height:100%;background:url('assets/img/standort-wide.jpg') center/cover;position:relative;color:#fff;transition:filter .3s ease}
.maparea__link::before{content:"";position:absolute;inset:0;background:rgba(20,30,60,.62)}
.maparea__link:hover{filter:brightness(1.08)}
.maparea__overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:2rem;gap:1.4rem;z-index:1}
.maparea__pin{filter:drop-shadow(0 8px 16px rgba(232,90,26,.35))}
.maparea__copy{display:flex;flex-direction:column;gap:.4rem;font-family:var(--font-body)}
.maparea__copy strong{font-family:var(--font-display);font-weight:700;font-size:clamp(1.4rem,2.4vw,2rem);text-transform:uppercase;letter-spacing:.02em;color:#fff}
.maparea__copy>span{color:#dadde2;font-size:.98rem}
.maparea__cta{margin-top:1rem;display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.4rem;background:var(--spark);color:#fff !important;font-family:var(--font-display);font-weight:700;font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;align-self:center;border-radius:7px}
.maparea__cta em{font-style:normal;transition:transform .2s ease}
.maparea__link:hover .maparea__cta em{transform:translateX(4px)}
@media (max-width:900px){.maparea__grid{grid-template-columns:1fr}.maparea__map{aspect-ratio:16/10}}

/* ------------ Benefits / joblist ------------ */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule-light);border:1px solid var(--rule-light);margin-top:2.5rem}
.benefit{background:var(--paper);padding:2.2rem 1.8rem;display:flex;flex-direction:column;gap:.8rem}
.benefit .icon{width:48px;height:48px;display:grid;place-items:center;background:var(--brand-soft);color:var(--brand);font-family:var(--font-display);font-weight:800;font-size:1.5rem;border-radius:7px}
.benefit h4{margin:.5rem 0 0;font-size:1.05rem}
.benefit p{margin:0;color:var(--steel-dark);font-size:.95rem;line-height:1.6}
@media (max-width:880px){.benefits{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.benefits{grid-template-columns:1fr}}

.joblist{margin-top:2rem;display:flex;flex-direction:column;gap:0;border:1px solid var(--rule-light);background:var(--paper)}
.joblist__row{display:grid;grid-template-columns:90px 1fr auto auto;gap:1.5rem;padding:1.5rem 1.6rem;border-bottom:1px solid var(--rule-light);align-items:center;text-decoration:none;color:var(--ink);transition:background .15s ease}
.joblist__row:last-child{border-bottom:0}
.joblist__row:hover{background:var(--paper-2)}
.joblist__row .num{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.18em;color:var(--brand)}
.joblist__row .title{font-family:var(--font-display);font-weight:700;font-size:1.1rem;text-transform:uppercase;letter-spacing:.02em;line-height:1.2}
.joblist__row .meta{display:flex;gap:1.4rem;font-family:var(--font-mono);font-size:.74rem;color:var(--steel-dark);letter-spacing:.06em;text-transform:uppercase;flex-wrap:wrap}
.joblist__row .arrow{color:var(--spark);font-size:1.4rem;transition:transform .18s ease}
.joblist__row:hover .arrow{transform:translateX(4px)}
@media (max-width:780px){.joblist__row{grid-template-columns:1fr;gap:.6rem}.joblist__row .meta{gap:.8rem;font-size:.7rem}}

/* ------------ Prose (legal) ------------ */
.prose{max-width:780px;font-size:1rem;line-height:1.75;color:var(--ink)}
.prose h2{font-size:1.5rem;margin:2.4rem 0 1rem;color:var(--ink)}
.prose h3{font-size:1.15rem;margin:1.6rem 0 .6rem}
.prose p{margin:0 0 1rem}
.prose ul{padding-left:1.4rem;margin:0 0 1.2rem}
.prose ul li{margin-bottom:.4rem}
.prose a{color:var(--brand);text-decoration:underline;text-underline-offset:3px}
.prose strong{color:var(--ink);font-weight:600}

/* ------------ Footer ------------ */
.footer{background:var(--ink);color:#C7CCD8;padding-block:clamp(3rem,5vw,4rem) clamp(1.5rem,3vw,2rem);position:relative;overflow:hidden}
.footer > .wrap{position:relative;z-index:1}
.footer__top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:clamp(1.6rem,3vw,3rem);padding-bottom:3rem;border-bottom:1px solid var(--rule-dark)}
.footer__brand img{height:42px;width:auto;margin-bottom:1rem}
.footer__brand p{color:#A8B0C2;font-size:.92rem;max-width:42ch;line-height:1.6}
.footer__brand .meta{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--spark);margin-top:1rem}
.footer h4{color:#fff;font-size:.85rem;letter-spacing:.16em;margin:0 0 1.2rem;font-family:var(--font-mono);font-weight:500;text-transform:uppercase}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}
.footer ul a{color:#A8B0C2;font-size:.92rem}
.footer ul a:hover{color:#fff}
.footer__bottom{padding-top:1.4rem;display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;color:#7A8194;flex-wrap:wrap;gap:.6rem}
.footer__bottom .legal{display:flex;gap:1.4rem}
.footer__bottom .legal a{color:#A8B0C2}
.footer__bottom .legal a:hover{color:#fff}
@media (max-width:880px){.footer__top{grid-template-columns:1fr 1fr;gap:2rem}.footer__brand{grid-column:span 2}}
@media (max-width:520px){.footer__top{grid-template-columns:1fr}.footer__brand{grid-column:span 1}}

/* ------------ Reveal animation ------------ */
.js [data-reveal]{opacity:0;transform:translateY(16px);transition:opacity .55s ease,transform .55s ease}
.js [data-reveal].is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .js [data-reveal]{opacity:1;transform:none;transition:none}
  .ribbon__track,.tool-float--drift,.tool-float--drift-slow{animation:none}
}

/* ------------ Print ------------ */
@media print{.site-header,.footer,.ribbon,.nav-toggle{display:none}body{color:#000;background:#fff}}

/* =================================================================
   Service Detail Pages
================================================================= */
.svcpage-intro{background:var(--paper)}
.svcpage-intro__grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(2.5rem,6vw,5rem);align-items:start;position:relative;z-index:1}
.svcpage-intro__lead h2{margin-top:.5rem}
.svcpage-intro__copy .lede{margin-bottom:2rem;font-size:1.18rem;line-height:1.7;color:var(--ink)}
.svcpage-intro__cta{display:flex;gap:1rem;flex-wrap:wrap}
@media (max-width:880px){.svcpage-intro__grid{grid-template-columns:1fr}}

.svcpage-strip{height:clamp(280px,40vw,520px);overflow:hidden;background:var(--ink-2)}
.svcpage-strip img{width:100%;height:100%;object-fit:cover;display:block}

.svcpage-cap{background:var(--paper-2);border-top:1px solid var(--rule-light);border-bottom:1px solid var(--rule-light)}
.svcpage-cap__head{margin-bottom:clamp(2.5rem,5vw,4rem);max-width:60ch}
.svcpage-cap__list{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule-light);border:1px solid var(--rule-light);position:relative;z-index:1}
.cap{background:var(--paper);padding:2.4rem 2.2rem;display:grid;grid-template-columns:auto 1fr;gap:1.4rem;align-items:start}
.cap__num{font-family:var(--font-display);font-weight:800;font-size:2.2rem;color:var(--brand);line-height:1;padding-top:.2rem}
.cap__title{margin:0 0 .6rem;font-size:1.15rem;text-transform:uppercase;letter-spacing:.02em}
.cap__copy{margin:0;color:var(--steel-dark);font-size:.98rem;line-height:1.65}
@media (max-width:780px){.svcpage-cap__list{grid-template-columns:1fr}}

.svcpage-cta{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.svcpage-cta__inner{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;position:relative;z-index:1}
.svcpage-cta__btns{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.svcpage-cta__btns .btn{width:100%;justify-content:space-between}
@media (max-width:880px){.svcpage-cta__inner{grid-template-columns:1fr}.svcpage-cta__btns{flex-direction:row;flex-wrap:wrap}.svcpage-cta__btns .btn{width:auto;flex-grow:1}}

.svcpage-related{background:var(--paper)}
.svcpage-related__head{text-align:center;max-width:54ch;margin:0 auto clamp(2.5rem,5vw,4rem);position:relative;z-index:1}
.svcpage-related__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;position:relative;z-index:1}
.related-svc{display:flex;flex-direction:column;background:var(--paper-2);border:1px solid var(--rule-light);overflow:hidden;color:var(--ink);text-decoration:none;transition:transform .25s ease,border-color .25s ease;border-radius:7px}
.related-svc:hover{transform:translateY(-3px);border-color:var(--brand)}
.related-svc__media{height:200px;overflow:hidden;border-bottom:1px solid var(--rule-light)}
.related-svc__media img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.related-svc:hover .related-svc__media img{transform:scale(1.04)}
.related-svc__copy{padding:1.6rem 1.4rem;display:flex;flex-direction:column;gap:.6rem;flex-grow:1}
.related-svc__num{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brand)}
.related-svc__copy h3{margin:.2rem 0;font-size:1.2rem;text-transform:uppercase;letter-spacing:.01em}
.related-svc__cta{font-family:var(--font-display);font-weight:700;font-size:.92rem;text-transform:uppercase;letter-spacing:.06em;color:var(--brand);margin-top:auto;padding-top:.8rem;border-top:1px solid var(--rule-light);display:flex;justify-content:space-between;align-items:center}
.related-svc__cta em{font-style:normal;transition:transform .2s ease}
.related-svc:hover .related-svc__cta em{transform:translateX(4px)}
@media (max-width:880px){.svcpage-related__grid{grid-template-columns:1fr}}
