/* ═══════════════════════════════════════════════════════════════
   SIMONE BORCHARDT MdB — Website V3
   CDU CI 2023 · Refined Editorial Design
   ═══════════════════════════════════════════════════════════════ */

/* ── FONTS ───────────────────────────────────────────────────── */
@font-face{font-family:'Inter';font-weight:400;font-style:normal;font-display:swap;src:url('../fonts/Inter-400-normal.woff2')format('woff2')}
@font-face{font-family:'Inter';font-weight:500;font-style:normal;font-display:swap;src:url('../fonts/Inter-500-normal.woff2')format('woff2')}
@font-face{font-family:'Inter';font-weight:600;font-style:normal;font-display:swap;src:url('../fonts/Inter-600-normal.woff2')format('woff2')}
@font-face{font-family:'Inter';font-weight:700;font-style:normal;font-display:swap;src:url('../fonts/Inter-700-normal.woff2')format('woff2')}
@font-face{font-family:'Inter';font-weight:800;font-style:normal;font-display:swap;src:url('../fonts/Inter-800-normal.woff2')format('woff2')}
@font-face{font-family:'Inter';font-weight:900;font-style:normal;font-display:swap;src:url('../fonts/Inter-900-normal.woff2')format('woff2')}
@font-face{font-family:'IBM Plex Serif';font-weight:400;font-style:normal;font-display:swap;src:url('../fonts/IBMPlexSerif-400-normal.woff2')format('woff2')}
@font-face{font-family:'IBM Plex Serif';font-weight:400;font-style:italic;font-display:swap;src:url('../fonts/IBMPlexSerif-400-italic.woff2')format('woff2')}
@font-face{font-family:'IBM Plex Serif';font-weight:600;font-style:normal;font-display:swap;src:url('../fonts/IBMPlexSerif-600-normal.woff2')format('woff2')}
@font-face{font-family:'IBM Plex Serif';font-weight:600;font-style:italic;font-display:swap;src:url('../fonts/IBMPlexSerif-600-italic.woff2')format('woff2')}

/* ── TOKENS ──────────────────────────────────────────────────── */
:root{
  --c-trkis:  #52b7c1;
  --c-trkis2: #3da5ae;
  --c-blau:   #2d3c4b;
  --c-gold:   #ffa600;
  --c-rot:    #bf111b;
  --c-ink:    #0e1015;
  --c-smoke:  #f5f7f9;
  --c-white:  #ffffff;
  --c-muted:  #5a6880;
  --c-border: rgba(14,16,21,.1);
  --shadow-s: 0 2px 8px rgba(14,16,21,.07);
  --shadow-m: 0 6px 24px rgba(14,16,21,.1);
  --shadow-l: 0 16px 56px rgba(14,16,21,.14);

  --f-display: 'Inter',system-ui,sans-serif;
  --f-body: 'IBM Plex Serif',Georgia,serif;

  --nav-h: 74px;
  --ease: cubic-bezier(.4,0,.2,1);
  --dur: .22s;

  --pad-x: clamp(1.25rem,5vw,4rem);
  --max-w: 1280px;
}

/* ── RESET ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h)+1rem)}
body{
  font-family:var(--f-body);font-size:1rem;line-height:1.75;
  color:var(--c-ink);background:var(--c-white);
  overflow-x:hidden;-webkit-font-smoothing:antialiased
}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit;border:none;background:none}
ul{list-style:none}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-thumb{background:var(--c-trkis);border-radius:2px}

/* ── SKIP LINK ───────────────────────────────────────────────── */
.skip-link{
  position:fixed;top:-100px;left:1.5rem;z-index:9999;
  background:var(--c-trkis);color:#fff;padding:.6rem 1.4rem;
  font-family:var(--f-display);font-weight:700;font-size:.85rem;
  border-radius:0 0 4px 4px;transition:top .2s
}
.skip-link:focus{top:0}

/* ════════════════════════════════════════════════════════════════
   NAVBAR — Komplett neu, professionell
   ════════════════════════════════════════════════════════════════ */

/* Hauptleiste */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);
  display:flex;align-items:center;gap:0;
  background:var(--c-ink);
  transition:box-shadow .3s
}
.nav.scrolled{box-shadow:0 4px 40px rgba(0,0,0,.45)}

/* Farbstreifen oben */
.nav::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--c-trkis) 0%,var(--c-gold) 55%,var(--c-rot) 100%)
}

/* Logo-Block */
.nav__logo-block{
  display:flex;align-items:center;gap:.85rem;
  padding:0 2rem 0 var(--pad-x);
  height:100%;flex-shrink:0;
  border-right:1px solid rgba(255,255,255,.06);
  text-decoration:none
}
.nav__logo-wrap{
  background:#fff;padding:5px 8px;
  display:flex;align-items:center;height:42px
}
.nav__logo-wrap img{height:26px;width:auto;display:block}
.nav__name-block{display:flex;flex-direction:column;gap:1px}
.nav__name{
  font-family:var(--f-display);font-weight:700;font-size:.9rem;
  color:#fff;letter-spacing:-.01em;line-height:1.15
}
.nav__role{
  font-family:var(--f-display);font-weight:500;font-size:.65rem;
  color:rgba(82,183,193,.85);letter-spacing:.06em;text-transform:uppercase
}

/* Links-Bereich */
.nav__menu{
  display:flex;align-items:center;gap:0;
  flex:1;padding:0 1rem;height:100%
}
.nav__link{
  font-family:var(--f-display);font-weight:500;font-size:.84rem;
  color:rgba(255,255,255,.58);
  padding:.4rem 1rem;
  display:inline-flex;align-items:center;gap:.3rem;
  border-radius:5px;white-space:nowrap;letter-spacing:.005em;
  transition:color var(--dur),background var(--dur);
  position:relative;height:48px
}
.nav__link:hover{color:#fff;background:rgba(255,255,255,.06)}
.nav__link.active{color:var(--c-trkis)}
.nav__link.active::after{
  content:'';position:absolute;bottom:-13px;left:1rem;right:1rem;
  height:2px;background:var(--c-trkis)
}

/* Dropdown-Gruppe */
.nav__group{position:relative;height:100%;display:flex;align-items:center}
.nav__group-btn{
  font-family:var(--f-display);font-weight:500;font-size:.84rem;
  color:rgba(255,255,255,.58);
  padding:.4rem 1rem;height:48px;
  display:inline-flex;align-items:center;gap:.4rem;
  border-radius:5px;white-space:nowrap;
  transition:color var(--dur),background var(--dur);cursor:pointer
}
.nav__group-btn:hover,.nav__group:hover .nav__group-btn,
.nav__group:focus-within .nav__group-btn{color:#fff;background:rgba(255,255,255,.06)}
.nav__chevron{
  width:13px;height:13px;flex-shrink:0;
  transition:transform .2s var(--ease)
}
.nav__group:hover .nav__chevron,
.nav__group:focus-within .nav__chevron{transform:rotate(180deg)}

/* Dropdown Panel */
.nav__dropdown{
  position:absolute;top:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(-6px);
  background:rgba(18,22,30,.98);backdrop-filter:blur(12px);
  border:1px solid rgba(82,183,193,.18);
  border-top:2px solid var(--c-trkis);
  min-width:230px;padding:.4rem 0;
  opacity:0;pointer-events:none;
  transition:opacity .18s,transform .18s;
  z-index:200;border-radius:0 0 6px 6px;
  box-shadow:0 24px 64px rgba(0,0,0,.55)
}
.nav__group:hover .nav__dropdown,
.nav__group:focus-within .nav__dropdown{
  opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)
}
/* Hover-Bridge verhindert Flickern */
.nav__group::after{
  content:'';position:absolute;top:100%;left:0;right:0;height:12px
}
.nav__dropdown a{
  display:flex;align-items:center;gap:.6rem;
  padding:.7rem 1.25rem;
  font-family:var(--f-display);font-weight:500;font-size:.82rem;
  color:rgba(255,255,255,.58);
  transition:color .14s,background .14s,padding-left .14s;
  border-bottom:1px solid rgba(255,255,255,.04)
}
.nav__dropdown a:last-child{border-bottom:none}
.nav__dropdown a::before{
  content:'';width:5px;height:5px;border-radius:50%;
  background:var(--c-trkis);opacity:0;flex-shrink:0;
  transition:opacity .14s
}
.nav__dropdown a:hover{
  color:#fff;background:rgba(82,183,193,.08);padding-left:1.5rem
}
.nav__dropdown a:hover::before{opacity:1}

/* Rechte Aktionen */
.nav__actions{
  display:flex;align-items:center;gap:.25rem;
  padding:0 var(--pad-x) 0 .5rem;flex-shrink:0
}
.nav__icon-btn{
  color:rgba(255,255,255,.4);
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;
  border-radius:6px;transition:color var(--dur),background var(--dur)
}
.nav__icon-btn:hover{color:#fff;background:rgba(255,255,255,.07)}
.nav__cta-btn{
  font-family:var(--f-display);font-weight:700;font-size:.75rem;
  letter-spacing:.06em;text-transform:uppercase;
  background:var(--c-trkis);color:#fff;
  padding:.55rem 1.25rem;border-radius:4px;
  transition:background var(--dur),transform var(--dur);
  white-space:nowrap
}
.nav__cta-btn:hover{background:var(--c-trkis2);transform:translateY(-1px)}

/* Burger (Mobile) */
.nav__burger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:42px;height:42px;border-radius:6px;padding:8px;
  transition:background var(--dur);margin-left:auto
}
.nav__burger:hover{background:rgba(255,255,255,.07)}
.nav__burger span{
  display:block;width:22px;height:2px;background:rgba(255,255,255,.75);
  border-radius:1px;transition:transform .3s,opacity .3s
}
.nav__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── MOBILE MENÜ ─────────────────────────────────────────────── */
.mobile-nav{
  position:fixed;inset:var(--nav-h) 0 0 0;z-index:999;
  background:var(--c-ink);
  transform:translateX(100%);transition:transform .35s var(--ease);
  overflow-y:auto;padding:1.5rem var(--pad-x) 4rem
}
.mobile-nav.open{transform:none}
.mobile-nav__section-label{
  font-family:var(--f-display);font-weight:700;font-size:.62rem;
  text-transform:uppercase;letter-spacing:.14em;
  color:rgba(82,183,193,.5);
  padding:1.25rem 0 .35rem;margin-top:.5rem;
  border-top:1px solid rgba(255,255,255,.05)
}
.mobile-nav__section-label:first-child{border-top:none;margin-top:0}
.mobile-nav a{
  display:block;font-family:var(--f-display);font-weight:500;font-size:1rem;
  color:rgba(255,255,255,.7);
  padding:.8rem 0;border-bottom:1px solid rgba(255,255,255,.04);
  transition:color var(--dur),padding-left var(--dur)
}
.mobile-nav a.sub{
  font-size:.9rem;color:rgba(255,255,255,.45);padding-left:1rem
}
.mobile-nav a:hover,.mobile-nav a.active{color:var(--c-trkis)}
.mobile-nav__cta{
  display:inline-flex;margin-top:1.5rem;
  background:var(--c-trkis);color:#fff;
  font-family:var(--f-display);font-weight:700;font-size:.82rem;
  letter-spacing:.05em;text-transform:uppercase;
  padding:.85rem 2rem;border-radius:4px;transition:background .2s
}
.mobile-nav__cta:hover{background:var(--c-trkis2)}

/* Suchleiste */
.search-bar{
  position:fixed;top:var(--nav-h);left:0;right:0;z-index:998;
  background:rgba(12,16,22,.97);backdrop-filter:blur(16px);
  padding:1rem var(--pad-x);display:flex;align-items:center;gap:.75rem;
  border-bottom:1px solid rgba(82,183,193,.15);
  transform:translateY(-110%);transition:transform .28s var(--ease)
}
.search-bar.open{transform:none}
.search-bar__input{
  flex:1;background:rgba(255,255,255,.06);border:1.5px solid rgba(82,183,193,.2);
  color:#fff;font-family:var(--f-body);font-size:1rem;
  padding:.7rem 1.1rem;outline:none;border-radius:3px;
  transition:border-color .2s
}
.search-bar__input:focus{border-color:var(--c-trkis)}
.search-bar__input::placeholder{color:rgba(255,255,255,.28)}
.search-bar__close{
  color:rgba(255,255,255,.4);padding:.5rem;
  transition:color var(--dur);display:flex;align-items:center
}
.search-bar__close:hover{color:#fff}

/* ════════════════════════════════════════════════════════════════
   LAYOUT
   ════════════════════════════════════════════════════════════════ */
main{padding-top:var(--nav-h)}
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--pad-x)}
.section{padding:clamp(3.5rem,7vw,6rem) var(--pad-x)}
.section--smoke{background:var(--c-smoke)}
.section--ink{background:var(--c-ink);color:#fff}
.section--blau{background:var(--c-blau);color:#fff}
.section--trkis{background:var(--c-trkis);color:#fff}

/* ── TYPOGRAPHY SYSTEM ───────────────────────────────────────── */
.eyebrow{
  font-family:var(--f-display);font-weight:700;font-size:.72rem;
  text-transform:uppercase;letter-spacing:.14em;color:var(--c-trkis);
  display:flex;align-items:center;gap:.65rem;margin-bottom:.85rem
}
.eyebrow::before{content:'';width:24px;height:2px;background:currentColor;flex-shrink:0}
.eyebrow--dim{color:rgba(255,255,255,.4)}
.eyebrow--dim::before{background:rgba(255,255,255,.3)}

/* Headlines */
.display-xl{
  font-family:var(--f-display);font-weight:900;
  font-size:clamp(2.8rem,7vw,5.5rem);
  line-height:.96;letter-spacing:-.055em;color:#fff
}
.display-xl em{font-style:italic;color:var(--c-trkis);font-weight:800}

.h2{
  font-family:var(--f-display);font-weight:800;
  font-size:clamp(2rem,4.5vw,3.5rem);
  line-height:1.0;letter-spacing:-.048em
}
.h2 em{font-style:italic;color:var(--c-trkis);font-weight:700}
.h2--ink{color:var(--c-ink)}
.h2--white{color:#fff}

.h3{
  font-family:var(--f-display);font-weight:700;
  font-size:clamp(1.25rem,2.5vw,1.85rem);
  line-height:1.12;letter-spacing:-.035em
}

/* Fließtext — größer, besser lesbar */
.lead{
  font-family:var(--f-body);font-size:1.175rem;line-height:1.85;
  color:var(--c-muted);margin-top:1.25rem;max-width:660px
}
.lead--white{color:rgba(255,255,255,.55)}
.lead strong{font-weight:600;color:var(--c-ink)}
.lead--white strong{color:#fff}

.body-text{
  font-family:var(--f-body);font-size:1.0625rem;line-height:1.9;
  color:#3d4455;margin-bottom:1.35rem;max-width:700px
}
.body-text strong{font-weight:600;color:var(--c-ink)}
.body-text a{color:var(--c-trkis);text-decoration:underline;text-decoration-color:rgba(82,183,193,.3);text-underline-offset:3px}
.body-text p+p{margin-top:1.1rem}

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn{
  font-family:var(--f-display);font-weight:700;font-size:.8rem;
  text-transform:uppercase;letter-spacing:.07em;
  padding:.9em 2.1em;display:inline-flex;align-items:center;gap:.5em;
  transition:all var(--dur) var(--ease);cursor:pointer;
  border:none;white-space:nowrap;min-height:50px;border-radius:3px
}
.btn-trkis{background:var(--c-trkis);color:#fff}
.btn-trkis:hover{background:var(--c-trkis2);transform:translateY(-2px);box-shadow:0 8px 28px rgba(82,183,193,.38)}
.btn-blau{background:var(--c-blau);color:#fff}
.btn-blau:hover{background:#1e2d3a;transform:translateY(-2px)}
.btn-gold{background:var(--c-gold);color:#fff}
.btn-gold:hover{background:#e09000;transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,166,0,.32)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.28)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.07)}
.btn-outline{background:transparent;color:var(--c-ink);border:1.5px solid rgba(14,16,21,.18)}
.btn-outline:hover{border-color:var(--c-ink);background:rgba(14,16,21,.04)}
.btn-row{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:2.25rem}

/* ── TAGS ────────────────────────────────────────────────────── */
.tag{
  font-family:var(--f-display);font-weight:700;font-size:.6rem;
  text-transform:uppercase;letter-spacing:.07em;
  padding:4px 10px;border:1.5px solid;display:inline-flex;
  align-items:center;border-radius:2px
}
.tag--trkis{background:rgba(82,183,193,.1);color:var(--c-trkis);border-color:rgba(82,183,193,.3)}
.tag--gold{background:rgba(255,166,0,.08);color:#c07800;border-color:rgba(255,166,0,.28)}
.tag--rot{background:rgba(191,17,27,.08);color:#a00010;border-color:rgba(191,17,27,.22)}
.tag--dim{background:rgba(255,255,255,.05);color:rgba(255,255,255,.5);border-color:rgba(255,255,255,.1)}
.tag-row{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.25rem}

/* ── SEITEN-HERO ─────────────────────────────────────────────── */
.page-hero{
  background:var(--c-ink);
  padding:clamp(3rem,7vw,5.5rem) var(--pad-x) clamp(2.5rem,5vw,4rem);
  position:relative;overflow:hidden
}
.page-hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--c-trkis),var(--c-gold) 60%,var(--c-rot))
}
.page-hero__kicker{
  font-family:var(--f-display);font-weight:700;font-size:.7rem;
  text-transform:uppercase;letter-spacing:.14em;
  color:var(--c-trkis);display:flex;align-items:center;gap:.6rem;
  margin-bottom:1.1rem
}
.page-hero__kicker::before{content:'';width:22px;height:2px;background:var(--c-trkis)}
.page-hero__h1{
  font-family:var(--f-display);font-weight:900;
  font-size:clamp(2.2rem,6vw,4.25rem);
  line-height:.98;letter-spacing:-.052em;color:#fff
}
.page-hero__h1 em{font-style:italic;color:var(--c-trkis);font-weight:800}
.page-hero__sub{
  font-family:var(--f-body);font-size:1.1rem;
  color:rgba(255,255,255,.45);line-height:1.8;
  max-width:620px;margin-top:1.25rem
}

/* ── STATS BAR ───────────────────────────────────────────────── */
.stats-bar{
  display:grid;grid-template-columns:repeat(6,1fr);
  border-top:4px solid var(--c-trkis);
  border-bottom:1px solid var(--c-border);
  background:#fff;
  box-shadow:var(--shadow-m)
}
.stat-item{
  padding:1.75rem 1.25rem;text-align:center;
  border-right:1px solid var(--c-border);
  transition:background var(--dur)
}
.stat-item:last-child{border-right:none}
.stat-item:hover{background:var(--c-smoke)}
.stat-item__n{
  font-family:var(--f-display);font-weight:900;
  font-size:clamp(1.6rem,2.5vw,2.4rem);
  letter-spacing:-.06em;color:var(--c-blau);display:block;margin-bottom:.35rem;
  line-height:1
}
.stat-item__label{
  font-family:var(--f-display);font-weight:600;font-size:.65rem;
  text-transform:uppercase;letter-spacing:.07em;
  color:var(--c-muted);line-height:1.4
}

/* ── PORTRAIT SPLIT ──────────────────────────────────────────── */
.portrait-split{display:grid;grid-template-columns:400px 1fr}
.portrait-split__img{position:relative;overflow:hidden;min-height:520px}
.portrait-split__img img{
  width:100%;height:100%;object-fit:cover;object-position:center top
}
.portrait-split__img::after{
  content:'';position:absolute;right:0;top:0;bottom:0;
  width:4px;background:var(--c-trkis)
}
.portrait-split__content{
  padding:clamp(2.5rem,5vw,4.5rem);background:#fff;
  display:flex;flex-direction:column;justify-content:center
}

/* ── GALERIE ─────────────────────────────────────────────────── */
.photo-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:250px 250px;
  gap:3px
}
.photo-cell{overflow:hidden;position:relative;cursor:zoom-in}
.photo-cell img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .55s var(--ease)
}
.photo-cell:hover img{transform:scale(1.07)}
.photo-cell__cap{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(14,16,21,.8) 0%,transparent 55%);
  display:flex;align-items:flex-end;padding:1.1rem 1.25rem;
  opacity:0;transition:opacity .28s
}
.photo-cell:hover .photo-cell__cap{opacity:1}
.photo-cell__cap span{
  font-family:var(--f-display);font-weight:600;font-size:.7rem;
  text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.9)
}

/* ── TIMELINE ────────────────────────────────────────────────── */
.timeline{position:relative;padding-left:1.35rem;margin:1.5rem 0}
.timeline::before{
  content:'';position:absolute;left:0;top:8px;bottom:8px;
  width:2px;background:linear-gradient(to bottom,var(--c-trkis),rgba(82,183,193,.12))
}
.tl-item{padding:0 0 1.2rem 1.65rem;position:relative}
.tl-item::before{
  content:'';position:absolute;left:-4.5px;top:7px;
  width:9px;height:9px;border-radius:50%;
  background:#fff;border:2.5px solid var(--c-trkis);
  transition:background .15s,transform .15s
}
.tl-item:hover::before{background:var(--c-trkis);transform:scale(1.4)}
.tl-item__yr{
  font-family:var(--f-display);font-weight:700;font-size:.67rem;
  text-transform:uppercase;letter-spacing:.08em;color:var(--c-trkis);margin-bottom:.18rem
}
.tl-item__txt{font-family:var(--f-body);font-size:1.0625rem;line-height:1.75;color:#3d4455}
.tl-item__txt strong{font-weight:600;color:var(--c-ink)}

/* ── POSITIONS-LISTE ─────────────────────────────────────────── */
.pos-list{display:flex;flex-direction:column;gap:.25rem}
.pos-item{
  display:flex;gap:.9rem;align-items:flex-start;
  padding:1.1rem 1.35rem;
  border-left:3px solid transparent;
  transition:all var(--dur)
}
.pos-item:hover{
  border-left-color:var(--c-trkis);
  background:rgba(82,183,193,.05);transform:translateX(4px)
}
.pos-item__dot{
  width:7px;height:7px;border-radius:50%;background:var(--c-trkis);
  flex-shrink:0;margin-top:.55rem
}
.pos-item__kicker{
  font-family:var(--f-display);font-weight:700;font-size:.67rem;
  text-transform:uppercase;letter-spacing:.07em;color:var(--c-trkis);margin-bottom:.2rem
}
.pos-item__text{font-family:var(--f-body);font-size:1rem;line-height:1.7;color:rgba(255,255,255,.52)}
.section--smoke .pos-item__text,
.section:not(.section--ink):not(.section--blau) .pos-item__text{color:var(--c-muted)}

/* ── REDEN-KARTEN ────────────────────────────────────────────── */
.reden-filter{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:2.25rem}
.f-chip{
  font-family:var(--f-display);font-weight:700;font-size:.68rem;
  letter-spacing:.05em;padding:.5rem 1rem;
  background:none;border:1.5px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.38);cursor:pointer;border-radius:3px;
  transition:all var(--dur)
}
.f-chip.active{background:rgba(82,183,193,.1);border-color:var(--c-trkis);color:var(--c-trkis)}
.f-chip:hover:not(.active){color:rgba(255,255,255,.75);border-color:rgba(255,255,255,.28)}

.reden-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));
  gap:1px;background:rgba(255,255,255,.05)
}
.rede-card{
  background:var(--c-ink);padding:1.85rem;
  display:flex;flex-direction:column;gap:.65rem;
  position:relative;overflow:hidden;cursor:pointer;text-decoration:none;
  transition:background var(--dur)
}
.rede-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--c-trkis);transform:scaleX(0);transform-origin:left;
  transition:transform var(--dur)
}
.rede-card:hover{background:rgba(255,255,255,.03)}
.rede-card:hover::before{transform:scaleX(1)}
.rede-card.hidden{display:none}
.rede-card__meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.rede-date{
  font-family:var(--f-display);font-weight:700;font-size:.64rem;
  text-transform:uppercase;letter-spacing:.07em;color:var(--c-trkis)
}
.rtag{
  font-family:var(--f-display);font-weight:700;font-size:.59rem;
  text-transform:uppercase;letter-spacing:.07em;padding:3px 8px;border-radius:2px
}
.rtag--g{background:rgba(82,183,193,.12);color:var(--c-trkis)}
.rtag--p{background:rgba(45,60,75,.8);color:rgba(255,255,255,.65)}
.rtag--c{background:rgba(191,17,27,.12);color:#e05560}
.rtag--s{background:rgba(255,166,0,.12);color:var(--c-gold)}
.rede-card__title{
  font-family:var(--f-body);font-size:1.0625rem;line-height:1.6;
  color:rgba(255,255,255,.78);flex:1
}
.rede-card__wp{font-family:var(--f-display);font-size:.63rem;color:rgba(255,255,255,.25)}
.rede-card__cta{
  font-family:var(--f-display);font-weight:700;font-size:.67rem;
  text-transform:uppercase;letter-spacing:.07em;color:var(--c-trkis);
  display:inline-flex;align-items:center;gap:.4em;margin-top:auto;
  padding-top:.75rem;border-top:1px solid rgba(255,255,255,.05);
  transition:gap var(--dur)
}
.rede-card:hover .rede-card__cta{gap:.7em}

/* ── TABS (Themen) ───────────────────────────────────────────── */
.theme-tabs{
  display:flex;border-bottom:2px solid rgba(255,255,255,.07);
  overflow-x:auto;scrollbar-width:none;margin-top:2.5rem
}
.theme-tabs::-webkit-scrollbar{display:none}
.theme-tab-btn{
  font-family:var(--f-display);font-weight:600;font-size:.78rem;
  letter-spacing:.03em;padding:1rem 1.5rem;background:none;
  color:rgba(255,255,255,.35);border:none;white-space:nowrap;
  flex-shrink:0;position:relative;cursor:pointer;transition:color var(--dur)
}
.theme-tab-btn::after{
  content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;
  background:var(--c-trkis);transform:scaleX(0);transition:transform var(--dur)
}
.theme-tab-btn.active{color:#fff}
.theme-tab-btn.active::after{transform:scaleX(1)}
.theme-tab-btn:hover{color:rgba(255,255,255,.78)}
.theme-panel{display:none;padding:3rem 0;animation:fadeUp .3s}
.theme-panel.active{display:grid;grid-template-columns:1fr 1fr;gap:4rem}
.theme-panel__h{
  font-family:var(--f-display);font-weight:800;
  font-size:clamp(1.5rem,3vw,2.4rem);
  line-height:1.05;letter-spacing:-.045em;color:#fff;margin-bottom:1.25rem
}
.theme-panel__h em{font-style:italic;color:var(--c-trkis);font-weight:700}
.theme-panel__body{
  font-family:var(--f-body);font-size:1.0625rem;line-height:1.9;
  color:rgba(255,255,255,.5)
}
.theme-panel__body p{margin-bottom:1rem}
.theme-panel__body strong{color:#fff;font-weight:600}

/* ── ZITAT-BLOCK ─────────────────────────────────────────────── */
.quote-block{
  position:relative;min-height:400px;
  display:flex;align-items:center;justify-content:center;overflow:hidden
}
.quote-block__bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  filter:brightness(.18) saturate(.35)
}
.quote-block__inner{
  position:relative;z-index:2;max-width:780px;
  padding:clamp(3rem,6vw,5.5rem) var(--pad-x);text-align:center
}
.quote-mark{
  font-family:var(--f-display);font-size:8rem;line-height:.2;
  color:rgba(82,183,193,.18);display:block;margin-bottom:1.75rem;
  font-style:italic;font-weight:900
}
.quote-text{
  font-family:var(--f-body);font-weight:600;font-style:italic;
  font-size:clamp(1.1rem,2.2vw,1.7rem);color:#fff;line-height:1.65;margin-bottom:1.5rem
}
.quote-src{
  font-family:var(--f-display);font-weight:600;font-size:.7rem;
  text-transform:uppercase;letter-spacing:.12em;color:var(--c-trkis)
}

/* ── KONTAKT-KARTEN ──────────────────────────────────────────── */
.contact-card{
  background:#fff;border:1px solid var(--c-border);
  border-top:4px solid var(--c-trkis);
  padding:2.25rem 2.5rem;
  box-shadow:var(--shadow-m);
  transition:box-shadow var(--dur),transform var(--dur)
}
.contact-card:hover{box-shadow:var(--shadow-l);transform:translateY(-3px)}
.contact-card--gold{border-top-color:var(--c-gold)}
.contact-card--blau{border-top-color:var(--c-blau)}
.contact-card__title{
  font-family:var(--f-display);font-weight:700;font-size:1rem;
  color:var(--c-ink);margin-bottom:1.5rem;
  padding-bottom:1.1rem;border-bottom:2px solid rgba(82,183,193,.18)
}
.contact-row{display:flex;gap:1rem;margin-bottom:1.1rem;align-items:flex-start}
.contact-icon{
  width:34px;height:34px;border-radius:50%;
  background:rgba(82,183,193,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;flex-shrink:0;margin-top:1px
}
.contact-row p{
  font-family:var(--f-body);font-size:1.05rem;color:#414855;line-height:1.75
}
.contact-row a{color:var(--c-trkis)}
.contact-team{
  margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--c-border)
}
.contact-team__label{
  font-family:var(--f-display);font-weight:700;font-size:.65rem;
  text-transform:uppercase;letter-spacing:.09em;color:var(--c-muted);margin-bottom:.85rem
}
.contact-member{font-family:var(--f-body);font-size:1rem;line-height:1.8;margin-bottom:.65rem}
.contact-member strong{font-weight:600;color:var(--c-ink);display:block;font-size:1.05rem}
.contact-member span{font-size:.95rem;color:var(--c-muted)}
.socials{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:1.5rem}
.soc-link{
  font-family:var(--f-display);font-weight:600;font-size:.67rem;
  text-transform:uppercase;letter-spacing:.05em;
  padding:7px 13px;background:var(--c-smoke);
  border:1px solid var(--c-border);color:var(--c-blau);
  transition:all var(--dur);display:inline-block;border-radius:3px
}
.soc-link:hover{background:var(--c-trkis);border-color:var(--c-trkis);color:#fff}

/* Bürobild */
.office-img{
  width:100%;height:220px;object-fit:cover;
  object-position:center center;display:block;
  margin-bottom:1.5rem;border-radius:2px
}

/* ════════════════════════════════════════════════════════════════
   FORMULARE — Professionell, mit Abständen
   ════════════════════════════════════════════════════════════════ */

/* Form-Tabs */
.form-tabs{
  display:flex;border-bottom:2px solid var(--c-border);
  margin-bottom:2.5rem;overflow-x:auto;scrollbar-width:none;gap:0
}
.form-tabs::-webkit-scrollbar{display:none}
.ftab-btn{
  font-family:var(--f-display);font-weight:600;font-size:.8rem;
  letter-spacing:.02em;padding:1rem 1.5rem;
  background:none;color:var(--c-muted);border:none;
  white-space:nowrap;flex-shrink:0;cursor:pointer;position:relative;
  transition:color .2s
}
.ftab-btn::after{
  content:'';position:absolute;bottom:-2px;left:0;right:0;
  height:2.5px;background:var(--c-trkis);transform:scaleX(0);transition:transform .2s
}
.ftab-btn.active{color:var(--c-ink)}
.ftab-btn.active::after{transform:scaleX(1)}
.ftab-btn:hover{color:var(--c-ink)}
.prio-badge{
  display:inline-block;background:var(--c-rot);color:#fff;
  font-size:.52rem;font-weight:700;padding:2px 6px;
  margin-left:.35em;vertical-align:middle;border-radius:2px
}
.fpanel{display:none}
.fpanel.active{display:block;animation:fadeUp .28s}

/* Form-Karte — mit großzügigem Padding */
.form-card{
  background:#fff;
  border:1px solid var(--c-border);
  border-top:4px solid var(--c-trkis);
  padding:3rem 3.5rem;
  max-width:840px;
  box-shadow:var(--shadow-m);
  border-radius:0 0 4px 4px
}
.form-card--gold{border-top-color:var(--c-gold)}
.form-card--blau{border-top-color:var(--c-blau)}
.form-card--rot{border-top-color:var(--c-rot)}

.form-desc{
  font-family:var(--f-body);font-size:1.0625rem;color:var(--c-muted);
  line-height:1.85;margin-bottom:2.25rem;
  padding-bottom:2rem;border-bottom:1px solid var(--c-border)
}
.form-desc strong{color:var(--c-ink);font-weight:600}

/* Felder-Grid */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem 1.75rem}
.fg-full{grid-column:1/-1}
.fg-sec{
  grid-column:1/-1;
  font-family:var(--f-display);font-weight:700;font-size:.67rem;
  text-transform:uppercase;letter-spacing:.1em;color:var(--c-muted);
  padding:.5rem 0 .4rem;border-bottom:1px solid var(--c-border);
  margin-top:.75rem
}

/* Labels */
.cf-label{
  font-family:var(--f-display);font-weight:700;font-size:.7rem;
  text-transform:uppercase;letter-spacing:.08em;color:var(--c-blau);
  display:block;margin-bottom:.45rem
}
.cf-label .req{color:var(--c-rot)}

/* Inputs */
.cf-ctrl{
  width:100%;padding:.85rem 1.1rem;
  border:1.5px solid rgba(14,16,21,.15);
  font-family:var(--f-body);font-size:1.0625rem;outline:none;
  transition:border-color .2s,box-shadow .2s;
  background:#fff;color:var(--c-ink);border-radius:4px;
  -webkit-appearance:none
}
.cf-ctrl:focus{
  border-color:var(--c-trkis);box-shadow:0 0 0 3.5px rgba(82,183,193,.13)
}
.cf-ctrl::placeholder{color:rgba(14,16,21,.3);font-style:italic}
select.cf-ctrl{
  cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%235a6880' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.8rem
}
textarea.cf-ctrl{resize:vertical;min-height:140px}

/* Checkbox */
.cf-check{
  display:flex;align-items:flex-start;gap:.75rem;
  grid-column:1/-1;margin-top:1.25rem;
  padding:1.25rem 1.5rem;
  background:rgba(82,183,193,.04);border:1.5px solid rgba(82,183,193,.15);
  border-radius:4px
}
.cf-check input[type=checkbox]{
  margin-top:3px;flex-shrink:0;accent-color:var(--c-trkis);width:18px;height:18px;cursor:pointer
}
.cf-check label{
  font-family:var(--f-body);font-size:1rem;color:var(--c-muted);line-height:1.7;cursor:pointer
}
.cf-check a{color:var(--c-trkis)}
.honeypot{display:none!important;visibility:hidden!important}
.form-actions{
  display:flex;align-items:center;gap:1.25rem;margin-top:2rem;
  flex-wrap:wrap;grid-column:1/-1
}
.form-note{font-family:var(--f-body);font-size:.9rem;color:var(--c-muted)}
.form-note a{color:var(--c-trkis)}

/* Alerts */
.f-alert{
  padding:1.1rem 1.35rem;margin-top:1.1rem;
  font-family:var(--f-body);font-size:1rem;line-height:1.7;
  display:none;border-left:4px solid;border-radius:0 4px 4px 0;
  grid-column:1/-1
}
.f-alert.show{display:block}
.f-alert--ok{background:rgba(82,183,193,.07);border-color:var(--c-trkis);color:#1a5a60}
.f-alert--err{background:rgba(191,17,27,.06);border-color:var(--c-rot);color:#7a0009}

/* Radiogruppe */
.radio-grp{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.4rem}
.radio-grp label{
  display:flex;align-items:center;gap:.45rem;
  font-family:var(--f-body);font-size:1rem;color:var(--c-ink);
  cursor:pointer;padding:.55rem .9rem;
  border:1.5px solid rgba(14,16,21,.14);border-radius:4px;transition:all .15s
}
.radio-grp input{accent-color:var(--c-trkis)}
.radio-grp label:has(input:checked){border-color:var(--c-trkis);background:rgba(82,183,193,.07);color:var(--c-trkis)}

/* File Upload */
.file-up{position:relative}
.file-up input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;z-index:2}
.file-up__face{
  display:flex;align-items:center;gap:.75rem;padding:.85rem 1.1rem;
  border:2px dashed rgba(14,16,21,.18);border-radius:4px;
  font-family:var(--f-body);font-size:1rem;color:var(--c-muted);
  background:#fcfcfd;transition:all .2s;cursor:pointer
}
.file-up:hover .file-up__face{border-color:var(--c-trkis);background:rgba(82,183,193,.04);color:var(--c-trkis)}
.file-name{font-family:var(--f-display);font-size:.72rem;color:var(--c-trkis);margin-top:.3rem}
.spinner{
  display:inline-block;width:15px;height:15px;
  border:2px solid rgba(255,255,255,.3);border-top-color:#fff;
  border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0
}

/* ── PRESS-GRID ──────────────────────────────────────────────── */
.press-photos{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;background:var(--c-border);margin-top:2.5rem
}
.press-photo{background:#fff;overflow:hidden;transition:box-shadow var(--dur)}
.press-photo:hover{box-shadow:var(--shadow-l);position:relative;z-index:1}
.press-photo img{
  width:100%;aspect-ratio:16/9;object-fit:cover;
  object-position:center top;transition:transform .5s var(--ease)
}
.press-photo:hover img{transform:scale(1.04)}
.press-photo__info{padding:1.25rem 1.5rem}
.press-photo__title{
  font-family:var(--f-display);font-weight:700;font-size:.85rem;
  color:var(--c-ink);margin-bottom:.85rem
}
.press-photo__btns{display:flex;gap:.4rem;flex-wrap:wrap}
.dl-btn{
  font-family:var(--f-display);font-weight:700;font-size:.6rem;
  text-transform:uppercase;letter-spacing:.06em;
  padding:5px 11px;border:none;cursor:pointer;
  transition:all var(--dur);text-decoration:none;
  display:inline-flex;align-items:center;gap:.3em;border-radius:3px
}
.dl-btn--s{background:var(--c-smoke);color:var(--c-blau);border:1px solid var(--c-border)}
.dl-btn--s:hover{background:var(--c-trkis);color:#fff;border-color:var(--c-trkis)}
.dl-btn--m{background:var(--c-trkis);color:#fff}
.dl-btn--m:hover{background:var(--c-trkis2)}
.dl-btn--l{background:var(--c-blau);color:#fff}
.dl-btn--l:hover{background:#1e2d3a}

/* ── GESETZ-ITEMS ────────────────────────────────────────────── */
.gz-item{
  background:#fff;border:1px solid var(--c-border);
  border-top:4px solid var(--c-trkis);
  padding:2.5rem;margin-bottom:2px;box-shadow:var(--shadow-s)
}
.gz-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}
.gz-title{
  font-family:var(--f-display);font-weight:800;
  font-size:clamp(1.25rem,2.5vw,2rem);
  letter-spacing:-.04em;color:var(--c-ink);margin-bottom:.65rem
}
.gz-intro{
  font-family:var(--f-body);font-style:italic;
  font-size:1.0625rem;color:var(--c-muted);margin-bottom:2rem
}
.gz-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem;align-items:start}
.gz-block__label{
  font-family:var(--f-display);font-weight:700;font-size:.67rem;
  text-transform:uppercase;letter-spacing:.1em;color:var(--c-trkis);margin-bottom:.5rem
}
.gz-block__text{font-family:var(--f-body);font-size:1.0625rem;color:#3d4455;line-height:1.85}
.gz-pos{background:rgba(82,183,193,.06);border-left:4px solid var(--c-trkis);padding:1.25rem 1.5rem}

/* ── INFOBOX ─────────────────────────────────────────────────── */
.infobox{
  background:rgba(82,183,193,.06);border-left:4px solid var(--c-trkis);
  padding:1.25rem 1.5rem;margin:2rem 0
}
.infobox__title{
  font-family:var(--f-display);font-weight:700;font-size:.7rem;
  text-transform:uppercase;letter-spacing:.09em;color:var(--c-trkis);margin-bottom:.4rem
}
.infobox p{font-family:var(--f-body);font-size:1.0625rem;color:var(--c-muted);line-height:1.8}

/* ── PRESSE-AUSSAGEN ─────────────────────────────────────────── */
.press-quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.05)}
.pquote{padding:2.25rem;background:var(--c-blau);position:relative;transition:background var(--dur)}
.pquote::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--c-trkis),var(--c-gold))
}
.pquote:hover{background:rgba(45,60,75,.65)}
.pquote__text{
  font-family:var(--f-body);font-style:italic;font-size:1.0625rem;
  line-height:1.8;color:rgba(255,255,255,.78);margin-bottom:1.1rem
}
.pquote__source{
  font-family:var(--f-display);font-weight:700;font-size:.63rem;
  letter-spacing:.09em;text-transform:uppercase;color:var(--c-gold)
}

/* ── THEMEN NAV (intern) ─────────────────────────────────────── */
.themen-subnav{
  display:flex;border-bottom:2px solid var(--c-border);
  margin-bottom:3.5rem;overflow-x:auto;scrollbar-width:none
}
.themen-subnav::-webkit-scrollbar{display:none}
.themen-subnav a{
  font-family:var(--f-display);font-weight:600;font-size:.8rem;
  letter-spacing:.04em;padding:1rem 1.5rem;color:var(--c-muted);
  white-space:nowrap;flex-shrink:0;position:relative;
  transition:color var(--dur);text-decoration:none
}
.themen-subnav a::after{
  content:'';position:absolute;bottom:-2px;left:0;right:0;
  height:3px;background:var(--c-trkis);transform:scaleX(0);transition:transform var(--dur)
}
.themen-subnav a:hover,.themen-subnav a.active{color:var(--c-ink)}
.themen-subnav a.active::after{transform:scaleX(1)}
.thema-section{padding:3.5rem 0;border-bottom:1px solid var(--c-border)}
.thema-section:last-child{border-bottom:none}

/* ── MODAL ───────────────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;z-index:2000;
  background:rgba(0,0,0,.72);backdrop-filter:blur(10px);
  display:none;align-items:center;justify-content:center;padding:1.5rem
}
.modal-overlay.open{display:flex;animation:fadeIn .22s}
.modal-box{
  background:#fff;max-width:760px;width:100%;
  max-height:90vh;overflow-y:auto;position:relative;
  animation:slideUp .28s var(--ease);border-radius:4px;
  box-shadow:0 40px 120px rgba(0,0,0,.4)
}
.modal-close{
  position:sticky;top:0;float:right;background:var(--c-ink);color:#fff;
  width:46px;height:46px;font-size:1.15rem;
  display:flex;align-items:center;justify-content:center;
  z-index:2;cursor:pointer;transition:background var(--dur)
}
.modal-close:hover{background:var(--c-trkis)}
.modal-body{padding:2.5rem 3rem;clear:both}
.modal-body h2{
  font-family:var(--f-display);font-weight:800;font-size:1.85rem;
  color:var(--c-ink);margin-bottom:1.5rem;letter-spacing:-.04em
}
.modal-body h3{
  font-family:var(--f-display);font-weight:700;font-size:.72rem;
  text-transform:uppercase;letter-spacing:.08em;color:var(--c-blau);
  margin:1.5rem 0 .65rem
}
.modal-body p,.modal-body li{
  font-family:var(--f-body);font-size:1.0625rem;color:#3d4455;line-height:1.85
}
.modal-body ul{padding-left:1.5rem;margin:.5rem 0 1rem}
.modal-body a{color:var(--c-trkis);text-decoration:underline}
.modal-hr{border:none;border-top:1px solid var(--c-border);margin:1.5rem 0}

/* ── FOOTER ──────────────────────────────────────────────────── */
.footer{
  background:var(--c-ink);
  padding:2.75rem var(--pad-x);
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1.5rem;position:relative
}
.footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--c-trkis) 0%,var(--c-gold) 50%,var(--c-rot) 100%)
}
.footer__brand{display:flex;align-items:center;gap:1rem}
.footer__logo{background:#fff;padding:5px 9px;display:flex;align-items:center}
.footer__logo img{height:26px;width:auto}
.footer__name{
  font-family:var(--f-display);font-weight:700;font-size:.85rem;color:rgba(255,255,255,.7);line-height:1.35
}
.footer__name small{
  display:block;font-family:var(--f-body);font-weight:400;font-size:.7rem;color:rgba(255,255,255,.28)
}
.footer__links{display:flex;gap:1.5rem;flex-wrap:wrap;align-items:center}
.footer__links a{
  font-family:var(--f-body);font-size:.82rem;color:rgba(255,255,255,.3);
  transition:color var(--dur)
}
.footer__links a:hover{color:var(--c-trkis)}
.footer__copy{font-family:var(--f-body);font-size:.72rem;color:rgba(255,255,255,.18)}

/* ── COOKIE NOTICE ───────────────────────────────────────────── */
.cookie-notice{
  position:fixed;bottom:0;left:0;right:0;z-index:800;
  background:rgba(14,16,21,.97);border-top:3px solid var(--c-trkis);
  padding:1.1rem var(--pad-x);
  display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;
  transform:translateY(100%);transition:transform .42s var(--ease)
}
.cookie-notice.visible{transform:none}
.cookie-notice p{
  font-family:var(--f-body);font-size:.95rem;color:rgba(255,255,255,.6);
  line-height:1.55;flex:1;min-width:220px
}
.cookie-notice a{color:var(--c-trkis)}
.cookie-btn{
  font-family:var(--f-display);font-weight:700;font-size:.72rem;
  text-transform:uppercase;letter-spacing:.07em;
  background:var(--c-trkis);color:#fff;padding:.65em 1.5em;
  border:none;cursor:pointer;flex-shrink:0;border-radius:3px;
  transition:background .2s
}
.cookie-btn:hover{background:var(--c-trkis2)}

/* ── PROGRESS BAR ────────────────────────────────────────────── */
.progress-bar{
  position:fixed;top:var(--nav-h);left:0;height:2px;
  background:var(--c-gold);z-index:999;width:0%;pointer-events:none;
  transition:width .1s linear
}

/* ── BACK TO TOP ─────────────────────────────────────────────── */
.back-to-top{
  position:fixed;bottom:2rem;right:2rem;z-index:500;
  width:48px;height:48px;background:var(--c-trkis);color:#fff;
  border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;
  cursor:pointer;box-shadow:0 6px 24px rgba(82,183,193,.4);
  opacity:0;transform:translateY(14px);
  transition:opacity .3s,transform .3s,background .2s;pointer-events:none
}
.back-to-top.visible{opacity:1;transform:none;pointer-events:auto}
.back-to-top:hover{background:var(--c-trkis2);transform:translateY(-2px)}

/* ── SCROLL REVEAL ───────────────────────────────────────────── */
.rv{opacity:1;transform:none;transition:opacity .6s var(--ease),transform .6s var(--ease)}
.js-ready .rv{opacity:0;transform:translateY(20px)}
.js-ready .rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}.rv.d3{transition-delay:.3s}

/* ── ANIMATIONS ──────────────────────────────────────────────── */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes slideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── FOCUS ───────────────────────────────────────────────────── */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2.5px solid var(--c-trkis);outline-offset:3px
}

/* ════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════ */
@media(max-width:1100px){
  .portrait-split{grid-template-columns:1fr}
  .portrait-split__img{min-height:380px;max-height:460px}
  .theme-panel.active{grid-template-columns:1fr;gap:2.5rem}
  .press-quotes{grid-template-columns:1fr}
}

@media(max-width:960px){
  :root{--nav-h:64px}
  .nav__menu{display:none}
  .nav__cta-btn{display:none}
  .nav__name-block{display:none}
  .nav__burger{display:flex}
  .stats-bar{grid-template-columns:repeat(3,1fr)}
  .stat-item:nth-child(n+4){border-top:1px solid var(--c-border)}
  .photo-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,200px)}
  .photo-cell__cap{opacity:1}
  .press-photos{grid-template-columns:repeat(2,1fr)}
  .press-quotes{grid-template-columns:1fr}
  .form-card{padding:2.25rem 2rem}
  .footer{flex-direction:column;text-align:center}
  .footer__links{justify-content:center}
  .footer__copy{text-align:center}
  .section{padding:clamp(2.5rem,5vw,4rem) var(--pad-x)}
}

@media(max-width:700px){
  :root{--pad-x:1.25rem}
  .fg{grid-template-columns:1fr}
  .fg-full,.cf-check,.form-actions,.f-alert{grid-column:auto}
  .stats-bar{grid-template-columns:repeat(2,1fr)}
  .stat-item:nth-child(n+3){border-top:1px solid var(--c-border)}
  .photo-grid{grid-template-columns:1fr;grid-template-rows:repeat(6,180px)}
  .press-photos{grid-template-columns:1fr}
  .gz-grid{grid-template-columns:1fr;gap:1.5rem}
  .btn-row{flex-direction:column;align-items:flex-start}
  .form-card{padding:1.75rem 1.25rem}
  .contact-card{padding:1.75rem 1.5rem}
  .modal-body{padding:2rem 1.5rem}
  .press-quotes{grid-template-columns:1fr}
  .back-to-top{bottom:1.25rem;right:1.25rem}
}

@media(max-width:480px){
  .stats-bar{grid-template-columns:1fr 1fr}
  .nav__logo-wrap img{height:22px}
  .display-xl{letter-spacing:-.04em}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .rv{opacity:1!important;transform:none!important}
}

/* ════════════════════════════════════════════════════════════════
   COMPAT ALIASES — alte Klassen auf neue mappen
   (keine HTML-Änderung nötig)
   ════════════════════════════════════════════════════════════════ */

/* Layout */
.sec                        { padding:clamp(3.5rem,7vw,6rem) var(--pad-x) }
.sec.sec--smoke,
.sec--smoke                 { background:var(--c-smoke) }
.sec.sec--ink,
.sec--ink                   { background:var(--c-ink);color:#fff }
.sec.sec--blau,
.sec--blau                  { background:var(--c-blau);color:#fff }

/* Portrait-Split (alt) */
.portrait-section           { display:grid;grid-template-columns:400px 1fr }
.portrait-section__img      { position:relative;overflow:hidden;min-height:480px }
.portrait-section__img img  { width:100%;height:100%;object-fit:cover;object-position:center top }
.portrait-section__img::after{ content:'';position:absolute;right:0;top:0;bottom:0;width:4px;background:var(--c-trkis) }
.portrait-section__content  { padding:clamp(2.5rem,5vw,4.5rem);background:#fff;display:flex;flex-direction:column;justify-content:center }

/* Stats (alt) */
.stats                      { display:grid;grid-template-columns:repeat(6,1fr);border-top:4px solid var(--c-trkis);border-bottom:1px solid var(--c-border);background:#fff;box-shadow:var(--shadow-m) }
.stat                       { padding:1.75rem 1.25rem;text-align:center;border-right:1px solid var(--c-border);transition:background var(--dur) }
.stat:last-child            { border-right:none }
.stat:hover                 { background:var(--c-smoke) }
.stat__n                    { font-family:var(--f-display);font-weight:900;font-size:clamp(1.6rem,2.5vw,2.4rem);letter-spacing:-.06em;color:var(--c-blau);display:block;margin-bottom:.35rem;line-height:1 }
.stat__l                    { font-family:var(--f-display);font-weight:600;font-size:.65rem;text-transform:uppercase;letter-spacing:.07em;color:var(--c-muted);line-height:1.4 }

/* Kontakt (alt k-) */
.k-card                     { background:#fff;border:1px solid var(--c-border);border-top:4px solid var(--c-trkis);padding:2.25rem 2.5rem;box-shadow:var(--shadow-m);transition:box-shadow var(--dur),transform var(--dur) }
.k-card:hover               { box-shadow:var(--shadow-l);transform:translateY(-3px) }
.k-card__title              { font-family:var(--f-display);font-weight:700;font-size:1rem;color:var(--c-ink);margin-bottom:1.5rem;padding-bottom:1.1rem;border-bottom:2px solid rgba(82,183,193,.18) }
.k-row                      { display:flex;gap:1rem;margin-bottom:1.1rem;align-items:flex-start }
.k-icon                     { width:34px;height:34px;border-radius:50%;background:rgba(82,183,193,.1);display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;margin-top:1px }
.k-row p                    { font-family:var(--f-body);font-size:1.05rem;color:#414855;line-height:1.75 }
.k-row a                    { color:var(--c-trkis) }
.k-team                     { margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--c-border) }
.k-team__label              { font-family:var(--f-display);font-weight:700;font-size:.65rem;text-transform:uppercase;letter-spacing:.09em;color:var(--c-muted);margin-bottom:.85rem }
.k-team__member             { font-family:var(--f-body);font-size:1rem;line-height:1.8;margin-bottom:.65rem }
.k-team__member strong      { font-weight:600;color:var(--c-ink);display:block;font-size:1.05rem }
.k-team__member span        { font-size:.95rem;color:var(--c-muted) }

/* Positions-Liste (alt) */
.pos-item__topic            { font-family:var(--f-display);font-weight:700;font-size:.67rem;text-transform:uppercase;letter-spacing:.07em;color:var(--c-trkis);margin-bottom:.2rem }
.pos-item__txt              { font-family:var(--f-body);font-size:1rem;line-height:1.7;color:rgba(255,255,255,.52) }
.sec--smoke .pos-item__txt,
:not(.sec--ink):not(.sec--blau) > .pos-list .pos-item__txt { color:var(--c-muted) }

/* Reden (alt) */
.reden-filter               { display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:2.25rem }
.filter-btn                 { font-family:var(--f-display);font-weight:700;font-size:.68rem;letter-spacing:.05em;padding:.5rem 1rem;background:none;border:1.5px solid rgba(255,255,255,.1);color:rgba(255,255,255,.38);cursor:pointer;border-radius:3px;transition:all var(--dur) }
.filter-btn.active          { background:rgba(82,183,193,.1);border-color:var(--c-trkis);color:var(--c-trkis) }
.filter-btn:hover:not(.active){ color:rgba(255,255,255,.75);border-color:rgba(255,255,255,.28) }
.reden-grid                 { display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:1px;background:rgba(255,255,255,.05) }
.rede                       { background:var(--c-ink);padding:1.85rem;display:flex;flex-direction:column;gap:.65rem;position:relative;overflow:hidden;cursor:pointer;text-decoration:none;transition:background var(--dur) }
.rede::before               { content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--c-trkis);transform:scaleX(0);transform-origin:left;transition:transform var(--dur) }
.rede:hover                 { background:rgba(255,255,255,.03) }
.rede:hover::before         { transform:scaleX(1) }
.rede.hidden                { display:none }
.rede__meta                 { display:flex;align-items:center;gap:.5rem;flex-wrap:wrap }
.rede__date                 { font-family:var(--f-display);font-weight:700;font-size:.64rem;text-transform:uppercase;letter-spacing:.07em;color:var(--c-trkis) }
.rede__title                { font-family:var(--f-body);font-size:1.0625rem;line-height:1.6;color:rgba(255,255,255,.78);flex:1 }
.rede__wp                   { font-family:var(--f-display);font-size:.63rem;color:rgba(255,255,255,.25) }
.rede__link                 { font-family:var(--f-display);font-weight:700;font-size:.67rem;text-transform:uppercase;letter-spacing:.07em;color:var(--c-trkis);display:inline-flex;align-items:center;gap:.4em;margin-top:auto;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.05);transition:gap var(--dur) }
.rede:hover .rede__link     { gap:.7em }
.cta-box                    { margin-top:2rem;padding:1.75rem 2rem;background:rgba(82,183,193,.06);border:1px solid rgba(82,183,193,.15);display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap }
.cta-box p                  { font-family:var(--f-body);font-size:1rem;color:rgba(255,255,255,.52) }
.cta-box strong             { color:#fff }

/* Tabs (alt) */
.tabs                       { display:flex;border-bottom:2px solid rgba(255,255,255,.07);overflow-x:auto;scrollbar-width:none;margin-top:2.5rem }
.tabs::-webkit-scrollbar    { display:none }
.tab-btn                    { font-family:var(--f-display);font-weight:600;font-size:.78rem;letter-spacing:.03em;padding:1rem 1.5rem;background:none;color:rgba(255,255,255,.35);border:none;white-space:nowrap;flex-shrink:0;position:relative;cursor:pointer;transition:color var(--dur) }
.tab-btn::after             { content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--c-trkis);transform:scaleX(0);transition:transform var(--dur) }
.tab-btn.active             { color:#fff }
.tab-btn.active::after      { transform:scaleX(1) }
.tab-btn:hover              { color:rgba(255,255,255,.78) }
.tab-panel                  { display:none;padding:3rem 0;animation:fadeUp .3s }
.tab-panel.active           { display:grid;grid-template-columns:1fr 1fr;gap:4rem }
.tab-panel__h3              { font-family:var(--f-display);font-weight:800;font-size:clamp(1.5rem,3vw,2.4rem);line-height:1.05;letter-spacing:-.045em;color:#fff;margin-bottom:1.25rem }
.tab-panel__h3 em           { font-style:italic;color:var(--c-trkis);font-weight:700 }
.tab-panel__body            { font-family:var(--f-body);font-size:1.0625rem;line-height:1.9;color:rgba(255,255,255,.5) }
.tab-panel__body p          { margin-bottom:1rem }
.tab-panel__body strong     { color:#fff;font-weight:600 }

/* Gallery (alt) */
.gallery                    { display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,250px);gap:3px }
.gallery__item              { overflow:hidden;position:relative;cursor:zoom-in }
.gallery__item img          { width:100%;height:100%;object-fit:cover;transition:transform .55s var(--ease) }
.gallery__item:hover img    { transform:scale(1.07) }
.gallery__cap               { position:absolute;inset:0;background:linear-gradient(to top,rgba(14,16,21,.8) 0%,transparent 55%);display:flex;align-items:flex-end;padding:1.1rem 1.25rem;opacity:0;transition:opacity .28s }
.gallery__item:hover .gallery__cap { opacity:1 }
.gallery__cap span          { font-family:var(--f-display);font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.9) }

/* Themen-Nav (alt) */
.themen-nav                 { display:flex;border-bottom:2px solid var(--c-border);margin-bottom:3.5rem;overflow-x:auto;scrollbar-width:none }
.themen-nav::-webkit-scrollbar { display:none }
.themen-nav a               { font-family:var(--f-display);font-weight:600;font-size:.8rem;letter-spacing:.04em;padding:1rem 1.5rem;color:var(--c-muted);white-space:nowrap;flex-shrink:0;position:relative;transition:color var(--dur);text-decoration:none }
.themen-nav a::after        { content:'';position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--c-trkis);transform:scaleX(0);transition:transform var(--dur) }
.themen-nav a:hover,.themen-nav a.active { color:var(--c-ink) }
.themen-nav a.active::after { transform:scaleX(1) }
.thema-block                { padding:3.5rem 0;border-bottom:1px solid var(--c-border) }
.thema-block:last-child     { border-bottom:none }

/* Formular (alt fg-item etc.) */
.fg-item                    { display:flex;flex-direction:column }
.fg-title                   { grid-column:1/-1;font-family:var(--f-display);font-weight:700;font-size:.67rem;text-transform:uppercase;letter-spacing:.1em;color:var(--c-muted);padding:.5rem 0 .4rem;border-bottom:1px solid var(--c-border);margin-top:.75rem }
.cf-label                   { font-family:var(--f-display);font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--c-blau);display:block;margin-bottom:.45rem }
.cf-label .req              { color:var(--c-rot) }
.cf-ctrl                    { width:100%;padding:.85rem 1.1rem;border:1.5px solid rgba(14,16,21,.15);font-family:var(--f-body);font-size:1.0625rem;outline:none;transition:border-color .2s,box-shadow .2s;background:#fff;color:var(--c-ink);border-radius:4px;-webkit-appearance:none }
.cf-ctrl:focus              { border-color:var(--c-trkis);box-shadow:0 0 0 3.5px rgba(82,183,193,.13) }
.cf-ctrl::placeholder       { color:rgba(14,16,21,.3);font-style:italic }
select.cf-ctrl              { cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%235a6880' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.8rem }
textarea.cf-ctrl            { resize:vertical;min-height:140px }
.cf-check                   { display:flex;align-items:flex-start;gap:.75rem;grid-column:1/-1;margin-top:1.25rem;padding:1.25rem 1.5rem;background:rgba(82,183,193,.04);border:1.5px solid rgba(82,183,193,.15);border-radius:4px }
.cf-check input[type=checkbox] { margin-top:3px;flex-shrink:0;accent-color:var(--c-trkis);width:18px;height:18px;cursor:pointer }
.cf-check label             { font-family:var(--f-body);font-size:1rem;color:var(--c-muted);line-height:1.7;cursor:pointer }
.cf-check a                 { color:var(--c-trkis) }
.form-actions               { display:flex;align-items:center;gap:1.25rem;margin-top:2rem;flex-wrap:wrap;grid-column:1/-1 }
.form-note                  { font-family:var(--f-body);font-size:.9rem;color:var(--c-muted) }
.form-note a                { color:var(--c-trkis) }
.f-alert                    { padding:1.1rem 1.35rem;margin-top:1.1rem;font-family:var(--f-body);font-size:1rem;line-height:1.7;display:none;border-left:4px solid;border-radius:0 4px 4px 0;grid-column:1/-1 }
.f-alert.show               { display:block }
.f-alert--ok                { background:rgba(82,183,193,.07);border-color:var(--c-trkis);color:#1a5a60 }
.f-alert--err               { background:rgba(191,17,27,.06);border-color:var(--c-rot);color:#7a0009 }
.honeypot                   { display:none!important;visibility:hidden!important }
.spinner                    { display:inline-block;width:15px;height:15px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0 }

/* Press (alt) */
.press-grid                 { display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--c-border);margin-top:2.5rem }
.press-photo                { background:#fff;overflow:hidden;transition:box-shadow var(--dur) }
.press-photo:hover          { box-shadow:var(--shadow-l);position:relative;z-index:1 }
.press-photo img            { width:100%;aspect-ratio:16/9;object-fit:cover;object-position:center top;transition:transform .5s var(--ease) }
.press-photo:hover img      { transform:scale(1.04) }
.press-photo__info          { padding:1.25rem 1.5rem }
.press-photo__title         { font-family:var(--f-display);font-weight:700;font-size:.85rem;color:var(--c-ink);margin-bottom:.85rem }
.press-photo__btns          { display:flex;gap:.4rem;flex-wrap:wrap }
.dl-btn                     { font-family:var(--f-display);font-weight:700;font-size:.6rem;text-transform:uppercase;letter-spacing:.06em;padding:5px 11px;border:none;cursor:pointer;transition:all var(--dur);text-decoration:none;display:inline-flex;align-items:center;gap:.3em;border-radius:3px }
.dl-btn--s                  { background:var(--c-smoke);color:var(--c-blau);border:1px solid var(--c-border) }
.dl-btn--s:hover            { background:var(--c-trkis);color:#fff;border-color:var(--c-trkis) }
.dl-btn--m                  { background:var(--c-trkis);color:#fff }
.dl-btn--m:hover            { background:var(--c-trkis2) }
.dl-btn--l                  { background:var(--c-blau);color:#fff }
.dl-btn--l:hover            { background:#1e2d3a }

/* Gesetze (alt) */
.gz-item                    { background:#fff;border:1px solid var(--c-border);border-top:4px solid var(--c-trkis);padding:2.5rem;margin-bottom:2px;box-shadow:var(--shadow-s) }
.gz-item__header            { display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap }
.gz-item__title             { font-family:var(--f-display);font-weight:800;font-size:clamp(1.25rem,2.5vw,2rem);letter-spacing:-.04em;color:var(--c-ink);margin-bottom:.65rem }
.gz-item__intro             { font-family:var(--f-body);font-style:italic;font-size:1.0625rem;color:var(--c-muted);margin-bottom:2rem }
.gz-grid                    { display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem;align-items:start }
.gz-block__label            { font-family:var(--f-display);font-weight:700;font-size:.67rem;text-transform:uppercase;letter-spacing:.1em;color:var(--c-trkis);margin-bottom:.5rem }
.gz-block__text             { font-family:var(--f-body);font-size:1.0625rem;color:#3d4455;line-height:1.85 }
.gz-pos                     { background:rgba(82,183,193,.06);border-left:4px solid var(--c-trkis);padding:1.25rem 1.5rem }

/* Quote Block (alt) */
.quote-block                { position:relative;min-height:400px;display:flex;align-items:center;justify-content:center;overflow:hidden }
.quote-block__bg            { position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.18) saturate(.35) }
.quote-block__inner         { position:relative;z-index:2;max-width:780px;padding:clamp(3rem,6vw,5.5rem) var(--pad-x);text-align:center }
.q-mark                     { font-family:var(--f-display);font-size:8rem;line-height:.2;color:rgba(82,183,193,.18);display:block;margin-bottom:1.75rem;font-style:italic;font-weight:900 }
.q-text                     { font-family:var(--f-body);font-weight:600;font-style:italic;font-size:clamp(1.1rem,2.2vw,1.7rem);color:#fff;line-height:1.65;margin-bottom:1.5rem }
.q-src                      { font-family:var(--f-display);font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--c-trkis) }

/* Presse-Statements (alt) */
.press-statements           { display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.05) }
.pstatement                 { padding:2.25rem;background:var(--c-blau);position:relative;transition:background var(--dur) }
.pstatement::before         { content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--c-trkis),var(--c-gold)) }
.pstatement:hover           { background:rgba(45,60,75,.65) }
.pstatement__txt            { font-family:var(--f-body);font-style:italic;font-size:1.0625rem;line-height:1.8;color:rgba(255,255,255,.78);margin-bottom:1.1rem }
.pstatement__src            { font-family:var(--f-display);font-weight:700;font-size:.63rem;letter-spacing:.09em;text-transform:uppercase;color:var(--c-gold) }

/* ── RESPONSIVE COMPAT ──────────────────────────────────────────── */
@media(max-width:1100px){
  .portrait-section          { grid-template-columns:1fr }
  .portrait-section__img     { min-height:320px;max-height:440px }
  .tab-panel.active          { grid-template-columns:1fr;gap:2.5rem }
  .press-statements          { grid-template-columns:1fr }
  .stats                     { grid-template-columns:repeat(3,1fr) }
}
@media(max-width:960px){
  .gallery                   { grid-template-columns:repeat(2,1fr);grid-template-rows:auto }
  .gallery__item img         { min-height:200px }
  .gallery__cap              { opacity:1 }
  .press-grid                { grid-template-columns:repeat(2,1fr) }
  .gz-grid                   { grid-template-columns:1fr;gap:1.5rem }
}
@media(max-width:700px){
  .stats                     { grid-template-columns:repeat(2,1fr) }
  .stat:nth-child(n+3)       { border-top:1px solid var(--c-border) }
  .gallery                   { grid-template-columns:1fr }
  .press-grid                { grid-template-columns:1fr }
  .tab-panel.active          { grid-template-columns:1fr }
}

/* ── CSS-VARIABLEN COMPAT ─────────────────────────────────────── */
:root {
  --smoke: var(--c-smoke);
  --fu:    var(--f-display);
  --fb:    var(--f-body);
}

/* ── FORM-PANEL SICHTBARKEIT ─────────────────────────────────── */
.form-panel          { display:none }
.form-panel.active   { display:block; animation:fadeUp .28s }
.form-tab-btn        {
  font-family:var(--f-display);font-weight:600;font-size:.85rem;
  letter-spacing:.02em;padding:.9rem 1.5rem;
  background:none;color:var(--c-muted);border:none;
  white-space:nowrap;flex-shrink:0;cursor:pointer;position:relative;
  transition:color .2s
}
.form-tab-btn::after {
  content:'';position:absolute;bottom:-2px;left:0;right:0;
  height:2.5px;background:var(--c-trkis);transform:scaleX(0);transition:transform .2s
}
.form-tab-btn.active { color:var(--c-ink) }
.form-tab-btn.active::after { transform:scaleX(1) }
.form-tab-btn:hover  { color:var(--c-ink) }

/* ── FOOTER ÜBERARBEITET ─────────────────────────────────────── */
.footer {
  background:var(--c-ink);
  padding:2.5rem var(--pad-x);
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:2rem;
  position:relative
}
.footer::before {
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--c-trkis) 0%,var(--c-gold) 50%,var(--c-rot) 100%)
}
.footer__brand       { display:flex;align-items:center;gap:.9rem }
.footer__logo        {
  background:#fff;padding:4px 8px;
  display:flex;align-items:center;flex-shrink:0
}
.footer__logo img    { height:22px;width:auto;display:block }
.footer__name        {
  font-family:var(--f-display);font-weight:700;font-size:.82rem;
  color:rgba(255,255,255,.65);line-height:1.4
}
.footer__name small  {
  display:block;font-family:var(--f-body);font-weight:400;
  font-size:.68rem;color:rgba(255,255,255,.28)
}
.footer__links       {
  display:flex;gap:1.25rem;flex-wrap:wrap;
  align-items:center;justify-content:center
}
.footer__links a     {
  font-family:var(--f-body);font-size:.8rem;
  color:rgba(255,255,255,.28);transition:color var(--dur)
}
.footer__links a:hover { color:var(--c-trkis) }
.footer__copy        {
  font-family:var(--f-body);font-size:.7rem;
  color:rgba(255,255,255,.18);text-align:right;white-space:nowrap
}
@media(max-width:960px){
  .footer              { grid-template-columns:1fr;text-align:center;gap:1.25rem }
  .footer__brand       { justify-content:center }
  .footer__links       { justify-content:center }
  .footer__copy        { text-align:center }
}

/* ── REDEN CARD TEXT CLAMP ───────────────────────────────────── */
.rede__title, .rede-card__title {
  overflow:hidden;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
}
/* Karten gleichmäßige Höhe */
.rede-card, .rede {
  min-height:0;
}
/* Reden-Grid Cards: einheitliche Höhe */
.reden-grid .rede,
.reden-grid .rede-card {
  height:100%;
  box-sizing:border-box;
}

/* ════════════════════════════════════════════════════════════════
   BUGFIXES V3.4
   ════════════════════════════════════════════════════════════════ */

/* Portrait-Split: keine extra max-width nötig, section selbst hat padding */
.portrait-split {
  display: grid;
  grid-template-columns: 420px 1fr;
  max-width: var(--max-w);
  margin: 0 auto;
}

/* Schwerpunkt-Karten: stabile Grid-Darstellung */
.schwerpunkte-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-top: 3rem;
}
.schwerpunkte-grid .card {
  background: #fff;
  border: 1px solid var(--c-border);
  padding: 1.75rem;
  box-shadow: var(--shadow-s);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: .65rem;
}
.schwerpunkte-grid .card h3 {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 1rem;
  color: var(--c-ink);
  line-height: 1.3;
}
.schwerpunkte-grid .card p {
  font-family: var(--f-body);
  font-size: .975rem;
  color: var(--c-muted);
  line-height: 1.75;
  flex: 1;
}
@media(max-width:1100px){
  .schwerpunkte-grid { grid-template-columns: repeat(3, 1fr) }
  .portrait-split    { grid-template-columns: 1fr }
}
@media(max-width:700px){
  .schwerpunkte-grid { grid-template-columns: repeat(2, 1fr) }
}
@media(max-width:480px){
  .schwerpunkte-grid { grid-template-columns: 1fr }
}

/* Stats-Bar: 6 Spalten, auf Mobile zusammenfalten */
.stats-bar {
  grid-template-columns: repeat(6, 1fr) !important;
}
@media(max-width:960px){
  .stats-bar { grid-template-columns: repeat(3, 1fr) !important }
}
@media(max-width:600px){
  .stats-bar { grid-template-columns: repeat(2, 1fr) !important }
}

/* Presse-Grid: einheitliche card-Höhe */
.press-photos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: var(--c-border);
}
@media(max-width:900px){
  .press-photos { grid-template-columns: repeat(2, 1fr) }
}
@media(max-width:560px){
  .press-photos { grid-template-columns: 1fr }
}

/* Reden-Cards: kein Text-Overflow */
.rede__title, .rede-card__title {
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

/* ════════════════════════════════════════════════════════════════
   BUGFIXES V3.4 — Layout-Korrekturen
   ════════════════════════════════════════════════════════════════ */

/* Portrait-Split: korrekte Breite, nicht am Rand kleben */
.portrait-split{
  display:grid;
  grid-template-columns:420px 1fr;
  max-width:var(--max-w);
  margin:0 auto
}
@media(max-width:1100px){.portrait-split{grid-template-columns:1fr}}

/* Stats-Bar: stabil 6 Spalten */
.stats-bar{grid-template-columns:repeat(6,1fr)!important}
@media(max-width:960px){.stats-bar{grid-template-columns:repeat(3,1fr)!important}}
@media(max-width:600px){.stats-bar{grid-template-columns:repeat(2,1fr)!important}}

/* Presse-Grid: immer 3 Spalten, nie 1-Karten-Container */
.press-photos{
  display:grid!important;
  grid-template-columns:repeat(3,1fr)!important;
  gap:2px!important;
  background:var(--c-border)!important
}
@media(max-width:900px){.press-photos{grid-template-columns:repeat(2,1fr)!important}}
@media(max-width:560px){.press-photos{grid-template-columns:1fr!important}}

/* Schwerpunkt-Karten: overflow verstecken, einheitliche Höhe */
.section--smoke [style*="border-top:4px"] {
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.section--smoke [style*="border-top:4px"] p {
  flex:1;
  overflow:hidden;
  display:-webkit-box;
  -webkit-line-clamp:4;
  -webkit-box-orient:vertical
}

/* Reden-Cards */
.rede__title,.rede-card__title{
  overflow:hidden;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical
}

/* Schwerpunkt-Grid (inline style "repeat(4,1fr)") responsiv machen */
@media(max-width:1200px){
  [style*="grid-template-columns:repeat(4,1fr)"]{
    grid-template-columns:repeat(3,1fr)!important
  }
}
@media(max-width:900px){
  [style*="grid-template-columns:repeat(4,1fr)"]{
    grid-template-columns:repeat(2,1fr)!important
  }
}
@media(max-width:560px){
  [style*="grid-template-columns:repeat(4,1fr)"]{
    grid-template-columns:1fr!important
  }
}

/* ── VOLLSTÄNDIGE CSS-VARIABLEN ALIASES (alle alten Namen) ──────── */
:root {
  --trkis:  #52b7c1;
  --blau:   #2d3c4b;
  --gold:   #ffa600;
  --rot:    #bf111b;
  --ink:    #0e1015;
  --smoke:  #f5f7f9;
  --white:  #ffffff;
  --muted:  #5a6880;
  --border: rgba(14,16,21,.1);
  --fu:    'Inter', system-ui, sans-serif;
  --fb:    'IBM Plex Serif', Georgia, serif;
  --nav-h: 74px;
  --shadow-s: 0 2px 8px rgba(14,16,21,.07);
  --shadow-m: 0 6px 24px rgba(14,16,21,.1);
  --shadow-l: 0 16px 56px rgba(14,16,21,.14);
}

/* Portrait-Split Mobile: padding hinzufügen wenn 1-spaltig */
@media(max-width:1100px){
  .portrait-split {
    max-width: 100%;
    margin: 0;
  }
  .portrait-split__content {
    padding: clamp(2rem,4vw,3.5rem) var(--pad-x);
  }
}

/* ════════════════════════════════════════════════════════════════
   SOCIAL MEDIA — V3.9
   ════════════════════════════════════════════════════════════════ */

/* Navbar Social Icons */
.nav__socials {
  display: flex;
  align-items: center;
  gap: .2rem;
  padding-left: .5rem;
  border-left: 1px solid rgba(255,255,255,.1);
  margin-left: .25rem;
}
.nav__social-icon {
  width: 34px; height: 34px;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.45);
  transition: color var(--dur), background var(--dur);
  flex-shrink: 0;
}
.nav__social-icon:hover { color: #fff; background: rgba(255,255,255,.08); }
.nav__social-icon svg { width: 17px; height: 17px; }
.nav__social-icon--wa:hover { color: #25D366; }
.nav__social-icon--ig:hover { color: #E1306C; }
.nav__social-icon--fb:hover { color: #1877F2; }
.nav__social-icon--li:hover { color: #0A66C2; }

/* Footer Social Icons */
.footer__socials {
  display: flex;
  align-items: center;
  gap: .35rem;
}
.footer__social {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.45);
  border: 1px solid rgba(255,255,255,.1);
  transition: all .2s;
  flex-shrink: 0;
}
.footer__social svg { width: 17px; height: 17px; }
.footer__social:hover { background: rgba(255,255,255,.14); color: #fff; transform: translateY(-2px); }
.footer__social--wa:hover { background: #25D366; border-color: #25D366; color: #fff; }
.footer__social--ig:hover { background: #E1306C; border-color: #E1306C; color: #fff; }
.footer__social--fb:hover { background: #1877F2; border-color: #1877F2; color: #fff; }
.footer__social--li:hover { background: #0A66C2; border-color: #0A66C2; color: #fff; }

/* Inline Social Buttons (Kontakt-Sektion, Hero-Ergänzung) */
.social-strip {
  display: flex;
  align-items: center;
  gap: .6rem;
  flex-wrap: wrap;
}
.social-btn {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  font-family: var(--f-display);
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: .6rem 1.1rem;
  border-radius: 4px;
  border: 1.5px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.65);
  background: transparent;
  transition: all .2s;
  text-decoration: none;
  white-space: nowrap;
}
.social-btn svg { width: 16px; height: 16px; flex-shrink: 0; }
.social-btn:hover { color: #fff; border-color: rgba(255,255,255,.4); background: rgba(255,255,255,.07); }
.social-btn--ig:hover { border-color: #E1306C; background: rgba(225,48,108,.15); color: #E1306C; }
.social-btn--fb:hover { border-color: #1877F2; background: rgba(24,119,242,.15); color: #1877F2; }
.social-btn--li:hover { border-color: #0A66C2; background: rgba(10,102,194,.15); color: #0A66C2; }
.social-btn--wa:hover { border-color: #25D366; background: rgba(37,211,102,.15); color: #25D366; }

/* Auf weißem Hintergrund */
.social-btn--light {
  border-color: rgba(14,16,21,.14);
  color: var(--c-muted);
  background: var(--c-smoke);
}
.social-btn--light:hover { background: var(--c-trkis); border-color: var(--c-trkis); color: #fff; }

/* WhatsApp Floating Button */
.wa-float {
  position: fixed;
  bottom: 5.5rem;
  right: 1.75rem;
  z-index: 490;
  width: 52px; height: 52px;
  border-radius: 50%;
  background: #25D366;
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(37,211,102,.5);
  text-decoration: none;
  transition: transform .25s, box-shadow .25s;
  animation: wa-pulse 3s ease-in-out infinite;
}
.wa-float svg { width: 26px; height: 26px; }
.wa-float:hover {
  transform: scale(1.12) translateY(-2px);
  box-shadow: 0 8px 32px rgba(37,211,102,.55);
  animation: none;
}
/* Tooltip */
.wa-float::before {
  content: 'WhatsApp';
  position: absolute;
  right: calc(100% + .75rem);
  background: rgba(14,16,21,.9);
  color: #fff;
  font-family: var(--f-display);
  font-weight: 600;
  font-size: .7rem;
  letter-spacing: .04em;
  padding: .4rem .85rem;
  border-radius: 4px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s;
}
.wa-float:hover::before { opacity: 1; }

@keyframes wa-pulse {
  0%,100% { box-shadow: 0 4px 20px rgba(37,211,102,.5); }
  50%      { box-shadow: 0 4px 30px rgba(37,211,102,.75), 0 0 0 8px rgba(37,211,102,.12); }
}

@media(max-width:960px){
  .nav__socials { display: none; }
  .wa-float { bottom: 4.5rem; right: 1.25rem; width: 48px; height: 48px; }
  .wa-float svg { width: 23px; height: 23px; }
}
