
:root{
  --bg-start:#040910;
  --bg-end:#09121d;
  --panel:#0f172a;
  --primary:#06b6d4;
  --primary-b:#3b82f6;
  --text:#e5e7eb;
  --muted:#93a4bc;
  --accent-grad:linear-gradient(135deg, var(--primary), var(--primary-b));
  --shadow:0 12px 40px rgba(0,0,0,.45);
  --radius:12px;
  --radius-lg:20px;
  --nav-h:72px;                 /* alto del header */
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg-start);
  background-image: radial-gradient(circle at 1px 1px, #1e293b55 1px, transparent 0);
  background-size:20px 20px;
  color:var(--text);
  overflow-x:hidden;
  scroll-behavior:smooth
}
h1,h2,h3{font-family:Poppins,sans-serif;letter-spacing:-0.03em}

/* ===== NAVBAR ===== */
header{
  position:fixed; top:0; left:0; right:0; z-index:9999; /* fijo y encima */
  background:rgba(15,23,42,.92);
  backdrop-filter:blur(15px);
  border-bottom:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 24px;box-shadow:0 5px 20px rgba(0,0,0,.5);
  isolation:isolate;
}
main{ padding-top:var(--nav-h); }                   /* deja espacio bajo header */
section{ padding:80px 24px; position:relative; scroll-margin-top:calc(var(--nav-h) + 12px); }

header .brand{display:flex;gap:.7rem;align-items:center}
header .logo{
  width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:none;padding:0;
}
header .logo img{
  width:100%;height:100%;object-fit:contain;display:block;border-radius:12px;
  border:1px solid rgba(255,255,255,.15);box-shadow:0 4px 12px rgba(0,0,0,.25);
}
header b{color:var(--primary)}
nav a{color:var(--muted);margin:0 12px;text-decoration:none;position:relative;padding:4px 0;transition:color .3s}
nav a:hover{color:var(--text)}
nav a::after{
  content:"";position:absolute;left:50%;bottom:-2px;width:0;height:3px;background:var(--accent-grad);
  transition:all .3s ease-out;border-radius:2px;transform:translateX(-50%);
}
nav a:hover::after{width:100%}

/* ===== LAYOUT UTIL ===== */
.container{max-width:1280px;margin:0 auto}
h2{font-size:clamp(1.8rem,3.5vw,2.8rem);margin:0 0 10px;text-align:center}
section p{text-align:center;max-width:800px;margin:0 auto 30px;color:#cbd5e1}
[data-animate]{opacity:0;transform:translateY(40px);transition:all 1s cubic-bezier(0.25,0.46,0.45,0.94)}
[data-animate].visible{opacity:1;transform:translateY(0)}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;padding:14px 28px;border:none;border-radius:999px;font-weight:700;
  color:var(--bg-start);background:var(--accent-grad);
  box-shadow:0 8px 25px rgba(6,182,212,.35);cursor:pointer;transition:transform .3s, box-shadow .3s, opacity .3s;text-decoration:none;
}
.btn:hover{transform:translateY(-3px);box-shadow:0 14px 35px rgba(6,182,212,.45)}
.btn-outline{
  display:inline-flex;align-items:center;gap:.6rem;padding:12px 26px;border-radius:999px;border:2px solid transparent;
  background:linear-gradient(var(--bg-end), var(--bg-end)) padding-box, var(--accent-grad) border-box;
  color:var(--primary);font-weight:600;transition:all .3s;text-decoration:none;
}
.btn-outline:hover{background:var(--accent-grad);color:var(--bg-start);box-shadow:0 6px 15px rgba(6,182,212,.3)}

/* ===== HERO ===== */
.hero{text-align:center;padding:120px 24px 80px;}
.hero h1{
  font-size:clamp(2.5rem,5.5vw,4.5rem);line-height:1.15;color:var(--text);
  text-shadow:0 0 20px rgba(6,182,212,.2);max-width:1000px;margin:0 auto;
}
.hero h1 span{color:var(--primary)}
.hero p{max-width:860px;margin:18px auto 30px;font-size:1.15rem;color:#aebedb}
.kpis{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:960px;margin:30px auto 0;padding:24px;
  background:rgba(15,23,42,.6);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-lg);backdrop-filter:blur(5px);
}
.kpi{padding:16px;border-radius:var(--radius);text-align:center;transition:transform .3s ease;}
.kpi h3{margin:0;font-size:2.2rem;color:var(--primary);line-height:1;font-weight:800}
.kpi p{margin:4px 0 0;font-size:.95rem;color:var(--muted);text-align:center}

/* ===== SERVICES ===== */
.services{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;margin-top:30px}
.service{
  background:var(--panel);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);padding:24px;
  box-shadow:0 12px 30px rgba(0,0,0,.3);transition:transform .3s, box-shadow .3s;position:relative;overflow:hidden;
}
.service:hover{transform:translateY(-8px);box-shadow:0 20px 45px rgba(6,182,212,.25)}
.service h3{color:var(--primary);display:flex;align-items:center;gap:12px;font-size:1.4rem;}
.service ul{list-style-type:'✅';padding-left:1.2em;margin-top:10px;line-height:1.6}
.service ul li{padding-left:.5em;margin-bottom:4px;color:#c0d6f4}
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:15px}
.chip{
  padding:7px 14px;border-radius:999px;border:1px solid rgba(6,182,212,.3);background:rgba(6,182,212,.08);
  color:#cffafe;font-size:.8rem;font-weight:600;
}

/* ===== LIDERAZGO ===== */
#liderazgo{padding:80px 24px;background:#0f172a;border-top:1px solid rgba(255,255,255,.1)}
.lider-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-top:30px}
@media (max-width:900px){.lider-grid{grid-template-columns:1fr}}
.lider-card{
  background:linear-gradient(180deg, #111a2e, #0c1524);
  border:2px solid var(--primary);
  border-radius:var(--radius-lg);
  padding:25px;box-shadow:0 10px 30px rgba(6,182,212,.3);
  display:flex;gap:20px;align-items:flex-start;
}
.lider-card img{
  width:120px;height:120px;object-fit:cover;border-radius:50%;
  border:4px solid var(--primary-b);box-shadow:0 0 15px rgba(59,130,246,.5);
}
.lider-info h3{color:var(--primary);margin-top:0;font-size:1.5rem}
.lider-info small{display:block;margin-bottom:10px;color:#c0d6f4;font-weight:600}
.lider-info ul{list-style-type:none;padding:0;margin:10px 0 0}
.lider-info ul li{margin-bottom:5px;font-size:.95rem;color:var(--muted);display:flex;align-items:center;gap:8px}

/* ===== TEAM ===== */
.team{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-top:30px;align-items:stretch}
.member{
  display:flex;flex-direction:column;justify-content:flex-start;background:var(--panel);border-radius:var(--radius-lg);
  padding:20px;box-shadow:0 10px 25px rgba(0,0,0,.35);text-align:center;border:1px solid rgba(255,255,255,.1);transition:transform .3s;
}
.member h3{font-size:1.15rem;margin:.4rem 0;color:var(--primary)}
.member small{color:#b7c5de}
.skills{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:12px;min-height:40px}
.skill{padding:6px 10px;border:1px solid rgba(6,182,212,.3);border-radius:999px;font-size:.8rem;color:#cfefff;background:rgba(6,182,212,.06)}

.frame{
  position:relative;display:flex;flex-direction:column;overflow:hidden;margin-bottom:15px;
  background:linear-gradient(to bottom right, #2c3e50, #17202a);
  box-shadow:0 6px 18px rgba(0,0,0,.6);border-radius:15px;transition:transform .3s ease, box-shadow .3s ease;aspect-ratio:4/5;
}
.frame img{width:100%;height:100%;object-fit:cover;object-position:center top;border-radius:15px}
.frame::after{
  content:"";position:absolute;inset:0;border-radius:15px;pointer-events:none;
  background:
    linear-gradient(90deg, rgba(4,9,16,.88), rgba(4,9,16,0) 12%),
    linear-gradient(-90deg, rgba(4,9,16,.88), rgba(4,9,16,0) 12%);
}

/* ===== CASO BLG ===== */
#blg{
  background:linear-gradient(45deg,rgba(15,23,42,.9),rgba(11,18,32,.9));
  border-radius:var(--radius-lg);padding:40px;box-shadow:0 8px 30px rgba(0,0,0,.4);
  text-align:center;border:2px solid var(--primary-b);position:relative;overflow:hidden;
}
#blg h2{color:var(--primary);margin-top:0;font-size:2.2rem}
#blg p{max-width:800px;margin:10px auto 20px;font-size:1.1rem;color:#c0d6f4;text-align:center}

/* MODAL */
.modal{
  position:fixed;inset:0;background:rgba(0,0,0,.9);display:none;align-items:center;justify-content:center;z-index:2000;
  overflow-y:auto;padding:20px;
}
.modal-content{
  background:linear-gradient(180deg,#111a2e,#0f172a);border:1px solid rgba(6,182,212,.25);border-radius:var(--radius-lg);
  max-width:1080px;width:95%;padding:30px;box-shadow:0 0 40px rgba(6,182,212,.35);
  position:relative;animation:zoomIn .4s cubic-bezier(0.25,0.46,0.45,0.94);margin:auto;
}
@keyframes zoomIn{from{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}
.close-modal{position:absolute;top:10px;right:15px;font-size:2rem;color:var(--primary);cursor:pointer;background:none;border:none;line-height:1}
.close-modal:hover{color:var(--primary-b)}

/* Galería uniforme */
.gallery{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-top:20px;
}
.gallery img{
  width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:15px;box-shadow:0 6px 15px rgba(0,0,0,.35);
  cursor:zoom-in;transition:transform .25s ease, box-shadow .25s ease;
}
.gallery img:hover{transform:scale(1.03);box-shadow:0 12px 28px rgba(6,182,212,.35)}

/* Visor (lightbox) */
.img-viewer{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:3000;align-items:center;justify-content:center;padding:24px;
}
.img-viewer img{
  max-width:92vw;max-height:92vh;border-radius:16px;box-shadow:0 0 30px rgba(6,182,212,.5);animation:zoomIn .2s ease;cursor:zoom-out;
}

/* ---- CHART (barras legibles) ---- */
.chart{display:flex;flex-direction:column;gap:14px;margin-top:20px}
.bar-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:center;
}
.bar-track{
  position:relative;height:22px;border-radius:999px;overflow:hidden;
  background:#0b1424;border:1px solid rgba(255,255,255,.08);
}
.bar-fill{
  position:relative;height:100%;width:var(--w,0%);
  background:var(--accent-grad);
  box-shadow:0 0 14px rgba(6,182,212,.45), inset 0 0 12px rgba(59,130,246,.25);
  border-radius:999px;transition:width .6s ease;
}
.bar-label{
  display:flex;gap:8px;align-items:center;font-weight:800;white-space:nowrap;
  color:#dbeafe;text-shadow:0 1px 2px rgba(0,0,0,.35);
}
.bar-perc{color:var(--primary);min-width:52px;text-align:right}
.bar-text{color:#cfe7ff;opacity:.95}
/* etiqueta dentro cuando hay espacio */
.bar-fill.inside::after{
  content:attr(data-label);
  position:absolute;right:10px;top:50%;transform:translateY(-50%);
  font-weight:800;color:var(--bg-start);
}

/* ===== TESTIMONIOS ===== */
.carousel{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);background:rgba(15,23,42,.4);padding:16px}
.slides{display:flex;transition:transform .5s ease}
.testimonial{flex:0 0 100%;padding:18px 22px;display:flex;flex-direction:column;gap:14px}
.testimonial p{margin:0;color:#d4e1f7;text-align:left}
.who{display:flex;align-items:center;gap:12px}
.dots{display:flex;gap:8px;justify-content:center;margin-top:10px}
.dot{width:10px;height:10px;border-radius:999px;border:2px solid #7dd3fc;opacity:.6;cursor:pointer;background:transparent}
.dot.active{background:#7dd3fc;opacity:1}

/* ===== CONTACTO ===== */
.contact-container{
  background:var(--panel);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);
  padding:40px;box-shadow:var(--shadow);max-width:900px;margin:0 auto;
}
.contact-grid-redesign{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:25px}
@media (max-width:800px){.contact-grid-redesign{grid-template-columns:1fr}}
input,textarea,select{
  padding:14px;border-radius:15px;border:1px solid rgba(6,182,212,.3);background:#070f17;color:var(--text);font-size:1rem;transition:border-color .3s, box-shadow .3s;
}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 10px rgba(6,182,212,.5)}
.form-group-inline{display:grid;grid-template-columns:1fr 1fr;gap:15px}
.contact-info-list{list-style:none;padding:0;margin-top:15px}
.contact-info-list li{margin-bottom:15px;display:flex;align-items:center;gap:10px;font-size:1.05rem}
.contact-info-list li i{color:var(--primary)}
.contact-info-list a{color:var(--text);text-decoration:none;transition:color .3s}
.contact-info-list a:hover{color:var(--primary)}
#responseMsg{text-align:left;margin-top:15px;font-weight:600;font-size:1rem}

/* ===== FOOTER ===== */
footer{background:var(--panel);padding:40px 28px;color:#9ca3af;border-top:1px solid rgba(255,255,255,.1)}
footer a{transition:color .3s}
footer a:hover{color:var(--primary)!important}

/* ===== RESPONSIVE ===== */
@media (max-width:900px){
  .kpis{grid-template-columns:1fr 1fr}
  .lider-grid{grid-template-columns:1fr}
  .form-group-inline{grid-template-columns:1fr}
}
@media (max-width:640px){
  :root{ --nav-h:64px; }        /* header más bajo en móvil */
  .kpis{grid-template-columns:1fr}
  header nav{display:none}
  .lider-card{flex-direction:column;align-items:center;text-align:center}
  .lider-info ul{text-align:left}
}