/* ===== Colección: Piedras naturales ===== */
.vh-section{ min-height: 100svh; display:flex; align-items:center; }
.reveal{ opacity:0; transform: translateY(18px); transition: opacity .6s, transform .6s; }
.reveal.is-visible{ opacity:1; transform:none; }

/* HERO */
.parallax-colec{
  background-image: url("../img/fondos/img1.webp");
  background-attachment: fixed;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative; color: var(--starlight);
}
@media (max-width: 991.98px){ .parallax-colec{ background-attachment: scroll; } }
.parallax-colec::after{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(900px 600px at 85% 20%, rgba(233,165,58,.12), transparent 65%),
    radial-gradient(1000px 700px at 10% 80%, rgba(107,74,124,.18), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.15), rgba(0,0,0,.35));
  pointer-events:none;
}

#colec-hero .hero-title{
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.5px;
  color: var(--starlight);
  font-size: clamp(2.4rem, 5.2vw, 140px);
  margin: 0;
  text-wrap: balance;
}

#colec-hero p{
  color: rgba(248,247,243,.92);
  font-weight: 600;
  font-size: clamp(1rem, .7vw + .95rem, 1.2rem);
  text-wrap: pretty;
}
.hero-social-proof .stars{ letter-spacing:.06em; color: color-mix(in oklab, var(--amber-glow) 90%, #fff 10%); }


/* ===== Tarjeta de colección unificada ===== */
#grid-piedras{ background:#ededed; }
#grid-piedras h2{
  font-weight:900; line-height:1.06; letter-spacing:-.3px;
  font-size: clamp(2rem, 4.6vw, 120px); color: var(--areya-text);
}
#grid-piedras .lead{ color: color-mix(in oklab, var(--areya-text) 85%, #000 15%); }
.card-coleccion{
  display:flex; flex-direction:column; height:100%;
  background: transparent; border:0; border-radius:16px; overflow:visible;
}

.cardc-media{
  position:relative; aspect-ratio: 4/5; border-radius:16px; overflow:hidden;
  border: 1px solid color-mix(in oklab, var(--amber-glow) 30%, #000 70%);
  box-shadow:
    0 0 0 2px color-mix(in oklab, var(--amber-glow) 12%, #000 88%),
    0 14px 28px rgba(0,0,0,.22);
  background:
    radial-gradient(520px 360px at 85% 15%, color-mix(in oklab, var(--amethyst) 16%, #000 84%), transparent 60%),
    radial-gradient(540px 380px at 15% 85%, color-mix(in oklab, var(--amber-glow) 12%, #000 88%), transparent 62%);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, background-color .22s ease;
}

.cardc-link{ display:block; position:absolute; inset:0; }
.cardc-img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center; display:block; background:#000;
  transform: scale(1); transition: transform .45s ease, filter .45s ease;
  will-change: transform, filter;
}

/* Chip material/piedra */
.cardc-chip{
  position:absolute; top:.65rem; left:.65rem; z-index:2;
  font-size:.72rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
  padding:.35rem .6rem; border-radius:999px;
  background:
    linear-gradient(#0000,#0000) padding-box,
    var(--areya-gradient) border-box;
  border:1.5px solid transparent;
  color:#141414; box-shadow: 0 6px 16px rgba(233,165,58,.18);
  max-width: 70%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Sello derecho */
.cardc-badge{
  position:absolute; top:.65rem; right:.65rem; z-index:2;
  font-size:.72rem; font-weight:800; letter-spacing:.02em;
  padding:.35rem .6rem; border-radius:8px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12); color: var(--starlight);
  backdrop-filter: blur(6px);
}

/* Estado agotado */
.cardc-overlay-estado{
  position:absolute; left:0; right:0; top:0; bottom:0; z-index:1;
  background: rgba(0,0,0,.45);
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-weight:900; letter-spacing:.06em; text-transform:uppercase;
}

/* Overlay inferior */
.cardc-overlay{
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  padding:.9rem .95rem;
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.58) 88%);
  color: var(--starlight);
}

/* Título (resistente a desbordes) */
.cardc-title{
  font-weight:800; line-height:1.2; letter-spacing:.2px; margin:0 0 .25rem 0;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}

/* Precio */
.cardc-price{
  display:flex; align-items:center; gap:.55rem; flex-wrap:wrap;
  font-weight:800; color: var(--starlight);
}
.cardc-price .price-now{ font-feature-settings: "tnum" 1, "lnum" 1; }
.cardc-price .price-old{
  color: rgba(248,247,243,.75); font-weight:700; text-decoration: line-through;
}
.cardc-price .price-pill{
  font-size:.72rem; font-weight:900; letter-spacing:.08em; text-transform:uppercase;
  padding:.2rem .5rem; border-radius:999px; background: #e84242; color:#fff;
}
.cardc-price .price-out{ color: rgba(248,247,243,.9); }

/* CTA */
.cardc-actions{ padding:.85rem 0 0; }

/* Hover */
.card-coleccion:hover .cardc-media,
.card-coleccion:focus-within .cardc-media{
  transform: translateY(-4px);
  box-shadow:
    0 0 0 2px color-mix(in oklab, var(--amber-glow) 18%, #000 82%),
    0 22px 46px rgba(0,0,0,.30);
}
.card-coleccion:hover .cardc-img,
.card-coleccion:focus-within .cardc-img{
  transform: scale(1.04);
  filter: brightness(1.03) saturate(1.05);
}

/* Accesibilidad foco */
.card-coleccion:focus-within{
  outline: 3px solid color-mix(in oklab, var(--moon-gold) 75%, #fff 25%);
  outline-offset: 3px; border-radius:18px;
}

/* ===== CTA bajo grid ===== */
.cta-band{
  margin-top: clamp(1.8rem, 4vw, 3rem);
  margin-bottom: clamp(1.8rem, 4vw, 3rem);
}

.cta-band__inner{
  position: relative;
  border-radius: 18px;
  padding: clamp(1rem, 2.2vw, 1.65rem);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 14px 36px rgba(0,0,0,.20), 0 0 0 1px rgba(233,165,58,.08) inset;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);

  /* “borde” degradado sutil (doble fondo) */
  background-image: url("../img/fondos/img1.webp");
  border: 1.5px solid transparent;

  display: grid;
  grid-template-columns: 1fr auto;
  gap: clamp(.9rem, 2vw, 1.4rem);
  align-items: center;
}



.cta-band__title{
  font-weight: 900;
  letter-spacing: -.3px;
  line-height: 1.08;
  font-size: clamp(1.25rem, 1.1vw + 1rem, 1.75rem);
  color: white;
}

.cta-band__lead{
  margin-top: .35rem;
  color: color-mix(in oklab, white 85%, #000 15%);
  font-weight: 600;
  font-size: clamp(1rem, .7vw + .92rem, 1.125rem);
}

/* Perks en línea */
.cta-band__perks{
  display: flex; flex-wrap: wrap;
  gap: .55rem .9rem;
  padding: 0; margin: .7rem 0 0 0;
  list-style: none;
}
.cta-band__perks li{
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .35rem .6rem;
  border-radius: 999px;
  background:
    linear-gradient(#0000,#0000) padding-box,
    var(--areya-gradient) border-box;
  border: 1px solid transparent;
  color: #141414;
  font-weight: 800;
  font-size: .82rem;
  letter-spacing: .02em;
  box-shadow: 0 6px 16px rgba(233,165,58,.14);
}
.cta-band__perks i{
  background: var(--areya-gradient);
  -webkit-background-clip:text; background-clip:text;
  color: transparent; -webkit-text-fill-color: transparent;
  font-size: 1rem;
}

/* Botón: separado y sin pisar tarjetas */
.cta-band__action{
  display:flex; justify-content:flex-end; align-items:center;
}
.cta-band__action .btn{
  white-space: nowrap;
}

/* Hover sutil del panel */
.cta-band__inner:hover{
  box-shadow: 0 18px 44px rgba(0,0,0,.26), 0 0 0 1px rgba(233,165,58,.12) inset;
}

/* Responsive */
@media (max-width: 767.98px){
  .cta-band__inner{
    grid-template-columns: 1fr;
    text-align: center;
  }
  .cta-band__action{ justify-content: center; }
}


/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .pieza-media, .pieza-img{ transition: none !important; }
}

/* Pequeño ajuste en móvil: reduce radios/márgenes si quieres */
@media (max-width: 575.98px){
  .pieza-media{ border-radius:14px; }
  .cta-band__perks{
    flex-direction: column;     /* en vez de filas */
    align-items: stretch;        /* que ocupen todo el ancho */
    gap: .55rem;
  }
  .cta-band__perks li{
    width: 100%;
    justify-content: center;     /* icono + texto centrados */
    text-align: center;
    font-size: 1em;
  }
}


/* ---------- PARALLAX EDITORIAL ---------- */
.parallax-editorial{
  background-image: url("../img/fondos/img3.webp"); /* 16:9 */
  background-attachment: fixed;
  background-position: center center; background-repeat:no-repeat; background-size: cover;
  position:relative; color: var(--starlight);
}
@media (max-width: 991.98px){ .parallax-editorial{ background-attachment: scroll; } }
.parallax-editorial::after{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(900px 600px at 86% 18%, rgba(233,165,58,.12), transparent 60%),
    radial-gradient(1000px 700px at 12% 80%, rgba(107,74,124,.18), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.15), rgba(0,0,0,.42));
  pointer-events:none;
}
#editorial .container{ position:relative; z-index:1; }
#editorial h2{
  font-weight:900; line-height:1.06; letter-spacing:-.3px;
  font-size: clamp(2rem, 4.6vw, 120px); margin:0; color: var(--starlight);
}
#editorial .lead{ color: rgba(248,247,243,.9); }
.editorial-media{ border-radius:16px; overflow:hidden; box-shadow:0 18px 40px rgba(0,0,0,.35); }
.editorial-img{ display:block; width:100%; height:auto; }

/* ---------- FAQ ---------- */
#faq-piedras h2{
  font-weight:900; line-height:1.06; letter-spacing:-.3px;
  font-size: clamp(2rem, 5vw, 120px); margin:0; color: var(--starlight);
}

.faq-intro{
  max-width: 62ch; margin-inline: auto;
  color: rgba(248,247,243,.92); font-weight: 500;
  font-size: clamp(1rem, .7vw + .92rem, 1.125rem);
  text-wrap: pretty;
}
#faq-piedras .accordion-item{
  border: 1px solid rgba(255,255,255,.10); border-radius:14px; overflow:hidden;
  background: rgba(255,255,255,.03); backdrop-filter: blur(6px);
}
#faq-piedras .accordion-item + .accordion-item{ margin-top:.8rem; }
#faq-piedras .accordion-button{
  background: linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.0));
  color: rgba(248,247,243,.95); font-weight:700; letter-spacing:.2px;
  padding: 1rem 1.1rem; box-shadow:none !important;
}
#faq-piedras .accordion-button:not(.collapsed){
  background: linear-gradient(#0000,#0000) padding-box, var(--areya-gradient) border-box;
  border-bottom:1px solid transparent; color:#111;
}
#faq-piedras .accordion-button.collapsed{ border-bottom:1px solid rgba(255,255,255,.06); }
#faq-piedras .accordion-body{
  color: rgba(248,247,243,.85); padding: 1rem 1.1rem 1.2rem; line-height:1.6; font-weight:700;
}




/* ===================== CTA FINAL ===================== */
.parallax-cta{
  background-image: url("../img/fondos/img1.webp"); /* tu imagen 16:9 */
  background-attachment: fixed;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  color: var(--starlight);
  overflow: hidden;
}
.parallax-cta::after{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(900px 600px at 78% 22%, rgba(233,165,58,.16), transparent 60%),
    radial-gradient(1100px 700px at 18% 80%, rgba(107,74,124,.20), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.42));
  pointer-events:none; z-index:0;
}
#cta-final .cta-title{
  font-weight: 900; letter-spacing: -0.4px; line-height: 1.06;
  font-size: clamp(2rem, 4.2vw + .6rem, 80px); color: var(--starlight); margin: 0;
}
#cta-final .cta-lead{
  max-width: 62ch; margin-inline: auto;
  color: rgba(248,247,243,.92); font-weight: 500;
  font-size: clamp(1rem, .7vw + .92rem, 1.125rem);
  text-wrap: pretty;
}

#cta-final .container{ position: relative; z-index: 1; }

@media (max-width: 991.98px){
  .parallax-cta{ background-attachment: scroll; }
}
