
:root{
  --bg:#F5F7FB;
  --surface:#FFFFFF;
  --text:#101828;
  --muted:#475467;
  --brand:#0B3C5D;
  --brand2:#1ABC9C;
  --border:#EAECF0;
  --shadow: 0 18px 45px rgba(16,24,40,.10);
  --shadow2: 0 8px 20px rgba(16,24,40,.08);
  --radius:18px;
  --radius2:14px;
  --max:1160px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  background: radial-gradient(1400px 700px at 10% -10%, rgba(26,188,156,.18), transparent 60%),
              radial-gradient(1200px 700px at 90% 0%, rgba(11,60,93,.16), transparent 55%),
              var(--bg);
  color:var(--text);
}
a{color:inherit}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 18px}
.topbar{background: rgba(255,255,255,.72);backdrop-filter: blur(10px);border-bottom:1px solid var(--border);}
.topbar .row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 0}
.topbar .meta{display:flex;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:14px}
.badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--border);background: rgba(255,255,255,.8);border-radius:999px;}
.badge svg{width:16px;height:16px;color:var(--brand)}
.site-header{position:sticky;top:0;z-index:50}
.navbar{background: rgba(255,255,255,.85);backdrop-filter: blur(14px);border-bottom:1px solid var(--border);}
.navbar .row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo{width:44px;height:44px;border-radius:14px;background: linear-gradient(135deg, var(--brand), #0E4C76);display:grid;place-items:center;box-shadow: 0 10px 28px rgba(11,60,93,.28);}
.logo span{color:#fff;font-weight:800;letter-spacing:.5px}
.brand .name{line-height:1.05}
.brand .name b{display:block;font-size:16px}
.brand .name small{color:var(--muted);font-size:12px}
.nav{display:flex;align-items:center;gap:16px;}
.nav a{text-decoration:none;color:var(--muted);font-weight:650;padding:10px 10px;border-radius:12px;}
.nav a:hover,.nav a:focus{background:rgba(26,188,156,.10);color:var(--text)}
.nav-toggle{display:none;border:1px solid var(--border);background:var(--surface);border-radius:12px;padding:10px;box-shadow:var(--shadow2)}
.nav-toggle svg{width:18px;height:18px;color:var(--brand)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;text-decoration:none;padding:12px 16px;border-radius:14px;border:1px solid var(--border);background: rgba(255,255,255,.9);font-weight:750;box-shadow: var(--shadow2);}
.btn.primary{background: linear-gradient(135deg, var(--brand2), #22c1a3);border-color: transparent;color:#fff;}
.btn.dark{background: linear-gradient(135deg, var(--brand), #0E4C76);border-color: transparent;color:#fff;}
.btn:hover{transform: translateY(-1px)}
.btn:active{transform: translateY(0)}
.hero{padding:56px 0 20px;}
.hero-grid{display:grid;grid-template-columns: 1.1fr .9fr;gap:26px;align-items:stretch;}
.hero-card{border:1px solid var(--border);background: rgba(255,255,255,.85);border-radius: var(--radius);box-shadow: var(--shadow);overflow:hidden;}
.hero-inner{padding:34px}
.kicker{display:inline-flex;align-items:center;gap:10px;color:var(--brand);font-weight:800;background: rgba(11,60,93,.08);border:1px solid rgba(11,60,93,.14);padding:8px 12px;border-radius:999px;}
h1{margin:14px 0 12px;font-size:42px;line-height:1.05;letter-spacing:-.02em}
.lead{color:var(--muted);font-size:16px;line-height:1.6;margin:0 0 18px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}
.stat{border:1px solid var(--border);border-radius:16px;background: rgba(255,255,255,.7);padding:12px;}
.stat b{display:block;font-size:16px}
.stat small{color:var(--muted)}
.hero-media{position:relative;min-height:380px;background: linear-gradient(135deg, rgba(26,188,156,.35), rgba(11,60,93,.22));}
.hero-media .img{position:absolute;inset:0;background-size:cover;background-position:center;filter: saturate(1.05) contrast(1.03);}
.hero-media .overlay{position:absolute;inset:0;background: linear-gradient(180deg, rgba(16,24,40,.05), rgba(16,24,40,.30));}
.hero-media .floating{position:absolute;left:18px;bottom:18px;right:18px;display:flex;flex-direction:column;gap:12px;}
.flo-card{background: rgba(255,255,255,.92);border:1px solid var(--border);border-radius:16px;padding:14px 14px;box-shadow: var(--shadow2);}
.flo-card b{display:block}
.flo-card small{color:var(--muted)}
.section{padding:26px 0}
.section .head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin:18px 0 16px}
.section h2{margin:0;font-size:26px;letter-spacing:-.01em}
.section p.sub{margin:6px 0 0;color:var(--muted);max-width:58ch}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.card{background: rgba(255,255,255,.90);border:1px solid var(--border);border-radius: var(--radius2);box-shadow: var(--shadow2);overflow:hidden;}
.card .p{padding:18px}
.icon{width:42px;height:42px;border-radius:14px;background: rgba(26,188,156,.15);display:grid;place-items:center;border:1px solid rgba(26,188,156,.22);color: var(--brand);}
.icon svg{width:20px;height:20px}
.program-card .thumb{aspect-ratio: 16/10;background: linear-gradient(135deg, rgba(11,60,93,.25), rgba(26,188,156,.30));position:relative;}
.program-card .thumb img{width:100%;height:100%;object-fit:cover}
.pills{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 0}
.pill{padding:6px 10px;border-radius:999px;background: rgba(11,60,93,.08);border:1px solid rgba(11,60,93,.14);color:var(--brand);font-weight:750;font-size:12px;}
.program-card h3{margin:10px 0 8px;font-size:18px}
.program-card p{margin:0;color:var(--muted);line-height:1.6}
.program-card .actions{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.filters{display:flex;gap:10px;flex-wrap:wrap}
.chip{cursor:pointer;border:1px solid var(--border);background: rgba(255,255,255,.85);padding:10px 12px;border-radius:999px;font-weight:750;color:var(--muted);}
.chip[data-active="1"]{background: rgba(26,188,156,.12);border-color: rgba(26,188,156,.25);color: var(--text);}
.contact-wrap{display:grid;grid-template-columns: .9fr 1.1fr;gap:16px}
.form{padding:18px;}
.field{margin-bottom:12px}
.field label{display:block;font-size:13px;color:var(--muted);font-weight:700;margin:0 0 6px}
.field input,.field select,.field textarea{width:100%;padding:12px 12px;border-radius:14px;border:1px solid var(--border);background: rgba(255,255,255,.95);outline:none;}
.field textarea{min-height:110px;resize:vertical}
.notice{padding:12px 14px;border-radius:14px;border:1px solid rgba(26,188,156,.30);background: rgba(26,188,156,.12);color: #0b3c5d;font-weight:700;}
.site-footer{margin-top:30px}
.footer{background: rgba(11,60,93,.96);color:#fff;padding:26px 0;border-top:1px solid rgba(255,255,255,.08);}
.footer-grid{display:grid;grid-template-columns: 1.2fr .8fr .8fr;gap:16px}
.footer a{color:#fff;text-decoration:none;opacity:.92}
.footer small{color:rgba(255,255,255,.75)}
.content{background: rgba(255,255,255,.90);border:1px solid var(--border);border-radius: var(--radius);box-shadow: var(--shadow2);padding:18px;}
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr}
  .hero-media{min-height:320px}
  .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .contact-wrap{grid-template-columns:1fr}
  h1{font-size:34px}
  .nav{display:none}
  .nav-toggle{display:inline-flex}
  .nav.mobile-open{display:flex;flex-direction:column;position:absolute;left:18px;right:18px;top:72px;
    background: rgba(255,255,255,.95);border:1px solid var(--border);border-radius:16px;padding:12px;box-shadow:var(--shadow)}
}


/* Hero quick form (right card) */
.hero-form{
  position:absolute;
  left:18px; right:18px; bottom:18px; top:18px;
  display:flex;
  align-items:flex-start;
}
.hero-form form{
  width:100%;
  background: rgba(255,255,255,.92);
  border:1px solid var(--border);
  border-radius:18px;
  padding:16px;
  box-shadow: var(--shadow2);
}
.hf-field{margin-bottom:12px}
.hf-field label{
  display:block;
  font-weight:900;
  letter-spacing:.04em;
  font-size:12px;
  color:#E11D48; /* rojo como en tu marca */
  margin:0 0 6px;
  text-transform:uppercase;
}
.hf-field input, .hf-field textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.98);
  outline:none;
}
.hf-field textarea{min-height:120px; resize:vertical}
.hf-btn{width:100%; justify-content:center}


/* Keep quick info cards under the hero form */
.hero-form{
  position:absolute;
  left:18px; right:18px;
  top:18px;
  bottom:150px; /* leaves space for the two cards */
  display:flex;
  align-items:flex-start;
}
.floating-under-form{
  position:absolute;
  left:18px; right:18px;
  bottom:18px;
  display:flex;
  flex-direction:column;
  gap:12px;
}


/* === Hero right: form encajado sobre Ubicación === */
.hero-media{position:relative; overflow:hidden;}
.hero-media .img{position:absolute; inset:0; z-index:0;}
.hero-media .overlay{position:absolute; inset:0; z-index:1; pointer-events:none;}

.hero-side-stack{
  position:absolute;
  left:18px; right:18px; top:18px; bottom:18px;
  z-index:2;
  display:flex;
  flex-direction:column;
  gap:12px;
  justify-content:flex-end;
}

.hero-mini-form{
  padding:16px;
  border-radius:18px;
  background: rgba(255,255,255,.94);
}

.hmf-field{margin-bottom:10px}
.hmf-field label{
  display:block;
  font-weight:900;
  letter-spacing:.04em;
  font-size:12px;
  color:#E11D48;
  text-transform:uppercase;
  margin:0 0 6px;
}
.hmf-field input,.hmf-field textarea{
  width:100%;
  padding:11px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.98);
  outline:none;
}
.hmf-field textarea{min-height:92px; resize:vertical}
.hmf-btn{width:100%; justify-content:center}

.hero-side-stack .flo-card{
  background: rgba(255,255,255,.92);
  border:1px solid var(--border);
  border-radius:16px;
  padding:14px;
  box-shadow: var(--shadow2);
}

@media (max-width: 980px){
  .hero-side-stack{position:static; padding:18px; height:auto}
  .hero-media{min-height:auto}
}
