:root {
  --bg: #ffffff;
  --text: #1a2e1a;
  --muted: #d6e4d6;
  --primary: #2d6a4f;
  --primary-600: #1b4332;
  --accent: #c9a96e;
  --accent-600: #b08040;
  --surface: #f4f7f0;
  --beige: #f9f4ec;
  --ring: rgba(45,106,79,.3);
  --font-head: 'Nunito', sans-serif;
  --font-body: 'Nunito', sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Nunito',sans-serif;color:var(--text);background:var(--bg);line-height:1.7;}
h1,h2,h3,h4{font-family:'Nunito',sans-serif;line-height:1.25;font-weight:800;}
img{max-width:100%;height:auto;display:block}
.container{width:min(1100px,92vw);margin-inline:auto}
.section{padding:3.5rem 0}
.section.alt{background:var(--surface)}
.muted{color:#8a9e8a}
@keyframes fadeInUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeInUp .7s ease both;}
.fade-in--delay-1{animation-delay:.2s}
.fade-in--delay-2{animation-delay:.4s}
.fade-in--delay-3{animation-delay:.6s}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease;}
.reveal.is-visible{opacity:1;transform:translateY(0);}
.reveal-banner{opacity:0;transform:translateY(40px);transition:opacity .9s ease,transform .9s ease;}
.reveal-banner.is-visible{opacity:1;transform:translateY(0);}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.65rem 1.3rem;border-radius:.5rem;font-weight:700;font-size:1rem;font-family:'Nunito',sans-serif;text-decoration:none;cursor:pointer;border:none;transition:filter .15s ease,transform .1s ease;letter-spacing:.03em;}
.btn:hover{filter:brightness(1.1)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:#1a2e1a;}
.btn-ghost{background:rgba(255,255,255,.15);color:#fff;border:2px solid rgba(255,255,255,.5);}
.site-header{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-bottom:2px solid var(--accent);}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0}
.brand{font-family:'Nunito',sans-serif;font-weight:800;font-size:1.25rem;letter-spacing:.5px;text-decoration:none;color:var(--primary);}
.lang-nav{display:flex;gap:.5rem}
.lang-btn{appearance:none;border:1px solid var(--primary);background:#fff;color:var(--primary);padding:.4rem .7rem;border-radius:.4rem;cursor:pointer;font-family:'Nunito',sans-serif;font-weight:700;font-size:.85rem;}
.lang-btn[aria-pressed="true"]{background:var(--primary);color:#fff;}
.hero{padding:0}
.hero-banner{position:relative;min-height:28rem;background-image:url('assets/hero-placeholder.jpg');background-size:cover;background-position:center;background-repeat:no-repeat;overflow:hidden;}
.hero-banner::after{content:"";position:absolute;left:0;right:0;bottom:0;height:180px;pointer-events:none;background:linear-gradient(to bottom,rgba(0,0,0,0) 0%,rgba(0,0,0,0.1) 40%,rgba(0,0,0,0.3) 100%);}
.hero-overlay{position:relative;inset:0;min-height:inherit;z-index:2;background:linear-gradient(180deg,rgba(26,46,26,.45) 0%,rgba(26,46,26,.25) 50%,rgba(26,46,26,.1) 100%);}
.hero-content{min-height:28rem;display:flex;flex-direction:column;justify-content:center;gap:1rem;color:#fff;padding:2.5rem 0;}
.hero-ctas{display:flex;gap:.75rem;flex-wrap:wrap;}
.hero-banner h1{color:#fff;margin:0 0 .3rem;font-size:clamp(2.2rem,5vw,3.8rem);text-shadow:0 2px 12px rgba(0,0,0,.3);font-weight:800;}
.hero-banner .lead{font-size:1.2rem;margin:0;text-shadow:0 1px 6px rgba(0,0,0,.25);font-weight:600;}
.hero-banner .highlights{display:flex;gap:.75rem;flex-wrap:wrap;margin:.5rem 0 0;padding:0;}
.hero-banner .highlights li{list-style:none;background:rgba(201,169,110,.25);border:1px solid rgba(201,169,110,.6);color:#fff;padding:.3rem .75rem;border-radius:2rem;font-size:.9rem;font-weight:700;backdrop-filter:blur(4px);}
.hero-banner .btn{box-shadow:0 6px 20px rgba(0,0,0,.25)}
@media(min-width:960px){.hero-banner,.hero-content{min-height:48rem}}
.parallax-section{position:relative;overflow:hidden;}
.parallax-bg{position:absolute;inset:-30% 0;background-size:cover;background-position:center;background-repeat:no-repeat;will-change:transform;z-index:0;}
.about-bg{background-image:url('assets/about-placeholder.jpeg');}

/* About Banner – mobil fix */
.about-banner{min-height:28rem;}
.about-banner::before{content:"";position:absolute;left:0;right:0;top:0;height:140px;pointer-events:none;z-index:1;background:linear-gradient(to top,rgba(0,0,0,0) 0%,rgba(0,0,0,0.08) 35%,rgba(0,0,0,0.18) 70%,rgba(0,0,0,0.28) 100%);}
.about-overlay{position:relative;inset:0;min-height:inherit;z-index:2;background:none;}
.about-content{position:relative;min-height:28rem}
.about-box{position:relative;left:0;bottom:0;max-width:100%;margin:.75rem .5rem;padding:1rem 1.1rem;background:rgba(26,46,26,.7);backdrop-filter:blur(4px);border-radius:12px;color:#fff;line-height:1.75;border-left:4px solid var(--accent);}
.about-box h2{margin:0 0 .6rem;color:#fff;font-weight:800;font-size:clamp(1rem,2.5vw,1.5rem);}
.about-box p{margin:.5rem 0;color:#eaf2ea;font-weight:400;font-size:clamp(.85rem,1.5vw,1rem);}
.about-box .muted{color:rgba(234,242,234,.65);}
@media(min-width:960px){
  .about-banner{min-height:48rem}
  .about-content{min-height:48rem;display:flex;align-items:flex-end;}
  .about-box{position:relative;margin:.75rem;padding:1.2rem 1.5rem 1.4rem;max-width:min(920px,92vw);}
}

/* Trenner & Slideshow */
.trenner{min-height:28rem;position:relative;overflow:hidden;}
@media(min-width:960px){.trenner{min-height:48rem}}
.trenner-overlay{position:relative;inset:0;min-height:inherit;z-index:2;background:rgba(0,0,0,.25);display:flex;align-items:center;justify-content:center;}
.trenner-quote{margin:0;padding:0 1.5rem;text-align:center;}
.trenner-quote-text{display:inline-block;font-family:'Nunito',sans-serif;font-size:clamp(1.1rem,2.5vw,1.8rem);font-style:italic;font-weight:600;color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.55);letter-spacing:.02em;line-height:1.5;}
.trenner-quote-text--warm{color:#f5e6c8;text-shadow:0 2px 20px rgba(0,0,0,.7);}
.slideshow-bg{position:absolute;inset:0;z-index:0;}
.slideshow-bg .slide{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:0;transition:opacity 2.5s ease;}
.slideshow-bg .slide.is-active{opacity:1;}

.section h2{font-family:'Nunito',sans-serif;font-weight:800;color:var(--primary);font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:1.25rem;}
.section h2::after{content:"";display:block;width:3rem;height:3px;background:var(--accent);margin-top:.4rem;border-radius:2px;}

/* Ausstattung */
#features{background:var(--surface);}
.features-list{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));padding:0;list-style:none;}
.features-list li{background:#fff;border:1px solid #d6e8d6;border-top:4px solid var(--accent);border-radius:.8rem;padding:1rem 1.1rem;font-size:.97rem;display:flex;align-items:stretch;min-height:140px;}
.feature-content{display:flex;flex-direction:column;gap:.3rem;width:100%;}
.feature-label{font-weight:800;color:var(--primary);font-size:.95rem;}
.feature-text{color:var(--text);font-size:.93rem;line-height:1.5;}
.features-hint{color:#4a6a4a;font-size:.92rem;margin-top:1rem;font-style:italic;padding:.6rem 1rem;background:#fff;border-left:4px solid var(--accent);border-radius:.4rem;}

/* Galerie */
#gallery{background:var(--surface);}
.gallery-tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin:.75rem 0 1rem}
.gallery-tabs .tab{appearance:none;border:1px solid #b8d4b8;background:#fff;color:var(--primary);padding:.5rem .9rem;border-radius:.5rem;cursor:pointer;font-weight:700;font-size:.92rem;transition:background .15s,color .15s;font-family:'Nunito',sans-serif;}
.gallery-tabs .tab.is-active{background:var(--primary);border-color:var(--primary-600);color:#fff;}
.gallery-grids{width:100%}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.8rem}
.gallery-grid img{border-radius:.6rem;aspect-ratio:4/3;object-fit:cover;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;}
.gallery-grid img:hover{transform:scale(1.03);box-shadow:0 8px 24px rgba(0,0,0,.18)}
.is-hidden{display:none!important}

/* Bewertungen */
#reviews{background:var(--surface);}
.reviews-source-note{color:#6a8a6a;font-size:.9rem;margin-bottom:1.75rem;font-style:italic;}
.slider-wrap{position:relative;overflow:hidden;padding:0 3rem;}
@media(min-width:720px){.slider-wrap{padding:0 4rem;}}
.slider-track{display:flex;gap:1.25rem;transition:transform .5s ease;cursor:grab;}
.slider-track:active{cursor:grabbing;}
.slider-card{flex:0 0 100%;background:#fff;border:1px solid #d6e8d6;border-radius:1rem;padding:1.6rem 1.4rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:0 2px 12px rgba(45,106,79,.06);}
@media(min-width:720px){.slider-card{flex:0 0 calc(50% - .625rem);}}
@media(min-width:1024px){.slider-card{flex:0 0 calc(33.333% - .835rem);}}
.review-stars{color:var(--accent);font-size:1.1rem;letter-spacing:.1rem;}
.review-text{margin:0;font-style:italic;color:#2a3a2a;line-height:1.7;font-size:.97rem;flex:1;}
.review-text--muted{color:#8a9e8a;font-style:normal;font-size:.9rem;}
.review-meta{display:flex;flex-direction:column;gap:.2rem;border-top:1px solid #d6e8d6;padding-top:.75rem;}
.review-name{font-weight:700;color:var(--primary);font-size:.95rem;}
.review-detail{color:#6a8a6a;font-size:.85rem;}
.review-source{font-size:.8rem;font-weight:700;color:var(--accent-600);text-transform:uppercase;letter-spacing:.06em;}
.slider-btn{position:absolute;top:50%;transform:translateY(-50%);background:var(--primary);border:none;color:#fff;width:2.5rem;height:2.5rem;border-radius:50%;font-size:1.6rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.15);transition:background .15s,transform .15s;z-index:2;}
.slider-btn:hover{background:var(--primary-600);transform:translateY(-50%) scale(1.08);}
.slider-btn--prev{left:0;}
.slider-btn--next{right:0;}
.slider-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1.25rem;}
.slider-dot{width:.6rem;height:.6rem;border-radius:50%;background:#b8d4b8;border:none;cursor:pointer;padding:0;transition:background .2s,transform .2s;}
.slider-dot.is-active{background:var(--primary);transform:scale(1.3);}

/* Preise */
#rates{background:var(--surface);overflow:visible;}
.rates-intro{color:#4a6a4a;margin-bottom:1.5rem;font-size:1rem;}
.flip-cards{display:grid;gap:1.25rem;grid-template-columns:1fr;margin-bottom:2rem;}
@media(min-width:600px){.flip-cards{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.flip-cards{grid-template-columns:repeat(5,1fr)}}
.flip-card{height:210px;cursor:pointer;perspective:1200px;}
.flip-card-inner{position:relative;width:100%;height:100%;transition:transform .7s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d;}
.flip-card.is-flipped .flip-card-inner{transform:rotateY(180deg);}
.flip-card-front,.flip-card-back{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;padding:1.25rem;text-align:center;box-shadow:0 4px 20px rgba(45,106,79,.1);}
.flip-card-front{background:var(--beige);border:1px solid #d6e8d6;}
.flip-front--highlight{border:2px solid var(--accent);background:linear-gradient(135deg,#f5ecd8 0%,var(--beige) 100%);}
.flip-card-back{transform:rotateY(180deg);}
.flip-back--winter{background:linear-gradient(135deg,#1a3a5c 0%,#2d5a8e 100%);color:#fff;}
.flip-back--frühling{background:linear-gradient(135deg,#2d6a2d 0%,#4a9a4a 100%);color:#fff;}
.flip-back--sommer{background:linear-gradient(135deg,#f5a623 0%,#f7c948 100%);color:#1a2e1a;}
.flip-back--herbst{background:linear-gradient(135deg,#8B4513 0%,#d4580a 100%);color:#fff;}
.flip-back--nebensaison{background:linear-gradient(135deg,#2c3e6b 0%,#4a6fa5 100%);color:#fff;}
.flip-season-icon{font-size:2.5rem;line-height:1;margin-bottom:.2rem;}
.flip-season-icon i{font-size:2.5rem;}
.flip-card-front .flip-season-icon i{color:var(--primary);}
.flip-back--nebensaison .flip-season-icon i{color:#add8f7;}
.flip-back--frühling .flip-season-icon i{color:#c8f7c8;}
.flip-back--sommer .flip-season-icon i{color:#1a2e1a;}
.flip-back--herbst .flip-season-icon i{color:#fff;}
.flip-back--winter .flip-season-icon i{color:#add8f7;}
.flip-card-front h3{font-size:.92rem;font-weight:800;color:var(--primary);margin:0;line-height:1.3;}
.flip-card-back h3{font-size:.92rem;font-weight:800;color:inherit;margin:0;line-height:1.3;}
.flip-period{font-size:.78rem;color:#6a8a6a;margin:0;}
.flip-card-back .flip-period{color:rgba(255,255,255,.8);}
.flip-back--sommer .flip-period{color:rgba(26,46,26,.7);}
.flip-hint{font-size:.8rem;font-weight:700;color:var(--accent-600);margin:.2rem 0 0;animation:pulse 2s ease-in-out infinite;}
.flip-price{font-size:2.2rem;font-weight:800;margin:0;color:inherit;line-height:1;}
.flip-price small{font-size:.85rem;font-weight:400;margin-left:.1rem;opacity:.85;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}
.rates-table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-size:.97rem;}
.rates-table td{padding:.6rem .8rem;border-bottom:1px solid #e4f0e4;}
.rates-table td:first-child{color:#4a6a4a;font-weight:700;width:55%;}
.rates-table tr:last-child td{border-bottom:none;}
.price-calc{background:#fff;border:1px solid #d6e8d6;border-top:4px solid var(--accent);border-radius:.8rem;padding:1.1rem 1.25rem;}
.price-calc h3{font-family:'Nunito',sans-serif;font-weight:800;color:var(--primary);margin:0 0 .5rem;font-size:1.05rem;}
.calc-result{margin:0;color:#4a6a4a;font-size:.97rem;}
.calc-result strong{color:var(--primary-600);}
.form-price-info{background:var(--beige);border:1px solid #d6e8d6;border-top:4px solid var(--accent);border-radius:.6rem;padding:.75rem 1rem;margin:.75rem 0;}
.form-price-info p{margin:0;color:var(--primary-600);font-weight:700;}

/* Umgebung */
#location{background:var(--surface);}
.location-intro{color:#4a6a4a;font-size:1.05rem;margin-bottom:2rem;max-width:820px;}
.location-grid{display:grid;gap:1.25rem;grid-template-columns:1fr;margin-bottom:2.5rem;}
@media(min-width:600px){.location-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){.location-grid{grid-template-columns:repeat(3,1fr)}}
.location-card{background:#fff;border:1px solid #d6e8d6;border-top:4px solid var(--accent);border-radius:.9rem;padding:1.3rem 1.2rem;box-shadow:0 2px 12px rgba(45,106,79,.06);transition:transform .2s ease,box-shadow .2s ease;}
.location-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(45,106,79,.12)}
.location-card h3{font-family:'Nunito',sans-serif;font-weight:800;color:var(--primary);margin:0 0 .8rem;font-size:1.05rem;}
.location-card ul{margin:0;padding-left:1.1rem;color:#2a3a2a;font-size:.94rem;line-height:1.75;}
.location-card li{margin-bottom:.25rem;}
.location-card a{color:var(--primary);text-decoration:none;border-bottom:1px dotted var(--primary);}
.location-card a:hover{color:var(--accent-600);border-bottom-color:var(--accent-600);}
.map-card{width:100%;height:420px;border-radius:12px;overflow:hidden;border:1px solid #d6e8d6;background:#fff;padding:.6rem;margin-bottom:.5rem;}
.map-card iframe{width:100%!important;height:100%!important;border:0;border-radius:.6rem;display:block}

/* Wetter */
#weather{background:var(--surface);}
.weather-subtitle{color:#4a6a4a;margin-bottom:1.5rem;font-size:1rem;}
.weather-now{display:flex;gap:2rem;align-items:center;background:#fff;border:1px solid #d6e8d6;border-radius:1rem;padding:1.5rem 2rem;margin-bottom:2rem;box-shadow:0 2px 12px rgba(45,106,79,.06);flex-wrap:wrap;}
.weather-now-main{display:flex;align-items:center;gap:1rem;}
.weather-icon-img{width:80px;height:80px;}
.weather-now-temp{font-size:3.5rem;font-weight:800;color:var(--primary);}
.weather-now-details{display:flex;flex-direction:column;gap:.4rem;color:#4a6a4a;font-size:.95rem;}
.weather-now-details p{margin:0;}
.weather-now-details i{color:var(--accent);margin-right:.4rem;width:1rem;}
.weather-desc{font-size:1.1rem;font-weight:700;color:var(--primary);text-transform:capitalize;}
.weather-forecast-title{font-family:'Nunito',sans-serif;font-weight:800;color:var(--primary);font-size:1.2rem;margin:0 0 1rem;}
.weather-forecast{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin-bottom:1rem;}
.weather-day{background:#fff;border:1px solid #d6e8d6;border-radius:.8rem;padding:.9rem;text-align:center;box-shadow:0 2px 8px rgba(45,106,79,.06);}
.weather-day-name{font-weight:800;color:var(--primary);font-size:.85rem;margin-bottom:.3rem;}
.weather-day img{width:48px;height:48px;margin:0 auto .3rem;}
.weather-day-temp{font-size:1.1rem;font-weight:800;color:var(--primary-600);}
.weather-day-desc{font-size:.75rem;color:#6a8a6a;text-transform:capitalize;margin-top:.2rem;}
.weather-source{font-size:.82rem;margin-top:.5rem;}

/* Kontakt */
#contact{background:var(--surface);}
.card{background:#fff;border:1px solid #d6e8d6;border-radius:1rem;padding:1.5rem;box-shadow:0 4px 24px rgba(45,106,79,.07);}
.form-grid{display:grid;gap:.9rem;grid-template-columns:1fr}
@media(min-width:720px){.form-grid{grid-template-columns:1fr 1fr}}
.form-field label{display:block;font-weight:700;margin-bottom:.35rem;color:var(--primary);font-size:.93rem;}
.form-field input,.form-field textarea,.form-field select{width:100%;padding:.7rem .9rem;border-radius:.5rem;border:1.5px solid #b8d4b8;background:#fff;color:var(--text);font-family:'Nunito',sans-serif;font-size:1rem;transition:border-color .15s,box-shadow .15s;}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 .2rem var(--ring);}
.form-status{margin-top:.6rem;min-height:1.2em;color:#4a7a4a;font-weight:700}
.back-to-top{position:fixed;bottom:1.75rem;right:1.75rem;z-index:99;width:3rem;height:3rem;border-radius:50%;background:var(--primary);color:#fff;border:none;font-size:1.6rem;line-height:1;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,.2);transition:opacity .25s ease,transform .25s ease,background .15s;display:flex;align-items:center;justify-content:center;}
.back-to-top:hover{background:var(--primary-600);transform:translateY(-3px);}
.back-to-top[hidden]{display:none!important}
.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.93);display:flex;align-items:center;justify-content:center;}
.lightbox[hidden]{display:none!important}
.lb-img-wrap{max-width:92vw;max-height:88vh;display:flex;align-items:center;justify-content:center;}
.lb-img-wrap img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:.5rem;box-shadow:0 8px 48px rgba(0,0,0,.6);}
.lb-close{position:fixed;top:1rem;right:1.25rem;background:none;border:none;color:#fff;font-size:2.5rem;cursor:pointer;line-height:1;z-index:1001;transition:transform .15s;}
.lb-close:hover{transform:scale(1.15)}
.lb-prev,.lb-next{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;color:#fff;font-size:3rem;cursor:pointer;padding:.2rem .7rem;border-radius:.5rem;z-index:1001;transition:background .15s;line-height:1;}
.lb-prev{left:.75rem}
.lb-next{right:.75rem}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.28)}
.site-footer{border-top:2px solid var(--accent);background:var(--primary-600);color:#d4ecd4;}
.footer-inner{padding:1.25rem 0;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;}
.footer-inner p{margin:0;color:#c4e0c4;font-size:.93rem;}
.footer-nav{display:flex;gap:1.25rem}
.footer-nav a{color:var(--accent);text-decoration:none;font-weight:700;font-size:.93rem;}
.footer-nav a:hover{color:#fff}
.imprint{background:var(--primary);padding:2rem 0;border-top:1px solid rgba(255,255,255,.1)}
.imprint-grid{display:grid;gap:2rem;grid-template-columns:1fr;}
@media(min-width:720px){.imprint-grid{grid-template-columns:1fr 1fr}}
.imprint-col h3{font-family:'Nunito',sans-serif;font-weight:800;color:#fff;margin:0 0 1rem;font-size:1.1rem;}
.imprint-col p{color:#c4e0c4;font-size:.9rem;margin:0 0 .75rem;line-height:1.65;}
.imprint-col strong{color:#e0f0e0;}
.imprint-col a{color:#ffffff;text-decoration:underline;}
.imprint-col a:hover{color:var(--accent);}