:root {
  --primary: #79dbbf;
  --primary-dark: #2a8870;
  --primary-light: #a8e8d4;
  --accent: #e89b6c;
  --accent-dark: #c47545;
  --bg: #faf8f4;
  --bg-alt: #eef7f3;
  --text: #2c2c2c;
  --text-light: #5a5a5a;
  --white: #fff;
  --shadow: 0 2px 8px rgba(0,0,0,.08);
  --shadow-lg: 0 8px 24px rgba(0,0,0,.12);
  --radius: 8px;
  --radius-lg: 16px;
  --transition: .25s ease;
  --max-width: 1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;-webkit-tap-highlight-color:transparent;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
button,a{-webkit-tap-highlight-color:rgba(121,219,191,.2)}
input,textarea,select{font-family:inherit}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none;transition:color var(--transition)}
a:hover,a:focus{color:var(--accent-dark)}

/* HEADER */
.site-header{background:var(--white);box-shadow:var(--shadow);position:sticky;top:0;z-index:100;padding-top:env(safe-area-inset-top);overflow:hidden;}
.header-inner{max-width:var(--max-width);margin:0 auto;padding:.75rem 1.25rem;padding-left:max(1.25rem,env(safe-area-inset-left));padding-right:max(14.25rem,env(safe-area-inset-right));display:flex;align-items:center;justify-content:space-between;gap:1rem}
.logo-link{display:flex;align-items:center;flex-shrink:0}
.logo-link img{height:60px;width:auto;transform:scale(4.8) translateX(-10px) translateY(2px);transform-origin: left center; position:relative; z-index:1;}
.header-right{display:flex;align-items:center;gap:.75rem}
.main-nav ul{display:flex;list-style:none;gap:.1rem;flex-wrap:nowrap}
.main-nav a{display:block;padding:.55rem .7rem;color:var(--text);font-weight:500;border-radius:var(--radius);transition:all var(--transition);white-space:nowrap;font-size:.95rem}
.main-nav a:hover,.main-nav a:focus,.main-nav a.active{background:var(--primary-dark);color:var(--white)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.menu-toggle span{display:block;width:28px;height:3px;background:var(--primary);border-radius:2px;transition:transform var(--transition),opacity var(--transition)}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* LANG */
.lang-switcher{position:relative}
.lang-btn{background:var(--bg-alt);border:1px solid transparent;padding:.45rem .75rem;border-radius:var(--radius);cursor:pointer;font-size:.9rem;font-weight:500;color:var(--text);display:flex;align-items:center;gap:.4rem;transition:all var(--transition)}
.lang-btn:hover{background:var(--primary-dark);color:var(--white)}
.lang-menu{display:none;position:absolute;top:calc(100% + .5rem);right:0;background:var(--white);box-shadow:var(--shadow-lg);border-radius:var(--radius);list-style:none;padding:.35rem;min-width:160px;z-index:50}
.lang-menu.open{display:block}
.lang-menu a{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;color:var(--text);border-radius:var(--radius);font-size:.9rem}
.lang-menu a:hover{background:var(--bg-alt)}
.flag{display:inline-block;width:1.4em;height:1em;flex-shrink:0;border-radius:2px;box-shadow:0 0 0 1px rgba(0,0,0,.08);vertical-align:middle;overflow:hidden}
.flag svg{width:100%;height:100%;display:block}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius);font-weight:600;text-decoration:none;cursor:pointer;border:none;transition:all var(--transition);font-size:1rem;font-family:inherit}
.btn-primary{background:var(--accent);color:var(--white)}
.btn-primary:hover,.btn-primary:focus{background:var(--accent-dark);color:var(--white);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-outline{background:transparent;color:var(--white);border:2px solid var(--white)}
.btn-outline:hover{background:var(--white);color:var(--primary-dark)}
.btn-whatsapp{background:#25d366;color:var(--white)}
.btn-whatsapp:hover{background:#1eac52;color:var(--white)}
.btn-secondary{background:var(--primary-dark);color:var(--white)}
.btn-secondary:hover{background:var(--primary-dark);color:var(--white);opacity:.9}
.btn-sm{padding:.5rem 1rem;font-size:.9rem}
.btn-group{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}

/* HERO */
.hero{background:linear-gradient(rgba(42,136,112,.6),rgba(42,136,112,.6)),url("../images/umgebung.jpg") center/cover no-repeat;color:var(--white);padding:5rem 1.25rem;text-align:center}
.hero.root-hero{background-image:linear-gradient(rgba(42,136,112,.6),rgba(42,136,112,.6)),url("images/umgebung.jpg")}
.hero-inner{max-width:900px;margin:0 auto}
.hero h1{font-size:clamp(1.75rem,4vw,3rem);margin-bottom:1rem;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.3);color:var(--white)}
.hero p{font-size:clamp(1rem,2vw,1.25rem);max-width:700px;margin:0 auto 1.5rem;text-shadow:0 1px 4px rgba(0,0,0,.3)}

/* MAIN */
main{flex:1;width:100%}
.section{max-width:var(--max-width);margin:0 auto;padding:3rem 1.25rem;position:relative;z-index:2;}
.section-alt{background:var(--bg-alt)}
.section-alt h3{margin-top:1.75rem;color:var(--primary-dark)}
h1,h2,h3,h4{color:var(--primary-dark);line-height:1.25;margin-bottom:1rem}
h1{font-size:clamp(1.75rem,4vw,2.5rem)}
h2{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:1.25rem;padding-bottom:.5rem}
h2::after{content:"";display:block;width:60px;height:3px;background:var(--accent);margin-top:.5rem;border-radius:2px}
h3{font-size:clamp(1.25rem,2.5vw,1.5rem)}
h4{font-size:1.1rem;color:var(--text-light);font-weight:500}
p{margin-bottom:1rem}
strong{color:var(--primary-dark);font-weight:600}
.text-center{text-align:center}

/* CARDS */
.grid-two{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;align-items:center}
.card{background:var(--white);padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card ul{list-style:none;padding:0;margin:1rem 0}
.card li{padding:.5rem 0;padding-left:1.75rem;position:relative;border-bottom:1px solid var(--bg-alt)}
.card li:last-child{border-bottom:none}
.card li::before{content:"✓";position:absolute;left:0;color:var(--accent-dark);font-weight:bold;font-size:1.1rem}
.rounded-img{border-radius:var(--radius-lg);box-shadow:var(--shadow);width:100%}
.info-box{background:var(--white);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);border-left:4px solid var(--accent);margin-bottom:1rem}

/* HIGHLIGHTS */
.highlights{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:2rem}
.highlight{background:var(--white);padding:2rem 1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow);text-align:center;transition:transform var(--transition)}
.highlight:hover{transform:translateY(-4px)}
.highlight-icon{display:flex;align-items:center;justify-content:center;width:60px;height:60px;margin:0 auto .85rem;background:var(--bg-alt);border-radius:50%;color:var(--primary-dark)}
.highlight-icon svg{width:30px;height:30px}
.highlight h3{font-size:1.15rem;margin-bottom:.5rem}
.highlight p{font-size:.95rem;color:var(--text-light);margin:0}

/* AMENITIES */
.amenities{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1rem;margin:1.5rem 0}
.amenity{background:var(--bg);padding:1rem .75rem;border-radius:var(--radius);text-align:center;border:1px solid var(--bg-alt);transition:all var(--transition)}
.amenity:hover{background:var(--white);border-color:var(--accent);transform:translateY(-2px)}
.amenity-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;margin:0 auto .35rem;color:var(--primary-dark)}
.amenity-icon svg{width:24px;height:24px}
.amenity-label{font-size:.85rem;color:var(--text);font-weight:500}

/* PRICE TABLE */
.price-table-wrapper{overflow-x:auto;margin:2rem 0;border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.price-table{width:100%;border-collapse:collapse;background:var(--white);min-width:500px}
.price-table th,.price-table td{padding:1rem 1.25rem;text-align:left;border-bottom:1px solid var(--bg-alt)}
.price-table th{background:var(--primary-dark);color:var(--white);font-weight:600}
.price-table tr:last-child td{border-bottom:none}
.price-table tr:hover td{background:var(--bg-alt)}
.price-note{background:var(--white);padding:1.25rem 1.5rem;border-left:4px solid var(--accent);border-radius:var(--radius);margin-top:1rem;box-shadow:var(--shadow)}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-top:2rem}
.contact-card{background:var(--white);padding:1.75rem;border-radius:var(--radius-lg);box-shadow:var(--shadow);text-align:center;transition:transform var(--transition)}
.contact-card:hover{transform:translateY(-3px)}
.contact-card .icon{display:flex;align-items:center;justify-content:center;width:60px;height:60px;margin:0 auto .85rem;background:var(--bg-alt);border-radius:50%;color:var(--primary-dark)}
.contact-card .icon svg{width:30px;height:30px}
.contact-card h3{margin-bottom:.5rem;font-size:1.15rem}
.contact-card a{word-break:break-word}

/* BOOKING PLATFORMS */
.booking-platforms{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-top:2rem}
.platform-card{background:var(--white);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow);text-align:center;transition:transform var(--transition),box-shadow var(--transition);display:flex;flex-direction:column;align-items:center}
.platform-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.platform-logo{display:flex;align-items:center;justify-content:center;width:90px;height:90px;border-radius:50%;margin-bottom:1.25rem;font-size:2rem;font-weight:700;color:var(--white);letter-spacing:-1px}
.platform-card.airbnb .platform-logo{background:linear-gradient(135deg,#ff5a5f,#e74c3c)}
.platform-card.booking .platform-logo{background:linear-gradient(135deg,#003580,#0071c2)}
.platform-card h2{font-size:1.5rem;margin-bottom:.5rem;color:var(--text)}
.platform-card .platform-tag{display:inline-block;background:var(--bg-alt);padding:.25rem .75rem;border-radius:99px;font-size:.8rem;color:var(--text-light);margin-bottom:1rem;font-weight:500}
.platform-card .platform-tag.coming-soon{background:#fef3cd;color:#856404}
.platform-card > p{color:var(--text-light);margin-bottom:1.5rem;line-height:1.6;flex-grow:1}
.platform-card .btn{margin-top:auto;width:100%;justify-content:center;padding:1rem 1.5rem;font-size:1.05rem}
.platform-card.airbnb .btn-platform{background:#ff5a5f;color:var(--white)}
.platform-card.airbnb .btn-platform:hover{background:#e74c3c;color:var(--white);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.platform-card.booking .btn-platform{background:#003580;color:var(--white)}
.platform-card.booking .btn-platform:hover{background:#0071c2;color:var(--white);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.platform-card .btn-platform.disabled{background:#ccc!important;cursor:not-allowed;pointer-events:none;opacity:.7}
.booking-info{background:var(--bg-alt);border-radius:var(--radius);padding:1.5rem;margin-top:2.5rem;text-align:center}
.booking-info p{margin:0;color:var(--text)}
.booking-info a{color:var(--primary-dark);font-weight:600}

/* GALLERY CATEGORIES */
.gallery-categories{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;margin-top:2rem}
.category-card{position:relative;display:block;aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;text-decoration:none;color:var(--white);box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition);background:var(--bg-alt)}
.category-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);color:var(--white)}
.category-card .category-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:1}
.category-card .category-fallback{position:absolute;inset:0;display:none;align-items:center;justify-content:center;color:var(--text-light);font-size:.9rem;font-style:italic;padding:1rem;text-align:center;background:linear-gradient(135deg,#eef7f3,#d4ebe1);border:2px dashed var(--primary-light);box-sizing:border-box;line-height:1.4;z-index:1}
.category-card.missing .category-bg{display:none}
.category-card.missing .category-fallback{display:flex}
.category-card .category-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.3) 50%,rgba(0,0,0,.1) 100%);z-index:2}
.category-card.missing .category-overlay{background:linear-gradient(to top,rgba(0,0,0,.4) 0%,rgba(0,0,0,.15) 60%,transparent 100%)}
.category-card .category-content{position:absolute;left:0;right:0;bottom:0;padding:1.5rem;z-index:3;text-align:left}
.category-card .category-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;background:rgba(255,255,255,.95);border-radius:50%;color:var(--primary-dark);margin-bottom:.75rem;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.category-card .category-icon svg{width:26px;height:26px}
.category-card h2{color:var(--white);margin:0 0 .25rem;font-size:1.5rem;text-shadow:0 2px 6px rgba(0,0,0,.5)}
.category-card .category-count{color:rgba(255,255,255,.95);font-size:.9rem;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.category-back{display:inline-flex;align-items:center;gap:.5rem;color:var(--primary-dark);text-decoration:none;margin-bottom:1.5rem;font-weight:500}
.category-back:hover{color:var(--accent-dark)}
.category-back svg{width:18px;height:18px;fill:currentColor}

/* TRAVEL OPTIONS (Anfahrt) */
.travel-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem;margin-top:2rem}
.travel-card{background:var(--white);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition);border-top:4px solid var(--primary)}
.travel-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.travel-card .travel-icon{display:flex;align-items:center;justify-content:center;width:54px;height:54px;background:var(--bg-alt);border-radius:50%;color:var(--primary-dark);margin-bottom:1rem}
.travel-card .travel-icon svg{width:30px;height:30px}
.travel-card h3{margin-bottom:.5rem;color:var(--primary-dark)}
.travel-card .travel-meta{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-light);margin:.5rem 0;flex-wrap:wrap}
.travel-card .travel-meta span{display:inline-flex;align-items:center;gap:.25rem;background:var(--bg-alt);padding:.25rem .65rem;border-radius:99px}
.travel-card .travel-meta svg{width:14px;height:14px;fill:currentColor}
.travel-card p{margin:.5rem 0;font-size:.95rem;line-height:1.6}
.travel-tip{background:var(--bg-alt);border-left:3px solid var(--accent);padding:.65rem .85rem;margin-top:.85rem;border-radius:var(--radius);font-size:.85rem}

/* ACTIVITIES */
.activity-section{margin-top:2.5rem}
.activity-section > h2{display:flex;align-items:center;gap:.75rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary-light)}
.activity-section > h2 .section-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;background:var(--primary);border-radius:50%;color:var(--white);flex-shrink:0}
.activity-section > h2 .section-icon svg{width:24px;height:24px}
.activity-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;margin-top:1.25rem}
.activity-item{background:var(--white);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow);transition:transform var(--transition)}
.activity-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.activity-item h3{margin-bottom:.4rem;color:var(--primary-dark);font-size:1.15rem}
.activity-item .activity-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin:.5rem 0}
.activity-item .tag{display:inline-flex;align-items:center;gap:.25rem;background:var(--bg-alt);padding:.2rem .6rem;border-radius:99px;font-size:.78rem;color:var(--text-light)}
.activity-item .tag svg{width:12px;height:12px;fill:currentColor}
.activity-item .tag.diff-easy{background:#d1f5e0;color:#1c6e3a}
.activity-item .tag.diff-medium{background:#fff3cd;color:#856404}
.activity-item .tag.diff-hard{background:#f8d7da;color:#721c24}
.activity-item p{margin:.5rem 0;font-size:.92rem;line-height:1.55;color:var(--text)}
.activity-item .activity-link{display:inline-flex;align-items:center;gap:.35rem;color:var(--primary-dark);text-decoration:none;font-weight:500;font-size:.9rem;margin-top:.5rem}
.activity-item .activity-link:hover{color:var(--accent-dark)}
.activity-item .activity-link svg{width:14px;height:14px;fill:currentColor}

/* CALENDAR */
.calendar-section{background:var(--white);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow);margin-top:2.5rem}
.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}
.calendar-title{font-size:1.25rem;color:var(--primary-dark);margin:0;display:flex;align-items:center;gap:.5rem}
.calendar-title svg{width:24px;height:24px;fill:currentColor}
.calendar-nav{display:flex;gap:.5rem;align-items:center}
.calendar-nav button{background:var(--bg-alt);border:none;width:36px;height:36px;border-radius:var(--radius);cursor:pointer;font-size:1.2rem;color:var(--primary-dark);transition:background var(--transition);display:flex;align-items:center;justify-content:center}
.calendar-nav button:hover{background:var(--primary-light)}
.calendar-nav button:disabled{opacity:.4;cursor:not-allowed}
.calendar-month-label{font-weight:600;color:var(--primary-dark);margin:0 .75rem;min-width:140px;text-align:center}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-top:.5rem}
.calendar-weekday{padding:.5rem;text-align:center;font-size:.8rem;font-weight:600;color:var(--text-light);text-transform:uppercase}
.calendar-day{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;background:var(--bg-alt);border-radius:6px;font-size:.9rem;color:var(--text);position:relative}
.calendar-day.empty{background:transparent}
.calendar-day.today{font-weight:700;color:var(--primary-dark);outline:2px solid var(--primary);outline-offset:-2px}
.calendar-day.past{opacity:.4}
.calendar-day.booked{background:#f8d7da;color:#721c24;text-decoration:line-through}
.calendar-day.available{background:#d1f5e0;color:#1c6e3a;font-weight:500}
.calendar-legend{display:flex;gap:1.25rem;justify-content:center;margin-top:1rem;flex-wrap:wrap;font-size:.85rem}
.calendar-legend span{display:inline-flex;align-items:center;gap:.4rem}
.calendar-legend .swatch{width:14px;height:14px;border-radius:3px;display:inline-block}
.calendar-loading,.calendar-error{text-align:center;padding:2rem;color:var(--text-light);font-style:italic}
.calendar-tabs{display:flex;gap:.25rem;margin-bottom:1rem;background:var(--bg-alt);border-radius:var(--radius);padding:.25rem}
.calendar-tab{flex:1;padding:.5rem .75rem;background:transparent;border:none;border-radius:calc(var(--radius) - 2px);cursor:pointer;font-size:.9rem;color:var(--text);font-weight:500;transition:all var(--transition)}
.calendar-tab.active{background:var(--white);color:var(--primary-dark);box-shadow:var(--shadow)}

/* LEGAL DOCUMENTS - kompakter */
.legal-section{max-width:900px;margin:0 auto}
.legal-section h2{margin-top:2rem;color:var(--primary-dark);font-size:1.3rem}
.legal-section h3{margin-top:1.5rem;font-size:1.1rem}
.legal-section ul{margin-left:1.5rem;margin-bottom:1rem;line-height:1.7}
.legal-section li{margin-bottom:.35rem}

/* MAP */
.map-wrapper{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);margin-top:2rem;aspect-ratio:16/9;min-height:300px;position:relative}
.map-wrapper iframe{width:100%;height:100%;border:0;display:block}
.map-consent{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1.5rem;background:linear-gradient(135deg,#eef7f3,#d4ebe1);color:var(--text)}
.map-consent svg{width:48px;height:48px;color:var(--primary-dark);margin-bottom:.75rem;fill:currentColor}
.map-consent h3{margin-bottom:.5rem;font-size:1.1rem}
.map-consent p{font-size:.9rem;max-width:480px;margin-bottom:1rem;color:var(--text-light)}
.map-consent .btn{margin-top:.5rem}
.map-consent details{margin-top:.75rem;font-size:.8rem;color:var(--text-light);max-width:480px}
.map-consent summary{cursor:pointer;text-decoration:underline}
.map-wrapper.loaded .map-consent{display:none}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;margin-top:1.5rem}
.gallery-item{position:relative;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;cursor:pointer;background:var(--bg-alt);transition:transform var(--transition)}
.gallery-item:hover{transform:scale(1.03)}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block}
/* Fallback: image broken/missing → show caption nicely */
.gallery-item .img-fallback{display:none;position:absolute;inset:0;align-items:center;justify-content:center;color:var(--text-light);font-size:.9rem;font-style:italic;padding:1rem;text-align:center;background:linear-gradient(135deg,#eef7f3,#d4ebe1);border:2px dashed var(--primary-light);border-radius:var(--radius);box-sizing:border-box;line-height:1.4}
.gallery-item.missing img{display:none}
.gallery-item.missing .img-fallback{display:flex}
.gallery-item.missing{cursor:default}
.gallery-item.missing:hover{transform:none}
.gallery-placeholder{display:flex;align-items:center;justify-content:center;color:var(--text-light);font-style:italic;font-size:.9rem;padding:1rem;text-align:center;height:100%}
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;align-items:center;justify-content:center;padding:2rem}
.lightbox.open{display:flex}
.lightbox img{max-width:95%;max-height:90vh;border-radius:var(--radius)}
.lightbox-close{position:absolute;top:1rem;right:1.5rem;background:none;border:none;color:var(--white);font-size:2.5rem;cursor:pointer;line-height:1;z-index:2}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);border:none;color:var(--white);font-size:2.5rem;cursor:pointer;width:50px;height:60px;border-radius:var(--radius);transition:background var(--transition);z-index:2}
.lightbox-nav:hover{background:rgba(255,255,255,.3)}
.lightbox-prev{left:1rem}
.lightbox-next{right:1rem}
.lightbox-caption{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.7);color:var(--white);padding:.5rem 1rem;border-radius:var(--radius);font-size:.95rem;max-width:90%;text-align:center;z-index:2}

/* FAQ */
.faq-list{margin-top:1.5rem}
.faq-item{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:.75rem;overflow:hidden;transition:box-shadow .2s ease}
/* :has() nur als Progressive Enhancement - Basis funktioniert auch ohne */
@supports selector(:has(*)){
  .faq-item:has(.faq-question[aria-expanded="true"]){box-shadow:var(--shadow-lg)}
}
.faq-question{width:100%;padding:1.1rem 1.25rem;background:none;border:none;text-align:left;font-size:1.05rem;font-weight:600;color:var(--primary-dark);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-family:inherit;transition:background .2s ease,color .2s ease}
.faq-question:hover{background:var(--bg-alt)}
.faq-question:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}
.faq-question::after{content:"+";font-size:1.6rem;color:var(--accent-dark);transition:transform .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;width:1.5rem;text-align:center;line-height:1}
.faq-question[aria-expanded="true"]::after{transform:rotate(45deg)}
.faq-question[aria-expanded="true"]{color:var(--primary-dark)}
/* Fallback für ältere Browser (Safari <16, Chrome <107): max-height */
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.4,0,.2,1)}
.faq-answer.open{max-height:600px}
.faq-answer > div{min-height:0}
.faq-answer p{margin:0;padding:0 1.25rem 1.1rem;color:var(--text);line-height:1.65}
/* Moderne Browser: sanftere grid-Animation (überschreibt max-height) */
@supports (grid-template-rows:0fr){
  .faq-answer{display:grid;grid-template-rows:0fr;max-height:none;transition:grid-template-rows .3s cubic-bezier(.4,0,.2,1)}
  .faq-answer.open{grid-template-rows:1fr;max-height:none}
  .faq-answer > div{overflow:hidden}
}

/* TESTIMONIALS */
.testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}
.testimonial{background:var(--white);padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow);position:relative}
.testimonial::before{content:"\201C";position:absolute;top:.5rem;left:1rem;font-size:4rem;color:var(--accent);opacity:.3;font-family:Georgia,serif;line-height:1}
.testimonial-text{font-style:italic;color:var(--text);margin-bottom:1rem;position:relative;z-index:1}
.testimonial-author{font-weight:600;color:var(--primary-dark);font-size:.95rem}
.testimonial-stars{display:flex;gap:.15rem;color:var(--accent-dark);margin-bottom:.5rem}
.testimonial-stars svg{width:18px;height:18px;fill:currentColor}

/* ATTRACTIONS */
.attractions{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-top:2rem}
.attraction{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:transform var(--transition)}
.attraction:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.attraction-img{aspect-ratio:16/10;background:var(--bg-alt) center/cover no-repeat;position:relative;overflow:hidden}
.attraction-img img{width:100%;height:100%;object-fit:cover;display:block}
.attraction-img .img-fallback{display:none;position:absolute;inset:0;align-items:center;justify-content:center;color:var(--text-light);font-size:.95rem;font-style:italic;padding:1rem;text-align:center;background:linear-gradient(135deg,#eef7f3,#d4ebe1);border-bottom:2px dashed var(--primary-light);box-sizing:border-box;line-height:1.4}
.attraction-img.missing img{display:none}
.attraction-img.missing .img-fallback{display:flex}
.attraction-body{padding:1.25rem}
.attraction h3{font-size:1.2rem;margin-bottom:.5rem}
.attraction-meta{display:flex;gap:1rem;font-size:.85rem;color:var(--text-light);margin-top:.5rem;flex-wrap:wrap}
.attraction-meta span{display:flex;align-items:center;gap:.35rem}
.attraction-meta svg{width:14px;height:14px;flex-shrink:0;fill:currentColor}

/* WEATHER */
.weather-widget{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:var(--white);padding:1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex;align-items:center;gap:1.25rem;margin-top:1.5rem;flex-wrap:wrap;justify-content:center;text-align:center}
.weather-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;color:var(--white)}
.weather-icon svg{width:54px;height:54px}
.spinner{animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.weather-info h3{color:var(--white);margin:0 0 .25rem;font-size:1.1rem}
.weather-info p{margin:0;opacity:.95;font-size:.9rem}
.weather-temp{font-size:2.5rem;font-weight:700}

/* IMPRESSUM */
.impressum-box{background:var(--white);padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow);max-width:700px;margin:1.5rem auto 0}
.impressum-box p{margin-bottom:1.5rem}
.impressum-box p:last-child{margin-bottom:0}
.impressum-box h2{font-size:1.25rem;margin-top:1.5rem;margin-bottom:.75rem}
.impressum-box h2:first-child{margin-top:0}

/* FOOTER */
.site-footer{background:var(--primary-dark);color:var(--white);padding:2rem 1.25rem 1rem;padding-left:max(1.25rem,env(safe-area-inset-left));padding-right:max(1.25rem,env(safe-area-inset-right));padding-bottom:max(1rem,env(safe-area-inset-bottom));margin-top:auto}
.footer-inner{max-width:var(--max-width);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:1.5rem}
.footer-col h4{color:var(--white);margin-bottom:.75rem;font-size:1rem}
.footer-col ul{list-style:none;padding:0}
.footer-col li{margin-bottom:.35rem;display:flex;align-items:flex-start;gap:.5rem}
.footer-col li svg{width:14px;height:14px;flex-shrink:0;margin-top:.3rem;fill:currentColor;opacity:.85}
.footer-col li > a{display:flex;align-items:center;gap:.5rem}
.footer-col a{color:rgba(255,255,255,.8)}
.footer-col a:hover{color:var(--accent)}
.btn svg{width:1.1em;height:1.1em;fill:currentColor;flex-shrink:0}
.footer-bottom{text-align:center;padding-top:1rem;border-top:1px solid rgba(255,255,255,.15);font-size:.9rem;opacity:.8}

/* SOCIAL ICONS */
.social-links{display:flex;gap:.6rem;margin-top:.5rem;flex-wrap:wrap}
.social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:rgba(255,255,255,.1);border-radius:50%;color:var(--white);transition:all var(--transition)}
.social-link svg{width:20px;height:20px;fill:currentColor;display:block}
.social-link:hover{background:var(--accent);color:var(--primary-dark);transform:translateY(-2px)}
.social-link.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}

/* ALERTS */
.alert{padding:1rem 1.25rem;border-radius:var(--radius);margin-bottom:1rem}
.alert-info{background:#e5f0f5;color:#1e5a75;border-left:4px solid #1e5a75}
.alert-info code{background:rgba(0,0,0,.05);padding:.1rem .3rem;border-radius:3px;font-size:.85em}

/* RESPONSIVE - TABLET (≤1150px) */
@media (max-width:1150px){
  .menu-toggle{display:flex;flex-direction:column;align-items:center;justify-content:center;order:3;width:44px;height:44px}
  .header-inner{position:relative;padding:.75rem 1rem;flex-wrap:nowrap;gap:.5rem}
  .logo-link{order:1;flex-shrink:1;min-width:0}
  .logo-link img{height:50px;width:auto;max-width:100%}
  .header-right{order:2;flex:0 0 auto;gap:.35rem;margin-left:auto}
  .header-right .main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--white);box-shadow:var(--shadow-lg);padding:1rem 1.25rem;border-top:1px solid var(--bg-alt);max-height:calc(100vh - 80px);overflow-y:auto;-webkit-overflow-scrolling:touch}
  .header-right .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:.25rem}
  .main-nav a{display:flex;align-items:center;padding:.85rem 1rem;min-height:44px}
  .lang-menu{right:0}
  .hero{padding:3.5rem 1rem;min-height:auto}
  .hero h1{font-size:2rem;line-height:1.2}
  .hero p{font-size:1.05rem}
  .section{padding:2.25rem 1rem}
  .lang-btn{padding:.4rem .55rem;font-size:.85rem;min-height:40px}
  .grid-two{grid-template-columns:1fr;gap:1.5rem}
  .testimonials{grid-template-columns:1fr}
  h1{font-size:1.85rem;line-height:1.2}
  h2{font-size:1.45rem;line-height:1.3}
  h3{font-size:1.2rem}
  .gallery{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem}
  .booking-platforms{grid-template-columns:1fr;gap:1rem}
  .gallery-categories{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}
}

/* RESPONSIVE - PHONE (≤640px) */
@media (max-width:640px){
  body{font-size:16px}
  .header-inner{padding:.6rem .75rem}
  .logo-link img{height:42px}
  .menu-toggle{padding:.5rem;min-width:44px;min-height:44px}
  .hero{padding:2.5rem .85rem}
  .hero h1{font-size:1.65rem}
  .hero p{font-size:.95rem}
  .section{padding:1.75rem .85rem}
  h1{font-size:1.65rem}
  h2{font-size:1.3rem;margin-top:1.5rem}
  h3{font-size:1.1rem}
  p{line-height:1.65}
  .btn{padding:.85rem 1.25rem;font-size:.95rem;min-height:48px}
  .btn-sm{padding:.6rem 1rem;min-height:40px}
  .btn-group{gap:.6rem;width:100%}
  .btn-group .btn{flex:1 1 100%}
  .hero .btn-group{flex-direction:column;align-items:stretch;max-width:320px;margin:1.5rem auto 0}
  .hero .btn-group .btn{width:100%;justify-content:center}
  .card{padding:1.25rem 1rem}
  .amenities{grid-template-columns:repeat(2,1fr);gap:.75rem}
  .amenity{padding:.85rem .5rem;font-size:.85rem}
  .amenity-icon{width:32px;height:32px}
  .amenity-icon svg{width:20px;height:20px}
  .highlights{grid-template-columns:repeat(2,1fr);gap:1rem}
  .highlight{padding:1rem .75rem}
  .highlight-icon{width:50px;height:50px}
  .highlight-icon svg{width:26px;height:26px}
  .highlight h3{font-size:1rem}
  .highlight p{font-size:.85rem}
  .contact-grid{grid-template-columns:1fr;gap:1rem}
  .contact-card{padding:1.25rem 1rem}
  .price-table{font-size:.9rem}
  .price-table th,.price-table td{padding:.65rem .5rem}
  .price-note{padding:1rem;font-size:.95rem}
  .gallery{grid-template-columns:repeat(2,1fr);gap:.5rem}
  .gallery-categories{grid-template-columns:1fr;gap:.85rem}
  .category-card{aspect-ratio:16/10}
  .category-card .category-content{padding:1.1rem}
  .category-card h2{font-size:1.25rem}
  .footer-inner{grid-template-columns:1fr;gap:1.5rem;text-align:left}
  .footer-col h4{margin-bottom:.5rem}
  .site-footer{padding:1.5rem 1rem .85rem}
  .footer-bottom{font-size:.75rem;padding-top:1rem}
  .social-link{width:44px;height:44px}
  .lang-menu{right:0;min-width:170px}
  .faq-question{padding:1rem;font-size:.95rem;min-height:48px}
  .faq-answer p{padding:0 1rem 1rem;font-size:.95rem}
  .platform-card{padding:1.5rem 1rem}
  .platform-logo{width:70px;height:70px;font-size:1.5rem}
  .map-wrapper{aspect-ratio:4/3;min-height:240px}
  .map-consent{padding:1rem}
  .map-consent svg{width:36px;height:36px;margin-bottom:.5rem}
  .map-consent h3{font-size:1rem}
  .map-consent p{font-size:.85rem}
  .lightbox{padding:.75rem}
  .lightbox-nav{width:42px;height:50px;font-size:2rem}
  .lightbox-prev{left:.5rem}
  .lightbox-next{right:.5rem}
  .lightbox-close{top:.5rem;right:.85rem;font-size:2.2rem;width:44px;height:44px;display:flex;align-items:center;justify-content:center}
  .lightbox-caption{bottom:.85rem;font-size:.85rem;padding:.4rem .85rem;max-width:calc(100% - 2rem)}
  .weather-widget{padding:1.25rem 1rem;gap:.85rem}
  .weather-icon{width:54px;height:54px}
  .weather-icon svg{width:44px;height:44px}
  .weather-temp{font-size:1.85rem}
  .testimonial{padding:1.25rem 1rem}
  .attractions{grid-template-columns:1fr}
  .impressum-box{padding:1rem!important}
  .impressum-box h2{font-size:1.15rem}
  .impressum-box p{font-size:.95rem}
  .calendar-weekday{font-size:.7rem;padding:.3rem 0}
  .calendar-day{font-size:.8rem}
  .calendar-month-label{min-width:100px;font-size:.95rem}
  .calendar-section{padding:1rem}
  .activity-list{grid-template-columns:1fr}
  .travel-options{grid-template-columns:1fr}
}

/* RESPONSIVE - SMALL PHONE (≤380px) */
@media (max-width:380px){
  .hero h1{font-size:1.4rem}
  h1{font-size:1.45rem}
  .amenities{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:1fr 1fr}
  .lang-btn .flag{display:none}
  .footer-col h4{font-size:1rem}
}

/* TOUCH-FRIENDLY: Hover-Effekte nur bei "echtem" Hover (Maus) */
@media (hover:none){
  .btn:hover,.platform-card:hover,.category-card:hover,.gallery-item:hover{transform:none}
  .btn-primary:hover{box-shadow:none}
}

/* iOS-spezifische Fixes */
@supports (-webkit-touch-callout:none){
  body{-webkit-text-size-adjust:100%}
  input,select,textarea,button{font-size:16px}
  .lightbox img{max-height:85vh}
}

/* Smooth Scrolling für moderne Geräte */
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

@media print{.site-header,.site-footer,.menu-toggle,.lightbox{display:none}}

/* ============================================
   CROSS-BROWSER-KOMPATIBILITÄT
   ============================================ */

/* Flexbox-gap-Fallback für Safari < 14.1 (iPhones ~2020 und älter).
   Diese Browser ignorieren "gap" bei flex. Fallback via Margin. */
@supports not (inset:0){
  .main-nav ul > li{margin:0 .05rem}
  .btn-group > *{margin:.25rem}
  .social-links > *{margin:0 .35rem}
  .footer-grid > *{margin-bottom:1rem}
}

/* Firefox: dünnere Scrollbar im mobilen Menü */
@supports (scrollbar-width:thin){
  .header-right .main-nav{scrollbar-width:thin}
}

/* Edge/IE-Legacy: -ms-Grid wird NICHT unterstützt, aber Flexbox schon.
   Grid-Bereiche fallen auf Flexbox zurück, falls Grid fehlt. */
@supports not (display:grid){
  .testimonials,.footer-grid,.apartment-grid,.category-grid,
  .activity-list,.gallery-grid,.highlight-grid{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
  }
  .testimonials > *,.apartment-grid > *,.category-grid > *,
  .activity-list > *,.gallery-grid > *,.highlight-grid > *{
    flex:1 1 280px;
    margin:.75rem;
  }
}

/* aspect-ratio-Fallback (Safari < 15): Padding-Hack für Galerie-Bilder */
@supports not (aspect-ratio:1){
  .gallery-item{position:relative;padding-bottom:75%;height:0;overflow:hidden}
  .gallery-item img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}
}

/* clamp()-Fallback (sehr alte Browser): feste Schriftgrößen vorher definiert,
   clamp() überschreibt nur wenn unterstützt. Defensive Basis-Größe: */
@supports not (width:clamp(1rem,2vw,2rem)){
  .hero h1{font-size:2.2rem}
  h1{font-size:2rem}
}

/* object-fit-Fallback (alte Edge): zentriertes Bild ohne Verzerrung */
@supports not (object-fit:cover){
  .gallery-item img,.apartment-img img{font-family:"object-fit:cover";}
}

/* Sticky-Header-Fallback: falls position:sticky fehlt, bleibt Header normal */
@supports not (position:sticky){
  .site-header{position:relative}
}
