/* ====== Base ====== */
:root {
  --pink-600: #db2777;
  --pink-500: #ec4899;
  --pink-400: #f472b6;
  --txt: #111827;
}

html,
body {
  max-width: 100%;
  overflow-x: hidden
}

* {
  box-sizing: border-box
}

img {
  max-width: 100%;
  height: auto;
  display: block
}

.font-display {
  font-family: 'Dancing Script', cursive
}

.font-body {
  font-family: 'Poppins', sans-serif
}

/* Header links */
.nav-link {
  color: #fff;
  transition: opacity .2s
}

.nav-link:hover {
  opacity: .9
}

/* Mobile menu */
.mobile-menu {
  background: linear-gradient(180deg, rgba(236, 72, 153, .98), rgba(244, 114, 182, .98));
  box-shadow: 0 10px 30px rgba(0, 0, 0, .15)
}

.mobile-link {
  display: block;
  color: #fff;
  padding: .5rem 0;
  font-weight: 600
}

.mobile-link:hover {
  opacity: .9
}

/* Sweet background pattern */
.sweet-bg {
  background-image:
    url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxwYXRoIGQ9Ik0wIDAgTCAxMDAgMCBMIDEwMCAxMDAgTCAwIDEwMCBaIiBmaWxsPSIjZmZmZmZmIiBvcGFjaXR5PSIwLjEiLz48L3N2Zz4='),
    url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAwIiBoZWlnaHQ9IjEwMCIgdmlld0JveD0iMCAwIDEwMCAxMDAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGNpcmNsZSBjeD0iNTAiIGN5PSI1MCIgcj0iNDAiIGZpbGw9IiNmZmYwZjYiIHN0cm9rZT0iI2ZmYzJkNyIgc3Ryb2tlLXdpZHRoPSIyIi8+PC9zdmc+');
  background-size: 100px 100px, 80px 80px;
  background-repeat: repeat;
  background-position: 0 0, 50px 50px;
}

/* Buttons */
.btn-primary {
  background: var(--pink-500);
  color: #fff;
  padding: .85rem 1.75rem;
  border-radius: 9999px;
  font-weight: 700;
  box-shadow: 0 10px 25px rgba(236, 72, 153, .25);
  transition: transform .2s, background .2s;
}

.btn-primary:hover {
  background: var(--pink-600);
  transform: translateY(-2px)
}

.btn-white {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .85rem 1.5rem;
  border-radius: 9999px;
  background: #fff;
  color: #be185d;
  font-weight: 700;
  transition: filter .2s;
}

.btn-white:hover {
  filter: brightness(.95)
}

.btn-soft {
  background: #ffe4ef;
  color: #9d174d;
  font-weight: 600;
  padding: .6rem 1rem;
  border-radius: 9999px;
  transition: background .2s, transform .2s;
}

.btn-soft:hover {
  background: #ffd3e5;
  transform: translateY(-1px)
}

.price {
  color: #be185d;
  font-weight: 800
}

/* Cards */
.card {
  background: #fff;
  border-radius: 0.75rem;
  overflow: hidden;
  box-shadow: 0 8px 18px rgba(233, 30, 99, .12);
  transition: transform .2s, box-shadow .2s
}

.card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 30px rgba(233, 30, 99, .22)
}

.card-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: #9d174d;
  margin-bottom: .25rem
}

.card-text {
  color: #4b5563;
  margin: .25rem 0 1rem
}

.badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: #ec4899;
  color: #fff;
  font-size: .7rem;
  font-weight: 800;
  padding: .25rem .5rem;
  border-radius: 9999px
}

/* Wedding card */
.wedding-card {
  background: linear-gradient(135deg, #fff, #ffe8f1);
  border-radius: .75rem;
  padding: 1.25rem;
  box-shadow: 0 8px 18px rgba(0, 0, 0, .06);
  text-align: center
}

/* Chips */
.chip {
  background: #f3f4f6;
  color: #374151;
  padding: .25rem .75rem;
  border-radius: 9999px;
  font-size: .875rem
}

/* Map wrapper keeps ratio and prevents overflow */
.map-wrapper {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  border-radius: .75rem;
  overflow: hidden;
  box-shadow: 0 10px 26px rgba(0, 0, 0, .1)
}

.map-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0
}

/* Footer */
.footer-link {
  color: #fff;
  opacity: .9
}

.footer-link:hover {
  opacity: 1
}

.newsletter-input {
  flex: 1;
  padding: .5rem .75rem;
  border-radius: 9999px 0 0 9999px;
  outline: none;
  color: #111827
}

.newsletter-btn {
  background: #7e0e42;
  padding: .5rem .9rem;
  border-radius: 0 9999px 9999px 0;
  color: #fff
}

/* WhatsApp floating */
.whats-btn {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 60;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #22c55e;
  color: #fff;
  font-size: 1.5rem;
  box-shadow: 0 12px 24px rgba(34, 197, 94, .35);
  animation: float 3s ease-in-out infinite;
}

.whats-btn:hover {
  filter: brightness(.95)
}

@keyframes float {
  0% {
    transform: translateY(0)
  }

  50% {
    transform: translateY(-8px)
  }

  100% {
    transform: translateY(0)
  }
}

/* Small tweaks */
@media (max-width:640px) {
  .btn-primary {
    width: 100%
  }
}

.hero-wave svg {
  transform: translateY(40px);
}