/* ──────────────────────────────────────────
   CREA-SECTIONS.CSS
   Nav, Hero, Strip, Servicios, Porque,
   Portafolio, IA, Equipo, Contacto,
   Footer, WA Float
   ────────────────────────────────────────── */

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  min-height:76px; height:auto; display:flex; align-items:center;
  padding:6px 6%;
  background:rgba(6,9,15,0.75);
  backdrop-filter:blur(28px);
  border-bottom:1px solid rgba(79,110,247,0.08);
  transition:background .3s;
}
.nav-inner { display:flex; align-items:center; justify-content:space-between; width:100%; max-width:1200px; margin:0 auto; }
/* [Nav/Footer] Lockup C + REA Studio en markup; footer: .footer-brand-wrap */
.nav-logo { display:flex; align-items:center; gap:0; text-decoration:none; }
.nav-links { display:flex; gap:36px; list-style:none; }
.nav-links a { font-size:14px; font-weight:500; color:var(--muted2); text-decoration:none; transition:color .2s; letter-spacing:-0.1px; }
.nav-links a:hover { color:var(--txt); }
.nav-pill {
  background:var(--indigo); color:#fff;
  font-size:13px; font-weight:600; padding:9px 20px;
  border-radius:8px; border:none; cursor:pointer;
  text-decoration:none; letter-spacing:-0.1px;
  transition:all .2s;
  box-shadow:0 0 0 1px rgba(79,110,247,0.4),0 4px 20px rgba(79,110,247,0.25);
}
.nav-pill:hover { background:var(--indigo2); box-shadow:0 0 0 1px rgba(107,135,255,0.5),0 8px 32px rgba(79,110,247,0.4); transform:translateY(-1px); }
.ham { display:none; flex-direction:column; gap:4px; cursor:pointer; padding:4px; }
.ham span { width:22px; height:1.5px; background:var(--muted2); border-radius:2px; transition:.3s; }
.mob-menu {
  display:none; position:fixed; top:76px; left:0; right:0;
  background:rgba(6,9,15,0.98); backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
  padding:24px 6% 32px; flex-direction:column; gap:0; z-index:199;
}
.mob-menu.open { display:flex; }
.mob-menu a { font-size:15px; font-weight:500; color:var(--muted2); text-decoration:none; padding:14px 0; border-bottom:1px solid rgba(255,255,255,0.04); transition:color .2s; }
.mob-menu a:hover { color:var(--txt); }
.mob-cta { margin-top:20px; }

/* ── HERO ── */
#hero {
  min-height:100vh; display:flex; align-items:center;
  padding:120px 6% 80px;
}
.hero-wrap {
  max-width:1200px; margin:0 auto; width:100%;
  display:grid; grid-template-columns:1fr 440px; gap:80px; align-items:center;
}
.h-chip {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(79,110,247,0.08);
  border:1px solid rgba(79,110,247,0.18);
  border-radius:6px; padding:6px 14px;
  font-size:12px; font-weight:600; color:var(--indigo3);
  letter-spacing:0.5px; text-transform:uppercase;
  margin-bottom:32px;
  animation:up .6s ease both;
}
.chip-dot { width:6px; height:6px; border-radius:50%; background:var(--indigo2); animation:pulse 2s infinite; }
h1 {
  font-weight:700; line-height:1.02;
  animation:up .7s .08s ease both; opacity:0;
}
/* [Hero] — lockup C + REA Studio; icono + texto compactos (gap 4px en markup) */
h1 .hero-brand-lockup {
  flex-wrap:wrap;
  max-width:min(560px,94vw);
  margin-bottom:0.38em;
}
h1 .hero-brand-lockup img {
  display:block;
  flex-shrink:0;
  max-width:min(200px,28vw);
  height:auto;
  object-fit:contain;
  object-position:left center;
  background:transparent;
}
h1 .h1-slogan {
  display:block;
  margin-top:0.42em;
  max-width:22ch;
  font-size:clamp(20px,2.8vw,34px);
  font-weight:600;
  letter-spacing:-0.03em;
  line-height:1.12;
  background:linear-gradient(105deg,var(--indigo),var(--ice));
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}
.hero-p {
  font-size:17px; color:var(--muted2); line-height:1.7;
  max-width:500px; margin:28px 0 44px; font-weight:400;
  animation:up .7s .16s ease both; opacity:0;
}
.hero-p b { color:var(--txt); font-weight:600; }
.hero-btns {
  display:flex; align-items:center;
  gap:18px; column-gap:22px; row-gap:14px;
  flex-wrap:wrap; margin-top:4px;
  animation:up .7s .24s ease both; opacity:0;
}
.btn-p {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--indigo); color:#fff;
  font-size:14px; font-weight:600; padding:13px 26px;
  border-radius:8px; border:none; cursor:pointer; text-decoration:none;
  box-shadow:0 0 0 1px rgba(79,110,247,0.4),0 4px 24px rgba(79,110,247,0.3);
  transition:all .2s; letter-spacing:-0.1px;
}
.btn-p:hover { background:var(--indigo2); transform:translateY(-2px); box-shadow:0 0 0 1px rgba(107,135,255,0.5),0 8px 40px rgba(79,110,247,0.45); }
.btn-g {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; border:1px solid rgba(255,255,255,0.1);
  color:var(--muted2); font-size:14px; font-weight:600;
  padding:13px 26px; border-radius:8px; cursor:pointer; text-decoration:none;
  transition:all .2s;
}
.btn-g:hover { border-color:rgba(79,110,247,0.35); color:var(--indigo3); }

/* hero panel */
.h-panel {
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:20px; padding:28px;
  box-shadow:0 40px 80px rgba(0,0,0,0.5),inset 0 1px 0 rgba(255,255,255,0.04);
  animation:up .7s .4s ease both; opacity:0;
}
.hp-header {
  display:flex; align-items:center; justify-content:space-between;
  padding-bottom:20px; border-bottom:1px solid rgba(255,255,255,0.05); margin-bottom:20px;
}
.hp-logo { display:flex; align-items:flex-start; min-width:0; }
/* [Hero panel] lockup C + REA Studio + subtítulo (bloque en index.html) */
.hp-sb { font-size:11px; color:var(--muted); margin-top:0; line-height:1.3; }
.hp-status {
  display:flex; align-items:center; gap:5px;
  font-size:10px; font-weight:600; color:var(--indigo3); letter-spacing:1px; text-transform:uppercase;
}
.hp-dot { width:5px; height:5px; border-radius:50%; background:var(--indigo2); animation:pulse 1.8s infinite; }
.hp-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:14px; }
.hp-stat {
  background:rgba(79,110,247,0.05); border:1px solid rgba(79,110,247,0.1);
  border-radius:12px; padding:14px;
}
.hp-sn { font-size:26px; font-weight:700; color:var(--indigo2); line-height:1; letter-spacing:-0.5px; }
.hp-sl { font-size:10px; color:var(--muted); margin-top:3px; font-weight:500; text-transform:uppercase; letter-spacing:0.5px; }
.hp-rows { display:flex; flex-direction:column; gap:8px; }
.hp-row {
  display:flex; align-items:center; gap:10px;
  background:var(--glass2); border:1px solid rgba(255,255,255,0.05);
  border-radius:10px; padding:10px 12px; font-size:13px; font-weight:500; color:var(--muted2);
}
.hp-row-icon { font-size:16px; }

/* ── STRIP ── */
#strip {
  padding:28px 0;
  border-top:1px solid rgba(79,110,247,0.07);
  border-bottom:1px solid rgba(79,110,247,0.07);
  background:var(--bg2);
}
.strip-inner {
  max-width:1200px; margin:0 auto; padding:0 6%;
  display:flex; align-items:center; justify-content:center; gap:48px; flex-wrap:wrap;
}
.strip-item {
  display:flex; align-items:center; gap:8px;
  font-size:13px; font-weight:500; color:var(--muted2); letter-spacing:-0.1px;
}
.strip-item svg { width:14px; height:14px; color:var(--indigo2); }

/* ── SERVICIOS ── */
#servicios { padding:120px 0; background:var(--bg2); }
.srv-g { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.sc {
  background:var(--bg3); border:1px solid var(--border);
  border-radius:16px; padding:32px;
  transition:all .3s; position:relative; overflow:hidden;
}
.sc::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(79,110,247,0.05),transparent);
  opacity:0; transition:opacity .3s; pointer-events:none;
}
.sc:hover { border-color:var(--border2); transform:translateY(-4px); box-shadow:0 20px 60px rgba(0,0,0,0.4); }
.sc:hover::after { opacity:1; }
.sc-n { font-size:11px; font-weight:600; color:var(--muted); letter-spacing:2px; text-transform:uppercase; margin-bottom:28px; }
/* [Servicios] Iconos Lucide ~48px, centrados; aura + hover scale */
.sc-ico {
  width:56px; height:56px; border-radius:12px;
  background:rgba(184,212,255,0.06); border:1px solid rgba(184,212,255,0.2);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:20px; transition:background .3s,border-color .3s,box-shadow .3s;
  color:var(--ice);
}
.sc-ico-svg {
  width:48px; height:48px;
  flex-shrink:0; display:block;
  filter:drop-shadow(0 0 8px var(--indigo));
  transition:transform .35s ease;
  transform-origin:center center;
}
.sc:hover .sc-ico {
  background:rgba(184,212,255,0.1);
  border-color:rgba(184,212,255,0.35);
  box-shadow:0 0 24px rgba(184,212,255,0.12);
}
.sc:hover .sc-ico-svg { transform:scale(1.1); }
@media (prefers-reduced-motion:reduce) {
  .sc-ico-svg { transition:none; }
  .sc:hover .sc-ico-svg { transform:none; }
}
.sc-title { font-size:18px; font-weight:700; letter-spacing:-0.4px; margin-bottom:8px; color:var(--txt); line-height:1.25; }
.sc-focus {
  font-size:12px; font-weight:600; color:var(--ice);
  letter-spacing:0.02em; margin:0 0 12px; line-height:1.45;
}
.sc-desc {
  font-size:14px; color:var(--muted2); line-height:1.65;
  margin:0;
  text-wrap:pretty;
}
.sc-tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:18px; }
.sc-tag {
  font-size:11px; font-weight:500;
  background:rgba(79,110,247,0.07); border:1px solid rgba(79,110,247,0.12);
  color:var(--indigo3); padding:4px 10px; border-radius:5px; line-height:1.3;
}
/* [Servicios] CTA al cuadro de cotización */
.sc-cta {
  display:inline-flex; align-items:center; justify-content:center;
  margin-top:20px; min-height:48px; padding:12px 20px;
  font-size:13px; font-weight:700; letter-spacing:0.04em; text-transform:uppercase;
  color:var(--ice);
  border:1px solid rgba(184,212,255,0.4);
  border-radius:10px; text-decoration:none;
  background:rgba(184,212,255,0.04);
  transition:background .2s,border-color .2s,color .2s,transform .2s;
}
.sc-cta:hover {
  background:rgba(184,212,255,0.1);
  border-color:var(--ice2);
  color:var(--ice2);
  transform:translateY(-1px);
}
.sc-cta:focus-visible {
  outline:2px solid var(--indigo2); outline-offset:3px;
}

/* ── PORQUE ── */
#porque { padding:120px 0; }
.pq-g { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.pq {
  display:flex; gap:18px; align-items:flex-start;
  background:var(--bg3); border:1px solid var(--border);
  border-radius:14px; padding:28px; transition:all .3s;
}
.pq:hover { border-color:var(--border2); }
.pq-ico {
  width:44px; height:44px; min-width:44px; border-radius:11px;
  background:rgba(79,110,247,0.08); border:1px solid rgba(79,110,247,0.15);
  display:flex; align-items:center; justify-content:center; font-size:20px;
}
.pq-t { font-size:15px; font-weight:700; letter-spacing:-0.2px; margin-bottom:6px; }
.pq-d { font-size:13px; color:var(--muted2); line-height:1.6; }

/* ── PORTAFOLIO ── */
#portafolio { padding:120px 0; background:var(--bg2); }
.port-feat {
  background:var(--bg3); border:1px solid var(--border2);
  border-radius:20px; padding:44px; margin-bottom:20px;
  display:grid; grid-template-columns:1fr minmax(300px,420px); gap:60px; align-items:center;
}
.pf-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(79,110,247,0.08); border:1px solid var(--border2);
  border-radius:5px; padding:4px 12px;
  font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--indigo3);
  margin-bottom:18px;
}
.pf-title { font-size:32px; font-weight:700; letter-spacing:-1px; margin-bottom:10px; }
.pf-desc { font-size:14px; color:var(--muted2); line-height:1.65; margin-bottom:28px; }
.pf-stats { display:flex; gap:28px; }
.pfs { text-align:center; }
.pfs-n { font-size:26px; font-weight:700; color:var(--indigo2); letter-spacing:-0.5px; }
.pfs-l { font-size:10px; color:var(--muted); margin-top:2px; text-transform:uppercase; letter-spacing:1px; }
.pf-screen {
  background:linear-gradient(165deg,rgba(16,24,41,0.98),var(--bg4));
  border:1px solid var(--border2);
  border-radius:16px;
  padding:0;
  overflow:hidden;
  box-shadow:
    0 32px 64px rgba(0,0,0,0.45),
    0 0 0 1px rgba(255,255,255,0.04) inset,
    inset 0 1px 0 rgba(255,255,255,0.06);
}
.pf-laptop-bar {
  display:flex; align-items:center; gap:8px;
  padding:12px 14px;
  background:linear-gradient(180deg,rgba(255,255,255,0.07),rgba(255,255,255,0.02));
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.pf-bar { display:flex; gap:6px; align-items:center; flex-shrink:0; }
.pf-dot {
  width:10px; height:10px; border-radius:50%;
  box-shadow:inset 0 -1px 2px rgba(0,0,0,0.25);
}
.pf-laptop-url {
  flex:1; text-align:center;
  font-size:11px; font-weight:500;
  letter-spacing:0.02em;
  color:var(--muted);
  font-variant-numeric:tabular-nums;
  padding:4px 12px;
  margin:0 8px;
  border-radius:6px;
  background:var(--glass);
  border:1px solid rgba(255,255,255,0.05);
}
.pf-iframe-wrap {
  position:relative;
  background:var(--bg);
  line-height:0;
}
.pf-iframe-wrap::after {
  content:'';
  position:absolute; left:0; right:0; bottom:0; height:32px;
  pointer-events:none;
  background:linear-gradient(180deg,transparent,var(--bg4));
  opacity:0.5;
}
.pf-iframe {
  width:100%; height:min(420px,52vh);
  min-height:280px;
  border:0;
  display:block;
  opacity:0;
  transition:opacity 0.5s ease;
}
.pf-iframe.is-loaded { opacity:1; }
.port-g { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.pc {
  background:var(--bg3); border:1px solid var(--border);
  border-radius:14px; padding:22px; transition:all .3s;
}
.pc:hover { border-color:var(--border2); transform:translateY(-2px); }
.pc-logo {
  width:40px; height:40px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:15px; color:#fff; margin-bottom:14px;
}
/* [Portafolio] Logos 64px — NERY/LOAN; LOAN en caja con gradiente blanco, colores nativos del PNG */
.port-g .pc-logo--asset {
  width:64px; height:64px; min-width:64px;
  padding:0; margin-bottom:14px; border-radius:12px;
  background:transparent;
  overflow:hidden;
}
.port-g .pc-logo--asset img {
  width:64px; height:64px; display:block;
  border-radius:12px;
  object-fit:cover;
}
.port-g .pc-logo--asset.pc-logo--loan {
  display:flex; align-items:center; justify-content:center;
  padding:7px; box-sizing:border-box;
  background:linear-gradient(155deg,#fff 0%,#f7f8fa 42%,#e8eaef 100%);
  border:1px solid rgba(255,255,255,0.85);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.95),0 1px 3px rgba(0,0,0,0.12);
  overflow:hidden;
}
.port-g .pc-logo--asset.pc-logo--loan img {
  width:auto; height:auto;
  max-width:52px; max-height:52px;
  object-fit:contain; object-position:center;
  border-radius:4px;
  padding:0;
  mix-blend-mode:normal;
  image-rendering:auto;
}
.port-g .pc-logo--zencyo {
  width:64px; height:64px; min-width:64px;
  margin-bottom:14px; border-radius:12px;
  font-size:22px; font-weight:800;
}
.pc-name { font-size:15px; font-weight:700; letter-spacing:-0.2px; margin-bottom:3px; }
.pc-type { font-size:11px; color:var(--muted); letter-spacing:1px; text-transform:uppercase; margin-bottom:10px; }
.pc-desc { font-size:13px; color:var(--muted2); line-height:1.5; }

/* ── IA ── */
#ia { padding:120px 0; }
.ia-g {
  background:var(--bg3); border:1px solid var(--border);
  border-radius:20px; padding:56px;
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start;
}
.ia-l h2 { text-align:left; margin-bottom:14px; }
.ia-l .sec-tag { justify-content:flex-start; }
.ia-l .sec-tag::before { display:none; }
.ia-p { font-size:15px; color:var(--muted2); line-height:1.65; margin-bottom:28px; }
.ia-feats { display:flex; flex-direction:column; gap:12px; }
.ia-f { display:flex; align-items:center; gap:10px; font-size:13px; color:var(--muted2); font-weight:500; }
.ia-ck {
  width:18px; height:18px; border-radius:5px; min-width:18px;
  background:rgba(79,110,247,0.1); border:1px solid rgba(79,110,247,0.25);
  display:flex; align-items:center; justify-content:center;
  font-size:10px; color:var(--indigo2); font-weight:700;
}
.ia-box {
  background:var(--bg4); border:1px solid var(--border);
  border-radius:16px; padding:28px;
}
.ia-box-t { font-size:16px; font-weight:700; letter-spacing:-0.3px; margin-bottom:6px; }
.ia-box-s { font-size:13px; color:var(--muted2); margin-bottom:20px; line-height:1.5; }
.ia-ta {
  width:100%; background:rgba(79,110,247,0.04);
  border:1px solid rgba(79,110,247,0.1); border-radius:10px;
  color:var(--txt); font-family:'DM Sans',sans-serif; font-size:14px;
  padding:13px 16px; outline:none; resize:vertical; min-height:90px;
  transition:all .2s; margin-bottom:10px;
}
.ia-ta:focus { border-color:var(--indigo); box-shadow:0 0 0 3px rgba(79,110,247,0.08); }
.ia-ta::placeholder { color:var(--muted); }
.ia-btn {
  width:100%; background:var(--indigo); color:#fff;
  font-family:'DM Sans',sans-serif; font-weight:600; font-size:14px;
  padding:13px; border:none; border-radius:10px; cursor:pointer;
  box-shadow:0 0 0 1px rgba(79,110,247,0.4),0 4px 20px rgba(79,110,247,0.25);
  transition:all .2s; display:flex; align-items:center; justify-content:center; gap:8px;
}
.ia-btn:hover:not(:disabled) { background:var(--indigo2); box-shadow:0 0 0 1px rgba(107,135,255,0.5),0 8px 32px rgba(79,110,247,0.4); transform:translateY(-1px); }
.ia-btn:disabled { opacity:0.85; cursor:wait; transform:none; }
.ia-btn #iaTxt { display:block; white-space:normal; line-height:1.35; text-align:center; }
.spin { width:16px; height:16px; border:1.5px solid rgba(79,110,247,0.2); border-top-color:var(--indigo2); border-radius:50%; animation:spin 1s linear infinite; }
/* [IA Elena] Salida con vidrio + animación */
.ia-res {
  display:none; margin-top:16px; border-radius:14px; overflow:hidden;
  border:1px solid rgba(184,212,255,0.18);
  background:rgba(6,9,15,0.35);
}
.ia-res.on { display:block; animation:elenaReveal .48s ease; }
@keyframes elenaReveal {
  from { opacity:0; transform:translateY(10px); }
  to { opacity:1; transform:translateY(0); }
}
.ia-res-c.elena-out {
  font-size:14px; color:var(--muted2); line-height:1.75;
  background:rgba(12,18,32,0.55);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  padding:20px 20px 18px;
  border-bottom:1px solid rgba(79,110,247,0.08);
}
.ia-res-c.elena-out h3 {
  color:var(--ice); font-size:16px; font-weight:700;
  margin:0 0 12px; letter-spacing:-0.02em;
  text-transform:none;
}
.ia-res-c.elena-out h3:not(:first-child) { margin-top:18px; }
.ia-res-c.elena-out p { margin:0 0 12px; }
.ia-res-c.elena-out p:last-child { margin-bottom:0; }
.ia-res-c.elena-out ul { padding-left:18px; margin:0 0 12px; }
.ia-res-c.elena-out li { margin-bottom:6px; color:var(--txt); }
.ia-res-c.elena-out strong { color:var(--indigo2); }
.ia-elena-footer {
  padding:16px 20px 20px;
  text-align:center;
  background:rgba(8,12,20,0.4);
}
.ia-elena-zoom {
  display:inline-flex; align-items:center; justify-content:center;
  min-height:48px; padding:12px 22px;
  font-size:14px; font-weight:700; letter-spacing:0.02em;
  color:var(--ice);
  border:1px solid rgba(184,212,255,0.45);
  border-radius:10px; text-decoration:none;
  background:rgba(184,212,255,0.08);
  transition:background .2s,border-color .2s,transform .2s;
}
.ia-elena-zoom:hover {
  background:rgba(184,212,255,0.14);
  border-color:var(--ice2);
  transform:translateY(-1px);
}
.ia-elena-zoom:focus-visible { outline:2px solid var(--indigo2); outline-offset:3px; }

/* ── EQUIPO — Tarjetas premium + bloque Squad ── */
#equipo { padding:120px 0; background:var(--bg2); }
.team-lead-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(18px,3vw,28px);
  max-width:920px; margin:0 auto;
}
/* [Equipo] Vidrio + borde luminoso --ice */
.tl-card {
  position:relative;
  display:flex;
  flex-direction:column;
  height:100%;
  border-radius:22px;
  padding:1px;
  background:linear-gradient(145deg,rgba(184,212,255,0.45),rgba(79,110,247,0.15));
  box-shadow:0 0 40px rgba(184,212,255,0.06),0 24px 64px rgba(0,0,0,0.35);
  transition:transform 0.3s ease;
}
.tl-card:hover {
  transform:translateY(-4px);
  box-shadow:0 0 48px rgba(184,212,255,0.12),0 28px 72px rgba(0,0,0,0.4);
}
.tl-card-inner {
  flex:1;
  display:flex;
  flex-direction:column;
  border-radius:21px;
  padding:clamp(24px,4vw,36px);
  text-align:center;
  background:rgba(12,18,32,0.55);
  backdrop-filter:blur(5px);
  -webkit-backdrop-filter:blur(5px);
  border:1px solid rgba(184,212,255,0.22);
}
.tl-avatar-wrap {
  width:132px; height:132px; margin:0 auto 20px;
  border-radius:50%;
  padding:3px;
  background:linear-gradient(135deg,rgba(184,212,255,0.5),rgba(79,110,247,0.35));
  box-shadow:0 0 28px rgba(79,110,247,0.2);
}
.tl-avatar {
  width:100%; height:100%; object-fit:cover;
  border-radius:50%; display:block;
  background-color:transparent;
}
.tl-name {
  font-size:clamp(18px,2.4vw,22px);
  font-weight:800;
  letter-spacing:-0.4px;
  color:var(--ice);
  margin:0 0 10px;
  line-height:1.15;
  min-height:2.6em;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.tl-role {
  font-size:10px;
  font-weight:700;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ice);
  opacity:0.92;
  margin:0 0 16px;
  line-height:1.45;
  min-height:4.2em;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.tl-desc {
  font-size:14px;
  color:var(--muted);
  line-height:1.65;
  margin:0;
  max-width:36ch;
  margin-left:auto; margin-right:auto;
}
.team-squad {
  max-width:640px;
  margin:clamp(40px,6vw,56px) auto 0;
  text-align:center;
  padding:0 12px;
}
.team-squad-title {
  font-size:clamp(15px,2vw,17px);
  font-weight:800;
  letter-spacing:0.12em;
  color:var(--ice);
  margin:0 0 14px;
  line-height:1.3;
}
.team-squad-desc {
  font-size:15px;
  color:var(--muted);
  line-height:1.7;
  margin:0;
}

/* ── CONTACTO ── */
#contacto { padding:120px 0; }
.ct-g { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.ct-l h2 { text-align:left; }
.ct-l .sec-tag { justify-content:flex-start; }
.ct-l .sec-tag::before { display:none; }
.ct-p { font-size:15px; color:var(--muted2); line-height:1.65; margin:0 0 32px; }
.ct-chs { display:flex; flex-direction:column; gap:12px; }
.ch {
  display:flex; align-items:center; gap:14px;
  background:var(--bg3); border:1px solid var(--border);
  border-radius:14px; padding:18px 20px; text-decoration:none; transition:all .3s;
}
.ch:hover { border-color:var(--border2); transform:translateX(4px); }
.ch-ico {
  width:42px; height:42px; min-width:42px; border-radius:10px;
  display:flex; align-items:center; justify-content:center; font-size:20px;
}
.ch-wa  { background:rgba(37,211,102,0.1); border:1px solid rgba(37,211,102,0.18); }
.ch-mail{ background:rgba(79,110,247,0.1); border:1px solid var(--border2); }
.ch-lbl { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-bottom:3px; }
.ch-val { font-size:14px; font-weight:700; color:var(--txt); }
.ch-hint{ font-size:11px; color:var(--muted); margin-top:2px; }
/* [Contacto] Cuadro cotización — vidrio alineado al panel hero */
.cf-box {
  background:rgba(12,18,32,0.72);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(184,212,255,0.14);
  border-radius:18px; padding:32px;
}
.cf-t { font-size:18px; font-weight:700; letter-spacing:-0.3px; margin-bottom:5px; }
.cf-s { font-size:13px; color:var(--muted2); margin-bottom:22px; }
.cf { display:flex; flex-direction:column; gap:12px; }
.cf-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.fg { display:flex; flex-direction:column; gap:5px; }
.fl {
  font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--ice);
}
.fi,.fta,.fsel {
  background:rgba(8,12,21,0.65);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  border:1px solid rgba(79,110,247,0.14);
  border-radius:9px; color:var(--txt); font-family:'DM Sans',sans-serif; font-size:14px;
  padding:11px 14px; outline:none; width:100%; transition:all .2s;
}
.fi:focus,.fta:focus,.fsel:focus { border-color:rgba(184,212,255,0.45); box-shadow:0 0 0 3px rgba(79,110,247,0.12); }
.fi::placeholder,.fta::placeholder { color:var(--muted); }
.fta { resize:vertical; min-height:90px; }
.fsel {
  cursor:pointer; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23B8D4FF' stroke-width='1.5' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center;
  padding-right:36px;
}
.fsel option { background:var(--bg3); color:var(--txt); }
.cf-hint {
  font-size:12px; color:var(--muted2); line-height:1.55;
  margin:4px 0 0; text-align:center;
}
.cf-id-hint {
  font-size:11px; color:var(--muted); line-height:1.45;
  margin:-4px 0 2px;
}
.cf-id-hint b { color:var(--ice); font-weight:700; }
.fsend {
  width:100%; background:var(--indigo); color:#fff;
  font-family:'DM Sans',sans-serif; font-weight:700; font-size:13px;
  letter-spacing:0.06em;
  padding:13px; border:none; border-radius:9px; cursor:pointer;
  box-shadow:0 0 0 1px rgba(79,110,247,0.4),0 4px 20px rgba(79,110,247,0.25);
  transition:all .2s; display:flex; align-items:center; justify-content:center; gap:8px;
}
.fsend:hover { background:var(--indigo2); transform:translateY(-1px); box-shadow:0 0 0 1px rgba(107,135,255,0.5),0 8px 32px rgba(79,110,247,0.4); }

/* ── FOOTER ── */
footer {
  background:var(--bg2); border-top:1px solid rgba(79,110,247,0.07);
  padding:56px 6% 40px; position:relative; z-index:1;
}
.ft-inner { max-width:1200px; margin:0 auto; }
.ft-top {
  display:grid; 
  /* CAMBIA ESTA LÍNEA DE AQUÍ: */
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr; /* Ahora son 5 columnas */
  gap: 40px; /* Reducimos un poco el gap para que todo entre bien */
  padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,0.04); margin-bottom:28px;
}
.ft-about { font-size:13px; color:var(--muted); line-height:1.7; margin-top:14px; max-width:240px; }
.ft-col-h { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--indigo3); margin-bottom:16px; }
.ft-ls { display:flex; flex-direction:column; gap:10px; }
.ft-ls a { font-size:13px; color:var(--muted2); text-decoration:none; transition:color .2s; font-weight:500; }
.ft-ls a:hover { color:var(--txt); }
.ft-bot { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px; }
.ft-cp { font-size:12px; color:var(--muted); }
.ft-cp b { color:var(--muted2); }
.ft-socs { display:flex; gap:8px; }
.ft-soc {
  width:32px; height:32px; border-radius:8px;
  background:var(--glass2); border:1px solid rgba(255,255,255,0.06);
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; font-size:13px; transition:all .2s; color:var(--muted2);
}
.ft-soc:hover { border-color:var(--border2); color:var(--indigo2); }

/* ── WA FLOAT ── */
.wa {
  position:fixed; bottom:24px; right:24px; z-index:500;
  width:52px; height:52px; border-radius:14px;
  background:#25D366; display:flex; align-items:center; justify-content:center;
  text-decoration:none; box-shadow:0 8px 28px rgba(37,211,102,0.35); transition:all .3s;
}
.wa:hover { transform:scale(1.08) translateY(-2px); box-shadow:0 14px 44px rgba(37,211,102,0.55); }
.wa svg { width:26px; height:26px; }
.wa-r { position:absolute; inset:-4px; border-radius:18px; border:1.5px solid rgba(37,211,102,0.35); animation:ring 2s ease infinite; }
