:root{
  --verde-oscuro:#063f15;
  --verde:#168233;
  --verde-claro:#e8f8e8;
  --verde-suave:#f5fff5;
  --texto:#172018;
  --gris:#647066;
  --blanco:#ffffff;
  --sombra:0 22px 60px rgba(6,63,21,.14);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Arial,Helvetica,sans-serif;background:#fff;color:var(--texto);overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.header{min-height:100vh;background:radial-gradient(circle at 12% 18%,#dff6dc 0,transparent 32%),radial-gradient(circle at 88% 12%,#eefbec 0,transparent 30%),linear-gradient(180deg,#fff,#fafffa)}
.nav{position:fixed;top:0;left:0;width:100%;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:14px 7%;background:rgba(255,255,255,.95);border-bottom:1px solid rgba(22,130,51,.16);box-shadow:0 8px 24px rgba(6,63,21,.06)}
.brand{display:flex;align-items:center;gap:12px;font-weight:900;color:var(--verde-oscuro);font-size:1.35rem}
.brand img{width:56px;height:56px;object-fit:contain;border-radius:50%;background:#eefbec}
.menu{display:flex;gap:24px;font-weight:800;color:var(--verde-oscuro)}
.menu a{padding:8px 0;border-bottom:3px solid transparent;transition:.25s}
.menu a:hover{border-color:var(--verde)}
.menu-btn{display:none;background:var(--verde-oscuro);color:#fff;border:0;border-radius:12px;font-size:1.5rem;padding:8px 12px}
.hero{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;gap:42px;align-items:center;padding:135px 7% 80px}
.tag{display:inline-block;text-transform:uppercase;letter-spacing:2px;color:var(--verde);font-weight:900;font-size:.84rem;margin-bottom:14px}.tag.light{color:#caffc9}
.hero h1{font-size:clamp(3.6rem,9vw,7.3rem);line-height:.88;color:var(--verde-oscuro);letter-spacing:-4px;text-transform:lowercase}
.hero h2{font-size:clamp(1.45rem,3vw,2.9rem);line-height:1.08;margin:18px 0;color:#0b2f12;max-width:840px}
.hero p{font-size:1.32rem;color:var(--gris);font-weight:700;margin-bottom:28px}
.actions{display:flex;flex-wrap:wrap;gap:14px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:15px 24px;border-radius:999px;font-weight:900;transition:.25s;border:2px solid transparent;box-shadow:0 12px 26px rgba(6,63,21,.1)}.primary{background:linear-gradient(135deg,var(--verde-oscuro),var(--verde));color:white}.secondary{background:white;color:var(--verde-oscuro);border-color:rgba(22,130,51,.24)}.btn:hover{transform:translateY(-3px);box-shadow:0 18px 35px rgba(6,63,21,.16)}
.hero-logo{background:white;border-radius:42px;padding:28px;box-shadow:var(--sombra);border:1px solid rgba(22,130,51,.14)}.hero-logo img{border-radius:30px;width:100%;height:auto;object-fit:contain;background:#f5fff5}
.section{padding:88px 7%}.title{text-align:center;max-width:880px;margin:0 auto 42px}.title h2,.treatment-card h2,.contact-card h2{font-size:clamp(2rem,4vw,4rem);color:var(--verde-oscuro);line-height:1.05;margin-bottom:14px}.title p{font-size:1.12rem;color:var(--gris);line-height:1.7}.image-card{max-width:1160px;margin:auto;background:white;border-radius:30px;box-shadow:var(--sombra);border:1px solid rgba(22,130,51,.14);padding:16px;overflow:hidden}.image-card img{width:100%;height:auto;object-fit:contain;border-radius:22px;background:#fafffa}
.info{background:linear-gradient(180deg,#f8fff8,#fff)}.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:1200px;margin:auto}.grid article{min-height:126px;background:white;border:1px solid rgba(22,130,51,.14);border-radius:22px;padding:22px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 12px 30px rgba(6,63,21,.08);position:relative;overflow:hidden}.grid article:after{content:"";position:absolute;right:-42px;top:-42px;width:98px;height:98px;border-radius:50%;background:var(--verde-claro)}.grid strong{color:var(--verde);position:relative;z-index:1}.grid span{font-size:1.08rem;font-weight:900;line-height:1.25;position:relative;z-index:1}.grid .wide{grid-column:span 2}
.treatment-card{max-width:1100px;margin:auto;border-radius:42px;padding:52px;background:linear-gradient(135deg,var(--verde-oscuro),#0d6b27);color:white;box-shadow:var(--sombra);position:relative;overflow:hidden}.treatment-card:after{content:"";position:absolute;right:-80px;bottom:-90px;width:260px;height:260px;border:35px solid rgba(255,255,255,.12);border-radius:50%}.treatment-card h2{color:white}.treatment-card p{font-size:1.35rem;line-height:1.6;max-width:850px;position:relative;z-index:1}
.contact{background:linear-gradient(180deg,#fff,#f4fcf3)}.contact-card{max-width:1080px;margin:auto;background:white;border-radius:42px;padding:36px;display:grid;grid-template-columns:280px 1fr;gap:36px;align-items:center;box-shadow:var(--sombra);border:1px solid rgba(22,130,51,.14)}.contact-card img{border-radius:28px;background:#eefbec}.phone{font-size:clamp(1.8rem,4vw,3.2rem);font-weight:900;color:var(--verde-oscuro);margin:8px 0}.float{position:fixed;right:22px;bottom:22px;width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#11a33c,#0b681f);color:white;display:grid;place-items:center;font-size:2rem;font-weight:900;z-index:20;box-shadow:0 18px 35px rgba(6,63,21,.28)}footer{background:var(--verde-oscuro);color:white;text-align:center;padding:42px 7%}footer img{width:92px;height:92px;object-fit:contain;border-radius:50%;margin:0 auto 12px;background:white}footer p{margin:8px 0;color:rgba(255,255,255,.9)}
@media(max-width:960px){.hero{grid-template-columns:1fr;text-align:center}.actions{justify-content:center}.grid{grid-template-columns:repeat(2,1fr)}.contact-card{grid-template-columns:1fr;text-align:center}.contact-card img{max-width:280px;margin:auto}}
@media(max-width:720px){.nav{padding:12px 5%}.brand span{font-size:1.08rem}.brand img{width:46px;height:46px}.menu-btn{display:block}.menu{display:none;position:absolute;top:74px;left:5%;right:5%;background:white;border:1px solid rgba(22,130,51,.14);border-radius:22px;padding:18px;box-shadow:var(--sombra);flex-direction:column;text-align:center}.menu.open{display:flex}.hero{padding:122px 5% 70px}.hero h1{letter-spacing:-2px}.section{padding:70px 5%}.grid{grid-template-columns:1fr}.grid .wide{grid-column:span 1}.treatment-card,.contact-card{padding:28px;border-radius:28px}.float{width:58px;height:58px;right:16px;bottom:16px}}
