:root{
  --bg:#F4EDE1; --bg-2:#EFE6D6; --paper:#FCF8F1; --ink:#34302A; --ink-soft:#6c655b;
  --clay:#B5532A; --clay-dk:#8f3f1f; --sage:#5E7355; --sage-dk:#4a5c43; --sand:#E0A458;
  --line:#e3d8c6; --maxw:1140px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--ink);font-family:'Karla',sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;}
h1,h2,h3{font-family:'Playfair Display',serif;font-weight:700;line-height:1.15;color:#2c2722;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.eyebrow{font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--clay);}
.btn{display:inline-block;font-weight:700;font-size:16px;padding:14px 26px;border-radius:5px;cursor:pointer;transition:.18s;border:none;}
.btn-primary{background:var(--clay);color:#fff;}
.btn-primary:hover{background:var(--clay-dk);}
.btn-ghost{background:transparent;border:1.5px solid var(--clay);color:var(--clay-dk);}
.btn-light{background:rgba(255,255,255,.14);border:1.5px solid rgba(255,255,255,.65);color:#fff;backdrop-filter:blur(4px);}

/* nav */
header{position:sticky;top:0;z-index:50;background:rgba(244,237,225,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);}
nav{display:flex;align-items:center;justify-content:space-between;height:74px;}
.logo{font-family:'Playfair Display',serif;font-size:23px;font-weight:700;color:var(--clay-dk);}
.logo small{display:block;font-family:'Karla';font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--sage);font-weight:600;}
.menu{display:flex;gap:26px;align-items:center;font-size:15px;font-weight:600;color:#54504a;}
.menu a:hover{color:var(--clay);}
.menu .btn{padding:10px 18px;font-size:15px;}
.burger{display:none;font-size:26px;color:var(--clay-dk);}

/* hero */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;
  background:linear-gradient(rgba(44,30,20,.42),rgba(44,30,20,.55)),url('/assets/img/hero.jpg') center/cover;color:#fff;}
.hero .wrap{padding-top:60px;padding-bottom:60px;}
.hero-inner{max-width:660px;}
.hero .eyebrow{color:#f2d9b8;}
.hero h1{color:#fff;font-size:clamp(38px,6vw,62px);margin:16px 0 20px;text-shadow:0 2px 30px rgba(0,0,0,.35);}
.hero p{font-size:19px;max-width:46ch;margin-bottom:30px;opacity:.96;}
.hero .btns{display:flex;gap:14px;flex-wrap:wrap;}

/* feature strip */
.strip{background:var(--sage);color:#fff;}
.strip .wrap{display:flex;flex-wrap:wrap;}
.strip .item{flex:1 1 0;min-width:160px;padding:20px 12px;text-align:center;border-right:1px solid rgba(255,255,255,.18);}
.strip .item:last-child{border-right:none;}
.strip b{font-family:'Playfair Display',serif;font-size:20px;display:block;}
.strip span{font-size:13.5px;opacity:.88;}

/* section base */
section.block{padding:84px 0;}
.section-head{text-align:center;max-width:640px;margin:0 auto 50px;}
.section-head h2{font-size:clamp(28px,4vw,40px);margin:12px 0 14px;}
.section-head p{color:var(--ink-soft);font-size:17px;}

/* welcome split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;}
.split img{border-radius:10px;box-shadow:0 18px 40px rgba(60,40,20,.18);height:100%;object-fit:cover;min-height:340px;}
.split h2{font-size:clamp(26px,3.5vw,36px);margin:12px 0 16px;}
.split p{color:var(--ink-soft);margin-bottom:14px;}

/* apartments */
.apts{background:var(--bg-2);}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.card{background:var(--paper);border-radius:10px;overflow:hidden;box-shadow:0 10px 26px rgba(60,40,20,.10);transition:.2s;border:1px solid var(--line);}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 38px rgba(60,40,20,.16);}
.card .ph{height:200px;background-size:cover;background-position:center;position:relative;}
.card .badge{position:absolute;top:12px;left:12px;background:var(--clay);color:#fff;font-size:12px;font-weight:700;padding:5px 11px;border-radius:4px;letter-spacing:.03em;}
.card .body{padding:20px 22px 24px;}
.card h3{font-size:22px;margin-bottom:6px;}
.card .meta{font-size:14px;color:var(--sage-dk);font-weight:600;margin-bottom:10px;}
.card p{font-size:14.5px;color:var(--ink-soft);margin-bottom:16px;}
.card .more{color:var(--clay-dk);font-weight:700;font-size:14.5px;}
.card.feature{grid-column:span 3;display:grid;grid-template-columns:1.3fr 1fr;}
.card.feature .ph{height:auto;min-height:280px;}
.card.feature .body{padding:34px 36px;display:flex;flex-direction:column;justify-content:center;}
.card.feature h3{font-size:28px;}
.card.feature .badge{background:var(--sage);}

/* calendar teaser */
.cal-teaser .split{align-items:stretch;}
.cal-card{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:24px;box-shadow:0 10px 26px rgba(60,40,20,.10);}
.cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.cal-head h3{font-size:20px;}
.cal-head span{font-size:14px;color:var(--ink-soft);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;}
.cal-grid .dow{font-size:11px;font-weight:700;color:var(--ink-soft);text-align:center;padding-bottom:4px;text-transform:uppercase;letter-spacing:.05em;}
.cal-grid .day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:13px;border-radius:5px;background:#eef3e9;color:#3f4a37;font-weight:600;}
.cal-grid .day.bel{background:#f0d9cd;color:var(--clay-dk);text-decoration:line-through;}
.cal-grid .day.muted{background:transparent;color:#c9bfb0;}
.legend{display:flex;gap:18px;margin-top:16px;font-size:13.5px;align-items:center;flex-wrap:wrap;}
.legend i{display:inline-block;width:14px;height:14px;border-radius:3px;margin-right:6px;vertical-align:-2px;}

/* gallery */
.gallery{background:var(--bg-2);}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:170px;gap:12px;}
.gal-grid div{background-size:cover;background-position:center;border-radius:8px;}
.gal-grid .tall{grid-row:span 2;}
.gal-grid .wide{grid-column:span 2;}

/* CTA band */
.cta-band{background:linear-gradient(rgba(44,30,20,.7),rgba(44,30,20,.78)),url('/assets/img/fotos/hof-feuer.jpg') center/cover;color:#fff;text-align:center;}
.cta-band h2{color:#fff;font-size:clamp(28px,4vw,40px);margin-bottom:14px;}
.cta-band p{opacity:.95;font-size:18px;margin-bottom:26px;}

/* footer */
footer{background:#2a2620;color:#d8cfc1;font-size:14.5px;}
footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;padding:56px 24px 30px;}
footer h4{font-family:'Playfair Display',serif;color:#fff;font-size:19px;margin-bottom:14px;}
footer .logo{color:#fff;margin-bottom:14px;}
footer a:hover{color:var(--sand);}
footer ul{list-style:none;}
footer li{margin-bottom:9px;}
.copyright{border-top:1px solid #443e35;text-align:center;padding:18px;font-size:13px;color:#9a8f7e;}

@media(max-width:900px){
  .menu{display:none;} .burger{display:block;}
  .split{grid-template-columns:1fr;gap:28px;}
  .grid{grid-template-columns:1fr 1fr;}
  .card.feature{grid-column:span 2;grid-template-columns:1fr;}
  .card.feature .ph{min-height:200px;}
  .gal-grid{grid-template-columns:repeat(2,1fr);}
  footer .wrap{grid-template-columns:1fr;}
}
@media(max-width:560px){ .grid{grid-template-columns:1fr;} .card.feature{grid-column:span 1;} }

.menu.is-open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;gap:0;background:var(--bg);border-bottom:1px solid var(--line);padding:8px 24px 16px;}
.menu.is-open a{padding:12px 0;border-bottom:1px solid var(--line);}
.menu a.is-active{color:var(--clay);}
.burger{background:none;border:none;cursor:pointer;}
@media(max-width:900px){ .burger{display:block;} }

/* ===== Inhaltsseiten (Plan 2) ===== */
.page-hero{background:linear-gradient(rgba(44,30,20,.5),rgba(44,30,20,.6)),var(--sage);color:#fff;padding:64px 0;}
.page-hero.with-photo{background:linear-gradient(rgba(44,30,20,.5),rgba(44,30,20,.62)),url('/assets/img/hero.jpg') center/cover;}
.page-hero .eyebrow{color:#f2d9b8;}
.page-hero h1{color:#fff;font-size:clamp(30px,5vw,46px);margin-top:10px;}
.page-hero p{max-width:60ch;margin-top:12px;font-size:18px;opacity:.95;}

.prose{max-width:720px;margin:0 auto;}
.prose h2{font-size:clamp(24px,3.5vw,32px);margin:32px 0 12px;}
.prose h3{font-size:21px;margin:24px 0 8px;}
.prose p{margin-bottom:16px;color:var(--ink-soft);}
.prose ul{margin:0 0 16px 22px;color:var(--ink-soft);}
.prose li{margin-bottom:6px;}
.note{background:var(--bg-2);border-left:4px solid var(--sand);padding:14px 18px;border-radius:6px;margin:18px 0;color:var(--ink-soft);font-size:15px;}

.facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;list-style:none;margin:24px 0;}
.facts li{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:14px 16px;}
.facts b{display:block;font-family:'Playfair Display',serif;color:var(--clay-dk);font-size:18px;}
.facts span{font-size:13.5px;color:var(--ink-soft);}

.apt-detail{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:start;}
.apt-detail .photo{border-radius:10px;overflow:hidden;box-shadow:0 18px 40px rgba(60,40,20,.18);}
.apt-detail .photo img{width:100%;height:100%;object-fit:cover;min-height:300px;}
.apt-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-top:14px;}
.apt-strip img{border-radius:8px;height:110px;width:100%;object-fit:cover;}

.cal-placeholder{background:var(--paper);border:1px dashed var(--sage);border-radius:10px;padding:26px;text-align:center;color:var(--ink-soft);margin:14px 0;}
.cal-placeholder b{font-family:'Playfair Display',serif;color:var(--sage-dk);font-size:18px;}

.price-table{width:100%;border-collapse:collapse;margin:18px 0;background:var(--paper);border:1px solid var(--line);border-radius:10px;overflow:hidden;}
.price-table th,.price-table td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line);}
.price-table th{background:var(--sage);color:#fff;font-family:'Karla';font-weight:700;}
.price-table tr:last-child td{border-bottom:none;}
.price-table td:not(:first-child){text-align:center;font-weight:600;}
.price-table .highlight{background:#fbf1e8;}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start;}
.contact-card{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:24px;}
.contact-card h3{font-size:20px;margin-bottom:10px;}
.map-embed{border-radius:10px;overflow:hidden;border:1px solid var(--line);min-height:300px;background:var(--bg-2);display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;color:var(--ink-soft);}

@media(max-width:820px){
  .apt-detail{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
}

/* ===== Galerie + Lightbox (Plan 3) ===== */
.gal-section{margin-bottom:44px;}
.gal-section h2{font-size:clamp(22px,3vw,30px);margin-bottom:6px;}
.gal-section .eyebrow{margin-bottom:4px;}
.gal-masonry{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:16px;}
.gal-masonry button{padding:0;border:none;background:none;cursor:pointer;border-radius:8px;overflow:hidden;aspect-ratio:4/3;}
.gal-masonry img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s;}
.gal-masonry button:hover img{transform:scale(1.05);}
.lb{position:fixed;inset:0;background:rgba(20,14,9,.92);display:none;align-items:center;justify-content:center;z-index:1000;}
.lb.open{display:flex;}
.lb img{max-width:92vw;max-height:86vh;border-radius:6px;box-shadow:0 10px 50px rgba(0,0,0,.5);}
.lb button{position:absolute;background:rgba(255,255,255,.12);color:#fff;border:none;font-size:30px;width:54px;height:54px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.lb .lb-close{top:18px;right:18px;font-size:24px;}
.lb .lb-prev{left:18px;top:50%;transform:translateY(-50%);}
.lb .lb-next{right:18px;top:50%;transform:translateY(-50%);}
.lb button:hover{background:rgba(255,255,255,.25);}
@media(max-width:560px){ .lb .lb-prev,.lb .lb-next{width:44px;height:44px;font-size:24px;} }

/* ===== Belegungskalender interaktiv (Plan 4) ===== */
.cal-card .cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.cal-nav{background:var(--bg-2);border:1px solid var(--line);border-radius:6px;width:34px;height:34px;font-size:18px;cursor:pointer;color:var(--clay-dk);}
.cal-nav:hover{background:var(--clay);color:#fff;}
.day.frei{background:#eef3e9;color:#3f4a37;}
.legend .i-frei,.legend .i-bel{display:inline-block;width:14px;height:14px;border-radius:3px;margin-right:6px;vertical-align:-2px;}
.legend .i-frei{background:#eef3e9;}
.legend .i-bel{background:#f0d9cd;}
.cal-multi{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;}
.cal-multi h3{margin-bottom:12px;}
/* Admin-Editor */
.adm-day{cursor:pointer;}
.adm-day.sel{background:#f0d9cd;color:var(--clay-dk);outline:2px solid var(--clay);}
.adm-bar{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin:16px 0;}
.adm-bar select{padding:8px 10px;border:1px solid var(--line);border-radius:6px;}
.login-box{max-width:380px;margin:48px auto;background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:30px;}
.login-box input{width:100%;padding:12px;border:1px solid var(--line);border-radius:6px;margin:12px 0;font-size:16px;}
/* ===== Anfrageformular (Plan 5) ===== */
.anfrage-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.anfrage-form label{display:block;font-weight:600;font-size:14px;color:var(--ink);margin-bottom:14px;}
.anfrage-form input,.anfrage-form select,.anfrage-form textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:6px;font-size:16px;font-family:inherit;margin-top:5px;background:var(--paper);}
.anfrage-form textarea{resize:vertical;}
.anfrage-form .check{font-weight:400;display:flex;gap:8px;align-items:flex-start;}
.anfrage-form .check input{width:auto;margin-top:4px;}
.anfrage-form .cap input{font-weight:400;}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.form-msg{padding:14px 18px;border-radius:8px;margin-bottom:18px;}
.form-msg.ok{background:#e9f3e6;border-left:4px solid var(--sage);color:var(--sage-dk);}
.form-msg.err{background:#f6e2da;border-left:4px solid var(--clay);color:var(--clay-dk);}
.preis-box{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:14px 18px;margin-bottom:18px;font-size:15px;}
.preis-box strong{font-family:'Playfair Display',serif;font-size:20px;color:var(--clay-dk);}
@media(max-width:620px){ .anfrage-form .form-grid{grid-template-columns:1fr;} }
