/* ==========================================================
   PRIME MODA MASCULINA — HEADER & ANNOUNCEMENT BAR

   ALTERAÇÕES vs versão anterior:
   - Header bg: rgba off-white warm (#F7F5F0) → rgba branco neutro (#FAFAFA)
   - Sombras do header: tons de vinho → tons de preto puro
   - Logo text: --fw-light (Cormorant 300) → --fw-semibold (Oswald 600)
   - Letter-spacing do logo text: 0.16em → 0.18em (Oswald aguenta mais)
   - Cart badge: texto preto sobre dourado → texto branco sobre vermelho
   - Hero links hover: gold/cream tones → red/cream tones
   - Estrutura, grid, comportamento e classes: 100% mantidos
   ========================================================== */

/* ----------------------------------------------------------
   ANNOUNCEMENT BAR
---------------------------------------------------------- */
.announce-bar {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: calc(var(--z-header) + 2);
  height: var(--announce-h);
  background: var(--c-burgundy);          /* preto */
  color: var(--c-cream);
  overflow: hidden;
  align-items: center;
}

.announce-bar[data-enabled="true"] {
  display: flex;
}

.announce-bar__track {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  white-space: nowrap;
  animation: marquee 90s linear infinite;
  will-change: transform;
}
.announce-bar__track:hover { animation-play-state: paused; }

.announce-bar__item {
  display: inline-flex;
  align-items: center;
  font-size: var(--text-2xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  flex-shrink: 0;
}

/* Separador entre stickers — traço vermelho vertical */
.announce-bar__sep {
  display: inline-block;
  width: 3px;
  height: 14px;
  background: #ED1B24;
  opacity: 0.85;
  flex-shrink: 0;
}

@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ----------------------------------------------------------
   HEADER WRAPPER — controla show/hide via transform
---------------------------------------------------------- */
.site-header-wrap {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: var(--z-header);
  transform: translateY(0);
  transition: transform var(--dur-slow) var(--ease-luxury);
  will-change: transform;
}
.site-header-wrap.is-hidden {
  transform: translateY(calc(-100% - 4px));
}

.has-announce .site-header-wrap {
  top: var(--announce-h);
}
.has-announce .site-header-wrap.is-hidden {
  transform: translateY(calc(-100% - var(--announce-h) - 4px));
}

/* ----------------------------------------------------------
   HEADER PRINCIPAL — fundo branco neutro
---------------------------------------------------------- */
.site-header {
  height: var(--header-h-mobile);
  display: flex;
  align-items: center;
  background: rgba(250,250,250,0.97);
  border-bottom: 1px solid transparent;
  transition:
    background    420ms var(--ease-luxury),
    border-color  420ms var(--ease-luxury),
    box-shadow    420ms var(--ease-luxury);
}

.site-header.is-scrolled {
  background: rgba(250,250,250,0.96);
  border-bottom-color: var(--c-gray-200);
  box-shadow: 0 1px 0 var(--c-gray-200), 0 4px 24px rgba(0,0,0,0.06);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

/* ----------------------------------------------------------
   HERO MODE — header transparente
---------------------------------------------------------- */
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .site-header {
  background: transparent;
  border-bottom-color: transparent;
  box-shadow: none;
}

.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__icon-btn,
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__nav-link,
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__action-link {
  color: rgba(255,255,255,0.90);
}
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__logo-text {
  color: var(--c-white);
}

.page-hero .site-header-wrap.is-scrolled-wrap .site-header {
  background: rgba(250,250,250,0.96);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom-color: var(--c-gray-200);
  box-shadow: 0 2px 20px rgba(0,0,0,0.07);
}

.page-hero .site-header-wrap.sidebar-is-open .site-header {
  background: rgba(250,250,250,0.97) !important;
  border-bottom-color: var(--c-gray-200) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.page-hero .site-header-wrap.sidebar-is-open .header__icon-btn,
.page-hero .site-header-wrap.sidebar-is-open .header__nav-link,
.page-hero .site-header-wrap.sidebar-is-open .header__action-link {
  color: var(--c-dark) !important;
}

/* ----------------------------------------------------------
   LOGO
---------------------------------------------------------- */
.header__logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  height: 100%;
  transition: opacity var(--dur-base) ease;
}
.header__logo:hover { opacity: 0.78; }

.header__logo img {
  height: 28px;
  width: auto;
  max-width: 140px;
  object-fit: contain;
  display: block;
}
@media (min-width: 1024px) {
  .header__logo img { height: 34px; }
}

.header__logo-text {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: var(--fw-semibold);     /* era --fw-light — Oswald 600 dialoga com wordmark PRIME */
  letter-spacing: 0.18em;              /* era 0.16em */
  text-transform: uppercase;
  color: var(--c-burgundy);
  white-space: nowrap;
  transition: color var(--dur-slow) ease;
}

.header__logo--dark  { display: none; }
.header__logo--light { display: flex; }

.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__logo--light { display: none; }
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__logo--dark  { display: flex; }

.page-hero .site-header-wrap.is-scrolled-wrap .header__logo--light,
.page-hero .site-header-wrap.sidebar-is-open  .header__logo--light { display: flex !important; }

.page-hero .site-header-wrap.is-scrolled-wrap .header__logo--dark,
.page-hero .site-header-wrap.sidebar-is-open  .header__logo--dark  { display: none  !important; }

/* ----------------------------------------------------------
   GRID INTERNO
---------------------------------------------------------- */
.site-header .container {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  height: 100%;
  gap: var(--sp-2);
}

.header__left   { display: flex; align-items: center; justify-content: flex-start; gap: var(--sp-1); }
.header__center { display: flex; align-items: center; justify-content: center; }
.header__right  { display: flex; align-items: center; justify-content: flex-end;  gap: var(--sp-1); }

/* ----------------------------------------------------------
   ICON BUTTONS
---------------------------------------------------------- */
.header__icon-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
  color: var(--c-dark);
  transition:
    color       var(--t-fast),
    background  var(--t-fast);
}
.header__icon-btn:hover {
  color: var(--c-gold);                /* vermelho marca no hover */
  background: var(--hover-surface);
}
.header__icon-btn:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 1px;
}
.header__icon-btn svg {
  width: 22px;
  height: 22px;
  stroke-width: 1.5;
  flex-shrink: 0;
}

/* Cart badge — vermelho marca com texto branco */
.header__cart-badge {
  position: absolute;
  top: 6px; right: 6px;
  min-width: 16px; height: 16px;
  padding: 0 3px;
  font-size: 10px;
  font-weight: var(--fw-semibold);
  background: var(--c-gold);
  color: var(--c-white);               /* era --c-dark — branco fica melhor sobre vermelho */
  border-radius: var(--radius-full);
  display: flex; align-items: center; justify-content: center;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.header__cart-badge[data-count="0"] { display: none; }
.header__cart-badge.bounce {
  animation: badge-bounce 0.4s var(--ease-spring);
}
@keyframes badge-bounce {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.55); }
  100% { transform: scale(1); }
}

/* ----------------------------------------------------------
   NAV + ACTIONS
---------------------------------------------------------- */
.header__nav,
.header__actions { display: none; }

.header__nav-link,
.header__action-link {
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);     /* era --fw-medium — peso masculino */
  letter-spacing: 0.08em;              /* era 0.07em */
  text-transform: uppercase;
  color: var(--c-text);
  padding: var(--sp-2) var(--sp-3);
  position: relative;
  transition: color var(--t-fast);
  white-space: nowrap;
}

/* Underline animado vermelho */
.header__nav-link::after,
.header__action-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: var(--sp-3);
  right: var(--sp-3);
  height: 2px;                          /* era 1px — mais robusto */
  background: var(--c-gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-base) var(--ease-luxury);
}
.header__nav-link:hover,
.header__action-link:hover { color: var(--c-burgundy); }
.header__nav-link:hover::after,
.header__action-link:hover::after { transform: scaleX(1); }

.header__nav-link.is-active { color: var(--c-burgundy); }
.header__nav-link.is-active::after { transform: scaleX(1); }

.header__nav-link:focus-visible,
.header__action-link:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 2px;
  border-radius: var(--radius-xs);
}

/* ----------------------------------------------------------
   DESKTOP
   Grid 3 colunas com simetria forçada via minmax(0, 1fr).
   Sem isso, o '1fr' nativo cresce conforme min-content e quebra
   a centralização da logo quando os sides têm tamanhos diferentes.
---------------------------------------------------------- */
@media (min-width: 1024px) {
  .site-header { height: var(--header-h-desktop); }

  .header__menu-btn { display: none; }

  /* Sides sempre da MESMA largura, logo (auto) no meio real */
  .site-header .container {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: center;
    height: 100%;
    gap: var(--sp-6);
  }

  /* Reset dos sides (anula configs do mobile/absolute) */
  .header__left,
  .header__right {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    padding: 0;
    flex: initial;
  }
  .header__left  { justify-content: flex-start; }
  .header__right { justify-content: flex-end;   }

  /* Logo de volta ao fluxo do grid */
  .header__center {
    position: static;
    transform: none;
    padding: 0;
    pointer-events: auto;
  }

  /* Exibe no máximo 3 links no nav esquerdo — garante simetria
     visual com os 2 links + ícone do cart à direita.
     A ordem dos 3 visíveis é controlada pelo admin/JS. */
  .header__nav > .header__nav-link:nth-of-type(n+4) {
    display: none;
  }

  .header__nav {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
  }
  .header__actions {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
  }
}

/* ----------------------------------------------------------
   SPACER
---------------------------------------------------------- */
.header-spacer { height: var(--header-h-mobile); }
.has-announce .header-spacer {
  height: calc(var(--header-h-mobile) + var(--announce-h));
}
@media (min-width: 1024px) {
  .header-spacer { height: var(--header-h-desktop); }
  .has-announce .header-spacer {
    height: calc(var(--header-h-desktop) + var(--announce-h));
  }
}
.page-hero .header-spacer { display: none; }

/* ==========================================================
   PRIME — ADIÇÕES PREMIUM: HEADER
   ========================================================== */

/* Gradiente âncora no wrapper: melhora contraste dos links no hero */
.page-hero .site-header-wrap:not(.is-scrolled-wrap):not(.sidebar-is-open)::after {
  content: '';
  position: absolute;
  inset: 0;
  bottom: -20px;
  background: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0.40) 0%,
    transparent          100%
  );
  pointer-events: none;
  z-index: -1;
}

/* Links hero: opacity maior + text-shadow para legibilidade */
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__nav-link,
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__action-link {
  color: rgba(245, 245, 245, 0.94);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
}
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__icon-btn {
  color: rgba(245, 245, 245, 0.92);
}

/* Hover hero: vermelho marca */
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__nav-link:hover,
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__action-link:hover {
  color: var(--c-gold-light);
}
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__nav-link::after,
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__action-link::after {
  background: var(--c-gold-light);
}

/* Icon btn hover no hero */
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__icon-btn:hover {
  background: rgba(245, 245, 245, 0.10);
  color: var(--c-gold-light);
}
