/*
  Remaster layer for VacationRentalPricing.com
  - Unified hamburger navigation (desktop + mobile)
  - Unified Calendly sizing (1080 desktop, 1000 mobile)
  - Safe header stacking over hero media
*/

/* Keep header from floating over content in a way that can block clicks */
header.topbar{
  position: relative !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  z-index: 2000 !important;
}

/* Ensure hero media never overlays header */
.hero, .video-card{
  position: relative;
  z-index: 1;
}

/* Accessible screen-reader-only helper */
.sr-only{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}

/* Remove legacy nav variants */
nav.navlinks{ display:none !important; }
details.nav{ display:none !important; }

/* Hamburger button */
.nav-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(7,10,18,.55);
  backdrop-filter: blur(10px);
  color:#fff;
  cursor:pointer;
  margin-left:auto;
}
.nav-toggle:focus-visible{
  outline: 2px solid rgba(124,240,199,.70);
  outline-offset: 2px;
}

.burger{
  width:18px;
  height:12px;
  position:relative;
  display:block;
}
.burger::before,
.burger::after,
.burger span{
  content:"";
  position:absolute;
  left:0;
  right:0;
  height:2px;
  border-radius:999px;
  background: rgba(255,255,255,.92);
  transition: transform .18s ease, top .18s ease, opacity .18s ease;
}
.burger::before{ top:0; }
.burger span{ top:5px; }
.burger::after{ top:10px; }

/* Open state -> X */
.nav-toggle[aria-expanded="true"] .burger::before{ top:5px; transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] .burger span{ opacity:0; }
.nav-toggle[aria-expanded="true"] .burger::after{ top:5px; transform: rotate(-45deg); }

/* Dropdown panel */
header.topbar .navpanel{
  position:absolute;
  top: calc(100% + 10px);
  left: 0;
  right: 0;
  z-index: 3000;

  background: rgba(7,10,18,.98);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  box-shadow: 0 28px 70px rgba(0,0,0,.55);

  padding: 10px;
  transform-origin: top;
  animation: vrpPanelIn .16s ease-out;
}
@keyframes vrpPanelIn{
  from { opacity:0; transform: translateY(-6px) scale(.985); }
  to   { opacity:1; transform: translateY(0) scale(1); }
}

header.topbar .navpanel a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 12px 12px;
  border-radius: 12px;
  text-decoration:none;
  color: rgba(255,255,255,.92);
  border: 1px solid transparent;
  background: transparent;
}
header.topbar .navpanel a:hover{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.08);
}

/* Keep Book Now visible but tidy */
header.topbar .btn.primary.small{
  margin-left: 10px;
  white-space: nowrap;
}

/* Video: enforce a reliable 16:9 box and iframe sizing */
.video-card .ratio{
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
  overflow: hidden;
  border-radius: inherit;
}
.video-card .ratio iframe{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

/* Calendly container (neutral so Calendly keeps default colors) */
.calendly-shell{
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 18px 55px rgba(0,0,0,.55);
  background: rgba(7,10,18,.35);
  padding: 10px;
}

.calendly-inline-widget{
  min-width: 320px;
  height: 1080px !important;
  border-radius: 14px;
  overflow: hidden;
  background: transparent;
}

@media (max-width: 720px){
  .calendly-inline-widget{ height: 1000px !important; }
  header.topbar .btn.primary.small{ display:none; }
}
