/* ═══════════════════════════════════════════════════════════
   MotorradAnhängerMieten.de — Production Stylesheet
   Aesthetic: Clean Light · Warm Contrast · Editorial
   ═══════════════════════════════════════════════════════════ */

/* ── Reset & Base ──────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

:root{
  /* Palette — Light */
  --bg:        #faf9f7;
  --bg-surface:#f1efec;
  --bg-card:   #ffffff;
  --bg-raised: #eae7e3;
  --accent:    #e8552e;
  --accent-dim:#e8552e22;
  --accent-glow:#e8552e0c;
  --text:      #1a1a1a;
  --text-muted:#5c5c5c;
  --text-dim:  #9a9a9a;
  --border:    #e0ddd8;
  --white:     #ffffff;
  --success:   #16a34a;
  --danger:    #dc2626;

  /* Type Scale */
  --font-display: 'Times New Roman', Times, serif;
  --font-body:    'Times New Roman', Times, serif;

  /* Spacing */
  --space-xs: .5rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 3rem;
  --space-xl: 5rem;
  --space-2xl:8rem;

  /* Radius */
  --radius:    12px;
  --radius-lg: 20px;
  --radius-xl: 28px;

  /* Transitions */
  --ease-out: cubic-bezier(.16,1,.3,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);

  /* Dynamic fixed layout offsets (updated via JS) */
  --header-h: 68px;
  --top-offset: 114px;
}

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  padding-top:var(--top-offset);
}

img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ── Container ─────────────────────────────────────────── */
.container{
  width:100%;
  max-width:1280px;
  margin:0 auto;
  padding:0 clamp(1.25rem, 4vw, 3rem);
}

/* ── Typography ────────────────────────────────────────── */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.1;letter-spacing:-.02em}
h1{font-size:clamp(2.8rem,7vw,5.5rem)}
h2{font-size:clamp(2rem,4.5vw,3.5rem)}
h3{font-size:clamp(1.3rem,2.5vw,1.8rem)}
h4{font-size:clamp(1.1rem,2vw,1.4rem)}

.accent-word{color:var(--accent)}
.section-label{
  font-family:var(--font-body);
  font-size:1.1 rem;
  font-weight:600;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:var(--space-sm);
  display:inline-block;
}

/* ── Buttons ───────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-display);font-weight:700;font-size:.95rem;
  padding:.9rem 2rem;
  border-radius:60px;
  transition:all .4s var(--ease-out);
  position:relative;overflow:hidden;
}
.btn.primary{
  background:var(--accent);color:#fff;
}
.btn.primary:hover{
  background:#ff8a55;
  transform:translateY(-2px);
  box-shadow:0 8px 30px var(--accent-dim);
}
.btn.ghost{
  border:1.5px solid var(--border);
  color:var(--text);
  background:transparent;
}
.btn.ghost:hover{
  border-color:var(--accent);
  color:var(--accent);
  transform:translateY(-2px);
}
.btn.dark{background:var(--bg-card);color:var(--text)}
.btn.dark:hover{background:var(--bg-raised)}

/* ── Site Header ───────────────────────────────────────── */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:.45rem 0;
  transition:all .4s var(--ease-out);
  background:var(--bg);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  box-shadow:0 1px 12px rgba(0,0,0,.06);
}
.site-header.elevated{
  padding:.4rem 0;
}
.site-header .container{
  display:flex;align-items:center;justify-content:space-between;
}
.logo{
  font-family:var(--font-display);font-weight:800;font-size:1.3rem;
  color:var(--text);
  letter-spacing:-.01em;
}
.logo span{color:var(--accent)}

.nav{display:flex;gap:.25rem;align-items:center}
.nav a{
  font-size:.85rem;font-weight:500;
  padding:.55rem 1rem;
  border-radius:40px;
  color:var(--text-muted);
  transition:all .3s var(--ease-out);
}
.nav a:hover{color:var(--text);background:var(--bg-raised)}

.nav-toggle{display:none;font-size:1.4rem;padding:.5rem}

/* ── Feature Strip ─────────────────────────────────────── */
.features-strip{
  position:fixed;
  left:0;
  right:0;
  top:calc(var(--header-h) - 1px);
  z-index:950;
  background:var(--bg);
  box-shadow:0 1px 0 rgba(0,0,0,.02);
  border-bottom:1px solid var(--border);
}
.features{
  display:flex;justify-content:center;gap:2.5rem;
  padding:.45rem 0;
  flex-wrap:wrap;
}
.feature{
  display:flex;align-items:center;gap:.5rem;
  font-size:.82rem;font-weight:500;
  color:var(--text-muted);
}
.feature svg{color:var(--accent);flex-shrink:0}

/* ── Hero Section ──────────────────────────────────────── */
.hero{
  position:relative;
  padding:var(--space-xl) 0 var(--space-2xl);
  min-height:90vh;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 70% 40%, var(--accent-glow), transparent),
    radial-gradient(ellipse 50% 50% at 20% 80%, rgba(232,85,46,.04), transparent);
  pointer-events:none;
}
.hero-inner{position:relative;z-index:2}
.hero-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--space-lg);
  align-items:center;
}
.hero-content{max-width:600px}
.hero-tagline{
  font-size:.9rem;
  color:var(--accent);
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:var(--space-md);
}
.hero h1{
  font-size:clamp(2.25rem,5.6vw,4.5rem);
  margin-bottom:var(--space-md);
}
.hero h1 .line{display:block}
.hero-sub{
  font-size:1.15rem;
  color:var(--text-muted);
  line-height:1.7;
  margin-bottom:var(--space-lg);
  max-width:480px;
}
.cta-group{display:flex;gap:1rem;flex-wrap:wrap}

.hero-visual{position:relative}
.hero-image-wrapper{
  position:relative;
  border-radius:var(--radius-xl);
  overflow:hidden;
  background:var(--bg-card);
  box-shadow:0 40px 80px rgba(0,0,0,.12);
}
.hero-image-wrapper img{
  width:100%;
  height:auto;
  object-fit:contain;
}
.hero-image-wrapper::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,.12));
  pointer-events:none;
}
.hero-badge{
  position:absolute;bottom:-1.5rem;right:2rem;
  background:var(--accent);color:#fff;
  font-family:var(--font-display);font-weight:800;
  font-size:1.4rem;
  padding:1rem 1.6rem;
  border-radius:var(--radius);
  box-shadow:0 12px 40px var(--accent-dim);
}
.hero-badge span{font-size:.75rem;font-weight:500;display:block;opacity:.7}

/* ── USP Cards ─────────────────────────────────────────── */
.usp-section{
  padding:var(--space-xl) 0;
  background:var(--bg-surface);
}
.usp-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:1.5rem;
}
.usp-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:2rem 1.75rem;
  transition:all .4s var(--ease-out);
  position:relative;
  overflow:hidden;
}
.usp-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;
  height:3px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s var(--ease-out);
}
.usp-card:hover::before{transform:scaleX(1)}
.usp-card:hover{
  border-color:var(--accent-dim);
  transform:translateY(-4px);
  box-shadow:0 20px 60px rgba(0,0,0,.08);
}
.usp-icon{
  width:48px;height:48px;
  background:var(--accent-dim);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.25rem;
  color:var(--accent);
}
.usp-card h4{margin-bottom:.6rem;font-size:clamp(1rem,1.8vw,1.2rem)}
.usp-card p{font-size:.9rem;color:var(--text-muted);line-height:1.6}

/* ── Section Base ──────────────────────────────────────── */
.section{padding:var(--space-2xl) 0}
.section.alt{background:var(--bg-surface)}
.section-header{text-align:center;margin-bottom:var(--space-xl);max-width:680px;margin-left:auto;margin-right:auto}
.section-header p{color:var(--text-muted);font-size:1.1rem;margin-top:.75rem;line-height:1.7}

/* ── Vorteile Section ──────────────────────────────────── */
.vorteile-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--space-lg);
  align-items:center;
}
.vorteile-image{
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:0 30px 60px rgba(0,0,0,.1);
}
.vorteile-image img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
}
.vorteile-list{display:flex;flex-direction:column;gap:1.25rem}
.vorteil-item{
  display:flex;gap:1rem;align-items:flex-start;
  padding:1.25rem;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  transition:all .35s var(--ease-out);
}
.vorteil-item:hover{
  border-color:var(--accent);
  transform:translateX(6px);
}
.vorteil-icon{
  flex-shrink:0;
  width:40px;height:40px;
  border-radius:10px;
  background:var(--accent-dim);
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);
  font-size:1.1rem;
}
.vorteil-item h4{margin-bottom:.2rem;font-size:1rem}
.vorteil-item p{font-size:.88rem;color:var(--text-muted)}

/* ── Preisvergleich ────────────────────────────────────── */
.price-cards{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2rem;
  max-width:900px;
  margin:0 auto;
}
.price-card{
  background:var(--bg-card);
  border:1.5px solid var(--border);
  border-radius:var(--radius-xl);
  padding:2.5rem 2rem;
  position:relative;
  overflow:hidden;
  transition:all .4s var(--ease-out);
}
.price-card.featured{
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent), 0 20px 60px rgba(232,85,46,.1);
}
.price-card.featured::before{
  content:'EMPFOHLEN';
  position:absolute;top:1.25rem;right:-2rem;
  background:var(--accent);color:#fff;
  font-size:.65rem;font-weight:700;letter-spacing:.1em;
  padding:.35rem 2.5rem;
  transform:rotate(45deg);
}
.price-card-header{margin-bottom:1.5rem}
.price-card-header h3{margin-bottom:.5rem}
.price-card-header .subtitle{font-size:.85rem;color:var(--text-muted)}
.price-amount{
  font-family:var(--font-display);
  font-size:2.8rem;font-weight:800;
  margin-bottom:1.5rem;
}
.price-amount span{font-size:.9rem;font-weight:400;color:var(--text-muted)}
.price-features{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}
.price-feature{display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:var(--text-muted)}
.price-feature svg{flex-shrink:0}
.price-feature .check{color:var(--success)}
.price-feature .cross{color:var(--danger)}
.price-highlight{
  margin-top:2rem;
  padding:1.25rem;
  background:var(--accent-glow);
  border-left:3px solid var(--accent);
  border-radius:0 var(--radius) var(--radius) 0;
  font-size:.9rem;
  color:var(--text);
}
.price-highlight-list ul{
  list-style:disc;
  margin-top:.65rem;
  margin-left:1.1rem;
  padding-left:.6rem;
}
.price-highlight-list li{
  margin-bottom:.4rem;
}
.price-highlight-list li:last-child{
  margin-bottom:0;
}

/* Cost comparison tables inside price cards */
.cost-table{
  width:100%;
  border-collapse:collapse;
  margin-bottom:1.5rem;
  font-size:.85rem;
  color:var(--text-muted);
}
.cost-table th{
  text-align:left;
  font-weight:600;
  color:var(--text);
  padding:.5rem 0;
  border-bottom:1.5px solid var(--border);
}
.cost-table th:last-child,
.cost-table td:last-child{
  text-align:right;
}
.cost-table td{
  padding:.4rem 0;
  border-bottom:1px solid var(--border);
}
.cost-table-total td{
  font-weight:700;
  color:var(--text);
  border-bottom:none;
  padding-top:.6rem;
}

/* Savings banner */
.savings-banner{
  display:flex;
  align-items:center;
  gap:1.25rem;
  padding:1.25rem 1.5rem;
  background:linear-gradient(135deg, rgba(34,197,94,.12), rgba(34,197,94,.04));
  border:1.5px solid rgba(34,197,94,.3);
  border-radius:var(--radius-xl);
  font-size:.9rem;
  color:var(--text);
}
.savings-amount{
  flex-shrink:0;
  font-family:var(--font-display);
  font-size:1.35rem;
  font-weight:800;
  color:#22c55e;
  white-space:nowrap;
}
.savings-text{
  color:var(--text-muted);
}
.price-image{
  margin-top:var(--space-lg);
  text-align:center;
}
.price-image img{
  max-width:100%;
  border-radius:var(--radius-lg);
  box-shadow:0 20px 50px rgba(0,0,0,.1);
}

/* ── Mietmodelle ──────────────────────────────────────── */
.rental-overview{
  display:grid;
  grid-template-columns:1fr;
  gap:2rem;
  align-items:start;
  justify-items:center;
  margin:0 auto var(--space-xl);
  max-width:980px;
}
.rental-copy{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:2rem 1.6rem;
  box-shadow:0 12px 36px rgba(0,0,0,.05);
  width:100%;
}
.rental-copy h3{
  margin-bottom:1.1rem;
  text-align:center;
  font-size:clamp(1.5rem,2.2vw,2rem);
}
.rental-copy p{
  color:var(--text-muted);
  font-size:1.04rem;
  line-height:1.8;
}
.rental-copy p + p{
  margin-top:1.1rem;
}
.rental-pricing{
  display:grid;
  grid-template-columns:repeat(2,minmax(220px,1fr));
  gap:1rem;
  margin-top:1.35rem;
}
.rental-price-item{
  background:linear-gradient(180deg, var(--bg-card), rgba(232,85,46,.04));
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:1rem 1.1rem;
}
.rental-price-item h4{
  margin-bottom:.35rem;
  font-size:1.08rem;
}
.rental-price-item p{
  margin:0;
  line-height:1.45;
}
.rental-price-item strong{
  color:var(--accent);
  font-size:1.02rem;
}
.rental-price-item span{
  display:block;
  color:var(--text-muted);
  font-size:.86rem;
}
.rental-points{
  display:grid;
  gap:1rem;
}
.rental-point{
  display:flex;
  flex-direction:column;
  gap:.35rem;
  padding:1.25rem 1.35rem;
  background:linear-gradient(180deg, var(--bg-card), rgba(232,85,46,.03));
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
}
.rental-point strong{
  font-family:var(--font-display);
  font-size:1rem;
}
.rental-point span{
  color:var(--text-muted);
  font-size:.9rem;
  line-height:1.6;
}

/* ── Modelle / Anhänger ────────────────────────────────── */
.modelle-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.5rem;
}
.modell-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:all .4s var(--ease-out);
}
.modell-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 50px rgba(0,0,0,.1);
  border-color:var(--accent-dim);
}
.modell-card img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
}
.modell-card-body{padding:1.25rem}
.modell-card-body h4{margin-bottom:.4rem}
.modell-card-body p{font-size:.85rem;color:var(--text-muted)}
.modelle-cta{text-align:center;margin-top:var(--space-lg)}
.modelle-demand-note{
  margin:.85rem auto 0;
  max-width:62ch;
  font-size:.9rem;
  color:var(--text-muted);
  line-height:1.6;
}
.modelle-demand-note strong{color:var(--text)}

/* ── Videos Section ────────────────────────────────────── */
.video-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1.5rem;
}
.video-card{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:var(--bg-card);
  border:1px solid var(--border);
  transition:all .4s var(--ease-out);
}
.video-card:hover{
  border-color:var(--accent-dim);
  transform:translateY(-4px);
  box-shadow:0 16px 48px rgba(0,0,0,.08);
}
.video-card iframe{
  width:100%;
  aspect-ratio:16/9;
  border:none;
  display:block;
}
.video-card-label{
  padding:1rem 1.25rem;
  font-weight:600;
  font-size:.9rem;
}
.video-thumb-link{
  position:relative;
  display:block;
  aspect-ratio:16/9;
  overflow:hidden;
}
.video-thumb-link img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .4s var(--ease-out);
}
.video-thumb-link:hover img{
  transform:scale(1.04);
}
.video-play-btn{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  font-size:3rem;
  color:#fff;
  background:rgba(0,0,0,.35);
  transition:background .3s;
  pointer-events:none;
}
.video-thumb-link:hover .video-play-btn{
  background:rgba(232,85,46,.55);
}
.video-section-image{
  margin-top:var(--space-lg);
  text-align:center;
}
.video-section-image img{
  max-width:720px;
  width:100%;
  border-radius:var(--radius-lg);
  box-shadow:0 20px 50px rgba(0,0,0,.1);
}

/* ── Product Showcase ───────────────────────────────────── */
.product-showcase{margin-top:var(--space-xl)}
.showcase-title{
  text-align:center;
  margin-bottom:var(--space-lg);
  font-family:var(--font-display);
  font-size:clamp(1.3rem,3vw,1.7rem);
}
.showcase-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2rem;
}
.showcase-card-link{
  display:block;
  color:inherit;
}
.showcase-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:all .4s var(--ease-out);
  height:100%;
}
.showcase-card:hover{
  border-color:var(--accent-dim);
  box-shadow:0 16px 48px rgba(0,0,0,.08);
}
.showcase-images{
  display:flex;
  flex-direction:column;
  gap:.5rem;
  padding:1rem;
  background:var(--bg-surface);
}
.showcase-main{
  width:100%;
  max-height:360px;
  object-fit:contain;
  border-radius:var(--radius);
  background:var(--bg-card);
  cursor:zoom-in;
}
.showcase-thumbs{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.5rem;
}
.showcase-thumbs img{
  width:100%;
  height:120px;
  object-fit:contain;
  border-radius:8px;
  cursor:pointer;
  transition:opacity .2s;
  background:var(--bg-card);
  cursor:zoom-in;
}
.showcase-thumbs img:hover{opacity:.8}
.showcase-info{
  padding:1.25rem 1.25rem 1.5rem;
}
.showcase-meta{
  display:flex;
  align-items:center;
  gap:.6rem;
  flex-wrap:wrap;
  margin-bottom:.45rem;
}
.showcase-meta .section-label{
  margin-bottom:0;
}
.showcase-pill{
  display:inline-flex;
  align-items:center;
  padding:.28rem .7rem;
  border-radius:999px;
  background:var(--accent-dim);
  color:var(--accent);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.showcase-info .section-label{display:inline-block;margin-bottom:.4rem}
.showcase-info h4{
  margin:.3rem 0 .75rem;
  font-size:clamp(1.1rem,2vw,1.35rem);
}
.showcase-info p{
  font-size:.88rem;
  color:var(--text-muted);
  line-height:1.65;
  margin-bottom:1rem;
}
.showcase-price{
  margin:-.15rem 0 .55rem;
  color:var(--text);
  font-size:.95rem;
}
.showcase-price strong{color:var(--accent)}
.showcase-features{
  list-style:none;
  padding:0;
  margin:0 0 1.3rem;
  display:flex;
  flex-direction:column;
  gap:.45rem;
}
.showcase-features li{
  font-size:.85rem;
  display:flex;
  align-items:flex-start;
  gap:.5rem;
}
.showcase-features li::before{
  content:"✓";
  color:var(--accent);
  font-weight:700;
  flex-shrink:0;
  margin-top:.05rem;
}
.showcase-link-hint{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  font-family:var(--font-display);
  font-size:.92rem;
  font-weight:700;
  color:var(--accent);
}
.showcase-link-hint::after{
  content:"↗";
  font-size:1rem;
}

/* ── Winter Promo ─────────────────────────────────────── */
.winter-promo{
  margin-top:var(--space-lg);
  background:linear-gradient(160deg, rgba(232,85,46,.08), rgba(232,85,46,.02) 55%, var(--bg-card));
  border:1px solid rgba(232,85,46,.26);
  border-radius:var(--radius-xl);
  padding:1.8rem 1.4rem;
}
.winter-promo-head h3{
  margin:.2rem 0 .7rem;
  font-size:clamp(1.35rem,2.8vw,2rem);
}
.winter-promo-head p{
  color:var(--text-muted);
  margin-bottom:1rem;
}
.winter-promo-list{
  display:grid;
  gap:.65rem;
  margin:0;
}
.winter-promo-list li{
  position:relative;
  padding-left:1.2rem;
  color:var(--text-muted);
  line-height:1.65;
}
.winter-promo-list li::before{
  content:"•";
  position:absolute;
  left:0;
  color:var(--accent);
  font-weight:700;
}
.winter-promo-tip{
  margin-top:1rem;
  padding-top:.9rem;
  border-top:1px dashed rgba(232,85,46,.35);
}
.winter-promo-tip strong{color:var(--accent)}

/* ── Kauf von Anhängern ───────────────────────────────── */
.kauf-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.5rem;
  max-width:960px;
  margin:0 auto;
}
.kauf-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:1.5rem;
  box-shadow:0 8px 30px rgba(0,0,0,.04);
}
.kauf-card h3{
  margin-bottom:1rem;
}
.purchase-table{
  width:100%;
  border-collapse:collapse;
  font-size:.92rem;
}
.purchase-table td{
  padding:.65rem 0;
  border-bottom:1px solid var(--border);
}
.purchase-table td:last-child{
  text-align:right;
  font-weight:700;
  color:var(--text);
  white-space:nowrap;
}
.kauf-note{
  margin-top:1rem;
  color:var(--text-muted);
  font-size:.9rem;
  line-height:1.6;
}
.kauf-note a{
  color:var(--accent);
  text-decoration:underline;
  text-underline-offset:2px;
}

/* ── Image Lightbox ───────────────────────────────────── */
.image-lightbox[hidden]{display:none}
.image-lightbox{
  position:fixed;
  inset:0;
  z-index:1200;
  background:rgba(10,10,10,.86);
  display:grid;
  place-items:center;
  padding:1rem;
}
.image-lightbox-dialog{
  position:relative;
  width:min(96vw, 1400px);
  height:min(92vh, 980px);
  display:flex;
  align-items:center;
  justify-content:center;
}
.image-lightbox img{
  position:relative;
  z-index:1;
  width:100%;
  height:100%;
  object-fit:contain;
  border-radius:var(--radius);
  background:#111;
}
.image-lightbox-close{
  position:fixed;
  top:1rem;
  right:1rem;
  z-index:1301;
  width:2.5rem;
  height:2.5rem;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  color:#fff;
  border:1px solid rgba(255,255,255,.35);
  font-size:1.4rem;
  line-height:1;
  display:grid;
  place-items:center;
}
.image-lightbox-close:hover{
  background:rgba(255,255,255,.28);
}

body.no-scroll{
  overflow:hidden;
}

/* ── Standorte ─────────────────────────────────────────── */
.standorte-wrapper{
  max-width:700px;
  margin:0 auto;
}
.standorte-cities{display:flex;flex-direction:column;gap:1rem}
.stadt{
  display:flex;align-items:center;gap:1rem;
  padding:1.25rem 1.5rem;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  transition:all .35s var(--ease-out);
  cursor:default;
}
.stadt:hover{
  border-color:var(--accent);
  transform:translateX(6px);
  background:var(--bg-raised);
}
.stadt-dot{
  width:10px;height:10px;
  border-radius:50%;
  background:var(--accent);
  flex-shrink:0;
  box-shadow:0 0 8px var(--accent-dim);
}
.stadt-name{font-family:var(--font-display);font-weight:700;font-size:1.1rem}
.stadt-badge{
  margin-left:auto;
  font-size:.75rem;
  color:var(--text-dim);
  font-weight:500;
}
.standorte-images{display:flex;flex-direction:column;gap:1rem}
.standorte-images img{
  border-radius:var(--radius-lg);
  box-shadow:0 20px 50px rgba(0,0,0,.1);
}
.standorte-note{
  margin-top:var(--space-md);
  font-size:.9rem;
  color:var(--text-muted);
  text-align:center;
}
.stadt--partner{
  flex-direction:column;
  align-items:stretch;
  cursor:default;
  padding:0;
  gap:0;
}
.stadt-partner-header{
  display:flex;
  align-items:center;
  gap:1rem;
  padding:1.25rem 1.5rem;
}
.stadt-partner-header .stadt-badge{margin-left:auto}
.stadt-partner-body{
  display:flex;
  align-items:center;
  gap:1.25rem;
  padding:0 1.5rem 1.25rem;
}
.stadt-partner-logo-link{
  flex-shrink:0;
}
.stadt-partner-logo{
  height:48px;
  width:auto;
  flex-shrink:0;
  border-radius:6px;
}
.stadt-partner-details{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:.25rem;
  font-size:.85rem;
  color:var(--text-muted);
}
.stadt-partner-details a{
  color:var(--accent);
  text-decoration:none;
}
.stadt-partner-details a:hover{text-decoration:underline}
.standorte-partner-heading{
  font-family:var(--font-display);
  font-size:1.2rem;
  font-weight:700;
  margin-bottom:1rem;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:.75rem;
}
.standorte-partner-card{
  display:flex;
  gap:var(--space-md);
  align-items:flex-start;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:1.5rem 2rem;
  text-decoration:none;
  color:inherit;
  transition:all .35s var(--ease-out);
  max-width:680px;
}
.standorte-partner-card:hover{
  border-color:var(--accent);
  box-shadow:0 8px 32px rgba(0,0,0,.07);
  transform:translateY(-2px);
}
.standorte-partner-logo{
  flex-shrink:0;
  width:140px;
}
.standorte-partner-logo img{
  width:100%;
  height:auto;
  border-radius:var(--radius);
}
.standorte-partner-info h4{
  font-family:var(--font-display);
  font-size:1.15rem;
  font-weight:700;
  margin-bottom:.25rem;
}
.standorte-partner-info>p{
  font-size:.88rem;
  color:var(--text-muted);
  margin-bottom:.75rem;
}
.standorte-partner-details{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:.45rem;
  font-size:.88rem;
  color:var(--text-muted);
  margin-bottom:.75rem;
}
.standorte-partner-details li{
  display:flex;
  align-items:center;
  gap:.45rem;
}
.standorte-partner-details a{
  color:var(--accent);
  text-decoration:none;
}
.standorte-partner-details a:hover{text-decoration:underline}
.standorte-partner-link{
  display:inline-block;
  font-size:.8rem;
  font-weight:600;
  color:var(--accent);
  letter-spacing:.03em;
}
@media(max-width:600px){
  .standorte-partner-card{flex-direction:column}
  .standorte-partner-logo{width:100px}
}

/* ── Partner ───────────────────────────────────────────── */
.partner-showcase{
  display:flex;flex-direction:column;gap:var(--space-lg);align-items:center;
}
.partner-image{
  width:100%;
  max-width:1000px;
  border-radius:var(--radius-xl);
  overflow:hidden;
  border:1px solid var(--border);
  background:var(--bg-card);
  padding:2.5rem;
}
.partner-image img{
  width:100%;
  object-fit:contain;
  max-height:400px;
}
.partner-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:var(--space-md);
  margin-top:var(--space-lg);
}
.partner-card{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.5rem;
  padding:2rem 1.5rem;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  text-decoration:none;
  transition:border-color .3s,box-shadow .3s,transform .3s;
}
.partner-card:hover{
  border-color:var(--accent);
  box-shadow:0 4px 24px rgba(0,0,0,.08);
  transform:translateY(-4px);
}
.partner-logo{
  width:100%;
  max-width:180px;
  height:64px;
  object-fit:contain;
  object-position:center;
}
.partner-logo--dark{
  background:#1c1c1c;
  border-radius:4px;
  padding:6px 10px;
  box-sizing:border-box;
}
.partner-logo-text{
  font-family:var(--font-heading);
  font-size:1.3rem;
  font-weight:700;
  color:var(--text);
  text-align:center;
  letter-spacing:-.01em;
}
.partner-label{
  font-size:.78rem;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:500;
  text-align:center;
}

/* ── Franchise ─────────────────────────────────────────── */
#franchise .section-header{margin-bottom:1.5rem}
.franchise-box{
  max-width:900px;
  margin:0 auto;
  padding:2rem;
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  background:linear-gradient(170deg, var(--bg-card), rgba(232,85,46,.04));
  box-shadow:0 8px 30px rgba(0,0,0,.04);
}
.franchise-box p{
  color:var(--text-muted);
  line-height:1.75;
  font-size:1rem;
}
.franchise-box h4{
  margin-top:1.35rem;
  margin-bottom:.8rem;
  font-size:1.08rem;
}
.franchise-closing{
  margin-top:1rem;
  margin-bottom:0;
}
.franchise-list{
  display:grid;
  gap:.55rem;
  margin:0;
}
.franchise-list li{
  position:relative;
  padding-left:1.15rem;
  color:var(--text-muted);
}
.franchise-list li::before{
  content:"•";
  position:absolute;
  left:0;
  color:var(--accent);
  font-weight:700;
}
.franchise-cta{
  margin-top:1.4rem;
}

/* ── Footer ────────────────────────────────────────────── */
.site-footer{
  padding:var(--space-xl) 0 var(--space-lg);
  background:var(--bg-surface);
  border-top:1px solid var(--border);
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:var(--space-lg);
  margin-bottom:var(--space-lg);
}
.footer-brand .logo{font-size:1.1rem;margin-bottom:.75rem;display:inline-block}
.footer-brand p{font-size:.85rem;color:var(--text-muted);max-width:320px;line-height:1.7}
.footer-col h4{
  font-size:.8rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-muted);margin-bottom:1rem;
}
.footer-col a{
  display:block;font-size:.9rem;color:var(--text-muted);
  padding:.3rem 0;transition:color .2s;
}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{
  padding-top:var(--space-md);
  border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
  font-size:.8rem;color:var(--text-dim);
  flex-wrap:wrap;gap:1rem;
}

/* ── Kontakt Form ──────────────────────────────────────── */
.kontakt-grid{
  display:grid;
  grid-template-columns:1fr 1.6fr;
  gap:var(--space-xl);
  align-items:start;
}
.kontakt-info h4{
  font-size:1.2rem;
  margin-bottom:.75rem;
}
.kontakt-info p{
  color:var(--text-muted);
  font-size:.95rem;
  line-height:1.7;
  margin-bottom:1.5rem;
}
.kontakt-detail{
  display:flex;
  align-items:center;
  gap:.75rem;
  padding:.6rem 0;
  border-bottom:1px solid var(--border);
  color:var(--text-muted);
  font-size:.95rem;
}
.kontakt-detail:last-child{border-bottom:none}
.kontakt-detail svg{flex-shrink:0;color:var(--accent)}
.kontakt-detail a{color:var(--text-muted);transition:color .2s}
.kontakt-detail a:hover{color:var(--accent)}

.kontakt-form{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:2.5rem 2rem;
  box-shadow:0 8px 40px rgba(0,0,0,.05);
}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
}
.form-group{
  display:flex;
  flex-direction:column;
  gap:.45rem;
  margin-bottom:1rem;
}
.form-group label{
  font-size:.8rem;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--text-muted);
}
.form-group label .optional{
  font-weight:400;
  text-transform:none;
  letter-spacing:0;
  color:var(--text-dim);
}
.form-group input,
.form-group select,
.form-group textarea{
  font-family:var(--font-body);
  font-size:.95rem;
  padding:.75rem 1rem;
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  background:var(--bg);
  color:var(--text);
  transition:border-color .25s, box-shadow .25s;
  outline:none;
  width:100%;
  resize:vertical;
}
.form-group input::placeholder,
.form-group textarea::placeholder{
  color:var(--text-dim);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-dim);
}
.form-group input:invalid:not(:placeholder-shown),
.form-group textarea:invalid:not(:placeholder-shown){
  border-color:var(--danger);
}
.form-footer{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
  margin-top:.5rem;
}
.form-hint{
  font-size:.78rem;
  color:var(--text-dim);
  line-height:1.6;
  max-width:340px;
}
.form-hint a{color:var(--accent);text-decoration:underline}
.form-success{
  display:flex;
  align-items:center;
  gap:.75rem;
  margin-top:1.25rem;
  padding:1rem 1.25rem;
  border-radius:var(--radius);
  background:rgba(22,163,74,.1);
  color:var(--success);
  font-size:.95rem;
}
.form-success[hidden]{display:none}

@media (max-width:1024px){
  .kontakt-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .form-row{grid-template-columns:1fr}
  .kontakt-form{padding:1.5rem 1.25rem}
  .form-footer{flex-direction:column}
  .form-footer .btn{width:100%;justify-content:center}
}

/* ── Scroll Reveal Animations ──────────────────────────── */
.reveal{
  opacity:0;
  transform:translateY(40px);
  transition:opacity .8s var(--ease-out), transform .8s var(--ease-out);
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}
.reveal-delay-5{transition-delay:.5s}

/* ── Comparison Section (Kaufen bindet / Mieten befreit) ── */
.compare-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2rem;
}
.compare-card{
  padding:2.5rem 2rem;
  border-radius:var(--radius-xl);
  border:1px solid var(--border);
  background:var(--bg-card);
  position:relative;
  transition:all .4s var(--ease-out);
}
.compare-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.07)}
.compare-card.highlight{
  border-color:var(--accent);
  background:linear-gradient(165deg, var(--bg-card), rgba(232,85,46,.05));
}
.compare-icon{
  width:56px;height:56px;
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.25rem;
  font-size:1.5rem;
}
.compare-card:first-child .compare-icon{background:rgba(248,113,113,.12);color:var(--danger)}
.compare-card.highlight .compare-icon{background:var(--accent-dim);color:var(--accent)}
.compare-card h3{margin-bottom:.75rem}
.compare-card p{color:var(--text-muted);font-size:.95rem;line-height:1.7}
.compare-card strong{color:var(--accent);font-weight:700}

/* ── Responsive ────────────────────────────────────────── */
@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{margin-top:var(--space-lg)}
  .vorteile-grid{grid-template-columns:1fr}
  .vorteile-image{order:-1}
  .rental-overview{grid-template-columns:1fr}
  .modelle-grid{grid-template-columns:repeat(2, 1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media (max-width:768px){
  .nav{
    position:fixed;top:0;right:0;bottom:0;
    flex-direction:column;
    background:var(--bg-surface);
    padding:5rem 2rem 2rem;
    width:280px;
    transform:translateX(100%);
    transition:transform .4s var(--ease-out);
    border-left:1px solid var(--border);
    gap:.25rem;
  }
  .nav.open{transform:translateX(0)}
  .nav-toggle{display:block}

  .features{gap:.65rem}
  .feature{font-size:.76rem}
  .hero-grid{grid-template-columns:1fr}
  .compare-grid{grid-template-columns:1fr}
  .price-cards{grid-template-columns:1fr}
  .kauf-grid{grid-template-columns:1fr}
  .savings-banner{flex-direction:column;text-align:center;gap:.75rem}
  .video-grid{grid-template-columns:1fr}
  .showcase-grid{grid-template-columns:1fr}
  .showcase-main{max-height:300px}
  .showcase-thumbs img{height:96px}
  .rental-copy{padding:1.5rem}
  .rental-pricing{grid-template-columns:1fr}
  .winter-promo{padding:1.35rem 1.1rem}
  .franchise-box{padding:1.35rem 1.1rem}
  .modelle-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
}
@media (max-width:480px){
  .hero-badge{right:1rem;bottom:-1rem;font-size:1.1rem;padding:.75rem 1.2rem}
  .price-amount{font-size:2.2rem}
}

/* ── Subtle grain overlay ──────────────────────────────── */
body::after{
  content:'';
  position:fixed;inset:0;
  pointer-events:none;
  z-index:9999;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px;
  opacity:.012;
  mix-blend-mode:multiply;
}
