:root{
  --plum:#3B2340;
  --plum-deep:#2A1A30;
  --blush:#FBEEF0;
  --cream:#F5F1EA;
  --ink:#2C2622;
  --sage:#8A9A5B;
  --fig:#B23A4E;
  --white:#FFFFFF;
  --serif:"Noto Serif Display",Georgia,serif;
  --sans:"Mulish",system-ui,sans-serif;
  --maxw:1280px;
}
*,*::before,*::after{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);
  background:var(--cream);font-weight:400;line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img,svg{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:300;line-height:1.08;margin:0;letter-spacing:.01em;overflow-wrap:break-word}
p{overflow-wrap:break-word;min-width:0}

.eyebrow{
  font-family:var(--sans);font-weight:600;font-size:.72rem;
  letter-spacing:.26em;text-transform:uppercase;color:var(--sage);
  display:inline-block;margin-bottom:1.1rem;
}
.eyebrow-light{color:#d8c4cf}

.btn{
  display:inline-block;font-family:var(--sans);font-weight:600;
  font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  padding:1.05rem 2.4rem;border:1px solid transparent;
  transition:transform .3s ease,background .3s ease,color .3s ease;
  cursor:pointer;
}
.btn-plum{background:var(--plum);color:var(--white)}
.btn-plum:hover{background:var(--plum-deep);transform:translateY(-2px)}
.btn-light{background:var(--white);color:var(--plum)}
.btn-light:hover{background:var(--blush);color:var(--plum-deep);transform:translateY(-2px)}

/* ─── Utility bar ─── */
.utility-bar{
  background:var(--plum-deep);color:#e9dde2;
  display:flex;justify-content:space-between;align-items:center;
  gap:1rem;padding:.5rem clamp(1rem,4vw,2.5rem);
  font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
}
.util-loc{display:flex;align-items:center;gap:.4rem;color:#cbb6c1}
.util-est{color:#a98ba0}
@media(max-width:680px){.util-est{display:none}.utility-bar{justify-content:center}}

/* ─── Header ─── */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(245,241,234,.0);backdrop-filter:blur(0);
  transition:background .35s ease,box-shadow .35s ease,padding .35s ease;
  padding:.5rem 0;
}
.site-header.stuck{
  background:rgba(245,241,234,.96);backdrop-filter:blur(10px);
  box-shadow:0 2px 24px rgba(43,26,48,.10);
}
.header-inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;gap:1.5rem;
  padding:.6rem clamp(1rem,4vw,2.5rem);
}
.brand-logo{height:62px;width:auto;transition:height .35s ease}
.site-header.stuck .brand-logo{height:50px}
.primary-nav{margin-left:auto}
.primary-nav>ul{list-style:none;display:flex;gap:1.7rem;margin:0;padding:0;align-items:center}
.primary-nav a,.nav-drop-toggle{
  font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  font-weight:600;color:var(--plum);background:none;border:none;
  cursor:pointer;font-family:var(--sans);display:flex;align-items:center;gap:.35rem;
  padding:.4rem 0;position:relative;
}
.primary-nav a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;
  background:var(--fig);transition:width .3s ease;
}
.primary-nav a:hover::after,.primary-nav a.active::after{width:100%}
.has-dropdown{position:relative}
.dropdown{
  list-style:none;position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);
  background:var(--white);min-width:230px;padding:.6rem 0;margin:.6rem 0 0;
  box-shadow:0 18px 50px rgba(43,26,48,.18);opacity:0;visibility:hidden;
  transition:opacity .25s ease,transform .25s ease;border-top:2px solid var(--sage);
}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown,
.dropdown.open{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown li a{padding:.6rem 1.4rem;display:block;letter-spacing:.1em}
.dropdown li a::after{display:none}
.dropdown li a:hover{background:var(--blush);color:var(--fig)}
.cta-inquire{
  background:var(--plum);color:var(--white);
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  padding:.85rem 1.7rem;transition:background .3s ease,transform .3s ease;
}
.cta-inquire:hover{background:var(--plum-deep);transform:translateY(-2px)}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.4rem;margin-left:auto}
.menu-toggle span{width:26px;height:2px;background:var(--plum);transition:.3s}

/* ─── Mobile drawer ─── */
.drawer-scrim{position:fixed;inset:0;background:rgba(42,26,48,.5);z-index:200;backdrop-filter:blur(2px)}
.mobile-drawer{
  position:fixed;top:0;right:0;height:100%;width:min(85vw,360px);
  background:var(--cream);z-index:210;transform:translateX(105%);
  transition:transform .4s cubic-bezier(.5,.1,.2,1);
  padding:1.5rem 1.6rem 2rem;display:flex;flex-direction:column;
  box-shadow:-10px 0 50px rgba(42,26,48,.25);overflow-y:auto;
}
.mobile-drawer.open{transform:translateX(0)}
.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.4rem}
.drawer-mono{height:48px;width:auto}
.drawer-close{background:none;border:none;font-size:2rem;color:var(--plum);cursor:pointer;line-height:1}
.mobile-drawer nav{display:flex;flex-direction:column}
.mobile-drawer nav a,.mobile-drawer summary{
  font-size:.95rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
  color:var(--plum);padding:.95rem 0;border-bottom:1px solid rgba(59,35,64,.12);cursor:pointer;
}
.mobile-drawer summary{list-style:none}
.mobile-drawer summary::-webkit-details-marker{display:none}
.mobile-drawer .sub{font-weight:400;font-size:.82rem;padding-left:1rem;color:var(--ink);text-transform:none;letter-spacing:.04em}
.drawer-cta{background:var(--plum);color:#fff;text-align:center;padding:1rem;margin-top:1.6rem;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600}
.drawer-loc{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sage);text-align:center;margin-top:1rem}

/* ─── Scroll reveal ─── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* ─── HERO ─── */
.hero{
  position:relative;
  min-height:92vh;
  display:flex;
  align-items:flex-end;  /* anchor content toward bottom for editorial feel */
  overflow:hidden;
}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:48% 52%}
.hero-scrim{position:absolute;inset:0;background:
  linear-gradient(105deg,rgba(26,15,30,.84) 0%,rgba(42,26,48,.56) 48%,rgba(42,26,48,.22) 100%);}
.hero-content{
  position:relative;z-index:2;
  max-width:var(--maxw);margin:0 auto;
  padding:0 clamp(1.4rem,5vw,4rem) clamp(3rem,6vw,5rem);
  width:100%;
}
.hero-content h1{
  color:#fff;
  font-size:clamp(2.6rem,6.5vw,5.2rem);
  font-weight:200;
  margin:.4rem 0 1.4rem;
  max-width:14ch;
  text-shadow:0 2px 30px rgba(26,15,30,.4);
}
.hero-tag{
  font-family:var(--serif);font-style:italic;font-weight:300;
  color:#f3e7ec;font-size:clamp(1.05rem,2.2vw,1.45rem);
  max-width:36ch;margin:0 0 2.2rem;
}
.hero-badges{
  position:absolute;
  right:clamp(1rem,4vw,3rem);
  bottom:clamp(1.2rem,4vw,2.6rem);
  z-index:3;
  display:flex;gap:.7rem;align-items:center;
}
.hero-badges img{
  width:clamp(60px,9vw,82px);
  height:auto;
  filter:drop-shadow(0 6px 18px rgba(0,0,0,.3));
}

/* Hero — mobile fix (badges overlap resolution) */
@media(max-width:680px){
  .hero{
    min-height:90vh;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-end;
    padding-top:6rem;  /* clear sticky header */
    padding-bottom:0;
  }
  .hero-content{
    padding:0 1.4rem 1.6rem;
  }
  .hero-content h1{
    font-size:clamp(2.4rem,10vw,3.6rem);
    max-width:none;
  }
  .hero-badges{
    position:static;   /* in-flow below content */
    display:flex;
    justify-content:flex-start;
    align-items:center;
    gap:.6rem;
    padding:0 1.4rem 2rem;
    z-index:3;
  }
  .hero-badges img{
    width:clamp(54px,14vw,70px);
  }
}

/* ─── INTRO ─── */
.intro{background:var(--cream);padding:clamp(4rem,9vw,8rem) 0;position:relative;overflow:hidden}
.intro-sprig{position:absolute;top:6%;left:-40px;width:200px;opacity:.5;pointer-events:none}
.intro-grid{
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.4rem,5vw,4rem);
  display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,6vw,5rem);align-items:center;
}
.intro-text h2{font-size:clamp(1.8rem,3.8vw,3.1rem);color:var(--plum);margin-bottom:1.6rem;max-width:16ch}
.intro-text p{font-size:1.05rem;color:#4a4039;max-width:46ch;margin:0 0 1.2rem}
.intro-italic{font-family:var(--serif);font-style:italic;color:var(--plum);font-size:1.25rem!important;margin-bottom:2rem!important}
.intro-photo{margin:0;position:relative}
.intro-photo img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:50% 45%;box-shadow:0 30px 70px rgba(42,26,48,.22)}
.intro-photo figcaption{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage);margin-top:.9rem}
@media(max-width:820px){
  .intro-grid{grid-template-columns:1fr}
  .intro-photo{order:-1}
  .intro-photo img{aspect-ratio:4/3}
}

/* ─── EDITORIAL STRIP ─── */
.editorial-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  height:clamp(280px,32vw,450px);
  overflow:hidden;
  gap:0;
}
.es-fig{
  margin:0;
  overflow:hidden;
  position:relative;
}
.es-fig img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .9s ease;
}
.es-fig:hover img{
  transform:scale(1.05);
}
@media(max-width:500px){
  .editorial-strip{
    grid-template-columns:repeat(3,1fr);
    height:180px;
  }
}

/* ─── FOUNDER ─── */
.founder{background:var(--blush);padding:clamp(4rem,9vw,8rem) 0;position:relative;overflow:hidden}
.founder-grid{
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.4rem,5vw,4rem);
  display:grid;grid-template-columns:0.95fr 1.1fr;gap:0;align-items:center;position:relative;
}
.founder-portrait{margin:0}
.founder-portrait img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:45% 35%;box-shadow:0 30px 70px rgba(42,26,48,.25)}
.founder-panel{
  background:var(--white);padding:clamp(2.2rem,4vw,3.5rem);
  margin-left:-3rem;position:relative;z-index:2;
  box-shadow:0 24px 60px rgba(42,26,48,.14);
}
.founder-panel h2{font-size:clamp(2.2rem,4.4vw,3.4rem);color:var(--plum);margin:.2rem 0 1rem}
.founder-tag{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--plum);margin:0 0 1.4rem;line-height:1.4}
.founder-bio{font-size:.98rem;color:#4a4039;margin:0 0 1.8rem}
.founder-headshot{
  position:absolute;bottom:-46px;right:clamp(1.4rem,5vw,4rem);
  width:clamp(120px,16vw,200px);aspect-ratio:1/1;object-fit:cover;object-position:45% 30%;
  border:6px solid var(--blush);box-shadow:0 18px 44px rgba(42,26,48,.28);z-index:3;
}
@media(max-width:860px){
  .founder-grid{grid-template-columns:1fr;gap:0}
  .founder-panel{margin-left:0;margin-top:-2.5rem;margin-right:0;width:92%}
  .founder-headshot{display:none}  /* hide orphaned thumbnail on mobile */
}

/* ─── OUR DIFFERENCE ─── */
.difference{position:relative;min-height:58vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.diff-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:60% 55%}
.diff-scrim{position:absolute;inset:0;background:linear-gradient(rgba(42,26,48,.80),rgba(26,15,30,.82))}
.diff-content{position:relative;z-index:2;max-width:760px;padding:4rem clamp(1.4rem,5vw,2rem)}
.diff-mono{
  display:inline-flex;width:88px;height:88px;
  border:1px solid rgba(255,255,255,.55);border-radius:50%;
  align-items:center;justify-content:center;margin-bottom:1.6rem;
  background:rgba(255,255,255,.92);
}
.diff-mono img{width:52px;height:auto}
.diff-quote{
  font-family:var(--serif);font-style:italic;font-weight:300;color:#fff;
  font-size:clamp(1.35rem,3.2vw,2.1rem);line-height:1.4;margin:0;
}

/* ─── SERVICES GRID ─── */
.services{background:var(--cream);padding:clamp(4rem,9vw,8rem) 0}
.services-head{text-align:center;max-width:var(--maxw);margin:0 auto 3rem;padding:0 clamp(1.4rem,5vw,4rem)}
.services-head h2{font-size:clamp(2rem,5vw,3.6rem);color:var(--plum)}

/* 3-column bento — no gaps, no empty cells */
.services-grid{
  max-width:var(--maxw);margin:0 auto;
  padding:0 clamp(1.4rem,5vw,4rem);
  display:grid;
  grid-template-columns:1.1fr 1fr 1fr;
  grid-template-rows:280px 280px;
  gap:1.1rem;
}
.tile{position:relative;overflow:hidden;display:block;background:var(--plum-deep);min-width:0}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;filter:brightness(.92)}
.tile:hover img{transform:scale(1.07)}
/* Wedding tile: tall left column spanning both rows */
.tile-tall{grid-row:span 2}
.tile-label{
  position:absolute;left:0;bottom:0;width:100%;padding:1.6rem 1.2rem 1.1rem;
  color:#fff;font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  background:linear-gradient(transparent,rgba(26,15,30,.82));
  display:flex;flex-direction:column;gap:.3rem;
}
.tile-label em{font-style:normal;font-size:.66rem;letter-spacing:.16em;color:#e6cdd6;opacity:0;transform:translateY(6px);transition:.35s}
.tile:hover .tile-label em{opacity:1;transform:none}

/* Tablet: 2-col, last tile full width */
@media(max-width:900px){
  .services-grid{
    grid-template-columns:repeat(2,1fr);
    grid-template-rows:none;
    grid-auto-rows:220px;
  }
  .tile-tall{grid-row:span 1}
  .services-grid .tile:last-child{grid-column:span 2}
}
/* Mobile: single column */
@media(max-width:520px){
  .services-grid{
    grid-template-columns:1fr;
    grid-auto-rows:230px;
  }
  .services-grid .tile:last-child{grid-column:span 1}
}

/* ─── TESTIMONIALS ─── */
.testimonials{background:var(--plum);padding:clamp(4rem,9vw,8rem) 0;color:#fff;position:relative}
.testi-inner{max-width:840px;margin:0 auto;padding:0 clamp(1.4rem,5vw,2rem);text-align:center}
.testi-inner .eyebrow{color:#caa9bb}
.testi-viewport{overflow:hidden;margin:1rem 0 2.2rem}
.testi-track{display:flex;list-style:none;margin:0;padding:0;transition:transform .6s cubic-bezier(.5,.1,.2,1)}
.testi-slide{min-width:100%;padding:0 .5rem}
.testi-slide blockquote{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(1.4rem,3.6vw,2.4rem);line-height:1.36;margin:0 0 1.4rem;color:#fff}
.testi-slide cite{font-family:var(--sans);font-style:normal;font-weight:600;font-size:.74rem;
  letter-spacing:.24em;text-transform:uppercase;color:#d9bccd}
.testi-controls{display:flex;align-items:center;justify-content:center;gap:1.6rem}
.testi-btn{width:52px;height:52px;border:1px solid rgba(255,255,255,.35);background:none;color:#fff;
  border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.3s}
.testi-btn:hover{background:#fff;color:var(--plum)}
.testi-btn:focus-visible{outline:2px solid var(--fig);outline-offset:3px}
.testi-dots{display:flex;gap:.55rem}
.testi-dots button{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.32);cursor:pointer;padding:0;transition:.3s}
.testi-dots button.active{background:#fff;transform:scale(1.3)}
.testi-dots button:focus-visible{outline:2px solid var(--fig);outline-offset:2px}

/* ─── GET STARTED ─── */
/* Full-bleed: no max-width constraint so photo + panel go edge-to-edge */
.get-started{
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:stretch;
}
.gs-photo{margin:0;overflow:hidden}
.gs-photo img{
  width:100%;height:100%;
  object-fit:cover;object-position:50% 40%;
  min-height:460px;
  display:block;
}
.gs-panel{background:var(--plum);color:#fff;padding:clamp(2.8rem,6vw,5rem) clamp(2.4rem,5vw,4.5rem)}
.gs-panel h2{font-size:clamp(2.2rem,4.6vw,3.6rem);margin-bottom:1.4rem;color:#fff}
.gs-italic{font-family:var(--serif);font-style:italic;font-size:clamp(1.15rem,2.2vw,1.45rem);line-height:1.45;color:#f0e3e9;margin:0 0 1.4rem}
.gs-body{color:#dcccd4;margin:0 0 2rem;max-width:42ch;font-size:.98rem}
@media(max-width:780px){
  .get-started{grid-template-columns:1fr}
  .gs-photo img{min-height:320px}
}

/* ─── CLOSING BANNER ─── */
.closing{position:relative;min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.closing-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.closing-scrim{position:absolute;inset:0;background:linear-gradient(rgba(59,35,64,.62),rgba(42,26,48,.72))}
.closing-content{position:relative;z-index:2;max-width:720px;padding:4rem clamp(1.4rem,5vw,2rem)}
.closing-content h2{color:#fff;font-size:clamp(2rem,5vw,3.5rem);margin-bottom:1.4rem}
.closing-content p{color:#f0e6ea;margin:0 auto 2.2rem;max-width:52ch}

/* ─── FOOTER ─── */
.site-footer{background:var(--plum-deep);color:#e6dbe1;padding:clamp(3rem,6vw,5rem) clamp(1.4rem,5vw,4rem) 2.4rem}
.footer-top{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1fr 1.2fr 1fr;
  gap:2.5rem;align-items:center;
}
/* Footer wordmark (replaces monogram) */
.footer-wordmark{
  width:clamp(120px,16vw,175px);
  height:auto;
  filter:brightness(0) invert(1);
  opacity:.9;
  margin-bottom:1.2rem;
}
.footer-tag{font-size:.92rem;color:#cbbac4;max-width:34ch}
.footer-tiles{display:flex;gap:.8rem;justify-content:center;align-items:stretch}
/* Flexible tile widths — no fixed px that overflow at mobile */
.footer-tiles img{
  flex:1;
  min-width:0;
  height:150px;
  object-fit:cover;
  width:0; /* let flex handle distribution */
  max-width:160px;
}
.footer-loc{text-align:right}
.floc-head{font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;font-weight:600;color:#fff;margin:0 0 .6rem}
.floc-sub{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:#a98ba0;line-height:1.8;margin:0}
.footer-nav{
  max-width:var(--maxw);margin:3rem auto;
  display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;
  padding:1.8rem 0;
  border-top:1px solid rgba(255,255,255,.12);
  border-bottom:1px solid rgba(255,255,255,.12);
}
.footer-nav a{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:#d8c8d1;transition:.3s}
.footer-nav a:hover{color:#fff}
.footer-bottom{
  max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:1.4rem;flex-wrap:wrap;
}
.footer-legal{display:flex;gap:1.4rem;flex-wrap:wrap}
.footer-legal a{font-size:.72rem;color:#b5a3ae;transition:.3s}
.footer-legal a:hover{color:#fff}
.footer-social{display:flex;gap:.4rem;flex-wrap:wrap}
.footer-social a{
  width:34px;height:34px;border:1px solid rgba(255,255,255,.2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:.85rem;
  color:#d8c8d1;transition:.3s;
}
.footer-social a:hover{background:#fff;color:var(--plum)}
.footer-copy{font-size:.72rem;color:#a98ba0;margin:0}

@media(max-width:820px){
  .footer-top{grid-template-columns:1fr;text-align:center;gap:2rem}
  .footer-brand,.footer-loc{text-align:center}
  .footer-tag{margin:0 auto}
  .footer-wordmark{margin:0 auto 1.2rem}
  .footer-loc{text-align:center}
  .floc-sub{text-align:center}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-tiles{justify-content:center}
  .footer-tiles img{max-width:none;height:130px}
}

/* ─── Nav responsive breakpoint ─── */
@media(max-width:1080px){
  .primary-nav{display:none}
  .cta-inquire{display:none}
  .menu-toggle{display:flex}
  .brand-logo{height:52px}
}

/* ─── Focus styles ─── */
a:focus-visible,button:focus-visible{outline:2px solid var(--fig);outline-offset:3px}