/* Design token system — LK Imports USA
   Estilo: Moderno/Clean — Sephora-inspired
   Paleta: preto editorial, branco puro, nude quente, dourado sutil
   Tipografia: Playfair Display (display) + Inter (body)
   Signature: linha dourada fina como separador de luxo + hover de produto com overlay escuro suave
*/

:root {
  --preto:      #0D0D0D;
  --branco:     #FFFFFF;
  --nude:       #F7F4F0;
  --nude-dark:  #EDE8E1;
  --dourado:    #C8A96E;
  --dourado-cl: #E8D5B0;
  --cinza:      #8A8A8A;
  --cinza-cl:   #F2F2F2;
  --cinza-bd:   #E0E0E0;
  --texto:      #1A1A1A;

  --fonte-display: 'Playfair Display', Georgia, serif;
  --fonte-body:    'Inter', -apple-system, sans-serif;

  --radius-sm:  4px;
  --radius:     8px;
  --trans:      .22s ease;
  --sombra:     0 2px 16px rgba(0,0,0,.08);
  --sombra-md:  0 6px 30px rgba(0,0,0,.13);
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { overflow-x: hidden; max-width: 100%; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body { font-family: var(--fonte-body); color: var(--texto); background: var(--branco); line-height: 1.6; font-size: 15px; }
a { text-decoration: none; color: inherit; }
img { display: block; max-width: 100%; }
button { font-family: inherit; cursor: pointer; }

/* ── TIPOGRAFIA ── */
h1, h2, h3 { font-family: var(--fonte-display); line-height: 1.2; letter-spacing: -.3px; }
h1 { font-size: clamp(2rem, 5vw, 3.2rem); font-weight: 700; }
h2 { font-size: clamp(1.5rem, 3.5vw, 2.2rem); font-weight: 600; }
h3 { font-size: 1.15rem; font-weight: 600; }

/* ── LAYOUT ── */
.container { max-width: 1260px; margin: 0 auto; padding: 0 1.5rem; }
.section { padding: 5rem 0; }

/* Linha dourada decorativa */
.linha-dourada {
  width: 40px; height: 2px;
  background: var(--dourado);
  display: block; margin: 1rem auto 0;
}
.linha-dourada.left { margin-left: 0; }

/* ── HEADER ── */
.header { position: relative; 
  background: var(--branco);
  border-bottom: 1px solid var(--cinza-bd);
  position: sticky; top: 0; z-index: 1000;
}
.header-top {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1.5rem; padding: 1.1rem 1.5rem;
  max-width: 1260px; margin: 0 auto;
}
.logo { display: flex; flex-direction: column; }
.logo-name {
  font-family: var(--fonte-display);
  font-size: 1.45rem; font-weight: 700;
  letter-spacing: .5px; color: var(--preto);
  line-height: 1;
}
.logo-sub { font-size: .62rem; letter-spacing: 3px; color: var(--cinza); text-transform: uppercase; margin-top: 2px; }

.header-busca { flex: 1; max-width: 460px; margin: 0 auto; }
.busca-form {
  display: flex;
  border: 1.5px solid var(--cinza-bd);
  border-radius: 2px;
  overflow: hidden;
  transition: var(--trans);
}
.busca-form:focus-within { border-color: var(--preto); }
.busca-input {
  flex: 1; border: none; padding: .6rem 1rem;
  font-size: .88rem; background: none; outline: none;
  font-family: var(--fonte-body); color: var(--texto);
}
.busca-input::placeholder { color: var(--cinza); }
.busca-btn {
  background: var(--preto); border: none;
  padding: .6rem 1rem; color: var(--branco);
  font-size: .9rem; transition: var(--trans);
}
.busca-btn:hover { background: #333; }

.header-acoes { display: flex; align-items: center; gap: 1rem; }
.btn-carrinho {
  display: flex; align-items: center; gap: .5rem;
  background: var(--preto); color: var(--branco);
  border: none; padding: .6rem 1.2rem;
  font-size: .82rem; font-weight: 600; letter-spacing: .5px;
  text-transform: uppercase; border-radius: 2px;
  transition: var(--trans); cursor: pointer;
}
.btn-carrinho:hover { background: #333; }
.carrinho-badge {
  background: var(--dourado); color: var(--preto);
  border-radius: 50%; width: 18px; height: 18px;
  font-size: .7rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}

/* ── NAV ── */
.nav { border-bottom: 1px solid var(--cinza-bd); background: var(--branco); }
.nav-inner { display: flex; align-items: center; justify-content: center; overflow-x: auto; overflow-y: visible; max-width: 1260px; margin: 0 auto; } .nav-inner-old {
  display: flex; align-items: center;
  max-width: 1260px; margin: 0 auto; padding: 0 1.5rem;
  overflow-x: auto; scrollbar-width: none;
}
.nav-inner::-webkit-scrollbar { display: none; }
.nav-inner a {
  display: block; padding: .75rem 1rem;
  font-size: .8rem; font-weight: 500; letter-spacing: .8px;
  text-transform: uppercase; color: var(--cinza);
  white-space: nowrap; transition: var(--trans);
  border-bottom: 2px solid transparent;
}
.nav-inner a:hover, .nav-inner a.ativo {
  color: var(--preto); border-bottom-color: var(--preto);
}

/* ── BANNER HERO ── */
.hero {
  background: var(--nude);
  padding: 5rem 1.5rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
  max-width: 1260px;
  margin: 0 auto;
}
.hero-eyebrow {
  font-size: .72rem; letter-spacing: 3px; text-transform: uppercase;
  color: var(--dourado); font-weight: 600; margin-bottom: 1rem;
}
.hero h1 { color: var(--preto); margin-bottom: 1.2rem; }
.hero p { color: var(--cinza); font-size: 1rem; max-width: 420px; margin-bottom: 2rem; line-height: 1.8; }
.hero-btns { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero-img {
  aspect-ratio: 4/5;
  background: var(--nude-dark);
  border-radius: var(--radius-sm);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  font-size: 5rem;
}

/* ── BOTÕES ── */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .75rem 1.8rem; border-radius: 2px;
  font-size: .8rem; font-weight: 600;
  letter-spacing: 1px; text-transform: uppercase;
  transition: var(--trans); border: 1.5px solid transparent;
  cursor: pointer;
}
.btn-preto { background: var(--preto); color: var(--branco); border-color: var(--preto); }
.btn-preto:hover { background: #333; border-color: #333; transform: translateY(-1px); }
.btn-outline { background: transparent; border-color: var(--preto); color: var(--preto); }
.btn-outline:hover { background: var(--preto); color: var(--branco); }
.btn-dourado { background: var(--dourado); color: var(--branco); border-color: var(--dourado); }
.btn-dourado:hover { background: #b8964e; border-color: #b8964e; }
.btn-sm { padding: .5rem 1.2rem; font-size: .75rem; }
.btn-block { width: 100%; justify-content: center; }

/* ── DIFERENCIAIS ── */
.diferenciais {
  border-top: 1px solid var(--cinza-bd);
  border-bottom: 1px solid var(--cinza-bd);
  padding: 1.5rem 0; background: var(--branco);
}
.diferenciais-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.diferencial-item {
  display: flex; align-items: center; gap: .9rem;
  padding: .8rem 1.5rem;
  border-right: 1px solid var(--cinza-bd);
}
.diferencial-item:last-child { border-right: none; }
.diferencial-icon { font-size: 1.4rem; flex-shrink: 0; }
.diferencial-texto strong { display: block; font-size: .82rem; font-weight: 700; color: var(--preto); }
.diferencial-texto span { font-size: .75rem; color: var(--cinza); }

/* ── SECTION TITULO ── */
.section-titulo { margin-bottom: 3rem; }
.section-titulo.center { text-align: center; }
.section-titulo .eyebrow {
  font-size: .72rem; letter-spacing: 3px; text-transform: uppercase;
  color: var(--dourado); font-weight: 600; margin-bottom: .6rem; display: block;
}
.section-titulo h2 { color: var(--preto); }
.section-titulo p { color: var(--cinza); margin-top: .6rem; font-size: .95rem; }

/* ── GRID PRODUTOS ── */
.produtos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 1.5rem;
}

/* ── CARD PRODUTO — signature element ── */
.produto-card {
  background: var(--branco);
  cursor: pointer;
  transition: var(--trans);
}
.produto-card:hover { transform: translateY(-4px); }
.produto-card:hover .produto-img::after { opacity: 1; }
.produto-card:hover .produto-acoes-quick { opacity: 1; transform: translateY(0); }

.produto-img {
  aspect-ratio: 1;
  background: var(--nude);
  overflow: hidden;
  position: relative;
}
.produto-img::after {
  content: '';
  position: absolute; inset: 0;
  background: rgba(0,0,0,.04);
  opacity: 0; transition: var(--trans);
}
.produto-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.produto-card:hover .produto-img img { transform: scale(1.03); }

.produto-badge {
  position: absolute; top: .8rem; left: .8rem;
  background: var(--preto); color: var(--branco);
  font-size: .65rem; font-weight: 700; letter-spacing: 1px;
  padding: .25rem .7rem; text-transform: uppercase; z-index: 1;
}
.produto-badge.novo { background: var(--dourado); color: var(--preto); }

.produto-acoes-quick {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: var(--preto); padding: .75rem;
  opacity: 0; transform: translateY(8px);
  transition: var(--trans); z-index: 2;
  display: flex; gap: .5rem;
}
.btn-add-quick {
  flex: 1; background: var(--branco); color: var(--preto);
  border: none; padding: .55rem; font-size: .75rem;
  font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
  cursor: pointer; transition: var(--trans);
}
.btn-add-quick:hover { background: var(--dourado); }

.produto-info { padding: 1rem .2rem .4rem; }
.produto-marca {
  font-size: .68rem; letter-spacing: 2px; text-transform: uppercase;
  color: var(--cinza); font-weight: 600; margin-bottom: .25rem;
}
.produto-nome {
  font-size: .88rem; font-weight: 500; color: var(--preto);
  line-height: 1.4; margin-bottom: .5rem;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  min-height: 2.5rem;
}
.produto-preco-linha { display: flex; align-items: baseline; gap: .5rem; }
.produto-preco { font-size: 1rem; font-weight: 700; color: var(--preto); }
.produto-preco-old { font-size: .8rem; color: var(--cinza); text-decoration: line-through; }

/* ── CATEGORIAS ── */
.categorias-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 1rem;
}
.categoria-card {
  background: var(--nude);
  padding: 2rem 1rem;
  text-align: center;
  transition: var(--trans);
  cursor: pointer;
  border: 1px solid transparent;
}
.categoria-card:hover { border-color: var(--preto); background: var(--branco); }
.categoria-nome { font-size: .78rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--preto); margin-top: .4rem; }
.categoria-qtd { font-size: .72rem; color: var(--cinza); margin-top: .2rem; }

/* ── FILTROS ── */
.catalogo-layout { display: grid; grid-template-columns: 220px 1fr; gap: 2.5rem; align-items: start; }
.filtros-sidebar { position: sticky; top: 90px; }
.filtro-titulo { font-size: .72rem; letter-spacing: 2px; text-transform: uppercase; font-weight: 700; color: var(--preto); margin-bottom: 1rem; }
.filtro-grupo { padding: 1.2rem 0; border-bottom: 1px solid var(--cinza-bd); }
.filtro-grupo:first-child { padding-top: 0; }
.filtro-item { display: flex; align-items: center; gap: .6rem; margin-bottom: .5rem; cursor: pointer; }
.filtro-item input { accent-color: var(--preto); cursor: pointer; }
.filtro-item label { font-size: .85rem; cursor: pointer; color: var(--cinza); transition: var(--trans); }
.filtro-item:hover label { color: var(--preto); }

/* ── PRODUTO DETALHE ── */
.produto-detalhe { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; }
.img-principal { aspect-ratio: 1; background: var(--nude); overflow: hidden; margin-bottom: 1rem; }
.img-principal img { width: 100%; height: 100%; object-fit: cover; }
.produto-miniaturas { display: flex; gap: .5rem; }
.produto-miniatura { width: 65px; aspect-ratio: 1; background: var(--nude); overflow: hidden; cursor: pointer; border: 1.5px solid transparent; transition: var(--trans); }
.produto-miniatura.ativo { border-color: var(--preto); }
.produto-miniatura img { width: 100%; height: 100%; object-fit: cover; }

.det-eyebrow { font-size: .7rem; letter-spacing: 2.5px; text-transform: uppercase; color: var(--dourado); font-weight: 600; margin-bottom: .6rem; }
.det-nome { font-family: var(--fonte-display); font-size: 1.8rem; font-weight: 700; margin-bottom: 1rem; line-height: 1.25; }
.det-preco { font-size: 1.6rem; font-weight: 700; margin-bottom: .3rem; }
.det-parcela { font-size: .82rem; color: var(--cinza); margin-bottom: 1.5rem; }
.det-attrs { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.5rem; }
.det-attr {
  font-size: .72rem; letter-spacing: 1px; text-transform: uppercase;
  font-weight: 600; padding: .35rem .9rem;
  border: 1px solid var(--cinza-bd); color: var(--cinza);
}
.det-acoes { display: flex; gap: .8rem; margin-bottom: 1.5rem; }
.qtd-control { display: flex; align-items: center; border: 1.5px solid var(--cinza-bd); }
.qtd-btn { width: 38px; height: 42px; background: none; border: none; font-size: 1.1rem; cursor: pointer; transition: var(--trans); }
.qtd-btn:hover { background: var(--cinza-cl); }
.qtd-input { width: 44px; text-align: center; border: none; border-left: 1.5px solid var(--cinza-bd); border-right: 1.5px solid var(--cinza-bd); height: 42px; font-size: .95rem; font-weight: 600; outline: none; }
.det-entrega { background: var(--nude); padding: 1.2rem; border-left: 3px solid var(--dourado); }
.det-entrega-item { font-size: .82rem; display: flex; gap: .6rem; padding: .3rem 0; color: var(--cinza); }

/* ── CARRINHO DRAWER ── */
.carrinho-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.4); z-index: 2000; opacity: 0; pointer-events: none; transition: opacity .3s; }
.carrinho-overlay.aberto { opacity: 1; pointer-events: auto; }
.carrinho-drawer {
  position: fixed; right: 0; top: 0; height: 100%; width: 400px; max-width: 100vw;
  background: var(--branco); z-index: 2001;
  transform: translateX(100%); transition: transform .32s cubic-bezier(.4,0,.2,1);
  display: flex; flex-direction: column;
  border-left: 1px solid var(--cinza-bd);
}
.carrinho-drawer.aberto { transform: translateX(0); }
.carrinho.header { position: relative;  display: flex; align-items: center; justify-content: space-between; padding: 1.3rem 1.5rem; border-bottom: 1px solid var(--cinza-bd); }
.carrinho-header h3 { font-family: var(--fonte-display); font-size: 1.1rem; font-weight: 600; }
.btn-fechar { background: none; border: none; font-size: 1.3rem; cursor: pointer; color: var(--cinza); transition: var(--trans); padding: .2rem; }
.btn-fechar:hover { color: var(--preto); }
.carrinho-items { flex: 1; overflow-y: auto; padding: 1.2rem 1.5rem; }
.carrinho-item { display: flex; gap: 1rem; padding: 1rem 0; border-bottom: 1px solid var(--cinza-bd); }
.carrinho-item-img { width: 72px; height: 72px; background: var(--nude); flex-shrink: 0; overflow: hidden; }
.carrinho-item-img img { width: 100%; height: 100%; object-fit: cover; }
.carrinho-item-nome { font-size: .85rem; font-weight: 500; margin-bottom: .3rem; line-height: 1.3; }
.carrinho-item-preco { font-size: .88rem; font-weight: 700; color: var(--preto); }
.carrinho-footer { padding: 1.5rem; border-top: 1px solid var(--cinza-bd); }
.carrinho-subtotal { display: flex; justify-content: space-between; font-size: .85rem; color: var(--cinza); margin-bottom: .5rem; }
.carrinho-total { display: flex; justify-content: space-between; font-size: 1rem; font-weight: 700; margin-bottom: 1.2rem; padding-top: .8rem; border-top: 1px solid var(--cinza-bd); }
.frete-info { font-size: .78rem; color: #2D7A4F; font-weight: 600; text-align: center; margin-bottom: .8rem; }

/* ── CHECKOUT ── */
.checkout-grid { display: grid; grid-template-columns: 1fr 380px; gap: 2.5rem; align-items: start; }
.checkout-card { border: 1px solid var(--cinza-bd); padding: 1.8rem; margin-bottom: 1.5rem; }
.checkout-card h3 { font-family: var(--fonte-display); font-size: 1rem; font-weight: 600; margin-bottom: 1.3rem; padding-bottom: .8rem; border-bottom: 1px solid var(--cinza-bd); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-full { grid-column: 1/-1; }
.form-group { display: flex; flex-direction: column; gap: .35rem; }
.form-group label { font-size: .72rem; letter-spacing: 1px; text-transform: uppercase; font-weight: 700; color: var(--cinza); }
.form-group input, .form-group select {
  border: 1.5px solid var(--cinza-bd); padding: .65rem .9rem;
  font-size: .9rem; outline: none; transition: var(--trans);
  border-radius: 0; font-family: var(--fonte-body); background: var(--branco);
}
.form-group input:focus, .form-group select:focus { border-color: var(--preto); }
.pagamento-opcoes { display: flex; gap: .8rem; margin-bottom: 1.2rem; }
.pagamento-opcao { flex: 1; border: 1.5px solid var(--cinza-bd); padding: 1rem; text-align: center; cursor: pointer; transition: var(--trans); }
.pagamento-opcao:hover { border-color: var(--cinza); }
.pagamento-opcao.ativo { border-color: var(--preto); }
.pagamento-opcao .icon { font-size: 1.3rem; margin-bottom: .3rem; }
.pagamento-opcao span { font-size: .72rem; letter-spacing: 1px; text-transform: uppercase; font-weight: 700; }

/* ── RESUMO ── */
.resumo-item { display: flex; gap: .8rem; padding: .8rem 0; border-bottom: 1px solid var(--cinza-bd); }
.resumo-img { width: 55px; height: 55px; background: var(--nude); flex-shrink: 0; overflow: hidden; }
.resumo-img img { width: 100%; height: 100%; object-fit: cover; }
.resumo-linha { display: flex; justify-content: space-between; font-size: .85rem; padding: .35rem 0; color: var(--cinza); }
.resumo-total { display: flex; justify-content: space-between; font-size: 1rem; font-weight: 700; padding-top: .8rem; margin-top: .4rem; border-top: 1.5px solid var(--preto); }

/* ── FOOTER ── */
.footer { background: var(--preto); color: rgba(255,255,255,.6); padding: 4rem 0 2rem; margin-top: 5rem; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 2.5rem; max-width: 1260px; margin: 0 auto 3rem; padding: 0 1.5rem; }
.footer-logo { font-family: var(--fonte-display); font-size: 1.3rem; font-weight: 700; color: var(--branco); margin-bottom: .8rem; }
.footer p { font-size: .82rem; line-height: 1.8; }
.footer h4 { font-size: .68rem; letter-spacing: 2.5px; text-transform: uppercase; font-weight: 700; color: var(--branco); margin-bottom: 1rem; }
.footer ul { list-style: none; }
.footer ul li { margin-bottom: .5rem; }
.footer ul li a { font-size: .82rem; transition: var(--trans); }
.footer ul li a:hover { color: var(--dourado); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); padding: 1.5rem 1.5rem 0; max-width: 1260px; margin: 0 auto; font-size: .75rem; display: flex; justify-content: space-between; align-items: center; }

/* ── PAGINAÇÃO ── */
.paginacao { display: flex; justify-content: center; gap: .3rem; margin-top: 3rem; }
.paginacao a, .paginacao span { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; font-size: .82rem; font-weight: 600; border: 1.5px solid var(--cinza-bd); transition: var(--trans); }
.paginacao a:hover { border-color: var(--preto); color: var(--preto); }
.paginacao .ativo { background: var(--preto); color: var(--branco); border-color: var(--preto); }

/* ── TOAST ── */
.toast-container { position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 9999; display: flex; flex-direction: column; gap: .5rem; }
.toast { background: var(--preto); color: var(--branco); padding: .9rem 1.3rem; font-size: .85rem; font-weight: 500; box-shadow: var(--sombra-md); animation: slideIn .25s ease; display: flex; align-items: center; gap: .6rem; min-width: 240px; }
.toast.sucesso { border-left: 3px solid var(--dourado); }
.toast.erro { border-left: 3px solid #E53935; }
@keyframes slideIn { from { transform: translateX(110%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }

/* ── RESPONSIVO ── */
.hero-full { background: var(--nude); }
.hero-full .hero { padding: 4rem 1.5rem; }

@media (max-width: 1024px) {
  .catalogo-layout { grid-template-columns: 1fr; }
  .filtros-sidebar {
    position: static;
    border: 1px solid var(--cinza-bd);
    margin-bottom: 1.5rem;
  }
  .filtros-sidebar .filtros-conteudo {
    display: none;
    padding: 1rem 1.2rem;
  }
  .filtros-sidebar.aberto .filtros-conteudo {
    display: block;
  }
  .filtros-toggle-mobile {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    padding: .9rem 1.2rem;
    cursor: pointer;
    font-weight: 700;
    font-size: .82rem;
    letter-spacing: .5px;
    text-transform: uppercase;
  }
  .checkout-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .diferenciais-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .hero { grid-template-columns: 1fr; }
  .hero-img { display: none; }
  .header-busca { display: none; }
  .header-busca-mobile { display: block !important; }
  .header-top { padding: .8rem 1rem; gap: .8rem; }
  .logo-name { font-size: 1.1rem; }
  .logo-sub { display: none; }
  .btn-carrinho { padding: .5rem .9rem; font-size: .75rem; }
  .nav { overflow: hidden; }
  .nav-inner { overflow-x: auto; overflow-y: visible; padding: 0 1rem; }
  .produto-detalhe { grid-template-columns: 1fr; gap: 2rem; }
  .form-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .diferenciais-grid { grid-template-columns: 1fr 1fr; }
  .carrinho-drawer { width: 100vw; max-width: 100vw; }
  .checkout-grid { grid-template-columns: 1fr; }
  .container { padding: 0 1rem; }
}
@media (max-width: 480px) {
  .produtos-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .carrinho-drawer { width: 100vw; }
  .diferenciais-grid { grid-template-columns: 1fr; }
}

/* ── UTILS ── */
.hidden { display: none !important; }
.text-center { text-align: center; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; }
.mb-3 { margin-bottom: 1.5rem; }

@media (max-width: 768px) {
  .btn-menu-mobile { display: flex !important; }
  .nav { display: none; }
  .nav-mobile {
    display: none;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,.5);
    z-index: 2000;
  }
  .nav-mobile.aberto { display: block; }
  .nav-mobile-inner {
    background: var(--branco);
    width: 80%;
    max-width: 300px;
    height: 100%;
    overflow-y: auto;
    padding: 1.5rem 0;
    transform: translateX(-100%);
    transition: transform .3s ease;
  }
  .nav-mobile.aberto .nav-mobile-inner { transform: translateX(0); }
  .nav-mobile-inner a {
    display: block;
    padding: .9rem 1.5rem;
    font-size: .85rem;
    font-weight: 600;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--cinza);
    border-bottom: 1px solid var(--cinza-cl);
    transition: .15s;
  }
  .nav-mobile-inner a:hover { color: var(--preto); background: var(--nude); }
  .nav-mobile-titulo {
    padding: 1rem 1.5rem .5rem;
    font-size: .65rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--dourado);
    font-weight: 700;
  }
  .nav-mobile-fechar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .8rem 1.5rem 1.2rem;
    border-bottom: 2px solid var(--cinza-bd);
    margin-bottom: .5rem;
  }
  .nav-mobile-fechar strong {
    font-family: var(--fonte-display);
    font-size: 1rem;
  }
}
/* Menu mobile hamburguer */
@media (max-width: 768px) {
  .btn-menu-mobile { display: flex !important; }
  .nav { display: none !important; }
  .menu-mobile-aberto {
    display: block !important;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--branco);
    border-top: 2px solid var(--preto);
    box-shadow: 0 8px 24px rgba(0,0,0,.15);
    z-index: 9999;
    max-height: 80vh;
    overflow-y: auto;
  }
}
.menu-mobile-dropdown {
  display: none;
}
.menu-mobile-dropdown a {
  display: block;
  padding: .85rem 1.5rem;
  font-size: .85rem;
  font-weight: 600;
  letter-spacing: .5px;
  text-transform: uppercase;
  color: var(--cinza);
  border-bottom: 1px solid var(--cinza-cl);
}
.menu-mobile-dropdown a:hover { color: var(--preto); background: var(--nude); }
.menu-mobile-secao {
  padding: .6rem 1.5rem .3rem;
  font-size: .65rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--dourado);
  font-weight: 700;
  background: var(--nude);
}

.filtros-toggle-mobile { display: none; }
.header-busca-mobile { display: none; }
@media (max-width: 768px) {
  .header-busca-mobile {
    padding: .7rem 1rem;
    border-top: 1px solid var(--cinza-bd);
  }
  .header-busca-mobile .busca-form {
    max-width: 100%;
    margin: 0;
  }
}
