/* ===========================
   BASE & VARIABLES
=========================== */
:root {
  --bg:#0b0f14; --surface:#121923; --muted:#8fa0b3; --text:#e7eef7;
  --primary:#00d187; --primary-700:#00a36a; --accent:#6ea8fe;
  --warning:#ffc107; --danger:#ff5c5c;
  --ring:0 0 0 4px rgba(0,209,135,.25);
  --radius:18px; --shadow:0 10px 30px rgba(0,0,0,.35);
  --container:1120px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 10% -10%, #0f1722 20%, transparent),
    radial-gradient(1200px 600px at 90% -10%, #0a1320 20%, transparent),
    var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  padding-bottom:env(safe-area-inset-bottom);
}

a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

.container{
  max-width:var(--container);
  margin-inline:auto;
  padding:0 clamp(16px,6vw,24px);
}

/* ===========================
   BOTONES
=========================== */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.9rem 1.1rem;border-radius:12px;border:1px solid transparent;
  font-weight:600;transition:.2s;cursor:pointer
}
.btn-primary{
  background:linear-gradient(135deg,var(--primary),#31e2a3);
  color:#002116
}
.btn-primary:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(0,209,135,.25)
}
.btn-outline{border-color:#2a3a4e;color:var(--text);background:#122132}
.btn-outline:hover{border-color:#3b5270;background:#16263b}
.tag{display:inline-block;padding:.25rem .6rem;border:1px solid #2a3a4e;
  border-radius:999px;color:var(--muted);font-size:.8rem}

/* ===========================
   HEADER & NAV
=========================== */
header.site{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(140%) blur(10px);
  background:linear-gradient(180deg,rgba(11,15,20,.9),rgba(11,15,20,.6));
  border-bottom:1px solid #1c2838
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{display:flex;align-items:center;gap:.75rem;font-weight:800;letter-spacing:.3px}
.brand .logo{
  width:clamp(120px,22vw,150px);height:auto;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(0,209,135,.18);
  background:transparent;overflow:hidden
}
.brand .logo img{width:100%;height:auto;object-fit:contain}

.menu{display:flex;gap:20px;align-items:center}
.menu a{padding:10px;color:var(--muted)}
.menu a:hover{color:var(--text)}
.hamb{display:none}

@media (max-width:880px){
  .hamb{display:block}
  .menu{
    position:fixed;
    inset:calc(60px + env(safe-area-inset-top)) 16px auto 16px;
    background:var(--surface);border:1px solid #203045;border-radius:14px;
    padding:10px;display:none;flex-direction:column;gap:6px;
    max-height:calc(100svh - 100px);overflow:auto;
  }
  .menu.open{display:flex}
}

/* ===========================
   HERO
=========================== */
.hero{position:relative;isolation:isolate}
.hero .grid{display:grid;grid-template-columns:1fr;gap:20px;padding:40px 0}
@media (min-width:980px){
  .hero .grid{grid-template-columns:1.15fr .85fr;gap:40px;padding:68px 0}
}
.eyebrow{color:var(--muted);font-weight:600;letter-spacing:.2px}
.title{font-size:clamp(1.6rem,5.5vw,3rem);line-height:1.15;margin:.4rem 0 .6rem;font-weight:800}
.lead{color:#c8d4e3;font-size:clamp(.98rem,2.8vw,1.05rem)}
.hero-card{background:linear-gradient(180deg,#0f1724,#0b1220);
  border:1px solid #1e2a3b;border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow)}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0 22px}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap}
.hero aside{display:grid;gap:14px}
.metric{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;
  background:#0f1b2b;border:1px solid #1f3146}
.metric svg{opacity:.9}
.loc{display:flex;align-items:center;gap:8px;color:#c9d6e6}
@media (max-width:420px){
  .hero-cta .btn{flex:1 1 100%;justify-content:center}
}

/* ===========================
   PRODUCTOS
=========================== */
.section{padding:40px 0}
@media (min-width:880px){.section{padding:56px 0}}
.section h2{font-size:clamp(1.25rem,4.5vw,2rem);margin:0 0 8px}
.section p.sub{color:var(--muted);margin:0 0 18px}

.cards{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width:700px){.cards{grid-template-columns:repeat(2,1fr);gap:18px}}
.card{background:linear-gradient(180deg,#0f1724,#0b1220);border:1px solid #1e2a3b;
  border-radius:var(--radius);padding:18px;display:grid;gap:10px;box-shadow:var(--shadow)}
@media (min-width:880px){.card{padding:22px}}
.card h3{margin:0;font-size:clamp(1.05rem,3.5vw,1.25rem)}
.card .desc{color:#c9d6e6}
.card .features{display:grid;gap:8px;margin:6px 0}
.card .features li{display:flex;gap:8px;align-items:flex-start;color:#cfe1f3}
.card .actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:2px}
.badge{font-size:.75rem;background:#0e2438;border:1px solid #254564;color:#b8d1eb;
  padding:.25rem .5rem;border-radius:999px}
.stamp{margin-left:auto}

/* ===========================
   SOBRE MI
=========================== */
.about{display:grid;grid-template-columns:1fr;gap:16px}
@media (min-width:980px){.about{grid-template-columns:1.2fr .8fr;gap:26px}}
.about .box{background:#0f1826;border:1px solid #1e2a3b;border-radius:var(--radius);padding:18px}
@media (min-width:880px){.about .box{padding:22px}}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:8px}
.kpis .k{background:#0e1a29;border:1px solid #1a2b44;border-radius:14px;padding:12px;text-align:center}
.k .n{font-size:clamp(1rem,4vw,1.35rem);font-weight:800}

/* ===========================
   CLIENTES
=========================== */
.logos{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;align-items:center;opacity:.9}
@media (min-width:640px){.logos{grid-template-columns:repeat(3,1fr)}}
@media (min-width:1024px){.logos{grid-template-columns:repeat(5,1fr);gap:16px}}
.logo{background:#0f1b2b;border:1px dashed #27405d;padding:14px;border-radius:12px;text-align:center}
.logos .logo img{width:100%;height:auto;object-fit:contain}

/* ===========================
   CONTACTO
=========================== */
form{display:grid;gap:12px}
.grid2{display:grid;grid-template-columns:1fr;gap:12px}
@media (min-width:700px){.grid2{grid-template-columns:1fr 1fr}}
label{font-size:.9rem;color:#cbd7e6}
input, textarea, select{
  width:100%;padding:14px;border-radius:12px;border:1px solid #26384f;
  background:#0b1320;color:var(--text);outline:none;font-size:16px;
}
input:focus, textarea:focus, select:focus{box-shadow:var(--ring);border-color:#2b8b70}
textarea{min-height:120px;resize:vertical}
.form-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}

/* ===========================
   FOOTER
=========================== */
footer{border-top:1px solid #1c2838;margin-top:32px;background:#0a121d}
.foot{display:grid;grid-template-columns:1fr;gap:12px;padding:20px 0;color:#a7b6c8;align-items:center}
@media (min-width:700px){.foot{grid-template-columns:1fr auto;gap:18px}}
.foot small{opacity:.9}
.social{display:flex;gap:10px}
.social a{width:36px;height:36px;border-radius:10px;border:1px solid #20334a;display:grid;place-items:center}
.pill{display:inline-flex;align-items:center;gap:8px;border:1px solid #27405d;background:#0f1b2b;border-radius:999px;padding:8px 12px;color:#cfe1f3}
