:root{
  --chalet-hero-h: 520px;
  --cal-approved-bg: rgba(25,135,84,.10);
  --cal-pending-bg: rgba(255,193,7,.16);
  --cal-holiday-bg: rgba(220,53,69,.08);
  --cal-vac-a: rgba(13,202,240,1);
  --cal-vac-b: rgba(13,110,253,1);
  --cal-vac-c: rgba(108,117,125,1);
}

.chalet-hero{
  height: var(--chalet-hero-h);
  object-fit: cover;
  border-radius: .5rem;
}

.chalet-hero{
  cursor: zoom-in;
}

.lightbox-img{
  max-width: 100%;
  max-height: calc(100vh - 80px);
  width: auto;
  height: auto;
  display: block;
}

.lightbox-stage{
  position: relative;
  width: 100%;
  height: 100%;
  min-height: calc(100vh - 80px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.lightbox-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 56px;
  height: 56px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(0,0,0,.35);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 0;
  padding: 0;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease, opacity .15s ease;
}

.lightbox-nav svg{
  width: 26px;
  height: 26px;
  display: block;
}

.lightbox-prev{ left: 18px; }
.lightbox-next{ right: 18px; }

.lightbox-nav:hover{
  background: rgba(0,0,0,.55);
  border-color: rgba(255,255,255,.6);
}

.lightbox-nav:disabled{
  opacity: .25;
  cursor: default;
}

@media (max-width: 576px){
  .lightbox-nav{
    width: 46px;
    height: 46px;
  }
  .lightbox-nav svg{
    width: 22px;
    height: 22px;
  }
  .lightbox-prev{ left: 10px; }
  .lightbox-next{ right: 10px; }
}

@media (max-width: 576px){
  :root{ --chalet-hero-h: 340px; }
}

.calendar-grid{
  display: block;
  padding-bottom: 6px;
}

.month{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: .5rem;
  padding: 10px;
  width: 100%;
  max-width: 100%;
}

.month h3{
  font-size: 1rem;
  margin: 0 0 8px 0;
}

.month .dow{
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  font-size: .75rem;
  color: #6c757d;
  margin-bottom: 6px;
}

.month .days{
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}

.day{
  border-radius: .35rem;
  padding: 6px 4px 12px 4px; /* espace bas pour les barres de zones */
  min-height: 36px;
  border: 1px solid rgba(0,0,0,.06);
  background: #f8f9fa;
  line-height: 1;
  position: relative; /* permet de placer les barres en bas */
}

.day .num{
  font-size: .78rem;
  font-weight: 600;
}

.day .tag{
  margin-top: 4px;
  font-size: .68rem;
  opacity: .95;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.day.is-out{
  opacity: .35;
}

.day.is-hidden{
  visibility: hidden;
  pointer-events: none;
}

.day.is-weekend{
  background: #f1f3f5;
}

.day.is-holiday{
  border-color: rgba(220,53,69,.35);
  background: var(--cal-holiday-bg);
}

.day.is-approved{
  border-color: rgba(25,135,84,.35);
  background: var(--cal-approved-bg);
}

.day.is-pending{
  border-color: rgba(255,193,7,.55);
  background: var(--cal-pending-bg);
}

.day.has-reservation{
  cursor: pointer;
}

.day.has-reservation:hover{
  box-shadow: 0 0 0 2px rgba(13,110,253,.25);
}

.vac-bars{
  position:absolute;
  left:3px;
  right:3px;
  bottom:2px;
  display:flex;
  flex-direction:column;
  gap:1px;
}

/* En vue mois, les jours "hors mois" restent visibles : on évite d’y afficher les barres de vacances */
.day.is-out .vac-bars{
  display:none;
}
.vac-bar{
  height:3px;
  border-radius:999px;
}
.vac-bar-a{ background:var(--cal-vac-a); }
.vac-bar-b{ background:var(--cal-vac-b); }
.vac-bar-c{ background:var(--cal-vac-c); }

.doc-group{
  display:none;
}
.doc-group.is-open{
  display:block;
}

/* Statuts réservations (admin_reservations) alignés sur les couleurs du calendrier */
.badge-status-approved{
  background: var(--cal-approved-bg);
  color: #000;
  border: 1px solid rgba(25,135,84,.6);
}
.badge-status-pending{
  background: var(--cal-pending-bg);
  color: #000;
  border: 1px solid rgba(255,193,7,.8);
}
.badge-status-rejected{
  background: rgba(220,53,69,.12);
  color: #842029;
  border: 1px solid rgba(220,53,69,.7);
}
.badge-status-cancelled{
  background: #e9ecef;
  color: #495057;
  border: 1px solid rgba(108,117,125,.6);
}
.badge-status-default{
  background: #212529;
  color: #fff;
}

/* Boutons "œil" (afficher/masquer mot de passe) */
button[data-toggle-password]{
  min-width: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

