/* =========================================================
   Buchungsmaschine – Gast-Frontend  (Modern & elegant)
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --accent:#1f6f5c; --accent-dark:#15523f; --accent-soft:#eaf3f0;
  --ink:#1b2228; --muted:#717b85; --bg:#f6f5f2; --card:#ffffff; --line:#e8e6e1;
  --gold:#b89b5e; --danger:#b4452f; --ok:#1f8f4e;
  --radius:18px; --radius-sm:12px;
  --shadow:0 10px 30px rgba(20,28,36,.07); --shadow-lg:0 24px 60px rgba(20,28,36,.14);
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
a{color:var(--accent)}
h1,h2,h3{font-family:var(--serif);font-weight:600;letter-spacing:.2px;line-height:1.15;margin:0}

.bm-wrap{max-width:1140px;margin:0 auto;padding:0 22px}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:340px;display:flex;align-items:flex-end;
  background:linear-gradient(180deg,rgba(15,22,28,.25),rgba(15,22,28,.62)),
    url('https://images.unsplash.com/photo-1566073771259-6a8506099945?w=1700&q=80') center/cover no-repeat;
  color:#fff;padding:40px 0 86px}
.hero .bm-wrap{width:100%}
.hero .logo{height:60px;width:auto;border-radius:8px;margin-bottom:14px;box-shadow:var(--shadow)}
.hero h1{font-size:clamp(2.1rem,5vw,3.4rem);font-weight:700;text-shadow:0 2px 18px rgba(0,0,0,.35)}
.hero .intro{font-size:1.05rem;max-width:680px;margin:10px 0 0;color:rgba(255,255,255,.92);font-family:var(--sans)}
.hero .eyebrow{display:inline-block;font-family:var(--sans);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.25);padding:5px 14px;border-radius:999px;margin-bottom:16px;backdrop-filter:blur(4px)}

/* ---------- Steps ---------- */
.bm-steps{display:flex;gap:10px;flex-wrap:wrap;margin:26px 0 18px}
.bm-steps .step{display:flex;align-items:center;gap:9px;font-size:.84rem;color:var(--muted);
  background:var(--card);border:1px solid var(--line);border-radius:999px;padding:7px 16px}
.bm-steps .step .n{width:23px;height:23px;border-radius:50%;background:#e7e4de;color:#fff;display:grid;place-items:center;font-size:.78rem;font-weight:700}
.bm-steps .step.active{color:var(--ink);border-color:var(--accent);box-shadow:0 4px 14px rgba(31,111,92,.12)}
.bm-steps .step.active .n{background:var(--accent)}
.bm-steps .step.done .n{background:var(--ok)}

/* ---------- Search bar ---------- */
.bm-search{position:relative;margin-top:-66px;z-index:5;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:18px;display:grid;
  grid-template-columns:1fr 1fr .8fr auto;gap:14px;align-items:end}
.bm-field label{display:block;font-size:.72rem;font-weight:600;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}
.bm-field input,.bm-field select{width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);
  font-size:1rem;font-family:inherit;background:#fff;color:var(--ink)}
.bm-field input:focus,.bm-field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* ---------- Buttons ---------- */
.btn{border:none;border-radius:var(--radius-sm);padding:13px 26px;font-size:1rem;font-weight:600;
  background:var(--accent);color:#fff;letter-spacing:.01em;transition:background .15s,transform .05s,box-shadow .15s;
  box-shadow:0 8px 20px rgba(31,111,92,.22)}
.btn:hover{background:var(--accent-dark)}
.btn:active{transform:translateY(1px)}
.btn:disabled,.btn-disabled{opacity:.5;cursor:not-allowed;box-shadow:none}
.btn-lg{width:100%;padding:15px;font-size:1.05rem}
.btn-ghost{background:transparent;color:var(--accent);border:1.5px solid var(--accent);box-shadow:none}
.btn-ghost:hover{background:var(--accent-soft)}

/* ---------- Layout ---------- */
.bm-layout{display:grid;grid-template-columns:1fr 360px;gap:30px;align-items:start;margin:34px 0 50px}
.section-head{margin:6px 0 16px}
.section-head h2{font-size:1.7rem}
.section-head p{margin:4px 0 0;color:var(--muted);font-size:.95rem}

/* ---------- Room cards ---------- */
.room{display:grid;grid-template-columns:300px 1fr;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-bottom:22px;transition:box-shadow .2s,transform .2s}
.room:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.room-media{position:relative;min-height:240px;background:#eee}
.room-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.tag-left{position:absolute;left:14px;bottom:14px;background:rgba(180,69,47,.95);color:#fff;font-size:.74rem;font-weight:600;padding:5px 12px;border-radius:999px}
.tag-soldout{position:absolute;inset:0;display:grid;place-items:center;background:rgba(20,28,36,.55);color:#fff;font-family:var(--serif);font-size:1.3rem}
.room-body{padding:24px 26px;display:flex;flex-direction:column}
.room-body h3{font-size:1.5rem}
.room-meta{color:var(--muted);font-size:.88rem;margin-top:3px;font-family:var(--sans)}
.room-desc{color:#454e57;font-size:.95rem;margin:12px 0 14px}
.room-amen{list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:0 0 16px}
.room-amen li{font-size:.78rem;color:var(--accent-dark);background:var(--accent-soft);padding:5px 12px;border-radius:8px}
.room-amen li::before{content:"✓ ";color:var(--accent);font-weight:700}
.room-foot{margin-top:auto;display:flex;align-items:flex-end;justify-content:space-between;gap:18px;padding-top:8px;border-top:1px solid var(--line)}
.room-price{display:flex;flex-direction:column;line-height:1.25}
.room-price .from{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.room-price .amount{font-family:var(--serif);font-size:1.9rem;font-weight:700;color:var(--ink)}
.room-price .per{font-size:.8rem;color:var(--muted)}
.room-price .total{font-size:.78rem;color:var(--muted);margin-top:4px}
.qty{display:flex;align-items:center;gap:4px;border:1px solid var(--line);border-radius:999px;padding:4px;background:#fff}
.qty button{width:38px;height:38px;border:none;background:var(--accent-soft);color:var(--accent-dark);border-radius:50%;font-size:1.25rem;line-height:1;transition:background .15s}
.qty button:hover{background:var(--accent);color:#fff}
.qty .val{min-width:30px;text-align:center;font-weight:700;font-size:1.1rem}
.room.soldout{opacity:.85}

/* ---------- Sections (extras / form) ---------- */
.bm-section{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px 26px;box-shadow:var(--shadow);margin-bottom:22px}
.bm-section h2{font-size:1.4rem;margin-bottom:6px}
.bm-section .sub{color:var(--muted);font-size:.9rem;margin:0 0 16px}

/* Extras */
.extra-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:10px;cursor:pointer;transition:border-color .15s,background .15s}
.extra-card:hover{border-color:var(--accent)}
.extra-card input{position:absolute;opacity:0;width:0;height:0}
.extra-check{width:24px;height:24px;border:2px solid var(--line);border-radius:7px;flex:none;display:grid;place-items:center;transition:all .15s}
.extra-check::after{content:"";width:11px;height:6px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg) scale(0);transition:transform .15s}
.extra-card input:checked + .extra-check{background:var(--accent);border-color:var(--accent)}
.extra-card input:checked + .extra-check::after{transform:rotate(-45deg) scale(1)}
.extra-card input:checked ~ .extra-info strong{color:var(--accent-dark)}
.extra-info{flex:1}
.extra-info strong{display:block;font-size:1rem}
.extra-info small{color:var(--muted)}
.extra-price{text-align:right;font-weight:700;white-space:nowrap}
.extra-price small{display:block;font-weight:400;font-size:.74rem;color:var(--muted)}

/* Guest form */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px}
.form-grid .full{grid-column:1/-1}
.form-grid label{display:block;font-size:.76rem;font-weight:600;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}
.form-grid input,.form-grid textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);font-size:.98rem;font-family:inherit}
.form-grid input:focus,.form-grid textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.form-grid textarea{min-height:90px;resize:vertical}
.check-row{display:flex;align-items:flex-start;gap:11px;margin-top:8px}
.check-row input{width:19px;height:19px;margin-top:3px;accent-color:var(--accent)}
.check-row label{font-size:.88rem;color:#454e57;margin:0;text-transform:none;letter-spacing:0;font-weight:400}

/* ---------- Summary ---------- */
.summary{position:sticky;top:20px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden}
.summary .head{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;padding:20px 22px}
.summary .head h2{font-size:1.35rem}
.summary .head .dates{font-size:.86rem;opacity:.92;margin-top:5px;font-family:var(--sans)}
.summary .body{padding:20px 22px}
.summary .line{display:flex;justify-content:space-between;gap:12px;font-size:.92rem;padding:7px 0}
.summary .line.muted{color:var(--muted)}
.summary .divider{border-top:1px solid var(--line);margin:12px 0}
.summary .total{display:flex;justify-content:space-between;align-items:baseline;padding-top:6px}
.summary .total span:first-child{font-family:var(--serif);font-size:1.2rem}
.summary .total span:last-child{font-family:var(--serif);font-size:1.7rem;font-weight:700;color:var(--accent-dark)}
.summary .tax-note{font-size:.76rem;color:var(--muted);margin-top:7px}
.summary .empty{color:var(--muted);font-size:.92rem;text-align:center;padding:20px 0}
.summary .foot{padding:0 22px 22px}
.summary .perks{list-style:none;margin:14px 0 0;padding:14px 22px 4px;border-top:1px solid var(--line)}
.summary .perks li{display:flex;align-items:center;gap:9px;font-size:.82rem;color:#454e57;padding:4px 0}
.summary .perks li svg{flex:none;color:var(--accent)}

/* ---------- Confirmation ---------- */
.confirm{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:48px 40px;text-align:center;max-width:660px;margin:40px auto}
.confirm .ok-icon{width:84px;height:84px;border-radius:50%;background:var(--accent-soft);color:var(--ok);display:grid;place-items:center;margin:0 auto 20px;font-size:2.6rem}
.confirm h2{font-size:2rem;margin-bottom:8px}
.confirm .ref{display:inline-block;background:var(--accent-soft);color:var(--accent-dark);font-weight:700;padding:8px 20px;border-radius:999px;letter-spacing:.08em;margin:12px 0 18px}
.confirm p{color:#454e57}

/* ---------- Trust footer ---------- */
.trust{background:#fff;border-top:1px solid var(--line);margin-top:10px;padding:40px 0}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;text-align:center}
.trust-grid .t h4{font-family:var(--serif);font-size:1.2rem;margin:10px 0 4px}
.trust-grid .t p{margin:0;color:var(--muted);font-size:.9rem}
.trust-grid .t .ic{width:48px;height:48px;border-radius:50%;background:var(--accent-soft);color:var(--accent-dark);display:grid;place-items:center;margin:0 auto;font-size:1.4rem}

/* ---------- Alerts / loading ---------- */
.bm-alert{padding:14px 18px;border-radius:var(--radius-sm);font-size:.94rem;margin:18px 0}
.bm-alert.error{background:#fbeae6;color:var(--danger);border:1px solid #f0c8bd}
.bm-alert.info{background:var(--accent-soft);color:var(--accent-dark)}
.bm-loading{text-align:center;padding:60px;color:var(--muted)}
.spinner{width:40px;height:40px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}
@keyframes spin{to{transform:rotate(360deg)}}
.hidden{display:none!important}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .bm-layout{grid-template-columns:1fr}
  .summary{position:static}
  .room{grid-template-columns:1fr}
  .room-media{min-height:200px;position:relative}
  .room-media img{position:relative}
  .bm-search{grid-template-columns:1fr 1fr;margin-top:-50px}
  .trust-grid{grid-template-columns:1fr;gap:18px}
}
@media(max-width:540px){
  .bm-search{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .hero{min-height:280px;padding-bottom:74px}
}

/* ---------- Raten-Detailfenster ---------- */
.bm-modal-overlay{position:fixed;inset:0;background:rgba(20,28,36,.55);display:flex;align-items:center;justify-content:center;z-index:100;padding:18px;opacity:0;pointer-events:none;transition:opacity .2s}
.bm-modal-overlay.open{opacity:1;pointer-events:auto}
.bm-modal{background:#fff;border-radius:var(--radius);max-width:820px;width:100%;max-height:92vh;overflow:auto;box-shadow:var(--shadow-lg);position:relative}
.bm-modal-close{position:absolute;top:14px;right:14px;width:40px;height:40px;border:none;background:rgba(255,255,255,.92);border-radius:50%;font-size:1.5rem;line-height:1;cursor:pointer;z-index:2;box-shadow:var(--shadow)}
.bm-modal-media{height:clamp(260px,44vh,440px);background:#eee;position:relative;overflow:hidden}
.bm-modal-media img{width:100%;height:100%;object-fit:cover}
.bm-modal-body{padding:26px 28px}
.bm-modal-body h3{font-size:1.7rem}
.bm-modal-body .meta{color:var(--muted);font-size:.9rem;margin:4px 0 12px}
.bm-modal-body h4{font-family:var(--sans);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:22px 0 12px}
.rate{display:flex;gap:14px;align-items:center;border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:15px 16px;margin-bottom:10px;cursor:pointer;transition:border-color .15s,box-shadow .15s}
.rate:hover{border-color:var(--accent)}
.rate input{accent-color:var(--accent);width:20px;height:20px;flex:none}
.rate.sel{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.rate-info{flex:1}
.rate-info strong{display:block;font-size:1.04rem}
.rate-info small{color:var(--muted)}
.rate-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:999px;margin-top:6px}
.rate-badge.flex{background:var(--accent-soft);color:var(--accent-dark)}
.rate-badge.nonref{background:#f1efe9;color:#6b665c}
.rate-badge.bf{background:#fdf3e3;color:#9a6a17;margin-right:6px}
.rate-price{text-align:right;white-space:nowrap}
.rate-price .pn{font-family:var(--serif);font-size:1.35rem;font-weight:700}
.rate-price .tt{display:block;font-size:.74rem;color:var(--muted)}
.modal-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:20px;padding-top:18px;border-top:1px solid var(--line);flex-wrap:wrap}
.modal-foot .qtywrap{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.92rem}
.room-selected{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.room-selected .chip{background:var(--accent-soft);color:var(--accent-dark);font-weight:600;font-size:.82rem;padding:7px 14px;border-radius:999px}
.btn-sm{padding:10px 18px;font-size:.9rem;box-shadow:none}
.btn-text{background:none;border:none;color:var(--danger);font-weight:600;cursor:pointer;font-size:.85rem;padding:4px}

.wish-head{margin:14px 0 8px;font-weight:700;color:var(--ink);font-size:.98rem}
.wish-head small{display:block;font-weight:400;color:var(--muted);font-size:.8rem;margin-top:2px}

/* Bildergalerie im Zimmerfenster */
.bm-gallery{display:flex;height:100%;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.bm-gallery::-webkit-scrollbar{display:none}
.bm-slide{flex:0 0 100%;width:100%;height:100%;scroll-snap-align:center}
.bm-slide img{width:100%;height:100%;object-fit:cover;display:block}
.bm-gnav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border:none;border-radius:50%;background:rgba(255,255,255,.92);color:#1b2228;font-size:1.7rem;line-height:1;cursor:pointer;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;z-index:2}
.bm-gnav:hover{background:#fff}
.bm-gnav.prev{left:14px}.bm-gnav.next{right:14px}
.bm-gcount{position:absolute;top:14px;left:14px;background:rgba(20,28,36,.6);color:#fff;font-size:.8rem;font-weight:600;padding:4px 11px;border-radius:999px;z-index:2}
.bm-gdots{position:absolute;bottom:12px;left:0;right:0;display:flex;justify-content:center;gap:7px;z-index:2}
.bm-gdot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.55);cursor:pointer;transition:background .15s,transform .15s;box-shadow:0 0 3px rgba(0,0,0,.25)}
.bm-gdot.on{background:#fff;transform:scale(1.25)}
@media(max-width:560px){.bm-gnav{width:38px;height:38px;font-size:1.4rem}}

/* Eigener Datums-Kalender */
.bm-cal{position:absolute;z-index:300;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:12px;width:300px;font-family:var(--sans);box-sizing:border-box}
.bm-cal *{box-sizing:border-box}
.bm-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.bm-cal-title{font-weight:700;color:var(--ink)}
.bm-cal-nav{border:none;background:var(--accent-soft);color:var(--accent-dark);width:34px;height:34px;border-radius:8px;font-size:1.2rem;cursor:pointer;line-height:1}
.bm-cal-nav:hover{background:var(--accent);color:#fff}
.bm-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.bm-cal-wd span{text-align:center;font-size:.72rem;color:var(--muted);font-weight:600;padding:4px 0}
.bm-cal-days{margin-top:2px}
.bm-cal-day{border:none;background:none;padding:0;height:36px;border-radius:8px;cursor:pointer;font-size:.92rem;color:var(--ink)}
.bm-cal-day:hover{background:var(--accent-soft)}
.bm-cal-day.today{outline:1px solid var(--accent)}
.bm-cal-day.sel{background:var(--accent);color:#fff;font-weight:700}
.bm-cal-day.off{color:#cfccc4;cursor:default;background:none}
.bm-cal-empty{height:36px}

/* Zimmerfenster auf dem Handy: Raten/Preise sauber umbrechen  (rate-mobile-fix) */
@media(max-width:560px){
  .bm-modal-body{padding:18px 16px}
  .bm-modal-body h3{font-size:1.4rem}
  .rate{flex-wrap:wrap;gap:6px 12px;padding:13px 14px}
  .rate input{flex:0 0 auto}
  .rate-info{flex:1 1 0;min-width:0}
  .rate-info strong{font-size:1rem}
  .rate-price{flex:1 1 100%;text-align:right;white-space:normal;border-top:1px dashed var(--line);margin-top:4px;padding-top:8px}
  .rate-price .pn{font-size:1.2rem}
  .rate-price .tt{display:block;white-space:normal}
  .modal-foot{gap:12px}
  .modal-foot .btn{flex:1 1 100%}
}

/* Mobile Buchungsleiste (Gesamtsumme + Knopf immer sichtbar) */
.bm-mbar{position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 22px rgba(0,0,0,.14);padding:10px 16px;align-items:center;justify-content:space-between;gap:14px}
.bm-mbar .t small{display:block;color:var(--muted);font-size:.68rem;text-transform:uppercase;letter-spacing:.05em}
.bm-mbar .t strong{font-size:1.18rem;font-family:var(--serif)}
.bm-mbar .btn{padding:12px 22px;white-space:nowrap}
@media(max-width:900px){
  .bm-mbar:not(.hidden){display:flex}
  body{scroll-padding-bottom:80px}
}

/* Bestätigung: nächste Schritte + Aktionen */
.next-steps{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:22px 0 14px}
.next-steps .ns{display:flex;align-items:center;gap:8px;background:#fafaf8;border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:.85rem;color:#444}
.next-steps .ns span{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:.74rem;font-weight:700;flex:none}
.confirm-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:10px}
@media print{.bm-mbar,.trust,.bm-search,.bm-steps{display:none!important}}

/* Apartment-Standort-Hinweis */
.apt-loc{display:flex;gap:8px;align-items:flex-start;background:#fff7e6;border:1px solid #f3e2b8;border-radius:10px;padding:10px 12px;margin:6px 0 10px;font-size:.88rem;color:#7a5b16;line-height:1.5}
.apt-loc .pin{font-size:1rem;flex:none}
.apt-loc a{color:var(--accent-dark);font-weight:600}

/* ============ Buchungsstrecke: Orientierung & Eleganz ============ */
html{scroll-behavior:smooth}

/* Fortschritts-Schritte oben fixieren – der Gast sieht immer, wo er ist */
.bm-steps{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.97);backdrop-filter:saturate(1.4) blur(10px);-webkit-backdrop-filter:saturate(1.4) blur(10px);margin:0 -22px 20px;padding:13px 22px;border-bottom:1px solid var(--line);box-shadow:0 6px 18px rgba(20,28,36,.06)}
.bm-steps .step{transition:transform .15s,box-shadow .15s,background .15s,color .15s}
.bm-steps .step.active{transform:translateY(-1px)}
.bm-steps .step.done{color:var(--accent-dark);border-color:var(--accent-soft)}
.bm-steps .step.done .n{background:var(--accent)}

/* Sektionen landen beim automatischen Scrollen sauber unter der Fixleiste */
#bookingArea,#roomsList,.bm-section,#guestSection,#confirmArea{scroll-margin-top:88px}

/* Buchungsübersicht bleibt sichtbar (Desktop) + auffälliger Weiter-Knopf */
@media(min-width:901px){
  .summary{top:82px}
  .summary .foot .btn-lg{font-size:1.08rem;box-shadow:0 8px 20px rgba(31,111,92,.22)}
}
/* Eleganter, einladender Übersichts-Kopf */
.summary .head{background:linear-gradient(135deg,var(--accent),var(--accent-dark))}
.summary .head h2{color:#fff}
.summary .head .dates{color:rgba(255,255,255,.88)}

/* Feinschliff: ruhige Hover-Effekte */
.room{transition:transform .18s,box-shadow .18s}
.room:hover{transform:translateY(-3px)}

/* Mobil: kompakte, seitlich scrollbare Schrittleiste */
@media(max-width:900px){
  .bm-steps{margin:0 -22px 16px;padding:10px 14px;gap:7px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .bm-steps::-webkit-scrollbar{display:none}
  .bm-steps .step{font-size:.78rem;padding:7px 11px;white-space:nowrap;flex:none}
  #bookingArea,#guestSection,.bm-section,#confirmArea{scroll-margin-top:72px}
}

/* Sprachumschalter DE/EN */
.bm-lang{display:flex;justify-content:flex-end;gap:6px;margin:0 0 10px}
.bm-lang-btn{border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:999px;padding:5px 12px;font-size:.82rem;font-weight:700;cursor:pointer;line-height:1}
.bm-lang-btn:hover{border-color:var(--accent);color:var(--accent)}
.bm-lang-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
