:root{
  --c-text:#111827;
  --c-bg:#fafafa;
  --c-primary:#005548;
  --c-primary-50: rgba(0,85,72,.5);
  --c-card:#000;
  --radius:12px;
}

/* ===== Contenedor principal ===== */
.section_products {
  width: 100%;
  padding: 3rem 1.25rem;
  margin: 3rem 0;
  font-size: 16px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  overflow: hidden;
  box-sizing: border-box;
}

.title_products{
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.title_products img{
  min-width: 200px;
  width: clamp(180px, 40vw, 420px);
  max-width: 100%;

-webkit-mask-image:
linear-gradient(to bottom, black 10%, transparent 100%),
linear-gradient(to left, black 90%, transparent 100%),
linear-gradient(to right, black 90%, transparent 100%);
-webkit-mask-repeat: no-repeat; -webkit-mask-size: 100% 100%;
-webkit-mask-composite: destination-in;
 mask-image:
 linear-gradient(to bottom, black 80%, transparent 100%),
 linear-gradient(to left, black 95%, transparent 100%),
 linear-gradient(to right, black 95%, transparent 100%);
 mask-repeat: no-repeat; mask-size: 100% 100%;
 mask-composite: intersect;
  mask-repeat: no-repeat;
  mask-size: 100% 100%;
  background-color: inherit;
}
.title_products h1 {
  position: relative;
  font-size: clamp(1.5rem, 1rem + 1vw, 2rem);
  font-weight: 800;
  letter-spacing: .5rem;
  text-align: center;
  color: #000;
  text-transform: uppercase;
  padding: 3rem;
}

/* Intro */
.info_product{
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: row;
  flex-wrap: wrap;
  gap: .5rem 2rem;
}
.info_product h2 {
  letter-spacing: 0.1vw;
  text-align: center;
  color: #000;
  padding: 1.5rem;
  width: min(30%, 620px);
  min-width: 300px;
  font-size: clamp(1rem, 0.7rem + .7vw, 1.125rem);
}

/* ===== GRID de tarjetas ===== */
.container_product {
  position: relative;
  width: 100%;
  max-width: 1200px;
  margin: auto;
  box-sizing: border-box;
  padding: 1rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.25rem;
  overflow: hidden;
}

/* ===== Tarjetas ===== */
.boxes_product{
  background-color: var(--c-card);
  color: #fff;
  padding: .5rem;
  border-radius: 8px;
  box-shadow: 0 10px 25px rgba(0,0,0,.06);
  display: grid;
  grid-template-rows: auto 1fr auto; /* header, imagen flexible, texto */
  gap: .5rem;
  overflow: hidden; /* recorta bordes del overlay */
}

/* Header de la tarjeta */
.info_box_product{
  background: linear-gradient(to bottom, rgba(235,255,235,0.45) 0%, var(--c-primary) 100%);
  padding: .6rem .8rem;
  border-radius: 6px;
  margin: 0;
}
.info_box_product a{
  color: #fff;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  min-height: 48px;     /* mejor tap-target */
  font-weight: 700;
  letter-spacing: .03em;
}
.info_box_product a:focus-visible{
  outline: 3px solid #fff;
  outline-offset: 2px;
}

/* Imagen + overlay (el enlace grande que cubre la imagen) */
.box_product {
  position: relative;
  border-radius: 6px;
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease;
  display: block;
}
.box_product:focus-visible{
  outline: 3px solid #fff;
  outline-offset: 2px;
}
.box_product:hover { transform: scale(1.01); }
.box_product:active { transform: scale(1.02); }

.box_product img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  aspect-ratio: 16 / 10; /* altura cómoda por defecto */
  display: block;
}

.shade_box_product {
  position: absolute;
  inset: auto 0 0 0;
  background: linear-gradient(to top, rgba(0,0,0,.55) 0%, rgba(0,0,0,.0) 90%);
  padding: .75rem .85rem;
  color: #fff;
  font-weight: 700;
  text-transform: uppercase;
}
.shade_box_product h2 {
  margin: 0;
  font-size: clamp(16px, 1.4vw, 22px);
  font-weight: 700;
  text-align: left;
}

/* Texto de la tarjeta */
.texto{
  background: linear-gradient(to top, rgba(235,255,235,0.45) 0%, var(--c-primary) 100%);
  padding: 1rem .9rem;
  border-radius: 6px;
  margin: 0;
  min-height: 88px;
  color: #fff;
  overflow:hidden;
}
.texto h3{
  margin: 0 0 .35rem 0;
  font-size: clamp(1rem, .9rem + .4vw, 1.1rem);
  font-weight: 800;
}
.texto p{
  margin: 0;
  font-size: clamp(.95rem, .85rem + .4vw, 1.05rem);
  line-height: 1.55;
  text-align: justify;
  opacity: .95;
}

/* ===== Responsivo fino ===== */
@media (min-width: 1200px){
  .container_product{ gap: 1.5rem; }
  .title_products h1{ letter-spacing: .45rem; }
  .info_product h2 { padding: 1.25rem 1.5rem; }
}

@media (max-width: 1024px){
  .section_products{ padding: 2.5rem 1rem; margin: 2rem 0; }
  .container_product{ gap: 1rem; }
  .shade_box_product h2{ font-size: clamp(15px, 1.6vw, 20px); }
}

@media (max-width: 768px){
  .title_products{ padding-top: .5rem; }
  .title_products h1{ padding: 1.5rem 0 0; letter-spacing: .2rem; }
  .container_product{
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 0.9rem;
  }
  .info_box_product{ padding: .55rem .75rem; }
  .shade_box_product{ padding: .65rem .75rem; }
  .texto{ padding: .85rem .8rem; min-height: 80px; }
  .texto p{ line-height: 1.5; }
}

@media (max-width: 560px){
  .section_products{ padding: 2rem .85rem; margin: 1.5rem 0; }
  .container_product{ grid-template-columns: 1fr; gap: 1rem; }
  .box_product img{ aspect-ratio: 4 / 3; } /* más alto en móviles */
  .shade_box_product h2{ font-size: clamp(14px, 4.2vw, 18px); }
  .texto{ min-height: 72px; }
}

@media (max-width: 380px){
  .title_products h1{ letter-spacing: .08rem; padding: 1rem 0 0; }
  .container_product{ grid-template-columns: 1fr; gap: .9rem; }
  .info_box_product a{ min-height: 44px; font-size: 1rem; }
}

/* Hover solo donde existe */
@media (hover:hover) and (pointer:fine){
  .box_product:hover { transform: scale(1.01); }
  .box_product:active { transform: scale(1.02); }
}
@media (hover:none){
  .box_product:hover, .box_product:active { transform: none; }
}

/* Preferencias del usuario */
@media (prefers-reduced-motion: reduce){
  .box_product{ transition: none; }
}
