/* =========================
   TecnoVerde Theme (Bootstrap 5.3)
   Cargar después de Bootstrap (como ya lo haces)
   ========================= */

/* 1) Variables base + color modes */
:root,
[data-bs-theme="light"]{
  /* Brand */
  --bs-primary: #16a34a;          /* verde */
  --bs-primary-rgb: 22, 163, 74;

  --bs-secondary: #f59e0b;        /* ámbar/solar */
  --bs-secondary-rgb: 245, 158, 11;

  /* Tokens que Bootstrap 5.3 usa harto (alerts, subtle, etc.) */
  --bs-primary-text-emphasis: #14532d;
  --bs-primary-bg-subtle: rgba(22, 163, 74, 0.12);
  --bs-primary-border-subtle: rgba(22, 163, 74, 0.28);

  --bs-secondary-text-emphasis: #7c2d12;
  --bs-secondary-bg-subtle: rgba(245, 158, 11, 0.14);
  --bs-secondary-border-subtle: rgba(245, 158, 11, 0.30);

  /* Links */
  --bs-link-color: var(--bs-primary);
  --bs-link-hover-color: #15803d;
}

/* (Opcional) Modo oscuro */
[data-bs-theme="dark"]{
  --bs-primary: #22c55e;
  --bs-primary-rgb: 34, 197, 94;

  --bs-secondary: #fbbf24;
  --bs-secondary-rgb: 251, 191, 36;

  --bs-primary-text-emphasis: #86efac;
  --bs-primary-bg-subtle: rgba(34, 197, 94, 0.16);
  --bs-primary-border-subtle: rgba(34, 197, 94, 0.34);

  --bs-secondary-text-emphasis: #fde68a;
  --bs-secondary-bg-subtle: rgba(251, 191, 36, 0.16);
  --bs-secondary-border-subtle: rgba(251, 191, 36, 0.34);

  --bs-link-color: var(--bs-primary);
  --bs-link-hover-color: #16a34a;
}

/* 2) FIX Bootstrap 5.3: botones primary/outline-primary
   (Bootstrap compila .btn-primary con variables de botón, no con --bs-primary directo)
*/
.btn-primary{
  --bs-btn-bg: var(--bs-primary);
  --bs-btn-border-color: var(--bs-primary);
  --bs-btn-hover-bg: #15803d;
  --bs-btn-hover-border-color: #15803d;
  --bs-btn-active-bg: #166534;
  --bs-btn-active-border-color: #166534;
  --bs-btn-focus-shadow-rgb: var(--bs-primary-rgb);
}

.btn-outline-primary{
  --bs-btn-color: var(--bs-primary);
  --bs-btn-border-color: var(--bs-primary);
  --bs-btn-hover-bg: var(--bs-primary);
  --bs-btn-hover-border-color: var(--bs-primary);
  --bs-btn-active-bg: #15803d;
  --bs-btn-active-border-color: #15803d;
  --bs-btn-focus-shadow-rgb: var(--bs-primary-rgb);
}

/* (Opcional) Si quieres que secondary sea ámbar también */
.btn-secondary{
  --bs-btn-bg: var(--bs-secondary);
  --bs-btn-border-color: var(--bs-secondary);
  --bs-btn-hover-bg: #d97706;
  --bs-btn-hover-border-color: #d97706;
  --bs-btn-active-bg: #b45309;
  --bs-btn-active-border-color: #b45309;
  --bs-btn-focus-shadow-rgb: var(--bs-secondary-rgb);
}

.btn-outline-secondary{
  --bs-btn-color: var(--bs-secondary);
  --bs-btn-border-color: var(--bs-secondary);
  --bs-btn-hover-bg: var(--bs-secondary);
  --bs-btn-hover-border-color: var(--bs-secondary);
  --bs-btn-active-bg: #d97706;
  --bs-btn-active-border-color: #d97706;
  --bs-btn-focus-shadow-rgb: var(--bs-secondary-rgb);
}

/* 3) Utilidades comunes (por si Bootstrap no las liga al token en tu caso) */
.text-bg-primary{ background-color: var(--bs-primary) !important; }
.bg-primary{ background-color: var(--bs-primary) !important; }
.border-primary{ border-color: var(--bs-primary) !important; }
.text-primary{ color: var(--bs-primary) !important; }

.text-bg-secondary{ background-color: var(--bs-secondary) !important; }
.bg-secondary{ background-color: var(--bs-secondary) !important; }
.border-secondary{ border-color: var(--bs-secondary) !important; }
.text-secondary{ color: var(--bs-secondary) !important; }

/* =========================
   Tu CSS original (adaptado)
   ========================= */

.card-product img{
  object-fit: cover;
  height: 180px;
}

/* Navbar logo */
.navbar-logo{
  height: 40px;
  width: auto;
  max-width: 220px;
}

@media (max-width: 576px){
  .navbar-logo{ height: 34px; max-width: 180px; }
}

.hero{
  border-radius: 18px;
  background: linear-gradient(
    135deg,
    rgba(var(--bs-primary-rgb), 0.10),
    rgba(var(--bs-secondary-rgb), 0.10)
  );
}

.badge-soft{
  background: var(--bs-primary-bg-subtle);
  color: var(--bs-primary);
  border: 1px solid var(--bs-primary-border-subtle);
}

/* =========================
   NUEVO: Hero full-width (premium)
   ========================= */

.hero-big{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  min-height: 420px;
}

/* Imagen de fondo del hero (cámbiala si quieres) */
.hero-bg{
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(100deg, rgba(9, 37, 20, .78), rgba(9, 37, 20, .35)),
    url("https://scontent.fscl8-1.fna.fbcdn.net/v/t39.30808-6/495938594_1099559802205978_6966372221282761979_n.jpg?_nc_cat=101&ccb=1-7&_nc_sid=cc71e4&_nc_eui2=AeGHsBj1B_2RgAcnZC5Bb0ftDmt3ob7PTFQOa3ehvs9MVAiHkflyjbB_hBW-jeXa7OE&_nc_ohc=TQzJo3-VWp4Q7kNvwFEMAdP&_nc_oc=AdmHcou-_hA0wIT3o9FPQj6-mzttue62GxTBCkS-cwSPniOnmOZlIS7kuPN34dQC4gY&_nc_zt=23&_nc_ht=scontent.fscl8-1.fna&_nc_gid=5ftetb7a-5O5iBwY6wAPTw&oh=00_AfpZL-aS8Eb-euLVyx9-htH1aR7ZxQVd-lyzGSocvOSEAg&oe=6961BDC9");
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
}

/* Tarjeta “glass” */
.hero-card{
  color: #fff;
  border-radius: 18px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 12px 30px rgba(0,0,0,.18);
}

.hero-badge{
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.22);
  color: #fff;
  padding: .4rem .7rem;
  border-radius: 999px;
  font-weight: 600;
}

/* Trust bar */
.trust-bar{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .75rem;
}

.trust-item{
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 14px;
  padding: .75rem .9rem;
  color: #fff;
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}

.trust-item span{
  opacity: .75;
  font-size: .85rem;
  margin-top: .25rem;
}

@media (max-width: 992px){
  .hero-big{ border-radius: 14px; }
  .trust-bar{ grid-template-columns: 1fr; }
}

/* Cards visuales para categorías */
.cat-card{
  position: relative;
  display: block;
  border-radius: 16px;
  overflow: hidden;
  height: 150px;
  box-shadow: 0 10px 22px rgba(0,0,0,.10);
  border: 1px solid rgba(255,255,255,.20);
  text-decoration: none;
}

.cat-card-wide{ height: 160px; }

.cat-img{
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
  transition: transform .25s ease;
}

.cat-overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.60));
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: .85rem .9rem;
  color: #fff;
}

.cat-title{
  font-weight: 800;
  font-size: 1.05rem;
  line-height: 1.1;
}

.cat-sub{
  opacity: .85;
  font-size: .85rem;
  margin-top: .15rem;
}

.cat-card:hover .cat-img{
  transform: scale(1.08);
}
