/* =====================================================================
   Brindes Empresariales — estilo público
   "Vidriera profesional de merchandising", no ecommerce frío.
   --color-primario y --color-secundario los inyecta cada sitio desde DB.
   ===================================================================== */

:root{
  --tinta:#15140f;
  --tinta-2:#3a382f;
  --papel:#f6f3ec;          /* fondo cálido tipo papel */
  --papel-2:#efe9dd;
  --linea:#e0d8c8;
  --blanco:#ffffff;
  --radio:14px;
  --sombra:0 8px 30px rgba(20,18,12,.08);
  --max:1160px;
  /* fallbacks por si el sitio no define color */
  --color-primario:#15140f;
  --color-secundario:#c8a24b;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--papel); color:var(--tinta);
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16px; line-height:1.55; -webkit-font-smoothing:antialiased;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
.contenedor{width:100%; max-width:var(--max); margin:0 auto; padding:0 20px}

/* ---------- Topbar ---------- */
.topbar{
  position:sticky; top:0; z-index:40;
  background:color-mix(in srgb, var(--papel) 88%, transparent);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--linea);
}
.topbar__inner{display:flex; align-items:center; justify-content:space-between; gap:18px; min-height:68px}
.marca__logo{height:38px; width:auto}
.marca__texto{
  font-family:"Fraunces",serif; font-weight:800; font-size:21px;
  letter-spacing:-.01em; color:var(--color-primario);
}
.nav{display:flex; align-items:center; gap:4px; flex-wrap:wrap}
.nav__item{
  font-size:14px; font-weight:500; padding:8px 12px; border-radius:999px;
  color:var(--tinta-2); transition:background .15s,color .15s;
}
.nav__item:hover{background:var(--papel-2); color:var(--tinta)}
.nav__item--cta{
  background:var(--color-primario); color:var(--blanco); font-weight:600;
}
.nav__item--cta:hover{background:var(--color-primario); opacity:.9; color:var(--blanco)}

/* ---------- Hero (la tesis de la página) ---------- */
.hero{position:relative; padding:64px 0 48px; overflow:hidden}
.hero__eyebrow{
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--color-secundario); font-weight:600; margin:0 0 14px;
}
.hero__titulo{
  font-family:"Fraunces",serif; font-weight:800; line-height:1.02;
  font-size:clamp(34px,6vw,62px); letter-spacing:-.02em; margin:0 0 18px;
  max-width:16ch;
}
.hero__titulo em{font-style:italic; color:var(--color-secundario)}
.hero__bajada{font-size:clamp(16px,2.2vw,19px); color:var(--tinta-2); max-width:52ch; margin:0 0 28px}
.hero__acciones{display:flex; gap:12px; flex-wrap:wrap}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px; cursor:pointer;
  font-weight:600; font-size:15px; padding:12px 20px; border-radius:999px;
  border:1px solid transparent; transition:transform .12s, box-shadow .15s, background .15s;
}
.btn:hover{transform:translateY(-1px)}
.btn--solido{background:var(--color-primario); color:var(--blanco)}
.btn--oro{background:var(--color-secundario); color:#1a1407}
.btn--linea{background:transparent; border-color:var(--tinta); color:var(--tinta)}
.btn--bloque{width:100%; justify-content:center}

/* ---------- Cintas de categorías ---------- */
.cintas{display:flex; gap:10px; flex-wrap:wrap; margin-top:34px}
.cinta{
  font-size:13px; padding:7px 14px; border-radius:999px;
  border:1px solid var(--linea); background:var(--blanco); color:var(--tinta-2);
}
.cinta:hover{border-color:var(--color-secundario); color:var(--tinta)}

/* ---------- Secciones ---------- */
.seccion{padding:54px 0}
.seccion__head{display:flex; align-items:end; justify-content:space-between; gap:16px; margin-bottom:26px}
.seccion__titulo{font-family:"Fraunces",serif; font-weight:600; font-size:clamp(24px,3.5vw,34px); margin:0; letter-spacing:-.01em}
.seccion__link{font-size:14px; color:var(--color-secundario); font-weight:600}

/* ---------- Grilla de productos (vidriera) ---------- */
.grilla{
  display:grid; gap:20px;
  grid-template-columns:repeat(auto-fill, minmax(240px,1fr));
}
.tarjeta{
  background:var(--blanco); border:1px solid var(--linea); border-radius:var(--radio);
  overflow:hidden; transition:box-shadow .2s, transform .2s, border-color .2s;
  display:flex; flex-direction:column;
}
.tarjeta:hover{box-shadow:var(--sombra); transform:translateY(-3px); border-color:transparent}
.tarjeta__foto{aspect-ratio:4/3; background:var(--papel-2); overflow:hidden}
.tarjeta__foto img{width:100%; height:100%; object-fit:cover; transition:transform .4s}
.tarjeta:hover .tarjeta__foto img{transform:scale(1.04)}
.tarjeta__cuerpo{padding:14px 16px 18px; display:flex; flex-direction:column; gap:6px; flex:1}
.tarjeta__cat{font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--color-secundario); font-weight:600}
.tarjeta__nombre{font-family:"Fraunces",serif; font-size:18px; font-weight:600; line-height:1.2}
.tarjeta__desc{font-size:13px; color:var(--tinta-2); flex:1}
.tarjeta__pie{display:flex; gap:8px; align-items:center; margin-top:8px}
.badge{font-size:11px; font-weight:600; padding:3px 9px; border-radius:999px; background:var(--papel-2); color:var(--tinta-2)}
.badge--pronta{background:#e7f4ea; color:#1d6b38}
.badge--nuevo{background:#eae6fb; color:#4a35a8}

/* ---------- Ficha de producto ---------- */
.ficha{display:grid; gap:34px; padding:40px 0; grid-template-columns:1fr}
.ficha__galeria{display:flex; flex-direction:column; gap:12px}
.ficha__principal{aspect-ratio:1/1; background:var(--papel-2); border-radius:var(--radio); overflow:hidden}
.ficha__principal img{width:100%; height:100%; object-fit:cover}
.ficha__miniaturas{display:grid; grid-template-columns:repeat(4,1fr); gap:10px}
.ficha__miniaturas img{aspect-ratio:1/1; object-fit:cover; border-radius:10px; border:1px solid var(--linea); cursor:pointer}
.ficha__titulo{font-family:"Fraunces",serif; font-size:clamp(26px,4vw,38px); font-weight:700; margin:6px 0 10px; line-height:1.08}
.ficha__codigo{font-size:13px; color:var(--tinta-2); letter-spacing:.04em}
.ficha__specs{margin:22px 0; border-top:1px solid var(--linea)}
.ficha__spec{display:flex; justify-content:space-between; gap:16px; padding:11px 0; border-bottom:1px solid var(--linea); font-size:14px}
.ficha__spec dt{color:var(--tinta-2)}
.ficha__spec dd{margin:0; font-weight:500; text-align:right}
.ficha__acciones{display:flex; flex-direction:column; gap:10px; margin-top:24px}

/* ---------- Bloque vendedores ---------- */
.vendedores{display:grid; gap:18px; grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.vendedor{background:var(--blanco); border:1px solid var(--linea); border-radius:var(--radio); padding:20px; display:flex; gap:14px; align-items:center}
.vendedor__foto{width:56px; height:56px; border-radius:50%; object-fit:cover; background:var(--papel-2); flex:none}
.vendedor__nombre{font-weight:600; font-family:"Fraunces",serif; font-size:18px}
.vendedor__cargo{font-size:13px; color:var(--tinta-2)}
.vendedor__wa{margin-top:8px; font-size:13px; font-weight:600; color:#1d6b38}

/* ---------- WhatsApp flotante ---------- */
.wa-flotante{
  position:fixed; right:18px; bottom:18px; z-index:50;
  width:54px; height:54px; border-radius:50%; display:grid; place-items:center;
  background:#25d366; color:#fff; box-shadow:0 8px 24px rgba(37,211,102,.4);
}
.wa-flotante:hover{transform:scale(1.06)}

/* ---------- Pie ---------- */
.pie{background:var(--color-primario); color:#e9e6df; margin-top:40px}
.pie__inner{display:grid; gap:30px; grid-template-columns:1fr; padding:44px 20px 26px}
.pie__marca{font-family:"Fraunces",serif; font-size:20px; font-weight:700; color:#fff; margin:0 0 10px}
.pie__col p{margin:4px 0; font-size:14px; color:#cfc9bd}
.pie__nav{display:flex; flex-direction:column; gap:8px; font-size:14px}
.pie__nav a:hover{color:#fff}
.pie__base{display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap;
  padding-top:18px; padding-bottom:24px; border-top:1px solid rgba(255,255,255,.12);
  font-size:12px; color:#a8a399}

/* ---------- Vacío / 404 ---------- */
.vacio{text-align:center; padding:80px 20px}
.vacio h1{font-family:"Fraunces",serif; font-size:40px; margin:0 0 10px}
.vacio p{color:var(--tinta-2)}

/* ---------- Responsive ---------- */
@media (min-width:760px){
  .ficha{grid-template-columns:1.05fr 1fr; align-items:start}
  .ficha__acciones{flex-direction:row; flex-wrap:wrap}
  .pie__inner{grid-template-columns:2fr 1fr}
}
@media (max-width:560px){
  .nav{display:none}
  .topbar__inner{min-height:60px}
}

@media (prefers-reduced-motion:reduce){
  *{transition:none !important; animation:none !important}
}
