/* =========================================================
   BASIS & RESET
========================================================= */
*{margin:0;padding:0;box-sizing:border-box}

:root{
  --color-dark:#1e1e1c;
  --color-red:#b83850;           /* Rot für Hover/Active in der Navi */
  --color-yellow:#fdd27a;        /* Gelb für Slogan/Icon-Badges */
  --color-white:#fff;
  --color-gray-light:#f5f5f5;
  --color-gray-medium:#666;
  --radius:14px;
  --shadow:0 4px 20px rgba(0,0,0,.1);
  --shadow-hover:0 8px 30px rgba(0,0,0,.15);
  --ease:all .3s cubic-bezier(.4,0,.2,1);
  --header-offset:96px;
}

/* Lokale Schriften aus /assets/fonts/ */
@font-face{font-family:"Inter";src:url("../fonts/Inter-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/Inter-Medium.ttf") format("truetype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/Inter-SemiBold.ttf") format("truetype");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/Inter-Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}

html{scroll-behavior:smooth}
body{
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  line-height:1.6;color:var(--color-dark);background:var(--color-white)
}
.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* =========================================================
   HEADER & NAVIGATION
========================================================= */
.header{
  position:fixed;left:0;right:0;top:0;
  background:var(--color-white);box-shadow:var(--shadow);z-index:1000;
}
.header-content{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:12px 0 10px;
}
.logo{height:88px;width:auto;display:block}
.nav{width:100%}
.nav-list{
  list-style:none;display:flex;gap:16px;align-items:center;justify-content:center;flex-wrap:wrap;
}
.nav-link,.nav-button{
  font:500 1rem/1 "Inter",system-ui,sans-serif;
  background:none;border:none;cursor:pointer;text-decoration:none;
  color:var(--color-dark);
  padding:12px 14px;border-radius:10px;transition:var(--ease);
  display:inline-flex;align-items:center;justify-content:center;min-height:42px;
}
.nav-link:hover,.nav-button:hover,.nav-link.active{background:var(--color-red);color:#fff}

/* Shrink auf Desktop */
.header.shrink .header-content{
  flex-direction:row;align-items:center;justify-content:space-between;gap:24px;
}
.header.shrink .logo{height:54px;}
.header.shrink .nav-list{justify-content:flex-end;}

/* =========================================================
   SEKTIONEN / GLOBAL
========================================================= */
.section{padding:72px 0;}
.home-section{padding-top:calc(var(--header-offset) + 16px);}
.section-title{text-align:center;font-size:2.4rem;font-weight:700;margin-bottom:40px;color:var(--color-dark);}

/* =========================================================
   SLIDER
========================================================= */
.slider-container{
  position:relative;height:60vh;min-height:460px;overflow:hidden;border-radius:0 0 var(--radius) var(--radius);
}
@media (min-width:1200px){.slider-container{height:54vh;min-height:440px;}}
.slider{position:relative;height:100%;}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 600ms ease-in-out;}
.slide.active{opacity:1;}
.slide img{width:100%;height:100%;object-fit:cover;image-rendering:auto;}

.slide-overlay{
  position:absolute;inset:auto 0 0 0;padding:50px 36px 30px;
  background:linear-gradient(transparent,rgba(30,30,28,.8));color:#fff;text-align:center;
}
.slide-overlay h1{font-size:2.4rem;font-weight:700;margin-bottom:8px;}
.slide-overlay p{font-size:1.1rem;opacity:.95;}

.slider-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(0,0,0,.18);color:#fff;border:none;width:56px;height:56px;
  display:grid;place-items:center;border-radius:50%;cursor:pointer;font-size:2rem;line-height:1;
}
.slider-btn.prev{left:16px;}
.slider-btn.next{right:16px;}
.slider-dots{position:absolute;left:50%;transform:translateX(-50%);bottom:16px;display:flex;gap:10px;}
.dot{width:12px;height:12px;border-radius:50%;background:rgba(255,255,255,.6);border:0;}
.dot.active,.dot:hover{background:#fff;}

/* =========================================================
   FEATURE-KARTEN
========================================================= */
.features-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:36px;margin:64px 0;
}
.feature-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:var(--ease);}
.feature-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover);}
.feature-image{padding:12px 12px 0;}
.feature-image img{width:100%;height:auto;border-radius:var(--radius);object-fit:contain;}
.feature-content{padding:20px 24px 28px;}
.feature-content h3{font-size:1.4rem;color:var(--color-red);margin-bottom:10px;}

/* =========================================================
   SLOGAN
========================================================= */
.slogan{display:flex;justify-content:center;}
.slogan-text{
  background:var(--color-yellow);border:2px solid var(--color-yellow);
  color:var(--color-dark);border-radius:12px;padding:14px 22px;
  max-width:760px;width:fit-content;margin:0 auto;font-size:2rem;font-weight:700;
}

/* =========================================================
   LEISTUNGEN
========================================================= */
.leistungen-section{background:var(--color-gray-light);}
.services-grid{display:grid;grid-template-columns:1fr;gap:36px;justify-items:center;}
.services-centered{width:100%;}
.service-category h3{display:none;}
.services-list{display:grid;gap:14px;width:100%;max-width:720px;margin:0 auto;}
.service-item{
  display:flex;align-items:center;gap:14px;background:#fff;padding:16px 18px;
  border-radius:var(--radius);box-shadow:var(--shadow);
}
.service-icon{
  width:40px;height:40px;display:grid;place-items:center;border-radius:50%;
  background:var(--color-yellow);flex-shrink:0;font-size:1.2rem;
}

/* =========================================================
   KONTAKT (zentriert & responsiv korrigiert)
========================================================= */
.contact-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));
  gap:28px;
  max-width:900px;
  width:100%;
  margin:0 auto;
  justify-items:center;
}
.contact-card{
  width:100%;
  max-width:520px;
  background:#fff;
  padding:28px;
  border-radius:var(--radius);
  text-align:center;
  box-shadow:var(--shadow);
}
.contact-icon{font-size:2.4rem;margin-bottom:10px;color:var(--color-red);}
.phone-link{
  display:inline-block;margin-top:8px;background:var(--color-red);color:#fff;text-decoration:none;
  padding:10px 18px;border-radius:12px;font-weight:700;
}

/* =========================================================
   ANFAHRT
========================================================= */
.anfahrt-section{background:var(--color-gray-light);}
.map-container{max-width:900px;margin:0 auto;}
.map-placeholder{
  background:#fff;padding:42px 36px;border-radius:var(--radius);
  box-shadow:var(--shadow);text-align:center;
}
.map-icon{font-size:2.4rem;margin-bottom:10px;color:var(--color-red);}
.btn-primary,.btn-secondary{
  border:0;padding:12px 20px;border-radius:12px;font-weight:600;cursor:pointer;
}
.btn-primary{background:var(--color-red);color:#fff;}
.btn-secondary{background:var(--color-gray-medium);color:#fff;}
.google-map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}

/* =========================================================
   FOOTER
========================================================= */
.footer{background:#1a1a1a;color:#fff;padding:36px 0;}
.footer-content{text-align:center;}
.footer-buttons{
  display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:16px;
}
.footer-btn{
  background:var(--color-red);color:#fff;border:none;padding:10px 16px;
  border-radius:12px;cursor:pointer;font-weight:600;transition:var(--ease);
}
.footer-btn:hover{background:#a12e43;}
.footer-btn.ghost{background:transparent;border:1px solid rgba(255,255,255,.5);}

/* =========================================================
   MODALS
========================================================= */
.modal{
  display:none;position:fixed;inset:0;z-index:2000;
  background:rgba(0,0,0,.5);backdrop-filter:blur(4px);
}
.modal-content{
  background:#fff;width:90%;max-width:880px;max-height:80vh;overflow:hidden;
  border-radius:var(--radius);box-shadow:var(--shadow-hover);margin:5% auto;position:relative;
}
.modal-content h2{background:var(--color-red);color:#fff;padding:18px 24px;}
.modal-body{padding:24px;max-height:60vh;overflow:auto;}
.modal-body h3{color:var(--color-red);margin:18px 0 10px;}
.close{
  position:absolute;right:16px;top:16px;width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.2);color:#fff;border:0;font-size:26px;cursor:pointer;
}

/* =========================================================
   COOKIE-BANNER
========================================================= */
.cookie-banner{
  position:fixed;left:0;right:0;bottom:0;background:#1a1a1a;color:#fff;
  padding:18px;z-index:1500;box-shadow:0 -4px 20px rgba(0,0,0,.3)
}
.cookie-content{
  max-width:1200px;margin:0 auto;display:flex;gap:12px;
  align-items:center;justify-content:space-between;
}
.cookie-buttons{display:flex;gap:10px}
.cookie-banner.hidden{display:none}

/* =========================================================
   REVEAL-EFFEKT
========================================================= */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;}
.reveal.show{opacity:1;transform:none;}

/* =========================================================
   RESPONSIVE
========================================================= */
@media (max-width:980px){
  .section{padding:64px 0;}
  .home-section{padding-top:calc(var(--header-offset) + 12px);}
}

/* === Mobile Shrink-Layout: Logo rechts, Navi daneben, kompakt === */
@media (max-width:640px){

  .header.shrink .header-content{
    display:grid;
    grid-template-columns:1fr auto; /* Navi links, Logo rechts */
    align-items:center;
    gap:8px;
    padding:6px 0;
  }

  .header.shrink .logo{
    height:46px; /* kleiner -> Platz für Navi */
  }

  .header.shrink .nav{width:100%;}
  .header.shrink .nav-list{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    justify-items:center;
    align-items:center;
    gap:clamp(2px,1vw,8px);
    max-height:20vh;
    overflow:auto;
    margin:0;
  }

  .header.shrink .nav-link,
  .header.shrink .nav-button{
    font-size:clamp(0.85rem,1.6vw,0.95rem);
    padding:8px 10px;
    line-height:1.1;
  }

  .logo{height:72px;}
  .slider-container{height:50vh;min-height:360px;}
  .slide-overlay{padding:34px 18px 18px;}
  .slide-overlay h1{font-size:1.7rem;}
  .slogan-text{font-size:1.5rem;}

  /* Kontaktbereich mobil korrigiert */
  .contact-grid{
    grid-template-columns:1fr;
    gap:24px;
    padding:0;
  }
  .contact-card{
    max-width:96vw;
    padding:24px;
  }
}

/* =========================================================
   DRUCK
========================================================= */
@media print{
  .header,.footer,.modal,.cookie-banner,.slider-btn,.slider-dots{display:none!important}
  .section{padding:20px 0;}
}
