:root {
      --yellow: #f5a400;
      --orange: #ef9500;
      --black: #111;
      --ink: #202020;
      --muted: #676767;
      --line: #dedbd5;
      --paper: #f6f3ed;
      --white: #fff;
      --max: 1180px;
      --radius: 8px;
      --font-head: "Barlow Condensed", Arial, Helvetica, sans-serif;
      --font-body: "Manrope", Arial, Helvetica, sans-serif;
      font-family: var(--font-body);
    }

    * { box-sizing: border-box; }

    html { scroll-behavior: smooth; }

    body {
      margin: 0;
      color: var(--ink);
      background: var(--white);
      font-size: 16px;
      line-height: 1.55;
      font-family: var(--font-body);
    }

    main {
      background:
        linear-gradient(180deg, #1b1b1b 0, #24221d 84px, #efe2c2 210px, #f4f1ea 430px, var(--paper) 100%);
    }

    a { color: inherit; text-decoration: none; }
    img { display: block; max-width: 100%; }

    .topbar {
      background: #1a1a1a;
      color: rgba(255,255,255,.86);
      font-size: 13px;
    }

    .topbar-inner {
      width: min(var(--max), calc(100% - 32px));
      min-height: 34px;
      margin: 0 auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px;
      flex-wrap: wrap;
    }

    .topbar a,
    .topbar strong {
      color: var(--yellow);
      font-weight: 500;
    }

    .topbar-links {
      display: flex;
      align-items: center;
      gap: 14px;
      flex-wrap: wrap;
    }

.topbar-inner .text {
	font-size: 12px;
	color: rgba(255,255,255,.56);
	font-weight: 500;	
}

    .social-icon-link {
      display: inline-grid;
      place-items: center;
      width: 28px;
      height: 28px;
      border-radius: 50%;
      background: var(--yellow);
      color: var(--black) !important;
      font-weight: 900;
      font-size: 13px;
      line-height: 1;
    }
    .site-head {
      background: rgba(255,255,255,.98);
      border-bottom: 1px solid #ddd;
      position: sticky;
      top: 0;
      z-index: 30;
    }

    .nav {
      width: min(var(--max), calc(100% - 32px));
      min-height: 76px;
      margin: 0 auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }

    .brand {
      display: flex;
      align-items: center;
      gap: 12px;
      min-width: 245px;
    }

    .brand img {
      width: 56px;
      height: 56px;
      object-fit: contain;
    }

    .brand span {
      display: grid;
      line-height: 1.1;
    }

    .brand strong {
      color: var(--black);
      font-size: 20px;
    }

    .brand small {
      color: #4e4e4e;
      font-size: 13px;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
    }

    .brand small.brand-subline {
      text-transform: none;
      letter-spacing: .05em;
    }

    .menu {
      display: flex;
      justify-content: flex-end;
      align-items: center;
      flex-wrap: wrap;
      gap: 4px;
    }

    .menu a {
      padding: 11px 12px;
      border-radius: 6px;
      color: var(--black);
      font-size: 14px;
      font-weight: 900;
      letter-spacing: .025em;
      text-transform: uppercase;
    }

    .menu a:hover,
    .menu a.cta {
      background: var(--yellow);
    }

    .menu a.search-link {
      width: 44px;
      min-height: 44px;
      display: inline-grid;
      place-items: center;
      padding: 0;
      font-size: 27px;
      line-height: 1;
      font-weight: 800;
    }

    .hero {
      position: relative;
      overflow: hidden;
      isolation: isolate;
      background-color: var(--black);
      background-size: cover;
      background-position: center;
      border-top: 8px solid var(--yellow);
      border-bottom: 8px solid var(--yellow);
      color: var(--white);
      height: calc(100svh - 148px);
      min-height: 560px;
      display: grid;
      grid-template-rows: minmax(0, 1fr) auto;
      align-content: center;
    }

    .hero::before {
      content: "";
      position: absolute;
      inset: 0;
      z-index: 0;
      pointer-events: none;
      background:
        linear-gradient(180deg, rgba(0,0,0,.18) 0%, rgba(0,0,0,.40) 45%, rgba(0,0,0,.82) 100%),
        linear-gradient(90deg, rgba(0,0,0,.70) 0%, rgba(0,0,0,.25) 48%, rgba(0,0,0,.70) 100%),
        rgba(0,0,0,.08);
    }

    .hero::after {
      content: "";
      position: absolute;
      inset: 0;
      z-index: 0;
      pointer-events: none;
      box-shadow: inset 0 0 120px rgba(0,0,0,.48);
    }

    .hero-media {
      position: relative;
      z-index: 1;
      width: min(var(--max), calc(100% - 32px));
      margin: 0 auto;
      padding: clamp(14px, 2.4vh, 28px) 0 0;
      align-self: center;
    }

    .hero-media img {
      width: 100%;
      max-height: clamp(260px, 45svh, 430px);
      object-fit: contain;
      object-position: center;
      filter: drop-shadow(0 18px 28px rgba(0,0,0,.24));
    }

    .hero-bar {
      position: relative;
      z-index: 1;
      width: min(var(--max), calc(100% - 32px));
      height: 8px;
      margin: 0 auto;
      background: var(--yellow);
    }

    .hero-content {
      position: relative;
      z-index: 1;
      width: min(var(--max), calc(100% - 32px));
      margin: 0 auto;
      padding: clamp(18px, 3vh, 34px) 0 clamp(22px, 4vh, 44px);
      display: block;
      max-width: min(var(--max), calc(100% - 32px));
    }

    .eyebrow {
      margin: 0 0 9px;
      color: #b96f00;
      font-size: 14px;
      font-weight: 900;
      letter-spacing: .12em;
      text-transform: uppercase;
    }

    h1,
    h2,
    h3 {
      margin: 0;
      color: var(--black);
      line-height: 1.12;
      letter-spacing: 0;
      font-family: var(--font-head);
    }

    h1 {
      font-size: clamp(36px, 5.8vw, 66px);
      font-weight: 800;
      text-transform: uppercase;
    }

    .hero h1 {
      color: var(--white);
      text-shadow: 0 14px 30px rgba(0,0,0,.55);
    }

    .hero .eyebrow {
      color: var(--yellow);
    }

    .hero .lead {
      color: rgba(255,255,255,.86);
    }

    h2 {
      font-size: clamp(26px, 3.2vw, 40px);
      font-weight: 800;
      text-transform: uppercase;
    }

    h3 {
      font-size: 22px;
      font-weight: 700;
    }

      p { margin: 11px 0 0; }

    .lead {
      max-width: 760px;
      color: #404040;
      font-size: 18px;
    }

    .office-card {
      border-left: 7px solid var(--yellow);
      background: rgba(255,255,255,.90);
      box-shadow: 0 14px 34px rgba(0,0,0,.10);
      padding: 24px;
    }

    .button-row {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-top: 22px;
    }

    .button {
      display: inline-flex;
      min-height: 44px;
      align-items: center;
      justify-content: center;
      padding: 0 16px;
      border: 2px solid var(--black);
      border-radius: 6px;
      background: var(--black);
      color: var(--white);
      font-size: 13px;
      font-weight: 900;
      letter-spacing: .04em;
      text-transform: uppercase;
    }

    .button.light {
      border-color: var(--yellow);
      background: var(--yellow);
      color: var(--black);
    }

    .button.outline {
      background: var(--white);
      color: var(--black);
    }

    .hero .button.hero-cta {
      border-color: var(--yellow);
      background: var(--yellow);
      color: var(--black);
      box-shadow: 0 12px 26px rgba(0,0,0,.26);
    }

    .hero-tiles {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 12px;
      margin-top: 24px;
    }

    .hero-tile {
      min-height: 108px;
      display: grid;
      align-content: center;
      gap: 4px;
      padding: 18px;
      border-radius: var(--radius);
      background: var(--white);
      border: 1px solid var(--line);
      border-top: 5px solid var(--yellow);
      box-shadow: 0 10px 22px rgba(0,0,0,.06);
    }

    .hero-tile strong {
      color: var(--black);
      font-family: var(--font-head);
      font-size: 23px;
      line-height: 1;
      text-transform: uppercase;
    }

    .hero-tile span {
      color: var(--muted);
      font-size: 14px;
    }

    .section { padding: 70px 0; }
    .section.soft { background: transparent; border-top: 1px solid rgba(0,0,0,.08); border-bottom: 1px solid rgba(0,0,0,.08); }

    .wrap {
      width: min(var(--max), calc(100% - 32px));
      margin: 0 auto;
    }

    .section-title {
      margin-bottom: 30px;
      display: flex;
      justify-content: space-between;
      align-items: end;
      gap: 26px;
    }

    .section-title.compact h2 {
      font-size: clamp(28px, 3.4vw, 44px);
      max-width: 720px;
    }

    .section-title p {
      max-width: 620px;
      color: var(--muted);
    }

    .dark {
      position: relative;
      background: transparent;
      color: var(--white);
      overflow: visible;
    }

    .dark::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 18% 20%, rgba(245,164,0,.24), transparent 30%),
        radial-gradient(circle at 90% 80%, rgba(245,164,0,.16), transparent 34%);
      pointer-events: none;
    }

    .dark .wrap { position: relative; z-index: 1; }
    .dark h2, .dark h3, .dark p { color: var(--white); }
    .dark .eyebrow { color: var(--yellow); }

    #news {
      width: 100%;
      margin: 0;
      padding: clamp(44px, 5vw, 66px) 0 clamp(44px, 5vw, 66px);
      background: transparent;
    }

    #news .wrap {
      width: min(var(--max), calc(100% - 32px));
      min-height: 0;
      padding: clamp(30px, 3.8vw, 46px) clamp(22px, 3.6vw, 42px);
      border-radius: var(--radius);
      overflow: hidden;
      background:
        linear-gradient(90deg, rgba(0,0,0,.90), rgba(0,0,0,.78)),
        url("/bilder/1775812628-1781427421-bg.webp") center center / cover no-repeat;
    }

    #news .section-title.compact {
      max-width: 960px;
      margin: 0 auto 22px;
    }

    .slider-shell {
      position: relative;
      padding: 0 54px;
    }

    .slider-track {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
    }

    .slider-arrow {
      position: absolute;
      top: 50%;
      width: 40px;
      height: 56px;
      transform: translateY(-50%);
      border: 0;
      background: transparent;
      color: rgba(255,255,255,.74);
      font-size: 58px;
      line-height: 1;
      cursor: default;
    }

    .slider-arrow.left { left: 0; }
    .slider-arrow.right { right: 0; }

    .news-card {
      background: rgba(255,255,255,.96);
      border: 1px solid rgba(255,255,255,.22);
      border-radius: 8px;
      box-shadow: 0 12px 26px rgba(0,0,0,.32);
      overflow: hidden;
      color: var(--black);
    }

    .news-image {
      min-height: 265px;
      margin: 18px 18px 0;
      border-radius: 6px;
      background:
        linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.55)),
        url("/bilder/1775812628/1775812628-1779923456-image002-header.jpg") center center / cover no-repeat;
    }

    .news-image.alt {
      background:
        linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.58)),
      url("/bilder/1775812628-1781427421-bg.webp") center center / cover no-repeat;
    }

    .news-card-body {
      padding: 16px 24px 24px;
      text-align: center;
    }

    .news-card h3 {
      font-size: 23px;
      line-height: 1.18;
      color: var(--black);
    }

    .news-card p {
      color: #444;
      margin-top: 8px;
    }

    .news-card a {
      display: inline-block;
      margin-top: 20px;
      color: #d71920;
      font-size: 18px;
    }

    .department-hero {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 20px;
      margin-bottom: 26px;
    }

    .sport-feature {
      position: relative;
      min-height: 250px;
      display: grid;
      align-content: end;
      padding: 24px;
      overflow: hidden;
      border-radius: var(--radius);
      background:
        linear-gradient(180deg, rgba(0,0,0,.38), rgba(0,0,0,.90)),
      url("/bilder/1775812628-1781428039-svh-hero_bild_sw.webp") var(--pos, center) center / 1040px auto no-repeat;
      box-shadow: inset 0 0 0 1px rgba(255,255,255,.15);
    }

    .sport-feature::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, rgba(0,0,0,.42), rgba(0,0,0,.12)),
        rgba(0,0,0,.30);
      pointer-events: none;
    }

    .sport-feature::after {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      height: 6px;
      background: var(--yellow);
    }

    .sport-feature h3,
    .sport-feature p {
      position: relative;
      z-index: 1;
      color: var(--white);
      text-shadow: 0 2px 8px rgba(0,0,0,.70);
    }

    .sport-feature h3 {
      font-size: 22px;
    }

    .sport-feature p {
      font-size: 15px;
    }

    .department-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 14px;
      border: 0;
      background: transparent;
    }

    .department-grid a {
      position: relative;
      min-height: 174px;
      display: grid;
      grid-template-rows: 1fr auto;
      justify-items: center;
      align-content: center;
      gap: 14px;
      padding: 22px 18px;
      background: rgba(255,255,255,.94);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: 0 10px 22px rgba(0,0,0,.045);
      overflow: hidden;
      text-align: center;
      transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background-color .16s ease;
    }

    .department-grid a::after {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      height: 4px;
      background: var(--yellow);
    }

    .department-grid a:hover {
      background: var(--white);
      border-color: var(--yellow);
      transform: translateY(-2px);
      box-shadow: 0 16px 30px rgba(0,0,0,.10);
    }

    .department-grid a:hover::after {
      background: var(--orange);
    }

    .department-logo {
      width: 104px;
      height: 104px;
      display: grid;
      place-items: center;
    }

    .department-logo img {
      width: 100%;
      height: 100%;
      object-fit: contain;
    }

    .department-grid strong {
      color: var(--black);
      font-family: var(--font-head);
      font-size: 22px;
      font-weight: 800;
      letter-spacing: .02em;
      line-height: 1;
      text-transform: uppercase;
    }

    .department-grid span {
      color: var(--muted);
      font-size: 14px;
      font-weight: 500;
    }

    .info-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 22px;
    }

    .info {
      overflow: hidden;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: var(--white);
    }

    .info-image {
      min-height: 205px;
      background:
        linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.64)),
        var(--image, url("/bilder/1775812628-1781428039-svh-hero_bild_sw.webp")) var(--pos, center) / cover no-repeat;
    }

    .info-video {
      width: 100%;
      height: 205px;
      display: block;
      object-fit: cover;
      background: var(--black);
    }

    .info-body {
      padding: 22px;
    }

    .info-body p { color: var(--muted); }

    .membership {
      background:
        linear-gradient(90deg, rgba(0,0,0,.94), rgba(0,0,0,.80)),
        url("/bilder/1775812628/1775812628-1779923456-image002-header.jpg") center center / cover no-repeat;
      color: var(--white);
      padding: 64px 0;
    }

    .membership .wrap {
      display: grid;
      grid-template-columns: minmax(0, 1fr) 360px;
      gap: 42px;
      align-items: center;
    }

    .membership h2,
    .membership p {
      color: var(--white);
    }

    .member-box {
      border-left: 7px solid var(--yellow);
      background: rgba(255,255,255,.10);
      padding: 24px;
    }

    .service-list {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 1px;
      border: 1px solid var(--line);
      background: var(--line);
    }

    .service-list article {
      background: var(--white);
      min-height: 170px;
      padding: 24px;
    }

    .service-list p { color: var(--muted); }

    .social-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 22px;
    }

    .social-card {
      min-height: 260px;
      display: grid;
      align-content: end;
      padding: 26px;
      border-radius: var(--radius);
      overflow: hidden;
      background:
        linear-gradient(180deg, rgba(0,0,0,.20), rgba(0,0,0,.84)),
        url("/bilder/1775812628/1775812628-1779923456-image002-header.jpg") center center / cover no-repeat;
      color: var(--white);
    }

    .social-card.alt {
      background:
        linear-gradient(180deg, rgba(0,0,0,.20), rgba(0,0,0,.84)),
      url("/bilder/1775812628-1781427421-bg.webp") center center / cover no-repeat;
    }

    .social-card h3,
    .social-card p {
      color: var(--white);
    }

    .sponsor-strip {
      background: var(--paper);
      border-top: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      padding: 42px 0;
    }

    .sponsor-row {
      display: grid;
      grid-template-columns: repeat(5, minmax(0, 1fr));
      gap: 12px;
    }

    .sponsor-box {
      min-height: 86px;
      display: grid;
      place-items: center;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: var(--white);
      color: var(--muted);
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: .04em;
    }

    .project {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 1px;
      border: 1px solid var(--line);
      background: var(--line);
    }

    .project div {
      min-height: 140px;
      background: var(--white);
      padding: 22px;
    }

    .project span {
      display: block;
      color: #b96f00;
      font-size: 13px;
      font-weight: 900;
      letter-spacing: .08em;
      text-transform: uppercase;
      margin-bottom: 7px;
    }

    .project p {
      color: var(--muted);
      font-size: 14px;
    }

    .footer {
      background: #111;
      border-top: 6px solid var(--yellow);
      color: var(--white);
      padding: 44px 0;
    }

    .footer-grid {
      display: grid;
      grid-template-columns: 1.35fr .75fr .85fr .85fr;
      gap: 28px;
    }

    .footer h3,
    .footer p,
    .footer li {
      color: var(--white);
    }

    .footer p,
    .footer li {
      opacity: .82;
    }

    .footer ul {
      list-style: none;
      padding: 0;
      margin: 12px 0 0;
      display: grid;
      gap: 5px;
    }

    @media (max-width: 960px) {
      .nav {
        display: grid;
        padding: 12px 0;
      }

      .hero {
        height: auto;
        min-height: calc(100svh - 170px);
      }

      .hero-media img {
        max-height: clamp(220px, 38svh, 360px);
      }

      .menu {
        justify-content: flex-start;
      }

      .hero-content,
      .slider-track,
      .department-hero,
      .department-grid,
      .info-grid,
      .membership .wrap,
      .hero-tiles,
      .social-grid,
      .sponsor-row,
      .service-list,
      .project,
      .footer-grid {
        grid-template-columns: 1fr;
      }

      .department-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .section-title {
        display: grid;
        align-items: start;
      }

      .slider-shell {
        padding: 0;
      }

      .slider-arrow {
        display: none;
      }
    }

    @media (max-width: 620px) {
      .brand { min-width: 0; }

      .menu a {
        padding: 8px 7px;
        font-size: 12px;
      }

      .hero-media img {
        max-height: clamp(180px, 32svh, 280px);
      }

      .hero-content {
        padding-top: 18px;
      }

      .department-grid {
        grid-template-columns: 1fr;
      }

      .department-grid a {
        min-height: 150px;
      }

      .department-logo {
        width: 86px;
        height: 86px;
      }

      .news-image {
        min-height: 195px;
      }
    }

/* --- Template extension --- */

:root {
      --yellow: #f5a400;
      --orange: #ef9500;
      --black: #111;
      --ink: #202020;
      --muted: #676767;
      --line: #dedbd5;
      --paper: #f6f3ed;
      --white: #fff;
      --max: 1180px;
      --radius: 8px;
      --font-head: "Barlow Condensed", Arial, Helvetica, sans-serif;
      --font-body: "Manrope", Arial, Helvetica, sans-serif;
      font-family: var(--font-body);
    }

    * { box-sizing: border-box; }
    body { margin: 0; color: var(--ink); background: var(--white); font-family: var(--font-body); font-size: 16px; line-height: 1.6; }
    a { color: inherit; text-decoration: none; }
    img { display: block; max-width: 100%; }

    .preview { background: var(--black); color: var(--white); padding: 8px 16px; text-align: center; font-size: 13px; }
    .preview strong { color: var(--yellow); }

    .topbar { background: #1a1a1a; color: rgba(255,255,255,.86); font-size: 13px; }
    .topbar-inner { width: min(var(--max), calc(100% - 32px)); min-height: 34px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
    .topbar a, .topbar strong { color: var(--yellow); font-weight: 500; }
    .topbar-links { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
    .social-icon-link { display: inline-grid; place-items: center; width: 28px; height: 28px; border-radius: 50%; background: var(--yellow); color: var(--black) !important; font-weight: 900; font-size: 13px; line-height: 1; }
    .site-head { background: rgba(255,255,255,.98); border-bottom: 1px solid #ddd; position: sticky; top: 0; z-index: 30; }
    .nav { width: min(var(--max), calc(100% - 32px)); min-height: 76px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
    .brand { display: flex; align-items: center; gap: 12px; min-width: 245px; }
    .brand img { width: 56px; height: 56px; object-fit: contain; }
    .brand span { display: grid; line-height: 1.1; }
    .brand strong { color: var(--black); font-size: 20px; }
    .brand small { color: #4e4e4e; font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
    .brand small.brand-subline { text-transform: none; letter-spacing: .05em; }
    .menu { display: flex; justify-content: flex-end; align-items: center; flex-wrap: wrap; gap: 4px; }
    .menu a { padding: 11px 12px; border-radius: 6px; color: var(--black); font-size: 14px; font-weight: 900; letter-spacing: .025em; text-transform: uppercase; }
    .menu a:hover, .menu a.cta { background: var(--yellow); }
    .menu a.search-link { width: 44px; min-height: 44px; display: inline-grid; place-items: center; padding: 0; font-size: 27px; line-height: 1; font-weight: 800; }

    .page-hero {
      background:
        linear-gradient(90deg, rgba(0,0,0,.90), rgba(0,0,0,.72)),
      url("/bilder/1775812628-1781427421-bg.webp") center center / cover no-repeat;
      color: var(--white);
      border-bottom: 6px solid var(--yellow);
    }

    .page-hero-inner {
      width: min(var(--max), calc(100% - 32px));
      margin: 0 auto;
      padding: 62px 0 58px;
    }

    .breadcrumb {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      align-items: center;
      margin-bottom: 18px;
      color: rgba(255,255,255,.78);
      font-size: 14px;
      font-weight: 700;
    }

    .breadcrumb a { color: var(--yellow); }
    .breadcrumb span { color: rgba(255,255,255,.55); }

    h1, h2, h3 {
      margin: 0;
      color: var(--black);
      font-family: var(--font-head);
      line-height: 1.08;
      letter-spacing: 0;
    }

    .page-hero h1 {
      color: var(--white);
      font-size: clamp(38px, 5vw, 64px);
      font-weight: 800;
      text-transform: uppercase;
    }

    .page-hero p {
      max-width: 720px;
      margin: 12px 0 0;
      color: rgba(255,255,255,.82);
      font-size: 18px;
    }

    .main {
      width: min(var(--max), calc(100% - 32px));
      margin: 0 auto;
      padding: 58px 0;
      display: grid;
      grid-template-columns: minmax(0, 1fr) 320px;
      gap: 38px;
      align-items: start;
    }

    .content {
      min-height: 440px;
      background: var(--white);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 34px;
    }

    .content img {
      max-width: 100%;
      height: auto !important;
      object-fit: contain;
    }

    .content img[data-svh-lightbox] {
      cursor: zoom-in;
    }

    .svh-lightbox {
      position: fixed;
      inset: 0;
      z-index: 9999;
      display: none;
      align-items: center;
      justify-content: center;
      padding: 24px;
      background: rgba(0,0,0,.86);
    }

    .svh-lightbox.is-open {
      display: flex;
    }

    .svh-lightbox img {
      width: auto;
      height: auto;
      max-width: 92vw;
      max-height: 88vh;
      object-fit: contain;
      box-shadow: 0 24px 70px rgba(0,0,0,.42);
    }

    .svh-lightbox-close {
      position: fixed;
      top: 18px;
      right: 22px;
      border: 0;
      background: transparent;
      color: #fff;
      font-size: 34px;
      line-height: 1;
      cursor: pointer;
    }

    .content h2 {
      font-size: 34px;
      text-transform: uppercase;
      margin-bottom: 12px;
    }

    .content-placeholder {
      margin-top: 24px;
      border: 2px dashed #cfcac2;
      border-radius: var(--radius);
      background: var(--paper);
      padding: 34px;
      color: var(--muted);
      font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
      font-size: 18px;
      text-align: center;
    }

    .sidebar {
      display: grid;
      gap: 18px;
    }

    .side-card {
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: var(--white);
      overflow: hidden;
    }

    .side-card h3 {
      background: var(--black);
      color: var(--white);
      font-size: 24px;
      text-transform: uppercase;
      padding: 16px 18px;
      border-bottom: 4px solid var(--yellow);
    }

    .side-card-body {
      padding: 18px;
    }

    .side-card-body p {
      margin: 0;
      color: var(--muted);
    }

    .side-list {
      list-style: none;
      padding: 0;
      margin: 0;
      display: grid;
      gap: 1px;
      background: var(--line);
    }

    .side-list a {
      display: block;
      background: var(--white);
      padding: 13px 18px;
      font-weight: 700;
    }

    .side-list a:hover {
      background: var(--yellow);
      color: var(--black);
    }

    .sponsors {
      background: var(--paper);
      border-top: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      padding: 36px 0;
    }

    .sponsors-inner {
      width: min(var(--max), calc(100% - 32px));
      margin: 0 auto;
    }

    .sponsors-head {
      display: flex;
      justify-content: space-between;
      align-items: end;
      gap: 22px;
      margin-bottom: 18px;
    }

    .sponsors h2 {
      font-size: 30px;
      text-transform: uppercase;
    }

    .sponsor-row {
      display: grid;
      grid-template-columns: repeat(5, minmax(0, 1fr));
      gap: 12px;
    }

    .sponsor {
      min-height: 86px;
      display: grid;
      place-items: center;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: var(--white);
      color: var(--muted);
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: .04em;
    }

    .footer {
      background: #111;
      border-top: 6px solid var(--yellow);
      color: var(--white);
      padding: 44px 0;
    }

    .footer-grid {
      width: min(var(--max), calc(100% - 32px));
      margin: 0 auto;
      display: grid;
      grid-template-columns: 1.35fr .75fr .85fr .85fr;
      gap: 28px;
    }

    .footer h3, .footer p, .footer li { color: var(--white); }
    .footer p, .footer li { opacity: .82; }
    .footer ul { list-style: none; padding: 0; margin: 12px 0 0; display: grid; gap: 5px; }

    @media (max-width: 920px) {
      .nav { display: grid; padding: 12px 0; }
      .menu { justify-content: flex-start; }
      .main, .sponsor-row, .footer-grid { grid-template-columns: 1fr; }
      .sponsors-head { display: grid; align-items: start; }
    }

    @media (max-width: 620px) {
      .brand { min-width: 0; }
      .menu a { padding: 8px 7px; font-size: 12px; }
      .page-hero-inner { padding: 42px 0; }
      .content { padding: 24px; }
    }


/* --- SVH Footer 2026-06-15 --- */
.footer a {
  color: var(--yellow);
  text-decoration: none;
  transition: color .18s ease;
}

.footer a:hover,
.footer a:focus {
  color: var(--white);
}

.footer-logo {
  width: 72px;
  height: 72px;
  object-fit: contain;
  margin-bottom: 14px;
}

.footer-address p {
  margin-top: 12px;
}

.footer-meta {
  margin-top: 18px;
  color: rgba(255,255,255,.68);
  font-size: 13px;
}

.footer-bottom {
  margin-top: 30px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.18);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 18px;
  color: rgba(255,255,255,.72);
  font-size: 14px;
}

.footer-bottom span:nth-child(2) {
  text-align: center;
}

.footer-bottom span:nth-child(3) {
  text-align: right;
}

@media (max-width: 760px) {
  .footer-bottom {
    grid-template-columns: 1fr;
  }

  .footer-bottom span,
  .footer-bottom span:nth-child(2),
  .footer-bottom span:nth-child(3) {
    text-align: left;
  }
}

/* --- SVH CMS update 2026-06-14 --- */
.sponsor-row-real {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.sponsor-slider-viewport {
  position: relative;
  overflow: hidden;
  width: 100%;
  padding: 4px 0;
}

.sponsor-slider-viewport::before,
.sponsor-slider-viewport::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 2;
  width: 70px;
  pointer-events: none;
}

.sponsor-slider-viewport::before {
  left: 0;
  background: linear-gradient(90deg, var(--paper), rgba(246,243,237,0));
}

.sponsor-slider-viewport::after {
  right: 0;
  background: linear-gradient(270deg, var(--paper), rgba(246,243,237,0));
}

.sponsor-row-real[data-sponsor-slider] {
  display: flex;
  width: max-content;
  gap: 14px;
  animation: svhSponsorMarquee 48s linear infinite;
  will-change: transform;
}

.sponsor-row-real[data-sponsor-slider]:hover {
  animation-play-state: paused;
}

.sponsor-row-real[data-sponsor-slider] .sponsor-logo {
  flex: 0 0 170px;
}

@keyframes svhSponsorMarquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.sponsor-logo {
  min-height: 104px;
  padding: 18px;
  background: var(--white);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

a.sponsor-logo:hover {
  transform: translateY(-2px);
  border-color: rgba(239, 149, 0, .55);
  box-shadow: 0 12px 30px rgba(0, 0, 0, .09);
}

.sponsor-logo img {
  width: 100%;
  max-width: 150px;
  max-height: 70px;
  object-fit: contain;
}

.social-timeline-grid {
  align-items: stretch;
}

.social-timeline {
  min-height: 360px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.social-timeline h3 {
  display: flex;
  align-items: center;
  gap: 10px;
}

.social-embed-placeholder {
  flex: 1;
  min-height: 240px;
  display: grid;
  place-items: center;
  border: 1px dashed rgba(255, 255, 255, .4);
  border-radius: var(--radius);
  padding: 18px;
  color: rgba(255, 255, 255, .78);
  background: rgba(0, 0, 0, .18);
  font-weight: 800;
  letter-spacing: .04em;
  text-align: center;
}

/* --- Template extension --- */

:root {
      --yellow: #f5a400;
      --orange: #ef9500;
      --black: #111;
      --ink: #202020;
      --muted: #676767;
      --line: #dedbd5;
      --paper: #f6f3ed;
      --white: #fff;
      --max: 1180px;
      --radius: 8px;
      --font-head: "Barlow Condensed", Arial, Helvetica, sans-serif;
      --font-body: "Manrope", Arial, Helvetica, sans-serif;
      font-family: var(--font-body);
    }

    * { box-sizing: border-box; }
    body { margin: 0; color: var(--ink); background: var(--white); font-family: var(--font-body); font-size: 16px; line-height: 1.6; }
    a { color: inherit; text-decoration: none; }
    img { display: block; max-width: 100%; }

    .preview { background: var(--black); color: var(--white); padding: 8px 16px; text-align: center; font-size: 13px; }
    .preview strong { color: var(--yellow); }

    .topbar { background: #1a1a1a; color: rgba(255,255,255,.86); font-size: 13px; }
    .topbar-inner { width: min(var(--max), calc(100% - 32px)); min-height: 34px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
    .topbar a, .topbar strong { color: var(--yellow); font-weight: 500; }
    .topbar-links { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
    .social-icon-link { display: inline-grid; place-items: center; width: 28px; height: 28px; border-radius: 50%; background: var(--yellow); color: var(--black) !important; font-weight: 900; font-size: 13px; line-height: 1; }
    .site-head { background: rgba(255,255,255,.98); border-bottom: 1px solid #ddd; position: sticky; top: 0; z-index: 30; }
    .nav { width: min(var(--max), calc(100% - 32px)); min-height: 76px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
    .brand { display: flex; align-items: center; gap: 12px; min-width: 245px; }
    .brand img { width: 56px; height: 56px; object-fit: contain; }
    .brand span { display: grid; line-height: 1.1; }
    .brand strong { color: var(--black); font-size: 20px; }
    .brand small { color: #4e4e4e; font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
    .brand small.brand-subline { text-transform: none; letter-spacing: .05em; }
    .menu { display: flex; justify-content: flex-end; align-items: center; flex-wrap: wrap; gap: 4px; }
    .menu a { padding: 11px 12px; border-radius: 6px; color: var(--black); font-size: 14px; font-weight: 900; letter-spacing: .025em; text-transform: uppercase; }
    .menu a:hover, .menu a.cta { background: var(--yellow); }
    .menu a.search-link { width: 44px; min-height: 44px; display: inline-grid; place-items: center; padding: 0; font-size: 27px; line-height: 1; font-weight: 800; }

    .page-hero {
      background:
        linear-gradient(90deg, rgba(0,0,0,.90), rgba(0,0,0,.72)),
      url("/bilder/1775812628-1781427421-bg.webp") center center / cover no-repeat;
      color: var(--white);
      border-bottom: 6px solid var(--yellow);
    }

    .page-hero-inner {
      width: min(var(--max), calc(100% - 32px));
      margin: 0 auto;
      padding: 62px 0 58px;
    }

    .breadcrumb {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      align-items: center;
      margin-bottom: 18px;
      color: rgba(255,255,255,.78);
      font-size: 14px;
      font-weight: 700;
    }

    .breadcrumb a { color: var(--yellow); }
    .breadcrumb span { color: rgba(255,255,255,.55); }

    h1, h2, h3 {
      margin: 0;
      color: var(--black);
      font-family: var(--font-head);
      line-height: 1.08;
      letter-spacing: 0;
    }

    .page-hero h1 {
      color: var(--white);
      font-size: clamp(38px, 5vw, 64px);
      font-weight: 800;
      text-transform: uppercase;
    }

    .page-hero p {
      max-width: 720px;
      margin: 12px 0 0;
      color: rgba(255,255,255,.82);
      font-size: 18px;
    }

    .main {
      width: min(var(--max), calc(100% - 32px));
      margin: 0 auto;
      padding: 58px 0;
      display: grid;
      grid-template-columns: minmax(0, 1fr) 320px;
      gap: 38px;
      align-items: start;
    }

    .content {
      min-height: 440px;
      background: var(--white);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 34px;
    }

    .content h2 {
      font-size: 34px;
      text-transform: uppercase;
      margin-bottom: 12px;
    }

    .content-placeholder {
      margin-top: 24px;
      border: 2px dashed #cfcac2;
      border-radius: var(--radius);
      background: var(--paper);
      padding: 34px;
      color: var(--muted);
      font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
      font-size: 18px;
      text-align: center;
    }

    .sidebar {
      display: grid;
      gap: 18px;
    }

    .side-card {
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: var(--white);
      overflow: hidden;
    }

    .side-card h3 {
      background: var(--black);
      color: var(--white);
      font-size: 24px;
      text-transform: uppercase;
      padding: 16px 18px;
      border-bottom: 4px solid var(--yellow);
    }

    .side-card-body {
      padding: 18px;
    }

    .side-card-body p {
      margin: 0;
      color: var(--muted);
    }

    .side-list {
      list-style: none;
      padding: 0;
      margin: 0;
      display: grid;
      gap: 1px;
      background: var(--line);
    }

    .side-list a {
      display: block;
      background: var(--white);
      padding: 13px 18px;
      font-weight: 700;
    }

    .side-list a:hover {
      background: var(--yellow);
      color: var(--black);
    }

    .sponsors {
      background: var(--paper);
      border-top: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      padding: 36px 0;
    }

    .sponsors-inner {
      width: min(var(--max), calc(100% - 32px));
      margin: 0 auto;
    }

    .sponsors-head {
      display: flex;
      justify-content: space-between;
      align-items: end;
      gap: 22px;
      margin-bottom: 18px;
    }

    .sponsors h2 {
      font-size: 30px;
      text-transform: uppercase;
    }

    .sponsor-row {
      display: grid;
      grid-template-columns: repeat(5, minmax(0, 1fr));
      gap: 12px;
    }

    .sponsor {
      min-height: 86px;
      display: grid;
      place-items: center;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: var(--white);
      color: var(--muted);
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: .04em;
    }

    .footer {
      background: #111;
      border-top: 6px solid var(--yellow);
      color: var(--white);
      padding: 44px 0;
    }

    .footer-grid {
      width: min(var(--max), calc(100% - 32px));
      margin: 0 auto;
      display: grid;
      grid-template-columns: 1.35fr .75fr .85fr .85fr;
      gap: 28px;
    }

    .footer h3, .footer p, .footer li { color: var(--white); }
    .footer p, .footer li { opacity: .82; }
    .footer ul { list-style: none; padding: 0; margin: 12px 0 0; display: grid; gap: 5px; }

    @media (max-width: 920px) {
      .nav { display: grid; padding: 12px 0; }
      .menu { justify-content: flex-start; }
      .main, .sponsor-row, .footer-grid { grid-template-columns: 1fr; }
      .sponsors-head { display: grid; align-items: start; }
    }

    @media (max-width: 620px) {
      .brand { min-width: 0; }
      .menu a { padding: 8px 7px; font-size: 12px; }
      .page-hero-inner { padding: 42px 0; }
      .content { padding: 24px; }
    }
/* --- Unterseiten-Prototyp: nur Templates mit body.template-subpage --- */
body.template-subpage {
  background:
    linear-gradient(
      180deg,
      #eadbb8 0,
      #f1eadb 190px,
      #f4f1eb 420px,
      #f4f1eb 100%
    ) !important;
}

body.template-subpage .page-hero {
  background:
    linear-gradient(90deg, rgba(0,0,0,.90), rgba(0,0,0,.68)),
    url("/bilder/1775812628/1775812628-1781436097-header-bild.png") center center / cover no-repeat;
  border-bottom: 5px solid var(--yellow);
}

body.template-subpage .page-hero-inner {
  padding: 30px 0 32px;
}

body.template-subpage .page-hero h1 {
  margin: 0;
  color: var(--white);
  font-size: clamp(34px, 3.6vw, 48px);
  line-height: .95;
}

body.template-subpage .page-hero p {
  max-width: 760px;
  margin: 10px 0 0;
  color: rgba(255,255,255,.86);
  font-size: 16px;
  line-height: 1.55;
}

body.template-subpage .subpage-layout {
  width: min(var(--max), calc(100% - 48px));
  margin: 0 auto;
  padding: 68px 0 76px;
  display: grid;
  grid-template-columns: minmax(0, 760px) 320px;
  justify-content: center;
  gap: 58px;
  align-items: start;
  background:
    linear-gradient(
      180deg,
      #eadbb8 0,
      #f1eadb 180px,
      #f4f1eb 420px,
      #f4f1eb 100%
    ) !important;
  box-shadow: 0 0 0 100vmax #f4f1eb;
  clip-path: inset(0 -100vmax);
}

body.template-subpage .subpage-content {
  min-height: 560px;
  padding: clamp(46px, 4.5vw, 64px);
  margin-bottom: 18px;
  background: rgba(255,255,255,.97);
  border: 1px solid rgba(17,17,17,.12);
  border-radius: var(--radius);
  box-shadow: 0 18px 42px rgba(0,0,0,.10);
}

body.template-subpage-default .subpage-layout {
  grid-template-columns: minmax(0, 1040px);
  justify-content: center;
}

body.template-subpage .subpage-content img {
  max-width: 100%;
  height: auto !important;
  object-fit: contain;
}

body.template-subpage .sidebar .side-card-body img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto !important;
  object-fit: contain;
  object-position: center;
}

body.template-subpage .subpage-content a.buttonlink,
body.template-subpage .subpage-content a.buttonlink:link,
body.template-subpage .subpage-content a.buttonlink:visited {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 16px;
  border-radius: 6px;
  background: var(--yellow);
  color: var(--black);
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

body.template-subpage .subpage-content a.buttonlink:hover,
body.template-subpage .subpage-content a.buttonlink:focus {
  background: var(--orange);
  color: var(--black);
  text-decoration: none;
}

body.template-subpage .kontakt-layout {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(320px, 1.05fr);
  gap: clamp(30px, 4vw, 54px);
  align-items: start;
}

body.template-subpage .kontakt-panel {
  padding: clamp(24px, 3vw, 34px);
  border: 1px solid rgba(17,17,17,.12);
  border-radius: var(--radius);
  background: #fff;
}

body.template-subpage .kontakt-panel h2,
body.template-subpage .kontakt-formular h2 {
  margin-top: 0;
}

body.template-subpage .kontakt-liste {
  display: grid;
  gap: 18px;
  margin-top: 22px;
}

body.template-subpage .kontakt-liste p {
  margin: 0;
}

body.template-subpage .kontakt-formular {
  padding: clamp(24px, 3vw, 34px);
  border: 1px solid rgba(17,17,17,.12);
  border-radius: var(--radius);
  background: #f7f4ed;
}

body.template-subpage .formularfeld {
  margin: 0 0 18px;
}

body.template-subpage .formularfeld label {
  display: block;
  margin: 0 0 7px;
  color: var(--black);
  font-weight: 800;
}

body.template-subpage .auswahl {
  width: 100%;
  min-height: 46px;
  padding: 11px 13px;
  border: 1px solid rgba(17,17,17,.22);
  border-radius: 6px;
  background: #fff;
  color: var(--black);
  font: 500 15px/1.45 "Manrope", Arial, Helvetica, sans-serif;
}

body.template-subpage textarea.auswahl {
  min-height: 170px;
  resize: vertical;
}

body.template-subpage .auswahl:focus {
  outline: 3px solid rgba(245,164,0,.22);
  border-color: var(--yellow);
}

body.template-subpage .kontakt-erfolg {
  padding: clamp(28px, 4vw, 44px);
  border-left: 6px solid var(--yellow);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: 0 18px 42px rgba(0,0,0,.08);
}

body.template-subpage .sidebar {
  display: grid;
  gap: 22px;
  position: sticky;
  top: 110px;
  align-self: start;
}

body.template-subpage .side-card {
  background: rgba(255,255,255,.97);
  border: 1px solid rgba(17,17,17,.16);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 12px 28px rgba(0,0,0,.08);
}

body.template-subpage .side-card h3 {
  margin: 0;
  padding: 17px 18px;
  background: var(--black);
  color: var(--white);
  border-bottom: 4px solid var(--yellow);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

body.template-subpage .side-card-body {
  min-height: 58px;
  padding: 18px;
}

body.template-subpage .sponsors {
  margin-top: 0;
  padding: 64px 0 66px;
  background: #f4f1eb !important;
  box-shadow: 0 0 0 100vmax #f4f1eb;
  clip-path: inset(0 -100vmax);
  border-top: 1px solid rgba(17,17,17,.10);
  border-bottom: 0;
}

/* CMS-Newsliste: zContent erzeugt eine Tabellenstruktur mit Bild und Text. */
body.template-subpage .subpage-content table.zcontent_main_table.zcontent_news {
  width: 100% !important;
  border-collapse: collapse;
}

body.template-subpage .subpage-content table.zcontent_news > tbody > tr > td {
  padding: 34px 0;
  vertical-align: top;
  border-bottom: 1px solid var(--line);
}

body.template-subpage .subpage-content table.zcontent_news > tbody > tr > td::after {
  content: "";
  display: block;
  clear: both;
}

body.template-subpage .subpage-content table.zcontent_news > tbody > tr:first-child > td {
  padding-top: 0;
}

body.template-subpage .subpage-content table.zcontent_news > tbody > tr:last-child > td {
  padding-bottom: 0;
  border-bottom: 0;
}

body.template-subpage .subpage-content table.zcontent_news .kategorie {
  display: block;
  margin: 0 0 5px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .05em;
  text-transform: uppercase;
}

body.template-subpage .subpage-content table.zcontent_news span.ueberschrift {
  display: block;
  margin: 0 0 16px;
  color: var(--black);
  font-family: var(--font-head);
  font-size: clamp(26px, 3vw, 34px);
  font-weight: 800;
  line-height: 1.05;
  text-transform: uppercase;
}

body.template-subpage .subpage-content table.zcontent_news td > div:has(> img.bild) {
  float: left !important;
  margin: 0 22px 10px 0 !important;
  padding: 0 !important;
}

body.template-subpage .subpage-content table.zcontent_news p[align="justify"] {
  margin: 0;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.65;
}

body.template-subpage .subpage-content table.zcontent_news p[align="justify"] a {
  color: var(--orange);
  font-weight: 700;
}

body.template-subpage .subpage-content table.zcontent_news p[align="justify"] a:hover,
body.template-subpage .subpage-content table.zcontent_news p[align="justify"] a:focus {
  color: var(--black);
}

/* CMS-Sponsorentafel */
body.template-subpage .subpage-content .sponsor-board {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin: 24px 0 0;
}

body.template-subpage .subpage-content .sponsor-board__item {
  min-height: 0;
  aspect-ratio: 16 / 9;
  display: grid;
  place-items: center;
  padding: 0;
  border: 1px solid rgba(17,17,17,.14);
  border-radius: 6px;
  background: var(--white);
  box-shadow: 0 7px 18px rgba(0,0,0,.13);
}

body.template-subpage .subpage-content a.sponsor-board__item {
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

body.template-subpage .subpage-content a.sponsor-board__item:hover,
body.template-subpage .subpage-content a.sponsor-board__item:focus {
  border-color: rgba(239,149,0,.58);
  box-shadow: 0 10px 26px rgba(0,0,0,.08);
  transform: translateY(-2px);
}

body.template-subpage .subpage-content .sponsor-board__item img {
  display: block;
  width: 100%;
  max-width: 100%;
  max-height: 100%;
  height: 100% !important;
  object-fit: contain;
  border-radius: 3px;
}

@media (max-width: 920px) {
  body.template-subpage .subpage-layout {
    grid-template-columns: 1fr;
    width: min(var(--max), calc(100% - 32px));
    padding: 46px 0 58px;
  }

  body.template-subpage .sidebar {
    position: static;
  }

  body.template-subpage .kontakt-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 620px) {
  body.template-subpage .page-hero-inner {
    padding: 26px 0 28px;
  }

  body.template-subpage .subpage-content {
    padding: 26px;
  }

  body.template-subpage .subpage-content table.zcontent_news > tbody > tr > td {
    padding: 28px 0;
  }

  body.template-subpage .subpage-content .sponsor-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.template-subpage .subpage-content table.zcontent_news td > div:has(> img.bild) {
    float: none !important;
    margin: 0 0 16px !important;
  }

}

.svh-top-button {
  position: fixed;
  right: clamp(18px, 3vw, 34px);
  bottom: clamp(18px, 3vw, 34px);
  z-index: 80;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-width: 58px;
  height: 42px;
  padding: 0 14px;
  border: 2px solid var(--black);
  border-radius: 6px;
  background: var(--yellow);
  color: var(--black);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .04em;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transform: translateY(12px);
  box-shadow: 0 14px 30px rgba(0,0,0,.20);
  transition: opacity .18s ease, transform .18s ease, background .18s ease, color .18s ease;
}

.svh-top-button span:first-child {
  font-size: 17px;
  line-height: 1;
}

.svh-top-button.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.svh-top-button:hover,
.svh-top-button:focus-visible {
  background: var(--black);
  color: var(--white);
}

@media (max-width: 620px) {
  .svh-top-button {
    min-width: 46px;
    width: 46px;
    height: 46px;
    padding: 0;
    border-radius: 50%;
  }

  .svh-top-button-text {
    display: none;
  }
}

