/*
Theme Name: Beatek Child
Theme URI: https://loja.grupobeatek.com.br
Description: Tema premium industrial do Grupo Beatek com homepage de loja.
Author: Grupo Beatek
Template: generatepress
Version: 1.2.0
Text Domain: beatek-child
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --teal-900:#0B3C42; --teal-700:#115E67; --teal-500:#1A8A95; --teal-100:#E6F2F3;
  --amber-600:#B8860B; --amber-500:#D4A017; --amber-400:#E5B73B;
  --bg-soft:#F4F7F8; --bg-card:#FFFFFF; --line:#E6EAEC;
  --ink-900:#0F1A1C; --ink-700:#2A3A3D; --ink-500:#5C6B6E; --ink-300:#97A2A4;
  --success:#1F8A4C; --danger:#C0392B;
  --shadow-sm:0 2px 8px rgba(11,60,66,.04);
  --shadow-md:0 4px 20px rgba(11,60,66,.06);
  --shadow-lg:0 12px 40px rgba(11,60,66,.10);
  --shadow-xl:0 24px 60px rgba(11,60,66,.16);
  --r-sm:8px; --r-md:12px; --r-lg:20px; --r-pill:999px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --t-fast:180ms; --t-base:280ms; --t-slow:480ms;
}

/* ============================================================
   BASE / TIPOGRAFIA
   ============================================================ */
body, .wp-site-blocks, .site {
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  color:var(--ink-900); background:var(--bg-card);
  font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3,h4,.site-title,
.woocommerce-products-header h1,
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.product_title {
  font-family:'Montserrat',system-ui,sans-serif;
  font-weight:700; letter-spacing:-0.02em;
  color:var(--teal-900); line-height:1.15;
}
h1,.product_title{font-size:clamp(1.85rem,3vw,2.75rem)}
h2{font-size:clamp(1.5rem,2.4vw,2.15rem)}
h3{font-size:1.2rem}
a{color:var(--teal-700);transition:color var(--t-fast) var(--ease)}
a:hover{color:var(--teal-500)}
em{color:var(--amber-500);font-style:normal;font-weight:800}

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
  background:var(--bg-card);
  border-bottom:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  padding:10px 0;
}
.site-header .inside-header{
  display:flex;align-items:center;gap:24px;
  flex-wrap:nowrap;
  max-width:1240px;margin:0 auto;
  padding:0 24px;
}
.site-branding{flex-shrink:0;margin-right:auto;display:flex;align-items:center;gap:12px}
body:not(.has-logo) .site-branding::before{
  content:'B';
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg, var(--teal-700) 0%, var(--teal-900) 100%);
  color:var(--amber-400);
  font-family:'Montserrat',sans-serif;
  font-weight:800;font-size:20px;
  flex-shrink:0;
  box-shadow:0 4px 12px rgba(11,60,66,.18);
}
.site-logo img{max-height:44px;width:auto;display:block}
.site-title{font-size:1.05rem;line-height:1.1;margin:0}
.site-title a{color:var(--teal-900);font-family:'Montserrat',sans-serif;font-weight:800;text-decoration:none}
.site-description{font-size:.7rem;color:var(--ink-500);margin:2px 0 0;letter-spacing:.04em;text-transform:uppercase}

.main-navigation{flex:1 1 auto;background:transparent;border:0}
.main-navigation .main-nav{display:flex;justify-content:flex-end}
.main-navigation .main-nav ul{display:flex;flex-wrap:nowrap;gap:2px;justify-content:flex-end}
.main-navigation .main-nav ul li a{
  font-weight:500;font-size:14px;
  color:var(--ink-700);padding:10px 14px;
  text-transform:none;letter-spacing:0;
  border-radius:var(--r-pill);
  transition:all var(--t-fast) var(--ease);
}
.main-navigation .main-nav ul li a:hover,
.main-navigation .main-nav ul li.current-menu-item>a{
  color:var(--teal-700);background:var(--teal-100);
}
@media (max-width:920px){
  .main-navigation .main-nav ul li a{padding:8px 10px;font-size:13px}
}

/* ============================================================
   HOMEPAGE: container full-width, sem entry-header
   ============================================================ */
body.home .site-main,
body.home #main,
body.home .content-area,
body.home #primary,
body.home .inside-article,
body.home .entry-content { padding:0 !important; margin:0 !important; max-width:none !important; }
body.home .entry-header { display:none !important; }
body.home .site-content { padding:0 !important; }
body.home .container.grid-container { max-width:none !important; padding:0 !important; }

/* Hero precisa ir 100vw mesmo dentro do main */
.beatek-hero{
  width:100%;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
}

/* ============================================================
   HOMEPAGE: HERO
   ============================================================ */
.beatek-hero{
  position:relative;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(212,160,23,.12), transparent 60%),
    radial-gradient(800px 500px at -10% 100%, rgba(26,138,149,.18), transparent 55%),
    linear-gradient(180deg, #0B3C42 0%, #07292E 100%);
  color:#fff;
  padding:88px 24px 96px;
  margin-bottom:0;
  overflow:hidden;
  isolation:isolate;
}
.beatek-hero::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(60% 60% at 50% 50%, #000 30%, transparent 75%);
}
.beatek-hero__inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1.25fr 1fr;gap:72px;
  align-items:center;
}
.beatek-hero__eyebrow{
  display:inline-block;padding:6px 14px;
  background:rgba(212,160,23,.18);
  color:var(--amber-400);
  border:1px solid rgba(212,160,23,.35);
  border-radius:var(--r-pill);
  font-size:12px;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;margin-bottom:20px;
}
.beatek-hero__title{
  color:#fff;font-size:clamp(2.2rem,4.5vw,3.6rem);
  margin:0 0 20px;letter-spacing:-0.025em;line-height:1.05;
}
.beatek-hero__title em{color:var(--amber-400)}
.beatek-hero__sub{
  color:rgba(230,242,243,.85);
  font-size:clamp(1rem,1.3vw,1.15rem);
  max-width:54ch;margin:0 0 32px;line-height:1.6;
}
.beatek-hero__ctas{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:40px}
.beatek-hero__props{
  display:flex;gap:32px;flex-wrap:wrap;
  list-style:none;padding:0;margin:0;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.1);
}
.beatek-hero__props li{
  font-size:14px;color:rgba(230,242,243,.7);
}
.beatek-hero__props strong{
  display:block;font-family:'Montserrat',sans-serif;
  font-size:1.6rem;color:var(--amber-400);font-weight:800;
  margin-bottom:2px;
}
.beatek-hero__art{
  position:relative;display:flex;align-items:center;justify-content:center;
  min-height:380px;
}
.beatek-hero__svg{width:100%;max-width:420px;height:auto;animation:beatek-float 6s var(--ease) infinite}
.beatek-hero__pulse{
  position:absolute;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,160,23,.35),transparent 70%);
  animation:beatek-pulse 2.4s var(--ease) infinite;
}
@keyframes beatek-pulse{
  0%,100%{transform:scale(.95);opacity:.6}
  50%{transform:scale(1.1);opacity:.9}
}
@keyframes beatek-float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-12px)}
}

/* botoes do hero */
.beatek-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:52px;padding:0 28px;
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:15px;
  border-radius:var(--r-pill);border:0;cursor:pointer;
  text-decoration:none;letter-spacing:.01em;
  transition:transform var(--t-fast) var(--ease),
             background var(--t-fast) var(--ease),
             box-shadow var(--t-fast) var(--ease);
}
.beatek-btn--primary{
  background:var(--amber-500);color:#1a1300!important;
  box-shadow:0 10px 28px rgba(212,160,23,.32);
}
.beatek-btn--primary:hover{background:var(--amber-400);transform:translateY(-2px);box-shadow:0 14px 36px rgba(212,160,23,.42)}
.beatek-btn--ghost{
  background:transparent;color:#fff!important;
  border:1.5px solid rgba(255,255,255,.25);
}
.beatek-btn--ghost:hover{border-color:var(--amber-400);color:var(--amber-400)!important;background:rgba(212,160,23,.08)}

/* ============================================================
   SECAO HEADER (titulo de bloco)
   ============================================================ */
.beatek-section-header{text-align:center;margin:0 auto 48px;max-width:760px;padding:0 24px}
.beatek-section-header h2{margin:8px 0 12px}
.beatek-section-header p{color:var(--ink-500);font-size:1.05rem;margin:0}
.beatek-eyebrow{
  display:inline-block;padding:6px 14px;
  background:var(--teal-100);color:var(--teal-700);
  border-radius:var(--r-pill);
  font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
}

/* ============================================================
   ESPACAMENTO ENTRE SECOES DA HOME
   ============================================================ */
body.home .beatek-hero + *,
body.home .beatek-props,
body.home .beatek-cats,
body.home .beatek-section,
body.home .woocommerce.columns-4,
body.home > .woocommerce { margin-top:80px; }
body.home .beatek-section + .woocommerce,
body.home .beatek-section-header + .woocommerce { margin-top:0; }
@media (max-width:768px){
  body.home .beatek-hero + *,
  body.home .beatek-props,
  body.home .beatek-cats,
  body.home .beatek-section { margin-top:48px; }
}

/* ============================================================
   VALUE PROPS
   ============================================================ */
.beatek-props{padding:0 24px;margin:0 auto 80px;max-width:1200px}
.beatek-props__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.beatek-props__item{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:28px 24px;
  text-align:left;
  transition:transform var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),border-color var(--t-base) var(--ease);
}
.beatek-props__item:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
  border-color:var(--teal-100);
}
.beatek-props__icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:48px;height:48px;border-radius:var(--r-sm);
  background:var(--teal-100);color:var(--teal-700);
  margin-bottom:14px;
}
.beatek-props__icon svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.beatek-props__item h3{margin:0 0 6px;font-size:1.05rem}
.beatek-props__item p{color:var(--ink-500);font-size:.92rem;line-height:1.5;margin:0}

/* ============================================================
   GRID DE CATEGORIAS
   ============================================================ */
.beatek-cats{padding:0 24px;margin:0 auto 96px;max-width:1200px}
.beatek-cats__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.beatek-cat-card{
  display:block;background:var(--bg-card);
  border-radius:var(--r-md);overflow:hidden;
  text-decoration:none;color:inherit;
  border:1px solid var(--line);
  transition:transform var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),border-color var(--t-base) var(--ease);
  position:relative;
}
.beatek-cat-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-lg);
  border-color:var(--teal-100);
}
.beatek-cat-card::after{
  content:'';position:absolute;top:16px;right:16px;
  width:32px;height:32px;border-radius:50%;
  background:var(--teal-700);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round'><path d='M5 12h14M13 5l7 7-7 7'/></svg>");
  background-repeat:no-repeat;background-position:center;background-size:14px;
  opacity:0;transform:translate(-6px,6px);
  transition:all var(--t-base) var(--ease);
}
.beatek-cat-card:hover::after{opacity:1;transform:translate(0,0)}
.beatek-cat-card__media{
  display:block;background:var(--bg-soft);
  aspect-ratio:5/3;overflow:hidden;
  position:relative;
}
.beatek-cat-card__media img{
  width:100%;height:100%;object-fit:contain;padding:20px;
  transition:transform var(--t-base) var(--ease);
}
.beatek-cat-card:hover .beatek-cat-card__media img{transform:scale(1.06)}
.beatek-cat-card__ph{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:var(--teal-500);
}
.beatek-cat-card__ph svg{width:48px;height:48px;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;opacity:.5}
.beatek-cat-card__body{display:block;padding:18px 20px}
.beatek-cat-card__body h3{
  font-size:1rem;margin:0 0 4px;
  color:var(--teal-900);
  font-weight:700;letter-spacing:-0.01em;
}
.beatek-cat-card__count{font-size:.85rem;color:var(--ink-500)}

/* ============================================================
   SECAO TITULO PARA SHORTCODES PADRAO DO WC
   ============================================================ */
.beatek-section{padding:0 24px;margin:0 auto 80px;max-width:1200px}

/* ============================================================
   GRID DE PRODUTOS — premium e-commerce
   ============================================================ */
.woocommerce-products-header{
  background:var(--bg-soft);
  padding:48px 24px;border-radius:var(--r-lg);
  margin-bottom:32px;
}
.woocommerce-products-header h1{margin:0 0 8px}
.term-description,.woocommerce-products-header .term-description{
  color:var(--ink-500);max-width:70ch;
}

/* Container externo — limita largura e centra */
body.home .woocommerce,
body.home .woocommerce-page,
.beatek-products-wrap,
.woocommerce.columns-1,
.woocommerce.columns-2,
.woocommerce.columns-3,
.woocommerce.columns-4,
.woocommerce.columns-5,
.woocommerce.columns-6{
  max-width:1320px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  padding-left:32px !important;
  padding-right:32px !important;
  box-sizing:border-box;
}

/* GRID — força 4 colunas independente de columns="6" do shortcode */
body .woocommerce ul.products,
body .woocommerce-page ul.products,
body .wc-block-grid__products,
body .woocommerce.columns-2 ul.products,
body .woocommerce.columns-3 ul.products,
body .woocommerce.columns-4 ul.products,
body .woocommerce.columns-5 ul.products,
body .woocommerce.columns-6 ul.products{
  display:grid !important;
  grid-template-columns:repeat(4, minmax(0, 1fr)) !important;
  gap:32px !important;
  margin:0 0 64px !important;
  padding:0 !important;
  list-style:none !important;
}

/* Tablet: 3 colunas */
@media (max-width:1100px){
  body .woocommerce ul.products,
  body .wc-block-grid__products,
  body [class*="columns-"] ul.products{
    grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
    gap:24px !important;
  }
}
/* Mobile: 2 colunas */
@media (max-width:680px){
  body .woocommerce ul.products,
  body .wc-block-grid__products,
  body [class*="columns-"] ul.products{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
    gap:14px !important;
  }
}

/* CARD */
body .woocommerce ul.products li.product,
body .wc-block-grid__product{
  width:auto !important;margin:0 !important;float:none !important;
  background:var(--bg-card) !important;
  border:1px solid var(--line) !important;
  border-radius:18px !important;
  box-shadow:0 1px 2px rgba(11,60,66,.04) !important;
  overflow:hidden !important;
  position:relative !important;
  display:flex !important;
  flex-direction:column !important;
  text-align:left !important;
  transition:transform var(--t-base) var(--ease),
             box-shadow var(--t-base) var(--ease),
             border-color var(--t-base) var(--ease) !important;
}
body .woocommerce ul.products li.product:hover,
body .wc-block-grid__product:hover{
  transform:translateY(-8px) !important;
  box-shadow:0 28px 56px -20px rgba(11,60,66,.22), 0 6px 16px rgba(11,60,66,.08) !important;
  border-color:var(--teal-100) !important;
}

/* MEDIA / IMAGEM */
body .woocommerce ul.products li.product > a:first-of-type,
body .woocommerce ul.products li.product .woocommerce-LoopProduct-link{
  display:block !important;
  position:relative;
  background:linear-gradient(180deg, #FAFCFC 0%, #EFF3F4 100%) !important;
  text-decoration:none;
  overflow:hidden;
}
body .woocommerce ul.products li.product a img,
body .wc-block-grid__product-image img{
  display:block !important;
  width:100% !important;
  aspect-ratio:1/1 !important;
  object-fit:contain !important;
  padding:32px !important;
  margin:0 !important;
  background:transparent !important;
  border:0 !important;
  border-bottom:1px solid var(--line) !important;
  transition:transform 600ms var(--ease) !important;
  box-sizing:border-box !important;
  border-radius:0 !important;
}
body .woocommerce ul.products li.product:hover a img{transform:scale(1.07) !important}

/* CORPO DO CARD */
body .woocommerce ul.products li.product .woocommerce-loop-product__title,
body .wc-block-grid__product-title{
  font-family:'Inter', sans-serif !important;
  font-size:1rem !important;
  font-weight:600 !important;
  letter-spacing:-0.01em !important;
  line-height:1.4 !important;
  color:var(--ink-900) !important;
  padding:22px 22px 6px !important;
  margin:0 !important;
  min-height:0 !important;
  display:-webkit-box !important;
  -webkit-line-clamp:2 !important;
  -webkit-box-orient:vertical !important;
  overflow:hidden !important;
  height:2.8em !important;
}

body .beatek-stock-line{
  display:inline-flex !important;
  align-items:center;gap:5px;
  margin:8px 22px 0 !important;
  padding:4px 10px !important;
  background:rgba(31,138,76,.08) !important;
  color:var(--success) !important;
  font-size:.74rem !important;font-weight:600 !important;
  border-radius:var(--r-pill) !important;
  letter-spacing:.02em;
  align-self:flex-start;
  width:fit-content;
}

/* PRECO — gigante e destacado */
body .woocommerce ul.products li.product .price,
body .wc-block-grid__product-price{
  display:block !important;
  padding:12px 22px 4px !important;
  margin:0 !important;
  color:var(--teal-900) !important;
  font-family:'Montserrat', sans-serif !important;
  font-size:1.55rem !important;
  font-weight:800 !important;
  letter-spacing:-0.025em !important;
  line-height:1.1 !important;
}
body .woocommerce ul.products li.product .price del{
  display:block !important;
  color:var(--ink-300) !important;
  font-weight:500 !important;
  font-size:.78rem !important;
  margin-bottom:2px !important;
  letter-spacing:0 !important;
}
body .woocommerce ul.products li.product .price ins{
  background:transparent !important;text-decoration:none !important;
}

/* CTA — sempre visivel, ancora no fundo */
body .woocommerce ul.products li.product .button,
body .wc-block-grid__product .wp-block-button__link{
  display:flex !important;
  align-items:center;justify-content:center;
  gap:10px;
  margin:18px 22px 22px !important;
  margin-top:auto !important;
  width:auto !important;
  height:48px !important;
  padding:0 22px !important;
  font-family:'Montserrat', sans-serif !important;
  font-weight:700 !important;
  font-size:13px !important;
  letter-spacing:.04em !important;
  text-transform:uppercase !important;
  border-radius:14px !important;
  border:0 !important;
  background:var(--teal-900) !important;
  color:#fff !important;
  cursor:pointer;text-decoration:none;
  opacity:1 !important;
  transform:none !important;
  box-shadow:0 4px 12px rgba(11,60,66,.15) !important;
  transition:background 200ms var(--ease),
             color 200ms var(--ease),
             box-shadow 200ms var(--ease),
             transform 200ms var(--ease) !important;
}
body .woocommerce ul.products li.product .button::before{
  content:'';
  width:16px;height:16px;flex-shrink:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 6h15l-2 11H8z'/><circle cx='9' cy='21' r='1.5'/><circle cx='18' cy='21' r='1.5'/><path d='M3 3h3'/></svg>");
  background-size:contain;background-repeat:no-repeat;
}
body .woocommerce ul.products li.product .button:hover{
  background:var(--amber-500) !important;
  color:#1a1300 !important;
  transform:translateY(-2px) !important;
  box-shadow:0 12px 24px rgba(212,160,23,.32) !important;
}
body .woocommerce ul.products li.product .button:hover::before{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231a1300' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 6h15l-2 11H8z'/><circle cx='9' cy='21' r='1.5'/><circle cx='18' cy='21' r='1.5'/><path d='M3 3h3'/></svg>");
}
body .woocommerce ul.products li.product .added_to_cart{display:none !important}

/* BADGES */
body .woocommerce span.onsale,
body .beatek-badge{
  position:absolute !important;
  top:16px !important;left:16px !important;
  min-height:0 !important;min-width:0 !important;
  padding:7px 13px !important;
  background:var(--amber-500) !important;
  color:#1a1300 !important;
  font-size:10px !important;
  font-weight:800 !important;
  letter-spacing:.1em !important;
  text-transform:uppercase !important;
  border-radius:var(--r-pill) !important;
  margin:0 !important;
  line-height:1 !important;
  box-shadow:0 8px 18px rgba(180,130,11,.32) !important;
  z-index:3 !important;
}
body .beatek-badge--new{
  background:var(--teal-900) !important;
  color:#fff !important;
  top:16px !important;
  right:16px !important;
  left:auto !important;
  box-shadow:0 8px 18px rgba(11,60,66,.32) !important;
}

/* MOBILE */
@media (max-width:680px){
  body .woocommerce ul.products li.product .woocommerce-loop-product__title{
    font-size:.85rem !important;
    padding:14px 14px 4px !important;
    height:2.6em !important;
  }
  body .woocommerce ul.products li.product .price{
    font-size:1.1rem !important;
    padding:8px 14px 2px !important;
  }
  body .woocommerce ul.products li.product a img{padding:18px !important}
  body .beatek-stock-line{margin:4px 14px !important;font-size:.68rem !important}
  body .woocommerce ul.products li.product .button{
    margin:12px 14px 14px !important;
    height:42px !important;
    font-size:11px !important;
    padding:0 14px !important;
  }
  body .woocommerce span.onsale,body .beatek-badge{
    top:10px !important;left:10px !important;
    padding:5px 10px !important;font-size:9px !important;
  }
  body .beatek-badge--new{top:10px !important;right:10px !important}
}

/* ============================================================
   BOTOES GLOBAIS (single product, blocos)
   ============================================================ */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce .button.alt,
.wp-block-button__link{
  display:inline-flex;align-items:center;justify-content:center;
  gap:8px;
  height:46px;padding:0 22px;
  font-family:'Montserrat',sans-serif;
  font-weight:600;font-size:14px;
  letter-spacing:.02em;text-transform:none;
  border-radius:var(--r-pill);border:0;
  background:var(--teal-700);color:#fff !important;
  cursor:pointer;text-decoration:none;
  transition:all var(--t-fast) var(--ease);
  box-shadow:0 6px 18px rgba(17,94,103,.18);
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.wp-block-button__link:hover{
  background:var(--teal-900);
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(17,94,103,.25);
}
.single_add_to_cart_button.button.alt{
  height:56px;padding:0 36px;font-size:15px;
  background:var(--amber-500);color:#1a1300 !important;
  box-shadow:0 12px 28px rgba(212,160,23,.32);
}
.single_add_to_cart_button.button.alt:hover{
  background:var(--amber-600);
  color:#fff !important;
}

/* ============================================================
   PAGINA DE PRODUTO
   ============================================================ */
.single-product div.product{display:grid;grid-template-columns:1.1fr 1fr;gap:48px}
.single-product div.product .woocommerce-product-gallery{
  background:#fff;border-radius:var(--r-md);
  padding:24px;box-shadow:var(--shadow-sm);
}
.single-product div.product .summary p.price{
  font-family:'Montserrat',sans-serif;
  font-size:2rem;font-weight:800;
  color:var(--teal-900);margin:8px 0 16px;
}
.single-product .stock.in-stock{color:var(--success);font-weight:600}
.woocommerce-tabs{margin-top:48px}
.woocommerce-tabs .tabs li{border:0!important;background:transparent!important}
.woocommerce-tabs .tabs li a{
  padding:12px 18px!important;font-weight:600;
  color:var(--ink-500);
  border-bottom:2px solid transparent!important;
  transition:all var(--t-fast) var(--ease);
}
.woocommerce-tabs .tabs li.active a{
  color:var(--teal-700)!important;
  border-bottom-color:var(--amber-500)!important;
}

/* ============================================================
   CHECKOUT
   ============================================================ */
.woocommerce-checkout #payment{
  background:var(--bg-soft);
  border-radius:var(--r-md);padding:24px;
}
.woocommerce form .form-row input,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea{
  height:48px;border-radius:var(--r-sm);
  border:1px solid var(--line);
  padding:0 14px;background:#fff;font-size:15px;
  transition:border-color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease);
}
.woocommerce form .form-row textarea{height:96px;padding-top:12px}
.woocommerce form .form-row input:focus{
  border-color:var(--teal-500);
  box-shadow:0 0 0 4px rgba(26,138,149,.12);outline:none;
}
.woocommerce-checkout-review-order-table{
  background:#fff;border-radius:var(--r-md);
  padding:16px;box-shadow:var(--shadow-sm);
}

/* ============================================================
   FOOTER (estiliza qualquer footer do GeneratePress)
   ============================================================ */
.site-footer.footer-bar-active,.site-info,.footer-widgets{
  background:var(--teal-900)!important;color:rgba(230,242,243,.7);
}
.site-footer a{color:rgba(230,242,243,.85)}
.site-footer a:hover{color:var(--amber-400)}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width:1024px){
  .beatek-hero__inner{grid-template-columns:1fr;gap:40px;text-align:center}
  .beatek-hero__copy{max-width:680px;margin:0 auto}
  .beatek-hero__sub{margin-left:auto;margin-right:auto}
  .beatek-hero__ctas{justify-content:center}
  .beatek-hero__props{justify-content:center}
  .beatek-hero__art{min-height:280px;order:-1}
  .beatek-hero__svg{max-width:280px}
  .beatek-cats__grid,.beatek-props__grid{grid-template-columns:repeat(2,1fr)}
  .single-product div.product{grid-template-columns:1fr;gap:24px}
}
@media (max-width:640px){
  .beatek-hero{padding:64px 20px 72px;margin-bottom:48px}
  .beatek-hero__props{gap:20px}
  .beatek-hero__props li{flex-basis:calc(50% - 10px)}
  .woocommerce ul.products{grid-template-columns:repeat(2,1fr);gap:14px}
  .woocommerce ul.products li.product .woocommerce-loop-product__title{font-size:.85rem;padding:12px 12px 4px}
  .woocommerce ul.products li.product .price{font-size:1rem;padding:4px 12px 12px}
  .beatek-cats__grid,.beatek-props__grid{grid-template-columns:1fr}
  body{padding-bottom:72px}
}

/* ============================================================
   TAB BAR MOBILE
   ============================================================ */
.beatek-tabbar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-top:1px solid var(--line);
  padding:8px 8px calc(8px + env(safe-area-inset-bottom));
}
.beatek-tabbar ul{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin:0;padding:0;list-style:none}
.beatek-tabbar a{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:4px;padding:8px 4px;
  color:var(--ink-500);font-size:11px;font-weight:500;
  border-radius:var(--r-sm);text-decoration:none;
  transition:all var(--t-fast) var(--ease);
}
.beatek-tabbar a.is-active,.beatek-tabbar a:hover{color:var(--teal-700);background:var(--teal-100)}
.beatek-tabbar svg{width:22px;height:22px;stroke-width:1.6;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}
@media (max-width:768px){.beatek-tabbar{display:block}}

/* ============================================================
   ACESSIBILIDADE
   ============================================================ */
:focus-visible{outline:2px solid var(--amber-500);outline-offset:2px;border-radius:var(--r-sm)}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .beatek-hero__svg,.beatek-hero__pulse{animation:none!important}
}
