/* ========================================
   EddyMobile – Schwarz / Rot / Gold
   Blau nur im Logo
   ======================================== */

/* --- Self-hosted Outfit Font (DSGVO-konform) --- */
@font-face{font-family:'Outfit';font-style:normal;font-weight:300;font-display:swap;src:url(fonts/outfit.woff2) format('woff2')}
@font-face{font-family:'Outfit';font-style:normal;font-weight:400;font-display:swap;src:url(fonts/outfit.woff2) format('woff2')}
@font-face{font-family:'Outfit';font-style:normal;font-weight:500;font-display:swap;src:url(fonts/outfit.woff2) format('woff2')}
@font-face{font-family:'Outfit';font-style:normal;font-weight:600;font-display:swap;src:url(fonts/outfit.woff2) format('woff2')}
@font-face{font-family:'Outfit';font-style:normal;font-weight:700;font-display:swap;src:url(fonts/outfit.woff2) format('woff2')}
@font-face{font-family:'Outfit';font-style:normal;font-weight:800;font-display:swap;src:url(fonts/outfit.woff2) format('woff2')}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  /* Farben */
  --black:#0B0B0B;
  --dark:#111;
  --gray-900:#1a1a1a;
  --gray-800:#252525;
  --gray-700:#333;
  --gray-600:#555;
  --gray-400:#888;
  --gray-300:#aaa;
  --gray-200:#d0d0d0;
  --gray-100:#eee;
  --light:#F7F7F8;
  --white:#fff;

  --red:#E60000;
  --red-hover:#c00;
  --blue:#0077C8;
  --blue-light:#FFF8E1;
  --green:#25D366;
  --gold:#FFD700;
  --gold-dark:#D4A800;
  --gold-light:#FFF8E1;

  /* Typografie */
  --font:'Outfit',system-ui,-apple-system,sans-serif;
  --radius:8px;
  --radius-lg:14px;
  --transition:.25s ease;
}

html{scroll-behavior:smooth;scroll-padding-top:72px}

body{
  font-family:var(--font);
  background:var(--white);
  color:var(--gray-700);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}

img{max-width:100%;height:auto;display:block}
a{color:var(--red);text-decoration:none;transition:color var(--transition)}

/* Skip-Nav (accessibility) */
.skip-nav{
  position:absolute;top:-100%;left:16px;
  padding:12px 24px;background:var(--red);color:#fff;
  font-weight:700;border-radius:0 0 var(--radius) var(--radius);
  z-index:9999;transition:top .2s;
}
.skip-nav:focus{top:0}

/* Form Error */
.form-error{
  margin-top:16px;
  padding:14px 20px;
  background:rgba(230,0,0,.08);
  border:1px solid rgba(230,0,0,.25);
  border-radius:var(--radius);
  display:none;
}
.form-error p{
  font-size:.88rem;color:var(--red);
  font-weight:500;margin:0;
}

.container{
  max-width:1080px;
  margin:0 auto;
  padding:0 24px;
}

/* ========== BUTTONS ========== */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:14px 28px;
  border-radius:var(--radius);
  font-weight:600;
  font-size:.92rem;
  transition:all var(--transition);
  border:2px solid transparent;
  cursor:pointer;
  letter-spacing:.2px;
}
.btn-primary{
  background:var(--red);
  color:#fff;
  border-color:var(--red);
}
.btn-primary:hover{
  background:var(--red-hover);
  border-color:var(--red-hover);
  color:#fff;
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(230,0,0,.3);
}
.btn-ghost{
  background:rgba(255,255,255,.1);
  color:#fff;
  border-color:rgba(255,255,255,.3);
  backdrop-filter:blur(4px);
}
.btn-ghost:hover{
  background:rgba(255,255,255,.2);
  border-color:rgba(255,255,255,.6);
  color:#fff;
}
.btn-call{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 18px;
  background:var(--red);
  color:#fff;
  border-radius:var(--radius);
  font-weight:600;
  font-size:.82rem;
  transition:all var(--transition);
}
.btn-call:hover{
  background:var(--red-hover);
  color:#fff;
}

/* ========== HEADER ========== */
.header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--gray-100);
  transition:all var(--transition);
}
.header.scrolled{
  box-shadow:0 1px 12px rgba(0,0,0,.08);
}
/* Header stays white always – no dark transparent mode */
/* Logo image in header */
.logo-img{
  height:80px;
  width:auto;
  display:block;
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:88px;
}
/* Text Logo */
.logo{display:flex;align-items:center;gap:0;text-decoration:none}
.logo-eddy{
  font-size:1.5rem;font-weight:800;color:var(--blue);
  letter-spacing:1px;line-height:1;
}
.logo-mobile{
  font-size:1.5rem;font-weight:300;color:var(--gray-700);
  letter-spacing:-.5px;line-height:1;
}
/* Logo text fallback colors (not used with image logo) */
.header-nav{display:flex;gap:28px}
.header-nav a{
  color:var(--gray-600);
  font-size:.85rem;
  font-weight:500;
  transition:color var(--transition);
}
.header-nav a:hover{color:var(--black)}

/* ========== HERO ========== */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  text-align:left;
  overflow:hidden;
}
.hero-bg{
  position:absolute;
  inset:0;
}
.hero-bg img{
  width:100%;
  height:100%;
  object-fit:cover;
  animation:heroZoom 25s ease-in-out infinite alternate;
}
@keyframes heroZoom{
  0%{transform:scale(1)}
  100%{transform:scale(1.06)}
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(0deg, rgba(11,11,11,.85) 0%, rgba(11,11,11,.3) 50%, rgba(11,11,11,.15) 100%);
}
.hero-content--bottom{
  position:relative;
  z-index:2;
  padding:0 24px 64px;
  max-width:1080px;
  width:100%;
  animation:fadeUp .8s ease-out .3s both;
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:translateY(0)}
}
.hero h1{
  font-size:clamp(1.8rem,4.5vw,3rem);
  font-weight:800;
  color:#fff;
  line-height:1.15;
  margin-bottom:14px;
  letter-spacing:-.3px;
}
.hero-sub{
  font-size:.95rem;
  color:rgba(255,255,255,.75);
  margin-bottom:28px;
  line-height:1.6;
  max-width:520px;
}
.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:28px;
}
.hero-trust{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  padding:8px 20px;
  border-radius:40px;
  backdrop-filter:blur(8px);
}
.hero-trust .stars{
  color:var(--gold);
  font-size:.9rem;
  letter-spacing:2px;
}
.hero-trust span:last-child{
  color:rgba(255,255,255,.7);
  font-size:.8rem;
  font-weight:500;
}

/* ========== SECTION LABELS ========== */
.section-label{
  display:inline-block;
  font-size:.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:2px;
  color:var(--gold-dark);
  margin-bottom:8px;
}

/* ========== SECTIONS (HELL) ========== */
section{padding:88px 0}
section h2{
  font-size:clamp(1.6rem,3.5vw,2.3rem);
  font-weight:800;
  color:var(--black);
  margin-bottom:40px;
  line-height:1.2;
  letter-spacing:-.3px;
}

/* ========== SERVICES ========== */
.services{background:var(--white)}
.services .container{text-align:center}
.services h2{margin-bottom:48px}

.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  text-align:left;
}
.service-card{
  background:var(--light);
  border:1px solid var(--gray-100);
  border-radius:var(--radius-lg);
  padding:32px 28px;
  transition:all var(--transition);
}
.service-card:hover{
  border-color:var(--gold);
  box-shadow:0 8px 30px rgba(255,215,0,.1);
  transform:translateY(-3px);
}
.service-icon{
  width:48px;
  height:48px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--gold-light);
  border-radius:var(--radius);
  margin-bottom:18px;
  color:var(--gold-dark);
}
.service-card h3{
  font-size:1.1rem;
  font-weight:700;
  color:var(--black);
  margin-bottom:10px;
}
.service-card p{
  font-size:.88rem;
  color:var(--gray-600);
  line-height:1.6;
}

/* ========== ABOUT ========== */
.about{background:var(--light)}
.about-inner{
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:56px;
  align-items:center;
}
.about-image{
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.about-image img{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
}
.about-text h2{margin-bottom:20px}
.about-text p{
  font-size:.95rem;
  color:var(--gray-600);
  margin-bottom:14px;
  line-height:1.7;
}
.about-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:20px;
}
.about-tags span{
  background:var(--gold-light);
  color:var(--gold-dark);
  padding:6px 16px;
  border-radius:40px;
  font-size:.78rem;
  font-weight:600;
}

/* ========== SERVICE AREA ========== */
.area{background:var(--white);text-align:center}
.area h2{margin-bottom:36px}
.area-map-layout{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:40px;
  align-items:center;
  text-align:left;
}
.area-map{
  min-height:420px;
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--gray-100);
  box-shadow:0 8px 32px rgba(0,0,0,.08);
}
.area-map iframe{
  width:100%;
  height:100%;
  min-height:420px;
}
/* --- Google Maps 2-Klick DSGVO Consent --- */
.maps-consent{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:420px;
  background:var(--gray-50,#f8f8f8);
  text-align:center;
  padding:32px;
}
.maps-consent-inner{
  max-width:320px;
}
.maps-consent-inner p{
  margin:8px 0;
  font-size:.95rem;
  color:var(--gray-700);
}
.maps-consent-text{
  font-size:.82rem !important;
  color:var(--gray-600) !important;
  line-height:1.5;
}
.maps-consent-text a{
  color:var(--red);
  text-decoration:underline;
}
.maps-consent .btn{
  margin-top:16px;
}
.area-intro{
  font-size:.92rem;
  color:var(--gray-600);
  line-height:1.7;
  margin-bottom:24px;
}
.area-grid{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:flex-start;
}
.area-tag{
  background:var(--light);
  border:1px solid var(--gray-100);
  padding:10px 24px;
  border-radius:40px;
  font-size:.85rem;
  font-weight:500;
  color:var(--gray-600);
  transition:all var(--transition);
}
.area-tag:hover{
  border-color:var(--gold);
  color:var(--gold-dark);
  background:var(--gold-light);
}

/* ========== REVIEWS (DUNKEL, wie Carina) ========== */
.reviews{
  background:var(--black);
  text-align:center;
  padding:96px 0;
}
.reviews h2{
  color:#fff;
  margin-bottom:48px;
}
.reviews-badge{
  display:inline-block;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.9);
  padding:8px 20px;
  border-radius:40px;
  font-size:.75rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1.5px;
  margin-bottom:16px;
}
.reviews-badge .stars{color:var(--gold)}
.reviews-count{
  text-align:center;
  color:var(--gray-400);
  font-size:.9rem;
  font-weight:400;
  margin-bottom:48px;
}

/* Carousel */
.carousel-wrap{
  position:relative;
  max-width:1200px;
  margin:0 auto;
  padding:0 56px;
  overflow:hidden;
}
.carousel-track-container{
  overflow:hidden;
  border-radius:16px;
}
.carousel-track{
  display:flex;
  gap:24px;
  transition:transform .5s cubic-bezier(.25,.8,.25,1);
  cursor:grab;
}
.carousel-track.grabbing{cursor:grabbing}
.carousel-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:5;
  width:44px;height:44px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.7);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:all .25s ease;
  backdrop-filter:blur(8px);
}
.carousel-btn:hover{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,215,0,.3);
  color:#fff;
}
.carousel-prev{left:0}
.carousel-next{right:0}
.carousel-dots{
  display:flex;justify-content:center;gap:8px;
  margin-top:32px;padding-bottom:16px;
}
.carousel-dot{
  width:8px;height:8px;
  border-radius:50%;
  background:rgba(255,255,255,.2);
  border:none;cursor:pointer;
  transition:all .25s ease;
}
.carousel-dot.active{
  background:var(--gold);
  width:24px;
  border-radius:4px;
}
.review-card{
  background:linear-gradient(145deg,rgba(255,255,255,.06) 0%,rgba(255,255,255,.02) 100%);
  border:1px solid rgba(255,215,0,.1);
  border-radius:16px;
  padding:26px 28px;
  display:flex;
  flex-direction:column;
  gap:14px;
  transition:all .35s ease;
  position:relative;
  overflow:hidden;
  min-width:calc(33.333% - 16px);
  flex-shrink:0;
}
.review-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:2px;
  background:linear-gradient(90deg,transparent,rgba(255,215,0,.4),transparent);
  opacity:0;
  transition:opacity .35s ease;
}
.review-card:hover{
  border-color:rgba(255,215,0,.3);
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(0,0,0,.3);
}
.review-card:hover::before{opacity:1}
.review-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.review-stars{
  color:var(--gold);
  font-size:.85rem;
  letter-spacing:2px;
}
.review-verified{
  font-size:.65rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.8px;
  color:var(--gold);
  border:1px solid rgba(255,215,0,.25);
  padding:4px 12px;
  border-radius:20px;
  background:rgba(255,215,0,.06);
}
.review-card p{
  font-size:.84rem;
  line-height:1.6;
  color:rgba(255,255,255,.75);
  flex:1;
  font-weight:300;
  letter-spacing:.1px;
  text-align:left;
}
.review-card cite{
  font-style:normal;
  font-weight:600;
  font-size:.82rem;
  color:var(--gold);
  letter-spacing:.3px;
  text-align:left;
  display:block;
}

/* ========== SPLIT SECTIONS (Geschäftskunden / Privatkunden) ========== */
.split-section{
  background:var(--white);
  padding:96px 0;
}
.split-section:nth-of-type(even){background:var(--light)}
.split-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:center;
}
.split-reverse .split-inner{direction:rtl}
.split-reverse .split-inner > *{direction:ltr}
.split-image{
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:0 16px 48px rgba(0,0,0,.1);
}
.split-image img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  transition:transform .6s ease;
}
.split-image:hover img{transform:scale(1.03)}
.split-text .section-label{margin-bottom:10px}
.split-text h2{
  font-size:clamp(1.5rem,3vw,2.2rem);
  margin-bottom:16px;
}
.split-text p{
  font-size:.95rem;
  color:var(--gray-600);
  line-height:1.7;
  margin-bottom:24px;
}
.split-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-bottom:32px;
}
.split-list li{
  position:relative;
  padding-left:28px;
  font-size:.9rem;
  color:var(--gray-600);
  line-height:1.5;
}
.split-list li::before{
  content:'';
  position:absolute;
  left:0;top:6px;
  width:18px;height:18px;
  border-radius:50%;
  background:var(--gold-light);
  border:2px solid var(--gold-dark);
}
.split-list li::after{
  content:'✓';
  position:absolute;
  left:3px;top:3px;
  font-size:.7rem;
  font-weight:700;
  color:var(--gold-dark);
}

/* ========== TRUST BAR ========== */
.trust-bar{
  background:var(--black);
  padding:56px 0;
}
.trust-bar-inner{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.trust-badge{
  display:flex;
  align-items:center;
  gap:14px;
  background:var(--gray-900);
  border:1px solid var(--gray-800);
  border-radius:var(--radius-lg);
  padding:20px 22px;
  color:var(--gray-300);
  text-decoration:none;
  transition:all var(--transition);
}
.trust-badge:hover{
  border-color:var(--gold);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(0,0,0,.3);
  color:var(--white);
}
.trust-badge-icon{
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,215,0,.1);
  border:1px solid rgba(255,215,0,.2);
  border-radius:50%;
  flex-shrink:0;
}
.trust-badge-icon svg{color:var(--gold)}
.trust-badge-icon--logo{
  background:var(--white);
  border-color:rgba(255,215,0,.25);
  padding:6px;
  overflow:hidden;
}
.trust-badge-icon--vf{
  background:transparent;
  border-color:rgba(230,0,0,.3);
  padding:0;
}
.trust-badge-icon--vf svg{
  width:48px;height:48px;
  border-radius:50%;
}
.trust-badge-icon--google{
  background:var(--white);
  border-color:rgba(66,133,244,.3);
}
.trust-badge-logo{
  width:100%;height:100%;
  object-fit:contain;
  border-radius:50%;
}
.trust-badge strong{
  display:block;
  font-size:.85rem;
  font-weight:700;
  color:var(--white);
  line-height:1.3;
  margin-bottom:2px;
}
.trust-badge span{
  font-size:.72rem;
  color:var(--gray-400);
  font-weight:400;
}

/* ========== VIDEO SECTION ========== */
.video-section{
  position:relative;
  min-height:70vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  overflow:hidden;
  padding:0;
}
.video-bg{
  position:absolute;
  inset:0;
}
.video-bg video{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:filter .15s linear;
  will-change:filter,transform;
}
.video-overlay{
  position:absolute;
  inset:0;
  background:rgba(11,11,11,.4);
}
.video-content{
  position:relative;
  z-index:2;
  padding:80px 24px;
  max-width:640px;
}
.video-content h2{
  color:#fff;
  font-size:clamp(1.6rem,4vw,2.6rem);
  margin-bottom:16px;
}
.video-content p{
  color:var(--gray-300);
  font-size:1rem;
  line-height:1.7;
  margin-bottom:32px;
}

/* ========== DIGITAL ASSISTANT ========== */
.assistant-section{
  background:var(--light);
  text-align:center;
  padding:96px 0;
}
.assistant-inner{max-width:680px;margin:0 auto}
.assistant-icon{
  width:72px;height:72px;
  display:flex;align-items:center;justify-content:center;
  background:var(--gold-light);
  border-radius:50%;
  margin:0 auto 24px;
  color:var(--gold-dark);
}
.assistant-section h2{
  font-size:clamp(1.5rem,3vw,2rem);
  margin-bottom:16px;
}
.assistant-section p{
  font-size:.95rem;
  color:var(--gray-600);
  line-height:1.7;
  margin-bottom:32px;
}
.assistant-features{
  display:flex;
  justify-content:center;
  gap:32px;
  flex-wrap:wrap;
  margin-bottom:36px;
}
.assistant-feature{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:.88rem;
  font-weight:500;
  color:var(--gray-700);
}

/* ========== BOOKING / TERMINBUCHUNG ========== */
.booking-section{
  background:var(--white);
  padding:96px 0;
}
.booking-inner{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:56px;
  align-items:start;
}
.booking-text .section-label{margin-bottom:10px}
.booking-text h2{
  font-size:clamp(1.5rem,3vw,2rem);
  margin-bottom:16px;
}
.booking-text p{
  font-size:.95rem;
  color:var(--gray-600);
  line-height:1.7;
  margin-bottom:28px;
}
.booking-perks{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.booking-perk{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:.88rem;
  font-weight:500;
  color:var(--gray-700);
}
.booking-form{
  background:var(--light);
  border:1px solid var(--gray-100);
  border-radius:var(--radius-lg);
  padding:36px;
}
.form-group{
  margin-bottom:18px;
}
.form-group label{
  display:block;
  font-size:.82rem;
  font-weight:600;
  color:var(--gray-700);
  margin-bottom:6px;
  letter-spacing:.2px;
}
.form-group input,
.form-group select,
.form-group textarea{
  width:100%;
  padding:12px 16px;
  border:1px solid var(--gray-200);
  border-radius:var(--radius);
  font-family:var(--font);
  font-size:.9rem;
  color:var(--black);
  background:var(--white);
  transition:border-color var(--transition),box-shadow var(--transition);
  outline:none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(255,215,0,.15);
}
.form-group input::placeholder,
.form-group textarea::placeholder{
  color:var(--gray-400);
}
.form-group select{
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:40px;
}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.btn-submit{
  width:100%;
  justify-content:center;
  margin-top:4px;
}
.form-success{
  margin-top:20px;
  display:flex;
  align-items:center;
  gap:12px;
  padding:16px 20px;
  background:rgba(37,211,102,.08);
  border:1px solid rgba(37,211,102,.2);
  border-radius:var(--radius);
}
.form-success p{
  font-size:.88rem;
  color:var(--gray-700);
  font-weight:500;
  margin:0;
}

/* ========== SUBPAGES ========== */
.page{padding-top:64px}

/* Page Hero (hell) */
.page-hero{
  padding:64px 0 48px;
  background:var(--light);
  border-bottom:1px solid var(--gray-100);
  text-align:center;
}
.page-hero h1{
  font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:800;
  color:var(--black);
  line-height:1.15;
  letter-spacing:-.3px;
}
/* Page Hero (dunkel) */
.page-hero--dark{
  background:var(--black);
  border-bottom:1px solid var(--gray-800);
}
.page-hero--dark h1{color:#fff}
.page-hero--dark .section-label{color:var(--gold)}
.page-hero-sub{
  color:var(--gray-300);
  margin-top:12px;
  font-size:1rem;
  line-height:1.6;
}

/* Active Nav */
.header-nav a.active{color:var(--red);font-weight:600}

/* About Full (Über-mich Seite) */
.about-full{padding:80px 0}
.about-full-inner{
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:56px;
  align-items:center;
}
.about-full-image{border-radius:var(--radius-lg);overflow:hidden}
.about-full-image img{width:100%;aspect-ratio:3/4;object-fit:cover}
.about-full-text h2{
  font-size:1.8rem;font-weight:800;color:var(--black);margin-bottom:20px;
}
.about-full-text p{
  font-size:.95rem;color:var(--gray-600);line-height:1.7;margin-bottom:14px;
}

/* Why Eddy Grid */
.why-eddy{background:var(--light);padding:80px 0;text-align:center}
.why-eddy h2{margin-bottom:48px}
.why-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
  text-align:left;
}
.why-card{
  background:var(--white);
  border:1px solid var(--gray-100);
  border-radius:var(--radius-lg);
  padding:28px;
  transition:all var(--transition);
}
.why-card:hover{
  border-color:var(--gold);
  box-shadow:0 8px 30px rgba(255,215,0,.08);
}
.why-icon{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  background:var(--gold-light);border-radius:var(--radius);
  margin-bottom:14px;color:var(--gold-dark);
}
.why-card h3{font-size:1rem;font-weight:700;color:var(--black);margin-bottom:6px}
.why-card p{font-size:.88rem;color:var(--gray-600);line-height:1.6}

/* Gallery Grid */
.shop-gallery{padding:80px 0;text-align:center}
.shop-gallery h2{margin-bottom:36px}
.gallery-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.gallery-item{border-radius:var(--radius-lg);overflow:hidden}
.gallery-item img{
  width:100%;aspect-ratio:16/10;object-fit:cover;
  transition:transform .4s ease;
}
.gallery-item:hover img{transform:scale(1.03)}
.gallery-grid--3{grid-template-columns:repeat(3,1fr)}
.gallery-grid--4{grid-template-columns:repeat(2,1fr)}

/* Page CTA */
.page-cta{padding:80px 0;text-align:center}
.page-cta h2{
  font-size:clamp(1.4rem,3vw,2rem);
  font-weight:800;color:var(--black);margin-bottom:12px;
}
.page-cta p{color:var(--gray-600);margin-bottom:28px;font-size:.95rem}
.page-cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.page-cta--dark{background:var(--black)}
.page-cta--dark h2{color:#fff}
.page-cta--dark p{color:var(--gray-300)}
.btn-whatsapp{
  background:var(--green);color:#fff;
  padding:14px 28px;border-radius:var(--radius);
  font-weight:600;font-size:.92rem;
  display:inline-flex;align-items:center;gap:8px;
  transition:all var(--transition);
}
.btn-whatsapp:hover{background:#1ebd59;color:#fff}

/* Business Cards */
.biz-services{padding:80px 0}
.biz-services .container{text-align:center}
.biz-services h2{margin-bottom:48px}
.biz-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
  text-align:left;
}
.biz-card{
  background:var(--light);
  border:1px solid var(--gray-100);
  border-radius:var(--radius-lg);
  padding:32px 28px;
  transition:all var(--transition);
}
.biz-card:hover{
  border-color:var(--gold);
  box-shadow:0 8px 30px rgba(255,215,0,.08);
}
.biz-icon{
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  background:var(--gold-light);border-radius:var(--radius);
  margin-bottom:16px;color:var(--gold-dark);
}
.biz-card h3{font-size:1.05rem;font-weight:700;color:var(--black);margin-bottom:8px}
.biz-card p{font-size:.88rem;color:var(--gray-600);line-height:1.6;margin-bottom:14px}
.biz-card ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.biz-card li{
  position:relative;padding-left:16px;
  font-size:.82rem;color:var(--gray-600);
}
.biz-card li::before{
  content:'';position:absolute;left:0;top:7px;
  width:5px;height:5px;border-radius:50%;background:var(--gold-dark);
}

/* Benefits List */
.biz-benefits{background:var(--light);padding:80px 0;text-align:center}
.biz-benefits h2{margin-bottom:48px}
.benefits-list{
  max-width:680px;margin:0 auto;
  display:flex;flex-direction:column;gap:24px;
  text-align:left;
}
.benefit-item{
  display:flex;gap:20px;align-items:flex-start;
  padding:24px;background:var(--white);
  border:1px solid var(--gray-100);border-radius:var(--radius-lg);
  transition:border-color var(--transition);
}
.benefit-item:hover{border-color:var(--gold)}
.benefit-number{
  font-size:1.6rem;font-weight:800;color:var(--red);
  line-height:1;min-width:36px;
}
.benefit-item h3{font-size:.95rem;font-weight:700;color:var(--black);margin-bottom:4px}
.benefit-item p{font-size:.85rem;color:var(--gray-600);line-height:1.5}

/* Contact Page */
.contact-section{padding:80px 0}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:48px;
  align-items:start;
}
.contact-block{margin-bottom:36px}
.contact-block h2{
  font-size:1.5rem;font-weight:800;color:var(--black);margin-bottom:24px;
}
.contact-block h3{
  font-size:1rem;font-weight:700;color:var(--black);margin-bottom:14px;
}
.contact-item{
  display:flex;gap:14px;align-items:flex-start;
  margin-bottom:20px;
}
.contact-item svg{
  color:var(--red);flex-shrink:0;margin-top:2px;
}
.contact-item strong{
  display:block;font-size:.85rem;font-weight:700;
  color:var(--black);margin-bottom:2px;
}
.contact-item p{font-size:.9rem;color:var(--gray-600);line-height:1.5}
.contact-item a{color:var(--red)}
.contact-item a:hover{color:var(--black)}

.contact-hours{
  font-size:.9rem;color:var(--gray-600);border-collapse:collapse;
  margin-bottom:12px;
}
.contact-hours td{padding:6px 20px 6px 0}
.contact-note{
  font-size:.82rem;color:var(--gold-dark);font-weight:500;margin-top:8px;
}

.btn-outline-dark{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 24px;border-radius:var(--radius);
  font-weight:600;font-size:.88rem;
  border:2px solid var(--gray-200);
  color:var(--gray-700);
  transition:all var(--transition);
  margin-top:8px;
}
.btn-outline-dark:hover{
  border-color:var(--red);color:var(--red);
}

.contact-map{
  min-height:500px;
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--gray-100);
}
.contact-map iframe{width:100%;height:100%;min-height:500px}

/* Subpage Responsive */
@media(max-width:900px){
  .about-full-inner{grid-template-columns:1fr;gap:32px}
  .about-full-image img{aspect-ratio:16/10}
  .biz-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .contact-map{min-height:350px}
  .contact-map iframe{min-height:350px}
  .gallery-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .page{padding-top:56px}
  .page-hero{padding:48px 0 36px}
  .why-grid{grid-template-columns:1fr}
}

/* ========== FOOTER ========== */
.footer{
  background:var(--dark);
  border-top:1px solid var(--gray-800);
  padding-top:56px;
}
.footer-inner{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr;
  gap:40px;
  padding-bottom:40px;
}
.footer-logo{margin-bottom:14px;mix-blend-mode:screen}
.footer-col p,.footer-col address p{
  font-size:.85rem;
  line-height:1.6;
  color:var(--gray-400);
}
.footer-col h3{
  font-size:.78rem;
  font-weight:700;
  color:var(--white);
  text-transform:uppercase;
  letter-spacing:1.5px;
  margin-bottom:16px;
}
.footer-col address{font-style:normal}
.footer-col address p{margin-bottom:8px}
.footer-col address a{color:var(--gray-300)}
.footer-col address a:hover{color:var(--white)}

.hours-table{font-size:.85rem;color:var(--gray-400);border-collapse:collapse}
.hours-table td{padding:3px 16px 3px 0}

.footer-social{
  display:flex;
  gap:10px;
  margin-top:18px;
}
.footer-social a{
  width:34px;
  height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:var(--gray-800);
  color:var(--gray-400);
  transition:all var(--transition);
}
.footer-social a:hover{
  background:var(--red);
  color:#fff;
}

.footer-bottom{
  border-top:1px solid var(--gray-800);
  padding:18px 0;
}
.footer-bottom-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.footer-bottom p{font-size:.78rem;color:var(--gray-600)}
.footer-legal{display:flex;gap:24px}
.footer-legal a{font-size:.78rem;color:var(--gray-600)}
.footer-legal a:hover{color:var(--gray-300)}

/* ========== WHATSAPP FLOAT ========== */
.whatsapp-float{
  position:fixed;
  bottom:24px;
  right:24px;
  z-index:90;
  width:54px;
  height:54px;
  background:var(--green);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 16px rgba(37,211,102,.35);
  transition:transform var(--transition),box-shadow var(--transition);
}
.whatsapp-float:hover{
  transform:scale(1.08);
  box-shadow:0 6px 24px rgba(37,211,102,.45);
}

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

/* Hamburger Button */
.menu-toggle{
  display:none;
  background:none;border:none;cursor:pointer;
  width:28px;height:20px;position:relative;
  flex-direction:column;justify-content:space-between;
  z-index:110;
}
.menu-toggle span{
  display:block;width:100%;height:2px;
  background:var(--gray-700);border-radius:2px;
  transition:all .3s ease;
}
/* Menu toggle always dark on white header */
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}

@media(max-width:900px){
  .logo-img{height:60px}
  .header-inner{height:72px}
  .menu-toggle{display:flex}
  .header-nav{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    justify-content:center;
    position:fixed;
    inset:0;
    background:var(--white);
    gap:0;
    z-index:105;
    padding:0 48px;
    clip-path:circle(0% at calc(100% - 44px) 36px);
    transition:clip-path .5s cubic-bezier(.4,0,.2,1);
  }
  .header-nav.open{
    clip-path:circle(150% at calc(100% - 44px) 36px);
  }
  .header-nav a{
    padding:16px 0;
    font-size:1.5rem;
    font-weight:700;
    color:var(--black) !important;
    letter-spacing:-.3px;
    opacity:0;
    transform:translateY(12px);
    transition:transform .3s ease, opacity .3s ease, color .2s ease;
    border-bottom:1px solid var(--gray-100);
    width:100%;
  }
  .header-nav a:last-child{border-bottom:none}
  .header-nav.open a{
    opacity:1;
    transform:translateY(0);
  }
  .header-nav.open a:nth-child(1){transition-delay:.12s}
  .header-nav.open a:nth-child(2){transition-delay:.18s}
  .header-nav.open a:nth-child(3){transition-delay:.24s}
  .header-nav.open a:nth-child(4){transition-delay:.30s}
  .header-nav a:hover{color:var(--red) !important}
  .header-nav a.active{color:var(--red) !important}
  /* Hamburger becomes X */
  .menu-toggle.active span{background:var(--black)}
  .menu-toggle.active{z-index:110}
  body.menu-open{overflow:hidden}
  body.menu-open .header{
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    background:transparent;
    border-bottom-color:transparent;
    box-shadow:none;
  }
  .services-grid{grid-template-columns:1fr 1fr}
  .about-inner{grid-template-columns:1fr;gap:32px}
  .about-image img{aspect-ratio:16/10}
  .review-card{min-width:calc(50% - 12px)}
  .footer-inner{grid-template-columns:1fr 1fr;gap:28px}
  /* New sections responsive */
  .split-inner{grid-template-columns:1fr;gap:32px}
  .split-reverse .split-inner{direction:ltr}
  .split-image img{aspect-ratio:16/10}
  .booking-inner{grid-template-columns:1fr;gap:32px}
  .video-section{min-height:50vh}
  .trust-bar-inner{grid-template-columns:1fr}
  .area-map-layout{grid-template-columns:1fr;gap:24px;text-align:center}
  .area-grid{justify-content:center}
  .area-map{min-height:320px}
  .area-map iframe{min-height:320px}
}

@media(max-width:640px){
  .container{padding:0 16px}
  section{padding:64px 0}

  .header-inner{height:56px}
  html{scroll-padding-top:56px}

  .hero{min-height:85vh}
  .hero-content,
  .hero-content--bottom{padding:0 16px 48px}
  .hero h1{font-size:2rem}
  /* hero-logo-anim removed */

  .services-grid{grid-template-columns:1fr}
  .review-card{min-width:calc(100% - 0px)}
  .carousel-wrap{padding:0 40px}

  .footer-inner{grid-template-columns:1fr;gap:24px}
  .footer-bottom-inner{
    flex-direction:column;
    gap:10px;
    text-align:center;
  }

  .whatsapp-float{bottom:16px;right:16px;width:50px;height:50px}

  /* Review cards mobile */
  .review-card{padding:20px 18px;gap:10px;max-width:420px;margin:0 auto}
  .review-card p{font-size:13px;line-height:1.5}
  .review-card cite{font-size:12px}
  .review-stars{font-size:13px;letter-spacing:1px}
  .review-verified{font-size:9px;padding:3px 8px}
  .reviews h2{font-size:1.4rem;margin-bottom:32px}
  .reviews-count{font-size:.8rem;margin-bottom:32px}

  /* New sections mobile */
  .split-section{padding:64px 0}
  .split-list li{font-size:.85rem}
  .form-row{grid-template-columns:1fr}
  .booking-form{padding:24px}
  .assistant-features{gap:16px;flex-direction:column;align-items:center}
  .video-section{min-height:40vh}
  .video-content{padding:48px 16px}
}

/* ========== SCROLL ANIMATIONS ========== */
.anim{
  opacity:0;
  transform:translateY(32px);
  transition:opacity .7s ease-out,transform .7s ease-out;
}
.anim.visible{
  opacity:1;
  transform:translateY(0);
}
/* Staggered children */
.anim.visible .service-card,
.anim.visible .review-card,
.anim.visible .area-tag{
  animation:staggerIn .5s ease-out both;
}
.anim.visible .service-card:nth-child(1),
.anim.visible .review-card:nth-child(1){animation-delay:.1s}
.anim.visible .service-card:nth-child(2),
.anim.visible .review-card:nth-child(2){animation-delay:.2s}
.anim.visible .service-card:nth-child(3),
.anim.visible .review-card:nth-child(3){animation-delay:.3s}
.anim.visible .area-tag:nth-child(1){animation-delay:.05s}
.anim.visible .area-tag:nth-child(2){animation-delay:.1s}
.anim.visible .area-tag:nth-child(3){animation-delay:.15s}
.anim.visible .area-tag:nth-child(4){animation-delay:.2s}
.anim.visible .area-tag:nth-child(5){animation-delay:.25s}
.anim.visible .area-tag:nth-child(6){animation-delay:.3s}
.anim.visible .area-tag:nth-child(7){animation-delay:.35s}
.anim.visible .area-tag:nth-child(8){animation-delay:.4s}

/* Split section children */
.anim.visible .split-list li{
  animation:staggerIn .5s ease-out both;
}
.anim.visible .split-list li:nth-child(1){animation-delay:.1s}
.anim.visible .split-list li:nth-child(2){animation-delay:.2s}
.anim.visible .split-list li:nth-child(3){animation-delay:.25s}
.anim.visible .split-list li:nth-child(4){animation-delay:.3s}

/* Assistant features */
.anim.visible .assistant-feature{
  animation:staggerIn .5s ease-out both;
}
.anim.visible .assistant-feature:nth-child(1){animation-delay:.1s}
.anim.visible .assistant-feature:nth-child(2){animation-delay:.2s}
.anim.visible .assistant-feature:nth-child(3){animation-delay:.3s}

/* Booking perks */
.anim.visible .booking-perk{
  animation:staggerIn .5s ease-out both;
}
.anim.visible .booking-perk:nth-child(1){animation-delay:.1s}
.anim.visible .booking-perk:nth-child(2){animation-delay:.2s}
.anim.visible .booking-perk:nth-child(3){animation-delay:.3s}

@keyframes staggerIn{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

/* ========== ACCESSIBILITY ========== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .anim{opacity:1;transform:none}
  .hero-bg img{animation:none}
}

/* ========== FOCUS VISIBLE ========== */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:2px;
}

/* Footer name style (replaces logo) */
.footer-main h3{
  font-size:1.2rem;
  font-weight:700;
  color:var(--white);
  margin-bottom:14px;
  letter-spacing:-.2px;
}
