:root{
  --bg:#F7F6F2;
  --card:#fffefa;
  --text:#333333;
  --muted:#70756e;
  --green:#2F4B3F;
  --soft:#E6E2D8;
  --accent:#8FA48F;
  --line:#ded8cd;
  --danger:#8d3b35;
}
*{box-sizing:border-box}
body{margin:0;background:radial-gradient(circle at top left,#eef0e9,var(--bg) 36%);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
.guest-app,.admin-app{width:min(1080px,calc(100% - 28px));margin:20px auto 70px}
.hero{min-height:58vh;border-radius:34px;overflow:hidden;background-image:linear-gradient(180deg,rgba(20,30,24,.08),rgba(20,30,24,.72)),url("fallback-hero.jpeg");background-size:cover;background-position:center;display:flex;align-items:end;box-shadow:0 28px 80px rgba(47,75,63,.16)}
.heroOverlay{color:white;padding:clamp(24px,5vw,56px);width:min(800px,100%)}
.eyebrow{text-transform:uppercase;letter-spacing:.14em;font-weight:850;color:var(--accent);margin:0 0 10px}
.hero .eyebrow{color:#e9f0e4}
h1{font-size:clamp(2.1rem,6vw,4.8rem);line-height:.98;letter-spacing:-.06em;margin:0 0 18px}
h2{color:var(--green);margin:0 0 18px}
h3{color:var(--green)}
p{line-height:1.55}
.hero p{font-size:1.15rem}
.stayBadge{display:inline-block;margin-top:14px;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.35);backdrop-filter:blur(12px);border-radius:999px;padding:10px 14px;font-weight:850}
.quickInfo{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:16px 0}
.quickInfo article,.card{background:rgba(255,254,250,.94);border:1px solid var(--line);border-radius:26px;padding:22px;box-shadow:0 18px 50px rgba(47,75,63,.08)}
.quickInfo article span:first-child{font-size:1.7rem}
.quickInfo b{display:block;margin:8px 0 4px;color:var(--green)}
.quickInfo p{margin:0;color:var(--muted)}
.development{margin:16px 0 0}
.development p{margin:8px 0 0;color:var(--muted)}
.mainNav{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;position:sticky;top:0;background:rgba(247,246,242,.88);backdrop-filter:blur(16px);padding:12px 0;z-index:2}
button,.previewLink{border:0;border-radius:999px;background:var(--soft);color:var(--green);padding:15px 18px;font:inherit;font-weight:850;cursor:pointer;text-decoration:none;text-align:center;display:inline-block}
button.active,button[type=submit]{background:var(--green);color:white}
button.secondary{background:#f0eee8;color:var(--green)}
button.danger{background:#f4e5e2;color:var(--danger)}
.content{margin-top:6px}
.infoGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.infoCard{border:1px solid var(--line);background:#fbfaf6;border-radius:22px;padding:18px}
.infoCard h3{margin:0 0 8px;color:var(--green)}
.infoCard p{margin:0;white-space:pre-line}
.feedbackForm{display:grid;gap:14px;margin-top:18px}
.feelingChoices{display:flex;flex-wrap:wrap;gap:10px}
.feelingChoices label{display:inline-flex;align-items:center;gap:8px;margin:0;border:1px solid var(--line);background:#fbfaf6;border-radius:999px;padding:10px 12px;font-weight:750}
.adminHeader{display:flex;justify-content:space-between;align-items:center;margin:30px 0 18px}
.adminLayout{display:grid;grid-template-columns:300px 1fr;gap:16px;margin-bottom:16px}
.groupButton{width:100%;display:block;text-align:left;margin:8px 0;border-radius:18px;background:#fbfaf6}
.groupButton.active{background:var(--green);color:white}
.twoCols{display:grid;grid-template-columns:1fr 1fr;gap:14px}
label{display:grid;gap:8px;font-weight:800;margin-bottom:16px}
input,textarea{border:1px solid var(--line);border-radius:16px;padding:13px;font:inherit;background:white;width:100%}
textarea{min-height:120px}
small{color:var(--muted);font-weight:500}
.feedbackItem{border-top:1px solid var(--line);padding:14px 0}
@media(max-width:820px){
  .hero{min-height:64vh;border-radius:24px}
  .quickInfo,.mainNav,.adminLayout,.twoCols{grid-template-columns:1fr}
  .adminHeader{display:block}
}

.stayBadgeLight{display:inline-block;margin:4px 4px 4px 0;background:var(--soft);border-radius:999px;padding:8px 10px;color:var(--green);font-weight:800}
fieldset{border:0;padding:0;margin:0} legend{font-weight:800;margin-bottom:10px;color:var(--green)}


/* v0.5 – Inhaltskarten und großzügiger Eindruck-Bereich */
.muted{color:var(--muted)}
.featureGrid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.featureCard{
  border:1px solid var(--line);
  background:#fbfaf6;
  border-radius:24px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height:100%;
}
.featureImage{
  min-height:150px;
  background:linear-gradient(135deg,#E6E2D8,#F7F6F2);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--green);
  font-size:3rem;
}
.featureImage img{
  width:100%;
  height:180px;
  object-fit:cover;
  display:block;
}
.featureBody{
  padding:18px;
  display:grid;
  gap:10px;
}
.featureBody h3{
  margin:0;
  color:var(--green);
}
.featureBody p{
  margin:0;
  color:var(--muted);
}
.moreButton{
  justify-self:start;
  margin-top:4px;
  padding:10px 14px;
  font-size:.95rem;
}
.detailBox{
  margin-top:18px;
  border:1px solid var(--line);
  background:#fffefa;
  border-radius:22px;
  padding:20px;
}
.detailBox h3{
  margin-top:0;
}
.detailBox p{
  white-space:pre-line;
}
.impressionSection{
  margin-top:20px;
  padding:26px;
  border-radius:26px;
  background:linear-gradient(135deg,#fffefa,#f3f1ea);
  border:1px solid var(--line);
}
.impressionSection h2{
  font-size:clamp(1.8rem,4vw,3rem);
  letter-spacing:-.04em;
}
.impressionIntro{
  color:var(--muted);
  max-width:680px;
  margin-bottom:22px;
}
.feelingChoices{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin:14px 0 20px;
}
.feelingChoices label{
  min-height:92px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  gap:7px;
  margin:0;
  border:1px solid var(--line);
  background:#fbfaf6;
  border-radius:20px;
  padding:16px;
  font-weight:850;
  cursor:pointer;
  transition:transform .12s ease, border-color .12s ease, background .12s ease;
}
.feelingChoices label:hover{
  transform:translateY(-1px);
  border-color:var(--accent);
}
.feelingChoices input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.feelingChoices label:has(input:checked){
  background:var(--green);
  color:white;
  border-color:var(--green);
}
.feelingEmoji{font-size:1.65rem;line-height:1}
.feelingText{font-size:1rem}
.cardEditorItem{
  border:1px solid var(--line);
  background:#fbfaf6;
  border-radius:24px;
  padding:18px;
  margin:14px 0;
}
.cardEditorItem header{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:baseline;
  margin-bottom:12px;
}
.cardEditorItem header strong{
  color:var(--green);
}
.cardEditorItem img{
  width:100%;
  max-height:180px;
  object-fit:cover;
  border-radius:16px;
  margin:8px 0 12px;
}
@media(max-width:820px){
  .featureGrid,.feelingChoices{grid-template-columns:1fr}
}
@media(max-width:520px){
  .feelingChoices{grid-template-columns:1fr 1fr}
  .featureGrid{grid-template-columns:1fr}
}


/* v0.5.1 – Info-Banner, Wohnen/Küche/Gut zu wissen */
.checkLabel{
  display:flex;
  align-items:center;
  gap:10px;
  margin:12px 0 18px;
}
.checkLabel input{
  width:auto;
}
.ruleList{
  display:grid;
  gap:12px;
  margin-top:14px;
}
.ruleItem{
  border:1px solid var(--line);
  background:#fffefa;
  border-radius:18px;
  padding:14px;
}
.ruleItem h4{
  margin:0 0 6px;
  color:var(--green);
}
.ruleItem p{
  margin:0;
  color:var(--muted);
  white-space:pre-line;
}


/* v0.6 – Reisegruppenlinks und editierbares Feedback */
.shareBox{
  border:1px solid var(--line);
  background:#fbfaf6;
  border-radius:20px;
  padding:16px;
  margin:12px 0 18px;
  display:grid;
  gap:10px;
}
.shareBox input{
  font-size:.95rem;
  color:var(--green);
  background:white;
}
.questionIntro{
  font-weight:850;
  color:var(--green);
  margin:16px 0 10px;
}


/* v0.7 – QR-Code und druckbare Willkommenskarte */
.shareButtons{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.qrPreview{
  display:flex;
  gap:14px;
  align-items:center;
  padding:12px;
  background:white;
  border:1px solid var(--line);
  border-radius:18px;
}
.qrPreview img{
  width:112px;
  height:112px;
  border-radius:12px;
  background:white;
}
.printBody{
  background:#ece8de;
}
.printPage{
  width:min(860px,calc(100% - 28px));
  margin:24px auto;
}
.welcomeCardPrint{
  width:100%;
  aspect-ratio:1.414 / 1;
  border-radius:34px;
  overflow:hidden;
  background-image:linear-gradient(180deg,rgba(20,30,24,.12),rgba(20,30,24,.68)),url("fallback-hero.jpeg");
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:end;
  box-shadow:0 24px 80px rgba(47,75,63,.22);
}
.welcomeCardOverlay{
  color:white;
  padding:48px;
  width:100%;
  display:grid;
  grid-template-columns:1fr auto;
  gap:24px;
  align-items:end;
}
.welcomeCardOverlay .eyebrow,
.welcomeCardOverlay h1,
.welcomeCardOverlay p{
  grid-column:1;
}
.welcomeCardOverlay h1{
  font-size:clamp(2.2rem,6vw,4.8rem);
  margin:0;
}
.welcomeCardOverlay p{
  max-width:560px;
  font-size:1.08rem;
}
.qrBoxPrint{
  grid-column:2;
  grid-row:1 / span 3;
  align-self:end;
  background:rgba(255,255,255,.93);
  color:var(--green);
  border-radius:24px;
  padding:16px;
  text-align:center;
  font-weight:850;
  min-width:190px;
}
.qrBoxPrint img{
  width:170px;
  height:170px;
  display:block;
  margin:auto;
}
.qrBoxPrint p{
  margin:8px 0 0;
  color:var(--green);
  font-size:.95rem;
}
.printControls{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
  margin:20px 0;
}
@media(max-width:720px){
  .welcomeCardOverlay{
    grid-template-columns:1fr;
    padding:28px;
  }
  .qrBoxPrint{
    grid-column:1;
    grid-row:auto;
    justify-self:start;
  }
}
@media print{
  body.printBody{
    background:white;
  }
  .printPage{
    width:100%;
    margin:0;
  }
  .printControls{
    display:none;
  }
  .welcomeCardPrint{
    border-radius:0;
    box-shadow:none;
    width:100vw;
    height:100vh;
    aspect-ratio:auto;
  }
}


/* v0.7.1 – zuverlässiger PDF-Druck der Willkommenskarte */
.welcomeCardPrint{
  position:relative;
  background:none !important;
  isolation:isolate;
}
.printHeroImage{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
}
.printShade{
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(180deg,rgba(20,30,24,.12),rgba(20,30,24,.70));
}
.welcomeCardOverlay{
  position:relative;
  z-index:2;
}
.welcomeTextBlock{
  min-width:0;
}
.printHint{
  text-align:center;
  color:var(--muted);
  font-size:.9rem;
  margin:14px auto 0;
  max-width:680px;
}
.welcomeCardPrint,
.welcomeCardPrint *{
  -webkit-print-color-adjust:exact;
  print-color-adjust:exact;
}
@media print{
  @page{
    size:A4 landscape;
    margin:0;
  }
  html,body{
    width:297mm;
    height:210mm;
  }
  .printHint{
    display:none;
  }
  .printHeroImage,
  .qrBoxPrint img{
    display:block !important;
    visibility:visible !important;
  }
  .welcomeCardPrint{
    width:297mm;
    height:210mm;
  }
}


/* v0.8 – echte PDF-Erzeugung */
button:disabled{
  opacity:.62;
  cursor:wait;
}


/* v0.8.1 – Safari-sichere Druckansicht als einzelnes Bild */
.singleImageMode{
  background:white !important;
}
.singlePrintImage{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
@media print{
  .singleImageMode{
    width:297mm !important;
    height:210mm !important;
  }
  .singlePrintImage{
    width:297mm !important;
    height:210mm !important;
    object-fit:cover !important;
  }
}


/* v0.9 – separates Export-Modul */
.exportComposer{
  margin-bottom:18px;
}
.exportComposer h1{
  font-size:clamp(2rem,5vw,3.8rem);
}
.composerGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.composerGrid label:first-child,
.composerGrid label:nth-child(3){
  grid-column:1 / -1;
}
.composerActions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}
.canvasPreview{
  overflow:auto;
}
.canvasPreview canvas{
  width:100%;
  max-width:100%;
  height:auto;
  border-radius:24px;
  box-shadow:0 18px 50px rgba(47,75,63,.12);
}
@media(max-width:760px){
  .composerGrid{
    grid-template-columns:1fr;
  }
}


/* v1.0 – Admin-Login */
.loginScreen{
  position:fixed;
  inset:0;
  z-index:9999;
  background:radial-gradient(circle at top left,#eef0e9,var(--bg) 42%);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.loginCard{
  width:min(460px,100%);
  background:rgba(255,254,250,.96);
  border:1px solid var(--line);
  border-radius:30px;
  padding:30px;
  box-shadow:0 28px 90px rgba(47,75,63,.16);
}
.loginCard h1{
  font-size:clamp(2rem,6vw,3.4rem);
  margin-bottom:24px;
}
.loginError{
  color:var(--danger);
  font-weight:800;
}
body:not(.adminUnlocked) .admin-app{
  display:none;
}
body.adminUnlocked .loginScreen{
  display:none;
}
.headerActions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}


/* v1.1 – öffentliche Startseite */
.public-app{
  width:min(1080px,calc(100% - 28px));
  margin:20px auto 70px;
}
.publicHero{
  min-height:68vh;
  border-radius:34px;
  overflow:hidden;
  background:
    linear-gradient(180deg,rgba(20,30,24,.10),rgba(20,30,24,.70)),
    radial-gradient(circle at 20% 20%,#8FA48F,#2F4B3F 70%);
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:end;
  box-shadow:0 28px 80px rgba(47,75,63,.16);
}
.publicHeroOverlay{
  color:white;
  padding:clamp(24px,5vw,56px);
  width:min(820px,100%);
}
.publicHeroOverlay .eyebrow{
  color:#e9f0e4;
}
.publicHeroOverlay p{
  font-size:1.18rem;
  line-height:1.55;
}
.publicIntroCard{
  margin-top:16px;
}
.publicImpressions{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.publicImpression{
  border:1px solid var(--line);
  background:#fbfaf6;
  border-radius:24px;
  overflow:hidden;
}
.publicImpressionImage{
  height:190px;
  background:linear-gradient(135deg,#E6E2D8,#F7F6F2);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--green);
  font-size:3rem;
}
.publicImpressionImage img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.publicImpression div:last-child{
  padding:18px;
}
.publicImpression h3{
  margin:0 0 8px;
  color:var(--green);
}
.publicImpression p{
  margin:0;
  color:var(--muted);
  white-space:pre-line;
}
.contactForm{
  display:grid;
  gap:14px;
}
@media(max-width:820px){
  .publicHero{
    min-height:64vh;
    border-radius:24px;
  }
  .publicImpressions{
    grid-template-columns:1fr;
  }
}


/* v1.2 – Admin-Cockpit */
.adminCockpit{
  display:grid;
  grid-template-columns:230px 1fr;
  gap:16px;
  align-items:start;
}
.adminNav{
  position:sticky;
  top:16px;
  display:grid;
  gap:8px;
}
.adminTab{
  width:100%;
  text-align:left;
  border-radius:18px;
  background:#fbfaf6;
}
.adminTab.active{
  background:var(--green);
  color:white;
}
.adminPanel{
  display:none;
}
.adminPanel.active{
  display:block;
}
.groupsCockpit{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:16px;
  align-items:start;
}
.groupButton{
  display:grid !important;
  gap:4px;
  width:100%;
  text-align:left;
  border-radius:18px;
  margin:8px 0;
}
.groupButton strong{
  font-size:1rem;
}
.groupButton span{
  font-size:.9rem;
  opacity:.78;
}
.groupCardPanel{
  min-height:520px;
}
.groupDashboard{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:18px;
}
.groupDashboard h2{
  font-size:clamp(1.8rem,4vw,3rem);
  letter-spacing:-.04em;
  margin-bottom:6px;
}
.dashboardBadges{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.subTabs{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin:12px 0 20px;
}
.subTab{
  background:#f0eee8;
  color:var(--green);
  padding:11px 14px;
}
.subTab.active{
  background:var(--green);
  color:white;
}
.subPanel{
  display:none;
}
.subPanel.active{
  display:block;
}
@media(max-width:920px){
  .adminCockpit,
  .groupsCockpit{
    grid-template-columns:1fr;
  }
  .adminNav{
    position:static;
  }
  .groupDashboard{
    display:block;
  }
  .dashboardBadges{
    justify-content:flex-start;
  }
}

/* v1.2.2 – Plakat und Vorschau */
#publicPosterLink{
  margin:6px 0 18px;
}


/* v1.2.3 – Datumsstatus Reisegruppen */
.groupDateStatus{
  font-style:normal;
  font-size:.78rem;
  font-weight:850;
  width:max-content;
  border-radius:999px;
  padding:5px 8px;
  background:#f0eee8;
  color:var(--green);
}
.groupDateStatus.invalid,
.stayBadgeLight.invalid{
  background:#f4e5e2;
  color:var(--danger);
}
.groupDateStatus.incomplete,
.stayBadgeLight.incomplete{
  background:#fff3d7;
  color:#7a5a16;
}
.groupDateStatus.open,
.stayBadgeLight.open{
  background:#f0eee8;
  color:var(--muted);
}
.groupDateStatus.ok,
.stayBadgeLight.ok{
  background:#e4ece2;
  color:var(--green);
}


/* v1.3 – Belegungsübersicht und Datumsvalidierung */
.dateMessage{
  border-radius:18px;
  padding:12px 14px;
  margin:10px 0 18px;
  font-weight:800;
  line-height:1.45;
}
.dateMessage.ok{
  background:#e4ece2;
  color:var(--green);
}
.dateMessage.warn{
  background:#fff3d7;
  color:#7a5a16;
}
.dateMessage.error{
  background:#f4e5e2;
  color:var(--danger);
}
.occupancyList,
.blockList{
  display:grid;
  gap:10px;
}
.occupancyItem{
  border:1px solid var(--line);
  background:#fbfaf6;
  border-radius:20px;
  padding:14px;
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:flex-start;
}
.occupancyItem.block{
  background:#f7f3ed;
}
.occupancyItem strong{
  display:block;
  color:var(--green);
  margin-bottom:4px;
}
.occupancyItem span{
  color:var(--muted);
}
.occupancyItem p{
  margin:8px 0 0;
  color:var(--muted);
}
@media(max-width:700px){
  .occupancyItem{
    display:block;
  }
  .occupancyItem button{
    margin-top:10px;
  }
}


/* v1.4 – Kalenderansicht Belegung */
.calendarToolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin:18px 0 14px;
  flex-wrap:wrap;
}
.calendarToolbar strong{
  color:var(--green);
  font-size:1.35rem;
}
.occupancyCalendar{
  margin-bottom:24px;
}
.calendarWeekdays{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:6px;
  margin-bottom:6px;
}
.calendarWeekdays span{
  font-weight:850;
  color:var(--muted);
  text-align:center;
  font-size:.9rem;
}
.calendarGrid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:6px;
}
.calendarDay{
  min-height:104px;
  border:1px solid var(--line);
  border-radius:16px;
  background:#fffefa;
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.calendarDay.empty{
  background:transparent;
  border:0;
}
.calendarDay.booked{
  background:#fbfaf6;
}
.calendarDate{
  font-weight:900;
  color:var(--green);
}
.calendarBookings{
  display:grid;
  gap:4px;
}
.calendarBooking{
  border:0;
  border-radius:999px;
  padding:5px 7px;
  font-size:.72rem;
  line-height:1.1;
  font-weight:850;
  text-align:left;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.calendarBooking.group{
  background:#dfe9dc;
  color:var(--green);
}
.calendarBooking.block{
  background:#f1e4d6;
  color:#7a4e20;
}
.calendarMore{
  color:var(--muted);
  font-weight:850;
  font-size:.75rem;
}
.calendarLegend{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:10px;
  color:var(--muted);
  font-weight:800;
}
.calendarLegend i{
  width:14px;
  height:14px;
  display:inline-block;
  border-radius:4px;
  vertical-align:-2px;
  margin-right:5px;
}
.legendGroup{background:#dfe9dc}
.legendBlock{background:#f1e4d6}
@media(max-width:760px){
  .calendarGrid,.calendarWeekdays{
    gap:4px;
  }
  .calendarDay{
    min-height:82px;
    padding:5px;
    border-radius:12px;
  }
  .calendarBooking{
    font-size:.62rem;
    padding:4px 5px;
  }
}


/* v1.5 – Gästekartei mit Personenzahl und Kontaktdaten */
.summaryGrid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:12px;
}
.summaryGrid article{
  border:1px solid var(--line);
  background:#fbfaf6;
  border-radius:20px;
  padding:16px;
}
.summaryGrid b{
  display:block;
  color:var(--green);
  margin-bottom:8px;
}
.summaryGrid p{
  margin:0;
  color:var(--muted);
}


/* v1.6 – An-/Abreise als halbe Tage und Schlüsselübergabe */
.calendarBooking.arrival{
  background:linear-gradient(135deg, transparent 0 48%, #dfe9dc 49% 100%);
  border:1px solid #c7d8c2;
}
.calendarBooking.departure{
  background:linear-gradient(135deg, #dfe9dc 0 48%, transparent 49% 100%);
  border:1px solid #c7d8c2;
}
.calendarBooking.single{
  background:linear-gradient(90deg, #dfe9dc 0 50%, #f1e4d6 50% 100%);
  border:1px solid #c7d8c2;
}
.legendHalf{
  background:linear-gradient(135deg, transparent 0 48%, #dfe9dc 49% 100%);
  border:1px solid #c7d8c2;
}
.handoverCard{
  margin:16px 0 0;
}
.handoverCard strong{
  color:var(--green);
}


/* v1.7 – Check-in/Check-out-Zeiten */
.handoverCard p + p{
  margin-top:8px;
}


/* v1.8 – Login verfeinert und Startseiten-Zugänge */
.loginCard{
  max-width:440px;
  padding:clamp(22px,4vw,34px);
}
.loginCard h1{
  font-size:clamp(1.85rem,5vw,2.7rem) !important;
  line-height:.96;
  letter-spacing:-.055em;
  word-break:normal;
  hyphens:auto;
}
.loginCard .eyebrow{
  font-size:.78rem;
  letter-spacing:.12em;
}

.publicQuickNav{
  position:fixed;
  top:18px;
  right:18px;
  z-index:20;
  display:flex;
  gap:8px;
}
.publicQuickNav button,
.publicQuickNav a{
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.42);
  background:rgba(255,254,250,.78);
  backdrop-filter:blur(10px);
  color:var(--green);
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-size:1.1rem;
  box-shadow:0 8px 28px rgba(47,75,63,.12);
  cursor:pointer;
}
.publicQuickNav button:hover,
.publicQuickNav a:hover{
  transform:translateY(-1px);
}

.guestLookupDialog{
  border:0;
  border-radius:28px;
  padding:0;
  background:transparent;
  width:min(440px,calc(100% - 32px));
}
.guestLookupDialog::backdrop{
  background:rgba(47,75,63,.28);
  backdrop-filter:blur(3px);
}
.guestLookupCard{
  background:#fffefa;
  border:1px solid var(--line);
  border-radius:28px;
  padding:26px;
  box-shadow:0 28px 90px rgba(47,75,63,.2);
}
.guestLookupCard h2{
  margin-top:0;
}
.dialogActions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:12px;
}
@media(max-width:520px){
  .publicQuickNav{
    top:12px;
    right:12px;
  }
  .publicQuickNav button,
  .publicQuickNav a{
    width:38px;
    height:38px;
  }
}


/* v1.8.2 – Login-Fehlermeldung */
.loginError{
  background:#f4e5e2;
  color:var(--danger);
  border-radius:14px;
  padding:10px 12px;
  margin-top:12px;
}


/* v1.9 – Kontaktkartei */
.contactsCockpit{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:16px;
  align-items:start;
}
.contactButton{
  display:grid !important;
  gap:4px;
  width:100%;
  text-align:left;
  border-radius:18px;
  margin:8px 0;
}
.contactButton strong{
  font-size:1rem;
}
.contactButton span,
.contactButton em{
  font-size:.88rem;
  opacity:.78;
  font-style:normal;
}
.contactHistoryBox{
  margin:18px 0;
}
.historyItem{
  display:grid !important;
  gap:4px;
  width:100%;
  text-align:left;
  border-radius:18px;
  margin:8px 0;
  background:#fbfaf6;
}
.historyItem span{
  font-size:.9rem;
  opacity:.78;
}
@media(max-width:920px){
  .contactsCockpit{
    grid-template-columns:1fr;
  }
}


/* v1.9.1 – Hero-Bild mobil sichtbar halten */
.publicHero{
  background-size:cover;
  background-position:center;
}
.publicHero.hasImage{
  background-blend-mode:normal;
}
@media(max-width:820px){
  .publicHero{
    min-height:76vh;
    background-position:center center;
  }
  .publicHero.hasImage{
    background-image:
      linear-gradient(180deg,rgba(20,30,24,.04),rgba(20,30,24,.42)),
      var(--public-hero-image) !important;
  }
  .publicHeroOverlay{
    padding:clamp(28px,8vw,44px);
    background:linear-gradient(180deg,rgba(20,30,24,0),rgba(20,30,24,.30));
  }
}


/* v1.9.2 – Fallback-Hero ist auf allen Geräten sichtbar */
.publicHero{
  background-image:
    linear-gradient(180deg,rgba(20,30,24,.08),rgba(20,30,24,.56)),
    url("fallback-hero.jpeg");
}
@media(max-width:820px){
  .publicHero{
    background-image:
      linear-gradient(180deg,rgba(20,30,24,.04),rgba(20,30,24,.42)),
      url("fallback-hero.jpeg");
  }
}


/* v1.9.3 – Bildpfade/URLs für geräteübergreifende Bilder */
small{
  line-height:1.35;
}


/* v1.9.4 – kleine Layout-Politur */
.handoverTimes{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  align-items:center;
}
.handoverTimes span{
  white-space:nowrap;
}
.contactLinkBox{
  margin-bottom:18px;
}
.contactLinkBox select{
  min-height:48px;
  font-size:1rem;
  width:100%;
}
.contactLinkActions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}
.contactLinkActions button{
  flex:1 1 220px;
}
@media(max-width:620px){
  .handoverTimes{
    display:block;
  }
  .handoverTimes span{
    display:block;
    white-space:normal;
  }
}
