/* Light, friendly Pfälzer‑Wald theme */
:root{
  --bg:#FAF7F2;           /* warm, freundlicher Hintergrund */
  --surface:#FFFFFF;       /* Flächenfarbe */
  --card:#FFFFFF;          /* Kartenfarbe */
  --text:#243225;          /* dunkles Waldgrün für Text */
  --muted:#5e6f63;         /* gedecktes Grün‑Grau */
  --primary:#2E7D32;       /* Waldgrün */
  --primary-700:#236528;   /* dunkleres Waldgrün */
  --accent:#C6873A;        /* Holzton */
  --border:#E6EBE6;        /* dezente Kanten */
  --shadow:0 8px 24px rgba(0,0,0,.08);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
section[id]{scroll-margin-top:90px}
body{
  margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);background:var(--bg);
}
img{max-width:100%;display:block}
/* Reserve space to reduce CLS by providing width/height */
img[width][height]{height:auto}
/* Lightbox pointer */
.lb-zoomable{cursor:zoom-in;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.container{width:min(1100px,92%);margin-inline:auto}

/* Header */
.site-header{position:sticky;top:0;z-index:3000;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);pointer-events:auto}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;flex-wrap:wrap;row-gap:8px}
.logo{display:none}
.logo-heart{display:none}
.logo-icon{height:24px;width:auto;display:inline-block;margin-right:8px;vertical-align:middle}
.logo-img{display:none}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:20px;align-items:center}
.main-nav a{color:#405246;text-decoration:none;padding:8px 10px;border-radius:10px}
.main-nav a:hover{color:var(--primary);background:#F3F6F3}
/* Hide call/whatsapp buttons from main nav on very small screens to avoid overflow */
@media (max-width:680px){
  .main-nav a.btn.btn-outline[href^="tel:"],
  .main-nav a.btn.btn-whatsapp[href^="https://wa.me/"]{display:none}
}

.nav-toggle{display:none;background:none;border:0;cursor:pointer;position:relative;z-index:3500;width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;touch-action:manipulation}

/* Make header stack better on mobile */
@media (max-width:680px){
  .header-inner{gap:6px}
}
.nav-toggle .bar{display:block;width:22px;height:2px;background:#243225;margin:4px 0;border-radius:2px}

/* Hero */
.hero{position:relative;min-height:72vh;display:grid;place-items:center;text-align:center;z-index:1;contain:layout paint style}
/* Background-based hero (for detail pages) */
.hero .hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;filter:brightness(.6);pointer-events:none}
/* Image-based hero (start pages) */
.hero .hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.6);}
.hero-content{position:relative;padding:clamp(32px,5vw,56px) 0}
.hero h1{font-size:clamp(28px,4vw,48px);margin:0 0 10px;color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.35)}
.hero p{color:#f3f7f4;font-size:18px;margin:0 0 24px;text-shadow:0 1px 10px rgba(0,0,0,.35)}
.hero-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
/* Buttons dichter unter den Text (nur Mobil) */
@media (max-width:680px){
  .hero{min-height:46vh}
  .hero .hero-ctas{margin-top:8px;flex-direction:column;align-items:center}
  .hero .hero-ctas .btn{width:min(320px,92%);justify-content:center}
  .section{padding:44px 0}
  /* Ersten Abschnitt (About) oben extra kompakt */
  .section:first-of-type{padding-top:24px}
}
@media (max-width:520px){
  .hero{min-height:42vh}
  .section{padding:36px 0}
  .section:first-of-type{padding-top:22px}
}
@media (max-width:680px){
  .hero h1{font-size:26px;margin-bottom:6px}
  .hero p{font-size:16px;margin-bottom:12px}
}
@media (max-width:520px){
  .hero h1{font-size:24px;margin-bottom:6px}
  .hero p{font-size:14.5px;margin-bottom:10px}
  .hero-ctas{gap:8px}
  .hero-ctas .btn{padding:9px 12px}
}

/* SEO: Fokus‑Stile für Tastatur-Nutzer */
:focus-visible{outline:3px solid #88C999;outline-offset:2px}

/* Sections */
.section{padding:72px 0}
.section h2{font-size:clamp(24px,3vw,36px);margin:0 0 14px;color:#203120}
.section p{color:var(--muted)}
.grid{display:grid;gap:28px}
.grid.two{grid-template-columns:repeat(2,1fr)}
.grid.four{grid-template-columns:repeat(4,1fr)}
.grid.five{grid-template-columns:repeat(5,1fr)}
@media (max-width:1000px){
  .grid.five{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:800px){
  .grid.two{grid-template-columns:1fr}
  .grid.four{grid-template-columns:repeat(2,1fr)}
  .grid.five{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:520px){
  .grid.four,.grid.five{grid-template-columns:1fr}
}

/* Room list (groß, untereinander) */
.room-list{display:flex;flex-direction:column;gap:36px;margin-top:18px}
.room-item{display:grid;grid-template-columns:360px 1fr;gap:24px;align-items:center;padding:18px;border-radius:18px;border-left:6px solid var(--primary);scroll-margin-top:80px}
.room-item .room-media img{width:100%;height:260px;object-fit:cover;border-radius:14px}
.room-item .room-content h3{margin:0 0 8px;font-size:clamp(20px,2.4vw,28px);color:#203120}
.room-item .room-content p{margin:0 0 12px}
.room-cta{display:flex;gap:10px;flex-wrap:wrap}

/* Visuelle Abgrenzung der Zimmer beim Scrollen */
.room-item{position:relative}
.room-item:nth-of-type(even){border-left-color:var(--accent);background:#FBFDFB}
.room-item .room-content h3{display:inline-block;background:#F3F7F3;padding:6px 10px;border-radius:10px;border-left:4px solid var(--primary)}
.room-item:nth-of-type(even) .room-content h3{border-left-color:var(--accent);background:#FFF7EE}

@media (max-width:860px){
  .room-item{grid-template-columns:1fr}
  .room-item .room-media img{height:240px}
}

/* Cards & elements */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;content-visibility:auto;contain-intrinsic-size:1px 400px}
.card .pad{padding:18px}
.card.accent{border-color:#D9E2D9}
.card img{width:100%;height:220px;object-fit:cover}
.card-body{padding:16px 16px 18px}
.card-body h3{margin:0 0 6px}

.checklist{padding-left:0;list-style:none;margin:14px 0 0}
.checklist li{margin:8px 0;padding-left:26px;position:relative;color:var(--muted)}
.checklist li:before{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;color:var(--primary);position:absolute;left:0;top:0}

.icons .feature{text-align:center;background:var(--card);border-radius:var(--radius);padding:18px;border:1px solid var(--border);text-decoration:none;display:block;color:inherit}
.icons .feature i{font-size:28px;color:var(--primary);margin-bottom:8px}
.icons .feature h3{margin:6px 0 6px;color:#2b3f2d}
.icons .feature p{color:var(--muted);margin:0}

.gallery-grid{grid-template-columns:repeat(3,1fr)}
.gallery-grid img{border-radius:14px;border:1px solid var(--border);height:220px;object-fit:cover}
/* Für Galerien, die unbearbeitete Originalbilder ohne Zuschnitt zeigen sollen */
.gallery-grid.gallery-original img{height:auto;object-fit:contain;border:none;border-radius:0;box-shadow:none}
@media (max-width:800px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.gallery-grid{grid-template-columns:1fr}}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;border:1px solid transparent;text-decoration:none;cursor:pointer;transition:background-color .2s,color .2s}
.btn i{font-size:14px}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-700)}
.btn-light{background:#ffffff;color:#1e2b1f;border:1px solid var(--border)}
.btn-light:hover{background:#F6FAF6}
.btn-outline{color:#1f2e21;border-color:var(--border);background:#fff}
.btn-outline:hover{background:#F3F7F3}

/* Emoji-Liste im About */
.emoji-list{list-style:none;padding:0;margin:10px 0}
.emoji-list li{margin:6px 0}

/* Preislisten-Styles */
.price-list{list-style:none;padding:0;margin:10px 0 0}
.price-list li{margin:8px 0;padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff}
.price-list li strong{display:block;margin-bottom:2px;color:#203120}
.price-list .price{font-weight:700;color:var(--primary)}
.price-note{margin-top:8px;color:var(--muted);font-size:.9rem}

/* Preis-Karten Akzent */
.price-card{border-left:6px solid var(--accent);background:#FFF7EE}
.price-card h3{display:flex;align-items:center;gap:8px;margin-top:0}
.price-card h3 i{color:var(--accent)}

/* Forms */
.form{padding:18px}
.form-row{display:flex;flex-direction:column;margin-bottom:12px}
.form-row label{font-weight:600;margin-bottom:6px;color:#2b3f2d}
.form-row input,.form-row textarea{background:#fff;border:1px solid var(--border);color:var(--text);border-radius:10px;padding:10px}
.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}
@media (max-width:700px){.form-grid{grid-template-columns:1fr}}
.form-status{color:var(--accent);margin-top:10px;min-height:1.2em}

/* About layout */
.about-figure img{border-radius:14px;border:1px solid var(--border)}
.about-figure figcaption{color:var(--muted);font-size:14px;margin-top:6px}

/* FAQ */
.faq details{padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#fff;margin:8px 0}
.faq details[open]{background:#F6FAF6}
.faq summary{cursor:pointer}

/* Footer */
.site-footer{background:#243225;color:#eaf2ec;padding:28px 0;margin-top:40px}
.footer-inner{display:grid;grid-template-columns:1fr auto auto;gap:20px;align-items:center}
.site-footer nav a{color:#cfe0d4;text-decoration:none;margin-right:14px}
.site-footer nav a:hover{color:#ffffff}
.copy{color:#cfe0d4}
@media (max-width:760px){.footer-inner{grid-template-columns:1fr}}

/* Lightbox */
.lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.85);z-index:9999;padding:24px}
.lightbox.open{display:flex}
.lightbox .lb-content{position:relative;max-width:min(96vw,1200px);max-height:92vh;width:100%}
.lightbox .lb-img{display:block;max-width:100%;max-height:80vh;margin:0 auto;border-radius:10px;box-shadow:0 14px 40px rgba(0,0,0,.45)}
.lightbox .lb-caption{color:#eaeaea;text-align:center;margin-top:10px;font-size:14px}
.lightbox .lb-close{position:absolute;top:-6px;right:-6px;background:transparent;border:0;color:#fff;font-size:38px;line-height:1;cursor:pointer;padding:6px}
.lightbox .lb-prev,.lightbox .lb-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(2px);width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:26px;display:grid;place-items:center}
.lightbox .lb-prev{left:-16px}
.lightbox .lb-next{right:-16px}
@media (max-width:600px){
  .lightbox .lb-prev{left:4px}
  .lightbox .lb-next{right:4px}
}

/* Back to top button */
.back-to-top{position:fixed;right:18px;bottom:18px;z-index:999;background:rgba(36,50,37,.85);color:#fff;border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(4px);width:44px;height:44px;border-radius:22px;display:grid;place-items:center;box-shadow:var(--shadow);opacity:0;transform:translateY(12px);transition:opacity .2s ease, transform .2s ease;pointer-events:none}
.back-to-top:hover{background:rgba(36,50,37,.95)}
.back-to-top.show{opacity:1;transform:translateY(0);pointer-events:auto}

/* WhatsApp Button */
.btn-whatsapp{background:#25D366;color:#fff;border:1px solid transparent}
.btn-whatsapp:hover{background:#1ebe57}
.phone-fab{position:fixed;right:18px;bottom:134px;z-index:999;background:#1e2b1f;color:#fff;border:1px solid rgba(0,0,0,.08);width:52px;height:52px;border-radius:26px;display:grid;place-items:center;box-shadow:var(--shadow);cursor:pointer}
.phone-fab:hover{background:#0f1711}
.phone-fab i{font-size:22px}
.whatsapp-fab{position:fixed;right:18px;bottom:76px;z-index:999;background:#25D366;color:#fff;border:1px solid rgba(0,0,0,.08);width:52px;height:52px;border-radius:26px;display:grid;place-items:center;box-shadow:var(--shadow);cursor:pointer}
.whatsapp-fab:hover{background:#1ebe57}
.whatsapp-fab i{font-size:24px}
/* Language switch */
.lang-switch{font-size:14px;color:var(--muted)}
/* Reduce expensive shadow on mobile and make header paint cheaper */
@media (max-width:680px){
  .site-header{backdrop-filter:none;will-change:auto}
}
.lang-switch a{color:inherit;text-decoration:none;padding:6px 8px;border-radius:8px}
.lang-switch a[aria-current="page"], .lang-switch a:hover{background:#F3F7F3;color:var(--primary);font-weight:600}
/* Place language switch in header, right side */
.header-inner .lang-switch{margin-left:auto;margin-right:96px;display:flex;gap:10px;align-items:center;white-space:nowrap;max-width:100%}
/* Sprachbereich immer über Menüs (Z-Index) */
.header-inner .lang-switch{position:relative;z-index:3600}
/* Sicherstellen, dass Sprachlinks nie hinter dem Burger verschwinden */
.header-inner .lang-switch a[hreflang]{display:inline-flex}
/* kurze Button-Texte mobil */
@media (max-width:680px){
  .lang-switch .btn .btn-text{display:none}
  .lang-switch .btn .btn-text-short{display:inline}
}
@media (min-width:681px){
  .lang-switch .btn .btn-text{display:inline}
  .lang-switch .btn .btn-text-short{display:none}
}
.header-inner .lang-switch .fi{margin-right:6px;box-shadow:0 0 0 1px rgba(0,0,0,.06);border-radius:3px}
/* Auf sehr kleinen Geräten: Sprach-Links umbrechen auf eigene Zeile */
@media (max-width:480px){
  .header-inner .lang-switch{gap:6px}
  .header-inner .lang-switch::after{content:"";flex-basis:100%}
  .header-inner .lang-switch a[hreflang]{order:1}
}
@media (max-width:900px){.header-inner .lang-switch{font-size:13px;margin-right:48px;gap:8px;flex:1 1 auto;min-width:0}}







/* Mobile: Platz schaffen für Sprach-Icons */
@media (max-width:680px){
  /* Grid-Layout für Header: Burger links, Menü rechts, Sprachbereich darunter über gesamte Breite */
  .header-inner{display:grid;grid-template-columns:auto 1fr;align-items:center;justify-content:unset;row-gap:6px}
  .nav-toggle{grid-column:1;grid-row:1}
  .main-nav{grid-column:2;grid-row:1}
  .header-inner .lang-switch{grid-column:1 / -1;grid-row:2;margin:4px 0 0;margin-right:0;margin-left:0;gap:6px;flex-wrap:wrap;white-space:normal;justify-content:flex-start;font-size:0}
  /* Sprachlinks zuerst (oben) */
  .header-inner .lang-switch a[hreflang]{order:1;padding:4px 6px;font-size:13px;display:inline-flex}
  /* Zeilenumbruch nach den Sprachlinks */
  .header-inner .lang-switch::after{content:"";order:2;flex-basis:100%}
  /* Buttons (Telefon + WhatsApp) darunter */
  .header-inner .lang-switch .btn{order:3;display:inline-flex;font-size:13px;padding:8px 10px}
  .header-inner .lang-switch .btn .btn-text,.header-inner .lang-switch .btn .btn-text-short{font-size:13px}
  .header-inner .lang-switch .fi{margin-right:4px}
}

/* Sehr kleine Geräte: Telefon/WhatsApp-Buttons im Header ausblenden, FABs bleiben */
@media (max-width:520px){
  .header-inner .lang-switch .btn{display:none}
}

/* Mobile: Hero-Content dichter an den oberen Rand */
@media (max-width:680px){
  /* Textblock im Hero ganz nach oben setzen */
  .hero{place-items:start center}
  .hero-content{padding:8px 0 10px}
}
@media (max-width:520px){
  .hero-content{padding:12px 0 22px}
}

/* Reserve Platz, damit der FAB den Back-to-top-Button nicht überlappt */
@media (max-width:680px){
  .back-to-top{bottom:138px}
  .phone-fab{bottom:76px}
  .whatsapp-fab{bottom:18px}
}

/* Cookie banner */
.cookie-banner{position:fixed;left:50%;bottom:14px;transform:translateX(-50%);z-index:10000;background:#ffffff;border:1px solid var(--border);box-shadow:var(--shadow);border-radius:14px;padding:14px;max-width:min(1100px,92%);display:none;align-items:center;gap:12px}
.cookie-banner.show{display:flex}
.cookie-banner p{margin:0;color:var(--muted)}
.cookie-actions{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
.cookie-actions .btn{padding:8px 12px}
.cookie-actions .btn-outline{background:#fff}

/* Header menu responsive */
@media (max-width:900px){
  .nav-toggle{display:block}
  .main-nav ul{position:absolute;right:4%;top:64px;background:#ffffff;border:1px solid var(--border);border-radius:12px;padding:12px;display:none;flex-direction:column;gap:10px;width:min(260px,90vw);box-shadow:var(--shadow);z-index:3500}
  .main-nav ul.show{display:flex}
}

/* Ensure anchors are not hidden behind sticky header on small screens */
@media (max-width:900px){
  section[id]{scroll-margin-top:110px}
}
