

 /* =============== Base ================= */
:root{
  --bg:#000; --bg2:#111; --ink:#fff; --muted:#d7d7d7; --gold:goldenrod;
  --radius:12px; --shadow:0 10px 28px rgba(0,0,0,.35);
  --maxw:1200px;
  --h1:clamp(1.9rem,2.8vw,2.7rem);
  --h2:clamp(1.6rem,2.2vw,2.1rem);
  --h3:clamp(1.2rem,1.6vw,1.4rem);
  --lead:clamp(1rem,1.2vw,1.1rem);
}

/* --- Responsive gutters that never disappear --- */
:root{
  /* you can tweak these numbers later */
  --maxw: 1200px;                       /* content max width */
  --gutter: clamp(16px, 4vw, 32px);     /* min 16px → grows to 32px on big screens */
}

/* container always leaves left/right space, even on tiny screens */
.container{
  width: min(var(--maxw), calc(100% - (var(--gutter) * 2.9)));
  margin-inline: auto;
  /* fallback if the min()/calc() isn’t supported somewhere ancient */
  padding-inline: max(16px, 4vw);
}


*{box-sizing:border-box}
html{font-family:Inter,system-ui,Arial,sans-serif;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);line-height:1.6;overflow-x:hidden}
img,video,iframe{max-width:100%;height:auto;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:64px 0}
.center{text-align:center}
h1{font-size:var(--h1);line-height:1.2;margin:.2rem 0 .6rem}
h2{font-size:var(--h2);line-height:1.25;margin:0 0 .5rem}
h3{font-size:var(--h3);line-height:1.3;margin:0 0 .4rem}
.lead{font-size:var(--lead);color:var(--muted)}
a{text-decoration:none;color:inherit}

/* =============== NAV ================== */
/* =============== NAV (updated) ================== */
.site-nav{
  position:sticky; top:0; z-index:1000;
  background:rgba(10,10,10,.9);
  backdrop-filter:saturate(120%) blur(8px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.site-nav__bar{
  min-height:68px;
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; flex-wrap:nowrap;
}
.site-nav__brand{ display:flex; align-items:center; gap:10px; color:#fff; text-decoration:none; white-space:nowrap; }
.site-nav__brand img{ height:48px; width:auto; }
.site-nav__brand span{ font-weight:700; letter-spacing:.3px; }

.site-nav__menu{
  display:flex; align-items:center; gap:10px;
  list-style:none; margin:0; padding:0; flex-wrap:nowrap;
}
.site-nav__menu a, .site-nav__menu .sub-toggle{
  appearance:none; background:none; border:0; color:#fff;
  text-decoration:none; cursor:pointer;
  padding:10px 12px; border-radius:8px; font-weight:600; font-size:1rem;
}
.site-nav__menu a:hover, .site-nav__menu .sub-toggle:hover{ background:#1a1a1a; }

/* dropdown */
.has-sub{ position:relative; }
.site-nav__submenu{
  position:absolute; left:0; top:100%;
  min-width:240px; padding:8px;
  background:#111; border:1px solid rgba(255,255,255,.08);
  border-radius:12px; box-shadow:0 12px 32px rgba(0,0,0,.45);
  opacity:0; transform:translateY(8px); pointer-events:none; transition:.16s;
}
.has-sub::after{ content:""; position:absolute; left:0; right:0; top:100%; height:12px; } /* hover bridge */
.has-sub:hover .site-nav__submenu, .has-sub.open .site-nav__submenu{
  opacity:1; transform:translateY(0); pointer-events:auto;
}
.site-nav__submenu, .site-nav__submenu li{ list-style:none; margin:0; padding:0; }
.site-nav__submenu a{ display:block; padding:10px 12px; border-radius:8px; color:#cfd6e4; }
.site-nav__submenu a:hover{ background:#1c1c1c; color:#fff; }

/* WhatsApp pill */
.site-nav__wa{
  background:var(--gold); color:#000; font-weight:800;
  padding:10px 14px; border-radius:999px; text-decoration:none;
  white-space:nowrap;
}
.site-nav__wa:hover{ background:#fff; color:var(--gold); }

/* burger (hidden by default) */
.site-nav__burger{
  display:none; width:44px; height:44px;
  border:1px solid rgba(255,255,255,.12);
  background:none; color:var(--gold);
  border-radius:8px; align-items:center; justify-content:center;
}

/* ===== tighten spacing slightly on mid widths (pre-hamburger) */
@media (max-width: 1240px){
  .site-nav__menu{ gap:8px; }
  .site-nav__menu a, .site-nav__menu .sub-toggle{ padding:8px 10px; font-size:.96rem; }
  .site-nav__wa{ padding:9px 12px; }
}

/* ===== switch to hamburger earlier to avoid wrap (≤1100px) */
@media (max-width: 1100px){
  .site-nav__burger{ display:flex; }
  .site-nav__wa{ display:none; }                /* hide WA on mobile */
  .site-nav__menu{
    position:absolute; left:0; right:0; top:100%;
    background:#0f0f0f; border-bottom:1px solid rgba(255,255,255,.08);
    flex-direction:column; align-items:flex-start; gap:8px;
    padding:16px 20px; display:none;
  }
  .site-nav__menu.show{ display:flex; }

  /* mobile submenu renders inline (no hover) */
  .site-nav__submenu{
    position:static; opacity:1; transform:none; pointer-events:auto;
    background:transparent; border:0; box-shadow:none; padding:0; margin-left:8px;
  }
}



 /* ===== Wedding Planners — HERO (Static) ===== */
.wp-hero {
  position:relative;
  height:70vh;
  min-height:520px;
  background:#000;
  color:#fff;
  overflow:hidden;
  z-index: -1;
}

.wp-hero-bg {
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  z-index:0;
}

.wp-hero-overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(0,0,0,0.65), rgba(0,0,0,0.25));
  z-index:1;
}

/* Content */
.wp-hero-inner {
  position:relative;
  z-index:2;
  max-width:1000px;
  margin:0 auto;
  padding:0 20px;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.wp-kicker {
  display:inline-block;
  color:goldenrod;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.95rem;
  padding:.35rem .9rem;
  border:2px solid goldenrod;
  border-radius:999px;
  margin-bottom:12px;
}
.wp-title {
  font-weight:800;
  line-height:1.2;
  margin:0 0 12px;
  font-size:clamp(1.8rem, 4vw, 2.8rem);
}
.wp-sub {
  color:#e8e8e8;
  max-width:800px;
  margin:0 auto 18px;
  font-size:clamp(1rem, 2vw, 1.1rem);
  line-height:1.7;
}

/* CTA Buttons */
.wp-cta {
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  justify-content:center;
}
.wp-btn {
  display:inline-block;
  padding:12px 26px;
  border-radius:8px;
  background:goldenrod;
  color:#000;
  font-weight:800;
  text-decoration:none;
  transition:.25s;
}
.wp-btn:hover { background:#fff; color:goldenrod; }
.wp-btn-outline {
  background:transparent;
  color:#fff;
  border:2px solid goldenrod;
}
.wp-btn-outline:hover { background:#fff; color:goldenrod; }

/* Responsive */
@media (max-width:680px){
  .wp-hero { height:64vh; min-height:460px; }
}


/* CTA Buttons */
.wp-cta {
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  justify-content:center;
}
.wp-btn {
  display:inline-block;
  padding:12px 26px;
  border-radius:8px;
  background:goldenrod;
  color:#000;
  font-weight:800;
  text-decoration:none;
  transition:.25s;
}
.wp-btn:hover { background:#fff; color:goldenrod; }
.wp-btn-outline {
  background:transparent;
  color:#fff;
  border:2px solid goldenrod;
}
.wp-btn-outline:hover { background:#fff; color:goldenrod; }

/* Responsive */
@media (max-width:680px){
  .wp-hero { height:64vh; min-height:460px; }
}

/* ===== Wedding Planners — Services Overview (Scoped) ===== */
/* ===== Wedding Planners — Services Overview (with images) ===== */
.wp-services {
  background:#111;
  color:#fff;
  padding:70px 20px;
}
.wp-services-container {
  max-width:1200px;
  margin:0 auto;
}
.wp-services-h2 {
  text-align:center;
  font-weight:800;
  font-size:clamp(1.6rem,3.8vw,2.2rem);
  margin:0 0 12px;
}
.wp-services-h2::after {
  content:"";
  display:block;
  width:90px;
  height:3px;
  margin:12px auto 0;
  background:linear-gradient(90deg, transparent, goldenrod, transparent);
  border-radius:3px;
}
.wp-services-lead {
  color:#d7d7d7;
  text-align:center;
  max-width:900px;
  margin:0 auto 36px;
  font-size:1.05rem;
  line-height:1.7;
}

/* Grid */
.wp-services-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.wp-services-card {
  background:#1a1a1a;
  border:2px solid rgba(255,255,255,.12);
  border-radius:12px;
  overflow:hidden;
  padding:0;
  transition:.25s;
  display:flex;
  flex-direction:column;
}
.wp-services-card:hover {
  transform:translateY(-4px);
  border-color:goldenrod;
  box-shadow:0 8px 28px rgba(218,165,32,.25);
}

/* Image inside card */
.wp-services-img {
  height:160px;
  background-size:cover;
  background-position:center;
  border-bottom:2px solid rgba(255,255,255,.08);
}
.wp-services-card h3 {
  margin:16px 16px 8px;
  font-size:1.2rem;
  font-weight:700;
  color:goldenrod;
}
.wp-services-card p {
  margin:0 16px 16px;
  color:#d7d7d7;
  font-size:.95rem;
  line-height:1.6;
}

/* Responsive */
@media (max-width:1000px){
  .wp-services-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:680px){
  .wp-services-grid { grid-template-columns:1fr; gap:16px; }
  .wp-services-img { height:200px; }
}

  /* ===== Wedding Planners — Spotlight (Scoped) ===== */
.wp-spotlight {
  background:#000;
  padding:70px 20px;
  color:#fff;
}
.wp-spotlight-container {
  max-width:1200px;
  margin:0 auto;
}
.wp-spotlight-flex {
  display:flex;
  gap:36px;
  align-items:center;
}

/* Image */
.wp-spotlight-img {
  flex:0 0 auto;
  width:25vw;
  height:50vh;
  min-width:320px;
  border-radius:16px;
  border:4px solid goldenrod;
  background-size:cover;
  background-position:center;
  box-shadow:0 0 0 2px rgba(0,0,0,.6) inset,
             0 10px 26px rgba(218,165,32,.25);
}

/* Copy */
.wp-spotlight-copy { flex:1; }
.wp-spotlight-kicker {
  color:goldenrod;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-bottom:8px;
  font-size:.95rem;
}
.wp-spotlight-h3 {
  font-size:clamp(1.4rem,3.4vw,2rem);
  margin:0 0 14px;
  font-weight:800;
}
.wp-spotlight-body {
  color:#d7d7d7;
  line-height:1.75;
  margin:0 0 14px;
  font-size:clamp(1rem,2.2vw,1.06rem);
  text-align:justify;
  hyphens:auto;
}

/* Responsive */
@media (max-width: 900px){
  .wp-spotlight-flex { flex-direction:column; }
  .wp-spotlight-img { width:92vw; height:60vw; }
  .wp-spotlight-copy { text-align:center; }
  .wp-spotlight-body { text-align:left; }
}


/* ===== Wedding Planners — Process Timeline (Scoped) ===== */
.wp-process {
  background:#111;
  padding:70px 20px;
  color:#fff;
}
.wp-process-container {
  max-width:1100px;
  margin:0 auto;
}

.wp-process-h2 {
  text-align:center;
  font-weight:800;
  font-size:clamp(1.6rem,3.8vw,2.2rem);
  margin:0 0 12px;
}
.wp-process-h2::after {
  content:"";
  display:block;
  width:90px;
  height:3px;
  margin:12px auto 0;
  background:linear-gradient(90deg, transparent, goldenrod, transparent);
  border-radius:3px;
}

.wp-process-lead {
  color:#d7d7d7;
  text-align:center;
  max-width:800px;
  margin:0 auto 40px;
  font-size:1.05rem;
  line-height:1.7;
}

/* Timeline */
.wp-process-timeline {
  position:relative;
  margin-left:40px;
}
.wp-process-timeline::before {
  content:"";
  position:absolute;
  left:8px;
  top:0; bottom:0;
  width:2px;
  background:linear-gradient(goldenrod, transparent);
}

.wp-process-step {
  display:flex;
  align-items:flex-start;
  gap:16px;
  position:relative;
  margin-bottom:28px;
}
.wp-process-dot {
  width:14px;
  height:14px;
  border-radius:50%;
  background:goldenrod;
  box-shadow:0 0 0 4px rgba(218,165,32,.25);
  margin-top:.4rem;
  flex-shrink:0;
}
.wp-process-card {
  background:#1a1a1a;
  border-radius:12px;
  padding:18px 20px;
  border:2px solid rgba(255,255,255,.12);
  flex:1;
}
.wp-process-card h4 {
  margin:0 0 8px;
  color:goldenrod;
  font-weight:700;
  font-size:1.1rem;
}
.wp-process-card p {
  margin:0;
  color:#d7d7d7;
  line-height:1.6;
  font-size:.96rem;
}

/* Responsive */
@media (max-width:680px){
  .wp-process-timeline { margin-left:24px; }
  .wp-process-timeline::before { left:4px; }
}
/* ===== Wedding Planners — Case Showcase (Scoped) ===== */
.wp-case {
  background:#000;
  padding:70px 20px;
  color:#fff;
}
.wp-case-container {
  max-width:1200px;
  margin:0 auto;
}

.wp-case-h2 {
  text-align:center;
  font-weight:800;
  font-size:clamp(1.6rem,3.8vw,2.2rem);
  margin:0 0 12px;
}
.wp-case-h2::after {
  content:"";
  display:block;
  width:90px;
  height:3px;
  margin:12px auto 0;
  background:linear-gradient(90deg, transparent, goldenrod, transparent);
  border-radius:3px;
}
.wp-case-lead {
  color:#d7d7d7;
  text-align:center;
  max-width:900px;
  margin:0 auto 36px;
  font-size:1.05rem;
  line-height:1.7;
}

/* Grid */
.wp-case-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.wp-case-card {
  background:#1a1a1a;
  border-radius:12px;
  border:2px solid rgba(255,255,255,.12);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:.25s;
}
.wp-case-card:hover {
  transform:translateY(-4px);
  border-color:goldenrod;
  box-shadow:0 8px 28px rgba(218,165,32,.25);
}
.wp-case-img {
  height:220px;
  background-size:cover;
  background-position:center;
}
.wp-case-body {
  padding:16px;
}
.wp-case-body h3 {
  margin:0 0 8px;
  color:goldenrod;
  font-size:1.2rem;
  font-weight:700;
}
.wp-case-body p {
  margin:0;
  color:#d7d7d7;
  font-size:.95rem;
  line-height:1.6;
}

/* Responsive */
@media (max-width:1000px){
  .wp-case-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:680px){
  .wp-case-grid { grid-template-columns:1fr; }
  .wp-case-img { height:200px; }
}

/* ===== Wedding Planners — FAQ (Scoped) ===== */
.wp-faq {
  background:#111;
  padding:70px 20px;
  color:#fff;
}
.wp-faq-container {
  max-width:1100px;
  margin:0 auto;
}

.wp-faq-h2 {
  text-align:center;
  font-weight:800;
  font-size:clamp(1.6rem,3.8vw,2.2rem);
  margin:0 0 12px;
}
.wp-faq-h2::after {
  content:"";
  display:block;
  width:90px;
  height:3px;
  margin:12px auto 0;
  background:linear-gradient(90deg, transparent, goldenrod, transparent);
  border-radius:3px;
}
.wp-faq-lead {
  color:#d7d7d7;
  text-align:center;
  max-width:800px;
  margin:0 auto 40px;
  font-size:1.05rem;
  line-height:1.7;
}

/* FAQ Grid */
.wp-faq-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
.wp-faq-card {
  background:#1a1a1a;
  border-radius:12px;
  border:2px solid rgba(255,255,255,.12);
  padding:20px;
  transition:.25s;
}
.wp-faq-card:hover {
  transform:translateY(-4px);
  border-color:goldenrod;
  box-shadow:0 8px 28px rgba(218,165,32,.25);
}
.wp-faq-card h3 {
  margin:0 0 10px;
  color:goldenrod;
  font-size:1.1rem;
  font-weight:700;
}
.wp-faq-card p {
  margin:0;
  color:#d7d7d7;
  line-height:1.6;
  font-size:.95rem;
}

/* Responsive */
@media (max-width:900px){
  .wp-faq-grid { grid-template-columns:1fr; }
}

/* ===== Wedding Planners — CTA Banner (Scoped & Renamed) ===== */
/* ===== Wedding — CTA Banner (matches global style) ===== */
.wp-cta-banner{
  background:#000;
  padding: clamp(70px, 12vh, 120px) 24px;
  color:#fff;
}
.wp-cta-banner-container{
  max-width: var(--maxw, 1280px);
  margin: 0 auto;
}
.wp-cta-banner-flex{
  display:flex;
  gap:40px;
  align-items:stretch;
  background:#0f0f0f;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 18px 48px rgba(0,0,0,.4);
}

/* Image panel */
.wp-cta-banner-img{
  flex:0 0 46%;
  min-height:380px;
  background-size:cover;
  background-position:center;
  position:relative;
}
.wp-cta-banner-img::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.4), transparent 50%);
}

/* Copy panel */
.wp-cta-banner-copy{
  flex:1;
  padding: clamp(32px, 6vw, 56px);
  display:flex; flex-direction:column; justify-content:center;
}
.wp-cta-banner-h3{
  font-weight:800;
  font-size: clamp(1.6rem, 3.4vw, 2.4rem);
  margin:0 0 14px;
}
.wp-cta-banner-text{
  color:#d7d7d7;
  font-size: clamp(1rem, 1.4vw, 1.125rem);
  line-height:1.75;
  margin:0 0 20px;
}

/* Button */
.wp-cta-banner-btn{
  align-self:flex-start;
  display:inline-block;
  padding:14px 32px;
  border-radius:12px;
  background:goldenrod; color:#000;
  font-weight:800; text-decoration:none;
  border:2px solid transparent; transition:.25s;
}
.wp-cta-banner-btn:hover{
  background:#fff; color:goldenrod; border-color:goldenrod;
}

/* Responsive stack */
@media (max-width: 900px){
  .wp-cta-banner-flex{ flex-direction:column; gap:24px; }
  .wp-cta-banner-img{ flex:0 0 auto; min-height:260px; }
  .wp-cta-banner-btn{ align-self:stretch; text-align:center; }
}



    
    /* =============== FOOTER =============== */
.site-footer{background:var(--bg2);color:var(--muted);padding:60px 0;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:40px}
.site-footer h3{color:#fff;margin-bottom:12px}
.site-footer a{color:var(--muted)}
.site-footer a:hover{color:#fff}
.footer-socials { display:grid;  gap:12px; margin-top:12px; }
.footer-socials .soc svg {
  width: 32px;   /* adjust to your liking */
  height: 32px;
}

.footer-socials .soc { color: var(--gold); display:inline-flex; }
.footer-socials .soc:hover { color:#fff; }


/* ==== GLOBAL REVEAL (utility) ==== */
@media (prefers-reduced-motion: no-preference) {
  .reveal {
    opacity: 0;
    transform: translateY(22px) scale(.995);
    filter: saturate(90%) blur(.3px);
    transition:
      opacity .6s ease,
      transform .6s ease,
      filter .6s ease;
    will-change: opacity, transform, filter;
  }
  .reveal.reveal--in {
    opacity: 1;
    transform: none;
    filter: none;
  }
  /* gentle stagger for children when parent has data-reveal-stagger */
  [data-reveal-stagger] > * {
    transition-delay: var(--rv-delay, 0ms);
  }
}
