/* Martinis Rudelfreunde - CSS Tab (Eigenes Layout) */

/* Jimdo-Systembars ausblenden */
#jimdo-bar,
.jimdo-bar,
#jimdo-footer-bar,
.j-footer,
.jimdo-powered-by,
[id*="jimdo-bar"],
[class*="jimdo-bar"],
#contentfooter,
[data-container="footer"],
.jimdo-free-footer-ad,
.jimdo-footer-branding { display: none !important; }

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Poppins:wght@500;600;700&display=swap');

/* Jimdo-Struktur anpassen */
#container { padding: 0; margin: 0; max-width: 100%; }
#sidebar { display: none !important; }

/* ============================================
   UNTERSEITEN (Impressum, Datenschutz, AGB)
   ============================================ */
.subpage-wrap {
  padding-top: 120px;
  background: #FAF4EE;
  min-height: calc(100vh - 120px);
}

/* Gemeinsame Basis */
.imp-wrap, .ds-wrap, .agb-wrap {
  max-width: 780px;
  margin: 0 auto;
  padding: 60px 32px 80px;
  font-family: 'Inter', sans-serif;
  color: #2F2F2F;
}
.imp-wrap h1, .ds-wrap h1, .agb-wrap h1 {
  font-family: 'Poppins', sans-serif;
  font-size: 2.2rem !important;
  font-weight: 600;
  margin-bottom: 8px;
  color: #2F2F2F !important;
}
.imp-wrap h2, .ds-wrap h2, .agb-wrap h2 {
  font-family: 'Poppins', sans-serif;
  font-size: 1.05rem !important;
  font-weight: 600;
  margin: 36px 0 8px;
  color: #2F2F2F !important;
}
.imp-wrap p, .ds-wrap p, .agb-wrap p,
.ds-wrap li, .agb-wrap li {
  line-height: 1.75;
  color: #444;
  margin: 0 0 8px;
  font-size: 0.95rem;
}
.ds-wrap ul, .agb-wrap ul {
  padding-left: 20px;
  margin: 8px 0 16px;
}
.imp-wrap a, .ds-wrap a, .agb-wrap a {
  color: #C97B6E;
  text-decoration: none;
}
.imp-wrap .eyebrow, .ds-wrap .eyebrow, .agb-wrap .eyebrow {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #9E6E7A;
  margin-bottom: 12px;
  display: block;
}
.imp-divider, .ds-divider, .agb-divider {
  border: none;
  border-top: 1px solid #e8e2d9;
  margin: 40px 0;
}
.agb-intro {
  background: #F0D5CB;
  border-radius: 16px;
  padding: 24px 28px;
  margin-bottom: 40px;
  color: #7a4a42;
  font-size: 0.95rem;
  line-height: 1.7;
}
.agb-hinweis {
  background: #F5EDE3;
  border-left: 3px solid #C97B6E;
  border-radius: 0 12px 12px 0;
  padding: 16px 20px;
  margin: 16px 0 24px;
  font-size: 0.9rem;
  color: #5a3a30;
  line-height: 1.65;
}
.agb-hinweis--confirm {
  background: #eef0ec;
  border-left-color: #8E9B87;
  color: #3a4a38;
}
.agb-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0 16px;
}
.agb-tag {
  background: #F0D5CB;
  color: #7a4a42;
  border-radius: 999px;
  padding: 4px 14px;
  font-size: 0.85rem;
  font-weight: 500;
}
.agb-zeiten-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 16px 0 24px;
}
.agb-zeiten-card {
  background: #FAF4EE;
  border: 1px solid #e8e2d9;
  border-radius: 16px;
  padding: 16px 18px;
}
.agb-zeiten-label {
  font-weight: 600;
  font-size: 0.85rem;
  color: #9E6E7A;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 10px;
}
.agb-zeiten-row {
  display: flex;
  justify-content: space-between;
  font-size: 0.88rem;
  color: #444;
  padding: 3px 0;
  gap: 8px;
  flex-wrap: wrap;
}
.agb-zeiten-row span:first-child {
  color: #888;
  flex-shrink: 0;
}
.agb-zeiten-row span:only-child {
  color: #666;
  flex-shrink: 1;
  white-space: normal;
}
.agb-table-wrap {
  margin: 12px 0 20px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid #e8e2d9;
}
.agb-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}
.agb-table thead tr {
  background: #F0D5CB;
}
.agb-table th {
  padding: 10px 16px;
  text-align: left;
  font-weight: 600;
  color: #7a4a42;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.agb-table td {
  padding: 10px 16px;
  color: #444;
  border-top: 1px solid #f0ebe4;
}
.agb-table tbody tr:nth-child(even) td {
  background: #fdf9f6;
}
@media (max-width: 600px) {
  .agb-zeiten-grid { grid-template-columns: 1fr; }
  .agb-table th, .agb-table td { padding: 8px 12px; }
}

#header {
  position: fixed !important;
  top: 0; left: 0;
  width: 100%;
  z-index: 999;
  padding: 0 !important;
  border: none !important;
  background: rgba(250,244,238,0.94) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(201,123,110,0.12) !important;
  box-shadow: none;
}
/* Nur Jimdo's auto-generierte Nav-Liste verstecken, nicht unsere .nav-links */
#header ul { display: none !important; }
#header li { display: none !important; }

#content { padding: 0; margin: 0; padding-top: 120px; }
#footer {
  padding: 0 !important;
  margin: 0 !important;
  background: #2F2F2F !important;
  border: none !important;
  color: rgba(255,255,255,0.75) !important;
}
#footer .footer-inner {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 48px;
  padding: 50px 32px 36px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
#footer .footer-brand p { color: rgba(255,255,255,0.75) !important; font-size: 0.9rem; margin-top: 14px; }
#footer .footer-col h4 { color: #fff !important; font-family: 'Poppins', sans-serif; font-size: 0.85rem; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 14px; }
#footer .footer-col a { color: rgba(255,255,255,0.65) !important; display: block; margin-bottom: 8px; font-size: 0.9rem; }
#footer .footer-col a:hover { color: #fff !important; }
#footer .footer-bottom { max-width: 1240px; margin: 0 auto; padding: 24px 32px; display: flex; justify-content: space-between; font-size: 0.82rem; color: rgba(255,255,255,0.4) !important; }
#footer h1, #footer h2, #footer h3, #footer h4 { color: #fff !important; }
#footer p { color: rgba(255,255,255,0.75) !important; }
@media (max-width: 768px) {
  #footer .footer-inner { grid-template-columns: 1fr; gap: 32px; }
  #footer .footer-bottom { flex-direction: column; gap: 8px; }
}

/* CTA-Button Text sichtbar */
.nav-cta,
a.nav-cta,
.nav-cta:link,
.nav-cta:visited,
.nav-cta:hover,
.nav-cta:active,
#header .nav-cta,
#header a.nav-cta,
#header .nav .nav-cta {
  color: #ffffff !important;
  background: #C97B6E !important;
  text-decoration: none !important;
  -webkit-text-fill-color: #ffffff !important;
  box-shadow: 0 2px 12px rgba(201,123,110,0.30) !important;
}
#header .nav-cta:hover,
#header a.nav-cta:hover {
  background: #B56A5E !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
}

.contact-content .j-module { background: #fff; border-radius: 16px; padding: 32px; margin-top: 24px; }

/* ============================================
   HARD RESET – altes Jimdo-Theme überschreiben
   ============================================ */
*, *::before, *::after {
  margin: 0; padding: 0; box-sizing: border-box;
  text-align: left !important;
}
/* Nur bei Überschriften das alte Jimdo-Theme neutralisieren */
h1, h2, h3, h4, h5, h6 {
  text-align: left !important;
  font-style: normal !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}
/* Ausnahmen: Footer-Bottom zentriert, alles andere links */
.footer-inner *, #footer * { text-align: left !important; }
.footer-bottom { text-align: center !important; }

/* RESET & BASE */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

    body {
      font-family: 'Inter', sans-serif;
      background: var(--cream);
      color: #2F2F2F;
      line-height: 1.75;
      text-align: left !important;
    }

    img { max-width: 100%; display: block; }
    /* Jimdo-Theme-Override: Schrift und Gewicht normalisieren */
    h1, h2, h3, h4, h5, h6 {
      color: #2F2F2F !important;
      font-weight: 600 !important;
      font-family: 'Poppins', sans-serif !important;
      line-height: 1.2 !important;
    }
    /* h3–h6 Grössen durch spezifische Klassen gesteuert, kein revert */
    .hero h1 { color: #fff !important; }
    .cta-box h2 { color: #fff !important; }
    .footer-col h4 { color: #fff !important; }
    .footer-brand p { color: rgba(255,255,255,0.75) !important; }

    a { text-decoration: none !important; color: inherit !important; }
    a:hover { text-decoration: none !important; }
    a:visited { color: inherit !important; }

    /* Nav-Links */
    .nav-links a { color: #555 !important; text-decoration: none !important; }
    .nav-links a:hover { color: var(--rose) !important; }
    .nav-cta { color: #fff !important; text-decoration: none !important; }

    /* Buttons */
    .btn { color: #2F2F2F !important; text-decoration: none !important; }
    .btn-whatsapp { color: #fff !important; }
    .btn-instagram { color: #fff !important; }
    .btn-outline { color: #fff !important; }

    /* Footer-Links */
    .footer-col a { color: rgba(255,255,255,0.75) !important; text-decoration: none !important; }
    .footer-col a:hover { color: #fff !important; }

    /* CTA-Buttons */
    .cta-buttons a { text-decoration: none !important; }

    /* Reviews-Link */
    .reviews-link { color: #8E9B87 !important; text-decoration: none !important; }

    /* Service-Links, Qual-Chips */
    .service-link { text-decoration: none !important; }
    .qual-chip { text-decoration: none !important; }

    /* ─── FARBEN (CSS-Variablen) ───────────────────────── */
    :root {
      /* Neue Farbpalette: Terrakotta-Rose als Primärakzent */
      --rose:        #C97B6E;        /* Hauptakzent – warmes Terrakotta-Rose */
      --rose-light:  #F0D5CB;        /* Heller Rose-Hintergrund */
      --rose-hover:  #B56A5E;        /* Rose Hover */
      --mauve:       #9E6E7A;        /* Eyebrows, Tags */
      --mauve-light: #F2E8EC;
      --cream:       #FAF4EE;        /* Hintergrund – warmes Off-White */
      --cream-warm:  #F5EDE3;        /* Etwas wärmerer Creme-Hintergrund */
      --gold:        #C5A050;        /* Akzent für Sterne/Preise */
      --dark:        #2F2F2F;
      --sage:        #8E9B87;        /* Sekundär – Natur (beibehalten) */
      --sage-light:  #eef0ec;
      --grey:        #666;
      --grey-light:  #999;
      --white:       #fff;
      --radius-card: 28px;
      --radius-btn:  999px;
      --shadow-card: 0 2px 16px rgba(180,100,80,0.08);
      --shadow:      0 4px 24px rgba(180,100,80,0.10);
      --max-w: 1240px;
    }

    /* ─── NAVIGATION ───────────────────────────────────── */
    header {
      position: fixed;
      width: 100%;
      top: 0;
      z-index: 999;
      background: rgba(250,244,238,0.94);
      backdrop-filter: blur(16px);
      -webkit-backdrop-filter: blur(16px);
      border-bottom: 1px solid rgba(201,123,110,0.12);
      transition: box-shadow 0.3s;
    }

    .nav {
      max-width: var(--max-w);
      margin: 0 auto;
      padding: 10px 32px;
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 24px;
    }

    /* ⬆ LOGO-FIX: gross und klar sichtbar */
    .logo img {
      height: 100px;
      width: auto;
      display: block;
    }

    .nav-links {
      display: flex;
      gap: 32px;
      font-size: 0.92rem;
      color: #555;
      font-weight: 500;
    }

    .nav-links a:hover { color: var(--dark); }

    .nav-cta {
      background: var(--rose);
      color: var(--white) !important;
      padding: 10px 22px;
      border-radius: var(--radius-btn);
      font-weight: 600;
      font-size: 0.88rem;
      white-space: nowrap;
      transition: background 0.2s;
      box-shadow: 0 2px 12px rgba(201,123,110,0.30);
    }
    .nav-cta:hover { background: var(--rose-hover); }

    /* ─── BUTTONS ──────────────────────────────────────── */
    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      padding: 16px 36px;
      border-radius: var(--radius-btn);
      background: var(--rose);
      color: #fff;
      font-weight: 600;
      font-size: 1rem;
      transition: all 0.25s ease;
      border: none;
      cursor: pointer;
      box-shadow: 0 4px 20px rgba(201,123,110,0.35);
    }
    .btn:hover { background: var(--rose-hover); transform: translateY(-2px); }

    .btn-dark {
      background: var(--dark);
      color: var(--white);
    }
    .btn-dark:hover { background: #444; }

    .btn-outline {
      background: transparent;
      border: 2px solid rgba(47,47,47,0.25);
      color: var(--dark);
    }
    .btn-outline:hover { border-color: var(--rose); color: var(--rose); background: transparent; }

    /* WhatsApp-Button */
    .btn-whatsapp {
      background: #25D366;
      color: var(--white);
    }
    .btn-whatsapp:hover { background: #1ebe5d; }

    /* Instagram-Button */
    .btn-instagram {
      background: #E1306C;
      color: #fff !important;
      -webkit-text-fill-color: #fff !important;
    }
    .btn-instagram:hover { background: #c9205a; }

    /* ─── SECTIONS ─────────────────────────────────────── */
    section { padding: 100px 32px; }

    .container {
      max-width: var(--max-w);
      margin: 0 auto;
    }

    .section-header { margin-bottom: 56px; }

    .eyebrow-label {
      display: inline-block;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      font-size: 0.75rem;
      font-weight: 600;
      color: var(--mauve);
      margin-bottom: 14px;
    }

    .section-title {
      font-family: 'Poppins', sans-serif !important;
      font-size: clamp(2rem, 3.5vw, 3rem) !important;
      font-weight: 600 !important;
      line-height: 1.15 !important;
      margin-bottom: 18px;
    }

    .section-subtitle {
      max-width: 680px;
      color: var(--grey);
      font-size: 1.05rem !important;
      font-weight: 400 !important;
      font-family: 'Inter', sans-serif !important;
      line-height: 1.8;
    }

    /* Trust- und Service-Karten h3 */
    .trust-card h3,
    .service-content h3,
    .lernt-card h3,
    .empfehlung-card h3,
    .notstand-card .notstand-name,
    .pricing-card h3 {
      font-family: 'Poppins', sans-serif !important;
      font-size: 1rem !important;
      font-weight: 600 !important;
      line-height: 1.3 !important;
      color: #2F2F2F !important;
    }

    /* ─── HERO BUTTON OVERRIDES ── */
    .hero .btn {
      background: var(--cream) !important;
      color: var(--dark) !important;
      -webkit-text-fill-color: var(--dark) !important;
      box-shadow: 0 4px 20px rgba(0,0,0,0.20) !important;
      font-weight: 700;
    }
    .hero .btn:hover {
      background: #fff !important;
      color: var(--dark) !important;
      -webkit-text-fill-color: var(--dark) !important;
      transform: translateY(-2px);
    }
    .hero .btn-outline {
      background: transparent !important;
      border: 2px solid rgba(255,255,255,0.6) !important;
      color: #fff !important;
      -webkit-text-fill-color: #fff !important;
      box-shadow: none !important;
    }
    .hero .btn-outline:hover {
      border-color: #fff !important;
      background: rgba(255,255,255,0.12) !important;
      color: #fff !important;
      -webkit-text-fill-color: #fff !important;
    }

    /* ─── HERO ─────────────────────────────────────────── */
    /*
      BILDEMPFEHLUNG HERO:
      Ideal: Hunde in Bewegung in natürlicher Umgebung (Wiese, Wald, Seeufer).
      Am besten 2–3 Hunde zusammen, goldene Stunde (warm light).
      NICHT: enge Räume, gestellte Stockfotos, einzelner Hund auf weissem BG.

      Aktuelle Datei: hero1.jpg (professionelles Shooting, Isabel mit Hunden im Garten)
      Overlay: neutrales Dunkel-Gradient von unten (kein Farbstich), Text gut lesbar.
    */
    .hero {
      min-height: 100vh;
      background-size: cover !important;
      background-position: center center !important;
      background-repeat: no-repeat !important;
      display: flex;
      align-items: flex-end;
      color: white;
      padding: 160px 32px 80px;
      position: relative;
    }

    .hero-content {
      max-width: var(--max-w);
      margin: 0 auto;
      width: 100%;
    }

    .hero-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      letter-spacing: 2px;
      text-transform: uppercase;
      font-size: 0.72rem;
      font-weight: 600;
      margin-bottom: 20px;
      color: rgba(255,255,255,0.92);
      background: rgba(255,255,255,0.15);
      border: 1px solid rgba(255,255,255,0.3);
      padding: 6px 16px;
      border-radius: 999px;
      backdrop-filter: blur(8px);
    }
    .hero-eyebrow::before {
      content: '●';
      font-size: 0.45rem;
      color: rgba(255,255,255,0.7);
    }

    .hero h1 {
      font-family: 'Poppins', sans-serif;
      font-size: clamp(3rem, 6.5vw, 6rem);
      font-weight: 700;
      line-height: 1.04;
      margin-bottom: 28px;
      max-width: 640px;
    }

    .hero-accent {
      color: var(--gold);
    }

    .hero p {
      font-size: 1.1rem;
      max-width: 520px;
      margin-bottom: 36px;
      color: rgba(255,255,255,0.88);
      line-height: 1.75;
    }

    .hero-btns {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
      align-items: center;
      margin-bottom: 56px;
    }

    .hero-trust {
      display: flex;
      gap: 28px;
      flex-wrap: wrap;
    }

    .hero-trust-item {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 0.88rem;
      color: rgba(255,255,255,0.82);
    }

    .hero-trust-item svg {
      opacity: 0.7;
      flex-shrink: 0;
    }

    /* Scroll-Indikator */
    .hero-scroll-indicator {
      position: absolute;
      bottom: 28px;
      right: 40px;
      font-size: 0.65rem;
      font-weight: 700;
      letter-spacing: 3px;
      color: rgba(255,255,255,0.45);
      writing-mode: vertical-rl;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 8px;
    }
    .hero-scroll-indicator::after {
      content: '';
      display: block;
      width: 1px;
      height: 36px;
      background: rgba(255,255,255,0.3);
    }

    /* ─── TRUST / VERTRAUEN ────────────────────────────── */
    .trust-section {
      background: var(--cream-warm);
      position: relative;
      overflow: hidden;
    }

    .trust-section::before {
      content: '';
      position: absolute; bottom: -80px; right: -80px;
      width: 300px; height: 300px; border-radius: 50%;
      background: var(--rose-light);
      opacity: 0.45;
      pointer-events: none;
    }

    .trust-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
      gap: 20px;
    }

    .trust-card {
      background: var(--white);
      border-radius: var(--radius-card);
      padding: 34px 30px;
      box-shadow: var(--shadow-card);
      border: 1.5px solid transparent;
      transition: transform 0.25s ease, border-color 0.25s, box-shadow 0.25s ease;
      position: relative;
      overflow: hidden;
    }

    .trust-card::after {
      content: '';
      position: absolute; top: 0; left: 0; right: 0;
      height: 3px;
      background: linear-gradient(90deg, var(--rose-light), var(--mauve-light));
      opacity: 0;
      transition: opacity 0.25s;
    }

    .trust-card:hover {
      transform: translateY(-5px);
      border-color: var(--rose-light);
      box-shadow: 0 16px 48px rgba(201,123,110,0.14);
    }

    .trust-card:hover::after { opacity: 1; }

    .trust-icon {
      width: 52px;
      height: 52px;
      background: linear-gradient(135deg, var(--rose-light), var(--mauve-light));
      border-radius: 14px;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 20px;
    }

    .trust-card h3 {
      font-family: 'Poppins', sans-serif;
      font-size: 1.05rem;
      font-weight: 600;
      margin-bottom: 10px;
    }

    .trust-card p {
      color: var(--grey);
      font-size: 0.93rem;
      line-height: 1.65;
    }

    /* ─── SERVICES ─────────────────────────────────────── */
    .services { background: var(--white); }

    .service-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 28px;
    }

    @media (max-width: 720px) {
      .service-grid {
        grid-template-columns: 1fr;
      }
    }

    .service-card {
      overflow: hidden;
      border-radius: 28px;
      background: var(--cream);
      transition: transform 0.25s ease, box-shadow 0.25s ease;
    }

    .service-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 20px 56px rgba(201,123,110,0.14);
    }

    /*
      BILDEMPFEHLUNG SERVICES:
      Tagesbetreuung   → imgi-20-image.jpg         (Hunde beim Spielen / Gruppenmoment)
      Ferienbetreuung  → imgi-121-image.jpg         (ruhiger, geborgener Moment)
      Spazierservice   → image2-2026-05-18-at-11-36-53.jpg  (Waldweg mit Isabel + Gruppe, object-position: center 35%)
      Ideal: Querformat, deutliche Hauptmotive, konsistente Helligkeit.
    */
    .service-card img {
      height: 280px;
      width: 100%;
      object-fit: cover;
      transition: transform 0.4s ease;
    }

    .service-card:hover img { transform: scale(1.03); }

    .service-content {
      padding: 30px 28px;
    }

    .service-tag {
      display: inline-block;
      background: var(--rose-light);
      color: var(--rose);
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      padding: 5px 14px;
      border-radius: 999px;
      margin-bottom: 12px;
    }

    .service-content h3 {
      font-family: 'Poppins', sans-serif;
      margin-bottom: 10px;
      font-size: 1.35rem;
      font-weight: 600;
    }

    .service-content p {
      color: var(--grey);
      font-size: 0.95rem;
      line-height: 1.7;
      margin-bottom: 20px;
    }

    .service-highlight {
      display: flex;
      align-items: center;
      gap: 12px;
      margin-top: 16px;
      padding: 14px 18px;
      background: var(--rose-light);
      border-radius: 14px;
      border-left: 3px solid var(--rose);
    }

    .service-highlight-icon {
      font-size: 1.4rem;
      flex-shrink: 0;
    }

    .service-highlight strong {
      display: block;
      font-family: 'Poppins', sans-serif;
      font-size: 0.95rem;
      font-weight: 700;
      color: var(--rose-hover);
    }

    .service-highlight span {
      font-size: 0.82rem;
      color: var(--rose-hover);
      opacity: 0.8;
    }

    .service-link {
      font-size: 0.88rem;
      font-weight: 600;
      color: var(--sage);
      display: inline-flex;
      align-items: center;
      gap: 4px;
    }

    .service-link::after { content: ' →'; }

    /* ─── ÜBER MICH ────────────────────────────────────── */
    #ueber {
      background: var(--cream-warm);
    }

    .about-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center;
    }

    /*
      BILDEMPFEHLUNG ÜBER MICH:
      Porträt von Isabel Mock mit einem oder mehreren Hunden.
      Natürliches Licht, draussen oder heller Raum.
      Kein Studioweiss-Hintergrund – Natur oder Heimatgefühl.
      Aktuelle Datei: haupt/imgi_3_image.jpg
    */
    .about-img {
      position: relative;
    }

    .about-img img {
      width: 100%;
      height: 680px;
      object-fit: cover;
      border-radius: 32px;
    }

    .about-badge {
      position: absolute;
      bottom: -20px;
      right: -20px;
      background: var(--white);
      border-radius: 20px;
      padding: 20px 24px;
      box-shadow: 0 8px 32px rgba(201,123,110,0.18);
      border: 1.5px solid var(--rose-light);
      text-align: center;
    }

    .about-badge strong {
      display: block;
      font-family: 'Poppins', sans-serif;
      font-size: 1.6rem;
      font-weight: 700;
      color: var(--rose);
    }

    .about-badge span {
      font-size: 0.8rem;
      color: var(--grey);
    }

    .about-text h2 {
      font-family: 'Poppins', sans-serif;
      font-size: clamp(2rem, 3.5vw, 2.8rem);
      font-weight: 600;
      margin-bottom: 22px;
      line-height: 1.2;
    }

    .about-text p {
      color: var(--grey);
      font-size: 1rem;
      line-height: 1.8;
      margin-bottom: 20px;
    }

    .quote {
      margin: 32px 0;
      padding: 24px 24px 24px 28px;
      border-left: 4px solid var(--rose-light);
      background: rgba(201,123,110,0.07);
      border-radius: 0 16px 16px 0;
      font-size: 1.15rem;
      color: #7a4a42;
      font-weight: 500;
      font-style: italic;
      line-height: 1.65;
    }

    .about-quals {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin: 24px 0;
    }

    .qual-chip {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: var(--white);
      border: 1.5px solid var(--rose-light);
      color: var(--dark);
      padding: 7px 16px;
      border-radius: 999px;
      font-size: 0.85rem;
      font-weight: 500;
    }
    .qual-chip::before { content: '🐾'; font-size: 0.78rem; }

    /* ─── PREISE ───────────────────────────────────────── */
    .pricing-section {
      background: var(--cream);
    }

    .pricing-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
      gap: 20px;
      margin-bottom: 48px;
    }

    .pricing-card {
      background: var(--white);
      border-radius: var(--radius-card);
      padding: 36px 32px;
      box-shadow: var(--shadow-card);
      position: relative;
      overflow: hidden;
      border: 1.5px solid transparent;
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .pricing-card:hover {
      transform: translateY(-3px);
      box-shadow: 0 16px 48px rgba(201,123,110,0.16);
    }

    /* Featured: rose-Akzent */
    .pricing-card.featured {
      background: var(--rose-light);
      border-color: var(--rose);
    }

    .pricing-badge {
      position: absolute;
      top: 18px;
      right: 18px;
      background: var(--rose-light);
      color: var(--rose);
      font-size: 0.7rem;
      font-weight: 700;
      letter-spacing: 1px;
      text-transform: uppercase;
      padding: 4px 12px;
      border-radius: 99px;
    }

    .pricing-label {
      font-size: 0.75rem;
      font-weight: 600;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: var(--mauve);
      margin-bottom: 10px;
    }

    .pricing-card h3 {
      font-family: 'Poppins', sans-serif;
      font-size: 1.35rem;
      font-weight: 600;
      margin-bottom: 14px;
      color: var(--dark);
    }

    .pricing-price {
      font-family: 'Poppins', sans-serif;
      font-size: 2.6rem;
      font-weight: 700;
      margin-bottom: 4px;
      color: var(--dark);
      line-height: 1;
    }

    .pricing-unit {
      font-size: 0.82rem;
      color: var(--grey-light);
      margin-bottom: 20px;
    }

    .pricing-card p {
      color: var(--grey);
      font-size: 0.92rem;
      line-height: 1.7;
    }

    /* Zuschlagstabelle */
    .pricing-surcharges {
      border-radius: 20px;
      overflow: hidden;
      background: var(--white);
      box-shadow: var(--shadow-card);
    }

    .surcharge-row {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 15px 28px;
      font-size: 0.94rem;
      color: var(--dark);
      border-bottom: 1px solid rgba(0,0,0,0.04);
    }

    .surcharge-row:last-child { border-bottom: none; }
    .surcharge-row:nth-child(even) { background: var(--cream); }

    .surcharge-price {
      font-family: 'Poppins', sans-serif;
      font-weight: 600;
      color: var(--dark);
      white-space: nowrap;
      margin-left: 24px;
    }

    /* Übernachtungs-Box */
    .pricing-overnight {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 32px;
      background: var(--cream);
      border: 1.5px solid var(--rose-light);
      border-radius: var(--radius-card);
      padding: 36px 40px;
      margin-bottom: 0;
    }

    .pricing-overnight-left { flex: 1; }

    .pricing-overnight-left h3 {
      font-family: 'Poppins', sans-serif;
      font-size: 1.5rem;
      font-weight: 600;
      margin-bottom: 10px;
      color: var(--dark);
    }

    .pricing-overnight-left p {
      color: var(--grey);
      font-size: 0.93rem;
      line-height: 1.7;
      max-width: 480px;
    }

    .pricing-overnight-right {
      text-align: right;
      flex-shrink: 0;
    }

    @media (max-width: 600px) {
      .pricing-overnight {
        flex-direction: column;
        align-items: flex-start;
        gap: 20px;
      }
      .pricing-overnight-right { text-align: left; }
    }

    .pricing-info-box {
      margin-top: 32px;
      max-width: 720px;
      padding: 20px 26px;
      background: var(--rose-light);
      border-radius: 16px;
      color: var(--rose-hover);
      font-size: 0.92rem;
      line-height: 1.7;
    }

    .pricing-note {
      text-align: center;
      color: var(--grey);
      font-size: 0.9rem;
      margin-top: 12px;
    }

    /* ─── GALERIE ──────────────────────────────────────── */
    .gallery { background: var(--white); }

    /*
      GALERIE – 14 Bilder (6 alt + 8 neu vom 18.05.2026), 3-spaltig
      Reihenfolge: See → Gruppe aktiv → Wald → Pause → Winter → Garten → Ruhe
       1. image-2026-05-18-at-11-36-53.jpg  [featured, span 2] Isabel + 6 Hunde am See
       2. imgi-9-image.jpg                  Hundegruppe Zürichsee
       3. image1-2026-05-18-at-11-36-54.jpg Gruppenspaziergang Sommer
       4. image3-2026-05-18-at-11-36-53.jpg Waldweg grün
       5. image5-2026-05-18-at-11-36-53.jpg 10 Hunde von hinten im Wald
       6. imgi-4-image.jpg                  Herrliberg
       7. image2-2026-05-18-at-11-36-53.jpg Baumstämme Wald
       8. imgi-6-image.jpg                  Freilauf Pfannenstiel
       9. image4-2026-05-18-at-11-36-53.jpg Winterspaziergang
      10. imgi-10-image.jpg                 Hundebetreuung Zürich
      11. image6-2026-05-18-at-11-36-53.jpg Garten Freilauf
      12. image-2026-05-18-at-11-36-54.jpg  Ruhepause drinnen
      13. imgi-30-image.jpg                 Zürichsee
      14. imgi-31-image.jpg                 Egg Zürich
    */
    .gallery-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      grid-template-rows: auto auto;
      gap: 16px;
    }

    .gallery-grid img {
      width: 100%;
      height: 420px;
      object-fit: cover;
      object-position: center center;
      border-radius: 22px;
      transition: transform 0.3s ease;
      cursor: pointer;
    }

    .gallery-grid img:hover { transform: scale(1.02); }

    /* Erstes Bild grösser (2 Spalten) */
    .gallery-grid img:first-child {
      grid-column: span 2;
      height: 520px;
    }

    /* ─── TESTIMONIALS ─────────────────────────────────── */
    .testimonials-section {
      background: var(--white);
    }

    .testimonials-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
      gap: 22px;
    }
    .testimonials-grid--4 {
      grid-template-columns: repeat(2, 1fr);
    }

    .testimonial {
      background: var(--cream);
      padding: 36px;
      border-radius: var(--radius-card);
      box-shadow: var(--shadow-card);
      border: 1.5px solid transparent;
      position: relative;
      transition: border-color 0.25s, box-shadow 0.25s;
    }
    .testimonial:hover {
      border-color: var(--rose-light);
      box-shadow: var(--shadow);
    }

    .testimonial::before {
      content: '"';
      font-family: 'Poppins', serif;
      font-size: 5rem;
      line-height: 1;
      color: var(--rose-light);
      opacity: 0.8;
      position: absolute;
      top: 16px;
      left: 28px;
    }

    .testimonial p {
      font-size: 0.98rem;
      line-height: 1.75;
      color: #444;
      margin-bottom: 20px;
      padding-top: 28px;
    }

    .testimonial-author {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .testimonial-avatar {
      width: 44px;
      height: 44px;
      background: linear-gradient(135deg, var(--rose-light), var(--mauve-light));
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.88rem;
      font-weight: 700;
      color: var(--rose-hover);
    }

    .testimonial-name {
      font-weight: 600;
      font-size: 0.9rem;
      color: var(--dark);
    }

    .testimonial-stars {
      font-size: 0.88rem;
      color: var(--gold);
      letter-spacing: 2px;
    }

    .faq-section {
      background: var(--white);
    }

    /* ─── FAQ ──────────────────────────────────────────── */
    .faq-list {
      max-width: 780px;
    }

    .faq-item {
      border-bottom: 1px solid rgba(0,0,0,0.07);
    }

    .faq-question {
      width: 100%;
      text-align: left;
      background: none;
      border: none;
      padding: 22px 0;
      font-family: 'Inter', sans-serif;
      font-size: 1rem;
      font-weight: 600;
      color: var(--dark);
      cursor: pointer;
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 16px;
    }

    .faq-question::after {
      content: '+';
      font-size: 1.4rem;
      font-weight: 300;
      color: var(--rose);
      flex-shrink: 0;
    }

    .faq-answer {
      display: none;
      padding: 0 0 22px;
      color: var(--grey);
      font-size: 0.95rem;
      line-height: 1.8;
    }

    .faq-item.open .faq-answer { display: block; }
    .faq-item.open .faq-question::after { content: '−'; }

    /* ─── KONTAKT / CTA ────────────────────────────────── */
    .cta-section { background: var(--cream-warm); }

    .cta-box {
      background: linear-gradient(135deg, var(--rose) 0%, var(--mauve) 100%);
      border-radius: 40px;
      padding: 80px 60px;
      color: var(--white);
      text-align: center;
      position: relative;
      overflow: hidden;
    }
    .cta-box::before {
      content: '';
      position: absolute; top: -60px; right: -60px;
      width: 260px; height: 260px; border-radius: 50%;
      background: rgba(255,255,255,0.07);
      pointer-events: none;
    }
    .cta-box::after {
      content: '';
      position: absolute; bottom: -80px; left: -40px;
      width: 320px; height: 320px; border-radius: 50%;
      background: rgba(255,255,255,0.05);
      pointer-events: none;
    }

    .cta-box h2 {
      font-family: 'Poppins', sans-serif;
      font-size: clamp(2rem, 4vw, 3.2rem);
      font-weight: 600;
      margin-bottom: 20px;
      line-height: 1.2;
    }

    .cta-box p {
      color: rgba(255,255,255,0.75);
      font-size: 1.05rem;
      max-width: 600px;
      margin: 0 auto 40px;
      line-height: 1.75;
    }

    .cta-buttons {
      display: flex;
      gap: 14px;
      justify-content: center;
      flex-wrap: wrap;
    }

    /* Kontaktformular */
    .contact-form {
      background: var(--white);
      border-radius: var(--radius-card);
      padding: 48px;
      box-shadow: var(--shadow-card);
      max-width: 640px;
      margin: 60px auto 0;
    }

    .contact-form h3 {
      font-family: 'Poppins', sans-serif;
      font-size: 1.4rem;
      font-weight: 600;
      margin-bottom: 28px;
      text-align: center;
    }

    .form-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }

    .form-group {
      display: flex;
      flex-direction: column;
      gap: 6px;
      margin-bottom: 16px;
    }

    .form-group label {
      font-size: 0.85rem;
      font-weight: 600;
      color: #555;
    }

    .form-group input,
    .form-group textarea,
    .form-group select {
      padding: 13px 16px;
      border: 1.5px solid #e5e5e5;
      border-radius: 12px;
      font-family: 'Inter', sans-serif;
      font-size: 0.95rem;
      color: var(--dark);
      background: var(--cream);
      transition: border-color 0.2s;
      outline: none;
    }

    .form-group input:focus,
    .form-group textarea:focus,
    .form-group select:focus {
      border-color: var(--rose);
    }

    .form-group textarea { resize: vertical; min-height: 120px; }

    .form-submit {
      width: 100%;
      margin-top: 8px;
      padding: 16px;
      font-size: 1rem;
      cursor: pointer;
      border: none;
      font-family: 'Inter', sans-serif;
      font-weight: 600;
      border-radius: 999px;
      background: #2F2F2F;
      color: #fff;
      -webkit-text-fill-color: #fff;
      transition: background 0.2s ease;
    }
    .form-submit:hover { background: #444; }

    /* ─── JIMDO NATIVE FORMULAR STYLING ─────────────────── */
    /* Passt das Jimdo-Kontaktformular ans Design an */
    .jimdo-form-wrapper { margin-top: 8px; }

    .jimdo-form-wrapper .j-form,
    .jimdo-form-wrapper form { width: 100%; }

    /* Labels */
    .jimdo-form-wrapper label,
    .jimdo-form-wrapper .j-form-label {
      font-family: 'Inter', sans-serif !important;
      font-size: 0.85rem !important;
      font-weight: 600 !important;
      color: #555 !important;
      display: block;
      margin-bottom: 6px;
    }

    /* Eingabefelder */
    .jimdo-form-wrapper input[type="text"],
    .jimdo-form-wrapper input[type="email"],
    .jimdo-form-wrapper input[type="tel"],
    .jimdo-form-wrapper textarea,
    .jimdo-form-wrapper select,
    .jimdo-form-wrapper .j-form-input {
      width: 100% !important;
      padding: 13px 16px !important;
      border: 1.5px solid #e5e5e5 !important;
      border-radius: 12px !important;
      font-family: 'Inter', sans-serif !important;
      font-size: 0.95rem !important;
      color: #2F2F2F !important;
      background: #FAF4EE !important;
      box-sizing: border-box !important;
      outline: none !important;
      margin-bottom: 16px !important;
      -webkit-appearance: none;
    }

    .jimdo-form-wrapper input[type="text"]:focus,
    .jimdo-form-wrapper input[type="email"]:focus,
    .jimdo-form-wrapper input[type="tel"]:focus,
    .jimdo-form-wrapper textarea:focus {
      border-color: #C97B6E !important;
    }

    .jimdo-form-wrapper textarea {
      min-height: 120px !important;
      resize: vertical !important;
    }

    /* Absenden-Button */
    .jimdo-form-wrapper input[type="submit"],
    .jimdo-form-wrapper button[type="submit"],
    .jimdo-form-wrapper .j-form-submit {
      width: 100% !important;
      padding: 16px 32px !important;
      background: #2F2F2F !important;
      color: #ffffff !important;
      -webkit-text-fill-color: #ffffff !important;
      border: none !important;
      border-radius: 999px !important;
      font-family: 'Inter', sans-serif !important;
      font-size: 1rem !important;
      font-weight: 600 !important;
      cursor: pointer !important;
      margin-top: 8px !important;
      transition: background 0.2s ease !important;
    }

    .jimdo-form-wrapper input[type="submit"]:hover,
    .jimdo-form-wrapper button[type="submit"]:hover {
      background: #444444 !important;
    }

    /* Erfolgs-/Fehlermeldung */
    .jimdo-form-wrapper .j-form-message,
    .jimdo-form-wrapper .j-form-success {
      font-family: 'Inter', sans-serif !important;
      font-size: 0.95rem !important;
      padding: 12px 16px !important;
      border-radius: 12px !important;
      margin-top: 12px !important;
    }

    /* ─── FOOTER ───────────────────────────────────────── */
    footer {
      background: var(--dark);
      color: rgba(255,255,255,0.6);
      padding: 50px 32px 36px;
    }

    .footer-inner {
      max-width: var(--max-w);
      margin: 0 auto;
      display: grid;
      grid-template-columns: 2fr 1fr 1fr;
      gap: 48px;
      padding-bottom: 36px;
      border-bottom: 1px solid rgba(255,255,255,0.08);
    }

    .footer-brand p {
      font-size: 0.9rem;
      line-height: 1.7;
      margin-top: 14px;
      max-width: 320px;
    }

    .footer-logo-wrap {
      display: inline-block;
      background: rgba(255,255,255,0.08);
      border-radius: 16px;
      padding: 10px 18px;
      margin-bottom: 4px;
    }

    .footer-logo {
      height: 72px;
      width: auto;
      display: block;
    }

    .footer-col h4 {
      font-size: 0.82rem;
      font-weight: 700;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.4);
      margin-bottom: 16px;
    }

    .footer-col a {
      display: block;
      font-size: 0.9rem;
      color: rgba(255,255,255,0.6);
      margin-bottom: 10px;
      transition: color 0.2s;
    }

    .footer-col a:hover { color: var(--white); }

    .footer-bottom {
      max-width: var(--max-w);
      margin: 0 auto;
      padding-top: 28px;
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-wrap: wrap;
      gap: 12px;
      font-size: 0.84rem;
    }

    /* ─── HAMBURGER MENU ───────────────────────────────── */
    .menu-toggle {
      display: none;
      flex-direction: column;
      justify-content: center;
      gap: 5px;
      background: none;
      border: none;
      cursor: pointer;
      padding: 8px;
      z-index: 1001;
    }
    .menu-toggle span {
      display: block;
      width: 24px;
      height: 2px;
      background: #2F2F2F;
      border-radius: 2px;
      transition: all 0.3s ease;
    }

    #mobile-menu {
      display: none;
      position: fixed;
      top: 0; left: 0;
      width: 100%; height: 100%;
      background: rgba(250,244,238,0.98);
      z-index: 1000;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 0;
    }
    #mobile-menu.open { display: flex; }
    #mobile-menu nav {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 8px;
      width: 100%;
      padding: 0 32px;
    }
    #mobile-menu nav a {
      font-family: 'Poppins', sans-serif;
      font-size: 1.5rem;
      font-weight: 600;
      color: #2F2F2F !important;
      text-decoration: none !important;
      padding: 14px 0;
      width: 100%;
      text-align: center;
      border-bottom: 1px solid rgba(0,0,0,0.06);
    }
    #mobile-menu nav a:last-child { border-bottom: none; }
    #mobile-menu .mobile-cta {
      margin-top: 24px;
      background: #2F2F2F !important;
      color: #fff !important;
      -webkit-text-fill-color: #fff !important;
      border-radius: 999px;
      padding: 16px 32px !important;
      font-size: 1rem !important;
      border-bottom: none !important;
    }
    .menu-close {
      position: absolute;
      top: 28px; right: 28px;
      background: none;
      border: none;
      font-size: 1.5rem;
      cursor: pointer;
      color: #2F2F2F;
      line-height: 1;
    }

    /* ─── RESPONSIVE ───────────────────────────────────── */
    @media (max-width: 920px) {
      .nav-links, .nav-cta { display: none; }
      .menu-toggle { display: flex; }

      section { padding: 72px 20px; }
      .hero { padding: 140px 20px 80px; }

      .trust-grid { grid-template-columns: 1fr 1fr; gap: 16px; }

      .about-grid { grid-template-columns: 1fr; gap: 40px; }
      .about-img img { height: 420px; }
      .about-badge { bottom: 12px; right: 12px; }

      .gallery-grid { grid-template-columns: 1fr 1fr; }
      .gallery-grid img:first-child {
        grid-column: span 2;
        height: 320px;
      }
      .gallery-grid img { height: 260px; }

      .testimonials-grid { grid-template-columns: 1fr; }
      .testimonials-grid--4 { grid-template-columns: 1fr; }

      .pricing-grid { grid-template-columns: 1fr; gap: 20px; }
      .pricing-card.featured { transform: none; }

      .cta-box { padding: 52px 28px; border-radius: 24px; }

      .footer-inner {
        grid-template-columns: 1fr;
        gap: 36px;
      }

      .contact-form { padding: 32px 24px; }
      .form-row { grid-template-columns: 1fr; }
    }

    @media (max-width: 600px) {
      #content { padding-top: 90px; }

      body { font-size: 1.05rem; }

      .hero { padding: 120px 20px 60px; }
      .hero h1 { font-size: 2.5rem !important; line-height: 1.1; }
      .hero p {
        font-size: 1.05rem;
        background: rgba(0,0,0,0.35);
        backdrop-filter: blur(10px);
        -webkit-backdrop-filter: blur(10px);
        border-radius: 14px;
        padding: 14px 18px;
        display: inline-block;
      }
      .hero-eyebrow { font-size: 0.82rem; }
      .hero-btns { flex-direction: column; gap: 12px; }
      .hero-btns .btn { width: 100%; text-align: center; }
      .hero .btn-outline {
        background: rgba(0,0,0,0.35) !important;
        backdrop-filter: blur(10px) !important;
        -webkit-backdrop-filter: blur(10px) !important;
      }
      .hero-trust { flex-direction: column; gap: 12px; }
      .hero-trust-item { font-size: 0.9rem; }

      .trust-grid { grid-template-columns: 1fr; }
      .trust-card h3 { font-size: 1.1rem; }
      .trust-card p { font-size: 1rem; }

      .section-title { font-size: 1.9rem !important; }
      .section-subtitle { font-size: 1rem !important; }
      .eyebrow-label { font-size: 0.75rem; }

      .service-content h3 { font-size: 1.25rem; }
      .service-content p { font-size: 1rem; }

      .gallery-grid { grid-template-columns: 1fr; }
      .gallery-grid img, .gallery-grid img:first-child {
        grid-column: span 1;
        height: 300px;
      }

      .pricing-card h3 { font-size: 1.05rem !important; }
      .pricing-price { font-size: 2.2rem; }

      .faq-question { font-size: 1rem; }
      .faq-answer p { font-size: 1rem; }

      .contact-btns { flex-direction: column; }
      .contact-btns a { width: 100%; text-align: center; justify-content: center; }

      #footer .footer-bottom { flex-direction: column; gap: 8px; text-align: center; }
      #footer .footer-col a { font-size: 1rem; }
    }

    /* ─── BARF SECTION ─────────────────────────────────── */
    .barf-section {
      margin-top: 48px;
      background: var(--sage-light);
      border-radius: 28px;
      padding: 40px 44px;
      border: 1px solid rgba(142,155,135,0.2);
    }

    .barf-eyebrow {
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: var(--sage);
      margin-bottom: 10px;
      font-family: 'Inter', sans-serif;
    }

    .barf-title {
      font-family: 'Poppins', sans-serif;
      font-size: 1.5rem;
      font-weight: 600;
      color: var(--dark) !important;
      margin-bottom: 12px;
      line-height: 1.25;
    }

    .barf-lead {
      color: var(--grey);
      font-size: 0.95rem;
      line-height: 1.7;
      max-width: 680px;
      margin-bottom: 32px;
    }

    .barf-facts {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
      margin-bottom: 28px;
    }

    .barf-fact {
      display: flex;
      align-items: flex-start;
      gap: 12px;
      background: rgba(255,255,255,0.65);
      border-radius: 16px;
      padding: 16px 18px;
    }

    .barf-fact-icon {
      flex-shrink: 0;
      width: 36px;
      height: 36px;
      background: var(--white);
      border-radius: 10px;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .barf-fact strong {
      display: block;
      font-family: 'Inter', sans-serif;
      font-size: 0.88rem;
      font-weight: 600;
      color: var(--dark);
      margin-bottom: 4px;
    }

    .barf-fact span {
      font-size: 0.83rem;
      color: var(--grey);
      line-height: 1.55;
    }

    .barf-quote {
      font-size: 0.95rem;
      font-style: italic;
      color: #5c6b56;
      padding: 16px 20px;
      border-left: 3px solid var(--sage);
      background: rgba(255,255,255,0.5);
      border-radius: 0 12px 12px 0;
      margin-bottom: 24px;
    }

    .barf-actions {
      display: flex;
      gap: 14px;
      flex-wrap: wrap;
    }

    .barf-shop-btn {
      border-color: var(--sage) !important;
      color: #5c6b56 !important;
    }

    .barf-shop-btn:hover {
      background: var(--sage) !important;
      color: var(--white) !important;
    }

    @media (max-width: 920px) {
      .barf-section { padding: 28px 24px; }
      .barf-facts { grid-template-columns: 1fr; }
    }

    /* ─── DAS LERNT IHR HUND ───────────────────────────── */
    .lernt-section {
      background: var(--white);
    }

    .lernt-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 22px;
    }

    .lernt-card {
      background: var(--rose-light);
      border-radius: 22px;
      padding: 30px 26px;
      border: 1.5px solid transparent;
      transition: transform 0.2s ease, border-color 0.2s, box-shadow 0.2s ease;
    }

    .lernt-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 12px 40px rgba(201,123,110,0.18);
      border-color: var(--rose);
    }

    .lernt-icon {
      width: 48px;
      height: 48px;
      background: var(--white);
      border-radius: 14px;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 18px;
    }

    .lernt-card h3 {
      font-family: 'Poppins', sans-serif;
      font-size: 1rem;
      font-weight: 600;
      margin-bottom: 10px;
      color: var(--dark);
    }

    .lernt-card p {
      font-size: 0.9rem;
      color: var(--grey);
      line-height: 1.7;
    }

    @media (max-width: 920px) {
      .lernt-grid { grid-template-columns: repeat(2, 1fr); }
    }

    @media (max-width: 600px) {
      .lernt-grid { grid-template-columns: 1fr; gap: 14px; }
    }

    /* ─── SEMINARE ─────────────────────────────────────── */
    .seminare-section {
      background: var(--cream);
    }

    .seminare-list {
      max-width: 720px;
    }

    .seminar-item {
      display: grid;
      grid-template-columns: 130px 1fr;
      gap: 24px;
      align-items: start;
      padding: 20px 0;
      border-bottom: 1px solid rgba(0,0,0,0.06);
    }

    .seminar-item:last-child {
      border-bottom: none;
    }

    .seminare-sub-label {
      font-family: 'Inter', sans-serif;
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      color: var(--rose);
      background: var(--rose-light);
      display: inline-block;
      padding: 5px 14px;
      border-radius: 999px;
      margin-bottom: 8px;
      margin-top: 4px;
    }

    .seminare-sub-label--second {
      margin-top: 32px;
    }

    .seminar-note {
      font-size: 0.82rem;
      color: var(--rose-hover);
      opacity: 0.75;
      font-style: italic;
      margin-left: 4px;
    }

    .seminar-date {
      font-size: 0.8rem;
      font-weight: 600;
      color: var(--mauve);
      text-transform: uppercase;
      letter-spacing: 1px;
      padding-top: 3px;
      font-family: 'Inter', sans-serif;
    }

    .seminar-content h3 {
      font-family: 'Poppins', sans-serif;
      font-size: 1rem;
      font-weight: 600;
      color: var(--dark);
      margin-bottom: 5px;
    }

    .seminar-content p {
      font-size: 0.88rem;
      color: var(--grey);
    }

    @media (max-width: 600px) {
      .seminar-item {
        grid-template-columns: 1fr;
        gap: 6px;
      }
    }

    /* ─── EMPFEHLUNGEN ─────────────────────────────────── */
    .empfehlungen-section {
      background: var(--white);
    }

    .empfehlungen-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 20px;
    }

    .empfehlung-card {
      background: var(--rose-light);
      border-radius: 22px;
      padding: 30px 24px;
      display: flex;
      flex-direction: column;
      gap: 12px;
      border: 1.5px solid transparent;
      transition: transform 0.2s ease, border-color 0.2s, box-shadow 0.2s ease;
    }

    .empfehlung-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 12px 40px rgba(201,123,110,0.18);
      border-color: var(--rose);
    }

    .empfehlung-icon {
      width: 48px;
      height: 48px;
      background: var(--white);
      border-radius: 14px;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .empfehlung-card h3 {
      font-family: 'Poppins', sans-serif;
      font-size: 1rem;
      font-weight: 600;
      color: var(--dark) !important;
      margin: 0;
    }

    .empfehlung-card p {
      font-size: 0.88rem;
      color: var(--grey) !important;
      line-height: 1.55;
      margin: 0;
    }

    .empfehlung-link {
      display: inline-block;
      font-size: 0.82rem;
      font-weight: 600;
      color: var(--sage) !important;
      margin-top: auto;
      text-decoration: none !important;
    }

    .empfehlung-link:hover {
      color: #5c6b56 !important;
    }

    @media (max-width: 920px) {
      .empfehlungen-grid { grid-template-columns: repeat(2, 1fr); }
    }

    @media (max-width: 480px) {
      .empfehlungen-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
    }

    /* ─── TIERE IM NOTSTAND ────────────────────────────── */
    .notstand-section {
      background: var(--cream);
    }

    .notstand-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 22px;
    }

    .notstand-card {
      background: var(--rose-light);
      border-radius: 22px;
      padding: 32px 28px;
      border: 1.5px solid rgba(201,123,110,0.20);
      position: relative;
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .notstand-card:hover {
      transform: translateY(-3px);
      box-shadow: 0 12px 40px rgba(201,123,110,0.18);
    }

    .notstand-card::before {
      content: '♥';
      position: absolute;
      top: 20px;
      right: 24px;
      font-size: 1.2rem;
      color: var(--rose);
      opacity: 0.5;
    }

    .notstand-name {
      font-family: 'Poppins', sans-serif;
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--dark);
      margin-bottom: 14px;
    }

    .notstand-card p {
      font-size: 0.93rem;
      color: var(--grey);
      line-height: 1.75;
      font-style: italic;
      margin-bottom: 18px;
    }

    .notstand-date {
      font-size: 0.78rem;
      font-weight: 600;
      color: var(--rose-hover);
      text-transform: uppercase;
      letter-spacing: 1px;
    }

    @media (max-width: 920px) {
      .notstand-grid { grid-template-columns: 1fr; max-width: 560px; }
    }

    /* ─── FERIENZEITEN ─────────────────────────────────── */
    .ferienzeiten-section {
      background: var(--cream-warm);
    }

    .ferien-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 20px;
      margin-bottom: 36px;
    }

    .ferien-card {
      background: var(--white);
      border-radius: 22px;
      padding: 28px 24px;
      border: 2px solid var(--rose-light);
      position: relative;
      overflow: hidden;
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .ferien-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 12px 40px rgba(201,123,110,0.15);
    }

    .ferien-card::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 4px;
      background: var(--rose-light);
      border-radius: 2px 2px 0 0;
    }

    .ferien-card.ferien-next::before {
      background: #e8913a;
    }

    .ferien-card.ferien-past {
      opacity: 0.42;
    }

    .ferien-card.ferien-past:hover {
      transform: none;
      box-shadow: none;
    }

    .ferien-monat {
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: var(--sage);
      margin-bottom: 10px;
      font-family: 'Inter', sans-serif;
    }

    .ferien-card.ferien-next .ferien-monat {
      color: #e8913a;
    }

    .ferien-dates {
      font-family: 'Poppins', sans-serif;
      font-size: 1.1rem;
      font-weight: 600;
      color: var(--dark);
      line-height: 1.35;
    }

    .ferien-status {
      margin-top: 14px;
      font-size: 0.77rem;
      font-weight: 600;
      color: #aaa;
      font-family: 'Inter', sans-serif;
      text-transform: uppercase;
      letter-spacing: 1px;
    }

    .ferien-upcoming {
      color: #e8913a;
    }

    .ferien-hinweis {
      display: flex;
      align-items: flex-start;
      gap: 12px;
      padding: 20px 24px;
      background: rgba(201,123,110,0.08);
      border-radius: 16px;
      border: 1px solid rgba(201,123,110,0.20);
      max-width: 680px;
      font-size: 0.93rem;
      color: var(--grey);
      line-height: 1.75;
    }

    .ferien-hinweis svg {
      flex-shrink: 0;
      color: var(--rose-hover);
      margin-top: 3px;
    }

    @media (max-width: 920px) {
      .ferien-grid { grid-template-columns: 1fr 1fr; gap: 16px; }
    }

    @media (max-width: 480px) {
      .ferien-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
      .ferien-dates { font-size: 0.95rem; }
      .ferien-card { padding: 20px 16px; }
    }