@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400;1,700&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&display=swap');

:root {
  --pink: #f4a7c0;
  --pink-light: #fce4ee;
  --pink-vivid: #e75480;
  --pink-deep: #c43a6a;
  --black: #0f0f0f;
  --white: #ffffff;
  --off-white: #fdf6f9;
  --gray: #666;
  --border: rgba(244,167,192,0.28);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--white);color:var(--black);overflow-x:hidden;}

/* ── NAV ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  height:72px;display:flex;align-items:center;justify-content:space-between;
  padding:0 5%;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition:box-shadow .3s;
}
.nav.scrolled{box-shadow:0 2px 28px rgba(231,84,128,.13);}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;z-index:301;}
.nav-logo img{height:44px;width:44px;border-radius:50%;object-fit:cover;border:2px solid var(--pink);}
.nav-logo-text{font-family:'Playfair Display',serif;font-size:1rem;line-height:1.25;color:var(--black);}
.nav-logo-text span{color:var(--pink-vivid);}

/* Desktop nav links */
.nav-links{display:flex;align-items:center;gap:4px;list-style:none;}
.nav-links a{
  text-decoration:none;color:var(--black);
  font-size:.82rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;
  padding:8px 13px;border-radius:30px;transition:all .2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--pink-vivid);}
.nav-links .nav-cta{background:var(--pink-vivid);color:var(--white)!important;padding:9px 22px;}
.nav-links .nav-cta:hover{background:var(--pink-deep);transform:translateY(-1px);}

/* Hamburger button */
.nav-hamburger{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  gap:5px;width:40px;height:40px;
  background:none;border:none;cursor:pointer;
  z-index:301;padding:4px;
}
.nav-hamburger span{
  display:block;width:24px;height:2px;
  background:var(--black);border-radius:2px;
  transition:all .3s;transform-origin:center;
}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* Mobile drawer */
.nav-drawer{
  display:none;
  position:fixed;top:72px;left:0;right:0;bottom:0;
  background:var(--white);z-index:299;
  flex-direction:column;
  padding:32px 8%;
  overflow-y:auto;
  border-top:1px solid var(--border);
}
.nav-drawer.open{display:flex;}
.nav-drawer a{
  text-decoration:none;color:var(--black);
  font-size:1.1rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;
  padding:18px 0;border-bottom:1px solid var(--border);
  transition:color .2s;
}
.nav-drawer a:hover,.nav-drawer a.active{color:var(--pink-vivid);}
.nav-drawer .drawer-cta{
  margin-top:28px;
  background:var(--pink-vivid);color:var(--white)!important;
  text-align:center;padding:16px;border-radius:40px;
  border:none;letter-spacing:.06em;font-size:1rem;
}
.nav-drawer .drawer-cta:hover{background:var(--pink-deep);}

/* ── PAGE ── */
.page{padding-top:72px;min-height:100vh;}

/* ── PAGE BANNER ── */
.page-banner{
  background:var(--black);padding:80px 8% 68px;
  position:relative;overflow:hidden;
}
.page-banner::before{
  content:'';position:absolute;top:-100px;right:-100px;
  width:420px;height:420px;
  background:radial-gradient(circle,rgba(231,84,128,.22),transparent 70%);
  border-radius:50%;pointer-events:none;
}
.page-banner::after{
  content:'';position:absolute;bottom:-60px;left:8%;
  width:220px;height:220px;
  background:radial-gradient(circle,rgba(244,167,192,.1),transparent 70%);
  border-radius:50%;pointer-events:none;
}
.banner-eyebrow{
  font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--pink);margin-bottom:16px;
  display:flex;align-items:center;gap:10px;
}
.banner-eyebrow::before{content:'';display:inline-block;width:26px;height:2px;background:var(--pink);}
.page-banner h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(2.8rem,5vw,4.4rem);
  color:var(--white);font-weight:400;line-height:1.1;
}
.page-banner h1 em{font-style:italic;color:var(--pink);}

/* ── SECTIONS ── */
.section{padding:96px 8%;}
.section-alt{background:var(--off-white);}

.eyebrow{
  font-size:.76rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  color:var(--pink-vivid);margin-bottom:12px;
  display:flex;align-items:center;gap:10px;
}
.eyebrow::before{content:'';display:inline-block;width:24px;height:2px;background:var(--pink-vivid);}
.eyebrow.center{justify-content:center;}
.eyebrow.center::before{display:none;}

h2.title{
  font-family:'Playfair Display',serif;
  font-size:clamp(2rem,3.5vw,2.9rem);
  font-weight:400;line-height:1.18;color:var(--black);margin-bottom:18px;
}
h2.title em{font-style:italic;color:var(--pink-vivid);}
.body-text{font-size:1.01rem;color:var(--gray);line-height:1.82;font-weight:300;max-width:580px;}

/* ── BUTTONS ── */
.btn{
  display:inline-block;text-decoration:none;
  padding:14px 32px;border-radius:40px;
  font-size:.9rem;font-weight:500;letter-spacing:.04em;
  transition:all .22s;cursor:pointer;border:none;
  font-family:'DM Sans',sans-serif;
}
.btn-dark{background:var(--black);color:var(--white);}
.btn-dark:hover{background:var(--pink-vivid);transform:translateY(-2px);}
.btn-pink{background:var(--pink-vivid);color:var(--white);}
.btn-pink:hover{background:var(--pink-deep);transform:translateY(-2px);}
.btn-outline{background:transparent;color:var(--black);border:2px solid var(--pink);}
.btn-outline:hover{border-color:var(--pink-vivid);color:var(--pink-vivid);transform:translateY(-2px);}

/* ── SERVICE CARDS ── */
.svc-card{
  border:1.5px solid var(--border);border-radius:20px;
  padding:40px 32px;transition:all .3s;
  position:relative;overflow:hidden;background:var(--white);
}
.svc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--pink),var(--pink-vivid));
  transform:scaleX(0);transform-origin:left;transition:transform .4s;
}
.svc-card:hover{border-color:var(--pink);box-shadow:0 16px 52px rgba(231,84,128,.12);transform:translateY(-4px);}
.svc-card:hover::before{transform:scaleX(1);}
.svc-icon{font-size:2.2rem;margin-bottom:20px;}
.svc-title{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:400;margin-bottom:14px;}
.svc-desc{font-size:.94rem;color:var(--gray);line-height:1.75;font-weight:300;}

/* ── TAGS ── */
.tag{background:var(--pink-light);color:var(--pink-vivid);padding:7px 17px;border-radius:30px;font-size:.8rem;font-weight:500;}

/* ── FOOTER ── */
footer{background:var(--black);color:var(--white);padding:64px 8% 32px;}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:60px;margin-bottom:48px;}
.footer-brand img{height:52px;border-radius:8px;margin-bottom:16px;display:block;}
.footer-brand p{font-size:.88rem;color:#888;line-height:1.75;font-weight:300;max-width:250px;}
.footer-col h4{font-family:'Playfair Display',serif;font-size:1.05rem;margin-bottom:18px;color:var(--white);font-weight:400;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:9px;}
.footer-col ul a{text-decoration:none;color:#888;font-size:.88rem;transition:color .2s;}
.footer-col ul a:hover{color:var(--pink);}
.footer-bottom{border-top:1px solid #1e1e1e;padding-top:26px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
.footer-bottom p{font-size:.8rem;color:#555;}
.footer-motto{font-family:'Playfair Display',serif;font-style:italic;color:var(--pink);font-size:.92rem;}

/* ── FADE IN ── */
.fade-in{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease;}
.fade-in.visible{opacity:1;transform:none;}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .footer-top{grid-template-columns:1fr;gap:28px;}
}

/* Hide desktop nav on mobile, show hamburger */
@media(max-width:700px){
  .nav-links{display:none;}
  .nav-hamburger{display:flex;}
  .page-banner{padding:60px 6% 48px;}
  .page-banner h1{font-size:clamp(2.2rem,8vw,3rem);}
}
