
:root{
  --brand:#34AC9C;        /* teal del logo */
  --brand-deep:#1B7468;   /* teal oscuro */
  --accent:#90D8D0;       /* mint del logo */
  --bg:#FFFFFF; --bg-soft:#F2F7F5; --bg-mint:#E7F1EE;
  --ink:#15211E; --ink-soft:#33433F; --muted:#647470;
  --line:rgba(15,79,73,.14);
  --display:'Poppins',-apple-system,Segoe UI,sans-serif;
  --sans:'Mulish',-apple-system,Segoe UI,sans-serif;
  --maxw:1180px; --r:18px; --shadow:0 18px 50px -24px rgba(15,79,73,.30);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
h1,h2,h3,h4,h5{font-family:var(--display);font-weight:600;letter-spacing:-.02em;line-height:1.1}
.eyebrow{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--brand);font-weight:700}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;font-size:15px;padding:13px 24px;border-radius:999px;transition:.2s;cursor:pointer;border:none}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 10px 24px -10px var(--brand)}
.btn-primary:hover{background:var(--brand-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand)}
.btn-wa{background:#25D366;color:#0a3d22}
.btn-wa:hover{filter:brightness(1.05);transform:translateY(-2px)}

.util{background:var(--brand-deep);color:#dcefe8;font-size:13.5px}
.util .wrap{display:flex;justify-content:space-between;align-items:center;height:42px;gap:18px}
.util a{display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.util a:hover{color:#fff}.util .left{display:flex;gap:22px;overflow:hidden}
.util svg{width:14px;height:14px;flex:none}.util .urg{color:#bdeede;font-weight:700}
@media(max-width:760px){.util .left a:not(.tel){display:none}}

header.top{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:.25s}
header.top.shrink{box-shadow:0 8px 30px -20px rgba(15,79,73,.4)}
header.top .wrap{display:flex;align-items:center;gap:24px;height:82px;transition:.25s}
header.top.shrink .wrap{height:64px}
.logo img{height:50px;width:auto;transition:.25s}header.top.shrink .logo img{height:40px}
.logo .fallback{font-family:var(--display);font-weight:700;font-size:20px;color:var(--brand-deep);line-height:1}
.logo .fallback small{display:block;font-size:9.5px;letter-spacing:.2em;color:var(--muted);font-weight:700}
nav.main{display:flex;gap:4px;margin-left:auto}
nav.main a{font-family:var(--display);font-weight:500;font-size:14.5px;color:var(--ink-soft);padding:10px 13px;border-radius:8px;transition:.18s}
nav.main a:hover{color:var(--brand);background:var(--bg-soft)}
header .cta{margin-left:8px}
.burger{display:none;margin-left:auto;background:none;border:none;cursor:pointer;padding:8px}
.burger span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0}
@media(max-width:960px){nav.main,header .cta.desk{display:none}.burger{display:block}}
.mobile-menu{display:none;flex-direction:column;padding:14px 26px 24px;border-bottom:1px solid var(--line);background:#fff}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:13px 0;font-family:var(--display);font-weight:600;border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:16px;justify-content:center}

.hero{position:relative;overflow:hidden;background:radial-gradient(120% 120% at 85% -10%,var(--bg-mint),transparent 55%),var(--bg)}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;padding:72px 26px 82px}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(38px,5.6vw,62px);line-height:1.07;margin:18px 0 22px}
.hero h1 em{font-style:normal;color:var(--brand)}
.hero p.lead{font-size:19px;color:var(--ink-soft);max-width:46ch;margin-bottom:32px}
.hero .actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-media{position:relative}
.hero-media .ph{aspect-ratio:4/5;border-radius:26px;overflow:hidden;background:linear-gradient(135deg,var(--brand),var(--brand-deep));box-shadow:var(--shadow)}
.hero-media .ph img{width:100%;height:100%;object-fit:cover}
.hero-media .float{position:absolute;left:-26px;bottom:38px;background:#fff;border-radius:16px;padding:16px 20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:13px;max-width:250px}
.hero-media .float .ring{width:44px;height:44px;border-radius:50%;background:var(--bg-mint);display:flex;align-items:center;justify-content:center;color:var(--brand);flex:none}
.hero-media .float b{font-family:var(--display);font-size:16px}.hero-media .float span{font-size:12.5px;color:var(--muted);display:block}
@media(max-width:860px){.hero .wrap{grid-template-columns:1fr;gap:34px;padding:46px 26px 56px}.hero-media{max-width:400px;margin:0 auto}.hero-media .float{left:0}}

.trust{background:var(--brand-deep);color:#eafaf4}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;padding:32px 26px}
.trust .item{display:flex;gap:13px;align-items:flex-start}
.trust .item svg{width:25px;height:25px;color:var(--accent);flex:none;margin-top:2px}
.trust .item b{display:block;font-family:var(--display);font-size:17px}.trust .item span{font-size:13px;color:#bfe4d8;line-height:1.4}
@media(max-width:820px){.trust .wrap{grid-template-columns:repeat(2,1fr);gap:22px}}

section.block{padding:80px 0}
.head{text-align:center;max-width:640px;margin:0 auto 46px}
.head h2{font-size:clamp(30px,4.2vw,46px);margin:12px 0 14px}
.head p{color:var(--muted);font-size:17px}

#especialidades{background:var(--bg-soft)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc{display:block;background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:0 10px 30px -22px rgba(15,79,73,.4);transition:.25s;border:1px solid transparent;color:inherit}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line)}
.svc .pic{aspect-ratio:16/11;overflow:hidden;background:var(--bg-mint);position:relative}
.svc .pic img{width:100%;height:100%;object-fit:cover;transition:.6s}.svc:hover .pic img{transform:scale(1.06)}
.imgfb{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:46px;background:var(--bg-mint)}
.svc .body{padding:20px 22px 22px}
.svc h3{font-size:20px;margin-bottom:8px}
.svc p{font-size:14.5px;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.svc .more{margin-top:14px;font-size:13.5px;font-weight:700;color:var(--brand);display:inline-flex;align-items:center;gap:6px}
@media(max-width:880px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr}}

.about .wrap{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.about .txt h2{font-size:clamp(28px,3.8vw,42px);margin:12px 0 18px}
.about .txt p{color:var(--ink-soft);font-size:16.5px;margin-bottom:16px}
.about .imgcol{aspect-ratio:1;border-radius:var(--r);overflow:hidden;background:linear-gradient(135deg,var(--brand),var(--brand-deep));box-shadow:var(--shadow)}
.about .imgcol img{width:100%;height:100%;object-fit:cover}
@media(max-width:820px){.about .wrap{grid-template-columns:1fr;gap:28px}}

.team{background:var(--bg-mint)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.doc{display:block;background:#fff;border-radius:var(--r);padding:26px 20px;text-align:center;box-shadow:0 10px 30px -24px rgba(15,79,73,.4);transition:.22s;color:inherit;cursor:pointer}
.doc:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.doc .av{width:104px;height:104px;border-radius:50%;margin:0 auto 16px;overflow:hidden;background:var(--brand);border:3px solid var(--bg-mint)}
.doc .av img{width:100%;height:100%;object-fit:cover}
.doc h4{font-size:18px}.doc .role{color:var(--brand);font-weight:700;font-size:12.5px;margin:5px 0 7px;text-transform:uppercase;letter-spacing:.05em}
.doc .col{color:var(--muted);font-size:12.5px}
.doc .more{margin-top:12px;font-size:12.5px;font-weight:700;color:var(--brand)}
.aux{text-align:center;margin-top:34px;color:var(--muted);font-size:14.5px}.aux b{color:var(--ink)}
@media(max-width:820px){.team-grid{grid-template-columns:repeat(2,1fr)}}

.band{background:linear-gradient(120deg,var(--brand-deep),var(--brand));color:#fff;text-align:center}
.band .wrap{padding:66px 26px}
.band h2{font-size:clamp(28px,4vw,44px);margin-bottom:14px}
.band p{color:#cdeee3;font-size:18px;max-width:50ch;margin:0 auto 28px}
.band .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.band .btn-ghost{color:#fff;border-color:rgba(255,255,255,.5)}.band .btn-ghost:hover{background:rgba(255,255,255,.12);color:#fff}

.contact .wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:44px;align-items:start}
.cinfo h2{font-size:clamp(28px,3.6vw,40px);margin:12px 0 22px}
.cline{display:flex;gap:15px;align-items:flex-start;padding:15px 0;border-bottom:1px solid var(--line)}
.cline svg{width:21px;height:21px;color:var(--brand);flex:none;margin-top:3px}
.cline b{display:block;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:3px;font-family:var(--display);font-weight:600}
.cline a,.cline span{font-size:16.5px;font-weight:600}
.hours{margin-top:8px}
.hours .row{display:flex;justify-content:space-between;padding:7px 0;font-size:14.5px;border-bottom:1px dashed var(--line)}
.hours .row span:first-child{font-weight:700;font-family:var(--display)}
.hours .row.closed span:last-child{color:#b46;font-weight:600}
.map{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);min-height:520px;border:1px solid var(--line)}
.map iframe{width:100%;height:100%;min-height:520px;border:0;display:block}
.contact .actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
@media(max-width:820px){.contact .wrap{grid-template-columns:1fr;gap:28px}.map,.map iframe{min-height:360px}}

footer{background:var(--ink);color:#c9d6d2;padding:54px 0 30px;font-size:14px}
footer .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
footer .logo .fallback{color:#fff}
footer img{height:46px;opacity:.95;margin-bottom:14px}
footer h5{color:#fff;font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:14px}
footer a{display:block;margin-bottom:9px;color:#b3c3bf}footer a:hover{color:#fff}
footer .legal{margin-top:40px;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#8aa09a;font-size:12.5px}
@media(max-width:760px){footer .grid{grid-template-columns:1fr;gap:26px}}

/* MODALES con :target (funcionan sin JS) */
.modal{position:fixed;inset:0;z-index:200;background:rgba(15,40,36,.5);backdrop-filter:blur(5px);display:none;align-items:flex-start;justify-content:center;overflow-y:auto;padding:5vh 16px}
.modal:target{display:flex}
.modal .box{background:#fff;max-width:620px;width:100%;border-radius:22px;overflow:hidden;box-shadow:0 40px 90px -30px rgba(0,0,0,.5);margin:auto;animation:pop .35s cubic-bezier(.2,.8,.2,1)}
@keyframes pop{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.modal .mhead{position:relative;aspect-ratio:16/9;background:var(--bg-mint);overflow:hidden}
.modal .mhead img{width:100%;height:100%;object-fit:cover}
.modal .x{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--ink);box-shadow:0 4px 14px rgba(0,0,0,.2)}
.modal .x:hover{background:#fff;color:var(--brand)}
.modal .mbody{padding:28px 30px 32px}
.modal .mbody h3{font-size:26px;margin-bottom:14px}
.modal .mbody p{color:var(--ink-soft);font-size:16px;margin-bottom:12px}
.modal .mbody ul{list-style:none;margin-top:6px}
.modal .mbody li{position:relative;padding-left:24px;margin-bottom:11px;color:var(--ink-soft);font-size:15.5px}
.modal .mbody li::before{content:"";position:absolute;left:0;top:8px;width:9px;height:9px;border-radius:50%;background:var(--brand)}
.modal .mrole{color:var(--brand);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.06em}
.modal .mcol{color:var(--muted);font-size:13.5px;margin:2px 0 16px}
.modal .docphoto{width:118px;height:118px;border-radius:50%;object-fit:cover;border:4px solid var(--bg-mint);margin:-66px auto 14px;position:relative;display:block;box-shadow:0 10px 26px -12px rgba(0,0,0,.4)}
.modal .mbody.team{text-align:center}
.modal .mbody.team ul{text-align:left;margin-top:14px;border-top:1px solid var(--line);padding-top:16px}
.modal .mact{margin-top:20px}

.reveal{transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
html.js-anim .reveal.pre{opacity:0;transform:translateY(22px)}
.reveal.in{opacity:1;transform:none}

.instal{background:var(--bg-soft)}
.feats{display:flex;flex-wrap:wrap;gap:13px;justify-content:center;margin-bottom:40px}
.feat{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);padding:11px 18px;border-radius:999px;font-family:var(--display);font-weight:600;font-size:14.5px}
.feat svg{width:18px;height:18px;color:var(--brand);flex:none}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:165px;gap:14px}
.gallery a{overflow:hidden;border-radius:14px;background:var(--bg-mint);display:block}
.gallery a:first-child{grid-column:span 2;grid-row:span 2}
.gallery img{width:100%;height:100%;object-fit:cover;transition:.6s}
.gallery a:hover img{transform:scale(1.06)}
.gallery .imgfb{font-size:34px}
@media(max-width:700px){.gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}.gallery a:first-child{grid-column:span 2;grid-row:span 1}}
.lb{align-items:center;justify-content:center;padding:4vh 4vw}
.lb img{max-width:92vw;max-height:88vh;border-radius:12px;box-shadow:0 30px 90px rgba(0,0,0,.55)}
.lbclose{position:fixed;top:18px;right:22px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--ink);z-index:210}
.lbclose:hover{background:#fff;color:var(--brand)}

/* --- páginas legales --- */
.legalpage{max-width:820px;margin:0 auto;padding:150px 24px 90px}
.legalpage h1{font-family:var(--display);font-size:2.1rem;color:var(--ink);margin-bottom:6px;letter-spacing:-.5px}
.legalpage .sub{color:#8a9690;margin-bottom:36px}
.legalpage h2{font-family:var(--display);font-size:1.25rem;color:var(--brand-d);margin:34px 0 10px}
.legalpage p,.legalpage li{color:#46524f;line-height:1.75;margin-bottom:10px}
.legalpage ul{padding-left:20px;margin-bottom:12px}
.legalpage a{color:var(--brand-d);text-decoration:underline}
.legalpage .note{background:var(--soft);border-left:3px solid var(--brand);padding:14px 18px;border-radius:8px;color:#46524f;font-size:.92rem;margin:18px 0}
footer .legal a{color:inherit;text-decoration:underline;opacity:.85}
