:root {
  --ink: #18312f;
  --green: #143f3a;
  --green-2: #1f5a52;
  --sage: #d9e4d7;
  --sage-light: #edf2ea;
  --cream: #f6f1e8;
  --paper: #fcfaf6;
  --terracotta: #c97d59;
  --line: rgba(24, 49, 47, .15);
  --white: #fff;
  --shadow: 0 28px 60px rgba(24, 49, 47, .12);
  --radius: 20px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: "DM Sans", sans-serif;
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .025;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  z-index: 10;
}
a { color: inherit; }
p { margin: 0 0 1rem; }
h1, h2, h3 { margin: 0; line-height: 1.08; }
h1, h2 { font-family: "Newsreader", serif; font-weight: 500; letter-spacing: -.035em; }
h1 { font-size: clamp(3.3rem, 7vw, 6.7rem); }
h2 { font-size: clamp(2.6rem, 5vw, 4.8rem); }
h3 { font-size: 1.2rem; }
em { color: var(--terracotta); font-weight: 500; }
.container { width: min(1180px, calc(100% - 40px)); margin-inline: auto; }
.section { padding: 120px 0; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
.skip-link { position: fixed; top: -100px; left: 20px; z-index: 999; padding: 12px 18px; background: white; }
.skip-link:focus { top: 20px; }
.eyebrow {
  margin-bottom: 22px;
  color: var(--green-2);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.eyebrow.light { color: #bdd6ce; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 54px;
  padding: 14px 24px;
  border: 1px solid var(--green);
  border-radius: 999px;
  background: var(--green);
  color: white;
  font-size: .91rem;
  font-weight: 700;
  text-decoration: none;
  transition: transform .2s, background .2s, color .2s;
}
.button:hover { transform: translateY(-2px); background: var(--green-2); }
.button-small { min-height: 43px; padding: 10px 18px; }
.button-outline { background: transparent; color: var(--green); }
.button-light {
  border-color: #082f4a;
  background: linear-gradient(110deg, #082f4a, #075b56);
  color: #fff;
  box-shadow: 0 12px 30px rgba(5,44,55,.2);
}
.button-light:hover { color: #fff; background-position: 100% 50%; }
.text-link { display: inline-block; font-weight: 700; text-underline-offset: 5px; }
.announcement { padding: 7px 0; background: var(--green); color: white; font-size: .76rem; }
.announcement-inner { display: flex; justify-content: space-between; gap: 20px; }
.announcement a { color: #d8e8e1; font-weight: 700; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  border-bottom: 1px solid transparent;
  background: rgba(252, 250, 246, .92);
  backdrop-filter: blur(16px);
}
.site-header.scrolled { border-color: var(--line); }
.nav-wrap { min-height: 82px; display: flex; align-items: center; justify-content: space-between; }
.brand { display: inline-flex; align-items: center; gap: 11px; text-decoration: none; line-height: 1.1; }
.brand-mark {
  width: 40px; height: 40px; display: grid; place-items: center;
  border-radius: 50% 50% 50% 12px; background: var(--terracotta); color: white;
}
.brand strong, .brand small { display: block; }
.brand strong { font-family: "Newsreader", serif; font-size: 1.25rem; }
.brand small { margin-top: 3px; color: #5d706e; font-size: .65rem; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; }
nav { display: flex; align-items: center; gap: 27px; }
nav > a:not(.button) { font-size: .88rem; font-weight: 600; text-decoration: none; }
.menu-button { display: none; border: 0; background: none; }
.menu-button span:not(.sr-only) { display: block; width: 24px; height: 2px; margin: 5px; background: var(--ink); }

.hero { position: relative; overflow: hidden; padding: 90px 0 110px; }
.hero::after {
  content: ""; position: absolute; width: 550px; height: 550px; top: -240px; left: -260px;
  border: 1px solid var(--sage); border-radius: 50%; box-shadow: 0 0 0 70px rgba(217,228,215,.15), 0 0 0 140px rgba(217,228,215,.1);
}
.hero-grid { display: grid; grid-template-columns: 1.08fr .92fr; align-items: center; gap: 80px; }
.home-hero .hero-grid { grid-template-columns: minmax(0, 900px); justify-content: center; text-align: center; }
.home-hero .hero-copy h1, .home-hero .hero-lead { margin-inline: auto; }
.home-hero .hero-promise { margin-inline: auto; }
.home-hero .hero-actions, .home-hero .trust-list { justify-content: center; }
.hero-copy { position: relative; z-index: 2; }
.hero-copy h1 { max-width: 760px; }
.hero-lead { max-width: 650px; margin: 28px 0 32px; font-size: 1.15rem; color: #50625f; }
.hero-promise {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  max-width: 720px;
  margin: 28px 0 0;
  border-block: 1px solid var(--line);
}
.hero-promise > div {
  position: relative;
  display: flex;
  align-items: center;
  gap: 11px;
  min-height: 76px;
  padding: 14px 18px;
  border-right: 1px solid var(--line);
}
.hero-promise > div:first-child { padding-left: 0; }
.hero-promise > div:last-child { border-right: 0; }
.hero-promise i {
  flex: 0 0 auto;
  width: 24px;
  height: 18px;
  border-radius: 100% 0 100% 0;
  background: linear-gradient(135deg, var(--turquoise), var(--green-2));
  transform: rotate(-12deg);
  opacity: .8;
}
.hero-promise span {
  color: var(--green);
  font: 500 1.02rem/1.25 "Newsreader", serif;
}
.hero-promise small {
  display: block;
  margin-bottom: 3px;
  color: #81918e;
  font: 700 .58rem/1 "DM Sans", sans-serif;
  letter-spacing: .12em;
}
.hero-detail { max-width: 680px; margin: -16px 0 30px; color: #61716e; font-size: .92rem; }
.hero-actions { display: flex; align-items: center; gap: 26px; }
.trust-list { display: flex; flex-wrap: wrap; gap: 24px; margin: 34px 0 0; padding: 0; list-style: none; font-size: .82rem; font-weight: 700; }
.trust-list li::before { content: "✓"; margin-right: 8px; color: var(--terracotta); }
.hero-visual { position: relative; }
.portrait-card { padding: 14px; border-radius: 220px 220px 24px 24px; background: white; box-shadow: var(--shadow); }
.portrait-art { position: relative; overflow: hidden; aspect-ratio: .84; border-radius: 210px 210px 18px 18px; background: var(--sage); }
.portrait-art img { display: block; width: 100%; height: 100%; object-fit: cover; object-position: 50% 34%; }
.portrait-caption { display: flex; align-items: center; justify-content: space-between; padding: 20px 11px 7px; }
.portrait-caption strong, .portrait-caption span { display: block; }
.portrait-caption strong { font-family: "Newsreader", serif; font-size: 1.3rem; }
.portrait-caption div span { color: #6e7c79; font-size: .8rem; }
.portrait-caption .gmc { padding: 6px 10px; border-radius: 999px; background: var(--sage-light); font-size: .67rem; font-weight: 700; }
.floating-note {
  position: absolute; left: -62px; bottom: 76px; display: flex; gap: 12px; align-items: center;
  width: 250px; padding: 16px; border-radius: 14px; background: rgba(255,255,255,.95); box-shadow: var(--shadow);
  font-size: .74rem; line-height: 1.4;
}
.floating-note span span, .floating-note strong { display: block; }
.note-icon { flex: 0 0 auto; width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%; background: var(--sage); color: var(--green); font-weight: 800; }

.reassurance { background: var(--cream); border-block: 1px solid rgba(24,49,47,.08); }
.reassurance-grid { display: grid; grid-template-columns: repeat(3, 1fr); }
.reassurance-grid > div { display: flex; align-items: center; gap: 18px; padding: 32px 35px; border-right: 1px solid var(--line); }
.reassurance-grid > div:first-child { padding-left: 0; }
.reassurance-grid > div:last-child { border: 0; }
.reassurance-grid span { color: var(--terracotta); font: 600 1.7rem "Newsreader"; }
.reassurance-grid p, .reassurance-grid strong { display: block; margin: 0; }
.reassurance-grid p { color: #62716e; font-size: .8rem; line-height: 1.45; }
.reassurance-grid strong { color: var(--ink); font-size: .95rem; }
.section-heading { display: grid; grid-template-columns: 1.5fr .65fr; align-items: end; gap: 70px; margin-bottom: 58px; }
.section-heading > p { color: #667572; }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.service-card { position: relative; min-height: 390px; padding: 34px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); transition: background .25s, transform .25s; }
.service-card:hover { z-index: 2; background: var(--green); color: white; transform: translateY(-5px); }
.service-number { position: absolute; top: 27px; right: 28px; color: #8e9b98; font-size: .68rem; }
.service-icon { width: 48px; height: 48px; display: grid; place-items: center; margin-bottom: 54px; border-radius: 50%; background: var(--sage-light); color: var(--green); font-size: 1.4rem; }
.service-card h3 { margin-bottom: 14px; font-family: "Newsreader", serif; font-size: 1.55rem; }
.service-card p { color: #667572; font-size: .9rem; }
.service-card:hover p, .service-card:hover .service-number { color: #c8d8d3; }
.clinical-note { max-width: 800px; margin: 30px 0 0; color: #697875; font-size: .78rem; }

.about { background: var(--sage-light); }
.about-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 90px; }
.about-panel { padding: 64px 54px; border-radius: var(--radius); background: var(--green); color: white; }
.about-panel h2 { font-size: clamp(2.8rem, 4.5vw, 4.3rem); }
blockquote { margin: 80px 0 45px; padding-left: 22px; border-left: 2px solid var(--terracotta); color: #d9e6e2; font: 500 1.35rem/1.5 "Newsreader"; }
.expertise-tree { position: relative; display: grid; gap: 13px; margin-top: 38px; padding: 8px 0; }
.expertise-stem { position: absolute; top: 10px; bottom: 10px; left: 50%; width: 2px; background: linear-gradient(rgba(216,248,228,.1), rgba(216,248,228,.72), rgba(216,248,228,.1)); transform: translateX(-50%); }
.expertise-leaf { position: relative; width: 62%; min-height: 82px; display: flex; flex-direction: column; justify-content: center; padding: 17px 25px; border: 1px solid rgba(255,255,255,.18); background: linear-gradient(135deg, rgba(255,255,255,.13), rgba(112,214,202,.08)); box-shadow: inset 0 1px 0 rgba(255,255,255,.15); backdrop-filter: blur(6px); }
.expertise-leaf::after { content: ""; position: absolute; top: 50%; width: 22px; height: 1px; background: rgba(216,248,228,.55); }
.expertise-leaf.leaf-left { justify-self: start; border-radius: 52px 8px 52px 8px; }
.expertise-leaf.leaf-left::after { right: -22px; }
.expertise-leaf.leaf-right { justify-self: end; border-radius: 8px 52px 8px 52px; text-align: right; }
.expertise-leaf.leaf-right::after { left: -22px; }
.expertise-leaf span { color: #b8dcd2; font-size: .63rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.expertise-leaf strong { margin-top: 4px; color: white; font: 500 1.08rem "Newsreader", serif; }
.about-copy { align-self: center; }
.about-copy > p { color: #536662; }
.about-copy .large-copy { color: var(--ink); font: 500 1.8rem/1.45 "Newsreader"; }
.doctor-credentials { margin-bottom: 22px; color: var(--ink) !important; font: 600 1.25rem/1.35 "Newsreader", serif; }
.doctor-credentials span { display: block; margin-top: 6px; color: var(--green-2); font: 700 .72rem/1.4 "DM Sans", sans-serif; letter-spacing: .08em; text-transform: uppercase; }
.qualifications { position: relative; margin-top: 38px; padding-left: 12px; }
.qualifications::before { content: ""; position: absolute; top: 18px; bottom: 18px; left: 30px; width: 1px; background: linear-gradient(var(--turquoise), var(--green-2)); opacity: .35; }
.qualifications div { position: relative; display: grid; grid-template-columns: 38px 1fr; gap: 18px; align-items: center; padding: 14px 0; }
.qualifications div > p { margin: 0; }
.qualifications p span, .qualifications p strong { display: block; }
.qualifications p span { color: #788682; font-size: .66rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; }
.qualifications strong { margin-top: 3px; font-size: .9rem; }
.qualification-leaf { position: relative; z-index: 1; width: 36px; height: 27px; border: 1px solid rgba(20,123,106,.25); border-radius: 100% 0 100% 0; background: linear-gradient(135deg, #dff6ee, #bfe8d4); transform: rotate(-10deg); }
.qualification-leaf::after { content: ""; position: absolute; width: 22px; height: 1px; top: 13px; left: 7px; background: rgba(20,123,106,.35); transform: rotate(-28deg); transform-origin: left; }

.steps { margin: 0; padding: 0; list-style: none; border-top: 1px solid var(--line); }
.steps li { display: grid; grid-template-columns: 90px 1fr; gap: 25px; align-items: start; padding: 36px 0; border-bottom: 1px solid var(--line); }
.steps li > span { width: 52px; height: 52px; display: grid; place-items: center; border-radius: 50%; background: var(--terracotta); color: white; font: 600 1.3rem "Newsreader"; }
.steps h3 { margin-bottom: 8px; font: 500 1.7rem "Newsreader"; }
.steps p { max-width: 660px; color: #657572; }
.why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.why-list { padding: 8px 34px; border-left: 1px solid var(--line); }
.why-list p { position: relative; margin: 0; padding: 18px 0 18px 32px; border-bottom: 1px solid var(--line); font-weight: 600; }
.why-list p::before { content: "✓"; position: absolute; left: 0; color: var(--turquoise); font-weight: 800; }
.closing-statement { max-width: 900px; margin: 60px auto 0; padding: 34px 40px; border-radius: var(--radius); background: linear-gradient(120deg, rgba(18,105,168,.08), rgba(24,168,160,.1), rgba(67,168,104,.08)); text-align: center; }
.closing-statement p { margin: 0; font: 500 1.35rem/1.55 "Newsreader", serif; }

.fees { background: var(--green); color: white; }
.fees-intro { max-width: 750px; margin-bottom: 50px; }
.fees-intro p:last-child { max-width: 570px; margin-top: 20px; color: #c1d0cc; }
.fee-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; align-items: stretch; }
.fee-card { position: relative; padding: 38px; border: 1px solid rgba(255,255,255,.2); border-radius: var(--radius); background: rgba(255,255,255,.04); }
.fee-card.featured { background: var(--cream); color: var(--ink); }
.popular { position: absolute; top: 14px; right: 14px; padding: 5px 9px; border-radius: 999px; background: var(--terracotta); color: white; font-size: .59rem; font-weight: 700; text-transform: uppercase; }
.fee-label { color: #bdd1cb; font-size: .7rem; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; }
.featured .fee-label { color: var(--terracotta); }
.fee-card h3 { min-height: 54px; font: 500 1.65rem "Newsreader"; }
.price { margin: 28px 0; padding-bottom: 25px; border-bottom: 1px solid rgba(255,255,255,.16); font: 500 1.9rem "Newsreader"; }
.featured .price { border-color: var(--line); }
.fee-card ul { min-height: 140px; margin: 0 0 28px; padding: 0; list-style: none; color: #c8d5d2; font-size: .86rem; }
.featured ul { color: #5f6f6c; }
.fee-card li { margin: 9px 0; }
.fee-card li::before { content: "✓"; margin-right: 9px; color: var(--terracotta); font-weight: 800; }
.fee-card .button { width: 100%; }
.fees .button-outline { border-color: rgba(255,255,255,.35); color: white; }

.availability { background: var(--cream); }
.availability-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 90px; align-items: center; }
.availability-grid > div:first-child p:last-child { max-width: 500px; margin-top: 22px; color: #657572; }
.schedule-card { padding: 20px 38px; border-radius: var(--radius); background: white; box-shadow: 0 18px 50px rgba(24,49,47,.08); }
.schedule-card div { display: flex; justify-content: space-between; gap: 20px; padding: 23px 0; border-bottom: 1px solid var(--line); }
.schedule-card span { color: #73817e; font-size: .83rem; }
.schedule-card strong { text-align: right; font-size: .88rem; }
.schedule-card .text-link { margin: 25px 0 8px; }

.faq-grid { display: grid; grid-template-columns: .7fr 1.3fr; gap: 100px; }
.faq-grid > div:first-child > p:not(.eyebrow) { margin: 24px 0; color: #647370; }
details { border-top: 1px solid var(--line); }
details:last-child { border-bottom: 1px solid var(--line); }
summary { display: flex; justify-content: space-between; gap: 20px; padding: 25px 0; cursor: pointer; font: 500 1.25rem "Newsreader"; list-style: none; }
summary::-webkit-details-marker { display: none; }
summary span { color: var(--terracotta); transition: transform .2s; }
details[open] summary span { transform: rotate(45deg); }
details p { max-width: 670px; padding: 0 40px 24px 0; color: #63736f; font-size: .9rem; }

.contact { padding: 90px 0; background: var(--terracotta); color: white; }
.contact-inner { display: grid; grid-template-columns: 1.4fr .6fr; gap: 80px; align-items: end; }
.contact-inner h2 { max-width: 800px; }
.contact-inner > div:first-child > p:last-child { margin-top: 20px; color: #f6ddd1; }
.contact-actions { display: flex; flex-direction: column; align-items: flex-start; gap: 18px; }
.contact-actions .button { width: 100%; }
.contact-actions p { font-size: .8rem; }
.contact-actions p span, .contact-actions p a { display: block; }
.contact-actions p span { color: #f5d8cb; }
.contact-actions p a { font-weight: 700; }

footer { padding: 75px 0 25px; background: #0c2926; color: #c8d8d3; }
.footer-main { display: grid; grid-template-columns: 2fr 1fr 1.3fr 1.3fr; gap: 65px; }
.brand-light strong { color: white; }
.brand-light small { color: #a8bdb7; }
.footer-brand > p { max-width: 340px; margin-top: 24px; font-size: .84rem; }
.footer-brand .gmc-footer { color: #91aaa3; font-size: .7rem; }
footer h3 { margin-bottom: 18px; color: white; font: 500 1.15rem "Newsreader"; }
.footer-main > div:not(:first-child) > a { display: block; margin: 10px 0; color: #c5d4d0; font-size: .8rem; text-decoration: none; }
.footer-main > div:not(:first-child) > a:hover { color: white; text-decoration: underline; }
.footer-main > div > p { font-size: .78rem; }
.footer-qr { display: flex; align-items: center; gap: 12px; margin-top: 20px; }
.footer-qr img { width: 82px; height: 82px; padding: 5px; border-radius: 8px; background: white; image-rendering: pixelated; }
.footer-qr span { color: #b9cdc7; font-size: .67rem; font-weight: 700; line-height: 1.45; }
.regulated { display: flex; justify-content: space-between; gap: 30px; margin-top: 60px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.12); font-size: .7rem; }
.mobile-book { display: none; }
.floating-contact {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 35;
  display: flex;
  align-items: center;
  gap: 10px;
}
.whatsapp-button, .email-button {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 52px;
  padding: 10px 17px 10px 12px;
  border: 2px solid rgba(255,255,255,.9);
  border-radius: 999px;
  background: #25d366;
  color: #fff;
  box-shadow: 0 12px 32px rgba(10,73,43,.25);
  font-size: .78rem;
  font-weight: 800;
  text-decoration: none;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.whatsapp-button:hover { transform: translateY(-3px); background: #1ebe5d; box-shadow: 0 16px 38px rgba(10,73,43,.32); }
.email-button { border-color: rgba(255,255,255,.9); background: linear-gradient(110deg, var(--blue-deep), var(--green-2)); color: white; box-shadow: 0 12px 32px rgba(8,47,74,.22); }
.email-button { width: auto !important; max-width: 140px !important; height: 52px !important; flex: 0 0 auto !important; overflow: hidden; }
.email-button:hover { transform: translateY(-3px); background-position: 100% 50%; box-shadow: 0 16px 38px rgba(8,47,74,.3); }
.whatsapp-button svg, .email-button svg { width: 29px; height: 29px; fill: currentColor; }
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 900px) {
  .section { padding: 85px 0; }
  .menu-button { display: block; }
  nav {
    position: absolute; top: 82px; left: 0; right: 0; display: none; flex-direction: column; align-items: stretch;
    gap: 0; padding: 18px 20px 25px; border-bottom: 1px solid var(--line); background: var(--paper);
  }
  nav.open { display: flex; }
  nav > a:not(.button) { padding: 13px 4px; }
  .hero { padding-top: 60px; }
  .hero-grid, .about-grid, .availability-grid, .faq-grid, .contact-inner { grid-template-columns: 1fr; }
  .hero-grid { gap: 60px; }
  .hero-visual { width: min(520px, 88%); margin-inline: auto; }
  .section-heading { grid-template-columns: 1fr; gap: 25px; }
  .service-grid, .fee-grid { grid-template-columns: 1fr 1fr; }
  .about-grid, .availability-grid, .faq-grid { gap: 50px; }
  .fee-card.featured { order: -1; }
  .footer-main { grid-template-columns: 1.5fr 1fr 1fr; }
  .footer-main > div:last-child { grid-column: 2 / 4; }
}

@media (max-width: 640px) {
  body { padding-bottom: 74px; }
  .container { width: min(100% - 28px, 1180px); }
  h1 { font-size: 3.25rem; }
  h2 { font-size: 2.65rem; }
  .announcement-inner span { display: none; }
  .announcement-inner { justify-content: center; }
  .nav-wrap { min-height: 70px; }
  nav { top: 70px; }
  .hero { padding: 50px 0 80px; }
  .hero-actions { align-items: flex-start; flex-direction: column; gap: 18px; }
  .trust-list { gap: 10px 18px; }
  .hero-visual { width: 100%; }
  .floating-note { left: 10px; bottom: 80px; width: 225px; }
  .reassurance-grid, .service-grid, .fee-grid { grid-template-columns: 1fr; }
  .reassurance-grid > div { padding: 24px 0; border-right: 0; border-bottom: 1px solid var(--line); }
  .service-card { min-height: 270px; }
  .hero-promise { grid-template-columns: 1fr; }
  .hero-promise > div { min-height: 60px; padding: 12px 4px; border-right: 0; border-bottom: 1px solid var(--line); }
  .hero-promise > div:last-child { border-bottom: 0; }
  .why-grid { grid-template-columns: 1fr; gap: 0; }
  .why-list { padding-inline: 10px; }
  .closing-statement { padding: 28px 22px; }
  .about-panel { padding: 45px 28px; }
  blockquote { margin-top: 55px; }
  .expertise-leaf { width: 72%; }
  .steps li { grid-template-columns: 60px 1fr; gap: 12px; }
  .fee-card { padding: 32px 25px; }
  .fee-card h3 { min-height: auto; }
  .fee-card ul { min-height: auto; }
  .schedule-card { padding: 14px 22px; }
  .schedule-card div { flex-direction: column; }
  .schedule-card strong { text-align: left; }
  .footer-main { grid-template-columns: 1fr 1fr; gap: 45px 25px; }
  .footer-brand, .footer-main > div:last-child { grid-column: 1 / 3; }
  .regulated { flex-direction: column; gap: 5px; }
  .mobile-book { position: fixed; display: block; z-index: 30; left: 0; right: 0; bottom: 0; padding: 10px 14px; background: rgba(255,255,255,.96); border-top: 1px solid var(--line); }
  .mobile-book .button { width: 100%; min-height: 52px; }
  .floating-contact { right: 16px; bottom: 84px; }
  .whatsapp-button, .email-button { width: 54px !important; max-width: 54px !important; height: 54px !important; padding: 11px; justify-content: center; }
  .whatsapp-button span, .email-button span { display: none; }
}

/* Dedicated About page */
.about-page { padding-top: 90px; background: linear-gradient(180deg, rgba(249,252,251,.85), rgba(232,247,242,.9)); }
.about-page-heading { max-width: 900px; margin-bottom: 65px; text-align: center; }
.about-page-heading h1 { font-size: clamp(3rem, 6vw, 5.7rem); }
.about-page-subtitle { max-width: 680px; margin: 24px auto 0; color: #5e716d; font-size: 1.08rem; }
.about-profile { display: grid; grid-template-columns: .82fr 1.18fr; gap: 90px; align-items: center; }
.about-portrait { overflow: hidden; border-radius: 220px 220px 24px 24px; background: white; box-shadow: var(--shadow); }
.about-portrait img { display: block; width: 100%; aspect-ratio: .82; object-fit: cover; object-position: center 32%; }
.about-portrait-caption { display: flex; justify-content: space-between; gap: 20px; padding: 20px 25px 24px; }
.about-portrait-caption strong, .about-portrait-caption span { display: block; }
.about-portrait-caption strong { font: 500 1.25rem "Newsreader", serif; }
.about-portrait-caption span { color: #6e7c79; font-size: .78rem; }
.about-values { background: var(--paper); }
.about-value-grid { display: grid; grid-template-columns: repeat(3,1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.about-value-grid article { min-height: 260px; padding: 35px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.about-value-grid article > span { color: var(--turquoise); font: 600 1.45rem "Newsreader", serif; }
.about-value-grid h3 { margin: 45px 0 12px; font: 500 1.55rem "Newsreader", serif; }
.about-value-grid p { color: #657572; font-size: .9rem; }
@media (max-width: 900px) {
  .about-profile { grid-template-columns: 1fr; gap: 55px; }
  .about-portrait { width: min(100%, 520px); margin-inline: auto; }
  .about-value-grid { grid-template-columns: 1fr; }
}

/* Official Harmony GP Care logo */
.site-brand-logo {
  display: block;
  width: 225px;
  height: 64px;
  object-fit: contain;
  object-position: left center;
}
.intro-brand-logo {
  position: relative;
  z-index: 2;
  display: block;
  width: min(88vw, 760px);
  height: auto;
  margin: 0 auto;
  opacity: 0;
  filter: none;
  animation: simple-logo-fade 1.15s cubic-bezier(.25,0,0,1) .18s forwards;
}
.footer-brand-logo {
  display: block;
  width: min(100%, 300px);
  height: auto;
  padding: 8px 12px;
  border-radius: 12px;
  background: rgba(255,255,255,.94);
}
@media (max-width: 640px) {
  .site-brand-logo { width: 175px; height: 54px; }
  .intro-brand-logo { width: min(90vw, 430px); }
}

/* Expanded services and fees */
.fees-intro { max-width: 900px; }
.fees-intro .fees-tagline { color: white; font: 500 1.5rem "Newsreader", serif; }
.fee-category { margin-top: 70px; }
.fee-category-heading { display: flex; align-items: center; gap: 18px; margin-bottom: 28px; padding-bottom: 18px; border-bottom: 1px solid rgba(255,255,255,.2); }
.fee-category-heading h3 { color: white; font: 500 clamp(2rem, 4vw, 3rem) "Newsreader", serif; }
.fee-category-heading .fee-label { margin: 0 0 5px; }
.category-leaf { width: 42px; height: 30px; flex: 0 0 auto; border-radius: 100% 0 100% 0; background: linear-gradient(135deg, #dff8e9, var(--aqua)); transform: rotate(-12deg); }
.appointment-only { margin-left: auto; padding: 7px 12px; border: 1px solid rgba(255,255,255,.25); border-radius: 999px; color: #d9ebe5; font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.remote-fees .fee-card { display: flex; flex-direction: column; }
.home-fees { grid-template-columns: repeat(2, 1fr); }
.fee-card-head { display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; padding-bottom: 22px; border-bottom: 1px solid rgba(255,255,255,.16); }
.featured .fee-card-head { border-color: var(--line); }
.fee-card-head h3 { min-height: 0; font-size: 1.45rem; }
.fee-card-head .price { flex: 0 0 auto; margin: 0; padding: 0; border: 0; text-align: right; white-space: nowrap; }
.price small { display: block; font: 700 .6rem "DM Sans", sans-serif; letter-spacing: .08em; text-transform: uppercase; }
.fee-availability { margin: 18px 0 0; color: var(--aqua); font-size: .78rem; font-weight: 700; }
.suitable-title { margin: 22px 0 8px; color: white; font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.featured .suitable-title { color: var(--green); }
.fee-card ul { min-height: 0; flex-grow: 1; }
.fee-summary { color: #c8d5d2; font-size: .8rem; }
.featured .fee-summary { color: #5f6f6c; }
.coverage-note { margin-top: 22px; padding: 30px 34px; border: 1px solid rgba(255,255,255,.16); border-radius: var(--radius); background: rgba(255,255,255,.055); }
.coverage-note h4 { margin: 0 0 12px; color: white; font: 500 1.45rem "Newsreader", serif; }
.coverage-note p { max-width: 1000px; color: #c4d5d0; font-size: .86rem; }
.fee-support-grid { display: grid; grid-template-columns: minmax(0, 780px); justify-content: center; margin-top: 70px; }
.included-panel, .pricing-summary { padding: 38px; border-radius: var(--radius); background: var(--cream); color: var(--ink); }
.included-panel h3, .pricing-summary h3 { margin-bottom: 24px; font: 500 1.8rem "Newsreader", serif; }
.included-panel ul { margin: 0; padding: 0; list-style: none; }
.included-panel li { position: relative; padding: 10px 0 10px 28px; border-bottom: 1px solid var(--line); font-size: .88rem; }
.included-panel li::before { content: "✓"; position: absolute; left: 0; color: var(--green-2); font-weight: 800; }
.no-fees { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 25px; }
.no-fees span { padding: 7px 11px; border-radius: 999px; background: var(--sage); color: var(--green); font-size: .7rem; font-weight: 700; }
.pricing-summary dl { margin: 0; }
.pricing-summary dl div { display: flex; justify-content: space-between; gap: 20px; padding: 15px 0; border-bottom: 1px solid var(--line); }
.pricing-summary dt { font-size: .82rem; }
.pricing-summary dd { margin: 0; color: var(--green); font-weight: 800; text-align: right; white-space: nowrap; }
.urgent-notice { margin-top: 24px; padding: 25px 30px; border-left: 4px solid var(--aqua); background: rgba(255,255,255,.08); }
.urgent-notice > strong { display: block; margin-bottom: 8px; color: white; font-size: .75rem; letter-spacing: .1em; text-transform: uppercase; }
.urgent-notice p { margin: 5px 0; color: #cfddd9; font-size: .8rem; }
@media (max-width: 900px) {
  .remote-fees, .home-fees { grid-template-columns: 1fr; }
  .fee-support-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .fee-category { margin-top: 50px; }
  .fee-category-heading { align-items: flex-start; flex-wrap: wrap; }
  .appointment-only { margin-left: 0; }
  .fee-card-head { display: block; }
  .fee-card-head .price { margin-top: 14px; text-align: left; }
  .coverage-note, .included-panel, .pricing-summary { padding: 27px 22px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition-duration: .01ms !important; animation-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}

/* Harmony colour system: blue, turquoise and green move together as the page scrolls. */
:root {
  --ink: #102f3b;
  --green: #0c594d;
  --green-2: #147b6a;
  --blue: #1269a8;
  --blue-deep: #124c78;
  --turquoise: #18a8a0;
  --aqua: #70d6ca;
  --sage: #d5ebe5;
  --sage-light: #edf7f4;
  --paper: #f9fcfb;
  --terracotta: #168f94;
  --line: rgba(16, 47, 59, .15);
  --shadow: 0 28px 60px rgba(12, 89, 77, .13);
  --scroll-progress: 0;
  --harmony-blue-x: 0vw;
  --harmony-blue-y: 0vh;
  --harmony-turquoise-x: 0vw;
  --harmony-turquoise-y: 0vh;
  --harmony-green-x: 0vw;
  --harmony-green-y: 0vh;
  --harmony-position: 10%;
}

body { overflow-x: hidden; }

.tree-intro {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 42%, rgba(255,255,255,.25), transparent 34%),
    linear-gradient(145deg, rgba(15,103,68,.94), rgba(48,151,94,.88) 48%, rgba(194,233,207,.82));
  color: white;
  backdrop-filter: blur(18px);
  transition: opacity .62s cubic-bezier(.25,0,0,1), visibility .62s ease, background .8s ease;
}
.tree-intro::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 48%, transparent 20%, rgba(0,48,31,.11) 72%, rgba(0,35,24,.22) 100%),
    linear-gradient(180deg, rgba(255,255,255,.04), transparent 32%, rgba(0,52,35,.08));
  opacity: .72;
  z-index: 0;
  transition: opacity .7s ease;
}
.tree-intro-content, .skip-intro { z-index: 2; }
.tree-intro.is-finished {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.tree-intro.is-resolving::after { opacity: .25; }
.tree-intro.is-handoff { background: rgba(235,249,241,.25); }
.tree-intro.is-handoff::after { opacity: 0; }
.tree-intro-sky,
.tree-glow { position: absolute; inset: 0; }
.tree-glow {
  width: 55vw;
  height: 55vw;
  margin: auto;
  border-radius: 50%;
  filter: blur(85px);
  opacity: 0;
  animation: intro-glow 3.6s ease forwards;
}
.tree-glow-blue { background: rgba(255,255,255,.34); transform: translate(-42%, -25%); }
.tree-glow-turquoise { background: rgba(213,248,224,.32); animation-delay: .25s; }
.tree-glow-green { background: rgba(107,204,139,.28); transform: translate(42%, 28%); animation-delay: .5s; }
.tree-intro-content {
  position: relative;
  width: min(92vw, 760px);
  text-align: center;
}
.care-tree-photo {
  position: relative;
  width: min(92vw, 850px);
  aspect-ratio: 1.82;
  margin: -22px auto -8px;
  overflow: visible;
  opacity: 0;
  transform: translateY(54px) scale(.72);
  transform-origin: 50% 100%;
  animation: tree-photo-rise 1.55s cubic-bezier(.2,.7,.25,1) .02s forwards;
}
.tree-image-layer {
  position: absolute;
  inset: -8%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(16,93,53,.03)),
    url("harmony-tree.png") center / cover no-repeat;
  clip-path: inset(100% 0 0 0);
  -webkit-mask-image:
    linear-gradient(to right, transparent 0%, black 12%, black 88%, transparent 100%),
    linear-gradient(to bottom, transparent 0%, black 10%, black 84%, transparent 100%);
  -webkit-mask-composite: source-in;
  mask-image:
    linear-gradient(to right, transparent 0%, black 12%, black 88%, transparent 100%),
    linear-gradient(to bottom, transparent 0%, black 10%, black 84%, transparent 100%);
  mask-composite: intersect;
  filter: saturate(.92) contrast(.96) brightness(1.07);
  animation: tree-photo-reveal 1.4s cubic-bezier(.2,.7,.25,1) .06s forwards;
}
.tree-image-layer::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 83%, rgba(222,255,229,.18), transparent 28%),
    linear-gradient(90deg, rgba(255,255,255,.1), transparent 35%, rgba(182,235,198,.08));
  mix-blend-mode: screen;
}
.tree-light {
  position: absolute;
  width: 48%;
  aspect-ratio: 1;
  top: -30%;
  left: 29%;
  border-radius: 50%;
  background: rgba(255,255,255,.65);
  filter: blur(55px);
  opacity: 0;
  animation: tree-sunlight 1.05s ease .45s forwards;
}
.tree-ground-glow {
  position: absolute;
  left: 22%;
  right: 22%;
  bottom: -5%;
  height: 22%;
  border-radius: 50%;
  background: rgba(221,255,230,.45);
  filter: blur(25px);
  opacity: 0;
  animation: ground-awaken .75s ease .18s forwards;
}
.drifting-leaves i {
  position: absolute;
  left: 50%;
  top: 48%;
  width: 11px;
  height: 6px;
  border-radius: 100% 0 100% 0;
  background: rgba(242,255,243,.9);
  opacity: 0;
  animation: photo-leaf-drift .95s cubic-bezier(.18,.7,.3,1) forwards;
}
.drifting-leaves i:nth-child(1) { --leaf-x: -260px; --leaf-y: 70px; animation-delay: .7s; }
.drifting-leaves i:nth-child(2) { --leaf-x: -205px; --leaf-y: 105px; animation-delay: .76s; rotate: 35deg; }
.drifting-leaves i:nth-child(3) { --leaf-x: -150px; --leaf-y: 54px; animation-delay: .82s; rotate: -28deg; }
.drifting-leaves i:nth-child(4) { --leaf-x: 160px; --leaf-y: 75px; animation-delay: .73s; rotate: 42deg; }
.drifting-leaves i:nth-child(5) { --leaf-x: 220px; --leaf-y: 112px; animation-delay: .8s; rotate: -18deg; }
.drifting-leaves i:nth-child(6) { --leaf-x: 275px; --leaf-y: 62px; animation-delay: .87s; rotate: 24deg; }
.drifting-leaves i:nth-child(7) { --leaf-x: 110px; --leaf-y: 130px; animation-delay: .94s; rotate: -35deg; }
.tree-intro-copy {
  position: relative;
  display: grid;
  place-items: center;
  width: min(94vw, 900px);
  min-height: 430px;
  margin-inline: auto;
  opacity: 1;
  transition: transform .75s cubic-bezier(.25,0,0,1), opacity .55s ease, filter .55s ease;
}
.tree-intro.is-resolving .tree-intro-copy { transform: scale(1.018); }
.tree-intro.is-handoff .tree-intro-copy { transform: scale(.985); opacity: 0; filter: blur(5px); }
.tree-intro-copy::before {
  content: none;
}
.harmony-pulse {
  position: absolute;
  z-index: 3;
  width: 100%;
  height: auto;
  overflow: visible;
  pointer-events: none;
  transition: opacity .55s ease, transform .7s cubic-bezier(.25,0,0,1);
}
.pulse-path {
  fill: none;
  stroke: url(#pulseGradient);
  stroke-width: 7;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: drop-shadow(0 0 8px rgba(112,214,202,.45));
}
.pulse-irregular { stroke-dasharray: 320; stroke-dashoffset: 320; animation: pulse-draw .58s cubic-bezier(.22,.7,.25,1) .1s forwards, pulse-soften .45s ease 2.55s forwards; }
.pulse-h { stroke-width: 9; stroke-dasharray: 720; stroke-dashoffset: 720; animation: h-draw .9s cubic-bezier(.22,.7,.25,1) .52s forwards, pulse-soften .45s ease 2.55s forwards; }
.pulse-heart { stroke-width: 9; stroke-dasharray: 820; stroke-dashoffset: 820; animation: heart-draw .86s cubic-bezier(.22,.7,.25,1) 1.28s forwards, heart-settle .42s ease 2.03s forwards, pulse-soften .45s ease 2.62s forwards; }
.pulse-regular { stroke-dasharray: 980; stroke-dashoffset: 980; animation: regular-draw .68s cubic-bezier(.22,.7,.25,1) 2.02s forwards, pulse-soften .42s ease 2.7s forwards; }
.pulse-glow {
  fill: none;
  stroke: rgba(112,214,202,.34);
  stroke-width: 22;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: blur(9px);
  opacity: 0;
}
.glow-irregular { stroke-dasharray: 320; stroke-dashoffset: 320; animation: pulse-draw .58s cubic-bezier(.22,.7,.25,1) .1s forwards, glow-live .25s ease .1s forwards, pulse-soften .5s ease 2.45s forwards; }
.glow-h { stroke-dasharray: 720; stroke-dashoffset: 720; animation: h-draw .9s cubic-bezier(.22,.7,.25,1) .52s forwards, glow-live .25s ease .52s forwards, pulse-soften .5s ease 2.5s forwards; }
.glow-heart { stroke-dasharray: 820; stroke-dashoffset: 820; animation: heart-draw .86s cubic-bezier(.22,.7,.25,1) 1.28s forwards, glow-live .25s ease 1.28s forwards, pulse-soften .5s ease 2.6s forwards; }
.glow-settled { stroke-dasharray: 980; stroke-dashoffset: 980; animation: regular-draw .68s cubic-bezier(.22,.7,.25,1) 2.02s forwards, glow-live .25s ease 2.02s forwards, pulse-soften .5s ease 2.75s forwards; }
.pulse-tracer { fill: white; filter: drop-shadow(0 0 7px white) drop-shadow(0 0 16px rgba(112,214,202,.98)); opacity: 0; }
.pulse-tracer-halo { fill: rgba(112,214,202,.23); filter: blur(5px); opacity: 0; }
.pulse-tracer-tail { fill: rgba(112,214,202,.09); filter: blur(10px); opacity: 0; }
.intro-glow-core {
  position: absolute;
  z-index: 1;
  left: 19%;
  top: 60%;
  width: 240px;
  height: 240px;
  border-radius: 50%;
  background: rgba(112,214,202,.24);
  filter: blur(52px);
  opacity: 0;
  transform: translate(-50%,-50%) scale(.35);
  animation: harmony-glow 1.1s cubic-bezier(.25,0,0,1) 1.62s forwards;
}
.tree-intro.is-resolving .intro-glow-core {
  opacity: .28;
  transform: translate(-50%,-50%) scale(1.12);
}
.pulse-core {
  position: absolute;
  z-index: 4;
  left: 19%;
  top: 60%;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: white;
  box-shadow: 0 0 0 0 rgba(112,214,202,.55);
  opacity: 0;
  animation: core-beat .58s cubic-bezier(.25,0,0,1) 1.72s 2;
}
.tree-intro-mark {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  margin-bottom: 12px;
  border-radius: 50% 50% 50% 12px;
  border: 1px solid rgba(255,255,255,.6);
  background: rgba(255,255,255,.16);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.35), 0 12px 30px rgba(0,71,39,.12);
  color: white;
  backdrop-filter: blur(12px);
}
.tree-intro-copy h1 { font-size: clamp(2rem, 5vw, 3.6rem); }
.tree-intro-copy h1 { color: white; text-shadow: 0 2px 20px rgba(0,70,38,.18); }
.tree-intro-copy p { margin: 8px 0 0; color: rgba(255,255,255,.84); font-size: clamp(.9rem, 2vw, 1.08rem); }
.skip-intro {
  position: absolute;
  right: 24px;
  bottom: 22px;
  padding: 9px 13px;
  border: 0;
  background: transparent;
  color: rgba(255,255,255,.8);
  font: 600 .72rem "DM Sans", sans-serif;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 4px;
}
@keyframes tree-photo-rise {
  12% { opacity: 1; }
  48% { opacity: 1; transform: translateY(18px) scale(.84, .96); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes tree-photo-reveal {
  0% { clip-path: inset(100% 0 0 0); }
  38% { clip-path: inset(52% 0 0 0); }
  68% { clip-path: inset(20% 0 0 0); }
  100% { clip-path: inset(0 0 0 0); }
}
@keyframes tree-sunlight {
  to { opacity: .55; transform: scale(1.18); }
}
@keyframes ground-awaken {
  to { opacity: 1; transform: scaleX(1.2); }
}
@keyframes photo-leaf-drift {
  20% { opacity: 1; }
  to { opacity: 0; transform: translate(var(--leaf-x), var(--leaf-y)) rotate(130deg); }
}
@keyframes intro-copy {
  to { opacity: 1; transform: translateY(0); }
}
@keyframes pulse-draw { to { stroke-dashoffset: 0; } }
@keyframes h-draw { to { stroke-dashoffset: 0; } }
@keyframes heart-draw { to { stroke-dashoffset: 0; } }
@keyframes regular-draw { to { stroke-dashoffset: 0; } }
@keyframes heart-settle {
  45% { stroke-width: 12; filter: drop-shadow(0 0 16px rgba(112,214,202,.85)); }
  100% { stroke-width: 9; filter: drop-shadow(0 0 8px rgba(112,214,202,.45)); }
}
@keyframes pulse-soften { to { opacity: 0; } }
@keyframes glow-live { to { opacity: 1; } }
@keyframes logo-reveal {
  from { opacity: 0; clip-path: circle(0% at 19% 61%); transform: scale(.96); filter: blur(4px) drop-shadow(0 18px 38px rgba(0,64,48,.15)); }
  to { opacity: 1; clip-path: circle(105% at 19% 61%); transform: scale(1); filter: blur(0) drop-shadow(0 18px 38px rgba(0,64,48,.2)); }
}
@keyframes simple-logo-fade {
  from { opacity: 0; transform: translateY(12px) scale(.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes core-beat {
  0% { opacity: 0; transform: scale(.7); box-shadow: 0 0 0 0 rgba(112,214,202,.55); }
  35% { opacity: 1; transform: scale(1.25); box-shadow: 0 0 0 18px rgba(112,214,202,0); }
  100% { opacity: 0; transform: scale(.9); }
}
@keyframes harmony-glow {
  35% { opacity: .8; transform: translate(-50%,-50%) scale(.75); }
  100% { opacity: 0; transform: translate(-50%,-50%) scale(1.5); }
}
@keyframes clinical-grid { to { opacity: 1; } }
@keyframes logo-breathe {
  to { transform: scale(1.018); filter: drop-shadow(0 22px 44px rgba(0,64,48,.25)); }
}
@keyframes intro-glow {
  30% { opacity: .7; }
  100% { opacity: .3; scale: 1.15; }
}

.harmony-atmosphere {
  position: fixed;
  inset: 0;
  z-index: -1;
  overflow: hidden;
  pointer-events: none;
  background: linear-gradient(145deg, rgba(18,105,168,.035), rgba(24,168,160,.04) 48%, rgba(12,89,77,.03));
}
.harmony-orb {
  position: absolute;
  width: min(58vw, 780px);
  aspect-ratio: 1;
  border-radius: 50%;
  opacity: .16;
  filter: blur(85px);
  will-change: transform;
  mix-blend-mode: multiply;
}
.harmony-orb-blue {
  top: -25%;
  left: -22%;
  background: var(--blue);
  transform: translate3d(var(--harmony-blue-x), var(--harmony-blue-y), 0);
  animation: breathe-blue 11s ease-in-out infinite alternate;
}
.harmony-orb-turquoise {
  top: 32%;
  right: -28%;
  background: var(--turquoise);
  transform: translate3d(var(--harmony-turquoise-x), var(--harmony-turquoise-y), 0);
  animation: breathe-turquoise 14s ease-in-out -4s infinite alternate;
}
.harmony-orb-green {
  bottom: -35%;
  left: 18%;
  background: #43a868;
  transform: translate3d(var(--harmony-green-x), var(--harmony-green-y), 0);
  animation: breathe-green 13s ease-in-out -7s infinite alternate;
}
@keyframes breathe-blue {
  from { scale: .88; opacity: .11; }
  to { scale: 1.12; opacity: .2; }
}
@keyframes breathe-turquoise {
  from { scale: 1.08; opacity: .12; }
  to { scale: .9; opacity: .22; }
}
@keyframes breathe-green {
  from { scale: .92; opacity: .12; }
  to { scale: 1.14; opacity: .19; }
}

em {
  color: var(--turquoise);
  background: linear-gradient(90deg, var(--blue), var(--turquoise), var(--green-2), var(--blue));
  background-size: 300% 100%;
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: harmony-text 9s ease-in-out infinite;
}
@keyframes harmony-text { 50% { background-position: 100% 50%; } }

.button {
  background: linear-gradient(110deg, var(--blue-deep), var(--green-2));
  background-size: 180% 100%;
  transition: transform .2s, background-position .5s, color .2s;
}
.button:hover { background-position: 100% 50%; }
.announcement { background: linear-gradient(90deg, var(--blue-deep), var(--turquoise), var(--green)); }
.brand-mark { background: linear-gradient(145deg, var(--blue), var(--turquoise), var(--green)); }

.harmony-logo {
  position: relative;
  flex: 0 0 auto;
  overflow: visible;
}
.harmony-logo svg {
  width: 82%;
  height: 82%;
  overflow: visible;
  filter: drop-shadow(0 2px 3px rgba(0,50,35,.12));
}
.harmony-logo .logo-h,
.harmony-logo .logo-branches,
.harmony-logo .logo-roots {
  fill: none;
  stroke: white;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.harmony-logo .logo-h { stroke-width: 7; }
.harmony-logo .logo-branches { stroke-width: 3.2; }
.harmony-logo .logo-roots { stroke-width: 2.6; opacity: .78; }
.harmony-logo .logo-leaf { fill: #d8f8e4; }
.harmony-logo .logo-cross {
  fill: white;
  stroke: rgba(12,89,77,.55);
  stroke-width: 1;
}
.brand-mark.harmony-logo {
  width: 50px;
  height: 50px;
  padding: 5px;
  border-radius: 50% 50% 50% 18%;
}
.tree-intro-mark.harmony-logo {
  width: 66px;
  height: 66px;
  padding: 7px;
  border-radius: 50% 50% 50% 20%;
}
.brand:hover .harmony-logo svg {
  transform: scale(1.05);
  transition: transform .3s ease;
}

.hero {
  background:
    radial-gradient(circle at 78% 25%, rgba(24,168,160,.12), transparent 30%),
    radial-gradient(circle at 8% 70%, rgba(18,105,168,.08), transparent 28%),
    rgba(249,252,251,.72);
}
.portrait-art { background: linear-gradient(155deg, #d8eef3, var(--sage), #cdebd9); }
.reassurance { background: linear-gradient(90deg, rgba(229,242,249,.94), rgba(226,247,241,.94), rgba(231,244,231,.94)); }
.services { background: linear-gradient(180deg, rgba(249,252,251,.9), rgba(238,248,247,.92)); }
.service-card:hover { background: linear-gradient(145deg, var(--blue-deep), var(--green-2)); }

.about {
  background:
    radial-gradient(circle at 8% 18%, rgba(18,105,168,.12), transparent 31%),
    linear-gradient(135deg, #eaf5f8, #e7f6f1 52%, #e8f5ea);
}
.about-panel {
  position: relative;
  overflow: hidden;
  background: linear-gradient(145deg, var(--blue-deep), var(--green));
}
.about-panel::after {
  content: "";
  position: absolute;
  width: 260px;
  height: 260px;
  right: -120px;
  bottom: -120px;
  border-radius: 50%;
  background: rgba(112,214,202,.25);
  animation: panel-breathe 8s ease-in-out infinite alternate;
}
.about-panel::before {
  content: "";
  position: absolute;
  width: 290px;
  height: 390px;
  top: -150px;
  left: -125px;
  border: 1px solid rgba(216,248,228,.18);
  border-radius: 100% 0 100% 0;
  transform: rotate(22deg);
  box-shadow: 45px 55px 0 -1px rgba(216,248,228,.04), 90px 110px 0 -1px rgba(216,248,228,.025);
}
.about-panel > * { position: relative; z-index: 1; }
@keyframes panel-breathe { to { scale: 1.35; opacity: .5; } }

.journey { background: linear-gradient(180deg, rgba(249,252,251,.86), rgba(235,247,242,.9)); }
.steps li > span { background: linear-gradient(145deg, var(--blue), var(--turquoise), var(--green-2)); }
.fees {
  background:
    radial-gradient(circle at var(--harmony-position) 10%, rgba(44,194,190,.3), transparent 30%),
    linear-gradient(125deg, #104a72, #087a75 52%, #145b46);
}
.availability { background: linear-gradient(125deg, #e8f4fa, #e7f7f3 52%, #edf7ea); }
.availability-heading { display: grid; grid-template-columns: 1.2fr .8fr; gap: 90px; align-items: end; margin-bottom: 55px; }
.availability-intro p { margin-bottom: 24px; color: #61716e; }
.weekly-schedule { display: grid; grid-template-columns: repeat(4,1fr); overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius); background: rgba(255,255,255,.72); box-shadow: 0 20px 55px rgba(12,89,77,.08); }
.schedule-day { min-height: 260px; padding: 30px 26px; border-right: 1px solid var(--line); }
.schedule-day:last-child { border-right: 0; }
.schedule-day.weekend { background: linear-gradient(155deg, rgba(216,242,235,.55), rgba(234,247,241,.78)); }
.day-heading { display: flex; align-items: center; gap: 13px; padding-bottom: 25px; border-bottom: 1px solid var(--line); }
.day-heading > span { width: 46px; height: 46px; display: grid; place-items: center; border-radius: 100% 0 100% 0; background: linear-gradient(135deg, var(--blue), var(--turquoise), var(--green-2)); color: white; font-size: .7rem; font-weight: 800; text-transform: uppercase; }
.day-heading strong, .day-heading small { display: block; }
.day-heading strong { font: 500 1.3rem "Newsreader", serif; }
.day-heading small { margin-top: 3px; color: #75837f; font-size: .65rem; }
.time-slots { display: grid; gap: 10px; margin-top: 27px; }
.time-slots span { padding: 12px 14px; border: 1px solid rgba(20,123,106,.16); border-radius: 10px; background: white; color: var(--green); font-size: .86rem; font-weight: 700; text-align: center; }
.availability-details { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 24px; }
.availability-details > span { padding: 20px 22px; border-left: 2px solid var(--turquoise); color: #687773; font-size: .75rem; }
.availability-details strong { display: block; margin-bottom: 4px; color: var(--ink); font-size: .85rem; }

@media (max-width: 900px) {
  .availability-heading { grid-template-columns: 1fr; gap: 30px; }
  .weekly-schedule { grid-template-columns: 1fr 1fr; }
  .schedule-day:nth-child(2) { border-right: 0; }
  .schedule-day:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
  .availability-details { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .weekly-schedule { grid-template-columns: 1fr; }
  .schedule-day, .schedule-day:nth-child(2) { min-height: 0; border-right: 0; border-bottom: 1px solid var(--line); }
  .schedule-day:last-child { border-bottom: 0; }
}
.faq-section { background: linear-gradient(180deg, rgba(249,252,251,.88), rgba(235,247,247,.92)); }
.contact {
  background: linear-gradient(105deg, var(--blue), var(--turquoise) 48%, var(--green-2));
  background-size: 180% 100%;
  animation: contact-harmony 12s ease-in-out infinite alternate;
}
@keyframes contact-harmony { to { background-position: 100% 50%; } }
footer { background: linear-gradient(125deg, #092d48, #073e3c 52%, #0a3428); }

@media (prefers-reduced-motion: reduce) {
  .harmony-orb, em, .contact, .about-panel::after { animation: none; }
  .tree-intro { transition-duration: .15s; }
  .care-tree-photo, .tree-image-layer, .tree-light, .tree-ground-glow, .tree-intro-copy {
    animation: none;
    opacity: 1;
    transform: none;
    clip-path: none;
  }
  .drifting-leaves { display: none; }
  .intro-brand-logo { animation: none; }
  .harmony-pulse, .pulse-core { display: none; }
  .intro-glow-core { display: none; }
  .intro-brand-logo { opacity: 1; clip-path: none; }
}

@media (max-width: 640px) {
  .tree-intro-copy { min-height: 330px; margin-top: 0; }
  .intro-brand-logo { width: min(94vw, 560px); }
  .skip-intro { right: 50%; transform: translateX(50%); white-space: nowrap; }
}
