/* ==========================================================
   GRANATO JOIAS — HEADER & ANNOUNCEMENT BAR
   ========================================================== */

/* ----------------------------------------------------------
   ANNOUNCEMENT BAR
---------------------------------------------------------- */
.announce-bar {
  /* Padrão: oculta. Mostrada apenas quando is-at-top + data-enabled=true */
  display: none;
  position: relative;
  z-index: calc(var(--z-header) + 1);
  height: var(--announce-h);
  background: var(--c-burgundy);
  color: var(--c-cream);
  overflow: hidden;
  align-items: center;
}

.site-header-wrap.is-at-top .announce-bar[data-enabled="true"] {
  display: flex;
}

.announce-bar__track {
  display: flex;
  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;
  gap: var(--sp-6);
  padding-inline: var(--sp-8);
  font-size: var(--text-2xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
}
.announce-bar__item::after {
  content: '◆';
  font-size: 6px;
  opacity: 0.5;
  color: var(--c-gold);
}
@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));
}

/* ----------------------------------------------------------
   HEADER PRINCIPAL
---------------------------------------------------------- */
.site-header {
  height: var(--header-h-mobile);
  display: flex;
  align-items: center;
  background: rgba(247,245,240,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(247,245,240,0.96);
  border-bottom-color: var(--c-gray-200);
  box-shadow: 0 1px 0 var(--c-gray-200), 0 4px 24px rgba(74,14,22,0.06);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

/* ----------------------------------------------------------
   HERO MODE — header transparente
   Ativa quando body.page-hero + wrap NÃO tem .is-scrolled-wrap
---------------------------------------------------------- */
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .site-header {
  background: transparent;
  border-bottom-color: transparent;
  box-shadow: none;
}

/* Ícones e links: brancos no modo hero */
.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);
}

/* Após rolar além do hero: fundo sólido */
.page-hero .site-header-wrap.is-scrolled-wrap .site-header {
  background: rgba(247,245,240,0.96);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom-color: var(--c-gray-200);
  box-shadow: 0 2px 20px rgba(74,14,22,0.07);
}

/* Sidebar aberta na hero: força fundo sólido + ícones escuros */
.page-hero .site-header-wrap.sidebar-is-open .site-header {
  background: rgba(247,245,240,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 — duas versões: light (header sólido) / dark (sobre hero)
   JS injeta src via site.js, ou renderiza fallback de texto
---------------------------------------------------------- */
.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-light);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-burgundy);
  white-space: nowrap;
  transition: color var(--dur-slow) ease;
}

/* Por padrão: logo clara visível, escura oculta */
.header__logo--dark  { display: none; }
.header__logo--light { display: flex; }

/* Hero (não scrollado): logo escura aparece, clara some */
.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; }

/* Hero scrollado ou sidebar aberta: volta logo clara */
.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 — Mobile: [left][center][right]
---------------------------------------------------------- */
.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 — área de toque confortável
---------------------------------------------------------- */
.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-burgundy);
  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 */
.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-dark);
  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 — só desktop
---------------------------------------------------------- */
.header__nav,
.header__actions { display: none; }

.header__nav-link,
.header__action-link {
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  letter-spacing: 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 via dourado */
.header__nav-link::after,
.header__action-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: var(--sp-3);
  right: var(--sp-3);
  height: 1px;
  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
---------------------------------------------------------- */
@media (min-width: 1024px) {
  .site-header { height: var(--header-h-desktop); }

  .header__menu-btn { display: none; }

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

/* ----------------------------------------------------------
   SPACER — empurra conteúdo abaixo do header fixo
   Usado em páginas não-hero
---------------------------------------------------------- */
.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));
  }
}
/* Hero: sem spacer, o conteúdo fica atrás */
.page-hero .header-spacer { display: none; }

/* ==========================================================
   GRANATO — ADIÇÕES PREMIUM: HEADER
   Regras novas — não alteram lógica JS
   ========================================================== */

/* Gradiente âncora no wrapper: melhora contraste dos links no hero
   Opera na camada do wrapper, abaixo do conteúdo */
.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(18, 6, 5, 0.28) 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(253, 252, 249, 0.94);
  text-shadow: 0 1px 3px rgba(18, 6, 5, 0.30);
}
.page-hero .site-header-wrap:not(.is-scrolled-wrap) .header__icon-btn {
  color: rgba(253, 252, 249, 0.92);
}

/* Hover hero: dourado ao invés de bordo — mais coerente sobre fundo escuro */
.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(253, 252, 249, 0.10);
  color: var(--c-gold-light);
}
