/*
Theme Name: Yellowbox
Theme URI: https://yellowbox.com.br
Author: Yellowbox
Description: Tema WooCommerce com a identidade visual Yellowbox (amarelo e preto). Mantém o motor do WooCommerce — carrinho, checkout, Mercado Pago e Melhor Envio — e aplica o visual do marketplace. Suporta blocos de produto, busca e conta reais.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: yellowbox
Tags: e-commerce, woocommerce, custom-colors, custom-menu, featured-images, two-columns, right-sidebar
WC requires at least: 6.0
WC tested up to: 11.0
*/

/* ===================== TOKENS YELLOWBOX ===================== */
:root{
  --amarelo:#FFD100; --amarelo-escuro:#E6BD00; --preto:#111111; --branco:#FFFFFF;
  --cinza:#2B2B2B; --cinza-claro:#f4f4f5; --cinza-borda:#e5e5e5;
  --texto:#1f1f1f; --texto-suave:#6b7280; --verde:#16a34a; --vermelho:#dc2626;
  --sombra:0 4px 18px rgba(0,0,0,.06); --sombra-hover:0 12px 30px rgba(0,0,0,.12);
}
*{ box-sizing:border-box; }
body{ margin:0; font-family:'Inter','Segoe UI',sans-serif; color:var(--texto); background:#fafafa; }
h1,h2,h3,h4,.display{ font-family:'Poppins','Segoe UI',sans-serif; margin:0; }
a{ text-decoration:none; color:inherit; }
img{ max-width:100%; height:auto; }
.container{ width:100%; max-width:1180px; margin:0 auto; padding:0 20px; }
.amarelo-bg{ background:var(--amarelo); } .preto-bg{ background:var(--preto); }

/* HEADER */
.topbar{ background:var(--branco); border-bottom:1px solid var(--cinza-borda); position:sticky; top:0; z-index:50; }
.topbar-inner{ display:flex; align-items:center; gap:20px; padding:14px 20px; max-width:1180px; margin:0 auto; }
.logo{ display:flex; align-items:center; gap:8px; font-family:'Poppins'; font-weight:800; font-size:24px; letter-spacing:-.5px; color:var(--preto); white-space:nowrap; }
.logo .cubo{ width:30px; height:30px; }
.logo img{ height:34px; width:auto; }
.busca{ flex:1; display:flex; align-items:center; background:var(--cinza-claro); border:1.5px solid transparent; border-radius:10px; overflow:hidden; min-width:0; }
.busca:focus-within{ border-color:var(--amarelo); background:#fff; }
.busca input{ flex:1; border:0; background:transparent; padding:13px 16px; font-size:15px; outline:none; min-width:0; }
.busca button{ background:var(--preto); color:#fff; border:0; padding:0 20px; align-self:stretch; cursor:pointer; font-size:16px; }
.busca button:hover{ background:var(--cinza); }
.acoes{ display:flex; align-items:center; gap:22px; }
.acao{ background:none; border:0; cursor:pointer; display:flex; align-items:center; gap:8px; color:var(--preto); font-size:13px; line-height:1.1; font-family:inherit; position:relative; }
.acao i{ font-size:20px; } .acao .rotulo{ text-align:left; }
.acao .rotulo b{ display:block; font-size:13px; } .acao .rotulo span{ color:var(--texto-suave); font-size:11px; }
.badge{ position:absolute; top:-6px; left:14px; background:var(--amarelo); color:var(--preto); font-size:10px; font-weight:800; min-width:17px; height:17px; padding:0 4px; border-radius:99px; display:none; align-items:center; justify-content:center; }
.badge.on{ display:flex; }
.navbar{ background:var(--preto); }
.navbar-inner{ display:flex; align-items:center; gap:6px; max-width:1180px; margin:0 auto; padding:0 20px; overflow-x:auto; }
.nav-cats{ display:flex; align-items:center; gap:8px; background:var(--cinza); color:#fff; font-weight:600; font-size:14px; padding:13px 16px; border:0; cursor:pointer; font-family:inherit; white-space:nowrap; }
.nav-menu{ display:flex; align-items:center; gap:0; list-style:none; margin:0; padding:0; }
.nav-menu li{ list-style:none; }
.nav-link, .nav-menu a{ color:#e5e5e5; font-size:14px; font-weight:500; padding:13px 12px; white-space:nowrap; cursor:pointer; background:none; border:0; font-family:inherit; display:inline-block; }
.nav-link:hover, .nav-menu a:hover{ color:var(--amarelo); }
.btn-ofertas-dia{ margin-left:auto; display:flex; align-items:center; gap:8px; background:var(--amarelo); color:var(--preto); font-weight:800; font-size:13px; padding:9px 18px; border-radius:8px; border:0; cursor:pointer; font-family:inherit; white-space:nowrap; }
.btn-ofertas-dia:hover{ background:var(--amarelo-escuro); }

/* HERO */
.hero{ background:var(--amarelo); padding:56px 0 0; }
.hero-grid{ display:grid; grid-template-columns:1fr 1fr; gap:30px; align-items:center; }
.hero .eyebrow{ display:inline-block; background:var(--preto); color:var(--amarelo); font-weight:700; font-size:12px; letter-spacing:.5px; padding:7px 14px; border-radius:99px; }
.hero h1{ font-size:54px; line-height:1.02; font-weight:800; color:var(--preto); margin:18px 0 16px; letter-spacing:-1px; }
.hero p{ font-size:18px; color:#3a3a1a; max-width:430px; margin:0 0 28px; }
.hero-botoes{ display:flex; gap:14px; flex-wrap:wrap; }
.btn-preto{ background:var(--preto); color:#fff; font-weight:700; padding:15px 30px; border-radius:10px; border:0; cursor:pointer; font-family:inherit; font-size:15px; display:inline-block; }
.btn-preto:hover{ background:var(--cinza); color:#fff; }
.btn-outline-preto{ background:transparent; color:var(--preto); font-weight:700; padding:15px 30px; border-radius:10px; border:2px solid var(--preto); cursor:pointer; font-family:inherit; font-size:15px; display:inline-block; }
.btn-outline-preto:hover{ background:var(--preto); color:#fff; }
.hero-visual{ display:flex; justify-content:center; }
.hero-trust{ display:flex; gap:26px; flex-wrap:wrap; padding:26px 0 30px; }
.trust-item{ display:flex; align-items:center; gap:11px; color:var(--preto); }
.trust-item i{ font-size:22px; }
.trust-item b{ display:block; font-size:13px; } .trust-item span{ font-size:12px; color:#4a4a25; }

/* SEÇÕES */
section.bloco{ padding:46px 0; }
.titulo-secao{ font-size:24px; font-weight:800; color:var(--preto); margin-bottom:26px; }
.titulo-secao.center{ text-align:center; }
.cats-grid{ display:grid; grid-template-columns:repeat(10,1fr); gap:14px; }
.cat-item{ text-align:center; cursor:pointer; }
.cat-bola{ width:84px; height:84px; margin:0 auto 10px; border-radius:50%; background:#fff; border:1px solid var(--cinza-borda); display:flex; align-items:center; justify-content:center; font-size:30px; color:var(--preto); transition:.2s; box-shadow:var(--sombra); overflow:hidden; }
.cat-bola img{ width:100%; height:100%; object-fit:cover; }
.cat-item:hover .cat-bola{ transform:translateY(-5px); box-shadow:var(--sombra-hover); border-color:var(--amarelo); }
.cat-item span{ font-size:12px; font-weight:600; color:var(--cinza); display:block; }
.duas-colunas{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.painel{ background:#fff; border:1px solid var(--cinza-borda); border-radius:16px; padding:22px; box-shadow:var(--sombra); }
.painel-topo{ display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.painel-topo h3{ font-size:19px; font-weight:800; color:var(--preto); }
.ver-todas{ font-size:13px; font-weight:700; color:var(--cinza); cursor:pointer; }
.ver-todas:hover{ color:var(--amarelo-escuro); }
.cronometro{ display:flex; align-items:center; gap:6px; font-size:12px; color:var(--texto-suave); }
.cronometro b{ background:var(--preto); color:#fff; padding:3px 7px; border-radius:5px; font-family:'Poppins'; font-size:13px; }
.cards-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
@media(min-width:560px){ .cards-2{ grid-template-columns:repeat(4,1fr); } }

/* CARD (compartilhado: home + loja/categoria WooCommerce) */
.card{ background:#fff; border:1px solid var(--cinza-borda); border-radius:14px; padding:12px; display:flex; flex-direction:column; transition:.18s; position:relative; }
.card:hover{ transform:translateY(-4px); box-shadow:var(--sombra-hover); }
.card .selo{ position:absolute; top:10px; left:10px; font-size:10px; font-weight:800; padding:4px 8px; border-radius:6px; z-index:2; }
.selo.frete{ background:#dcfce7; color:var(--verde); } .selo.mais{ background:var(--preto); color:var(--amarelo); } .selo.desc{ background:var(--vermelho); color:#fff; }
.card .fav{ position:absolute; top:8px; right:8px; background:#fff; border:1px solid var(--cinza-borda); width:32px; height:32px; border-radius:50%; cursor:pointer; color:#9ca3af; z-index:2; }
.card .fav.ativo{ color:var(--vermelho); border-color:var(--vermelho); }
.card .img{ height:160px; display:flex; align-items:center; justify-content:center; font-size:54px; margin:8px 0 12px; overflow:hidden; }
.card .img img{ max-height:100%; width:auto; object-fit:contain; }
.card .nome{ font-size:13px; font-weight:600; color:var(--texto); line-height:1.3; min-height:34px; }
.card .nome a{ color:inherit; }
.estrelas{ color:var(--amarelo-escuro); font-size:12px; margin:6px 0; } .estrelas span{ color:var(--texto-suave); margin-left:4px; }
.preco-antigo{ font-size:12px; color:var(--texto-suave); text-decoration:line-through; }
.preco{ font-size:21px; font-weight:800; color:var(--preto); font-family:'Poppins'; }
.preco .amount{ font-weight:800; }
.parcela{ font-size:12px; color:var(--verde); font-weight:600; }
.frete-gratis-txt{ font-size:11px; font-weight:800; color:var(--verde); margin-top:2px; }
.btn-comprar{ margin-top:12px; background:var(--amarelo); color:var(--preto); font-weight:800; border:0; padding:10px; border-radius:9px; cursor:pointer; font-family:inherit; font-size:13px; text-align:center; display:block; width:100%; }
.btn-comprar:hover{ background:var(--amarelo-escuro); color:var(--preto); }
.btn-comprar.loading, .btn-comprar.added{ opacity:.85; }

/* DIFERENCIAIS */
.dif-grid{ display:grid; grid-template-columns:repeat(8,1fr); gap:10px; }
.dif{ text-align:center; padding:18px 8px; }
.dif i{ font-size:30px; color:var(--amarelo-escuro); }
.dif p{ font-size:12px; font-weight:700; color:var(--cinza); margin:10px 0 0; line-height:1.3; }

/* VENDA (preto) */
.venda{ background:var(--preto); color:#fff; }
.venda-grid{ display:grid; grid-template-columns:1fr 1.2fr; gap:30px; align-items:center; padding:50px 0; }
.venda h2{ color:#fff; font-size:30px; font-weight:800; }
.venda p{ color:#cfcfcf; margin:14px 0 24px; max-width:380px; }
.btn-amarelo{ background:var(--amarelo); color:var(--preto); font-weight:800; padding:14px 28px; border-radius:10px; border:0; cursor:pointer; font-family:inherit; font-size:15px; display:inline-block; }
.btn-amarelo:hover{ background:var(--amarelo-escuro); color:var(--preto); }
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.stat i{ font-size:26px; color:var(--amarelo); }
.stat b{ display:block; font-size:22px; font-family:'Poppins'; margin-top:8px; } .stat span{ font-size:12px; color:#9ca3af; }

/* APP + NEWSLETTER */
.app-grid{ display:grid; grid-template-columns:1fr 1fr; gap:30px; align-items:center; }
.app-benef{ list-style:none; padding:0; margin:18px 0 0; }
.app-benef li{ display:flex; align-items:center; gap:10px; padding:6px 0; font-weight:600; color:var(--cinza); }
.app-benef i{ color:var(--amarelo-escuro); }
.newsletter{ background:var(--amarelo); border-radius:20px; padding:40px; display:flex; flex-direction:column; justify-content:center; }
.newsletter h2{ font-size:26px; font-weight:800; color:var(--preto); }
.news-form{ display:flex; gap:10px; margin-top:18px; }
.news-form input{ flex:1; border:0; border-radius:10px; padding:14px 16px; font-size:14px; outline:none; }
.news-form button{ background:var(--preto); color:#fff; font-weight:800; border:0; padding:0 22px; border-radius:10px; cursor:pointer; font-family:inherit; white-space:nowrap; }

/* FOOTER */
footer.rodape{ background:var(--preto); color:#cfcfcf; padding:46px 0 0; }
.rodape-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr 1.2fr; gap:24px; }
.rodape h5{ color:#fff; font-size:13px; letter-spacing:.5px; margin:0 0 14px; text-transform:uppercase; }
.rodape ul{ list-style:none; padding:0; margin:0; }
.rodape li{ font-size:13px; padding:5px 0; cursor:pointer; } .rodape li:hover{ color:var(--amarelo); }
.rodape a:hover{ color:var(--amarelo); }
.rodape .logo{ color:#fff; }
.socials{ display:flex; gap:10px; margin-top:14px; }
.socials a{ width:36px; height:36px; border-radius:50%; background:var(--cinza); display:flex; align-items:center; justify-content:center; color:#fff; }
.socials a:hover{ background:var(--amarelo); color:var(--preto); }
.rodape-base{ border-top:1px solid #2b2b2b; margin-top:34px; padding:18px 0; text-align:center; font-size:12px; color:#8a8a8a; }

/* FOCO / ACESSIBILIDADE */
button:focus-visible,a:focus-visible,input:focus-visible{ outline:3px solid var(--amarelo); outline-offset:2px; }
@media (prefers-reduced-motion: reduce){ *{ transition:none!important; } }

/* ===================== WOOCOMMERCE ===================== */
.woo-banner{ background:var(--preto); color:#fff; padding:34px 0; margin-bottom:6px; }
.woo-banner .container{ display:flex; flex-direction:column; gap:6px; }
.woo-banner h1{ color:#fff; font-size:30px; font-weight:800; }
.woo-banner p{ color:#cfcfcf; margin:0; font-size:14px; }
.woo-wrap{ padding-top:6px; }

/* Grade de produtos do WooCommerce com o card Yellowbox */
.woocommerce ul.products, .woocommerce-page ul.products{ display:grid; gap:16px; margin:0; padding:0; list-style:none; grid-template-columns:repeat(2,1fr); }
@media(min-width:560px){ .woocommerce ul.products{ grid-template-columns:repeat(3,1fr); } }
@media(min-width:820px){ .woocommerce ul.products{ grid-template-columns:repeat(4,1fr); } }
.woocommerce ul.products li.product{ width:auto!important; margin:0!important; float:none!important; }
.woocommerce ul.products li.product::before, .woocommerce ul.products li.product::after{ display:none; }

/* Botões padrão do WooCommerce → amarelo/preto */
.woocommerce #respond input#submit,
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce a.button.alt, .woocommerce button.button.alt, .woocommerce input.button.alt,
.woocommerce #respond input#submit.alt{
  background:var(--amarelo); color:var(--preto); font-weight:800; border-radius:9px; border:0;
  font-family:'Inter',sans-serif; text-transform:none; padding:12px 22px; transition:.15s;
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce a.button.alt:hover, .woocommerce button.button.alt:hover, .woocommerce #respond input#submit:hover{
  background:var(--amarelo-escuro); color:var(--preto);
}
.woocommerce .button.btn-preto, .woocommerce-info a.button{ background:var(--preto); color:#fff; }

/* Preços, links e estrelas */
.woocommerce div.product p.price, .woocommerce div.product span.price,
.woocommerce ul.products li.product .price{ color:var(--preto); font-family:'Poppins'; font-weight:800; }
.woocommerce .star-rating span{ color:var(--amarelo-escuro); }
.woocommerce a{ color:var(--preto); }

/* Mensagens / avisos */
.woocommerce-message, .woocommerce-info, .woocommerce-error, .woocommerce-noreviews{
  border-top-color:var(--amarelo); border-radius:10px;
}
.woocommerce-message::before, .woocommerce-info::before{ color:var(--amarelo-escuro); }

/* Tabela do carrinho / formulários */
.woocommerce table.shop_table{ border-radius:12px; overflow:hidden; }
.woocommerce form .form-row input.input-text, .woocommerce .select2-container,
.woocommerce form .form-row textarea{ border-radius:9px; }
.woocommerce .cart-collaterals .cart_totals, .woocommerce-checkout #payment{ border-radius:12px; }

/* Título de página padrão (woocommerce_show_page_title) escondido — usamos o banner */
.woocommerce-products-header__title.page-title{ display:none; }

/* Ordenação / contagem */
.woocommerce .woocommerce-result-count{ color:var(--texto-suave); font-size:13px; }
.woocommerce .woocommerce-ordering select{ border-radius:9px; padding:8px 10px; border:1.5px solid var(--cinza-borda); }

/* Página simples (page.php) */
.pagina-simples{ background:#fff; }
.pagina-simples .entry-title{ font-size:30px; font-weight:800; color:var(--preto); margin-bottom:18px; }
.pagina-simples .entry-content{ line-height:1.7; color:var(--texto); }
.pagina-simples .entry-content a{ color:var(--amarelo-escuro); font-weight:600; }

/* RESPONSIVO */
@media(max-width:900px){
  .hero-grid,.duas-colunas,.venda-grid,.app-grid{ grid-template-columns:1fr; }
  .hero h1{ font-size:38px; }
  .cats-grid{ grid-template-columns:repeat(5,1fr); }
  .dif-grid{ grid-template-columns:repeat(4,1fr); }
  .rodape-grid{ grid-template-columns:repeat(2,1fr); }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .acao .rotulo{ display:none; }
}
@media(max-width:520px){ .cats-grid{ grid-template-columns:repeat(3,1fr); } }
