:root{
  --cream: #FBF5E9;
  --cream-deep: #F3E9D4;
  --ink: #2C2417;
  --ink-soft: #5B4E3B;
  --gold: #C48A2E;
  --gold-deep: #9C6B1D;
  --orange: #D9702C;
  --amber: #F0B646;
  --line: rgba(44,36,23,0.12);
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:'Work Sans', -apple-system, sans-serif;
  line-height:1.6;
  overflow-x:hidden;
}
h1,h2,h3,h4{
  font-family:'Fraunces', Georgia, serif;
  font-weight:600;
  color:var(--ink);
  line-height:1.15;
  letter-spacing:-0.01em;
}
a{color:inherit; text-decoration:none;}
img{max-width:100%; display:block;}
section{position:relative;}
.wrap{max-width:1140px; margin:0 auto; padding:0 24px;}

.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-size:0.78rem; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--gold-deep); font-weight:600; margin-bottom:14px;
}
.eyebrow::before{content:''; width:18px; height:2px; background:var(--orange); display:inline-block;}

/* HEADER */
header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(251,245,233,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:1140px; margin:0 auto; padding:16px 24px;
  display:flex; align-items:center; justify-content:space-between;
}
.logo{font-family:'Fraunces', serif; font-size:1.25rem; font-weight:700; color:var(--ink);}
.logo span{color:var(--orange);}
nav ul{display:flex; gap:32px; list-style:none;}
nav a{font-size:0.92rem; font-weight:500; color:var(--ink-soft); transition:color 0.2s;}
nav a:hover, nav a.active{color:var(--orange);}
.nav-cta{
  background:var(--ink); color:var(--cream) !important;
  padding:10px 22px; border-radius:100px; font-size:0.88rem; font-weight:600;
}
.burger{display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px;}
.burger span{width:24px; height:2px; background:var(--ink); display:block;}

.mobile-menu{
  display:none; position:fixed; top:64px; left:0; right:0; bottom:0;
  background:var(--cream); z-index:99; padding:32px 24px;
}
.mobile-menu.open{display:block;}
.mobile-menu ul{list-style:none; display:flex; flex-direction:column; gap:22px;}
.mobile-menu a{font-size:1.2rem; font-family:'Fraunces', serif;}

/* Page header banner (used on inner pages) */
.page-hero{
  padding:150px 0 64px;
  position:relative;
  overflow:hidden;
}
.page-hero::before{
  content:'';
  position:absolute; top:-120px; right:-160px;
  width:460px; height:460px;
  background:radial-gradient(circle, rgba(240,182,70,0.32), rgba(240,182,70,0) 70%);
  z-index:0;
}
.page-hero .wrap{position:relative; z-index:1;}
.page-hero h1{font-size:clamp(2rem, 3.6vw, 2.9rem); max-width:680px;}
.page-hero p.lead{color:var(--ink-soft); max-width:560px; margin-top:16px; font-size:1.05rem;}
.breadcrumb{font-size:0.85rem; color:var(--ink-soft); margin-bottom:18px;}
.breadcrumb a{color:var(--gold-deep); font-weight:600;}

/* HERO (home) */
.hero{padding:150px 0 90px; position:relative; overflow:hidden;}
.hero::before{
  content:''; position:absolute; top:-120px; right:-160px;
  width:520px; height:520px;
  background:radial-gradient(circle, rgba(240,182,70,0.35), rgba(240,182,70,0) 70%);
  z-index:0;
}
.hero-grid{display:grid; grid-template-columns:1.1fr 0.9fr; gap:60px; align-items:center; position:relative; z-index:1;}
.hero h1{font-size:clamp(2.1rem, 4vw, 3.2rem); margin-bottom:20px;}
.hero h1 em{font-style:italic; color:var(--orange);}
.hero p.lead{font-size:1.08rem; color:var(--ink-soft); max-width:480px; margin-bottom:32px;}
.hero-ctas{display:flex; gap:16px; flex-wrap:wrap; margin-bottom:36px;}
.btn-primary{
  background:var(--orange); color:#fff; padding:14px 30px; border-radius:100px;
  font-weight:600; font-size:0.95rem; display:inline-flex; align-items:center; gap:8px;
  box-shadow:0 10px 24px rgba(217,112,44,0.28); transition:transform 0.2s, box-shadow 0.2s;
}
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 14px 28px rgba(217,112,44,0.36);}
.btn-ghost{border:1.5px solid var(--ink); padding:13px 28px; border-radius:100px; font-weight:600; font-size:0.95rem;}
.hero-stats{display:flex; gap:36px; padding-top:24px; border-top:1px solid var(--line); flex-wrap:wrap;}
.stat-num{font-family:'Fraunces', serif; font-size:1.7rem; font-weight:700; color:var(--gold-deep);}
.stat-label{font-size:0.8rem; color:var(--ink-soft);}

.hero-visual{position:relative; background:var(--cream-deep); border-radius:28px; padding:36px; border:1px solid var(--line);}
.hero-visual .tag{font-size:0.78rem; color:var(--ink-soft); text-transform:uppercase; letter-spacing:0.1em; margin-bottom:6px;}
.hero-visual .reading{font-family:'Fraunces', serif; font-size:2.4rem; font-weight:700; color:var(--ink); margin-bottom:2px;}
.hero-visual .reading small{font-size:1rem; font-weight:500; color:var(--ink-soft);}
.glucose-svg{width:100%; height:auto; margin-top:18px;}
.glucose-path{
  fill:none; stroke:var(--orange); stroke-width:3; stroke-linecap:round;
  stroke-dasharray:600; stroke-dashoffset:600; animation:draw 2.2s ease forwards 0.4s;
}
@keyframes draw{ to{stroke-dashoffset:0;} }
.glucose-dot{fill:var(--gold);}
.visual-caption{display:flex; justify-content:space-between; margin-top:14px; font-size:0.78rem; color:var(--ink-soft);}

.trust-strip{background:var(--ink); color:var(--cream); padding:16px 0;}
.trust-strip .wrap{display:flex; justify-content:center; gap:48px; flex-wrap:wrap; font-size:0.85rem; letter-spacing:0.03em; opacity:0.9;}
.trust-strip strong{color:var(--amber); font-weight:600;}

.section{padding:96px 0;}
.section-head{max-width:640px; margin-bottom:56px;}
.section-head h2{font-size:clamp(1.7rem, 3vw, 2.4rem);}
.section-head p{color:var(--ink-soft); margin-top:14px; font-size:1.02rem;}

.services-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:24px;}
.service-card{
  background:#fff; border:1px solid var(--line); border-radius:20px; padding:32px 28px;
  transition:transform 0.25s, box-shadow 0.25s, border-color 0.25s;
}
.service-card:hover{transform:translateY(-4px); box-shadow:0 20px 40px rgba(44,36,23,0.08); border-color:transparent;}
.service-icon{
  width:48px; height:48px; border-radius:14px; background:var(--cream-deep);
  display:flex; align-items:center; justify-content:center; margin-bottom:20px; font-size:1.3rem;
}
.service-card h3{font-size:1.18rem; margin-bottom:10px;}
.service-card p{color:var(--ink-soft); font-size:0.94rem;}
.service-card .details{
  list-style:none; margin-top:14px; padding-top:14px; border-top:1px solid var(--line);
}
.service-card .details li{font-size:0.86rem; color:var(--ink-soft); margin-bottom:6px; padding-left:16px; position:relative;}
.service-card .details li::before{content:'—'; position:absolute; left:0; color:var(--orange);}

.doctors{display:grid; grid-template-columns:1fr 1fr; gap:28px;}
.doctor-card{background:var(--cream-deep); border-radius:24px; padding:36px; display:flex; gap:24px; align-items:flex-start;}
.doctor-avatar{
  width:76px; height:76px; min-width:76px; border-radius:50%;
  background:linear-gradient(135deg, var(--gold), var(--orange));
  display:flex; align-items:center; justify-content:center; color:#fff;
  font-family:'Fraunces', serif; font-size:1.4rem; font-weight:700;
}
.doctor-card h3{font-size:1.15rem; margin-bottom:4px;}
.doctor-role{color:var(--orange); font-size:0.85rem; font-weight:600; margin-bottom:10px;}
.doctor-card p{color:var(--ink-soft); font-size:0.92rem;}
.doctor-card .doctor-tags{display:flex; gap:8px; flex-wrap:wrap; margin-top:14px;}
.doctor-card .doctor-tags span{
  font-size:0.76rem; background:#fff; border:1px solid var(--line);
  padding:5px 12px; border-radius:100px; color:var(--ink-soft);
}

.why-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:20px;}
.why-item{padding:24px 0; border-top:2px solid var(--ink);}
.why-num{font-family:'Fraunces', serif; font-size:1.1rem; color:var(--orange); margin-bottom:10px;}
.why-item h4{font-size:1.02rem; margin-bottom:8px;}
.why-item p{font-size:0.9rem; color:var(--ink-soft);}

.testi-strip{
  background:var(--ink); border-radius:28px; padding:56px; color:var(--cream);
  display:grid; grid-template-columns:1fr 1fr 1fr; gap:36px;
}
.testi-strip .quote{font-size:0.95rem; line-height:1.7; opacity:0.92; margin-bottom:16px;}
.testi-strip .who{font-size:0.82rem; color:var(--amber); font-weight:600;}
.stars{color:var(--amber); font-size:0.9rem; margin-bottom:14px; letter-spacing:2px;}

.review-grid{display:grid; grid-template-columns:1fr 1fr; gap:24px;}
.review-card{
  background:#fff; border:1px solid var(--line); border-radius:20px; padding:30px;
}
.review-card .quote{font-size:0.96rem; color:var(--ink-soft); margin-bottom:16px; line-height:1.7;}
.review-card .who{font-size:0.85rem; font-weight:600; color:var(--ink);}
.review-card .for{font-size:0.8rem; color:var(--gold-deep);}

.rating-banner{
  display:flex; align-items:center; gap:28px; background:var(--cream-deep);
  border-radius:24px; padding:32px 40px; margin-bottom:48px; flex-wrap:wrap;
}
.rating-num{font-family:'Fraunces', serif; font-size:3rem; font-weight:700; color:var(--gold-deep);}
.rating-banner .stars{margin-bottom:4px;}
.rating-sub{font-size:0.88rem; color:var(--ink-soft);}

.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:stretch;}
.contact-card{background:var(--cream-deep); border-radius:24px; padding:40px;}
.contact-row{display:flex; gap:16px; padding:16px 0; border-bottom:1px solid var(--line);}
.contact-row:last-child{border-bottom:none;}
.contact-row .ic{
  width:36px; height:36px; min-width:36px; border-radius:10px; background:var(--orange);
  display:flex; align-items:center; justify-content:center; color:#fff; font-size:0.9rem;
}
.contact-row h4{font-size:0.95rem; margin-bottom:4px;}
.contact-row p{font-size:0.88rem; color:var(--ink-soft);}
.map-frame{border-radius:24px; overflow:hidden; border:1px solid var(--line); min-height:340px;}
.map-frame iframe{width:100%; height:100%; min-height:340px; border:0; display:block;}

.cta-banner{
  background:linear-gradient(120deg, var(--gold-deep), var(--orange));
  border-radius:28px; padding:64px 48px; text-align:center; color:#fff;
}
.cta-banner h2{color:#fff; font-size:clamp(1.6rem,3vw,2.2rem); margin-bottom:16px;}
.cta-banner p{opacity:0.92; max-width:520px; margin:0 auto 30px;}
.cta-banner .btn-primary{background:#fff; color:var(--ink); box-shadow:none;}
.cta-banner .btn-primary:hover{background:var(--cream);}

footer{padding:56px 0 32px; border-top:1px solid var(--line);}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; margin-bottom:40px;}
.footer-grid h4{font-size:0.92rem; margin-bottom:16px;}
.footer-grid ul{list-style:none;}
.footer-grid li{margin-bottom:10px; font-size:0.9rem; color:var(--ink-soft);}
.footer-bottom{
  display:flex; justify-content:space-between; padding-top:24px; border-top:1px solid var(--line);
  font-size:0.82rem; color:var(--ink-soft); flex-wrap:wrap; gap:12px;
}

@media (max-width:860px){
  nav ul, .nav-cta{display:none;}
  .burger{display:flex;}
  .hero-grid, .doctors, .contact-grid, .review-grid{grid-template-columns:1fr;}
  .services-grid{grid-template-columns:1fr 1fr;}
  .why-grid{grid-template-columns:1fr 1fr;}
  .testi-strip{grid-template-columns:1fr; padding:36px 28px;}
  .footer-grid{grid-template-columns:1fr;}
  .hero{padding:120px 0 60px;}
  .page-hero{padding:130px 0 48px;}
}
@media (max-width:520px){
  .services-grid{grid-template-columns:1fr;}
  .why-grid{grid-template-columns:1fr;}
  .hero-stats{flex-wrap:wrap; row-gap:16px;}
  .cta-banner{padding:44px 24px;}
  .rating-banner{padding:26px 24px;}
}