* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: 'Manrope', sans-serif;
  background: #f8f3ee;
  color: #222;
  overflow-x: hidden;
}

img {
  max-width: 100%;
  display: block;
}


/* HEADER */

.header {
  width: 100%;
  padding: 18px 60px;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(10px);

  display: flex;
  justify-content: space-between;
  align-items: center;

  position: fixed;
  top: 0;
  z-index: 1000;

  transition: 0.3s;
}

.header.scrolled {
  background: rgba(0, 0, 0, 0.625);
  box-shadow: 0 10px 30px rgba(0,0,0,0.25);
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
}

.logo {
  width: 60px;
  height: 60px;
  object-fit: contain;
}

.brand h1 {
  font-family: 'Cormorant Garamond', serif;
  color: white;
  font-size: 28px;
}

.nav {
  display: flex;
  align-items: center;
  gap: 28px;
}

.nav a {
  color: white;
  text-decoration: none;
  font-size: 15px;
  position: relative;
  transition: 0.3s;
}

.nav a::after {
  content: "";
  width: 0;
  height: 2px;
  background: #d8b48c;

  position: absolute;
  left: 0;
  bottom: -5px;

  transition: 0.3s;
}

.nav a:hover {
  color: #d8b48c;
}

.nav a:hover::after {
  width: 100%;
}

.cart-btn {
  color: #000;
  background: #d8b48c;
  border: none;
  padding: 12px 18px;
  border-radius: 30px;
  cursor: pointer;
  font-weight: 700;
}

.menu-btn {
  display: none;
  background: none;
  border: none;
  color: white;
  font-size: 30px;
  cursor: pointer;
}

.premium-video{

    position: relative;

    width: 100%;

    height: 500px;

    overflow: hidden;

    display: flex;

    justify-content: center;

    align-items: center;

    text-align: center;

    background: #000;

}

.premium-bg-video{

    position: absolute;

    top: 0;
    left: 0;

    width: 100%;
    height: 100%;

    object-fit: cover;

    z-index: 1;

    opacity: 0.6;

}

.premium-overlay {
  position: absolute;
  inset: 0;

  background: rgba(0,0,0,0.7);

  backdrop-filter: blur(2px);
}

.premium-content{

    position: relative;

    z-index: 3;

    color: white;

    padding: 20px;

    max-width: 900px;

}

.premium-label{

    color: #d6b28a;

    letter-spacing: 4px;

    margin-bottom: 20px;

    font-size: 14px;

}

.premium-content h2{

    font-size: 70px;

    margin-bottom: 20px;

    line-height: 1.1;

}

.premium-content p{

    font-size: 22px;

    opacity: .95;

}

@media(max-width:768px){

    .premium-video{
        height: 400px;
    }

    .premium-content h2{
        font-size: 42px;
    }

    .premium-content p{
        font-size: 18px;
    }

}

/* HERO */

.hero {
  height: 100vh;
  position: relative;
  overflow: hidden;

  display: flex;
  align-items: center;

  padding: 0 60px;
  color: white;
}

.hero-slide {
  position: absolute;
  inset: 0;

  background-size: cover;
  background-position: center;

  opacity: 0;
  transform: scale(1.08);

  transition: 1.5s ease;
}

.hero-slide.active {
  opacity: 1;
  transform: scale(1);
}

.hero-overlay {
  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      90deg,
      rgba(0,0,0,0.75),
      rgba(0,0,0,0.25)
    );

  z-index: 1;
}

.hero-content {
  max-width: 750px;
  position: relative;
  z-index: 2;
}

.tag {
  color: #d8b48c;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.hero h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 72px;
  line-height: 1.1;

  margin: 20px 0;
}

.hero p {
  font-size: 20px;
  margin-bottom: 30px;
}

.hero-buttons {
  display: flex;
  gap: 15px;
  flex-wrap: wrap;
}

/* BOTONES */

.btn {
  display: inline-block;

  padding: 14px 32px;

  background: #d8b48c;
  color: #111;

  text-decoration: none;
  border-radius: 40px;

  font-weight: 600;

  border: none;
  cursor: pointer;

  transition: 0.3s;
}

.btn:hover {
  background: white;
  transform: translateY(-4px);
}

.btn-outline {
  background: transparent;
  border: 1px solid white;
  color: white;
}

.btn-outline:hover {
  background: white;
  color: black;
}

/* GENERAL */

section {
  padding: 100px 60px;
}

.section-title {
  text-align: center;
  margin-bottom: 50px;
}

.section-title span {
  color: #b48a5a;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 2px;
}

.section-title h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 45px;
  margin-top: 10px;
}

/* SOBRE */

.sobre-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

.sobre-text p {
  font-size: 18px;
  line-height: 1.8;
  margin-bottom: 20px;
}

.sobre-img img {
  border-radius: 25px;
  height: 520px;
  object-fit: cover;
  box-shadow: 0 15px 40px rgba(0,0,0,0.18);
}

/* FILTROS */

.filters {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-bottom: 45px;
  flex-wrap: wrap;
}

.filters input,
.filters select {
  padding: 14px 18px;
  border: 1px solid #ddd;
  border-radius: 30px;
  min-width: 260px;
  font-family: 'Manrope', sans-serif;
  outline: none;
}

/* PRODUCTOS */

.productos {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 35px;
}

.card {
  background: white;
  border-radius: 25px;
  overflow: hidden;

  box-shadow: 0 10px 30px rgba(0,0,0,0.12);

  transition: 0.4s;
}

.card:hover {
  transform: translateY(-12px);
}

.card-img {
  height: 430px;
  width: 100%;
  object-fit: cover;
  transition: 0.4s;
}

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

.card-info {
  padding: 25px;
}

.card-info h3 {
  font-size: 24px;
  margin-bottom: 10px;
}

.category {
  color: #b48a5a;
  font-weight: 600;
  margin-bottom: 10px;
}

.price {
  font-size: 22px;
  font-weight: 700;
  margin: 15px 0;
}

.options {
  display: flex;
  gap: 10px;
  margin: 12px 0;
  flex-wrap: wrap;
}

.options select {
  padding: 10px;
  border-radius: 10px;
  border: 1px solid #ddd;
}

.stock {
  font-size: 14px;
  color: #555;
  margin-bottom: 15px;
}

.add-btn {
  width: 100%;
  background: #111;
  color: white;
}

.add-btn:hover {
  background: #d8b48c;
  color: #111;
}

/* VIDEO */

.video-section {
  min-height: 430px;

  background:
    linear-gradient(
      rgba(0,0,0,0.65),
      rgba(0,0,0,0.65)
    ),
    url("img/fondo.jpg");

  background-attachment: fixed;
  background-size: cover;
  background-position: center;

  color: white;

  display: flex;
  align-items: center;
  justify-content: center;

  text-align: center;
}

.video-content span {
  color: #d8b48c;
  text-transform: uppercase;
  letter-spacing: 2px;
}

.video-content h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 50px;
  margin: 15px 0;
}

/* SERVICIOS */

.servicios {
  background: #111;
  color: white;
}

.servicios-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 25px;
}

.servicio {
  background: #1d1d1d;
  padding: 35px;
  border-radius: 25px;
  border: 1px solid #333;

  transition: 0.3s;
}

.servicio:hover {
  transform: translateY(-8px);
  border-color: #d8b48c;
}

.servicio h3 {
  color: #d8b48c;
  margin-bottom: 15px;
}

/* GALERÍA PREMIUM */

.galeria-filtros {
  display: flex;
  justify-content: center;
  gap: 15px;
  margin-bottom: 40px;
  flex-wrap: wrap;
}

.galeria-filter {
  border: none;
  padding: 12px 24px;
  border-radius: 30px;
  background: white;
  color: #111;
  cursor: pointer;
  font-weight: 600;
  transition: 0.3s;
}

.galeria-filter.active,
.galeria-filter:hover {
  background: #d8b48c;
}

.galeria-masonry {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;
  gap: 20px;
}

.galeria-item {
  position: relative;
  overflow: hidden;
  border-radius: 25px;
  cursor: pointer;
  opacity: 1;
  transform: scale(1);
  transition: 0.4s;
}

.galeria-item.hide {
  opacity: 0;
  transform: scale(0.9);
  pointer-events: none;
  display: none;
}

.galeria-item.tall {
  grid-row: span 2;
}

.galeria-item.wide {
  grid-column: span 2;
}

.galeria-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 0.5s;
}

.galeria-item:hover img {
  transform: scale(1.12);
  filter: brightness(0.65);
}

.galeria-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0,0,0,0.75),
    transparent
  );
  color: white;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 25px;
  opacity: 0;
  transition: 0.4s;
}

.galeria-item:hover .galeria-overlay {
  opacity: 1;
}

.galeria-overlay h3 {
  font-size: 24px;
  margin-bottom: 5px;
}

.galeria-overlay p {
  color: #d8b48c;
}

/* LIGHTBOX */

.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.92);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 999999;
}

.lightbox.active {
  display: flex;
}

.lightbox img {
  max-width: 90%;
  max-height: 85vh;
  border-radius: 20px;
}

.lightbox-close {
  position: absolute;
  top: 25px;
  right: 35px;
  color: white;
  font-size: 45px;
  cursor: pointer;
}

.galeria-img {
  cursor: pointer;
}

/* TESTIMONIOS */

.testimonios {
  background: #efe3d6;
}

.testimonios-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 25px;
}

.testimonio {
  background: white;
  padding: 35px;
  border-radius: 25px;

  box-shadow: 0 10px 25px rgba(0,0,0,0.08);
}

.testimonio p {
  font-style: italic;
  margin-bottom: 20px;
}

/* CONTACTO */

.contacto {
  background: #111;
  color: white;
}

.contacto-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
}

.contacto-info h3 {
  font-size: 32px;
  margin-bottom: 20px;
}

.contacto-info p {
  margin-bottom: 15px;
}

.formulario {
  background: white;
  padding: 35px;
  border-radius: 25px;
}

.formulario input,
.formulario textarea {
  width: 100%;
  padding: 15px;
  margin-bottom: 18px;

  border: 1px solid #ddd;
  border-radius: 12px;

  font-family: 'Manrope', sans-serif;
}

.formulario textarea {
  height: 150px;
  resize: none;
}


/* SCROLL */

.scroll-top {
  position: fixed;

  right: 25px;
  bottom: 90px;

  width: 45px;
  height: 45px;

  border: none;
  border-radius: 50%;

  background: #111;
  color: white;

  cursor: pointer;

  display: none;

  z-index: 999;
}


/* FOOTER */

footer {
  background: black;
  color: white;

  text-align: center;
  padding: 25px;
}

/* ANIMACIONES */

.reveal {
  opacity: 0;
  transform: translateY(45px);

  transition: 0.9s ease;
}

.reveal.active {
  opacity: 1;
  transform: translateY(0);
}

/* RESPONSIVE */

@media(max-width: 900px){

  .header{
    padding: 15px 25px;
  }

  .nav{
    position: absolute;
    top: 90px;
    right: 0;

    width: 100%;

    background: #111;

    flex-direction: column;

    display: none;
  }

  .nav.active{
    display: flex;
  }

  .nav a{
    padding: 18px;
    border-top: 1px solid #222;
    text-align: center;
  }

  .menu-btn{
    display: block;
  }

  .hero{
    padding: 0 25px;
    text-align: center;
    justify-content: center;
  }

  .hero h2{
    font-size: 42px;
  }

  section{
    padding: 80px 25px;
  }

  .sobre-content,
  .contacto-content,
  .productos,
  .servicios-grid,
  .testimonios-grid{
    grid-template-columns: 1fr;
  }

  .galeria-grid{
    grid-template-columns: repeat(2,1fr);
  }
}

@media(max-width: 500px){

  .brand h1{
    font-size: 20px;
  }

  .logo{
    width: 48px;
    height: 48px;
  }

  .hero h2{
    font-size: 35px;
  }

  .galeria-grid{
    grid-template-columns: 1fr;
  }
}
/* ADMIN */

.admin {
  background: #f8f3ee;
}

.admin-login,
.admin-panel {
  max-width: 900px;
  margin: auto;
  background: white;
  padding: 35px;
  border-radius: 25px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.1);
}

.admin-login h3,
.admin-panel h3 {
  margin-bottom: 20px;
  font-size: 26px;
}

.admin-login input,
.admin-panel input,
.admin-panel select,
.admin-panel textarea {
  width: 100%;
  padding: 15px;
  margin-bottom: 15px;
  border: 1px solid #ddd;
  border-radius: 12px;
  font-family: 'Manrope', sans-serif;
}

.admin-panel textarea {
  height: 120px;
  resize: none;
}

.admin-panel {
  display: none;
}

.admin-panel.active {
  display: block;
}

#loginError {
  margin-top: 15px;
  color: crimson;
  font-weight: 600;
}

.cancel-btn {
  background: #111;
  color: white;
  margin-left: 10px;
}

.admin-product {
  display: grid;
  grid-template-columns: 90px 1fr auto;
  gap: 15px;
  align-items: center;
  border-bottom: 1px solid #eee;
  padding: 18px 0;
}

.admin-product img {
  width: 90px;
  height: 110px;
  object-fit: cover;
  border-radius: 12px;
}

.admin-product h4 {
  font-size: 18px;
}

.admin-product p {
  color: #555;
  font-size: 14px;
}

.admin-actions {
  display: flex;
  gap: 8px;
}

.admin-actions button {
  border: none;
  padding: 9px 13px;
  border-radius: 20px;
  cursor: pointer;
  font-weight: 600;
}

.edit-btn {
  background: #d8b48c;
  color: #111;
}

.delete-btn {
  background: crimson;
  color: white;
}

@media(max-width: 700px) {
  .admin-product {
    grid-template-columns: 1fr;
  }

  .admin-actions {
    flex-wrap: wrap;
  }

  .cancel-btn {
    margin-left: 0;
    margin-top: 10px;
  }
}

/* ADMIN FIREBASE */

.admin-page {
  min-height: 100vh;
  padding: 120px 25px;
  background: #f8f3ee;
}

.admin-box,
.admin-dashboard {
  max-width: 1000px;
  margin: auto;
  background: white;
  padding: 35px;
  border-radius: 25px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.12);
}

.admin-box h2,
.admin-dashboard h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 38px;
  margin-bottom: 15px;
}

.admin-box p {
  margin-bottom: 20px;
  color: #555;
}

.admin-box input,
.admin-form input,
.admin-form select,
.admin-form textarea {
  width: 100%;
  padding: 15px;
  margin-bottom: 15px;
  border: 1px solid #ddd;
  border-radius: 12px;
  font-family: 'Manrope', sans-serif;
}

.admin-form textarea {
  height: 120px;
  resize: none;
}

.admin-dashboard {
  display: none;
}

.admin-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 25px;
  gap: 15px;
}

.admin-cancel {
  background: #111;
  color: white;
  margin-left: 10px;
}

#loginMessage {
  margin-top: 15px;
  color: crimson;
  font-weight: 600;
}

#adminProductsList {
  margin-top: 25px;
}

.admin-product {
  display: grid;
  grid-template-columns: 90px 1fr auto;
  gap: 15px;
  align-items: center;
  border-bottom: 1px solid #eee;
  padding: 18px 0;
}

.admin-product img {
  width: 90px;
  height: 110px;
  object-fit: cover;
  border-radius: 12px;
}

.admin-product h4 {
  font-size: 18px;
}

.admin-product p {
  color: #555;
  font-size: 14px;
}

.admin-actions {
  display: flex;
  gap: 8px;
}

.admin-actions button {
  border: none;
  padding: 9px 13px;
  border-radius: 20px;
  cursor: pointer;
  font-weight: 600;
}

.edit-btn {
  background: #d8b48c;
  color: #111;
}

.delete-btn {
  background: crimson;
  color: white;
}

@media(max-width: 700px) {
  .admin-top {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-product {
    grid-template-columns: 1fr;
  }

  .admin-cancel {
    margin-left: 0;
    margin-top: 10px;
  }
}

/* OPINIONES INTERACTIVAS */

.opinion-form-box {
  max-width: 650px;
  margin: 50px auto 0;
  background: white;
  padding: 35px;
  border-radius: 25px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.1);
}

.opinion-form-box h3 {
  font-size: 28px;
  margin-bottom: 20px;
  text-align: center;
}

#opinionForm input,
#opinionForm select,
#opinionForm textarea {
  width: 100%;
  padding: 15px;
  margin-bottom: 16px;
  border: 1px solid #ddd;
  border-radius: 12px;
  font-family: 'Manrope', sans-serif;
}

#opinionForm textarea {
  height: 130px;
  resize: none;
}

#opinionMessage {
  margin-top: 15px;
  text-align: center;
  color: #b48a5a;
  font-weight: 600;
}

.stars {
  color: #d8b48c;
  margin-bottom: 12px;
  font-size: 18px;
}

.admin-opinion {
  background: #f8f3ee;
  padding: 22px;
  border-radius: 18px;
  margin-bottom: 18px;
}

.admin-opinion h4 {
  font-size: 18px;
  margin-bottom: 8px;
}

.admin-opinion p {
  margin-bottom: 10px;
  color: #555;
}

.admin-tabs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 30px;
}

.admin-tab {
  border: none;
  padding: 12px 18px;
  border-radius: 30px;
  background: #f1e5d8;
  cursor: pointer;
  font-weight: 600;
}

.admin-tab.active {
  background: #111;
  color: white;
}

.admin-section {
  display: none;
}

.admin-section.active {
  display: block;
}

.admin-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 25px;
  margin-top: 25px;
}

.stat-card {
  background: #f8f3ee;
  padding: 30px;
  border-radius: 22px;
  text-align: center;
}

.stat-card h3 {
  font-size: 42px;
  color: #b48a5a;
}

.stat-card p {
  margin-top: 8px;
  color: #555;
  font-weight: 600;
}

@media(max-width: 700px) {
  .admin-stats {
    grid-template-columns: 1fr;
  }
}

.header {
  height: 90px;
  padding: 0 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.brand-center {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.menu-btn {
  display: block !important;
  order: 1;
}

.brand {
  order: 2;
}

.cart-btn {
  order: 3;
  margin-left: auto;
}

.nav {
  position: fixed !important;
  top: 0;
  left: -320px;
  width: 300px;
  height: 100vh;
  background: #111;
  flex-direction: column;
  padding: 120px 35px;
  gap: 25px;
  transition: .4s;
}

.nav.active {
  left: 0;
}

.intro-screen {
  position: fixed;
  inset: 0;
  background: #000;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 20000;
  animation: introFade 1.2s ease forwards;
  animation-delay: 3s;
}

.intro-brand {
  display: flex;
  align-items: center;
  gap: 25px;
  overflow: hidden;
  position: relative;
}

.intro-brand::after{

  content:"";

  position:absolute;

  left:0;
  top:0;

  width:260px;
  height:100%;

  background:#000;

  z-index:2;

  pointer-events:none;

}

.intro-logo{

  width:230px;

  position:relative;

  z-index:3;

  opacity:0;

  transform:scale(.85);

  animation:logoEnter 1.2s ease forwards;

}

.intro-text{

  color:#fff;

  font-family:'Cormorant Garamond', serif;

  font-size:54px;

  position:relative;

  z-index:1;

  opacity:0;

  transform:translateX(-220px);

  animation:textSlideRight 1.3s ease forwards;

  animation-delay:1s;

}

@keyframes logoEnter {
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes textSlideRight {
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes introFade {
  to {
    opacity: 0;
    visibility: hidden;
  }
}

@media(max-width: 768px) {
  .intro-logo {
    width: 150px;
  }

  .intro-text {
    font-size: 32px;
    transform: translateX(-50px);
  }
}

.floating-cart {
  position: fixed;
  right: 25px;
  bottom: 25px;
  z-index: 9999;

  width: 72px;
  height: 72px;
  border-radius: 50%;

  border: none;
  background: #d8b48c;
  color: #000;

  font-size: 22px;
  font-weight: 700;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;

  box-shadow: 0 12px 30px rgba(0,0,0,.25);
  cursor: pointer;
}

/* ARREGLO INTRO EN CELULAR */

@media (max-width: 768px) {

  .intro-brand {
    gap: 10px;
    transform: scale(0.75);
  }

  .intro-logo {
    width: 120px;
    max-width: 40vw;
  }

  .intro-text {
    font-size: 30px;
    white-space: nowrap;
  }

  .header .brand {
    opacity: 0;
    animation: headerBrandShow .4s ease forwards;
    animation-delay: 3.2s;
  }

}
@media (max-width: 768px) {

  @keyframes introMoveToHeader {
    to {
      transform: scale(0.75);
    }
  }

}

@media (max-width: 768px) {

  .intro-brand {
    gap: 12px;
    overflow: visible;
    transform: scale(0.8);
  }

  .intro-brand::after {
    display: none;
  }

  .intro-logo {
    width: 145px;
  }

  .intro-text {
    font-size: 34px;
    white-space: nowrap;
    transform: translateX(0);
  }

}

.galeria-masonry {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 210px;
  gap: 18px;
}

.galeria-item {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  cursor: pointer;
}

.galeria-item.normal {
  grid-column: span 1;
  grid-row: span 1;
}

.galeria-item.tall {
  grid-row: span 2;
}

.galeria-item.wide {
  grid-column: span 2;
}

.galeria-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.9);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 99999;
}

.lightbox.active {
  display: flex;
}

.lightbox img {
  max-width: 90%;
  max-height: 85vh;
  border-radius: 18px;
}

.lightbox-close {
  position: absolute;
  top: 25px;
  right: 35px;
  color: white;
  font-size: 42px;
  cursor: pointer;
}

@media(max-width: 768px) {
  .galeria-masonry {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 170px;
  }

  .galeria-item.wide,
  .galeria-item.tall {
    grid-column: span 2;
    grid-row: span 1;
  }
}

.galeria-item {
  cursor: pointer;
}

.lightbox {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0,0,0,.92) !important;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 999999 !important;
}

.lightbox.active {
  display: flex !important;
}

.lightbox img {
  max-width: 90% !important;
  max-height: 85vh !important;
  border-radius: 20px;
}

.lightbox-close {
  position: absolute;
  top: 25px;
  right: 35px;
  color: white;
  font-size: 45px;
  cursor: pointer;
}

/* =============================== */
/* MOBILE PRO - LAOS STUDIO */
/* =============================== */

@media (max-width: 768px) {

  html,
  body {
    width: 100%;
    overflow-x: hidden;
  }

  body {
    background: #f8f3ee;
  }

  section {
    padding: 75px 18px;
  }

  /* HEADER */

  .header {
    height: 72px;
    padding: 0 16px;
    background: rgba(0,0,0,0.82);
    backdrop-filter: blur(14px);
  }

  .menu-btn {
    width: 42px;
    height: 42px;
    font-size: 22px;
    background: #d8b48c;
    color: #111;
    border-radius: 50%;
  }

  .brand-center {
    gap: 8px;
    max-width: 190px;
  }

  .logo {
    width: 38px;
    height: 38px;
  }

  .brand h1 {
    font-size: 18px;
    white-space: nowrap;
  }

  .nav {
    width: 78%;
    max-width: 290px;
    height: 100vh;
    left: -100%;
    top: 0;
    padding: 105px 28px;
    background: rgba(0,0,0,0.96);
    gap: 22px;
    box-shadow: 10px 0 30px rgba(0,0,0,0.35);
  }

  .nav.active {
    left: 0;
  }

  .nav a {
    font-size: 18px;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }

  /* HERO */

  .hero {
    min-height: 100vh;
    padding: 110px 20px 60px;
    justify-content: center;
    text-align: center;
  }

  .hero-overlay {
    background: linear-gradient(
      rgba(0,0,0,0.72),
      rgba(0,0,0,0.55)
    );
  }

  .hero-content {
    max-width: 100%;
  }

  .tag {
    font-size: 12px;
    letter-spacing: 2px;
  }

  .hero h2 {
    font-size: 38px;
    line-height: 1.12;
    margin: 18px 0;
  }

  .hero p {
    font-size: 16px;
    line-height: 1.7;
    margin-bottom: 28px;
  }

  .hero-buttons {
    flex-direction: column;
    gap: 12px;
  }

  .hero-buttons .btn {
    width: 100%;
    text-align: center;
  }

  .btn {
    width: 100%;
    padding: 14px 24px;
    text-align: center;
  }

  /* TITULOS */

  .section-title {
    margin-bottom: 38px;
  }

  .section-title span {
    font-size: 12px;
    letter-spacing: 2px;
  }

  .section-title h2 {
    font-size: 32px;
    line-height: 1.15;
  }

  /* SOBRE */

  .sobre-content {
    grid-template-columns: 1fr;
    gap: 35px;
  }

  .sobre-text {
    text-align: center;
  }

  .sobre-text p {
    font-size: 16px;
    line-height: 1.8;
  }

.sobre-img {
  width: 100%;
  overflow: hidden;
  border-radius: 24px;
}

.sobre-img img {
  width: 100%;
  height: 100%;
  min-height: 520px;

  display: block;

  object-fit: cover;
  object-position: center;

  border-radius: 24px;
}

  /* PRODUCTOS */

  .filters {
    flex-direction: column;
    gap: 12px;
    margin-bottom: 35px;
  }

  .filters input,
  .filters select {
    width: 100%;
    min-width: unset;
  }

  .productos {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .card {
    border-radius: 24px;
  }

  .card-img {
    height: 390px;
  }

  .card-info {
    padding: 22px;
  }

  .card-info h3 {
    font-size: 23px;
  }

  .price {
    font-size: 22px;
  }

  .options select {
    flex: 1;
  }

  /* VIDEO PREMIUM */

  .premium-video {
    height: 390px;
  }

  .premium-content {
    padding: 22px;
  }

  .premium-label {
    font-size: 11px;
    letter-spacing: 3px;
  }

  .premium-content h2 {
    font-size: 34px;
    line-height: 1.15;
  }

  .premium-content p {
    font-size: 16px;
    line-height: 1.6;
  }

  /* SERVICIOS */

  .servicios-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .servicio {
    padding: 28px;
    border-radius: 22px;
    text-align: center;
  }

  .servicio h3 {
    font-size: 22px;
  }

  .servicio p {
    font-size: 15px;
    line-height: 1.7;
  }

  /* GALERÍA */

  .galeria-masonry {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 180px;
    gap: 12px;
  }

  .galeria-item {
    border-radius: 18px;
  }

  .galeria-item.wide,
  .galeria-item.tall {
    grid-column: span 2;
    grid-row: span 1;
  }

  .galeria-overlay {
    opacity: 1;
    padding: 16px;
    background: linear-gradient(
      to top,
      rgba(0,0,0,0.72),
      rgba(0,0,0,0.05)
    );
  }

  .galeria-overlay h3 {
    font-size: 17px;
  }

  .galeria-overlay p {
    font-size: 13px;
  }

  /* OPINIONES */

  .testimonios-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .testimonio {
    padding: 28px;
    border-radius: 22px;
  }

  .opinion-form-box {
    padding: 26px;
    border-radius: 22px;
  }

  .opinion-form-box h3 {
    font-size: 24px;
  }

  /* CONTACTO */

  .contacto-content {
    grid-template-columns: 1fr;
    gap: 35px;
  }

  .contacto-info {
    text-align: center;
  }

  .contacto-info h3 {
    font-size: 26px;
  }

  .contacto-info p {
    font-size: 15px;
    line-height: 1.7;
  }

  .formulario {
    padding: 26px;
    border-radius: 22px;
  }

  .formulario input,
  .formulario textarea {
    font-size: 15px;
  }

  /* CARRITO */

  .floating-cart {
    width: 64px;
    height: 64px;
    right: 18px;
    bottom: 18px;
    font-size: 21px;
    box-shadow: 0 12px 30px rgba(0,0,0,0.3);
  }

  .cart-panel {
    width: 94%;
    max-width: 94%;
    padding: 22px;
  }

  .cart-item {
    gap: 10px;
  }

  .cart-item img {
    width: 70px;
    height: 90px;
  }

  .cart-item-info h4 {
    font-size: 15px;
  }

  .cart-footer h3 {
    font-size: 21px;
  }

  /* LIGHTBOX */

  .lightbox img {
    max-width: 94%;
    max-height: 78vh;
  }

  .lightbox-close {
    top: 18px;
    right: 24px;
    font-size: 40px;
  }

  /* INTRO */

  .intro-brand {
    gap: 10px;
    transform: scale(0.72);
    overflow: visible;
  }

  .intro-brand::after {
    display: none;
  }

  .intro-logo {
    width: 140px;
  }

  .intro-text {
    font-size: 34px;
    white-space: nowrap;
    transform: translateX(0);
  }

  /* FOOTER */

  footer {
    padding: 24px 18px;
    font-size: 14px;
    line-height: 1.6;
  }
}

/* FIX DEFINITIVO LOGO HEADER MÓVIL */

@media (max-width: 768px) {

  .header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    height: 76px !important;
    padding: 0 16px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .header .brand-center {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    z-index: 10002 !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .header .brand-center .logo {
    display: block !important;
    width: 44px !important;
    height: 44px !important;
    object-fit: contain !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .header .brand-center h1 {
    display: block !important;
    color: #fff !important;
    font-size: 18px !important;
    white-space: nowrap !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .menu-btn {
    position: absolute !important;
    left: 16px !important;
    z-index: 10003 !important;
  }
}

/* CARRITO EN HEADER */

.floating-cart {
  display: none !important;
}

.cart-btn {
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10003;

  background: #d8b48c;
  color: #000;
  border: none;
  border-radius: 30px;
  padding: 10px 16px;
  font-weight: 700;
  cursor: pointer;
}

@media (max-width: 768px) {
  .cart-btn {
    right: 14px;
    padding: 9px 12px;
    font-size: 15px;
  }
}


/* SOBRE NOSOTRAS ORIGINAL */

.sobre-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;

  align-items: center;
}
.sobre-img {
  width: 100%;
  max-width: 520px;

  justify-self: end;

  margin-top: 0 !important;

  overflow: hidden;
  border-radius: 24px;
}


/* MÓVIL */

@media (max-width: 768px) {

  .sobre-content {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .sobre-img {
    justify-self: center;
    max-width: 100%;
  }

}
.sobre-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.sobre-text .btn {
  margin-top: 30px;
  align-self: flex-start;
}

/* SOBRE NOSOTRAS PREMIUM */

.sobre-premium {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 70px;
  align-items: center;
}

.sobre-premium .sobre-img {
  position: relative;
  max-width: 520px;
  height: 620px;
  border-radius: 32px;
  overflow: hidden;
  justify-self: end;
  box-shadow: 0 25px 60px rgba(0,0,0,.18);
}

.sobre-premium .sobre-img::before {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(255,255,255,.55);
  border-radius: 24px;
  z-index: 2;
  pointer-events: none;
}

.sobre-premium .sobre-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.sobre-premium .sobre-text {
  max-width: 760px;
}

.sobre-label {
  display: inline-block;
  color: #b48a5a;
  letter-spacing: 4px;
  text-transform: uppercase;
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 18px;
}

.sobre-text h3 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 46px;
  line-height: 1.12;
  margin-bottom: 25px;
}

.sobre-text p {
  font-size: 18px;
  line-height: 1.9;
  color: #333;
  margin-bottom: 18px;
}

.sobre-features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin: 35px 0;
}

.sobre-features div {
  background: #fff;
  padding: 22px;
  border-radius: 22px;
  box-shadow: 0 14px 35px rgba(0,0,0,.08);
}

.sobre-features strong {
  display: block;
  color: #d8b48c;
  font-size: 28px;
  font-family: 'Cormorant Garamond', serif;
}

.sobre-features span {
  font-size: 14px;
  font-weight: 600;
}

.sobre-btn {
  width: auto;
}

@media (max-width: 768px) {
  .sobre-premium {
    grid-template-columns: 1fr;
    gap: 35px;
  }

  .sobre-premium .sobre-img {
    order: 2;
    height: 430px;
    justify-self: center;
  }

  .sobre-premium .sobre-text {
    order: 1;
    text-align: center;
  }

  .sobre-text h3 {
    font-size: 32px;
  }

  .sobre-text p {
    font-size: 16px;
  }

  .sobre-features {
    grid-template-columns: 1fr;
  }

  .sobre-btn {
    width: 100%;
  }
}

/* HERO PREMIUM */

.hero-premium .hero-overlay {
  background:
    linear-gradient(
      90deg,
      rgba(0,0,0,.82),
      rgba(0,0,0,.45),
      rgba(0,0,0,.2)
    );
}

.hero-premium-content {
  max-width: 820px;
}

.hero-premium-content h2 {
    font-family: 'Cormorant Garamond', serif;
  font-size: 65px;
}

.hero-mini-info {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin: 28px 0;
}

.hero-mini-info span {
  background: rgba(255,255,255,.12);
  color: #fff;
  padding: 10px 18px;
  border-radius: 30px;
  backdrop-filter: blur(8px);
  font-size: 14px;
}

@media (max-width: 768px) {
  .hero-premium-content h2 {
    font-size: 40px;
  }

  .hero-mini-info {
    justify-content: center;
  }

  .hero-mini-info span {
    font-size: 13px;
  }
}

/* COLECCIÓN PREMIUM */

.coleccion-premium {
  background: #f8f3ee;
}

.section-subtitle {
  max-width: 650px;
  margin: 18px auto 0;
  color: #666;
  font-size: 17px;
  line-height: 1.7;
}

.collection-categories {
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 35px;
}

.collection-filter {
  border: none;
  padding: 13px 26px;
  border-radius: 40px;
  background: #fff;
  color: #111;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 10px 25px rgba(0,0,0,.08);
  transition: .3s;
}

.collection-filter.active,
.collection-filter:hover {
  background: #111;
  color: #fff;
  transform: translateY(-3px);
}

.collection-search {
  margin-bottom: 50px;
}

.premium-product-card {
  position: relative;
  border-radius: 28px;
  overflow: hidden;
}

.product-img-box {
  position: relative;
  overflow: hidden;
}

.product-badge {
  position: absolute;
  top: 18px;
  left: 18px;
  background: rgba(0,0,0,.78);
  color: #fff;
  padding: 8px 16px;
  border-radius: 30px;
  font-size: 13px;
  font-weight: 700;
}

.product-label {
  color: #b48a5a;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 8px;
}

.product-description {
  color: #555;
  line-height: 1.7;
}

.empty-products {
  grid-column: 1 / -1;
  text-align: center;
  font-size: 18px;
  color: #666;
  padding: 40px;
}

@media(max-width: 768px) {
  .collection-categories {
    gap: 10px;
  }

  .collection-filter {
    padding: 11px 18px;
    font-size: 14px;
  }

  .section-subtitle {
    font-size: 15px;
  }
}

/* =============================== */
/* GALERÍA PREMIUM EDITORIAL */
/* =============================== */

.galeria {
  background:
    linear-gradient(
      to bottom,
      #f8f3ee,
      #ffffff
    );

  position: relative;
}

.galeria::before {
  content: "";
  position: absolute;

  top: 0;
  left: 50%;

  transform: translateX(-50%);

  width: 300px;
  height: 300px;

  background: rgba(212, 180, 140, 0.12);

  filter: blur(90px);
  border-radius: 50%;
}

.galeria-masonry {
  position: relative;
  z-index: 2;

  display: grid;

  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;

  gap: 18px;
}

.galeria-item {
  position: relative;

  overflow: hidden;
  border-radius: 28px;

  cursor: pointer;

  background: #000;

  box-shadow:
    0 18px 45px rgba(0,0,0,.12);

  transition: .45s ease;
}

.galeria-item::after {
  content: "";

  position: absolute;
  inset: 0;

  background:
    linear-gradient(
      to top,
      rgba(0,0,0,.72),
      rgba(0,0,0,.12),
      transparent
    );

  opacity: .9;

  transition: .4s;
}

.galeria-item:hover {
  transform:
    translateY(-8px)
    scale(1.015);
}

.galeria-item:hover::after {
  opacity: 1;
}

.galeria-item img {
  width: 100%;
  height: 100%;

  object-fit: cover;

  transition: transform .7s ease;
}

.galeria-item:hover img {
  transform: scale(1.08);
}

/* TAMAÑOS */

.galeria-item.wide {
  grid-column: span 2;
}

.galeria-item.tall {
  grid-row: span 2;
}

.galeria-item.large {
  grid-column: span 2;
  grid-row: span 2;
}

/* OVERLAY */

.galeria-overlay {
  position: absolute;

  left: 0;
  bottom: 0;

  width: 100%;

  z-index: 5;

  padding: 24px;

  color: #fff;

  transform: translateY(12px);

  opacity: 0;

  transition: .4s ease;
}

.galeria-item:hover .galeria-overlay {
  opacity: 1;
  transform: translateY(0);
}

.galeria-overlay h3 {
  font-size: 24px;
  margin-bottom: 8px;

  font-family: 'Cormorant Garamond', serif;
}

.galeria-overlay p {
  font-size: 14px;
  line-height: 1.6;

  color: rgba(255,255,255,.82);
}

/* EFECTO PREMIUM */

.galeria-item::before {
  content: "";

  position: absolute;
  inset: 0;

  border: 1px solid rgba(255,255,255,.15);

  border-radius: 28px;

  z-index: 4;

  margin: 14px;

  pointer-events: none;
}

/* LIGHTBOX */

.lightbox {
  position: fixed;
  inset: 0;

  background: rgba(0,0,0,.95);

  display: none;

  align-items: center;
  justify-content: center;

  z-index: 999999;

  backdrop-filter: blur(8px);
}

.lightbox.active {
  display: flex;
}

.lightbox img {
  max-width: 90%;
  max-height: 88vh;

  border-radius: 22px;

  box-shadow:
    0 20px 60px rgba(0,0,0,.45);

  animation: zoomLightbox .35s ease;
}

@keyframes zoomLightbox {
  from {
    transform: scale(.88);
    opacity: 0;
  }

  to {
    transform: scale(1);
    opacity: 1;
  }
}

.lightbox-close {
  position: absolute;

  top: 30px;
  right: 40px;

  color: #fff;

  font-size: 52px;

  cursor: pointer;

  transition: .3s;
}

.lightbox-close:hover {
  transform: rotate(90deg);
}

/* MÓVIL */

@media(max-width:768px){

  .galeria-masonry{
    grid-template-columns: repeat(2,1fr);
    grid-auto-rows: 170px;

    gap: 12px;
  }

  .galeria-item.large,
  .galeria-item.wide,
  .galeria-item.tall{
    grid-column: span 2;
    grid-row: span 1;
  }

  .galeria-overlay{
    opacity: 1;
    transform: none;

    padding: 16px;
  }

  .galeria-overlay h3{
    font-size: 18px;
  }

  .galeria-overlay p{
    font-size: 12px;
  }

}

/* OPINIONES PREMIUM */

.opiniones-premium {
  background: linear-gradient(135deg, #efe3d6, #f8f3ee);
}

.opinion-callout {
  max-width: 720px;
  margin: 55px auto 0;
  background: #111;
  color: white;
  padding: 40px;
  border-radius: 30px;
  box-shadow: 0 20px 55px rgba(0,0,0,.18);
  text-align: center;
}

.opinion-callout h3 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 34px;
  margin-bottom: 10px;
}

.opinion-callout p {
  color: rgba(255,255,255,.78);
  margin-bottom: 25px;
}

#opinionForm input,
#opinionForm select,
#opinionForm textarea {
  background: white;
  border: none;
  border-radius: 16px;
  padding: 16px;
}

.opinion-btn {
  width: 100%;
  margin-top: 5px;
  background: #d8b48c;
  color: #111;
}

.opinion-btn:hover {
  background: white;
}

.testimonio {
  position: relative;
  overflow: hidden;
}

.testimonio::before {
  content: "“";
  position: absolute;
  top: -25px;
  left: 20px;
  font-size: 100px;
  color: rgba(216,180,140,.25);
  font-family: 'Cormorant Garamond', serif;
}

@media(max-width: 768px) {
  .opinion-callout {
    padding: 28px;
    border-radius: 24px;
  }

  .opinion-callout h3 {
    font-size: 28px;
  }
}

/* OPINIONES NIVEL PREMIUM */

.opiniones-premium {
  position: relative;
  background:
    radial-gradient(circle at top left, rgba(216,180,140,.35), transparent 35%),
    linear-gradient(135deg, #f8f3ee, #efe3d6);
  overflow: hidden;
}

.opiniones-premium .section-title h2 {
  font-size: 52px;
}

.testimonios-grid {
  align-items: stretch;
}

.testimonio {
  position: relative;
  background: rgba(255,255,255,.86);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(216,180,140,.35);
  padding: 38px;
  border-radius: 30px;
  box-shadow: 0 22px 55px rgba(0,0,0,.10);
  transition: .35s ease;
}

.testimonio:hover {
  transform: translateY(-8px);
  box-shadow: 0 28px 70px rgba(0,0,0,.16);
}

.testimonio::before {
  content: "“";
  position: absolute;
  top: -35px;
  left: 25px;
  font-size: 130px;
  color: rgba(216,180,140,.25);
  font-family: 'Cormorant Garamond', serif;
}

.testimonio p {
  position: relative;
  z-index: 2;
  font-size: 16px;
  line-height: 1.8;
  color: #333;
}

.testimonio h4 {
  margin-top: 20px;
  color: #111;
  font-weight: 700;
}

.stars {
  font-size: 22px;
  margin-bottom: 18px;
}

.opinion-callout {
  position: relative;
  max-width: 820px;
  margin: 70px auto 0;
  padding: 48px;
  border-radius: 36px;
  background:
    linear-gradient(145deg, #111, #1d1d1d);
  color: white;
  box-shadow: 0 30px 80px rgba(0,0,0,.28);
  overflow: hidden;
}

.opinion-callout::before {
  content: "★★★★★";
  position: absolute;
  top: 22px;
  right: 28px;
  color: rgba(216,180,140,.22);
  font-size: 34px;
  letter-spacing: 5px;
}

.opinion-callout h3 {
  font-size: 42px;
}

.opinion-callout p {
  max-width: 570px;
  margin: 0 auto 28px;
  line-height: 1.7;
}

.opinion-btn {
  font-size: 16px;
  letter-spacing: .5px;
  box-shadow: 0 15px 35px rgba(216,180,140,.25);
}

@media(max-width:768px) {
  .opiniones-premium .section-title h2 {
    font-size: 34px;
  }

  .testimonio {
    padding: 30px;
  }

  .opinion-callout {
    padding: 32px 24px;
  }

  .opinion-callout h3 {
    font-size: 30px;
  }
}

/* =============================== */
/* HEADER CART PREMIUM */
/* =============================== */

.header-cart {
  position: absolute;
  right: 18px;
  top: 50%;

  transform: translateY(-50%);

  display: flex;
  align-items: center;
  gap: 12px;

  padding: 10px 16px;

  border: none;
  border-radius: 50px;

  background:
    linear-gradient(
      135deg,
      #111,
      #1f1f1f
    );

  color: white;

  cursor: pointer;

  box-shadow:
    0 12px 30px rgba(0,0,0,.25);

  transition: .35s ease;

  z-index: 10005;
}

.header-cart:hover {
  transform:
    translateY(-50%)
    scale(1.04);

  box-shadow:
    0 18px 45px rgba(0,0,0,.35);
}

.cart-icon-wrap {
  position: relative;

  width: 48px;
  height: 48px;

  border-radius: 50%;

  display: flex;
  align-items: center;
  justify-content: center;

  background:
    linear-gradient(
      135deg,
      #d8b48c,
      #c89b68
    );

  font-size: 22px;

  color: #111;
}

.cart-icon-wrap span {
  position: absolute;

  top: -4px;
  right: -4px;

  width: 22px;
  height: 22px;

  border-radius: 50%;

  background: crimson;
  color: white;

  font-size: 12px;
  font-weight: 700;

  display: flex;
  align-items: center;
  justify-content: center;

  border: 2px solid white;
}

.cart-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.cart-text small {
  font-size: 11px;
  color: rgba(255,255,255,.65);
}

.cart-text strong {
  font-size: 15px;
  font-weight: 700;
}

/* EFECTO CUANDO HAY PRODUCTOS */

.header-cart.has-items .cart-icon-wrap {
  animation: cartPulse 1.2s infinite;
}

@keyframes cartPulse {

  0% {
    box-shadow: 0 0 0 rgba(216,180,140,.7);
  }

  50% {
    box-shadow:
      0 0 18px rgba(216,180,140,.9);
  }

  100% {
    box-shadow: 0 0 0 rgba(216,180,140,.7);
  }

}

/* MÓVIL */

@media(max-width:768px){

  .header-cart{
    right: 12px;

    padding: 8px 12px;
    gap: 8px;
  }

  .cart-icon-wrap{
    width: 42px;
    height: 42px;

    font-size: 18px;
  }

  .cart-text{
    display: none;
  }

}


/* FIX DEFINITIVO LOGO HEADER */

.header .brand-center,
.header .brand-center .logo,
.header .brand-center h1 {
  display: flex !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.header .brand-center {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  align-items: center !important;
  gap: 10px !important;
  z-index: 99999 !important;
}

.header .brand-center .logo {
  width: 55px !important;
  height: 55px !important;
  object-fit: contain !important;
  filter: none !important;
}

.header .brand-center h1 {
  color: #fff !important;
  font-size: 26px !important;
  white-space: nowrap !important;
}

/* BRILLO ELEGANTE LOGO */

.header .brand-center .logo {
  filter:
    drop-shadow(0 0 8px rgba(216,180,140,.28));
    
  transition: .35s ease;
}

.header .brand-center .logo:hover {
  transform: scale(1.05);

  filter:
    drop-shadow(0 0 14px rgba(216,180,140,.55));
}

.header .brand-center h1 {
  text-shadow:
    0 0 10px rgba(216,180,140,.12);
}

/* BRILLO MÁS VISIBLE DEL LOGO */

.header .brand-center .logo {
  filter:
    drop-shadow(0 0 10px rgba(220, 207, 86, 0.9))
    drop-shadow(0 0 22px rgba(216,180,140,.6))
    drop-shadow(0 0 38px rgba(216,180,140,.35)) !important;
}

.header .brand-center h1 {
  color: #fff !important;
  text-shadow:
    0 0 8px rgba(216,180,140,.8),
    0 0 18px rgba(216,180,140,.45) !important;
}

.logo-texto{
    display: flex;
    flex-direction: column;
    line-height: 1;
}

.subtitulo-logo{
    position: absolute;
    top: 58px;
    left: 52%;
    transform: translateX(-50%);
    
    font-size: 10px;
    letter-spacing: 1px;
    color: rgba(255,255,255,0.75);

    text-transform: uppercase;
    font-weight: 300;
}
.subtitulo-logo{
    display: flex;
    align-items: center;
    gap: 10px;
}

.subtitulo-logo span{
    width: 30px;
    height: 1px;
    background: rgba(255,255,255,0.4);
}

header{
    backdrop-filter: blur(12px);
    background: rgba(0,0,0,0.45);
}

/* INTRO SIGNATURE PREMIUM */

.intro-signature {
  position: fixed;
  inset: 0;
  z-index: 999999;
  background:
    radial-gradient(circle at center, rgba(216,180,140,.16), transparent 32%),
    linear-gradient(135deg, #020202, #100b07 55%, #000);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.intro-signature.hide {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: 1s ease;
}

.signature-orb {
  position: absolute;
  width: 520px;
  height: 520px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(216,180,140,.22), transparent 65%);
  filter: blur(35px);
  animation: orbMove 5s ease-in-out infinite alternate;
}

.signature-lines {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, transparent 49.8%, rgba(216,180,140,.22) 50%, transparent 50.2%),
    linear-gradient(0deg, transparent 49.8%, rgba(216,180,140,.08) 50%, transparent 50.2%);
  opacity: .35;
}

.signature-content {
  position: relative;
  z-index: 3;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  animation: signatureIn 1.2s ease forwards;
}

.signature-kicker {
  color: #d8b48c;
  font-size: 13px;
  letter-spacing: 12px;
  margin-bottom: 30px;
}

.signature-logo {
  width: 170px;
  margin-bottom: 22px;
  filter:
    drop-shadow(0 0 14px rgba(255,255,255,.22))
    drop-shadow(0 0 34px rgba(216,180,140,.28));
  animation: logoFloat 3.5s ease-in-out infinite;
}

.signature-content h1 {
  color: #fff;
  font-family: 'Cormorant Garamond', serif;
  font-size: 78px;
  line-height: 1;
  text-shadow: 0 0 35px rgba(216,180,140,.22);
}

.signature-content p {
  margin-top: 22px;
  color: rgba(255,255,255,.78);
  font-size: 13px;
  letter-spacing: 10px;
}

.signature-btn {
  margin-top: 42px;
  padding: 15px 58px;
  background: transparent;
  border: 1px solid rgba(216,180,140,.55);
  color: #e8c79d;
  letter-spacing: 6px;
  cursor: pointer;
  transition: .35s ease;
}

.signature-btn:hover {
  background: rgba(216,180,140,.12);
  color: #fff;
  transform: translateY(-4px);
  box-shadow: 0 0 35px rgba(216,180,140,.28);
}

@keyframes signatureIn {
  from {
    opacity: 0;
    transform: translateY(35px) scale(.95);
    filter: blur(8px);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}

@keyframes logoFloat {
  0%,100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-9px);
  }
}

@keyframes orbMove {
  from {
    transform: translate(-70px, -40px) scale(.95);
  }

  to {
    transform: translate(70px, 40px) scale(1.08);
  }
}

@media(max-width:768px) {
  .signature-kicker {
    font-size: 11px;
    letter-spacing: 7px;
  }

  .signature-logo {
    width: 125px;
  }

  .signature-content h1 {
    font-size: 48px;
  }

  .signature-content p {
    font-size: 10px;
    letter-spacing: 5px;
  }

  .signature-btn {
    padding: 14px 38px;
    font-size: 12px;
  }
}

/* HEADER PREMIUM REAL */

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 92px;
  padding: 0 46px;
  z-index: 9999;

  display: flex;
  align-items: center;
  justify-content: space-between;

  background: rgba(5, 5, 5, 0.52);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);

  border-bottom: 1px solid rgba(216, 180, 140, 0.18);
  box-shadow: 0 14px 45px rgba(0,0,0,.35);
}

.header::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 42%;
  height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, transparent, rgba(216,180,140,.8), transparent);
}

/* MENÚ */

.menu-btn {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  color: white;
  font-size: 28px;
  cursor: pointer;
  transition: .35s ease;
}

.menu-btn:hover {
  background: rgba(216,180,140,.12);
  box-shadow: 0 0 25px rgba(216,180,140,.18);
}

/* LOGO CENTRADO */

.brand-center {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  
  display: flex;
  align-items: center;
  gap: 16px;
}

.brand-center .logo {
  height: 68px;
  width: auto;
  filter:
    drop-shadow(0 0 10px rgba(255,255,255,.32))
    drop-shadow(0 0 28px rgba(216,180,140,.28));
}

.brand-center h1 {
  color: #fff;
  font-family: 'Cormorant Garamond', serif;
  font-size: 35px;
  font-weight: 700;
  line-height: 1;
  text-shadow: 0 0 18px rgba(216,180,140,.22);
}

/* SUBTÍTULO BAJO LOGO */

.subtitulo-logo {
  position: absolute;
  left: 50%;
  top: 62px;
  transform: translateX(-50%);

  display: flex;
  align-items: center;
  gap: 10px;

  color: rgba(255,255,255,.74);
  font-size: 9px;
  letter-spacing: 4px;
  font-weight: 300;
}

.subtitulo-logo span {
  width: 42px;
  height: 1px;
  background: rgba(216,180,140,.45);
}


/* CARRITO PREMIUM */

.header-cart {
  height: 62px;
  min-width: 150px;
  padding: 0 18px;

  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.09);
  background: rgba(255,255,255,.06);

  display: flex;
  align-items: center;
  gap: 12px;

  color: white;
  cursor: pointer;

  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);

  box-shadow:
    0 10px 30px rgba(0,0,0,.45),
    inset 0 0 24px rgba(255,255,255,.035);

  transition: .35s ease;
}

.header-cart:hover {
  transform: translateY(-3px);
  border-color: rgba(216,180,140,.35);
  box-shadow:
    0 14px 38px rgba(0,0,0,.55),
    0 0 28px rgba(216,180,140,.18);
}

.cart-icon-wrap {
  position: relative;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #e2b985;

  display: flex;
  align-items: center;
  justify-content: center;

  font-size: 20px;
}

#cartCount {
  position: absolute;
  top: -8px;
  right: -6px;

  width: 20px;
  height: 20px;
  border-radius: 50%;

  background: #ff3b5c;
  color: #fff;

  font-size: 12px;
  font-weight: 700;

  display: flex;
  align-items: center;
  justify-content: center;
}

.cart-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  line-height: 1.1;
}

.cart-text small {
  font-size: 11px;
  color: rgba(255,255,255,.72);
}

.cart-text strong {
  font-size: 16px;
}

/* MÓVIL */

@media (max-width: 768px) {
  .header {
    height: 82px;
    padding: 0 16px;
  }

  .brand-center .logo {
    height: 54px;
  }

  .brand-center h1 {
    font-size: 25px;
  }

  .subtitulo-logo {
    top: 56px;
    font-size: 7px;
    letter-spacing: 3px;
  }

  .subtitulo-logo span {
    width: 24px;
  }

  .header-cart {
    min-width: 58px;
    height: 54px;
    padding: 0 8px;
  }

  .cart-text {
    display: none;
  }

  .cart-icon-wrap {
    width: 38px;
    height: 38px;
  }

  .menu-btn {
    width: 48px;
    height: 48px;
    font-size: 25px;
  }
}

/* HEADER CINEMATIC */

.header{
    position: fixed;
    top: 0;
    left: 0;

    width: 100%;
    height: 92px;

    padding: 0 42px;

    display: flex;
    align-items: center;
    justify-content: space-between;

    background: rgba(0,0,0,.42);

    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);

    border-bottom: 1px solid rgba(255,255,255,.05);

    z-index: 9999;
}

/* MENU */

.menu-btn{

    width: 52px;
    height: 52px;

    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 7px;

    background: transparent;
    border: none;

    cursor: pointer;
}

.menu-btn span{

    width: 30px;
    height: 2px;

    background: white;

    border-radius: 999px;

    transition: .3s;
}

.menu-btn:hover span{

    background: #d9b98b;
    box-shadow: 0 0 10px rgba(217,185,139,.6);
}

/* LOGO */

.brand-center{

    position: absolute;

    left: 50%;
    top: 50%;

    transform: translate(-50%, -50%);

    display: flex;
    align-items: center;

    gap: 14px;
}

.logo{

    height: 68px;
    width: auto;

    filter:
    drop-shadow(0 0 10px rgba(255,255,255,.22))
    drop-shadow(0 0 28px rgba(217,185,139,.18));
}

.logo-text{

    display: flex;
    flex-direction: column;
}

.logo-text h1{

    color: white;

    font-size: 38px;

    font-family: 'Cormorant Garamond', serif;

    line-height: 1;
}

.logo-text p{

    color: rgba(255,255,255,.78);

    letter-spacing: 5px;

    font-size: 10px;

    margin-top: 4px;
}
/* RESPONSIVE */

@media(max-width:768px){

    .header{

        padding: 0 18px;
        height: 82px;
    }

    .logo{

        height: 54px;
    }

    .logo-text h1{

        font-size: 25px;
    }

    .logo-text p{

        font-size: 8px;
        letter-spacing: 3px;
    }

    .header-cart{

        width: 58px;
        height: 58px;

        padding: 0;

        justify-content: center;
    }

    .cart-text{

        display: none;
    }

}

.menu-btn {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 7px !important;
  background: transparent !important;
  border: none !important;
}

.menu-btn span {
  display: block !important;
  width: 34px !important;
  height: 2px !important;
  background: #fff !important;
  border-radius: 20px !important;
}

/* VER IMÁGENES COMPLETAS EN PRODUCTOS */

.producto-img,
.product-card img,
.producto img,
.productos img {
  width: 100%;
  height: 360px;
  object-fit: contain !important;
  object-position: center;
  background: #f4eee8;
  padding: 12px;
}

/* TARJETAS MÁS PREMIUM */

.product-card,
.producto-card,
.producto {
  overflow: hidden;
  border-radius: 28px;
}

/* CONTENEDOR DE IMAGEN */

.product-card-image,
.producto-img-wrap,
.product-image {
  height: 520px;

  display: flex;
  align-items: center;
  justify-content: center;

  background: #f5f0ea;

  padding: 0;
}

/* IMAGEN */

.product-card img,
.producto img,
.productos img {
  width: 100%;
  height: 100%;

  object-fit: contain !important;

  transform: scale(1.12);

  transition: .5s ease;
}

/* HOVER ELEGANTE */

.product-card:hover img,
.producto:hover img {
  transform: scale(1.16);
}

.products-grid,
.product-grid,
.productos-grid {
  display: grid;

  grid-template-columns: repeat(5, 1fr);

  gap: 22px;
}

/* COLECCIÓN PREMIUM - AJUSTE SENIOR */

.coleccion-premium {
  position: relative;
  padding: 110px 5vw;
  overflow: hidden;

  background:
    radial-gradient(circle at 15% 10%, rgba(216, 180, 140, .18), transparent 28%),
    radial-gradient(circle at 85% 20%, rgba(0, 0, 0, .08), transparent 30%),
    linear-gradient(180deg, #f8f2ec 0%, #efe6dc 55%, #f9f5ef 100%);
}

.coleccion-premium::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.35) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.28) 1px, transparent 1px);
  background-size: 80px 80px;
  opacity: .18;
  pointer-events: none;
}

.coleccion-premium .section-title {
  position: relative;
  z-index: 2;
  margin-bottom: 42px;
}

/* FILTROS */

.collection-categories,
.filters.collection-search {
  position: relative;
  z-index: 2;
}

.collection-categories {
  margin-bottom: 26px;
}

.collection-filter {
  box-shadow: 0 10px 25px rgba(0,0,0,.06);
}

/* GRID PRODUCTOS */

.productos {
  position: relative;
  z-index: 2;

  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 24px;

  margin-top: 46px;
}

/* TARJETA */

.producto {
  overflow: hidden;
  border-radius: 24px;
  background: rgba(255,255,255,.74);
  box-shadow: 0 18px 45px rgba(75, 55, 35, .10);
  border: 1px solid rgba(216,180,140,.16);
  transition: .35s ease;
}

.producto:hover {
  transform: translateY(-7px);
  box-shadow: 0 26px 65px rgba(75, 55, 35, .16);
}

/* IMAGEN COMPLETA PERO NORMAL */

.producto img,
.productos img {
  width: 100%;
  height: 300px;
  object-fit: contain !important;
  object-position: center;
  display: block;

  background:
    radial-gradient(circle at center, #ffffff 0%, #f1e8df 75%);
  padding: 14px;

  transition: .45s ease;
}

.producto:hover img {
  transform: scale(1.04);
}

/* CONTENIDO */

.producto .producto-info,
.producto-info {
  background: rgba(255,255,255,.95);
  padding: 22px;
}

.producto h3 {
  font-size: 22px;
  line-height: 1.15;
}

.producto p {
  font-size: 14px;
}

.producto .precio,
.precio {
  font-size: 22px;
  font-weight: 700;
}

/* RESPONSIVE */

@media (max-width: 1500px) {
  .productos {
    grid-template-columns: repeat(4, 1fr);
  }

  .producto img,
  .productos img {
    height: 285px;
  }
}

@media (max-width: 1100px) {
  .productos {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  .coleccion-premium {
    padding: 80px 18px;
  }

  .productos {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }

  .producto img,
  .productos img {
    height: 230px;
    padding: 10px;
  }

  .producto-info {
    padding: 16px;
  }

  .producto h3 {
    font-size: 18px;
  }
}

.product-modal {
  position: fixed;
  inset: 0;
  z-index: 1000000;
  background: rgba(0,0,0,.82);
  backdrop-filter: blur(12px);

  display: none;
  align-items: center;
  justify-content: center;

  padding: 30px;
}

.product-modal.active {
  display: flex;
}

.product-modal-box {
  width: min(1100px, 96vw);
  max-height: 92vh;
  overflow-y: auto;

  background: #f7f1ea;
  border-radius: 28px;
  padding: 28px;

  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 28px;
}

.product-modal-box > img {
  width: 100%;
  max-height: 78vh;
  object-fit: contain;
  background: #eee5dc;
  border-radius: 22px;
}

.product-modal-close {
  position: fixed;
  top: 25px;
  right: 35px;

  width: 46px;
  height: 46px;
  border-radius: 50%;
  border: none;

  font-size: 32px;
  cursor: pointer;
  background: #fff;
  z-index: 2;
}

.laos-recommended {
  padding: 12px;
}

.laos-recommended span {
  color: #b78352;
  letter-spacing: 4px;
  text-transform: uppercase;
  font-size: 12px;
  font-weight: 700;
}

.laos-recommended h3 {
  margin: 12px 0 24px;
  font-size: 34px;
  font-family: 'Cormorant Garamond', serif;
}

.recommended-grid {
  display: grid;
  gap: 16px;
}

.recommended-card {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 14px;
  align-items: center;

  padding: 12px;
  border-radius: 18px;
  background: #fff;
  text-decoration: none;
  color: #111;
  transition: .3s ease;
}

.recommended-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 35px rgba(0,0,0,.12);
}

.recommended-card img {
  width: 90px;
  height: 90px;
  object-fit: cover;
  border-radius: 14px;
}

.recommended-card p {
  font-weight: 700;
}

.producto img,
.productos img {
  cursor: zoom-in;
}

@media(max-width:768px) {
  .product-modal-box {
    grid-template-columns: 1fr;
  }

  .laos-recommended h3 {
    font-size: 26px;
  }
}

.card-img {
  transition: opacity .25s ease, transform .35s ease;
}

.nav {
  position: fixed;
  top: 100px;
  left: 32px;
  z-index: 1000000;

  display: flex;
  flex-direction: column;
  gap: 16px;

  background: rgba(0,0,0,.86);
  backdrop-filter: blur(16px);

  padding: 24px;
  border-radius: 22px;
  border: 1px solid rgba(216,180,140,.22);

  opacity: 0;
  visibility: hidden;
  transform: translateY(-12px);
  transition: .3s ease;
}

.nav.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav a {
  color: white;
  text-decoration: none;
  font-weight: 600;
}

.menu-btn.active span:nth-child(1) {
  transform: rotate(45deg) translate(6px, 6px);
}

.menu-btn.active span:nth-child(2) {
  opacity: 0;
}

.menu-btn.active span:nth-child(3) {
  transform: rotate(-45deg) translate(6px, -6px);
}

#closeCart {
  width: 42px !important;
  height: 42px !important;
  border-radius: 50% !important;
  border: none !important;
  background: #111 !important;
  color: #fff !important;
  cursor: pointer !important;
}

/* CORREGIR CARRITO SOBRE EL ENCABEZADO */

.header {
  z-index: 1000 !important;
}

/* =============================== */
/* CARRITO FINAL LIMPIO - LAOS */
/* =============================== */

body.cart-open {
  overflow: hidden;
}

.overlay {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0, 0, 0, 0.58) !important;
  backdrop-filter: blur(5px) !important;
  z-index: 2500 !important;
  display: none !important;
}

.overlay.active {
  display: block !important;
}

.cart-panel {
  position: fixed !important;
  top: 0 !important;
  right: -440px !important;
  width: 420px !important;
  max-width: 94vw !important;
  height: 100vh !important;
  background: #fbf7f1 !important;
  z-index: 3000 !important;
  padding: 30px 26px !important;
  display: flex !important;
  flex-direction: column !important;
  box-shadow: -22px 0 55px rgba(0, 0, 0, 0.22) !important;
  transition: right 0.35s ease !important;
  opacity: 1 !important;
  filter: none !important;
  backdrop-filter: none !important;
}

.cart-panel.active {
  right: 0 !important;
}

.cart-header {
  flex: 0 0 auto !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 18px !important;
  padding: 0 0 22px !important;
  margin: 0 !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.10) !important;
  position: static !important;
  min-height: auto !important;
}

.cart-label {
  display: block !important;
  font-size: 10px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: #b48a5a !important;
  margin: 0 0 8px !important;
  font-weight: 600 !important;
}

.cart-header h2 {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 34px !important;
  line-height: 1 !important;
  margin: 0 !important;
  color: #111 !important;
  white-space: nowrap !important;
}

#cartItemsCount {
  font-family: 'Manrope', sans-serif !important;
  font-size: 16px !important;
  color: #777 !important;
  margin-left: 4px !important;
  vertical-align: middle !important;
}

.cart-close {
  flex: 0 0 auto !important;
  width: 44px !important;
  height: 44px !important;
  border: none !important;
  border-radius: 50% !important;
  background: #111 !important;
  color: #fff !important;
  font-size: 26px !important;
  line-height: 1 !important;
  cursor: pointer !important;
  display: grid !important;
  place-items: center !important;
}

.cart-body {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  padding: 24px 0 !important;
}

.cart-body::-webkit-scrollbar {
  width: 5px;
}

.cart-body::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,.18);
  border-radius: 20px;
}

.empty-cart-premium {
  min-height: 360px !important;
  height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  padding: 20px !important;
}

.empty-cart-premium h3 {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 28px !important;
  color: #111 !important;
  margin: 0 0 10px !important;
}

.empty-cart-premium p {
  max-width: 270px !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
  color: #777 !important;
  margin: 0 0 22px !important;
}

.empty-cart-premium .btn,
.empty-cart-btn {
  width: auto !important;
  background: #111 !important;
  color: #fff !important;
  padding: 12px 28px !important;
  border-radius: 999px !important;
  font-size: 13px !important;
}

.cart-item {
  display: grid !important;
  grid-template-columns: 86px 1fr !important;
  gap: 16px !important;
  align-items: start !important;
  background: transparent !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.10) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 0 20px !important;
  margin: 0 0 20px !important;
  position: static !important;
}

.cart-item img {
  width: 86px !important;
  height: 112px !important;
  object-fit: cover !important;
  border-radius: 16px !important;
  flex-shrink: 0 !important;
}

.cart-item-info {
  min-width: 0 !important;
}

.cart-item-info h4 {
  font-size: 17px !important;
  line-height: 1.3 !important;
  margin: 0 0 8px !important;
  color: #111 !important;
  font-weight: 700 !important;
}

.cart-item-info p {
  font-size: 13px !important;
  color: #777 !important;
  margin: 2px 0 !important;
  line-height: 1.45 !important;
}

.cart-item-info strong {
  display: block !important;
  font-size: 20px !important;
  margin: 10px 0 !important;
  color: #111 !important;
  font-weight: 800 !important;
}

.qty {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 5px 12px !important;
  border: 1px solid rgba(0,0,0,.12) !important;
  border-radius: 999px !important;
  background: #fff !important;
  margin: 2px 0 0 !important;
}

.qty button {
  width: 22px !important;
  height: 22px !important;
  border: none !important;
  background: transparent !important;
  color: #111 !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
}

.qty span {
  font-size: 13px !important;
  min-width: 12px !important;
  text-align: center !important;
}

.remove {
  display: block !important;
  margin-top: 10px !important;
  border: none !important;
  background: transparent !important;
  color: #777 !important;
  font-size: 12px !important;
  text-decoration: underline !important;
  cursor: pointer !important;
  padding: 0 !important;
}

.remove:hover {
  color: crimson !important;
}

.cart-footer {
  flex: 0 0 auto !important;
  margin-top: auto !important;
  background: #fff !important;
  border-radius: 26px !important;
  padding: 24px !important;
  border: 1px solid rgba(0,0,0,.08) !important;
  box-shadow: 0 14px 35px rgba(0,0,0,.06) !important;
}

.cart-total-line {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 18px !important;
  margin: 0 0 18px !important;
}

.cart-total-line span {
  font-size: 15px !important;
  color: #777 !important;
}

.cart-total-line strong {
  font-size: 32px !important;
  color: #111 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

.checkout-btn {
  width: 100% !important;
  border: none !important;
  border-radius: 999px !important;
  background: #111 !important;
  color: #fff !important;
  padding: 15px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: .25s ease !important;
}

.checkout-btn:hover {
  background: #b48a5a !important;
  color: #111 !important;
  transform: translateY(-2px) !important;
}

.cart-note {
  text-align: center !important;
  font-size: 13px !important;
  color: #888 !important;
  margin: 14px 0 0 !important;
}

@media (max-width: 520px) {
  .cart-panel {
    width: 100% !important;
    max-width: 100vw !important;
    padding: 26px 20px !important;
  }

  .cart-header h2 {
    font-size: 30px !important;
  }

  .cart-item {
    grid-template-columns: 76px 1fr !important;
    gap: 14px !important;
  }

  .cart-item img {
    width: 76px !important;
    height: 100px !important;
  }

  .cart-footer {
    border-radius: 22px !important;
    padding: 20px !important;
  }

  .cart-total-line strong {
    font-size: 28px !important;
  }
}

/* HERO EDITORIAL PREMIUM */

body {
  font-family: 'Manrope', sans-serif;
}

.hero-premium-content {
  max-width: 720px;
}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #e8c49d;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  margin-bottom: 22px;
}

.hero-eyebrow::before {
  content: "✦";
  font-size: 12px;
}

.hero-premium-content h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(64px, 7vw, 108px);
  line-height: .88;
  letter-spacing: -3px;
  max-width: 760px;
  margin-bottom: 28px;
}

.hero-premium-content p {
  max-width: 590px;
  font-size: 19px;
  line-height: 1.75;
  color: rgba(255,255,255,.9);
  margin-bottom: 32px;
}

.hero-highlights {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 34px;
}

.hero-highlights span {
  padding: 11px 18px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
  color: white;
  font-size: 14px;
  font-weight: 600;
}

.hero-buttons .btn {
  min-width: 185px;
  text-align: center;
}

@media(max-width: 768px) {
  .hero-premium-content h2 {
    font-size: 52px;
    letter-spacing: -1px;
    line-height: .95;
  }

  .hero-premium-content p {
    font-size: 16px;
  }

  .hero-highlights {
    justify-content: center;
  }
}

/* =========================
   HERO PREMIUM EDITORIAL
========================= */

.hero-premium-content{
    max-width: 760px;
}

.hero-premium-content .tag{
    display:inline-block;
    color:#d8b48c;
    font-size:13px;
    font-weight:600;
    letter-spacing:4px;
    text-transform:uppercase;
    margin-bottom:25px;
}

.hero-premium-content h2{
    font-family:'Cormorant Garamond', serif;
    font-size:clamp(4.2rem,6vw,7.5rem);
    font-weight:600;
    line-height:.92;
    letter-spacing:-2px;
    max-width:900px;
    margin-bottom:25px;
    text-wrap:balance;
}

.hero-premium-content p{
    max-width:580px;
    font-size:20px;
    line-height:1.7;
    color:rgba(255,255,255,.92);
    margin-bottom:25px;
}

.hero-line{
    width:90px;
    height:1px;
    background:#d8b48c;
    margin:35px 0;
    opacity:.9;
}

.hero-buttons{
    margin-top:10px;
}

.hero-main-btn{
    background:#d8b48c;
    color:#111;
    padding:18px 42px;
    border-radius:999px;
    font-size:16px;
    font-weight:600;
    letter-spacing:.5px;
    transition:.35s;
    box-shadow:0 15px 35px rgba(216,180,140,.25);
}

.hero-main-btn:hover{
    transform:translateY(-4px);
    background:#e3c29f;
}

@media(max-width:768px){

    .hero-premium-content{
        text-align:left;
    }

    .hero-premium-content h2{
        font-size:clamp(3rem,12vw,4.5rem);
        line-height:.95;
        letter-spacing:-1px;
    }

    .hero-premium-content p{
        font-size:17px;
    }

    .hero-line{
        margin:25px 0;
    }

    .hero-main-btn{
        width:auto;
    }
}

/* AJUSTE HERO MÁS LIMPIO */

.hero-premium-content {
  max-width: 680px !important;
  margin-top: 70px !important;
}

.hero-premium-content h2 {
  font-size: clamp(3.8rem, 5vw, 6.2rem) !important;
  line-height: .96 !important;
  letter-spacing: -1.5px !important;
  max-width: 760px !important;
  margin-bottom: 22px !important;
}

.hero-premium-content p {
  max-width: 560px !important;
  font-size: 18px !important;
  line-height: 1.65 !important;
}

.hero-line {
  margin: 26px 0 28px !important;
}

.hero-buttons {
  gap: 14px !important;
}

.hero-buttons .btn {
  padding: 14px 32px !important;
  font-size: 15px !important;
}

@media(max-width:768px) {
  .hero-premium-content {
    margin-top: 40px !important;
  }

  .hero-premium-content h2 {
    font-size: clamp(2.8rem, 12vw, 4.1rem) !important;
    line-height: .98 !important;
  }

  .hero-premium-content p {
    font-size: 16px !important;
  }
}
.hero-premium-content h2,
.hero h2,
.hero-content h2{
    font-family:'Cormorant Garamond',serif !important;
    font-weight:600 !important;
}

/* ===============================
   ORDEN PREMIUM DE SECCIONES
   Hero → Colección → Video → Galería → Sobre + Servicios → Opiniones → Contacto
================================ */

/* Sobre + servicios integrados */
.sobre .atelier-services {
  margin-top: 90px;
  padding-top: 70px;
  border-top: 1px solid rgba(0,0,0,.08);
}

.sobre .atelier-title {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.sobre .servicios-grid {
  margin-top: 35px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.sobre .servicio {
  background: #fff;
  color: #111;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 24px;
  padding: 28px;
  box-shadow: 0 16px 45px rgba(0,0,0,.06);
}

.sobre .servicio h3 {
  color: #b48a5a;
  margin-bottom: 12px;
}

.sobre .servicio p {
  color: #444;
  font-size: 15px;
  line-height: 1.75;
}

/* La sección servicios ya no existe como bloque separado */
.servicios:not(.sobre .servicios) {
  display: none;
}

@media (max-width: 900px) {
  .sobre .servicios-grid {
    grid-template-columns: 1fr;
  }

  .sobre .atelier-services {
    margin-top: 60px;
    padding-top: 50px;
  }
}


/* =====================================================
   COLECCIÓN LOOKBOOK - FONDO COMPLETO DINÁMICO
   El fondo de toda la sección cambia por producto/color.
===================================================== */

.lookbook-collection {
  --collection-bg: url("img/fondo.webp");
  position: relative !important;
  min-height: 100vh;
  padding: 110px 4.2vw 70px !important;
  overflow: hidden;
  background: #1b120d !important;
  color: #fff;
}

.lookbook-collection .lookbook-bg-layer {
  position: absolute;
  inset: 0;
  background-image: var(--collection-bg);
  background-size: cover;
  background-position: center;
  transform: scale(1.06);
  filter: blur(1px);
  opacity: .72;
  transition: background-image .45s ease, opacity .45s ease, transform .65s ease;
  z-index: 0;
}

.lookbook-collection .lookbook-bg-overlay {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 78% 48%, rgba(216,180,140,.12), transparent 33%),
    linear-gradient(90deg, rgba(18,10,6,.86) 0%, rgba(35,22,14,.62) 42%, rgba(16,9,5,.42) 100%);
  z-index: 1;
  pointer-events: none;
}

.lookbook-collection::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(248,243,238,.05);
  backdrop-filter: blur(10px);
  z-index: 1;
  pointer-events: none;
}

.lookbook-collection > *:not(.lookbook-bg-layer):not(.lookbook-bg-overlay) {
  position: relative;
  z-index: 2;
}

.lookbook-collection .section-title,
.lookbook-collection .collection-search {
  display: none !important;
}

.lookbook-filters {
  display: flex;
  justify-content: flex-end;
  gap: 14px;
  margin-bottom: 28px;
}

.lookbook-filters .collection-filter {
  border: 1px solid rgba(255,255,255,.28) !important;
  background: rgba(255,255,255,.10) !important;
  color: #fff !important;
  backdrop-filter: blur(12px);
  padding: 11px 22px !important;
  border-radius: 999px !important;
  box-shadow: none !important;
}

.lookbook-filters .collection-filter.active,
.lookbook-filters .collection-filter:hover {
  background: #d8b48c !important;
  color: #17100c !important;
  border-color: #d8b48c !important;
}

.lookbook-stage.productos,
.productos.lookbook-stage {
  display: block !important;
  margin: 0 !important;
  position: relative;
  z-index: 3;
}

.lookbook-product {
  min-height: calc(100vh - 220px);
  display: grid;
  grid-template-columns: minmax(270px, 360px) minmax(520px, 1fr);
  gap: clamp(36px, 5vw, 86px);
  align-items: center;
}

.lookbook-info {
  max-width: 360px;
  color: #fff;
  text-shadow: 0 10px 35px rgba(0,0,0,.24);
}

.lookbook-label {
  display: inline-block;
  letter-spacing: 5px;
  text-transform: uppercase;
  font-size: 13px;
  color: #e4c09a;
  margin-bottom: 18px;
}

.lookbook-mark {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 34px;
  color: #e4c09a;
}

.lookbook-mark span {
  width: 52px;
  height: 1px;
  background: rgba(228,192,154,.72);
}

.lookbook-info h3 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(54px, 5.7vw, 90px);
  line-height: .9;
  letter-spacing: -2px;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 22px;
}

.lookbook-fabric,
.lookbook-description {
  font-size: 17px;
  line-height: 1.65;
  color: rgba(255,255,255,.84);
  margin-bottom: 16px;
}

.lookbook-features {
  display: grid;
  gap: 16px;
  margin: 30px 0;
}

.lookbook-features div {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 16px;
  align-items: center;
}

.lookbook-feature-icon {
  width: 46px;
  height: 46px;
  border: 1px solid rgba(228,192,154,.48);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #e4c09a;
  font-size: 22px;
}

.lookbook-features p {
  font-size: 14px;
  line-height: 1.45;
  color: rgba(255,255,255,.82);
  margin: 0;
}

.lookbook-line {
  height: 1px;
  width: 100%;
  background: rgba(228,192,154,.35);
  margin: 28px 0 22px;
}

.lookbook-selects {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 18px;
}

.lookbook-selects label {
  display: block;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #e4c09a;
  margin-bottom: 8px;
}

.lookbook-selects select {
  width: 100%;
  border: 1px solid rgba(255,255,255,.32);
  border-radius: 999px;
  padding: 12px 14px;
  color: #fff;
  background: rgba(255,255,255,.10);
  backdrop-filter: blur(12px);
  outline: none;
}

.lookbook-selects option {
  color: #111;
}

.lookbook-price {
  font-family: 'Cormorant Garamond', serif;
  font-size: 32px;
  color: #fff;
  margin: 8px 0 18px;
}

.lookbook-cart-btn {
  width: 100%;
  border: none;
  border-radius: 999px;
  background: linear-gradient(135deg, #d8b48c, #b88958);
  color: #17100c;
  padding: 16px 22px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 1.8px;
  font-weight: 800;
  box-shadow: 0 20px 45px rgba(0,0,0,.23);
  transition: .3s ease;
}

.lookbook-cart-btn:hover {
  transform: translateY(-3px);
  filter: brightness(1.08);
}

.lookbook-visuals {
  width: 100%;
}

.lookbook-collage {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: minmax(180px, 36vh);
  gap: 14px;
  max-height: 72vh;
}

.lookbook-image-tile {
  border: 1px solid rgba(255,255,255,.24);
  border-radius: 28px;
  min-height: 0;
  background-size: cover;
  background-position: center;
  box-shadow: 0 28px 80px rgba(0,0,0,.26);
  cursor: pointer;
  transition: .35s ease;
}

.lookbook-image-tile:hover {
  transform: translateY(-4px);
  filter: brightness(1.05);
}

.lookbook-tile-large {
  grid-column: span 1;
  grid-row: span 2;
}

.lookbook-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 6;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.30);
  background: rgba(0,0,0,.26);
  color: #fff;
  font-size: 38px;
  line-height: 1;
  cursor: pointer;
  backdrop-filter: blur(14px);
  transition: .25s ease;
}

.lookbook-arrow:hover {
  background: #d8b48c;
  color: #17100c;
  border-color: #d8b48c;
}

.lookbook-prev {
  left: 24px;
}

.lookbook-next {
  right: 24px;
}

.lookbook-empty {
  min-height: 420px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
}

@media (max-width: 1100px) {
  .lookbook-product {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .lookbook-info {
    max-width: 680px;
  }

  .lookbook-collage {
    max-height: none;
    grid-auto-rows: 240px;
  }
}

@media (max-width: 768px) {
  .lookbook-collection {
    padding: 96px 18px 55px !important;
  }

  .lookbook-filters {
    justify-content: flex-start;
    overflow-x: auto;
    padding-bottom: 8px;
  }

  .lookbook-info h3 {
    font-size: clamp(42px, 13vw, 58px);
  }

  .lookbook-selects {
    grid-template-columns: 1fr;
  }

  .lookbook-collage {
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 190px;
    gap: 10px;
  }

  .lookbook-image-tile {
    border-radius: 20px;
  }

  .lookbook-arrow {
    width: 46px;
    height: 46px;
    font-size: 32px;
  }

  .lookbook-prev {
    left: 12px;
  }

  .lookbook-next {
    right: 12px;
  }
}


/* =====================================================
   AJUSTE FINAL LOOKBOOK: FONDO TOTAL + CENTRO LIBRE + COLLAGE DERECHA
===================================================== */

.lookbook-collection {
  min-height: 100vh !important;
  padding: 104px 3.4vw 62px !important;
}

.lookbook-collection .lookbook-bg-layer {
  opacity: .82 !important;
  filter: blur(.5px) saturate(.95) brightness(.82) !important;
  transform: scale(1.04) !important;
  background-position: center !important;
}

.lookbook-collection .lookbook-bg-overlay {
  background:
    radial-gradient(circle at 48% 52%, rgba(216,180,140,.10), transparent 34%),
    linear-gradient(90deg,
      rgba(16,9,5,.82) 0%,
      rgba(30,18,11,.58) 32%,
      rgba(25,15,9,.28) 55%,
      rgba(18,10,6,.58) 100%
    ) !important;
}

.lookbook-collection::before {
  background: rgba(20,12,8,.10) !important;
  backdrop-filter: blur(5px) !important;
}

.lookbook-filters {
  justify-content: flex-end !important;
  margin-bottom: 22px !important;
  padding-right: 2vw !important;
}

.lookbook-product {
  min-height: calc(100vh - 190px) !important;
  display: grid !important;
  grid-template-columns: minmax(300px, 390px) minmax(260px, 1fr) minmax(300px, 440px) !important;
  gap: clamp(26px, 4vw, 70px) !important;
  align-items: center !important;
}

.lookbook-info {
  max-width: 390px !important;
  align-self: center !important;
}

.lookbook-info h3 {
  font-size: clamp(50px, 4.5vw, 78px) !important;
  line-height: .92 !important;
  margin-bottom: 18px !important;
}

.lookbook-description {
  max-width: 360px !important;
}

.lookbook-center-space {
  min-height: 58vh;
  border-radius: 34px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(135deg, rgba(255,255,255,.035), rgba(255,255,255,.006));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.025);
  pointer-events: none;
}

.lookbook-visuals {
  width: min(100%, 430px) !important;
  justify-self: end !important;
}

.lookbook-collage {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  grid-template-rows: 260px 300px !important;
  gap: 14px !important;
  max-height: none !important;
  width: 100% !important;
}

.lookbook-image-tile {
  min-height: 0 !important;
  height: 100% !important;
  border-radius: 26px !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  box-shadow: 0 22px 60px rgba(0,0,0,.25) !important;
}

.lookbook-tile-large {
  grid-column: auto !important;
  grid-row: auto !important;
}

.lookbook-tile-wide {
  grid-column: 1 / -1 !important;
  grid-row: 2 !important;
}

.lookbook-arrow {
  width: 58px !important;
  height: 58px !important;
  border: 1px solid rgba(216,180,140,.68) !important;
  background: rgba(0,0,0,.22) !important;
  color: #fff !important;
  font-size: 40px !important;
  box-shadow: 0 18px 50px rgba(0,0,0,.25) !important;
}

.lookbook-arrow:hover {
  background: #d8b48c !important;
  color: #17100c !important;
}

.lookbook-prev {
  left: 22px !important;
}

.lookbook-next {
  right: 22px !important;
}

@media (max-width: 1200px) {
  .lookbook-product {
    grid-template-columns: minmax(280px, 380px) minmax(180px, 1fr) minmax(280px, 380px) !important;
    gap: 28px !important;
  }

  .lookbook-collage {
    grid-template-rows: 230px 270px !important;
  }
}

@media (max-width: 980px) {
  .lookbook-product {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    gap: 30px !important;
  }

  .lookbook-center-space {
    display: none !important;
  }

  .lookbook-info {
    max-width: 680px !important;
  }

  .lookbook-visuals {
    width: 100% !important;
    justify-self: stretch !important;
  }

  .lookbook-collage {
    grid-template-rows: 220px 260px !important;
  }
}

@media (max-width: 768px) {
  .lookbook-collection {
    padding: 96px 18px 55px !important;
  }

  .lookbook-filters {
    padding-right: 0 !important;
  }

  .lookbook-collage {
    grid-template-rows: 180px 220px !important;
    gap: 10px !important;
  }

  .lookbook-arrow {
    width: 46px !important;
    height: 46px !important;
    font-size: 32px !important;
  }

  .lookbook-prev {
    left: 10px !important;
  }

  .lookbook-next {
    right: 10px !important;
  }
}

/* =====================================================
   AJUSTES FINALES COLECCIÓN: FONDO NÍTIDO + COLORES CIRCULARES
   - Fondo visible sin opacidad pesada.
   - Se elimina el cuadro translúcido del centro.
   - Filtros de tipo de prenda más hacia la derecha.
   - Colores como círculos.
   - Texto claro/oscuro automático según clase del JS.
===================================================== */

.lookbook-collection {
  --lookbook-text: #ffffff;
  --lookbook-muted: rgba(255,255,255,.86);
  --lookbook-soft: rgba(255,255,255,.72);
  --lookbook-accent: #e4c09a;
  --lookbook-border: rgba(255,255,255,.28);
  --lookbook-chip-bg: rgba(255,255,255,.12);
  background: #111 !important;
}

.lookbook-collection.lookbook-text-dark {
  --lookbook-text: #17100c;
  --lookbook-muted: rgba(23,16,12,.84);
  --lookbook-soft: rgba(23,16,12,.68);
  --lookbook-accent: #7b4f2d;
  --lookbook-border: rgba(23,16,12,.24);
  --lookbook-chip-bg: rgba(255,255,255,.52);
}

.lookbook-collection.lookbook-text-light {
  --lookbook-text: #ffffff;
  --lookbook-muted: rgba(255,255,255,.86);
  --lookbook-soft: rgba(255,255,255,.72);
  --lookbook-accent: #e4c09a;
  --lookbook-border: rgba(255,255,255,.28);
  --lookbook-chip-bg: rgba(0,0,0,.18);
}

.lookbook-collection .lookbook-bg-layer {
  opacity: 1 !important;
  filter: none !important;
  transform: scale(1.015) !important;
  background-size: cover !important;
  background-position: center !important;
}

.lookbook-collection .lookbook-bg-overlay {
  background: linear-gradient(
    90deg,
    rgba(0,0,0,.18) 0%,
    rgba(0,0,0,.06) 36%,
    rgba(0,0,0,.02) 62%,
    rgba(0,0,0,.08) 100%
  ) !important;
}

.lookbook-collection.lookbook-text-dark .lookbook-bg-overlay {
  background: linear-gradient(
    90deg,
    rgba(255,255,255,.30) 0%,
    rgba(255,255,255,.12) 34%,
    rgba(255,255,255,.03) 65%,
    rgba(255,255,255,.10) 100%
  ) !important;
}

.lookbook-collection::before {
  display: none !important;
}

.lookbook-filters {
  justify-content: flex-end !important;
  margin-left: auto !important;
  padding-right: clamp(56px, 7vw, 120px) !important;
  transform: translateX(18px);
}

.lookbook-filters .collection-filter {
  color: var(--lookbook-text) !important;
  border-color: var(--lookbook-border) !important;
  background: var(--lookbook-chip-bg) !important;
  box-shadow: 0 12px 30px rgba(0,0,0,.10) !important;
}

.lookbook-filters .collection-filter.active,
.lookbook-filters .collection-filter:hover {
  background: #d8b48c !important;
  border-color: #d8b48c !important;
  color: #17100c !important;
}

.lookbook-info,
.lookbook-info h3,
.lookbook-price {
  color: var(--lookbook-text) !important;
}

.lookbook-label,
.lookbook-mark,
.lookbook-feature-icon,
.lookbook-selects label {
  color: var(--lookbook-accent) !important;
}

.lookbook-mark span,
.lookbook-line {
  background: color-mix(in srgb, var(--lookbook-accent) 70%, transparent) !important;
}

.lookbook-fabric,
.lookbook-description,
.lookbook-features p {
  color: var(--lookbook-muted) !important;
}

.lookbook-info {
  text-shadow: 0 8px 30px rgba(0,0,0,.18) !important;
}

.lookbook-collection.lookbook-text-dark .lookbook-info {
  text-shadow: 0 8px 28px rgba(255,255,255,.20) !important;
}

.lookbook-center-space {
  display: block !important;
  min-height: 58vh !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
}

.lookbook-selects-redesign {
  grid-template-columns: 1fr !important;
  gap: 16px !important;
}

.lookbook-selects select {
  border-color: var(--lookbook-border) !important;
  background: var(--lookbook-chip-bg) !important;
  color: var(--lookbook-text) !important;
}

.lookbook-selects option {
  color: #111 !important;
}

.lookbook-color-dots {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  min-height: 46px;
}

.lookbook-color-dot {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.65);
  background: var(--dot-color);
  cursor: pointer;
  position: relative;
  box-shadow: 0 8px 22px rgba(0,0,0,.24);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.lookbook-color-dot::after {
  content: "";
  position: absolute;
  inset: -7px;
  border-radius: 50%;
  border: 1px solid transparent;
  transition: .25s ease;
}

.lookbook-color-dot:hover {
  transform: translateY(-2px) scale(1.04);
}

.lookbook-color-dot.active {
  transform: scale(1.08);
  border-color: #fff;
  box-shadow: 0 0 0 4px rgba(216,180,140,.26), 0 14px 30px rgba(0,0,0,.28);
}

.lookbook-color-dot.active::after {
  border-color: #d8b48c;
}

.lookbook-collection.lookbook-text-dark .lookbook-color-dot {
  border-color: rgba(23,16,12,.42);
}

.lookbook-collection.lookbook-text-dark .lookbook-color-dot.active {
  border-color: #17100c;
  box-shadow: 0 0 0 4px rgba(123,79,45,.22), 0 14px 30px rgba(0,0,0,.16);
}

.lookbook-arrow {
  background: rgba(255,255,255,.18) !important;
  color: var(--lookbook-text) !important;
  border-color: var(--lookbook-border) !important;
  backdrop-filter: blur(8px) !important;
}

.lookbook-arrow:hover {
  background: #d8b48c !important;
  color: #17100c !important;
}

.lookbook-image-tile {
  border-color: var(--lookbook-border) !important;
  box-shadow: 0 20px 50px rgba(0,0,0,.20) !important;
}

@media (max-width: 980px) {
  .lookbook-filters {
    justify-content: flex-start !important;
    padding-right: 0 !important;
    transform: none !important;
  }

  .lookbook-center-space {
    display: none !important;
  }
}


/* =====================================================
   AJUSTE FINAL: FILTRO COMO DESPLEGABLE + FONDO/COLLAGE POR COLOR
===================================================== */

.lookbook-filter-panel {
  position: relative !important;
  z-index: 8 !important;
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  gap: 14px !important;
  width: 100% !important;
  margin-left: auto !important;
  padding-right: clamp(72px, 9vw, 160px) !important;
  transform: none !important;
}

.lookbook-filter-panel label {
  color: var(--lookbook-text, #fff) !important;
  font-size: 11px !important;
  letter-spacing: 2.6px !important;
  text-transform: uppercase !important;
  opacity: .86 !important;
}

.lookbook-filter-select {
  min-width: 210px !important;
  border: 1px solid var(--lookbook-border, rgba(255,255,255,.28)) !important;
  border-radius: 999px !important;
  padding: 12px 44px 12px 18px !important;
  color: var(--lookbook-text, #fff) !important;
  background: var(--lookbook-chip-bg, rgba(255,255,255,.12)) !important;
  backdrop-filter: blur(10px) !important;
  outline: none !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  box-shadow: 0 14px 35px rgba(0,0,0,.12) !important;
}

.lookbook-filter-select option {
  color: #111 !important;
  background: #fff !important;
}

.lookbook-collection .lookbook-bg-layer {
  opacity: 1 !important;
  filter: none !important;
  background-size: cover !important;
  background-position: center !important;
}

.lookbook-collection .lookbook-bg-overlay {
  background: linear-gradient(
    90deg,
    rgba(0,0,0,.16) 0%,
    rgba(0,0,0,.06) 34%,
    rgba(0,0,0,.02) 64%,
    rgba(0,0,0,.08) 100%
  ) !important;
}

.lookbook-collection.lookbook-text-dark .lookbook-bg-overlay {
  background: linear-gradient(
    90deg,
    rgba(255,255,255,.32) 0%,
    rgba(255,255,255,.12) 34%,
    rgba(255,255,255,.03) 64%,
    rgba(255,255,255,.10) 100%
  ) !important;
}

@media (max-width: 980px) {
  .lookbook-filter-panel {
    justify-content: flex-start !important;
    padding-right: 0 !important;
  }

  .lookbook-filter-panel label {
    display: none !important;
  }

  .lookbook-filter-select {
    width: 100% !important;
    min-width: unset !important;
  }
}

/* =====================================================
   COLECCIÓN FINAL: PANEL IZQUIERDO PREMIUM + HERO FIT
   - Panel izquierdo siempre claro como referencia.
   - Fondo visible sin cuadro central.
   - Collage derecho más grande y ordenado.
   - Sección completa en altura tipo hero.
===================================================== */

.lookbook-collection {
  min-height: 100vh !important;
  height: 100vh !important;
  padding: 92px clamp(24px, 3vw, 56px) 28px !important;
  overflow: hidden !important;
  background: #efe5da !important;
}

.lookbook-collection .lookbook-bg-layer {
  opacity: 1 !important;
  filter: none !important;
  transform: none !important;
  background-image: var(--collection-bg) !important;
  background-size: cover !important;
  background-position: center top !important;
  background-repeat: no-repeat !important;
}

.lookbook-collection .lookbook-bg-overlay {
  background: linear-gradient(
    90deg,
    rgba(255,255,255,.12) 0%,
    rgba(255,255,255,.03) 34%,
    rgba(255,255,255,0) 62%,
    rgba(0,0,0,.02) 100%
  ) !important;
}

.lookbook-collection::before {
  display: none !important;
}

.lookbook-filter-panel {
  position: absolute !important;
  top: 112px !important;
  right: clamp(40px, 6vw, 120px) !important;
  width: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  z-index: 10 !important;
  display: flex !important;
  align-items: center !important;
  gap: 18px !important;
}

.lookbook-filter-panel label {
  color: #fff !important;
  text-shadow: 0 2px 16px rgba(0,0,0,.35) !important;
  letter-spacing: 3px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
}

.lookbook-filter-select {
  min-width: 210px !important;
  height: 54px !important;
  border-radius: 999px !important;
  padding: 0 48px 0 22px !important;
  border: 1px solid rgba(255,255,255,.45) !important;
  background: rgba(65,50,40,.36) !important;
  color: #fff !important;
  backdrop-filter: blur(14px) !important;
  box-shadow: 0 20px 45px rgba(0,0,0,.12) !important;
}

.lookbook-stage.productos,
.productos.lookbook-stage {
  height: 100% !important;
  display: block !important;
}

.lookbook-product {
  height: calc(100vh - 120px) !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(360px, 445px) minmax(300px, 1fr) minmax(360px, 480px) !important;
  gap: clamp(22px, 3.5vw, 62px) !important;
  align-items: center !important;
  padding: 0 !important;
}

.lookbook-info {
  align-self: start !important;
  margin-top: -10px !important;
  width: min(100%, 445px) !important;
  max-width: 445px !important;
  min-height: auto !important;
  max-height: calc(100vh - 126px) !important;
  padding: clamp(22px, 2.1vw, 30px) !important;
  border-radius: 28px !important;
  background: linear-gradient(135deg, rgba(255,250,244,.86), rgba(238,222,204,.74)) !important;
  border: 1px solid rgba(255,255,255,.62) !important;
  box-shadow: 0 26px 70px rgba(72,44,24,.18) !important;
  backdrop-filter: blur(16px) !important;
  color: #111 !important;
  text-shadow: none !important;
  overflow: visible !important;
}

.lookbook-info,
.lookbook-info h3,
.lookbook-price {
  color: #090807 !important;
}

.lookbook-label {
  color: #9a6034 !important;
  font-size: 12px !important;
  letter-spacing: 5px !important;
  margin-bottom: 14px !important;
}

.lookbook-mark {
  color: #b48255 !important;
  margin-bottom: clamp(18px, 2vh, 24px) !important;
}

.lookbook-mark span,
.lookbook-line {
  background: rgba(154,96,52,.55) !important;
}

.lookbook-info h3 {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(47px, 4.1vw, 72px) !important;
  line-height: .82 !important;
  letter-spacing: -2.2px !important;
  margin-bottom: clamp(12px, 1.5vh, 18px) !important;
}

.lookbook-fabric,
.lookbook-description {
  color: rgba(17,17,17,.82) !important;
  font-size: 15px !important;
  line-height: 1.35 !important;
  margin-bottom: 10px !important;
}

.lookbook-features {
  gap: 10px !important;
  margin: clamp(14px, 2vh, 20px) 0 !important;
}

.lookbook-features div {
  grid-template-columns: 42px 1fr !important;
  gap: 14px !important;
}

.lookbook-feature-icon {
  width: 38px !important;
  height: 38px !important;
  color: #b48255 !important;
  border-color: rgba(180,130,85,.45) !important;
  font-size: 18px !important;
}

.lookbook-features p {
  color: rgba(17,17,17,.78) !important;
  font-size: 13px !important;
  line-height: 1.28 !important;
}

.lookbook-line {
  margin: clamp(12px, 1.8vh, 18px) 0 clamp(10px, 1.4vh, 14px) !important;
}

.lookbook-selects-redesign {
  gap: 10px !important;
  margin-bottom: 8px !important;
}

.lookbook-selects label {
  color: #9a6034 !important;
  font-size: 11px !important;
  letter-spacing: 3px !important;
  margin-bottom: 7px !important;
}

.lookbook-selects select {
  height: 48px !important;
  color: #111 !important;
  background: rgba(255,255,255,.70) !important;
  border: 1px solid rgba(20,20,20,.20) !important;
  box-shadow: inset 0 1px 4px rgba(0,0,0,.04) !important;
}

.lookbook-color-dots {
  min-height: 42px !important;
  gap: 12px !important;
}

.lookbook-color-dot {
  width: 36px !important;
  height: 36px !important;
  border: 2px solid rgba(20,20,20,.20) !important;
  box-shadow: 0 8px 18px rgba(0,0,0,.16) !important;
}

.lookbook-color-dot.active {
  border-color: #111 !important;
  box-shadow: 0 0 0 5px rgba(216,180,140,.40), 0 10px 24px rgba(0,0,0,.18) !important;
}

.lookbook-price {
  font-size: clamp(27px, 2.3vw, 34px) !important;
  margin: clamp(6px, 1.2vh, 12px) 0 clamp(10px, 1.6vh, 16px) !important;
}

.lookbook-cart-btn {
  height: 54px !important;
  padding: 0 20px !important;
  color: #111 !important;
  background: linear-gradient(135deg, #e1b77f, #c89053) !important;
  box-shadow: 0 18px 45px rgba(180,130,85,.24) !important;
  letter-spacing: 2px !important;
}

.lookbook-center-space {
  display: block !important;
  min-height: 0 !important;
  height: 100% !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
}

.lookbook-visuals {
  align-self: center !important;
  justify-self: end !important;
  width: min(100%, 470px) !important;
  max-height: calc(100vh - 150px) !important;
}

.lookbook-collage {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  grid-template-rows: minmax(250px, 42vh) minmax(170px, 28vh) !important;
  gap: 10px !important;
  max-height: calc(100vh - 155px) !important;
}

.lookbook-image-tile {
  height: 100% !important;
  min-height: 0 !important;
  border-radius: 20px !important;
  background-size: cover !important;
  background-position: center !important;
  border: 1px solid rgba(255,255,255,.72) !important;
  box-shadow: 0 18px 45px rgba(0,0,0,.16) !important;
}

.lookbook-image-tile:nth-child(1) {
  grid-column: 1 / -1 !important;
  grid-row: 1 !important;
}

.lookbook-image-tile:nth-child(2) {
  grid-column: 1 !important;
  grid-row: 2 !important;
}

.lookbook-image-tile:nth-child(3),
.lookbook-tile-wide {
  grid-column: 2 !important;
  grid-row: 2 !important;
}

.lookbook-arrow {
  display: none !important;
}

@media (max-height: 760px) and (min-width: 981px) {
  .lookbook-collection {
    padding-top: 84px !important;
    padding-bottom: 18px !important;
  }

  .lookbook-product {
    height: calc(100vh - 102px) !important;
  }

  .lookbook-info {
    padding: 20px 24px !important;
    max-height: calc(100vh - 108px) !important;
  }

  .lookbook-info h3 {
    font-size: clamp(42px, 3.6vw, 62px) !important;
  }

  .lookbook-mark {
    margin-bottom: 14px !important;
  }

  .lookbook-features {
    gap: 8px !important;
    margin: 12px 0 !important;
  }

  .lookbook-feature-icon {
    width: 34px !important;
    height: 34px !important;
  }

  .lookbook-selects select,
  .lookbook-cart-btn {
    height: 46px !important;
  }

  .lookbook-color-dot {
    width: 32px !important;
    height: 32px !important;
  }
}

@media (max-width: 1200px) and (min-width: 981px) {
  .lookbook-product {
    grid-template-columns: minmax(330px, 420px) minmax(170px, 1fr) minmax(310px, 420px) !important;
    gap: 24px !important;
  }

  .lookbook-info h3 {
    font-size: clamp(42px, 4vw, 62px) !important;
  }
}

@media (max-width: 980px) {
  .lookbook-collection {
    height: auto !important;
    min-height: 100vh !important;
    padding: 96px 18px 45px !important;
    overflow: visible !important;
  }

  .lookbook-filter-panel {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    justify-content: flex-start !important;
    margin-bottom: 22px !important;
  }

  .lookbook-product {
    height: auto !important;
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }

  .lookbook-info {
    max-width: 100% !important;
    width: 100% !important;
    margin-top: 0 !important;
    max-height: none !important;
  }

  .lookbook-center-space {
    display: none !important;
  }

  .lookbook-visuals {
    width: 100% !important;
    max-height: none !important;
  }

  .lookbook-collage {
    grid-template-rows: 260px 210px !important;
    max-height: none !important;
  }
}

/* =====================================================
   AJUSTE FINAL SOLICITADO: PANEL ARRIBA + FILTRO ARRIBA
   + FONDO COMPLETO TIPO HERO
===================================================== */

@media (min-width: 981px) {
  .lookbook-collection {
    height: 100vh !important;
    min-height: 100vh !important;
    padding: 86px clamp(24px, 3vw, 54px) 22px !important;
    display: flex !important;
    align-items: center !important;
    overflow: hidden !important;
  }

  .lookbook-collection .lookbook-bg-layer {
    opacity: 1 !important;
    filter: none !important;
    transform: none !important;
    background-image: var(--collection-bg) !important;
    background-size: contain !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    background-color: #f2e8dc !important;
  }

  .lookbook-collection .lookbook-bg-overlay {
    background: linear-gradient(
      90deg,
      rgba(255,255,255,.08) 0%,
      rgba(255,255,255,.03) 32%,
      rgba(255,255,255,0) 62%,
      rgba(0,0,0,.02) 100%
    ) !important;
  }

  .lookbook-stage.productos,
  .productos.lookbook-stage {
    width: 100% !important;
    height: 100% !important;
  }

  .lookbook-product {
    height: calc(100vh - 112px) !important;
    min-height: 0 !important;
    grid-template-columns: minmax(360px, 445px) minmax(330px, 1fr) minmax(340px, 455px) !important;
    gap: clamp(22px, 3vw, 52px) !important;
    align-items: center !important;
  }

  .lookbook-info {
    align-self: center !important;
    justify-self: start !important;
    margin-top: -42px !important;
    width: min(100%, 445px) !important;
    max-width: 445px !important;
    max-height: calc(100vh - 116px) !important;
    padding: clamp(20px, 1.85vw, 27px) !important;
    overflow: visible !important;
  }

  .lookbook-info h3 {
    font-size: clamp(45px, 3.9vw, 66px) !important;
    line-height: .84 !important;
    margin-bottom: 10px !important;
  }

  .lookbook-label {
    margin-bottom: 10px !important;
  }

  .lookbook-mark {
    margin-bottom: 15px !important;
  }

  .lookbook-fabric,
  .lookbook-description {
    font-size: 14px !important;
    line-height: 1.3 !important;
    margin-bottom: 8px !important;
  }

  .lookbook-features {
    gap: 8px !important;
    margin: 12px 0 !important;
  }

  .lookbook-features div {
    grid-template-columns: 36px 1fr !important;
    gap: 12px !important;
  }

  .lookbook-feature-icon {
    width: 34px !important;
    height: 34px !important;
    font-size: 16px !important;
  }

  .lookbook-features p {
    font-size: 12px !important;
    line-height: 1.22 !important;
  }

  .lookbook-line {
    margin: 11px 0 9px !important;
  }

  .lookbook-selects-redesign {
    gap: 8px !important;
    margin-bottom: 6px !important;
  }

  .lookbook-selects label {
    margin-bottom: 5px !important;
  }

  .lookbook-selects select {
    height: 44px !important;
  }

  .lookbook-color-dots {
    min-height: 38px !important;
    gap: 10px !important;
  }

  .lookbook-color-dot {
    width: 32px !important;
    height: 32px !important;
  }

  .lookbook-price {
    font-size: clamp(26px, 2.1vw, 32px) !important;
    margin: 6px 0 10px !important;
  }

  .lookbook-cart-btn {
    height: 50px !important;
  }

  .lookbook-center-space {
    height: 100% !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
  }

  .lookbook-visuals {
    align-self: center !important;
    justify-self: end !important;
    width: min(100%, 455px) !important;
    max-height: calc(100vh - 135px) !important;
    padding-top: 34px !important;
  }

  .lookbook-collage {
    grid-template-rows: minmax(235px, 40vh) minmax(160px, 25vh) !important;
    gap: 10px !important;
    max-height: calc(100vh - 150px) !important;
  }

  .lookbook-filter-panel {
    top: 82px !important;
    right: clamp(34px, 6.5vw, 118px) !important;
    z-index: 15 !important;
    transform: none !important;
  }

  .lookbook-filter-select {
    height: 50px !important;
  }
}

@media (max-height: 760px) and (min-width: 981px) {
  .lookbook-collection {
    padding-top: 76px !important;
    padding-bottom: 14px !important;
  }

  .lookbook-product {
    height: calc(100vh - 92px) !important;
  }

  .lookbook-info {
    margin-top: -52px !important;
    padding: 18px 24px !important;
    max-height: calc(100vh - 98px) !important;
  }

  .lookbook-info h3 {
    font-size: clamp(40px, 3.5vw, 58px) !important;
  }

  .lookbook-filter-panel {
    top: 72px !important;
  }

  .lookbook-visuals {
    padding-top: 24px !important;
  }
}


/* =====================================================
   COLECCIÓN NUEVO ESTILO EDITORIAL - REFERENCIA LAOS
   Mantiene: filtro, cambio de color, carrito, modal, flechas.
   Cambia: layout visual completo a fondo sólido + imagen central protagonista.
===================================================== */

.lookbook-collection {
  --editorial-bg: #f3eadf;
  --editorial-bg-2: #fbf6ef;
  --editorial-ink: #17120e;
  --editorial-muted: rgba(23,18,14,.72);
  --editorial-accent: #bf8a55;
  --editorial-line: rgba(164,112,68,.34);
  position: relative !important;
  min-height: 100vh !important;
  height: 100vh !important;
  padding: 92px clamp(26px, 3.8vw, 72px) 28px !important;
  overflow: hidden !important;
  background: radial-gradient(circle at 52% 45%, rgba(214,178,133,.22), transparent 30%), linear-gradient(90deg, #fbf6ee 0%, #f3eadf 45%, #f8f2ea 100%) !important;
}

.lookbook-collection .lookbook-bg-layer,
.lookbook-collection .lookbook-bg-overlay { display: none !important; }

.lookbook-collection::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background: linear-gradient(90deg, rgba(23,18,14,.10) 0 1px, transparent 1px) 29% 0 / 1px 100% no-repeat, radial-gradient(circle at 56% 46%, rgba(255,255,255,.78), transparent 34%) !important;
  opacity: 1 !important;
  z-index: 0 !important;
}

.lookbook-stage {
  position: relative !important;
  z-index: 2 !important;
  height: calc(100vh - 120px) !important;
  width: 100% !important;
  display: block !important;
}

.lookbook-product {
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(330px, 29%) minmax(420px, 42%) minmax(340px, 29%) !important;
  gap: clamp(24px, 3vw, 58px) !important;
  align-items: stretch !important;
}

.lookbook-info {
  position: relative !important;
  z-index: 3 !important;
  align-self: stretch !important;
  height: 100% !important;
  max-height: none !important;
  overflow: hidden !important;
  padding: clamp(24px, 3.2vh, 42px) clamp(24px, 3vw, 54px) !important;
  border-radius: 0 28px 28px 0 !important;
  border: 1px solid rgba(255,255,255,.75) !important;
  border-left: none !important;
  background: rgba(255,250,242,.72) !important;
  color: var(--editorial-ink) !important;
  backdrop-filter: blur(14px) !important;
  box-shadow: 0 30px 70px rgba(72,45,25,.08) !important;
}

.lookbook-label { color: var(--editorial-accent) !important; letter-spacing: 9px !important; font-size: clamp(11px, .82vw, 14px) !important; font-weight: 500 !important; text-transform: uppercase !important; }
.lookbook-mark { justify-content: flex-start !important; gap: 16px !important; margin: 18px 0 26px !important; color: var(--editorial-accent) !important; }
.lookbook-mark span { width: 70px !important; height: 1px !important; background: var(--editorial-line) !important; }
.lookbook-info h3 { color: var(--editorial-ink) !important; font-family: 'Cormorant Garamond', 'Cormorant Garamond', serif !important; font-size: clamp(48px, 5.3vw, 88px) !important; line-height: .88 !important; letter-spacing: -2px !important; max-width: 470px !important; margin-bottom: 18px !important; text-transform: uppercase !important; }
.lookbook-fabric, .lookbook-description { color: var(--editorial-muted) !important; font-size: clamp(13px, .95vw, 16px) !important; margin-bottom: 9px !important; }
.lookbook-features { display: grid !important; gap: 14px !important; margin: 26px 0 18px !important; }
.lookbook-features > div { display: grid !important; grid-template-columns: 42px 1fr !important; gap: 14px !important; align-items: center !important; }
.lookbook-feature-icon { width: 36px !important; height: 36px !important; border-radius: 50% !important; border: 1px solid rgba(191,138,85,.32) !important; display: flex !important; align-items: center !important; justify-content: center !important; color: var(--editorial-accent) !important; background: rgba(255,255,255,.35) !important; }
.lookbook-features p { color: rgba(23,18,14,.72) !important; font-size: 13px !important; line-height: 1.35 !important; }
.lookbook-line { height: 1px !important; background: var(--editorial-line) !important; margin: 18px 0 14px !important; }
.lookbook-selects { display: grid !important; grid-template-columns: 1fr !important; gap: 12px !important; }
.lookbook-selects label { display: block !important; color: #9f6739 !important; letter-spacing: 5px !important; font-size: 11px !important; text-transform: uppercase !important; margin-bottom: 8px !important; }
.lookbook-selects select { width: 100% !important; height: 50px !important; border-radius: 999px !important; border: 1px solid rgba(23,18,14,.14) !important; background: rgba(255,255,255,.82) !important; color: #17120e !important; padding: 0 20px !important; font-weight: 500 !important; box-shadow: inset 0 1px 0 rgba(255,255,255,.8) !important; }
.lookbook-color-dots { display: flex !important; gap: 12px !important; align-items: center !important; }
.lookbook-color-dot { width: 38px !important; height: 38px !important; border-radius: 50% !important; border: 1px solid rgba(23,18,14,.16) !important; background: var(--dot-color) !important; box-shadow: 0 8px 18px rgba(0,0,0,.12) !important; cursor: pointer !important; }
.lookbook-color-dot.active { outline: 2px solid #d5a066 !important; outline-offset: 5px !important; }
.lookbook-price { color: var(--editorial-ink) !important; font-family: 'Cormorant Garamond', 'Cormorant Garamond', serif !important; font-size: clamp(34px, 3vw, 48px) !important; line-height: 1 !important; margin: 20px 0 18px !important; }
.lookbook-cart-btn { width: 100% !important; height: 58px !important; border-radius: 999px !important; border: none !important; background: #1c1b18 !important; color: #fff !important; letter-spacing: 6px !important; text-transform: uppercase !important; font-size: 12px !important; font-weight: 700 !important; cursor: pointer !important; box-shadow: 0 18px 40px rgba(0,0,0,.18) !important; }
.lookbook-favorite { width: 100% !important; margin-top: 18px !important; border: none !important; background: transparent !important; color: rgba(23,18,14,.56) !important; letter-spacing: 5px !important; text-transform: uppercase !important; font-size: 11px !important; }

.lookbook-center-space { display: none !important; }
.lookbook-main-area { position: relative !important; z-index: 2 !important; height: 100% !important; min-height: 0 !important; display: flex !important; justify-content: center !important; align-items: flex-end !important; overflow: visible !important; }
.lookbook-main-area::before { content: "" !important; position: absolute !important; width: min(39vw, 620px) !important; height: min(39vw, 620px) !important; border-radius: 50% !important; background: radial-gradient(circle, rgba(255,255,255,.88), rgba(216,180,140,.22) 54%, transparent 72%) !important; filter: blur(2px) !important; bottom: 13% !important; z-index: -1 !important; }
.lookbook-main-img { display: block !important; height: calc(100vh - 122px) !important; max-height: calc(100vh - 122px) !important; width: auto !important; max-width: 100% !important; object-fit: contain !important; object-position: center bottom !important; cursor: zoom-in !important; transition: opacity .24s ease, transform .45s ease !important; filter: drop-shadow(0 34px 48px rgba(55,38,25,.18)) !important; }
.lookbook-main-img:hover { transform: scale(1.018) !important; }
.lookbook-main-arrow { position: absolute !important; top: 52% !important; transform: translateY(-50%) !important; width: 56px !important; height: 56px !important; border-radius: 50% !important; border: none !important; background: rgba(255,255,255,.68) !important; color: #17120e !important; font-size: 46px !important; line-height: 1 !important; cursor: pointer !important; box-shadow: 0 16px 40px rgba(68,44,24,.10) !important; z-index: 3 !important; transition: .28s ease !important; }
.lookbook-main-arrow:hover { background: #1c1b18 !important; color: #fff !important; }
.lookbook-main-prev { left: 2% !important; }
.lookbook-main-next { right: 2% !important; }
.lookbook-counter { position: absolute !important; bottom: 20px !important; left: 50% !important; transform: translateX(-50%) !important; display: flex !important; align-items: center !important; gap: 12px !important; color: #fff !important; font-size: 14px !important; letter-spacing: 2px !important; text-shadow: 0 2px 16px rgba(0,0,0,.28) !important; }
.lookbook-counter i { display: block !important; width: 34px !important; height: 1px !important; background: rgba(255,255,255,.7) !important; }

.lookbook-visuals { position: relative !important; z-index: 3 !important; width: 100% !important; height: 100% !important; display: flex !important; flex-direction: column !important; justify-content: flex-start !important; padding-top: 92px !important; }
.lookbook-collage { width: 100% !important; display: grid !important; grid-template-columns: 1fr 1fr !important; grid-template-rows: minmax(210px, 34vh) minmax(150px, 24vh) !important; gap: 12px !important; max-height: none !important; }
.lookbook-image-tile { border: none !important; border-radius: 18px !important; background-size: cover !important; background-position: center !important; box-shadow: 0 18px 40px rgba(75,49,27,.12) !important; cursor: zoom-in !important; }
.lookbook-image-tile:nth-child(1) { grid-column: 1 / -1 !important; grid-row: 1 !important; }
.lookbook-image-tile:nth-child(2) { grid-column: 1 !important; grid-row: 2 !important; }
.lookbook-image-tile:nth-child(3), .lookbook-tile-wide { grid-column: 2 !important; grid-row: 2 !important; }
.lookbook-mini-progress { display: flex !important; justify-content: center !important; gap: 12px !important; margin: 24px 0 !important; }
.lookbook-mini-progress span { width: 38px !important; height: 4px !important; border-radius: 999px !important; background: rgba(23,18,14,.10) !important; }
.lookbook-mini-progress span.active { background: #c3915e !important; }
.lookbook-benefits { background: rgba(255,255,255,.60) !important; border: 1px solid rgba(255,255,255,.76) !important; border-radius: 20px !important; padding: 18px 22px !important; display: grid !important; gap: 14px !important; box-shadow: 0 20px 55px rgba(72,45,25,.08) !important; backdrop-filter: blur(12px) !important; }
.lookbook-benefits > div { display: grid !important; grid-template-columns: 42px 1fr !important; gap: 14px !important; align-items: center !important; }
.lookbook-benefits span { color: rgba(23,18,14,.62) !important; font-size: 25px !important; }
.lookbook-benefits p { margin: 0 !important; display: grid !important; gap: 2px !important; }
.lookbook-benefits strong { color: #17120e !important; font-size: 14px !important; }
.lookbook-benefits small { color: rgba(23,18,14,.60) !important; font-size: 12px !important; }
.lookbook-safe-buy { margin-top: 18px !important; text-align: center !important; color: rgba(23,18,14,.56) !important; letter-spacing: 5px !important; text-transform: uppercase !important; font-size: 11px !important; }

.lookbook-filter-panel { position: absolute !important; top: 118px !important; right: clamp(38px, 4.2vw, 72px) !important; z-index: 8 !important; display: flex !important; align-items: center !important; gap: 20px !important; width: auto !important; padding: 0 !important; margin: 0 !important; }
.lookbook-filter-panel label { color: #a46b42 !important; text-shadow: none !important; letter-spacing: 6px !important; font-size: 12px !important; font-weight: 700 !important; text-transform: uppercase !important; }
.lookbook-filter-select { min-width: 220px !important; height: 56px !important; border-radius: 999px !important; border: none !important; padding: 0 46px 0 24px !important; background: rgba(255,255,255,.78) !important; color: #17120e !important; font-weight: 600 !important; box-shadow: 0 18px 40px rgba(72,45,25,.08) !important; }
.lookbook-arrow { display: none !important; }

@media (max-width: 1280px) and (min-width: 981px) {
  .lookbook-product { grid-template-columns: minmax(300px, 31%) minmax(360px, 39%) minmax(300px, 30%) !important; gap: 24px !important; }
  .lookbook-info h3 { font-size: clamp(42px, 4.6vw, 70px) !important; }
  .lookbook-visuals { padding-top: 84px !important; }
}

@media (max-height: 780px) and (min-width: 981px) {
  .lookbook-info { padding-top: 20px !important; padding-bottom: 20px !important; }
  .lookbook-info h3 { font-size: clamp(40px, 4.2vw, 64px) !important; }
  .lookbook-features { margin: 16px 0 12px !important; gap: 8px !important; }
  .lookbook-selects select, .lookbook-cart-btn { height: 48px !important; }
  .lookbook-main-img { height: calc(100vh - 110px) !important; max-height: calc(100vh - 110px) !important; }
  .lookbook-collage { grid-template-rows: minmax(190px, 31vh) minmax(130px, 21vh) !important; }
  .lookbook-benefits { gap: 8px !important; padding: 14px 18px !important; }
}

@media (max-width: 980px) {
  .lookbook-collection { height: auto !important; min-height: 100vh !important; padding: 96px 18px 48px !important; overflow: visible !important; }
  .lookbook-filter-panel { position: relative !important; top: auto !important; right: auto !important; width: 100% !important; justify-content: flex-start !important; margin-bottom: 24px !important; }
  .lookbook-product { grid-template-columns: 1fr !important; height: auto !important; gap: 28px !important; }
  .lookbook-info { border-radius: 24px !important; border-left: 1px solid rgba(255,255,255,.75) !important; height: auto !important; }
  .lookbook-main-area { min-height: 620px !important; align-items: flex-end !important; }
  .lookbook-main-img { height: 620px !important; max-height: 72vh !important; }
  .lookbook-visuals { padding-top: 0 !important; }
  .lookbook-collage { grid-template-rows: 260px 210px !important; }
}

@media (max-width: 600px) {
  .lookbook-info h3 { font-size: 46px !important; }
  .lookbook-filter-panel { flex-direction: column !important; align-items: flex-start !important; }
  .lookbook-filter-select { width: 100% !important; }
  .lookbook-main-area { min-height: 500px !important; }
  .lookbook-main-img { height: 500px !important; }
  .lookbook-main-arrow { width: 46px !important; height: 46px !important; font-size: 34px !important; }
  .lookbook-collage { grid-template-rows: 230px 170px !important; }
}

/* ===============================
   PULIDO GENERAL 2026
================================ */

:root {
  --laos-ink: #17120e;
  --laos-paper: #fbf7f1;
  --laos-gold: #c3915e;
  --laos-rose: #9f3f52;
  --laos-muted: rgba(23, 18, 14, .66);
  --laos-focus: #f2c27b;
}

html {
  scroll-padding-top: 96px;
}

body {
  font-family: 'Manrope', sans-serif !important;
  text-rendering: optimizeLegibility;
}

button,
input,
select,
textarea {
  font: inherit;
}

button:disabled,
.btn:disabled {
  cursor: not-allowed !important;
  opacity: .62 !important;
  transform: none !important;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid var(--laos-focus) !important;
  outline-offset: 4px !important;
}

.menu-btn span {
  pointer-events: none;
}

.galeria-item {
  border: 0 !important;
  padding: 0 !important;
  font: inherit !important;
  color: inherit !important;
  text-align: left !important;
  cursor: pointer !important;
}

.galeria-item img {
  transition: transform .45s ease, filter .45s ease;
}

.galeria-item:hover img {
  transform: scale(1.04);
  filter: saturate(1.05) contrast(1.04);
}

.empty-products {
  width: 100%;
  color: var(--laos-muted);
}

#opinionMessage,
#loginMessage {
  min-height: 22px;
  margin-top: 12px;
  color: var(--laos-rose);
  font-size: 14px;
}

.admin-form input,
.admin-form select,
.admin-form textarea,
.formulario input,
.formulario textarea,
.opinion-callout input,
.opinion-callout select,
.opinion-callout textarea {
  transition: border-color .25s ease, box-shadow .25s ease, background .25s ease;
}

.admin-form input:focus,
.admin-form select:focus,
.admin-form textarea:focus,
.formulario input:focus,
.formulario textarea:focus,
.opinion-callout input:focus,
.opinion-callout select:focus,
.opinion-callout textarea:focus {
  border-color: var(--laos-gold) !important;
  box-shadow: 0 0 0 4px rgba(195, 145, 94, .14) !important;
}

.lookbook-cart-btn,
.checkout-btn,
.signature-btn,
.btn {
  min-height: 44px;
}

.cart-item-info h4,
.lookbook-info h3,
.section-title h2 {
  overflow-wrap: anywhere;
}

@media (max-width: 768px) {
  html {
    scroll-padding-top: 84px;
  }

  .hero {
    min-height: 100svh;
  }

  .hero-premium-content {
    padding-top: 84px;
  }

  .brand-center {
    max-width: calc(100vw - 150px);
  }

  .brand-center h1 {
    max-width: 130px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .lookbook-info h3 {
    letter-spacing: 0 !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }

  .intro-signature {
    display: none !important;
  }
}

/* ===============================
   REDISEÑO BOUTIQUE LAOS
================================ */

:root {
  --laos-ink: #161113;
  --laos-night: #0f0c0d;
  --laos-wine: #6f2437;
  --laos-berry: #9f3f52;
  --laos-clay: #b87358;
  --laos-gold: #d6ad78;
  --laos-ivory: #fff8ee;
  --laos-blush: #f5e4dc;
  --laos-paper: #fbf5eb;
  --laos-muted: rgba(22, 17, 19, .68);
  --laos-line: rgba(111, 36, 55, .16);
}

body {
  background:
    linear-gradient(180deg, #fff8ee 0%, #f5e4dc 42%, #fff8ee 100%) !important;
  color: var(--laos-ink) !important;
  font-family: 'Manrope', sans-serif !important;
}

h1,
h2,
h3,
.brand-center h1,
.logo-text h1,
.section-title h2,
.hero-content h2,
.premium-content h2,
.cart-header h2 {
  font-family: 'Cormorant Garamond', serif !important;
  letter-spacing: 0 !important;
}

.header {
  height: 86px !important;
  background: rgba(15, 12, 13, .72) !important;
  border-bottom: 1px solid rgba(214, 173, 120, .22) !important;
  box-shadow: 0 18px 44px rgba(15, 12, 13, .26) !important;
}

.brand-center h1 {
  font-size: clamp(27px, 2.4vw, 40px) !important;
  font-weight: 700 !important;
}

.brand-center .logo {
  filter: drop-shadow(0 0 18px rgba(214, 173, 120, .22)) !important;
}

.nav a {
  font-size: 13px !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}

.header-cart,
.menu-btn {
  border-color: rgba(255, 248, 238, .16) !important;
  background: rgba(255, 248, 238, .08) !important;
}

.cart-icon-wrap {
  background: linear-gradient(135deg, var(--laos-gold), var(--laos-berry)) !important;
}

.hero {
  min-height: 100svh !important;
  padding: 112px clamp(20px, 6vw, 82px) 72px !important;
  background: var(--laos-night) !important;
}

.hero-slide {
  filter: saturate(.86) contrast(1.12) sepia(.12) brightness(.78) !important;
  background-position: center top !important;
}

.hero-overlay {
  background:
    linear-gradient(90deg, rgba(15, 12, 13, .88) 0%, rgba(50, 24, 29, .64) 42%, rgba(15, 12, 13, .16) 100%),
    radial-gradient(circle at 72% 42%, rgba(214, 173, 120, .24), transparent 34%) !important;
}

.hero-premium-content {
  max-width: 680px !important;
}

.hero-content .tag,
.section-kicker,
.premium-label,
.sobre-label,
.section-title span {
  color: var(--laos-wine) !important;
  letter-spacing: .32em !important;
  font-weight: 800 !important;
}

.hero-content .tag {
  color: #f0c892 !important;
}

.hero-content h2 {
  font-size: clamp(58px, 8vw, 112px) !important;
  line-height: .82 !important;
  max-width: 820px !important;
  text-shadow: 0 20px 60px rgba(0, 0, 0, .32) !important;
}

.hero-content p {
  max-width: 590px !important;
  font-size: clamp(16px, 1.4vw, 21px) !important;
  line-height: 1.72 !important;
  color: rgba(255, 248, 238, .88) !important;
}

.btn,
.hero-buttons .btn,
.checkout-btn,
.collection-add-btn {
  background: linear-gradient(135deg, var(--laos-night), #322026) !important;
  color: #fff8ee !important;
  border: 1px solid rgba(214, 173, 120, .28) !important;
  box-shadow: 0 18px 42px rgba(15, 12, 13, .18) !important;
}

.btn:hover,
.checkout-btn:hover,
.collection-add-btn:hover {
  background: linear-gradient(135deg, var(--laos-wine), var(--laos-clay)) !important;
  color: #fff !important;
}

.btn-outline,
.hero-buttons .btn-outline {
  background: rgba(255, 248, 238, .08) !important;
  color: #fff8ee !important;
  border: 1px solid rgba(255, 248, 238, .52) !important;
}

.collection-boutique {
  position: relative !important;
  min-height: auto !important;
  height: auto !important;
  padding: clamp(82px, 9vw, 132px) clamp(18px, 5vw, 76px) !important;
  overflow: hidden !important;
  background:
    linear-gradient(135deg, rgba(255, 248, 238, .96), rgba(245, 228, 220, .94)),
    radial-gradient(circle at 82% 12%, rgba(159, 63, 82, .22), transparent 30%),
    radial-gradient(circle at 10% 90%, rgba(214, 173, 120, .18), transparent 36%) !important;
  color: var(--laos-ink) !important;
}

.collection-boutique::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg, rgba(111, 36, 55, .055) 1px, transparent 1px),
    linear-gradient(180deg, rgba(111, 36, 55, .045) 1px, transparent 1px) !important;
  background-size: 72px 72px !important;
  mask-image: linear-gradient(180deg, transparent, #000 12%, #000 84%, transparent) !important;
}

.collection-shell {
  position: relative !important;
  z-index: 1 !important;
  max-width: 1440px !important;
  margin: 0 auto !important;
}

.collection-header {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 430px) !important;
  gap: clamp(24px, 4vw, 76px) !important;
  align-items: end !important;
  margin-bottom: 34px !important;
}

.collection-header .section-kicker {
  grid-column: 1 / -1 !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
}

.collection-header h2 {
  max-width: 840px !important;
  margin: 0 !important;
  color: var(--laos-ink) !important;
  font-size: clamp(48px, 6vw, 94px) !important;
  line-height: .9 !important;
  font-weight: 700 !important;
}

.collection-header p {
  max-width: 650px !important;
  margin: 22px 0 0 !important;
  color: var(--laos-muted) !important;
  font-size: 16px !important;
  line-height: 1.8 !important;
}

.collection-metrics {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 12px !important;
}

.collection-metrics span {
  min-height: 96px !important;
  border: 1px solid rgba(111, 36, 55, .13) !important;
  background: rgba(255, 255, 255, .48) !important;
  display: grid !important;
  place-items: center !important;
  text-align: center !important;
  padding: 14px !important;
  color: var(--laos-muted) !important;
  border-radius: 8px !important;
  backdrop-filter: blur(10px) !important;
}

.collection-metrics strong {
  display: block !important;
  color: var(--laos-wine) !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 30px !important;
  line-height: 1 !important;
}

.collection-toolbar {
  display: grid !important;
  grid-template-columns: minmax(260px, 360px) 1fr auto !important;
  gap: 16px !important;
  align-items: center !important;
  padding: 14px !important;
  margin: 34px 0 16px !important;
  border: 1px solid rgba(111, 36, 55, .13) !important;
  background: rgba(255, 255, 255, .56) !important;
  border-radius: 12px !important;
  box-shadow: 0 24px 70px rgba(111, 36, 55, .08) !important;
  backdrop-filter: blur(18px) !important;
}

.collection-search-field,
.collection-select-wrap {
  display: grid !important;
  gap: 6px !important;
}

.collection-search-field span,
.collection-select-wrap span {
  color: var(--laos-wine) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
}

.collection-search-field input,
.collection-select-wrap select {
  width: 100% !important;
  height: 48px !important;
  border: 1px solid rgba(111, 36, 55, .16) !important;
  border-radius: 8px !important;
  background: rgba(255, 248, 238, .88) !important;
  color: var(--laos-ink) !important;
  padding: 0 16px !important;
  outline: none !important;
  box-shadow: none !important;
}

.collection-categories {
  display: flex !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  align-items: center !important;
}

.collection-filter {
  height: 42px !important;
  padding: 0 16px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(111, 36, 55, .15) !important;
  background: transparent !important;
  color: rgba(22, 17, 19, .74) !important;
  cursor: pointer !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  transition: transform .24s ease, background .24s ease, color .24s ease !important;
}

.collection-filter:hover,
.collection-filter.active {
  transform: translateY(-1px) !important;
  background: var(--laos-wine) !important;
  color: #fff8ee !important;
  border-color: var(--laos-wine) !important;
}

.visually-hidden-collection {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
}

.collection-results-meta {
  min-height: 22px !important;
  margin: 0 0 22px !important;
  color: rgba(22, 17, 19, .58) !important;
  font-size: 13px !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  font-weight: 800 !important;
}

.collection-grid,
.productos.collection-grid {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: clamp(18px, 2vw, 28px) !important;
  min-height: 0 !important;
  height: auto !important;
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.collection-card {
  position: relative !important;
  display: grid !important;
  grid-template-rows: auto 1fr !important;
  overflow: hidden !important;
  border-radius: 10px !important;
  background: rgba(255, 255, 255, .66) !important;
  border: 1px solid rgba(111, 36, 55, .12) !important;
  box-shadow: 0 24px 70px rgba(83, 33, 45, .10) !important;
  transform: translateZ(0) !important;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease !important;
}

.collection-card:hover {
  transform: translateY(-8px) !important;
  border-color: rgba(111, 36, 55, .28) !important;
  box-shadow: 0 32px 90px rgba(83, 33, 45, .16) !important;
}

.collection-card-featured {
  grid-column: span 2 !important;
  grid-row: span 2 !important;
}

.collection-card-media {
  position: relative !important;
  background:
    radial-gradient(circle at 50% 28%, rgba(214, 173, 120, .24), transparent 44%),
    linear-gradient(180deg, #f6e8dc, #fff8ee) !important;
}

.collection-image-btn {
  width: 100% !important;
  display: block !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  cursor: zoom-in !important;
  overflow: hidden !important;
}

.collection-slider-btn {
  position: absolute !important;
  top: 50% !important;
  z-index: 4 !important;
  width: 38px !important;
  height: 38px !important;
  display: grid !important;
  place-items: center !important;
  transform: translateY(-50%) !important;
  border: 1px solid rgba(255, 248, 238, .42) !important;
  border-radius: 50% !important;
  background: rgba(15, 12, 13, .70) !important;
  color: #fff8ee !important;
  font-size: 28px !important;
  line-height: 1 !important;
  cursor: pointer !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity .24s ease, background .24s ease, transform .24s ease !important;
}

.collection-slider-prev {
  left: 14px !important;
}

.collection-slider-next {
  right: 14px !important;
}

.collection-card-slider:hover .collection-slider-btn,
.collection-card-slider:focus-within .collection-slider-btn {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.collection-card-slider .collection-slider-btn:hover {
  background: rgba(15, 12, 13, .92) !important;
  transform: translateY(-50%) scale(1.06) !important;
}

.collection-slider-dots {
  position: absolute !important;
  left: 50% !important;
  bottom: 14px !important;
  z-index: 4 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
  transform: translateX(-50%) !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity .24s ease !important;
}

.collection-card-slider:hover .collection-slider-dots,
.collection-card-slider:focus-within .collection-slider-dots {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.collection-slider-dot {
  width: 8px !important;
  height: 8px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(255, 248, 238, .72) !important;
  cursor: pointer !important;
  box-shadow: 0 6px 18px rgba(15, 12, 13, .24) !important;
  transition: width .24s ease, background .24s ease !important;
}

.collection-slider-dot.active {
  width: 22px !important;
  background: var(--laos-wine) !important;
}

.collection-card-media img {
  width: 100% !important;
  aspect-ratio: 4 / 5 !important;
  object-fit: cover !important;
  object-position: center top !important;
  filter: saturate(.94) contrast(1.06) sepia(.06) brightness(.98) !important;
  transition: transform .5s ease, filter .5s ease, opacity .2s ease !important;
}

.collection-card-featured .collection-card-media img {
  aspect-ratio: 1 / 1.04 !important;
}

.collection-card:hover .collection-card-media img {
  transform: scale(1.045) !important;
  filter: saturate(1.02) contrast(1.08) sepia(.04) brightness(1) !important;
}

.collection-badge,
.collection-stock {
  position: absolute !important;
  z-index: 2 !important;
  top: 14px !important;
  padding: 8px 11px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  backdrop-filter: blur(10px) !important;
}

.collection-badge {
  left: 14px !important;
  background: rgba(15, 12, 13, .78) !important;
  color: #fff8ee !important;
}

.collection-stock {
  right: 14px !important;
  background: rgba(255, 248, 238, .78) !important;
  color: var(--laos-wine) !important;
}

.collection-card-body {
  display: grid !important;
  gap: 16px !important;
  padding: 22px !important;
}

.collection-title-row {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  gap: 16px !important;
  align-items: start !important;
}

.collection-title-row h3 {
  margin: 0 !important;
  color: var(--laos-ink) !important;
  font-size: clamp(29px, 2.2vw, 42px) !important;
  line-height: .9 !important;
  font-weight: 700 !important;
}

.collection-title-row strong {
  white-space: nowrap !important;
  color: var(--laos-wine) !important;
  font-size: 18px !important;
}

.collection-card-body > p {
  margin: 0 !important;
  color: var(--laos-muted) !important;
  line-height: 1.65 !important;
  font-size: 14px !important;
}

.collection-options {
  display: grid !important;
  grid-template-columns: minmax(120px, .8fr) 1.2fr !important;
  gap: 14px !important;
  align-items: end !important;
}

.collection-options label,
.collection-color-field {
  display: grid !important;
  gap: 8px !important;
}

.collection-options span,
.collection-color-field > span {
  color: var(--laos-wine) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
}

.collection-options select {
  width: 100% !important;
  height: 44px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(111, 36, 55, .16) !important;
  background: #fff8ee !important;
  color: var(--laos-ink) !important;
  padding: 0 12px !important;
}

.collection-color-dots {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
  min-height: 44px !important;
}

.collection-color-dot {
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  border: 2px solid rgba(255, 248, 238, .9) !important;
  background: var(--dot-color) !important;
  cursor: pointer !important;
  box-shadow: 0 8px 18px rgba(15, 12, 13, .14) !important;
}

.collection-color-dot.active {
  outline: 2px solid var(--laos-wine) !important;
  outline-offset: 4px !important;
}

.collection-actions {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  gap: 10px !important;
  align-items: center !important;
}

.collection-add-btn {
  width: 100% !important;
  min-height: 48px !important;
  border-radius: 8px !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  font-size: 12px !important;
  font-weight: 900 !important;
}

.collection-detail-btn {
  min-height: 48px !important;
  padding: 0 16px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(111, 36, 55, .18) !important;
  background: rgba(255, 248, 238, .74) !important;
  color: var(--laos-wine) !important;
  cursor: pointer !important;
  font-weight: 900 !important;
}

.collection-add-btn,
.collection-detail-btn {
  white-space: nowrap !important;
  font-size: 12px !important;
}

.collection-empty {
  grid-column: 1 / -1 !important;
  min-height: 320px !important;
  display: grid !important;
  place-items: center !important;
  text-align: center !important;
  border: 1px dashed rgba(111, 36, 55, .22) !important;
  border-radius: 12px !important;
  background: rgba(255, 255, 255, .42) !important;
}

.premium-video {
  height: clamp(420px, 48vw, 620px) !important;
}

.premium-overlay {
  background:
    linear-gradient(90deg, rgba(15, 12, 13, .86), rgba(111, 36, 55, .42)),
    rgba(0, 0, 0, .24) !important;
}

.premium-bg-video {
  filter: saturate(.85) contrast(1.08) sepia(.1) !important;
}

.premium-content h2,
.section-title h2 {
  color: var(--laos-ink) !important;
  font-size: clamp(42px, 5.4vw, 82px) !important;
  line-height: .92 !important;
}

.premium-content h2,
.premium-content p {
  color: #fff8ee !important;
}

.sobre,
.testimonios,
.contacto,
.galeria {
  background: transparent !important;
}

.sobre-content,
.contacto-content,
.opinion-callout,
.testimonio,
.servicio,
.admin-box,
.admin-dashboard {
  border-radius: 10px !important;
  border: 1px solid rgba(111, 36, 55, .12) !important;
  box-shadow: 0 24px 70px rgba(83, 33, 45, .08) !important;
}

.galeria-item {
  border-radius: 10px !important;
  box-shadow: 0 24px 70px rgba(83, 33, 45, .12) !important;
}

.galeria-overlay {
  background: linear-gradient(180deg, transparent, rgba(15, 12, 13, .78)) !important;
}

.lightbox {
  background: rgba(15, 12, 13, .88) !important;
  backdrop-filter: blur(14px) !important;
}

@media (max-width: 1180px) {
  .collection-grid,
  .productos.collection-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .collection-card-featured {
    grid-column: span 2 !important;
  }

  .collection-toolbar {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 820px) {
  .collection-card-slider .collection-slider-btn,
  .collection-card-slider .collection-slider-dots {
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  .collection-slider-btn {
    width: 34px !important;
    height: 34px !important;
    font-size: 24px !important;
  }

  .collection-slider-prev {
    left: 10px !important;
  }

  .collection-slider-next {
    right: 10px !important;
  }

  .collection-slider-dots {
    bottom: 10px !important;
  }

  .header {
    height: 78px !important;
    padding: 0 14px !important;
  }

  .hero {
    padding: 100px 20px 56px !important;
  }

  .hero-content h2 {
    font-size: clamp(54px, 15vw, 72px) !important;
  }

  .collection-boutique {
    padding: 78px 16px !important;
  }

  .collection-header {
    grid-template-columns: 1fr !important;
  }

  .collection-metrics {
    grid-template-columns: 1fr 1fr 1fr !important;
  }

  .collection-metrics span {
    min-height: 78px !important;
    font-size: 12px !important;
  }

  .collection-metrics strong {
    font-size: 24px !important;
  }

  .collection-grid,
  .productos.collection-grid {
    grid-template-columns: 1fr 1fr !important;
  }

  .collection-card-featured {
    grid-column: 1 / -1 !important;
  }

  .collection-title-row {
    grid-template-columns: 1fr !important;
  }

  .collection-options,
  .collection-actions {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 560px) {
  .brand-center {
    max-width: 198px !important;
    gap: 9px !important;
  }

  .brand-center .logo {
    height: 42px !important;
  }

  .brand-center h1 {
    font-size: 22px !important;
    max-width: 124px !important;
  }

  .logo-text p {
    font-size: 8px !important;
    letter-spacing: 3px !important;
  }

  .collection-header h2 {
    font-size: 45px !important;
  }

  .collection-toolbar {
    padding: 12px !important;
  }

  .collection-categories {
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    padding: 0 2px 4px !important;
    scrollbar-width: none !important;
  }

  .collection-categories::-webkit-scrollbar {
    display: none !important;
  }

  .collection-filter {
    flex: 0 0 auto !important;
  }

  .collection-grid,
  .productos.collection-grid {
    grid-template-columns: 1fr !important;
  }

  .collection-card-body {
    padding: 18px !important;
  }
}

/* ===============================
   CAPA DE CONVERSION PREMIUM
================================ */

body.modal-open {
  overflow: hidden !important;
}

.quick-view {
  position: fixed !important;
  inset: 0 !important;
  z-index: 1000000 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  padding: clamp(16px, 4vw, 54px) !important;
  background: rgba(15, 12, 13, .72) !important;
  backdrop-filter: blur(16px) !important;
}

.quick-view.active {
  display: flex !important;
}

.quick-view-panel {
  position: relative !important;
  width: min(1080px, 100%) !important;
  max-height: min(780px, 92vh) !important;
  display: grid !important;
  grid-template-columns: minmax(300px, .92fr) minmax(320px, 1fr) !important;
  overflow: hidden !important;
  border-radius: 14px !important;
  background: linear-gradient(135deg, #fff8ee, #f4e1d9) !important;
  box-shadow: 0 40px 110px rgba(0, 0, 0, .36) !important;
}

.quick-view-close {
  position: absolute !important;
  top: 16px !important;
  right: 16px !important;
  z-index: 4 !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  border: 1px solid rgba(255, 248, 238, .28) !important;
  background: rgba(15, 12, 13, .78) !important;
  color: #fff8ee !important;
  font-size: 28px !important;
  cursor: pointer !important;
}

.quick-view-media {
  min-height: 560px !important;
  background:
    radial-gradient(circle at 50% 20%, rgba(214, 173, 120, .24), transparent 42%),
    #edd7cd !important;
}

.quick-view-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center top !important;
  filter: saturate(.96) contrast(1.06) sepia(.05) !important;
}

.quick-view-content {
  display: flex !important;
  flex-direction: column !important;
  gap: 18px !important;
  padding: clamp(28px, 4vw, 58px) !important;
  overflow-y: auto !important;
}

.quick-view-kicker {
  color: var(--laos-wine) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .28em !important;
  text-transform: uppercase !important;
}

.quick-view-content h2 {
  margin: 0 !important;
  color: var(--laos-ink) !important;
  font-size: clamp(46px, 5vw, 74px) !important;
  line-height: .84 !important;
}

.quick-view-content p {
  margin: 0 !important;
  color: var(--laos-muted) !important;
  font-size: 15px !important;
  line-height: 1.75 !important;
}

.quick-view-price {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 18px 0 !important;
  border-top: 1px solid var(--laos-line) !important;
  border-bottom: 1px solid var(--laos-line) !important;
}

.quick-view-price span {
  color: var(--laos-muted) !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .16em !important;
  font-size: 11px !important;
}

.quick-view-price strong {
  color: var(--laos-wine) !important;
  font-size: 28px !important;
}

.quick-view-selects {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 14px !important;
}

.quick-view-selects label {
  display: grid !important;
  gap: 8px !important;
}

.quick-view-selects span {
  color: var(--laos-wine) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
}

.quick-view-selects select {
  height: 50px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(111, 36, 55, .16) !important;
  background: rgba(255, 248, 238, .84) !important;
  color: var(--laos-ink) !important;
  padding: 0 14px !important;
}

.quick-view-notes {
  display: grid !important;
  gap: 10px !important;
  color: rgba(22, 17, 19, .66) !important;
  font-size: 13px !important;
}

.quick-view-notes span {
  position: relative !important;
  padding-left: 22px !important;
}

.quick-view-notes span::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: .7em !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: var(--laos-wine) !important;
}

.quick-view-add,
.quick-view-whatsapp {
  min-height: 52px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 8px !important;
  text-decoration: none !important;
  font-weight: 900 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
}

.quick-view-add {
  border: 0 !important;
  background: linear-gradient(135deg, var(--laos-night), var(--laos-wine)) !important;
  color: #fff8ee !important;
  cursor: pointer !important;
}

.quick-view-whatsapp {
  border: 1px solid rgba(111, 36, 55, .18) !important;
  color: var(--laos-wine) !important;
  background: rgba(255, 248, 238, .64) !important;
}

.hero-proof {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin-top: 30px !important;
}

.hero-proof span {
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: rgba(255, 248, 238, .10) !important;
  border: 1px solid rgba(255, 248, 238, .18) !important;
  color: rgba(255, 248, 238, .86) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.trust-ribbon {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 1px !important;
  background: var(--laos-wine) !important;
}

.trust-ribbon div {
  min-height: 132px !important;
  display: grid !important;
  align-content: center !important;
  gap: 8px !important;
  padding: 28px clamp(20px, 4vw, 52px) !important;
  background: #171113 !important;
}

.trust-ribbon strong {
  color: #fff8ee !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 30px !important;
  line-height: 1 !important;
}

.trust-ribbon span {
  color: rgba(255, 248, 238, .68) !important;
  line-height: 1.6 !important;
}

.style-advisor {
  display: grid !important;
  grid-template-columns: minmax(300px, .9fr) minmax(320px, 1fr) !important;
  gap: clamp(28px, 5vw, 82px) !important;
  align-items: center !important;
  padding: clamp(80px, 9vw, 140px) clamp(18px, 6vw, 86px) !important;
  background: linear-gradient(135deg, #171113, #321820 58%, #6f2437) !important;
  color: #fff8ee !important;
}

.advisor-media {
  height: 620px !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  box-shadow: 0 34px 90px rgba(0, 0, 0, .28) !important;
}

.advisor-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  filter: saturate(.9) contrast(1.08) sepia(.08) !important;
}

.advisor-content {
  max-width: 680px !important;
}

.advisor-content .section-kicker {
  color: #f0c892 !important;
}

.advisor-content h2 {
  margin: 16px 0 22px !important;
  color: #fff8ee !important;
  font-size: clamp(48px, 6vw, 88px) !important;
  line-height: .88 !important;
}

.advisor-content p {
  color: rgba(255, 248, 238, .76) !important;
  font-size: 17px !important;
  line-height: 1.8 !important;
}

.advisor-steps {
  display: grid !important;
  gap: 14px !important;
  margin: 32px 0 !important;
}

.advisor-steps div {
  display: grid !important;
  grid-template-columns: 54px 1fr !important;
  gap: 16px !important;
  align-items: center !important;
  padding: 18px 0 !important;
  border-top: 1px solid rgba(255, 248, 238, .16) !important;
}

.advisor-steps strong {
  color: #f0c892 !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 34px !important;
}

.advisor-steps span {
  color: rgba(255, 248, 238, .82) !important;
}

.advisor-btn {
  width: fit-content !important;
  background: #fff8ee !important;
  color: var(--laos-wine) !important;
}

.atelier-signature {
  display: grid !important;
  gap: 4px !important;
  margin: 26px 0 !important;
  padding: 22px !important;
  border-left: 3px solid var(--laos-wine) !important;
  background: rgba(111, 36, 55, .06) !important;
}

.atelier-signature span {
  color: var(--laos-wine) !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: .18em !important;
  font-weight: 900 !important;
}

.atelier-signature strong {
  color: var(--laos-ink) !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 30px !important;
}

.social-proof-strip {
  max-width: 980px !important;
  margin: 34px auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 18px !important;
  padding: 22px !important;
  border-top: 1px solid var(--laos-line) !important;
  border-bottom: 1px solid var(--laos-line) !important;
  text-align: center !important;
}

.social-proof-strip span {
  color: var(--laos-wine) !important;
  letter-spacing: .18em !important;
}

.social-proof-strip p {
  margin: 0 !important;
  color: var(--laos-muted) !important;
}

.contact-card-list {
  display: grid !important;
  gap: 10px !important;
  margin-top: 22px !important;
}

.contact-card-list span {
  padding: 12px 14px !important;
  border-radius: 8px !important;
  background: rgba(255, 248, 238, .62) !important;
  color: var(--laos-wine) !important;
  font-weight: 800 !important;
}

.faq-section {
  padding: clamp(76px, 8vw, 118px) clamp(18px, 6vw, 86px) !important;
  background: linear-gradient(180deg, #fff8ee, #f5e4dc) !important;
}

.faq-grid {
  max-width: 1180px !important;
  margin: 40px auto 0 !important;
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 18px !important;
}

.faq-grid div {
  padding: 30px !important;
  border-radius: 10px !important;
  border: 1px solid rgba(111, 36, 55, .12) !important;
  background: rgba(255, 255, 255, .56) !important;
}

.faq-grid h3 {
  margin: 0 0 12px !important;
  color: var(--laos-ink) !important;
  font-size: 30px !important;
  line-height: 1 !important;
}

.faq-grid p {
  margin: 0 !important;
  color: var(--laos-muted) !important;
  line-height: 1.65 !important;
}

.floating-whatsapp {
  position: fixed !important;
  right: 22px !important;
  bottom: 22px !important;
  z-index: 2400 !important;
  min-width: 138px !important;
  min-height: 56px !important;
  display: grid !important;
  align-content: center !important;
  gap: 2px !important;
  padding: 10px 18px !important;
  border-radius: 999px !important;
  text-decoration: none !important;
  color: #fff8ee !important;
  background: linear-gradient(135deg, #255f45, #128c55) !important;
  box-shadow: 0 20px 52px rgba(18, 140, 85, .32) !important;
}

.floating-whatsapp span {
  font-size: 11px !important;
  opacity: .76 !important;
}

.floating-whatsapp strong {
  font-size: 15px !important;
  line-height: 1 !important;
}

footer {
  background: #171113 !important;
  color: rgba(255, 248, 238, .72) !important;
  padding: 28px 20px !important;
  text-align: center !important;
}

@media (max-width: 900px) {
  .quick-view-panel,
  .style-advisor {
    grid-template-columns: 1fr !important;
  }

  .quick-view-panel {
    max-height: 92vh !important;
    overflow-y: auto !important;
  }

  .quick-view-media {
    min-height: 360px !important;
  }

  .trust-ribbon,
  .faq-grid {
    grid-template-columns: 1fr !important;
  }

  .style-advisor {
    padding: 72px 18px !important;
  }

  .advisor-media {
    height: 420px !important;
  }
}

@media (max-width: 560px) {
  .quick-view {
    padding: 10px !important;
  }

  .quick-view-content {
    padding: 24px !important;
  }

  .quick-view-selects {
    grid-template-columns: 1fr !important;
  }

  .hero-proof span {
    width: 100% !important;
    text-align: center !important;
  }

  .trust-ribbon div {
    min-height: 112px !important;
  }

  .social-proof-strip {
    display: grid !important;
  }

  .floating-whatsapp {
    right: 14px !important;
    bottom: 14px !important;
    width: 56px !important;
    min-width: 56px !important;
    min-height: 56px !important;
    padding: 0 !important;
    place-items: center !important;
  }

  .floating-whatsapp span,
  .floating-whatsapp strong {
    display: none !important;
  }

  .floating-whatsapp::before {
    content: "WA" !important;
    font-weight: 900 !important;
    letter-spacing: .02em !important;
  }
}

/* ===============================
   LIMPIEZA PROFESIONAL ESENCIAL
================================ */

body,
button,
input,
textarea,
select,
a,
.section-kicker,
.section-title span,
.collection-results-meta,
.collection-filter,
.collection-add-btn,
.collection-detail-btn {
  letter-spacing: 0 !important;
}

body {
  background: #fbf7f2 !important;
}

.header {
  height: 78px !important;
  padding: 0 clamp(16px, 4vw, 42px) !important;
  background: rgba(18, 14, 15, .88) !important;
  border-bottom: 1px solid rgba(255, 248, 238, .12) !important;
  box-shadow: 0 12px 34px rgba(15, 12, 13, .22) !important;
}

.brand-center {
  gap: 10px !important;
}

.brand-center .logo {
  width: 52px !important;
  height: 52px !important;
}

.brand-center h1 {
  font-size: clamp(24px, 2.2vw, 32px) !important;
  line-height: 1 !important;
}

.logo-text p {
  display: none !important;
}

.menu-btn {
  width: 44px !important;
  height: 44px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  padding: 0 !important;
  border: 1px solid rgba(255, 248, 238, .18) !important;
  border-radius: 999px !important;
  background: rgba(255, 248, 238, .06) !important;
  box-shadow: none !important;
}

.menu-btn span {
  width: 20px !important;
  height: 2px !important;
  background: #fff8ee !important;
}

.nav {
  top: 70px !important;
  left: clamp(16px, 4vw, 42px) !important;
  width: min(252px, calc(100vw - 32px)) !important;
  padding: 10px !important;
  gap: 2px !important;
  border-radius: 10px !important;
  border: 1px solid rgba(255, 248, 238, .12) !important;
  background: rgba(18, 14, 15, .96) !important;
  box-shadow: 0 22px 54px rgba(15, 12, 13, .28) !important;
}

.nav a {
  padding: 11px 12px !important;
  border-radius: 8px !important;
  color: rgba(255, 248, 238, .86) !important;
  font-size: 13px !important;
  text-transform: none !important;
}

.nav a:hover {
  background: rgba(255, 248, 238, .08) !important;
  color: #fff8ee !important;
}

.nav a::after {
  display: none !important;
}

.header-cart {
  width: 46px !important;
  min-width: 46px !important;
  height: 46px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  justify-content: center !important;
  box-shadow: none !important;
}

.cart-text {
  display: none !important;
}

.cart-icon-wrap {
  width: 38px !important;
  height: 38px !important;
  margin: 0 !important;
  display: grid !important;
  place-items: center !important;
  font-size: 17px !important;
}

#cartCount {
  top: -5px !important;
  right: -5px !important;
}

.hero {
  min-height: 92svh !important;
  padding-top: 104px !important;
  padding-bottom: 68px !important;
}

.hero-content {
  max-width: 760px !important;
}

.hero-content h2 {
  font-size: clamp(48px, 7vw, 86px) !important;
  line-height: .98 !important;
}

.hero-buttons {
  margin-top: 30px !important;
}

.hero-buttons .btn {
  min-width: 190px !important;
  min-height: 50px !important;
}

.collection-boutique {
  padding: clamp(76px, 8vw, 116px) clamp(18px, 5vw, 72px) !important;
  background: #fbf7f2 !important;
}

.collection-boutique::before {
  display: none !important;
}

.collection-header {
  grid-template-columns: 1fr !important;
  max-width: 980px !important;
  margin-bottom: 28px !important;
}

.collection-header .section-kicker {
  font-size: 13px !important;
  color: var(--laos-wine) !important;
  text-transform: none !important;
}

.collection-header h2 {
  max-width: 820px !important;
  font-size: clamp(38px, 5vw, 68px) !important;
  line-height: 1 !important;
}

.collection-header p {
  max-width: 700px !important;
  margin-top: 18px !important;
  color: rgba(22, 17, 19, .68) !important;
  font-size: 15.5px !important;
  line-height: 1.75 !important;
}

.collection-toolbar {
  grid-template-columns: minmax(240px, 320px) 1fr auto !important;
  align-items: end !important;
  margin: 24px 0 18px !important;
  padding: 12px !important;
  border-radius: 8px !important;
  background: rgba(255, 255, 255, .84) !important;
  box-shadow: 0 12px 34px rgba(83, 33, 45, .06) !important;
}

.collection-search-field span,
.collection-select-wrap span {
  font-size: 12px !important;
  text-transform: none !important;
  color: rgba(22, 17, 19, .62) !important;
}

.collection-search-field input,
.collection-select-wrap select {
  height: 44px !important;
  border-radius: 6px !important;
  background: #fff !important;
}

.collection-categories {
  gap: 8px !important;
}

.collection-filter {
  height: 38px !important;
  padding: 0 13px !important;
  border-radius: 6px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

.collection-filter:hover,
.collection-filter.active {
  transform: none !important;
}

.collection-card {
  border-radius: 8px !important;
  background: #fff !important;
  box-shadow: 0 14px 38px rgba(83, 33, 45, .08) !important;
}

.collection-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 18px 44px rgba(83, 33, 45, .12) !important;
}

.collection-card-media {
  background: #f1e8df !important;
}

.collection-actions {
  grid-template-columns: 1fr auto !important;
}

.collection-add-btn,
.collection-detail-btn {
  min-height: 44px !important;
  border-radius: 6px !important;
  font-size: 13px !important;
}

.collection-detail-btn {
  background: transparent !important;
}

.quick-view-whatsapp,
.floating-whatsapp,
.trust-ribbon,
.style-advisor,
.social-proof-strip,
.faq-section,
.contact-card-list,
.hero-proof {
  display: none !important;
}

.contacto {
  padding: clamp(78px, 8vw, 118px) clamp(18px, 5vw, 72px) !important;
  background: #171113 !important;
  color: #fff8ee !important;
}

.contacto .section-title span,
.contacto .section-title h2,
.contacto .section-subtitle {
  color: #fff8ee !important;
}

.contacto .section-subtitle {
  opacity: .78 !important;
}

.contacto-content {
  max-width: 1120px !important;
  grid-template-columns: .92fr 1.08fr !important;
  gap: clamp(24px, 4vw, 52px) !important;
  padding: clamp(24px, 4vw, 46px) !important;
  border: 1px solid rgba(255, 248, 238, .18) !important;
  border-radius: 10px !important;
  background: #fffaf3 !important;
  color: #171113 !important;
  box-shadow: 0 26px 70px rgba(0, 0, 0, .22) !important;
}

.contacto-info,
.contacto-info h3,
.contacto-info p,
.contacto-info span {
  color: #171113 !important;
  opacity: 1 !important;
}

.contacto-info h3 {
  font-size: clamp(32px, 4vw, 48px) !important;
  line-height: 1 !important;
}

.contacto-info p {
  line-height: 1.75 !important;
}

.contacto-info strong {
  color: var(--laos-wine) !important;
}

.formulario {
  background: transparent !important;
  gap: 14px !important;
}

.formulario input,
.formulario textarea {
  background: #fff !important;
  color: #171113 !important;
  border: 1px solid rgba(111, 36, 55, .18) !important;
  border-radius: 7px !important;
  box-shadow: none !important;
}

.formulario input::placeholder,
.formulario textarea::placeholder {
  color: rgba(22, 17, 19, .5) !important;
}

.formulario .btn {
  background: var(--laos-wine) !important;
  color: #fff8ee !important;
  border-radius: 7px !important;
}

@media (max-width: 980px) {
  .collection-toolbar {
    grid-template-columns: 1fr !important;
    align-items: stretch !important;
  }

  .collection-categories {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    padding-bottom: 4px !important;
  }

  .collection-filter {
    flex: 0 0 auto !important;
  }

  .contacto-content {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 620px) {
  .header {
    height: 72px !important;
    padding: 0 12px !important;
  }

  .brand-center .logo {
    width: 44px !important;
    height: 44px !important;
  }

  .brand-center h1 {
    font-size: 23px !important;
  }

  .menu-btn,
  .header-cart {
    width: 42px !important;
    min-width: 42px !important;
    height: 42px !important;
  }

  .nav {
    top: 66px !important;
    left: 12px !important;
    width: calc(100vw - 24px) !important;
  }

  .hero {
    min-height: 90svh !important;
    padding: 96px 18px 54px !important;
  }

  .hero-content h2 {
    font-size: clamp(44px, 14vw, 64px) !important;
  }

  .collection-actions {
    grid-template-columns: 1fr !important;
  }

  .collection-detail-btn {
    min-height: 40px !important;
  }

  .contacto {
    padding: 70px 16px !important;
  }

  .contacto-content {
    padding: 22px !important;
  }
}


/* AJUSTE SOLICITADO: productos 1:1 y carrusel solo en detalle */
.collection-card-featured {
  grid-column: auto !important;
  grid-row: auto !important;
}

.collection-card-media {
  overflow: hidden !important;
}

.collection-image-btn {
  cursor: default !important;
}

.collection-card-media img,
.collection-card-featured .collection-card-media img {
  aspect-ratio: 1 / 1 !important;
  height: auto !important;
}

.quick-view-media {
  position: relative !important;
  overflow: hidden !important;
}

.quick-view-media img {
  transition: opacity .2s ease !important;
}

.quick-view-slider-btn {
  position: absolute !important;
  top: 50% !important;
  z-index: 5 !important;
  width: 42px !important;
  height: 42px !important;
  display: grid !important;
  place-items: center !important;
  transform: translateY(-50%) !important;
  border: 1px solid rgba(255, 248, 238, .42) !important;
  border-radius: 50% !important;
  background: rgba(15, 12, 13, .72) !important;
  color: #fff8ee !important;
  font-size: 30px !important;
  line-height: 1 !important;
  cursor: pointer !important;
}

.quick-view-slider-prev {
  left: 16px !important;
}

.quick-view-slider-next {
  right: 16px !important;
}

.quick-view-slider-dots {
  position: absolute !important;
  left: 50% !important;
  bottom: 18px !important;
  z-index: 5 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  transform: translateX(-50%) !important;
}

.quick-view-slider-dot {
  width: 9px !important;
  height: 9px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(255, 248, 238, .72) !important;
  cursor: pointer !important;
  box-shadow: 0 6px 18px rgba(15, 12, 13, .24) !important;
  transition: width .24s ease, background .24s ease !important;
}

.quick-view-slider-dot.active {
  width: 24px !important;
  background: var(--laos-wine) !important;
}

@media (max-width: 900px) {
  .quick-view-slider-btn {
    width: 36px !important;
    height: 36px !important;
    font-size: 25px !important;
  }

  .quick-view-slider-prev {
    left: 12px !important;
  }

  .quick-view-slider-next {
    right: 12px !important;
  }

  .quick-view-slider-dots {
    bottom: 12px !important;
  }
}


/* AJUSTE SOLICITADO: encabezado de colección más minimalista */
.collection-boutique {
  padding: clamp(48px, 5vw, 76px) clamp(18px, 5vw, 72px) !important;
  background: #fbf7f2 !important;
}

.collection-shell {
  max-width: 1480px !important;
}

.collection-header {
  display: grid !important;
  grid-template-columns: 170px minmax(0, 1fr) !important;
  gap: clamp(16px, 3vw, 34px) !important;
  align-items: start !important;
  max-width: none !important;
  margin-bottom: 18px !important;
}

.collection-header .section-kicker {
  grid-column: auto !important;
  padding-top: 8px !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
  letter-spacing: .02em !important;
  color: var(--laos-wine) !important;
  text-transform: none !important;
  font-weight: 800 !important;
}

.collection-header h2 {
  max-width: 780px !important;
  margin: 0 !important;
  font-size: clamp(32px, 3.8vw, 54px) !important;
  line-height: 1.03 !important;
  letter-spacing: -.025em !important;
  font-weight: 700 !important;
}

.collection-header p {
  max-width: 650px !important;
  margin-top: 10px !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  color: rgba(22, 17, 19, .60) !important;
}

.collection-toolbar {
  display: grid !important;
  grid-template-columns: minmax(220px, 300px) 1fr minmax(150px, 170px) !important;
  gap: 12px !important;
  align-items: end !important;
  margin: 12px 0 12px !important;
  padding: 0 0 14px !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(111, 36, 55, .12) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.collection-search-field,
.collection-select-wrap {
  gap: 5px !important;
}

.collection-search-field span,
.collection-select-wrap span {
  font-size: 10px !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
  color: rgba(22, 17, 19, .46) !important;
  font-weight: 800 !important;
}

.collection-search-field input,
.collection-select-wrap select {
  height: 40px !important;
  border-radius: 4px !important;
  border: 1px solid rgba(111, 36, 55, .13) !important;
  background: rgba(255, 255, 255, .56) !important;
  padding: 0 14px !important;
  font-size: 14px !important;
}

.collection-search-field input::placeholder {
  color: rgba(22, 17, 19, .42) !important;
}

.collection-categories {
  justify-content: center !important;
  gap: 7px !important;
}

.collection-filter {
  height: 38px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  border-color: rgba(111, 36, 55, .13) !important;
  background: rgba(255, 255, 255, .42) !important;
  color: rgba(22, 17, 19, .68) !important;
  box-shadow: none !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

.collection-filter:hover,
.collection-filter.active {
  transform: none !important;
  background: var(--laos-wine) !important;
  border-color: var(--laos-wine) !important;
  color: #fff8ee !important;
  box-shadow: none !important;
}

.collection-results-meta {
  min-height: 16px !important;
  margin: 0 0 14px !important;
  font-size: 12px !important;
  letter-spacing: .02em !important;
  text-transform: none !important;
  color: rgba(22, 17, 19, .52) !important;
}

@media (max-width: 980px) {
  .collection-header {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    margin-bottom: 14px !important;
  }

  .collection-header .section-kicker {
    padding-top: 0 !important;
  }

  .collection-toolbar {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .collection-categories {
    justify-content: flex-start !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    padding-bottom: 4px !important;
  }
}

@media (max-width: 620px) {
  .collection-boutique {
    padding: 42px 16px 56px !important;
  }

  .collection-header h2 {
    font-size: clamp(30px, 10vw, 42px) !important;
    line-height: 1.02 !important;
  }

  .collection-header p {
    display: none !important;
  }

  .collection-toolbar {
    margin-top: 10px !important;
    padding-bottom: 12px !important;
  }

  .collection-search-field span,
  .collection-select-wrap span {
    font-size: 9px !important;
  }

  .collection-search-field input,
  .collection-select-wrap select {
    height: 38px !important;
  }
}

/* =============================== */
/* GALERÍA - EFECTO HOVER PREMIUM */
/* =============================== */

.galeria .galeria-masonry {
  perspective: 1200px;
}

.galeria .galeria-item {
  position: relative;
  border: 0;
  padding: 0;
  background: transparent;
  isolation: isolate;
  box-shadow: 0 18px 45px rgba(40, 24, 20, 0.08);
  transition:
    transform .45s cubic-bezier(.2,.8,.2,1),
    box-shadow .45s ease,
    filter .45s ease;
}

.galeria .galeria-item::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(
      180deg,
      rgba(18, 9, 9, 0.02) 0%,
      rgba(18, 9, 9, 0.18) 45%,
      rgba(18, 9, 9, 0.82) 100%
    );
  opacity: 0;
  transition: opacity .45s ease;
  pointer-events: none;
}

.galeria .galeria-item::after {
  content: "Ver diseño";
  position: absolute;
  right: 20px;
  bottom: 20px;
  z-index: 3;

  padding: 10px 16px;
  border-radius: 999px;

  background: rgba(255, 248, 241, 0.92);
  color: #7a1f35;

  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;

  opacity: 0;
  transform: translateY(14px);
  transition:
    opacity .35s ease,
    transform .35s ease;
  pointer-events: none;
}

.galeria .galeria-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1);
  filter: saturate(.95) contrast(.98);
  transition:
    transform .7s cubic-bezier(.2,.8,.2,1),
    filter .45s ease;
}

.galeria .galeria-overlay {
  z-index: 2;
  padding: 26px;
  text-align: left;
  align-items: flex-start;

  background: transparent;
  opacity: 0;
  transform: translateY(22px);

  transition:
    opacity .35s ease,
    transform .45s cubic-bezier(.2,.8,.2,1);
  pointer-events: none;
}

.galeria .galeria-overlay h3 {
  color: #fff;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(24px, 2vw, 34px);
  line-height: 1;
  margin-bottom: 8px;
  text-shadow: 0 8px 22px rgba(0,0,0,.35);
}

.galeria .galeria-overlay p {
  max-width: 85%;
  color: rgba(255,255,255,.84);
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  line-height: 1.5;
}

.galeria .galeria-masonry:hover .galeria-item:not(:hover) {
  filter: saturate(.7) brightness(.92);
}

.galeria .galeria-item:hover,
.galeria .galeria-item:focus-visible {
  transform: translateY(-10px) scale(1.015);
  box-shadow: 0 30px 70px rgba(40, 24, 20, 0.18);
}

.galeria .galeria-item:hover::before,
.galeria .galeria-item:focus-visible::before,
.galeria .galeria-item:hover::after,
.galeria .galeria-item:focus-visible::after {
  opacity: 1;
  transform: translateY(0);
}

.galeria .galeria-item:hover img,
.galeria .galeria-item:focus-visible img {
  transform: scale(1.1);
  filter: saturate(1.06) contrast(1.04) brightness(.86);
}

.galeria .galeria-item:hover .galeria-overlay,
.galeria .galeria-item:focus-visible .galeria-overlay {
  opacity: 1;
  transform: translateY(0);
}

.galeria .galeria-item:focus-visible {
  outline: 2px solid rgba(122, 31, 53, .55);
  outline-offset: 4px;
}

/* En pantallas táctiles el hover no existe, por eso se deja una vista suave y legible. */
@media (hover: none) {
  .galeria .galeria-item::before {
    opacity: .58;
  }

  .galeria .galeria-item::after {
    display: none;
  }

  .galeria .galeria-overlay {
    opacity: 1;
    transform: none;
    padding: 18px;
  }

  .galeria .galeria-overlay h3 {
    font-size: 22px;
  }

  .galeria .galeria-overlay p {
    display: none;
  }
}

@media (max-width: 768px) {
  .galeria .galeria-item:hover,
  .galeria .galeria-item:focus-visible {
    transform: translateY(-6px);
  }

  .galeria .galeria-overlay {
    padding: 18px;
  }
}



/* ==========================================================
   SHOP THE LOOK - CARRUSEL DE LOOKS COMPLETOS
   ========================================================== */

.shop-look-section {
  --shop-bg: #fbf7f2;
  --shop-card: #ffffff;
  --shop-ink: #1f1717;
  --shop-muted: #7a7070;
  --shop-accent: #7b243a;
  --shop-border: rgba(123, 36, 58, .12);
  --shop-shadow: 0 24px 70px rgba(42, 25, 20, .11);

  background:
    radial-gradient(circle at 50% 10%, rgba(216, 180, 140, .16), transparent 34%),
    var(--shop-bg);
  padding-top: 86px;
  padding-bottom: 90px;
}

.shop-look-section .shop-look-heading {
  max-width: 820px;
  margin-inline: auto;
  margin-bottom: 44px;
}

.shop-look-section .shop-look-heading span {
  color: var(--shop-accent);
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  letter-spacing: .18em;
}

.shop-look-section .shop-look-heading h2 {
  font-size: clamp(42px, 6vw, 86px);
  line-height: .95;
}

.shop-look-section .shop-look-heading p {
  max-width: 650px;
  margin: 18px auto 0;
  color: var(--shop-muted);
  font-family: 'Manrope', sans-serif;
  line-height: 1.7;
}

.shop-look-carousel {
  position: relative;
  width: min(100%, 1120px);
  margin: 0 auto;
  padding: 0 74px 48px;
}

.shop-look-viewport {
  overflow: hidden;
  border-radius: 32px;
}

.shop-look-track {
  display: flex;
  transition: transform .45s cubic-bezier(.22, .61, .36, 1);
  will-change: transform;
}

.shop-look-slide {
  min-width: 100%;
  display: flex;
  justify-content: center;
}

.shop-look-card {
  width: min(100%, 560px);
  background: var(--shop-card);
  border: 1px solid var(--shop-border);
  border-radius: 32px;
  overflow: hidden;
  box-shadow: var(--shop-shadow);
}

.shop-look-photo {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 5;
  min-height: 520px;
  overflow: hidden;
  background: #eee6dc;
}

.shop-look-photo > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform .45s ease, filter .45s ease;
}

.shop-look-card:hover .shop-look-photo > img {
  transform: scale(1.035);
  filter: saturate(1.03) contrast(1.02);
}

.shop-look-shade {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.03), transparent 34%, rgba(0,0,0,.24)),
    radial-gradient(circle at 50% 44%, transparent 0 42%, rgba(0,0,0,.11) 100%);
}

.shop-look-hotspot {
  position: absolute;
  top: var(--hotspot-top);
  left: var(--hotspot-left);
  width: 18px;
  height: 18px;
  transform: translate(-50%, -50%);
  z-index: 4;
  border-radius: 999px;
  text-decoration: none;
  outline: none;
}

.shop-look-hotspot-dot {
  position: absolute;
  inset: 0;
  display: block;
  border-radius: inherit;
  background: #fff;
  border: 3px solid var(--shop-accent);
  box-shadow: 0 0 0 7px rgba(255,255,255,.34), 0 10px 22px rgba(0,0,0,.22);
}

.shop-look-hotspot-dot::after {
  content: "";
  position: absolute;
  inset: -10px;
  border-radius: inherit;
  border: 1px solid rgba(255,255,255,.85);
  animation: shopLookPulse 1.8s ease-out infinite;
}

@keyframes shopLookPulse {
  0% {
    opacity: .8;
    transform: scale(.72);
  }
  100% {
    opacity: 0;
    transform: scale(1.65);
  }
}

.shop-look-tooltip {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 16px);
  min-width: 172px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.96);
  color: var(--shop-ink);
  box-shadow: 0 18px 42px rgba(0,0,0,.18);
  backdrop-filter: blur(10px);
  transform: translate(-50%, 10px) scale(.96);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .3s ease, transform .3s ease, visibility .3s ease;
}

.shop-look-tooltip::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -7px;
  width: 14px;
  height: 14px;
  background: rgba(255,255,255,.96);
  transform: translateX(-50%) rotate(45deg);
}

.shop-look-tooltip strong,
.shop-look-tooltip small {
  display: block;
  font-family: 'Manrope', sans-serif;
}

.shop-look-tooltip strong {
  font-size: 13px;
  line-height: 1.25;
  margin-bottom: 4px;
}

.shop-look-tooltip small {
  color: var(--shop-accent);
  font-size: 12px;
  font-weight: 800;
}

.shop-look-hotspot:hover .shop-look-tooltip,
.shop-look-hotspot:focus-visible .shop-look-tooltip {
  opacity: 1;
  visibility: visible;
  transform: translate(-50%, 0) scale(1);
}

.shop-look-body {
  padding: 22px;
}

.shop-look-copy {
  display: grid;
  gap: 6px;
  margin-bottom: 18px;
}

.shop-look-copy span {
  color: var(--shop-accent);
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.shop-look-copy h3 {
  color: var(--shop-ink);
  font-family: 'Manrope', sans-serif;
  font-size: 22px;
  line-height: 1.1;
}

.shop-look-copy p {
  color: var(--shop-muted);
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  line-height: 1.6;
}

.shop-look-products {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.shop-look-product {
  display: grid;
  gap: 8px;
  padding: 10px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  color: var(--shop-ink);
  text-decoration: none;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}

.shop-look-product:hover,
.shop-look-product:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(123,36,58,.22);
  box-shadow: 0 14px 32px rgba(42, 25, 20, .10);
}

.shop-look-product-img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 14px;
  background: #f8f4ef;
  overflow: hidden;
}

.shop-look-product-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .3s ease;
}

.shop-look-product:hover img,
.shop-look-product:focus-visible img {
  transform: scale(1.06);
}

.shop-look-product-name {
  min-height: 28px;
  color: #514747;
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 700;
  line-height: 1.25;
}

.shop-look-product strong {
  color: var(--shop-accent);
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
}

.shop-look-arrow {
  position: absolute;
  top: 42%;
  z-index: 8;
  width: 50px;
  height: 50px;
  border: 1px solid rgba(123, 36, 58, .14);
  border-radius: 50%;
  background: rgba(255,255,255,.86);
  color: var(--shop-ink);
  box-shadow: 0 14px 32px rgba(42,25,20,.12);
  backdrop-filter: blur(12px);
  font-size: 34px;
  line-height: 1;
  cursor: pointer;
  transition: transform .3s ease, background .3s ease, color .3s ease;
}

.shop-look-arrow:hover {
  background: var(--shop-accent);
  color: #fff;
  transform: translateY(-2px);
}

.shop-look-prev {
  left: 0;
}

.shop-look-next {
  right: 0;
}

.shop-look-dots {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  display: flex;
  justify-content: center;
  gap: 9px;
}

.shop-look-dot {
  width: 8px;
  height: 8px;
  border: 0;
  border-radius: 999px;
  background: rgba(123, 36, 58, .25);
  cursor: pointer;
  transition: width .3s ease, background .3s ease;
}

.shop-look-dot.active {
  width: 26px;
  background: var(--shop-accent);
}

@media (max-width: 900px) {
  .shop-look-section {
    padding: 70px 18px;
  }

  .shop-look-carousel {
    padding: 0 0 48px;
  }

  .shop-look-card {
    width: min(100%, 520px);
    border-radius: 26px;
  }

  .shop-look-photo {
    min-height: unset;
    aspect-ratio: 3 / 4;
  }

  .shop-look-arrow {
    top: 38%;
    width: 42px;
    height: 42px;
    font-size: 28px;
  }

  .shop-look-prev {
    left: 10px;
  }

  .shop-look-next {
    right: 10px;
  }

  .shop-look-products {
    display: flex;
    overflow-x: auto;
    padding-bottom: 4px;
    scroll-snap-type: x mandatory;
  }

  .shop-look-product {
    min-width: 126px;
    scroll-snap-align: start;
  }
}

@media (max-width: 560px) {
  .shop-look-section .shop-look-heading h2 {
    font-size: 42px;
  }

  .shop-look-section .shop-look-heading p {
    font-size: 14px;
  }

  .shop-look-body {
    padding: 16px;
  }

  .shop-look-copy h3 {
    font-size: 20px;
  }

  .shop-look-tooltip {
    min-width: 148px;
    padding: 10px 12px;
  }

  .shop-look-hotspot {
    width: 16px;
    height: 16px;
  }
}

.shop-look-section::before {
  display: none;
}

.shop-look-section .shop-look-heading h2 {
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
  letter-spacing: -.055em;
}


/* =========================================================
   SOBRE NOSOTRAS / NUESTRO ATELIER - PROCESO ARTESANAL
   Reemplaza las imágenes desde el HTML sin tocar esta estructura.
   ========================================================= */
:root {
  --atelier-bg: #faf4ee;
  --atelier-surface: #fffaf5;
  --atelier-rose: #b56f64;
  --atelier-rose-dark: #8f4d45;
  --atelier-ink: #2b2422;
  --atelier-muted: #726763;
  --atelier-line: rgba(143, 77, 69, 0.18);
  --atelier-shadow: 0 22px 48px rgba(77, 49, 43, 0.08);
}

.atelier-about {
  background: var(--atelier-bg) !important;
  padding: clamp(72px, 8vw, 120px) 60px !important;
  color: var(--atelier-ink);
}

.atelier-about-shell {
  width: min(1180px, 100%);
  margin: 0 auto;
}

.atelier-main-title,
.atelier-team-title {
  margin: 0;
  font-family: 'Cormorant Garamond', Georgia, serif;
  color: var(--atelier-ink);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.atelier-main-title {
  text-align: center;
  font-size: clamp(28px, 3vw, 46px);
  margin-bottom: clamp(34px, 5vw, 56px);
}

.atelier-process-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(18px, 2vw, 28px);
}

.atelier-process-card {
  background: var(--atelier-surface);
  border: 1px solid var(--atelier-line);
  border-radius: 2px;
  overflow: hidden;
  box-shadow: var(--atelier-shadow);
  transition: transform .3s ease, box-shadow .3s ease;
}

.atelier-process-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 28px 60px rgba(77, 49, 43, 0.12);
}

.atelier-card-header,
.atelier-card-copy {
  background: var(--atelier-rose);
}

.atelier-card-header {
  padding: 22px 24px;
  text-align: center;
}

.atelier-card-header h3 {
  margin: 0;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(28px, 2.4vw, 40px);
  line-height: 1;
  color: #fff8ef;
  font-weight: 700;
}

.atelier-card-image {
  margin: 0;
  height: clamp(340px, 42vw, 520px);
  background: #efe5dc;
  overflow: hidden;
}

.atelier-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform .3s ease, filter .3s ease;
}

.atelier-process-card:hover .atelier-card-image img {
  transform: scale(1.035);
  filter: saturate(1.04) contrast(1.02);
}

.atelier-card-copy {
  min-height: 118px;
  padding: 24px 26px;
  display: flex;
  align-items: center;
}

.atelier-card-copy p {
  margin: 0;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 15px;
  line-height: 1.75;
  color: #fff8ef;
}

.atelier-team-block {
  margin-top: clamp(70px, 8vw, 118px);
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr);
  gap: clamp(28px, 4vw, 62px);
  align-items: stretch;
}

.atelier-video-box {
  position: relative;
  min-height: clamp(360px, 42vw, 560px);
  border-radius: 2px;
  overflow: hidden;
  background: #e9ded4;
  box-shadow: var(--atelier-shadow);
}

.atelier-video-box::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(43, 36, 34, .08), rgba(43, 36, 34, .28));
  pointer-events: none;
}

.atelier-video-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.atelier-play {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  width: 78px;
  height: 78px;
  border-radius: 50%;
  background: rgba(255, 250, 245, .92);
  display: grid;
  place-items: center;
  z-index: 2;
  box-shadow: 0 20px 40px rgba(43, 36, 34, .22);
  transition: transform .3s ease, background .3s ease, box-shadow .3s ease;
}

.atelier-play span {
  width: 0;
  height: 0;
  margin-left: 5px;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
  border-left: 18px solid var(--atelier-rose-dark);
}

.atelier-play:hover {
  transform: translate(-50%, -50%) scale(1.08);
  background: #ffffff;
  box-shadow: 0 26px 52px rgba(43, 36, 34, .28);
}

.atelier-team-content {
  background: var(--atelier-surface);
  border: 1px solid var(--atelier-line);
  border-radius: 2px;
  padding: clamp(28px, 4vw, 46px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.atelier-team-title {
  font-size: clamp(26px, 3vw, 44px);
  line-height: 1.08;
  max-width: 520px;
  margin-bottom: 34px;
}

.atelier-team-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.atelier-member-card {
  background: #fff;
  border: 1px solid var(--atelier-line);
  border-radius: 2px;
  overflow: hidden;
  transition: transform .3s ease, box-shadow .3s ease;
}

.atelier-member-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 38px rgba(77, 49, 43, .10);
}

.atelier-member-card img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  object-position: center;
  background: #efe5dc;
}

.atelier-member-card div {
  padding: 18px;
}

.atelier-member-card h3 {
  margin: 0 0 8px;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 16px;
  color: var(--atelier-ink);
  font-weight: 800;
}

.atelier-member-card p {
  margin: 0;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 13.5px;
  line-height: 1.65;
  color: var(--atelier-muted);
}

@media (max-width: 1024px) {
  .atelier-about {
    padding-inline: 28px !important;
  }

  .atelier-team-block {
    grid-template-columns: 1fr;
  }

  .atelier-team-content {
    min-height: auto;
  }
}

@media (max-width: 820px) {
  .atelier-process-grid,
  .atelier-team-grid {
    grid-template-columns: 1fr;
  }

  .atelier-card-image {
    height: 430px;
  }

  .atelier-team-title {
    text-align: center;
    margin-inline: auto;
  }

  .atelier-member-card {
    display: grid;
    grid-template-columns: 120px 1fr;
    align-items: center;
  }

  .atelier-member-card img {
    height: 100%;
    aspect-ratio: 1 / 1;
  }
}

@media (max-width: 520px) {
  .atelier-about {
    padding: 64px 18px !important;
  }

  .atelier-card-image {
    height: 360px;
  }

  .atelier-card-copy {
    min-height: auto;
    padding: 22px;
  }

  .atelier-video-box {
    min-height: 320px;
  }

  .atelier-play {
    width: 64px;
    height: 64px;
  }

  .atelier-member-card {
    grid-template-columns: 1fr;
  }

  .atelier-member-card img {
    aspect-ratio: 4 / 4.5;
  }
}


/* =============================== */
/* OPINIONES LUXURY - REDISEÑO UI */
/* =============================== */

.opiniones-premium {
  --opinion-cream: #fbf6ef;
  --opinion-card: #fffdf9;
  --opinion-soft: #f2e2d9;
  --opinion-rose: #c99a8c;
  --opinion-terracotta: #8a4b3f;
  --opinion-brown: #4b2f28;
  --opinion-text: #2f2a27;
  --opinion-muted: #746a64;
  --opinion-line: rgba(75, 47, 40, .24);
  --opinion-gold: #c99a35;

  padding: 96px 60px !important;
  background:
    radial-gradient(circle at 12% 12%, rgba(201, 154, 140, .16), transparent 32%),
    linear-gradient(180deg, #fbf6ef 0%, #f8f1e9 100%) !important;
  color: var(--opinion-text);
}

.opiniones-shell {
  width: min(1180px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .9fr);
  gap: clamp(34px, 5vw, 72px);
  align-items: start;
}

.opiniones-heading-block {
  max-width: 620px;
  margin-bottom: 34px;
}

.opiniones-kicker,
.opiniones-form-kicker {
  display: inline-block;
  margin-bottom: 14px;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #7a1f35;
}

.opiniones-heading-block h2 {
  margin: 0;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(44px, 6vw, 78px);
  font-weight: 600;
  line-height: .92;
  letter-spacing: -.035em;
  color: #161211;
}

.opiniones-heading-block p {
  max-width: 560px;
  margin: 22px 0 0;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 15.5px;
  line-height: 1.85;
  color: var(--opinion-muted);
}

.opiniones-premium .testimonios-grid,
.opiniones-list {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 18px !important;
  margin: 0 !important;
  align-items: stretch !important;
}

.opiniones-premium .testimonio,
.opiniones-premium .opinion-card {
  position: relative;
  min-height: auto;
  padding: 26px 28px !important;
  overflow: hidden;
  background: rgba(255, 253, 249, .92) !important;
  border: 1px solid rgba(75, 47, 40, .10) !important;
  border-radius: 2px !important;
  box-shadow: 0 18px 45px rgba(68, 42, 34, .06) !important;
  backdrop-filter: blur(10px);
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}

.opiniones-premium .testimonio:hover {
  transform: translateY(-4px);
  border-color: rgba(138, 75, 63, .22) !important;
  box-shadow: 0 24px 60px rgba(68, 42, 34, .10) !important;
}

.opiniones-premium .testimonio::before {
  content: none !important;
}

.opiniones-premium .stars {
  margin: 0 0 14px !important;
  font-size: 17px !important;
  letter-spacing: .12em;
  line-height: 1;
  color: var(--opinion-gold) !important;
}

.opiniones-premium .testimonio p {
  margin: 0;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 14.5px !important;
  line-height: 1.8 !important;
  font-style: italic;
  color: #443b36 !important;
}

.opinion-author {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 22px;
}

.opinion-avatar {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, #ead2c8, #fff8f1);
  border: 1px solid rgba(138, 75, 63, .18);
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: var(--opinion-terracotta);
}

.opiniones-premium .testimonio h4 {
  margin: 0 !important;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 13.5px;
  font-weight: 800;
  color: #221b18 !important;
}

.opiniones-premium .opinion-callout,
.opiniones-form-card {
  width: 100%;
  max-width: none !important;
  margin: 0 !important;
  padding: clamp(30px, 4vw, 48px) !important;
  text-align: left !important;
  color: var(--opinion-text) !important;
  background:
    linear-gradient(135deg, rgba(242, 226, 217, .82), rgba(255, 250, 245, .96)) !important;
  border: 1px solid rgba(138, 75, 63, .16) !important;
  border-radius: 2px !important;
  box-shadow: 0 24px 70px rgba(68, 42, 34, .08) !important;
  overflow: visible !important;
}

.opiniones-premium .opinion-callout::before {
  content: none !important;
}

.opiniones-premium .opinion-callout h3 {
  margin: 0 0 12px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(34px, 4vw, 52px) !important;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -.025em;
  color: #191412 !important;
}

.opiniones-premium .opinion-callout p {
  max-width: 460px;
  margin: 0 0 34px !important;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 14.5px;
  line-height: 1.75;
  color: var(--opinion-muted) !important;
}

.opinion-form-luxury {
  display: grid;
  gap: 28px;
}

.opinion-field,
.opinion-rating-field {
  display: grid;
  gap: 8px;
}

.opinion-field span,
.opinion-rating-field > span {
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--opinion-brown);
}

.opiniones-premium #opinionForm .opinion-field-input {
  width: 100%;
  margin: 0 !important;
  padding: 10px 0 12px !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--opinion-line) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  outline: none;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 15px;
  color: var(--opinion-text);
  transition: border-color .3s ease, color .3s ease;
}

.opiniones-premium #opinionForm textarea.opinion-field-input {
  min-height: 112px;
  resize: vertical;
}

.opiniones-premium #opinionForm .opinion-field-input::placeholder {
  color: rgba(75, 47, 40, .45);
}

.opiniones-premium #opinionForm .opinion-field-input:focus {
  border-color: var(--opinion-terracotta) !important;
  box-shadow: none !important;
}

.opinion-star-rating {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  width: fit-content;
  padding-top: 4px;
}

.opinion-star {
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(75, 47, 40, .25);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  transition: color .3s ease, transform .3s ease, opacity .3s ease;
}

.opinion-star:hover,
.opinion-star:focus-visible,
.opinion-star.active {
  color: var(--opinion-gold);
  transform: translateY(-2px) scale(1.04);
}

.opinion-star:focus-visible {
  outline: 1px solid var(--opinion-terracotta);
  outline-offset: 3px;
}

.opiniones-premium .opinion-btn {
  width: 100%;
  min-height: 50px;
  margin-top: 4px !important;
  padding: 14px 22px !important;
  border: 0 !important;
  border-radius: 2px !important;
  background: var(--opinion-terracotta) !important;
  color: #fff8f1 !important;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 13px !important;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  box-shadow: none !important;
  transition: opacity .3s ease, transform .3s ease, background .3s ease;
}

.opiniones-premium .opinion-btn:hover {
  opacity: .86;
  background: var(--opinion-terracotta) !important;
  transform: translateY(-1px);
}

.opiniones-premium .opinion-btn:disabled {
  opacity: .55;
  cursor: not-allowed;
  transform: none;
}

.opiniones-premium #opinionMessage {
  min-height: 22px;
  margin-top: 18px !important;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 13px;
  color: var(--opinion-terracotta) !important;
}

@media (max-width: 980px) {
  .opiniones-premium {
    padding: 78px 28px !important;
  }

  .opiniones-shell {
    grid-template-columns: 1fr;
    gap: 44px;
  }

  .opiniones-heading-block {
    max-width: 760px;
    text-align: center;
    margin-inline: auto;
  }

  .opiniones-heading-block p {
    margin-inline: auto;
  }

  .opiniones-premium .opinion-callout,
  .opiniones-form-card {
    max-width: 720px !important;
    margin-inline: auto !important;
  }
}

@media (max-width: 560px) {
  .opiniones-premium {
    padding: 64px 18px !important;
  }

  .opiniones-heading-block h2 {
    font-size: 42px;
  }

  .opiniones-premium .testimonio,
  .opiniones-premium .opinion-card,
  .opiniones-premium .opinion-callout,
  .opiniones-form-card {
    padding: 24px !important;
  }

  .opinion-star {
    width: 30px;
    height: 30px;
    font-size: 25px;
  }
}




/* =========================================================
   OPINIONES PREMIUM - REFINAMIENTO FINAL
   Testimonios boutique + formulario más limpio y compacto
   ========================================================= */

.opiniones-premium {
  --opinion-cream: #fbf6ef;
  --opinion-card: #fffaf4;
  --opinion-soft: #f2e2d9;
  --opinion-terracotta: #8a4b3f;
  --opinion-burgundy: #76243a;
  --opinion-text: #221817;
  --opinion-muted: rgba(61, 47, 42, .68);
  --opinion-line: rgba(122, 36, 58, .16);
  --opinion-gold: #c49534;

  padding: clamp(82px, 8vw, 118px) clamp(22px, 5vw, 72px) !important;
  background:
    radial-gradient(circle at 18% 14%, rgba(201, 154, 140, .13), transparent 34%),
    linear-gradient(135deg, #fbf6ef 0%, #f8efe6 100%) !important;
}

.opiniones-shell {
  width: min(1220px, 100%) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1.04fr) minmax(360px, .82fr) !important;
  gap: clamp(38px, 5.4vw, 78px) !important;
  align-items: start !important;
}

.opiniones-heading-block {
  max-width: 650px !important;
  margin-bottom: 34px !important;
}

.opiniones-kicker,
.opiniones-form-kicker {
  margin-bottom: 16px !important;
  color: var(--opinion-burgundy) !important;
  font-family: 'Manrope', Arial, sans-serif !important;
  font-size: 11.5px !important;
  font-weight: 800 !important;
  letter-spacing: .24em !important;
  line-height: 1 !important;
}

.opiniones-heading-block h2 {
  max-width: 610px;
  font-size: clamp(48px, 5.4vw, 76px) !important;
  line-height: .94 !important;
  letter-spacing: -.04em !important;
}

.opiniones-heading-block p {
  max-width: 560px !important;
  margin-top: 22px !important;
  font-size: 15.5px !important;
  line-height: 1.8 !important;
  color: var(--opinion-muted) !important;
}

.opiniones-premium .testimonios-grid,
.opiniones-list {
  gap: 16px !important;
}

.opiniones-premium .testimonio,
.opiniones-premium .opinion-card {
  padding: 24px 26px !important;
  border-radius: 18px !important;
  background:
    linear-gradient(180deg, rgba(255, 253, 248, .98), rgba(255, 249, 242, .95)) !important;
  border: 1px solid rgba(122, 36, 58, .10) !important;
  box-shadow: 0 18px 44px rgba(61, 38, 31, .055) !important;
}

.opiniones-premium .testimonio:hover,
.opiniones-premium .opinion-card:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(122, 36, 58, .20) !important;
  box-shadow: 0 24px 58px rgba(61, 38, 31, .09) !important;
}

.opiniones-premium .testimonio::after,
.opiniones-premium .opinion-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 26px;
  width: 42px;
  height: 2px;
  background: linear-gradient(90deg, rgba(122,36,58,.55), rgba(196,149,52,.25));
}

.opiniones-premium .stars {
  margin-bottom: 12px !important;
  font-size: 15.5px !important;
  letter-spacing: .16em !important;
  color: var(--opinion-gold) !important;
}

.opiniones-premium .testimonio p,
.opiniones-premium .opinion-card p {
  max-width: 620px;
  font-size: 14.5px !important;
  line-height: 1.72 !important;
  color: rgba(47, 38, 34, .76) !important;
}

.opinion-author {
  margin-top: 18px !important;
}

.opinion-avatar {
  width: 34px !important;
  height: 34px !important;
  flex-basis: 34px !important;
  background: #f4e5dc !important;
  border-color: rgba(122, 36, 58, .16) !important;
  color: var(--opinion-burgundy) !important;
}

.opiniones-premium .testimonio h4,
.opiniones-premium .opinion-card h4 {
  font-size: 13.5px !important;
  letter-spacing: -.01em !important;
}

.opiniones-premium .opinion-callout,
.opiniones-form-card {
  max-width: 500px !important;
  justify-self: end !important;
  padding: clamp(30px, 3.5vw, 44px) !important;
  border-radius: 24px !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(255,255,255,.64), transparent 34%),
    linear-gradient(145deg, rgba(255, 250, 245, .96), rgba(247, 235, 226, .88)) !important;
  border: 1px solid rgba(122, 36, 58, .15) !important;
  box-shadow: 0 26px 70px rgba(63, 40, 32, .08) !important;
}

.opiniones-premium .opinion-callout h3,
.opiniones-form-card h3 {
  max-width: 410px;
  margin-bottom: 12px !important;
  font-size: clamp(36px, 3.4vw, 48px) !important;
  line-height: .98 !important;
  letter-spacing: -.035em !important;
}

.opiniones-premium .opinion-callout > p,
.opiniones-form-card > p {
  max-width: 420px !important;
  margin-bottom: 28px !important;
  font-size: 14.5px !important;
  line-height: 1.75 !important;
}

.opinion-form-luxury {
  gap: 22px !important;
}

.opinion-field,
.opinion-rating-field {
  gap: 9px !important;
}

.opinion-field span,
.opinion-rating-field > span {
  color: rgba(75, 47, 40, .86) !important;
  font-size: 10.5px !important;
  letter-spacing: .22em !important;
}

.opiniones-premium #opinionForm .opinion-field-input {
  padding: 9px 0 11px !important;
  font-size: 14.5px !important;
  border-bottom-color: rgba(75, 47, 40, .20) !important;
}

.opiniones-premium #opinionForm textarea.opinion-field-input {
  min-height: 94px !important;
}

.opinion-star-rating {
  gap: 8px !important;
  padding-top: 2px !important;
}

.opinion-star {
  width: 28px !important;
  height: 28px !important;
  font-size: 24px !important;
  color: rgba(75, 47, 40, .22) !important;
}

.opinion-star:hover,
.opinion-star:focus-visible,
.opinion-star.active {
  color: var(--opinion-gold) !important;
}

.opiniones-premium .opinion-btn {
  width: 100% !important;
  min-height: 48px !important;
  margin-top: 0 !important;
  border-radius: 999px !important;
  background: #8a4b3f !important;
  box-shadow: 0 14px 32px rgba(122, 36, 58, .12) !important;
}

.opiniones-premium .opinion-btn:hover {
  opacity: 1 !important;
  background: #6f2637 !important;
  transform: translateY(-2px) !important;
}

.opiniones-premium #opinionMessage {
  margin-top: 14px !important;
  font-size: 12.5px !important;
}

@media (max-width: 980px) {
  .opiniones-shell {
    grid-template-columns: 1fr !important;
  }

  .opiniones-premium .opinion-callout,
  .opiniones-form-card {
    justify-self: center !important;
    max-width: 680px !important;
  }
}

@media (max-width: 560px) {
  .opiniones-premium {
    padding: 66px 18px !important;
  }

  .opiniones-heading-block {
    margin-bottom: 28px !important;
  }

  .opiniones-heading-block h2 {
    font-size: 40px !important;
  }

  .opiniones-heading-block p {
    font-size: 14.2px !important;
  }

  .opiniones-premium .testimonio,
  .opiniones-premium .opinion-card {
    padding: 22px 20px !important;
    border-radius: 18px !important;
  }

  .opiniones-premium .opinion-callout,
  .opiniones-form-card {
    padding: 26px 22px !important;
    border-radius: 22px !important;
  }

  .opiniones-premium .opinion-callout h3,
  .opiniones-form-card h3 {
    font-size: 34px !important;
  }

  .opinion-star {
    width: 27px !important;
    height: 27px !important;
    font-size: 23px !important;
  }
}


/* =========================================================
   CONTACTO + FOOTER INTEGRADO - LAOS STUDIO
   ========================================================= */

.contact-footer-section {
  --contact-bg: #150d10;
  --contact-card: #fff8ef;
  --contact-card-soft: #fbefe8;
  --contact-cream: #f7efe4;
  --contact-muted: rgba(247, 239, 228, .68);
  --contact-line: rgba(247, 239, 228, .16);
  --contact-text: #261717;
  --contact-text-soft: rgba(38, 23, 23, .66);
  --contact-accent: #7b2435;
  --contact-accent-soft: #a66154;
  --contact-gold: #d8b48c;

  background:
    radial-gradient(circle at 18% 10%, rgba(123, 36, 53, .20), transparent 32%),
    radial-gradient(circle at 92% 12%, rgba(216, 180, 140, .10), transparent 26%),
    linear-gradient(180deg, #170f12 0%, var(--contact-bg) 100%) !important;
  color: var(--contact-cream) !important;
  padding: clamp(88px, 8vw, 126px) clamp(18px, 5vw, 68px) 0 !important;
}

.contact-footer-shell {
  width: min(1380px, 100%);
  margin: 0 auto;
}

.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, .82fr);
  gap: clamp(34px, 5.8vw, 88px);
  align-items: stretch;
}

.contact-card {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 86% 12%, rgba(216, 180, 140, .18), transparent 30%),
    linear-gradient(135deg, rgba(255, 250, 245, .98), rgba(250, 238, 228, .96));
  color: var(--contact-text);
  padding: clamp(34px, 4.7vw, 64px);
  border: 1px solid rgba(216, 180, 140, .26);
  border-radius: 28px;
  box-shadow: 0 30px 80px rgba(0, 0, 0, .24);
}

.contact-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: clamp(34px, 4.7vw, 64px);
  width: 72px;
  height: 3px;
  background: linear-gradient(90deg, var(--contact-accent), var(--contact-gold));
  border-radius: 999px;
}

.contact-kicker {
  display: inline-block;
  margin-bottom: 16px;
  color: var(--contact-accent);
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .28em;
  text-transform: uppercase;
}

.contact-card h2 {
  max-width: 720px;
  margin: 0 0 18px;
  color: #1c1112;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(46px, 5.2vw, 82px);
  font-weight: 700;
  line-height: .92;
  letter-spacing: -.045em;
}

.contact-intro {
  max-width: 650px;
  margin: 0 0 26px;
  color: rgba(38, 23, 23, .70);
  font-family: 'Manrope', sans-serif;
  font-size: 16px;
  line-height: 1.8;
}

.contact-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  margin-bottom: 30px;
}

.contact-primary-action,
.contact-secondary-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 13px 22px;
  border-radius: 999px;
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-decoration: none;
  transition: transform .28s ease, background .28s ease, color .28s ease, border-color .28s ease;
}

.contact-primary-action {
  color: #fff8ef;
  background: #7b2435;
  border: 1px solid #7b2435;
  box-shadow: 0 14px 32px rgba(123, 36, 53, .22);
}

.contact-primary-action:hover {
  transform: translateY(-2px);
  background: #1c1112;
  border-color: #1c1112;
}

.contact-secondary-action {
  color: #7b2435;
  background: rgba(255, 255, 255, .34);
  border: 1px solid rgba(123, 36, 53, .22);
}

.contact-secondary-action:hover {
  transform: translateY(-2px);
  background: #fff8ef;
  border-color: rgba(123, 36, 53, .42);
}

.contact-channel-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 34px;
  padding-bottom: 32px;
  border-bottom: 1px solid rgba(42, 23, 25, .12);
}

.contact-channel-card {
  min-height: 128px;
  padding: 18px 17px;
  border: 1px solid rgba(123, 36, 53, .12);
  border-radius: 20px;
  background: rgba(255, 248, 239, .70);
  box-shadow: 0 14px 30px rgba(86, 47, 33, .06);
  font-family: 'Manrope', sans-serif;
}

.contact-channel-card--highlight {
  background: linear-gradient(135deg, #fbefeb, #fff8ef);
  border-color: rgba(123, 36, 53, .20);
}

.contact-channel-card span {
  display: block;
  margin-bottom: 8px;
  color: var(--contact-accent);
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.contact-channel-card strong {
  display: block;
  margin-bottom: 8px;
  color: #241414;
  font-size: 14px;
  line-height: 1.35;
}

.contact-channel-card em {
  display: block;
  color: rgba(38, 23, 23, .58);
  font-size: 12.5px;
  font-style: normal;
  line-height: 1.55;
}

.contact-footer-section .contact-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px 26px;
  width: 100%;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.contact-footer-section .contact-form label {
  display: block;
  margin: 0;
}

.contact-footer-section .contact-form label:nth-child(3) {
  grid-column: 1 / -1;
}

.contact-footer-section .contact-form label span {
  display: block;
  margin-bottom: 9px;
  color: rgba(42, 23, 25, .62);
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.contact-footer-section .contact-form input,
.contact-footer-section .contact-form textarea {
  width: 100% !important;
  padding: 0 0 14px !important;
  margin: 0 !important;
  color: var(--contact-text) !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid rgba(42, 23, 25, .24) !important;
  border-radius: 0 !important;
  outline: none;
  font-family: 'Manrope', sans-serif !important;
  font-size: 15px;
  transition: border-color .3s ease, opacity .3s ease;
}

.contact-footer-section .contact-form textarea {
  min-height: 112px;
  resize: vertical;
}

.contact-footer-section .contact-form input::placeholder,
.contact-footer-section .contact-form textarea::placeholder {
  color: rgba(42, 23, 25, .40);
}

.contact-footer-section .contact-form input:focus,
.contact-footer-section .contact-form textarea:focus {
  border-bottom-color: var(--contact-accent) !important;
}

.contact-submit {
  grid-column: 1 / -1;
  justify-self: start;
  min-width: 190px;
  margin-top: 4px;
  padding: 15px 28px;
  color: #fff7ef;
  background: var(--contact-accent);
  border: 1px solid rgba(123, 36, 53, .92);
  border-radius: 999px;
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .05em;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 14px 30px rgba(123, 36, 53, .18);
  transition: background .3s ease, transform .3s ease, box-shadow .3s ease;
}

.contact-submit:hover {
  background: #1c1112;
  transform: translateY(-2px);
  box-shadow: 0 18px 36px rgba(0, 0, 0, .18);
}

.contact-visual {
  position: relative;
  min-height: 680px;
  margin: 0;
  overflow: hidden;
  border-radius: 28px;
  background: rgba(247, 239, 228, .05);
  border: 1px solid rgba(247, 239, 228, .14);
  box-shadow: 0 30px 80px rgba(0, 0, 0, .30);
}

.contact-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, .03) 0%, rgba(0, 0, 0, .48) 100%),
    linear-gradient(90deg, rgba(123, 36, 53, .18), transparent 52%);
  pointer-events: none;
}

.contact-visual-main {
  width: 100%;
  height: 100%;
  min-height: 680px;
  object-fit: cover;
  object-position: center;
  filter: saturate(.90) contrast(.98) brightness(.95);
}

.contact-visual-caption {
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 28px;
  z-index: 3;
  padding: 24px 24px 22px;
  border: 1px solid rgba(255, 248, 239, .22);
  border-radius: 22px;
  background: rgba(25, 14, 16, .54);
  backdrop-filter: blur(14px);
  color: #fff8ef;
}

.contact-visual-caption span {
  display: block;
  margin-bottom: 10px;
  color: #e8c59d;
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .20em;
  text-transform: uppercase;
}

.contact-visual-caption strong {
  display: block;
  max-width: 420px;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(30px, 3.1vw, 46px);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -.035em;
}

.contact-visual-tags {
  position: absolute;
  top: 26px;
  left: 26px;
  right: 26px;
  z-index: 3;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.contact-visual-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 9px 13px;
  border: 1px solid rgba(255, 248, 239, .22);
  border-radius: 999px;
  background: rgba(255, 248, 239, .82);
  color: #6f2436;
  font-family: 'Manrope', sans-serif;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .10em;
  text-transform: uppercase;
  box-shadow: 0 12px 28px rgba(0, 0, 0, .12);
}

.contact-footer-section .integrated-footer {
  padding: 78px 0 32px !important;
  margin: 0;
  color: var(--contact-cream);
  background: transparent !important;
  text-align: left !important;
}

.footer-divider {
  height: 1px;
  margin: 0 0 56px;
  border: 0;
  background: var(--contact-line);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr .8fr .9fr 1fr;
  gap: clamp(30px, 5vw, 72px);
  align-items: start;
}

.footer-brand h2 {
  margin-bottom: 14px;
  color: #fff8ef;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(34px, 3.2vw, 52px);
  font-weight: 700;
  line-height: 1;
}

.footer-brand p {
  max-width: 320px;
  color: var(--contact-muted);
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  line-height: 1.8;
}

.footer-column h3 {
  margin-bottom: 18px;
  color: #fff8ef;
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.footer-column a {
  display: block;
  width: fit-content;
  margin-bottom: 12px;
  color: var(--contact-muted);
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  line-height: 1.4;
  text-decoration: none;
  transition: opacity .3s ease, color .3s ease;
}

.footer-column a:hover {
  color: #fff8ef;
  opacity: .72;
}

.footer-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.footer-socials a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  margin: 0;
  padding: 10px 14px;
  border: 1px solid rgba(247, 239, 228, .18);
  color: #fff8ef;
  background: rgba(247, 239, 228, .04);
  font-size: 12px;
  letter-spacing: .04em;
}

.footer-socials a:hover {
  opacity: .65;
}

.footer-copy {
  margin-top: 56px;
  padding-top: 26px;
  border-top: 1px solid var(--contact-line);
  color: rgba(247, 239, 228, .52);
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  text-align: center;
}

@media (max-width: 1180px) {
  .contact-layout {
    grid-template-columns: 1fr;
  }

  .contact-visual {
    min-height: 560px;
  }

  .contact-visual-main {
    min-height: 560px;
  }

  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .contact-footer-section {
    padding: 86px 18px 0 !important;
  }

  .contact-card {
    padding: 34px 24px;
    border-radius: 24px;
  }

  .contact-card::before {
    left: 24px;
  }

  .contact-card h2 {
    font-size: 46px;
  }

  .contact-intro {
    font-size: 14.5px;
  }

  .contact-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .contact-primary-action,
  .contact-secondary-action {
    width: 100%;
  }

  .contact-channel-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .contact-channel-card {
    min-height: auto;
  }

  .contact-footer-section .contact-form {
    grid-template-columns: 1fr;
  }

  .contact-submit {
    width: 100%;
  }

  .contact-visual {
    min-height: 480px;
    border-radius: 24px;
  }

  .contact-visual-main {
    min-height: 480px;
  }

  .contact-visual-caption {
    left: 18px;
    right: 18px;
    bottom: 18px;
    padding: 20px;
    border-radius: 18px;
  }

  .contact-visual-caption strong {
    font-size: 30px;
  }

  .contact-visual-tags {
    top: 18px;
    left: 18px;
    right: 18px;
  }

  .contact-visual-tags span {
    min-height: 32px;
    padding: 8px 11px;
    font-size: 9.8px;
  }

  .contact-footer-section .integrated-footer {
    padding-top: 58px !important;
  }

  .footer-divider {
    margin-bottom: 38px;
  }

  .footer-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .footer-brand p {
    max-width: none;
  }

  .footer-socials {
    gap: 8px;
  }

  .footer-copy {
    margin-top: 40px;
  }
}

@media (max-width: 460px) {
  .contact-card h2 {
    font-size: 40px;
  }

  .contact-visual {
    min-height: 430px;
  }

  .contact-visual-main {
    min-height: 430px;
  }

  .contact-visual-caption strong {
    font-size: 27px;
  }

  .footer-socials {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* =========================================================
   COLECCIÓN LAOS STUDIO - CATÁLOGO COMPLETO
   Edita solo si deseas ajustar la apariencia de las tarjetas.
   Los productos y sus textos están en script.js > PRODUCTOS_CATALOGO_LAOS.
   ========================================================= */

.collection-title-row small {
  display: inline-block !important;
  margin-top: 7px !important;
  color: rgba(22, 17, 19, .50) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}

.collection-featured-tag {
  position: absolute !important;
  left: 14px !important;
  bottom: 14px !important;
  z-index: 5 !important;
  padding: 8px 11px !important;
  border-radius: 999px !important;
  background: rgba(111, 36, 55, .92) !important;
  color: #fff8ee !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  backdrop-filter: blur(10px) !important;
}

.collection-product-meta {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 9px !important;
}

.collection-product-meta span {
  min-height: 54px !important;
  display: grid !important;
  align-content: center !important;
  gap: 4px !important;
  padding: 10px 11px !important;
  border: 1px solid rgba(111, 36, 55, .12) !important;
  border-radius: 7px !important;
  background: rgba(255, 248, 238, .58) !important;
  color: rgba(22, 17, 19, .70) !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
}

.collection-product-meta strong {
  display: block !important;
  color: var(--laos-wine) !important;
  font-size: 9px !important;
  font-weight: 900 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
}

.collection-actions {
  grid-template-columns: 1fr 1fr !important;
}

.collection-whatsapp-btn {
  grid-column: 1 / -1 !important;
  min-height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 16px !important;
  border-radius: 7px !important;
  background: #171113 !important;
  color: #fff8ee !important;
  text-decoration: none !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  transition: transform .24s ease, background .24s ease !important;
}

.collection-whatsapp-btn:hover {
  transform: translateY(-1px) !important;
  background: var(--laos-wine) !important;
}

.collection-add-btn,
.collection-detail-btn {
  width: 100% !important;
}

@media (max-width: 1180px) {
  .collection-grid,
  .productos.collection-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 820px) {
  .collection-grid,
  .productos.collection-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 520px) {
  .collection-grid,
  .productos.collection-grid {
    grid-template-columns: 1fr !important;
  }

  .collection-product-meta,
  .collection-actions {
    grid-template-columns: 1fr !important;
  }

  .collection-whatsapp-btn {
    grid-column: auto !important;
  }
}


/* =========================================================
   NUESTRA COLECCIÓN - CARDS PREMIUM LIMPIAS
   Esta capa solo afecta la sección #coleccion y mantiene intactas
   las funciones existentes de filtros, carrito, WhatsApp y modal.
   ========================================================= */

#coleccion.collection-boutique {
  --laos-card-bg: rgba(255, 252, 247, .96);
  --laos-card-border: rgba(111, 36, 55, .10);
  --laos-soft: #fff8ee;
  --laos-ink-soft: rgba(22, 17, 19, .76);
}

#coleccion .collection-select-mobile {
  display: none !important;
}

#coleccion .collection-toolbar {
  align-items: center !important;
}

#coleccion .collection-grid,
#coleccion .productos.collection-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: clamp(18px, 2.4vw, 30px) !important;
}

#coleccion .collection-card {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
  overflow: hidden !important;
  border: 1px solid var(--laos-card-border) !important;
  border-radius: 22px !important;
  background: var(--laos-card-bg) !important;
  box-shadow: 0 22px 60px rgba(26, 16, 17, .08) !important;
  transform: translateZ(0) !important;
}

#coleccion .collection-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 32px 82px rgba(26, 16, 17, .14) !important;
}

#coleccion .collection-card-media {
  position: relative !important;
  aspect-ratio: 3 / 4 !important;
  min-height: 320px !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 50% 24%, rgba(216, 180, 140, .28), transparent 36%),
    linear-gradient(135deg, #f7ece2, #ead5c9) !important;
}

#coleccion .collection-image-btn {
  width: 100% !important;
  height: 100% !important;
  border: 0 !important;
  background: transparent !important;
  cursor: default !important;
}

#coleccion .collection-card-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center top !important;
  transition: opacity .2s ease, transform .55s ease !important;
}

#coleccion .collection-card:hover .collection-card-media img {
  transform: scale(1.035) !important;
}

#coleccion .collection-badge,
#coleccion .collection-featured-tag {
  position: absolute !important;
  z-index: 5 !important;
  display: inline-flex !important;
  align-items: center !important;
  min-height: 30px !important;
  padding: 8px 12px !important;
  border-radius: 999px !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  letter-spacing: .14em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  backdrop-filter: blur(12px) !important;
}

#coleccion .collection-badge {
  left: 14px !important;
  top: 14px !important;
  background: rgba(255, 248, 238, .88) !important;
  color: var(--laos-wine, #6f2437) !important;
  border: 1px solid rgba(111, 36, 55, .10) !important;
}

#coleccion .collection-featured-tag {
  right: 14px !important;
  bottom: 14px !important;
  left: auto !important;
  background: rgba(22, 17, 19, .82) !important;
  color: #fff8ee !important;
}

#coleccion .collection-stock,
#coleccion .collection-product-meta,
#coleccion .collection-title-row small,
#coleccion .collection-title-row strong {
  display: none !important;
}

#coleccion .collection-card-body {
  display: flex !important;
  flex: 1 1 auto !important;
  flex-direction: column !important;
  gap: 14px !important;
  padding: 22px !important;
}

#coleccion .collection-title-row {
  display: block !important;
}

#coleccion .collection-title-row h3 {
  display: -webkit-box !important;
  min-height: calc(1.08em * 2) !important;
  margin: 0 !important;
  overflow: hidden !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  color: var(--laos-ink, #161113) !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(25px, 2.1vw, 32px) !important;
  font-weight: 700 !important;
  line-height: 1.08 !important;
  letter-spacing: -.02em !important;
}

#coleccion .collection-card-description {
  display: -webkit-box !important;
  min-height: calc(1.65em * 2) !important;
  margin: 0 !important;
  overflow: hidden !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  color: var(--laos-ink-soft) !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
}

#coleccion .collection-card-essentials {
  display: grid !important;
  gap: 13px !important;
  padding-top: 2px !important;
}

#coleccion .collection-color-field,
#coleccion .collection-size-field {
  display: grid !important;
  gap: 8px !important;
}

#coleccion .collection-color-field > span,
#coleccion .collection-size-field > span {
  color: rgba(111, 36, 55, .72) !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
}

#coleccion .collection-color-dots {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  min-height: 28px !important;
}

#coleccion .collection-color-dot {
  width: 22px !important;
  height: 22px !important;
  flex: 0 0 22px !important;
  border: 2px solid rgba(255, 252, 247, .98) !important;
  border-radius: 50% !important;
  background: var(--dot-color, #d8b48c) !important;
  box-shadow: 0 0 0 1px rgba(22, 17, 19, .16), 0 5px 12px rgba(22, 17, 19, .12) !important;
  cursor: pointer !important;
}

#coleccion .collection-color-dot.active {
  box-shadow: 0 0 0 2px var(--laos-wine, #6f2437), 0 7px 16px rgba(111, 36, 55, .18) !important;
  transform: translateY(-1px) !important;
}

#coleccion .collection-size-chips {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 7px !important;
}

#coleccion .collection-size-chip {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 34px !important;
  min-height: 28px !important;
  padding: 6px 10px !important;
  border: 1px solid rgba(111, 36, 55, .12) !important;
  border-radius: 999px !important;
  background: rgba(255, 248, 238, .78) !important;
  color: rgba(22, 17, 19, .74) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: .04em !important;
}

#coleccion .collection-hidden-select {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
}

#coleccion .collection-commercial-status {
  margin: auto 0 0 !important;
  padding: 10px 12px !important;
  border: 1px solid rgba(111, 36, 55, .10) !important;
  border-radius: 999px !important;
  background: rgba(111, 36, 55, .055) !important;
  color: rgba(111, 36, 55, .86) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .08em !important;
  line-height: 1.2 !important;
  text-align: center !important;
  text-transform: uppercase !important;
}

#coleccion .collection-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
}

#coleccion .collection-whatsapp-btn {
  grid-column: 1 / -1 !important;
  min-height: 48px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 16px !important;
  border-radius: 999px !important;
  background: #171113 !important;
  color: #fff8ee !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .10em !important;
  line-height: 1.15 !important;
  text-align: center !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  transition: transform .24s ease, background .24s ease !important;
}

#coleccion .collection-whatsapp-btn:hover {
  transform: translateY(-1px) !important;
  background: var(--laos-wine, #6f2437) !important;
}

#coleccion .collection-detail-btn,
#coleccion .collection-add-btn {
  min-height: 42px !important;
  width: 100% !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .10em !important;
  text-transform: uppercase !important;
}

#coleccion .collection-detail-btn {
  border: 1px solid rgba(22, 17, 19, .14) !important;
  background: rgba(255, 248, 238, .72) !important;
  color: #171113 !important;
}

#coleccion .collection-add-btn {
  border: 0 !important;
  background: var(--laos-wine, #6f2437) !important;
  color: #fff8ee !important;
}

#coleccion .collection-slider-btn,
#coleccion .collection-slider-dots {
  opacity: 0 !important;
  pointer-events: none !important;
}

#coleccion .collection-card-slider:hover .collection-slider-btn,
#coleccion .collection-card-slider:focus-within .collection-slider-btn,
#coleccion .collection-card-slider:hover .collection-slider-dots,
#coleccion .collection-card-slider:focus-within .collection-slider-dots {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.quick-view-details {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.quick-view-detail-item {
  display: grid !important;
  gap: 5px !important;
  padding: 12px 13px !important;
  border: 1px solid rgba(111, 36, 55, .12) !important;
  border-radius: 10px !important;
  background: rgba(255, 248, 238, .62) !important;
}

.quick-view-detail-item span {
  color: rgba(111, 36, 55, .72) !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
}

.quick-view-detail-item strong {
  color: rgba(22, 17, 19, .76) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
}

.quick-view-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 12px !important;
}

.quick-view-actions .quick-view-whatsapp,
.quick-view-actions .quick-view-add {
  width: 100% !important;
  min-height: 52px !important;
}

@media (max-width: 1180px) {
  #coleccion .collection-grid,
  #coleccion .productos.collection-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 900px) {
  #coleccion .collection-grid,
  #coleccion .productos.collection-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #coleccion .collection-select-mobile {
    display: grid !important;
  }
}

@media (max-width: 560px) {
  #coleccion .collection-grid,
  #coleccion .productos.collection-grid {
    grid-template-columns: 1fr !important;
  }

  #coleccion .collection-card-media {
    min-height: 380px !important;
  }

  #coleccion .collection-actions,
  .quick-view-actions,
  .quick-view-details {
    grid-template-columns: 1fr !important;
  }

  #coleccion .collection-whatsapp-btn {
    grid-column: auto !important;
  }
}


/* =============================== */
/* VARIANTES DE PRODUCTO - COLECCIÓN */
/* =============================== */

#coleccion .collection-variant-label {
  margin: -4px 0 0 !important;
  color: rgba(111, 36, 55, .82) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: .04em !important;
}

#coleccion .color-dot,
#coleccion .collection-color-dot {
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease !important;
}

#coleccion .color-dot.active,
#coleccion .collection-color-dot.active {
  border-color: #fffaf4 !important;
  box-shadow: 0 0 0 3px var(--laos-wine, #6f2437), 0 8px 18px rgba(111, 36, 55, .2) !important;
  transform: scale(1.12) !important;
}

#coleccion .color-dot:hover,
#coleccion .collection-color-dot:hover {
  transform: scale(1.08) !important;
}


/* =====================================================
   LAOS STUDIO - Miniaturas por variante en colección
   ===================================================== */
#coleccion .product-thumbnails,
#coleccion .collection-slider-dots.product-thumbnails {
  position: static !important;
  display: flex !important;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin: 10px auto 0;
  padding: 0 12px 12px;
  opacity: 1 !important;
  transform: none !important;
  background: transparent !important;
}

#coleccion .product-thumb,
#coleccion .collection-slider-dot.product-thumb {
  width: 54px !important;
  height: 68px !important;
  border-radius: 10px !important;
  padding: 0 !important;
  border: 2px solid transparent !important;
  background: #f8f3ee !important;
  cursor: pointer;
  overflow: hidden;
  opacity: 1 !important;
  box-shadow: 0 8px 18px rgba(0,0,0,.08);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

#coleccion .product-thumb img,
#coleccion .collection-slider-dot.product-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
}

#coleccion .product-thumb.active,
#coleccion .collection-slider-dot.product-thumb.active {
  border-color: #7b243d !important;
  transform: scale(1.04);
  box-shadow: 0 0 0 3px #fff, 0 10px 24px rgba(123,36,61,.18);
}

#coleccion .product-thumb:hover,
#coleccion .collection-slider-dot.product-thumb:hover {
  transform: scale(1.03);
}

#coleccion .collection-card-media {
  padding-bottom: 8px;
}

#coleccion .collection-slider-btn {
  top: 42% !important;
}

.quick-view-slider-dots {
  display: flex !important;
  gap: 10px;
  justify-content: flex-start;
  align-items: center;
  margin-top: 12px;
}

.quick-view-thumb,
.quick-view-slider-dot.quick-view-thumb {
  width: 64px !important;
  height: 78px !important;
  border-radius: 12px !important;
  overflow: hidden;
  border: 2px solid transparent !important;
  background: #f8f3ee !important;
  padding: 0 !important;
  box-shadow: 0 8px 18px rgba(0,0,0,.10);
}

.quick-view-thumb img,
.quick-view-slider-dot.quick-view-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.quick-view-thumb.active,
.quick-view-slider-dot.quick-view-thumb.active {
  border-color: #7b243d !important;
  transform: scale(1.04);
  box-shadow: 0 0 0 3px #fff, 0 10px 24px rgba(123,36,61,.18);
}

#coleccion .color-dot,
#coleccion .collection-color-dot {
  background: var(--dot-color, #d8c2a8) !important;
}

@media (max-width: 768px) {
  #coleccion .product-thumb,
  #coleccion .collection-slider-dot.product-thumb {
    width: 48px !important;
    height: 60px !important;
  }

  .quick-view-thumb,
  .quick-view-slider-dot.quick-view-thumb {
    width: 54px !important;
    height: 68px !important;
  }
}


/* CREA TU PROPIO LOOK | GALERÍA INTERACTIVA LAOS */
.look-builder-section {
  --lb-bg: #fbf7f2;
  --lb-paper: rgba(255, 255, 255, .86);
  --lb-ink: #16120f;
  --lb-muted: rgba(22, 18, 15, .64);
  --lb-soft: #efe2d4;
  --lb-line: rgba(48, 34, 24, .12);
  --lb-gold: #c99d64;
  --lb-gold-deep: #a7793f;
  --lb-shadow: 0 32px 90px rgba(53, 35, 24, .13);
  --lb-radius-xl: 30px;
  position: relative;
  overflow: hidden;
  padding-top: clamp(88px, 8vw, 118px);
  background:
    radial-gradient(circle at 14% 12%, rgba(216, 180, 140, .22), transparent 34%),
    radial-gradient(circle at 88% 16%, rgba(117, 77, 38, .10), transparent 36%),
    linear-gradient(135deg, #fffaf6 0%, var(--lb-bg) 52%, #f0e3d5 100%);
  color: var(--lb-ink);
}

.look-builder-section::before,
.look-builder-section::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.look-builder-section::before {
  inset: 32px;
  border: 1px solid rgba(48, 34, 24, .055);
  border-radius: 44px;
}

.look-builder-section::after {
  width: 360px;
  height: 360px;
  right: -150px;
  bottom: 8%;
  border-radius: 999px;
  background: rgba(201, 157, 100, .10);
  filter: blur(3px);
}

.look-builder-shell {
  position: relative;
  z-index: 1;
  width: min(100%, 1220px);
  margin: 0 auto;
}

.look-builder-heading {
  width: min(100%, 860px);
  margin: 0 auto 36px;
}

.look-builder-heading span {
  color: var(--lb-gold-deep);
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .24em;
}

.look-builder-heading h2 {
  color: var(--lb-ink);
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(48px, 7vw, 88px);
  line-height: .92;
  letter-spacing: -.045em;
}

.look-builder-heading p {
  width: min(100%, 640px);
  margin: 18px auto 0;
  color: var(--lb-muted);
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  line-height: 1.8;
}

.look-builder-app {
  width: 100%;
}

.look-builder-loading {
  width: min(100%, 720px);
  margin: 0 auto;
  padding: 34px;
  border: 1px solid var(--lb-line);
  border-radius: 28px;
  background: var(--lb-paper);
  text-align: center;
  box-shadow: var(--lb-shadow);
}

.look-builder-loading h3,
.look-builder-empty h3 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 34px;
  line-height: 1;
}

.look-builder-loading p,
.look-builder-empty p {
  margin-top: 10px;
  color: var(--lb-muted);
  font-family: 'Manrope', sans-serif;
  line-height: 1.7;
}

.look-builder-main {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(390px, .95fr);
  gap: 28px;
  align-items: stretch;
}

.look-stage-card,
.look-controls-card,
.look-suggestions {
  border: 1px solid var(--lb-line);
  border-radius: var(--lb-radius-xl);
  background: var(--lb-paper);
  box-shadow: var(--lb-shadow);
  backdrop-filter: blur(14px);
}

.look-stage-card {
  position: relative;
  overflow: hidden;
  min-height: 690px;
}

.look-stage-actions {
  position: absolute;
  top: 22px;
  left: 22px;
  z-index: 5;
  display: grid;
  gap: 10px;
}

.look-icon-btn {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, .66);
  border-radius: 50%;
  background: rgba(255, 255, 255, .68);
  color: var(--lb-ink);
  cursor: pointer;
  box-shadow: 0 14px 32px rgba(31, 20, 12, .10);
  backdrop-filter: blur(10px);
  transition: transform .25s ease, background .25s ease;
}

.look-icon-btn:hover,
.look-icon-btn:focus-visible {
  transform: translateY(-2px);
  background: #fff;
  outline: 0;
}

.look-stage-scene {
  position: relative;
  min-height: 690px;
  padding: 34px 28px 122px;
  display: grid;
  place-items: center;
  background:
    linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.60)),
    url('img/galeria/base/escenario-fondo.webp') center/cover no-repeat;
}

.look-stage-scene::before {
  content: "LAOS\A STUDIO";
  white-space: pre;
  position: absolute;
  top: 54px;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(152, 108, 58, .42);
  font-family: 'Cormorant Garamond', serif;
  font-size: 44px;
  line-height: .78;
  letter-spacing: .20em;
  text-align: center;
}

.look-mannequin-frame {
  position: relative;
  width: min(78%, 430px);
  aspect-ratio: 9 / 13;
  transform: scale(var(--look-zoom, 1));
  transform-origin: center bottom;
  transition: transform .35s ease;
}

.look-layer {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
  user-select: none;
  opacity: 1;
  transition: opacity .25s ease, transform .25s ease;
}

.look-layer-base { z-index: 1; }
.look-layer-inferior { z-index: 2; }
.look-layer-superior { z-index: 3; }
.look-layer-capa-extra { z-index: 4; }
.look-layer-shadow { z-index: 0; }

.look-selection-strip {
  position: absolute;
  left: 22px;
  right: 22px;
  bottom: 22px;
  z-index: 6;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.look-selected-chip {
  min-width: 0;
  display: grid;
  grid-template-columns: 46px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 9px;
  border: 1px solid rgba(255, 255, 255, .62);
  border-radius: 17px;
  background: rgba(255, 255, 255, .66);
  box-shadow: 0 14px 34px rgba(31, 20, 12, .10);
  backdrop-filter: blur(12px);
}

.look-selected-chip img {
  width: 46px;
  height: 54px;
  object-fit: contain;
  border-radius: 12px;
  background: rgba(255, 255, 255, .54);
}

.look-selected-chip small {
  display: block;
  color: rgba(22, 18, 15, .48);
  font: 800 9px/1 'Manrope', sans-serif;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.look-selected-chip strong {
  display: block;
  overflow: hidden;
  color: var(--lb-ink);
  font: 800 12px/1.28 'Manrope', sans-serif;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.look-remove-chip {
  width: 24px;
  height: 24px;
  border: 0;
  border-radius: 50%;
  background: rgba(22, 18, 15, .07);
  color: rgba(22, 18, 15, .64);
  cursor: pointer;
}

.look-controls-card {
  padding: 30px 30px 26px;
}

.look-controls-card h3 {
  margin-bottom: 6px;
  color: var(--lb-ink);
  font-family: 'Cormorant Garamond', serif;
  font-size: 34px;
  line-height: 1;
}

.look-controls-intro {
  margin-bottom: 24px;
  color: var(--lb-muted);
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  line-height: 1.7;
}

.look-option-group {
  margin-top: 24px;
  padding-top: 22px;
  border-top: 1px solid var(--lb-line);
}

.look-option-group:first-of-type {
  margin-top: 18px;
}

.look-group-heading {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: baseline;
  margin-bottom: 12px;
}

.look-group-heading h4 {
  color: var(--lb-ink);
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  line-height: 1;
}

.look-group-heading span {
  color: rgba(22, 18, 15, .46);
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 800;
}

.look-options-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.look-option-card {
  position: relative;
  min-height: 124px;
  padding: 9px 8px 7px;
  border: 1px solid rgba(48, 34, 24, .11);
  border-radius: 15px;
  background: rgba(255, 255, 255, .74);
  cursor: pointer;
  text-align: center;
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease, background .25s ease;
}

.look-option-card:hover,
.look-option-card:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(201, 157, 100, .55);
  outline: 0;
  box-shadow: 0 18px 38px rgba(31, 20, 12, .08);
}

.look-option-card.active {
  border-color: var(--lb-gold);
  background: #fff;
  box-shadow: 0 18px 42px rgba(201, 157, 100, .18);
}

.look-option-card.active::after {
  content: "✓";
  position: absolute;
  top: 8px;
  right: 8px;
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--lb-gold-deep);
  color: #fff;
  font: 900 13px/1 'Manrope', sans-serif;
}

.look-option-card img {
  width: 100%;
  height: 78px;
  object-fit: contain;
}

.look-option-card span {
  display: block;
  overflow: hidden;
  margin-top: 7px;
  color: rgba(22, 18, 15, .72);
  font: 800 10px/1.25 'Manrope', sans-serif;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.look-color-panel {
  margin-top: 24px;
  padding-top: 22px;
  border-top: 1px solid var(--lb-line);
}

.look-color-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 12px 0 14px;
}

.look-color-tab {
  min-height: 33px;
  border: 1px solid rgba(48, 34, 24, .10);
  border-radius: 999px;
  padding: 0 13px;
  background: rgba(255, 255, 255, .70);
  color: rgba(22, 18, 15, .65);
  font: 900 11px/1 'Manrope', sans-serif;
  cursor: pointer;
}

.look-color-tab.active {
  border-color: var(--lb-ink);
  background: var(--lb-ink);
  color: #fff;
}

.look-color-swatches {
  display: flex;
  gap: 13px;
  flex-wrap: wrap;
}

.look-color-dot {
  position: relative;
  width: 43px;
  height: 43px;
  border: 1px solid rgba(48, 34, 24, .10);
  border-radius: 50%;
  background: var(--color, #ddd);
  cursor: pointer;
  box-shadow: inset 0 0 0 5px rgba(255,255,255,.72), 0 10px 22px rgba(31,20,12,.08);
}

.look-color-dot.active::after {
  content: "✓";
  position: absolute;
  right: -3px;
  bottom: -3px;
  width: 20px;
  height: 20px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--lb-gold-deep);
  color: #fff;
  font: 900 11px/1 'Manrope', sans-serif;
}

.look-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 24px;
}

.look-action-primary,
.look-action-secondary,
.look-action-whatsapp {
  min-height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: 12px;
  padding: 0 18px;
  font: 900 13px/1 'Manrope', sans-serif;
  text-decoration: none;
  cursor: pointer;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
}

.look-action-primary {
  grid-column: 1 / -1;
  border: 1px solid var(--lb-ink);
  background: var(--lb-ink);
  color: #fff;
}

.look-action-secondary {
  border: 1px solid rgba(48, 34, 24, .18);
  background: rgba(255,255,255,.72);
  color: var(--lb-ink);
}

.look-action-whatsapp {
  border: 1px solid rgba(201, 157, 100, .36);
  background: linear-gradient(135deg, rgba(201,157,100,.26), rgba(255,255,255,.72));
  color: var(--lb-ink);
}

.look-action-primary:hover,
.look-action-secondary:hover,
.look-action-whatsapp:hover,
.look-action-primary:focus-visible,
.look-action-secondary:focus-visible,
.look-action-whatsapp:focus-visible {
  transform: translateY(-2px);
  outline: 0;
  box-shadow: 0 16px 34px rgba(31, 20, 12, .11);
}

.look-suggestions {
  margin-top: 28px;
  padding: 26px;
}

.look-suggestions-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: end;
  margin-bottom: 18px;
}

.look-suggestions-head h3 {
  color: var(--lb-ink);
  font-family: 'Cormorant Garamond', serif;
  font-size: 32px;
  line-height: 1;
}

.look-suggestions-head p {
  width: min(100%, 500px);
  color: var(--lb-muted);
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  line-height: 1.7;
}

.look-suggestions-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.look-suggestion-card {
  overflow: hidden;
  display: grid;
  grid-template-rows: 200px 1fr;
  border: 1px solid rgba(48, 34, 24, .10);
  border-radius: 22px;
  background: rgba(255,255,255,.68);
}

.look-suggestion-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.look-suggestion-copy {
  padding: 18px;
}

.look-suggestion-copy small {
  color: var(--lb-gold-deep);
  font: 900 10px/1 'Manrope', sans-serif;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.look-suggestion-copy h4 {
  margin-top: 8px;
  color: var(--lb-ink);
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px;
  line-height: .96;
}

.look-suggestion-copy p {
  margin-top: 10px;
  min-height: 42px;
  color: var(--lb-muted);
  font: 500 12px/1.6 'Manrope', sans-serif;
}

.look-suggestion-copy button {
  margin-top: 15px;
  min-height: 38px;
  border: 1px solid rgba(201,157,100,.50);
  border-radius: 999px;
  padding: 0 17px;
  background: rgba(255,255,255,.70);
  color: var(--lb-gold-deep);
  font: 900 11px/1 'Manrope', sans-serif;
  cursor: pointer;
}

.look-builder-empty {
  padding: 38px;
  border: 1px solid var(--lb-line);
  border-radius: 28px;
  background: var(--lb-paper);
  text-align: center;
}

@media (max-width: 1080px) {
  .look-builder-main {
    grid-template-columns: 1fr;
  }

  .look-controls-card {
    padding: 26px;
  }

  .look-options-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .look-suggestions-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .look-builder-section {
    padding: 76px 16px;
  }

  .look-builder-section::before {
    inset: 14px;
    border-radius: 28px;
  }

  .look-builder-heading h2 {
    font-size: clamp(43px, 13vw, 62px);
  }

  .look-stage-card {
    min-height: 610px;
    border-radius: 24px;
  }

  .look-stage-scene {
    min-height: 610px;
    padding: 28px 18px 162px;
  }

  .look-stage-scene::before {
    top: 44px;
    font-size: 31px;
  }

  .look-mannequin-frame {
    width: min(86%, 330px);
  }

  .look-stage-actions {
    top: 15px;
    left: 15px;
  }

  .look-icon-btn {
    width: 39px;
    height: 39px;
  }

  .look-selection-strip {
    grid-template-columns: 1fr;
    left: 14px;
    right: 14px;
    bottom: 14px;
  }

  .look-selected-chip {
    grid-template-columns: 40px 1fr auto;
  }

  .look-selected-chip img {
    width: 40px;
    height: 48px;
  }

  .look-controls-card,
  .look-suggestions {
    padding: 20px;
    border-radius: 24px;
  }

  .look-options-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .look-option-card {
    min-height: 120px;
  }

  .look-actions {
    grid-template-columns: 1fr;
  }

  .look-action-primary {
    grid-column: auto;
  }

  .look-suggestions-head {
    display: block;
  }

  .look-suggestions-head p {
    margin-top: 8px;
  }

  .look-suggestions-grid {
    grid-template-columns: 1fr;
  }

  .look-suggestion-card {
    grid-template-rows: 210px 1fr;
  }
}

/* FIN CREA TU PROPIO LOOK | GALERÍA INTERACTIVA LAOS */

/* =========================================================
   COLECCIÓN LAOS | CATÁLOGO PREMIUM REFACTORIZADO
   Cambios aislados a la sección #coleccion, cards y vista rápida
   ========================================================= */

#coleccion.collection-boutique {
  background:
    radial-gradient(circle at 12% 8%, rgba(216, 180, 140, .24), transparent 34%),
    linear-gradient(180deg, #fffaf3 0%, #f7eee4 52%, #f4eadf 100%) !important;
  color: var(--laos-ink, #161113) !important;
  overflow: hidden !important;
}

#coleccion .collection-shell {
  width: min(1440px, 100%) !important;
  margin: 0 auto !important;
}

#coleccion .collection-header {
  display: grid !important;
  grid-template-columns: minmax(160px, 220px) minmax(0, 780px) !important;
  align-items: end !important;
  gap: clamp(22px, 4vw, 62px) !important;
  margin-bottom: 34px !important;
}

#coleccion .collection-header .section-kicker {
  color: var(--laos-wine, #6f2437) !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: .22em !important;
  text-transform: uppercase !important;
}

#coleccion .collection-header h2 {
  max-width: 760px !important;
  color: var(--laos-ink, #161113) !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(38px, 4.6vw, 72px) !important;
  line-height: .92 !important;
  letter-spacing: -.035em !important;
  margin: 0 0 16px !important;
}

#coleccion .collection-header p {
  max-width: 650px !important;
  color: rgba(22, 17, 19, .66) !important;
  font-size: 15px !important;
  line-height: 1.8 !important;
}

#coleccion .collection-toolbar {
  display: grid !important;
  grid-template-columns: minmax(280px, 1.2fr) minmax(180px, .42fr) !important;
  align-items: end !important;
  gap: 16px !important;
  margin: 0 0 18px !important;
  padding: 18px !important;
  border: 1px solid rgba(111, 36, 55, .11) !important;
  border-radius: 26px !important;
  background: rgba(255, 248, 238, .76) !important;
  box-shadow: 0 22px 70px rgba(86, 60, 42, .09) !important;
  backdrop-filter: blur(14px) !important;
}

#coleccion .collection-search-field,
#coleccion .collection-select-wrap {
  min-width: 0 !important;
  display: grid !important;
  gap: 8px !important;
}

#coleccion .collection-search-field span,
#coleccion .collection-select-wrap span {
  color: var(--laos-wine, #6f2437) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .17em !important;
  text-transform: uppercase !important;
}

#coleccion .collection-search-field input,
#coleccion .collection-select-wrap select {
  width: 100% !important;
  height: 52px !important;
  padding: 0 18px !important;
  border: 1px solid rgba(111, 36, 55, .14) !important;
  border-radius: 999px !important;
  background: #fffaf3 !important;
  color: var(--laos-ink, #161113) !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 14px !important;
  outline: none !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7) !important;
}

#coleccion .collection-search-field input:focus,
#coleccion .collection-select-wrap select:focus {
  border-color: rgba(111, 36, 55, .42) !important;
  box-shadow: 0 0 0 4px rgba(111, 36, 55, .08) !important;
}

#coleccion .collection-categories {
  grid-column: 1 / -1 !important;
  display: flex !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  overflow-x: auto !important;
  padding: 4px 2px 6px !important;
  scrollbar-width: thin !important;
}

#coleccion .collection-categories::-webkit-scrollbar {
  height: 5px !important;
}

#coleccion .collection-filter {
  flex: 0 0 auto !important;
  min-height: 42px !important;
  border: 1px solid rgba(111, 36, 55, .13) !important;
  border-radius: 999px !important;
  background: rgba(255, 250, 243, .86) !important;
  color: rgba(22, 17, 19, .76) !important;
  padding: 0 18px !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: .04em !important;
  cursor: pointer !important;
  transition: transform .22s ease, background .22s ease, color .22s ease, border-color .22s ease !important;
}

#coleccion .collection-filter span {
  opacity: .72 !important;
  margin-left: 4px !important;
}

#coleccion .collection-filter:hover:not(:disabled) {
  transform: translateY(-2px) !important;
  border-color: rgba(111, 36, 55, .28) !important;
}

#coleccion .collection-filter.active {
  background: linear-gradient(135deg, #161113, #6f2437) !important;
  color: #fff8ee !important;
  border-color: rgba(111, 36, 55, .72) !important;
  box-shadow: 0 12px 28px rgba(111, 36, 55, .22) !important;
}

#coleccion .collection-filter:disabled {
  opacity: .42 !important;
  cursor: not-allowed !important;
}

#coleccion .collection-results-meta {
  min-height: 24px !important;
  margin: 12px 4px 28px !important;
  color: rgba(22, 17, 19, .62) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: .04em !important;
}

#coleccion .collection-grid,
#coleccion .productos.collection-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: clamp(18px, 2vw, 28px) !important;
  align-items: stretch !important;
}

#coleccion .collection-card {
  height: 100% !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  border: 1px solid rgba(111, 36, 55, .10) !important;
  border-radius: 28px !important;
  background: rgba(255, 250, 243, .92) !important;
  box-shadow: 0 18px 60px rgba(44, 31, 22, .08) !important;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease !important;
}

#coleccion .collection-card:hover {
  transform: translateY(-8px) !important;
  border-color: rgba(111, 36, 55, .20) !important;
  box-shadow: 0 30px 80px rgba(44, 31, 22, .14) !important;
}

#coleccion .collection-card-media {
  position: relative !important;
  width: 100% !important;
  aspect-ratio: 3 / 4 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 50% 16%, rgba(214, 173, 120, .20), transparent 34%),
    #efe2d4 !important;
}

#coleccion .collection-image-btn {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  overflow: hidden !important;
}

#coleccion .collection-card-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center top !important;
  transform: scale(1.001) !important;
  transition: transform .45s ease, opacity .18s ease, filter .28s ease !important;
  background: #efe2d4 !important;
}

#coleccion .collection-card:hover .collection-card-media img {
  transform: scale(1.035) !important;
  filter: saturate(1.02) contrast(1.02) !important;
}

#coleccion .image-fallback-active img,
#coleccion .collection-card-media.image-fallback-active img {
  object-fit: cover !important;
  object-position: center !important;
}

#coleccion .collection-badge {
  position: absolute !important;
  top: 14px !important;
  left: 14px !important;
  z-index: 3 !important;
  max-width: calc(100% - 28px) !important;
  border: 1px solid rgba(255, 248, 238, .40) !important;
  border-radius: 999px !important;
  background: rgba(22, 17, 19, .74) !important;
  color: #fff8ee !important;
  backdrop-filter: blur(10px) !important;
  padding: 8px 11px !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  letter-spacing: .12em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}

#coleccion .collection-badge-a-pedido,
#coleccion .collection-badge-personalizable {
  background: rgba(111, 36, 55, .82) !important;
}

#coleccion .collection-badge-agotado {
  background: rgba(22, 17, 19, .82) !important;
}

#coleccion .collection-card-body {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  padding: 20px !important;
}

#coleccion .collection-card-category {
  margin: 0 !important;
  color: var(--laos-wine, #6f2437) !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  letter-spacing: .16em !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
}

#coleccion .collection-title-row {
  display: block !important;
  min-height: auto !important;
}

#coleccion .collection-title-row h3 {
  min-height: 2.35em !important;
  margin: 0 !important;
  color: var(--laos-ink, #161113) !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(24px, 1.8vw, 31px) !important;
  font-weight: 700 !important;
  line-height: 1.04 !important;
  letter-spacing: -.02em !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

#coleccion .collection-card-subtitle {
  margin: -2px 0 0 !important;
  color: rgba(22, 17, 19, .56) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: .02em !important;
}

#coleccion .collection-card-description {
  min-height: 3.15em !important;
  margin: 0 !important;
  color: rgba(22, 17, 19, .65) !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

#coleccion .collection-price {
  margin: 2px 0 4px !important;
  display: flex !important;
  align-items: baseline !important;
  gap: 9px !important;
}

#coleccion .collection-price strong {
  color: var(--laos-wine, #6f2437) !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 19px !important;
  font-weight: 900 !important;
  letter-spacing: .01em !important;
}

#coleccion .collection-old-price {
  color: rgba(22, 17, 19, .40) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  text-decoration: line-through !important;
}

#coleccion .collection-price-consult {
  color: var(--laos-wine, #6f2437) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
}

#coleccion .collection-card-essentials {
  display: grid !important;
  gap: 12px !important;
  margin-top: 2px !important;
}

#coleccion .collection-color-field,
#coleccion .collection-size-field {
  display: grid !important;
  gap: 8px !important;
}

#coleccion .collection-color-field > span,
#coleccion .collection-size-field > span {
  color: rgba(22, 17, 19, .48) !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  letter-spacing: .15em !important;
  text-transform: uppercase !important;
}

#coleccion .collection-color-dots {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 9px !important;
}

#coleccion .collection-color-dot {
  width: 21px !important;
  height: 21px !important;
  flex: 0 0 21px !important;
  border: 1px solid rgba(22, 17, 19, .20) !important;
  border-radius: 999px !important;
  background: var(--dot-color, #d8b48c) !important;
  cursor: pointer !important;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.45) !important;
  transition: transform .2s ease, outline .2s ease, box-shadow .2s ease !important;
}

#coleccion .collection-color-dot.is-pattern {
  background:
    radial-gradient(circle at 30% 34%, #111 0 10%, transparent 11%),
    radial-gradient(circle at 66% 60%, #3b2316 0 12%, transparent 13%),
    radial-gradient(circle at 60% 22%, #f3d6a6 0 11%, transparent 12%),
    var(--dot-color, #a6764f) !important;
}

#coleccion .collection-color-dot:hover,
#coleccion .collection-color-dot.active {
  transform: translateY(-1px) scale(1.08) !important;
  outline: 2px solid rgba(111, 36, 55, .70) !important;
  outline-offset: 3px !important;
}

#coleccion .collection-single-color-label {
  color: rgba(22, 17, 19, .52) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
}

#coleccion .collection-size-chips {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 7px !important;
}

#coleccion .collection-size-chip {
  min-width: 29px !important;
  min-height: 28px !important;
  display: inline-grid !important;
  place-items: center !important;
  border: 1px solid rgba(111, 36, 55, .14) !important;
  border-radius: 999px !important;
  background: rgba(255, 248, 238, .72) !important;
  color: rgba(22, 17, 19, .78) !important;
  padding: 0 10px !important;
  font-size: 11px !important;
  font-weight: 900 !important;
}

#coleccion .collection-size-chip.is-disabled {
  opacity: .38 !important;
  text-decoration: line-through !important;
}

#coleccion .collection-hidden-select {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

#coleccion .collection-commercial-status {
  margin: auto 0 0 !important;
  color: rgba(22, 17, 19, .58) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

#coleccion .collection-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  margin-top: 8px !important;
}

#coleccion .collection-actions .collection-whatsapp-btn {
  display: none !important;
}

#coleccion .collection-add-btn,
#coleccion .collection-detail-btn {
  width: 100% !important;
  min-height: 46px !important;
  display: inline-grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .12em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease !important;
}

#coleccion .collection-detail-btn {
  border: 1px solid rgba(111, 36, 55, .18) !important;
  background: rgba(255, 248, 238, .72) !important;
  color: var(--laos-wine, #6f2437) !important;
}

#coleccion .collection-add-btn {
  border: 1px solid var(--laos-wine, #6f2437) !important;
  background: linear-gradient(135deg, #161113, #6f2437) !important;
  color: #fff8ee !important;
}

#coleccion .collection-detail-btn:hover,
#coleccion .collection-add-btn:hover:not(:disabled) {
  transform: translateY(-2px) !important;
}

#coleccion .collection-add-btn:disabled,
#coleccion .collection-card.is-sold-out .collection-add-btn {
  opacity: .48 !important;
  cursor: not-allowed !important;
  background: #7d746b !important;
  border-color: #7d746b !important;
}

#coleccion .collection-skeleton-card {
  pointer-events: none !important;
}

#coleccion .skeleton-block {
  display: block !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, rgba(255,255,255,.30), rgba(216,180,140,.22), rgba(255,255,255,.30)) !important;
  background-size: 220% 100% !important;
  animation: laosSkeleton 1.35s ease-in-out infinite !important;
}

#coleccion .skeleton-image {
  width: 100% !important;
  height: 100% !important;
  border-radius: 0 !important;
}

#coleccion .skeleton-line {
  width: 100% !important;
  height: 13px !important;
}

#coleccion .skeleton-line.short { width: 42% !important; }
#coleccion .skeleton-line.medium { width: 70% !important; }

#coleccion .skeleton-button {
  width: 100% !important;
  height: 44px !important;
  margin-top: 12px !important;
}

@keyframes laosSkeleton {
  0% { background-position: 180% 0; }
  100% { background-position: -180% 0; }
}

#coleccion .collection-empty {
  grid-column: 1 / -1 !important;
  min-height: 260px !important;
  display: grid !important;
  place-items: center !important;
  text-align: center !important;
  padding: 48px 22px !important;
  border: 1px solid rgba(111, 36, 55, .13) !important;
  border-radius: 28px !important;
  background: rgba(255, 248, 238, .78) !important;
}

#coleccion .collection-empty span {
  color: var(--laos-wine, #6f2437) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
}

#coleccion .collection-empty h3 {
  margin: 10px 0 8px !important;
  color: var(--laos-ink, #161113) !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(30px, 4vw, 48px) !important;
  line-height: 1 !important;
}

#coleccion .collection-empty p {
  max-width: 460px !important;
  color: rgba(22, 17, 19, .60) !important;
  line-height: 1.7 !important;
}

.quick-view-availability {
  width: fit-content !important;
  margin: -4px 0 0 !important;
  border: 1px solid rgba(111, 36, 55, .15) !important;
  border-radius: 999px !important;
  background: rgba(255, 248, 238, .68) !important;
  color: var(--laos-wine, #6f2437) !important;
  padding: 8px 12px !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
}

.quick-view-details {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.quick-view-detail-item {
  border: 1px solid rgba(111, 36, 55, .12) !important;
  border-radius: 14px !important;
  background: rgba(255, 248, 238, .54) !important;
  padding: 12px !important;
}

.quick-view-detail-item span {
  display: block !important;
  margin-bottom: 4px !important;
  color: rgba(22, 17, 19, .45) !important;
  font-size: 9px !important;
  font-weight: 900 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
}

.quick-view-detail-item strong {
  color: var(--laos-ink, #161113) !important;
  font-size: 12px !important;
  line-height: 1.4 !important;
}

.quick-view-price .modal-price-inline,
.quick-view-price .collection-price-consult {
  display: inline-flex !important;
  align-items: baseline !important;
  gap: 9px !important;
}

.quick-view-price .modal-price-inline strong {
  color: var(--laos-wine, #6f2437) !important;
  font-size: 28px !important;
}

.quick-view-price .collection-old-price {
  color: rgba(22, 17, 19, .42) !important;
  font-size: 14px !important;
  text-decoration: line-through !important;
}

.quick-view-add:disabled {
  opacity: .48 !important;
  cursor: not-allowed !important;
  background: #7d746b !important;
}

.quick-view-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 12px !important;
}

.quick-view-slider-dots {
  position: absolute !important;
  left: 18px !important;
  right: 18px !important;
  bottom: 18px !important;
  z-index: 3 !important;
  display: flex !important;
  gap: 9px !important;
  overflow-x: auto !important;
  padding: 8px !important;
  border-radius: 18px !important;
  background: rgba(22, 17, 19, .28) !important;
  backdrop-filter: blur(14px) !important;
}

.quick-view-slider-dot {
  width: 54px !important;
  height: 68px !important;
  flex: 0 0 54px !important;
  overflow: hidden !important;
  border: 2px solid transparent !important;
  border-radius: 12px !important;
  background: #f3e4d6 !important;
  padding: 0 !important;
  cursor: pointer !important;
}

.quick-view-slider-dot.active {
  border-color: #fff8ee !important;
}

.quick-view-slider-dot img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

.quick-view-slider-btn {
  position: absolute !important;
  top: 50% !important;
  z-index: 4 !important;
  width: 42px !important;
  height: 42px !important;
  transform: translateY(-50%) !important;
  border: 1px solid rgba(255, 248, 238, .42) !important;
  border-radius: 50% !important;
  background: rgba(22, 17, 19, .42) !important;
  color: #fff8ee !important;
  font-size: 28px !important;
  cursor: pointer !important;
  backdrop-filter: blur(10px) !important;
}

.quick-view-slider-prev { left: 16px !important; }
.quick-view-slider-next { right: 16px !important; }

@media (max-width: 1180px) {
  #coleccion .collection-grid,
  #coleccion .productos.collection-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 900px) {
  #coleccion .collection-header {
    grid-template-columns: 1fr !important;
  }

  #coleccion .collection-toolbar {
    grid-template-columns: 1fr 1fr !important;
  }

  #coleccion .collection-grid,
  #coleccion .productos.collection-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .quick-view-details,
  .quick-view-actions {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 620px) {
  #coleccion.collection-boutique {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  #coleccion .collection-toolbar {
    grid-template-columns: 1fr !important;
    padding: 14px !important;
    border-radius: 22px !important;
  }

  #coleccion .collection-categories {
    margin-left: -2px !important;
    margin-right: -2px !important;
  }

  #coleccion .collection-filter {
    min-height: 40px !important;
    padding: 0 15px !important;
  }

  #coleccion .collection-grid,
  #coleccion .productos.collection-grid {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }

  #coleccion .collection-card-media {
    aspect-ratio: 4 / 5 !important;
  }

  #coleccion .collection-card-body {
    padding: 19px !important;
  }

  #coleccion .collection-actions {
    gap: 9px !important;
  }

  #coleccion .collection-add-btn,
  #coleccion .collection-detail-btn {
    min-height: 48px !important;
  }

  .quick-view {
    padding: 10px !important;
    align-items: end !important;
  }

  .quick-view-panel {
    width: 100% !important;
    max-height: 94vh !important;
    grid-template-columns: 1fr !important;
    border-radius: 24px 24px 0 0 !important;
    overflow-y: auto !important;
  }

  .quick-view-media {
    min-height: 420px !important;
  }

  .quick-view-content {
    padding: 24px 18px 28px !important;
  }

  .quick-view-content h2 {
    font-size: clamp(34px, 12vw, 48px) !important;
    line-height: .95 !important;
  }

  .quick-view-selects {
    grid-template-columns: 1fr !important;
  }
}

/* =========================================================
   AJUSTE PUNTUAL | ENCABEZADO COMPACTO DE COLECCIÓN
   Solo afecta a la sección #coleccion
   ========================================================= */

#coleccion .collection-header.collection-header-compact {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: 20px !important;
  margin-bottom: 24px !important;
  padding-bottom: 16px !important;
  border-bottom: 1px solid rgba(111, 36, 55, .12) !important;
}

#coleccion .collection-header.collection-header-compact .section-kicker {
  flex: 0 0 auto !important;
  margin-bottom: 7px !important;
  white-space: nowrap !important;
}

#coleccion .collection-header.collection-header-compact h2 {
  max-width: none !important;
  margin: 0 !important;
  font-size: clamp(34px, 3.2vw, 48px) !important;
  line-height: 1 !important;
  letter-spacing: -.025em !important;
}

#coleccion .collection-header.collection-header-compact p {
  display: none !important;
}

@media (max-width: 720px) {
  #coleccion .collection-header.collection-header-compact {
    align-items: flex-start !important;
    flex-direction: column !important;
    gap: 8px !important;
    margin-bottom: 18px !important;
    padding-bottom: 14px !important;
  }

  #coleccion .collection-header.collection-header-compact .section-kicker {
    margin-bottom: 0 !important;
  }

  #coleccion .collection-header.collection-header-compact h2 {
    font-size: clamp(32px, 10vw, 40px) !important;
  }
}



/* =========================================================
   AJUSTE COLECCIÓN: encabezado mínimo sin título grande
   ========================================================= */
#coleccion .collection-header.collection-header-minimal {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 0 !important;
  margin-bottom: 24px !important;
  padding-bottom: 16px !important;
  border-bottom: 1px solid rgba(111, 36, 55, .12) !important;
}

#coleccion .collection-header.collection-header-minimal .section-kicker {
  margin: 0 !important;
  color: var(--laos-wine, #6f2437) !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .24em !important;
  text-transform: uppercase !important;
}

#coleccion .collection-header.collection-header-minimal h2,
#coleccion .collection-header.collection-header-minimal p,
#coleccion .collection-header.collection-header-minimal > div {
  display: none !important;
}

@media (max-width: 720px) {
  #coleccion .collection-header.collection-header-minimal {
    margin-bottom: 18px !important;
    padding-bottom: 14px !important;
  }
}

/* =========================================================
   AJUSTE COLECCIÓN: tallas como selectores visuales premium
   ========================================================= */
#coleccion .collection-size-chips {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 9px !important;
  min-height: 32px !important;
}

#coleccion .collection-size-chip,
#coleccion .collection-size-button {
  appearance: none !important;
  -webkit-appearance: none !important;
  min-width: 34px !important;
  height: 34px !important;
  display: inline-grid !important;
  place-items: center !important;
  padding: 0 12px !important;
  border: 1px solid rgba(111, 36, 55, .18) !important;
  border-radius: 999px !important;
  background: rgba(255, 252, 247, .82) !important;
  color: rgba(22, 17, 19, .78) !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .05em !important;
  line-height: 1 !important;
  cursor: pointer !important;
  box-shadow: 0 6px 14px rgba(22, 17, 19, .06) !important;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease !important;
}

#coleccion .collection-size-chip:hover,
#coleccion .collection-size-button:hover,
#coleccion .collection-size-chip.active,
#coleccion .collection-size-button.active {
  transform: translateY(-1px) !important;
  border-color: rgba(111, 36, 55, .75) !important;
  background: rgba(111, 36, 55, .08) !important;
  color: var(--laos-wine, #6f2437) !important;
  box-shadow: 0 0 0 2px rgba(111, 36, 55, .32), 0 8px 18px rgba(111, 36, 55, .14) !important;
}

#coleccion .collection-size-chip.is-disabled,
#coleccion .collection-size-button.is-disabled,
#coleccion .collection-size-button:disabled {
  opacity: .38 !important;
  cursor: not-allowed !important;
  text-decoration: line-through !important;
  transform: none !important;
  box-shadow: none !important;
}


/* =========================================================
   AJUSTE COLECCIÓN: carga progresiva por filas
   Solo afecta a la sección #coleccion
   ========================================================= */
#coleccion .collection-load-more {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  margin: 34px auto 0 !important;
}

#coleccion .collection-load-more[hidden] {
  display: none !important;
}

#coleccion .collection-load-more-btn {
  appearance: none !important;
  -webkit-appearance: none !important;
  min-width: min(280px, 100%) !important;
  min-height: 54px !important;
  padding: 0 34px !important;
  border: 1px solid rgba(111, 36, 55, .32) !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #42101d, #6f2437) !important;
  color: #fff8ee !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  box-shadow: 0 18px 38px rgba(111, 36, 55, .22) !important;
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease, border-color .22s ease !important;
}

#coleccion .collection-load-more-btn:hover {
  transform: translateY(-2px) !important;
  border-color: rgba(199, 163, 90, .52) !important;
  background: linear-gradient(135deg, #1b1416, #5b1729) !important;
  box-shadow: 0 24px 52px rgba(111, 36, 55, .30) !important;
}

#coleccion .collection-load-more-btn:focus-visible {
  outline: 3px solid rgba(199, 163, 90, .38) !important;
  outline-offset: 4px !important;
}

@media (max-width: 620px) {
  #coleccion .collection-load-more {
    margin-top: 26px !important;
  }

  #coleccion .collection-load-more-btn {
    width: 100% !important;
    min-height: 52px !important;
  }
}


/* =========================================================
   QUICK VIEW BOUTIQUE | MODAL DE PRENDA LAOS
   Solo afecta la vista rápida que abre “Ver prenda”
   ========================================================= */

.quick-view.active {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: clamp(14px, 2vw, 28px) !important;
}

.quick-view-panel {
  width: min(1480px, 96vw) !important;
  height: min(860px, 90vh) !important;
  max-height: 90vh !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1.04fr) minmax(420px, .96fr) !important;
  overflow: hidden !important;
  border: 1px solid rgba(255, 248, 238, .18) !important;
  border-radius: 18px !important;
  background: #fbefe6 !important;
  box-shadow: 0 30px 80px rgba(0, 0, 0, .36) !important;
}

.quick-view-close {
  position: absolute !important;
  top: 24px !important;
  right: 24px !important;
  z-index: 20 !important;
  width: 54px !important;
  height: 54px !important;
  border: 1px solid rgba(255, 248, 238, .22) !important;
  border-radius: 50% !important;
  background: rgba(22, 17, 19, .72) !important;
  color: #fff8ee !important;
  font-size: 30px !important;
  line-height: 1 !important;
  display: grid !important;
  place-items: center !important;
  cursor: pointer !important;
  backdrop-filter: blur(12px) !important;
}

.quick-view-media {
  position: relative !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
  background: #eadbcd !important;
}

.quick-view-media img#quickViewImg {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center top !important;
  transition: opacity .24s ease !important;
}

.quick-view-content {
  height: 100% !important;
  max-height: 90vh !important;
  overflow-y: auto !important;
  overscroll-behavior: contain !important;
  padding: clamp(34px, 4vw, 72px) clamp(28px, 4vw, 76px) 42px !important;
  background: linear-gradient(135deg, #fff4eb 0%, #f7e5dc 100%) !important;
  scrollbar-width: thin !important;
  scrollbar-color: rgba(111, 36, 55, .35) rgba(255, 248, 238, .4) !important;
}

.quick-view-content::-webkit-scrollbar {
  width: 8px !important;
}

.quick-view-content::-webkit-scrollbar-track {
  background: rgba(255, 248, 238, .4) !important;
}

.quick-view-content::-webkit-scrollbar-thumb {
  border-radius: 999px !important;
  background: rgba(111, 36, 55, .35) !important;
}

.quick-view-summary {
  display: grid !important;
  gap: 18px !important;
  margin-bottom: 24px !important;
}

.quick-view-kicker {
  color: var(--laos-wine, #6f2437) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .42em !important;
  text-transform: uppercase !important;
}

.quick-view-content h2,
.quick-view-title {
  max-width: 760px !important;
  margin: 0 !important;
  color: var(--laos-ink, #161113) !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(42px, 4.4vw, 66px) !important;
  font-weight: 700 !important;
  line-height: .92 !important;
  letter-spacing: -.045em !important;
}

.quick-view-content p#quickViewDescription {
  max-width: 680px !important;
  margin: 0 !important;
  color: rgba(22, 17, 19, .66) !important;
  font-size: 16px !important;
  line-height: 1.75 !important;
}

.quick-view-main-info {
  display: grid !important;
  grid-template-columns: minmax(0, 1.1fr) minmax(180px, .9fr) !important;
  gap: 12px !important;
  margin: 24px 0 !important;
}

.quick-view-price,
.quick-view-status-card {
  min-height: 86px !important;
  display: grid !important;
  align-content: center !important;
  gap: 8px !important;
  padding: 18px !important;
  border: 1px solid rgba(111, 36, 55, .13) !important;
  border-radius: 18px !important;
  background: rgba(255, 248, 238, .54) !important;
}

.quick-view-price {
  border-top: 1px solid rgba(111, 36, 55, .13) !important;
  border-bottom: 1px solid rgba(111, 36, 55, .13) !important;
}

.quick-view-price span,
.quick-view-status-card > span,
.quick-view-option-heading span {
  color: rgba(22, 17, 19, .48) !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
}

.quick-view-price .quick-view-price-value,
.quick-view-price .modal-price-inline,
.quick-view-price .collection-price-consult {
  color: var(--laos-wine, #6f2437) !important;
  font-size: 25px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

.quick-view-price .modal-price-inline strong,
.quick-view-price .collection-price-consult strong {
  color: var(--laos-wine, #6f2437) !important;
  font-size: 25px !important;
}

.quick-view-availability {
  width: fit-content !important;
  margin: 0 !important;
  padding: 7px 11px !important;
  border: 1px solid rgba(111, 36, 55, .13) !important;
  border-radius: 999px !important;
  background: rgba(111, 36, 55, .07) !important;
  color: var(--laos-wine, #6f2437) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
}

.quick-view-options {
  display: grid !important;
  gap: 14px !important;
  margin: 0 0 18px !important;
}

.quick-view-option-block {
  display: grid !important;
  gap: 13px !important;
  padding: 18px !important;
  border: 1px solid rgba(111, 36, 55, .12) !important;
  border-radius: 20px !important;
  background: rgba(255, 248, 238, .42) !important;
}

.quick-view-option-block[hidden] {
  display: none !important;
}

.quick-view-option-heading {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
}

.quick-view-option-heading strong {
  color: var(--laos-ink, #161113) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
}

.quick-view-color-options,
.quick-view-size-options {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}

.quick-view-color-dot {
  width: 34px !important;
  height: 34px !important;
  flex: 0 0 34px !important;
  border: 1px solid rgba(22, 17, 19, .20) !important;
  border-radius: 50% !important;
  background: var(--dot-color, #d8b48c) !important;
  box-shadow: inset 0 0 0 4px #fff8ee !important;
  cursor: pointer !important;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease !important;
}

.quick-view-color-dot:hover,
.quick-view-color-dot.active {
  transform: translateY(-1px) !important;
  border-color: var(--laos-wine, #6f2437) !important;
  box-shadow: inset 0 0 0 4px #fff8ee, 0 0 0 3px rgba(111, 36, 55, .18) !important;
}

.quick-view-color-dot.is-pattern {
  background:
    linear-gradient(135deg, rgba(22, 17, 19, .82), rgba(111, 36, 55, .34)),
    repeating-linear-gradient(45deg, #d8b48c 0 6px, #5a3927 6px 12px) !important;
}

.quick-view-size-chip {
  min-width: 42px !important;
  height: 38px !important;
  padding: 0 14px !important;
  border: 1px solid rgba(111, 36, 55, .18) !important;
  border-radius: 999px !important;
  background: rgba(255, 248, 238, .68) !important;
  color: var(--laos-ink, #161113) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  cursor: pointer !important;
  transition: background .22s ease, color .22s ease, transform .22s ease, border-color .22s ease !important;
}

.quick-view-size-chip:hover,
.quick-view-size-chip.active {
  transform: translateY(-1px) !important;
  border-color: var(--laos-wine, #6f2437) !important;
  background: var(--laos-wine, #6f2437) !important;
  color: #fff8ee !important;
}

.quick-view-single-option {
  color: rgba(22, 17, 19, .52) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.quick-view-hidden-select {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.quick-view-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 12px !important;
  margin: 18px 0 24px !important;
}

.quick-view-actions .quick-view-add,
.quick-view-actions .quick-view-whatsapp {
  min-height: 54px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  text-decoration: none !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .13em !important;
  text-align: center !important;
  text-transform: uppercase !important;
}

.quick-view-actions .quick-view-add {
  border: 0 !important;
  background: linear-gradient(135deg, #161113, #6f2437) !important;
  color: #fff8ee !important;
  cursor: pointer !important;
}

.quick-view-actions .quick-view-whatsapp {
  border: 1px solid rgba(111, 36, 55, .24) !important;
  background: rgba(255, 248, 238, .58) !important;
  color: var(--laos-wine, #6f2437) !important;
}

.quick-view-add:disabled {
  opacity: .48 !important;
  cursor: not-allowed !important;
  background: #7d746b !important;
}

.quick-view-accordions,
.quick-view-details {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  margin-top: 0 !important;
}

.quick-view-accordion {
  border: 1px solid rgba(111, 36, 55, .13) !important;
  border-radius: 18px !important;
  background: rgba(255, 248, 238, .44) !important;
  overflow: hidden !important;
}

.quick-view-accordion summary {
  min-height: 56px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  padding: 0 18px !important;
  color: var(--laos-ink, #161113) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  list-style: none !important;
}

.quick-view-accordion summary::-webkit-details-marker {
  display: none !important;
}

.quick-view-accordion summary i {
  font-style: normal !important;
  color: var(--laos-wine, #6f2437) !important;
  font-size: 20px !important;
  transition: transform .22s ease !important;
}

.quick-view-accordion[open] summary i {
  transform: rotate(45deg) !important;
}

.quick-view-accordion-content {
  display: grid !important;
  gap: 10px !important;
  padding: 0 18px 18px !important;
  color: rgba(22, 17, 19, .68) !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

.quick-view-accordion-row {
  display: grid !important;
  grid-template-columns: minmax(120px, .75fr) minmax(0, 1.25fr) !important;
  gap: 12px !important;
  padding: 9px 0 !important;
  border-top: 1px solid rgba(111, 36, 55, .09) !important;
}

.quick-view-accordion-row span {
  color: rgba(22, 17, 19, .45) !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
}

.quick-view-accordion-row strong {
  color: var(--laos-ink, #161113) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.45 !important;
}

.quick-view-accordion-list {
  display: grid !important;
  gap: 8px !important;
  margin: 0 !important;
  padding-left: 18px !important;
}

@media (max-width: 980px) {
  .quick-view-panel {
    grid-template-columns: 1fr !important;
    height: auto !important;
    width: min(680px, 96vw) !important;
    max-height: 94vh !important;
    overflow-y: auto !important;
    border-radius: 24px !important;
  }

  .quick-view-media {
    height: min(58vh, 560px) !important;
    min-height: 340px !important;
  }

  .quick-view-content {
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    padding: 28px 22px 30px !important;
  }

  .quick-view-content h2 {
    font-size: clamp(34px, 10vw, 52px) !important;
    line-height: .96 !important;
  }

  .quick-view-main-info,
  .quick-view-actions {
    grid-template-columns: 1fr !important;
  }

  .quick-view-slider-dots {
    bottom: 12px !important;
  }
}

@media (max-width: 560px) {
  .quick-view.active {
    align-items: flex-end !important;
    padding: 8px !important;
  }

  .quick-view-panel {
    width: 100% !important;
    max-height: 94vh !important;
    border-radius: 24px 24px 0 0 !important;
  }

  .quick-view-close {
    top: 14px !important;
    right: 14px !important;
    width: 46px !important;
    height: 46px !important;
    font-size: 26px !important;
  }

  .quick-view-media {
    height: 48vh !important;
    min-height: 310px !important;
  }

  .quick-view-content {
    padding: 24px 18px 28px !important;
  }

  .quick-view-kicker {
    font-size: 10px !important;
    letter-spacing: .32em !important;
  }

  .quick-view-content h2 {
    font-size: clamp(32px, 12vw, 44px) !important;
  }

  .quick-view-accordion-row {
    grid-template-columns: 1fr !important;
    gap: 4px !important;
  }
}

/* =========================================================
   AJUSTE MODAL VER PRENDA: imagen completa y miniaturas limpias
   Solo afecta la vista rápida de producto.
   ========================================================= */
.quick-view-media {
  background:
    radial-gradient(circle at center, rgba(255, 248, 238, .55), transparent 58%),
    #eee5da !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.quick-view-media img#quickViewImg,
.quick-view-media > img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  background: transparent !important;
  transform: none !important;
}

.quick-view-slider-btn {
  display: none !important;
}

.quick-view-slider-dots,
.quick-view-thumbnails-centered {
  left: 50% !important;
  right: auto !important;
  bottom: 22px !important;
  width: auto !important;
  max-width: min(72%, 420px) !important;
  transform: translateX(-50%) !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 12px !important;
  border: 1px solid rgba(255, 248, 238, .38) !important;
  border-radius: 999px !important;
  background: rgba(22, 17, 19, .34) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  overflow-x: auto !important;
  scrollbar-width: none !important;
}

.quick-view-slider-dots::-webkit-scrollbar,
.quick-view-thumbnails-centered::-webkit-scrollbar {
  display: none !important;
}

.quick-view-slider-dot,
.quick-view-thumb,
.quick-view-slider-dot.quick-view-thumb {
  width: 56px !important;
  height: 72px !important;
  flex: 0 0 56px !important;
  border-radius: 14px !important;
  border: 2px solid rgba(255, 248, 238, .72) !important;
  background: rgba(255, 248, 238, .76) !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .16) !important;
}

.quick-view-slider-dot.active,
.quick-view-thumb.active,
.quick-view-slider-dot.quick-view-thumb.active {
  border-color: #d8b48c !important;
  box-shadow: 0 0 0 3px rgba(216, 180, 140, .36), 0 12px 28px rgba(0, 0, 0, .20) !important;
}

.quick-view-slider-dot img,
.quick-view-thumb img,
.quick-view-slider-dot.quick-view-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
}

@media (max-width: 980px) {
  .quick-view-media img#quickViewImg,
  .quick-view-media > img {
    object-fit: contain !important;
  }

  .quick-view-slider-dots,
  .quick-view-thumbnails-centered {
    max-width: min(86%, 420px) !important;
    bottom: 16px !important;
  }
}

@media (max-width: 560px) {
  .quick-view-slider-dots,
  .quick-view-thumbnails-centered {
    max-width: calc(100% - 42px) !important;
    padding: 8px 10px !important;
    gap: 8px !important;
  }

  .quick-view-slider-dot,
  .quick-view-thumb,
  .quick-view-slider-dot.quick-view-thumb {
    width: 48px !important;
    height: 62px !important;
    flex-basis: 48px !important;
  }
}

/* =========================================================
   AJUSTE FINAL MODAL VER PRENDA: imagen alineada, miniaturas limpias
   e información secundaria en desplegables.
   ========================================================= */
.quick-view-panel {
  grid-template-columns: minmax(0, .82fr) minmax(500px, 1.18fr) !important;
  width: min(1460px, 96vw) !important;
}

.quick-view-media {
  background: #ebe1d5 !important;
}

.quick-view-media img#quickViewImg,
.quick-view-media > img {
  object-fit: contain !important;
  object-position: right center !important;
  background: #ebe1d5 !important;
}

.quick-view-content {
  padding-top: clamp(36px, 3.4vw, 58px) !important;
}

.quick-view-summary {
  margin-bottom: 20px !important;
}

.quick-view-content h2,
.quick-view-title {
  font-size: clamp(40px, 4vw, 60px) !important;
  line-height: .96 !important;
  max-width: 720px !important;
}

.quick-view-content p#quickViewDescription {
  max-width: 720px !important;
  margin-bottom: 0 !important;
}

.quick-view-actions-visible,
.quick-view-actions {
  margin: 22px 0 22px !important;
}

.quick-view-purchase-accordion .quick-view-accordion-content {
  padding-top: 0 !important;
}

.quick-view-purchase-content {
  gap: 14px !important;
}

.quick-view-main-info {
  margin: 0 0 14px !important;
}

.quick-view-options {
  margin: 0 !important;
}

.quick-view-accordion-dynamic {
  display: grid !important;
  gap: 10px !important;
}

.quick-view-accordion-dynamic .quick-view-accordion:first-child {
  margin-top: 0 !important;
}

.quick-view-slider-dots,
.quick-view-thumbnails-centered {
  bottom: 24px !important;
  padding: 9px 10px !important;
  border: 0 !important;
  border-radius: 22px !important;
  background: rgba(22, 17, 19, .32) !important;
  box-shadow: none !important;
}

.quick-view-slider-dot,
.quick-view-thumb,
.quick-view-slider-dot.quick-view-thumb {
  border: 1px solid rgba(255, 248, 238, .84) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

.quick-view-slider-dot.active,
.quick-view-thumb.active,
.quick-view-slider-dot.quick-view-thumb.active {
  border-color: rgba(255, 248, 238, .96) !important;
  box-shadow: none !important;
  outline: none !important;
  transform: none !important;
}

.quick-view-slider-dot.active img,
.quick-view-thumb.active img,
.quick-view-slider-dot.quick-view-thumb.active img {
  filter: contrast(1.04) saturate(1.03) !important;
}

@media (max-width: 1120px) {
  .quick-view-panel {
    grid-template-columns: minmax(0, .9fr) minmax(440px, 1.1fr) !important;
  }
}

@media (max-width: 980px) {
  .quick-view-panel {
    grid-template-columns: 1fr !important;
    width: min(680px, 96vw) !important;
  }

  .quick-view-media img#quickViewImg,
  .quick-view-media > img {
    object-position: center center !important;
  }

  .quick-view-actions-visible,
  .quick-view-actions {
    margin: 18px 0 18px !important;
  }
}

@media (max-width: 560px) {
  .quick-view-content h2,
  .quick-view-title {
    font-size: clamp(32px, 10.8vw, 42px) !important;
    line-height: 1 !important;
  }

  .quick-view-slider-dots,
  .quick-view-thumbnails-centered {
    bottom: 12px !important;
    border-radius: 18px !important;
  }
}


/* =========================================================
   AJUSTE MODAL: encabezado limpio y acordeones antes de acciones
   ========================================================= */
.quick-view-summary,
.quick-view-summary * {
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
}

.quick-view-summary {
  border: 0 !important;
  outline: 0 !important;
  padding: 0 !important;
  margin-bottom: clamp(20px, 2vw, 28px) !important;
}

.quick-view-summary::before,
.quick-view-summary::after {
  content: none !important;
  display: none !important;
}

.quick-view-accordions {
  margin: clamp(22px, 2.4vw, 32px) 0 clamp(22px, 2.4vw, 32px) !important;
}

.quick-view-purchase-accordion {
  order: 0 !important;
}

.quick-view-accordion-dynamic {
  order: 1 !important;
}

.quick-view-purchase-content {
  padding-top: 0 !important;
}

.quick-view-main-info,
.quick-view-options {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.quick-view-actions {
  margin: 0 !important;
}

@media (max-width: 980px) {
  .quick-view-accordions {
    margin: 20px 0 22px !important;
  }
}


/* =====================================================
   LOOKBOOK LAOS SIMPLE - reemplazo ligero de Galería
   - Looks prearmados, prendas incluidas y WhatsApp.
   - No usa maniquí, PNG superpuestos ni lógica compleja.
===================================================== */

.lookbook-simple-section {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 12%, rgba(216,180,140,.20), transparent 28%),
    linear-gradient(135deg, #fff8ef 0%, #f4eadf 46%, #eadbcf 100%);
  color: #1d1714;
}

.lookbook-simple-section::before {
  content: "";
  position: absolute;
  inset: 28px;
  border: 1px solid rgba(120, 82, 52, .12);
  border-radius: 34px;
  pointer-events: none;
}

.lookbook-simple-shell {
  position: relative;
  z-index: 1;
  max-width: 1240px;
  margin: 0 auto;
}

.lookbook-simple-heading {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.lookbook-simple-heading span {
  color: #9d6e43;
  font-family: 'Manrope', sans-serif;
  letter-spacing: .22em;
}

.lookbook-simple-heading h2 {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(42px, 5vw, 72px);
  font-weight: 600;
  line-height: .96;
  color: #211815;
}

.lookbook-simple-heading .section-subtitle {
  max-width: 660px;
  margin: 18px auto 0;
  color: #6f5d52;
  font-size: 16px;
  line-height: 1.8;
}

.lookbook-simple-app {
  margin-top: 42px;
}

.lookbook-simple-loading {
  max-width: 520px;
  margin: 0 auto;
  padding: 34px;
  text-align: center;
  border-radius: 28px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(120,82,52,.12);
}

.lookbook-simple-layout {
  display: grid;
  grid-template-columns: minmax(240px, 320px) 1fr;
  gap: 28px;
  align-items: start;
}

.lookbook-simple-intro {
  position: sticky;
  top: 112px;
  padding: 34px;
  border-radius: 30px;
  background: rgba(255,255,255,.68);
  border: 1px solid rgba(120,82,52,.12);
  box-shadow: 0 24px 70px rgba(77, 48, 31, .10);
  backdrop-filter: blur(14px);
}

.lookbook-simple-kicker,
.lookbook-simple-occasion {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  color: #9d6e43;
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.lookbook-simple-intro h3 {
  margin: 14px 0 12px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 38px;
  line-height: 1;
  color: #241916;
}

.lookbook-simple-intro p {
  color: #65534a;
  line-height: 1.75;
  font-size: 15px;
}

.lookbook-simple-benefits {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 24px;
}

.lookbook-simple-benefits span {
  padding: 9px 12px;
  border-radius: 999px;
  background: #f4eadf;
  color: #4c3b33;
  font-size: 12px;
  font-weight: 700;
}

.lookbook-simple-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.lookbook-simple-card {
  overflow: hidden;
  border-radius: 34px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(120,82,52,.12);
  box-shadow: 0 24px 70px rgba(77, 48, 31, .10);
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}

.lookbook-simple-card:hover,
.lookbook-simple-card:focus-visible {
  transform: translateY(-8px);
  border-color: rgba(157,110,67,.30);
  box-shadow: 0 34px 90px rgba(77, 48, 31, .16);
  outline: none;
}

.lookbook-simple-image {
  position: relative;
  height: 440px;
  overflow: hidden;
  background: #efe3d6;
}

.lookbook-simple-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .55s ease, filter .55s ease;
}

.lookbook-simple-card:hover .lookbook-simple-image img,
.lookbook-simple-card:focus-visible .lookbook-simple-image img {
  transform: scale(1.045);
  filter: saturate(1.05) contrast(1.02);
}

.lookbook-simple-image figcaption {
  position: absolute;
  left: 18px;
  top: 18px;
  padding: 9px 13px;
  border-radius: 999px;
  background: rgba(255,255,255,.78);
  color: #30231d;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}

.lookbook-simple-copy {
  padding: 26px;
}

.lookbook-simple-copy h3 {
  margin: 10px 0 8px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 36px;
  line-height: 1;
  color: #211815;
}

.lookbook-simple-copy p {
  color: #66544b;
  font-size: 14px;
  line-height: 1.7;
}

.lookbook-simple-pieces {
  display: grid;
  gap: 10px;
  margin: 22px 0;
}

.lookbook-piece {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 12px;
  align-items: center;
  padding: 10px;
  border-radius: 18px;
  background: #fbf4ec;
  border: 1px solid rgba(120,82,52,.08);
}

.lookbook-piece img {
  width: 52px;
  height: 62px;
  border-radius: 14px;
  object-fit: cover;
  background: #efe3d6;
}

.lookbook-piece strong {
  display: block;
  color: #221815;
  font-size: 13px;
  line-height: 1.25;
}

.lookbook-piece span {
  display: block;
  margin-top: 3px;
  color: #9d6e43;
  font-size: 12px;
  font-weight: 700;
}

.lookbook-simple-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.lookbook-consult-btn {
  border-radius: 999px;
  background: #111 !important;
  color: #fff !important;
}

.lookbook-consult-btn:hover {
  background: #d8b48c !important;
  color: #111 !important;
}

.lookbook-see-products {
  border: none;
  background: transparent;
  color: #7b4e2d;
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 5px;
}

@media (max-width: 1024px) {
  .lookbook-simple-layout {
    grid-template-columns: 1fr;
  }

  .lookbook-simple-intro {
    position: relative;
    top: auto;
  }
}

@media (max-width: 760px) {
  .lookbook-simple-section {
    padding: 78px 16px !important;
  }

  .lookbook-simple-section::before {
    inset: 12px;
    border-radius: 24px;
  }

  .lookbook-simple-heading h2 {
    font-size: 44px;
  }

  .lookbook-simple-grid {
    grid-template-columns: 1fr;
  }

  .lookbook-simple-intro {
    padding: 24px;
    border-radius: 24px;
  }

  .lookbook-simple-image {
    height: 390px;
  }

  .lookbook-simple-copy {
    padding: 22px;
  }

  .lookbook-simple-actions .btn,
  .lookbook-see-products {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .lookbook-see-products {
    padding: 12px 0;
  }
}
/* =========================================================
   FIX FINAL MOBILE HERO - Laos Studio
   Mejora portada móvil sin tocar otras secciones
   ========================================================= */

@media (max-width: 768px) {
  .header {
    height: 74px !important;
    padding: 0 14px !important;
    background: rgba(15, 10, 12, .58) !important;
    border-bottom: 1px solid rgba(216, 180, 140, .16) !important;
    box-shadow: 0 12px 34px rgba(0, 0, 0, .18) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
  }

  .header.scrolled {
    background: rgba(15, 10, 12, .72) !important;
  }

  .header .brand-center {
    max-width: 210px !important;
    gap: 9px !important;
  }

  .header .brand-center .logo,
  .brand-center .logo {
    width: 44px !important;
    height: 44px !important;
    object-fit: contain !important;
  }

  .header .brand-center h1,
  .brand-center h1 {
    font-size: 23px !important;
    line-height: 1 !important;
    max-width: 138px !important;
    text-shadow: 0 0 16px rgba(255, 248, 238, .28) !important;
  }

  .menu-btn,
  .header-cart,
  .cart-btn {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
    border-radius: 50% !important;
    background: rgba(255, 248, 238, .08) !important;
    border: 1px solid rgba(255, 248, 238, .18) !important;
    box-shadow: none !important;
  }

  .cart-icon-wrap {
    width: 38px !important;
    height: 38px !important;
  }

  .hero {
    min-height: 100svh !important;
    height: auto !important;
    padding: 118px 22px 42px !important;
    align-items: center !important;
    justify-content: flex-start !important;
    text-align: left !important;
    overflow: hidden !important;
  }

  .hero-slide {
    background-size: cover !important;
    background-position: 72% center !important;
    filter: saturate(.92) contrast(1.04) brightness(.72) !important;
    transform: scale(1.01) !important;
  }

  .hero-slide.active {
    transform: scale(1.01) !important;
  }

  .hero-overlay {
    background:
      linear-gradient(90deg,
        rgba(15, 10, 12, .94) 0%,
        rgba(30, 16, 20, .82) 43%,
        rgba(30, 16, 20, .54) 72%,
        rgba(15, 10, 12, .34) 100%
      ),
      linear-gradient(180deg,
        rgba(15, 10, 12, .62) 0%,
        rgba(15, 10, 12, .18) 36%,
        rgba(15, 10, 12, .78) 100%
      ) !important;
  }

  .hero-content,
  .hero-premium-content {
    width: min(100%, 430px) !important;
    max-width: 430px !important;
    margin: 0 !important;
    padding: 0 !important;
    text-align: left !important;
  }

  .hero-content .tag,
  .hero-premium-content .tag {
    display: block !important;
    max-width: 100% !important;
    margin: 0 0 18px !important;
    color: #f0c892 !important;
    font-size: 10.5px !important;
    line-height: 1.55 !important;
    letter-spacing: .31em !important;
    font-weight: 800 !important;
    text-align: left !important;
  }

  .hero-content h2,
  .hero-premium-content h2,
  .hero h2 {
    max-width: 390px !important;
    margin: 0 0 18px !important;
    font-size: clamp(41px, 12.4vw, 54px) !important;
    line-height: .95 !important;
    letter-spacing: -.025em !important;
    text-align: left !important;
    text-wrap: balance !important;
    text-shadow: 0 18px 46px rgba(0, 0, 0, .46) !important;
  }

  .hero-content p,
  .hero-premium-content p,
  .hero p {
    max-width: 385px !important;
    margin: 0 !important;
    color: rgba(255, 248, 238, .88) !important;
    font-size: 15.5px !important;
    line-height: 1.62 !important;
    text-align: left !important;
    text-shadow: 0 12px 34px rgba(0, 0, 0, .34) !important;
  }

  .hero-line {
    width: 72px !important;
    height: 1px !important;
    margin: 24px 0 26px !important;
    background: rgba(216, 180, 140, .78) !important;
  }

  .hero-buttons {
    width: auto !important;
    margin-top: 0 !important;
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center !important;
  }

  .hero-buttons .btn,
  .hero .btn {
    width: auto !important;
    min-width: 205px !important;
    max-width: 260px !important;
    min-height: 52px !important;
    padding: 14px 30px !important;
    border-radius: 999px !important;
    font-size: 14.5px !important;
    font-weight: 800 !important;
    text-align: center !important;
    letter-spacing: 0 !important;
    box-shadow: 0 16px 40px rgba(0, 0, 0, .24) !important;
  }
}

@media (max-width: 430px) {
  .hero {
    padding: 112px 20px 36px !important;
  }

  .hero-slide {
    background-position: 74% center !important;
  }

  .hero-content,
  .hero-premium-content {
    max-width: 360px !important;
  }

  .hero-content .tag,
  .hero-premium-content .tag {
    font-size: 10px !important;
    letter-spacing: .27em !important;
    margin-bottom: 16px !important;
  }

  .hero-content h2,
  .hero-premium-content h2,
  .hero h2 {
    max-width: 350px !important;
    font-size: clamp(38px, 12.1vw, 48px) !important;
    line-height: .96 !important;
    margin-bottom: 18px !important;
  }

  .hero-content p,
  .hero-premium-content p,
  .hero p {
    max-width: 342px !important;
    font-size: 14.8px !important;
    line-height: 1.58 !important;
  }

  .hero-line {
    margin: 22px 0 24px !important;
  }

  .hero-buttons .btn,
  .hero .btn {
    min-width: 198px !important;
    min-height: 50px !important;
    padding: 13px 28px !important;
  }
}

@media (max-width: 360px) {
  .header .brand-center h1,
  .brand-center h1 {
    font-size: 20px !important;
  }

  .header .brand-center .logo,
  .brand-center .logo {
    width: 40px !important;
    height: 40px !important;
  }

  .hero {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .hero-content h2,
  .hero-premium-content h2,
  .hero h2 {
    font-size: 36px !important;
  }

  .hero-content p,
  .hero-premium-content p,
  .hero p {
    font-size: 14px !important;
  }
}


/* =========================================================
   HERO COPY + BOTÓN CONTACTO - Laos Studio
   Ajuste específico para portada sin tocar otras secciones
   ========================================================= */
.hero-buttons {
  gap: 14px;
  align-items: center;
}

.hero-buttons .hero-contact-btn {
  background: rgba(255, 248, 238, .08);
  color: #fff;
  border: 1px solid rgba(216, 180, 140, .55);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03);
}

.hero-buttons .hero-contact-btn:hover {
  background: rgba(216, 180, 140, .92);
  color: #111;
  border-color: rgba(216, 180, 140, .92);
}

@media (max-width: 768px) {
  .hero-buttons {
    gap: 10px !important;
    flex-wrap: wrap !important;
  }

  .hero-buttons .btn,
  .hero .btn {
    min-width: 170px !important;
    max-width: 210px !important;
    min-height: 50px !important;
    padding: 13px 22px !important;
    font-size: 14px !important;
  }

  .hero-buttons .hero-contact-btn {
    background: rgba(255, 248, 238, .07) !important;
    color: #fff !important;
    border: 1px solid rgba(216, 180, 140, .48) !important;
  }
}

@media (max-width: 430px) {
  .hero-content h2,
  .hero-premium-content h2,
  .hero h2 {
    max-width: 330px !important;
    font-size: clamp(37px, 11.6vw, 46px) !important;
    line-height: .98 !important;
  }

  .hero-content p,
  .hero-premium-content p,
  .hero p {
    max-width: 340px !important;
  }

  .hero-buttons .btn,
  .hero .btn {
    min-width: 158px !important;
    max-width: 206px !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
  }
}

@media (max-width: 380px) {
  .hero-buttons {
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .hero-buttons .btn,
  .hero .btn {
    width: min(100%, 220px) !important;
    max-width: 220px !important;
  }
}

/* =========================================================
   HEADER HERO REFINADO - botones elegantes + móvil centrado
   Solo afecta la portada/header principal
   ========================================================= */
.hero-line {
  display: none !important;
}

.hero-content,
.hero-premium-content {
  text-align: left !important;
}

.hero-buttons {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
  margin-top: 30px !important;
}

.hero-buttons .btn,
.hero .btn {
  min-width: 176px !important;
  min-height: 52px !important;
  padding: 14px 30px !important;
  border-radius: 999px !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  letter-spacing: .02em !important;
  line-height: 1 !important;
  text-align: center !important;
  text-decoration: none !important;
  transition: transform .28s ease, background .28s ease, border-color .28s ease, color .28s ease, box-shadow .28s ease !important;
}

.hero-buttons .btn:first-child {
  background: linear-gradient(135deg, #e4c39e, #c99f73) !important;
  color: #16100f !important;
  border: 1px solid rgba(255, 248, 238, .28) !important;
  box-shadow: 0 18px 46px rgba(0, 0, 0, .30), 0 10px 28px rgba(216, 180, 140, .18) !important;
}

.hero-buttons .hero-contact-btn,
.hero-buttons .btn-outline {
  background: rgba(255, 248, 238, .055) !important;
  color: #fff8ee !important;
  border: 1px solid rgba(228, 195, 158, .58) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.035), 0 16px 38px rgba(0, 0, 0, .20) !important;
  backdrop-filter: blur(8px) !important;
}

.hero-buttons .btn:hover,
.hero-buttons .btn:focus-visible {
  transform: translateY(-3px) !important;
}

.hero-buttons .btn:first-child:hover,
.hero-buttons .btn:first-child:focus-visible {
  background: linear-gradient(135deg, #efcfaa, #d9b083) !important;
  box-shadow: 0 22px 52px rgba(0, 0, 0, .32), 0 12px 30px rgba(216, 180, 140, .24) !important;
}

.hero-buttons .hero-contact-btn:hover,
.hero-buttons .hero-contact-btn:focus-visible,
.hero-buttons .btn-outline:hover,
.hero-buttons .btn-outline:focus-visible {
  background: rgba(255, 248, 238, .14) !important;
  color: #fff !important;
  border-color: rgba(239, 207, 170, .88) !important;
}

@media (max-width: 768px) {
  .hero {
    text-align: center !important;
    justify-content: center !important;
  }

  .hero-content,
  .hero-premium-content {
    width: min(100%, 410px) !important;
    max-width: 410px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
  }

  .hero-content .tag,
  .hero-premium-content .tag {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .hero-content h2,
  .hero-premium-content h2,
  .hero h2 {
    max-width: 390px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
  }

  .hero-content p,
  .hero-premium-content p,
  .hero p {
    max-width: 370px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
  }

  .hero-buttons {
    justify-content: center !important;
    gap: 10px !important;
    margin-top: 28px !important;
  }

  .hero-buttons .btn,
  .hero .btn {
    min-width: 158px !important;
    max-width: 190px !important;
    min-height: 48px !important;
    padding: 13px 18px !important;
    font-size: 13.5px !important;
  }
}

@media (max-width: 390px) {
  .hero-buttons {
    flex-direction: column !important;
    align-items: center !important;
    gap: 11px !important;
  }

  .hero-buttons .btn,
  .hero .btn {
    width: min(100%, 235px) !important;
    max-width: 235px !important;
  }
}

/* =========================================================
   AJUSTE FINAL HEADER: sin línea, botones iguales y móvil centrado
   Solo afecta el hero principal
   ========================================================= */
.hero-line {
  display: none !important;
}

.hero-content,
.hero-premium-content {
  text-align: left !important;
}

.hero-buttons {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
}

.hero-buttons .btn,
.hero-buttons .btn-outline,
.hero-buttons .hero-contact-btn,
.hero .btn {
  min-width: 176px !important;
  min-height: 52px !important;
  padding: 14px 30px !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #e4c39e, #c99f73) !important;
  color: #16100f !important;
  border: 1px solid rgba(255, 248, 238, .28) !important;
  box-shadow: 0 18px 46px rgba(0, 0, 0, .30), 0 10px 28px rgba(216, 180, 140, .18) !important;
  backdrop-filter: none !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  letter-spacing: .02em !important;
  line-height: 1 !important;
  text-align: center !important;
  text-decoration: none !important;
}

.hero-buttons .btn:hover,
.hero-buttons .btn:focus-visible,
.hero-buttons .btn-outline:hover,
.hero-buttons .btn-outline:focus-visible,
.hero-buttons .hero-contact-btn:hover,
.hero-buttons .hero-contact-btn:focus-visible {
  background: linear-gradient(135deg, #efcfaa, #d9b083) !important;
  color: #16100f !important;
  border-color: rgba(255, 248, 238, .36) !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 22px 52px rgba(0, 0, 0, .32), 0 12px 30px rgba(216, 180, 140, .24) !important;
}

@media (max-width: 768px) {
  .hero {
    text-align: center !important;
    justify-content: center !important;
  }

  .hero-content,
  .hero-premium-content {
    width: min(100%, 410px) !important;
    max-width: 410px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
  }

  .hero-content .tag,
  .hero-premium-content .tag,
  .hero-content h2,
  .hero-premium-content h2,
  .hero h2,
  .hero-content p,
  .hero-premium-content p,
  .hero p {
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
  }

  .hero-buttons {
    justify-content: center !important;
    gap: 10px !important;
  }

  .hero-buttons .btn,
  .hero-buttons .btn-outline,
  .hero-buttons .hero-contact-btn,
  .hero .btn {
    min-width: 158px !important;
    max-width: 190px !important;
    min-height: 48px !important;
    padding: 13px 18px !important;
    font-size: 13.5px !important;
  }
}

@media (max-width: 390px) {
  .hero-buttons {
    flex-direction: column !important;
    align-items: center !important;
    gap: 11px !important;
  }

  .hero-buttons .btn,
  .hero-buttons .btn-outline,
  .hero-buttons .hero-contact-btn,
  .hero .btn {
    width: min(100%, 235px) !important;
    max-width: 235px !important;
  }
}

/* =========================================================
   AJUSTE FINAL SOLICITADO: botones con degradado y texto centrado
   Solo afecta los botones del hero/header principal
   ========================================================= */
.hero-line {
  display: none !important;
}

.hero-buttons .btn,
.hero-buttons .btn-outline,
.hero-buttons .hero-contact-btn,
.hero .btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;
  min-width: 176px !important;
  min-height: 52px !important;
  padding: 0 30px !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #211018 0%, #321821 42%, #6f3a3f 72%, #d8b48c 100%) !important;
  color: #fff8ee !important;
  border: 1px solid rgba(216, 180, 140, .55) !important;
  box-shadow: 0 18px 42px rgba(0, 0, 0, .30), inset 0 1px 0 rgba(255,255,255,.10) !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  letter-spacing: .02em !important;
  line-height: 1 !important;
  text-align: center !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  vertical-align: middle !important;
  transition: transform .28s ease, box-shadow .28s ease, filter .28s ease !important;
}

.hero-buttons .btn:hover,
.hero-buttons .btn:focus-visible,
.hero-buttons .btn-outline:hover,
.hero-buttons .btn-outline:focus-visible,
.hero-buttons .hero-contact-btn:hover,
.hero-buttons .hero-contact-btn:focus-visible {
  background: linear-gradient(135deg, #2b141e 0%, #44202a 42%, #835050 72%, #e4c39e 100%) !important;
  color: #fff8ee !important;
  border-color: rgba(228, 195, 158, .78) !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 22px 50px rgba(0, 0, 0, .34), 0 10px 24px rgba(216, 180, 140, .18), inset 0 1px 0 rgba(255,255,255,.14) !important;
}

@media (max-width: 768px) {
  .hero-buttons {
    justify-content: center !important;
  }

  .hero-buttons .btn,
  .hero-buttons .btn-outline,
  .hero-buttons .hero-contact-btn,
  .hero .btn {
    min-width: 158px !important;
    max-width: 190px !important;
    min-height: 48px !important;
    padding: 0 18px !important;
    font-size: 13.5px !important;
  }
}

@media (max-width: 390px) {
  .hero-buttons .btn,
  .hero-buttons .btn-outline,
  .hero-buttons .hero-contact-btn,
  .hero .btn {
    width: min(100%, 235px) !important;
    max-width: 235px !important;
  }
}

/* =============================== */
/* HEADER BRAND: LAOS STUDIO + SUBTÍTULO */
/* Ajuste puntual solicitado: nombre en mayúsculas y subtítulo visible debajo */
/* =============================== */

.header .brand-center {
  align-items: center !important;
  gap: 10px !important;
}

.header .logo-text {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: center !important;
  gap: 2px !important;
  line-height: 1 !important;
}

.header .brand-center h1,
.header .logo-text h1 {
  text-transform: uppercase !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(23px, 2vw, 31px) !important;
  font-weight: 700 !important;
  line-height: .88 !important;
  letter-spacing: .035em !important;
  color: #fffaf2 !important;
  margin: 0 !important;
  white-space: nowrap !important;
  text-shadow: 0 0 18px rgba(214, 173, 120, .28) !important;
}

.header .logo-text p {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  margin: 4px 0 0 !important;
  padding: 0 !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: clamp(7px, .58vw, 9px) !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: .34em !important;
  text-transform: uppercase !important;
  color: rgba(216, 180, 140, .92) !important;
  white-space: nowrap !important;
  text-shadow: 0 0 12px rgba(216, 180, 140, .20) !important;
}

@media (max-width: 768px) {
  .header .brand-center {
    gap: 8px !important;
    max-width: 210px !important;
  }

  .header .brand-center .logo,
  .header .logo {
    width: 46px !important;
    height: 46px !important;
  }

  .header .brand-center h1,
  .header .logo-text h1 {
    font-size: 21px !important;
    letter-spacing: .025em !important;
  }

  .header .logo-text p {
    font-size: 6.8px !important;
    letter-spacing: .25em !important;
    margin-top: 3px !important;
  }
}

@media (max-width: 420px) {
  .header .brand-center {
    gap: 7px !important;
    max-width: 190px !important;
  }

  .header .brand-center .logo,
  .header .logo {
    width: 42px !important;
    height: 42px !important;
  }

  .header .brand-center h1,
  .header .logo-text h1 {
    font-size: 19px !important;
  }

  .header .logo-text p {
    font-size: 6.4px !important;
    letter-spacing: .22em !important;
  }
}


/* =============================== */
/* HEADER BRAND: SOLO STUDIO + SUBTÍTULO CENTRADO */
/* Ajuste puntual solicitado: mostrar STUDIO y centrar TIENDA VIRTUAL debajo */
/* =============================== */

.header .logo-text {
  align-items: center !important;
  text-align: center !important;
}

.header .brand-center h1,
.header .logo-text h1 {
  font-size: clamp(24px, 2.15vw, 34px) !important;
  letter-spacing: .075em !important;
  line-height: .9 !important;
}

.header .logo-text p {
  width: 100% !important;
  text-align: center !important;
  font-size: clamp(6.5px, .52vw, 8px) !important;
  letter-spacing: .28em !important;
  margin: 5px 0 0 !important;
  padding-left: .28em !important;
}

@media (max-width: 768px) {
  .header .brand-center h1,
  .header .logo-text h1 {
    font-size: 23px !important;
    letter-spacing: .06em !important;
  }

  .header .logo-text p {
    font-size: 6.3px !important;
    letter-spacing: .22em !important;
    padding-left: .22em !important;
  }
}

@media (max-width: 420px) {
  .header .brand-center h1,
  .header .logo-text h1 {
    font-size: 21px !important;
  }

  .header .logo-text p {
    font-size: 6px !important;
  }
}

/* =============================== */
/* COLECCIÓN: TIPO DEBAJO DE ORDENAR */
/* Ajuste puntual solicitado: mover el desplegable Tipo bajo Ordenar en desktop */
/* =============================== */

@media (min-width: 901px) {
  #coleccion .collection-toolbar {
    grid-template-columns: minmax(280px, 1.2fr) minmax(180px, .42fr) !important;
    align-items: end !important;
  }

  #coleccion .collection-categories {
    grid-column: 1 / 2 !important;
    grid-row: 2 !important;
    align-self: end !important;
    padding-bottom: 0 !important;
  }

  #coleccion .collection-select-mobile {
    grid-column: 2 / 3 !important;
    grid-row: 2 !important;
    align-self: end !important;
    width: 100% !important;
  }
}

@media (max-width: 900px) {
  #coleccion .collection-categories,
  #coleccion .collection-select-mobile {
    grid-column: 1 / -1 !important;
    grid-row: auto !important;
  }
}

/* =========================================================
   COLECCIÓN MÓVIL MINIMALISTA CON ICONOS
   Mantiene todas las funciones y reduce saturación visual.
   ========================================================= */
#coleccion .collection-mobile-actions {
  display: none;
}

#coleccion .collection-mobile-action .action-icon {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(111, 36, 55, .10), rgba(216, 180, 140, .22));
  color: var(--laos-wine, #6f2437);
  font-size: 15px;
  line-height: 1;
}

#coleccion .collection-mobile-action .action-label {
  font-family: 'Manrope', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(22, 17, 19, .72);
}

@media (max-width: 900px) {
  #coleccion .collection-toolbar {
    display: block !important;
    padding: 18px !important;
    border-radius: 24px !important;
  }

  #coleccion .collection-mobile-actions {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
  }

  #coleccion .collection-mobile-action {
    appearance: none;
    -webkit-appearance: none;
    min-height: 64px;
    border: 1px solid rgba(111, 36, 55, .12);
    border-radius: 18px;
    background: rgba(255, 252, 247, .88);
    box-shadow: 0 10px 24px rgba(22, 17, 19, .04);
    display: grid;
    justify-items: center;
    align-content: center;
    gap: 6px;
    padding: 8px 6px;
    cursor: pointer;
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease, background .2s ease;
  }

  #coleccion .collection-mobile-action.is-active {
    border-color: rgba(111, 36, 55, .34);
    background: linear-gradient(135deg, rgba(111, 36, 55, .06), rgba(216, 180, 140, .18));
    box-shadow: 0 14px 30px rgba(111, 36, 55, .08);
    transform: translateY(-1px);
  }

  #coleccion .collection-mobile-action.is-active .action-icon {
    background: linear-gradient(135deg, #42101d, #6f2437 70%, #b48a5a);
    color: #fff8ee;
  }

  #coleccion .collection-mobile-panel {
    display: none !important;
    width: 100% !important;
    margin: 0 !important;
  }

  #coleccion .collection-mobile-panel.is-open.collection-search-field,
  #coleccion .collection-mobile-panel.is-open.collection-sort-wrap,
  #coleccion .collection-mobile-panel.is-open.collection-select-mobile {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
  }

  #coleccion .collection-mobile-panel.is-open.collection-categories {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    padding: 0 !important;
    margin-top: 0 !important;
  }

  #coleccion .collection-search-field span,
  #coleccion .collection-select-wrap span {
    font-size: 11px !important;
    letter-spacing: .22em !important;
    margin-bottom: 0 !important;
  }

  #coleccion .collection-search-field input,
  #coleccion .collection-select-wrap select {
    min-height: 54px !important;
    border-radius: 18px !important;
    font-size: 15px !important;
    padding: 0 18px !important;
    box-shadow: none !important;
  }

  #coleccion .collection-filter {
    min-height: 44px !important;
    padding: 0 16px !important;
    border-radius: 999px !important;
    font-size: 11px !important;
    letter-spacing: .06em !important;
    box-shadow: none !important;
  }

  #coleccion .collection-results-meta {
    margin-top: 16px !important;
    font-size: 14px !important;
  }
}

@media (max-width: 520px) {
  #coleccion .collection-toolbar {
    padding: 16px !important;
    border-radius: 22px !important;
  }

  #coleccion .collection-mobile-actions {
    gap: 8px;
  }

  #coleccion .collection-mobile-action {
    min-height: 60px;
    border-radius: 16px;
  }

  #coleccion .collection-mobile-action .action-label {
    font-size: 9px;
    letter-spacing: .10em;
  }

  #coleccion .collection-mobile-action .action-icon {
    width: 28px;
    height: 28px;
    font-size: 14px;
  }
}


/* =====================================
   ASESORÍA POR INSTAGRAM - REEMPLAZO VIDEO
   ===================================== */
.instagram-advice-section {
  padding: clamp(78px, 8vw, 130px) 60px !important;
  background:
    radial-gradient(circle at 85% 20%, rgba(214, 173, 120, .18), transparent 34%),
    linear-gradient(135deg, #fff8ee 0%, #f7ecdf 48%, #efe0d3 100%) !important;
  color: var(--laos-ink, #161113) !important;
}

.instagram-advice-shell {
  width: min(1180px, 100%) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr) !important;
  gap: clamp(34px, 5vw, 72px) !important;
  align-items: center !important;
}

.instagram-advice-label {
  display: inline-block !important;
  margin-bottom: 18px !important;
  color: var(--laos-wine, #6f2437) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .34em !important;
  text-transform: uppercase !important;
}

.instagram-advice-copy h2 {
  max-width: 620px !important;
  margin: 0 0 22px !important;
  color: var(--laos-ink, #161113) !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(48px, 6vw, 88px) !important;
  line-height: .92 !important;
  letter-spacing: -.045em !important;
}

.instagram-advice-copy p {
  max-width: 620px !important;
  margin: 0 !important;
  color: rgba(22, 17, 19, .72) !important;
  font-size: 18px !important;
  line-height: 1.8 !important;
}

.instagram-advice-actions {
  display: flex !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
  margin-top: 34px !important;
}

.instagram-advice-btn {
  min-width: 210px !important;
  min-height: 56px !important;
  padding: 0 28px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
  border: 1px solid rgba(111, 36, 55, .24) !important;
  background: linear-gradient(135deg, #241318 0%, #6f2437 48%, #d6ad78 100%) !important;
  color: #fff8ee !important;
  text-decoration: none !important;
  font-weight: 900 !important;
  letter-spacing: -.01em !important;
  box-shadow: 0 18px 45px rgba(111, 36, 55, .18) !important;
  transition: transform .28s ease, box-shadow .28s ease, filter .28s ease !important;
}

.instagram-advice-btn:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 24px 58px rgba(111, 36, 55, .24) !important;
  filter: brightness(1.04) !important;
}

.instagram-advice-points {
  display: grid !important;
  gap: 14px !important;
}

.instagram-advice-points article {
  padding: 24px 24px 22px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(111, 36, 55, .14) !important;
  background: rgba(255, 251, 246, .72) !important;
  box-shadow: 0 22px 60px rgba(83, 33, 45, .08) !important;
  backdrop-filter: blur(12px) !important;
}

.instagram-advice-points span {
  display: inline-flex !important;
  margin-bottom: 12px !important;
  color: var(--laos-gold, #d6ad78) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .24em !important;
}

.instagram-advice-points h3 {
  margin: 0 0 8px !important;
  color: var(--laos-wine, #6f2437) !important;
  font-size: 17px !important;
  font-weight: 900 !important;
}

.instagram-advice-points p {
  margin: 0 !important;
  color: rgba(22, 17, 19, .66) !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
}

@media (max-width: 900px) {
  .instagram-advice-section {
    padding: 72px 20px !important;
  }

  .instagram-advice-shell {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }
}

@media (max-width: 768px) {
  .instagram-advice-section {
    padding: 64px 18px !important;
  }

  .instagram-advice-copy {
    text-align: center !important;
  }

  .instagram-advice-label {
    font-size: 10px !important;
    letter-spacing: .28em !important;
    margin-bottom: 14px !important;
  }

  .instagram-advice-copy h2 {
    max-width: 360px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    font-size: clamp(42px, 13vw, 58px) !important;
    line-height: .95 !important;
  }

  .instagram-advice-copy p {
    max-width: 360px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    font-size: 15px !important;
    line-height: 1.7 !important;
  }

  .instagram-advice-actions {
    justify-content: center !important;
    gap: 10px !important;
    margin-top: 26px !important;
  }

  .instagram-advice-btn {
    width: 100% !important;
    min-height: 52px !important;
    font-size: 14px !important;
  }

  .instagram-advice-points article {
    padding: 20px 18px !important;
    border-radius: 14px !important;
  }
}


/* =============================== */
/* VIDEO CTA INSTAGRAM - LAOS */
/* =============================== */

.instagram-video-cta {
  min-height: clamp(430px, 46vw, 620px) !important;
  padding: 0 24px !important;
  isolation: isolate !important;
}

.instagram-video-cta .premium-overlay {
  background:
    linear-gradient(90deg, rgba(18, 10, 12, .82) 0%, rgba(68, 24, 35, .56) 48%, rgba(18, 10, 12, .34) 100%),
    rgba(0, 0, 0, .18) !important;
}

.instagram-video-content {
  max-width: 860px !important;
  text-align: center !important;
}

.instagram-video-content .premium-label {
  color: #e8c89f !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  letter-spacing: 5px !important;
}

.instagram-video-content h2 {
  max-width: 820px !important;
  margin: 14px auto 18px !important;
  color: #fff8ee !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(48px, 6vw, 88px) !important;
  line-height: .92 !important;
  letter-spacing: -.04em !important;
}

.instagram-video-content > p:not(.premium-label) {
  max-width: 760px !important;
  margin: 0 auto !important;
  color: rgba(255, 248, 238, .9) !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: clamp(16px, 1.65vw, 21px) !important;
  line-height: 1.65 !important;
}

.premium-video-actions {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 16px !important;
  flex-wrap: wrap !important;
  margin-top: 34px !important;
}

.premium-video-btn {
  min-width: 210px !important;
  min-height: 58px !important;
  padding: 0 34px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-decoration: none !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  letter-spacing: .02em !important;
  color: #130c0e !important;
  border: 1px solid rgba(232, 200, 159, .58) !important;
  background: linear-gradient(135deg, #f4d4a8 0%, #d4a86f 46%, #f0c98f 100%) !important;
  box-shadow: 0 18px 44px rgba(0, 0, 0, .24), inset 0 1px 0 rgba(255, 255, 255, .32) !important;
  transition: transform .28s ease, box-shadow .28s ease, filter .28s ease !important;
}

.premium-video-btn:hover {
  transform: translateY(-3px) !important;
  filter: brightness(1.04) !important;
  box-shadow: 0 24px 58px rgba(0, 0, 0, .32), inset 0 1px 0 rgba(255, 255, 255, .4) !important;
}

.premium-video-btn-secondary {
  color: #fff8ee !important;
  background: rgba(255, 248, 238, .08) !important;
  border-color: rgba(255, 248, 238, .35) !important;
  backdrop-filter: blur(10px) !important;
}

@media (max-width: 768px) {
  .instagram-video-cta {
    min-height: 520px !important;
    padding: 88px 18px 72px !important;
  }

  .instagram-video-cta .premium-overlay {
    background:
      linear-gradient(180deg, rgba(18, 10, 12, .78) 0%, rgba(68, 24, 35, .62) 48%, rgba(18, 10, 12, .78) 100%),
      rgba(0, 0, 0, .18) !important;
  }

  .instagram-video-content {
    max-width: 100% !important;
  }

  .instagram-video-content .premium-label {
    font-size: 11px !important;
    letter-spacing: 3.8px !important;
  }

  .instagram-video-content h2 {
    font-size: clamp(42px, 14vw, 58px) !important;
    line-height: .96 !important;
    margin-bottom: 16px !important;
  }

  .instagram-video-content > p:not(.premium-label) {
    font-size: 15px !important;
    line-height: 1.7 !important;
  }

  .premium-video-actions {
    width: 100% !important;
    gap: 12px !important;
    margin-top: 28px !important;
  }

  .premium-video-btn {
    width: min(100%, 310px) !important;
    min-height: 54px !important;
  }
}

/* ========================================================= */
/* AJUSTE VIDEO ASESORÍA - RELLENAR TODO EL ESPACIO          */
/* ========================================================= */
.instagram-video-cta {
  width: 100% !important;
  max-width: none !important;
  background: #120c0d !important;
}

.instagram-video-cta .premium-bg-video {
  width: 100% !important;
  height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  object-fit: cover !important;
  object-position: center top !important;
  transform: scale(1.18) !important;
  transform-origin: center top !important;
  opacity: .78 !important;
}

.instagram-video-cta .premium-overlay {
  background:
    linear-gradient(90deg, rgba(18, 10, 12, .78) 0%, rgba(68, 24, 35, .46) 48%, rgba(18, 10, 12, .42) 100%),
    rgba(0, 0, 0, .12) !important;
}

@media (max-width: 768px) {
  .instagram-video-cta .premium-bg-video {
    transform: scale(1.35) !important;
    object-position: center top !important;
    transform-origin: center top !important;
    opacity: .74 !important;
  }

  .instagram-video-cta .premium-overlay {
    background:
      linear-gradient(180deg, rgba(18, 10, 12, .72) 0%, rgba(68, 24, 35, .54) 48%, rgba(18, 10, 12, .76) 100%),
      rgba(0, 0, 0, .12) !important;
  }
}

/* ========================================================= */
/* TEXTO VIDEO ASESORÍA - MÁS ELEGANTE / PREMIUM            */
/* ========================================================= */
.instagram-video-content {
  width: min(92%, 780px) !important;
  max-width: 780px !important;
  padding: clamp(26px, 3.2vw, 46px) clamp(24px, 4vw, 58px) !important;
  border: 1px solid rgba(255, 248, 238, .18) !important;
  border-radius: 28px !important;
  background:
    linear-gradient(135deg, rgba(22, 12, 15, .38), rgba(74, 33, 42, .18)) !important;
  box-shadow:
    0 28px 80px rgba(0, 0, 0, .28),
    inset 0 1px 0 rgba(255, 255, 255, .10) !important;
  backdrop-filter: blur(10px) saturate(1.08) !important;
  -webkit-backdrop-filter: blur(10px) saturate(1.08) !important;
}

.instagram-video-content h2 {
  max-width: 720px !important;
  margin: 0 auto 16px !important;
  color: #fff8ef !important;
  font-size: clamp(46px, 5.4vw, 78px) !important;
  line-height: .98 !important;
  letter-spacing: -.035em !important;
  font-weight: 600 !important;
  text-shadow: 0 10px 34px rgba(0, 0, 0, .46) !important;
  text-wrap: balance !important;
}

.instagram-video-content > p:not(.premium-label) {
  max-width: 650px !important;
  margin: 0 auto !important;
  color: rgba(255, 248, 238, .86) !important;
  font-size: clamp(15px, 1.35vw, 18px) !important;
  line-height: 1.85 !important;
  font-weight: 400 !important;
  letter-spacing: .005em !important;
  text-shadow: 0 8px 26px rgba(0, 0, 0, .36) !important;
}

.instagram-video-cta .premium-overlay {
  background:
    radial-gradient(circle at center, rgba(255, 248, 238, .08), transparent 34%),
    linear-gradient(90deg, rgba(18, 10, 12, .80) 0%, rgba(68, 24, 35, .48) 48%, rgba(18, 10, 12, .46) 100%),
    rgba(0, 0, 0, .10) !important;
}

@media (max-width: 768px) {
  .instagram-video-content {
    width: calc(100% - 34px) !important;
    padding: 28px 22px !important;
    border-radius: 24px !important;
    background:
      linear-gradient(145deg, rgba(22, 12, 15, .44), rgba(74, 33, 42, .22)) !important;
  }

  .instagram-video-content h2 {
    font-size: clamp(38px, 11vw, 52px) !important;
    line-height: 1.02 !important;
    margin-bottom: 14px !important;
  }

  .instagram-video-content > p:not(.premium-label) {
    max-width: 330px !important;
    font-size: 14.5px !important;
    line-height: 1.72 !important;
  }

  .instagram-video-cta .premium-overlay {
    background:
      radial-gradient(circle at center, rgba(255, 248, 238, .10), transparent 38%),
      linear-gradient(180deg, rgba(18, 10, 12, .76) 0%, rgba(68, 24, 35, .56) 48%, rgba(18, 10, 12, .78) 100%),
      rgba(0, 0, 0, .10) !important;
  }
}


/* =====================================================
   CÓMO LLEVAR LAOS - DECK DE CARTAS ELEGANTE
   Swipe tipo match, pero con estética boutique premium.
===================================================== */

.lookbook-simple-section {
  padding-top: clamp(86px, 8vw, 128px) !important;
  padding-bottom: clamp(92px, 9vw, 140px) !important;
  background:
    radial-gradient(circle at 10% 18%, rgba(216,180,140,.24), transparent 30%),
    radial-gradient(circle at 86% 22%, rgba(107,32,50,.10), transparent 26%),
    linear-gradient(135deg, #fff8ef 0%, #f3e8dc 45%, #ead9ca 100%) !important;
}

.lookbook-simple-heading {
  max-width: 820px !important;
}

.lookbook-simple-heading h2 {
  letter-spacing: -.03em;
}

.lookbook-swipe-layout {
  display: grid;
  grid-template-columns: minmax(260px, 340px) minmax(0, 1fr);
  gap: clamp(28px, 4vw, 58px);
  align-items: center;
}

.lookbook-swipe-intro {
  position: sticky;
  top: 112px;
  padding: 34px;
  border-radius: 34px;
  background: rgba(255, 250, 244, .68);
  border: 1px solid rgba(120, 82, 52, .13);
  box-shadow: 0 28px 80px rgba(77, 48, 31, .12);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.lookbook-swipe-intro h3 {
  margin: 14px 0 14px;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(38px, 4vw, 54px);
  font-weight: 600;
  line-height: .95;
  letter-spacing: -.03em;
  color: #211815;
}

.lookbook-swipe-intro p {
  color: #66544b;
  line-height: 1.8;
  font-size: 15px;
}

.lookbook-swipe-active {
  margin-top: 26px;
  padding: 18px 18px 17px;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(34, 24, 21, .94), rgba(85, 48, 38, .92));
  color: #fff8ef;
  box-shadow: 0 18px 48px rgba(58, 34, 26, .18);
}

.lookbook-swipe-active span {
  display: block;
  margin-bottom: 6px;
  color: #d8b48c;
  font-family: 'Manrope', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.lookbook-swipe-active strong {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px;
  font-weight: 600;
  line-height: 1;
}

.lookbook-swipe-area {
  min-width: 0;
}

.lookbook-swipe-topline {
  width: min(100%, 650px);
  margin: 0 auto 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.lookbook-swipe-topline > span {
  color: #7a604f;
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .18em;
}

.lookbook-swipe-arrows {
  display: inline-flex;
  gap: 10px;
}

.lookbook-swipe-btn {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(120,82,52,.18);
  background: rgba(255,255,255,.70);
  color: #2b1d18;
  font-family: 'Cormorant Garamond', serif;
  font-size: 34px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 14px 34px rgba(77, 48, 31, .10);
  transition: transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}

.lookbook-swipe-btn:hover {
  transform: translateY(-2px);
  background: #211815;
  color: #fff8ef;
  border-color: #211815;
}

.lookbook-swipe-stage {
  position: relative;
  height: min(720px, 78vh);
  min-height: 620px;
  width: min(100%, 690px);
  margin: 0 auto;
  outline: none;
  touch-action: pan-y;
  user-select: none;
}

.lookbook-swipe-card {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(430px, 78vw);
  height: min(650px, 74vh);
  min-height: 570px;
  overflow: hidden;
  border-radius: 38px;
  background: rgba(255, 250, 244, .94);
  border: 1px solid rgba(120, 82, 52, .14);
  box-shadow: 0 34px 90px rgba(77, 48, 31, .18);
  transform: translate(-50%, -50%) scale(.82);
  opacity: 0;
  pointer-events: none;
  transition:
    transform .46s cubic-bezier(.22,.9,.25,1),
    opacity .36s ease,
    filter .36s ease,
    box-shadow .36s ease;
  will-change: transform, opacity;
}

.lookbook-swipe-card.is-active {
  z-index: 5;
  opacity: 1;
  pointer-events: auto;
  cursor: grab;
  transform:
    translate(-50%, -50%)
    translateX(var(--drag-x, 0px))
    rotate(var(--drag-rotate, 0deg))
    scale(1);
}

.lookbook-swipe-card.is-active:active,
.lookbook-swipe-card.is-dragging {
  cursor: grabbing;
  transition: none;
}

.lookbook-swipe-card.is-prev {
  z-index: 3;
  opacity: .68;
  filter: saturate(.92) brightness(.92);
  transform: translate(calc(-50% - 84px), -50%) rotate(-5deg) scale(.90);
}

.lookbook-swipe-card.is-next {
  z-index: 3;
  opacity: .68;
  filter: saturate(.92) brightness(.92);
  transform: translate(calc(-50% + 84px), -50%) rotate(5deg) scale(.90);
}

.lookbook-swipe-card.is-far-prev {
  z-index: 1;
  opacity: .20;
  filter: blur(.2px) saturate(.85) brightness(.88);
  transform: translate(calc(-50% - 146px), -50%) rotate(-8deg) scale(.80);
}

.lookbook-swipe-card.is-far-next {
  z-index: 1;
  opacity: .20;
  filter: blur(.2px) saturate(.85) brightness(.88);
  transform: translate(calc(-50% + 146px), -50%) rotate(8deg) scale(.80);
}

.lookbook-swipe-card.is-hidden {
  opacity: 0;
  transform: translate(-50%, -50%) scale(.72);
}

.lookbook-swipe-media {
  position: relative;
  height: 70%;
  overflow: hidden;
  background: #efe3d6;
}

.lookbook-swipe-media::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 46%;
  background: linear-gradient(to top, rgba(0,0,0,.52), transparent);
  pointer-events: none;
}

.lookbook-swipe-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  transform: scale(1.01);
}

.lookbook-swipe-media figcaption {
  position: absolute;
  left: 18px;
  right: 18px;
  top: 18px;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.lookbook-swipe-media figcaption span,
.lookbook-swipe-media figcaption strong {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  border-radius: 999px;
  background: rgba(255,255,255,.76);
  color: #2c211d;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.lookbook-swipe-media figcaption span {
  padding: 8px 13px;
  font-family: 'Manrope', sans-serif;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.lookbook-swipe-media figcaption strong {
  width: 34px;
  justify-content: center;
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px;
  font-weight: 700;
}

.lookbook-swipe-copy {
  padding: 22px 24px 24px;
}

.lookbook-swipe-copy h3 {
  margin: 9px 0 8px;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(34px, 3.8vw, 44px);
  font-weight: 600;
  line-height: .92;
  letter-spacing: -.025em;
  color: #211815;
}

.lookbook-swipe-copy p {
  color: #66544b;
  font-size: 13px;
  line-height: 1.55;
}

.lookbook-swipe-pieces {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 15px 0 18px;
}

.lookbook-swipe-pieces span {
  max-width: 100%;
  padding: 7px 10px;
  border-radius: 999px;
  background: #f5ece3;
  color: #6a5042;
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 800;
}

.lookbook-swipe-card .lookbook-simple-actions {
  gap: 9px;
}

.lookbook-swipe-card .lookbook-consult-btn {
  padding: 12px 20px !important;
  width: auto !important;
  min-width: 150px;
  font-size: 13px;
}

.lookbook-swipe-card .lookbook-see-products {
  padding: 12px 10px;
}

.lookbook-swipe-dots {
  display: flex;
  justify-content: center;
  gap: 9px;
  margin-top: 22px;
}

.lookbook-swipe-dots button {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  border: none;
  background: rgba(90, 64, 49, .28);
  cursor: pointer;
  transition: width .28s ease, background .28s ease;
}

.lookbook-swipe-dots button.active {
  width: 30px;
  border-radius: 999px;
  background: #6b2032;
}

.lookbook-swipe-hint {
  max-width: 520px;
  margin: 14px auto 0;
  color: #7a604f;
  font-size: 12px;
  line-height: 1.55;
  text-align: center;
}

@media (max-width: 1024px) {
  .lookbook-swipe-layout {
    grid-template-columns: 1fr;
  }

  .lookbook-swipe-intro {
    position: relative;
    top: auto;
    max-width: 700px;
    margin: 0 auto;
    text-align: center;
  }

  .lookbook-swipe-active {
    max-width: 360px;
    margin-left: auto;
    margin-right: auto;
  }

  .lookbook-simple-benefits {
    justify-content: center;
  }
}

@media (max-width: 760px) {
  .lookbook-simple-section {
    padding: 76px 14px 88px !important;
  }

  .lookbook-simple-heading h2 {
    font-size: clamp(42px, 14vw, 58px) !important;
  }

  .lookbook-simple-heading .section-subtitle {
    font-size: 14px;
    line-height: 1.7;
  }

  .lookbook-swipe-intro {
    padding: 24px;
    border-radius: 28px;
  }

  .lookbook-swipe-intro h3 {
    font-size: 40px;
  }

  .lookbook-swipe-stage {
    width: 100%;
    min-height: 590px;
    height: 640px;
  }

  .lookbook-swipe-card {
    width: min(92vw, 390px);
    height: 585px;
    min-height: 585px;
    border-radius: 30px;
  }

  .lookbook-swipe-card.is-prev {
    opacity: .32;
    transform: translate(calc(-50% - 34px), -50%) rotate(-4deg) scale(.88);
  }

  .lookbook-swipe-card.is-next {
    opacity: .32;
    transform: translate(calc(-50% + 34px), -50%) rotate(4deg) scale(.88);
  }

  .lookbook-swipe-card.is-far-prev,
  .lookbook-swipe-card.is-far-next {
    opacity: 0;
  }

  .lookbook-swipe-media {
    height: 66%;
  }

  .lookbook-swipe-copy {
    padding: 20px;
  }

  .lookbook-swipe-copy h3 {
    font-size: 34px;
  }

  .lookbook-swipe-card .lookbook-simple-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .lookbook-swipe-card .lookbook-consult-btn,
  .lookbook-swipe-card .lookbook-see-products {
    width: 100% !important;
    text-align: center;
    justify-content: center;
  }

  .lookbook-swipe-topline {
    padding: 0 4px;
  }
}


/* =====================================================
   AJUSTE LOOKBOOK - CARTAS CENTRADAS SIN BLOQUE IZQUIERDO
   Mantiene el swipe, libera el centro y evita que la descripción quede tapada.
===================================================== */

.lookbook-swipe-layout-centered,
.lookbook-swipe-layout {
  grid-template-columns: 1fr !important;
  place-items: center !important;
  justify-items: center !important;
  gap: 0 !important;
}

.lookbook-swipe-intro {
  display: none !important;
}

.lookbook-swipe-area {
  width: 100% !important;
  max-width: 820px !important;
  margin: 0 auto !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

.lookbook-swipe-topline {
  width: min(100%, 600px) !important;
  margin: 0 auto 18px !important;
}

.lookbook-swipe-stage {
  width: min(100%, 760px) !important;
  height: min(760px, 84vh) !important;
  min-height: 690px !important;
  margin: 0 auto !important;
}

.lookbook-swipe-card {
  width: min(444px, 82vw) !important;
  height: 690px !important;
  min-height: 690px !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: column !important;
}

.lookbook-swipe-media {
  height: 61% !important;
  flex: 0 0 61% !important;
}

.lookbook-swipe-media img {
  object-position: center top !important;
}

.lookbook-swipe-copy {
  height: 39% !important;
  flex: 1 1 auto !important;
  padding: 18px 24px 22px !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: visible !important;
}

.lookbook-swipe-copy h3 {
  margin: 7px 0 7px !important;
  font-size: clamp(32px, 3.4vw, 40px) !important;
  line-height: .94 !important;
}

.lookbook-swipe-copy p {
  margin: 0 !important;
  color: #66544b !important;
  font-size: 12.8px !important;
  line-height: 1.48 !important;
}

.lookbook-swipe-pieces {
  margin: 12px 0 14px !important;
  max-height: 58px !important;
  overflow: hidden !important;
}

.lookbook-swipe-pieces span {
  padding: 6px 9px !important;
  font-size: 10.5px !important;
}

.lookbook-swipe-card .lookbook-simple-actions {
  margin-top: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 9px !important;
}

.lookbook-swipe-card .lookbook-consult-btn,
.lookbook-swipe-card .lookbook-see-products {
  min-height: 42px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.lookbook-swipe-card .lookbook-consult-btn {
  min-width: 148px !important;
  padding: 11px 18px !important;
}

.lookbook-swipe-card .lookbook-see-products {
  padding: 11px 16px !important;
}

.lookbook-swipe-dots {
  margin-top: 18px !important;
}

.lookbook-swipe-hint {
  margin-top: 12px !important;
}

@media (max-width: 760px) {
  .lookbook-swipe-area {
    max-width: 100% !important;
  }

  .lookbook-swipe-topline {
    width: min(100%, 390px) !important;
  }

  .lookbook-swipe-stage {
    height: 660px !important;
    min-height: 660px !important;
  }

  .lookbook-swipe-card {
    width: min(92vw, 390px) !important;
    height: 625px !important;
    min-height: 625px !important;
  }

  .lookbook-swipe-media {
    height: 56% !important;
    flex-basis: 56% !important;
  }

  .lookbook-swipe-copy {
    height: 44% !important;
    padding: 17px 18px 19px !important;
  }

  .lookbook-swipe-copy h3 {
    font-size: 31px !important;
  }

  .lookbook-swipe-copy p {
    font-size: 12.5px !important;
    line-height: 1.45 !important;
  }

  .lookbook-swipe-pieces {
    margin: 10px 0 12px !important;
    max-height: 54px !important;
  }

  .lookbook-swipe-card .lookbook-simple-actions {
    grid-template-columns: 1fr !important;
    display: grid !important;
  }
}


/* =====================================================
   AJUSTE FINAL LOOKS - TEXTO MÁS FINO + IMAGEN COMPLETA
   Centra el deck, reduce la escala y muestra la foto 9:16 sin recortar.
===================================================== */

.lookbook-simple-section {
  padding-top: clamp(72px, 7vw, 108px) !important;
  padding-bottom: clamp(78px, 7vw, 118px) !important;
}

.lookbook-simple-heading {
  max-width: 680px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: clamp(28px, 4vw, 44px) !important;
}

.lookbook-simple-heading span {
  font-size: 11px !important;
  letter-spacing: .14em !important;
}

.lookbook-simple-heading h2 {
  max-width: 620px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  font-size: clamp(38px, 4.4vw, 62px) !important;
  line-height: .96 !important;
  letter-spacing: -.035em !important;
}

.lookbook-simple-heading .section-subtitle {
  max-width: 560px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  font-size: 13.5px !important;
  line-height: 1.7 !important;
}

.lookbook-swipe-area {
  max-width: 700px !important;
  margin-inline: auto !important;
  align-items: center !important;
}

.lookbook-swipe-topline {
  width: min(100%, 410px) !important;
  margin: 0 auto 12px !important;
}

.lookbook-swipe-stage {
  width: min(100%, 660px) !important;
  height: clamp(700px, 82vh, 780px) !important;
  min-height: 700px !important;
  margin-inline: auto !important;
}

.lookbook-swipe-card {
  width: min(340px, 82vw) !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: column !important;
  border-radius: 30px !important;
}

.lookbook-swipe-card.is-prev {
  transform: translate(calc(-50% - 76px), -50%) rotate(-4.5deg) scale(.90) !important;
}

.lookbook-swipe-card.is-next {
  transform: translate(calc(-50% + 76px), -50%) rotate(4.5deg) scale(.90) !important;
}

.lookbook-swipe-card.is-far-prev {
  transform: translate(calc(-50% - 126px), -50%) rotate(-7deg) scale(.80) !important;
}

.lookbook-swipe-card.is-far-next {
  transform: translate(calc(-50% + 126px), -50%) rotate(7deg) scale(.80) !important;
}

.lookbook-swipe-media {
  height: auto !important;
  flex: 0 0 auto !important;
  aspect-ratio: 9 / 16 !important;
  background: #efe3d6 !important;
}

.lookbook-swipe-media::after {
  height: 26% !important;
  background: linear-gradient(to top, rgba(0,0,0,.34), transparent) !important;
}

.lookbook-swipe-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  transform: none !important;
}

.lookbook-swipe-media figcaption {
  left: 14px !important;
  right: 14px !important;
  top: 14px !important;
}

.lookbook-swipe-media figcaption span,
.lookbook-swipe-media figcaption strong {
  min-height: 30px !important;
}

.lookbook-swipe-media figcaption span {
  padding: 7px 11px !important;
  font-size: 9px !important;
  letter-spacing: .12em !important;
}

.lookbook-swipe-media figcaption strong {
  width: 30px !important;
  font-size: 17px !important;
}

.lookbook-swipe-copy {
  height: auto !important;
  min-height: 122px !important;
  flex: 0 0 auto !important;
  padding: 15px 18px 18px !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: visible !important;
}

.lookbook-simple-occasion {
  margin-bottom: 4px !important;
  font-size: 9.5px !important;
  letter-spacing: .16em !important;
}

.lookbook-swipe-copy h3 {
  margin: 0 0 6px !important;
  font-size: clamp(27px, 3vw, 34px) !important;
  line-height: .96 !important;
  letter-spacing: -.025em !important;
}

.lookbook-swipe-copy p {
  margin: 0 !important;
  color: #6b5a50 !important;
  font-size: 12px !important;
  line-height: 1.45 !important;
}

.lookbook-swipe-pieces {
  display: none !important;
}

.lookbook-swipe-card .lookbook-simple-actions {
  margin-top: 12px !important;
  gap: 8px !important;
}

.lookbook-swipe-card .lookbook-consult-btn,
.lookbook-swipe-card .lookbook-see-products {
  min-height: 38px !important;
  font-size: 11px !important;
}

.lookbook-swipe-card .lookbook-consult-btn {
  min-width: 128px !important;
  padding: 9px 16px !important;
}

.lookbook-swipe-card .lookbook-see-products {
  padding: 9px 14px !important;
}

.lookbook-swipe-dots {
  margin-top: 14px !important;
}

.lookbook-swipe-hint {
  max-width: 430px !important;
  margin-top: 10px !important;
  font-size: 11.5px !important;
}

@media (max-width: 760px) {
  .lookbook-simple-section {
    padding: 66px 14px 78px !important;
  }

  .lookbook-simple-heading {
    margin-bottom: 24px !important;
  }

  .lookbook-simple-heading h2 {
    font-size: clamp(34px, 10.5vw, 46px) !important;
    line-height: .98 !important;
  }

  .lookbook-simple-heading .section-subtitle {
    max-width: 340px !important;
    font-size: 12.8px !important;
    line-height: 1.62 !important;
  }

  .lookbook-swipe-topline {
    width: min(100%, 330px) !important;
  }

  .lookbook-swipe-stage {
    height: 690px !important;
    min-height: 690px !important;
  }

  .lookbook-swipe-card {
    width: min(82vw, 320px) !important;
    border-radius: 26px !important;
  }

  .lookbook-swipe-card.is-prev {
    opacity: .28 !important;
    transform: translate(calc(-50% - 32px), -50%) rotate(-4deg) scale(.90) !important;
  }

  .lookbook-swipe-card.is-next {
    opacity: .28 !important;
    transform: translate(calc(-50% + 32px), -50%) rotate(4deg) scale(.90) !important;
  }

  .lookbook-swipe-copy {
    min-height: 126px !important;
    padding: 14px 16px 17px !important;
  }

  .lookbook-swipe-copy h3 {
    font-size: 28px !important;
  }

  .lookbook-swipe-copy p {
    font-size: 11.8px !important;
  }

  .lookbook-swipe-card .lookbook-simple-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .lookbook-swipe-card .lookbook-consult-btn,
  .lookbook-swipe-card .lookbook-see-products {
    width: 100% !important;
  }
}

/* =====================================================
   AJUSTE LOOKS - SIN SUPERPOSICIONES + MÓVIL PRO
   Mantiene las cartas centradas, reduce escala y evita que
   textos, dots, flechas o cartas laterales tapen la información.
===================================================== */

.lookbook-simple-section {
  padding-top: clamp(64px, 6vw, 96px) !important;
  padding-bottom: clamp(78px, 7vw, 110px) !important;
  overflow: hidden !important;
}

.lookbook-simple-heading {
  max-width: 620px !important;
  margin-bottom: clamp(22px, 3vw, 34px) !important;
}

.lookbook-simple-heading span {
  font-size: 10px !important;
  letter-spacing: .15em !important;
}

.lookbook-simple-heading h2 {
  max-width: 560px !important;
  font-size: clamp(35px, 4vw, 52px) !important;
  line-height: 1 !important;
  letter-spacing: -.035em !important;
}

.lookbook-simple-heading .section-subtitle {
  max-width: 500px !important;
  font-size: 12.8px !important;
  line-height: 1.65 !important;
}

.lookbook-swipe-area {
  position: relative !important;
  max-width: 640px !important;
  isolation: isolate !important;
}

.lookbook-swipe-topline {
  width: min(100%, 360px) !important;
  margin: 0 auto 10px !important;
  position: relative !important;
  z-index: 10 !important;
}

.lookbook-swipe-topline > span {
  font-size: 10px !important;
}

.lookbook-swipe-btn {
  width: 38px !important;
  height: 38px !important;
  font-size: 28px !important;
  background: rgba(255,255,255,.88) !important;
}

.lookbook-swipe-stage {
  width: min(100%, 600px) !important;
  height: 648px !important;
  min-height: 648px !important;
  margin: 0 auto !important;
  position: relative !important;
  overflow: visible !important;
  z-index: 3 !important;
}

.lookbook-swipe-card {
  width: min(312px, 78vw) !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  background: #fffaf4 !important;
  border-color: rgba(120, 82, 52, .12) !important;
  box-shadow: 0 28px 68px rgba(77, 48, 31, .16) !important;
}

.lookbook-swipe-card.is-active {
  z-index: 9 !important;
}

.lookbook-swipe-card.is-prev,
.lookbook-swipe-card.is-next {
  z-index: 2 !important;
  opacity: .34 !important;
  pointer-events: none !important;
  filter: saturate(.75) brightness(.92) !important;
}

.lookbook-swipe-card.is-prev {
  transform: translate(calc(-50% - 66px), -50%) rotate(-4deg) scale(.88) !important;
}

.lookbook-swipe-card.is-next {
  transform: translate(calc(-50% + 66px), -50%) rotate(4deg) scale(.88) !important;
}

.lookbook-swipe-card.is-far-prev,
.lookbook-swipe-card.is-far-next {
  z-index: 1 !important;
  opacity: .12 !important;
  pointer-events: none !important;
}

.lookbook-swipe-card.is-far-prev {
  transform: translate(calc(-50% - 106px), -50%) rotate(-6deg) scale(.78) !important;
}

.lookbook-swipe-card.is-far-next {
  transform: translate(calc(-50% + 106px), -50%) rotate(6deg) scale(.78) !important;
}

.lookbook-swipe-media {
  aspect-ratio: 9 / 16 !important;
  height: auto !important;
  flex: 0 0 auto !important;
  background: #f3eadf !important;
}

.lookbook-swipe-media::after {
  height: 22% !important;
  background: linear-gradient(to top, rgba(0,0,0,.26), transparent) !important;
}

.lookbook-swipe-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  transform: none !important;
  background: #f3eadf !important;
}

.lookbook-swipe-media figcaption {
  left: 12px !important;
  right: 12px !important;
  top: 12px !important;
}

.lookbook-swipe-media figcaption span,
.lookbook-swipe-media figcaption strong {
  min-height: 28px !important;
  background: rgba(255,255,255,.84) !important;
}

.lookbook-swipe-media figcaption span {
  padding: 6px 10px !important;
  font-size: 8.3px !important;
  letter-spacing: .12em !important;
}

.lookbook-swipe-media figcaption strong {
  width: 28px !important;
  font-size: 16px !important;
}

.lookbook-swipe-copy {
  min-height: 118px !important;
  padding: 13px 16px 16px !important;
  background: #fffaf4 !important;
  position: relative !important;
  z-index: 11 !important;
}

.lookbook-simple-occasion {
  margin-bottom: 4px !important;
  font-size: 8.8px !important;
  line-height: 1.25 !important;
  letter-spacing: .15em !important;
}

.lookbook-swipe-copy h3 {
  margin: 0 0 4px !important;
  font-size: clamp(24px, 2.6vw, 30px) !important;
  line-height: .98 !important;
}

.lookbook-swipe-copy p {
  display: block !important;
  margin: 0 !important;
  font-size: 11px !important;
  line-height: 1.38 !important;
  color: #6b5a50 !important;
}

.lookbook-swipe-card .lookbook-simple-actions {
  margin-top: 10px !important;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
}

.lookbook-swipe-card .lookbook-consult-btn,
.lookbook-swipe-card .lookbook-see-products {
  min-height: 34px !important;
  width: auto !important;
  white-space: nowrap !important;
  font-size: 10.5px !important;
}

.lookbook-swipe-card .lookbook-consult-btn {
  min-width: 118px !important;
  padding: 8px 13px !important;
}

.lookbook-swipe-card .lookbook-see-products {
  padding: 8px 11px !important;
}

.lookbook-swipe-dots {
  position: relative !important;
  z-index: 12 !important;
  margin-top: 12px !important;
}

.lookbook-swipe-hint {
  position: relative !important;
  z-index: 12 !important;
  max-width: 390px !important;
  margin-top: 9px !important;
  font-size: 10.8px !important;
}

@media (max-width: 760px) {
  .lookbook-simple-section {
    padding: 54px 12px 72px !important;
  }

  .lookbook-simple-shell {
    width: 100% !important;
  }

  .lookbook-simple-heading {
    max-width: 350px !important;
    margin-bottom: 18px !important;
  }

  .lookbook-simple-heading span {
    font-size: 9px !important;
  }

  .lookbook-simple-heading h2 {
    max-width: 330px !important;
    font-size: clamp(30px, 9vw, 38px) !important;
    line-height: 1.02 !important;
  }

  .lookbook-simple-heading .section-subtitle {
    max-width: 330px !important;
    font-size: 11.6px !important;
    line-height: 1.55 !important;
  }

  .lookbook-swipe-area {
    max-width: 100% !important;
  }

  .lookbook-swipe-topline {
    width: min(100%, 286px) !important;
    margin-bottom: 8px !important;
  }

  .lookbook-swipe-topline > span {
    font-size: 9px !important;
    letter-spacing: .14em !important;
  }

  .lookbook-swipe-arrows {
    gap: 8px !important;
  }

  .lookbook-swipe-btn {
    width: 34px !important;
    height: 34px !important;
    font-size: 24px !important;
  }

  .lookbook-swipe-stage {
    width: 100% !important;
    height: 592px !important;
    min-height: 592px !important;
  }

  .lookbook-swipe-card {
    width: min(74vw, 276px) !important;
    border-radius: 24px !important;
  }

  .lookbook-swipe-card.is-prev {
    opacity: .20 !important;
    transform: translate(calc(-50% - 22px), -50%) rotate(-3deg) scale(.90) !important;
  }

  .lookbook-swipe-card.is-next {
    opacity: .20 !important;
    transform: translate(calc(-50% + 22px), -50%) rotate(3deg) scale(.90) !important;
  }

  .lookbook-swipe-card.is-far-prev,
  .lookbook-swipe-card.is-far-next {
    opacity: 0 !important;
  }

  .lookbook-swipe-media figcaption {
    left: 10px !important;
    right: 10px !important;
    top: 10px !important;
  }

  .lookbook-swipe-media figcaption span {
    max-width: 180px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  .lookbook-swipe-copy {
    min-height: 112px !important;
    padding: 12px 14px 14px !important;
  }

  .lookbook-simple-occasion {
    font-size: 8.2px !important;
  }

  .lookbook-swipe-copy h3 {
    font-size: 24px !important;
  }

  .lookbook-swipe-copy p {
    font-size: 10.4px !important;
    line-height: 1.32 !important;
  }

  .lookbook-swipe-card .lookbook-simple-actions {
    margin-top: 8px !important;
    gap: 6px !important;
  }

  .lookbook-swipe-card .lookbook-consult-btn,
  .lookbook-swipe-card .lookbook-see-products {
    min-height: 32px !important;
    font-size: 9.4px !important;
  }

  .lookbook-swipe-card .lookbook-consult-btn {
    min-width: 104px !important;
    padding: 7px 10px !important;
  }

  .lookbook-swipe-card .lookbook-see-products {
    padding: 7px 9px !important;
  }

  .lookbook-swipe-dots {
    margin-top: 10px !important;
  }

  .lookbook-swipe-hint {
    max-width: 300px !important;
    margin-top: 8px !important;
    font-size: 10px !important;
  }
}

@media (max-width: 390px) {
  .lookbook-swipe-stage {
    height: 560px !important;
    min-height: 560px !important;
  }

  .lookbook-swipe-card {
    width: min(72vw, 252px) !important;
  }

  .lookbook-swipe-copy h3 {
    font-size: 22px !important;
  }

  .lookbook-swipe-copy p {
    font-size: 10px !important;
  }
}


/* =====================================================
   AJUSTE FINAL LOOKBOOK - HEADER LIMPIO + CONTROLES FINOS
   Quita el título grande visual, elimina el contador visible
   y convierte las flechas en controles laterales elegantes.
===================================================== */

.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.lookbook-simple-section {
  padding-top: clamp(52px, 5vw, 82px) !important;
}

.lookbook-simple-heading {
  max-width: 560px !important;
  margin-bottom: clamp(28px, 3.2vw, 44px) !important;
}

.lookbook-simple-heading span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 12px !important;
  color: #7a2635 !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
}

.lookbook-simple-heading h2 {
  display: none !important;
}

.lookbook-simple-heading .section-subtitle {
  max-width: 520px !important;
  margin: 0 auto !important;
  color: #7b6b61 !important;
  font-size: clamp(13px, 1.08vw, 15px) !important;
  line-height: 1.75 !important;
}

.lookbook-swipe-area {
  max-width: 720px !important;
  margin: 0 auto !important;
  position: relative !important;
}

/* La línea ya no debe aparecer como elemento después del subtítulo */
.lookbook-swipe-topline {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: min(600px, 92vw) !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  transform: translate(-50%, -50%) !important;
  z-index: 30 !important;
  pointer-events: none !important;
}

.lookbook-swipe-topline > span,
[data-look-counter] {
  display: none !important;
}

.lookbook-swipe-arrows {
  width: 100% !important;
  height: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 0 !important;
  pointer-events: none !important;
}

.lookbook-swipe-btn {
  pointer-events: auto !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(103, 59, 40, .14) !important;
  background: rgba(255, 250, 244, .82) !important;
  color: #4d2f24 !important;
  font-size: 24px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 12px 30px rgba(69, 44, 31, .10) !important;
  backdrop-filter: blur(12px) !important;
  transition: transform .22s ease, background .22s ease, box-shadow .22s ease, border-color .22s ease !important;
}

.lookbook-swipe-btn:hover,
.lookbook-swipe-btn:focus-visible {
  background: #fffaf4 !important;
  border-color: rgba(122, 38, 53, .28) !important;
  box-shadow: 0 16px 38px rgba(69, 44, 31, .16) !important;
  transform: translateY(-1px) !important;
  outline: none !important;
}

.lookbook-swipe-stage {
  margin-top: 0 !important;
}

.lookbook-swipe-dots {
  margin-top: 16px !important;
}

.lookbook-swipe-dots button {
  width: 6px !important;
  height: 6px !important;
  opacity: .34 !important;
  border-radius: 999px !important;
  transition: width .25s ease, opacity .25s ease, background .25s ease !important;
}

.lookbook-swipe-dots button.active {
  width: 24px !important;
  opacity: 1 !important;
  background: #7a2635 !important;
}

.lookbook-swipe-hint {
  display: none !important;
}

@media (max-width: 760px) {
  .lookbook-simple-section {
    padding: 44px 14px 64px !important;
  }

  .lookbook-simple-heading {
    max-width: 330px !important;
    margin-bottom: 22px !important;
  }

  .lookbook-simple-heading span {
    margin-bottom: 10px !important;
    font-size: 9.5px !important;
    letter-spacing: .16em !important;
  }

  .lookbook-simple-heading .section-subtitle {
    max-width: 310px !important;
    font-size: 11.7px !important;
    line-height: 1.62 !important;
  }

  .lookbook-swipe-area {
    max-width: 100% !important;
  }

  .lookbook-swipe-topline {
    top: 48% !important;
    width: min(330px, 96vw) !important;
  }

  .lookbook-swipe-btn {
    width: 34px !important;
    height: 34px !important;
    font-size: 21px !important;
    background: rgba(255, 250, 244, .76) !important;
  }

  .lookbook-swipe-card.is-prev,
  .lookbook-swipe-card.is-next {
    opacity: .16 !important;
  }

  .lookbook-swipe-dots {
    margin-top: 12px !important;
  }
}

@media (max-width: 390px) {
  .lookbook-swipe-topline {
    width: min(300px, 96vw) !important;
  }

  .lookbook-swipe-btn {
    width: 32px !important;
    height: 32px !important;
    font-size: 20px !important;
  }
}

/* =====================================================
   LOOKS LAOS - DESKTOP CON DESCRIPCIÓN LATERAL
   Móvil conserva el diseño actual y solo oculta flechas.
===================================================== */

@media (min-width: 761px) {
  .lookbook-simple-section {
    padding-top: clamp(64px, 5.5vw, 92px) !important;
    padding-bottom: clamp(78px, 6.5vw, 112px) !important;
  }

  .lookbook-simple-heading {
    margin-bottom: clamp(34px, 4vw, 58px) !important;
  }

  .lookbook-desktop-grid {
    width: min(100%, 1040px) !important;
    margin: 0 auto !important;
    display: grid !important;
    grid-template-columns: minmax(260px, 320px) minmax(500px, 1fr) !important;
    align-items: center !important;
    justify-content: center !important;
    gap: clamp(34px, 5vw, 72px) !important;
  }

  .lookbook-desktop-info {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-self: center !important;
    min-height: 430px !important;
    padding: 30px 28px !important;
    border-radius: 28px !important;
    background: rgba(255, 250, 244, .72) !important;
    border: 1px solid rgba(122, 38, 53, .10) !important;
    box-shadow: 0 24px 62px rgba(69, 44, 31, .08) !important;
    backdrop-filter: blur(10px) !important;
  }

  .lookbook-desktop-kicker {
    margin-bottom: 18px !important;
    color: #7a2635 !important;
    font-size: 9.5px !important;
    font-weight: 800 !important;
    letter-spacing: .18em !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
  }

  .lookbook-desktop-meta {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
    margin-bottom: 14px !important;
  }

  .lookbook-desktop-meta span {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 28px !important;
    padding: 7px 10px !important;
    border-radius: 999px !important;
    background: #fff6ec !important;
    color: #7a5244 !important;
    font-size: 8.6px !important;
    font-weight: 800 !important;
    letter-spacing: .14em !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
  }

  .lookbook-desktop-info h3 {
    margin: 0 0 14px !important;
    color: #1b1410 !important;
    font-family: 'Cormorant Garamond', Georgia, serif !important;
    font-size: clamp(40px, 3.8vw, 54px) !important;
    font-weight: 600 !important;
    letter-spacing: -.04em !important;
    line-height: .92 !important;
  }

  .lookbook-desktop-occasion {
    margin: 0 0 12px !important;
    color: #7a2635 !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    letter-spacing: .14em !important;
    line-height: 1.35 !important;
    text-transform: uppercase !important;
  }

  .lookbook-desktop-description {
    max-width: 260px !important;
    margin: 0 !important;
    color: #74645a !important;
    font-size: 13px !important;
    line-height: 1.75 !important;
  }

  .lookbook-desktop-actions {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
    margin-top: 24px !important;
  }

  .lookbook-desktop-actions .lookbook-consult-btn,
  .lookbook-desktop-actions .lookbook-see-products {
    width: auto !important;
    min-height: 38px !important;
    white-space: nowrap !important;
    font-size: 11px !important;
  }

  .lookbook-desktop-actions .lookbook-consult-btn {
    min-width: 132px !important;
    padding: 10px 18px !important;
  }

  .lookbook-desktop-actions .lookbook-see-products {
    padding: 10px 4px !important;
    border: 0 !important;
    background: transparent !important;
    color: #7a2635 !important;
    text-decoration: underline !important;
    text-underline-offset: 5px !important;
    cursor: pointer !important;
    font-weight: 800 !important;
  }

  .lookbook-desktop-grid .lookbook-swipe-area {
    max-width: 620px !important;
    margin: 0 !important;
  }

  .lookbook-desktop-grid .lookbook-swipe-stage {
    width: min(100%, 620px) !important;
    height: 600px !important;
    min-height: 600px !important;
  }

  .lookbook-desktop-grid .lookbook-swipe-card {
    width: min(330px, 86vw) !important;
    background: #fffaf4 !important;
  }

  .lookbook-desktop-grid .lookbook-swipe-card .lookbook-swipe-copy {
    display: none !important;
  }

  .lookbook-desktop-grid .lookbook-swipe-media {
    aspect-ratio: 9 / 16 !important;
    height: auto !important;
  }

  .lookbook-desktop-grid .lookbook-swipe-media img {
    object-fit: contain !important;
    object-position: center center !important;
  }

  .lookbook-desktop-grid .lookbook-swipe-dots {
    margin-top: 18px !important;
  }
}

@media (max-width: 760px) {
  .lookbook-desktop-info {
    display: none !important;
  }

  .lookbook-desktop-grid {
    display: block !important;
  }

  .lookbook-swipe-arrows,
  .lookbook-swipe-btn {
    display: none !important;
  }
}


/* =====================================================
   REFINAMIENTO PREMIUM - DESCRIPCIÓN LATERAL LOOKS
   Mantiene móvil y ordena la información en PC.
===================================================== */

@media (min-width: 761px) {
  .lookbook-desktop-info {
    position: relative !important;
    overflow: hidden !important;
    padding: 38px 34px 34px !important;
    border-radius: 30px !important;
    background:
      linear-gradient(145deg, rgba(255, 251, 246, .92), rgba(248, 238, 228, .70)) !important;
    border: 1px solid rgba(122, 38, 53, .12) !important;
    box-shadow: 0 30px 78px rgba(60, 38, 26, .10) !important;
  }

  .lookbook-desktop-info::before {
    content: "" !important;
    width: 48px !important;
    height: 1px !important;
    margin-bottom: 24px !important;
    display: block !important;
    background: linear-gradient(90deg, #7a2635, rgba(122, 38, 53, 0)) !important;
  }

  .lookbook-desktop-kicker {
    margin-bottom: 18px !important;
    color: #7a2635 !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    letter-spacing: .22em !important;
  }

  .lookbook-desktop-meta {
    margin-bottom: 18px !important;
    gap: 8px !important;
  }

  .lookbook-desktop-meta span {
    min-height: 30px !important;
    padding: 8px 12px !important;
    background: rgba(255, 246, 236, .86) !important;
    border: 1px solid rgba(122, 38, 53, .06) !important;
    color: #8a6656 !important;
    font-size: 8.8px !important;
    letter-spacing: .15em !important;
  }

  .lookbook-desktop-info h3 {
    max-width: 300px !important;
    margin: 0 0 16px !important;
    font-size: clamp(42px, 3.5vw, 56px) !important;
    line-height: .94 !important;
    letter-spacing: -.045em !important;
  }

  .lookbook-desktop-occasion {
    width: fit-content !important;
    margin: 0 0 20px !important;
    padding-bottom: 9px !important;
    border-bottom: 1px solid rgba(122, 38, 53, .22) !important;
    color: #7a2635 !important;
    font-size: 11px !important;
    letter-spacing: .16em !important;
  }

  .lookbook-desktop-description-panel {
    display: grid !important;
    gap: 16px !important;
    width: 100% !important;
    max-width: 292px !important;
    margin: 0 !important;
    padding: 18px 0 2px !important;
    border-top: 1px solid rgba(122, 38, 53, .10) !important;
  }

  .lookbook-desktop-row {
    display: grid !important;
    gap: 7px !important;
  }

  .lookbook-desktop-row span {
    color: #9b7b6a !important;
    font-size: 9px !important;
    font-weight: 800 !important;
    letter-spacing: .18em !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
  }

  .lookbook-desktop-row p,
  .lookbook-desktop-description {
    max-width: 292px !important;
    margin: 0 !important;
    color: #62534a !important;
    font-size: 14px !important;
    line-height: 1.72 !important;
    font-weight: 400 !important;
  }

  .lookbook-desktop-actions {
    margin-top: 30px !important;
    padding-top: 22px !important;
    border-top: 1px solid rgba(122, 38, 53, .10) !important;
  }

  .lookbook-desktop-actions .lookbook-consult-btn {
    min-width: 142px !important;
    min-height: 42px !important;
    border-radius: 999px !important;
    box-shadow: 0 14px 28px rgba(0, 0, 0, .10) !important;
  }

  .lookbook-desktop-actions .lookbook-see-products {
    min-height: 42px !important;
    color: #7a2635 !important;
  }
}


/* Ajuste: sección Nuestro proceso artesanal sin las 3 tarjetas superiores */
.atelier-process-block .atelier-main-title {
  margin-bottom: clamp(26px, 4vw, 44px);
}

.atelier-process-block + .atelier-team-block,
.atelier-team-block {
  margin-top: clamp(42px, 5vw, 72px);
}

@media (max-width: 520px) {
  .atelier-process-block .atelier-main-title {
    margin-bottom: 24px;
  }

  .atelier-team-block {
    margin-top: 34px;
  }
}

/* =============================== */
/* VIDEO REAL - PROCESO ARTESANAL  */
/* =============================== */

.atelier-video-box {
  aspect-ratio: 3 / 2;
  min-height: 0 !important;
  height: auto;
  background: #111;
  border-radius: 4px;
}

.atelier-video-box::after {
  display: none;
}

.atelier-process-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
  background: #111;
}

.atelier-process-video::-webkit-media-controls-panel {
  background-image: linear-gradient(transparent, rgba(0, 0, 0, .52));
}

.atelier-audio-controls {
  position: absolute;
  right: 18px;
  bottom: 18px;
  z-index: 5;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255, 250, 245, .88);
  border: 1px solid rgba(255, 255, 255, .56);
  box-shadow: 0 12px 28px rgba(43, 36, 34, .18);
  backdrop-filter: blur(10px);
  color: #4e2f2b;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.atelier-audio-controls button {
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 50%;
  background: #4b1e28;
  color: #fffaf5;
  font-size: 16px;
  line-height: 1;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: transform .25s ease, background .25s ease;
}

.atelier-audio-controls button:hover {
  transform: translateY(-1px);
  background: #111;
}

@media (max-width: 768px) {
  .atelier-video-box {
    aspect-ratio: 3 / 2;
    width: 100%;
  }

  .atelier-audio-controls {
    right: 12px;
    bottom: 12px;
    padding: 7px 9px;
    gap: 7px;
    font-size: 9px;
  }

  .atelier-audio-controls button {
    width: 26px;
    height: 26px;
  }
}

/* =========================================================
   AJUSTE FINAL - VIDEO ARTESANAL + TEXTO PREMIUM
   ========================================================= */
.atelier-about .atelier-about-shell {
  width: min(1240px, 100%);
}

.atelier-about .atelier-main-title {
  margin-bottom: clamp(34px, 4.6vw, 62px) !important;
}

.atelier-about .atelier-team-block {
  width: 100%;
  margin-top: clamp(26px, 3.5vw, 48px) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, .78fr) !important;
  gap: clamp(34px, 4.8vw, 76px) !important;
  align-items: center !important;
  justify-content: center;
}

.atelier-about .atelier-video-box {
  width: 100% !important;
  max-width: 760px;
  justify-self: start;
  aspect-ratio: 3 / 2 !important;
  min-height: 0 !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  background: #111 !important;
  box-shadow: 0 34px 70px rgba(77, 49, 43, .16) !important;
  border: 1px solid rgba(143, 77, 69, .12);
}

.atelier-about .atelier-process-video {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center !important;
}

.atelier-about .atelier-process-copy {
  width: 100%;
  max-width: 430px;
  justify-self: start;
  align-self: center;
  text-align: left !important;
  background: rgba(255, 250, 245, .82) !important;
  border: 1px solid rgba(143, 77, 69, .16) !important;
  border-radius: 26px !important;
  padding: clamp(30px, 3.6vw, 52px) !important;
  box-shadow: 0 28px 58px rgba(77, 49, 43, .08) !important;
  backdrop-filter: blur(10px);
}

.atelier-copy-kicker {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  color: #7a2635;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .22em;
  line-height: 1;
}

.atelier-copy-kicker::after {
  content: "";
  width: 46px;
  height: 1px;
  background: rgba(122, 38, 53, .32);
}

.atelier-about .atelier-process-copy .atelier-team-title {
  max-width: 100% !important;
  margin: 0 0 18px !important;
  text-align: left !important;
  color: #241918 !important;
  font-size: clamp(34px, 3.2vw, 50px) !important;
  line-height: .96 !important;
  letter-spacing: -.035em !important;
  text-transform: none !important;
  font-weight: 700 !important;
}

.atelier-team-intro {
  margin: 0 0 28px;
  max-width: 380px;
  color: #6b5d56;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 15px;
  line-height: 1.78;
}

.atelier-process-points {
  display: grid;
  gap: 14px;
}

.atelier-process-points article {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 16px;
  padding: 16px 0;
  border-top: 1px solid rgba(143, 77, 69, .12);
}

.atelier-process-points article:first-child {
  border-top-color: rgba(143, 77, 69, .20);
}

.atelier-process-points span {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: #f2e4d9;
  color: #7a2635;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
}

.atelier-process-points h3 {
  margin: 0 0 6px;
  color: #2b2422;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.atelier-process-points p {
  margin: 0;
  color: #756660;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 13.5px;
  line-height: 1.65;
}

.atelier-about .atelier-audio-controls {
  right: 18px;
  bottom: 18px;
}

@media (max-width: 980px) {
  .atelier-about .atelier-team-block {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  .atelier-about .atelier-video-box,
  .atelier-about .atelier-process-copy {
    justify-self: center;
    max-width: 760px;
  }

  .atelier-about .atelier-process-copy .atelier-team-title,
  .atelier-copy-kicker,
  .atelier-team-intro {
    text-align: left !important;
  }
}

@media (max-width: 560px) {
  .atelier-about .atelier-main-title {
    font-size: 27px !important;
    line-height: 1.08 !important;
    margin-bottom: 28px !important;
  }

  .atelier-about .atelier-video-box {
    border-radius: 16px !important;
    box-shadow: 0 22px 44px rgba(77, 49, 43, .14) !important;
  }

  .atelier-about .atelier-process-copy {
    padding: 26px 22px !important;
    border-radius: 22px !important;
  }

  .atelier-about .atelier-process-copy .atelier-team-title {
    font-size: 32px !important;
  }

  .atelier-process-points article {
    grid-template-columns: 36px 1fr;
    gap: 13px;
  }

  .atelier-process-points span {
    width: 32px;
    height: 32px;
    font-size: 10px;
  }

  .atelier-about .atelier-audio-controls {
    right: 10px;
    bottom: 10px;
    transform: scale(.9);
    transform-origin: right bottom;
  }
}


/* =========================================================
   AJUSTE FINAL - VIDEO ARTESANAL SIN BOTÓN DE VOLUMEN
   ========================================================= */
.atelier-audio-controls {
  display: none !important;
}

.atelier-about .atelier-video-box {
  background:
    radial-gradient(circle at 28% 18%, rgba(216, 180, 140, .24), transparent 34%),
    linear-gradient(135deg, #241918 0%, #0f0b0c 100%) !important;
}

.atelier-process-video {
  background:
    radial-gradient(circle at 28% 18%, rgba(216, 180, 140, .18), transparent 36%),
    linear-gradient(135deg, #241918 0%, #0f0b0c 100%) !important;
}

.atelier-process-video.is-preview-ready {
  background: #111 !important;
}


/* =========================================================
   AJUSTE PREMIUM - COPY PROCESO ARTESANAL
   ========================================================= */
.atelier-about .atelier-main-title {
  font-family: 'Cormorant Garamond', 'Cormorant Garamond', Georgia, serif !important;
  font-size: clamp(42px, 4.6vw, 68px) !important;
  font-weight: 600 !important;
  line-height: .94 !important;
  letter-spacing: -.035em !important;
  text-transform: none !important;
  color: #241918 !important;
  margin: 0 auto clamp(34px, 4.8vw, 66px) !important;
  max-width: 760px !important;
  text-align: center !important;
  position: relative;
}

.atelier-about .atelier-main-title::after {
  content: "";
  display: block;
  width: 74px;
  height: 1px;
  margin: 18px auto 0;
  background: linear-gradient(90deg, transparent, rgba(122, 38, 53, .55), transparent);
}

.atelier-about .atelier-process-copy {
  max-width: 460px !important;
  padding: clamp(34px, 3.8vw, 56px) clamp(30px, 3.6vw, 52px) !important;
  background: linear-gradient(145deg, rgba(255, 250, 245, .94), rgba(250, 244, 238, .82)) !important;
  border: 1px solid rgba(143, 77, 69, .18) !important;
  box-shadow: 0 30px 70px rgba(77, 49, 43, .09) !important;
}

.atelier-about .atelier-process-copy::before {
  content: "";
  display: block;
  width: 38px;
  height: 2px;
  margin-bottom: 22px;
  background: #7a2635;
  border-radius: 99px;
  opacity: .78;
}

.atelier-copy-kicker {
  margin-bottom: 16px !important;
  color: #7a2635 !important;
  font-size: 11px !important;
  letter-spacing: .26em !important;
}

.atelier-about .atelier-process-copy .atelier-team-title {
  max-width: 420px !important;
  margin-bottom: 20px !important;
  font-size: clamp(36px, 3.45vw, 56px) !important;
  line-height: .94 !important;
  letter-spacing: -.04em !important;
  font-weight: 600 !important;
}

.atelier-team-intro {
  max-width: 410px !important;
  margin-bottom: 30px !important;
  color: #6f625d !important;
  font-size: 15.5px !important;
  line-height: 1.78 !important;
}

.atelier-process-points {
  gap: 0 !important;
}

.atelier-process-points article {
  grid-template-columns: 44px 1fr !important;
  gap: 18px !important;
  padding: 20px 0 !important;
  border-top: 1px solid rgba(143, 77, 69, .14) !important;
}

.atelier-process-points article:last-child {
  padding-bottom: 0 !important;
}

.atelier-process-points span {
  width: 38px !important;
  height: 38px !important;
  background: #f0e0d5 !important;
  color: #7a2635 !important;
  box-shadow: inset 0 0 0 1px rgba(143, 77, 69, .08) !important;
}

.atelier-process-points h3 {
  margin-bottom: 7px !important;
  color: #2a1d1b !important;
  font-family: 'Cormorant Garamond', 'Cormorant Garamond', Georgia, serif !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  line-height: 1.08 !important;
  letter-spacing: .01em !important;
  text-transform: none !important;
}

.atelier-process-points p {
  max-width: 330px !important;
  color: #746760 !important;
  font-size: 14px !important;
  line-height: 1.68 !important;
}

@media (max-width: 980px) {
  .atelier-about .atelier-main-title {
    font-size: clamp(36px, 8vw, 54px) !important;
  }

  .atelier-about .atelier-process-copy {
    max-width: 760px !important;
  }

  .atelier-about .atelier-process-copy .atelier-team-title {
    max-width: 520px !important;
  }

  .atelier-team-intro,
  .atelier-process-points p {
    max-width: 100% !important;
  }
}

@media (max-width: 560px) {
  .atelier-about .atelier-main-title {
    font-size: 34px !important;
    line-height: 1 !important;
    margin-bottom: 26px !important;
  }

  .atelier-about .atelier-main-title::after {
    width: 54px;
    margin-top: 14px;
  }

  .atelier-about .atelier-process-copy {
    padding: 28px 22px !important;
  }

  .atelier-about .atelier-process-copy .atelier-team-title {
    font-size: 34px !important;
    line-height: .98 !important;
  }

  .atelier-team-intro {
    font-size: 14.5px !important;
    line-height: 1.72 !important;
  }

  .atelier-process-points article {
    grid-template-columns: 36px 1fr !important;
    gap: 13px !important;
    padding: 17px 0 !important;
  }

  .atelier-process-points span {
    width: 32px !important;
    height: 32px !important;
  }

  .atelier-process-points h3 {
    font-size: 17px !important;
  }

  .atelier-process-points p {
    font-size: 13.5px !important;
  }
}

/* =========================================================
   AJUSTE FINAL - PROCESO ARTESANAL UNIFORME
   ========================================================= */
.atelier-about {
  padding-top: clamp(72px, 7vw, 104px) !important;
  padding-bottom: clamp(72px, 7vw, 104px) !important;
}

.atelier-about .atelier-about-shell {
  max-width: 1380px !important;
  margin: 0 auto !important;
}

.atelier-about .atelier-main-title {
  font-size: clamp(36px, 3.2vw, 50px) !important;
  line-height: 1.02 !important;
  letter-spacing: -.02em !important;
  margin-bottom: clamp(42px, 5vw, 76px) !important;
}

.atelier-about .atelier-main-title::after {
  width: 62px !important;
  margin-top: 16px !important;
  opacity: .6 !important;
}

.atelier-about .atelier-team-block {
  width: min(100%, 1280px) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1.18fr) minmax(380px, .72fr) !important;
  gap: clamp(44px, 6vw, 88px) !important;
  align-items: center !important;
}

.atelier-about .atelier-video-box {
  width: 100% !important;
  max-width: 820px !important;
  justify-self: end !important;
  aspect-ratio: 3 / 2 !important;
  min-height: 0 !important;
  height: auto !important;
  border-radius: 24px !important;
  overflow: hidden !important;
  border: 1px solid rgba(143, 77, 69, .15) !important;
  box-shadow: 0 30px 70px rgba(67, 45, 38, .13) !important;
}

.atelier-about .atelier-process-video {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.atelier-about .atelier-process-copy {
  width: 100% !important;
  max-width: 430px !important;
  justify-self: start !important;
  padding: clamp(30px, 3vw, 42px) clamp(28px, 3vw, 40px) !important;
  border-radius: 30px !important;
  background: linear-gradient(145deg, rgba(255, 251, 246, .97), rgba(250, 244, 238, .9)) !important;
  border: 1px solid rgba(143, 77, 69, .18) !important;
  box-shadow: 0 28px 64px rgba(67, 45, 38, .10) !important;
}

.atelier-about .atelier-process-copy::before {
  width: 34px !important;
  margin-bottom: 18px !important;
}

.atelier-copy-kicker {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  margin-bottom: 14px !important;
  font-size: 10.5px !important;
  letter-spacing: .28em !important;
  line-height: 1 !important;
}

.atelier-copy-kicker::after {
  content: "" !important;
  display: block !important;
  width: 42px !important;
  height: 1px !important;
  background: rgba(122, 38, 53, .45) !important;
}

.atelier-about .atelier-process-copy .atelier-team-title {
  max-width: 350px !important;
  margin: 0 0 18px !important;
  font-size: clamp(35px, 3vw, 48px) !important;
  line-height: .98 !important;
  letter-spacing: -.032em !important;
}

.atelier-team-intro {
  max-width: 360px !important;
  margin-bottom: 24px !important;
  font-size: 15px !important;
  line-height: 1.72 !important;
  color: #6d625e !important;
}

.atelier-process-points article {
  grid-template-columns: 40px 1fr !important;
  gap: 16px !important;
  padding: 17px 0 !important;
  border-top: 1px solid rgba(143, 77, 69, .13) !important;
}

.atelier-process-points span {
  width: 34px !important;
  height: 34px !important;
  font-size: 10px !important;
}

.atelier-process-points h3 {
  margin-bottom: 5px !important;
  font-size: 17px !important;
  line-height: 1.1 !important;
}

.atelier-process-points p {
  max-width: 320px !important;
  font-size: 13.7px !important;
  line-height: 1.58 !important;
}

@media (max-width: 1100px) {
  .atelier-about .atelier-team-block {
    grid-template-columns: 1fr !important;
    gap: 34px !important;
    max-width: 820px !important;
  }

  .atelier-about .atelier-video-box,
  .atelier-about .atelier-process-copy {
    justify-self: center !important;
    max-width: 820px !important;
  }

  .atelier-about .atelier-process-copy .atelier-team-title,
  .atelier-team-intro,
  .atelier-process-points p {
    max-width: 100% !important;
  }
}

@media (max-width: 560px) {
  .atelier-about {
    padding-top: 62px !important;
    padding-bottom: 62px !important;
  }

  .atelier-about .atelier-main-title {
    font-size: 31px !important;
    line-height: 1.04 !important;
    margin-bottom: 30px !important;
  }

  .atelier-about .atelier-video-box {
    border-radius: 18px !important;
    box-shadow: 0 18px 40px rgba(67, 45, 38, .13) !important;
  }

  .atelier-about .atelier-process-copy {
    padding: 26px 20px !important;
    border-radius: 24px !important;
  }

  .atelier-copy-kicker {
    font-size: 9.5px !important;
    letter-spacing: .24em !important;
  }

  .atelier-about .atelier-process-copy .atelier-team-title {
    font-size: 32px !important;
    line-height: 1 !important;
  }

  .atelier-team-intro {
    font-size: 14.2px !important;
    line-height: 1.65 !important;
    margin-bottom: 20px !important;
  }

  .atelier-process-points article {
    grid-template-columns: 34px 1fr !important;
    gap: 12px !important;
    padding: 15px 0 !important;
  }

  .atelier-process-points span {
    width: 30px !important;
    height: 30px !important;
  }

  .atelier-process-points h3 {
    font-size: 16px !important;
  }

  .atelier-process-points p {
    font-size: 13.2px !important;
    line-height: 1.55 !important;
  }
}


/* ========================================================= */
/* ATELIER LAOS - PROCESO ARTESANAL FINAL PREMIUM OVERRIDES  */
/* ========================================================= */

.atelier-process {
  width: 100%;
  padding: clamp(78px, 7vw, 118px) clamp(20px, 5vw, 78px) !important;
  background:
    radial-gradient(circle at 18% 18%, rgba(216, 180, 140, 0.13), transparent 34%),
    linear-gradient(135deg, #fbf5ee 0%, #f6ece3 100%);
  color: #201817;
}

.atelier-process__inner {
  width: min(1220px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.22fr) minmax(360px, 0.78fr);
  gap: clamp(38px, 5.5vw, 78px);
  align-items: center;
}

.atelier-process__media {
  width: 100%;
  aspect-ratio: 3 / 2;
  border-radius: 26px;
  overflow: hidden;
  background: #100b0b;
  box-shadow: 0 28px 70px rgba(47, 28, 22, 0.16);
}

.atelier-process__video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border: 0;
  outline: none;
}

.atelier-process__video::-webkit-media-controls,
.atelier-process__video::-webkit-media-controls-enclosure,
.atelier-process__video::-webkit-media-controls-panel,
.atelier-process__video::-webkit-media-controls-play-button,
.atelier-process__video::-webkit-media-controls-timeline,
.atelier-process__video::-webkit-media-controls-current-time-display,
.atelier-process__video::-webkit-media-controls-time-remaining-display,
.atelier-process__video::-webkit-media-controls-mute-button,
.atelier-process__video::-webkit-media-controls-volume-slider,
.atelier-process__video::-webkit-media-controls-fullscreen-button,
.atelier-process__video::-webkit-media-controls-toggle-closed-captions-button {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
}

.atelier-process__content {
  position: relative;
  padding: clamp(32px, 3.7vw, 52px);
  border: 1px solid rgba(111, 40, 55, 0.16);
  border-radius: 30px;
  background: rgba(255, 250, 245, 0.78);
  backdrop-filter: blur(12px);
  box-shadow: 0 24px 64px rgba(68, 38, 28, 0.08);
}

.atelier-process__eyebrow {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0 0 18px 0;
  padding: 0;
}

.atelier-process__eyebrow span {
  width: 38px;
  height: 1px;
  display: block;
  background: #8a2f45;
  flex: 0 0 auto;
}

.atelier-process__eyebrow p {
  margin: 0;
  padding: 0;
  font-family: "Manrope", sans-serif;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.28em;
  color: #7a2438;
}

.atelier-process__content h2 {
  margin: 0;
  padding: 0;
  max-width: 520px;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(44px, 4.6vw, 66px);
  font-weight: 600;
  line-height: 0.94;
  letter-spacing: -0.045em;
  color: #1f1716;
}

.atelier-process__intro {
  margin: 24px 0 32px 0;
  max-width: 520px;
  font-family: "Manrope", sans-serif;
  font-size: 15.5px;
  line-height: 1.8;
  color: rgba(32, 24, 23, 0.68);
}

.atelier-process__steps {
  display: grid;
  gap: 24px;
  margin: 0 0 32px 0;
}

.atelier-process__step {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 18px;
  align-items: flex-start;
  border: 0 !important;
  padding: 0 !important;
}

.atelier-process__step > span {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f0dfd3;
  color: #7a2438;
  font-family: "Cormorant Garamond", serif;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.atelier-process__step h3 {
  margin: 2px 0 7px 0;
  font-family: "Cormorant Garamond", serif;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.1;
  color: #241817;
}

.atelier-process__step p {
  margin: 0;
  font-family: "Manrope", sans-serif;
  font-size: 14.2px;
  line-height: 1.72;
  color: rgba(32, 24, 23, 0.64);
}

.atelier-process__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  padding: 13px 24px;
  border: 1px solid rgba(122, 36, 56, 0.28);
  border-radius: 999px;
  background: transparent;
  font-family: "Manrope", sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  color: #7a2438;
  transition: all 0.28s ease;
}

.atelier-process__cta:hover {
  background: #7a2438;
  color: #fff8ef;
  border-color: #7a2438;
  transform: translateY(-2px);
}

@media (max-width: 980px) {
  .atelier-process__inner {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .atelier-process__content {
    max-width: 760px;
    margin: 0 auto;
  }
}

@media (max-width: 620px) {
  .atelier-process {
    padding: 72px 18px !important;
  }

  .atelier-process__media {
    border-radius: 22px;
  }

  .atelier-process__content {
    padding: 30px 24px;
    border-radius: 24px;
  }

  .atelier-process__content h2 {
    font-size: 42px;
    line-height: 0.96;
  }

  .atelier-process__intro {
    font-size: 14.5px;
    line-height: 1.75;
    margin-bottom: 28px;
  }

  .atelier-process__step {
    grid-template-columns: 44px 1fr;
    gap: 16px;
  }

  .atelier-process__step > span {
    width: 44px;
    height: 44px;
    font-size: 18px;
  }

  .atelier-process__step h3 {
    font-size: 20px;
  }

  .atelier-process__step p {
    font-size: 13.5px;
  }

  .atelier-process__cta {
    width: 100%;
  }
}

/* ========================================================= */
/* ATELIER LAOS - AJUSTE COMPACTO A ALTURA DEL VIDEO         */
/* ========================================================= */

@media (min-width: 981px) {
  .atelier-process {
    padding-top: clamp(70px, 6vw, 96px) !important;
    padding-bottom: clamp(70px, 6vw, 96px) !important;
  }

  .atelier-process__inner {
    width: min(1120px, 100%);
    grid-template-columns: minmax(0, 1.18fr) minmax(300px, 360px);
    gap: clamp(42px, 5vw, 64px);
    align-items: center;
  }

  .atelier-process__media {
    max-width: 630px;
    justify-self: end;
    border-radius: 22px;
  }

  .atelier-process__content {
    max-width: 360px;
    min-height: auto;
    justify-self: start;
    padding: 30px 34px 32px;
    border-radius: 26px;
  }

  .atelier-process__eyebrow {
    gap: 10px;
    margin-bottom: 14px;
  }

  .atelier-process__eyebrow span {
    width: 30px;
  }

  .atelier-process__eyebrow p {
    font-size: 10.5px;
    letter-spacing: 0.24em;
  }

  .atelier-process__content h2 {
    max-width: 300px;
    font-size: clamp(38px, 3.15vw, 46px);
    line-height: 0.96;
    letter-spacing: -0.04em;
  }

  .atelier-process__intro {
    max-width: 295px;
    margin: 16px 0 22px;
    font-size: 13.2px;
    line-height: 1.62;
  }

  .atelier-process__steps {
    gap: 15px;
    margin-bottom: 24px;
  }

  .atelier-process__step {
    grid-template-columns: 40px 1fr;
    gap: 14px;
  }

  .atelier-process__step > span {
    width: 40px;
    height: 40px;
    font-size: 16px;
  }

  .atelier-process__step h3 {
    margin: 0 0 4px;
    font-size: 18.5px;
    line-height: 1.05;
  }

  .atelier-process__step p {
    max-width: 250px;
    font-size: 12.5px;
    line-height: 1.52;
  }

  .atelier-process__cta {
    padding: 10px 18px;
    font-size: 11.5px;
    letter-spacing: 0.075em;
  }
}

@media (min-width: 981px) and (max-width: 1180px) {
  .atelier-process__inner {
    width: min(1040px, 100%);
    grid-template-columns: minmax(0, 1.12fr) minmax(300px, 340px);
    gap: 40px;
  }

  .atelier-process__content {
    max-width: 340px;
    padding: 28px 30px 30px;
  }

  .atelier-process__content h2 {
    font-size: 40px;
  }
}

/* =========================================================
   OPINIONES LAOS - FECHAS + TARJETAS BOUTIQUE
   ========================================================= */

.opiniones-premium {
  --opinion-card: #fff7ef;
  --opinion-card-deep: #f8ebe2;
  --opinion-chip: rgba(122, 36, 58, .075);
  --opinion-chip-border: rgba(122, 36, 58, .14);
}

.opiniones-premium .testimonio,
.opiniones-premium .opinion-card {
  position: relative !important;
  overflow: hidden !important;
  padding: 24px 28px 23px !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, .82), transparent 32%),
    linear-gradient(135deg, #fff8ef 0%, #fbf0e8 100%) !important;
  border: 1px solid rgba(122, 36, 58, .16) !important;
  box-shadow: 0 22px 52px rgba(67, 43, 35, .075) !important;
}

.opiniones-premium .testimonio:hover,
.opiniones-premium .opinion-card:hover {
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, .9), transparent 34%),
    linear-gradient(135deg, #fff6ec 0%, #f8e8df 100%) !important;
  border-color: rgba(122, 36, 58, .24) !important;
}

.opinion-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 13px;
}

.opinion-experience-chip {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 7px 11px;
  border-radius: 999px;
  background: var(--opinion-chip);
  border: 1px solid var(--opinion-chip-border);
  color: var(--opinion-burgundy);
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 9.8px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: .18em;
  text-transform: uppercase;
  white-space: nowrap;
}

.opinion-card-date {
  color: rgba(61, 47, 42, .52);
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 11.2px;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

.opiniones-premium .stars {
  margin-bottom: 13px !important;
}

.opiniones-premium .testimonio p,
.opiniones-premium .opinion-card p {
  margin-bottom: 0 !important;
}

.opinion-author {
  display: flex !important;
  align-items: center !important;
  gap: 13px !important;
  margin-top: 19px !important;
}

.opinion-author-copy {
  display: grid;
  gap: 2px;
}

.opinion-author-copy h4,
.opiniones-premium .testimonio .opinion-author-copy h4,
.opiniones-premium .opinion-card .opinion-author-copy h4 {
  margin: 0 !important;
  font-family: 'Manrope', Arial, sans-serif !important;
  font-size: 13.4px !important;
  font-weight: 800 !important;
  color: var(--opinion-text) !important;
  line-height: 1.2 !important;
}

.opinion-author-copy span {
  color: rgba(61, 47, 42, .48);
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 11.4px;
  font-weight: 600;
  line-height: 1.25;
}

.opiniones-premium #opinionForm .opinion-field-input {
  background: rgba(255, 248, 239, .62) !important;
  border-radius: 10px 10px 0 0 !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
}

.opiniones-premium #opinionForm .opinion-field-input:focus {
  background: rgba(255, 250, 245, .92) !important;
}

@media (max-width: 560px) {
  .opinion-card-head {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }

  .opinion-card-date {
    font-size: 11px;
  }

  .opinion-experience-chip {
    font-size: 9.4px;
    letter-spacing: .16em;
  }
}

/* =========================================================
   CONTACTO COMPACTO PREMIUM - INSTAGRAM PRINCIPAL
   ========================================================= */

.contact-footer-section {
  padding: clamp(62px, 6.2vw, 92px) clamp(18px, 5vw, 64px) 0 !important;
}

.contact-footer-shell {
  width: min(1220px, 100%) !important;
}

.contact-layout {
  grid-template-columns: minmax(0, .96fr) minmax(320px, .72fr) !important;
  gap: clamp(26px, 4.2vw, 58px) !important;
  align-items: center !important;
}

.contact-card--compact {
  padding: clamp(28px, 3.1vw, 44px) !important;
  border-radius: 24px !important;
}

.contact-card--compact::before {
  left: clamp(28px, 3.1vw, 44px) !important;
  width: 54px !important;
}

.contact-card--compact .contact-kicker {
  margin-bottom: 12px !important;
  font-size: 10px !important;
  letter-spacing: .24em !important;
}

.contact-card--compact h2 {
  max-width: 500px !important;
  margin-bottom: 13px !important;
  font-size: clamp(38px, 4.2vw, 62px) !important;
  line-height: .94 !important;
}

.contact-card--compact .contact-intro {
  max-width: 530px !important;
  margin-bottom: 18px !important;
  font-size: 13.5px !important;
  line-height: 1.65 !important;
}

.contact-actions--compact {
  gap: 10px !important;
  margin-bottom: 18px !important;
}

.contact-actions--compact .contact-primary-action,
.contact-actions--compact .contact-secondary-action {
  min-height: 38px !important;
  padding: 10px 18px !important;
  font-size: 10px !important;
  letter-spacing: .07em !important;
}

.contact-form--compact {
  gap: 18px 22px !important;
}

.contact-form--compact label span {
  margin-bottom: 6px !important;
  font-size: 9.5px !important;
  letter-spacing: .15em !important;
}

.contact-form--compact input,
.contact-form--compact textarea {
  padding-bottom: 10px !important;
  font-size: 13.5px !important;
}

.contact-form--compact textarea {
  min-height: 78px !important;
}

.contact-form--compact .contact-submit {
  min-width: 158px !important;
  margin-top: 0 !important;
  padding: 12px 22px !important;
  font-size: 10.5px !important;
}

.contact-visual--compact {
  min-height: 545px !important;
  border-radius: 24px !important;
}

.contact-visual--compact .contact-visual-main {
  min-height: 545px !important;
}

.contact-visual--compact .contact-visual-caption {
  left: 20px !important;
  right: 20px !important;
  bottom: 20px !important;
  padding: 20px 20px 18px !important;
  border-radius: 18px !important;
}

.contact-visual--compact .contact-visual-caption span {
  margin-bottom: 7px !important;
  font-size: 9.5px !important;
  letter-spacing: .18em !important;
}

.contact-visual--compact .contact-visual-caption strong {
  max-width: 330px !important;
  font-size: clamp(26px, 2.45vw, 36px) !important;
  line-height: .98 !important;
}

.contact-visual--compact .contact-visual-tags {
  top: 18px !important;
  left: 18px !important;
  right: 18px !important;
  gap: 8px !important;
}

.contact-visual--compact .contact-visual-tags span {
  min-height: 29px !important;
  padding: 7px 10px !important;
  font-size: 8.8px !important;
  letter-spacing: .08em !important;
}

.contact-footer-section .integrated-footer {
  padding-top: 46px !important;
  padding-bottom: 22px !important;
}

.contact-footer-section .footer-divider {
  margin-bottom: 36px !important;
}

.contact-footer-section .footer-grid {
  gap: clamp(26px, 4vw, 52px) !important;
}

.contact-footer-section .footer-brand h2 {
  font-size: clamp(30px, 2.8vw, 42px) !important;
}

.contact-footer-section .footer-brand p,
.contact-footer-section .footer-column a {
  font-size: 12.5px !important;
}

.contact-footer-section .footer-copy {
  margin-top: 34px !important;
  padding-top: 20px !important;
}

@media (max-width: 1180px) {
  .contact-layout {
    grid-template-columns: 1fr !important;
  }

  .contact-visual--compact,
  .contact-visual--compact .contact-visual-main {
    min-height: 470px !important;
  }
}

@media (max-width: 820px) {
  .contact-footer-section {
    padding: 70px 18px 0 !important;
  }

  .contact-card--compact {
    padding: 30px 22px !important;
  }

  .contact-card--compact::before {
    left: 22px !important;
  }

  .contact-card--compact h2 {
    font-size: 38px !important;
  }

  .contact-card--compact .contact-intro {
    font-size: 13.5px !important;
  }

  .contact-actions--compact {
    flex-direction: column;
    align-items: stretch;
  }

  .contact-actions--compact .contact-primary-action,
  .contact-actions--compact .contact-secondary-action {
    width: 100%;
  }

  .contact-form--compact {
    grid-template-columns: 1fr !important;
  }

  .contact-form--compact .contact-submit {
    width: 100%;
  }

  .contact-visual--compact,
  .contact-visual--compact .contact-visual-main {
    min-height: 420px !important;
  }

  .contact-footer-section .integrated-footer {
    padding-top: 40px !important;
  }
}

@media (max-width: 460px) {
  .contact-card--compact h2 {
    font-size: 34px !important;
  }

  .contact-visual--compact,
  .contact-visual--compact .contact-visual-main {
    min-height: 385px !important;
  }

  .contact-visual--compact .contact-visual-caption strong {
    font-size: 24px !important;
  }
}

/* =========================================================
   AJUSTES FINALES CONTACTO: SIN DATOS RÁPIDOS + IMAGEN COMPACTA
   ========================================================= */

.contact-actions--compact {
  margin-bottom: 0 !important;
}

.contact-form--compact {
  margin-top: 22px !important;
  padding-top: 22px !important;
  border-top: 1px solid rgba(42, 23, 25, .12) !important;
}

.contact-layout {
  grid-template-columns: minmax(0, .96fr) minmax(280px, .58fr) !important;
  gap: clamp(24px, 3.8vw, 52px) !important;
}

.contact-visual--compact {
  width: min(395px, 100%) !important;
  min-height: 500px !important;
  justify-self: center !important;
}

.contact-visual--compact .contact-visual-main {
  min-height: 500px !important;
}

.contact-visual--compact .contact-visual-caption {
  left: 18px !important;
  right: 18px !important;
  bottom: 18px !important;
  padding: 18px 18px 16px !important;
}

.contact-visual--compact .contact-visual-caption strong {
  max-width: 300px !important;
  font-size: clamp(24px, 2.15vw, 32px) !important;
}

.contact-visual--compact .contact-visual-tags {
  top: 16px !important;
  left: 16px !important;
  right: 16px !important;
}

.contact-visual--compact .contact-visual-tags span {
  min-height: 27px !important;
  padding: 6px 9px !important;
  font-size: 8px !important;
}

@media (max-width: 1180px) {
  .contact-layout {
    grid-template-columns: 1fr !important;
  }

  .contact-visual--compact,
  .contact-visual--compact .contact-visual-main {
    min-height: 430px !important;
  }
}

@media (max-width: 820px) {
  .contact-form--compact {
    margin-top: 18px !important;
    padding-top: 18px !important;
  }

  .contact-visual--compact {
    width: 100% !important;
  }

  .contact-visual--compact,
  .contact-visual--compact .contact-visual-main {
    min-height: 385px !important;
  }
}

@media (max-width: 460px) {
  .contact-visual--compact,
  .contact-visual--compact .contact-visual-main {
    min-height: 340px !important;
  }
}


/* =========================================================
   AJUSTE FINAL CONTACTO: BOTONES SIN SUPERPOSICIÓN + FOOTER LIMPIO
   ========================================================= */

.contact-actions--compact {
  position: relative !important;
  z-index: 3 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 12px !important;
  margin-bottom: 24px !important;
}

.contact-actions--compact .contact-primary-action,
.contact-actions--compact .contact-secondary-action {
  position: relative !important;
  z-index: 4 !important;
  flex: 0 0 auto !important;
  width: auto !important;
  white-space: nowrap !important;
}

.contact-form--compact {
  clear: both !important;
  margin-top: 0 !important;
  padding-top: 24px !important;
  border-top: 1px solid rgba(42, 23, 25, .12) !important;
}

.contact-footer-section .footer-brand p {
  display: none !important;
}

.contact-footer-section .footer-brand {
  display: flex !important;
  align-items: flex-start !important;
}

.contact-footer-section .footer-brand h2 {
  margin-bottom: 0 !important;
}

@media (max-width: 820px) {
  .contact-actions--compact {
    gap: 10px !important;
    margin-bottom: 22px !important;
  }

  .contact-actions--compact .contact-primary-action,
  .contact-actions--compact .contact-secondary-action {
    width: 100% !important;
    flex: 1 1 100% !important;
  }

  .contact-form--compact {
    padding-top: 22px !important;
  }
}

@media (min-width: 821px) and (max-width: 1080px) {
  .contact-actions--compact .contact-primary-action,
  .contact-actions--compact .contact-secondary-action {
    min-width: 0 !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

/* =========================================================
   CONTACTO FINAL: SIN FOTO + FOOTER MINIMAL BOUTIQUE
   ========================================================= */

.contact-footer-section {
  padding-top: clamp(58px, 5.6vw, 86px) !important;
}

.contact-footer-shell {
  width: min(1180px, 100%) !important;
}

.contact-layout {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  grid-template-columns: none !important;
  gap: 0 !important;
}

.contact-card--compact {
  width: min(760px, 100%) !important;
  margin: 0 auto !important;
  padding: clamp(34px, 4vw, 58px) !important;
  border-radius: 28px !important;
  box-shadow: 0 26px 80px rgba(0, 0, 0, .18), 0 14px 38px rgba(118, 48, 58, .10) !important;
}

.contact-card--compact::before {
  left: clamp(34px, 4vw, 58px) !important;
}

.contact-card--compact h2 {
  max-width: 620px !important;
  font-size: clamp(44px, 4.9vw, 70px) !important;
  line-height: .92 !important;
}

.contact-card--compact .contact-intro {
  max-width: 610px !important;
  margin-bottom: 24px !important;
}

.contact-actions--compact {
  margin-bottom: 26px !important;
}

.contact-form--compact {
  padding-top: 26px !important;
  gap: 20px 26px !important;
}

.contact-form--compact textarea {
  min-height: 92px !important;
}

.contact-visual,
.contact-visual--compact {
  display: none !important;
}

.contact-footer-section .integrated-footer {
  width: min(980px, 100%) !important;
  margin: 0 auto !important;
  padding-top: 42px !important;
}

.contact-footer-section .footer-divider {
  margin-bottom: 30px !important;
  opacity: .55 !important;
}

.contact-footer-section .footer-grid,
.contact-footer-section .footer-grid--minimal {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 28px !important;
}

.contact-footer-section .footer-brand,
.contact-footer-section .footer-brand--minimal {
  display: block !important;
}

.contact-footer-section .footer-brand h2 {
  margin: 0 !important;
  font-size: clamp(30px, 3vw, 42px) !important;
  line-height: 1 !important;
}

.contact-footer-section .footer-column--social {
  align-items: flex-end !important;
  text-align: right !important;
}

.contact-footer-section .footer-column--social h3 {
  margin-bottom: 14px !important;
}

.contact-footer-section .footer-socials {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  gap: 10px !important;
}

.contact-footer-section .footer-socials a {
  min-width: 86px !important;
  text-align: center !important;
}

.contact-footer-section .footer-copy {
  margin-top: 30px !important;
  padding-top: 18px !important;
}

@media (max-width: 820px) {
  .contact-footer-section {
    padding-top: 62px !important;
  }

  .contact-card--compact {
    padding: 32px 22px !important;
    border-radius: 24px !important;
  }

  .contact-card--compact::before {
    left: 22px !important;
  }

  .contact-card--compact h2 {
    font-size: 40px !important;
  }

  .contact-footer-section .footer-grid,
  .contact-footer-section .footer-grid--minimal {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    gap: 22px !important;
  }

  .contact-footer-section .footer-column--social {
    align-items: center !important;
    text-align: center !important;
  }

  .contact-footer-section .footer-socials {
    justify-content: center !important;
  }
}

@media (max-width: 460px) {
  .contact-card--compact h2 {
    font-size: 34px !important;
  }

  .contact-actions--compact .contact-primary-action,
  .contact-actions--compact .contact-secondary-action,
  .contact-form--compact .contact-submit {
    width: 100% !important;
  }
}

/* =========================================================
   LAOS STUDIO — PULIDO SENIOR 10/10
   Capa final conservadora: no cambia estructura ni lógica.
   ========================================================= */

:root {
  --laos-ink: #1f1714;
  --laos-ink-soft: #4f4038;
  --laos-muted: #837166;
  --laos-cream: #f8f3ee;
  --laos-cream-2: #fbf7f1;
  --laos-ivory: #fffaf4;
  --laos-sand: #e8d8c8;
  --laos-sand-2: #d9bea4;
  --laos-gold: #c49a6c;
  --laos-gold-dark: #9b744e;
  --laos-wine: #6b2032;
  --laos-line: rgba(64, 43, 34, .12);
  --laos-shadow-soft: 0 18px 45px rgba(52, 35, 27, .08);
  --laos-shadow-hover: 0 26px 70px rgba(52, 35, 27, .13);
  --laos-radius-xs: 12px;
  --laos-radius-sm: 18px;
  --laos-radius-md: 24px;
  --laos-radius-lg: 32px;
  --laos-serif: 'Cormorant Garamond', Georgia, serif;
  --laos-sans: 'Manrope', Arial, sans-serif;
}

html {
  background: var(--laos-cream) !important;
}

body {
  font-family: var(--laos-sans) !important;
  color: var(--laos-ink) !important;
  background:
    radial-gradient(circle at top left, rgba(255, 250, 244, .92), transparent 34vw),
    linear-gradient(180deg, #fbf7f1 0%, #f8f3ee 44%, #f4ebe2 100%) !important;
  letter-spacing: -.01em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3,
.brand h1,
.logo-text strong,
.section-title h2,
.hero h2,
.premium-content h2,
.collection-header h2,
.collection-title-row h3,
.quick-view-summary h2,
.lookbook-desktop-info h3,
.lookbook-swipe-copy h3,
.opiniones-heading-block h2,
.contact-card--compact h2,
.footer-brand h2,
.admin-box h2,
.admin-dashboard h2,
.stat-card h3 {
  font-family: var(--laos-serif) !important;
  font-weight: 600 !important;
  letter-spacing: -.025em !important;
}

p, a, button, input, select, textarea, label, span, small, li,
.collection-card-description,
.collection-card-subtitle,
.quick-view-content,
.contact-form,
.admin-form,
.cart-panel {
  font-family: var(--laos-sans) !important;
}

::selection {
  background: rgba(196, 154, 108, .26) !important;
  color: var(--laos-ink) !important;
}

img {
  image-rendering: auto;
}

section {
  padding-top: clamp(72px, 7vw, 112px) !important;
  padding-bottom: clamp(72px, 7vw, 112px) !important;
}

.section-title,
.collection-header,
.lookbook-simple-heading,
.opiniones-heading-block {
  margin-bottom: clamp(30px, 4vw, 56px) !important;
}

.section-title span,
.section-kicker,
.tag,
.collection-card-category,
.quick-view-kicker,
.opiniones-kicker,
.opiniones-form-kicker,
.contact-kicker,
.cart-label,
.premium-label,
.lookbook-desktop-kicker {
  color: var(--laos-gold-dark) !important;
  font-family: var(--laos-sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .22em !important;
  text-transform: uppercase !important;
}

.section-title h2,
.collection-header h2,
.opiniones-heading-block h2,
.contact-card--compact h2 {
  color: var(--laos-ink) !important;
}

.section-subtitle,
.collection-header p,
.opiniones-heading-block p,
.contact-intro,
.quick-view-summary p {
  color: var(--laos-muted) !important;
  line-height: 1.78 !important;
}

/* Header / navegación */
.header {
  height: 84px !important;
  padding: 0 clamp(18px, 3.5vw, 48px) !important;
  background: rgba(22, 17, 15, .74) !important;
  border-bottom: 1px solid rgba(255, 250, 244, .10) !important;
  box-shadow: 0 12px 42px rgba(0, 0, 0, .16) !important;
  backdrop-filter: blur(18px) saturate(135%) !important;
}

.header.scrolled {
  background: rgba(17, 14, 13, .86) !important;
  box-shadow: 0 16px 54px rgba(0, 0, 0, .22) !important;
}

.brand-center {
  gap: 10px !important;
}

.logo {
  width: 50px !important;
  height: 50px !important;
  object-fit: contain !important;
}

.logo-text strong,
.brand h1 {
  color: #fffaf4 !important;
  font-size: clamp(22px, 2vw, 30px) !important;
  line-height: .95 !important;
}

.logo-text span {
  color: rgba(255, 250, 244, .68) !important;
  font-size: 10px !important;
  letter-spacing: .24em !important;
}

.menu-btn {
  background: rgba(255, 250, 244, .08) !important;
  border: 1px solid rgba(255, 250, 244, .18) !important;
  color: #fffaf4 !important;
  box-shadow: none !important;
}

.menu-line {
  background: #fffaf4 !important;
}

.nav {
  background:
    linear-gradient(180deg, rgba(26, 20, 18, .98), rgba(12, 10, 9, .98)) !important;
  border-right: 1px solid rgba(255, 250, 244, .10) !important;
  box-shadow: 18px 0 55px rgba(0, 0, 0, .28) !important;
}

.nav a {
  color: rgba(255, 250, 244, .82) !important;
  font-weight: 600 !important;
  letter-spacing: .05em !important;
}

.nav a:hover,
.nav a:focus-visible {
  color: var(--laos-sand-2) !important;
}

.header-cart,
.cart-btn,
.floating-cart {
  background: rgba(216, 180, 140, .95) !important;
  color: #171210 !important;
  border: 1px solid rgba(255, 250, 244, .22) !important;
  box-shadow: 0 12px 28px rgba(0, 0, 0, .18) !important;
}

/* Botones / formularios */
.btn,
.collection-detail-btn,
.collection-add-btn,
.lookbook-cart-btn,
.lookbook-consult-btn,
.lookbook-see-products,
.quick-view-add,
.quick-view-whatsapp,
.contact-primary-action,
.contact-secondary-action,
.contact-submit,
.checkout-btn,
.opinion-btn,
.admin-tab,
.admin-actions button,
.collection-load-more-btn,
.signature-btn {
  border-radius: 999px !important;
  font-family: var(--laos-sans) !important;
  font-weight: 700 !important;
  letter-spacing: .045em !important;
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease, color .22s ease, border-color .22s ease, opacity .22s ease !important;
}

.btn,
.collection-add-btn,
.lookbook-cart-btn,
.quick-view-add,
.contact-primary-action,
.contact-submit,
.checkout-btn,
.opinion-btn,
.collection-load-more-btn {
  background: #1f1714 !important;
  color: #fffaf4 !important;
  border: 1px solid #1f1714 !important;
  box-shadow: 0 13px 30px rgba(31, 23, 20, .16) !important;
}

.btn:hover,
.collection-add-btn:hover,
.lookbook-cart-btn:hover,
.quick-view-add:hover,
.contact-primary-action:hover,
.contact-submit:hover,
.checkout-btn:hover,
.opinion-btn:hover,
.collection-load-more-btn:hover {
  background: var(--laos-gold) !important;
  border-color: var(--laos-gold) !important;
  color: #171210 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 17px 38px rgba(125, 87, 56, .21) !important;
}

.btn-outline,
.collection-detail-btn,
.quick-view-whatsapp,
.contact-secondary-action,
.lookbook-see-products {
  background: rgba(255, 250, 244, .58) !important;
  color: var(--laos-ink) !important;
  border: 1px solid rgba(64, 43, 34, .16) !important;
  box-shadow: none !important;
}

.btn-outline:hover,
.collection-detail-btn:hover,
.quick-view-whatsapp:hover,
.contact-secondary-action:hover,
.lookbook-see-products:hover {
  background: #fffaf4 !important;
  border-color: rgba(196, 154, 108, .55) !important;
  color: var(--laos-ink) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 14px 32px rgba(64, 43, 34, .10) !important;
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid rgba(196, 154, 108, .72) !important;
  outline-offset: 3px !important;
}

input,
select,
textarea,
.filters input,
.filters select,
.collection-search-field input,
.collection-select-wrap select,
.formulario input,
.formulario textarea,
.opinion-field-input,
.admin-box input,
.admin-form input,
.admin-form select,
.admin-form textarea {
  background: rgba(255, 250, 244, .84) !important;
  border: 1px solid rgba(64, 43, 34, .13) !important;
  border-radius: 18px !important;
  color: var(--laos-ink) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .55) !important;
}

input::placeholder,
textarea::placeholder {
  color: rgba(79, 64, 56, .52) !important;
}

/* Hero */
.hero,
.hero-premium {
  min-height: 100svh !important;
  padding-left: clamp(22px, 5vw, 76px) !important;
  padding-right: clamp(22px, 5vw, 76px) !important;
}

.hero-overlay {
  background:
    linear-gradient(90deg, rgba(16, 12, 11, .68) 0%, rgba(16, 12, 11, .38) 48%, rgba(16, 12, 11, .18) 100%),
    radial-gradient(circle at 16% 44%, rgba(196, 154, 108, .20), transparent 34%) !important;
}

.hero-content,
.hero-premium-content {
  max-width: 780px !important;
}

.hero h2,
.hero-premium-content h2 {
  font-size: clamp(48px, 7vw, 92px) !important;
  line-height: .94 !important;
  margin: 18px 0 20px !important;
  color: #fffaf4 !important;
  text-wrap: balance;
}

.hero p,
.hero-premium-content p {
  max-width: 640px !important;
  color: rgba(255, 250, 244, .84) !important;
  font-size: clamp(16px, 1.45vw, 20px) !important;
  line-height: 1.74 !important;
}

.hero-buttons {
  gap: 12px !important;
  margin-top: 26px !important;
}

.hero-buttons .btn:first-child {
  background: #fffaf4 !important;
  border-color: #fffaf4 !important;
  color: #171210 !important;
}

.hero-buttons .btn:nth-child(2) {
  background: rgba(255, 250, 244, .08) !important;
  border: 1px solid rgba(255, 250, 244, .40) !important;
  color: #fffaf4 !important;
  box-shadow: none !important;
}

/* Colección */
.collection-boutique {
  background:
    linear-gradient(180deg, rgba(255, 250, 244, .70), rgba(248, 243, 238, .95)) !important;
}

.collection-shell {
  width: min(1240px, 100%) !important;
  margin-inline: auto !important;
}

.collection-header-minimal {
  max-width: 760px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}

.collection-toolbar {
  background: rgba(255, 250, 244, .78) !important;
  border: 1px solid rgba(64, 43, 34, .10) !important;
  border-radius: 28px !important;
  padding: clamp(14px, 2.2vw, 24px) !important;
  box-shadow: var(--laos-shadow-soft) !important;
  backdrop-filter: blur(16px) !important;
}

.collection-mobile-action,
.collection-filter {
  border-radius: 999px !important;
  border: 1px solid rgba(64, 43, 34, .12) !important;
  background: rgba(255, 250, 244, .78) !important;
  color: var(--laos-ink-soft) !important;
  font-weight: 700 !important;
}

.collection-mobile-action.is-active,
.collection-filter.active,
.collection-filter:hover {
  background: #1f1714 !important;
  color: #fffaf4 !important;
  border-color: #1f1714 !important;
}

.collection-results-meta {
  color: var(--laos-muted) !important;
  font-size: 13px !important;
  letter-spacing: .04em !important;
}

.productos.collection-grid,
.collection-grid {
  gap: clamp(22px, 2.4vw, 34px) !important;
  align-items: stretch !important;
}

.collection-card {
  background: rgba(255, 250, 244, .92) !important;
  border: 1px solid rgba(64, 43, 34, .10) !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  box-shadow: var(--laos-shadow-soft) !important;
  transform: translateY(0) !important;
}

.collection-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: var(--laos-shadow-hover) !important;
  border-color: rgba(196, 154, 108, .24) !important;
}

.collection-card-media {
  background: linear-gradient(180deg, #f3e7da, #fbf7f1) !important;
  border-radius: 0 !important;
  overflow: hidden !important;
}

.collection-card-media img,
.card-img {
  height: clamp(380px, 34vw, 530px) !important;
  width: 100% !important;
  object-fit: cover !important;
  object-position: center top !important;
  transform: scale(1) !important;
  transition: transform .55s ease, filter .35s ease !important;
}

.collection-card:hover .collection-card-media img,
.card:hover .card-img {
  transform: scale(1.025) !important;
  filter: saturate(.98) contrast(1.02) !important;
}

.collection-badge {
  top: 16px !important;
  left: 16px !important;
  border-radius: 999px !important;
  background: rgba(255, 250, 244, .90) !important;
  color: var(--laos-ink) !important;
  border: 1px solid rgba(64, 43, 34, .12) !important;
  box-shadow: 0 8px 22px rgba(31, 23, 20, .10) !important;
  backdrop-filter: blur(10px) !important;
}

.collection-card-body {
  padding: clamp(20px, 2vw, 28px) !important;
  gap: 12px !important;
}

.collection-card-category {
  margin-bottom: 6px !important;
  color: var(--laos-gold-dark) !important;
}

.collection-title-row {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 14px !important;
}

.collection-title-row h3 {
  color: var(--laos-ink) !important;
  font-size: clamp(27px, 2.3vw, 36px) !important;
  line-height: .98 !important;
  margin: 0 !important;
  text-wrap: balance;
}

.collection-card-subtitle {
  color: var(--laos-muted) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
}

.collection-card-description {
  color: rgba(79, 64, 56, .76) !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

.collection-price,
.collection-price-consult,
.modal-price-inline {
  color: var(--laos-ink) !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  letter-spacing: .025em !important;
}

.collection-price-consult {
  color: var(--laos-wine) !important;
}

.collection-card-essentials {
  margin-top: 6px !important;
  padding-top: 14px !important;
  border-top: 1px solid rgba(64, 43, 34, .09) !important;
  gap: 14px !important;
}

.collection-color-field > span,
.collection-size-field > span,
.quick-view-option-heading span {
  color: var(--laos-muted) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
}

.collection-color-dots,
.lookbook-color-dots,
.quick-view-color-options {
  gap: 9px !important;
}

.color-dot,
.collection-color-dot,
.lookbook-color-dot,
.quick-view-color-dot {
  width: 24px !important;
  height: 24px !important;
  min-width: 24px !important;
  border-radius: 50% !important;
  background: var(--dot-color, #d8c2a8) !important;
  border: 2px solid #fffaf4 !important;
  box-shadow: 0 0 0 1px rgba(64, 43, 34, .16), 0 5px 12px rgba(31, 23, 20, .10) !important;
}

.color-dot.active,
.collection-color-dot.active,
.lookbook-color-dot.active,
.quick-view-color-dot.active {
  box-shadow: 0 0 0 2px var(--laos-ink), 0 6px 14px rgba(31, 23, 20, .14) !important;
  transform: translateY(-1px) !important;
}

.collection-size-chip,
.collection-size-button,
.quick-view-size-chip {
  min-width: 36px !important;
  min-height: 34px !important;
  border-radius: 12px !important;
  background: rgba(255, 250, 244, .80) !important;
  border: 1px solid rgba(64, 43, 34, .14) !important;
  color: var(--laos-ink-soft) !important;
  font-weight: 800 !important;
}

.collection-size-chip.active,
.collection-size-button.active,
.quick-view-size-chip.active {
  background: var(--laos-ink) !important;
  color: #fffaf4 !important;
  border-color: var(--laos-ink) !important;
}

.collection-commercial-status {
  color: var(--laos-muted) !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
}

.collection-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  margin-top: 12px !important;
}

.collection-actions button {
  min-height: 44px !important;
  padding: 12px 16px !important;
  font-size: 12px !important;
  white-space: nowrap !important;
}

.collection-slider-dot,
.product-thumb {
  border-radius: 12px !important;
  border: 1px solid rgba(64, 43, 34, .12) !important;
  box-shadow: 0 8px 18px rgba(31, 23, 20, .08) !important;
}

/* Video editorial */
.premium-video,
.instagram-video-cta {
  min-height: clamp(390px, 46vw, 560px) !important;
}

.premium-overlay {
  background: rgba(12, 10, 9, .58) !important;
  backdrop-filter: blur(1.5px) !important;
}

.premium-content h2 {
  font-size: clamp(44px, 6vw, 76px) !important;
  line-height: .96 !important;
  color: #fffaf4 !important;
}

.premium-content p {
  color: rgba(255, 250, 244, .82) !important;
  line-height: 1.72 !important;
}

/* Quick view */
.quick-view.active {
  backdrop-filter: blur(14px) !important;
}

.quick-view-panel {
  width: min(1120px, calc(100vw - 40px)) !important;
  max-height: min(86vh, 820px) !important;
  display: grid !important;
  grid-template-columns: minmax(380px, .96fr) minmax(360px, .84fr) !important;
  gap: 0 !important;
  background: rgba(255, 250, 244, .98) !important;
  border: 1px solid rgba(64, 43, 34, .12) !important;
  border-radius: 32px !important;
  overflow: hidden !important;
  box-shadow: 0 35px 90px rgba(0, 0, 0, .28) !important;
}

.quick-view-media {
  background: linear-gradient(180deg, #efe1d3, #fbf7f1) !important;
  min-height: 620px !important;
  border-right: 1px solid rgba(64, 43, 34, .10) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.quick-view-media > img,
#quickViewImg {
  width: 100% !important;
  height: 100% !important;
  max-height: 720px !important;
  object-fit: cover !important;
  object-position: center top !important;
}

.quick-view-content {
  padding: clamp(28px, 3vw, 44px) !important;
  overflow-y: auto !important;
  scrollbar-width: thin !important;
}

.quick-view-close,
.product-modal-close,
.cart-close {
  background: rgba(255, 250, 244, .92) !important;
  color: var(--laos-ink) !important;
  border: 1px solid rgba(64, 43, 34, .13) !important;
  box-shadow: 0 12px 28px rgba(31, 23, 20, .12) !important;
}

.quick-view-summary {
  padding-bottom: 18px !important;
  margin-bottom: 18px !important;
  border-bottom: 1px solid rgba(64, 43, 34, .10) !important;
}

.quick-view-summary h2 {
  font-size: clamp(42px, 4.4vw, 64px) !important;
  line-height: .94 !important;
  color: var(--laos-ink) !important;
  margin: 8px 0 14px !important;
}

.quick-view-summary p {
  font-size: 15px !important;
  line-height: 1.75 !important;
}

.quick-view-accordion,
.quick-view-main-info,
.quick-view-option-block,
.quick-view-status-card {
  background: rgba(255, 250, 244, .70) !important;
  border: 1px solid rgba(64, 43, 34, .10) !important;
  border-radius: 20px !important;
  box-shadow: none !important;
}

.quick-view-accordion summary {
  color: var(--laos-ink) !important;
  font-weight: 800 !important;
  letter-spacing: .05em !important;
}

.quick-view-main-info {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 12px !important;
  padding: 14px !important;
}

.quick-view-options {
  gap: 14px !important;
}

.quick-view-option-block {
  padding: 16px !important;
}

.quick-view-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 12px !important;
  margin-top: 20px !important;
}

.quick-view-actions a,
.quick-view-actions button {
  min-height: 48px !important;
  padding: 14px 18px !important;
  font-size: 12px !important;
  text-align: center !important;
}

.quick-view-thumbnails-centered,
.quick-view-slider-dots {
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  bottom: 18px !important;
  justify-content: center !important;
  gap: 10px !important;
}

.quick-view-thumb,
.quick-view-slider-dot {
  width: 54px !important;
  height: 68px !important;
  border-radius: 14px !important;
  border: 1px solid rgba(64, 43, 34, .16) !important;
  overflow: hidden !important;
  background: #fffaf4 !important;
}

.quick-view-thumb.active,
.quick-view-slider-dot.active {
  box-shadow: 0 0 0 2px var(--laos-ink), 0 12px 22px rgba(31, 23, 20, .14) !important;
}

/* Lookbook / galería */
.lookbook-simple-section {
  background: linear-gradient(180deg, #f8f3ee, #fffaf4 48%, #f3e7da) !important;
}

.lookbook-simple-shell,
.lookbook-simple-app,
.lookbook-desktop-grid {
  border-radius: 34px !important;
}

.lookbook-simple-app {
  background: rgba(255, 250, 244, .82) !important;
  border: 1px solid rgba(64, 43, 34, .10) !important;
  box-shadow: var(--laos-shadow-soft) !important;
  overflow: hidden !important;
}

.lookbook-desktop-info {
  background: linear-gradient(180deg, rgba(255, 250, 244, .93), rgba(247, 239, 231, .82)) !important;
  border-right: 1px solid rgba(64, 43, 34, .10) !important;
}

.lookbook-desktop-info h3,
.lookbook-swipe-copy h3 {
  color: var(--laos-ink) !important;
  text-transform: none !important;
  letter-spacing: -.035em !important;
}

.lookbook-desktop-description-panel,
.lookbook-swipe-card,
.lookbook-swipe-media,
.lookbook-swipe-copy {
  border-color: rgba(64, 43, 34, .10) !important;
  box-shadow: none !important;
}

.lookbook-swipe-card {
  border-radius: 28px !important;
  background: #fffaf4 !important;
}

.lookbook-swipe-media img {
  filter: saturate(.97) contrast(1.02) !important;
  transition: transform .55s ease !important;
}

.lookbook-swipe-card:hover .lookbook-swipe-media img {
  transform: scale(1.018) !important;
}

.lookbook-swipe-btn {
  background: #fffaf4 !important;
  border: 1px solid rgba(64, 43, 34, .12) !important;
  color: var(--laos-ink) !important;
}

.lookbook-swipe-dots button.active {
  background: var(--laos-ink) !important;
}

/* Sobre / proceso */
.atelier-process {
  background: linear-gradient(180deg, #fbf7f1, #f4ebe2) !important;
}

.atelier-process__inner,
.atelier-process__step,
.atelier-process__media {
  border-color: rgba(64, 43, 34, .10) !important;
  box-shadow: var(--laos-shadow-soft) !important;
}

.atelier-process__content h2 {
  font-family: var(--laos-serif) !important;
  color: var(--laos-ink) !important;
  letter-spacing: -.03em !important;
}

.atelier-process__intro,
.atelier-process__step p {
  color: var(--laos-muted) !important;
  line-height: 1.78 !important;
}

/* Opiniones */
.opiniones-premium {
  background: linear-gradient(180deg, #efe3d6, #f8f3ee) !important;
}

.opiniones-shell {
  width: min(1180px, 100%) !important;
  margin-inline: auto !important;
}

.testimonio,
.opinion-callout,
.opiniones-form-card,
.opinion-form-box,
.admin-box,
.admin-dashboard,
.stat-card,
.admin-opinion {
  background: rgba(255, 250, 244, .92) !important;
  border: 1px solid rgba(64, 43, 34, .10) !important;
  border-radius: 26px !important;
  box-shadow: var(--laos-shadow-soft) !important;
}

.testimonio p,
.opiniones-heading-block p,
.opiniones-form-card p {
  color: var(--laos-muted) !important;
  line-height: 1.75 !important;
}

.opinion-star {
  color: var(--laos-gold) !important;
}

/* Contacto / footer */
.contact-footer-section,
.contacto {
  background:
    radial-gradient(circle at 20% 0%, rgba(196, 154, 108, .18), transparent 32vw),
    linear-gradient(180deg, #211916 0%, #120f0e 100%) !important;
}

.contact-card--compact {
  background: rgba(255, 250, 244, .96) !important;
  border: 1px solid rgba(255, 250, 244, .18) !important;
  box-shadow: 0 30px 85px rgba(0, 0, 0, .22) !important;
}

.contact-card--compact h2 {
  color: var(--laos-ink) !important;
}

.contact-form--compact {
  background: transparent !important;
  border-color: rgba(64, 43, 34, .10) !important;
  box-shadow: none !important;
}

.integrated-footer,
.footer-copy,
.footer-column h3,
.footer-column a,
.footer-brand h2 {
  color: rgba(255, 250, 244, .86) !important;
}

.footer-socials a {
  background: rgba(255, 250, 244, .08) !important;
  border: 1px solid rgba(255, 250, 244, .14) !important;
  color: #fffaf4 !important;
  border-radius: 999px !important;
}

/* Carrito */
.cart-panel {
  background: rgba(255, 250, 244, .98) !important;
  border-left: 1px solid rgba(64, 43, 34, .12) !important;
  box-shadow: -24px 0 70px rgba(0, 0, 0, .20) !important;
}

.cart-header,
.cart-footer,
.cart-item {
  border-color: rgba(64, 43, 34, .10) !important;
}

.cart-item {
  background: rgba(255, 250, 244, .72) !important;
  border-radius: 18px !important;
}

.cart-note {
  color: var(--laos-muted) !important;
}

/* Admin — pulido visual sin tocar lógica */
.admin-page {
  background: linear-gradient(180deg, #f8f3ee, #efe3d6) !important;
}

.admin-tabs {
  gap: 8px !important;
}

.admin-tab.active {
  background: var(--laos-ink) !important;
  color: #fffaf4 !important;
}

.edit-btn {
  background: var(--laos-gold) !important;
  color: #171210 !important;
}

.delete-btn {
  background: #7a2231 !important;
  color: #fffaf4 !important;
}

/* Responsive boutique */
@media (max-width: 1024px) {
  .quick-view-panel {
    width: min(940px, calc(100vw - 28px)) !important;
    grid-template-columns: 1fr 1fr !important;
  }

  .quick-view-media {
    min-height: 560px !important;
  }
}

@media (max-width: 820px) {
  section {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .header {
    height: 72px !important;
    padding: 0 16px !important;
  }

  .logo {
    width: 38px !important;
    height: 38px !important;
  }

  .brand-center {
    max-width: 190px !important;
  }

  .logo-text strong,
  .brand h1 {
    font-size: 18px !important;
  }

  .menu-btn {
    width: 42px !important;
    height: 42px !important;
  }

  .hero,
  .hero-premium {
    justify-content: center !important;
    text-align: center !important;
    padding-top: 112px !important;
    padding-bottom: 62px !important;
  }

  .hero-overlay {
    background: linear-gradient(180deg, rgba(16, 12, 11, .74), rgba(16, 12, 11, .52)) !important;
  }

  .hero h2,
  .hero-premium-content h2 {
    font-size: clamp(40px, 13vw, 58px) !important;
    line-height: .96 !important;
  }

  .hero p,
  .hero-premium-content p {
    margin-left: auto !important;
    margin-right: auto !important;
    font-size: 15.5px !important;
  }

  .hero-buttons {
    flex-direction: column !important;
    width: 100% !important;
  }

  .hero-buttons .btn,
  .collection-load-more-btn,
  .contact-actions--compact a,
  .contact-submit,
  .checkout-btn,
  .opinion-btn {
    width: 100% !important;
  }

  .collection-toolbar {
    border-radius: 22px !important;
  }

  .collection-mobile-actions {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .collection-mobile-action {
    min-height: 56px !important;
    padding: 8px 6px !important;
  }

  .collection-card {
    border-radius: 24px !important;
  }

  .collection-card-media img,
  .card-img {
    height: clamp(390px, 116vw, 520px) !important;
  }

  .collection-title-row h3 {
    font-size: 30px !important;
  }

  .collection-actions {
    grid-template-columns: 1fr !important;
  }

  .quick-view-panel {
    width: calc(100vw - 22px) !important;
    max-height: 88vh !important;
    grid-template-columns: 1fr !important;
    border-radius: 26px !important;
  }

  .quick-view-media {
    min-height: 42vh !important;
    max-height: 48vh !important;
    border-right: none !important;
    border-bottom: 1px solid rgba(64, 43, 34, .10) !important;
  }

  .quick-view-media > img,
  #quickViewImg {
    max-height: 48vh !important;
  }

  .quick-view-content {
    padding: 24px 20px !important;
  }

  .quick-view-summary h2 {
    font-size: 38px !important;
  }

  .quick-view-main-info,
  .quick-view-actions {
    grid-template-columns: 1fr !important;
  }

  .quick-view-thumb,
  .quick-view-slider-dot {
    width: 46px !important;
    height: 58px !important;
  }

  .lookbook-simple-app,
  .lookbook-simple-shell,
  .lookbook-desktop-grid {
    border-radius: 24px !important;
  }

  .lookbook-desktop-info {
    border-right: none !important;
    border-bottom: 1px solid rgba(64, 43, 34, .10) !important;
  }

  .contact-card--compact {
    border-radius: 24px !important;
  }
}

@media (max-width: 480px) {
  section {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .collection-mobile-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .collection-card-body {
    padding: 20px !important;
  }

  .collection-card-media img,
  .card-img {
    height: 410px !important;
  }

  .collection-title-row h3 {
    font-size: 28px !important;
  }

  .premium-content h2 {
    font-size: 38px !important;
  }

  .contact-card--compact h2 {
    font-size: 34px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }
}


/* =========================================================
   ADMIN PRO - PRODUCTOS, LOOKBOOK, SERVICIOS Y PEDIDOS
   Capa segura: solo mejora el panel sin tocar lógica pública.
   ========================================================= */

.admin-kicker {
  display: inline-block;
  margin-bottom: 8px;
  color: var(--laos-wine, #6f2437);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.admin-muted,
.admin-field small {
  color: #7a6d63;
  font-size: 13px;
  line-height: 1.6;
}

.admin-section-head,
.admin-list-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 24px;
}

.admin-section-head h2,
.admin-list-head h3 {
  margin-bottom: 6px;
}

.admin-toolbar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.admin-toolbar .btn,
.admin-actions-row .btn {
  width: auto;
}

.admin-toolbar select,
.admin-order-actions select {
  min-height: 44px;
  padding: 0 16px;
  border: 1px solid rgba(111, 36, 55, 0.18);
  border-radius: 999px;
  background: #fffaf4;
  color: #2b2521;
  font-family: 'Manrope', sans-serif;
  font-weight: 700;
  outline: none;
}

.admin-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 18px;
  margin-bottom: 34px;
}

.admin-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.admin-field label {
  color: #3a2f29;
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.admin-field-full {
  grid-column: 1 / -1;
}

.admin-field input,
.admin-field select,
.admin-field textarea,
.admin-form input,
.admin-form select,
.admin-form textarea {
  font-family: 'Manrope', sans-serif;
}

.admin-field textarea {
  min-height: 115px;
}

#productVariants,
#galleryItems {
  min-height: 150px;
  font-family: Consolas, Monaco, 'Courier New', monospace;
  font-size: 13px;
}

.admin-actions-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.admin-panel-note {
  margin-top: 24px;
  padding: 18px 20px;
  border: 1px solid rgba(199, 163, 90, 0.28);
  border-radius: 20px;
  background: #fff8ef;
  color: #54473f;
  line-height: 1.6;
}

.admin-hidden-head {
  margin-top: 34px;
  padding-top: 26px;
  border-top: 1px solid rgba(111, 36, 55, 0.12);
}

.admin-empty {
  padding: 18px 20px;
  border: 1px dashed rgba(111, 36, 55, 0.18);
  border-radius: 18px;
  background: #fffaf4;
  color: #75675d;
}

.admin-product,
.admin-opinion,
.admin-order-card {
  border: 1px solid rgba(111, 36, 55, 0.10);
  border-radius: 22px;
  background: #fffaf4;
}

.admin-product {
  margin-bottom: 14px;
  padding: 16px;
}

.admin-product img {
  background: #f3eadf;
  border: 1px solid rgba(199, 163, 90, 0.20);
}

.admin-product h4,
.admin-opinion h4,
.admin-order-card h4 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 23px;
  letter-spacing: -0.01em;
}

.admin-product p,
.admin-opinion p,
.admin-order-card p {
  line-height: 1.55;
}

.admin-actions button,
.edit-btn,
.delete-btn {
  font-family: 'Manrope', sans-serif;
}

.is-hidden-product {
  opacity: 0.72;
  background: #f3eee7;
}

.is-hidden-product img {
  filter: grayscale(1);
}

.admin-order-summary {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.admin-order-summary span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  border-radius: 999px;
  background: #f1e5d8;
  color: #3d3029;
  font-size: 13px;
  font-weight: 700;
}

.admin-order-card {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 18px;
  margin-bottom: 14px;
  padding: 18px;
}

.admin-order-status {
  display: inline-block;
  margin-bottom: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.admin-order-main strong {
  display: inline-block;
  margin-top: 8px;
  color: #6f2437;
}

.admin-order-actions {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  flex-direction: column;
  gap: 10px;
}

.admin-order-actions button,
.admin-order-actions select {
  width: 100%;
  min-width: 150px;
}

@media (max-width: 860px) {
  .admin-section-head,
  .admin-list-head,
  .admin-order-card {
    grid-template-columns: 1fr;
    flex-direction: column;
  }

  .admin-form-grid {
    grid-template-columns: 1fr;
  }

  .admin-toolbar,
  .admin-actions-row,
  .admin-order-actions {
    width: 100%;
    align-items: stretch;
  }

  .admin-toolbar .btn,
  .admin-actions-row .btn,
  .admin-toolbar select,
  .admin-order-actions select,
  .admin-order-actions button {
    width: 100%;
  }
}
