/*
Theme Name: velocultour
Theme URI: https://velocultour.de
Author: velocultour Webteam
Author URI: https://velocultour.de
Description: Cinematic Bikestore-Theme für velocultour Bikestore in Neuhof. Designed für Premium-Marken-Storytelling, integriert mit dem velocultour-booking-Plugin für Werkstatt- und Beratungstermine.
Version: 1.7.12
Requires at least: 6.0
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: velocultour
Tags: bike, premium, custom-menu, custom-logo
*/

/* ========================================================================
   Inline-CSS aus dem v13-Mockup
   ======================================================================== */

:root {
    --orange: #E77C05;
    --orange-deep: #C66700;
    --orange-glow: rgba(231, 124, 5, 0.45);
    --ink: #0A0A0B;
    --ink-soft: #15151A;
    --paper: #F5F1EA;
    --paper-warm: #ECE5D7;
    --line: rgba(10,10,11,0.1);
    --muted: #6B6660;
    --white: #FFFFFF;
  }
  * { margin: 0; padding: 0; box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  body {
    font-family: 'Familjen Grotesk', sans-serif;
    background:
      linear-gradient(180deg, rgba(70, 70, 75, 0.65) 0%, rgba(140, 140, 145, 0.4) 80px, rgba(220, 220, 225, 0.22) 160px, transparent 220px) no-repeat,
      var(--ink);
    color: var(--paper);
    overflow-x: hidden;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    cursor: none;
  }
  .display {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    letter-spacing: -0.01em;
    line-height: 0.85;
    text-transform: uppercase;
  }
  .mono { font-family: 'JetBrains Mono', monospace; font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; }

  /* ============= CUSTOM CURSOR ============= */
  .cursor {
    position: fixed;
    width: 8px; height: 8px;
    background: var(--orange);
    border-radius: 50%;
    pointer-events: none;
    z-index: 10000;
    mix-blend-mode: difference;
    transition: transform 0.15s ease, width 0.3s ease, height 0.3s ease;
    will-change: transform;
    transform: translate(-100px, -100px);
  }
  .cursor-ring {
    position: fixed;
    width: 36px; height: 36px;
    border: 1.5px solid rgba(255,255,255,0.4);
    border-radius: 50%;
    pointer-events: none;
    z-index: 9999;
    transition: transform 0.4s cubic-bezier(0.2, 0, 0.1, 1), width 0.3s ease, height 0.3s ease, border-color 0.3s ease;
    will-change: transform;
    transform: translate(-100px, -100px);
  }
  .cursor.hover { transform: translate(-100px, -100px) scale(0); }
  .cursor-ring.hover { width: 64px; height: 64px; border-color: var(--orange); }
  @media (max-width: 900px), (pointer: coarse) {
    body { cursor: auto; }
    .cursor, .cursor-ring { display: none; }
  }

  /* ============= LOADER ============= */
  .loader {
    /* v1.7.1: BG-Bild entfernt — reines Dunkelschwarz, fokus aufs Logo */
    position: fixed;
    inset: 0;
    background: var(--ink);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.5s ease 0.15s, visibility 0.5s ease 0.15s;
  }
  /* v1.7.8: Zwei-Phasen-Fadeout für Reveal-Effekt — erst fällt der
     schwarze BG auf 70 % Opacity (Hero-Video schimmert leicht durch),
     dann blendet er vollständig in die Videosequenz aus. */
  .loader.done {
    animation: loaderFadeOut 1.1s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  }
  @keyframes loaderFadeOut {
    0%   { opacity: 1; visibility: visible; }
    40%  { opacity: 0.7; visibility: visible; }
    100% { opacity: 0; visibility: hidden; }
  }
  .loader-mark {
    /* v1.2.0: Logo deutlich vergroessert (vorher 220-340 px) */
    width: clamp(320px, 42vw, 520px);
    display: block;
    position: relative;
  }
  .loader-logo {
    /* v1.7.4: clip-path-Reveal zurück mit lokalem PNG (zuverlässig). Schneller (0.9s). */
    width: 100%;
    height: auto;
    display: block;
    clip-path: inset(0 0 100% 0);
    -webkit-clip-path: inset(0 0 100% 0);
    opacity: 0;
    transform: scale(0.96);
    animation: logoStaged 0.9s cubic-bezier(0.22, 0.61, 0.36, 1) 0.1s forwards;
    filter: drop-shadow(0 6px 20px rgba(0,0,0,0.4));
  }
  @keyframes logoStaged {
    0% {
      clip-path: inset(0 0 100% 0);
      -webkit-clip-path: inset(0 0 100% 0);
      opacity: 0;
      transform: scale(0.94);
    }
    18% {
      opacity: 1;
    }
    55% {
      clip-path: inset(0 0 38% 0);
      -webkit-clip-path: inset(0 0 38% 0);
      transform: scale(1);
    }
    100% {
      clip-path: inset(0 0 0 0);
      -webkit-clip-path: inset(0 0 0 0);
      opacity: 1;
      transform: scale(1);
    }
  }
  .loader-bar {
    /* v1.7.1: schneller (vorher 1.7s) */
    position: absolute;
    bottom: 0; left: 0;
    height: 2px;
    background: var(--orange);
    width: 0;
    animation: loaderBar 1s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  }
  @keyframes loaderBar {
    to { width: 100%; }
  }

  /* ============= TOP MARQUEE ============= */
  .marquee {
    background: var(--orange);
    color: var(--ink);
    overflow: hidden;
    padding: 12px 0;
    position: relative;
    z-index: 50;
    box-shadow:
      0 -38px 78px rgba(230, 230, 235, 0.22),
      0 -14px 32px rgba(210, 210, 215, 0.15),
      0 -4px 12px rgba(190, 190, 195, 0.1);
  }
  .marquee-track {
    display: flex;
    gap: 56px;
    white-space: nowrap;
    animation: scroll 28s linear infinite;
    width: max-content;
  }
  .marquee-track span {
    font-family: 'Familjen Grotesk', sans-serif;
    font-size: 0.92rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 56px;
  }
  .marquee-track span::after {
    content: '◆';
    font-size: 0.6rem;
    transform: translateY(-2px);
  }
  @keyframes scroll {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
  }

  /* ============= NAV ============= */
  nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 100;
    padding: 18px 40px;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 40px;
    background: linear-gradient(180deg, rgba(10,10,11,0.85) 0%, rgba(10,10,11,0.45) 55%, rgba(10,10,11,0) 100%);
    transition: background 0.3s, padding 0.3s, backdrop-filter 0.3s;
  }
  nav.scrolled {
    background: rgba(10,10,11,0.95);
    backdrop-filter: blur(20px);
    padding: 12px 40px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .logo {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 1.7rem;
    letter-spacing: -0.01em;
    text-decoration: none;
    color: var(--paper);
    text-transform: uppercase;
  }
  .logo-mark {
    width: 36px; height: 36px;
    position: relative;
  }
  .logo-mark svg { width: 100%; height: 100%; }
  /* v1.3.2: Nav — Big Shoulders Display als Echo der Hero-Typografie.
     Größer, sportlich-präzise, rhymt mit den Section-Headlines. */
  .nav-links {
    display: flex;
    gap: 38px;
    list-style: none;
    justify-content: center;
    align-items: center;
    margin: 0;
    padding: 0;
  }
  .nav-links li {
    margin: 0;
    padding: 0;
    list-style: none;
  }
  .nav-links a {
    position: relative;
    display: inline-block;
    text-decoration: none;
    color: rgba(245,241,234,0.78);
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 700;
    font-size: 1.18rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    line-height: 1;
    padding: 10px 0 12px;
    transition: color 0.22s ease, transform 0.22s ease;
  }
  .nav-links a::before {
    content: "";
    position: absolute;
    left: 50%;
    right: 50%;
    bottom: 2px;
    height: 2px;
    background: var(--orange);
    transition: left 0.34s cubic-bezier(0.2,0,0.1,1), right 0.34s cubic-bezier(0.2,0,0.1,1);
    pointer-events: none;
  }
  .nav-links a:hover {
    color: var(--paper);
    transform: translateY(-1px);
  }
  .nav-links a:hover::before {
    left: 0;
    right: 0;
  }
  .nav-links a.active {
    color: var(--orange);
    font-weight: 800;
  }
  .nav-links a.active::before {
    left: 0;
    right: 0;
    height: 2.5px;
  }
  /* Auf gescrolltem Nav: kompakter, aber immer noch BS */
  nav.scrolled .nav-links {
    gap: 32px;
  }
  nav.scrolled .nav-links a {
    font-size: 1.05rem;
    padding: 6px 0 8px;
  }
  nav.scrolled .nav-links a::before {
    bottom: 0;
  }
  @media (max-width: 1100px) {
    .nav-links { gap: 28px; }
    .nav-links a { font-size: 1.05rem; }
  }
  .nav-cta {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    align-items: center;
  }
  .btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 13px 22px;
    border-radius: 6px;
    font-weight: 600;
    font-size: 0.88rem;
    text-decoration: none;
    transition: transform 0.15s, background 0.2s, color 0.2s;
    border: 1.5px solid transparent;
    cursor: none;
    font-family: 'Familjen Grotesk', sans-serif;
    position: relative;
    overflow: hidden;
  }
  .btn-primary {
    background: var(--orange);
    color: var(--white);
  }
  .btn-primary:hover { background: var(--orange-deep); }
  .btn-ghost {
    background: transparent;
    color: var(--paper);
    border-color: rgba(255,255,255,0.3);
  }
  .btn-ghost:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .btn-light {
    background: var(--paper);
    color: var(--ink);
  }
  .btn-light:hover { background: var(--orange); color: var(--white); }

  /* ============= HERO VIDEO ============= */
  .hero {
    position: relative;
    height: 100vh;
    min-height: 720px;
    overflow: hidden;
    background: var(--ink);
  }
  .hero-video-wrap {
    position: absolute;
    inset: 0;
    overflow: hidden;
  }
  .hero-video {
    position: absolute;
    inset: -5%;
    width: 110%;
    height: 110%;
    object-fit: cover;
    filter: contrast(1.1) saturate(1.1) brightness(0.6);
    transition: transform 0.8s cubic-bezier(0.2, 0, 0.1, 1);
  }
  .hero-poster {
    position: absolute;
    inset: 0;
    background: url('img/hero-loader.jpg') center/cover;
    filter: contrast(1.1) saturate(1.1) brightness(0.5);
    z-index: 0;
  }
  .hero-overlay {
    position: absolute;
    inset: 0;
    background:
      linear-gradient(180deg, rgba(10,10,11,0.4) 0%, transparent 30%, rgba(10,10,11,0.85) 100%),
      linear-gradient(90deg, rgba(10,10,11,0.5) 0%, transparent 50%);
    z-index: 1;
  }
  .hero-noise {
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
    opacity: 0.06;
    pointer-events: none;
    z-index: 2;
    mix-blend-mode: overlay;
  }

  .hero-content {
    position: relative;
    z-index: 3;
    height: 100%;
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 40px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding-bottom: 80px;
  }
  .hero-eyebrow {
    display: flex;
    align-items: center;
    gap: 14px;
    color: var(--paper);
    margin-bottom: 24px;
    opacity: 0;
    animation: fadeUp 0.8s cubic-bezier(0.2,0,0.1,1) 1.2s forwards;
  }
  .hero-eyebrow .live-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--orange);
    box-shadow: 0 0 0 0 var(--orange-glow);
    animation: pulseDot 2s ease-in-out infinite;
  }
  @keyframes pulseDot {
    0%, 100% { box-shadow: 0 0 0 0 var(--orange-glow); }
    50% { box-shadow: 0 0 0 12px transparent; }
  }
  .hero-headline {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: clamp(4.5rem, 16vw, 17rem);
    line-height: 0.82;
    letter-spacing: -0.025em;
    text-transform: uppercase;
    color: var(--paper);
    margin-bottom: 32px;
    overflow: hidden;
  }
  .hero-headline .line {
    display: block;
    overflow: hidden;
  }
  .hero-headline .line span {
    display: inline-block;
    transform: translateY(105%);
    animation: lineUp 1s cubic-bezier(0.2, 0, 0.1, 1) forwards;
  }
  .hero-headline .line:nth-child(1) span { animation-delay: 0.5s; }
  .hero-headline .line:nth-child(2) span { animation-delay: 0.7s; }
  .hero-headline .line:nth-child(3) span { animation-delay: 0.9s; }
  @keyframes lineUp {
    to { transform: translateY(0); }
  }
  .hero-headline .accent { color: var(--orange); }
  .hero-headline .italic {
    font-style: italic;
    font-weight: 700;
    /* v1.7.8: Italic-Slant kompensieren — sonst wird das letzte
       Zeichen (z. B. das R von „your") bei overflow: hidden / engen
       Viewports rechts abgeschnitten. */
    padding-right: 0.1em;
  }

  .hero-bottom {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 48px;
    align-items: end;
    border-top: 1px solid rgba(245,241,234,0.15);
    padding-top: 32px;
    opacity: 0;
    animation: fadeUp 0.8s cubic-bezier(0.2,0,0.1,1) 1.4s forwards;
  }
  @keyframes fadeUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
  }
  .hero-tagline {
    font-size: 1.05rem;
    color: var(--paper);
    line-height: 1.5;
    max-width: 360px;
  }
  .hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }
  .hero-meta-block {
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-items: flex-end;
    text-align: right;
  }
  .hero-meta-num {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 3rem;
    line-height: 1;
    color: var(--orange);
  }
  .hero-meta-label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.72rem;
    letter-spacing: 0.12em;
    color: rgba(245,241,234,0.7);
    text-transform: uppercase;
  }

  /* Sound toggle */
  .sound-toggle {
    position: absolute;
    top: 50%;
    right: 32px;
    transform: translateY(-50%);
    z-index: 10;
    background: rgba(10,10,11,0.5);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 50%;
    width: 56px; height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: none;
    transition: all 0.3s;
  }
  .sound-toggle:hover { background: var(--orange); border-color: var(--orange); }
  .sound-toggle svg { stroke: var(--paper); }

  /* Scroll indicator */
  .scroll-indicator {
    position: absolute;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    color: rgba(245,241,234,0.7);
    z-index: 4;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.65rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    opacity: 0;
    animation: fadeIn 1s ease 1.8s forwards;
  }
  @keyframes fadeIn { to { opacity: 1; } }
  .scroll-line {
    width: 1px;
    height: 40px;
    background: linear-gradient(180deg, var(--orange) 0%, transparent 100%);
    animation: scrollLine 1.6s ease-in-out infinite;
  }
  @keyframes scrollLine {
    0% { transform: scaleY(0); transform-origin: top; }
    50% { transform: scaleY(1); transform-origin: top; }
    51% { transform: scaleY(1); transform-origin: bottom; }
    100% { transform: scaleY(0); transform-origin: bottom; }
  }

  /* Ticker side */
  .hero-side {
    position: absolute;
    left: 24px;
    top: 50%;
    transform: translateY(-50%) rotate(-90deg);
    transform-origin: left center;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.3em;
    color: rgba(245,241,234,0.5);
    text-transform: uppercase;
    z-index: 4;
  }

  /* ============= REVEAL UTILITY ============= */
  .reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.9s cubic-bezier(0.2, 0, 0.1, 1), transform 0.9s cubic-bezier(0.2, 0, 0.1, 1);
  }
  .reveal.in {
    opacity: 1;
    transform: translateY(0);
  }
  .reveal.delay-1 { transition-delay: 0.1s; }
  .reveal.delay-2 { transition-delay: 0.2s; }
  .reveal.delay-3 { transition-delay: 0.3s; }

  /* ============= SECTIONS ============= */
  section.s-light {
    background: var(--paper);
    color: var(--ink);
  }
  .container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 120px 40px;
  }
  .section-head {
    display: flex;
    justify-content: space-between;
    align-items: end;
    margin-bottom: 60px;
    gap: 40px;
  }
  .section-eyebrow {
    color: var(--orange);
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.72rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 12px;
  }
  .section-eyebrow::before {
    content: '';
    width: 24px;
    height: 1px;
    background: var(--orange);
  }
  .section-head h2 {
    /* v1.7.5: vereinheitlicht & leicht verkleinert (vorher max 6rem) */
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: clamp(2.6rem, 5.8vw, 4.6rem);
    letter-spacing: -0.02em;
    line-height: 0.9;
    text-transform: uppercase;
  }
  .section-head h2 .accent { color: var(--orange); }
  .section-head h2 .italic { font-style: italic; font-weight: 600; }
  .section-head .link {
    color: inherit;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.9rem;
    border-bottom: 2px solid var(--orange);
    padding-bottom: 4px;
    white-space: nowrap;
    transition: color 0.2s;
  }
  .section-head .link:hover { color: var(--orange); }

  /* ============= BRAND MARQUEE ============= */
  .brand-marquee {
    background: var(--paper);
    overflow: hidden;
    padding: 32px 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }
  .brand-track {
    display: flex;
    gap: 80px;
    white-space: nowrap;
    animation: scroll 40s linear infinite;
    width: max-content;
  }
  .brand-item {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 2.4rem;
    letter-spacing: -0.02em;
    color: var(--ink);
    transition: color 0.2s, opacity 0.2s;
    opacity: 0.4;
    text-transform: uppercase;
  }
  .brand-item:hover { color: var(--orange); opacity: 1; }
  .brand-item .arrow { color: var(--orange); margin-left: 12px; }

  /* ============= CATEGORIES ============= */
  .cat-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
  }
  .cat-card {
    aspect-ratio: 3/4;
    background: var(--paper-warm);
    overflow: hidden;
    position: relative;
    cursor: none;
    transition: transform 0.5s cubic-bezier(0.2, 0, 0.1, 1);
  }
  .cat-card:hover { transform: translateY(-8px); }
  .cat-card-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.8s cubic-bezier(0.2, 0, 0.1, 1), filter 0.5s ease;
    filter: grayscale(0.4) contrast(1.1);
    display: block;
  }
  .cat-card:hover .cat-card-img { transform: scale(1.08); filter: grayscale(0) contrast(1.1) saturate(1.2); }
  .cat-card-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 40%, rgba(10,10,11,0.92) 100%);
  }
  .cat-card-content {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    padding: 28px;
    color: var(--paper);
    z-index: 2;
  }
  .cat-card-num {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    opacity: 0.6;
    margin-bottom: 8px;
    letter-spacing: 0.1em;
  }
  .cat-card-title {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 2.2rem;
    line-height: 0.9;
    margin-bottom: 6px;
    text-transform: uppercase;
  }
  .cat-card:hover .cat-card-title { color: var(--orange); transition: color 0.3s; }
  .cat-card-count { font-size: 0.82rem; opacity: 0.7; }
  .cat-card-arrow {
    position: absolute;
    top: 20px; right: 20px;
    width: 44px; height: 44px;
    background: var(--paper);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.3s, transform 0.4s cubic-bezier(0.2, 0, 0.1, 1);
    z-index: 2;
  }
  .cat-card:hover .cat-card-arrow {
    background: var(--orange);
    transform: rotate(-45deg) scale(1.1);
  }
  .cat-card:hover .cat-card-arrow svg { stroke: var(--paper); }

  /* ============= SERVICE TICKER ============= */
  .service-section {
    background: var(--ink);
    color: var(--paper);
    overflow: hidden;
    position: relative;
  }
  .service-ticker {
    padding: 40px 0;
    overflow: hidden;
    border-top: 1px solid rgba(245,241,234,0.08);
    border-bottom: 1px solid rgba(245,241,234,0.08);
  }
  .service-ticker-track {
    display: flex;
    gap: 60px;
    white-space: nowrap;
    animation: scroll 35s linear infinite reverse;
    width: max-content;
    align-items: center;
  }
  .service-ticker-item {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: clamp(3rem, 7vw, 6rem);
    letter-spacing: -0.02em;
    color: var(--paper);
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: 60px;
  }
  .service-ticker-item.outline {
    color: transparent;
    -webkit-text-stroke: 1.5px var(--paper);
  }
  .service-ticker-item .star {
    color: var(--orange);
    font-size: 0.7em;
  }

  /* SERVICE CARDS dark */
  .service-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .service-card {
    background: var(--ink-soft);
    padding: 56px;
    position: relative;
    min-height: 480px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    overflow: hidden;
    border: 1px solid rgba(245,241,234,0.08);
    transition: background 0.4s;
    cursor: none;
  }
  .service-card:hover { background: var(--orange); }
  .service-card:hover .service-eyebrow,
  .service-card:hover h3,
  .service-card:hover p,
  .service-card:hover .service-list li { color: var(--ink); }
  .service-card:hover .service-list li { background: rgba(10,10,11,0.15); }
  .service-card:hover .service-bg-num { color: rgba(10,10,11,0.15); }
  .service-card:hover .btn-light { background: var(--ink); color: var(--paper); }
  .service-icon {
    width: 64px; height: 64px;
    border-radius: 50%;
    background: var(--orange);
    color: var(--paper);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 32px;
    transition: background 0.3s;
  }
  .service-card:hover .service-icon { background: var(--ink); color: var(--orange); }
  .service-eyebrow {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.95rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(245,241,234,0.92);
    font-weight: 600;
    margin-bottom: 22px;
    transition: color 0.3s;
    display: inline-flex;
    align-items: center;
    gap: 10px;
  }
  .service-eyebrow::before {
    content: '';
    width: 24px;
    height: 2px;
    background: var(--orange);
    transition: background 0.3s;
  }
  .service-card:hover .service-eyebrow::before { background: var(--ink); }
  .service-card h3 {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 2.8rem;
    line-height: 0.9;
    margin-bottom: 16px;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    transition: color 0.3s;
  }
  .service-card p {
    font-size: 1rem;
    color: rgba(245,241,234,0.7);
    margin-bottom: 28px;
    max-width: 380px;
    transition: color 0.3s;
  }
  .service-list {
    list-style: none;
    margin-bottom: 32px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  .service-list li {
    background: rgba(245,241,234,0.06);
    color: rgba(245,241,234,0.9);
    padding: 7px 14px;
    border-radius: 4px;
    font-size: 0.82rem;
    font-weight: 500;
    transition: all 0.3s;
  }
  .service-bg-num {
    position: absolute;
    top: -40px; right: -10px;
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 18rem;
    line-height: 0.8;
    color: rgba(245,241,234,0.04);
    pointer-events: none;
    transition: color 0.3s;
  }

  /* ============= PRODUCT GRID ============= */
  .product-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .product-card {
    background: var(--paper);
    border: 1px solid var(--line);
    overflow: hidden;
    cursor: none;
    transition: transform 0.4s cubic-bezier(0.2, 0, 0.1, 1), box-shadow 0.4s;
    display: flex;
    flex-direction: column;
    position: relative;
  }
  .product-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 30px 60px rgba(10,10,11,0.15);
  }
  .product-image {
    aspect-ratio: 5/4;
    background: var(--paper-warm);
    position: relative;
    overflow: hidden;
  }
  .product-image-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    background-size: cover;
    background-position: center;
    transition: transform 0.8s cubic-bezier(0.2, 0, 0.1, 1);
  }
  /* v1.7.8: <img>-Tag innerhalb von .product-image-bg (Fallback-Demo-Bilder)
     auf Card-Format zwingen — object-fit ist auf dem inneren <img>, nicht
     auf dem Wrapper-div nötig. */
  .product-image-bg-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
  }
  .product-card:hover .product-image-bg { transform: scale(1.06); }
  .product-badges {
    position: absolute;
    top: 16px; left: 16px;
    display: flex;
    gap: 6px;
    z-index: 2;
  }
  .badge-tag {
    background: var(--ink);
    color: var(--paper);
    padding: 6px 12px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.62rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }
  .badge-tag.new { background: var(--orange); }
  .badge-tag.sale { background: #1a4d2e; color: var(--paper); }
  .product-quick {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    background: var(--ink);
    color: var(--paper);
    padding: 14px;
    display: flex;
    justify-content: center;
    gap: 24px;
    transform: translateY(100%);
    transition: transform 0.4s cubic-bezier(0.2, 0, 0.1, 1);
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
  }
  .product-card:hover .product-quick { transform: translateY(0); }
  .product-quick a { color: inherit; text-decoration: none; transition: color 0.2s; }
  .product-quick a:hover { color: var(--orange); }
  .product-info {
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .product-meta-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--muted);
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.05em;
  }
  .product-rating { color: var(--orange); }
  .product-name {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 800;
    font-size: 1.8rem;
    letter-spacing: -0.01em;
    line-height: 0.95;
    text-transform: uppercase;
    color: var(--ink);
  }
  .product-spec {
    font-size: 0.85rem;
    color: var(--muted);
  }
  .product-footer {
    margin-top: 14px;
    padding-top: 18px;
    border-top: 1px solid var(--line);
    display: flex;
    justify-content: space-between;
    align-items: end;
  }
  .product-price-block .price-now {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 1.8rem;
    line-height: 1;
    color: var(--ink);
  }
  .product-price-block .price-leasing {
    font-size: 0.78rem;
    color: var(--orange);
    font-weight: 600;
    margin-top: 4px;
  }
  .product-cta {
    background: var(--ink);
    color: var(--paper);
    border: none;
    padding: 12px 18px;
    border-radius: 6px;
    font-family: 'Familjen Grotesk', sans-serif;
    font-size: 0.82rem;
    font-weight: 600;
    cursor: none;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: background 0.2s, padding 0.3s;
  }
  .product-cta:hover { background: var(--orange); padding-right: 22px; }

  /* ============= FOOTER ============= */
  footer {
    color: var(--paper);
    padding: 100px 40px 32px;
    border-top: 1px solid rgba(245,241,234,0.08);
    position: relative;
    background: transparent;
  }
  .footer-inner {
    position: relative;
    z-index: 2;
  }

  /* ============= DARK ZONE: Contact + Footer mit gemeinsamem BG ============= */
  .dark-zone {
    position: relative;
    background: var(--ink);
    overflow: hidden;
  }
    .dark-zone::before {
    /* Wald-BG verschoben in <img class="dark-zone-bg"> für Klartext-Tausch (v1.6.7) */
    display: none;
  }
  .dark-zone::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
      linear-gradient(180deg, rgba(10,10,11,0.55) 0%, rgba(10,10,11,0.25) 35%, rgba(10,10,11,0.45) 65%, rgba(10,10,11,0.85) 100%),
      radial-gradient(circle at 30% 30%, rgba(231,124,5,0.1) 0%, transparent 50%);
    pointer-events: none;
    z-index: 1;
  }
  .dark-zone > * {
    position: relative;
    z-index: 2;
  }
  .footer-inner {
    max-width: 1600px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
  }
  .footer-top {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 64px;
    padding-bottom: 60px;
    border-bottom: 1px solid rgba(245,241,234,0.08);
  }
  .footer-cta h3 {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 3.2rem;
    line-height: 0.9;
    letter-spacing: -0.02em;
    margin-bottom: 20px;
    text-transform: uppercase;
  }
  .footer-cta h3 .accent { color: var(--orange); font-style: italic; font-weight: 700; }
  .footer-cta p {
    color: rgba(245,241,234,0.6);
    margin-bottom: 24px;
    max-width: 360px;
  }
  .newsletter {
    display: flex;
    background: rgba(245,241,234,0.05);
    border: 1px solid rgba(245,241,234,0.1);
    border-radius: 6px;
    padding: 4px 4px 4px 22px;
    max-width: 380px;
  }
  .newsletter input {
    flex: 1;
    background: transparent;
    border: none;
    color: var(--paper);
    font-family: 'Familjen Grotesk', sans-serif;
    font-size: 0.9rem;
    outline: none;
  }
  .newsletter input::placeholder { color: rgba(245,241,234,0.4); }
  .newsletter button {
    background: var(--orange);
    color: var(--paper);
    border: none;
    padding: 11px 22px;
    border-radius: 4px;
    font-family: 'Familjen Grotesk', sans-serif;
    font-weight: 600;
    cursor: none;
    transition: background 0.2s;
  }
  .newsletter button:hover { background: var(--orange-deep); }
  .footer-col h4 {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.72rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--orange);
    margin-bottom: 20px;
  }
  .footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 12px; }
  .footer-col li { color: var(--paper); font-size: 0.92rem; opacity: 0.65; }
  .footer-col a { color: var(--paper); text-decoration: none; font-size: 0.92rem; opacity: 0.65; transition: opacity 0.2s, color 0.2s; }
  .footer-col a:hover { opacity: 1; color: var(--orange); }
  .footer-bottom {
    margin-top: 32px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.82rem;
    color: rgba(245,241,234,0.5);
    flex-wrap: wrap;
    gap: 16px;
  }
  .footer-bottom-links { display: flex; gap: 20px; }
  .footer-bottom-links a {
    color: rgba(245,241,234,0.7);
    text-decoration: none;
    transition: color 0.2s;
  }
  .footer-bottom-links a:hover { color: var(--orange); }
  .footer-mark {
    font-family: 'Cabin', sans-serif;
    font-weight: 600;
    line-height: 0.9;
    letter-spacing: -0.035em;
    margin: 60px 0 -20px;
    color: transparent;
    -webkit-text-stroke: 1.5px rgba(245,241,234,0.12);
    text-transform: lowercase;
    white-space: nowrap;
    width: 100%;
    text-align: left;
    font-size: 18vw;
  }


  .logo-img {
    height: 72px;
    width: auto;
    display: block;
    transition: transform 0.3s ease, height 0.3s ease;
    filter: drop-shadow(0 4px 14px rgba(0,0,0,0.35));
  }
  .logo:hover .logo-img { transform: scale(1.04); }
  nav.scrolled .logo-img { height: 52px; }
  @media (max-width: 640px) {
    .logo-img { height: 48px; }
    nav.scrolled .logo-img { height: 38px; }
  }


  /* ============= CONTACT SECTION ============= */
  .contact-section {
    background: transparent;
    color: var(--paper);
    padding: 120px 40px;
    position: relative;
  }
  .contact-inner {
    max-width: 1600px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    gap: 80px;
    align-items: start;
    position: relative;
  }
  .contact-left h2 {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: clamp(3rem, 6vw, 5.5rem);
    line-height: 0.9;
    letter-spacing: -0.025em;
    text-transform: uppercase;
    margin-bottom: 28px;
  }
  .contact-left h2 .accent { color: var(--orange); font-style: italic; font-weight: 700; }
  .contact-left p {
    color: rgba(245,241,234,0.7);
    margin-bottom: 40px;
    font-size: 1.04rem;
    line-height: 1.6;
    max-width: 460px;
  }
  .contact-info {
    display: flex;
    flex-direction: column;
    gap: 24px;
    margin-bottom: 40px;
  }
  .contact-info-item {
    display: flex;
    gap: 16px;
    align-items: flex-start;
  }
  .contact-info-icon {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: rgba(245,241,234,0.06);
    border: 1px solid rgba(245,241,234,0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--orange);
  }
  .contact-info-text {
    flex: 1;
  }
  .contact-info-label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.65rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: rgba(245,241,234,0.5);
    margin-bottom: 4px;
  }
  .contact-info-value {
    font-size: 1rem;
    color: var(--paper);
    line-height: 1.4;
  }
  .contact-info-value a {
    color: inherit;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,0.2);
    transition: border-color 0.2s, color 0.2s;
  }
  .contact-info-value a:hover { color: var(--orange); border-color: var(--orange); }

  /* === FORM === */
  .contact-form {
    background: rgba(245,241,234,0.06);
    border: 1px solid rgba(245,241,234,0.14);
    padding: 0;
    backdrop-filter: blur(20px);
    position: relative;
    overflow: hidden;
  }
  .contact-form::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: var(--orange);
  }
  .contact-form-header {
    padding: 28px 40px 24px;
    border-bottom: 1px solid rgba(245,241,234,0.08);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
  }
  .contact-form-header-title {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 1.6rem;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: -0.015em;
  }
  .contact-form-header-time {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(245,241,234,0.6);
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .contact-form-header-time::before {
    content: '';
    width: 7px; height: 7px;
    border-radius: 50%;
    background: #6bcb77;
    box-shadow: 0 0 8px #6bcb77;
  }
  .contact-form-body {
    padding: 32px 40px 36px;
  }
  .contact-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 16px;
  }
  .contact-form-group {
    margin-bottom: 16px;
  }
  .contact-form label {
    display: block;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.65rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: rgba(245,241,234,0.6);
    margin-bottom: 8px;
  }
  .contact-form label .req { color: var(--orange); }
  .contact-form input,
  .contact-form select,
  .contact-form textarea {
    width: 100%;
    background: rgba(0,0,0,0.3);
    border: 1px solid rgba(245,241,234,0.12);
    border-radius: 4px;
    padding: 12px 14px;
    color: var(--paper);
    font-family: 'Familjen Grotesk', sans-serif;
    font-size: 0.95rem;
    transition: border-color 0.2s, background 0.2s;
    outline: none;
  }
  .contact-form input:focus,
  .contact-form select:focus,
  .contact-form textarea:focus {
    border-color: var(--orange);
    background: rgba(0,0,0,0.5);
  }
  .contact-form input::placeholder,
  .contact-form textarea::placeholder { color: rgba(245,241,234,0.3); }
  .contact-form textarea {
    resize: vertical;
    min-height: 120px;
    font-family: 'Familjen Grotesk', sans-serif;
  }
  .contact-form select option {
    background: var(--ink);
    color: var(--paper);
  }
  /* Honeypot field — versteckt für echte User, sichtbar für Bots */
  .hp-field {
    position: absolute;
    left: -10000px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
  }
  .contact-form-captcha {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: rgba(0,0,0,0.3);
    border: 1px solid rgba(245,241,234,0.1);
    border-radius: 4px;
    margin-bottom: 16px;
  }
  .contact-form-captcha-q {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.85rem;
    color: rgba(245,241,234,0.7);
    letter-spacing: 0.05em;
  }
  .contact-form-captcha input {
    width: 80px;
    background: rgba(0,0,0,0.4);
    border: 1px solid rgba(245,241,234,0.15);
    border-radius: 3px;
    padding: 6px 10px;
    color: var(--paper);
    font-size: 0.9rem;
    text-align: center;
    font-family: 'JetBrains Mono', monospace;
  }
  .contact-form-checkbox {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 24px;
    font-size: 0.84rem;
    line-height: 1.5;
    color: rgba(245,241,234,0.7);
  }
  .contact-form-checkbox input[type="checkbox"] {
    width: 16px;
    height: 16px;
    margin-top: 2px;
    accent-color: var(--orange);
    flex-shrink: 0;
  }
  .contact-form-checkbox a {
    color: var(--orange);
    text-decoration: underline;
    text-decoration-color: rgba(231,124,5,0.4);
  }
  .contact-form-submit {
    width: 100%;
    background: var(--orange);
    color: white;
    border: none;
    padding: 16px;
    border-radius: 6px;
    font-family: 'Familjen Grotesk', sans-serif;
    font-weight: 700;
    font-size: 0.95rem;
    cursor: none;
    transition: background 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }
  .contact-form-submit:hover { background: var(--orange-deep); }
  .contact-form-submit:disabled {
    opacity: 0.5;
    cursor: not-allowed;
  }
  .contact-form-status {
    margin-top: 16px;
    padding: 12px 16px;
    border-radius: 4px;
    font-size: 0.9rem;
    display: none;
  }
  .contact-form-status.show { display: block; }
  .contact-form-status.success {
    background: rgba(34, 139, 34, 0.15);
    color: #6bcb77;
    border: 1px solid rgba(34, 139, 34, 0.3);
  }
  .contact-form-status.error {
    background: rgba(220, 53, 69, 0.15);
    color: #ff8088;
    border: 1px solid rgba(220, 53, 69, 0.3);
  }
  .contact-form-meta {
    margin-top: 14px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.65rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(245,241,234,0.4);
    text-align: center;
  }
  .contact-form-meta::before {
    content: '🛡 ';
    color: var(--orange);
  }
  @media (max-width: 1100px) {
    .contact-inner { grid-template-columns: 1fr; gap: 60px; }
    .contact-section { padding: 80px 40px; }
  }
  @media (max-width: 640px) {
    .contact-section { padding: 60px 20px; }
    .contact-form-header { padding: 22px 24px 20px; }
    .contact-form-body { padding: 24px 24px 28px; }
    .contact-form-row { grid-template-columns: 1fr; }
  }

  /* ============= RADREISEN ============= */
  .tour-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: 16px;
    margin-top: 60px;
  }
  .tour-card {
    background: var(--paper);
    overflow: hidden;
    cursor: none;
    display: flex;
    flex-direction: column;
    border: 1px solid var(--line);
    transition: transform 0.4s cubic-bezier(0.2, 0, 0.1, 1), box-shadow 0.4s;
    position: relative;
  }
  .tour-card.featured {
    grid-row: span 1;
  }
  .tour-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 30px 60px rgba(10,10,11,0.12);
  }
  .tour-card-img {
    aspect-ratio: 16/11;
    background-size: cover;
    background-position: center;
    position: relative;
    overflow: hidden;
  }
  .tour-card.featured .tour-card-img { aspect-ratio: 16/13; }
  .tour-card-img-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.7s cubic-bezier(0.2, 0, 0.1, 1);
    display: block;
  }
  .tour-card:hover .tour-card-img-bg { transform: scale(1.06); }
  .tour-card-img-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(10,10,11,0.4) 0%, transparent 30%, rgba(10,10,11,0.7) 100%);
    z-index: 1;
  }
  .tour-card-region {
    position: absolute;
    top: 18px; left: 18px;
    background: rgba(10,10,11,0.7);
    backdrop-filter: blur(10px);
    color: var(--paper);
    padding: 7px 12px;
    border-radius: 4px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    z-index: 2;
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .tour-card-flag {
    font-size: 1.1rem;
    line-height: 1;
  }
  .tour-card-overlay-title {
    position: absolute;
    bottom: 18px; left: 18px;
    right: 18px;
    z-index: 2;
    color: var(--paper);
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 2.4rem;
    line-height: 0.9;
    text-transform: uppercase;
    letter-spacing: -0.02em;
  }
  .tour-card.featured .tour-card-overlay-title { font-size: 3.4rem; }
  .tour-card-content {
    padding: 24px;
    display: flex;
    flex-direction: column;
    flex: 1;
  }
  .tour-card-meta {
    display: flex;
    gap: 14px;
    margin-bottom: 14px;
    color: var(--muted);
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }
  .tour-card-meta span { display: flex; align-items: center; gap: 6px; }
  .tour-card-meta span + span::before {
    content: '·';
    margin-right: 8px;
    opacity: 0.5;
  }
  .tour-card-desc {
    color: var(--ink);
    font-size: 0.95rem;
    line-height: 1.55;
    margin-bottom: 22px;
    opacity: 0.8;
    flex: 1;
  }
  .tour-card-foot {
    display: flex;
    justify-content: space-between;
    align-items: end;
    padding-top: 18px;
    border-top: 1px solid var(--line);
  }
  .tour-card-price {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 1.4rem;
    line-height: 1;
    color: var(--ink);
  }
  .tour-card-price small {
    display: block;
    font-size: 0.7rem;
    font-weight: 400;
    color: var(--muted);
    margin-bottom: 4px;
    font-family: 'Familjen Grotesk', sans-serif;
    text-transform: uppercase;
    letter-spacing: 0.1em;
  }
  .tour-card-cta {
    color: var(--ink);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.85rem;
    border-bottom: 2px solid var(--orange);
    padding-bottom: 3px;
    transition: color 0.2s;
  }
  .tour-card:hover .tour-card-cta { color: var(--orange); }

  .reisewelt-partnership {
    margin-top: 60px;
    padding: 32px 40px;
    background: var(--ink);
    color: var(--paper);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    flex-wrap: wrap;
  }
  .reisewelt-partnership-label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.75rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: rgba(245,241,234,0.6);
  }
  .reisewelt-partnership-name {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 2.4rem;
    text-transform: uppercase;
    letter-spacing: -0.02em;
    line-height: 1;
  }
  .reisewelt-partnership-name .accent { color: var(--orange); }
  .reisewelt-partnership-cta {
    font-size: 0.9rem;
    color: var(--paper);
    text-decoration: none;
    border-bottom: 2px solid var(--orange);
    padding-bottom: 3px;
    font-weight: 600;
  }

  /* ============= B2B LEASING ============= */
  .b2b-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-top: 60px;
  }
  .b2b-feature {
    background: var(--paper);
    padding: 40px 36px;
    border: 1px solid rgba(10,10,11,0.1);
    display: flex;
    flex-direction: column;
    gap: 16px;
    position: relative;
    transition: transform 0.3s, border-color 0.3s;
  }
  .b2b-feature:hover {
    transform: translateY(-4px);
    border-color: var(--orange);
  }
  .b2b-feature-num {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 4.5rem;
    line-height: 0.85;
    color: var(--orange);
    letter-spacing: -0.03em;
    margin-bottom: 12px;
  }
  .b2b-feature h3 {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 900;
    font-size: 1.6rem;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: -0.015em;
  }
  .b2b-feature p {
    font-size: 0.95rem;
    line-height: 1.55;
    color: var(--ink);
    opacity: 0.75;
  }

  .leasing-partners {
    margin-top: 60px;
    padding: 32px 40px;
    background: var(--paper);
    border: 1px solid rgba(10,10,11,0.1);
  }
  .leasing-partners-label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 12px;
  }
  .leasing-partners-list {
    font-family: 'Big Shoulders Display', sans-serif;
    font-weight: 700;
    font-size: 1.3rem;
    line-height: 1.4;
    text-transform: uppercase;
    letter-spacing: -0.015em;
  }
  .leasing-partners-list .sep {
    color: var(--orange);
    margin: 0 12px;
    font-weight: 400;
  }
  .leasing-partners-list .primary {
    color: var(--orange);
  }

  .b2b-cta {
    margin-top: 48px;
    text-align: center;
  }
  .b2b-cta .btn {
    font-size: 1rem;
    padding: 16px 32px;
  }

  @media (max-width: 1100px) {
    .tour-grid { grid-template-columns: 1fr 1fr; }
    .tour-card.featured { grid-column: 1 / -1; }
    .b2b-grid { grid-template-columns: 1fr; }
  }
  @media (max-width: 640px) {
    .tour-grid { grid-template-columns: 1fr; }
    .tour-card.featured { grid-column: auto; }
    .reisewelt-partnership { padding: 24px; flex-direction: column; align-items: flex-start; }
    .leasing-partners { padding: 24px; }
    .leasing-partners-list { font-size: 1rem; }
  }

  /* ============= BRAND STORIES ============= */
  .s-warm {
    background: var(--paper-warm);
    color: var(--ink);
  }
  .section-sub {
    color: var(--muted);
    font-size: 1.05rem;
    line-height: 1.6;
    max-width: 360px;
    margin-bottom: 8px;
  }
  .brand-stories {
    margin-top: 60px;
  }
  .brand-story {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
    padding: 80px 0;
    border-top: 1px solid rgba(10,10,11,0.12);
    position: relative;
  }
  .brand-story:first-child { border-top: 2px solid var(--ink); }
  .brand-story:last-child { border-bottom: 2px solid var(--ink); }
  .brand-story.reverse .brand-story-img { order: 2; }
  .brand-story-img {
    aspect-ratio: 4/5;
    background-size: cover;
    background-position: center;
    position: relative;
    overflow: hidden;
    transition: transform 0.6s cubic-bezier(0.2, 0, 0.1, 1);
  }
  .brand-story:hover .brand-story-img-bg {
    transform: scale(1.04);
  }
  .brand-story-img-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.8s cubic-bezier(0.2, 0, 0.1, 1);
    filter: contrast(1.05);
    display: block;
  }
  .brand-story-img-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(10,10,11,0.15) 0%, transparent 40%, rgba(10,10,11,0.65) 100%);
    z-index: 1;
  }
  .brand-story-num {
    position: absolute;
    top: 24px; left: 24px;
    font-family: 'Big Shoulders Display', sans-serif;
    font-size: 5rem;
    font-weight: 900;
    color: var(--paper);
    line-height: 0.85;
    letter-spacing: -0.04em;
    z-index: 2;
    mix-blend-mode: difference;
  }
  .brand-story-tag {
    position: absolute;
    bottom: 24px; left: 24px;
    background: var(--orange);
    color: var(--paper);
    padding: 8px 14px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 500;
    z-index: 2;
  }
  .brand-story-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 28px;
    color: var(--muted);
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
  }
  .brand-story-meta span {
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .brand-story-meta span::before {
    content: '◆';
    color: var(--orange);
    font-size: 0.6em;
  }
  .brand-story-name {
    font-family: 'Big Shoulders Display', sans-serif;
    font-size: clamp(3rem, 6.5vw, 6rem);
    font-weight: 900;
    line-height: 0.85;
    letter-spacing: -0.025em;
    text-transform: uppercase;
    margin-bottom: 18px;
  }
  .brand-story-tagline {
    font-family: 'Familjen Grotesk', sans-serif;
    font-size: 1.5rem;
    font-style: italic;
    font-weight: 500;
    color: var(--orange);
    margin-bottom: 28px;
    letter-spacing: -0.01em;
  }
  .brand-story-text {
    color: var(--ink);
    font-size: 1.04rem;
    line-height: 1.7;
    max-width: 520px;
    margin-bottom: 28px;
    opacity: 0.85;
  }
  .brand-story-facts {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 36px;
  }
  .brand-story-facts .fact {
    background: rgba(10,10,11,0.06);
    color: var(--ink);
    padding: 8px 14px;
    border-radius: 4px;
    font-size: 0.84rem;
    font-weight: 500;
  }
  @media (max-width: 1100px) {
    .brand-story { grid-template-columns: 1fr; gap: 32px; padding: 60px 0; }
    .brand-story.reverse .brand-story-img { order: 0; }
    .brand-story-img { aspect-ratio: 5/4; }
  }

  .footer-logo-top {
    height: 80px;
    width: auto;
    display: block;
    margin-bottom: 28px;
  }
  @media (max-width: 640px) {
    .footer-logo-top { height: 60px; }
  }

  /* ============= RESPONSIVE ============= */
  @media (max-width: 1100px) {
    .nav-links { display: none; }
    .cat-grid, .product-grid { grid-template-columns: repeat(2, 1fr); }
    .service-grid { grid-template-columns: 1fr; }
    .footer-top { grid-template-columns: 1fr 1fr; }
    .hero-bottom { grid-template-columns: 1fr; gap: 24px; }
    .hero-meta-block { align-items: flex-start; text-align: left; }
  }
  @media (max-width: 640px) {
    nav { padding: 16px 20px; gap: 16px; }
    .container { padding: 80px 20px; }
    footer { padding: 80px 20px 24px; }
    .hero-content { padding: 0 24px 60px; }
    .hero-side { display: none; }
    .sound-toggle { right: 16px; width: 48px; height: 48px; }
    .cat-grid, .product-grid { grid-template-columns: 1fr; }
    .footer-top { grid-template-columns: 1fr; gap: 40px; }
    .service-card { padding: 36px; }
    .footer-mark { font-size: 32vw; }

    /* v1.7.8: Header-CTA auf Mobile kompakter, max 2-zeilig. */
    .nav-cta .btn {
      padding: 10px 14px;
      font-size: 0.78rem;
      line-height: 1.25;
      gap: 6px;
      letter-spacing: 0.005em;
      text-align: left;
    }
    .nav-cta .btn svg { width: 11px; height: 11px; flex-shrink: 0; }
  }
  @media (max-width: 420px) {
    .nav-cta .btn svg { display: none; }
    .nav-cta .btn { padding: 10px 12px; }
  }

/* ========================================================================
   v1.0.1 — Cursor-Override: kein Custom-Cursor, klassischer Browser-Pointer.
   Überschreibt die `cursor: none`-Regeln aus dem v13-Mockup gezielt.
   ======================================================================== */

.cursor,
.cursor-ring { display: none !important; }

html, body { cursor: auto !important; }

a, button,
[data-hover],
label,
input[type="submit"],
input[type="button"],
input[type="checkbox"],
input[type="radio"],
select,
.btn, .btn-cta, .nav-cta, .btn-light, .btn-ghost, .btn-primary,
.product-cta, .product-quick a,
.service-card,
.brand-story-img,
.cat-card,
.tour-card,
.vc-booking__btn,
.vc-booking__cal-day,
.vc-booking__slot,
.vc-booking__type,
.vc-booking__radio,
.vc-booking__step {
	cursor: pointer !important;
}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="search"],
input[type="url"],
input[type="password"],
textarea,
[contenteditable="true"] {
	cursor: text !important;
}

input:disabled,
button:disabled,
.is-disabled,
[disabled] {
	cursor: not-allowed !important;
}

/* ========================================================================
   v1.1.0 — Lesbare Typografie für Sub-Pages (Impressum, Datenschutz, AGB).
   Alles unter .vc-page__content gescoped.
   ======================================================================== */

.vc-page__content {
	max-width: 760px;
	color: rgba(245,241,234,0.92);
	font-family: 'Familjen Grotesk', system-ui, sans-serif;
	font-size: 1rem;
	line-height: 1.65;
}

.vc-page__content p {
	margin: 0 0 1.1em;
	color: rgba(245,241,234,0.84);
}

.vc-page__content h2 {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 800;
	font-size: clamp(1.4rem, 2.2vw, 1.85rem);
	line-height: 1.05;
	letter-spacing: -0.005em;
	text-transform: uppercase;
	color: var(--paper);
	margin: 2.4em 0 0.6em;
	padding-top: 1em;
	border-top: 1px solid rgba(245,241,234,0.12);
}

.vc-page__content h2:first-child {
	margin-top: 0;
	padding-top: 0;
	border-top: 0;
}

.vc-page__content h3 {
	font-family: 'Familjen Grotesk', sans-serif;
	font-weight: 600;
	font-size: 1.1rem;
	color: var(--paper);
	margin: 1.6em 0 0.5em;
}

.vc-page__content ul,
.vc-page__content ol {
	margin: 0 0 1.2em;
	padding-left: 1.4em;
}
.vc-page__content li {
	margin-bottom: 0.4em;
	color: rgba(245,241,234,0.84);
}
.vc-page__content li::marker {
	color: var(--orange);
}

.vc-page__content a {
	color: var(--orange);
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1px;
}
.vc-page__content a:hover {
	color: var(--paper);
}

.vc-page__content em {
	color: rgba(245,241,234,0.65);
	font-style: italic;
}

.vc-page__content strong {
	color: var(--paper);
}

/* Hinweis-Boxen für „Vorlage prüfen lassen"-Texte (em am Anfang) */
.vc-page__content > p:first-child em {
	display: block;
	background: rgba(231,124,5,0.08);
	border-left: 3px solid var(--orange);
	padding: 12px 16px;
	font-size: 0.9rem;
	color: rgba(245,241,234,0.78);
	font-style: normal;
}

/* Mobile: Container-Padding */
@media (max-width: 700px) {
	.vc-page__content { font-size: 0.95rem; }
	.vc-page__content h2 { font-size: 1.4rem; }
}

/* ========================================================================
   v1.3.0 — Smooth-Scroll für Anker-Sprünge + Section-Padding für #service.
   ======================================================================== */

html {
	scroll-behavior: smooth;
}

/* Section-Anker: Nav-Höhe einplanen, damit der Headline nicht hinter der
   fixed Nav verschwindet. Nav ist gescrollt ca. 60–80 px hoch. */
section[id] {
	scroll-margin-top: 90px;
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
}

/* ========================================================================
   v1.3.1 — Page-Template-Klassen statt Inline-Styles, Back-Button prominent.
   ======================================================================== */

.vc-page {
	background: var(--ink);
	min-height: 100vh;
	padding: 140px 0 80px;
}

.vc-page__container {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 24px;
	box-sizing: border-box;
}

.vc-page__header {
	margin-bottom: 48px;
}

/* Zur-Startseite-Button: orangener Ghost mit Hover-Fill */
.vc-page__back {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 11px 20px 11px 16px;
	border: 1.5px solid var(--orange);
	border-radius: 4px;
	color: var(--orange);
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.78rem;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	text-decoration: none;
	background: transparent;
	transition: background 0.22s ease, color 0.22s ease, transform 0.18s ease, border-color 0.22s ease;
}

.vc-page__back:hover,
.vc-page__back:focus-visible {
	background: var(--orange);
	color: var(--paper);
	border-color: var(--orange);
	transform: translateX(-3px);
}

.vc-page__back-arrow {
	flex-shrink: 0;
	transition: transform 0.18s ease;
}

.vc-page__back:hover .vc-page__back-arrow {
	transform: translateX(-2px);
}

/* Page-Headline */
.vc-page__title {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: clamp(2.4rem, 5vw, 4rem);
	line-height: 0.9;
	color: var(--paper);
	text-transform: uppercase;
	letter-spacing: -0.01em;
	margin: 28px 0 0;
}

@media (max-width: 600px) {
	.vc-page { padding: 110px 0 60px; }
	.vc-page__back {
		padding: 9px 16px 9px 14px;
		font-size: 0.72rem;
	}
}

/* ========================================================================
   v1.3.4 — Back-to-Top-Button unten links.
   Erscheint nach ~500 px Scroll, smooth-scroll zum Anfang.
   ======================================================================== */

.vc-totop {
	position: fixed;
	bottom: 28px;
	left: 28px;
	z-index: 90;
	width: 52px;
	height: 52px;
	background: var(--orange);
	color: #fff;
	border: 0;
	border-radius: 4px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.25s ease, background 0.2s ease;
	box-shadow: 0 10px 28px rgba(0,0,0,0.28), 0 2px 6px rgba(231,124,5,0.25);
	font-family: inherit;
	padding: 0;
}

.vc-totop.is-visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.vc-totop:hover {
	background: var(--orange-deep);
	transform: translateY(-3px);
	box-shadow: 0 14px 32px rgba(0,0,0,0.32), 0 4px 10px rgba(231,124,5,0.35);
}

.vc-totop:focus-visible {
	outline: 2px solid var(--paper);
	outline-offset: 3px;
}

.vc-totop svg {
	display: block;
	transition: transform 0.2s ease;
}

.vc-totop:hover svg {
	transform: translateY(-2px);
}

@media (max-width: 600px) {
	.vc-totop {
		width: 44px;
		height: 44px;
		bottom: 18px;
		left: 18px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.vc-totop {
		transition: opacity 0.2s, visibility 0.2s !important;
		transform: none !important;
	}
}

/* ========================================================================
   v1.4.0 — Leasing-Page Spezifika.
   Lead-Paragraph, Partner-Block, Callout, PDF-Download, CTA-Button.
   ======================================================================== */

/* Lead-Paragraph: groß, italic, Akzent */
.vc-page__content .vc-leasing-lead {
	font-family: 'Big Shoulders Display', sans-serif;
	font-size: clamp(1.4rem, 2.4vw, 1.95rem);
	line-height: 1.15;
	font-weight: 700;
	font-style: italic;
	color: var(--orange);
	letter-spacing: 0;
	text-transform: none;
	margin: -8px 0 28px;
	padding-bottom: 24px;
	border-bottom: 1px solid rgba(245,241,234,0.15);
}

.vc-page__content .vc-leasing-lead em {
	font-style: italic;
	color: var(--orange);
	background: none;
	border: 0;
	padding: 0;
	display: inline;
	font-size: inherit;
}

/* Partner-Block: velolease-Logo + Tagline, prominent */
.vc-leasing-partner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 14px;
	margin: 28px 0 16px;
	padding: 36px 24px;
	background: rgba(245,241,234,0.04);
	border: 1px solid rgba(245,241,234,0.1);
	border-radius: 6px;
}
.vc-leasing-partner-logo {
	max-width: 260px;
	width: 100%;
	height: auto;
	display: block;
	filter: brightness(0) invert(1);
	opacity: 0.92;
}
.vc-leasing-partner-tagline {
	margin: 0;
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 700;
	font-size: 1.15rem;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--paper);
	text-align: center;
}

/* Callout: orange Card mit zentralem CTA */
.vc-leasing-callout {
	margin: 36px 0 32px;
	padding: 36px 32px;
	background: rgba(231,124,5,0.08);
	border: 1.5px solid var(--orange);
	border-radius: 6px;
	text-align: center;
}
.vc-leasing-callout-title {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 800;
	font-size: clamp(1.25rem, 2vw, 1.65rem);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--orange);
	margin-bottom: 14px;
}
.vc-leasing-callout-text {
	color: rgba(245,241,234,0.92) !important;
	margin: 0 0 22px !important;
	max-width: 580px;
	margin-left: auto !important;
	margin-right: auto !important;
}
a.vc-leasing-cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 13px 26px;
	background: var(--orange);
	color: var(--paper);
	border: 0;
	border-radius: 4px;
	font-family: 'Familjen Grotesk', sans-serif;
	font-size: 0.98rem;
	font-weight: 600;
	text-decoration: none !important;
	transition: background 0.2s, transform 0.18s, box-shadow 0.2s;
	box-shadow: 0 6px 18px rgba(231,124,5,0.28);
}
a.vc-leasing-cta:hover {
	background: var(--orange-deep);
	color: var(--paper) !important;
	transform: translateY(-2px);
	box-shadow: 0 10px 24px rgba(231,124,5,0.35);
}

/* PDF-Download: prominenter Button mit Icon und Meta */
a.vc-leasing-pdf {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	margin: 24px 0 8px;
	padding: 16px 22px;
	background: rgba(245,241,234,0.04);
	border: 1px solid var(--orange);
	border-radius: 4px;
	color: var(--paper);
	font-family: 'Familjen Grotesk', sans-serif;
	font-size: 0.95rem;
	text-decoration: none !important;
	transition: background 0.2s, border-color 0.2s, transform 0.18s;
}
a.vc-leasing-pdf:hover {
	background: var(--orange);
	color: var(--paper) !important;
	transform: translateY(-1px);
}
a.vc-leasing-pdf svg {
	flex-shrink: 0;
	color: var(--orange);
	transition: color 0.2s;
}
a.vc-leasing-pdf:hover svg {
	color: var(--paper);
}
.vc-leasing-pdf-meta {
	display: block;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.7rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	opacity: 0.7;
	margin-top: 2px;
}

/* Mobile-Anpassungen */
@media (max-width: 600px) {
	.vc-leasing-callout { padding: 24px 18px; }
	.vc-leasing-partner { padding: 24px 16px; }
	.vc-leasing-partner-logo { max-width: 200px; }
	a.vc-leasing-pdf { padding: 14px 16px; gap: 12px; }
}

/* ========================================================================
   v1.4.1 — Leasing-Partner-Grid (12 Cards) + Print-CSS für Flyer-Druck.
   ======================================================================== */

.vc-leasing-partners-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	margin: 28px 0 36px;
}

.vc-leasing-partner-card {
	position: relative;
	background: var(--paper);
	border: 1px solid rgba(245,241,234,0.1);
	border-radius: 4px;
	padding: 22px 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 110px;
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.vc-leasing-partner-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 22px rgba(0,0,0,0.18);
}

.vc-leasing-partner-card img {
	max-width: 100%;
	max-height: 56px;
	width: auto;
	height: auto;
	object-fit: contain;
	display: block;
}

/* Text-Platzhalter für Partner ohne Logo */
.vc-leasing-partner-card--text .vc-leasing-partner-name {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 700;
	font-size: 1.1rem;
	letter-spacing: 0.02em;
	color: var(--ink);
	text-align: center;
	line-height: 1.15;
	text-transform: none;
}

.vc-leasing-partner-card--text {
	background: var(--paper-warm);
}

.vc-leasing-partner-card--text::before {
	content: "";
	position: absolute;
	top: 8px;
	right: 8px;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: rgba(10,10,11,0.18);
}

/* Hauspartner: orangefarbene Hervorhebung */
.vc-leasing-partner-card--featured {
	border: 2px solid var(--orange);
	box-shadow: 0 6px 20px rgba(231,124,5,0.18);
}

.vc-leasing-partner-card--featured:hover {
	box-shadow: 0 10px 26px rgba(231,124,5,0.28);
}

.vc-leasing-partner-badge {
	position: absolute;
	top: -10px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--orange);
	color: var(--paper);
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.6rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 4px 10px;
	border-radius: 3px;
	white-space: nowrap;
}

/* Mobile-Anpassungen */
@media (max-width: 900px) {
	.vc-leasing-partners-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
	.vc-leasing-partners-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
	.vc-leasing-partner-card { min-height: 90px; padding: 16px 10px; }
	.vc-leasing-partner-card img { max-height: 44px; }
	.vc-leasing-partner-card--text .vc-leasing-partner-name { font-size: 0.95rem; }
}

/* ========================================================================
   PRINT-CSS — Wer die Leasing-Page druckt oder als PDF speichert,
   bekommt einen sauberen Flyer im velocultour-Look.
   ======================================================================== */

@media print {
	@page {
		size: A4;
		margin: 18mm 16mm;
	}

	html, body {
		background: #fff !important;
		color: #111 !important;
		font-size: 10.5pt;
		line-height: 1.42;
	}

	/* Theme-Chrome ausblenden */
	nav, footer, .marquee, .loader, .cursor, .cursor-ring,
	.vc-totop, .vc-page__back,
	.brand-strip, .service-ticker, .service-section,
	.section-eyebrow {
		display: none !important;
	}

	.vc-page,
	.vc-page__container,
	.vc-page__article,
	.vc-page__content {
		background: #fff !important;
		color: #111 !important;
		padding: 0 !important;
		margin: 0 !important;
		max-width: 100% !important;
	}

	.vc-page__title {
		color: #111 !important;
		font-size: 26pt !important;
		line-height: 1 !important;
		margin: 0 0 6mm 0 !important;
		page-break-after: avoid;
	}

	.vc-page__content h2 {
		color: #111 !important;
		font-size: 14pt !important;
		margin: 8mm 0 3mm !important;
		padding: 3mm 0 0 !important;
		border-top: 0.5pt solid #ccc !important;
		page-break-after: avoid;
	}

	.vc-page__content h3 {
		color: #111 !important;
		font-size: 12pt !important;
		margin: 5mm 0 2mm !important;
	}

	.vc-page__content p,
	.vc-page__content li {
		color: #222 !important;
	}

	.vc-page__content a {
		color: #111 !important;
		text-decoration: underline;
	}

	.vc-page__content ul,
	.vc-page__content ol {
		page-break-inside: avoid;
	}

	/* Lead-Paragraph: dezent in print */
	.vc-page__content .vc-leasing-lead {
		color: #C66700 !important;
		border-bottom: 0.5pt solid #ccc !important;
		font-size: 14pt !important;
		padding-bottom: 4mm !important;
	}

	/* Partner-Block */
	.vc-leasing-partner {
		background: #f5f1ea !important;
		border: 0.5pt solid #ddd !important;
		padding: 6mm !important;
		page-break-inside: avoid;
	}
	.vc-leasing-partner-logo {
		filter: none !important;
		opacity: 1 !important;
		max-width: 50mm !important;
	}
	.vc-leasing-partner-tagline {
		color: #111 !important;
	}

	/* Partner-Grid */
	.vc-leasing-partners-grid {
		grid-template-columns: repeat(4, 1fr) !important;
		gap: 4mm !important;
		page-break-inside: avoid;
	}
	.vc-leasing-partner-card {
		background: #fff !important;
		border: 0.5pt solid #ccc !important;
		min-height: 22mm !important;
		padding: 4mm !important;
		box-shadow: none !important;
	}
	.vc-leasing-partner-card--featured {
		border: 1pt solid #C66700 !important;
		box-shadow: none !important;
	}
	.vc-leasing-partner-card--text {
		background: #fafafa !important;
	}
	.vc-leasing-partner-card--text .vc-leasing-partner-name {
		color: #111 !important;
		font-size: 9pt !important;
	}
	.vc-leasing-partner-badge {
		background: #C66700 !important;
		color: #fff !important;
	}

	/* Callout */
	.vc-leasing-callout {
		background: #fff5e8 !important;
		border: 1pt solid #C66700 !important;
		padding: 6mm !important;
		page-break-inside: avoid;
	}
	.vc-leasing-callout-title { color: #C66700 !important; }
	.vc-leasing-callout-text { color: #222 !important; }
	a.vc-leasing-cta {
		background: #C66700 !important;
		color: #fff !important;
		box-shadow: none !important;
		display: inline-block !important;
	}

	/* PDF-Download-Button: in der Print-Version irrelevant — ausblenden */
	a.vc-leasing-pdf {
		display: none !important;
	}

	/* Standardmäßiger Print-Footer mit URL der Page */
	.vc-page__article::after {
		content: "velocultour.de/leasing  ·  Stand: " attr(data-print-date);
		display: block;
		margin-top: 8mm;
		padding-top: 3mm;
		border-top: 0.5pt solid #ccc;
		font-size: 8pt;
		color: #666;
		text-align: center;
	}

	/* Links: URLs in Klammern hinter dem Linktext anzeigen — nur bei externen Links */
	.vc-page__content a[href^="http"]::after {
		content: " (" attr(href) ")";
		font-size: 8pt;
		color: #666;
	}
}

/* ========================================================================
   v1.4.2 — BIDEX-Siegel dezent im Footer-Bottom.
   ======================================================================== */

.footer-bottom-left {
	display: flex;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
}

.footer-bottom-text {
	font-size: inherit;
	color: inherit;
}

.footer-bidex {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
	transition: opacity 0.22s ease, transform 0.18s ease;
	opacity: 0.78;
}

.footer-bidex:hover {
	opacity: 1;
	transform: translateY(-1px);
}

.footer-bidex img {
	display: block;
	width: 56px;
	height: 56px;
	object-fit: contain;
}

@media (max-width: 600px) {
	.footer-bottom-left { gap: 12px; }
	.footer-bidex img { width: 46px; height: 46px; }
}

/* Print: BIDEX-Siegel im Druck dezent mitnehmen */
@media print {
	.footer-bidex { opacity: 1 !important; }
	.footer-bidex img { width: 14mm !important; height: 14mm !important; }
}

/* ========================================================================
   v1.5.0 — Bike-Showcase: /angebote/-Archive + /angebote/{slug}/-Single.
   ======================================================================== */

/* ============= BIKE-ARCHIVE-PAGE ============= */
.vc-bikes-archive .vc-page__header {
	margin-bottom: 56px;
}
.vc-page__eyebrow {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--orange);
	margin: 6px 0 12px;
}
.vc-page__subtitle {
	font-size: 1.05rem;
	color: rgba(245,241,234,0.75);
	max-width: 640px;
	margin: 18px 0 0;
	line-height: 1.55;
}

/* ============= BIKE-GRID ============= */
.vc-bike-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin: 0 0 48px;
}
@media (max-width: 960px) { .vc-bike-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .vc-bike-grid { grid-template-columns: 1fr; gap: 18px; } }

.vc-bike-card {
	position: relative;
	background: var(--ink-soft);
	border: 1px solid rgba(245,241,234,0.08);
	border-radius: 6px;
	overflow: hidden;
	transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}
.vc-bike-card:hover {
	transform: translateY(-3px);
	border-color: rgba(231,124,5,0.4);
	box-shadow: 0 16px 40px rgba(0,0,0,0.32);
}

.vc-bike-card__link {
	display: block;
	color: var(--paper);
	text-decoration: none;
}
.vc-bike-card__link:hover { color: var(--paper); }

.vc-bike-card__image {
	position: relative;
	aspect-ratio: 4 / 3;
	background: var(--ink);
	overflow: hidden;
}
.vc-bike-card__image img,
.vc-bike-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.5s ease;
}
.vc-bike-card:hover .vc-bike-card__img {
	transform: scale(1.04);
}

.vc-bike-card__placeholder {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--ink-soft) 0%, var(--ink) 100%);
	color: rgba(245,241,234,0.18);
}

.vc-bike-card__status {
	position: absolute;
	top: 14px;
	left: 14px;
	padding: 5px 10px;
	border-radius: 3px;
	background: rgba(0,0,0,0.85);
	color: var(--paper);
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.65rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 600;
}
.vc-bike-card--reserviert .vc-bike-card__status { background: #b06a00; color: #fff; }
.vc-bike-card--verkauft .vc-bike-card__status   { background: #555; color: #fff; }
.vc-bike-card--verkauft .vc-bike-card__img      { opacity: 0.55; filter: grayscale(0.5); }

.vc-bike-card__featured {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: var(--orange);
	color: var(--paper);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.95rem;
	box-shadow: 0 4px 14px rgba(231,124,5,0.4);
}

.vc-bike-card__body {
	padding: 22px 22px 24px;
}

.vc-bike-card__meta-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 8px;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(245,241,234,0.55);
}
.vc-bike-card__brand { color: var(--orange); font-weight: 600; }
.vc-bike-card__rating { color: rgba(245,241,234,0.65); }

.vc-bike-card__name {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 800;
	font-size: 1.5rem;
	line-height: 1.05;
	letter-spacing: -0.005em;
	text-transform: uppercase;
	color: var(--paper);
	margin: 0 0 6px;
}

.vc-bike-card__tagline {
	font-size: 0.88rem;
	color: rgba(245,241,234,0.62);
	margin: 0 0 16px;
	line-height: 1.4;
}

.vc-bike-card__footer {
	margin: 18px 0 14px;
	padding-top: 14px;
	border-top: 1px solid rgba(245,241,234,0.08);
}

.vc-bike-card__price {
	display: flex;
	align-items: baseline;
	gap: 6px;
	flex-wrap: wrap;
}
.vc-bike-card__price-label {
	font-size: 0.78rem;
	color: rgba(245,241,234,0.55);
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
.vc-bike-card__price-value {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 800;
	font-size: 1.5rem;
	color: var(--paper);
}
.vc-bike-card__leasing {
	font-size: 0.78rem;
	color: rgba(245,241,234,0.5);
	margin-top: 4px;
}

.vc-bike-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--orange);
	font-weight: 600;
	transition: gap 0.2s ease;
}
.vc-bike-card:hover .vc-bike-card__cta { gap: 10px; }

/* ============= ARCHIVE-FOOTER ============= */
.vc-bikes-archive__footer {
	margin: 40px 0 0;
	padding: 36px 32px;
	background: rgba(231,124,5,0.06);
	border: 1px solid rgba(231,124,5,0.3);
	border-radius: 6px;
	text-align: center;
}
.vc-bikes-archive__footer p {
	color: rgba(245,241,234,0.85) !important;
	margin: 0 0 18px !important;
}
.vc-bikes-archive__empty {
	padding: 80px 20px;
	text-align: center;
	color: rgba(245,241,234,0.6);
}

/* ============= BIKE-SINGLE ============= */
.vc-bike-single__container {
	max-width: 1280px;
}
.vc-bike-single__header {
	margin-bottom: 32px;
}

.vc-bike-single__layout {
	display: grid;
	grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
	gap: 56px;
	align-items: start;
}
@media (max-width: 960px) {
	.vc-bike-single__layout { grid-template-columns: 1fr; gap: 36px; }
}

/* Linke Spalte: Visual */
.vc-bike-single__image {
	position: relative;
	aspect-ratio: 4 / 3;
	background: var(--ink-soft);
	border-radius: 6px;
	overflow: hidden;
	border: 1px solid rgba(245,241,234,0.08);
}
.vc-bike-single__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.vc-bike-single__status {
	position: absolute;
	top: 18px;
	left: 18px;
	padding: 7px 14px;
	background: rgba(0,0,0,0.85);
	color: var(--paper);
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	border-radius: 3px;
}
.vc-bike-single__status--reserviert { background: #b06a00; }
.vc-bike-single__status--verkauft   { background: #555; }

.vc-bike-single__description {
	margin-top: 28px;
	color: rgba(245,241,234,0.82);
	line-height: 1.65;
}
.vc-bike-single__description p { margin: 0 0 1em; color: inherit; }

/* Rechte Spalte: Info */
.vc-bike-single__meta-top {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(245,241,234,0.6);
	margin-bottom: 12px;
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}
.vc-bike-single__brand { color: var(--orange); font-weight: 700; }
.vc-bike-single__rating { margin-left: auto; color: rgba(245,241,234,0.7); }

.vc-bike-single__title {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: clamp(2rem, 4vw, 3rem);
	line-height: 0.95;
	letter-spacing: -0.005em;
	text-transform: uppercase;
	color: var(--paper);
	margin: 0 0 12px;
}

.vc-bike-single__tagline {
	font-size: 1.05rem;
	color: rgba(245,241,234,0.7) !important;
	margin: 0 0 28px !important;
}

.vc-bike-single__price-block {
	margin: 0 0 28px;
	padding: 22px 24px;
	background: rgba(245,241,234,0.04);
	border-left: 3px solid var(--orange);
	border-radius: 0 4px 4px 0;
}
.vc-bike-single__price-label {
	display: inline-block;
	margin-right: 6px;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.78rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(245,241,234,0.55);
	vertical-align: middle;
}
.vc-bike-single__price-value {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: 2.2rem;
	color: var(--paper);
	letter-spacing: -0.005em;
}
.vc-bike-single__leasing {
	margin-top: 10px;
	font-size: 0.85rem;
	color: rgba(245,241,234,0.65) !important;
}
.vc-bike-single__leasing a { color: var(--orange); }

.vc-bike-single__section-title {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--orange);
	margin: 0 0 12px;
	padding-bottom: 8px;
	border-bottom: 1px solid rgba(245,241,234,0.1);
}

.vc-bike-single__highlights {
	margin: 0 0 28px;
}
.vc-bike-single__highlights ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.vc-bike-single__highlights li {
	padding: 8px 0 8px 24px;
	position: relative;
	color: rgba(245,241,234,0.85);
	border-bottom: 1px solid rgba(245,241,234,0.06);
}
.vc-bike-single__highlights li::before {
	content: "✓";
	position: absolute;
	left: 0;
	color: var(--orange);
	font-weight: 700;
}

.vc-bike-single__cta-block {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin: 0 0 32px;
}
.vc-bike-single__cta-block .btn {
	justify-content: center;
}

.vc-bike-single__specs dl {
	display: grid;
	grid-template-columns: 1fr 1.3fr;
	gap: 10px 18px;
	margin: 0;
}
.vc-bike-single__specs dt {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(245,241,234,0.55);
	padding: 6px 0;
}
.vc-bike-single__specs dd {
	margin: 0;
	padding: 6px 0;
	color: rgba(245,241,234,0.92);
	border-bottom: 1px solid rgba(245,241,234,0.06);
}
.vc-bike-single__specs dt {
	border-bottom: 1px solid rgba(245,241,234,0.06);
}

/* Print für Bike-Single */
@media print {
	.vc-bike-single__layout { grid-template-columns: 1fr 1fr; }
	.vc-bike-single, .vc-bike-single * { color: #111 !important; background: transparent !important; }
	.vc-bike-single__image { border: 0.5pt solid #ccc !important; }
	.vc-bike-single__price-block { background: #fff5e8 !important; border-left: 2pt solid #C66700 !important; }
	.vc-bike-single__cta-block { display: none !important; }
}

/* ========================================================================
   v1.5.1 — Topic-Pre-Select-Highlight im Kontaktformular.
   Wenn das Thema via ?topic=… vorausgefüllt wurde, kurz orange aufblitzen.
   ======================================================================== */

@keyframes vcCfTopicGlow {
	0%, 100% { box-shadow: 0 0 0 0 rgba(231,124,5,0); }
	30%      { box-shadow: 0 0 0 4px rgba(231,124,5,0.45); }
}

#cf-topic.cf-topic-prefilled {
	animation: vcCfTopicGlow 2.2s ease;
	border-color: var(--orange) !important;
}

/* ========================================================================
   v1.5.2 — Angebote-CTA-Banner direkt nach dem Brand-Strip.
   Cream-BG mit oranger Border-Accent, Editorial-Look.
   ======================================================================== */

.angebote-banner {
	background: var(--paper);
	border-top: 1px solid rgba(10,10,11,0.06);
	border-bottom: 1px solid rgba(10,10,11,0.06);
	padding: 72px 0;
	position: relative;
}

/* Subtiler Orange-Akzent links als Editorial-Touch */
.angebote-banner::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 4px;
	background: var(--orange);
	opacity: 0.7;
}

.angebote-banner__inner {
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
	gap: 56px;
	align-items: center;
}

.angebote-banner__eyebrow {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--orange);
	margin-bottom: 14px;
}

.angebote-banner__title {
	/* v1.7.5: vereinheitlicht auf .section-head h2 (vorher max 3.4rem) */
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: clamp(2.6rem, 5.8vw, 4.6rem);
	line-height: 0.9;
	letter-spacing: -0.02em;
	text-transform: uppercase;
	color: var(--ink);
	margin: 0 0 18px;
}

.angebote-banner__title .italic {
	font-style: italic;
	font-weight: 600; /* v1.7.7: einheitlich mit .section-head h2 .italic */
}

.angebote-banner__title .accent {
	color: var(--orange);
}

.angebote-banner__sub {
	font-size: 1.05rem;
	line-height: 1.55;
	color: rgba(10,10,11,0.7);
	margin: 0;
	max-width: 480px;
}

.angebote-banner__actions {
	display: flex;
	flex-direction: column;
	gap: 18px;
	align-items: flex-start;
}

.angebote-banner__cta {
	font-size: 1rem;
	padding: 15px 28px;
}

/* Live-Counter daneben */
.angebote-banner__meta {
	display: flex;
	align-items: baseline;
	gap: 10px;
	padding-left: 4px;
}

.angebote-banner__meta-num {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: 2.6rem;
	line-height: 1;
	color: var(--orange);
	font-variant-numeric: tabular-nums;
}

.angebote-banner__meta-label {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.74rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(10,10,11,0.6);
}

/* Mobile */
@media (max-width: 900px) {
	.angebote-banner { padding: 56px 0; }
	.angebote-banner__inner {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	.angebote-banner__sub { max-width: 100%; }
}

/* ========================================================================
   v1.6.0 — CO2-Rechner: Page-Calculator + Homepage-Teaser-Card.
   Grüner Akzent (eco) parallel zum bestehenden Orange-System.
   ======================================================================== */

:root {
	--eco: #2E8B57;
	--eco-deep: #246E45;
	--eco-soft: rgba(46,139,87,0.12);
}

/* Marquee-Link klickbar machen */
.marquee a.marquee-link {
	color: inherit;
	text-decoration: underline;
	text-underline-offset: 4px;
	text-decoration-thickness: 1px;
}
.marquee a.marquee-link:hover {
	text-decoration-thickness: 2px;
}

/* ============= HOMEPAGE-TEASER-CARD ============= */
.co2-teaser {
	background: var(--paper);
	padding: 40px 0;
	border-top: 1px solid rgba(10,10,11,0.06);
	border-bottom: 1px solid rgba(10,10,11,0.06);
}

.co2-teaser__card {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) auto;
	align-items: center;
	gap: 32px;
	background: linear-gradient(135deg, var(--eco) 0%, var(--eco-deep) 100%);
	color: var(--paper);
	padding: 28px 32px;
	border-radius: 6px;
	text-decoration: none !important;
	transition: transform 0.22s ease, box-shadow 0.22s ease;
	box-shadow: 0 12px 32px rgba(46,139,87,0.22);
}

.co2-teaser__card:hover {
	transform: translateY(-3px);
	box-shadow: 0 18px 42px rgba(46,139,87,0.32);
}

.co2-teaser__icon {
	width: 84px;
	height: 84px;
	border-radius: 50%;
	background: rgba(255,255,255,0.18);
	border: 2px solid rgba(255,255,255,0.4);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.co2-teaser__icon-text {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: 1.5rem;
	color: var(--paper);
	letter-spacing: -0.01em;
}
.co2-teaser__icon-text sub {
	font-size: 0.85em;
	vertical-align: baseline;
}

.co2-teaser__eyebrow {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	opacity: 0.85;
	margin-bottom: 6px;
}
.co2-teaser__headline {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 800;
	font-size: clamp(1.3rem, 2.4vw, 1.85rem);
	line-height: 1.05;
	letter-spacing: -0.005em;
	text-transform: uppercase;
	margin-bottom: 4px;
}
.co2-teaser__headline strong { color: var(--paper); }
.co2-teaser__sub {
	font-size: 0.95rem;
	line-height: 1.45;
	opacity: 0.92;
}

.co2-teaser__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 22px;
	background: var(--paper);
	color: var(--eco-deep);
	font-family: 'Familjen Grotesk', sans-serif;
	font-size: 0.95rem;
	font-weight: 700;
	border-radius: 4px;
	white-space: nowrap;
	flex-shrink: 0;
	transition: gap 0.2s ease;
}
.co2-teaser__card:hover .co2-teaser__cta {
	gap: 12px;
}

@media (max-width: 800px) {
	.co2-teaser__card {
		grid-template-columns: 1fr;
		text-align: center;
		padding: 28px 22px;
		gap: 18px;
	}
	.co2-teaser__icon { margin: 0 auto; }
	.co2-teaser__cta { justify-content: center; }
}

/* ============= CO2-RECHNER (Page-Widget) ============= */
.vc-co2-rechner {
	margin: 32px 0 24px;
	background: var(--ink-soft);
	border: 1px solid rgba(245,241,234,0.1);
	border-radius: 6px;
	padding: 36px;
}

.vc-co2-controls { margin-bottom: 28px; }

.vc-co2-vs {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 32px;
	margin-bottom: 28px;
	padding-bottom: 24px;
	border-bottom: 1px solid rgba(245,241,234,0.1);
}
.vc-co2-vs__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}
.vc-co2-vs__item--auto { color: #d65a5a; }
.vc-co2-vs__item--bike { color: var(--eco); }
.vc-co2-vs__item span {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.78rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(245,241,234,0.85);
}
.vc-co2-vs__sep {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: 1.6rem;
	color: var(--orange);
	font-style: italic;
}

.vc-co2-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 28px;
	margin-bottom: 22px;
}
.vc-co2-row--types { grid-template-columns: 1fr 1fr; }
@media (max-width: 700px) {
	.vc-co2-row, .vc-co2-row--types { grid-template-columns: 1fr; gap: 18px; }
}

.vc-co2-field label {
	display: block;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.74rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(245,241,234,0.7);
	margin-bottom: 10px;
}
.vc-co2-field label strong {
	color: var(--orange);
	font-weight: 700;
	margin-left: 4px;
}
.vc-co2-field input[type="range"] {
	width: 100%;
	accent-color: var(--orange);
	cursor: pointer;
}

.vc-co2-types {
	border: 1px solid rgba(245,241,234,0.1);
	border-radius: 4px;
	padding: 16px 18px;
	margin: 0;
	background: rgba(245,241,234,0.03);
}
.vc-co2-types legend {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--orange);
	padding: 0 8px;
}
.vc-co2-types label {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 7px 0;
	cursor: pointer;
	color: rgba(245,241,234,0.85);
	font-size: 0.92rem;
}
.vc-co2-types label input { accent-color: var(--orange); }
.vc-co2-types label em {
	margin-left: auto;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.06em;
	color: rgba(245,241,234,0.55);
	font-style: normal;
}
.vc-co2-types label span { display: flex; align-items: center; flex: 1; gap: 8px; }
.vc-co2-types label:hover { color: var(--paper); }

/* Result-Block */
.vc-co2-result {
	display: grid;
	grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
	gap: 28px;
	margin-top: 28px;
	padding-top: 28px;
	border-top: 1px solid rgba(245,241,234,0.1);
}
@media (max-width: 800px) {
	.vc-co2-result { grid-template-columns: 1fr; }
}

.vc-co2-bars { display: flex; flex-direction: column; gap: 18px; }
.vc-co2-bar__head {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: 6px;
}
.vc-co2-bar__label {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(245,241,234,0.65);
}
.vc-co2-bar__value {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 800;
	font-size: 1.4rem;
	color: var(--paper);
}
.vc-co2-bar__track {
	height: 14px;
	background: rgba(245,241,234,0.08);
	border-radius: 3px;
	overflow: hidden;
}
.vc-co2-bar__fill {
	height: 100%;
	transition: width 0.4s ease;
	border-radius: 3px;
}
.vc-co2-bar--auto .vc-co2-bar__fill { background: linear-gradient(90deg, #d65a5a 0%, #b34141 100%); }
.vc-co2-bar--bike .vc-co2-bar__fill { background: linear-gradient(90deg, var(--eco) 0%, var(--eco-deep) 100%); }

.vc-co2-savings {
	background: linear-gradient(135deg, var(--eco) 0%, var(--eco-deep) 100%);
	color: var(--paper);
	padding: 24px 26px;
	border-radius: 6px;
	box-shadow: 0 10px 28px rgba(46,139,87,0.28);
}
.vc-co2-savings__label {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	opacity: 0.92;
}
.vc-co2-savings__big {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: clamp(2.2rem, 4vw, 3rem);
	line-height: 1;
	margin: 8px 0 12px;
	letter-spacing: -0.01em;
}
.vc-co2-savings__sub {
	font-size: 0.9rem;
	line-height: 1.5;
	opacity: 0.95;
	color: var(--paper) !important;
}
.vc-co2-savings__sub strong { color: var(--paper); }

.vc-co2-source {
	margin-top: 24px;
	padding-top: 18px;
	border-top: 1px dashed rgba(245,241,234,0.15);
	font-size: 0.78rem;
	color: rgba(245,241,234,0.55);
	line-height: 1.5;
}
.vc-co2-source strong { color: rgba(245,241,234,0.75); }

/* CO2-Lead-Paragraph (intro) */
.vc-page__content .vc-co2-lead {
	font-family: 'Big Shoulders Display', sans-serif;
	font-size: clamp(1.4rem, 2.4vw, 1.95rem);
	line-height: 1.15;
	font-weight: 700;
	font-style: italic;
	color: var(--eco);
	letter-spacing: 0;
	text-transform: none;
	margin: -8px 0 28px;
	padding-bottom: 24px;
	border-bottom: 1px solid rgba(245,241,234,0.15);
}
.vc-page__content .vc-co2-lead em {
	font-style: italic;
	background: none;
	border: 0;
	padding: 0;
	display: inline;
	color: inherit;
	font-size: inherit;
}

/* Mobile-Polish */
@media (max-width: 600px) {
	.vc-co2-rechner { padding: 24px 20px; }
	.vc-co2-vs { gap: 22px; }
}

/* ========================================================================
   v1.6.1 — Background-Fotos für Banner + Angebote-Page, mehr Row-Gap.
   ======================================================================== */

/* Angebote-Banner: weiches Bike-Foto im Hintergrund, Cream-Tint drüber */
.angebote-banner {
	position: relative;
	overflow: hidden;
}
.angebote-banner::after {
	/* Cream-Tint-Overlay über dem <img class="angebote-banner__bg"> (v1.6.7) */
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(rgba(245,241,234,0.86), rgba(245,241,234,0.94));
	z-index: 1;
	pointer-events: none;
}
.angebote-banner > .container {
	position: relative;
	z-index: 2;
}

/* Angebote-Archive: cinematisches Trail-Bild im Background, dunkel überlagert */
.vc-bikes-archive::before {
	content: "";
	position: fixed;
	inset: 0;
	background:
		linear-gradient(rgba(10,10,11,0.88), rgba(10,10,11,0.94)),
		url('img/hero-loader.jpg') center/cover no-repeat fixed;
	z-index: 0;
	pointer-events: none;
}
.vc-bikes-archive > .vc-page__container {
	position: relative;
	z-index: 1;
}

/* Auch für Single-Bike-Page: dasselbe Background-Treatment */
.vc-bike-single::before {
	content: "";
	position: fixed;
	inset: 0;
	background:
		linear-gradient(rgba(10,10,11,0.9), rgba(10,10,11,0.96)),
		url('img/hero-loader.jpg') center/cover no-repeat fixed;
	z-index: 0;
	pointer-events: none;
}
.vc-bike-single > .vc-page__container {
	position: relative;
	z-index: 1;
}

/* Bike-Grid: mehr Luft zwischen den Reihen */
.vc-bike-grid {
	row-gap: 48px;
}
@media (max-width: 600px) {
	.vc-bike-grid { row-gap: 24px; }
}

/* ========================================================================
 * v1.6.6 — Klartext-Klick-Durchgriff auf Card-Bilder
 * ------------------------------------------------------------------------
 * Bei den Cat-Cards, Brand-Stories und Tour-Cards liegen dekorative
 * Overlay-Layer ganzflächig (inset:0) über den <img>-Tags. Sie fangen
 * den Klick ab, bevor er das Bild erreicht — Klartext-Extension kann
 * das Bild dadurch nicht selektieren.
 *
 * Lösung: Alle nicht-interaktiven Overlay-Layer auf pointer-events:none.
 * Klickbare Elemente (Tour-CTA, Brand-Story-Button) liegen unterhalb
 * des Bildes im Content-Block und sind nicht betroffen.
 * ======================================================================== */

/* Cat-Cards: Gradient-Overlay, Pfeil-Badge, Text-Content über dem Bild */
.cat-card-overlay,
.cat-card-arrow,
.cat-card-content { pointer-events: none; }

/* Tour-Cards: Bild-Overlay-Gradient, Region-Badge, Overlay-Titel */
.tour-card-img-overlay,
.tour-card-region,
.tour-card-overlay-title { pointer-events: none; }

/* Brand-Stories: Bild-Overlay-Gradient, Nummer-Badge, Tag-Label */
.brand-story-img-overlay,
.brand-story-num,
.brand-story-tag { pointer-events: none; }

/* Sicherheitsnetz: Bilder selbst dürfen Klicks empfangen */
.cat-card-img,
.tour-card-img-bg,
.brand-story-img-bg { pointer-events: auto; }

/* ========================================================================
 * v1.6.7 — Footer- & Angebote-Banner-BGs als <img> (Klartext-tauglich)
 * ------------------------------------------------------------------------
 * .dark-zone-bg ersetzt die alte ::before-Pseudo-Schicht mit base64-data-URL
 * .angebote-banner__bg ersetzt die url(...) im ::after
 * Beide liegen jetzt als echte <img> im DOM und können von Klartext
 * angeklickt werden.
 * ======================================================================== */

.dark-zone .dark-zone-bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	opacity: 0.18;
	filter: grayscale(0.5) contrast(1.05) brightness(0.85);
	z-index: 0 !important; /* überschreibt .dark-zone > * { z-index: 2 } */
	display: block;
}

.angebote-banner__bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	z-index: 0;
	display: block;
}

/* ========================================================================
 * v1.6.10 — Reisewelt-Partnership: Schriftzug durch Logo ersetzt
 * ======================================================================== */
.reisewelt-partnership-logo {
	display: block;
	height: 88px;
	width: auto;
	max-width: 100%;
	margin-top: 8px;
}
@media (max-width: 600px) {
	.reisewelt-partnership-logo { height: 64px; }
}

/* ========================================================================
 * v1.7.0 — Banner + Featured-Bikes verschmolzen
 * ------------------------------------------------------------------------
 * Der angebote-banner trägt jetzt zusätzlich das 3-Card-Featured-Grid.
 * Header oben (text + actions), darunter die 3 Featured-Cards aus CPT.
 * ======================================================================== */

.angebote-banner--featured .angebote-banner__featured-wrap {
	margin-top: 56px;
	position: relative;
	z-index: 2;
}

.angebote-banner--featured .angebote-banner__featured-wrap .product-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
}

/* Card-Optik im hellen Banner-BG: leichter Shadow + Cream-Background */
.angebote-banner--featured .product-card {
	background: #ffffff;
	box-shadow: 0 8px 24px rgba(10,10,11,0.06);
	transition: transform 0.4s cubic-bezier(0.2,0,0.1,1), box-shadow 0.4s ease;
}
.angebote-banner--featured .product-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 20px 48px rgba(10,10,11,0.12);
}

@media (max-width: 900px) {
	.angebote-banner--featured .angebote-banner__featured-wrap { margin-top: 40px; }
	.angebote-banner--featured .angebote-banner__featured-wrap .product-grid {
		grid-template-columns: 1fr;
		gap: 16px;
	}
}

/* ========================================================================
 * v1.7.2 — Parallax-Trenner + Veranstaltungs-Banner (Dummy)
 * ======================================================================== */

/* -------- Parallax-Divider (500px, CSS-only) — v1.7.8 -------- */
.parallax-divider {
	position: relative;
	height: 500px;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

.parallax-divider__bg {
	position: absolute;
	inset: -10% 0;
	background-size: cover;
	background-position: center;
	background-attachment: fixed; /* CSS-Parallax (Desktop) */
	z-index: 0;
}

.parallax-divider__tint {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(10,10,11,0.55) 0%, rgba(10,10,11,0.78) 100%);
	z-index: 1;
}

.parallax-divider__content {
	position: relative;
	z-index: 2;
	text-align: center;
	padding: 0 24px;
}

.parallax-divider__eyebrow {
	display: block;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(245,241,234,0.65);
	margin-bottom: 18px;
}

.parallax-divider__quote {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: clamp(2.2rem, 5vw, 4rem);
	line-height: 1;
	letter-spacing: -0.015em;
	color: var(--paper);
	text-transform: uppercase;
	margin: 0;
}

.parallax-divider__quote .italic { font-style: italic; }
.parallax-divider__quote .accent { color: var(--orange); }

/* Mobile: Parallax-Fixed ist auf iOS/Android effektlos, daher kleinere Höhe + scroll-Fallback */
@media (max-width: 900px) {
	.parallax-divider { height: 340px; }
	.parallax-divider__bg { background-attachment: scroll; inset: 0; }
}

/* -------- Veranstaltungs-Banner -------- */
.events-banner .events-banner__sub {
	font-size: 1.02rem;
	line-height: 1.55;
	color: rgba(10,10,11,0.72);
	max-width: 540px;
	margin: 18px 0 0;
}

.events-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
	margin-top: 56px;
}

.event-card {
	background: #ffffff;
	box-shadow: 0 8px 24px rgba(10,10,11,0.06);
	overflow: hidden;
	transition: transform 0.4s cubic-bezier(0.2,0,0.1,1), box-shadow 0.4s ease;
	display: flex;
	flex-direction: column;
}

.event-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 20px 48px rgba(10,10,11,0.12);
}

.event-card__media {
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
}

.event-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.7s cubic-bezier(0.2,0,0.1,1);
	display: block;
}

.event-card:hover .event-card__media img {
	transform: scale(1.05);
}

.event-card__badge {
	position: absolute;
	top: 14px;
	left: 14px;
	z-index: 2;
	background: var(--ink);
	color: var(--paper);
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.66rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 6px 12px;
	font-weight: 500;
}

.event-card__badge--reise    { background: var(--orange); }
.event-card__badge--training { background: #1a4d2e; }
.event-card__badge--vortrag  { background: var(--ink); }

.event-card__body {
	padding: 24px 24px 26px;
	display: flex;
	gap: 18px;
	flex: 1;
}

.event-card__date {
	flex-shrink: 0;
	width: 64px;
	border-right: 1px solid rgba(10,10,11,0.1);
	padding-right: 16px;
	text-align: center;
}

.event-card__day {
	display: block;
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: 2.6rem;
	line-height: 1;
	color: var(--orange);
	font-variant-numeric: tabular-nums;
}

.event-card__month {
	display: block;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.68rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(10,10,11,0.55);
	margin-top: 6px;
}

.event-card__main { flex: 1; min-width: 0; }

.event-card__title {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: 1.32rem;
	line-height: 1.1;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	color: var(--ink);
	margin: 0 0 8px;
}

.event-card__meta {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(10,10,11,0.55);
	margin: 0 0 12px;
}

.event-card__desc {
	font-size: 0.92rem;
	line-height: 1.5;
	color: rgba(10,10,11,0.72);
	margin: 0;
}

@media (max-width: 900px) {
	.events-grid { grid-template-columns: 1fr; gap: 16px; margin-top: 36px; }
	.event-card__day { font-size: 2.2rem; }
}

/* ========================================================================
 * v1.7.11 — Unser Bikestore: Hero + Filter + Galerie + Lightbox
 * ======================================================================== */

.vc-bikestore-hero {
	background: var(--paper);
	padding: 120px 40px 60px;
	position: relative;
}
.vc-bikestore-hero__inner {
	max-width: 1200px;
	margin: 0 auto;
}
.vc-bikestore-hero__eyebrow {
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.74rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--orange);
	margin-bottom: 18px;
}
.vc-bikestore-hero__title {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: clamp(2.6rem, 5.8vw, 4.6rem);
	line-height: 0.9;
	letter-spacing: -0.02em;
	text-transform: uppercase;
	color: var(--ink);
	margin: 0 0 28px;
}
.vc-bikestore-hero__title .italic { font-style: italic; font-weight: 600; }
.vc-bikestore-hero__title .accent { color: var(--orange); }
.vc-bikestore-hero__sub {
	font-size: 1.05rem;
	line-height: 1.6;
	max-width: 640px;
	color: rgba(10,10,11,0.72);
	margin: 0;
}

.vc-bikestore-section {
	background: var(--paper);
	padding: 40px 40px 100px;
}
.vc-bikestore-section__inner {
	max-width: 1400px;
	margin: 0 auto;
}

.vc-impressions-filter {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 36px;
	padding-bottom: 24px;
	border-bottom: 1px solid rgba(10,10,11,0.08);
}
.vc-impressions-filter__pill {
	background: transparent;
	border: 1px solid rgba(10,10,11,0.15);
	color: var(--ink);
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.78rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 10px 18px;
	cursor: pointer;
	transition: all 0.25s ease;
}
.vc-impressions-filter__pill:hover {
	border-color: var(--orange);
	color: var(--orange);
}
.vc-impressions-filter__pill.is-active {
	background: var(--ink);
	color: var(--paper);
	border-color: var(--ink);
}

.vc-impressions-grid {
	column-count: 3;
	column-gap: 16px;
}
@media (max-width: 900px) {
	.vc-impressions-grid { column-count: 2; }
}
@media (max-width: 600px) {
	.vc-impressions-grid { column-count: 1; }
}

.vc-impression {
	break-inside: avoid;
	margin: 0 0 16px;
	background: #fff;
	box-shadow: 0 4px 12px rgba(10,10,11,0.06);
	transition: transform 0.4s cubic-bezier(0.2,0,0.1,1), box-shadow 0.4s ease;
}
.vc-impression:hover {
	transform: translateY(-3px);
	box-shadow: 0 16px 36px rgba(10,10,11,0.12);
}
.vc-impression__link {
	display: block;
	overflow: hidden;
	cursor: zoom-in;
}
.vc-impression__link img {
	display: block;
	width: 100%;
	height: auto;
	transition: transform 0.6s cubic-bezier(0.2,0,0.1,1);
}
.vc-impression:hover .vc-impression__link img {
	transform: scale(1.03);
}
.vc-impression__caption {
	padding: 12px 16px;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.72rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(10,10,11,0.6);
	border-top: 1px solid rgba(10,10,11,0.06);
}

.vc-lightbox {
	position: fixed;
	inset: 0;
	background: rgba(10,10,11,0.96);
	z-index: 99998;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}
.vc-lightbox.is-open {
	opacity: 1;
	visibility: visible;
}
.vc-lightbox__figure {
	margin: 0;
	max-width: 92vw;
	max-height: 88vh;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.vc-lightbox__img {
	max-width: 100%;
	max-height: 80vh;
	object-fit: contain;
	display: block;
}
.vc-lightbox__caption {
	color: var(--paper);
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.82rem;
	letter-spacing: 0.08em;
	margin-top: 18px;
	text-align: center;
	max-width: 720px;
	display: none;
}
.vc-lightbox__close,
.vc-lightbox__prev,
.vc-lightbox__next {
	position: absolute;
	background: rgba(245,241,234,0.1);
	border: 1px solid rgba(245,241,234,0.25);
	color: var(--paper);
	width: 48px;
	height: 48px;
	border-radius: 0;
	font-size: 1.4rem;
	cursor: pointer;
	transition: all 0.2s ease;
	display: flex;
	align-items: center;
	justify-content: center;
}
.vc-lightbox__close:hover,
.vc-lightbox__prev:hover,
.vc-lightbox__next:hover {
	background: var(--orange);
	border-color: var(--orange);
}
.vc-lightbox__close { top: 24px; right: 24px; font-size: 1.8rem; }
.vc-lightbox__prev  { left: 24px;  top: 50%; transform: translateY(-50%); }
.vc-lightbox__next  { right: 24px; top: 50%; transform: translateY(-50%); }

@media (max-width: 600px) {
	.vc-lightbox__close { top: 12px; right: 12px; width: 40px; height: 40px; }
	.vc-lightbox__prev  { left: 8px;  width: 40px; height: 40px; }
	.vc-lightbox__next  { right: 8px; width: 40px; height: 40px; }
}

/* ========================================================================
 * v1.7.12 — Unser Bikestore: Full-Width + Backend-Refinements
 * Überschreibt die v1.7.11-Layout-Settings für volle Breite.
 * ======================================================================== */

/* Page-Wrapper (Template) */
.vc-bikestore-page {
	background: var(--paper);
	min-height: 100vh;
}

/* Hero — full-width, mehr Luft */
.vc-bikestore-hero {
	background: var(--paper);
	padding: 96px 6vw 60px;
	position: relative;
	overflow: hidden;
}
.vc-bikestore-hero__inner {
	max-width: none; /* full width */
	margin: 0;
}
.vc-bikestore-hero__back {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--orange);
	text-decoration: none;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 0.74rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	padding: 6px 14px;
	border: 1px solid var(--orange);
	margin-bottom: 36px;
	transition: all 0.2s ease;
}
.vc-bikestore-hero__back:hover {
	background: var(--orange);
	color: var(--paper);
}
.vc-bikestore-hero__title--solo {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: clamp(2rem, 4vw, 3rem);
	line-height: 1;
	letter-spacing: -0.01em;
	text-transform: uppercase;
	color: var(--ink);
	margin: 0 0 24px;
}
.vc-bikestore-hero__statement {
	font-family: 'Big Shoulders Display', sans-serif;
	font-weight: 900;
	font-size: clamp(2.6rem, 5.6vw, 4.4rem);
	line-height: 0.95;
	letter-spacing: -0.02em;
	text-transform: uppercase;
	color: var(--ink);
	margin: 0 0 22px;
}
.vc-bikestore-hero__statement .italic { font-style: italic; font-weight: 600; }
.vc-bikestore-hero__statement .accent { color: var(--orange); }

/* Section: full-width */
.vc-bikestore-section {
	background: var(--paper);
	padding: 40px 4vw 100px;
}
.vc-bikestore-section__inner {
	max-width: none; /* full width */
	margin: 0;
}

/* Galerie — column-Layout für Masonry-Optik mit mehr Spalten */
.vc-impressions-grid {
	column-count: 4;
	column-gap: 14px;
}
@media (max-width: 1400px) { .vc-impressions-grid { column-count: 3; } }
@media (max-width: 900px)  { .vc-impressions-grid { column-count: 2; } }
@media (max-width: 600px)  { .vc-impressions-grid { column-count: 1; } }

.vc-impression {
	margin: 0 0 14px;
}

/* Empty-State */
.vc-impressions-empty {
	padding: 60px 40px;
	background: #fff;
	text-align: center;
	color: var(--muted);
	border: 1px dashed rgba(10,10,11,0.15);
}
.vc-impressions-empty p {
	margin: 0 0 8px;
	font-size: 1rem;
	line-height: 1.5;
}
