/* =========================
   Theme & Base
========================= */
:root{
  --bg:#ffffff;
  --text:#2a2a2a;
  --muted:#6e6e6e;
  --primary:#cc3366;
  --primary-600:#b02b57;
  --primary-100:#ffe6ef;
  --card-bg:rgba(255,255,255,.22);
  --glass-border:rgba(255,255,255,.38);
  --shadow:0 22px 48px rgba(0,0,0,.2);
  --radius:22px;
  --radius-sm:14px;
  --container:1180px;
  --trans:180ms cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  scroll-behavior:smooth;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-600)}
.container{width:min(100%,var(--container));margin-inline:auto;padding-inline:20px}

/* =========================
   Header / Nav
========================= */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.8);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.05)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:64px}
.brand{font-weight:800;font-size:clamp(20px,2.6vw,26px);color:#111}
.brand span{color:var(--primary)}
.brand-invert{color:#fff}
.nav-links{display:flex;gap:18px}
.nav-links a{padding:10px 12px;border-radius:10px;color:#111}
.nav-links a.active,.nav-links a:hover{background:var(--primary-100);color:var(--primary)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:transparent;border:0}
.nav-toggle span{width:26px;height:2px;background:#111;border-radius:2px;display:block}

/* ===== Mobile-Menü: als Overlay ganz vorne ===== */
@media (max-width:900px){
  .nav-toggle{display:flex}
  /* Header selbst ganz oben halten */
  .site-header{ z-index:10002; }

  /* Overlay-Menü */
  .nav-links{
    position:fixed;
    top:64px; left:0; right:0;
    background:#fff;
    display:flex;flex-direction:column;gap:8px;
    padding:12px 14px calc(14px + env(safe-area-inset-bottom));
    max-height:calc(100vh - 64px);
    overflow-y:auto;
    box-shadow:0 22px 60px rgba(0,0,0,.22);

    transform:translateY(-12px);
    opacity:0; pointer-events:none;
    transition:transform 180ms cubic-bezier(.2,.7,.2,1), opacity 180ms cubic-bezier(.2,.7,.2,1);

    z-index:10002; /* über allem Content */
  }
  .nav-links.show{
    transform:none;
    opacity:1;
    pointer-events:auto;
  }

  .nav-links a{
    display:block;
    padding:14px 12px;
    border-radius:10px;
    color:#111;
  }
  .nav-links a:hover,.nav-links a:focus{ background:#f6f6f7 }
  .nav-links a.active{
    font-weight:700; position:relative; background:transparent;
  }
  .nav-links a.active::before{
    content:""; position:absolute; left:0; top:10px; bottom:10px; width:4px;
    border-radius:4px; background:var(--primary);
  }
}

/* Scrim (Dimmer) unter dem Menü, über der Seite */
.nav-scrim{
  position:fixed; inset:0;
  background:rgba(0,0,0,.35);
  backdrop-filter:blur(2px);
  opacity:0; pointer-events:none;
  transition:opacity 180ms cubic-bezier(.2,.7,.2,1);
  z-index:10001;
}
.nav-scrim.show{ opacity:1; pointer-events:auto }

/* Seite sperren, wenn Menü offen */
body.no-scroll{ overflow:hidden }

/* =========================
   Hero Glass Card + Blumen
========================= */
.hero{position:relative;min-height:100svh;display:grid;place-items:center;overflow:hidden;isolation:isolate}
.hero::before{content:"";position:absolute;inset:0;background:rgba(255,255,255,.04);z-index:1;backdrop-filter:blur(2px)}
.hero-bg{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;z-index:0;transform:translateY(0);transition:transform 500ms ease-out}

.hero-card-wrap{position:relative;z-index:2;display:grid;place-items:center;overflow:visible}
.hero-card{
  background:var(--card-bg);
  backdrop-filter:blur(20px) saturate(150%) brightness(.75) contrast(1.05);
  -webkit-backdrop-filter:blur(20px) saturate(150%) brightness(.75) contrast(1.05);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  width:clamp(320px,70vw,1100px);
  min-height:clamp(260px,45vh,520px);
  padding:clamp(28px,5vw,72px);
  text-align:center;
}
.hero-card h1{color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.35);font-size:clamp(28px,3.4vw,46px);line-height:1.15;margin:0 0 12px}
.hero-card p{color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.35);font-size:clamp(15px,1.15vw,19px);margin:0 0 14px}
.tick-list{list-style:none;display:grid;justify-items:center;gap:10px;margin:18px 0 24px;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.35)}
.tick-list li::before{content:"✓ ";margin-right:.25rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}

.flower{position:absolute;pointer-events:none;user-select:none;filter:drop-shadow(0 12px 18px rgba(0,0,0,.15));width:clamp(120px,22%,240px);z-index:3}
.flower-tl{top:0;left:0;transform:translate(-50%,-50%)}
.flower-br{right:0;bottom:0;transform:translate(50%,50%)}

/* Interaktion & Animationen */
.spin-hover{transition:transform 700ms cubic-bezier(.2,.7,.2,1)}
.spin-hover:hover{transform:rotate(360deg) translateZ(0)}
.float-anim{animation:float 7s ease-in-out infinite}
@keyframes float{
  0%,100%{transform:translate(-50%,-50%)}
  50%{transform:translate(-45%,-55%)}
}
.flower-br.float-anim{animation:floatBR 7s ease-in-out infinite}
@keyframes floatBR{
  0%,100%{transform:translate(50%,50%)}
  50%{transform:translate(55%,45%)}
}

.scroll-indicator{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:#fff;opacity:.85;letter-spacing:.2em;font-size:.75rem}

/* =========================
   Sections / Cards / Slider
========================= */
.section{padding:80px 0}
.section-alt{background:linear-gradient(180deg,#fff, #fff0)}
.section-header{text-align:center;margin-bottom:28px}
.section-header h2{font-size:clamp(22px,2.8vw,30px);margin:0 0 8px}
.section-header p{color:var(--muted);margin:0}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--radius-sm);padding:22px;box-shadow:0 8px 24px rgba(0,0,0,.06);transition:transform var(--trans), box-shadow var(--trans)}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(0,0,0,.08)}
.card h3{margin:0 0 6px}
.card .link{display:inline-block;margin-top:8px}

.band{background:#fff;border-block:1px solid rgba(0,0,0,.06);padding:36px 0}
.band-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.band-item{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:18px;text-align:center;box-shadow:0 10px 24px rgba(0,0,0,.05)}
.band-item .icon{font-size:26px;margin-bottom:6px}

/* ====== Auto-Slider (3 Bilder, sanft) ====== */
.slider{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius-sm);
  width:100%;
  max-width:1100px;
  margin-inline:auto;
}
.slider-track{
  display:flex;
  width:100%;
  transition:transform 0.8s ease-in-out;
}
.slide{
  min-width:100%;
  height:clamp(260px,45vh,480px);
}
.slide img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  user-select:none;
  -webkit-user-drag:none;
}

/* =========================
   CTA
========================= */
.cta{padding:80px 0;background:linear-gradient(180deg,#fff,#ffe6ef)}
.cta-inner{text-align:center}
.btn{display:inline-flex;align-items:center;gap:.5rem;border-radius:12px;padding:12px 18px;font-weight:600;border:1px solid rgba(0,0,0,.08);transition:all var(--trans)}
.btn-primary{background:var(--primary);color:#fff;border-color:transparent}
.btn-primary:hover{background:var(--primary-600)}
.btn-ghost{background:#fff;color:#111}
.btn-lg{padding:14px 22px}

/* =========================
   Footer
========================= */
.site-footer{background:#0f0f12;color:#cfcfd4;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:18px;padding:28px 0}
.site-footer a{color:#fff}
.footer-base{border-top:1px solid rgba(255,255,255,.08);padding:12px 0;text-align:center}

/* =========================
   Reveal on Scroll
========================= */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 700ms ease, transform 700ms ease}
.reveal.visible{opacity:1;transform:none}

/* =========================
   Responsive
========================= */
@media (max-width:1024px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .band-grid{grid-template-columns:repeat(2,1fr)}
  .two-col{grid-template-columns:1fr}
}
@media (max-width:620px){
  .cards{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
}

/* ====== Testimonials (edle Glas-Karten) ====== */
.testimonials-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.t-card{
  position:relative;border-radius:18px;overflow:hidden;
  background:rgba(255,255,255,.65);
  backdrop-filter:blur(12px) saturate(130%);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 14px 34px rgba(0,0,0,.08);
  transition:transform .25s ease, box-shadow .25s ease;
}
.t-card:hover{transform:translateY(-4px);box-shadow:0 20px 44px rgba(0,0,0,.12)}
.t-quote-mark{position:absolute;top:-8px;left:14px;font-size:84px;line-height:1;color:rgba(204,51,102,.10);pointer-events:none;user-select:none}
.t-body{position:relative;padding:22px;display:flex;flex-direction:column;gap:12px}
.t-stars{letter-spacing:2px;color:#ffb703;font-size:18px}
.t-card blockquote{margin:0;font-size:1rem;color:#2a2a2a}
.t-user{margin-top:auto;display:flex;align-items:center;gap:12px}
.t-user img{width:44px;height:44px;border-radius:50%;object-fit:cover;box-shadow:0 4px 12px rgba(0,0,0,.12)}
.t-user strong{font-weight:700;display:block}
.t-user small{color:#6e6e6e}
@media (max-width:1024px){.testimonials-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.testimonials-grid{grid-template-columns:1fr}}

/* ===== Leistungen: Accordion – Ergänzung ===== */
.page-hero{padding:48px 0 24px;text-align:center}
.page-hero h1{margin:0 0 8px}
.page-hero p{color:var(--muted);margin:0}
.acc-kicker{display:flex;align-items:center;gap:10px}
.acc-teaser{color:var(--muted);font-weight:400;font-size:.95rem}
.acc-head strong{font-size:1.05rem}
.badge{display:inline-flex;align-items:center;gap:.35rem;background:var(--primary-100);color:var(--primary);border-radius:999px;padding:6px 10px;font-size:.8rem;font-weight:700}
.pill-list{display:flex;flex-wrap:wrap;gap:8px;margin:.4rem 0 0}
.pill{background:#f7f7f8;border:1px solid rgba(0,0,0,.06);padding:6px 10px;border-radius:999px;font-size:.85rem}
.acc-body h4{margin:16px 0 6px;font-size:1.02rem}
.dot-list{padding-left:1rem}
.dot-list li{margin:.25rem 0}
.price{display:grid;grid-template-columns:1fr auto;gap:8px 16px;margin:10px 0 0}
.price div{padding:8px 0;border-bottom:1px dashed rgba(0,0,0,.12)}
.hint{color:var(--muted);font-size:.9rem}
@media (max-width:700px){.price{grid-template-columns:1fr auto}}
.accordion{display:grid;gap:12px}
.acc-item{border:1px solid rgba(0,0,0,.08);border-radius:16px;overflow:hidden;background:#fff;transition:box-shadow var(--trans)}
.acc-item:hover{box-shadow:0 4px 14px rgba(0,0,0,.06)}
.acc-head{width:100%;text-align:left;background:#fff;padding:16px 18px;border:0;display:flex;justify-content:space-between;align-items:center;font-weight:700;cursor:pointer}
.acc-head:hover{background:#fafafa}
.acc-icon{transition:transform var(--trans);font-size:1.2rem;line-height:1}
.acc-body{display:grid;grid-template-rows:0fr;overflow:hidden;transition:grid-template-rows var(--trans), padding var(--trans);padding:0 18px}
.acc-body > *{overflow:hidden}
.acc-item.open .acc-body{grid-template-rows:1fr;padding:0 18px 16px}
.acc-item.open .acc-icon{transform:rotate(45deg)}

/* =========================
   Kontakt – polierter Look
========================= */

/* Split-Layout (Form links, Infos/Map rechts) */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:start}
@media (max-width:1024px){.contact-grid{grid-template-columns:1fr}}

/* Form-Karte */
.form-modern{
  background:#fff;border:1px solid rgba(0,0,0,.06);
  border-radius:var(--radius);
  box-shadow:0 18px 44px rgba(0,0,0,.08);
  padding:26px 26px 20px;
}
.form-modern .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:620px){.form-modern .grid-2{grid-template-columns:1fr}}

.form-modern .field label{
  font-weight:700;color:#3a3a3a;margin-bottom:6px;display:block;
}
.form-modern .field input,
.form-modern .field select,
.form-modern .field textarea{
  width:100%;padding:14px 16px;border-radius:14px;border:1px solid rgba(0,0,0,.12);
  background:#fff;font-size:16px;line-height:1.4;outline:none;
  transition:border var(--trans), box-shadow var(--trans), background var(--trans);
  appearance:none;
}
.form-modern .field textarea{min-height:140px;resize:vertical}
.form-modern .field input:focus,
.form-modern .field select:focus,
.form-modern .field textarea:focus{
  border-color:var(--primary);box-shadow:0 0 0 4px rgba(204,51,102,.12);
}

/* Select-Pfeil */
.select-clean{
  background-image:
    linear-gradient(45deg, transparent 50%, #9aa0a6 50%),
    linear-gradient(135deg, #9aa0a6 50%, transparent 50%),
    linear-gradient(to right, transparent, transparent);
  background-position:
    calc(100% - 18px) calc(50% - 4px),
    calc(100% - 12px) calc(50% - 4px),
    calc(100% - 2.2em) 50%;
  background-size:6px 6px,6px 6px,1px 100%;
  background-repeat:no-repeat;
}

/* Consent */
.consent-box{
  background:var(--primary-100);
  border:1px solid rgba(204,51,102,.28);
  border-radius:14px;
  padding:12px 14px;
}
.consent-line{display:flex;align-items:flex-start;gap:10px;line-height:1.5}
.consent-line input{margin-top:3px}
.consent-box a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}

/* Actions */
.form-modern .actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
@media (max-width:620px){.form-modern .actions{justify-content:center}}

/* Info-Karte + Map */
.info-card{
  background:#fff;border:1px solid rgba(0,0,0,.06);
  border-radius:var(--radius);
  box-shadow:0 18px 44px rgba(0,0,0,.08);
  overflow:hidden;
}
.info-card .pad{padding:22px}
.info-card h2{margin:0 0 10px}
.info-card p{margin:0 0 12px;color:#333}
.info-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.info-pills .pill{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:999px;padding:8px 12px;color:#444}

/* responsive Map (16:9) */
.map-wrap{position:relative;width:100%;padding-top:56.25%;background:#f7f7f8;border-top:1px solid rgba(0,0,0,.06)}
.map-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ===== Leistungen: iOS/Link-Blau neutralisieren & Mobile-Polish ===== */

/* Links im Accordion sollen wie Text aussehen */
.accordion a,
.accordion a:link,
.accordion a:visited {
  color: inherit;
  text-decoration: none;
  -webkit-text-size-adjust: 100%;
}

/* Falls der Header selbst ein <a> ist: als Button wirken lassen */
.acc-head {
  color: var(--text);
  -webkit-tap-highlight-color: transparent;
}
.acc-head:focus-visible {
  outline: 2px solid rgba(204,51,102,.4); /* var(--primary) zart */
  outline-offset: 2px;
  border-radius: 12px;
}

/* Plus-Icon immer in unserer Farbe, nicht Link-Blau */
.acc-icon {
  color: #111;               /* neutral dunkel */
}
.acc-item.open .acc-icon {
  color: var(--primary);     /* geöffnet: Akzent */
}
.acc-head:hover .acc-icon {
  color: var(--primary);
}

/* Titel/Teaser bewusst einfärben (statt Browser-Blau) */
.acc-head strong {
  color: #1c1c1f;
}
.acc-teaser {
  color: var(--muted);
}

/* Touch-optimierte Abstände & Hit-Area auf Mobile */
@media (max-width: 700px){
  .acc-item { border-radius: 18px; }
  .acc-head { padding: 18px 16px; }
  .acc-head strong { font-size: 1.05rem; line-height: 1.25; }
  .acc-teaser { font-size: .95rem; }
  .acc-icon { font-size: 1.35rem; }
}

/* iOS: automatisches Erkennen (Telefon/Datum) nicht blau färben */
a[href^="tel:"],
a[href^="mailto:"],
a[href^="sms:"],
a[href^="maps:"],
a[href^="http"] {
  color: inherit;
  text-decoration: none;
}
