/*
  Estilo replicando (a nivel visual) la referencia de tus capturas:
  - Franja superior blanca con direcciones + logo centrado + contacto.
  - Barra de navegación turquesa con enlaces en mayúsculas y subrayado activo.
  - Secciones por local: título turquesa, dos fotos en 2 columnas, mapa debajo.
  - Bloque de 3 cajas grises con iconos.
  - Botón flotante de “subir”.
*/

:root{
  --teal:#70a030;
  --teal-dark:#4f7a24;
  --washgo:#70a030; /* turquesa principal del footer */
  --text:#222;
  --muted:#6b6b6b;
  --line:#e6e6e6;
  --soft:#efefef;
  --active:#f08030;
  --container:1120px;
}


*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Open Sans',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:#fff;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block;}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 22px;
}

/* ------------------ TOPBAR ------------------ */
.topbar{
  background:#fff;
}

.topbar-inner{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  gap:20px;
  align-items:start;
  padding:18px 0 10px;
}

.topbar-col p{
  margin:8px 0;
  font-size:12.5px;
  line-height:1.3;
  color:#3b3b3b;
  display:flex;
  gap:10px;
  align-items:flex-start;
}

.topbar-col a{color:inherit;text-decoration:none;}
.topbar-col a:hover{color:var(--teal-dark);}

.ico svg{fill:var(--teal);flex:0 0 auto;margin-top:1px;}

.topbar-center{
  text-align:center;
  align-self:center;
}

.logo{
  width:150px;
  max-width:34vw;
  height:auto;
  margin:0 auto;
}

.logo-sub{
  margin-top:6px;
  font-family:'Montserrat',sans-serif;
  font-style:italic;
  font-size:16px;
  color:#222;
}

.topbar-right{
  text-align:left;
}

/* ------------------ NAV ------------------ */
.navwrap{
  background:var(--teal);
  position:sticky;
  top:0;
  z-index:1000;
}

.nav-inner{
  height:68px;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}

.nav{
  display:flex;
  align-items:center;
  gap:26px;
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  letter-spacing:.4px;
}

.nav .sep{color:rgba(255,255,255,.65);}

/* Enlaces del menú: siempre blancos, incluidos visitados */
.nav-link{
  color:#fff;
  text-decoration:none;
  position:relative;
  padding:10px 2px;
  font-size:13px;
}
.nav-link:link,
.nav-link:visited{
  color:#fff;
}

.quality-list-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:0; /* sin separación para que la columna derecha quede pegada al borde */
  margin:16px auto 0;
  max-width:900px;
  align-items:start;
}
.quality-list{
  list-style:none;
  margin:0;
  padding:0;
  text-align:left;
}

.nav-link.active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-8px;
  height:3px;
  background:var(--active);
  border-radius:2px;
}

.nav-toggle{
  display:none;
  position:absolute;
  left:0;
/* Columna derecha: texto alineado a la derecha, puntos a la izquierda */
.quality-list--right{ text-align:right; }
.quality-list--right li{ padding-left:18px; padding-right:0; }
  border:0;
  background:transparent;
  color:#fff;
  font-size:28px;
  cursor:pointer;
  padding:10px 6px;
}

/* Para que el scroll no quede tapado por la barra */
section{scroll-margin-top:90px;}

/* ------------------ LOCALES ------------------ */
.location-section{
  padding:46px 0 16px;
}

.location-title{
  margin:0 0 18px;
  font-family:'Montserrat',sans-serif;
  color:var(--teal);
  font-size:40px;
  letter-spacing:.5px;
}

.two-photos{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:26px;
}

.two-photos figure{margin:0;}

.two-photos img{
  width:100%;
  height:clamp(240px, 30vw, 360px);
  object-fit:cover;
  border-radius:14px;
  box-shadow:0 12px 30px rgba(0,0,0,.10);
  transition:transform .25s ease, box-shadow .25s ease;
}
.two-photos img:hover{
  transform:translateY(-2px) scale(1.01);
  box-shadow:0 16px 38px rgba(0,0,0,.14);
}

/* una mínima variación visual cuando duplicamos foto */
.alt-photo{transform:scale(1.01);filter:saturate(1.05) contrast(1.02);}

.map-block{margin:18px 0 36px;}
.map-block iframe{
  width:100%;
  height:300px;
  border:0;
  border-radius:14px;
  box-shadow:0 10px 26px rgba(0,0,0,.08);
}

/* Click-to-load Map embed */
.map-embed{
  border:1px solid var(--line);
  border-radius:10px;
  overflow:hidden;
  background:#fafafa;
}
.map-embed__placeholder{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px;
}
.map-embed__btn{
  appearance:none;
  border:0;
  background:var(--teal);
  color:#fff;
  font-weight:600;
  font-family:'Montserrat',sans-serif;
  letter-spacing:.2px;
  border-radius:6px;
  padding:10px 14px;
  cursor:pointer;
}
.map-embed__btn:hover{background:var(--teal-dark);}
.map-embed__hint{margin:0;color:#666;font-size:12.5px;}
.map-embed__frame{display:block;width:100%;height:300px;border:0;}
.map-embed__error{padding:14px;color:#a33;font-size:13px;background:#fff5f5;border-top:1px solid #f1d6d6;}

/* ------------------ FEATURES (3 cajas grises) ------------------ */
.features{padding:18px 0 36px;}

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

.feature{
  background:var(--soft);
  padding:46px 28px;
  text-align:center;
  min-height:270px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.feature-ico svg{fill:var(--teal);}

.feature h3{
  margin:14px 0 10px;
  font-family:'Montserrat',sans-serif;
  color:var(--teal-dark);
  font-size:16px;
  letter-spacing:.4px;
}

.feature p{margin:0;color:#2f2f2f;font-size:13.5px;}

.feature-center{
  position:relative;
  overflow:hidden;
}

.feature-center .bubble{
  position:absolute;
  inset:-40% -30% auto auto;
  width:280px;
  height:280px;
  border-radius:50%;
  background:rgba(255,255,255,.55);
}

.feature-center-text{
  font-family:'Montserrat',sans-serif;
  font-size:24px;
  line-height:1.15;
  color:#2a2a2a;
  position:relative;
  z-index:1;
}

.feature-center-text p{margin:4px 0;}
.feature-center-text strong{font-weight:700;}

/* ------------------ TITULAR GRANDE ------------------ */
.big-title{padding:34px 0 40px;}
.big-title h2{
  margin:0;
  text-align:center;
  font-family:'Montserrat',sans-serif;
  color:var(--teal-dark);
  font-size:42px;
  letter-spacing:.6px;
}

.underline{
  width:56px;
  height:3px;
  background:var(--teal);
  margin:14px auto 0;
}

/* Texto bajo el titular grande */
.big-title-content{
  margin:20px auto 0;
  max-width:820px;
  color:#333;
  line-height:1.6;
  text-align:center;
}
.big-title-content h3{
  margin:0 0 10px;
  font-family:'Montserrat',sans-serif;
  color:var(--teal-dark);
  font-size:22px;
  font-weight:700;
}
.big-title-content p{
  margin:0 0 12px;
  font-weight:400;
}

/* Texto adicional y lista con puntos verdes */
.quality-content{
  margin:22px auto 0;
  max-width:900px;
  color:#333;
  line-height:1.6;
  text-align:center;
}
.quality-content p{margin:0 0 12px;}
/* Lista de servicios: dos columnas con separación y puntos a la izquierda */
.quality-list{
  list-style:none;
  margin:16px auto 0;
  padding:0;
  max-width:900px;
  text-align:left;
  column-count:2;
  column-gap:0; /* pegar la columna derecha al margen derecho del bloque */
}
.quality-list li{
  position:relative;
  padding-left:18px;
  margin:6px 0;
  break-inside:avoid;
}
.quality-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:0.85em;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--teal);
}

/* ------------------ SECCIONES (Instrucciones, Contacto, Quienes) ------------------ */
.section-title{
  margin:0 0 18px;
  font-family:'Montserrat',sans-serif;
  font-size:clamp(24px, 2.2vw, 32px);
  color:var(--teal-dark);
  letter-spacing:.4px;
  text-align:center;
  text-wrap:balance;
}

.instructions{padding:10px 0 40px;}

/* --- INSTRUCCIONES (rediseño con cards y grids) --- */
.instructions-wrap{display:flex;flex-direction:column;gap:20px;}

/* Grid base */
.grid{display:grid;gap:16px;}
.grid--steps{grid-template-columns:repeat(4,1fr);align-items:stretch;}
.grid--content{grid-template-columns:1fr 1fr;align-items:start;}
.grid--stack{grid-template-columns:1fr;}
.grid--prices{grid-template-columns:repeat(4,1fr);} /* dentro de la card de tarifas */

@media (max-width: 980px){
  .grid--steps{grid-template-columns:repeat(2,1fr);} 
  .grid--content{grid-template-columns:1fr;} 
  .grid--prices{grid-template-columns:repeat(2,1fr);} 
}
@media (max-width: 720px){
  .grid--steps{grid-template-columns:1fr;} 
  .grid--prices{grid-template-columns:1fr;} 
}

/* Card base */
.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:12px;
  box-shadow:0 10px 26px rgba(0,0,0,.07);
  padding:18px 18px;
}
.card-header h3,
.card-header h4{
  margin:0;
  font-family:'Montserrat',sans-serif;
  color:var(--teal-dark);
  letter-spacing:.03em;
}
.card-header h3{font-size:16px;text-transform:uppercase;}
.card-header h4{font-size:14px;text-transform:uppercase;opacity:.95;}
.card-body{display:block;}
.subcard{padding:12px 12px;margin:10px 0 0;border-radius:8px;}

/* Steps cards: igual altura y tipografía limpia */
.step-card{display:flex;}
.step-card .card-body{display:flex;flex-direction:column;gap:8px;}
.step-card h3{margin:0;font-size:15px;font-family:'Montserrat',sans-serif;color:#1f1f1f;}
.step-card p{margin:0;color:var(--muted);font-size:13px;}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;background:var(--teal);color:#fff;font-weight:700;
  border-radius:6px; /* consistente con el resto */
}

/* Listas reutilizables */
.list{margin:10px 0 0;padding-left:18px;color:#333;line-height:1.65;font-size:13px;}
.list li{margin:6px 0;}
.list--ordered{list-style:decimal;}

/* Pills/Badges */
.pill-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;}
.badge,.pill{
  display:inline-flex;align-items:center;gap:6px;
  border:1px solid var(--line);background:#fafafa;padding:6px 10px;
  border-radius:999px;font-size:12px;color:var(--muted);
}

/* Callout para notas (tiempos y aparcamiento) */
.callout{
  margin:12px 0 0;
  border:1px solid var(--line);
  background:#f8fbf5;
  padding:12px;
  border-left:4px solid var(--teal);
  display:flex;gap:10px;align-items:flex-start;
}
.callout-ico svg{fill:var(--teal);}
.callout-content{color:#333;font-size:13px;}

/* Tabla/Grilla de precios dentro de card */
.card-prices .card-body{padding-top:6px;}
.price-table{margin-top:4px;}
.price-item{padding:14px;}
.price-item h4{
  margin:0 0 8px;font-size:14px;font-family:'Montserrat',sans-serif;text-transform:uppercase;letter-spacing:.06em;color:var(--teal-dark);
}
.price-meta{margin:0 0 12px;color:var(--muted);font-size:13px;}
.price-lines{display:grid;gap:8px;}
.price-line{display:flex;justify-content:space-between;align-items:baseline;gap:10px;padding-top:8px;border-top:1px dashed var(--line);} 
.price-line:first-child{border-top:none;padding-top:0;}
.price-line span{color:var(--muted);font-size:13px;}
.price-line strong{color:var(--text);font-size:14px;}
.price-highlight{color:var(--teal-dark);font-weight:700;font-size:16px;}

/* ------------------ INSTRUCCIONES (detalle + tarifas) ------------------ */
.instructions-lead{
  margin:10px auto 18px;
  max-width:820px;
  color:var(--muted);
  line-height:1.65;
  font-size:14px;
}
.instructions-lead strong{color:var(--text);}
.instructions-lead .muted{color:var(--muted);}

.instructions-grid{
  margin-top:18px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:16px;
}

.info-card{
  border:1px solid var(--line);
  padding:18px 16px;
  background:#fff;
}

.info-card h3{
  margin:0 0 8px;
  font-size:15px;
  font-family:'Montserrat',sans-serif;
  color:var(--teal-dark);
  letter-spacing:.02em;
  text-transform:uppercase;
}

.info-list{
  margin:10px 0 0;
  padding-left:18px;
  color:#333;
  line-height:1.65;
  font-size:13px;
}
.info-list li{margin:6px 0;}

.pills{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  border:1px solid var(--line);
  background:#fafafa;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  color:var(--muted);
}

.instructions-subtitle{
  margin:28px 0 12px;
  font-size:15px;
  font-family:'Montserrat',sans-serif;
  color:var(--text);
  text-transform:uppercase;
  letter-spacing:.06em;
}

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

.price-card{
  border:1px solid var(--line);
  padding:18px 16px;
  background:#fff;
}

.price-card h4{
  margin:0 0 8px;
  font-size:14px;
  font-family:'Montserrat',sans-serif;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--teal-dark);
}

.price-meta{
  margin:0 0 12px;
  color:var(--muted);
  font-size:13px;
}

.price-lines{display:grid;gap:8px;}
.price-line{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:10px;
  padding-top:8px;
  border-top:1px dashed var(--line);
}
.price-line:first-child{border-top:none;padding-top:0;}
.price-line span{color:var(--muted);font-size:13px;}
.price-line strong{color:var(--text);font-size:14px;}

.note{
  margin-top:16px;
  border:1px solid var(--line);
  background:#f8fbf5;
  padding:14px 14px;
  border-left:4px solid var(--teal);
  color:#333;
  line-height:1.55;
  font-size:13px;
}

@media (max-width: 980px){
  .instructions-grid{grid-template-columns:1fr;}
  .price-grid{grid-template-columns:1fr;}
}

}

.contact{padding:10px 0 40px;}
.contact-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:22px;
}

.contact-box{
  border:1px solid var(--line);
  padding:18px 16px;
}

.contact-box p{margin:0 0 10px;}
.contact-box a{color:var(--teal-dark);text-decoration:none;}
.contact-box a:hover{text-decoration:underline;}
.contact-box ul{margin:8px 0 0;padding-left:18px;color:#333;}
.contact-box li{margin:6px 0;}

.about{padding:10px 0 60px;}
.about-text{margin:0;max-width:820px;color:#333;line-height:1.6;}

/* ------------------ FOOTER ------------------ */
.footer{
  border-top:1px solid var(--line);
  padding:16px 0;
  color:#666;
  font-size:13px;
}

.footer-inner{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:center;
}

.footer a{color:var(--teal-dark);text-decoration:none;}
.footer a:hover{text-decoration:underline;}

/* ------------------ BOTÓN SUBIR ------------------ */
.to-top{
  position:fixed;
  right:28px;
  bottom:26px;
  width:52px;
  height:52px;
  border-radius:999px;
  border:0;
  background:var(--teal-dark);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
  z-index:1200; /* por encima del footer */
  opacity:0;
  transform:translateY(8px);
  pointer-events:none;
  transition:opacity .2s ease, transform .2s ease;
}

.to-top svg{fill:#fff;}

.to-top.show{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}


/* ------------------ CATEGORÍAS (3 tarjetas con imagen) ------------------ */
.categories{padding:10px 0 44px;}
.category-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.category-card{
  position:relative;
  border-radius:10px;
  overflow:hidden;
  border:1px solid var(--line);
  text-decoration:none;
  color:inherit;
  min-height:220px;
}
.category-card img{
  width:100%;
  height:220px;
  object-fit:cover;
  filter:saturate(1.05) contrast(1.05);
  transform:scale(1.02);
}
.category-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,.55) 100%);
}
.category-card span{
  position:absolute;
  left:16px;
  right:16px;
  bottom:14px;
  z-index:1;
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  letter-spacing:.3px;
  color:#fff;
  font-size:18px;
  text-transform:uppercase;
}

/* ------------------ FOOTER NUEVO (Wash&Go) ------------------ */
.footer-partners{
  background:#fff;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.partners-inner{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:28px;
  padding:14px 0;
}
.partners-inner img{
  height:32px;
  width:auto;
  opacity:.9;
  filter:saturate(1.05) contrast(1.02);
}

.footer-cta{
  position:relative;
  background:var(--washgo);
  color:#fff;
  padding:60px 0;
  overflow:hidden; /* para burbujas */
}

.footer-cta__inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 24px;
  position:relative;
  z-index:1;
}

.footer-cta__top{
  display:grid;
  grid-template-columns: 260px 1fr 240px;
  gap:32px;
  align-items:start;
}

.footer-brand{display:flex;flex-direction:column;gap:10px;}
.footer-logo{width:150px;height:auto;filter:drop-shadow(0 2px 6px rgba(0,0,0,.15));}
.copyright{margin:0;color:rgba(255,255,255,.85);font-size:13px;}

.footer-main-cta{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.cta-text{font-family:'Montserrat',sans-serif;font-weight:700;letter-spacing:.6px;font-size:28px;}
.cta-phone{color:#fff;text-decoration:none;font-weight:700;font-family:'Montserrat',sans-serif;font-size:20px;
  white-space:nowrap;
}

.cta-phone:hover{text-decoration:underline;}
.footer-line{height:1px;background:rgba(255,255,255,.55);margin:14px 0;}

.footer-contact-row{display:flex;gap:24px;flex-wrap:wrap;align-items:center;}
.contact-item{display:flex;align-items:center;gap:8px;color:#fff;}
.contact-item a{color:#fff;text-decoration:underline;}
.contact-ico svg{fill:#fff;opacity:.95;}

/* Mini-grid de pasos en el footer */
.footer-cta__steps{
  margin-top:28px;
  display:grid;
  grid-template-columns:repeat(4, minmax(170px, 1fr));
  gap:16px;
  align-items:stretch;
  justify-items:stretch;
}
.footer-cta__steps .step-card{
  background:rgba(255,255,255,.9);
  color:#1e1e1e;
  border:1px solid rgba(255,255,255,.75);
  border-radius:8px;
  padding:14px 12px;
  box-shadow:0 8px 22px rgba(0,0,0,.12);
  display:flex;
  flex-direction:column;
  height:100%;
  transition:transform .2s ease, box-shadow .2s ease;
}
.footer-cta__steps .step-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 28px rgba(0,0,0,.18);
}
.footer-cta__steps .step-card h3{margin:6px 0 6px;font-family:'Montserrat',sans-serif;font-size:15px;color:#183c3d;}
.footer-cta__steps .step-card p{margin:0;color:#3b3b3b;font-size:13px;line-height:1.45;}
.footer-cta__steps .step-card .step-num{background:var(--teal);color:#fff;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;font-weight:700;margin-bottom:6px;}

/* Legal links columna derecha */
.footer-legal{align-self:stretch;}
.legal-links{list-style:none;margin:0;padding:0;}
.legal-links li{margin:6px 0;}
.legal-links a{color:#fff;text-decoration:underline;opacity:.9;}
.legal-links a:hover{opacity:1;}

/* Burbujas decorativas */
.footer-bubbles{
  position:absolute;
  left:0;right:0;bottom:0;top:0;
  pointer-events:none;
  z-index:0; /* detrás del contenido */
}

.footer-bubbles .bubble{
  position:absolute;
  left:0;
  bottom:-10vh;
  width:16px; height:16px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.9), rgba(255,255,255,.35));
  filter:blur(.2px);
  opacity:.75;
  animation-name:bubbleRise;
  animation-timing-function:linear;
  animation-iteration-count:infinite;
}

@keyframes bubbleRise{
  0%{ transform:translateY(0) translateX(0); opacity:.0; }
  5%{ opacity:.6; }
  50%{ transform:translateY(-50vh) translateX(8px); }
  100%{ transform:translateY(-95vh) translateX(-6px); opacity:0; }
}

/* ------------------ RESPONSIVE ajustes footer ------------------ */
@media (max-width: 980px){
  .footer-cta__top{grid-template-columns:1fr 1fr; }
  .footer-legal{grid-column:1 / -1; text-align:center;}
  .footer-main-cta{flex-direction:column;align-items:flex-start;gap:8px;}
  .cta-text{font-size:24px;}
  .cta-phone{font-size:18px;}
  .footer-cta__steps{grid-template-columns:repeat(2,1fr);}  
}
@media (max-width: 720px){
  .footer-cta__top{grid-template-columns:1fr;}
  .footer-cta__steps{grid-template-columns:1fr;}
  .partners-inner{gap:18px;}
  .partners-inner img{height:26px;}
}

/* ------------------ OPINIONES (Parallax + carrusel) ------------------ */
.reviews-parallax{
  position:relative;
  padding:86px 0 70px;
  /* Fondo fijo (efecto "imagen quieta") */
  background-image:url('assets/images/imagen_interior_duquesa_parcent.jpg');
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  background-attachment:fixed;
  overflow:hidden;
}

/* Capa oscura para que el texto sea legible */
.reviews-parallax::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.42);
}

.reviews-inner{position:relative;}

.reviews-slider{
  max-width:980px;
  margin:0 auto;
  outline:none;
}

.review-slide{
  display:none;
  align-items:flex-start;
  gap:18px;
  color:#fff;
}

.review-slide.is-active{
  display:flex;
  animation:reviewFade .25s ease;
}

@keyframes reviewFade{
  from{opacity:.0;transform:translateY(4px);} 
  to{opacity:1;transform:translateY(0);} 
}

.review-quote{
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:72px;
  line-height:1;
  color:rgba(255,255,255,.85);
  margin-top:-10px;
}

.review-avatar{
  width:96px;
  height:96px;
  border-radius:999px;
  background:rgba(47,178,178,.95);
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 10px 24px rgba(0,0,0,.22);
}

.review-avatar svg{fill:#fff;opacity:.95;}

.review-content{max-width:760px;}

.review-name{
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:20px;
  color:rgba(47,178,178,1);
  margin:2px 0 10px;
}

.review-text{
  font-style:italic;
  font-size:20px;
  line-height:1.45;
  color:rgba(255,255,255,.92);
}

.review-dots{
  display:flex;
  justify-content:center;
  gap:12px;
  margin-top:26px;
}

.review-dots .dot{
  width:8px;
  height:8px;
  border-radius:999px;
  border:0;
  background:rgba(255,255,255,.55);
  cursor:pointer;
}

.review-dots .dot:hover{background:rgba(255,255,255,.78);}

.review-dots .dot.is-active{
  background:rgba(47,178,178,1);
  width:10px;
  height:10px;
}


/* ------------------ POR QUÉ ELEGIRNOS ------------------ */
.why-us{padding:10px 0 56px;}
.why-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.why-item{
  border-left:4px solid var(--teal);
  padding:10px 12px 10px 12px;
  background:#fff;
  border:1px solid var(--line);
}
.why-item h3{
  margin:0 0 6px;
  font-family:'Montserrat',sans-serif;
  font-size:15px;
  color:var(--teal-dark);
}
.why-item p{margin:0;color:#444;font-size:13px;line-height:1.45;}

/* Fallback para móviles: desactivar background fijo para evitar bugs iOS */
@media (max-width: 980px), (pointer: coarse){
  .reviews-parallax{background-attachment:scroll;}
  .review-text{font-size:18px;}
}

@media (max-width: 720px){
  .review-slide{flex-direction:column;align-items:flex-start;}
  .review-quote{font-size:58px;}
  .review-avatar{width:86px;height:86px;}
}


/* ------------------ POLISH (sin cambiar paleta ni estructura) ------------------ */
:where(a, button, input, textarea, select):focus-visible{
  outline:3px solid rgba(112,160,48,.55);
  outline-offset:3px;
}

section[id]{scroll-margin-top:90px;}

a{transition:opacity .18s ease, transform .18s ease;}
a:hover{opacity:1;}
a:active{transform:translateY(1px);}

.muted{line-height:1.5;}
.instructions-lead{max-width:78ch;margin-left:auto;margin-right:auto;}
/* Cards: texto más legible */
.card p{line-height:1.55;}
/* Steps: títulos equilibrados */
.step-card h3{text-wrap:balance;}
/* Partners row: mejor alineado en móvil */
@media (max-width: 640px){
  .partners-inner{flex-wrap:wrap; gap:16px; padding:12px 0;}
  .partners-inner img{height:28px;}
}

/* ------------------ EFECTO HOVER PREMIUM INSTRUCCIONES ------------------ */

/* 1. Estilo base para las tarjetas en la sección de instrucciones */
#instrucciones .card {
  /* Propiedades para una transición suave */
  will-change: transform, box-shadow;
  transform-origin: center;
  transition: transform 240ms cubic-bezier(.2, .8, .2, 1), 
              box-shadow 240ms cubic-bezier(.2, .8, .2, 1);
}

/* 2. Efecto al pasar el ratón (hover) o al enfocar con el teclado */
#instrucciones .card:hover,
#instrucciones .card:focus-visible {
  transform: translateY(-5px) scale(1.04);
  box-shadow: 0 14px 32px rgba(0, 0, 0, .12);
  outline: 2px solid transparent; /* Para accesibilidad, sin cambiar el diseño */
  outline-offset: 2px;
}

/* 3. Micro-efecto en los números de los pasos */
#instrucciones .card:hover .step-num,
#instrucciones .card:focus-visible .step-num {
  transform: scale(1.08);
  transition: transform 200ms ease-out;
}

/* 4. Respetar las preferencias de movimiento reducido del usuario */
@media (prefers-reduced-motion: reduce) {
  #instrucciones .card {
    transition: none; /* Desactiva la animación */
  }

  #instrucciones .card:hover,
  #instrucciones .card:focus-visible {
    transform: none; /* Anula el cambio de posición y escala */
  }

  #instrucciones .card:hover .step-num,
  #instrucciones .card:focus-visible .step-num {
    transform: none; /* Anula el micro-efecto */
  }
}
