/* ==========================================================================
   Gärtnerei Schanbacher — styles.css
   Design-System nach SPEC §2 · Mobile-first · Breakpoints 600 / 900 / 1200px
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Fonts (lokal, font-display: swap)
   -------------------------------------------------------------------------- */
@font-face{
  font-family:"Playfair Display";
  font-style:normal;
  font-weight:400;
  font-display:swap;
  src:url("fonts/playfair-display-v40-latin-regular.woff2") format("woff2");
}
@font-face{
  font-family:"Playfair Display";
  font-style:italic;
  font-weight:400;
  font-display:swap;
  src:url("fonts/playfair-display-v40-latin-italic.woff2") format("woff2");
}
@font-face{
  font-family:"Playfair Display";
  font-style:normal;
  font-weight:600;
  font-display:swap;
  src:url("fonts/playfair-display-v40-latin-600.woff2") format("woff2");
}
@font-face{
  font-family:"Playfair Display";
  font-style:normal;
  font-weight:700;
  font-display:swap;
  src:url("fonts/playfair-display-v40-latin-700.woff2") format("woff2");
}
@font-face{
  font-family:"Inter";
  font-style:normal;
  font-weight:400;
  font-display:swap;
  src:url("fonts/inter-v20-latin-regular.woff2") format("woff2");
}
@font-face{
  font-family:"Inter";
  font-style:normal;
  font-weight:500;
  font-display:swap;
  src:url("fonts/inter-v20-latin-500.woff2") format("woff2");
}
@font-face{
  font-family:"Inter";
  font-style:normal;
  font-weight:600;
  font-display:swap;
  src:url("fonts/inter-v20-latin-600.woff2") format("woff2");
}
@font-face{
  font-family:"Inter";
  font-style:normal;
  font-weight:700;
  font-display:swap;
  src:url("fonts/inter-v20-latin-700.woff2") format("woff2");
}

/* --------------------------------------------------------------------------
   2. Tokens (SPEC §2 — exakt)
   -------------------------------------------------------------------------- */
:root{
  --bg:#fafaf7; --bg-warm:#f5f3ec; --white:#fff;
  --green-900:#0f3d1f; --green-700:#166534; --green-600:#16a34a; --green-500:#22c55e; --green-100:#dcfce7; --green-50:#f0fdf4;
  --gold-600:#b8894f; --gold-500:#d4a574; --gold-100:#f5e6cf;
  --ink-900:#10231a; --ink-800:#1a2e1f; --ink-700:#2d4536; --ink-500:#5b6e60; --ink-400:#8a9a8f;
  --line:#e6e3d8; --radius:16px; --radius-sm:10px; --container:1200px;
  --shadow-sm:0 1px 2px rgba(16,35,26,.04),0 2px 8px rgba(16,35,26,.04);
  --shadow-md:0 4px 12px rgba(16,35,26,.06),0 12px 32px rgba(16,35,26,.06);
  --shadow-lg:0 8px 24px rgba(16,35,26,.08),0 24px 48px rgba(16,35,26,.08);
  --font-serif:"Playfair Display",Georgia,serif; --font-sans:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;
}

/* --------------------------------------------------------------------------
   3. Reset & Base
   -------------------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--font-sans);
  font-size:1rem;
  line-height:1.65;
  color:var(--ink-800);
  background:var(--bg);
}
img{max-width:100%;height:auto;display:block;}
h1,h2,h3,h4{
  font-family:var(--font-serif);
  color:var(--ink-900);
  line-height:1.18;
  margin:0 0 .6em;
  font-weight:700;
}
h1{font-size:clamp(2.2rem,5vw,4rem);}
h2{font-size:clamp(1.7rem,3.4vw,2.6rem);}
h3{font-size:clamp(1.25rem,2.2vw,1.5rem);font-weight:600;}
h4{font-size:1.1rem;font-weight:600;font-family:var(--font-sans);}
p{margin:0 0 1em;}
a{color:var(--green-700);text-decoration-thickness:1px;text-underline-offset:3px;}
a:hover{color:var(--green-900);}
ul,ol{margin:0 0 1em;padding-left:1.3em;}
strong{font-weight:600;color:var(--ink-900);}
table{border-collapse:collapse;width:100%;}
button{font:inherit;cursor:pointer;}
input,select,textarea{font:inherit;color:inherit;}
::selection{background:var(--gold-100);color:var(--ink-900);}

/* Akzentwort kursiv gold in Überschriften */
.accent{font-style:italic;color:var(--gold-500);font-weight:600;}
.on-light .accent,.section .accent{color:var(--gold-600);}

/* Fokus-Stile */
:focus-visible{
  outline:3px solid var(--green-600);
  outline-offset:2px;
  border-radius:4px;
}
.hero :focus-visible,.site-header :focus-visible,.site-footer :focus-visible,.cta-band :focus-visible{
  outline-color:var(--gold-500);
}

/* Skip-Link */
.skip-link{
  position:absolute;
  left:-9999px;
  top:0;
  z-index:200;
  background:var(--green-900);
  color:#fff;
  padding:.7rem 1.2rem;
  border-radius:0 0 var(--radius-sm) 0;
  font-weight:600;
  text-decoration:none;
}
.skip-link:focus{left:0;color:#fff;}

/* --------------------------------------------------------------------------
   4. Layout-Helfer
   -------------------------------------------------------------------------- */
.container{
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:1.25rem;
}
@media (min-width:600px){.container{padding-inline:2rem;}}

.section{padding-block:3.5rem;}
@media (min-width:900px){.section{padding-block:5.5rem;}}
.section--warm{background:var(--bg-warm);}
.section--white{background:var(--white);}
.section--green{background:linear-gradient(160deg,var(--green-900),var(--ink-900));color:#e8efe9;}
.section--green h2,.section--green h3{color:#fff;}
.section--green p{color:#cfdbd2;}

.section-head{max-width:720px;margin-bottom:2.5rem;}
.section-head--center{margin-inline:auto;text-align:center;}
.section-head .lead{font-size:1.1rem;color:var(--ink-500);}

/* Eyebrow */
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.55em;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--green-700);
  margin:0 0 1rem;
}
.eyebrow::before{
  content:"";
  width:6px;height:6px;
  border-radius:50%;
  background:var(--gold-500);
  flex:none;
}
.eyebrow--gold,.hero .eyebrow,.section--green .eyebrow,.cta-band .eyebrow{color:var(--gold-500);}

/* Zwei-Spalten-Split (Text + Bild) */
.split{display:grid;gap:2.5rem;align-items:center;}
@media (min-width:900px){
  .split{grid-template-columns:1fr 1fr;gap:4rem;}
  .split--reverse > :first-child{order:2;}
}
.split-media img{
  width:100%;
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  aspect-ratio:4/3;
  object-fit:cover;
}

/* Check-Listen */
.check-list{list-style:none;padding:0;margin:0 0 1.5rem;display:grid;gap:.75rem;}
.check-list li{padding-left:1.9em;position:relative;}
.check-list li::before{
  content:"✓";
  position:absolute;left:0;top:0;
  width:1.35em;height:1.35em;
  display:grid;place-items:center;
  background:var(--green-100);
  color:var(--green-700);
  border-radius:50%;
  font-size:.85em;
  font-weight:700;
}
.section--green .check-list li::before,.hero .check-list li::before{background:rgba(212,165,116,.18);color:var(--gold-500);}

/* --------------------------------------------------------------------------
   5. Buttons (pill)
   -------------------------------------------------------------------------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5em;
  min-height:48px;
  padding:.7rem 1.6rem;
  border-radius:999px;
  border:2px solid transparent;
  font-weight:600;
  font-size:1rem;
  text-decoration:none;
  line-height:1.2;
  transition:background .2s ease,color .2s ease,border-color .2s ease,transform .15s ease,box-shadow .2s ease;
}
.btn:hover{transform:translateY(-1px);}
.btn:active{transform:translateY(0);}

.btn--gold{background:var(--gold-500);color:var(--ink-900);}
.btn--gold:hover{background:var(--gold-600);color:var(--ink-900);}
.btn--green{background:var(--green-900);color:#fff;}
.btn--green:hover{background:var(--ink-900);color:#fff;}
.btn--outline{background:transparent;border-color:var(--green-900);color:var(--green-900);}
.btn--outline:hover{background:var(--green-900);color:#fff;}
.btn--outline-light{background:transparent;border-color:rgba(255,255,255,.55);color:#fff;}
.btn--outline-light:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff;}
.btn--lg{padding:.9rem 2.1rem;font-size:1.05rem;}
.btn--sm{min-height:40px;padding:.4rem 1.1rem;font-size:.92rem;}
.btn--block{width:100%;}
.btn[disabled],.btn[aria-disabled="true"]{opacity:.5;pointer-events:none;}
.btn .arrow{transition:transform .2s ease;}
.btn:hover .arrow{transform:translateX(3px);}

.btn-row{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center;}

/* --------------------------------------------------------------------------
   6. Topbar
   -------------------------------------------------------------------------- */
.topbar{
  background:var(--ink-900);
  color:#dbe6dd;
  font-size:.88rem;
  position:relative;
  z-index:60;
}
.topbar.is-hidden{display:none;}
.topbar-inner{
  max-width:var(--container);
  margin-inline:auto;
  padding:.45rem 3rem .45rem 1.25rem;
  text-align:center;
}
.topbar a{color:#fff;font-weight:500;text-decoration:none;}
.topbar a:hover{color:var(--gold-500);}
.topbar a .arrow{color:var(--gold-500);}
.topbar-close{
  position:absolute;
  right:.5rem;top:50%;
  transform:translateY(-50%);
  background:none;border:0;
  color:#9fb3a5;
  font-size:1.15rem;
  line-height:1;
  padding:.4rem .6rem;
  border-radius:50%;
}
.topbar-close:hover{color:#fff;background:rgba(255,255,255,.1);}

/* --------------------------------------------------------------------------
   7. Header / Navigation
   -------------------------------------------------------------------------- */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:var(--green-900);
  box-shadow:0 1px 0 rgba(255,255,255,.06),var(--shadow-sm);
}
.header-inner{
  max-width:var(--container);
  margin-inline:auto;
  padding:.65rem 1.25rem;
  display:flex;
  align-items:center;
  gap:1rem;
}
@media (min-width:600px){.header-inner{padding-inline:2rem;}}

/* Logo */
.logo{
  display:inline-flex;
  align-items:center;
  gap:.7rem;
  text-decoration:none;
  flex:none;
}
.logo-mark{flex:none;}
.logo-text{display:flex;flex-direction:column;line-height:1.15;}
.logo-text .logo-over{
  font-size:.62rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold-500);
  font-weight:600;
}
.logo-text .logo-name{
  font-family:var(--font-serif);
  font-weight:700;
  font-size:1.05rem;
  letter-spacing:.06em;
  color:#fff;
}

/* Hauptnavigation */
.main-nav{margin-left:auto;}
.main-nav ul{
  list-style:none;
  margin:0;padding:0;
  display:flex;
  align-items:center;
  gap:.25rem;
}
.main-nav a{
  display:block;
  padding:.55rem .9rem;
  color:#e2ece4;
  font-weight:500;
  font-size:.97rem;
  text-decoration:none;
  border-radius:999px;
  transition:color .15s ease,background .15s ease;
}
.main-nav a:hover{color:#fff;background:rgba(255,255,255,.08);}
.main-nav a[aria-current="page"]{color:#fff;background:rgba(255,255,255,.12);}

.header-actions{display:flex;align-items:center;gap:.7rem;margin-left:auto;}
@media (min-width:900px){.header-actions{margin-left:0;}}
.header-phone{
  display:inline-flex;
  align-items:center;
  gap:.45em;
  color:#fff;
  font-weight:600;
  font-size:.95rem;
  text-decoration:none;
  padding:.5rem .7rem;
  border-radius:999px;
  white-space:nowrap;
}
.header-phone:hover{color:var(--gold-500);}
.header-phone svg{flex:none;}
.header-cta{display:none;}
@media (min-width:600px){.header-cta{display:inline-flex;min-height:42px;padding:.45rem 1.25rem;font-size:.95rem;}}

/* Hamburger */
.nav-toggle{
  display:inline-flex;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  width:44px;height:44px;
  padding:10px;
  background:none;
  border:0;
  border-radius:var(--radius-sm);
}
.nav-toggle .bar{
  display:block;
  width:100%;height:2px;
  background:#fff;
  border-radius:2px;
  transition:transform .25s ease,opacity .2s ease;
}
.nav-toggle[aria-expanded="true"] .bar:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle[aria-expanded="true"] .bar:nth-child(2){opacity:0;}
.nav-toggle[aria-expanded="true"] .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* Mobile Drawer (<900px) */
@media (max-width:899.98px){
  .main-nav{
    position:fixed;
    inset:0 0 0 auto;
    width:min(320px,85vw);
    background:var(--ink-900);
    padding:5.5rem 1.5rem 2rem;
    transform:translateX(100%);
    transition:transform .3s ease;
    visibility:hidden;
    z-index:55;
    margin-left:0;
    overflow-y:auto;
  }
  .main-nav.is-open{transform:translateX(0);visibility:visible;box-shadow:var(--shadow-lg);}
  .main-nav ul{flex-direction:column;align-items:stretch;gap:.35rem;}
  .main-nav a{font-size:1.1rem;padding:.85rem 1rem;border-radius:var(--radius-sm);}
  .nav-backdrop{
    position:fixed;inset:0;
    background:rgba(16,35,26,.55);
    opacity:0;visibility:hidden;
    transition:opacity .3s ease;
    z-index:54;
    border:0;padding:0;
  }
  .nav-backdrop.is-open{opacity:1;visibility:visible;}
  body.nav-open{overflow:hidden;}
}
@media (min-width:900px){
  .nav-toggle,.nav-backdrop{display:none;}
}

/* --------------------------------------------------------------------------
   8. Hero
   -------------------------------------------------------------------------- */
.hero{
  position:relative;
  background:linear-gradient(160deg,var(--green-900) 0%,var(--ink-900) 100%);
  color:#e8efe9;
  overflow:hidden;
}
.hero-bg{
  position:absolute;
  inset:0;
}
.hero-bg img{
  width:100%;height:100%;
  object-fit:cover;
}
.hero-bg::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(110deg,rgba(15,61,31,.92) 0%,rgba(16,35,26,.78) 55%,rgba(16,35,26,.55) 100%);
}
.hero-inner{
  position:relative;
  z-index:1;
  max-width:var(--container);
  margin-inline:auto;
  padding:4.5rem 1.25rem 5rem;
}
@media (min-width:600px){.hero-inner{padding-inline:2rem;}}
@media (min-width:900px){.hero-inner{padding-block:7rem 7.5rem;}}
.hero-content{max-width:680px;}
.hero h1{color:#fff;margin-bottom:.5em;}
.hero .sub{
  font-size:clamp(1.05rem,1.6vw,1.25rem);
  color:#cfdbd2;
  max-width:560px;
  margin-bottom:2rem;
}
.hero .btn-row{margin-top:.5rem;}

/* Hero mit zweispaltigem Layout (Bild als Karte rechts) */
@media (min-width:900px){
  .hero--split .hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:4rem;align-items:center;}
}
.hero--split .hero-media img{
  width:100%;
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  aspect-ratio:4/3;
  object-fit:cover;
}
.hero--split .hero-media{display:none;}
@media (min-width:900px){.hero--split .hero-media{display:block;position:relative;z-index:1;}}

/* Kompakter Hero (Unterseiten / Ratgeber) */
.hero--compact .hero-inner{padding-block:3.5rem 4rem;}
@media (min-width:900px){.hero--compact .hero-inner{padding-block:5rem;}}

/* Breadcrumb (Ratgeber) */
.breadcrumb{
  font-size:.88rem;
  margin-bottom:1.25rem;
  color:#9fb3a5;
}
.breadcrumb ol{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.4em;}
.breadcrumb li+li::before{content:"›";margin-right:.4em;color:var(--gold-500);}
.breadcrumb a{color:#cfdbd2;text-decoration:none;}
.breadcrumb a:hover{color:#fff;text-decoration:underline;}
.breadcrumb [aria-current="page"]{color:#fff;}

/* --------------------------------------------------------------------------
   9. Trust-Leiste
   -------------------------------------------------------------------------- */
.trust-bar{
  background:var(--white);
  border-bottom:1px solid var(--line);
}
.trust-bar-inner{
  max-width:var(--container);
  margin-inline:auto;
  padding:1.1rem 1.25rem;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.9rem 1.5rem;
}
@media (min-width:600px){.trust-bar-inner{padding-inline:2rem;}}
@media (min-width:900px){.trust-bar-inner{grid-template-columns:repeat(4,auto);justify-content:space-between;}}
.trust-item{
  display:flex;
  align-items:center;
  gap:.6em;
  font-size:.92rem;
  font-weight:500;
  color:var(--ink-700);
}
.trust-item svg,.trust-item .dot{flex:none;color:var(--gold-600);}
.trust-item .dot{width:8px;height:8px;border-radius:50%;background:var(--gold-500);display:inline-block;}

/* --------------------------------------------------------------------------
   10. Cards
   -------------------------------------------------------------------------- */
.cards-grid{
  display:grid;
  gap:1.5rem;
}
@media (min-width:600px){.cards-grid{grid-template-columns:repeat(2,1fr);}}
@media (min-width:900px){
  .cards-grid{grid-template-columns:repeat(3,1fr);gap:2rem;}
  .cards-grid--2{grid-template-columns:repeat(2,1fr);}
  .cards-grid--4{grid-template-columns:repeat(4,1fr);gap:1.5rem;}
}

.card{
  background:var(--white);
  border-radius:var(--radius);
  box-shadow:var(--shadow-md);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .25s ease,box-shadow .25s ease;
}
a.card{text-decoration:none;color:inherit;}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.card-media img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
}
.card-body{padding:1.5rem;display:flex;flex-direction:column;flex:1;gap:.25rem;}
.card-body h3{margin-bottom:.35em;}
.card-body p{color:var(--ink-500);font-size:.97rem;margin-bottom:.75em;}
.card-link{
  margin-top:auto;
  font-weight:600;
  color:var(--green-700);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:.4em;
}
.card:hover .card-link{color:var(--green-900);}
.card:hover .card-link .arrow{transform:translateX(3px);}
.card-link .arrow{transition:transform .2s ease;}

/* Galerie-Kachel (Pflanzenwelt) */
.tile{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-md);
  display:block;
  text-decoration:none;
  transition:transform .25s ease,box-shadow .25s ease;
}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.tile img{width:100%;aspect-ratio:4/3;object-fit:cover;}
.tile-label{
  position:absolute;
  inset:auto 0 0 0;
  padding:2.2rem 1.2rem .9rem;
  background:linear-gradient(transparent,rgba(16,35,26,.85));
  color:#fff;
  font-weight:600;
  font-size:1.05rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.5em;
}
.tile-label .arrow{color:var(--gold-500);}

/* Schritt-Karten (So einfach geht's / Ablauf) */
.steps-grid{display:grid;gap:1.5rem;counter-reset:step;}
@media (min-width:600px){.steps-grid{grid-template-columns:repeat(2,1fr);}}
@media (min-width:900px){.steps-grid{grid-template-columns:repeat(4,1fr);}}
.step{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.5rem;
  position:relative;
}
.step-num{
  display:grid;place-items:center;
  width:42px;height:42px;
  border-radius:50%;
  background:var(--green-50);
  color:var(--green-700);
  font-family:var(--font-serif);
  font-size:1.25rem;
  font-weight:700;
  margin-bottom:1rem;
}
.step h3{font-size:1.1rem;font-family:var(--font-sans);font-weight:600;}
.step p{color:var(--ink-500);font-size:.95rem;margin:0;}

/* Icon-Benefit (3 Gründe) */
.benefit{
  background:var(--white);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  padding:1.75rem;
}
.benefit-icon{
  width:52px;height:52px;
  display:grid;place-items:center;
  border-radius:14px;
  background:var(--green-50);
  color:var(--green-700);
  margin-bottom:1.1rem;
  font-size:1.4rem;
}
.benefit h3{font-size:1.15rem;font-family:var(--font-sans);font-weight:600;}
.benefit p{color:var(--ink-500);font-size:.96rem;margin:0;}

/* --------------------------------------------------------------------------
   11. Preistabellen & Preiskarten
   -------------------------------------------------------------------------- */
.price-table-wrap{
  background:var(--white);
  border-radius:var(--radius);
  box-shadow:var(--shadow-md);
  overflow-x:auto;
}
.price-table{min-width:480px;}
.price-table caption{
  text-align:left;
  padding:1.25rem 1.5rem .25rem;
  font-family:var(--font-serif);
  font-size:1.25rem;
  font-weight:600;
  color:var(--ink-900);
}
.price-table th,.price-table td{
  padding:.85rem 1.5rem;
  text-align:left;
  border-bottom:1px solid var(--line);
  font-size:.97rem;
}
.price-table thead th{
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--ink-500);
  font-weight:600;
  border-bottom:2px solid var(--line);
}
.price-table tbody tr:last-child th,.price-table tbody tr:last-child td{border-bottom:0;}
.price-table tbody tr:hover{background:var(--green-50);}
.price-table .price{font-weight:700;color:var(--green-900);white-space:nowrap;}
.price-table tbody th{font-weight:600;color:var(--ink-900);}

.price-note{
  font-size:.88rem;
  color:var(--ink-500);
  margin-top:.9rem;
}

/* Paket-/Richtpreis-Karten */
.price-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.75rem;
  display:flex;
  flex-direction:column;
  gap:.4rem;
  position:relative;
  transition:transform .25s ease,box-shadow .25s ease;
}
.price-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.price-card--featured{border:2px solid var(--gold-500);box-shadow:var(--shadow-md);}
.price-card .plan{font-weight:600;font-size:1.05rem;color:var(--ink-900);}
.price-card .amount{
  font-family:var(--font-serif);
  font-size:2.1rem;
  font-weight:700;
  color:var(--green-900);
  line-height:1.1;
}
.price-card .amount small{font-family:var(--font-sans);font-size:.95rem;font-weight:500;color:var(--ink-500);}
.price-card ul{list-style:none;padding:0;margin:.5rem 0 0;display:grid;gap:.45rem;font-size:.93rem;color:var(--ink-700);}
.price-card ul li{padding-left:1.5em;position:relative;}
.price-card ul li::before{content:"✓";position:absolute;left:0;color:var(--green-600);font-weight:700;}
.price-card .btn{margin-top:1rem;}

/* Badge */
.badge{
  display:inline-block;
  padding:.25em .85em;
  border-radius:999px;
  font-size:.74rem;
  font-weight:600;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.badge--gold{background:var(--gold-100);color:var(--gold-600);}
.badge--green{background:var(--green-100);color:var(--green-700);}
.price-card .badge{position:absolute;top:-0.8em;left:1.5rem;}

/* Hinweis-/Info-Boxen */
.note-box{
  background:var(--green-50);
  border:1px solid var(--green-100);
  border-radius:var(--radius-sm);
  padding:1.1rem 1.4rem;
  font-size:.95rem;
  color:var(--ink-700);
}
.note-box--gold{background:var(--gold-100);border-color:#ecd9bb;}
.note-box strong{color:var(--ink-900);}

/* --------------------------------------------------------------------------
   12. FAQ (natives <details>)
   -------------------------------------------------------------------------- */
.faq-list{max-width:780px;margin-inline:auto;display:grid;gap:.9rem;}
.faq-item{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  overflow:hidden;
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:1.1rem 3.2rem 1.1rem 1.4rem;
  font-weight:600;
  color:var(--ink-900);
  position:relative;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{
  content:"+";
  position:absolute;
  right:1.3rem;top:50%;
  transform:translateY(-50%);
  width:28px;height:28px;
  display:grid;place-items:center;
  border-radius:50%;
  background:var(--green-50);
  color:var(--green-700);
  font-size:1.2rem;
  font-weight:500;
  transition:transform .25s ease,background .2s ease;
}
.faq-item[open] summary::after{transform:translateY(-50%) rotate(45deg);background:var(--green-100);}
.faq-item summary:hover{background:var(--bg);}
.faq-body{padding:0 1.4rem 1.25rem;color:var(--ink-700);font-size:.97rem;}
.faq-body p:last-child{margin-bottom:0;}

/* --------------------------------------------------------------------------
   13. CTA-Band (dunkelgrün, Seitenabschluss)
   -------------------------------------------------------------------------- */
.cta-band{
  background:linear-gradient(160deg,var(--green-900),var(--ink-900));
  color:#e8efe9;
  text-align:center;
}
.cta-band .cta-inner{
  max-width:760px;
  margin-inline:auto;
  padding:4rem 1.25rem;
}
@media (min-width:900px){.cta-band .cta-inner{padding-block:5.5rem;}}
.cta-band h2{color:#fff;}
.cta-band p{color:#cfdbd2;font-size:1.08rem;}
.cta-band .btn-row{justify-content:center;margin-top:1.75rem;}

/* --------------------------------------------------------------------------
   14. Rechner-Komponenten
   -------------------------------------------------------------------------- */
.rechner{scroll-margin-top:90px;}
.rechner-layout{display:grid;gap:2rem;align-items:start;}
@media (min-width:900px){.rechner-layout{grid-template-columns:1.15fr .85fr;gap:2.5rem;}}

.rechner-step{
  background:var(--white);
  border-radius:var(--radius);
  box-shadow:var(--shadow-md);
  padding:1.5rem;
  margin-bottom:1.5rem;
}
@media (min-width:600px){.rechner-step{padding:2rem;}}
.rechner-step-head{
  display:flex;
  align-items:center;
  gap:.9rem;
  margin-bottom:1.25rem;
}
.rechner-step-head .step-num{margin-bottom:0;width:38px;height:38px;font-size:1.1rem;flex:none;}
.rechner-step-head h3{margin:0;font-family:var(--font-sans);font-weight:600;font-size:1.2rem;}

/* Pflanzen-Zeile mit Stepper */
.plant-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.9rem 0;
  border-bottom:1px solid var(--line);
}
.plant-row:last-of-type{border-bottom:0;}
.plant-info .plant-name{font-weight:600;color:var(--ink-900);}
.plant-info .plant-size{font-size:.86rem;color:var(--ink-500);display:block;}
.plant-info .plant-price{font-size:.86rem;color:var(--green-700);font-weight:600;display:block;}

/* Stepper (−/+) */
.stepper{
  display:inline-flex;
  align-items:center;
  gap:0;
  border:1px solid var(--line);
  border-radius:999px;
  background:var(--bg);
  flex:none;
}
.stepper button{
  width:44px;height:44px;
  border:0;
  background:none;
  border-radius:50%;
  font-size:1.3rem;
  font-weight:600;
  color:var(--green-700);
  display:grid;place-items:center;
  transition:background .15s ease;
}
.stepper button:hover{background:var(--green-100);}
.stepper button:disabled{color:var(--ink-400);opacity:.5;cursor:not-allowed;background:none;}
.stepper output,.stepper .stepper-value{
  min-width:2.2em;
  text-align:center;
  font-weight:700;
  font-size:1.05rem;
  color:var(--ink-900);
  font-variant-numeric:tabular-nums;
}

/* Radio-Cards (Transport) */
.radio-cards{display:grid;gap:.8rem;}
.radio-card{
  position:relative;
  display:block;
  cursor:pointer;
}
.radio-card input{
  position:absolute;
  opacity:0;
  inset:0;
  cursor:pointer;
}
.radio-card-body{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  border:2px solid var(--line);
  border-radius:var(--radius-sm);
  padding:1rem 1.2rem;
  background:var(--white);
  transition:border-color .15s ease,background .15s ease,box-shadow .15s ease;
}
.radio-card:hover .radio-card-body{border-color:var(--ink-400);}
.radio-card input:checked + .radio-card-body{
  border-color:var(--green-700);
  background:var(--green-50);
  box-shadow:var(--shadow-sm);
}
.radio-card input:focus-visible + .radio-card-body{outline:3px solid var(--green-600);outline-offset:2px;}
.radio-card .rc-label{font-weight:600;color:var(--ink-900);}
.radio-card .rc-sub{display:block;font-size:.85rem;color:var(--ink-500);font-weight:400;}
.radio-card .rc-price{font-weight:700;color:var(--green-900);white-space:nowrap;font-variant-numeric:tabular-nums;}
.radio-card .badge{margin-left:.5em;vertical-align:middle;}

/* Extra-Zeilen (Checkboxen/Stepper in Schritt 3) */
.extra-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.85rem 0;
  border-bottom:1px solid var(--line);
}
.extra-row:last-of-type{border-bottom:0;}
.extra-row label{display:flex;align-items:flex-start;gap:.7em;cursor:pointer;}
.extra-row input[type="checkbox"]{
  width:22px;height:22px;
  accent-color:var(--green-700);
  margin-top:.15em;
  flex:none;
}

/* Buchungsübersicht (Summary-Panel) */
.summary-panel{
  background:var(--white);
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  border-top:4px solid var(--gold-500);
  padding:1.5rem;
}
@media (min-width:600px){.summary-panel{padding:2rem;}}
@media (min-width:900px){
  .summary-panel{position:sticky;top:90px;}
}
.summary-panel h3{font-family:var(--font-sans);font-weight:600;font-size:1.2rem;margin-bottom:1rem;}
.summary-list{list-style:none;margin:0 0 1rem;padding:0;display:grid;gap:.55rem;}
.summary-list li{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  font-size:.95rem;
  color:var(--ink-700);
}
.summary-list li .pos-price{font-weight:600;color:var(--ink-900);white-space:nowrap;font-variant-numeric:tabular-nums;}
.summary-list li.is-hint{color:var(--ink-500);font-size:.88rem;}
.summary-empty{color:var(--ink-500);font-size:.95rem;font-style:italic;}
.summary-total{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:1rem;
  border-top:2px solid var(--line);
  padding-top:1rem;
  margin-top:.5rem;
}
.summary-total .label{font-weight:600;color:var(--ink-900);}
.summary-total .sum{
  font-family:var(--font-serif);
  font-size:2rem;
  font-weight:700;
  color:var(--green-900);
  font-variant-numeric:tabular-nums;
}
.summary-meta{font-size:.84rem;color:var(--ink-500);margin:.4rem 0 1.25rem;}

/* Spar-Tipp-Box im Rechner */
.tip-box{
  background:var(--gold-100);
  border:1px solid #ecd9bb;
  border-radius:var(--radius-sm);
  padding:1rem 1.2rem;
  font-size:.92rem;
  color:var(--ink-800);
  margin-bottom:1.25rem;
}
.tip-box strong{color:var(--gold-600);}

/* Abschluss-Formular im Summary-Panel */
.summary-form{display:grid;gap:.9rem;margin-top:1.25rem;}
.summary-actions{display:grid;gap:.7rem;margin-top:.25rem;}
.summary-call{font-size:.9rem;color:var(--ink-500);text-align:center;margin:0;}
.summary-call a{font-weight:600;white-space:nowrap;}
.summary-confirm{
  background:var(--green-50);
  border:1px solid var(--green-100);
  border-radius:var(--radius-sm);
  padding:.9rem 1.1rem;
  font-size:.92rem;
  color:var(--green-700);
  font-weight:500;
}

/* Mobile Bottom-Bar (<900px) */
.rechner-bottombar{
  position:fixed;
  inset:auto 0 0 0;
  z-index:45;
  background:var(--ink-900);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.8rem 1.25rem calc(.8rem + env(safe-area-inset-bottom));
  box-shadow:0 -4px 16px rgba(16,35,26,.25);
  transform:translateY(110%);
  transition:transform .3s ease;
}
.rechner-bottombar.is-visible{transform:translateY(0);}
@media (min-width:900px){.rechner-bottombar{display:none;}}
.rechner-bottombar .bb-label{font-size:.78rem;color:#9fb3a5;display:block;}
.rechner-bottombar .bb-sum{
  font-family:var(--font-serif);
  font-size:1.4rem;
  font-weight:700;
  color:var(--gold-500);
  font-variant-numeric:tabular-nums;
}
.rechner-bottombar .btn{min-height:44px;padding:.5rem 1.3rem;font-size:.95rem;}

/* --------------------------------------------------------------------------
   15. Formulare
   -------------------------------------------------------------------------- */
.form-grid{display:grid;gap:1.1rem;}
@media (min-width:600px){
  .form-grid--2{grid-template-columns:1fr 1fr;}
  .form-grid--2 .form-field--full{grid-column:1/-1;}
}
.form-field{display:grid;gap:.35rem;}
.form-field label{font-weight:600;font-size:.92rem;color:var(--ink-900);}
.form-field .req{color:var(--gold-600);}
.form-field input,.form-field select,.form-field textarea{
  width:100%;
  min-height:48px;
  padding:.65rem .9rem;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  background:var(--white);
  color:var(--ink-900);
  transition:border-color .15s ease,box-shadow .15s ease;
}
.form-field textarea{min-height:120px;resize:vertical;}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;
  border-color:var(--green-700);
  box-shadow:0 0 0 3px var(--green-100);
}
.form-field select{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%235b6e60' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right .9rem center;
  padding-right:2.5rem;
}
.form-check{display:flex;align-items:flex-start;gap:.7em;font-size:.92rem;color:var(--ink-700);}
.form-check input{width:22px;height:22px;accent-color:var(--green-700);flex:none;margin-top:.1em;}
.form-hint{font-size:.85rem;color:var(--ink-500);margin:0;}

/* Kontakt-Infokarten */
.contact-card{
  background:var(--white);
  border-radius:var(--radius);
  box-shadow:var(--shadow-md);
  padding:1.75rem;
}
.contact-card + .contact-card{margin-top:1.5rem;}
.contact-list{list-style:none;margin:0;padding:0;display:grid;gap:1rem;}
.contact-list li{display:flex;gap:.85em;align-items:flex-start;}
.contact-list .ico{
  flex:none;
  width:40px;height:40px;
  display:grid;place-items:center;
  border-radius:12px;
  background:var(--green-50);
  color:var(--green-700);
}
.contact-list a{font-weight:600;}
.contact-list .sub{display:block;font-size:.88rem;color:var(--ink-500);}

/* --------------------------------------------------------------------------
   16. Footer (4 Spalten)
   -------------------------------------------------------------------------- */
.site-footer{
  background:var(--ink-900);
  color:#aebfb3;
  font-size:.95rem;
}
.footer-grid{
  max-width:var(--container);
  margin-inline:auto;
  padding:3.5rem 1.25rem 2.5rem;
  display:grid;
  gap:2.5rem;
}
@media (min-width:600px){.footer-grid{grid-template-columns:repeat(2,1fr);padding-inline:2rem;}}
@media (min-width:900px){.footer-grid{grid-template-columns:1.3fr 1fr 1fr 1fr;gap:3rem;}}
.footer-col .footer-heading{
  color:#fff;
  font-family:var(--font-sans);
  font-size:.82rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.12em;
  margin:0 0 1.1rem;
}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem;}
.footer-col a{color:#aebfb3;text-decoration:none;}
.footer-col a:hover{color:#fff;text-decoration:underline;}
.footer-about p{margin:1rem 0 0;font-size:.92rem;line-height:1.6;}
.footer-eg{
  margin-top:1rem;
  font-size:.85rem;
  color:#8aa090;
  display:flex;
  gap:.6em;
  align-items:flex-start;
}
.footer-eg::before{content:"✓";color:var(--gold-500);font-weight:700;}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
}
.footer-bottom-inner{
  max-width:var(--container);
  margin-inline:auto;
  padding:1.25rem;
  font-size:.85rem;
  color:#8aa090;
  display:flex;
  flex-wrap:wrap;
  gap:.5rem 2rem;
  justify-content:space-between;
}
@media (min-width:600px){.footer-bottom-inner{padding-inline:2rem;}}

/* --------------------------------------------------------------------------
   17. Reveal-Animationen
   -------------------------------------------------------------------------- */
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .6s ease,transform .6s ease;
}
.reveal.is-visible{opacity:1;transform:none;}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.2s;}
.reveal-delay-3{transition-delay:.3s;}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    transition-delay:0s !important;
  }
  .reveal{opacity:1;transform:none;}
}

/* --------------------------------------------------------------------------
   18. Print
   -------------------------------------------------------------------------- */
@media print{
  .topbar,.site-header,.nav-backdrop,.rechner-bottombar,.cta-band,.skip-link{display:none !important;}
  body{background:#fff;color:#000;}
  .hero{background:#fff;color:#000;}
  .hero-bg{display:none;}
  .hero h1,.hero .sub{color:#000;}
  .section--green{background:#fff;color:#000;}
  .section--green h2,.section--green h3,.section--green p{color:#000;}
  .card,.price-card,.summary-panel,.rechner-step,.contact-card,.price-table-wrap{box-shadow:none;border:1px solid #ccc;}
  .btn{border:1px solid #000;background:none;color:#000;}
  a{color:#000;}
  .site-footer{background:#fff;color:#000;}
  .footer-col a,.footer-col .footer-heading,.footer-bottom-inner{color:#000;}
  .reveal{opacity:1;transform:none;}
}

/* --------------------------------------------------------------------------
   19. Rechtsseiten (Impressum / Datenschutz)
   -------------------------------------------------------------------------- */
.legal{max-width:760px;}
.legal h2{font-size:1.45rem;margin-top:2.75rem;}
.legal h2:first-child{margin-top:0;}
.legal h3{font-size:1.08rem;margin-top:1.75rem;}
.legal p,.legal li{color:var(--ink-700);}
.legal ul{margin-bottom:1.25rem;}
.legal address{font-style:normal;color:var(--ink-700);line-height:1.7;margin:0 0 1em;}
.legal .legal-updated{color:var(--ink-500);font-size:.9rem;margin-top:2.5rem;margin-bottom:0;}
