/* Lokal gehostete Schriften (statt Google Fonts von externen Servern zu laden -
   vermeidet die Übertragung von Besucher-IPs an Google ohne Einwilligung) */
@font-face{
  font-family:'Space Grotesk';font-style:normal;font-weight:500 700;font-display:swap;
  src:url('fonts/space-grotesk-variable.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Inter';font-style:normal;font-weight:400 600;font-display:swap;
  src:url('fonts/inter-variable.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;
  src:url('fonts/ibm-plex-mono-400.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;
  src:url('fonts/ibm-plex-mono-500.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

:root{
  --bg:#14171A;
  --bg-alt:#191D21;
  --surface:#1E2328;
  --border:#2B3137;
  --text:#EDEAE3;
  --text-muted:#9BA2A9;
  --accent:#4C7FE8;
  --accent-soft:rgba(76,127,232,0.12);
  --gold:#E8B04C;
  --gold-soft:rgba(232,176,76,0.12);
  --whatsapp:#25D366;
  --font-display:'Space Grotesk', sans-serif;
  --font-body:'Inter', sans-serif;
  --font-mono:'IBM Plex Mono', monospace;
  --radius:6px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;scroll-padding-top:88px;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img,svg{display:block;max-width:100%;}
button{font:inherit;cursor:pointer;background:none;border:none;color:inherit;}
ul{list-style:none;}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}

.container{width:100%;max-width:1180px;margin-inline:auto;padding-inline:24px;}
.section{padding:120px 0;}
.section-alt{background:var(--bg-alt);}
.section-head{max-width:640px;margin-bottom:56px;}
.eyebrow{
  font-family:var(--font-mono);
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.75rem;
  color:var(--accent);
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;}
h2{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(2rem,4vw,2.75rem);
  letter-spacing:-0.01em;
  line-height:1.15;
  margin:16px 0 16px;
}
.section-head p{color:var(--text-muted);font-size:1.05rem;}

.skip-link{
  position:absolute;left:-999px;top:0;background:var(--accent);color:var(--bg);
  padding:12px 20px;z-index:200;border-radius:0 0 4px 0;font-weight:600;
}
.skip-link:focus{left:0;}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 30px;border-radius:4px;font-weight:500;font-size:.95rem;
  transition:background .25s ease, color .25s ease, border-color .25s ease;
  white-space:nowrap;
}
.btn-primary{border:1.5px solid var(--accent);color:var(--text);}
.btn-primary:hover,.btn-primary:focus-visible{background:var(--accent);color:var(--bg);}
.btn-ghost{color:var(--text-muted);font-weight:500;gap:8px;padding:14px 6px;}
.btn-ghost:hover,.btn-ghost:focus-visible{color:var(--text);}
.btn-ghost .arrow{transition:transform .25s ease;}
.btn-ghost:hover .arrow{transform:translateX(5px);}

/* Nav */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(20,23,26,.72);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:76px;}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;font-size:1.1rem;letter-spacing:.01em;}
.logo .dash{color:var(--accent);}
.logo-img{width:auto;display:block;}
.nav-logo-img{height:50px;}
.footer-logo-img{height:60px;}
.nav-links{display:flex;align-items:center;gap:2.2rem;font-size:.93rem;}
.nav-links a{position:relative;padding:6px 0;color:var(--text-muted);transition:color .2s;}
.nav-links a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--accent);transition:width .25s;}
.nav-links a:hover,.nav-links a:focus-visible{color:var(--text);}
.nav-links a:hover::after{width:100%;}
.nav-links .btn{margin-left:8px;padding:10px 20px;font-size:.88rem;}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;}
.nav-toggle span{width:22px;height:2px;background:var(--text);transition:transform .25s ease, opacity .25s ease;}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* Hero */
.hero{position:relative;padding:172px 0 120px;overflow:hidden;}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(var(--border) 1px, transparent 1px);
  background-size:28px 28px;opacity:.45;
  -webkit-mask-image:linear-gradient(to bottom, black, transparent 85%);
  mask-image:linear-gradient(to bottom, black, transparent 85%);
  pointer-events:none;
}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;}
.hero-title{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(2.75rem,6vw,5rem);line-height:1.03;letter-spacing:-.02em;
  margin:20px 0 28px;
}
.hero-title .safe{color:var(--accent);}
.hero-sub{color:var(--text-muted);font-size:1.08rem;max-width:46ch;margin-bottom:36px;}
.hero-ctas{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.hero-visual{position:relative;}
.route-svg{width:100%;height:auto;}
.route-draw{animation:draw 2.2s ease forwards;animation-delay:.3s;}
@keyframes draw{to{stroke-dashoffset:0;}}

/* Vehicle showcase (eine Karte pro Fahrzeug aus content/vehicles.json) */
.vehicles-list{display:flex;flex-direction:column;gap:32px;}
.vehicles-loading,.vehicles-empty{color:var(--text-muted);font-size:.95rem;padding:40px 0;text-align:center;}
.vehicle-showcase{
  display:grid;grid-template-columns:1.15fr .85fr;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;align-items:center;
}
.vehicle-visual{align-self:stretch;display:flex;flex-direction:column;gap:10px;padding:14px;}
.vehicle-photo-frame{position:relative;flex:1;min-height:260px;border-radius:4px;overflow:hidden;background:var(--bg);}
.vehicle-photo-frame img{width:100%;height:100%;object-fit:cover;display:block;}
.vehicle-thumbs{display:flex;gap:8px;}
.thumb{
  width:64px;height:64px;flex-shrink:0;border-radius:4px;overflow:hidden;padding:0;
  border:1.5px solid var(--border);opacity:.55;
  transition:opacity .2s ease, border-color .2s ease;
}
.thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.thumb:hover{opacity:.85;}
.thumb.active{opacity:1;border-color:var(--accent);}
.vehicle-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:36px;height:36px;border-radius:50%;
  background:rgba(20,23,26,.35);color:#fff;
  display:flex;align-items:center;justify-content:center;
  opacity:.5;transition:opacity .2s ease, background-color .2s ease;
}
.vehicle-nav:hover,.vehicle-nav:focus-visible{opacity:1;background:rgba(20,23,26,.6);}
.vehicle-nav.prev{left:12px;}
.vehicle-nav.next{right:12px;}
.vehicle-nav svg{width:18px;height:18px;}
.vehicle-info{padding:48px;}
.vehicle-eyebrow{
  font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--text-muted);margin-bottom:10px;display:block;
}
.vehicle-info h3{font-family:var(--font-display);font-size:1.8rem;font-weight:600;margin-bottom:6px;}
.vehicle-price{
  font-family:var(--font-display);color:var(--accent);font-weight:600;
  font-size:1.1rem;margin-bottom:16px;
}
.vehicle-price strong{font-size:1.25em;}
.vehicle-info .desc{color:var(--text-muted);margin-bottom:26px;font-size:1.02rem;}
.tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:26px;}
.tag{
  font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;
  color:var(--text-muted);border:1px solid var(--border);padding:5px 11px;border-radius:20px;
}
.vehicle-specs{
  display:grid;grid-template-columns:1fr 1fr;gap:12px 24px;
  padding:22px 0;margin-bottom:28px;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.vehicle-specs div{display:flex;justify-content:space-between;gap:10px;font-size:.88rem;}
.vehicle-specs .spec-label{color:var(--text-muted);}
.vehicle-specs .spec-value{font-family:var(--font-mono);font-weight:500;text-align:right;}

/* Why */
.why-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
}
.why-item{background:var(--bg-alt);padding:44px 40px;}
.why-item .icon{color:var(--accent);margin-bottom:22px;}
.why-item .icon svg{width:30px;}
.why-item h3{font-family:var(--font-display);font-size:1.15rem;font-weight:600;margin-bottom:10px;}
.why-item p{color:var(--text-muted);font-size:.95rem;}

/* Reviews */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.review-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px 28px;}
.stars{color:var(--gold);font-size:.9rem;letter-spacing:3px;margin-bottom:20px;}
.review-quote{font-size:1rem;color:var(--text);margin-bottom:26px;line-height:1.65;}
.review-author{font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;}

/* Contact (eigene Seite kontakt.html, braucht daher mehr Abstand zur fixen Nav) */
.contact{padding-top:168px;}
/* Spam-Falle fuer Netlify Forms: fuer Menschen unsichtbar, Bots fuellen sie trotzdem oft aus */
.netlify-hp{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;}
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;}
.field{margin-bottom:20px;display:flex;flex-direction:column;gap:8px;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
label{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);}
.label-optional{text-transform:none;letter-spacing:0;opacity:.7;}
.vehicle-picker{display:flex;flex-wrap:wrap;gap:10px;}
.vehicle-picker-loading{color:var(--text-muted);font-size:.85rem;}
.vehicle-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 16px 6px 6px;border:1.5px solid var(--border);border-radius:30px;
  background:var(--surface);color:var(--text-muted);font-family:var(--font-body);font-size:.88rem;
  transition:border-color .2s ease, color .2s ease;
}
.vehicle-chip img{width:30px;height:30px;border-radius:50%;object-fit:cover;flex-shrink:0;}
.vehicle-chip:hover,.vehicle-chip:focus-visible{border-color:var(--accent);color:var(--text);}
.vehicle-chip.active{border-color:var(--accent);color:var(--text);background:var(--accent-soft);}
input,select,textarea{
  background:var(--surface);border:1px solid var(--border);border-radius:4px;
  padding:13px 14px;color:var(--text);font-family:var(--font-body);font-size:.95rem;
  transition:border-color .2s ease;
}
input:focus,select:focus,textarea:focus{border-color:var(--accent);}
textarea{resize:vertical;min-height:110px;}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%239BA2A9'%3E%3Cpath d='M5 7l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;}
.submit-btn{border:1.5px solid var(--accent);background:var(--accent);color:var(--bg);width:100%;margin-top:8px;}
.submit-btn:hover,.submit-btn:focus-visible{background:transparent;color:var(--text);}
.form-success{
  display:none;margin-top:18px;padding:14px 16px;border:1px solid var(--accent);
  border-radius:4px;background:var(--accent-soft);font-size:.9rem;
}
.form-success.show{display:block;}
.form-error{border-color:#E23B3B;background:rgba(226,59,59,0.12);}

.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px;margin-bottom:24px;}
.info-card h3{font-family:var(--font-display);font-size:1.1rem;font-weight:600;margin-bottom:18px;}
.info-row{display:flex;gap:12px;color:var(--text-muted);margin-bottom:12px;font-size:.95rem;}
.info-row svg{flex-shrink:0;width:18px;color:var(--accent);margin-top:2px;}
.info-note{font-size:.82rem;color:var(--text-muted);margin-top:14px;opacity:.8;}
.wa-btn{
  display:inline-flex;align-items:center;gap:9px;margin-top:6px;
  background:var(--whatsapp);color:#0B1A10;font-weight:600;font-size:.9rem;
  padding:11px 20px;border-radius:4px;transition:filter .2s ease, transform .2s ease;
}
.wa-btn:hover,.wa-btn:focus-visible{filter:brightness(1.08);transform:translateY(-1px);}
.wa-btn svg{width:18px;height:18px;flex-shrink:0;}
.whatsapp-float{
  position:fixed;right:22px;bottom:22px;z-index:90;
  width:56px;height:56px;border-radius:50%;background:var(--whatsapp);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 22px rgba(0,0,0,.4);
  transition:transform .25s ease, box-shadow .25s ease;
  animation:wa-pulse 2.4s ease-in-out infinite;
}
.whatsapp-float:hover,.whatsapp-float:focus-visible{transform:translateY(-3px) scale(1.05);box-shadow:0 12px 26px rgba(0,0,0,.45);}
@keyframes wa-pulse{
  0%,100%{box-shadow:0 8px 22px rgba(0,0,0,.4), 0 0 0 0 rgba(37,211,102,.55);}
  50%{box-shadow:0 8px 22px rgba(0,0,0,.4), 0 0 0 10px rgba(37,211,102,0);}
}
.whatsapp-float svg{width:27px;height:27px;color:#fff;}
.map-frame{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);aspect-ratio:4/3;}
.map-frame iframe{width:100%;height:100%;border:0;filter:invert(92%) hue-rotate(180deg) brightness(.95) contrast(.9);}

/* Footer */
.site-footer{border-top:1px solid var(--border);padding:56px 0 32px;background:var(--bg-alt);}
.footer-grid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px;margin-bottom:40px;}
.footer-brand p.tag{color:var(--text-muted);font-family:var(--font-mono);font-size:.8rem;letter-spacing:.04em;margin-top:10px;}
.footer-nav{display:flex;gap:28px;flex-wrap:wrap;font-size:.9rem;color:var(--text-muted);}
.footer-nav a:hover{color:var(--text);}
.footer-address{color:var(--text-muted);font-size:.9rem;line-height:1.7;}
.footer-bottom{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  padding-top:28px;border-top:1px solid var(--border);font-size:.8rem;color:var(--text-muted);
}
.legal-links{display:flex;gap:20px;}
.legal-links a:hover{color:var(--text);}

/* Intro-Animation (Startseite): Logo + Claim blenden ein, dann Zoom auf die Seite */
.intro{
  position:fixed;inset:0;z-index:300;background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  animation:intro-out .65s ease 1.7s forwards;
}
.intro-inner{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;}
.intro-logo{
  height:clamp(64px,10vw,96px);width:auto;opacity:0;
  animation:intro-fade-in .7s ease .2s forwards;
}
.intro-tag{
  font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;
  letter-spacing:.14em;color:var(--text-muted);opacity:0;
  animation:intro-fade-in .7s ease .45s forwards;
}
.intro-lock{overflow:hidden;}
/* Zoom auf die Seite, während das Intro ausblendet */
.page-zoom{
  animation:page-zoom 1s cubic-bezier(.22,.61,.36,1) 1.6s both;
  transform-origin:50% 240px;
}
@keyframes page-zoom{
  from{transform:scale(.72);}
  to{transform:scale(1);}
}
@keyframes intro-fade-in{
  to{opacity:1;}
}
@keyframes intro-out{
  to{opacity:0;visibility:hidden;}
}
@media (prefers-reduced-motion: reduce){
  .intro{display:none;}
  .page-zoom{animation:none;}
}

/* Reveal on scroll */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease;}
[data-reveal].in-view{opacity:1;transform:translateY(0);}

@media (max-width:960px){
  .hero-inner{grid-template-columns:1fr;}
  .hero-visual{order:-1;max-width:380px;margin-inline:auto;opacity:.85;}
  .vehicle-showcase{grid-template-columns:1fr;}
  .vehicle-info{padding:28px 32px 40px;}
  .vehicle-photo-frame{min-height:0;aspect-ratio:3/2;}
  .vehicle-specs{grid-template-columns:1fr;}
  .why-grid{grid-template-columns:1fr;}
  .reviews-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .nav-links{
    display:none;position:absolute;top:76px;left:0;right:0;flex-direction:column;
    align-items:flex-start;gap:0;background:var(--bg);border-bottom:1px solid var(--border);
    padding:8px 24px 20px;
  }
  .nav-links.open{display:flex;}
  .nav-links a{width:100%;padding:14px 0;border-bottom:1px solid var(--border);}
  .nav-links .btn{margin:16px 0 0;width:100%;}
  .nav-toggle{display:flex;}
}
@media (max-width:600px){
  .section{padding:80px 0;}
  .hero{padding-top:150px;}
  .field-row{grid-template-columns:1fr;}
  .footer-grid{flex-direction:column;gap:28px;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;}
  html{scroll-behavior:auto;}
  .route-draw{stroke-dashoffset:0;}
  [data-reveal]{opacity:1;transform:none;}
}

.legal-page{padding:168px 0 120px;}
.legal-page .container{max-width:760px;}
.legal-back{
  display:inline-flex;align-items:center;gap:8px;color:var(--text-muted);
  font-size:.9rem;margin-bottom:32px;transition:color .2s ease;
}
.legal-back:hover,.legal-back:focus-visible{color:var(--accent);}
.legal-back .arrow{transition:transform .25s ease;}
.legal-back:hover .arrow{transform:translateX(-4px);}
.legal-page h1{font-family:var(--font-display);font-weight:600;font-size:clamp(2.2rem,4vw,2.8rem);letter-spacing:-.01em;margin-bottom:12px;}
.legal-intro{color:var(--text-muted);margin-bottom:52px;font-size:1rem;}
.legal-block{border-top:1px solid var(--border);padding:32px 0;}
.legal-block:last-of-type{border-bottom:1px solid var(--border);}
.legal-block h2{font-family:var(--font-display);font-weight:600;font-size:1.2rem;margin-bottom:16px;}
.legal-block p{color:var(--text);line-height:1.75;margin-bottom:6px;}
.legal-block p.muted{color:var(--text-muted);font-size:.9rem;margin-top:10px;}
.legal-block a{color:var(--accent);}
.legal-block a:hover{text-decoration:underline;}
.todo{
  display:inline-block;font-family:var(--font-mono);font-size:.82rem;color:var(--gold);
  background:var(--gold-soft);padding:2px 9px;border-radius:4px;
}
