/* ===================================================================
   Sefilex — Design System  ·  site.css
   Navy-Basis mit hellen Kontrapunkten · Pfeil-Motiv · Türkis-Highlights
=================================================================== */

@font-face{font-family:'Inter';src:url('fonts/inter-200.woff2') format('woff2');font-weight:200;font-display:swap}
@font-face{font-family:'Inter';src:url('fonts/inter-300.woff2') format('woff2');font-weight:300;font-display:swap}
@font-face{font-family:'Inter';src:url('fonts/inter-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Inter';src:url('fonts/inter-500.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Inter';src:url('fonts/inter-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Inter';src:url('fonts/inter-700.woff2') format('woff2');font-weight:700;font-display:swap}

:root{
  --ink:#050E1C;
  --navy:#0B2545;
  --navy-2:#0E2C53;
  --deep:#081A33;
  --paper:#ECE9E0;
  --paper-2:#E0DCCF;
  --beige:#E8E4D9;
  --beige-2:#C7C3B8;
  --mute:#8C93A1;
  --mute-d:#5C6473;
  --blue:#6FB1E1;
  --blue-d:#3C7FB3;
  --line:rgba(232,228,217,0.13);
  --line-2:rgba(232,228,217,0.06);
  --line-dk:rgba(11,37,69,0.14);
  --ease:cubic-bezier(.16,.84,.44,1);
  --maxw:1320px;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{background:var(--ink)}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,'Helvetica Neue',Arial,sans-serif;
  font-weight:300;line-height:1.62;color:var(--beige);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
html.menu-lock,body.menu-lock{overflow:hidden}
body.lock{overflow:hidden}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font-family:inherit;border:none;background:none;color:inherit}
::selection{background:var(--blue);color:var(--ink)}

/* ---------- cursor ---------- */
.cur{position:fixed;top:0;left:0;z-index:9000;pointer-events:none;mix-blend-mode:difference;will-change:transform}
.cur-dot{width:6px;height:6px;border-radius:50%;background:#fff;margin:-3px 0 0 -3px}
.cur-ring{width:40px;height:40px;border:1px solid #fff;border-radius:50%;margin:-20px 0 0 -20px;
  transition:width .4s var(--ease),height .4s var(--ease),margin .4s var(--ease),opacity .3s,background .3s}
.cur-ring.lg{width:84px;height:84px;margin:-42px 0 0 -42px}
.cur-ring.lbl{width:104px;height:104px;margin:-52px 0 0 -52px;background:#fff}
.cur-ring .cap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:var(--ink);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  opacity:0;transition:opacity .25s;mix-blend-mode:normal}
.cur-ring.lbl .cap{opacity:1}
.cur-dot.hide{opacity:0}
body.is-touch .cur{display:none}
@media(pointer:fine){body{cursor:none}body a,body button,body input{cursor:none}}

.progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--blue);z-index:8000}

/* ---------- preloader ---------- */
.loader{position:fixed;inset:0;z-index:9500;background:var(--ink);display:flex;align-items:center;justify-content:center}
.loader-bars{display:flex;align-items:flex-end;gap:6px;height:60px}
.loader-bars i{width:11px;background:var(--blue);display:block;transform-origin:bottom;transform:scaleY(.12);
  animation:lbar 1.1s var(--ease) infinite}
.loader-bars i:nth-child(1){animation-delay:0s}
.loader-bars i:nth-child(2){animation-delay:.13s}
.loader-bars i:nth-child(3){animation-delay:.26s}
@keyframes lbar{0%,100%{transform:scaleY(.16)}45%{transform:scaleY(1)}}
.loader-num{position:absolute;right:5vw;bottom:4vw;font-size:clamp(3rem,11vw,8rem);font-weight:200;
  letter-spacing:-.04em;color:var(--navy-2);line-height:1}
.loader-line{position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--blue)}
.loader.done{transform:translateY(-100%);transition:transform 1s var(--ease)}

/* ---------- header ---------- */
.header{position:fixed;top:0;left:0;width:100%;z-index:7000;display:flex;align-items:center;
  justify-content:space-between;padding:22px clamp(18px,4vw,52px);
  transition:transform .55s var(--ease),background .5s,padding .5s var(--ease),border-color .5s;
  border-bottom:1px solid transparent}
.header.scrolled{background:rgba(5,14,28,.86);backdrop-filter:blur(14px);padding-top:13px;padding-bottom:13px;border-color:var(--line)}
.header.hidden{transform:translateY(-104%)}
.logo{display:flex;align-items:center;gap:11px}
.logo .lg-glyph{height:29px;width:auto}
.logo .lg-word{height:16px;width:auto}
.header-right{display:flex;align-items:center;gap:clamp(12px,2vw,26px)}
.cta-mini{font-size:12.5px;letter-spacing:.02em;padding:11px 19px;border:1px solid var(--line);
  border-radius:40px;position:relative;overflow:hidden;transition:color .45s var(--ease);white-space:nowrap}
.cta-mini span{position:relative;z-index:2}
.cta-mini::before{content:"";position:absolute;inset:0;background:var(--blue);transform:translateY(101%);
  transition:transform .5s var(--ease);z-index:1}
.cta-mini:hover{color:var(--ink)}
.cta-mini:hover::before{transform:translateY(0)}
.menu-btn{display:flex;align-items:center;gap:11px;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase}
.menu-btn .bars{width:24px;height:9px;position:relative}
.menu-btn .bars i{position:absolute;left:0;height:1px;width:100%;background:var(--beige);
  transition:transform .45s var(--ease),width .45s var(--ease)}
.menu-btn .bars i:first-child{top:0}
.menu-btn .bars i:last-child{bottom:0;width:62%}
.menu-btn:hover .bars i:last-child{width:100%}
body.menu-open .menu-btn .bars i:first-child{transform:translateY(4px) rotate(45deg)}
body.menu-open .menu-btn .bars i:last-child{transform:translateY(-4px) rotate(-45deg);width:100%}

/* ---------- fullscreen menu ---------- */
.overlay{position:fixed;inset:0;z-index:6800;background:var(--deep);clip-path:inset(0 0 100% 0);
  transition:clip-path .9s var(--ease);display:flex;flex-direction:column;overflow-y:auto}
body.menu-open .overlay{clip-path:inset(0 0 0 0)}
.overlay-grid{position:absolute;inset:0;background-image:
  linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);
  background-size:64px 64px;opacity:.5}
.overlay-in{position:relative;margin:auto;width:100%;max-width:var(--maxw);
  padding:120px clamp(18px,5vw,80px) 60px;display:grid;grid-template-columns:1.5fr 1fr;gap:60px;align-items:center}
.nav-list{list-style:none}
.nav-list li{overflow:hidden}
.nav-list a{display:flex;align-items:baseline;gap:18px;font-size:clamp(2rem,5vw,3.9rem);font-weight:300;
  letter-spacing:-.025em;padding:7px 0;color:var(--beige);transform:translateY(110%);
  transition:transform .8s var(--ease),color .4s}
body.menu-open .nav-list a{transform:translateY(0)}
body.menu-open .nav-list li:nth-child(1) a{transition-delay:.16s}
body.menu-open .nav-list li:nth-child(2) a{transition-delay:.22s}
body.menu-open .nav-list li:nth-child(3) a{transition-delay:.28s}
body.menu-open .nav-list li:nth-child(4) a{transition-delay:.34s}
body.menu-open .nav-list li:nth-child(5) a{transition-delay:.40s}
body.menu-open .nav-list li:nth-child(6) a{transition-delay:.46s}
.nav-list a .ix{font-size:13px;font-weight:500;color:var(--blue);letter-spacing:.1em;transform:translateY(-.6em)}
.nav-list a .ar{margin-left:4px;color:var(--blue);opacity:0;transform:translateX(-14px);
  transition:opacity .4s,transform .4s var(--ease)}
.nav-list a:hover{color:var(--blue)}
.nav-list a:hover .ar{opacity:1;transform:translateX(0)}
.overlay-aside{border-left:1px solid var(--line);padding-left:46px;opacity:0;transition:opacity .6s .55s}
body.menu-open .overlay-aside{opacity:1}
.overlay-aside .lbl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:14px}
.overlay-aside p{font-size:15px;color:var(--beige-2);margin-bottom:26px}
.overlay-aside a.contact{font-size:18px;display:block;margin-bottom:6px}
.socials{display:flex;gap:20px;margin-top:28px;font-size:12.5px;color:var(--mute)}
.socials a{transition:color .3s}.socials a:hover{color:var(--blue)}

/* ---------- layout primitives ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,5vw,80px)}
section{position:relative}
.band-ink{background:var(--ink);color:var(--beige)}
.band-navy{background:var(--navy);color:var(--beige)}
.band-deep{background:var(--deep);color:var(--beige)}
.band-light{background:var(--paper);color:var(--navy)}
.pad{padding:clamp(96px,14vh,180px) 0}
.pad-s{padding:clamp(70px,9vh,120px) 0}

.kicker{display:inline-flex;align-items:center;gap:12px;font-size:11px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--blue-d)}
.band-ink .kicker,.band-navy .kicker,.band-deep .kicker{color:var(--blue)}
.kicker::before{content:"";width:26px;height:1px;background:currentColor;opacity:.7}
.h1{font-size:clamp(2.3rem,5.6vw,4.9rem);font-weight:200;letter-spacing:-.04em;line-height:1.03}
.h2{font-size:clamp(1.9rem,3.8vw,3.4rem);font-weight:200;letter-spacing:-.03em;line-height:1.1}
.h3{font-size:1.28rem;font-weight:500;letter-spacing:-.01em}
.lead{font-size:clamp(1rem,1.35vw,1.2rem);font-weight:300}
.band-ink .lead,.band-navy .lead,.band-deep .lead{color:var(--beige-2)}
.band-light .lead{color:var(--navy-2)}
.muted{color:var(--mute)}
.band-light .muted{color:var(--mute-d)}

/* ---------- reveal ---------- */
.r{opacity:0;transform:translateY(34px);transition:opacity 1.05s var(--ease),transform 1.05s var(--ease)}
.r.in{opacity:1;transform:none}
.r.d1{transition-delay:.09s}.r.d2{transition-delay:.18s}.r.d3{transition-delay:.27s}
.r.d4{transition-delay:.36s}.r.d5{transition-delay:.45s}
.line-mask{display:block;overflow:hidden}
.line-mask>*{display:block;transform:translateY(110%);transition:transform 1s var(--ease)}
.line-mask.in>*{transform:translateY(0)}

/* ---------- türkis highlight (Eversheds-Stil) ---------- */
.hl{position:relative;white-space:nowrap;transition:color .35s .15s var(--ease);z-index:0}
.hl::before{content:"";position:absolute;left:-.1em;right:-.1em;top:.06em;bottom:.04em;z-index:-1;
  background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease)}
.hl.lit::before{transform:scaleX(1)}
.hl.lit{color:var(--ink)}

/* ---------- arrows motif ---------- */
.amotif{display:inline-flex;align-items:flex-end;gap:3px;height:1em}
.amotif i{width:.2em;background:var(--blue);display:block}
.amotif i:nth-child(1){height:.42em}
.amotif i:nth-child(2){height:.66em}
.amotif i:nth-child(3){height:1em}
.amotif.rise i{transform:scaleY(0);transform-origin:bottom;transition:transform .6s var(--ease)}
.amotif.rise.in i:nth-child(1){transform:scaleY(1)}
.amotif.rise.in i:nth-child(2){transform:scaleY(1);transition-delay:.1s}
.amotif.rise.in i:nth-child(3){transform:scaleY(1);transition-delay:.2s}
.amotif-bg{position:absolute;pointer-events:none;display:flex;align-items:flex-end;gap:14px;opacity:.05;z-index:0}
.amotif-bg span{display:block;background:currentColor;width:38px}
.amotif-bg span:nth-child(1){height:120px}
.amotif-bg span:nth-child(2){height:200px}
.amotif-bg span:nth-child(3){height:300px}

/* ---------- buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:11px;padding:17px 32px;border-radius:46px;
  font-size:14px;font-weight:500;letter-spacing:.02em;background:var(--blue);color:var(--ink);
  overflow:hidden;will-change:transform}
.btn .t{position:relative;z-index:2}
.btn::after{content:"";position:absolute;inset:0;background:#fff;transform:translateY(101%);
  transition:transform .55s var(--ease);z-index:1}
.btn:hover::after{transform:translateY(0)}
.btn-line{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:400}
.btn-line .dl{width:28px;height:1px;background:var(--blue);transition:width .45s var(--ease)}
.btn-line:hover .dl{width:52px}
.btn-ghost{display:inline-flex;align-items:center;gap:11px;padding:17px 30px;border-radius:46px;
  border:1px solid currentColor;font-size:14px;font-weight:400;transition:background .4s,color .4s}
.band-light .btn-ghost:hover{background:var(--navy);color:var(--paper)}
.band-ink .btn-ghost:hover,.band-navy .btn-ghost:hover,.band-deep .btn-ghost:hover{background:var(--beige);color:var(--ink)}

/* ---------- section heading block ---------- */
.shead{display:flex;gap:50px;align-items:flex-end;flex-wrap:wrap;margin-bottom:60px}
.shead .stxt{flex:1;min-width:280px}
.shead .h2{margin-top:20px}
.sno{font-size:.78rem;font-weight:600;letter-spacing:.16em;color:var(--blue);padding-bottom:6px}

/* ---------- hero ---------- */
.hero{min-height:100vh;display:flex;align-items:center;overflow:hidden;padding:150px 0 130px;position:relative}
#orbs{position:absolute;inset:0;z-index:1}
.hero-grid{position:absolute;inset:0;z-index:2;background-image:
  linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);
  background-size:88px 88px;-webkit-mask-image:radial-gradient(ellipse 72% 68% at 50% 42%,#000,transparent 82%);
  mask-image:radial-gradient(ellipse 72% 68% at 50% 42%,#000,transparent 82%)}
.hero-in{position:relative;z-index:3;width:100%;will-change:transform}
.hero .kicker{margin-bottom:28px}
.hero-title{font-size:clamp(2.5rem,6.4vw,5.6rem);font-weight:200;letter-spacing:-.045em;line-height:1.0}
.hero-title .accent{color:var(--blue)}
.rot{display:inline-block;position:relative;height:1.06em;overflow:hidden;vertical-align:bottom;
  transition:width .58s var(--ease)}
.rot-in{display:block;transition:transform .62s var(--ease)}
.rot i{display:block;font-style:normal;width:max-content;height:1.06em;line-height:1.06}
.hero-sub{margin-top:30px;max-width:50ch}
.hero-act{margin-top:40px;display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.hero-cue{position:absolute;left:clamp(18px,5vw,80px);bottom:28px;z-index:3;display:flex;align-items:center;
  gap:11px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute)}
.hero-cue .v{width:1px;height:28px;background:var(--line);position:relative;overflow:hidden}
.hero-cue .v::after{content:"";position:absolute;top:0;left:0;width:100%;height:50%;background:var(--blue);
  animation:vrun 1.9s var(--ease) infinite}
@keyframes vrun{0%{transform:translateY(-100%)}100%{transform:translateY(200%)}}

/* ---------- logo marquee ---------- */
.logos{padding:38px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--deep);overflow:hidden;position:relative}
.logos::before,.logos::after{content:"";position:absolute;top:0;bottom:0;width:110px;z-index:2;pointer-events:none}
.logos::before{left:0;background:linear-gradient(90deg,var(--deep),transparent)}
.logos::after{right:0;background:linear-gradient(270deg,var(--deep),transparent)}
.logos-lab{text-align:center;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:26px}
.logos-track{display:flex;align-items:center;width:max-content;animation:scrollx 36s linear infinite}
.logos:hover .logos-track{animation-play-state:paused}
.logos-track img{height:25px;width:auto;margin-right:82px;opacity:.48;transition:opacity .4s}
.logos-track img.krone{height:42px}
.logos-track img:hover{opacity:1}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- sectors (Pininfarina-Stil) ---------- */
.sectors-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.sector{position:relative;display:block;border-bottom:1px solid var(--line);overflow:hidden}
.sector-row{position:relative;z-index:2;display:grid;grid-template-columns:80px 1fr auto auto;gap:30px;
  align-items:center;padding:clamp(22px,3vw,40px) 6px;transition:padding .5s var(--ease),color .4s}
.sector .sx{font-size:12px;font-weight:600;letter-spacing:.1em;color:var(--blue)}
.sector .sname{font-size:clamp(1.7rem,3.6vw,3rem);font-weight:200;letter-spacing:-.03em}
.sector .sdesc{max-width:34ch;font-size:.92rem;color:var(--mute);opacity:.7;transition:opacity .4s,color .4s}
.sector .sarrow{color:var(--blue);font-size:1.1rem;transform:translateX(-8px);opacity:.5;
  transition:transform .45s var(--ease),opacity .4s}
.sector-img{position:absolute;inset:0;z-index:1;opacity:0;transition:opacity .6s var(--ease)}
.sector-img img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);transition:transform 1.1s var(--ease)}
.sector-img::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,14,28,.92),rgba(5,14,28,.45))}
.sector:hover .sector-img{opacity:1}
.sector:hover .sector-img img{transform:scale(1)}
.sector:hover .sector-row{padding-left:26px}
.sector:hover .sdesc{opacity:1;color:var(--beige-2)}
.sector:hover .sarrow{transform:translateX(0);opacity:1}

/* ---------- feature / card grids ---------- */
.grid{display:grid;gap:1px;background:var(--line);border:1px solid var(--line)}
.band-light .grid{background:var(--line-dk);border-color:var(--line-dk)}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.cell{background:var(--navy);padding:38px 34px}
.band-ink .cell{background:var(--ink)}
.band-deep .cell{background:var(--deep)}
.band-light .cell{background:var(--paper)}
.cell .ci{font-size:.76rem;font-weight:600;letter-spacing:.12em;color:var(--blue);margin-bottom:20px}
.cell .h3{margin-bottom:11px}
.cell p{font-size:.95rem}
.cell.hovic{transition:background .5s var(--ease)}
.band-deep .cell.hovic:hover{background:var(--navy)}
.band-light .cell.hovic:hover{background:var(--paper-2)}

/* ---------- numbered process ---------- */
.steps{counter-reset:st}
.step{display:grid;grid-template-columns:64px 1fr;gap:26px;padding:30px 0;border-bottom:1px solid var(--line);
  transition:padding-left .45s var(--ease)}
.band-light .step{border-color:var(--line-dk)}
.step:first-child{border-top:1px solid var(--line)}
.band-light .step:first-child{border-top-color:var(--line-dk)}
.step:hover{padding-left:14px}
.step .stn{font-size:2rem;font-weight:200;color:var(--blue);line-height:1}
.step h4{font-size:1.2rem;font-weight:500;margin-bottom:7px}
.step p{font-size:.96rem}

/* ---------- stats ---------- */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.stat{background:var(--ink);padding:clamp(32px,4vw,52px) clamp(24px,3vw,40px)}
.band-navy .stat{background:var(--navy)}
.stat .num{font-size:clamp(3rem,6vw,5rem);font-weight:200;letter-spacing:-.04em;line-height:1;color:var(--beige)}
.stat .num u{text-decoration:none;color:var(--blue);font-size:.5em;vertical-align:.35em}
.stat .cap{margin-top:15px;color:var(--mute);font-size:.94rem;max-width:30ch}

/* ---------- disclosure list (Branchen-Seiten) ---------- */
.disc{border-top:1px solid var(--line)}
.band-light .disc{border-color:var(--line-dk)}
.disc-item{border-bottom:1px solid var(--line)}
.band-light .disc-item{border-color:var(--line-dk)}
.disc-q{width:100%;display:flex;align-items:center;gap:22px;padding:26px 6px;text-align:left;
  transition:padding .4s var(--ease)}
.disc-q .dqn{font-size:.8rem;font-weight:600;color:var(--blue);letter-spacing:.1em}
.disc-q .dqt{flex:1;font-size:clamp(1.1rem,1.7vw,1.5rem);font-weight:400;letter-spacing:-.01em}
.disc-q .dqx{position:relative;width:16px;height:16px;flex:none}
.disc-q .dqx::before,.disc-q .dqx::after{content:"";position:absolute;background:var(--blue);
  transition:transform .4s var(--ease)}
.disc-q .dqx::before{left:0;top:7px;width:16px;height:2px}
.disc-q .dqx::after{left:7px;top:0;width:2px;height:16px}
.disc-item.open .dqx::after{transform:scaleY(0)}
.disc-q:hover{padding-left:14px}
.disc-body{max-height:0;overflow:hidden;transition:max-height .55s var(--ease)}
.disc-body-in{padding:4px 6px 32px;display:grid;grid-template-columns:1fr 1fr;gap:14px 40px}
.disc-body-in .di-intro{grid-column:1/-1;color:var(--beige-2);max-width:64ch;margin-bottom:14px}
.band-light .disc-body-in .di-intro{color:var(--navy-2)}
.di-point{display:flex;gap:14px;padding:14px 0;border-top:1px solid var(--line)}
.band-light .di-point{border-color:var(--line-dk)}
.di-point .dp-mark{flex:none;margin-top:6px}
.di-point p{font-size:.93rem}
.di-point b{font-weight:600;color:var(--beige)}
.band-light .di-point b{color:var(--navy)}

/* ---------- team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(13px,1.5vw,22px)}
.member{display:block;color:inherit;text-decoration:none}
.member .portrait{position:relative;overflow:hidden;aspect-ratio:4/5;background:var(--deep);border:1px solid var(--line)}
.member .portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:none;transition:transform 1s var(--ease)}
.member:hover .portrait img{transform:scale(1.05)}
.member .m-name{margin-top:16px;font-size:1.1rem;font-weight:500}
.member .m-role{font-size:.85rem;color:var(--mute);margin-top:2px}

/* ---------- image frame ---------- */
.frame{position:relative;overflow:hidden;background:var(--navy)}
.frame img{width:100%;height:114%;object-fit:cover;will-change:transform}
.frame .fl{position:absolute;inset:13px;border:1px solid rgba(232,228,217,.22);z-index:2;pointer-events:none}
.frame .badge{position:absolute;left:20px;bottom:20px;z-index:3;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;background:rgba(5,14,28,.66);backdrop-filter:blur(4px);border:1px solid var(--line);
  padding:9px 13px;color:var(--beige)}

/* ---------- testimonial ---------- */
.quote{font-size:clamp(1.5rem,3vw,2.7rem);font-weight:200;letter-spacing:-.025em;line-height:1.32}
.quote .q{color:var(--blue)}

/* ---------- forms ---------- */
.field{margin-bottom:26px}
.field label{display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);margin-bottom:9px}
.field input,.field textarea,.field select{width:100%;background:transparent;border:none;
  border-bottom:1px solid var(--line);color:inherit;font-family:inherit;font-size:1.02rem;
  padding:11px 2px;outline:none;transition:border-color .35s}
.band-light .field input,.band-light .field textarea,.band-light .field select{border-color:var(--line-dk)}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--blue)}
.field textarea{resize:vertical;min-height:120px}
.checkrow{display:flex;gap:12px;align-items:flex-start;font-size:.86rem;color:var(--mute)}
.checkrow input{width:17px;height:17px;flex:none;accent-color:var(--blue)}

/* ---------- footer ---------- */
footer{background:var(--ink);color:var(--beige);padding-top:96px;overflow:hidden}
.foot-cta{text-align:center;padding-bottom:90px;border-bottom:1px solid var(--line)}
.foot-mark{padding:54px clamp(18px,5vw,80px) 0}
.foot-mark img{width:100%;opacity:.14}
.foot-cols{display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:40px;padding:64px 0 46px;border-bottom:1px solid var(--line)}
.foot-cols .ch{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:16px}
.foot-cols a{display:block;font-size:.95rem;color:var(--beige-2);padding:5px 0;transition:color .3s}
.foot-cols a:hover{color:var(--blue)}
.foot-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;padding:26px 0 42px;
  font-size:12px;color:var(--mute)}
.foot-bot a:hover{color:var(--beige-2)}

/* ---------- page hero (subpages) ---------- */
.phero{padding:170px 0 clamp(70px,9vh,120px);position:relative;overflow:hidden}
.phero .h1{margin:24px 0 26px;max-width:20ch}
.phero .lead{max-width:60ch}
.phero-img{position:absolute;inset:0;z-index:0}
.phero-img img{width:100%;height:100%;object-fit:cover;opacity:.26}
.phero-img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(5,14,28,.7),var(--ink) 92%),linear-gradient(90deg,var(--ink),transparent 70%)}
.phero .wrap{position:relative;z-index:2}
.crumb{display:flex;gap:9px;font-size:12px;letter-spacing:.04em;color:var(--mute)}
.crumb a:hover{color:var(--blue)}

/* ---------- prose (Recht/Datenschutz) ---------- */
.prose{max-width:72ch}
.prose h2{font-size:1.4rem;font-weight:500;margin:42px 0 12px;letter-spacing:-.01em}
.prose h3{font-size:1.08rem;font-weight:600;margin:26px 0 8px}
.prose p{margin-bottom:13px;color:var(--beige-2)}
.band-light .prose p{color:var(--navy-2)}
.prose a{color:var(--blue);border-bottom:1px solid var(--line)}

/* ---------- subpage sections ---------- */
.phero.lg{padding:188px 0 clamp(80px,11vh,144px)}
.phero.lg .phero-img img{opacity:.4}
.phero.lg .phero-img::after{background:linear-gradient(180deg,rgba(5,14,28,.5),var(--ink) 95%),linear-gradient(90deg,rgba(5,14,28,.84),transparent 72%)}
.secnum{font-size:clamp(3.6rem,8vw,7rem);font-weight:200;line-height:.8;letter-spacing:-.04em;color:var(--blue);opacity:.22;min-width:46px}
.band-light .secnum{color:var(--navy);opacity:.16}
.imgband{height:clamp(260px,42vh,480px);overflow:hidden;position:relative}
.imgband img{width:100%;height:124%;object-fit:cover;will-change:transform}
.imgband::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,14,28,.42),rgba(5,14,28,.66))}
.imgband .ib-txt{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;text-align:center;padding:0 28px}
.imgband .ib-txt p{font-size:clamp(1.3rem,2.6vw,2.2rem);font-weight:200;letter-spacing:-.02em;line-height:1.3;max-width:26ch;color:var(--beige)}
.nextsec{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-dk);border:1px solid var(--line-dk)}
.nextsec a{background:var(--paper);padding:28px 30px;display:flex;justify-content:space-between;align-items:center;gap:20px;transition:background .45s var(--ease),padding .4s var(--ease)}
.nextsec a:hover{background:var(--paper-2);padding-left:38px}
.nextsec a .ns-n{font-size:1.18rem;font-weight:400}
.nextsec a .ns-x{color:var(--blue-d);transition:transform .4s var(--ease)}
.nextsec a:hover .ns-x{transform:translateX(6px)}
@media(max-width:680px){.nextsec{grid-template-columns:1fr}}

/* ---------- responsive ---------- */
@media(max-width:1180px){
  .overlay-in{grid-template-columns:1fr;gap:38px;padding-top:120px}
  .overlay-aside{border-left:none;border-top:1px solid var(--line);padding-left:0;padding-top:32px}
  .g4{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .disc-body-in{grid-template-columns:1fr}
}
@media(max-width:860px){
  .g2,.g3,.stat-row{grid-template-columns:1fr}
  .sector-row{grid-template-columns:48px 1fr auto;gap:16px}
  .sector .sdesc{display:none}
  .shead{margin-bottom:42px}
  .foot-cols{grid-template-columns:1fr 1fr}
  .cta-mini{display:none}
  .hero{padding:130px 0 100px}
}
@media(max-width:560px){
  body{cursor:auto}
  .cur{display:none}
  .g4,.team-grid{grid-template-columns:1fr}
  .foot-cols{grid-template-columns:1fr}
  .step{grid-template-columns:1fr;gap:8px}
  .sector-row{grid-template-columns:1fr auto;gap:10px}
  .sector .sx{display:none}
  .pad{padding:80px 0}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .r,.line-mask>*,.amotif.rise i{opacity:1;transform:none}
  html{scroll-behavior:auto}
}


/* ===== Startseiten-Designsystem, fuer alle Seiten ===== */

:root{--f1:clamp(2.3rem,5vw,4.5rem);--f2:clamp(1.5rem,2.7vw,2.35rem);--f3:1.05rem;--f4:.8rem;
--ink:#07182E;--navy:#0B2545;--navy-2:#0B2545;--deep:#07182E;
--paper:#E8E4D9;--paper-2:#DCD7C9;--beige:#E8E4D9;--beige-2:rgba(232,228,217,.66);
--mute:rgba(232,228,217,.5);--mute-d:rgba(11,37,69,.58);--blue:#6FB1E1;--blue-d:#0B2545;
--line:rgba(232,228,217,.13);--line-2:rgba(232,228,217,.055);--line-dk:rgba(11,37,69,.13)}
body{font-size:var(--f3)}
.progress{height:3px}
.cur-ring{width:34px;height:34px;margin:-17px 0 0 -17px}
.cur-ring.lg{width:60px;height:60px;margin:-30px 0 0 -30px}
.cur-ring.lbl{width:88px;height:88px;margin:-44px 0 0 -44px}
.h1,.hero-title,.cta-block-h{font-size:var(--f1);font-weight:200;letter-spacing:-.04em;line-height:1.05}
.h2{font-size:var(--f2);font-weight:200;letter-spacing:-.03em;line-height:1.12}
.h3{font-size:var(--f3);font-weight:500}
.lead{font-size:var(--f3)}
.kicker,.sno,.m-role,.crumb,.foot-bot,.logos-lab,.foot-cols .ch{font-size:var(--f4)}
.nav-list a{font-size:var(--f1)}

/* ---- Preloader: Logo färbt sich von links nach rechts ---- */
.loader-bars,.loader-num{display:none}
.ld-logo{position:relative;width:min(186px,42vw)}
.ld-logo img{width:100%;display:block}
.ld-base{filter:grayscale(1) brightness(.4)}
.ld-fill{position:absolute;inset:0;clip-path:inset(0 100% 0 0);animation:ldWipe .58s var(--ease) .14s forwards}
@keyframes ldWipe{to{clip-path:inset(0 0 0 0)}}

/* ---- Header ---- */
.header{padding-left:clamp(18px,4vw,52px);padding-right:clamp(16px,3vw,38px)}
.header-right{gap:clamp(12px,1.6vw,20px)}

/* ---- Menü ohne Scrollen ---- */
.overlay-in{padding:96px clamp(18px,5vw,80px) 64px;gap:48px;align-items:center}
.nav-list a{padding:3px 0;line-height:1.14;letter-spacing:-.03em}
.overlay-aside .socials{flex-wrap:wrap;gap:14px 18px;margin-top:22px}
@media(max-height:780px){.overlay-in{padding-top:80px}.nav-list a{font-size:clamp(1.7rem,4.3vh,2.9rem)}}

/* ---- Hero: rotierendes Adjektiv flexibel ---- */
.hero-title{line-height:1.2}
.hero-line2{display:inline}
.rot{display:inline-block;position:relative;height:1.2em;overflow:hidden;vertical-align:bottom;
  transition:width .5s var(--ease)}
.rot-in{display:block;transition:transform .6s var(--ease)}
.rot i{display:block;font-style:normal;height:1.2em;line-height:1.2;width:max-content;color:var(--blue)}

.hl::before{top:.04em;bottom:.06em}

/* ---- Zahlen: ruhig, konsistent, hochwertig ---- */
.facts{margin-top:18px;display:grid;grid-template-columns:repeat(3,1fr)}
.fact{padding:clamp(8px,1.4vw,18px) clamp(20px,2.6vw,42px)}
.fact:first-child{padding-left:0}
.fact+.fact{border-left:1px solid var(--line)}
.fact-num{display:block;font-size:var(--f1);font-weight:200;letter-spacing:-.05em;line-height:.9;color:var(--beige)}
.fact-num u{text-decoration:none;color:var(--blue);font-size:.34em;vertical-align:.9em;margin-left:.04em}
.fact-cap{display:block;font-size:var(--f3);color:var(--beige-2);margin-top:16px}
@media(max-width:760px){.facts{grid-template-columns:1fr}
  .fact+.fact{border-left:none;border-top:1px solid var(--line)}}

/* ---- Prinzipien ---- */
.princ{border-top:1px solid var(--line)}
.princ-row{display:grid;grid-template-columns:84px 1fr 1.1fr;gap:34px;align-items:center;
  padding:clamp(26px,3.4vw,44px) 0;border-bottom:1px solid var(--line);transition:padding-left .5s var(--ease)}
.princ-row:hover{padding-left:18px}
.princ-ar{width:48px;height:auto;overflow:visible}
.princ-ar>*{transform:scaleY(0);transform-origin:bottom;transform-box:fill-box;transition:transform .55s var(--ease)}
.princ-row.in .princ-ar>*{transform:scaleY(1)}
.princ-row.in .princ-ar .p2{transition-delay:.09s}
.princ-row.in .princ-ar .p3{transition-delay:.18s}
.princ-row:hover .princ-ar>*{transform:scaleY(1.04)}
.princ-name{font-size:var(--f2);font-weight:300;letter-spacing:-.02em}
.princ-desc{font-size:var(--f3);color:var(--mute)}
@media(max-width:760px){.princ-row{grid-template-columns:1fr;gap:14px}.princ-ar{height:42px}}

/* ---- Philosophie ---- */
.philo-g2{display:grid;grid-template-columns:.92fr 1fr;gap:clamp(36px,5vw,80px);align-items:stretch}
.philo-portrait{position:relative;overflow:hidden;background:var(--navy);min-height:100%}
.philo-portrait img{width:100%;height:100%;object-fit:cover;object-position:50% 20%}
.philo-portrait .fl{position:absolute;inset:14px;border:1px solid rgba(232,228,217,.2)}
.philo-side{display:flex;flex-direction:column;justify-content:center}
.philo-side .badge{align-self:flex-start;font-size:var(--f4);letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin-bottom:20px}
.philo-quote{font-size:var(--f2);font-weight:200;line-height:1.34;letter-spacing:-.02em}
.philo-sign{margin-top:26px;padding-top:20px;border-top:1px solid var(--line)}
.philo-sign .nm{font-weight:500}.philo-sign .rl{font-size:var(--f4);color:var(--mute);margin-top:3px}
@media(max-width:820px){.philo-g2{grid-template-columns:1fr}.philo-portrait{aspect-ratio:4/5;min-height:0}}

/* ---- Schnittmenge ---- */
.venn-wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.venn{width:100%;max-width:440px;margin:0 auto;overflow:visible}
.venn circle.disc{mix-blend-mode:screen}
@media(max-width:860px){.venn-wrap{grid-template-columns:1fr;gap:46px}}

/* ---- Timeline ---- */
.tl{margin-top:58px}
.tl-row{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,30px);position:relative}
.tl-line{position:absolute;left:27px;right:27px;top:27px;height:2px;background:var(--line)}
.tl-line span{position:absolute;left:0;top:0;height:100%;width:0;background:var(--blue);transition:width 1.7s var(--ease)}
.tl.in .tl-line span{width:100%}
.tl-step{cursor:pointer}
.tl-node{width:54px;height:54px;border-radius:50%;border:1.5px solid var(--line);background:var(--navy);
  display:flex;align-items:center;justify-content:center;font-size:var(--f3);font-weight:300;color:var(--blue);
  position:relative;z-index:2;transition:border-color .4s,background .4s,color .4s,transform .45s var(--ease)}
.tl-step:hover .tl-node{border-color:var(--blue);background:var(--blue);color:var(--ink);transform:scale(1.1)}
.tl-h{font-size:var(--f3);font-weight:500;margin:22px 0 0;transition:color .35s}
.tl-step:hover .tl-h{color:var(--blue)}
.tl-more{max-height:0;overflow:hidden;opacity:0;transition:max-height .55s var(--ease),opacity .4s,margin .4s}
.tl-step:hover .tl-more{max-height:220px;opacity:1;margin-top:12px}
.tl-more p{font-size:var(--f4);color:var(--mute);line-height:1.65;max-width:30ch}
@media(max-width:760px){.tl-row{grid-template-columns:1fr;gap:0}
  .tl-line{left:27px;right:auto;top:27px;bottom:27px;width:2px;height:auto}
  .tl.in .tl-line span{width:100%;height:100%}
  .tl-step{display:grid;grid-template-columns:54px 1fr;gap:20px;padding-bottom:30px;align-items:start}
  .tl-h{margin:14px 0 0}.tl-step:hover .tl-more,.tl-more{max-height:220px;opacity:1;margin-top:8px}}

/* ---- Sektoren: rotierendes Rad ---- */
.sek{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(34px,5vw,70px);align-items:center}
.sek-info{position:relative;min-height:330px}
.sek-panel{position:absolute;inset:0;opacity:0;transform:translateY(18px);
  transition:opacity .55s var(--ease),transform .55s var(--ease);pointer-events:none}
.sek-panel.on{opacity:1;transform:none;pointer-events:auto}
.sek-pn{font-size:var(--f4);color:var(--blue);font-weight:600;letter-spacing:.12em}
.sek-pname{font-size:var(--f1);font-weight:200;letter-spacing:-.04em;margin:14px 0 18px}
.sek-pdesc{font-size:var(--f3);color:var(--beige-2);max-width:40ch}
.sek-plink{margin-top:24px;display:inline-flex;align-items:center;gap:10px;font-size:var(--f3)}
.sek-plink .dl{width:30px;height:1px;background:var(--blue);transition:width .4s var(--ease)}
.sek-plink:hover .dl{width:54px}
.sek-stage{position:relative;aspect-ratio:1;width:100%;max-width:500px;justify-self:end}
.sek-orbit{position:absolute;inset:15%;border:1px solid var(--line-2);border-radius:50%}
.sek-spoke{position:absolute;top:50%;left:50%;height:1px;background:var(--line-2);transform-origin:0 50%;z-index:1}
.sek-spoke.on{background:linear-gradient(90deg,transparent,var(--blue))}
.sek-hub{position:absolute;top:50%;left:50%;width:104px;height:104px;margin:-52px 0 0 -52px;border-radius:50%;
  border:1px solid var(--line);background:var(--ink);display:flex;align-items:center;justify-content:center;z-index:3}
.sek-hub img{width:42px;opacity:.9}
.sek-node{position:absolute;z-index:2;padding:11px 18px;border-radius:30px;border:1px solid var(--line);
  background:rgba(8,26,51,.82);backdrop-filter:blur(4px);font-size:var(--f4);letter-spacing:.02em;
  color:var(--beige-2);white-space:nowrap;animation:waver 5.6s ease-in-out infinite;
  transition:background .35s,color .35s,border-color .35s}
.sek-node:hover{border-color:var(--blue);color:var(--beige);background:rgba(111,177,225,.16)}
.sek-node.on{background:var(--blue);color:var(--ink);border-color:var(--blue);font-weight:600}
@keyframes waver{0%,100%{transform:translate(-3px,-5px)}50%{transform:translate(3px,5px)}}
@media(max-width:860px){.sek{grid-template-columns:1fr;gap:42px}.sek-info{min-height:280px}
  .sek-stage{max-width:380px}.sek-node{font-size:.72rem;padding:9px 13px}}

/* ---- Team-Hover ruhig ---- */
.member .portrait img{filter:none}
.member:hover .portrait img{transform:scale(1.045)}
.member .portrait::after{background:linear-gradient(180deg,rgba(8,26,51,0) 54%,rgba(8,26,51,.8))}
.member .portrait .tag{background:none;border:none;backdrop-filter:none;left:16px;bottom:14px;padding:0}
body.cur-plain .cur{mix-blend-mode:normal}
body.cur-plain .cur-ring{border-color:var(--blue)}
body.cur-plain .cur-dot{background:var(--blue)}

/* ---- Zitate ---- */
.quotes{position:relative;text-align:center}
.q-track{position:relative;min-height:clamp(330px,40vh,400px)}
.q-item{position:absolute;left:0;right:0;top:0;opacity:0;transform:translateY(22px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);pointer-events:none}
.q-item.on{opacity:1;transform:none;pointer-events:auto}
.q-logo{height:26px;width:auto;margin:0 auto 30px;opacity:.6}
.q-text{font-size:var(--f2);font-weight:200;line-height:1.42;letter-spacing:-.02em;max-width:30ch;margin:0 auto}
.q-text .q{color:var(--blue)}
.q-who{margin-top:30px}.q-who .nm{font-weight:500}.q-who .rl{font-size:var(--f4);color:var(--mute);margin-top:3px}
.q-dots{display:flex;gap:10px;justify-content:center;margin-top:42px;position:relative}
.q-dots button{width:36px;height:3px;background:var(--line);transition:background .4s}
.q-dots button.on{background:var(--blue)}
@media(pointer:fine){.quotes{cursor:none}}

/* ---- Ressourcen ---- */
.res-feat{display:grid;grid-template-columns:1.25fr 1fr;gap:0;border:1px solid var(--line);margin-bottom:18px}
.res-feat .rf-img{position:relative;overflow:hidden;min-height:340px}
.res-feat .rf-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.res-feat:hover .rf-img img{transform:scale(1.05)}
.res-feat .rf-body{padding:clamp(30px,4vw,54px);display:flex;flex-direction:column;justify-content:center}
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.res-card{border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column}
.res-card .rc-img{aspect-ratio:3/2;overflow:hidden}
.res-card .rc-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.res-card:hover .rc-img img{transform:scale(1.06)}
.res-card .rc-body{padding:24px 24px 28px}
.res-btns{display:flex;gap:22px;flex-wrap:wrap;margin-top:42px;align-items:center}
@media(max-width:820px){.res-feat,.res-grid{grid-template-columns:1fr}.res-feat .rf-img{min-height:240px}}

/* ---- Footer-Logo sauber ---- */
.foot-mark{display:none}
.foot-logo{display:inline-block}
.foot-logo img{height:30px;width:auto;display:block}

/* ---- Venn-Outline, Hero-Kunst, Zitat-Cursor ---- */
.venn .vc{stroke-dasharray:806;stroke-dashoffset:806}
.venn.in .vc{stroke-dashoffset:0}
.venn #vcB{transition-delay:.15s}
.venn #vcC{transition-delay:.3s}
.venn .vint{opacity:0;transition:opacity .8s var(--ease) .55s}
.venn.in .vint{opacity:1}
.venn .vt{pointer-events:all}
.hero-art{position:absolute;right:clamp(-30px,3vw,70px);top:50%;transform:translateY(-50%);
  width:clamp(190px,27vw,420px);z-index:2}
.hero-art svg{width:100%;height:auto;overflow:visible}
.hero-art svg>*{fill:var(--blue);opacity:.15;transform-origin:bottom;transform-box:fill-box;
  transition:opacity .6s var(--ease),filter .6s var(--ease)}
.hero-art svg>*:nth-child(1){animation:hb 3.8s var(--ease) infinite}
.hero-art svg>*:nth-child(2){animation:hb 3.8s var(--ease) .22s infinite}
.hero-art svg>*:nth-child(3){animation:hb 3.8s var(--ease) .44s infinite}
.hero-art:hover svg>*{opacity:.5;filter:drop-shadow(0 0 13px rgba(111,177,225,.55))}
.hero-art:hover svg>*:nth-child(2){transition-delay:.08s}
.hero-art:hover svg>*:nth-child(3){transition-delay:.16s}
@keyframes hb{0%,100%{transform:scaleY(.85)}50%{transform:scaleY(1)}}
@media(max-width:1024px){.hero-art{display:none}}
.hero-in{pointer-events:none}
.hero-in .kicker,.hero-in .hero-act,.hero-in .hero-act a{pointer-events:auto}
body.cur-q .cur-ring{width:56px;height:56px;margin:-28px 0 0 -28px;background:none;border-color:var(--beige)}
body.cur-q .cur-ring .cap{opacity:1;color:var(--beige);font-size:19px;mix-blend-mode:normal}
body.cur-q .cur-dot{opacity:0}
.q-track{transition:height .5s var(--ease)}
.tl-line span{transition:width .55s var(--ease)}

/* ---- Feinschliff Runde ---- */
.philo-side .badge{color:var(--blue-d)}
.philo-sign .rl{color:var(--mute-d)}
footer .kicker,.foot-cta .kicker{color:var(--blue)}
.venn .vc{transition:stroke-dashoffset 1.5s var(--ease),stroke-width .3s,stroke .3s;pointer-events:all}
.venn .vc.hot{stroke:#E8E4D9;stroke-width:3}
.sek-conn{position:absolute;left:50%;top:50%;height:2px;width:0;transform-origin:0 50%;
  opacity:0;transition:opacity .3s;z-index:1;pointer-events:none}
.sek-conn i{display:block;width:100%;height:100%;background:var(--blue);
  transform:scaleX(0);transform-origin:100% 50%;transition:transform .55s var(--ease)}
.header,.header.scrolled{border-bottom:none}
.logos{border-top:none;border-bottom:none}
#ressourcen{padding-top:clamp(54px,7vh,92px)}
.res-feat{border:none;margin-bottom:16px}
.res-feat .rf-body{background:var(--navy)}
.res-card{border:none;background:var(--navy);transition:transform .5s var(--ease)}
.res-card:hover{transform:translateY(-7px)}
.res-grid{gap:16px}

/* ---- Fixierter CTA + Abschnitts-Navigation ---- */
.fixcta{position:fixed;right:20px;bottom:20px;z-index:6000;background:var(--blue);color:var(--ink);
  font-size:var(--f4);font-weight:600;letter-spacing:.02em;padding:15px 23px;border-radius:40px;
  display:inline-flex;align-items:center;gap:10px;overflow:hidden;
  opacity:0;transform:translateY(18px) scale(.96);pointer-events:none;
  transition:opacity .5s var(--ease),transform .5s var(--ease);
  box-shadow:0 14px 40px rgba(3,9,20,.5)}
.fixcta.on{opacity:1;transform:none;pointer-events:auto}
.fixcta span,.fixcta .fx-ar{position:relative;z-index:2;transition:transform .45s var(--ease)}
.fixcta .fx-ar{font-style:normal}
.fixcta::before{content:"";position:absolute;inset:0;z-index:1;background:var(--beige);
  transform:translateY(101%);transition:transform .5s var(--ease)}
.fixcta:hover::before{transform:translateY(0)}
.fixcta:hover span{transform:translateX(-3px)}
.fixcta:hover .fx-ar{transform:translateX(5px)}
footer{padding-top:18px}
.foot-cta{padding-top:60px;padding-bottom:84px}
.foot-cta .kicker{font-size:var(--f4)}
.foot-cta .cta-block-h{margin-top:20px}
.snav{position:fixed;right:24px;top:50%;transform:translateY(-50%);z-index:5800;
  display:flex;flex-direction:column;align-items:center;gap:13px;opacity:0;transition:opacity .5s var(--ease)}
.snav.on{opacity:1}
.snav button{width:7px;height:7px;border-radius:50%;border:1px solid rgba(232,228,217,.34);
  background:transparent;transition:background .35s,border-color .35s,transform .35s var(--ease);position:relative}
.snav button:hover{border-color:var(--blue)}
.snav button.on{background:var(--blue);border-color:var(--blue);transform:scale(1.45)}
.snav button span{position:absolute;right:18px;top:50%;transform:translateY(-50%) translateX(6px);
  white-space:nowrap;font-size:11px;letter-spacing:.06em;color:var(--beige-2);opacity:0;
  transition:opacity .3s,transform .3s var(--ease);pointer-events:none}
.snav button:hover span{opacity:1;transform:translateY(-50%)}
@media(max-width:960px){.snav{display:none}}
@media(max-width:560px){.fixcta{right:14px;bottom:14px;padding:13px 20px}}

/* ---- Sprachumschalter DE / EN ---- */
.langsw{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:2px;overflow:hidden}
.langsw button{font-family:inherit;font-size:11px;font-weight:600;letter-spacing:.1em;
  padding:8px 11px;color:var(--mute);background:transparent;border:none;cursor:pointer;
  transition:color .3s var(--ease),background .3s var(--ease)}
.langsw button+button{border-left:1px solid var(--line)}
.langsw button:hover{color:var(--beige)}
.langsw button.on{background:var(--blue);color:var(--ink)}
.langsw button.on:hover{color:var(--ink)}
.header-right .langsw{margin-right:2px}
.overlay-aside .langsw{margin-top:26px}
.overlay-aside .langsw button{padding:10px 15px;font-size:12px}
@media(max-width:560px){.header-right .langsw{display:none}}

/* ---- Abschnittsnavigation auf hellem Band ---- */
.snav.on-light button{border-color:var(--blue);border-width:1.5px}
.snav.on-light button:hover{border-color:var(--blue-d)}
.snav.on-light button.on{background:var(--blue);border-color:var(--blue)}
.snav.on-light button span{color:var(--navy)}

/* ---- Animiertes Sefilex-Zeichen (dezent, dekorativ) ---- */
.logomark{display:block;width:clamp(104px,12.5vw,168px)}
.logomark svg{width:100%;height:auto;overflow:visible;display:block}
.logomark svg>*{fill:none;stroke:var(--blue);stroke-width:1.5;stroke-linejoin:round;
  vector-effect:non-scaling-stroke;transform-origin:50% 100%;transform-box:fill-box;
  animation:lmRise 3.8s var(--ease) infinite}
.logomark svg>*:nth-child(2){animation-delay:.16s}
.logomark svg>*:nth-child(3){animation-delay:.32s}
@keyframes lmRise{0%,100%{transform:scaleY(.9);opacity:.5}50%{transform:scaleY(1);opacity:1}}

/* ============================================================
   MOBILE SAMMEL-FIXES
   ============================================================ */
html,body{max-width:100%;overflow-x:hidden}
img,svg{max-width:100%;height:auto}
.wrap{box-sizing:border-box}

@media(max-width:760px){
  /* Header: kompakter, niemals Überlappung */
  .header{padding-top:14px;padding-bottom:14px}
  .logo .lg-glyph{height:24px}
  .logo .lg-word{height:13px}

  /* Hero-Adressen, fixcta, snav, langsw bleiben wie ist */

  /* Hero-Padding */
  .hero{padding:120px 0 80px}
  .phero{padding:130px 0 60px}
  .phero.lg{padding:140px 0 70px}
  .phero .h1{margin-top:18px}

  /* Sektoren-Rad auf Mobile: Kreis-Layout erhalten, kleiner skaliert */
  .sek{grid-template-columns:1fr;gap:32px}
  .sek-stage{max-width:360px;aspect-ratio:1;margin:0 auto;justify-self:center}
  .sek-hub{width:80px;height:80px;margin:-40px 0 0 -40px}
  .sek-hub img{width:34px}
  .sek-node{font-size:.66rem;padding:7px 11px}
  .sek-info{min-height:240px}
  .sek-pname{font-size:clamp(1.6rem,7vw,2.4rem)}

  /* logos-track: mobil größerer Abstand zwischen den Logos, schneller laufend */
  .logos{padding:24px 0 28px;overflow:hidden}
  .logos-track{animation-duration:18s}
  .logos-track img{height:20px;margin-right:48px}
  .logos-track img.krone{height:32px}
  .logos-lab{position:relative;z-index:5;text-align:center;font-size:10px;letter-spacing:.16em;
    padding:0 24px;margin-bottom:20px;background:var(--deep);max-width:100%;line-height:1.4}
  .logos::before,.logos::after{width:42px;top:50px;bottom:0}

  /* Quote-Slider */
  .q-text{font-size:clamp(1.05rem,4vw,1.4rem);max-width:100%}
  .q-track{min-height:280px}

  /* Footer 1 Spalte */
  .foot-cols{grid-template-columns:1fr;gap:34px}
  .foot-cols a{font-size:.95rem}

  /* Lange Links umbrechen */
  a{word-break:break-word}
  .contact{word-break:break-all}

  /* Generische Schrift-Skalierung */
  .h1,.hero-title,.cta-block-h{font-size:clamp(2rem,7.5vw,3rem)}
  .h2{font-size:clamp(1.4rem,5.5vw,2rem)}

  /* Sektor-Subpages: ssec-grid */
  .ssec-grid{grid-template-columns:1fr!important;gap:24px}
  .ssec-head{position:static!important}
  .ssec-num{font-size:clamp(2.6rem,12vw,4rem)}

  /* Branchen-Signaturen: kompakter, kein Side-by-Side */
  .sig{padding:60px 0 50px}
  .sig-bg img{opacity:.16}
  .sig-body{grid-template-columns:1fr!important;gap:22px}
  .sig-aside{border-left:none;padding-left:0;border-top:1px solid rgba(111,177,225,.18);padding-top:22px}
  .sig-art{height:clamp(220px,42vh,280px)}
  .sig-display{font-size:clamp(1.9rem,9vw,3rem)}
  .sb-v{font-size:.86rem;max-width:14ch}

  /* Branchen-Übersicht (Ansatz, ybr) */
  .appr-head{flex-wrap:wrap;gap:12px}
  .appr-body{grid-template-columns:1fr!important;gap:24px}
  .appr-pillars{grid-template-columns:1fr!important;gap:24px;padding-top:24px}
  .scx,.scx:hover{height:auto;min-height:170px}
  .scx-desc{opacity:1;transform:none;font-size:.95rem}
  .ybr{grid-template-columns:1fr;gap:26px;align-items:start}

  /* Leistungen lf master/detail: stack */
  .lf{grid-template-columns:1fr;gap:24px}
  .lf-stage{min-height:0}
  .lf-panel{position:relative;transform:none;opacity:1;pointer-events:auto;display:none}
  .lf-panel.on{display:block}
  .lf-ghost{font-size:5.5rem;top:8px;right:8px}

  /* Leistungen Keynotes Bühne */
  .kf{grid-template-columns:1fr}
  .kf-img{min-height:220px}

  /* Leistungen Themen */
  .themes{grid-template-columns:1fr;gap:14px}
  .thb{padding:24px 22px 28px}

  /* Case Study Stats: stack */
  .cs{grid-template-columns:1fr;gap:30px}
  .cs-meta{position:static}
  .cs-stats{grid-template-columns:1fr}
  .cs-stat{padding-left:0}
  .cs-stat+.cs-stat{border-left:none;border-top:1px solid var(--line);margin-top:6px;padding-top:24px}

  /* Vergangene Vorträge */
  .vf{grid-template-columns:1fr}
  .vf-img{min-height:180px}
  .vt-item{grid-template-columns:1fr;gap:8px}
  .vt-item:hover{padding-left:0}

  /* Team: stack */
  .tmember{grid-template-columns:1fr;gap:24px}
  .thero-row{grid-template-columns:repeat(2,1fr)}
  .disc3{grid-template-columns:1fr;gap:18px}
  .disc3-i{padding:24px 22px 28px}
  .haltung{grid-template-columns:1fr;gap:24px}
  .haltung-side{border-right:none;padding-right:0;border-bottom:1px solid var(--line);padding-bottom:24px;
    flex-direction:row;align-items:center;gap:18px;flex-wrap:wrap}
  .haltung-side .logomark{width:78px}

  /* Ressourcen Cover-Grid */
  .aufs{grid-template-columns:repeat(2,1fr)}
  .pf,.brief{grid-template-columns:1fr}
  .pf-img{min-height:220px}

  /* Kontaktformular */
  .cform{grid-template-columns:1fr!important;gap:28px;padding:30px 0 60px}
  .cpanel{padding:26px 22px}

  /* Cnext Prozessband */
  .cnext{grid-template-columns:1fr;gap:0}
  .cnext-i{padding:22px 0}
  .cnext-i::before{height:2px}

  /* Blog list-feat */
  .blog-feat,.blog-grid{grid-template-columns:1fr}

  /* Container-Padding generisch */
  .wrap{padding-left:18px;padding-right:18px}
  .pad{padding:60px 0}
  .pad-s{padding:48px 0}

  /* Princ-Row: Nummern und Texte bündig zur senkrechten Spine-Linie */
  .princ-row{display:grid;grid-template-columns:42px 1fr;gap:18px;
    padding:22px 0;align-items:start}
  .princ-row:hover{padding-left:0}
  .princ-ar{width:32px;height:32px;flex-shrink:0;grid-row:1/3;align-self:start;margin-top:4px}
  .princ-name{grid-column:2;font-size:1.15rem;font-weight:400;letter-spacing:-.015em;margin-bottom:8px;line-height:1.25}
  .princ-desc{grid-column:2;font-size:var(--f3);color:var(--mute);line-height:1.55}

  /* Philo (Unsere Philosophie): Bild auf voller Breite, kein beiger Rand, Zitat passt */
  .philo-g2{grid-template-columns:1fr;gap:28px}
  .philo-portrait{aspect-ratio:4/5;min-height:0;width:100%;max-width:none;margin:0}
  .philo-portrait img{width:100%;height:100%;object-fit:cover;object-position:50% 28%;display:block}
  .philo-portrait .fl{inset:10px}
  .philo-quote{font-size:clamp(1.05rem,4.4vw,1.4rem);line-height:1.4;max-width:100%;
    word-wrap:break-word;overflow-wrap:anywhere;hyphens:auto;padding:0}
  .philo-side{padding:0;justify-content:flex-start}

  /* Footer CTA */
  .foot-cta{padding-top:50px;padding-bottom:60px}

  /* DL/Arrow nach Link kompakt halten */
  .btn-line .dl{width:22px}
  .btn-line:hover .dl{width:38px}
}

@media(max-width:480px){
  .thero-row{grid-template-columns:1fr;gap:16px}
  .aufs{grid-template-columns:1fr}
  .footnav,.foot-cols{grid-template-columns:1fr}
  .wrap{padding-left:16px;padding-right:16px}
  .h1,.hero-title,.cta-block-h{font-size:clamp(1.8rem,8.5vw,2.6rem)}
  .sig-display{font-size:clamp(1.7rem,9.5vw,2.4rem)}
}

/* ============================================================
   MOBILE SUBSEITEN-ABSICHERUNG (gegen Inline-CSS-Konflikte)
   ============================================================ */
@media(max-width:760px){

  /* Generisch: nichts überfließt, alle Hover-Padding-Shifts stillgelegt */
  *{max-width:100%}
  .pt:hover,.tile:hover,.ofmt:hover,.appr-pi:hover,.disc3-i:hover,
  .vt-item:hover,.lfi:hover,.csp:hover,.scx:hover,.thb:hover,
  .princ-row:hover{padding-left:0!important;transform:none!important}

  /* Schriftgrößen ungefähr lesbar halten überall */
  .h2,.cs-quote,.philo-quote,.haltung-q{font-size:clamp(1.25rem,5vw,1.75rem)!important;line-height:1.32!important}
  .sig-display{font-size:clamp(1.8rem,8vw,2.6rem)!important;line-height:1.06!important}
  .scx-name,.sek-pname,.csp-h{font-size:clamp(1.4rem,6vw,2rem)!important}

  /* Wrap auf 18px Padding setzen (Inline-Padding-Regeln aushebeln) */
  .wrap{padding-left:18px!important;padding-right:18px!important;box-sizing:border-box}

  /* Section-Padding generell auf 60px stutzen */
  .pad,.band-deep.pad,.band-ink.pad,.band-navy.pad,.band-light.pad{padding-top:60px!important;padding-bottom:60px!important}
  .pad-s{padding-top:48px!important;padding-bottom:48px!important}

  /* Phero kompakt */
  .phero,.phero.lg{padding-top:120px!important;padding-bottom:60px!important}
  .phero .h1{font-size:clamp(1.9rem,8vw,2.8rem);max-width:100%}
  .phero .lead{font-size:var(--f3);max-width:100%}

  /* Leistungen: lf-Stage, Themen, Keynotes auf Mobile sauber */
  .lf{grid-template-columns:1fr!important;gap:24px!important}
  .lf-stage{min-height:0!important}
  .lf-panel{position:relative!important;transform:none!important;opacity:1!important;pointer-events:auto;padding:18px 0}
  .lf-panel:not(.on){display:none}
  .lf-ghost{font-size:5rem!important;top:4px!important;right:4px!important}
  .lfi{padding:14px 4px}
  .kf{grid-template-columns:1fr!important}
  .kf-img{min-height:200px!important}
  .kf-bd{padding:24px 22px!important}
  .themes{grid-template-columns:1fr!important;gap:14px!important}
  .thb{padding:24px 22px 28px!important}
  .cs{grid-template-columns:1fr!important;gap:28px!important}
  .cs-meta{position:static!important}
  .cs-stats{grid-template-columns:1fr!important}
  .cs-stat{padding-left:0!important}
  .cs-stat+.cs-stat{border-left:none!important;border-top:1px solid var(--line);margin-top:6px;padding-top:24px}
  .cs-statn{font-size:clamp(2.4rem,11vw,3.6rem)!important}
  .cs-quote{margin-top:32px!important;padding-left:18px!important;max-width:100%}
  .cs-phases::before{display:none!important}
  .csp{grid-template-columns:1fr!important;gap:6px!important}
  .csp-no{width:auto!important;text-align:left!important;background:none!important;padding:0!important}
  .vf{grid-template-columns:1fr!important}
  .vf-img{min-height:180px!important}
  .vf-bd{padding:24px 22px!important}
  .vt-item{grid-template-columns:1fr!important;gap:8px!important;padding:22px 0}
  .vtl{margin-top:30px}

  /* Team: alles 1-spaltig, Skill-Pillen wickeln, Haltung neutral */
  .tmember{grid-template-columns:1fr!important;gap:22px!important;padding:30px 0!important}
  .tm-portrait{aspect-ratio:4/5;max-width:340px;margin:0 auto;width:100%}
  .tm-tags{margin-top:14px}
  .tm-bio{max-width:100%}
  .disc3{grid-template-columns:1fr!important;gap:14px!important}
  .disc3-i{padding:24px 22px 28px!important}
  .haltung{grid-template-columns:1fr!important;gap:22px!important}
  .haltung-side{flex-direction:row;align-items:center;gap:18px;border:none!important;padding:0!important;border-bottom:1px solid var(--line)!important;padding-bottom:20px!important;flex-wrap:wrap}
  .haltung-side .logomark{width:64px!important}
  .haltung-q{font-size:clamp(1.3rem,6vw,1.85rem)!important;line-height:1.32!important;max-width:100%}

  /* Branchen-Übersicht: Ansatz und Sektoren */
  .appr-head{flex-wrap:wrap;gap:12px!important}
  .appr-body{grid-template-columns:1fr!important;gap:24px!important}
  .appr-pillars{grid-template-columns:1fr!important;gap:24px!important;padding-top:24px!important}
  .scx,.scx:hover{height:auto!important;min-height:160px!important}
  .scx-bg img{filter:saturate(.85) brightness(.52);transform:none!important}
  .scx-desc{opacity:1!important;transform:none!important;font-size:.95rem;margin-top:12px}
  .scx-ar{display:none!important}
  .scx-in{padding:20px 22px!important}
  .ybr{grid-template-columns:1fr!important;gap:24px!important;align-items:start!important}

  /* Ressourcen Cover-Grid: zwei Spalten unter 760, eine unter 480 (schon weiter unten) */
  .pf,.brief{grid-template-columns:1fr!important;gap:24px!important}
  .pf-img{min-height:220px!important}
  .aufs{grid-template-columns:repeat(2,1fr)!important;gap:14px!important}
  .res-feat,.res-grid{grid-template-columns:1fr!important;gap:18px!important}
  .res-feat .rf-img{min-height:220px!important}
  .res-feat .rf-body{padding:24px 22px!important}
  .res-card .rc-body{padding:20px 22px 24px!important}
  .pod-cover{min-height:160px!important}

  /* Blog: post-list */
  .blog-feat,.blog-grid,.posts{grid-template-columns:1fr!important;gap:20px!important}
  .post{display:block}
  .post-img{min-height:200px}
  .post-bd{padding:22px}
  .post-t{font-size:clamp(1.15rem,5vw,1.5rem)!important;line-height:1.25}
  .post-x{font-size:var(--f3);max-width:100%}

  /* Kontakt-Formular und Briefing-Anmeldung */
  .cform{grid-template-columns:1fr!important;gap:28px!important;padding:30px 0 60px!important}
  .cpanel{padding:24px 22px!important}
  .cpanel .field input,.cpanel .field textarea{font-size:1rem}
  .cnext{grid-template-columns:1fr!important;gap:0!important}
  .cnext-i{padding:22px 0!important}
  .cdirect-row{padding:16px 0}

  /* Artikel (Blog-Beitragsseiten) */
  .article{padding:30px 18px!important}
  .article h1{font-size:clamp(1.7rem,7vw,2.4rem)!important;line-height:1.18}
  .article h2{font-size:clamp(1.3rem,5.5vw,1.75rem)!important;margin-top:36px}
  .article p{font-size:var(--f3);line-height:1.65}
  .article figure,.article img{max-width:100%}
  .article blockquote{padding:14px 18px;font-size:1.05rem}
  .artnext{grid-template-columns:1fr!important}

  /* Sektor-Subseiten: ssec-grid und pts-Liste */
  .ssec-grid{grid-template-columns:1fr!important;gap:24px!important}
  .ssec-head{position:static!important;top:auto!important}
  .ssec-num{font-size:clamp(2.6rem,12vw,4rem)!important}
  .ssec-head .h2{margin-top:12px;font-size:clamp(1.4rem,6vw,2rem)!important}
  .ssec-lead{font-size:var(--f3)}
  .pts::before{display:none!important}
  .pt{grid-template-columns:32px 1fr!important;gap:14px!important;padding:18px 0!important}
  .pt-t{font-size:1.05rem!important;line-height:1.3}
  .pt-d{font-size:.97rem!important;line-height:1.55}
  .pt-node{width:30px;height:30px;font-size:.66rem}

  /* Sektor-Signaturen sind bereits oben behandelt */

  /* Crumb (Brotkrumen) auf Mobile umbrechen erlauben */
  .crumb{flex-wrap:wrap;font-size:.7rem;gap:6px;line-height:1.4}

  /* nextsec (folgende Branchen-Liste): jede Zeile passt */
  .nextsec{grid-template-columns:1fr!important}
  .nextsec a{padding:22px 20px!important}
  .nextsec a:hover{padding-left:20px!important}

  /* imgband (cinematische Bildbänder) niedrigere Höhe */
  .imgband{min-height:200px}
  .imgband .ib-txt p{font-size:1.05rem}

  /* sq (sector quote bands) kleinere Schrift */
  .sq blockquote{font-size:clamp(1.4rem,6vw,2rem)!important;max-width:100%}

  /* Footer: alle Spalten 1fr, sefilex-lockup nicht überdimensional */
  .foot-cta{padding-top:50px!important;padding-bottom:50px!important}
  .foot-cta .cta-block-h{font-size:clamp(1.7rem,7vw,2.3rem)!important;line-height:1.16}
  .foot-cols{grid-template-columns:1fr!important;gap:28px!important}
  .foot-logo img{height:24px}

  /* shead (section heads) auf 1 Spalte */
  .shead{grid-template-columns:1fr!important;gap:18px!important;margin-bottom:30px!important}
}

/* Sehr kleine Bildschirme: Schriftgrößen weiter reduzieren */
@media(max-width:420px){
  .aufs{grid-template-columns:1fr!important}
  .tm-portrait{max-width:280px}
  .cs-stat{padding:8px 0!important}
  .csp-no{font-size:1.5rem!important}
  .h2{font-size:clamp(1.2rem,5.6vw,1.6rem)!important}
  .h1,.hero-title,.cta-block-h{font-size:clamp(1.7rem,8vw,2.4rem)!important}
}

/* === Defensive Mobile-Sammelpass (alle Seiten) === */
@media(max-width:760px){
  /* Branchen-Ansatz: Pillars stack sauber, kein Overflow */
  .appr-pillars{grid-template-columns:1fr!important;gap:26px!important;padding-top:26px!important}
  .appr-pi{max-width:100%}
  .appr-pd{max-width:100%!important}
  .appr-pt{font-size:1.18rem!important}
  .appr-mark{width:48px!important}

  /* Datenschutz / Impressum: TOC kompakt, prose volle Breite, Hero kompakt */
  .legal{display:block!important;grid-template-columns:1fr!important;gap:20px!important}
  .legal-toc{position:static!important;display:flex!important;flex-direction:row!important;flex-wrap:wrap!important;
    gap:8px!important;margin-bottom:24px!important;width:100%!important}
  .legal-toc .tl-lbl{width:100%!important;margin-bottom:6px!important}
  .legal-toc a{border-left:none!important;border:1px solid var(--line)!important;padding:7px 11px!important;
    font-size:.78rem!important;display:inline-block!important}
  .legal .prose{max-width:100%!important;display:block!important}
  .legal .prose h2{font-size:1.12rem!important;margin-top:24px!important;line-height:1.3;color:var(--beige)!important}
  .legal .prose p{font-size:.95rem!important;line-height:1.6;color:var(--beige-2)!important}
  .phero{padding-top:110px!important;padding-bottom:40px!important;min-height:0!important}
  .phero+.pad,.phero+.band-navy.pad,.phero+.band-deep.pad{padding-top:40px!important}

  /* Team-Haltung: SEFILEX-PRINZIP-Zeile niemals zerbrechen, leere Streifen weg */
  .haltung-by{flex-wrap:wrap;font-size:10px!important;letter-spacing:.16em!important;gap:10px!important}
  .haltung-by::before{width:20px!important}
  .haltung-q{font-size:clamp(1.35rem,5.6vw,1.8rem)!important;max-width:100%!important;line-height:1.32}
  .haltung-side{flex-direction:row!important;align-items:center!important;gap:18px!important;
    padding-bottom:18px!important;padding-right:0!important;border-right:none!important;
    border-bottom:1px solid var(--line)!important}
  .haltung-side .logomark{width:64px!important;flex:none!important}
  .haltung{padding-top:0!important;gap:24px!important}
  /* Übergänge zwischen aufeinanderfolgenden Bändern verdichten */
  .band-light.pad+.band-deep.pad,.band-deep.pad+.band-light.pad,
  .band-paper.pad+.band-deep.pad,.band-light.pad+.band-navy.pad,
  .band-paper.pad+.band-navy.pad,.band-light.pad+.band-ink.pad{padding-top:48px!important}
  .band-light.pad,.band-paper.pad{padding-bottom:48px!important}

  /* Sektoren-Wheel: Beschreibungstext darf Nodes nicht überlagern */
  .sek-info{padding:0 10px}
  .sek-pdesc{font-size:.92rem!important;line-height:1.55!important;max-width:100%!important}
  .sek-pname{font-size:1.45rem!important}

  /* Index Princ-Row: zwei-spaltiges Mini-Grid (Index inline-rule),
     hier global abgesichert */
  .princ-row{display:grid!important;grid-template-columns:34px 1fr!important;gap:14px!important;
    align-items:center!important;padding:22px 0!important}
  .princ-name{grid-row:1!important;font-size:1rem!important;line-height:1.3}
  .princ-desc{grid-column:1 / -1!important;font-size:.92rem!important;line-height:1.55!important;margin-top:4px}
  .princ-no{font-size:.72rem!important}
}

/* === Sehr schmale Geräte (Sektor-pts spine sichtbar halten) === */
@media(max-width:560px){
  .pts::before{display:block!important}
}

/* === Tablet (768-1024) Feinabstimmung === */
@media(min-width:761px) and (max-width:1024px){
  .pad{padding:clamp(70px,8vh,110px) 0}
  .h1{font-size:clamp(2rem,5vw,3.4rem)}
  .h2{font-size:clamp(1.4rem,3.4vw,2.2rem)}
  /* Sektoren-Wheel breit stehen lassen aber nicht zu groß */
  .sek-stage{max-width:420px}
  /* Princ-Row noch 3-spaltig aber tighter */
  .princ-row{grid-template-columns:64px 1fr 1.1fr;gap:24px}
  /* Datenschutz TOC kompakt zentrieren */
  .legal{grid-template-columns:200px 1fr;gap:30px}
  /* Disc3 Cards auf 2 Spalten statt 3 */
  .disc3{grid-template-columns:repeat(2,1fr)}
}

/* === disc3 Cards Mobile (Team — Kompetenz-Block) === */
@media(max-width:760px){
  .disc3{grid-template-columns:1fr!important;gap:16px!important}
  .disc3-i{padding:32px 26px 44px!important;height:auto!important;min-height:0!important;overflow:visible!important}
  .disc3-i::after{display:none!important}
  .disc3-d{font-size:.95rem!important;line-height:1.55!important;max-width:100%!important;
    overflow-wrap:anywhere!important;hyphens:auto!important}
  .disc3-nm{font-size:1.25rem!important;line-height:1.3!important;margin:8px 0 12px!important}
  .disc3-no{font-size:2rem!important}
}

/* === Podcast-Liste Mobile (Ressourcen) === */
@media(max-width:760px){
  .pod{display:flex!important;flex-direction:row!important;gap:14px!important;
    padding:18px 0!important;align-items:flex-start!important;width:100%!important;box-sizing:border-box!important}
  .pod-cover{width:72px!important;height:72px!important;flex:0 0 72px!important;aspect-ratio:1!important;
    border-radius:8px!important;overflow:hidden!important;position:relative!important}
  .pod-cover img{width:100%!important;height:100%!important;object-fit:cover!important;display:block!important}
  .pod>div:not(.pod-cover){flex:1 1 auto!important;min-width:0!important;display:block!important}
  .pod-t{font-size:1.02rem!important;line-height:1.3!important;margin:2px 0 0!important;font-weight:500!important}
  .pod-d{font-size:.88rem!important;line-height:1.5!important;margin-top:6px!important;
    max-width:100%!important;color:var(--beige-2)!important}
  .pod-play{width:26px!important;height:26px!important}
  .pod-play svg{width:9px!important;height:9px!important}
  .pod-ar{display:none!important}
  .pod:hover{padding-left:0!important}
}

/* === Global Timeline (tl-row) Mobile — gilt für index.html UND leistungen.html === */
@media(max-width:760px){
  .tl-row{grid-template-columns:1fr!important;gap:0!important}
  .tl-line{left:27px!important;right:auto!important;top:27px!important;bottom:27px!important;
    width:2px!important;height:auto!important}
  .tl-line span{width:100%!important;transition:height .12s linear!important}
  .tl.in .tl-line span{width:100%!important}
  .tl-step{display:grid!important;grid-template-columns:54px 1fr!important;
    gap:20px!important;padding-bottom:30px!important;align-items:start!important;
    grid-template-rows:auto auto!important}
  .tl-node{grid-column:1!important;grid-row:1!important}
  .tl-h{grid-column:2!important;grid-row:1!important;margin:14px 0 0!important;align-self:center!important}
  .tl-more{grid-column:2!important;grid-row:2!important;
    max-height:300px!important;opacity:1!important;margin-top:8px!important;
    overflow:visible!important}
  .tl-more p{max-width:100%!important;font-size:.95rem!important;line-height:1.6}
}
