/* === Variables de marca === */
:root{
  --lavanda:#A586C7;
  --nude:#E9D8C8;
  --champagne:#F2E6D8;
  --gris:#EFEFF3;
  --grafito:#2A2A2A;
  --blanco:#fff;
}

/* === Reset mínimo === */
*{box-sizing:border-box}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--grafito);background:var(--blanco);}
img{max-width:100%;display:block}
h1,h2,h3{font-family:'Playfair Display',serif;margin:0 0 .5rem}
h1{font-size:clamp(2rem,5vw,3rem);line-height:1.1}
h2{font-size:clamp(1.6rem,3.5vw,2.2rem);line-height:1.2;margin-bottom:.75rem}
h3{font-size:1.1rem}
p{line-height:1.7;margin:.5rem 0 1rem}
small{opacity:.8}
a{text-decoration:none;color:inherit}

/* Containers */
.container{width:min(1120px,90%);margin-inline:auto}
.section{padding:72px 0}
.center{text-align:center}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.8);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid #eee}
.header-inner{display:flex;align-items:center;gap:16px;justify-content:space-between;padding:12px 0}
.brand{font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:700}
.brand span{color:var(--lavanda)}
.nav{display:none;gap:16px}
.nav a{opacity:.9}
@media(min-width:880px){.nav{display:flex}}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1rem;border-radius:999px;border:1px solid transparent;font-weight:600;cursor:pointer;transition:.2s}
.btn-primary{background:var(--lavanda);color:var(--blanco)}
.btn-primary:hover{filter:brightness(0.95)}
.btn-ghost{border-color:#ddd;background:#fff}
.btn-ghost:hover{background:#fafafa}
.btn-light{background:var(--gris);border-color:transparent}
.btns-row{display:flex;gap:.75rem;flex-wrap:wrap}

/* Hero */
.hero{background:linear-gradient(180deg,var(--champagne),var(--blanco));padding:48px 0 24px}
.hero-inner{display:grid;gap:24px;align-items:center;grid-template-columns:1fr}
.hero-copy em{font-style:italic}
.hero-cta{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.75rem}
.trust{margin-top:.5rem;display:flex;gap:.5rem;align-items:center}
.hero-media{order:-1}
.hero-media img{border-radius:20px;box-shadow:0 10px 30px rgba(0,0,0,.08)}
@media(min-width:900px){
  .hero-inner{grid-template-columns:1.1fr .9fr}
  .hero-media{order:unset}
}

/* About */
.grid-2{display:grid;gap:24px;grid-template-columns:1fr}
@media(min-width:900px){.grid-2{grid-template-columns:1fr 1fr}}
.about-photo{border-radius:18px;box-shadow:0 8px 24px rgba(0,0,0,.08)}
.values{display:flex;gap:8px;flex-wrap:wrap;padding:0;margin:8px 0 16px;list-style:none}
.values li{background:var(--gris);padding:.4rem .7rem;border-radius:999px;font-size:.9rem}
.diploma{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid #eee;border-radius:14px;padding:10px}
.diploma img{width:360px;border-radius:8px}

/* Services */
.services .cards{display:grid;gap:16px;grid-template-columns:1fr}
@media(min-width:740px){.services .cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.services .cards{grid-template-columns:repeat(4,1fr)}}
.card{background:#fff;border:1px solid #eee;border-radius:16px;overflow:hidden;display:flex;flex-direction:column}
.card img{aspect-ratio:4/3;object-fit:cover}
.card-body{padding:14px}
.tag{background:var(--champagne);padding:.2rem .5rem;border-radius:999px;font-size:.75rem}

/* Process */
.steps{display:grid;gap:8px;counter-reset:step}
.steps li{list-style:none;border:1px solid #eee;border-radius:12px;padding:.7rem .9rem;background:#fff;position:relative}
.steps li::before{counter-increment:step;content:counter(step);position:absolute;left:-10px;top:-10px;background:var(--lavanda);color:#fff;width:26px;height:26px;border-radius:999px;display:grid;place-items:center;font-weight:700}
.note{margin-top:10px;font-style:italic;color:#666}
.process-photos{display:grid;gap:14px;grid-template-columns:repeat(2,1fr);margin-top:16px}
.process-photos img{border-radius:12px;height:220px;object-fit:cover}
@media(min-width:900px){
  .process-photos{
    grid-template-columns:repeat(3,1fr); /* 3 columnas en desktop */
  }
  .process-photos img{
    height:260px;       /* más alto en desktop */
  }
}

/* Before / After slider */
.sliders{display:grid;gap:16px}
.ba-slider{position:relative;overflow:hidden;border-radius:16px;border:1px solid #eee;aspect-ratio:4/5;background:#000}
.ba-slider img{width:100%;height:100%;object-fit:cover;display:block}
.ba-resize{position:absolute;top:0;left:0;height:100%;width:50%;overflow:hidden;border-right:2px solid var(--lavanda)}
.ba-handle{position:absolute;top:0;left:50%;transform:translateX(-50%);height:100%;width:2px;background:var(--lavanda)}
.ba-handle::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:var(--lavanda);border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.2)}


/* === Ajuste de tamaño para sliders Antes/Después === */
.results .ba-slider{aspect-ratio:3/4; max-height:420px; margin-inline:auto;}
@media(min-width:768px){
  .results .ba-slider{aspect-ratio:4/5; max-height:520px;}
}

/* Pricing */
.pricing .salon-photos{display:grid;gap:12px}
.pricing .salon-photos img{border-radius:12px;height:160px;object-fit:cover}

/* Testimonials */
.testi-grid{display:grid;gap:12px}
blockquote{background:#fff;border:1px solid #eee;padding:16px;border-radius:12px}
blockquote cite{display:block;margin-top:8px;opacity:.7}

/* Testimonials (con imágenes) */
.review-grid{
  display:grid;
  gap:12px;
  grid-template-columns:1fr;
}
@media(min-width:740px){ .review-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1024px){ .review-grid{ grid-template-columns:repeat(3,1fr); } }

.review{
  background:#fff;
  border:1px solid #eee;
  border-radius:12px;
  padding:10px;
  box-shadow:0 4px 12px rgba(0,0,0,.04);
}

.review img{
  width:100%;
  /* Usamos contain para NO cortar texto de la captura */
  object-fit:contain;
  background:#fff;
  border-radius:8px;
  /* Mantén tamaño visual uniforme de capturas horizontales */
  aspect-ratio: 16/9;
}

.review figcaption{
  font-size:.85rem;
  color:#666;
  margin-top:8px;
  text-align:center;
}

/* CTA final */
.cta-final{background:linear-gradient(180deg,var(--blanco),var(--champagne))}
.contact-mini{margin-top:12px}
.contact-mini .btn{margin-top:8px}

/* Footer */
.site-footer{border-top:1px solid #eee;padding:18px 0;background:#fff}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.brand-footer{font-family:'Playfair Display',serif;font-weight:700}

/* WhatsApp Float */
.wa-float{position:fixed;right:16px;bottom:16px;background:#25D366;color:#fff;border-radius:999px;padding:.7rem 1rem;box-shadow:0 6px 16px rgba(0,0,0,.2);z-index:60}

/* Modal */
.modal{position:fixed;inset:0;display:none}
.modal[aria-hidden="false"]{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(2px)}
.modal-content{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(920px,92vw);height:min(720px,86vh);background:#fff;border-radius:16px;overflow:hidden;display:flex;flex-direction:column}
.modal-content h3{padding:12px 16px}
.modal-close{position:absolute;right:8px;top:6px;background:#fff;border:1px solid #eee;border-radius:999px;width:32px;height:32px;cursor:pointer}
#sbIframe{border:0;width:100%;height:100%}

/* Proceso (centrado sencillo) */
.process-photos{
  display:grid;
  gap:14px;
  grid-template-columns:repeat(3,1fr);
  margin-top:16px;

  /* clave para centrar el conjunto */
  max-width:900px;        /* ajusta 820–980px a gusto */
  margin-inline:auto;     /* centra el grid dentro del container */
  justify-items:center;   /* centra cada imagen en su celda */
}
.process-photos img{
  border-radius:12px;
  width:100%;
  height:220px;           /* o el valor que definiste */
  object-fit:cover;
}

/* responsive: menos columnas en pantallas chicas */
@media (max-width:900px){
  .process-photos{ grid-template-columns:repeat(2,1fr); max-width:620px; }
}
@media (max-width:560px){
  .process-photos{ grid-template-columns:1fr; max-width:360px; }
}

/* === Override: Diploma apilado y centrado === */
.about .diploma{
  display:flex;
  flex-direction:column;  /* texto debajo de la imagen */
  align-items:center;     /* centra horizontalmente */
  text-align:center;      /* centra el texto */
  gap:12px;
  max-width:720px;        /* limita el ancho para que se vea prolijo */
  margin:12px auto 0;     /* centra el bloque dentro de la columna */
  padding:14px;
}

.about .diploma img{
  width:100%;
  max-width:560px;        /* controla el tamaño máximo de la foto */
  height:auto;
  border-radius:12px;
}

/* Modal por encima de todo y con capas correctas */
.modal{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999;           /* por encima de header/WhatsApp */
}
.modal[aria-hidden="false"]{ display: block; }

.modal-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.5);
  backdrop-filter: blur(2px);
  z-index: 1;              /* debajo del contenido */
}

.modal-content{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  width: min(920px,92vw);
  height: min(720px,86vh);
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  z-index: 2;              /* por encima del backdrop */
}