/* Selbstgehostete Schriften (kein Google-Server, DSGVO-freundlich) */
@font-face{font-family:'Montserrat';font-style:normal;font-weight:400 700;font-display:swap;src:url('../fonts/montserrat.woff2') format('woff2')}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:400;font-display:swap;src:url('../fonts/fraunces-italic.woff2') format('woff2')}

/* =================================================================
   FAMILIENHUND MIT HERZ — Designsystem
   Montserrat-geführt · Creme/Sage · Herz-Rot als einziger Akzent
   Signature: das rote Herz (Loader, Divider, CTA-Puls, Scroll-Reveal)
   ================================================================= */

/* ---------- 1. Design-Tokens ---------- */
:root{
  /* Flächen */
  --papier:#FBF8F2;      /* Warmweiß, Haupt-Hintergrund */
  --creme:#F3ECDF;       /* Creme, Sektionswechsel */
  --sand:#E8DCC6;        /* Sand, Karten/Chips */
  --sage:#8DA081;        /* Sage Green, Markengrün */
  --sage-tief:#5C6E52;   /* dunkles Grün, Text auf hell */
  --sage-hell:#DDE4D5;   /* zartes Grün, Flächen/Blobs */

  /* Schrift & Linien */
  --tinte:#39352F;       /* warmes Fast-Schwarz */
  --tinte-weich:#6B655C; /* Fließtext gedämpft */
  --linie:#E4DAC8;       /* Hairlines */

  /* Akzent — NUR Herz */
  --herz:#A82F3D;
  --herz-tief:#8E2531;

  /* Maße */
  --maxw:1180px;
  --maxw-text:680px;
  --r-s:14px;
  --r-m:22px;
  --r-l:32px;
  --r-pill:999px;

  /* Tempo */
  --t-schnell:.2s cubic-bezier(.4,0,.2,1);
  --t-ruhig:.5s cubic-bezier(.22,1,.36,1);

  --schatten-weich:0 18px 50px -28px rgba(57,53,47,.35);
  --schatten-karte:0 10px 30px -20px rgba(57,53,47,.4);
}

/* ---------- 2. Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0}
img,picture,svg{display:block;max-width:100%}
img{height:auto}
button,input,textarea,select{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,p,figure,blockquote,ul,ol{margin:0}
ul[class]{list-style:none;padding:0}

/* ---------- 3. Basis-Typografie ---------- */
body{
  font-family:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',Arial,sans-serif;
  background:var(--papier);
  color:var(--tinte);
  font-size:clamp(1.02rem,.97rem + .25vw,1.15rem);
  line-height:1.72;
  font-weight:400;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

h1,h2,h3,h4{font-weight:600;line-height:1.12;letter-spacing:-.015em;color:var(--tinte)}
.h-display{font-size:clamp(2.5rem,1.6rem + 4.4vw,4.6rem);font-weight:600;line-height:1.04;letter-spacing:-.025em}
h1{font-size:clamp(2.1rem,1.5rem + 3vw,3.5rem)}
h2{font-size:clamp(1.7rem,1.25rem + 2.2vw,2.7rem)}
h3{font-size:clamp(1.2rem,1.05rem + .8vw,1.55rem);letter-spacing:-.01em}
h4{font-size:1.05rem;font-weight:600;letter-spacing:0}
p{max-width:var(--maxw-text)}
strong{font-weight:600}

/* Eyebrow / Label — gesperrt, Sage, Funktionssignal */
.eyebrow{
  font-size:.78rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--sage-tief);display:inline-flex;align-items:center;gap:.6em;margin:0 0 1rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--sage)}

/* Editoriale Großzitate — einziger Serif-Einsatz (Echo zum E-Book) */
.pull{
  font-family:'Fraunces',Georgia,'Times New Roman',serif;
  font-weight:400;font-style:italic;
  font-size:clamp(1.5rem,1.1rem + 1.9vw,2.4rem);
  line-height:1.28;letter-spacing:-.01em;color:var(--tinte);
  max-width:18ch;
}

/* ---------- 4. Layout ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.15rem,4vw,2.4rem)}
.section{padding-block:clamp(3.6rem,2.5rem + 5vw,7rem)}
.section--creme{background:var(--creme)}
.section--sage{background:var(--sage-tief);color:#F6F1E8}
.section--sage h1,.section--sage h2,.section--sage h3{color:#fff}
.section--sage .eyebrow{color:#cdd6c2}
.section--sage .eyebrow::before{background:#9fb094}
.center{text-align:center}
.center .eyebrow{justify-content:center}
.center p{margin-inline:auto}
.lede{font-size:clamp(1.1rem,1rem + .6vw,1.3rem);color:var(--tinte-weich);line-height:1.7}
.stack>*+*{margin-top:1.1rem}
.measure{max-width:var(--maxw-text)}

/* ---------- 5. Header / Navigation ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(251,248,242,.82);backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent;transition:border-color var(--t-schnell),background var(--t-schnell);
}
.site-header.is-scrolled{border-bottom-color:var(--linie)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;min-height:74px}
.brand{display:flex;flex-direction:column;line-height:1;gap:.18em;padding-block:.4rem}
.brand__top{font-weight:600;letter-spacing:.085em;font-size:1.04rem;color:#4a4744}
.brand__bottom{display:flex;align-items:center;gap:.4em;font-weight:400;letter-spacing:.04em;font-size:.95rem;color:#4a4744}
.brand__bottom svg{width:15px;height:auto;color:var(--herz)}
.nav__links{display:flex;align-items:center;gap:.35rem;list-style:none;margin:0;padding:0}
.nav__links a{
  display:inline-block;padding:.55rem .85rem;border-radius:var(--r-pill);
  font-size:.95rem;font-weight:500;color:var(--tinte);transition:background var(--t-schnell),color var(--t-schnell);
}
.nav__links a:hover{background:var(--sage-hell)}
.nav__links a[aria-current="page"]{color:var(--sage-tief);font-weight:600}
.nav__cta{margin-left:.4rem}
.nav__toggle{display:none;border:0;background:none;cursor:pointer;padding:.5rem;width:44px;height:44px;border-radius:12px}
.nav__toggle span{display:block;width:22px;height:2px;background:var(--tinte);margin:5px auto;transition:transform var(--t-schnell),opacity var(--t-schnell)}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:860px){
  .nav__toggle{display:block}
  .nav__links{
    position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;gap:.2rem;
    background:var(--papier);border-bottom:1px solid var(--linie);
    padding:1rem clamp(1.15rem,4vw,2.4rem) 1.6rem;
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity var(--t-schnell),transform var(--t-schnell);
  }
  .nav__links.is-open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav__links a{padding:.85rem 1rem;font-size:1.05rem}
  .nav__cta{margin:.4rem 0 0}
  .btn--nav{width:100%;justify-content:center}
}

/* ---------- 6. Buttons + CTA-Herzpuls ---------- */
.btn{
  --b:var(--herz);
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:.92em 1.6em;border-radius:var(--r-pill);border:1.5px solid transparent;
  font-weight:600;font-size:.98rem;letter-spacing:.01em;cursor:pointer;
  transition:transform var(--t-schnell),box-shadow var(--t-schnell),background var(--t-schnell),color var(--t-schnell),border-color var(--t-schnell);
  will-change:transform;
}
.btn:focus-visible{outline:3px solid var(--sage);outline-offset:3px}
.btn--primary{background:var(--herz);color:#fff;box-shadow:0 12px 26px -16px rgba(168,47,61,.85)}
.btn--primary:hover{background:var(--herz-tief);transform:translateY(-2px);box-shadow:0 18px 34px -16px rgba(168,47,61,.9)}
.btn--ghost{background:transparent;color:var(--tinte);border-color:var(--linie)}
.btn--ghost:hover{border-color:var(--sage);background:var(--sage-hell);transform:translateY(-2px)}
.btn--sage{background:var(--sage);color:#fff}
.btn--sage:hover{background:var(--sage-tief);transform:translateY(-2px)}
.btn--light{background:#F6F1E8;color:var(--tinte)}
.btn--light:hover{background:#fff;transform:translateY(-2px)}
.btn--lg{padding:1.05em 2em;font-size:1.05rem}

/* Herz im CTA: schlägt einmal beim Hover */
.btn .beat{width:1em;height:1em;color:currentColor}
.btn:hover .beat{animation:beat .9s ease both}
@keyframes beat{0%{transform:scale(1)}18%{transform:scale(1.28)}36%{transform:scale(.96)}54%{transform:scale(1.16)}100%{transform:scale(1)}}

/* ---------- 7. Hero ---------- */
.hero{position:relative;overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,4rem);align-items:center;
  padding-block:clamp(2.6rem,2rem + 4vw,5.5rem)}
.hero__media{position:relative}
.hero__media img{border-radius:var(--r-l);box-shadow:var(--schatten-weich);width:100%;object-fit:cover;aspect-ratio:4/5}
.hero__media .float-heart{position:absolute;right:-10px;bottom:34px;width:46px;color:var(--herz);filter:drop-shadow(0 8px 14px rgba(168,47,61,.35))}
.hero h1{margin-bottom:1.25rem}
.hero .cta-row{margin-top:2rem}
@media (max-width:860px){
  .hero__grid{grid-template-columns:1fr;gap:2rem}
  .hero__media{order:-1}
  .hero__media img{aspect-ratio:5/4;max-height:62vh}
}

/* ---------- 8. CTA-Reihe ---------- */
.cta-row{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.cta-note{font-size:.86rem;color:var(--tinte-weich)}

/* ---------- 9. Karten ---------- */
.grid{display:grid;gap:clamp(1rem,2vw,1.6rem)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
@media (max-width:860px){.grid--3{grid-template-columns:1fr}.grid--2{grid-template-columns:1fr}}
.card{
  background:#fff;border:1px solid var(--linie);border-radius:var(--r-m);
  padding:clamp(1.4rem,1rem + 1.5vw,2rem);box-shadow:var(--schatten-karte);
  transition:transform var(--t-ruhig),box-shadow var(--t-ruhig);height:100%;
}
.card:hover{transform:translateY(-4px);box-shadow:0 22px 44px -26px rgba(57,53,47,.5)}
.card h3{margin-bottom:.6rem}
.card p{color:var(--tinte-weich);font-size:.98rem}
.card--soft{background:var(--sage-hell);border-color:transparent}
.card--sand{background:var(--sand);border-color:transparent}
.card__num{font-size:.8rem;font-weight:700;letter-spacing:.12em;color:var(--herz);display:block;margin-bottom:.5rem}

/* Foto-Karte */
.media-card{border-radius:var(--r-m);overflow:hidden;box-shadow:var(--schatten-karte)}
.media-card img{width:100%;height:100%;object-fit:cover}

/* Split (Text + Bild) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,4rem);align-items:center}
.split--flip .split__media{order:-1}
.split__media img{border-radius:var(--r-l);box-shadow:var(--schatten-weich);width:100%;object-fit:cover;aspect-ratio:4/5}
@media (max-width:860px){.split{grid-template-columns:1fr;gap:2rem}.split--flip .split__media{order:0}}

/* ---------- 10. Herz-Divider (Signature) ---------- */
.heart-divider{display:flex;align-items:center;justify-content:center;gap:1rem;padding-block:clamp(2rem,4vw,3.2rem)}
.heart-divider::before,.heart-divider::after{content:"";height:1px;width:min(120px,18vw);background:var(--linie)}
.heart-divider svg{width:26px;flex:none;color:var(--herz)}

/* ---------- 11. Schritt-Liste / Journey ---------- */
.steps{counter-reset:step;display:grid;gap:1.1rem}
.step{display:grid;grid-template-columns:auto 1fr;gap:1.1rem;align-items:start;
  background:#fff;border:1px solid var(--linie);border-radius:var(--r-m);padding:1.2rem 1.4rem}
.step__no{counter-increment:step;width:38px;height:38px;border-radius:50%;background:var(--sage-hell);
  color:var(--sage-tief);font-weight:700;display:grid;place-items:center;font-size:.95rem}
.step__no::before{content:counter(step,decimal-leading-zero)}
.step h4{margin-bottom:.25rem}
.step p{color:var(--tinte-weich);font-size:.96rem;margin:0}

/* ---------- 12. Check-Liste ---------- */
.checks{display:grid;gap:.7rem}
.checks li{display:grid;grid-template-columns:auto 1fr;gap:.75rem;align-items:start}
.checks li svg{width:20px;margin-top:.28em;flex:none;color:var(--herz)}

/* ---------- 13. FAQ ---------- */
.faq{max-width:760px;margin-inline:auto;display:grid;gap:.7rem}
.faq details{background:#fff;border:1px solid var(--linie);border-radius:var(--r-s);overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:1.05rem 1.3rem;font-weight:600;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--sage);line-height:1;transition:transform var(--t-schnell)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details>p{padding:0 1.3rem 1.2rem;color:var(--tinte-weich);max-width:none}

/* ---------- 14. Preis-Box ---------- */
.price{background:#fff;border:1px solid var(--linie);border-radius:var(--r-l);padding:clamp(1.6rem,1rem + 2vw,2.6rem);
  box-shadow:var(--schatten-karte);text-align:center;max-width:520px;margin-inline:auto}
.price__tag{display:flex;align-items:baseline;justify-content:center;gap:.6rem;margin:.4rem 0 .2rem}
.price__old{color:var(--tinte-weich);text-decoration:line-through;font-size:1.3rem}
.price__now{font-size:3rem;font-weight:700;color:var(--herz);letter-spacing:-.02em}
.price__meta{font-size:.86rem;color:var(--tinte-weich)}
.price ul{margin:1.4rem 0;text-align:left}

/* ---------- 15. Formular ---------- */
.form{max-width:480px;display:grid;gap:1rem}
.field{display:grid;gap:.4rem}
.field label{font-size:.9rem;font-weight:600}
.field input,.field textarea{
  width:100%;padding:.85rem 1rem;border:1.5px solid var(--linie);border-radius:var(--r-s);
  background:#fff;transition:border-color var(--t-schnell),box-shadow var(--t-schnell);
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--sage);box-shadow:0 0 0 3px var(--sage-hell)}
.consent{display:grid;grid-template-columns:auto 1fr;gap:.6rem;align-items:start;font-size:.85rem;color:var(--tinte-weich)}
.consent input{margin-top:.25em}

/* ---------- 16. Footer ---------- */
.site-footer{background:var(--tinte);color:#E9E3D8;padding-block:clamp(3rem,2rem + 3vw,4.5rem)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem}
.site-footer .brand__top,.site-footer .brand__bottom{color:#F6F1E8}
/* Herz im dunklen Footer etwas heller, damit es klar rot leuchtet */
.site-footer .brand__bottom svg,.site-footer .heart-inline{color:#E0566A}
.site-footer p{color:#B7AFA1;font-size:.92rem}
.site-footer h4{color:#fff;margin-bottom:1rem;letter-spacing:.04em}
.site-footer ul{display:grid;gap:.55rem;list-style:none;margin:0;padding:0}
.site-footer ul a{display:inline-flex;align-items:center}
.site-footer a{color:#D9D2C5;font-size:.94rem;transition:color var(--t-schnell)}
.site-footer a:hover{color:#fff}
.footer-bottom{margin-top:2.5rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.12);
  display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;font-size:.84rem;color:#9c9488}
.footer-bottom .heart-inline{color:var(--herz)}
@media (max-width:760px){.footer-grid{grid-template-columns:1fr;gap:2rem}}

/* ---------- 17. Breadcrumb / Artikel ---------- */
.crumb{font-size:.85rem;color:var(--tinte-weich);padding-top:1.4rem}
.crumb a:hover{color:var(--sage-tief)}
.article{max-width:720px;margin-inline:auto}
.article p,.article ul,.article ol{margin-bottom:1.1rem}
.article h2{margin:2.4rem 0 .9rem}
.article h3{margin:1.8rem 0 .6rem}
.article ul,.article ol{padding-left:1.3rem;color:var(--tinte-weich)}
.article li{margin-bottom:.5rem}
.article blockquote{border-left:3px solid var(--sage);padding:.4rem 0 .4rem 1.4rem;margin:1.8rem 0}
.article img{border-radius:var(--r-m);margin:1.6rem 0;box-shadow:var(--schatten-karte)}
.post-meta{font-size:.85rem;color:var(--tinte-weich);margin-bottom:1.4rem}
.post-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--linie);border-radius:var(--r-m);overflow:hidden;height:100%;transition:transform var(--t-ruhig),box-shadow var(--t-ruhig)}
.post-card:hover{transform:translateY(-4px);box-shadow:0 22px 44px -26px rgba(57,53,47,.5)}
.post-card img{aspect-ratio:16/10;object-fit:cover}
.post-card__body{padding:1.3rem 1.4rem 1.6rem}
.post-card__cat{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sage-tief);font-weight:600}
.post-card h3{margin:.5rem 0 .5rem;font-size:1.2rem}
.post-card p{color:var(--tinte-weich);font-size:.95rem}

/* ---------- 18. Chips / Pills ---------- */
.chips{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{background:var(--sand);color:var(--tinte);padding:.4rem .9rem;border-radius:var(--r-pill);font-size:.84rem;font-weight:500}

/* ---------- 19. Stat / Vertrauen ---------- */
.trust{display:flex;flex-wrap:wrap;gap:2rem;align-items:center;justify-content:center}
.trust__item{text-align:center}
.trust__item b{display:block;font-size:1.7rem;color:var(--sage-tief);font-weight:700}
.trust__item span{font-size:.85rem;color:var(--tinte-weich)}

/* ---------- 20. Loader (Signature Herzschlag) ---------- */
.loader{position:fixed;inset:0;z-index:200;background:var(--papier);display:grid;place-items:center;
  transition:opacity .5s ease,visibility .5s ease;
  animation:loaderSafetyFade .6s ease 2.6s forwards}
.loader.is-done{opacity:0;visibility:hidden}
.loader svg{width:54px}
/* Sicherheitsnetz: Loader verschwindet auch ohne JavaScript */
@keyframes loaderSafetyFade{to{opacity:0;visibility:hidden}}
.loader svg path{fill:var(--herz);transform-origin:center;animation:loadbeat 1.1s ease-in-out infinite}
@keyframes loadbeat{0%,100%{transform:scale(.86);opacity:.6}30%{transform:scale(1.12);opacity:1}45%{transform:scale(.98)}}

/* ---------- 21. Scroll-Reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}

/* ---------- 22. Deko-Blobs (Sage, sehr dezent) ---------- */
.blob{position:absolute;z-index:0;border-radius:50%;filter:blur(2px);opacity:.5;pointer-events:none}
.blob--1{width:340px;height:300px;background:radial-gradient(circle at 30% 30%,var(--sage-hell),transparent 70%);top:-80px;right:-60px}
.blob--2{width:280px;height:260px;background:radial-gradient(circle at 60% 40%,var(--sand),transparent 70%);bottom:-60px;left:-80px}
.has-blobs{position:relative;overflow:hidden}
.has-blobs>.wrap{position:relative;z-index:1}

/* ---------- 23. Utilities ---------- */
.mt-0{margin-top:0}.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.mb-2{margin-bottom:2rem}
.maxw-text{max-width:var(--maxw-text)}
.skip{position:absolute;left:-9999px;top:0;background:var(--herz);color:#fff;padding:.8rem 1.2rem;border-radius:0 0 10px 0;z-index:300}
.skip:focus{left:0}
.heart-inline{display:inline-block;width:.95em;vertical-align:-.12em;color:var(--herz)}
.heart-inline path{fill:currentColor}
/* Kontakt-Icons (Telefon, Mail, WhatsApp, Instagram) */
.ico{width:16px;height:16px;display:inline-block;vertical-align:-.18em;margin-right:.55em;flex:none}
.site-footer .ico{color:#D9D2C5}

/* ---------- 24. Reduced Motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
  .loader{display:none}
}
