/* =========================================================
   QUIÉNES SOMOS (qs-*)
   Premium + responsive. Pinyon SOLO en #qs-hero-title.
   Fondo con foto real suavizada (opción 4)
   Carrusel unificado (Homenajes + Galería actual)
   ========================================================= */

/* ---------- Variables ---------- */
:root {
  --qs-verde: #155e40;
  --qs-verde-osc: #0f4a32;
  --qs-crema: #f7f4ed;
  --qs-blanco: #fff;
  --qs-texto: #1f1f1f;
  --qs-muted: #666;
  --qs-borde: rgba(0, 0, 0, .06);
  --qs-gap: clamp(12px, 2.5vw, 22px);
  --qs-radius: 14px;
  --qs-shadow: 0 10px 22px rgba(0, 0, 0, .12);
  --qs-maxw-narrow: min(760px, 94vw);
  --qs-bg: url("/media/Espejo.jpg");
}

/* ---------- Lienzo (foto + overlay) ---------- */
.qs {
  min-height: 100vh;
  padding: 12px 0 12px;
  padding-top: 0;
  text-align: center;
  color: var(--qs-crema);
  font-family: "Charm", cursive;
  font-size: clamp(18px, 2.6vw, 20px);
  line-height: 1.65;
  background:
    radial-gradient(circle at 30% 20%, #d6c34b63 0%, #155e40a1 70%, rgba(0, 0, 0, 0.834) 100%),
    var(--qs-bg) bottom/cover no-repeat fixed;
  
}

@media (max-width:900px) {
  .qs {
    background-attachment: scroll;
  }
}

/* ---------- Tarjetas (hero + secciones) ---------- */
.qs .qs-hero,
.qs .qs-section,
#qs-reviews.qs-section {
  max-width: var(--qs-maxw-narrow);
  margin: clamp(18px, 3vw, 32px) auto;
  padding: clamp(16px, 3vw, 24px);
  
}

/* ---------- HERO ancho completo tipo Historia ---------- */
.qs .qs-hero {
  max-width: none;
  width: 100%;
  margin: 0;
  padding: clamp(18px, 3vw, 28px) 0;
  background: var(--qs-crema);
  border: 0;
  border-bottom: 1px solid var(--qs-borde);
  border-radius: 0;
  box-shadow: none;
}

.qs .qs-hero__wrap {
  max-width: var(--qs-maxw-narrow);
  margin: 0 auto;
  padding: 0 var(--qs-gap);
  text-align: center;
}

/* Solo el H1 principal con Pinyon */
#qs-hero-title {
  font-family: "Pinyon Script", cursive;
  font-weight: 400;
  font-size: clamp(32px, 5.2vw, 56px);
  margin: 0 0 .35rem;
  letter-spacing: .2px;
  text-decoration: underline 1px;
  text-underline-offset: 4px;
  text-shadow: -1px 0 #fafafa, 1px 0 #bebebe, 0 1px #494949, 0 -1px #b9b9b9;
  color: var(--qs-texto);
}

.qs .qs-hero__subtitle {
  margin: .25rem 0 1.25rem;
  color: #334155;
  font-size: clamp(16px, 2.6vw, 20px);
}

/* ---------- CTA hero (botones) ---------- */
.qs .qs-hero__cta {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
  justify-content: center;
}

.qs .btn {
  display: inline-block;
  padding: .7rem 1.1rem;
  border-radius: 999px;
  background: var(--qs-verde);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  border: 1px solid transparent;
  box-shadow: 0 8px 18px rgba(21, 94, 64, .22);
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
}

.qs .btn:hover {
  transform: translateY(-1px);
  background: var(--qs-verde-osc);
}

.qs .btn:active {
  transform: translateY(0);
  box-shadow: 0 3px 10px rgba(21, 94, 64, .18);
}

.qs .btn--ghost {
  background: rgba(21, 94, 64, .06);
  color: var(--qs-verde);
  border-color: rgba(21, 94, 64, .25);
}

.qs .btn--ghost:hover {
  background: rgba(21, 94, 64, .12);
}

@media (max-width:420px) {
  .qs .qs-hero__cta .btn {
    width: 100%;
    text-align: center;
  }
}

/* ---------- Secciones ---------- */
.qs .qs-section>h2 {
  color: #fff;
  margin: 0 0 .8rem;
  font-size: clamp(24px, 3.6vw, 36px);

  border-radius: 999px;

}

.qs .qs-card {
  position: relative;
  text-align: left;
  background: #fff;
  color: var(--qs-texto);
  border: 1px solid rgba(0, 0, 0, .06);
  border-radius: var(--qs-radius);
  box-shadow: 0 10px 22px rgba(0, 0, 0, .10);
  padding: clamp(12px, 2.4vw, 18px);
  transition: transform .15s ease, box-shadow .2s ease;
}

.qs .qs-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(0, 0, 0, .14);
}

/* ---------- Tipo de empresa / Impacto ---------- */
.qs .qs-tipo__grid {
  display: grid;
  gap: var(--qs-gap);
}

@media (min-width:900px) {
  .qs .qs-tipo__grid {
    grid-template-columns: 1fr 1fr;
  }
}

.qs .qs-kpis {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 0;
  list-style: none;
}

@media (max-width:480px) {
  .qs .qs-kpis {
    grid-template-columns: 1fr;
  }
}

.qs .qs-kpis li {
  background: linear-gradient(180deg, #155e40, #0f4a32);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 12px;
  padding: .9rem .85rem;
  text-align: center;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .18);
}

.qs .qs-kpi {
  display: block;
  font-weight: 800;
  font-size: clamp(18px, 4.2vw, 28px);
}

.qs .muted {
  color: #d1d5db;
}

/* ---------- Homenajes ---------- */
.qs .qs-hdr {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: .5rem;

  border-radius: 999px;

}



.qs .qs-select select {
  padding: .55rem .8rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .35);
  background: rgba(255, 255, 255, .08);
  color: #000000;
  backdrop-filter: blur(2px);
}

.qs .qs-homenaje {
  display: grid;
  gap: var(--qs-gap);
}

.qs .qs-homenaje__grid {
  display: grid;
  gap: var(--qs-gap);
  grid-template-columns: 1fr;
}

@media (min-width:900px) {
  .qs .qs-homenaje__grid {
    grid-template-columns: 1fr 1fr;
  }
}

.qs .qs-card--honor {
  background: linear-gradient(180deg, #0f4a32, #0b3926);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, .10);
  border-radius: 14px;
  padding: 1rem .9rem;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .18);
  text-align: left;
}

/* ---------- Carrusel UNIFICADO (Homenajes + Galería actual) ---------- */
.qs-carousel {
  position: relative;
  width: 100%;
  margin-inline: auto;
  display: grid;
  gap: 10px;
}

.qs-carousel__viewport {
  position: relative;
  width: 100%;
  height: min(70vh, 720px);
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: #fff;
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, .08);
  box-shadow: 0 8px 18px rgba(0, 0, 0, .10);
}

.qs-carousel__track {
  display: flex;
  align-items: center;
  gap: 0;
  width: 100%;
  height: 100%;
}

.qs-carousel__slide {
  flex: 0 0 100%;
  display: grid;
  place-items: center;
  height: 100%;
  padding: 10px;
}

.qs-carousel__slide figure {
  margin: 0;
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 8px;
}

.qs-carousel__slide img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #fff;
  border-radius: 8px;
}

.qs-carousel__caption {
  text-align: center;
  font-size: .95rem;
  color: #475569;
  padding-bottom: 4px;
}

/* Flechas (usa tus clases y estilos) */
.qs-car-btn--prev,
.qs-car-btn--next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  background-color: rgba(0, 0, 0, .5);
  color: #fff;
  border: none;
  padding: .4rem .6rem;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(0, 0, 0, .3);
  transition: background-color .2s ease;
  z-index: 10;
}

.qs-car-btn--prev:hover,
.qs-car-btn--next:hover {
  background-color: rgba(0, 0, 0, .7);
}

.qs-car-btn--prev {
  left: 12px;
}

.qs-car-btn--next {
  right: 12px;
}

/* Dots (no clicables) */
.qs-carousel__dots {
  display: flex;
  gap: 8px;
  justify-content: center;
  align-items: center;
}

.qs-carousel__dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .45);
}

.qs-carousel__dot.is-active {
  background: #fff;
}

/* --- MÓVIL: listado horizontal con scroll-snap y “peek” --- */
@media (max-width: 768px) {
  .qs-carousel__viewport {
    height: auto;
    background: transparent;
    border: 0;
    box-shadow: none;
  }

  .qs-carousel__track {
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 12px;
    padding: 6px 4px;
  }

  .qs-carousel__slide {
    flex: 0 0 80%;
    max-width: 80%;
    scroll-snap-align: start;
    height: auto;
  }

  .qs-carousel__slide img {
    aspect-ratio: 4/3;
  }

  .qs-car-btn--prev,
  .qs-car-btn--next {
    display: none;
  }

  /* en móvil navegamos con swipe */
}

/* ---------- Proceso AOVE ---------- */
.qs .qs-steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--qs-gap);
}

@media (max-width:768px) {
  .qs .qs-steps {
    display: flex;
    overflow: auto;
    gap: var(--qs-gap);
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 6px;
  }

  .qs .qs-step {
    min-width: 85%;
    scroll-snap-align: start;
  }
}

.qs .qs-step {
  display: grid;
  grid-template-columns: 62px 1fr;
  gap: 12px;
  align-items: start;
  padding: 16px;
  text-align: left;
  background: #fff;
  color: var(--qs-texto);
  border: 1px solid var(--qs-borde);
  border-radius: var(--qs-radius);
  box-shadow: var(--qs-shadow);
}

.qs .qs-step__n {
  width: 62px;
  height: 62px;
  border-radius: 18px;
  background: radial-gradient(90% 90% at 50% 50%, #eef6f1, #e6f2ec);
  color: var(--qs-verde);
  display: grid;
  place-items: center;
  font-weight: 900;
  font-size: 20px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, .06), inset 0 1px 0 #fff;
  border: 1px solid rgba(21, 94, 64, .08);
}

.qs .qs-step img {
  width: 100%;
  max-width: 520px;
  border-radius: 12px;
}

/* ---------- Galería actual: usará el MISMO carrusel ---------- */
.qs .qs-gallery {
  display: block;
}

/* placeholder: se renderiza carrusel con JS */

/* ---------- Reseñas ---------- */
#qs-reviews.qs-section {
  border: 1px solid rgba(0, 0, 0, .06);
  box-shadow: 0 10px 22px rgba(0, 0, 0, .10), inset 0 1px 0 rgba(255, 255, 255, .5);
  text-align: center;
}

#qs-reviews .qs-reviews__cta {
  margin: 0 0 var(--qs-gap);
}

#qs-reviews .btn {
  background: transparent;
  color: var(--qs-verde);
  border: 1px solid rgba(21, 94, 64, .35);
}

#qs-reviews .btn:hover {
  background: rgba(21, 94, 64, .08);
}

#qs-reviews .qs-reviews__map {
  position: relative;
  width: 100%;
  max-width: var(--qs-maxw-narrow);
  margin: 0 auto;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--qs-borde);
  box-shadow: var(--qs-shadow);
}

#qs-reviews .qs-reviews__map::before {
  content: "";
  display: block;
  padding-bottom: 56.25%;
}

#qs-reviews .qs-reviews__map iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

#qs-reviews .qs-reviews__note {
  margin-top: .7rem;
  font-size: .95rem;
  color: #475569;
}

/* ---------- Skeleton + reduce motion ---------- */
.qs .skeleton {
  background: linear-gradient(90deg, #eee 25%, #f5f5f5 37%, #eee 63%);
  background-size: 400% 100%;
  animation: qs-sk 1.2s ease infinite;
  border-radius: 12px;
}

@keyframes qs-sk {
  0% {
    background-position: 100% 0
  }

  100% {
    background-position: 0 0
  }
}

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