/* =========================================================
   Kaiserwinkl HM – Light Grey Theme (mit Brand-Akzenten)
   - Hintergrund: hellgrau + orange/blau Verlauf-Akzente
   - Cards: clean, modern, leichtes Glass/Shadow
   - Sticky Nav bleibt dunkel für Kontrast
   - Section Trenner + Active Menu
========================================================= */

:root{
  /* Brand */
  --brand-orange: #f07a1a;
  --brand-orange-2: #ff9a3d;
  --brand-blue: #2aa7df;
  --brand-blue-2: #5cc3ef;

  /* Background (hellgrau) */
  --bg:  #f2f4f7;
  --bg2: #eef1f5;
  --bg3: #e9edf3;

  /* Surfaces (hell) */
  --surface: rgba(255,255,255,.70);
  --surface2: rgba(255,255,255,.85);
  --card: rgba(255,255,255,.92);
  --card2: rgba(255,255,255,.96);

  /* Text (dark on light) */
  --text: #141826;
  --text2: rgba(20,24,38,.92);
  --muted: rgba(20,24,38,.68);
  --muted2: rgba(20,24,38,.52);

  /* Borders */
  --border: rgba(20,24,38,.12);
  --border2: rgba(20,24,38,.18);

  /* Accents */
  --accent: var(--brand-orange);
  --accent2: var(--brand-orange-2);
  --accent-blue: var(--brand-blue);

  /* Gradients */
  --grad-accent: linear-gradient(135deg, var(--brand-orange), var(--brand-orange-2));
  --grad-blue: linear-gradient(135deg, var(--brand-blue), var(--brand-blue-2));

  /* Card shading */
  --grad-card: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.90));

  /* Radii */
  --radius: 18px;
  --radius-lg: 22px;

  /* Shadows (helles Theme => weichere Schatten) */
  --shadow: 0 18px 48px rgba(16,20,30,.10);
  --shadow-soft: 0 12px 30px rgba(16,20,30,.08);
  --shadow-glow: 0 18px 42px rgba(240,122,26,.16);

  /* Layout */
  --max: 1140px;
  --container-pad: 22px;
  --container-pad-sm: 16px;

  /* Motion */
  --ease: cubic-bezier(.2,.8,.2,1);
  --t: 180ms var(--ease);

  /* Focus ring */
  --ring: 0 0 0 4px rgba(240,122,26,.22);

  /* Sponsor ticker */
  --ticker-speed: 28s;

  /* Nav */
  --nav-h: 64px;
  --nav-bg: rgba(22, 24, 31, .72);
  --nav-border: rgba(255,255,255,.08);
  --nav-shadow: 0 8px 24px rgba(0,0,0,.18);
  --panel-bg: rgba(20, 22, 28, .92);
  --panel-shadow: 0 20px 60px rgba(0,0,0,.35);

  --logo-w: 125px;
  --logo-overlap: 25px;

  --chip-bg: rgba(255,255,255,.07);
  --chip-border: rgba(255,255,255,.10);

  --focus: rgba(249,115,22,.55); /* orange */
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}

body.theme-dark{
  color:var(--text);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  background:
    radial-gradient(1200px 680px at 18% 12%, rgba(240,122,26,.20), transparent 62%),
    radial-gradient(1200px 680px at 86% 14%, rgba(42,167,223,.16), transparent 65%),
    radial-gradient(1200px 680px at 55% 95%, rgba(255,154,61,.12), transparent 70%),
    linear-gradient(180deg, var(--bg), var(--bg2) 55%, var(--bg3));
}

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

/* Container / spacing */
.container{max-width:var(--max);margin:0 auto;padding:0 var(--container-pad)}
@media (max-width: 640px){ .container{padding:0 var(--container-pad-sm)} }

.main{padding-bottom:64px}
.section{padding:5px 0; position:relative}
@media (max-width: 640px){ .section{padding:5px 0} }

.section-head h1,.section-head h2{margin:0 0 10px 0; padding: 50px 0 20px 0; letter-spacing:-0.02em}
.muted{color:var(--muted)}
.mt{margin-top:28px}

/* =========================================================
   Sticky Nav
========================================================= */
.site-nav{
  position: sticky;
  top: 0;
  z-index: 1000;
  backdrop-filter: blur(12px);
  background: var(--nav-bg);
  border-bottom: 1px solid var(--nav-border);
  box-shadow: var(--nav-shadow);
  padding: 15px 0;
}

.topbar{
  height: var(--nav-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  position: relative;
}

.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 220px;
}

.brand .logo{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--logo-w);
  height: var(--logo-w);
  flex: 0 0 var(--logo-w);
}

.brand .logo-img{
  width: var(--logo-w);
  height: var(--logo-w);
  object-fit: contain;
  display:block;
  position: absolute;
  left: 0;
  bottom: calc(var(--logo-overlap) * -1);
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.35));
}

.brand .sub{
  font-size: 12px;
  opacity: .85;
  white-space: nowrap;
}

.nav{
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1 1 auto;
  justify-content: center;
}

.nav a{
  display:inline-flex;
  align-items:center;
  height: 36px;
  padding: 0 12px;
  border-radius: 999px;
  font-weight:bold;
  font-size: 15px;
  color: rgba(255,255,255,.86);
  transition: transform .18s ease, background .18s ease, color .18s ease;
}
.nav a:hover{ background: rgba(255,255,255,.06); transform: translateY(-1px); }
.nav a.is-active{
  background: rgba(249,115,22,.16);
  color: #fff;
  box-shadow: 0 6px 18px rgba(249,115,22,.12);
}

/* Desktop Dropdown "Bewerbe" */
.nav-dd{
  position: relative;
  display: inline-flex;
  align-items: center;
}
.nav .nav-dd-btn{
  appearance: none;
  border: 0;
  background: transparent;
  font: inherit;
  color: rgba(255,255,255,.92);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 999px;
  line-height: 1;
  font-weight: 700;
}
.nav .nav-dd-btn:hover{ background: rgba(255,255,255,.06); }
.nav .nav-dd-btn:focus-visible{ outline: none; }

.nav-dd.is-active > .nav-dd-btn{
  box-shadow: 0 0 0 1px rgba(249,115,22,.35), 0 10px 30px rgba(249,115,22,.18);
}

.nav-dd::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 16px;
}

.nav-dd-menu{
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  min-width: 260px;
  padding: 10px;
  border-radius: 18px;
  background: rgba(20, 24, 32, .78);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow:
    0 14px 40px rgba(0,0,0,.30),
    0 1px 0 rgba(255,255,255,.06) inset;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity .14s ease, transform .14s ease, visibility .14s ease;
  z-index: 50;
}

.nav-dd:hover .nav-dd-menu,
.nav-dd:focus-within .nav-dd-menu,
.nav-dd.is-open .nav-dd-menu{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav-dd-menu a{
  display: flex;
  align-items: center;
  padding: 12px 14px;
  border-radius: 14px;
  color: rgba(255,255,255,.92);
  font-weight: 700;
  letter-spacing: .2px;
  background: transparent;
}
.nav-dd-menu a:hover{ background: rgba(255,255,255,.08); }
.nav-dd-menu a.is-active{
  background: rgba(249,115,22,.18);
  border: 1px solid rgba(249,115,22,.35);
  box-shadow: 0 10px 26px rgba(249,115,22,.12);
}
.nav-dd-menu a + a{ margin-top: 6px; }

.nav-dd-caret{ font-size: .85em; opacity: .8; }

.actions{ display:flex; align-items:center; gap: 10px; }

/* Flag language buttons */
.langflag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: var(--chip-bg);
  border: 1px solid var(--chip-border);
  line-height: 1;
  font-size: 16px;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.langflag:hover{ transform: translateY(-1px); background: rgba(255,255,255,.10); }
.langflag.is-active{ border-color: rgba(249,115,22,.55); box-shadow: 0 0 0 3px rgba(249,115,22,.18); }

/* Burger */
.burger{
  display:none;
  align-items:center;
  justify-content:center;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  cursor: pointer;
  color: #fff;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.burger:hover{ transform: translateY(-1px); background: rgba(255,255,255,.10); }
.burger:focus{ outline: none; box-shadow: 0 0 0 3px var(--focus); }
.burger span{
  display:block;
  width: 18px;
  height: 2px;
  background: rgba(255,255,255,.86);
  position: relative;
  border-radius: 2px;
}
.burger span::before,
.burger span::after{
  content:"";
  position:absolute;
  left:0;
  width: 18px;
  height: 2px;
  background: rgba(255,255,255,.86);
  border-radius: 2px;
}
.burger span::before{ top:-6px; }
.burger span::after{ top: 6px; }

/* Mobile panel */
.mobile-nav{
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: none;
}
.mobile-nav.is-open{ display:block; }

.mobile-nav .backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(6px);
}
.mobile-nav .panel{
  position:absolute;
  top: 10px;
  right: 10px;
  width: min(88vw, 340px);
  background: var(--panel-bg);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  box-shadow: var(--panel-shadow);
  padding: 14px;
  transform: translateY(-8px);
  opacity: 0;
  transition: transform .22s ease, opacity .22s ease;
}
.mobile-nav.is-open .panel{ transform: translateY(0); opacity: 1; }

.mobile-nav .panel-head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.mobile-nav .panel-title{ font-weight: 700; color: rgba(255,255,255,.92); }

.mobile-nav .close{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  color: #fff;
  cursor: pointer;
}
.mobile-nav .close:focus{ outline:none; box-shadow: 0 0 0 3px var(--focus); }

.mobile-nav .links{
  display:flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px 0;
}
.mobile-nav .links a{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 12px 12px;
  border-radius: 14px;
  color: rgba(255,255,255,.90);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
}
.mobile-nav .links a:hover{ background: rgba(255,255,255,.08); }

.mobile-nav .panel-actions{
  display:flex;
  gap: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,.10);
  align-items:center;
  justify-content: space-between;
}

@media (max-width: 980px){
  .nav{ display:none; }
  .burger{ display:inline-flex; }
  .brand{ min-width: 0; }
  .brand .sub{ display:none; }
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.16);
  font-weight:800;
  font-size:14px;
  background: rgba(255,255,255,.06);
  color: #fff;
  transition: transform var(--t), filter var(--t), background var(--t), border-color var(--t), box-shadow var(--t);
}
.btn:hover{ transform: translateY(-1px); background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.22); }

.btn-primary{
  background: var(--grad-accent);
  border-color: transparent;
  box-shadow: var(--shadow-glow);
  color: #141826;
}
.btn-primary:hover{ filter: brightness(1.03); box-shadow: 0 18px 56px rgba(240,122,26,.22); }

.btn-ghost{background: rgba(255,255,255,.06)}
.btn-ghost:hover{background: rgba(255,255,255,.12)}

.btn.sheen{ position:relative; overflow:hidden; }
.btn.sheen::after{
  content:"";
  position:absolute;
  top:-40%;
  left:-40%;
  width: 40%;
  height: 180%;
  transform: rotate(18deg);
  background: linear-gradient(90deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.35) 45%,
    rgba(255,255,255,0) 100%);
  opacity:0;
  transition: opacity var(--t), transform 520ms var(--ease);
}
.btn.sheen:hover::after{ opacity: .85; transform: translateX(240%) rotate(18deg); }

.inner-main{padding-top:12px}

/* =========================================================
   HERO (final: passt zu deinem HTML + Hero-Slider)
========================================================= */

.home-hero{
  position: relative;
  min-height: clamp(520px, 66vh, 760px);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  background: #111;
}

/* Hero slides layer */
.hero-slides{
  position:absolute;
  inset:0;
  z-index:0;
}

.hero-slide{
  position:absolute;
  inset:0;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
  opacity:0;

  will-change: opacity, transform;
  backface-visibility: hidden;
  transform: translateZ(0) scale(1.02);

  transition: opacity 900ms ease, transform 2500ms ease;
}
.hero-slide.is-active{
  opacity:1;
  transform: translateZ(0) scale(1.00);
}

/* Overlay for readability (matches your current final outcome) */
.home-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(1200px 600px at 50% 38%,
      rgba(0,0,0,.30),
      rgba(0,0,0,.55) 55%,
      rgba(0,0,0,.70) 100%);
  pointer-events:none;
  z-index: 0;
}
.home-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(to bottom, rgba(0,0,0,.25), rgba(0,0,0,.25));
  mix-blend-mode: multiply;
  pointer-events:none;
  z-index: 0;
}

/* hero content wrapper */
.home-hero .container.hero{
  position: relative;
  z-index: 1;
  width: 100%;
  padding-top: calc(var(--nav-h) + 26px);
  padding-bottom: 36px;
}

.hero-content{
  max-width: 980px;
  margin: 0 auto;
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap: 14px;
  position: relative;
  z-index: 2;
}

.hero-scrim{
  display:inline-block;
  padding: 18px 22px;
  border-radius: 18px;
  background: rgba(10,12,16,.1);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  box-shadow: 0 14px 40px rgba(0,0,0,.75);
  position: relative;
}

.hero-scrim::before{
  content:"";
  position:absolute;
  inset:-40px -55px;
  border-radius: 28px;
  background: radial-gradient(
    ellipse at center,
    rgba(10,12,16,.55) 0%,
    rgba(10,12,16,.35) 45%,
    rgba(10,12,16,0) 75%
  );
  z-index:-1;
  pointer-events:none;
  filter: blur(2px);
}

/* hero title: your HTML uses <h1 class="hero-title ..."> */
.hero-title{
  margin: 0;
  font-weight: 900;
  letter-spacing: -.02em;
  color: #fff;
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.05;
  text-shadow: 0 2px 14px rgba(0,0,0,.62);
}

/* Meta line */
.hero-meta-line{
  margin: 0;
  font-size: 30px;
  color: var(--brand-orange);
  text-shadow: 0 2px 12px rgba(0,0,0,.60);
  font-weight:bold;
}

/* Tagline */
.hero-tagline{
  margin: 0;
  color: rgba(255,255,255,.85);
  max-width: 680px;
  font-size: 20px;
  text-shadow: 0 2px 12px rgba(0,0,0,.60);
}

/* Countdown */
.countdown{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content:center;
  margin-top: 6px;
}
.cd-box{
  width: 92px;
  min-width: 90px;
  padding: 10px 10px;
  border-radius: 16px;
  background: rgba(0,0,0,.30);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 12px 30px rgba(0,0,0,.22);
}
.cd-num{
  font-weight: 900;
  font-size: 22px;
  color: #fff;
  line-height: 1;
  text-shadow: 0 2px 10px rgba(0,0,0,.55);
}
.cd-lab{
  margin-top: 6px;
  font-size: 11px;
  color: rgba(255,255,255,.78);
  text-transform: uppercase;
  letter-spacing: .12em;
}

/* CTA */
.hero-cta{
  margin-top: 18px;
  display:flex;
  justify-content:center;
  gap: 12px;
}
.home-hero .hero-cta .btn{ box-shadow: 0 12px 30px rgba(0,0,0,.25); }

/* Animation */
.hero-animate{
  opacity: 0;
  transform: translateY(34px);
  filter: blur(2px);
}
.hero-animate.is-in{
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
  transition:
    opacity 1.05s cubic-bezier(.2,.8,.2,1),
    transform 1.10s cubic-bezier(.2,.8,.2,1),
    filter 1.10s cubic-bezier(.2,.8,.2,1);
}
.hero-animate.delay-1.is-in{ transition-delay: .10s; }
.hero-animate.delay-2.is-in{ transition-delay: .28s; }

@media (max-width: 720px){
  .cd-box{ width: 50px; min-width:70px; }
  .cd-num{ font-weight: 700; font-size: 18px; }
}

/* Topbar CTA Abstand */
.site-nav .actions .btn.btn-primary{ margin-left: 14px; }

/* =========================================================
   Cards / Layout (hell)
========================================================= */
.grid{display:grid;gap:16px}
.grid.cards{grid-template-columns:repeat(3,1fr)}
@media (max-width: 960px){.grid.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 640px){.grid.cards{grid-template-columns:1fr}}

.card{
  background: var(--grad-card);
  border: 1px solid rgba(20,24,38,.10);
  border-radius: var(--radius-lg);
  padding: 16px;
  box-shadow: var(--shadow);
  position: relative;
  overflow: hidden;
  transition: transform var(--t), border-color var(--t), box-shadow var(--t), background var(--t);
}
.card::before{
  content:"";
  position:absolute;
  inset:-90px -90px auto -90px;
  height: 150px;
  background:
    radial-gradient(closest-side at 25% 45%, rgba(240,122,26,.18), transparent 64%),
    radial-gradient(closest-side at 65% 40%, rgba(42,167,223,.14), transparent 66%);
  filter: blur(16px);
  opacity: .85;
}
.card:hover{
  transform: translateY(-3px);
  border-color: rgba(20,24,38,.16);
  box-shadow: 0 22px 60px rgba(16,20,30,.12);
}

.badge{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(240,122,26,.14);
  border: 1px solid rgba(240,122,26,.26);
  color: rgba(20,24,38,.92);
  font-size:12px;
  font-weight:900;
  position: relative;
}
.badge.blue{ background: rgba(42,167,223,.14); border-color: rgba(42,167,223,.24); }

.card-title{
  margin-top: 12px;
  font-size: 18px;
  font-weight: 950;
  letter-spacing:-0.01em;
  position: relative;
  color: var(--text);
}
.card-meta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:12px;
  position: relative;
}
.meta-item{
  font-size:13px;
  color: rgba(20,24,38,.86);
  background: rgba(20,24,38,.05);
  border:1px solid rgba(20,24,38,.10);
  padding:6px 10px;
  border-radius:999px;
}

.card-actions{
  display:flex;
  gap:10px;
  justify-content:space-between;
  align-items:center;
  margin-top:14px;
  position: relative;
}

/* =========================================================
   Tables / Panels
========================================================= */
.schedule{
  border:1px solid rgba(20,24,38,.10);
  border-radius: var(--radius-lg);
  overflow:hidden;
  background: rgba(255,255,255,.80);
  box-shadow: var(--shadow-soft);
}

/* NOTE: final schedule-row/time = spätere Definition aus deiner Datei (2-col) */
.schedule-row{
  display:grid;
  grid-template-columns: 110px 1fr;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px solid rgba(0,0,0,.06);
}
.schedule-row:first-of-type{ border-top: 0; }
.schedule-time{ font-weight: 700; opacity: .85; }
.schedule-note{ color: var(--muted); }

@media(max-width:640px){
  .schedule-row{ grid-template-columns: 90px 1fr; }
  .schedule-note{ grid-column:2/3; }
}

.grid.plans{grid-template-columns:repeat(3,1fr)}
@media(max-width:960px){.grid.plans{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid.plans{grid-template-columns:1fr}}

.plan-link{
  border-radius: var(--radius-lg);
  border:1px solid rgba(20,24,38,.10);
  background: rgba(255,255,255,.86);
  padding: 14px;
  box-shadow: var(--shadow-soft);
  transition: transform var(--t), border-color var(--t), background var(--t);
}
.plan-link:hover{
  transform: translateY(-2px);
  border-color: rgba(20,24,38,.16);
  background: rgba(255,255,255,.96);
}
.plan-cat{font-size:12px;color:var(--muted)}
.plan-title{font-weight:950;margin-top:6px}

.grid.detail{grid-template-columns:1.2fr .8fr}
@media(max-width:960px){.grid.detail{grid-template-columns:1fr}}

.panel{
  border-radius: var(--radius-lg);
  border: 1px solid rgba(20,24,38,.10);
  background: rgba(255,255,255,.86);
  padding: 16px;
  box-shadow: var(--shadow-soft);
}
.panel-title{font-weight:950;margin-bottom:10px}
.panel-row{padding:10px 0;border-bottom:1px solid rgba(20,24,38,.08)}
.panel-row:last-child{border-bottom:none}
.panel-actions{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}

/* =========================================================
   Sponsor ticker (base + footer override)
========================================================= */
.sponsor-ticker{
  overflow:hidden;
  border-top:1px solid rgba(20,24,38,.08);
  border-bottom:1px solid rgba(20,24,38,.08);
  background: rgba(255,255,255,.65);
  position: relative;
}
.sponsor-ticker::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(closest-side at 20% 50%, rgba(240,122,26,.14), transparent 70%),
    radial-gradient(closest-side at 80% 50%, rgba(42,167,223,.12), transparent 70%);
  pointer-events:none;
}
.sponsor-ticker-footer{ margin-top: 34px; padding: 14px 0; }

.ticker-track{
  display:flex;
  gap:22px;
  align-items:center;
  padding:12px 0;
  width:max-content;
  animation: ticker var(--ticker-speed) linear infinite;
  position: relative;
}
.ticker-item{
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 6px 10px;
  border-radius: 14px;
  border: 1px solid rgba(20,24,38,.10);
  background: rgba(255,255,255,.86);
  transition: transform var(--t), border-color var(--t), background var(--t);
}
.ticker-item:hover{
  transform: translateY(-2px);
  border-color: rgba(20,24,38,.16);
  background: rgba(255,255,255,.96);
}
.ticker-item img{height: 34px; opacity: .96}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Footer Sponsor-Ticker override (bigger logos + viewport) */
.sponsor-ticker .ticker-viewport{
  overflow: hidden;
  border-radius: 18px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
}
.sponsor-ticker .ticker-track{
  display: flex;
  align-items: center;
  gap: 26px;
  padding: 2px 18px;
  width: max-content;
  animation: ticker-move 28s linear infinite;
  will-change: transform;
}
.sponsor-ticker:hover .ticker-track{ animation-play-state: paused; }

.sponsor-ticker .ticker-item{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  min-width: 110px;
  padding: 10px;
  border-radius: 14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.sponsor-ticker .ticker-item:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.10);
  border-color: rgba(249,115,22,.22);
}
.sponsor-ticker .ticker-item img{
  height: 75px;
  width: auto;
  max-width: 150px;
  object-fit: contain;
  filter: drop-shadow(0 6px 14px rgba(0,0,0,.25));
}
@keyframes ticker-move{ from { transform: translateX(0); } to { transform: translateX(-50%); } }

@media (max-width: 720px){
  .sponsor-ticker .ticker-track{ gap: 18px; padding: 12px 14px; animation-duration: 22s; }
  .sponsor-ticker .ticker-item{ height: 54px; min-width: 96px; }
  .sponsor-ticker .ticker-item img{ height: 50px; max-width: 130px; }
}

/* =========================================================
   Sponsors grid
========================================================= */
.tier{margin-top:22px}
.sponsor-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:960px){.sponsor-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.sponsor-grid{grid-template-columns:repeat(2,1fr)}}

.sponsor-card{
  border-radius: 18px;
  border:1px solid rgba(20,24,38,.10);
  background: rgba(255,255,255,.90);
  padding: 16px;
  min-height: 84px;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow: var(--shadow-soft);
  transition: transform var(--t), border-color var(--t), background var(--t);
}
.sponsor-card:hover{
  transform: translateY(-2px);
  border-color: rgba(20,24,38,.16);
  background: rgba(255,255,255,.98);
}
.sponsor-card img{max-height:46px}

/* =========================================================
   Archive (final = grid variant)
========================================================= */
.archive-list{ display: grid; gap: 12px; }

.year-card{
  display: grid;
  grid-template-columns: 120px 1fr;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 14px;
  background: var(--card, rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,0.08);
}
.year-title{
  font-size: 22px;
  font-weight: 900;
  letter-spacing: .3px;
}
.year-actions{
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}
.pill-disabled{
  opacity: .45;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  cursor: not-allowed;
}
.pill-primary{
  background: linear-gradient(135deg, #f97316, #fb923c);
  color: #111;
  font-weight: 700;
}
@media (max-width: 700px){
  .year-card{ grid-template-columns: 1fr; }
  .year-actions{ justify-content: flex-start; }
}

/* =========================================================
   Contact
========================================================= */
.grid.contact-grid{grid-template-columns: 1fr 1.2fr}
@media(max-width:960px){ .grid.contact-grid{grid-template-columns:1fr} }

.form{display:flex;flex-direction:column;gap:12px}
.form label span{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}

.form input,.form textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(20,24,38,.14);
  background: rgba(255,255,255,.92);
  color: var(--text);
  transition: border-color var(--t), box-shadow var(--t), background var(--t);
}
.form input:focus,.form textarea:focus{
  outline:none;
  border-color: rgba(240,122,26,.55);
  box-shadow: var(--ring);
  background: rgba(255,255,255,.98);
}

/* =========================================================
   Footer
========================================================= */
.footer{
  border-top:1px solid rgba(20,24,38,.10);
  padding: 26px 0;
  background: rgba(255,255,255,.60);
  position: relative;
}
.footer::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(closest-side at 18% 30%, rgba(240,122,26,.12), transparent 70%),
    radial-gradient(closest-side at 82% 30%, rgba(42,167,223,.10), transparent 70%);
  pointer-events:none;
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:16px;
  position: relative;
}
.footer-grid--2{ grid-template-columns: 1.2fr .8fr; }

@media(max-width:960px){ .footer-grid{grid-template-columns:1fr} }
@media (max-width: 860px){
  .footer-grid--2{ grid-template-columns: 1fr; gap: 18px; }
}

.footer-title{font-weight:950;margin-bottom:10px}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{color: rgba(20,24,38,.86)}
.footer-links a:hover{text-decoration:underline}
.footer-bottom{
  margin-top:18px;
  padding-top:14px;
  border-top:1px solid rgba(20,24,38,.10);
  position: relative;
  color: rgba(20,24,38,.70);
}

/* Scroll-to-top */
.to-top{
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 1400;
  width: 46px;
  height: 46px;
  border-radius: 16px;
  border: 1px solid rgba(20,24,38,.16);
  background: rgba(255,255,255,.92);
  color: var(--text);
  font-weight: 950;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
  transition: opacity var(--t), transform var(--t), background var(--t), border-color var(--t), box-shadow var(--t);
  box-shadow: 0 14px 34px rgba(16,20,30,.12);
}
.to-top:hover{
  background: rgba(255,255,255,.98);
  border-color: rgba(20,24,38,.22);
  transform: translateY(8px);
  box-shadow: 0 18px 44px rgba(16,20,30,.14);
}
.to-top.show{
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

/* =========================================================
   Livebar + Stats
========================================================= */
.livebar{
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(20,24,38,.12);
  background:
    radial-gradient(closest-side at 20% 50%, rgba(240,122,26,.18), transparent 72%),
    radial-gradient(closest-side at 80% 50%, rgba(42,167,223,.14), transparent 74%),
    rgba(255,255,255,.82);
  box-shadow: 0 18px 46px rgba(16,20,30,.10);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.livebar-left{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }

.livebadge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:999px;
  font-weight:900;
  font-size:12px;
  border:1px solid rgba(240,122,26,.28);
  background: rgba(240,122,26,.10);
}
.livebadge .dot{
  width:8px;height:8px;border-radius:99px;
  background: var(--brand-orange);
  box-shadow: 0 0 0 6px rgba(240,122,26,.18);
}

.livechips{ display:flex; gap:8px; flex-wrap:wrap; }
.chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(20,24,38,.10);
  background: rgba(255,255,255,.88);
  color: rgba(20,24,38,.92);
  font-size:12px;
  box-shadow: 0 10px 26px rgba(16,20,30,.06);
}
.chip strong{font-weight:950}
.livebar-actions{ display:flex; gap:10px; flex-wrap:wrap; }

/* Stats strip */
.stats-strip{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:12px;
  margin-top: 14px;
}
@media(max-width: 960px){ .stats-strip{grid-template-columns: repeat(2, 1fr)} }
@media(max-width: 520px){ .stats-strip{grid-template-columns: 1fr} }

.statbox{
  border-radius: 18px;
  border:1px solid rgba(20,24,38,.10);
  background: rgba(255,255,255,.90);
  box-shadow: 0 18px 46px rgba(16,20,30,.10);
  padding: 14px 14px;
  position: relative;
  overflow:hidden;
}
.statbox::before{
  content:"";
  position:absolute;
  inset:-70px -70px auto -70px;
  height: 120px;
  background:
    radial-gradient(closest-side at 25% 45%, rgba(240,122,26,.18), transparent 66%),
    radial-gradient(closest-side at 65% 40%, rgba(42,167,223,.14), transparent 68%);
  filter: blur(16px);
  opacity:.85;
  pointer-events:none;
}
.statbox .value{
  font-size: 24px;
  font-weight: 1000;
  letter-spacing: -0.02em;
  color: rgba(20,24,38,.95);
  position:relative;
}
.statbox .label{
  margin-top: 2px;
  font-size: 12px;
  color: rgba(20,24,38,.62);
  position:relative;
}

/* Nation cards */
.nation-grid-wrap{
  margin-top: 14px;
  display: flex;
  justify-content: center;
}
.nation-grid{
  display: grid;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  gap: 12px;
  justify-content: center;
  grid-template-columns: repeat(auto-fit, minmax(96px, 96px));
}
.nation-card{
  border-radius: 16px;
  padding: 12px 10px;
  background: rgba(255,255,255,.60);
  box-shadow: 0 10px 26px rgba(0,0,0,.08);
  backdrop-filter: blur(10px);
  display:flex;
  flex-direction: column;
  align-items:center;
  justify-content:center;
  text-align:center;
  min-height: 92px;
}
.nation-flag{ font-size: 22px; line-height: 1; margin-bottom: 6px; }
.nation-code{ font-weight: 800; font-size: 12px; letter-spacing: .4px; opacity: .9; }
.nation-count{ margin-top: 6px; font-weight: 900; font-size: 16px; color: var(--accent, #f59e0b); }

.nation-total{
  background: rgba(245, 158, 11, .10);
  border: 1px solid rgba(245, 158, 11, .25);
}
.nation-total-title{ font-weight: 900; margin-bottom: 2px; }
.nation-total-sub{ font-size: 12px; opacity: .75; }

/* =========================================================
   Dividers zwischen Sections
========================================================= */
.section + .section::before{
  content:"";
  display:block;
  height: 14px;
  margin: 22px 0 26px;
  border-radius: 999px;
  background:
    linear-gradient(90deg,
      rgba(255,140,0,.22),
      rgba(255,140,0,.08) 35%,
      rgba(80,165,255,.08) 65%,
      rgba(80,165,255,.22)
    );
  box-shadow:
    0 10px 26px rgba(0,0,0,.06),
    0 0 18px rgba(255,140,0,.10),
    0 0 18px rgba(80,165,255,.10),
    inset 0 1px 0 rgba(255,255,255,.65);
  opacity: .95;
  transform: skewX(-6deg);
}
@media (max-width: 640px){
  .section + .section::before{
    height: 12px;
    margin: 18px 0 22px;
    transform: skewX(-5deg);
  }
}

/* =========================================================
   Home Intro / Slider
========================================================= */
.section-intro .intro-grid{
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 26px;
  align-items: center;
}
@media (max-width: 980px){ .section-intro .intro-grid{ grid-template-columns: 1fr; } }

.intro-text h2{ margin: 0 0 10px; }
.intro-copy{ color: var(--text-muted); line-height: 1.55; font-size: 15px; }
.intro-actions{ margin-top: 16px; display: flex; gap: 12px; flex-wrap: wrap; }

.slider{
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  background: rgba(255,255,255,.55);
  box-shadow: 0 18px 44px rgba(0,0,0,.12);
  border: 1px solid rgba(255,255,255,.7);
}
.slider-track{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 100%;
  transition: transform .6s cubic-bezier(.2,.8,.2,1);
  will-change: transform;
}
.slide{ margin: 0; aspect-ratio: 4 / 3; position: relative; }
.slide img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
}
.slider-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.65);
  background: rgba(20,22,28,.45);
  color: #fff;
  font-size: 26px;
  line-height: 1;
  display: grid;
  place-items: center;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(0,0,0,.18);
}
.slider-btn:hover{ background: rgba(20,22,28,.62); }
.slider-btn.prev{ left: 12px; }
.slider-btn.next{ right: 12px; }

.slider-dots{
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 10px;
  display: flex;
  gap: 8px;
  justify-content: center;
}
.slider-dots .dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(0,0,0,.12);
}
.slider-dots .dot.is-active{ background: var(--accent); border-color: rgba(0,0,0,.12); }

/* =========================================================
   Zeitplan Cards / Extras
========================================================= */
.schedule-days{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
@media (max-width: 920px){ .schedule-days{ grid-template-columns: 1fr; } }

.schedule-card{
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(255,255,255,.75);
  border-radius: 18px;
  box-shadow: 0 18px 44px rgba(0,0,0,.10);
  padding: 16px;
}
.schedule-day-title{ font-weight: 800; margin-bottom: 10px; }

.schedule-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 900px){ .schedule-grid{ grid-template-columns: 1fr; } }

.schedule-day{
  background: rgba(255,255,255,.55);
  border-radius: 18px;
  padding: 14px 14px 6px;
  box-shadow: 0 14px 40px rgba(0,0,0,.08);
  backdrop-filter: blur(8px);
}
.schedule-day-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom: 10px;
}

.schedule-grid-2{ display:grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 900px){ .schedule-grid-2{ grid-template-columns: 1fr; } }

.schedule-extra{
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(0,0,0,.06);
}
.schedule-extra-title{ font-weight: 800; margin-bottom: 10px; }
.schedule-extra-box{
  border-radius: 14px;
  padding: 25px 12px;
  background: rgba(255,255,255,.55);
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
  backdrop-filter: blur(10px);
}
.schedule-extra-name{ font-weight: 900; margin-bottom: 4px; }
.schedule-extra-addr{ opacity: .8; margin-bottom: 8px; }
.schedule-extra-link{
  display:inline-flex;
  gap:8px;
  align-items:center;
  font-weight: 800;
  text-decoration: none;
}

/* =========================================================
   About two-column + Gallery
========================================================= */
.two-col{
  display:grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 28px;
  align-items: center;
}
.two-col-left h2{ margin: 0 0 10px; }
.two-col-right{ min-width: 0; }

.gallery{
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255,255,255,.55);
  box-shadow: 0 14px 40px rgba(0,0,0,.10);
  backdrop-filter: blur(8px);
}
.gallery-track{
  display:flex;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling: touch;
}
.gallery-track::-webkit-scrollbar{ display:none; }
.gallery-slide{
  min-width:100%;
  scroll-snap-align:start;
  aspect-ratio: 16/10;
  display:flex;
}
.gallery-slide img{ width:100%; height:100%; object-fit: cover; display:block; }

.gallery-btn{
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  width:38px;
  height:38px;
  border-radius: 999px;
  border:0;
  background: rgba(0,0,0,.40);
  color:#fff;
  cursor:pointer;
  display:grid;
  place-items:center;
  z-index:2;
}
.gallery-btn.prev{ left:10px; }
.gallery-btn.next{ right:10px; }

.gallery-dots{
  position:absolute;
  left:0; right:0;
  bottom:10px;
  display:flex;
  gap:8px;
  justify-content:center;
  z-index:2;
}
.gallery-dots .dot{
  width:8px; height:8px;
  border-radius: 999px;
  border:0;
  background: rgba(255,255,255,.55);
  cursor:pointer;
}
.gallery-dots .dot.is-active{ background: rgba(255,255,255,.95); }

@media (max-width: 900px){
  .two-col{ grid-template-columns: 1fr; gap: 16px; }
}

/* =========================================================
   GPX map container
========================================================= */
.gpx-map{
  width: 100%;
  height: 420px;
  border-radius: 14px;
  overflow: hidden;
}
@media (max-width: 700px){ .gpx-map{ height: 320px; } }

/* =========================================================
   FAQ / Accordion
========================================================= */
.faq { display: grid; gap: 12px; margin-top: 14px; }

.faq-item{
  background: var(--card, #fff);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  padding: 0;
  overflow: hidden;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.faq-item:hover{
  border-color: rgba(249,115,22,.5);
  box-shadow: 0 10px 24px rgba(0,0,0,.25);
}
.faq-q{
  list-style: none;
  cursor: pointer;
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-weight: 600;
  color: var(--text, #fff);
}
.faq-q::-webkit-details-marker{ display: none; }
.faq-q span:first-child{ flex: 1; }

.faq-ico{
  font-size: 22px;
  font-weight: 700;
  color: var(--accent, #f97316);
  transition: transform .25s ease;
}
.faq-item[open] .faq-ico{ transform: rotate(180deg); }

.faq-a{
  padding: 0 16px 16px 16px;
  animation: faqFade .25s ease;
}
@keyframes faqFade{
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
@media (prefers-color-scheme: dark){
  .faq-item{ background: rgba(255,255,255,0.03); }
}

/* =========================================================
   Course grid
========================================================= */
.course-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 12px;
}
.course-card{
  display: block;
  text-decoration: none;
  color: inherit;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,.10);
  transition: transform .18s ease, box-shadow .18s ease;
}
.course-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(0,0,0,.14);
}
.course-thumb{
  height: 170px;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
}
.course-body{ padding: 14px 14px 16px; }
.course-title{ font-weight: 900; letter-spacing: -.01em; }
.course-sub{ margin-top: 4px; font-size: .95rem; }
.course-actions{ display: flex; justify-content: flex-start; }

@media (max-width: 820px){
  .course-grid{ grid-template-columns: 1fr; }
  .course-thumb{ height: 190px; }
}

/* =========================================================
   Lightbox
========================================================= */
.lightbox{ position: fixed; inset: 0; z-index: 9999; display: none; }
.lightbox.is-open{ display:block; }

.lightbox-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(6px);
}
.lightbox-panel{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  width: min(1100px, 92vw);
  max-height: 92vh;
  background: rgba(20,22,28,.92);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  box-shadow: 0 22px 80px rgba(0,0,0,.45);
  overflow: hidden;
  padding: 12px;
}
.lightbox-img{
  display: block;
  width: 100%;
  height: auto;
  max-height: calc(92vh - 64px);
  object-fit: contain;
  border-radius: 14px;
  background: rgba(255,255,255,.02);
}
.lightbox-cap{ margin-top: 8px; font-size: .95rem; }
.lightbox-x{
  position: absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  border: 0;
  border-radius: 12px;
  background: rgba(255,255,255,.08);
  color: #fff;
  cursor: pointer;
}
.lightbox-x:hover{ background: rgba(255,255,255,.14); }

/* =========================================================
   Legal page grid
========================================================= */
.legal-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:14px;
}
@media (max-width: 860px){ .legal-grid{ grid-template-columns: 1fr; } }

/* =========================================================
   Cookie UI
========================================================= */
.cookie-fab{
  position: fixed;
  left: 14px;
  bottom: 14px;
  z-index: 80;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(20,24,32,.1);
  backdrop-filter: blur(10px);
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 800;
  cursor: pointer;
  display:none;
}
.cookie-fab:hover{ transform: translateY(-1px); }

.cookie-modal{
  position: fixed;
  inset: 0;
  z-index: 90;
  display: none;
}
.cookie-modal.is-open{ display:block; }

.cookie-backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.55);
}
.cookie-panel{
  position:absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  max-width: 720px;
  margin: 0 auto;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(16,18,24,.96);
  backdrop-filter: blur(12px);
  border-radius: 18px;
  padding: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
}
.cookie-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.cookie-title{
  font-weight: 900;
  font-size: 16px;
  color:lightgrey;
}
.cookie-x{
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: white;
  border-radius: 12px;
  padding: 6px 10px;
  cursor:pointer;
}
.cookie-text{ margin-top:8px; line-height:1.55; color:lightgrey; }

.cookie-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top: 12px;
  align-items:center;
  justify-content:flex-end;
}
@media (max-width: 520px){
  .cookie-panel{ padding: 12px; }
  .cookie-actions{ justify-content:stretch; }
  .cookie-actions .btn{ width:100%; }
}

/* =========================================================
   Scroll-Reveal (final = is-visible)
========================================================= */
[data-reveal]{
  opacity: 0;
  transform: translateY(14px);
  filter: blur(6px);
  transition: opacity .55s ease, transform .55s ease, filter .55s ease;
  will-change: opacity, transform, filter;
}
[data-reveal].is-visible{
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
[data-reveal][data-reveal-delay="1"]{ transition-delay: .06s; }
[data-reveal][data-reveal-delay="2"]{ transition-delay: .12s; }
[data-reveal][data-reveal-delay="3"]{ transition-delay: .18s; }

@media (prefers-reduced-motion: reduce){
  [data-reveal]{
    opacity: 1;
    transform: none;
    filter: none;
    transition: none;
  }
}

/* =========================================================
   Mobile polish patch (safe overrides)
========================================================= */
@media (max-width: 640px){
  :root{ --container-pad-sm: 18px; }
  .container{ padding-left: var(--container-pad-sm); padding-right: var(--container-pad-sm); }
}

@media (max-width: 980px){
  .topbar .langflag{ display: none !important; }
  .topbar .actions a.btn,
  .topbar .actions button.btn{ display: none !important; }
  .topbar .burger{ display: inline-flex !important; }
  .topbar .actions .login,
  .topbar .actions .auth,
  .topbar .actions .account{ display:none !important; }
}

/* Kleine Mobile tweaks, die du hattest */
@media (max-width: 640px){
  .logo-img{ height: 48px; transform: translateY(8px); }
  .brand{ min-width: 0; }
  .topbar{ gap:12px; }
  .nav{ gap:6px; }
  .nav a{ padding:7px 8px; font-size:13px; }
}

/*Höhenprofil Strecke*/
.gpx-elev{
  margin-top: 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
  overflow: hidden;
  padding: 10px;
}

.gpx-elev svg{
  width: 100%;
  height: 150px;
  display:block;
}

.gpx-elev .lbl{
  font-size: 12px;
  opacity: .7;
}

/*Sponsoren grid unterschiedliche größe*/


.sponsor-grid--main{
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
}

.sponsor-card--main{
  min-height: 180px;
  padding: 28px;
}

.sponsor-card--main img{
  max-height: 120px;
}

.sponsor-grid--partner{
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.sponsor-card--partner{
  min-height: 140px;
  padding: 22px;
}

.sponsor-card--partner img{
  max-height: 100px;
}

/* =========================
   Pills (Links & Buttons)
========================= */

.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
  text-decoration: none;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease, transform .15s ease;
}

.pill-link {
  background: var(--bg2);
  color: #111827;
  box-shadow: var(--shadow-glow);
}

.pill-link:hover {
  background: #f3f4f6;
  transform: translateY(-1px);
}

.pill-primary {
  background: var(--grad-accent);
  color: #141826;
  box-shadow: var(--shadow-glow);
}

.pill-primary:hover {
  background: #ea580c;
  transform: translateY(-1px);
}

background: var(--grad-accent);
  border-color: transparent;
  box-shadow: var(--shadow-glow);
  color: #141826;
