
:root{
  --teal:#073846;
  --teal2:#0a4055;
  --gold:#d9b45f;
  --cream:#fbf7ef;
  --soft:#f3eee6;
  --ink:#173644;
  --muted:#5c6f77;
}
*{box-sizing:border-box}
body{margin:0;background:var(--cream);color:var(--ink);font-family:Arial,Helvetica,sans-serif;line-height:1.65}
h1,h2,h3{font-family:Georgia,'Times New Roman',serif;font-weight:400;line-height:1.12;margin:0}
p{margin:0 0 14px}
a{text-decoration:none;color:inherit}
.inner-header{background:linear-gradient(90deg,#062f3d,#0a4055);color:#fff;padding:18px 5vw;display:flex;align-items:center;justify-content:space-between;gap:20px;position:sticky;top:0;z-index:20;box-shadow:0 8px 30px rgba(0,0,0,.15)}
.logo{display:flex;align-items:center}
.logo img{height:46px;width:auto;display:block}
.nav{display:flex;gap:22px;align-items:center;font-size:15px}
.nav a{color:#fff}.nav a:hover{color:var(--gold)}
.book{background:linear-gradient(135deg,#f2cf7c,var(--gold));color:#102d37;padding:11px 22px;border-radius:999px;font-weight:700;display:inline-block;border:0}
.page-hero{background:linear-gradient(90deg,#062f3d,#0a4055);color:#fff;padding:82px 5vw;text-align:center}
.page-hero h1{font-size:clamp(40px,5vw,62px)}
.page-hero p{font-size:19px;max-width:860px;margin:18px auto 0;color:#e9f5f7}
section{padding:70px 5vw}
.container{max-width:1180px;margin:0 auto}
.section-title{font-size:42px;color:var(--ink);margin-bottom:20px}
.eyebrow{color:var(--gold);letter-spacing:2px;text-transform:uppercase;font-size:13px;font-weight:700;margin-bottom:12px}
.lead{font-size:19px;color:#314b55;max-width:900px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.image-card{border-radius:22px;overflow:hidden;box-shadow:0 20px 60px rgba(11,47,57,.16);background:#fff}
.image-card img{width:100%;height:100%;min-height:360px;object-fit:cover;display:block}
.panel{background:#fff;border-radius:22px;padding:34px;box-shadow:0 18px 55px rgba(11,47,57,.10)}
.panel h3{font-size:28px;color:var(--teal);margin-bottom:12px}
.treatment-card{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 18px 50px rgba(11,47,57,.12);display:flex;flex-direction:column}
.treatment-card img{width:100%;height:210px;object-fit:cover;display:block}
.treatment-card .body{padding:24px;flex:1}
.treatment-card h3{font-size:25px;color:var(--teal);margin-bottom:10px}
.badge{display:inline-block;background:#f4e4bd;color:#173644;border-radius:999px;padding:6px 12px;font-size:13px;font-weight:700;margin-bottom:12px}
.band{background:#edf6f7}
.list{margin:18px 0 0;padding-left:20px}
.list li{margin:8px 0}
.quote{background:linear-gradient(90deg,#062f3d,#0a4055);color:#fff;border-radius:22px;padding:34px}
.quote h2{color:#fff;font-size:36px;margin-bottom:12px}
.quote p{color:#e7f3f4}
.cta-strip{background:linear-gradient(90deg,#062f3d,#0a4055);color:#fff;padding:38px 5vw}
.cta-inner{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.footer{background:#062f3d;color:#dcecee;padding:28px 5vw;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:14px}

/* utility bar above home image */
.utility-bar{background:linear-gradient(90deg,#062f3d,#0a4055);color:#fff;padding:10px 5vw;display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:15px;flex-wrap:wrap}
.utility-bar .util-phone{color:var(--gold);font-weight:600;font-size:15px;letter-spacing:.4px;display:inline-flex;align-items:center;gap:8px}
.utility-bar .util-phone:hover{color:#f2cf7c}
.utility-bar .util-phone span{color:var(--gold);font-size:15px;line-height:1;font-variant-emoji:text}
.utility-bar .util-book{color:var(--gold);font-weight:600;font-size:15px;letter-spacing:.4px;background:none;padding:0;border-radius:0}
.utility-bar .util-book:hover{color:#f2cf7c}

/* exact homepage image */
.home-wrap{width:100%;background:#073846;display:flex;justify-content:center;overflow-x:auto}
.home-art{position:relative;width:100%;max-width:1536px;min-width:980px}
.home-art img{width:100%;display:block}
.hotspot{position:absolute;z-index:3;display:block}
.hs-home{left:33.5%;top:2.2%;width:4.5%;height:3.2%}
.hs-about{left:38.3%;top:2.2%;width:4.6%;height:3.2%}
.hs-treat{left:43%;top:2.2%;width:8.2%;height:3.2%}
.hs-meno{left:51.7%;top:2.2%;width:15.3%;height:3.2%}
.hs-skin{left:67.2%;top:2.2%;width:8%;height:3.2%}
.hs-contact{left:75.4%;top:2.2%;width:7%;height:3.2%}
.hs-booktop{right:3.5%;top:1.45%;width:11.8%;height:4%}
.hs-bookhero{left:12.3%;top:26.25%;width:17.2%;height:4.1%}
.hs-learn{left:30.3%;top:26.25%;width:12.6%;height:4.1%}
.hs-view{left:42.6%;top:62.8%;width:14.4%;height:3.2%}
.hs-menobook{left:31.5%;top:75.35%;width:11.4%;height:3.3%}
.hs-bottombook{right:3.7%;bottom:4.35%;width:18.2%;height:4.2%}

@media(max-width:950px){
  .inner-header{display:block;text-align:center;position:relative}
  .logo{justify-content:center}.nav{justify-content:center;flex-wrap:wrap;margin:16px 0;gap:14px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .image-card img{min-height:260px}
  section{padding:50px 6vw}
  .section-title{font-size:34px}
}

/* v3 image polish */
.treatment-card img{height:230px;object-fit:cover;object-position:center;}
.image-card img{object-fit:cover;object-position:center;}
.grid-3{align-items:stretch}
.treatment-card{height:100%}
.treatment-card .body{display:flex;flex-direction:column}
.treatment-card .body p{flex:1}
.treatment-card .price{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:18px;padding-top:16px;border-top:1px solid #ecf2f3}
.treatment-card .price .price-note{font-size:13px;font-weight:600;color:#60737b;line-height:1.3}
.treatment-card .book{padding:9px 16px;font-size:14px}

/* home hero */
.home-hero{background:linear-gradient(90deg,#062f3d,#0a4055);color:#fff;padding:70px 5vw 0}
.home-hero-grid{align-items:end;gap:40px;max-width:1180px;margin:0 auto}
.home-hero-copy{padding-bottom:80px}
.home-hero-copy .eyebrow{color:var(--gold)}
.home-hero-copy h1{font-family:Georgia,'Times New Roman',serif;font-size:clamp(40px,5.2vw,64px);color:#fff;margin:14px 0 18px}
.home-hero-copy h1 em{color:var(--gold);font-style:italic}
.home-hero-copy .lead{color:#e9f5f7;max-width:520px;margin-bottom:26px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.ghost{display:inline-block;padding:11px 22px;border-radius:999px;border:1px solid rgba(255,255,255,.6);color:#fff;font-weight:600}
.ghost:hover{border-color:var(--gold);color:var(--gold)}
.home-hero-img{align-self:end}
.home-hero-img .home-hero-video{width:100%;display:block;border-top-left-radius:14px;border-top-right-radius:14px;object-fit:cover;max-height:520px;background:#062f3d}
@media(prefers-reduced-motion:reduce){
  .home-hero-img .home-hero-video{pointer-events:none}
}

/* values strip */
.values-strip{background:#0a4055;color:#fff;padding:28px 5vw}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:1180px;margin:0 auto;text-align:center}
.values-grid .value h4{margin:0 0 4px;color:var(--gold);text-transform:uppercase;letter-spacing:1.2px;font-size:13px;font-weight:700;font-family:Arial,Helvetica,sans-serif}
.values-grid .value p{margin:0;color:#e9f5f7;font-size:14px}

/* center heads & ctas */
.center-head{text-align:center;margin-bottom:36px}
.center-cta{text-align:center;margin-top:32px}

/* homepage treatment cards (compact) */
.treatment-card.mini .body{padding:18px;text-align:center}
.treatment-card.mini h3{font-size:18px;line-height:1.25;margin:0}

/* mini panel row under menopause */
.mini-panels{margin-top:50px;text-align:center}
.mini-panel{padding:22px}
.mini-panel h3{font-size:16px;color:var(--teal);margin:0;text-transform:uppercase;letter-spacing:1px}

@media(max-width:950px){
  .home-hero{padding:50px 6vw 0}
  .home-hero-copy{padding-bottom:30px}
  .values-grid{grid-template-columns:repeat(2,1fr)}
}


/* blog section */
.blog-section{background:#edf6f7}
.blog-tabs{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:28px}
.blog-tab{background:#fff;color:var(--teal);border:1px solid #d6e4e7;padding:11px 22px;border-radius:999px;font-weight:700;font-size:15px;cursor:pointer;transition:all .2s ease}
.blog-tab:hover{border-color:var(--gold);color:var(--teal2)}
.blog-tab.active{background:linear-gradient(135deg,#f2cf7c,var(--gold));color:#102d37;border-color:transparent;box-shadow:0 8px 22px rgba(217,180,95,.35)}
.blog-panel{display:none;background:#fff;border-radius:22px;padding:34px;box-shadow:0 18px 55px rgba(11,47,57,.10)}
.blog-panel.active{display:block;animation:blogFade .25s ease}
@keyframes blogFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.blog-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:24px}
.blog-img{border-radius:16px;overflow:hidden;box-shadow:0 12px 36px rgba(11,47,57,.12)}
.blog-img img{width:100%;height:340px;object-fit:cover;display:block}
.blog-body h3{font-size:30px;color:var(--teal);margin-bottom:8px}
.blog-body h4{font-family:Georgia,'Times New Roman',serif;font-weight:400;font-size:22px;color:var(--teal);margin:22px 0 10px}
.blog-tagline{color:var(--gold);font-size:18px;margin-bottom:16px}
.blog-body p{color:#314b55;font-size:16px}
.blog-body ul{color:#314b55;font-size:16px;margin:8px 0 16px;padding-left:22px}
.blog-body ul li{margin-bottom:6px}
.blog-disclaimer{margin-top:22px;padding-top:18px;border-top:1px solid #e3eef0;color:#5c6f77;font-size:14px}
@media(max-width:768px){
  .blog-grid{grid-template-columns:1fr}
  .blog-img img{height:260px}
  .blog-panel{padding:22px}
}

/* legal pages (privacy / cookies) */
.legal-content{max-width:880px;margin:0 auto}
.legal-content h2{font-size:30px;color:var(--teal);margin:36px 0 12px}
.legal-content h3{font-size:22px;color:var(--teal);margin:24px 0 10px;font-family:Georgia,'Times New Roman',serif;font-weight:400}
.legal-content p,.legal-content li{color:#314b55;font-size:16px}
.legal-content ul{padding-left:22px;margin:8px 0 16px}
.legal-content li{margin-bottom:6px}
.legal-content table{width:100%;border-collapse:collapse;margin:14px 0 22px;font-size:15px;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 12px 36px rgba(11,47,57,.08)}
.legal-content table th,.legal-content table td{padding:12px 14px;text-align:left;border-bottom:1px solid #e3eef0;vertical-align:top;color:#314b55}
.legal-content table th{background:#edf6f7;color:var(--teal);font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.6px}
.legal-content table tr:last-child td{border-bottom:0}
.legal-meta{color:#5c6f77;font-size:14px;margin-bottom:18px}
.legal-content a{color:var(--teal2);text-decoration:underline}
.legal-content a:hover{color:var(--gold)}

/* footer with policy links */
.footer{flex-direction:column;align-items:flex-start;gap:10px}
.footer .footer-row{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;width:100%}
.footer .footer-links{display:flex;gap:14px;flex-wrap:wrap}
.footer .footer-links a,.footer .footer-links button{color:#dcecee;background:none;border:0;padding:0;font:inherit;cursor:pointer;text-decoration:underline}
.footer .footer-links a:hover,.footer .footer-links button:hover{color:var(--gold)}
.footer .footer-social{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.footer .footer-social a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(220,236,238,.08);color:#dcecee;transition:background .2s ease,color .2s ease}
.footer .footer-social a:hover{background:var(--gold);color:#062f3d}
.footer .footer-social svg{width:18px;height:18px;fill:currentColor}


/* cookie banner */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:9999;background:#ffffff;color:var(--ink);border-radius:16px;box-shadow:0 28px 70px rgba(6,47,61,.28);border:1px solid #e3eef0;animation:cookieSlideUp .3s ease}
@keyframes cookieSlideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.cookie-banner-inner{display:flex;align-items:center;gap:22px;padding:20px 24px;flex-wrap:wrap;max-width:1180px;margin:0 auto}
.cookie-banner-text{flex:1;min-width:260px}
.cookie-banner-text h3{font-family:Georgia,'Times New Roman',serif;font-size:20px;color:var(--teal);margin-bottom:6px}
.cookie-banner-text p{font-size:14px;color:#314b55;margin:0;line-height:1.55}
.cookie-banner-text a{color:var(--teal2);text-decoration:underline}
.cookie-banner-text a:hover{color:var(--gold)}
.cookie-banner-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cookie-btn{font:inherit;font-weight:700;font-size:14px;border-radius:999px;padding:10px 20px;cursor:pointer;border:1px solid transparent;transition:all .2s ease;line-height:1.2}
.cookie-btn-primary{background:linear-gradient(135deg,#f2cf7c,var(--gold));color:#102d37}
.cookie-btn-primary:hover{filter:brightness(1.04)}
.cookie-btn-secondary{background:#fff;color:var(--teal);border-color:#cfdde0}
.cookie-btn-secondary:hover{border-color:var(--gold);color:var(--teal2)}

/* cookie preferences modal */
.cookie-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px}
.cookie-modal-backdrop{position:absolute;inset:0;background:rgba(7,42,55,.55);backdrop-filter:blur(2px)}
.cookie-modal-card{position:relative;background:#fff;border-radius:18px;max-width:560px;width:100%;padding:32px 28px 24px;box-shadow:0 30px 80px rgba(6,47,61,.32);max-height:88vh;overflow-y:auto}
.cookie-modal-card h3{font-family:Georgia,'Times New Roman',serif;font-size:26px;color:var(--teal);margin-bottom:8px}
.cookie-modal-card p{font-size:15px;color:#314b55}
.cookie-modal-close{position:absolute;top:10px;right:14px;background:none;border:0;font-size:28px;line-height:1;color:#5c6f77;cursor:pointer;padding:4px 10px}
.cookie-modal-close:hover{color:var(--teal)}
.cookie-cat{margin:16px 0;padding:14px 16px;border:1px solid #e3eef0;border-radius:12px;background:#f7fafb}
.cookie-cat-row{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--teal);cursor:pointer}
.cookie-cat-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--teal2)}
.cookie-cat-name em{font-style:italic;font-weight:400;color:#5c6f77;font-size:13px;margin-left:4px}
.cookie-cat-desc{margin:8px 0 0;font-size:13px;color:#5c6f77;line-height:1.55}
.cookie-modal-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;margin-top:18px}
body.cookie-modal-open{overflow:hidden}

@media(max-width:700px){
  .cookie-banner{left:8px;right:8px;bottom:8px}
  .cookie-banner-inner{padding:16px 18px;gap:14px}
  .cookie-banner-actions{width:100%}
  .cookie-banner-actions .cookie-btn{flex:1 1 auto;text-align:center}
  .cookie-modal-actions{justify-content:stretch}
  .cookie-modal-actions .cookie-btn{flex:1 1 auto;text-align:center}
}
