
:root{
  --bg:#f4f7f5; --card:#ffffff; --text:#1f2a24; --muted:#5a6b61;
  --brand:#2f5c3b; --brand2:#7aa57f; --line:rgba(47,92,59,.14);
  --shadow:0 10px 30px rgba(0,0,0,.06); --radius:18px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,"Noto Sans","Helvetica Neue",sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(122,165,127,.18), transparent 55%),
    radial-gradient(900px 500px at 100% 20%, rgba(47,92,59,.12), transparent 55%),
    var(--bg);
  line-height:1.6;
}
a{color:inherit}
.container{width:min(1100px,calc(100% - 40px)); margin:0 auto}

.topbar{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(10px);
  background:rgba(244,247,245,.8);
  border-bottom:1px solid var(--line);
}
.topbar-inner{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:12px 0}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none}
.brand img{width:40px; height:40px; border-radius:12px; background:#fff; border:1px solid var(--line); object-fit:cover}
.brand strong{font-size:16px; color:var(--brand); letter-spacing:.2px}
.brand span{display:block; font-size:12px; color:var(--muted)}

.nav{display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end}
.nav a{text-decoration:none; font-size:14px; color:var(--muted); padding:8px 10px; border-radius:12px}
.nav a:hover{background:rgba(47,92,59,.07); color:var(--text)}
.nav a.active{background:rgba(122,165,127,.16); color:var(--text); border:1px solid rgba(122,165,127,.28)}

.hero{padding:46px 0 18px}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:22px; align-items:center}
.kicker{display:inline-flex; gap:10px; align-items:center; font-size:13px; color:var(--muted);
  background:rgba(255,255,255,.75); border:1px solid var(--line); padding:8px 12px; border-radius:999px}
h1{margin:14px 0 10px; font-size:clamp(30px,4vw,48px); line-height:1.08; letter-spacing:-.6px}
.lead{font-size:16px; color:var(--muted); margin:0 0 10px; max-width:66ch}
.note{font-size:14px; color:var(--muted); background:rgba(255,255,255,.75); border:1px solid var(--line);
  padding:10px 12px; border-radius:14px; display:inline-block}

.hero-card{background:rgba(255,255,255,.88); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; box-shadow:var(--shadow)}
.hero-card img{width:100%; height:390px; object-fit:cover; display:block}
.hero-card .caption{padding:14px 16px; font-size:13px; color:var(--muted)}

section{padding:26px 0}
.section-title{display:flex; align-items:baseline; justify-content:space-between; gap:12px; margin-bottom:14px}
h2{margin:0; font-size:22px; letter-spacing:-.2px; color:var(--brand)}
.hint{color:var(--muted); font-size:13px}

.cards{display:grid; grid-template-columns:repeat(12,1fr); gap:14px}
.card{grid-column:span 6; background:rgba(255,255,255,.9); border:1px solid var(--line);
  border-radius:var(--radius); box-shadow:var(--shadow); padding:16px}
.card h3{margin:0 0 8px; font-size:18px; letter-spacing:-.2px}
.card p{margin:0; color:var(--muted); font-size:14px}
.price{margin-top:10px; display:inline-flex; gap:8px; align-items:center; padding:8px 10px; border-radius:12px;
  background:rgba(122,165,127,.14); border:1px solid rgba(122,165,127,.26); font-weight:700; font-size:14px}

.content-box{background:rgba(255,255,255,.9); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:18px}
.content-box p{margin:0 0 10px; color:var(--muted)}
.bullets{margin:10px 0 0; padding-left:18px; color:var(--muted)}
.bullets li{margin:6px 0}

.split{display:grid; grid-template-columns:.9fr 1.1fr; gap:18px; align-items:start}
.split img{width:100%; height:360px; object-fit:cover; border-radius:var(--radius); border:1px solid var(--line); box-shadow:var(--shadow); background:#fff}

.gallery{display:grid; grid-template-columns:repeat(12,1fr); gap:14px}
.gallery img{grid-column:span 6; width:100%; height:320px; object-fit:cover; border-radius:var(--radius); border:1px solid var(--line); box-shadow:var(--shadow); background:#fff}

.footer{padding:22px 0 40px; color:var(--muted); font-size:13px}
.footer .foot{display:flex; gap:12px; justify-content:space-between; flex-wrap:wrap; border-top:1px solid var(--line); padding-top:14px}
.social{display:flex; gap:10px; align-items:center}
.social a{display:inline-flex; gap:8px; align-items:center; text-decoration:none; color:var(--muted);
  padding:8px 10px; border-radius:12px; border:1px solid transparent}
.social a:hover{border-color:var(--line); background:rgba(255,255,255,.7); color:var(--text)}
.social svg{width:18px; height:18px}

@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr}
  .hero-card img{height:340px}
  .split{grid-template-columns:1fr}
  .split img{height:320px}
}
@media (max-width:520px){
  .container{width:calc(100% - 28px)}
  .card{grid-column:span 12}
  .gallery img{grid-column:span 12; height:280px}
}


/* --- Overrides aus deinem letzten Stand --- */
:root {
      --bg: #f4f7f5;
      --card: #ffffff;
      --text: #1f2a24;
      --muted: #5a6b61;
      --brand: #2f5c3b;
      --brand2: #7aa57f;
      --line: rgba(47, 92, 59, 0.14);
      --shadow: 0 10px 30px rgba(0,0,0,0.06);
      --radius: 18px;
    }
    * { box-sizing: border-box; }
    html, body { margin: 0; padding: 0; }
    body {
      font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
      color: var(--text);
      background: radial-gradient(1200px 600px at 10% 0%, rgba(122,165,127,0.18), transparent 55%),
                  radial-gradient(900px 500px at 100% 20%, rgba(47,92,59,0.12), transparent 55%),
                  var(--bg);
      line-height: 1.55;
    }
    .container {
      width: min(1100px, calc(100% - 40px));
      margin: 0 auto;
    }
    a { color: inherit; }
    .topbar {
      position: sticky;
      top: 0;
      z-index: 50;
      backdrop-filter: blur(10px);
      background: rgba(244,247,245,0.75);
      border-bottom: 1px solid var(--line);
    }
    .topbar-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 12px 0;
      gap: 12px;
    }
    .brand {
      display: flex;
      flex-direction: column;
      gap: 2px;
      text-decoration: none;
    }
    .brand strong {
      font-size: 16px;
      letter-spacing: 0.2px;
      color: var(--brand);
    }
    .brand span {
      font-size: 12px;
      color: var(--muted);
    }
    .nav {
      display: flex;
      gap: 14px;
      align-items: center;
      flex-wrap: wrap;
      justify-content: flex-end;
    }
    .nav a {
      text-decoration: none;
      font-size: 14px;
      color: var(--muted);
      padding: 8px 10px;
      border-radius: 12px;
    }
    .nav a:hover {
      background: rgba(47,92,59,0.07);
      color: var(--text);
    }
    .cta {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      padding: 10px 14px;
      border-radius: 14px;
      background: linear-gradient(135deg, var(--brand), #2b6b41);
      color: white !important;
      text-decoration: none;
      font-weight: 600;
      box-shadow: var(--shadow);
      border: 1px solid rgba(255,255,255,0.22);
    }
    .cta:hover { filter: brightness(1.04); }

    .hero { padding: 56px 0 26px; }
    .hero-grid {
      display: grid;
      grid-template-columns: 1.1fr 0.9fr;
      gap: 28px;
      align-items: center;
    }
    .kicker {
      display: inline-flex;
      gap: 10px;
      align-items: center;
      font-size: 13px;
      color: var(--muted);
      background: rgba(255,255,255,0.75);
      border: 1px solid var(--line);
      padding: 8px 12px;
      border-radius: 999px;
    }
    h1 {
      margin: 14px 0 10px;
      font-size: clamp(30px, 4vw, 48px);
      line-height: 1.08;
      letter-spacing: -0.6px;
    }
    .lead {
      font-size: 16px;
      color: var(--muted);
      margin: 0 0 18px;
      max-width: 60ch;
    }
    .hero-actions {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
      margin-top: 14px;
    }
    .ghost {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      padding: 10px 14px;
      border-radius: 14px;
      background: rgba(255,255,255,0.75);
      border: 1px solid var(--line);
      color: var(--text);
      text-decoration: none;
      font-weight: 600;
    }
    .ghost:hover { background: rgba(255,255,255,0.95); }

    .hero-card {
      background: rgba(255,255,255,0.82);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      overflow: hidden;
      box-shadow: var(--shadow);
    }
    .hero-card img {
      width: 100%;
      height: 420px;
      object-fit: cover;
      display: block;
    }
    .hero-card .caption {
      padding: 14px 16px;
      font-size: 13px;
      color: var(--muted);
    }

    section { padding: 28px 0; }
    .section-title {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      gap: 12px;
      margin-bottom: 14px;
    }
    h2 {
      margin: 0;
      font-size: 22px;
      letter-spacing: -0.2px;
      color: var(--brand);
    }
    .hint { color: var(--muted); font-size: 13px; }

    .cards {
      display: grid;
      grid-template-columns: repeat(12, 1fr);
      gap: 14px;
    }
    .card {
      grid-column: span 6;
      background: rgba(255,255,255,0.88);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      padding: 16px;
    }
    .card h3 {
      margin: 0 0 8px;
      font-size: 18px;
      letter-spacing: -0.2px;
    }
    .card p {
      margin: 0;
      color: var(--muted);
      font-size: 14px;
    }
    .price {
      margin-top: 10px;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 8px 10px;
      border-radius: 12px;
      background: rgba(122,165,127,0.14);
      border: 1px solid rgba(122,165,127,0.26);
      color: var(--text);
      font-weight: 700;
      font-size: 14px;
    }

    .about {
      display: grid;
      grid-template-columns: 0.9fr 1.1fr;
      gap: 18px;
      align-items: start;
    }
    .about img {
      width: 100%;
      height: 373px;
      object-fit: cover;
      border-radius: var(--radius);
      border: 1px solid var(--line);
      box-shadow: var(--shadow);
      background: #fff;
    }
    .about .box {
      background: rgba(255,255,255,0.88);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      padding: 18px;
    }
    .about .box p {
      margin: 0 0 10px;
      color: var(--muted);
    }
    .bullets {
      margin: 12px 0 0;
      padding-left: 18px;
      color: var(--muted);
    }
    .bullets li { margin: 6px 0; }

    .booking {
      background: rgba(255,255,255,0.86);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      padding: 18px;
    }
    .booking small {
      display: block;
      color: var(--muted);
      margin-top: 8px;
    }
    .embed {
      margin-top: 14px;
      border: 1px dashed rgba(47,92,59,0.35);
      border-radius: 14px;
      padding: 14px;
      background: rgba(122,165,127,0.08);
      color: var(--muted);
      font-size: 14px;
    }

    .gallery {
      display: grid;
      grid-template-columns: repeat(12, 1fr);
      gap: 14px;
    }
    .gallery img {
      grid-column: span 6;
      width: 100%;
      height: 702px!important;
      object-fit: cover;
      border-radius: var(--radius);
      border: 1px solid var(--line);
      box-shadow: var(--shadow);
      background: #fff;
    }

    .contact-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 14px;
    }
    .contact-card {
      background: rgba(255,255,255,0.88);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      padding: 18px;
    }
    .contact-card a {
      color: var(--brand);
      text-decoration: none;
      font-weight: 700;
    }
    .contact-card a:hover { text-decoration: underline; }

    footer {
      padding: 22px 0 40px;
      color: var(--muted);
      font-size: 13px;
    }
    footer .foot {
      display: flex;
      gap: 12px;
      justify-content: space-between;
      flex-wrap: wrap;
      border-top: 1px solid var(--line);
      padding-top: 14px;
    }

    @media (max-width: 860px) {
      .hero-grid { grid-template-columns: 1fr; }
      .hero-card img { height: 360px; }
      .about { grid-template-columns: 1fr; }
      .about img { height: 320px; }
      .contact-grid { grid-template-columns: 1fr; }
    }
    @media (max-width: 520px) {
      .container { width: calc(100% - 28px); }
      .nav a { padding: 6px 8px; }
      .hero { padding-top: 36px; }
      .hero-card img { height: 320px; }
      .card { grid-column: span 12; }
      .gallery img { grid-column: span 12; height: 700px; }
    }

.logo-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:10px 0 6px}
.logo-center img{width:min(520px,92%);height:auto;display:block;filter:drop-shadow(0 10px 25px rgba(0,0,0,.08))}
.script-line{text-align:center;font-family:"Brush Script MT","Segoe Script","Apple Chancery","Lucida Handwriting",cursive;
  font-size:clamp(28px,4.2vw,46px);color:var(--brand);line-height:1.08;margin:0}

/* --- Startseiten-Logo: weniger Abstand + stärker verschmelzen --- */
.logo-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:0;margin-top:-12px}
.logo-center img{width:min(560px,94%);height:auto;display:block;opacity:.95;mix-blend-mode:multiply;filter:drop-shadow(0 8px 20px rgba(0,0,0,.06))}


/* --- Mobile: Subtitle im Header ausblenden (Headerhöhe reduzieren) --- */
@media (max-width: 520px){
  .brand span{display:none !important;}
}

/* --- Mobile Hamburger Menü --- */
.nav-toggle{
  display:none;
  width:42px;
  height:42px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.7);
  box-shadow:var(--shadow);
  align-items:center;
  justify-content:center;
  gap:5px;
  padding:0;
  cursor:pointer;
}
.nav-toggle span{
  display:block;
  width:18px;
  height:2px;
  background:var(--brand);
  border-radius:999px;
}

@media (max-width: 860px){
  .topbar-inner{position:relative;}
  .nav-toggle{display:inline-flex; flex-direction:column;}
  .nav{
    position:absolute;
    right:0;
    top:calc(100% + 10px);
    display:none;          /* wird via .open eingeblendet */
    flex-direction:column;
    align-items:stretch;
    min-width: min(260px, 92vw);
    padding:10px;
    background:rgba(244,247,245,.98);
    border:1px solid var(--line);
    border-radius:16px;
    box-shadow:var(--shadow);
  }
  .nav.open{display:flex;}
  .nav a{width:100%;}
}

