:root {
  --turquoise: #0fa7a0;
  --turquoise-dark: #086f6c;
  --teal: #075a58;
  --deep: #064b49;
  --mint: #e7f5f2;
  --mint-2: #d8efeb;
  --coral: #ed7a6f;
  --coral-soft: #fff0ec;
  --gold: #c99a3b;
  --gold-2: #efcd7a;
  --gold-dark: #9b6d19;
  --cream: #fffdf8;
  --ink: #243837;
  --muted: #667775;
  --shadow: 0 18px 50px rgba(14, 86, 83, .12);
  --font-body: "Aventa", "Manrope", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-display: "Cormorant Garamond", Georgia, serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--font-body); color: var(--ink); background: var(--cream); line-height: 1.6; -webkit-font-smoothing: antialiased; }
img, svg { display: block; }
button, input, select { font: inherit; }
button { cursor: pointer; }
a { color: inherit; }
.skip-link { position: fixed; left: 12px; top: -80px; z-index: 999; background: #fff; padding: 10px 14px; border-radius: 10px; }
.skip-link:focus { top: 12px; }
.shell { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }
.section { padding: 96px 0; }
.topbar { height: 82px; padding: 0 max(20px, calc((100vw - 1180px) / 2)); display: flex; align-items: center; justify-content: space-between; position: sticky; top: 0; z-index: 80; background: rgba(255, 253, 248, .92); border-bottom: 1px solid rgba(7, 90, 88, .08); backdrop-filter: blur(14px); }
.brand { display: inline-flex; flex-direction: column; text-decoration: none; line-height: 1; }
.brand-name { font-size: 32px; letter-spacing: -.03em; color: var(--turquoise-dark); font-weight: 500; }
.brand-city { display: flex; align-items: center; gap: 10px; justify-content: center; margin-top: 8px; color: var(--gold-dark); letter-spacing: .42em; font-size: 15px; font-weight: 700; text-transform: uppercase; }
.brand-city i { width: 30px; height: 1px; background: linear-gradient(90deg, var(--gold), var(--gold-2)); display: inline-block; }
.brand-tagline { margin-top: 8px; color: var(--muted); font-size: 11px; letter-spacing: .06em; text-transform: lowercase; }
.top-cta { text-decoration: none; color: var(--deep); font-weight: 800; font-size: 14px; border-bottom: 1px solid var(--gold); padding-bottom: 4px; }
.hero { position: relative; min-height: 680px; overflow: hidden; background: radial-gradient(circle at 18% 20%, rgba(15,167,160,.12), transparent 28%), linear-gradient(135deg, #f8fffd 0%, #e5f5f1 55%, #d3ebe7 100%); }
.hero::before { content: ""; position: absolute; width: 520px; height: 520px; border: 1px solid rgba(201,154,59,.52); border-radius: 50%; right: -110px; top: -120px; }
.hero-content { min-height: 680px; display: grid; grid-template-columns: 1.1fr .9fr; align-items: center; gap: 58px; padding-top: 30px; padding-bottom: 70px; position: relative; z-index: 2; }
.hero-copy { padding: 44px 0; }
.eyebrow { margin: 0 0 14px; font-size: 12px; line-height: 1.2; letter-spacing: .22em; color: var(--gold-dark); font-weight: 700; }
.eyebrow.light { color: var(--gold-2); }
h1, h2, h3 { margin-top: 0; color: var(--deep); }
h1 { margin-bottom: 18px; font-family: var(--font-display); font-size: clamp(54px, 6vw, 82px); line-height: .98; font-weight: 600; letter-spacing: -.025em; }
h1 span { color: var(--turquoise-dark); }
h2 { font-family: var(--font-display); font-size: clamp(38px, 4vw, 54px); line-height: 1.05; font-weight: 600; letter-spacing: -.015em; }
.gold-rule { width: 112px; height: 2px; background: linear-gradient(90deg, var(--gold), var(--gold-2)); margin: 22px 0 24px; }
.hero-lead { font-size: 18px; max-width: 650px; color: #425654; margin-bottom: 20px; }
.premium-pill { display: flex; flex-wrap: wrap; gap: 10px 14px; margin: 0 0 24px; }
.premium-pill span { min-height: 38px; display: inline-flex; align-items: center; border-radius: 999px; padding: 8px 14px; background: rgba(255,255,255,.78); border: 1px solid rgba(201,154,59,.28); color: var(--deep); font-size: 13px; font-weight: 700; box-shadow: 0 10px 24px rgba(7,90,88,.07); }
.location-line { display: flex; align-items: center; gap: 9px; font-size: 14px; color: var(--muted); margin-top: 18px; }
.location-line svg { width: 20px; height: 20px; stroke: var(--gold); fill: none; stroke-width: 1.8; }
.hero-image { width: 100%; height: 570px; align-self: end; border-radius: 44% 44% 22% 22% / 38% 38% 16% 16%; background: linear-gradient(to top, rgba(229,245,241,.18), transparent 35%), url("assets/hero.jpg") center 15% / cover no-repeat; box-shadow: 0 30px 80px rgba(7, 90, 88, .16); position: relative; }
.hero-image::after { content: ""; position: absolute; inset: 18px -18px -18px 18px; border: 1px solid rgba(201,154,59,.65); border-radius: inherit; z-index: -1; }
.hero-wave { position: absolute; left: -4%; bottom: -58px; width: 108%; height: 120px; background: var(--cream); border-radius: 50% 50% 0 0 / 55% 55% 0 0; z-index: 3; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 50px; border-radius: 999px; border: 0; padding: 13px 22px; text-decoration: none; font-weight: 700; font-size: 14px; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.btn:hover { transform: translateY(-2px); }
.btn svg { width: 22px; height: 22px; stroke: currentColor; fill: none; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.btn-gold { color: #fff; background: linear-gradient(135deg, #b97c16 0%, #efc96d 45%, #c4871e 100%); box-shadow: 0 12px 28px rgba(175, 116, 19, .28), inset 0 1px 0 rgba(255,255,255,.45); }
.btn-large { min-height: 60px; padding: 16px 28px; font-size: 16px; }
.btn-outline { border: 1px solid rgba(201,154,59,.75); color: var(--gold-dark); background: transparent; }
.btn-outline:hover { background: rgba(201,154,59,.08); }
.btn-full { width: 100%; min-height: 58px; }
.section-heading { max-width: 760px; margin: 0 auto 46px; text-align: center; }
.section-heading p:last-child { color: var(--muted); font-size: 17px; }
.treatments { padding-top: 66px; }
.treatment-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.treatment-card { background: rgba(255,255,255,.78); border: 1px solid rgba(201,154,59,.18); border-radius: 28px; padding: 34px 28px 30px; box-shadow: var(--shadow); text-align: center; display: flex; flex-direction: column; align-items: center; backdrop-filter: blur(6px); }
.icon-ring { width: 90px; height: 90px; border: 1px solid rgba(201,154,59,.62); border-radius: 50%; display: grid; place-items: center; background: linear-gradient(145deg, #fff, #f8fffd); margin-bottom: 22px; }
.icon-ring svg { width: 56px; height: 56px; stroke: var(--teal); fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.treatment-card h3 { font-family: var(--font-display); font-size: 32px; margin-bottom: 10px; }
.treatment-card p { color: var(--muted); flex: 1; margin: 0 0 24px; font-size: 16px; }
.learn { padding-top: 30px; }
.learn-panel { background: radial-gradient(circle at 12% 25%, rgba(255,255,255,.9), transparent 35%), linear-gradient(125deg, var(--mint), #f7fbfa 72%); border: 1px solid rgba(7,90,88,.08); border-radius: 34px; padding: 46px; display: grid; grid-template-columns: .85fr 1.15fr; gap: 54px; box-shadow: 0 22px 55px rgba(7,90,88,.08); position: relative; overflow: hidden; }
.learn-panel::after { content: ""; position: absolute; width: 330px; height: 120px; left: -30px; bottom: -72px; border: 1px solid rgba(201,154,59,.48); border-radius: 50%; transform: rotate(-8deg); }
.info-mark { width: 46px; height: 46px; display: grid; place-items: center; border: 1px solid var(--gold); border-radius: 50%; color: var(--gold-dark); font-family: var(--font-display); font-size: 27px; margin-bottom: 28px; }
.learn-intro h2 { max-width: 460px; }
.learn-intro > p:last-child { color: var(--muted); }
.learn-list { display: grid; gap: 14px; }
details { background: rgba(255,255,255,.88); border: 1px solid rgba(7,90,88,.1); border-radius: 16px; box-shadow: 0 8px 24px rgba(7,90,88,.07); overflow: hidden; }
summary { list-style: none; cursor: pointer; padding: 18px 52px 18px 20px; font-weight: 700; color: var(--deep); position: relative; }
summary::-webkit-details-marker { display: none; }
summary::after { content: "+"; position: absolute; right: 20px; top: 50%; transform: translateY(-50%); color: var(--gold-dark); font-size: 24px; font-weight: 400; }
details[open] summary::after { content: "−"; }
details p { margin: 0; padding: 0 20px 20px; color: var(--muted); }
.contact-section { padding-top: 48px; }
.contact-card { border-radius: 34px; padding: 48px; display: grid; grid-template-columns: .9fr 1.1fr; gap: 64px; align-items: center; background: linear-gradient(135deg, #fffdf9, #eff9f7); border: 1px solid rgba(201,154,59,.22); box-shadow: var(--shadow); }
.contact-copy > p:not(.eyebrow) { color: var(--muted); font-size: 17px; }
.trust-list { margin: 26px 0 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.trust-list li { display: flex; align-items: center; gap: 10px; color: var(--deep); font-weight: 600; }
.trust-list li::before { content: "✓"; color: var(--gold-dark); width: 24px; height: 24px; border: 1px solid rgba(201,154,59,.65); border-radius: 50%; display: grid; place-items: center; font-size: 12px; }
form { display: grid; gap: 16px; }
label span { display: block; font-size: 12px; font-weight: 700; letter-spacing: .08em; color: var(--deep); margin: 0 0 7px 4px; text-transform: uppercase; }
input, select { width: 100%; height: 58px; border: 1px solid rgba(7,90,88,.16); border-radius: 14px; background: rgba(255,255,255,.92); color: var(--ink); padding: 0 16px; outline: 0; box-shadow: 0 6px 20px rgba(7,90,88,.05); }
input:focus, select:focus { border-color: var(--turquoise); box-shadow: 0 0 0 4px rgba(15,167,160,.11); }
.form-note { margin: 0; font-size: 11px; color: var(--muted); text-align: center; }
.form-error { color: #9d2f27; margin: 0; font-size: 13px; min-height: 1em; text-align: center; }
.benefits { padding-top: 34px; }
.benefit-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.benefit { padding: 24px 22px; border-top: 1px solid rgba(201,154,59,.5); }
.benefit span { color: var(--gold); font-family: var(--font-display); font-size: 26px; }
.benefit h3 { margin: 10px 0 7px; font-size: 18px; }
.benefit p { color: var(--muted); font-size: 14px; margin: 0; }
.romance-strip { min-height: 154px; border-radius: 28px; border: 1px solid rgba(237,122,111,.25); background: linear-gradient(100deg, #fff7f4, var(--coral-soft) 55%, #fffaf1); display: grid; grid-template-columns: 120px 1fr auto; align-items: center; gap: 30px; padding: 28px 38px; box-shadow: 0 12px 30px rgba(164,89,78,.08); }
.heart-line { font-family: var(--font-display); font-size: 78px; line-height: 1; color: var(--gold); text-align: center; }
.romance-strip p { margin: 0; font-family: var(--font-display); font-size: 32px; line-height: 1.05; color: var(--deep); }
.romance-strip span { color: var(--coral); }
.romance-strip strong { color: var(--coral); font-weight: 600; }
.faq { padding-bottom: 54px; }
.faq-shell { max-width: 920px; }
.faq-list { display: grid; gap: 12px; }
.faq-list details { box-shadow: none; }
.faq-list summary { font-size: 17px; }
.final-cta { padding: 44px 0 70px; }
.final-card { border-radius: 36px; min-height: 380px; padding: 56px 40px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; color: #fff; background: radial-gradient(circle at 15% 10%, rgba(30,184,175,.42), transparent 28%), radial-gradient(circle at 90% 90%, rgba(239,205,122,.13), transparent 25%), linear-gradient(135deg, #086f6c, #034541); position: relative; overflow: hidden; box-shadow: 0 24px 60px rgba(3,69,65,.24); }
.final-card::before, .final-card::after { content: ""; position: absolute; border: 1px solid rgba(239,205,122,.72); border-radius: 50%; }
.final-card::before { width: 420px; height: 140px; left: -110px; bottom: -85px; transform: rotate(10deg); }
.final-card::after { width: 360px; height: 150px; right: -120px; top: -90px; transform: rotate(-14deg); }
.final-card h2 { color: #fff; max-width: 760px; margin-bottom: 8px; }
.final-card > p:not(.eyebrow) { color: rgba(255,255,255,.82); margin: 0 0 28px; }
.mini-mark { width: 48px; height: 48px; display: grid; place-items: center; border: 1px solid var(--gold-2); color: var(--gold-2); transform: rotate(45deg); margin-bottom: 24px; }
footer { padding: 40px 0 110px; border-top: 1px solid rgba(7,90,88,.08); }
.footer-inner { text-align: center; color: var(--muted); font-size: 12px; }
.footer-brand { width: fit-content; margin: 0 auto 22px; }
.footer-brand .brand-name { font-size: 26px; }
.footer-brand .brand-city { font-size: 13px; }
.footer-brand .brand-tagline { display: block; margin-top: 8px; }
.copyright { margin-top: 18px; }
.mobile-sticky { display: none; }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .65s ease, transform .65s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
@media (max-width: 920px) {
  .section { padding: 76px 0; }
  .hero-content { grid-template-columns: 1fr; gap: 20px; padding-top: 30px; }
  .hero-copy { text-align: center; padding-bottom: 16px; }
  .premium-pill { justify-content: center; }
  .hero-lead { margin-left: auto; margin-right: auto; }
  .gold-rule { margin-left: auto; margin-right: auto; }
  .location-line { justify-content: center; }
  .hero-image { height: 480px; width: min(520px, 100%); margin: 0 auto; }
  .treatment-grid { grid-template-columns: 1fr; }
  .treatment-card { max-width: 620px; margin: 0 auto; }
  .learn-panel, .contact-card { grid-template-columns: 1fr; gap: 34px; }
  .benefit-grid { grid-template-columns: repeat(2, 1fr); }
  .romance-strip { grid-template-columns: 86px 1fr; }
  .romance-strip .btn { grid-column: 1 / -1; width: fit-content; justify-self: center; }
}
@media (max-width: 640px) {
  .shell { width: min(100% - 28px, 1180px); }
  .topbar { height: 72px; padding: 0 16px; }
  .brand-name { font-size: 27px; }
  .brand-city { font-size: 12px; letter-spacing: .34em; }
  .brand-city i { width: 18px; }
  .brand-tagline { font-size: 10px; }
  .top-cta { font-size: 12px; }
  .hero { min-height: auto; }
  .hero-content { min-height: auto; padding-bottom: 84px; }
  .hero-copy { padding-top: 26px; }
  .eyebrow { font-size: 10px; }
  h1 { font-size: 48px; }
  h2 { font-size: 38px; }
  .hero-lead { font-size: 16px; }
  .btn-large { width: 100%; font-size: 14px; }
  .hero-image { height: 430px; border-radius: 44% 44% 18% 18% / 30% 30% 14% 14%; background-position: center 10%; }
  .section { padding: 64px 0; }
  .treatments { padding-top: 40px; }
  .section-heading { margin-bottom: 34px; }
  .learn { padding-top: 20px; }
  .learn-panel, .contact-card { padding: 28px 20px; border-radius: 24px; }
  .learn-panel { gap: 24px; }
  .contact-card { gap: 28px; }
  .benefit-grid { grid-template-columns: 1fr 1fr; gap: 6px; }
  .benefit { padding: 18px 12px; }
  .benefit h3 { font-size: 15px; }
  .benefit p { font-size: 12px; }
  .romance-strip { min-height: auto; grid-template-columns: 1fr; text-align: center; padding: 28px 20px; gap: 12px; }
  .heart-line { font-size: 62px; }
  .romance-strip p { font-size: 26px; }
  .final-card { min-height: 360px; padding: 48px 22px; border-radius: 26px; }
  footer { padding-bottom: 100px; }
  .mobile-sticky { display: flex; position: fixed; left: 14px; right: 14px; bottom: max(12px, env(safe-area-inset-bottom)); z-index: 90; min-height: 56px; align-items: center; justify-content: center; gap: 10px; border-radius: 999px; text-decoration: none; color: #fff; font-weight: 800; background: linear-gradient(135deg, #0a8f88, #05635f); box-shadow: 0 16px 38px rgba(3,69,65,.34); }
  .mobile-sticky svg { width: 23px; height: 23px; stroke: #fff; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .btn { transition: none; }
}
