:root{
  --nav-h: 72px;
  --content-max: 1200px;
  --pad-x: 18px;

  --deep: #0b1f2a;
  --sand: #f2e7d3;

  --nav-border: rgba(242,231,211,.16);
  --panel-border: rgba(242,231,211,.14);

  --hover-bg: rgba(242,231,211,.08);

  --brand-hover: #ff8a3d;
}

/* NAV fixa */
.pf-nav{
  position:fixed;
  top:0; left:0; right:0;
  height:var(--nav-h);
  z-index:99999;
  background:var(--deep);
  border-bottom:1px solid var(--nav-border);
}
.pf-nav__inner{
  max-width:var(--content-max);
  margin:0 auto;
  height:100%;
  padding:0 var(--pad-x);
  display:flex;
  align-items:center;
  gap:14px;
}

/* Brand */
.pf-brand{
  color:var(--sand);
  text-decoration:none;
  font-weight:800;
  font-size:16px;
  line-height:1;
  white-space:nowrap;
  flex:0 0 auto;
  transition:color .18s ease, opacity .18s ease;
}
.pf-brand:hover,
.pf-brand:focus-visible{
  color:var(--brand-hover);
  opacity:1;
  outline:none;
}

/* Menu desktop base */
.pf-menu{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  gap:10px;
  flex:1 1 auto;
  justify-content:flex-start;
  text-align:left;
}
.pf-menu > li{ position:relative; }

.pf-menu > li > a{
  display:inline-flex;
  align-items:center;
  color:rgba(242,231,211,.85);
  text-decoration:none;
  font-weight:600;
  font-size:14px;
  line-height:1;
  padding:10px 12px;
  border-radius:12px;
  background:transparent;
  transition:background-color .18s ease, color .18s ease;
}
.pf-menu > li > a:hover,
.pf-menu > li > a:focus-visible{
  color:var(--lava);
  border: 1px solid var(--lava);
  outline:none;
}
.pf-menu .current-menu-item > a,
.pf-menu .current_page_item > a{
  background:rgba(242,231,211,.06);
  color:#fff;
}

/* Submenu base */
.pf-menu .sub-menu{
  display:none;
  position:absolute;
  left:0;
  top:100%;
  margin:0;
  padding:8px;
  min-width:220px;
  background:var(--deep);
  border:1px solid var(--nav-border);
  border-radius:14px;
  box-shadow:0 12px 30px rgba(0,0,0,.25);
  z-index:100000;
}
.pf-menu > li.menu-item-has-children > .sub-menu::before{
  content:"";
  position:absolute;
  left:0; right:0;
  top:-10px;
  height:10px;
  background:transparent;
}
.pf-menu .sub-menu a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  white-space:nowrap;
  color:rgba(242,231,211,.88);
  text-decoration:none;
  transition:background-color .18s ease, color .18s ease;
}
.pf-menu .sub-menu a:hover,
.pf-menu .sub-menu a:focus-visible{
  background:var(--hover-bg);
  color:#fff;
  outline:none;
}

/* Toggle + overlay */
.pf-nav__toggle{
  display:none;
  width:44px;
  height:44px;
  border:1px solid var(--nav-border);
  background:transparent;
  border-radius:12px;
  cursor:pointer;
  align-items:center;
  justify-content:center;
  color:var(--sand);
  font-size:22px;
  line-height:1;
}
.pf-nav__toggle:hover{ background:rgba(242,231,211,.06); }

.pf-nav__overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.35);
  z-index:99997;
}

/* CTA */
.nav-cta{ flex:0 0 auto; }
.nav-cta .btn-book{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:44px;
  padding:0 14px;
  border-radius:12px;
  border:1px solid rgba(242,231,211,.20);
  color:var(--sand);
  text-decoration:none;
  font-weight:700;
  font-size:13px;
  line-height:1;
  white-space:nowrap;
  transition:background-color .18s ease, border-color .18s ease, color .18s ease;
}
.nav-cta .btn-book:hover,
.nav-cta .btn-book:focus-visible{
  background: transparent;
  border-color:var(--lava);
  color:var(--lava);
  outline:none;
}

/* DESKTOP */
@media (min-width: 921px){
  .pf-menu > li:hover > .sub-menu,
  .pf-menu > li:focus-within > .sub-menu{ display:block; }

  .pf-menu > li.menu-item-has-children > a::after{
    content:"▾";
    display:inline-block;
    margin-left:6px;
    font-size:12px;
    transform:translateY(-1px);
    opacity:.9;
  }

  /* CTA encostada à direita */
  .nav-cta{ margin-left:auto; }

  /* mata toggles do tema se aparecerem */
  .pf-menu button.submenu-toggle,
  .pf-menu button.dropdown-toggle{
    display:none !important;
  }
}

/* MOBILE */
@media (max-width: 920px){
  .pf-nav__toggle{ display:inline-flex; }

  /* ordem no topo: Brand | (empurra) | Toggle | Book */
  .pf-nav__toggle{ margin-left:auto; order:2; }
  .nav-cta{ order:3; }
  .pf-menu{ order:1; } /* irrelevante em mobile pq está fixed, mas mantém consistente */

  .pf-menu{
    display:none;
    position:fixed;
    top:calc(var(--nav-h) + 10px);
    left:12px;
    right:12px;
    max-height:calc(100vh - var(--nav-h) - 24px);
    overflow:auto;
    padding:10px;
    flex-direction:column;
    gap:0;
    align-items:stretch;
    justify-content:flex-start;
    text-align:left;
    background:rgba(11,31,42,.94);
    backdrop-filter: blur(10px);
    border:1px solid var(--panel-border);
    border-radius:18px;
    box-shadow:0 18px 50px rgba(0,0,0,.35);
    z-index:99998;
  }

  .pf-nav.is-open .pf-menu{ display:flex; }
  .pf-nav.is-open ~ .pf-nav__overlay{ display:block; }

  .pf-menu > li{ position:relative; }

  .pf-menu > li > a{
    display:block;
    width:100%;
    box-sizing:border-box;
    text-align:left;
    padding:14px 56px 14px 14px;
    border-radius:12px;
    border-bottom:1px solid rgba(242,231,211,.10);
    background:transparent;
  }
  .pf-menu > li:last-child > a{ border-bottom:0; }

  .pf-menu > li > a:hover,
  .pf-menu > li > a:focus-visible{
    background:transparent;
    color:var(--lava);
    border: 1px solid var(--lava);
    outline:none;
  }

  /* mobile: nunca abrir submenu por hover/focus */
  .pf-menu > li:hover > .sub-menu,
  .pf-menu > li:focus-within > .sub-menu{ display:none !important; }

  /* remove caret do desktop no mobile */
  .pf-menu > li.menu-item-has-children > a::after{ content:""; }

  /* botão seta (blindado) */
  .pf-menu > li.menu-item-has-children > button.submenu-toggle{
    appearance:none !important;
    -webkit-appearance:none !important;
    border:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    outline:0 !important;

    display:flex !important;
    position:absolute !important;
    right:6px !important;
    top:6px !important;
    width:44px !important;
    height:44px !important;
    padding:0 !important;
    margin:0 !important;

    align-items:center !important;
    justify-content:center !important;
    cursor:pointer !important;
    border-radius:12px !important;
  }
  .pf-menu > li.menu-item-has-children > button.submenu-toggle:hover{
    background:rgba(242,231,211,.06) !important;
  }
  .pf-menu > li.menu-item-has-children > button.submenu-toggle::before,
  .pf-menu > li.menu-item-has-children > button.submenu-toggle::after{
    content:none !important;
    display:none !important;
  }

  /* Chevron: fechado aponta para a direita; aberto aponta para baixo */
  .pf-menu > li.menu-item-has-children > button.submenu-toggle .pf-chev{
    display:block;
    color:var(--sand);
    font-size:20px;
    line-height:1;
    opacity:.95;
    transform:rotate(0deg);          /* direita */
    transform-origin:center;
    transition:transform .18s ease;
  }
  .pf-menu li.subopen > button.submenu-toggle .pf-chev{
    transform:rotate(90deg);         /* baixo */
  }

  /* submenu mobile inline */
  .pf-menu .sub-menu{
    position:static;
    display:none;
    border:0;
    background:transparent;
    box-shadow:none;
    margin:0;
    padding:6px 0 6px;
    min-width:0;
  }
  .pf-menu li.subopen > .sub-menu{ display:block !important; }

  .pf-menu .sub-menu a{
    white-space:normal;
    padding:12px 14px 12px 26px;
    border-bottom:1px solid rgba(242,231,211,.10);
  }
  .pf-menu .sub-menu li:last-child a{ border-bottom:0; }
}