/* EcomSolutions - Theme CSS */

/* ===== Paleta / Tokens ===== */
:root{
  /* Paleta principal */
  --ecom-dark:     #2F4F4F; /* Verde Pinho Escuro */
  --ecom-dark-900: #254742; /* Variação mais escura */
  --ecom-sage:     #A8B9A3; /* Verde Sálvia Claro */
  --ecom-sage-200: #F5F7F5; /* Cinza Neve / fundo claro */
  --ecom-orange:   #FF8552; /* Coral (accent) */
  --ecom-text:     #3C3C3C; /* Cinza Carvão (texto) */
  --ecom-muted:    #6B7570; /* Cinza suave */
  --ecom-white:    #FFFFFF;

  --radius-xl:     1.25rem;
  --shadow-soft:   0 10px 30px rgba(0,0,0,.08);

  /* Para títulos onde usamos var(--ecom-ink) */
  --ecom-ink: var(--ecom-dark);
}

/* ===== Tipografia base ===== */
html,body{
  height:100%;
  color:var(--ecom-text);
  font-family:'Poppins','Open Sans',system-ui,-apple-system,Segoe UI,Roboto,
              'Helvetica Neue',Arial,'Noto Sans','Liberation Sans',sans-serif;
}
body{background:#fff}

/* ===== Utilities ===== */
.bg-sage{background:var(--ecom-sage-200)!important}
.bg-snow{background:var(--ecom-sage-200)!important}
.text-sage{color:var(--ecom-sage)!important}
.text-ink{color:var(--ecom-dark)!important}
.text-muted-soft{color:var(--ecom-muted)!important}
.rounded-xl{border-radius:var(--radius-xl)!important}
.shadow-soft{box-shadow:var(--shadow-soft)}
.border-soft{border:1px solid #e8eceb}

/* ===== Botões ===== */

/* Primário laranja (accent) — visível ao hover */
.btn-accent{
  --btn-accent:        #FF8552; /* base */
  --btn-accent-hover:  #FF7A45; /* mais escuro/contraste */
  --btn-accent-active: #E96A3A; /* ainda mais escuro */

  color:#fff !important;
  background-color: var(--btn-accent) !important;
  border-color: var(--btn-accent) !important;

  transition: background-color .2s ease, border-color .2s ease,
              box-shadow .2s ease, transform .05s ease-in-out;
}
.btn-accent:hover,
.btn-accent:focus{
  color:#fff !important;
  background-color: var(--btn-accent-hover) !important;
  border-color: var(--btn-accent-hover) !important;
  box-shadow: 0 8px 18px rgba(233,106,58,.28) !important;
  transform: translateY(-1px);
}
.btn-accent:active{
  background-color: var(--btn-accent-active) !important;
  border-color: var(--btn-accent-active) !important;
  box-shadow: 0 4px 10px rgba(233,106,58,.32) !important;
  transform: translateY(0);
}

/* Primário verde cheio */
.btn-ecom{
  --btn-dark:        #2F4F4F; /* base */
  --btn-dark-hover:  #1E3A3A; /* bem mais escuro p/ contrastar */
  --btn-dark-active: #122A2A; /* ainda mais escuro */

  color:#fff !important;
  background-color: var(--btn-dark) !important;
  border-color: var(--btn-dark) !important;

  --bs-btn-color:#fff;
  --bs-btn-bg: var(--btn-dark);
  --bs-btn-border-color: var(--btn-dark);
  --bs-btn-hover-color:#fff;
  --bs-btn-hover-bg: var(--btn-dark-hover);
  --bs-btn-hover-border-color: var(--btn-dark-hover);
  --bs-btn-active-color:#fff;
  --bs-btn-active-bg: var(--btn-dark-active);
  --bs-btn-active-border-color: var(--btn-dark-active);
  --bs-btn-focus-shadow-rgb: 47,79,79;

  transition: background-color .2s ease, border-color .2s ease,
              box-shadow .2s ease, transform .05s ease-in-out;
}
.btn-ecom:hover,
.btn-ecom:focus{
  color:#fff !important;
  background-color: var(--btn-dark-hover) !important;
  border-color: var(--btn-dark-hover) !important;
  box-shadow: 0 6px 14px rgba(30,58,58,.22) !important;
  transform: translateY(-1px);
}
.btn-ecom:active{
  background-color: var(--btn-dark-active) !important;
  border-color: var(--btn-dark-active) !important;
  box-shadow: 0 3px 8px rgba(18,42,42,.28) !important;
  transform: translateY(0);
}
.btn-ecom:focus-visible{
  outline:3px solid rgba(47,79,79,.35);
  outline-offset:2px;
  box-shadow:none;
}
.btn-ecom:disabled,
.btn-ecom.disabled{
  opacity:.65;
  background-color: var(--btn-dark) !important;
  border-color: var(--btn-dark) !important;
  color:#fff !important;
  transform:none;
  box-shadow:none !important;
}

/* Versão contornada verde explícita (se usar) */
.btn-outline-ecom{
  --btn-ol:        #2F4F4F;
  --btn-ol-hover:  #1E3A3A;
  --btn-ol-active: #122A2A;

  color: var(--btn-ol) !important;
  background-color: transparent !important;
  border-color: var(--btn-ol) !important;

  transition: background-color .2s ease, border-color .2s ease,
              color .2s ease, box-shadow .2s ease, transform .05s ease-in-out;
}
.btn-outline-ecom:hover,
.btn-outline-ecom:focus{
  color:#fff !important;
  background-color: var(--btn-ol) !important;
  border-color: var(--btn-ol) !important;
  box-shadow: 0 6px 14px rgba(30,58,58,.22) !important;
  transform: translateY(-1px);
}
.btn-outline-ecom:active{
  color:#fff !important;
  background-color: var(--btn-ol-active) !important;
  border-color: var(--btn-ol-active) !important;
  box-shadow: 0 3px 8px rgba(18,42,42,.28) !important;
  transform: translateY(0);
}
.btn-outline-ecom:focus-visible{
  outline:3px solid rgba(47,79,79,.28);
  outline-offset:2px;
  box-shadow:none;
}

/* Também tematiza o .btn-outline-secondary do Bootstrap como “verde contornado”,
   pois ele é usado no site (ex.: botões de atalho na hero). */
.btn-outline-secondary{
  color: var(--ecom-dark) !important;
  border-color: var(--ecom-dark) !important;
  background: transparent !important;
  transition: background-color .2s ease, border-color .2s ease,
              color .2s ease, box-shadow .2s ease, transform .05s ease-in-out;
}
.btn-outline-secondary:hover,
.btn-outline-secondary:focus{
  color:#fff !important;
  background-color: var(--ecom-dark) !important;
  border-color: var(--ecom-dark) !important;
  box-shadow: 0 6px 14px rgba(30,58,58,.22) !important;
  transform: translateY(-1px);
}
.btn-outline-secondary:active{
  color:#fff !important;
  background-color: #1E3A3A !important;
  border-color: #1E3A3A !important;
  box-shadow: 0 3px 8px rgba(18,42,42,.28) !important;
  transform: translateY(0);
}

/* ===== Header / Navbar ===== */
.navbar-ecom{background:#fff;border-bottom:1px solid #eef2f1}
.navbar-brand img{height:94px}
.nav-link{color:var(--ecom-dark)}
.nav-link.active{font-weight:700}

/* Sublinhado animado para links do menu (hover/active) */
.navbar-ecom .nav-link{
  position:relative;
  padding-bottom:.35rem;
  transition:color .2s ease;
}
.navbar-ecom .nav-link::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-6px;
  margin:0 auto;
  width:56px; height:3px;
  background:var(--ecom-dark);
  border-radius:999px;
  transform:scaleX(0);
  transform-origin:center;
  transition:transform .22s ease;
}
.navbar-ecom .nav-link:hover::after,
.navbar-ecom .nav-link:focus::after{ transform:scaleX(1); }
.navbar-ecom .nav-link.active::after{ transform:scaleX(1); }

/* ===== Hero ===== */
.hero{background:var(--ecom-sage-200)}
.hero h1{
  font-weight:800;
  letter-spacing:-.5px;
  color:var(--ecom-text) !important; /* H1 padrão preto; use .text-ink em spans para partes verdes */
}
.hero .lead{color:var(--ecom-muted)}

/* ===== Feature cards ===== */
.card-feature{border-radius:var(--radius-xl);border:1px solid #e9edeb}
.card-feature .icon{
  width:64px;height:64px;border-radius:999px;display:grid;place-items:center;
  background:#e6ecea;color:var(--ecom-dark)
}

/* ===== Steps (“Como Funciona”) ===== */
.section-steps{background:var(--ecom-dark);color:#ecf2f1}
.section-steps h2{color:#fff!important}
.step-dot{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.09);display:grid;place-items:center;font-weight:700}
.step-sep{height:3px;width:60px;border-radius:999px;background:rgba(255,255,255,.25)}

/* ===== Títulos das seções ===== */
/* Todos os H2 (fora da seção escura) em verde pinho */
section:not(.section-steps) h2{ color:var(--ecom-dark) !important; }

/* ===== Testimonials (Depoimentos) ===== */

/* Seção: variáveis locais para o cartão */
.section-testimonials{
  --sage-card:   #EEF5F1;
  --sage-border: #D9E7E1;
}

/* Cartões com fundo verde-sage claro e borda suave */
.section-testimonials .card,
.section-testimonials .t-card,
.section-testimonials .card-testimonial,
.section-testimonials .bg-white{
  background-color:var(--sage-card)!important;
  border:1px solid var(--sage-border)!important;
  border-radius:16px;
}

/* Avatar tipo “quadradinho” verde escuro com iniciais */
.section-testimonials .avatar-badge,
.section-testimonials .avatar{
  width:52px;height:52px;border-radius:10px;
  background:var(--ecom-dark)!important;color:#fff!important;
  font-weight:700;font-size:.95rem;letter-spacing:.5px;
  display:inline-flex;align-items:center;justify-content:center;
  border:0!important;box-shadow:inset 0 -2px rgba(0,0,0,.12);
}

/* Tipos */
.section-testimonials .who small{ color:#5B6B65; }
.section-testimonials .quote{ color:#53645F; }

/* Estrelas */
.section-testimonials .stars i{ font-size:1rem; line-height:1; }
.section-testimonials .stars .bi-star-fill{ color:#FF7A45!important; }  /* laranja */
.section-testimonials .stars .bi-star,
.section-testimonials .stars .bi-star-half{ color:#C8D1CC!important; }  /* cinza suave */

/* ===== Forms ===== */
.form-control{border-color:#e0e6e4}
.form-control:focus{border-color:var(--ecom-dark);box-shadow:0 0 0 .25rem rgba(46,88,82,.15)}

/* ===== Footer ===== */
.footer{background:var(--ecom-dark);color:#dfe7e5}
.footer a{color:#dfe7e5;text-decoration:none}
.footer a:hover{text-decoration:underline}

/* ===== Products ===== */
.product-card{
  border:1px solid #e7ecea;border-radius:var(--radius-xl);
  overflow:hidden;transition:.2s transform,.2s box-shadow
}
.product-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft)}
.product-badge{
  background:#e9f1ef;color:var(--ecom-dark);border-radius:8px;
  padding:.15rem .5rem;font-size:.8rem
}
.price{font-weight:800}

/* ===== Dashboard sidebar ===== */
.sidebar{
  width:270px;background:#fff;border-right:1px solid #eef2f1;
  position:sticky;top:0;height:100vh;padding:1rem
}
.sidebar a{
  color:var(--ecom-dark);text-decoration:none;display:flex;
  align-items:center;gap:.5rem;padding:.6rem .75rem;border-radius:.75rem
}
.sidebar a.active,.sidebar a:hover{background:var(--ecom-sage-200)}
@media (max-width:991.98px){
  .sidebar{position:static;height:auto;width:100%;border-right:0;border-bottom:1px solid #eef2f1}
}


  /* Caixa verde (benefícios) */
  .benefits-card{
    background:#1e3e38; /* verde escuro */
    color:#fff;border-radius:16px;padding:24px;border:0;
  }
  .benefits-card h5{font-weight:700}
  .benefits-card .benefit{display:flex;gap:.75rem;align-items:flex-start;margin:.6rem 0}
  .benefits-card .benefit i{font-size:1.1rem}
  .benefits-card .sub{
    background:rgba(255,255,255,.08);
    border-radius:12px;padding:16px;margin-top:10px;
  }
  .benefits-card .btn-light{color:#1e3e38;font-weight:600}

  /* Cartões da FAQ */
  .faq-card{
    background:#fff;border:1px solid var(--ecom-border,#eee);
    border-radius:16px;padding:18px;height:100%;
  }

