
:root{
  --green:#006b5d;
  --green-2:#007d6c;
  --green-dark:#00483f;
  --mint:#dff3ee;
  --mint-2:#f1faf7;
  --bg:#ffffff;
  --bg-soft:#f5f8f7;
  --text:#1c2630;
  --muted:#647181;
  --line:#e4ece9;
  --shadow:0 24px 80px rgba(19,42,47,.10);
  --shadow-soft:0 10px 30px rgba(19,42,47,.07);
  --radius:28px;
  --container:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.58;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
p,h1,h2,h3{margin-top:0}
.container{width:min(calc(100% - 48px),var(--container));margin-inline:auto}
.section{padding:clamp(72px,8vw,118px) 0}
.skip-link{position:absolute;left:-999px;top:8px;background:#fff;color:var(--green);padding:.8rem 1rem;border-radius:12px;z-index:1000}
.skip-link:focus{left:8px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.94);
  border-bottom:1px solid rgba(28,38,48,.08);
  backdrop-filter:blur(18px);
}
.site-header.is-scrolled{box-shadow:0 12px 32px rgba(19,42,47,.08)}
.header-inner{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand-mark{
  width:38px;height:38px;
  border-radius:14px;
  background:var(--green);
  color:#fffaf3;
  display:grid;
  place-items:center;
  box-shadow:0 12px 30px rgba(0,107,93,.22);
}
.brand-heart{
  width:23px;
  height:23px;
  display:block;
  color:#fff;
}
.brand-name{
  display:block;
  font-size:1.32rem;
  line-height:1.05;
  letter-spacing:-.035em;
  color:var(--green-dark);
  font-weight:760;
}
.brand-line{
  display:block;
  color:var(--muted);
  font-size:.92rem;
  margin-top:3px;
  font-weight:500;
}
.site-nav{display:flex;align-items:center;gap:8px;font-size:.94rem;font-weight:650}
.site-nav a{
  color:#26323d;
  padding:10px 13px;
  border-radius:999px;
  transition:background .16s ease,color .16s ease,transform .16s ease;
}
.site-nav a:hover{background:var(--mint-2);color:var(--green);transform:translateY(-1px)}
.nav-cta{
  margin-left:6px;
  background:var(--green)!important;
  color:#fff!important;
  padding:12px 18px!important;
  box-shadow:0 12px 26px rgba(0,107,93,.18);
}
.nav-toggle{display:none;background:transparent;border:0;width:44px;height:44px;padding:9px;cursor:pointer}
.nav-toggle span:not(.sr-only){display:block;width:26px;height:2px;background:#22303a;border-radius:999px;margin:5px 0}

.eyebrow,.kicker{
  color:var(--green);
  font-size:.82rem;
  font-weight:760;
  letter-spacing:.02em;
  display:inline-flex;
  align-items:center;
  gap:9px;
  margin:0 0 15px;
}
.eyebrow span{
  width:11px;height:11px;border-radius:999px;background:#21c5a4;
  box-shadow:0 0 0 8px rgba(33,197,164,.14);
}
h1,h2,h3{letter-spacing:-.045em;color:var(--green-dark)}
h1{
  max-width:720px;
  font-size:clamp(3.15rem,6vw,5.35rem);
  line-height:.98;
  font-weight:800;
  margin:0 0 24px;
}
h2{
  font-size:clamp(2.05rem,4vw,3.65rem);
  line-height:1.03;
  font-weight:780;
  margin:0 0 18px;
}
h3{
  font-size:1.32rem;
  line-height:1.15;
  font-weight:760;
  margin-bottom:10px;
  color:#162536;
}
p{font-size:1.03rem;color:var(--muted)}
.hero{
  position:relative;
  overflow:hidden;
  padding:clamp(72px,8vw,120px) 0 clamp(74px,9vw,130px);
  background:
    radial-gradient(circle at 92% 18%, rgba(32,197,164,.13), transparent 360px),
    linear-gradient(180deg,#fff 0%,#fbfdfc 68%,#f4f8f7 100%);
}
.hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.78) 46%,rgba(255,255,255,0) 100%);
  pointer-events:none;
}
.hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(360px,.82fr);
  gap:clamp(48px,7vw,96px);
  align-items:center;
}
.hero-lead{
  max-width:680px;
  color:#637081;
  font-size:clamp(1.08rem,1.6vw,1.27rem);
  line-height:1.76;
  margin-bottom:28px;
}
.trust-row{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  max-width:720px;
  margin:0 0 28px;
}
.trust-row div{
  background:rgba(255,255,255,.86);
  border:1px solid var(--line);
  border-radius:18px;
  padding:16px 18px;
  box-shadow:0 10px 30px rgba(28,38,48,.055);
}
.trust-row strong{
  display:block;
  color:var(--green);
  font-size:1.18rem;
  line-height:1.1;
  letter-spacing:-.03em;
}
.trust-row span{
  display:block;
  color:#4d5a68;
  font-size:.91rem;
  margin-top:4px;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px}
.btn{
  min-height:54px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:999px;
  padding:14px 22px;
  font-weight:760;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{
  color:#fff;
  background:var(--green);
  box-shadow:0 18px 34px rgba(0,107,93,.22);
}
.btn-primary:hover{background:var(--green-dark)}
.btn-secondary{
  color:var(--green);
  background:#fff;
  border:1.5px solid rgba(0,107,93,.35);
}
.btn-secondary:hover{border-color:var(--green);box-shadow:0 12px 24px rgba(0,107,93,.08)}
.btn-light{background:#fff;color:var(--green);box-shadow:0 18px 36px rgba(0,0,0,.14)}

.hero-card{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:18px;
  width:100%;
  max-width:460px;
  margin-left:auto;
  padding:10px 18px 14px 0;
}
.hero-card:before{
  content:"";
  position:absolute;
  z-index:0;
  width:82%;
  height:84%;
  right:0;
  top:20px;
  border-radius:40px;
  background:linear-gradient(160deg,rgba(33,197,164,.14),rgba(0,107,93,.04));
}
.portrait-shell{
  position:relative;
  z-index:1;
  width:min(100%,392px);
  aspect-ratio:1/1;
  border-radius:32px;
  overflow:hidden;
  background:#eaf5f2;
  border:1px solid rgba(0,107,93,.10);
  box-shadow:var(--shadow);
}
.portrait-shell img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
}
.doctor-card{
  z-index:2;
  position:relative;
  width:min(92%,360px);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-left:10px;
  padding:18px 18px 18px 20px;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(228,236,233,.9);
  border-radius:22px;
  box-shadow:0 24px 50px rgba(19,42,47,.12);
  backdrop-filter:blur(16px);
}
.doctor-card span{
  display:block;
  color:#21a88d;
  font-size:.76rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-weight:780;
}
.doctor-card strong{
  display:block;
  color:var(--green-dark);
  font-size:1.03rem;
  line-height:1.25;
  margin-top:2px;
}
.doctor-card em{
  display:block;
  font-style:normal;
  color:var(--muted);
  font-size:.9rem;
  margin-top:5px;
}
.doctor-card b{
  flex:0 0 64px;
  height:64px;
  display:grid;
  place-items:center;
  border-radius:20px;
  background:var(--green);
  color:#fff;
  font-size:1.28rem;
  box-shadow:0 12px 28px rgba(0,107,93,.24);
}

.section-soft{background:var(--bg-soft)}
.section-head{
  max-width:820px;
  margin-bottom:34px;
}
.section-head p:last-child{
  max-width:720px;
  font-size:1.12rem;
  line-height:1.72;
}
.card-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.info-card{
  background:#fff;
  border:1px solid rgba(28,38,48,.075);
  border-radius:26px;
  padding:28px;
  box-shadow:var(--shadow-soft);
  min-height:245px;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.info-card:hover{
  transform:translateY(-4px);
  border-color:rgba(0,107,93,.20);
  box-shadow:0 20px 48px rgba(19,42,47,.10);
}
.card-icon{
  width:48px;height:48px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:var(--mint-2);
  color:var(--green);
  font-weight:800;
  font-size:1.25rem;
  margin-bottom:28px;
}
.info-card p{line-height:1.68;margin:0}
.accent-card{
  background:linear-gradient(180deg,#ffffff 0%,#f5fbf9 100%);
  border-color:rgba(0,107,93,.18);
}

.split{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(320px,.86fr);
  gap:clamp(36px,7vw,86px);
  align-items:center;
}
.split.reverse{grid-template-columns:minmax(320px,.86fr) minmax(0,.92fr)}
.split-copy p{font-size:1.12rem;line-height:1.76;max-width:620px}
.steps{
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  padding:16px;
  box-shadow:var(--shadow-soft);
  display:grid;
  gap:10px;
}
.steps div{
  display:flex;
  align-items:center;
  gap:16px;
  padding:18px;
  border-radius:20px;
  background:#f8fbfa;
}
.steps span{
  width:38px;height:38px;
  flex:0 0 38px;
  border-radius:14px;
  background:var(--green);
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:800;
}
.steps strong{font-size:1.02rem;color:#1f2d38}

.section-green{
  background:
    radial-gradient(circle at 88% 12%, rgba(33,197,164,.16), transparent 360px),
    linear-gradient(135deg,var(--green-dark),var(--green));
  color:#fff;
}
.section-green h2,.section-green .kicker{color:#fff}
.section-green p{color:rgba(255,255,255,.78)}
.procedure-card{
  background:rgba(255,255,255,.98);
  border-radius:30px;
  padding:32px;
  box-shadow:0 26px 60px rgba(0,0,0,.18);
}
.procedure-card h2{font-size:clamp(1.8rem,3vw,2.65rem);color:var(--green-dark)}
.procedure-card p{color:#596878}
.procedure-card ul{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  padding:0;
  margin:24px 0 0;
  list-style:none;
}
.procedure-card li{
  padding:11px 13px;
  border-radius:14px;
  background:var(--mint-2);
  color:var(--green-dark);
  font-weight:700;
  font-size:.96rem;
}
.light p{color:rgba(255,255,255,.8)}


.about-doctor-card{
  display:grid;
  grid-template-columns:minmax(240px,.72fr) minmax(0,1.15fr);
  gap:clamp(24px,5vw,64px);
  align-items:start;
  border:1px solid rgba(28,38,48,.075);
  border-radius:32px;
  background:#fff;
  padding:clamp(28px,5vw,46px);
  box-shadow:var(--shadow-soft);
}
.about-doctor-card h2{
  font-size:clamp(1.8rem,3.2vw,3rem);
  margin-bottom:0;
}
.about-doctor-card > p{
  font-size:1.12rem;
  line-height:1.78;
  margin:0;
  color:#455463;
}

.safety-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
  padding:36px;
  border:1px solid var(--line);
  border-radius:32px;
  background:#fff;
  box-shadow:var(--shadow-soft);
}
.safety-card div{max-width:760px}
.safety-card h2{font-size:clamp(1.9rem,3.6vw,3.15rem)}
.safety-card p{font-size:1.1rem;line-height:1.78;margin-bottom:0}

.final-cta{
  padding:clamp(72px,9vw,120px) 0;
  background:linear-gradient(135deg,#f2faf7 0%,#ffffff 100%);
}
.final-box{
  text-align:center;
  border-radius:34px;
  background:var(--green);
  padding:clamp(38px,7vw,76px);
  color:#fff;
  box-shadow:var(--shadow);
  background:
    radial-gradient(circle at 12% 10%,rgba(255,255,255,.18),transparent 260px),
    linear-gradient(135deg,var(--green-dark),var(--green));
}
.final-box h2{
  max-width:900px;
  margin:0 auto 28px;
  color:#fff;
  font-size:clamp(2rem,4vw,3.6rem);
}
.final-box .kicker{color:#fff;justify-content:center}
.site-footer{
  padding:36px 0;
  background:#fff;
  border-top:1px solid var(--line);
}
.footer-grid{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:28px;
}
.site-footer strong{display:block;color:var(--green-dark);font-size:1.15rem}
.site-footer p{margin:.25rem 0 0;font-size:.92rem}
.site-footer a{color:var(--green);font-weight:760}

@media (max-width: 980px){
  .header-inner{min-height:70px}
  .site-nav{
    position:fixed;
    left:16px;right:16px;top:78px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:4px;
    padding:14px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:22px;
    box-shadow:var(--shadow);
  }
  .site-nav.is-open{display:flex}
  .site-nav a{padding:13px 14px}
  .nav-cta{margin-left:0;text-align:center}
  .nav-toggle{display:block}
  .hero-grid,.split,.split.reverse{grid-template-columns:1fr}
  .hero{padding-top:58px}
  .hero:before{display:none}
  .hero-card{max-width:430px;margin-inline:auto;align-items:center;padding:0}
  .hero-card:before{width:78%;height:80%;right:0;top:16px}
  .portrait-shell{width:min(100%,350px)}
  .doctor-card{width:min(100%,330px);margin-left:0}
  .card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  
.safety-card{align-items:flex-start;flex-direction:column}
}

@media (max-width: 640px){
  .container{width:min(calc(100% - 34px),var(--container))}
  .section{padding:64px 0}
  .brand-mark{width:34px;height:34px;border-radius:12px}.brand-heart{width:21px;height:21px}
  .brand-name{font-size:1.12rem}
  .brand-line{font-size:.78rem}
  h1{font-size:clamp(2.7rem,14vw,4.2rem);letter-spacing:-.06em}
  .hero-lead{font-size:1.05rem;line-height:1.68}
  .trust-row{grid-template-columns:1fr}
  .hero-actions{display:grid}
  .btn{width:100%}
  .hero-card{max-width:360px}
  .portrait-shell{width:min(100%,312px);border-radius:26px}
  .doctor-card{width:min(100%,312px);border-radius:20px;padding:16px}
  .doctor-card b{width:58px;height:58px;flex-basis:58px}
  .card-grid{grid-template-columns:1fr}
  .info-card{min-height:auto;padding:24px}
  .procedure-card ul{grid-template-columns:1fr}

  .about-doctor-card{grid-template-columns:1fr;padding:26px}
  .about-doctor-card > p{font-size:1.04rem;line-height:1.7}
  .footer-grid{display:grid}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .btn,.info-card,.site-nav a{transition:none}
}
