@charset "UTF-8";
/***!  /templates/jb_brilliant/css/custom.css  !***/

/* ===========================================
   SPONSOREN-SEITE – FINALE CSS (gekapselt unter .sponsor-wall)
   - Exklusiv: 3 + 2, identische Karten via aspect-ratio
   - Hover nur Desktop (kein Hover auf Mobile)
   - prefers-reduced-motion berücksichtigt
   - generische Klassen werden NICHT global überschrieben
=========================================== */

/* ===========================================
   GRUNDLAYOUT
=========================================== */

.sponsor-intro {
  max-width: 900px;
  margin: 0 auto 2.5rem;
  text-align: center;
  font-size: 1.1rem;
  line-height: 1.6;
  color: #444;
}
.sponsor-intro p { margin: 0; }

.sponsor-wall {
  max-width: 1200px;
  margin: 0 auto 4rem;
  padding: 0 1rem 3rem;
}

.sponsor-wall .sponsor-section {
  margin-bottom: 3rem;
}

.sponsor-wall .sponsor-section__title {
  font-size: 1.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0 0 1.5rem;
  display: inline-block;
  padding-bottom: 0.4rem;
  border-bottom: 3px solid currentColor;
}

/* Titel-Farben */
.sponsor-wall .sponsor-section--toppartner .sponsor-section__title { color: #a0a4ac; }
.sponsor-wall .sponsor-section--basispartner .sponsor-section__title { color: #cd7f32; }
.sponsor-wall .sponsor-section--ausruester   .sponsor-section__title { color: #bdbdbd; }

/* ===========================================
   GRIDS
=========================================== */

.sponsor-wall .sponsor-grid {
  display: grid;
  gap: 1.25rem;
}

.sponsor-wall .sponsor-grid--4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* ===========================================
   EXKLUSIVPARTNER (3 + 2)
   -> Look wie Toppartner (weiß, ruhig), aber größer + roter Akzent
=========================================== */

.sponsor-wall .sponsor-section--exklusiv {
  margin-bottom: 4rem;
}

.sponsor-wall .sponsor-section--exklusiv .sponsor-section__title {
  font-size: 2rem;
  letter-spacing: 0.1em;
  color: #c80000;
  margin-bottom: 2rem;
}

/* Grid: 3 Spalten, zentriert auf großen Screens */
.sponsor-wall .sponsor-grid--exklusiv {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2rem;
  align-items: stretch;
  max-width: 1100px;
  margin: 0 auto;
}

/* Alte Vollbreite-Regeln neutralisieren (falls noch im HTML vorhanden) */
.sponsor-wall .sponsor-grid--exklusiv .sponsor-item:nth-child(1),
.sponsor-wall .sponsor-grid--exklusiv .sponsor-item:nth-child(4),
.sponsor-wall .sponsor-grid--exklusiv .sponsor-item--full {
  grid-column: auto;
}

/* 2. Reihe: Item 4 links, Item 5 rechts (Mitte frei) */
.sponsor-wall .sponsor-grid--exklusiv .sponsor-item:nth-child(4) {
  grid-column: 1 / 2;
  justify-self: center;
}
.sponsor-wall .sponsor-grid--exklusiv .sponsor-item:nth-child(5) {
  grid-column: 3 / 4;
  justify-self: center;
}

/* EXKLUSIV-Karten (NEU): wie Toppartner-Kacheln, nur größer */
.sponsor-wall .sponsor-section--exklusiv .sponsor-item {
  width: 100%;
  max-width: 420px;
  aspect-ratio: 16 / 9;
  height: auto;
  padding: 1.2rem; /* weniger „graue Fläche“ -> wirkt wie Toppartner */

  background: #fff;
  border-radius: 18px;
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-top: 4px solid #c80000;

  /* Schatten bewusst wie normale Kacheln (ruhiger) */
  box-shadow:
    0 6px 16px rgba(0, 0, 0, 0.08),
    0 1px 3px rgba(0, 0, 0, 0.06);

  display: flex;
  align-items: center;
  justify-content: center;

  transition: transform .25s ease, box-shadow .25s ease;
}

.sponsor-wall .sponsor-section--exklusiv .sponsor-item img {
  width: 100%;
  height: 100%;
  max-width: 86%;
  max-height: 86%;
  object-fit: contain;

  filter: grayscale(100%);
  opacity: 0.9;

  transition: transform .25s ease, filter .25s ease, opacity .25s ease;
}

/* Hover nur Desktop */
@media (hover: hover) and (pointer: fine) {
  .sponsor-wall .sponsor-section--exklusiv .sponsor-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.16); /* wie bei Toppartner-Hover */
  }

  .sponsor-wall .sponsor-section--exklusiv .sponsor-item:hover img {
    transform: scale(1.04);
    filter: grayscale(0%);
    opacity: 1;
  }
}

/* ===========================================
   ALLGEMEINE SPONSOR-KACHELN (Top/Ausrüster)
=========================================== */

.sponsor-wall .sponsor-item,
.sponsor-wall .sponsor-cloud-item {
  background: #fff;
  border-radius: 14px;
  padding: 0.75rem;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.05);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 120px;
  border-top: 4px solid transparent;

  opacity: 0;
  transform: scale(0.95);
  animation: sponsorFadeIn 0.6s ease forwards;

  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    border-color 0.25s ease,
    opacity 0.25s ease;
}

/* Farbakzente */
.sponsor-wall .sponsor-section--toppartner .sponsor-item { border-top-color: #a0a4ac; }
.sponsor-wall .sponsor-section--basispartner .sponsor-item { border-top-color: #cd7f32; }
.sponsor-wall .sponsor-section--ausruester   .sponsor-item { border-top-color: #d4d4d4; }

.sponsor-wall .sponsor-item img,
.sponsor-wall .sponsor-cloud-item img {
  max-width: 100%;
  max-height: 80px;
  height: auto;
  object-fit: contain;
  transition: transform 0.3s ease, filter 0.3s ease;
}

/* Hover nur Desktop (für alle normalen Kacheln) */
@media (hover: hover) and (pointer: fine) {
  .sponsor-wall .sponsor-item:hover img,
  .sponsor-wall .sponsor-cloud-item:hover img {
    transform: scale(1.08);
    filter: brightness(1.08);
  }

  .sponsor-wall .sponsor-item:hover,
  .sponsor-wall .sponsor-cloud-item:hover {
    transform: translateY(-6px) scale(1.05);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
    opacity: 0.95;
  }
}

/* ===========================================
   SPONSOR CLOUD BASISPARTNER
=========================================== */

.sponsor-wall .sponsor-section--basispartner .sponsor-cloud {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); /* etwas ruhiger */
  gap: 0.75rem;
}

.sponsor-wall .sponsor-cloud-item {
  border-radius: 10px;
  padding: 0.3rem 0.5rem;
  border-top: 3px solid #cd7f32;
  min-height: 70px;
}

.sponsor-wall .sponsor-cloud-item img {
  max-height: 50px;
}

/* ===========================================
   OPENER-WAVE-EFFEKT
=========================================== */

.sponsor-wall .sponsor-item:nth-child(odd),
.sponsor-wall .sponsor-cloud-item:nth-child(odd) { animation-delay: 0.1s; }

.sponsor-wall .sponsor-item:nth-child(even),
.sponsor-wall .sponsor-cloud-item:nth-child(even) { animation-delay: 0.2s; }

@keyframes sponsorFadeIn {
  to { opacity: 1; transform: scale(1); }
}

/* Reduce Motion */
@media (prefers-reduced-motion: reduce) {
  .sponsor-wall .sponsor-item,
  .sponsor-wall .sponsor-cloud-item {
    animation: none;
    opacity: 1;
    transform: none;
    transition: none;
  }

  .sponsor-wall .sponsor-item img,
  .sponsor-wall .sponsor-cloud-item img {
    transition: none;
  }
}

/* ===========================================
   RESPONSIVE
=========================================== */

@media (max-width: 1024px) {
  .sponsor-wall .sponsor-grid--4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sponsor-wall .sponsor-grid--exklusiv {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: 900px;
  }

  /* Zentrier-Regeln zurücksetzen */
  .sponsor-wall .sponsor-grid--exklusiv .sponsor-item:nth-child(4),
  .sponsor-wall .sponsor-grid--exklusiv .sponsor-item:nth-child(5) {
    grid-column: auto;
    justify-self: stretch;
  }

  .sponsor-wall .sponsor-section--exklusiv .sponsor-item {
    max-width: none;
  }
}

@media (max-width: 768px) {
  .sponsor-wall .sponsor-grid--4 {
    grid-template-columns: 1fr;
  }

  .sponsor-wall .sponsor-grid--exklusiv {
    grid-template-columns: 1fr;
    max-width: 650px;
  }

  /* Mobile: Exklusiv-Logos direkt farbig */
  .sponsor-wall .sponsor-section--exklusiv .sponsor-item img {
    filter: none;
    opacity: 1;
    transform: none;
  }
}

@media (max-width: 480px) {
  .sponsor-wall .sponsor-section__title {
    font-size: 1.25rem;
  }
}

/* ---- FORCE: Exklusivpartner wirklich weiß (gegen Template-Overrides) ---- */
.sponsor-wall .sponsor-section--exklusiv .sponsor-grid--exklusiv a.sponsor-item{
  background-color:#fff !important;
  background:#fff !important;
}

/* Falls ein Overlay/Pseudo-Element grau färbt */
.sponsor-wall .sponsor-section--exklusiv .sponsor-grid--exklusiv a.sponsor-item::before,
.sponsor-wall .sponsor-section--exklusiv .sponsor-grid--exklusiv a.sponsor-item::after{
  background:transparent !important;
  box-shadow:none !important;
  content:none !important;
}
/* ===========================================
   STARTSEITE: Kappelberg-Modal weiter unten
   (überschreibt .kb-dialog { margin: 8vh auto; })
=========================================== */

/* Falls du es nur auf der Startseite willst:
   - Joomla hat oft body.home oder body.site
   - Wenn du keine Startseiten-Klasse hast, entferne die erste Zeile (body.home ...)
*/
body.home #kappelbergModal .kb-dialog,
#kappelbergModal .kb-dialog {
  /* mehr Abstand nach oben -> Modal wandert nach unten */
  margin-top: clamp(14vh, 18vh, 26vh) !important;
}

/* Optional: auf kleineren Screens etwas weniger nach unten */
@media (max-width: 560px) {
  body.home #kappelbergModal .kb-dialog,
  #kappelbergModal .kb-dialog {
    margin-top: clamp(10vh, 14vh, 18vh) !important;
  }
}
/* ===========================================
   NUR STARTSEITE – Modal tiefer & nicht abgeschnitten
=========================================== */

body.home #kappelbergModal {
  display: flex;
  align-items: flex-start !important;
  justify-content: center;
  padding-top: 22vh; /* hier steuerst du die Höhe */
}

body.home #kappelbergModal .kb-dialog {
  margin: 0 !important;
}
/* ===========================================
   STARTSEITE – Modal tief positionieren (sauber & stabil)
=========================================== */

body.home #kappelbergModal {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: center !important;
  padding-top: 30vh !important;   /* HIER steuerst du die Tiefe */
  overflow-y: auto;               /* verhindert Abschneiden */
}

body.home #kappelbergModal .kb-dialog {
  margin: 0 !important;
}
/* ===========================================
   STARTSEITE – Modal tiefer + kein Abschneiden (mit Scroll im Dialog)
=========================================== */

body.home #kappelbergModal{
  display: flex !important;
  justify-content: center !important;
  align-items: flex-start !important;

  /* deutlich tiefer: kombi aus px (Header) + vh (Viewport) */
  padding-top: clamp(240px, 34vh, 420px) !important;

  /* falls es trotzdem zu groß wird: Overlay darf scrollen */
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch;
}

/* alte Positionierung neutralisieren */
body.home #kappelbergModal .kb-dialog{
  margin: 0 !important;

  /* WICHTIG: Dialog darf nicht höher als Viewport -> sonst wird oben abgeschnitten */
  max-height: calc(100vh - 160px) !important;
  overflow: auto !important;
}

/* Mobile: etwas weniger “Header-Anteil”, aber weiterhin tief genug */
@media (max-width: 560px) {
  body.home #kappelbergModal{
    padding-top: clamp(180px, 26vh, 320px) !important;
  }
  body.home #kappelbergModal .kb-dialog{
    max-height: calc(100vh - 120px) !important;
  }
}
/* ===========================================
   STARTSEITE (nur innerhalb .svf-page) – Modal tiefer + kein Abschneiden
=========================================== */

.svf-page #kappelbergModal{
  display: flex !important;
  align-items: flex-start !important;
  justify-content: center !important;

  /* deutlich tiefer (anpassen wenn nötig) */
  padding-top: clamp(320px, 42vh, 520px) !important;

  /* wenn Dialog/Viewport klein: Overlay darf scrollen */
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch;
}

/* Original-Margin aus deinem Inline-CSS neutralisieren */
.svf-page #kappelbergModal .kb-dialog{
  margin: 0 !important;

  /* sorgt dafür, dass nix "oben abgeschnitten" wird */
  max-height: calc(100vh - 120px) !important;
  overflow: auto !important;
}
/* ===========================================
   STARTSEITE (nur .svf-page) – Modal tiefer & nicht abgeschnitten
   Wichtig: überschreibt .kb-modal.is-open { display:block; }
=========================================== */

.svf-page #kappelbergModal.kb-modal.is-open{
  display: flex !important;                 /* <- gewinnt gegen display:block */
  justify-content: center !important;
  align-items: flex-start !important;

  /* tiefer positionieren */
  padding-top: clamp(360px, 46vh, 620px) !important;
  padding-bottom: 6vh !important;

  /* falls Viewport klein: Overlay darf scrollen */
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch;
}

/* Dialog darf nicht "aus dem Viewport ragen" */
.svf-page #kappelbergModal .kb-dialog{
  margin: 0 !important;
  max-height: calc(100dvh - 120px) !important;  /* verhindert Abschneiden */
  overflow: auto !important;                     /* scrollt dann im Dialog */
}
/* ===========================================
   STARTSEITE (.svf-page) – Modal nicht verdeckt + tiefer + nie abgeschnitten
=========================================== */

/* Modal-Overlay IMMER über Header/Template */
.svf-page #kappelbergModal.kb-modal.is-open{
  z-index: 2147483647 !important; /* höher geht’s praktisch nicht */
}

/* Dialog selbst fix positionieren (unabhängig von margin/flow) */
.svf-page #kappelbergModal.kb-modal.is-open .kb-dialog{
  position: fixed !important;
  left: 50% !important;
  transform: translateX(-50%) !important;

  /* tiefer setzen (hier steuern!) */
  top: clamp(220px, 32vh, 520px) !important;

  margin: 0 !important;

  /* niemals “aus dem Viewport” */
  max-height: calc(100dvh - 40px) !important;
  overflow: auto !important;

  width: min(640px, calc(100vw - 24px)) !important;
}

