/* ===== STANDORT ===== */
.location-hero{position:relative;border-radius:20px;overflow:hidden;margin-bottom:64px;aspect-ratio:21/9}
.location-hero img{width:100%;height:100%;object-fit:cover}
.location-hero__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);display:flex;align-items:flex-end;padding:48px}
.location-hero__text{color:var(--white);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700;max-width:600px;line-height:1.3}

.quote-block{background:var(--black);color:var(--white);border-radius:16px;padding:48px;margin-top:64px;text-align:center}
.quote-block__text{font-size:clamp(1rem,2vw,1.35rem);font-weight:600;line-height:1.6;max-width:800px;margin:0 auto}
.quote-block__text em{font-style:normal;color:var(--neon)}
.philosophy-quote {
  position: relative;
  margin-top: 64px;
  padding: 72px 72px 64px;
  border-radius: 28px;
  background: rgba(48, 67, 95, 0.9);
  border: 1px solid rgba(255,255,255,0.14);
  color: var(--white);
  box-shadow: 0 24px 70px rgba(48,67,95,0.18), inset 0 1px 0 rgba(255,255,255,0.06);
  overflow: hidden;
}
.philosophy-quote::before {
  content: "“";
  position: absolute;
  top: -4px;
  left: 64px;
  color: rgba(216,180,255,0.16);
  font-family: Georgia, serif;
  font-size: 8.5rem;
  line-height: 1;
  font-weight: 700;
}
.philosophy-quote__label {
  position: relative;
  z-index: 1;
  margin-bottom: 36px;
  color: var(--yellow);
  font-family: var(--mono);
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.philosophy-quote__text {
  position: relative;
  z-index: 1;
  max-width: 920px;
  color: var(--white);
  font-size: clamp(1.25rem, 2.2vw, 1.58rem);
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: -0.01em;
}
.philosophy-quote__rule {
  position: relative;
  z-index: 1;
  width: 96px;
  height: 1px;
  margin-top: 44px;
  background: linear-gradient(90deg, var(--yellow), rgba(216,180,255,0));
}
.philosophy-quote--center {
  text-align: center;
}
.philosophy-quote--center::before {
  display: none;
}
.philosophy-quote--center .philosophy-quote__label {
  margin-bottom: 26px;
}
.philosophy-quote--center .philosophy-quote__text {
  max-width: 980px;
  margin: 0 auto;
  font-size: clamp(1.45rem, 2.4vw, 1.9rem);
  line-height: 1.58;
}
.philosophy-quote--center .philosophy-quote__rule {
  display: none;
}
.philosophy-quote__accent {
  color: var(--yellow);
  font-style: normal;
}
.philosophy-quote--compact {
  padding: 52px 56px 48px;
}
.philosophy-quote--compact::before {
  left: 48px;
  font-size: 7rem;
}
.philosophy-quote--compact .philosophy-quote__label {
  margin-bottom: 24px;
}
.philosophy-quote--compact .philosophy-quote__text {
  max-width: 920px;
  font-size: clamp(1.08rem, 1.65vw, 1.32rem);
  line-height: 1.62;
}
.philosophy-quote--compact .philosophy-quote__rule {
  margin-top: 32px;
}
@media (max-width: 768px) {
  .philosophy-quote {
    padding: 54px 28px 46px;
    border-radius: 22px;
  }
  .philosophy-quote::before {
    left: 24px;
    font-size: 6rem;
  }
  .philosophy-quote__label {
    margin-bottom: 28px;
    font-size: .72rem;
  }
  .philosophy-quote__text {
    font-size: clamp(1.05rem, 4.4vw, 1.28rem);
  }
  .philosophy-quote__rule {
    margin-top: 34px;
  }
  .philosophy-quote--center .philosophy-quote__text {
    font-size: clamp(1.12rem, 5vw, 1.35rem);
  }
  .philosophy-quote--compact {
    padding: 42px 24px 38px;
  }
  .philosophy-quote--compact::before {
    left: 20px;
    font-size: 5.4rem;
  }
  .philosophy-quote--compact .philosophy-quote__text {
    font-size: clamp(1rem, 4vw, 1.18rem);
  }
}

.vision-box{background:linear-gradient(135deg,var(--yellow-dim),var(--sand-light));border:1px solid rgba(196,167,231,.25);border-radius:16px;padding:48px;margin-top:64px;text-align:center}
.vision-box__text{font-size:clamp(1rem,1.8vw,1.2rem);font-weight:500;line-height:1.7;max-width:800px;margin:0 auto;color:#444}
.vision-box__text strong{color:var(--orange)}

/* ===== THE LAB (EINBLICKE) ===== */
.lab-intro{font-size:clamp(1rem,1.6vw,1.15rem);max-width:750px;color:#555;line-height:1.8;margin-bottom:64px}

/* ===== KARRIERE ===== */
.karriere-hero{text-align:center;margin-bottom:64px}
.karriere-hero__img{border-radius:20px;overflow:hidden;margin-bottom:48px;aspect-ratio:21/9}
.karriere-hero__img img{width:100%;height:100%;object-fit:cover}
.perks-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.perk-card{background:var(--white);border-radius:30px;padding:40px;border:none;box-shadow:0 10px 30px rgba(0,0,0,.03);text-align:center;transition:all .3s var(--ease)}
.perk-card:hover{transform:scale(1.05);box-shadow:0 20px 50px var(--orange-dim)}
.perk-card__icon{width:56px;height:56px;background:var(--orange-dim);border-radius:14px;display:grid;place-items:center;margin:0 auto 16px;color:var(--orange)}
.perk-card__icon svg{width:28px;height:28px}
.perk-card__title{font-weight:700;font-size:1rem;margin-bottom:8px}
.perk-card__text{color:#555;font-size:.88rem;line-height:1.6}
.wa-btn{display:inline-flex;align-items:center;gap:12px;background:#25D366;color:var(--white);padding:18px 36px;border-radius:100px;font-weight:700;font-size:1.05rem;margin-top:48px;border:2px solid var(--black);box-shadow:4px 4px 0px 0px var(--black);transition:all .2s ease-out}
.wa-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0px 0px var(--black)}
.wa-btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0px 0px var(--black)}

/* ===== ÜBER UNS ===== */
.team-card{text-align:center}
.team-card__name{font-size:1.3rem;font-weight:700;margin-bottom:4px}
.team-card__role{font-size:.85rem;color:var(--black);font-weight:600;margin-bottom:16px;font-family:var(--mono)}
.team-card__quote{font-style:italic;color:#888;font-size:.9rem;margin-bottom:16px;padding:0 20px}
.team-card__text{color:#555;font-size:.9rem;line-height:1.7;text-align:left}
.synergy{background:var(--black);color:var(--white);border-radius:16px;padding:48px;margin-top:48px}
.synergy__title{font-size:1.3rem;font-weight:700;margin-bottom:24px;text-align:center}
.synergy__grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.synergy__item{display:flex;gap:12px}
.synergy__icon{width:40px;height:40px;background:var(--yellow-dim);border-radius:10px;display:grid;place-items:center;flex-shrink:0;color:var(--yellow)}
.synergy__text{font-size:.9rem;color:rgba(255,255,255,.7);line-height:1.6}
.synergy__text strong{color:var(--white)}

/* ===== CO-CREATION ===== */
.cocreation-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-bottom:64px}
.cocreation-step{background:var(--white);border-radius:16px;padding:32px;border:1px solid var(--sand-dark);transition:all .3s}
.cocreation-step:hover{border-color:var(--orange);transform:translateY(-4px);box-shadow:0 8px 24px var(--orange-dim)}
.cocreation-step__num{font-size:2rem;font-weight:800;color:var(--black);opacity:.12;margin-bottom:12px;font-family:var(--mono)}
.cocreation-step__title{font-weight:700;font-size:1.05rem;margin-bottom:8px}
.cocreation-step__text{color:#555;font-size:.88rem;line-height:1.6}
/* ===== FOOTER ===== */
.footer{background:var(--black);color:rgba(255,255,255,.5);padding:48px 0 24px;font-size:.85rem}
.footer__inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer__logo{color:var(--white);font-weight:700;font-size:1rem}
.footer__links{display:flex;gap:24px}
.footer__links a:hover{color:var(--yellow)}

/* ===== SCROLL TO TOP ===== */
.scroll-to-top {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 60px;
    height: 60px;
    background-color: var(--orange);
    border-radius: 50%;
    color: var(--white);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 15px rgba(238,97,51,.4);
    z-index: 999;
    opacity: 0;
    pointer-events: none;
    transform: translateY(20px);
    transition: all 0.4s var(--ease);
}
.scroll-to-top.visible {
    opacity: 1;
    pointer-events: all;
    transform: translateY(0);
}
.scroll-to-top:hover {
    transform: translateY(0) scale(1.1);
    background-color: var(--black);
}

/* ===== MOBILE NAV ===== */
.mobile-menu{display:flex;visibility:hidden;position:fixed;inset:0;background:var(--sand);z-index:999;flex-direction:column;justify-content:center;align-items:center;gap:32px;opacity:0;pointer-events:none;transition:opacity .3s,visibility .3s}
.mobile-menu.open{visibility:visible;opacity:1;pointer-events:all}
.mobile-menu a{font-size:1.5rem;font-weight:700}
.lang-switch--mobile{font-size:1rem;padding:8px 14px;background:rgba(255,255,255,.5);border-radius:100px}
.lang-switch--mobile .lang-text{font-size:0.95rem}

/* ===== RESPONSIVE ===== */
@media(max-width:968px){
  .nav-pill{display:none}.nav__burger{display:flex}
  .team-grid,.synergy__grid{grid-template-columns:1fr}
  .sectors,.cocreation-steps{grid-template-columns:1fr}
  .pilot-box__benefits{flex-direction:column;align-items:center}
}
@media(max-width:600px){
  .hero__title{font-size:2.2rem}
  .section__title{font-size:1.8rem}
  .container{width:92%}
  .location-hero{aspect-ratio:16/9}
}

/* ===== SUB-PAGE TOP SPACING (accounts for fixed nav) ===== */
.section--page-start{padding-top:calc(var(--nav-h) + clamp(80px,12vh,140px))}

/* ===== LANGUAGE TRANSITION ===== */
body::after {
    content: '';
    position: fixed;
    inset: 0;
    background: var(--sand);
    z-index: 9999;
    pointer-events: none;
    opacity: 0;
    transition: opacity .18s ease;
}
body.lang-transitioning::after {
    opacity: 1;
}

/* ===== LOGO IMAGE ===== */
.nav__logo { padding: 4px 0; }
.nav__logo-img {
    height: 48px;
    width: auto;
    display: block;
    /* Logo has light bg — invert slightly on dark scrolled nav if needed */
    transition: opacity .3s;
}
.nav__logo-img:hover { opacity: .85; }

.footer__logo-img {
    height: 56px;
    width: auto;
    display: block;
    /* Logo is dark on light — apply brightness filter for dark footer bg */
    filter: brightness(0) invert(1);
    opacity: .85;
}

/* section--sand */
.section--sand { background: var(--sand); }

/* ===== KEYFRAMES (moved from inline <style>) ===== */
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.3; }
}
@keyframes pulse-border {
  0%   { box-shadow: 0 0 0 0   rgba(216,180,255,0.6); }
  70%  { box-shadow: 0 0 0 10px rgba(216,180,255,0);   }
  100% { box-shadow: 0 0 0 0   rgba(216,180,255,0);   }
}
@keyframes ars-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.3; }
}
@keyframes dpp-p {
  50%      { opacity: 0.25; }
}

/* ===== FABRIC PAGE OVERRIDES (Homepage) ===== */
.page--fabric .section--white,
.page--fabric .section--sand {
    background: transparent !important;
}
.page--fabric .feature-card {
    background: rgba(255, 255, 255, 0.4) !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
