:root{
  /* Brand */
  --jp-blue:  #2F80C1;
  --jp-green: #6FAF3A;

  /* Neutral */
  --bg: #ffffff;
  --bg2: #eef4f2;
  --bg3: white;
  --surface: #ffffff;
  --text: #2b2f33;
  --text2: #ffffff;
  --muted: #5c6670;

  /* UI */
  --border: rgba(0,0,0,.12);
  --ring: rgba(47,128,193,.25);
  --shadow: 0 10px 30px rgba(0,0,0,.08);

  /* Links */
  --link: var(--jp-blue);
  --link-hover: #256da6;

  /* Buttons */
  --btn-primary: var(--jp-green);
  --btn-primary-hover: #5b9a32;

  /* Layout */
  --content-max: 1200px;
  --gutter: 24px;

  /* Header */
  --topbar-h: 34px;
  --header-h: 74px;
}

/* Darkmode */
@media (prefers-color-scheme: dark){
  :root{
    --bg: #0b1220;
    --bg2: #0f1b2e;
    --bg3: #1a2741;
    --surface: #0f1a2b;
    --text: #e7edf6;
    --text2: #0b1220;
    --muted: #b2bdcc;

    /* UI */
    --border: rgba(231,237,246,.14);
    --ring: rgba(47,128,193,.35);
    --shadow: 0 14px 38px rgba(0,0,0,.45);

    /* Links */
    --link: #7db9ff;
    --link-hover: #a6d0ff;

    /* Buttons */
    --btn-primary: var(--jp-green);
    --btn-primary-hover: color-mix(in srgb, var(--jp-green) 80%, #000);

    /* Brand */
    --jp-blue:  #2F80C1;
    --jp-green: #6FAF3A;
  }
}

/*  Darkmode-robuste Defaults */

/* generische Border-Farbe */
.main-header{ border-bottom: 1px solid color-mix(in srgb, var(--border) 70%, transparent); }

/* Karten/Boxen  */
.card,
.service-box,
.reference-card,
.category-card,
.contact__main,
.contact__aside .contact-card,
.career__main,
.refs-logos,
.ref-card{
  background: var(--surface);
  border-color: var(--border);
}

/* Mobile Nav Panel + Submenu */
.nav-panel,
.submenu{
  background: var(--surface);
  border-color: var(--border);
}

/* Inputs/Select/Textarea */
.input, .select, .textarea, .file{
  background: var(--surface);
  border-color: var(--border);
  color: var(--text);
}
.input::placeholder, .textarea::placeholder{
  color: color-mix(in srgb, var(--muted) 70%, transparent);
}

/* Hover-Flächen im Darkmode */
.nav-link:hover,
.submenu-toggle:hover,
.submenu a:hover{
  background: color-mix(in srgb, var(--jp-blue) 16%, transparent);
}

/* Basics */
*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
html, body{ overflow-x: hidden; }

body{
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
}

a{ color: var(--link); text-decoration: none; }
a:hover{ color: var(--link-hover); }

img{ max-width: 100%; height: auto; }
button, input, textarea{ font: inherit; }
:focus-visible{ outline: 3px solid var(--ring); outline-offset: 2px; }

.container{
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

/* Top Bar */
.top-bar{
  background: var(--jp-blue);
  color: var(--text2);
  font-size: 14px;
  position: relative; 
  z-index: 2001;
}

.top-bar-inner{
  max-width: var(--content-max);
  margin: auto;
  padding: 6px var(--gutter);
  display: flex;
  justify-content: flex-end;
  gap: 18px;
  align-items: center;
}

/* Header */
.main-header{
  background: var(--surface);
  border-bottom: 1px solid rgba(0,0,0,.06);
  position: relative; 
  z-index: 2000; 
  overflow: visible;
}

.header-inner{
  max-width: var(--content-max);
  margin: auto;
  padding: 15px var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  overflow: visible;
}

.logo img{
  height: 64px;
  width: auto;
  display: block;
}

@media (max-width: 768px){
  .logo img{ height: 38px; }
}

.main-nav a{
  color: var(--text);
  font-weight: 500;
}

.main-nav a:hover{
  color: var(--jp-blue);
}

/* Buttons */
.btn-primary{
  background: var(--btn-primary);
  color: var(--text2) !important;
  padding: 10px 18px;
  border-radius: 4px;
}

.btn-primary:hover{
  background: var(--btn-primary-hover);
}

/* Navigation */
.main-nav{
  display: flex;
  align-items: center;
  gap: 25px;
}

.nav-item{
  position: relative;
  display: inline-flex;
  align-items: center;
}

.submenu{
  position: absolute;
  left: 0;
  top: 100%;
  min-width: 260px;
  background: var(--bg);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  transition: opacity .2s ease, transform .2s ease;
  z-index: 5000;
  pointer-events: none; 
}

.nav-item:hover .submenu{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.nav-item::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 12px;
  pointer-events: none;
}

/* Submenu Links */
.submenu a{
  display: block;
  padding: 8px 18px;
  color: var(--text);
  font-size: 14px;
  white-space: nowrap;
}

.submenu a:hover{
  background: rgba(47,128,193,.08);
  color: var(--jp-blue);
}

.submenu-separator{
  height: 1px;
  background: var(--border);
}

/* Navigation Toggle */
.site-nav{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap: 10px;
}

.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border:1px solid rgba(0,0,0,.12);
  border-radius:10px;
  background:var(--bg);
  cursor:pointer;
  align-items:center;
  justify-content:center;
}

.nav-toggle__icon{
  width:22px;
  height:2px;
  background: var(--text);
  position: relative;
  display:block;
}
.nav-toggle__icon::before,
.nav-toggle__icon::after{
  content:"";
  position:absolute;
  left:0;
  width:22px;
  height:2px;
  background: var(--text);
}
.nav-toggle__icon::before{ top:-7px; }
.nav-toggle__icon::after{ top:7px; }

.submenu-toggle{
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  font: inherit;
  color: var(--text);
  font-weight: 500;
  cursor: pointer;
}

.submenu-toggle:hover{
  color: var(--jp-blue);
}

.submenu-toggle .caret{
  font-size: 14px;
  opacity: .8;
  margin-left: 6px;
}

.nav-panel{
  display:flex;
  align-items:center;
  gap: 25px;
}
.nav-link{ font-weight:500; color:var(--text); }
.nav-link:hover{ color:var(--jp-blue); }

.nav-cta{ white-space:nowrap; }

.has-submenu{ position:relative; }
.has-submenu .submenu{
  position:absolute;
  left:0; top:100%;
  min-width: 260px;
  background:var(--bg);
  border:1px solid var(--border);
  box-shadow: var(--shadow);
  opacity:0;
  visibility:hidden;
  transform: translateY(6px);
  transition: opacity .2s ease, transform .2s ease;
  pointer-events:none;
  z-index: 5000;
}
.has-submenu:hover .submenu{
  opacity:1; visibility:visible;
  transform: translateY(0);
  pointer-events:auto;
}

/* Mobile Layout */
@media (max-width: 900px){
  .nav-toggle{ display:inline-flex; }

  .nav-panel{
    position: absolute;
    right: var(--gutter);
    top: calc(100% + 10px);
    width: min(92vw, 360px);
    background:var(--bg);
    border:1px solid rgba(0,0,0,.10);
    box-shadow: var(--shadow);
    border-radius:14px;
    padding: 12px;
    display:none;
    flex-direction: column;
    align-items: stretch;
    overflow-x: hidden;
    gap: 6px;
    z-index: 9999;
  }

  .nav-panel[data-open="true"]{ display:flex; }

   .nav-panel a,
  .nav-panel .submenu a{
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
    line-height: 1.1;
  }

  .nav-panel .submenu a{
    padding: 10px 12px;
  }

  .nav-link{
    padding: 10px 12px;
    border-radius:10px;
  }
  .nav-link:hover{
    background: rgba(47,128,193,.08);
  }

  .submenu-toggle{
    width:100%;
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding: 10px 12px;
    border-radius:10px;
    border:0;
    background: transparent;
    font: 600 15px/1.2 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    color: var(--text);
    cursor:pointer;
  }
  .submenu-toggle:hover{
    background: rgba(47,128,193,.08);
  }

  .has-submenu .submenu{
    position: static;
    transform:none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    border:0;
    box-shadow:none;
    display:none;
    padding: 6px 0 0;
    min-width: 0;
  }
  .has-submenu[data-open="true"] .submenu{ display:block; }

  .submenu a{
    display:block;
    padding: 9px 12px;
    border-radius:10px;
    font-size:14px;
  }

  .has-submenu:hover .submenu{
    opacity:1; visibility:visible; transform:none; pointer-events:auto;
  }

  .nav-cta{
    margin-top: 6px;
    text-align:center;
  }

  .logo img{ height: 42px; }
}

/* Navi */

/* Header */

/* Hero */
.hero{
  position: relative;
  height: 65vh;
  min-height: 520px;
  color: var(--text2);
  overflow: hidden;
}

.hero-overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    rgba(47,128,193,0.85),
    rgba(111,175,58,0.85)
  );
}

.hero-content{
  position: relative;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 120px var(--gutter);
}

.hero h1{
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.05;
  margin: 0 0 14px;
  font-weight: 800;
}

.hero p{
  margin: 0 0 22px;
  font-size: 16px;
  font-weight: 600;
  opacity: .95;
}

.hero-actions{
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.btn-ghost{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 18px;
  border-radius: 4px;
  border: 1px solid rgba(255,255,255,.55);
  color: var(--text2);
  background: rgba(255,255,255,.12);
}
.btn-ghost:hover{
  background: rgba(255,255,255,.18);
}

.cards-section{
  background: var(--bg2);
  padding: 54px var(--gutter);
}

.cards-grid{
  max-width: var(--content-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  transform: translateY(-100px);
}

.card{
  background: var(--bg);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 6px;
  overflow: hidden;
  box-shadow: var(--shadow);
}

.card-img{
  width: 100%;
  height: 210px;
  object-fit: cover;
  display: block;
}

.card-body{
  padding: 18px 18px 22px;
  text-align: center;
}

.card h3{
  margin: 6px 0 10px;
  font-size: 20px;
}

.card p{
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
  font-size: 14px;
}

/* ===== Split Section wie Bild 3 ===== */
.split-section{
  background: var(--bg2);
  padding: 40px var(--gutter) 70px;
}

.split-inner{
  max-width: var(--content-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 40px;
  align-items: start;
}

.split-left h2{
  margin: 0 0 10px;
  font-size: 34px;
  line-height: 1.1;
}

.split-sub{
  color: var(--muted);
  margin: 0;
  line-height: 1.6;
}

.split-right p{
  margin: 0 0 12px;
  line-height: 1.7;
}

.muted{ color: var(--muted); }

.icon-row{
  max-width: var(--content-max);
  margin: 40px auto 0;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
  text-align: center;
}

.icon-item{
  display: grid;
  gap: 10px;
  justify-items: center;
  color: var(--muted);
  font-weight: 600;
  font-size: 14px;
}

.icon{
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(47,128,193,.10);
  color: var(--jp-blue);
  font-size: 22px;
}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .cards-grid{ grid-template-columns: 1fr; transform: translateY(-40px); }
  .split-inner{ grid-template-columns: 1fr; }
  .icon-row{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 520px){
  .hero-content{ padding: 92px var(--gutter); }
  .icon-row{ grid-template-columns: repeat(2, 1fr); }
}

/* Hero */

/* Prozess */
.process-section{
  background: var(--bg);
  padding: 80px var(--gutter);
}

.process-inner{
  max-width: var(--content-max);
  margin: 0 auto;
  text-align: center;
}

.process-head{
  margin-bottom: 56px;
}

.process-line{
  display: inline-block;
  width: 46px;
  height: 4px;
  background: var(--jp-green);
  margin-bottom: 12px;
}

.process-head h2{
  margin: 0;
  font-size: clamp(26px, 3vw, 36px);
  font-weight: 700;
}

.process-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 36px;
  align-items: start;
}

.process-step{
  max-width: 260px;
  margin: 0 auto;
}

.process-icon{
  width: 96px;
  height: 96px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;

  background: rgba(47,128,193,.06);
  border: 4px solid rgba(47,128,193,.08);
  color: var(--jp-blue);
  font-size: 34px;
}

.process-step h3{
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: 700;
}

.process-step p{
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--muted);
}

/* Prozess */

/* CTA-Kontakt */
.cta-contact{
  background: var(--bg);
  padding: 80px var(--gutter);
}

.cta-inner{
  max-width: var(--content-max);
  margin: 0 auto;
}

.cta-contact h2{
  margin: 0 0 14px;
  font-size: clamp(28px, 3.2vw, 44px);
  font-weight: 800;
  color: var(--text);
}

.cta-strong{
  color: var(--jp-blue);
}

.cta-contact p{
  margin: 0 0 26px;
  max-width: 860px;
  line-height: 1.7;
  color: var(--muted);
}

.cta-contact p strong{
  color: var(--text);
}

.cta-actions{
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.cta-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: var(--jp-blue);
  color: var(--text2);
  padding: 14px 22px;
  border-radius: 6px;
  font-weight: 700;
  text-decoration: none;
  box-shadow: var(--shadow);
}

.cta-btn:hover{
  color: var(--text);
  background: var(--link-hover);
}

.cta-link{
  color: var(--jp-blue);
  font-weight: 700;
}

.cta-link:hover{
  color: var(--link-hover);
}

/* CTA-Kontakt */

/* Referenzen Index */
.references-section{
  background: var(--bg2);
  padding: 90px var(--gutter);
}

.references-inner{
  max-width: var(--content-max);
  margin: 0 auto;
}

.references-head{
  max-width: 720px;
  margin-bottom: 54px;
}

.references-line{
  display: inline-block;
  width: 46px;
  height: 4px;
  background: var(--jp-green);
  margin-bottom: 12px;
}

.references-head h2{
  margin: 0 0 12px;
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 800;
}

.references-head p{
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.references-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
}

.reference-card{
  background: var(--bg);
  padding: 26px 24px 28px;
  border-radius: 6px;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: var(--shadow);
}

.reference-tag{
  display: inline-block;
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--jp-blue);
}

.reference-card h3{
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: 700;
}

.reference-card p{
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
  font-size: 14px;
}

.logos-wrap{
  margin-top: 48px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 32px;
  align-items: center;
}

.logos-wrap img{
  max-height: 48px;
  width: auto;
  margin: 0 auto;
  filter: grayscale(100%) contrast(1.1);
  opacity: .65;
  transition: opacity .2s ease, filter .2s ease;
}

.logos-wrap img:hover{
  filter: grayscale(0%);
  opacity: 1;
}

/* Referenzen Index */

/* Footer */

.site-footer{
  background: var(--bg);
  border-top: 1px solid rgba(0,0,0,.08);
}

.footer-top{
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 46px var(--gutter);
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 34px;
}

.footer-col h4{
  margin: 0 0 14px;
  font-size: 14px;
  font-weight: 800;
  color: var(--text);
}

.footer-col a{
  display: block;
  margin: 10px 0;
  color: var(--muted);
  font-size: 14px;
}

.footer-col a:hover{
  color: var(--jp-blue);
}

/* Brand-Spalte */
.footer-logo{
  height: 44px;
  width: auto;
  display: block;
  margin-bottom: 12px;
}

.footer-brand p{
  margin: 0 0 16px;
  color: var(--muted);
  line-height: 1.6;
  font-size: 14px;
  max-width: 320px;
}

.footer-social{
  display: flex;
  gap: 10px;
}

.footer-social a{
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(47,128,193,.08);
  color: var(--jp-blue);
  font-weight: 800;
  font-size: 13px;
}

.footer-social a:hover{
  background: rgba(47,128,193,.16);
}

/* Kontakt */
.footer-contact{
  display: grid;
  gap: 10px;
}

.fc-row{
  display: grid;
  grid-template-columns: 22px 1fr;
  align-items: center;
  gap: 10px;
  color: var(--muted);
  font-size: 14px;
}

.fc-row a{
  margin: 0;
  display: inline-block;
}

/* Bottom Bar */
.footer-bottom{
  border-top: 1px solid rgba(0,0,0,.08);
  padding: 16px var(--gutter);
  max-width: var(--content-max);
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 13px;
}

.footer-links{
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
}

.footer-links a{
  color: var(--muted);
}

.footer-links a:hover{
  color: var(--jp-blue);
}

@media (max-width: 980px){
  .footer-top{
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 560px){
  .footer-top{
    grid-template-columns: 1fr;
  }
}

/* Footer */

/* Kontakt */

.sr-only{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0);
  white-space:nowrap; border:0;
}

.contact-grid{
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap: 26px;
  align-items:start;
  padding: 30px 0 90px;
}

.contact__main,
.contact__aside .contact-card{
  background:var(--bg3);
  border:1px solid rgba(0,0,0,.06);
  border-radius:6px;
  box-shadow: var(--shadow);
  padding: 22px 20px;
}

.contact__main{
  padding: 26px 24px 28px;
}

.contact__aside{
  display:grid;
  gap: 18px;
}
.contact-card{
  background: var(--bg3);
  padding: 22px 20px;
  border-radius:6px;
}
.contact-card h3{
  margin: 0 0 12px;
  font-size: 18px;
  font-weight: 800;
}
.contact-card p{
  margin: 0 0 10px;
  color: var(--muted);
  line-height: 1.6;
}
.contact-card p strong{ color: var(--text); }

.link{
  color: var(--jp-blue);
  font-weight: 800;
}
.link:hover{ color: var(--link-hover); }

.form-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}

.field{ grid-column: 1 / -1; }
.field--6{ grid-column: span 6; }

.field label{
  display:block;
  font-weight: 800;
  font-size: 13px;
  margin: 0 0 8px;
}

.input, .select, .textarea, .file{
  width:100%;
  border:1px solid rgba(0,0,0,.12);
  border-radius:6px;
  padding: 10px 12px;
  background: var(--bg);
  color: var(--text);
}

.textarea{ min-height: 140px; resize: vertical; }

.input:focus, .select:focus, .textarea:focus, .file:focus{
  outline: 3px solid var(--ring);
  outline-offset: 2px;
}

.checkbox{
  display:flex;
  gap: 10px;
  align-items:flex-start;
}
.checkbox input{ margin-top: 3px; }
.checkbox label{
  margin:0;
  color: var(--muted);
  line-height:1.5;
  font-weight: 600;
  font-size: 14px;
}

.actions{
  display:flex;
  flex-wrap:wrap;
  gap: 12px;
  align-items:center;
  margin-top: 16px;
}

.status{
  color: var(--muted);
  font-weight: 700;
  font-size: 14px;
}

/* ===== Buttons (falls du sie noch nicht hast) ===== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding: 10px 16px;
  border-radius: 999px;
  font-weight: 800;
  border: 0;
  cursor: pointer;
  text-decoration:none;
  user-select:none;
}
.btn--primary{
  background: var(--jp-blue);
  color:var(--text2);
}
.btn--primary:hover{ background: var(--link-hover); }

.btn--ghost{
  background: rgba(47,128,193,.08);
  color: var(--jp-blue);
  border: 1px solid rgba(47,128,193,.20);
}
.btn--ghost:hover{ background: rgba(47,128,193,.14); }

/* Modal */
.modal{
  position:fixed; inset:0; z-index:99999;
  display:none;
  align-items:center; justify-content:center;
  background: rgba(0,0,0,.5);
}
.modal.is-open{ display:flex; }

.modalContent{
  background: var(--bg);
  color: var(--text);
  width: min(92vw, 480px);
  border-radius: 16px;
  padding: 24px;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  text-align:center;
}

.modalLogo{ width: 150px; height:auto; margin-bottom: 10px; }
.modalContent h2{ margin: 6px 0; font-size: 22px; font-weight: 900; }
.modalContent p{ margin: 0 0 14px; color: var(--muted); }

#closeModal{
  background: var(--jp-blue);
  color:var(--text2);
  border:0;
  border-radius:999px;
  padding:10px 16px;
  font-weight:900;
  cursor:pointer;
}
#closeModal:hover{ background: var(--link-hover); }

@media (max-width: 980px){
  .contact-grid{
    grid-template-columns: 1fr;
    padding-bottom: 70px;
  }
  .field--6{ grid-column: 1 / -1; }
}

/* Kontakt */

/* Bewerbung */

.career-grid{
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap: 26px;
  align-items:start;
  padding: 30px 0 90px;
}

.career__main{
  background:var(--bg3);
  border:1px solid rgba(0,0,0,.06);
  border-radius:6px;
  box-shadow: var(--shadow);
  padding: 26px 24px 28px;
}

.career__aside{
  display:grid;
  gap: 18px;
}

@media (max-width: 980px){
  .career-grid{
    grid-template-columns: 1fr;
    padding-bottom: 70px;
  }
}

/* Bewerbung */

/* Facility */

.page-hero{
  position: relative;
  height: 55vh;
  min-height: 420px;
  color: var(--text2);
  overflow: hidden;
}

.page-hero-overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    rgba(47,128,193,.88),
    rgba(111,175,58,.88)
  );
}

.page-hero-content{
  position: relative;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 120px var(--gutter);
}

.page-hero h1{
  margin: 0 0 12px;
  font-size: clamp(34px, 4vw, 52px);
  font-weight: 800;
}

.page-hero p{
  max-width: 640px;
  font-size: 16px;
  line-height: 1.6;
  opacity: .95;
}

.page-intro{
  padding: 70px var(--gutter) 40px;
  background: var(--bg);
}

.page-intro-inner{
  max-width: 820px;
  margin: 0 auto;
}

.page-intro h2{
  margin: 0 0 14px;
  font-size: clamp(26px, 3vw, 36px);
  font-weight: 800;
}

.page-intro p{
  margin: 0;
  line-height: 1.7;
  color: var(--muted);
}

.services-section{
  background: var(--bg2);
  padding: 60px var(--gutter) 80px;
}

.services-grid{
  max-width: var(--content-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 26px;
}

.service-box{
  background: var(--bg);
  padding: 26px 26px 28px;
  border-radius: 6px;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: var(--shadow);
}

.service-box h3{
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.3;
  min-height: 2.6em;
}

.service-box p{
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--muted);
}

.service-points{
  margin: 14px 0 0;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.6;
  font-size: 14px;
}

.service-points li{
  margin: 8px 0;
}

.service-points strong{
  color: var(--text);
}

.service-cta{
  display: inline-block;
  margin-top: 14px;
  font-weight: 800;
  color: var(--jp-blue);
}

.service-cta:hover{
  color: var(--link-hover);
}

/* temporäres Highlight */
.service-box.is-highlight{
  outline: 3px solid rgba(47,128,193,.35);
  box-shadow: 0 0 0 6px rgba(47,128,193,.12), var(--shadow);
  animation: highlightPulse .6s ease-out;
}

@keyframes highlightPulse{
  0%{ transform: translateY(0); }
  30%{ transform: translateY(-3px); }
  100%{ transform: translateY(0); }
}

.service-box{
  scroll-margin-top: 120px;
}

/* Facility */

/* Industrie */

/* Industrie */

/* Leistungen */

.category-section{
  background: var(--bg2);
  padding: 70px var(--gutter) 90px;
}

.category-grid{
  max-width: var(--content-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 26px;
}

.category-card{
  background: var(--bg);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 6px;
  box-shadow: var(--shadow);
  padding: 28px 26px 26px;
}

.category-top h3{
  margin: 10px 0 10px;
  font-size: 22px;
  font-weight: 800;
}

.category-top p{
  margin: 0 0 14px;
  color: var(--muted);
  line-height: 1.6;
  font-size: 14px;
}

.category-badge{
  display: inline-block;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 999px;
}

.category-badge--blue{
  background: rgba(47,128,193,.12);
  color: var(--jp-blue);
}

.category-badge--green{
  background: rgba(111,175,58,.16);
  color: var(--jp-green);
}

.category-points{
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.6;
  font-size: 14px;
}

.category-points li{
  margin: 10px 0;
}

.category-points strong{
  color: var(--text);
}

.category-actions{
  margin-top: 18px;
  display: grid;
  gap: 10px;
  align-items: start;
}

.category-link{
  color: var(--jp-blue);
  font-weight: 800;
  font-size: 14px;
}

.category-link:hover{
  color: var(--link-hover);
}

/* Einsatzbereiche */
.areas-section{
  background: var(--bg);
  padding: 70px var(--gutter) 90px;
}

.areas-inner{
  max-width: var(--content-max);
  margin: 0 auto;
}

.areas-inner h2{
  margin: 0 0 10px;
  font-size: clamp(26px, 3vw, 36px);
  font-weight: 800;
}

.areas-sub{
  margin: 0 0 22px;
  color: var(--muted);
  line-height: 1.6;
}

.areas-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}

.area-item{
  background: var(--bg2);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 6px;
  padding: 14px 16px;
  font-weight: 700;
  color: var(--text);
}

@media (max-width: 980px){
  .category-grid{
    grid-template-columns: 1fr;
  }
}

/* Leistungen */

/* Qualität */

.content-section{
  padding: 70px var(--gutter);
  background: var(--bg);
}

.content-section.alt{
  background: var(--bg2);
}

.content-inner{
  max-width: var(--content-max);
  margin: 0 auto;
}

.content-inner h2{
  margin-bottom: 12px;
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 800;
}

.content-inner p{
  max-width: 720px;
  line-height: 1.7;
  color: var(--muted);
}

.content-list{
  margin-top: 18px;
  padding-left: 20px;
  line-height: 1.7;
}

.content-list li{
  margin: 8px 0;
}

/* Qualität */

/* Company */

/* Company */

/* Referenzen */

/* Referenzen Seite */
.refs-section{
  background: var(--bg2);
  padding: 70px var(--gutter) 90px;
}

.refs-inner{
  max-width: var(--content-max);
  margin: 0 auto;
}

.refs-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 22px;
}

/* Referenz-Karten */
.ref-card{
  background: var(--bg);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 6px;
  box-shadow: var(--shadow);
  padding: 24px 24px 26px;
}

.ref-tag{
  display: inline-block;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(47,128,193,.12);
  color: var(--jp-blue);
  margin-bottom: 10px;
}

.ref-card h3{
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: 800;
}

.ref-lead{
  margin: 0 0 12px;
  color: var(--muted);
  line-height: 1.6;
}

.ref-points{
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.6;
  font-size: 14px;
}

.ref-points li{ margin: 8px 0; }
.ref-points strong{ color: var(--text); }

.refs-logos{
  margin-top: 70px;
  background: var(--bg);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 6px;
  box-shadow: var(--shadow);
  padding: 28px 26px 30px;
}

.refs-logos h2{
  margin: 0 0 10px;
  font-size: 22px;
  font-weight: 800;
}

.refs-logos-sub{
  margin: 0 0 22px;
  color: var(--muted);
  line-height: 1.6;
}

/* Referenzen */