/* ============================================================
   PIAVE — WIREFRAME OVERRIDE
   Carregar SEMPRE depois de tokens.css + components.css
   Neutraliza paleta, oculta imagens, adiciona rótulos de bloco
   Objetivo: discussão em IA/UX, não em estética
============================================================ */

/* ---------- RESET DE TOKENS ---------- */
:root,
[data-area="home"],
[data-area="pro"] {
  /* Cores principais → grayscale */
  --piave-branco:        #FFFFFF;
  --piave-verde:         #E0E0E0;
  --piave-verde-dark:    #707070;
  --piave-verde-soft:    #F3F3F3;
  --piave-salmao:        #B5B5B5;
  --piave-salmao-dark:   #707070;
  --piave-salmao-soft:   #F3F3F3;
  --piave-grafite:       #2A2A2A;
  --piave-grafite-soft:  #555555;
  --piave-grafite-light: #999999;
  --piave-cinza-bg:      #F6F6F6;
  --piave-divider:       #C8C8C8;

  /* Cores por linha → todas viram cinza sutilmente diferente */
  --linha-hydranutri:    #DCDCDC;
  --linha-fortifying:    #C8C8C8;
  --linha-smoothpro:     #B5B5B5;
  --linha-highlights:    #D8D8D8;
  --linha-styling:       #BFBFBF;
  --linha-bondrepair:    #A8A8A8;
  --linha-home:          #E0E0E0;
  --linha-eventos:       #D0D0D0;
  --linha-saloes:        #888888;

  /* Estados neutralizados */
  --piave-success:       #707070;
  --piave-warning:       #B5B5B5;
  --piave-error:         #707070;
  --piave-whatsapp:      #999999;

  /* Área Home/PRO → sem diferença visual */
  --area-accent:         #707070;
  --area-accent-dark:    #2A2A2A;
  --area-accent-soft:    #F0F0F0;
  --area-cta-bg:         #2A2A2A;
  --area-cta-hover:      #707070;

  /* Tipografia mantém Work Sans para coerência, mas reduzimos contraste de pesos */
}

body {
  background: var(--piave-branco);
  color: var(--piave-grafite);
}

/* ---------- BARRA DE MODO (toolbar fixa, injetada via JS) ---------- */
.wf-toolbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: #1A1A1A;
  color: #E0E0E0;
  padding: 0 20px;
  height: 48px;
  font-family: 'Work Sans', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-bottom: 1px dashed #555;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  box-sizing: border-box;
}
.wf-toolbar__label { color: #999; font-weight: 500; letter-spacing: 0.18em; }
.wf-toolbar__label strong { color: #FFF; font-weight: 700; margin-right: 8px; }
.wf-toolbar__links { display: flex; gap: 4px; align-items: center; }
.wf-toolbar__links a {
  color: #E0E0E0;
  padding: 6px 12px;
  border: 1px dashed #555;
  transition: all 0.2s;
  line-height: 1;
}
.wf-toolbar__links a:hover { background: #E0E0E0; color: #1A1A1A; border-color: #E0E0E0; }
.wf-toolbar__links a.is-current { background: #E0E0E0; color: #1A1A1A; border-style: solid; }
.wf-toolbar__hifi { color: #FCD9D0; border-color: #5C4A00 !important; border-style: solid !important; background: #4A3800; }
.wf-toolbar__hifi:hover { background: #FCD9D0; color: #4A3800; border-color: #FCD9D0 !important; }

/* Empurra todo o conteúdo da página pra baixo da toolbar (toolbar = 48px) */
body { padding-top: 48px; }

/* Header sticky gruda imediatamente abaixo da toolbar */
.site-header {
  top: 48px !important;
  /* Header precisa ter altura confortável pra acomodar nav + switcher */
  min-height: 72px;
  height: auto !important;
  z-index: 50 !important;
}
.country-overlay { padding-top: 60px !important; }

/* Pseudo-elements [COUNTRY] e [SWITCH] não devem quebrar layout flex */
.country-trigger::before,
.area-switcher::before {
  display: inline-block;
  flex-shrink: 0;
  white-space: nowrap;
}

/* Garante que o area-switcher fica na linha do header (3a coluna do grid) */
.header-cta-group { flex-shrink: 0; }
.area-switcher { flex-shrink: 0; }

/* Mobile: toolbar fica em coluna, viewport menor, dá mais espaço */
@media (max-width: 900px) {
  .wf-toolbar {
    flex-direction: column;
    gap: 6px;
    padding: 8px 12px;
    height: auto;
  }
  body { padding-top: 92px; }
  .site-header { top: 92px !important; }
}

/* ---------- HAMBURGER MENU (visível só abaixo de 1100px, onde a nav desktop some) ---------- */
@media (max-width: 1100px) {
  .header-cta-group::before {
    content: "☰ MENU";
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    margin-right: 8px;
    border: 1px dashed var(--piave-divider);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--piave-grafite);
    background: var(--piave-cinza-bg);
    cursor: pointer;
    line-height: 1;
  }
  .area-switcher { display: none !important; }
}

/* ---------- IFRAME EMBED MODE (suprime toolbar quando dentro de mockup mobile) ---------- */
body.is-embed { padding-top: 0 !important; }
body.is-embed .site-header { top: 0 !important; }

/* ---------- FOOTER CREDITS (DigitAll) — neutraliza azul em modo wireframe ---------- */
.footer-credits__logo .brand-all { color: rgba(255, 255, 255, 0.92) !important; }

/* ---------- ESTILO DE BLOCO WIREFRAME ---------- */
/* Botes principais viram contornos sólidos */
.btn-primary {
  background: var(--piave-grafite) !important;
  color: var(--piave-branco) !important;
  border: 1px solid var(--piave-grafite) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  transform: none !important;
}
.btn-primary:hover {
  background: var(--piave-branco) !important;
  color: var(--piave-grafite) !important;
}
.btn-primary::after { content: " [BTN PRIM]"; opacity: 0.55; font-weight: 400; font-size: 9px; letter-spacing: 0.1em; }

.btn-outline {
  border-color: var(--piave-grafite) !important;
  color: var(--piave-grafite) !important;
  border-radius: 0 !important;
}
.btn-outline::after { content: " [BTN SEC]"; opacity: 0.55; font-weight: 400; font-size: 9px; letter-spacing: 0.1em; }

.btn-ghost::after { content: " [LINK CTA]"; opacity: 0.55; font-weight: 400; font-size: 9px; letter-spacing: 0.1em; margin-left: 6px; }

/* ---------- LOGO/BRAND-MARK ---------- */
.brand-mark__mark {
  background: var(--piave-grafite) !important;
  color: var(--piave-branco) !important;
  border: 1px dashed var(--piave-divider);
}
.brand-mark { letter-spacing: 0.04em; }
[data-area="pro"] .brand-mark::after {
  color: var(--piave-grafite-light) !important;
  border-left-color: var(--piave-divider) !important;
}

/* ---------- HEADER ---------- */
.site-header {
  background: var(--piave-branco) !important;
  border-bottom: 1px dashed var(--piave-divider) !important;
}
.country-trigger {
  border: 1px dashed var(--piave-divider) !important;
  background: var(--piave-cinza-bg) !important;
}
.country-trigger::before { content: "[COUNTRY] "; font-size: 9px; color: var(--piave-grafite-light); letter-spacing: 0.1em; margin-right: 6px; }

.area-switcher { border: 1px dashed var(--piave-divider) !important; background: var(--piave-branco) !important; }
.area-switcher__btn.is-active { background: var(--piave-grafite) !important; color: var(--piave-branco) !important; }
.area-switcher::before { content: "[SWITCH]"; align-self: center; font-size: 9px; color: var(--piave-grafite-light); letter-spacing: 0.1em; padding: 0 8px; }

.primary-nav__link { color: var(--piave-grafite) !important; }
.nav-dropdown { background: var(--piave-branco) !important; border: 1px dashed var(--piave-divider) !important; box-shadow: none !important; }
.nav-dropdown a { color: var(--piave-grafite) !important; }
.nav-dropdown a:hover { background: var(--piave-cinza-bg) !important; }

/* ---------- HERO ---------- */
.hero {
  background: var(--piave-cinza-bg) !important;
  border-bottom: 1px dashed var(--piave-divider);
  position: relative;
}
.hero--grafite { background: var(--piave-grafite) !important; }
.hero--grafite h1, .hero--grafite .display, .hero--grafite .lead { color: var(--piave-branco) !important; }
.hero--verde, .hero--salmao, .hero--cinza { background: var(--piave-cinza-bg) !important; }

.hero::before {
  content: "[HERO]";
  position: absolute;
  top: 8px;
  left: 12px;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.16em;
  color: var(--piave-grafite-light);
  z-index: 2;
}

/* ---------- SECTIONS ---------- */
.section {
  border-bottom: 1px dashed var(--piave-divider);
  position: relative;
}
.section--white, .section--cinza, .section--verde, .section--salmao { background: var(--piave-branco) !important; }
.section--grafite { background: var(--piave-grafite) !important; }
.section--grafite h1, .section--grafite h2, .section--grafite h3 { color: var(--piave-branco) !important; }

/* Rótulo genérico de bloco */
.section::before {
  content: "[SECTION]";
  position: absolute;
  top: 8px;
  left: 12px;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.16em;
  color: var(--piave-grafite-light);
}
.section--grafite::before { color: rgba(255,255,255,0.45); }

/* ---------- EYEBROW E LEAD ---------- */
.eyebrow {
  color: var(--piave-grafite-soft) !important;
  border-left: 2px solid var(--piave-grafite-light);
  padding-left: 8px;
}
.lead { color: var(--piave-grafite-soft) !important; }
.title-mix em { color: var(--piave-grafite) !important; font-style: italic; }

/* ---------- IMAGENS → PLACEHOLDERS ---------- */
img {
  visibility: hidden;
  position: relative;
}
img::after {
  visibility: visible;
  content: "[IMG: " attr(alt) "]";
  display: block;
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    45deg,
    #EAEAEA,
    #EAEAEA 8px,
    #DEDEDE 8px,
    #DEDEDE 16px
  );
  color: var(--piave-grafite-soft);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: 8px;
  text-align: center;
}

/* Cobertura para containers com img filho */
.line-card__media, .product-card__media, .pistache-feature__visual, .hero-visual {
  background: var(--piave-cinza-bg) !important;
  position: relative;
  display: flex !important;
  align-items: center;
  justify-content: center;
}
.line-card__media::before {
  content: "[IMG LINHA]";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(45deg, #EAEAEA, #EAEAEA 8px, #DEDEDE 8px, #DEDEDE 16px);
  color: var(--piave-grafite-soft);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 0;
}
.line-card__media img { display: none; }
.line-card__media .line-card__tag {
  background: var(--piave-branco) !important;
  border: 1px solid var(--piave-grafite) !important;
  color: var(--piave-grafite) !important;
  z-index: 1;
}

.product-card__media {
  aspect-ratio: 1 !important;
  background: var(--piave-cinza-bg) !important;
  position: relative;
}
.product-card__media::before {
  content: "[IMG PRODUTO]";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(45deg, #EAEAEA, #EAEAEA 8px, #DEDEDE 8px, #DEDEDE 16px);
  color: var(--piave-grafite-soft);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.14em;
  display: flex;
  align-items: center;
  justify-content: center;
}
.product-card__media * { display: none !important; }

.pistache-feature {
  background: var(--piave-cinza-bg) !important;
  border: 1px dashed var(--piave-divider) !important;
  border-radius: 0 !important;
}
.pistache-feature__visual {
  background: var(--piave-branco) !important;
  border: 1px dashed var(--piave-divider);
  border-radius: 0 !important;
  font-size: 0 !important;
  position: relative;
}
.pistache-feature__visual::before {
  content: "[VISUAL HERO PISTACHE]";
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.16em;
  color: var(--piave-grafite-soft);
  text-align: center;
}

/* ---------- ELEMENTOS DECORATIVOS (emoji-heroes) ---------- */
/* Esconde emoji decorativo gigante usado em vez de imagem */
[style*="font-size: 14rem"],
[style*="font-size: 12rem"],
[style*="font-size: 9rem"] {
  font-size: 0 !important;
  background: var(--piave-cinza-bg);
  border: 1px dashed var(--piave-divider);
  aspect-ratio: 4/5;
  display: flex !important;
  align-items: center;
  justify-content: center;
  position: relative;
}
[style*="font-size: 14rem"]::before,
[style*="font-size: 12rem"]::before,
[style*="font-size: 9rem"]::before {
  content: "[IMG EDITORIAL]";
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  color: var(--piave-grafite-soft);
}

/* ---------- PRO SEAL ---------- */
.pro-seal {
  background: var(--piave-branco) !important;
  color: var(--piave-grafite) !important;
  border: 2px dashed var(--piave-grafite) !important;
}
.pro-seal::before { border-style: dashed !important; animation: none !important; }
.pro-seal__ring { color: var(--piave-grafite-soft) !important; }

/* ---------- AREA CARDS (Home vs PRO) ---------- */
.area-card {
  background: var(--piave-cinza-bg) !important;
  border: 1px dashed var(--piave-divider) !important;
  box-shadow: none !important;
}
.area-card--pro { background: var(--piave-grafite) !important; color: var(--piave-branco) !important; }
.area-card--pro .area-card__desc { color: rgba(255,255,255,0.78) !important; }
.area-card__tag {
  background: var(--piave-branco) !important;
  color: var(--piave-grafite) !important;
  border: 1px solid var(--piave-grafite) !important;
}
.area-card--pro .area-card__tag { background: var(--piave-grafite-light) !important; color: var(--piave-grafite) !important; }
.area-card__title em { color: inherit !important; }

/* ---------- LINE CARDS / PRODUCT CARDS — contorno ---------- */
.line-card, .product-card {
  border: 1px dashed var(--piave-divider);
  background: var(--piave-branco) !important;
  box-shadow: none !important;
  transform: none !important;
}
.line-card:hover, .product-card:hover {
  transform: none !important;
  border-color: var(--piave-grafite);
}
.line-card__body, .product-card__body { background: var(--piave-branco) !important; }
.line-card__name, .product-card__name { color: var(--piave-grafite) !important; }
.line-card__benefit, .product-card__line { color: var(--piave-grafite-soft) !important; }

/* ---------- FOOTER ---------- */
.site-footer {
  background: var(--piave-grafite) !important;
  border-top: 1px dashed var(--piave-divider);
  position: relative;
}
.site-footer::before {
  content: "[FOOTER]";
  position: absolute;
  top: 8px;
  left: 12px;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.16em;
  color: rgba(255,255,255,0.45);
}

/* ---------- COUNTRY OVERLAY ---------- */
.country-overlay { background: rgba(42, 42, 42, 0.8) !important; backdrop-filter: blur(4px); }
.country-panel { background: var(--piave-branco) !important; border: 1px dashed var(--piave-divider); }
.continents-grid button.is-active { background: var(--piave-grafite) !important; }
.country-link .badge--shop { background: var(--piave-grafite) !important; color: var(--piave-branco) !important; }
.country-link .badge--distrib { background: var(--piave-grafite-light) !important; color: var(--piave-grafite) !important; }
.country-link .badge--soon { background: var(--piave-cinza-bg) !important; color: var(--piave-grafite-light) !important; }

/* ---------- GEO BANNER ---------- */
.geo-banner { border-top-color: var(--piave-grafite) !important; }

/* ---------- TIMELINE / TABS / ACCORDION ---------- */
.timeline__dot { background: var(--piave-grafite) !important; color: var(--piave-branco) !important; }
.tabs button.is-active { color: var(--piave-grafite) !important; border-bottom-color: var(--piave-grafite) !important; }
.accordion__head { color: var(--piave-grafite) !important; }
.accordion__item.is-open { background: var(--piave-cinza-bg); }

/* ---------- FORMS ---------- */
.form-field input, .form-field select, .form-field textarea {
  background: var(--piave-branco) !important;
  border: 1px dashed var(--piave-divider) !important;
  border-radius: 0 !important;
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus {
  border-color: var(--piave-grafite) !important;
  border-style: solid !important;
}

/* ---------- WHATSAPP FLOAT ---------- */
.wa-float {
  background: var(--piave-grafite) !important;
  color: var(--piave-branco) !important;
  border: 1px dashed var(--piave-branco);
}

/* ---------- ANOTAÇÕES INLINE ([NOTE]) ---------- */
.wf-note {
  display: inline-block;
  background: #FFF4C0;
  color: #5C4A00;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  border-left: 3px solid #D9B400;
  margin: 8px 0;
  text-transform: uppercase;
}

/* ---------- ESCONDE GRADIENTES E SOMBRAS RESIDUAIS ---------- */
*[class*="line-card"]::after { display: none !important; }
.line-card::after { display: none !important; }

/* Espaço entre seções mais compacto para wireframe */
.section { padding-block: clamp(48px, 6vw, 80px); }

/* Filtros e chips em wireframe */
.chip {
  border-style: dashed !important;
  border-radius: 0 !important;
  background: var(--piave-branco) !important;
}
.chip.is-active { background: var(--piave-grafite) !important; color: var(--piave-branco) !important; border-style: solid !important; }

/* Salao card no localizador */
.salao.is-active { background: var(--piave-cinza-bg) !important; border-left: 3px solid var(--piave-grafite); }
.locator__map { background: var(--piave-cinza-bg) !important; border: 1px dashed var(--piave-divider); }
.locator__map::before {
  content: "[MAPA INTERATIVO · Google Maps ou Mapbox no site final]";
  position: absolute;
  top: 50%; left: 50%; transform: translate(-50%, -50%);
  background: var(--piave-branco);
  padding: 16px 24px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.16em;
  color: var(--piave-grafite-soft);
  border: 1px dashed var(--piave-divider);
  text-transform: uppercase;
  z-index: 5;
  text-align: center;
}
.map-pin { background: var(--piave-grafite) !important; border-color: var(--piave-branco) !important; }
.map-pin.is-active { background: var(--piave-grafite) !important; }

/* Antes/Depois cards */
[style*="background: var(--linha-"] {
  /* Cards de cor de linha viram cinza */
}
