.om-bp-front-wrap{
  background:#20373B0A;
  border-radius:24px;
  padding:22px;
}

.om-bp-front-months{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}

@media (max-width:900px){
  .om-bp-front-months{
    grid-template-columns:1fr;
  }
}

.om-bp-front-nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}

.om-bp-front-nav__btn{
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(32,55,59,.12);
  background:#ffffff;
  color:#20373B;
  font-size:22px;
  line-height:1;
  cursor:pointer;
  transition:border-color .2s ease, transform .2s ease, background-color .2s ease;
}

.om-bp-front-nav__btn:hover{
  border-color:rgba(32,55,59,.22);
  transform:translateY(-1px);
}

.om-bp-front-nav__label{
  font-weight:700;
  color:#20373B;
  text-align:center;
}

.om-bp-front-cal{
  background:#fff;
  border:1px solid rgba(32,55,59,.12);
  border-radius:16px;
  padding:12px;
}

.om-bp-front-title{
  font-weight:700;
  margin:4px 6px 10px;
  color:#20373B;
}

.om-bp-front-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:6px;
}

.om-bp-front-cell{
  aspect-ratio:1/1;
  border-radius:12px;
  border:1px solid rgba(32,55,59,.12);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#20373B;
  background:#ffffff;
  position:relative;
  overflow:hidden;
  font-size:14px;
}

.om-bp-front-cell.dow{
  border:none;
  background:transparent;
  font-weight:700;
  color:rgba(32,55,59,.7);
  aspect-ratio:auto;
}

.om-bp-front-cell.empty{
  border:none;
  background:transparent;
}

.om-bp-front-cell.occ{
  background:#6B9EAA;
  color:#ffffff;
  border-color:#6B9EAA;
}

/* Anreise: dezente Markierung links oben */
.om-bp-front-cell.arrival::before{
  content:'';
  position:absolute;
  top:4px;
  left:4px;
  width:8px;
  height:8px;
  border-radius:50%;
  background:#EAC462;
  box-shadow:0 0 0 2px rgba(255,255,255,.9);
}

/* Abreise: dezente Markierung rechts oben */
.om-bp-front-cell.departure::after{
  content:'';
  position:absolute;
  top:4px;
  right:4px;
  width:8px;
  height:8px;
  border-radius:50%;
  background:#20373B;
  box-shadow:0 0 0 2px rgba(255,255,255,.9);
}

/* Echter Wechseltag */
.om-bp-front-cell.turnover{
  background:linear-gradient(135deg, #6B9EAA 0 50%, #ffffff 50% 100%);
  color:#20373B;
  border-color:#519CAB;
}

/* Marker auf Wechseltag leicht anpassen */
.om-bp-front-cell.turnover::before{
  background:#EAC462;
  box-shadow:0 0 0 2px rgba(255,255,255,.95);
}

.om-bp-front-cell.turnover::after{
  background:#20373B;
  box-shadow:0 0 0 2px rgba(255,255,255,.95);
}

/* Nur Abreise ohne belegte Nacht */
.om-bp-front-cell.departure:not(.occ):not(.turnover){
  background:#ffffff;
  color:#20373B;
  border-color:rgba(32,55,59,.18);
}

/* Nur Anreise ohne belegte Nacht */
.om-bp-front-cell.arrival:not(.occ):not(.turnover){
  background:#ffffff;
  color:#20373B;
  border-color:rgba(32,55,59,.18);
}

.om-bp-front-legend{
  margin-top:12px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
  color:#20373B;
  font-size:14px;
}

.om-bp-front-legend .lg{
  display:inline-flex;
  gap:8px;
  align-items:center;
}

.om-bp-front-legend .lg::before{
  content:'';
  width:12px;
  height:12px;
  border-radius:4px;
  display:inline-block;
}

.om-bp-front-legend .lg-free::before{
  background:#ffffff;
  border:1px solid rgba(32,55,59,.15);
}

.om-bp-front-legend .lg-occ::before{
  background:#6B9EAA;
}

.om-bp-front-legend .lg-note::before{
  background:linear-gradient(135deg, #6B9EAA 0 50%, #ffffff 50% 100%);
  border:1px solid rgba(32,55,59,.15);
}