/* SERVICES PAGE */

/* HERO */
.services-hero {
  position: relative;
  height: 85vh;
  min-height: 560px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  padding-top: var(--nav-h);
}
.services-hero-bg {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  background-color: var(--purple);
  animation: zoomIn 10s ease forwards;
}
.services-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(15,5,41,.6) 0%, rgba(15,5,41,.35) 50%, rgba(15,5,41,.8) 100%);
  z-index: 1;
}
.services-hero-content {
  position: relative; z-index: 2;
  max-width: 700px; padding: 0 2rem;
}
.services-hero-content h1 { color: #fff; margin-bottom: 1.2rem; }
.services-hero-content p { color: rgba(255,255,255,.6); font-size: .95rem; font-weight: 300; line-height: 1.8; }

/* SERVICES LIST */
.services-list-section { padding: 8rem 0; }
.sl-header { margin-bottom: 5rem; }
.sl-grid { display: flex; flex-direction: column; gap: 0; }

.sl-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 520px;
  border-top: 1px solid rgba(15,5,41,.08);
}
.sl-item.reverse { direction: rtl; }
.sl-item.reverse > * { direction: ltr; }

.sl-photo { overflow: hidden; }
.sl-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .8s ease;
  display: block;
}
.sl-item:hover .sl-photo img { transform: scale(1.05); }

.sl-text {
  display: flex; flex-direction: column;
  justify-content: center;
  padding: 4rem 4.5rem;
  background: var(--cream);
}
.sl-item.reverse .sl-text { background: #fff; }
.sl-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: .9rem; font-style: italic;
  color: var(--pink); display: block;
  margin-bottom: 1rem;
}
.sl-text h3 { font-size: 1.8rem; margin-bottom: 1rem; }
.sl-text p { font-size: .88rem; line-height: 1.9; color: var(--mid); font-weight: 300; margin-bottom: 1.5rem; }
.sl-text ul { list-style: none; margin-bottom: 2rem; display: flex; flex-direction: column; gap: .5rem; }
.sl-text ul li {
  font-size: .8rem; color: var(--mid); font-weight: 300;
  padding-left: 1.2rem; position: relative;
}
.sl-text ul li::before {
  content: '✦'; position: absolute; left: 0;
  color: var(--pink); font-size: .55rem; top: .15rem;
}

/* AUTO SCROLL GAP */
.svc-gallery { padding: 1rem 0; overflow: hidden; }

/* PACKAGES */
.packages-section { padding: 8rem 0; background: var(--purple); }
.pkg-header { margin-bottom: 4rem; }
.pkg-header h2 { color: #fff; margin-bottom: 1rem; }
.pkg-header p { font-size: .88rem; color: rgba(255,255,255,.45); font-weight: 300; max-width: 500px; }
.pkg-header .eyebrow { color: rgba(255,255,255,.35); }

.pkg-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5px;
  background: rgba(255,255,255,.08);
}
.pkg-card {
  background: var(--purple);
  padding: 3rem 2.5rem;
  display: flex; flex-direction: column;
  gap: 0; position: relative;
  transition: .4s;
}
.pkg-card:hover { background: rgba(255,255,255,.06); }
.pkg-card.featured {
  background: #fff;
}
.pkg-card.featured:hover { background: var(--cream); }
.pkg-badge {
  position: absolute; top: 2rem; right: 2rem;
  background: var(--pink);
  color: var(--purple);
  font-family: 'Montserrat', sans-serif;
  font-size: .58rem; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase;
  padding: .35rem .8rem;
}
.pkg-eyebrow {
  font-family: 'Montserrat', sans-serif;
  font-size: .58rem; font-weight: 500;
  letter-spacing: .3em; text-transform: uppercase;
  color: var(--pink); display: block; margin-bottom: .8rem;
}
.pkg-card.featured .pkg-eyebrow { color: var(--lilac); }
.pkg-top { margin-bottom: 2rem; padding-bottom: 1.5rem; border-bottom: 1px solid rgba(255,255,255,.1); }
.pkg-card.featured .pkg-top { border-color: rgba(15,5,41,.1); }
.pkg-top h3 { color: #fff; font-size: 1.6rem; margin-bottom: .4rem; }
.pkg-card.featured .pkg-top h3 { color: var(--purple); }
.pkg-tag { font-size: .78rem; color: rgba(255,255,255,.4); font-weight: 300; }
.pkg-card.featured .pkg-tag { color: var(--mid); }
.pkg-list {
  list-style: none; display: flex; flex-direction: column;
  gap: .8rem; flex: 1; margin-bottom: 2.5rem;
}
.pkg-list li {
  font-size: .82rem; color: rgba(255,255,255,.55);
  font-weight: 300; padding-left: 1.2rem; position: relative;
}
.pkg-card.featured .pkg-list li { color: var(--mid); }
.pkg-list li::before {
  content: '✦'; position: absolute; left: 0;
  color: var(--pink); font-size: .5rem; top: .2rem;
}
.btn-solid-light {
  display: inline-block; background: var(--purple);
  color: #fff; padding: 1rem 2.8rem;
  font-family: 'Montserrat', sans-serif;
  font-size: .65rem; font-weight: 500;
  letter-spacing: .25em; text-transform: uppercase;
  transition: .35s; border: 1.5px solid var(--purple);
  text-align: center;
}
.btn-solid-light:hover { background: transparent; color: var(--purple); }
.pkg-card .btn-dark {
  background: transparent;
  border-color: rgba(255,255,255,.25);
  text-align: center;
}
.pkg-card .btn-dark:hover { background: #fff; color: var(--purple); border-color: #fff; }

/* RESPONSIVE */
@media(max-width: 1024px) {
  .sl-item { grid-template-columns: 1fr; min-height: auto; }
  .sl-item.reverse { direction: ltr; }
  .sl-photo { min-height: 50vw; }
  .sl-text { padding: 3rem 2.5rem; }
  .pkg-grid { grid-template-columns: 1fr; gap: 1px; }
}
@media(max-width: 600px) {
  .sl-text { padding: 2.5rem 1.5rem; }
}
