/* ============================================================
   STYLE · Lang & Langer GbR Chemnitz
   Komponenten-Styles. CI-Farben siehe theme.css.
   ============================================================ */
:root{
  --ff-display:'Space Grotesk',system-ui,sans-serif;
  --ff-body:'Hanken Grotesk',system-ui,sans-serif;
  --ff-mono:'JetBrains Mono','SF Mono',monospace;
  --t-hero:clamp(2.5rem,10vw,8rem);
  --t-h2:clamp(1.375rem,2.8vw,2.375rem);
  --t-h3:clamp(1.0625rem,1.3vw,1.4375rem);
  --t-lead:clamp(1rem,.8vw + .85rem,1.3125rem);
  --t-body:clamp(.9375rem,.3vw + .875rem,1.0625rem);
  --t-small:.875rem;--t-mono:.75rem;--t-kicker:.6875rem;
  --s1:.25rem;--s2:.5rem;--s3:.75rem;--s4:1rem;--s5:1.25rem;
  --s6:1.75rem;--s7:2.5rem;--s8:3.5rem;--s9:5rem;--s10:6rem;
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-pow:cubic-bezier(.83,0,.17,1);
  --wrap:min(92%,1280px);--header-h:64px;--sticky-h:60px;
  --safe-b:env(safe-area-inset-bottom,0px);
}
@media(min-width:900px){:root{--t-hero:clamp(3.5rem,11vw,10.5rem);--s10:7rem;--header-h:72px;}}
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:var(--header-h);}
body{margin:0;font-family:var(--ff-body);font-size:var(--t-body);line-height:1.55;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;overflow-x:hidden;padding-bottom:calc(var(--sticky-h) + var(--safe-b));}
body.cookie-locked{overflow:hidden;}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:300;line-height:.98;letter-spacing:-.025em;margin:0 0 var(--s4);font-variation-settings:"SOFT" 30,"WONK" 0;}
h2{font-size:var(--t-h2);font-weight:250;letter-spacing:-.035em;}
h3{font-size:var(--t-h3);font-weight:400;letter-spacing:-.015em;}
p{margin:0 0 var(--s4);}strong{font-weight:600;}a{color:inherit;}
img{max-width:100%;height:auto;display:block;}
em{font-family:var(--ff-display);font-style:normal;font-weight:500;color:var(--accent);}
::selection{background:var(--accent);color:var(--paper);}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.06;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");}
.wrap{width:var(--wrap);margin:0 auto;}.section{padding:var(--s10) 0;position:relative;}
.section-dark{background:var(--ink);color:var(--paper);}.section-dark h2,.section-dark h3{color:var(--paper);}
.section-mid{background:var(--paper-deep);}
.kicker{display:inline-flex;align-items:center;gap:var(--s3);font-family:var(--ff-mono);font-weight:500;font-size:var(--t-kicker);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mid);margin-bottom:var(--s5);}
.kicker::before{content:'';width:24px;height:1px;background:var(--accent);}
.section-dark .kicker{color:rgba(246,248,245,.55);}
.lead{font-size:var(--t-lead);line-height:1.45;color:var(--ink-soft);font-weight:350;font-family:var(--ff-display);max-width:38ch;font-variation-settings:"SOFT" 50;}
.section-dark .lead{color:rgba(246,248,245,.78);}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s3);padding:var(--s4) var(--s6);font-family:var(--ff-body);font-weight:500;font-size:var(--t-body);line-height:1;text-decoration:none;border:1.5px solid transparent;cursor:pointer;transition:all .4s var(--ease-out);min-height:52px;white-space:nowrap;position:relative;overflow:hidden;}
.btn::before{content:'';position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .5s var(--ease-pow);z-index:0;}
.btn span{position:relative;z-index:1;}
.btn-primary{background:var(--accent);color:var(--paper);}.btn-primary::before{background:var(--accent-deep);}
.btn-primary:hover{color:var(--paper);}.btn-primary:hover::before{transform:translateY(0);}
.btn-secondary{background:transparent;color:var(--ink);border-color:var(--ink);}
.btn-secondary::before{background:var(--ink);}.btn-secondary:hover{color:var(--paper);}
.btn-secondary:hover::before{transform:translateY(0);}
.section-dark .btn-secondary{color:var(--paper);border-color:var(--paper);}
.section-dark .btn-secondary::before{background:var(--paper);}
.section-dark .btn-secondary:hover{color:var(--ink);}
/* COOKIE WALL */
.cookie-wall{position:fixed;inset:0;z-index:10000;display:flex;align-items:flex-end;justify-content:center;padding:var(--s6) var(--s4);}
.cookie-wall__blur{position:absolute;inset:0;backdrop-filter:blur(14px) brightness(.65);-webkit-backdrop-filter:blur(14px) brightness(.65);background:rgba(15,30,17,.5);}
.cookie-wall__box{position:relative;z-index:1;background:var(--paper);border:1px solid var(--paper-rule);max-width:540px;width:100%;padding:var(--s7);box-shadow:0 32px 80px rgba(0,0,0,.4);}
@media(max-width:600px){.cookie-wall__box{padding:var(--s6) var(--s5);}}
.cw-label{font-family:var(--ff-mono);font-size:var(--t-mono);font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--s4);}
.cw-title{font-family:var(--ff-display);font-size:clamp(1.5rem,3vw,2rem);font-weight:300;letter-spacing:-.03em;line-height:1.1;margin:0 0 var(--s4);font-variation-settings:"SOFT" 30;}
.cw-text{font-size:var(--t-small);color:var(--ink-mid);line-height:1.6;margin:0 0 var(--s5);}
.cw-items{list-style:none;padding:0;margin:0 0 var(--s6);display:grid;gap:var(--s2);}
.cw-item{display:flex;align-items:flex-start;gap:var(--s3);font-size:var(--t-small);color:var(--ink-soft);}
.cw-dot{width:18px;height:18px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;}
.cw-dot svg{width:10px;height:10px;stroke:var(--paper);}
.cw-btns{display:flex;flex-wrap:wrap;gap:var(--s3);align-items:center;}
.cw-link{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.06em;color:var(--ink-mid);text-decoration:underline;margin-left:auto;}
.cookie-wall.hidden{display:none;}
/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);display:flex;align-items:center;background:rgba(255,255,255,.85);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);color:var(--ink);border-bottom:1px solid transparent;transition:background .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);}
.site-header.is-light{background:rgba(255,255,255,.96);border-bottom:1px solid var(--paper-rule);box-shadow:0 2px 20px rgba(46,46,48,.05);}
.hdr-inner{width:var(--wrap);max-width:1440px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--s4);}
.brand{display:flex;align-items:center;gap:var(--s4);text-decoration:none;color:inherit;}
.brand-mark{height:38px;flex-shrink:0;display:flex;align-items:center;}
.brand-mark img{height:38px;width:auto;object-fit:contain;}
.brand-name{display:flex;flex-direction:column;gap:2px;line-height:1;}
.brand-main{font-family:var(--ff-mono);font-weight:600;font-size:clamp(.75rem,2.2vw,.9375rem);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;}
.brand-sub{font-family:var(--ff-mono);font-style:normal;font-size:clamp(.625rem,1.6vw,.75rem);font-weight:400;letter-spacing:.04em;color:var(--ink-mid);white-space:nowrap;}
.hdr-nav{display:none;}
@media(min-width:1024px){
  .hdr-nav{display:flex;align-items:center;gap:var(--s6);margin-left:auto;}
  .hdr-nav a{font-family:var(--ff-mono);font-size:.8125rem;font-weight:500;letter-spacing:.04em;color:var(--ink-mid);text-decoration:none;position:relative;padding:.25rem 0;transition:color .3s;white-space:nowrap;}
  .hdr-nav a::after{content:'';position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--accent);transition:width .3s var(--ease-out);}
  .hdr-nav a:hover{color:var(--ink);}
  .hdr-nav a:hover::after{width:100%;}
  .hdr-nav__cta{color:var(--accent) !important;border:1.5px solid var(--accent);border-radius:2px;padding:.5rem 1rem !important;transition:background .3s,color .3s !important;}
  .hdr-nav__cta::after{display:none;}
  .hdr-nav__cta:hover{background:var(--accent);color:var(--paper) !important;}
  .nav-toggle{display:none !important;}
}
.nav-toggle{width:48px;height:36px;display:flex;flex-direction:column;justify-content:center;align-items:flex-end;gap:5px;background:transparent;border:none;cursor:pointer;padding:0;}
.nav-toggle span{display:block;height:1.5px;background:var(--ink);transition:all .4s var(--ease-pow);}
.nav-toggle span:nth-child(1){width:28px;}.nav-toggle span:nth-child(2){width:20px;}
.nav-toggle[aria-expanded="true"] span{background:var(--paper);}
.nav-toggle[aria-expanded="true"] span:nth-child(1){width:28px;transform:translateY(6.5px) rotate(45deg);}
.nav-toggle[aria-expanded="true"] span:nth-child(2){width:28px;transform:translateY(-6.5px) rotate(-45deg);}
.nav-overlay{position:fixed;inset:0;background:var(--ink);color:var(--paper);z-index:99;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .5s var(--ease-pow);overflow-y:auto;padding:calc(var(--header-h) + 1.5rem) 1.5rem 2rem;}
.nav-overlay.open{opacity:1;pointer-events:auto;}
.nav-list{list-style:none;padding:0;margin:0;}
.nav-list li{overflow:hidden;margin-bottom:var(--s2);}
.nav-list a{display:block;font-family:var(--ff-display);font-size:clamp(1.5rem,4.5vw,2.75rem);font-weight:250;line-height:1.1;letter-spacing:-.03em;color:var(--paper);text-decoration:none;transform:translateY(120%);transition:transform .6s var(--ease-pow),color .3s;font-variation-settings:"SOFT" 30;}
.nav-overlay.open .nav-list li:nth-child(1) a{transition-delay:.10s;}
.nav-overlay.open .nav-list li:nth-child(2) a{transition-delay:.18s;}
.nav-overlay.open .nav-list li:nth-child(3) a{transition-delay:.26s;}
.nav-overlay.open .nav-list li:nth-child(4) a{transition-delay:.34s;}
.nav-overlay.open .nav-list li:nth-child(5) a{transition-delay:.42s;}
.nav-overlay.open .nav-list li:nth-child(6) a{transition-delay:.50s;}
.nav-overlay.open .nav-list li:nth-child(7) a{transition-delay:.58s;}
.nav-overlay.open .nav-list a{transform:translateY(0);}
.nav-list a:hover{color:var(--accent);}
/* HERO — hell, zweispaltig mit Bild-Slider */
.hero{background:var(--paper);color:var(--ink);position:relative;padding:calc(var(--header-h) + var(--s8)) 0 var(--s9);overflow:hidden;}
.hero::after{content:'';position:absolute;top:0;right:0;width:42%;height:100%;background:linear-gradient(180deg,var(--accent-light) 0%,rgba(253,241,230,0) 100%);z-index:0;pointer-events:none;}
@media(max-width:899px){.hero::after{display:none;}}
.hero__grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr;gap:var(--s8);align-items:center;}
@media(min-width:900px){.hero__grid{grid-template-columns:1.05fr 1fr;gap:var(--s9);}}
.hero__text{opacity:0;animation:hfade .8s var(--ease-out) .1s forwards;}
.hero__badge{display:inline-flex;align-items:center;gap:var(--s3);font-family:var(--ff-mono);font-size:var(--t-mono);font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--s5);background:var(--accent-light);padding:var(--s2) var(--s4);border-radius:100px;}
.hero__badge-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);}
.hero__badge-sep{width:1px;height:12px;background:rgba(31,116,216,.3);}
.hero__title{font-family:var(--ff-display);font-size:clamp(2.25rem,5.5vw,4.5rem);font-weight:300;line-height:1.0;letter-spacing:-.035em;margin:0 0 var(--s5);font-variation-settings:"SOFT" 30,"WONK" 0,"opsz" 144;color:var(--gray-brand);}
.hero__title em{color:var(--accent);font-style:normal;font-weight:500;}
.hero__lead{font-size:var(--t-lead);line-height:1.5;color:var(--ink-mid);max-width:46ch;margin:0 0 var(--s6);}
.hero__ctas{display:flex;flex-wrap:wrap;gap:var(--s3);align-items:center;margin-bottom:var(--s6);}
.hero__trust{display:flex;flex-wrap:wrap;gap:var(--s5);padding-top:var(--s5);border-top:1px solid var(--paper-rule);}
.hero__trust-item{display:flex;flex-direction:column;gap:2px;}
.hero__trust-num{font-family:var(--ff-display);font-size:1.5rem;font-weight:400;color:var(--accent);line-height:1;font-variation-settings:"SOFT" 30;}
.hero__trust-label{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);}
/* SLIDER */
.hero__slider{position:relative;opacity:0;animation:hfade .8s var(--ease-out) .35s forwards;}
.slider{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 30px 70px rgba(46,46,48,.18);aspect-ratio:4/3.1;background:var(--paper-deep);}
.slider__track{display:flex;height:100%;transition:transform .7s var(--ease-pow);}
.slider__slide{min-width:100%;height:100%;position:relative;}
.slider__slide img{width:100%;height:100%;object-fit:cover;display:block;}
.slider__cap{position:absolute;left:0;right:0;bottom:0;padding:var(--s7) var(--s5) var(--s5);background:linear-gradient(to top,rgba(46,46,48,.85) 0%,rgba(46,46,48,0) 100%);color:#fff;}
.slider__cap-kick{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.14em;text-transform:uppercase;color:#A8CEF7;margin-bottom:var(--s2);}
.slider__cap-title{font-family:var(--ff-display);font-size:clamp(1.125rem,2.2vw,1.5rem);font-weight:300;letter-spacing:-.02em;font-variation-settings:"SOFT" 40;}
.slider__btn{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:44px;height:44px;border-radius:50%;border:none;background:rgba(255,255,255,.9);color:var(--gray-brand);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s,transform .3s;box-shadow:0 4px 16px rgba(0,0,0,.15);}
.slider__btn:hover{background:var(--accent);color:#fff;}
.slider__btn svg{width:18px;height:18px;stroke:currentColor;stroke-width:2.5;fill:none;}
.slider__btn--prev{left:14px;}.slider__btn--next{right:14px;}
.slider__dots{position:absolute;bottom:var(--s4);left:50%;transform:translateX(-50%);z-index:6;display:flex;gap:8px;}
.slider__dot{width:8px;height:8px;border-radius:50%;border:none;background:rgba(255,255,255,.5);cursor:pointer;padding:0;transition:background .3s,width .3s;}
.slider__dot.active{background:var(--accent);width:24px;border-radius:4px;}
.hero__slider-badge{position:absolute;top:-16px;left:-16px;z-index:8;background:var(--accent);color:#fff;padding:var(--s3) var(--s5);border-radius:12px;box-shadow:0 12px 28px rgba(31,116,216,.4);transform:rotate(-3deg);}
.hero__slider-badge strong{display:block;font-family:var(--ff-display);font-size:1.25rem;font-weight:400;line-height:1;font-variation-settings:"SOFT" 30;}
.hero__slider-badge span{font-family:var(--ff-mono);font-size:.625rem;letter-spacing:.1em;text-transform:uppercase;opacity:.85;}
@media(max-width:560px){.hero__slider-badge{top:-12px;left:-8px;padding:var(--s2) var(--s4);}.slider__btn{width:38px;height:38px;}}
@keyframes hfade{to{opacity:1;}}
/* MARQUEE */
.marquee{background:var(--accent);color:var(--paper);overflow:hidden;padding:var(--s4) 0;}
.marq-track{display:flex;gap:0;width:max-content;animation:marq 25s linear infinite;}
.marquee:hover .marq-track{animation-play-state:paused;}
.marquee.fast .marq-track{animation-duration:8s;}
.marq-item{display:flex;align-items:center;gap:var(--s4);padding:0 var(--s8);font-family:var(--ff-mono);font-size:var(--t-mono);font-weight:500;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;}
.marq-sep{width:4px;height:4px;border-radius:50%;background:rgba(246,248,245,.4);}
@keyframes marq{from{transform:translateX(0);}to{transform:translateX(-50%);}}
/* ÜBER UNS */
.ueber__grid{display:grid;grid-template-columns:1fr;gap:var(--s8);align-items:center;}
@media(min-width:900px){.ueber__grid{grid-template-columns:1fr 1fr;}}
.ueber__visual{aspect-ratio:4/3;background:var(--ink);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.ueber__vis-bg{position:absolute;inset:0;background:linear-gradient(135deg,#0B1F36 0%,#123A63 50%,#0F58AE 100%);}
.ueber__vis-grid{position:absolute;inset:0;opacity:.1;background-image:repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(246,248,245,.4) 40px),repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(246,248,245,.4) 40px);}
.ueber__vis-badge{position:relative;z-index:2;text-align:center;color:var(--paper);padding:var(--s6);}
.uvb-label{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.16em;text-transform:uppercase;color:rgba(246,248,245,.45);margin-bottom:var(--s4);}
.uvb-num{font-family:var(--ff-display);font-size:clamp(3rem,8vw,6rem);font-weight:200;line-height:.9;letter-spacing:-.05em;font-variation-settings:"SOFT" 20;}
.uvb-num em{color:var(--accent);font-style:normal;}
.uvb-sub{font-family:var(--ff-display);font-style:normal;font-size:1rem;color:rgba(246,248,245,.6);margin-top:var(--s3);}
.uvb-azav{display:inline-flex;align-items:center;gap:var(--s3);margin-top:var(--s4);background:rgba(31,116,216,.15);border:1px solid rgba(31,116,216,.35);padding:var(--s2) var(--s4);}
.uvb-azav-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);}
.uvb-azav-text{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.1em;text-transform:uppercase;color:rgba(246,248,245,.65);}
/* LEISTUNGEN */
.lst-grid{display:grid;grid-template-columns:1fr;gap:var(--s4);}
@media(min-width:600px){.lst-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:900px){.lst-grid{grid-template-columns:repeat(3,1fr);}}
.lst-card{background:var(--paper);border:1px solid var(--paper-rule);padding:var(--s6);position:relative;overflow:hidden;transition:border-color .3s,transform .3s var(--ease-out);}
.lst-card:hover{border-color:var(--accent);transform:translateY(-3px);}
.lst-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-out);}
.lst-card:hover::before{transform:scaleX(1);}
.lst-num{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.1em;color:var(--ink-muted);margin-bottom:var(--s5);}
.lst-icon{width:42px;height:42px;background:var(--paper-deep);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:var(--s5);}
.lst-icon svg{width:18px;height:18px;stroke:var(--accent);stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.lst-card h3{color:var(--ink);margin-bottom:var(--s3);}
.lst-card p{font-size:var(--t-small);color:var(--ink-mid);margin:0;}
/* WARUM */
.usp-grid{display:grid;grid-template-columns:1fr;gap:var(--s4);}
@media(min-width:600px){.usp-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:900px){.usp-grid{grid-template-columns:repeat(3,1fr);}}
.usp{border:1px solid rgba(246,248,245,.12);padding:var(--s6);transition:border-color .3s,background .3s;}
.usp:hover{border-color:var(--accent);background:rgba(31,116,216,.08);}
.usp__ico{font-size:1.75rem;margin-bottom:var(--s4);}
.usp h3{color:var(--paper);font-size:var(--t-h3);margin-bottom:var(--s3);}
.usp p{font-size:var(--t-small);color:rgba(246,248,245,.6);margin:0;}
/* TEAM */
.team-photo{position:relative;border-radius:16px;overflow:hidden;margin-bottom:var(--s8);box-shadow:0 20px 50px rgba(46,46,48,.12);}
.team-photo img{width:100%;height:auto;display:block;aspect-ratio:16/7;object-fit:cover;object-position:center 30%;}
.team-photo__cap{position:absolute;left:0;bottom:0;padding:var(--s7) var(--s6) var(--s5);background:linear-gradient(to top,rgba(46,46,48,.8),rgba(46,46,48,0));color:#fff;width:100%;}
.team-photo__cap span{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.14em;text-transform:uppercase;color:#A8CEF7;}
.team-photo__cap strong{display:block;font-family:var(--ff-display);font-weight:300;font-size:clamp(1.25rem,2.5vw,1.75rem);letter-spacing:-.02em;margin-top:var(--s2);font-variation-settings:"SOFT" 40;}
.team-grid{display:grid;grid-template-columns:1fr;gap:var(--s6);}
@media(min-width:600px){.team-grid{grid-template-columns:repeat(3,1fr);}}
.team-card{border:1px solid var(--paper-rule);padding:var(--s6);text-align:center;border-radius:12px;transition:border-color .3s,transform .3s var(--ease-out);}
.team-card:hover{border-color:var(--accent);transform:translateY(-3px);}
.team-avatar{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-deep) 100%);display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-size:2rem;font-weight:300;color:var(--paper);margin:0 auto var(--s5);font-variation-settings:"SOFT" 30;overflow:hidden;}
.team-avatar img{width:100%;height:100%;object-fit:cover;object-position:center top;}
.team-card h3{font-size:var(--t-h3);margin-bottom:var(--s2);}
.team-role{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mid);margin-bottom:var(--s4);}
.team-card p{font-size:var(--t-small);color:var(--ink-mid);margin-bottom:var(--s4);}
.team-card a{display:inline-flex;align-items:center;gap:var(--s2);font-size:var(--t-small);color:var(--accent);text-decoration:none;}
.team-card a:hover{text-decoration:underline;}
.team-card a svg{width:13px;height:13px;stroke:var(--accent);stroke-width:2;fill:none;stroke-linecap:round;}
/* AKTUELLES */
.akt-grid{display:grid;grid-template-columns:1fr;gap:var(--s8);align-items:center;}
@media(min-width:900px){.akt-grid{grid-template-columns:1fr 1fr;}}
.akt-badge{display:inline-flex;align-items:center;gap:var(--s2);background:var(--accent);color:var(--paper);padding:var(--s1) var(--s4);font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--s5);}
.akt-list{list-style:none;padding:0;margin:var(--s5) 0 0;display:grid;gap:var(--s3);}
.akt-list li{display:flex;align-items:flex-start;gap:var(--s3);font-size:var(--t-small);color:var(--ink-soft);padding-bottom:var(--s3);border-bottom:1px solid var(--paper-rule);}
.akt-list li::before{content:'✓';color:var(--accent);font-weight:700;flex-shrink:0;margin-top:1px;}
/* FAQ */
.faq-head{margin-bottom:var(--s8);display:grid;grid-template-columns:1fr;gap:var(--s6);}
@media(min-width:900px){.faq-head{grid-template-columns:1fr 1fr;align-items:end;}}
.faq-item{border-bottom:1px solid var(--paper-rule);}
.faq-item:first-child{border-top:1px solid var(--paper-rule);}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:var(--s4);padding:var(--s5) 0;font-weight:500;color:var(--ink);font-size:var(--t-body);transition:color .3s;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary:hover,.faq-item[open] summary{color:var(--accent);}
.faq-arrow{width:24px;height:24px;flex-shrink:0;border:1px solid var(--paper-rule);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .4s var(--ease-out),background .3s,border-color .3s;}
.faq-item[open] .faq-arrow{background:var(--accent);border-color:var(--accent);transform:rotate(45deg);}
.faq-arrow svg{width:10px;height:10px;stroke:var(--ink-mid);stroke-width:2;}
.faq-item[open] .faq-arrow svg{stroke:var(--paper);}
.faq-body{padding:0 0 var(--s5);color:var(--ink-soft);font-size:var(--t-small);line-height:1.65;max-width:66ch;}
/* KONTAKT */
.kont-inner{display:grid;grid-template-columns:1fr;gap:var(--s8);}
@media(min-width:900px){.kont-inner{grid-template-columns:1fr 1.4fr;}}
.kont-items{display:grid;gap:var(--s5);}
.kont-item{padding-bottom:var(--s5);border-bottom:1px solid rgba(246,248,245,.1);}
.kont-label{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.12em;text-transform:uppercase;color:rgba(246,248,245,.4);margin-bottom:var(--s2);}
.kont-value{font-size:var(--t-lead);font-weight:500;}
.kont-value a{text-decoration:none;color:var(--paper);transition:color .3s;}
.kont-value a:hover{color:var(--accent);}
/* FORM */
.form-block{display:grid;gap:var(--s4);}
.form-row{display:grid;grid-template-columns:1fr;gap:var(--s4);}
@media(min-width:540px){.form-row{grid-template-columns:1fr 1fr;}}
.field{display:grid;gap:var(--s2);}
.field label{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.1em;text-transform:uppercase;color:rgba(246,248,245,.5);}
.field input,.field textarea,.field select{background:rgba(246,248,245,.05);border:1px solid rgba(246,248,245,.15);color:var(--paper);font-family:var(--ff-body);font-size:var(--t-body);padding:var(--s3) var(--s4);outline:none;width:100%;transition:border-color .3s;-webkit-appearance:none;appearance:none;}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent);}
.field textarea{resize:vertical;min-height:100px;}
.field select option{background:var(--ink-soft);color:var(--paper);}
.field small{font-size:.75rem;color:rgba(246,248,245,.35);}
.field-req{color:var(--accent);}
.field-honey{position:absolute;left:-9999px;opacity:0;pointer-events:none;height:0;overflow:hidden;}
.field-check{flex-direction:row;align-items:flex-start;}
.field-check input[type=checkbox]{-webkit-appearance:auto;appearance:auto;width:18px;height:18px;flex-shrink:0;accent-color:var(--accent);cursor:pointer;margin-top:2px;padding:0;background:transparent;border:none;}
.field-check label{font-family:var(--ff-body);font-size:var(--t-small);color:rgba(246,248,245,.6);text-transform:none;letter-spacing:0;line-height:1.5;}
.field-check label a{color:var(--accent);}
.form-status{display:none;margin-bottom:var(--s4);padding:var(--s4) var(--s5);border:1px solid currentColor;font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.06em;}
/* ANFAHRT */
.anf-grid{display:grid;grid-template-columns:1fr;gap:var(--s8);align-items:start;}
@media(min-width:900px){.anf-grid{grid-template-columns:1fr 1fr;}}
.anf-map{aspect-ratio:4/3;background:var(--ink);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.anf-map-bg{position:absolute;inset:0;background:linear-gradient(160deg,#0B1F36 0%,#123A63 50%,#0F58AE 100%);}
.anf-map-grid{position:absolute;inset:0;opacity:.1;background-image:repeating-linear-gradient(0deg,transparent,transparent 29px,rgba(246,248,245,.5) 30px),repeating-linear-gradient(90deg,transparent,transparent 29px,rgba(246,248,245,.5) 30px);}
.anf-map-content{position:relative;z-index:2;text-align:center;color:var(--paper);padding:var(--s6);}
.anf-pin{width:48px;height:48px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--s4);}
.anf-pin svg{width:22px;height:22px;fill:var(--paper);}
.anf-addr{font-family:var(--ff-display);font-size:1.25rem;font-weight:300;letter-spacing:-.02em;margin-bottom:var(--s2);font-variation-settings:"SOFT" 30;}
.anf-note{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.1em;text-transform:uppercase;color:rgba(246,248,245,.45);}
.anf-map-load{display:inline-block;margin-top:var(--s4);background:var(--accent);color:var(--paper);border:none;cursor:pointer;font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.08em;text-transform:uppercase;padding:.7rem 1.4rem;transition:background .2s;}
.anf-map-load:hover{background:var(--accent-deep,#0E4829);}
.anf-map-consent{font-size:.75rem;line-height:1.5;color:rgba(246,248,245,.55);max-width:38ch;margin:var(--s3) auto 0;}
.anf-map-consent a{color:rgba(246,248,245,.85);text-decoration:underline;}
.anf-map-frame{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;z-index:3;}
.anf-map--loaded .anf-map-bg,.anf-map--loaded .anf-map-grid{display:none;}
.anf-ways{display:grid;gap:var(--s4);}
.anf-way{border:1px solid var(--paper-rule);padding:var(--s5);}
.anf-way-head{display:flex;align-items:center;gap:var(--s3);font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mid);margin-bottom:var(--s3);}
.anf-way-head svg{width:15px;height:15px;stroke:var(--accent);stroke-width:2;fill:none;stroke-linecap:round;}
.anf-way p{font-size:var(--t-small);color:var(--ink-soft);margin:0;}
/* FOOTER */
.site-footer{background:var(--ink-soft);color:rgba(246,248,245,.7);padding:var(--s8) 0 var(--s6);}
.ftr-grid{display:grid;grid-template-columns:1fr;gap:var(--s6);margin-bottom:var(--s8);}
@media(min-width:768px){.ftr-grid{grid-template-columns:1.5fr 1fr 1fr;}}
.ftr-brand{display:flex;align-items:flex-start;gap:var(--s4);margin-bottom:var(--s5);}
.ftr-mark{height:40px;flex-shrink:0;display:flex;align-items:center;}
.ftr-mark img{height:40px;width:auto;object-fit:contain;filter:brightness(0) invert(1);}
.ftr-bname{font-family:var(--ff-mono);font-weight:600;font-size:.875rem;letter-spacing:.08em;text-transform:uppercase;color:var(--paper);}
.ftr-bsub{font-family:var(--ff-mono);font-style:normal;font-size:.75rem;letter-spacing:.04em;color:rgba(246,248,245,.45);}
.ftr-col h4{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.12em;text-transform:uppercase;color:rgba(246,248,245,.4);margin:0 0 var(--s4);font-weight:500;}
.ftr-col ul{list-style:none;padding:0;margin:0;display:grid;gap:var(--s2);}
.ftr-col ul li a{font-size:var(--t-small);color:rgba(246,248,245,.6);text-decoration:none;transition:color .3s;}
.ftr-col ul li a:hover{color:var(--accent);}
.ftr-bottom{border-top:1px solid rgba(246,248,245,.1);padding-top:var(--s5);display:flex;flex-wrap:wrap;gap:var(--s4);align-items:center;justify-content:space-between;}
.ftr-meta{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.06em;color:rgba(246,248,245,.35);margin:0;}
.ftr-links{display:flex;gap:var(--s5);flex-wrap:wrap;}
.ftr-links a{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.08em;text-transform:uppercase;color:rgba(246,248,245,.45);text-decoration:none;transition:color .3s;}
.ftr-links a:hover{color:var(--accent);}
.ftr-dsgvo{margin-top:var(--s5);font-size:.75rem;color:rgba(246,248,245,.28);line-height:1.6;border-top:1px solid rgba(246,248,245,.07);padding-top:var(--s4);}
.ftr-credits{text-align:center;padding:var(--s4) 0 var(--s2);font-size:.75rem;font-family:var(--ff-mono);letter-spacing:.06em;}
.ftr-credits a{color:rgba(246,248,245,.5);text-decoration:none;border-bottom:1px dotted rgba(246,248,245,.25);padding-bottom:1px;transition:color .3s,border-color .3s;}
.ftr-credits a:hover{color:rgba(246,248,245,.85);border-bottom-color:var(--accent);}
.ftr-admin{display:flex;align-items:center;justify-content:center;margin-top:var(--s3);padding-top:var(--s4);border-top:1px solid rgba(246,248,245,.06);}
.ftr-admin a{display:inline-flex;align-items:center;gap:.375rem;color:rgba(246,248,245,.14);text-decoration:none;font-size:.625rem;font-family:var(--ff-mono);letter-spacing:.08em;text-transform:uppercase;transition:color .4s;}
.ftr-admin a:hover{color:rgba(246,248,245,.45);}
.ftr-admin svg{width:12px;height:12px;stroke:currentColor;stroke-width:1.5;fill:none;}
/* SITE-BILD SCROLL-REVEAL — echte Transparenz, bündig rechter Rand, nach Hero */
.ueber__site-bild{
  position:fixed;right:0;bottom:0;
  height:min(78vh,680px);
  z-index:40;pointer-events:none;
  opacity:0;
  transform:translateX(40px);
  transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);
}
.ueber__site-bild.sb-visible{
  opacity:1;
  transform:translateX(0);
}
.ueber__site-bild picture{display:block;height:100%;}
.ueber__site-bild img{
  height:100%;width:auto;display:block;
}
@media(max-width:1023px){.ueber__site-bild{display:none !important;}}
/* STICKY BAR */
.sticky-bar{position:fixed;bottom:0;left:0;right:0;z-index:90;height:var(--sticky-h);background:var(--ink);display:flex;align-items:stretch;padding-bottom:var(--safe-b);border-top:1px solid rgba(246,248,245,.1);}
.sticky-bar__call,.sticky-bar__cta{display:flex;align-items:center;justify-content:center;gap:var(--s3);text-decoration:none;font-weight:500;font-size:.875rem;color:var(--paper);transition:background .3s;flex:1;}
.sticky-bar__call{border-right:1px solid rgba(246,248,245,.1);}
.sticky-bar__call:hover{background:rgba(246,248,245,.06);}
.sticky-bar__cta{background:var(--accent);}
.sticky-bar__cta:hover{background:var(--accent-deep);}
.sticky-bar svg{width:18px;height:18px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;}
/* REVEAL ANIM */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .85s var(--ease-out),transform .85s var(--ease-out);}
.reveal.in{opacity:1;transform:translateY(0);}
/* VORHER / NACHHER — DRAG-SLIDER */
.beforeafter{display:grid;grid-template-columns:1fr;gap:var(--s6);}
@media(min-width:760px){.beforeafter{grid-template-columns:repeat(3,1fr);}}
.ba-card{display:flex;flex-direction:column;}
.ba-slider{position:relative;aspect-ratio:3/4;border-radius:14px;overflow:hidden;background:var(--paper-deep);box-shadow:0 16px 40px rgba(14,39,66,.14);cursor:ew-resize;touch-action:none;user-select:none;-webkit-user-select:none;}
/* is-composite-h: EIN Bild, horizontal geteilt — links Vorher, rechts Nachher */
.ba-img{position:absolute;inset:0;background-repeat:no-repeat;background-size:200% 100%;pointer-events:none;}
.ba-before{background-position:left center;}
.ba-after{background-position:right center;clip-path:inset(0 0 0 var(--pos,50%));will-change:clip-path;}
.ba-label{position:absolute;top:var(--s4);font-family:var(--ff-mono);font-size:.625rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:rgba(14,39,66,.72);padding:.3rem .6rem;border-radius:100px;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:3;}
.ba-label.is-before{left:var(--s4);}
.ba-label.is-after{right:var(--s4);background:var(--accent);}
.ba-handle{position:absolute;top:0;bottom:0;left:var(--pos,50%);width:2px;background:#fff;transform:translateX(-1px);z-index:4;box-shadow:0 0 0 1px rgba(14,39,66,.15);pointer-events:none;}
.ba-handle::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;background:#fff;box-shadow:0 4px 14px rgba(14,39,66,.35);}
.ba-handle::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;z-index:1;background:no-repeat center/20px url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%231F74D8' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='9 6 3 12 9 18'/><polyline points='15 6 21 12 15 18'/></svg>");}
.ba-range{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;z-index:5;}
.ba-range:focus-visible+.ba-handle::after{outline:3px solid var(--accent);outline-offset:2px;}
.ba-meta{font-family:var(--ff-mono);font-size:var(--t-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin:var(--s4) 0 var(--s2);}
.ba-text{font-size:var(--t-small);color:var(--ink-mid);margin:0;line-height:1.6;}
.beforeafter-note{font-size:.75rem;color:var(--ink-muted);margin-top:var(--s6);max-width:64ch;}
