/* ============================================================
   Serenity Wills — foundation, atmosphere, components
   ============================================================ */

:root{
  --mist:#EAF2F9;      /* page bg, soft blue */
  --cloud:#FFFFFF;     /* cards */
  --panel:#E0ECF5;     /* soft inset panels */
  --sky:#5FA8DD;       /* sky blue, blobs/gradients/accents */
  --teal:#15607A;      /* dominant deep serene teal-blue */
  --teal-deep:#0B3D4F; /* dark anchor / hover */
  --ink:#13303D;       /* deep navy text */
  --ink-soft:#566E79;  /* secondary text */
  --gold:#C9923B;      /* warm champagne accent */
  --coral:#E8896B;     /* warm coral, sparing contrast */

  --maxw:1180px;
  --gutter:clamp(20px, 5vw, 56px);
  --radius:18px;
  --radius-lg:26px;
  --shadow-soft:0 10px 30px -16px rgba(11,61,79,.28), 0 2px 8px -3px rgba(11,61,79,.12);
  --shadow-card:0 18px 44px -22px rgba(11,61,79,.42), 0 3px 10px -4px rgba(11,61,79,.16);
  --shadow-lift:0 30px 64px -28px rgba(11,61,79,.5), 0 6px 16px -6px rgba(11,61,79,.2);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:"Mulish", system-ui, -apple-system, sans-serif;
  font-size:17px;
  line-height:1.62;
  color:var(--ink);
  background:var(--mist);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

@media (min-width:768px){ body{ font-size:18px; } }

h1,h2,h3{
  font-family:"Cormorant Garamond", Georgia, serif;
  font-weight:600;
  line-height:1.06;
  letter-spacing:.004em;
  margin:0;
  color:var(--ink);
  text-wrap:balance;
}

p{ margin:0; text-wrap:pretty; }

a{ color:inherit; text-decoration:none; }

button{ font-family:inherit; cursor:pointer; }

:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:2px;
  border-radius:6px;
}

.shell{
  width:100%;
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--gutter);
}

/* ---------- atmosphere: gradient mesh + drifting blobs ---------- */

.atmosphere{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  overflow:hidden;
  background:
    radial-gradient(70% 55% at 12% 8%, rgba(111,177,227,.20), transparent 60%),
    radial-gradient(60% 50% at 92% 4%, rgba(21,96,122,.12), transparent 58%),
    radial-gradient(75% 60% at 80% 92%, rgba(111,177,227,.16), transparent 60%);
}

.blob{
  position:absolute;
  border-radius:46% 54% 60% 40% / 52% 44% 56% 48%;
  filter:blur(46px);
  opacity:.5;
  will-change:transform;
  mix-blend-mode:multiply;
}
.blob--a{
  width:46vw; height:46vw; max-width:620px; max-height:620px;
  top:-8vw; left:-10vw;
  background:radial-gradient(circle at 35% 35%, var(--sky), rgba(111,177,227,0) 70%);
  animation:drift-a 34s var(--ease) infinite alternate;
}
.blob--b{
  width:40vw; height:40vw; max-width:540px; max-height:540px;
  top:30vh; right:-12vw;
  background:radial-gradient(circle at 60% 40%, rgba(21,96,122,.55), rgba(21,96,122,0) 70%);
  opacity:.34;
  animation:drift-b 42s var(--ease) infinite alternate;
}
.blob--c{
  width:50vw; height:50vw; max-width:680px; max-height:680px;
  bottom:-16vw; left:18vw;
  background:radial-gradient(circle at 50% 50%, var(--sky), rgba(111,177,227,0) 68%);
  opacity:.4;
  animation:drift-c 48s var(--ease) infinite alternate;
}

@keyframes drift-a{ to{ transform:translate3d(6vw,5vh,0) scale(1.12) rotate(12deg); } }
@keyframes drift-b{ to{ transform:translate3d(-7vw,-4vh,0) scale(1.08) rotate(-10deg); } }
@keyframes drift-c{ to{ transform:translate3d(4vw,-6vh,0) scale(1.14) rotate(8deg); } }

.grain{
  position:fixed; inset:0; z-index:0; pointer-events:none;
  opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

main{ position:relative; z-index:1; }

/* ============================================================
   HEADER
   ============================================================ */

.header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(234,242,249,.72);
  backdrop-filter:blur(14px) saturate(1.4);
  -webkit-backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid rgba(21,96,122,.10);
  transition:box-shadow .4s var(--ease), background .4s var(--ease);
}
.header[data-scrolled="true"]{
  background:rgba(234,242,249,.9);
  box-shadow:0 12px 34px -26px rgba(14,74,96,.5);
}

.header__bar{
  display:flex;
  align-items:center;
  gap:22px;
  min-height:78px;
  padding-block:12px;
}

/* wordmark */
.wordmark{ display:flex; align-items:center; margin-right:auto; }
.wordmark__logo{
  display:block;
  height:54px;
  width:auto;
  /* logo art is bright blue (#3399ff) on a light ground; multiply drops the
     ground against the misty header, the filter pulls it toward brand teal */
  mix-blend-mode:multiply;
  filter:saturate(.86) brightness(.66) hue-rotate(-16deg) contrast(1.1);
}
@media (max-width:767px){ .wordmark__logo{ height:48px; } }
.wordmark.logo-fail .wordmark__logo{ display:none; }

.wordmark__fallback{ display:none; flex-direction:column; line-height:1; }
.wordmark.logo-fail .wordmark__fallback{ display:flex; }
.wordmark__name{
  font-family:"Cormorant Garamond", serif;
  font-style:italic;
  font-weight:600;
  font-size:clamp(28px, 5.4vw, 38px);
  letter-spacing:.01em;
  background:linear-gradient(95deg, var(--teal) 0%, var(--sky) 92%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.wordmark__sub{
  font-size:9.5px;
  font-weight:700;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--ink-soft);
  padding-left:.18em;
  margin-top:3px;
  white-space:nowrap;
}
@media (min-width:768px){
  .wordmark__sub{ font-size:10.5px; letter-spacing:.4em; }
}

/* nav */
.nav{ display:none; }
@media (min-width:1024px){
  .nav{ display:flex; align-items:center; gap:26px; }
}
.nav__link{
  position:relative;
  font-size:15px;
  font-weight:500;
  color:var(--ink);
  padding-block:6px;
  white-space:nowrap;
  transition:color .25s var(--ease);
}
.nav__link::after{
  content:"";
  position:absolute; left:0; bottom:0;
  width:100%; height:1.5px;
  background:var(--gold);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .32s var(--ease);
}
.nav__link:hover{ color:var(--teal); }
.nav__link:hover::after{ transform:scaleX(1); }

.header__actions{ display:flex; align-items:center; gap:14px; }

.tel{
  display:none;
  align-items:center;
  gap:8px;
  font-weight:700;
  font-size:15px;
  color:var(--teal);
  white-space:nowrap;
  transition:color .25s var(--ease);
}
.tel:hover{ color:var(--teal-deep); }
.tel svg{ width:16px; height:16px; }
@media (min-width:560px){ .tel{ display:inline-flex; } }

/* buttons */
.btn{
  --pad-y:13px; --pad-x:22px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  padding:var(--pad-y) var(--pad-x);
  border-radius:999px;
  font-weight:700;
  font-size:15px;
  letter-spacing:.01em;
  border:1.5px solid transparent;
  white-space:nowrap;
  transition:transform .28s var(--ease), box-shadow .28s var(--ease),
             background .28s var(--ease), color .28s var(--ease), border-color .28s var(--ease);
}
.btn svg{ width:17px; height:17px; flex:none; }

.btn--gold{
  background:linear-gradient(170deg, #d6ac5e, var(--gold));
  color:#3a2c10;
  box-shadow:0 14px 30px -16px rgba(196,154,77,.7);
}
.btn--gold:hover{ transform:translateY(-2px); box-shadow:0 20px 38px -16px rgba(196,154,77,.8); }
.btn--gold:active{ transform:translateY(0); }

.btn--teal{
  background:var(--teal);
  color:#fff;
  box-shadow:0 16px 32px -18px rgba(21,96,122,.8);
}
.btn--teal:hover{ background:var(--teal-deep); transform:translateY(-2px); }

.btn--outline{
  background:rgba(255,255,255,.55);
  color:var(--teal);
  border-color:rgba(21,96,122,.4);
}
.btn--outline:hover{ background:#fff; border-color:var(--teal); transform:translateY(-2px); }

.btn--sm{ --pad-y:10px; --pad-x:18px; font-size:14px; }

.header .btn--gold{ display:none; }
@media (min-width:768px){ .header .btn--gold{ display:inline-flex; } }

/* ============================================================
   HERO
   ============================================================ */

.hero{
  position:relative;
  padding-top:clamp(40px, 7vh, 84px);
  padding-bottom:clamp(48px, 8vh, 96px);
}
.hero__inner{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(34px,5vw,56px);
  align-items:center;
}
@media (min-width:920px){
  .hero__inner{ grid-template-columns:1.05fr .95fr; }
}
.hero__copy{ text-align:center; }
@media (min-width:920px){ .hero__copy{ text-align:left; } }
.hero .eyebrow{ margin-bottom:18px; }

.eyebrow{
  display:inline-block;
  font-size:12.5px;
  font-weight:700;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
}
.eyebrow--center{ margin-bottom:18px; }

.hero h1{
  font-size:clamp(40px, 6.6vw, 70px);
  font-weight:500;
  letter-spacing:-.01em;
  margin-bottom:22px;
}
.hero h1 em{
  font-style:italic;
  font-weight:500;
  background:linear-gradient(95deg, var(--teal), var(--sky));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

.hero__sub{
  font-size:clamp(17px, 2.2vw, 20px);
  color:var(--ink-soft);
  max-width:560px;
  margin-inline:auto;
  margin-bottom:32px;
}
@media (min-width:920px){ .hero__sub{ margin-inline:0; } }

.hero__ctas{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  justify-content:center;
}
@media (min-width:920px){ .hero__ctas{ justify-content:flex-start; } }
.hero__ctas .btn{ --pad-y:16px; --pad-x:28px; font-size:16px; }

.hero__trust{
  display:inline-flex;
  align-items:flex-start;
  gap:10px;
  margin-top:30px;
  font-size:15px;
  color:var(--ink-soft);
  text-align:left;
}
.hero__trust .seal{
  width:22px; height:22px; color:var(--teal); flex:none; margin-top:2px;
}
.hero__trust b{ color:var(--ink); font-weight:700; }

/* hero focal image */
.hero__figure{
  position:relative;
  justify-self:center;
  width:min(100%, 520px);
  aspect-ratio:5/6;
}
.hero__ring{
  position:absolute;
  inset:-6% -6% -6% -6%;
  border:2px solid rgba(95,168,221,.4);
  border-radius:48% 52% 46% 54% / 52% 46% 54% 48%;
  z-index:0;
}
.hero__warm{
  position:absolute;
  width:46%; height:46%;
  right:-7%; top:-7%;
  border-radius:50%;
  background:radial-gradient(circle at 40% 40%, var(--gold), var(--coral) 70%, rgba(232,137,107,0));
  filter:blur(8px);
  opacity:.78;
  z-index:0;
}
.hero__warm--low{
  right:auto; left:-8%; top:auto; bottom:-6%;
  width:30%; height:30%;
  background:radial-gradient(circle at 50% 50%, var(--sky), rgba(95,168,221,0) 72%);
  opacity:.6;
}
.hero__shape{
  position:relative;
  z-index:1;
  width:100%; height:100%;
  border-radius:54% 46% 48% 52% / 46% 52% 48% 54%;
  overflow:hidden;
  box-shadow:var(--shadow-lift);
  background:linear-gradient(150deg, var(--teal), var(--sky));
  border:5px solid #fff;
}
.hero__shape img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
}
.hero__shape.is-failed{
  background:linear-gradient(150deg, var(--teal-deep), var(--sky));
}
.hero__shape.is-failed img{ display:none; }
.hero__shape.is-failed::after{
  content:"";
  position:absolute; width:60%; height:60%; right:-10%; bottom:-10%;
  border-radius:50%;
  background:radial-gradient(circle at 40% 40%, rgba(255,255,255,.35), rgba(255,255,255,0) 70%);
}

/* ============================================================
   TRUST STRIP
   ============================================================ */

.trust{ padding-block:clamp(34px, 6vh, 64px); }

.trust__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
@media (min-width:560px){ .trust__grid{ grid-template-columns:1fr 1fr; } }
@media (min-width:1024px){ .trust__grid{ grid-template-columns:repeat(4,1fr); gap:18px; } }

.chip{
  display:flex;
  align-items:center;
  gap:14px;
  padding:18px 20px;
  background:rgba(255,255,255,.7);
  border:1px solid rgba(21,96,122,.12);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(6px);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.chip:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lift); }

.chip__icon{
  flex:none;
  width:46px; height:46px;
  display:grid; place-items:center;
  border-radius:13px;
  background:linear-gradient(160deg, var(--panel), #fff);
  border:1px solid rgba(21,96,122,.14);
  color:var(--teal);
}
.chip__icon svg{ width:23px; height:23px; }
.chip__text{ font-size:15px; font-weight:600; line-height:1.34; color:var(--ink); }

/* ============================================================
   COMPACT SELECTOR NUDGE (optional extra, after fees)
   ============================================================ */

.nudge{ padding-block:clamp(40px,7vh,78px); }
.nudge__card{
  max-width:980px; margin-inline:auto;
  background:var(--cloud);
  border:1px solid rgba(19,48,61,.10);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  padding:clamp(26px,4vw,42px);
  display:grid; gap:24px;
}
@media (min-width:820px){
  .nudge__card{ grid-template-columns:.82fr 1.18fr; align-items:center; gap:clamp(28px,4vw,48px); }
}
.nudge__intro h2{ font-size:clamp(27px,3.6vw,36px); font-weight:500; margin:12px 0 12px; }
.nudge__intro p{ font-size:16px; color:var(--ink-soft); }

.seg{ display:flex; flex-wrap:wrap; gap:10px; }
.seg__btn{
  flex:1 1 auto;
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  min-height:48px; padding:11px 16px;
  background:var(--mist);
  border:1.5px solid rgba(19,48,61,.12);
  border-radius:14px;
  font-family:"Mulish",sans-serif; font-size:15px; font-weight:600; color:var(--ink);
  text-align:left; line-height:1.2;
  transition:transform .25s var(--ease), border-color .25s var(--ease),
             background .25s var(--ease), box-shadow .25s var(--ease), color .25s var(--ease);
}
.seg__btn svg{ width:18px; height:18px; flex:none; color:var(--teal); transition:color .25s var(--ease); }
.seg__btn:hover{ border-color:rgba(19,48,61,.28); transform:translateY(-2px); }
.seg__btn[aria-pressed="true"]{
  background:linear-gradient(160deg, #fff, var(--panel));
  border-color:var(--gold);
  box-shadow:0 0 0 2px rgba(201,146,59,.35), var(--shadow-soft);
  color:var(--teal-deep);
}
.seg__btn[aria-pressed="true"] svg{ color:var(--gold); }

.suggest{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .42s var(--ease); }
.suggest.is-open{ grid-template-rows:1fr; }
.suggest__clip{ overflow:hidden; min-height:0; }
.suggest__inner{
  display:flex; align-items:flex-start; gap:14px;
  margin-top:18px; padding:18px 20px;
  background:linear-gradient(150deg, rgba(95,168,221,.12), rgba(201,146,59,.10));
  border:1px solid rgba(19,48,61,.1);
  border-radius:16px;
}
.suggest__arrow{
  flex:none; width:34px; height:34px; border-radius:10px;
  display:grid; place-items:center; color:#fff;
  background:linear-gradient(160deg, var(--gold), #b07f2c);
}
.suggest__arrow svg{ width:18px; height:18px; }
.suggest__text{ font-size:16px; color:var(--ink); line-height:1.45; }
.suggest__text strong{ color:var(--teal-deep); font-weight:700; }
.suggest__link{
  display:inline-block; margin-top:2px;
  font-weight:700; color:var(--teal);
  border-bottom:1.5px solid rgba(21,96,122,.4);
}
.suggest__link:hover{ color:var(--teal-deep); }

/* ============================================================
   ENTRANCE + REVEAL MOTION
   ============================================================ */

[data-rise]{ opacity:0; transform:translateY(22px); }
.is-loaded [data-rise]{
  animation:rise .9s var(--ease) forwards;
  animation-delay:var(--d, 0ms);
}
@keyframes rise{ to{ opacity:1; transform:none; } }

[data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }

@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  .blob{ animation:none !important; }
  [data-rise],[data-reveal]{ opacity:1 !important; transform:none !important; animation:none !important; transition:none !important; }
}

/* sticky-header scroll offset for anchors */
section[id], div[id].anchor{ scroll-margin-top:92px; }

/* ============================================================
   SHARED SECTION HEADINGS
   ============================================================ */

.section{ position:relative; padding-block:clamp(48px, 8vh, 92px); }
.section--mist{ background:var(--mist); }
.section--white{ background:var(--cloud); }
.section--dark{
  background:
    radial-gradient(90% 120% at 85% 0%, rgba(95,168,221,.22), transparent 60%),
    linear-gradient(165deg, var(--teal-deep), #08303f);
  color:#e6f1f7;
}
.section--dark .eyebrow{ color:#e8b65f; }
.section--dark .section__head h2{ color:#fff; }
.section__head{ text-align:center; max-width:640px; margin-inline:auto; margin-bottom:clamp(30px,4.5vh,48px); }
.section__head h2{
  font-size:clamp(34px, 5.6vw, 52px);
  font-weight:500;
  margin-top:14px;
  margin-bottom:14px;
}
.section__head p{ font-size:clamp(17px,2.2vw,19px); color:var(--ink-soft); max-width:560px; margin-inline:auto; }

/* ============================================================
   SOFT SECTION TRANSITIONS (gentle wave drips, no hard rules)
   Each section drips its own colour downward into the next with
   a calm curved edge, so every boundary reads as organic.
   ============================================================ */

.softdiv{ position:relative; }
.softdiv::after{
  content:"";
  position:absolute;
  left:-2px; right:-2px;
  bottom:0;
  height:clamp(36px, 5vw, 66px);
  transform:translateY(99.5%);
  background-repeat:no-repeat;
  background-position:center top;
  background-size:100% 100%;
  pointer-events:none;
  z-index:3;
}
.drip-mist::after{ background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%201440%2066'%20preserveAspectRatio='none'%3E%3Cpath%20d='M0,0H1440V30C1050,8,400,56,0,30Z'%20fill='%23EAF2F9'/%3E%3C/svg%3E"); }
.drip-white::after{ background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%201440%2066'%20preserveAspectRatio='none'%3E%3Cpath%20d='M0,0H1440V30C1050,8,400,56,0,30Z'%20fill='%23FFFFFF'/%3E%3C/svg%3E"); }
.drip-dark::after{ background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%201440%2066'%20preserveAspectRatio='none'%3E%3Cpath%20d='M0,0H1440V30C1050,8,400,56,0,30Z'%20fill='%230a3848'/%3E%3C/svg%3E"); }

/* ============================================================
   FEES
   ============================================================ */

.fees__lead{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
}
@media (min-width:760px){ .fees__lead{ grid-template-columns:repeat(3,1fr); align-items:stretch; } }

.fee{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:30px 26px;
  background:var(--cloud);
  border:1px solid rgba(19,48,61,.10);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  transition:transform .34s var(--ease), box-shadow .34s var(--ease), border-color .34s var(--ease);
}
.fee:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lift); }
.fee--featured{ border-color:rgba(196,154,77,.55); box-shadow:0 0 0 1px rgba(196,154,77,.4), var(--shadow-lift); }
@media (min-width:760px){ .fee--featured{ transform:translateY(-10px); } .fee--featured:hover{ transform:translateY(-16px); } }

.fee__tag{
  position:absolute; top:-12px; left:50%; transform:translateX(-50%);
  font-size:11px; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  color:#3a2c10;
  background:linear-gradient(170deg, #d6ac5e, var(--gold));
  padding:6px 14px; border-radius:999px;
  box-shadow:0 10px 22px -12px rgba(196,154,77,.8);
  white-space:nowrap;
}
.fee__name{ font-family:"Cormorant Garamond",serif; font-size:25px; font-weight:600; line-height:1.16; }
.fee__price{
  font-family:"Cormorant Garamond",serif; font-size:48px; font-weight:600; line-height:1;
  color:var(--ink);
}
.fee__desc{ font-size:15.5px; color:var(--ink-soft); margin-top:auto; }
.fee__rule{ height:1px; background:linear-gradient(90deg, transparent, rgba(196,154,77,.5), transparent); }

/* LPA fee panel */
.lpa-fee{
  margin-top:18px;
  display:grid; gap:20px; align-items:center;
  grid-template-columns:1fr;
  padding:28px 30px;
  background:linear-gradient(160deg, var(--panel), #fff);
  border:1px solid rgba(21,96,122,.16);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-soft);
}
@media (min-width:680px){ .lpa-fee{ grid-template-columns:auto 1fr; gap:28px; } }
.lpa-fee__price{
  font-family:"Cormorant Garamond",serif; font-weight:600; line-height:1; color:var(--teal);
  font-size:40px; white-space:nowrap;
}
.lpa-fee__price small{ display:block; font-size:15px; font-family:"Mulish",sans-serif; color:var(--ink-soft); font-weight:600; margin-top:6px; }
.lpa-fee__name{ font-family:"Cormorant Garamond",serif; font-size:24px; font-weight:600; margin-bottom:6px; }
.lpa-fee__desc{ font-size:15.5px; color:var(--ink-soft); }

/* more services */
.more{
  margin-top:26px;
  background:var(--panel);
  border:1px solid rgba(19,48,61,.10);
  border-radius:var(--radius-lg);
  padding:22px clamp(20px,3vw,30px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6);
}
.more__title{
  font-size:12.5px; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink-soft); margin-bottom:6px;
}
.more__list{ list-style:none; margin:0; padding:0; }
.more__list li{
  display:flex; justify-content:space-between; gap:18px;
  padding:13px 0;
  border-bottom:1px solid rgba(21,96,122,.1);
  font-size:15.5px;
}
.more__list li:last-child{ border-bottom:0; }
.more__list .svc{ color:var(--ink); font-weight:500; }
.more__list .amt{ color:var(--teal); font-weight:700; white-space:nowrap; }

.footnote{
  text-align:center; margin-top:24px;
  font-size:15px; color:var(--ink-soft); font-style:italic;
  font-family:"Cormorant Garamond",serif; font-size:19px;
}

/* ============================================================
   STEPS (how it works / home visit)
   ============================================================ */

.steps{
  display:grid; gap:18px;
  grid-template-columns:1fr;
}
@media (min-width:760px){ .steps{ grid-template-columns:repeat(3,1fr); } }

.step{
  position:relative;
  padding:30px 26px;
  background:var(--cloud);
  border:1px solid rgba(21,96,122,.12);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-soft);
  transition:transform .34s var(--ease), box-shadow .34s var(--ease);
}
.step:hover{ transform:translateY(-5px); box-shadow:var(--shadow-lift); }
.step__row{ display:flex; align-items:center; gap:14px; margin-bottom:16px; }
.step__num{
  flex:none; width:38px; height:38px;
  display:grid; place-items:center; border-radius:50%;
  font-family:"Cormorant Garamond",serif; font-size:20px; font-weight:600;
  color:var(--gold);
  background:linear-gradient(160deg,#f4e6c8,#fff);
  border:1px solid rgba(196,154,77,.4);
}
.step__icon{
  width:46px; height:46px; display:grid; place-items:center; border-radius:13px;
  background:linear-gradient(160deg, var(--panel), #fff);
  border:1px solid rgba(21,96,122,.14); color:var(--teal); margin-left:auto;
}
.step__icon svg{ width:23px; height:23px; }
.step__title{ font-family:"Cormorant Garamond",serif; font-size:23px; font-weight:600; margin-bottom:8px; line-height:1.18; }
.step__body{ font-size:15.5px; color:var(--ink-soft); }

/* dark-section steps */
.section--dark .step{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(232,182,95,.28);
  box-shadow:0 20px 44px -28px rgba(0,0,0,.6);
  backdrop-filter:blur(4px);
}
.section--dark .step:hover{ background:rgba(255,255,255,.08); box-shadow:0 28px 56px -28px rgba(0,0,0,.7); }
.section--dark .step__num{
  color:var(--teal-deep);
  background:linear-gradient(160deg, #e8b65f, #cf9836);
  border:1px solid rgba(232,182,95,.6);
}
.section--dark .step__icon{
  background:rgba(95,168,221,.16);
  border:1px solid rgba(232,182,95,.3);
  color:#bfe0f3;
}
.section--dark .step__title{ color:#fff; }
.section--dark .step__body{ color:#bcd3de; }

.center-cta{ text-align:center; margin-top:clamp(30px,5vh,44px); }

/* ============================================================
   LPA EXPLAINER
   ============================================================ */

.lpa-panel{
  position:relative;
  max-width:880px; margin-inline:auto;
  padding:clamp(32px,5vw,56px);
  background:linear-gradient(165deg, rgba(255,255,255,.95), rgba(231,241,248,.92));
  border:1px solid rgba(21,96,122,.16);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-soft);
  text-align:center;
  overflow:hidden;
}
.lpa-panel::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:radial-gradient(70% 80% at 100% 0%, rgba(111,177,227,.18), transparent 60%);
}
.lpa-panel h2{ font-size:clamp(30px,4.6vw,42px); font-weight:500; margin-bottom:18px; }
.lpa-panel p{ font-size:clamp(17px,2.2vw,19px); color:var(--ink-soft); max-width:620px; margin-inline:auto; margin-bottom:28px; }

/* ============================================================
   REVIEWS
   ============================================================ */

.reviews__grid{ display:grid; gap:18px; grid-template-columns:1fr; }
@media (min-width:720px){ .reviews__grid{ grid-template-columns:1fr 1fr; } }

.quote{
  position:relative;
  padding:34px 30px 30px;
  background:var(--cloud);
  border:1px solid rgba(21,96,122,.12);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-soft);
  transition:transform .34s var(--ease), box-shadow .34s var(--ease);
}
.quote:hover{ transform:translateY(-5px); box-shadow:var(--shadow-lift); }
.quote__mark{
  font-family:"Cormorant Garamond",serif; font-size:64px; line-height:.6;
  color:rgba(196,154,77,.5); height:30px; display:block;
}
.quote__text{
  font-family:"Cormorant Garamond",serif; font-size:clamp(21px,3vw,25px);
  font-weight:500; line-height:1.34; color:var(--ink); margin-bottom:18px;
}
.quote__who{ display:flex; align-items:center; gap:12px; }
.quote__dot{ width:8px; height:8px; border-radius:50%; background:var(--gold); flex:none; }
.quote__name{ font-size:15px; font-weight:700; color:var(--teal); }
.quote__place{ font-size:14px; color:var(--ink-soft); }

/* ============================================================
   CONTACT
   ============================================================ */

.contact__grid{
  display:grid; gap:28px; grid-template-columns:1fr;
  align-items:start;
}
@media (min-width:880px){ .contact__grid{ grid-template-columns:1.1fr .9fr; gap:44px; } }

.contact__intro h2{ font-size:clamp(32px,5vw,48px); font-weight:500; margin-bottom:18px; text-align:left; }
.contact__intro p{ font-size:clamp(17px,2.2vw,19px); color:var(--ink-soft); margin-bottom:22px; }

.contact__where{
  margin-top:8px;
  padding:22px 24px;
  background:rgba(255,255,255,.6);
  border:1px solid rgba(21,96,122,.12);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
}
.contact__where .label{
  font-size:12px; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold); margin-bottom:8px;
}
.contact__where p{ font-size:16px; color:var(--ink); margin:0; }
.contact__call{
  display:inline-flex; align-items:center; gap:9px; margin-top:18px; white-space:nowrap;
  font-family:"Cormorant Garamond",serif; font-size:28px; font-weight:600; color:var(--teal);
}
.contact__call:hover{ color:var(--teal-deep); }
.contact__call svg{ width:22px; height:22px; }

/* form */
.form{
  background:var(--cloud);
  border:1px solid rgba(21,96,122,.14);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lift);
  padding:clamp(26px,4vw,38px);
}
.field{ margin-bottom:18px; }
.field label{
  display:block; font-size:14px; font-weight:700; color:var(--ink); margin-bottom:7px;
}
.field input, .field textarea{
  width:100%;
  font-family:inherit; font-size:16px; color:var(--ink);
  background:var(--mist);
  border:1.5px solid rgba(21,96,122,.18);
  border-radius:12px;
  padding:13px 15px;
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
}
.field input::placeholder, .field textarea::placeholder{ color:#9bb0ba; }
.field input:focus, .field textarea:focus{
  outline:none;
  border-color:var(--teal);
  background:#fff;
  box-shadow:0 0 0 3px rgba(21,96,122,.12);
}
.field input:focus-visible, .field textarea:focus-visible{
  outline:2px solid var(--gold); outline-offset:2px;
}
.field textarea{ resize:vertical; min-height:110px; }
.field--error input, .field--error textarea{ border-color:#c2532f; }
.field__err{ font-size:13px; color:#c2532f; margin-top:6px; display:none; }
.field--error .field__err{ display:block; }

.form .btn{ width:100%; --pad-y:16px; font-size:16px; margin-top:4px; }
.form__note{ font-size:13px; color:var(--ink-soft); margin-top:14px; text-align:center; }

.form__sent{
  text-align:center; padding:18px 10px;
}
.form__sent .tick{
  width:60px; height:60px; margin:0 auto 16px; border-radius:50%;
  display:grid; place-items:center; color:#fff;
  background:linear-gradient(160deg, var(--sky), var(--teal));
}
.form__sent .tick svg{ width:30px; height:30px; }
.form__sent h3{ font-size:28px; font-weight:600; margin-bottom:8px; }
.form__sent p{ font-size:16px; color:var(--ink-soft); }

/* ============================================================
   FOOTER
   ============================================================ */

.footer{
  position:relative; z-index:1;
  background:linear-gradient(180deg, var(--teal), var(--teal-deep));
  color:#cfe4ee;
}
.footer__inner{ padding-block:clamp(58px,8vh,86px) clamp(46px,7vh,72px); display:grid; gap:34px; grid-template-columns:1fr; }
@media (min-width:760px){ .footer__inner{ grid-template-columns:1.3fr 1fr 1fr; gap:44px; } }

.footer__word{ font-family:"Cormorant Garamond",serif; font-style:italic; font-weight:600; font-size:34px; color:#fff; line-height:1; }
.footer__word small{ display:block; font-family:"Mulish",sans-serif; font-style:normal; font-size:10px; letter-spacing:.34em; text-transform:uppercase; color:#9cc3d4; margin-top:8px; font-weight:700; }
.footer p{ font-size:15px; line-height:1.7; color:#bcd8e4; }
.footer__col h4{
  font-family:"Mulish",sans-serif; font-size:12px; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold); margin-bottom:14px;
}
.footer__col a{ color:#dcebf3; }
.footer a.footer__link{ color:#e3f0f6; display:block; margin-bottom:9px; font-size:15px; transition:color .25s var(--ease); }
.footer a.footer__link:hover{ color:#fff; }
.footer__phone{ font-size:18px; font-weight:700; color:#fff; }
.footer__phone a{ color:#fff; }
.footer__bar{
  border-top:1px solid rgba(255,255,255,.14);
}
.footer__bar .footer__barinner{
  padding-block:22px; display:flex; flex-wrap:wrap; gap:10px 22px; justify-content:space-between; align-items:center;
}
.footer__bar p{ font-size:13px; color:#a8cad9; margin:0; }
.footer__bar a{ font-size:13px; color:#cfe4ee; }
.footer__bar a:hover{ color:#fff; }
