:root{
  --bg:#FFF7F5;
  --paper:#FFFFFF;
  --rose-50:#FCEDEF;
  --rose-100:#F7D5DC;
  --rose-200:#EFB4BE;
  --rose-300:#E48796;
  --rose-deep:#C95A6E;
  --ink:#171012;
  --ink-2:#2B1F22;
  --ink-soft:#6B5057;
  --ink-muted:#9E8189;
  --rule:rgba(23,16,18,.08);
  --rule-strong:rgba(23,16,18,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}
body{overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* Type */
.display{font-family:'Fraunces',Georgia,serif;font-weight:400;line-height:.9}
.kicker{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--rose-deep);font-weight:500}
.italic{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:400}

/* Layout */
.container{max-width:1240px;margin:0 auto;padding:0 32px}
@media (max-width:680px){.container{padding:0 20px}}

/* ===== Nav ===== */
.site-nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;gap:32px;
  padding:18px 32px;
  background:rgba(255,247,245,.82);backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--rule);
}
.nav-monogram{font-family:'Fraunces',Georgia,serif;font-size:30px;letter-spacing:-.02em;color:var(--ink);font-weight:500}
.nav-monogram .dot{color:var(--rose-deep)}
.nav-panel{display:flex;align-items:center;gap:32px;margin-left:auto}
.nav-links{display:flex;gap:28px;font-size:14px}
.nav-links a{color:var(--ink-soft);padding:6px 0;border-bottom:1px solid transparent;transition:.15s}
.nav-links a:hover{color:var(--ink);border-color:var(--rose-deep)}
.nav-cta{
  background:var(--ink);color:var(--bg);padding:11px 22px;border-radius:999px;
  font-size:13px;font-weight:500;letter-spacing:.02em;
  transition:.18s;white-space:nowrap;
}
.nav-cta:hover{background:var(--rose-deep);transform:translateY(-1px)}
.nav-burger{
  display:none;background:none;border:0;
  width:36px;height:36px;cursor:pointer;
  flex-direction:column;align-items:center;justify-content:center;gap:5px;
  position:relative;z-index:60;
}
.nav-burger span{
  display:block;height:1.5px;background:var(--ink);width:22px;
  transition:transform .38s cubic-bezier(.2,.7,.2,1),opacity .22s ease;
  transform-origin:center;
}
.site-nav.open .nav-burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.site-nav.open .nav-burger span:nth-child(2){opacity:0;transform:translateX(-12px)}
.site-nav.open .nav-burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

@media (max-width:880px){
  .nav-burger{display:flex;margin-left:auto}
  .nav-panel{
    position:absolute;top:100%;left:0;right:0;margin:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--bg);
    padding:24px 32px 28px;
    border-bottom:1px solid var(--rule);
    transform:translateY(-16px);opacity:0;pointer-events:none;visibility:hidden;
    transition:transform .38s cubic-bezier(.2,.7,.2,1),opacity .26s ease,visibility 0s linear .38s;
    box-shadow:0 24px 40px -28px rgba(23,16,18,.25);
  }
  .site-nav.open .nav-panel{
    transform:none;opacity:1;pointer-events:auto;visibility:visible;
    transition:transform .38s cubic-bezier(.2,.7,.2,1),opacity .3s ease,visibility 0s;
  }
  .nav-links{
    flex-direction:column;gap:0;width:100%;font-size:18px;
  }
  .nav-links a{
    padding:16px 0;color:var(--ink);font-family:'Fraunces',Georgia,serif;font-size:22px;
    border-bottom:1px solid var(--rule);font-weight:300;letter-spacing:-.01em;
    transform:translateY(-8px);opacity:0;
    transition:transform .35s ease,opacity .3s ease,color .15s;
  }
  .nav-links a:last-of-type{border-bottom:0}
  .nav-cta{
    margin-top:18px;width:100%;text-align:center;padding:16px 22px;font-size:15px;
    border-radius:14px;
    transform:translateY(-8px);opacity:0;
    transition:transform .35s ease,opacity .3s ease,background .18s,color .18s;
  }
  /* Stagger entry animation */
  .site-nav.open .nav-links a,
  .site-nav.open .nav-cta{transform:none;opacity:1}
  .site-nav.open .nav-links a:nth-child(1){transition-delay:.06s}
  .site-nav.open .nav-links a:nth-child(2){transition-delay:.10s}
  .site-nav.open .nav-links a:nth-child(3){transition-delay:.14s}
  .site-nav.open .nav-links a:nth-child(4){transition-delay:.18s}
  .site-nav.open .nav-links a:nth-child(5){transition-delay:.22s}
  .site-nav.open .nav-cta{transition-delay:.28s}
}

/* ===== Animated soft rose blobs ===== */
.flux-bg{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none}
.flux-blob{position:absolute;border-radius:50%;will-change:transform}
.flux-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,transparent 0%,transparent 40%,rgba(255,247,245,.45) 75%,rgba(255,247,245,.85) 100%);pointer-events:none}

/* Hero blobs */
.fb-h1{width:55vw;height:55vw;left:-15vw;top:-20vw;background:radial-gradient(circle,rgba(247,213,220,.95),rgba(252,237,239,.4) 50%,transparent 70%);filter:blur(60px)}
.fb-h2{width:48vw;height:48vw;right:-12vw;top:-10vw;background:radial-gradient(circle,rgba(239,180,190,.85),rgba(247,213,220,.3) 50%,transparent 70%);filter:blur(70px)}
.fb-h3{width:40vw;height:40vw;right:10vw;bottom:-20vw;background:radial-gradient(circle,rgba(228,135,150,.55),rgba(247,213,220,.2) 50%,transparent 70%);filter:blur(80px)}
.fb-h4{width:30vw;height:30vw;left:30vw;bottom:0vw;background:radial-gradient(circle,rgba(252,237,239,.9),rgba(247,213,220,.3) 50%,transparent 70%);filter:blur(90px)}

/* Offer/CTA blobs */
.fb-c1{width:50vw;height:50vw;left:-15vw;top:-15vw;background:radial-gradient(circle,rgba(247,213,220,.95),rgba(252,237,239,.3) 50%,transparent 70%);filter:blur(70px)}
.fb-c2{width:45vw;height:45vw;right:-12vw;bottom:-15vw;background:radial-gradient(circle,rgba(239,180,190,.85),rgba(247,213,220,.3) 50%,transparent 70%);filter:blur(80px)}
.fb-c3{width:35vw;height:35vw;left:25vw;top:30vw;background:radial-gradient(circle,rgba(228,135,150,.55),rgba(247,213,220,.2) 50%,transparent 70%);filter:blur(90px)}
.fb-c4{width:28vw;height:28vw;right:25vw;top:10vw;background:radial-gradient(circle,rgba(252,237,239,.9),rgba(247,213,220,.3) 50%,transparent 70%);filter:blur(80px)}

@keyframes drift-1{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(10vw,6vh,0) scale(1.15)}}
@keyframes drift-2{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(-9vw,-5vh,0) scale(1.12)}}
@keyframes drift-3{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(8vw,-7vh,0) scale(1.18)}}
@keyframes drift-4{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(-7vw,6vh,0) scale(.88)}}
.fb-h1,.fb-c1{animation:drift-1 19s ease-in-out infinite alternate}
.fb-h2,.fb-c2{animation:drift-2 23s ease-in-out infinite alternate}
.fb-h3,.fb-c3{animation:drift-3 17s ease-in-out infinite alternate}
.fb-h4,.fb-c4{animation:drift-4 26s ease-in-out infinite alternate}
@media (prefers-reduced-motion: reduce){.flux-blob{animation:none !important}}

/* ===== Hero ===== */
.hero{position:relative;padding:80px 32px 120px;overflow:hidden;border-bottom:1px solid var(--rule)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;max-width:1240px;margin:0 auto}
.hero-pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;background:rgba(255,255,255,.7);border:1px solid var(--rule-strong);
  border-radius:999px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);
  margin-bottom:36px;font-weight:500;
}
.hero-pill::before{content:"";width:6px;height:6px;background:var(--rose-deep);border-radius:50%}
.hero-title{
  font-family:'Fraunces',Georgia,serif;font-weight:300;
  font-size:clamp(64px,9.5vw,148px);line-height:.88;letter-spacing:-.025em;
  color:var(--ink);margin-bottom:36px;
}
.hero-title .row1{display:block}
.hero-title .row2{display:block;font-style:italic;font-weight:300;color:var(--ink-2)}
.hero-tag{
  font-family:'Fraunces',Georgia,serif;font-weight:400;font-style:italic;
  font-size:clamp(22px,2.4vw,30px);line-height:1.3;color:var(--ink-soft);max-width:520px;margin-bottom:32px;
}
.hero-tag em{font-style:normal;color:var(--ink);border-bottom:1px solid var(--rose-deep);padding-bottom:2px}
.hero-meta{font-size:13px;letter-spacing:.06em;color:var(--ink-muted);margin-bottom:48px;display:flex;flex-wrap:wrap;gap:8px 18px}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta span::after{content:"·";color:var(--rose-200);margin-left:10px}
.hero-meta span:last-child::after{display:none}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 26px;border-radius:999px;font-size:15px;font-weight:500;
  transition:.18s;letter-spacing:.005em;
}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--rose-deep);transform:translateY(-2px)}
.btn-secondary{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-secondary:hover{background:var(--ink);color:var(--bg)}
.btn svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.6;fill:none}

/* Hero portrait */
.hero-portrait{position:relative;aspect-ratio:3/4;width:100%}
.hero-portrait::before{
  content:"";position:absolute;inset:-32px -32px -16px 16px;
  background:radial-gradient(ellipse at 30% 30%,var(--rose-100),transparent 65%);
  filter:blur(20px);z-index:0;
}
.hero-portrait::after{
  content:"";position:absolute;left:-12px;top:-12px;right:18px;bottom:18px;
  border:1px solid var(--ink);z-index:1;mix-blend-mode:multiply;
}
.hero-portrait .frame{
  position:relative;z-index:2;width:100%;height:100%;overflow:hidden;
  background:#0f0a0b;
  box-shadow:0 30px 80px -30px rgba(23,16,18,.45);
}
.hero-portrait .frame img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.hero-portrait .badge{
  position:absolute;z-index:3;right:-8px;bottom:24px;
  padding:18px 22px;background:var(--bg);color:var(--ink);
  border:1px solid var(--ink);max-width:200px;
  font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:18px;line-height:1.25;
}
.hero-portrait .badge::before{content:"❝";display:block;color:var(--rose-deep);font-size:32px;line-height:.5;margin-bottom:6px}

@media (max-width:1000px){
  .hero{padding:48px 20px 80px}
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-portrait{max-width:480px;justify-self:center}
}

/* ===== Sections ===== */
section{padding:120px 0;border-bottom:1px solid var(--rule);position:relative}
@media (max-width:680px){section{padding:80px 0}}

.section-eyebrow{
  display:flex;align-items:baseline;gap:18px;margin-bottom:56px;
  font-size:13px;letter-spacing:.28em;text-transform:uppercase;color:var(--rose-deep);font-weight:500;
}
.section-eyebrow::before{content:"";width:36px;height:1px;background:var(--rose-deep)}
.section-title{
  font-family:'Fraunces',Georgia,serif;font-weight:300;
  font-size:clamp(40px,6vw,88px);line-height:.95;letter-spacing:-.02em;
  margin-bottom:36px;max-width:18ch;
}
.section-title em{font-style:italic;font-weight:300;color:var(--rose-deep)}
.section-lead{font-size:22px;line-height:1.5;color:var(--ink-soft);max-width:680px;font-family:'Fraunces',Georgia,serif;font-weight:300}

/* ===== About ===== */
.about-body{display:grid;grid-template-columns:1fr 1fr;gap:64px;margin-top:64px;align-items:start}
.about-body p{font-size:18px;line-height:1.7;color:var(--ink-soft);margin-bottom:18px}
.about-body p strong{color:var(--ink);font-weight:500}
.about-stat-row{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:28px}
.about-stat{padding:24px;background:var(--paper);border:1px solid var(--rule)}
.about-stat .num{font-family:'Fraunces',Georgia,serif;font-size:44px;line-height:1;color:var(--ink);margin-bottom:10px;font-weight:300}
.about-stat .num em{font-style:italic;color:var(--rose-deep)}
.about-stat .lab{font-size:13px;color:var(--ink-soft);letter-spacing:.04em}
@media (max-width:880px){.about-body{grid-template-columns:1fr;gap:32px}}

/* ===== Services ===== */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service{
  position:relative;padding:32px;background:var(--paper);border:1px solid var(--rule);
  transition:.2s;display:flex;flex-direction:column;gap:14px;min-height:220px;
}
.service:hover{transform:translateY(-4px);border-color:var(--rose-deep);box-shadow:0 24px 50px -28px rgba(228,135,150,.35)}
.service-num{font-family:'Fraunces',Georgia,serif;font-size:14px;color:var(--rose-deep);font-style:italic}
.service h3{font-family:'Fraunces',Georgia,serif;font-weight:400;font-size:26px;line-height:1.1;color:var(--ink);letter-spacing:-.01em}
.service p{font-size:14px;line-height:1.55;color:var(--ink-soft);margin-top:auto}
@media (max-width:1000px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.services-grid{grid-template-columns:1fr}}

/* ===== Cases ===== */
.cases{display:flex;flex-direction:column;gap:20px}
.case{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;
  padding:48px;background:var(--paper);border:1px solid var(--rule);
  align-items:start;transition:.2s;
}
.case:nth-child(even){background:var(--rose-50)}
.case:hover{border-color:var(--rose-deep)}
.case-meta .case-num{font-family:'Fraunces',Georgia,serif;font-size:64px;line-height:1;color:var(--rose-deep);font-style:italic;font-weight:300;margin-bottom:18px}
.case-tag{display:inline-block;padding:6px 12px;background:var(--ink);color:var(--bg);font-size:11px;letter-spacing:.18em;text-transform:uppercase;border-radius:999px}
.case-meta .case-loc{font-size:13px;color:var(--ink-soft);margin-top:14px;letter-spacing:.04em}
.case h3{font-family:'Fraunces',Georgia,serif;font-weight:400;font-size:32px;line-height:1.15;color:var(--ink);margin-bottom:24px;letter-spacing:-.01em}
.case h3 em{font-style:italic;color:var(--rose-deep)}
.case-row{display:grid;grid-template-columns:120px 1fr;gap:18px;padding:18px 0;border-top:1px solid var(--rule)}
.case-row:first-of-type{border-top:1px solid var(--ink-2)}
.case-row dt{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--rose-deep);font-weight:500;padding-top:2px}
.case-row dd{font-size:16px;line-height:1.55;color:var(--ink-2)}
@media (max-width:880px){.case{grid-template-columns:1fr;gap:24px;padding:32px 24px}.case-row{grid-template-columns:1fr;gap:6px}}

/* ===== Approach ===== */
.approach{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--ink-2);border-left:1px solid var(--ink-2)}
.step{padding:36px 28px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);display:flex;flex-direction:column;gap:12px;background:var(--bg);min-height:200px;transition:.2s}
.step:hover{background:var(--rose-50)}
.step-num{font-family:'Fraunces',Georgia,serif;font-size:16px;color:var(--rose-deep);font-style:italic;font-weight:400}
.step h3{font-family:'Fraunces',Georgia,serif;font-weight:400;font-size:22px;line-height:1.1;color:var(--ink);letter-spacing:-.01em}
.step p{font-size:14px;line-height:1.55;color:var(--ink-soft);margin-top:auto}
@media (max-width:880px){.approach{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.approach{grid-template-columns:1fr}}

/* ===== Why ===== */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.why-card{padding:36px;background:var(--paper);border:1px solid var(--rule);display:flex;flex-direction:column;gap:18px}
.why-card.dark{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.why-card.dark .why-num,.why-card.dark .why-card-title{color:var(--rose-200)}
.why-card.dark p{color:rgba(255,247,245,.78)}
.why-card.rose{background:var(--rose-100)}
.why-num{font-family:'Fraunces',Georgia,serif;font-size:14px;font-style:italic;color:var(--rose-deep);letter-spacing:.04em}
.why-card-title{font-family:'Fraunces',Georgia,serif;font-weight:400;font-size:28px;line-height:1.1;color:var(--ink);letter-spacing:-.01em}
.why-card p{font-size:15px;line-height:1.6;color:var(--ink-soft)}
@media (max-width:680px){.why-grid{grid-template-columns:1fr}}

/* ===== Offer ===== */
.offer{position:relative;overflow:hidden;padding:140px 0;background:linear-gradient(180deg,var(--bg) 0%,var(--rose-50) 100%)}
.offer .container{position:relative;z-index:2}
.offer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px}
.offer-card{
  position:relative;padding:36px;background:var(--paper);border:1px solid var(--rule);
  display:flex;flex-direction:column;gap:16px;transition:.2s;overflow:hidden;
}
.offer-card:hover{transform:translateY(-3px);border-color:var(--rose-deep);box-shadow:0 30px 70px -30px rgba(228,135,150,.5)}
.offer-card.feat{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.offer-card.feat .offer-num,.offer-card.feat h3{color:var(--rose-200)}
.offer-card.feat p{color:rgba(255,247,245,.85)}
.offer-card.feat .offer-cta{color:var(--rose-200);border-color:var(--rose-200)}
.offer-num{font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:14px;color:var(--rose-deep);letter-spacing:.02em}
.offer-card h3{font-family:'Fraunces',Georgia,serif;font-weight:400;font-size:30px;line-height:1.12;color:var(--ink);letter-spacing:-.01em}
.offer-card p{font-size:15px;line-height:1.6;color:var(--ink-soft)}
.offer-cta{
  margin-top:auto;display:inline-flex;align-items:center;gap:8px;
  font-size:13px;letter-spacing:.05em;color:var(--ink);font-weight:500;
  border-bottom:1px solid var(--ink);padding:8px 0 6px;width:fit-content;
}
.offer-cta::after{content:"→";transition:.2s}
.offer-cta:hover::after{transform:translateX(4px)}
@media (max-width:680px){.offer-grid{grid-template-columns:1fr}}

/* ===== CTA ===== */
.cta-final{position:relative;overflow:hidden;padding:140px 0;text-align:center;background:var(--ink);color:var(--bg);border:0}
.cta-final .container{position:relative;z-index:2}
.cta-final .section-eyebrow{color:var(--rose-200);justify-content:center}
.cta-final .section-eyebrow::before{background:var(--rose-200)}
.cta-final h2{font-family:'Fraunces',Georgia,serif;font-weight:300;font-size:clamp(56px,8.5vw,148px);line-height:.9;letter-spacing:-.025em;margin:0 auto 36px;max-width:18ch}
.cta-final h2 em{font-style:italic;color:var(--rose-200)}
.cta-final p{font-family:'Fraunces',Georgia,serif;font-weight:400;font-style:italic;font-size:22px;line-height:1.4;max-width:560px;margin:0 auto 48px;color:rgba(255,247,245,.85)}
.cta-final .btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta-final .btn-primary{background:var(--bg);color:var(--ink)}
.cta-final .btn-primary:hover{background:var(--rose-200);color:var(--ink)}
.cta-final .btn-secondary{border-color:var(--rose-200);color:var(--rose-200)}
.cta-final .btn-secondary:hover{background:var(--rose-200);color:var(--ink)}
.cta-final::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 80%,rgba(228,135,150,.18),transparent 50%),
    radial-gradient(circle at 80% 30%,rgba(247,213,220,.14),transparent 50%);
  pointer-events:none;
}

/* ===== Footer ===== */
.site-footer{background:var(--bg);border-top:1px solid var(--rule);padding:80px 32px 32px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;max-width:1240px;margin:0 auto 56px}
.footer-monogram{font-family:'Fraunces',Georgia,serif;font-size:36px;color:var(--ink);margin-bottom:12px;font-weight:400}
.footer-monogram .dot{color:var(--rose-deep)}
.footer-line{font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:18px;color:var(--ink-soft);max-width:280px;line-height:1.35}
.footer-col h4{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--rose-deep);font-weight:500;margin-bottom:18px}
.footer-col a,.footer-col span{display:block;color:var(--ink-soft);font-size:14px;padding:5px 0;transition:.15s}
.footer-col a:hover{color:var(--ink)}
.footer-bottom{display:flex;justify-content:space-between;max-width:1240px;margin:0 auto;padding-top:24px;border-top:1px solid var(--rule);font-size:12px;color:var(--ink-muted);letter-spacing:.04em}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;gap:8px}}

/* Reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
