:root{
  --black:#181818;
  --dark:#111;
  --card:#161616;
  --orange:#FE5000;
  --white:#fff;
  --grey:#888;
  --border:rgba(255,255,255,0.08);
  --font-d:'League Gothic','Arial Narrow',sans-serif;
  --font-b:'Raleway',sans-serif;
}
#logo-3d-wrap{
  position:fixed;top:0;left:0;
  z-index:1001;pointer-events:none;
  will-change:transform,opacity;
  transform-origin:top left;
  opacity:0;
}
#logo-3d-wrap canvas{display:block;width:160px;height:160px}
.hero{
  position:relative;height:100vh;min-height:700px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background:url('https://runningsociety.de/wp-content/uploads/2026/06/hero-rs-athletes-abendlauf.jpg') center 44% / cover no-repeat;
  animation:heroEntry 14s ease-out forwards;
  transform-origin:center center;will-change:transform;
}
.hero-fade{
  position:absolute;inset:0;z-index:3;
  background:#000;
  animation:heroFadeOut 1.8s 0.05s cubic-bezier(0.4,0,0.2,1) forwards;
  pointer-events:none;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(24,24,24,0.2) 0%,rgba(24,24,24,0.5) 55%,rgba(24,24,24,0.92) 100%);
}
#particle-canvas{position:absolute;inset:0;z-index:2;pointer-events:none}
.hero-content{
  position:relative;z-index:3;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:24px;
  padding-top:60px;
}
.hero-headline{
  font-family:var(--font-d);
  font-size:clamp(72px,12vw,140px);
  line-height:0.9;letter-spacing:0.02em;text-transform:uppercase;
}
.hero-headline .word{display:block;overflow:hidden;padding:4px 0}
.hero-headline .word span{
  display:block;opacity:0;transform:translateY(100%);
  animation:wordReveal 0.7s cubic-bezier(0.22,1,0.36,1) forwards;
}
.hero-headline .word:nth-child(1) span{animation-delay:1.0s}
.hero-headline .word:nth-child(2) span{animation-delay:1.2s;color:var(--orange)}
.hero-sub{
  font-size:13px;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;
  color:rgba(255,255,255,0.55);
  opacity:0;animation:fadeIn 0.8s 1.8s forwards;
}
.hero-cta{
  display:flex;align-items:center;gap:24px;
  opacity:0;animation:fadeIn 0.8s 2.1s forwards;
}
.hero-scroll{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  opacity:0;animation:fadeIn 1s 2.5s forwards;z-index:3;
}
.hero-scroll span{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.35)}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--orange),transparent);animation:scrollPulse 2s 2.5s infinite}
.stats-strip{
  background:var(--orange);padding:20px 48px;
  display:flex;align-items:center;justify-content:center;gap:0;
}
.stats-left{display:flex;align-items:center;gap:40px;flex-wrap:wrap}
.stat{text-align:center}
.stat-num{font-family:var(--font-d);font-size:clamp(18px,2.2vw,26px);line-height:1}
.stat-label{font-size:9px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;opacity:0.5;margin-top:2px}
.stats-divider{width:1px;height:40px;background:rgba(255,255,255,0.35);flex-shrink:0;margin:0 40px}
.stats-partners{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
.stats-partners-label{font-size:9px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;white-space:nowrap;opacity:0.65;margin-top:2px}
.stats-partners-logos{display:flex;align-items:center;gap:36px;flex-wrap:wrap;justify-content:center}
.stats-partners-logos img{height:26px;filter:brightness(0) invert(1);opacity:0.65;transition:opacity 0.2s,transform 0.2s,filter 0.2s;object-fit:contain;max-width:90px}
.stats-partners-logos img:hover{opacity:1;transform:scale(1.1);filter:brightness(0) invert(1) drop-shadow(0 0 8px rgba(255,255,255,0.7))}
.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:none}
.d1{transition-delay:0.1s}
.d2{transition-delay:0.2s}
.d3{transition-delay:0.3s}
.d4{transition-delay:0.4s}
.d5{transition-delay:0.5s}
.section-about-wrap{background:var(--dark)}
.section-about{
  padding:80px 48px;
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
  max-width:1280px;margin:0 auto;
}
.about-visual{position:relative}
.about-slideshow{position:relative;width:100%;aspect-ratio:4/5;overflow:hidden}
.about-slideshow img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;filter:grayscale(20%);opacity:0;transition:opacity 1.2s ease}
.about-slideshow img.active{opacity:1}
.about-img-label{
  position:absolute;bottom:-1px;left:0;right:0;
  background:var(--orange);padding:14px 20px;
  font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;
}
.about-text{display:flex;flex-direction:column;gap:32px}
.section-eyebrow{font-size:11px;font-weight:700;letter-spacing:0.25em;text-transform:uppercase;color:var(--orange);margin-bottom:8px;display:block}
.section-title{font-family:var(--font-d);font-size:clamp(48px,6vw,80px);line-height:0.9;text-transform:uppercase}
.section-body{font-size:16px;line-height:1.8;color:rgba(255,255,255,0.65);max-width:none;font-weight:300}
.section-training{background:var(--black);padding:100px 48px}
.section-training-inner{max-width:1280px;margin:0 auto}
.section-header{margin-bottom:40px}
.training-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.training-card{position:relative;aspect-ratio:1/1;overflow:hidden;cursor:pointer}
.training-card::before,.training-card::after{content:'';position:absolute;top:0;bottom:0;width:48px;z-index:2;pointer-events:none}
.training-card::before{left:0;background:linear-gradient(to right,rgba(0,0,0,0.55),transparent)}
.training-card::after{right:0;background:linear-gradient(to left,rgba(0,0,0,0.55),transparent)}
.training-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease,filter 0.5s ease;filter:brightness(0.3) saturate(0.9)}
.training-card:hover img{transform:scale(1.06);filter:brightness(0.75) saturate(1.1)}
.training-card-content{
  position:absolute;inset:0;padding:32px;z-index:3;
  display:flex;flex-direction:column;justify-content:flex-end;
}
.training-tag{font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.75);margin-bottom:8px;transition:color 0.3s;text-shadow:0 1px 6px rgba(0,0,0,0.7)}
.training-name{font-family:var(--font-d);font-size:52px;line-height:0.95;text-transform:uppercase;text-shadow:0 2px 12px rgba(0,0,0,0.5)}
.training-info{font-size:12px;color:rgba(255,255,255,0.65);margin-top:8px;letter-spacing:0.05em;text-shadow:0 1px 4px rgba(0,0,0,0.6)}
.training-location{font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.65);margin-top:6px;transition:color 0.3s;text-shadow:0 1px 6px rgba(0,0,0,0.7)}
.training-cta{
  position:absolute;bottom:32px;right:32px;
  width:44px;height:44px;border:1px solid rgba(255,255,255,0.3);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.5);
  transition:background 0.2s,border-color 0.2s,color 0.2s;font-size:18px;
}
.training-card:hover .training-tag{color:var(--orange)}
.training-card:hover .training-location{color:var(--orange)}
.training-card:hover .training-cta{background:var(--orange);border-color:var(--orange);color:var(--white)}
.training-schedule-widget{margin-top:48px;background:var(--card);display:grid;grid-template-columns:1fr 280px;overflow:hidden}
.training-schedule-meta{padding:40px 36px;display:flex;flex-direction:column;justify-content:space-between;border-left:1px solid rgba(255,255,255,0.06)}
.training-schedule-label{font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--orange);margin-bottom:16px}
.training-schedule-desc{font-size:13px;color:rgba(255,255,255,0.45);line-height:1.7;font-weight:300}
.eversports-wrap{zoom:0.72;transform-origin:top left;overflow:hidden;padding:24px 28px}
.partners-inline{margin-top:32px;padding-top:20px;border-top:1px solid rgba(255,255,255,0.08);display:flex;align-items:center;gap:40px;flex-wrap:wrap}
.partners-inline .partners-label{font-size:10px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--grey);white-space:nowrap}
.partners-inline .partners-logos{display:flex;align-items:center;gap:36px;flex-wrap:wrap}
.partners-inline .partners-logos img{height:26px;filter:brightness(0) invert(1);opacity:0.5;transition:opacity 0.2s,transform 0.2s,filter 0.2s}
.partners-inline .partners-logos img:hover{opacity:1;transform:scale(1.12);filter:brightness(0) invert(1) drop-shadow(0 0 8px rgba(255,255,255,0.6))}
.section-coaching{background:var(--dark);padding:100px 48px}
.section-coaching-inner{max-width:1280px;margin:0 auto}
.coaching-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:24px}
.coaching-card{position:relative;aspect-ratio:1/1;overflow:hidden;cursor:pointer;text-decoration:none;display:block}
.coaching-card::before,.coaching-card::after{content:'';position:absolute;top:0;bottom:0;width:48px;z-index:2;pointer-events:none}
.coaching-card::before{left:0;background:linear-gradient(to right,rgba(0,0,0,0.55),transparent)}
.coaching-card::after{right:0;background:linear-gradient(to left,rgba(0,0,0,0.55),transparent)}
.coaching-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease,filter 0.5s ease;filter:brightness(0.3) saturate(0.9)}
.coaching-card:hover img{transform:scale(1.05);filter:grayscale(0%) brightness(0.75) saturate(1.05)}
.coaching-card-content{
  position:absolute;inset:0;padding:32px;z-index:3;
  display:flex;flex-direction:column;justify-content:flex-end;
  background:linear-gradient(to top,rgba(10,10,10,0.9) 0%,rgba(10,10,10,0.3) 55%,transparent 100%);
}
.coaching-badge{
  position:absolute;top:28px;right:28px;
  font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  background:var(--orange);color:var(--white);padding:4px 10px;
}
.coaching-tag{font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-bottom:10px;transition:color 0.3s}
.coaching-card:hover .coaching-tag{color:var(--orange)}
.coaching-name{font-family:var(--font-d);font-size:54px;line-height:0.95;text-transform:uppercase;color:var(--white)}
.coaching-price{font-size:13px;font-weight:600;color:rgba(255,255,255,0.55);letter-spacing:0.05em;margin-top:8px}
.coaching-bullets{margin-top:14px;display:flex;flex-direction:column;gap:4px;list-style:none;padding:0}
.coaching-bullets li{font-size:10px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:rgba(255,255,255,0.6);text-shadow:0 1px 4px rgba(0,0,0,0.6)}
.coaching-bullets li::before{content:"—  ";color:rgba(255,255,255,0.45);transition:color 0.3s}
.coaching-card:hover .coaching-bullets li::before{color:var(--orange)}
.coaching-cta-btn{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:20px;padding:10px 20px;
  border:1px solid rgba(255,255,255,0.3);
  font-size:10px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;
  color:rgba(255,255,255,0.5);background:transparent;
  transition:background 0.2s,border-color 0.2s,color 0.2s;
}
.coaching-card:hover .coaching-cta-btn{background:var(--orange);border-color:var(--orange);color:var(--white)}
.section-coaches{background:var(--dark);padding:80px 48px}
.section-coaches-inner{max-width:1280px;margin:0 auto}
.coaches-scroll-wrap{
  margin-top:48px;overflow-x:auto;overflow-y:visible;
  scrollbar-width:none;cursor:grab;
  margin-right:-48px;
}
.coaches-scroll-wrap::-webkit-scrollbar{display:none}
.coaches-scroll-wrap.grabbing{cursor:grabbing;user-select:none}
.coaches-scroll{display:flex;gap:3px;width:max-content;padding-right:48px}
.coach-card{
  flex-shrink:0;width:196px;height:260px;
  position:relative;overflow:hidden;
}
.coach-card img{
  width:100%;height:100%;display:block;
  object-fit:cover;object-position:center 20%;
  filter:brightness(0.3) saturate(0.9);
  transition:filter 0.4s,transform 0.5s;
}
.coach-card:hover img{filter:brightness(0.65) saturate(1.1);transform:scale(1.04)}
.coach-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(24,24,24,0.9) 0%,transparent 55%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:16px 14px;
}
.coach-name{font-size:13px;font-weight:700;letter-spacing:0.05em}
.coach-role{font-size:10px;color:rgba(255,255,255,0.45);letter-spacing:0.04em;margin-top:2px}
.coach-city{font-size:10px;color:rgba(255,255,255,0.4);font-weight:600;letter-spacing:0.12em;text-transform:uppercase;margin-top:3px;transition:color 0.3s}
.coach-card:hover .coach-city{color:var(--orange)}
.coach-card.no-photo{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.07);height:260px}
.coach-initials{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-60%);
  font-family:var(--font-d);font-size:54px;line-height:1;
  color:rgba(255,255,255,0.09);letter-spacing:-2px;pointer-events:none;
}
.coach-sep{
  flex-shrink:0;width:52px;height:260px;
  display:flex;align-items:center;justify-content:center;
  margin:0 4px;
  border-left:1px solid rgba(254,80,0,0.25);
}
.coach-sep-label{
  writing-mode:vertical-rl;transform:rotate(180deg);
  font-size:10px;font-weight:700;letter-spacing:0.25em;text-transform:uppercase;
  color:var(--orange);opacity:0.7;
}
.coaches-filters{
  display:flex;gap:16px;margin-top:32px;flex-wrap:wrap;align-items:center;
}
.filter-divider{width:1px;height:18px;background:rgba(255,255,255,0.15);flex-shrink:0}
.filter-group{display:flex;gap:5px;flex-wrap:wrap}
.filter-btn{
  background:transparent;border:1px solid rgba(255,255,255,0.15);
  color:rgba(255,255,255,0.45);padding:6px 13px;
  font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  cursor:pointer;transition:all 0.2s;font-family:var(--font-b);white-space:nowrap;
}
.filter-btn:hover{border-color:rgba(255,255,255,0.3);color:rgba(255,255,255,0.75)}
.filter-btn.active{background:var(--orange);border-color:var(--orange);color:var(--white)}
.section-cta{
  position:relative;height:420px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.section-cta-bg{
  position:absolute;inset:0;
  background:url('https://runningsociety.de/wp-content/uploads/2026/06/hero-rooftop-sonnenuntergang-2.jpg') center 60%/cover no-repeat;
  transform:scale(1.08) translate(0,0);
  animation:cta-drift 18s ease-in-out infinite;
}
@keyframes cta-drift{0%{transform:scale(1.08) translate(0,0)}50%{transform:scale(1.08) translate(-1.5%,-1%)}100%{transform:scale(1.08) translate(0,0)}}
.section-cta-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(254,80,0,.18) 0%,rgba(20,20,20,.82) 35%,rgba(20,20,20,.76) 100%)}
.section-cta-content{position:relative;z-index:2;text-align:center}
.cta-headline{
  font-family:var(--font-d);font-size:clamp(64px,10vw,120px);
  text-transform:uppercase;line-height:0.9;margin-bottom:40px;
}
.cta-headline em{color:var(--orange);font-style:normal}
.section-partners{
  background:var(--black);padding:64px 48px;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.partners-inner{
  max-width:1280px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:40px;
}
.partners-label{font-size:10px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--grey);white-space:nowrap}
.partners-logos{display:flex;align-items:center;gap:48px;flex-wrap:wrap}
.partners-logos img{height:28px;filter:brightness(0) invert(1);opacity:0.4;transition:opacity 0.2s}
.partners-logos img:hover{opacity:0.8}
.section-koop{background:var(--dark);padding:40px 48px}
.section-koop-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.koop-label{font-size:10px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--grey);white-space:nowrap}
.koop-logos{display:flex;align-items:center;gap:48px;flex-wrap:wrap}
.koop-logos img{height:24px;filter:brightness(0) invert(1);opacity:0.35;transition:opacity 0.2s;object-fit:contain}
.koop-logos img:hover{opacity:0.7}
@keyframes heroEntry{
  0%  {transform:scale(1.04) rotate(0deg) translateX(0)}
  100%{transform:scale(1.18) rotate(-2.5deg) translateX(-1.5%)}
}
@keyframes heroFadeOut{0%{opacity:1}100%{opacity:0}}
@keyframes wordReveal{from{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scrollPulse{0%,100%{opacity:0.3}50%{opacity:1}}
.training-card.tapped img{transform:scale(1.06);filter:brightness(0.75) saturate(1.1)}
.training-card.tapped .training-tag{color:var(--orange)}
.training-card.tapped .training-location{color:var(--orange)}
.training-card.tapped .training-cta{background:var(--orange);border-color:var(--orange);color:var(--white)}
.coaching-card.tapped img{transform:scale(1.05);filter:grayscale(0%) brightness(0.75) saturate(1.05)}
.coaching-card.tapped .coaching-tag{color:var(--orange)}
.coaching-card.tapped .coaching-bullets li::before{color:var(--orange)}
.coaching-card.tapped .coaching-cta-btn{background:var(--orange);border-color:var(--orange);color:var(--white)}
.coach-card.tapped img{filter:brightness(0.65) saturate(1.1);transform:scale(1.04)}
.coach-card.tapped .coach-city{color:var(--orange)}
@media(max-width:900px){
  .nav-links,.nav-social{display:none}
  .section-about{grid-template-columns:1fr;gap:40px}
  .training-grid{grid-template-columns:1fr}
  .training-schedule-widget{grid-template-columns:1fr}
  .training-schedule-meta{border-right:none;border-bottom:1px solid rgba(255,255,255,0.06)}
  .training-card{aspect-ratio:unset;height:160px}
  .coaching-grid{grid-template-columns:1fr}
  .coaching-card{aspect-ratio:unset;height:280px}
  .coaching-card img{position:absolute;inset:0}
  .coaches-scroll-wrap{margin-right:-24px}
  .partners-inner{flex-direction:column;align-items:flex-start}
  #logo-3d-wrap{display:none}
  #nav-logo-2d{display:none!important}
  .nav-logo-fallback{display:block!important;height:38px!important}
  .nav-logo-space{display:flex;align-items:center;justify-content:flex-start}

  .hero-logo-mobile{
    display:block;width:72px;height:72px;
    opacity:0;animation:fadeIn 0.8s 0.5s ease forwards;
    margin-bottom:8px;
  }
}
@media(max-width:768px){
  #nav{padding:16px 24px}
  .hero-content{padding:0 var(--pad-x);padding-top:80px}
  .hero-headline{font-size:clamp(56px,16vw,96px)}
  .hero-cta{flex-direction:column;gap:12px;width:100%;max-width:320px}
  .hero-cta a{width:100%;text-align:center;display:block}


  .stats-strip{flex-direction:column;gap:40px;padding:48px var(--pad-x)}
  .stats-divider{display:none}
  .stats-left{display:grid;grid-template-columns:1fr 1fr;gap:28px 16px}
  .stats-partners{width:100%;border-top:1px solid rgba(255,255,255,0.18);padding-top:28px}
  .stats-partners-logos{flex-wrap:nowrap;gap:12px;justify-content:space-between;width:100%}
  .stats-partners-logos a{flex:1;display:flex;align-items:center;justify-content:center;min-width:0}
  .stats-partners-logos img{height:auto!important;max-height:22px;max-width:100%;width:auto}
  .stats-partners-logos a.tapped img{opacity:1;transform:scale(1.1);filter:brightness(0) invert(1) drop-shadow(0 0 8px rgba(255,255,255,0.7))}
  .training-schedule-meta .partners-logos a.tapped img{opacity:1;transform:scale(1.12);filter:brightness(0) invert(1) drop-shadow(0 0 8px rgba(255,255,255,0.6))}


  .training-schedule-widget{background:transparent}
  .training-schedule-meta{border:none;align-items:center;text-align:center;padding:24px 24px 0}
  .training-schedule-meta .partners-inline{flex-direction:column;align-items:center;padding-top:0;border-top:none;margin-top:0;gap:16px}
  .training-schedule-meta .partners-logos{flex-direction:row!important;flex-wrap:wrap;align-items:center!important;justify-content:center;gap:20px!important}


  .section-about{padding:0 var(--pad-x);gap:0;grid-template-columns:1fr}
  .about-text{order:1;padding:48px 0 40px}
  .about-visual{order:2;width:100%}
  .about-slideshow{aspect-ratio:4/5}


  .section-body{white-space:normal;max-width:none}

  section{padding:64px var(--pad-x)}
  .section-training,.section-coaching,.section-coaches,.section-koop{padding-left:var(--pad-x);padding-right:var(--pad-x)}
  .section-title{font-size:clamp(48px,12vw,80px)}

  footer{padding:40px var(--pad-x) 24px;flex-direction:column;align-items:flex-start}
  .footer-top{flex-direction:column;gap:40px;align-items:stretch}
  .footer-nav{display:flex;flex-wrap:wrap;width:100%;row-gap:32px;column-gap:0}
  .footer-nav-col{width:50%;box-sizing:border-box;padding-right:20px}
  .footer-nav-col:nth-child(even){padding-right:0;padding-left:20px}
}
