:root{
  --pink:#F2C4DD;
  --gold:#C9A368;
  --gold2:#DFC18C;
  --brown:#977959;
  --black:#100F0F;
  --white:#FFFFFF;
  --bg: #FFF7FB;
  --card: rgba(255,255,255,.78);
  --shadow: 0 10px 30px rgba(16,15,15,.12);
  --radius: 22px;
  --max: 1120px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: var(--black);
  background:
    radial-gradient(1000px 600px at 10% 0%, rgba(242,196,221,.45), transparent 60%),
    radial-gradient(900px 600px at 90% 20%, rgba(201,163,104,.28), transparent 60%),
    linear-gradient(180deg, var(--bg), #FFFFFF 35%, #FFF7FB);
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
.container{width:min(var(--max), calc(100% - 40px)); margin:0 auto}
/* Header */
header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(12px);
  background: rgba(255,255,255,.62);
  border-bottom: 1px solid rgba(16,15,15,.06);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 0;
  gap:14px;
}
.brand{display:flex; align-items:center; gap:12px; min-width:240px}
.brand img{width:44px;height:44px;border-radius:50%; box-shadow:0 6px 16px rgba(16,15,15,.16)}
.brand .t1{font-weight:750; letter-spacing:.2px}
.brand .t2{font-size:12.5px; opacity:.75; margin-top:2px}
nav ul{display:flex; gap:18px; list-style:none; padding:0;margin:0; flex-wrap:wrap; justify-content:center}
nav a{font-size:14px; opacity:.82; padding:10px 8px; border-radius:999px}
nav a:hover{background:rgba(242,196,221,.35); opacity:1}
.cta{display:flex; align-items:center; gap:10px; justify-content:flex-end; min-width:240px}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px; padding:10px 14px; border-radius:999px;
  border:1px solid rgba(16,15,15,.10);
  background: rgba(255,255,255,.75);
  box-shadow: 0 10px 24px rgba(16,15,15,.10);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  font-weight:650; font-size:14px;
}
.btn:hover{transform: translateY(-2px); box-shadow:0 14px 30px rgba(16,15,15,.14); background: rgba(255,255,255,.92)}
.btn.primary{
  border-color: rgba(201,163,104,.55);
  background: linear-gradient(135deg, rgba(242,196,221,.85), rgba(201,163,104,.50));
}
.btn .dot{width:10px;height:10px;border-radius:50%; background: var(--gold)}

/* Hero */
.hero{padding: 36px 0 18px}
.heroGrid{
  display:grid; gap:22px;
  grid-template-columns: 1.1fr .9fr;
  align-items:stretch;
}
@media (max-width: 980px){
  .heroGrid{grid-template-columns:1fr}
  .cta{min-width:auto}
  .brand{min-width:auto}
}
.card{
  background: var(--card);
  border:1px solid rgba(16,15,15,.06);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.heroCopy{padding:28px 26px}
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 12px; border-radius:999px;
  background: rgba(242,196,221,.35);
  border: 1px solid rgba(242,196,221,.55);
  font-size:13px; font-weight:650;
}
h1{margin:14px 0 10px; font-size: clamp(30px, 4vw, 46px); line-height:1.05}
.sub{font-size:16px; opacity:.82; line-height:1.55; margin:0 0 18px}
.badges{display:flex; flex-wrap:wrap; gap:10px; margin: 14px 0 20px}
.badge{
  font-size:13px; padding:8px 10px; border-radius:999px;
  border:1px solid rgba(201,163,104,.40);
  background: rgba(255,255,255,.65);
}
.heroActions{display:flex; flex-wrap:wrap; gap:10px; margin-top: 10px}
.heroMedia{
  overflow:hidden;
  position:relative;
}
.heroMedia .img{
  height:100%;
  min-height: 340px;
  background: url("assets/img/portada.webp") center/cover no-repeat;
}
.heroMedia:after{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(900px 520px at 80% 10%, rgba(242,196,221,.18), transparent 55%),
              linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,247,251,.55));
}
.heroMedia .overlay{
  position:absolute; inset:auto 18px 18px 18px;
  padding:14px 14px;
  border-radius: 18px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(16,15,15,.06);
}
.overlay strong{display:block; font-size:14px}
.overlay span{display:block; font-size:12.5px; opacity:.75; margin-top:3px}

/* Sections */
section{padding: 26px 0}
.sectionTitle{display:flex; align-items:flex-end; justify-content:space-between; gap:18px; margin-bottom:14px}
.sectionTitle h2{margin:0; font-size:24px}
.sectionTitle p{margin:0; opacity:.72; font-size:14px}
.grid3{display:grid; grid-template-columns: repeat(3,1fr); gap:14px}
@media (max-width: 920px){.grid3{grid-template-columns:1fr}}
.service{
  padding:18px 16px;
}
.service h3{margin:0 0 8px; font-size:16px}
.service p{margin:0; opacity:.78; line-height:1.5; font-size:14px}
.icon{
  width:44px;height:44px;border-radius:14px;
  background: linear-gradient(135deg, rgba(242,196,221,.75), rgba(201,163,104,.35));
  display:grid; place-items:center;
  margin-bottom:10px;
  border: 1px solid rgba(201,163,104,.30);
}
.icon svg{width:22px;height:22px; opacity:.9}
/* Gallery */
.gallery{display:grid; grid-template-columns: repeat(12, 1fr); gap:12px}
.gItem{grid-column: span 4; overflow:hidden; border-radius: 18px; position:relative}
.gItem img{width:100%; height:260px; object-fit:cover; display:block; transition: transform .25s ease}
.gItem:hover img{transform: scale(1.03)}
@media (max-width: 980px){.gItem{grid-column: span 6}}
@media (max-width: 640px){.gItem{grid-column: span 12} .gItem img{height:240px}}
.gItem .cap{
  position:absolute; inset:auto 10px 10px 10px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(16,15,15,.06);
  padding:10px 10px;
  border-radius: 14px;
  font-size:13px; opacity:.92;
}
/* Promo cards */
.promos{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px}
@media (max-width: 920px){.promos{grid-template-columns: 1fr}}
.promo{overflow:hidden}
.promo img{width:100%; height:320px; object-fit:cover; display:block}
.promo .pbody{padding:14px 14px}
.promo .pbody strong{display:block}
.promo .pbody span{display:block; opacity:.75; font-size:13px; margin-top:4px}
/* Video + socials + contact */
.twoCol{display:grid; grid-template-columns: 1fr 1fr; gap:14px}
@media (max-width: 980px){.twoCol{grid-template-columns:1fr}}
.embed{overflow:hidden; border-radius: 18px}
.embed iframe{width:100%; height:340px; border:0; display:block}
.small iframe{height:280px}
.contact{padding:18px 16px}
.formRow{display:grid; grid-template-columns: 1fr 1fr; gap:10px}
@media (max-width: 720px){.formRow{grid-template-columns:1fr}}
input, textarea{
  width:100%;
  padding:12px 12px;
  border-radius: 14px;
  border:1px solid rgba(16,15,15,.12);
  background: rgba(255,255,255,.78);
  outline:none;
  font-size:14px;
}
textarea{min-height:120px; resize:vertical}
label{font-size:13px; opacity:.8; display:block; margin: 8px 0 6px}
.formActions{display:flex; flex-wrap:wrap; gap:10px; margin-top:10px}
.note{font-size:12.5px; opacity:.7; line-height:1.45}
.map iframe{height:320px}
/* Footer */
footer{padding: 26px 0 34px; opacity:.86}
footer .wrap{display:flex; flex-wrap:wrap; gap:10px; justify-content:space-between; align-items:center}
footer small{opacity:.75}

/* Floating WhatsApp */
.whats{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 80;
}
.whats a{
  width:56px;height:56px;
  border-radius: 18px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(242,196,221,.92), rgba(201,163,104,.55));
  box-shadow: 0 16px 36px rgba(16,15,15,.18);
  border: 1px solid rgba(201,163,104,.55);
}
.whats svg{width:28px;height:28px}
/* Fade-in */
.reveal{opacity:0; transform: translateY(14px); transition: opacity .6s ease, transform .6s ease}
.reveal.on{opacity:1; transform: translateY(0)}