/* ===================================================== */
/* ESTILOS GLOBALES BASE - JAS SOLUTIONS                 */
/* ===================================================== */

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: #17324d;
  background-color: #f7fafb;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img {
  max-width: 100%;
  display: block;
  height: auto;
}

a {
  text-decoration: none;
  transition: all 0.3s ease;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 0;
  margin-bottom: 0;
  font-weight: 700;
  color: #17324d;
}

p {
  margin-top: 0;
  margin-bottom: 0;
}

ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

button,
.btn {
  font-family: 'Montserrat', sans-serif;
}

.container {
  width: 100%;
  max-width: 1320px;
  margin: 0 auto;
  padding-left: 24px;
  padding-right: 24px;
}

section {
  position: relative;
}

/* ===================================================== */
/* NAVBAR                                                */
/* ===================================================== */

#navbar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1100;
}

.jas-header {
  position: relative;
}

.jas-navbar {
  padding: 16px 0;
  background: transparent !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-bottom: 1px solid transparent;
  box-shadow: none;
  transition: all 0.35s ease;
}

.jas-navbar.scrolled {
  padding: 12px 0;
  background: rgba(255, 255, 255, 0.78) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(15, 53, 84, 0.06);
  box-shadow: 0 10px 28px rgba(20, 45, 70, 0.08);
}



.jas-navbar .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.jas-brand {
  display: flex;
  align-items: center;
  padding: 0;
  margin-right: 28px;
  flex-shrink: 0;
  min-height: 62px;
  overflow: visible;
}

.jas-brand img {
  height: 35px;
  width: auto;
  display: block;
  transform: scale(1.85);
  transform-origin: left center;
}

.jas-navbar .navbar-collapse {
  justify-content: flex-end;
}

.jas-navbar .navbar-nav {
  gap: 8px;
}

.jas-navbar .nav-link {
  color: #0F3554 !important;
}

.jas-navbar .nav-link:hover,
.jas-navbar .nav-link:focus {
  color: #156B9A !important;
  background: rgba(21, 107, 154, 0.06);
}

.jas-navbar .navbar-toggler {
  border: 1px solid rgba(23, 50, 77, 0.12);
  border-radius: 10px;
  padding: 8px 10px;
  box-shadow: none;
}

.jas-navbar .navbar-toggler:focus {
  box-shadow: none;
  border-color: rgba(14, 111, 120, 0.28);
}



@media (min-width: 992px) {
  .jas-navbar .navbar-toggler {
    display: none;
  }

  .jas-navbar .navbar-collapse {
    display: block !important;
    flex-basis: auto;
    flex-grow: 0;
    justify-content: flex-end;
  }

  .jas-navbar .navbar-nav {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 8px;
  }

  .jas-navbar .nav-item {
    display: flex;
    align-items: center;
  }

  #navbar:hover .jas-navbar:not(.scrolled),
  .jas-navbar:not(.scrolled):focus-within {
    padding: 18px 0 16px;
    background: rgba(255, 255, 255, 0.74) !important;
    border-bottom: 1px solid rgba(15, 53, 84, 0.06);
    box-shadow: 0 14px 34px rgba(10, 39, 64, 0.08);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }  

}

/* ===================================================== */
/* HERO NUEVO - JAS SOLUTIONS                            */
/* ===================================================== */

.hero-section {
  background:
    radial-gradient(circle at 12% 20%, rgba(34, 184, 240, 0.09) 0%, rgba(34, 184, 240, 0) 30%),
    radial-gradient(circle at 82% 18%, rgba(88, 215, 255, 0.10) 0%, rgba(88, 215, 255, 0) 24%),
    radial-gradient(circle at 72% 70%, rgba(21, 107, 154, 0.06) 0%, rgba(21, 107, 154, 0) 26%),
    linear-gradient(135deg, #F9FCFE 0%, #EEF5F9 55%, #FFFFFF 100%);
    padding-top: 140px;
}

.hero-container {
  position: relative;
  z-index: 2;
}

.hero-layout {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  align-items: center;
  gap: 0;
  min-height: 470px;
}

/* Columna izquierda */
.hero-content {
  max-width: 500px;
  align-self: center;
  margin-top: -10px;
}

.hero-eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(21, 107, 154, 0.14);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.4;
  color: #156B9A;
}

.hero-title {
  margin: 0 0 22px;
  font-size: clamp(2rem, 3vw, 2.2rem);
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #0f3554;
}

.hero-description {
  max-width: 460px;
  margin: 0 0 20px;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.75;
  color: #5E7488;
}

.hero-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.hero-btn-primary,
.hero-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 20px;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  transition: all 0.3s ease;
}

.hero-btn-primary {
  background-color: #156B9A;
  border: 1px solid #156B9A;
  color: #ffffff !important;
  box-shadow: 0 12px 30px rgba(21, 107, 154, 0.18);
}

.hero-btn-primary:hover {
  background-color: #0F3554;
  border-color: #0F3554;
  color: #ffffff !important;
  transform: translateY(-2px);
}

.hero-btn-secondary {
  background-color: #ffffff;
  border: 1px solid rgba(15, 53, 84, 0.16);
  color: #0F3554 !important;
  box-shadow: 0 10px 24px rgba(15, 53, 84, 0.06);
}

.hero-btn-secondary:hover {
  background-color: #0F3554;
  color: #ffffff !important;
  transform: translateY(-2px);
}

/* Columna derecha */
.hero-visual {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.hero-visual-frame {
  width: 100%;
  max-width: 900px;
  height: 390px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-artwork {
  width: 670px;
  max-width: none;
  height: auto;
  object-fit: contain;
  transform: translate(18px, -6px) scale(1.06);
  transform-origin: center center;
  margin-top: 15px;
}

/* ===================================================== */
/* RESPONSIVE HERO                                       */
/* ===================================================== */

@media (max-width: 1199.98px) {
  .hero-layout {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    min-height: 480px;
  }

  .hero-title {
    font-size: clamp(38px, 4.2vw, 52px);
  }

  .hero-visual-frame {
    max-width: 720px;
    height: 380px;
  }

  .hero-artwork {
    width: 760px;
    transform: translate(20px, -4px) scale(1.1);
  }
}

@media (max-width: 991.98px) {
  /* Navbar tablet/móvil */
  .jas-navbar {
    padding: 16px 0;
  }

  .jas-navbar.scrolled {
    padding: 14px 0;
  }

  .jas-brand {
    min-height: auto;
  }

  .jas-brand img {
    height: 56px;
    transform: scale(1.45);
  }

  .jas-navbar .container {
    display: block;
  }

  .jas-navbar .navbar-collapse {
    margin-top: 16px;
    padding-top: 12px;
    border-top: 1px solid rgba(14, 111, 120, 0.08);
  }

  .jas-navbar .navbar-nav {
    gap: 2px;
  }

  .jas-navbar .nav-link {
    padding: 12px 0 !important;
    border-radius: 0;
  }

  /* Hero tablet */
  .hero-section {
    padding: 52px 0 36px;
  }

  .hero-layout {
    grid-template-columns: 1fr;
    gap: 24px;
    min-height: auto;
  }

  .hero-content {
    max-width: 100%;
    text-align: center;
    margin: 0 auto;
  }

  .hero-eyebrow {
    margin-left: auto;
    margin-right: auto;
  }

  .hero-title {
    max-width: 100%;
    font-size: clamp(36px, 7vw, 48px);
  }

  .hero-description {
    max-width: 100%;
  }

  .hero-buttons {
    justify-content: center;
  }

  .hero-visual {
    justify-content: center;
  }

  .hero-visual-frame {
    max-width: 640px;
    height: 340px;
  }

  .hero-artwork {
    width: 680px;
    transform: translate(0, -2px) scale(1.04);
  }
}

@media (max-width: 767.98px) {
  .container {
    padding-left: 18px;
    padding-right: 18px;
  }

  .jas-brand img {
    height: 55px;
    transform: scale(1.25);
    margin-left:-10px;
  }

  .hero-section {
    padding: 44px 0 28px;
  }

  .hero-eyebrow {
    font-size: 13px;
    margin-bottom: 14px;
  }

  .hero-title {
    font-size: clamp(30px, 8vw, 40px);
    letter-spacing: -1px;
  }

  .hero-description {
    font-size: 16px;
    line-height: 1.7;
  }

  .hero-buttons {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }

  .hero-btn-primary,
  .hero-btn-secondary {
    width: 100%;
    min-height: 54px;
    font-size: 16px;
  }

  .hero-visual-frame {
    height: 240px;
  }

  .hero-artwork {
    width: 100%;
    max-width: 460px;
    transform: translate(0, 0) scale(1);
  }
}

/* ===================================================== */
/* SECCIÓN NARRATIVA - ENFOQUE JAS SOLUTIONS             */
/* ===================================================== */

.jas-process-section {
  position: relative;
  padding: 110px 0;
  background:
    radial-gradient(circle at top left, rgba(27, 167, 216, 0.08), transparent 32%),
    linear-gradient(180deg, #f8fbfd 0%, #eef6fa 100%);
  overflow: hidden;
}

.jas-process-content {
  position: relative;
  z-index: 2;
  max-width: 620px;
}

.jas-section-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #156b9a;
}

.jas-section-label::before {
  content: "";
  width: 42px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1ba7d8 0%, #156b9a 100%);
}

.jas-process-title {
  margin: 0 0 22px;
  font-size: clamp(2rem, 3vw, 3.2rem);
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #0f3554;
}

.jas-process-intro {
  margin: 0 0 38px;
  max-width: 580px;
  font-size: 1.03rem;
  line-height: 1.8;
  color: #5e7488;
}

.jas-process-steps {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.jas-process-step {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  padding: 24px 24px;
  border: 1px solid rgba(15, 53, 84, 0.08);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 14px 34px rgba(15, 53, 84, 0.06);
  backdrop-filter: blur(8px);
  transition: all 0.3s ease;
}

.jas-process-step:hover {
  transform: translateY(-3px);
  border-color: rgba(27, 167, 216, 0.25);
  box-shadow: 0 18px 40px rgba(15, 53, 84, 0.1);
}

.jas-process-step.active {
  border-color: rgba(27, 167, 216, 0.4);
  background: linear-gradient(180deg, rgba(255,255,255,0.95) 0%, rgba(234,244,248,0.95) 100%);
  box-shadow: 0 20px 44px rgba(15, 53, 84, 0.12);
}

.jas-step-number {
  flex: 0 0 68px;
  width: 68px;
  height: 68px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, #0f3554 0%, #156b9a 100%);
  color: #ffffff;
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  box-shadow: 0 14px 30px rgba(21, 107, 154, 0.22);
}

.jas-process-step.active .jas-step-number {
  background: linear-gradient(145deg, #156b9a 0%, #1ba7d8 100%);
}

.jas-step-body {
  flex: 1;
  min-width: 0;
}

.jas-step-title {
  margin: 0 0 10px;
  font-size: 1.22rem;
  line-height: 1.3;
  font-weight: 800;
  color: #17324d;
}

.jas-step-text {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.75;
  color: #5e7488;
}

/* ===================================================== */
/* BLOQUE VISUAL DERECHO                                 */
/* ===================================================== */

.jas-process-visual {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}

.jas-visual-frame {
  position: relative;
  width: 100%;
  max-width: 560px;
  min-height: 560px;
  border-radius: 36px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.88) 0%, rgba(234,244,248,0.72) 100%);
  border: 1px solid rgba(21, 107, 154, 0.12);
  box-shadow:
    0 20px 55px rgba(15, 53, 84, 0.08),
    inset 0 1px 0 rgba(255,255,255,0.75);
  overflow: hidden;
}

.jas-visual-frame::before {
  content: "";
  position: absolute;
  inset: 30px;
  border-radius: 30px;
  border: 1px dashed rgba(27, 167, 216, 0.18);
  pointer-events: none;
}

.jas-visual-orbit {
  position: absolute;
  inset: 50%;
  width: 340px;
  height: 340px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(27, 167, 216, 0.12) 0%, rgba(27, 167, 216, 0.05) 42%, transparent 72%);
  border: 1px solid rgba(27, 167, 216, 0.12);
}

.jas-visual-core {
  position: absolute;
  inset: 50%;
  transform: translate(-50%, -50%);
  z-index: 3;
}

.jas-core-circle {
  width: 210px;
  height: 210px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.96) 0%, rgba(234,244,248,0.88) 58%, rgba(21,107,154,0.08) 100%);
  border: 1px solid rgba(21, 107, 154, 0.14);
  box-shadow:
    0 18px 38px rgba(15, 53, 84, 0.12),
    inset 0 1px 0 rgba(255,255,255,0.9);
}

.jas-core-logo {
  width: 125px;
  max-width: 100%;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(15, 53, 84, 0.14));
}

/* ===================================================== */
/* NODOS                                                 */
/* ===================================================== */

.jas-visual-node {
  position: absolute;
  z-index: 4;
  min-width: 132px;
  padding: 14px 18px;
  border-radius: 16px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(15, 53, 84, 0.08);
  box-shadow: 0 12px 28px rgba(15, 53, 84, 0.08);
  text-align: center;
  backdrop-filter: blur(8px);
}

.jas-visual-node span {
  font-size: 0.95rem;
  font-weight: 700;
  color: #17324d;
  letter-spacing: -0.01em;
}

.jas-node-1 {
  top: 88px;
  left: 50%;
  transform: translateX(-50%);
}

.jas-node-2 {
  left: 56px;
  bottom: 118px;
}

.jas-node-3 {
  right: 56px;
  bottom: 118px;
}

/* ===================================================== */
/* LÍNEAS DECORATIVAS                                    */
/* ===================================================== */

.jas-visual-lines {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

.jas-line {
  position: absolute;
  display: block;
  background: linear-gradient(90deg, rgba(27,167,216,0.05), rgba(21,107,154,0.28), rgba(27,167,216,0.05));
  border-radius: 999px;
}

.jas-line-1 {
  top: 180px;
  left: 50%;
  width: 2px;
  height: 90px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(27,167,216,0.04), rgba(21,107,154,0.24), rgba(27,167,216,0.04));
}

.jas-line-2 {
  left: 155px;
  bottom: 182px;
  width: 110px;
  height: 2px;
  transform: rotate(-28deg);
}

.jas-line-3 {
  right: 155px;
  bottom: 182px;
  width: 110px;
  height: 2px;
  transform: rotate(28deg);
}

/* ===================================================== */
/* RESPONSIVE                                            */
/* ===================================================== */

@media (max-width: 1199.98px) {
  .jas-visual-frame {
    max-width: 520px;
    min-height: 520px;
  }

  .jas-core-circle {
    width: 190px;
    height: 190px;
  }

  .jas-core-logo {
    width: 112px;
  }
}

@media (max-width: 991.98px) {
  .jas-process-section {
    padding: 90px 0;
  }

  .jas-process-content {
    max-width: 100%;
  }

  .jas-process-title {
    max-width: 100%;
  }

  .jas-process-intro {
    max-width: 100%;
  }

  .jas-visual-frame {
    margin-top: 10px;
    max-width: 100%;
    min-height: 500px;
  }

  .jas-node-2 {
    left: 42px;
  }

  .jas-node-3 {
    right: 42px;
  }
}

@media (max-width: 767.98px) {
  .jas-process-section {
    padding: 78px 0;
  }

  .jas-process-step {
    padding: 20px 18px;
    border-radius: 20px;
    gap: 14px;
  }

  .jas-step-number {
    flex: 0 0 58px;
    width: 58px;
    height: 58px;
    border-radius: 16px;
    font-size: 0.92rem;
  }

  .jas-step-title {
    font-size: 1.08rem;
  }

  .jas-step-text {
    font-size: 0.94rem;
  }

  .jas-visual-frame {
    min-height: 440px;
    border-radius: 28px;
  }

  .jas-visual-frame::before {
    inset: 20px;
    border-radius: 22px;
  }

  .jas-visual-orbit {
    width: 270px;
    height: 270px;
  }

  .jas-core-circle {
    width: 165px;
    height: 165px;
  }

  .jas-core-logo {
    width: 96px;
  }

  .jas-visual-node {
    min-width: 110px;
    padding: 12px 14px;
  }

  .jas-visual-node span {
    font-size: 0.88rem;
  }

  .jas-node-1 {
    top: 64px;
  }

  .jas-node-2 {
    left: 24px;
    bottom: 92px;
  }

  .jas-node-3 {
    right: 24px;
    bottom: 92px;
  }

  .jas-line-1 {
    top: 150px;
    height: 70px;
  }

  .jas-line-2,
  .jas-line-3 {
    width: 84px;
    bottom: 144px;
  }
}

@media (max-width: 575.98px) {
  .jas-process-title {
    font-size: 1.85rem;
  }

  .jas-process-intro {
    font-size: 0.97rem;
    line-height: 1.75;
  }

  .jas-process-step {
    flex-direction: column;
  }

  .jas-step-number {
    margin-bottom: 2px;
  }

  .jas-visual-frame {
    min-height: 400px;
  }

  .jas-visual-orbit {
    width: 230px;
    height: 230px;
  }

  .jas-core-circle {
    width: 145px;
    height: 145px;
  }

  .jas-core-logo {
    width: 86px;
  }

  .jas-visual-node {
    min-width: 96px;
    padding: 10px 12px;
    border-radius: 14px;
  }

  .jas-node-1 {
    top: 54px;
  }

  .jas-node-2 {
    left: 16px;
    bottom: 72px;
  }

  .jas-node-3 {
    right: 16px;
    bottom: 72px;
  }

  .jas-line-2,
  .jas-line-3 {
    width: 64px;
    bottom: 125px;
  }
}

/* ===================================================== */
/* SECCIÓN ENFOQUE OSCURA - JAS SOLUTIONS                */
/* ===================================================== */

.jas-approach-section {
  position: relative;
  padding: 110px 0;
  overflow: hidden;
  background: #081a2b;
}

.jas-approach-bg,
.jas-approach-overlay,
.jas-approach-grid {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.jas-approach-bg {
  background:
    radial-gradient(circle at 16% 24%, rgba(34, 184, 240, 0.16) 0%, transparent 18%),
    radial-gradient(circle at 82% 70%, rgba(88, 215, 255, 0.14) 0%, transparent 20%),
    radial-gradient(circle at 68% 30%, rgba(21, 107, 154, 0.12) 0%, transparent 24%),
    linear-gradient(135deg, #071826 0%, #0b2236 45%, #081a2b 100%);
  opacity: 1;
  z-index: 0;
}

.jas-approach-overlay {
  background:
    radial-gradient(circle at 20% 28%, rgba(34, 184, 240, 0.10), transparent 18%),
    radial-gradient(circle at 78% 68%, rgba(88, 215, 255, 0.08), transparent 18%),
    linear-gradient(115deg, transparent 0 43%, rgba(88, 215, 255, 0.10) 50%, transparent 57%),
    linear-gradient(30deg, transparent 0 45%, rgba(34, 184, 240, 0.08) 50%, transparent 55%);
  z-index: 1;
  opacity: 0.9;
}

.jas-approach-grid {
  z-index: 2;
  opacity: 0.16;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px),
    radial-gradient(circle at 18% 30%, rgba(88,215,255,0.26) 0 2px, transparent 3px),
    radial-gradient(circle at 32% 52%, rgba(88,215,255,0.20) 0 2px, transparent 3px),
    radial-gradient(circle at 52% 24%, rgba(88,215,255,0.20) 0 2px, transparent 3px),
    radial-gradient(circle at 72% 42%, rgba(88,215,255,0.20) 0 2px, transparent 3px),
    radial-gradient(circle at 84% 68%, rgba(88,215,255,0.24) 0 2px, transparent 3px),
    linear-gradient(125deg, transparent 0 21%, rgba(88,215,255,0.10) 21.5%, rgba(88,215,255,0.10) 22%, transparent 22.5%),
    linear-gradient(28deg, transparent 0 51%, rgba(88,215,255,0.08) 51.5%, rgba(88,215,255,0.08) 52%, transparent 52.5%);
  background-size:
    52px 52px,
    52px 52px,
    100% 100%,
    100% 100%,
    100% 100%,
    100% 100%,
    100% 100%,
    100% 100%,
    100% 100%;
  mask-image: radial-gradient(circle at center, rgba(0,0,0,1) 48%, rgba(0,0,0,0.22) 78%, transparent 100%);
  -webkit-mask-image: radial-gradient(circle at center, rgba(0,0,0,1) 48%, rgba(0,0,0,0.22) 78%, transparent 100%);
}

.jas-approach-section .container {
  position: relative;
  z-index: 5;
}

.jas-approach-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(420px, 0.95fr);
  gap: 64px;
  align-items: center;
}

/* ===================================================== */
/* CONTENIDO IZQUIERDO                                   */
/* ===================================================== */

.jas-approach-content {
  max-width: 650px;
}

.jas-approach-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  color: #7bdcff;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.jas-approach-label::before {
  content: "";
  width: 44px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1ba7d8 0%, #7bdcff 100%);
}

.jas-approach-title {
  margin: 0 0 18px;
  max-width: 580px;
  font-size: clamp(2rem, 2.7vw, 3rem);
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: -0.025em;
  color: #ffffff;
}

.jas-approach-intro {
  margin: 0 0 32px;
  max-width: 560px;
  font-size: 0.98rem;
  line-height: 1.75;
  color: rgba(225, 238, 247, 0.82);
}

.jas-approach-steps {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 26px;
  padding-left: 18px;
  padding-top: 80px;
}

.jas-approach-steps::before {
  content: "";
  position: absolute;
  top: 40px;
  bottom: -30px;
  left: 0;
  width: 2px;
  border-radius: 999px;
  background: linear-gradient(
    180deg,
    rgba(27, 167, 216, 0.15) 0%,
    rgba(27, 167, 216, 0.7) 30%,
    rgba(21, 107, 154, 0.5) 70%,
    rgba(27, 167, 216, 0.12) 100%
  );
}

.jas-approach-step {
  position: relative;
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 18px;
  align-items: start;
}

.jas-step-index {
  position: relative;
  z-index: 2;
  width: 58px;
  height: 58px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(14, 47, 74, 0.82);
  border: 1px solid rgba(123, 220, 255, 0.22);
  box-shadow:
    0 10px 28px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255,255,255,0.08);
  color: #ffffff;
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.jas-approach-step.is-active .jas-step-index {
  background: linear-gradient(145deg, #156b9a 0%, #1ba7d8 100%);
  border-color: rgba(123, 220, 255, 0.5);
  box-shadow:
    0 16px 32px rgba(17, 102, 143, 0.3),
    0 0 0 8px rgba(27, 167, 216, 0.08);
}

.jas-step-copy h3 {
  margin: 2px 0 10px;
  font-size: 1.26rem;
  line-height: 1.3;
  font-weight: 800;
  color: #ffffff;
}

.jas-step-copy p {
  margin: 0;
  max-width: 520px;
  font-size: 0.98rem;
  line-height: 1.78;
  color: rgba(219, 233, 242, 0.8);
}

.jas-approach-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 38px;
}

.jas-approach-tags span {
  display: inline-flex;
  align-items: center;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid rgba(123, 220, 255, 0.14);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(235, 245, 251, 0.9);
  font-size: 0.9rem;
  font-weight: 600;
  backdrop-filter: blur(6px);
}

/* ===================================================== */
/* VISUAL DERECHO                                        */
/* ===================================================== */

.jas-approach-visual {
  display: flex;
  justify-content: center;
  align-items: center;
}

.jas-visual-shell {
  position: relative;
  width: min(100%, 560px);
  height: 560px;
  border-radius: 34px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.02) 100%);
  border: 1px solid rgba(123, 220, 255, 0.14);
  box-shadow:
    0 24px 60px rgba(0, 0, 0, 0.26),
    inset 0 1px 0 rgba(255,255,255,0.06);
  backdrop-filter: blur(10px);
  overflow: hidden;
}

.jas-visual-shell::before {
  content: "";
  position: absolute;
  inset: 28px;
  border-radius: 28px;
  border: 1px dashed rgba(123, 220, 255, 0.16);
}

.jas-visual-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(18px);
}

.jas-glow-1 {
  width: 240px;
  height: 240px;
  top: 60px;
  right: 54px;
  background: rgba(27, 167, 216, 0.14);
}

.jas-glow-2 {
  width: 210px;
  height: 210px;
  left: 70px;
  bottom: 70px;
  background: rgba(21, 107, 154, 0.16);
}

.jas-visual-lines {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.jas-visual-line {
  position: absolute;
  display: block;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(123,220,255,0.02), rgba(123,220,255,0.5), rgba(123,220,255,0.02));
}

.jas-line-a {
  width: 2px;
  height: 120px;
  top: 130px;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(123,220,255,0.02), rgba(123,220,255,0.5), rgba(123,220,255,0.02));
}

.jas-line-b {
  width: 125px;
  height: 2px;
  left: 148px;
  bottom: 176px;
  transform: rotate(-29deg);
}

.jas-line-c {
  width: 125px;
  height: 2px;
  right: 148px;
  bottom: 176px;
  transform: rotate(29deg);
}

.jas-visual-node {
  position: absolute;
  z-index: 3;
  min-width: 126px;
  padding: 13px 18px;
  border-radius: 16px;
  text-align: center;
  background: rgba(7, 24, 40, 0.78);
  border: 1px solid rgba(123, 220, 255, 0.18);
  box-shadow:
    0 16px 30px rgba(0, 0, 0, 0.2),
    inset 0 1px 0 rgba(255,255,255,0.05);
  color: #ffffff;
  font-size: 0.92rem;
  font-weight: 700;
  backdrop-filter: blur(8px);
}

.jas-node-top {
  top: 64px;
  left: 50%;
  transform: translateX(-50%);
}

.jas-node-left {
  left: 54px;
  bottom: 110px;
}

.jas-node-right {
  right: 54px;
  bottom: 110px;
}

.jas-visual-core {
  position: absolute;
  inset: 50%;
  transform: translate(-50%, -50%);
  width: 310px;
  height: 310px;
  z-index: 2;
}

.jas-core-ring,
.jas-core-ring-secondary {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1px solid rgba(123, 220, 255, 0.18);
  background: radial-gradient(circle, rgba(123, 220, 255, 0.08) 0%, rgba(123, 220, 255, 0.02) 58%, transparent 72%);
}

.jas-core-ring-secondary {
  inset: 26px;
  border-color: rgba(123, 220, 255, 0.1);
}

.jas-core-logo-wrap {
  position: absolute;
  inset: 50%;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.18) 0%, rgba(255,255,255,0.06) 55%, rgba(27,167,216,0.04) 100%);
  border: 1px solid rgba(123, 220, 255, 0.18);
  box-shadow:
    0 18px 40px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255,255,255,0.08);
  backdrop-filter: blur(8px);
}

.jas-core-logo {
  width: 124px;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 14px 22px rgba(0,0,0,0.24));
}

/* ===================================================== */
/* RESPONSIVE                                            */
/* ===================================================== */

@media (max-width: 1199.98px) {
  .jas-approach-inner {
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.9fr);
    gap: 44px;
  }

  .jas-approach-title {
    font-size: clamp(2rem, 3vw, 3.15rem);
  }

  .jas-visual-shell {
    width: min(100%, 500px);
    height: 500px;
  }

  .jas-visual-core {
    width: 280px;
    height: 280px;
  }

  .jas-core-logo-wrap {
    width: 184px;
    height: 184px;
  }

  .jas-core-logo {
    width: 114px;
  }

  .jas-line-b {
    left: 124px;
    bottom: 160px;
  }

  .jas-line-c {
    right: 124px;
    bottom: 160px;
  }
}

@media (max-width: 991.98px) {
  .jas-approach-section {
    padding: 90px 0;
  }

  .jas-approach-inner {
    grid-template-columns: 1fr;
    gap: 46px;
  }

  .jas-approach-content {
    max-width: 100%;
  }

  .jas-approach-title,
  .jas-approach-intro {
    max-width: 100%;
  }

  .jas-approach-visual {
    justify-content: flex-start;
  }

  .jas-visual-shell {
    width: min(100%, 520px);
    height: 500px;
  }
}

@media (max-width: 767.98px) {
  .jas-approach-section {
    padding: 76px 0;
  }

  .jas-approach-title {
    font-size: 1.72rem;
    line-height: 1.14;
  }

  .jas-approach-intro {
    font-size: 0.97rem;
    line-height: 1.75;
    margin-bottom: 32px;
  }

  .jas-approach-steps {
    gap: 22px;
    padding-left: 14px;
  }

  .jas-approach-step {
    grid-template-columns: 62px 1fr;
    gap: 14px;
  }

  .jas-step-index {
    width: 52px;
    height: 52px;
    border-radius: 16px;
    font-size: 0.88rem;
  }

  .jas-step-copy h3 {
    font-size: 1.08rem;
    margin-bottom: 8px;
  }

  .jas-step-copy p {
    font-size: 0.94rem;
    line-height: 1.7;
  }

  .jas-approach-tags {
    gap: 10px;
    margin-top: 30px;
  }

  .jas-approach-tags span {
    padding: 9px 14px;
    font-size: 0.84rem;
  }

  .jas-visual-shell {
    height: 420px;
    border-radius: 26px;
  }

  .jas-visual-shell::before {
    inset: 18px;
    border-radius: 20px;
  }

  .jas-visual-node {
    min-width: 104px;
    padding: 10px 14px;
    border-radius: 14px;
    font-size: 0.84rem;
  }

  .jas-node-top {
    top: 48px;
  }

  .jas-node-left {
    left: 22px;
    bottom: 82px;
  }

  .jas-node-right {
    right: 22px;
    bottom: 82px;
  }

  .jas-visual-core {
    width: 230px;
    height: 230px;
  }

  .jas-core-logo-wrap {
    width: 154px;
    height: 154px;
  }

  .jas-core-logo {
    width: 92px;
  }

  .jas-line-a {
    height: 88px;
    top: 110px;
  }

  .jas-line-b {
    width: 88px;
    left: 92px;
    bottom: 130px;
  }

  .jas-line-c {
    width: 88px;
    right: 92px;
    bottom: 130px;
  }
}

@media (max-width: 575.98px) {
  .jas-approach-title {
    font-size: 1.52rem;
    line-height: 1.16;
  }

  .jas-approach-step {
    grid-template-columns: 1fr;
  }

  .jas-step-index {
    margin-bottom: 4px;
  }

  .jas-visual-shell {
    height: 360px;
  }

  .jas-visual-core {
    width: 190px;
    height: 190px;
  }

  .jas-core-logo-wrap {
    width: 128px;
    height: 128px;
  }

  .jas-core-logo {
    width: 76px;
  }

  .jas-visual-node {
    min-width: 92px;
    padding: 9px 12px;
    font-size: 0.78rem;
  }

  .jas-node-top {
    top: 40px;
  }

  .jas-node-left {
    left: 12px;
    bottom: 62px;
  }

  .jas-node-right {
    right: 12px;
    bottom: 62px;
  }

  .jas-line-b,
  .jas-line-c {
    width: 64px;
    bottom: 108px;
  }
}

/* ========================================= */
/* HOVER EN NÚMEROS DE LOS PASOS             */
/* ========================================= */

.jas-step-index {
  transition:
    background 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.35s ease,
    transform 0.35s ease;
}

/* estado activo por defecto */
.jas-approach-step.is-active .jas-step-index {
  background: linear-gradient(145deg, #156b9a 0%, #1ba7d8 100%);
  border-color: rgba(123, 220, 255, 0.5);
  box-shadow:
    0 16px 32px rgba(17, 102, 143, 0.3),
    0 0 0 8px rgba(27, 167, 216, 0.08);
}

/* al pasar el mouse por cualquier paso, ese toma el protagonismo */
.jas-approach-step:hover .jas-step-index {
  background: linear-gradient(145deg, #156b9a 0%, #1ba7d8 100%);
  border-color: rgba(123, 220, 255, 0.5);
  box-shadow:
    0 16px 32px rgba(17, 102, 143, 0.3),
    0 0 0 8px rgba(27, 167, 216, 0.08);
  transform: translateY(-2px);
}

/* cuando el mouse está dentro del bloque de pasos, el activo fijo se apaga
   si no es el que está recibiendo hover */
.jas-approach-steps:hover .jas-approach-step.is-active:not(:hover) .jas-step-index {
  background: rgba(14, 47, 74, 0.82);
  border-color: rgba(123, 220, 255, 0.22);
  box-shadow:
    0 10px 28px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255,255,255,0.08);
  transform: none;
}

/* ========================================= */
/* MOVIMIENTO SUTIL - VISUAL DERECHO         */
/* VERSIÓN LIMPIA Y ESTABLE                  */
/* ========================================= */

.jas-visual-shell,
.jas-visual-node,
.jas-visual-line,
.jas-core-logo-wrap,
.jas-core-ring,
.jas-core-ring-secondary,
.jas-glow-1,
.jas-glow-2 {
  transition:
    transform 0.55s ease,
    box-shadow 0.55s ease,
    opacity 0.55s ease,
    filter 0.55s ease,
    border-color 0.55s ease;
}

/* movimiento base suave */
.jas-core-logo-wrap {
  animation: jasCoreFloat 4.8s ease-in-out infinite;
}

.jas-core-ring {
  animation: jasRingPulse 6s ease-in-out infinite;
}

.jas-core-ring-secondary {
  animation: jasRingPulseSecondary 6s ease-in-out infinite;
}

.jas-glow-1 {
  animation: jasGlowMoveOne 7s ease-in-out infinite;
}

.jas-glow-2 {
  animation: jasGlowMoveTwo 8s ease-in-out infinite;
}

/* hover general del bloque */
.jas-visual-shell:hover {
  box-shadow:
    0 34px 80px rgba(0, 0, 0, 0.34),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

.jas-visual-shell {
  transform: none !important;
}

/* núcleo */
.jas-visual-shell:hover .jas-core-logo-wrap {
  transform: translate(-50%, -50%) translateY(-10px) scale(1.03);
  box-shadow:
    0 26px 54px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255,255,255,0.08);
}

/* nodos con micro desplazamiento */
.jas-visual-shell:hover .jas-node-top {
  transform: translateX(-50%) translateY(-6px);
}

.jas-visual-shell:hover .jas-node-left {
  transform: translateX(-6px) translateY(4px);
}

.jas-visual-shell:hover .jas-node-right {
  transform: translateX(6px) translateY(4px);
}

/* líneas con ligera expansión */
.jas-visual-shell:hover .jas-line-a {
  transform: translateX(-50%) scaleY(1.08);
  opacity: 0.95;
}

.jas-visual-shell:hover .jas-line-b {
  transform: rotate(-29deg) scaleX(1.06);
  opacity: 0.95;
}

.jas-visual-shell:hover .jas-line-c {
  transform: rotate(29deg) scaleX(1.06);
  opacity: 0.95;
}

/* anillos */
.jas-visual-shell:hover .jas-core-ring {
  transform: scale(1.03);
  opacity: 0.95;
}

.jas-visual-shell:hover .jas-core-ring-secondary {
  transform: scale(1.05);
  opacity: 0.9;
}

/* glow */
.jas-visual-shell:hover .jas-glow-1,
.jas-visual-shell:hover .jas-glow-2 {
  filter: blur(22px);
  opacity: 1;
}

/* ========================================= */
/* KEYFRAMES                                 */
/* ========================================= */

@keyframes jasCoreFloat {
  0%, 100% {
    transform: translate(-50%, -50%) translateY(0);
  }
  50% {
    transform: translate(-50%, -50%) translateY(-8px);
  }
}

@keyframes jasRingPulse {
  0%, 100% {
    transform: scale(1);
    opacity: 0.7;
  }
  50% {
    transform: scale(1.025);
    opacity: 0.95;
  }
}

@keyframes jasRingPulseSecondary {
  0%, 100% {
    transform: scale(1);
    opacity: 0.45;
  }
  50% {
    transform: scale(1.04);
    opacity: 0.72;
  }
}

@keyframes jasGlowMoveOne {
  0%, 100% {
    transform: translate(0, 0);
    opacity: 0.7;
  }
  50% {
    transform: translate(-8px, 10px);
    opacity: 0.95;
  }
}

@keyframes jasGlowMoveTwo {
  0%, 100% {
    transform: translate(0, 0);
    opacity: 0.62;
  }
  50% {
    transform: translate(10px, -8px);
    opacity: 0.88;
  }
}


/* ========================================= */
/* HEADER CENTRADO DE LA SECCIÓN             */
/* ========================================= */

.jas-approach-header {
  max-width: 980px;
  margin: 0 auto 52px;
  text-align: center;
}

.jas-approach-header .jas-approach-label {
  justify-content: center;
  margin-bottom: 18px;
}

.jas-approach-header .jas-approach-title {
  max-width: 900px;
  margin: 0 auto 18px;
  font-size: clamp(2.2rem, 3vw, 3.6rem);
  line-height: 1.08;
  text-align: center;
}

.jas-approach-header .jas-approach-intro {
  max-width: 860px;
  margin: 0 auto;
  font-size: 1rem;
  line-height: 1.75;
  text-align: center;
  color: rgba(225, 238, 247, 0.82);
}

/* ========================================= */
/* AJUSTE DEL BLOQUE INFERIOR                */
/* ========================================= */

.jas-approach-inner {
  align-items: start;
  gap: 52px;
}

.jas-approach-content {
  max-width: 100%;
}

.jas-approach-steps {
  margin-top: 0;
}

.jas-approach-capabilities {
  margin-top: 34px;
}

/* responsive */
@media (max-width: 991.98px) {
  .jas-approach-header {
    margin-bottom: 40px;
  }

  .jas-approach-header .jas-approach-title {
    font-size: clamp(2rem, 4vw, 3rem);
  }

  .jas-approach-header .jas-approach-intro {
    max-width: 100%;
  }
}

@media (max-width: 767.98px) {
  .jas-approach-header {
    margin-bottom: 34px;
  }

  .jas-approach-header .jas-approach-title {
    font-size: 1.9rem;
    line-height: 1.12;
  }

  .jas-approach-header .jas-approach-intro {
    font-size: 0.96rem;
    line-height: 1.72;
  }
}

/*=======================*/
/*==Logo Nuestro enfoque==*/
/*=======================*/

.jas-core-logo-wrap {
  position: absolute;
  inset: 50%;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.18) 0%, rgba(255,255,255,0.06) 55%, rgba(27,167,216,0.04) 100%);
  border: 1px solid rgba(123, 220, 255, 0.18);
  box-shadow:
    0 18px 40px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255,255,255,0.08);
  backdrop-filter: blur(8px);
}

.jas-core-logo {
  width: 135px;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 12px 22px rgba(0,0,0,0.22));
}

/* ========================================= */
/* SECCIÓN SERVICIOS / CAPACIDADES JAS       */
/* ========================================= */

.jas-services-section {
  position: relative;
  padding: 105px 0 110px;
  background:
    radial-gradient(circle at top right, rgba(27, 167, 216, 0.08), transparent 28%),
    linear-gradient(180deg, #f5fafc 0%, #edf5f9 100%);
  overflow: hidden;
}

.jas-services-header {
  max-width: 860px;
  margin: 0 auto 54px;
  text-align: center;
}

.jas-services-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  color: #156b9a;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.jas-services-label::before {
  content: "";
  width: 44px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1ba7d8 0%, #156b9a 100%);
}

.jas-services-title {
  margin: 0 0 18px;
  font-size: clamp(2rem, 3vw, 3.25rem);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #0f3554;
}

.jas-services-intro {
  margin: 0 auto;
  max-width: 760px;
  font-size: 1rem;
  line-height: 1.78;
  color: #5e7488;
}

.jas-services-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}

.jas-service-card {
  position: relative;
  min-height: 260px;
  padding: 28px 24px 24px;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.94) 0%, rgba(250,253,255,0.92) 100%);
  border: 1px solid rgba(21, 107, 154, 0.10);
  box-shadow:
    0 16px 40px rgba(15, 53, 84, 0.08),
    inset 0 1px 0 rgba(255,255,255,0.82);
  transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    border-color 0.35s ease,
    background 0.35s ease;
  overflow: hidden;
}

.jas-service-card::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, #0f3554 0%, #156b9a 45%, #1ba7d8 100%);
  opacity: 0.95;
}

.jas-service-card:hover {
  transform: translateY(-6px);
  border-color: rgba(27, 167, 216, 0.22);
  box-shadow:
    0 22px 48px rgba(15, 53, 84, 0.14),
    0 0 0 1px rgba(27, 167, 216, 0.05);
}

.jas-service-icon {
  width: 58px;
  height: 58px;
  margin-bottom: 20px;
  border-radius: 18px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.30) 0%, rgba(255,255,255,0.06) 34%, transparent 35%),
    linear-gradient(145deg, #0f3554 0%, #156b9a 58%, #1ba7d8 100%);
  box-shadow:
    0 14px 28px rgba(21, 107, 154, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.18);
  position: relative;
}

.jas-service-icon::after {
  content: "";
  position: absolute;
  inset: 50%;
  width: 22px;
  height: 22px;
  transform: translate(-50%, -50%);
  border-radius: 7px;
  border: 2px solid rgba(255,255,255,0.88);
  opacity: 0.95;
}

.jas-service-title {
  position: relative;
  z-index: 4;
  color: #EAF4F8 !important;
  margin: 0 0 12px;
  font-size: 1.08rem;
  line-height: 1.2;
  font-weight: 800;
  min-height: 52px; /* reserva espacio para 2 líneas */
  display: flex;
  align-items: flex-start;
}

.jas-service-text {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.72;
  color: #5e7488;
}

/* ========================================= */
/* RESPONSIVE                                */
/* ========================================= */

@media (max-width: 1199.98px) {
  .jas-services-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991.98px) {
  .jas-services-section {
    padding: 88px 0 94px;
  }

  .jas-services-header {
    margin-bottom: 42px;
  }

  .jas-services-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
  }
}

@media (max-width: 767.98px) {
  .jas-services-title {
    font-size: 1.9rem;
    line-height: 1.12;
  }

  .jas-services-intro {
    font-size: 0.96rem;
    line-height: 1.72;
  }

  .jas-service-card {
    min-height: 230px;
    padding: 24px 20px 20px;
    border-radius: 20px;
  }

  .jas-service-icon {
    width: 52px;
    height: 52px;
    border-radius: 16px;
    margin-bottom: 18px;
  }

  .jas-service-title {
    font-size: 1.05rem;
  }

  .jas-service-text {
    font-size: 0.93rem;
  }
}

@media (max-width: 575.98px) {
  .jas-services-grid {
    grid-template-columns: 1fr;
  }

  .jas-services-section {
    padding: 76px 0 82px;
  }

  .jas-services-header {
    margin-bottom: 34px;
  }
}

/*===============================*/
/* CSS de Servcios y Capacidades*/
/*=============================*/

.jas-service-icon {
  width: 58px;
  height: 58px;
  margin-bottom: 20px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.30) 0%, rgba(255,255,255,0.06) 34%, transparent 35%),
    linear-gradient(145deg, #0f3554 0%, #156b9a 58%, #1ba7d8 100%);
  box-shadow:
    0 14px 28px rgba(21, 107, 154, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.18);
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.jas-service-icon i {
  font-size: 1.35rem;
  color: #ffffff;
  line-height: 1;
}

.jas-service-card:hover .jas-service-icon {
  transform: translateY(-3px) rotate(-4deg);
  box-shadow:
    0 18px 34px rgba(21, 107, 154, 0.28),
    0 0 0 6px rgba(27, 167, 216, 0.08);
}

/* ========================================= */
/* SECCIÓN POR QUÉ JAS                       */
/* ========================================= */

.jas-value-section {
  position: relative;
  padding: 105px 0 110px;
  overflow: hidden;
  background: #081a2b;
}

.jas-value-bg,
.jas-value-overlay {
  position: relative;
  inset: 0;
  pointer-events: none;
}

.jas-value-bg {
  background:
    radial-gradient(circle at 18% 22%, rgba(27, 167, 216, 0.10), transparent 24%),
    radial-gradient(circle at 82% 78%, rgba(21, 107, 154, 0.12), transparent 28%),
    linear-gradient(180deg, #071726 0%, #0a1d2f 100%);
  z-index: 1;
}

.jas-value-overlay {
  z-index: 1 !important;
  opacity: 1 !important;
  background:
    radial-gradient(circle at 15% 58%, rgba(88,215,255,0.40) 0 2px, transparent 3px),
    radial-gradient(circle at 27% 46%, rgba(88,215,255,0.30) 0 2px, transparent 3px),
    radial-gradient(circle at 41% 62%, rgba(88,215,255,0.24) 0 2px, transparent 3px),
    radial-gradient(circle at 58% 46%, rgba(88,215,255,0.24) 0 2px, transparent 3px),
    radial-gradient(circle at 73% 60%, rgba(88,215,255,0.30) 0 2px, transparent 3px),
    radial-gradient(circle at 86% 50%, rgba(88,215,255,0.38) 0 2px, transparent 3px),

    /* rayo izquierdo inferior, más suave */
    linear-gradient(122deg, transparent 0 17%, rgba(88,215,255,0.10) 17.35%, rgba(88,215,255,0.10) 17.8%, transparent 18.25%),

    /* rayo central, bajado de intensidad */
    linear-gradient(67deg, transparent 0 55%, rgba(88,215,255,0.055) 55.4%, rgba(88,215,255,0.055) 55.9%, transparent 56.4%),

    /* rayo derecho superior, nuevo y suave */
    linear-gradient(138deg, transparent 0 73%, rgba(88,215,255,0.085) 73.35%, rgba(88,215,255,0.085) 73.8%, transparent 74.25%),

    /* señal corta adicional a la derecha */
    linear-gradient(28deg, transparent 0 82%, rgba(88,215,255,0.06) 82.35%, rgba(88,215,255,0.06) 82.7%, transparent 83.05%) !important;

  -webkit-mask-image: none !important;
  mask-image: none !important;
}

.jas-value-section .container {
  position: relative;
  z-index: 5;
}

.jas-value-header {
  max-width: 860px;
  margin: 0 auto 52px;
  text-align: center;
}

.jas-value-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  color: #7bdcff;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.jas-value-label::before {
  content: "";
  width: 44px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1ba7d8 0%, #7bdcff 100%);
}

.jas-value-title {
  margin: 0 0 18px;
  font-size: clamp(2rem, 3vw, 3.2rem);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #ffffff;
}

.jas-value-intro {
  margin: 0 auto;
  max-width: 760px;
  font-size: 1rem;
  line-height: 1.78;
  color: rgba(225, 238, 247, 0.82);
}

.jas-value-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}

.jas-value-card {
  position: relative;
  min-height: 250px;
  padding: 28px 24px 24px;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.03) 100%);
  border: 1px solid rgba(123, 220, 255, 0.12);
  box-shadow:
    0 18px 42px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.04);
  backdrop-filter: blur(8px);
  transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    border-color 0.35s ease,
    background 0.35s ease;
  overflow: hidden;
  isolation: isolate;
}

.jas-value-card::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, #1ba7d8 0%, #156b9a 50%, #0f3554 100%);
  opacity: 0.95;
}

.jas-value-card:hover {
  transform: translateY(-6px);
  border-color: rgba(123, 220, 255, 0.24);
  box-shadow:
    0 24px 52px rgba(0, 0, 0, 0.28),
    0 0 0 1px rgba(27, 167, 216, 0.06);
}

/* ========================================= */
/* CAPA HOVER TIPO "MANTEL"                  */
/* ========================================= */

.jas-value-hover-layer {
 position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: 148px; /* baja el mantel debajo del bloque de título */
  border-radius: 18px 18px 24px 24px;
  background:
    linear-gradient(180deg, rgba(7, 23, 38, 0.78) 0%, rgba(7, 23, 38, 0.99) 100%);
  backdrop-filter: blur(4px);
  z-index: 2;
  opacity: 0;
  transform: translateY(100%);
  transition:
    transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.35s ease;
}

/* cards pares: entra desde la derecha, pero cubre todo el ancho */
.jas-value-card:nth-child(even) .jas-value-hover-layer {
  left: 0;
  right: 0;
  top: 148px;
  bottom: 0;
  border-radius: 18px 18px 24px 24px;
  transform: translateX(100%);
  background:
    linear-gradient(90deg, rgba(7, 23, 38, 0.78) 0%, rgba(7, 23, 38, 0.99) 100%);
}

/* orden de capas */
.jas-value-card-title {
  position: relative;
  z-index: 4;
  color: #EAF4F8 !important;
  text-shadow: 0 1px 10px rgba(0, 0, 0, 0.12);
}
.jas-value-content {
  padding-top: 2px;
}

.jas-value-number,
.jas-value-content {
  position: relative;
  z-index: 1;
}

.jas-value-number {
  width: 56px;
  height: 56px;
  margin-bottom: 20px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, #0f3554 0%, #156b9a 58%, #1ba7d8 100%);
  color: #ffffff;
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  box-shadow:
    0 14px 28px rgba(21, 107, 154, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.14);
  transition:
    transform 0.4s ease,
    opacity 0.35s ease,
    box-shadow 0.35s ease;
}

.jas-value-card-title {
  margin: 0 0 12px;
  font-size: 1.14rem;
  line-height: 1.3;
  font-weight: 800;
  color: #ffffff;
  transition:
    color 0.35s ease,
    transform 0.35s ease;
}

.jas-value-content {
  transition:
    transform 0.45s ease,
    opacity 0.35s ease;
}

.jas-value-card-text {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.72;
  color: rgba(219, 233, 242, 0.82);
  text-align: justify;
}

/* ========================================= */
/* HOVER                                     */
/* ========================================= */

.jas-value-card:hover .jas-value-hover-layer {
  opacity: 1;
  transform: translateY(0);
}

.jas-value-card:nth-child(even):hover .jas-value-hover-layer {
  transform: translateX(0);
}

.jas-value-card:hover .jas-value-content {
  transform: translateY(14px);
  opacity: 0;
}

.jas-value-card:nth-child(even):hover .jas-value-content {
  transform: translateX(12px);
  opacity: 0;
}

.jas-value-card:hover .jas-value-number {
  transform: translateY(8px) scale(0.94);
  opacity: 0.06;
  box-shadow:
    0 8px 18px rgba(21, 107, 154, 0.08),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

.jas-value-card:nth-child(even):hover .jas-value-number {
  transform: translateX(8px) scale(0.94);
  opacity: 0.06;
}

.jas-value-card:hover .jas-value-card-title {
  color: #ffffff;
  transform: translateY(-2px);
}

/* ========================================= */
/* RESPONSIVE                                */
/* ========================================= */

@media (max-width: 1199.98px) {
  .jas-value-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991.98px) {
  .jas-value-section {
    padding: 88px 0 94px;
  }

  .jas-value-header {
    margin-bottom: 42px;
  }

  .jas-value-grid {
    gap: 20px;
  }
}

@media (max-width: 767.98px) {
  .jas-value-title {
    font-size: 1.9rem;
    line-height: 1.12;
  }

  .jas-value-intro {
    font-size: 0.96rem;
    line-height: 1.72;
  }

  .jas-value-card {
    min-height: 220px;
    padding: 24px 20px 20px;
    border-radius: 20px;
  }

.jas-value-hover-layer {
  top: 118px;
  border-radius: 16px 16px 20px 20px;
}

.jas-value-card:nth-child(even) .jas-value-hover-layer {
  top: 118px;
  left: 0;
  right: 0;
  border-radius: 16px 16px 20px 20px;
}

  .jas-value-number {
    width: 50px;
    height: 50px;
    border-radius: 16px;
    margin-bottom: 18px;
    font-size: 0.88rem;
  }

  .jas-value-card-title {
    font-size: 1.05rem;
  }

  .jas-value-card-text {
    font-size: 0.93rem;
  }
}

@media (max-width: 575.98px) {
  .jas-value-grid {
    grid-template-columns: 1fr;
  }

  .jas-value-section {
    padding: 76px 0 82px;
  }

  .jas-value-header {
    margin-bottom: 34px;
  }

.jas-value-card:nth-child(even) .jas-value-hover-layer {
  left: 0;
  right: 0;
  top: 118px;
  transform: translateY(100%);
  background:
    linear-gradient(180deg, rgba(7, 23, 38, 0.72) 0%, rgba(7, 23, 38, 0.98) 100%);
}

  .jas-value-card:nth-child(even):hover .jas-value-hover-layer {
    transform: translateY(0);
  }

  .jas-value-card:nth-child(even):hover .jas-value-content {
    transform: translateY(22px);
    opacity: 0.02;
  }

  .jas-value-card:nth-child(even):hover .jas-value-number {
    transform: translateY(10px) scale(0.94);
    opacity: 0.10;
  }
}

/* ========================================= */
/* CTA FINAL / CONTACTO - VERSIÓN CLARA      */
/* ========================================= */

.jas-final-cta-section {
  position: relative;
  padding: 95px 0 105px;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 24%, rgba(27, 167, 216, 0.07), transparent 24%),
    radial-gradient(circle at 82% 76%, rgba(21, 107, 154, 0.08), transparent 28%),
    linear-gradient(180deg, #E6EFF4 0%, #DCE8F0 100%);
}

.jas-final-cta-bg,
.jas-final-cta-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.jas-final-cta-bg {
  background:
    radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.28), transparent 34%);
  z-index: 1;
}

.jas-final-cta-overlay {
  display: none;
}

.jas-final-cta-section .container {
  position: relative;
  z-index: 5;
}

.jas-final-cta-inner {
  max-width: 920px;
  margin: 0 auto;
  text-align: center;
  padding: 0 10px;
}

.jas-final-cta-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  color: #156B9A;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.jas-final-cta-label::before {
  content: "";
  width: 44px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 100%);
}

.jas-final-cta-title {
  margin: 0 auto 18px;
  max-width: 760px;
  font-size: clamp(2rem, 3vw, 3.1rem);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #0F3554;
}

.jas-final-cta-text {
  margin: 0 auto 30px;
  max-width: 720px;
  font-size: 1rem;
  line-height: 1.78;
  color: #4F6578;
}

.jas-final-cta-buttons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}

.jas-final-cta-btn-primary,
.jas-final-cta-btn-secondary {
  min-width: 220px;
  padding: 15px 28px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.98rem;
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease,
    background 0.3s ease,
    color 0.3s ease,
    border-color 0.3s ease;
}

.jas-final-cta-btn-primary {
  background: linear-gradient(145deg, #0F3554 0%, #156B9A 58%, #1BA7D8 100%);
  color: #ffffff;
  border: none;
  box-shadow: 0 16px 34px rgba(21, 107, 154, 0.22);
}

.jas-final-cta-btn-primary:hover {
  color: #ffffff;
  transform: translateY(-3px);
  box-shadow: 0 20px 38px rgba(21, 107, 154, 0.28);
}

.jas-final-cta-btn-secondary {
  background: rgba(255, 255, 255, 0.72);
  color: #17324D;
  border: 1px solid rgba(21, 107, 154, 0.14);
  box-shadow:
    0 10px 24px rgba(15, 53, 84, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.84);
}

.jas-final-cta-btn-secondary:hover {
  color: #0F3554;
  transform: translateY(-3px);
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(27, 167, 216, 0.22);
}

.jas-final-cta-meta {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px 22px;
  flex-wrap: wrap;
  color: #5E7488;
  font-size: 0.92rem;
  font-weight: 600;
}

.jas-final-cta-meta span {
  position: relative;
  padding-left: 18px;
}

.jas-final-cta-meta span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  transform: translateY(-50%);
  background: linear-gradient(145deg, #1BA7D8 0%, #156B9A 100%);
  box-shadow: 0 0 0 5px rgba(27, 167, 216, 0.08);
}

/* ========================================= */
/* RESPONSIVE                                */
/* ========================================= */

@media (max-width: 991.98px) {
  .jas-final-cta-section {
    padding: 82px 0 90px;
  }
}

@media (max-width: 767.98px) {
  .jas-final-cta-title {
    font-size: 1.9rem;
    line-height: 1.12;
  }

  .jas-final-cta-text {
    font-size: 0.96rem;
    line-height: 1.72;
  }

  .jas-final-cta-btn-primary,
  .jas-final-cta-btn-secondary {
    width: 100%;
    min-width: 0;
  }

  .jas-final-cta-buttons {
    gap: 12px;
  }

  .jas-final-cta-meta {
    font-size: 0.88rem;
    gap: 10px 16px;
  }
}

@media (max-width: 575.98px) {
  .jas-final-cta-section {
    padding: 72px 0 78px;
  }
}

/* ========================================= */
/* FOOTER JAS SOLUTIONS - NUEVA VERSIÓN      */
/* ========================================= */

.jas-footer {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 24%, rgba(27, 167, 216, 0.10), transparent 24%),
    radial-gradient(circle at 82% 76%, rgba(21, 107, 154, 0.12), transparent 28%),
    linear-gradient(180deg, #071726 0%, #091d2f 100%);
  color: #EAF4F8;
  padding: 72px 0 24px;
}

.jas-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.05;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.08) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: radial-gradient(circle at center, rgba(0,0,0,1) 42%, rgba(0,0,0,0.2) 75%, transparent 100%);
  -webkit-mask-image: radial-gradient(circle at center, rgba(0,0,0,1) 42%, rgba(0,0,0,0.2) 75%, transparent 100%);
}

.jas-footer .container {
  position: relative;
  z-index: 2;
}

.jas-footer-grid {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) max-content max-content max-content;
  column-gap: 64px;
  row-gap: 24px;
  align-items: start;
  justify-content: space-between;
  padding-bottom: 34px;
  border-bottom: 1px solid rgba(123, 220, 255, 0.12);
}

.jas-footer-brand {
  max-width: 360px;
}

.jas-footer-logo {
  width: 92px;
  height: auto;
  object-fit: contain;
  flex-shrink: 0;
  margin-bottom: 0;
  filter: drop-shadow(0 12px 24px rgba(0, 0, 0, 0.16));
}

.jas-footer-description {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.75;
  color: rgba(219, 233, 242, 0.78);
}

.jas-footer-title {
  margin: 0 0 18px;
  font-size: 1rem;
  font-weight: 800;
  color: #FFFFFF;
  letter-spacing: -0.01em;
}

.jas-footer-links,
.jas-footer-contact {
  list-style: none;
  padding: 0;
  margin: 0;
}

.jas-footer-links li,
.jas-footer-contact li {
  margin-bottom: 12px;
}

.jas-footer-links a {
  color: rgba(219, 233, 242, 0.78);
  text-decoration: none;
  transition: color 0.3s ease, padding-left 0.3s ease;
}

.jas-footer-links a:hover {
  color: #7BDCFF;
  padding-left: 4px;
}

.jas-footer-contact li {
  color: rgba(219, 233, 242, 0.78);
  line-height: 1.65;
}

.jas-footer-contact strong {
  color: #FFFFFF;
  font-weight: 700;
}

.jas-footer-bottom {
  padding-top: 22px;
  text-align: center;
}

.jas-footer-bottom p {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(219, 233, 242, 0.68);
}

/* ========================================= */
/* RESPONSIVE                                */
/* ========================================= */

@media (max-width: 1199.98px) {
  .jas-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 34px 28px;
  }
}

@media (max-width: 767.98px) {
  .jas-footer {
    padding: 56px 0 22px;
  }

  .jas-footer-grid {
    grid-template-columns: 1fr;
    gap: 26px;
    padding-bottom: 26px;
  }

  .jas-footer-logo {
    width: 76px;
    margin-bottom: 12px;
  }

  .jas-footer-description,
  .jas-footer-links a,
  .jas-footer-contact li {
    font-size: 0.93rem;
  }

  .jas-footer-bottom p {
    font-size: 0.86rem;
  }
}

/* ========================================= */
/* PALETA REFINADA JAS - OVERRIDE GENERAL    */
/* Pegar al final del style.css              */
/* ========================================= */

:root {
  --jas-navy-950: #081F33;
  --jas-navy-900: #0A2740;
  --jas-navy-800: #0F3554;
  --jas-blue-700: #156B9A;
  --jas-cyan-500: #22B8F0;
  --jas-cyan-400: #58D7FF;
  --jas-bg-soft: #EEF5F9;
  --jas-bg-soft-2: #E7F0F6;
  --jas-white: #FFFFFF;
  --jas-text: #17324D;
  --jas-muted: #5E7488;
  --jas-line: rgba(21, 107, 154, 0.14);
  --jas-glow-soft: rgba(34, 184, 240, 0.12);
  --jas-glow-medium: rgba(34, 184, 240, 0.18);
}

body {
  color: var(--jas-text);
  background-color: var(--jas-bg-soft);
}

/* NAVBAR */
.jas-navbar {
  background: rgba(255, 255, 255, 0.56);
  border-bottom: 1px solid rgba(15, 53, 84, 0.05);
}

.jas-navbar.scrolled {
  background: rgba(255, 255, 255, 0.92);
  border-bottom: 1px solid rgba(15, 53, 84, 0.08);
  box-shadow: 0 12px 30px rgba(10, 39, 64, 0.08);
}

.jas-navbar .nav-link {
  color: var(--jas-navy-800) !important;
}

.jas-navbar .nav-link:hover,
.jas-navbar .nav-link:focus {
  color: var(--jas-blue-700) !important;
  background: rgba(34, 184, 240, 0.08);
}

/* HERO */
.hero-section {
  background:
    radial-gradient(circle at 12% 20%, rgba(34, 184, 240, 0.09) 0%, rgba(34, 184, 240, 0) 30%),
    radial-gradient(circle at 82% 18%, rgba(88, 215, 255, 0.10) 0%, rgba(88, 215, 255, 0) 24%),
    radial-gradient(circle at 72% 70%, rgba(21, 107, 154, 0.06) 0%, rgba(21, 107, 154, 0) 26%),
    linear-gradient(135deg, #F9FCFE 0%, #EEF5F9 55%, #FFFFFF 100%);
}

.hero-eyebrow {
  color: var(--jas-blue-700);
  border-bottom: 1px solid rgba(21, 107, 154, 0.18);
}

.hero-title {
  color: var(--jas-navy-800);
}

.hero-description {
  color: var(--jas-muted);
}

.hero-btn-primary {
  background: linear-gradient(135deg, var(--jas-navy-800) 0%, var(--jas-blue-700) 55%, var(--jas-cyan-500) 100%);
  border: none;
  color: var(--jas-white) !important;
  box-shadow: 0 14px 34px rgba(21, 107, 154, 0.24);
}

.hero-btn-primary:hover {
  background: linear-gradient(135deg, var(--jas-navy-900) 0%, var(--jas-navy-800) 100%);
  transform: translateY(-2px);
}

.hero-btn-secondary {
  background-color: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(15, 53, 84, 0.14);
  color: var(--jas-navy-800) !important;
  box-shadow: 0 10px 24px rgba(10, 39, 64, 0.07);
}

.hero-btn-secondary:hover {
  background-color: var(--jas-navy-800);
  border-color: var(--jas-navy-800);
  color: var(--jas-white) !important;
}

/* ENFOQUE */
.jas-approach-section {
  background: var(--jas-navy-950);
}

.jas-approach-bg {
  background:
    radial-gradient(circle at 18% 24%, rgba(34, 184, 240, 0.18), transparent 24%),
    radial-gradient(circle at 82% 72%, rgba(21, 107, 154, 0.18), transparent 30%),
    linear-gradient(135deg, var(--jas-navy-950) 0%, var(--jas-navy-900) 48%, #0D3049 100%);
}

.jas-approach-overlay {
  background:
    radial-gradient(circle at 50% 50%, rgba(88, 215, 255, 0.05), transparent 40%),
    linear-gradient(180deg, rgba(8, 31, 51, 0.10) 0%, rgba(8, 31, 51, 0.28) 100%);
}

.jas-approach-grid {
  opacity: 0.06;
}

.jas-approach-label,
.jas-value-label {
  color: var(--jas-cyan-400);
}

.jas-approach-label::before,
.jas-value-label::before,
.jas-services-label::before,
.jas-final-cta-label::before {
  background: linear-gradient(90deg, var(--jas-cyan-500) 0%, var(--jas-cyan-400) 100%);
}

.jas-approach-intro,
.jas-value-intro {
  color: rgba(231, 241, 246, 0.82);
}

.jas-step-index {
  background: rgba(12, 42, 66, 0.84);
  border: 1px solid rgba(88, 215, 255, 0.20);
}

.jas-approach-step.is-active .jas-step-index,
.jas-approach-step:hover .jas-step-index {
  background: linear-gradient(145deg, var(--jas-blue-700) 0%, var(--jas-cyan-500) 100%);
  border-color: rgba(88, 215, 255, 0.45);
  box-shadow:
    0 16px 32px rgba(17, 102, 143, 0.32),
    0 0 0 8px rgba(34, 184, 240, 0.08);
}

.jas-visual-shell {
  background: linear-gradient(180deg, rgba(255,255,255,0.07) 0%, rgba(255,255,255,0.025) 100%);
  border: 1px solid rgba(88, 215, 255, 0.14);
  box-shadow:
    0 28px 64px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255,255,255,0.05);
}

/* SERVICIOS */
.jas-services-section {
  background:
    radial-gradient(circle at top right, rgba(34, 184, 240, 0.08), transparent 28%),
    radial-gradient(circle at 18% 82%, rgba(21, 107, 154, 0.05), transparent 26%),
    linear-gradient(180deg, #F7FBFD 0%, var(--jas-bg-soft) 100%);
}

.jas-services-label {
  color: var(--jas-blue-700);
}

.jas-services-title,
.jas-final-cta-title {
  color: var(--jas-navy-800);
}

.jas-services-intro,
.jas-final-cta-text,
.jas-service-text {
  color: var(--jas-muted);
}

.jas-service-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(249,252,254,0.94) 100%);
  border: 1px solid rgba(21, 107, 154, 0.11);
  box-shadow:
    0 18px 44px rgba(10, 39, 64, 0.08),
    inset 0 1px 0 rgba(255,255,255,0.86);
}

.jas-service-card::before {
  background: linear-gradient(90deg, var(--jas-navy-800) 0%, var(--jas-blue-700) 48%, var(--jas-cyan-500) 100%);
}

.jas-service-card:hover {
  border-color: rgba(34, 184, 240, 0.22);
  box-shadow:
    0 24px 54px rgba(10, 39, 64, 0.14),
    0 0 0 1px rgba(34, 184, 240, 0.04);
}

.jas-service-icon {
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.34) 0%, rgba(255,255,255,0.07) 34%, transparent 35%),
    linear-gradient(145deg, var(--jas-navy-800) 0%, var(--jas-blue-700) 58%, var(--jas-cyan-500) 100%);
  box-shadow:
    0 14px 30px rgba(21, 107, 154, 0.24),
    inset 0 1px 0 rgba(255,255,255,0.18);
}

.jas-service-card .jas-service-title {
  color: var(--jas-navy-800) !important;
}

/* VALOR DIFERENCIAL */
.jas-value-section {
  background: var(--jas-navy-950);
}

.jas-value-bg {
  background:
    radial-gradient(circle at 18% 22%, rgba(34, 184, 240, 0.12), transparent 24%),
    radial-gradient(circle at 82% 78%, rgba(21, 107, 154, 0.14), transparent 28%),
    linear-gradient(180deg, var(--jas-navy-950) 0%, var(--jas-navy-900) 100%);
}

.jas-value-overlay {
  opacity: 0.05;
}

.jas-value-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.07) 0%, rgba(255,255,255,0.03) 100%);
  border: 1px solid rgba(88, 215, 255, 0.12);
  box-shadow:
    0 20px 46px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255,255,255,0.04);
}

.jas-value-card::before {
  background: linear-gradient(90deg, var(--jas-cyan-500) 0%, var(--jas-blue-700) 50%, var(--jas-navy-800) 100%);
}

.jas-value-card:hover {
  border-color: rgba(88, 215, 255, 0.24);
  box-shadow:
    0 26px 56px rgba(0, 0, 0, 0.30),
    0 0 0 1px rgba(34, 184, 240, 0.05);
}

.jas-value-number {
  background: linear-gradient(145deg, var(--jas-navy-800) 0%, var(--jas-blue-700) 58%, var(--jas-cyan-500) 100%);
}

.jas-value-card-title {
  color: var(--jas-white);
}

.jas-value-card-text {
  color: rgba(219, 233, 242, 0.82);
}

/* CTA FINAL */
.jas-final-cta-section {
  background:
    radial-gradient(circle at 18% 24%, rgba(34, 184, 240, 0.08), transparent 24%),
    radial-gradient(circle at 82% 76%, rgba(21, 107, 154, 0.08), transparent 28%),
    linear-gradient(180deg, #EDF5F9 0%, #E4EFF5 100%);
}

.jas-final-cta-label {
  color: var(--jas-blue-700);
}

.jas-final-cta-btn-primary {
  background: linear-gradient(145deg, var(--jas-navy-800) 0%, var(--jas-blue-700) 58%, var(--jas-cyan-500) 100%);
  box-shadow: 0 16px 36px rgba(21, 107, 154, 0.24);
}

.jas-final-cta-btn-primary:hover {
  box-shadow: 0 20px 40px rgba(21, 107, 154, 0.30);
}

.jas-final-cta-btn-secondary {
  background: rgba(255, 255, 255, 0.84);
  color: var(--jas-text);
  border: 1px solid rgba(21, 107, 154, 0.14);
}

.jas-final-cta-btn-secondary:hover {
  color: var(--jas-navy-800);
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(34, 184, 240, 0.24);
}

.jas-final-cta-meta {
  color: var(--jas-muted);
}

.jas-final-cta-meta span::before {
  background: linear-gradient(145deg, var(--jas-cyan-500) 0%, var(--jas-blue-700) 100%);
  box-shadow: 0 0 0 5px rgba(34, 184, 240, 0.08);
}

/* FOOTER */
.jas-footer {
  background:
    radial-gradient(circle at 18% 24%, rgba(34, 184, 240, 0.12), transparent 24%),
    radial-gradient(circle at 82% 76%, rgba(21, 107, 154, 0.14), transparent 28%),
    linear-gradient(180deg, var(--jas-navy-950) 0%, #0A2236 100%);
  color: #EAF4F8;
}

.jas-footer-grid {
  border-bottom: 1px solid rgba(88, 215, 255, 0.12);
}

.jas-footer-links a:hover {
  color: var(--jas-cyan-400);
}

/* ========================================= */
/* AJUSTE 1.1 - PULIDO VISUAL JAS            */
/* ========================================= */

/* NAVBAR MÁS LIMPIO */
.jas-navbar {
  background: rgba(255, 255, 255, 0.78);
  border-bottom: 1px solid rgba(15, 53, 84, 0.04);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.jas-navbar.scrolled {
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 10px 26px rgba(10, 39, 64, 0.08);
}

/* HERO MÁS LUMINOSO Y CON MÁS ATMÓSFERA */
.hero-section {
  background:
    radial-gradient(circle at 12% 20%, rgba(34, 184, 240, 0.09) 0%, rgba(34, 184, 240, 0) 30%),
    radial-gradient(circle at 82% 18%, rgba(88, 215, 255, 0.10) 0%, rgba(88, 215, 255, 0) 24%),
    radial-gradient(circle at 72% 70%, rgba(21, 107, 154, 0.06) 0%, rgba(21, 107, 154, 0) 26%),
    linear-gradient(135deg, #F9FCFE 0%, #EEF5F9 55%, #FFFFFF 100%);
}

/* SECCIÓN SERVICIOS CON MÁS PROFUNDIDAD */
.jas-services-section {
  background:
    radial-gradient(circle at 15% 20%, rgba(34, 184, 240, 0.05), transparent 24%),
    radial-gradient(circle at 85% 80%, rgba(21, 107, 154, 0.04), transparent 28%),
    linear-gradient(180deg, #F8FBFD 0%, #EDF4F8 100%);
}

.jas-service-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,253,0.96) 100%);
  border: 1px solid rgba(21, 107, 154, 0.09);
  box-shadow:
    0 20px 46px rgba(10, 39, 64, 0.08),
    0 6px 14px rgba(21, 107, 154, 0.04);
}

.jas-service-card:hover {
  transform: translateY(-6px);
  box-shadow:
    0 28px 60px rgba(10, 39, 64, 0.14),
    0 10px 22px rgba(21, 107, 154, 0.08);
}

/* TÍTULOS DE CARDS MÁS LIMPIOS */
.jas-service-title {
  line-height: 1.15;
}

/* CTA FINAL UN POCO MÁS PREMIUM */
.jas-final-cta-section {
  background:
    radial-gradient(circle at 20% 20%, rgba(34, 184, 240, 0.06), transparent 24%),
    radial-gradient(circle at 80% 75%, rgba(21, 107, 154, 0.05), transparent 28%),
    linear-gradient(180deg, #F2F8FB 0%, #EAF2F7 100%);
}

/* ========================================== */
/* FONDOS TECNOLÓGICOS SUTILES - JAS          */
/* ========================================== */

/* Base común */
.jas-approach-section,
.jas-value-section,
.jas-final-cta-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

/* para que el contenido quede encima */
.jas-approach-section > *,
.jas-value-section > *,
.jas-final-cta-section > * {
  position: relative;
  z-index: 2;
}

/* ========================= */
/* 1) NUESTRO ENFOQUE        */
/* ========================= */

.jas-approach-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.32;
  background-image:
    radial-gradient(circle at 18% 28%, rgba(34, 184, 240, 0.18) 0, rgba(34, 184, 240, 0) 18%),
    radial-gradient(circle at 82% 72%, rgba(88, 215, 255, 0.16) 0, rgba(88, 215, 255, 0) 18%),
    radial-gradient(circle at 70% 30%, rgba(21, 107, 154, 0.12) 0, rgba(21, 107, 154, 0) 22%),
    linear-gradient(rgba(255,255,255,0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.045) 1px, transparent 1px);
  background-size:
    auto,
    auto,
    auto,
    120px 120px,
    120px 120px;
  background-position:
    center,
    center,
    center,
    0 0,
    0 0;
}

.jas-approach-section::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(circle at 78% 36%, rgba(34, 184, 240, 0.16), transparent 22%),
    radial-gradient(circle at 22% 75%, rgba(21, 107, 154, 0.12), transparent 24%);
  filter: blur(8px);
  opacity: 0.9;
}

/* líneas decorativas suaves */
.jas-approach-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0.14;
  background:
    linear-gradient(115deg, transparent 0 42%, rgba(88, 215, 255, 0.22) 50%, transparent 58%),
    linear-gradient(25deg, transparent 0 46%, rgba(34, 184, 240, 0.18) 50%, transparent 54%);
}

/* ========================= */
/* 2) VALOR DIFERENCIAL      */
/* ========================= */

.jas-value-section::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 24%;
  width: 620px;
  height: 280px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  background: radial-gradient(ellipse, rgba(34, 184, 240, 0.08) 0%, rgba(34, 184, 240, 0) 72%);
  filter: blur(20px);
}

.jas-value-section::after {
  content: "";
  position: absolute;
  right: 6%;
  top: 44%;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  background: radial-gradient(circle, rgba(88, 215, 255, 0.065) 0%, rgba(88, 215, 255, 0) 68%);
  filter: blur(24px);
}

/* un leve glow en el centro */
.jas-value-bg::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 44%;
  width: 680px;
  height: 680px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 1;
  background: radial-gradient(circle, rgba(34, 184, 240, 0.10) 0%, rgba(34, 184, 240, 0) 62%);
  filter: blur(18px);
}

/* ========================= */
/* 3) CTA FINAL             */
/* ========================= */

.jas-final-cta-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.22;
  background:
    radial-gradient(circle at 30% 28%, rgba(34, 184, 240, 0.10), transparent 18%),
    radial-gradient(circle at 72% 70%, rgba(21, 107, 154, 0.08), transparent 22%);
}

.jas-final-cta-section::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 34%;
  width: 540px;
  height: 540px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 1;
  background: radial-gradient(circle, rgba(88, 215, 255, 0.10) 0%, rgba(88, 215, 255, 0) 65%);
  filter: blur(20px);
}

/* detalle sutil para el título del CTA */
.jas-final-cta-title {
  position: relative;
  z-index: 2;
}

/* ========================================== */
/* FONDOS TECNOLÓGICOS VISIBLES PERO SUTILES  */
/* USANDO LAS CAPAS YA EXISTENTES DE JAS      */
/* ========================================== */

/* -------------------------------------------------- */
/* 1. NUESTRO ENFOQUE                                 */
/* -------------------------------------------------- */

.jas-approach-bg {
  background:
    radial-gradient(circle at 16% 24%, rgba(34, 184, 240, 0.16) 0%, transparent 18%),
    radial-gradient(circle at 82% 70%, rgba(88, 215, 255, 0.14) 0%, transparent 20%),
    radial-gradient(circle at 68% 30%, rgba(21, 107, 154, 0.12) 0%, transparent 24%),
    linear-gradient(135deg, #071826 0%, #0b2236 45%, #081a2b 100%);
  opacity: 1;
}

.jas-approach-overlay {
  background:
    radial-gradient(circle at 20% 28%, rgba(34, 184, 240, 0.10), transparent 18%),
    radial-gradient(circle at 78% 68%, rgba(88, 215, 255, 0.08), transparent 18%),
    linear-gradient(115deg, transparent 0 43%, rgba(88, 215, 255, 0.10) 50%, transparent 57%),
    linear-gradient(30deg, transparent 0 45%, rgba(34, 184, 240, 0.08) 50%, transparent 55%);
  z-index: 1;
  opacity: 0.85;
}

.jas-approach-grid {
  z-index: 2;
  opacity: 0.14;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px),
    radial-gradient(circle at 18% 30%, rgba(88,215,255,0.26) 0 2px, transparent 3px),
    radial-gradient(circle at 32% 52%, rgba(88,215,255,0.20) 0 2px, transparent 3px),
    radial-gradient(circle at 52% 24%, rgba(88,215,255,0.20) 0 2px, transparent 3px),
    radial-gradient(circle at 72% 42%, rgba(88,215,255,0.20) 0 2px, transparent 3px),
    radial-gradient(circle at 84% 68%, rgba(88,215,255,0.24) 0 2px, transparent 3px),
    linear-gradient(125deg, transparent 0 21%, rgba(88,215,255,0.10) 21.5%, rgba(88,215,255,0.10) 22%, transparent 22.5%),
    linear-gradient(28deg, transparent 0 51%, rgba(88,215,255,0.08) 51.5%, rgba(88,215,255,0.08) 52%, transparent 52.5%);
  background-size:
    52px 52px,
    52px 52px,
    100% 100%,
    100% 100%,
    100% 100%,
    100% 100%,
    100% 100%,
    100% 100%,
    100% 100%;
  mask-image: radial-gradient(circle at center, rgba(0,0,0,1) 48%, rgba(0,0,0,0.22) 78%, transparent 100%);
  -webkit-mask-image: radial-gradient(circle at center, rgba(0,0,0,1) 48%, rgba(0,0,0,0.22) 78%, transparent 100%);
}

/* -------------------------------------------------- */
/* 2. ¿POR QUÉ ELEGIR JAS?                            */
/* -------------------------------------------------- */

.jas-value-bg {
  background:
    radial-gradient(circle at 18% 24%, rgba(34, 184, 240, 0.12), transparent 22%),
    radial-gradient(circle at 82% 78%, rgba(21, 107, 154, 0.14), transparent 24%),
    radial-gradient(circle at 50% 44%, rgba(88, 215, 255, 0.06), transparent 30%),
    linear-gradient(180deg, #071726 0%, #0a1d2f 100%);
  z-index: 1;
}

.jas-value-overlay {
  z-index: 2;
  opacity: 0.12;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px),
    radial-gradient(circle at 22% 28%, rgba(88,215,255,0.18) 0 2px, transparent 3px),
    radial-gradient(circle at 76% 34%, rgba(88,215,255,0.18) 0 2px, transparent 3px),
    radial-gradient(circle at 68% 76%, rgba(88,215,255,0.18) 0 2px, transparent 3px),
    linear-gradient(135deg, transparent 0 35%, rgba(88,215,255,0.08) 35.5%, rgba(88,215,255,0.08) 36%, transparent 36.5%);
  background-size:
    58px 58px,
    58px 58px,
    100% 100%,
    100% 100%,
    100% 100%,
    100% 100%;
  mask-image: radial-gradient(circle at center, rgba(0,0,0,1) 44%, rgba(0,0,0,0.24) 76%, transparent 100%);
  -webkit-mask-image: radial-gradient(circle at center, rgba(0,0,0,1) 44%, rgba(0,0,0,0.24) 76%, transparent 100%);
}

/* -------------------------------------------------- */
/* 3. CTA FINAL                                       */
/* -------------------------------------------------- */

.jas-final-cta-bg {
  background:
    radial-gradient(circle at 50% 8%, rgba(255, 255, 255, 0.34), transparent 28%),
    radial-gradient(circle at 18% 32%, rgba(34, 184, 240, 0.08), transparent 18%),
    radial-gradient(circle at 78% 72%, rgba(21, 107, 154, 0.08), transparent 20%);
  z-index: 1;
}

.jas-final-cta-overlay {
  display: block;
  z-index: 2;
  opacity: 0.10;
  background-image:
    radial-gradient(circle at 30% 34%, rgba(88,215,255,0.20) 0 2px, transparent 3px),
    radial-gradient(circle at 70% 46%, rgba(88,215,255,0.16) 0 2px, transparent 3px),
    radial-gradient(circle at 58% 70%, rgba(88,215,255,0.14) 0 2px, transparent 3px),
    linear-gradient(122deg, transparent 0 47%, rgba(88,215,255,0.08) 47.5%, rgba(88,215,255,0.08) 48%, transparent 48.5%);
  background-size: 100% 100%;
  mask-image: radial-gradient(circle at center, rgba(0,0,0,0.9) 36%, rgba(0,0,0,0.16) 72%, transparent 100%);
  -webkit-mask-image: radial-gradient(circle at center, rgba(0,0,0,0.9) 36%, rgba(0,0,0,0.16) 72%, transparent 100%);
}

/* ===================================================== */
/* AJUSTE FINAL NAVBAR + HERO - JAS SOLUTIONS            */
/* Bloque final autoritativo para cerrar conflictos      */
/* ===================================================== */

:root {
  --jas-header-height: 112px;
  --jas-header-height-scrolled: 84px;
}

#navbar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1200;
}

.jas-navbar {
  padding: 12px 0 12px;
  background: transparent !important;
  border-bottom: 1px solid transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  transition:
    background 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.35s ease,
    backdrop-filter 0.35s ease,
    padding 0.35s ease;
}

.jas-navbar.scrolled {
  padding: 12px 0 12px;
  background: rgba(255, 255, 255, 0.74) !important;
  border-bottom: 1px solid rgba(15, 53, 84, 0.06);
  box-shadow: 0 14px 34px rgba(10, 39, 64, 0.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.jas-navbar .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 56px;
}

.jas-brand {
  min-height: 55px;
  margin-right: 36px;
}

.jas-brand img {
  height: 40px;
  transform: scale(1.9);
  transform-origin: left center;
}

.jas-navbar .navbar-collapse {
  justify-content: flex-end;
}

.jas-navbar .navbar-nav {
  gap: 12px;
}

.jas-navbar .nav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 14px !important;
  border-radius: 12px;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #0F3554 !important;
}

.jas-navbar .nav-link:hover,
.jas-navbar .nav-link:focus {
  color: #156B9A !important;
  background: rgba(34, 184, 240, 0.08);
}

.hero-section {
  position: relative;
  background:
    radial-gradient(circle at 10% 18%, rgba(34, 184, 240, 0.09) 0%, rgba(34, 184, 240, 0) 32%),
    radial-gradient(circle at 84% 20%, rgba(88, 215, 255, 0.12) 0%, rgba(88, 215, 255, 0) 26%),
    radial-gradient(circle at 74% 74%, rgba(21, 107, 154, 0.06) 0%, rgba(21, 107, 154, 0) 26%),
    linear-gradient(135deg, #F9FCFE 0%, #EEF5F9 55%, #FFFFFF 100%);
  padding-top: 180px;
  padding-bottom: 74px;
}

.hero-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 72% 42%, rgba(255, 255, 255, 0.30) 0%, rgba(255, 255, 255, 0) 30%),
    linear-gradient(180deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0) 26%);
}

.hero-container {
  position: relative;
  z-index: 2;
}

.hero-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.96fr) minmax(0, 1.04fr);
  align-items: center;
  gap: 32px;
  min-height: 620px;
}

.hero-content {
  max-width: 610px;
  align-self: center;
  margin-top: 0;
}

.hero-eyebrow {
  margin-bottom: 18px;
  padding-bottom: 10px;
  font-size: 0.98rem;
  font-weight: 700;
  line-height: 1.4;
  color: #156B9A;
  border-bottom: 1px solid rgba(21, 107, 154, 0.16);
}

.hero-title {
  margin: 0 0 24px;
  max-width: 690px;
  font-size: clamp(3rem, 4.7vw, 5rem);
  line-height: 1.02;
  font-weight: 800;
  letter-spacing: -0.045em;
  color: #0F3554;
}

.hero-description {
  max-width: 560px;
  margin: 0 0 28px;
  font-size: 1.18rem;
  line-height: 1.82;
  color: #5E7488;
}

.hero-buttons {
  gap: 16px;
}

.hero-btn-primary,
.hero-btn-secondary {
  min-height: 58px;
  padding: 0 28px;
  border-radius: 16px;
  font-size: 1rem;
  font-weight: 700;
}

.hero-btn-primary {
  background: linear-gradient(135deg, #0F3554 0%, #156B9A 56%, #22B8F0 100%);
  border: 0;
  color: #FFFFFF !important;
  box-shadow: 0 18px 38px rgba(21, 107, 154, 0.22);
}

.hero-btn-primary:hover {
  background: linear-gradient(135deg, #0A2740 0%, #0F3554 100%);
  transform: translateY(-3px);
}

.hero-btn-secondary {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(15, 53, 84, 0.14);
  color: #0F3554 !important;
  box-shadow: 0 12px 26px rgba(15, 53, 84, 0.07);
}

.hero-btn-secondary:hover {
  background: #0F3554;
  border-color: #0F3554;
  color: #FFFFFF !important;
  transform: translateY(-3px);
}

.hero-visual {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.hero-visual-frame {
  width: 100%;
  max-width: 980px;
  height: 560px;
  overflow: visible;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-artwork {
  width: 860px;
  max-width: none;
  height: auto;
  object-fit: contain;
  transform: translate(22px, 8px) scale(1.12);
  transform-origin: center center;
  margin-top: 0;
}

@media (max-width: 1399.98px) {
  .hero-layout {
    min-height: 590px;
  }

  .hero-title {
    font-size: clamp(2.8rem, 4.5vw, 4.4rem);
  }

  .hero-description {
    font-size: 1.08rem;
  }

  .hero-visual-frame {
    height: 510px;
  }

  .hero-artwork {
    width: 790px;
    transform: translate(18px, 8px) scale(1.08);
  }
}

@media (max-width: 1199.98px) {
  .jas-navbar {
    padding: 24px 0 20px;
  }

  .jas-navbar.scrolled {
    padding: 16px 0 14px;
  }

  .jas-brand {
    min-height: 64px;
  }

  .jas-brand img {
    height: 38px;
    transform: scale(1.72);
  }

  .jas-navbar .navbar-nav {
    gap: 8px;
  }

  .jas-navbar .nav-link {
    min-height: 42px;
    padding: 0 11px !important;
    font-size: 0.98rem;
  }

  .hero-section {
    padding-top: 168px;
    padding-bottom: 62px;
  }

  .hero-layout {
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    min-height: 540px;
  }

  .hero-title {
    font-size: clamp(2.6rem, 4.4vw, 4rem);
  }

  .hero-description {
    font-size: 1.03rem;
  }

  .hero-visual-frame {
    height: 470px;
    max-width: 860px;
  }

  .hero-artwork {
    width: 720px;
    transform: translate(12px, 4px) scale(1.04);
  }
}

@media (max-width: 991.98px) {
  .jas-navbar {
    padding: 18px 0;
    background: rgba(255, 255, 255, 0.56) !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(15, 53, 84, 0.05);
  }

  .jas-navbar.scrolled {
    padding: 16px 0;
    background: rgba(255, 255, 255, 0.92) !important;
  }

  .jas-navbar .container {
    display: block;
  }

  .jas-brand {
    min-height: auto;
  }

  .jas-brand img {
    height: 52px;
    transform: scale(1.38);
  }

  .jas-navbar .navbar-collapse {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid rgba(14, 111, 120, 0.08);
  }

  .jas-navbar .navbar-nav {
    gap: 4px;
  }

  .jas-navbar .nav-link {
    justify-content: flex-start;
    min-height: 46px;
    padding: 10px 0 !important;
    border-radius: 0;
  }

  .hero-section {
    padding-top: 138px;
    padding-bottom: 48px;
  }

  .hero-layout {
    grid-template-columns: 1fr;
    gap: 28px;
    min-height: auto;
  }

  .hero-content {
    max-width: 100%;
    text-align: center;
    margin: 0 auto;
  }

  .hero-eyebrow {
    margin-left: auto;
    margin-right: auto;
  }

  .hero-title {
    max-width: 100%;
    font-size: clamp(2.4rem, 7vw, 3.6rem);
  }

  .hero-description {
    max-width: 100%;
    font-size: 1rem;
  }

  .hero-buttons {
    justify-content: center;
  }

  .hero-visual {
    justify-content: center;
  }

  .hero-visual-frame {
    max-width: 700px;
    height: 380px;
  }

  .hero-artwork {
    width: 620px;
    transform: translate(0, 0) scale(1.02);
  }

}

@media (max-width: 767.98px) {
  .container {
    padding-left: 18px;
    padding-right: 18px;
  }

  .jas-brand img {
    height: 48px;
    transform: scale(1.18);
    margin-left: -6px;
  }

  .hero-section {
    padding-top: 128px;
    padding-bottom: 36px;
  }

  .hero-eyebrow {
    font-size: 0.86rem;
    margin-bottom: 14px;
  }

  .hero-title {
    font-size: clamp(2.15rem, 9vw, 3rem);
    letter-spacing: -0.04em;
  }

  .hero-description {
    font-size: 0.98rem;
    line-height: 1.72;
  }

  .hero-buttons {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }

  .hero-btn-primary,
  .hero-btn-secondary {
    width: 100%;
    min-height: 54px;
    font-size: 1rem;
  }

  .hero-visual-frame {
    height: 280px;
  }

  .hero-artwork {
    width: 100%;
    max-width: 500px;
    transform: translate(0, 0) scale(1);
  }
}

/* ===================================== */
/* AJUSTE HERO - TÍTULO 3 LÍNEAS         */
/* ===================================== */

.hero-content {
  max-width: 560px;
  margin-top: 0;
}

.hero-title {
  margin: 0 0 18px;
  font-size: clamp(1.9rem, 2.55vw, 2.85rem);
  line-height: 1.04;
  letter-spacing: -0.03em;
}

.hero-description {
  max-width: 500px;
  margin: 0 0 18px;
}

.hero-buttons {
  margin-top: 2px;
}

/* imagen un poco más abajo */
.hero-visual-frame {
  height: 410px;
}

.hero-artwork {
  width: 720px;
  transform: translate(18px, 18px) scale(1.04);
  margin-top: 0;
}

/* ===================================================== */
/* ENFOQUE - RED TECNOLÓGICA FINAL VISIBLE               */
/* BLOQUE FINAL AUTORITATIVO                             */
/* ===================================================== */

.jas-approach-section {
  position: relative !important;
  overflow: hidden !important;
  background: #071a2b !important;
}

.jas-approach-bg,
.jas-approach-overlay,
.jas-approach-grid {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
}

/* fondo base */
.jas-approach-bg {
  z-index: 0 !important;
  opacity: 1 !important;
  background:
    radial-gradient(circle at 18% 24%, rgba(34, 184, 240, 0.18) 0%, transparent 18%),
    radial-gradient(circle at 82% 72%, rgba(88, 215, 255, 0.16) 0%, transparent 20%),
    radial-gradient(circle at 68% 32%, rgba(21, 107, 154, 0.14) 0%, transparent 24%),
    linear-gradient(135deg, #061522 0%, #0a2236 46%, #081a2b 100%) !important;
}

/* brillos y diagonales */
.jas-approach-overlay {
  z-index: 1 !important;
  opacity: 0.9 !important;
  background:
    radial-gradient(circle at 24% 28%, rgba(34, 184, 240, 0.14), transparent 16%),
    radial-gradient(circle at 76% 66%, rgba(88, 215, 255, 0.12), transparent 18%),
    linear-gradient(118deg, transparent 0 43%, rgba(88, 215, 255, 0.12) 49%, transparent 55%),
    linear-gradient(28deg, transparent 0 46%, rgba(34, 184, 240, 0.09) 50%, transparent 54%) !important;
}

/* red visible */
.jas-approach-grid {
  z-index: 2 !important;
  opacity: 1 !important;
  background:
    repeating-linear-gradient(
      to right,
      rgba(88, 215, 255, 0.08) 0,
      rgba(88, 215, 255, 0.08) 1px,
      transparent 1px,
      transparent 72px
    ),
    repeating-linear-gradient(
      to bottom,
      rgba(88, 215, 255, 0.06) 0,
      rgba(88, 215, 255, 0.06) 1px,
      transparent 1px,
      transparent 72px
    ),
    radial-gradient(circle at 12% 24%, rgba(88,215,255,0.65) 0 2px, transparent 3px),
    radial-gradient(circle at 22% 40%, rgba(88,215,255,0.55) 0 2px, transparent 3px),
    radial-gradient(circle at 34% 30%, rgba(88,215,255,0.55) 0 2px, transparent 3px),
    radial-gradient(circle at 46% 48%, rgba(88,215,255,0.55) 0 2px, transparent 3px),
    radial-gradient(circle at 58% 34%, rgba(88,215,255,0.55) 0 2px, transparent 3px),
    radial-gradient(circle at 70% 44%, rgba(88,215,255,0.55) 0 2px, transparent 3px),
    radial-gradient(circle at 82% 60%, rgba(88,215,255,0.6) 0 2px, transparent 3px),
    linear-gradient(122deg, transparent 0 18%, rgba(88,215,255,0.14) 18.4%, rgba(88,215,255,0.14) 18.8%, transparent 19.2%),
    linear-gradient(32deg, transparent 0 52%, rgba(88,215,255,0.12) 52.3%, rgba(88,215,255,0.12) 52.7%, transparent 53%) !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
}

/* asegura que el contenido quede encima */
.jas-approach-section .container {
  position: relative !important;
  z-index: 5 !important;
}

/* ===================================================== */
/* VALOR DIFERENCIAL - RED / ATMÓSFERA FINAL VISIBLE     */
/* BLOQUE FINAL AUTORITATIVO                             */
/* ===================================================== */

.jas-value-section {
  position: relative !important;
  overflow: hidden !important;
  background: #071726 !important;
}

.jas-value-bg,
.jas-value-overlay {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
}

/* fondo base con profundidad */
.jas-value-bg {
  z-index: 0 !important;
  opacity: 1 !important;
  background:
    radial-gradient(circle at 18% 24%, rgba(34, 184, 240, 0.14) 0%, transparent 18%),
    radial-gradient(circle at 82% 76%, rgba(21, 107, 154, 0.16) 0%, transparent 22%),
    radial-gradient(circle at 50% 42%, rgba(88, 215, 255, 0.07) 0%, transparent 28%),
    linear-gradient(180deg, #061522 0%, #0a1d2f 100%) !important;
}

/* red tecnológica sutil pero visible */
.jas-value-overlay {
  z-index: 1 !important;
  opacity: 1 !important;
  background:
    repeating-linear-gradient(
      to right,
      rgba(88, 215, 255, 0.06) 0,
      rgba(88, 215, 255, 0.06) 1px,
      transparent 1px,
      transparent 86px
    ),
    repeating-linear-gradient(
      to bottom,
      rgba(88, 215, 255, 0.045) 0,
      rgba(88, 215, 255, 0.045) 1px,
      transparent 1px,
      transparent 86px
    ),
    radial-gradient(circle at 20% 28%, rgba(88,215,255,0.45) 0 2px, transparent 3px),
    radial-gradient(circle at 34% 42%, rgba(88,215,255,0.35) 0 2px, transparent 3px),
    radial-gradient(circle at 50% 30%, rgba(88,215,255,0.30) 0 2px, transparent 3px),
    radial-gradient(circle at 66% 44%, rgba(88,215,255,0.35) 0 2px, transparent 3px),
    radial-gradient(circle at 80% 62%, rgba(88,215,255,0.42) 0 2px, transparent 3px),
    linear-gradient(135deg, transparent 0 23%, rgba(88,215,255,0.10) 23.4%, rgba(88,215,255,0.10) 23.8%, transparent 24.2%),
    linear-gradient(32deg, transparent 0 58%, rgba(88,215,255,0.08) 58.4%, rgba(88,215,255,0.08) 58.8%, transparent 59.2%) !important;
  -webkit-mask-image: radial-gradient(circle at center, rgba(0,0,0,0.95) 34%, rgba(0,0,0,0.42) 72%, transparent 100%) !important;
  mask-image: radial-gradient(circle at center, rgba(0,0,0,0.95) 34%, rgba(0,0,0,0.42) 72%, transparent 100%) !important;
}

/* halo central elegante */
.jas-value-section::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 42%;
  width: 760px;
  height: 760px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  background: radial-gradient(circle, rgba(34, 184, 240, 0.10) 0%, rgba(34, 184, 240, 0) 62%);
  filter: blur(22px);
}

/* contenido arriba */
.jas-value-section .container {
  position: relative !important;
  z-index: 5 !important;
}

/* ===================================================== */
/* VALOR DIFERENCIAL - VERSIÓN PREMIUM DIFERENTE         */
/* MENOS RED, MÁS HALOS + NODOS + SEÑALES                */
/* ===================================================== */

.jas-value-section {
  position: relative !important;
  overflow: hidden !important;
  background: #071625 !important;
}

.jas-value-bg,
.jas-value-overlay {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
}

/* Fondo base más premium y menos cuadriculado */
.jas-value-bg {
  z-index: 0 !important;
  opacity: 1 !important;
  background:
    radial-gradient(ellipse at 14% 72%, rgba(34, 184, 240, 0.10) 0%, transparent 26%),
    radial-gradient(ellipse at 38% 68%, rgba(88, 215, 255, 0.07) 0%, transparent 22%),
    radial-gradient(ellipse at 62% 68%, rgba(34, 184, 240, 0.07) 0%, transparent 22%),
    radial-gradient(ellipse at 86% 72%, rgba(21, 107, 154, 0.10) 0%, transparent 26%),
    radial-gradient(circle at 50% 18%, rgba(255, 255, 255, 0.04) 0%, transparent 22%),
    linear-gradient(180deg, #061420 0%, #091c2d 100%) !important;
}

/* Nodos dispersos + trazos suaves, sin cuadrícula */
.jas-value-overlay {
  z-index: 1 !important;
  opacity: 1 !important;
  background:
    radial-gradient(circle at 15% 58%, rgba(88,215,255,0.42) 0 2px, transparent 3px),
    radial-gradient(circle at 27% 46%, rgba(88,215,255,0.34) 0 2px, transparent 3px),
    radial-gradient(circle at 41% 62%, rgba(88,215,255,0.28) 0 2px, transparent 3px),
    radial-gradient(circle at 58% 46%, rgba(88,215,255,0.30) 0 2px, transparent 3px),
    radial-gradient(circle at 73% 60%, rgba(88,215,255,0.36) 0 2px, transparent 3px),
    radial-gradient(circle at 86% 50%, rgba(88,215,255,0.44) 0 2px, transparent 3px),

    linear-gradient(118deg, transparent 0 46%, rgba(88,215,255,0.09) 47%, rgba(88,215,255,0.09) 47.6%, transparent 48.2%),
    linear-gradient(68deg, transparent 0 58%, rgba(88,215,255,0.07) 58.5%, rgba(88,215,255,0.07) 59%, transparent 59.5%),
    linear-gradient(22deg, transparent 0 34%, rgba(88,215,255,0.06) 34.4%, rgba(88,215,255,0.06) 34.9%, transparent 35.4%) !important;

  -webkit-mask-image: none !important;
  mask-image: none !important;
}

/* Halo principal detrás del título */
.jas-value-section::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 26%;
  width: 680px;
  height: 320px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  background: radial-gradient(ellipse, rgba(34, 184, 240, 0.11) 0%, rgba(34, 184, 240, 0) 70%);
  filter: blur(22px);
}

/* Glow lateral suave para romper rigidez */
.jas-value-section::after {
  content: "";
  position: absolute;
  right: 8%;
  top: 56%;
  width: 380px;
  height: 380px;
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  background: radial-gradient(circle, rgba(88, 215, 255, 0.08) 0%, rgba(88, 215, 255, 0) 68%);
  filter: blur(24px);
}

/* Contenido por encima */
.jas-value-section .container {
  position: relative !important;
  z-index: 5 !important;
}

/* ===================================================== */
/* VALOR DIFERENCIAL - VERSIÓN MÁS LLENA Y PREMIUM       */
/* MENOS VACÍO, MÁS MASA VISUAL                          */
/* ===================================================== */

.jas-value-section {
  position: relative !important;
  overflow: hidden !important;
  background: #071625 !important;
}

.jas-value-bg,
.jas-value-overlay {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
}

.jas-value-bg {
  z-index: 0 !important;
  opacity: 1 !important;
  background:
    radial-gradient(ellipse at 18% 72%, rgba(34, 184, 240, 0.10) 0%, transparent 26%),
    radial-gradient(ellipse at 50% 74%, rgba(88, 215, 255, 0.08) 0%, transparent 28%),
    radial-gradient(ellipse at 82% 72%, rgba(21, 107, 154, 0.11) 0%, transparent 26%),
    radial-gradient(circle at 50% 20%, rgba(255, 255, 255, 0.035) 0%, transparent 20%),
    linear-gradient(180deg, #061420 0%, #091c2d 100%) !important;
}

/* nodos y detalles suaves, sin rayos dominantes */
.jas-value-overlay {
  z-index: 1 !important;
  opacity: 1 !important;
  background:
    radial-gradient(circle at 14% 58%, rgba(88,215,255,0.36) 0 2px, transparent 3px),
    radial-gradient(circle at 24% 48%, rgba(88,215,255,0.24) 0 2px, transparent 3px),
    radial-gradient(circle at 38% 64%, rgba(88,215,255,0.20) 0 2px, transparent 3px),
    radial-gradient(circle at 52% 46%, rgba(88,215,255,0.18) 0 2px, transparent 3px),
    radial-gradient(circle at 68% 60%, rgba(88,215,255,0.22) 0 2px, transparent 3px),
    radial-gradient(circle at 84% 50%, rgba(88,215,255,0.34) 0 2px, transparent 3px),

    linear-gradient(118deg, transparent 0 18%, rgba(88,215,255,0.05) 18.35%, rgba(88,215,255,0.05) 18.75%, transparent 19.15%),
    linear-gradient(28deg, transparent 0 82%, rgba(88,215,255,0.04) 82.35%, rgba(88,215,255,0.04) 82.7%, transparent 83.05%) !important;

  -webkit-mask-image: none !important;
  mask-image: none !important;
}

/* halo detrás del título */
.jas-value-section::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 23%;
  width: 760px;
  height: 300px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  background: radial-gradient(ellipse, rgba(34, 184, 240, 0.10) 0%, rgba(34, 184, 240, 0) 72%);
  filter: blur(24px);
}

/* aura horizontal detrás de TODAS las cards */
.jas-value-section::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 67%;
  width: 1180px;
  height: 360px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  background:
    radial-gradient(ellipse, rgba(34, 184, 240, 0.11) 0%, rgba(34, 184, 240, 0.05) 34%, rgba(34, 184, 240, 0) 72%);
  filter: blur(26px);
}

/* contenido arriba */
.jas-value-section .container {
  position: relative !important;
  z-index: 5 !important;
}

/* cards un poco más integradas con el fondo */
.jas-value-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0.035) 100%) !important;
  border: 1px solid rgba(88, 215, 255, 0.14) !important;
  box-shadow:
    0 22px 50px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255,255,255,0.05),
    0 0 0 1px rgba(34,184,240,0.02) !important;
}

.jas-value-card:hover {
  border-color: rgba(88, 215, 255, 0.24) !important;
  box-shadow:
    0 28px 60px rgba(0, 0, 0, 0.30),
    0 0 0 1px rgba(34,184,240,0.05),
    0 0 36px rgba(34,184,240,0.06) !important;
}

/* ===================================================== */
/* CTA FINAL - VERSIÓN PREMIUM SUAVE Y LUMINOSA          */
/* BLOQUE FINAL AUTORITATIVO                             */
/* ===================================================== */

.jas-final-cta-section {
  position: relative !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 18% 24%, rgba(34, 184, 240, 0.06), transparent 24%),
    radial-gradient(circle at 82% 76%, rgba(21, 107, 154, 0.06), transparent 28%),
    linear-gradient(180deg, #EEF5F9 0%, #E5EFF5 100%) !important;
}

.jas-final-cta-bg,
.jas-final-cta-overlay {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
}

/* base luminosa */
.jas-final-cta-bg {
  z-index: 0 !important;
  display: block !important;
  opacity: 1 !important;
  background:
    radial-gradient(ellipse at 50% 8%, rgba(255, 255, 255, 0.34) 0%, transparent 30%),
    radial-gradient(ellipse at 50% 72%, rgba(34, 184, 240, 0.07) 0%, transparent 34%),
    radial-gradient(circle at 20% 34%, rgba(34, 184, 240, 0.05) 0%, transparent 18%),
    radial-gradient(circle at 80% 68%, rgba(21, 107, 154, 0.05) 0%, transparent 20%) !important;
}

/* nodos mínimos y señales muy sutiles */
.jas-final-cta-overlay {
  z-index: 1 !important;
  display: block !important;
  opacity: 1 !important;
  background:
    radial-gradient(circle at 26% 40%, rgba(88,215,255,0.22) 0 2px, transparent 3px),
    radial-gradient(circle at 44% 30%, rgba(88,215,255,0.18) 0 2px, transparent 3px),
    radial-gradient(circle at 62% 44%, rgba(88,215,255,0.18) 0 2px, transparent 3px),
    radial-gradient(circle at 76% 58%, rgba(88,215,255,0.22) 0 2px, transparent 3px),
    linear-gradient(118deg, transparent 0 46%, rgba(88,215,255,0.045) 46.4%, rgba(88,215,255,0.045) 46.8%, transparent 47.2%),
    linear-gradient(28deg, transparent 0 74%, rgba(88,215,255,0.035) 74.4%, rgba(88,215,255,0.035) 74.8%, transparent 75.2%) !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
}

/* halo detrás del título */
.jas-final-cta-section::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 24%;
  width: 760px;
  height: 260px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  background: radial-gradient(ellipse, rgba(34, 184, 240, 0.09) 0%, rgba(34, 184, 240, 0) 72%);
  filter: blur(24px);
}

/* aura horizontal detrás de botones y meta */
.jas-final-cta-section::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 66%;
  width: 960px;
  height: 240px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  background: radial-gradient(ellipse, rgba(88, 215, 255, 0.08) 0%, rgba(88, 215, 255, 0.03) 36%, rgba(88, 215, 255, 0) 72%);
  filter: blur(26px);
}

/* contenido arriba */
.jas-final-cta-section .container {
  position: relative !important;
  z-index: 5 !important;
}

/* refuerzo visual del bloque interno */
.jas-final-cta-inner {
  position: relative;
  max-width: 940px;
  margin: 0 auto;
}

/* botones un poco más premium */
.jas-final-cta-btn-primary {
  background: linear-gradient(145deg, #0F3554 0%, #156B9A 58%, #22B8F0 100%) !important;
  box-shadow: 0 18px 38px rgba(21, 107, 154, 0.22) !important;
}

.jas-final-cta-btn-primary:hover {
  box-shadow: 0 22px 42px rgba(21, 107, 154, 0.28) !important;
  transform: translateY(-3px);
}

.jas-final-cta-btn-secondary {
  background: rgba(255, 255, 255, 0.88) !important;
  border: 1px solid rgba(21, 107, 154, 0.14) !important;
  box-shadow:
    0 12px 24px rgba(15, 53, 84, 0.05),
    inset 0 1px 0 rgba(255,255,255,0.82) !important;
}

.jas-final-cta-btn-secondary:hover {
  background: rgba(255, 255, 255, 0.96) !important;
  border-color: rgba(34, 184, 240, 0.22) !important;
  transform: translateY(-3px);
}

/* ===================================================== */
/* CTA FINAL - UPGRADE 9/10                              */
/* PANEL PREMIUM CENTRAL                                 */
/* ===================================================== */

.jas-final-cta-section {
  position: relative !important;
  overflow: hidden !important;
  padding: 110px 0 95px !important;
  background:
    radial-gradient(circle at 18% 24%, rgba(34, 184, 240, 0.05), transparent 24%),
    radial-gradient(circle at 82% 76%, rgba(21, 107, 154, 0.05), transparent 28%),
    linear-gradient(180deg, #EEF5F9 0%, #E4EEF4 100%) !important;
}

/* fondo suave atmosférico */
.jas-final-cta-bg,
.jas-final-cta-overlay {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
}

.jas-final-cta-bg {
  display: block !important;
  z-index: 0 !important;
  opacity: 1 !important;
  background:
    radial-gradient(ellipse at 50% 10%, rgba(255, 255, 255, 0.34) 0%, transparent 30%),
    radial-gradient(ellipse at 50% 72%, rgba(34, 184, 240, 0.06) 0%, transparent 34%) !important;
}

.jas-final-cta-overlay {
  display: block !important;
  z-index: 1 !important;
  opacity: 1 !important;
  background:
    radial-gradient(circle at 28% 40%, rgba(88,215,255,0.16) 0 2px, transparent 3px),
    radial-gradient(circle at 46% 30%, rgba(88,215,255,0.14) 0 2px, transparent 3px),
    radial-gradient(circle at 64% 44%, rgba(88,215,255,0.14) 0 2px, transparent 3px),
    radial-gradient(circle at 76% 58%, rgba(88,215,255,0.16) 0 2px, transparent 3px) !important;
}

/* halo general */
.jas-final-cta-section::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 26%;
  width: 760px;
  height: 260px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  background: radial-gradient(ellipse, rgba(34, 184, 240, 0.08) 0%, rgba(34, 184, 240, 0) 72%);
  filter: blur(26px);
}

/* contenido arriba */
.jas-final-cta-section .container {
  position: relative !important;
  z-index: 5 !important;
}

/* =============================== */
/* PANEL CENTRAL PREMIUM           */
/* =============================== */

.jas-final-cta-inner {
  position: relative;
  max-width: 1080px !important;
  margin: 0 auto;
  padding: 58px 54px 42px !important;
  border-radius: 34px;
  text-align: center;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.84) 0%, rgba(255,255,255,0.70) 100%) !important;
  border: 1px solid rgba(21, 107, 154, 0.12);
  box-shadow:
    0 28px 70px rgba(15, 53, 84, 0.12),
    0 10px 24px rgba(15, 53, 84, 0.05),
    inset 0 1px 0 rgba(255,255,255,0.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  overflow: hidden;
}

.jas-final-cta-inner::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,0.48) 0%, transparent 34%),
    radial-gradient(circle at 18% 78%, rgba(34,184,240,0.06) 0%, transparent 24%),
    radial-gradient(circle at 82% 24%, rgba(21,107,154,0.05) 0%, transparent 20%);
}

.jas-final-cta-inner::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -48px;
  width: 78%;
  height: 120px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: radial-gradient(ellipse, rgba(34,184,240,0.10) 0%, rgba(34,184,240,0) 72%);
  filter: blur(20px);
  pointer-events: none;
}

/* =============================== */
/* COPY                            */
/* =============================== */

.jas-final-cta-label,
.jas-final-cta-title,
.jas-final-cta-text,
.jas-final-cta-buttons,
.jas-final-cta-meta {
  position: relative;
  z-index: 2;
}

.jas-final-cta-label {
  margin-bottom: 18px !important;
}

.jas-final-cta-title {
  max-width: 820px !important;
  margin: 0 auto 18px !important;
  font-size: clamp(2.15rem, 3.2vw, 3.45rem) !important;
  line-height: 1.04 !important;
  letter-spacing: -0.04em !important;
  color: #0F3554 !important;
}

.jas-final-cta-text {
  max-width: 760px !important;
  margin: 0 auto 30px !important;
  font-size: 1.03rem !important;
  line-height: 1.8 !important;
  color: #52697C !important;
}

/* =============================== */
/* BOTONES                         */
/* =============================== */

.jas-final-cta-buttons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 26px !important;
}

.jas-final-cta-btn-primary,
.jas-final-cta-btn-secondary {
  min-width: 240px !important;
  min-height: 58px !important;
  padding: 0 30px !important;
  border-radius: 16px !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease,
    background 0.3s ease,
    border-color 0.3s ease !important;
}

.jas-final-cta-btn-primary {
  background: linear-gradient(145deg, #0F3554 0%, #156B9A 58%, #22B8F0 100%) !important;
  color: #FFFFFF !important;
  box-shadow: 0 18px 38px rgba(21, 107, 154, 0.24) !important;
}

.jas-final-cta-btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 22px 42px rgba(21, 107, 154, 0.30) !important;
}

.jas-final-cta-btn-secondary {
  background: rgba(255,255,255,0.82) !important;
  color: #17324D !important;
  border: 1px solid rgba(21, 107, 154, 0.14) !important;
  box-shadow:
    0 12px 24px rgba(15, 53, 84, 0.05),
    inset 0 1px 0 rgba(255,255,255,0.82) !important;
}

.jas-final-cta-btn-secondary:hover {
  transform: translateY(-3px);
  background: rgba(255,255,255,0.96) !important;
  border-color: rgba(34, 184, 240, 0.22) !important;
}

/* =============================== */
/* META                            */
/* =============================== */

.jas-final-cta-meta {
  gap: 16px 26px !important;
  font-size: 0.94rem !important;
  color: #607688 !important;
}

/* =============================== */
/* TRANSICIÓN AL FOOTER            */
/* =============================== */

.jas-footer {
  margin-top: -18px;
  padding-top: 92px !important;
}

/* =============================== */
/* RESPONSIVE                      */
/* =============================== */

@media (max-width: 991.98px) {
  .jas-final-cta-section {
    padding: 92px 0 82px !important;
  }

  .jas-final-cta-inner {
    padding: 46px 28px 34px !important;
    border-radius: 28px;
  }

  .jas-final-cta-title {
    font-size: clamp(2rem, 5vw, 2.8rem) !important;
  }
}

@media (max-width: 767.98px) {
  .jas-final-cta-inner {
    padding: 38px 20px 28px !important;
    border-radius: 24px;
  }

  .jas-final-cta-buttons {
    gap: 12px;
  }

  .jas-final-cta-btn-primary,
  .jas-final-cta-btn-secondary {
    width: 100% !important;
    min-width: 0 !important;
  }

  .jas-footer {
    margin-top: -12px;
    padding-top: 78px !important;
  }
}

/* ===================================================== */
/* CTA FINAL - VERSIÓN INTEGRADA, SIN CARD FLOTANTE      */
/* ===================================================== */

.jas-final-cta-section {
  position: relative !important;
  overflow: hidden !important;
  padding: 80px 0 80px !important;
  background:
    radial-gradient(circle at 18% 24%, rgba(34, 184, 240, 0.06), transparent 24%),
    radial-gradient(circle at 82% 76%, rgba(21, 107, 154, 0.06), transparent 28%),
    linear-gradient(180deg, #EEF5F9 0%, #E4EEF4 100%) !important;
}

.jas-final-cta-bg,
.jas-final-cta-overlay {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
}

.jas-final-cta-bg {
  display: block !important;
  z-index: 0 !important;
  opacity: 1 !important;
  background:
    radial-gradient(ellipse at 50% 10%, rgba(255,255,255,0.30) 0%, transparent 30%),
    radial-gradient(ellipse at 50% 74%, rgba(34,184,240,0.08) 0%, transparent 34%),
    radial-gradient(circle at 20% 38%, rgba(34,184,240,0.05) 0%, transparent 18%),
    radial-gradient(circle at 80% 64%, rgba(21,107,154,0.05) 0%, transparent 20%) !important;
}

.jas-final-cta-overlay {
  display: block !important;
  z-index: 1 !important;
  opacity: 1 !important;
  background:
    radial-gradient(circle at 28% 40%, rgba(88,215,255,0.16) 0 2px, transparent 3px),
    radial-gradient(circle at 46% 30%, rgba(88,215,255,0.12) 0 2px, transparent 3px),
    radial-gradient(circle at 64% 44%, rgba(88,215,255,0.12) 0 2px, transparent 3px),
    radial-gradient(circle at 76% 58%, rgba(88,215,255,0.16) 0 2px, transparent 3px) !important;
}

/* halo superior suave */
.jas-final-cta-section::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 24%;
  width: 760px;
  height: 240px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  background: radial-gradient(ellipse, rgba(34,184,240,0.08) 0%, rgba(34,184,240,0) 72%);
  filter: blur(24px);
}

/* base luminosa horizontal, integrada */
.jas-final-cta-section::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 66%;
  width: 1080px;
  height: 260px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 2;
  background: radial-gradient(ellipse, rgba(88,215,255,0.10) 0%, rgba(88,215,255,0.04) 36%, rgba(88,215,255,0) 72%);
  filter: blur(26px);
}

.jas-final-cta-section .container {
  position: relative !important;
  z-index: 5 !important;
}

/* quitamos el look de card */
.jas-final-cta-inner {
  position: relative;
  max-width: 980px !important;
  margin: 0 auto;
  padding: 0 12px !important;
  text-align: center;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-radius: 0 !important;
}

.jas-final-cta-inner::before,
.jas-final-cta-inner::after {
  content: none !important;
}

.jas-final-cta-label,
.jas-final-cta-title,
.jas-final-cta-text,
.jas-final-cta-buttons,
.jas-final-cta-meta {
  position: relative;
  z-index: 3;
}

.jas-final-cta-title {
  max-width: 820px !important;
  margin: 0 auto 18px !important;
  font-size: clamp(2.15rem, 3.2vw, 3.35rem) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.04em !important;
}

.jas-final-cta-text {
  max-width: 760px !important;
  margin: 0 auto 30px !important;
  font-size: 1.02rem !important;
  line-height: 1.8 !important;
}

.jas-final-cta-buttons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 26px !important;
}

.jas-final-cta-btn-primary,
.jas-final-cta-btn-secondary {
  min-width: 240px !important;
  min-height: 58px !important;
  padding: 0 30px !important;
  border-radius: 16px !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
}

.jas-final-cta-btn-primary {
  background: linear-gradient(145deg, #0F3554 0%, #156B9A 58%, #22B8F0 100%) !important;
  color: #FFFFFF !important;
  box-shadow: 0 18px 38px rgba(21, 107, 154, 0.22) !important;
}

.jas-final-cta-btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 22px 42px rgba(21, 107, 154, 0.28) !important;
}

.jas-final-cta-btn-secondary {
  background: rgba(255,255,255,0.88) !important;
  color: #17324D !important;
  border: 1px solid rgba(21, 107, 154, 0.14) !important;
  box-shadow:
    0 12px 24px rgba(15, 53, 84, 0.05),
    inset 0 1px 0 rgba(255,255,255,0.82) !important;
}

.jas-final-cta-btn-secondary:hover {
  transform: translateY(-3px);
  background: rgba(255,255,255,0.96) !important;
  border-color: rgba(34,184,240,0.22) !important;
}

/* mejor unión con footer */
.jas-footer {
  margin-top: 0 !important;
  padding-top: 84px !important;
}

@media (max-width: 991.98px) {
  .jas-final-cta-section {
    padding: 92px 0 78px !important;
  }

  .jas-final-cta-title {
    font-size: clamp(2rem, 5vw, 2.8rem) !important;
  }
}

@media (max-width: 767.98px) {
  .jas-final-cta-inner {
    padding: 0 !important;
  }

  .jas-final-cta-buttons {
    gap: 12px;
  }

  .jas-final-cta-btn-primary,
  .jas-final-cta-btn-secondary {
    width: 100% !important;
    min-width: 0 !important;
  }

  .jas-final-cta-section::after {
    width: 760px;
    height: 220px;
  }
}

/* ===================================== */
/* CTA FINAL - CENTRADO REAL DE BOTONES  */
/* ===================================== */

.jas-final-cta-btn-primary,
.jas-final-cta-btn-secondary {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  vertical-align: middle;
  line-height: 1 !important;
  text-align: center !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.jas-final-cta-btn-primary span,
.jas-final-cta-btn-secondary span,
.jas-final-cta-btn-primary i,
.jas-final-cta-btn-secondary i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1 !important;
}

/* ===================================================== */
/* TICKER PREMIUM - JAS SOLUTIONS                        */
/* ===================================================== */

.jas-ticker-section {
  position: relative;
  z-index: 10;
  margin-top: -10px;
  background: linear-gradient(180deg, rgba(255,255,255,0.0) 0%, rgba(255,255,255,0.0) 100%);
}

.jas-ticker-wrap {
  position: relative;
  overflow: hidden;
  padding: 16px 0;
  border-top: 1px solid rgba(21, 107, 154, 0.10);
  border-bottom: 1px solid rgba(123, 220, 255, 0.10);
  background:
    linear-gradient(90deg, rgba(7, 23, 38, 0.98) 0%, rgba(10, 39, 64, 0.98) 50%, rgba(7, 23, 38, 0.98) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 10px 28px rgba(10, 39, 64, 0.12);
}

.jas-ticker-wrap::before,
.jas-ticker-wrap::after {
  content: "";
  position: absolute;
  top: 0;
  width: 120px;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}

.jas-ticker-wrap::before {
  left: 0;
  background: linear-gradient(90deg, rgba(7, 23, 38, 1) 0%, rgba(7, 23, 38, 0) 100%);
}

.jas-ticker-wrap::after {
  right: 0;
  background: linear-gradient(270deg, rgba(7, 23, 38, 1) 0%, rgba(7, 23, 38, 0) 100%);
}

.jas-ticker-track {
  display: flex;
  align-items: center;
  width: max-content;
  gap: 0;
  animation: jasTickerMove 34s linear infinite;
  will-change: transform;
}

.jas-ticker-track span {
  position: relative;
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  padding: 0 34px;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: rgba(234, 244, 248, 0.92);
  white-space: nowrap;
}

.jas-ticker-track span::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  transform: translateY(-50%);
  background: linear-gradient(145deg, #22B8F0 0%, #156B9A 100%);
  box-shadow: 0 0 0 6px rgba(34, 184, 240, 0.08);
}

.jas-ticker-track span:hover {
  color: #7BDCFF;
}

.jas-ticker-wrap:hover .jas-ticker-track {
  animation-play-state: paused;
}

@keyframes jasTickerMove {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

/* Responsive */
@media (max-width: 991.98px) {
  .jas-ticker-wrap {
    padding: 14px 0;
  }

  .jas-ticker-track span {
    padding: 0 26px;
    font-size: 0.88rem;
  }
}

@media (max-width: 767.98px) {
  .jas-ticker-wrap::before,
  .jas-ticker-wrap::after {
    width: 48px;
  }

  .jas-ticker-track {
    animation-duration: 26s;
  }

  .jas-ticker-track span {
    padding: 0 20px;
    font-size: 0.82rem;
  }

  .jas-ticker-track span::after {
    width: 6px;
    height: 6px;
  }
}

/* ===================================================== */
/* HERO MÁS CORTO PARA QUE ASOME EL TICKER               */
/* ===================================================== */

@media (min-width: 1200px) {
  .hero-section {
    padding-top: 164px !important;
    padding-bottom: 34px !important;
  }

  .hero-layout {
    min-height: 520px !important;
    gap: 24px !important;
  }

  .hero-content {
    max-width: 560px !important;
  }

  .hero-title {
    font-size: clamp(2.7rem, 3.9vw, 4.15rem) !important;
    margin-bottom: 18px !important;
  }

  .hero-description {
    max-width: 500px !important;
    margin-bottom: 22px !important;
  }

  .hero-buttons {
    margin-top: 0 !important;
  }

  .hero-visual-frame {
    height: 470px !important;
    max-width: 900px !important;
  }

  .hero-artwork {
    width: 760px !important;
    transform: translate(18px, 18px) scale(1.03) !important;
  }

  /* para que la franja ya asome en el primer pantallazo */
  .jas-ticker-section {
    margin-top: 0 !important;
  }

  .jas-ticker-wrap {
    padding: 14px 0 !important;
  }
}

/* ===================================================== */
/* HERO - NUBE QUIETA + CUBO QUE SE MUEVE EN HOVER       */
/* ===================================================== */

.hero-visual {
  position: relative;
  isolation: isolate;
}

.hero-cube-scene {
  position: relative;
  overflow: visible;
}

/* base completa quieta */
.hero-artwork-base {
  position: relative;
  z-index: 1;
  display: block;
  width: 720px !important;
  max-width: none;
  height: auto;
  transform: translate(18px, 18px) scale(1.04) !important;
  transform-origin: center center;
  filter: drop-shadow(0 18px 34px rgba(21, 107, 154, 0.14));
}

/* capa recortada: SOLO el cubo */
.hero-cube-hover {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background-image: url("assets/images/hero/hero-jas-visual.png");
  background-repeat: no-repeat;
  background-size: 720px auto;
  background-position: calc(50% + 18px) calc(50% + 18px);

  /* recorte aproximado de la zona del cubo */
  clip-path: polygon(
    46% 18%,
    67% 29%,
    71% 54%,
    52% 73%,
    31% 60%,
    28% 34%
  );

  transform: translate(0, 0) scale(1);
  transform-origin: center center;
  opacity: 1;
  transition:
    transform 0.45s ease,
    filter 0.45s ease;
  filter: drop-shadow(0 16px 26px rgba(21, 107, 154, 0.16));
}

/* aura muy suave detrás del cubo */
.hero-cube-scene::before {
  content: "";
  position: absolute;
  left: 53%;
  top: 52%;
  width: 240px;
  height: 240px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(34, 184, 240, 0.14) 0%, rgba(34, 184, 240, 0.04) 44%, rgba(34, 184, 240, 0) 72%);
  filter: blur(22px);
  z-index: 2;
  pointer-events: none;
  opacity: 0.72;
  transition:
    transform 0.45s ease,
    opacity 0.45s ease,
    filter 0.45s ease;
}

/* hover: solo reacciona el cubo */
.hero-cube-scene:hover .hero-cube-hover {
  transform: translate(-8px, -10px) rotate(-3deg) scale(1.04);
  filter: drop-shadow(0 28px 42px rgba(21, 107, 154, 0.24));
}

.hero-cube-scene:hover::before {
  transform: translate(-50%, -50%) scale(1.08);
  opacity: 1;
  filter: blur(26px);
}

/* opcional: un micro empuje general casi imperceptible */
.hero-cube-scene:hover .hero-artwork-base {
  filter: drop-shadow(0 20px 36px rgba(21, 107, 154, 0.16));
}

/* tablet */
@media (max-width: 991.98px) {
  .hero-artwork-base {
    width: 620px !important;
    transform: translate(0, 0) scale(1.02) !important;
  }

  .hero-cube-hover {
    background-size: 620px auto;
    background-position: center center;
  }

  .hero-cube-scene::before {
    width: 190px;
    height: 190px;
  }

  .hero-cube-scene:hover .hero-cube-hover {
    transform: translate(-5px, -6px) rotate(-2deg) scale(1.03);
  }
}

/* móvil: mejor sin efecto fuerte */
@media (max-width: 767.98px) {
  .hero-cube-hover {
    display: none;
  }

  .hero-cube-scene::before {
    display: none;
  }
}

/* ===================================================== */
/* HERO - NUBE QUIETA + CUBO QUE REACCIONA EN HOVER      */
/* ===================================================== */

.hero-visual {
  position: relative;
  isolation: isolate;
}

.hero-cube-scene {
  position: relative;
  overflow: visible;
}

/* imagen base completa, quieta */
.hero-artwork-base {
  position: relative;
  z-index: 1;
}

/* capa superior recortada solo al cubo */
.hero-cube-hover {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background-image: url("assets/images/hero/hero-jas-visual.png");
  background-repeat: no-repeat;
  background-size: 720px auto;
  background-position: calc(50% + 18px) calc(50% + 18px);

  /* recorte aproximado del cubo */
  clip-path: polygon(
    46% 18%,
    67% 29%,
    71% 54%,
    52% 73%,
    31% 60%,
    28% 34%
  );

  transform: translate(0, 0) rotate(0deg) scale(1);
  transform-origin: center center;
  transition:
    transform 0.45s ease,
    filter 0.45s ease;
  filter: drop-shadow(0 16px 26px rgba(21, 107, 154, 0.16));
}

/* glow suave detrás del cubo */
.hero-cube-scene::before {
  content: "";
  position: absolute;
  left: 53%;
  top: 52%;
  width: 240px;
  height: 240px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(34, 184, 240, 0.14) 0%, rgba(34, 184, 240, 0.04) 44%, rgba(34, 184, 240, 0) 72%);
  filter: blur(22px);
  z-index: 2;
  pointer-events: none;
  opacity: 0.72;
  transition:
    transform 0.45s ease,
    opacity 0.45s ease,
    filter 0.45s ease;
}

/* SOLO el cubo reacciona */
.hero-cube-scene:hover .hero-cube-hover {
  transform: translate(-8px, -10px) rotate(-3deg) scale(1.04);
  filter: drop-shadow(0 28px 42px rgba(21, 107, 154, 0.24));
}

.hero-cube-scene:hover::before {
  transform: translate(-50%, -50%) scale(1.08);
  opacity: 1;
  filter: blur(26px);
}

@media (max-width: 991.98px) {
  .hero-cube-hover {
    background-size: 620px auto;
    background-position: center center;
  }

  .hero-cube-scene::before {
    width: 190px;
    height: 190px;
  }

  .hero-cube-scene:hover .hero-cube-hover {
    transform: translate(-5px, -6px) rotate(-2deg) scale(1.03);
  }
}

@media (max-width: 767.98px) {
  .hero-cube-hover,
  .hero-cube-scene::before {
    display: none;
  }
}

/* ===================================================== */
/* HERO POR CAPAS - VERSIÓN CORREGIDA                    */
/* ===================================================== */

.hero-scene {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: visible;
}

/* NUBE / BASE */
.hero-cloud-layer {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 760px;
  max-width: none;
  transform: translate(-50%, -50%);
  z-index: 1;
  pointer-events: none;
  user-select: none;
  -webkit-user-drag: none;
  filter: drop-shadow(0 10px 20px rgba(21, 107, 154, 0.06));
}

/* CUBO RECORTADO */
.hero-cube-layer {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 258px;
  max-width: none;
  transform: translate(-50%, -50%);
  z-index: 3;
  user-select: none;
  -webkit-user-drag: none;
  transition:
    transform 0.35s ease,
    filter 0.35s ease;
  filter: drop-shadow(0 18px 28px rgba(15, 53, 84, 0.18));
  cursor: pointer;
}

/* Glow detrás del cubo */
.hero-scene::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 240px;
  height: 240px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(34, 184, 240, 0.16) 0%,
    rgba(34, 184, 240, 0.05) 42%,
    rgba(34, 184, 240, 0) 72%
  );
  filter: blur(18px);
  z-index: 2;
  pointer-events: none;
  transition:
    transform 0.35s ease,
    opacity 0.35s ease,
    filter 0.35s ease;
  opacity: 0.8;
}

/* Hover solo sobre el cubo */
.hero-scene:hover .hero-cube-layer {
  transform: translate(-50%, -56%) rotate(-4deg) scale(1.06);
  filter: drop-shadow(0 26px 40px rgba(15, 53, 84, 0.24));
}

.hero-scene:hover::before {
  transform: translate(-50%, -50%) scale(1.08);
  opacity: 1;
  filter: blur(22px);
}

/* =============================== */
/* RESPONSIVE                      */
/* =============================== */

@media (max-width: 1199.98px) {
  .hero-cloud-layer {
    width: 680px;
  }

  .hero-cube-layer {
    width: 232px;
  }
}

@media (max-width: 991.98px) {
  .hero-cloud-layer {
    width: 600px;
  }

  .hero-cube-layer {
    width: 210px;
  }

  .hero-scene::before {
    width: 200px;
    height: 200px;
  }
}

@media (max-width: 767.98px) {
  .hero-cloud-layer {
    width: 100%;
    max-width: 500px;
  }

  .hero-cube-layer {
    width: 172px;
  }

  .hero-scene::before {
    width: 170px;
    height: 170px;
  }

  .hero-scene:hover .hero-cube-layer {
    transform: translate(-50%, -53%) rotate(-2deg) scale(1.03);
  }
}

.jas-footer-column {
  min-width: 160px;
}

.jas-footer-brand {
  max-width: 360px;
}

.jas-footer-title {
  margin-bottom: 20px;
}

.jas-footer-links li,
.jas-footer-contact li {
  margin-bottom: 14px;
}

/* ========================================= */
/* FOOTER BRAND - LOGO Y TEXTO EN FILA       */
/* ========================================= */

.jas-footer-brand {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  max-width: 420px;
}

.jas-footer-logo {
  width: 108px;
  height: auto;
  object-fit: contain;
  margin-bottom: 0;
  flex-shrink: 0;
}

.jas-footer-description {
  margin: 0;
  padding-top: 6px;
  font-size: 0.96rem;
  line-height: 1.75;
  color: rgba(219, 233, 242, 0.78);
}

/* móvil */
@media (max-width: 767.98px) {
  .jas-footer-brand {
    display: block;
    max-width: 100%;
  }

  .jas-footer-logo {
    width: 170px;
    margin-bottom: 14px;
  }

  .jas-footer-description {
    padding-top: 0;
  }
}

/* ========================================= */
/* FOOTER PREMIUM - MENOS FRÍO, MÁS CERRADO  */
/* ========================================= */

/* ========================================= */
/* FOOTER JAS SOLUTIONS - VERSIÓN PREMIUM    */
/* ========================================= */

.jas-footer {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 24%, rgba(34, 184, 240, 0.10), transparent 24%),
    radial-gradient(circle at 82% 76%, rgba(21, 107, 154, 0.10), transparent 28%),
    linear-gradient(180deg, #071726 0%, #09213A 100%);
  color: #EAF4F8;
  padding: 64px 0 24px;
}

.jas-footer::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 86%;
  height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(
    90deg,
    rgba(123, 220, 255, 0) 0%,
    rgba(123, 220, 255, 0.18) 20%,
    rgba(123, 220, 255, 0.30) 50%,
    rgba(123, 220, 255, 0.18) 80%,
    rgba(123, 220, 255, 0) 100%
  );
}

.jas-footer::after {
  content: "";
  position: absolute;
  left: 14%;
  top: 18%;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(34, 184, 240, 0.08) 0%, rgba(34, 184, 240, 0) 72%);
  filter: blur(30px);
  pointer-events: none;
}

.jas-footer .container {
  position: relative;
  z-index: 2;
}

.jas-footer-grid {
  display: grid;
  grid-template-columns: minmax(320px, 1.15fr) minmax(120px, max-content) minmax(140px, max-content) minmax(260px, 320px);
  column-gap: 48px;
  row-gap: 24px;
  align-items: start;
  justify-content: space-between;
  padding-bottom: 32px;
  border-bottom: 1px solid rgba(123, 220, 255, 0.10);
}

/* Marca */
.jas-footer-brand {
  display: flex;
  align-items: flex-start;
  gap: 22px;
  max-width: 470px;
  padding-right: 18px;
}

/*.jas-footer-logo {
  width: 112px;
  height: auto;
  object-fit: contain;
  flex-shrink: 0;
  margin-bottom: 0;
  filter: drop-shadow(0 12px 24px rgba(0, 0, 0, 0.16));
}*/

.jas-footer-description {
  margin: 0;
  padding-top: 6px;
  max-width: 320px;
  font-size: 1rem;
  line-height: 1.7;
  color: rgba(219, 233, 242, 0.82);
}

/* Columnas */
.jas-footer-column {
  min-width: 0;
}

.jas-footer-title {
  position: relative;
  margin: 0 0 20px;
  padding-bottom: 10px;
  font-size: 1rem;
  font-weight: 800;
  color: #FFFFFF;
  letter-spacing: -0.01em;
}

.jas-footer-title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 26px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #22B8F0 0%, #58D7FF 100%);
  opacity: 0.9;
}

.jas-footer-links,
.jas-footer-contact {
  list-style: none;
  margin: 0;
  padding: 0;
}

.jas-footer-links li,
.jas-footer-contact li {
  margin-bottom: 14px;
}

.jas-footer-links a {
  color: rgba(219, 233, 242, 0.82);
  text-decoration: none;
  transition: color 0.28s ease, transform 0.28s ease;
}

.jas-footer-links a:hover {
  color: #7BDCFF;
  transform: translateX(3px);
}

.jas-footer-contact {
  padding-left: 18px;
  border-left: 1px solid rgba(123, 220, 255, 0.12);
}

.jas-footer-contact li {
  color: rgba(219, 233, 242, 0.82);
  line-height: 1.65;
}

.jas-footer-contact strong {
  color: #FFFFFF;
  font-weight: 700;
}

/* Pie */
.jas-footer-bottom {
  padding-top: 20px;
  text-align: center;
}

.jas-footer-bottom p {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(219, 233, 242, 0.66);
}

/* Responsive */
@media (max-width: 1199.98px) {
  .jas-footer-grid {
    grid-template-columns: minmax(280px, 1fr) repeat(3, max-content);
    column-gap: 36px;
  }

  .jas-footer-brand {
    max-width: 400px;
  }

  .jas-footer-description {
    max-width: 280px;
  }
}

@media (max-width: 991.98px) {
  .jas-footer {
    padding: 56px 0 22px;
  }

  .jas-footer-grid {
    grid-template-columns: 1fr 1fr;
    column-gap: 28px;
    row-gap: 28px;
  }

  .jas-footer-brand {
    grid-column: 1 / -1;
    max-width: 100%;
    padding-right: 0;
  }

  .jas-footer-description {
    max-width: 100%;
  }

  .jas-footer-contact {
    padding-left: 0;
    border-left: 0;
  }
}

@media (max-width: 768.98px) {
  .jas-footer-grid {
    grid-template-columns: 1fr;
    row-gap: 24px;
    padding-bottom: 24px;
  }

  .jas-footer-brand {
    display: block;
  }

  .jas-footer-logo {
    width: 90px;
    margin-bottom: 14px;
  }

  .jas-footer-description {
    padding-top: 0;
    font-size: 0.94rem;
  }

  .jas-footer-title {
    margin-bottom: 16px;
  }

  .jas-footer-bottom p {
    font-size: 0.85rem;
  }
}
/* ===================================================== */
/* FIX MÓVIL - TICKER                                    */
/* ===================================================== */

@media (max-width: 767.98px) {
  .jas-ticker-section {
    margin-top: 4px !important;
  }

  .jas-ticker-wrap {
    padding: 10px 0 !important;
  }

  .jas-ticker-track {
    animation-duration: 22s !important;
  }

  .jas-ticker-track span {
    font-size: 0.8rem !important;
    padding: 0 16px !important;
  }

  .jas-ticker-track span::after {
    width: 5px !important;
    height: 5px !important;
  }
}

/* ===================================================== */
/* FIX MÓVIL - NUESTRO ENFOQUE                           */
/* ===================================================== */

@media (max-width: 767.98px) {
  .jas-approach-section {
    padding: 70px 0 !important;
  }

  .jas-approach-header {
    margin-bottom: 28px !important;
  }

  .jas-approach-header .jas-approach-title {
    font-size: 1.9rem !important;
    line-height: 1.12 !important;
  }

  .jas-approach-inner {
    gap: 28px !important;
  }

  .jas-visual-shell {
    width: 100% !important;
    max-width: 360px !important;
    height: 340px !important;
    margin: 0 auto;
    border-radius: 24px !important;
  }

  .jas-visual-shell::before {
    inset: 16px !important;
    border-radius: 18px !important;
  }

  .jas-visual-core {
    width: 180px !important;
    height: 180px !important;
  }

  .jas-core-logo-wrap {
    width: 120px !important;
    height: 120px !important;
  }

  .jas-core-logo {
    width: 72px !important;
  }

  .jas-node-top {
    top: 34px !important;
  }

  .jas-node-left {
    left: 12px !important;
    bottom: 56px !important;
  }

  .jas-node-right {
    right: 12px !important;
    bottom: 56px !important;
  }

  .jas-visual-node {
    min-width: 92px !important;
    padding: 9px 12px !important;
    font-size: 0.78rem !important;
    border-radius: 12px !important;
  }

  .jas-line-a {
    height: 64px !important;
    top: 92px !important;
  }

  .jas-line-b,
  .jas-line-c {
    width: 62px !important;
    bottom: 102px !important;
  }
}

/* ===================================================== */
/* MOBILE FINAL - NAVBAR + HERO                         */
/* ===================================================== */

@media (max-width: 768px) {

  html,
  body {
    overflow-x: hidden !important;
  }

  #navbar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 2000;
  }

  .jas-navbar {
    padding: 12px 0 !important;
    background: #ffffff !important;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06) !important;
  }

  .jas-navbar .container,
  .hero-section .container,
  .hero-container {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .jas-brand {
    display: flex;
    align-items: center;
    margin-right: 0 !important;
  }

  .jas-brand img,
  .navbar-brand img {
    height: 44px !important;
    width: auto !important;
    max-width: 100% !important;
    margin: 0 !important;
    transform: none !important;
  }

  .jas-navbar .navbar-toggler {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    padding: 0;
    border-radius: 14px;
    border: 1px solid rgba(15, 53, 84, 0.10);
    background: #ffffff;
    box-shadow: 0 6px 14px rgba(15, 53, 84, 0.06);
  }

  .jas-navbar .navbar-collapse {
    display: none !important;
    position: absolute;
    top: calc(100% + 10px);
    left: 16px;
    right: 16px;
    padding: 16px !important;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(15, 53, 84, 0.06);
    border-radius: 18px;
    box-shadow: 0 18px 40px rgba(10, 39, 64, 0.12);
  }

  .jas-navbar .navbar-collapse:not(.show) {
    display: none !important;
  }

  .jas-navbar .navbar-collapse.show {
    display: block !important;
  }

  .jas-navbar .navbar-nav {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
  }

  .jas-navbar .nav-link {
    display: block !important;
    width: 100% !important;
    padding: 12px 6px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    text-align: left !important;
  }

  .hero-section {
    padding-top: 110px !important;
    padding-bottom: 28px !important;
    overflow: hidden !important;
  }

  .hero-layout {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 20px !important;
    text-align: center !important;
    min-height: auto !important;
  }

  .hero-layout > * {
    min-width: 0 !important;
  }

  .hero-content {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 auto !important;
    padding: 0 !important;
    text-align: center !important;
  }

  .hero-eyebrow {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto 14px !important;
    padding: 0 0 8px !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
    text-align: center !important;
  }

  .hero-title {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 auto 16px !important;
    padding: 0 !important;
    font-size: 32px !important;
    line-height: 1.1 !important;
    text-align: center !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
  }

  .hero-description {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 auto 20px !important;
    padding: 0 !important;
    font-size: 15px !important;
    line-height: 1.7 !important;
    text-align: center !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
  }

  .hero-buttons {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;
  }

  .hero-btn-primary,
  .hero-btn-secondary {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: 52px !important;
    margin: 0 auto !important;
    padding: 0 16px !important;
    box-sizing: border-box !important;
  }

  .hero-visual {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    margin-top: 4px !important;
  }

  .hero-visual-frame {
    width: 100% !important;
    max-width: 280px !important;
    height: 180px !important;
    margin: 0 auto !important;
    overflow: hidden !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .hero-cloud-layer {
    width: 240px !important;
    max-width: none !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
  }

  .hero-cube-layer {
    width: 90px !important;
    max-width: none !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
  }
}

@media (max-width: 425px) {
  .hero-title {
    font-size: 29px !important;
  }

  .hero-description {
    font-size: 14px !important;
  }

  .hero-visual-frame {
    max-width: 250px !important;
    height: 165px !important;
  }

  .hero-cloud-layer {
    width: 215px !important;
  }

  .hero-cube-layer {
    width: 82px !important;
  }
}

@media (max-width: 360px) {
  .hero-title {
    font-size: 26px !important;
    line-height: 1.08 !important;
  }

  .hero-description {
    font-size: 13px !important;
  }

  .hero-visual-frame {
    max-width: 225px !important;
    height: 150px !important;
  }

  .hero-cloud-layer {
    width: 195px !important;
  }

  .hero-cube-layer {
    width: 74px !important;
  }
}

/* ============================================== */
/* PARCHE DIRECTO NAVBAR MÓVIL JAS                */
/* ============================================== */

@media (max-width: 768px) {

  #navbar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 2000;
  }

  #navbar .navbar,
  #navbar .jas-navbar {
    background: #ffffff !important;
    padding: 12px 0 !important;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06) !important;
  }

  #navbar .container,
  #navbar .container-fluid {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
  }

  #navbar .navbar-brand,
  #navbar .jas-brand {
    display: flex !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
    flex: 0 1 auto !important;
    min-width: 0 !important;
  }

  #navbar .navbar-brand img,
  #navbar .jas-brand img {
    height: 42px !important;
    width: auto !important;
    max-width: none !important;
    display: block !important;
  }

  #navbar .navbar-toggler {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 auto !important;
    width: 48px !important;
    height: 48px !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 14px !important;
    border: 1px solid rgba(15, 53, 84, 0.10) !important;
    background: #ffffff !important;
    box-shadow: 0 6px 14px rgba(15, 53, 84, 0.06) !important;
  }

  #navbar .navbar-toggler-icon {
    display: block !important;
    width: 20px !important;
    height: 20px !important;
    background-size: 20px 20px !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2815,53,84,0.9%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
  }

  #navbar .navbar-collapse {
    position: absolute !important;
    top: calc(100% + 10px) !important;
    left: 16px !important;
    right: 16px !important;
    padding: 16px !important;
    background: rgba(255, 255, 255, 0.98) !important;
    border: 1px solid rgba(15, 53, 84, 0.06) !important;
    border-radius: 18px !important;
    box-shadow: 0 18px 40px rgba(10, 39, 64, 0.12) !important;
  }

  #navbar .navbar-collapse.collapse:not(.show) {
    display: none !important;
  }

  #navbar .navbar-collapse.show,
  #navbar .navbar-collapse.collapsing {
    display: block !important;
  }

  #navbar .navbar-nav {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
  }

  #navbar .nav-link {
    display: block !important;
    width: 100% !important;
    padding: 12px 6px !important;
    text-align: left !important;
    font-size: 16px !important;
    font-weight: 700 !important;
  }
}

/* ===================================================== */
/* HERO RESPONSIVE MASTER - JAS                          */
/* ===================================================== */

/* ----------- hasta 992px ----------- */
@media (max-width: 991.98px) {
  .hero-section {
    padding-top: 126px !important;
    padding-bottom: 36px !important;
    overflow: hidden !important;
  }

  .hero-layout {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 28px !important;
    text-align: center !important;
    min-height: auto !important;
  }

  .hero-content {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    text-align: center !important;
  }

  .hero-title {
    max-width: 100% !important;
    margin: 0 auto 18px !important;
    font-size: clamp(2.3rem, 5.2vw, 3.2rem) !important;
    line-height: 1.05 !important;
    text-align: center !important;
  }

  .hero-description {
    max-width: 100% !important;
    margin: 0 auto 22px !important;
    font-size: 1rem !important;
    line-height: 1.72 !important;
    text-align: center !important;
  }

  .hero-buttons {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
  }

  .hero-btn-primary,
  .hero-btn-secondary {
    width: 100% !important;
    min-height: 54px !important;
    justify-content: center !important;
  }

  .hero-visual {
    display: flex !important;
    justify-content: center !important;
    margin-top: 6px !important;
  }

  .hero-visual-frame {
    width: 100% !important;
    max-width: 460px !important;
    height: 250px !important;
    margin: 0 auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
  }

  .hero-cloud-layer {
    width: 100% !important;
    max-width: 360px !important;
    height: auto !important;
    display: block !important;
    margin: 0 auto !important;
    transform: translateY(8px) scale(0.96) !important;
    transform-origin: center center !important;
  }
}

/* ----------- hasta 768px ----------- */
@media (max-width: 768px) {
  .hero-section {
    padding-top: 114px !important;
    padding-bottom: 30px !important;
  }

  .hero-layout {
    gap: 22px !important;
  }

  .hero-title {
    margin: 0 auto 16px !important;
    font-size: 32px !important;
    line-height: 1.08 !important;
  }

  .hero-description {
    margin: 0 auto 20px !important;
    font-size: 15px !important;
    line-height: 1.7 !important;
  }

  .hero-buttons {
    gap: 12px !important;
  }

  .hero-btn-primary,
  .hero-btn-secondary {
    min-height: 52px !important;
  }

  .hero-visual-frame {
    max-width: 360px !important;
    height: 210px !important;
  }

  .hero-cloud-layer {
    max-width: 280px !important;
    transform: translateY(10px) scale(0.92) !important;
  }
}

/* ----------- hasta 425px ----------- */
@media (max-width: 425px) {
  .hero-section {
    padding-top: 108px !important;
    padding-bottom: 26px !important;
  }

  .hero-title {
    font-size: 29px !important;
    line-height: 1.08 !important;
  }

  .hero-description {
    font-size: 14px !important;
    line-height: 1.68 !important;
  }

  .hero-visual-frame {
    max-width: 300px !important;
    height: 180px !important;
  }

  .hero-cloud-layer {
    max-width: 228px !important;
    transform: translateY(12px) scale(0.88) !important;
  }
}

/* ----------- hasta 375px ----------- */
@media (max-width: 375px) {
  .hero-title {
    font-size: 27px !important;
    line-height: 1.07 !important;
  }

  .hero-description {
    font-size: 13.5px !important;
  }

  .hero-btn-primary,
  .hero-btn-secondary {
    min-height: 50px !important;
    font-size: 14px !important;
  }

  .hero-visual-frame {
    max-width: 270px !important;
    height: 165px !important;
  }

  .hero-cloud-layer {
    max-width: 205px !important;
    transform: translateY(12px) scale(0.84) !important;
  }
}

/* ----------- hasta 320px ----------- */
@media (max-width: 320px) {
  .hero-section {
    padding-top: 104px !important;
  }

  .hero-title {
    font-size: 24px !important;
    line-height: 1.08 !important;
  }

  .hero-description {
    font-size: 13px !important;
    line-height: 1.64 !important;
  }

  .hero-buttons {
    gap: 10px !important;
  }

  .hero-btn-primary,
  .hero-btn-secondary {
    min-height: 48px !important;
    font-size: 13.5px !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .hero-visual-frame {
    max-width: 235px !important;
    height: 150px !important;
  }

  .hero-cloud-layer {
    max-width: 182px !important;
    transform: translateY(10px) scale(0.8) !important;
  }
}

/* ============================================== */
/* AJUSTE FINO - IMAGEN HERO                      */
/* ============================================== */

.hero-visual-frame{
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.hero-cloud-layer{
  display: block !important;
  width: 100% !important;
  height: auto !important;
  max-width: 100% !important;
  margin: 0 auto !important;
  object-fit: contain !important;
  object-position: center center !important;
  transform: none !important;
}

/* 992 */
@media (max-width: 991.98px){
  .hero-cloud-layer{
    max-width: 360px !important;
  }
}

/* 768 */
@media (max-width: 768px){
  .hero-cloud-layer{
    max-width: 280px !important;
  }
}

/* 425 */
@media (max-width: 425px){
  .hero-cloud-layer{
    max-width: 228px !important;
  }
}

/* 375 */
@media (max-width: 375px){
  .hero-cloud-layer{
    max-width: 205px !important;
  }
}

/* 320 */
@media (max-width: 320px){
  .hero-cloud-layer{
    max-width: 182px !important;
  }
}

/* ============================================== */
/* FIX REAL - IMAGEN HERO ACTUAL                  */
/* ============================================== */

.hero-visual-frame.hero-scene{
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.hero-cloud-layer{
  position: relative !important;
  left: auto !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  display: block !important;
  width: 100% !important;
  height: auto !important;
  margin: 0 auto !important;
  object-fit: contain !important;
  object-position: center center !important;
  transform: none !important;
}

/* 992 */
@media (max-width: 991.98px){
  .hero-visual-frame.hero-scene{
    max-width: 460px !important;
    height: 250px !important;
  }

  .hero-cloud-layer{
    max-width: 360px !important;
  }
}

/* 768 */
@media (max-width: 768px){
  .hero-visual-frame.hero-scene{
    max-width: 360px !important;
    height: 210px !important;
  }

  .hero-cloud-layer{
    max-width: 280px !important;
  }
}

/* 425 */
@media (max-width: 425px){
  .hero-visual-frame.hero-scene{
    max-width: 300px !important;
    height: 185px !important;
  }

  .hero-cloud-layer{
    max-width: 235px !important;
  }
}

/* 375 */
@media (max-width: 375px){
  .hero-visual-frame.hero-scene{
    max-width: 270px !important;
    height: 170px !important;
  }

  .hero-cloud-layer{
    max-width: 215px !important;
  }
}

/* 320 */
@media (max-width: 320px){
  .hero-visual-frame.hero-scene{
    max-width: 235px !important;
    height: 150px !important;
  }

  .hero-cloud-layer{
    max-width: 185px !important;
  }
}

/* ============================================== */
/* REDISEÑO MOBILE NAVBAR - JAS                   */
/* ============================================== */

@media (max-width: 768px) {

  #navbar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 2000;
  }

  #navbar .navbar,
  #navbar .jas-navbar {
    background: rgba(255, 255, 255, 0.98) !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    padding: 14px 0 !important;
    border-bottom: 1px solid rgba(15, 53, 84, 0.08) !important;
    box-shadow: 0 4px 14px rgba(15, 53, 84, 0.05) !important;
  }

  #navbar .container,
  #navbar .container-fluid {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
  }

  #navbar .navbar-brand,
  #navbar .jas-brand {
    display: flex !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  #navbar .navbar-brand img,
  #navbar .jas-brand img {
    height: 55px !important;
    width: auto !important;
    display: block !important;
  }

  /* Botón hamburguesa más limpio */
  #navbar .navbar-toggler {
    width: 46px !important;
    height: 46px !important;
    padding: 0 !important;
    margin: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 14px !important;
    border: 1px solid rgba(15, 53, 84, 0.10) !important;
    background: #ffffff !important;
    box-shadow: none !important;
  }

  #navbar .navbar-toggler:focus {
    box-shadow: none !important;
    outline: none !important;
  }

  #navbar .navbar-toggler-icon {
    width: 20px !important;
    height: 20px !important;
    background-size: 20px 20px !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
  }

  /* Menú pegado al navbar, no flotando */
  #navbar .navbar-collapse {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: 0 !important;
    margin-top: 0 !important;
    padding: 10px 20px 18px !important;
    background: rgba(255, 255, 255, 0.98) !important;
    border-top: 0 !important;
    border-left: 0 !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(15, 53, 84, 0.08) !important;
    border-radius: 0 0 20px 20px !important;
    box-shadow: 0 12px 30px rgba(15, 53, 84, 0.08) !important;
  }

  #navbar .navbar-collapse.collapse:not(.show) {
    display: none !important;
  }

  #navbar .navbar-collapse.show,
  #navbar .navbar-collapse.collapsing {
    display: block !important;
  }

  #navbar .navbar-nav {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
  }

  #navbar .nav-link {
    display: block !important;
    width: 100% !important;
    padding: 14px 2px !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    color: #12395c !important;
    text-align: left !important;
    border-radius: 0 !important;
    background: transparent !important;
  }

  #navbar .nav-link:hover,
  #navbar .nav-link:focus {
    color: #0E6F78 !important;
    background: transparent !important;
  }

  /* Ajuste del hero para que no choque */
  .hero-section {
    padding-top: 108px !important;
  }
}

/* ============================================== */
/* FOOTER- JAS                                    */
/* ============================================== */

@media (max-width: 425px) {
  .jas-footer-logo {
  width: 68px;
  }
}

/* ===================================================== */
/* QUIÉNES SOMOS - JAS SOLUTIONS                         */
/* ===================================================== */

/* ------------------------------------- */
/* BASE                                  */
/* ------------------------------------- */

.jas-about-hero-section,
.jas-about-intro-section,
.jas-about-focus-section,
.jas-about-sectors-section,
.jas-about-why-section,
.jas-about-cta-section {
  position: relative;
  overflow: hidden;
}

.jas-about-section-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #156B9A;
}

.jas-about-section-label::before {
  content: "";
  width: 42px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 100%);
}

.jas-about-section-title {
  margin: 0 0 18px;
  font-size: clamp(2rem, 3vw, 3.1rem);
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #0F3554;
}

.jas-about-section-text,
.jas-about-section-intro {
  margin: 0;
  font-size: 1rem;
  line-height: 1.82;
  color: #5E7488;
}

/* ------------------------------------- */
/* HERO                                  */
/* ------------------------------------- */

.jas-about-hero-section {
  padding: 100px 0 96px;
  background:
    radial-gradient(circle at 12% 18%, rgba(27, 167, 216, 0.16) 0%, transparent 18%),
    radial-gradient(circle at 84% 20%, rgba(88, 215, 255, 0.14) 0%, transparent 20%),
    radial-gradient(circle at 70% 72%, rgba(21, 107, 154, 0.18) 0%, transparent 24%),
    linear-gradient(135deg, #071826 0%, #0A2136 48%, #081A2B 100%);
}

.jas-about-hero-bg,
.jas-about-hero-grid,
.jas-about-hero-glow {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.jas-about-hero-grid {
  opacity: 0.18;
  background-image:
    linear-gradient(rgba(255,255,255,0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.045) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: radial-gradient(circle at center, rgba(0,0,0,1) 45%, rgba(0,0,0,0.22) 78%, transparent 100%);
  -webkit-mask-image: radial-gradient(circle at center, rgba(0,0,0,1) 45%, rgba(0,0,0,0.22) 78%, transparent 100%);
}

.jas-about-hero-glow-1 {
  background: radial-gradient(circle at 18% 28%, rgba(34, 184, 240, 0.18) 0%, transparent 24%);
}

.jas-about-hero-glow-2 {
  background: radial-gradient(circle at 78% 66%, rgba(88, 215, 255, 0.14) 0%, transparent 22%);
}

.jas-about-hero-container {
  position: relative;
  z-index: 2;
}

.jas-about-hero-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(420px, 0.96fr);
  gap: 60px;
  align-items: center;
}

.jas-about-hero-content {
  max-width: 650px;
}

.jas-about-hero-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
  color: #7BDCFF;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.jas-about-hero-label::before {
  content: "";
  width: 42px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #7BDCFF 100%);
}

.jas-about-hero-title {
  margin: 0 0 22px;
  font-size: clamp(2.2rem, 4vw, 4rem);
  line-height: 1.03;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: #FFFFFF;
}

.jas-about-hero-description {
  max-width: 590px;
  margin: 0 0 28px;
  font-size: 1rem;
  line-height: 1.84;
  color: rgba(225, 238, 247, 0.82);
}

.jas-about-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 24px;
}

.jas-about-hero-btn-primary,
.jas-about-hero-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 22px;
  border-radius: 14px;
  font-size: 0.94rem;
  font-weight: 700;
  transition: all 0.3s ease;
}

.jas-about-hero-btn-primary {
  background: linear-gradient(135deg, #156B9A 0%, #1BA7D8 100%);
  border: 1px solid rgba(123, 220, 255, 0.28);
  color: #FFFFFF !important;
  box-shadow: 0 16px 36px rgba(21, 107, 154, 0.28);
}

.jas-about-hero-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 42px rgba(21, 107, 154, 0.34);
  color: #FFFFFF !important;
}

.jas-about-hero-btn-secondary {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(123, 220, 255, 0.16);
  color: #FFFFFF !important;
  backdrop-filter: blur(10px);
}

.jas-about-hero-btn-secondary:hover {
  background: rgba(255, 255, 255, 0.14);
  transform: translateY(-2px);
  color: #FFFFFF !important;
}

.jas-about-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.jas-about-hero-meta span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(123, 220, 255, 0.12);
  color: rgba(229, 240, 247, 0.88);
  font-size: 0.86rem;
  font-weight: 600;
  backdrop-filter: blur(8px);
}

.jas-about-hero-meta i {
  color: #7BDCFF;
}

/* Visual derecho */

.jas-about-hero-visual {
  display: flex;
  justify-content: center;
  align-items: center;
}

.jas-about-hero-visual-shell {
  position: relative;
  width: 100%;
  max-width: 560px;
  min-height: 560px;
  border-radius: 34px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0.04) 100%);
  border: 1px solid rgba(123, 220, 255, 0.14);
  box-shadow:
    0 24px 60px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.08);
  backdrop-filter: blur(10px);
  overflow: hidden;
}

.jas-about-hero-visual-shell::before {
  content: "";
  position: absolute;
  inset: 24px;
  border-radius: 28px;
  border: 1px dashed rgba(123, 220, 255, 0.14);
}

.jas-about-orbit {
  position: absolute;
  inset: 50%;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  border: 1px solid rgba(123, 220, 255, 0.11);
  pointer-events: none;
}

.jas-about-orbit-1 {
  width: 360px;
  height: 360px;
  animation: jasOrbitSpin 18s linear infinite;
}

.jas-about-orbit-2 {
  width: 270px;
  height: 270px;
  opacity: 0.9;
  animation: jasOrbitSpinReverse 14s linear infinite;
}

.jas-about-orbit-3 {
  width: 150px;
  height: 150px;
  opacity: 0.72;
  animation: jasOrbitPulse 5s ease-in-out infinite;
}

.jas-about-core-card {
  position: absolute;
  inset: 50%;
  transform: translate(-50%, -50%);
  z-index: 3;
  width: min(78%, 360px);
  padding: 28px 24px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(234,244,248,0.86) 100%);
  border: 1px solid rgba(123, 220, 255, 0.2);
  box-shadow:
    0 20px 50px rgba(5, 18, 29, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.8);
  text-align: center;
}

.jas-about-core-icon {
  width: 104px;
  height: 104px;
  margin: 0 auto 18px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.98) 0%, rgba(226,241,248,0.92) 58%, rgba(27,167,216,0.10) 100%);
  border: 1px solid rgba(21, 107, 154, 0.14);
  box-shadow: 0 18px 36px rgba(15, 53, 84, 0.14);
}

.jas-about-core-logo {
  width: 64px;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(15, 53, 84, 0.12));
}

.jas-about-core-kicker {
  display: inline-block;
  margin-bottom: 8px;
  color: #156B9A;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.jas-about-core-copy h2 {
  margin: 0 0 10px;
  font-size: 1.26rem;
  line-height: 1.22;
  font-weight: 800;
  color: #0F3554;
}

.jas-about-core-copy p {
  margin: 0;
  font-size: 0.94rem;
  line-height: 1.72;
  color: #5E7488;
}

.jas-about-floating-card {
  position: absolute;
  z-index: 4;
  min-width: 160px;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(123, 220, 255, 0.16);
  box-shadow: 0 14px 28px rgba(5, 18, 29, 0.18);
  backdrop-filter: blur(10px);
  color: #EAF4F8;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.9rem;
  font-weight: 700;
  animation: jasFloatSoft 6s ease-in-out infinite;
}

.jas-about-floating-card i {
  color: #7BDCFF;
  font-size: 1rem;
}

.jas-about-floating-card-top {
  top: 74px;
  left: 50%;
  transform: translateX(-50%);
}

.jas-about-floating-card-left {
  left: 26px;
  bottom: 110px;
  animation-delay: 0.8s;
}

.jas-about-floating-card-right {
  right: 26px;
  bottom: 110px;
  animation-delay: 1.4s;
}

/* ------------------------------------- */
/* INTRO                                 */
/* ------------------------------------- */

.jas-about-intro-section {
  padding: 110px 0;
  background: #FFFFFF;
}

.jas-about-intro-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.72fr);
  gap: 40px;
  align-items: start;
}

.jas-about-intro-main {
  max-width: 760px;
}

.jas-about-intro-main .jas-about-section-text + .jas-about-section-text {
  margin-top: 20px;
}

.jas-about-intro-side {
  display: flex;
  justify-content: flex-end;
}

.jas-about-highlight-card {
  position: relative;
  width: 100%;
  max-width: 360px;
  padding: 28px 24px;
  border-radius: 24px;
  background:
    linear-gradient(180deg, #FFFFFF 0%, #F4FAFD 100%);
  border: 1px solid rgba(21, 107, 154, 0.08);
  box-shadow: 0 18px 42px rgba(15, 53, 84, 0.08);
}

.jas-about-highlight-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 24px;
  padding: 1px;
  background: linear-gradient(135deg, rgba(27,167,216,0.18), rgba(15,53,84,0.08));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}

.jas-about-highlight-icon {
  width: 58px;
  height: 58px;
  margin-bottom: 16px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, #0F3554 0%, #156B9A 100%);
  box-shadow: 0 16px 32px rgba(21, 107, 154, 0.18);
}

.jas-about-highlight-icon i {
  color: #FFFFFF;
  font-size: 1.2rem;
}

.jas-about-highlight-card h3 {
  margin: 0 0 12px;
  font-size: 1.2rem;
  line-height: 1.3;
  font-weight: 800;
  color: #0F3554;
}

.jas-about-highlight-card p {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.75;
  color: #5E7488;
}

/* ------------------------------------- */
/* ENFOQUE                               */
/* ------------------------------------- */

.jas-about-focus-section {
  padding: 110px 0;
  background:
    radial-gradient(circle at 12% 12%, rgba(27, 167, 216, 0.06) 0%, transparent 20%),
    linear-gradient(180deg, #F8FBFD 0%, #EEF5F9 100%);
}

.jas-about-focus-header {
  max-width: 760px;
  margin-bottom: 42px;
}

.jas-about-focus-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.jas-about-focus-card {
  position: relative;
  padding: 32px 26px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(240,248,251,0.88) 100%);
  border: 1px solid rgba(15, 53, 84, 0.06);
  box-shadow: 0 18px 42px rgba(15, 53, 84, 0.07);
  transition: all 0.32s ease;
}

.jas-about-focus-card:hover {
  transform: translateY(-4px);
  border-color: rgba(27, 167, 216, 0.18);
  box-shadow: 0 22px 48px rgba(15, 53, 84, 0.11);
}

.jas-about-focus-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 24px;
  width: 72px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 100%);
}

.jas-about-focus-icon {
  width: 60px;
  height: 60px;
  margin-bottom: 18px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, #0F3554 0%, #156B9A 100%);
  box-shadow: 0 14px 30px rgba(21, 107, 154, 0.18);
}

.jas-about-focus-icon i {
  color: #FFFFFF;
  font-size: 1.18rem;
}

.jas-about-focus-card h3 {
  margin: 0 0 12px;
  font-size: 1.18rem;
  line-height: 1.28;
  font-weight: 800;
  color: #17324D;
}

.jas-about-focus-card p {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.74;
  color: #5E7488;
}

/* ------------------------------------- */
/* SECTORES                              */
/* ------------------------------------- */

.jas-about-sectors-section {
  padding: 105px 0;
  background: #FFFFFF;
}

.jas-about-sectors-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 34px;
  align-items: center;
}

.jas-about-sectors-copy {
  max-width: 560px;
}

.jas-about-sectors-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: flex-start;
}

.jas-sector-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 52px;
  padding: 0 18px;
  border-radius: 999px;
  background:
    linear-gradient(180deg, #FFFFFF 0%, #F3F9FC 100%);
  border: 1px solid rgba(21, 107, 154, 0.10);
  box-shadow: 0 10px 24px rgba(15, 53, 84, 0.06);
  font-size: 0.94rem;
  font-weight: 700;
  color: #17324D;
  transition: all 0.3s ease;
}

.jas-sector-pill:hover {
  transform: translateY(-2px);
  border-color: rgba(27, 167, 216, 0.24);
  box-shadow: 0 14px 28px rgba(15, 53, 84, 0.10);
}

.jas-sector-pill i {
  color: #156B9A;
  font-size: 1rem;
}

/* ------------------------------------- */
/* POR QUÉ JAS                           */
/* ------------------------------------- */

.jas-about-why-section {
  padding: 112px 0;
  background:
    radial-gradient(circle at 84% 14%, rgba(27, 167, 216, 0.08) 0%, transparent 22%),
    linear-gradient(180deg, #F8FBFD 0%, #EEF5F9 100%);
}

.jas-about-why-header {
  max-width: 760px;
  margin-bottom: 42px;
}

.jas-about-why-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.jas-about-why-card {
  position: relative;
  padding: 34px 28px 30px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, #0A2236 0%, #0E2D46 100%);
  border: 1px solid rgba(123, 220, 255, 0.10);
  box-shadow: 0 20px 44px rgba(6, 22, 35, 0.16);
  overflow: hidden;
  transition: all 0.32s ease;
}

.jas-about-why-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 52px rgba(6, 22, 35, 0.22);
}

.jas-about-why-card::before {
  content: "";
  position: absolute;
  inset: auto -60px -60px auto;
  width: 170px;
  height: 170px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(34,184,240,0.18) 0%, rgba(34,184,240,0) 70%);
  pointer-events: none;
}

.jas-about-why-number {
  margin-bottom: 18px;
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  color: rgba(123, 220, 255, 0.82);
}

.jas-about-why-icon {
  width: 62px;
  height: 62px;
  margin-bottom: 18px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(123, 220, 255, 0.14);
  backdrop-filter: blur(10px);
}

.jas-about-why-icon i {
  color: #7BDCFF;
  font-size: 1.18rem;
}

.jas-about-why-card h3 {
  margin: 0 0 12px;
  font-size: 1.2rem;
  line-height: 1.28;
  font-weight: 800;
  color: #FFFFFF;
}

.jas-about-why-card p {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.74;
  color: rgba(226, 239, 246, 0.78);
}

/* ------------------------------------- */
/* CTA FINAL                             */
/* ------------------------------------- */

.jas-about-cta-section {
  padding: 110px 0;
  background:
    radial-gradient(circle at 14% 18%, rgba(34, 184, 240, 0.16) 0%, transparent 20%),
    radial-gradient(circle at 82% 68%, rgba(88, 215, 255, 0.12) 0%, transparent 24%),
    linear-gradient(135deg, #071826 0%, #0B2236 52%, #081A2B 100%);
}

.jas-about-cta-overlay {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 54px 54px;
  opacity: 0.12;
  pointer-events: none;
}

.jas-about-cta-inner {
  position: relative;
  z-index: 2;
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
}

.jas-about-cta-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
  color: #7BDCFF;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.jas-about-cta-label::before,
.jas-about-cta-label::after {
  content: "";
  width: 36px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #7BDCFF 100%);
}

.jas-about-cta-title {
  margin: 0 0 18px;
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #FFFFFF;
}

.jas-about-cta-text {
  max-width: 720px;
  margin: 0 auto 28px;
  font-size: 1rem;
  line-height: 1.82;
  color: rgba(225, 238, 247, 0.82);
}

.jas-about-cta-buttons {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 14px;
}

.jas-about-cta-btn-primary,
.jas-about-cta-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 22px;
  border-radius: 14px;
  font-size: 0.94rem;
  font-weight: 700;
  transition: all 0.3s ease;
}

.jas-about-cta-btn-primary {
  background: linear-gradient(135deg, #156B9A 0%, #1BA7D8 100%);
  border: 1px solid rgba(123, 220, 255, 0.24);
  color: #FFFFFF !important;
  box-shadow: 0 16px 36px rgba(21, 107, 154, 0.28);
}

.jas-about-cta-btn-primary:hover {
  transform: translateY(-2px);
  color: #FFFFFF !important;
}

.jas-about-cta-btn-secondary {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(123, 220, 255, 0.16);
  color: #FFFFFF !important;
  backdrop-filter: blur(8px);
}

.jas-about-cta-btn-secondary:hover {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.14);
  color: #FFFFFF !important;
}

/* ------------------------------------- */
/* ANIMACIONES                           */
/* ------------------------------------- */

@keyframes jasOrbitSpin {
  from { transform: translate(-50%, -50%) rotate(0deg); }
  to   { transform: translate(-50%, -50%) rotate(360deg); }
}

@keyframes jasOrbitSpinReverse {
  from { transform: translate(-50%, -50%) rotate(360deg); }
  to   { transform: translate(-50%, -50%) rotate(0deg); }
}

@keyframes jasOrbitPulse {
  0%, 100% { transform: translate(-50%, -50%) scale(1); opacity: 0.72; }
  50%      { transform: translate(-50%, -50%) scale(1.06); opacity: 1; }
}

@keyframes jasFloatSoft {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}

/* ------------------------------------- */
/* RESPONSIVE                            */
/* ------------------------------------- */

@media (max-width: 1199.98px) {
  .jas-about-hero-layout {
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.95fr);
    gap: 42px;
  }

  .jas-about-hero-visual-shell {
    max-width: 510px;
    min-height: 520px;
  }

  .jas-about-orbit-1 {
    width: 320px;
    height: 320px;
  }

  .jas-about-orbit-2 {
    width: 244px;
    height: 244px;
  }

  .jas-about-sectors-layout {
    grid-template-columns: 1fr;
    gap: 26px;
  }
}

@media (max-width: 991.98px) {
  .jas-about-hero-section {
    padding: 138px 0 78px;
  }

  .jas-about-hero-layout,
  .jas-about-intro-grid,
  .jas-about-sectors-layout {
    grid-template-columns: 1fr;
  }

  .jas-about-hero-content,
  .jas-about-intro-main,
  .jas-about-focus-header,
  .jas-about-why-header,
  .jas-about-sectors-copy {
    max-width: 100%;
  }

  .jas-about-hero-content {
    text-align: center;
    margin: 0 auto;
  }

  .jas-about-hero-label,
  .jas-about-section-label {
    justify-content: center;
  }

  .jas-about-hero-actions,
  .jas-about-hero-meta {
    justify-content: center;
  }

  .jas-about-hero-visual-shell {
    max-width: 100%;
    min-height: 500px;
  }

  .jas-about-intro-side {
    justify-content: flex-start;
  }

  .jas-about-highlight-card {
    max-width: 100%;
  }

  .jas-about-focus-grid,
  .jas-about-why-grid {
    grid-template-columns: 1fr;
  }

  .jas-about-intro-section,
  .jas-about-focus-section,
  .jas-about-sectors-section,
  .jas-about-why-section,
  .jas-about-cta-section {
    padding: 88px 0;
  }
}

@media (max-width: 767.98px) {
  .jas-about-hero-section {
    padding: 126px 0 66px;
  }

  .jas-about-hero-title,
  .jas-about-section-title,
  .jas-about-cta-title {
    font-size: 2rem;
  }

  .jas-about-hero-description,
  .jas-about-section-text,
  .jas-about-section-intro,
  .jas-about-cta-text {
    font-size: 0.96rem;
    line-height: 1.78;
  }

  .jas-about-hero-actions,
  .jas-about-cta-buttons {
    flex-direction: column;
    align-items: stretch;
  }

  .jas-about-hero-btn-primary,
  .jas-about-hero-btn-secondary,
  .jas-about-cta-btn-primary,
  .jas-about-cta-btn-secondary {
    width: 100%;
  }

  .jas-about-hero-visual-shell {
    min-height: 430px;
    border-radius: 28px;
  }

  .jas-about-hero-visual-shell::before {
    inset: 18px;
    border-radius: 22px;
  }

  .jas-about-orbit-1 {
    width: 270px;
    height: 270px;
  }

  .jas-about-orbit-2 {
    width: 210px;
    height: 210px;
  }

  .jas-about-orbit-3 {
    width: 124px;
    height: 124px;
  }

  .jas-about-core-card {
    width: min(82%, 320px);
    padding: 24px 18px;
  }

  .jas-about-core-icon {
    width: 88px;
    height: 88px;
  }

  .jas-about-core-logo {
    width: 54px;
  }

  .jas-about-floating-card {
    min-width: 132px;
    padding: 12px 13px;
    font-size: 0.82rem;
    gap: 8px;
  }

  .jas-about-floating-card-top {
    top: 48px;
  }

  .jas-about-floating-card-left {
    left: 14px;
    bottom: 84px;
  }

  .jas-about-floating-card-right {
    right: 14px;
    bottom: 84px;
  }

  .jas-about-focus-card,
  .jas-about-why-card,
  .jas-about-highlight-card {
    padding: 26px 20px;
    border-radius: 22px;
  }

  .jas-sector-pill {
    min-height: 48px;
    padding: 0 16px;
    font-size: 0.9rem;
  }
}

@media (max-width: 575.98px) {
  .jas-about-hero-title,
  .jas-about-section-title,
  .jas-about-cta-title {
    font-size: 1.8rem;
    line-height: 1.08;
  }

  .jas-about-hero-meta span {
    width: 100%;
    justify-content: center;
  }

  .jas-about-hero-visual-shell {
    min-height: 380px;
  }

  .jas-about-orbit-1 {
    width: 226px;
    height: 226px;
  }

  .jas-about-orbit-2 {
    width: 176px;
    height: 176px;
  }

  .jas-about-orbit-3 {
    width: 110px;
    height: 110px;
  }

  .jas-about-core-card {
    width: min(88%, 286px);
  }

  .jas-about-core-copy h2 {
    font-size: 1.08rem;
  }

  .jas-about-core-copy p {
    font-size: 0.88rem;
  }

  .jas-about-floating-card {
    min-width: 118px;
    font-size: 0.76rem;
    padding: 10px 12px;
  }

  .jas-about-floating-card-left,
  .jas-about-floating-card-right {
    bottom: 58px;
  }

  .jas-about-focus-icon,
  .jas-about-why-icon,
  .jas-about-highlight-icon {
    width: 54px;
    height: 54px;
    border-radius: 16px;
  }
}

@media (max-width: 375px) {
  .jas-about-hero-section {
    padding-top: 118px;
  }

  .jas-about-hero-title,
  .jas-about-section-title,
  .jas-about-cta-title {
    font-size: 1.65rem;
  }

  .jas-about-hero-visual-shell {
    min-height: 350px;
  }

  .jas-about-floating-card {
    min-width: 108px;
    font-size: 0.72rem;
    padding: 9px 10px;
  }

  .jas-sector-pill {
    width: 100%;
    justify-content: center;
  }
}

/* ===================================================== */
/* HERO FINAL - QUIÉNES SOMOS                            */
/* ===================================================== */

.jas-about-hero-section {
  position: relative;
  min-height: 90vh;
  display: flex;
  align-items: center;
  padding: 190px 0 95px;
  overflow: hidden;
  background: #071826;
}

.jas-about-hero-media,
.jas-about-hero-overlay,
.jas-about-hero-grid {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.jas-about-hero-media {
  z-index: 0;
}

.jas-about-hero-bg-video,
.jas-about-hero-bg-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

.jas-about-hero-overlay {
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(4, 16, 26, 0.82) 0%, rgba(4, 16, 26, 0.70) 34%, rgba(7, 24, 38, 0.44) 62%, rgba(7, 24, 38, 0.62) 100%),
    linear-gradient(180deg, rgba(4, 16, 26, 0.18) 0%, rgba(4, 16, 26, 0.48) 100%);
}

.jas-about-hero-grid {
  z-index: 2;
  opacity: 0.12;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 52px 52px;
  pointer-events: none;
}

.jas-about-hero-container {
  position: relative;
  z-index: 3;
}

.jas-about-hero-inner {
  max-width: 720px;
}

.jas-about-hero-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  color: #7BDCFF;
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.jas-about-hero-label::before {
  content: "";
  width: 44px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #7BDCFF 100%);
}

.jas-about-hero-title {
  margin: 0 0 22px;
  font-size: 58.5px;
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #FFFFFF;
  text-wrap: balance;
}

.jas-about-hero-description {
  max-width: 620px;
  margin: 0 0 24px;
  font-size: 1rem;
  line-height: 1.78;
  color: rgba(227, 238, 246, 0.86);
}

.jas-about-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 20px;
}

.jas-about-hero-btn-primary,
.jas-about-hero-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border-radius: 14px;
  font-size: 0.93rem;
  font-weight: 700;
  transition: all 0.3s ease;
}

.jas-about-hero-btn-primary {
  background: linear-gradient(135deg, #156B9A 0%, #1BA7D8 100%);
  border: 1px solid rgba(123, 220, 255, 0.24);
  color: #FFFFFF !important;
  box-shadow: 0 16px 32px rgba(21, 107, 154, 0.24);
}

.jas-about-hero-btn-primary:hover {
  transform: translateY(-2px);
  color: #FFFFFF !important;
}

.jas-about-hero-btn-secondary {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(123, 220, 255, 0.16);
  color: #FFFFFF !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.jas-about-hero-btn-secondary:hover {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.14);
  color: #FFFFFF !important;
}

.jas-about-hero-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.jas-about-hero-tags span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(123, 220, 255, 0.12);
  color: rgba(229, 240, 247, 0.88);
  font-size: 0.84rem;
  font-weight: 600;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.jas-about-hero-tags i {
  color: #7BDCFF;
}

/* HERO SIN BLOQUE DERECHO */
.jas-about-hero-layout,
.jas-about-hero-content,
.jas-about-hero-visual,
.jas-about-hero-visual-shell,
.jas-about-orbit,
.jas-about-core-card,
.jas-about-floating-card,
.jas-about-visual-composition {
  all: unset;
}

/* CTA CLARO FINAL */
.jas-about-cta-section {
  position: relative;
  padding: 88px 0 126px;
  background:
    radial-gradient(circle at 14% 22%, rgba(27, 167, 216, 0.06) 0%, transparent 24%),
    radial-gradient(circle at 84% 70%, rgba(88, 215, 255, 0.08) 0%, transparent 26%),
    linear-gradient(180deg, #FFFFFF 0%, #F4FAFD 100%);
}

.jas-about-cta-overlay {
  display: none !important;
}

.jas-about-cta-inner,
.jas-about-cta-card {
  position: relative;
  max-width: 980px;
  margin: 0 auto;
  padding: 46px 48px;
  border-radius: 30px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(238,246,250,0.95) 100%);
  border: 1px solid rgba(15, 53, 84, 0.08);
  box-shadow:
    0 24px 60px rgba(15, 53, 84, 0.10),
    inset 0 1px 0 rgba(255,255,255,0.92);
  overflow: hidden;
  text-align: center;
}

.jas-about-cta-inner::before,
.jas-about-cta-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 10% 18%, rgba(27, 167, 216, 0.10) 0%, transparent 22%),
    radial-gradient(circle at 88% 78%, rgba(88, 215, 255, 0.10) 0%, transparent 24%);
  pointer-events: none;
}

.jas-about-cta-inner::after,
.jas-about-cta-card::after {
  content: "";
  position: absolute;
  inset: 20px;
  border-radius: 24px;
  border: 1px dashed rgba(21, 107, 154, 0.10);
  pointer-events: none;
}

.jas-about-cta-inner > *,
.jas-about-cta-card > * {
  position: relative;
  z-index: 2;
}

.jas-about-cta-title {
  margin: 0 0 16px;
  font-size: clamp(1.9rem, 3vw, 3rem);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #0F3554;
}

.jas-about-cta-text {
  max-width: 720px;
  margin: 0 auto 26px;
  font-size: 1rem;
  line-height: 1.78;
  color: #5E7488;
}

.jas-about-cta-buttons,
.jas-about-cta-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
}

.jas-about-cta-btn-primary,
.jas-about-cta-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 22px;
  border-radius: 14px;
  font-size: 0.94rem;
  font-weight: 700;
  transition: all 0.3s ease;
}

.jas-about-cta-btn-primary {
  background: linear-gradient(135deg, #156B9A 0%, #1BA7D8 100%);
  border: 1px solid rgba(21, 107, 154, 0.18);
  color: #FFFFFF !important;
  box-shadow: 0 16px 32px rgba(21, 107, 154, 0.22);
}

.jas-about-cta-btn-secondary {
  background: #FFFFFF;
  border: 1px solid rgba(15, 53, 84, 0.14);
  color: #0F3554 !important;
  box-shadow: 0 10px 24px rgba(15, 53, 84, 0.06);
}

.jas-about-cta-btn-secondary:hover {
  background: #0F3554;
  color: #FFFFFF !important;
}

/* RESPONSIVE */
@media (max-width: 991.98px) {
  .jas-about-hero-section {
    min-height: auto;
    padding: 146px 0 80px;
  }

  .jas-about-hero-inner {
    max-width: 100%;
  }

  .jas-about-hero-title {
    max-width: 11ch;
    font-size: clamp(2.4rem, 6vw, 4rem);
  }

  .jas-about-cta-inner,
  .jas-about-cta-card {
    padding: 40px 30px;
  }
}

@media (max-width: 767.98px) {
  .jas-about-hero-section {
    padding: 122px 0 66px;
    min-height: auto;
  }

  .jas-about-hero-title {
    max-width: 100%;
    font-size: clamp(2rem, 8.2vw, 2.9rem);
    line-height: 1.02;
  }

  .jas-about-hero-description,
  .jas-about-cta-text {
    font-size: 0.95rem;
    line-height: 1.75;
  }

  .jas-about-hero-actions,
  .jas-about-cta-buttons,
  .jas-about-cta-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .jas-about-hero-btn-primary,
  .jas-about-hero-btn-secondary,
  .jas-about-cta-btn-primary,
  .jas-about-cta-btn-secondary {
    width: 100%;
  }

  .jas-about-hero-tags span {
    width: 100%;
    justify-content: center;
  }

  .jas-about-cta-section {
    padding: 78px 0 96px;
  }

  .jas-about-cta-inner,
  .jas-about-cta-card {
    padding: 32px 20px;
    border-radius: 24px;
  }
}

@media (max-width: 375px) {
  .jas-about-hero-title {
    font-size: 1.85rem;
  }

  .jas-about-hero-description {
    font-size: 0.9rem;
  }
}

.jas-about-hero-media,
.jas-about-hero-bg-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.jas-about-hero-bg-video {
  object-fit: cover;
  object-position: center center;
  display: block;
}

.jas-about-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(4,16,26,.78) 0%, rgba(4,16,26,.62) 38%, rgba(7,24,38,.46) 100%);
  pointer-events: none;
}

/* ============================================== */
/* NAVBAR REVEAL ON HOVER - SOLO DESKTOP          */
/* ============================================== */

.page-about .jas-navbar:not(.scrolled) .nav-link {
  color: #EDF4F8 !important;
}

.page-about .jas-navbar:not(.scrolled) .nav-link:hover,
.page-about .jas-navbar:not(.scrolled) .nav-link:focus {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.08);
}

/* ===================================================*/
/* CAMBIO DE LOGO SEGÚN EL FONDO DEL IMAGEN DEL HERO */
/* ===================================================*/
.page-about .jas-navbar:not(.scrolled) .jas-brand img {
  content: url("../images/logo/jas-logo-horizontal-light.png");
}

/* ===================================================== */
/* CTA FINAL ABIERTO - QUIÉNES SOMOS                     */
/* ===================================================== */

.jas-about-cta-open-section {
  position: relative;
  padding: 80px 0 80px;
  overflow: hidden;
  background:
    radial-gradient(circle at 14% 22%, rgba(27, 167, 216, 0.08) 0%, transparent 24%),
    radial-gradient(circle at 84% 78%, rgba(88, 215, 255, 0.08) 0%, transparent 24%),
    linear-gradient(180deg, #F8FBFD 0%, #EEF5F9 100%);
}

.jas-about-cta-open-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.00) 0%, rgba(255,255,255,0.32) 50%, rgba(255,255,255,0.00) 100%);
  opacity: 0.55;
  pointer-events: none;
}

.jas-about-cta-open-glow {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(24px);
  opacity: 0.95;
}

.jas-about-cta-open-glow-left {
  width: 420px;
  height: 420px;
  left: -120px;
  top: 40px;
  background: radial-gradient(circle, rgba(34, 184, 240, 0.14) 0%, rgba(34, 184, 240, 0.04) 42%, rgba(34, 184, 240, 0) 72%);
}

.jas-about-cta-open-glow-right {
  width: 420px;
  height: 420px;
  right: -120px;
  bottom: 18px;
  background: radial-gradient(circle, rgba(21, 107, 154, 0.12) 0%, rgba(21, 107, 154, 0.04) 42%, rgba(21, 107, 154, 0) 72%);
}

.jas-about-cta-open-inner {
  position: relative;
  z-index: 3;
  max-width: 1040px;
  margin: 0 auto;
  text-align: center;
}

.jas-about-cta-open-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-bottom: 22px;
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #1BA7D8;
}

.jas-about-cta-open-label::before,
.jas-about-cta-open-label::after {
  content: "";
  width: 46px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 100%);
}

.jas-about-cta-open-title {
  max-width: 1050px;
  margin: 0 auto 22px;
  font-size: 46.08px;
  line-height: 0.98;
  font-weight: 800;
  letter-spacing: -0.045em;
  color: #0F3554;
}

.jas-about-cta-open-text {
  max-width: 780px;
  margin: 0 auto 34px;
  font-size: 1.04rem;
  line-height: 1.9;
  color: #5E7488;
}

.jas-about-cta-open-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 28px;
}

.jas-about-cta-open-btn-primary,
.jas-about-cta-open-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 240px;
  min-height: 58px;
  padding: 0 30px;
  border-radius: 16px;
  font-size: 1rem;
  font-weight: 700;
  transition: all 0.3s ease;
}

.jas-about-cta-open-btn-primary {
  background: linear-gradient(145deg, #0F3554 0%, #156B9A 58%, #22B8F0 100%);
  border: 1px solid rgba(27, 167, 216, 0.18);
  color: #FFFFFF !important;
  box-shadow: 0 18px 38px rgba(21, 107, 154, 0.24);
}

.jas-about-cta-open-btn-primary:hover {
  transform: translateY(-3px);
  color: #FFFFFF !important;
  box-shadow: 0 22px 42px rgba(21, 107, 154, 0.30);
}

.jas-about-cta-open-btn-secondary {
  background: rgba(255,255,255,0.78);
  border: 1px solid rgba(15, 53, 84, 0.10);
  color: #0F3554 !important;
  box-shadow: 0 14px 30px rgba(15, 53, 84, 0.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.jas-about-cta-open-btn-secondary:hover {
  transform: translateY(-3px);
  background: #FFFFFF;
  color: #0F3554 !important;
}

.jas-about-cta-open-meta {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px 28px;
}

.jas-about-cta-open-meta span {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.98rem;
  font-weight: 600;
  color: #5E7488;
}

.jas-about-cta-open-meta i {
  font-size: 0.92rem;
  color: #1BA7D8;
}

/* ------------------------------------- */
/* RESPONSIVE                            */
/* ------------------------------------- */

@media (max-width: 991.98px) {
  .jas-about-cta-open-section {
    padding: 92px 0 105px;
  }

  .jas-about-cta-open-title {
    max-width: 760px;
    font-size: clamp(2rem, 6vw, 3.35rem);
  }

  .jas-about-cta-open-text {
    max-width: 700px;
  }
}

@media (max-width: 767.98px) {
  .jas-about-cta-open-section {
    padding: 82px 0 92px;
  }

  .jas-about-cta-open-label {
    font-size: 0.82rem;
    letter-spacing: 0.14em;
  }

  .jas-about-cta-open-label::before,
  .jas-about-cta-open-label::after {
    width: 32px;
  }

  .jas-about-cta-open-title {
    font-size: clamp(1.95rem, 8vw, 2.7rem);
    line-height: 1.02;
  }

  .jas-about-cta-open-text {
    font-size: 0.98rem;
    line-height: 1.82;
    margin-bottom: 28px;
  }

  .jas-about-cta-open-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .jas-about-cta-open-btn-primary,
  .jas-about-cta-open-btn-secondary {
    width: 100%;
    min-width: 0;
  }

  .jas-about-cta-open-meta {
    gap: 12px;
  }

  .jas-about-cta-open-meta span {
    width: 100%;
    justify-content: center;
    text-align: center;
  }
}

@media (max-width: 575.98px) {
  .jas-about-cta-open-section {
    padding: 74px 0 86px;
  }

  .jas-about-cta-open-glow-left,
  .jas-about-cta-open-glow-right {
    width: 280px;
    height: 280px;
  }
}

/* ===================================================== */
/* SERVICIOS - JAS SOLUTIONS                             */
/* ===================================================== */

/* ------------------------------------- */
/* BASE                                  */
/* ------------------------------------- */

.jas-services-hero-section,
.jas-services-intro-section,
.jas-services-catalog-section,
.jas-services-value-section,
.jas-services-adapt-section,
.jas-services-cta-section {
  position: relative;
  overflow: hidden;
}

.jas-services-section-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #156B9A;
}

.jas-services-section-label::before {
  content: "";
  width: 42px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 100%);
}

.jas-services-section-title {
  margin: 0 0 18px;
  font-size: clamp(2rem, 3vw, 3.1rem);
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #0F3554;
}

.jas-services-section-text,
.jas-services-section-intro {
  margin: 0;
  font-size: 1rem;
  line-height: 1.82;
  color: #5E7488;
}

/* ------------------------------------- */
/* HERO                                  */
/* ------------------------------------- */

.jas-services-hero-section {
  position: relative;
  min-height: 90vh;
  display: flex;
  align-items: center;
  padding: 190px 0 95px;
  background: #071826;
}

.jas-services-hero-media,
.jas-services-hero-overlay,
.jas-services-hero-grid {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.jas-services-hero-media {
  z-index: 0;
}

.jas-services-hero-bg-image,
.jas-services-hero-bg-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

.jas-services-hero-overlay {
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(4, 16, 26, 0.84) 0%, rgba(4, 16, 26, 0.72) 34%, rgba(7, 24, 38, 0.50) 62%, rgba(7, 24, 38, 0.68) 100%),
    linear-gradient(180deg, rgba(4, 16, 26, 0.20) 0%, rgba(4, 16, 26, 0.54) 100%);
}

.jas-services-hero-grid {
  z-index: 2;
  opacity: 0.12;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 52px 52px;
  pointer-events: none;
}

.jas-services-hero-container {
  position: relative;
  z-index: 3;
}

.jas-services-hero-inner {
  max-width: 760px;
}

.jas-services-hero-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  color: #7BDCFF;
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.jas-services-hero-label::before {
  content: "";
  width: 44px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #7BDCFF 100%);
}

.jas-services-hero-title {
  margin: 0 0 22px;
  font-size: 58.5px;
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #FFFFFF;
  text-wrap: balance;
}

.jas-services-hero-description {
  max-width: 640px;
  margin: 0 0 26px;
  font-size: 1rem;
  line-height: 1.8;
  color: rgba(227, 238, 246, 0.86);
}

.jas-services-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.jas-services-hero-btn-primary,
.jas-services-hero-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border-radius: 14px;
  font-size: 0.93rem;
  font-weight: 700;
  transition: all 0.3s ease;
}

.jas-services-hero-btn-primary {
  background: linear-gradient(135deg, #156B9A 0%, #1BA7D8 100%);
  border: 1px solid rgba(123, 220, 255, 0.24);
  color: #FFFFFF !important;
  box-shadow: 0 16px 32px rgba(21, 107, 154, 0.24);
}

.jas-services-hero-btn-primary:hover {
  transform: translateY(-2px);
  color: #FFFFFF !important;
}

.jas-services-hero-btn-secondary {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(123, 220, 255, 0.16);
  color: #FFFFFF !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.jas-services-hero-btn-secondary:hover {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.14);
  color: #FFFFFF !important;
}

/* ------------------------------------- */
/* INTRO                                 */
/* ------------------------------------- */

.jas-services-intro-section {
  padding: 108px 0;
  background: #FFFFFF;
}

.jas-services-intro-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.72fr);
  gap: 40px;
  align-items: start;
}

.jas-services-intro-main {
  max-width: 760px;
}

.jas-services-intro-main .jas-services-section-text + .jas-services-section-text {
  margin-top: 20px;
}

.jas-services-intro-side {
  display: flex;
  justify-content: flex-end;
}

.jas-services-intro-card {
  position: relative;
  width: 100%;
  max-width: 370px;
  padding: 28px 24px;
  border-radius: 24px;
  background: linear-gradient(180deg, #FFFFFF 0%, #F4FAFD 100%);
  border: 1px solid rgba(21, 107, 154, 0.08);
  box-shadow: 0 18px 42px rgba(15, 53, 84, 0.08);
}

.jas-services-intro-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 24px;
  padding: 1px;
  background: linear-gradient(135deg, rgba(27,167,216,0.18), rgba(15,53,84,0.08));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}

.jas-services-intro-card-icon {
  width: 58px;
  height: 58px;
  margin-bottom: 16px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, #0F3554 0%, #156B9A 100%);
  box-shadow: 0 16px 32px rgba(21, 107, 154, 0.18);
}

.jas-services-intro-card-icon i {
  color: #FFFFFF;
  font-size: 1.18rem;
}

.jas-services-intro-card h3 {
  margin: 0 0 12px;
  font-size: 1.18rem;
  line-height: 1.3;
  font-weight: 800;
  color: #0F3554;
}

.jas-services-intro-card p {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.75;
  color: #5E7488;
}

/* ------------------------------------- */
/* CATÁLOGO INTERACTIVO 4 + PANEL + 4    */
/* ------------------------------------- */

.jas-services-catalog-section {
  padding: 112px 0;
  background:
    radial-gradient(circle at 12% 12%, rgba(27, 167, 216, 0.06) 0%, transparent 20%),
    linear-gradient(180deg, #F8FBFD 0%, #EEF5F9 100%);
}

.jas-services-catalog-header {
  max-width: 780px;
  margin-bottom: 44px;
}

.jas-services-showcase-layout--three {
  display: grid;
  grid-template-columns: 280px minmax(620px, 760px) 280px;
  justify-content: center;
  gap: 24px;
  align-items: start;
}

/* COLUMNAS LATERALES */

.jas-services-showcase-nav {
  display: grid;
  gap: 14px;
  position: sticky;
  top: 118px;
}

.jas-service-tab {
  position: relative;
  width: 100%;
  display: grid;
  grid-template-columns: 44px 52px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  padding: 18px 18px 18px 16px;
  border-radius: 22px;
  border: 1px solid rgba(15, 53, 84, 0.08);
  background: linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(244,250,253,0.93) 100%);
  box-shadow: 0 14px 34px rgba(15, 53, 84, 0.05);
  cursor: pointer;
  text-align: left;
  transition: all 0.28s ease;
}

.jas-service-tab::before {
  content: "";
  position: absolute;
  left: 0;
  top: 16px;
  bottom: 16px;
  width: 3px;
  border-radius: 999px;
  background: transparent;
  transition: all 0.28s ease;
}

.jas-service-tab:hover {
  transform: translateY(-2px);
  border-color: rgba(27, 167, 216, 0.18);
  box-shadow: 0 18px 40px rgba(15, 53, 84, 0.09);
}

.jas-service-tab.is-active {
  border-color: rgba(27, 167, 216, 0.22);
  background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(235,247,252,0.97) 100%);
  box-shadow: 0 18px 42px rgba(15, 53, 84, 0.10);
}

.jas-service-tab.is-active::before {
  background: linear-gradient(180deg, #1BA7D8 0%, #156B9A 100%);
}

.jas-service-tab-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 13px;
  background: rgba(21, 107, 154, 0.06);
  color: #156B9A;
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.jas-service-tab.is-active .jas-service-tab-number {
  background: linear-gradient(145deg, #0F3554 0%, #156B9A 100%);
  color: #FFFFFF;
  box-shadow: 0 12px 24px rgba(21, 107, 154, 0.18);
}

.jas-service-tab-icon {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, #0F3554 0%, #156B9A 100%);
  box-shadow: 0 12px 24px rgba(21, 107, 154, 0.16);
  color: #FFFFFF;
  font-size: 1.05rem;
  flex-shrink: 0;
}

.jas-service-tab-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.jas-service-tab-text strong {
  display: block;
  font-size: 1rem;
  line-height: 1.15;
  font-weight: 700;
  color: #17324D;
}

.jas-service-tab-text small {
  display: block;
  font-size: 0.92rem;
  line-height: 1.35;
  font-weight: 500;
  color: #6E8396;
}

/* PANEL CENTRAL */

.jas-services-showcase-panels {
  position: relative;
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  min-height: 620px;
}

.jas-service-panel {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-rows: 220px auto;
  border-radius: 28px;
  overflow: hidden;
  border: 1px solid rgba(15, 53, 84, 0.08);
  background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(241,248,251,0.95) 100%);
  box-shadow: 0 24px 56px rgba(15, 53, 84, 0.10);
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition:
    opacity 0.35s ease,
    transform 0.35s ease,
    visibility 0.35s ease;
  pointer-events: none;
}

.jas-service-panel.is-active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.jas-service-panel::after {
  content: "";
  position: absolute;
  top: 0;
  left: 34px;
  width: 100px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 100%);
  z-index: 3;
}

.jas-service-panel-media {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 20% 30%, rgba(27,167,216,0.20) 0%, transparent 28%),
    linear-gradient(135deg, #071826 0%, #0A2236 55%, #0E3554 100%);
}

.jas-service-panel-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(7, 24, 38, 0.22) 0%, rgba(15, 53, 84, 0.08) 48%, rgba(27, 167, 216, 0.06) 100%);
  pointer-events: none;
}

.jas-service-panel-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  transition: transform 0.45s ease;
}

.jas-service-panel.is-active .jas-service-panel-media img {
  transform: scale(1.02);
}

.jas-service-panel-content {
  padding: 28px 30px 24px;
}

.jas-service-panel-kicker {
  display: inline-block;
  margin-bottom: 10px;
  color: #156B9A;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.jas-service-panel-content h3 {
  margin: 0 0 14px;
  font-size: 1.62rem;
  line-height: 1.16;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0F3554;
}

.jas-service-panel-content p {
  margin: 0 0 18px;
  font-size: 1rem;
  line-height: 1.8;
  color: #5E7488;
}

.jas-service-panel-content ul {
  list-style: none;
  margin: 0 0 20px;
  padding: 0;
  display: grid;
  gap: 10px;
}

.jas-service-panel-content li {
  position: relative;
  padding-left: 22px;
  font-size: 0.94rem;
  line-height: 1.65;
  color: #4F6476;
}

.jas-service-panel-content li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #1BA7D8 0%, #156B9A 100%);
  box-shadow: 0 0 0 4px rgba(27, 167, 216, 0.08);
}

.jas-service-panel-foot {
  padding-top: 18px;
  border-top: 1px solid rgba(15, 53, 84, 0.08);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.65;
  color: #0F3554;
}

/* =========================================
   AJUSTE DE SIMETRÍA - CATÁLOGO SERVICIOS JAS
========================================= */

.jas-services-catalog-grid {
  display: grid;
  grid-template-columns: minmax(250px, 280px) minmax(520px, 680px) minmax(250px, 280px);
  gap: 28px;
  align-items: start;
  justify-content: center;
}

/* columnas laterales */
.jas-services-catalog-side {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

/* cards laterales más compactas */
.jas-service-item {
  min-height: 98px;
  padding: 18px 18px;
  border-radius: 28px;
  display: flex;
  align-items: center;
  gap: 16px;
}

/* número */
.jas-service-item-number {
  width: 50px;
  height: 50px;
  min-width: 50px;
  border-radius: 16px;
  font-size: 1.45rem;
}

/* icono */
.jas-service-item-icon {
  width: 58px;
  height: 58px;
  min-width: 58px;
  border-radius: 18px;
  font-size: 1.35rem;
}

/* texto lateral más compacto */
.jas-service-item-text {
  max-width: 145px;
}

.jas-service-item-text h4 {
  margin: 0;
  font-size: 1.02rem;
  line-height: 1.12;
  font-weight: 700;
  letter-spacing: -0.01em;
}

/* panel central más contenido */
.jas-service-detail {
  max-width: 680px;
  width: 100%;
  margin: 0 auto;
  border-radius: 34px;
  overflow: hidden;
}

/* imagen superior del panel */
.jas-service-detail-media {
  height: 250px;
}

/* contenido interno */
.jas-service-detail-body {
  padding: 34px 34px 30px;
}

.jas-service-detail-kicker {
  font-size: 0.95rem;
  letter-spacing: 0.18em;
}

.jas-service-detail-body h3 {
  font-size: 2.1rem;
  line-height: 1.08;
  margin-bottom: 18px;
}

.jas-service-detail-body p {
  font-size: 1rem;
  line-height: 1.8;
}

.jas-service-detail-body ul li {
  font-size: 1rem;
  line-height: 1.6;
}

.jas-service-detail-footer {
  font-size: 1rem;
  line-height: 1.5;
}

@media (max-width: 1399px) {
  .jas-services-catalog-grid {
    grid-template-columns: minmax(230px, 260px) minmax(470px, 620px) minmax(230px, 260px);
    gap: 22px;
  }

  .jas-service-item {
    min-height: 92px;
    padding: 16px 16px;
    gap: 14px;
  }

  .jas-service-item-number {
    width: 46px;
    height: 46px;
    min-width: 46px;
  }

  .jas-service-item-icon {
    width: 54px;
    height: 54px;
    min-width: 54px;
  }

  .jas-service-item-text {
    max-width: 132px;
  }

  .jas-service-item-text h4 {
    font-size: 0.97rem;
  }

  .jas-service-detail {
    max-width: 620px;
  }

  .jas-service-detail-media {
    height: 225px;
  }

  .jas-service-detail-body {
    padding: 30px 30px 26px;
  }

  .jas-service-detail-body h3 {
    font-size: 1.9rem;
  }
}

/* RESPONSIVE */

@media (max-width: 1399.98px) {
  .jas-services-showcase-layout--three {
    grid-template-columns: minmax(220px, 250px) minmax(0, 1fr) minmax(220px, 250px);
    gap: 22px;
  }

  .jas-service-tab {
    grid-template-columns: 40px 48px minmax(0, 1fr);
    gap: 12px;
    padding: 16px 16px 16px 14px;
  }

  .jas-service-tab-number {
    width: 36px;
    height: 36px;
    font-size: 0.8rem;
  }

  .jas-service-tab-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    font-size: 1rem;
  }

  .jas-service-tab-text strong {
    font-size: 0.94rem;
  }

  .jas-service-panel-content h3 {
    font-size: 1.48rem;
  }
}

@media (max-width: 1199.98px) {
  .jas-services-showcase-layout--three {
    grid-template-columns: 1fr minmax(0, 1.25fr);
    grid-template-areas:
      "left panel"
      "right panel";
    gap: 20px;
  }

  .jas-services-showcase-nav-left {
    grid-area: left;
    position: static;
  }

  .jas-services-showcase-nav-right {
    grid-area: right;
    position: static;
  }

  .jas-services-showcase-panels {
    grid-area: panel;
    min-height: 700px;
  }
}

@media (max-width: 991.98px) {
  .jas-services-catalog-section {
    padding: 88px 0;
  }

  .jas-services-showcase-layout--three {
    grid-template-columns: 1fr;
    grid-template-areas:
      "panel"
      "left"
      "right";
  }

  .jas-services-showcase-panels {
    min-height: auto;
  }

  .jas-service-panel {
    position: relative;
    inset: auto;
    display: none;
    grid-template-rows: 240px auto;
    border-radius: 26px;
  }

  .jas-service-panel.is-active {
    display: grid;
  }

  .jas-services-showcase-nav-left,
  .jas-services-showcase-nav-right {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  .jas-service-tab {
    min-height: 92px;
  }
}

@media (max-width: 767.98px) {
  .jas-services-showcase-nav-left,
  .jas-services-showcase-nav-right {
    grid-template-columns: 1fr;
  }

  .jas-service-panel {
    grid-template-rows: 210px auto;
  }

  .jas-service-panel-content {
    padding: 26px 20px 24px;
  }

  .jas-service-panel-content h3 {
    font-size: 1.3rem;
  }

  .jas-service-panel-content p,
  .jas-service-panel-content li,
  .jas-service-panel-foot {
    font-size: 0.93rem;
  }

  .jas-service-tab {
    border-radius: 18px;
  }
}

@media (max-width: 575.98px) {
  .jas-service-tab {
    grid-template-columns: 38px 44px minmax(0, 1fr);
    gap: 10px;
    padding: 14px 12px;
  }

  .jas-service-tab-number {
    width: 34px;
    height: 34px;
    border-radius: 12px;
  }

  .jas-service-tab-icon {
    width: 44px;
    height: 44px;
    border-radius: 13px;
    font-size: 0.96rem;
  }

  .jas-service-tab-text strong {
    font-size: 0.9rem;
  }

  .jas-service-panel {
    grid-template-rows: 190px auto;
  }
}

/* ------------------------------------- */
/* VALOR TRANSVERSAL                     */
/* ------------------------------------- */

.jas-services-value-section {
  padding: 110px 0;
  background: #FFFFFF;
}

.jas-services-value-header {
  max-width: 760px;
  margin-bottom: 42px;
}

.jas-services-value-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
}

.jas-services-value-card {
  position: relative;
  padding: 30px 24px;
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.95) 0%, rgba(243,249,252,0.92) 100%);
  border: 1px solid rgba(15, 53, 84, 0.06);
  box-shadow: 0 16px 38px rgba(15, 53, 84, 0.06);
  transition: all 0.3s ease;
}

.jas-services-value-card:hover {
  transform: translateY(-3px);
  border-color: rgba(27, 167, 216, 0.18);
  box-shadow: 0 20px 42px rgba(15, 53, 84, 0.10);
}

.jas-services-value-icon {
  width: 56px;
  height: 56px;
  margin-bottom: 16px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, #0F3554 0%, #156B9A 100%);
  box-shadow: 0 14px 28px rgba(21, 107, 154, 0.16);
}

.jas-services-value-icon i {
  color: #FFFFFF;
  font-size: 1.08rem;
}

.jas-services-value-card h3 {
  margin: 0 0 10px;
  font-size: 1.08rem;
  line-height: 1.3;
  font-weight: 800;
  color: #17324D;
}

.jas-services-value-card p {
  margin: 0;
  font-size: 0.93rem;
  line-height: 1.72;
  color: #5E7488;
}

/* ------------------------------------- */
/* ADAPTABILIDAD                         */
/* ------------------------------------- */

.jas-services-adapt-section {
  padding: 108px 0;
  background:
    radial-gradient(circle at 84% 14%, rgba(27, 167, 216, 0.08) 0%, transparent 22%),
    linear-gradient(180deg, #F8FBFD 0%, #EEF5F9 100%);
}

.jas-services-adapt-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.72fr);
  gap: 40px;
  align-items: start;
}

.jas-services-adapt-copy {
  max-width: 760px;
}

.jas-services-adapt-copy .jas-services-section-text + .jas-services-section-text {
  margin-top: 20px;
}

.jas-services-adapt-side {
  display: flex;
  justify-content: flex-end;
}

.jas-services-adapt-card {
  position: relative;
  width: 100%;
  max-width: 370px;
  padding: 30px 24px;
  border-radius: 24px;
  background: linear-gradient(180deg, #0A2236 0%, #0E2D46 100%);
  border: 1px solid rgba(123, 220, 255, 0.10);
  box-shadow: 0 20px 44px rgba(6, 22, 35, 0.16);
  overflow: hidden;
}

.jas-services-adapt-card::before {
  content: "";
  position: absolute;
  inset: auto -50px -50px auto;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(34,184,240,0.18) 0%, rgba(34,184,240,0) 70%);
  pointer-events: none;
}

.jas-services-adapt-card-icon {
  position: relative;
  z-index: 2;
  width: 58px;
  height: 58px;
  margin-bottom: 16px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(123, 220, 255, 0.14);
  backdrop-filter: blur(10px);
}

.jas-services-adapt-card-icon i {
  color: #7BDCFF;
  font-size: 1.12rem;
}

.jas-services-adapt-card h3 {
  position: relative;
  z-index: 2;
  margin: 0 0 12px;
  font-size: 1.16rem;
  line-height: 1.3;
  font-weight: 800;
  color: #FFFFFF;
}

.jas-services-adapt-card p {
  position: relative;
  z-index: 2;
  margin: 0;
  font-size: 0.94rem;
  line-height: 1.74;
  color: rgba(226, 239, 246, 0.78);
}

/* ------------------------------------- */
/* CTA FINAL                             */
/* ------------------------------------- */

.jas-services-cta-section {
  position: relative;
  padding: 96px 0 124px;
  background:
    radial-gradient(circle at 14% 22%, rgba(27, 167, 216, 0.08) 0%, transparent 24%),
    radial-gradient(circle at 84% 70%, rgba(88, 215, 255, 0.10) 0%, transparent 26%),
    linear-gradient(180deg, #FFFFFF 0%, #F4FAFD 100%);
}

.jas-services-cta-glow {
  position: absolute;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  filter: blur(34px);
  pointer-events: none;
  opacity: 0.42;
}

.jas-services-cta-glow-left {
  left: -80px;
  top: 28px;
  background: radial-gradient(circle, rgba(27,167,216,0.22) 0%, rgba(27,167,216,0) 72%);
}

.jas-services-cta-glow-right {
  right: -80px;
  bottom: 20px;
  background: radial-gradient(circle, rgba(88,215,255,0.20) 0%, rgba(88,215,255,0) 72%);
}

.jas-services-cta-inner {
  position: relative;
  max-width: 1040px;
  margin: 0 auto;
  padding: 48px 52px;
  border-radius: 32px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(238,246,250,0.95) 100%);
  border: 1px solid rgba(15, 53, 84, 0.08);
  box-shadow:
    0 24px 60px rgba(15, 53, 84, 0.10),
    inset 0 1px 0 rgba(255,255,255,0.92);
  text-align: center;
  overflow: hidden;
}

.jas-services-cta-inner::before {
  content: "";
  position: absolute;
  inset: 22px;
  border-radius: 24px;
  border: 1px dashed rgba(21, 107, 154, 0.10);
  pointer-events: none;
}

.jas-services-cta-inner > * {
  position: relative;
  z-index: 2;
}

.jas-services-cta-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  color: #156B9A;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.jas-services-cta-label::before,
.jas-services-cta-label::after {
  content: "";
  width: 36px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 100%);
}

.jas-services-cta-title {
  margin: 0 0 16px;
  font-size: clamp(1.9rem, 3vw, 3rem);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #0F3554;
}

.jas-services-cta-text {
  max-width: 740px;
  margin: 0 auto 26px;
  font-size: 1rem;
  line-height: 1.8;
  color: #5E7488;
}

.jas-services-cta-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 20px;
}

.jas-services-cta-btn-primary,
.jas-services-cta-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 22px;
  border-radius: 14px;
  font-size: 0.94rem;
  font-weight: 700;
  transition: all 0.3s ease;
}

.jas-services-cta-btn-primary {
  background: linear-gradient(135deg, #156B9A 0%, #1BA7D8 100%);
  border: 1px solid rgba(21, 107, 154, 0.18);
  color: #FFFFFF !important;
  box-shadow: 0 16px 32px rgba(21, 107, 154, 0.22);
}

.jas-services-cta-btn-primary:hover {
  transform: translateY(-2px);
  color: #FFFFFF !important;
}

.jas-services-cta-btn-secondary {
  background: #FFFFFF;
  border: 1px solid rgba(15, 53, 84, 0.14);
  color: #0F3554 !important;
  box-shadow: 0 10px 24px rgba(15, 53, 84, 0.06);
}

.jas-services-cta-btn-secondary:hover {
  background: #0F3554;
  color: #FFFFFF !important;
  transform: translateY(-2px);
}

.jas-services-cta-meta {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
}

.jas-services-cta-meta span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(21, 107, 154, 0.05);
  border: 1px solid rgba(21, 107, 154, 0.08);
  color: #4F6476;
  font-size: 0.84rem;
  font-weight: 600;
}

.jas-services-cta-meta i {
  color: #156B9A;
}

/* ------------------------------------- */
/* RESPONSIVE                            */
/* ------------------------------------- */

@media (max-width: 1199.98px) {
  .jas-services-hero-title {
    font-size: clamp(2.5rem, 5vw, 4.6rem);
  }

  .jas-services-value-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991.98px) {
  .jas-services-hero-section {
    min-height: auto;
    padding: 148px 0 80px;
  }

  .jas-services-hero-inner,
  .jas-services-intro-main,
  .jas-services-catalog-header,
  .jas-services-value-header,
  .jas-services-adapt-copy {
    max-width: 100%;
  }

  .jas-services-intro-grid,
  .jas-services-adapt-inner {
    grid-template-columns: 1fr;
  }

  .jas-services-intro-side,
  .jas-services-adapt-side {
    justify-content: flex-start;
  }

  .jas-services-intro-card,
  .jas-services-adapt-card {
    max-width: 100%;
  }

  .jas-services-catalog-grid,
  .jas-services-value-grid {
    grid-template-columns: 1fr;
  }

  .jas-services-intro-section,
  .jas-services-catalog-section,
  .jas-services-value-section,
  .jas-services-adapt-section {
    padding: 88px 0;
  }

  .jas-services-cta-inner {
    padding: 40px 30px;
  }
}

@media (max-width: 767.98px) {
  .jas-services-hero-section {
    padding: 122px 0 64px;
    min-height: auto;
  }

  .jas-services-hero-title {
    max-width: 100%;
    font-size: clamp(2rem, 8vw, 2.9rem);
    line-height: 1.02;
  }

  .jas-services-hero-description,
  .jas-services-section-text,
  .jas-services-section-intro,
  .jas-services-cta-text {
    font-size: 0.95rem;
    line-height: 1.75;
  }

  .jas-services-hero-actions,
  .jas-services-cta-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .jas-services-hero-btn-primary,
  .jas-services-hero-btn-secondary,
  .jas-services-cta-btn-primary,
  .jas-services-cta-btn-secondary {
    width: 100%;
  }

  .jas-service-detail-card,
  .jas-services-value-card,
  .jas-services-intro-card,
  .jas-services-adapt-card {
    padding: 26px 20px;
    border-radius: 22px;
  }

  .jas-services-cta-section {
    padding: 78px 0 96px;
  }

  .jas-services-cta-inner {
    padding: 32px 20px;
    border-radius: 24px;
  }

  .jas-services-cta-meta span {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 375px) {
  .jas-services-hero-title,
  .jas-services-section-title,
  .jas-services-cta-title {
    font-size: 1.78rem;
  }

  .jas-service-detail-title,
  .jas-services-value-card h3,
  .jas-services-intro-card h3,
  .jas-services-adapt-card h3 {
    font-size: 1.05rem;
  }
}

/* ============================================== */
/* NAVBAR REVEAL ON HOVER - SOLO DESKTOP          */
/* ============================================== */

.page-services .jas-navbar:not(.scrolled) .nav-link {
  color: #EDF4F8 !important;
}

.page-services .jas-navbar:not(.scrolled) .nav-link:hover,
.page-services .jas-navbar:not(.scrolled) .nav-link:focus {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.08);
}

/* ===================================================*/
/* CAMBIO DE LOGO SEGÚN EL FONDO DEL IMAGEN DEL HERO */
/* ===================================================*/
.page-services .jas-navbar:not(.scrolled) .jas-brand img {
  content: url("../images/logo/jas-logo-horizontal-light.png");
}


/* =========================================
   HOVER MÁS VISIBLE PARA CARDS LATERALES
   ESTILO JAS - PREMIUM / ENERGY REVEAL
========================================= */

.jas-premium-card {
  position: relative;
  overflow: hidden;
  border-radius: 32px;
  transition:
    transform 0.42s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.42s cubic-bezier(0.22, 1, 0.36, 1),
    border-color 0.42s ease,
    background-color 0.42s ease;
  will-change: transform, box-shadow;
}

/* masa luminosa */
.jas-premium-card::before {
  content: "";
  position: absolute;
  top: -90px;
  left: -90px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background:
    radial-gradient(circle,
      rgba(27, 167, 216, 0.30) 0%,
      rgba(21, 107, 154, 0.18) 38%,
      rgba(15, 53, 84, 0.00) 72%);
  transform: scale(0.75);
  opacity: 0;
  transition:
    transform 0.52s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.42s ease;
  pointer-events: none;
}

/* línea inferior */
.jas-premium-card::after {
  content: "";
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 0;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 55%, transparent 100%);
  transform: scaleX(0.15);
  transform-origin: left center;
  opacity: 0;
  transition:
    transform 0.42s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.32s ease;
  pointer-events: none;
}

.jas-premium-card:hover,
.jas-premium-card:focus-within {
  transform: translateY(-10px) scale(1.015);
  box-shadow: 0 24px 48px rgba(15, 53, 84, 0.18);
}

.jas-premium-card:hover::before,
.jas-premium-card:focus-within::before {
  transform: scale(1.28);
  opacity: 1;
}

.jas-premium-card:hover::after,
.jas-premium-card:focus-within::after {
  transform: scaleX(1);
  opacity: 1;
}

/* ícono */
.jas-premium-card-icon {
  position: relative;
  z-index: 2;
  transition:
    transform 0.42s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.42s ease,
    background 0.42s ease;
}

.jas-premium-card:hover .jas-premium-card-icon,
.jas-premium-card:focus-within .jas-premium-card-icon {
  transform: translateY(-4px) scale(1.08) rotate(-4deg);
  box-shadow: 0 16px 28px rgba(27, 167, 216, 0.22);
}

/* textos */
.jas-premium-card h3,
.jas-premium-card h4,
.jas-premium-card p {
  position: relative;
  z-index: 2;
  transition:
    transform 0.36s ease,
    color 0.36s ease,
    opacity 0.36s ease;
}

.jas-premium-card:hover h3,
.jas-premium-card:hover h4,
.jas-premium-card:focus-within h3,
.jas-premium-card:focus-within h4 {
  transform: translateY(-2px);
}

.jas-premium-card:hover p,
.jas-premium-card:focus-within p {
  transform: translateY(-1px);
}

/* versión clara */
.jas-premium-card.jas-premium-card--light:hover,
.jas-premium-card.jas-premium-card--light:focus-within {
  border-color: rgba(27, 167, 216, 0.25);
  background: linear-gradient(180deg, #f8fbfd 0%, #eef5f9 100%);
}

/* versión oscura */
.jas-premium-card.jas-premium-card--dark::before {
  background:
    radial-gradient(circle,
      rgba(27, 167, 216, 0.34) 0%,
      rgba(21, 107, 154, 0.20) 36%,
      rgba(15, 53, 84, 0.02) 72%);
}

.jas-premium-card.jas-premium-card--dark:hover,
.jas-premium-card.jas-premium-card--dark:focus-within {
  box-shadow: 0 26px 52px rgba(8, 26, 43, 0.28);
}

/* accesibilidad */
@media (prefers-reduced-motion: reduce) {
  .jas-premium-card,
  .jas-premium-card::before,
  .jas-premium-card::after,
  .jas-premium-card-icon,
  .jas-premium-card h3,
  .jas-premium-card h4,
  .jas-premium-card p {
    transition: none !important;
  }

  .jas-premium-card:hover,
  .jas-premium-card:focus-within {
    transform: none !important;
  }
}
/* =========================================================
   CTA FINAL FULL WIDTH - SERVICIOS JAS
   REEMPLAZA EL BLOQUE ANTERIOR
========================================================= */

.jas-services-cta-section {
  position: relative;
  overflow: hidden;
  padding: 80px 0 80px;
  background:
    #FFFFFF;
}

.jas-services-cta-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 8% 50%, rgba(27, 167, 216, 0.10), transparent 26%),
    radial-gradient(circle at 92% 52%, rgba(27, 167, 216, 0.10), transparent 26%);
  pointer-events: none;
}

.jas-services-cta-wrap {
  position: relative;
  z-index: 2;
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
}

.jas-services-cta-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-bottom: 26px;
  font-size: 0.98rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #1BA7D8;
}

.jas-services-cta-label::before,
.jas-services-cta-label::after {
  content: "";
  width: 56px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 100%);
}

.jas-services-cta-title {
  margin: 0 auto 26px;
  max-width: 980px;
  font-size: 46.08px;
  line-height: 0.98;
  letter-spacing: -0.03em;
  font-weight: 800;
  color: #17324D;
}

.jas-services-cta-text {
  max-width: 860px;
  margin: 0 auto 42px;
  font-size: 1.28rem;
  line-height: 1.75;
  color: #5E7488;
}

.jas-services-cta-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  margin-bottom: 34px;
}

.jas-btn-primary,
.jas-btn-secondary {
  min-width: 280px;
  padding: 18px 30px;
  border-radius: 18px;
  font-size: 1.15rem;
  font-weight: 700;
  text-decoration: none;
  text-align: center;
  transition: all 0.30s ease;
}

.jas-btn-primary {
  color: #ffffff;
  background: linear-gradient(90deg, #0F3554 0%, #1BA7D8 100%);
  box-shadow: 0 14px 28px rgba(15, 53, 84, 0.16);
}

.jas-btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 34px rgba(15, 53, 84, 0.22);
}

.jas-btn-secondary {
  color: #17324D;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid rgba(21, 107, 154, 0.12);
  box-shadow: 0 10px 22px rgba(15, 53, 84, 0.05);
}

.jas-btn-secondary:hover {
  transform: translateY(-3px);
  background: #ffffff;
  box-shadow: 0 16px 28px rgba(15, 53, 84, 0.10);
}

.jas-services-cta-points {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 28px;
  flex-wrap: wrap;
}

.jas-services-cta-points span {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 1.02rem;
  font-weight: 600;
  color: #5E7488;
}

.jas-services-cta-points i {
  font-size: 1rem;
  color: #1BA7D8;
}

/* =========================
   RESPONSIVE
========================= */

@media (max-width: 991.98px) {
  .jas-services-cta-section {
    padding: 96px 0 96px;
  }

  .jas-services-cta-title {
    font-size: clamp(2.4rem, 7vw, 3.6rem);
    line-height: 1.02;
  }

  .jas-services-cta-text {
    font-size: 1.12rem;
    line-height: 1.7;
  }

  .jas-btn-primary,
  .jas-btn-secondary {
    min-width: 240px;
    font-size: 1.05rem;
    padding: 16px 24px;
  }
}

@media (max-width: 575.98px) {
  .jas-services-cta-section {
    padding: 78px 0 82px;
  }

  .jas-services-cta-label {
    gap: 12px;
    margin-bottom: 20px;
    font-size: 0.88rem;
    letter-spacing: 0.14em;
  }

  .jas-services-cta-label::before,
  .jas-services-cta-label::after {
    width: 38px;
  }

  .jas-services-cta-title {
    font-size: 2.2rem;
    line-height: 1.04;
    margin-bottom: 20px;
  }

  .jas-services-cta-text {
    font-size: 1rem;
    line-height: 1.75;
    margin-bottom: 30px;
  }

  .jas-services-cta-actions {
    gap: 14px;
    margin-bottom: 28px;
  }

  .jas-btn-primary,
  .jas-btn-secondary {
    width: 100%;
    min-width: 100%;
    padding: 15px 20px;
    font-size: 1rem;
  }

  .jas-services-cta-points {
    gap: 14px;
    flex-direction: column;
  }

  .jas-services-cta-points span {
    justify-content: center;
    text-align: center;
    font-size: 0.96rem;
  }
}

/* =========================================================
   SOLUCIONES - JAS SOLUTIONS
   NUEVA VERSIÓN DIFERENCIADA DE SERVICIOS
========================================================= */

.page-solutions .jas-solutions-hero-section,
.page-solutions .jas-solutions-challenges-section,
.page-solutions .jas-solutions-architecture-section,
.page-solutions .jas-solutions-scenarios-section,
.page-solutions .jas-solutions-route-section,
.page-solutions .jas-solutions-cta-section {
  position: relative;
  overflow: hidden;
}

/* =========================================================
   TEXTOS BASE
========================================================= */

.page-solutions .jas-solutions-section-heading {
  max-width: 980px;
  margin: 0 auto 48px;
}

.page-solutions .jas-solutions-section-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-bottom: 18px;
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #1BA7D8;
}

.page-solutions .jas-solutions-section-label::before,
.page-solutions .jas-solutions-section-label::after {
  content: "";
  width: 38px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 100%);
}

.page-solutions .jas-solutions-section-title {
  margin: 0 0 20px;
  font-size: clamp(2.2rem, 4vw, 3.7rem);
  line-height: 1.02;
  font-weight: 800;
  letter-spacing: -0.035em;
  color: #17324D;
}

.page-solutions .jas-solutions-section-intro,
.page-solutions .jas-solutions-section-text {
  margin: 0;
  font-size: 1.06rem;
  line-height: 1.85;
  color: #5E7488;
}

/* =========================================================
   BOTONES
========================================================= */

.page-solutions .jas-btn-primary,
.page-solutions .jas-btn-secondary,
.page-solutions .jas-solutions-hero-btn-primary,
.page-solutions .jas-solutions-hero-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 16px 28px;
  min-width: 220px;
  border-radius: 18px;
  font-size: 1rem;
  font-weight: 700;
  text-decoration: none;
  transition: all 0.3s ease;
}

.page-solutions .jas-btn-primary,
.page-solutions .jas-solutions-hero-btn-primary {
  color: #ffffff;
  background: linear-gradient(90deg, #0F3554 0%, #1BA7D8 100%);
  border: 1px solid transparent;
  box-shadow: 0 16px 32px rgba(15, 53, 84, 0.18);
}

.page-solutions .jas-btn-primary:hover,
.page-solutions .jas-solutions-hero-btn-primary:hover {
  transform: translateY(-3px);
  color: #ffffff;
  box-shadow: 0 22px 38px rgba(15, 53, 84, 0.24);
}

.page-solutions .jas-btn-secondary,
.page-solutions .jas-solutions-hero-btn-secondary {
  color: #17324D;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(21, 107, 154, 0.14);
  box-shadow: 0 12px 24px rgba(15, 53, 84, 0.06);
  backdrop-filter: blur(10px);
}

.page-solutions .jas-btn-secondary:hover,
.page-solutions .jas-solutions-hero-btn-secondary:hover {
  transform: translateY(-3px);
  color: #17324D;
  background: #ffffff;
  box-shadow: 0 18px 30px rgba(15, 53, 84, 0.10);
}

/* =========================================================
   HERO
========================================================= */

.page-solutions .jas-solutions-hero-section {
  min-height: 80vh;
  display: flex;
  align-items: center;
  background: #0F3554;
  padding: 75px 0 5px;
}

.page-solutions .jas-solutions-hero-media,
.page-solutions .jas-solutions-hero-overlay {
  position: absolute;
  inset: 0;
}

.page-solutions .jas-solutions-hero-bg-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
  display: block;
  margin-bottom: 3px;
}

.page-solutions .jas-solutions-hero-overlay {
  background:
    linear-gradient(110deg, rgba(7, 22, 36, 0.88) 0%, rgba(7, 22, 36, 0.74) 34%, rgba(7, 22, 36, 0.34) 68%, rgba(7, 22, 36, 0.20) 100%),
    radial-gradient(circle at 75% 30%, rgba(27, 167, 216, 0.14), transparent 28%),
    radial-gradient(circle at 88% 72%, rgba(27, 167, 216, 0.10), transparent 24%);
  z-index: 1;
}

.page-solutions .jas-solutions-hero-container {
  position: relative;
  z-index: 2;
}

.page-solutions .jas-solutions-hero-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(420px, 520px);
  gap: 42px;
  align-items: center;
  min-height: 90vh;

}

.page-solutions .jas-solutions-hero-copy {
  max-width: 760px;
}

.page-solutions .jas-solutions-hero-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 22px;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #9FE5F8;
}

.page-solutions .jas-solutions-hero-label::before {
  content: "";
  width: 44px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #9FE5F8 100%);
}

.page-solutions .jas-solutions-hero-title {
  margin: 0 0 24px;
  font-size: 58.5px;
  line-height: 0.95;
  font-weight: 800;
  letter-spacing: -0.05em;
  color: #EDF4F8;
}

.page-solutions .jas-solutions-hero-description {
  max-width: 690px;
  margin: 0 0 34px;
  font-size: 1.12rem;
  line-height: 1.85;
  color: rgba(237, 244, 248, 0.86);
}

.page-solutions .jas-solutions-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 30px;
}

/* =====================================
   BLOQUES FLOTANTES HERO
===================================== */

.page-solutions .jas-solutions-hero-visual {
  position: relative;
}

.page-solutions .jas-solutions-floating-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  position: relative;
  margin-bottom: 15px;
}

.page-solutions .jas-solutions-floating-card {
  position: relative;
  padding: 20px 18px;
  min-height: 118px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(14px);
  box-shadow: 0 20px 34px rgba(7, 22, 36, 0.18);
  color: #EDF4F8;
}

.page-solutions .jas-solutions-floating-card i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  margin-bottom: 14px;
  border-radius: 16px;
  background: linear-gradient(180deg, #1BA7D8 0%, #156B9A 100%);
  font-size: 1.15rem;
  color: #ffffff;
  box-shadow: 0 12px 24px rgba(9, 31, 48, 0.22);
}

.page-solutions .jas-solutions-floating-card span {
  display: block;
  font-size: 1rem;
  line-height: 1.25;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.page-solutions .jas-solutions-floating-card--lg {
  grid-column: span 2;
  min-height: 120px;
  padding: 22px 22px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0.10) 100%);
}

.page-solutions .jas-solutions-floating-kicker {
  display: inline-block;
  margin-bottom: 12px;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #9FE5F8;
}

.page-solutions .jas-solutions-floating-card--lg h3 {
  margin: 0 0 12px;
  font-size: 1.52rem;
  line-height: 1.10;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #ffffff;
}

.page-solutions .jas-solutions-floating-card--lg p {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.7;
  color: rgba(237, 244, 248, 0.84);
}

/* =========================================================
   DESAFÍOS
========================================================= */

.page-solutions .jas-solutions-challenges-section {
  padding: 110px 0 90px;
  background:
    linear-gradient(180deg, #F7FBFD 0%, #FFFFFF 34%, #F7FBFD 100%);
}

.page-solutions .jas-solutions-challenges-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.page-solutions .jas-solutions-challenge-card {
  position: relative;
  padding: 30px 26px;
  min-height: 240px;
  border-radius: 28px;
  background: #ffffff;
  border: 1px solid rgba(21, 107, 154, 0.08);
  box-shadow: 0 18px 36px rgba(15, 53, 84, 0.06);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.page-solutions .jas-solutions-challenge-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 42px rgba(15, 53, 84, 0.11);
}

.page-solutions .jas-solutions-challenge-card--wide {
  grid-column: span 2;
}

.page-solutions .jas-solutions-challenge-card--accent {
  background: linear-gradient(180deg, #EDF6FA 0%, #F8FBFD 100%);
}

.page-solutions .jas-solutions-challenge-icon {
  width: 62px;
  height: 62px;
  margin-bottom: 18px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #156B9A 0%, #0F3554 100%);
  color: #ffffff;
  font-size: 1.3rem;
  box-shadow: 0 14px 26px rgba(15, 53, 84, 0.14);
}

.page-solutions .jas-solutions-challenge-card h3 {
  margin: 0 0 14px;
  font-size: 1.28rem;
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: -0.025em;
  color: #17324D;
}

.page-solutions .jas-solutions-challenge-card p {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.76;
  color: #5E7488;
}

/* =========================================================
   ARQUITECTURA DE SOLUCIÓN
========================================================= */

.page-solutions .jas-solutions-architecture-section {
  padding: 100px 0 110px;
  background: #ffffff;
}

.page-solutions .jas-solutions-architecture-core {
  position: relative;
  max-width: 1080px;
  min-height: 760px;
  margin: 0 auto;
}

.page-solutions .jas-solutions-architecture-core::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 540px;
  height: 540px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(27, 167, 216, 0.10) 0%, rgba(27, 167, 216, 0.04) 42%, transparent 68%);
  pointer-events: none;
  z-index: 0;
}

/* SVG DE LÍNEAS */
.page-solutions .jas-solutions-architecture-lines {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
  overflow: visible;
}

.page-solutions .jas-solutions-architecture-lines path {
  filter: drop-shadow(0 0 6px rgba(27, 167, 216, 0.18));
  animation: jasFlowLine 7s linear infinite;
}

.page-solutions .jas-solutions-architecture-lines circle {
  filter: drop-shadow(0 0 8px rgba(27, 167, 216, 0.35));
}

.page-solutions .jas-solutions-core-center {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 360px;
  min-height: 360px;
  transform: translate(-50%, -50%);
  padding: 46px 38px;
  border-radius: 50%;
  background: linear-gradient(180deg, #16324F 0%, #0F3554 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-shadow: 0 28px 54px rgba(8, 26, 43, 0.22);
  z-index: 2;
}

.page-solutions .jas-solutions-core-label {
  display: inline-block;
  margin-bottom: 12px;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #9FE5F8;
}

.page-solutions .jas-solutions-core-center h3 {
  margin: 0 0 14px;
  font-size: 2rem;
  line-height: 1.02;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #EDF4F8;
}

.page-solutions .jas-solutions-core-center p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.75;
  color: rgba(237, 244, 248, 0.82);
}

.page-solutions .jas-solutions-core-node {
  position: absolute;
  width: 166px;
  min-height: 166px;
  padding: 20px 16px;
  border-radius: 24px;
  background: #ffffff;
  border: 1px solid rgba(21, 107, 154, 0.08);
  box-shadow: 0 18px 36px rgba(15, 53, 84, 0.08);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 10px;
  z-index: 3;
}

.page-solutions .jas-solutions-core-node i {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #1BA7D8 0%, #156B9A 100%);
  color: #ffffff;
  font-size: 1.18rem;
  box-shadow: 0 12px 24px rgba(15, 53, 84, 0.12);
}

.page-solutions .jas-solutions-core-node span {
  font-size: 0.98rem;
  line-height: 1.22;
  font-weight: 700;
  color: #17324D;
}

/* POSICIONES */
.page-solutions .jas-solutions-core-node--1 { top: 0%; left: 43%; }
.page-solutions .jas-solutions-core-node--2 { top: 15%; right: 14%; }
.page-solutions .jas-solutions-core-node--3 { top: 40.2%; right: 0; }
.page-solutions .jas-solutions-core-node--4 { bottom: 12%; right: 13%; }
.page-solutions .jas-solutions-core-node--5 { bottom: 0%; left: 43%; }
.page-solutions .jas-solutions-core-node--6 { bottom: 13%; left: 15%; }
.page-solutions .jas-solutions-core-node--7 { top: 40.2%; left: 0; }
.page-solutions .jas-solutions-core-node--8 { top: 15%; left: 15%; }

@keyframes jasFlowLine {
  from {
    stroke-dashoffset: 0;
  }
  to {
    stroke-dashoffset: -72;
  }
}

@media (max-width: 991.98px) {
  .page-solutions .jas-solutions-architecture-lines {
    display: none;
  }
}

/* =========================================================
   ESCENARIOS
========================================================= */

.page-solutions .jas-solutions-scenarios-section {
  background: #F8FBFD;
}

.page-solutions .jas-solutions-scenario-row {
  padding: 96px 0;
}

.page-solutions .jas-solutions-scenario-row--alt {
  background: #ffffff;
}

.page-solutions .jas-solutions-scenario-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(360px, 460px);
  gap: 46px;
  align-items: center;
}

.page-solutions .jas-solutions-scenario-grid--reverse {
  grid-template-columns: minmax(360px, 460px) minmax(0, 1.2fr);
}

.page-solutions .jas-solutions-scenario-grid--reverse .jas-solutions-scenario-copy {
  order: 2;
}

.page-solutions .jas-solutions-scenario-grid--reverse .jas-solutions-scenario-visual {
  order: 1;
}

.page-solutions .jas-solutions-scenario-copy {
  max-width: 760px;
}

.page-solutions .jas-solutions-scenario-list {
  margin: 26px 0 0;
  padding: 0;
  list-style: none;
}

.page-solutions .jas-solutions-scenario-list li {
  position: relative;
  padding-left: 28px;
  margin-bottom: 14px;
  font-size: 1rem;
  line-height: 1.7;
  color: #5E7488;
}

.page-solutions .jas-solutions-scenario-list li::before {
  content: "";
  position: absolute;
  top: 11px;
  left: 0;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: linear-gradient(180deg, #1BA7D8 0%, #156B9A 100%);
  box-shadow: 0 0 0 5px rgba(27, 167, 216, 0.10);
}

.page-solutions .jas-solutions-scenario-card {
  position: relative;
  padding: 38px 32px;
  border-radius: 30px;
  background: linear-gradient(180deg, #F9FCFE 0%, #EDF5F9 100%);
  border: 1px solid rgba(21, 107, 154, 0.08);
  box-shadow: 0 18px 36px rgba(15, 53, 84, 0.08);
}

.page-solutions .jas-solutions-scenario-card--dark {
  background: linear-gradient(180deg, #16324F 0%, #0F3554 100%);
  border-color: rgba(255, 255, 255, 0.08);
  box-shadow: 0 22px 42px rgba(8, 26, 43, 0.18);
}

.page-solutions .jas-solutions-scenario-card-kicker {
  display: inline-block;
  margin-bottom: 14px;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #1BA7D8;
}

.page-solutions .jas-solutions-scenario-card--dark .jas-solutions-scenario-card-kicker {
  color: #9FE5F8;
}

.page-solutions .jas-solutions-scenario-card h3 {
  margin: 0 0 14px;
  font-size: 1.48rem;
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #17324D;
}

.page-solutions .jas-solutions-scenario-card p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.78;
  color: #5E7488;
}

.page-solutions .jas-solutions-scenario-card--dark h3 {
  color: #EDF4F8;
}

.page-solutions .jas-solutions-scenario-card--dark p {
  color: rgba(237, 244, 248, 0.82);
}

/* =========================================================
   RUTA
========================================================= */

.page-solutions .jas-solutions-route-section {
  padding: 108px 0 110px;
  background: #EEF5F9;
}

.page-solutions .jas-solutions-route-line {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 22px;
}

.page-solutions .jas-solutions-route-line::before {
  content: "";
  position: absolute;
  top: 34px;
  left: 8%;
  right: 8%;
  height: 2px;
  background: linear-gradient(90deg, rgba(27, 167, 216, 0.35) 0%, rgba(21, 107, 154, 0.35) 100%);
  z-index: 0;
}

.page-solutions .jas-solutions-route-step {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 0 10px;
}

.page-solutions .jas-solutions-route-number {
  width: 70px;
  height: 70px;
  margin: 0 auto 20px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #156B9A 0%, #0F3554 100%);
  color: #ffffff;
  font-size: 1.02rem;
  font-weight: 800;
  box-shadow: 0 16px 30px rgba(15, 53, 84, 0.16);
}

.page-solutions .jas-solutions-route-step h3 {
  margin: 0 0 12px;
  font-size: 1.12rem;
  line-height: 1.16;
  font-weight: 800;
  color: #17324D;
  letter-spacing: -0.02em;
}

.page-solutions .jas-solutions-route-step p {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.7;
  color: #5E7488;
}

/* =========================================================
   CTA FINAL
========================================================= */

.page-solutions .jas-solutions-cta-section {
  padding: 80px 0 80px;
  background:#FFFFFF;
}

.page-solutions .jas-solutions-cta-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 10% 50%, rgba(27, 167, 216, 0.10), transparent 26%),
    radial-gradient(circle at 90% 50%, rgba(27, 167, 216, 0.10), transparent 26%);
  pointer-events: none;
}

.page-solutions .jas-solutions-cta-wrap {
  position: relative;
  z-index: 2;
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
}

.page-solutions .jas-solutions-cta-label {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 24px;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #1BA7D8;
}

.page-solutions .jas-solutions-cta-label::before,
.page-solutions .jas-solutions-cta-label::after {
  content: "";
  width: 54px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 100%);
}

.page-solutions .jas-solutions-cta-title {
  margin: 0 auto 22px;
  max-width: 980px;
  font-size: 46.08px;
  line-height: 0.98;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: #17324D;
}

.page-solutions .jas-solutions-cta-text {
  max-width: 820px;
  margin: 0 auto 36px;
  font-size: 1.14rem;
  line-height: 1.82;
  color: #5E7488;
}

.page-solutions .jas-solutions-cta-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 18px;
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width: 1399.98px) {
  .page-solutions .jas-solutions-architecture-core {
    max-width: 1000px;
  }

  .page-solutions .jas-solutions-core-node {
    width: 154px;
    min-height: 154px;
  }
}

@media (max-width: 1199.98px) {
  .page-solutions .jas-solutions-hero-layout {
    grid-template-columns: 1fr;
    gap: 36px;
    min-height: auto;
  }

  .page-solutions .jas-solutions-hero-copy {
    max-width: 860px;
  }

  .page-solutions .jas-solutions-challenges-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .page-solutions .jas-solutions-challenge-card--wide {
    grid-column: span 2;
  }

  .page-solutions .jas-solutions-scenario-grid,
  .page-solutions .jas-solutions-scenario-grid--reverse {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .page-solutions .jas-solutions-scenario-grid--reverse .jas-solutions-scenario-copy,
  .page-solutions .jas-solutions-scenario-grid--reverse .jas-solutions-scenario-visual {
    order: initial;
  }

  .page-solutions .jas-solutions-route-line {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    row-gap: 34px;
  }

  .page-solutions .jas-solutions-route-line::before {
    display: none;
  }
}

@media (max-width: 991.98px) {
  .page-solutions .jas-solutions-hero-layout {
    padding: 136px 0 86px;
  }

  .page-solutions .jas-solutions-hero-title {
    font-size: clamp(2.4rem, 7vw, 4.3rem);
    line-height: 1.01;
  }

  .page-solutions .jas-solutions-hero-description {
    font-size: 1.02rem;
    line-height: 1.78;
  }

  .page-solutions .jas-solutions-challenges-section,
  .page-solutions .jas-solutions-architecture-section,
  .page-solutions .jas-solutions-route-section,
  .page-solutions .jas-solutions-cta-section {
    padding-top: 90px;
    padding-bottom: 90px;
  }

  .page-solutions .jas-solutions-scenario-row {
    padding: 82px 0;
  }

  .page-solutions .jas-solutions-architecture-core {
    min-height: auto;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
  }

  .page-solutions .jas-solutions-architecture-core::before {
    display: none;
  }

  .page-solutions .jas-solutions-core-center,
  .page-solutions .jas-solutions-core-node {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    bottom: auto;
    transform: none;
    width: 100%;
    min-height: 220px;
  }

  .page-solutions .jas-solutions-core-center {
    grid-column: span 2;
    border-radius: 32px;
    min-height: 260px;
  }

  .page-solutions .jas-solutions-route-line {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  .page-solutions .jas-solutions-hero-section {
    min-height: auto;
  }

  .page-solutions .jas-solutions-hero-overlay {
    background:
      linear-gradient(180deg, rgba(7, 22, 36, 0.84) 0%, rgba(7, 22, 36, 0.66) 50%, rgba(7, 22, 36, 0.46) 100%),
      radial-gradient(circle at 80% 25%, rgba(27, 167, 216, 0.12), transparent 28%);
  }

  .page-solutions .jas-solutions-hero-actions,
  .page-solutions .jas-solutions-cta-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .page-solutions .jas-solutions-hero-btn-primary,
  .page-solutions .jas-solutions-hero-btn-secondary,
  .page-solutions .jas-btn-primary,
  .page-solutions .jas-btn-secondary {
    width: 100%;
    min-width: 100%;
  }

  .page-solutions .jas-solutions-floating-grid {
    grid-template-columns: 1fr;
  }

  .page-solutions .jas-solutions-floating-card--lg {
    grid-column: span 1;
  }

  .page-solutions .jas-solutions-challenges-grid {
    grid-template-columns: 1fr;
  }

  .page-solutions .jas-solutions-challenge-card--wide {
    grid-column: span 1;
  }

  .page-solutions .jas-solutions-architecture-core {
    grid-template-columns: 1fr;
  }

  .page-solutions .jas-solutions-core-center {
    grid-column: span 1;
  }

  .page-solutions .jas-solutions-route-line {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 575.98px) {
  .page-solutions .jas-solutions-section-label {
    gap: 10px;
    margin-bottom: 14px;
    font-size: 0.84rem;
    letter-spacing: 0.13em;
  }

  .page-solutions .jas-solutions-section-label::before,
  .page-solutions .jas-solutions-section-label::after {
    width: 28px;
  }

  .page-solutions .jas-solutions-section-title {
    font-size: 2rem;
    line-height: 1.05;
    margin-bottom: 16px;
  }

  .page-solutions .jas-solutions-section-intro,
  .page-solutions .jas-solutions-section-text {
    font-size: 0.98rem;
    line-height: 1.76;
  }

  .page-solutions .jas-solutions-hero-layout {
    padding: 126px 0 74px;
  }

  .page-solutions .jas-solutions-hero-title {
    font-size: 2.18rem;
    line-height: 1.03;
  }

  .page-solutions .jas-solutions-hero-description {
    font-size: 0.97rem;
    line-height: 1.74;
  }

  .page-solutions .jas-solutions-floating-card,
  .page-solutions .jas-solutions-challenge-card,
  .page-solutions .jas-solutions-core-node,
  .page-solutions .jas-solutions-scenario-card {
    border-radius: 22px;
  }

  .page-solutions .jas-solutions-floating-card--lg {
    min-height: auto;
    padding: 24px 20px;
  }

  .page-solutions .jas-solutions-floating-card--lg h3 {
    font-size: 1.26rem;
  }

  .page-solutions .jas-solutions-challenge-card,
  .page-solutions .jas-solutions-scenario-card {
    padding: 24px 20px;
    min-height: auto;
  }

  .page-solutions .jas-solutions-core-center {
    min-height: auto;
    padding: 28px 22px;
    border-radius: 26px;
  }

  .page-solutions .jas-solutions-core-center h3 {
    font-size: 1.58rem;
  }

  .page-solutions .jas-solutions-core-node {
    min-height: 140px;
    padding: 18px 14px;
  }

  .page-solutions .jas-solutions-scenario-card h3 {
    font-size: 1.24rem;
  }

  .page-solutions .jas-solutions-route-number {
    width: 62px;
    height: 62px;
    margin-bottom: 16px;
  }

  .page-solutions .jas-solutions-route-step h3 {
    font-size: 1.04rem;
  }

  .page-solutions .jas-solutions-cta-label {
    gap: 12px;
    margin-bottom: 18px;
    font-size: 0.84rem;
    letter-spacing: 0.14em;
  }

  .page-solutions .jas-solutions-cta-label::before,
  .page-solutions .jas-solutions-cta-label::after {
    width: 34px;
  }

  .page-solutions .jas-solutions-cta-title {
    font-size: 2.12rem;
    line-height: 1.04;
    margin-bottom: 18px;
  }

  .page-solutions .jas-solutions-cta-text {
    font-size: 0.98rem;
    line-height: 1.74;
    margin-bottom: 28px;
  }
}

/* ============================================== */
/* NAVBAR REVEAL ON HOVER - SOLO DESKTOP          */
/* ============================================== */

.page-solutions .jas-navbar:not(.scrolled) .nav-link {
  color: #EDF4F8 !important;
}

.page-solutions .jas-navbar:not(.scrolled) .nav-link:hover,
.page-solutions .jas-navbar:not(.scrolled) .nav-link:focus {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.08);
}

/* ===================================================*/
/* CAMBIO DE LOGO SEGÚN EL FONDO DEL IMAGEN DEL HERO */
/* ===================================================*/
.page-solutions .jas-navbar:not(.scrolled) .jas-brand img {
  content: url("../images/logo/jas-logo-horizontal-light.png");
}

/* =========================================================
   DESAFÍOS QUE RESOLVEMOS - CARRUSEL PREMIUM
   REEMPLAZA EL BLOQUE GRID ANTERIOR
========================================================= */

.page-solutions .jas-solutions-challenges-section {
  padding: 110px 0 95px;
  background:
    linear-gradient(180deg, #f7fbfd 0%, #ffffff 34%, #f7fbfd 100%);
}

.page-solutions .jas-solutions-challenges-carousel {
  position: relative;
  margin-top: 10px;
}

.page-solutions .jas-solutions-challenges-viewport {
  position: relative;
  overflow: hidden;
  padding: 8px 0 18px;
}

.page-solutions .jas-solutions-challenges-track {
  display: flex;
  gap: 24px;
  align-items: stretch;
  will-change: transform;
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

.page-solutions .jas-solutions-challenge-slide {
  flex: 0 0 calc(33.333% - 16px);
  min-width: 0;
  opacity: 0.78;
  transform: scale(0.96);
  transition:
    opacity 0.45s ease,
    transform 0.45s ease;
}

.page-solutions .jas-solutions-challenge-slide.is-active {
  opacity: 1;
  transform: scale(1);
}

.page-solutions .jas-solutions-challenge-card {
  position: relative;
  height: 100%;
  min-height: 340px;
  padding: 28px 26px 28px;
  border-radius: 30px;
  background: #ffffff;
  border: 1px solid rgba(21, 107, 154, 0.08);
  box-shadow: 0 18px 36px rgba(15, 53, 84, 0.06);
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease,
    border-color 0.3s ease;
}

.page-solutions .jas-solutions-challenge-card:hover {
  transform: translateY(-6px);
  border-color: rgba(27, 167, 216, 0.18);
  box-shadow: 0 26px 44px rgba(15, 53, 84, 0.12);
}

.page-solutions .jas-solutions-challenge-card--accent {
  background: linear-gradient(180deg, #edf6fa 0%, #f8fbfd 100%);
}

.page-solutions .jas-solutions-challenge-meta {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 18px;
}

.page-solutions .jas-solutions-challenge-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 52px;
  height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: #edf4f8;
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: #156b9a;
}

.page-solutions .jas-solutions-challenge-icon {
  width: 66px;
  height: 66px;
  margin-bottom: 20px;
  border-radius: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #156b9a 0%, #0f3554 100%);
  color: #ffffff;
  font-size: 1.35rem;
  box-shadow: 0 14px 26px rgba(15, 53, 84, 0.14);
}

.page-solutions .jas-solutions-challenge-card h3 {
  margin: 0 0 14px;
  font-size: 1.28rem;
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: -0.025em;
  color: #17324d;
}

.page-solutions .jas-solutions-challenge-card p {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.76;
  color: #5e7488;
}

/* CONTROLES */

.page-solutions .jas-solutions-challenges-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  margin-top: 26px;
}

.page-solutions .jas-solutions-challenges-arrow {
  width: 54px;
  height: 54px;
  border: 0;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #ffffff;
  color: #17324d;
  box-shadow: 0 14px 28px rgba(15, 53, 84, 0.08);
  border: 1px solid rgba(21, 107, 154, 0.08);
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease,
    background 0.3s ease,
    color 0.3s ease;
}

.page-solutions .jas-solutions-challenges-arrow:hover {
  transform: translateY(-2px);
  background: linear-gradient(180deg, #156b9a 0%, #0f3554 100%);
  color: #ffffff;
  box-shadow: 0 18px 32px rgba(15, 53, 84, 0.16);
}

.page-solutions .jas-solutions-challenges-arrow i {
  font-size: 1rem;
  line-height: 1;
}

.page-solutions .jas-solutions-challenges-progress {
  position: relative;
  width: min(320px, 42vw);
  height: 8px;
  border-radius: 999px;
  background: rgba(21, 107, 154, 0.10);
  overflow: hidden;
}

.page-solutions .jas-solutions-challenges-progress-bar {
  display: block;
  width: 18%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #1ba7d8 0%, #156b9a 100%);
  box-shadow: 0 0 14px rgba(27, 167, 216, 0.18);
  transition: width 0.45s ease, transform 0.45s ease;
}

/* ESTADO CON FOCUS */

.page-solutions .jas-solutions-challenges-arrow:focus-visible {
  outline: 2px solid rgba(27, 167, 216, 0.55);
  outline-offset: 3px;
}

/* RESPONSIVE */

@media (max-width: 1199.98px) {
  .page-solutions .jas-solutions-challenge-slide {
    flex: 0 0 calc(50% - 12px);
  }

  .page-solutions .jas-solutions-challenge-card {
    min-height: 320px;
  }
}

@media (max-width: 767.98px) {
  .page-solutions .jas-solutions-challenges-section {
    padding: 90px 0 82px;
  }

  .page-solutions .jas-solutions-challenges-track {
    gap: 18px;
  }

  .page-solutions .jas-solutions-challenge-slide {
    flex: 0 0 100%;
    opacity: 1;
    transform: none;
  }

  .page-solutions .jas-solutions-challenge-card {
    min-height: auto;
    border-radius: 24px;
    padding: 24px 20px;
  }

  .page-solutions .jas-solutions-challenge-icon {
    width: 60px;
    height: 60px;
    border-radius: 18px;
    font-size: 1.2rem;
  }

  .page-solutions .jas-solutions-challenge-card h3 {
    font-size: 1.18rem;
    line-height: 1.14;
  }

  .page-solutions .jas-solutions-challenge-card p {
    font-size: 0.96rem;
    line-height: 1.72;
  }

  .page-solutions .jas-solutions-challenges-controls {
    gap: 14px;
    margin-top: 22px;
  }

  .page-solutions .jas-solutions-challenges-arrow {
    width: 48px;
    height: 48px;
  }

  .page-solutions .jas-solutions-challenges-progress {
    width: min(180px, 42vw);
    height: 7px;
  }
}

@media (max-width: 575.98px) {
  .page-solutions .jas-solutions-challenge-number {
    min-width: 46px;
    height: 34px;
    font-size: 0.82rem;
  }

  .page-solutions .jas-solutions-challenge-card {
    padding: 22px 18px;
  }
}

/* =========================================
   LÍNEAS DE CONEXIÓN - ARQUITECTURA
========================================= */

.page-solutions .jas-solutions-architecture-core {
  position: relative;
}

.page-solutions .jas-solutions-architecture-lines {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}

.page-solutions .jas-solutions-architecture-lines path {
  fill: none;
  stroke: rgba(27, 167, 216, 0.28);
  stroke-width: 2.2;
  stroke-linecap: round;
  filter: drop-shadow(0 0 8px rgba(27, 167, 216, 0.16));
  stroke-dasharray: 8 10;
  animation: jasFlowLine 7s linear infinite;
}

/* para que centro y nodos queden sobre las líneas */
.page-solutions .jas-solutions-core-center,
.page-solutions .jas-solutions-core-node {
  position: absolute;
  z-index: 2;
}

/* brillo extra del núcleo */
.page-solutions .jas-solutions-core-center::before {
  content: "";
  position: absolute;
  inset: -18px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(27, 167, 216, 0.12) 0%, transparent 68%);
  z-index: -1;
}

/* punto glow en nodos */
.page-solutions .jas-solutions-core-node::after {
  content: "";
  position: absolute;
  top: 14px;
  right: 14px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #1BA7D8;
  box-shadow: 0 0 0 6px rgba(27, 167, 216, 0.12);
}

/* animación suave de flujo */
@keyframes jasFlowLine {
  from {
    stroke-dashoffset: 0;
  }
  to {
    stroke-dashoffset: -72;
  }
}

/* en tablet/móvil mejor ocultarlas */
@media (max-width: 991.98px) {
  .page-solutions .jas-solutions-architecture-lines {
    display: none;
  }
}

/* =========================================
   HOVER PREMIUM PARA ESCENARIOS DE SOLUCIÓN
   MISMA LÍNEA QUE SERVICIOS
========================================= */

.page-solutions .jas-solutions-scenario-card {
  overflow: hidden;
  transition:
    transform 0.42s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.42s cubic-bezier(0.22, 1, 0.36, 1),
    border-color 0.42s ease,
    background 0.42s ease;
  will-change: transform, box-shadow;
}

/* glow superior/izquierdo */
.page-solutions .jas-solutions-scenario-card::before {
  content: "";
  position: absolute;
  top: -90px;
  left: -90px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background:
    radial-gradient(circle,
      rgba(27, 167, 216, 0.30) 0%,
      rgba(21, 107, 154, 0.18) 38%,
      rgba(15, 53, 84, 0.00) 72%);
  transform: scale(0.75);
  opacity: 0;
  transition:
    transform 0.52s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.42s ease;
  pointer-events: none;
  z-index: 0;
}

/* línea inferior reveal */
.page-solutions .jas-solutions-scenario-card::after {
  content: "";
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 0;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 55%, transparent 100%);
  transform: scaleX(0.15);
  transform-origin: left center;
  opacity: 0;
  transition:
    transform 0.42s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.32s ease;
  pointer-events: none;
  z-index: 1;
}

.page-solutions .jas-solutions-scenario-card:hover {
  transform: translateY(-10px) scale(1.015);
  box-shadow: 0 24px 48px rgba(15, 53, 84, 0.18);
}

.page-solutions .jas-solutions-scenario-card:hover::before {
  transform: scale(1.28);
  opacity: 1;
}

.page-solutions .jas-solutions-scenario-card:hover::after {
  transform: scaleX(1);
  opacity: 1;
}

/* contenido encima del efecto */
.page-solutions .jas-solutions-scenario-card > * {
  position: relative;
  z-index: 2;
}

/* textos con micro movimiento */
.page-solutions .jas-solutions-scenario-card h3,
.page-solutions .jas-solutions-scenario-card p,
.page-solutions .jas-solutions-scenario-card .jas-solutions-scenario-card-kicker {
  transition:
    transform 0.36s ease,
    color 0.36s ease,
    opacity 0.36s ease;
}

.page-solutions .jas-solutions-scenario-card:hover h3,
.page-solutions .jas-solutions-scenario-card:hover .jas-solutions-scenario-card-kicker {
  transform: translateY(-2px);
}

.page-solutions .jas-solutions-scenario-card:hover p {
  transform: translateY(-1px);
}

/* card claro */
.page-solutions .jas-solutions-scenario-card:hover {
  border-color: rgba(27, 167, 216, 0.20);
}

/* card oscuro */
.page-solutions .jas-solutions-scenario-card--dark::before {
  background:
    radial-gradient(circle,
      rgba(27, 167, 216, 0.34) 0%,
      rgba(21, 107, 154, 0.22) 36%,
      rgba(15, 53, 84, 0.02) 72%);
}

.page-solutions .jas-solutions-scenario-card--dark:hover {
  box-shadow: 0 26px 52px rgba(8, 26, 43, 0.28);
}

.page-solutions .jas-solutions-scenario-card--dark:hover h3 {
  color: #ffffff;
}

.page-solutions .jas-solutions-scenario-card--dark:hover p {
  color: rgba(255, 255, 255, 0.88);
}

/* móvil */
@media (max-width: 767.98px) {
  .page-solutions .jas-solutions-scenario-card:hover {
    transform: translateY(-6px) scale(1.01);
  }
}

/* =========================================
   HOVER PARA NÚMEROS DE LA RUTA
========================================= */

.page-solutions .jas-solutions-route-step {
  transition: transform 0.32s ease;
}

.page-solutions .jas-solutions-route-number {
  position: relative;
  transition:
    transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.35s ease,
    background 0.35s ease;
  overflow: visible;
}

/* halo exterior */
.page-solutions .jas-solutions-route-number::before {
  content: "";
  position: absolute;
  inset: -10px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(27, 167, 216, 0.18) 0%, transparent 68%);
  opacity: 0;
  transform: scale(0.8);
  transition:
    opacity 0.35s ease,
    transform 0.35s ease;
  z-index: -1;
}

/* brillo puntual */
.page-solutions .jas-solutions-route-number::after {
  content: "";
  position: absolute;
  top: 10px;
  right: 12px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.9);
  opacity: 0;
  box-shadow: 0 0 12px rgba(255, 255, 255, 0.35);
  transition:
    opacity 0.3s ease,
    transform 0.3s ease;
  transform: scale(0.7);
}

/* hover del bloque completo */
.page-solutions .jas-solutions-route-step:hover {
  transform: translateY(-4px);
}

.page-solutions .jas-solutions-route-step:hover .jas-solutions-route-number {
  transform: translateY(-6px) scale(1.08);
  background: linear-gradient(180deg, #1BA7D8 0%, #0F3554 100%);
  box-shadow:
    0 20px 34px rgba(15, 53, 84, 0.20),
    0 0 0 8px rgba(27, 167, 216, 0.08);
}

.page-solutions .jas-solutions-route-step:hover .jas-solutions-route-number::before {
  opacity: 1;
  transform: scale(1);
}

.page-solutions .jas-solutions-route-step:hover .jas-solutions-route-number::after {
  opacity: 1;
  transform: scale(1);
}

/* pequeño efecto también al título */
.page-solutions .jas-solutions-route-step h3,
.page-solutions .jas-solutions-route-step p {
  transition: transform 0.3s ease, color 0.3s ease;
}

.page-solutions .jas-solutions-route-step:hover h3 {
  transform: translateY(-2px);
}

.page-solutions .jas-solutions-route-step:hover p {
  transform: translateY(-1px);
}

/* móvil: más suave */
@media (max-width: 767.98px) {
  .page-solutions .jas-solutions-route-step:hover {
    transform: translateY(-2px);
  }

  .page-solutions .jas-solutions-route-step:hover .jas-solutions-route-number {
    transform: translateY(-3px) scale(1.05);
  }
}

/* =========================================================
   CONTACTO - JAS SOLUTIONS
   BLOQUE COMPLETO
========================================================= */

.page-contact .jas-contact-hero-section,
.page-contact .jas-contact-main-section,
.page-contact .jas-contact-info-section {
  position: relative;
  overflow: hidden;
}

/* =========================================================
   TEXTOS BASE
========================================================= */

.page-contact .jas-contact-section-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #1BA7D8;
}

.page-contact .jas-contact-section-label::before {
  content: "";
  width: 40px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #156B9A 100%);
}

.page-contact .jas-contact-section-title {
  margin: 0 0 18px;
  font-size: clamp(2.15rem, 3.8vw, 3.6rem);
  line-height: 1.03;
  font-weight: 800;
  letter-spacing: -0.035em;
  color: #17324D;
}

.page-contact .jas-contact-section-text,
.page-contact .jas-contact-section-intro {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.85;
  color: #5E7488;
}

.page-contact .jas-contact-section-text--lead {
  max-width: 560px;
  font-size: 1.04rem;
  line-height: 1.8;
  color: #5E7488;
}

/* =========================================================
   HERO
========================================================= */

.page-contact .jas-contact-hero-section {
  min-height: 85vh;
  display: flex;
  align-items: flex-end;
  background: #0F3554;
  padding: 190px 0 95px;
  height: 800px;
}

.page-contact .jas-contact-hero-media,
.page-contact .jas-contact-hero-overlay {
  position: absolute;
  inset: 0;
}

.page-contact .jas-contact-hero-bg-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top !important;
  display: block;
}

.page-contact .jas-contact-hero-overlay {
  background:
    linear-gradient(180deg, rgba(7, 22, 36, 0.28) 0%, rgba(7, 22, 36, 0.42) 42%, rgba(7, 22, 36, 0.82) 100%),
    radial-gradient(circle at 50% 72%, rgba(27, 167, 216, 0.10), transparent 34%);
  z-index: 1;
}

.page-contact .jas-contact-hero-container {
  position: relative;
  z-index: 2;
}

.page-contact .jas-contact-hero-inner {
  max-width: 980px;
  margin: 0 auto -35px;
  padding: 40px 0 0px;
  text-align: center;
}

.page-contact .jas-contact-hero-label {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #9FE5F8;
}

.page-contact .jas-contact-hero-label::before,
.page-contact .jas-contact-hero-label::after {
  content: "";
  width: 46px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #1BA7D8 0%, #9FE5F8 100%);
}

.page-contact .jas-contact-hero-title {
  margin: 0;
  font-size: 58.5px;
  line-height: 0.98;
  font-weight: 800;
  letter-spacing: -0.05em;
  color: #EDF4F8;
}

/* =========================================================
   BLOQUE PRINCIPAL
========================================================= */

.page-contact .jas-contact-main-section {
  padding: 82px 0 76px;
  background: linear-gradient(180deg, #F7FBFD 0%, #FFFFFF 42%, #F7FBFD 100%);
}

.page-contact .jas-contact-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(520px, 620px);
  gap: 46px;
  align-items: start;
}

/* -----------------------------------------
   COLUMNA IZQUIERDA
----------------------------------------- */

.page-contact .jas-contact-main-copy {
  max-width: 620px;
}

.page-contact .jas-contact-main-points {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
  margin-bottom: 24px;
}

.page-contact .jas-contact-main-points span {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  border-radius: 999px;
  background: #EDF4F8;
  border: 1px solid rgba(21, 107, 154, 0.08);
  font-size: 0.95rem;
  font-weight: 600;
  color: #4F6579;
}

.page-contact .jas-contact-main-points i {
  color: #1BA7D8;
}

.page-contact .jas-contact-main-image {
  border-radius: 28px;
  overflow: hidden;
  background: #EAF4F8;
  border: 1px solid rgba(21, 107, 154, 0.08);
  box-shadow: 0 20px 40px rgba(15, 53, 84, 0.08);
  margin-top: 23px;
}

.page-contact .jas-contact-main-image img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* -----------------------------------------
   FORMULARIO
----------------------------------------- */

.page-contact .jas-contact-form-wrap {
  position: relative;
}

.page-contact .jas-contact-form-card {
  padding: 34px 32px 30px;
  border-radius: 32px;
  background: #FFFFFF;
  border: 1px solid rgba(21, 107, 154, 0.08);
  box-shadow: 0 24px 46px rgba(15, 53, 84, 0.08);
}

.page-contact .jas-contact-form-head {
  margin-bottom: 22px;
}

.page-contact .jas-contact-form-kicker {
  display: inline-block;
  margin-bottom: 8px;
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #1BA7D8;
}

.page-contact .jas-contact-form-head h3 {
  margin: 0;
  font-size: 1.7rem;
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #17324D;
}

.page-contact .jas-contact-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.page-contact .jas-contact-field {
  min-width: 0;
}

.page-contact .jas-contact-field--full {
  grid-column: 1 / -1;
}

.page-contact .jas-contact-form .form-control {
  width: 100%;
  min-height: 62px;
  padding: 15px 18px;
  border-radius: 18px;
  border: 1px solid rgba(21, 107, 154, 0.14);
  background: #F9FCFE;
  color: #17324D;
  font-size: 1rem;
  box-shadow: none;
  transition:
    border-color 0.25s ease,
    box-shadow 0.25s ease,
    background 0.25s ease,
    transform 0.25s ease;
}

.page-contact .jas-contact-form textarea.form-control {
  min-height: 170px;
  resize: vertical;
}

.page-contact .jas-contact-form .form-control::placeholder {
  color: #8AA0B4;
}

.page-contact .jas-contact-form .form-control:focus {
  border-color: rgba(27, 167, 216, 0.42);
  background: #FFFFFF;
  box-shadow: 0 0 0 5px rgba(27, 167, 216, 0.10);
  transform: translateY(-1px);
}

.page-contact .jas-contact-form-footer {
  margin-top: 18px;
}

.page-contact .jas-contact-submit-btn {
  width: 100%;
  min-height: 62px;
  border: 0;
  border-radius: 18px;
  padding: 16px 24px;
  background: linear-gradient(90deg, #0F3554 0%, #1BA7D8 100%);
  color: #FFFFFF;
  font-size: 1.04rem;
  font-weight: 700;
  box-shadow: 0 16px 32px rgba(15, 53, 84, 0.18);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.page-contact .jas-contact-submit-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 22px 38px rgba(15, 53, 84, 0.24);
}

/* =========================================================
   INFORMACIÓN DE CONTACTO
========================================================= */

.page-contact .jas-contact-info-section {
  padding: 54px 0 92px;
  background: #FFFFFF;
}

.page-contact .jas-contact-info-header {
  max-width: 960px;
  margin: 0 auto 28px;
  text-align: center;
}

.page-contact .jas-contact-info-header .jas-contact-section-label {
  justify-content: center;
}

.page-contact .jas-contact-info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.page-contact .jas-contact-info-link {
  text-decoration: none;
}

.page-contact .jas-contact-info-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 24px 22px;
  border-radius: 24px;
  background: linear-gradient(180deg, #F8FBFD 0%, #EDF5F9 100%);
  border: 1px solid rgba(21, 107, 154, 0.08);
  box-shadow: 0 16px 30px rgba(15, 53, 84, 0.05);
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease,
    border-color 0.3s ease,
    background 0.3s ease;
}

.page-contact .jas-contact-info-card:hover {
  transform: translateY(-6px);
  border-color: rgba(27, 167, 216, 0.16);
  box-shadow: 0 24px 40px rgba(15, 53, 84, 0.10);
  background: #FFFFFF;
}

.page-contact .jas-contact-info-icon {
  width: 58px;
  height: 58px;
  min-width: 58px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #156B9A 0%, #0F3554 100%);
  color: #FFFFFF;
  font-size: 1.2rem;
  box-shadow: 0 14px 26px rgba(15, 53, 84, 0.14);
}

.page-contact .jas-contact-info-content h3 {
  margin: 0 0 6px;
  font-size: 1.08rem;
  line-height: 1.15;
  font-weight: 800;
  color: #17324D;
}

.page-contact .jas-contact-info-content p {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.6;
  color: #5E7488;
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width: 1199.98px) {
  .page-contact .jas-contact-main-grid {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .page-contact .jas-contact-main-copy {
    max-width: 100%;
  }

  .page-contact .jas-contact-info-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 991.98px) {
  .page-contact .jas-contact-hero-section {
    min-height: 62vh;
  }

  .page-contact .jas-contact-hero-inner {
    padding: 145px 0 60px;
  }

  .page-contact .jas-contact-hero-title {
    font-size: clamp(2.25rem, 7vw, 4rem);
    line-height: 1.02;
  }
}

@media (max-width: 767.98px) {
  .page-contact .jas-contact-hero-section {
    min-height: 56vh;
  }

  .page-contact .jas-contact-hero-overlay {
    background:
      linear-gradient(180deg, rgba(7, 22, 36, 0.28) 0%, rgba(7, 22, 36, 0.42) 40%, rgba(7, 22, 36, 0.82) 100%);
  }

  .page-contact .jas-contact-hero-inner {
    padding: 132px 0 54px;
  }

  .page-contact .jas-contact-form-grid {
    grid-template-columns: 1fr;
  }

  .page-contact .jas-contact-form-card,
  .page-contact .jas-contact-main-image,
  .page-contact .jas-contact-info-card {
    border-radius: 22px;
  }
}

@media (max-width: 575.98px) {
  .page-contact .jas-contact-section-label {
    gap: 10px;
    margin-bottom: 14px;
    font-size: 0.84rem;
    letter-spacing: 0.13em;
  }

  .page-contact .jas-contact-section-label::before {
    width: 28px;
  }

  .page-contact .jas-contact-section-title {
    font-size: 2rem;
    line-height: 1.05;
    margin-bottom: 16px;
  }

  .page-contact .jas-contact-section-text,
  .page-contact .jas-contact-section-intro,
  .page-contact .jas-contact-section-text--lead {
    font-size: 0.98rem;
    line-height: 1.76;
  }

  .page-contact .jas-contact-hero-label {
    gap: 10px;
    margin-bottom: 14px;
    font-size: 0.84rem;
    letter-spacing: 0.14em;
  }

  .page-contact .jas-contact-hero-label::before,
  .page-contact .jas-contact-hero-label::after {
    width: 32px;
  }

  .page-contact .jas-contact-hero-title {
    font-size: 2.1rem;
    line-height: 1.04;
  }

  .page-contact .jas-contact-main-section {
    padding: 72px 0 68px;
  }

  .page-contact .jas-contact-form-card {
    padding: 24px 18px 22px;
  }

  .page-contact .jas-contact-form-head h3 {
    font-size: 1.38rem;
  }

  .page-contact .jas-contact-main-points {
    flex-direction: column;
    align-items: stretch;
  }

  .page-contact .jas-contact-main-points span {
    justify-content: center;
    text-align: center;
  }
}

/* ============================================== */
/* NAVBAR REVEAL ON HOVER - SOLO DESKTOP          */
/* ============================================== */

.page-contact .jas-navbar:not(.scrolled) .nav-link {
  color: #EDF4F8 !important;
}

.page-contact .jas-navbar:not(.scrolled) .nav-link:hover,
.page-contact .jas-navbar:not(.scrolled) .nav-link:focus {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.08);
}

/* ===================================================*/
/* CAMBIO DE LOGO SEGÚN EL FONDO DEL IMAGEN DEL HERO */
/* ===================================================*/
.page-contact .jas-navbar:not(.scrolled) .jas-brand img {
  content: url("../images/logo/jas-logo-horizontal-light.png");
}

.jas-contact-form input,
.jas-contact-form textarea {
  font-family: 'Montserrat', sans-serif;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0;
}

.jas-contact-form input::placeholder,
.jas-contact-form textarea::placeholder {
  font-family: 'Montserrat', sans-serif;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0;
  color: #8aa0b5;
}

.jas-contact-form select.form-control {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  cursor: pointer;
}