/* RentalPage Studio CSS · keine externen Fonts */
/* Hinweis: @font-face wird dynamisch in index.php ausgegeben – nur wenn die
   lokalen Font-Dateien wirklich existieren. So entstehen keine 404-Fehler. */
:root{--cream:#F7F4EE;--sand:#E8E0D0;--stone:#9C9080;--dark:#1A1814;--charcoal:#2E2B26;--gold:#B8955A;--gold-lt:#D4B483;--white:#fff;--font-display:"RentalPage Serif",Georgia,serif;--font-body:"RentalPage Sans",Arial,sans-serif;--r:28px;--rf:999px;--theme-primary:var(--gold);--theme-primary-contrast:var(--dark);--gold-contrast:var(--dark);--theme-secondary:var(--charcoal);--theme-accent:var(--gold-lt);--theme-muted:var(--cream);--theme-surface:var(--sand);--theme-text:var(--dark);--theme-text-muted:var(--stone);--theme-border:var(--sand)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-body);background:var(--cream);color:var(--dark);font-weight:300;letter-spacing:.01em}a{color:inherit}.hero{height:100vh;min-height:650px;position:relative;display:flex;align-items:flex-end;padding:24px;overflow:hidden}.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;border-radius:var(--r)}.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,24,20,.9),rgba(26,24,20,.2),transparent);border-radius:var(--r)}.hero-content{position:relative;z-index:1;max-width:1280px;width:100%;margin:0 auto;padding:0 16px 70px;color:#fff}.hero h1{font-family:var(--font-display);font-size:clamp(46px,6vw,88px);font-weight:300;line-height:1.03;margin:0 0 14px;max-width:840px}.hero-subtitle{font-size:20px;color:rgba(255,255,255,.82);max-width:680px}.hero-desc{font-size:15px;line-height:1.7;color:rgba(255,255,255,.68);max-width:620px}.quickfacts{display:flex;gap:12px;flex-wrap:wrap;margin:28px 0}.quickfacts span{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:var(--rf);padding:8px 16px;font-size:12px;color:rgba(255,255,255,.78)}.section-inner{max-width:1280px;margin:auto;padding:96px 40px}.section-inner.slim{max-width:900px}.section-inner.two{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}.eyebrow{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;display:block}h2{font-family:var(--font-display);font-size:clamp(32px,4vw,58px);font-weight:300;line-height:1.1;margin:0 0 22px}h3{font-size:15px;letter-spacing:.08em;text-transform:uppercase}.booking-section,.gallery-section,.about-section,.reviews-section{background:#fff}.trustline{color:#6c6256}.booking-widget{margin-top:28px}.booking-widget iframe{display:block;width:100%;max-width:100%;border:0}.booking-card{background:#fff;border:1px solid var(--sand);border-radius:var(--r);padding:28px;box-shadow:0 12px 40px rgba(0,0,0,.07)}.benefits-section{background:var(--dark);color:#fff}.benefit-grid,.info-grid,.review-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:44px}.benefit-grid article{background:var(--charcoal);border-radius:var(--r);padding:34px;border:1px solid rgba(255,255,255,.05)}.benefit-grid strong{font-family:var(--font-display);font-size:44px;color:rgba(184,149,90,.35)}.benefit-grid p{color:rgba(255,255,255,.58);line-height:1.65}.facts{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:30px}.facts div{background:#fff;border:1px solid var(--sand);border-radius:20px;padding:20px}.facts b{font-family:var(--font-display);font-size:32px;font-weight:400;display:block}.facts span{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone)}.card-img{border-radius:var(--r);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.12)}.card-img img{width:100%;height:100%;object-fit:cover;display:block}.floor img{object-fit:contain;background:#fff}.portrait{max-height:520px}.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.gallery-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:20px}.amenities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}.amenities-grid article,.info-grid article,.review-grid article{background:#fff;border:1px solid var(--sand);border-radius:var(--r);padding:28px}.amenities-grid ul{padding-left:18px;margin:0}.amenities-grid li{margin:.35rem 0;color:#5f574e}.notice{background:#fff8ea;border:1px solid var(--gold-lt);border-radius:18px;padding:18px;color:#5f574e}.extra-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}.extra-list span,.rules-list p{background:#fff;border:1px solid var(--sand);border-radius:var(--rf);padding:10px 16px;margin:0;line-height:1.35;max-width:100%;overflow-wrap:normal}.location-section{background:#eee7db}.map-wrap{position:relative}.map-consent,#map{height:430px;border-radius:var(--r);overflow:hidden;box-shadow:0 12px 40px rgba(0,0,0,.1);position:relative;z-index:1}.map-consent{display:flex;align-items:center;justify-content:center;background:#ddd}.map-placeholder{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}.map-consent:before{content:"";position:absolute;inset:0;background:rgba(26,24,20,.46);backdrop-filter:blur(2px);z-index:1}.map-consent-box{position:relative;z-index:2;background:rgba(255,255,255,.95);border-radius:24px;padding:28px;max-width:430px;margin:24px;text-align:center;box-shadow:0 18px 50px rgba(0,0,0,.22)}.map-consent-box h3{margin-top:0}.map-consent-box p{line-height:1.6;color:#5f574e}.map-consent-box button{border:0;background:var(--gold);color:var(--theme-primary-contrast,var(--dark));border-radius:var(--rf);padding:12px 24px;font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;cursor:pointer}.is-hidden{display:none!important}.leaflet-container{z-index:1}.address{color:var(--stone)}.info-grid{grid-template-columns:repeat(3,1fr)}.rules-section{background:var(--cream)}.rules-list{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start}.review-grid{grid-template-columns:repeat(3,1fr)}.review-grid p{font-family:var(--font-display);font-size:22px;line-height:1.35}.review-grid span{display:block;color:var(--stone);font-size:13px;margin-top:4px}.faq-layout{display:grid;grid-template-columns:1fr 2fr;gap:60px;align-items:start}.faq-list details{background:#fff;border:1px solid var(--sand);border-radius:18px;margin:12px 0;padding:18px 22px}.faq-intro{position:sticky;top:120px}.faq-intro p{color:#5f574e;line-height:1.65}summary{cursor:pointer;font-weight:500}details p{color:#5f574e;line-height:1.65}footer{background:var(--dark);color:#fff}.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding-bottom:36px}.legal-links{display:flex;flex-direction:column;gap:10px}.legal-links a{color:rgba(255,255,255,.65);text-decoration:none}.copyright{border-top:1px solid rgba(255,255,255,.08);max-width:1280px;margin:auto;padding:20px 40px;color:rgba(255,255,255,.42);font-size:12px}.legal-page{background:var(--cream)}.legal-wrap{max-width:880px;margin:0 auto;padding:70px 32px}.legal-wrap h1{font-family:var(--font-display);font-size:56px;font-weight:300}.legal-content{background:#fff;border:1px solid var(--sand);border-radius:var(--r);padding:36px;line-height:1.75;white-space:normal}.back{display:inline-block;margin-bottom:28px;text-decoration:none;color:var(--gold)}@media (max-width:640px){.rules-list{gap:8px}.rules-list p{width:100%;border-radius:14px;padding:8px 12px;font-size:14px;line-height:1.35}}@media (max-width:980px){.section-inner.two,.benefit-grid,.amenities-grid,.info-grid,.review-grid,.footer-inner{grid-template-columns:1fr}.gallery-grid{grid-template-columns:1fr 1fr}.section-inner{padding:70px 24px}.hero{padding:12px}.hero-content{padding-bottom:45px}}



@media (max-width:640px){.rules-list{gap:8px}.rules-list p{width:100%;border-radius:14px;padding:8px 12px;font-size:14px;line-height:1.35}}@media (max-width:980px){.hero{padding-top:116px}.hero-content{padding-bottom:34px}}

@media (max-width:640px){.rules-list{gap:8px}.rules-list p{width:100%;border-radius:14px;padding:8px 12px;font-size:14px;line-height:1.35}}@media (max-width:980px){.faq-layout{grid-template-columns:1fr;gap:24px}.faq-intro{position:static;text-align:center}.booking-widget{margin-top:22px}}


/* Ausgelagerte Styles aus index.php */
/* Korrekturen: mobile CTA rechts, Buchungswidget zentriert, FAQ-Breite */
.mobile-book-btn{display:none}
.booking-embed{display:block;width:100%;max-width:1200px;margin-left:auto!important;margin-right:auto!important;text-align:center}
.booking-embed iframe,.booking-embed > *{max-width:100%;margin-left:auto!important;margin-right:auto!important}
.booking-embed iframe{display:block!important}
.faq-layout{max-width:1280px;width:100%}
@media (max-width:640px){.rules-list{gap:8px}.rules-list p{width:100%;border-radius:14px;padding:8px 12px;font-size:14px;line-height:1.35}}@media (max-width:980px){.mobile-book-btn{order:2;display:inline-flex;align-items:center;justify-content:center;background:var(--gold);color:var(--theme-primary-contrast,var(--dark))!important;border-radius:999px;padding:12px 18px;text-decoration:none;font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap}.booking-embed{text-align:center}.faq-layout{grid-template-columns:1fr;gap:24px}.faq-intro{text-align:center}}

/* Lightbox-Galerie mit sichtbarem Mouseover-Titel */
.gallery-grid a.gallery-item{position:relative;display:block;overflow:hidden;border-radius:28px;text-decoration:none;color:#fff;background:#111;min-height:220px}
.gallery-grid a.gallery-item img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .35s ease,filter .35s ease}
.gallery-grid a.gallery-item:hover img,.gallery-grid a.gallery-item:focus img{transform:scale(1.04);filter:brightness(.72)}
.gallery-caption{position:absolute;left:0;right:0;bottom:0;padding:22px 24px;background:linear-gradient(to top,rgba(0,0,0,.68),rgba(0,0,0,0));font-size:15px;line-height:1.35;opacity:0;transform:translateY(8px);transition:opacity .25s ease,transform .25s ease;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.35)}
.gallery-item:hover .gallery-caption,.gallery-item:focus .gallery-caption{opacity:1;transform:translateY(0)}
.lightbox{position:fixed;inset:0;z-index:9999;display:none;background:#000;padding:0;overflow:hidden;touch-action:pan-y}
.lightbox.open{display:block}
.lightbox-stage{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:grab;user-select:none;touch-action:pan-y}
.lightbox-stage.dragging{cursor:grabbing}
.lightbox-figure{margin:0;width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:46px 0 70px;transition:transform .28s ease,opacity .22s ease;will-change:transform}
.lightbox-img{display:block;max-width:100vw;max-height:calc(100vh - 130px);width:auto;height:auto;border-radius:0;box-shadow:none;background:#111;object-fit:contain;pointer-events:none}
.lightbox-caption{position:absolute;left:0;right:0;bottom:22px;color:#fff;font-size:15px;line-height:1.5;text-align:center;max-width:920px;margin:0 auto;padding:0 24px;text-shadow:0 1px 2px rgba(0,0,0,.7)}
.lightbox-close{position:absolute;top:18px;right:22px;z-index:3;width:44px;height:44px;border:0;background:transparent;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:42px;line-height:1;opacity:.72;transition:opacity .2s}
.lightbox-close:hover,.lightbox-close:focus{opacity:1}
.lightbox-nav{position:absolute;top:0;bottom:0;z-index:2;width:18vw;max-width:220px;min-width:72px;border:0;background:transparent;color:#fff;cursor:pointer;opacity:0;transition:opacity .22s;display:flex;align-items:center;font-size:44px;font-weight:200;line-height:1}
.lightbox:hover .lightbox-nav,.lightbox-nav:focus{opacity:.62}
.lightbox-nav:hover{opacity:1}
.lightbox-prev{left:0;justify-content:flex-start;padding-left:30px}
.lightbox-next{right:0;justify-content:flex-end;padding-right:30px}
.lightbox-counter{position:absolute;left:50%;bottom:24px;z-index:3;transform:translateX(-50%);color:rgba(255,255,255,.72);font-size:12px;letter-spacing:.08em;opacity:0;transition:opacity .22s;pointer-events:none}
.lightbox:hover .lightbox-counter{opacity:1}
@media (max-width:760px){.gallery-grid a.gallery-item{border-radius:20px;min-height:180px}.gallery-caption{opacity:1;transform:none;padding:18px;font-size:14px}.lightbox-figure{padding:44px 0 82px}.lightbox-img{max-width:100vw;max-height:calc(100vh - 150px)}.lightbox-caption{font-size:14px;bottom:34px;padding:0 18px}.lightbox-close{top:10px;right:12px;font-size:38px}.lightbox-nav{opacity:.45;width:22vw;min-width:54px;font-size:34px}.lightbox-prev{padding-left:16px}.lightbox-next{padding-right:16px}.lightbox-counter{bottom:14px;opacity:.75}}

/* Korrektur: nur ein Buchungs-Button, kein zusätzlicher Textlink */
.mobile-book-btn{display:none!important}


/* Lightbox: Caption ohne überlagerte Slide-Nummer */
.lightbox-counter{display:none!important}
@media (max-width:640px){.rules-list{gap:8px}.rules-list p{width:100%;border-radius:14px;padding:8px 12px;font-size:14px;line-height:1.35}}


/* Rechtliches als Modal */
.legal-links button{background:transparent;border:0;color:inherit;font:inherit;text-decoration:none;cursor:pointer;padding:0;text-align:left}
.legal-links button:hover,.legal-links button:focus{text-decoration:underline}
.legal-modal{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center;padding:24px;background:rgba(0,0,0,.58)}
.legal-modal.open{display:flex}
.legal-modal-box{width:min(920px,100%);max-height:min(82vh,900px);overflow:auto;background:#f7f3ec;color:var(--dark);border-radius:28px;box-shadow:0 30px 90px rgba(0,0,0,.35);border:1px solid rgba(184,149,90,.22)}
.legal-modal-head{position:sticky;top:0;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 30px;background:#f7f3ec;border-bottom:1px solid rgba(184,149,90,.22)}
.legal-modal-head h2{margin:0;font-family:var(--serif);font-size:clamp(30px,4vw,48px);font-weight:300}
.legal-modal-close{border:0;background:var(--dark);color:#fff;width:42px;height:42px;border-radius:50%;font-size:28px;line-height:1;cursor:pointer}
.legal-modal-content{padding:28px 30px 36px;font-size:16px;line-height:1.75}
.legal-modal-content h2,.legal-modal-content h3,.legal-modal-content h4{font-family:var(--serif);font-weight:300;margin:1.35em 0 .45em;line-height:1.18}
.legal-modal-content h2:first-child,.legal-modal-content h3:first-child{margin-top:0}
.legal-modal-content p{margin:.65em 0}
.legal-modal-content ul,.legal-modal-content ol{margin:.75em 0 .75em 1.4em}
.legal-modal-content a{color:var(--gold-dark);text-decoration:underline}
@media (max-width:760px){.legal-modal{padding:12px}.legal-modal-box{border-radius:18px;max-height:88vh}.legal-modal-head{padding:18px 20px}.legal-modal-content{padding:22px 20px 28px}}


/* Mehrsprachigkeit + ausbalancierte Navigation */












@media (max-width:640px){.rules-list{gap:8px}.rules-list p{width:100%;border-radius:14px;padding:8px 12px;font-size:14px;line-height:1.35}}


.section-subline{max-width:720px;color:#6c6256;line-height:1.65;margin:-8px 0 26px}.benefits-section .section-subline{color:rgba(255,255,255,.65)}.map-revoke{margin-top:14px;border:0;background:transparent;color:var(--stone);text-decoration:underline;cursor:pointer;font:inherit;font-size:13px}.map-revoke:hover{color:var(--gold)}



/* Allgemeine Beschreibung unter dem Buchungswidget */
.description-section{background:#fff}
.description-section .section-inner.slim{text-align:left}
.description-section h2{max-width:900px;margin-left:0;margin-right:0}
.description-text{max-width:820px;margin:0;color:#5f574e;font-size:18px;line-height:1.8}
@media (max-width:760px){.description-text{font-size:16px;line-height:1.7}}
/* Beschreibung am normalen Section-Raster ausrichten */
.description-section .section-inner{max-width:1280px;text-align:left}
.description-section .description-text{max-width:820px;margin-left:0;margin-right:0}


/* Optionaler 3-Monats-Belegungskalender aus iCal */
.availability-section{background:var(--cream)}
.availability-legend{display:flex;flex-wrap:wrap;gap:16px;margin:8px 0 30px;color:#6c6256;font-size:13px}
.availability-legend span{display:inline-flex;align-items:center;gap:8px}
.availability-legend i{width:14px;height:14px;border-radius:5px;display:inline-block;border:1px solid var(--sand);background:#fff}
.availability-legend i.is-booked{background:var(--dark);border-color:var(--dark)}
.availability-legend i.is-unknown{background:repeating-linear-gradient(45deg,#fff,#fff 4px,#f0eadf 4px,#f0eadf 8px);border-color:var(--sand)}
.availability-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}
.availability-month{background:#fff;border:1px solid var(--sand);border-radius:var(--r);padding:26px;box-shadow:0 12px 36px rgba(0,0,0,.05)}
.availability-month-label{margin:0 0 18px;font-family:var(--font-display);font-size:30px;font-weight:300;letter-spacing:0;text-transform:none;line-height:1.1;color:var(--dark)}
.availability-weekdays,.availability-days{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.availability-weekdays{margin-bottom:8px;color:var(--stone);font-size:10px;letter-spacing:.12em;text-transform:uppercase;text-align:center}
.availability-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#f7f4ee;border:1px solid rgba(232,224,208,.9);font-size:13px;color:#5f574e;text-decoration:none;position:relative}
.availability-day.empty{background:transparent;border-color:transparent}
.availability-day.booked{background:var(--dark);border-color:var(--dark);color:#fff}
.availability-day.unknown{background:repeating-linear-gradient(45deg,#fff,#fff 6px,#f0eadf 6px,#f0eadf 12px);border-color:var(--sand);color:#8a8176}
.availability-day.today{outline:2px solid var(--gold);outline-offset:2px}
.availability-day.past{opacity:.48}
.availability-updated{margin-top:18px;color:var(--stone);font-size:12px}
.availability-error{background:#fff;border:1px solid var(--gold-lt);border-radius:var(--r);padding:24px;color:#5f574e;line-height:1.65;max-width:760px}
@media (max-width:640px){.rules-list{gap:8px}.rules-list p{width:100%;border-radius:14px;padding:8px 12px;font-size:14px;line-height:1.35}}@media (max-width:980px){.availability-grid{grid-template-columns:1fr}.availability-month{padding:22px}.availability-day{border-radius:10px}}

/* Navigierbarer iCal-Belegungskalender */
.availability-toolbar{display:flex;align-items:center;justify-content:center;gap:18px;margin:4px 0 24px}
.availability-range{min-width:260px;text-align:center;font-family:var(--font-display);font-size:24px;font-weight:300;color:var(--dark)}
.availability-nav{width:46px;height:46px;border:1px solid var(--sand);border-radius:999px;background:#fff;color:var(--dark);font-size:30px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 24px rgba(0,0,0,.05);transition:background .2s,border-color .2s,opacity .2s,transform .2s}
.availability-nav:hover,.availability-nav:focus{background:var(--gold);border-color:var(--gold);outline:none;transform:translateY(-1px)}
.availability-nav:disabled{opacity:.35;cursor:not-allowed;transform:none;background:#fff;border-color:var(--sand)}
.availability-month.is-calendar-hidden,.availability-month[hidden]{display:none!important}
@media (max-width:760px){.availability-toolbar{justify-content:space-between;gap:10px}.availability-range{min-width:0;font-size:19px}.availability-nav{width:42px;height:42px;font-size:27px}}

/* iCal-Buchungswidget: links Kalender, rechts Anfrageformular */
.availability-booking-layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(320px,1fr);gap:24px;align-items:start}
.availability-calendar-pane{min-width:0}
.availability-section--with-booking .availability-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:22px}
.availability-booking-widget{background:#fff;border:1px solid var(--sand);border-radius:var(--r);padding:30px;box-shadow:0 12px 36px rgba(0,0,0,.05);position:sticky;top:110px}
.availability-booking-widget h3{margin:0 0 12px;font-family:var(--font-display);font-size:32px;font-weight:300;color:var(--dark)}
.availability-booking-widget p{margin:0 0 22px;color:#6c6256;line-height:1.65}
.availability-booking-fields{display:grid;gap:14px;margin-bottom:20px}
.availability-booking-fields label{display:grid;gap:7px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);min-width:0}
.availability-booking-fields input{display:block;width:100%;max-width:100%;min-width:0;box-sizing:border-box;border:1px solid var(--sand);border-radius:14px;background:#f7f4ee;color:var(--dark);padding:13px 14px;font:inherit;font-size:15px;letter-spacing:0;text-transform:none;-webkit-appearance:none;appearance:none}
.availability-booking-fields input:focus{outline:2px solid var(--gold);outline-offset:2px;background:#fff}
.availability-booking-fields input[type="date"]::-webkit-date-and-time-value{text-align:inherit}
.availability-booking-fields input[type="date"]::-webkit-calendar-picker-indicator{opacity:.9}
.availability-booking-submit{width:100%;justify-content:center;border:0;cursor:pointer}
.availability-booking-missing{border:1px solid var(--gold-lt);border-radius:14px;padding:14px 16px;background:#f7f4ee;color:#6c6256;font-size:14px}
.availability-section--with-booking .availability-day.free:not(.past){cursor:pointer}
.availability-day.is-in-range{background:var(--sand);border-color:var(--sand);color:var(--dark)}
.availability-day.is-selected{background:var(--gold);border-color:var(--gold);color:var(--dark);box-shadow:0 0 0 2px rgba(184,149,90,.25)}
@media (max-width:1100px){.availability-booking-layout{grid-template-columns:1fr}.availability-booking-widget{position:static}.availability-section--with-booking .availability-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:760px){.availability-section--with-booking .availability-grid{grid-template-columns:1fr}.availability-booking-widget{padding:24px;overflow:hidden}.availability-booking-widget h3{font-size:28px}.availability-booking-fields{display:block}.availability-booking-fields label{display:block;width:100%;max-width:100%;min-width:0;overflow:hidden}.availability-booking-fields label+label{margin-top:14px}.availability-booking-fields label input{margin-top:7px}.availability-booking-fields input,.availability-booking-fields input[type="date"]{display:block;width:100%;max-width:100%;min-width:0;inline-size:100%;max-inline-size:100%;}}


/* RentalPage Studio · final mobile menu safety fix
   Ensures the rounded theme menu is closed by default on mobile, despite earlier desktop display rules. */





/* Allgemeine Beschreibung wirklich am normalen Raster ausrichten */
.description-section .section-inner,
.description-section .section-inner.slim {
  max-width: 1280px !important;
  width: 100% !important;
  text-align: left !important;
}
.description-section .eyebrow,
.description-section h2,
.description-section .description-text {
  max-width: none !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}



/* =====================================================================
   NAVIGATION — konsolidiert (ersetzt alle früheren, verstreuten Nav-Regeln)
   Aufbau:
     1. Basis / Desktop (gilt überall, sofern nicht überschrieben)
     2. @media ≤1180px  – Desktop-Feinabstimmung (Abstände/Größen)
     3. @media ≤980px   – Mobiler Drawer (Slide-in von links) + Hamburger
     4. @media ≤420px   – Feinabstimmung sehr schmale Geräte
   ===================================================================== */

/* ---------- 1. BASIS / DESKTOP ---------- */

/* Goldener CTA-Button (Navigation, Hero, Inline-Links) */
.btn-book-nav,.hero-cta,.big-link{display:inline-block;background:var(--gold);color:var(--theme-primary-contrast,var(--dark))!important;border-radius:var(--rf);padding:12px 26px;text-decoration:none;font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase}

.nav-wrap{position:fixed;inset:0 0 auto;z-index:9980;padding:16px 40px;transition:.3s}
.nav-wrap.scrolled{padding:10px 40px}

.nav-inner{max-width:1280px;margin:auto;display:flex;align-items:center;justify-content:flex-start;gap:0;background:rgba(26,24,20,.78);backdrop-filter:blur(16px);border-radius:var(--rf);padding:14px 14px 14px 32px}

.nav-logo{flex:1 1 auto;min-width:0;max-width:min(36vw,460px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-display);font-size:22px;color:#fff;text-decoration:none;letter-spacing:.05em}
.nav-logo span{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.logo-img{display:block;max-width:190px;max-height:46px;width:auto;height:auto;object-fit:contain}

/* zentrale Linkliste */
.nav-links{display:flex;align-items:center;justify-content:flex-end;gap:clamp(18px,2vw,30px);margin:0 34px 0 auto}
.nav-links a{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.72);text-decoration:none;transition:color .15s ease}
.nav-links a:hover,.nav-links a:focus,.nav-links a.is-active,.nav-links a[aria-current="location"]{color:#fff}
/* Buchungs-Link gehört in die Actions, nicht in die Linkliste */
.nav-links a[href="#buchung"],.nav-links a[href="#booking"]{display:none!important}

/* rechte Aktionsgruppe: Sprache + Buchen-Button */
.nav-actions{display:flex;align-items:center;justify-content:flex-end;gap:18px;flex:0 0 auto;white-space:nowrap;margin:0}
.nav-actions>.btn-book-nav{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;margin:0;white-space:nowrap}
.nav-inner>.btn-book-nav{display:none}

/* Sprachumschalter */
.lang-switcher{display:inline-flex;align-items:center;gap:4px;margin:0 4px 0 0;padding:6px 10px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:rgba(255,255,255,.07);font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.56)}
.lang-switcher a{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:24px;padding:0 8px;border:0;border-radius:999px;background:transparent;color:rgba(255,255,255,.62);text-decoration:none;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;line-height:1}
.lang-switcher a:hover,.lang-switcher a:focus{color:#fff;background:rgba(255,255,255,.13)}
.lang-switcher a.active{color:#fff;background:rgba(255,255,255,.18)}

/* Hamburger-Button (nur mobil sichtbar) */
.nav-toggle{display:none;appearance:none;border:0;background:rgba(255,255,255,.1);border-radius:999px;width:46px;height:42px;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer}
.nav-toggle span{width:20px;height:2px;background:#fff;border-radius:3px;transition:.2s}

/* Overlay hinter dem Drawer (nur mobil aktiv) */
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9990}
.nav-overlay.open{display:block}

/* mobile Marken-Zeile + Drawer-Schließen-Button: Desktop aus */
.mobile-brand-top{display:none}
.nav-drawer-close{display:none}

/* ---------- 2. @media ≤1180px – Desktop-Feinabstimmung ---------- */
@media(max-width:1180px){
  .nav-logo{max-width:min(30vw,340px)}
  .nav-links{gap:16px;margin-right:24px}
  .nav-links a{font-size:10px;letter-spacing:.11em}
  .nav-actions{gap:12px}
  .lang-switcher{padding:5px 8px}
  .lang-switcher a{min-width:25px;height:22px;padding:0 6px;font-size:9px}
}

/* ---------- 3. @media ≤980px – Mobiler Drawer ---------- */
@media(max-width:980px){
  .nav-wrap{padding:10px 12px}
  .nav-wrap.scrolled{padding:8px 12px}

  /* Overlay unter die Leiste/den Drawer legen (nav-inner bekommt z-index:2) */
  .nav-overlay{z-index:1}

  /* zentrierte Marken-Zeile über der Leiste */
  .mobile-brand-top{display:flex;align-items:center;justify-content:center;max-width:min(420px,calc(100vw - 24px));min-height:48px;margin:0 auto 8px;padding:10px 18px;border-radius:999px;background:rgba(26,24,20,.78);backdrop-filter:blur(16px);color:#fff;text-decoration:none;font-family:var(--font-display);font-size:20px;letter-spacing:.05em}
  .mobile-brand-top .logo-img{max-height:34px;max-width:260px}

  /* Leiste: Hamburger links, Buchen rechts */
  .nav-inner{position:relative;z-index:2;justify-content:space-between;gap:10px;padding:10px 10px 10px 14px;border-radius:24px;-webkit-backdrop-filter:none;backdrop-filter:none}
  .nav-logo{display:none}
  .nav-toggle{display:flex;order:1;flex:0 0 46px}
  .nav-actions{order:3;flex:0 0 auto;gap:10px}
  .nav-inner>.btn-book-nav{display:none!important}
  .nav-actions>.btn-book-nav{display:inline-flex;white-space:nowrap;padding:10px 14px;font-size:9px}
  .lang-switcher{display:none}

  /* Body-Scroll sperren, solange der Drawer offen ist */
  body.nav-open{overflow:hidden!important}

  /* Drawer von links */
  #mainMenu.nav-links{display:block;position:fixed;top:0;left:0;right:auto;bottom:0;width:min(280px,80vw);height:100dvh;margin:0;gap:0;padding:80px 16px 40px;background:rgba(26,24,20,.97);box-shadow:4px 0 40px rgba(0,0,0,.4);border-radius:0;z-index:9999;overflow-y:auto;transform:translateX(-100%);visibility:hidden;transition:transform .28s cubic-bezier(.4,0,.2,1),visibility .28s}
  #mainMenu.nav-links.open{transform:translateX(0);visibility:visible}

  /* Drawer-Links */
  #mainMenu.nav-links a,#mainMenu.nav-links a:not(.btn-book-nav){display:block;padding:14px 12px;border-radius:10px;border-bottom:1px solid rgba(255,255,255,.08);background:transparent;color:rgba(255,255,255,.72);font-size:13px;letter-spacing:.12em;-webkit-tap-highlight-color:transparent;transition:background .18s,color .18s,padding-left .18s}
  #mainMenu.nav-links a:last-of-type{border-bottom:none}
  #mainMenu.nav-links a:hover,#mainMenu.nav-links a:focus{color:#fff;background:rgba(255,255,255,.09);padding-left:20px}
  #mainMenu.nav-links a.is-active,#mainMenu.nav-links a[aria-current="location"]{color:#fff;background:rgba(255,255,255,.09)}
  /* Buchen-Button gehört nicht in den Drawer */
  #mainMenu.nav-links .btn-book-nav{display:none!important}

  /* Schließen-Button im Drawer */
  .nav-drawer-close{display:flex;position:absolute;top:20px;right:20px;width:36px;height:36px;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.25);border-radius:999px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.8);font-size:16px;line-height:1;cursor:pointer;transition:background .15s,color .15s}
  .nav-drawer-close:hover{background:rgba(255,255,255,.2);color:#fff}
}

/* ---------- 4. @media ≤420px – sehr schmale Geräte ---------- */
@media(max-width:420px){
  .nav-actions>.btn-book-nav{padding:9px 11px;font-size:8.5px}
}

/* Barrierefreier iCal-Kalender */
.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
.availability-keyboard-help{margin:0 0 18px;color:#6c6256;font-size:13px;line-height:1.6}
.availability-calendar-grid{display:grid;gap:6px}
.availability-weekdays,.availability-week{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}
.availability-weekdays{margin-bottom:2px}
.availability-cell{display:block;min-width:0}
.availability-cell.empty{aspect-ratio:1}
button.availability-day{width:100%;padding:0;font:inherit;line-height:1;appearance:none;-webkit-appearance:none;cursor:pointer}
button.availability-day:focus-visible,.availability-nav:focus-visible{outline:3px solid var(--dark)!important;outline-offset:3px!important;position:relative;z-index:3}
.availability-day.today:focus-visible{outline:3px solid var(--dark)!important;outline-offset:3px!important}
.availability-booking-fields input[aria-invalid="true"]{border-color:#9b2c2c;box-shadow:0 0 0 1px #9b2c2c}
@media (prefers-reduced-motion:reduce){.availability-nav{transition:none!important}}

/* Mobile Sprachwahl im Navigations-Drawer: dezente Textlinks */
.mobile-lang-switcher{display:none}
@media(max-width:980px){
  #mainMenu.nav-links .mobile-lang-switcher{display:block;margin:24px 0 0;padding:18px 12px 0;border-top:1px solid rgba(255,255,255,.14)}
  #mainMenu.nav-links .mobile-lang-switcher-title{display:none}
  #mainMenu.nav-links .mobile-lang-switcher-options{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0}
  #mainMenu.nav-links .mobile-lang-switcher a,#mainMenu.nav-links .mobile-lang-switcher a:not(.btn-book-nav){display:inline-flex!important;align-items:center!important;justify-content:center!important;width:auto!important;min-width:0!important;height:auto!important;margin:0!important;padding:4px 7px!important;border:0!important;border-radius:0!important;background:transparent!important;color:rgba(255,255,255,.72)!important;font-size:11px!important;font-weight:600!important;letter-spacing:.1em!important;line-height:1.2!important;text-decoration:none!important;text-transform:uppercase!important;transition:color .18s ease!important}
  #mainMenu.nav-links .mobile-lang-switcher a+a::before{content:"|";display:inline-block;margin-right:14px;color:rgba(255,255,255,.28);font-weight:400}
  #mainMenu.nav-links .mobile-lang-switcher a:hover,#mainMenu.nav-links .mobile-lang-switcher a:focus{padding-left:7px!important;background:transparent!important;color:#fff!important;text-decoration:underline!important;text-underline-offset:4px}
  #mainMenu.nav-links .mobile-lang-switcher a.active{background:transparent!important;color:#fff!important;font-weight:800!important;text-decoration:underline!important;text-underline-offset:4px}
}
/* Footer brand line */
.footer-brand{margin:-10px 0 8px;color:rgba(255,255,255,.72);font-size:15px;line-height:1.45;font-weight:500}
.footer-location{margin-top:0;color:rgba(255,255,255,.62)}


/* =====================================================================
   RentalPage Studio · Template "Feriendorf"
   Inspiriert von einer klaren Portal-/Feriendorf-Seite: helle Navigation,
   große Bildcollage, kompakte Karten, ruhige Grün-/Naturtöne.
   ===================================================================== */
:root{
  --cream:#FAF9F5;
  --sand:#E8E1D6;
  --stone:#757A69;
  --dark:#222A22;
  --charcoal:#344236;
  --gold:#6F8B57;
  --gold-lt:#DDE9D3;
  --white:#fff;
  --font-display:var(--font-body);
  --r:14px;
  --rf:999px;
  --theme-primary:var(--gold);
  --theme-primary-contrast:#fff;
  --theme-secondary:var(--charcoal);
  --theme-accent:#A9BF92;
  --theme-muted:#FAF9F5;
  --theme-surface:#F1EFE8;
  --theme-text:#222A22;
  --theme-text-muted:#757A69;
  --theme-border:#E8E1D6;
}
body{background:#fff;color:var(--dark);font-weight:400;letter-spacing:0;line-height:1.6;}
body:before{content:"";display:block;height:0;}

/* Navigation: weiß, kompakt, portalartig */
.nav-wrap{position:sticky;top:0;padding:0;background:#fff;border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 2px 14px rgba(30,42,34,.06);}
.nav-wrap.scrolled{padding:0;}
.nav-inner{max-width:1200px;border-radius:0;background:#fff;backdrop-filter:none;padding:12px 28px;min-height:64px;}
.nav-logo{font-family:var(--font-body);font-size:18px;font-weight:700;letter-spacing:.01em;color:var(--dark);}
.nav-links{gap:22px;margin-right:24px;}
.nav-links a{color:#5C6256;font-size:12px;font-weight:600;letter-spacing:.02em;text-transform:none;}
.nav-links a:hover,.nav-links a:focus,.nav-links a.is-active{color:var(--gold);}
.lang-switcher{background:#F4F5F1;border-color:#E4E6DE;color:#5C6256;}
.lang-switcher a{color:#5C6256;}
.lang-switcher a.active{background:#fff;color:var(--gold);box-shadow:0 1px 4px rgba(0,0,0,.08);}
.btn-book-nav,.hero-cta,.big-link{background:var(--gold);color:#fff!important;border-radius:8px;padding:11px 18px;font-size:12px;font-weight:700;letter-spacing:.02em;text-transform:none;box-shadow:0 6px 16px rgba(81,111,64,.16);}
.btn-book-nav:hover,.hero-cta:hover,.big-link:hover{background:#5F7D49;}
.logo-img{max-height:38px;}

/* Hero: Bildcollage wie Portal-Header */
.hero.hero-alpenstein{height:auto;min-height:0;display:block;max-width:1200px;margin:0 auto;padding:24px 28px 26px;background:#fff;overflow:visible;}
.hero-media-grid{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;gap:10px;height:min(56vw,520px);min-height:340px;max-height:560px;border-radius:16px;overflow:hidden;background:#EDF0E8;}
.hero-tile{position:relative;overflow:hidden;background:#E9E5DA;}
.hero-tile-main{grid-row:1 / span 2;}
.hero-tile img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.hero-media-grid:hover .hero-tile img{transform:scale(1.015);}
.hero-overlay,.hero-bg{display:none!important;}
.hero-content{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);gap:22px;align-items:end;width:100%;padding:26px 0 0;color:var(--dark);}
.hero-content h1{grid-column:1 / 2;font-family:var(--font-body);font-size:clamp(30px,4vw,52px);font-weight:760;letter-spacing:-.04em;line-height:1.04;margin:0 0 2px;max-width:760px;color:var(--dark);}
.hero-subtitle{grid-column:1 / 2;font-size:17px;font-weight:520;color:#525A4E;max-width:720px;margin:0;}
.hero-desc{grid-column:1 / 2;font-size:14.5px;line-height:1.72;color:#62685E;max-width:760px;margin:0;}
.quickfacts{grid-column:2 / 3;grid-row:1 / span 3;align-self:start;display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0;}
.quickfacts span{background:#fff;border:1px solid var(--sand);border-radius:12px;padding:13px 14px;font-size:12px;font-weight:650;color:#41483E;box-shadow:0 4px 18px rgba(0,0,0,.04);}
.hero-cta{grid-column:1 / 2;justify-self:start;margin-top:5px;}

/* Grundrhythmus */
.section-inner{max-width:1120px;padding:70px 28px;}
.section-inner.slim{max-width:880px;}
.section-inner.two{grid-template-columns:1.05fr .95fr;gap:44px;}
.eyebrow{font-size:12px;letter-spacing:.04em;text-transform:none;font-weight:750;color:var(--gold);margin-bottom:10px;}
h2{font-family:var(--font-body);font-size:clamp(26px,3.1vw,42px);font-weight:760;letter-spacing:-.035em;line-height:1.12;margin-bottom:16px;color:var(--dark);}
h3{font-size:14px;letter-spacing:.02em;text-transform:none;font-weight:750;}
p{line-height:1.72;}.section-subline,.trustline,.description-text{color:#62685E;max-width:780px;}

.booking-section,.gallery-section,.about-section,.reviews-section{background:#fff;}
.description-section,.apartment-section,.floorplan-section,.amenities-section,.info-section,.faq-section{background:#fff;}
.benefits-section,.location-section,.rules-section{background:#F7F6F1;color:var(--dark);}

/* Buchung / Kalender */
.booking-section .section-inner{padding-top:40px;}
.booking-card,.booking-widget{border-radius:16px;}
.booking-card{border:1px solid var(--sand);box-shadow:0 8px 28px rgba(30,42,34,.08);}
.booking-extra-cta a,.availability-cta-button{background:var(--gold)!important;color:#fff!important;border-radius:8px!important;}
.availability-section{background:#F7F6F1;}
.availability-month{border-radius:16px!important;border:1px solid var(--sand)!important;box-shadow:0 4px 18px rgba(30,42,34,.04);}
.availability-nav{border-radius:10px;border-color:var(--sand);}

/* Direktbucher-Vorteile: helle Feature-Karten */
.benefit-grid,.info-grid,.review-grid{gap:14px;margin-top:30px;}
.benefit-grid{grid-template-columns:repeat(4,minmax(0,1fr));}
.benefit-grid article{background:#fff;border:1px solid var(--sand);border-radius:16px;padding:24px;box-shadow:0 8px 26px rgba(30,42,34,.05);}
.benefit-grid strong{font-family:var(--font-body);font-size:32px;font-weight:800;color:rgba(111,139,87,.22);}
.benefit-grid h3{margin-top:8px;color:var(--dark);}
.benefit-grid p{color:#62685E;line-height:1.62;}

/* Unterkunft / Fakten */
.facts{grid-template-columns:repeat(3,1fr);gap:12px;}
.facts div{border:1px solid var(--sand);border-radius:14px;background:#FAF9F5;padding:18px;}
.facts b{font-family:var(--font-body);font-size:28px;font-weight:760;color:var(--dark);}
.facts span{letter-spacing:.03em;text-transform:none;color:#6F7469;font-size:12px;font-weight:650;}
.card-img{border-radius:16px;box-shadow:0 10px 32px rgba(30,42,34,.09);}
.card-img img{min-height:320px;}
.floor img{min-height:0;}

/* Galerie: masonry-artig, ähnlich der Vorlage */
.gallery-grid{display:block;columns:4 210px;column-gap:14px;margin-top:28px;}
.gallery-grid a.gallery-item{display:block;break-inside:avoid;margin:0 0 14px;border-radius:6px;min-height:0;background:#EFF1EA;box-shadow:0 4px 16px rgba(30,42,34,.06);}
.gallery-grid a.gallery-item img{width:100%;height:auto;aspect-ratio:4/3;border-radius:6px;object-fit:cover;}
.gallery-grid a.gallery-item:nth-child(5n+2) img{aspect-ratio:3/4;}
.gallery-grid a.gallery-item:nth-child(7n+3) img{aspect-ratio:1/1;}
.gallery-grid a.gallery-item:nth-child(6n+4) img{aspect-ratio:4/5;}
.gallery-caption{font-size:13px;padding:18px;background:linear-gradient(to top,rgba(0,0,0,.62),rgba(0,0,0,0));}

/* Ausstattung / Listen */
.amenities-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;}
.amenities-grid article,.info-grid article,.review-grid article{border:1px solid var(--sand);border-radius:16px;background:#fff;padding:22px;box-shadow:0 4px 18px rgba(30,42,34,.04);}
.amenities-grid ul{padding-left:18px;}.amenities-grid li{color:#62685E;margin:.28rem 0;font-size:14px;}
.notice{background:#FFF7E8;border-color:#E8C98E;border-radius:14px;color:#665A45;}
.extra-list span,.rules-list p{border-color:var(--sand);border-radius:10px;background:#fff;font-size:14px;}

/* Karte / Lage */
.map-consent,#map{border-radius:16px;box-shadow:0 10px 30px rgba(30,42,34,.10);}
.map-consent-box{border-radius:16px;}.map-consent-box button{background:var(--gold);color:#fff;border-radius:8px;}
.address{color:#62685E;}.map-revoke{color:var(--gold)!important;}

/* Bewertungen, FAQ, Footer */
.review-grid{grid-template-columns:repeat(3,1fr);}
.review-grid p{font-family:var(--font-body);font-size:18px;font-weight:520;}
.faq-layout{grid-template-columns:.8fr 1.2fr;gap:44px;}
.faq-list details{border-color:var(--sand);border-radius:12px;background:#fff;}
footer{background:#F7F6F1;color:var(--dark);border-top:1px solid var(--sand);}
.footer-inner{padding-top:54px;padding-bottom:36px;}
.legal-links a{color:#62685E;}.copyright{border-top:1px solid var(--sand);color:#8A8E84;}

/* Mobile */
@media(max-width:1180px){.nav-inner{padding-left:18px;padding-right:18px}.nav-links{gap:14px}.nav-links a{font-size:11px}.hero.hero-alpenstein{padding-left:18px;padding-right:18px}.section-inner{padding-left:22px;padding-right:22px}.amenities-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:980px){.nav-wrap{padding:8px 10px;background:transparent;border-bottom:0;box-shadow:none}.nav-inner{border-radius:18px;background:rgba(255,255,255,.96);box-shadow:0 6px 24px rgba(30,42,34,.12)}.mobile-brand-top{background:#fff;color:var(--dark);box-shadow:0 6px 24px rgba(30,42,34,.10)}#mainMenu.nav-links{background:#fff!important;color:var(--dark)!important}#mainMenu.nav-links a,#mainMenu.nav-links a:not(.btn-book-nav){color:#4E554B!important;border-bottom:1px solid #EEF0EA!important}.nav-toggle{background:#F3F5F0}.nav-toggle span{background:var(--dark)}.nav-actions .lang-switcher{display:none}.hero.hero-alpenstein{padding-top:18px}.hero-media-grid{height:auto;min-height:0;grid-template-columns:1fr 1fr;grid-template-rows:auto}.hero-tile-main{grid-column:1 / span 2;grid-row:auto}.hero-tile-main img{aspect-ratio:16/10}.hero-tile-side img{aspect-ratio:4/3}.hero-content{grid-template-columns:1fr;gap:14px}.hero-content h1,.hero-subtitle,.hero-desc,.hero-cta,.quickfacts{grid-column:auto;grid-row:auto}.quickfacts{grid-template-columns:1fr 1fr}.section-inner.two,.benefit-grid,.info-grid,.review-grid,.footer-inner,.faq-layout{grid-template-columns:1fr}.section-inner{padding-top:56px;padding-bottom:56px}.gallery-grid{columns:2 160px}.card-img img{min-height:240px}}
@media(max-width:640px){.hero.hero-alpenstein{padding:12px 12px 20px}.hero-media-grid{gap:6px;border-radius:12px}.hero-content h1{font-size:30px}.quickfacts{grid-template-columns:1fr}.quickfacts span{padding:11px 12px}.section-inner{padding:46px 16px}.amenities-grid{grid-template-columns:1fr}.gallery-grid{columns:2 130px;column-gap:8px}.gallery-grid a.gallery-item{margin-bottom:8px;border-radius:4px}.btn-book-nav,.hero-cta,.big-link{width:auto;max-width:100%;}.nav-actions>.btn-book-nav{font-size:10px;padding:10px 12px}}


/* =====================================================================
   RentalPage Studio · Template "Alpenstein Lodge"
   Dunkelblaues Lodge-Template nach Berg-/Chalet-Vorlage.
   Basierend auf der gemeinsamen Template-Struktur; Assets bleiben zentral
   unter core/current/themes/alpenstein/.
   ===================================================================== */
:root{
  --cream:#EAF3FA;
  --sand:#C9D6EA;
  --stone:#7483A2;
  --dark:#15233B;
  --charcoal:#243A64;
  --gold:#5B74B4;
  --gold-lt:#8FA4D7;
  --white:#fff;
  --font-display:var(--font-body);
  --r:0px;
  --rf:999px;
  --theme-primary:#5B74B4;
  --theme-primary-contrast:#fff;
  --theme-secondary:#243A64;
  --theme-accent:#8FA4D7;
  --theme-muted:#EAF3FA;
  --theme-surface:#DCE8F4;
  --theme-text:#15233B;
  --theme-text-muted:#7483A2;
  --theme-border:#C9D6EA;
}
html,body{background:#EAF3FA;color:var(--dark);font-family:var(--font-body);font-weight:400;letter-spacing:0;line-height:1.6;}
body{overflow-x:hidden;}
a{color:inherit;}

/* Navigation: schmale blaue Leiste über dem Hero */
.nav-wrap{position:fixed;top:0;left:0;right:0;z-index:9980;padding:0;background:rgba(36,58,100,.96);border:0;box-shadow:0 8px 24px rgba(8,18,36,.18);}
.nav-wrap.scrolled{padding:0;background:rgba(36,58,100,.98);}
.nav-inner{max-width:none;width:100%;min-height:62px;border-radius:0;background:transparent;backdrop-filter:none;padding:0 34px;display:flex;align-items:center;}
.nav-logo{flex:0 1 auto;max-width:280px;font-family:var(--font-body);font-size:18px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#fff;text-decoration:none;}
.logo-img{max-height:42px;max-width:220px;filter:brightness(0) invert(1);}
.nav-links{gap:26px;margin:0 auto;justify-content:center;}
.nav-links a{color:rgba(255,255,255,.74);font-size:11px;font-weight:650;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;}
.nav-links a:hover,.nav-links a:focus,.nav-links a.is-active{color:#fff;}
.nav-actions{gap:12px;margin-left:0;}
.lang-switcher{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.7);}
.lang-switcher a{color:rgba(255,255,255,.66);}
.lang-switcher a.active{background:#fff;color:var(--charcoal);}
.btn-book-nav,.hero-cta,.big-link{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#fff;color:var(--charcoal)!important;padding:11px 21px;font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;box-shadow:0 10px 28px rgba(4,16,36,.18);}
.btn-book-nav:hover,.hero-cta:hover,.big-link:hover{background:#EAF3FA;color:#1d2f55!important;}

/* Hero: ein großes Bergbild, zentrierte Lodge-Anmutung */
.hero.hero-alpenstein{height:min(82vh,780px);min-height:560px;max-width:none;margin:0;padding:0;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--charcoal);position:relative;color:#fff;}
.hero-alpenstein .hero-media-grid{position:absolute;inset:0;display:block;height:auto;min-height:0;max-height:none;border-radius:0;background:#15233B;overflow:hidden;}
.hero-alpenstein .hero-tile{position:absolute;inset:0;display:none;border-radius:0;background:#15233B;}
.hero-alpenstein .hero-tile-main{display:block;}
.hero-alpenstein .hero-tile img{width:100%;height:100%;object-fit:cover;object-position:center;filter:saturate(.88) contrast(1.08) brightness(.75);transform:none!important;}
.hero-alpenstein .hero-tile-main:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,16,32,.34),rgba(7,16,32,.16) 42%,rgba(7,16,32,.72));}
.hero-alpenstein .hero-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center;width:min(920px,calc(100% - 48px));padding:116px 0 70px;color:#fff;}
.hero-alpenstein .hero-content:before{content:"";display:block;width:142px;height:84px;margin:0 auto 18px;background:linear-gradient(135deg,#fff 0 50%,transparent 50%) 34px 23px/26px 38px no-repeat,linear-gradient(135deg,#fff 0 50%,transparent 50%) 58px 9px/34px 52px no-repeat,linear-gradient(135deg,#fff 0 50%,transparent 50%) 88px 30px/22px 34px no-repeat;border-bottom:2px solid rgba(255,255,255,.85);opacity:.95;}
.hero-alpenstein h1{font-family:var(--font-body);font-size:clamp(42px,7vw,86px);font-weight:900;letter-spacing:.045em;line-height:.95;margin:0 0 18px;max-width:100%;text-transform:uppercase;color:#fff;text-shadow:0 14px 42px rgba(0,0,0,.34);}
.hero-alpenstein .hero-subtitle{font-size:clamp(12px,1.5vw,15px);font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.9);max-width:760px;margin:0 auto 12px;}
.hero-alpenstein .hero-desc{font-size:15px;line-height:1.75;color:rgba(255,255,255,.78);max-width:680px;margin:0 auto 24px;}
.hero-alpenstein .quickfacts{display:flex;flex-wrap:wrap;justify-content:center;gap:9px;margin:18px 0 0;}
.hero-alpenstein .quickfacts span{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.28);border-radius:999px;color:#fff;padding:9px 16px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;}
.hero-alpenstein .hero-cta{margin-top:22px;background:#fff;color:var(--charcoal)!important;}

/* Grundrhythmus: hellblauer Fond und große Typografie */
.section-inner{max-width:1180px;padding:84px 32px;}
.section-inner.slim{max-width:900px;}
.section-inner.two{grid-template-columns:1.05fr .95fr;gap:58px;align-items:center;}
.eyebrow{display:block;margin-bottom:13px;color:var(--gold);font-size:11px;font-weight:850;letter-spacing:.18em;text-transform:uppercase;}
h2{font-family:var(--font-body);font-size:clamp(34px,5vw,72px);font-weight:900;letter-spacing:.07em;line-height:.92;text-transform:uppercase;color:#334B86;margin:0 0 22px;}
h3{font-size:15px;font-weight:850;letter-spacing:.04em;text-transform:none;color:var(--dark);}
p,.description-text,.section-subline{color:#30405d;line-height:1.76;}
.section-subline,.trustline{max-width:780px;}
.booking-section,.description-section,.apartment-section,.availability-section,.gallery-section,.floorplan-section,.faq-section{background:#EAF3FA;}
.benefits-section,.amenities-section,.location-section,.rules-section,.reviews-section,.about-section,.info-section{background:#5872AF;color:#fff;}
.benefits-section h2,.amenities-section h2,.location-section h2,.rules-section h2,.reviews-section h2,.about-section h2,.info-section h2{color:#fff;}
.benefits-section .eyebrow,.amenities-section .eyebrow,.location-section .eyebrow,.rules-section .eyebrow,.reviews-section .eyebrow,.about-section .eyebrow,.info-section .eyebrow{color:rgba(255,255,255,.74);}
.benefits-section p,.amenities-section p,.location-section p,.rules-section p,.reviews-section p,.about-section p,.info-section p{color:rgba(255,255,255,.86);}

/* Buchung: schlank und zentriert */
.booking-section{padding-top:34px;}
.booking-section .section-inner{padding-top:42px;text-align:center;}
.booking-section h2{font-size:clamp(28px,4vw,52px);letter-spacing:.06em;}
.booking-card,.booking-widget{border-radius:0;background:#fff;border:1px solid rgba(36,58,100,.14);box-shadow:0 18px 50px rgba(36,58,100,.09);}
.booking-card{padding:28px;}
.booking-embed{background:#fff;}
.trustline{margin-left:auto;margin-right:auto;color:#52627e;}
.booking-extra-cta a,.availability-cta-button{background:#5B74B4!important;color:#fff!important;border-radius:999px!important;}

/* Unterkunft/Fakten: drei große Kacheln wie im Screenshot */
.apartment-section{text-align:left;}
.apartment-section .section-inner.two{grid-template-columns:1fr 1fr;}
.facts{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:34px;}
.facts div{background:transparent;border:0;border-radius:0;text-align:center;padding:0;color:#334B86;}
.facts b{font-family:var(--font-body);font-size:18px;font-weight:850;color:#334B86;display:block;font-style:italic;}
.facts span{font-size:12px;color:#6B7DA5;font-weight:700;letter-spacing:.05em;text-transform:none;}
.card-img{border-radius:0;box-shadow:0 18px 56px rgba(36,58,100,.14);overflow:hidden;}
.card-img img{min-height:360px;object-fit:cover;}

/* Kalender */
.availability-section{text-align:center;}
.availability-section h2{font-size:clamp(26px,4vw,54px);}
.availability-grid{gap:18px;}
.availability-month{background:#fff!important;border:1px solid rgba(36,58,100,.16)!important;border-radius:0!important;box-shadow:0 12px 32px rgba(36,58,100,.07)!important;}
.availability-month-label{font-family:var(--font-body)!important;font-weight:800!important;color:#334B86!important;letter-spacing:.08em!important;text-transform:uppercase!important;}
.availability-day.free{background:#5B74B4!important;color:#fff!important;border-color:#5B74B4!important;}
.availability-day.booked{background:#A2AAB9!important;color:#fff!important;border-color:#A2AAB9!important;}
.availability-day.past{background:#D9E3EE!important;color:#8794A8!important;}
.availability-day.is-selected{background:#334B86!important;border-color:#334B86!important;color:#fff!important;}
.availability-nav{border-radius:999px;border-color:#BFCBE0;color:#334B86;}
.availability-booking-widget{border-radius:0;border-color:rgba(36,58,100,.16);box-shadow:0 12px 36px rgba(36,58,100,.08);}
.availability-booking-widget h3{font-family:var(--font-body);font-weight:900;color:#334B86;letter-spacing:.04em;text-transform:uppercase;}

/* Blaue Ausstattungs-/Vorteile-Blöcke */
.benefits-section,.amenities-section,.location-section,.rules-section,.reviews-section,.about-section,.info-section{background:#5872AF;}
.benefit-grid,.info-grid,.review-grid{gap:18px;margin-top:36px;}
.benefit-grid{grid-template-columns:repeat(4,minmax(0,1fr));}
.benefit-grid article,.info-grid article,.review-grid article{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:0;padding:28px;box-shadow:none;color:#fff;}
.benefit-grid strong{font-family:var(--font-body);font-size:34px;font-weight:900;color:rgba(255,255,255,.25);}
.benefit-grid h3,.info-grid h3,.review-grid h3{color:#fff;}
.benefit-grid p,.info-grid p,.review-grid p{color:rgba(255,255,255,.84);}
.amenities-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;}
.amenities-grid article{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:0;padding:24px;color:#fff;box-shadow:none;}
.amenities-grid article h3{color:#fff;font-weight:850;}
.amenities-grid ul{padding-left:18px;margin:0;}
.amenities-grid li{color:rgba(255,255,255,.87);font-size:14px;margin:.32rem 0;}
.notice{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.24);border-radius:0;color:#fff;}
.extra-list span,.rules-list p{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.18);border-radius:0;color:#fff;}

/* Galerie: versetzte Bildcollage */
.gallery-section{background:#EAF3FA;}
.gallery-section .section-inner{text-align:center;}
.gallery-grid{display:block;columns:4 190px;column-gap:18px;margin-top:38px;text-align:left;}
.gallery-grid a.gallery-item{display:block;break-inside:avoid;margin:0 0 18px;border-radius:0;min-height:0;background:#D9E4F0;box-shadow:0 10px 30px rgba(36,58,100,.13);overflow:hidden;}
.gallery-grid a.gallery-item img{width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;border-radius:0;filter:saturate(.95) contrast(1.03);}
.gallery-grid a.gallery-item:nth-child(4n+1) img{aspect-ratio:3/4;}
.gallery-grid a.gallery-item:nth-child(5n+2) img{aspect-ratio:1/1;}
.gallery-grid a.gallery-item:nth-child(6n+4) img{aspect-ratio:4/5;}
.gallery-caption{font-size:13px;padding:18px;background:linear-gradient(to top,rgba(13,26,48,.72),rgba(13,26,48,0));}

/* Lage/Karte: große blaue Fläche */
.location-section .section-inner.two{grid-template-columns:1fr 1.15fr;}
.map-consent,#map{height:460px;border-radius:0;box-shadow:0 18px 48px rgba(8,18,36,.22);}
.map-consent:before{background:rgba(14,24,40,.46);}
.map-consent-box{border-radius:0;background:rgba(255,255,255,.94);color:var(--dark);}
.map-consent-box h3{color:var(--dark);}
.map-consent-box p{color:#30405d;}
.map-consent-box button{background:#5B74B4;color:#fff;border-radius:999px;}
.address{color:rgba(255,255,255,.82);}
.map-revoke{color:#fff!important;}

/* FAQ und Kontakt/Footer */
.faq-section{background:#EAF3FA;}
.faq-layout{grid-template-columns:.85fr 1.15fr;gap:52px;}
.faq-list details{background:transparent;border:0;border-bottom:1px solid rgba(36,58,100,.18);border-radius:0;margin:0;padding:19px 0;}
.faq-list summary{color:#334B86;font-weight:800;}
.faq-list details p{color:#30405d;}
.review-grid{grid-template-columns:repeat(3,1fr);}
.review-grid p{font-family:var(--font-body);font-size:18px;font-weight:520;line-height:1.58;}
footer{background:#243A64;color:#fff;border:0;}
.footer-inner{padding-top:56px;padding-bottom:36px;}
.footer-inner h2,footer h2{color:#fff;}
.legal-links a{color:rgba(255,255,255,.72);}
.copyright{border-top:1px solid rgba(255,255,255,.16);color:rgba(255,255,255,.55);}

/* Rechtliche Seiten */
.legal-page{background:#EAF3FA;}
.legal-wrap h1{font-family:var(--font-body);font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:#334B86;}
.legal-content{border-radius:0;border-color:rgba(36,58,100,.16);box-shadow:0 18px 50px rgba(36,58,100,.08);}
.back{color:#334B86;font-weight:800;}

/* Mobile */
@media(max-width:1180px){
  .nav-inner{padding-left:22px;padding-right:22px}.nav-links{gap:16px}.nav-links a{font-size:10px}.amenities-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:980px){
  .nav-wrap{padding:10px 12px;background:transparent;box-shadow:none}.nav-wrap.scrolled{padding:8px 12px;background:transparent}.nav-inner{border-radius:22px;background:rgba(36,58,100,.96);padding:10px 12px;box-shadow:0 10px 30px rgba(7,16,32,.25)}.mobile-brand-top{background:rgba(36,58,100,.96);color:#fff;box-shadow:0 10px 30px rgba(7,16,32,.25)}.mobile-brand-top .logo-img{filter:brightness(0) invert(1)}#mainMenu.nav-links{background:#243A64!important;color:#fff!important}#mainMenu.nav-links a,#mainMenu.nav-links a:not(.btn-book-nav){color:rgba(255,255,255,.82)!important;border-bottom:1px solid rgba(255,255,255,.12)!important}.nav-toggle{background:rgba(255,255,255,.12)}.nav-toggle span{background:#fff}.nav-actions .lang-switcher{display:none}.hero.hero-alpenstein{min-height:620px;height:auto}.hero-alpenstein .hero-content{padding-top:154px;padding-bottom:74px}.hero-alpenstein h1{font-size:clamp(40px,12vw,64px)}.hero-alpenstein .quickfacts{display:grid;grid-template-columns:1fr 1fr;width:100%;}.section-inner.two,.benefit-grid,.info-grid,.review-grid,.footer-inner,.faq-layout,.location-section .section-inner.two,.apartment-section .section-inner.two{grid-template-columns:1fr}.section-inner{padding-top:62px;padding-bottom:62px}.gallery-grid{columns:2 160px}.card-img img{min-height:260px}.availability-booking-layout{grid-template-columns:1fr}.availability-section--with-booking .availability-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:640px){
  .nav-wrap{padding:8px}.nav-actions>.btn-book-nav{font-size:0;padding:11px 13px}.nav-actions>.btn-book-nav:after{content:"Buchen";font-size:10px}.hero.hero-alpenstein{min-height:560px}.hero-alpenstein .hero-content{width:calc(100% - 28px);padding-top:136px}.hero-alpenstein .hero-content:before{width:104px;height:58px;margin-bottom:14px;transform:scale(.85)}.hero-alpenstein .hero-subtitle{letter-spacing:.14em}.hero-alpenstein .hero-desc{display:none}.hero-alpenstein .quickfacts{grid-template-columns:1fr}.section-inner{padding:48px 18px}h2{font-size:34px;letter-spacing:.05em}.facts{grid-template-columns:1fr;gap:12px}.amenities-grid{grid-template-columns:1fr}.gallery-grid{columns:2 130px;column-gap:10px}.gallery-grid a.gallery-item{margin-bottom:10px}.availability-section--with-booking .availability-grid{grid-template-columns:1fr}.availability-booking-widget{position:static}.btn-book-nav,.hero-cta,.big-link{max-width:100%}
}


/* =====================================================================
   Alpenstein 1.0.4 · variable Farben + kleinere Überschriften
   ---------------------------------------------------------------------
   Dieses Template nutzt ab hier konsequent die globalen Farbvariablen aus
   dem Editor. Die blauen Werte aus dem ursprünglichen Entwurf bleiben nur
   Default-Werte in theme.json/Palette, sind aber nicht mehr fest verdrahtet.
   ===================================================================== */
html,body{background:var(--theme-muted,var(--cream))!important;color:var(--theme-text,var(--dark))!important;}

/* Navigation */
.nav-wrap,.nav-wrap.scrolled{background:var(--theme-secondary,var(--charcoal))!important;box-shadow:0 8px 24px rgba(0,0,0,.16)!important;}
.nav-logo,.nav-links a,.nav-links a:hover,.nav-links a:focus,.nav-links a.is-active{color:var(--theme-white,#fff)!important;}
.nav-links a{opacity:.78;}.nav-links a:hover,.nav-links a:focus,.nav-links a.is-active{opacity:1;}
.lang-switcher{background:rgba(255,255,255,.08)!important;border-color:rgba(255,255,255,.18)!important;color:rgba(255,255,255,.72)!important;}
.lang-switcher a{color:rgba(255,255,255,.72)!important;}
.lang-switcher a.active{background:var(--theme-white,#fff)!important;color:var(--theme-secondary,var(--charcoal))!important;}
.btn-book-nav,.hero-cta,.big-link,.booking-extra-cta a,.availability-cta-button,.map-consent-box button{background:var(--theme-primary,var(--gold))!important;color:var(--theme-primary-contrast,var(--gold-contrast,#fff))!important;}
.btn-book-nav:hover,.hero-cta:hover,.big-link:hover{background:var(--theme-accent,var(--gold-lt))!important;color:var(--theme-primary-contrast,var(--gold-contrast,#fff))!important;}

/* Hero */
.hero.hero-alpenstein,.hero-alpenstein .hero-media-grid,.hero-alpenstein .hero-tile{background:var(--theme-secondary,var(--charcoal))!important;}
.hero-alpenstein .hero-content,.hero-alpenstein h1,.hero-alpenstein .hero-subtitle,.hero-alpenstein .hero-desc,.hero-alpenstein .quickfacts span{color:var(--theme-white,#fff)!important;}
.hero-alpenstein h1{font-size:clamp(29px,4.9vw,60px)!important;letter-spacing:.04em!important;}
.hero-alpenstein .hero-subtitle{font-size:clamp(11px,1.15vw,13px)!important;}
.hero-alpenstein .hero-desc{font-size:14px!important;}

/* Grundfarben der Inhaltsbereiche */
.booking-section,.description-section,.apartment-section,.availability-section,.gallery-section,.floorplan-section,.faq-section,.legal-page{background:var(--theme-muted,var(--cream))!important;}
.benefits-section,.amenities-section,.location-section,.rules-section,.reviews-section,.about-section,.info-section,footer{background:var(--theme-secondary,var(--charcoal))!important;color:var(--theme-white,#fff)!important;}

/* Überschriften ca. 30% kleiner */
h1,.legal-wrap h1{font-size:clamp(30px,4.2vw,48px)!important;}
h2{font-size:clamp(24px,3.5vw,50px)!important;line-height:1.02!important;color:var(--theme-secondary,var(--charcoal))!important;}
.booking-section h2{font-size:clamp(20px,2.8vw,36px)!important;}
.availability-section h2{font-size:clamp(18px,2.8vw,38px)!important;}
.availability-booking-widget h3{font-size:22px!important;color:var(--theme-secondary,var(--charcoal))!important;}
.availability-month-label{font-size:21px!important;color:var(--theme-secondary,var(--charcoal))!important;}
h3{color:var(--theme-text,var(--dark))!important;}
.eyebrow{color:var(--theme-primary,var(--gold))!important;}
.benefits-section h2,.amenities-section h2,.location-section h2,.rules-section h2,.reviews-section h2,.about-section h2,.info-section h2,footer h2,.footer-inner h2{color:var(--theme-white,#fff)!important;}
.benefits-section .eyebrow,.amenities-section .eyebrow,.location-section .eyebrow,.rules-section .eyebrow,.reviews-section .eyebrow,.about-section .eyebrow,.info-section .eyebrow{color:rgba(255,255,255,.78)!important;}

/* Textfarben */
p,.description-text,.section-subline,.trustline,.faq-list details p,.map-consent-box p{color:var(--theme-text,var(--dark))!important;}
.trustline,.facts span,.address,.availability-updated{color:var(--theme-text-muted,var(--stone))!important;}
.benefits-section p,.amenities-section p,.location-section p,.rules-section p,.reviews-section p,.about-section p,.info-section p{color:rgba(255,255,255,.86)!important;}
.facts div,.facts b,.faq-list summary,.legal-wrap h1,.back{color:var(--theme-secondary,var(--charcoal))!important;}

/* Karten, Rahmen, Flächen */
.booking-card,.booking-widget,.availability-month,.availability-booking-widget,.legal-content{background:var(--theme-white,#fff)!important;border-color:var(--theme-border,var(--sand))!important;box-shadow:0 12px 36px rgba(0,0,0,.07)!important;}
.gallery-grid a.gallery-item{background:var(--theme-surface,var(--sand))!important;box-shadow:0 10px 30px rgba(0,0,0,.10)!important;}
.benefit-grid article,.info-grid article,.review-grid article,.amenities-grid article,.notice,.extra-list span,.rules-list p{background:rgba(255,255,255,.08)!important;border-color:rgba(255,255,255,.18)!important;color:var(--theme-white,#fff)!important;}
.benefit-grid strong{font-size:24px!important;color:rgba(255,255,255,.25)!important;}
.benefit-grid h3,.info-grid h3,.review-grid h3,.amenities-grid article h3{color:var(--theme-white,#fff)!important;}
.amenities-grid li{color:rgba(255,255,255,.87)!important;}

/* Kalender */
.availability-day.free{background:var(--theme-primary,var(--gold))!important;color:var(--theme-primary-contrast,var(--gold-contrast,#fff))!important;border-color:var(--theme-primary,var(--gold))!important;}
.availability-day.booked{background:var(--theme-text-muted,var(--stone))!important;color:var(--theme-white,#fff)!important;border-color:var(--theme-text-muted,var(--stone))!important;}
.availability-day.past{background:var(--theme-surface,var(--sand))!important;color:var(--theme-text-muted,var(--stone))!important;}
.availability-day.is-selected{background:var(--theme-secondary,var(--charcoal))!important;border-color:var(--theme-secondary,var(--charcoal))!important;color:var(--theme-white,#fff)!important;}
.availability-day.today{outline-color:var(--theme-primary,var(--gold))!important;}
.availability-nav{border-color:var(--theme-border,var(--sand))!important;color:var(--theme-secondary,var(--charcoal))!important;}
.availability-nav:hover,.availability-nav:focus{background:var(--theme-primary,var(--gold))!important;border-color:var(--theme-primary,var(--gold))!important;color:var(--theme-primary-contrast,var(--gold-contrast,#fff))!important;}

/* Karte / FAQ / Footer */
.map-consent-box{background:var(--theme-white,#fff)!important;color:var(--theme-text,var(--dark))!important;}
.map-consent-box h3{color:var(--theme-text,var(--dark))!important;}
.faq-list details{border-bottom-color:var(--theme-border,var(--sand))!important;}
.legal-links a,.copyright{color:rgba(255,255,255,.7)!important;}

@media(max-width:980px){
  .nav-inner,.mobile-brand-top,#mainMenu.nav-links{background:var(--theme-secondary,var(--charcoal))!important;color:var(--theme-white,#fff)!important;}
  #mainMenu.nav-links a,#mainMenu.nav-links a:not(.btn-book-nav){color:rgba(255,255,255,.84)!important;border-bottom-color:rgba(255,255,255,.14)!important;}
  .hero-alpenstein h1{font-size:clamp(28px,8.4vw,45px)!important;}
}
@media(max-width:640px){
  .hero-alpenstein h1{font-size:clamp(28px,8.4vw,45px)!important;}
  h2{font-size:24px!important;letter-spacing:.045em!important;line-height:1.08!important;}
  .booking-section h2,.availability-section h2{font-size:22px!important;}
}


/* =====================================================================
   Alpenstein 1.0.5 · Hero-Branding + Bergpanorama-Divider
   ---------------------------------------------------------------------
   - Hero-Button bekommt mehr Luft und klebt nicht mehr am unteren Rand.
   - Festes CSS-Bergsymbol wurde durch dynamisches Branding ersetzt:
     logoInverse → logo → dezentes Bergsymbol-Fallback.
   - Bergpanorama-Trenner werden per CSS erzeugt und nutzen die aktiven
     Theme-Farben; keine zusätzlichen Bilddateien notwendig.
   ===================================================================== */
.hero-alpenstein .hero-content{padding-bottom:clamp(98px,12vh,150px)!important;gap:0;}
.hero-alpenstein .hero-content:before{content:none!important;display:none!important;}
.hero-brand-mark{display:flex;align-items:center;justify-content:center;margin:0 auto 22px;color:var(--theme-white,#fff);}
.hero-brand-mark--logo img{display:block;max-width:min(250px,58vw);max-height:112px;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 10px 32px rgba(0,0,0,.28));}
.hero-brand-mark--mountains svg{display:block;width:clamp(96px,14vw,152px);height:auto;opacity:.94;filter:drop-shadow(0 10px 28px rgba(0,0,0,.24));}
.hero-alpenstein .hero-cta{margin-top:clamp(26px,4vh,44px)!important;margin-bottom:0!important;position:relative;}
.hero-alpenstein .quickfacts{margin-top:20px!important;}

/* Sections mit Alpen-Silhouette als Übergang. Die Silhouette nutzt die
   Hintergrundfarbe der jeweiligen folgenden Section und funktioniert daher
   auch mit frei gewählten User-Farben. */
.booking-section,.amenities-section,.location-section,.faq-section,footer{position:relative;}
.booking-section::before,.amenities-section::before,.location-section::before,.faq-section::before,footer::before{
  content:"";position:absolute;left:0;right:0;top:-57px;height:58px;z-index:2;pointer-events:none;background:inherit;
  -webkit-clip-path:polygon(0 100%,0 78%,5% 75%,9% 57%,13% 72%,17% 44%,22% 74%,27% 52%,33% 78%,39% 36%,47% 80%,54% 58%,61% 76%,67% 32%,75% 77%,81% 56%,87% 80%,94% 49%,100% 76%,100% 100%);
  clip-path:polygon(0 100%,0 78%,5% 75%,9% 57%,13% 72%,17% 44%,22% 74%,27% 52%,33% 78%,39% 36%,47% 80%,54% 58%,61% 76%,67% 32%,75% 77%,81% 56%,87% 80%,94% 49%,100% 76%,100% 100%);
}
.booking-section::before{top:-63px;height:64px;opacity:1;}
.amenities-section::before,.location-section::before,footer::before{height:50px;top:-49px;}
.faq-section::before{height:44px;top:-43px;}
.booking-section,.amenities-section,.location-section,.faq-section,footer{scroll-margin-top:110px;}

@media(max-width:980px){
  .hero-alpenstein .hero-content{padding-bottom:clamp(86px,10vh,118px)!important;}
  .hero-brand-mark{margin-bottom:18px;}
  .hero-brand-mark--logo img{max-height:86px;}
  .booking-section::before,.amenities-section::before,.location-section::before,.faq-section::before,footer::before{height:38px;top:-37px;}
}
@media(max-width:640px){
  .hero-alpenstein .hero-content{padding-bottom:76px!important;}
  .hero-brand-mark{margin-bottom:14px;}
  .hero-brand-mark--logo img{max-width:min(210px,70vw);max-height:72px;}
  .hero-brand-mark--mountains svg{width:104px;}
  .hero-alpenstein .hero-cta{margin-top:22px!important;}
  .booking-section::before,.amenities-section::before,.location-section::before,.faq-section::before,footer::before{height:30px;top:-29px;}
}


/* =====================================================================
   Alpenstein 1.0.6 · weichere Bergpanorama-Divider
   ---------------------------------------------------------------------
   Die alte Clip-Path-Kante war zu grob und wurde je nach Abschnitt nur
   am Footer sichtbar. Die neuen Trenner sind echte SVG-Elemente im Markup
   und erscheinen gezielt an sinnvollen Übergängen:
   Hero → Inhalt, Galerie/Grundriss → Ausstattung, Inhalt → FAQ, FAQ → Footer.
   ===================================================================== */
.booking-section::before,.amenities-section::before,.location-section::before,.faq-section::before,footer::before{content:none!important;display:none!important;}
.alpen-divider{position:relative;z-index:5;height:clamp(24px,3.2vw,40px);margin-top:calc(clamp(24px,3.2vw,40px) * -1);margin-bottom:-1px;overflow:hidden;line-height:0;background:transparent;color:var(--alpen-divider-fill,var(--theme-muted,var(--cream)));pointer-events:none;}
.alpen-divider svg{position:relative;display:block;width:100%;height:calc(100% + 2px);margin-bottom:-1px;transform:translateY(1px);transform-origin:center;}
.alpen-divider .ridge-back{fill:currentColor;opacity:.14;}
.alpen-divider .ridge-front{fill:currentColor;opacity:1;}
.alpen-divider--hero{--alpen-divider-fill:var(--theme-muted,var(--cream));}
.alpen-divider--gallery-to-amenities,.alpen-divider--faq-to-footer{--alpen-divider-fill:var(--theme-secondary,var(--charcoal));}
.alpen-divider--content-to-faq{--alpen-divider-fill:var(--theme-muted,var(--cream));}
@media(max-width:640px){.alpen-divider{height:22px;margin-top:-22px;margin-bottom:-1px}}

/* =====================================================================
   Alpenstein Lodge · Raster-, Footer-, Kontrast- und Kalender-Korrekturen
   ===================================================================== */
.description-section .section-inner,
.description-section .section-inner.slim{
  max-width:1180px!important;
  width:100%!important;
  text-align:left!important;
}
.description-section .eyebrow,
.description-section h2{
  max-width:820px!important;
  width:auto!important;
}
.description-section .description-text{
  max-width:820px!important;
  width:auto!important;
  margin-left:0!important;
  margin-right:0!important;
}
footer .section-inner.footer-inner,
footer .copyright{
  max-width:1180px!important;
}
footer .copyright{
  padding:20px 32px!important;
  margin-left:auto!important;
  margin-right:auto!important;
}
.footer-contact a,
.footer-contact a:visited,
.footer-contact p,
.legal-links a,
.legal-links a:visited{
  color:rgba(255,255,255,.7)!important;
}
.footer-contact a,
.legal-links a{
  text-decoration:none;
}
.footer-contact a:hover,
.footer-contact a:focus,
.legal-links a:hover,
.legal-links a:focus{
  color:var(--theme-white,#fff)!important;
}
.location-section .map-consent-box,
.location-section .map-consent-box h3,
.location-section .map-consent-box p{
  color:var(--theme-text,var(--dark))!important;
}
.availability-day.is-in-range:not(.is-selected),
.availability-day.free.is-in-range:not(.is-selected){
  background:var(--theme-accent,var(--gold-lt))!important;
  border-color:var(--theme-primary,var(--gold))!important;
  color:var(--theme-text,var(--dark))!important;
  box-shadow:inset 0 0 0 1px var(--theme-primary,var(--gold))!important;
}
.hero-alpenstein .hero-cta{
  color:var(--theme-primary-contrast,var(--gold-contrast,#fff))!important;
}
@media(max-width:640px){
  footer .copyright{padding-left:18px!important;padding-right:18px!important;}
}
