:root{
  --text:#231730;
  --muted: rgba(35,23,48,0.70);

  --bg0:#fff7fb;
  --bg1:#fff0f8;
  --bg2:#f6f0ff;

  --pink:#ff4fb8;
  --violet:#7a3cff;

  --card: rgba(255,255,255,0.72);
  --stroke: rgba(35,23,48,0.10);

  --shadow: 0 18px 45px rgba(26, 7, 35, 0.14);
  --shadow2: 0 10px 26px rgba(26, 7, 35, 0.10);

  --radius: 22px;
  --fadeH: 34px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  font-weight: 600;
  line-height:1.65;
  background: linear-gradient(180deg, var(--bg0), var(--bg1) 45%, var(--bg2));
}
.no-scroll{ overflow:hidden; }

.container{
  width:min(980px, calc(100% - 34px));
  margin-inline:auto;
}
.nowrap{ white-space: nowrap; }

/* ✅ 6 SECTION TINTS (much more distinct but still luxury/pastel) */
.section--tint-1{
  background: linear-gradient(180deg,
    rgba(255,255,255,0.00),
    rgba(255, 74, 160, 0.12),
    rgba(255,255,255,0.00)
  );
}
.section--tint-2{
  background: linear-gradient(180deg,
    rgba(255,255,255,0.00),
    rgba(160, 92, 255, 0.12),
    rgba(255,255,255,0.00)
  );
}
.section--tint-3{
  background: linear-gradient(180deg,
    rgba(255,255,255,0.00),
    rgba(255, 140, 200, 0.13),
    rgba(255,255,255,0.00)
  );
}
.section--tint-4{
  background: linear-gradient(180deg,
    rgba(255,255,255,0.00),
    rgba(200, 150, 255, 0.13),
    rgba(255,255,255,0.00)
  );
}
.section--tint-5{
  background: linear-gradient(180deg,
    rgba(255,255,255,0.00),
    rgba(255, 95, 130, 0.12),
    rgba(255,255,255,0.00)
  );
}
.section--tint-6{
  background: linear-gradient(180deg,
    rgba(255,255,255,0.00),
    rgba(130, 115, 255, 0.12),
    rgba(255,255,255,0.00)
  );
}

/* Highlighted subtitle blocks */
.hl{
  display:block;
  margin: 10px auto 14px;
  max-width: 78ch;
  padding: 12px 14px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(255,79,184,0.16), rgba(122,60,255,0.12));
  border: 1px solid rgba(35,23,48,0.10);
  box-shadow: 0 12px 26px rgba(26, 7, 35, 0.10);
  color: rgba(35,23,48,0.88);
  font-size: 18px;
  text-align:center;
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 800;
  letter-spacing: 0.15px;
}
.hl--hero{
  font-size: 18px;
  max-width: 64ch;
  padding: 14px 16px;
  border-radius: 22px;
}

/* Background */
.bg{ position:fixed; inset:0; pointer-events:none; z-index:-1; }
.bg__blob{
  position:absolute; width:560px; height:560px; border-radius:999px;
  filter: blur(40px); opacity:0.58;
}
.bg__blob--a{
  left:-180px; top:-120px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,79,184,0.58), transparent 60%),
    radial-gradient(circle at 70% 70%, rgba(182,107,255,0.46), transparent 62%);
}
.bg__blob--b{
  right:-220px; bottom:-180px;
  background:
    radial-gradient(circle at 30% 30%, rgba(122,60,255,0.36), transparent 62%),
    radial-gradient(circle at 70% 70%, rgba(255,123,214,0.46), transparent 60%);
}
.bg__sparkles{
  position:absolute; inset:0;
  background:
    radial-gradient(2px 2px at 12% 18%, rgba(255,255,255,0.95), transparent 60%),
    radial-gradient(2px 2px at 74% 14%, rgba(255,255,255,0.92), transparent 60%),
    radial-gradient(2px 2px at 56% 56%, rgba(255,255,255,0.88), transparent 60%),
    radial-gradient(2px 2px at 28% 72%, rgba(255,255,255,0.88), transparent 60%),
    radial-gradient(2px 2px at 86% 66%, rgba(255,255,255,0.92), transparent 60%);
  opacity:0.32;
}
.bg__pattern{
  position:absolute; inset:0; opacity:0.18;
  background:
    radial-gradient(circle at 20% 30%, rgba(255,79,184,0.18), transparent 35%),
    radial-gradient(circle at 80% 20%, rgba(122,60,255,0.14), transparent 35%),
    radial-gradient(circle at 70% 80%, rgba(255,123,214,0.14), transparent 35%),
    radial-gradient(circle at 30% 85%, rgba(182,107,255,0.12), transparent 35%);
}
.bg__grain{
  position:absolute; inset:0; opacity:0.10;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  background-size: 180px 180px;
  mix-blend-mode: soft-light;
}

/* Menu */
.menu-bubble{
  position:fixed; top:16px; right:16px; z-index:60;
  width:46px; height:46px; border-radius:18px;
  border:1px solid var(--stroke); background: rgba(255,255,255,0.88);
  box-shadow: var(--shadow2); cursor:pointer;
}
.menu-bubble span{
  display:block; width:18px; height:2px; margin:4px auto;
  background: rgba(35,23,48,0.86); border-radius:2px;
}
.menu-panel[hidden]{display:none!important}
.menu-panel{
  position:fixed; top:70px; right:16px; z-index:60;
  width:min(320px, calc(100% - 32px));
  border-radius:22px; background: rgba(255,255,255,0.94);
  border:1px solid var(--stroke); box-shadow: var(--shadow);
  overflow:hidden;
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.menu-panel a{
  display:block; padding:14px 16px; text-align:center; text-decoration:none;
  font-weight:800; color: rgba(35,23,48,0.92);
  border-top: 1px solid rgba(35,23,48,0.08);
}
.menu-panel a:first-child{border-top:none}
.menu-panel a:hover{background: rgba(255,79,184,0.08);}

/* Sections base */
.section{ position:relative; padding:24px 0 0; text-align:center; }
.section--soft{ background: linear-gradient(180deg, rgba(255,255,255,0.28), rgba(255,255,255,0.00)); }
.section--hero{ padding-top:20px; }
.section--tightTop{ padding-top:6px; }
.section--contactBottom{ padding-top: 12px; }

.fade{ height: var(--fadeH); margin-top:10px; }
.fade--down{
  background: linear-gradient(180deg, rgba(255,255,255,0.00), rgba(255,255,255,0.30), rgba(255,255,255,0.00));
}

/* Hero */
.hero__wrap{ display:flex; flex-direction:column; align-items:center; gap:14px; }
.hero__logo{
  width:min(520px, 92vw); height:auto; display:block; margin: 0 auto;
  filter: drop-shadow(0 18px 38px rgba(26, 7, 35, 0.18));
}

/* Titles */
.title{
  font-family: "Cinzel Decorative", serif;
  letter-spacing: 0.4px;
  margin: 6px 0 0;
  line-height:1.05;
}
.title--gradient{
  font-size: clamp(30px, 7.2vw, 54px);
  background: linear-gradient(90deg, var(--pink), var(--violet));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  text-shadow: 0 10px 30px rgba(255,79,184,0.10);
}
.title--pink{ font-size: clamp(28px, 6vw, 40px); color:#3b1032; }
.title--violet{ font-size: clamp(28px, 6vw, 40px); color:#2b1346; }

/* Meta */
.meta{
  display:flex; flex-direction:column; gap:6px; margin-top:4px;
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.meta__item{ font-size: 13px; color: rgba(35,23,48,0.72); font-weight: 700; }

/* Section head */
.section__head{ margin-bottom: 12px; }
.section__sub{
  margin: 0 auto; max-width: 70ch;
  color: rgba(35,23,48,0.74);
  font-size: 18px;
}

/* Stacks */
.stack{ display:flex; flex-direction:column; gap:14px; margin-top:12px; }
.stack--airy{ gap:22px; margin-top:22px; }
.stack--contactBottom{ margin-top: 8px; }

/* Cards */
.card{
  background: rgba(255,255,255,0.78);
  border:1px solid var(--stroke);
  border-radius: var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.card::before{
  content:""; position:absolute; inset:-1px;
  background:
    radial-gradient(600px 220px at 20% 0%, rgba(255,79,184,0.14), transparent 55%),
    radial-gradient(600px 220px at 80% 10%, rgba(122,60,255,0.12), transparent 58%);
  pointer-events:none;
}
.card::after{
  content:""; position:absolute; inset:-1px;
  background: linear-gradient(180deg, rgba(255,255,255,0.30), transparent 55%);
  opacity:0.55; pointer-events:none;
}
.card h3{
  position:relative; margin:0 0 8px;
  font-size:20px; font-weight:900; color: rgba(35,23,48,0.92);
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.card ul{
  position:relative; margin:0 auto; padding-left:18px; max-width:560px;
  text-align:left; color: rgba(35,23,48,0.78);
  font-size: 18px;
}
.card li{ margin:7px 0; }

/* Grid */
.grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:14px;
  margin-top: 12px;
}
@media (max-width: 820px){
  .grid{ grid-template-columns: 1fr; }
}

/* Note */
.note{
  border-radius: var(--radius);
  padding:14px 16px;
  background: rgba(255,255,255,0.78);
  border:1px dashed rgba(255,79,184,0.35);
  color: rgba(35,23,48,0.82);
  box-shadow: var(--shadow2);
  font-size: 18px;
}

/* CTA */
.cta-card{
  background: linear-gradient(135deg, rgba(255,79,184,0.18), rgba(122,60,255,0.14));
  border: 1px solid rgba(35,23,48,0.10);
  border-radius: 26px;
  box-shadow: var(--shadow);
  padding: 18px;
  text-align:center;
}
.cta-title{
  font-family: "Cinzel Decorative", serif;
  font-weight:900;
  letter-spacing:0.4px;
  font-size: 22px;
  margin:0;
  background: linear-gradient(90deg, var(--pink), var(--violet));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.cta-row{
  display:flex; gap:12px; width:100%;
  justify-content:center; flex-wrap:wrap;
  margin-top: 12px;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center; justify-content:center;
  padding:14px 16px;
  border-radius: 18px;
  text-decoration:none;
  font-weight:900;
  font-size:15px;
  letter-spacing:0.2px;
  border:1px solid var(--stroke);
  box-shadow: var(--shadow2);
  min-width: 220px;
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.btn--primary{
  color:#fff;
  border-color: rgba(255,255,255,0.20);
  background: linear-gradient(135deg, var(--pink), var(--violet));
}
.btn--ghost{
  color: rgba(35,23,48,0.92);
  background: rgba(255,255,255,0.80);
}

/* Prices */
.price{ padding-top: 34px; }
.price__big{ margin: 4px 0 10px; font-size: 22px; }
.price__amount{
  display:inline-block;
  font-family:"Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 900;
  font-size: 28px;
  letter-spacing: 0.2px;
  padding: 6px 12px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(255,79,184,0.18), rgba(122,60,255,0.14));
  border: 1px solid rgba(35,23,48,0.10);
  box-shadow: 0 10px 22px rgba(26, 7, 35, 0.10);
}
.price--featured{
  border-color: rgba(255,79,184,0.35);
  background: linear-gradient(180deg, rgba(255,79,184,0.13), rgba(255,255,255,0.78));
}

/* Badge */
.badge{
  position:absolute; top:12px;
  left:50%; transform: translateX(-50%);
  z-index:2;
  padding:6px 10px;
  border-radius:999px;
  background: linear-gradient(135deg, rgba(255,79,184,0.92), rgba(122,60,255,0.92));
  color:#fff;
  font-weight:900;
  font-size:11px;
  box-shadow: var(--shadow2);
  white-space: nowrap;
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
@media (min-width: 821px){
  .badge{ left:auto; right:14px; transform:none; }
}

/* Team */
.team-brand{ margin-top: 6px; margin-bottom: 8px; }
.title-like{
  font-family: "Cinzel Decorative", serif;
  font-weight: 900;
  font-size: 22px;
  background: linear-gradient(90deg, var(--pink), var(--violet));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.team-story{
  margin: 0 auto 14px;
  max-width: 70ch;
  font-size: 18px;
  color: rgba(35,23,48,0.80);
}
.team-img{
  width:100%;
  border-radius: 18px;
  margin-top: 10px;
  border: 1px solid rgba(35,23,48,0.10);
  box-shadow: var(--shadow2);
}
.team-fallback{
  margin-top: 10px;
  color: rgba(35,23,48,0.68);
  padding: 14px;
  border-radius: 18px;
  background: rgba(255,255,255,0.62);
  border: 1px dashed rgba(35,23,48,0.12);
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* WhatsApp floating */
.wa-float{
  position:fixed;
  right:12px;
  bottom:22px;
  z-index:40;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 14px;
  border-radius: 999px;
  text-decoration:none;
  font-weight:900;
  letter-spacing:0.2px;
  color:#0c3b22;
  background: linear-gradient(135deg, #25d366, #b7ffd0);
  box-shadow: var(--shadow);
  border: 1px solid rgba(255,255,255,0.35);
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* Footer + modals */
.footer{
  padding: 22px 0 22px;
  border-top: 1px solid rgba(35,23,48,0.08);
  background: rgba(255,255,255,0.45);
  text-align:center;
}
.footer__brand{
  font-family:"Cinzel Decorative", serif;
  font-weight:900;
  font-size:18px;
  color: rgba(35,23,48,0.92);
}
.footer__small{
  color: rgba(35,23,48,0.70);
  font-size:12.5px;
  margin-top: 6px;
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.footer a{ color: rgba(35,23,48,0.88); }

.footer__links{
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top: 12px;
}
.legal-pill{
  border:1px solid var(--stroke);
  background: rgba(255,255,255,0.74);
  box-shadow: var(--shadow2);
  padding:10px 12px;
  border-radius:999px;
  font-weight:900;
  cursor:pointer;
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.legal-pill:hover{ background: rgba(255,79,184,0.08); }

.footer__bottom{
  margin-top: 14px;
  color: rgba(35,23,48,0.62);
  font-size:12.5px;
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.modal{
  position:fixed; inset:0; display:none;
  align-items:center; justify-content:center;
  padding: 18px;
  background: rgba(20, 10, 30, 0.28);
  backdrop-filter: blur(6px);
  z-index:80;
}
.modal.is-open{ display:flex; }
.modal__card{
  width:min(560px, 100%);
  border-radius: 22px;
  background: rgba(255,255,255,0.95);
  border:1px solid rgba(35,23,48,0.10);
  box-shadow: var(--shadow);
  padding:18px;
  text-align:left;
  position:relative;
  font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  font-weight: 600;
}
.modal__card h3{
  margin:0 0 8px;
  font-size:20px;
  font-weight:900;
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.modal__card p{ margin:0 0 10px; color: rgba(35,23,48,0.78); font-size:18px; }
.modal__close{
  position:absolute; top:12px; right:12px;
  width:40px; height:40px;
  border-radius: 14px;
  border:1px solid rgba(35,23,48,0.12);
  background: rgba(255,255,255,0.90);
  cursor:pointer;
  font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* Mobile */
@media (max-width: 900px){
  .btn{ width:100%; max-width: 520px; }
  .menu-panel{ right:12px; width: calc(100% - 24px); }
  .menu-bubble{ right:12px; top:12px; }
  .hl{ font-size: 16px; }
  .hl--hero{ font-size: 16.5px; }
}