@font-face{
  font-family:"TradeGothicCondensed";
  src:url("../fonts/TradeGothicProCondensed18.woff2") format("woff2"),
      url("../fonts/TradeGothicProCondensed18.woff") format("woff");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"TradeGothicCondensed";
  src:url("../fonts/TradeGothicProBoldCondensed20.woff2") format("woff2"),
      url("../fonts/TradeGothicProBoldCondensed20.woff") format("woff");
  font-weight:700;
  font-style:normal;
  font-display:swap;
}


:root{
  --navy:#001b44;
  --navy-2:#00163a;
  --text:#0a1d3a;
  --muted:#2b3b52;
  --red:#e63328;
  --bg:#ffffff;

  --maxw:1200px;
  --font:"TradeGothicCondensed", Arial, sans-serif;

  --hero-ratio:0.4532;

  --h1: clamp(30px, 4.2vw, 53px);            
  --h2: calc(var(--h1) * 0.6604);            
  --p:  calc(var(--h1) * 0.4528);            
  --ui: calc(var(--p)  * 0.5833);            
  --dot: calc(var(--p) * 2.1667);            

  --footer-lh: 1.25;
  --footer-row: calc(var(--p) * var(--footer-lh));
}


*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--font);
  font-weight:400;
  color:var(--text);
  background:var(--bg);
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

h1,h2,h3{ font-weight:400; }
img{ max-width:100%; height:auto; display:block; }

a{ color:inherit; text-decoration:none; }
a:hover{ text-decoration:underline; text-underline-offset:3px; }

a:focus-visible, button:focus-visible{
  outline:3px solid rgba(197,31,36,.6);
  outline-offset:3px;
  border-radius:6px;
}

.container{
  width:min(var(--maxw), calc(100% - 48px));
  margin-inline:auto;
}
.header-container{
  width:min(var(--maxw), calc(100% - 48px));
  margin-inline:auto;
}

/* Skip link (A11y) */
.skip-link{
  position:absolute;
  left:-999px; top:12px;
  background:#fff;
  color:#000;
  padding:10px 12px;
  z-index:9999;
  border-radius:10px;
  box-shadow:0 10px 30px rgba(0,0,0,.2);
}
.skip-link:focus{ left:12px; }

/* =========================
   Header / Nav
========================= */

.site-header{
  position:absolute;
  inset:0 0 auto 0;
  z-index:30;
  color:#fff;
}

.header-inner{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:24px;
  padding:28px 0 0;
}

.brand{ display:flex; align-items:flex-start; }

.brand-logo{ height:auto; display:block; }
.brand-logo--header{ width:220px; }

.brand--header{ margin-left:-46px; }

/* =========================
   Header-Logo
========================= */
.brand--header{
  position:relative;
  display:inline-block;
}

.brand--header::before{
  content:"";
  position:absolute;
  background: var(--red);

  top: 23.5887%;
  height: 1.8145%;

  left: -100vw;
  right: 68.7243%;

  opacity: 0;
  transform: translateX(-100%);
  transform-origin: left center;
  will-change: transform, opacity;
}

@keyframes headerLineIn{
  to{ transform: translateX(0); opacity: 1; }
}

.hero.is-loaded .brand--header::before{
  animation: headerLineIn 700ms ease forwards;
  animation-delay: 120ms;
}

@media (prefers-reduced-motion: reduce){
  .hero.is-loaded .brand--header::before{
    animation:none;
    transform:none;
    opacity:1;
  }
}

@media (max-width:860px){
  .brand--header{ margin-left:-28px; }
}

.nav{
  display:flex;
  align-items:center;
  gap:34px;
  margin-top:6px;
}
.nav a{
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:var(--p);
  white-space:nowrap;
}

.nav-toggle{
  display:none;
  border:0;
  background:transparent;
  color:#fff;
  padding:10px;
  border-radius:12px;
}
.nav-toggle .bars{
  width:26px;
  height:18px;
  position:relative;
  display:block;
}
.nav-toggle .bars span{
  position:absolute;
  left:0;
  width:100%;
  height:2px;
  background:#fff;
  border-radius:2px;
  transition:transform .2s ease, top .2s ease, opacity .2s ease;
}
.nav-toggle .bars span:nth-child(1){ top:0; }
.nav-toggle .bars span:nth-child(2){ top:8px; }
.nav-toggle .bars span:nth-child(3){ top:16px; }

@media (max-width:860px){
  .header-inner{ padding-top:18px; }
  .brand-logo--header{ width:190px; }
  .nav-toggle{ display:inline-flex; }

  .nav{
    position:absolute;
    right:24px;
    top:64px;
    display:none;
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
    background:rgba(0,0,0,.25);
    backdrop-filter: blur(10px);
    border:1px solid rgba(255,255,255,.18);
    padding:14px 14px;
    border-radius:0;
  }

  .nav a{
    font-size:var(--p);
    letter-spacing:.04em;
  }

  body.nav-open .nav{ display:flex; }
  body.nav-open .nav-toggle .bars span:nth-child(1){ top:8px; transform:rotate(45deg); }
  body.nav-open .nav-toggle .bars span:nth-child(2){ opacity:0; }
  body.nav-open .nav-toggle .bars span:nth-child(3){ top:8px; transform:rotate(-45deg); }
}

/* =========================
   Hero
========================= */

.hero{
  position:relative;
  background:var(--navy);
  color:#fff;
  height: clamp(560px, calc(100vw * var(--hero-ratio)), 900px);
  display:flex;
  align-items:flex-end;
  padding:0 0 46px;
  overflow:hidden;
}

.hero-center{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  pointer-events:none;
  z-index:20;
  padding-top:0;
  transform: translateY(118px);
}
@media (max-width:980px){ .hero-center{ transform: translateY(96px); } }
@media (max-width:520px){ .hero-center{ transform: translateY(72px); } }

.hero-title{ pointer-events:none; text-transform:uppercase; }

.hero-title .name{
  color:var(--red);
  font-weight:700;
  font-size:var(--h1);
  line-height:1.1;
  margin:0 0 6px;
}
.hero-title .sub{
  margin:0;
  font-weight:400;
  font-size:var(--h1); 
  line-height:1.1;
  letter-spacing:.01em;
  display:inline-flex;
  gap:28px;
  justify-content:center;
}
.hero-title .sub span{ display:inline-block; }

.hero-lines{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:10;
}
.hero-lines-svg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
}

.hline{
  fill:#fff;
  opacity:0;
  transform: translateX(-28px);
  transform-box: fill-box;
  transform-origin: left center;
  will-change: transform, opacity;
}
.hero.is-loaded .hline{ animation: lineFlyIn 700ms ease forwards; }
@keyframes lineFlyIn{ to{ transform:translateX(0); opacity:.95; } }
.h1{ animation-delay: 40ms; }
.h2{ animation-delay: 90ms; }
.h3{ animation-delay:140ms; }
.h4{ animation-delay:190ms; }
.h5{ animation-delay:240ms; }
.h6{ animation-delay:290ms; }
.h7{ animation-delay:340ms; }
.h8{ animation-delay:390ms; }
.h9{ animation-delay:440ms; }
.h10{animation-delay:490ms; }
.h11{animation-delay:540ms; }

@keyframes headerLineIn{
  to{
    transform: translateX(0);
    opacity:1;
  }
}

.hero.is-loaded .brand--header::before{
  animation: headerLineIn 700ms ease forwards;
  animation-delay: 120ms;
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  .hero.is-loaded .hline{ animation:none; transform:none; opacity:.95; }
}

/* =========================
   Main
========================= */

.main{ padding:56px 0 0; }
.h1-block{ padding:18px 0 10px; }

.h1-block h1{
  margin:0 0 18px;
  font-size:var(--h1);
  line-height:1.12;
  text-transform:uppercase;
  letter-spacing:.02em;
}

.intro{
  max-width:900px;
  color:var(--muted);
  font-size:var(--p);
}
.intro p{ margin:0 0 14px; }

.section-label{
  display:inline-block;
  margin:100px 0 18px;
  padding:20px 18px 10px;
  border:5px solid var(--red);
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:var(--h1);
  line-height:1.1;
  color:var(--text);
}

.section{ padding:10px 0 28px; }
.section h2{
  margin:20px 0 22px;
  font-size:var(--h2);
  line-height:1.15;
  color:var(--text);
  position:relative;
}

.h2-ruled{
  position:relative;
  padding-bottom:15px;
}
.h2-ruled::after{
  content:"";
  position:absolute;
  left: calc(-1 * var(--h2-left, 0px));
  bottom: 6px;
  height: 5px;
  width: calc(var(--h2-left, 0px) + 3.8ch);
  background: var(--red);
  transform: scaleX(0);
  transform-origin: left;
}
.h2-ruled.in-view::after{ animation: h2LineIn 700ms ease forwards; }
@keyframes h2LineIn{ to{ transform: scaleX(1); } }

.section p{
  margin:0 0 10px;
  font-size:var(--p);
  color:var(--muted);
  max-width:920px;
}

.list{
  margin:8px 0 12px 0;
  padding-left:0;                
  list-style:none;               
  color:var(--muted);
  font-size:var(--p);
}

.list li{
  position:relative;
  padding-left:22px;            
  margin:6px 0;
}

.list li::before{
  content:"";
  position:absolute;
  left:0;
  top:0.50em;                    
  width:6px;
  height:6px;
  background:var(--red);
  border-radius:50%;
}

/* =========================
   Branchenfokus 
========================= */

.band{
  background:linear-gradient(0deg, var(--navy-2), var(--navy));
  color:#fff;
  padding:26px 0 28px;
  margin-top:18px;
}
.band h2{
  margin:0 0 16px;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:var(--h2);
}
.focus-grid{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap:14px;
  align-items:start;
}
.focus-item{ text-align:center; }
.focus-dot{
  position:relative;
  width:var(--dot);
  height:var(--dot);
  border-radius:50%;
  background:#fff;
  margin:0 auto 10px;
  overflow:hidden;               
}

.focus-dot::after{
  content:"";
  position:absolute;
  inset:0;
  background:var(--red);
  transform: translateX(-100%);  
  transition: transform 0.35s ease;
}

.focus-item:hover .focus-dot::after{
  transform: translateX(0);      
}

.focus-item p{
  margin:0;
  font-size:var(--p);
  line-height:1.2;
}
@media (max-width:980px){
  .focus-grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width:560px){
  .focus-grid{ grid-template-columns: repeat(2, 1fr); }
  .focus-dot{
    width: calc(var(--dot) * 0.88);
    height: calc(var(--dot) * 0.88);
  }
}

/* =========================
   Footer 
========================= */

.footer{
  padding: 46px 0 34px;

  font-size: var(--p);
  line-height: var(--footer-lh);
}

.footer strong,
.footer small,
.footer a,
.footer-mid,
.footer-address,
.footer-links{
  font-size: inherit;
  line-height: inherit;
}


.footer small{ font-size: inherit; }


.footer-inner{
  display:grid;
  grid-template-columns: auto auto auto 1fr;          
  grid-template-rows: repeat(4, var(--footer-row));  
  column-gap: 62px;
  align-items: stretch;
}

.footer-brand{
  margin-left: -28px;          
  grid-column: 1;
  grid-row: 1 / 5;           
  align-self: start;
}

.brand-logo--footer{
  width:auto;
  height: calc(var(--footer-row) * 4);
}

.footer-mid{
  grid-column: 2;
  grid-row: 2 / 5;              
  align-self: stretch;

  color: var(--text);

  display:flex;
  flex-direction:column;
  justify-content:space-between; 
}

.footer-mid strong{
  font-weight:700;
  margin:0;
  padding:0;
}

.footer-mid small{
  display:block;
  margin:0;
  padding:0;
  color: var(--text);
}

.footer-address{
  grid-column: 3;
  grid-row: 3 / 5;              
  align-self: stretch;

  color: var(--text);

  display:flex;
  flex-direction:column;
  justify-content:space-between; 
}
.footer-address small{
  display:block;
  margin:0;
  padding:0;
  color: var(--text);
}

.footer-links{
  grid-column: 4;
  grid-row: 4;                   
  justify-self: end;
  align-self: end;

  display:flex;
  gap: 72px;                   
}

/* =========================
   Mobile Footer
========================= */

@media (max-width:860px){

  .footer .container{
    width:100%;
    margin:0;
    padding-left:16px;
    padding-right:16px;
  }

  .footer-inner{
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto auto; 
    column-gap: 26px;
    row-gap: 14px;
    align-items:start;
  }

  .footer-brand{
    grid-column:1;
    grid-row:1;
    margin-left:-16px; 
  }

  .brand-logo--footer{
    height: calc(var(--footer-row) * 3.2);
  }

  .footer-mid{
    grid-column:2;
    grid-row:1;
    padding-left:12px;
    display:block;
  }

  .footer-address{
    grid-column:1 / -1;
    grid-row:2;              
    display:block;
  }

  .footer-links{
    grid-column:1 / -1;
    grid-row:3;
    justify-self:start;
    align-self:start;
    gap:22px;
    margin-top:8px;
  }
}

/* =========================
   Go-to-top
========================= */

.to-top{
  position:fixed;
  right:22px;
  bottom:72px; 
  width:92px;
  height:44px;
  border:2px solid var(--red);
  border-radius:2px;
  background:transparent;
  color:var(--red);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:50;
  opacity:0;
  transform: translateY(8px);
  transition: opacity .18s ease, transform .18s ease;
}
.to-top svg{ width:22px; height:22px; }
.to-top.is-visible{ opacity:1; transform: translateY(0); }
.to-top:hover{ transform: translateY(-1px); }

@media (max-width:520px){
  .to-top{ right:16px; width:78px; height:40px; }
}

/* =========================
   Legal pages
========================= */

.legal{ padding:120px 0 60px; }
.legal h1{
  margin:0 0 14px;
  font-size:var(--h1);
  text-transform:uppercase;
}
.legal h2{
  margin:40px 0 10px;
  font-size:var(--h2);
}
.legal p, .legal li{
  font-size:var(--p);
  color:var(--muted);
}
.legal ul{ padding-left:18px; }