/* ==========================================================================
   Maria Lindner – Freie Rednerin
   Design-Tokens
   ========================================================================== */
/* Google Fonts werden asynchron im <head> jeder Seite geladen (siehe HTML),
   nicht mehr per @import, da das Render-Blocking verursacht hätte. */

:root{
  --cream: #FBF6EF;
  --sand: #F1E6D7;
  --sand-deep: #E6D5BE;
  --ink: #2E2A24;
  --ink-soft: #5C5245;
  --clay: #B3654A;
  --clay-dark: #8F4E38;
  --clay-deep: #723D2B;
  --sage: #5D6650;
  --sage-soft: #A9AF95;
  --line: #E2D3BE;
  --white: #FFFFFF;

  --font-display: "Fraunces", "Iowan Old Style", serif;
  --font-body: "Work Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --container: 1180px;
  --radius-arch: 220px 220px 16px 16px;
  --radius-soft: 22px;
}

*, *::before, *::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration: none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{
  font-family: var(--font-display);
  font-weight: 500;
  line-height: 1.15;
  margin: 0 0 .5em;
  color: var(--ink);
}
h1{ font-size: clamp(2.4rem, 4.4vw, 4rem); font-weight: 400; }
h2{ font-size: clamp(1.9rem, 3vw, 2.6rem); }
h3{ font-size: clamp(1.3rem, 1.8vw, 1.6rem); font-weight: 500; }
p{ margin: 0 0 1.1em; }
.container{ max-width: var(--container); margin: 0 auto; padding: 0 28px; }

.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  color: var(--clay-dark); font-size: 1.05rem; margin-bottom: .6em;
}
.eyebrow::before{
  content:""; width: 26px; height: 1px; background: var(--clay);
  display:inline-block;
}

.lede{ color: var(--ink-soft); font-size: 1.1rem; max-width: 620px; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family: var(--font-body); font-weight: 500; font-size: .95rem;
  letter-spacing:.02em;
  padding: 15px 30px;
  border-radius: 999px;
  border: 1px solid var(--clay-dark);
  background: var(--clay-dark);
  color: var(--white);
  transition: all .25s ease;
  cursor:pointer;
}
.btn:hover{ background: var(--clay-deep); border-color: var(--clay-deep); transform: translateY(-1px); }
.btn.btn-outline{
  background: transparent; color: var(--ink); border-color: var(--ink-soft);
}
.btn.btn-outline:hover{ background: var(--ink); color:var(--white); border-color: var(--ink); }
.btn.btn-light{ background: var(--white); color: var(--clay-dark); border-color: var(--white); }
.btn.btn-light:hover{ background: var(--sand); }

/* ==========================================================================
   Header
   ========================================================================== */
.site-header{
  position: sticky; top:0; z-index: 100;
  background: rgba(251,246,239,.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: 16px 28px;
  max-width: var(--container); margin:0 auto;
  gap: 24px;
}
.logo img{ height: 52px; width:auto; }
.main-nav{ display:flex; align-items:center; gap: 34px; }
.main-nav > ul{ display:flex; gap: 30px; align-items:center; }
.main-nav a{
  font-size: .97rem; font-weight: 500; color: var(--ink);
  position: relative; padding: 4px 0;
}
.main-nav a:hover{ color: var(--clay); }
.has-sub{ position: relative; }
.has-sub > a::after{ content:"⌄"; margin-left:5px; font-size:.8em; color: var(--ink-soft); }
.sub-nav{
  position:absolute; top: 100%; left: -18px; padding-top: 14px;
  min-width: 210px; opacity:0; visibility:hidden; transform: translateY(6px);
  transition: all .2s ease;
}
.has-sub:hover .sub-nav{ opacity:1; visibility:visible; transform: translateY(0); }
.sub-nav ul{
  background: var(--white); border:1px solid var(--line); border-radius: var(--radius-soft);
  padding: 10px; display:flex; flex-direction:column; gap:2px;
  box-shadow: 0 18px 40px rgba(46,42,36,.08);
}
.sub-nav a{ display:block; padding: 9px 14px; border-radius: 12px; font-weight:400; }
.sub-nav a:hover{ background: var(--sand); }
.header-actions{ display:flex; align-items:center; gap:16px; }
.header-cta{
  font-family: var(--font-display); font-style: italic; font-size: 1.05rem;
  padding: 11px 26px; border-radius: 999px; background: var(--ink); color: var(--white);
  white-space: nowrap; display: inline-flex; align-items:center; line-height: 1;
}
.header-cta:hover{ background: var(--clay-dark); color: var(--white); }
.menu-toggle{ display:none; background:none; border:none; cursor:pointer; padding:6px; }
.menu-toggle span{ display:block; width:26px; height:2px; background:var(--ink); margin:6px 0; transition:.25s; }
.menu-toggle.open span:nth-child(1){ transform: translateY(8px) rotate(45deg); }
.menu-toggle.open span:nth-child(2){ opacity:0; }
.menu-toggle.open span:nth-child(3){ transform: translateY(-8px) rotate(-45deg); }

/* ==========================================================================
   Hero
   ========================================================================== */
.hero{
  padding: 76px 0 60px;
}
.hero-grid{
  display:grid; grid-template-columns: 1.1fr .9fr; column-gap: 60px; row-gap:0; align-items:center;
  grid-template-areas: "top image" "bottom image";
}
.hero-text-top{ grid-area: top; }
.hero-text-bottom{ grid-area: bottom; }
.hero h1{ margin-bottom: .3em; }
.hero h1 em{ font-style: italic; color: var(--clay); }
.hero-sub{ font-family: var(--font-display); font-style: italic; font-size: 1.35rem; color: var(--ink-soft); margin-bottom: .9em; font-weight:400; }
.hero-image{
  grid-area: image;
  border-radius: var(--radius-arch);
  overflow:hidden;
  aspect-ratio: 3/4;
  background: var(--sand);
}
.hero-image img{ width:100%; height:100%; object-fit:cover; }

/* ==========================================================================
   Sections
   ========================================================================== */
section{ padding: 80px 0; }
.section-sand{ background: var(--sand); }
.section-head{ max-width: 680px; margin-bottom: 46px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }

/* Services grid (home) */
.services-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 28px;
}
.service-card{
  position: relative; border-radius: var(--radius-soft); overflow:hidden;
  aspect-ratio: 3/4.4; background: var(--ink);
  display:block; cursor:pointer;
}
.service-card img{ width:100%; height:100%; object-fit:cover; opacity:.88; transition: transform .5s ease, opacity .3s; }
.service-card:hover img{ transform: scale(1.05); opacity: 1; }
.service-card-overlay{
  position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end;
  padding: 30px; background: linear-gradient(180deg, rgba(46,42,36,0) 40%, rgba(30,26,20,.82) 100%);
}
.service-card-overlay h3{ color:var(--white); margin-bottom:.3em; }
.service-card-overlay .card-link{ color: var(--sand); font-size:.9rem; font-weight:500; display:inline-flex; align-items:center; gap:6px; }
.service-card:hover .card-link{ color: var(--white); }

.hero-location{
  font-family: var(--font-body); font-size: .95rem; color: var(--ink-soft);
  font-style: normal; margin-bottom: .9em; text-transform: uppercase; letter-spacing:.06em;
}

/* Split rows (about, angebote detail) */
.split{
  display:grid; grid-template-columns: .85fr 1.15fr; gap: 64px; align-items:center;
}
.split.reverse{ grid-template-columns: 1.15fr .85fr; }
.split.reverse .split-img{ order:2; }
.split-img{ border-radius: var(--radius-arch); overflow:hidden; }
.split-img img{ width:100%; }

/* Fact list (Über mich) */
.facts{ display:grid; grid-template-columns: repeat(2,1fr); gap: 34px 48px; margin-top: 10px; }
.fact dt{ font-family: var(--font-display); font-style:italic; color:var(--clay); font-size:1.15rem; margin-bottom:.25em; }
.fact dd{ margin:0; color: var(--ink-soft); }

/* Quote / typical-list */
.bullet-list li{
  position:relative; padding-left: 26px; margin-bottom: 14px; color: var(--ink-soft);
}
.bullet-list li::before{
  content:""; position:absolute; left:0; top:.55em; width:8px; height:8px;
  border-radius:50%; background: var(--clay);
}

.pull-quote{
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  font-size: clamp(1.5rem, 2.6vw, 2.1rem); text-align:center;
  max-width: 820px; margin: 0 auto; line-height:1.4; color: var(--ink);
}

/* Reviews / testimonials */
.review-grid{ display:grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.review-grid-3{ grid-template-columns: repeat(3,1fr); }
.review-card{
  background: var(--white); border:1px solid var(--line); border-radius: var(--radius-soft);
  padding: 28px 24px; display:flex; flex-direction:column; gap:16px; height:100%;
}
.review-card p{ font-size:.94rem; color: var(--ink-soft); margin:0; flex:1; }
.review-who{ display:flex; align-items:center; gap: 12px; margin-top:auto; }
.review-who img{ width:44px; height:44px; border-radius:50%; object-fit:cover; }
.review-who span{ font-weight:500; font-size:.92rem; }
.review-long p{ font-size:1rem; }

/* FAQ */
.faq{ max-width: 820px; margin: 0 auto; }
.faq-item{ border-bottom: 1px solid var(--line); }
.faq-item summary{
  cursor:pointer; list-style:none; padding: 22px 0; display:flex; justify-content:space-between; gap:20px;
  font-family: var(--font-display); font-size:1.15rem; font-weight:500;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:"+"; font-size:1.4rem; color: var(--clay); flex-shrink:0; transition: transform .2s; }
.faq-item[open] summary::after{ transform: rotate(45deg); }
.faq-item .faq-body{ padding: 0 0 24px; color: var(--ink-soft); }
.faq-item .faq-body ul{ margin-top: 10px; }
.faq-item .faq-body li{ position:relative; padding-left:20px; margin-bottom:8px; }
.faq-item .faq-body li::before{ content:"–"; position:absolute; left:0; color: var(--clay); }

/* Icon logo divider */
.icon-divider{ text-align:center; margin: 12px 0 0; }
.icon-divider img{ height: 46px; margin: 0 auto; opacity:.8; }

/* Audio */
.audio-block{
  background: var(--white); border:1px solid var(--line); border-radius: var(--radius-soft);
  padding: 30px; text-align:center;
}
.audio-block audio{ width:100%; margin-top: 14px; }

/* CTA banner */
.cta-banner{
  border-radius: 32px; overflow:hidden; position:relative;
  display:grid; grid-template-columns: 1fr 1fr; align-items:stretch;
  background: var(--ink);
}
.cta-banner-text{ padding: 60px; color: var(--sand); display:flex; flex-direction:column; justify-content:center; }
.cta-banner-text h2{ color: var(--white); }
.cta-banner-text p{ color: var(--sage-soft); }
.cta-banner-img{ min-height: 320px; }
.cta-banner-img img{ width:100%; height:100%; object-fit:cover; }

/* Gallery grid (Abschiedsfeier) */
.mini-gallery{ display:grid; grid-template-columns: repeat(4,1fr); gap:18px; }
.mini-gallery img{ border-radius: 16px; aspect-ratio: 3/2; object-fit:cover; }

/* Reasons list numbered (Zeit für euch "das ist für euch, wenn") */
.check-list{ display:grid; grid-template-columns: repeat(2,1fr); gap: 14px 32px; }
.check-list li{ position:relative; padding-left:28px; color: var(--ink-soft); }
.check-list li::before{ content:"✓"; position:absolute; left:0; color: var(--sage); font-weight:600; }

/* Pricing note */
.price-tag{
  display:inline-flex; align-items:baseline; gap:10px; background: var(--sand);
  padding: 16px 24px; border-radius: 16px; margin: 6px 10px 6px 0;
}
.price-tag strong{ font-family: var(--font-display); font-size:1.3rem; color: var(--clay); }
.price-tag span{ color: var(--ink-soft); font-size:.9rem; }

/* Blog */
.blog-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap: 34px; }
.blog-card{ display:flex; flex-direction:column; }
.blog-card-img{ border-radius: var(--radius-soft); overflow:hidden; aspect-ratio: 4/3; margin-bottom: 20px; }
.blog-card-img img{ width:100%; height:100%; object-fit:cover; transition: transform .4s; }
.blog-card:hover .blog-card-img img{ transform: scale(1.04); }
.blog-date{ font-size:.82rem; color: var(--ink-soft); text-transform:uppercase; letter-spacing:.06em; margin-bottom:.4em; }
.blog-card h3 a:hover{ color: var(--clay); }
.blog-read{ font-size:.9rem; font-weight:500; color: var(--clay); margin-top: 10px; display:inline-block; }

.post-hero-img{ border-radius: var(--radius-arch); overflow:hidden; margin-bottom: 40px; max-height: 460px; }
.post-hero-img img{ width:100%; height:100%; object-fit:cover; }
.post-meta{ color: var(--ink-soft); font-size:.9rem; margin-bottom: 8px; }
.prose{ max-width: 760px; margin:0 auto; font-size: 1.06rem; }
.prose h2{ margin-top: 1.4em; font-size: 1.6rem; }
.prose ul{ margin: 1em 0 1.4em; }
.prose ul li{ position:relative; padding-left:22px; margin-bottom:8px; color: var(--ink-soft); }
.prose ul li::before{ content:"–"; position:absolute; left:0; color: var(--clay); }
.post-nav{ display:flex; justify-content:space-between; gap: 20px; max-width:760px; margin: 50px auto 0; padding-top: 28px; border-top:1px solid var(--line); }
.post-nav a{ font-weight:500; }
.post-nav a:hover{ color: var(--clay); }

/* Contact form */
.contact-grid{ display:grid; grid-template-columns: 1.1fr .9fr; gap: 60px; align-items:start; }
.form-field{ margin-bottom: 20px; }
.form-row{ display:grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-row .form-field{ margin-bottom: 20px; }
.form-field label{ display:block; font-size:.88rem; font-weight:500; margin-bottom:6px; color: var(--ink-soft); }
.form-field input, .form-field select, .form-field textarea{
  width:100%; padding: 14px 16px; border-radius: 14px; border:1px solid var(--line);
  background: var(--white); font-family: var(--font-body); font-size: .98rem; color: var(--ink);
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus{
  outline: 2px solid var(--clay); outline-offset: 1px; border-color: var(--clay);
}
.form-note{ font-size:.82rem; color: var(--ink-soft); margin: 6px 0 22px; }
.form-note a{ text-decoration: underline; }
.form-result{ margin-top: 16px; font-size: .92rem; font-weight: 500; min-height: 1.3em; }
.form-result.success{ color: var(--sage); }
.form-result.error{ color: var(--clay-dark); }
.btn[disabled]{ opacity:.6; cursor:not-allowed; }
.contact-side{
  background: var(--white); border:1px solid var(--line); border-radius: var(--radius-soft); padding: 34px;
}

/* Legal pages */
.legal h2{ margin-top: 1.6em; font-size:1.5rem; }
.legal h3{ margin-top:1.2em; }
.legal p, .legal li{ color: var(--ink-soft); }
.legal{ max-width: 800px; margin: 0 auto; }

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{ background: var(--ink); color: var(--sand); padding: 70px 0 30px; }
.footer-inner{ text-align:center; }
.footer-inner .icon-divider img{ height:56px; opacity:.9; filter: invert(1) brightness(1.6) grayscale(1) opacity(.85); }
.footer-logo{ margin: 22px 0 26px; }
.footer-logo img{ height: 46px; margin: 0 auto; filter: brightness(0) invert(1); opacity:.92; }
.footer-nav{ display:flex; justify-content:center; gap: 30px; margin-bottom: 26px; flex-wrap:wrap; }
.footer-nav a{ color: var(--sage-soft); font-size:.92rem; }
.footer-nav a:hover{ color: var(--white); }
.footer-meta{ color:#A89F8E; font-size:.82rem; }

/* ==========================================================================
   Cookie-Banner
   ========================================================================== */
.cookie-banner{
  position: fixed; left:0; right:0; bottom:0; z-index: 300;
  background: var(--ink); color: var(--sand);
  padding: 18px 24px;
  box-shadow: 0 -10px 30px rgba(0,0,0,.15);
}
.cookie-banner[hidden]{ display:none; }
.cookie-banner-inner{
  max-width: var(--container); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
}
.cookie-banner p{ margin:0; font-size:.88rem; color: var(--sand); flex:1; min-width:240px; line-height:1.5; }
.cookie-banner a{ text-decoration:underline; color: var(--white); }
.cookie-banner .btn{ flex-shrink:0; }
.cookie-banner-actions{ display:flex; gap:10px; flex-wrap:wrap; }
.cookie-banner-actions .btn-outline{ border-color: var(--sand); color: var(--sand); }
.cookie-banner-actions .btn-outline:hover{ background: var(--sand); color: var(--ink); }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 980px){
  .services-grid{ grid-template-columns: repeat(2,1fr); }
  .review-grid, .review-grid-3{ grid-template-columns: repeat(2,1fr); }
  .blog-grid{ grid-template-columns: repeat(2,1fr); }
  .mini-gallery{ grid-template-columns: repeat(2,1fr); }
  .hero-grid{ grid-template-columns: 1fr; grid-template-areas: "top" "image" "bottom"; row-gap: 26px; }
  .split, .split.reverse, .contact-grid{ grid-template-columns: 1fr; }
  .split.reverse .split-img{ order:0; }
  .cta-banner{ grid-template-columns: 1fr; }
  .cta-banner-img{ min-height: 240px; order:-1; }
  .facts, .check-list{ grid-template-columns: 1fr; }
}
@media (max-width: 760px){
  .form-row{ grid-template-columns: 1fr; gap:0; }
  .main-nav{ position: fixed; inset: 74px 0 0 0; background: var(--cream); flex-direction:column;
    padding: 30px 28px; align-items:flex-start; overflow-y:auto; z-index: 250;
    transform: translateX(100%); transition: transform .3s ease; }
  .site-header{ backdrop-filter: none; -webkit-backdrop-filter: none; background: var(--cream); }
  .main-nav.open{ transform: translateX(0); }
  .main-nav > ul{ flex-direction:column; align-items:flex-start; gap:0; width:100%; }
  .main-nav > ul > li{ width:100%; border-bottom:1px solid var(--line); }
  .main-nav a{ display:block; padding: 16px 0; }
  .sub-nav{ position:static; opacity:1; visibility:visible; transform:none; padding-top:0; display:none; }
  .has-sub.open .sub-nav{ display:block; }
  .sub-nav ul{ border:none; box-shadow:none; background:transparent; padding: 0 0 10px 14px; }
  .header-cta{ padding: 9px 18px; font-size: .92rem; }
  .menu-toggle{ display:block; }
  .services-grid, .review-grid, .review-grid-3, .blog-grid, .mini-gallery{ grid-template-columns: 1fr; }
}
