*{
margin:0;
padding:0;
box-sizing:border-box;
font-family:'Poppins',sans-serif;
}

body{
background:#062b36;
color:#fff;
}


/* =========================
   FONTS
========================= */
@font-face{font-family:"font1";src:url("../fonts/font1.ttf") format("truetype");font-display:swap;}
@font-face{font-family:"font2";src:url("../fonts/font2.ttf") format("truetype");font-display:swap;}
@font-face{font-family:"font3";src:url("../fonts/font3.ttf") format("truetype");font-display:swap;}
@font-face{font-family:"font4";src:url("../fonts/font4.ttf") format("truetype");font-display:swap;}
@font-face{font-family:"font5";src:url("../fonts/font5.ttf") format("truetype");font-display:swap;}
@font-face{font-family:"font6";src:url("../fonts/font6.ttf") format("truetype");font-display:swap;}
@font-face{font-family:"font7";src:url("../fonts/font7.ttf") format("truetype");font-display:swap;}
@font-face{font-family:"font8";src:url("../fonts/font8.ttf") format("truetype");font-display:swap;}
@font-face{font-family:"font9";src:url("../fonts/font9.ttf") format("truetype");font-display:swap;}



/* =========================
   VARIABLES
========================= */
:root{
  --color-primary:#0399d4;
  --color-secondary:#4ec738;
  --color-dark:#222;
  --color-gray:#f2f2f2;
  --color-white:#ffffff;


  --radius-sm:8px;
  --radius-md:12px;
  --radius-lg:18px;

  --shadow-sm:0 4px 10px rgba(0,0,0,.15);
  --shadow-md:0 8px 18px rgba(0,0,0,.25);

  --t:.25s ease;

  --text-sm: clamp(12px,1vw,18px);
  --text: clamp(15px,1.3vw,20px);
  --text-lg: clamp(18px,2vw,28px);
  --h3: clamp(24px,3vw,42px);
  --h2: clamp(35px,5vw,96px);
  --hero: clamp(40px,5.5vw,160px);
}


/* ================= HERO ================= */

.hero{
position:relative;
height:110vh;
background:url("../img/banerh.webp") center/cover no-repeat;
display:flex;
align-items:center;
}

.overlay{
position:absolute;
inset:10;
background:linear-gradient(90deg,#0c3c52cc,#79c8e0cc);
}

.hero-container{
width:90%;
margin:auto;
display:flex;
justify-content:space-between;
align-items:center;
position:relative;
z-index:2;
}

.logo{
width:200px;
margin-bottom:20px;
}

.promo{
background:rgba(255,255,255,.15);
padding:25px;
backdrop-filter:blur(8px);
}

.promo button{
margin-top:10px;
background:#1ec6da;
border:none;
padding:10px 20px;
border-radius:6px;
color:#fff;
cursor:pointer;
}

/* FORM */

.hero-left{
display:flex;
flex-direction:column;
align-items:left;
width: 70%;
padding: 0% 3% 0% 0%;
}



.hero-form{
background:#fff;
padding:25px;
border-radius:10px;
width:320px;
color:#333;
}

.hero-form input,
.hero-form textarea{
width:100%;
margin:8px 0;
padding:12px;
border-radius:6px;
border:none;
background:#f1f1f1dc;
}

.hero-form button{
width:60%;
background: var(--color-secondary);
border:none;
padding:12px;
color:#fff;
border-radius:6px;
cursor:pointer;
margin-left: 20%;
}

.hero-seo{
  max-width:700px;
  margin:20px auto 0;
  padding:0 20px;
  text-align:center;
  color:#fff;
  position:relative;
  z-index:2;
}

.hero h1{
  font-size: var(--hero);
  margin-bottom: 5%;
  line-height:1;
  font-family: font5;
}

.hero p{
  font-family: font2;
  font-size: var(--text-sm);
  line-height:1.6;
  opacity:.95;
}

.benefit{
  margin-top:10px;
  font-size: var(--h1)
}

.seo-context{
  padding:40px 20px;
  max-width:900px;
  margin:auto;
  font-size:16px;
  line-height:1.6;
}

/* ================= CLINICAS ================= */

.seo-info{
padding:3%;
}

.seo-info h2{
font-size: var(--h3);
}

.seo-info p{
font-size: var(--text-sm);
}

.centros li{
font-size: var(--text-sm);
line-height: 180%;
font-family: font2;
}

.centros p{
font-size: var(--text-sm);
line-height: 200%;
}

/* ================= CLINICAS ================= */

.clinicas{
padding:10%;
background:#072a35;
text-align:center;
background-color: #19c4d6;
}

.cols{
display:flex;
gap:40px;
margin-top:40px;
text-align:left;
width: 100%;
}

.cols ul{
margin-top:10px;
}

.plan-btn{
display:block;
background:#2a7cff;
margin:8px 0;
padding:10px;
border-radius:6px;
text-align:center;
}

/* ================= PLANES ================= */

.planes{
padding:80px 10%;
text-align:center;
}

.planes h3{
font-size: var(--text-lg);
margin-bottom: 3%;
}

.planes ul{
font-size: var(--text-sm);
text-align: left;
line-height: 180%;
}

.cards{
display:flex;
justify-content:center;
gap:30px;
margin-top:40px;
}

.card{
background:#fff;
color:#333;
padding:25px;
border-radius:12px;
width:260px;
text-align: left;
}

.card button{
margin-top:15px;
background:#2bbbd3;
border:none;
padding:10px;
color:#fff;
border-radius:6px;
}

/* ================= CENTROS ================= */

.centros{
padding:80px 10%;
background:#083847;
text-align:center;
}

.grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
gap:25px;
margin-top:40px;
}

.grid p{
font-family: font1;
font-size: var(--text-sm);
line-height: 150%;
}

.sucursal{
background:#0c4b5e;
padding:10%;
border-radius:10px;
text-align: left;
}

.sucursal p{
font-family: font2;
}

.sucursal button{
margin-top:10px;
background:#19c4d6;
border:none;
padding:10px;
color:#fff;
border-radius:6px;
}

/* ================= FOOTER ================= */

footer{
background:#021a21;
padding:20px;
text-align:center;
font-size:14px;
}

/* ======================================
   RESPONSIVE TABLET
====================================== */

@media (max-width:1024px){

.hero-container{
flex-direction:column;
text-align:center;
gap:30px;
}

.hero{
height:auto;
padding:80px 0;
}

.hero-form{
width:100%;
max-width:420px;
}

.cols{
flex-direction:column;
text-align:center;
}

.cards{
flex-wrap:wrap;
}

}


/* ======================================
   RESPONSIVE MOBILE
====================================== */

@media (max-width:768px){

body{
font-size:15px;
}

/* HERO */

.hero-container{
flex-direction:column;
padding:20px;
}

.hero-left,
.hero-form{
width:100%;
}

.hero{
height:auto;
padding:80px 0;
}

.logo{
width:90%;
margin: 0% 5% 15% 5%;

}

.hero-form{
width:100%;
padding:20px;
}

/* CLINICAS */

.clinicas{
padding:50px 20px;
}

.cols{
gap:25px;
}

.cols div{
width:100%;
}

/* PLANES */

.planes{
padding:60px 20px;
}

.cards{
flex-direction:column;
align-items:center;
}

.card{
width:100%;
max-width:320px;
}

/* CENTROS */

.centros{
padding:60px 20px;
}

.grid{
grid-template-columns:1fr;
}

}


/* ======================================
   MOBILE SMALL
====================================== */

@media (max-width:480px){

.promo{
padding:18px;
}

.promo h1{
font-size:34px;
}

.hero-form h3{
font-size:18px;
}

.hero-form input,
.hero-form textarea{
padding:10px;
}

}