@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--header-space,150px)}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial;color:rgba(255,255,255,.90);background:
  radial-gradient(900px 520px at 18% 0%, rgba(var(--accent-rgb),.18), transparent 60%),
  radial-gradient(800px 520px at 88% 8%, rgba(var(--accent-rgb),.12), transparent 60%),
  linear-gradient(180deg,#070709,#0a0a10);
  line-height:1.6}
/* IMPORTANT: The hero background must NOT be global.
   Keep the site background clean; apply imagery only inside .hero. */
body::before{content:"";position:fixed;inset:0;z-index:-2;background:linear-gradient(180deg,#060608,#0a0a10);pointer-events:none}
body::after{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(900px 600px at 18% 18%, rgba(var(--accent-rgb),.10), rgba(0,0,0,.22) 55%, rgba(0,0,0,.80)), linear-gradient(180deg, rgba(0,0,0,.42), rgba(0,0,0,.90));pointer-events:none}

img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}

/* gold selection highlight (replace blue) */
::selection{background:rgba(var(--accent-rgb),.90);color:#0b0b0b}

/* ensure content is never hidden behind fixed header
   - On pages WITH a hero, we keep the hero background at the top (no blank bar).
   - On pages WITHOUT a hero, main is padded to sit below the fixed header.
*/
body:not(.has-hero) main{padding-top:var(--header-space,150px)}
section[id], [id].section{scroll-margin-top:var(--header-space,150px)}
:root{
  /* Luxury Black & Gold palette */
  /* stronger gold accent */
  --accent:#d9ba70;
  --accent-2:#e8cc84;
  --gold:var(--accent);
  --accent-rgb:217,186,112;
  --accent-2-rgb:232,204,132;

  --bg:#070709;
  /* slightly more transparent surfaces (cleaner glass feel) */
  --panel:rgba(255,255,255,.03);
  --panel-2:rgba(255,255,255,.05);

  --ink:#0a0a0f;     /* used as a deep “ink” surface */
  --ink-2:#11111a;   /* hover surface */

  --muted:rgba(255,255,255,.68);
  --soft:rgba(255,255,255,.025);
  --border:rgba(255,255,255,.09);
  --shadow:0 18px 55px rgba(0,0,0,.55);
  --shadow-soft:0 12px 34px rgba(0,0,0,.35);

  --container:1220px;
  --ease:cubic-bezier(.2,.8,.2,1);}

h1,h2,h3,h4,h5,h6{color:rgba(255,255,255,.95)}
.container{width:min(var(--container),calc(100% - 48px));margin:0 auto}
@media(max-width:520px){.container{width:calc(100% - 32px)}}

.skip-link{position:absolute;left:-999px;top:10px;background:rgba(0,0,0,.78);color:rgba(255,255,255,.92);padding:10px 12px;border-radius:10px;z-index:9999;border:1px solid var(--border);backdrop-filter:blur(10px)}
.skip-link:focus{left:12px}

.topbar{display:none}
.topbar .row{display:flex;align-items:center;justify-content:flex-end;gap:16px;padding:10px 0;flex-wrap:wrap}
.topbar .chip{display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
.icon-16{width:16px;height:16px}

.header{position:fixed;top:28px;left:0;right:0;z-index:80;background:transparent;border:0;padding:0}
.header .navbar{pointer-events:auto}
.nav-shell{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  /* match the reference: narrower glass bar, slightly lower height */
  max-width:1240px;margin:0 auto;
  /* target ~2.8cm visual height: keep the bar centered, add vertical room */
  /* allow the larger logo to breathe without crowding the nav */
  min-height:118px;
  padding:22px 24px;
  border-radius:18px;
  /* more transparent + gold-tinted glass (clean, not loud) */
  background:linear-gradient(180deg, rgba(var(--accent-rgb),.09), rgba(0,0,0,.02));
  border:1px solid rgba(var(--accent-rgb),.18);
  box-shadow:0 12px 32px rgba(0,0,0,.20), 0 0 54px rgba(var(--accent-rgb),.08);
  backdrop-filter:blur(18px)
}
.brand{
  /* allow consistent sizing/indent for the two-line wordmark */
  --brand-mark:62px;
  --brand-gap:12px;
  display:flex;align-items:center;gap:14px;text-decoration:none;
  /* nudge the wordmark slightly down/right to match the reference balance */
  transform:translate(10px, 8px);
}
.brand-stack{display:flex;flex-direction:column;align-items:flex-start;gap:2px;line-height:1.05}
.brand-row{display:flex;align-items:center;gap:var(--brand-gap)}
.brand-mark{height:var(--brand-mark);width:var(--brand-mark);object-fit:contain;filter:drop-shadow(0 10px 24px rgba(0,0,0,.35))}
.brand-text{
  font-weight:950;
  font-size:54px;
  letter-spacing:.01em;
  line-height:1;
  display:inline-flex;
  align-items:baseline;
  color:#fff;
  /* Trajan Pro ist eine proprietäre Schrift – wird genutzt, wenn beim Besucher vorhanden/geladen. */
  font-family:"Trajan Pro","TrajanPro","Trajan Pro 3","Trajan Pro Regular",serif;
  text-shadow:0 0 22px rgba(var(--accent-rgb),.18),0 14px 36px rgba(0,0,0,.55)
}
.brand-text__p,.brand-text .brand-text__p{color:var(--gold) !important;text-shadow:0 0 26px rgba(var(--accent-rgb),.38),0 14px 36px rgba(0,0,0,.55)}
.brand-subtitle{
  /* start the subtitle under the “PARS” text (not under the mark) */
  margin-left:calc(var(--brand-mark) + var(--brand-gap));
  font-weight:750;
  font-size:.74rem;
  letter-spacing:.04em;
  color:rgba(255,255,255,.90);
  text-shadow:0 0 18px rgba(var(--accent-rgb),.18),0 10px 26px rgba(0,0,0,.45)
}
@media(max-width:520px){
  .brand{--brand-mark:48px;transform:translate(6px, 6px);}
  .brand-text{font-size:42px}
  .brand-subtitle{font-size:.70rem}
}
.nav{display:none;align-items:center;gap:18px}
.nav a{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 12px;border-radius:12px;
  color:rgba(255,255,255,.92);
  font-weight:900;font-size:0.95rem;letter-spacing:.02em;
  text-decoration:none;position:relative;
  transition:background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease), box-shadow .2s var(--ease);
  text-shadow:0 0 16px rgba(var(--accent-rgb),.18), 0 10px 30px rgba(0,0,0,.45)
}
.nav a::after{
  content:"";position:absolute;left:12px;right:12px;bottom:7px;height:2px;border-radius:99px;
  background:var(--accent);
  transform:scaleX(0);transform-origin:left;
  transition:transform .22s var(--ease), background .22s var(--ease);
  opacity:.95
}
.nav a:not(.nav-contact):hover{
  background:var(--accent);
  color:var(--ink);
  text-shadow:none
}
.nav a:not(.nav-contact):hover::after{transform:scaleX(1);background:var(--ink)}
.nav a[aria-current="page"]{
  background:rgba(var(--accent-rgb),.18);
  outline:1px solid rgba(var(--accent-rgb),.35)
}
.nav a.nav-contact{
  background:var(--ink);
  color:var(--accent);
  border:1px solid rgba(255,255,255,.14);
  padding:10px 14px;
  border-radius:14px;
  text-shadow:none;
  box-shadow:0 10px 22px rgba(0,0,0,.25)
}
.nav a.nav-contact::after{display:none}
.nav a.nav-contact:hover{
  background:var(--ink-2);
  color:var(--accent);
  border-color:rgba(var(--accent-rgb),.55);
  box-shadow:0 12px 28px rgba(0,0,0,.35)
}

/* CHECKS: black tick, gold ring/fill */
.check{background:rgba(var(--accent-rgb),.95);outline:1px solid rgba(var(--accent-rgb),.80);color:var(--ink)}
.check svg path{stroke:var(--ink) !important}
.menu-btn{width:44px;height:44px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);display:grid;place-items:center;cursor:pointer}
.menu-btn:hover{background:rgba(255,255,255,.12)}
.mobile-panel{display:none;padding:12px 0 16px;border-top:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.66);backdrop-filter:blur(14px)}
.mobile-panel a{display:block;padding:12px 12px;border-radius:14px;font-weight:850;color:rgba(255,255,255,.92)}
.mobile-panel a:hover{background:rgba(255,255,255,.08)}
.mobile-panel .actions{display:flex;gap:10px;flex-wrap:wrap;padding-top:10px}
@media(min-width:980px){.nav{display:flex}.nav-actions{display:flex}.menu-btn{display:none}.mobile-panel{display:none!important}}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;border-radius:14px;
  border:1px solid var(--accent);
  font-weight:900;cursor:pointer;user-select:none;
  background:var(--accent);
  color:var(--ink);
  box-shadow:0 14px 34px rgba(0,0,0,.45);
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease, border-color .16s ease, color .16s ease, filter .16s ease
}
.btn:focus{outline:3px solid rgba(var(--accent-rgb),.50);outline-offset:2px}
.btn:hover{transform:translateY(-1px);background:var(--accent-2);border-color:var(--accent-2);color:var(--ink)}

/* Varianten: bleiben als Alias bestehen, aber ohne Farbabweichungen */
.btn-ink,.btn-gold,.btn-gold-solid{
  background:var(--accent);
  border-color:var(--accent);
  color:var(--ink)
}
.btn-ink{box-shadow:0 16px 42px rgba(0,0,0,.55)}
.btn-gold{filter:saturate(1.02)}
.btn-gold-solid{box-shadow:0 18px 52px rgba(0,0,0,.55)}
.btn-outline{
  background:var(--accent);
  border-color:var(--accent);
  color:var(--ink);
  box-shadow:0 0 0 1px rgba(0,0,0,.10) inset, 0 12px 28px rgba(0,0,0,.35)
}

.hero{min-height:100vh;padding-top:0;position:relative;display:flex;align-items:stretch;color:#fff}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.82) 0%,rgba(0,0,0,.62) 45%,rgba(0,0,0,.28) 100%),url("./../img/hero-bg.png");background-size:cover;background-position:center;filter:saturate(.92) contrast(1.08)}
/* Hero background: remove gold glow overlay so only the image + neutral dark overlay remains */
.hero::after{content:"";position:absolute;inset:0;background:none;pointer-events:none}
.hero .container{
  position:relative;
  z-index:1;
  /* keep hero image starting at the very top; only move the content below the fixed header */
  padding:calc(var(--header-space,150px) + 26px) 0 46px;
  display:flex;
  align-items:center
}
.hero-grid{width:100%;display:grid;gap:22px;grid-template-columns:1fr;align-items:center}
.hero h1{margin:0 0 12px;font-size:clamp(2.2rem,3.8vw,3.6rem);letter-spacing:-.6px;line-height:1.05;text-transform:uppercase;text-shadow:0 18px 70px rgba(0,0,0,.70)}
.hero p{margin:0 0 10px;color:rgba(255,255,255,.88);max-width:62ch;text-shadow:0 10px 34px rgba(0,0,0,.60)}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}
.hero-side{display:flex;justify-content:center}
.hero-figure{width:min(420px,100%);border-radius:22px;overflow:hidden;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);box-shadow:0 26px 70px rgba(0,0,0,.35)}
.hero-figure img{width:100%;height:420px;object-fit:cover;transform:scale(1.02)}
@media(min-width:980px){
  .hero-grid{grid-template-columns:1.15fr .85fr}
  .hero .container{padding:calc(var(--header-space,150px) + 40px) 0 62px}
  .hero-figure img{height:520px}
}

.bullets{margin:16px 0 18px;padding:0;list-style:none;display:grid;gap:10px}
.bullet{display:flex;align-items:flex-start;gap:10px;color:rgba(255,255,255,.92)}
.check{width:22px;height:22px;border-radius:999px;background:rgba(var(--accent-rgb),.22);outline:1px solid rgba(var(--accent-rgb),.52);display:grid;place-items:center;flex:0 0 22px;color:#fff}
.check svg{width:14px;height:14px}



/* ========== STATS BAR (unter Hero) ========== */
.hero-stats{
  position:relative;
  z-index:6;
  /* Abstand unter dem Hero (kein Overlap) */
  margin-top:24px;
  padding:0 0 18px;
}
.stats-bar{
  width:min(1120px,100%);
  margin:0 auto;
  display:flex;
  align-items:stretch;
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(var(--accent-rgb),.22);
  background:rgba(255,255,255,.04);
  box-shadow:0 22px 62px rgba(0,0,0,.60),0 0 72px rgba(var(--accent-rgb),.10);
  backdrop-filter:blur(18px);
}
.stats-bar__left{
  flex:0 0 34%;
  padding:26px 26px;
  background:
    radial-gradient(520px 260px at 20% 10%, rgba(var(--accent-rgb),.22), transparent 60%),
    linear-gradient(180deg, rgba(10,10,15,.92), rgba(10,10,15,.76));
  border-right:1px solid rgba(255,255,255,.10);
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:6px;
}
.stats-big{
  font-weight:950;
  font-size:clamp(2.4rem, 3.4vw, 3.2rem);
  letter-spacing:-.02em;
  line-height:1;
  color:#fff;
  text-shadow:0 18px 70px rgba(0,0,0,.72);
}
.stats-big__unit{font-size:.55em;opacity:.95;margin-left:4px;color:var(--accent)}
.stats-title{font-weight:900;letter-spacing:.02em;color:rgba(255,255,255,.92)}
.stats-note{color:rgba(255,255,255,.70);font-weight:650;font-size:.95rem;max-width:28ch}

.stats-bar__right{
  flex:1;
  padding:18px 22px;
  display:grid;
  gap:10px;
  grid-template-columns:repeat(4,1fr);
  align-items:center;
  background:
    radial-gradient(520px 280px at 85% 0%, rgba(var(--accent-rgb),.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
}
.metric{
  padding:14px 10px;
  text-align:center;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.16);
}
.metric__value{
  font-weight:950;
  letter-spacing:.01em;
  color:var(--accent);
  font-size:clamp(1.25rem, 2.0vw, 1.65rem);
  text-shadow:0 0 24px rgba(var(--accent-rgb),.18);
}
.metric__label{
  margin-top:4px;
  color:rgba(255,255,255,.78);
  font-weight:750;
  font-size:.92rem;
  line-height:1.25;
}

@media(max-width:980px){
  .stats-bar__right{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:720px){
  .hero-stats{margin-top:16px}
  .stats-bar{flex-direction:column}
  .stats-bar__left{flex:0 0 auto;border-right:0;border-bottom:1px solid rgba(255,255,255,.10)}
  .stats-note{max-width:none}
}

.partners-grid{margin-top:26px;display:grid;gap:14px;grid-template-columns:repeat(2,1fr)}
@media(min-width:760px){.partners-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1100px){.partners-grid{grid-template-columns:repeat(6,1fr)}}
.partner-card{border-radius:0;overflow:visible;background:transparent;border:0;box-shadow:none;transition:transform .18s ease;display:flex;align-items:center;justify-content:center;padding:0}
.partner-card img{width:auto;height:clamp(46px, 4.2vw, 74px);max-width:170px;object-fit:contain;filter:saturate(1) contrast(1.06) drop-shadow(0 10px 26px rgba(0,0,0,.55)) drop-shadow(0 0 22px rgba(var(--accent-rgb),.18));opacity:.98}
/* Wenn Logos sehr dunkel/monochrom sind (z.B. schwarze Platzhalter),
   werden sie per JS als .logo-dark markiert und hier automatisch aufgehellt,
   damit sie auf dem dunklen Background sichtbar sind. */
.partner-card img.logo-dark{
  filter:invert(1) brightness(1.25) contrast(1.08)
    drop-shadow(0 10px 26px rgba(0,0,0,.55))
    drop-shadow(0 0 22px rgba(var(--accent-rgb),.22));
}
.partner-card:hover{transform:translateY(-2px);border-color:rgba(var(--accent-rgb),.22);box-shadow:0 18px 46px rgba(0,0,0,.48),0 0 62px rgba(var(--accent-rgb),.14)}
/* Referenzen: Logo-Reihe (wie Screenshot) */
.refs-logos{
  margin-top:26px;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:28px;
}
.refs-logos img{
  width:auto;
  height:auto;               /* passt sich dem Bild an */
  max-height:72px;           /* verhindert riesige Logos */
  max-width:min(190px, 34vw);
  object-fit:contain;
  filter:drop-shadow(0 10px 26px rgba(0,0,0,.22)) drop-shadow(0 0 18px rgba(var(--accent-rgb),.12));
  opacity:.98;
}

/* Debug-Fallback: sichtbar, wenn ein Logo nicht geladen wird (Pfad/Name/Endung) */
.refs-logos img.img-missing{
  width:160px;
  height:56px;
  border:1px dashed rgba(var(--accent-rgb),.35);
  border-radius:14px;
  background:rgba(0,0,0,.08);
  filter:none;
  opacity:1;
}
.refs-cta{ text-align:center; margin-top:18px; }

@media(max-width:720px){
  .refs-logos{ gap:18px; }
  .refs-logos img{ max-height:56px; }
}


.trust-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.trust-pill{display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border-radius:999px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.92);font-weight:850}
.trust-pill .badge{width:28px;height:28px;border-radius:999px;background:rgba(var(--accent-rgb),.16);outline:1px solid rgba(var(--accent-rgb),.28);display:grid;place-items:center}
.trust-pill .badge svg{width:16px;height:16px}

.section{padding:70px 0}
.section.soft{background:var(--soft)}
.section .eyebrow{color:var(--accent);font-weight:900;display:inline-flex;gap:10px;align-items:center}
.section .eyebrow::before{content:"";width:4px;height:26px;background:var(--accent);border-radius:99px}
.section h2{margin:12px 0 12px;font-size:clamp(1.6rem,2.4vw,2.1rem);line-height:1.2;letter-spacing:-.3px}
.section p{margin:0 0 12px;color:var(--muted)}
.lead{font-size:1.06rem;color:rgba(255,255,255,.78)}

.split{display:grid;gap:26px;grid-template-columns:1fr;align-items:center}
@media(min-width:980px){.split{grid-template-columns:1.05fr .95fr}.split.reverse{grid-template-columns:.95fr 1.05fr}.split.reverse .split-text{order:2}.split.reverse .split-media{order:1}}

.media{
  border-radius:22px;
  overflow:hidden;
  /* always-on gold glow */
  box-shadow:var(--shadow-soft),0 0 56px rgba(var(--accent-rgb),.12),0 0 72px rgba(var(--accent-rgb),.10);
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.09);
  transform:translateZ(0);
  will-change:transform, box-shadow;
  transition:transform .28s var(--ease), box-shadow .28s var(--ease), border-color .28s var(--ease), background .28s var(--ease)
}
.media img{width:100%;height:360px;object-fit:cover;transform:scale(1.02);transition:transform .55s var(--ease)}
.media:hover{
  /* subtle “comes forward” feel */
  transform:translateY(-4px) scale(1.01);
  box-shadow:0 22px 60px rgba(0,0,0,.60),0 0 84px rgba(var(--accent-rgb),.18),0 0 110px rgba(var(--accent-rgb),.12);
  border-color:rgba(var(--accent-rgb),.22);
  background:rgba(var(--accent-rgb),.04)
}
.media:hover img{transform:scale(1.06)}
@media(max-width:520px){.media img{height:260px}}

.list{margin:14px 0 0;padding-left:18px;color:rgba(255,255,255,.78)}
.list li{margin:8px 0}

.card-grid{display:grid;gap:18px;grid-template-columns:1fr;margin-top:18px}
@media(min-width:980px){.card-grid{grid-template-columns:1fr 1fr}}
.card{background:var(--panel);border:1px solid rgba(255,255,255,.09);border-radius:16px;box-shadow:var(--shadow-soft),0 0 46px rgba(var(--accent-rgb),.07);padding:18px;transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 18px 46px rgba(0,0,0,.45);border-color:rgba(var(--accent-rgb),.22);background:rgba(var(--accent-rgb),.06)}
.card h3{margin:0 0 10px;color:rgba(255,255,255,.92);font-size:1.15rem;letter-spacing:-.2px;display:flex;align-items:center;gap:10px}
.card h3 svg{width:20px;height:20px}
.card h3 svg path{stroke:rgba(var(--accent-rgb),.95)}
.checklist{list-style:none;padding:0;margin:0;display:grid;gap:8px;color:rgba(255,255,255,.78)}
.checklist li{display:flex;gap:10px;align-items:flex-start}
.tick{width:18px;height:18px;margin-top:2px;border-radius:999px;background:rgba(var(--accent-rgb),.95);outline:1px solid rgba(var(--accent-rgb),.80);display:grid;place-items:center;flex:0 0 18px;color:var(--ink)}
.tick svg path{stroke:var(--ink) !important}
.tick svg{width:12px;height:12px}

.cert-wrap{background:rgba(255,255,255,.022);border:1px solid rgba(255,255,255,.09);border-radius:18px;box-shadow:var(--shadow);padding:28px}
@media(min-width:980px){.cert-wrap{padding:44px}}
.cert-wrap h2{margin:0 0 18px;font-size:clamp(1.6rem,2.1vw,2.2rem);letter-spacing:-.4px}

.cert-grid{display:grid;gap:26px;grid-template-columns:1fr;align-items:start}
@media(min-width:980px){.cert-grid{grid-template-columns:1.15fr .85fr;gap:42px}}

.cert-left p{margin:0 0 14px;color:rgba(255,255,255,.78);max-width:70ch}
.cert-logos{display:flex;gap:18px;flex-wrap:wrap;align-items:center;margin-top:14px}
.cert-logos img{height:48px;width:auto;object-fit:contain;filter:grayscale(.05);opacity:.95}

.cert-right-lead{margin:0 0 14px;color:rgba(255,255,255,.78)}

.cert-tiles{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:620px){.cert-tiles{grid-template-columns:repeat(3,1fr)}}

.cert-tile{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:16px;display:flex;align-items:center;justify-content:center;gap:12px;min-height:130px;text-align:center;box-shadow:var(--shadow-soft);transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease}
.cert-tile:hover{transform:translateY(-2px);box-shadow:0 18px 46px rgba(0,0,0,.55);border-color:rgba(var(--accent-rgb),.22);background:rgba(var(--accent-rgb),.06)}

/* replace any legacy blue icon strokes with gold */
.cert-tile .go svg path{stroke:rgba(var(--accent-rgb),.95) !important}

.cert-tile--stack{flex-direction:column}
.cert-badge{width:74px;height:74px;display:block;border-radius:20px;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.10);box-shadow:var(--shadow-soft);padding:10px}
.cert-label{font-weight:800;color:rgba(255,255,255,.92);letter-spacing:-.2px}
.cert-label span{display:inline;color:var(--muted);font-weight:700;margin-left:6px}


.center-head{padding:52px 0;text-align:center}
.center-head h2{margin:0 0 10px;font-size:clamp(1.7rem,2.2vw,2.2rem)}
.center-head p{margin:0 auto;color:var(--muted);max-width:72ch}

.breadcrumb{font-size:.92rem;color:var(--muted);margin-bottom:10px}
.breadcrumb a{color:var(--muted);text-decoration:underline;text-decoration-color:rgba(var(--accent-rgb),.35)}
.breadcrumb a:hover{text-decoration-color:rgba(var(--accent-rgb),.65)}

.cert-box{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.10);border-radius:14px;box-shadow:var(--shadow);padding:14px;text-align:center}
.cert-box img{width:100%;height:360px;object-fit:contain;background:transparent}
.cert-box .small{margin:10px 0 12px;color:var(--muted);font-size:.92rem}

.footer{background:#050508;color:rgba(255,255,255,.92);padding:50px 0 18px;border-top:1px solid rgba(255,255,255,.06)}
.footer .grid{display:grid;gap:18px;grid-template-columns:1fr}
@media(min-width:980px){.footer .grid{grid-template-columns:1.1fr 1fr 1fr 2fr}}
.footer a{color:rgba(255,255,255,.92)}
.footer a:hover{text-decoration:underline}
.footer a.btn{color:var(--ink)}
.footer a.btn:hover{color:var(--ink)}
.footer-contact-highlight{margin-top:12px;line-height:1.7}
.footer-contact-highlight .label-accent{color:var(--accent);font-weight:900}
.footer-contact-highlight a{color:rgba(255,255,255,.92);text-decoration:underline;text-decoration-color:rgba(255,255,255,.35)}
.footer-contact-highlight a:hover{text-decoration-color:rgba(255,255,255,.70)}

.footer-training{margin-top:14px}
.footer-subhead{margin:12px 0 8px;font-size:1rem;color:rgba(255,255,255,.92)}

.footer-hotline{
  margin-top:0;
  padding:26px 24px;
  border-radius:18px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:var(--shadow-soft);
  position:relative
}
.footer-hotline::before{
  content:"";
  position:absolute;
  left:16px;
  top:18px;
  bottom:18px;
  width:4px;
  border-radius:999px;
  background:var(--accent)
}
.footer-hotline > *{padding-left:20px}
.footer-hotline h4{
  margin:0 0 12px;
  font-size:1.35rem;
  letter-spacing:.02em;
  text-transform:uppercase
}
.footer-hotline p{margin:0;color:rgba(255,255,255,.90);font-size:1.15rem;line-height:1.65}
.footer-hotline strong, .footer-hotline a{color:var(--accent)}
.footer-hotline a:hover{text-decoration:underline}



.footer h3{margin:0 0 10px;font-size:1.05rem}
.footer .muted{color:rgba(255,255,255,.72)}
.footer .bottom{margin-top:18px;padding-top:14px;border-top:1px solid rgba(255,255,255,.16);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:rgba(255,255,255,.68)}



/* === STATS BAR (unter Hero) === */
@media(min-width:980px){
}




@media(min-width:720px){
}



/* === REFERENCES / PARTNERSHIPS STRIP === */
.refs{text-align:center}
.refs p{max-width:72ch;margin-left:auto;margin-right:auto}
.partner-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:26px}
@media(min-width:720px){.partner-grid{grid-template-columns:repeat(6,1fr)}}
.partner-card{border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.03);box-shadow:var(--shadow-soft),0 0 46px rgba(var(--accent-rgb),.08);transition:transform .18s var(--ease), box-shadow .18s var(--ease)}
.partner-card img{width:100%;height:76px;object-fit:contain;padding:14px;filter:grayscale(.05);opacity:.95}
.partner-card:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 18px 50px rgba(0,0,0,.55),0 0 62px rgba(var(--accent-rgb),.14)}


/* Footer CTA: "Kontakt" button should be the brand blue (not white) */

.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:100;display:none;background:rgba(7,7,9,.78);color:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.14);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.55);padding:14px;backdrop-filter:blur(14px)}
.cookie-banner .row{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.cookie-banner p{margin:0;max-width:75ch;color:rgba(255,255,255,.80);font-size:.95rem}
.modal{position:fixed;inset:0;display:none;z-index:120;background:rgba(0,0,0,.55);padding:18px}
.modal .panel{width:min(720px,100%);margin:40px auto;background:rgba(10,10,14,.92);border-radius:18px;box-shadow:0 30px 80px rgba(0,0,0,.55);overflow:hidden;border:1px solid rgba(255,255,255,.12)}
.modal header,.modal footer{padding:14px 16px;display:flex;justify-content:space-between;align-items:center;gap:12px;background:rgba(10,10,14,.92)}
.modal header{border-bottom:1px solid rgba(255,255,255,.10)}
.modal footer{border-top:1px solid rgba(255,255,255,.10)}
.modal main{padding:16px}
.x{width:42px;height:42px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:rgba(255,255,255,.90);cursor:pointer}
.x:hover{background:rgba(var(--accent-rgb),.08);border-color:rgba(var(--accent-rgb),.30)}
.toggle{border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:12px;background:rgba(255,255,255,.03);margin-bottom:10px}
.toggle .trow{display:flex;justify-content:space-between;gap:12px;align-items:center}
.toggle p{margin:6px 0 0;color:var(--muted);font-size:.95rem}
.switch{width:54px;height:30px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);position:relative;cursor:pointer;flex:0 0 auto}
.switch::after{content:"";position:absolute;top:2px;left:2px;width:24px;height:24px;border-radius:999px;background:var(--ink);transition:transform .18s ease}
.switch[data-on="true"]{background:rgba(var(--accent-rgb),.16);border-color:rgba(var(--accent-rgb),.55)}
.switch[data-on="true"]::after{transform:translateX(24px)}
.switch[aria-disabled="true"]{opacity:.55;cursor:not-allowed}

.field{display:grid;gap:6px;margin-bottom:12px}
.field label{font-weight:900;color:rgba(255,255,255,.88)}
.field input,.field textarea{border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:12px 12px;font:inherit;background:rgba(0,0,0,.22);color:rgba(255,255,255,.90)}
.field input:focus,.field textarea:focus{outline:0;border-color:rgba(var(--accent-rgb),.55);box-shadow:0 0 0 4px rgba(var(--accent-rgb),.12)}
.field textarea{min-height:120px;resize:vertical}

/* ===== Hidden fields (Spam / Honeypot) ===== */
.honeypot{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

/* ===== MAP (Consent / Opt-in) ===== */
.mapbox{border:1px solid rgba(255,255,255,.10);border-radius:18px;overflow:hidden;background:rgba(255,255,255,.03);box-shadow:var(--shadow-soft)}
.map-placeholder{padding:18px}
.map-placeholder h3{margin:0 0 8px;color:rgba(255,255,255,.92)}
.map-embed{width:100%;height:380px;border:0;display:none}

/* ===== Legal pages ===== */
.legal h2{margin:22px 0 10px;color:rgba(255,255,255,.92);letter-spacing:-.2px}
.legal h2.legal-highlight-title{
  /* Zurück zur normalen Überschrift – nur Text gelb, keine gelbe Badge-Fläche */
  display:block;
  background:transparent;
  color:var(--accent);
  padding:0;
  border-radius:0;
  box-shadow:none;
}
.legal h3{margin:18px 0 8px;color:rgba(255,255,255,.92)}
.legal p,.legal li{color:var(--muted)}
.legal ul{margin:10px 0 14px;padding-left:18px}
.legal .box{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.10);border-radius:16px;box-shadow:var(--shadow-soft);padding:18px}

/* Impressum: Bild in die freie rechte Fläche wie im Referenz-Screenshot */
.legal-grid{display:grid;gap:18px;grid-template-columns:1fr;align-items:start}
.legal-right .media img{height:520px;object-fit:cover}

/* Impressum: Logo-Platzhalter links neben dem Bild */
.impressum-media-row{display:flex;gap:16px;align-items:flex-start}
.impressum-logo-slot{
  width:160px;
  height:160px;
  border-radius:18px;
  border:2px dashed rgba(255,255,255,.22);
  background:rgba(255,255,255,.03);
  display:grid;
  place-items:center;
  color:rgba(255,255,255,.78);
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
}
.impressum-logo-slot small{display:block;opacity:.85;font-weight:800;letter-spacing:.08em}
@media(max-width:980px){
  .impressum-media-row{flex-direction:column}
  .impressum-logo-slot{width:100%;max-width:280px;height:140px}
}
@media(min-width:980px){
  .legal-grid{grid-template-columns:1fr 420px;gap:22px}
  .legal-right{position:sticky;top:130px}
}

/* ========== PARTNERS / LOGOS ========== */
.partners{padding:70px 0;background:var(--soft)}
.partners h2{margin:12px 0 18px}
.partners-grid{display:grid;gap:16px;grid-template-columns:repeat(2,1fr);align-items:center}
@media(min-width:760px){.partners-grid{grid-template-columns:repeat(4,1fr)}}
.partner-logo{width:100%;height:72px;object-fit:contain;filter:grayscale(.15) contrast(1.05);opacity:.95}
.partner-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.10);border-radius:16px;padding:14px;display:grid;place-items:center;box-shadow:var(--shadow-soft)}
.section.dark{background:#0b0f1a;color:#fff}
.section.dark .eyebrow{color:var(--accent)}

/* ========== REVEAL / SCROLL ANIMATIONS ========== */
/*
  Wichtig: Der Hintergrund/Abschnitt selbst soll beim Scrollen NICHT „hochkommen“.
  Deshalb bleiben [data-reveal]-Container immer sichtbar.
  Animiert werden nur Text-Elemente (.anim), nicht die Flächen.
*/
.js [data-reveal]{opacity:1;transform:none;transition:none;will-change:auto}
.js [data-reveal].is-visible{opacity:1;transform:none}

/* Bigger fly-in animations for text & blocks (still clean) */
.js .anim{opacity:0;will-change:opacity, transform, filter}
.js .anim[data-anim="up"]{transform:translate3d(0,70px,0);filter:blur(2px)}
.js .anim[data-anim="fade"]{transform:translate3d(0,36px,0);filter:blur(2px)}
.js .anim[data-anim="left"]{transform:translate3d(-90px,0,0);filter:blur(2px)}
.js .anim[data-anim="right"]{transform:translate3d(90px,0,0);filter:blur(2px)}
.js .anim[data-anim="zoom"]{transform:translate3d(0,46px,0) scale(.88);filter:blur(2px)}
.js .anim[data-anim="pop"]{transform:scale(.82);filter:blur(1.5px)}

@keyframes flyUpBig{from{opacity:0;transform:translate3d(0,70px,0);filter:blur(2px)}to{opacity:1;transform:none;filter:blur(0)}}
@keyframes flyFade{from{opacity:0;transform:translate3d(0,36px,0);filter:blur(2px)}to{opacity:1;transform:none;filter:blur(0)}}
@keyframes flyLeftBig{from{opacity:0;transform:translate3d(-90px,0,0);filter:blur(2px)}to{opacity:1;transform:none;filter:blur(0)}}
@keyframes flyRightBig{from{opacity:0;transform:translate3d(90px,0,0);filter:blur(2px)}to{opacity:1;transform:none;filter:blur(0)}}
@keyframes zoomRise{from{opacity:0;transform:translate3d(0,46px,0) scale(.88);filter:blur(2px)}to{opacity:1;transform:none;filter:blur(0)}}
@keyframes popIn{0%{opacity:0;transform:scale(.82);filter:blur(1.5px)}70%{opacity:1;transform:scale(1.03);filter:blur(0)}100%{opacity:1;transform:scale(1);filter:blur(0)}}

@media (prefers-reduced-motion: no-preference){
  .js .anim.in{opacity:1;transform:none;filter:none}
  .js .anim.in[data-anim="up"]{animation:flyUpBig .95s var(--ease) both;animation-delay:var(--delay,0ms)}
  .js .anim.in[data-anim="fade"]{animation:flyFade .85s var(--ease) both;animation-delay:var(--delay,0ms)}
  .js .anim.in[data-anim="left"]{animation:flyLeftBig 1.0s var(--ease) both;animation-delay:var(--delay,0ms)}
  .js .anim.in[data-anim="right"]{animation:flyRightBig 1.0s var(--ease) both;animation-delay:var(--delay,0ms)}
  .js .anim.in[data-anim="zoom"]{animation:zoomRise .95s var(--ease) both;animation-delay:var(--delay,0ms)}
  .js .anim.in[data-anim="pop"]{animation:popIn .85s var(--ease) both;animation-delay:var(--delay,0ms)}
}

.hero-grid--single{grid-template-columns:1fr}

.page-hero{padding:56px 0 36px;background:none}
.page-hero h1{margin-top:0}


/* ========== HERO ENTRANCE ANIMATION ========== */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px) scale(.985)}to{opacity:1;transform:none}}
@keyframes heroKenBurns{from{transform:scale(1.07)}to{transform:scale(1.01)}}
@keyframes glowDrift{from{transform:translate3d(-2%, -2%, 0)}to{transform:translate3d(3%, 2%, 0)}}
@keyframes headerDrop{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
@keyframes floatSoft{0%,100%{transform:translateY(0) scale(1.02)}50%{transform:translateY(-6px) scale(1.02)}}

@media (prefers-reduced-motion: no-preference){
  /* Kein Ken-Burns / Drift im Hero-BG: Hintergrund bleibt „direkt da“ */
  .hero::before{animation:none!important;transform:none!important}
  .hero::after{animation:none!important;transform:none!important}
  .header{animation:headerDrop .55s cubic-bezier(.2,.8,.2,1) both}
  .hero h1{animation:fadeUp .72s cubic-bezier(.2,.8,.2,1) both;animation-delay:.05s}
  .hero .lead{animation:fadeUp .72s cubic-bezier(.2,.8,.2,1) both;animation-delay:.12s}
  .hero p:not(.lead){animation:fadeUp .72s cubic-bezier(.2,.8,.2,1) both;animation-delay:.16s}
  .hero .bullet{opacity:0;transform:translateY(14px) scale(.99);will-change:opacity, transform;animation:fadeUp .66s cubic-bezier(.2,.8,.2,1) both}
  .hero .bullet:nth-child(1){animation-delay:.22s}
  .hero .bullet:nth-child(2){animation-delay:.28s}
  .hero .bullet:nth-child(3){animation-delay:.34s}
  .hero .bullet:nth-child(4){animation-delay:.40s}
  .hero-actions{animation:fadeUp .72s cubic-bezier(.2,.8,.2,1) both;animation-delay:.48s}
  /* Nur Text animieren: keine permanente Bild-Float-Animation */
  .hero-figure img{animation:none!important}
  .hero .trust-pill{opacity:0;transform:translateY(12px);will-change:opacity, transform;animation:fadeUp .66s cubic-bezier(.2,.8,.2,1) both}
  .hero .trust-pill:nth-child(1){animation-delay:.58s}
  .hero .trust-pill:nth-child(2){animation-delay:.64s}
  .hero .trust-pill:nth-child(3){animation-delay:.70s}
  .trust-pill{transition:transform .18s ease, background .18s ease, border-color .18s ease}
  .trust-pill:hover{transform:translateY(-1px);background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.22)}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .header{animation:none!important}
  .hero::before,.hero::after{animation:none!important}
  .hero h1,.hero .lead,.hero p:not(.lead),.hero-actions{animation:none!important}
  .hero .bullet,.hero .trust-pill{animation:none!important;opacity:1!important;transform:none!important}
  .js [data-reveal]{transition:none!important;transform:none!important;opacity:1!important}
  .js .anim{transition:none!important;transform:none!important;opacity:1!important;filter:none!important;animation:none!important}
}


/* Partnerships: no fixed boxes; image defines the space */
.partners-grid{display:flex;flex-wrap:wrap;gap:22px;justify-content:center;align-items:center}
.partner-card{background:transparent!important;border:0!important;box-shadow:none!important;padding:0!important;border-radius:0!important;overflow:visible!important;display:inline-flex;align-items:center;justify-content:center}
.partner-card img{width:auto!important;height:auto!important;max-width:100%!important;max-height:none!important;padding:0!important;object-fit:unset!important;filter:saturate(.98) contrast(1.05)}
.partner-card:hover{transform:translateY(-2px) scale(1.02);box-shadow:none!important}

/* ===== v11 tweaks (requested) ===== */

/* Stronger gold highlight */
::selection{background:rgba(var(--accent-rgb),.90);color:#0b0b0b}
::-moz-selection{background:rgba(var(--accent-rgb),.90);color:#0b0b0b}

/* Partnerships: no fixed boxes, image determines size */
.partners-grid{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;align-items:center}
.partner-card{background:transparent !important;border:0 !important;box-shadow:none !important;padding:0 !important;border-radius:0 !important;overflow:visible !important;display:inline-flex !important;align-items:center !important;justify-content:center !important;transform:none !important}
.partner-card img{width:auto !important;height:auto !important;max-width:100% !important;max-height:none !important;padding:0 !important;display:block;filter:saturate(1) contrast(1.05) drop-shadow(0 12px 30px rgba(0,0,0,.45)) drop-shadow(0 0 22px rgba(var(--accent-rgb),.18));opacity:.98}
.partner-card:hover img{transform:translateY(-2px) scale(1.02)}

/* =========================================================
   Partnerships / Referenzen – Layout wie Referenz-Screenshot
   Ziel: keine Boxen, Logos in 4 + 2 (Desktop) / responsiv
   Bilder kommen aus: /Partnerships/assets/img/
   ========================================================= */

/* Container: centered, wraps to a second row naturally */
.partners-grid{
  display:flex !important;
  flex-wrap:wrap !important;
  justify-content:center !important;
  align-items:center !important;
  gap:28px 34px !important;
  margin-top:30px !important;
}

/* Item: no card/box styling, but keep clickable area on index */
.partners-grid .partner-card{
  flex:0 1 150px !important; /* more items per row, still large */
  max-width:170px !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  padding:0 !important;
  border-radius:0 !important;
  overflow:visible !important;
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
}

.partners-grid .partner-card img{
  display:block;
  width:auto !important;
  height:clamp(46px, 4.2vw, 74px) !important;
  max-width:170px !important;
  object-fit:contain !important;
  padding:0 !important;
  border-radius:0 !important;
  opacity:.98;
  filter:saturate(1) contrast(1.06)
    drop-shadow(0 10px 26px rgba(0,0,0,.55))
    drop-shadow(0 0 22px rgba(var(--accent-rgb),.18));
  transition:transform .18s var(--ease);
}

/* Global images: ensure replacements auto-fit the intended UI size */
img{max-width:100%;height:auto;display:block}
.media{border-radius:18px;overflow:hidden}
.media img{width:100%;height:100%;object-fit:cover}

/* Reviews row under hero */
.reviews{padding:22px 0 0}
.reviews-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.review-pill{display:inline-flex;align-items:center;gap:10px;padding:12px 14px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(var(--accent-rgb),.20);box-shadow:0 10px 26px rgba(0,0,0,.35),0 0 28px rgba(var(--accent-rgb),.10);backdrop-filter:blur(14px)}
.review-pill strong{color:#fff}
.stars{display:inline-flex;gap:4px}
.stars svg{width:16px;height:16px}
.stars path{fill:var(--gold)}

/* Subtile 3D-Lift auf Hover */
.partners-grid .partner-card:hover img{
  transform:translateY(-2px) scale(1.02);
}

@media (max-width: 720px){
  .partners-grid{gap:18px 22px !important;}
  .partners-grid .partner-card{flex:0 1 42% !important;max-width:42% !important;}
  .partners-grid .partner-card img{max-width:100% !important;height:clamp(28px, 8vw, 52px) !important;}
}

@media (max-width: 420px){
  .partners-grid .partner-card{flex:0 1 46% !important;max-width:46% !important;}
}

/* Prevent header overlap on certificate pages / anchors */
:root{scroll-padding-top:var(--header-space, 140px)}

