/*
Theme Name: Dekal
Theme URI: https://dekal.com.br
Author: Dekal Adesivos Decorativos
Author URI: https://dekal.com.br
Description: Tema profissional para loja de adesivos decorativos Dekal. Compatível com Elementor.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dekal
Tags: elementor, woocommerce, dark, e-commerce, full-width-template
*/

/* =====================================================
   VARIÁVEIS GLOBAIS — IDENTIDADE DEKAL
   ===================================================== */
:root {
  --dekal-dark:    #242430;
  --dekal-dark2:   #1a1a24;
  --dekal-dark3:   #2e2e3d;
  --dekal-green:   #43E67B;
  --dekal-teal:    #38f6d4;
  --dekal-text:    #f0f0f0;
  --dekal-muted:   #999aaa;
  --dekal-radius:  12px;
  --dekal-gradient: linear-gradient(135deg, #43E67B, #38f6d4);
}

/* =====================================================
   RESET & BASE
   ===================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: 'Space Grotesk', sans-serif;
  background: var(--dekal-dark);
  color: var(--dekal-text);
  overflow-x: hidden;
  line-height: 1.6;
}

/* =====================================================
   TIPOGRAFIA
   ===================================================== */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  line-height: 1.1;
  color: var(--dekal-text);
}

a { color: var(--dekal-teal); text-decoration: none; transition: color .2s; }
a:hover { color: var(--dekal-green); }

p { color: var(--dekal-muted); line-height: 1.7; }

/* =====================================================
   LOGO
   ===================================================== */
.site-title a,
.dekal-logo {
  font-family: 'Syne', sans-serif;
  font-size: 1.6rem;
  font-weight: 800;
  background: var(--dekal-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* =====================================================
   HEADER / NAV
   ===================================================== */
.site-header,
#site-navigation {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 9999;
  background: rgba(36, 36, 48, 0.92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(56, 246, 212, 0.12);
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 2rem;
}

.nav-menu { display: flex; gap: 2rem; list-style: none; }
.nav-menu a { color: var(--dekal-muted); font-size: .9rem; font-weight: 500; transition: color .2s; }
.nav-menu a:hover { color: var(--dekal-teal); }

/* OFFSET para o header fixo */
.elementor-section, .wp-block-group { scroll-margin-top: 64px; }

/* =====================================================
   BOTÕES GLOBAIS
   ===================================================== */
.btn-dekal-primary,
.elementor-button.btn-primary,
button.btn-primary {
  background: var(--dekal-gradient) !important;
  color: var(--dekal-dark) !important;
  border: none !important;
  border-radius: 50px !important;
  font-weight: 700 !important;
  font-family: 'Space Grotesk', sans-serif !important;
  padding: .9rem 2rem !important;
  cursor: pointer !important;
  transition: opacity .2s, transform .2s !important;
}
.btn-dekal-primary:hover { opacity: .88 !important; transform: translateY(-2px) !important; }

.btn-dekal-outline,
.elementor-button.btn-outline {
  background: transparent !important;
  color: var(--dekal-text) !important;
  border: 1.5px solid rgba(255,255,255,0.2) !important;
  border-radius: 50px !important;
  font-weight: 600 !important;
  padding: .9rem 2rem !important;
  transition: border-color .2s !important;
}
.btn-dekal-outline:hover { border-color: var(--dekal-teal) !important; color: var(--dekal-teal) !important; }

/* =====================================================
   SEÇÕES
   ===================================================== */
.section-label {
  display: inline-block;
  color: var(--dekal-teal);
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: .75rem;
}

.section-bg-dark { background: var(--dekal-dark2) !important; }
.section-bg-card { background: var(--dekal-dark3) !important; }

/* =====================================================
   HERO
   ===================================================== */
.hero-section {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 6rem 2rem 4rem;
  position: relative;
  overflow: hidden;
  background: var(--dekal-dark);
}

.hero-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(67,230,123,.08) 0%, transparent 70%),
    radial-gradient(ellipse 60% 40% at 80% 80%, rgba(56,246,212,.06) 0%, transparent 60%);
  pointer-events: none;
}

.hero-badge {
  display: inline-block;
  background: rgba(67,230,123,.12);
  border: 1px solid rgba(67,230,123,.3);
  color: var(--dekal-green);
  padding: .35rem 1rem;
  border-radius: 50px;
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 1.5rem;
}

.hero-title {
  font-family: 'Syne', sans-serif;
  font-size: clamp(2.8rem, 7vw, 5rem);
  font-weight: 800;
  line-height: 1.05;
  margin-bottom: 1.2rem;
  color: var(--dekal-text);
}

.hero-title .highlight {
  background: var(--dekal-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-subtitle {
  font-size: 1.1rem;
  color: var(--dekal-muted);
  margin-bottom: 2.5rem;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.hero-stats {
  display: flex;
  gap: 3rem;
  justify-content: center;
  margin-top: 4rem;
  padding-top: 2.5rem;
  border-top: 1px solid rgba(255,255,255,.06);
  flex-wrap: wrap;
}

.hero-stat-number {
  display: block;
  font-family: 'Syne', sans-serif;
  font-size: 1.8rem;
  font-weight: 800;
  background: var(--dekal-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-stat-label { font-size: .8rem; color: var(--dekal-muted); }

/* =====================================================
   CARDS DE CATEGORIA
   ===================================================== */
.cat-card {
  background: var(--dekal-dark3);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--dekal-radius);
  padding: 2rem 1.5rem;
  text-align: center;
  cursor: pointer;
  transition: border-color .25s, transform .25s;
}
.cat-card:hover { border-color: var(--dekal-teal); transform: translateY(-4px); }
.cat-card .cat-icon { font-size: 2.2rem; margin-bottom: .8rem; }
.cat-card h3 { font-size: .95rem; font-weight: 600; color: var(--dekal-text); margin-bottom: .3rem; }
.cat-card p  { font-size: .78rem; color: var(--dekal-muted); }

/* =====================================================
   CARDS DE PRODUTO (WooCommerce + Elementor)
   ===================================================== */
.product-card,
.woocommerce ul.products li.product,
.elementor-wc-products .product {
  background: var(--dekal-dark3) !important;
  border: 1px solid rgba(255,255,255,.06) !important;
  border-radius: var(--dekal-radius) !important;
  overflow: hidden !important;
  transition: border-color .25s, transform .25s !important;
  padding: 0 !important;
}
.product-card:hover,
.woocommerce ul.products li.product:hover {
  border-color: var(--dekal-green) !important;
  transform: translateY(-4px) !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  color: var(--dekal-text) !important;
  font-size: .95rem !important;
  font-weight: 600 !important;
}

.woocommerce ul.products li.product .price,
.woocommerce .price {
  color: var(--dekal-green) !important;
  font-family: 'Syne', sans-serif !important;
  font-size: 1.3rem !important;
  font-weight: 800 !important;
}

.woocommerce ul.products li.product .button,
.woocommerce .button,
.woocommerce #respond input#submit {
  background: var(--dekal-gradient) !important;
  color: var(--dekal-dark) !important;
  border: none !important;
  border-radius: 50px !important;
  font-weight: 700 !important;
  padding: .45rem 1rem !important;
  transition: opacity .2s !important;
}
.woocommerce ul.products li.product .button:hover { opacity: .8 !important; }

/* Badge de produto */
.product-badge,
.woocommerce span.onsale {
  background: var(--dekal-green) !important;
  color: var(--dekal-dark) !important;
  border-radius: 50px !important;
  font-size: .7rem !important;
  font-weight: 700 !important;
  padding: .25rem .65rem !important;
}

/* =====================================================
   CARDS DE DIFERENCIAIS
   ===================================================== */
.why-card {
  padding: 1.75rem;
  border: 1px solid rgba(56,246,212,.12);
  border-radius: var(--dekal-radius);
  background: var(--dekal-dark3);
}
.why-icon {
  width: 44px; height: 44px;
  border-radius: 10px;
  background: rgba(67,230,123,.12);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem;
  margin-bottom: 1rem;
}
.why-card h3 { font-size: 1rem; font-weight: 600; margin-bottom: .5rem; color: var(--dekal-text); }
.why-card p  { font-size: .85rem; color: var(--dekal-muted); line-height: 1.6; }

/* =====================================================
   DEPOIMENTOS
   ===================================================== */
.review-card {
  background: var(--dekal-dark3);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--dekal-radius);
  padding: 1.5rem;
}
.review-stars { color: var(--dekal-green); font-size: 1rem; margin-bottom: .75rem; }
.review-card blockquote,
.review-card p {
  font-size: .9rem; color: var(--dekal-muted); line-height: 1.6;
  margin-bottom: 1rem; font-style: italic;
}
.reviewer { display: flex; align-items: center; gap: .75rem; }
.reviewer-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--dekal-gradient);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: .85rem; color: var(--dekal-dark);
  flex-shrink: 0;
}
.reviewer-name { font-size: .85rem; font-weight: 600; color: var(--dekal-text); }
.reviewer-city { font-size: .75rem; color: var(--dekal-muted); }

/* =====================================================
   FORMULÁRIO DE CONTATO
   ===================================================== */
.contact-form-wrap,
.wpcf7-form,
.elementor-form {
  background: var(--dekal-dark3) !important;
  border: 1px solid rgba(255,255,255,.06) !important;
  border-radius: var(--dekal-radius) !important;
  padding: 2rem !important;
}

.wpcf7-form input,
.wpcf7-form textarea,
.wpcf7-form select,
.elementor-field-type-text input,
.elementor-field-type-email input,
.elementor-field-type-textarea textarea,
.elementor-field-type-select select {
  width: 100% !important;
  background: var(--dekal-dark2) !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  border-radius: 8px !important;
  padding: .75rem 1rem !important;
  color: var(--dekal-text) !important;
  font-family: 'Space Grotesk', sans-serif !important;
  font-size: .9rem !important;
  transition: border-color .2s !important;
}

.wpcf7-form input:focus,
.wpcf7-form textarea:focus {
  outline: none !important;
  border-color: var(--dekal-teal) !important;
}

.wpcf7-form input[type="submit"],
.elementor-button-wrapper .elementor-button {
  background: var(--dekal-gradient) !important;
  color: var(--dekal-dark) !important;
  border: none !important;
  border-radius: 50px !important;
  font-weight: 700 !important;
  width: 100% !important;
  padding: .85rem !important;
  cursor: pointer !important;
  transition: opacity .2s !important;
}

/* Labels */
.wpcf7-form label,
.elementor-field-label {
  color: var(--dekal-muted) !important;
  font-size: .85rem !important;
  font-weight: 600 !important;
  margin-bottom: .5rem !important;
  display: block !important;
}

/* =====================================================
   BOTÃO WHATSAPP FLUTUANTE
   ===================================================== */
.whatsapp-float {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 9998;
  background: #25D366;
  color: #fff;
  width: 58px; height: 58px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(37,211,102,.4);
  transition: transform .2s;
  text-decoration: none;
}
.whatsapp-float:hover { transform: scale(1.1); color: #fff; }
.whatsapp-float svg { width: 28px; height: 28px; }

/* =====================================================
   WOOCOMMERCE — PÁGINA DE PRODUTO
   ===================================================== */
.woocommerce div.product .product_title {
  font-family: 'Syne', sans-serif !important;
  font-size: 2rem !important;
  font-weight: 800 !important;
  color: var(--dekal-text) !important;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--dekal-green) !important;
  font-family: 'Syne', sans-serif !important;
  font-size: 1.8rem !important;
  font-weight: 800 !important;
}

.woocommerce div.product .woocommerce-product-details__short-description p {
  color: var(--dekal-muted) !important;
}

.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce div.product form.cart .button {
  background: var(--dekal-gradient) !important;
  color: var(--dekal-dark) !important;
  border-radius: 50px !important;
  border: none !important;
  font-weight: 700 !important;
  padding: .9rem 2rem !important;
  transition: opacity .2s !important;
}

/* Tabs do produto */
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: var(--dekal-dark3) !important;
  border-color: rgba(255,255,255,.06) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
  background: var(--dekal-dark2) !important;
  border-bottom-color: var(--dekal-green) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  color: var(--dekal-muted) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--dekal-green) !important;
}
.woocommerce div.product .woocommerce-tabs .panel {
  background: var(--dekal-dark2) !important;
  border-color: rgba(255,255,255,.06) !important;
}

/* =====================================================
   WOOCOMMERCE — CARRINHO & CHECKOUT
   ===================================================== */
.woocommerce-cart-form table,
.woocommerce table.shop_table {
  background: var(--dekal-dark3) !important;
  border-radius: var(--dekal-radius) !important;
  border: 1px solid rgba(255,255,255,.06) !important;
}

.woocommerce table.shop_table th {
  background: var(--dekal-dark2) !important;
  color: var(--dekal-teal) !important;
  font-size: .8rem !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

.woocommerce table.shop_table td {
  border-color: rgba(255,255,255,.06) !important;
  color: var(--dekal-text) !important;
}

.woocommerce .cart-collaterals .cart_totals,
.woocommerce-checkout #order_review {
  background: var(--dekal-dark3) !important;
  border-radius: var(--dekal-radius) !important;
  padding: 1.5rem !important;
  border: 1px solid rgba(255,255,255,.06) !important;
}

/* Campos de checkout */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
  background: var(--dekal-dark2) !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  border-radius: 8px !important;
  color: var(--dekal-text) !important;
  font-family: 'Space Grotesk', sans-serif !important;
}

.woocommerce form .form-row label { color: var(--dekal-muted) !important; }

/* =====================================================
   FOOTER
   ===================================================== */
.site-footer {
  background: var(--dekal-dark2) !important;
  border-top: 1px solid rgba(255,255,255,.06) !important;
  padding: 3rem 2rem 2rem !important;
  color: var(--dekal-muted) !important;
}

.site-footer .footer-logo { font-size: 1.5rem; margin-bottom: .75rem; }
.site-footer p { color: var(--dekal-muted); font-size: .85rem; line-height: 1.6; }
.site-footer a { color: var(--dekal-muted); transition: color .2s; font-size: .85rem; }
.site-footer a:hover { color: var(--dekal-text); }

.footer-widgets h4 {
  color: var(--dekal-teal) !important;
  font-size: .85rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  margin-bottom: 1rem !important;
}

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 1.5rem;
  margin-top: 2rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .5rem;
  font-size: .8rem;
  color: var(--dekal-muted);
}

.footer-bottom .dekal-brand {
  background: var(--dekal-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 700;
}

/* =====================================================
   TOAST / NOTIFICAÇÕES WOOCOMMERCE
   ===================================================== */
.woocommerce-message,
.woocommerce-info {
  background: var(--dekal-dark3) !important;
  border-top-color: var(--dekal-green) !important;
  color: var(--dekal-text) !important;
}

/* =====================================================
   ELEMENTOR — AJUSTES GERAIS
   ===================================================== */
.elementor-section { background-color: var(--dekal-dark); }

/* Textos dentro do Elementor */
.elementor-widget-text-editor p,
.elementor-widget-text-editor { color: var(--dekal-muted); }
.elementor-heading-title { color: var(--dekal-text) !important; }

/* Ícones Elementor */
.elementor-icon { color: var(--dekal-teal) !important; }

/* Separadores */
.elementor-divider-separator { border-color: rgba(255,255,255,.06) !important; }

/* =====================================================
   RESPONSIVO
   ===================================================== */
@media (max-width: 768px) {
  .hero-stats { gap: 1.5rem; }
  .site-header { padding: 0 1rem; }
  .whatsapp-float { bottom: 1.25rem; right: 1.25rem; }
}
