*{box-sizing:border-box}
:root{
  --bg:#fff7f9;
  --bg-soft:#fff0f4;
  --card:#ffffff;
  --text:#342a30;
  --muted:#74656d;
  --accent:#ea90a7;
  --accent-dark:#c76a83;
  --line:#f3d8e0;
  --line-strong:#ebb8c6;
  --shadow:0 22px 55px rgba(176, 89, 116, 0.14);
}
html{scroll-behavior:smooth}
body{margin:0;font-family:'DM Sans',sans-serif;background:linear-gradient(180deg,#fffdfd 0%,#fff7f9 45%,var(--bg) 100%);color:var(--text)}
a{text-decoration:none;color:inherit} img{max-width:100%;display:block}
.container{width:min(1120px,calc(100% - 32px));margin:0 auto}
.sticky-bar{position:sticky;top:0;z-index:30;display:flex;justify-content:center;gap:14px;padding:10px 12px;background:#2f272b;color:#fff;font-size:14px}
.sticky-bar a{padding:8px 14px;border-radius:999px;background:#fff;color:#2f272b;font-weight:700}
.site-header{position:sticky;top:44px;z-index:20;background:rgba(255,248,248,.9);backdrop-filter:blur(12px);border-bottom:1px solid rgba(241,215,220,.7)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px 0}
.brand{display:flex;flex-direction:column}.brand-script{font-family:'Playfair Display',serif;font-size:32px;color:var(--accent-dark)}.brand-sub{text-transform:uppercase;letter-spacing:.28em;font-size:11px;color:var(--muted)}
.menu{display:flex;gap:22px;color:var(--muted);font-size:14px}
.hero{padding:72px 0 90px}.hero-grid,.facials-top,.contact-box,.wide-card,.story-card.reverse{display:grid;grid-template-columns:1.02fr .98fr;gap:30px;align-items:center}
.hero-card,.story-card,.review-box,.contact-box,.mini,.pack-card{background:var(--card);border:1px solid rgba(255,255,255,.8);box-shadow:var(--shadow);border-radius:32px}
.hero-card{padding:34px}.eyebrow,.section-kicker,.pill{text-transform:uppercase;letter-spacing:.2em;font-size:12px;color:var(--accent-dark)}
h1,h2,h3{font-family:'Playfair Display',serif;line-height:1.05;margin:0 0 14px} h1{font-size:clamp(42px,5.4vw,70px)} h2{font-size:clamp(34px,4vw,50px)} h3{font-size:30px}
p{color:var(--muted);line-height:1.8;margin:0 0 14px}.lead{font-size:18px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 20px;border-radius:999px;background:var(--accent);color:#fff;font-weight:700;border:1px solid var(--accent)}.btn-soft{background:transparent;color:var(--text);border-color:var(--line)}

.btncenter{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:14px 20px;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
  font-weight:700;
  border:1px solid var(--accent);
  width:fit-content;
  margin:0 auto;
}

.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin:24px 0}.chips{display:flex;gap:10px;flex-wrap:wrap}.chips span,.mini span,.pill{display:inline-flex;align-items:center;padding:9px 13px;border-radius:999px;background:var(--bg-soft);color:var(--accent-dark)}
.hero-collage{position:relative;min-height:520px}.hero-collage img{position:absolute;object-fit:cover;border-radius:28px;box-shadow:var(--shadow)}.img-a{width:62%;height:72%;left:0;top:0}.img-b{width:46%;height:44%;right:0;bottom:10%}.metric-card{position:absolute;left:12%;bottom:-62px;background:#fff;padding:18px 20px;border-radius:24px;box-shadow:var(--shadow);max-width:220px;z-index:2}
.section{padding:48px 0}.benefit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.benefit-grid article{background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:var(--shadow)}
.section-heading{text-align:center;max-width:760px;margin:0 auto 24px}.wide-card{padding:18px;margin-bottom:22px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,245,246,.96))}.wide-card.reverse .story-media{order:2}.story-media img,.facial-visual img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:24px}.story-copy{padding:10px 8px}.story-copy ul{margin:14px 0 0;padding-left:18px;color:var(--muted);line-height:1.8}.accent-card{outline:2px solid rgba(228,143,157,.24)}
.pack-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}.pack-card{padding:22px;text-align:center}.pack-card span{display:block;color:var(--muted);margin-bottom:8px}.pack-card strong{font-size:34px;font-family:'Playfair Display',serif;color:var(--accent-dark)}.pack-card.featured{background:linear-gradient(180deg,#fff,#fff1f4)}.pack-card small{display:block;color:var(--accent-dark);margin-top:6px}
.featured-mini{background:linear-gradient(180deg,#fff,#fff2f4)}.facial-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}.mini{padding:22px}.mini .meta{display:flex;justify-content:space-between;align-items:center;margin-top:14px;color:var(--accent-dark);font-weight:700}.accent-mini{outline:2px solid rgba(228,143,157,.28)}
.review-box{padding:28px;text-align:center;background:linear-gradient(135deg,#fff,#fff3f4)}.contact-box{padding:30px;justify-content:space-between}.contact-box ul{list-style:none;padding:0;margin:0;display:grid;gap:12px;color:var(--muted)}.contact-cta{display:flex;flex-direction:column;gap:12px;min-width:240px}
@media (max-width:1020px){.menu{display:none}.hero-grid,.facials-top,.contact-box,.wide-card,.wide-card.reverse{grid-template-columns:1fr}.hero-collage{min-height:420px}.benefit-grid,.pack-grid,.facial-cards{grid-template-columns:repeat(2,1fr)}.site-header{top:42px}}
@media (max-width:700px){.sticky-bar{flex-direction:column;align-items:center}.site-header{top:78px}.container{width:min(100% - 24px,1120px)}.hero{padding-top:36px}.hero-card,.story-card,.review-box,.contact-box,.mini,.pack-card,.benefit-grid article{border-radius:24px}.hero-collage{min-height:360px}.metric-card{left:6%;right:6%;max-width:none;bottom:-26px}.benefit-grid,.pack-grid,.facial-cards{grid-template-columns:1fr}}

/* palette ajustada para recuperar el rosa del primer concepto instagram */
.hero-card,.story-card,.review-box,.contact-box,.mini,.pack-card,.benefit-grid article{border:1px solid rgba(255,255,255,.86)}
.site-header{background:rgba(255,247,249,.92);border-bottom:1px solid rgba(243,216,224,.88)}
.btn{box-shadow:0 14px 32px rgba(199,106,131,.18)}
.btn:hover{background:var(--accent-dark);border-color:var(--accent-dark)}
.pack-card.featured,.featured-mini{background:linear-gradient(180deg,#fff,#fff0f5)}
.wide-card{background:linear-gradient(180deg,rgba(255,255,255,.99),rgba(255,240,245,.98))}
.review-box{background:linear-gradient(135deg,#fff,#fff0f4)}
.accent-card,.accent-mini{outline-color:rgba(234,144,167,.33)}
.metric-card{border:1px solid var(--line);background:rgba(255,255,255,.96)}


/* bloque treatwell */
.treatwell-section{padding-top:18px}
.treatwell-block{display:grid;grid-template-columns:.95fr 1.05fr;gap:22px;align-items:stretch;background:linear-gradient(180deg,rgba(255,255,255,.99),rgba(255,240,245,.98));border:1px solid var(--line);border-radius:32px;box-shadow:var(--shadow);padding:24px}
.treatwell-intro{padding:10px 8px}
.treatwell-intro h2{margin-bottom:12px}
.treatwell-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}
.treatwell-widget-wrap{background:linear-gradient(180deg,#fffbfd 0%,#fff1f5 100%);border:1px solid var(--line);border-radius:24px;padding:18px;display:flex;align-items:center;justify-content:center;min-height:320px}
.widget-placeholder{width:100%;border:2px dashed var(--line-strong);border-radius:20px;background:rgba(255,255,255,.82);padding:24px;text-align:left}
.widget-placeholder strong{display:block;font-family:'Playfair Display',serif;font-size:26px;color:var(--accent-dark);margin-bottom:10px}
.widget-placeholder p{margin-bottom:14px}
.widget-placeholder pre{margin:0;white-space:pre-wrap;word-break:break-word;padding:16px;border-radius:16px;background:#fff7fa;border:1px solid var(--line);color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;line-height:1.6}
.widget-placeholder code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#fff3f6;padding:2px 6px;border-radius:8px}
@media (max-width:1020px){.treatwell-block{grid-template-columns:1fr}}


/* widget treatwell activo */
.treatwell-widget-wrap iframe{
  display:block;
  width:100%;
  min-height:900px;
  border:0;
  border-radius:20px;
  background:#fff;
}
@media (max-width:700px){
  .treatwell-widget-wrap iframe{min-height:1100px}
}

/* contacto + mapa */
.contact-layout{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:24px;
  align-items:stretch;
}
.contact-info{
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.contact-info p{max-width:560px}
.map-card{
  background:linear-gradient(180deg,#fff 0%,#fff2f6 100%);
  border:1px solid var(--line);
  border-radius:28px;
  padding:22px;
  box-shadow:var(--shadow);
}
.map-card h3{
  margin-bottom:8px;
  font-size:28px;
}
.map-card p{
  margin-bottom:16px;
}
.map-embed{
  overflow:hidden;
  border-radius:20px;
  border:1px solid var(--line);
  min-height:360px;
  background:#fff;
}
.map-embed iframe{
  display:block;
  width:100%;
  min-height:360px;
}
.map-link{
  display:inline-flex;
  margin-top:16px;
  font-weight:700;
  color:var(--accent-dark);
}
@media (max-width:1020px){
  .contact-layout{grid-template-columns:1fr}
}


/* mejora de Treatwell en móvil */
.treatwell-desktop{display:block;width:100%}
.treatwell-mobile-card{display:none;width:100%;text-align:left;background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:var(--shadow)}
.treatwell-mobile-card h3{font-size:28px;margin-bottom:10px}
.treatwell-mobile-card p{margin-bottom:16px}
@media (max-width:700px){
  .treatwell-section .container{width:100%}
  .treatwell-block{padding:16px;border-radius:0;border-left:0;border-right:0}
  .treatwell-intro{padding:4px 4px 0}
  .treatwell-widget-wrap{padding:0;background:transparent;border:0;min-height:auto}
  .treatwell-desktop{display:none}
  .treatwell-mobile-card{display:block}
}


.instagram-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--primary-dark);
  font-weight: 500;
}

.instagram-link svg {
  color: #E1306C; /* color oficial Instagram */
  transition: transform 0.2s ease;
}

.instagram-link:hover svg {
  transform: scale(1.15);
}

.flag-br {
  display: inline-block;
  width: 18px;
  height: 18px;
  margin-left: 6px;
  vertical-align: -3px;
}