.elementor-1842 .elementor-element.elementor-element-ccc8b92{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1842 .elementor-element.elementor-element-87179b9{width:100%;max-width:100%;}.elementor-1842 .elementor-element.elementor-element-87179b9 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-1842 .elementor-element.elementor-element-3c2a9ea{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1842 .elementor-element.elementor-element-512cce0{width:100%;max-width:100%;}.elementor-1842 .elementor-element.elementor-element-512cce0 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-1842 .elementor-element.elementor-element-9a237c8{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1842 .elementor-element.elementor-element-463e6a3{width:100%;max-width:100%;}.elementor-1842 .elementor-element.elementor-element-463e6a3 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-1842 .elementor-element.elementor-element-79226b0{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1842 .elementor-element.elementor-element-12f811d{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1842 .elementor-element.elementor-element-1144d71{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1842 .elementor-element.elementor-element-3a77e46{width:100%;max-width:100%;}.elementor-1842 .elementor-element.elementor-element-3a77e46 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-1842 .elementor-element.elementor-element-4806c03{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1842 .elementor-element.elementor-element-8f07782{width:100%;max-width:100%;}.elementor-1842 .elementor-element.elementor-element-8f07782 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-1842 .elementor-element.elementor-element-9706f0a{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1842 .elementor-element.elementor-element-72b25c3{width:100%;max-width:100%;}.elementor-1842 .elementor-element.elementor-element-72b25c3 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-1842 .elementor-element.elementor-element-f45a86e{width:100%;max-width:100%;}.elementor-1842 .elementor-element.elementor-element-f45a86e > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-1842 .elementor-element.elementor-element-4d66b52{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1842 .elementor-element.elementor-element-185aadc{width:100%;max-width:100%;}.elementor-1842 .elementor-element.elementor-element-185aadc > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-1842 .elementor-element.elementor-element-c1a6cb4{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1842 .elementor-element.elementor-element-ecea7dc{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1842 .elementor-element.elementor-element-2fbf653{width:100%;max-width:100%;}.elementor-1842 .elementor-element.elementor-element-2fbf653 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}/* Start custom CSS for html, class: .elementor-element-87179b9 *//* =====================================================
   JACEO – ENGINEERED HERO FRAME
===================================================== */

#jaceo{
  --blue:#193886;
  --yellow:#feb42f;
  --white:#ffffff;
  --dark:#0c1222;
}

/* Reset */
#jaceo *{ box-sizing:border-box; }

/* ================= HERO ================= */

#jaceo .hero-frame{
  position:relative;
  min-height:100vh;
  padding:0 5%;
  display:flex;
  align-items:center;
  background:
    url("http://topmetalsupplier.com/wp-content/uploads/2026/01/Media_Portada_Top_Metal-5-scaled.png")
    center/cover no-repeat;
  color:var(--white);
  overflow:hidden;
}

/* ================= GRID (BLUEPRINT) ================= */

#jaceo .hero-grid{
  position:absolute;
  inset:0;
  background:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:80px 80px;
  pointer-events:none;
}

/* ================= LOGO STRUCTURE ================= */

#jaceo .hero-logo-structure{
  position:absolute;
  right:-15%;
  top:50%;
  transform:translateY(-50%);
  width:900px;
  height:900px;
  background:
    url("http://topmetalsupplier.com/wp-content/uploads/2025/11/Topmetal_logos_2025-08-3-scaled.png")
    center/contain no-repeat;
  opacity:0.035;
  filter:grayscale(100%);
  pointer-events:none;
}

/* ================= FRAME BOX ================= */

#jaceo .hero-frame-box{
  position:relative;
  max-width:1100px;
  padding:90px 110px;
  border:3px solid var(--blue);
  background:
    linear-gradient(180deg,
      rgba(25,56,134,.08),
      rgba(25,56,134,.02)
    );
}

/* yellow engineering corner */
#jaceo .hero-frame-box::before{
  content:"";
  position:absolute;
  top:-3px;
  left:-3px;
  width:140px;
  height:140px;
  border-top:6px solid var(--yellow);
  border-left:6px solid var(--yellow);
}

/* ================= CONTENT ================= */

#jaceo .hero-content h1{
  font-size:clamp(60px,6vw,96px);
  font-weight:900;
  line-height:1.02;
  margin-bottom:28px;
}

#jaceo .hero-content p{
  max-width:720px;
  font-size:20px;
  line-height:1.7;
  margin-bottom:56px;
  color:rgba(255,255,255,.9);
}

/* ================= BUTTONS ================= */

#jaceo .hero-actions{
  display:flex;
  gap:22px;
}

#jaceo .btn-primary{
  background:var(--blue);
  color:#fff;
  padding:18px 48px;
  font-weight:900;
  letter-spacing:.12em;
  text-decoration:none;
}

#jaceo .btn-secondary{
  background:var(--yellow);
  color:#000;
  padding:18px 48px;
  font-weight:900;
  letter-spacing:.12em;
  text-decoration:none;
}

/* =====================================================
   HERO MOBILE FIX: NO SE VE LA SIGUIENTE SECCIÓN
   (mantiene el hero en 100% viewport y compacta contenido)
===================================================== */

@media (max-width: 900px){

  /* el hero vuelve a ocupar todo el alto visible del móvil */
  #jaceo .hero-frame{
    min-height: 100svh;       /* 🔥 mejor que 100vh en móviles */
    padding: 78px 7% 78px;    /* 🔥 top/bottom reales */
    align-items: center;      /* centra el bloque */
  }

  /* el frame ya no puede ser gigante */
  #jaceo .hero-frame-box{
    width: 100%;
    max-width: 100%;
    padding: 34px 24px;       /* 🔥 compacto */
    border-width: 2px;
  }

  #jaceo .hero-frame-box::before{
    width: 72px;
    height: 72px;
    border-width: 4px;
  }

  /* tipografía y espacios compactos para que no “empuje” */
  #jaceo .hero-content h1{
    font-size: clamp(38px, 9vw, 56px);
    margin-bottom: 16px;
    line-height: 1.02;
  }

  #jaceo .hero-content p{
    font-size: 15px;
    line-height: 1.65;
    margin-bottom: 24px;
  }

  /* botones full-width para que no rompa el layout */
  #jaceo .hero-actions{
    flex-direction: column;
    gap: 12px;
  }

  #jaceo .btn-primary,
  #jaceo .btn-secondary{
    width: 100%;
    text-align: center;
    padding: 14px 18px;
  }
}

@media (max-width: 600px){

  #jaceo .hero-frame{
    min-height: 100svh;
    padding: 68px 6% 68px;
  }

  #jaceo .hero-frame-box{
    padding: 28px 18px;
  }

  #jaceo .hero-content h1{
    font-size: clamp(34px, 10vw, 48px);
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-512cce0 *//* =====================================================
   JACEO – PEOPLE & ENGINEERING (FINAL REAL FIX)
   Blue:   #193886
   Yellow: #feb42f
===================================================== */

#jaceo{
  --blue:#193886;
  --yellow:#feb42f;
  overflow-x:hidden;
}

#jaceo *,
#jaceo *::before,
#jaceo *::after{
  box-sizing:border-box;
}

/* ================= SECTION ================= */

#jaceo .tm-people-100vh{
  width:100%;
  height:100vh;
  background:#ffffff;
  display:flex;
  flex-direction:column;
}

/* ================= MAIN GRID (5% REAL) ================= */

#jaceo .tm-people-main{
  flex:1;
  width:100%;
  padding-left:5%;
  padding-right:5%;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:120px;
  align-items:center; /* 🔥 CLAVE */
}

/* ================= IMAGE (CENTRADA REAL) ================= */

#jaceo .tm-people-image{
  display:flex;
  align-items:center;     /* centra vertical */
  justify-content:center; /* centra horizontal */
}

#jaceo .tm-people-image img{
  width:100%;
  max-height:520px;
  object-fit:cover;
  border-radius:28px;
  box-shadow:0 40px 110px rgba(0,0,0,.28);
  display:block;
}

/* ================= CONTENT ================= */

#jaceo .tm-people-content{
  display:flex;
  flex-direction:column;
  justify-content:center;
}

/* Logo */
#jaceo .tm-people-logo{
  width:140px;
  margin-bottom:26px;
}

#jaceo .tm-people-logo img{
  width:100%;
  display:block;
}

/* Title */
#jaceo .tm-people-content h2{
  font-size:46px;
  font-weight:900;
  line-height:1.15;
  margin-bottom:22px;
  color:#0b0b0b;
}

/* Paragraph */
#jaceo .tm-people-content p{
  font-size:16px;
  line-height:1.85;
  color:#1f2937;
  text-align:justify;
  margin:0;
}

/* ================= ENGINEERING STRIP ================= */

#jaceo .tm-engineering-strip{
  width:100%;
  background:#f9fafb;
  border-top:1px solid rgba(25,56,134,.18);
  padding:26px 0;
}

#jaceo .tm-engineering-wrap{
  width:100%;
  padding-left:5%;
  padding-right:5%;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:60px;
}

#jaceo .tm-eng-block{
  position:relative;
  padding-left:22px;
}

#jaceo .tm-eng-block::before{
  content:"■";
  position:absolute;
  left:0;
  top:6px;
  color:var(--yellow);
}

#jaceo .tm-eng-block h3{
  font-size:20px;
  font-weight:900;
  color:var(--blue);
  margin-bottom:6px;
}

#jaceo .tm-eng-block p{
  font-size:16px;
  color:#0b0b0b;
  margin:0;
}

/* ================= RESPONSIVE ================= */

@media(max-width:1200px){

  #jaceo .tm-people-100vh{
    height:auto;
  }

  #jaceo .tm-people-main{
    grid-template-columns:1fr;
    gap:80px;
    padding:120px 5% 60px;
  }

  #jaceo .tm-engineering-wrap{
    grid-template-columns:1fr;
    gap:28px;
  }
}

@media(max-width:640px){

  #jaceo .tm-people-main{
    padding:100px 7% 50px;
  }

  #jaceo .tm-people-content h2{
    font-size:34px;
  }

  #jaceo .tm-people-image img{
    max-height:420px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-463e6a3 *//* =====================================================
   JACEO – TRUST & CERTIFICATIONS (ENHANCED)
===================================================== */

#jaceo .cert{ cursor:pointer; }


#jaceo{
  --blue:#193886;
  --yellow:#feb42f;
  --navy:#070f28;
  --navy-soft:#0b1536;
  --navy-deep:#050b20;
  --text:#ffffff;
  --muted:rgba(255,255,255,.78);
  --line:rgba(255,255,255,.12);
}

/* Reset */
#jaceo *{
  box-sizing:border-box;
}

/* ================= SECTION ================= */

#jaceo .trust-100vh{
  width:100%;
  min-height:100vh;
  background:
    radial-gradient(1200px 60px at 10% 20%, rgba(25,56,134,.18), transparent 60%),
    radial-gradient(800px 500px at 90% 80%, rgba(254,180,47,.08), transparent 60%),
    linear-gradient(180deg,var(--navy-deep),var(--navy-soft));
  padding:120px 0;
  display:flex;
  align-items:center;
  position:relative;
  overflow:hidden;
}

/* ================= WRAP ================= */

#jaceo .trust-100vh .wrap{
  width:100%;
  max-width:1900px;
  margin:auto;
  padding:0 5%;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:120px;
  align-items:center;
}

/* ================= LEFT COPY ================= */

#jaceo .trust-copy{
  max-width:740px;
}

#jaceo .trust-copy .line{
  width:84px;
  height:3px;
  background:linear-gradient(90deg,var(--yellow),transparent);
  margin-bottom:22px;
}

#jaceo .trust-copy h2{
  font-size:clamp(44px,5vw,66px);
  font-weight:900;
  line-height:1.08;
  margin-bottom:22px;
  color:var(--text);
  letter-spacing:-.02em;
}

#jaceo .trust-copy p{
  font-size:20px;
  line-height:1.75;
  color:var(--muted);
  margin-bottom:40px;
  max-width:680px;
}

#jaceo .trust-copy .divider{
  width:160px;
  height:1px;
  background:linear-gradient(90deg,var(--line),transparent);
}

/* ================= CERTS GRID ================= */

#jaceo .trust-certs{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:42px;
  align-items:center;
}

/* ================= CERT CARD ================= */





/* ================= CERT CARD – CONTROL TOTAL ================= */

#jaceo .cert{
  width:380px;          /* TODOS IGUALES */
  height:300px;         /* PROPORCIÓN LIMPIA (NO LARGOS) */

  background:
    linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.01)),
    linear-gradient(180deg,#0e1d4d,#091437);

  border:1px solid rgba(255,255,255,.14);
  padding:40px;

  display:flex;
  align-items:center;
  justify-content:center;

  box-shadow:
    0 22px 60px rgba(0,0,0,.45),
    inset 0 1px 0 rgba(255,255,255,.08);
}

/* IMAGEN */
#jaceo .cert img{
  max-width:240px;
  max-height:180px;
  width:auto;
  height:auto;
  object-fit:contain;
}






#jaceo .cert{
  position:relative;
  background:
    linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.01)),
    linear-gradient(180deg,#0e1d4d,#091437);
  border:1px solid rgba(255,255,255,.14);
  padding:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:
    0 22px 60px rgba(0,0,0,.45),
    inset 0 1px 0 rgba(255,255,255,.08);
  transition:transform .35s ease, box-shadow .35s ease;
}

/* subtle glow edge */
#jaceo .cert::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:linear-gradient(120deg,transparent,rgba(254,180,47,.18),transparent);
  opacity:0;
  transition:opacity .35s ease;
}

/* Desktop hover only */
@media (hover:hover){
  #jaceo .cert:hover{
    transform:translateY(-6px);
    box-shadow:0 32px 80px rgba(0,0,0,.55);
  }
  #jaceo .cert:hover::before{
    opacity:1;
  }
}

#jaceo .cert img{
  width:100%;
  max-width:320px;
  height:auto;
  display:block;
  filter:brightness(1.08) contrast(1.05);
}

/* Center last cert */
#jaceo .cert:nth-child(3){
  grid-column:1 / -1;
  justify-self:center;
  max-width:380px;
}

/* =========================================
   FIX RESPONSIVE CERTS: 1 x 1 (stack vertical)
   Pegar al FINAL del CSS
========================================= */

/* Tablet y abajo: SIEMPRE 1 columna */
@media (max-width:1200px){
  #jaceo .trust-certs{
    grid-template-columns:1fr !important;
  }

  /* Para que no queden cortados si usas width fijo */
  #jaceo .cert{
    width:100% !important;
    max-width:520px !important; /* ajusta si quieres más grande */
    height:auto !important;     /* evita “bloques raros” */
    margin:0 auto !important;
  }

  #jaceo .cert img{
    max-width:320px !important;
    height:auto !important;
  }

  /* Quita cualquier “centrado especial” del 3ro */
  #jaceo .cert:nth-child(3){
    grid-column:auto !important;
    justify-self:stretch !important;
    max-width:520px !important;
  }
}
/* =========================================
   FIX MOBILE: CERTS DEBAJO DEL TEXTO
========================================= */

@media (max-width:600px){

  /* Quitar centrado vertical que los “desaparece” */
  #jaceo .trust-100vh{
    min-height:auto !important;
    display:block !important;
    padding:80px 0 !important;
  }

  /* Stack natural: texto arriba, certs abajo */
  #jaceo .trust-100vh .wrap{
    display:block !important;
  }

  /* Separación clara entre texto y certs */
  #jaceo .trust-copy{
    margin-bottom:48px;
  }

  /* Certificados en columna, visibles */
  #jaceo .trust-certs{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:28px !important;
  }

  /* Cards fluidas en mobile */
  #jaceo .cert{
    width:100% !important;
    max-width:100% !important;
    height:auto !important;
    margin:0 auto !important;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-3a77e46 *//* =====================================================
   JACEO – LOCATION (FINAL FIXED VERSION)
   Yellow: #feb42f
   Blue:   #193886
===================================================== */

#jaceo{
  --blue:#193886;
  --yellow:#feb42f;
  --white:#ffffff;
  --gray-soft:rgba(255,255,255,.72);
  --line-soft:rgba(255,255,255,.16);
}

/* Reset interno */
#jaceo *,
#jaceo *::before,
#jaceo *::after{
  box-sizing:border-box;
}

/* ================= SECTION ================= */

#jaceo .location-hero{
  width:100%;
  min-height:100vh;
  background:radial-gradient(circle at center, #111 0%, #000 70%);
  color:var(--white);
  display:flex;
  align-items:center;
  padding:80px 0;
  isolation:isolate;
}

/* ===== 5% REAL MARGINS ===== */
#jaceo .location-inner{
  width:100%;
  padding-left:5%;
  padding-right:5%;
}

/* ================= HEADER ================= */

#jaceo .location-header{
  max-width:760px;
  margin-bottom:56px;
}

#jaceo .location-header .line{
  width:72px;
  height:3px;
  background:var(--yellow);
  margin-bottom:18px;
}

#jaceo .location-header h2{
  font-size:48px;
  font-weight:800;
  margin-bottom:14px;
}

#jaceo .location-header p{
  font-size:18px;
  line-height:1.65;
  color:var(--gray-soft);
}

/* ================= GRID ================= */

#jaceo .location-grid{
  display:grid;
  grid-template-columns:1.25fr .75fr;
  gap:60px;
  align-items:stretch;
}

/* ================= MAP ================= */

#jaceo .map-box{
  border:3px solid var(--blue);
  height:420px;
}

#jaceo .map-box iframe{
  width:100%;
  height:100%;
  border:0;
}

/* ================= INFO ================= */

#jaceo .location-info{
  background:#0f0f0f;
  border-left:5px solid var(--yellow);
  padding:40px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:420px;
}

#jaceo .location-info h3{
  font-size:26px;
  margin-bottom:26px;
}

/* Info lines */
#jaceo .info-item{
  font-size:16px;
  line-height:1.6;
  color:var(--gray-soft);
  margin-bottom:16px;
  padding-bottom:14px;
  border-bottom:1px solid var(--line-soft);
}

#jaceo .info-item:last-child{
  border-bottom:0;
  margin-bottom:0;
}

#jaceo .info-item strong{
  color:var(--white);
}

/* ================= BUTTONS ================= */

#jaceo .info-actions{
  display:flex;
  gap:16px;
  margin-top:30px;
  flex-wrap:wrap;
}

#jaceo .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 36px;
  font-weight:800;
  letter-spacing:.08em;
  text-decoration:none;
  white-space:nowrap;
  border:0;
  outline:0;
  box-shadow:none;
  transition:transform .25s ease, box-shadow .25s ease;
}

/* CALL NOW – azul sólido SIN BORDE (desktop + mobile) */
#jaceo .btn-call{
  background:var(--blue);
  color:var(--white);
  border:0;
  box-shadow:none;
}

/* DROP US A LINE */
#jaceo .btn-line{
  background:var(--yellow);
  color:#000;
  border:0;
  box-shadow:none;
}

#jaceo .btn:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 32px rgba(0,0,0,.35);
}

/* ================= BUTTON FIX – REMOVE WHITE LINE ================= */

#jaceo .btn-call,
#jaceo .btn-call:hover,
#jaceo .btn-call:focus,
#jaceo .btn-call:active,
#jaceo .btn-call:visited{
  background:var(--blue);
  color:var(--white);
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  -webkit-tap-highlight-color:transparent;
}


/* ================= RESPONSIVE ================= */

@media(max-width:1000px){

  #jaceo .location-grid{
    grid-template-columns:1fr;
    gap:40px;
  }

  #jaceo .map-box{
    height:320px;
  }

  #jaceo .location-info{
    min-height:auto;
  }
}

@media(max-width:600px){

  #jaceo .location-hero{
    padding:100px 0 80px;
    align-items:flex-start;
  }

  #jaceo .location-inner{
    padding-left:7%;
    padding-right:7%;
  }

  #jaceo .location-header h2{
    font-size:38px;
  }

  #jaceo .info-actions{
    flex-direction:column;
  }

  #jaceo .btn{
    width:100%;
    border:0;
    box-shadow:none;
  }

  /* refuerzo extra: nunca borde en mobile */
  #jaceo .btn-call{
    border:0;
    box-shadow:none;
  }
}



@media(max-width:600px){

  #jaceo .map-box{
    height:300px; /* más bajo, no se corta */
  }

  #jaceo .location-hero{
    padding-bottom:160px; /* evita que la siguiente sección lo tape */
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-8f07782 *//* =====================================================
   JACEO – WHAT WE DO (OFFICIAL COLORS)
   Yellow: #feb42f
   Blue:   #193886
===================================================== */

#jaceo{
  --blue:#193886;
  --yellow:#feb42f;
  --black:#0b0b0b;
  --white:#ffffff;
  --gray:#6b6b6b;
  --light:#f7f7f7;
}

/* Reset interno */
#jaceo *,
#jaceo *::before,
#jaceo *::after{
  box-sizing:border-box;
}

/* ================= SECTION ================= */

#jaceo .whatwedo{
  background:#ffffff;
  padding:110px 5%;
  color:#111;
}

/* ================= HEADER ================= */

#jaceo .whatwedo-header{
  max-width:820px;
  margin-bottom:80px;
}

#jaceo .whatwedo-header span{
  display:inline-block;
  width:70px;
  height:4px;
  background:var(--yellow);
  margin-bottom:22px;
}

#jaceo .whatwedo-header h2{
  font-size:52px;
  font-weight:800;
  margin-bottom:18px;
  letter-spacing:-.02em;
}

#jaceo .whatwedo-header p{
  font-size:20px;
  line-height:1.7;
  color:#555;
}

/* ================= GRID ================= */

#jaceo .whatwedo-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:42px;
}

/* ================= CARD ================= */

#jaceo .wedo-card{
  background:var(--light);
  border-top:5px solid var(--blue);
  padding:44px 34px;
  transition:
    transform .35s ease,
    box-shadow .35s ease;
}

#jaceo .wedo-card:hover{
  transform:translateY(-10px);
  box-shadow:0 18px 45px rgba(0,0,0,.12);
}

#jaceo .wedo-card h3{
  font-size:22px;
  margin-bottom:16px;
  font-weight:800;
  color:var(--blue);
}

#jaceo .wedo-card p{
  font-size:16px;
  line-height:1.65;
  color:#444;
}

/* ================= TARGET ================= */

#jaceo .wedo-target{
  margin-top:90px;
  padding-top:50px;
  border-top:1px solid #e5e5e5;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:30px;
}

#jaceo .target-list{
  display:flex;
  gap:34px;
  font-weight:700;
  color:#111;
}

#jaceo .target-list span{
  position:relative;
  padding-left:18px;
}

#jaceo .target-list span::before{
  content:"■";
  color:var(--yellow);
  position:absolute;
  left:0;
  top:1px;
}

/* ================= CTA ================= */

#jaceo .wedo-cta a{
  display:inline-block;
  background:var(--blue);
  color:var(--white);
  padding:16px 40px;
  font-weight:800;
  letter-spacing:.06em;
  text-decoration:none;
  border:3px solid var(--blue);
  transition:
    background .3s ease,
    color .3s ease,
    transform .3s ease;
}

#jaceo .wedo-cta a:hover{
  background:transparent;
  color:var(--blue);
  transform:scale(1.06);
}

/* ================= RESPONSIVE ================= */

@media(max-width:1200px){
  #jaceo .whatwedo-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:650px){
  #jaceo .whatwedo-grid{
    grid-template-columns:1fr;
  }

  #jaceo .whatwedo-header h2{
    font-size:40px;
  }
}


@media(max-width:650px){

  #jaceo .wedo-target{
    flex-direction:column;
    align-items:flex-start;
    gap:26px;
  }

  #jaceo .target-list{
    flex-wrap:wrap;
    gap:16px 26px;
  }

  #jaceo .whatwedo{
    padding-bottom:180px; /* refuerzo mobile */
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-72b25c3 *//* =====================================================
   TOP METAL – GALLERY HEADER (COMPACT / PREMIUM)
   Palette: Blue #193886 | Yellow #feb42f
   REAL 5% margins – no extra whitespace
===================================================== */

#tmGalleryHeader{
  position:relative;
  background:
    linear-gradient(
      180deg,
      #ffffff 0%,
      #eef2fa 38%,
      #ffffff 100%
    );
  padding:110px 0 56px; /* compacto, sin aire abajo */
}

/* ===== REAL 5% ===== */
#tmGalleryHeader .tm-gallery-inner{
  width:100%;
  padding-left:5%;
  padding-right:5%;
}

/* ================= KICKER ================= */

#tmGalleryHeader .tm-gallery-kicker{
  display:inline-block;
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#193886;
  margin-bottom:14px;
}

#tmGalleryHeader .tm-gallery-kicker::after{
  content:"";
  display:block;
  width:64px;
  height:3px;
  background:#feb42f;
  margin-top:8px;
}

/* ================= TITLE ================= */

#tmGalleryHeader .tm-gallery-title{
  font-family:"Poppins",system-ui,sans-serif;
  font-size:clamp(38px,4.4vw,56px);
  font-weight:900;
  line-height:1.06;
  letter-spacing:-.02em;
  color:#0f2356;
  margin:0 0 16px;
  max-width:1000px;
}

/* ================= DESCRIPTION ================= */

#tmGalleryHeader .tm-gallery-desc{
  font-family:"Montserrat",system-ui,sans-serif;
  font-size:17px;
  line-height:1.75;
  color:#2a344a;
  max-width:860px;
  margin:0; /* CLAVE: sin espacio debajo */
  text-align:justify;
  text-justify:inter-word;
}

/* ================= RESPONSIVE ================= */

@media(max-width:640px){

  #tmGalleryHeader{
    padding:86px 0 44px;
  }

  #tmGalleryHeader .tm-gallery-inner{
    padding-left:7%;
    padding-right:7%;
  }

  #tmGalleryHeader .tm-gallery-title{
    font-size:34px;
    line-height:1.08;
  }

  #tmGalleryHeader .tm-gallery-desc{
    font-size:15.5px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-f45a86e *//* 1) Por si Elementor mete margen/padding arriba */
#tmGalleryPro,
#tmGalleryPro .tg-wrap,
#tmGalleryPro .tg-grid{
  margin-top:0 !important;
  padding-top:0 !important;
}

/* 2) Evita colapso de márgenes si hay un título/elemento antes del grid */
#tmGalleryPro .tg-wrap{
  display:flow-root;
}

/* 3) Si hay algún heading o bloque arriba del grid (aunque no lo veas) */
#tmGalleryPro .tg-wrap > *:first-child{
  margin-top:0 !important;
  padding-top:0 !important;
}

/* 4) Si el grid tiene margen por defecto en tu builder */
#tmGalleryPro .tg-grid{
  margin:0 !important;
}






#tmGalleryPro{
  background:#ffffff;
  padding:140px 0;
}

#tmGalleryPro *{ box-sizing:border-box; }

#tmGalleryPro .tg-wrap{
  width:100%;
  padding-left:5%;
  padding-right:5%;
}

#tmGalleryPro .tg-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:repeat(4,220px);
  gap:28px;
}

/* ITEM */
#tmGalleryPro .tg-item{
  position:relative;
  overflow:hidden;
  border-radius:26px;
  background:#f4f6fb;
  box-shadow:0 30px 80px rgba(0,0,0,.18);
  cursor:zoom-in;
}

/* IMAGE */
#tmGalleryPro img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.04);
  transition:transform .9s cubic-bezier(.22,.61,.36,1);
}

/* OVERLAY (NO BLOCK CLICKS) */
#tmGalleryPro .tg-item::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(
    180deg,
    rgba(0,0,0,0) 35%,
    rgba(0,0,0,.45) 100%
  );
  opacity:.42;
  transition:opacity .6s ease;
  pointer-events:none; /* 🔑 FIX */
}

@media (hover:hover){
  #tmGalleryPro .tg-item:hover img{ transform:scale(1.14); }
  #tmGalleryPro .tg-item:hover::after{ opacity:.26; }
}

/* GRID POSITIONS */
#tmGalleryPro .tg-main{ grid-column:1 / 3; grid-row:1 / 4; }
#tmGalleryPro .tg-img2{ grid-column:3 / 4; grid-row:1 / 2; }
#tmGalleryPro .tg-img6{ grid-column:4 / 5; grid-row:1 / 2; }
#tmGalleryPro .tg-img3{ grid-column:3 / 5; grid-row:2 / 5; }
#tmGalleryPro .tg-img4{ grid-column:1 / 2; grid-row:4 / 5; }
#tmGalleryPro .tg-img5{ grid-column:2 / 3; grid-row:4 / 5; }

/* RESPONSIVE */
@media(max-width:1100px){
  #tmGalleryPro .tg-grid{
    grid-template-columns:repeat(2,1fr);
    grid-template-rows:auto;
  }

  #tmGalleryPro .tg-main{
    grid-column:1 / -1;
    min-height:420px;
  }

  #tmGalleryPro .tg-item{
    min-height:240px;
  }
}

@media(max-width:640px){
  #tmGalleryPro{
    padding:100px 0;
  }

  #tmGalleryPro .tg-wrap{
    padding-left:7%;
    padding-right:7%;
  }

  #tmGalleryPro .tg-grid{
    grid-template-columns:1fr;
  }

  #tmGalleryPro .tg-item{
    min-height:260px;
  }
}

/* =====================================================
   MODAL
===================================================== */

#tmGalleryModal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:9999;
}

#tmGalleryModal.is-open{
  display:flex;
}

#tmGalleryModal .tgm-backdrop{
  position:absolute;
  inset:0;
  background:rgba(5,11,32,.92);
  backdrop-filter:blur(6px);
}

#tmGalleryModal .tg-modal-content{
  position:relative;
  max-width:90vw;
  max-height:90vh;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 60px 160px rgba(0,0,0,.65);
  animation:tgZoomIn .35s cubic-bezier(.22,.61,.36,1);
  z-index:2;
}

#tmGalleryModal img{
  width:100%;
  height:100%;
  max-height:90vh;
  object-fit:contain;
  background:#050b20;
}

#tmGalleryModal .tgm-close{
  position:absolute;
  top:18px;
  right:18px;
  width:46px;
  height:46px;
  border-radius:50%;
  border:0;
  cursor:pointer;
  font-size:28px;
  color:#fff;
  background:rgba(255,255,255,.12);
  backdrop-filter:blur(6px);
}

@keyframes tgZoomIn{
  from{ opacity:0; transform:scale(.92); }
  to{ opacity:1; transform:scale(1); }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-185aadc *//* =====================================================
   JACEO – PREMIUM CTA (OFFICIAL COLORS)
   Yellow: #feb42f
   Blue:   #193886
===================================================== */

#jaceo{
  --blue:#193886;
  --yellow:#feb42f;
  --ink:#0b0b0b;
  --muted:#6b7280;
  --paper:#ffffff;
  --soft:#f4f6f9;
  --radius:16px;
}

/* Reset interno */
#jaceo *,
#jaceo *::before,
#jaceo *::after{
  box-sizing:border-box;
}

/* ================= CTA SECTION ================= */

#jaceo .cta-premium{
  width:100%;
  padding:110px 5%;
  background:linear-gradient(
    180deg,
    #ffffff 0%,
    #f7f9ff 60%,
    #ffffff 100%
  );
}

/* Layout */
#jaceo .cta-premium .wrap{
  max-width:1600px;
  margin:auto;
  display:grid;
  grid-template-columns:1.05fr 0.95fr;
  gap:70px;
  align-items:center;
}

/* ================= COLLAGE ================= */

#jaceo .collage{
  position:relative;
  min-height:520px;
}

#jaceo .img-card{
  position:absolute;
  overflow:hidden;
  border-radius:var(--radius);
  background:#ddd;
  box-shadow:0 22px 60px rgba(0,0,0,.12);
  border:1px solid rgba(0,0,0,.08);
}

#jaceo .img-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.02);
}

/* Image placements */
#jaceo .img-1{
  left:0;
  top:0;
  width:58%;
  height:62%;
}

#jaceo .img-2{
  right:0;
  bottom:0;
  width:56%;
  height:60%;
}

/* Decorative accents */
#jaceo .accent{
  position:absolute;
  width:26px;
  height:26px;
  background:var(--yellow);
}

#jaceo .accent.a1{ top:-10px; left:48%; }
#jaceo .accent.a2{ bottom:44%; left:-10px; background:var(--blue); }
#jaceo .accent.a3{ top:52%; right:-10px; background:var(--blue); }


#jaceo .stat.s1 .label,
#jaceo .stat.s2 .label{
  color:#0b0b0b;
}



/* Stats cards */
#jaceo .stat{
  position:absolute;
  background:var(--paper);
  border-radius:14px;
  padding:18px 20px;
  min-width:230px;
  box-shadow:0 20px 55px rgba(0,0,0,.14);
  border:1px solid rgba(0,0,0,.08);
}

#jaceo .stat .big{
  font-size:34px;
  font-weight:900;
  letter-spacing:.02em;
  color:var(--blue);
  line-height:1.05;
}

#jaceo .stat .label{
  margin-top:8px;
  color:var(--muted);
  font-size:14px;
  line-height:1.4;
}

#jaceo .stat.s1{ left:18px; bottom:44px; }
#jaceo .stat.s2{ right:26px; top:44px; }

/* Chips */
#jaceo .chip{
  position:absolute;
  width:14px;
  height:14px;
  top:-7px;
  right:16px;
  background:var(--yellow);
}

#jaceo .stat.s2 .chip{
  background:var(--blue);
}

/* ================= CONTENT ================= */

#jaceo .content{
  background:var(--paper);
  border-radius:var(--radius);
  padding:54px;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 20px 55px rgba(0,0,0,.08);
}

#jaceo .kicker{
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--blue);
  font-size:12px;
  margin-bottom:18px;
}

#jaceo .kicker::before{
  content:"";
  width:54px;
  height:4px;
  background:var(--yellow);
}

#jaceo .content h2{
  font-size:42px;
  line-height:1.15;
  margin-bottom:16px;
  font-weight:900;
  color:#0f172a;
}

#jaceo .sub{
  font-size:18px;
  line-height:1.7;
  color:#374151;
  margin-bottom:26px;
  max-width:560px;
}

/* Bullets */
#jaceo .bullets{
  display:grid;
  gap:12px;
  margin-bottom:34px;
}

#jaceo .bullets div{
  display:flex;
  gap:12px;
  color:#374151;
  font-size:16px;
  line-height:1.55;
}

#jaceo .bullets div::before{
  content:"■";
  color:var(--yellow);
  font-size:12px;
  margin-top:2px;
}

/* Buttons */
#jaceo .actions{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}

#jaceo .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:16px 34px;
  font-weight:900;
  letter-spacing:.03em;
  text-decoration:none;
  border:3px solid;
  transition:
    transform .32s ease,
    box-shadow .32s ease,
    background .32s ease,
    color .32s ease;
}

#jaceo .btn.call{
  background:var(--blue);
  border-color:var(--blue);
  color:#fff;
}

#jaceo .btn.quote{
  background:var(--yellow);
  border-color:var(--yellow);
  color:#0b0b0b;
}

#jaceo .btn:hover{
  transform:scale(1.08);
  box-shadow:0 22px 50px rgba(0,0,0,.18);
}


/* ================= RESPONSIVE ================= */

@media(max-width:1100px){
  #jaceo .cta-premium .wrap{
    grid-template-columns:1fr;
    gap:48px;
  }
}

@media(max-width:640px){
  #jaceo .cta-premium{
    padding:90px 7%;
  }

  #jaceo .content{
    padding:40px 26px;
  }

  #jaceo .content h2{
    font-size:34px;
  }

  #jaceo .stat{
    min-width:200px;
  }

  #jaceo .img-1,
  #jaceo .img-2{
    width:100%;
    left:0;
    right:auto;
  }

  #jaceo .img-1{ top:0; height:260px; }
  #jaceo .img-2{ bottom:0; height:240px; }

  #jaceo .stat.s2{ right:18px; top:18px; }
  #jaceo .stat.s1{ left:18px; bottom:18px; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-2fbf653 *//* =====================================================
   JACEO – FAQ FINAL RESTRUCTURED
===================================================== */

#jaceo{
  --blue:#193886;
  --yellow:#feb42f;
  --bg1:#0b1536;
  --bg2:#070f28;
  --text:#ffffff;
  --muted:#cbd3e6;
  --line:rgba(255,255,255,.1);
}

/* Reset */
#jaceo *{ box-sizing:border-box; }

/* ================= SECTION ================= */

#jaceo .faq-section{
  min-height:100vh;
  padding:90px 5%;
  background:linear-gradient(180deg,var(--bg1),var(--bg2));
  color:var(--text);
  display:flex;
  align-items:center;
}

#jaceo .faq-container{
  width:100%;
  max-width:1800px;
  margin:auto;
}

/* ================= HEADER ================= */

#jaceo .faq-head{
  max-width:900px;
  margin-bottom:70px;
}

#jaceo .faq-head .line{
  display:block;
  width:90px;
  height:4px;
  background:var(--yellow);
  margin-bottom:26px;
}

#jaceo .faq-head h2{
  font-size:56px;
  font-weight:900;
  margin-bottom:18px;
}

#jaceo .faq-head p{
  font-size:20px;
  line-height:1.7;
  color:var(--muted);
}

/* ================= BODY ================= */

#jaceo .faq-body{
  display:grid;
  grid-template-columns:420px 1fr;
  gap:80px;
}

/* ================= QUESTIONS ================= */

#jaceo .faq-questions{
  border-top:1px solid var(--line);
}

#jaceo .faq-q{
  all:unset;
  display:block;
  width:100%;
  padding:26px 0 26px 22px;
  border-bottom:1px solid var(--line);
  cursor:pointer;
  font-size:17px;
  color:var(--muted);
  position:relative;
  transition:.25s ease;
}

#jaceo .faq-q::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:4px;
  height:100%;
  background:transparent;
  transition:.25s ease;
}

#jaceo .faq-q:hover{
  color:#fff;
}

#jaceo .faq-q.active{
  color:#fff;
  font-weight:700;
}

#jaceo .faq-q.active::before{
  background:var(--yellow);
}

/* ================= ANSWER ================= */

#jaceo .faq-answer{
  background:linear-gradient(180deg,#0f255f,#0b1c45);
  border-left:4px solid var(--yellow);
  padding:0;
  display:flex;
}

#jaceo .faq-answer-inner{
  padding:64px 72px;
  max-width:900px;
  transition:opacity .25s ease;
}

#jaceo .faq-answer-inner h3{
  font-size:32px;
  font-weight:900;
  margin-bottom:26px;
}

#jaceo .faq-answer-inner p{
  font-size:18px;
  line-height:1.85;
  color:var(--muted);
}

/* ================= RESPONSIVE ================= */

@media(max-width:1200px){
  #jaceo .faq-body{
    grid-template-columns:1fr;
    gap:50px;
  }

  #jaceo .faq-answer-inner{
    padding:48px 36px;
  }
}/* End custom CSS */