/* ================================
   HEADER VENUS (Premium)
   ================================ */

:root{
  --hdr-bg: #fff;
  --hdr-text: #0b1f2a;
  --hdr-muted: rgba(11,31,42,.72);
  --hdr-border: rgba(15,23,42,.10);
  --brand: var(--color-primario);
  --gold: #F2A900;
}

/* sticky + efecto */
.site-header{
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--hdr-bg);
  transition: box-shadow .25s ease, transform .25s ease;
}

/* TOPBAR tipo Ritzé */
.topbar{
  background: var(--gold);
  color: #fff;
  font-size: 13px;
}
.topbar .topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 8px 0;
}
.topbar-left{
  display:flex;
  align-items:center;
  gap: 12px;
  flex-wrap: wrap;
}
.topbar-left i{ margin-right: 6px; opacity: .95; }
.topbar-left .sep{ opacity:.65; }

.topbar-right{
  display:flex;
  align-items:center;
  gap: 10px;
}
.topbar-right a{
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  color:#fff;
  background: rgba(255,255,255,.16);
  transition: transform .2s ease, background .2s ease;
}
.topbar-right a:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.26);
}

/* MAIN */
.site-header .header-inner{
  max-width: 1100px;
  margin: 0 auto;
  padding: 14px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  border-bottom: 1px solid transparent;
}

/* Logo */
.site-header .logo{
  display:flex;
  align-items:center;
  gap: 10px;
  text-decoration:none;
  min-width: 0;          /* evita forzar ancho */
}

.site-header .logo img{
  width: 120px;          /* más similar a Ritzé (ancho manda) */
  height: 48px;          /* altura contenida */
  object-fit: contain;
  display: block;

  /* ✅ quitar “cajita” */
  padding: 0;
  background: transparent;
  border-radius: 0;
  box-shadow: none;

  /* mejora visual en PNG transparente */
  filter: drop-shadow(0 6px 14px rgba(15,23,42,.10));
}

.site-header .logo span{
  font-weight: 900;
  letter-spacing: .2px;
  font-size: 1.35rem;
  color: var(--hdr-text);
}

/* NAV */
.site-header .nav ul{
  list-style:none;
  display:flex;
  align-items:center;
  gap: 22px;
  margin:0;
  padding:0;
}
.site-header .nav > ul > li{ position: relative; }

.site-header .nav a{
  position: relative;
  text-decoration:none;
  color: var(--hdr-text);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .02em;
  padding: 10px 2px;
  transition: color .2s ease;
}

/* underline elegante */
.site-header .nav > ul > li > a::after{
  content:"";
  position:absolute;
  left: 50%;
  bottom: 4px;
  width: 0;
  height: 2px;
  background: var(--gold);
  border-radius: 999px;
  transition: width .22s ease, left .22s ease;
}
.site-header .nav > ul > li > a:hover::after,
.site-header .nav > ul > li > a.active::after{
  width: 100%;
  left: 0;
}
.site-header .nav > ul > li > a:hover{
  color: var(--hdr-text);
}

/* caret */
.caret{
  margin-left: 6px;
  font-size: 16px;
  opacity: .75;
}

/* Dropdown premium */
/* Dropdown premium */
.has-dropdown .dropdown{
  position: absolute;
  top: 100%;              /* ✅ pegado al item */
  left: 0;
  margin-top: 8px;        /* ✅ separación controlada (no se baja de más) */

  min-width: 220px;
  background: #fff;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  padding: 10px;
  box-shadow: 0 25px 60px rgba(15,23,42,.18);

  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;

  z-index: 2000;          /* ✅ evita que quede "detrás" al bajar */
}

/* ✅ Se abre por hover (desktop) */
.has-dropdown:hover .dropdown{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* ✅ Se abre también por click (cuando tu JS pone .open) */
.has-dropdown.open .dropdown{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.dropdown li{ margin: 2px 0; }

.dropdown a{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 10px;
  border-radius: 10px;
  color: var(--hdr-text);
  font-weight: 600;
}
.dropdown a:hover{
  background: rgba(242,169,0,.12);
}

/* acciones */
.header-actions{
  display:flex;
  align-items:center;
  gap: 12px;
}

/* CTA WhatsApp (usa tu handler .btn-whatsapp) */
.header-cta{
  display:flex;
  align-items:center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  text-decoration:none;
  color: #0b1f2a;
  background: rgba(242,169,0,.18);
  border: 1px solid rgba(242,169,0,.35);
  font-weight: 800;
  transition: transform .2s ease, background .2s ease;
}
.header-cta i{ font-size: 18px; }
.header-cta:hover{
  transform: translateY(-1px);
  background: rgba(242,169,0,.26);
}

/* hamburger */
.hamburger{
  display:none;
  background: none;
  border:none;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  cursor:pointer;
  color: var(--hdr-text);
  transition: background .2s ease;
}
.hamburger:hover{ background: rgba(15,23,42,.06); }
.hamburger i{ font-size: 24px; }

/* scrolled */
.site-header.scrolled{
  box-shadow: 0 18px 55px rgba(15,23,42,.14);
}
.site-header.scrolled .header-inner{
  border-bottom-color: var(--hdr-border);
}

/* overlay móvil */
.nav-overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.42);
  opacity: 0;
  pointer-events:none;
  transition: opacity .2s ease;
  z-index: 999;
}
.nav-overlay.show{
  opacity: 1;
  pointer-events: auto;
}

/* Responsive */
@media (max-width: 980px){
  .topbar .topbar-inner{ padding: 8px 14px; }
  .site-header .header-inner{ padding: 12px 14px; }
  .site-header .logo span{ font-size: 1.15rem; }
  .header-cta span{ display:none; } /* solo ícono */
}

@media (max-width: 768px){
  .hamburger{ display:inline-flex; align-items:center; justify-content:center; }
  .site-header .nav{
    position: fixed;
    top: 0;
    right: 0;
    height: 100vh;
    width: min(86vw, 360px);
    background: #fff;
    box-shadow: -20px 0 60px rgba(15,23,42,.18);
    transform: translateX(110%);
    transition: transform .22s ease;
    z-index: 1000;
    padding: 18px 14px;
  }
  .site-header .nav.active{
    transform: translateX(0);
  }

  .site-header .nav ul{
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    margin-top: 10px;
  }

  .site-header .nav a{
    padding: 12px 12px;
    border-radius: 12px;
    background: rgba(15,23,42,.03);
  }
  .site-header .nav > ul > li > a::after{ display:none; }

  /* dropdown como accordion en móvil */
  .has-dropdown .dropdown{
    position: static;
    opacity: 1;
    transform: none;
    pointer-events: auto;
    box-shadow: none;
    border: 0;
    padding: 6px 0 0;
    display:none;
  }
  .has-dropdown.open .dropdown{ display:block; }
  .dropdown a{ background: rgba(242,169,0,.10); }
}

.sr-only{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

@media (max-width: 980px){
  .site-header .logo img{
    width: 105px;
    height: 44px;
  }
}
