/* 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)}
