/* =========================
   Farb- & Typo-Setup
   ========================= */
:root{
  --bg:#f6f3ef; --paper:#fffdfa; --ink:#1f150e; --muted:#6d6258;
  --brand:#8a5a3b; --brand-dark:#3b2a1c; --accent:#d4a373;
  --success:#2e7d32; --error:#b00020; --radius:14px; --shadow:0 10px 30px rgba(0,0,0,.08);

  /* Fixe Leiste: Höhen (Desktop-Defaults) */
  --topbarH: 32px;
  --headerH: 64px;
  --offset: calc(var(--topbarH) + var(--headerH));
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0; font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink); background:var(--bg); line-height:1.6;
  padding-top: var(--offset); /* Platz für fixe Topbar + Header */
}
h1,h2,h3{font-family:"Playfair Display", Georgia, serif; line-height:1.2; margin:0 0 .4rem}
h1{font-size:clamp(2rem, 1.6rem + 2vw, 3.2rem)}
h2{font-size:clamp(1.5rem, 1.2rem + 1.2vw, 2.2rem)}
h3{font-size:1.2rem}
p{margin:.5rem 0 1rem}
a{color:var(--brand); text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%; display:block; border-radius:12px}
strong{font-weight:800} em{font-style:italic}
.container{width:min(1100px, 92vw); margin:0 auto}
.section{padding:72px 0; scroll-margin-top: calc(var(--offset) + 8px)}
.section.alt{background:linear-gradient(180deg, #f0ebe6, #f7f3ef)}
.section-title{margin-bottom:24px; position:relative; display:inline-block}
.section-title::after{content:""; position:absolute; left:0; bottom:-8px; width:52%; height:4px;
  background:linear-gradient(90deg, var(--brand), var(--accent)); border-radius:2px}

/* Skip-Link */
.skip-link{position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden}
.skip-link:focus{left:12px; top:12px; background:#fff; padding:.5rem .75rem; z-index:9999; border-radius:8px; box-shadow:var(--shadow)}

/* =========================
   Fixe Topbar + Header (mitlaufend)
   ========================= */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:var(--brand-dark); color:#f3eae3; font-size:.9rem;
}
.topbar .container{display:flex; gap:16px; align-items:center; justify-content:space-between; padding:.4rem 0}
.top-link{color:#f3eae3; opacity:.9} .top-link:hover{opacity:1}

/* Header: fix direkt unter Topbar */
.site-header{
  position:fixed; left:0; right:0; top:var(--topbarH); z-index:180;
  background:rgba(255,253,250,.92); backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid #e8e1da; transition: box-shadow .2s ease;
}
.site-header.shadow{ box-shadow: 0 8px 20px rgba(0,0,0,.06) }

.nav-wrap{display:flex; align-items:center; justify-content:space-between; padding:.8rem 0}
.brand{display:flex; align-items:center; gap:.6rem; font-weight:700; letter-spacing:.2px; color:var(--ink)}
.brand:hover{text-decoration:none}
.brand strong{color:var(--brand)}
.logo{width:28px; height:28px} .logomark{fill:var(--brand)} .logodoor{fill:#fff1e3}

.main-nav{display:flex; align-items:center; gap:1rem}
.main-nav a{padding:.5rem .4rem; border-radius:8px}
.main-nav a.active{background:#fff; box-shadow:var(--shadow)}

.btn{background:var(--brand); color:#fff; padding:.7rem 1rem; border-radius:999px; border:0; display:inline-block; font-weight:700; letter-spacing:.2px}
.btn:hover{filter:brightness(1.05); text-decoration:none}
.btn-outline{border:1.5px solid var(--brand); background:transparent; color:var(--brand)}
.btn-outline:hover{background:#fff}
.btn-sm{padding:.45rem .8rem; font-size:.92rem}
.btn-block{width:100%}

/* Burger */
.burger{display:none; background:none; border:0; padding:.4rem; cursor:pointer}
.burger span{display:block; width:24px; height:2px; background:var(--brand-dark); margin:5px 0; transition:.2s}

/* =========================
   Hero
   ========================= */
.hero{padding:84px 0}
.hero-grid{display:grid; gap:28px; align-items:center}
.hero-copy p{font-size:1.1rem; color:#3c3026}
.hero-cta{display:flex; gap:.6rem; margin:1rem 0 1.2rem}
.badges{display:flex; flex-wrap:wrap; gap:.5rem; padding:0; margin:0; list-style:none}
.badges li{background:#fff; border:1px solid #eadfd6; border-radius:999px; padding:.35rem .6rem; font-size:.9rem}

.hero-card{background:#fff; border:1px solid #eadfd6; border-radius:var(--radius); padding:1rem; box-shadow:var(--shadow)}
.hero-card h3{margin-bottom:.25rem}
.hero-card .muted{font-size:.8rem; color:var(--muted)}
.hero-card label{display:block; font-weight:600; margin:.6rem 0 .3rem}
.hero-card input, .hero-card select, .hero-card textarea{width:100%; padding:.65rem .75rem; border-radius:10px; border:1px solid #dfd5cc; background:#fffdfa}
.form-msg{margin:.6rem 0 0; font-size:.9rem}
.form-msg.success{color:var(--success)} .form-msg.error{color:var(--error)}

/* Holztextur */
.wood-bg{
  background:
    radial-gradient(100% 60% at 0% 0%, rgba(255,255,255,.6), rgba(255,255,255,0) 60%),
    repeating-linear-gradient(8deg, #d9b38c 0 8px, #caa078 8px 18px, #b88964 18px 26px),
    linear-gradient(180deg, #f4e7da 0%, #f0e2d3 100%);
}

/* =========================
   Cards / Grid
   ========================= */
.cards{display:grid; grid-template-columns:1fr; gap:16px}
.card{background:#fff; border:1px solid #eadfd6; border-radius:var(--radius); padding:1rem; box-shadow:var(--shadow)}
.list{margin:.6rem 0 0; padding-left:1.1rem} .list li{margin:.2rem 0}

/* Gallery */
.gallery{display:grid; grid-template-columns:1fr; gap:14px}
.gallery figure{margin:0} .gallery figcaption{margin-top:.4rem; font-size:.9rem; color:var(--muted)}

/* About */
.about p{max-width:70ch}
.timeline{list-style:none; padding:0; margin:1rem 0 0; display:grid; gap:.4rem}
.timeline li{display:flex; gap:.8rem; align-items:flex-start}
.timeline span{display:inline-block; min-width:64px; padding:.2rem .5rem; border-radius:999px; background:#fff; border:1px solid #eadfd6; font-weight:700; color:var(--brand-dark)}

/* Perks / Quotes */
.perks{grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:14px}
.perk{background:#fff; border:1px solid #eadfd6; border-radius:var(--radius); padding:1rem; box-shadow:var(--shadow)}
.quotes{grid-template-columns:repeat(auto-fit, minmax(260px,1fr)); gap:12px}
blockquote{background:#fff; border-left:4px solid var(--accent); margin:0; padding:1rem; border-radius:10px; box-shadow:var(--shadow)}
blockquote cite{display:block; margin-top:.4rem; color:var(--muted); font-style:normal}

/* FAQ */
.faq{background:#fff; border:1px solid #eadfd6; border-radius:var(--radius); padding:.8rem 1rem; margin:.6rem 0; box-shadow:var(--shadow)}
.faq summary{cursor:pointer; font-weight:700}
.faq[open]{border-color:#e0cbb6}

/* Kontakt */
.grid{display:grid}
.contact{grid-template-columns:1fr; gap:18px}
.contact-info p{margin:.2rem 0 1rem}
.contact-form label{display:block; font-weight:600; margin:.6rem 0 .3rem}
.contact-form input, .contact-form textarea{width:100%; padding:.7rem .8rem; border-radius:10px; border:1px solid #dfd5cc; background:#fffdfa}
.checkbox{display:flex; align-items:flex-start; gap:.5rem}
.checkbox input{margin-top:.25rem}

/* Footer */
.footer{background:var(--brand-dark); color:#efe8e1; padding:36px 0}
.footer-grid{display:grid; grid-template-columns:1fr; gap:12px}
.brand--footer{display:flex; align-items:center; gap:.5rem; font-weight:800}
.footer a{color:#fff}
.footer-links{list-style:none; padding:0; margin:0; display:grid; gap:.3rem}
.muted{color:#b9aea5}

/* Reveal Animations */
.reveal{opacity:0; transform:translateY(12px); transition:opacity .5s ease, transform .5s ease}
.reveal.active{opacity:1; transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1; transform:none}
  html{scroll-behavior:auto}
}

/* =========================
   Mobile Overlay-Nav (öffnet unter der fixen Leiste)
   ========================= */
.no-scroll{overflow:hidden; position:fixed; width:100%}

@media (max-width: 900px){
  /* Topbar aus, Offset neu berechnen */
  :root{ --topbarH: 0px; --headerH: 64px; --offset: calc(var(--topbarH) + var(--headerH)); }
  .topbar{ display:none; }

  .burger{ display:block; position:relative; z-index:200 }

  /* Overlay-Menü: volle Fahrhöhe, scrollt intern */
  .main-nav{
    position:fixed; left:0; right:0;
    top: var(--offset);
    height: calc(100dvh - var(--offset));
    overflow:auto; -webkit-overflow-scrolling:touch;
    background:#fffdfa;
    display:flex; flex-direction:column; gap:.25rem;
    padding:1rem;
    transform:translateY(-100%);
    transition:transform .22s ease;
    box-shadow:0 40px 40px rgba(0,0,0,.1);
    z-index:150; /* unter Header/Burger, über Content/Bottom-Bar */
  }
  .main-nav.open{ transform:translateY(0) }
  .main-nav a{ font-size:1.1rem; padding:.8rem .6rem; border-radius:10px }
  .main-nav a.active{ background:#fff; box-shadow:var(--shadow) }
}

/* Layout Breakpoints */
@media (min-width: 800px){
  .hero-grid{grid-template-columns:1.1fr .9fr}
  .cards{grid-template-columns:repeat(4, 1fr)}
  .gallery{grid-template-columns:repeat(3, 1fr)}
  .contact{grid-template-columns:1fr 1.1fr}
  .nav-wrap{gap:16px}
}

/* =========================
   Mobile Bottom Bar (optional)
   ========================= */
.mobile-bar{
  position:fixed; left:0; right:0; bottom:0; z-index:60;
  display:none;
  background:#fffdfa; border-top:1px solid #e8e1da; box-shadow:0 -10px 30px rgba(0,0,0,.06);
  padding:6px max(10px, env(safe-area-inset-left)) calc(6px + env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-right));
}
.mobile-bar .mitem{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:4px; text-decoration:none; color:var(--brand-dark); font-size:.78rem; border-radius:10px; padding:6px 8px;
}
.mobile-bar .mitem.active{background:#fff; box-shadow:var(--shadow)}
.mobile-bar .mitem svg{width:22px; height:22px; stroke:currentColor; fill:none; stroke-width:2}
.mobile-bar .mitem--cta{background:var(--brand); color:#fff}
.mobile-bar .mitem--cta svg{stroke:#fff}

@media (max-width: 900px){
  .mobile-bar{display:grid; grid-template-columns:repeat(5, 1fr)}
  body{padding-bottom:72px}
}

/* Utility */
.muted{color:var(--muted)}

/* =========================
   Platzhalter für Galerie
   ========================= */
.gallery--placeholders .ph-media{
  aspect-ratio: 16 / 10;
  display: grid;
  place-items: center;
  border: 2px dashed #d6c6b6;
  border-radius: 12px;
  background:
    radial-gradient(100% 60% at 0% 0%, rgba(255,255,255,.6), rgba(255,255,255,0) 60%),
    repeating-linear-gradient(8deg, #f6efe7 0 12px, #f1e7dd 12px 24px);
  color: #a38a73;
  position: relative;
  overflow: hidden;
}
.gallery--placeholders .ph-media::before{
  content: "Ihr Bild hier";
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  opacity: .9;
}
.gallery--placeholders .ph-media:hover{
  filter: brightness(1.02);
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}
