:root {
  --violet: #6f3cff;
  --violet-dark: #3e237d;
  --lila: #d9c8ff;
  --pink: #ff8cc8;
  --soft-pink: #ffe5f1;
  --hot-pink: #ff2f92;
  --coral: #ff7a7a;
  --yellow: #ffe875;
  --sea: #4fd6e8;
  --sand: #fff0d8;
  --cream: #fff8ee;
  --ink: #24133f;
  --muted: #6f6280;
  --white: #ffffff;
  --line: rgba(36, 19, 63, .13);
  --shadow: 0 24px 70px rgba(255, 47, 146, .18);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Manrope, system-ui, -apple-system, Segoe UI, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at 8% 0%, rgba(255,47,146,.34), transparent 30%),
    radial-gradient(circle at 92% 6%, rgba(255,140,200,.42), transparent 28%),
    radial-gradient(circle at 80% 30%, rgba(79,214,232,.26), transparent 24%),
    linear-gradient(180deg, #fff0d8 0%, #ffe5f1 34%, #fff8ee 72%, #f7ecff 100%);
}
body:before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .45;
  background-image: radial-gradient(rgba(255,47,146,.20) 1px, transparent 1px);
  background-size: 22px 22px;
  mask-image: linear-gradient(180deg, #000, transparent 74%);
}
a { color: inherit; text-decoration: none; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px clamp(18px, 4vw, 56px);
  background: rgba(255, 229, 241, .88);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,47,146,.16);
}
.brand { font-weight: 900; letter-spacing: -.04em; color: var(--hot-pink); font-size: 18px; }
.nav { display: flex; gap: 20px; align-items: center; font-size: 14px; font-weight: 800; }
.hero {
  min-height: auto;
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, .92fr);
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
  padding: clamp(28px, 4vw, 52px) clamp(18px, 6vw, 88px) clamp(22px, 3vw, 34px);
  overflow: hidden;
}
.hero-copy h1 {
  font-family: Fraunces, Manrope, serif;
  text-transform: uppercase;
  font-size: clamp(48px, 8.2vw, 104px);
  line-height: .88;
  letter-spacing: -.07em;
  margin: 12px 0 24px;
  max-width: 980px;
}
.lead { font-size: clamp(18px, 2vw, 24px); line-height: 1.45; color: #4f3d68; max-width: 760px; }
.eyebrow { margin: 0; text-transform: uppercase; letter-spacing: .14em; color: var(--hot-pink); font-size: 12px; font-weight: 900; }
.hero-facts { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 28px; }
.hero-facts span { background: rgba(255,255,255,.84); border: 1px solid rgba(255,47,146,.18); padding: 12px 14px; border-radius: 16px; font-size: 14px; box-shadow: 0 12px 34px rgba(255,47,146,.08); }
.hero-facts strong { color: var(--hot-pink); }
.hero-image {
  min-height: 430px;
  border-radius: 38px;
  background:
    linear-gradient(180deg, rgba(255,47,146,.08), rgba(62,35,125,.14)),
    url('playa-dia.jpg') center/cover;
  box-shadow: var(--shadow);
  border: 8px solid rgba(255,255,255,.78);
  transform: rotate(1.4deg);
}
.section { padding: clamp(36px, 5.5vw, 72px) clamp(18px, 6vw, 88px); position: relative; }
h2 { font-family: Fraunces, Manrope, serif; font-size: clamp(32px, 4.8vw, 62px); line-height: .97; letter-spacing: -.06em; margin: 10px 0 0; }
.section-title { max-width: 900px; margin-bottom: 28px; }
.centered { text-align: center; margin-left: auto; margin-right: auto; }
.service-layout { display: grid; grid-template-columns: .78fr 1.22fr; gap: 22px; align-items: stretch; }
.beach-tile {
  min-height: 620px;
  border-radius: 36px;
  background:
    linear-gradient(180deg, rgba(255,47,146,.08), rgba(255,140,200,.18)),
    url('playa-noche.jpg') center/cover;
  box-shadow: var(--shadow);
  border: 8px solid rgba(255,255,255,.75);
}
.service-list { display: grid; gap: 14px; }
.service-item {
  display: block;
  padding: 20px 22px;
  border-radius: 28px;
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(255,47,146,.16);
  box-shadow: 0 14px 44px rgba(255,47,146,.07);
}
.service-item span { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 999px; background: var(--soft-pink); color: var(--hot-pink); font-weight: 900; }
.service-item h3 { margin: 0; font-size: 20px; letter-spacing: -.025em; }
.included-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 22px; }
.included-grid article { padding: 26px; border-radius: 30px; background: rgba(255,255,255,.84); border: 1px solid rgba(255,47,146,.16); box-shadow: 0 14px 44px rgba(255,47,146,.07); }
.included-grid h3 { margin: 0 0 14px; font-size: 24px; letter-spacing: -.035em; color: var(--hot-pink); }
ul { margin: 0; padding-left: 20px; color: #4f3d68; line-height: 1.8; font-weight: 700; }
.included-grid p { margin: 14px 0 0; color: var(--muted); font-weight: 800; }
.intro { display: grid; grid-template-columns: .9fr 1.1fr; gap: 34px; align-items: start; background: linear-gradient(180deg, rgba(255,229,241,.42), rgba(255,248,238,.16)); }
.intro-copy p, .reserve-copy p { color: #4f3d68; font-size: 18px; line-height: 1.65; }
.intro-copy p:first-child { margin-top: 0; }
.price { background: linear-gradient(180deg, rgba(255,229,241,.42), rgba(255,248,238,.16)); padding-top: clamp(28px, 4vw, 48px); }
.price .section-title { margin-bottom: 20px; }
.price h2 { font-size: clamp(30px, 4vw, 52px); }
.price-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; align-items: stretch; }
.price-card {
  min-height: 150px;
  padding: 22px;
  border-radius: 26px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(255,47,146,.22);
  box-shadow: 0 14px 36px rgba(255,47,146,.10);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.price-card h3 { margin: 8px 0 8px; font-family: Fraunces, Manrope, serif; font-size: clamp(27px, 2.75vw, 38px); line-height: .96; letter-spacing: -.052em; }
.price-card p:not(.eyebrow) { color: var(--muted); line-height: 1.45; margin: 0; font-size: 15px; }
.main-price { background: linear-gradient(135deg, var(--hot-pink), #ff93c7 54%, var(--violet)); color: white; }
.main-price .eyebrow, .main-price p:not(.eyebrow) { color: white; }
.reserve-mini { background: #fff0f7; }
.reserve { display: grid; grid-template-columns: .9fr 1.1fr; gap: 26px; align-items: start; }
.form { padding: 24px; display: grid; gap: 14px; background: rgba(255,255,255,.84); border: 1px solid rgba(255,47,146,.18); border-radius: 28px; box-shadow: 0 14px 44px rgba(255,47,146,.07); }
label { display: grid; gap: 8px; font-weight: 900; font-size: 14px; }
input, textarea { width: 100%; border: 1px solid rgba(255,47,146,.18); border-radius: 16px; padding: 14px 15px; font: inherit; background: #fff; color: var(--ink); outline-color: var(--hot-pink); }
textarea { resize: vertical; }
.button { display: inline-flex; align-items: center; justify-content: center; border: 0; border-radius: 999px; padding: 15px 22px; font-weight: 900; cursor: pointer; font-size: 15px; }
.primary { background: linear-gradient(135deg, var(--hot-pink), var(--coral)); color: white; box-shadow: 0 16px 34px rgba(255, 47, 146, .30); }
.faq { max-width: 1120px; margin: 0 auto; }
.faq-list { display: grid; gap: 14px; }
.qa {
  padding: 24px 26px;
  border-radius: 28px;
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(255,47,146,.18);
  box-shadow: 0 14px 44px rgba(255,47,146,.07);
}
.qa h3 { margin: 0 0 10px; font-size: 20px; letter-spacing: -.025em; color: var(--hot-pink); }
.qa p { margin: 0 0 12px; color: var(--muted); line-height: 1.6; }
.qa p:last-child { margin-bottom: 0; }
.footer { display: flex; justify-content: space-between; gap: 18px; padding: 28px clamp(18px, 6vw, 88px); border-top: 1px solid rgba(255,47,146,.16); color: var(--muted); }
.footer div { display: flex; gap: 18px; flex-wrap: wrap; }
@media (max-width: 980px) {
  .hero, .intro, .service-layout, .reserve { grid-template-columns: 1fr; }
  .price-grid { grid-template-columns: 1fr 1fr; }
  .included-grid { grid-template-columns: 1fr 1fr; }
  .hero-image { min-height: 440px; }
  .beach-tile { min-height: 360px; }
}
@media (max-width: 640px) {
  .nav a { display: none; }
  .hero { min-height: auto; }
  .price-grid, .included-grid { grid-template-columns: 1fr; }
  .main-price { grid-column: auto; }
  .footer { flex-direction: column; }
}

.hidden { display: none !important; }
.form-note { color: var(--muted); font-size: 13px; line-height: 1.45; margin: 0; }
.thank-you-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
}
.thank-you-card {
  max-width: 760px;
  padding: clamp(32px, 6vw, 72px);
  border-radius: 34px;
  background: rgba(255,255,255,.82);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  text-align: center;
}
.thank-you-card h1 {
  font-family: Fraunces, Manrope, serif;
  font-size: clamp(46px, 8vw, 86px);
  line-height: .9;
  letter-spacing: -.06em;
  margin: 12px 0 18px;
}
.thank-you-card p:not(.eyebrow) {
  color: var(--muted);
  font-size: 18px;
  line-height: 1.6;
  margin-bottom: 28px;
}
