
:root{
  --navy:#0A1923;
  --navy2:#062B3A;
  --teal:#00B2B3;
  --coral:#FF4D4F;
  --gray:#E6ECEF;
  --bg:#F7FAFB;
  --white:#FFFFFF;
  --text:#12222D;
  --muted:#5B6870;
  --line:rgba(10,25,35,.10);
  --shadow:0 18px 46px rgba(10,25,35,.10);
  --soft:0 10px 26px rgba(10,25,35,.06);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Lato',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(1160px,calc(100% - 44px));margin:0 auto}
.skip-link{position:absolute;left:-999px;top:12px;background:#fff;color:var(--navy);padding:10px 14px;border-radius:12px;font-weight:900;z-index:999}
.skip-link:focus{left:16px;outline:3px solid rgba(0,178,179,.45)}
.topbar{
  position:sticky;top:0;z-index:40;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(230,236,239,.95);
}
.nav{height:78px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;min-width:0}
.brand-logo{
  height:54px!important;
  width:auto!important;
  max-width:250px!important;
  object-fit:contain!important;
}
.menu{display:flex;gap:22px;align-items:center;font-weight:900;font-size:.92rem;color:#273743}
.menu a:hover{color:var(--teal)}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  min-height:50px;
  padding:13px 20px;
  border-radius:17px;
  background:var(--teal);
  color:#fff;
  font-family:'Montserrat',sans-serif;
  font-weight:900;
  box-shadow:0 12px 26px rgba(0,178,179,.22);
  transition:.2s ease;
}
.btn:hover{transform:translateY(-2px);background:#009a9b}
.btn.dark{background:var(--navy)}
.btn.light{background:#fff;color:var(--navy);border:2px solid var(--navy);box-shadow:none}
.btn:focus-visible,.menu a:focus-visible,.tag:focus-visible{outline:3px solid rgba(0,178,179,.45);outline-offset:4px}
.floating-wa{
  position:fixed;right:18px;bottom:18px;z-index:50;
  background:#25D366;color:#fff;border-radius:999px;
  padding:14px 18px;
  font-family:'Montserrat',sans-serif;font-weight:900;
  box-shadow:0 12px 30px rgba(0,0,0,.22);
}
section{padding:78px 0}
.hero{
  position:relative;overflow:hidden;background:#fff;
}
.hero:before{content:"";position:absolute;right:-180px;top:-160px;width:460px;height:460px;border-radius:50%;background:rgba(0,178,179,.10)}
.hero:after{content:"";position:absolute;left:-220px;bottom:-260px;width:540px;height:540px;border-radius:50%;background:rgba(255,77,79,.08)}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;gap:38px;align-items:center;padding:72px 0}
.kicker,.eyebrow{
  font-family:'Montserrat',sans-serif;
  color:var(--teal);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.20em;
  font-size:.78rem;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(230,236,239,.72);
  border:1px solid rgba(0,178,179,.24);
  color:var(--navy2);
  border-radius:999px;
  padding:10px 14px;
  letter-spacing:.04em;
  text-transform:none;
}
.dot{width:9px;height:9px;background:var(--teal);border-radius:50%}
h1,h2,h3{font-family:'Montserrat',sans-serif;margin:0;color:var(--navy);letter-spacing:-.04em}
h1{font-size:clamp(2.35rem,5.4vw,4.75rem);line-height:1.02;margin:20px 0 0;font-weight:900}
h2{font-size:clamp(1.95rem,3.6vw,3rem);line-height:1.08;font-weight:900}
h3{font-size:1.28rem;line-height:1.18}
.accent{color:var(--teal)}
.lead{font-size:1.18rem;color:var(--muted);line-height:1.78;max-width:720px;margin:22px 0 0}
.actions{display:flex;flex-wrap:wrap;gap:13px;margin-top:28px}
.hero-card{
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  color:#fff;
  border-radius:34px;
  padding:28px;
  box-shadow:var(--shadow);
}
.hero-card h2{color:#fff;font-size:1.55rem;margin-top:12px}
.hero-card p{color:rgba(255,255,255,.82)}
.hero-services{display:grid;gap:11px;margin-top:22px}
.hero-service{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  padding:13px 14px;
  display:flex;gap:12px;align-items:center;
  font-weight:900;
}
.icon{
  width:42px;height:42px;border-radius:14px;
  background:var(--teal);color:#fff;
  display:grid;place-items:center;
  font-size:1.28rem;flex:0 0 auto;
}
.section-title{text-align:center;max-width:820px;margin:0 auto 42px}
.section-title p{color:var(--muted);font-size:1.08rem;line-height:1.76;margin:14px 0 0}
.about-wrap{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:24px;
  align-items:stretch;
}
.about-intro{
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  color:#fff;
  border-radius:34px;
  padding:32px;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}
.about-intro:before{content:"";position:absolute;right:-80px;top:-80px;width:220px;height:220px;border-radius:50%;background:rgba(0,178,179,.22)}
.about-intro .kicker{color:var(--teal)}
.about-intro h2{color:#fff;margin-top:10px}
.about-intro p{color:rgba(255,255,255,.84);line-height:1.78}
.about-badge{
  margin-top:24px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  border-radius:24px;
  padding:18px;
}
.about-badge strong{display:block;font-family:'Montserrat',sans-serif;font-size:1.42rem;color:#fff}
.about-badge span{display:block;color:rgba(255,255,255,.78);font-weight:900}
.about-detail{
  background:#fff;border:1px solid rgba(230,236,239,.95);
  border-radius:34px;padding:32px;box-shadow:var(--soft);
}
.about-detail p{color:var(--muted);line-height:1.78}
.about-detail .lead-strong{color:var(--text);font-weight:900;font-size:1.08rem}
.about-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:22px 0}
.metric{background:#F7FAFB;border:1px solid rgba(0,178,179,.18);border-radius:20px;padding:16px}
.metric strong{display:block;font-family:'Montserrat',sans-serif;color:var(--navy)}
.metric span{color:var(--muted);font-weight:700;font-size:.92rem}
.credentials{display:grid;gap:10px;margin-top:18px}
.credential{background:rgba(230,236,239,.64);border-radius:18px;padding:14px 16px;display:grid;gap:3px}
.credential strong{font-family:'Montserrat',sans-serif;color:var(--navy)}
.credential span{color:var(--muted);font-weight:700}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{
  background:#fff;border:1px solid rgba(230,236,239,.95);
  border-radius:28px;padding:25px;
  box-shadow:var(--soft);
  transition:.2s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:rgba(0,178,179,.24)}
.card h3{margin:16px 0 9px}
.card p{color:var(--muted);line-height:1.72;margin:0}
.clinical{
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  color:#fff;border-radius:36px;padding:38px;
  display:grid;grid-template-columns:1fr 1.25fr;gap:26px;align-items:center;
}
.clinical h2{color:#fff}
.clinical p{color:rgba(255,255,255,.82)}
.check-list{display:grid;gap:10px}
.check{
  background:rgba(255,255,255,.08);
  border-radius:16px;padding:12px 14px;
  font-weight:900;display:flex;gap:10px;
}
.check:before{content:"✓";color:var(--teal);font-weight:900}
.light-check .check{background:#fff;color:var(--navy);box-shadow:0 6px 14px rgba(10,25,35,.04)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.panel{
  border-radius:32px;padding:28px;box-shadow:var(--soft);
  background:#fff;border:1px solid rgba(230,236,239,.95);
}
.panel.dark{background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff}
.panel.dark h3{color:#fff}.panel.dark p{color:rgba(255,255,255,.82)}
.panel.gray{background:var(--gray)}
.panel h3{margin:10px 0}
.panel p{color:var(--muted)}
.service-links{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.service-link{
  background:#fff;border:1px solid rgba(230,236,239,.95);
  border-radius:24px;padding:20px;box-shadow:var(--soft);
}
.service-link h3{font-size:1.16rem}
.service-link p{color:var(--muted);font-size:.98rem}
.tag{display:inline-flex;margin-top:10px;background:rgba(0,178,179,.10);color:var(--navy);border:1px solid rgba(0,178,179,.18);border-radius:999px;padding:7px 10px;font-weight:900;font-size:.82rem}
.faq{max-width:920px;margin:0 auto;display:grid;gap:13px}
.faq details{background:#fff;border:1px solid rgba(230,236,239,.95);border-radius:22px;padding:18px 20px;box-shadow:var(--soft)}
.faq summary{cursor:pointer;font-family:'Montserrat',sans-serif;font-weight:900;color:var(--navy)}
.faq p{color:var(--muted);line-height:1.75}
.location-grid{display:grid;grid-template-columns:2fr 1fr;gap:22px}
.map-card{background:var(--gray);border-radius:32px;padding:26px}
.mapbox{margin-top:16px;border-radius:24px;overflow:hidden;background:#fff;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}
iframe{width:100%;height:310px;border:0}
.reserve{background:var(--navy);color:#fff;border-radius:32px;padding:26px}
.reserve h3{color:#fff;margin-top:12px}
.reserve p{color:var(--gray)}
.contact-card{
  background:#fff;border-radius:36px;padding:40px;text-align:center;
  box-shadow:var(--shadow);border:1px solid rgba(230,236,239,.95);max-width:930px;margin:0 auto;
}
.contact-card p{color:var(--muted)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px;text-align:left}
.contact-item{background:var(--gray);border-radius:20px;padding:18px}
.contact-item strong{font-family:'Montserrat',sans-serif;color:var(--navy)}
.contact-item p{font-size:1.08rem;font-weight:900;color:var(--teal);margin:.35rem 0 0}
footer{background:var(--navy);color:#fff;padding:30px 0}
.footer-row{display:flex;align-items:center;justify-content:space-between;gap:18px}
.footer-brand strong{font-family:'Montserrat',sans-serif;display:block}
.footer-brand span{display:block;color:var(--gray);font-weight:900}
.footer-wa{color:var(--teal);font-weight:900;font-family:'Montserrat',sans-serif}
.page-hero{background:#fff;padding:60px 0;border-bottom:1px solid rgba(230,236,239,.95)}
.breadcrumb{font-weight:900;color:var(--muted);font-size:.92rem;margin-bottom:16px}
.content{max-width:900px;margin:0 auto}
.content p,.content li{color:var(--muted);line-height:1.82;font-size:1.05rem}
.content h2{margin-top:34px}
.notice{background:rgba(255,77,79,.08);border-left:4px solid var(--coral);border-radius:20px;padding:18px;margin-top:24px}
@media(max-width:980px){
  .menu{display:none}
  .hero-grid,.about-wrap,.clinical,.two-col,.location-grid{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr 1fr}
  .service-links{grid-template-columns:1fr}
  .footer-row{flex-direction:column;text-align:center}
}
@media(max-width:640px){
  .container{width:min(100% - 32px,1160px)}
  section{padding:58px 0}
  .cards,.about-metrics,.contact-grid{grid-template-columns:1fr}
  h1{font-size:2.35rem}
  .actions .btn{width:100%}
  .brand-logo{max-width:210px!important;height:auto!important}
  .floating-wa{left:14px;right:14px;text-align:center}
  .hero-card,.about-intro,.about-detail,.panel,.map-card,.reserve,.contact-card{border-radius:26px;padding:22px}
}


/* =========================================================
   SECCIÓN ÁREAS DE ATENCIÓN — versión premium final
   ========================================================= */

.areas-section{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 10% 18%, rgba(0,178,179,.12), transparent 28%),
    radial-gradient(circle at 88% 12%, rgba(255,77,79,.07), transparent 26%),
    linear-gradient(180deg,#F7FAFB 0%, #FFFFFF 100%);
}

.areas-section:before{
  content:"";
  position:absolute;
  left:50%;
  top:48px;
  width:min(920px,92%);
  height:1px;
  transform:translateX(-50%);
  background:linear-gradient(90deg,transparent,rgba(0,178,179,.34),transparent);
}

.areas-heading{
  max-width:860px;
  margin:0 auto 42px;
  text-align:center;
}

.areas-heading p{
  color:var(--muted);
  font-size:1.08rem;
  line-height:1.76;
  margin:14px 0 0;
}

.areas-premium-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  align-items:stretch;
}

.area-card{
  position:relative;
  display:flex;
  flex-direction:column;
  min-height:292px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,250,251,.98));
  border:1px solid rgba(230,236,239,.95);
  border-radius:30px;
  padding:24px;
  box-shadow:var(--soft);
  overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.area-card:before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:6px;
  background:linear-gradient(90deg,var(--teal),rgba(0,178,179,.20));
}

.area-card:after{
  content:"";
  position:absolute;
  width:150px;
  height:150px;
  right:-78px;
  top:-78px;
  border-radius:50%;
  background:rgba(0,178,179,.08);
  pointer-events:none;
}

.area-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
  border-color:rgba(0,178,179,.28);
}

.area-card-featured{
  background:
    linear-gradient(135deg,rgba(10,25,35,.98),rgba(6,43,58,.98));
  color:white;
  border-color:rgba(0,178,179,.24);
}

.area-card-featured:before{
  background:linear-gradient(90deg,var(--teal),rgba(255,255,255,.34));
}

.area-card-featured:after{
  background:rgba(255,255,255,.08);
}

.area-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:18px;
  position:relative;
  z-index:1;
}

.area-icon{
  width:46px;
  height:46px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:var(--teal);
  color:white;
  font-size:1.35rem;
  box-shadow:0 10px 22px rgba(0,178,179,.20);
}

.area-label{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(0,178,179,.10);
  color:var(--navy);
  font-family:'Montserrat',sans-serif;
  font-size:.74rem;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.area-card-featured .area-label{
  background:rgba(255,255,255,.12);
  color:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.16);
}

.area-card h3{
  position:relative;
  z-index:1;
  font-size:1.26rem;
  margin:0 0 10px;
}

.area-card-featured h3{
  color:white;
}

.area-card p{
  position:relative;
  z-index:1;
  color:var(--muted);
  line-height:1.68;
  margin:0;
  flex:1;
}

.area-card-featured p{
  color:rgba(255,255,255,.82);
}

.area-cta{
  position:relative;
  z-index:1;
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:20px;
  color:var(--navy);
  font-family:'Montserrat',sans-serif;
  font-weight:900;
}

.area-cta:after{
  content:"→";
  color:var(--teal);
  transition:transform .2s ease;
}

.area-card:hover .area-cta:after{
  transform:translateX(3px);
}

.area-card-featured .area-cta{
  color:white;
}

@media(max-width:980px){
  .areas-premium-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:640px){
  .areas-premium-grid{
    grid-template-columns:1fr;
  }

  .area-card{
    min-height:auto;
  }
}


/* =========================================================
   FORMULARIO DE CONTACTO — versión clínica premium
   ========================================================= */

.contact-form-section{
  background:
    radial-gradient(circle at 12% 18%, rgba(0,178,179,.11), transparent 28%),
    radial-gradient(circle at 88% 14%, rgba(255,77,79,.06), transparent 24%),
    linear-gradient(180deg,#FFFFFF 0%, #F7FAFB 100%);
}

.form-layout{
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:26px;
  align-items:stretch;
}

.form-copy{
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  color:white;
  border-radius:34px;
  padding:34px;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}

.form-copy:before{
  content:"";
  position:absolute;
  right:-80px;
  top:-80px;
  width:230px;
  height:230px;
  border-radius:50%;
  background:rgba(0,178,179,.24);
}

.form-copy .kicker,
.form-copy h2,
.form-copy p,
.form-copy .form-note,
.form-copy .contact-mini-list{
  position:relative;
  z-index:1;
}

.form-copy h2{
  color:white;
  margin-top:10px;
}

.form-copy p{
  color:rgba(255,255,255,.84);
  line-height:1.78;
}

.form-note{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  border-radius:22px;
  padding:18px;
  margin-top:22px;
}

.form-note strong{
  display:block;
  font-family:'Montserrat',sans-serif;
  color:white;
  margin-bottom:4px;
}

.form-note span{
  color:rgba(255,255,255,.78);
  font-weight:700;
}

.contact-mini-list{
  display:grid;
  gap:10px;
  margin-top:22px;
}

.contact-mini-list div{
  background:rgba(255,255,255,.08);
  border-radius:16px;
  padding:13px 14px;
}

.contact-mini-list strong{
  display:block;
  font-family:'Montserrat',sans-serif;
  color:white;
}

.contact-mini-list span{
  color:rgba(255,255,255,.78);
  font-weight:700;
}

.contact-form{
  background:white;
  border:1px solid rgba(230,236,239,.95);
  border-radius:34px;
  padding:30px;
  box-shadow:var(--shadow);
}

.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.form-row{
  display:grid;
  gap:8px;
  margin-bottom:16px;
}

.form-row label{
  font-family:'Montserrat',sans-serif;
  font-weight:900;
  color:var(--navy);
  font-size:.92rem;
}

.form-row input,
.form-row select,
.form-row textarea{
  width:100%;
  border:1px solid rgba(10,25,35,.14);
  border-radius:16px;
  padding:13px 14px;
  font:inherit;
  color:var(--text);
  background:#F7FAFB;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.form-row textarea{
  resize:vertical;
  min-height:130px;
}

.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus{
  outline:none;
  border-color:rgba(0,178,179,.72);
  background:white;
  box-shadow:0 0 0 4px rgba(0,178,179,.12);
}

.form-error{
  min-height:24px;
  color:#B42318;
  font-weight:900;
  margin:0 0 12px;
}

.form-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.form-actions .btn{
  border:0;
  cursor:pointer;
}

.form-actions .btn.light{
  border:2px solid var(--navy);
}

.form-privacy{
  margin:16px 0 0;
  color:var(--muted);
  font-size:.92rem;
  line-height:1.6;
}

@media(max-width:980px){
  .form-layout{
    grid-template-columns:1fr;
  }
}

@media(max-width:640px){
  .form-grid{
    grid-template-columns:1fr;
  }

  .contact-form,
  .form-copy{
    padding:24px;
    border-radius:28px;
  }

  .form-actions .btn{
    width:100%;
  }
}
